mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-23 06:17:21 +08:00
157 lines
5.3 KiB
C
157 lines
5.3 KiB
C
|
/*
|
||
|
* @brief LPC8xx INPUT MUX chip driver
|
||
|
*
|
||
|
* @note
|
||
|
* Copyright(C) NXP Semiconductors, 2013
|
||
|
* All rights reserved.
|
||
|
*
|
||
|
* @par
|
||
|
* Software that is described herein is for illustrative purposes only
|
||
|
* which provides customers with programming information regarding the
|
||
|
* LPC products. This software is supplied "AS IS" without any warranties of
|
||
|
* any kind, and NXP Semiconductors and its licensor disclaim any and
|
||
|
* all warranties, express or implied, including all implied warranties of
|
||
|
* merchantability, fitness for a particular purpose and non-infringement of
|
||
|
* intellectual property rights. NXP Semiconductors assumes no responsibility
|
||
|
* or liability for the use of the software, conveys no license or rights under any
|
||
|
* patent, copyright, mask work right, or any other intellectual property rights in
|
||
|
* or to any products. NXP Semiconductors reserves the right to make changes
|
||
|
* in the software without notification. NXP Semiconductors also makes no
|
||
|
* representation or warranty that such application will be suitable for the
|
||
|
* specified use without further testing or modification.
|
||
|
*
|
||
|
* @par
|
||
|
* Permission to use, copy, modify, and distribute this software and its
|
||
|
* documentation is hereby granted, under NXP Semiconductors' and its
|
||
|
* licensor's relevant copyrights in the software, without fee, provided that it
|
||
|
* is used in conjunction with NXP Semiconductors microcontrollers. This
|
||
|
* copyright, permission, and disclaimer notice must appear in all copies of
|
||
|
* this code.
|
||
|
*/
|
||
|
|
||
|
#ifndef __INMUX_8XX_H_
|
||
|
#define __INMUX_8XX_H_
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/** @defgroup INMUX_8XX CHIP: LPC8xx INPUT Mux Controller driver
|
||
|
* @ingroup CHIP_8XX_Drivers
|
||
|
* @{
|
||
|
*/
|
||
|
typedef struct {
|
||
|
__IO uint32_t DMA_INMUX_INMUX[2]; /*!< DMA Trigger Input 20 & 21 PINMUX 0-1 */
|
||
|
__O uint32_t RESERVED[6]; /*!< Reserved; Should not be used */
|
||
|
__IO uint32_t SCT0_INMUX[4]; /*!< Input mux register for SCT0; INPUT0-3 */
|
||
|
} LPC_INMUX_T;
|
||
|
|
||
|
/**
|
||
|
* @brief DMA INPUT MUX Index see Chip_INMUX_SetDMAOTrig()
|
||
|
*/
|
||
|
typedef enum {
|
||
|
DMA_INMUX_0, /*!< MUX for DMA input trigger 20 */
|
||
|
DMA_INMUX_1, /*!< MUX for DMA input trigger 21 */
|
||
|
}DMA_INMUX_T;
|
||
|
|
||
|
/**
|
||
|
* @brief SCT Input Mux Index; See Chip_INMUX_SetSCTInMux()
|
||
|
*/
|
||
|
typedef enum {
|
||
|
SCT_INMUX_0, /*!< Input mux for SCT0; INPUT 0 */
|
||
|
SCT_INMUX_1, /*!< Input mux for SCT0; INPUT 1 */
|
||
|
SCT_INMUX_2, /*!< Input mux for SCT0; INPUT 2 */
|
||
|
SCT_INMUX_3, /*!< Input mux for SCT0; INPUT 3 */
|
||
|
} SCT_INMUX_T;
|
||
|
|
||
|
/**
|
||
|
* @brief SCT INPUT triggers
|
||
|
*/
|
||
|
typedef enum {
|
||
|
SCT_INP_IN0, /*!< SCT0_IN0 selected by Pin Matrix */ /* FIXME: UM hints about changes */
|
||
|
SCT_INP_IN1, /*!< SCT0_IN1 selected by Pin Matrix */
|
||
|
SCT_INP_IN2, /*!< SCT0_IN2 selected by Pin Matrix */
|
||
|
SCT_INP_IN3, /*!< SCT0_IN3 selected by Pin Matrix */
|
||
|
SCT_INP_ADC_THCMP_IRQ, /*!< ADC Threshold compare IRQ */
|
||
|
SCT_INP_ACMP_O, /*!< Analog comparator output */
|
||
|
SCT_INP_ARM_TXEV, /*!< ARM TX Event */
|
||
|
SCT_INP_DEBUG_HALTED, /*!< Debug halted event */
|
||
|
} SCT_INP_T;
|
||
|
|
||
|
/**
|
||
|
* @brief Select a trigger source for a DMA channel
|
||
|
* @param pINMUX : The base of INPUT MUX register block
|
||
|
* @param imux : Index of DMA input mux
|
||
|
* @param ch : DMA channel ID
|
||
|
* @return Nothing
|
||
|
*/
|
||
|
STATIC INLINE void Chip_INMUX_SetDMAOTrig(LPC_INMUX_T *pINMUX, DMA_INMUX_T imux, DMA_CHID_T ch)
|
||
|
{
|
||
|
pINMUX->DMA_INMUX_INMUX[imux] = ch;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @brief Select a trigger source SCT module
|
||
|
* @param pINMUX : The base of INPUT MUX register block
|
||
|
* @param isct : Index of SCT input mux
|
||
|
* @param trig : SCT Input function that will cause the trigger
|
||
|
* @return Nothing
|
||
|
*/
|
||
|
STATIC INLINE void Chip_INMUX_SetSCTInMux(LPC_INMUX_T *pINMUX, SCT_INMUX_T isct, SCT_INP_T trig)
|
||
|
{
|
||
|
pINMUX->SCT0_INMUX[isct] = trig;
|
||
|
}
|
||
|
|
||
|
/** @defgroup DMATRIGMUX_8XX CHIP: LPC8xx DMA trigger selection driver
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @brief DMA trigger pin muxing structure
|
||
|
*/
|
||
|
typedef struct { /*!< DMA trigger pin muxing register structure */
|
||
|
__IO uint32_t DMA_ITRIG_INMUX[MAX_DMA_CHANNEL]; /*!< Trigger input select register for DMA channels */
|
||
|
} LPC_DMATRIGMUX_T;
|
||
|
|
||
|
/* DMA triggers that can mapped to DMA channels */
|
||
|
typedef enum {
|
||
|
DMATRIG_ADC_SEQA_IRQ = 0, /*!< ADC0 sequencer A interrupt as trigger */
|
||
|
DMATRIG_ADC_SEQB_IRQ, /*!< ADC0 sequencer B interrupt as trigger */
|
||
|
DMATRIG_SCT0_DMA0, /*!< SCT 0, DMA 0 as trigger */
|
||
|
DMATRIG_SCT0_DMA1, /*!< SCT 1, DMA 1 as trigger */
|
||
|
DMATRIG_ACMP_O, /*!< Analog comparator output */
|
||
|
DMATRIG_PINT0, /*!< Pin interrupt 0 as trigger */
|
||
|
DMATRIG_PINT1, /*!< Pin interrupt 1 as trigger */
|
||
|
DMATRIG_DMA_INMUX0, /*!< DMA Trigger MUX0 */
|
||
|
DMATRIG_DMA_INMUX1, /*!< DMA Trigger MUX1 */
|
||
|
} DMA_TRIGSRC_T;
|
||
|
|
||
|
/**
|
||
|
* @brief Select a trigger source for a DMA channel
|
||
|
* @param pDMATRIG : The base of DMA trigger setup block on the chip
|
||
|
* @param ch : DMA channel ID
|
||
|
* @param trig : Trigger source for the DMA channel
|
||
|
* @return Nothing
|
||
|
* @note A DMA trigger source only needs to be setup when the DMA is setup
|
||
|
* for hardware trigger mode (when Chip_DMA_SetupChannelConfig() is
|
||
|
* called with DMA_CFG_HWTRIGEN as OR'ed option).
|
||
|
*/
|
||
|
STATIC INLINE void Chip_DMATRIGMUX_SetInputTrig(LPC_DMATRIGMUX_T *pDMATRIG, DMA_CHID_T ch, DMA_TRIGSRC_T trig)
|
||
|
{
|
||
|
pDMATRIG->DMA_ITRIG_INMUX[ch] = (uint32_t) trig;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* __INMUX_8XX_H_ */
|