diff options
| author | Daniel Mack <github@zonque.org> | 2015-10-23 10:50:53 +0200 | 
|---|---|---|
| committer | Daniel Mack <github@zonque.org> | 2015-10-23 10:50:53 +0200 | 
| commit | 952b4473bc392652b1d4c9dae5ec88fd003c4e1d (patch) | |
| tree | 8d27afa9b27ceb997013868f2b80a4bb5a993911 /src/shared/machine-image.c | |
| parent | c9fc270e462bf2f4eab963bf71234d64b0c4c30f (diff) | |
| parent | b0830e21f47109d8a6ba2fc0afbf9b2ca1ffc2a9 (diff) | |
Merge pull request #1641 from poettering/btrfs-quota
btrfs quota beef up and various other unrelated changes
Diffstat (limited to 'src/shared/machine-image.c')
| -rw-r--r-- | src/shared/machine-image.c | 41 | 
1 files changed, 30 insertions, 11 deletions
| diff --git a/src/shared/machine-image.c b/src/shared/machine-image.c index 9c1e4d5e13..8ed3ad7f44 100644 --- a/src/shared/machine-image.c +++ b/src/shared/machine-image.c @@ -176,11 +176,10 @@ static int image_make(                                  return r;                          if (r) {                                  BtrfsSubvolInfo info; -                                BtrfsQuotaInfo quota;                                  /* It's a btrfs subvolume */ -                                r = btrfs_subvol_get_info_fd(fd, &info); +                                r = btrfs_subvol_get_info_fd(fd, 0, &info);                                  if (r < 0)                                          return r; @@ -195,13 +194,17 @@ static int image_make(                                  if (r < 0)                                          return r; -                                r = btrfs_subvol_get_quota_fd(fd, "a); -                                if (r >= 0) { -                                        (*ret)->usage = quota.referenced; -                                        (*ret)->usage_exclusive = quota.exclusive; +                                if (btrfs_quota_scan_ongoing(fd) == 0) { +                                        BtrfsQuotaInfo quota; -                                        (*ret)->limit = quota.referenced_max; -                                        (*ret)->limit_exclusive = quota.exclusive_max; +                                        r = btrfs_subvol_get_subtree_quota_fd(fd, 0, "a); +                                        if (r >= 0) { +                                                (*ret)->usage = quota.referenced; +                                                (*ret)->usage_exclusive = quota.exclusive; + +                                                (*ret)->limit = quota.referenced_max; +                                                (*ret)->limit_exclusive = quota.exclusive_max; +                                        }                                  }                                  return 1; @@ -397,7 +400,7 @@ int image_remove(Image *i) {          switch (i->type) {          case IMAGE_SUBVOLUME: -                r = btrfs_subvol_remove(i->path, true); +                r = btrfs_subvol_remove(i->path, BTRFS_REMOVE_RECURSIVE|BTRFS_REMOVE_QUOTA);                  if (r < 0)                          return r;                  break; @@ -587,7 +590,12 @@ int image_clone(Image *i, const char *new_name, bool read_only) {          case IMAGE_DIRECTORY:                  new_path = strjoina("/var/lib/machines/", new_name); -                r = btrfs_subvol_snapshot(i->path, new_path, (read_only ? BTRFS_SNAPSHOT_READ_ONLY : 0) | BTRFS_SNAPSHOT_FALLBACK_COPY | BTRFS_SNAPSHOT_RECURSIVE); +                r = btrfs_subvol_snapshot(i->path, new_path, (read_only ? BTRFS_SNAPSHOT_READ_ONLY : 0) | BTRFS_SNAPSHOT_FALLBACK_COPY | BTRFS_SNAPSHOT_RECURSIVE | BTRFS_SNAPSHOT_QUOTA); + +                /* Enable "subtree" quotas for the copy, if we didn't +                 * copy any quota from the source. */ +                (void) btrfs_subvol_auto_qgroup(i->path, 0, true); +                  break;          case IMAGE_RAW: @@ -629,6 +637,10 @@ int image_read_only(Image *i, bool b) {          switch (i->type) {          case IMAGE_SUBVOLUME: + +                /* Note that we set the flag only on the top-level +                 * subvolume of the image. */ +                  r = btrfs_subvol_set_read_only(i->path, b);                  if (r < 0)                          return r; @@ -729,7 +741,14 @@ int image_set_limit(Image *i, uint64_t referenced_max) {          if (i->type != IMAGE_SUBVOLUME)                  return -EOPNOTSUPP; -        return btrfs_quota_limit(i->path, referenced_max); +        /* We set the quota both for the subvolume as well as for the +         * subtree. The latter is mostly for historical reasons, since +         * we didn't use to have a concept of subtree quota, and hence +         * only modified the subvolume quota. */ + +        (void) btrfs_qgroup_set_limit(i->path, 0, referenced_max); +        (void) btrfs_subvol_auto_qgroup(i->path, 0, true); +        return btrfs_subvol_set_subtree_quota_limit(i->path, 0, referenced_max);  }  int image_name_lock(const char *name, int operation, LockFile *ret) { | 
