GPIO(General Purse I/O Ports)意思为通用输入/输出端口,通俗地说,就是一些引脚,可以通过它们输出高低电平或者通过它们读入引脚的状态----高电平还是低电平。
S3C2410有117个I/O端口,共分为A- H 共8组:GPA、GPB、...、GPH。S3C2440有130个I/O端口,分为A-J共9组。可以通过设置寄存器来确定某个引脚用于输入、输出还是其他特殊功能。
GPIO的操作是所有硬件操作的基础,由此扩展开来可以了解所有硬件的操作,这是底层开发人员必须掌握的。
1.通过寄存器来操作GPIO引脚
既然一个引脚可以用于输入、输出或其他特殊功能,那么,一定有寄存器用来选择这些功能;对于输入,一定可以通过读取某个寄存器来确定引脚的电平是高还是低;对于输出,一定可以通过写入某个寄存器来让这个引脚输出高电平或低电平;对于其他特殊功能,则又另外的寄存器来控制它。
对于这几组GPIO引脚,它们的寄存器是相似的:GPxCON用于选择引脚功能,GPxDAT用于读/写引脚数据;另外,GPxUP用于确定是否使用内部上拉电阻。
- GPxCON寄存器
从寄存器的名字即可看出,用于配置--选择引脚的功能。
PORT A 与 PORT B - PORT J在功能选择方面有所不同,GPACON中没一位对应一根引脚(共23跟引脚)。当某位被设为0时,相应引脚为输出引脚,此时我们可以在GPADAT中相应位写入0或1让此引脚输出低电平或高电平;当某位被设为1是,相应引脚为抵制线或用于地址控制,此时GPADAT无用。一般而言,GPACON通常被设为全1,以便方位外部存储器件。
PORT B - PORT J 在寄存器操作方面完全相同。 GPxCON中每两位控制一根引脚:00表示输入、01表示输出、10表示特殊功能,11保留不用。 - GPxDAT 寄存器
GPxDAT用于读/写引脚:当引脚被设置为输入是,读此寄存器可知相应引脚的点评状态时高还是低;当引脚被设为输出时,写此寄存器相应位可令此引脚输出高电平或低电平。 - GPxUP 寄存器
GPxUP:某位为1时,相应引脚无内部上拉电阻;当0时,相应引脚使用内部上拉电阻。
上拉电阻、下拉电阻的作用在于,当GPIO引脚处于第三态(既不是输出高电平,也不是输出低电平,而是高阻态,即相当于没接芯片)时,它的电平状态有上拉电阻、下拉电阻确定。
2。通过单个引脚来访问硬件。
3。以总线方式访问硬件。