免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2940 | 回复: 8
打印 上一主题 下一主题

大家帮忙分析下下面问题原因 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-23 13:45 |只看该作者 |倒序浏览
在S3C2410的开发平台上经过下面的测试:
1、
volatile unsigned long *p_iiccon;
unsigned long temp = 0;
p_iiccon = (unsigned long *)ioremap(0x56000000, 4);

temp =(unsigned long) ioread32 (p_iiccon);
mb();
printk("0x%x\n", temp);  //结果是0x7fffff
iowrite32(0x3fffff, p_iiccon);
mb();
temp =(unsigned long) ioread32 (p_iiccon);
mb();
printk("0x%x\n", temp);  //结果是0x3fffff
从结果可以看出来操作是成功的
2、
volatile unsigned long *p_iiccon;
unsigned long temp = 0;
p_iiccon = (unsigned long *)ioremap(0x56000000, 4);

temp = *p_iiccon;
mb();
printk("0x%x\n", temp);  //结果是0x7fffff
*p_iiccon = 0x3fffff;
mb();
temp = *p_iiccon
mb();
printk("0x%x\n", temp);  //结果是0x3fffff
从结果可以看出来操作是成功的
3、
volatile unsigned long *p_iiccon;
unsigned long temp = 0;
p_iiccon = (unsigned long *)ioremap(0x54000000, 4);

temp =(unsigned long) ioread32 (p_iiccon);
mb();
printk("0x%x\n", temp);  //结果是0x0
iowrite32(0x3f, p_iiccon);
mb();
temp =(unsigned long) ioread32 (p_iiccon);
mb();
printk("0x%x\n", temp);  //结果是0x0
从结果可以看出来操作是不成功的

4、
volatile unsigned long *p_iiccon;
unsigned long temp = 0;
p_iiccon = (unsigned long *)ioremap(0x54000000, 4);
temp =(unsigned long) ioread8 (p_iiccon);
mb();
printk("0x%x\n", temp);
iowrite8(0x3f, p_iiccon); //结果是0x0
mb();
temp =(unsigned long) ioread8 (p_iiccon);
mb();
printk("0x%x\n", temp); //结果是0x0
从结果可以看出来操作还是不成功的
5、
temp = *p_iiccon;
mb();
printk("0x%x\n", temp); //结果是0x0
*p_iiccon = 0x3f;
mb();
temp = *p_iiccon;
mb();
printk("0x%x\n", temp); //结果是0x0
从结果可以看出来操作还是不成功的

从上述5种情况对比,发现唯一的区别就是映射的物理地址不同,映射GPIO的地址后操作可以成功,但是映射IIC寄存器的地址操作是失败的,这是为什么呢?
(注:使用的内核是2.6.14.1, 内核配置未选择IIC支持)

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
2 [报告]
发表于 2008-07-23 13:50 |只看该作者

回复 #1 xzsxiao213 的帖子

2、
volatile unsigned long *p_iiccon;
unsigned long temp = 0;
p_iiccon = (unsigned long *)ioremap(0x56000000, 4);

temp = *p_iiccon;
mb();
printk("0x%x\n", temp);  //结果是0x7fffff
*p_iiccon = 0x3fffff;
mb();
temp = *p_iiccon
mb();
printk("0x%x\n", temp);  //结果是0x3fffff
从结果可以看出来操作是成功的

这个似乎不能确定是对的吧?

论坛徽章:
0
3 [报告]
发表于 2008-07-23 14:08 |只看该作者

回复 #2 dreamice 的帖子

哦,这个地方是有些不确定,先排除这个测试,看其它的

[ 本帖最后由 xzsxiao213 于 2008-7-23 14:11 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2008-07-23 14:09 |只看该作者
还有,就是网上搜到一些相同的问题,发现一个规律,说是这样操作8位的寄存器都不行,而IIC和SPI都是8位的寄存器

论坛徽章:
0
5 [报告]
发表于 2008-07-23 16:39 |只看该作者
找到问题的原因了,给大家共享下,原因就是 CLKCON寄存器的IIC bit位为0导致无法操作IIC寄存器

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
6 [报告]
发表于 2008-07-23 16:46 |只看该作者
原帖由 xzsxiao213 于 2008-7-23 16:39 发表
找到问题的原因了,给大家共享下,原因就是 CLKCON寄存器的IIC bit位为0导致无法操作IIC寄存器


谢谢分享,这个应该是你的硬件寄存器设置的问题吧

论坛徽章:
0
7 [报告]
发表于 2008-07-24 09:01 |只看该作者
2.6内核,把它置0了

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
8 [报告]
发表于 2008-07-24 09:11 |只看该作者
原帖由 xzsxiao213 于 2008-7-24 09:01 发表
2.6内核,把它置0了


置0是不是没有使能CLK?

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
9 [报告]
发表于 2008-07-24 09:13 |只看该作者
这个问题要是有人来整理一下,保存就好了,呵呵,很有指导意义。LZ可以把CLKCON寄存器各位的功能描述一下。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP