#include "libfrog/logging.h"
static cmdinfo_t fsuuid_cmd;
+static cmdinfo_t sysfspath_cmd;
static int
fsuuid_f(
return 0;
}
+#ifndef FS_IOC_GETFSSYSFSPATH
+struct fs_sysfs_path {
+ __u8 len;
+ __u8 name[128];
+};
+#define FS_IOC_GETFSSYSFSPATH _IOR(0x15, 1, struct fs_sysfs_path)
+#endif
+
+static void
+sysfspath_help(void)
+{
+ printf(_(
+"\n"
+" print the sysfs path for the open file\n"
+"\n"
+" Prints the path in sysfs where one might find information about the\n"
+" filesystem backing the open files. The path is not required to exist.\n"
+" -d -- return the path in debugfs, if any\n"
+"\n"));
+}
+
+static int
+sysfspath_f(
+ int argc,
+ char **argv)
+{
+ struct fs_sysfs_path path;
+ bool debugfs = false;
+ int c;
+ int ret;
+
+ while ((c = getopt(argc, argv, "d")) != EOF) {
+ switch (c) {
+ case 'd':
+ debugfs = true;
+ break;
+ default:
+ exitcode = 1;
+ return command_usage(&sysfspath_cmd);
+ }
+ }
+
+ ret = ioctl(file->fd, FS_IOC_GETFSSYSFSPATH, &path);
+ if (ret) {
+ xfrog_perror(ret, "FS_IOC_GETSYSFSPATH");
+ exitcode = 1;
+ return 0;
+ }
+
+ if (debugfs)
+ printf("/sys/kernel/debug/%.*s\n", path.len, path.name);
+ else
+ printf("/sys/fs/%.*s\n", path.len, path.name);
+ return 0;
+}
+
void
fsuuid_init(void)
{
fsuuid_cmd.oneline = _("get mounted filesystem UUID");
add_command(&fsuuid_cmd);
+
+ sysfspath_cmd.name = "sysfspath";
+ sysfspath_cmd.cfunc = sysfspath_f;
+ sysfspath_cmd.argmin = 0;
+ sysfspath_cmd.argmax = -1;
+ sysfspath_cmd.args = _("-d");
+ sysfspath_cmd.flags = CMD_NOMAP_OK | CMD_FLAG_FOREIGN_OK;
+ sysfspath_cmd.oneline = _("get mounted filesystem sysfs path");
+ sysfspath_cmd.help = sysfspath_help;
+
+ add_command(&sysfspath_cmd);
}
if (xfsquotactl(XFS_GETQUOTA, dev, type, id, (void *)&d) < 0)
return 0;
+ dquot_fudge_numbers(&d);
+
if (!(flags & VERBOSE_FLAG)) {
count = 0;
if ((form & XFS_BLOCK_QUOTA) && d.d_bcount)
extern FILE *fopen_write_secure(char *__filename);
+void __dquot_fudge_numbers(struct fs_disk_quota *d);
+
+extern int expert;
+
+/*
+ * Fudge the rtblock quota numbers if we're running in fstests so we don't have
+ * to rewrite fstests.
+ */
+static inline bool
+dquot_want_fudged_numbers(void)
+{
+ return expert && getenv("XFSTESTS_RTQUOTA_FAKERY") != NULL;
+}
+
+static inline void dquot_fudge_numbers(struct fs_disk_quota *d)
+{
+ if (dquot_want_fudged_numbers())
+ __dquot_fudge_numbers(d);
+}
+
/*
* Various utility routine flags
*/
}
return fp;
}
+
+/*
+ * Push the rt block quota numbers into the regular block quota numbers so that
+ * we don't have to rewrite fstests. The limits have to match, and the regular
+ * block timer cannot be active. Only call this if you know what you are
+ * doing!
+ */
+void
+__dquot_fudge_numbers(
+ struct fs_disk_quota *d)
+{
+ if (!d->d_btimer && !d->d_btimer_hi) {
+ d->d_btimer = d->d_rtbtimer;
+ d->d_btimer_hi = d->d_rtbtimer_hi;
+ d->d_rtbtimer = 0;
+ d->d_rtbtimer_hi = 0;
+ }
+
+ if (d->d_blk_hardlimit == d->d_rtb_hardlimit)
+ d->d_rtb_hardlimit = 0;
+ if (d->d_blk_softlimit == d->d_rtb_softlimit)
+ d->d_rtb_softlimit = 0;
+
+ d->d_bcount += d->d_rtbcount;
+ d->d_rtbcount = 0;
+}