mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
306 lines
14 KiB
C
306 lines
14 KiB
C
/******************************************************************************
|
|
* Filename: hw_aux_anaif_h
|
|
* Revised: 2017-05-30 11:42:02 +0200 (Tue, 30 May 2017)
|
|
* Revision: 49074
|
|
*
|
|
* Copyright (c) 2015 - 2017, Texas Instruments Incorporated
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions are met:
|
|
*
|
|
* 1) Redistributions of source code must retain the above copyright notice,
|
|
* this list of conditions and the following disclaimer.
|
|
*
|
|
* 2) Redistributions in binary form must reproduce the above copyright notice,
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
* and/or other materials provided with the distribution.
|
|
*
|
|
* 3) Neither the name of the ORGANIZATION nor the names of its contributors may
|
|
* be used to endorse or promote products derived from this software without
|
|
* specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
******************************************************************************/
|
|
|
|
#ifndef __HW_AUX_ANAIF_H__
|
|
#define __HW_AUX_ANAIF_H__
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// This section defines the register offsets of
|
|
// AUX_ANAIF component
|
|
//
|
|
//*****************************************************************************
|
|
// ADC Control
|
|
#define AUX_ANAIF_O_ADCCTL 0x00000010
|
|
|
|
// ADC FIFO Status
|
|
#define AUX_ANAIF_O_ADCFIFOSTAT 0x00000014
|
|
|
|
// ADC FIFO
|
|
#define AUX_ANAIF_O_ADCFIFO 0x00000018
|
|
|
|
// ADC Trigger
|
|
#define AUX_ANAIF_O_ADCTRIG 0x0000001C
|
|
|
|
// Current Source Control
|
|
#define AUX_ANAIF_O_ISRCCTL 0x00000020
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_ANAIF_O_ADCCTL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [13] START_POL
|
|
//
|
|
// Select active polarity for START_SRC event.
|
|
// ENUMs:
|
|
// FALL Set ADC trigger on falling edge of event source.
|
|
// RISE Set ADC trigger on rising edge of event source.
|
|
#define AUX_ANAIF_ADCCTL_START_POL 0x00002000
|
|
#define AUX_ANAIF_ADCCTL_START_POL_BITN 13
|
|
#define AUX_ANAIF_ADCCTL_START_POL_M 0x00002000
|
|
#define AUX_ANAIF_ADCCTL_START_POL_S 13
|
|
#define AUX_ANAIF_ADCCTL_START_POL_FALL 0x00002000
|
|
#define AUX_ANAIF_ADCCTL_START_POL_RISE 0x00000000
|
|
|
|
// Field: [12:8] START_SRC
|
|
//
|
|
// Select ADC trigger event source from the asynchronous AUX event bus.
|
|
//
|
|
// Set START_SRC to NO_EVENT<n> if you want to trigger the ADC manually through
|
|
// ADCTRIG.START.
|
|
// ENUMs:
|
|
// ADC_IRQ AUX_EVCTL:EVSTAT1.ADC_IRQ
|
|
// MCU_EV AUX_EVCTL:EVSTAT1.MCU_EV
|
|
// ACLK_REF AUX_EVCTL:EVSTAT1.ACLK_REF
|
|
// AUXIO15 AUX_EVCTL:EVSTAT1.AUXIO15
|
|
// AUXIO14 AUX_EVCTL:EVSTAT1.AUXIO14
|
|
// AUXIO13 AUX_EVCTL:EVSTAT1.AUXIO13
|
|
// AUXIO12 AUX_EVCTL:EVSTAT1.AUXIO12
|
|
// AUXIO11 AUX_EVCTL:EVSTAT1.AUXIO11
|
|
// AUXIO10 AUX_EVCTL:EVSTAT1.AUXIO10
|
|
// AUXIO9 AUX_EVCTL:EVSTAT1.AUXIO9
|
|
// AUXIO8 AUX_EVCTL:EVSTAT1.AUXIO8
|
|
// AUXIO7 AUX_EVCTL:EVSTAT1.AUXIO7
|
|
// AUXIO6 AUX_EVCTL:EVSTAT1.AUXIO6
|
|
// AUXIO5 AUX_EVCTL:EVSTAT1.AUXIO5
|
|
// AUXIO4 AUX_EVCTL:EVSTAT1.AUXIO4
|
|
// AUXIO3 AUX_EVCTL:EVSTAT1.AUXIO3
|
|
// AUXIO2 AUX_EVCTL:EVSTAT0.AUXIO2
|
|
// AUXIO1 AUX_EVCTL:EVSTAT0.AUXIO1
|
|
// AUXIO0 AUX_EVCTL:EVSTAT0.AUXIO0
|
|
// AON_PROG_WU AUX_EVCTL:EVSTAT0.AON_PROG_WU
|
|
// AON_SW AUX_EVCTL:EVSTAT0.AON_SW
|
|
// NO_EVENT1 No event.
|
|
// NO_EVENT0 No event.
|
|
// RESERVED1 Reserved - Do not use.
|
|
// RESERVED0 Reserved - Do not use.
|
|
// SMPH_AUTOTAKE_DONE AUX_EVCTL:EVSTAT0.SMPH_AUTOTAKE_DONE
|
|
// TIMER1_EV AUX_EVCTL:EVSTAT0.TIMER1_EV
|
|
// TIMER0_EV AUX_EVCTL:EVSTAT0.TIMER0_EV
|
|
// TDC_DONE AUX_EVCTL:EVSTAT0.TDC_DONE
|
|
// AUX_COMPB AUX_EVCTL:EVSTAT0.AUX_COMPB
|
|
// AUX_COMPA AUX_EVCTL:EVSTAT0.AUX_COMPA
|
|
// RTC_CH2_EV AUX_EVCTL:EVSTAT0.AON_RTC_CH2
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_W 5
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_M 0x00001F00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_S 8
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_ADC_IRQ 0x00001F00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_MCU_EV 0x00001E00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_ACLK_REF 0x00001D00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO15 0x00001C00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO14 0x00001B00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO13 0x00001A00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO12 0x00001900
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO11 0x00001800
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO10 0x00001700
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO9 0x00001600
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO8 0x00001500
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO7 0x00001400
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO6 0x00001300
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO5 0x00001200
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO4 0x00001100
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO3 0x00001000
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO2 0x00000F00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO1 0x00000E00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUXIO0 0x00000D00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AON_PROG_WU 0x00000C00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AON_SW 0x00000B00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_NO_EVENT1 0x00000A00
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_NO_EVENT0 0x00000900
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_RESERVED1 0x00000800
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_RESERVED0 0x00000700
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_SMPH_AUTOTAKE_DONE 0x00000600
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_TIMER1_EV 0x00000500
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_TIMER0_EV 0x00000400
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_TDC_DONE 0x00000300
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUX_COMPB 0x00000200
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_AUX_COMPA 0x00000100
|
|
#define AUX_ANAIF_ADCCTL_START_SRC_RTC_CH2_EV 0x00000000
|
|
|
|
// Field: [1:0] CMD
|
|
//
|
|
// ADC interface command.
|
|
//
|
|
// Non-enumerated values are not supported. The written value is returned when
|
|
// read.
|
|
// ENUMs:
|
|
// FLUSH Flush ADC FIFO.
|
|
//
|
|
// You must set CMD to EN or
|
|
// DIS after flush.
|
|
//
|
|
// System CPU must wait two
|
|
// clock cycles before it sets CMD to EN or DIS.
|
|
// EN Enable ADC interface.
|
|
// DIS Disable ADC interface.
|
|
#define AUX_ANAIF_ADCCTL_CMD_W 2
|
|
#define AUX_ANAIF_ADCCTL_CMD_M 0x00000003
|
|
#define AUX_ANAIF_ADCCTL_CMD_S 0
|
|
#define AUX_ANAIF_ADCCTL_CMD_FLUSH 0x00000003
|
|
#define AUX_ANAIF_ADCCTL_CMD_EN 0x00000001
|
|
#define AUX_ANAIF_ADCCTL_CMD_DIS 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_ANAIF_O_ADCFIFOSTAT
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [4] OVERFLOW
|
|
//
|
|
// FIFO overflow flag.
|
|
//
|
|
// 0: FIFO has not overflowed.
|
|
// 1: FIFO has overflowed, this flag is sticky until you flush the FIFO.
|
|
//
|
|
// When the flag is set, the ADC FIFO write pointer is static. It is not
|
|
// possible to add more samples to the ADC FIFO. Flush FIFO to clear the flag.
|
|
#define AUX_ANAIF_ADCFIFOSTAT_OVERFLOW 0x00000010
|
|
#define AUX_ANAIF_ADCFIFOSTAT_OVERFLOW_BITN 4
|
|
#define AUX_ANAIF_ADCFIFOSTAT_OVERFLOW_M 0x00000010
|
|
#define AUX_ANAIF_ADCFIFOSTAT_OVERFLOW_S 4
|
|
|
|
// Field: [3] UNDERFLOW
|
|
//
|
|
// FIFO underflow flag.
|
|
//
|
|
// 0: FIFO has not underflowed.
|
|
// 1: FIFO has underflowed, this flag is sticky until you flush the FIFO.
|
|
//
|
|
// When the flag is set, the ADC FIFO read pointer is static. Read returns the
|
|
// previous sample that was read. Flush FIFO to clear the flag.
|
|
#define AUX_ANAIF_ADCFIFOSTAT_UNDERFLOW 0x00000008
|
|
#define AUX_ANAIF_ADCFIFOSTAT_UNDERFLOW_BITN 3
|
|
#define AUX_ANAIF_ADCFIFOSTAT_UNDERFLOW_M 0x00000008
|
|
#define AUX_ANAIF_ADCFIFOSTAT_UNDERFLOW_S 3
|
|
|
|
// Field: [2] FULL
|
|
//
|
|
// FIFO full flag.
|
|
//
|
|
// 0: FIFO is not full, there is less than 4 samples in the FIFO.
|
|
// 1: FIFO is full, there are 4 samples in the FIFO.
|
|
//
|
|
// When the flag is set, it is not possible to add more samples to the ADC
|
|
// FIFO. An attempt to add samples sets the OVERFLOW flag.
|
|
#define AUX_ANAIF_ADCFIFOSTAT_FULL 0x00000004
|
|
#define AUX_ANAIF_ADCFIFOSTAT_FULL_BITN 2
|
|
#define AUX_ANAIF_ADCFIFOSTAT_FULL_M 0x00000004
|
|
#define AUX_ANAIF_ADCFIFOSTAT_FULL_S 2
|
|
|
|
// Field: [1] ALMOST_FULL
|
|
//
|
|
// FIFO almost full flag.
|
|
//
|
|
// 0: There are less than 3 samples in the FIFO, or the FIFO is full. The FULL
|
|
// flag is also asserted in the latter case.
|
|
// 1: There are 3 samples in the FIFO, there is room for one more sample.
|
|
#define AUX_ANAIF_ADCFIFOSTAT_ALMOST_FULL 0x00000002
|
|
#define AUX_ANAIF_ADCFIFOSTAT_ALMOST_FULL_BITN 1
|
|
#define AUX_ANAIF_ADCFIFOSTAT_ALMOST_FULL_M 0x00000002
|
|
#define AUX_ANAIF_ADCFIFOSTAT_ALMOST_FULL_S 1
|
|
|
|
// Field: [0] EMPTY
|
|
//
|
|
// FIFO empty flag.
|
|
//
|
|
// 0: FIFO contains one or more samples.
|
|
// 1: FIFO is empty.
|
|
//
|
|
// When the flag is set, read returns the previous sample that was read and
|
|
// sets the UNDERFLOW flag.
|
|
#define AUX_ANAIF_ADCFIFOSTAT_EMPTY 0x00000001
|
|
#define AUX_ANAIF_ADCFIFOSTAT_EMPTY_BITN 0
|
|
#define AUX_ANAIF_ADCFIFOSTAT_EMPTY_M 0x00000001
|
|
#define AUX_ANAIF_ADCFIFOSTAT_EMPTY_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_ANAIF_O_ADCFIFO
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [11:0] DATA
|
|
//
|
|
// FIFO data.
|
|
//
|
|
// Read:
|
|
// Get oldest ADC sample from FIFO.
|
|
//
|
|
// Write:
|
|
// Write dummy sample to FIFO. This is useful for code development when you do
|
|
// not have real ADC samples.
|
|
#define AUX_ANAIF_ADCFIFO_DATA_W 12
|
|
#define AUX_ANAIF_ADCFIFO_DATA_M 0x00000FFF
|
|
#define AUX_ANAIF_ADCFIFO_DATA_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_ANAIF_O_ADCTRIG
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] START
|
|
//
|
|
// Manual ADC trigger.
|
|
//
|
|
// 0: No effect.
|
|
// 1: Single ADC trigger.
|
|
//
|
|
// To manually trigger the ADC, you must set ADCCTL.START_SRC to NO_EVENT<n> to
|
|
// avoid conflict with event-driven ADC trigger.
|
|
#define AUX_ANAIF_ADCTRIG_START 0x00000001
|
|
#define AUX_ANAIF_ADCTRIG_START_BITN 0
|
|
#define AUX_ANAIF_ADCTRIG_START_M 0x00000001
|
|
#define AUX_ANAIF_ADCTRIG_START_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_ANAIF_O_ISRCCTL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] RESET_N
|
|
//
|
|
// ISRC reset control.
|
|
//
|
|
// 0: ISRC drives 0 uA.
|
|
// 1: ISRC drives current ADI_4_AUX:ISRC.TRIM to COMPA_IN.
|
|
#define AUX_ANAIF_ISRCCTL_RESET_N 0x00000001
|
|
#define AUX_ANAIF_ISRCCTL_RESET_N_BITN 0
|
|
#define AUX_ANAIF_ISRCCTL_RESET_N_M 0x00000001
|
|
#define AUX_ANAIF_ISRCCTL_RESET_N_S 0
|
|
|
|
|
|
#endif // __AUX_ANAIF__
|