blob: 80b9af08e8fca1302fa8687fe16789a491745b2a [file] [log] [blame]
Andrew Geissler595f6302022-01-24 19:11:47 +00001From 4febda271c6bb0dc69ebf573446c6922a1ec35fb Mon Sep 17 00:00:00 2001
2From: Khem Raj <raj.khem@gmail.com>
3Date: Thu, 2 Dec 2021 19:57:42 -0800
4Subject: [PATCH] util/format: Check for NEON before using it
5
6This fixes build on rpi0-w and any other machine which does not have
7neon unit and is not used as FPU unit
8
9Fixes errors e.g.
10
11In file included from ../mesa-21.3.0/src/util/format/u_format_unpack_neon.c:35:
12/mnt/b/yoe/master/build/tmp/work/arm1176jzfshf-vfp-yoe-linux-gnueabi/mesa/2_21.3.0-r0/recipe-sysroot-native/usr/lib/clang/13.0.1/include/arm_neon.h:32:2: error: "NEON support not enabled"
13
14Upstream-Status: Submitted [https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/14032]
15Signed-off-by: Khem Raj <raj.khem@gmail.com>
16---
17 src/util/format/u_format.c | 2 +-
18 src/util/format/u_format_unpack_neon.c | 2 +-
19 2 files changed, 2 insertions(+), 2 deletions(-)
20
21diff --git a/src/util/format/u_format.c b/src/util/format/u_format.c
22index 36c5e52008e..f0a00971691 100644
23--- a/src/util/format/u_format.c
24+++ b/src/util/format/u_format.c
25@@ -1138,7 +1138,7 @@ static void
26 util_format_unpack_table_init(void)
27 {
28 for (enum pipe_format format = PIPE_FORMAT_NONE; format < PIPE_FORMAT_COUNT; format++) {
29-#if (defined(PIPE_ARCH_AARCH64) || defined(PIPE_ARCH_ARM)) && !defined(NO_FORMAT_ASM) && !defined(__SOFTFP__)
30+#if (defined(PIPE_ARCH_AARCH64) || (defined(__ARM_NEON) && defined(PIPE_ARCH_ARM))) && !defined(NO_FORMAT_ASM)
31 const struct util_format_unpack_description *unpack = util_format_unpack_description_neon(format);
32 if (unpack) {
33 util_format_unpack_table[format] = unpack;
34diff --git a/src/util/format/u_format_unpack_neon.c b/src/util/format/u_format_unpack_neon.c
35index a4a5cb1f723..1e4f794a295 100644
36--- a/src/util/format/u_format_unpack_neon.c
37+++ b/src/util/format/u_format_unpack_neon.c
38@@ -23,7 +23,7 @@
39
40 #include <u_format.h>
41
42-#if (defined(PIPE_ARCH_AARCH64) || defined(PIPE_ARCH_ARM)) && !defined(NO_FORMAT_ASM) && !defined(__SOFTFP__)
43+#if (defined(PIPE_ARCH_AARCH64) || (defined(__ARM_NEON) && defined(PIPE_ARCH_ARM))) && !defined(NO_FORMAT_ASM)
44
45 /* armhf builds default to vfp, not neon, and refuses to compile neon intrinsics
46 * unless you tell it "no really".
47--
482.34.1
49