Use sigaction(2) instead of sigignore(3) for portability

sigignore(3) isn't portable.
This code fails to compile on platforms without sigignore(3).
Use sigaction(2).

--
zfs_main.c: In function 'zfs_do_diff':
zfs_main.c:7178:9: error: implicit declaration of function 'sigignore' [-Werror=implicit-function-declaration]
  (void) sigignore(SIGPIPE);
         ^~~~~~~~~

Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Tomohiro Kusumi <kusumi.tomohiro@gmail.com>
Closes #8593
This commit is contained in:
Tomohiro Kusumi 2019-04-10 01:58:28 +09:00 committed by Brian Behlendorf
parent 5b1443c47e
commit 2a15c00f89
1 changed files with 12 additions and 2 deletions

View File

@ -7195,6 +7195,7 @@ zfs_do_diff(int argc, char **argv)
char *atp, *copy; char *atp, *copy;
int err = 0; int err = 0;
int c; int c;
struct sigaction sa;
while ((c = getopt(argc, argv, "FHt")) != -1) { while ((c = getopt(argc, argv, "FHt")) != -1) {
switch (c) { switch (c) {
@ -7252,10 +7253,19 @@ zfs_do_diff(int argc, char **argv)
* Ignore SIGPIPE so that the library can give us * Ignore SIGPIPE so that the library can give us
* information on any failure * information on any failure
*/ */
(void) sigignore(SIGPIPE); if (sigemptyset(&sa.sa_mask) == -1) {
err = errno;
goto out;
}
sa.sa_flags = 0;
sa.sa_handler = SIG_IGN;
if (sigaction(SIGPIPE, &sa, NULL) == -1) {
err = errno;
goto out;
}
err = zfs_show_diffs(zhp, STDOUT_FILENO, fromsnap, tosnap, flags); err = zfs_show_diffs(zhp, STDOUT_FILENO, fromsnap, tosnap, flags);
out:
zfs_close(zhp); zfs_close(zhp);
return (err != 0); return (err != 0);