Re: [PATCH v2 3/5] xfs_quota: separate get_dquot() and report_mount()

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, Apr 20, 2022 at 04:45:06PM +0200, Andrey Albershteyn wrote:
> Separate quota info acquisition from outputting. This allows upper
> functions to filter obtained info (e.g. within specific ID range).
> 
> Signed-off-by: Andrey Albershteyn <aalbersh@xxxxxxxxxx>

Looks ok,
Reviewed-by: Darrick J. Wong <djwong@xxxxxxxxxx>

--D

> ---
>  quota/report.c | 178 ++++++++++++++++++++++++++++---------------------
>  1 file changed, 103 insertions(+), 75 deletions(-)
> 
> diff --git a/quota/report.c b/quota/report.c
> index d5c6f84f..8ca154f0 100644
> --- a/quota/report.c
> +++ b/quota/report.c
> @@ -339,30 +339,25 @@ report_header(
>  static int
>  report_mount(
>  	FILE		*fp,
> -	uint32_t	id,
> +	struct fs_disk_quota *d,
>  	char		*name,
> -	uint32_t	*oid,
>  	uint		form,
>  	uint		type,
>  	fs_path_t	*mount,
>  	uint		flags)
>  {
> -	fs_disk_quota_t	d;
>  	time64_t	timer;
>  	char		c[8], h[8], s[8];
>  	uint		qflags;
>  	int		count;
>  
> -	if (!get_dquot(&d, id, oid, type, mount->fs_name, flags))
> -		return 0;
> -
>  	if (flags & TERSE_FLAG) {
>  		count = 0;
> -		if ((form & XFS_BLOCK_QUOTA) && d.d_bcount)
> +		if ((form & XFS_BLOCK_QUOTA) && d->d_bcount)
>  			count++;
> -		if ((form & XFS_INODE_QUOTA) && d.d_icount)
> +		if ((form & XFS_INODE_QUOTA) && d->d_icount)
>  			count++;
> -		if ((form & XFS_RTBLOCK_QUOTA) && d.d_rtbcount)
> +		if ((form & XFS_RTBLOCK_QUOTA) && d->d_rtbcount)
>  			count++;
>  		if (!count)
>  			return 0;
> @@ -372,19 +367,19 @@ report_mount(
>  		report_header(fp, form, type, mount, flags);
>  
>  	if (flags & NO_LOOKUP_FLAG) {
> -		fprintf(fp, "#%-10u", d.d_id);
> +		fprintf(fp, "#%-10u", d->d_id);
>  	} else {
>  		if (name == NULL) {
>  			if (type == XFS_USER_QUOTA) {
> -				struct passwd	*u = getpwuid(d.d_id);
> +				struct passwd	*u = getpwuid(d->d_id);
>  				if (u)
>  					name = u->pw_name;
>  			} else if (type == XFS_GROUP_QUOTA) {
> -				struct group	*g = getgrgid(d.d_id);
> +				struct group	*g = getgrgid(d->d_id);
>  				if (g)
>  					name = g->gr_name;
>  			} else if (type == XFS_PROJ_QUOTA) {
> -				fs_project_t	*p = getprprid(d.d_id);
> +				fs_project_t	*p = getprprid(d->d_id);
>  				if (p)
>  					name = p->pr_name;
>  			}
> @@ -393,73 +388,73 @@ report_mount(
>  		if (name != NULL)
>  			fprintf(fp, "%-10s", name);
>  		else
> -			fprintf(fp, "#%-9u", d.d_id);
> +			fprintf(fp, "#%-9u", d->d_id);
>  	}
>  
>  	if (form & XFS_BLOCK_QUOTA) {
> -		timer = decode_timer(&d, d.d_btimer, d.d_btimer_hi);
> +		timer = decode_timer(d, d->d_btimer, d->d_btimer_hi);
>  		qflags = (flags & HUMAN_FLAG);
> -		if (d.d_blk_hardlimit && d.d_bcount > d.d_blk_hardlimit)
> +		if (d->d_blk_hardlimit && d->d_bcount > d->d_blk_hardlimit)
>  			qflags |= LIMIT_FLAG;
> -		if (d.d_blk_softlimit && d.d_bcount > d.d_blk_softlimit)
> +		if (d->d_blk_softlimit && d->d_bcount > d->d_blk_softlimit)
>  			qflags |= QUOTA_FLAG;
>  		if (flags & HUMAN_FLAG)
>  			fprintf(fp, " %6s %6s %6s  %02d %8s",
> -				bbs_to_string(d.d_bcount, c, sizeof(c)),
> -				bbs_to_string(d.d_blk_softlimit, s, sizeof(s)),
> -				bbs_to_string(d.d_blk_hardlimit, h, sizeof(h)),
> -				d.d_bwarns,
> +				bbs_to_string(d->d_bcount, c, sizeof(c)),
> +				bbs_to_string(d->d_blk_softlimit, s, sizeof(s)),
> +				bbs_to_string(d->d_blk_hardlimit, h, sizeof(h)),
> +				d->d_bwarns,
>  				time_to_string(timer, qflags));
>  		else
>  			fprintf(fp, " %10llu %10llu %10llu     %02d %9s",
> -				(unsigned long long)d.d_bcount >> 1,
> -				(unsigned long long)d.d_blk_softlimit >> 1,
> -				(unsigned long long)d.d_blk_hardlimit >> 1,
> -				d.d_bwarns,
> +				(unsigned long long)d->d_bcount >> 1,
> +				(unsigned long long)d->d_blk_softlimit >> 1,
> +				(unsigned long long)d->d_blk_hardlimit >> 1,
> +				d->d_bwarns,
>  				time_to_string(timer, qflags));
>  	}
>  	if (form & XFS_INODE_QUOTA) {
> -		timer = decode_timer(&d, d.d_itimer, d.d_itimer_hi);
> +		timer = decode_timer(d, d->d_itimer, d->d_itimer_hi);
>  		qflags = (flags & HUMAN_FLAG);
> -		if (d.d_ino_hardlimit && d.d_icount > d.d_ino_hardlimit)
> +		if (d->d_ino_hardlimit && d->d_icount > d->d_ino_hardlimit)
>  			qflags |= LIMIT_FLAG;
> -		if (d.d_ino_softlimit && d.d_icount > d.d_ino_softlimit)
> +		if (d->d_ino_softlimit && d->d_icount > d->d_ino_softlimit)
>  			qflags |= QUOTA_FLAG;
>  		if (flags & HUMAN_FLAG)
>  			fprintf(fp, " %6s %6s %6s  %02d %8s",
> -				num_to_string(d.d_icount, c, sizeof(c)),
> -				num_to_string(d.d_ino_softlimit, s, sizeof(s)),
> -				num_to_string(d.d_ino_hardlimit, h, sizeof(h)),
> -				d.d_iwarns,
> +				num_to_string(d->d_icount, c, sizeof(c)),
> +				num_to_string(d->d_ino_softlimit, s, sizeof(s)),
> +				num_to_string(d->d_ino_hardlimit, h, sizeof(h)),
> +				d->d_iwarns,
>  				time_to_string(timer, qflags));
>  		else
>  			fprintf(fp, " %10llu %10llu %10llu     %02d %9s",
> -				(unsigned long long)d.d_icount,
> -				(unsigned long long)d.d_ino_softlimit,
> -				(unsigned long long)d.d_ino_hardlimit,
> -				d.d_iwarns,
> +				(unsigned long long)d->d_icount,
> +				(unsigned long long)d->d_ino_softlimit,
> +				(unsigned long long)d->d_ino_hardlimit,
> +				d->d_iwarns,
>  				time_to_string(timer, qflags));
>  	}
>  	if (form & XFS_RTBLOCK_QUOTA) {
> -		timer = decode_timer(&d, d.d_rtbtimer, d.d_rtbtimer_hi);
> +		timer = decode_timer(d, d->d_rtbtimer, d->d_rtbtimer_hi);
>  		qflags = (flags & HUMAN_FLAG);
> -		if (d.d_rtb_hardlimit && d.d_rtbcount > d.d_rtb_hardlimit)
> +		if (d->d_rtb_hardlimit && d->d_rtbcount > d->d_rtb_hardlimit)
>  			qflags |= LIMIT_FLAG;
> -		if (d.d_rtb_softlimit && d.d_rtbcount > d.d_rtb_softlimit)
> +		if (d->d_rtb_softlimit && d->d_rtbcount > d->d_rtb_softlimit)
>  			qflags |= QUOTA_FLAG;
>  		if (flags & HUMAN_FLAG)
>  			fprintf(fp, " %6s %6s %6s  %02d %8s",
> -				bbs_to_string(d.d_rtbcount, c, sizeof(c)),
> -				bbs_to_string(d.d_rtb_softlimit, s, sizeof(s)),
> -				bbs_to_string(d.d_rtb_hardlimit, h, sizeof(h)),
> -				d.d_rtbwarns,
> +				bbs_to_string(d->d_rtbcount, c, sizeof(c)),
> +				bbs_to_string(d->d_rtb_softlimit, s, sizeof(s)),
> +				bbs_to_string(d->d_rtb_hardlimit, h, sizeof(h)),
> +				d->d_rtbwarns,
>  				time_to_string(timer, qflags));
>  		else
>  			fprintf(fp, " %10llu %10llu %10llu     %02d %9s",
> -				(unsigned long long)d.d_rtbcount >> 1,
> -				(unsigned long long)d.d_rtb_softlimit >> 1,
> -				(unsigned long long)d.d_rtb_hardlimit >> 1,
> -				d.d_rtbwarns,
> +				(unsigned long long)d->d_rtbcount >> 1,
> +				(unsigned long long)d->d_rtb_softlimit >> 1,
> +				(unsigned long long)d->d_rtb_hardlimit >> 1,
> +				d->d_rtbwarns,
>  				time_to_string(timer, qflags));
>  	}
>  	fputc('\n', fp);
> @@ -476,30 +471,40 @@ report_user_mount(
>  	uint		flags)
>  {
>  	struct passwd	*u;
> +	struct fs_disk_quota	d;
>  	uint		id = 0, oid;
>  
>  	if (upper) {	/* identifier range specified */
>  		for (id = lower; id <= upper; id++) {
> -			if (report_mount(fp, id, NULL, NULL,
> -					form, XFS_USER_QUOTA, mount, flags))
> +			if (get_dquot(&d, id, NULL, XFS_USER_QUOTA,
> +						mount->fs_name, flags)) {
> +				report_mount(fp, &d, NULL, form, XFS_USER_QUOTA,
> +						mount, flags);
>  				flags |= NO_HEADER_FLAG;
> +			}
>  		}
> -	} else if (report_mount(fp, id, NULL, &oid, form,
> -				XFS_USER_QUOTA, mount,
> +	} else if (get_dquot(&d, id, &oid, XFS_USER_QUOTA, mount->fs_name,
>  				flags|GETNEXTQUOTA_FLAG)) {
> +		report_mount(fp, &d, NULL, form, XFS_USER_QUOTA, mount,
> +			flags|GETNEXTQUOTA_FLAG);
>  		id = oid + 1;
>  		flags |= GETNEXTQUOTA_FLAG;
>  		flags |= NO_HEADER_FLAG;
> -		while (report_mount(fp, id, NULL, &oid, form, XFS_USER_QUOTA,
> -				    mount, flags)) {
> +		while (get_dquot(&d, id, &oid, XFS_USER_QUOTA, mount->fs_name,
> +				flags)) {
> +			report_mount(fp, &d, NULL, form, XFS_USER_QUOTA,
> +				mount, flags);
>  			id = oid + 1;
>  		}
>  	} else {
>  		setpwent();
>  		while ((u = getpwent()) != NULL) {
> -			if (report_mount(fp, u->pw_uid, u->pw_name, NULL,
> -					form, XFS_USER_QUOTA, mount, flags))
> +			if (get_dquot(&d, u->pw_uid, NULL, XFS_USER_QUOTA,
> +						mount->fs_name, flags)) {
> +				report_mount(fp, &d, u->pw_name, form,
> +						XFS_USER_QUOTA, mount, flags);
>  				flags |= NO_HEADER_FLAG;
> +			}
>  		}
>  		endpwent();
>  	}
> @@ -518,30 +523,40 @@ report_group_mount(
>  	uint		flags)
>  {
>  	struct group	*g;
> +	struct fs_disk_quota	d;
>  	uint		id = 0, oid;
>  
>  	if (upper) {	/* identifier range specified */
>  		for (id = lower; id <= upper; id++) {
> -			if (report_mount(fp, id, NULL, NULL,
> -					form, XFS_GROUP_QUOTA, mount, flags))
> +			if (get_dquot(&d, id, NULL, XFS_GROUP_QUOTA,
> +						mount->fs_name, flags)) {
> +				report_mount(fp, &d, NULL, form,
> +						XFS_GROUP_QUOTA, mount, flags);
>  				flags |= NO_HEADER_FLAG;
> +			}
>  		}
> -	} else if (report_mount(fp, id, NULL, &oid, form,
> -				XFS_GROUP_QUOTA, mount,
> -				flags|GETNEXTQUOTA_FLAG)) {
> +	} else if (get_dquot(&d, id, &oid, XFS_GROUP_QUOTA,
> +				mount->fs_name, flags|GETNEXTQUOTA_FLAG)) {
> +		report_mount(fp, &d, NULL, form, XFS_GROUP_QUOTA, mount,
> +				flags|GETNEXTQUOTA_FLAG);
>  		id = oid + 1;
>  		flags |= GETNEXTQUOTA_FLAG;
>  		flags |= NO_HEADER_FLAG;
> -		while (report_mount(fp, id, NULL, &oid, form, XFS_GROUP_QUOTA,
> -				    mount, flags)) {
> +		while (get_dquot(&d, id, &oid, XFS_GROUP_QUOTA,
> +					mount->fs_name, flags)) {
> +			report_mount(fp, &d, NULL, form, XFS_GROUP_QUOTA, mount,
> +					flags);
>  			id = oid + 1;
>  		}
>  	} else {
>  		setgrent();
>  		while ((g = getgrent()) != NULL) {
> -			if (report_mount(fp, g->gr_gid, g->gr_name, NULL,
> -					form, XFS_GROUP_QUOTA, mount, flags))
> +			if (get_dquot(&d, g->gr_gid, NULL, XFS_GROUP_QUOTA,
> +						mount->fs_name, flags)) {
> +				report_mount(fp, &d, g->gr_name, form,
> +						XFS_GROUP_QUOTA, mount, flags);
>  				flags |= NO_HEADER_FLAG;
> +			}
>  		}
>  	}
>  	if (flags & NO_HEADER_FLAG)
> @@ -559,22 +574,29 @@ report_project_mount(
>  	uint		flags)
>  {
>  	fs_project_t	*p;
> +	struct fs_disk_quota	d;
>  	uint		id = 0, oid;
>  
>  	if (upper) {	/* identifier range specified */
>  		for (id = lower; id <= upper; id++) {
> -			if (report_mount(fp, id, NULL, NULL,
> -					form, XFS_PROJ_QUOTA, mount, flags))
> +			if (get_dquot(&d, id, NULL, XFS_PROJ_QUOTA,
> +						mount->fs_name, flags)) {
> +				report_mount(fp, &d, NULL, form, XFS_PROJ_QUOTA,
> +						mount, flags);
>  				flags |= NO_HEADER_FLAG;
> +			}
>  		}
> -	} else if (report_mount(fp, id, NULL, &oid, form,
> -				XFS_PROJ_QUOTA, mount,
> -				flags|GETNEXTQUOTA_FLAG)) {
> +	} else if (get_dquot(&d, id, &oid, XFS_PROJ_QUOTA,
> +				mount->fs_name, flags|GETNEXTQUOTA_FLAG)) {
> +		report_mount(fp, &d, NULL, form, XFS_PROJ_QUOTA, mount,
> +				flags|GETNEXTQUOTA_FLAG);
>  		id = oid + 1;
>  		flags |= GETNEXTQUOTA_FLAG;
>  		flags |= NO_HEADER_FLAG;
> -		while (report_mount(fp, id, NULL, &oid, form, XFS_PROJ_QUOTA,
> -				    mount, flags)) {
> +		while (get_dquot(&d, id, &oid, XFS_PROJ_QUOTA,
> +					mount->fs_name, flags)) {
> +			report_mount(fp, &d, NULL, form, XFS_PROJ_QUOTA, mount,
> +					flags);
>  			id = oid + 1;
>  		}
>  	} else {
> @@ -583,16 +605,22 @@ report_project_mount(
>  			 * Print default project quota, even if projid 0
>  			 * isn't defined
>  			 */
> -			if (report_mount(fp, 0, NULL, NULL,
> -					form, XFS_PROJ_QUOTA, mount, flags))
> +			if (get_dquot(&d, 0, NULL, XFS_PROJ_QUOTA,
> +						mount->fs_name, flags)) {
> +				report_mount(fp, &d, NULL, form, XFS_PROJ_QUOTA,
> +						mount, flags);
>  				flags |= NO_HEADER_FLAG;
> +			}
>  		}
>  
>  		setprent();
>  		while ((p = getprent()) != NULL) {
> -			if (report_mount(fp, p->pr_prid, p->pr_name, NULL,
> -					form, XFS_PROJ_QUOTA, mount, flags))
> +			if (get_dquot(&d, p->pr_prid, NULL, XFS_PROJ_QUOTA,
> +						mount->fs_name, flags)) {
> +				report_mount(fp, &d, p->pr_name, form,
> +						XFS_PROJ_QUOTA, mount, flags);
>  				flags |= NO_HEADER_FLAG;
> +			}
>  		}
>  		endprent();
>  	}
> -- 
> 2.27.0
> 



[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux