Gentoo Archives: gentoo-commits

From: William Hubbs <williamh@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: sys-fs/udev/
Date: Mon, 17 Jul 2017 17:50:58
Message-Id: 1500313819.e77fd82b6849268a7ec245855c1f36e52615e120.williamh@gentoo
1 commit: e77fd82b6849268a7ec245855c1f36e52615e120
2 Author: William Hubbs <williamh <AT> gentoo <DOT> org>
3 AuthorDate: Mon Jul 17 17:49:22 2017 +0000
4 Commit: William Hubbs <williamh <AT> gentoo <DOT> org>
5 CommitDate: Mon Jul 17 17:50:19 2017 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e77fd82b
7
8 sys-fs/udev: 234 version bump
9
10 Drop all keywords except for amd64 and x86 due to meson and patchelf.
11
12 Package-Manager: Portage-2.3.6, Repoman-2.3.2
13
14 sys-fs/udev/Manifest | 1 +
15 sys-fs/udev/udev-234.ebuild | 353 ++++++++++++++++++++++++++++++++++++++++++++
16 2 files changed, 354 insertions(+)
17
18 diff --git a/sys-fs/udev/Manifest b/sys-fs/udev/Manifest
19 index 13164cbdeac..1209982a951 100644
20 --- a/sys-fs/udev/Manifest
21 +++ b/sys-fs/udev/Manifest
22 @@ -5,5 +5,6 @@ DIST systemd-229.tar.gz 4319173 SHA256 b51b0a48d1beb388d95bd6a98d62be05490335d4b
23 DIST systemd-230.tar.gz 4288027 SHA256 46b07568142adcd017c62e6230d39eb10d219ed3b2f13ffc12d9a3a6b1c840cd SHA512 a0057c5258055a6b4000eb762ab2ec3c5329361711540f7124ba5c4b1119a1b531ad336ddef3bbe5d08218c8d7f1fd175c86d61357ac72935a932921cff28a96 WHIRLPOOL 95404535eb85d3b8c20dc13b12427a9da1f92729eb9e66a58d7e990f09fee28762be00088897bf1bf485d9a34619799ff0171a161824cc8f135ac2438e978d1e
24 DIST systemd-232.tar.gz 4529048 SHA256 1172c7c7d5d72fbded53186e7599d5272231f04cc8b72f9a0fb2c5c20dfc4880 SHA512 5dbe52f655ec2901b1bfbb1256f83ba26bc82c13097ac9a82e4fbb97886551530f9888c369592f1b410cfff40d6d127b985533a3e29cfab5b30d18739ee5dcb1 WHIRLPOOL f2a1499584c5b5c4d9e945e45ef5e0eef2e8be77acdbd7b3b29a8c8b62dc7a10c162a856df7107c19e2eb19e63bc43a33433686472ca30909237981683cbe980
25 DIST systemd-233.tar.gz 4660737 SHA256 8b3e99da3d4164b66581830a7f2436c0c8fe697b5fbdc3927bdb960646be0083 SHA512 5ad5329ea116d973cf67096f7e7ad28e9ea0905696e9451291f1d25e5064f4a9bfcfae87e912996c6a38397e9f4a148d4ccecfa9b70f7ecdf04deadb61784c8e WHIRLPOOL ce19f6a546b8f899cfa952e49d47f063fd29186be4a53391bc30ea2c487eb2c140a74ad843a1dc499bb61bba3e9ca055613852291e38b85af5d79c59409dc176
26 +DIST systemd-234.tar.gz 4800186 SHA256 da3e69d10aa1c983d33833372ad4929037b411ac421fb085c8cee79ae1d80b6a SHA512 762336a7d96c6583cf71cad62efce95a0ed93cd0a0d7251f128d10dba8200c0c8df0e5a7d168179ababa5b221295a231e73b7e7ea2697cb3fb5c1b33538efa68 WHIRLPOOL 9ff9f25ce82514db969a427eee51c0483b2bcaaa611f93c1fc17c356ea25eee712217708c54101ecaafd835cd8ac988b16e8ad411b48541a32442b9a0d148f07
27 DIST udev-216-patches-2.tar.xz 1264 SHA256 18b7b8f852f11c2ac2a58458462ce686ebec48859562df99c5b9c29c95ddfa3c SHA512 1f5912f3bbc3e40a4efad9de8b1fab2b3a750f3f23c9f2e33a581658959d22cf23f9ff1b8f51597874e7bca1d0f757f37fd5550b4112160261559524eda261f4 WHIRLPOOL 8f93f982de2d1fa10f7e3c6541c559f2c881730276498b14d4d27b8577bdb340d49b2dc7a50a40e8a13fcabbbabb3dfa5f1605aa842e325d12c17e82d2dc787b
28 DIST udev-229-patches-1.tar.xz 996 SHA256 29fe3d2ebbbfed8d30237b79275865ab486ca636282bba40f499b624166e4d2d SHA512 1d6f80311049a441acc49fa88e316e83f4a22a4015e2bfc5b76b6b512ed35b431791acdb11d3bcc4a70913019bb23cfcfaeefcf38bdacace1412a9946cba1a74 WHIRLPOOL 580874fc492e84c66e8f1771d7d4da531f9358802e94b0e4bbbda21f0e08e987295553429c55adba56dcd4c333a231dc2ea2c0a2dc42ac999bb018168f200549
29
30 diff --git a/sys-fs/udev/udev-234.ebuild b/sys-fs/udev/udev-234.ebuild
31 new file mode 100644
32 index 00000000000..a0c39c43d08
33 --- /dev/null
34 +++ b/sys-fs/udev/udev-234.ebuild
35 @@ -0,0 +1,353 @@
36 +# Copyright 1999-2017 Gentoo Foundation
37 +# Distributed under the terms of the GNU General Public License v2
38 +
39 +EAPI=6
40 +
41 +inherit bash-completion-r1 linux-info meson ninja-utils multilib-minimal toolchain-funcs udev user versionator
42 +
43 +if [[ ${PV} = 9999* ]]; then
44 + EGIT_REPO_URI="https://github.com/systemd/systemd.git"
45 + inherit git-r3
46 +else
47 + patchset=
48 + SRC_URI="https://github.com/systemd/systemd/archive/v${PV}.tar.gz -> systemd-${PV}.tar.gz"
49 + if [[ -n "${patchset}" ]]; then
50 + SRC_URI+="
51 + https://dev.gentoo.org/~williamh/dist/${P}-patches-${patchset}.tar.xz
52 + https://dev.gentoo.org/~ssuominen/${P}-patches-${patchset}.tar.xz"
53 + fi
54 + KEYWORDS="~amd64 ~x86"
55 +fi
56 +
57 +DESCRIPTION="Linux dynamic and persistent device naming support (aka userspace devfs)"
58 +HOMEPAGE="https://www.freedesktop.org/wiki/Software/systemd"
59 +
60 +LICENSE="LGPL-2.1 MIT GPL-2"
61 +SLOT="0"
62 +IUSE="acl +kmod selinux"
63 +
64 +RESTRICT="test"
65 +
66 +COMMON_DEPEND=">=sys-apps/util-linux-2.27.1[${MULTILIB_USEDEP}]
67 + sys-libs/libcap[${MULTILIB_USEDEP}]
68 + acl? ( sys-apps/acl )
69 + kmod? ( >=sys-apps/kmod-16 )
70 + selinux? ( >=sys-libs/libselinux-2.1.9 )
71 + !<sys-libs/glibc-2.11
72 + !sys-apps/gentoo-systemd-integration
73 + !sys-apps/systemd
74 + abi_x86_32? (
75 + !<=app-emulation/emul-linux-x86-baselibs-20130224-r7
76 + !app-emulation/emul-linux-x86-baselibs[-abi_x86_32(-)]
77 + )"
78 +DEPEND="${COMMON_DEPEND}
79 + dev-util/gperf
80 + >=dev-util/intltool-0.50
81 + >=dev-util/meson-0.40.0
82 + dev-util/ninja
83 + >=dev-util/patchelf-0.9
84 + >=sys-apps/coreutils-8.16
85 + virtual/os-headers
86 + virtual/pkgconfig
87 + >=sys-kernel/linux-headers-3.9
88 + app-text/docbook-xml-dtd:4.2
89 + app-text/docbook-xml-dtd:4.5
90 + app-text/docbook-xsl-stylesheets
91 + dev-libs/libxslt"
92 +RDEPEND="${COMMON_DEPEND}
93 + !<sys-fs/lvm2-2.02.103
94 + !<sec-policy/selinux-base-2.20120725-r10"
95 +PDEPEND=">=sys-apps/hwids-20140304[udev]
96 + >=sys-fs/udev-init-scripts-26"
97 +
98 +S=${WORKDIR}/systemd-${PV}
99 +EGIT_CHECKOUT_DIR=${S}
100 +
101 +pkg_setup() {
102 + if [[ ${MERGE_TYPE} != buildonly ]]; then
103 + CONFIG_CHECK="~BLK_DEV_BSG ~DEVTMPFS ~!IDE ~INOTIFY_USER ~!SYSFS_DEPRECATED ~!SYSFS_DEPRECATED_V2 ~SIGNALFD ~EPOLL ~FHANDLE ~NET ~!FW_LOADER_USER_HELPER ~UNIX"
104 + linux-info_pkg_setup
105 +
106 + # CONFIG_FHANDLE was introduced by 2.6.39
107 + local MINKV=2.6.39
108 +
109 + if kernel_is -lt ${MINKV//./ }; then
110 + eerror "Your running kernel is too old to run this version of ${P}"
111 + eerror "You need to upgrade kernel at least to ${MINKV}"
112 + fi
113 +
114 + if kernel_is -lt 3 7; then
115 + ewarn "Your running kernel is too old to have firmware loader and"
116 + ewarn "this version of ${P} doesn't have userspace firmware loader"
117 + ewarn "If you need firmware support, you need to upgrade kernel at least to 3.7"
118 + fi
119 + fi
120 +}
121 +
122 +src_prepare() {
123 + if ! [[ ${PV} = 9999* ]]; then
124 + # secure_getenv() disable for non-glibc systems wrt bug #443030
125 + if ! [[ $(grep -r secure_getenv * | wc -l) -eq 27 ]]; then
126 + eerror "The line count for secure_getenv() failed, see bug #443030"
127 + die
128 + fi
129 + fi
130 +
131 + # backport some patches
132 + if [[ -n "${patchset}" ]]; then
133 + eapply "${WORKDIR}"/patch
134 + fi
135 +
136 + cat <<-EOF > "${T}"/40-gentoo.rules
137 + # Gentoo specific floppy and usb groups
138 + ACTION=="add", SUBSYSTEM=="block", KERNEL=="fd[0-9]", GROUP="floppy"
139 + ACTION=="add", SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", GROUP="usb"
140 + EOF
141 +
142 + # change rules back to group uucp instead of dialout for now wrt #454556
143 + sed -i -e 's/GROUP="dialout"/GROUP="uucp"/' rules/*.rules || die
144 +
145 + # apply user patches
146 + eapply_user
147 +
148 + if ! use elibc_glibc; then #443030
149 + echo '#define secure_getenv(x) NULL' >> config.h.in
150 + sed -i -e '/error.*secure_getenv/s:.*:#define secure_getenv(x) NULL:' src/shared/missing.h || die
151 + fi
152 +}
153 +
154 +meson_multilib_native_use() {
155 + if multilib_is_native_abi && use "$1"; then
156 + echo true
157 + else
158 + echo false
159 + fi
160 +}
161 +
162 +multilib_src_configure() {
163 + local emesonargs=(
164 + -Dacl=$(meson_multilib_native_use acl)
165 + -Defi=false
166 + -Dkmod=$(meson_multilib_native_use kmod)
167 + -Dselinux=$(meson_multilib_native_use selinux)
168 + -Dlink-udev-shared=false
169 + -Dsplit-usr=true
170 + )
171 + meson_src_configure
172 +}
173 +
174 +src_configure() {
175 + # Prevent conflicts with i686 cross toolchain, bug 559726
176 + tc-export AR CC NM OBJCOPY RANLIB
177 + multilib-minimal_src_configure
178 +}
179 +
180 +multilib_src_compile() {
181 + # meson creates this link
182 + local libudev=$(readlink src/libudev/libudev.so.1)
183 +
184 + local targets=(
185 + src/libudev/${libudev}
186 + )
187 + if multilib_is_native_abi; then
188 + targets+=(
189 + systemd-udevd
190 + udevadm
191 + src/udev/ata_id
192 + src/udev/cdrom_id
193 + src/udev/collect
194 + src/udev/mtd_probe
195 + src/udev/scsi_id
196 + src/udev/v4l_id
197 + man/udev.conf.5
198 + man/systemd.link.5
199 + man/hwdb.7
200 + man/udev.7
201 + man/systemd-udevd.service.8
202 + man/udevadm.8
203 + )
204 + fi
205 + eninja "${targets[@]}"
206 +}
207 +
208 +# meson uses an private python script for this
209 +strip_rpath() {
210 + local x
211 + for x; do
212 + patchelf --remove-rpath "${x}" || die
213 + done
214 +}
215 +
216 +multilib_src_install() {
217 + local libudev=$(readlink src/libudev/libudev.so.1)
218 +
219 + into /
220 + strip_rpath src/libudev/${libudev}
221 + dolib.so src/libudev/{${libudev},libudev.so.1,libudev.so}
222 +
223 + insinto "/usr/$(get_libdir)/pkgconfig"
224 + doins src/libudev/libudev.pc
225 +
226 + if multilib_is_native_abi; then
227 + into /
228 + strip_rpath udevadm
229 + dobin udevadm
230 +
231 + exeinto /lib/systemd
232 + strip_rpath systemd-udevd
233 + doexe systemd-udevd
234 +
235 + exeinto /lib/udev
236 + strip_rpath src/udev/{ata_id,cdrom_id,collect,mtd_probe,scsi_id,v4l_id}
237 + doexe src/udev/{ata_id,cdrom_id,collect,mtd_probe,scsi_id,v4l_id}
238 +
239 + rm rules/99-systemd.rules || die
240 + insinto /lib/udev/rules.d
241 + doins rules/*.rules
242 +
243 + insinto /usr/share/pkgconfig
244 + doins src/udev/udev.pc
245 +
246 + mv man/systemd-udevd.service.8 man/systemd-udevd.8 || die
247 + rm man/systemd-udevd-{control,kernel}.socket.8 || die
248 + doman man/*.[0-9]
249 + fi
250 +}
251 +
252 +multilib_src_install_all() {
253 + doheader src/libudev/libudev.h
254 +
255 + insinto /etc/udev
256 + doins src/udev/udev.conf
257 +
258 + insinto /lib/systemd/network
259 + doins network/99-default.link
260 +
261 + # see src_prepare() for content of 40-gentoo.rules
262 + insinto /lib/udev/rules.d
263 + doins "${T}"/40-gentoo.rules
264 + doins "${S}"/rules/*.rules
265 +
266 + dobashcomp shell-completion/bash/udevadm
267 +
268 + insinto /usr/share/zsh/site-functions
269 + doins shell-completion/zsh/_udevadm
270 +
271 + einstalldocs
272 +}
273 +
274 +pkg_postinst() {
275 + mkdir -p "${ROOT%/}"/run
276 +
277 + # "losetup -f" is confused if there is an empty /dev/loop/, Bug #338766
278 + # So try to remove it here (will only work if empty).
279 + rmdir "${ROOT%/}"/dev/loop 2>/dev/null
280 + if [[ -d ${ROOT%/}/dev/loop ]]; then
281 + ewarn "Please make sure your remove /dev/loop,"
282 + ewarn "else losetup may be confused when looking for unused devices."
283 + fi
284 +
285 + local fstab="${ROOT%/}"/etc/fstab dev path fstype rest
286 + while read -r dev path fstype rest; do
287 + if [[ ${path} == /dev && ${fstype} != devtmpfs ]]; then
288 + ewarn "You need to edit your /dev line in ${fstab} to have devtmpfs"
289 + ewarn "filesystem. Otherwise udev won't be able to boot."
290 + ewarn "See, https://bugs.gentoo.org/453186"
291 + fi
292 + done < "${fstab}"
293 +
294 + if [[ -d ${ROOT%/}/usr/lib/udev ]]; then
295 + ewarn
296 + ewarn "Please re-emerge all packages on your system which install"
297 + ewarn "rules and helpers in /usr/lib/udev. They should now be in"
298 + ewarn "/lib/udev."
299 + ewarn
300 + ewarn "One way to do this is to run the following command:"
301 + ewarn "emerge -av1 \$(qfile -q -S -C /usr/lib/udev)"
302 + ewarn "Note that qfile can be found in app-portage/portage-utils"
303 + fi
304 +
305 + local old_cd_rules="${ROOT%/}"/etc/udev/rules.d/70-persistent-cd.rules
306 + local old_net_rules="${ROOT%/}"/etc/udev/rules.d/70-persistent-net.rules
307 + for old_rules in "${old_cd_rules}" "${old_net_rules}"; do
308 + if [[ -f ${old_rules} ]]; then
309 + ewarn
310 + ewarn "File ${old_rules} is from old udev installation but if you still use it,"
311 + ewarn "rename it to something else starting with 70- to silence this deprecation"
312 + ewarn "warning."
313 + fi
314 + done
315 +
316 + elog
317 + elog "Starting from version >= 197 the new predictable network interface names are"
318 + elog "used by default, see:"
319 + elog "https://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames"
320 + elog "https://cgit.freedesktop.org/systemd/systemd/tree/src/udev/udev-builtin-net_id.c"
321 + elog
322 + elog "Example command to get the information for the new interface name before booting"
323 + elog "(replace <ifname> with, for example, eth0):"
324 + elog "# udevadm test-builtin net_id /sys/class/net/<ifname> 2> /dev/null"
325 + elog
326 + elog "You can use either kernel parameter \"net.ifnames=0\", create empty"
327 + elog "file /etc/systemd/network/99-default.link, or symlink it to /dev/null"
328 + elog "to disable the feature."
329 +
330 + if has_version 'sys-apps/biosdevname'; then
331 + ewarn
332 + ewarn "You can replace the functionality of sys-apps/biosdevname which has been"
333 + ewarn "detected to be installed with the new predictable network interface names."
334 + fi
335 +
336 + ewarn
337 + ewarn "You need to restart udev as soon as possible to make the upgrade go"
338 + ewarn "into effect."
339 + ewarn "The method you use to do this depends on your init system."
340 + if has_version 'sys-apps/openrc'; then
341 + ewarn "For sys-apps/openrc users it is:"
342 + ewarn "# /etc/init.d/udev --nodeps restart"
343 + fi
344 +
345 + elog
346 + elog "For more information on udev on Gentoo, upgrading, writing udev rules, and"
347 + elog "fixing known issues visit:"
348 + elog "https://wiki.gentoo.org/wiki/Udev"
349 + elog "https://wiki.gentoo.org/wiki/Udev/upgrade"
350 +
351 + # If user has disabled 80-net-name-slot.rules using a empty file or a symlink to /dev/null,
352 + # do the same for 80-net-setup-link.rules to keep the old behavior
353 + local net_move=no
354 + local net_name_slot_sym=no
355 + local net_rules_path="${ROOT%/}"/etc/udev/rules.d
356 + local net_name_slot="${net_rules_path}"/80-net-name-slot.rules
357 + local net_setup_link="${net_rules_path}"/80-net-setup-link.rules
358 + if [[ ! -e ${net_setup_link} ]]; then
359 + [[ -f ${net_name_slot} && $(sed -e "/^#/d" -e "/^\W*$/d" ${net_name_slot} | wc -l) == 0 ]] && net_move=yes
360 + if [[ -L ${net_name_slot} && $(readlink ${net_name_slot}) == /dev/null ]]; then
361 + net_move=yes
362 + net_name_slot_sym=yes
363 + fi
364 + fi
365 + if [[ ${net_move} == yes ]]; then
366 + ebegin "Copying ${net_name_slot} to ${net_setup_link}"
367 +
368 + if [[ ${net_name_slot_sym} == yes ]]; then
369 + ln -nfs /dev/null "${net_setup_link}"
370 + else
371 + cp "${net_name_slot}" "${net_setup_link}"
372 + fi
373 + eend $?
374 + fi
375 +
376 + # https://cgit.freedesktop.org/systemd/systemd/commit/rules/50-udev-default.rules?id=3dff3e00e044e2d53c76fa842b9a4759d4a50e69
377 + # https://bugs.gentoo.org/246847
378 + # https://bugs.gentoo.org/514174
379 + enewgroup input
380 +
381 + # Update hwdb database in case the format is changed by udev version.
382 + if has_version 'sys-apps/hwids[udev]'; then
383 + udevadm hwdb --update --root="${ROOT%/}"
384 + # Only reload when we are not upgrading to avoid potential race w/ incompatible hwdb.bin and the running udevd
385 + # https://cgit.freedesktop.org/systemd/systemd/commit/?id=1fab57c209035f7e66198343074e9cee06718bda
386 + [[ -z ${REPLACING_VERSIONS} ]] && udev_reload
387 + fi
388 +}