Commit 8412ede0 authored by Jakob Unterwurzacher's avatar Jakob Unterwurzacher Committed by Han-Wen Nienhuys

nodefs: drop unused fields from Inode struct

Reduces Sizeof(nodefs.Inode{}) from 112 to 96 bytes.

The "generation" field in "Inode" is not used anywhere.
"portableHandleMap" has it's own generation field, which
is actually used.

The "check" field, embedded through the "handled" struct,
is checked for zero, but never set.

This is part of an effort to reduce the memory usage of go-fuse
and gocryptfs. Details can be seen at
https://github.com/rfjakob/gocryptfs/issues/132 .
parent 204b45db
...@@ -35,7 +35,6 @@ type handleMap interface { ...@@ -35,7 +35,6 @@ type handleMap interface {
} }
type handled struct { type handled struct {
check uint32
handle uint64 handle uint64
count int count int
} }
...@@ -77,10 +76,6 @@ func newPortableHandleMap() *portableHandleMap { ...@@ -77,10 +76,6 @@ func newPortableHandleMap() *portableHandleMap {
func (m *portableHandleMap) Register(obj *handled) (handle, generation uint64) { func (m *portableHandleMap) Register(obj *handled) (handle, generation uint64) {
m.Lock() m.Lock()
if obj.count == 0 { if obj.count == 0 {
if obj.check != 0 {
panic(_ALREADY_MSG)
}
if len(m.freeIds) == 0 { if len(m.freeIds) == 0 {
handle = uint64(len(m.handles)) handle = uint64(len(m.handles))
m.handles = append(m.handles, obj) m.handles = append(m.handles, obj)
......
...@@ -90,9 +90,6 @@ func TestHandleMapBasic(t *testing.T) { ...@@ -90,9 +90,6 @@ func TestHandleMapBasic(t *testing.T) {
if hm.Has(h) { if hm.Has(h) {
t.Fatal("Still has handle") t.Fatal("Still has handle")
} }
if v.check != 0 {
t.Errorf("forgotten object still has a check.")
}
} }
func TestHandleMapMultiple(t *testing.T) { func TestHandleMapMultiple(t *testing.T) {
......
...@@ -24,10 +24,6 @@ type parentData struct { ...@@ -24,10 +24,6 @@ type parentData struct {
type Inode struct { type Inode struct {
handled handled handled handled
// Generation number of the inode. Each (re)use of an inode
// should have a unique generation number.
generation uint64
// Number of open files and its protection. // Number of open files and its protection.
openFilesMutex sync.Mutex openFilesMutex sync.Mutex
openFiles []*openedFile openFiles []*openedFile
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment