/*
* Copyright (C) 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef _EXTI_H_
#define _EXTI_H_
#include <isr.h>
#include <stdbool.h>
#include <plat/inc/cmsis.h>
#include <plat/inc/gpio.h>
#include <gpio.h>
#ifdef __cplusplus
extern "C" {
#endif
enum ExtiTrigger
{
EXTI_TRIGGER_RISING = 0,
EXTI_TRIGGER_FALLING,
EXTI_TRIGGER_BOTH,
};
enum ExtiLine
{
EXTI_LINE_P0 = 0,
EXTI_LINE_P1,
EXTI_LINE_P2,
EXTI_LINE_P3,
EXTI_LINE_P4,
EXTI_LINE_P5,
EXTI_LINE_P6,
EXTI_LINE_P7,
EXTI_LINE_P8,
EXTI_LINE_P9,
EXTI_LINE_P10,
EXTI_LINE_P11,
EXTI_LINE_P12,
EXTI_LINE_P13,
EXTI_LINE_P14,
EXTI_LINE_P15,
EXTI_LINE_PVD = 16,
EXTI_LINE_RTC_ALARM = 17,
EXTI_LINE_USB_OTG_FS_WKUP = 18,
EXTI_LINE_RTC_TAMPER_TS = 21,
EXTI_LINE_RTC_WKUP = 22,
};
void extiEnableIntLine(const enum ExtiLine line, enum ExtiTrigger trigger);
void extiDisableIntLine(const enum ExtiLine line);
bool extiIsPendingLine(const enum ExtiLine line);
void extiClearPendingLine(const enum ExtiLine line);
int extiChainIsr(IRQn_Type n, struct ChainedIsr *isr);
int extiUnchainIsr(IRQn_Type n, struct ChainedIsr *isr);
int extiUnchainAll(uint32_t tid);
static inline void extiEnableIntGpio(const struct Gpio *__restrict gpioHandle, enum ExtiTrigger trigger)
{
if (gpioHandle) {
uint32_t gpioNum = (uint32_t)gpioHandle - GPIO_HANDLE_OFFSET;
extiEnableIntLine(gpioNum & GPIO_PIN_MASK, trigger);
}
}
static inline void extiDisableIntGpio(const struct Gpio *__restrict gpioHandle)
{
if (gpioHandle) {
uint32_t gpioNum = (uint32_t)gpioHandle - GPIO_HANDLE_OFFSET;
extiDisableIntLine(gpioNum & GPIO_PIN_MASK);
}
}
static inline bool extiIsPendingGpio(const struct Gpio *__restrict gpioHandle)
{
if (gpioHandle) {
uint32_t gpioNum = (uint32_t)gpioHandle - GPIO_HANDLE_OFFSET;
return extiIsPendingLine(gpioNum & GPIO_PIN_MASK);
}
return false;
}
static inline void extiClearPendingGpio(const struct Gpio *__restrict gpioHandle)
{
if (gpioHandle) {
uint32_t gpioNum = (uint32_t)gpioHandle - GPIO_HANDLE_OFFSET;
extiClearPendingLine(gpioNum & GPIO_PIN_MASK);
}
}
#ifdef __cplusplus
}
#endif
#endif