网卡设备驱动研讨.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
网卡设备驱动 8139too网卡设备简介一个PCI设备,总共有三个地址空间:内存,端口和配置。内存和端口其实是同一个内容的不同访问路径而已。PCI设备的配置空间是标准化的,每个PCI设备的配置空间的前64个字节的含义都是一样的。但各个设备的内存和端口空间是完全不一样的。在硬件概念上,设备的I/O内存和I/O端口空间没有区别,其实都是设备拥用的一些读写寄存器。 ??? 8139too网卡拥有256字节的读写寄存器空间。它的整个布局如下: ??????? /* Symbolic offsets to registers. */ ??????? enum RTL8139_registers { ??????????? MAC0 = 0,?????? /* Ethernet hardware address. */ ??????????? MAR0 = 8,?????? /* Multicast filter. */ ??????????? TxStatus0 = 0x10,?? /* Transmit status (Four 32bit registers). */ ??????????? TxAddr0 = 0x20,???? /* Tx descriptors (also four 32bit). */ ??????????? RxBuf = 0x30, ??????????? ChipCmd = 0x37, ??????????? RxBufPtr = 0x38, ??????????? RxBufAddr = 0x3A, ??????????? IntrMask = 0x3C, ??????????? IntrStatus = 0x3E, ??????????? TxConfig = 0x40, ??????????? RxConfig = 0x44, ??????????? Timer = 0x48,?????? /* A general-purpose counter. */ ??????????? RxMissed = 0x4C,??? /* 24 bits valid, write clears. */ ??????????? Cfg9346 = 0x50, ??????????? Config0 = 0x51, ??????????? Config1 = 0x52, ??????????? FlashReg = 0x54, ??????????? MediaStatus = 0x58, ??????????? Config3 = 0x59, ??????????? Config4 = 0x5A,???? /* absent on RTL-8139A */ ??????????? HltClk = 0x5B, ??????????? MultiIntr = 0x5C, ??? ??? ??? TxSummary = 0x60, ??????????? BasicModeCtrl = 0x62, ??????????? BasicModeStatus = 0x64, ??????????? NWayAdvert = 0x66, ??????????? NWayLPAR = 0x68, ??????????? NWayExpansion = 0x6A, ??????????? /* Undocumented registers, but required for proper operation. */ ??????????? FIFOTMS = 0x70,???? /* FIFO Control and test. */ ??????????? CSCR = 0x74,??????? /* Chip Status and Configuration Register. */ ??????????? PARA78 = 0x78, ??????????? PARA7c = 0x7c,????? /* Magic transceiver parameter register. */ ??????????? Config5 = 0xD8,???? /* absent on RTL-8139A */ ??????? }; ??? 每个寄存器都有它特殊的含义和用途。举个例子(我们假设使用I/O内存的方式,ioaddr为设备内存映射在CPU内存地址空间的起始地址,下述代码能读取板卡的版本号): ??????? #define HW_REVID(b30, b29, b28, b27, b26, b23, b22) \ ??????????? (b3030 | b2929 | b2828 | b2727 | b2626 | b2323

文档评论(0)

***** + 关注
实名认证
文档贡献者

我是自由职业者,从事文档的创作工作。

1亿VIP精品文档

相关文档