当前位置:网站首页>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

分解指令过程

  1. 指令预读取-定从哪里读取指令 perfetch
  2. 指令读取-从内存系统(lr/r14)中读取指令 fetch
  3. 指令译码-解读指令并产生控制信号
  4. 寄存器读取-提供寄存器的值给操作单元
  5. 分配-分配指令给执行单元
  6. 执行-实际的alu单元处理
  7. 内存访问-数据的存取
  8. 寄存器回写-更新运行结果到寄存器

分支预测

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

在软件中的操作步骤

  1. 敲完之后,要调试设置,选择debugrel-arm汇编版本,浮点,大小端
  2. arm linker-simple image-ro base(烧录地址),设置了烧录地址,之后还要咋
  3. ILINKER-OPTIONS-IMAGE ENTRY POINT 修改同样的入口地址
  4. ILINKER-listing-勾选image map,设置list f name可以设置log日志
  5. arm fromelf - output file name-输出格式
  6. 设置好之后,make,弹出log,点debug,再点击调试代码-写入4

指令条件cond和状态status码

相关的cond,status:见截图

在这里插入图片描述

在这里插入图片描述

c进位
v溢出

关于立即数

  1. 有效性:十六进制的数值/4,也就是数值要向右移动2的n次方,要能被4整除
    向左移动是乘,向右移动是除

寻址方式

内存ddr,寄存器(片上存储器)和外存硬盘,flash的地址

  1. 立即数寻址 ADD R0,R0,#0X3F

  2. 寄存器寻址 ADD R0,R1,R2—R1+R2–>R0

  3. 寄存器间接寻址 LDR R0,[R1] /n STR R0,[R1]

  4. 寄存器移位寻址 LDR ADD R3,R2,R1.LSL,#2

  5. 基地址寻址 LDR R0,[R1,#4] /n LDR R0,[R1] /n LDR R0,[R1,R2]

  6. 多寄存器寻址 LDMIA R0,{R1,R2,R3,R4}

  7. 相对寻址 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

原网站

版权声明
本文为[Btobk]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_42427637/article/details/125946734