- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在尝试从源代码交叉编译 Qt 4.7.1,这里有一些关于我的设置的注释:
我对这应该如何工作的理解是我下载了我的目标平台的工具链(这是 TI 的 Linaro 工具链),我下载了 Qt 4.7.1 的源代码。 ,我将 mkspec 设置为使用我的工具链,运行 configure
,然后只需要运行 make
/make install
我应该能够找到我告诉它安装到的所有 .so
。然而,我在实现这个想法时遇到了很多问题。
首先,我下载了 TI SDK 版本:ti-sdk-am335x-evm-06.00.00.00,其中包含 arm 工具:[root_install_dir]/linux-devkit/sysroots/i686-arago-linux/usr/bin
我用那个目录更新了我的 $PATH
:
mike@mike-VirtualBox:~$ echo $PATH /home/mike/ti-sdk-am335x-evm-06.00.00.00/linux-devkit/sysroots/i686-arago-linux/usr/bin :/usr/local/Trolltech/Qt-4.8.5/bin:/home/mike/bin:/usr/lib/lightdm/lightdm: /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/home/mike/bin
然后我根据最接近的示例创建了自己的 mkspec:cp -R [qt_install_dir]/mkspecs/qws/linux-arm-gnueabi-g++/[qt_install_dir]/mkspecs/qws/linux-am335x-g++
我修改了 linux-am335x-g++/qmake.conf
以指向来自 TI sdk 的工具:
# modifications to g++.conf
QMAKE_CC = arm-linux-gnueabihf-gcc
QMAKE_CXX = arm-linux-gnueabihf-g++
QMAKE_LINK = arm-linux-gnueabihf-g++
QMAKE_LINK_SHLIB = arm-linux-gnueabihf-g++
# modifications to linux.conf
QMAKE_AR = arm-linux-gnueabihf-ar cqs
QMAKE_OBJCOPY = arm-linux-gnueabihf-objcopy
QMAKE_STRIP = arm-linux-gnueabihf-strip
然后我运行了一个配置命令:
./configure -prefix /home/mike/qt4.7.1_source/my_qt -embedded arm -platform qws/linux-x86_64-g++ -xplatform qws/linux-am335x-g++ -no-mmx -no-3dnow -no-sse -no-sse2 -no-glib -no-cups -no-largefile -no-accessibility -no-openssl -no-gtkstyle -fast -opensource
它运行了一段时间然后完成并说它已准备好执行 make
/make install
此时我运行 make
就是在那里它开始失败:
/home/mike/qt4.7.1_source/qt-everywhere-opensource-src-4.7.1/bin/moc -DQT_SHARED -DQT_BUILD_CORE_LIB -DQT_NO_USING_NAMESPACE -DQT_NO_CAST_TO_ASCII -DQT_ASCII_CAST_WARNINGS -DQT3_SUPPORT -DQT_MOC_COMPAT -DQT_USE_FAST_OPERATOR_PLUS -DQT_USE_FAST_CONCATENATION -DELF_INTERPRETER=\"/lib64/ld-linux-x86-64.so.2\" -DHB_EXPORT=Q_CORE_EXPORT -DQT_HAVE_NEON -DQT_NO_DEBUG -I../../mkspecs/qws/linux-am335x-g++ -I. -I../../include -I../../include/QtCore -I.rcc/release-shared-emb-arm -Iglobal -I../3rdparty/harfbuzz/src -I../3rdparty/md5 -I../3rdparty/md4 -I.moc/release-shared-emb-arm kernel/qobject.h -o .moc/release-shared-emb-arm/moc_qobject.cpp arm-linux-gnueabihf-g++ -c -include .pch/release-shared-emb-arm/QtCore -pipe -fno-exceptions -mfpu=neon -O2 -fvisibility=hidden -fvisibility-inlines-hidden -Wall -W -D_REENTRANT -fPIC -DQT_SHARED -DQT_BUILD_CORE_LIB -DQT_NO_USING_NAMESPACE -DQT_NO_CAST_TO_ASCII -DQT_ASCII_CAST_WARNINGS -DQT3_SUPPORT -DQT_MOC_COMPAT -DQT_USE_FAST_OPERATOR_PLUS -DQT_USE_FAST_CONCATENATION -DELF_INTERPRETER=\"/lib64/ld-linux-x86-64.so.2\" -DHB_EXPORT=Q_CORE_EXPORT -DQT_HAVE_NEON -DQT_NO_DEBUG -I../../mkspecs/qws/linux-am335x-g++ -I. -I../../include -I../../include/QtCore -I.rcc/release-shared-emb-arm -Iglobal -I../3rdparty/harfbuzz/src -I../3rdparty/md5 -I../3rdparty/md4 -I.moc/release-shared-emb-arm -o .obj/release-shared-emb-arm/qobject.o kernel/qobject.cpp
{standard input}: Assembler messages:
{standard input}:1294: Error: selected processor does not support Thumb mode 'swp r6,r4,[r3]'
make[1]: [.obj/release-shared-emb-arm/qobject.o] Error 1*
make[1]: Leaving directory
'/home/mike/qt4.7.1_source/qt-everywhere-opensource-src-4.7.1/src/corelib'
make: * [sub-corelib-make_default-ordered] Error 2
所以,问题...为什么编译器提示不支持拇指模式?由于这是基于 ARM 的处理器的交叉编译工具链,因此应该 支持它。它不是的事实让我觉得 make
以某种方式选择了错误版本的 g++。
关于哪里出了问题以及如何解决这个问题有什么想法吗?
最佳答案
{standard input}:1294: Error: selected processor does not support Thumb mode 'swp r6,r4,[r3]'
Why is the compiler complaining that the thumb mode is not supported?
请注意,编译器正在提示 swp
指令不适用于thumb 模式。您的 CPU 支持 thumb、thumb2 和 ARM。 Cortex 系列不推荐使用 swp
并且更喜欢 ldrex/strex
对。
Any thoughts on what went wrong and how to fix this?
你需要得到 gcc 来定义 __ARM_ARCH_7__
;这是通过 -mcpu=cortex-a8
完成的或组合-mtune=cortex-a8
和 -march=armv7-a
或者你喜欢什么,这取决于你希望 Qt 在多少种类型的板上运行。
详见qatomic_arm.h用于选择子文件的位置。你选择了一个非常通用的 ARM(我猜),所以你得到 qatomic_armv5.h 注意 1 您可以在第 125 行附近看到代码。适合您的 CPU 的文件是 qatomic_armv7.h,它主要只包含 qatomic_armv6.h。 .在此文件中,您可以找到 ldrex/strex
这是你的gcc
的有益健康正在请求。
我还建议您不要使用-fast 进行编译。有 another question OP 说这解决了他的问题;但我认为这是不同的。
可以尝试通过-armfpa
配置。 ./configure -embedded arm --help
很有用。 configure
似乎选择了 NEON,所以它似乎知道你有一个更高级的 CPU(armv5 上没有 NEON,但这也许configure
的故障)。
当然,您不想要 swp
代码和 ldrex/strex
是您系统的首选,即使 swp
可以以某种方式工作。我至少会解决这个问题。改变 -xplatform qws/linux-am335x-g++
更新-mcpu
或者可能传递一个明确的 -D__ARM_ARCH_7__
.您可以使用 arm-gcc -mcpu=cortex-a8 -dM -E - < /dev/null
获取定义列表, 以验证 __ARM_ARCH_7__
正在定义。看起来是moc
失败,所以可能是 -D__ARM_ARCH_7_
将需要解决方案。
您也可以尝试更改 -mthumb
在编译器选项中。最好使用 -mcpu=cortex-a8
和 -mthumb
对于您的系统,如果您可以编译/构建它。省略 -mthumb
会使代码稍大。您也可以尝试 -Os
.出于某种原因,我有 巨大的 构建以及其他优化和更新 gcc
版本。这似乎是由于某些 C++ 特性造成的,因为普通的“C”不会这样运行;但这可能只是我的编译器。我看了看并相信这是异常表,但我从未确认任何事情并继续前进。我相信您知道 Qt 编译需要多长时间。
注意 1:qatomic_armv5.h 代码相当困惑且较新 gcc
或 binutils 即使这是要使用的正确文件也会阻塞。
asm volatile("swpb %0,%2,[%3]"
: "=&r"(ret), "=m" (*ptr)
: "r"(newval), "r"(ptr)
: "cc", "memory");
这指定了一些从未使用过的内联汇编器参数。更不用说没有使用条件代码等。
asm volatile("swpb %0,%1,[%2]"
: "=r"(ret)
: "0"(newval), "r"(ptr)
: "memory");
将使用较新的 gcc
编译和 binutils。它还使用较少的寄存器,并且最适合 Qt 当前使用它的方式;可能有 ret
的情况需要保留以便与 newval
进行比较但它目前只是一个用户空间自旋锁。
支架[x]
是一个内存操作数寄存器,必须不同于其他两个有效的参数 swp
.我相信第一种形式用于停止 %0
从与 %3
相同.第二种形式通过制作 %0
来避免这种情况。和 %1
一样,所以%2
必须不同。
关于c++ - 从 ARM 的源代码交叉编译 Qt 4.7 的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21268833/
将 ARM 处理器模式与 x86 操作模式(ring0 到 ring 3)进行比较,用户模式看起来就像 ring3,用户空间程序在其中运行。 但是,我无法将 ring0 与系统模式或主管模式联系起来。
为什么我们在 ARM 架构中有暂存寄存器?处理器如何使用它,我的意思是这个寄存器的用途是什么? 最佳答案 来自 Procedure Call Standard for the Arm Architec
我了解弱内存模型和强内存模型的基本区别。但是没有确切的弱定义,它取决于体系结构(这里是 ARM)。 我已经阅读了有关 ARM 信息中心的文档,但仍有很多内容不清楚。有人可以列出 - ARM 保证哪些内
我想在 arm 9 上分析我的代码,是否有任何分析器可以给我函数调用时间和每个函数占用的总周期?我更喜欢任何免费的分析器。我喜欢在 Linux 中使用 kcachegrind。 最佳答案 我不知道有什
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 7 年前。 Improve this qu
众所周知,对于X86架构:按下电源按钮后,机器开始执行0xFFFFFFF0处的代码,然后开始执行BIOS中的代码以进行硬件初始化。 BIOS 执行后,它使用引导加载程序将操作系统镜像加载到内存中。最后
我有 rootfs 和 klibc 文件系统。我正在创建 make 规则,而一些开发人员的编译器较旧,但没有联网。note1 我正在尝试验证所有文件都是使用 arm 仅当检测到某个版本的编译器时。我已
在部署实际应用程序之前,我们使用 ARM 模板部署 Azure 资源,作为构建过程的一部分。 到目前为止,我们所有的应用程序资源都自包含在资源组中。例如需要 SQL Server 和存储帐户的 Web
为什么 ARM Controller 在发生异常时要从 THUMB 状态返回到 ARM 状态? 最佳答案 一种解释可能是 ARM 模式是 CPU 的“ native ”操作模式,与有限的 Thumb
我正在尝试反转 128 位向量 (uint16x8) 的顺序。 例如,如果我有 a b c d e f g h 我想获得 h g f e d c b a 有没有一种简单的方法可以使用 NEON 内在函
有很多关于内存屏障的信息。大多数信息是指多核或多处理器架构。 Stackoverflow 上的某个地方还指出,单核处理器不需要内存屏障。 到目前为止,我找不到任何明确的解释,为什么单核 CPU 上不需
我想在 ARM Cortex A8 处理器上移植一小段代码。 L1 缓存和 L2 缓存都非常有限。我的程序中有 3 个数组。其中两个是顺序访问的(大小> 数组 A:6MB 和数组 B:3MB),第三个
我无法弄清楚这个 ARM 指令是做什么的: strd.w r0, r1, [r2] 我知道这是一个存储指令,它在 *r2 中存储了一些东西。但我不完全确定是什么。为什么有两个源寄存器
我很好奇为什么有些 ARM 指令(如 MUL 和 ADD)不使用桶形移位器。我想知道极限背后的理性。谢谢! 最佳答案 并不是没有使用桶形移位器;这是您无法指定它在非常具体的指令(数据处理和加载/存储)
我需要计算与 SSE 相同的操作: __m128i result1=_mm_avg_epu8 (upper, lower); 使用 NEON,我执行以下操作: uint8x16_t result1=v
我正在尝试使用 PLD 指令。我面临的问题如下: int32_t addr[10]; asm ("PLD [addr,#5]"); 我收到以下错误: Error: ARM register expec
根据 ARM 手册,应该可以访问特定 CPU 模式的存储寄存器,例如“r13_svc”。当我尝试执行此操作时,gcc 对我大喊大叫,并显示以下错误: 立即表达式需要 # 前缀 -- `mov r2,s
我正在使用 mbxxx 目标开发 Contiki 2.7。在构建我的代码时,链接器提示 .ARM.exidx 和 .data 部分的重叠 .在修改了链接器脚本 contiki-2.7/cpu/stm3
如何确定给定 ARM 处理器上是否存在 NEON 引擎?可以为此目的查询任何状态/标志寄存器吗? 最佳答案 我相信unixsmurf's answer如果使用具有特权内核的操作系统,这将与您获得的一样
如何在设备上分析我的 ARM 代码。 这是涉及 USB 和 SDH 处理的裸机代码,我看到了这个 Code Profiler for ARM但似乎很 slim ,我很熟悉DS5但如果您使用基于 lin
我是一名优秀的程序员,十分优秀!