mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 03:32:49 +01:00
7db791476e
Signed-off-by: Jean Pierre Dudey <me@jeandudey.tech>
695 lines
36 KiB
C
695 lines
36 KiB
C
/******************************************************************************
|
|
* Filename: hw_aux_tdc_h
|
|
* Revised: 2017-05-16 19:35:21 +0200 (Tue, 16 May 2017)
|
|
* Revision: 49005
|
|
*
|
|
* 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_TDC_H__
|
|
#define __HW_AUX_TDC_H__
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// This section defines the register offsets of
|
|
// AUX_TDC component
|
|
//
|
|
//*****************************************************************************
|
|
// Control
|
|
#define AUX_TDC_O_CTL 0x00000000
|
|
|
|
// Status
|
|
#define AUX_TDC_O_STAT 0x00000004
|
|
|
|
// Result
|
|
#define AUX_TDC_O_RESULT 0x00000008
|
|
|
|
// Saturation Configuration
|
|
#define AUX_TDC_O_SATCFG 0x0000000C
|
|
|
|
// Trigger Source
|
|
#define AUX_TDC_O_TRIGSRC 0x00000010
|
|
|
|
// Trigger Counter
|
|
#define AUX_TDC_O_TRIGCNT 0x00000014
|
|
|
|
// Trigger Counter Load
|
|
#define AUX_TDC_O_TRIGCNTLOAD 0x00000018
|
|
|
|
// Trigger Counter Configuration
|
|
#define AUX_TDC_O_TRIGCNTCFG 0x0000001C
|
|
|
|
// Prescaler Control
|
|
#define AUX_TDC_O_PRECTL 0x00000020
|
|
|
|
// Prescaler Counter
|
|
#define AUX_TDC_O_PRECNT 0x00000024
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_TDC_O_CTL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [1:0] CMD
|
|
//
|
|
// TDC commands.
|
|
// ENUMs:
|
|
// ABORT Force TDC state machine back to IDLE state.
|
|
//
|
|
// Never write this command
|
|
// while AUX_TDC:STAT.STATE equals CLR_CNT or
|
|
// WAIT_CLR_CNT_DONE.
|
|
// RUN Asynchronous counter start.
|
|
//
|
|
// The counter starts to
|
|
// count when the start event is high. To achieve
|
|
// precise edge-to-edge measurements you must
|
|
// ensure that the start event is low for at least
|
|
// 420 ns after you write this command.
|
|
// RUN_SYNC_START Synchronous counter start.
|
|
//
|
|
// The counter looks for the
|
|
// opposite edge of the selected start event
|
|
// before it starts to count when the selected
|
|
// edge occurs. This guarantees an edge-triggered
|
|
// start and is recommended for frequency
|
|
// measurements.
|
|
// CLR_RESULT Clear STAT.SAT, STAT.DONE, and RESULT.VALUE.
|
|
//
|
|
// This is not needed as
|
|
// prerequisite for a measurement. Reliable clear
|
|
// is only guaranteed from IDLE state.
|
|
#define AUX_TDC_CTL_CMD_W 2
|
|
#define AUX_TDC_CTL_CMD_M 0x00000003
|
|
#define AUX_TDC_CTL_CMD_S 0
|
|
#define AUX_TDC_CTL_CMD_ABORT 0x00000003
|
|
#define AUX_TDC_CTL_CMD_RUN 0x00000002
|
|
#define AUX_TDC_CTL_CMD_RUN_SYNC_START 0x00000001
|
|
#define AUX_TDC_CTL_CMD_CLR_RESULT 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_TDC_O_STAT
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7] SAT
|
|
//
|
|
// TDC measurement saturation flag.
|
|
//
|
|
// 0: Conversion has not saturated.
|
|
// 1: Conversion stopped due to saturation.
|
|
//
|
|
// This field is cleared when a new measurement is started or when CLR_RESULT
|
|
// is written to CTL.CMD.
|
|
#define AUX_TDC_STAT_SAT 0x00000080
|
|
#define AUX_TDC_STAT_SAT_BITN 7
|
|
#define AUX_TDC_STAT_SAT_M 0x00000080
|
|
#define AUX_TDC_STAT_SAT_S 7
|
|
|
|
// Field: [6] DONE
|
|
//
|
|
// TDC measurement complete flag.
|
|
//
|
|
// 0: TDC measurement has not yet completed.
|
|
// 1: TDC measurement has completed.
|
|
//
|
|
// This field clears when a new TDC measurement starts or when you write
|
|
// CLR_RESULT to CTL.CMD.
|
|
#define AUX_TDC_STAT_DONE 0x00000040
|
|
#define AUX_TDC_STAT_DONE_BITN 6
|
|
#define AUX_TDC_STAT_DONE_M 0x00000040
|
|
#define AUX_TDC_STAT_DONE_S 6
|
|
|
|
// Field: [5:0] STATE
|
|
//
|
|
// TDC state machine status.
|
|
// ENUMs:
|
|
// FORCE_STOP Current state is TDC_FORCESTOP.
|
|
// You wrote ABORT to
|
|
// CTL.CMD to abort the TDC measurement.
|
|
// START_FALL Current state is TDC_WAIT_STARTFALL.
|
|
// The fast-counter circuit
|
|
// waits for a falling edge on the start event.
|
|
// WAIT_CLR_CNT_DONE Current state is TDC_STATE_WAIT_CLRCNT_DONE.
|
|
// The state machine waits
|
|
// for fast-counter circuit to finish reset.
|
|
// POR Current state is TDC_STATE_POR.
|
|
// This is the reset state.
|
|
// GET_RESULT Current state is TDC_STATE_GETRESULTS.
|
|
// The state machine copies
|
|
// the counter value from the fast-counter
|
|
// circuit.
|
|
// WAIT_STOP_CNTDWN Current state is TDC_STATE_WAIT_STOPCNTDOWN.
|
|
// The fast-counter circuit
|
|
// looks for the stop condition. It will ignore a
|
|
// number of stop events configured in
|
|
// TRIGCNTLOAD.CNT.
|
|
// WAIT_STOP Current state is TDC_STATE_WAIT_STOP.
|
|
// The state machine waits
|
|
// for the fast-counter circuit to stop.
|
|
// CLR_CNT Current state is TDC_STATE_CLRCNT. The
|
|
// fast-counter circuit is reset.
|
|
// IDLE Current state is TDC_STATE_IDLE.
|
|
// This is the default state
|
|
// after reset and abortion. State will change
|
|
// when you write CTL.CMD to either RUN_SYNC_START
|
|
// or RUN.
|
|
// WAIT_START_STOP_CNT_EN Current state is TDC_STATE_WAIT_STARTSTOPCNTEN.
|
|
// The fast-counter circuit
|
|
// looks for the start condition. The state
|
|
// machine waits for the fast-counter to
|
|
// increment.
|
|
// WAIT_START Current state is TDC_STATE_WAIT_START.
|
|
// The fast-counter circuit
|
|
// looks for the start condition. The state
|
|
// machine waits for the fast-counter to
|
|
// increment.
|
|
#define AUX_TDC_STAT_STATE_W 6
|
|
#define AUX_TDC_STAT_STATE_M 0x0000003F
|
|
#define AUX_TDC_STAT_STATE_S 0
|
|
#define AUX_TDC_STAT_STATE_FORCE_STOP 0x0000002E
|
|
#define AUX_TDC_STAT_STATE_START_FALL 0x0000001E
|
|
#define AUX_TDC_STAT_STATE_WAIT_CLR_CNT_DONE 0x00000016
|
|
#define AUX_TDC_STAT_STATE_POR 0x0000000F
|
|
#define AUX_TDC_STAT_STATE_GET_RESULT 0x0000000E
|
|
#define AUX_TDC_STAT_STATE_WAIT_STOP_CNTDWN 0x0000000C
|
|
#define AUX_TDC_STAT_STATE_WAIT_STOP 0x00000008
|
|
#define AUX_TDC_STAT_STATE_CLR_CNT 0x00000007
|
|
#define AUX_TDC_STAT_STATE_IDLE 0x00000006
|
|
#define AUX_TDC_STAT_STATE_WAIT_START_STOP_CNT_EN 0x00000004
|
|
#define AUX_TDC_STAT_STATE_WAIT_START 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_TDC_O_RESULT
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [24:0] VALUE
|
|
//
|
|
// TDC conversion result.
|
|
//
|
|
// The result of the TDC conversion is given in number of clock edges of the
|
|
// clock source selected in DDI_0_OSC:CTL0.ACLK_TDC_SRC_SEL. Both rising and
|
|
// falling edges are counted.
|
|
//
|
|
// If TDC counter saturates, VALUE is slightly higher than SATCFG.LIMIT, as it
|
|
// takes a non-zero time to stop the measurement. Hence, the maximum value of
|
|
// this field becomes slightly higher than 2^24 if you configure SATCFG.LIMIT
|
|
// to R24.
|
|
#define AUX_TDC_RESULT_VALUE_W 25
|
|
#define AUX_TDC_RESULT_VALUE_M 0x01FFFFFF
|
|
#define AUX_TDC_RESULT_VALUE_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_TDC_O_SATCFG
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [3:0] LIMIT
|
|
//
|
|
// Saturation limit.
|
|
//
|
|
// The flag STAT.SAT is set when the TDC counter saturates.
|
|
//
|
|
// Values not enumerated are not supported
|
|
// ENUMs:
|
|
// R24 Result bit 24: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[24] is set.
|
|
// R23 Result bit 23: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[23] is set.
|
|
// R22 Result bit 22: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[22] is set.
|
|
// R21 Result bit 21: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[21] is set.
|
|
// R20 Result bit 20: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[20] is set.
|
|
// R19 Result bit 19: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[19] is set.
|
|
// R18 Result bit 18: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[18] is set.
|
|
// R17 Result bit 17: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[17] is set.
|
|
// R16 Result bit 16: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[16] is set.
|
|
// R15 Result bit 15: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[15] is set.
|
|
// R14 Result bit 14: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[14] is set.
|
|
// R13 Result bit 13: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[13] is set.
|
|
// R12 Result bit 12: TDC conversion saturates and stops
|
|
// when RESULT.VALUE[12] is set.
|
|
#define AUX_TDC_SATCFG_LIMIT_W 4
|
|
#define AUX_TDC_SATCFG_LIMIT_M 0x0000000F
|
|
#define AUX_TDC_SATCFG_LIMIT_S 0
|
|
#define AUX_TDC_SATCFG_LIMIT_R24 0x0000000F
|
|
#define AUX_TDC_SATCFG_LIMIT_R23 0x0000000E
|
|
#define AUX_TDC_SATCFG_LIMIT_R22 0x0000000D
|
|
#define AUX_TDC_SATCFG_LIMIT_R21 0x0000000C
|
|
#define AUX_TDC_SATCFG_LIMIT_R20 0x0000000B
|
|
#define AUX_TDC_SATCFG_LIMIT_R19 0x0000000A
|
|
#define AUX_TDC_SATCFG_LIMIT_R18 0x00000009
|
|
#define AUX_TDC_SATCFG_LIMIT_R17 0x00000008
|
|
#define AUX_TDC_SATCFG_LIMIT_R16 0x00000007
|
|
#define AUX_TDC_SATCFG_LIMIT_R15 0x00000006
|
|
#define AUX_TDC_SATCFG_LIMIT_R14 0x00000005
|
|
#define AUX_TDC_SATCFG_LIMIT_R13 0x00000004
|
|
#define AUX_TDC_SATCFG_LIMIT_R12 0x00000003
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_TDC_O_TRIGSRC
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [13] STOP_POL
|
|
//
|
|
// Polarity of stop source.
|
|
//
|
|
// Change only while STAT.STATE is IDLE.
|
|
// ENUMs:
|
|
// LOW TDC conversion stops when low level is detected.
|
|
// HIGH TDC conversion stops when high level is detected.
|
|
#define AUX_TDC_TRIGSRC_STOP_POL 0x00002000
|
|
#define AUX_TDC_TRIGSRC_STOP_POL_BITN 13
|
|
#define AUX_TDC_TRIGSRC_STOP_POL_M 0x00002000
|
|
#define AUX_TDC_TRIGSRC_STOP_POL_S 13
|
|
#define AUX_TDC_TRIGSRC_STOP_POL_LOW 0x00002000
|
|
#define AUX_TDC_TRIGSRC_STOP_POL_HIGH 0x00000000
|
|
|
|
// Field: [12:8] STOP_SRC
|
|
//
|
|
// Select stop source from the asynchronous AUX event bus.
|
|
//
|
|
// Change only while STAT.STATE is IDLE.
|
|
// ENUMs:
|
|
// TDC_PRE Select TDC Prescaler event which is generated by
|
|
// configuration of PRECTL.
|
|
// 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
|
|
// OBSMUX1 AUX_EVCTL:EVSTAT0.OBSMUX1
|
|
// OBSMUX0 AUX_EVCTL:EVSTAT0.OBSMUX0
|
|
// ADC_FIFO_ALMOST_FULL AUX_EVCTL:EVSTAT0.ADC_FIFO_ALMOST_FULL
|
|
// ADC_DONE AUX_EVCTL:EVSTAT0.ADC_DONE
|
|
// SMPH_AUTOTAKE_DONE AUX_EVCTL:EVSTAT0.SMPH_AUTOTAKE_DONE
|
|
// TIMER1_EV AUX_EVCTL:EVSTAT0.TIMER1_EV
|
|
// TIMER0_EV AUX_EVCTL:EVSTAT0.TIMER0_EV
|
|
// ISRC_RESET AUX_ANAIF:ISRCCTL.RESET_N
|
|
// AUX_COMPB AUX_EVCTL:EVSTAT0.AUX_COMPB
|
|
// AUX_COMPA AUX_EVCTL:EVSTAT0.AUX_COMPA
|
|
// AON_RTC_CH2 AUX_EVCTL:EVSTAT0.AON_RTC_CH2
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_W 5
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_M 0x00001F00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_S 8
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_TDC_PRE 0x00001F00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_MCU_EV 0x00001E00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_ACLK_REF 0x00001D00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO15 0x00001C00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO14 0x00001B00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO13 0x00001A00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO12 0x00001900
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO11 0x00001800
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO10 0x00001700
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO9 0x00001600
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO8 0x00001500
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO7 0x00001400
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO6 0x00001300
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO5 0x00001200
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO4 0x00001100
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO3 0x00001000
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO2 0x00000F00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO1 0x00000E00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUXIO0 0x00000D00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AON_PROG_WU 0x00000C00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AON_SW 0x00000B00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_OBSMUX1 0x00000A00
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_OBSMUX0 0x00000900
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_ADC_FIFO_ALMOST_FULL 0x00000800
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_ADC_DONE 0x00000700
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_SMPH_AUTOTAKE_DONE 0x00000600
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_TIMER1_EV 0x00000500
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_TIMER0_EV 0x00000400
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_ISRC_RESET 0x00000300
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUX_COMPB 0x00000200
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AUX_COMPA 0x00000100
|
|
#define AUX_TDC_TRIGSRC_STOP_SRC_AON_RTC_CH2 0x00000000
|
|
|
|
// Field: [5] START_POL
|
|
//
|
|
// Polarity of start source.
|
|
//
|
|
// Change only while STAT.STATE is IDLE.
|
|
// ENUMs:
|
|
// LOW TDC conversion starts when low level is detected.
|
|
// HIGH TDC conversion starts when high level is detected.
|
|
#define AUX_TDC_TRIGSRC_START_POL 0x00000020
|
|
#define AUX_TDC_TRIGSRC_START_POL_BITN 5
|
|
#define AUX_TDC_TRIGSRC_START_POL_M 0x00000020
|
|
#define AUX_TDC_TRIGSRC_START_POL_S 5
|
|
#define AUX_TDC_TRIGSRC_START_POL_LOW 0x00000020
|
|
#define AUX_TDC_TRIGSRC_START_POL_HIGH 0x00000000
|
|
|
|
// Field: [4:0] START_SRC
|
|
//
|
|
// Select start source from the asynchronous AUX event bus.
|
|
//
|
|
// Change only while STAT.STATE is IDLE.
|
|
// ENUMs:
|
|
// TDC_PRE Select TDC Prescaler event which is generated by
|
|
// configuration of PRECTL.
|
|
// 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
|
|
// OBSMUX1 AUX_EVCTL:EVSTAT0.OBSMUX1
|
|
// OBSMUX0 AUX_EVCTL:EVSTAT0.OBSMUX0
|
|
// ADC_FIFO_ALMOST_FULL AUX_EVCTL:EVSTAT0.ADC_FIFO_ALMOST_FULL
|
|
// ADC_DONE AUX_EVCTL:EVSTAT0.ADC_DONE
|
|
// SMPH_AUTOTAKE_DONE AUX_EVCTL:EVSTAT0.SMPH_AUTOTAKE_DONE
|
|
// TIMER1_EV AUX_EVCTL:EVSTAT0.TIMER1_EV
|
|
// TIMER0_EV AUX_EVCTL:EVSTAT0.TIMER0_EV
|
|
// ISRC_RESET AUX_ANAIF:ISRCCTL.RESET_N
|
|
// AUX_COMPB AUX_EVCTL:EVSTAT0.AUX_COMPB
|
|
// AUX_COMPA AUX_EVCTL:EVSTAT0.AUX_COMPA
|
|
// AON_RTC_CH2 AUX_EVCTL:EVSTAT0.AON_RTC_CH2
|
|
#define AUX_TDC_TRIGSRC_START_SRC_W 5
|
|
#define AUX_TDC_TRIGSRC_START_SRC_M 0x0000001F
|
|
#define AUX_TDC_TRIGSRC_START_SRC_S 0
|
|
#define AUX_TDC_TRIGSRC_START_SRC_TDC_PRE 0x0000001F
|
|
#define AUX_TDC_TRIGSRC_START_SRC_MCU_EV 0x0000001E
|
|
#define AUX_TDC_TRIGSRC_START_SRC_ACLK_REF 0x0000001D
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO15 0x0000001C
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO14 0x0000001B
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO13 0x0000001A
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO12 0x00000019
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO11 0x00000018
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO10 0x00000017
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO9 0x00000016
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO8 0x00000015
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO7 0x00000014
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO6 0x00000013
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO5 0x00000012
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO4 0x00000011
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO3 0x00000010
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO2 0x0000000F
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO1 0x0000000E
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUXIO0 0x0000000D
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AON_PROG_WU 0x0000000C
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AON_SW 0x0000000B
|
|
#define AUX_TDC_TRIGSRC_START_SRC_OBSMUX1 0x0000000A
|
|
#define AUX_TDC_TRIGSRC_START_SRC_OBSMUX0 0x00000009
|
|
#define AUX_TDC_TRIGSRC_START_SRC_ADC_FIFO_ALMOST_FULL 0x00000008
|
|
#define AUX_TDC_TRIGSRC_START_SRC_ADC_DONE 0x00000007
|
|
#define AUX_TDC_TRIGSRC_START_SRC_SMPH_AUTOTAKE_DONE 0x00000006
|
|
#define AUX_TDC_TRIGSRC_START_SRC_TIMER1_EV 0x00000005
|
|
#define AUX_TDC_TRIGSRC_START_SRC_TIMER0_EV 0x00000004
|
|
#define AUX_TDC_TRIGSRC_START_SRC_ISRC_RESET 0x00000003
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUX_COMPB 0x00000002
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AUX_COMPA 0x00000001
|
|
#define AUX_TDC_TRIGSRC_START_SRC_AON_RTC_CH2 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_TDC_O_TRIGCNT
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [15:0] CNT
|
|
//
|
|
// Number of stop events to ignore when AUX_TDC:TRIGCNTCFG.EN is 1.
|
|
//
|
|
// Read CNT to get the remaining number of stop events to ignore during a TDC
|
|
// measurement.
|
|
//
|
|
// Write CNT to update the remaining number of stop events to ignore during a
|
|
// TDC measurement. The TDC measurement ignores updates of CNT if there are no
|
|
// more stop events left to ignore.
|
|
//
|
|
// When AUX_TDC:TRIGCNTCFG.EN is 1, TRIGCNTLOAD.CNT is loaded into CNT at the
|
|
// start of the measurement.
|
|
#define AUX_TDC_TRIGCNT_CNT_W 16
|
|
#define AUX_TDC_TRIGCNT_CNT_M 0x0000FFFF
|
|
#define AUX_TDC_TRIGCNT_CNT_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_TDC_O_TRIGCNTLOAD
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [15:0] CNT
|
|
//
|
|
// Number of stop events to ignore when AUX_TDC:TRIGCNTCFG.EN is 1.
|
|
//
|
|
// To measure frequency of an event source:
|
|
// - Set start event equal to stop event.
|
|
// - Set CNT to number of periods to measure. Both 0 and 1 values measures a
|
|
// single event source period.
|
|
//
|
|
// To measure pulse width of an event source:
|
|
// - Set start event source equal to stop event source.
|
|
// - Select different polarity for start and stop event.
|
|
// - Set CNT to 0.
|
|
//
|
|
// To measure time from the start event to the Nth stop event when N > 1:
|
|
// - Select different start and stop event source.
|
|
// - Set CNT to (N-1).
|
|
//
|
|
// See the Technical Reference Manual for event timing requirements.
|
|
//
|
|
// When AUX_TDC:TRIGCNTCFG.EN is 1, CNT is loaded into TRIGCNT.CNT at the start
|
|
// of the measurement.
|
|
#define AUX_TDC_TRIGCNTLOAD_CNT_W 16
|
|
#define AUX_TDC_TRIGCNTLOAD_CNT_M 0x0000FFFF
|
|
#define AUX_TDC_TRIGCNTLOAD_CNT_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_TDC_O_TRIGCNTCFG
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] EN
|
|
//
|
|
// Enable stop-counter.
|
|
//
|
|
// 0: Disable stop-counter.
|
|
// 1: Enable stop-counter.
|
|
//
|
|
// Change only while STAT.STATE is IDLE.
|
|
#define AUX_TDC_TRIGCNTCFG_EN 0x00000001
|
|
#define AUX_TDC_TRIGCNTCFG_EN_BITN 0
|
|
#define AUX_TDC_TRIGCNTCFG_EN_M 0x00000001
|
|
#define AUX_TDC_TRIGCNTCFG_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_TDC_O_PRECTL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7] RESET_N
|
|
//
|
|
// Prescaler reset.
|
|
//
|
|
// 0: Reset prescaler.
|
|
// 1: Release reset of prescaler.
|
|
//
|
|
// AUX_TDC_PRE event becomes 0 when you reset the prescaler.
|
|
#define AUX_TDC_PRECTL_RESET_N 0x00000080
|
|
#define AUX_TDC_PRECTL_RESET_N_BITN 7
|
|
#define AUX_TDC_PRECTL_RESET_N_M 0x00000080
|
|
#define AUX_TDC_PRECTL_RESET_N_S 7
|
|
|
|
// Field: [6] RATIO
|
|
//
|
|
// Prescaler ratio.
|
|
//
|
|
// This controls how often the AUX_TDC_PRE event is generated by the prescaler.
|
|
// ENUMs:
|
|
// DIV64 Prescaler divides input by 64.
|
|
//
|
|
// AUX_TDC_PRE event has a
|
|
// rising edge for every 64 rising edges of the
|
|
// input. AUX_TDC_PRE event toggles on every 32nd
|
|
// rising edge of the input.
|
|
// DIV16 Prescaler divides input by 16.
|
|
//
|
|
// AUX_TDC_PRE event has a
|
|
// rising edge for every 16 rising edges of the
|
|
// input. AUX_TDC_PRE event toggles on every 8th
|
|
// rising edge of the input.
|
|
#define AUX_TDC_PRECTL_RATIO 0x00000040
|
|
#define AUX_TDC_PRECTL_RATIO_BITN 6
|
|
#define AUX_TDC_PRECTL_RATIO_M 0x00000040
|
|
#define AUX_TDC_PRECTL_RATIO_S 6
|
|
#define AUX_TDC_PRECTL_RATIO_DIV64 0x00000040
|
|
#define AUX_TDC_PRECTL_RATIO_DIV16 0x00000000
|
|
|
|
// Field: [4:0] SRC
|
|
//
|
|
// Prescaler event source.
|
|
//
|
|
// Select an event from the asynchronous AUX event bus to connect to the
|
|
// prescaler input.
|
|
//
|
|
// Configure only while RESET_N is 0.
|
|
// 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
|
|
// OBSMUX1 AUX_EVCTL:EVSTAT0.OBSMUX1
|
|
// OBSMUX0 AUX_EVCTL:EVSTAT0.OBSMUX0
|
|
// ADC_FIFO_ALMOST_FULL AUX_EVCTL:EVSTAT0.ADC_FIFO_ALMOST_FULL
|
|
// ADC_DONE AUX_EVCTL:EVSTAT0.ADC_DONE
|
|
// SMPH_AUTOTAKE_DONE AUX_EVCTL:EVSTAT0.SMPH_AUTOTAKE_DONE
|
|
// TIMER1_EV AUX_EVCTL:EVSTAT0.TIMER1_EV
|
|
// TIMER0_EV AUX_EVCTL:EVSTAT0.TIMER0_EV
|
|
// ISRC_RESET AUX_ANAIF:ISRCCTL.RESET_N
|
|
// AUX_COMPB AUX_EVCTL:EVSTAT0.AUX_COMPB
|
|
// AUX_COMPA AUX_EVCTL:EVSTAT0.AUX_COMPA
|
|
// AON_RTC_CH2 AUX_EVCTL:EVSTAT0.AON_RTC_CH2
|
|
#define AUX_TDC_PRECTL_SRC_W 5
|
|
#define AUX_TDC_PRECTL_SRC_M 0x0000001F
|
|
#define AUX_TDC_PRECTL_SRC_S 0
|
|
#define AUX_TDC_PRECTL_SRC_ADC_IRQ 0x0000001F
|
|
#define AUX_TDC_PRECTL_SRC_MCU_EV 0x0000001E
|
|
#define AUX_TDC_PRECTL_SRC_ACLK_REF 0x0000001D
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO15 0x0000001C
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO14 0x0000001B
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO13 0x0000001A
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO12 0x00000019
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO11 0x00000018
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO10 0x00000017
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO9 0x00000016
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO8 0x00000015
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO7 0x00000014
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO6 0x00000013
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO5 0x00000012
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO4 0x00000011
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO3 0x00000010
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO2 0x0000000F
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO1 0x0000000E
|
|
#define AUX_TDC_PRECTL_SRC_AUXIO0 0x0000000D
|
|
#define AUX_TDC_PRECTL_SRC_AON_PROG_WU 0x0000000C
|
|
#define AUX_TDC_PRECTL_SRC_AON_SW 0x0000000B
|
|
#define AUX_TDC_PRECTL_SRC_OBSMUX1 0x0000000A
|
|
#define AUX_TDC_PRECTL_SRC_OBSMUX0 0x00000009
|
|
#define AUX_TDC_PRECTL_SRC_ADC_FIFO_ALMOST_FULL 0x00000008
|
|
#define AUX_TDC_PRECTL_SRC_ADC_DONE 0x00000007
|
|
#define AUX_TDC_PRECTL_SRC_SMPH_AUTOTAKE_DONE 0x00000006
|
|
#define AUX_TDC_PRECTL_SRC_TIMER1_EV 0x00000005
|
|
#define AUX_TDC_PRECTL_SRC_TIMER0_EV 0x00000004
|
|
#define AUX_TDC_PRECTL_SRC_ISRC_RESET 0x00000003
|
|
#define AUX_TDC_PRECTL_SRC_AUX_COMPB 0x00000002
|
|
#define AUX_TDC_PRECTL_SRC_AUX_COMPA 0x00000001
|
|
#define AUX_TDC_PRECTL_SRC_AON_RTC_CH2 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: AUX_TDC_O_PRECNT
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [15:0] CNT
|
|
//
|
|
// Prescaler counter value.
|
|
//
|
|
// Write a value to CNT to capture the value of the 16-bit prescaler counter
|
|
// into CNT. Read CNT to get the captured value.
|
|
//
|
|
// The read value gets 1 LSB uncertainty if the event source level rises when
|
|
// you release the reset.
|
|
//
|
|
// You must capture the prescaler counter value when the event source level is
|
|
// stable, either high or low:
|
|
// - Disable AUX I/O input buffer to clamp AUXIO event low.
|
|
// - Disable COMPA to clamp AUX_COMPA event low.
|
|
// The read value can in general get 1 LSB uncertainty when you gate the event
|
|
// source asynchronously.
|
|
//
|
|
// Please note the following:
|
|
// - The prescaler counter is reset to 2 by PRECTL.RESET_N.
|
|
// - The captured value is 2 when the number of rising edges on prescaler input
|
|
// is less than 3. Otherwise, captured value equals number of event pulses - 1.
|
|
#define AUX_TDC_PRECNT_CNT_W 16
|
|
#define AUX_TDC_PRECNT_CNT_M 0x0000FFFF
|
|
#define AUX_TDC_PRECNT_CNT_S 0
|
|
|
|
|
|
#endif // __AUX_TDC__
|