diff options
author | Rosen Penev <rosenp@gmail.com> | 2020-08-14 02:18:10 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-08-14 02:18:10 -0700 |
commit | 8d063061bf2df0bc2b7c684fcf0d11e0d3f2459f (patch) | |
tree | 25a4388794e57fa24120f6d4cdc328bab02d77fd | |
parent | 74747b569f9a03825c4772ff96772a4cfcf5da8b (diff) | |
parent | 40b71e324b76ff1124d0532023093058b6b81091 (diff) |
Merge pull request #13112 from neheb/isn
open-isns: fix compilation without deprecated signal API
-rw-r--r-- | net/open-isns/Makefile | 2 | ||||
-rw-r--r-- | net/open-isns/patches/20-signals.patch | 41 |
2 files changed, 42 insertions, 1 deletions
diff --git a/net/open-isns/Makefile b/net/open-isns/Makefile index 12df1260a..f2a0991e5 100644 --- a/net/open-isns/Makefile +++ b/net/open-isns/Makefile @@ -5,7 +5,7 @@ include $(TOPDIR)/rules.mk PKG_NAME:=open-isns PKG_VERSION:=0.100 -PKG_RELEASE:=1 +PKG_RELEASE:=2 PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz PKG_SOURCE_URL:=https://codeload.github.com/open-iscsi/open-isns/tar.gz/v$(PKG_VERSION)? diff --git a/net/open-isns/patches/20-signals.patch b/net/open-isns/patches/20-signals.patch new file mode 100644 index 000000000..898284794 --- /dev/null +++ b/net/open-isns/patches/20-signals.patch @@ -0,0 +1,41 @@ +From e7dac76ce61039fefa58985c955afccb60dabe87 Mon Sep 17 00:00:00 2001 +From: Rosen Penev <rosenp@gmail.com> +Date: Wed, 29 Apr 2020 15:55:55 -0700 +Subject: [PATCH] libisns: remove sighold and sigrelse + +The man page says that these are deprecated. Use sugprocmask as a replacement. +--- + include/libisns/util.h | 16 ++++++++++++---- + 1 file changed, 12 insertions(+), 4 deletions(-) + +diff --git a/include/libisns/util.h b/include/libisns/util.h +index e5ed037..f1b97f0 100644 +--- a/include/libisns/util.h ++++ b/include/libisns/util.h +@@ -41,14 +41,22 @@ char * print_size(unsigned long); + */ + static inline void signals_hold(void) + { +- sighold(SIGTERM); +- sighold(SIGINT); ++ sigset_t s; ++ ++ sigemptyset(&s); ++ sigaddset(&s, SIGTERM); ++ sigaddset(&s, SIGINT); ++ sigprocmask(SIG_BLOCK, &s, 0); + } + + static inline void signals_release(void) + { +- sigrelse(SIGTERM); +- sigrelse(SIGINT); ++ sigset_t s; ++ ++ sigemptyset(&s); ++ sigaddset(&s, SIGTERM); ++ sigaddset(&s, SIGINT); ++ sigprocmask(SIG_UNBLOCK, &s, 0); + } + + /* |