?? ethernet.lst
字號:
C51 COMPILER V7.02b ETHERNET 12/10/2005 21:31:08 PAGE 1
C51 COMPILER V7.02b, COMPILATION OF MODULE ETHERNET
OBJECT MODULE PLACED IN Ethernet.OBJ
COMPILER INVOKED BY: E:\EDATOOLS\KEILC7.0\C51\BIN\C51.EXE Ethernet.c BROWSE DEBUG OBJECTEXTEND
stmt level source
1 /*****************************************/
2 /* Copyright (c) 2005, 通信工程學院 */
3 /* All rights reserved. */
4 /* 作 者:戴 佳 */
5 /*****************************************/
6
7 #include "Ethernet.h"
8
9 /* 主函數(shù) */
10 void main(void)
11 {
12 1 delay(1000); // 延時1s,保證電源穩(wěn)定和網卡自身的上電完成
13 1
14 1 NICRst(); // RTL8019AS熱復位
15 1
16 1 ClearISR(); // 清除ISR寄存器
17 1
18 1 RTL8019Init(); // 初始化RTL8019AS
19 1
20 1 while(1)
21 1 {
22 2 ;
23 2 }
24 1 }
25
26 /* 延時t毫秒 */
27 void delay(uint t)
28 {
29 1 uint i;
30 1 while(t--)
31 1 {
32 2 /* 對于12M時鐘,約延時1ms */
33 2 for (i=0;i<125;i++)
34 2 {}
35 2 }
36 1 }
37
38 /* RTL8019AS熱復位 */
39 void NICRst()
40 {
41 1 uchar i,tmp;
42 1 tmp = REG1f; // 讀RTL8019AS的復位端口
43 1 REG1f = tmp; // 寫RTL8019AS的復位端口
44 1 for(i=0;i<250;i++); // 適當延時
45 1 }
46
47 /* 通過CR寄存器的PS1和PS0設置寄存器頁 */
48 void SelectPage(uchar pagenum)
49 {
50 1 uchar tmp;
51 1 tmp = REG00;
52 1 tmp = tmp&0x3B; // 注意不是0x3F,TXP位在不發(fā)送時要置0
53 1 pagenum = pagenum<<6;
54 1 tmp = tmp|pagenum;
55 1 REG00 = tmp;
C51 COMPILER V7.02b ETHERNET 12/10/2005 21:31:08 PAGE 2
56 1 }
57
58 /* 初始化RTL8019AS,PAGE2寄存器只讀,PAGE3寄存器不是NE2000兼容的,均不用設置 */
59 /* 使用0x40-0x4b為網卡的發(fā)送緩沖區(qū),共12頁,剛好存儲2個最大的以太網數(shù)據(jù)包。
60 使用0x4c-0x7f為網卡的接收緩沖區(qū),共52頁。因此PSTART=0x4c,PSTOP=0x80
61 (0x80為停止頁,接收緩沖區(qū)直到0x7f,不包括0x80)。剛開始時,網卡沒有接收
62 到任何數(shù)據(jù)包,因此BNRY設置為指向第一個接收緩沖區(qū)的頁0x4c) */
63 void RTL8019Init()
64 {
65 1 REG00 = 0x21; // 選擇頁0的寄存器,網卡停止運行,因為還沒有初始化
66 1
67 1 REG01 = 0x4c; // 寄存器PSTART,設置接收緩沖區(qū)的起始頁的地址
68 1 REG02 = 0x80; // 寄存器PSTOP,設置接收緩沖區(qū)的結束頁的地址
69 1 REG03 = 0x4c; // 寄存器BNRY,設置為指向第一個接收緩沖區(qū)的頁0x4c(用作讀指針)
70 1 REG04 = 0x40; // 寄存器TPSR,發(fā)送起始頁地址初始化為指向第一個發(fā)送緩沖區(qū)的頁
71 1 REG0c = 0xcc; /* 接收配置寄存器RCR,設置為僅接收自己地址的數(shù)據(jù)包以及廣播地址
72 1 和多點播送地址數(shù)據(jù)包,小于64字節(jié)的包丟棄,校驗錯的數(shù)據(jù)包不接收 */
73 1 REG0d = 0xe0; // 發(fā)送配置寄存器TCR,設置為啟用crc自動生成和校驗,正常模式工作
74 1 REG0e = 0xc8; /* 數(shù)據(jù)配置寄存器DCR,設置為使用FIFO緩存,普通模式,8位數(shù)據(jù)傳輸,
75 1 字節(jié)順序為高位字節(jié)在前,低位字節(jié)在后 */
76 1 REG0f = 0x00; // 中斷屏蔽寄存器IMR,設置為屏蔽所有中斷
77 1 SelectPage(1); // 選擇頁1的寄存器
78 1 REG07=0x4d; // 寄存器CURR,設置為指向當前正在寫的頁的下一頁(用作寫指針)
79 1
80 1 /* 多址地址寄存器MAR0-MAR7均設置為0x00 */
81 1 REG08 = 0x00; // MAR0
82 1 REG09 = 0x00; // MAR1
83 1 REG0a = 0x00; // MAR2
84 1 REG0b = 0x80; // MAR3
85 1 REG0c = 0x00; // MAR4
86 1 REG0d = 0x00; // MAR5
87 1 REG0e = 0x00; // MAR6
88 1 REG0f = 0x00; // MAR7
89 1
90 1 GetPhyAdd(); // 獲取以太網物理地址
91 1
92 1 REG00 = 0x22; // 選擇頁0寄存器,執(zhí)行命令。
93 1 }
94
95 /* 上電后清除ISR寄存器 */
96 void ClearISR()
97 {
98 1 SelectPage(0);
99 1 REG07 = REG07|0xff;
100 1 }
101
102 /* 獲取以太網物理地址 */
103 void GetPhyAdd()
104 {
105 1 uchar tmp;
106 1
107 1 SelectPage(0); // 選擇頁0
108 1 REG08 = 0; // 遠程DMA起始地址低位寄存器RSAR0,設置為0
109 1 REG09 = 0; // 遠程DMA起始地址高位寄存器RSAR1,設置為0
110 1 REG0a = 12; // 遠程DMA計數(shù)器低位寄存器RBCR0,設置為12
111 1 REG0b = 0; // 遠程DMA計數(shù)器高位寄存器RBCR1,設置為0
112 1
113 1 REG00 = 0x0a; // 遠程DMA,啟動命令
114 1
115 1 SelectPage(1); // 選擇頁1
116 1 tmp = REG10; // 讀取一個字節(jié)
117 1 REG01 = tmp; // 寫入PAR0
C51 COMPILER V7.02b ETHERNET 12/10/2005 21:31:08 PAGE 3
118 1 tmp = REG10; // 讀取一個重復的字節(jié),這個字節(jié)被丟棄
119 1 tmp = REG10; // 讀取一個字節(jié)
120 1 REG02 = tmp; // 寫入PAR1
121 1 tmp = REG10; // 讀取一個重復的字節(jié),這個字節(jié)被丟棄
122 1 tmp = REG10; // 讀取一個字節(jié)
123 1 REG03 = tmp; // 寫入PAR2
124 1 tmp = REG10; // 讀取一個重復的字節(jié),這個字節(jié)被丟棄
125 1 tmp = REG10; // 讀取一個字節(jié)
126 1 REG04 = tmp; // 寫入PAR3
127 1 tmp = REG10; // 讀取一個重復的字節(jié),這個字節(jié)被丟棄
128 1 tmp = REG10; // 讀取一個字節(jié)
129 1 REG05 = tmp; // 寫入PAR4
130 1 tmp = REG10; // 讀取一個重復的字節(jié),這個字節(jié)被丟棄
131 1 tmp = REG10; // 讀取一個字節(jié)
132 1 REG06 = tmp; // 寫入PAR5
133 1 }
134
MODULE INFORMATION: STATIC OVERLAYABLE
CODE SIZE = 262 ----
CONSTANT SIZE = ---- ----
XDATA SIZE = ---- ----
PDATA SIZE = ---- ----
DATA SIZE = ---- ----
IDATA SIZE = ---- ----
BIT SIZE = ---- ----
END OF MODULE INFORMATION.
C51 COMPILATION COMPLETE. 0 WARNING(S), 0 ERROR(S)
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -