NEON intrinsics not available with the soft-float ABI
时间: 2024-04-06 19:30:13 浏览: 252
这是一个关于ARM架构软件开发中的问题。NEON是ARM架构中的一种SIMD指令集,可以加速向量操作。soft-float ABI是一种使用软件实现浮点运算的ABI,不支持硬件浮点运算。因此,在使用soft-float ABI时,无法使用NEON指令集。如果需要使用NEON指令集,需要使用硬件浮点运算的ABI。
相关问题
sudo make install Making install in libfcgi make[1]: Entering directory '/home/yk/fcgi-2.4.1-SNAP-0910052249/libfcgi' make[2]: Entering directory '/home/yk/fcgi-2.4.1-SNAP-0910052249/libfcgi' test -z "/home/yk/fcgi/lib" || mkdir -p -- "/home/yk/fcgi/lib" /bin/bash ../libtool --mode=install /usr/bin/install -c 'libfcgi.la' '/home/yk/fcgi/lib/libfcgi.la' /usr/bin/install -c .libs/libfcgi.so.0.0.0 /home/yk/fcgi/lib/libfcgi.so.0.0.0 (cd /home/yk/fcgi/lib && { ln -s -f libfcgi.so.0.0.0 libfcgi.so.0 || { rm -f libfcgi.so.0 && ln -s libfcgi.so.0.0.0 libfcgi.so.0; }; }) (cd /home/yk/fcgi/lib && { ln -s -f libfcgi.so.0.0.0 libfcgi.so || { rm -f libfcgi.so && ln -s libfcgi.so.0.0.0 libfcgi.so; }; }) /usr/bin/install -c .libs/libfcgi.lai /home/yk/fcgi/lib/libfcgi.la /usr/bin/install -c .libs/libfcgi.a /home/yk/fcgi/lib/libfcgi.a chmod 644 /home/yk/fcgi/lib/libfcgi.a arm-xilinx-linux-gnueabi-ranlib /home/yk/fcgi/lib/libfcgi.a ../libtool: line 6556: arm-xilinx-linux-gnueabi-ranlib: command not found /bin/bash ../libtool --mode=install /usr/bin/install -c 'libfcgi++.la' '/home/yk/fcgi/lib/libfcgi++.la' libtool: install: warning: relinking `libfcgi++.la' (cd /home/yk/fcgi-2.4.1-SNAP-0910052249/libfcgi; /bin/bash ../libtool --tag=CXX --mode=relink arm-xilinx-linux-gnueabi-g++ -march=armv7-a -mthumb -mfpu=neon -mfloat-abi=hard -mcpu=cortex-a9 --sysroot=/home/yk/sdk/sysroots/cortexa9t2hf-neon-xilinx-linux-gnueabi -O2 -pipe -g -feliminate-unused-debug-types -Wl,-O1 -Wl,--hash-style=gnu -Wl,--as-needed -o libfcgi++.la -lfcgi -rpath /home/yk/fcgi/lib fcgio.lo ) arm-xilinx-linux-gnueabi-g++ -march=armv7-a -mthumb -mfpu=neon -mfloat-abi=hard -mcpu=cortex-a9 --sysroot=/home/yk/sdk/sysroots/cortexa9t2hf-neon-xilinx-linux-gnueabi -shared -nostdlib /home/yk/sdk/sysroots/cortexa9t2hf-neon-xilinx-linux-gnueabi/usr/lib/crti.o /home/yk/sdk/sysroots/cortexa9t2hf-neon-xilinx-linux-gnueabi/usr/lib/arm-xilinx-linux-gnueabi/8.2.0/crtbeginS.o .libs/fcgio.o -Wl,--rpath -Wl,/home/yk/fcgi/lib -L/home/yk/fcgi/lib -lfcgi -L/home/yk/sdk/sysroots/x86_64-petalinux-linux/usr/lib/arm-xilinx-linux-gnueabi/gcc/arm-xilinx-linux-gnueabi/8.2.0 -L/home/yk/sdk/sysroots/cortexa9t2hf-neon-xilinx-linux-gnueabi/lib -L/home/yk/sdk/sysroots/cortexa9t2hf-neon-xilinx-linux-gnueabi/usr/lib/arm-xilinx-linux-gnueabi/8.2.0 -L/home/yk/sdk/sysroots/cortexa9t2hf-neon-xilinx-linux-gnueabi/usr/lib -lstdc++ -lm -lc -lgcc_s /home/yk/sdk/sysroots/cortexa9t2hf-neon-xilinx-linux-gnueabi/usr/lib/arm-xilinx-linux-gnueabi/8.2.0/crtendS.o /home/yk/sdk/sysroots/cortexa9t2hf-neon-xilinx-linux-gnueabi/usr/lib/crtn.o -march=armv7-a -mthumb -mfpu=neon -mfloat-abi=hard -mcpu=cortex-a9 -Wl,-O1 -Wl,--hash-style=gnu -Wl,--as-needed -Wl,-soname -Wl,libfcgi++.so.0 -o .libs/libfcgi++.so.0.0.0 ../libtool: line 4501: arm-xilinx-linux-gnueabi-g++: command not found libtool: install: error: relink `libfcgi++.la' with the above command before installing it Makefile:256: recipe for target 'install-libLTLIBRARIES' failed make[2]: *** [install-libLTLIBRARIES] Error 1 make[2]: Leaving directory '/home/yk/fcgi-2.4.1-SNAP-0910052249/libfcgi' Makefile:459: recipe for target 'install-am' failed make[1]: *** [install-am] Error 2 make[1]: Leaving directory '/home/yk/fcgi-2.4.1-SNAP-0910052249/libfcgi' Makefile:373: recipe for target 'install-recursive' failed make: *** [install-recursive] Error 1
根据您提供的信息,安装过程中出现了一些错误。错误信息显示缺少 arm-xilinx-linux-gnueabi-ranlib 和 arm-xilinx-linux-gnueabi-g++ 命令。
这些命令是交叉编译工具链的一部分,可能需要先安装适当的工具链并将其添加到环境变量中,以便正确编译和安装 libfcgi。
您可以尝试以下步骤来解决此问题:
1. 确保已正确安装交叉编译工具链,并将其添加到系统的 PATH 环境变量中。您可以通过运行以下命令来验证是否已正确配置工具链:
```
arm-xilinx-linux-gnueabi-g++ --version
arm-xilinx-linux-gnueabi-ranlib --version
```
如果命令成功执行并显示版本信息,则说明工具链已正确安装和配置。
2. 如果工具链未正确安装,请根据您的系统和需求安装适当的工具链。在安装工具链时,请确保将其正确配置,并将工具链的 bin 目录添加到 PATH 环境变量中。
3. 如果已正确安装工具链但仍然出现问题,请检查 Makefile 文件中的相关配置。可能需要根据您的系统环境进行调整。
请按照上述步骤操作,并确保您的系统满足所需的依赖项和配置,然后重新运行 `sudo make install` 命令来尝试安装 libfcgi。如果问题仍然存在,请提供更多信息,以便我们能够更好地帮助您解决问题。
使用 Neon Intrinsics 函数改写矩阵乘法
Neon Intrinsics 是用于在 ARM 架构上优化运算的一组函数,其中包括加减乘除、矩阵乘法等。为了使用 Neon Intrinsics 函数改写矩阵乘法,你可以使用以下代码作为参考:
```c
#include <arm_neon.h>
void neon_matrix_multiply(float* A, float* B, float* C, int N, int M, int K) {
for (int i = 0; i < N; i++) {
for (int j = 0; j < K; j++) {
float32x4_t c = vdupq_n_f32(0.0);
for (int k = 0; k < M; k += 4) {
float32x4_t a = vld1q_f32(&A[i * M + k]);
float32x4x4_t b = vld4q_f32(&B[k * K + j * 4]);
c = vmlaq_f32(c, b.val[0], a);
c = vmlaq_f32(c, b.val[1], a);
c = vmlaq_f32(c, b.val[2], a);
c = vmlaq_f32(c, b.val[3], a);
}
C[i * K + j] = vgetq_lane_f32(c, 0) + vgetq_lane_f32(c, 1) + vgetq_lane_f32(c, 2) + vgetq_lane_f32(c, 3);
}
}
}
```
上述代码使用了 `float32x4_t` 类型来存储和计算矩阵,其中 `vld1q_f32` 和 `vld4q_f32` 分别是从内存中读取 4 个 float 类型数据和 4x4 矩阵的函数,`vmlaq_f32` 是乘加操作,`vgetq_lane_f32` 是从向量中获取指定下标的数值。
用上述代码替换掉普通的矩阵乘法即可实现 Neon Intrinsics 优化的矩阵乘法。
阅读全文