历史上的今天
返回首页

历史上的今天

今天是:2024年11月03日(星期日)

2021年11月03日 | ATmega128 内核介绍

2021-11-03 来源:eefocus

本节从总体上讨论AVR 内核的结构。CPU 的主要任务是保证程序的正确执行。因此它必 须能够访问存储器,执行运算,控制外设以及处理中断。

ATmega128 结构方框图

为了得到最大程度的性能以及并行性, AVR 采用了Harvard 结构,具有独立的数据和程 序总线。程序存储器的指令通过一级流水线运行。CPU 在执行一条指令的同时读取下一 条指令( 在本文称为预取)。这个概念实现了指令的单时钟周期运行。程序存储器为可以 在线编程的FLASH。


快速访问寄存器文件包括32个8位通用工作寄存器,而且都可以在一个时钟周期内访问。 从而实现单时钟周期的ALU 操作。在典型的ALU 操作过程中,两个位于寄存器文件中的 操作数同时被访问,然后执行相应的运算,结果再被送回寄存器文件。整个过程仅需要一 个时钟周期。


寄存器文件里有6 个寄存器可以用作3 个16 位的间接地址寄存器指针以寻址数据空间, 实现高效的地址运算。其中一个指针还可以作为程序存储器查询表的地址指针。这些附加 的功能寄存器即为16 位的X、Y、Z 寄存器。


ALU支持寄存器之间以及寄存器和常数之间的算术和逻辑运算。ALU也可以执行单寄存器 操作。运算完成之后状态寄存器的内容将更新以反映操作结果。


程序流程通过有/ 无条件的跳转指令和调用指令来控制,从而直接寻址整个地址空间。大 多数指令长度为16 位,亦即每个程序存储器地址都包含一条16 位或32 位的指令。


程序存储器空间分为两个区:引导程序区和应用程序区。这两个区都有专门的锁定位以实 现读和读/ 写保护。用于写应用程序区的SPM 指令必须位于引导程序区。


在中断和调用子程序时返回地址程序计数器(PC) 保存于堆栈之中。堆栈位于通用数据 SRAM,故此其深度仅受限于SRAM 的大小。在复位例程里用户首先要初始化堆栈指针 SP。这个指针位于I/O 空间,可以进行读写访问。数据SRAM 可以通过5 种不同的寻址模 式进行访问。


AVR 存储器空间为线性的平面结构。

AVR 具有一个灵活的中断模块。控制寄存器位于I/O 空间。状态寄存器里有全局中断使能 位。在程序存储器起始处有一个中断向量表,每一个中断在此都有独立的中断向量。各个 中断的优先级与其在中断向量表的位置有关,中断向量地址越低,优先级越高。


I/O存储器空间包含64 个可以直接寻址的地址。映射到数据空间即为寄存器文件之后的地 址$20 - $5F。此外,ATmega128 在SRAM 里还有扩展的I/O 空间,位于地址$60 - $FF。 但是只能使用ST/STS/STD 和LD/LDS/LDD 指令。


推荐阅读

史海拾趣

ETRI公司的发展小趣事

自1976年成立以来,ETRI一直致力于打造高效便捷的智慧产业生态圈。在汽车制造、轨道交通等行业中,电气和机械设备是必不可少的。ETRI凭借其卓越的技术实力,为这些行业提供了在各种恶劣环境下都能保持稳定性的产品。无论是在电机马达、编码器、传感器,还是在泵、阀、流量计以及温度计压力表等广泛使用的设备中,ETRI都展现了其行业领先的解决方案。

Ark-Les Connectors公司的发展小趣事

在电子行业中,成本控制是企业竞争力的重要体现。Ark-Les Connectors公司深知优化供应链管理对于降低成本、提高盈利能力的重要性。因此,公司投入大量资源建设高效的供应链体系,与优质供应商建立长期合作关系,确保原材料的稳定供应和成本优化。同时,公司还通过引入先进的生产设备和工艺,提高生产效率,降低生产成本。这些措施使得Ark-Les能够在激烈的市场竞争中保持价格优势,进一步巩固市场地位。

磁联达(CND-tek)公司的发展小趣事

为了提高产品质量和客户满意度,磁联达(CND-tek)公司引入了一套严格的质量管理体系。公司从原材料采购、生产过程到成品检验等各个环节都进行了严格把关,确保每一件产品都符合高标准的质量要求。此外,公司还建立了完善的售后服务体系,为客户提供及时、专业的技术支持和解决方案。这些举措使得磁联达(CND-tek)的产品质量得到了客户的高度认可。

