DM9000裸機驅動程式設計

来源:http://www.cnblogs.com/chd-zhangbo/archive/2016/01/27/5164581.html
-Advertisement-
Play Games

對於任何一個硬體模塊的設計,首先第一步都是要先瞭解硬體本身後,再開始程式的軟體設計。而由於DM9000的晶元文檔內容很多,要驅動好網卡,需要很長時間,特別對於新手比較困難,所以可以參考linux內核代碼中的網卡驅動程式,將其移植到裸機程式當中。下麵將就ok6410,介紹DM9000裸機程式驅動的詳細


對於任何一個硬體模塊的設計,首先第一步都是要先瞭解硬體本身後,再開始程式的軟體設計。而由於DM9000的晶元文檔內容很多,要驅動好網卡,需要很長時間,特別對於新手比較困難,所以可以參考linux內核代碼中的網卡驅動程式,將其移植到裸機程式當中。下麵將就ok6410,介紹DM9000裸機程式驅動的詳細過程,並且完成arp協議的程式設計。

1.       DM9000硬體介面

  打開ok6410的底板原理圖可以看到DM9000和ok6410的硬體介面,通過DM9000的文檔大概瀏覽可知一些比較重要的引腳介面,如圖:

再參考ok6410的核心板原理圖可以很清楚的知道硬體介面對應的管腳:

SD0~SD15:DATA0~DATA15:XM0DATA0~XM0DATA15

CMD:ADDR2:XM0ADDR2

INT:IRQ_LAN:GPN7

IOR:OEN:XM0OEN

IOW:WEN:XM0WEN

CS:CSN1:XM0CSN1

 

  從上面一些管腳的對應關係,可能很難理解控制的方式,這和GPIO等一些模塊的裸機程式時有很大的不同。在6410晶元手冊中搜索關鍵字,對於初學者,也很難瞭解到各個引腳的關係。但是通過網上的資料還是可以知道DM9000介面,接在了ROM1的控制模塊中,ok6410並沒有接ROM。這樣就可以很清楚的知道以下的關係

DATA0~DATA15:ROM1的數據匯流排

ADDR2:ROM1的地址匯流排的第二位

IRQ_LAN:中斷介面

OEN:nOE

WEN:nWE

CSN1:XM0CSn

這樣對DM9000模塊的讀寫相當於對ROM的讀寫了,關鍵的是CMD的引腳即ADDR2。

當CMD為1時DATA0~DATA15為數據匯流排

當CMD為0時DATA0~DATA15為地址匯流排。

通過ok6410手冊可以得出ROM1的起始地址為:0x18000000

 

 

2.       DM9000程式設計

2.1    初始化讀寫時序

Ok6410的DM9000裸機程式驅動設計

通過時序圖配置以下寄存器

void cs_init()

   SROM_BW &= (~(0xf<<4));

   SROM_BW |=  (0x1<<4);

   SROM_BC1 =(0<<0)|(0x2<<4)|(0x2<<8)|(0x2<<12)|(0x2<<16)|(0x2<<24)|(0x2<<28);

}

2.2    讀寫操作函數

#define DM_ADD (*((volatile unsigned short *)0x18000000))

#define DM_DAT (*((volatile unsigned short *)0x18000004))

void dm9000_reg_write(u16 reg,u16 data)

{

    DM_ADD = reg;        

    DM_DAT = data;      

}

u8 dm9000_reg_read(u16 reg)

{

    DM_ADD = reg;

    return DM_DAT;       

}

由硬體介面分析可知CMD即ROM1的地址匯流排的第二位,為1時為數據匯流排,為0是為地址匯流排,從而可以按上巨集定義進行讀寫。

2.3    DM9000初始化

參考linux內核的DM9000驅動程式,可以清楚瞭解初始化的具體步驟

void dm9000_reset()

{

    dm9000_reg_write(DM9000_GPCR, GPCR_GPIO0_OUT);

    dm9000_reg_write(DM9000_GPR, 0);    

    dm9000_reg_write(DM9000_NCR, (NCR_LBK_INT_MAC | NCR_RST));

    dm9000_reg_write(DM9000_NCR, 0);

    dm9000_reg_write(DM9000_NCR, (NCR_LBK_INT_MAC | NCR_RST));

    dm9000_reg_write(DM9000_NCR, 0);

}

void dm9000_probe(void)

{

     u32 id_val;

            id_val  = dm9000_reg_read(DM9000_VIDL);

            id_val |= dm9000_reg_read(DM9000_VIDH) << 8;

            id_val |= dm9000_reg_read(DM9000_PIDL) << 16;

            id_val |= dm9000_reg_read(DM9000_PIDH) << 24;

            if (id_val == DM9000_ID)

     {

        printf("dm9000 is found !\n");

        return ;

     }

     else

    {

               printf("dm9000 is not found !\n");

               return ;

  }

}

void dm9000_init()

