-
Notifications
You must be signed in to change notification settings - Fork 6.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
drivers: Add interrupt controller API
Add intc API header Signed-off-by: Bjarki Arge Andreasen <[email protected]>
- Loading branch information
1 parent
00d1450
commit 1b9e4a3
Showing
1 changed file
with
196 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,196 @@ | ||
/* | ||
* Copyright (c) 2023 Bjarki Arge Andreasen | ||
* | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
#ifndef ZEPHYR_INCLUDE_DRIVERS_INTC_H_ | ||
#define ZEPHYR_INCLUDE_DRIVERS_INTC_H_ | ||
|
||
/** | ||
* @brief Interrupt controller cnterface | ||
* @defgroup intc_interface Interrupt controller interface | ||
* @ingroup io_interfaces | ||
* @{ | ||
*/ | ||
|
||
#include <zephyr/device.h> | ||
#include <zephyr/kernel.h> | ||
#include <zephyr/devicetree.h> | ||
#include <zephyr/dt-bindings/interrupt-controller/irq.h> | ||
#include <errno.h> | ||
|
||
#ifdef __cplusplus | ||
extern "C" { | ||
#endif | ||
|
||
/** Interrupt request handle forward declaration */ | ||
struct intc_irq; | ||
|
||
/** Interrupt request handler */ | ||
typedef void (*intc_irq_handler_t)(struct intc_irq *irq); | ||
|
||
/** @cond INTERNAL_HIDDEN */ | ||
|
||
/** Interrupt request specification */ | ||
struct intc_irq_spec { | ||
const struct device *intc; | ||
uint32_t irq; | ||
uint32_t flags; | ||
intc_irq_handler_t handler; | ||
}; | ||
|
||
/** Interrupt request handle */ | ||
struct intc_irq { | ||
/** Interrupt request single-linked list node */ | ||
sys_snode_t node; | ||
/** Interrupt request specification */ | ||
const struct intc_irq_spec *spec; | ||
}; | ||
|
||
/** Request interrupt request API template function */ | ||
typedef int (*intc_api_request_irq)(struct intc_irq *irq); | ||
|
||
/** Set interrupt request priority API template function */ | ||
typedef int (*intc_api_set_irq_priority)(struct intc_irq *irq, uint16_t priority); | ||
|
||
/** Enable interrupt request API template function */ | ||
typedef int (*intc_api_enable_irq)(struct intc_irq *irq); | ||
|
||
/** Disable interrupt request API template function */ | ||
typedef int (*intc_api_disable_irq)(struct intc_irq *irq); | ||
|
||
/** Interrupt request is enabled API template function */ | ||
typedef int (*intc_api_irq_is_enabled)(struct intc_irq *irq); | ||
|
||
/** Release interrupt request API template function */ | ||
typedef int (*intc_api_release_irq)(struct intc_irq *irq); | ||
|
||
/** Interrupt controller API structure */ | ||
struct intc_driver_api { | ||
intc_api_request_irq request_irq; | ||
intc_api_set_irq_priority set_irq_priority; | ||
intc_api_enable_irq enable_irq; | ||
intc_api_disable_irq disable_irq; | ||
intc_api_irq_is_enabled irq_enabled; | ||
intc_api_release_irq release_irq; | ||
}; | ||
|
||
/** @endcond */ | ||
|
||
/** | ||
* @brief Request interrupt request | ||
* | ||
* @param irq Interrupt request handle | ||
* @param spec Interrupt request specification | ||
* | ||
* @note The irq handle and the irq spec must remain valid until released | ||
* | ||
* @retval 0 if successful | ||
* @retval -errno code if failure | ||
*/ | ||
static int intc_request_irq(struct intc_irq *irq, const struct intc_irq_spec *spec) | ||
{ | ||
const struct intc_driver_api *api = | ||
(const struct intc_driver_api *)irq->spec->intc->api; | ||
|
||
irq->spec = spec; | ||
return api->request_irq(irq); | ||
} | ||
|
||
/** | ||
* @brief Set interrupt request priority | ||
* | ||
* @param irq Interrupt request handle | ||
* @param priority Interrupt request priority to set | ||
* | ||
* @retval 0 if successful | ||
* @retval -ENOTSUP if setting interrupt request priority is not supported | ||
* @retval -errno code if failure | ||
*/ | ||
static int intc_set_irq_priority(struct intc_irq *irq, uint16_t priority) | ||
{ | ||
const struct intc_driver_api *api = | ||
(const struct intc_driver_api *)irq->spec->intc->api; | ||
|
||
if (!api->set_irq_priority) { | ||
return -ENOTSUP; | ||
} | ||
|
||
return api->set_irq_priority(irq, priority); | ||
} | ||
|
||
/** | ||
* @brief Enable interrupt request | ||
* | ||
* @param irq Interrupt request handle | ||
* | ||
* @retval 0 if successful | ||
* @retval -errno code if failure | ||
*/ | ||
static int intc_enable_irq(struct intc_irq *irq) | ||
{ | ||
const struct intc_driver_api *api = | ||
(const struct intc_driver_api *)irq->spec->intc->api; | ||
|
||
return api->enable_irq(irq); | ||
} | ||
|
||
/** | ||
* @brief Disable interrupt request | ||
* | ||
* @param irq Interrupt request handle | ||
* | ||
* @retval 0 if successful | ||
* @retval -errno code if failure | ||
*/ | ||
static int intc_disable_irq(struct intc_irq *irq) | ||
{ | ||
const struct intc_driver_api *api = | ||
(const struct intc_driver_api *)irq->spec->intc->api; | ||
|
||
return api->disable_irq(irq); | ||
} | ||
|
||
/** | ||
* @brief Test if interrupt request is enabled | ||
* | ||
* @param irq Interrupt request handle | ||
* | ||
* @retval 1 if interrupt request is enabled | ||
* @retval 0 if interrupt request is disabled | ||
* @retval -errno code if failure | ||
*/ | ||
static int intc_irq_is_enabled(struct intc_irq *irq) | ||
{ | ||
const struct intc_driver_api *api = | ||
(const struct intc_driver_api *)irq->spec->intc->api; | ||
|
||
return api->irq_enabled(irq); | ||
} | ||
|
||
/** | ||
* @brief Release interrupt request | ||
* | ||
* @param irq Interrupt request handle | ||
* | ||
* @retval 0 if successful | ||
* @retval -errno code if failure | ||
*/ | ||
static int intc_release_irq(struct intc_irq *irq) | ||
{ | ||
const struct intc_driver_api *api = | ||
(const struct intc_driver_api *)irq->spec->intc->api; | ||
|
||
return api->release_irq(irq); | ||
} | ||
|
||
#ifdef __cplusplus | ||
} | ||
#endif | ||
|
||
/** | ||
* @} | ||
*/ | ||
|
||
#endif /* ZEPHYR_INCLUDE_DRIVERS_INTC_H_ */ |