diff mbox series

[1/1] package/procps-ng: link the w command with systemd or elogin libs.

Message ID 20240914172710.2917184-1-hugo.cornelis@essensium.com
State Accepted
Headers show
Series [1/1] package/procps-ng: link the w command with systemd or elogin libs. | expand

Commit Message

Hugo Cornelis Sept. 14, 2024, 5:27 p.m. UTC
The build of procps-ng was broken when systemd was enabled.  Applying
commit ca004d46 of procps-ng upstream to explictly link the 'w'
command to libsystemd or elogind even though libproc2 is linked to it.

This was (likely) broken since the upgrade to procps-ng v4.0.4 with
commit d79f40dbbe98983bc657d4c82d46b38b8283351b.

Fixes: http://autobuild.buildroot.org/results/e8b/e8bae7bfd7d6a7987f3afa199d8d944429144817/build-end.log
Signed-off-by: Hugo Cornelis <hugo.cornelis@essensium.com>
---
 ...1-build-sys-Add-systemd-elogind-to-w.patch | 48 +++++++++++++++++++
 package/procps-ng/procps-ng.mk                |  3 ++
 2 files changed, 51 insertions(+)
 create mode 100644 package/procps-ng/0001-build-sys-Add-systemd-elogind-to-w.patch

Comments

Yann E. MORIN Sept. 14, 2024, 6:45 p.m. UTC | #1
On 2024-09-14 19:27 +0200, Hugo Cornelis via buildroot spake thusly:
> The build of procps-ng was broken when systemd was enabled.  Applying
> commit ca004d46 of procps-ng upstream to explictly link the 'w'
> command to libsystemd or elogind even though libproc2 is linked to it.
> 
> This was (likely) broken since the upgrade to procps-ng v4.0.4 with
> commit d79f40dbbe98983bc657d4c82d46b38b8283351b.
> 
> Fixes: http://autobuild.buildroot.org/results/e8b/e8bae7bfd7d6a7987f3afa199d8d944429144817/build-end.log

I've also added Fixes: tag for the issue in gitlab:
    https://gitlab.com/buildroot.org/buildroot/-/issues/28

