<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                ## 17.15.?幾個其他細節 本節涵蓋了幾個其他主題, 對網絡驅動作者感興趣的. 在每種情況, 我們試著簡單指點你正確的方向. 獲取了一個主題的完整描繪可能還需要花費一些時間深入內核源碼. ### 17.15.1.?獨立于媒介的接口支持 媒介獨立接口(或 MII) 是一個 IEEE 802.3 標準, 描述以太網收發器如何與網絡控制器接口; 很多市場上的產品遵守這個接口. 如果你在編寫一個驅動為一個 MII 兼容控制器, 內核輸出了一個通用 MII 支持層, 可能會使你易做一些. 為使用通用 MII 層, 你應當包含 <linux/mii.h>. 你需要填充一個 mii_if_info 結構使用收發器的物理 ID 信息, 如是否全雙工有效. 還要求 mii_if_info 結構的 2 個方法: ~~~ int (*mdio_read) (struct net_device *dev, int phy_id, int location); void (*mdio_write) (struct net_device *dev, int phy_id, int location, int val); ~~~ 如你可能預料的, 這些方法應當實現與你的特殊 MII 接口的通訊. 通用的 MII 代碼提供一套函數, 來查詢和改變收發器的操作模式; 許多設計成與 ethtool 工具一起工作( 下一節描述 ). 在 <linux/mii.h> 和 drivers/net/mii.c 中查看細節. ### 17.15.2.?ethtool 支持 ethtool 是一個實用工具, 設計來給系統管理員以大量的控制網絡接口的操作. 用 ethtool, 可能來控制各種接口參數, 包括速度, 介質類型, 雙工模式, DMA 環設置, 硬件校驗和, LAN 喚醒操作, 等等, 但是只有當 ethtool 被驅動支持. ethtool 可以從 http://sf.net/projects/gkernel/. 下載. 對 ethtool 支持的相關聲明可在 <linux/ethtool.h> 中找到. 它的核心是一個 ethtool_ops 類型的結構, 里面包含一個全部 24 個不同方法來支持 ethtool. 大部分這些方法是相對直接地; 細節看 <linux/ethtool.h>. 如果你的驅動使用 MII 層, 你能使用 mii_ethtool_gset 和 mii_ethtool_sset 來實現 get_settings 和 set_settings 方法, 分別地. 對于和你的設備一起工作的 ethtool, 你必須放置一個指向你的 ethtool_ops 結構的指針在 net_devcie 結構中. 宏定義 SET_ETHTOOL_OPS( 在 <linux/netdevice.h> 中定義)應當用作這個目的. 注意你的 ethtool 方法可能會在接口關閉時被調用. Netpoll ### 17.15.3.?netpoll "netpoll" 是相對遲的增加到網絡協議棧中; 它的目的是使內核能夠發送和接收報文, 在完整的網絡和I/O子系統不可用的情況下. 它用來給如遠程網絡控制臺和遠程內核調試等特色使用的. 無論如何, 你的驅動不必支持 netpoll, 但是它可能使你的驅動在某些情況下更有用. 在大部分情況下支持 netpoll 也相對容易. 實現 netpoll 的驅動應當實現 poll_controller 方法. 它的工作是跟上控制器上可能發生的任何東西, 在缺乏設備中斷時. 幾乎所有的 poll_controller 方法采用下面形式: ~~~ void my_poll_controller(struct net_device *dev) { disable_device_interrupts(dev); call_interrupt_handler(dev->irq, dev, NULL); reenable_device_interrupts(dev); } ~~~ poll_controller 方法, 實際上, 是簡單模擬自給定設備的中斷.
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看