expose balance ioc

This commit is contained in:
Denys Smirnov 2017-01-09 15:31:52 +02:00
parent 3b69894215
commit 51976cacd4
4 changed files with 50 additions and 22 deletions

View File

@ -223,3 +223,9 @@ func (f *FS) ListSubvolumes(filter func(Subvolume) bool) ([]Subvolume, error) {
} }
func (f *FS) Usage() (UsageInfo, error) { return spaceUsage(f.f) } func (f *FS) Usage() (UsageInfo, error) { return spaceUsage(f.f) }
func (f *FS) Balance(flags BalanceFlags) (BalanceProgress, error) {
args := btrfs_ioctl_balance_args{flags: flags}
err := iocBalanceV2(f.f, &args)
return args.stat, err
}

View File

@ -4,7 +4,7 @@ import "strings"
const maxUint64 = 1<<64 - 1 const maxUint64 = 1<<64 - 1
const BTRFS_LABEL_SIZE = 256 const labelSize = 256
type FeatureFlags uint64 type FeatureFlags uint64
@ -56,3 +56,18 @@ const (
FeatureIncompatSkinnyMetadata = IncompatFeatures(1 << 8) FeatureIncompatSkinnyMetadata = IncompatFeatures(1 << 8)
FeatureIncompatNoHoles = IncompatFeatures(1 << 9) FeatureIncompatNoHoles = IncompatFeatures(1 << 9)
) )
// Flags definition for balance.
type BalanceFlags uint64
// Restriper's general type filter.
const (
BalanceData = BalanceFlags(1 << 0)
BalanceSystem = BalanceFlags(1 << 1)
BalanceMetadata = BalanceFlags(1 << 2)
BalanceMask = (BalanceData | BalanceSystem | BalanceMetadata)
BalanceForce = BalanceFlags(1 << 3)
BalanceResume = BalanceFlags(1 << 4)
)

View File

