ext4: add sysfs entry showing whether the fs contains errors
Currently there is no easy way to tell that the mounted file system contains errors other than checking for log messages, or reading the information directly from superblock. This patch adds new sysfs entries: errors_count (number of fs errors we encounter) first_error_time (unix timestamp for the first error we see) last_error_time (unix timestamp for the last error we see) If the file system is not marked as containing errors then any of the file will return 0. Otherwise it will contain valid information. More details about the errors should as always be found in the logs. Signed-off-by: Lukas Czerner <lczerner@redhat.com> Signed-off-by: Theodore Ts'o <tytso@mit.edu>
This commit is contained in:
parent
a2d4a646e6
commit
52c198c682
@ -2548,6 +2548,16 @@ static ssize_t sbi_ui_store(struct ext4_attr *a,
|
|||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static ssize_t es_ui_show(struct ext4_attr *a,
|
||||||
|
struct ext4_sb_info *sbi, char *buf)
|
||||||
|
{
|
||||||
|
|
||||||
|
unsigned int *ui = (unsigned int *) (((char *) sbi->s_es) +
|
||||||
|
a->u.offset);
|
||||||
|
|
||||||
|
return snprintf(buf, PAGE_SIZE, "%u\n", *ui);
|
||||||
|
}
|
||||||
|
|
||||||
static ssize_t reserved_clusters_show(struct ext4_attr *a,
|
static ssize_t reserved_clusters_show(struct ext4_attr *a,
|
||||||
struct ext4_sb_info *sbi, char *buf)
|
struct ext4_sb_info *sbi, char *buf)
|
||||||
{
|
{
|
||||||
@ -2601,14 +2611,29 @@ static struct ext4_attr ext4_attr_##_name = { \
|
|||||||
.offset = offsetof(struct ext4_sb_info, _elname),\
|
.offset = offsetof(struct ext4_sb_info, _elname),\
|
||||||
}, \
|
}, \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define EXT4_ATTR_OFFSET_ES(_name,_mode,_show,_store,_elname) \
|
||||||
|
static struct ext4_attr ext4_attr_##_name = { \
|
||||||
|
.attr = {.name = __stringify(_name), .mode = _mode }, \
|
||||||
|
.show = _show, \
|
||||||
|
.store = _store, \
|
||||||
|
.u = { \
|
||||||
|
.offset = offsetof(struct ext4_super_block, _elname), \
|
||||||
|
}, \
|
||||||
|
}
|
||||||
|
|
||||||
#define EXT4_ATTR(name, mode, show, store) \
|
#define EXT4_ATTR(name, mode, show, store) \
|
||||||
static struct ext4_attr ext4_attr_##name = __ATTR(name, mode, show, store)
|
static struct ext4_attr ext4_attr_##name = __ATTR(name, mode, show, store)
|
||||||
|
|
||||||
#define EXT4_INFO_ATTR(name) EXT4_ATTR(name, 0444, NULL, NULL)
|
#define EXT4_INFO_ATTR(name) EXT4_ATTR(name, 0444, NULL, NULL)
|
||||||
#define EXT4_RO_ATTR(name) EXT4_ATTR(name, 0444, name##_show, NULL)
|
#define EXT4_RO_ATTR(name) EXT4_ATTR(name, 0444, name##_show, NULL)
|
||||||
#define EXT4_RW_ATTR(name) EXT4_ATTR(name, 0644, name##_show, name##_store)
|
#define EXT4_RW_ATTR(name) EXT4_ATTR(name, 0644, name##_show, name##_store)
|
||||||
|
|
||||||
|
#define EXT4_RO_ATTR_ES_UI(name, elname) \
|
||||||
|
EXT4_ATTR_OFFSET_ES(name, 0444, es_ui_show, NULL, elname)
|
||||||
#define EXT4_RW_ATTR_SBI_UI(name, elname) \
|
#define EXT4_RW_ATTR_SBI_UI(name, elname) \
|
||||||
EXT4_ATTR_OFFSET(name, 0644, sbi_ui_show, sbi_ui_store, elname)
|
EXT4_ATTR_OFFSET(name, 0644, sbi_ui_show, sbi_ui_store, elname)
|
||||||
|
|
||||||
#define ATTR_LIST(name) &ext4_attr_##name.attr
|
#define ATTR_LIST(name) &ext4_attr_##name.attr
|
||||||
#define EXT4_DEPRECATED_ATTR(_name, _val) \
|
#define EXT4_DEPRECATED_ATTR(_name, _val) \
|
||||||
static struct ext4_attr ext4_attr_##_name = { \
|
static struct ext4_attr ext4_attr_##_name = { \
|
||||||
@ -2641,6 +2666,9 @@ EXT4_RW_ATTR_SBI_UI(warning_ratelimit_interval_ms, s_warning_ratelimit_state.int
|
|||||||
EXT4_RW_ATTR_SBI_UI(warning_ratelimit_burst, s_warning_ratelimit_state.burst);
|
EXT4_RW_ATTR_SBI_UI(warning_ratelimit_burst, s_warning_ratelimit_state.burst);
|
||||||
EXT4_RW_ATTR_SBI_UI(msg_ratelimit_interval_ms, s_msg_ratelimit_state.interval);
|
EXT4_RW_ATTR_SBI_UI(msg_ratelimit_interval_ms, s_msg_ratelimit_state.interval);
|
||||||
EXT4_RW_ATTR_SBI_UI(msg_ratelimit_burst, s_msg_ratelimit_state.burst);
|
EXT4_RW_ATTR_SBI_UI(msg_ratelimit_burst, s_msg_ratelimit_state.burst);
|
||||||
|
EXT4_RO_ATTR_ES_UI(errors_count, s_error_count);
|
||||||
|
EXT4_RO_ATTR_ES_UI(first_error_time, s_first_error_time);
|
||||||
|
EXT4_RO_ATTR_ES_UI(last_error_time, s_last_error_time);
|
||||||
|
|
||||||
static struct attribute *ext4_attrs[] = {
|
static struct attribute *ext4_attrs[] = {
|
||||||
ATTR_LIST(delayed_allocation_blocks),
|
ATTR_LIST(delayed_allocation_blocks),
|
||||||
@ -2664,6 +2692,9 @@ static struct attribute *ext4_attrs[] = {
|
|||||||
ATTR_LIST(warning_ratelimit_burst),
|
ATTR_LIST(warning_ratelimit_burst),
|
||||||
ATTR_LIST(msg_ratelimit_interval_ms),
|
ATTR_LIST(msg_ratelimit_interval_ms),
|
||||||
ATTR_LIST(msg_ratelimit_burst),
|
ATTR_LIST(msg_ratelimit_burst),
|
||||||
|
ATTR_LIST(errors_count),
|
||||||
|
ATTR_LIST(first_error_time),
|
||||||
|
ATTR_LIST(last_error_time),
|
||||||
NULL,
|
NULL,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user