新手问linux-2.6下对S3C2410的IIC虚拟地址

发布于 2022-09-22 11:34:04 字数 1360 浏览 11 评论 0

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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

国粹 2022-09-29 11:34:04

不应该修改,因为你修改之后原来引用这些宏的函数就无法运行了,比如你改了之后driver/i2c/busses/i2c-s3c2410.c中的s3c24xx_i2c_init()函数就无法运行了,系统会出错;

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文