summaryrefslogtreecommitdiff
path: root/lib/btrfs/btrfsvol/chunk.go
diff options
context:
space:
mode:
authorLuke Shumaker <lukeshu@lukeshu.com>2022-07-15 14:36:47 -0600
committerLuke Shumaker <lukeshu@lukeshu.com>2022-07-15 15:51:32 -0600
commit5627aaea2c15a6fa8cca202614119f72972be37f (patch)
tree45e6199cb43fc0e64ca7714872cffd86a37d4959 /lib/btrfs/btrfsvol/chunk.go
parentd9cb7963948cfb1d705c35653f5237a5e8fee3f3 (diff)
tidy up
Diffstat (limited to 'lib/btrfs/btrfsvol/chunk.go')
-rw-r--r--lib/btrfs/btrfsvol/chunk.go19
1 files changed, 8 insertions, 11 deletions
diff --git a/lib/btrfs/btrfsvol/chunk.go b/lib/btrfs/btrfsvol/chunk.go
index 9c77a49..8a2d439 100644
--- a/lib/btrfs/btrfsvol/chunk.go
+++ b/lib/btrfs/btrfsvol/chunk.go
@@ -8,6 +8,7 @@ import (
"fmt"
"sort"
+ "git.lukeshu.com/btrfs-progs-ng/lib/containers"
"git.lukeshu.com/btrfs-progs-ng/lib/maps"
"git.lukeshu.com/btrfs-progs-ng/lib/slices"
)
@@ -18,7 +19,7 @@ type chunkMapping struct {
PAddrs []QualifiedPhysicalAddr
Size AddrDelta
SizeLocked bool
- Flags *BlockGroupFlags
+ Flags containers.Optional[BlockGroupFlags]
}
type ChunkMapping = chunkMapping
@@ -73,10 +74,7 @@ func (a chunkMapping) union(rest ...chunkMapping) (chunkMapping, error) {
for _, chunk := range chunks {
offsetWithinRet := chunk.LAddr.Sub(ret.LAddr)
for _, stripe := range chunk.PAddrs {
- paddrs[QualifiedPhysicalAddr{
- Dev: stripe.Dev,
- Addr: stripe.Addr.Add(-offsetWithinRet),
- }] = struct{}{}
+ paddrs[stripe.Add(-offsetWithinRet)] = struct{}{}
}
}
ret.PAddrs = maps.Keys(paddrs)
@@ -85,15 +83,14 @@ func (a chunkMapping) union(rest ...chunkMapping) (chunkMapping, error) {
})
// figure out the flags (.Flags)
for _, chunk := range chunks {
- if chunk.Flags == nil {
+ if !chunk.Flags.OK {
continue
}
- if ret.Flags == nil {
- val := *chunk.Flags
- ret.Flags = &val
+ if !ret.Flags.OK {
+ ret.Flags = chunk.Flags
}
- if *ret.Flags != *chunk.Flags {
- return ret, fmt.Errorf("mismatch flags: %v != %v", *ret.Flags, *chunk.Flags)
+ if ret.Flags != chunk.Flags {
+ return ret, fmt.Errorf("mismatch flags: %v != %v", ret.Flags.Val, chunk.Flags.Val)
}
}
// done