(But that did not actually auto-closed the issue, unfortunately, but
obviously that's not on you.)

> Signed-off-by: Hugo Cornelis <hugo.cornelis@essensium.com>
> ---
>  ...1-build-sys-Add-systemd-elogind-to-w.patch | 48 +++++++++++++++++++
>  package/procps-ng/procps-ng.mk                |  3 ++
>  2 files changed, 51 insertions(+)
>  create mode 100644 package/procps-ng/0001-build-sys-Add-systemd-elogind-to-w.patch
> 
> diff --git a/package/procps-ng/0001-build-sys-Add-systemd-elogind-to-w.patch b/package/procps-ng/0001-build-sys-Add-systemd-elogind-to-w.patch
> new file mode 100644
> index 0000000000..3fecb4746d
> --- /dev/null
> +++ b/package/procps-ng/0001-build-sys-Add-systemd-elogind-to-w.patch
> @@ -0,0 +1,48 @@
> +From 788248ee631b3b5f82073c36320fc3f4a3c8f9ba Mon Sep 17 00:00:00 2001
> +From: Craig Small <csmall@dropbear.xyz>
> +Date: Thu, 31 Aug 2023 22:24:23 +1000
> +Subject: [PATCH 1/1] build-sys: Add systemd/elogind to w

    $ ./utils/docker-run make check-package
    package/procps-ng/0001-build-sys-Add-systemd-elogind-to-w.patch:4: generate your patches with 'git format-patch -N'

I've fixed that when applying to master, thanks!

Regards,
Yann E. MORIN.

> +Depending on the compiler flags, w needs to be explictly linked
> +to libsystemd or elogind even though libproc2 is linked to it.
> +
> +Signed-off-by: Craig Small <csmall@dropbear.xyz>
> +Upstream: https://gitlab.com/procps-ng/procps/-/commit/ca004d4657d5e8b468a4552ede429be53193a3a9
> +Signed-off-by: Hugo Cornelis <hugo.cornelis@essensium.com>
> +---
> + Makefile.am | 7 +++++++
> + NEWS        | 3 +++
> + 2 files changed, 10 insertions(+)
> +
> +diff --git a/Makefile.am b/Makefile.am
> +index f70c8fb1..ddfc0141 100644
> +--- a/Makefile.am
> ++++ b/Makefile.am
> +@@ -149,6 +149,13 @@ endif
> + 
> + dist_man_MANS += man/w.1
> + src_w_SOURCES = src/w.c local/fileutils.c
> ++src_w_LDADD = $(LDADD)
> ++if WITH_SYSTEMD
> ++src_w_LDADD += @SYSTEMD_LIBS@
> ++endif
> ++if WITH_ELOGIND
> ++src_w_LDADD += @ELOGIND_LIBS@
> ++endif
> + else
> +   EXTRA_DIST += man/w.1
> + endif
> +diff --git a/NEWS b/NEWS
> +index 3f2158d4..4ad9f74e 100644
> +--- a/NEWS
> ++++ b/NEWS
> +@@ -1,3 +1,6 @@
> ++procps-ng-NEXT
> ++---------------
> ++
> + procps-ng-4.0.4
> + ---------------
> +   * library (API & ABI unchanged)
> +-- 
> +2.34.1
> +
> diff --git a/package/procps-ng/procps-ng.mk b/package/procps-ng/procps-ng.mk
> index 2f28e3571e..1002d6340f 100644
> --- a/package/procps-ng/procps-ng.mk
> +++ b/package/procps-ng/procps-ng.mk
> @@ -14,6 +14,9 @@ PROCPS_NG_INSTALL_STAGING = YES
>  PROCPS_NG_DEPENDENCIES = ncurses host-pkgconf $(TARGET_NLS_DEPENDENCIES)
>  PROCPS_NG_CONF_OPTS = LIBS=$(TARGET_NLS_LIBS)
>  
> +# Applying 0001-build-sys-Add-systemd-elogind-to-w.patch touches Makefile.am
> +PROCPS_NG_AUTORECONF = YES
> +
>  ifeq ($(BR2_PACKAGE_SYSTEMD),y)
>  PROCPS_NG_DEPENDENCIES += systemd
>  PROCPS_NG_CONF_OPTS += --with-systemd
> -- 
> 2.34.1
> 
> _______________________________________________
> buildroot mailing list
> buildroot@buildroot.org
> https://lists.buildroot.org/mailman/listinfo/buildroot
Peter Korsgaard Oct. 11, 2024, 12:50 p.m. UTC | #2
>>>>> "Hugo" == Hugo Cornelis via buildroot <buildroot@buildroot.org> writes:

 > The build of procps-ng was broken when systemd was enabled.  Applying
 > commit ca004d46 of procps-ng upstream to explictly link the 'w'
 > command to libsystemd or elogind even though libproc2 is linked to it.

 > This was (likely) broken since the upgrade to procps-ng v4.0.4 with
 > commit d79f40dbbe98983bc657d4c82d46b38b8283351b.

 > Fixes: http://autobuild.buildroot.org/results/e8b/e8bae7bfd7d6a7987f3afa199d8d944429144817/build-end.log
 > Signed-off-by: Hugo Cornelis <hugo.cornelis@essensium.com>

Committed to 2024.02.x and 2024.08.x, thanks.
diff mbox series

Patch

diff --git a/package/procps-ng/0001-build-sys-Add-systemd-elogind-to-w.patch b/package/procps-ng/0001-build-sys-Add-systemd-elogind-to-w.patch
new file mode 100644
index 0000000000..3fecb4746d
--- /dev/null
+++ b/package/procps-ng/0001-build-sys-Add-systemd-elogind-to-w.patch
@@ -0,0 +1,48 @@ 
+From 788248ee631b3b5f82073c36320fc3f4a3c8f9ba Mon Sep 17 00:00:00 2001
+From: Craig Small <csmall@dropbear.xyz>
+Date: Thu, 31 Aug 2023 22:24:23 +1000
+Subject: [PATCH 1/1] build-sys: Add systemd/elogind to w
+
+Depending on the compiler flags, w needs to be explictly linked
+to libsystemd or elogind even though libproc2 is linked to it.
+
+Signed-off-by: Craig Small <csmall@dropbear.xyz>
+Upstream: https://gitlab.com/procps-ng/procps/-/commit/ca004d4657d5e8b468a4552ede429be53193a3a9
+Signed-off-by: Hugo Cornelis <hugo.cornelis@essensium.com>
+---
+ Makefile.am | 7 +++++++
+ NEWS        | 3 +++
+ 2 files changed, 10 insertions(+)
+
+diff --git a/Makefile.am b/Makefile.am
+index f70c8fb1..ddfc0141 100644
+--- a/Makefile.am
++++ b/Makefile.am
+@@ -149,6 +149,13 @@ endif
+ 
+ dist_man_MANS += man/w.1
+ src_w_SOURCES = src/w.c local/fileutils.c
++src_w_LDADD = $(LDADD)
++if WITH_SYSTEMD
++src_w_LDADD += @SYSTEMD_LIBS@
++endif
++if WITH_ELOGIND
++src_w_LDADD += @ELOGIND_LIBS@
++endif
+ else
+   EXTRA_DIST += man/w.1
+ endif
+diff --git a/NEWS b/NEWS
+index 3f2158d4..4ad9f74e 100644
+--- a/NEWS
++++ b/NEWS
+@@ -1,3 +1,6 @@
++procps-ng-NEXT
++---------------
++
+ procps-ng-4.0.4
+ ---------------
+   * library (API & ABI unchanged)
+-- 
+2.34.1
+
diff --git a/package/procps-ng/procps-ng.mk b/package/procps-ng/procps-ng.mk
index 2f28e3571e..1002d6340f 100644
--- a/package/procps-ng/procps-ng.mk
+++ b/package/procps-ng/procps-ng.mk
@@ -14,6 +14,9 @@  PROCPS_NG_INSTALL_STAGING = YES
 PROCPS_NG_DEPENDENCIES = ncurses host-pkgconf $(TARGET_NLS_DEPENDENCIES)
 PROCPS_NG_CONF_OPTS = LIBS=$(TARGET_NLS_LIBS)
 
+# Applying 0001-build-sys-Add-systemd-elogind-to-w.patch touches Makefile.am
+PROCPS_NG_AUTORECONF = YES
+
 ifeq ($(BR2_PACKAGE_SYSTEMD),y)
 PROCPS_NG_DEPENDENCIES += systemd
 PROCPS_NG_CONF_OPTS += --with-systemd