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

📄 swreg.h

📁 source code of armboot for s3c4510
💻 H
字号:
/*
 * Copyright (c) 1996, 2003 VIA Networking Technologies, Inc.
 * All rights reserved.
 *
 * This software is copyrighted by and is the sole property of
 * VIA Networking Technologies, Inc. This software may only be used
 * in accordance with the corresponding license agreement. Any unauthorized
 * use, duplication, transmission, distribution, or disclosure of this
 * software is expressly forbidden.
 *
 * This software is provided by VIA Networking Technologies, Inc. "as is"
 * and any express or implied warranties, including, but not limited to, the
 * implied warranties of merchantability and fitness for a particular purpose
 * are disclaimed. In no event shall VIA Networking Technologies, Inc.
 * be liable for any direct, indirect, incidental, special, exemplary, or
 * consequential damages.
 *
 *
 * File:    swreg.h
 *
 * Purpose: Switch register hardware accessing functions
 *
 * Author:  Tevin Chen
 *
 * Date:    Nov 18, 2005
 *
 */


#ifndef __SWREG_H__
#define __SWREG_H__


#if !defined(__TTYPE_H__)
#include "ttype.h"
#endif
#if !defined(__SWCFG_H__)
#include "swcfg.h"
#endif
#if !defined(__SWITCH_H__)
#include "switch.h"
#endif


/*---------------------  Static Definitions  ------------------------*/
#define MAC_ADDR_SIZE               6

/*---------------------  Export Definitions -------------------------*/
#define MAX_LOOP_TIMEOUT        0x162F  // Write module card's EEPROM should delay time

/*---------------------  Export Types  ------------------------------*/

/*---------------------  Export Macros ------------------------------*/
#if 0
#define SWREG_vSpecBitOn(u16Addr, u8BitId)        \
    SWREG_vBitsOnU8((UINT16)((u16Addr) + ((u8BitId) / 8)), (UINT8)(0x01 << ((u8BitId) % 8)))
#define SWREG_vSpecBitOff(u16Addr, u8BitId)       \
    SWREG_vBitsOffU8((UINT16)((u16Addr) + ((u8BitId) / 8)), (UINT8)(0x01 << ((u8BitId) % 8)))

#define SWREG_vIsSpecBitOn(u16Addr, u8BitId)      \
    SWREG_bIsBitsOnU8((UINT16)((u16Addr) + ((u8BitId) / 8)), (UINT8)(0x01 << ((u8BitId) % 8)))
#define SWREG_vIsSpecBitOff(u16Addr, u8BitId)     \
    SWREG_bIsBitsOffU8((UINT16)((u16Addr) + ((u8BitId) / 8)), (UINT8)(0x01 << ((u8BitId) % 8)))
#endif
/*---------------------  Export Classes  ----------------------------*/

/*---------------------  Export Variables  --------------------------*/
//extern  volatile UINT8 sg_pioCpuPktData[];
#ifndef __CPU_80390
extern  volatile UINT8 sg_pioModuleAddr[];
#endif
/*---------------------  Export Functions  --------------------------*/
void SWREG_vReadU8(UINT16 u16Addr, PUINT8 pu8Data) ;
void SWREG_vWriteU8(UINT16 u16Addr, UINT8 u8Data) ;

void SWREG_vReadU16(UINT16 u16Addr, PUINT16 pu16Data) ;
void SWREG_vWriteU16(UINT16 u16Addr, UINT16 u16Data) ;

void SWREG_vReadU32(UINT16 u16Addr, PUINT32 pu32Data) ;
void SWREG_vWriteU32(UINT16 u16Addr, UINT32 u32Data) ;

void SWREG_vBitsOnU8(UINT16 u16Addr, UINT8 u8BitPtn) ;
void SWREG_vBitsOffU8(UINT16 u16Addr, UINT8 u8BitPtn) ;

BOOL SWREG_bIsBitsOnU8(UINT16 u16Addr, UINT8 u8BitPtn) ;
BOOL SWREG_bIsBitsOffU8(UINT16 u16Addr, UINT8 u8BitPtn) ;

BOOL SWREG_bWaitStatus(UINT16 u16Addr, UINT8 u8StsBitPtn, BOOL bWaitCond) ;

// access long data bits, using byte array data structure
void SWREG_vReadU64(UINT16 u16Addr, PUINT8 pu8Data) ;
void SWREG_vWriteU64(UINT16 u16Addr, PUINT8 pu8Data) ;

void SWREG_vReadU128(UINT16 u16Addr, PUINT8 pu8Data) ;
void SWREG_vWriteU128(UINT16 u16Addr, PUINT8 pu8Data) ;




#endif /* __SWREG_H__ */

⌨️ 快捷键说明

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