/* * 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