标签:映射 访问 linux FIFO 物理地址 内存 IO 寄存器
先看一个在无操作系统的情况下,用C语言访问片上寄存器的范例,这是访问S3C2440UART1的FIFO控制寄存器的示例,先定义FIFO控制寄存器为UFCON1:
#define UFCON1 (*(volatile unsigned *)Ox50004008) //*UART 1 FIFO控制寄存器
给UFCON1赋值:
UFCON1 = Ox00; //禁止FIFO功能
这个示例的使用条件是禁止CPU的MMU。在禁止MMU的情况下,可以直接访问CPU的物理地址。
Linux内核运行后,开启了MMU,所以不能直接访问CPU的物理地址,也就是说,不能直接使用物理地址访问系统的IO内存。必须将物理地址转换为虚拟地址,内核通过虚拟地址来访问系统的IO内存。
在内核中,物理地址到虚拟地址的转换,可以采用静态IO映射,还可以采用动态IO映射。通常情况下,CPU片上寄存器和内部总线都采用静态IO映射,外部总线扩展IO则通常采用动态IO映射,也可以添加到系统中,采用静态IO映射的方式。
下面分别来看这两种方式的实现和使用方法。
标签:映射,访问,linux,FIFO,物理地址,内存,IO,寄存器 来源: https://www.cnblogs.com/yuanqiangfei/p/15735726.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。