Skip to content

Commit

Permalink
drivers: Add interrupt controller API
Browse files Browse the repository at this point in the history
Add intc API header

Signed-off-by: Bjarki Arge Andreasen <[email protected]>
  • Loading branch information
bjarki-andreasen committed Dec 14, 2023
1 parent 00d1450 commit 1b9e4a3
Showing 1 changed file with 196 additions and 0 deletions.
196 changes: 196 additions & 0 deletions include/zephyr/drivers/intc.h
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_ */

0 comments on commit 1b9e4a3

Please sign in to comment.