《DM9000网卡驱动分析》.doc

  1. 1、本文档共39页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
DM9000网卡驱动分析 #include linux/module.h #include linux/ioport.h #include linux/netdevice.h #include linux/etherdevice.h #include linux/init.h #include linux/skbuff.h #include linux/spinlock.h #include linux/crc32.h #include linux/mii.h #include linux/ethtool.h #include linux/dm9000.h #include linux/delay.h #include linux/platform_device.h #include linux/irq.h #include asm/delay.h #include asm/irq.h #include asm/io.h #if defined(CONFIG_ARCH_S3C2410) #include mach/regs-mem.h #endif #include dm9000.h /* Board/System/Debug information/definition ---------------- */ //在EEPROM或PHY地址寄存器中要选择内部PHY,那么7-6位强制为01 #define DM9000_PHY??0x40?/* PHY address 0x01 */ #define CARDNAME?dm9000 #define DRV_VERSION?1.31 /* ?* Transmit timeout, default 5 seconds. ?*/ ?//传输超时时间设定,当传输超时时调用函数dm9000_timeout(struct net_device *dev) static int watchdog = 5000; module_param(watchdog, int, 0400);//在驱动程序加载时可以重新设定watchdog MODULE_PARM_DESC(watchdog, transmit timeout in milliseconds); /* DM9000 register address locking. ?* ?* The DM9000 uses an address register to control where data written ?* to the data register goes. This means that the address register ?* must be preserved over interrupts or similar calls. ?* ?* During interrupt and other critical calls, a spinlock is used to ?* protect the system, but the calls themselves save the address ?* in the address register in case they are interrupting another ?* access to the device. ?* ?* For general accesses a lock is provided so that calls which are ?* allowed to sleep are serialised so that the address register does ?* not need to be saved. This lock also serves to serialise access ?* to the EEPROM and PHY access registers which are shared between ?* these two devices. ?*/ /* The driver supports the original DM9000E, and now the two newer ?* devices, DM9000A and DM9000B. ?*/ enum dm9000_type { ?TYPE_DM9000E,?/* original DM9000 */ ?TYPE_DM9000A, ?TYPE_DM9000B }; /* Structure/enum declaration ------------------------------- */ typedef struct board_info { /

文档评论(0)

ghfa + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档