标题 | 阅读 | 评论 | 转发 | 发布日期 | |
---|---|---|---|---|---|
S3C2440的中断控制器 | 1540 | 0 | 0 | 2009-08-21 | |
S3C2440的uart 设置 | 1253 | 0 | 0 | 2009-08-19 | |
从PC总线到ARM的内部总线 | 1173 | 0 | 0 | 2009-08-16 | |
AMBA、AHB、APB总线简介 | 2790 | 0 | 0 | 2009-08-16 |
config20102010-01-06 21:06
关于中断的问题,请教! 一个线程会执行一段code,发生中断也会执行这段code,而且线程执行的过程中不能被中断打断,线程执行完毕,再响应中断去执行这段代码。 调查了用spinlock_t,但是它可以被中断打断。用local_irq_disable/enable,中断被屏蔽,(执行code时)中断产生的数据会丢失。spin_lock_irqsave/irqrestore,好像也不能。 求助!能否有可行的方法。
config20102009-12-28 15:18
又有问题要请教了,照着开发板做了DM9000电路(开发板软件硬件都没问题)。现在我的板子ping的时候,时不是的会丢些包,如1114 packets transmitted, 1111 received,而且延时与开板相比,变化较大。请问问题出在哪?软件上开发板是一样的。
config20102009-12-10 07:57
谢谢LxDr兄的回复: 2.value2 = readw(fpga_base_addr+0x191c); fpga_base_addr是一个void *指针,加上0x191c后, 地址超过0x1ffc了 这里0x191c<0x1ffc,0x1ffc是地址偏移,怎么会超过了?
config20102009-12-08 20:01
又来想博主求助了,外设fpga做memory(地址为nGCS3起始),用arm9去读写它,在linux2.6系统下; 地址总线:a0-a12 数据总线:d0-d15 #define FPGA_BASE_ADDR (0x18000000)//片选为nGCS3 #define BWSCON (0x48000000) #define BANKCON3 (0x48000010) #define IP_SIZE (0x1FFF)//13根地址线8K的物理空间 static void *bwscon,*bankcon3,*fpga_base_addr; bwscon = ioremap_nocache(BWSCON,0x0000004); bankcon3 = ioremap_nocache(BANKCON3,0x0000004); fpga_base_addr = ioremap_nocache(FPGA_BASE_ADDR,IP_SIZE); writel(readl(bwscon)|0xD000,bwscon);//总线宽度 writel(0x7FFC,bankcon3);//bank控制 读写memory writew(0xF0,fpga_base_addr); ndelay(300); value1 = readw(fpga_base_addr); ndelay(300); 读寄存器地址为191c(有初始值) value2 = readw(fpga_base_addr+0x191c); 上面为与读写相关的设置。 1,在电路上试验了,读写memory的数据不一致。 2,读寄存器中的值90%情况下是个定值,和初始值不同,少数情况是0. 谢谢。
config20102009-11-19 19:22
外设fpga做的8k的memory,用arm9去读写它,在linux2.6系统下;这样做对吗?
实际地址映射到虚拟内存中,用得到的虚拟地址去读写。
地址总线:a1-a14 数据总线:d0-d16
#define FPGA_BASE_ADDR (0x18000000)//片选为nGCS3
#define BWSCON (0x48000000)
#define BANKCON3 (0x48000010)
#define IP_SIZE (0x1FFF)//13根地址线8K的物理空间
static void *bwscon,*bankcon3,*fpga_base_addr;
bwscon = ioremap_nocache(BWSCON,0x0000004);
bankcon3 = ioremap_nocache(BANKCON3,0x0000004);
fpga_base_addr = ioremap_nocache(FPGA_BASE_ADDR,IP_SIZE);
writel(readl(bwscon)|0xD000,bwscon);
writel(0x7FFC,bankcon3);
for(i=0;i