From: gmbeard <gmbeard@users.noreply.github.com>
To: ml@inbox.vuxu.org
Subject: Re: [PR PATCH] [Updated] New package: MangoHud-nvidia-0.6.8
Date: Sat, 15 Apr 2023 12:41:34 +0200 [thread overview]
Message-ID: <20230415104134.8ACZq_2bTF9frVSTEDPuXG2ibnVsrEZfx4B9zgTqCO0@z> (raw)
In-Reply-To: <gh-mailinglist-notifications-41a7ca26-5023-4802-975b-f1789d68868e-void-packages-42919@inbox.vuxu.org>
[-- Attachment #1: Type: text/plain, Size: 1608 bytes --]
There is an updated pull request by gmbeard against master on the void-packages repository
https://github.com/gmbeard/void-packages feature/MangoHud-nvidia
https://github.com/void-linux/void-packages/pull/42919
New package: MangoHud-nvidia-0.6.8
### Description
This packages MangoHud with the necessary build config to enable nVidia GPU stats. Because of the non-free license of the nVidia headers used in the source distribution, I've made the assumption that this must be treated in the same way as the `nvidia*` packages (i.e `nonfree`), hence the separate package.
This is essentially a straight clone of the existing MangoHud package, but uses a non-DFSG upstream.
<!-- Uncomment relevant sections and delete options which are not applicable -->
#### Testing the changes
- I tested the changes in this PR: **YES**
#### New package
- This new package conforms to the [package requirements](https://github.com/void-linux/void-packages/blob/master/CONTRIBUTING.md#package-requirements): **YES**
<!-- Note: If the build is likely to take more than 2 hours, please add ci skip tag as described in
https://github.com/void-linux/void-packages/blob/master/CONTRIBUTING.md#continuous-integration
and test at least one native build and, if supported, at least one cross build.
Ignore this section if this PR is not skipping CI.
-->
#### Local build testing
- I built this PR locally for my native architecture, x86\_64-glibc
- I built this PR locally for these architectures:
- x86\_64-musl
A patch file from https://github.com/void-linux/void-packages/pull/42919.patch is attached
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: github-pr-feature/MangoHud-nvidia-42919.patch --]
[-- Type: text/x-diff, Size: 9688 bytes --]
From 5f5b2ed0af783be57d160a01fa1208e7deda1455 Mon Sep 17 00:00:00 2001
From: Greg Beard <gmbeard@googlemail.com>
Date: Wed, 22 Mar 2023 07:28:46 +0000
Subject: [PATCH] New package: MangoHud-nvidia-0.6.9
---
srcpkgs/MangoHud-nvidia/files/musl.patch | 13 ++
...libdir_mangohud-handling-remove-ld_l.patch | 142 ++++++++++++++++++
srcpkgs/MangoHud-nvidia/template | 33 ++++
3 files changed, 188 insertions(+)
create mode 100644 srcpkgs/MangoHud-nvidia/files/musl.patch
create mode 100644 srcpkgs/MangoHud-nvidia/patches/0001-meson-unwrap-ld_libdir_mangohud-handling-remove-ld_l.patch
create mode 100644 srcpkgs/MangoHud-nvidia/template
diff --git a/srcpkgs/MangoHud-nvidia/files/musl.patch b/srcpkgs/MangoHud-nvidia/files/musl.patch
new file mode 100644
index 000000000000..71e58f83dc82
--- /dev/null
+++ b/srcpkgs/MangoHud-nvidia/files/musl.patch
@@ -0,0 +1,13 @@
+--- a/src/meson.build 2021-06-11 22:12:53.000000000 +0200
++++ b/src/meson.build 2021-06-14 23:32:49.677413454 +0200
+@@ -3,8 +3,8 @@
+ # Needs prefix for configure_file()
+ if get_option('append_libdir_mangohud')
+ libdir_mangohud = join_paths(get_option('libdir'), 'mangohud')
+- ld_libdir_mangohud = get_option('prefix') + '/\$LIB/mangohud/'
++ ld_libdir_mangohud = join_paths(get_option('prefix') ,get_option('libdir'), 'mangohud')
+ else
+ libdir_mangohud = get_option('libdir')
+- ld_libdir_mangohud = get_option('prefix') + '/\$LIB/'
++ ld_libdir_mangohud = join_paths(get_option('prefix') ,get_option('libdir'))
+ endif
diff --git a/srcpkgs/MangoHud-nvidia/patches/0001-meson-unwrap-ld_libdir_mangohud-handling-remove-ld_l.patch b/srcpkgs/MangoHud-nvidia/patches/0001-meson-unwrap-ld_libdir_mangohud-handling-remove-ld_l.patch
new file mode 100644
index 000000000000..05b18d847ea3
--- /dev/null
+++ b/srcpkgs/MangoHud-nvidia/patches/0001-meson-unwrap-ld_libdir_mangohud-handling-remove-ld_l.patch
@@ -0,0 +1,142 @@
+This reverts commit f47f777e26825b23d191f7a28d0c2404750e4207.
+
+There seems to be an issue using MangoHud with Steam (and other apps)
+when the absolute library path is used in LD_PRELOAD. This patch
+reverts back to the 0.6.8 behaviour.
+
+diff --git a/bin/mangohud.in b/bin/mangohud.in
+--- a/bin/mangohud.in
++++ b/bin/mangohud.in
+@@ -8,16 +8,21 @@ if [ "$#" -eq 0 ]; then
+ exit 1
+ fi
+
+-MANGOHUD_LIB_NAME="@ld_libdir_mangohud@libMangoHud.so"
+-
+ if [ "$1" = "--dlsym" ]; then
+ MANGOHUD_DLSYM=1
+- MANGOHUD_LIB_NAME="@ld_libdir_mangohud@libMangoHud_dlsym.so:${MANGOHUD_LIB_NAME}"
+ shift
+ fi
+
++MANGOHUD_LIB_NAME="@ld_libdir_mangohud_abs@libMangoHud.so"
++
++if [ "$MANGOHUD_DLSYM" = "1" ]; then
++ MANGOHUD_LIB_NAME="@ld_libdir_mangohud_abs@libMangoHud_dlsym.so:${MANGOHUD_LIB_NAME}"
++fi
++
+ # Preload using the plain filenames of the libs, the dynamic linker will
+-# figure out whether the 32 or 64 bit version should be used
+-LD_PRELOAD="${LD_PRELOAD:+$LD_PRELOAD:}${MANGOHUD_LIB_NAME}"
++# figure out whether the 32 or 64 bit version should be used, and will search
++# for it in the correct directory
++LD_PRELOAD="${LD_PRELOAD}${LD_PRELOAD:+:}${MANGOHUD_LIB_NAME}"
++LD_LIBRARY_PATH="${LD_LIBRARY_PATH}${LD_LIBRARY_PATH:+:}@ld_libdir_mangohud@"
+
+-exec env MANGOHUD=1 LD_PRELOAD="${LD_PRELOAD}" "$@"
++exec env MANGOHUD=1 LD_LIBRARY_PATH="${LD_LIBRARY_PATH}" LD_PRELOAD="${LD_PRELOAD}" "$@"
+diff --git a/build.sh b/build.sh
+--- a/build.sh
++++ b/build.sh
+@@ -142,13 +142,13 @@ configure() {
+ git submodule update --init --depth 50
+ CONFIGURE_OPTS="-Dwerror=true"
+ if [[ ! -f "build/meson64/build.ninja" ]]; then
+- meson build/meson64 --libdir lib/mangohud/lib64 --prefix /usr -Dappend_libdir_mangohud=false $@ ${CONFIGURE_OPTS}
++ meson build/meson64 --libdir lib/mangohud/lib64 --prefix /usr -Dappend_libdir_mangohud=false -Dld_libdir_abs=true $@ ${CONFIGURE_OPTS}
+ fi
+ if [[ ! -f "build/meson32/build.ninja" && "$MACHINE" = "x86_64" ]]; then
+ export CC="gcc -m32"
+ export CXX="g++ -m32"
+ export PKG_CONFIG_PATH="/usr/lib32/pkgconfig:/usr/lib/i386-linux-gnu/pkgconfig:/usr/lib/pkgconfig:${PKG_CONFIG_PATH_32}"
+- meson build/meson32 --libdir lib/mangohud/lib32 --prefix /usr -Dappend_libdir_mangohud=false $@ ${CONFIGURE_OPTS}
++ meson build/meson32 --libdir lib/mangohud/lib32 --prefix /usr -Dappend_libdir_mangohud=false -Dld_libdir_abs=true $@ ${CONFIGURE_OPTS}
+ fi
+ }
+
+diff --git a/meson_options.txt b/meson_options.txt
+--- a/meson_options.txt
++++ b/meson_options.txt
+@@ -1,6 +1,7 @@
+ option('glibcxx_asserts', type : 'boolean', value : false)
+ option('use_system_spdlog', type : 'feature', value : 'disabled', description: 'Use system spdlog library')
+ option('append_libdir_mangohud', type : 'boolean', value : true, description: 'Append "mangohud" to libdir path or not.')
++option('ld_libdir_abs', type : 'boolean', value : false, description: 'Use absolute path in LD_PRELOAD')
+ option('include_doc', type : 'boolean', value : true, description: 'Include the example config, man pages, appstream files etc.')
+ option('with_nvml', type : 'combo', value : 'enabled', choices: ['enabled', 'system', 'disabled'], description: 'Enable NVML support')
+ option('with_xnvctrl', type : 'feature', value : 'enabled', description: 'Enable XNVCtrl support')
+diff --git a/src/app/layer.json.in b/src/app/layer.json.in
+--- a/src/app/layer.json.in
++++ b/src/app/layer.json.in
+@@ -4,7 +4,7 @@
+ "name": "VK_LAYER_MANGOAPP_overlay",
+ "type": "GLOBAL",
+ "api_version": "1.3.0",
+- "library_path": "@ld_libdir_mangohud_abs@/libMangoApp.so",
++ "library_path": "@ld_libdir_mangohud@libMangoApp.so",
+ "implementation_version": "1",
+ "description": "Mangoapp Layer",
+ "functions": {
+diff --git a/src/mangohud.json.in b/src/mangohud.json.in
+--- a/src/mangohud.json.in
++++ b/src/mangohud.json.in
+@@ -4,7 +4,7 @@
+ "name": "VK_LAYER_MANGOHUD_overlay",
+ "type": "GLOBAL",
+ "api_version": "1.3.0",
+- "library_path": "@ld_libdir_mangohud_abs@/libMangoHud.so",
++ "library_path": "@ld_libdir_mangohud@libMangoHud.so",
+ "implementation_version": "1",
+ "description": "Vulkan Hud Overlay",
+ "functions": {
+diff --git a/src/meson.build b/src/meson.build
+--- a/src/meson.build
++++ b/src/meson.build
+@@ -2,17 +2,22 @@ glslang = find_program('glslangValidator')
+
+ # Needs prefix for configure_file()
+ if get_option('append_libdir_mangohud')
+- libdir_mangohud = join_paths(get_option('prefix'), get_option('libdir'), 'mangohud')
++ libdir_mangohud = join_paths(get_option('libdir'), 'mangohud')
+ ld_libdir_mangohud = get_option('prefix') + '/\$LIB/mangohud/'
+ else
+- libdir_mangohud = join_paths(get_option('prefix'), get_option('libdir'))
++ libdir_mangohud = get_option('libdir')
+ ld_libdir_mangohud = get_option('prefix') + '/\$LIB/'
+ endif
+
+ conf_data = configuration_data()
+
+-conf_data.set('ld_libdir_mangohud_abs', libdir_mangohud)
+-conf_data.set('ld_libdir_mangohud', ld_libdir_mangohud)
++if get_option('ld_libdir_abs')
++ conf_data.set('ld_libdir_mangohud_abs', ld_libdir_mangohud)
++ conf_data.set('ld_libdir_mangohud', '')
++else
++ conf_data.set('ld_libdir_mangohud_abs', '')
++ conf_data.set('ld_libdir_mangohud', ld_libdir_mangohud)
++endif
+
+ overlay_shaders = [
+ 'overlay.frag',
+@@ -282,7 +287,7 @@ endif
+
+ configure_file(input : 'mangohud.json.in',
+ output : '@0@.@1@.json'.format(meson.project_name(), host_machine.cpu_family()),
+- configuration : conf_data,
++ configuration : {'ld_libdir_mangohud' : ld_libdir_mangohud.replace('\$', '$')},
+ install : true,
+ install_dir : join_paths(get_option('datadir'), 'vulkan', 'implicit_layer.d'),
+ install_tag : 'runtime',
+@@ -298,7 +303,7 @@ configure_file(input : '../bin/mangohud.in',
+ if get_option('mangoapp_layer')
+ configure_file(input : 'app/layer.json.in',
+ output : 'libMangoApp.@0@.json'.format(host_machine.cpu_family()),
+- configuration : conf_data,
++ configuration : {'ld_libdir_mangohud' : ld_libdir_mangohud.replace('\$', '$')},
+ install : true,
+ install_dir : join_paths(get_option('datadir'), 'vulkan', 'implicit_layer.d'),
+ install_tag : 'mangoapp',
+--
+2.40.0
+
diff --git a/srcpkgs/MangoHud-nvidia/template b/srcpkgs/MangoHud-nvidia/template
new file mode 100644
index 000000000000..d888f25fb84b
--- /dev/null
+++ b/srcpkgs/MangoHud-nvidia/template
@@ -0,0 +1,33 @@
+# Template file for 'MangoHud-nvidia'
+pkgname=MangoHud-nvidia
+version=0.6.9
+revision=1
+build_style=meson
+configure_args="-Dwith_xnvctrl=disabled -Dwith_nvml=enabled -Duse_system_spdlog=enabled"
+hostmakedepends="Vulkan-Headers python3-Mako glslang pkg-config"
+makedepends="libglvnd-devel dbus-devel vulkan-loader Vulkan-Headers spdlog"
+short_desc="Vulkan and OpenGL overlay for monitoring FPS, temperatures and more"
+maintainer="gmbeard <gmbeard@googlemail.com>"
+license="MIT,custom:NVIDIA"
+homepage="https://github.com/flightlessmango/MangoHud"
+distfiles="https://github.com/flightlessmango/MangoHud/releases/download/v${version}/MangoHud-v${version}-Source.tar.xz"
+checksum=a6e59ad810a30cd0a6a62ac5a7b5d8a10abab48eb1312e084ca7c81472d76573
+conflicts=MangoHud
+repository=nonfree
+
+post_patch() {
+ if [ "$XBPS_TARGET_LIBC" = "musl" ]; then
+ patch -Np1 -i ${FILESDIR}/musl.patch
+ fi
+}
+
+post_install() {
+ # Extract the NVIDIA license from the nvml.h header
+ head -n $( \
+ awk '/NVML API Reference/{ print NR-1; exit }' ${wrksrc}/include/nvml.h \
+ ) ${wrksrc}/include/nvml.h \
+ | sed 's;^\([/ ]\?\)\*/\?;;g' >${wrksrc}/LICENSE-NVIDIA
+
+ vlicense LICENSE
+ vlicense LICENSE-NVIDIA
+}
next prev parent reply other threads:[~2023-04-15 10:41 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-03-22 7:44 [PR PATCH] " gmbeard
2023-03-28 17:11 ` [PR PATCH] [Updated] " gmbeard
2023-03-28 17:12 ` gmbeard
2023-04-15 10:41 ` gmbeard [this message]
2023-04-27 5:55 ` [PR PATCH] [Updated] New package: MangoHud-nvidia-0.6.9 gmbeard
2023-04-27 6:03 ` gmbeard
2023-04-27 6:06 ` [PR PATCH] [Updated] " gmbeard
2023-07-27 1:46 ` github-actions
2023-07-28 13:15 ` gmbeard
2023-10-28 1:44 ` github-actions
2023-10-28 6:23 ` gmbeard
2024-01-28 1:45 ` github-actions
2024-02-12 1:44 ` [PR PATCH] [Closed]: " github-actions
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20230415104134.8ACZq_2bTF9frVSTEDPuXG2ibnVsrEZfx4B9zgTqCO0@z \
--to=gmbeard@users.noreply.github.com \
--cc=ml@inbox.vuxu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).