mirror of
https://github.com/pvvx/RTL00MP3.git
synced 2025-01-15 06:45:18 +00:00
167 lines
6.6 KiB
C
167 lines
6.6 KiB
C
/*
|
|
* Routines to access hardware
|
|
*
|
|
* Copyright (c) 2013 Realtek Semiconductor Corp.
|
|
*
|
|
*/
|
|
#ifndef _HAL_API_H_
|
|
#define _HAL_API_H_
|
|
|
|
#include "basic_types.h"
|
|
#include "hal_irqn.h"
|
|
|
|
#define HAL_READ32(base, addr) \
|
|
rtk_le32_to_cpu(*((volatile u32*)(base + addr)))
|
|
|
|
#define HAL_WRITE32(base, addr, value32) \
|
|
((*((volatile u32*)(base + addr))) = rtk_cpu_to_le32(value32))
|
|
|
|
|
|
#define HAL_READ16(base, addr) \
|
|
rtk_le16_to_cpu(*((volatile u16*)(base + addr)))
|
|
|
|
#define HAL_WRITE16(base, addr, value) \
|
|
((*((volatile u16*)(base + addr))) = rtk_cpu_to_le16(value))
|
|
|
|
|
|
#define HAL_READ8(base, addr) \
|
|
(*((volatile u8*)(base + addr)))
|
|
|
|
#define HAL_WRITE8(base, addr, value) \
|
|
((*((volatile u8*)(base + addr))) = value)
|
|
|
|
#if 1
|
|
// These "extern _LONG_CALL_" function declaration are for RAM code building only
|
|
// For ROM code building, thses code should be marked off
|
|
extern _LONG_CALL_ u8
|
|
HalPinCtrlRtl8195A(
|
|
IN u32 Function,
|
|
IN u32 PinLocation,
|
|
IN BOOL Operation
|
|
);
|
|
|
|
extern _LONG_CALL_ VOID
|
|
HalSerialPutcRtl8195a(
|
|
IN u8 c
|
|
);
|
|
|
|
extern _LONG_CALL_ u8
|
|
HalSerialGetcRtl8195a(
|
|
IN BOOL PullMode
|
|
);
|
|
|
|
extern _LONG_CALL_ u32
|
|
HalSerialGetIsrEnRegRtl8195a(VOID);
|
|
|
|
extern _LONG_CALL_ VOID
|
|
HalSerialSetIrqEnRegRtl8195a (
|
|
IN u32 SetValue
|
|
);
|
|
|
|
extern _LONG_CALL_ VOID
|
|
VectorTableInitForOSRtl8195A(
|
|
IN VOID *PortSVC,
|
|
IN VOID *PortPendSVH,
|
|
IN VOID *PortSysTick
|
|
);
|
|
|
|
extern _LONG_CALL_ BOOL
|
|
VectorIrqRegisterRtl8195A(
|
|
IN PIRQ_HANDLE pIrqHandle
|
|
);
|
|
|
|
extern _LONG_CALL_ BOOL
|
|
VectorIrqUnRegisterRtl8195A(
|
|
IN PIRQ_HANDLE pIrqHandle
|
|
);
|
|
|
|
extern _LONG_CALL_ VOID
|
|
VectorIrqEnRtl8195A(
|
|
IN PIRQ_HANDLE pIrqHandle
|
|
);
|
|
|
|
extern _LONG_CALL_ VOID
|
|
VectorIrqDisRtl8195A(
|
|
IN PIRQ_HANDLE pIrqHandle
|
|
);
|
|
|
|
extern _LONG_CALL_ int HalUart0PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalUart1PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalUart2PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalSPI0PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalSPI1PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalSPI2PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalSPI0MCSPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalI2C0PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalI2C1PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalI2C2PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalI2C3PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalI2S0PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalI2S1PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalPCM0PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalPCM1PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalSDIODPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalSDIOHPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalMIIPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalWLLEDPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalWLANT0PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalWLANT1PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalWLBTCOEXPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalWLBTCMDPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalNFCPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalPWM0PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalPWM1PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalPWM2PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalPWM3PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalETE0PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalETE1PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalETE2PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalETE3PinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalEGTIMPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalSPIFlashPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalSDRPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalJTAGPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalTRACEPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalLOGUartPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalLOGUartIRPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalSICPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalEEPROMPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
extern _LONG_CALL_ int HalDEBUGPinCtrlRtl8195A(IN u32 PinLocation, IN BOOL Operation);
|
|
#endif
|
|
|
|
extern BOOLEAN SpicFlashInitRtl8195A(u8 SpicBitMode);
|
|
extern VOID InitWDGIRQ(VOID);
|
|
|
|
#define PinCtrl HalPinCtrlRtl8195A
|
|
|
|
#define DiagPutChar HalSerialPutcRtl8195a
|
|
#define DiagGetChar HalSerialGetcRtl8195a
|
|
#define DiagGetIsrEnReg HalSerialGetIsrEnRegRtl8195a
|
|
#define DiagSetIsrEnReg HalSerialSetIrqEnRegRtl8195a
|
|
|
|
#define InterruptForOSInit VectorTableInitForOSRtl8195A
|
|
#define InterruptRegister VectorIrqRegisterRtl8195A
|
|
#define InterruptUnRegister VectorIrqUnRegisterRtl8195A
|
|
|
|
#define InterruptEn VectorIrqEnRtl8195A
|
|
#define InterruptDis VectorIrqDisRtl8195A
|
|
|
|
#define SpicFlashInit SpicFlashInitRtl8195A
|
|
#define Calibration32k En32KCalibration
|
|
#define WDGInit InitWDGIRQ
|
|
|
|
typedef enum _HAL_Status
|
|
{
|
|
HAL_OK = 0x00,
|
|
HAL_BUSY = 0x01,
|
|
HAL_TIMEOUT = 0x02,
|
|
HAL_ERR_PARA = 0x03, // error with invaild parameters
|
|
HAL_ERR_MEM = 0x04, // error with memory allocation failed
|
|
HAL_ERR_HW = 0x05, // error with hardware error
|
|
|
|
HAL_ERR_UNKNOWN = 0xee // unknown error
|
|
|
|
} HAL_Status;
|
|
|
|
|
|
#endif //_HAL_API_H_
|