亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? etherdev.c

?? 《嵌入式固件開發》一書的源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* etherdev.c:    This file, along with common/ethernet.c supports the ethernet interface.    It is the lowest layer of code supporting the monitor's IP, ICMP & UDP    services.  This file is specific to one particular ethernet device    and provides the hooks needed by common/ethernet.c to initialize,    and transmit/receive packets in a polled environment.    The common vs device-specific code is generally noted by a naming     convention where ...Ethernet... is common and ...Etherdev... is device-    specific.    General notice:    This code is part of a boot-monitor package developed as a generic base    platform for embedded system designs.  As such, it is likely to be    distributed to various projects beyond the control of the original    author.  Please notify the author of any enhancements made or bugs found    so that all may benefit from the changes.  In addition, notification back    to the author will allow the new user to pick up changes that may have    been made by other users after this version of the code was distributed.    Author: Ed Sutter    email:  esutter@lucent.com      (home: lesutter@worldnet.att.net)    phone:  908-582-2351            (home: 908-889-5161)*/#include "config.h"#if INCLUDE_ETHERNET#include "cpuio.h"#include "ether.h"#include "stddefs.h"#include "genlib.h"#include "bcsr.h"#include "arch_ppc.h"#include "mpc860.h"#include "masks860.h"extern  char *processARP();extern  EPPC *IMMRBase;#define RTS1_PB19   1#define RTS1_PC15   0int EtherRLCnt, EtherDEFCnt, EtherLCCnt, EtherDRVRETRYCnt;int eninit();static uchar xbuf[XBUFCNT][1600];   /* Transmit & receive buffers pointed */static uchar rbuf[RBUFCNT][1600];   /* to by the buffer descriptors. */struct  snoopinfo snoopInfo;struct  enet_bd *tbptr, *rbptr, *prevtbptr;/* ShowEtherdevStats():    Called by the command "ether stat" on the monitor's command line.    This function and a common ShowEthernetStats() are used to dump    generic as well as device-specific ethernet driver statistics.*/voidShowEtherdevStats(){    printf("Driver retry count:      %d\n",EtherDRVRETRYCnt);    printf("Retry_count_exceeded:    %d times\n",EtherRLCnt);    printf("Late-collision count:    %d\n",EtherLCCnt);    printf("Defer-indication count:  %d\n",EtherDEFCnt);    if (snoopInfo.on) {        char smac[32];        EtherToString(snoopInfo.mac,smac);        printf("Snoop MAC:               %s\n",smac);    }}/* EtherdevStartup():    Called by EthernetStartup().  Initialize all device-specific     counters, reset and initialized the ethernet device.*/intEtherdevStartup(int verbose){    EtherRLCnt = 0;    EtherLCCnt = 0;    EtherDEFCnt = 0;    EtherDRVRETRYCnt = 0;    snoopInfo.on = 0;    /* Put ethernet controller in reset: */    enreset();    /* Initialize controller: */    eninit();    return(0);}/* DisableEtherdev():    Called by DisableEthernet() to do the device-specific portion of     the turn-down.*/voidDisableEtherdev(){    ulong   bcsr;    bcsr = *(ulong *)BCSR1_BASE;    bcsr |= ETHERDISABLE;               /* Disable ethernet */    *(ulong *)BCSR1_BASE = bcsr;    enreset();#if RTS1_PB19    IMMRBase->pip_pbpar &= ~(0x1000);    /* set port B -> RTS1 = *TENA */#elif RTS1_PC15    IMMRBase->pio_pcpar &= ~(0x0001);    /* set port C -> RTS1 = *TENA */#else#error#endif    IMMRBase->cpmi_cimr &= ~CIMR_SCC1;    EtherIsActive = 0;    IPMonCmdActive = 0;}voidenreset(){    int timeout;    /* Issue CPM Command to init RX/TX params for SCC1: */    /* (wait for completion) */    IMMRBase->cp_cr = 0x0001;    timeout = 500000;    while(IMMRBase->cp_cr & 0x0001) {        timeout--;        if (timeout <= 0) {            printf("enreset() timeout\n");            break;        }    }}/* eninit():    These steps are basically taken from the MPC860 User's Manual (rev1)    section 28.22 "SCC Ethernet Programming Example".*/inteninit(){    ushort  mac;    uchar   *cp;    ulong   bcsr;    int     i, timeout;    struct  enet_bd *tbd, *rbd;    /* Set IMMR pointing to the MPC860's internal register memory map. */    IMMRBase = (EPPC *)(ppcMfimmr() & 0xFFFF0000);    /* Configure ports for ethernet... */    IMMRBase->si_sicr  &= 0xFFFFFF00;   /* Clear SCC1 info */    IMMRBase->pio_papar |=  0x0303;     /* RXD1,TXD1, CLK1, CLK2 */    IMMRBase->pio_padir &= ~0x0303;     /* RXD1,TXD1, CLK1, CLK2*/    bcsr = *(ulong *)BCSR4_BASE;    bcsr &= ~ETHLOOP;                   /* Disable loopback */    bcsr |= (TFPLDL | TPSQEL);          /* Disable squelch & full duplex */    *(ulong *)BCSR4_BASE = bcsr;    bcsr = *(ulong *)BCSR1_BASE;    bcsr &= ~ETHERDISABLE;              /* Enable ethernet */    *(ulong *)BCSR1_BASE = bcsr;    IMMRBase->si_sicr  |= 0x0000002c;   /* NMSI, recv = CLK2, xmit = CLK1 */#if RTS1_PB19    IMMRBase->pip_pbpar |=  0x1000;     /* RTS1 */    IMMRBase->pip_pbdir |=  0x1000;     /* RTS1 */    IMMRBase->pip_pbdat &= ~0x1000;     /* Data=0 for when RTS1 is disabled */#else    IMMRBase->pio_pcpar |=  0x0001;     /* RTS1 */    IMMRBase->pio_pcdir &=  ~0x0001;    /* RTS1 */    IMMRBase->pio_pcdat &= ~0x0001;     /* Data=0 for when RTS1 is disabled */#endif    IMMRBase->pio_pcpar &= ~0x0030;         /* CD1, CTS1 */    IMMRBase->pio_pcdir &= ~0x0030;         /* CD1, CTS1 */    IMMRBase->pio_pcso  |=  0x0030;         /* CD1, CTS1 */    /* Configure General SCC Mode Register for ethernet: */    IMMRBase->scc_regs[SCC1_REG].scc_gsmr_h = 0;    IMMRBase->scc_regs[SCC1_REG].scc_gsmr_l = 0x1088000c;    /* Initialize Buffer Descriptors (located in DPRAM): */    /* Refer to mpc860.h for the layout of DPRAM as used by MicroMonitor. */    tbd = tbptr = IMMRBase->qcp_or_ud.umd.e_bdtbl;    rbd = rbptr = &IMMRBase->qcp_or_ud.umd.e_bdtbl[XBUFCNT];    /* Set parameter ram to point to buffer descriptors in DPRAM: */    /* Note that this will generate a compiler warning because we are */    /* casting a pointer to a short. This can be ignored because these */    /* two entries are offsets relative to the base of the IMMR, not the */    /* actual address. */    IMMRBase->PRAM[PAGE1].enet_scc.rbase = (ushort)rbd;    IMMRBase->PRAM[PAGE1].enet_scc.tbase = (ushort)tbd;    for (i=0;i<XBUFCNT;i++,tbd++) {        tbd->status = 0;        tbd->length = 0;        tbd->baddr = xbuf[i];        if (i == (XBUFCNT-1))            tbd->status |= BD_WRAP; /* Set WRAP bit on final BD */    }    for(i=0;i<RBUFCNT;i++,rbd++) {        rbd->status = BD_READY;        rbd->length = 0;        rbd->baddr = rbuf[i];        if (i == (RBUFCNT-1))            rbd->status |= BD_WRAP; /* Set WRAP bit on final BD */    }    /* Issue CPM Command to init RX/TX params for SCC1: */    /* (wait for completion) */    IMMRBase->cp_cr = 0x0001;    timeout = 500000;    while(IMMRBase->cp_cr & 0x0001) {        timeout--;        if (timeout <= 0)            break;    }    /* Set RFCR,TFCR -- Rx,Tx Function Code */    /* Normal Operation and Motorola byte ordering */    IMMRBase->PRAM[PAGE1].enet_scc.rfcr = 0x10;      IMMRBase->PRAM[PAGE1].enet_scc.tfcr = 0x10;      /* MRBLR = MAX buffer length (first value larger than 1518 evenly */    /* divisible by 4). */    IMMRBase->PRAM[PAGE1].enet_scc.mrblr = 1520;        /* Initialize based on example in mpc860 manual. */    IMMRBase->PRAM[PAGE1].enet_scc.c_pres = 0xffffffff;    IMMRBase->PRAM[PAGE1].enet_scc.c_mask = 0xdebb20e3;    IMMRBase->PRAM[PAGE1].enet_scc.crcec = 0;    IMMRBase->PRAM[PAGE1].enet_scc.alec = 0;    IMMRBase->PRAM[PAGE1].enet_scc.disfc = 0;    IMMRBase->PRAM[PAGE1].enet_scc.pads = 0x8888;    IMMRBase->PRAM[PAGE1].enet_scc.ret_lim = 15;    IMMRBase->PRAM[PAGE1].enet_scc.mflr = 1518;    IMMRBase->PRAM[PAGE1].enet_scc.minflr = 64;    IMMRBase->PRAM[PAGE1].enet_scc.maxd1 = 1520;    IMMRBase->PRAM[PAGE1].enet_scc.maxd2 = 1520;    IMMRBase->PRAM[PAGE1].enet_scc.gaddr1 = 0;    IMMRBase->PRAM[PAGE1].enet_scc.gaddr2 = 0;    IMMRBase->PRAM[PAGE1].enet_scc.gaddr3 = 0;    IMMRBase->PRAM[PAGE1].enet_scc.gaddr4 = 0;    /* Load the PADDR registers with this board's ethernet address. */    cp = (uchar *)&mac;    cp[0] = BinEnetAddr[5];    cp[1] = BinEnetAddr[4];    IMMRBase->PRAM[PAGE1].enet_scc.paddr_h = mac;    cp[0] = BinEnetAddr[3];    cp[1] = BinEnetAddr[2];    IMMRBase->PRAM[PAGE1].enet_scc.paddr_m = mac;    cp[0] = BinEnetAddr[1];    cp[1] = BinEnetAddr[0];    IMMRBase->PRAM[PAGE1].enet_scc.paddr_l = mac;    IMMRBase->PRAM[PAGE1].enet_scc.p_per = 0;    IMMRBase->PRAM[PAGE1].enet_scc.iaddr1 = 0;    IMMRBase->PRAM[PAGE1].enet_scc.iaddr2 = 0;    IMMRBase->PRAM[PAGE1].enet_scc.iaddr3 = 0;    IMMRBase->PRAM[PAGE1].enet_scc.iaddr4 = 0;    IMMRBase->PRAM[PAGE1].enet_scc.taddr_h = 0;    IMMRBase->PRAM[PAGE1].enet_scc.taddr_m = 0;    IMMRBase->PRAM[PAGE1].enet_scc.taddr_l = 0;    /* Clear any events: */    IMMRBase->scc_regs[SCC1_REG].scc_scce = 0xffff;    /* Enable RXF events: */    IMMRBase->scc_regs[SCC1_REG].scc_sccm = ENET_SCCM_RXF;    IMMRBase->cpmi_cimr |= CIPR_SCC1;    IMMRBase->scc_regs[SCC1_REG].scc_dsr = 0xd555;    IMMRBase->scc_regs[SCC1_REG].scc_psmr = 0x080a;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人美女视频在线观看18| 亚洲视频1区2区| 欧美一区二区三区在线| 欧美精品丝袜久久久中文字幕| 欧美三级在线播放| 精品国产乱码久久久久久影片| 久久精品一区二区三区不卡| 一区二区三区加勒比av| 另类人妖一区二区av| 日韩午夜小视频| 国产精品久久三| 日本一区中文字幕| 99久久久精品| 欧美日韩成人在线| 精品久久五月天| 中文字幕在线观看一区| 天天综合天天综合色| 国产美女娇喘av呻吟久久| 波多野结衣91| 精品国产免费一区二区三区四区 | 午夜视频在线观看一区| 欧美一区二区三区精品| 国产.精品.日韩.另类.中文.在线.播放 | 久久精品国产澳门| 综合中文字幕亚洲| 欧美日本不卡视频| 国产福利一区在线| 精品av综合导航| 成人av在线播放网址| 久久久综合网站| 国产一区二区三区黄视频| 国产精品初高中害羞小美女文| 欧美性大战久久| 亚洲精品第一国产综合野| heyzo一本久久综合| 亚洲成av人**亚洲成av**| 色婷婷综合久久久中文一区二区| 国产色91在线| 欧美人与性动xxxx| 91色porny| 亚洲一区电影777| 欧美色老头old∨ideo| 国产成人精品www牛牛影视| 伊人婷婷欧美激情| 国产日产欧产精品推荐色| 国产精品伊人色| 欧美激情艳妇裸体舞| 成人精品高清在线| 久久疯狂做爰流白浆xx| 夜夜嗨av一区二区三区中文字幕 | 久久伊人蜜桃av一区二区| 美国毛片一区二区| 久久久青草青青国产亚洲免观| 一本色道久久综合亚洲精品按摩| 国产乱码精品一区二区三区av| 亚洲高清不卡在线观看| 色94色欧美sute亚洲线路一ni| 尤物在线观看一区| 国产日韩欧美制服另类| 日韩美女天天操| 成人亚洲精品久久久久软件| 久色婷婷小香蕉久久| 日韩成人av影视| 亚洲精品视频在线看| 国产精品美女久久久久久2018| 99国产欧美久久久精品| 国产成人亚洲综合a∨婷婷 | 精品在线播放免费| 国产区在线观看成人精品| 日韩欧美自拍偷拍| 欧美少妇bbb| 欧美影视一区在线| 色综合天天性综合| 日产国产欧美视频一区精品| 亚洲一区二区美女| 午夜天堂影视香蕉久久| 爽爽淫人综合网网站| 国产精品日韩成人| 国产精品伦理在线| 日韩美女视频一区二区| 亚洲欧美日韩电影| 日韩欧美国产一区二区三区| 91精品国产aⅴ一区二区| 911国产精品| www.欧美日韩| 91麻豆国产精品久久| 一本色道久久综合狠狠躁的推荐| 91精品福利视频| 欧美美女喷水视频| 日韩欧美一区在线| 久久―日本道色综合久久| 久久久国产精华| 最新高清无码专区| 亚洲午夜电影在线观看| 伦理电影国产精品| 国产v综合v亚洲欧| 91黄视频在线观看| 91精品国产综合久久香蕉麻豆 | xnxx国产精品| 中文字幕不卡在线观看| 中文字幕亚洲在| 一区二区三区国产精华| 九色porny丨国产精品| 国产成人小视频| 欧美偷拍一区二区| 精品欧美久久久| 国产精品国模大尺度视频| 夜夜操天天操亚洲| 狠狠色丁香婷综合久久| 午夜精品久久久久久久99水蜜桃| 午夜国产精品一区| 国产一区二区在线影院| 91蝌蚪porny成人天涯| 欧美久久婷婷综合色| 久久一区二区视频| 一区二区三区中文在线| 日韩1区2区3区| www.欧美日韩国产在线| 欧美一区二区三区免费视频| 成人欧美一区二区三区视频网页| 亚洲444eee在线观看| 精品一区二区三区久久久| 99久久精品免费| 日韩精品综合一本久道在线视频| 国产精品免费av| 美女网站色91| 在线亚洲高清视频| 色av成人天堂桃色av| 久久综合久久99| 亚洲国产美女搞黄色| 大胆亚洲人体视频| 精品国产一区二区三区忘忧草| 亚洲精品中文字幕在线观看| 久久99精品久久久久久动态图| 91啪亚洲精品| 久久久久久久久蜜桃| 亚洲成av人片在线观看无码| 国产盗摄精品一区二区三区在线| 欧美喷潮久久久xxxxx| 日韩一区中文字幕| 国产超碰在线一区| 日韩小视频在线观看专区| 亚洲午夜免费电影| 99久久婷婷国产综合精品| 欧美成人性战久久| 日本最新不卡在线| 欧美精品一卡两卡| 亚洲精品伦理在线| 99免费精品视频| 国产欧美日韩另类视频免费观看| 蜜桃视频免费观看一区| 欧美三级乱人伦电影| 一区二区成人在线观看| 97久久人人超碰| 一色屋精品亚洲香蕉网站| 国产xxx精品视频大全| 国产日韩综合av| 国产一区二区三区精品视频| 精品久久久久久久久久久久久久久久久| 亚洲电影一区二区| 欧美午夜片在线看| 亚洲成在人线在线播放| 欧美性受xxxx| 午夜欧美视频在线观看| 欧美日韩成人一区二区| 偷拍日韩校园综合在线| 欧美人xxxx| 日本不卡1234视频| 不卡在线观看av| 成人欧美一区二区三区黑人麻豆 | 肉丝袜脚交视频一区二区| 欧美午夜精品久久久久久超碰| 亚洲欧美福利一区二区| 色婷婷精品久久二区二区蜜臂av| 亚洲欧美日韩国产手机在线| 日本乱人伦一区| 丝瓜av网站精品一区二区| 日韩一区二区三区免费看| 九一久久久久久| 久久久久国产精品人| 成人精品国产一区二区4080| 亚洲色图一区二区三区| 欧美性受xxxx黑人xyx性爽| 性做久久久久久| 欧美大片国产精品| 激情综合五月婷婷| 国产精品你懂的| 欧美性猛交xxxx黑人交| 日韩av电影天堂| 久久久久综合网| 色哟哟国产精品免费观看| 亚洲综合久久久久| 日韩精品资源二区在线| 成人综合在线观看| 亚洲国产sm捆绑调教视频 | 国产视频一区在线观看| 91丨九色丨蝌蚪丨老版| 五月天婷婷综合| 久久精品免视看| 欧美亚洲禁片免费|