diff options
author | Lin Ling <Lin.Ling@Sun.COM> | 2009-04-27 11:08:32 -0700 |
---|---|---|
committer | Lin Ling <Lin.Ling@Sun.COM> | 2009-04-27 11:08:32 -0700 |
commit | edea4b556f0b07459cdcc780ffcd28a40b374945 (patch) | |
tree | b4a3df57ae8f98c99122a68576f165c1a3c4582e /usr/src/lib/libzfs/common/libzfs_dataset.c | |
parent | 4baa2c25868c5c0ae97aa381b8b1c571c85dc5ef (diff) | |
download | illumos-joyent-edea4b556f0b07459cdcc780ffcd28a40b374945.tar.gz |
6824968 add ZFS userquota support to rquotad
Diffstat (limited to 'usr/src/lib/libzfs/common/libzfs_dataset.c')
-rw-r--r-- | usr/src/lib/libzfs/common/libzfs_dataset.c | 46 |
1 files changed, 36 insertions, 10 deletions
diff --git a/usr/src/lib/libzfs/common/libzfs_dataset.c b/usr/src/lib/libzfs/common/libzfs_dataset.c index ad2a74861b..1571914e8f 100644 --- a/usr/src/lib/libzfs/common/libzfs_dataset.c +++ b/usr/src/lib/libzfs/common/libzfs_dataset.c @@ -2168,20 +2168,19 @@ userquota_propname_decode(const char *propname, boolean_t zoned, return (0); } -int -zfs_prop_get_userquota(zfs_handle_t *zhp, const char *propname, - char *propbuf, int proplen, boolean_t literal) +static int +zfs_prop_get_userquota_common(zfs_handle_t *zhp, const char *propname, + uint64_t *propvalue, zfs_userquota_prop_t *typep) { int err; zfs_cmd_t zc = { 0 }; - zfs_userquota_prop_t type; (void) strncpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name)); err = userquota_propname_decode(propname, zfs_prop_get_int(zhp, ZFS_PROP_ZONED), - &type, zc.zc_value, sizeof (zc.zc_value), &zc.zc_guid); - zc.zc_objset_type = type; + typep, zc.zc_value, sizeof (zc.zc_value), &zc.zc_guid); + zc.zc_objset_type = *typep; if (err) return (err); @@ -2189,14 +2188,41 @@ zfs_prop_get_userquota(zfs_handle_t *zhp, const char *propname, if (err) return (err); + *propvalue = zc.zc_cookie; + return (0); +} + +int +zfs_prop_get_userquota_int(zfs_handle_t *zhp, const char *propname, + uint64_t *propvalue) +{ + zfs_userquota_prop_t type; + + return (zfs_prop_get_userquota_common(zhp, propname, propvalue, + &type)); +} + +int +zfs_prop_get_userquota(zfs_handle_t *zhp, const char *propname, + char *propbuf, int proplen, boolean_t literal) +{ + int err; + uint64_t propvalue; + zfs_userquota_prop_t type; + + err = zfs_prop_get_userquota_common(zhp, propname, &propvalue, + &type); + + if (err) + return (err); + if (literal) { - (void) snprintf(propbuf, proplen, "%llu", - (u_longlong_t)zc.zc_cookie); - } else if (zc.zc_cookie == 0 && + (void) snprintf(propbuf, proplen, "%llu", propvalue); + } else if (propvalue == 0 && (type == ZFS_PROP_USERQUOTA || type == ZFS_PROP_GROUPQUOTA)) { (void) strlcpy(propbuf, "none", proplen); } else { - zfs_nicenum(zc.zc_cookie, propbuf, proplen); + zfs_nicenum(propvalue, propbuf, proplen); } return (0); } |