BSI公司的发展小趣事

在全球化的背景下,电子行业的国际合作日益加强。BSI作为国际标准化组织的重要成员,积极推动了电子行业的国际合作和交流。通过组织国际会议、研讨会等活动,BSI为各国政府、行业协会和企业提供了一个交流和合作的平台。这些活动不仅促进了电子行业的国际合作和交流,还推动了电子行业的全球化发展。

虽然以上并非具体的发展故事,但通过这些描述,可以看出BSI在电子行业发展中扮演了重要角色,通过标准制定、产品测试与认证、推动绿色发展、支持技术创新以及促进国际合作等方式,为电子行业的健康发展做出了积极贡献。如需更多关于BSI公司具体发展故事的信息,建议查阅公司官方发布的资料或相关新闻报道。

FTDI [Future Technology Devices International Ltd.]公司的发展小趣事

近年来,FTDI通过并购等方式不断拓展其业务范围。例如,电连技术通过发行股份及支付现金的方式收购了FTDI的部分股权,使FTDI成为其控股子公司。这一并购不仅为电连技术带来了FTDI在USB桥接芯片领域的领先技术,还促进了双方在产品、客户和销售渠道等方面的协同效应。同时,FTDI也借此机会进一步提升了其在新兴市场如汽车电子、物联网等领域的竞争力。

Global Navigation Systems公司的发展小趣事
安装远程无线防盗报警系统时,首先需要将入侵探测器安装在需要防范的门窗等位置,并确保其能够准确检测到异常情况。然后,将微型无线报警发射机安装在探测器附近,并确保其能够接收到探测器的信号并发射出去。最后,将无线报警接收控制器安装在便于监控和接收报警信息的位置,并进行相应的调试和设置。在安装过程中,需要注意避免电磁干扰和信号衰减等问题,确保系统的稳定性和可靠性。

问答坊 | AI 解惑

基于单片机的酒瓶自动计数系统的设计

大家好啊,在这转悠了好几天,发现大家都是高手!我是一名专升本的学生,专科没有学过单片机本科学校因为大部分人都学过所以也就没开这门课,现在要做有关单片机的毕业设计,想请大家帮帮忙,谢谢了!     昨天问了一下老师那个设计一共 ...…

查看全部问答>

Altera的用IP核设计的信号发生程序

本帖最后由 paulhyde 于 2014-9-15 09:24 编辑 Altera的用IP核设计的信号发生程序  …

查看全部问答>

如何将SMDK2440变成多个版本?例如我的产品210,对应的BSP是smdk2440210,产品220对应的是smdk2440220

本人菜鸟,现在碰到一个问题,希望向大家求助一下. 现在我的wince目录中的PLATFORM只有smdk2440一个bsp,这样产生了很多不方便的地方. 第一,目前有3个系列的产品,虽然都是基于2440的,但是在BSP上,还是有些地方是不同的,要维护这三个系列的产品.虽然 ...…

查看全部问答>

如何将ucfs文件系统植入nios ii工程中?

各位大侠:    ucfs导入nios ii工程后,编译时文件一直出错。求移植的具体步骤。不胜感激!…

查看全部问答>

VC6++封装成exe文件的问题

一直用VC++6做编译器,虽然有人让我换了,我嫌麻烦一直没换。用它写程序调试程序一切都很正常,唯独有个问题。把写好的程序封装成exe文件。具体的操作其实挺简单(当然没有命令行下简单)首先写代码,编译看有没有错误,没错误以后封装。封装方法是 ...…

查看全部问答>

小光棍节的礼物!让QVGA屏普及吧!2.4寸 QVGA TFT屏带触摸屏15元一个!

让QVGA屏普及吧!2.4寸 QVGA TFT屏带触摸屏15元一个(5个起),全新37脚ILI9320驱动,提供程序! 单个20元一个,数量不多欢迎抢购!     [ 本帖最后由 shanyan 于 2011-11-1 23:04 编辑 ]…

查看全部问答>

msp430g2553如何使外接的ch451控制8位数码管显示?

其实就是要AD采集的电压数据显示在数码管上,可这个数码管是通过CH451外接的,该怎么编程呢? …

查看全部问答>

我自己构建了CCSV5的工程,编译后总是提示如下错误

我自己构建了CCSV5的工程,编译后总是提示如下错误,我查了很多资料,都没有解决,能给我解决和解释一下吗,谢谢 …

查看全部问答>