结构综述Figure 3. AVR 结构的方框图
为了获得最高的性能以及并行性, AVR 采用了Harvard 结构,具有独立的数据和程序总线。程序存储器里的指令通过一级流水线运行。CPU 在执行一条指令的同时读取下一条指令( 在本文称为预取)。这个概念实现了指令的单时钟周期运行。程序存储器是可以在线编程的FLASH。
快速访问寄存器文件包括32 个8 位通用工作寄存器,访问时间为一个时钟周期。从而实现了单时钟周期的ALU 操作。在典型的ALU 操作中,两个位于寄存器文件中的操作数同时被访问,然后执行运算,结果再被送回到寄存器文件。整个过程仅需一个时钟周期。
寄存器文件里有6 个寄存器可以用作3 个 16位的间接寻址寄存器指针以寻址数据空间,实现高效的地址运算。其中一个指针还可以作为程序存储器查询表的地址指针。这些附加的功能寄存器即为16 位的X、Y、Z 寄存器。
ALU支持寄存器之间以及寄存器和常数之间的算术和逻辑运算。ALU也可以执行单寄存器操作。运算完成之后状态寄存器的内容得到更新以反映操作结果。
程序流程通过有/ 无条件的跳转指令和调用指令来控制,从而直接寻址整个地址空间。大多数指令长度为16 位,亦即每个程序存储器地址都包含一条16 位或32 位的指令。
程序存储器空间分为两个区:引导程序区(Boot 区) 和应用程序区。这两个区都有专门的锁定位以实现读和读/ 写保护。用于写应用程序区的SPM 指令必须位于引导程序区。
在中断和调用子程序时返回地址的程序计数器(PC) 保存于堆栈之中。堆栈位于通用数据SRAM,因此其深度仅受限于SRAM 的大小。在复位例程里用户首先要初始化堆栈指针SP。这个指针位于I/O 空间,可以进行读写访问。数据SRAM 可以通过5 种不同的寻址模
式进行访问。
AVR 存储器空间为线性的平面结构。
AVR有一个灵活的中断模块。控制寄存器位于I/O空间。状态寄存器里有全局中断使能位。每个中断在中断向量表里都有独立的中断向量。各个中断的优先级与其在中断向量表的位置有关,中断向量地址越低,优先级越高。
I/O I/O 存储器 64 个可以直接寻址的地址,作为 CPU 外设的控制寄存器、SPI,以及其他 I/O 功能。映射到数据 0x20 - 0x5F。此外,ATmega48/88/168还有位于SRAM地址0x60 - 0xFF的扩展I/OST/STS/STD 和 LD/LDS/LDD 指令来访问。
上一篇:ATmega48 ALU
下一篇:ATmega48 引脚功能
设计资源 培训 开发板 精华推荐
- AM3G-0505DZ ±5V 3 瓦 DC 至 DC 转换器的典型应用
- 使用 NXP Semiconductors 的 ISP1161 的参考设计
- LTC2656IFE-L12 八通道、12 位数模转换器的典型应用
- 使用 Diodes Incorporated 的 AP1519 的参考设计
- ADM00317、MCP47X6 PicTail Plus 子板,用于 MCP4726、MCP4716 和 MCP4706 DAC 器件
- 使用 ROHM Semiconductor 的 BD5358 的参考设计
- 全志v3s游戏机 -0603版本
- 555电路的仿真 1810300305
- LM431SB 三端固定稳压器输出控制的典型应用
- 使用 Analog Devices 的 ADR01AKSZ 的参考设计
- 看视频赢京东卡 | 泰享实测之水哥秘籍第三期
- TI 中国大学计划20周年官网“幸运雨”了,你还不来抢?
- 安森美半导体移动、消费及汽车应用图像稳定方案下载有礼!
- 用“芯”做好表|英飞凌智能手表解决方案
- 下载喽:PCIe要了解的10件事和识别协议的BSX系列BERTScope误码率测试仪技术资料
- ST有奖直播 | 75V降压控制器和隔离降压方案
- TI机器人系统学习套件,低成本开启你的电子工程课程实战之旅
- 畅游安富利人工智能云会展,挑战60天打卡学习养成记!冲击华为Mate40 Pro、Apple iPad Air等豪礼啦!
- STM32 Nucleo 板卡智勇大闯关
- 2024安路科技FPGA技术研讨会-广州站 火热报名中