From 6e104326f81ec59ece1817988af41b70e4f4cd15 Mon Sep 17 00:00:00 2001 From: Luke Shumaker Date: Sun, 23 Jul 2023 00:18:47 -0600 Subject: rebuildmappings scan: Include the device size and superblock --- cmd/btrfs-rec/inspect/rebuildmappings/scan.go | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) (limited to 'cmd/btrfs-rec/inspect') diff --git a/cmd/btrfs-rec/inspect/rebuildmappings/scan.go b/cmd/btrfs-rec/inspect/rebuildmappings/scan.go index d96005e..9454ca0 100644 --- a/cmd/btrfs-rec/inspect/rebuildmappings/scan.go +++ b/cmd/btrfs-rec/inspect/rebuildmappings/scan.go @@ -19,6 +19,7 @@ import ( "git.lukeshu.com/btrfs-progs-ng/lib/btrfs/btrfsvol" "git.lukeshu.com/btrfs-progs-ng/lib/btrfsutil" "git.lukeshu.com/btrfs-progs-ng/lib/containers" + "git.lukeshu.com/btrfs-progs-ng/lib/jsonutil" "git.lukeshu.com/btrfs-progs-ng/lib/textui" ) @@ -27,6 +28,8 @@ import ( type ScanDevicesResult = map[btrfsvol.DeviceID]ScanOneDeviceResult type ScanOneDeviceResult struct { + Size btrfsvol.PhysicalAddr + Superblock jsonutil.Binary[btrfstree.Superblock] Checksums btrfssum.SumRun[btrfsvol.PhysicalAddr] FoundNodes map[btrfsvol.LogicalAddr][]btrfsvol.PhysicalAddr FoundChunks []FoundChunk @@ -72,7 +75,6 @@ func ScanOneDevice(ctx context.Context, dev *btrfs.Device) (ScanOneDeviceResult, // scanner implementation ////////////////////////////////////////////////////// type deviceScanner struct { - alg btrfssum.CSumType sums strings.Builder result ScanOneDeviceResult } @@ -104,17 +106,18 @@ func (scanner *deviceScanner) ScanStats() scanStats { } } -func newDeviceScanner(_ context.Context, sb btrfstree.Superblock, _ btrfsvol.PhysicalAddr, numSectors int) btrfsutil.DeviceScanner[scanStats, ScanOneDeviceResult] { +func newDeviceScanner(_ context.Context, sb btrfstree.Superblock, numBytes btrfsvol.PhysicalAddr, numSectors int) btrfsutil.DeviceScanner[scanStats, ScanOneDeviceResult] { scanner := new(deviceScanner) - scanner.alg = sb.ChecksumType + scanner.result.Size = numBytes + scanner.result.Superblock.Val = sb scanner.result.FoundNodes = make(map[btrfsvol.LogicalAddr][]btrfsvol.PhysicalAddr) - scanner.result.Checksums.ChecksumSize = scanner.alg.Size() + scanner.result.Checksums.ChecksumSize = scanner.result.Superblock.Val.ChecksumType.Size() scanner.sums.Grow(scanner.result.Checksums.ChecksumSize * numSectors) return scanner } func (scanner *deviceScanner) ScanSector(_ context.Context, dev *btrfs.Device, paddr btrfsvol.PhysicalAddr) error { - sum, err := btrfs.ChecksumPhysical(dev, scanner.alg, paddr) + sum, err := btrfs.ChecksumPhysical(dev, scanner.result.Superblock.Val.ChecksumType, paddr) if err != nil { return err } -- cgit v1.2.3-2-g168b