⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 devs_eth_frv400.inl

📁 eCos操作系统源码
💻 INL
字号:
//==========================================================================////      devs/eth/frv/frv400/..../include/devs_eth_frv400.inl////      FRV400 ethernet I/O definitions.////==========================================================================//####ECOSGPLCOPYRIGHTBEGIN####// -------------------------------------------// This file is part of eCos, the Embedded Configurable Operating System.// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.//// eCos 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 or (at your option) any later version.//// eCos 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 eCos; if not, write to the Free Software Foundation, Inc.,// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.//// As a special exception, if other files instantiate templates or use macros// or inline functions from this file, or you compile this file and link it// with other works to produce a work based on this file, this file does not// by itself cause the resulting work to be covered by the GNU General Public// License. However the source code for this file must still be made available// in accordance with section (3) of the GNU General Public License.//// This exception does not invalidate any other reasons why a work based on// this file might be covered by the GNU General Public License.//// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.// at http://sources.redhat.com/ecos/ecos-license/// -------------------------------------------//####ECOSGPLCOPYRIGHTEND####//==========================================================================//#####DESCRIPTIONBEGIN####//// Author(s):    jskov, hmt, gthomas// Contributors: jskov// Date:         2001-02-28// Purpose:      FRV400 ethernet defintions//####DESCRIPTIONEND####//==========================================================================#include <cyg/hal/hal_intr.h>           // CYGNUM_HAL_INTERRUPT_ETHR#include <cyg/hal/hal_if.h>#include <cyg/io/pci.h>#ifdef __WANT_CONFIG#define CYGHWR_NS_DP83902A_PLF_RESET(_dp_)      \    CYG_MACRO_START                             \    cyg_uint8 _t;                               \    HAL_READ_UINT8(_dp_->reset, _t);            \    CYGACC_CALL_IF_DELAY_US(10);                \    HAL_WRITE_UINT8(_dp_->reset, _t);           \    CYGACC_CALL_IF_DELAY_US(10000);                \    CYG_MACRO_END#define DP_IN(_b_, _o_, _d_)                                    \    CYG_MACRO_START                                             \    HAL_READ_UINT8(((cyg_addrword_t)(_b_)+(_o_))^0x03, (_d_));    \    CYG_MACRO_END#define DP_OUT(_b_, _o_, _d_)                                   \    CYG_MACRO_START                                             \    HAL_WRITE_UINT8(((cyg_addrword_t)(_b_)+(_o_))^0x03, (_d_));   \    CYG_MACRO_END#define DP_IN_DATA(_b_, _d_)                                    \    CYG_MACRO_START                                             \    HAL_READ_UINT16((cyg_addrword_t)(_b_)^0x02, (_d_));         \    CYG_MACRO_END#define DP_OUT_DATA(_b_, _d_)                                   \    CYG_MACRO_START                                             \    HAL_WRITE_UINT16((cyg_addrword_t)(_b_)^0x02, (_d_));        \    CYG_MACRO_END//#define CYGHWR_NS_DP83902A_PLF_16BIT_DATA//#define CYGHWR_NS_DP83902A_PLF_BROKEN_TX_DMA#endif // __WANT_CONFIG#ifdef __WANT_DEVS#if defined(CYGSEM_DEVS_ETH_FRV400_ETH0_SET_ESA) #if defined(CYGPKG_REDBOOT) #include <pkgconf/redboot.h>#ifdef CYGSEM_REDBOOT_FLASH_CONFIG#include <redboot.h>#include <flash_config.h>RedBoot_config_option("Network hardware address [MAC]",                      lan_esa,                      ALWAYS_ENABLED, true,                      CONFIG_ESA, 0    );#endif  // CYGSEM_REDBOOT_FLASH_CONFIG#endif  // CYGPKG_REDBOOT#include <cyg/hal/hal_if.h>#ifndef CONFIG_ESA#define CONFIG_ESA 6#endif#endifstatic cyg_boolfind_rtl8029_match_func( cyg_uint16 v, cyg_uint16 d, cyg_uint32 c, void *p ){    return ((v == 0x10EC) && (d == 0x8029));}static void_frv400_eth_init(dp83902a_priv_data_t *dp){    cyg_pci_device_id devid;    cyg_pci_device dev_info;#if defined(CYGSEM_DEVS_ETH_FRV400_ETH0_SET_ESA)     cyg_bool esa_ok;    unsigned char _esa[6];#else    unsigned char prom[32];    int i;#endif    devid = CYG_PCI_NULL_DEVID;    if (cyg_pci_find_matching( &find_rtl8029_match_func, NULL, &devid )) {        cyg_pci_get_device_info(devid, &dev_info);        cyg_pci_translate_interrupt(&dev_info, &dp->interrupt);        dp->base = (cyg_uint8 *)(dev_info.base_map[0] & ~1);        dp->data = dp->base + 0x10;        dp->reset = dp->base + 0x1F;        diag_printf("RTL8029 at %p, interrupt: %x\n", dp->base, dp->interrupt);#if defined(CYGSEM_DEVS_ETH_FRV400_ETH0_SET_ESA)         esa_ok = CYGACC_CALL_IF_FLASH_CFG_OP(CYGNUM_CALL_IF_FLASH_CFG_GET,                                                      "lan_esa", _esa, CONFIG_ESA);        if (esa_ok) {            memcpy(dp->esa, _esa, sizeof(_esa));        }#else        // Read ESA from EEPROM        DP_OUT(dp->base, DP_DCR, 0x49);  // Wordwide access        DP_OUT(dp->base, DP_RBCH, 0);    // Remote byte count        DP_OUT(dp->base, DP_RBCL, 0);        DP_OUT(dp->base, DP_ISR, 0xFF);  // Clear any pending interrupts        DP_OUT(dp->base, DP_IMR, 0x00);  // Mask all interrupts         DP_OUT(dp->base, DP_RCR, 0x20);  // Monitor        DP_OUT(dp->base, DP_TCR, 0x02);  // loopback        DP_OUT(dp->base, DP_RBCH, 32);   // Remote byte count        DP_OUT(dp->base, DP_RBCL, 0);        DP_OUT(dp->base, DP_RSAL, 0);    // Remote address        DP_OUT(dp->base, DP_RSAH, 0);        DP_OUT(dp->base, DP_CR, DP_CR_START|DP_CR_RDMA);  // Read data        for (i = 0;  i < 32;  i++) {            cyg_uint16 _val;            HAL_READ_UINT16(dp->data, _val);            prom[i] = _val;        }        // Set ESA into chip        DP_OUT(dp->base, DP_CR, DP_CR_NODMA | DP_CR_PAGE1);  // Select page 1        for (i = 0; i < 6; i++) {            DP_OUT(dp->base, DP_P1_PAR0+i, prom[i]);        }        DP_OUT(dp->base, DP_CR, DP_CR_NODMA | DP_CR_PAGE0);  // Select page 0#endif    }}#define CYGHWR_NS_DP83902A_PLF_INIT(dp) _frv400_eth_init(dp)#ifndef CYGINT_IO_ETH_INT_SUPPORT_REQUIREDstatic void_frv400_eth_int_clear(dp83902a_priv_data_t *dp){    cyg_drv_interrupt_acknowledge(dp->interrupt);}#define CYGHWR_NS_DP83902A_PLF_INT_CLEAR(dp) _frv400_eth_int_clear(dp)#endif#ifdef CYGPKG_DEVS_ETH_FRV400_ETH0static dp83902a_priv_data_t dp83902a_eth0_priv_data = {     base : (cyg_uint8*) 0,  //    data : (cyg_uint8*) 0,  // Filled in at runtime    reset: (cyg_uint8*) 0,  //    interrupt: 0,           //    tx_buf1: 0x40,          //     tx_buf2: 0x48,          // Buffer layout - change with care    rx_buf_start: 0x50,     //    rx_buf_end: 0x80,       //#ifdef CYGSEM_DEVS_ETH_FRV400_ETH0_SET_ESA    esa : CYGDAT_DEVS_ETH_FRV400_ETH0_ESA,    hardwired_esa : true,#else    hardwired_esa : false,#endif};ETH_DRV_SC(dp83902a_sc,           &dp83902a_eth0_priv_data, // Driver specific data           CYGDAT_DEVS_ETH_FRV400_ETH0_NAME,           dp83902a_start,           dp83902a_stop,           dp83902a_control,           dp83902a_can_send,           dp83902a_send,           dp83902a_recv,           dp83902a_deliver,     // "pseudoDSR" called from fast net thread           dp83902a_poll,        // poll function, encapsulates ISR and DSR           dp83902a_int_vector);NETDEVTAB_ENTRY(dp83902a_netdev,                 "dp83902a_" CYGDAT_DEVS_ETH_FRV400_ETH0_NAME,                dp83902a_init,                 &dp83902a_sc);#endif // CYGPKG_DEVS_ETH_FRV400_ETH0#endif // __WANT_DEVS// --------------------------------------------------------------// EOF devs_eth_frv400.inl

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -