- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以,我最近购买了一 block SAMC21 Xplained 开发板,开始尝试学习 ARM 编程。我以前的经验主要是与 PIC 相关。作为示例应用程序,我启动了一个针对 SAMC21 Xplained 板的 ASF Board 项目,并编写了以下主要函数:
#include <asf.h>
#include <stdbool.h>
int main (void) {
system_init();
SysTick_Config(SystemCoreClock/1000);
system_interrupt_enable(SYSTEM_INTERRUPT_SYSTICK);
while(true);
}
void SysTick_Handler(void) {
port_pin_toggle_output_level(LED_0_PIN);
}
当我开始调试时,我成功到达 main 并执行 system_init() 函数。此后,程序计数器将永远挂起。反汇编如下所示:
int main (void) {
000004D0 ??? Memory out of bounds or read error
system_init();
000004D2 ldr r3, #60
000004D4 blx r3
SysTick_Config(SystemCoreClock/1000);
000004D6 ldr r3, #60
000004D8 ldr r0, [r3]
000004DA movs r1, #250
000004DC lsls r1, r1, #2
000004DE ldr r3, #56
000004E0 blx r3
if ((ticks - 1) > SysTick_LOAD_RELOAD_Msk) return (1); /* Reload value impossible */
000004E2 subs r0, #1
000004E4 ldr r3, #52
000004E6 cmp r0, r3
000004E8 bhi #26
SysTick->LOAD = ticks - 1; /* set reload register */
000004EA ldr r3, #52
000004EC str r0, [r3, #4]
SCB->SHP[_SHP_IDX(IRQn)] = (SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFF << _BIT_SHIFT(IRQn))) |
000004EE ldr r2, #52
000004F0 ldr r0, [r2, #32]
000004F2 lsls r0, r0, #8
000004F4 lsrs r0, r0, #8
000004F6 movs r1, #192
000004F8 lsls r1, r1, #24
000004FA orrs r1, r0
000004FC str r1, [r2, #32]
SysTick->VAL = 0; /* Load the SysTick Counter Value */
000004FE movs r2, #0
00000500 str r2, [r3, #8]
SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk |
00000502 movs r2, #7
00000504 str r2, [r3]
NVIC->ISER[0] = (uint32_t)(1 << ((uint32_t)vector & 0x0000001f));
00000506 movs r2, #128
00000508 lsls r2, r2, #24
0000050A ldr r3, #28
0000050C str r2, [r3]
0000050E b #-4 // Debugger PC Hangs
00000510 lsls r1, r2, #16
00000512 movs r0, r0
00000514 movs r4, r0
00000516 movs r0, #0
00000518 lsls r1, r7, #20
0000051A movs r0, r0
0000051C ??? Memory out of bounds or read error
0000051E lsls r7, r7, #3
00000520 b #32
00000522 b #0
00000524 ??? Memory out of bounds or read error
00000526 b #0
00000528 b #512
0000052A b #0
port_base->OUTTGL.reg = pin_mask;
0000052C movs r2, #128
0000052E lsls r2, r2, #8
00000530 movs r3, #130
00000532 lsls r3, r3, #23
00000534 str r2, [r3, #28]
}
00000536 bx lr
我已向 PC 挂起的行添加了注释 (0x0000050E
)。我很困惑,因为看起来 b #-4
汇编指令通过重复分支到自身而表现正确。我不明白的是为什么它首先存在。
编辑首先感谢大家的热心回复!其次,我应该包含更多的代码(对此感到抱歉),但不确定哪些是相关的。我已经编辑了上面的代码以显示整个 main.c 文件。看起来代码中的 while(true) 几乎被放错了地方,但我仍然在努力理解它。
还从我的 .lss 文件中添加一些(希望如此!)有用的片段:
00000000 <_sfixed>:
* Initialize the System and update the SystemCoreClock variable.
*/
void SystemInit(void)
{
// Keep the default device state after reset
SystemCoreClock = __SYSTEM_CLOCK;
0: 20002030 .word 0x20002030
4: 00000441 .word 0x00000441
return;
}
8: 0000043d .word 0x0000043d
c: 0000043d .word 0x0000043d
...
2c: 0000043d .word 0x0000043d
...
38: 0000043d .word 0x0000043d
3c: 0000052d .word 0x0000052d
40: 0000043d .word 0x0000043d
44: 0000043d .word 0x0000043d
48: 0000043d .word 0x0000043d
4c: 0000043d .word 0x0000043d
50: 0000043d .word 0x0000043d
54: 0000043d .word 0x0000043d
58: 0000043d .word 0x0000043d
5c: 0000043d .word 0x0000043d
60: 0000043d .word 0x0000043d
64: 0000043d .word 0x0000043d
68: 0000043d .word 0x0000043d
6c: 0000043d .word 0x0000043d
70: 0000043d .word 0x0000043d
74: 0000043d .word 0x0000043d
78: 0000043d .word 0x0000043d
7c: 0000043d .word 0x0000043d
80: 0000043d .word 0x0000043d
84: 0000043d .word 0x0000043d
88: 0000043d .word 0x0000043d
8c: 0000043d .word 0x0000043d
90: 0000043d .word 0x0000043d
94: 0000043d .word 0x0000043d
98: 0000043d .word 0x0000043d
9c: 0000043d .word 0x0000043d
a0: 0000043d .word 0x0000043d
a4: 0000043d .word 0x0000043d
a8: 0000043d .word 0x0000043d
ac: 0000043d .word 0x0000043d
b0: 0000043d .word 0x0000043d
b4: 0000043d .word 0x0000043d
b8: 0000043d .word 0x0000043d
000004d0 <main>:
#include <asf.h>
#include <stdbool.h>
int main (void) {
4d0: b508 push {r3, lr}
system_init();
4d2: 4b0f ldr r3, [pc, #60] ; (510 <main+0x40>)
4d4: 4798 blx r3
SysTick_Config(SystemCoreClock/1000);
4d6: 4b0f ldr r3, [pc, #60] ; (514 <main+0x44>)
4d8: 6818 ldr r0, [r3, #0]
4da: 21fa movs r1, #250 ; 0xfa
4dc: 0089 lsls r1, r1, #2
4de: 4b0e ldr r3, [pc, #56] ; (518 <main+0x48>)
4e0: 4798 blx r3
must contain a vendor-specific implementation of this function.
*/
__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks)
{
if ((ticks - 1) > SysTick_LOAD_RELOAD_Msk) return (1); /* Reload value impossible */
4e2: 3801 subs r0, #1
4e4: 4b0d ldr r3, [pc, #52] ; (51c <main+0x4c>)
4e6: 4298 cmp r0, r3
4e8: d80d bhi.n 506 <main+0x36>
SysTick->LOAD = ticks - 1; /* set reload register */
4ea: 4b0d ldr r3, [pc, #52] ; (520 <main+0x50>)
4ec: 6058 str r0, [r3, #4]
\param [in] priority Priority to set.
*/
__STATIC_INLINE void NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
{
if(IRQn < 0) {
SCB->SHP[_SHP_IDX(IRQn)] = (SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFF << _BIT_SHIFT(IRQn))) |
4ee: 4a0d ldr r2, [pc, #52] ; (524 <main+0x54>)
4f0: 6a10 ldr r0, [r2, #32]
4f2: 0200 lsls r0, r0, #8
4f4: 0a00 lsrs r0, r0, #8
4f6: 21c0 movs r1, #192 ; 0xc0
4f8: 0609 lsls r1, r1, #24
4fa: 4301 orrs r1, r0
4fc: 6211 str r1, [r2, #32]
{
if ((ticks - 1) > SysTick_LOAD_RELOAD_Msk) return (1); /* Reload value impossible */
SysTick->LOAD = ticks - 1; /* set reload register */
NVIC_SetPriority (SysTick_IRQn, (1<<__NVIC_PRIO_BITS) - 1); /* set Priority for Systick Interrupt */
SysTick->VAL = 0; /* Load the SysTick Counter Value */
4fe: 2200 movs r2, #0
500: 609a str r2, [r3, #8]
SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk |
502: 2207 movs r2, #7
504: 601a str r2, [r3, #0]
* \param[in] vector Interrupt vector to enable
*/
static inline void system_interrupt_enable(
const enum system_interrupt_vector vector)
{
NVIC->ISER[0] = (uint32_t)(1 << ((uint32_t)vector & 0x0000001f));
506: 2280 movs r2, #128 ; 0x80
508: 0612 lsls r2, r2, #24
50a: 4b07 ldr r3, [pc, #28] ; (528 <main+0x58>)
50c: 601a str r2, [r3, #0]
50e: e7fe b.n 50e <main+0x3e>
510: 00000411 .word 0x00000411
514: 20000004 .word 0x20000004
518: 00000539 .word 0x00000539
51c: 00ffffff .word 0x00ffffff
520: e000e010 .word 0xe000e010
524: e000ed00 .word 0xe000ed00
528: e000e100 .word 0xe000e100
0000052c <SysTick_Handler>:
{
PortGroup *const port_base = port_get_group_from_gpio_pin(gpio_pin);
uint32_t pin_mask = (1UL << (gpio_pin % 32));
/* Toggle pin output level */
port_base->OUTTGL.reg = pin_mask;
52c: 2280 movs r2, #128 ; 0x80
52e: 0212 lsls r2, r2, #8
530: 2382 movs r3, #130 ; 0x82
532: 05db lsls r3, r3, #23
534: 61da str r2, [r3, #28]
while(true);
}
void SysTick_Handler(void) {
port_pin_toggle_output_level(LED_0_PIN);
}
536: 4770 bx lr
最佳答案
最近遇到了同样的系统问题。通过分析和更改链接描述文件 (.ld),问题得到了解决。我正在使用自定义链接器脚本。检查您的链接器脚本、MSR、 vector 地址(位于位置 0x0000003C)
关于c - Atmel Cortex-M0+ SAMC21 在 SysTick_Config 之后挂起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32333739/
Cortex M23/33 的 TrustZone 和 Cortex A 的 TrustZone 有什么区别?我可以开始在 Cortex A 处理器上构建我的 Cortex M23 应用程序原型(pr
Cortex-M3 的初始堆栈指针值位于 0x0 且复位处理程序位于 0x4 的原因是什么?这样做的设计理由是什么? 为什么 ARM 人员不能像对待 Cortex-A 那样将 0x0 留给重置处理程序
为一家公司构建的 Cortex A5 编写的代码能否轻松移植到另一家公司构建的 Cortex A9 上? 我想编写一些在 Atmel 的 SAMA5D4 上运行的裸机 C 代码(Cortex A5),
我决定按照本指南在 XU4 上编译 Qt5.8: http://freecode.hu/sbcomp/2016/08/15/compiling-qt-5-8-on-odroid-xu4/但在第 4 步
我正在使用 Sourcery CodeBench Lite 2012.03-56 编译器和 gdb 套件 texane gdb server . 今天我想尝试使用便宜的 STM32VLDISCOVER
我想知道ARM内核(Cortex-A系列处理器)访问内存的顺序?从内核生成的虚拟地址到内存,再从内存传输指令/数据到内核。考虑核心已经为一些数据/指令生成了一个虚拟地址并且 TLB 有一个未命中,那么
据我了解,Cortex M0/M3 处理器只有一个存储空间来保存指令和数据,并且只能通过内存总线接口(interface)进行访问。因此,如果我理解正确,处理器必须在每个时钟周期读取一条新指令才能进入
Cortex-A57 优化指南指出,大多数在 128 位向量数据上运行的整数指令可以双发出(第 24 页,整数基本 F0/F1,逻辑 F0/F1,执行吞吐量 2)。 然而,根据我们的内部(综合)基准测
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我正在使用 Cortex管理一些用于 React 应用程序的数据。 Cortex's API listing列出了一些只存在于数组上的方法,即 filter 和 find。 给定一个对象: var s
我有一个 KL17,我正在尝试编写一个引导加载程序以允许 OTA 更新。我无法跳转到用户应用程序,这就是我正在尝试的。 void JumpToUserApplication(uint32_t user
我正在尝试调试基于运行 FreeRTOS 的 STM32F3 uC 的应用程序。我已在应用程序的线程上下文中的随机位置手动将 PSP 设置为无效值(例如 0),希望触发 memManageFault/
我有一个关于在 cortex m3 中使用信号量的问题。我发现了一个线程“ARM cortex:mutex using bit banding”ARM cortex: mutex using bit
我已经阅读了有关 Cortex-M3(或 M0)的 ARM 文档,它说它可以用作 NVIC Controller 内的电平感应或脉冲(边沿)中断。问题是,如果这是通过软件完成的,那么如何做到这一点相当
Cortex M架构,典型就是STM32系列,比如STM32F103(Cortex M3)。 Cortex A架构,可以细分为Cortex A7,Cortex A8,Cortex A9,Cor
我正在尝试通过编写自己的启动代码和链接器脚本来学习 ARM 处理器的启动过程。我使用的芯片是LPC810,我遵循了http://midibel.com/blink0.html中的示例, 两个例子都在我
有一个比较: if( val0 > val1 ) 其中val0和val1是双变量。 Apple LLVM编译器生成的代码是 +0x184 vcmpe.f64
在 ARM documentation ,它提到 The Cortex-M4 processor supports ARMv7 unaligned accesses, and performs all
我或多或少有关于 Cortex-M 异常(IRQ 中断)的理论问题。假设我们有两个由同一外部信号触发的外部中断 PINT0 和 PINT1。两个中断(在 NVIC 寄存器 IPR0 中)设置相同的优先
我编写了(IMO)几乎最简单的 ARM 应用程序,但它不起作用:)可能出什么问题了?错过了什么? 闪存写入和 CPU 复位后,寄存器中存在垃圾。 请友善,如果你知道,请告诉我必须做什么才能运行最简单的
我是一名优秀的程序员,十分优秀!