1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/cpu/cc26x0/vendor/inc/hw_aux_anaif.h
2020-11-05 23:25:49 -08:00

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__