⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 s3c2410 中的网卡cs8900a的驱动程序总结.txt

📁 s3c2410 中的网卡cs8900a的驱动程序总结
💻 TXT
字号:
s3c2410 中的网卡cs8900a的驱动程序总结
zz:
基本步骤(引用):
============ for 2.6.16=================
 (1) #cp cs8900.c  ./drivers/net/arm/
        #cp cs8900.h  ./drivers/net/arm/
    
  并在cs8900_probe()函数中,memset (&priv,0,sizeof (cs8900_t));函数之后添加如下
两条语句:
 __raw_writel(0x2211d110,S3C2410_BWSCON);
 __raw_writel(0x1f7c,S3C2410_BANKCON3);


(2)修改drivers/net/arm/目录下的Kconfig文件,在最后添加如下内容:
Config ARM_CS8900
   tristate "CS8900 support"
   depends on NET_ETHERNET && ARM && ARCH_SMDK2410
 help
   Support for CS8900A chipset based Ethernet cards. If you have a network 
   (Ethernet) card of this type, say Y and read the  Ethernet-HOWTO, available 
   from  as well as .
   To compile this driver as a module, choose M here and read
.  The module will be
   called cs8900.o.
   
注:内核系统配置文件由2.4版本的config.in变成了2.6版本Kconfig文件,在这个文件里
面添加如上内容,则在运行make menuconfig或者make xconfig命令的时候就会出现:
        [ ]   CS8900 support  
这一选项。

(3)修改drivers/net/arm/目录下的Makefile文件,在最后添加如下内容:

      obj-$(CONFIG_ARM_CS8900)    += cs8900.o
      
注:2.6版本内核的Makefile文件也与2.4版本的有所不同。添加以上语句,就会使内核在编
译的时候根据配置将cs8900A的驱动程序以模块或静态的方式编译到内核当中。

(4)在/arch/arm/mach-s3c2410/mach-smdk2410.c文件中,找到smdk2410_iodesc[]结构
数组,添加如下如下内容:

{vSMDK2410_ETH_IO, 0x19000000, SZ_1M, MT_DEVICE}

修改之后变成了:

 static struct map_desc smdk2410_iodesc[] __initdata = {
       /* nothing here yet */
        /* Map the ethernet controller CS8900A */        
        {vSMDK2410_ETH_IO, 0x19000000, SZ_1M, MT_DEVICE}
};

结论:
 
关于linux-2.6.16的头文件就应该改成
 
#ifndef _INCLUDE_SMDK2410_H_
#define _INCLUDE_SMDK2410_H_
#include 
#define pSMDK2410_ETH_IO  __phys_to_pfn(0x19000000)
#define vSMDK2410_ETH_IO  0xE0000000
#define SMDK2410_ETH_IRQ   IRQ_EINT9


=============================for 2.6.11 ==================
#define pSMDK2410_ETH_IO 0x19000000
在S3C2410X中BWSCON是Bus width & wait controlregister(总线宽度及等待控制寄存器),这个寄存器控制着系统地址空间内(包括bank0-bank7)的总线数据宽度以及是否等待。BANKCONn(n=0~7)寄存器是Bank controlregister。这个寄存器控制着处于某个bank区间内的总线的地址setup的时钟周期,片选信号的保持时间,访问周期等。这个两个寄存器中每个位的含义可以参见S3C2410X数据手册的5-13~5-15,在此不加以详叙。
查看了cpu的数据手册、开发板原理图以及2.4的驱动程序之后,发现在2.4的驱动程序中的以下两条语句:
BWSCON = (BWSCON & ~(BWSCON_ST3 | BWSCON_WS3 | BWSCON_DW3)) |  (BWSCON_ST3 | BWSCON_WS3 | WSCON_DW(3, BWSCON_DW_16));
BANKCON3= BANKCON_Tacs0 | BANKCON_Tcos4 | BANKCON_Tacc14 | BANKCON_Toch1 | BANKCON_Tcah4 | BANKCON_Tacp6 | BANKCON_PMC1;
实际上是对地址区间BANK3(因为开发板用的的是nGCS3,处于BANKCON3区间内)进行了设置。
先看对BWSCON的设置,这条语句实际上是要使BWSCON中除了ST3、WS3和DW3这四个位的其它各位得到保护,使ST3、WS3和DW3这四个位清零,然后再对ST3、WS3和DW3这四个位进行设置,经过这条语句之后,ST3、WS3和DW3这四个位被设置成了1101(二进制),意思就是对BANK3采用cpu引脚(A17、B16、C15、A16,这几个引脚都分别有三种信号表示意义)的nBE信号(具体什么意思,本人也不知道),对BANK3使用WAIT enable,使用16位的数据总线宽度。
其次就是对BANKCON3寄存器的设置。这条语句将BANKCON3设置成了0001 1111 0111 1100。(各个位的意思,我也没弄明白什么意思,估计就是设置各种操作的时钟周期数目。)
清楚了驱动程序对寄存器的设置之后,就想到应该在vivi里面对cpu的这几个内存控制寄存器进行设置,于是找到vivi源代码中include/platform/目录下的smdk.h文件中对寄存器的初始化值的设置,修改之后如下:
/*#define vBWSCON               0x22111120*/
#define vBWSCON                 0x2211d110
#define vBANKCON0               0x00000700
#define vBANKCON1               0x00000700
#define vBANKCON2             0x00000700
#define vBANKCON3               0x00001f7c
#define vBANKCON4             0x00000700
#define vBANKCON5               0x00001f7c
#define vBANKCON6               0x00018005
#define vBANKCON7               0x00018005
#define vREFRESH                0x008e0459
#define vBANKSIZE               0xb2
#define vMRSRB6                 0x30
#define vMRSRB7                 0x30
重新通过JTAG口下载vivi,重新启动内核后,发现问题依然存在,于是就想到在驱动程序里面添加对内存控制器的设置。最开始是想模仿2.4的驱动程序那样,找到各个相应的宏去代替2.4驱动程序里的宏,在memset()函数之前添加,但是编译的时候出错,出错信息是:
LValue incorrect in assignment
跟踪内核的代码发现对S3C2410_BWSCON、S3C2410_BANKCON3宏的定义分别返回的其实是一个常量,分别是0xf0100000和0xf0100010,这个常量是右值,不能当左值。因此就想到采用如下直接对地址进行赋值的方式对寄存器进行设置:
*(volatile unsigned short __force *)(0xf0100000)=(0x2211d110);
*(volatile unsigned short __force  *)(0xf0100010)=(0x00001f7c);
后来运行内核时发现,驱动程序初始化到了memset()函数之后,上述两条语句之前就停止不动了(疑问:不知道这是什么原因)。最后查找linux内核代码找到了__raw_writell(v,a)这样一个函数,于是就将上述两条语句替换成:
__raw_writel(0x2211d110,S3C2410_BWSCON);
__raw_writel(0x1f7c,S3C2410_BANKCON3);

=================note:=======================
在smtd2410中发现网卡用的是cpu的nGCS3片选信号,该片选信号对应的地址空间起始地址是0x18000000,而在驱动中对用的是0x19000000,


链结:
http://bibu.blogchina.com/4914641.html
http://xw009.cnblogs.com/archive/2005/08/04/207687.html
http://www.linuxforum.net/forum/showflat.php?Cat=&Board=embedded&Number=546995&page=0&view=collapsed&sb=5&o=all&fpar



Trackback: http://tb.donews.net/TrackBack.aspx?PostId=888614

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -