mirror of
https://github.com/eggman/ameba-gcc-sample-rtos.git
synced 2024-11-23 04:14:14 +00:00
353 lines
8 KiB
C
353 lines
8 KiB
C
|
/*
|
||
|
* Routines to access hardware
|
||
|
*
|
||
|
* Copyright (c) 2013 Realtek Semiconductor Corp.
|
||
|
*
|
||
|
* This module is a confidential and proprietary property of RealTek and
|
||
|
* possession or use of this module requires written permission of RealTek.
|
||
|
*/
|
||
|
|
||
|
|
||
|
#ifndef _RTL8195A_GPIO_H_
|
||
|
#define _RTL8195A_GPIO_H_
|
||
|
|
||
|
#include "hal_api.h"
|
||
|
#include "hal_gpio.h"
|
||
|
|
||
|
#define GPIO_PORTA_DR 0x00 // data register
|
||
|
#define GPIO_PORTA_DDR 0x04 // data direction
|
||
|
#define GPIO_PORTA_CTRL 0x08 // data source control, we should keep it as default: data source from software
|
||
|
|
||
|
#define GPIO_PORTB_DR 0x0c // data register
|
||
|
#define GPIO_PORTB_DDR 0x10 // data direction
|
||
|
#define GPIO_PORTB_CTRL 0x14 // data source control, we should keep it as default: data source from software
|
||
|
|
||
|
#define GPIO_PORTC_DR 0x18 // data register
|
||
|
#define GPIO_PORTC_DDR 0x1c // data direction
|
||
|
#define GPIO_PORTC_CTRL 0x20 // data source control, we should keep it as default: data source from software
|
||
|
|
||
|
//1 Only the PORTA can be configured to generate interrupts
|
||
|
#define GPIO_INT_EN 0x30 // Interrupt enable register
|
||
|
#define GPIO_INT_MASK 0x34 // Interrupt mask
|
||
|
#define GPIO_INT_TYPE 0x38 // Interrupt type(level/edge) register
|
||
|
#define GPIO_INT_POLARITY 0x3C // Interrupt polarity(Active low/high) register
|
||
|
#define GPIO_INT_STATUS 0x40 // Interrupt status
|
||
|
#define GPIO_INT_RAWSTATUS 0x44 // Interrupt status without mask
|
||
|
#define GPIO_DEBOUNCE 0x48 // Interrupt signal debounce
|
||
|
#define GPIO_PORTA_EOI 0x4c // Clear interrupt
|
||
|
|
||
|
#define GPIO_EXT_PORTA 0x50 // GPIO IN read or OUT read back
|
||
|
#define GPIO_EXT_PORTB 0x54 // GPIO IN read or OUT read back
|
||
|
#define GPIO_EXT_PORTC 0x58 // GPIO IN read or OUT read back
|
||
|
|
||
|
#define GPIO_INT_SYNC 0x60 // Is level-sensitive interrupt being sync sith PCLK
|
||
|
|
||
|
enum {
|
||
|
HAL_GPIO_HIGHZ = 0,
|
||
|
HAL_GPIO_PULL_LOW = 1,
|
||
|
HAL_GPIO_PULL_HIGH = 2
|
||
|
};
|
||
|
|
||
|
//======================================================
|
||
|
// ROM Function prototype
|
||
|
extern PHAL_GPIO_ADAPTER _pHAL_Gpio_Adapter;
|
||
|
|
||
|
static __inline HAL_Status
|
||
|
GPIO_Lock (
|
||
|
VOID
|
||
|
)
|
||
|
{
|
||
|
HAL_Status Status;
|
||
|
|
||
|
if (_pHAL_Gpio_Adapter->EnterCritical) {
|
||
|
_pHAL_Gpio_Adapter->EnterCritical();
|
||
|
}
|
||
|
|
||
|
if(_pHAL_Gpio_Adapter->Locked) {
|
||
|
Status = HAL_BUSY;
|
||
|
}
|
||
|
else {
|
||
|
_pHAL_Gpio_Adapter->Locked = 1;
|
||
|
Status = HAL_OK;
|
||
|
}
|
||
|
|
||
|
if (_pHAL_Gpio_Adapter->ExitCritical) {
|
||
|
_pHAL_Gpio_Adapter->ExitCritical();
|
||
|
}
|
||
|
|
||
|
return Status;
|
||
|
}
|
||
|
|
||
|
|
||
|
static __inline VOID
|
||
|
GPIO_UnLock (
|
||
|
VOID
|
||
|
)
|
||
|
{
|
||
|
if (_pHAL_Gpio_Adapter->EnterCritical) {
|
||
|
_pHAL_Gpio_Adapter->EnterCritical();
|
||
|
}
|
||
|
|
||
|
_pHAL_Gpio_Adapter->Locked = 0;
|
||
|
|
||
|
if (_pHAL_Gpio_Adapter->ExitCritical) {
|
||
|
_pHAL_Gpio_Adapter->ExitCritical();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
_LONG_CALL_ extern u32
|
||
|
HAL_GPIO_IrqHandler_8195a(
|
||
|
IN VOID *pData
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ extern u32
|
||
|
HAL_GPIO_MbedIrqHandler_8195a(
|
||
|
IN VOID *pData
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_IntCtrl_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin,
|
||
|
u32 En
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_Init_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_DeInit_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_GPIO_PIN_STATE
|
||
|
HAL_GPIO_ReadPin_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_WritePin_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin,
|
||
|
HAL_GPIO_PIN_STATE Pin_State
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_RegIrq_8195a(
|
||
|
IN PIRQ_HANDLE pIrqHandle
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_UnRegIrq_8195a(
|
||
|
IN PIRQ_HANDLE pIrqHandle
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_UserRegIrq_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin,
|
||
|
VOID *IrqHandler,
|
||
|
VOID *IrqData
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_UserUnRegIrq_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_MaskIrq_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_UnMaskIrq_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_IntDebounce_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin,
|
||
|
u8 Enable
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ u32
|
||
|
HAL_GPIO_GetIPPinName_8195a(
|
||
|
u32 chip_pin
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ HAL_Status
|
||
|
HAL_GPIO_PullCtrl_8195a(
|
||
|
u32 chip_pin,
|
||
|
u8 pull_type
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ u32
|
||
|
GPIO_GetChipPinName_8195a(
|
||
|
u32 port,
|
||
|
u32 pin
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ VOID
|
||
|
GPIO_PullCtrl_8195a(
|
||
|
u32 chip_pin,
|
||
|
u8 pull_type
|
||
|
);
|
||
|
|
||
|
_LONG_CALL_ VOID
|
||
|
GPIO_Int_SetType_8195a(
|
||
|
u8 pin_num,
|
||
|
u8 int_mode
|
||
|
);
|
||
|
|
||
|
|
||
|
_LONG_CALL_ HAL_Status HAL_GPIO_IntCtrl_8195aV02(HAL_GPIO_PIN *GPIO_Pin, u32 En);
|
||
|
_LONG_CALL_ u32 GPIO_Int_Clear_8195aV02(u32 irq_clr);
|
||
|
|
||
|
HAL_Status
|
||
|
HAL_GPIO_ClearISR_8195a(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
);
|
||
|
|
||
|
|
||
|
/********** HAL In-Line Functions **********/
|
||
|
|
||
|
/**
|
||
|
* @brief De-Initializes a GPIO Pin, reset it as default setting.
|
||
|
*
|
||
|
* @param GPIO_Pin: The data structer which contains the parameters for the GPIO Pin.
|
||
|
*
|
||
|
* @retval HAL_Status
|
||
|
*/
|
||
|
static __inline VOID
|
||
|
HAL_GPIO_DeInit(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
)
|
||
|
{
|
||
|
HAL_GPIO_DeInit_8195a(GPIO_Pin);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @brief Reads the specified input port pin.
|
||
|
*
|
||
|
* @param GPIO_Pin: The data structer which contains the parameters for the GPIO Pin.
|
||
|
*
|
||
|
* @retval The input port pin current status(High or Low).
|
||
|
*/
|
||
|
static __inline s32
|
||
|
HAL_GPIO_ReadPin(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
)
|
||
|
{
|
||
|
return (s32)HAL_GPIO_ReadPin_8195a(GPIO_Pin);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @brief Write the specified output port pin.
|
||
|
*
|
||
|
* @param GPIO_Pin: The data structer which contains the parameters for the GPIO Pin.
|
||
|
*
|
||
|
* @param Pin_State: The state going to be set to the assigned GPIO pin.
|
||
|
*
|
||
|
* @retval None
|
||
|
*/
|
||
|
static __inline VOID
|
||
|
HAL_GPIO_WritePin(
|
||
|
HAL_GPIO_PIN *GPIO_Pin,
|
||
|
u32 Value
|
||
|
)
|
||
|
{
|
||
|
HAL_GPIO_WritePin_8195a(GPIO_Pin, (HAL_GPIO_PIN_STATE)Value);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @brief To register a user interrupt handler for a specified pin
|
||
|
*
|
||
|
* @param GPIO_Pin: The data structer which contains the parameters for the GPIO Pin.
|
||
|
*
|
||
|
* @param IrqHandler: The IRQ handler to be assigned to the specified pin
|
||
|
*
|
||
|
* @param IrqData: The pointer will be pass the the IRQ handler
|
||
|
*
|
||
|
* @retval None
|
||
|
*/
|
||
|
static __inline VOID
|
||
|
HAL_GPIO_UserRegIrq(
|
||
|
HAL_GPIO_PIN *GPIO_Pin,
|
||
|
VOID *IrqHandler,
|
||
|
VOID *IrqData
|
||
|
)
|
||
|
{
|
||
|
HAL_GPIO_UserRegIrq_8195a(GPIO_Pin, IrqHandler, IrqData);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @brief To un-register a user interrupt handler for a specified pin
|
||
|
*
|
||
|
* @param GPIO_Pin: The data structer which contains the parameters for the GPIO Pin.
|
||
|
*
|
||
|
* @retval None
|
||
|
*/
|
||
|
static __inline VOID
|
||
|
HAL_GPIO_UserUnRegIrq(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
)
|
||
|
{
|
||
|
HAL_GPIO_UserUnRegIrq_8195a(GPIO_Pin);
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @brief Enable/Disable GPIO interrupt
|
||
|
*
|
||
|
* @param GPIO_Pin: The data structer which contains the parameters for the GPIO Pin initialization.
|
||
|
*
|
||
|
* @param En: Enable (1) or Disable (0)
|
||
|
*
|
||
|
* @retval HAL_Status
|
||
|
*/
|
||
|
static __inline VOID
|
||
|
HAL_GPIO_IntCtrl(
|
||
|
HAL_GPIO_PIN *GPIO_Pin,
|
||
|
u32 En
|
||
|
)
|
||
|
{
|
||
|
HAL_GPIO_IntCtrl_8195a(GPIO_Pin, En);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @brief Mask the interrupt of a specified pin
|
||
|
*
|
||
|
* @param GPIO_Pin: The data structer which contains the parameters for the GPIO Pin.
|
||
|
*
|
||
|
* @retval None
|
||
|
*/
|
||
|
static __inline VOID
|
||
|
HAL_GPIO_MaskIrq(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
)
|
||
|
{
|
||
|
HAL_GPIO_MaskIrq_8195a(GPIO_Pin);
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @brief UnMask the interrupt of a specified pin
|
||
|
*
|
||
|
* @param GPIO_Pin: The data structer which contains the parameters for the GPIO Pin.
|
||
|
*
|
||
|
* @retval None
|
||
|
*/
|
||
|
static __inline VOID
|
||
|
HAL_GPIO_UnMaskIrq(
|
||
|
HAL_GPIO_PIN *GPIO_Pin
|
||
|
)
|
||
|
{
|
||
|
HAL_GPIO_ClearISR_8195a(GPIO_Pin);
|
||
|
HAL_GPIO_UnMaskIrq_8195a(GPIO_Pin);
|
||
|
}
|
||
|
|
||
|
|
||
|
#endif // end of "#define _RTL8195A_GPIO_H_"
|
||
|
|