@ -277,29 +277,31 @@ type btrfs_balance_args struct {
_ [48]byte _ [48]byte
} }
// report balance progress to userspace // Report balance progress to userspace.
type btrfs_balance_progress struct { //
expected uint64 // estimated # of chunks that will be relocated to fulfill the request // btrfs_balance_progress
considered uint64 // # of chunks we have considered so far type BalanceProgress struct {
completed uint64 // # of chunks relocated so far Expected uint64 // estimated # of chunks that will be relocated to fulfill the request
Considered uint64 // # of chunks we have considered so far
Completed uint64 // # of chunks relocated so far
} }
type balanceState uint64 type BalanceState uint64
const ( const (
_BTRFS_BALANCE_STATE_RUNNING balanceState = (1 << 0) BalanceStateRunning BalanceState = (1 << 0)
_BTRFS_BALANCE_STATE_PAUSE_REQ balanceState = (1 << 1) BalanceStatePauseReq BalanceState = (1 << 1)
_BTRFS_BALANCE_STATE_CANCEL_REQ balanceState = (1 << 2) BalanceStateCancelReq BalanceState = (1 << 2)
) )
type btrfs_ioctl_balance_args struct { type btrfs_ioctl_balance_args struct {
flags uint64 // in/out flags BalanceFlags // in/out
state balanceState // out state BalanceState // out
data btrfs_balance_args // in/out data btrfs_balance_args // in/out
meta btrfs_balance_args // in/out meta btrfs_balance_args // in/out
sys btrfs_balance_args // in/out sys btrfs_balance_args // in/out
stat btrfs_balance_progress // out stat BalanceProgress // out
_ [72 * 8]byte // pad to 1k _ [72 * 8]byte // pad to 1k
} }
const _BTRFS_INO_LOOKUP_PATH_MAX = 4080 const _BTRFS_INO_LOOKUP_PATH_MAX = 4080
@ -586,6 +588,7 @@ var (
_BTRFS_IOC_SCRUB_PROGRESS = ioctl.IOWR(ioctlMagic, 29, unsafe.Sizeof(btrfs_ioctl_scrub_args{})) _BTRFS_IOC_SCRUB_PROGRESS = ioctl.IOWR(ioctlMagic, 29, unsafe.Sizeof(btrfs_ioctl_scrub_args{}))
_BTRFS_IOC_DEV_INFO = ioctl.IOWR(ioctlMagic, 30, unsafe.Sizeof(btrfs_ioctl_dev_info_args{})) _BTRFS_IOC_DEV_INFO = ioctl.IOWR(ioctlMagic, 30, unsafe.Sizeof(btrfs_ioctl_dev_info_args{}))
_BTRFS_IOC_FS_INFO = ioctl.IOR(ioctlMagic, 31, unsafe.Sizeof(btrfs_ioctl_fs_info_args{})) _BTRFS_IOC_FS_INFO = ioctl.IOR(ioctlMagic, 31, unsafe.Sizeof(btrfs_ioctl_fs_info_args{}))
_BTRFS_IOC_BALANCE_V2 = ioctl.IOWR(ioctlMagic, 32, unsafe.Sizeof(btrfs_ioctl_balance_args{}))
_BTRFS_IOC_BALANCE_CTL = ioctl.IOW(ioctlMagic, 33, 4) // int32 _BTRFS_IOC_BALANCE_CTL = ioctl.IOW(ioctlMagic, 33, 4) // int32
_BTRFS_IOC_BALANCE_PROGRESS = ioctl.IOR(ioctlMagic, 34, unsafe.Sizeof(btrfs_ioctl_balance_args{})) _BTRFS_IOC_BALANCE_PROGRESS = ioctl.IOR(ioctlMagic, 34, unsafe.Sizeof(btrfs_ioctl_balance_args{}))
_BTRFS_IOC_INO_PATHS = ioctl.IOWR(ioctlMagic, 35, unsafe.Sizeof(btrfs_ioctl_ino_path_args{})) _BTRFS_IOC_INO_PATHS = ioctl.IOWR(ioctlMagic, 35, unsafe.Sizeof(btrfs_ioctl_ino_path_args{}))
@ -600,8 +603,8 @@ var (
_BTRFS_IOC_QUOTA_RESCAN = ioctl.IOW(ioctlMagic, 44, unsafe.Sizeof(btrfs_ioctl_quota_rescan_args{})) _BTRFS_IOC_QUOTA_RESCAN = ioctl.IOW(ioctlMagic, 44, unsafe.Sizeof(btrfs_ioctl_quota_rescan_args{}))
_BTRFS_IOC_QUOTA_RESCAN_STATUS = ioctl.IOR(ioctlMagic, 45, unsafe.Sizeof(btrfs_ioctl_quota_rescan_args{})) _BTRFS_IOC_QUOTA_RESCAN_STATUS = ioctl.IOR(ioctlMagic, 45, unsafe.Sizeof(btrfs_ioctl_quota_rescan_args{}))
_BTRFS_IOC_QUOTA_RESCAN_WAIT = ioctl.IO(ioctlMagic, 46) _BTRFS_IOC_QUOTA_RESCAN_WAIT = ioctl.IO(ioctlMagic, 46)
_BTRFS_IOC_GET_FSLABEL = ioctl.IOR(ioctlMagic, 49, BTRFS_LABEL_SIZE) _BTRFS_IOC_GET_FSLABEL = ioctl.IOR(ioctlMagic, 49, labelSize)
_BTRFS_IOC_SET_FSLABEL = ioctl.IOW(ioctlMagic, 50, BTRFS_LABEL_SIZE) _BTRFS_IOC_SET_FSLABEL = ioctl.IOW(ioctlMagic, 50, labelSize)
_BTRFS_IOC_GET_DEV_STATS = ioctl.IOWR(ioctlMagic, 52, unsafe.Sizeof(btrfs_ioctl_get_dev_stats{})) _BTRFS_IOC_GET_DEV_STATS = ioctl.IOWR(ioctlMagic, 52, unsafe.Sizeof(btrfs_ioctl_get_dev_stats{}))
_BTRFS_IOC_DEV_REPLACE = ioctl.IOWR(ioctlMagic, 53, unsafe.Sizeof(btrfs_ioctl_dev_replace_args_u1{})) _BTRFS_IOC_DEV_REPLACE = ioctl.IOWR(ioctlMagic, 53, unsafe.Sizeof(btrfs_ioctl_dev_replace_args_u1{}))
_BTRFS_IOC_FILE_EXTENT_SAME = ioctl.IOWR(ioctlMagic, 54, unsafe.Sizeof(btrfs_ioctl_same_args{})) _BTRFS_IOC_FILE_EXTENT_SAME = ioctl.IOWR(ioctlMagic, 54, unsafe.Sizeof(btrfs_ioctl_same_args{}))
@ -783,6 +786,10 @@ func iocDevInfo(f *os.File, devid uint64, uuid UUID) (out btrfs_ioctl_dev_info_a
return return
} }
func iocBalanceV2(f *os.File, out *btrfs_ioctl_balance_args) error {
return ioctl.Do(f, _BTRFS_IOC_BALANCE_V2, out)
}
func iocBalanceCtl(f *os.File, out *int32) error { func iocBalanceCtl(f *os.File, out *int32) error {
return ioctl.Do(f, _BTRFS_IOC_BALANCE_CTL, out) return ioctl.Do(f, _BTRFS_IOC_BALANCE_CTL, out)
} }
@ -839,11 +846,11 @@ func iocQuotaRescanWait(f *os.File) error {
return ioctl.Do(f, _BTRFS_IOC_QUOTA_RESCAN_WAIT, nil) return ioctl.Do(f, _BTRFS_IOC_QUOTA_RESCAN_WAIT, nil)
} }
func iocGetFslabel(f *os.File, out *[BTRFS_LABEL_SIZE]byte) error { func iocGetFslabel(f *os.File, out *[labelSize]byte) error {
return ioctl.Do(f, _BTRFS_IOC_GET_FSLABEL, out) return ioctl.Do(f, _BTRFS_IOC_GET_FSLABEL, out)
} }
func iocSetFslabel(f *os.File, out *[BTRFS_LABEL_SIZE]byte) error { func iocSetFslabel(f *os.File, out *[labelSize]byte) error {
return ioctl.Do(f, _BTRFS_IOC_SET_FSLABEL, out) return ioctl.Do(f, _BTRFS_IOC_SET_FSLABEL, out)
} }

View File

@ -25,7 +25,7 @@ var caseSizes = []struct {
{obj: btrfs_ioctl_fs_info_args{}, size: 1024}, {obj: btrfs_ioctl_fs_info_args{}, size: 1024},
{obj: btrfs_ioctl_feature_flags{}, size: 24}, {obj: btrfs_ioctl_feature_flags{}, size: 24},
{obj: btrfs_balance_args{}, size: 136}, {obj: btrfs_balance_args{}, size: 136},
{obj: btrfs_balance_progress{}, size: 24}, {obj: BalanceProgress{}, size: 24},
{obj: btrfs_ioctl_balance_args{}, size: 1024}, {obj: btrfs_ioctl_balance_args{}, size: 1024},
{obj: btrfs_ioctl_ino_lookup_args{}, size: 4096}, {obj: btrfs_ioctl_ino_lookup_args{}, size: 4096},
{obj: btrfs_ioctl_search_key{}, size: 104}, {obj: btrfs_ioctl_search_key{}, size: 104},