嵌入式八股文4 cpu架构
1.cpu是怎么读取内存的(不考虑dma的情况,通过中断读取)
2.寄存器和cache哪个快(寄存器更快)
3.寄存器,cache,内存,外存的关系(寄存器是cpu内部的存储单元,速度最快,程序运行时变量返回值等可以通过寄存器传递。cache是cpu和内存之间的高速缓存,用来保存一部分数据,方便cpu使用,提高性能。内存是程序运行的时候指令存放的地方,也是堆栈所存在的物理位置。外存即磁盘。)
4.中断基本概念(外部中断由外设或硬件引起,内部中断由软件引起,也称为异常)
5.什么是中断上下文:中断发生时寄存器和堆栈的信息
6.中断函数特点(没有返回值,只能系统调用)
7.中断函数里不能做什么(循环,复杂计算复杂逻辑,阻塞逻辑,延时等)
8.中断向量表是什么(把中断号和中断函数对应起来放到内存中某个位置(例如地址0),从而形成了一个数组,在中断发生时查表从而调用中断函数。
9.函数是怎么传递返回值的(数值型用寄存器返回例如arm的R0,x86的rax,如果是结构体返回值,在栈上生成变量,返回该变量的地址。)
10.为什么返回一个指针后,使用该指针崩溃了(新手常犯的错误,由于返回值是子函数栈上的内容,因为是指针,本质上是把这个地址进行了返回,返回后子函数栈被销毁,该地址不再可用,出现访问非法内容。应当注意在子函数中指针到底指向了什么内容。而数值型的返回值本质上只是把数值进行了拷贝,自然不会有问题。)
11.函数是怎么入参的(从右到左依次入栈,先赋值给寄存器,例如arm最多能用寄存器R0-R3传递4个参数,多余4个参数再直接压栈)
12.如果函数只有一个参数需要入栈吗(可以不入,因为直接使用寄存器传值,但如果还有子函数调用,则需要把寄存器的值保存在栈中再进行调用)
13.R14链接寄存器是干什么的(保存R15的值,子函数调用结束再把这个值赋给R15,这样就返回了此前的指令地址)
14.pc指针指向哪里(下一条要执行的指令地址,鱿鱼arm的三级流水线机制,实际为当前指令地址+8)
15.R13寄存器是什么(sp指针,指向栈顶地址)
16.arm32一共有多少个寄存器(37个,但一般来说都是16个通用寄存器)
17.nandflash和norflash的区别
18.sram和dram区别
19.一个核同时只能运行一个进程对吗(对)
20.Mcu和Soc有什么区别
2.寄存器和cache哪个快(寄存器更快)
3.寄存器,cache,内存,外存的关系(寄存器是cpu内部的存储单元,速度最快,程序运行时变量返回值等可以通过寄存器传递。cache是cpu和内存之间的高速缓存,用来保存一部分数据,方便cpu使用,提高性能。内存是程序运行的时候指令存放的地方,也是堆栈所存在的物理位置。外存即磁盘。)
4.中断基本概念(外部中断由外设或硬件引起,内部中断由软件引起,也称为异常)
5.什么是中断上下文:中断发生时寄存器和堆栈的信息
6.中断函数特点(没有返回值,只能系统调用)
7.中断函数里不能做什么(循环,复杂计算复杂逻辑,阻塞逻辑,延时等)
8.中断向量表是什么(把中断号和中断函数对应起来放到内存中某个位置(例如地址0),从而形成了一个数组,在中断发生时查表从而调用中断函数。
9.函数是怎么传递返回值的(数值型用寄存器返回例如arm的R0,x86的rax,如果是结构体返回值,在栈上生成变量,返回该变量的地址。)
10.为什么返回一个指针后,使用该指针崩溃了(新手常犯的错误,由于返回值是子函数栈上的内容,因为是指针,本质上是把这个地址进行了返回,返回后子函数栈被销毁,该地址不再可用,出现访问非法内容。应当注意在子函数中指针到底指向了什么内容。而数值型的返回值本质上只是把数值进行了拷贝,自然不会有问题。)
11.函数是怎么入参的(从右到左依次入栈,先赋值给寄存器,例如arm最多能用寄存器R0-R3传递4个参数,多余4个参数再直接压栈)
12.如果函数只有一个参数需要入栈吗(可以不入,因为直接使用寄存器传值,但如果还有子函数调用,则需要把寄存器的值保存在栈中再进行调用)
13.R14链接寄存器是干什么的(保存R15的值,子函数调用结束再把这个值赋给R15,这样就返回了此前的指令地址)
14.pc指针指向哪里(下一条要执行的指令地址,鱿鱼arm的三级流水线机制,实际为当前指令地址+8)
15.R13寄存器是什么(sp指针,指向栈顶地址)
16.arm32一共有多少个寄存器(37个,但一般来说都是16个通用寄存器)
17.nandflash和norflash的区别
18.sram和dram区别
19.一个核同时只能运行一个进程对吗(对)
20.Mcu和Soc有什么区别
全部评论
相关推荐
点赞 评论 收藏
分享