b648276122
CI binary segfaulted on HEVC vaEndPicture even though /etc/makepkg.conf has OPTIONS=(... !lto ...). Root cause: arch-meson's wrapper hard-codes `-D b_lto=true` regardless of makepkg.conf, so the binary still gets cross-function ICF (Identical Code Folding) under -O2 + LTO. HEVC is the only codec in the campaign that submits a per-frame chain of 4 control structs (SPS + PPS + DECODE_PARAMS + SLICE_PARAMS); ICF finds a near-duplicate per-codec helper across the codec dispatch and merges them, then the wrong instance's local stack layout is invoked on the HEVC path → SEGV. The other 4 codecs (H.264, VP8, VP9, MPEG-2) submit fewer/simpler control structs and tolerate the folding by accident. Empirical confirmation from the issue body's binary bisection: meson build (default debugoptimized) 485 KB HEVC ✓ arch-meson + --buildtype=release 145 KB HEVC ✓ arch-meson + release + -flto 76 KB HEVC SEGV CI build (this package, 7ac934e-1) 133 KB HEVC SEGV Fix: append `-Db_lto=false` to the arch-meson invocation. pkgrel 1 -> 2.
84 lines
3.9 KiB
Bash
84 lines
3.9 KiB
Bash
# Maintainer: Markus Fritsche <fritsche.markus@gmail.com>
|
|
#
|
|
# libva-v4l2-request-fourier — VA-API backend for V4L2 stateless decoders,
|
|
# multiplanar fork. Successor to the predecessor experimental package
|
|
# libva-v4l2-request-ohm-gl-fix (tarball + 18-patch stack); this package
|
|
# tracks the campaign fork's git history directly, so iteration sweeps
|
|
# (DEBUG removal, follow-up bugfixes) land in a clean linear log.
|
|
#
|
|
# Campaign: ~/src/libva-multiplanar/ (iter8 close 2026-05-06) plus
|
|
# ~/src/fresnel-fourier/ which carried the fork to iter38b — multi-device
|
|
# probe so a single libva session serves all 5 codecs (rkvdec H.264 +
|
|
# HEVC + VP9, hantro MPEG-2 + VP8) plus a bounds-check fix for
|
|
# MAX_PROFILES. Pinned below.
|
|
# Fork repo: https://git.reauktion.de/marfrit/libva-v4l2-request-fourier
|
|
# Bootlin upstream: https://github.com/bootlin/libva-v4l2-request
|
|
#
|
|
# Build target: fermi LXC actrunner-aarch64-hertz via marfrit-packages
|
|
# Gitea Actions (path=arch/libva-v4l2-request-fourier triggers the
|
|
# libva-v4l2-request-fourier-aarch64 job — wire up alongside the existing
|
|
# ffmpeg-v4l2-request-git job in .gitea/workflows/build.yml).
|
|
# Alternative: boltzmann via his subagent + marfrit-publish.
|
|
|
|
pkgname=libva-v4l2-request-fourier
|
|
_upstreampkg=libva-v4l2-request
|
|
|
|
# Pin the fork tip. 7ac934e = "iter38b: bounds check uses MAX_PROFILES
|
|
# (11), not MAX_CONFIG_ATTRIBUTES (10)" — fresnel-fourier campaign
|
|
# production tip 2026-05-14, sibling iter38 added multi-device probe so
|
|
# a single libva session serves rkvdec + hantro without requiring
|
|
# LIBVA_V4L2_REQUEST_VIDEO_PATH overrides. Promote to a later pin only
|
|
# after a future iteration closes cleanly.
|
|
_commit=7ac934e0c5420814c7a5fc3e2a2f08251d590d9e
|
|
|
|
# Project version from meson.build (1.0.0) + commit count + short sha,
|
|
# matching the ffmpeg-v4l2-request-fourier convention. Recomputed at
|
|
# build time by pkgver() below; the static value here is a placeholder
|
|
# so AUR-style consumers see something coherent before src/ exists.
|
|
pkgver=1.0.0.r348.7ac934e
|
|
pkgrel=2
|
|
pkgdesc="VA-API backend for V4L2 stateless decoders (multiplanar fork — fourier umbrella)"
|
|
arch=('aarch64')
|
|
url="https://git.reauktion.de/marfrit/libva-v4l2-request-fourier"
|
|
license=('LGPL2.1' 'MIT')
|
|
depends=('libva' 'libdrm' 'systemd-libs')
|
|
makedepends=('meson' 'ninja' 'pkgconf' 'git')
|
|
provides=("${_upstreampkg}=${pkgver}" 'libva-driver')
|
|
conflicts=("${_upstreampkg}" 'libva-v4l2-request-ohm-gl-fix')
|
|
replaces=("${_upstreampkg}" 'libva-v4l2-request-ohm-gl-fix')
|
|
|
|
source=("git+https://git.reauktion.de/marfrit/libva-v4l2-request-fourier.git#commit=${_commit}")
|
|
sha256sums=('SKIP')
|
|
|
|
pkgver() {
|
|
cd "${srcdir}/${_upstreampkg}-fourier"
|
|
printf '1.0.0.r%s.%s' \
|
|
"$(git rev-list --count HEAD)" \
|
|
"$(git rev-parse --short=7 HEAD)"
|
|
}
|
|
|
|
build() {
|
|
cd "${srcdir}/${_upstreampkg}-fourier"
|
|
# meson_options.txt only exposes 'kernel_headers' — leave it empty to
|
|
# use system /usr/include kernel UAPI headers. No per-codec toggles.
|
|
#
|
|
# b_lto=false: override arch-meson's wrapper default of `-D b_lto=true`,
|
|
# which the makepkg.conf OPTIONS=(..., !lto, ...) line does NOT actually
|
|
# override (arch-meson hard-codes b_lto=true). The hand-built reproducer
|
|
# from issue #17 shows: LTO/ICF kernel-folds per-codec helpers and HEVC's
|
|
# multi-control-struct chain (SPS+PPS+DECODE_PARAMS+SLICE_PARAMS) gets a
|
|
# wrong helper-instance pulled in at vaEndPicture → segfault. The 4 other
|
|
# codecs (single-control-struct) tolerate the folding by accident.
|
|
arch-meson build --buildtype=release -Db_lto=false
|
|
meson compile -C build
|
|
}
|
|
|
|
package() {
|
|
cd "${srcdir}/${_upstreampkg}-fourier"
|
|
meson install -C build --destdir "${pkgdir}"
|
|
|
|
install -Dm644 COPYING "${pkgdir}/usr/share/licenses/${pkgname}/COPYING"
|
|
install -Dm644 COPYING.LGPL "${pkgdir}/usr/share/licenses/${pkgname}/COPYING.LGPL"
|
|
install -Dm644 COPYING.MIT "${pkgdir}/usr/share/licenses/${pkgname}/COPYING.MIT"
|
|
}
|