diff options
| author | Luke Shumaker <lukeshu@lukeshu.com> | 2022-06-05 18:38:31 -0600 | 
|---|---|---|
| committer | Luke Shumaker <lukeshu@lukeshu.com> | 2022-06-05 18:38:31 -0600 | 
| commit | ba2e78f4b59db9fe8bd5bdaf26996b71dfc05e83 (patch) | |
| tree | d4d86235ba3aa961724610bd100d61cd5a124d2a /pkg/btrfs | |
| parent | 7ef276daaa132683ff8b04004f1ce5c992097d14 (diff) | |
factor out a .Resolve method from .maybeShortReadAt
Diffstat (limited to 'pkg/btrfs')
| -rw-r--r-- | pkg/btrfs/io2_fs.go | 28 | 
1 files changed, 18 insertions, 10 deletions
| diff --git a/pkg/btrfs/io2_fs.go b/pkg/btrfs/io2_fs.go index f8ebe93..ae0680a 100644 --- a/pkg/btrfs/io2_fs.go +++ b/pkg/btrfs/io2_fs.go @@ -3,6 +3,7 @@ package btrfs  import (  	"bytes"  	"fmt" +	"math"  	"reflect"  	"lukeshu.com/btrfs-tools/pkg/btrfs/btrfsitem" @@ -153,22 +154,21 @@ func (fs *FS) ReadAt(dat []byte, laddr LogicalAddr) (int, error) {  	return done, nil  } -func (fs *FS) maybeShortReadAt(dat []byte, laddr LogicalAddr) (int, error) { -	type physicalAddr struct { -		Dev  UUID -		Addr PhysicalAddr -	} +type QualifiedPhysicalAddr struct { +	Dev  UUID +	Addr PhysicalAddr +} -	paddrs := make(map[physicalAddr]struct{}) +func (fs *FS) Resolve(laddr LogicalAddr) (paddrs map[QualifiedPhysicalAddr]struct{}, maxlen uint64) { +	paddrs = make(map[QualifiedPhysicalAddr]struct{}) +	maxlen = math.MaxUint64  	for _, chunk := range fs.chunks {  		if chunk.Key.Offset <= uint64(laddr) && uint64(laddr) < chunk.Key.Offset+uint64(chunk.Chunk.Size) {  			offsetWithinChunk := uint64(laddr) - chunk.Key.Offset -			if offsetWithinChunk+uint64(len(dat)) > chunk.Chunk.Size { -				dat = dat[:chunk.Chunk.Size-offsetWithinChunk] -			} +			maxlen = util.Min(maxlen, chunk.Chunk.Size-offsetWithinChunk)  			for _, stripe := range chunk.Chunk.Stripes { -				paddrs[physicalAddr{ +				paddrs[QualifiedPhysicalAddr{  					Dev:  stripe.DeviceUUID,  					Addr: PhysicalAddr(stripe.Offset + offsetWithinChunk),  				}] = struct{}{} @@ -176,9 +176,17 @@ func (fs *FS) maybeShortReadAt(dat []byte, laddr LogicalAddr) (int, error) {  		}  	} +	return paddrs, maxlen +} + +func (fs *FS) maybeShortReadAt(dat []byte, laddr LogicalAddr) (int, error) { +	paddrs, maxlen := fs.Resolve(laddr)  	if len(paddrs) == 0 {  		return 0, fmt.Errorf("could not map logical address %v", laddr)  	} +	if uint64(len(dat)) > maxlen { +		dat = dat[:maxlen] +	}  	buf := make([]byte, len(dat))  	first := true | 
