1
2
3
7
8
9
10
11
12
13
14
15
16
17
20
21
22
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/* ... */
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include "rtos.h"
#include "target/armv7m.h"
#include "rtos_standard_stackings.h"
#include "rtos_riot_stackings.h"
/* ... */
static target_addr_t rtos_riot_cortex_m_stack_align(struct target *target,
const uint8_t *stack_data, const struct rtos_register_stacking *stacking,
target_addr_t stack_ptr)
{
const int XPSR_OFFSET = 0x40;
return rtos_cortex_m_stack_align(target, stack_data, stacking,
stack_ptr, XPSR_OFFSET);
}{ ... }
static const struct stack_register_offset rtos_riot_cortex_m0_stack_offsets[ARMV7M_NUM_CORE_REGS] = {
{ ARMV7M_R0, 0x24, 32 },
{ ARMV7M_R1, 0x28, 32 },
{ ARMV7M_R2, 0x2c, 32 },
{ ARMV7M_R3, 0x30, 32 },
{ ARMV7M_R4, 0x14, 32 },
{ ARMV7M_R5, 0x18, 32 },
{ ARMV7M_R6, 0x1c, 32 },
{ ARMV7M_R7, 0x20, 32 },
{ ARMV7M_R8, 0x04, 32 },
{ ARMV7M_R9, 0x08, 32 },
{ ARMV7M_R10, 0x0c, 32 },
{ ARMV7M_R11, 0x10, 32 },
{ ARMV7M_R12, 0x34, 32 },
{ ARMV7M_R13, -2, 32 },
{ ARMV7M_R14, 0x38, 32 },
{ ARMV7M_PC, 0x3c, 32 },
{ ARMV7M_XPSR, 0x40, 32 },
...};
const struct rtos_register_stacking rtos_riot_cortex_m0_stacking = {
.stack_registers_size = 0x44,
.stack_growth_direction = -1,
.num_output_registers = ARMV7M_NUM_CORE_REGS,
.calculate_process_stack = rtos_riot_cortex_m_stack_align,
.register_offsets = rtos_riot_cortex_m0_stack_offsets
...};
static const struct stack_register_offset rtos_riot_cortex_m34_stack_offsets[ARMV7M_NUM_CORE_REGS] = {
{ ARMV7M_R0, 0x24, 32 },
{ ARMV7M_R1, 0x28, 32 },
{ ARMV7M_R2, 0x2c, 32 },
{ ARMV7M_R3, 0x30, 32 },
{ ARMV7M_R4, 0x04, 32 },
{ ARMV7M_R5, 0x08, 32 },
{ ARMV7M_R6, 0x0c, 32 },
{ ARMV7M_R7, 0x10, 32 },
{ ARMV7M_R8, 0x14, 32 },
{ ARMV7M_R9, 0x18, 32 },
{ ARMV7M_R10, 0x1c, 32 },
{ ARMV7M_R11, 0x20, 32 },
{ ARMV7M_R12, 0x34, 32 },
{ ARMV7M_R13, -2, 32 },
{ ARMV7M_R14, 0x38, 32 },
{ ARMV7M_PC, 0x3c, 32 },
{ ARMV7M_XPSR, 0x40, 32 },
...};
const struct rtos_register_stacking rtos_riot_cortex_m34_stacking = {
.stack_registers_size = 0x44,
.stack_growth_direction = -1,
.num_output_registers = ARMV7M_NUM_CORE_REGS,
.calculate_process_stack = rtos_riot_cortex_m_stack_align,
.register_offsets = rtos_riot_cortex_m34_stack_offsets
...};