标题 | 阅读 | 评论 | 转发 | 发布日期 | |
---|---|---|---|---|---|
自己写的通用makefile 多文件夹 | 1810 | 0 | 0 | 2009-12-25 | |
Linux initial RAM disk (initrd) overview | 1304 | 0 | 0 | 2009-12-10 | |
从codepage,iocharset 到ASCII,Unicode,UTF-8 | 4084 | 0 | 0 | 2009-11-25 | |
音频设备的3种硬件接口--PCM,IIS和AC97 | 2023 | 1 | 0 | 2009-09-03 | |
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 | |
linux中ctime,mtime,atime的区别 | 1595 | 0 | 0 | 2009-07-08 | |
linux AS4 安装时选择英文,中文显示乱码的问题 | 1764 | 0 | 0 | 2009-06-29 | |
uboot1.1.6之nor SST39VF160 移植 | 2085 | 0 | 0 | 2009-04-09 | |
arm linux内核启动大致流程 | 1995 | 1 | 0 | 2009-04-03 | |
X11 、XFree86 、KDE、GNOME、窗口管理器等相关概念 | 1637 | 0 | 0 | 2009-03-03 | |
S3C2440的时钟设定 | 1440 | 0 | 0 | 2009-02-27 | |
第九章 与硬件通信 | 1891 | 0 | 0 | 2009-01-20 | |
LDS 资料 | 1723 | 0 | 1 | 2009-01-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