[FFmpeg-devel] aarch64: Implement support for elf_aux_info(3) on FreeBSD and OpenBSD
Rémi Denis-Courmont
remi at remlab.net
Fri Jul 26 14:56:19 EEST 2024
Le 26 juillet 2024 13:58:34 GMT+03:00, Brad Smith <brad-at-comstyle.com at ffmpeg.org> a écrit :
>aarch64: Implement support for elf_aux_info(3) on FreeBSD and OpenBSD
>
>FreeBSD 12.0+, OpenBSD -current and what will be OpenBSD 7.6 support
>elf_aux_info(3).
>
>Signed-off-by: Brad Smith <brad at comstyle.com>
>---
> configure | 2 ++
> libavutil/aarch64/cpu.c | 23 ++++++++++++++++++++++-
> 2 files changed, 24 insertions(+), 1 deletion(-)
>
>diff --git a/configure b/configure
>index f6f5c29fea..e80b549582 100755
>--- a/configure
>+++ b/configure
>@@ -2366,6 +2366,7 @@ SYSTEM_FUNCS="
> clock_gettime
> closesocket
> CommandLineToArgvW
>+ elf_aux_info
> fcntl
> getaddrinfo
> getauxval
>@@ -6565,6 +6566,7 @@ check_func_headers mach/mach_time.h mach_absolute_time
> check_func_headers stdlib.h getenv
> check_func_headers sys/stat.h lstat
> check_func_headers sys/auxv.h getauxval
>+check_func_headers sys/auxv.h elf_aux_info
> check_func_headers sys/sysctl.h sysctlbyname
>
> check_func_headers windows.h GetModuleHandle
>diff --git a/libavutil/aarch64/cpu.c b/libavutil/aarch64/cpu.c
>index cfa9306663..05272b4db4 100644
>--- a/libavutil/aarch64/cpu.c
>+++ b/libavutil/aarch64/cpu.c
>@@ -42,6 +42,27 @@ static int detect_flags(void)
> return flags;
> }
>
>+#elif (defined(__FreeBSD__) || defined(__OpenBSD__)) && HAVE_ELF_AUX_INFO
>+#include <stdint.h>
>+#include <sys/auxv.h>
>+
>+static int detect_flags(void)
>+{
>+ int flags = 0;
>+
>+ unsigned long hwcap = 0;
>+ elf_aux_info(AT_HWCAP, &hwcap, sizeof hwcap);
>+ unsigned long hwcap2 = 0;
>+ elf_aux_info(AT_HWCAP2, &hwcap2, sizeof hwcap2);
>+
>+ if (hwcap & HWCAP_ASIMDDP)
>+ flags |= AV_CPU_FLAG_DOTPROD;
>+ if (hwcap2 & HWCAP2_I8MM)
>+ flags |= AV_CPU_FLAG_I8MM;
>+
>+ return flags;
>+}
>+
Can't getauxval() be implemented with elf_aux_info(), or vice versa? It seems that otherwise the code should be identical to that from Linux.
> #elif defined(__APPLE__) && HAVE_SYSCTLBYNAME
> #include <sys/sysctl.h>
>
>@@ -65,7 +86,7 @@ static int detect_flags(void)
> return flags;
> }
>
>-#elif defined(__OpenBSD__)
>+#elif defined(__OpenBSD__) && !HAVE_ELF_AUX_INFO
> #include <machine/armreg.h>
> #include <machine/cpu.h>
> #include <sys/types.h>
More information about the ffmpeg-devel
mailing list