diff options
author | Stelios Tsampas | 2024-01-25 22:38:13 +0200 |
---|---|---|
committer | Stelios Tsampas | 2024-01-25 22:38:13 +0200 |
commit | 9dc9c6ea48cb036bf5118231e5c2160630105aed (patch) | |
tree | 76f3fe52974ffab8f1e443421b33dc67aa11e45f | |
parent | 718f963a47e2c9708270a49005adcd544af8e22c (diff) | |
download | aur-9dc9c6ea48cb036bf5118231e5c2160630105aed.tar.gz |
[dxvk,dxvk-nvapi,vkd3d-proton,d8vk] Infer march and mtune
-rw-r--r-- | PKGBUILD.personal | 123 |
1 files changed, 0 insertions, 123 deletions
diff --git a/PKGBUILD.personal b/PKGBUILD.personal deleted file mode 100644 index 1d174279cd91..000000000000 --- a/PKGBUILD.personal +++ /dev/null @@ -1,123 +0,0 @@ -# Maintainer: loathingkernel <loathingkernel @at gmail .dot com> - -pkgname=dxvk-nvapi-mingw-git -pkgver=0.6.4.r16.g03cc59d -pkgrel=1 -pkgdesc='Alternative NVAPI implementation on top of DXVK' -arch=('x86_64') -url="https://github.com/jp7677/dxvk-nvapi" -license=('MIT') -makedepends=('ninja' 'meson>=0.43' 'glslang' 'git' 'mingw-w64-gcc') -provides=('dxvk-nvapi-mingw') -conflicts=('dxvk-nvapi-mingw') -options=(!lto !staticlibs) -source=( - "git+https://github.com/jp7677/dxvk-nvapi.git" - "dxvk-nvapi-extraopts.patch" - "setup_dxvk_nvapi.sh" - "setup_dxvk_nvapi" -) - -pkgver() { - cd dxvk-nvapi - printf "%s" "$(git describe --long --tags | sed 's/\([^-]*-g\)/r\1/;s/-/./g;s/v//g')" -} - -prepare() { - cd dxvk-nvapi - - # Explicitly set origin URL for submodules using relative paths - git remote set-url origin https://github.com/jp7677/dxvk-nvapi.git - git submodule update --init --filter=tree:0 --recursive - - # Uncomment to enable extra optimizations - # Patch crossfiles with extra optimizations from makepkg.conf - patch -p1 -i "$srcdir"/dxvk-nvapi-extraopts.patch - - # By default export FLAGS used by proton and ignore makepkg - # This overrides FLAGS from makepkg.conf, if you comment these you are on your own - # If you want the "best" possible optimizations for your system you can use - # `-march=native` and remove the `-mtune=core-avx2` option. - - local -a split=($CFLAGS) - local -A flags - for opt in "${split[@]}"; do flags["${opt%%=*}"]="${opt##*=}"; done - local march="${flags["-march"]:-nocona}" - local mtune="${flags["-mtune"]:-core-avx2}" - - export CFLAGS="-O2 -march="$march" -mtune="$mtune" -pipe" - export CXXFLAGS="-O2 -march="$march" -mtune="$mtune" -pipe" - export LDFLAGS="-Wl,-O1,--sort-common,--as-needed" - - # These flags are taken from Proton - CFLAGS+=" -mfpmath=sse -fwrapv -fno-strict-aliasing" - CXXFLAGS+=" -mfpmath=sse -fwrapv -fno-strict-aliasing -std=c++17" - LDFLAGS+=" -Wl,--file-alignment,4096" - - # If using -march= with a CPU that supports supports AVX, launching a 32bit - # d3d9 game can cause an Unhandled exception. The cause seems to be the - # combination of AVX instructions and tree vectorization (implied by O3), - # all tested archictures from sandybridge to haswell are affected. - # Disabling AVX (and AVX2 as a side-effect). - # Since Wine 5.16 AVX is supported. Testing showed 32bit applications - # crashing with AVX regardless, but 64bit applications worked just fine. - # So disable AVX only for the 32bit binaries and AVX2 for the 64bit. - # AVX2 seems to degrade performance. So disregard the above. - # Relevant Wine issues - # https://bugs.winehq.org/show_bug.cgi?id=45289 - # https://bugs.winehq.org/show_bug.cgi?id=43516 - CFLAGS+=" -mno-avx2" - CXXFLAGS+=" -mno-avx2" - - local cross_ldflags="$LDFLAGS" - - local cross_cflags="$CFLAGS -mcmodel=small" - local cross_cxxflags="$CXXFLAGS -mcmodel=small" - sed -i build-win64.txt \ - -e "s|@CARGS@|\'${cross_cflags// /\',\'}\'|g" \ - -e "s|@CXXARGS@|\'${cross_cxxflags// /\',\'}\'|g" \ - -e "s|@LDARGS@|\'${cross_ldflags// /\',\'}\'|g" - - local cross_cflags="$CFLAGS -mstackrealign -mno-avx" - local cross_cxxflags="$CXXFLAGS -mstackrealign -mno-avx" - sed -i build-win32.txt \ - -e "s|@CARGS@|\'${cross_cflags// /\',\'}\'|g" \ - -e "s|@CXXARGS@|\'${cross_cxxflags// /\',\'}\'|g" \ - -e "s|@LDARGS@|\'${cross_ldflags// /\',\'}\'|g" -} - -build() { - meson setup dxvk-nvapi "build/x64" \ - --cross-file dxvk-nvapi/build-win64.txt \ - --prefix "/usr/share/dxvk-nvapi/x64" \ - --bindir "" --libdir "" \ - --buildtype "plain" \ - --strip \ - -Denable_tests=false - ninja -C "build/x64" -v - - meson setup dxvk-nvapi "build/x32" \ - --cross-file dxvk-nvapi/build-win32.txt \ - --prefix "/usr/share/dxvk-nvapi/x32" \ - --bindir "" --libdir "" \ - --buildtype "plain" \ - --strip \ - -Denable_tests=false - ninja -C "build/x32" -v -} - -package() { - depends=('vulkan-icd-loader' 'lib32-vulkan-icd-loader' 'wine' 'dxvk' 'bash') - - DESTDIR="$pkgdir" ninja -C "build/x32" install - DESTDIR="$pkgdir" ninja -C "build/x64" install - install -Dm 755 -t "$pkgdir/usr/share/dxvk-nvapi" setup_dxvk_nvapi.sh - install -Dm 644 -t "$pkgdir/usr/share/doc/$pkgname" dxvk-nvapi/README.md - install -Dm 644 -t "$pkgdir/usr/share/licenses/$pkgname" dxvk-nvapi/LICENSE - install -Dm 755 -t "$pkgdir/usr/bin" setup_dxvk_nvapi -} - -sha256sums=('SKIP' - 'dff5ecd1a35a94a4dc1fa5fd08c10b5c88703797520d6b315207124ff1adeef8' - 'b40b67bdc1bbe9bf103737824c53e1f7dcbaa78345e8df5b767bd72bff7c78c4' - '1f4934c5bfcf208e288a0eda2f385f82acc9e78a4b0ac2a77b5af14c64c8e21e') |