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

📄 devs_eth_sh_se77x9.inl

📁 eCos操作系统源码
💻 INL
字号:
//==========================================================================////      devs_eth_sh_se77x9.inl////      SE77X9 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// Contributors:jskov// Date:        2001-06-13// Purpose:     SE77X9 ethernet defintions//// FIXME:       M17 contains an EPROM. May contain the ESA, but don't//              know how to access it.////####DESCRIPTIONEND####//==========================================================================#include <cyg/hal/hal_intr.h>           // CYGNUM_HAL_INTERRUPT_ETHR#include <cyg/hal/hal_if.h>#ifdef __WANT_CONFIG#define CYGHWR_NS_DP83902A_PLF_RESET(_dp_)      \    CYG_MACRO_START                             \    HAL_WRITE_UINT16(_dp_->reset, 0x0000);      \    CYGACC_CALL_IF_DELAY_US(10);                \    HAL_WRITE_UINT16(_dp_->reset, 0x0100);      \    CYG_MACRO_END#define DP_IN(_b_, _o_, _d_)                                    \    CYG_MACRO_START                                             \    cyg_uint16 _t;                                              \    HAL_READ_UINT16 ((cyg_addrword_t)(_b_)+2*(_o_), _t);        \    (_d_) = (_t >> 8) & 0xff;                                   \    CYG_MACRO_END#define DP_OUT(_b_, _o_, _d_)                                   \    CYG_MACRO_START                                             \    HAL_WRITE_UINT16((cyg_addrword_t)(_b_)+2*(_o_), (_d_)<<8);  \    CYG_MACRO_END#define DP_IN_DATA(_b_, _d_)                                    \    CYG_MACRO_START                                             \    cyg_uint16 _t;                                              \    HAL_READ_UINT16 ((cyg_addrword_t)(_b_), _t);                \    (_d_) = ((_t >> 8) & 0xff) | ((_t & 0xff) << 8);            \    CYG_MACRO_END#define DP_OUT_DATA(_b_, _d_)                                   \    CYG_MACRO_START                                             \    cyg_uint16 _t;                                              \    _t = (_d_);                                                 \    (_t) = (((_t) >> 8) & 0xff) | ((_t & 0xff) << 8);           \    HAL_WRITE_UINT16((cyg_addrword_t)(_b_), _t);                \    CYG_MACRO_END#define CYGHWR_NS_DP83902A_PLF_16BIT_DATA#define CYGHWR_NS_DP83902A_PLF_BROKEN_TX_DMA#endif // __WANT_CONFIG#ifdef __WANT_DEVS#ifdef CYGPKG_DEVS_ETH_SH_SE77X9_ETH0static dp83902a_priv_data_t dp83902a_eth0_priv_data = {     base : (cyg_uint8*) 0xb0000000,    data : (cyg_uint8*) 0xb0040000,    reset: (cyg_uint8*) 0xb0080000,    interrupt: CYGNUM_HAL_INTERRUPT_LAN,    tx_buf1: 0x80,    tx_buf2: 0x88,    rx_buf_start: 0x90,    rx_buf_end: 0xff,#ifdef CYGSEM_DEVS_ETH_SH_SE77X9_ETH0_SET_ESA    esa : CYGDAT_DEVS_ETH_SH_SE77X9_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_SH_SE77X9_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_SH_SE77X9_ETH0_NAME,                dp83902a_init,                 &dp83902a_sc);#endif // CYGPKG_DEVS_ETH_SH_SE77X9_ETH0#endif // __WANT_DEVS// EOF devs_eth_sh_se77x9.inl

⌨️ 快捷键说明

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