1. 之前查cpu寄存器是0x01f02c00 + 0x04,里面的的第16位到第18位,
.start = 0x01f02c00 + 0x4,//PL12
.end = 0x01f02c00 + 0x4 + 32,
resPL12 = platform_get_resource(pdev, IORESOURCE_MEM, 0);
pl_cfg0 = ioremap(resPL12->start, resPL12->end - resPL12->start);
pl_cfg0 = ioremap(resPL12->start, resPL12->end - resPL12->start);
printk("pl_cfg0 addr -> 0x%lx\n", pl_cfg0);
printk("pl_cfg0 data -> 0x%lx\n", *pl_cfg0);//这行就会报错
//Unhandled fault: alignment fault (0x96000021) at 0xffffff8002a70c64
后来发现应该是64位是8个字节,指针是static volatile unsigned long *pl_cfg0; 也是8个字节, 指针++都是8个字节的搬移。后来改成如下:
.start = 0x01f02c00 + 0x00,//PL12
.end = 0x01f02c00 + 0x00 + 32,
然后指针用的时候是:
printk(“*pl_cfg0 value -> 0x%lx\n”, *pl_cfg0);
*pl_cfg0 &= ~(7<<(32+4*4)); //clear bit
printk(“*pl_cfg0 value -> 0x%lx\n”, *pl_cfg0);
printk(“clear pl_cfg0 bit 1 end … \n”);
*pl_cfg0 |= (1<<(32+4*4)); //set bit
printk(“*pl_cfg0 value -> 0x%lx\n”, *pl_cfg0);
这样的话就能访问这个地址,同时也不会alighment fault了。