标题 | 阅读 | 评论 | 转发 | 发布日期 | |
---|---|---|---|---|---|
udelay与calibrate_delay | 3343 | 0 | 0 | 2010-03-16 | |
字节对齐算法 | 1366 | 0 | 0 | 2010-02-08 | |
glibc笔记——strlen | 1660 | 0 | 0 | 2010-02-08 | |
vmware下找不到hgfs | 11681 | 0 | 0 | 2010-02-06 | |
在centos5(rhel5)中使用iso光盘和本地文件来进行Yum软件管理(system-conf | 1081 | 0 | 0 | 2010-02-06 | |
Gamma知识 | 1447 | 0 | 0 | 2010-02-02 | |
Linux initial RAM disk (initrd) overview | 1318 | 0 | 0 | 2009-12-10 | |
从codepage,iocharset 到ASCII,Unicode,UTF-8 | 4129 | 0 | 0 | 2009-11-25 | |
linux中ctime,mtime,atime的区别 | 1603 | 0 | 0 | 2009-07-08 |
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