ping.
On 2025-07-08 12:44 a.m., Brad Smith wrote:
On Sat, Jul 05, 2025 at 01:15:11AM -0400, Brad Smith wrote:
Here is an update to libavif 1.3.0.
Tested on aarch64 and build tested with all dependent ports.
Added a dist tuple to fetch libargparse.
Index: Makefile
===================================================================
RCS file: /cvs/ports/graphics/libavif/Makefile,v
retrieving revision 1.24
diff -u -p -u -p -r1.24 Makefile
--- Makefile 30 Aug 2024 07:48:53 -0000 1.24
+++ Makefile 8 Jul 2025 04:07:47 -0000
@@ -1,11 +1,13 @@
COMMENT= library for encoding and decoding .avif files
-DIST_TUPLE+= github AOMediaCodec libavif v1.1.1 .
+DIST_TUPLE+= github AOMediaCodec libavif v1.3.0 .
DIST_TUPLE+= github lemenkov libyuv \
- a6a2ec654b1be1166b376476a7555c89eca0c275 ext/libyuv
+ 4db2af62dab48895226be6b52737247e898ebe36 ext/libyuv
+DIST_TUPLE+= github kmurray libargparse \
+ ee74d1b53bd680748af14e737378de57e2a0a954 ext/libargparse
CATEGORIES= graphics
-SHARED_LIBS= avif 7.1
+SHARED_LIBS= avif 8.0
HOMEPAGE= https://github.com/AOMediaCodec/libavif
Index: distinfo
===================================================================
RCS file: /cvs/ports/graphics/libavif/distinfo,v
retrieving revision 1.18
diff -u -p -u -p -r1.18 distinfo
--- distinfo 30 Aug 2024 07:48:53 -0000 1.18
+++ distinfo 8 Jul 2025 04:07:47 -0000
@@ -1,4 +1,6 @@
-SHA256 (AOMediaCodec-libavif-v1.1.1.tar.gz) =
kUZi4WJF4GLtc/kBEvu0VIJBMAhDp3ctjUQbtoWd5Fs=
-SHA256 (lemenkov-libyuv-a6a2ec654b1be1166b376476a7555c89eca0c275.tar.gz) =
+5dXKi3B2Ok3bmGzPrSHCMzPs0Egb8m02atl9Asyb7M=
-SIZE (AOMediaCodec-libavif-v1.1.1.tar.gz) = 13644189
-SIZE (lemenkov-libyuv-a6a2ec654b1be1166b376476a7555c89eca0c275.tar.gz) = 570482
+SHA256 (AOMediaCodec-libavif-v1.3.0.tar.gz) =
ClRelTzASb9bz07kZzBqLxE6dREO31nmEkiHMQHNJsE=
+SHA256 (kmurray-libargparse-ee74d1b53bd680748af14e737378de57e2a0a954.tar.gz) =
dyewSYhR5bam/Nc062Z6iiMYl+LIajV67FHMBmSBMGA=
+SHA256 (lemenkov-libyuv-4db2af62dab48895226be6b52737247e898ebe36.tar.gz) =
0eVhTT+9BDkVvV4VaVG7GgnmMciQsyJ5aG69rUze7C0=
+SIZE (AOMediaCodec-libavif-v1.3.0.tar.gz) = 14062497
+SIZE (kmurray-libargparse-ee74d1b53bd680748af14e737378de57e2a0a954.tar.gz) =
22394
+SIZE (lemenkov-libyuv-4db2af62dab48895226be6b52737247e898ebe36.tar.gz) = 615749
Index: patches/patch-ext_libyuv_include_libyuv_cpu_id_h
===================================================================
RCS file: patches/patch-ext_libyuv_include_libyuv_cpu_id_h
diff -N patches/patch-ext_libyuv_include_libyuv_cpu_id_h
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ patches/patch-ext_libyuv_include_libyuv_cpu_id_h 8 Jul 2025 04:07:47
-0000
@@ -0,0 +1,12 @@
+Index: ext/libyuv/include/libyuv/cpu_id.h
+--- ext/libyuv/include/libyuv/cpu_id.h.orig
++++ ext/libyuv/include/libyuv/cpu_id.h
+@@ -95,7 +95,7 @@ int MipsCpuCaps(const char* cpuinfo_name);
+ LIBYUV_API
+ int RiscvCpuCaps(const char* cpuinfo_name);
+
+-#ifdef __linux__
++#if defined(__linux__) || defined(__FreeBSD__) || defined(__OpenBSD__)
+ // On Linux, parse AArch64 features from getauxval(AT_HWCAP{,2}).
+ LIBYUV_API
+ int AArch64CpuCaps(unsigned long hwcap, unsigned long hwcap2);
Index: patches/patch-ext_libyuv_source_cpu_id_cc
===================================================================
RCS file: patches/patch-ext_libyuv_source_cpu_id_cc
diff -N patches/patch-ext_libyuv_source_cpu_id_cc
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ patches/patch-ext_libyuv_source_cpu_id_cc 8 Jul 2025 04:07:47 -0000
@@ -0,0 +1,44 @@
+Index: ext/libyuv/source/cpu_id.cc
+--- ext/libyuv/source/cpu_id.cc.orig
++++ ext/libyuv/source/cpu_id.cc
+@@ -23,7 +23,8 @@
+ #include <stdio.h> // For fopen()
+ #include <string.h>
+
+-#if defined(__linux__) && defined(__aarch64__)
++#if (defined(__linux__) || defined(__FreeBSD__) || defined(__OpenBSD__)) && \
++ defined(__aarch64__)
+ #include <sys/auxv.h> // For getauxval()
+ #endif
+
+@@ -179,7 +180,7 @@ LIBYUV_API SAFEBUFFERS int ArmCpuCaps(const char* cpui
+ }
+
+ #ifdef __aarch64__
+-#ifdef __linux__
++#if defined(__linux__) || defined(__FreeBSD__) || defined(__OpenBSD__)
+ // Define hwcap values ourselves: building with an old auxv header where these
+ // hwcap values are not defined should not prevent features from being
enabled.
+ #define YUV_AARCH64_HWCAP_ASIMDDP (1UL << 20)
+@@ -472,13 +473,20 @@ static SAFEBUFFERS int GetCpuFlags(void) {
+ cpu_info |= kCpuHasLOONGARCH;
+ #endif
+ #if defined(__aarch64__)
+-#if defined(__linux__)
++#if defined(__linux__) || defined(__FreeBSD__) || defined(__OpenBSD__)
++#if defined(__FreeBSD__) || defined(__OpenBSD__)
++ unsigned long hwcap = 0;
++ unsigned long hwcap2 = 0;
++ elf_aux_info(AT_HWCAP, &hwcap, sizeof(hwcap));
++ elf_aux_info(AT_HWCAP2, &hwcap2, sizeof(hwcap2));
++#else
+ // getauxval is supported since Android SDK version 18, minimum at time of
+ // writing is 21, so should be safe to always use this. If getauxval is
+ // somehow disabled then getauxval returns 0, which will leave Neon enabled
+ // since Neon is mandatory on AArch64.
+ unsigned long hwcap = getauxval(AT_HWCAP);
+ unsigned long hwcap2 = getauxval(AT_HWCAP2);
++#endif
+ cpu_info = AArch64CpuCaps(hwcap, hwcap2);
+ #else
+ cpu_info = AArch64CpuCaps();
Index: pkg/PLIST
===================================================================
RCS file: /cvs/ports/graphics/libavif/pkg/PLIST,v
retrieving revision 1.6
diff -u -p -u -p -r1.6 PLIST
--- pkg/PLIST 27 Aug 2024 07:54:17 -0000 1.6
+++ pkg/PLIST 8 Jul 2025 04:07:47 -0000
@@ -1,5 +1,6 @@
@bin bin/avifdec
@bin bin/avifenc
+@bin bin/avifgainmaputil
include/avif/
include/avif/avif.h
include/avif/avif_cxx.h