diff options
author | Luke Shumaker <lukeshu@lukeshu.com> | 2022-08-27 22:30:19 -0600 |
---|---|---|
committer | Luke Shumaker <lukeshu@lukeshu.com> | 2022-08-28 18:11:46 -0600 |
commit | 8758b0e2000f0892e487afc376a6d75bb08ffb9b (patch) | |
tree | 5e93fca9635e07f6aa6e045dac264d2ce553b3e9 /lib/btrfsprogs | |
parent | 8bd5cfbedb026ac64bd26fc9b9ae5bd358893203 (diff) |
dbg
Diffstat (limited to 'lib/btrfsprogs')
-rw-r--r-- | lib/btrfsprogs/btrfsinspect/rebuildnodes/rebuildnodes.go | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/lib/btrfsprogs/btrfsinspect/rebuildnodes/rebuildnodes.go b/lib/btrfsprogs/btrfsinspect/rebuildnodes/rebuildnodes.go index 16b1e84..cac9483 100644 --- a/lib/btrfsprogs/btrfsinspect/rebuildnodes/rebuildnodes.go +++ b/lib/btrfsprogs/btrfsinspect/rebuildnodes/rebuildnodes.go @@ -6,10 +6,12 @@ package rebuildnodes import ( "context" + "errors" "fmt" iofs "io/fs" "math" "sort" + "strings" "github.com/datawire/dlib/dlog" @@ -152,6 +154,9 @@ func lostAndFoundNodes(ctx context.Context, fs *btrfs.FS, nodeScanResults btrfsi }, Err: func(err *btrfsutil.WalkError) { // do nothing + if !errors.Is(err, btrfstree.ErrNotANode) && !strings.Contains(err.Error(), "read: could not map logical address") { + dlog.Errorf(ctx, "dbg walk err: %v", err) + } }, }) @@ -220,6 +225,7 @@ func getChunkTreeUUID(ctx context.Context, fs *btrfs.FS) (btrfsprim.UUID, bool) }, Err: func(err *btrfsutil.WalkError) { // do nothing + dlog.Errorf(ctx, "dbg err: %v", err) }, }) return ret, retOK @@ -255,9 +261,17 @@ func reInitBrokenNodes(ctx context.Context, fs *btrfs.FS, nodeScanResults btrfsi var done int rebuiltNodes := make(map[btrfsvol.LogicalAddr]*RebuiltNode) + dbg := make(map[btrfsvol.LogicalAddr]btrfstree.TreePath) walkHandler := btrfstree.TreeWalkHandler{ - Node: func(_ btrfstree.TreePath, _ *diskio.Ref[btrfsvol.LogicalAddr, btrfstree.Node]) error { + Node: func(path btrfstree.TreePath, _ *diskio.Ref[btrfsvol.LogicalAddr, btrfstree.Node]) error { + if other, conflict := dbg[path.Node(-1).ToNodeAddr]; conflict { + panic(fmt.Errorf("same node visited twice: %v != %v", other, path)) + } + dbg[path.Node(-1).ToNodeAddr] = path.DeepCopy() done++ + if done != len(dbg) { + panic(fmt.Errorf("done=%v != len(dbg)=%v", done, len(dbg))) + } progress(done) return nil }, |