AVR--I/O端口寄存器

Posted mickey-double

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AVR--I/O端口寄存器相关的知识,希望对你有一定的参考价值。

ATmega16的4个8位的端口都有各自对应的3个I/O端口寄存器,它们占用了I/O空间的12个地址

技术图片

下面是PA口寄存器—PORTA、DDRA、PINA各个位的具体定义,以及其是否可以通过指令读写操作和RESET复位后的初始值。其它3个口的寄存器的情况与PA口相同,只是地址不一样。

 技术图片

 技术图片

1) 正确使用AVR的I/O口要注意:先正确设置DDRx方向寄存器,再进行I/O口的读写操作。

2) AVR的I/O口复位后的初始状态全部为输入工作方式,内部上拉电阻无效。所以,外部引脚呈现三态高阻输入状态。

3) 因此,用户程序需要首先对要使用的I/O口进行初始化设置,根据实际需要设定使用I/O口的工作方式(输出还是输入),当设定为输入方式时,还要考虑是否使用内部的上拉电阻。

4) 在硬件电路设计时,如能利用AVR内部I/O口的上拉电阻,可以节省外部的上拉电阻。

以上是关于AVR--I/O端口寄存器的主要内容,如果未能解决你的问题,请参考以下文章

CPU微架构设计分布式多端口(4写2读)寄存器堆设计

linux 系统对IO端口和IO内存的管理

FPGA两种寄存器的使能

IO端口和IO内存的区别及分别使用的函数接口

GPIO寄存器

汇编学习笔记(10)-IO端口与指令