|
@ -1,6 +1,8 @@ |
|
|
package mount |
|
|
package mount |
|
|
|
|
|
|
|
|
import ( |
|
|
import ( |
|
|
|
|
|
"golang.org/x/sync/semaphore" |
|
|
|
|
|
"math" |
|
|
"sync" |
|
|
"sync" |
|
|
|
|
|
|
|
|
"golang.org/x/exp/slices" |
|
|
"golang.org/x/exp/slices" |
|
@ -28,17 +30,18 @@ type FileHandle struct { |
|
|
reader *filer.ChunkReadAt |
|
|
reader *filer.ChunkReadAt |
|
|
contentType string |
|
|
contentType string |
|
|
handle uint64 |
|
|
handle uint64 |
|
|
sync.Mutex |
|
|
|
|
|
|
|
|
orderedMutex *semaphore.Weighted |
|
|
|
|
|
|
|
|
isDeleted bool |
|
|
isDeleted bool |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func newFileHandle(wfs *WFS, handleId FileHandleId, inode uint64, entry *filer_pb.Entry) *FileHandle { |
|
|
func newFileHandle(wfs *WFS, handleId FileHandleId, inode uint64, entry *filer_pb.Entry) *FileHandle { |
|
|
fh := &FileHandle{ |
|
|
fh := &FileHandle{ |
|
|
fh: handleId, |
|
|
|
|
|
counter: 1, |
|
|
|
|
|
inode: inode, |
|
|
|
|
|
wfs: wfs, |
|
|
|
|
|
|
|
|
fh: handleId, |
|
|
|
|
|
counter: 1, |
|
|
|
|
|
inode: inode, |
|
|
|
|
|
wfs: wfs, |
|
|
|
|
|
orderedMutex: semaphore.NewWeighted(int64(math.MaxInt64)), |
|
|
} |
|
|
} |
|
|
// dirtyPages: newContinuousDirtyPages(file, writeOnly),
|
|
|
// dirtyPages: newContinuousDirtyPages(file, writeOnly),
|
|
|
fh.dirtyPages = newPageWriter(fh, wfs.option.ChunkSizeLimit) |
|
|
fh.dirtyPages = newPageWriter(fh, wfs.option.ChunkSizeLimit) |
|
|