当前位置:网站首页>arm-2-基础阶段
arm-2-基础阶段
2022-08-04 05:30:00 【Btobk】
1.熟悉开发板,搭建环境,开发基础流程厘清
1.1 熟悉tiny210开发板结构
arm 9 - 2410, arm11 - 6410, corttexA8-tiny210
认识板子组成以及元件
测试烧写boot,kernel(cp),rootfs(ap),脱机烧写
用户手册
image:烧写镜像---bootloader-boot.bin,kernel-zimage,rootfs-app
1.1.1 核心板和底板介绍
核心板:210——三星的s5pv210 cpu——arm架构(corttexA8)(只是出方案,没有芯片)
实际制造中,主芯片会镶嵌在核心板上,包括存储,cpu,引脚,类似pc上的cpu插槽
ndflash:需要烧系统,系统的存储空间
ddrram:扩展储存空间(128g存储量)
com口
tage的调试口(bootloader)
电源灯
高清接口
底板:更多的是外设
lcd,usb,启动式(sd,内存【ndflash】),uart
1.2 建立板子和pc com连接
通过com口进行log观察,烧写,调试的工作,以后可以用网络更新
1.3 脱机刷系统
1.3.1 烧写
1.启动scurecrt,通过com连接开发板,操作,看log
连接协议-serial(串口),设置基本操作(口,波特率-波特频率)
2.用 sd 卡写入boot loader ,copy相关image,准备烧写
插sd
分区:引导扇区,非引导扇区——引导扇区是看不到的,根据扇区位置以及卷标有无,系统识别出引导和非
无卷标的看不到
使用工具把boot烧进去(引导区)并分区,把images的文件夹copy进去,sd卡会把image装到ndflash,
下次开机就可以使用ndflash启动
3.烧录系统-bootload,ram(kernel,rootfs)
上电之后要去读内容(bl决定内容,arm(ap)决定地址)---bl决定操作系统的地址
以上就是裸板开发(不包含bl)
1.4 基础概念
arm遵循冯诺依曼体系:cpu(转轮)+存储器+外设+总线
高低电平交错产生电子脉冲---模拟0,1, 产生的0,1需要规整一点,系统轮询时钟解决这个事情
1.4.1 电子脉冲的产生:数字电路
二极管,三极管,开关,地线,电阻,电容,与或非
我们的工作核心就是:电子脉冲,看板子,看电路,找到地址,操作地址(操作的最小单元--位)
由此,要学习c语言的地址操作,特别是位运算
推荐知识: 简单的电路原理概要
c语言的地址操作
c语言位运算
1.4.2 开发流程(参考)
1.提需求
2.概要设计(方案):采用什么cpu,nandflash ram,ddrram,norflash
3.两头走: 硬件设计(芯片,模具),软件设计(bsp,uboot往上定制)
4.硬件,修改,软件,驱动(官方有提供),修改
5.集成
6.测试
实际过程,软件很少用开发板,直接上原型板去做 或者模具。
1.4.3 CPU
cpu就是一个轮子,f-取指令(arm指令),d-译码,s-解码(转换成脉冲)
这三个步骤是cpu运行---流水线
三级流水
三级流水
原理图以及电路图以及与或非门
如何控制10的状态-控制电流的走向-控制高低电频-数字电路控制
参考文档:datasheet-s5pv210文档(三星
操作寄存器,让cpu的引脚产生不同的电频,从而实现导通电流和外设,达到目的
开发板:cpu-核心板-底板,对应三个文档手册
电路图:schematic:s5pv210-1205-1148,
电路基本三部分:电源,负载(极管,电阻),中间环节(导线,开关)
数字电路逻辑原件图:见视频11季-0.20秒
基本操作步骤:
确定要控制的电子单元-查看电路图,确定寄存器-查看用户手册(芯片的),寻找寄存器地址
与:
1,1 ->1
a1,a2都通,y才通
或
一个通就行
非
你通我就不通
上图下面的例子是与非门的符号等式和或非门的符号等式
操控高低电平主要是晶体管来进行
.arm体系以及环境
.1 主流芯片
arm官网:www.arm.com
.1 搭建环境
把gcc工具编译链加到环境变量----vim /etc/environment 里
在linux里安装souceinsight
下载一个wine sudo apt install wine
回到桌面,出现wine软件,他会模拟window
把si移动到相关目录并cd
wine xxx.exe
.2 学习的内容
arm---指令集以及译码工作
寄存器---管脚引导到的寄存器,用arm指令控制它输出高低电平
arm汇编---因为没有操作系统,要操作寄存器就需要用汇编
cash---操作过程中会有虚拟内存,缓存机制
mmu---除了寄存器,还有mmu,内存管理机制
协议---不同的协议(网卡,com,蓝牙),连接协议不一样
arm的芯片系列文档观看
.3 开发工具
qeml - 模拟路由器
buybox - 编译生成rootfs文件夹,不用一个,去编译
scrarchbox-交叉编译平台
uboot
uefi-统一可扩展部件接口,规定了硬件的条件,系统跟随硬件,没有这些硬件就装不了(可以限制盗版)‘了,
模拟arm的开发环境工具:详见29-12.00
工具链
工具链的工作原理
eabi:嵌入式 应用 二进制 接口
编译链命令
.Arm寄存器,模式和指令合集
Arm指令集
32位指令集
thumb指令集--16位,代码密度高,运行慢
thumb指令集--16位和32位混合指令集
cpu组成
alu(逻辑运算单元-运算器-跑起来的轮子)+控制器(什么时候干什么)+寄存器(切换,读取效率提升,存储临时性和控制性的代码)+cpu内部总线(连接前面几个组件)
处理器模式
遇到突发状况(*蓝屏),可以进行改变模式来达到-效率控制,节能控制,安全控制
ctexa有9种模式
见下图
fiq:快速中断模式(中断:*正在运行,用户敲键盘,优先执行用户的需求(有软件中断,也有硬件中断))
irq:一般中断(要处理的数据相对于ifq要少)
svc-supervisor 超级管理员:优先级高的
mon:监视,类似于后台服务,不需要处理用户中断
abort abt:退出模式
hyp:超级监视者,比超级管理员级别低,用于虚拟化扩展,用到少
und:未定义指令执行
sys:系统模式,系统自身异常时进入,特点是寄存器和用户共享,只是访问权限不一样
以上除了user,其他全是特权模式
armA系列寄存器
—寄存器有内部寄存器和外部寄存器,内部是控制cpu的,外部是控制外设的—
寄存器相当于cpu工作台,ram相当于笔筒(里面有很多工具),rom相当于仓库
*当cpu轮子转动,从内存中读取数据,当异常,转换cpu模式,存数据,不过存内存太慢,不稳定,就可以存到寄存器
见下图
r0-r12 都是通用,放通用数据,32bit
r13 sp:stack point 栈指针,储存需要指向某些栈空间的位置,提醒cpu改切换空间
r14 lr:link r 连接寄存器,储存了子程序回家的地址(切换函数的调用)
r15 pc:程序计数 cpu在每个空间,模式切换的时候会+1,-1
apsr/cpsr:psr 程序状态寄存器 ,a-应用(在用户模式下),c-当前(在其他模式)
spsr:已保存程序状态寄存器(use模式没有,因为user是非常正常的模式,基本上不会异常),缓存状态的c(ab交换值的操作)
使用汇编的时候,就可以使用这个寄存器的图表了
- 程序返回 :MOV PC,LR
把lr的值给pc
不同的指令集,能够使用的寄存器数量也不一样
CPSR格式
:见截图
5位:thumb 是否位,1是
6:fiq,是不是禁用fiq,0使能-允许,使可以
9:大端还是小端操作,字节的存储位置
smid:单指令多数据流
指令流水线pipeline
分解指令过程
- 指令预读取-定从哪里读取指令 perfetch
- 指令读取-从内存系统(lr/r14)中读取指令 fetch
- 指令译码-解读指令并产生控制信号
- 寄存器读取-提供寄存器的值给操作单元
- 分配-分配指令给执行单元
- 执行-实际的alu单元处理
- 内存访问-数据的存取
- 寄存器回写-更新运行结果到寄存器
分支预测
a运行到一个点发现需要b‘,于是到b,b需要c,c完事到b,b到a,如果cpu只会单线程进行,就会很慢,如果提前告诉cpu,a-》b-》c,效率会大大增加
预测就是把这个流程存在lr里面,他就去跳的快
动态预测(btac/btb)比早期的预测更厉害,应用了缓存,l1,l2;把下一步可能跳转到的分区全部列出来,定了那个口就直接知道去哪,典型的用空间换时间
.arm汇编
程序 = 数据结构+算法
与硬件 相关的编程语言,汇编
承上启下-寄存器和内存操作,更多以指令新式存在
不同平台上简单的格式,见下图:
完整的指令格式
operation(cond) (s)Rd,Rn,Operand2
add(条件) (状态码/标识符) 目标寄存器,原寄存器 后续操作
*
* ADD(EQ)(N) R1,R2,#100
//把r2加上100存到r1,设置标识符,并判断比较值是否相等
在32位的指令集中,会转换成32位的01串,6块占用不同的块
汇编格式
AREA EX,CODE,READONLY
//代码区域 代码名,表代码,只读
ENTRY
//入口
CODE32
32位
START
//开始?跳转
END
metrowerks codewarrior for arm 仿真软件,ads软件,
参考文档:https://www.cnblogs.com/cc11001100/p/13974597.html
这个软件安装的时候要特别小心,出错了会很麻烦
AREA TEST,CODE,READONLY
ENTRY
CODE32
START
ADD R1,R2,#5
END
在软件中的操作步骤
- 敲完之后,要调试设置,选择debugrel-arm汇编版本,浮点,大小端
- arm linker-simple image-ro base(烧录地址),设置了烧录地址,之后还要咋
- ILINKER-OPTIONS-IMAGE ENTRY POINT 修改同样的入口地址
- ILINKER-listing-勾选image map,设置list f name可以设置log日志
- arm fromelf - output file name-输出格式
- 设置好之后,make,弹出log,点debug,再点击调试代码-写入4
指令条件cond和状态status码
相关的cond,status:见截图
c进位
v溢出
关于立即数
- 有效性:十六进制的数值/4,也就是数值要向右移动2的n次方,要能被4整除
向左移动是乘,向右移动是除
寻址方式
内存ddr,寄存器(片上存储器)和外存硬盘,flash的地址
立即数寻址 ADD R0,R0,#0X3F
寄存器寻址 ADD R0,R1,R2—R1+R2–>R0
寄存器间接寻址 LDR R0,[R1] /n STR R0,[R1]
寄存器移位寻址 LDR ADD R3,R2,R1.LSL,#2
基地址寻址 LDR R0,[R1,#4] /n LDR R0,[R1] /n LDR R0,[R1,R2]
多寄存器寻址 LDMIA R0,{R1,R2,R3,R4}
相对寻址 BL NEXT /n MOV PC,LR
3. LDR R0,[R1] STR R0,[R1] 在内存和寄存器中操作,把r1的值的地址赋值到r0 ldr:*r1的值:103,他会把103当成内存的一个地址,去内存里找值传递到r0 str:把r0的值放到r1的内存地址里 可以在mermory里查看 4. LDR ADD R3,R2,R1.LSL,#2 把r1+r2赋值r3,左移(L)两个立即数 5. LDR R0,[R1,#4] 把r1里的值加上立即数4的指向的地址的值读到r0 LDR R0,[R1] r1指向内存的地址,取出值,加上4,赋值 LDR R0,[R1,R2] r1+r2的地址指向内存的值,赋值 6. LDMIA R0,{R1,R2,R3,R4} 用的少,批量操作,类似与上面一个 7. BL NEXT 跳转到next,保存状态到寄存器 MOV PC,LR
arm堆栈
先进后出,堆栈指针指向最上面,arm在读取和存储内存相关信息(LDR,SDR),就会用到
- 满堆栈 堆栈指针指向最上面
- 空堆栈 堆栈指针指向最上面的下一个
- 递增堆栈 低地址向高压栈(下往上)
- 递减堆栈 高地址向低压栈(上往下)
数据操作(寄存器alu操作)
常用命令
数学操作
黑体的是重点掌握的
mul(乘法)不能用立即数,op和r一个是可以表示寄存器,一个表示寄存器
逻辑操作
与:只有两个都为1,才为1
或:只要有一个为1,就为1
非:见到0就变成1,见到0就变成1
抑或:当两个值不同时才为1(1和1抑或=0)
比较操作
比较完的结果,会存到cpsr里
见截图:
回顾:二进制的取反运算复习
内存操作-读取内存
之前都是寄存器的操作
把内存的东西放到寄存器,或者反过来–存储器和内存的互换
单寄存器内存访问
单对单的访问
ldr:load register
在这里,ldr把#0x19赋值给R1,LDR取R1的值(0x19)的地址(最下面圈起来的两块地方)给R0,因为是0x19,找10和9的地址,在下方框坐标(10,2),取四个字节,因为取完了(到b)然后转到8(因为是一整块),有因为是小端模式,所以R0的取值顺序是00 ff e7,取完了回到地8-10,,小端模式–10e7ff00
STR-寄存器的值反向写到内存的地址里去
把r1的值写成0f(寄存器的值)
STR R1,[R0,0x0C]:把r1的值写到内存的地址(内存的地址:把0x0c这个地址给r0)
多寄存器内存访问
单对多或者多对单访问(连续的一块)
ldm:读,把r0读到r3-r9
stm:写,把r3-r9写到r1为起始的地方
把r1的值代表的地址 的值 给 r2,r3(每次赋值,地址+上4)
ldr和ldm都是寄存器把值给内存,只是入口不一样
数据交换
有中括号的就是寄存电器间接寻址
如果要直接交换,可以改成 SWP R1,R1,[R2]
跳转,状态操作
cpsr和spsr 是状态寄存器,是不允许直接操作的
特殊寄存器:sp,lr,pc(计数器)
MOV跳转
MOV LR,PC ///lr就是用来储存值的,这里储pc的跳转前位置,好让pc跳转之后再回来
MOV PC,[R0] ///把r0给pc,相当于把r0变成pc
B (Branch)
跳了但是回不来了 ,BL可以调回来,原理类似于MOV跳转
用b或者bl实现循环
伪指令
伪指令作用以及类别
基本常用伪指令
EQU:定义常量
伪指令要顶头才能识别出来
EXPORT 相当于GLOBAL,引用外部函数
Rn 给寄存器起别名
在汇编中常用符号
符号命名约定
符号,变量
rlist,给一堆的寄存器顶一个别名
//把relist中的寄存器从r2的位置开始写进去
变量常量
变量代换
表达式和运算符
/= ,<> 都是不等于
寄存器操作(是伪指令,不是arm指令)
数据定义汇编
dcb docontrol bit
dcw docontrol word
dcd: docontol doc
如果存储的是字符串
控制伪指令
混合编程
1.调高工作效率
2.提高兼容性
在uboot中,刚启动还没有任何系统,需要用汇编来启动,启动之后就会有自己的系统了,这个时候引入高级语言
汇编和c/c++混合编程方程
c嵌入汇编
pc寄存器:计数器
一般情况下就用r0~r7
目标实现:src复制到dest
ldrb :按字节读取
strb:按字节存
bne:b+ne(条件)
ldrb ch,【src】,#1 按字节读取src到ch,然后地址加一
cmp ch,#0 因为字符串最后一位为0
调用,在这个过程中不断用到了r0和r1存参数
c调用汇编
看下面一个例子
:
接下来跳到汇编
汇编调用c
大量使用
在这里,返回值是r0,所以把0赋值了4
汇编常用操作
这里有很多例子
arm硬件
程序操纵记忆,记忆里面全是地址
arm硬件基础概述
了解常用硬件接口,并编程控制
掌握各个接口与实现原理
各个接口的作用,实现医院里以及特性
地址,寄存器,协议
研究方向&如何研究
类似于两个人对话,需要语言,讲话频率
硬件原理和构造
通信协议
时长/频率2
ARM文档
厂家芯片文档
厂家外设文档
s5pv210的硬件(1)
CPU核心
simd和neon
Cache(缓存)
系统外围
RTC(实时时钟 real-time clock )
cpu在转动,需要一个计数的时钟
PLL
一般情况不去控制
PWM TIMER
液晶屏一亮一亮,就是她的问题
也用来做蜂鸣器
WATCG DOG TIMER
由于电磁脉冲的干扰,有电就有磁力,有磁力就会干扰电,如果总线没有抗干扰能力,程序就会烤飞,达不到想要的效果
没有烤飞的时候,看门狗会不断发出信号告知正常,一旦烤飞,停止发送信号,程序会复位,再次执行
DMA
直接 内存 访问
外设的物理地址会映射到虚拟地址,假如内存的数据需要和外设的网卡进行交互,交互的过程中需要依赖于cpu的轮子,但是如果cpu正在处理别的程序,就会浪费时间,耗时间dma就是,没有中间商(cpu)赚差价
KEYPAD
按钮
ADC
模拟信号和数字信号转换器
- 温度传感器
连接
USB/otg
otg:小一点的usb
UART
一条 串行总线,出来了一条连着适配器,就叫yart
IIC
uart太简单了,就有人设计了这种串口总线
SPL
MODEM IF(if:inter face 接口)
通讯
GPIO
最简单的连接方式
AUDIO IF(音频)
STORAGE IF(存储器)
多媒体
储存接口
sram/srom
s表示静态
onenand
效率较高的nandflash ,速度快,造价不 贵,存储量大
slc/mlc nand
单层 单元
多层 单元
nandflash内存存储的硬件结构不同
ddr
内存
电源管理
clock gating 时钟
power gating 电源
frequency scaling 频率
s5pv210的硬件(2)
gpio(通输入输出)
协议(uart,usb,i2c … … )
控制器和转换器
列如存储控制器,网卡,lcd
数电模电转换:温度感应器
simd&neon
sisd读取内存到寄存器中,只能一条一条去fdz,但是simd却能一批一批
neon就是simd升级扩展
cache
为什么需要
soram
缓存的命中率:程序分块,一块块进入缓存,cpu直接从缓存读取数据,要是没有读取到想要的数据,还是会从主存读取,这就涉及到一个命中率:
内存层级
sram造价高,内存大没有意义,而且是曲线的一个趋势,命中率是指数级
存储器层级
缓存控制器 cache controller
直接映射缓存direct maooed cache
联合缓存 set-assocative cache
缓存结构总结
局部性:连续的代码空间上时间上,有规律可以被预测,被预缓存
MMU
存储 管理 单元
- 程序和程序之间互不干扰
- 内存4g,程序占用2g,游戏3g,内存不够,就会使用预处理,先存游戏的一小部分,加载完再销毁
虚拟存储器
作用
虚拟地址,物理地址,页,缺页
页:存储的最小单元,内存空间不是亿字节一字节存的,他是有字节的方法的,她是一片一片存储的,一页一般是4-16k
虚拟内存也有命中率,没有命中就是缺页
页与页之间要通过mmu
mmu会保护,负责各个进程有顺序的访问物理地址,不会同时访问一个地址
mmu会通过地址映射吧vm编程物理地址
页保护以及锁定
mmu会保护,负责各个进程有顺序的访问物理地址,不会同时访问一个地址
mmu会通过地址映射吧vm编程物理地址
地址转换过程
分段
代码再一段,静态变量在一段
页的存放和查找
index就是页码表
缺页
不缺页直接读取内存,缺页了就交给操作系统,从磁盘地址取值
TLB高速地址转换
*十户一组
TLB缺失
srom:cache
drom:内存
rom:硬盘/nandflash
边栏推荐
- 如何用Pygame制作简单的贪吃蛇游戏
- ConnectionRefusedError: [Errno 111] Connection refused问题解决
- MNIST手写数字识别 —— 基于Mindspore快速构建感知机实现十分类
- [CV-Learning] Convolutional Neural Network Preliminary Knowledge
- tensorRT5.15 使用中的注意点
- 0, deep learning 21 days learning challenge 】 【 set up learning environment
- 【论文阅读】SPANET: SPATIAL PYRAMID ATTENTION NETWORK FOR ENHANCED IMAGE RECOGNITION
- 亚马逊云科技 Build On 2022 - AIot 第二季物联网专场实验心得
- Deep Learning Theory - Initialization, Parameter Adjustment
- 度量学习(Metric learning)—— 基于分类损失函数(softmax、交叉熵、cosface、arcface)
猜你喜欢
在AWS-EC2中安装Minikube集群
[CV-Learning] Semantic Segmentation
强化学习中,Q-Learning与Sarsa的差别有多大?
[Deep Learning 21 Days Learning Challenge] Memo: What does our neural network model look like? - detailed explanation of model.summary()
Halcon缺陷检测
Vision Transformer 论文 + 详解( ViT )
MNIST handwritten digit recognition, sorted by from two to ten
Copy攻城狮信手”粘“来 AI 对对联
【Copy攻城狮日志】“一分钟”跑通MindSpore的LeNet模型
【CV-Learning】图像分类
随机推荐
强化学习中,Q-Learning与Sarsa的差别有多大?
Android connects to mysql database using okhttp
学习资料re-id
"A minute" Copy siege lion log 】 【 run MindSpore LeNet model
BatchNorm&&LayerNorm
[CV-Learning] Linear Classifier (SVM Basics)
【CV-Learning】图像分类
SQL注入详解
【CV-Learning】Object Detection & Instance Segmentation
动手学深度学习_softmax回归
lstm pipeline 过程理解(输入输出)
TensorFlow2 study notes: 7. Optimizer
亚马逊云科技Build On-Amazon Neptune基于知识图谱的推荐模型构建心得
中国联通、欧莱雅和钉钉都在争相打造的秘密武器?虚拟IP未来还有怎样的可能
机器学习——分类问题对于文字标签的处理(特征工程)
Copy攻城狮的年度之“战”|回顾2020
How to grow into a senior engineer?
Lee‘s way of Deep Learning 深度学习笔记
【论文阅读】Mining Cross-Image Semantics for Weakly Supervised Semantic Segmentation
【Copy攻城狮日志】飞浆学院强化学习7日打卡营-学习笔记