{

       u32 i;

    //設置片選

       cs_init();

    //複位設備

        dm9000_reset();

    //捕獲dm9000

        dm9000_probe();

    //MAC初始化

    //Program operating register, only internal phy supported

        dm9000_reg_write(DM9000_NCR, 0x0);

            //TX Polling clear

  dm9000_reg_write(DM9000_TCR, 0);

            //Less 3Kb, 200us

  dm9000_reg_write(DM9000_BPTR, BPTR_BPHW(3) | BPTR_JPT_600US);

            // Flow Control : High/Low Water

  dm9000_reg_write(DM9000_FCTR, FCTR_HWOT(3) | FCTR_LWOT(8));

    //SH FIXME: This looks strange! Flow Control

  dm9000_reg_write(DM9000_FCR, 0x0);

                     //Special Mode

  dm9000_reg_write(DM9000_SMCR, 0);

                     //clear TX status

  dm9000_reg_write(DM9000_NSR, NSR_WAKEST | NSR_TX2END | NSR_TX1END);

    // Clear interrupt status

  dm9000_reg_write(DM9000_ISR, ISR_ROOS | ISR_ROS | ISR_PTS | ISR_PRS);

   //填充MAC地址

    for (i = 0; i < 6; i++)

    dm9000_reg_write(DM9000_PAR+i, macc_addr[i]);

          //激活DM9000

    dm9000_reg_write(DM9000_RCR, RCR_DIS_LONG | RCR_DIS_CRC | RCR_RXEN);

             //Enable TX/RX interrupt mask

  dm9000_reg_write(DM9000_IMR, IMR_PAR);

}

2.4    DM9000發送函數

void dm9000_tx(u8 *data,u32 length)

{

    u32 i;

    //禁止中斷

    dm9000_reg_write(DM9000_IMR,0x80);

    //寫入發送數據的長度

    dm9000_reg_write(DM9000_TXPLL, length & 0xff);

    dm9000_reg_write(DM9000_TXPLH, (length >> 8) & 0xff);

    //寫入待發送的數據

    DM_ADD = DM9000_MWCMD;

    for(i=0;i

    {

    DM_DAT = data[i] | (data[i+1]<<8);

    }

    //啟動發送

    dm9000_reg_write(DM9000_TCR, TCR_TXREQ);

    //等待發送結束

    while(1)

    {

       u8 status;

       status = dm9000_reg_read(DM9000_TCR);

       if((status&0x01)==0x00)

           break;

    }

    //清除發送狀態

    dm9000_reg_write(DM9000_NSR,0x2c);

    //恢復中斷使能

    dm9000_reg_write(DM9000_IMR,0x81);

}

2.5    DM9000接收函數

 

   #define PTK_MAX_LEN 1522

u32 dm9000_rx(u8 *data)

{

    u8 status,len;

    u16 tmp;

    u32 i;

    //判斷是否產生中斷,且清除

    if(dm9000_reg_read(DM9000_ISR) & 0x01)

        dm9000_reg_write(DM9000_ISR,0x01);

    else

        return 0;   

    //空讀

    dm9000_reg_read(DM9000_MRCMDX);

    //讀取狀態

    status = dm9000_reg_read(DM9000_MRCMD);

    //讀取包長度

    len = DM_DAT;

    //讀取包數據

    if(len

    {

       for(i=0;i

       {

           tmp = DM_DAT;

           data[i] = tmp & 0x0ff;

           data[i+1] = (tmp>>8)&0x0ff;

       }

    }

}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 想瞭解一下DM9000的移植修改原理,所以分析了一下時序圖和引腳連接 首先看一下DM9000的引腳和MINI2440的引腳連接 DM9000 MINI2440 功能描述 SD0 DATA0 數據信號 | | SD15 DATA15 數據信號 CMD ADDR2 識別為地址還是數據 INT EINT7
  • 出現這種情況的原因是因為解壓命令沒有加—C參數,使用的命令為:tat -xvzf VMware Tools; 正確的解壓命令應該是: tar -xvzf VMware Tools -C /opt,加上-C參數,指明解壓的路徑,就是解壓到哪裡!
  • 這篇文章不是介紹 nand flash的物理結構和關於nand flash的一些基本知識的。你需要至少瞭解 你手上的 nand flash的物理結構和一些諸如讀寫命令 操作的大概印象,你至少也需要看過 s3c2440中關於nand flash控制寄存器的說明。 由於本人也沒有專門學過這方面的知識,下
  • 前言 這個事JSPath集成到客戶端的第二篇,第一篇鏈接:http://www.cnblogs.com/hxwj/p/5163158.html 安全部署鏈接:http://blog.cnbang.net/tech/2879/ 我這裡就是將原文的方案三RSA效驗實現了 首先我們要得到公鑰私鑰,可以看我
  • 用 Windows 來刷 ESP8266 固件有很多中文教程,來試試直接用 BBB 刷吧。目標是 NodeMCU,ESP-01 可用,就是我買的那個。 接線方式在上一篇。當 echo ‘BB-UART2’ > /sys/devices/bone ….. 之後,ttyO2 可用,測試能連接後可以動手(...
  • 網上很多方法都有人說試過了,不可以。其實不是不可以,他們都沒有說完整 今天自己弄了下,弄出來了,廢話不多說先上圖 1、獲得desktop.ini文件:文件存在於文件夾中,這是文件夾配置文件,預設是沒有這個文件的 產生方法1:需要先對文件夾屬性(比如文件夾圖標)進行改變操作,這樣才能產生文件夾下產生d
  • 本系統是10月5日最新完整版本的Windows10 安裝版鏡像,win10正式版,更新了重要補丁,提升應用載入速度,微軟和百度今天宣佈達成合作,百度成為win10 Edge瀏覽器中國預設主頁和搜索引擎,系統增加了搜狗輸入法,安裝過程需要用戶手動創建個人賬戶等步驟,為保證系統的穩定性,win10為未激
  • 一.概述 乙太網的arp數據包結構: arp結構op操作參數:1為請求,2為應答。 常用的數據結構如下: 1.物理地址結構位於netpacket/packet.h 1 struct sockaddr_ll 2 { 3 unsigned short int sll_family; 4 unsigned
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...