Gentoo Archives: gentoo-commits

From: Thomas Deutschmann <whissi@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: sys-block/open-iscsi/files/, sys-block/open-iscsi/
Date: Sat, 08 Sep 2018 18:40:11
Message-Id: 1536431987.f6b63795ab790ba89aecbe08c831be87b02ea780.whissi@gentoo
1 commit: f6b63795ab790ba89aecbe08c831be87b02ea780
2 Author: Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
3 AuthorDate: Sat Sep 8 18:31:21 2018 +0000
4 Commit: Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
5 CommitDate: Sat Sep 8 18:39:47 2018 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f6b63795
7
8 sys-block/open-iscsi: add snapshot version to allow building against gcc-8
9
10 Closes: https://bugs.gentoo.org/660970
11 Package-Manager: Portage-2.3.49, Repoman-2.3.10
12
13 sys-block/open-iscsi/Manifest | 1 +
14 .../open-iscsi-2.0.876_p20180814-musl-fixes.patch | 85 ++++++++++++++
15 .../open-iscsi/open-iscsi-2.0.876_p20180814.ebuild | 125 +++++++++++++++++++++
16 3 files changed, 211 insertions(+)
17
18 diff --git a/sys-block/open-iscsi/Manifest b/sys-block/open-iscsi/Manifest
19 index e8a6d18310e..069168c6adc 100644
20 --- a/sys-block/open-iscsi/Manifest
21 +++ b/sys-block/open-iscsi/Manifest
22 @@ -3,3 +3,4 @@ DIST open-iscsi-2.0-873.tar.gz 667069 BLAKE2B edb427f8483c31499cdde644bbf8d65895
23 DIST open-iscsi-2.0.874.tar.gz 625039 BLAKE2B 39e4b818b1c977d43aa6490acd4d65e688c8cd03a7ae4c03d18d6b81aa76773b0a1227b3e8d975f2a14108075bb680434ded5337db296839bd5be012130df9df SHA512 66d8a52b6401229d51873f1ee0f4e7259a8ed584800403a41741c7eeedc0ec21a2b116671cb7259f60918d083ffb46d76860236a1b10fbb94a4c1d61bddae1ae
24 DIST open-iscsi-2.0.875.tar.gz 635121 BLAKE2B 34a7083087c53ed0e59d293d26efe166b09c5ea18b6022869cc9ff3d2edb2fb8b69e2c1ce6c9011bd20fc590b02dafd6d7c13d8bfa1eae6408c4bace13992e5e SHA512 1709011d7d12d3dd9278a0d775af064d5f7da37357f35d6d5c5b3aa8ec16385c28b201b1261f4581dbbbbca3d815015ed8696e1694aa19f3231132f90d1e5b36
25 DIST open-iscsi-2.0.876.tar.gz 576111 BLAKE2B 2fbe4f37e91730d15bad77feeb9a418a8bbf709582598571a5905080eb60649f3ece6a52e9cf94a28128f2b0bc30093e67f6a47624545243b10bcebe318750ac SHA512 f9319016bd6abf3bf675ad050b0489095a21db58c93f9baaca6adc239129ad08f8e18ed96c91c36406e5c42d35118e67dfde6d3c37e97027467c4472db3b2422
26 +DIST open-iscsi-2.0.876_p20180814.tar.gz 602779 BLAKE2B 8403d69ef43c868a009e1b7bf6e67ea0ecc0d10113b842e1f853a759398f56bb447f6c6ce5474bb2f4e9dfe59d9effc5eea58a1e7da9bbfd81c370eba1759edc SHA512 d79b3025888a8b6db944c86abb13940a6c75fe10166d79ab7e242fc108603e86a81c2ea3448318a45f0e51d89d45a21bda5ab43cf75ff759007e1949030ad0bf
27
28 diff --git a/sys-block/open-iscsi/files/open-iscsi-2.0.876_p20180814-musl-fixes.patch b/sys-block/open-iscsi/files/open-iscsi-2.0.876_p20180814-musl-fixes.patch
29 new file mode 100644
30 index 00000000000..68b1bca7c7c
31 --- /dev/null
32 +++ b/sys-block/open-iscsi/files/open-iscsi-2.0.876_p20180814-musl-fixes.patch
33 @@ -0,0 +1,85 @@
34 +--- a/usr/idbm.c
35 ++++ b/usr/idbm.c
36 +@@ -27,2 +27,3 @@
37 + #include <errno.h>
38 ++#include <fcntl.h>
39 + #include <dirent.h>
40 +--- a/usr/iscsiadm.c
41 ++++ b/usr/iscsiadm.c
42 +@@ -3269,2 +3269,3 @@
43 + int do_discover = 0, sub_mode = -1;
44 ++ int argerror = 0;
45 + int portal_type = -1;
46 +@@ -3458,2 +3459,5 @@
47 + usage(0);
48 ++ case '?':
49 ++ log_error("unrecognized character '%c'", optopt);
50 ++ argerror = 1;
51 + }
52 +@@ -3473,4 +3477,3 @@
53 +
54 +- if (optopt) {
55 +- log_error("unrecognized character '%c'", optopt);
56 ++ if (argerror) {
57 + rc = ISCSI_ERR_INVAL;
58 +--- a/iscsiuio/src/unix/libs/bnx2x.c
59 ++++ b/iscsiuio/src/unix/libs/bnx2x.c
60 +@@ -44,3 +44,3 @@
61 + #include <linux/sockios.h>
62 +-#include <linux/ethtool.h>
63 ++#include "ethtool-compat.h"
64 + #include <sys/mman.h>
65 +--- /dev/null
66 ++++ b/iscsiuio/src/unix/libs/ethtool-compat.h
67 +@@ -0,0 +1,51 @@
68 ++/*
69 ++ * ethtool-compat.h: adopted from
70 ++ # ethtool.h: Defines for Linux ethtool.
71 ++ *
72 ++ * Copyright (C) 1998 David S. Miller (davem@××××××.com)
73 ++ * Copyright 2001 Jeff Garzik <jgarzik@×××××.com>
74 ++ * Portions Copyright 2001 Sun Microsystems (thockin@×××.com)
75 ++ * Portions Copyright 2002 Intel (eli.kupermann@×××××.com,
76 ++ * christopher.leech@×××××.com,
77 ++ * scott.feldman@×××××.com)
78 ++ * Portions Copyright (C) Sun Microsystems 2008
79 ++ */
80 ++
81 ++#include <linux/types.h>
82 ++#include <netinet/if_ether.h>
83 ++
84 ++#define ETHTOOL_FWVERS_LEN 32
85 ++#define ETHTOOL_BUSINFO_LEN 32
86 ++#define ETHTOOL_EROMVERS_LEN 32
87 ++
88 ++struct ethtool_drvinfo {
89 ++ __u32 cmd;
90 ++ char driver[32];
91 ++ char version[32];
92 ++ char fw_version[ETHTOOL_FWVERS_LEN];
93 ++ char bus_info[ETHTOOL_BUSINFO_LEN];
94 ++ char erom_version[ETHTOOL_EROMVERS_LEN];
95 ++ char reserved2[12];
96 ++ __u32 n_priv_flags;
97 ++ __u32 n_stats;
98 ++ __u32 testinfo_len;
99 ++ __u32 eedump_len;
100 ++ __u32 regdump_len;
101 ++};
102 ++
103 ++struct ethtool_tcpip4_spec {
104 ++ __be32 ip4src;
105 ++ __be32 ip4dst;
106 ++ __be16 psrc;
107 ++ __be16 pdst;
108 ++ __u8 tos;
109 ++};
110 ++
111 ++struct ethtool_ah_espip4_spec {
112 ++ __be32 ip4src;
113 ++ __be32 ip4dst;
114 ++ __be32 spi;
115 ++ __u8 tos;
116 ++};
117 ++
118 ++#define ETHTOOL_GDRVINFO 0x00000003 /* Get driver info. */
119
120 diff --git a/sys-block/open-iscsi/open-iscsi-2.0.876_p20180814.ebuild b/sys-block/open-iscsi/open-iscsi-2.0.876_p20180814.ebuild
121 new file mode 100644
122 index 00000000000..b111b48a68e
123 --- /dev/null
124 +++ b/sys-block/open-iscsi/open-iscsi-2.0.876_p20180814.ebuild
125 @@ -0,0 +1,125 @@
126 +# Copyright 1999-2018 Gentoo Foundation
127 +# Distributed under the terms of the GNU General Public License v2
128 +
129 +EAPI="6"
130 +
131 +inherit autotools linux-info flag-o-matic toolchain-funcs udev systemd
132 +
133 +MY_COMMIT="96c1a8e344d93594a3bb4faa848f878cc7315bde"
134 +
135 +DESCRIPTION="A performant, transport independent, multi-platform implementation of RFC3720"
136 +HOMEPAGE="http://www.open-iscsi.com/"
137 +SRC_URI="https://github.com/${PN}/${PN}/archive/${MY_COMMIT}.tar.gz -> ${P}.tar.gz"
138 +
139 +LICENSE="GPL-2"
140 +SLOT="0/0.2"
141 +KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86"
142 +IUSE="debug infiniband +tcp rdma"
143 +
144 +DEPEND="sys-block/open-isns:=
145 + infiniband? ( sys-fabric/ofed )
146 + sys-kernel/linux-headers"
147 +RDEPEND="${DEPEND}
148 + sys-fs/lsscsi
149 + sys-apps/util-linux"
150 +REQUIRED_USE="infiniband? ( rdma ) || ( rdma tcp )"
151 +
152 +PATCHES=(
153 + "${FILESDIR}/${PN}-2.0.876_p20180814-musl-fixes.patch"
154 + "${FILESDIR}/${PN}-2.0.876-Makefiles.patch"
155 +)
156 +
157 +S="${WORKDIR}/${PN}-${MY_COMMIT}"
158 +
159 +pkg_setup() {
160 + linux-info_pkg_setup
161 +
162 + if kernel_is -lt 2 6 16; then
163 + die "Sorry, your kernel must be 2.6.16-rc5 or newer!"
164 + fi
165 +
166 + # Needs to be done, as iscsid currently only starts, when having the iSCSI
167 + # support loaded as module. Kernel builtin options don't work. See this for
168 + # more information:
169 + # https://groups.google.com/group/open-iscsi/browse_thread/thread/cc10498655b40507/fd6a4ba0c8e91966
170 + # If there's a new release, check whether this is still valid!
171 + TCP_MODULES="SCSI_ISCSI_ATTRS ISCSI_TCP"
172 + RDMA_MODULES="INFINIBAND_ISER"
173 + INFINIBAND_MODULES="INFINIBAND_IPOIB INIBAND_USER_MAD INFINIBAND_USER_ACCESS"
174 + CONFIG_CHECK_MODULES="tcp? ( ${TCP_MODULES} ) rdma? ( ${RDMA_MODULES} ) infiniband? ( ${INFINIBAND_MODULES} )"
175 + if linux_config_exists; then
176 + if use tcp; then
177 + for module in ${TCP_MODULES}; do
178 + linux_chkconfig_module ${module} || ewarn "${module} needs to be built as module (builtin doesn't work)"
179 + done
180 + fi
181 + if use infiniband; then
182 + for module in ${INFINIBAND_MODULES}; do
183 + linux_chkconfig_module ${module} || ewarn "${module} needs to be built as module (builtin doesn't work)"
184 + done
185 + fi
186 + if use rdma; then
187 + for module in ${RDMA_MODULES}; do
188 + linux_chkconfig_module ${module} || ewarn "${module} needs to be built as module (builtin doesn't work)"$
189 + done
190 + fi
191 + fi
192 +}
193 +
194 +src_prepare() {
195 + sed -i -e 's:^\(iscsid.startup\)\s*=.*:\1 = /usr/sbin/iscsid:' etc/iscsid.conf || die
196 + default
197 +
198 + pushd iscsiuio >/dev/null || die
199 + eautoreconf
200 + popd >/dev/null || die
201 +}
202 +
203 +src_configure() {
204 + use debug && append-cppflags -DDEBUG_TCP -DDEBUG_SCSI
205 + append-lfs-flags
206 +}
207 +
208 +src_compile() {
209 + # Stuffing CPPFLAGS into CFLAGS isn't entirely correct, but the build
210 + # is messed up already here, so it's not making it that much worse.
211 + KSRC="${KV_DIR}" CFLAGS="" \
212 + emake \
213 + OPTFLAGS="${CFLAGS} ${CPPFLAGS}" \
214 + AR="$(tc-getAR)" CC="$(tc-getCC)" \
215 + user
216 +}
217 +
218 +src_install() {
219 + emake DESTDIR="${ED}" sbindir="/usr/sbin" install
220 + # Upstream make is not deterministic, per bug #601514
221 + rm -f "${ED}"/etc/initiatorname.iscsi
222 +
223 + dodoc README THANKS
224 +
225 + docinto test/
226 + dodoc test/*
227 +
228 + insinto /etc/iscsi
229 + newins "${FILESDIR}"/initiatorname.iscsi initiatorname.iscsi.example
230 +
231 + newconfd "${FILESDIR}"/iscsid-conf.d iscsid
232 + newinitd "${FILESDIR}"/iscsid-init.d iscsid
233 +
234 + systemd_dounit "${S%/}"/etc/systemd/iscsid.service
235 +
236 + keepdir /var/db/iscsi
237 + fperms 700 /var/db/iscsi
238 + fperms 600 /etc/iscsi/iscsid.conf
239 +}
240 +
241 +pkg_postinst() {
242 + in='/etc/iscsi/initiatorname.iscsi'
243 + if [ ! -f "${EROOT}${in}" -a -f "${EROOT}${in}.example" ]; then
244 + {
245 + cat "${EROOT}${in}.example"
246 + echo "# InitiatorName generated by ${CATEGORY}/${PF} at $(date -uR)"
247 + echo "InitiatorName=$(${ROOT}/usr/sbin/iscsi-iname)"
248 + } >> "${EROOT}${in}.tmp" && mv -f "${EROOT}${in}.tmp" "${EROOT}${in}"
249 + fi
250 +}