标题: 以为是sizeof问题,后来发现是C语言指针定义问题,记录下遇到的问题(1) [打印本页]

作者: songjie_he    时间: 2022-3-2 23:13
标题: 以为是sizeof问题,后来发现是C语言指针定义问题,记录下遇到的问题(1)
typedef struct
{
e_uint32_t r0;
e_uint32_t r1;
e_uint32_t r2;
e_uint32_t r3;

e_uint32_t r12;
e_uint32_t lr;
e_uint32_t pc;
e_uint32_t xpsr;        
}e_cpu_reg;

typedef struct
{
e_uint32_t r4;
e_uint32_t r5;
e_uint32_t r6;
e_uint32_t r7;

e_uint32_t r8;
e_uint32_t r9;
e_uint32_t r10;
e_uint32_t r11;
        
e_cpu_reg cpu_reg_autosave;        
}e_cpu_reg_to_save;


void *e_thread_sp_init(e_thread *thread)
{
e_uint32_t        *stk;  //////指针类型定义错误,造成极其严重的后果。(应改为e_uint8_t)
e_cpu_reg_to_save *cpu_save_reg;
        
stk =  thread -> stack_addr;///获取任务的堆栈        
stk = stk + thread->size;/////取得任务的堆栈最大值,因为是向下生长的
stk = (stk - (((e_uint32_t)stk) % 8));        /////模8处理,地址不
stk = stk - (sizeof(e_cpu_reg_to_save));////从底部腾出CPU需要保存的寄存器占用的地址
         
cpu_save_reg        = (e_cpu_reg_to_save *)stk;
        
cpu_save_reg ->cpu_reg_autosave.r0= 0x0;        
cpu_save_reg ->cpu_reg_autosave.r1 = 0x1;
cpu_save_reg ->cpu_reg_autosave.r2 = 0x2;
cpu_save_reg ->cpu_reg_autosave.r3 = 0x3;
cpu_save_reg ->cpu_reg_autosave.r12 = 0x12;         
        
cpu_save_reg ->cpu_reg_autosave.lr = 0xdeadbeef;
cpu_save_reg ->cpu_reg_autosave.pc = (e_uint32_t)(thread -> program);
cpu_save_reg ->cpu_reg_autosave.xpsr = 0x01000000;
         
cpu_save_reg ->r4  = 0x04;
cpu_save_reg ->r5  = 0x05;
cpu_save_reg ->r6  = 0x06;
cpu_save_reg ->r7  = 0x07;
cpu_save_reg ->r8  = 0x08;
cpu_save_reg ->r9  = 0x09;
cpu_save_reg ->r10 = 0x0a;
cpu_save_reg ->r11 = 0x0b;

return stk;
}



作者: songjie_he    时间: 2022-3-3 16:16
本帖最后由 songjie_he 于 2022-3-3 16:18 编辑

这个是我自己写的RTOS中任务堆栈初始化的函数,仅供参考,参考的是RT_THREAD。适用于堆栈向下生长的处理器。




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1