|
@ -106,7 +106,7 @@ func (c *ChunkReadAt) ReadAt(p []byte, offset int64) (n int, err error) { |
|
|
c.readerLock.Lock() |
|
|
c.readerLock.Lock() |
|
|
defer c.readerLock.Unlock() |
|
|
defer c.readerLock.Unlock() |
|
|
|
|
|
|
|
|
glog.V(4).Infof("ReadAt [%d,%d) of total file size %d bytes %d chunk views", offset, offset+int64(len(p)), c.fileSize, len(c.chunkViews)) |
|
|
|
|
|
|
|
|
// glog.V(4).Infof("ReadAt [%d,%d) of total file size %d bytes %d chunk views", offset, offset+int64(len(p)), c.fileSize, len(c.chunkViews))
|
|
|
return c.doReadAt(p, offset) |
|
|
return c.doReadAt(p, offset) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -137,7 +137,7 @@ func (c *ChunkReadAt) doReadAt(p []byte, offset int64) (n int, err error) { |
|
|
if chunkStart >= chunkStop { |
|
|
if chunkStart >= chunkStop { |
|
|
continue |
|
|
continue |
|
|
} |
|
|
} |
|
|
glog.V(4).Infof("read [%d,%d), %d/%d chunk %s [%d,%d)", chunkStart, chunkStop, i, len(c.chunkViews), chunk.FileId, chunk.LogicOffset-chunk.Offset, chunk.LogicOffset-chunk.Offset+int64(chunk.Size)) |
|
|
|
|
|
|
|
|
// glog.V(4).Infof("read [%d,%d), %d/%d chunk %s [%d,%d)", chunkStart, chunkStop, i, len(c.chunkViews), chunk.FileId, chunk.LogicOffset-chunk.Offset, chunk.LogicOffset-chunk.Offset+int64(chunk.Size))
|
|
|
var buffer []byte |
|
|
var buffer []byte |
|
|
bufferOffset := chunkStart - chunk.LogicOffset + chunk.Offset |
|
|
bufferOffset := chunkStart - chunk.LogicOffset + chunk.Offset |
|
|
bufferLength := chunkStop - chunkStart |
|
|
bufferLength := chunkStop - chunkStart |
|
@ -152,7 +152,7 @@ func (c *ChunkReadAt) doReadAt(p []byte, offset int64) (n int, err error) { |
|
|
startOffset, remaining = startOffset+int64(copied), remaining-int64(copied) |
|
|
startOffset, remaining = startOffset+int64(copied), remaining-int64(copied) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
glog.V(4).Infof("doReadAt [%d,%d), n:%v, err:%v", offset, offset+int64(len(p)), n, err) |
|
|
|
|
|
|
|
|
// glog.V(4).Infof("doReadAt [%d,%d), n:%v, err:%v", offset, offset+int64(len(p)), n, err)
|
|
|
|
|
|
|
|
|
if err == nil && remaining > 0 && c.fileSize > startOffset { |
|
|
if err == nil && remaining > 0 && c.fileSize > startOffset { |
|
|
delta := int(min(remaining, c.fileSize-startOffset)) |
|
|
delta := int(min(remaining, c.fileSize-startOffset)) |
|
|