super皮波 发表于 2014-05-30 17:58

已经找到对应的代码 在setup中的 cpu_init函数的内嵌汇编中,设置的und irq fiq模式下的堆栈,每种模式下的堆栈都是3个word
回复 3# arm-linux-gcc


   

super皮波 发表于 2014-05-30 17:59

贴一下代码,方便后来人学习
void notrace cpu_init(void)
{
        unsigned int cpu = smp_processor_id();
        struct stack *stk = &stacks;

        if (cpu >= NR_CPUS) {
                printk(KERN_CRIT "CPU%u: bad primary CPU number\n", cpu);
                BUG();
        }

        /*
       * This only works on resume and secondary cores. For booting on the
       * boot cpu, smp_prepare_boot_cpu is called after percpu area setup.
       */
        set_my_cpu_offset(per_cpu_offset(cpu));

        cpu_proc_init();

        /*
       * Define the placement constraint for the inline asm directive below.
       * In Thumb-2, msr with an immediate value is not allowed.
       */
#ifdef CONFIG_THUMB2_KERNEL
#define PLC        "r"
#else
#define PLC        "I"
#endif

        /*
       * setup stacks for re-entrant exception handlers
       */
        __asm__ (
        "msr        cpsr_c, %1\n\t"
        "add        r14, %0, %2\n\t"
        "mov        sp, r14\n\t"
        "msr        cpsr_c, %3\n\t"
        "add        r14, %0, %4\n\t"
        "mov        sp, r14\n\t"
        "msr        cpsr_c, %5\n\t"
        "add        r14, %0, %6\n\t"
        "mov        sp, r14\n\t"
        "msr        cpsr_c, %7"
          :
          : "r" (stk),
              PLC (PSR_F_BIT | PSR_I_BIT | IRQ_MODE),
              "I" (offsetof(struct stack, irq)),
              PLC (PSR_F_BIT | PSR_I_BIT | ABT_MODE),
              "I" (offsetof(struct stack, abt)),
              PLC (PSR_F_BIT | PSR_I_BIT | UND_MODE),
              "I" (offsetof(struct stack, und)),
              PLC (PSR_F_BIT | PSR_I_BIT | SVC_MODE)
          : "r14");
}

勤奋的小青蛙 发表于 2015-01-31 17:27

你好,我有个地方不是很明白。
ARM的CPSR寄存器如图所示:

后5位M决定了处理器的运行模式。
此时我想进入SVC32模式,看了一下别人的代码,是这样写的:        mrs        r0,cpsr
        bic        r0,r0,#0x1f
        orr        r0,r0,#0xd3
        msr        cpsr,r0根据上表的显示,SVC32模式下,M的值为0b10011,但是设置时这个0b是干嘛用的?好像没啥用啊。



回复 8# arm-linux-gcc


   

arm-linux-gcc 发表于 2015-02-01 11:52

回复 13# 勤奋的小青蛙


    0b就表示是二进制啊
页: 1 [2]
查看完整版本: arm中断异常时cpsr显示都是svc模式?