judy的博客

ARM的22个概念总结

judy的头像

1.ARM中一些常见英文缩写解释

MSB:最高有效位;

LSB:最低有效位;

AHB:先进的高性能总线;

VPB:连接片内外设功能的VLSI外设总线;

EMC:外部存储器控制器;

MAM:存储器加速模块;

VIC:向量中断控制器;

SPI:全双工串行接口;

CAN:控制器局域网,一种串行通讯协议;

PWM:脉宽调制器;

ETM:嵌入式跟踪宏;

CPSR:当前程序状态寄存器;

SPSR:程序保护状态寄存器;

2.MAM 使用注意事项

当改变 MAM 定时值时,必须先通过向 MAMCR 写入 0 来关闭 MAM,然后将新值写入 MAMTIM。最后,将需要的操作模式的对应值写入MAMCR,再次打开MAM。

对于低于 20MHz 的系统时钟,MAMTIM 设定为 001。对于 20MHz 到 40MHz 之间的系统时钟,建议将Flash访问时间设定为2cclk,而在高于40MHz的系统时钟下,建议使用3cclk。

3.VIC 使用注意事项

单片机小白学步(22) IO口:蜂鸣器的使用/三极管的工作原理

judy的头像

这一篇继续上一篇的内容,我们来做实验四:按键控制有源蜂鸣器,按下按键蜂鸣器响,释放按键不响。

蜂鸣器

实验四之前简单介绍下蜂鸣器。蜂鸣器有两种,无源蜂鸣器和有源蜂鸣器,一般用于发出报警的声音。声音是由震动产生的,大家都见过喇叭,喇叭里面有磁铁和线圈。给线圈通上不断变化的电压,在磁铁产生的磁场中就会运动。于是和线圈固定在一起的振膜就会震动,于是就能听见声音了,而无源蜂鸣器和喇叭效果基本一样。和无源蜂鸣器不同的是,有源蜂鸣器内部就有发声电路,通上电压合适的直流电就会发出叫声。另外,有源蜂鸣器有正负极之分。图中是常用的一种工作电压为5V的有源蜂鸣器,正面标有加号的一侧引脚为正极,如果器件是全新的没有剪过引脚,正极引脚比负极长。

从应用角度比较块存储、文件存储、对象存储

judy的头像

从应用角度看块存储、文件存储、对象存储

产品和市场需求有各种相互影响的关系,但不管是哪一种,最终呈现都是产品和应用需求需要对应匹配。应用需求越多样化,市场也就划分得更加细,产品种类也就更加丰富。在存储行业,我们也可以从“应用适配”这个角度来聊聊各类存储。

传统认知上来说,IT设备分为计算/存储/网络三大类,相互之间是有明显的楚河汉界的。计算大家都清楚,服务器,小型机,大型机;网络也就是路由器交换机;存储有内置存储和外置存储,最常见的就是磁盘阵列。在HCI(超融合)这个概念没被热炒之前,计算网络存储还都是泾渭分明,各担其责的。今天我们先不讨论超融合的情况,仅基于传统理解,看看存储的情况。

从逻辑上存储通常分为块存储,文件存储,对象存储。这三类存储在实际应用中的适配环境还是有着明显的不同的。

ARM的37个寄存器

judy的头像

31个通用寄存器,包括程序计数器(PC)在内。这些寄存器都是32位寄存器。

6个状态寄存器。这些寄存器都是32位寄存器。

通用寄存器(R0-R15)可分为三类 :

• 不分组寄存器R0~R7;

• 分组寄存器R8~R14;

• 程序计数器PC。

对于R13,R14备份寄存器来说,每个寄存器对应六个不同的物理寄存器,其中的一个是系统模式和用户模式共用的;另外的五个对应于其他的五种处理器模式。

1、ARM总共有37个寄存器,但是每种模式下最多只能看到18个寄存器,其他寄存器虽然名字相同但是在当前模式不可见。

2、对r13这个名字来说,在ARM中共有6个名叫r13(又叫sp)的寄存器,但是在每种特定处理器模式下,只有一个r13是当前可见的,其他的r13必须切换到他的对应模式下才能看到。这种设计叫影子寄存器(banked register)。

3、R14(lr)存放返回地址

CPSR程序状态寄存器

由内至外分析晶振停振的原因

judy的头像

有许多工程师在遇到,晶振在电路板,一会儿起振,一会儿不起振,或用电吹风吹一下又可以正常工作等问题。这个时候就开始怀疑是否是晶振出问题了,其实我们不能下太早结论,必须抓到问题核心,才能做出正确判断。

唯物辩证法指的是一种研究自然、社会、历史和思维的哲学方法。其实就是告诉我们在遇到事情是要以一分为二,对于晶振也不例外,应从内外因不同的角度来分析晶振停振。

下面我们以内外因来分析晶振停振:

1、排除外界元件不良的情况,因为外界零件无非为电阻、电容,让你很容易鉴别是否为不良品。

2、排除晶振为不起振品的可能性,这里你不会只试了1~2个晶振就停止了测试。

3、排除线路错误的可能性,这样先试着用相应型号线路的推荐电路进行比较。

4、可以改变晶体两端的电容,没准晶振就能正常工作了,电容的大小请参考晶振的使用说明,相匹配的电容很重要。

晶振本身的原因,晶片碎裂、阻抗过大、频率不良、晶体牵引力不足过大寄生反应。或在电路上,负载电容或电路设计或加工造成的杂散电容离散度大,晶体两端电压不足,这些也会导致晶振停振!

