.B \-n
Only check filesystem metadata.
Do not repair or optimize anything.
+.HP
+.B \-o
+.I subopt\c
+[\c
+.B =\c
+.IR value ]
+.BR
+Override what the program might conclude about the filesystem
+if left to its own devices.
+.IP
+The
+.IR subopt ions
+supported are:
+.RS 1.0i
+.TP
+.BI iwarn
+Treat informational messages as warnings.
+This will result in a nonzero return code, and a higher logging level.
+.RE
.TP
.BI \-T
Print timing and memory usage information for each phase.
/* Set to true if the kernel supports XFS_SCRUB_IFLAG_FORCE_REBUILD */
bool use_force_rebuild;
+/* Should we count informational messages as warnings? */
+bool info_is_warning;
+
#define SCRUB_RET_SUCCESS (0) /* no problems left behind */
#define SCRUB_RET_CORRUPT (1) /* corruption remains on fs */
#define SCRUB_RET_UNOPTIMIZED (2) /* fs could be optimized */
# define XFS_SCRUB_HAVE_UNICODE "-"
#endif
+/*
+ * -o: user-supplied override options
+ */
+enum o_opt_nums {
+ IWARN = 0,
+ O_MAX_OPTS,
+};
+
+static char *o_opts[] = {
+ [IWARN] = "iwarn",
+ [O_MAX_OPTS] = NULL,
+};
+
+static void
+parse_o_opts(
+ struct scrub_ctx *ctx,
+ char *p)
+{
+ while (*p != '\0') {
+ char *val;
+
+ switch (getsubopt(&p, o_opts, &val)) {
+ case IWARN:
+ if (val) {
+ fprintf(stderr,
+ _("iwarn does not take an argument\n"));
+ usage();
+ }
+ info_is_warning = true;
+ break;
+ default:
+ usage();
+ break;
+ }
+ }
+}
+
int
main(
int argc,
pthread_mutex_init(&ctx.lock, NULL);
ctx.mode = SCRUB_MODE_REPAIR;
ctx.error_action = ERRORS_CONTINUE;
- while ((c = getopt(argc, argv, "a:bC:de:km:nTvxV")) != EOF) {
+ while ((c = getopt(argc, argv, "a:bC:de:km:no:TvxV")) != EOF) {
switch (c) {
case 'a':
ctx.max_errors = cvt_u64(optarg, 10);
case 'n':
ctx.mode = SCRUB_MODE_DRY_RUN;
break;
+ case 'o':
+ parse_o_opts(&ctx, optarg);
+ break;
case 'T':
display_rusage = true;
break;