完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
本帖最后由 一只耳朵怪 于 2018-6-5 09:41 编辑
我想配置3359的I2C为从模式。在UBOOT下面,如果用常用的p=0x44e0b000;然后再通过指针*(unsigned int *)p去访问这个寄存器就会产生data abort的异常中断,用readl(p)就可以正常访问寄存器了。在linux下面,我们新建的空白驱动里,如果去读I2C控制器寄存器也会产生异常。 p = ioremap(0x44e0b000,0x200); 之后,显示映射成功,并且和I2C总线驱动的映射是同一个。 可是之后执行 printk("%x",*p); 就内存访问异常了,采用 __raw_read(p); 也会异常访问异常。把地址换成SPI的也是这样,但只要不是L4 PER MEM就没问题,比如GPMC,MDIO都可以的。请问L4的外设寄存器访问是不是有什么特殊规定? 使能时钟?地址映射? |
|
相关推荐
4个回答
|
|
|
|
|
|
在kernel下做的,但是会崩溃。 然后再去UBOOT下测试了一遍,发现要用volatile这个关键词修饰后是能访问的 |
|
|
|
这个可以参考其他驱动的写法 如果我的回答解决了您的问题,请确认答案,谢谢!:) |
|
|
|
问题解决了,在于某些外设是需要设置好电源和时钟的,否则外设寄存器访问会引起异常。 |
|
|
|
只有小组成员才能发言,加入小组>>
350 浏览 1 评论
544 浏览 2 评论
NA555DR VCC最低电压需要在5V供电,为什么用3.3V供电搭了个单稳态触发器也使用正常?
789 浏览 3 评论
MSP430F249TPMR出现高温存储后失效了的情况,怎么解决?
660 浏览 1 评论
对于多级放大电路板,在PCB布局中,电源摆放的位置应该注意什么?
1140 浏览 1 评论
AT32F407在USART2 DMA发送数据时,接包接到了要发送的数据,程序还是处于等待传输完成的标识判断中,为什么?
81浏览 29评论
282浏览 23评论
请问下tpa3220实际测试引脚功能和官方资料不符,哪位大佬可以帮忙解答下
261浏览 20评论
请教下关于TAS5825PEVM评估模块原理图中不太明白的地方,寻求答疑
210浏览 14评论
两个TMP117传感器一个可以正常读取温度值,一个读取的值一直是0,为什么?
68浏览 13评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-27 17:18 , Processed in 0.801069 second(s), Total 53, Slave 47 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号