嵌入式工程师必须知道的八大加密算法

judy的头像

伴随着人工智能、物联网时代的到来,数据应用变得频繁起来,数据安全应该如何保护?软件加密算法都有哪些,这些算法在哪些方面得到了应用?慢慢读下去,你会发现围绕在我们身边的“小密码”。

对称加密算法

对称加密算法是应用较早的加密算法,技术成熟。在对称加密算法中,数据发信方将明文(原始数据)和加密密钥一起经过特殊加密算法处理后,使其变成复杂的加密密文发送出去。在对称加密算法中,使用的密钥只有一个,发收信双方都使用这个密钥对数据进行加密和解密,这就要求解密方事先必须知道加密密钥。对称加密算法的特点是算法公开、计算量小、加密速度快、加密效率高。不足之处是,交易双方都使用同样钥匙,安全性得不到保证。对称加密算法在分布式网络系统上使用较为困难,主要是因为密钥管理困难,使用成本较高。

DES加密算法

单片机小白学步(21) IO口:基本的LED和按键操作

judy的头像

本篇我们先介绍最基础的几个IO口操作。学完本篇,大家要能自己独立完成下面几个实验。

1、点亮LED

2、一个按键控制LED,按下灯亮,释放灯灭

3、两个按键控制一个LED,一个键开灯,一个键关灯

实验一

点亮LED的例子前面入门篇已经讲过了,程序写起来很简单,Keil编写程序并编译生成HEX文件,烧写进单片机的过程,也做了完整详细的介绍。

点亮LED利用了IO口输出操作。简单复习一下,最核心的两句代码是:

sbit LED = P1^0;

LED = 0;

第一句定义LED为sbit型变量,对应了P1.0口的高低电平,具体应该写哪个IO口,和实际电路有关。第二句设置LED对应的P1.0管脚输出低电平,从而点亮LED。

实验二:按键开关

讲第二个实验前,先简单介绍下常用的按键开关。下图就是最常见的按键开关,有四个引脚,图中的1、2连在一起,3、4连接在一起。按下按键时,四个引脚就全部导通了。

嵌入式开源软件的十大弊端

judy的头像

俗话说得好, “得来全不费功夫”,免费当然是个好事情了。既然是免费的,开源的实时操作系统(RTOS)看起来是个不错的选择。但是对于嵌入式设备和物联网设备的开发者来说,有时并不愿轻易涉足, 比如家居自动化和可穿戴设备,医疗仪器和工业控制系统。在决定之前,需要了解使用开放源码的真正成本和弊端。

1.可靠性

如果 RTOS 失败或者行为出人意料,会导致产品的异常。即使一个 RTOS 故障可能不会导致异常或挂掉,也可能会导致顾客不满,销售不佳甚至产品召回。一个安全认证的 RTOS 提供了信心,由于经过彻底的审查,测试和验证,一般能够满足预期。

2.安全性

开放源码软件(OSS)是免费提供的,这意味着任何人都可以设计出破坏它的方法。如果被用于一个成功的商业产品,黑客的动机可能会增强。开放源码软件组件可能包含安全漏洞,这些漏洞可能被别有用心的人加以利用。

3.独立性

STM32中的抢占优先级、响应优先级概念

judy的头像

STM32(Cortex-M3)中有两个优先级的概念——抢占式优先级和响应优先级,有人把响应优先级称作'亚优先级'或'副优先级',每个中断源都需要被指定这两种优先级。

具有高抢占式优先级的中断可以在具有低抢占式优先级的中断处理过程中被响应,即中断嵌套,或者说高抢占式优先级的中断可以嵌套在低抢占式优先级的中断中。

当两个中断源的抢占式优先级相同时,这两个中断将没有嵌套关系,当一个中断到来后,如果正在处理另一个中断,这个后到来的中断就要等到前一个中断处理完之后才能被处理。如果这两个中断同时到达,则中断控制器根据他们的响应优先级高低来决定先处理哪一个;如果他们的抢占式优先级和响应优先级都相等,则根据他们在中断表中的排位顺序决定先处理哪一个。

看了上面的介绍后,相信大家都明白了这里面的关系了,总结下便是:抢占式优先级>响应优先级>中断表中的排位顺序(其中“>”理解为比较的方向)。

正是因为每个中断源都需要被指定这两种优先级,就需要有相应的寄存器位记录每个中断的优先级;在Cortex-M3中定义了8个比特位用于设置中断源的优先级,这8个比特位可以有8种分配方式,如下:

1. 所有8位用于指定响应优先级

2. 最高1位用于指定抢占式优先级,最低7位用于指定响应优先级

几种flash存储芯片的用途和分类

judy的头像

1、IIC EEPROM------容量小,采用的是IIC通信协议;用于在掉电时,存系统配置参数,比如屏幕亮度等。常用芯片型号有 AT24C02、FM24C02、CAT24C02等,其常见的封装多为DIP8,SOP8,TSSOP8等;

2、SPI NorFlash------容量略大,采用的是SPI 通信协议;用于存放程序和数据。程序和数据可存放在同一芯片上,拥有独立的数据总线和地址总线,能快速随机读取,允许系统直接从Flash中读取代码执行;可以单字节或单字编程,但不能单字节擦除,必须以Sector为单位或对整片执行擦除操作。常见到的S25FL128、MX25L1605、W25Q64等型号都是SPI NorFlash。

页面

订阅 RSS - judy的博客