Accepting request 1180336 from graphics
- Backport patch to fix PAC/BTI support on aarch64: * 563.patch (forwarded request 1180119 from Guillaume_G) OBS-URL: https://build.opensuse.org/request/show/1180336 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/libpng16?expand=0&rev=55
This commit is contained in:
commit
cdb0b7f6f9
98
563.patch
Normal file
98
563.patch
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
From ceed2a3cf6af420a0782e7f6147d5965b01b772a Mon Sep 17 00:00:00 2001
|
||||||
|
From: John Bowler <jbowler@acm.org>
|
||||||
|
Date: Thu, 30 May 2024 07:53:42 -0700
|
||||||
|
Subject: [PATCH] SECURITY: disable build of filter_neon.S on arm
|
||||||
|
|
||||||
|
This fixes the bug https://github.com/pnggroup/libpng/issues/505
|
||||||
|
"libpng does not support PAC/BTI on aarch64 targets" which arises
|
||||||
|
because the build mechanisms (both cmake and configure) assemble
|
||||||
|
arm/filter_neon.S even though it ends up completely empty. The empty
|
||||||
|
file effectively poisons the so that the PAC/BTI support gets disabled.
|
||||||
|
|
||||||
|
The fix is minimal; it simply removes arm/filter_neon.S from the list of
|
||||||
|
sources included in the 64-bit ARM builds build. Note that this was
|
||||||
|
already done in cmake for MSVC - it's not clear whether this change was
|
||||||
|
a partial fix for the same issue.
|
||||||
|
|
||||||
|
This version of the fix ONLY affects aarch64 (arm64) builds; 32-bit ARM
|
||||||
|
systems can still invoke the assembler if required and, indeed, there
|
||||||
|
should be no change whatsover to those builds.
|
||||||
|
|
||||||
|
The assembler code could not be used on 64-bit systems in any case so
|
||||||
|
in practice there is no material change to 64-bit builds either.
|
||||||
|
|
||||||
|
TESTING: pull the changes then type "autoreconf" if using configure (not
|
||||||
|
required for cmake).
|
||||||
|
|
||||||
|
TESTS: cmake has not been tested because cross-builds with cmake
|
||||||
|
currently fail to find the zlib installation from the cmake system root
|
||||||
|
path. The following has been tested with configure cross builds:
|
||||||
|
|
||||||
|
armv7-linux-gnueabi [no neon support]
|
||||||
|
armv7a-linux-gnueabi [no neon support]
|
||||||
|
armv7a-hardfloat-linux-gnueabi [neon support not enabled]
|
||||||
|
armv7a-hardfloat-linux-gnueabi -mfpu=neon [uses intrinics]
|
||||||
|
armv7a-hardfloat-linux-gnueabi -mfpu=neon
|
||||||
|
-DPNG_ARM_NEON_IMPLEMENTATION=2 [uses assembler]
|
||||||
|
aarch64-linux-gnu [uses intrinsics]
|
||||||
|
aarch64-linux-gnu -DPNG_ARM_NEON_OPT=0 [neon support disabled]
|
||||||
|
|
||||||
|
Signed-off-by: John Bowler <jbowler@acm.org>
|
||||||
|
---
|
||||||
|
CMakeLists.txt | 2 +-
|
||||||
|
Makefile.am | 6 ++++--
|
||||||
|
configure.ac | 10 ++++++++++
|
||||||
|
3 files changed, 15 insertions(+), 3 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
||||||
|
index 77e5398b6a..11bbe36d2a 100644
|
||||||
|
--- a/CMakeLists.txt
|
||||||
|
+++ b/CMakeLists.txt
|
||||||
|
@@ -153,7 +153,7 @@ if(TARGET_ARCH MATCHES "^(ARM|arm|aarch)")
|
||||||
|
arm/arm_init.c
|
||||||
|
arm/filter_neon_intrinsics.c
|
||||||
|
arm/palette_neon_intrinsics.c)
|
||||||
|
- if(NOT MSVC)
|
||||||
|
+ if(NOT MSVC AND NOT TARGET_ARCH MATCHES "^(ARM64|arm64|aarch64)")
|
||||||
|
list(APPEND libpng_arm_sources arm/filter_neon.S)
|
||||||
|
endif()
|
||||||
|
if(PNG_ARM_NEON STREQUAL "on")
|
||||||
|
diff --git a/Makefile.am b/Makefile.am
|
||||||
|
index 1f06c703a1..5cc27a4c8f 100644
|
||||||
|
--- a/Makefile.am
|
||||||
|
+++ b/Makefile.am
|
||||||
|
@@ -107,9 +107,11 @@ libpng@PNGLIB_MAJOR@@PNGLIB_MINOR@_la_SOURCES = png.c pngerror.c\
|
||||||
|
png.h pngconf.h pngdebug.h pnginfo.h pngpriv.h pngstruct.h pngusr.dfa
|
||||||
|
|
||||||
|
if PNG_ARM_NEON
|
||||||
|
+if PNG_ARM_NEON_ASM
|
||||||
|
+libpng@PNGLIB_MAJOR@@PNGLIB_MINOR@_la_SOURCES += arm/filter_neon.S
|
||||||
|
+endif
|
||||||
|
libpng@PNGLIB_MAJOR@@PNGLIB_MINOR@_la_SOURCES += arm/arm_init.c\
|
||||||
|
- arm/filter_neon.S arm/filter_neon_intrinsics.c \
|
||||||
|
- arm/palette_neon_intrinsics.c
|
||||||
|
+ arm/filter_neon_intrinsics.c arm/palette_neon_intrinsics.c
|
||||||
|
endif
|
||||||
|
|
||||||
|
if PNG_MIPS_MSA
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index 2c6b3333c6..e3c1536f0c 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -425,6 +425,16 @@ AM_CONDITIONAL([PNG_ARM_NEON],
|
||||||
|
*) test "$enable_arm_neon" != '' ;;
|
||||||
|
esac])
|
||||||
|
|
||||||
|
+# Add the assembler implementation source file. This only works on 32-bit
|
||||||
|
+# ARM and causes problems even if empty on 64-bit ARM.
|
||||||
|
+AM_CONDITIONAL([PNG_ARM_NEON_ASM],
|
||||||
|
+ [test "$enable_arm_neon" != 'no' &&
|
||||||
|
+ case "$host_cpu" in
|
||||||
|
+ arm64*|aarch64*) false ;;
|
||||||
|
+ arm*) true ;;
|
||||||
|
+ *) test "$enable_arm_neon" != '' ;;
|
||||||
|
+ esac])
|
||||||
|
+
|
||||||
|
# MIPS MSA
|
||||||
|
# ========
|
||||||
|
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Jun 12 08:07:31 UTC 2024 - Guillaume GARDET <guillaume.gardet@opensuse.org>
|
||||||
|
|
||||||
|
- Backport patch to fix PAC/BTI support on aarch64:
|
||||||
|
* 563.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Thu Mar 7 12:31:25 UTC 2024 - pgajdos@suse.com
|
Thu Mar 7 12:31:25 UTC 2024 - pgajdos@suse.com
|
||||||
|
|
||||||
|
@ -34,6 +34,8 @@ Source0: https://prdownloads.sourceforge.net/libpng/libpng-%{version}.tar
|
|||||||
Source2: libpng16.keyring
|
Source2: libpng16.keyring
|
||||||
Source3: rpm-macros.libpng-tools
|
Source3: rpm-macros.libpng-tools
|
||||||
Source4: baselibs.conf
|
Source4: baselibs.conf
|
||||||
|
# PATCH-FIX-UPSTREAM - https://github.com/pnggroup/libpng/pull/563
|
||||||
|
Patch1: 563.patch
|
||||||
BuildRequires: libtool
|
BuildRequires: libtool
|
||||||
BuildRequires: pkgconfig
|
BuildRequires: pkgconfig
|
||||||
BuildRequires: pkgconfig(zlib)
|
BuildRequires: pkgconfig(zlib)
|
||||||
@ -91,7 +93,7 @@ Package consists of low level tools for manipulating and fixing particular
|
|||||||
PNG files.
|
PNG files.
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%autosetup -n libpng-%{version}
|
%autosetup -p1 -n libpng-%{version}
|
||||||
|
|
||||||
%build
|
%build
|
||||||
# PNG_SAFE_LIMITS_SUPPORTED: http://www.openwall.com/lists/oss-security/2015/01/10/1
|
# PNG_SAFE_LIMITS_SUPPORTED: http://www.openwall.com/lists/oss-security/2015/01/10/1
|
||||||
@ -100,6 +102,8 @@ export LDFLAGS="-Wl,-z,relro,-z,now"
|
|||||||
%if %{debug_build}
|
%if %{debug_build}
|
||||||
export CFLAGS="$CFLAGS -Og"
|
export CFLAGS="$CFLAGS -Og"
|
||||||
%endif
|
%endif
|
||||||
|
# autoreconf required by Patch1
|
||||||
|
autoreconf -f
|
||||||
%configure \
|
%configure \
|
||||||
--enable-hardware-optimizations=yes \
|
--enable-hardware-optimizations=yes \
|
||||||
%ifarch armv6l armv6hl
|
%ifarch armv6l armv6hl
|
||||||
|
Loading…
Reference in New Issue
Block a user