zdb: dump_history can be improved
We only recognize some history records, instead, use same logic as in print_history_records() in zpool_main.c. Reviewed-by: Igor Kozhukhov <igor@dilos.org> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Toomas Soome <tsoome@me.com> Closes #11940
This commit is contained in:
parent
e4288a8397
commit
17b83525f5
|
@ -32,6 +32,7 @@
|
||||||
* [1] Portions of this software were developed by Allan Jude
|
* [1] Portions of this software were developed by Allan Jude
|
||||||
* under sponsorship from the FreeBSD Foundation.
|
* under sponsorship from the FreeBSD Foundation.
|
||||||
* Copyright (c) 2021 Allan Jude
|
* Copyright (c) 2021 Allan Jude
|
||||||
|
* Copyright (c) 2021 Toomas Soome <tsoome@me.com>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
@ -2066,10 +2067,7 @@ dump_history(spa_t *spa)
|
||||||
uint64_t resid, len, off = 0;
|
uint64_t resid, len, off = 0;
|
||||||
uint_t num = 0;
|
uint_t num = 0;
|
||||||
int error;
|
int error;
|
||||||
time_t tsec;
|
|
||||||
struct tm t;
|
|
||||||
char tbuf[30];
|
char tbuf[30];
|
||||||
char internalstr[MAXPATHLEN];
|
|
||||||
|
|
||||||
if ((buf = malloc(SPA_OLD_MAXBLOCKSIZE)) == NULL) {
|
if ((buf = malloc(SPA_OLD_MAXBLOCKSIZE)) == NULL) {
|
||||||
(void) fprintf(stderr, "%s: unable to allocate I/O buffer\n",
|
(void) fprintf(stderr, "%s: unable to allocate I/O buffer\n",
|
||||||
|
@ -2095,38 +2093,81 @@ dump_history(spa_t *spa)
|
||||||
|
|
||||||
(void) printf("\nHistory:\n");
|
(void) printf("\nHistory:\n");
|
||||||
for (unsigned i = 0; i < num; i++) {
|
for (unsigned i = 0; i < num; i++) {
|
||||||
uint64_t time, txg, ievent;
|
|
||||||
char *cmd, *intstr;
|
|
||||||
boolean_t printed = B_FALSE;
|
boolean_t printed = B_FALSE;
|
||||||
|
|
||||||
if (nvlist_lookup_uint64(events[i], ZPOOL_HIST_TIME,
|
if (nvlist_exists(events[i], ZPOOL_HIST_TIME)) {
|
||||||
&time) != 0)
|
time_t tsec;
|
||||||
goto next;
|
struct tm t;
|
||||||
if (nvlist_lookup_string(events[i], ZPOOL_HIST_CMD,
|
|
||||||
&cmd) != 0) {
|
tsec = fnvlist_lookup_uint64(events[i],
|
||||||
if (nvlist_lookup_uint64(events[i],
|
ZPOOL_HIST_TIME);
|
||||||
ZPOOL_HIST_INT_EVENT, &ievent) != 0)
|
(void) localtime_r(&tsec, &t);
|
||||||
goto next;
|
(void) strftime(tbuf, sizeof (tbuf), "%F.%T", &t);
|
||||||
verify(nvlist_lookup_uint64(events[i],
|
} else {
|
||||||
ZPOOL_HIST_TXG, &txg) == 0);
|
tbuf[0] = '\0';
|
||||||
verify(nvlist_lookup_string(events[i],
|
}
|
||||||
ZPOOL_HIST_INT_STR, &intstr) == 0);
|
|
||||||
|
if (nvlist_exists(events[i], ZPOOL_HIST_CMD)) {
|
||||||
|
(void) printf("%s %s\n", tbuf,
|
||||||
|
fnvlist_lookup_string(events[i], ZPOOL_HIST_CMD));
|
||||||
|
} else if (nvlist_exists(events[i], ZPOOL_HIST_INT_EVENT)) {
|
||||||
|
uint64_t ievent;
|
||||||
|
|
||||||
|
ievent = fnvlist_lookup_uint64(events[i],
|
||||||
|
ZPOOL_HIST_INT_EVENT);
|
||||||
if (ievent >= ZFS_NUM_LEGACY_HISTORY_EVENTS)
|
if (ievent >= ZFS_NUM_LEGACY_HISTORY_EVENTS)
|
||||||
goto next;
|
goto next;
|
||||||
|
|
||||||
(void) snprintf(internalstr,
|
(void) printf(" %s [internal %s txg:%ju] %s\n",
|
||||||
sizeof (internalstr),
|
tbuf,
|
||||||
"[internal %s txg:%lld] %s",
|
|
||||||
zfs_history_event_names[ievent],
|
zfs_history_event_names[ievent],
|
||||||
(longlong_t)txg, intstr);
|
fnvlist_lookup_uint64(events[i],
|
||||||
cmd = internalstr;
|
ZPOOL_HIST_TXG),
|
||||||
}
|
fnvlist_lookup_string(events[i],
|
||||||
tsec = time;
|
ZPOOL_HIST_INT_STR));
|
||||||
(void) localtime_r(&tsec, &t);
|
} else if (nvlist_exists(events[i], ZPOOL_HIST_INT_NAME)) {
|
||||||
(void) strftime(tbuf, sizeof (tbuf), "%F.%T", &t);
|
(void) printf("%s [txg:%ju] %s", tbuf,
|
||||||
(void) printf("%s %s\n", tbuf, cmd);
|
fnvlist_lookup_uint64(events[i],
|
||||||
printed = B_TRUE;
|
ZPOOL_HIST_TXG),
|
||||||
|
fnvlist_lookup_string(events[i],
|
||||||
|
ZPOOL_HIST_INT_NAME));
|
||||||
|
|
||||||
|
if (nvlist_exists(events[i], ZPOOL_HIST_DSNAME)) {
|
||||||
|
(void) printf("%s (%llu)",
|
||||||
|
fnvlist_lookup_string(events[i],
|
||||||
|
ZPOOL_HIST_DSNAME),
|
||||||
|
(u_longlong_t)fnvlist_lookup_uint64(
|
||||||
|
events[i],
|
||||||
|
ZPOOL_HIST_DSID));
|
||||||
|
}
|
||||||
|
|
||||||
|
(void) printf(" %s\n", fnvlist_lookup_string(events[i],
|
||||||
|
ZPOOL_HIST_INT_STR));
|
||||||
|
} else if (nvlist_exists(events[i], ZPOOL_HIST_IOCTL)) {
|
||||||
|
(void) printf("%s ioctl %s\n", tbuf,
|
||||||
|
fnvlist_lookup_string(events[i],
|
||||||
|
ZPOOL_HIST_IOCTL));
|
||||||
|
|
||||||
|
if (nvlist_exists(events[i], ZPOOL_HIST_INPUT_NVL)) {
|
||||||
|
(void) printf(" input:\n");
|
||||||
|
dump_nvlist(fnvlist_lookup_nvlist(events[i],
|
||||||
|
ZPOOL_HIST_INPUT_NVL), 8);
|
||||||
|
}
|
||||||
|
if (nvlist_exists(events[i], ZPOOL_HIST_OUTPUT_NVL)) {
|
||||||
|
(void) printf(" output:\n");
|
||||||
|
dump_nvlist(fnvlist_lookup_nvlist(events[i],
|
||||||
|
ZPOOL_HIST_OUTPUT_NVL), 8);
|
||||||
|
}
|
||||||
|
if (nvlist_exists(events[i], ZPOOL_HIST_ERRNO)) {
|
||||||
|
(void) printf(" errno: %lld\n",
|
||||||
|
(longlong_t)fnvlist_lookup_int64(events[i],
|
||||||
|
ZPOOL_HIST_ERRNO));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
goto next;
|
||||||
|
}
|
||||||
|
|
||||||
|
printed = B_TRUE;
|
||||||
next:
|
next:
|
||||||
if (dump_opt['h'] > 1) {
|
if (dump_opt['h'] > 1) {
|
||||||
if (!printed)
|
if (!printed)
|
||||||
|
|
Loading…
Reference in New Issue