- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我已按照标准程序从 STMicroelectronics 启动并运行我的新 Nucleo-F767ZI 板。流程如下:
第一步
我从 AC6 下载了 SW4STM32 IDE。这是一个基于 Eclipse 的 IDE,用于对 STMicroelectronics 的 STM32 微 Controller 系列进行编程。
第 2 步
我从 STMicroelectronics 下载了最新的 CubeMX 软件。 CubeMX 是一个基于 java 的工具,您可以在其中为您的微 Controller 配置一些基本设置:时钟速度、实时操作系统、外围设备……。之后,CubeMX 吐出一个文件夹,里面有一堆 c 源文件。这基本上就是您要开始的项目。
第 3 步
我打开 SW4STM32 IDE 并导入 CubeMX 刚刚生成的项目。我不更改或添加任何代码。我只是单击构建按钮,希望该项目将编译为可执行的 .bin 文件(也可能是 .elf 文件)。这就是问题所在。
错误
编译器发现(或认为他发现)FreeRTOS文件portmacro.h
中的以下函数有错误:
171 /* Generic helper function. */
172 __attribute__( ( always_inline ) ) static inline uint8_t ucPortCountLeadingZeros( uint32_t ulBitmap )
173 {
174 uint8_t ucReturn;
175
176 __asm volatile ( "clz %0, %1" : "=r" ( ucReturn ) : "r" ( ulBitmap ) );
177 return ucReturn;
178 }
我从编译器得到的错误信息是:
line 173 : sorry, unimplemented: Thumb-1 hard-float VFP ABI
现在有几个原因导致我不理解这个特定的错误消息:
>> 第一期
第一个问题是关于错误的位置。第 173 行是左花括号所在的行。为什么错误消息会引用该行?
>> 第 2 期
其次,我不明白为什么错误消息会提到我的微 Controller 上的硬件浮点单元。我在 ucPortCountLeadingZeros(..)
函数中看不到任何浮点指令。
>> 第 3 期
我在Eclipse项目中打开了GCC编译器设置。只是为了看一下默认设置。我没有改变任何东西。这是两个屏幕截图:
第一个屏幕截图显示选择了以下选项:
Instruction set : Thumb II
第二个屏幕截图显示为 GCC 提供了以下选项:
-mfloat-abi=hard # Inform GCC that this micro has a hardware floating point unit
-mfpu=fpv5-d16 # The hardware floating point unit is double precision
-mthumb # ARM Thumb instruction set
那么,实际上选择的是什么Thumb指令集版本。拇指 I 还是拇指 II?
请帮我找出为什么这个从 CubeMX 生成的项目无法编译。我非常感谢任何提示和提示。
编辑:
传递给 GCC 编译器的完整选项集(如第二个屏幕截图所示)如下:
-mthumb
-mfloat-abi=hard
-mfpu=fpv5-d16
-D__weak="__attribute__((weak))"
-D__packed="__attribute__((__packed__))"
-DUSE_HAL_DRIVER
-DSTM32F767xx
-I../Inc
-I../Drivers/STM32F7xx_HAL_Driver/Inc
-I../Drivers/STM32F7xx_HAL_Driver/Inc/Legacy
-I../Middlewares/Third_Party/FreeRTOS/Source/portable/GCC/ARM_CM7/r0p1
-I../Middlewares/Third_Party/FreeRTOS/Source/include
-I../Middlewares/Third_Party/FreeRTOS/Source/CMSIS_RTOS
-I../Drivers/CMSIS/Include
-I../Drivers/CMSIS/Device/ST/STM32F7xx/Include
-Os
-g3
-Wall
-fmessage-length=0
-ffunction-sections
-c
-fmessage-length=0
最佳答案
如问题下方的评论所述,CubeMX 生成的项目未向编译器指定 -mcpu
选项。因此,应该手动将此选项添加到编译器、链接器和汇编器中:
-mcpu=cortex-m7
如果你这样做,它会毫无问题地构建。
将选项添加到编译器、链接器和汇编器有点棘手。我将详细解释如何操作。
<强>1。将选项添加到编译器
> 在 Eclipse 的左侧窗口中右键单击您的项目文件夹。在弹出窗口中单击Properties
。
> 在属性窗口中,选择左侧的 C/C++ Build
> Settings
。
> 现在您应该在窗口中间看到 3 个选项:MCU GCC Compiler
、MCU GCC Linker
和 MCU GCC Assembler
。单击第一个,然后选择 Miscellaneous
。
> 您应该看到 other flags
行。将以下选项添加到该行:-mcpu=cortex-m7
。
<强>2。将选项添加到汇编器
> 在同一属性窗口中,选择 MCU GCC Assembler
> General
。
> 您应该看到 Assembler flags
行。将选项 -mcpu=cortex-m7
添加到该行。
<强>3。将选项添加到链接器
> 再次在属性窗口中,选择MCU GCC Linker
。
> 您应该看到 命令行模式
行,其中包含以下文本:
${COMMAND} ${FLAGS} ${OUTPUT_FLAG} ${OUTPUT_PREFIX}${OUTPUT} ${INPUTS}
> 将选项 -mcpu=cortex-m7
添加到该行。
完成所有这些之后,编译器、汇编器和链接器都知道您要为 Cortex-M7 架构构建。 CubeMX 默认情况下没有将它放在生成项目的配置文件中,这仍然让我有些困扰。但至少,我们现在知道解决方法..
非常感谢@Notlikethat、@Jean-Louis Bonnaffe 和@rjp 给我带来了这个解决方案并提供了有用的评论:-)
关于c - GCC 交叉编译器(用于 ARM micro)在不存在 FP 指令的函数中提示 'non supported floating point ABI',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39348909/
将 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
我是一名优秀的程序员,十分优秀!