新手问linux-2.6下对S3C2410的IIC虚拟地址
linux-2.6.14.1中的/include/asm/arch-s3c2410/regs-iic.h中定义了 IIC的寄存器的地址:
#define S3C2410_IICREG(x) (x)
#define S3C2410_IICCON S3C2410_IICREG(0x00)
#define S3C2410_IICSTAT S3C2410_IICREG(0x04)
#define S3C2410_IICADD S3C2410_IICREG(0x0
#define S3C2410_IICDS S3C2410_IICREG(0x0C)
#define S3C2440_IICLC S3C2410_IICREG(0x10)
我将/linux-2.6.14.1/include/asm/arch-s3c2410/map.h文件下的如下:
/* IIC hardware controller */
#define S3C24XX_VA_IIC S3C2410_ADDR(0x00C00000)
#define S3C2400_PA_IIC (0x15400000)
#define S3C2410_PA_IIC (0x54000000)
#define S3C24XX_SZ_IIC SZ_1M
#define VA_IIC_BASE (S3C24XX_VA_IIC)
将 VA_IIC_BASE加入到 #define S3C2410_IICREG(x) (x) 变成 #define S3C2410_IICREG(x) (VA_IIC_BASE+X)
这样在驱动中直接利用readb()和writeb()函数对S3C2410_IICCON ,S3C2410_IICSTAT ,
S3C2410_IICADD , S3C2410_IICDS 直接访问,编译通过后,在板子运行出错。
不知道这么加是不是IIC的寄存器在系统系统里映射地址。
看了别的寄存器的定义好象都行。
盼指点下,谢谢
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
不应该修改,因为你修改之后原来引用这些宏的函数就无法运行了,比如你改了之后driver/i2c/busses/i2c-s3c2410.c中的s3c24xx_i2c_init()函数就无法运行了,系统会出错;