mirror of
https://github.com/pvvx/rtl00TstMinAmebaV35a.git
synced 2024-11-25 02:34:15 +00:00
145 lines
3.7 KiB
C
145 lines
3.7 KiB
C
/* mbed Microcontroller Library
|
|
*******************************************************************************
|
|
* Copyright (c) 2014, Realtek Semiconductor Corp.
|
|
* All rights reserved.
|
|
*
|
|
* This module is a confidential and proprietary property of RealTek and
|
|
* possession or use of this module requires written permission of RealTek.
|
|
*******************************************************************************
|
|
*/
|
|
#include "objects.h"
|
|
#include "pinmap.h"
|
|
|
|
//static uint32_t channel_ids[32] = {0};
|
|
|
|
//static gpio_irq_handler irq_handler;
|
|
|
|
#if CONFIG_GPIO_EN
|
|
#include "gpio_irq_api.h"
|
|
#include "gpio_irq_ex_api.h"
|
|
|
|
int gpio_irq_init(gpio_irq_t *obj, PinName pin, gpio_irq_handler handler, uint32_t id)
|
|
{
|
|
uint32_t pin_name;
|
|
|
|
if (pin == NC) return -1;
|
|
|
|
obj->pin = pin;
|
|
pin_name = HAL_GPIO_GetPinName((u32)pin);; // get the IP pin name
|
|
obj->hal_pin.pin_name = pin_name;
|
|
obj->hal_pin.pin_mode = INT_FALLING; // default use Falling trigger
|
|
obj->hal_port_num = HAL_GPIO_GET_PORT_BY_NAME(pin_name);
|
|
obj->hal_pin_num = HAL_GPIO_GET_PIN_BY_NAME(pin_name);
|
|
HAL_GPIO_Irq_Init(&obj->hal_pin);
|
|
HAL_GPIO_UserRegIrq(&obj->hal_pin, (VOID*) handler, (VOID*) id);
|
|
|
|
return 0;
|
|
}
|
|
|
|
void gpio_irq_free(gpio_irq_t *obj)
|
|
{
|
|
HAL_GPIO_UserUnRegIrq(&obj->hal_pin);
|
|
HAL_GPIO_DeInit(&obj->hal_pin);
|
|
}
|
|
|
|
void gpio_irq_set(gpio_irq_t *obj, gpio_irq_event event, uint32_t enable)
|
|
{
|
|
switch((uint32_t)event) {
|
|
case IRQ_RISE:
|
|
obj->hal_pin.pin_mode = INT_RISING;
|
|
break;
|
|
|
|
case IRQ_FALL:
|
|
obj->hal_pin.pin_mode = INT_FALLING;
|
|
break;
|
|
|
|
case IRQ_LOW:
|
|
obj->hal_pin.pin_mode = INT_LOW;
|
|
break;
|
|
|
|
case IRQ_HIGH:
|
|
obj->hal_pin.pin_mode = INT_HIGH;
|
|
break;
|
|
|
|
case IRQ_NONE:
|
|
// ?
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
// HAL_GPIO_Irq_Init(&obj->hal_pin);
|
|
HAL_GPIO_Init_8195a(&obj->hal_pin);
|
|
|
|
HAL_GPIO_IntCtrl(&obj->hal_pin, enable);
|
|
}
|
|
|
|
void gpio_irq_enable(gpio_irq_t *obj)
|
|
{
|
|
HAL_GPIO_UnMaskIrq(&obj->hal_pin);
|
|
}
|
|
|
|
void gpio_irq_disable(gpio_irq_t *obj)
|
|
{
|
|
HAL_GPIO_MaskIrq(&obj->hal_pin);
|
|
}
|
|
|
|
void gpio_irq_deinit(gpio_irq_t *obj)
|
|
{
|
|
HAL_GPIO_DeInit(&obj->hal_pin);
|
|
}
|
|
|
|
void gpio_irq_pull_ctrl(gpio_irq_t *obj, PinMode pull_type)
|
|
{
|
|
HAL_GPIO_PullCtrl((u32) obj->pin, (u32)pull_type);
|
|
}
|
|
|
|
void gpio_irq_set_event(gpio_irq_t *obj, gpio_irq_event event)
|
|
{
|
|
uint32_t reg_value;
|
|
uint32_t level_edge;
|
|
uint32_t polarity;
|
|
uint8_t pin_num;
|
|
|
|
pin_num = obj->hal_pin_num & 0x1f; // Max 31
|
|
|
|
switch (event) {
|
|
case IRQ_LOW:
|
|
level_edge = 0; // level trigger
|
|
polarity = 0; // active low
|
|
break;
|
|
|
|
case IRQ_HIGH:
|
|
level_edge = 0; // level trigger
|
|
polarity = 1; // active high
|
|
break;
|
|
|
|
case IRQ_FALL:
|
|
level_edge = 1; // edge trigger
|
|
polarity = 0; // active low
|
|
break;
|
|
|
|
case IRQ_RISE:
|
|
level_edge = 1; // edge trigger
|
|
polarity = 1; // active high
|
|
break;
|
|
|
|
default:
|
|
DBG_GPIO_ERR("Unknow Interrupt Trigger Type(%d)\n", event);
|
|
return;
|
|
}
|
|
|
|
// Config Level or Edge trigger
|
|
reg_value = HAL_READ32(GPIO_REG_BASE, GPIO_INT_TYPE);
|
|
reg_value &= ~(1 << pin_num);
|
|
reg_value |= (level_edge << pin_num);
|
|
HAL_WRITE32(GPIO_REG_BASE, GPIO_INT_TYPE, reg_value);
|
|
|
|
// Config Low active or Gigh active
|
|
reg_value = HAL_READ32(GPIO_REG_BASE, GPIO_INT_POLARITY);
|
|
reg_value &= ~(1 << pin_num);
|
|
reg_value |= (polarity << pin_num);
|
|
HAL_WRITE32(GPIO_REG_BASE, GPIO_INT_POLARITY, reg_value);
|
|
}
|
|
|
|
#endif
|