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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? cs8900.c

?? s3c2440 bootloader 源碼
?? C
字號:
/* * Cirrus Logic CS8900A Ethernet * * (C) Copyright 2002 * Sysgo Real-Time Solutions, GmbH <www.elinos.com> * Marius Groeger <mgroeger@sysgo.de> * * Copyright (C) 1999 Ben Williamson <benw@pobox.com> * * See file CREDITS for list of people who contributed to this * project. * * This program is loaded into SRAM in bootstrap mode, where it waits * for commands on UART1 to read and write memory, jump to code etc. * A design goal for this program is to be entirely independent of the * target board.  Anything with a CL-PS7111 or EP7211 should be able to run * this code in bootstrap mode.  All the board specifics can be handled on * the host. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */#include "armboot.h"#include "command.h"#include "cs8900.h"#include "net.h"#ifdef CONFIG_DRIVER_CS8900#if (CONFIG_COMMANDS & CFG_CMD_NET)/* packet page register access functions */#ifdef CS8900_BUS32/* we don't need 16 bit initialisation on 32 bit bus */#define get_reg_init_bus(x) get_reg((x))#elsestatic unsigned short get_reg_init_bus(int regno){    /* force 16 bit busmode */    volatile unsigned char c;    c = CS8900_BUS16_0;    c = CS8900_BUS16_1;    c = CS8900_BUS16_0;    c = CS8900_BUS16_1;    c = CS8900_BUS16_0;    CS8900_PPTR = regno;    return (unsigned short) CS8900_PDATA;}#endifstatic unsigned shortget_reg(int regno){    CS8900_PPTR = regno;    return (unsigned short) CS8900_PDATA;}static void put_reg(int regno, unsigned short val){    CS8900_PPTR = regno;    CS8900_PDATA = val;}static void eth_reset(void){    int tmo;    unsigned short us;    /* reset NIC */    put_reg(PP_SelfCTL, get_reg(PP_SelfCTL) | PP_SelfCTL_Reset );    /* wait for 200ms */    udelay(200000);    /* Wait until the chip is reset */    tmo = get_timer(0) + 1 * CFG_HZ;    while ((((us = get_reg_init_bus(PP_SelfSTAT)) & PP_SelfSTAT_InitD) == 0)	   && tmo < get_timer(0))      /*NOP*/;}void cs8900_get_enetaddr (uchar *addr){    int i;    /* verify chip id */    if (get_reg_init_bus(PP_ChipID) != 0x630e)	return;    eth_reset();        if ((get_reg(PP_SelfST) & (PP_SelfSTAT_EEPROM | PP_SelfSTAT_EEPROM_OK)) == 	      (PP_SelfSTAT_EEPROM|PP_SelfSTAT_EEPROM_OK)) {	/* Load the MAC from EEPROM */      	for (i=0; i<6/2; i++) {	    unsigned int Addr;	    Addr = get_reg(PP_IA+i*2);	    addr[i*2] = Addr & 0xFF;	    addr[i*2+1] = Addr >> 8;	}    }		}void eth_halt( void ){    /* disable transmitter/receiver mode */    put_reg(PP_LineCTL, 0);    /* "shutdown" to show ChipID or kernel wouldn't find he cs8900 ... */    get_reg_init_bus(PP_ChipID);}int eth_init( bd_t *bd ){    int ret;#if 1#include <s3c2410.h>   printf(" rBWSCON 0x%08X   \n",rBWSCON );    rBWSCON = ( rBWSCON & ~(0xf<<12)) | (0xd << 12);    printf(" rBWSCON 0x%08X   \n",rBWSCON );   rBANKCON3 = ( 3<<11)|(0x7<<8)|(0x1<<6)|(0x3<<4)|(0x3<<2);#endif       	    ret  =  get_reg_init_bus(PP_ChipID);     /* verify chip id */    if (ret != 0x630e)    {	printf( "CS8900 ID 0x%08X Ethernet chip not found?!\n",ret );	return 0;    }    eth_reset();    /* set the ethernet address */    put_reg(PP_IA + 0, bd->bi_enetaddr[0] | (bd->bi_enetaddr[1] << 8));    put_reg(PP_IA + 2, bd->bi_enetaddr[2] | (bd->bi_enetaddr[3] << 8));    put_reg(PP_IA + 4, bd->bi_enetaddr[4] | (bd->bi_enetaddr[5] << 8));	         /* receive only error free packets addressed to this card */    put_reg(PP_RxCTL, PP_RxCTL_IA | PP_RxCTL_Broadcast | PP_RxCTL_RxOK);    /* do not generate any interrupts on receive operations */    put_reg(PP_RxCFG, 0);    /* do not generate any interrupts on transmit operations */    put_reg(PP_TxCFG, 0);    /* do not generate any interrupts on buffer operations */    put_reg(PP_BufCFG, 0);    /* enable transmitter/receiver mode */    put_reg(PP_LineCTL, PP_LineCTL_Rx | PP_LineCTL_Tx);    return 0;}/* Get a data block via Ethernet */extern int eth_rx(void){    int i;    unsigned short rxlen;    unsigned short *addr;    unsigned short status;    status = get_reg(PP_RER);    if ((status & PP_RER_RxOK) == 0)      return 0;    status = CS8900_RTDATA;       /* stat */    rxlen = CS8900_RTDATA;        /* len */    if(rxlen > PKTSIZE_ALIGN + PKTALIGN)      printf("packet too big!\n");    for(addr = (unsigned short *)NetRxPackets[0], i = rxlen >> 1; i > 0; i-- )      *addr++ = CS8900_RTDATA;    if(rxlen & 1)      *addr++ = CS8900_RTDATA;    /* Pass the packet up to the protocol layers. */    NetReceive(NetRxPackets[0], rxlen);    return rxlen;}/* Send a data block via Ethernet. */extern int eth_send(volatile void *packet, int length){    volatile unsigned short *addr;    int tmo;    unsigned short s;retry:    /* initiate a transmit sequence */    CS8900_TxCMD = PP_TxCmd_TxStart_Full;    CS8900_TxLEN = length;        /* Test to see if the chip has allocated memory for the packet */    if ((get_reg(PP_BusSTAT) & PP_BusSTAT_TxRDY) == 0) {    	/* Oops... this should not happen! */	printf("cs: unable to send packet; retrying...\n");	for (tmo = get_timer(0) + 5 * CFG_HZ; get_timer(0) < tmo; )	  /*NOP*/;	eth_reset();	goto retry;     }    /* Write the contents of the packet */    /* assume even number of bytes */    for(addr = packet; length > 0; length -= 2 )      CS8900_RTDATA = *addr++;    /* wait for transfer to succeed */    tmo = get_timer(0) + 5 * CFG_HZ;    while((s = get_reg(PP_TER) & ~0x1F) == 0)     {	if (get_timer(0) >= tmo)	  break;    }           /* nothing */ ;    if ((s & (PP_TER_CRS | PP_TER_TxOK)) != PP_TER_TxOK) {	printf("\ntransmission error %#x\n", s);    }    return 0;}#endif /* COMMANDS & CFG_NET */#endif /* CONFIG_DRIVER_CS8900 */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
美国一区二区三区在线播放| 日本一区二区不卡视频| 性做久久久久久| 欧美视频中文一区二区三区在线观看 | 国产校园另类小说区| 国产乱码精品1区2区3区| 国产欧美中文在线| av电影一区二区| 亚洲精品国产视频| 欧美精品日韩精品| 久久国产精品72免费观看| 久久影院午夜片一区| 成人在线一区二区三区| 伊人一区二区三区| 欧美日韩成人一区| 国模少妇一区二区三区| 亚洲欧美偷拍三级| 5月丁香婷婷综合| 国产麻豆日韩欧美久久| 亚洲精品伦理在线| 欧美一区二区三区视频免费播放 | 欧美精品久久99| 国产主播一区二区三区| 最新中文字幕一区二区三区| 欧美精品日韩一区| 成人午夜电影久久影院| 亚洲1区2区3区视频| 久久久久国产一区二区三区四区| 91视频免费播放| 日韩电影在线免费看| 欧美国产综合一区二区| 欧美日韩高清在线| 欧美色综合久久| 精品一区二区国语对白| 亚洲精品高清在线| 久久亚洲欧美国产精品乐播| 一本色道久久综合狠狠躁的推荐| 久久精品国产在热久久| 一区二区三区成人| 国产欧美日韩一区二区三区在线观看| 在线中文字幕一区| 夫妻av一区二区| 欧美a级一区二区| 亚洲精品国久久99热| 久久精品综合网| 91精品国产综合久久久久久久久久| 国产成人丝袜美腿| 久久国产精品无码网站| 亚洲午夜国产一区99re久久| 亚洲国产精品精华液ab| 日韩一区二区三区观看| 欧美性猛交xxxx乱大交退制版| 国产精品一区二区视频| 久久国产夜色精品鲁鲁99| 亚洲高清不卡在线| 最新日韩av在线| 国产精品久久看| 久久久久久久久久久黄色| 91精品中文字幕一区二区三区| 91极品视觉盛宴| 99精品视频在线播放观看| 国产成人高清视频| 激情综合色播激情啊| 麻豆国产精品一区二区三区| 五月婷婷久久丁香| 一区二区三区日韩在线观看| 亚洲欧洲精品成人久久奇米网| 久久久国产午夜精品| 精品国产污污免费网站入口 | 欧美日韩国产一区| 在线视频欧美区| 色婷婷综合久色| 色网站国产精品| 色天使久久综合网天天| 精品久久久久一区| 欧美变态tickling挠脚心| 欧美一级午夜免费电影| 日韩一级大片在线观看| 欧美一区二区在线视频| 91.麻豆视频| 欧美一区二区三区四区视频 | 国产麻豆一精品一av一免费| 日本三级韩国三级欧美三级| 丝袜亚洲另类欧美综合| 日韩电影在线观看电影| 免费精品99久久国产综合精品| 日韩va亚洲va欧美va久久| 青草国产精品久久久久久| 免费成人在线播放| 韩国视频一区二区| 国产精品一区二区久激情瑜伽| 国产精品66部| www.欧美.com| 97久久超碰国产精品电影| 日本精品裸体写真集在线观看| 在线国产亚洲欧美| 欧美日韩成人在线| 欧美大片顶级少妇| 国产偷v国产偷v亚洲高清| 亚洲私人黄色宅男| 亚洲成a天堂v人片| 久久99精品久久久久久国产越南 | 成人av在线网| 欧美性极品少妇| 欧美一区二区播放| 亚洲国产激情av| 亚洲最大色网站| 麻豆国产精品视频| 精品福利在线导航| 国产精品国产馆在线真实露脸 | 高清在线观看日韩| 97精品电影院| 91精品免费观看| 国产日韩欧美精品电影三级在线 | 亚洲成年人影院| 国模无码大尺度一区二区三区| 91美女片黄在线观看91美女| 欧美区在线观看| 国产日韩av一区二区| 亚洲高清免费一级二级三级| 精品一区二区免费在线观看| 本田岬高潮一区二区三区| 欧美精品18+| 国产精品网站在线| 日韩精品电影在线| 99re66热这里只有精品3直播| 日韩亚洲欧美中文三级| 亚洲欧美区自拍先锋| 国产一区视频网站| 欧美性感一区二区三区| 欧美国产日本视频| 裸体健美xxxx欧美裸体表演| 91啪九色porn原创视频在线观看| 日韩精品一区二区在线观看| 亚洲欧美日韩系列| 久久99精品久久久久久动态图| 91国产免费看| 中文字幕第一区二区| 日韩av成人高清| 欧美性受极品xxxx喷水| 国产精品伦一区| 久久99精品久久久久久久久久久久 | 欧美国产精品一区| 麻豆久久久久久久| 欧美午夜精品久久久| 国产精品女同一区二区三区| 精品一区二区久久久| 在线播放国产精品二区一二区四区| 国产精品人成在线观看免费| 久久99国内精品| 欧美一级午夜免费电影| 亚洲成人av福利| 91国偷自产一区二区三区成为亚洲经典 | 91精品在线观看入口| 亚洲在线中文字幕| 一本一道综合狠狠老| 欧美国产日韩a欧美在线观看| 欧美精品v日韩精品v韩国精品v| 亚洲少妇屁股交4| 97se亚洲国产综合自在线不卡| 国产人久久人人人人爽| 国产在线不卡一卡二卡三卡四卡| 欧美精品黑人性xxxx| 视频一区二区三区入口| 欧美日韩免费在线视频| 亚洲超碰精品一区二区| 欧美探花视频资源| 亚洲国产欧美在线| 欧美三级在线看| 亚洲成人在线免费| 欧美高清精品3d| 日本欧美在线观看| 日韩女优电影在线观看| 久久国产精品无码网站| 久久精品欧美一区二区三区麻豆| 精品一区中文字幕| 国产色产综合色产在线视频| 懂色av一区二区三区免费观看 | 精品久久国产字幕高潮| 国产一区在线观看视频| 日本一区二区三区四区在线视频 | 91在线观看免费视频| 亚洲精品成人精品456| 欧美影院午夜播放| 午夜视频一区二区| 欧美大肚乱孕交hd孕妇| 精品一区二区国语对白| 一区免费观看视频| 欧美优质美女网站| 日本最新不卡在线| 久久久美女毛片| 91丨porny丨户外露出| 天堂午夜影视日韩欧美一区二区| 欧美日韩色综合| 美女视频一区二区| 中文字幕电影一区| 欧美精品第1页| 国产不卡视频在线观看| 国产伦精品一区二区三区视频青涩| 精品一区二区影视|