mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 19:32:46 +01:00
cde8ac6093
The NXP QN908x CPU family is a Cortex-M4F CPU with integrated USB, Bluetooth Low Energy and in some variants NFC. This patch implements the first steps for having support for this CPU. While the QN908x can be considered the successor of similar chips from NXP like the KW41Z when looking at the feature set, the internal architecture, boot image format and CPU peripherals don't match those in the Kinetis line. Therefore, this patch creates a new directory for just the QN908x chip under cpu/qn908x. The minimal set of peripherals are implemented in this patch to allow the device to boot and enable a GPIO: the gpio and wdt peripheral modules only. The wdt driver is required to boot and disable the wdt. On reset, the wdt is disabled by the chip, however the QN908x bootloader stored in the internal ROM enables the wdt and sets a timer to reboot after 10 seconds, therefore it is needed to disable the wdt in RIOT OS soon after booting. This patch sets it up such that when no periph_wdt module is used the Watchdog is disabled, but if the periph_wdt is used it must be configured (initialized) within the first 10 seconds. Tests performed: Defined a custom board for this CPU and compiled a simple application that blinks some LEDs. Manually tested with periph_wdt and with periph_wdt_cb as well.
119 lines
3.8 KiB
C
119 lines
3.8 KiB
C
/*
|
|
* Copyright (C) 2020 iosabi
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
* details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup cpu_qn908x
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Interrupt service routine declarations NXP QN908x MCUs
|
|
*
|
|
* @author iosabi <iosabi@protonmail.com>
|
|
*
|
|
* @}
|
|
*/
|
|
|
|
#ifndef VECTORS_QN908X_H
|
|
#define VECTORS_QN908X_H
|
|
|
|
#include <stdint.h>
|
|
#include "vectors_cortexm.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Dummy handler
|
|
*/
|
|
void dummy_handler(void);
|
|
|
|
/* Device specific interrupt vectors */
|
|
void isr_ext_gpio_wakeup(void); /**< Ext GPIO wakeup */
|
|
void isr_osc(void); /**< BLE wakeup */
|
|
void isr_acmp0(void); /**< Analog comparator0 */
|
|
void isr_acmp1(void); /**< Analog comparator1 */
|
|
void isr_rtc_sec(void); /**< RTC second */
|
|
void isr_rtc_fr(void); /**< RTC free running */
|
|
void isr_cs_wakeup(void); /**< Capacitive sense wakeup */
|
|
void isr_cs(void); /**< Capacitive sense */
|
|
void isr_gpioa(void); /**< GPIO group A */
|
|
void isr_gpiob(void); /**< GPIO group B */
|
|
void isr_dma0(void); /**< DMA controller */
|
|
void isr_pin_int0(void); /**< pin or pattern match engine slice 0 */
|
|
void isr_pin_int1(void); /**< pin or pattern match engine slice 1 */
|
|
void isr_pin_int2(void); /**< pin or pattern match engine slice 2 */
|
|
void isr_pin_int3(void); /**< pin or pattern match engine slice 3 */
|
|
void isr_osc_int_low(void); /**< Inverse of OSC */
|
|
void isr_usb0(void); /**< USB device */
|
|
void isr_flexcomm0(void); /**< Flexcomm Interface 0 (USART) */
|
|
void isr_flexcomm1(void); /**< Flexcomm Interface 1 (USART, I2C) */
|
|
void isr_flexcomm2(void); /**< Flexcomm Interface 2 (SPI, I2C) */
|
|
void isr_flexcomm3(void); /**< Flexcomm Interface 3 (SPI) */
|
|
void isr_ble(void); /**< BLE interrupts */
|
|
void isr_fsp(void); /**< FSP */
|
|
void isr_qdec0(void); /**< QDEC0 */
|
|
void isr_qdec1(void); /**< QDEC1 */
|
|
void isr_ctimer0(void); /**< Standard counter/timer CTIMER0 */
|
|
void isr_ctimer1(void); /**< Standard counter/timer CTIMER1 */
|
|
void isr_ctimer2(void); /**< Standard counter/timer CTIMER2 */
|
|
void isr_ctimer3(void); /**< Standard counter/timer CTIMER3 */
|
|
void isr_wdt(void); /**< Watch dog timer */
|
|
void isr_adc(void); /**< ADC */
|
|
void isr_dac(void); /**< DAC */
|
|
void isr_xtal_ready(void); /**< High frequency crystal ready */
|
|
void isr_flash(void); /**< Flash */
|
|
void isr_spifi0(void); /**< SPI flash interface */
|
|
void isr_sct0(void); /**< SCTimer/PWM */
|
|
void isr_rng(void); /**< Random number generator */
|
|
void isr_calib(void); /**< Calibration */
|
|
void isr_ble_tx(void); /**< ble tx flag */
|
|
void isr_ble_rx(void); /**< ble rx flag */
|
|
void isr_ble_freq_hop(void); /**< ble frequency hop */
|
|
void isr_bod(void); /**< Brown out detect */
|
|
|
|
/**
|
|
* @{
|
|
* @brief In-System Programming configuration field
|
|
*
|
|
* After the interrupt vectors, at address 0x110 there's a ISP
|
|
* (In-System Programming) configuration field. Define isp_configuration to
|
|
* any | combination of the following `QN908X_ISP_*` values to change the ISP
|
|
* allowed options.
|
|
*/
|
|
__attribute__((section(".vectors.100")))
|
|
extern const uint32_t isp_configuration;
|
|
|
|
/**
|
|
* @brief SMART write enabled to ISP
|
|
*/
|
|
#define QN908X_ISP_SMART_EN 0x80
|
|
|
|
/**
|
|
* @brief SMART USB disabled to ISP
|
|
*/
|
|
#define QN908X_ISP_USB_DIS 0x20
|
|
|
|
/**
|
|
* @brief SMART UART disabled to ISP
|
|
*/
|
|
#define QN908X_ISP_UART_DIS 0x08
|
|
|
|
/**
|
|
* @brief SMART SPI disabled to ISP
|
|
*/
|
|
#define QN908X_ISP_SPI_DIS 0x02
|
|
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
} /* extern "C" */
|
|
#endif
|
|
|
|
#endif /* VECTORS_QN908X_H */
|