diff options
| author | Kirill Ponomarev <krion@FreeBSD.org> | 2004-02-24 21:55:22 +0000 |
|---|---|---|
| committer | Kirill Ponomarev <krion@FreeBSD.org> | 2004-02-24 21:55:22 +0000 |
| commit | 11ad482d5f67a4fdc76b69aee95d73883be45588 (patch) | |
| tree | 72dee68c712118345552b0209acea8e1462de7c8 /sysutils/e2fsprogs/files/patch-SIGINFO-e2fck_unix.c | |
| parent | - Update to version 20040212 (diff) | |
- e2fsck now handles SIGINFO (Ctrl+T): print progress bar once
- Bugfix: fsck_ext2fs would abort the boot when run as part of
/etc/rc and e2fsck had repaired a file system. fsck_ext2fs
now maps exit codes 0 to 3 from e2fsck to 0. If e2fsck is
aborted by a signal or an exit code of 4 or higher, maps to
EXIT_FAILURE.
PR: ports/63320
Submitted by: maintainer
Diffstat (limited to 'sysutils/e2fsprogs/files/patch-SIGINFO-e2fck_unix.c')
| -rw-r--r-- | sysutils/e2fsprogs/files/patch-SIGINFO-e2fck_unix.c | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/sysutils/e2fsprogs/files/patch-SIGINFO-e2fck_unix.c b/sysutils/e2fsprogs/files/patch-SIGINFO-e2fck_unix.c new file mode 100644 index 000000000000..fa10795ad942 --- /dev/null +++ b/sysutils/e2fsprogs/files/patch-SIGINFO-e2fck_unix.c @@ -0,0 +1,54 @@ +--- e2fsprogs-1.35/e2fsck/unix.c~ Sun Dec 7 18:11:38 2003 ++++ e2fsprogs-1.35/e2fsck/unix.c Tue Feb 24 22:13:52 2004 +@@ -416,6 +416,24 @@ + return 0; + } + ++static int e2fsck_progress_once(e2fsck_t ctx, int pass, unsigned long cur, unsigned long max) ++{ ++ char buf[80]; ++ float percent; ++ ++ if (pass == 0) ++ return 0; ++ ++ percent = calc_percent(&e2fsck_tbl, pass, cur, max); ++ e2fsck_simple_progress(ctx, ctx->device_name, ++ percent, 0); ++ ++ printf("\n"); ++ ctx->progress = 0; ++ return 0; ++} ++ ++ + #define PATH_SET "PATH=/sbin" + + static void reserve_stdio_fds(void) +@@ -448,6 +466,17 @@ + ctx->progress_fd = 0; + } + ++static void signal_progress_now(int sig EXT2FS_ATTR((unused))) ++{ ++ e2fsck_t ctx = e2fsck_global_ctx; ++ ++ if (!ctx) ++ return; ++ ++ ctx->progress = e2fsck_progress_once; ++ ctx->progress_fd = 0; ++} ++ + static void signal_progress_off(int sig EXT2FS_ATTR((unused))) + { + e2fsck_t ctx = e2fsck_global_ctx; +@@ -740,6 +769,8 @@ + sigaction(SIGUSR1, &sa, 0); + sa.sa_handler = signal_progress_off; + sigaction(SIGUSR2, &sa, 0); ++ sa.sa_handler = signal_progress_now; ++ sigaction(SIGINFO, &sa, 0); + #endif + + /* Update our PATH to include /sbin if we need to run badblocks */ |
