struct ll_sb_info *sbi = container_of(kobj, struct ll_sb_info,
ll_kset.kobj);
- return sprintf(buf, "%u\n", (sbi->ll_flags & LL_SBI_CHECKSUM) ? 1 : 0);
+ return scnprintf(buf, PAGE_SIZE, "%u\n",
+ test_bit(LL_SBI_CHECKSUM, sbi->ll_flags));
}
static ssize_t checksums_store(struct kobject *kobj, struct attribute *attr,
if (rc)
return rc;
if (val)
- sbi->ll_flags |= LL_SBI_CHECKSUM;
+ set_bit(LL_SBI_CHECKSUM, sbi->ll_flags);
else
- sbi->ll_flags &= ~LL_SBI_CHECKSUM;
+ clear_bit(LL_SBI_CHECKSUM, sbi->ll_flags);
tmp = val;
rc = obd_set_info_async(NULL, sbi->ll_dt_exp, sizeof(KEY_CHECKSUM),
struct ll_sb_info *sbi = container_of(kobj, struct ll_sb_info,
ll_kset.kobj);
- return sprintf(buf, "%u\n", sbi->ll_flags & LL_SBI_AGL_ENABLED ? 1 : 0);
+ return scnprintf(buf, PAGE_SIZE, "%u\n",
+ test_bit(LL_SBI_AGL_ENABLED, sbi->ll_flags));
}
static ssize_t statahead_agl_store(struct kobject *kobj,
return rc;
if (val)
- sbi->ll_flags |= LL_SBI_AGL_ENABLED;
+ set_bit(LL_SBI_AGL_ENABLED, sbi->ll_flags);
else
- sbi->ll_flags &= ~LL_SBI_AGL_ENABLED;
+ clear_bit(LL_SBI_AGL_ENABLED, sbi->ll_flags);
return count;
}
struct ll_sb_info *sbi = container_of(kobj, struct ll_sb_info,
ll_kset.kobj);
- return sprintf(buf, "%u\n", (sbi->ll_flags & LL_SBI_LAZYSTATFS) ? 1 : 0);
+ return scnprintf(buf, PAGE_SIZE, "%u\n",
+ test_bit(LL_SBI_LAZYSTATFS, sbi->ll_flags));
}
static ssize_t lazystatfs_store(struct kobject *kobj,
return rc;
if (val)
- sbi->ll_flags |= LL_SBI_LAZYSTATFS;
+ set_bit(LL_SBI_LAZYSTATFS, sbi->ll_flags);
else
- sbi->ll_flags &= ~LL_SBI_LAZYSTATFS;
+ clear_bit(LL_SBI_LAZYSTATFS, sbi->ll_flags);
return count;
}
}
LUSTRE_RW_ATTR(default_easize);
-static int ll_sbi_flags_seq_show(struct seq_file *m, void *v)
-{
- const char *const str[] = LL_SBI_FLAGS;
- struct super_block *sb = m->private;
- int flags = ll_s2sbi(sb)->ll_flags;
- int i = 0;
-
- while (flags != 0) {
- if (ARRAY_SIZE(str) <= i) {
- CERROR("%s: Revise array LL_SBI_FLAGS to match sbi "
- "flags please.\n", ll_s2sbi(sb)->ll_fsname);
- return -EINVAL;
- }
-
- if (flags & 0x1)
- seq_printf(m, "%s ", str[i]);
- flags >>= 1;
- ++i;
- }
- seq_printf(m, "\b\n");
- return 0;
-}
-
LDEBUGFS_SEQ_FOPS_RO(ll_sbi_flags);
static ssize_t xattr_cache_show(struct kobject *kobj,
if (rc)
return rc;
- if (val && !(sbi->ll_flags & LL_SBI_XATTR_CACHE))
+ if (val && !test_bit(LL_SBI_XATTR_CACHE, sbi->ll_flags))
return -ENOTSUPP;
sbi->ll_xattr_cache_enabled = val;
struct ll_sb_info *sbi = container_of(kobj, struct ll_sb_info,
ll_kset.kobj);
- return sprintf(buf, "%u\n", !!(sbi->ll_flags & LL_SBI_TINY_WRITE));
+ return scnprintf(buf, PAGE_SIZE, "%u\n",
+ test_bit(LL_SBI_TINY_WRITE, sbi->ll_flags));
}
static ssize_t tiny_write_store(struct kobject *kobj,
spin_lock(&sbi->ll_lock);
if (val)
- sbi->ll_flags |= LL_SBI_TINY_WRITE;
+ set_bit(LL_SBI_TINY_WRITE, sbi->ll_flags);
else
- sbi->ll_flags &= ~LL_SBI_TINY_WRITE;
+ clear_bit(LL_SBI_TINY_WRITE, sbi->ll_flags);
spin_unlock(&sbi->ll_lock);
return count;
ll_kset.kobj);
return snprintf(buf, PAGE_SIZE, "%u\n",
- !!(sbi->ll_flags & LL_SBI_PARALLEL_DIO));
+ test_bit(LL_SBI_PARALLEL_DIO, sbi->ll_flags));
}
static ssize_t parallel_dio_store(struct kobject *kobj,
spin_lock(&sbi->ll_lock);
if (val)
- sbi->ll_flags |= LL_SBI_PARALLEL_DIO;
+ set_bit(LL_SBI_PARALLEL_DIO, sbi->ll_flags);
else
- sbi->ll_flags &= ~LL_SBI_PARALLEL_DIO;
+ clear_bit(LL_SBI_PARALLEL_DIO, sbi->ll_flags);
spin_unlock(&sbi->ll_lock);
return count;
struct ll_sb_info *sbi = container_of(kobj, struct ll_sb_info,
ll_kset.kobj);
- return sprintf(buf, "%u\n", !!(sbi->ll_flags & LL_SBI_FAST_READ));
+ return scnprintf(buf, PAGE_SIZE, "%u\n",
+ test_bit(LL_SBI_FAST_READ, sbi->ll_flags));
}
static ssize_t fast_read_store(struct kobject *kobj,
spin_lock(&sbi->ll_lock);
if (val)
- sbi->ll_flags |= LL_SBI_FAST_READ;
+ set_bit(LL_SBI_FAST_READ, sbi->ll_flags);
else
- sbi->ll_flags &= ~LL_SBI_FAST_READ;
+ clear_bit(LL_SBI_FAST_READ, sbi->ll_flags);
spin_unlock(&sbi->ll_lock);
return count;
ll_kset.kobj);
return scnprintf(buf, PAGE_SIZE, "%u\n",
- !!(sbi->ll_flags & LL_SBI_FILE_HEAT));
+ test_bit(LL_SBI_FILE_HEAT, sbi->ll_flags));
}
static ssize_t file_heat_store(struct kobject *kobj,
spin_lock(&sbi->ll_lock);
if (val)
- sbi->ll_flags |= LL_SBI_FILE_HEAT;
+ set_bit(LL_SBI_FILE_HEAT, sbi->ll_flags);
else
- sbi->ll_flags &= ~LL_SBI_FILE_HEAT;
+ clear_bit(LL_SBI_FILE_HEAT, sbi->ll_flags);
spin_unlock(&sbi->ll_lock);
return count;