1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/cpu/cc2538/include/vendor/hw_gptimer.h
Benjamin Valentin 9d836888c2 treewide: fix file permissions
C files should not be executable.
2020-07-08 17:32:36 +02:00

1032 lines
66 KiB
C

/******************************************************************************
* Filename: hw_gptimer.h
* Revised: $Date: 2013-04-12 15:10:54 +0200 (Fri, 12 Apr 2013) $
* Revision: $Revision: 9735 $
*
* Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.com/
*
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 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.
*
* Neither the name of Texas Instruments Incorporated 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
* OWNER 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_GPTIMER_H__
#define __HW_GPTIMER_H__
//*****************************************************************************
//
// The following are defines for the GPTIMER register offsets.
//
//*****************************************************************************
#define GPTIMER_O_CFG 0x00000000 // GPTM configuration This
// register configures the global
// operation of the GPTM. The value
// written to this register
// determines whether the GPTM is
// in 32-bit mode (concatenated
// timers) or in 16-bit mode
// (individual, split timers).
#define GPTIMER_O_TAMR 0x00000004 // GPTM Timer A mode This register
// configures the GPTM based on the
// configuration selected in the
// CFG register. This register
// controls the modes for Timer A
// when it is used individually.
// When Timer A and Timer B are
// concatenated, this register
// controls the modes for both
// Timer A and Timer B, and the
// contents of TBMR are ignored.
#define GPTIMER_O_TBMR 0x00000008 // GPTM Timer B mode This register
// configures the GPTM based on the
// configuration selected in the
// CFG register. This register
// controls the modes for Timer B
// when it is used individually.
// When Timer A and Timer B are
// concatenated, this register is
// ignored and TBMR controls the
// modes for both Timer A and Timer
// B.
#define GPTIMER_O_CTL 0x0000000C // GPTM control This register is
// used alongside the CFG and TnMR
// registers to fine-tune the timer
// configuration, and to enable
// other features such as timer
// stall.
#define GPTIMER_O_SYNC 0x00000010 // GPTM synchronize Note: This
// register is implemented on GPTM
// 0 base address only. This
// register does however, allow
// software to synchronize a number
// of timers.
#define GPTIMER_O_IMR 0x00000018 // GPTM interrupt mask This
// register allows software to
// enable and disable GPTM
// controller-level interrupts.
// Setting a bit enables the
// corresponding interrupt, while
// clearing a bit disables it.
#define GPTIMER_O_RIS 0x0000001C // GPTM raw interrupt status This
// register shows the state of the
// GPTM internal interrupt signal.
// These bits are set whether or
// not the interrupt is masked in
// the IMR register. Each bit can
// be cleared by writing 1 to its
// corresponding bit in ICR.
#define GPTIMER_O_MIS 0x00000020 // GPTM masked interrupt status
// This register shows the state of
// the GPTM controller-level
// interrupt. If an interrupt is
// unmasked in IMR, and there is an
// event that causes the interrupt
// to be asserted, the
// corresponding bit is set in this
// register. All bits are cleared
// by writing 1 to the
// corresponding bit in ICR.
#define GPTIMER_O_ICR 0x00000024 // GPTM interrupt clear This
// register is used to clear the
// status bits in the RIS and MIS
// registers. Writing 1 to a bit
// clears the corresponding bit in
// the RIS and MIS registers.
#define GPTIMER_O_TAILR 0x00000028 // GPTM Timer A interval load When
// the Timer is counting down, this
// register is used to load the
// starting count value into the
// Timer. When the Timer is
// counting up, this register sets
// the upper bound for the timeout
// event. When a GPTM is configured
// to one of the 32-bit modes,
// TAILR appears as a 32-bit
// register (the upper 16-bits
// correspond to the contents of
// the GPTM Timer B Interval Load
// (TBILR) register). In a 16-bit
// mode, the upper 16 bits of this
// register read as 0s and have no
// effect on the state of TBILR.
#define GPTIMER_O_TBILR 0x0000002C // GPTM Timer B interval load When
// the Timer is counting down, this
// register is used to load the
// starting count value into the
// Timer. When the Timer is
// counting up, this register sets
// the upper bound for the time-out
// event. When a GPTM is configured
// to one of the 32-bit modes, the
// contents of bits [15:0] in this
// register are loaded into the
// upper 16 bits of the TAILR
// register. Reads from this
// register return the current
// value of Timer B and writes are
// ignored. In a 16-bit mode, bits
// [15:0] are used for the load
// value. Bits [31:16] are reserved
// in both cases.
#define GPTIMER_O_TAMATCHR 0x00000030 // GPTM Timer A match This
// register is loaded with a match
// value. Interrupts can be
// generated when the Timer value
// is equal to the value in this
// register in one-shot or periodic
// mode. When a GPTM is configured
// to one of the 32-bit modes,
// TAMATCHR appears as a 32-bit
// register (the upper 16-bits
// correspond to the contents of
// the GPTM Timer B match
// (GPTMTBMATCHR) register). In a
// 16-bit mode, the upper 16 bits
// of this register read as 0s and
// have no effect on the state of
// TBMATCHR.
#define GPTIMER_O_TBMATCHR 0x00000034 // PTM Timer B match This register
// is loaded with a match value.
// Interrupts can be generated when
// the Timer value is equal to the
// value in this register in
// one-shot or periodic mode. When
// a GPTM is configured to one of
// the 32-bit modes, the contents
// of bits [15:0] in this register
// are loaded into the upper 16
// bits of the TAMATCHR register.
// Reads from this register return
// the current match value of Timer
// B and writes are ignored. In a
// 16-bit mode, bits [15:0] are
// used for the match value. Bits
// [31:16] are reserved in both
// cases.
#define GPTIMER_O_TAPR 0x00000038 // GPTM Timer A prescale This
// register allows software to
// extend the range of the 16-bit
// Timers in periodic and one-shot
// modes.
#define GPTIMER_O_TBPR 0x0000003C // GPTM Timer B prescale This
// register allows software to
// extend the range of the 16-bit
// Timers in periodic and one-shot
// modes.
#define GPTIMER_O_TAPMR 0x00000040 // GPTM Timer A prescale match
// This register effectively
// extends the range of TAMATCHR to
// 24 bits when operating in
// 16-bit, one-shot or periodic
// mode.
#define GPTIMER_O_TBPMR 0x00000044 // GPTM Timer B prescale match
// This register effectively
// extends the range ofMTBMATCHR to
// 24 bits when operating in
// 16-bit, one-shot or periodic
// mode.
#define GPTIMER_O_TAR 0x00000048 // GPTM Timer A This register
// shows the current value of the
// Timer A counter. When a GPTM is
// configured to one of the 32-bit
// modes, TAR appears as a 32-bit
// register (the upper 16-bits
// correspond to the contents of
// the GPTM Timer B (TBR)
// register). In the16-bit Input
// edge count, input edge time, and
// PWM modes, bits [15:0] contain
// the value of the counter and
// bits 23:16 contain the value of
// the prescaler, which is the
// upper 8 bits of the count. Bits
// [31:24] always read as 0. To
// read the value of the prescaler
// in 16-bit, one-shot and periodic
// modes, read bits [23:16] in the
// TAV register.
#define GPTIMER_O_TBR 0x0000004C // GPTM Timer B This register
// shows the current value of the
// Timer B counter. When a GPTM is
// configured to one of the 32-bit
// modes, the contents of bits
// [15:0] in this register are
// loaded into the upper 16 bits of
// the TAR register. Reads from
// this register return the current
// value of Timer B. In a 16-bit
// mode, bits 15:0 contain the
// value of the counter and bits
// [23:16] contain the value of the
// prescaler in Input edge count,
// input edge time, and PWM modes,
// which is the upper 8 bits of the
// count. Bits [31:24] always read
// as 0. To read the value of the
// prescaler in 16-bit, one-shot
// and periodic modes, read bits
// [23:16] in the TBV register.
#define GPTIMER_O_TAV 0x00000050 // GPTM Timer A value When read,
// this register shows the current,
// free-running value of Timer A in
// all modes. Software can use this
// value to determine the time
// elapsed between an interrupt and
// the ISR entry when using the
// snapshot feature with the
// periodic operating mode. When
// written, the value written into
// this register is loaded into the
// TAR register on the next clock
// cycle. When a GPTM is configured
// to one of the 32-bit modes, TAV
// appears as a 32-bit register
// (the upper 16-bits correspond to
// the contents of the GPTM Timer B
// Value (TBV) register). In a
// 16-bit mode, bits [15:0] contain
// the value of the counter and
// bits [23:16] contain the
// current, free-running value of
// the prescaler, which is the
// upper 8 bits of the count in
// input edge count, input edge
// time, PWM and one-shot or
// periodic up count modes. In
// one-shot or periodic down count
// modes, the prescaler stored in
// [23:16] is a true prescaler,
// meaning bits [23:16] count down
// before decrementing the value in
// bits [15:0]. The prescaler its
// [31:24] always read as 0.
#define GPTIMER_O_TBV 0x00000054 // GPTM Timer B value When read,
// this register shows the current,
// free-running value of Timer B in
// all modes. Software can use this
// value to determine the time
// elapsed between an interrupt and
// the ISR entry. When written, the
// value written into this register
// is loaded into the TBR register
// on the next clock cycle. When a
// GPTM is configured to one of the
// 32-bit modes, the contents of
// bits 15:0 in this register are
// loaded into the upper 16 bits of
// the TAV register. Reads from
// this register return the current
// free-running value of Timer B.
// In a 16-bit mode, bits [15:0]
// contain the value of the counter
// and bits [23:16] contain the
// current, free-running value of
// the prescaler, which is the
// upper 8 bits of the count in
// input edge count, input edge
// time, PWM and one-shot or
// periodic up count modes. In
// one-shot or periodic down count
// modes, the prescaler stored in
// [23:16] is a true prescaler,
// meaning bits [23:16] count down
// before decrementing the value in
// bits [15:0]. The prescaler its
// [31:24] always read as 0.
#define GPTIMER_O_TAPS 0x0000005C // GPTM Timer A prescale snapshot
// For the 32-bit wide GPTM, this
// register shows the current value
// of the Timer A prescaler in the
// 32-bit modes. This register is
// ununsed in 16-bit GPTM mode.
#define GPTIMER_O_TBPS 0x00000060 // GPTM Timer B prescale snapshot
// For the 32-bit wide GPTM, this
// register shows the current value
// of the Timer B prescaler in the
// 32-bit modes. This register is
// ununsed in 16-bit GPTM mode.
#define GPTIMER_O_TAPV 0x00000064 // GPTM Timer A prescale value For
// the 32-bit wide GPTM, this
// register shows the current
// free-running value of the Timer
// A prescaler in the 32-bit modes.
// Software can use this value in
// conjunction with the TAV
// register to determine the time
// elapsed between an interrupt and
// the ISR entry. This register is
// ununsed in 16- or 32-bit GPTM
// mode.
#define GPTIMER_O_TBPV 0x00000068 // GPTM Timer B prescale value For
// the 32-bit wide GPTM, this
// register shows the current
// free-running value of the Timer
// B prescaler in the 32-bit modes.
// Software can use this value in
// conjunction with the TBV
// register to determine the time
// elapsed between an interrupt and
// the ISR entry. This register is
// ununsed in 16- or 32-bit GPTM
// mode.
#define GPTIMER_O_PP 0x00000FC0 // GPTM peripheral properties The
// PP register provides information
// regarding the properties of the
// general-purpose Timer module.
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_CFG register.
//
//*****************************************************************************
#define GPTIMER_CFG_GPTMCFG_M 0x00000007 // GPTM configuration The GPTMCFG
// values are defined as follows:
// 0x0: 32-bit timer configuration.
// 0x1: 32-bit real-time clock 0x2:
// Reserved 0x3: Reserved 0x4:
// 16-bit timer configuration. The
// function is controlled by bits
// [1:0] of GPTMTAMR and GPTMTBMR.
// 0x5-0x7: Reserved
#define GPTIMER_CFG_GPTMCFG_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TAMR register.
//
//*****************************************************************************
#define GPTIMER_TAMR_TAPLO 0x00000800 // Legacy PWM operation 0: Legacy
// operation 1: CCP is set to 1 on
// time-out.
#define GPTIMER_TAMR_TAPLO_M 0x00000800
#define GPTIMER_TAMR_TAPLO_S 11
#define GPTIMER_TAMR_TAMRSU 0x00000400 // Timer A match register update
// mode 0: Update GPTMAMATCHR and
// GPTMAPR if used on the next
// cycle. 1: Update GPTMAMATCHR and
// GPTMAPR if used on the next
// time-out. If the timer is
// disabled (TAEN is clear) when
// this bit is set, GPTMTAMATCHR
// and GPTMTAPR are updated when
// the timer is enabled. If the
// timer is stalled (TASTALL is
// set), GPTMTAMATCHR and GPTMTAPR
// are updated according to the
// configuration of this bit.
#define GPTIMER_TAMR_TAMRSU_M 0x00000400
#define GPTIMER_TAMR_TAMRSU_S 10
#define GPTIMER_TAMR_TAPWMIE 0x00000200 // GPTM Timer A PWM interrupt
// enable This bit enables
// interrupts in PWM mode on
// rising, falling, or both edges
// of the CCP output. 0: Interrupt
// is disabled. 1: Interrupt is
// enabled. This bit is valid only
// in PWM mode.
#define GPTIMER_TAMR_TAPWMIE_M 0x00000200
#define GPTIMER_TAMR_TAPWMIE_S 9
#define GPTIMER_TAMR_TAILD 0x00000100 // GPTM Timer A PWM interval load
// write 0: Update the GPTMTAR
// register with the value in the
// GPTMTAILR register on the next
// cycle. If the prescaler is used,
// update the GPTMTAPS register
// with the value in the GPTMTAPR
// register on the next cycle. 1:
// Update the GPTMTAR register with
// the value in the GPTMTAILR
// register on the next cycle. If
// the prescaler is used, update
// the GPTMTAPS register with the
// value in the GPTMTAPR register
// on the next time-out.
#define GPTIMER_TAMR_TAILD_M 0x00000100
#define GPTIMER_TAMR_TAILD_S 8
#define GPTIMER_TAMR_TASNAPS 0x00000080 // GPTM Timer A snap-shot mode 0:
// Snap-shot mode is disabled. 1:
// If Timer A is configured in
// periodic mode, the actual
// free-running value of Timer A is
// loaded at the time-out event
// into the GPTM Timer A (GPTMTAR)
// register.
#define GPTIMER_TAMR_TASNAPS_M 0x00000080
#define GPTIMER_TAMR_TASNAPS_S 7
#define GPTIMER_TAMR_TAWOT 0x00000040 // GPTM Timer A wait-on-trigger 0:
// Timer A begins counting as soon
// as it is enabled. 1: If Timer A
// is enabled (TAEN is set in the
// GPTMCTL register), Timer A does
// not begin counting until it
// receives a trigger from the
// Timer in the previous position
// in the daisy-chain. This bit
// must be clear for GP Timer
// module 0, Timer A.
#define GPTIMER_TAMR_TAWOT_M 0x00000040
#define GPTIMER_TAMR_TAWOT_S 6
#define GPTIMER_TAMR_TAMIE 0x00000020 // GPTM Timer A match interrupt
// enable 0: The match interrupt is
// disabled. 1: An interrupt is
// generated when the match value
// in the GPTMTAMATCHR register is
// reached in the one-shot and
// periodic modes.
#define GPTIMER_TAMR_TAMIE_M 0x00000020
#define GPTIMER_TAMR_TAMIE_S 5
#define GPTIMER_TAMR_TACDIR 0x00000010 // GPTM Timer A count direction 0:
// The timer counts down. 1: The
// timer counts up. When counting
// up, the timer starts from a
// value of 0x0.
#define GPTIMER_TAMR_TACDIR_M 0x00000010
#define GPTIMER_TAMR_TACDIR_S 4
#define GPTIMER_TAMR_TAAMS 0x00000008 // GPTM Timer A alternate mode 0:
// Capture mode is enabled. 1: PWM
// mode is enabled. Note: To enable
// PWM mode, the TACM bit must be
// cleared and the TAMR field must
// be configured to 0x2.
#define GPTIMER_TAMR_TAAMS_M 0x00000008
#define GPTIMER_TAMR_TAAMS_S 3
#define GPTIMER_TAMR_TACMR 0x00000004 // GPTM Timer A capture mode 0:
// Edge-count mode 1: Edge-time
// mode
#define GPTIMER_TAMR_TACMR_M 0x00000004
#define GPTIMER_TAMR_TACMR_S 2
#define GPTIMER_TAMR_TAMR_M 0x00000003 // GPTM Timer A mode 0x0: Reserved
// 0x1: One-shot mode 0x2: Periodic
// mode 0x3: Capture mode The timer
// mode is based on the timer
// configuration defined by bits
// [2:0] in the GPTMCFG register.
#define GPTIMER_TAMR_TAMR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TBMR register.
//
//*****************************************************************************
#define GPTIMER_TBMR_TBPLO 0x00000800 // Legacy PWM operation 0: Legacy
// operation 1: CCP is set to 1 on
// time-out.
#define GPTIMER_TBMR_TBPLO_M 0x00000800
#define GPTIMER_TBMR_TBPLO_S 11
#define GPTIMER_TBMR_TBMRSU 0x00000400 // Timer B match register update
// mode 0: Update the GPTMBMATCHR
// and the GPTMBPR, if used on the
// next cycle. 1: Update the
// GPTMBMATCHR and the GPTMBPR, if
// used on the next time-out. If
// the timer is disabled (TAEN is
// clear) when this bit is set,
// GPTMTBMATCHR and GPTMTBPR are
// updated when the timer is
// enabled. If the timer is stalled
// (TBSTALL is set), GPTMTBMATCHR
// and GPTMTBPR are updated
// according to the configuration
// of this bit.
#define GPTIMER_TBMR_TBMRSU_M 0x00000400
#define GPTIMER_TBMR_TBMRSU_S 10
#define GPTIMER_TBMR_TBPWMIE 0x00000200 // GPTM Timer B PWM interrupt
// enable This bit enables
// interrupts in PWM mode on
// rising, falling, or both edges
// of the CCP output. 0: Interrupt
// is disabled. 1: Interrupt is
// enabled. This bit is valid only
// in PWM mode.
#define GPTIMER_TBMR_TBPWMIE_M 0x00000200
#define GPTIMER_TBMR_TBPWMIE_S 9
#define GPTIMER_TBMR_TBILD 0x00000100 // GPTM Timer B PWM interval load
// write 0: Update the GPTMTBR
// register with the value in the
// GPTMTBILR register on the next
// cycle. If the prescaler is used,
// update the GPTMTBPS register
// with the value in the GPTMTBPR
// register on the next cycle. 1:
// Update the GPTMTBR register with
// the value in the GPTMTBILR
// register on the next cycle. If
// the prescaler is used, update
// the GPTMTBPS register with the
// value in the GPTMTBPR register
// on the next time-out.
#define GPTIMER_TBMR_TBILD_M 0x00000100
#define GPTIMER_TBMR_TBILD_S 8
#define GPTIMER_TBMR_TBSNAPS 0x00000080 // GPTM Timer B snap-shot mode 0:
// Snap-shot mode is disabled. 1:
// If Timer B is configured in the
// periodic mode, the actual
// free-running value of Timer A is
// loaded into the GPTM Timer B
// (GPTMTBR) register at the
// time-out event.
#define GPTIMER_TBMR_TBSNAPS_M 0x00000080
#define GPTIMER_TBMR_TBSNAPS_S 7
#define GPTIMER_TBMR_TBWOT 0x00000040 // GPTM Timer B wait-on-trigger 0:
// Timer B begins counting as soon
// as it is enabled. 1: If Timer B
// is enabled (TBEN is set in the
// GPTMCTL register), Timer B does
// not begin counting until it
// receives a trigger from the
// timer in the previous position
// in the daisy-chain.
#define GPTIMER_TBMR_TBWOT_M 0x00000040
#define GPTIMER_TBMR_TBWOT_S 6
#define GPTIMER_TBMR_TBMIE 0x00000020 // GPTM Timer B match interrupt
// enable 0: The match interrupt is
// disabled. 1: An interrupt is
// generated when the match value
// in the GPTMTBMATCHR register is
// reached in the one-shot and
// periodic modes.
#define GPTIMER_TBMR_TBMIE_M 0x00000020
#define GPTIMER_TBMR_TBMIE_S 5
#define GPTIMER_TBMR_TBCDIR 0x00000010 // GPTM Timer B count direction 0:
// The timer counts down. 1: The
// timer counts up. When counting
// up, the timer starts from a
// value of 0x0.
#define GPTIMER_TBMR_TBCDIR_M 0x00000010
#define GPTIMER_TBMR_TBCDIR_S 4
#define GPTIMER_TBMR_TBAMS 0x00000008 // GPTM Timer B alternate mode 0:
// Capture mode is enabled. 1: PWM
// mode is enabled. Note: To enable
// PWM mode, the TBCM bit must be
// cleared and the TBMR field must
// be configured to 0x2.
#define GPTIMER_TBMR_TBAMS_M 0x00000008
#define GPTIMER_TBMR_TBAMS_S 3
#define GPTIMER_TBMR_TBCMR 0x00000004 // GPTM Timer B capture mode 0:
// Edge-count mode 1: Edge-time
// mode
#define GPTIMER_TBMR_TBCMR_M 0x00000004
#define GPTIMER_TBMR_TBCMR_S 2
#define GPTIMER_TBMR_TBMR_M 0x00000003 // GPTM Timer B mode 0x0: Reserved
// 0x1: One-shot timer mode 0x2:
// Periodic timer mode 0x3: Capture
// mode The timer mode is based on
// the timer configuration defined
// by bits [2:0] in the GPTMCFG
// register.
#define GPTIMER_TBMR_TBMR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_CTL register.
//
//*****************************************************************************
#define GPTIMER_CTL_TBPWML 0x00004000 // GPTM Timer B PWM output level
// 0: Output is unaffected. 1:
// Output is inverted.
#define GPTIMER_CTL_TBPWML_M 0x00004000
#define GPTIMER_CTL_TBPWML_S 14
#define GPTIMER_CTL_TBOTE 0x00002000 // GPTM Timer B output trigger
// enable 0: The ADC trigger of
// output Timer B is disabled. 1:
// The ADC trigger of output Timer
// B is enabled.
#define GPTIMER_CTL_TBOTE_M 0x00002000
#define GPTIMER_CTL_TBOTE_S 13
#define GPTIMER_CTL_TBEVENT_M 0x00000C00 // GPTM Timer B event mode 0x0:
// Positive edge 0x1: Negative edge
// 0x2: Reserved 0x3: Both edges
#define GPTIMER_CTL_TBEVENT_S 10
#define GPTIMER_CTL_TBSTALL 0x00000200 // GPTM Timer B stall enable 0:
// Timer B continues counting while
// the processor is halted by the
// debugger. 1: Timer B freezes
// counting while the processor is
// halted by the debugger.
#define GPTIMER_CTL_TBSTALL_M 0x00000200
#define GPTIMER_CTL_TBSTALL_S 9
#define GPTIMER_CTL_TBEN 0x00000100 // GPTM Timer B enable 0: Timer B
// is disabled. 1: Timer B is
// enabled and begins counting or
// the capture logic is enabled
// based on the GPTMCFG register.
#define GPTIMER_CTL_TBEN_M 0x00000100
#define GPTIMER_CTL_TBEN_S 8
#define GPTIMER_CTL_TAPWML 0x00000040 // GPTM Timer A PWM output level
// 0: Output is unaffected. 1:
// Output is inverted.
#define GPTIMER_CTL_TAPWML_M 0x00000040
#define GPTIMER_CTL_TAPWML_S 6
#define GPTIMER_CTL_TAOTE 0x00000020 // GPTM Timer A output trigger
// enable 0: The ADC trigger of
// output Timer A is disabled. 1:
// The ADC trigger of output Timer
// A is enabled.
#define GPTIMER_CTL_TAOTE_M 0x00000020
#define GPTIMER_CTL_TAOTE_S 5
#define GPTIMER_CTL_TAEVENT_M 0x0000000C // GPTM Timer A event mode 0x0:
// Positive edge 0x1: Negative edge
// 0x2: Reserved 0x3: Both edges
#define GPTIMER_CTL_TAEVENT_S 2
#define GPTIMER_CTL_TASTALL 0x00000002 // GPTM Timer A stall enable 0:
// Timer A continues counting while
// the processor is halted by the
// debugger. 1: Timer A freezes
// counting while the processor is
// halted by the debugger.
#define GPTIMER_CTL_TASTALL_M 0x00000002
#define GPTIMER_CTL_TASTALL_S 1
#define GPTIMER_CTL_TAEN 0x00000001 // GPTM Timer A enable 0: Timer A
// is disabled. 1: Timer A is
// enabled and begins counting or
// the capture logic is enabled
// based on the GPTMCFG register.
#define GPTIMER_CTL_TAEN_M 0x00000001
#define GPTIMER_CTL_TAEN_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_SYNC register.
//
//*****************************************************************************
#define GPTIMER_SYNC_SYNC3_M 0x000000C0 // Synchronize GPTM3 0x0: GPTM3 is
// not affected. 0x1: A time-out
// event for Timer A of GPTM3 is
// triggered. 0x2: A time-out event
// for Timer B of GPTM3 is
// triggered. 0x3: A time-out event
// for Timer A and Timer B of GPTM3
// is triggered.
#define GPTIMER_SYNC_SYNC3_S 6
#define GPTIMER_SYNC_SYNC2_M 0x00000030 // Synchronize GPTM2 0x0: GPTM2 is
// not affected. 0x1: A time-out
// event for Timer A of GPTM2 is
// triggered. 0x2: A time-out event
// for Timer B of GPTM2 is
// triggered. 0x3: A time-out event
// for Timer A and Timer B of GPTM2
// is triggered.
#define GPTIMER_SYNC_SYNC2_S 4
#define GPTIMER_SYNC_SYNC1_M 0x0000000C // Synchronize GPTM1 0x0: GPTM1 is
// not affected. 0x1: A time-out
// event for Timer A of GPTM1 is
// triggered. 0x2: A time-out event
// for Timer B of GPTM1 is
// triggered. 0x3: A time-out event
// for Timer A and Timer B of GPTM1
// is triggered.
#define GPTIMER_SYNC_SYNC1_S 2
#define GPTIMER_SYNC_SYNC0_M 0x00000003 // Synchronize GPTM0 0x0: GPTM0 is
// not affected. 0x1: A time-out
// event for Timer A of GPTM0 is
// triggered. 0x2: A time-out event
// for Timer B of GPTM0 is
// triggered. 0x3: A time-out event
// for Timer A and Timer B of GPTM0
// is triggered.
#define GPTIMER_SYNC_SYNC0_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_IMR register.
//
//*****************************************************************************
#define GPTIMER_IMR_TBMIM 0x00000800 // GPTM Timer B match interrupt
// mask 0: Interrupt is disabled.
// 1: Interrupt is enabled.
#define GPTIMER_IMR_TBMIM_M 0x00000800
#define GPTIMER_IMR_TBMIM_S 11
#define GPTIMER_IMR_CBEIM 0x00000400 // GPTM Timer B capture event
// interrupt mask 0: Interrupt is
// disabled. 1: Interrupt is
// enabled.
#define GPTIMER_IMR_CBEIM_M 0x00000400
#define GPTIMER_IMR_CBEIM_S 10
#define GPTIMER_IMR_CBMIM 0x00000200 // GPTM Timer B capture match
// interrupt mask 0: Interrupt is
// disabled. 1: Interrupt is
// enabled.
#define GPTIMER_IMR_CBMIM_M 0x00000200
#define GPTIMER_IMR_CBMIM_S 9
#define GPTIMER_IMR_TBTOIM 0x00000100 // GPTM Timer B time-out interrupt
// mask 0: Interrupt is disabled.
// 1: Interrupt is enabled.
#define GPTIMER_IMR_TBTOIM_M 0x00000100
#define GPTIMER_IMR_TBTOIM_S 8
#define GPTIMER_IMR_TAMIM 0x00000010 // GPTM Timer A match interrupt
// mask 0: Interrupt is disabled.
// 1: Interrupt is enabled.
#define GPTIMER_IMR_TAMIM_M 0x00000010
#define GPTIMER_IMR_TAMIM_S 4
#define GPTIMER_IMR_CAEIM 0x00000004 // GPTM Timer A capture event
// interrupt mask 0: Interrupt is
// disabled. 1: Interrupt is
// enabled.
#define GPTIMER_IMR_CAEIM_M 0x00000004
#define GPTIMER_IMR_CAEIM_S 2
#define GPTIMER_IMR_CAMIM 0x00000002 // GPTM Timer A capture match
// interrupt mask 0: Interrupt is
// disabled. 1: Interrupt is
// enabled.
#define GPTIMER_IMR_CAMIM_M 0x00000002
#define GPTIMER_IMR_CAMIM_S 1
#define GPTIMER_IMR_TATOIM 0x00000001 // GPTM Timer A time-out interrupt
// mask 0: Interrupt is disabled.
// 1: Interrupt is enabled.
#define GPTIMER_IMR_TATOIM_M 0x00000001
#define GPTIMER_IMR_TATOIM_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_RIS register.
//
//*****************************************************************************
#define GPTIMER_RIS_TBMRIS 0x00000800 // GPTM Timer B match raw
// interrupt
#define GPTIMER_RIS_TBMRIS_M 0x00000800
#define GPTIMER_RIS_TBMRIS_S 11
#define GPTIMER_RIS_CBERIS 0x00000400 // GPTM Timer B capture event raw
// interrupt
#define GPTIMER_RIS_CBERIS_M 0x00000400
#define GPTIMER_RIS_CBERIS_S 10
#define GPTIMER_RIS_CBMRIS 0x00000200 // GPTM Timer B capture match raw
// interrupt
#define GPTIMER_RIS_CBMRIS_M 0x00000200
#define GPTIMER_RIS_CBMRIS_S 9
#define GPTIMER_RIS_TBTORIS 0x00000100 // GPTM Timer B time-out raw
// interrupt
#define GPTIMER_RIS_TBTORIS_M 0x00000100
#define GPTIMER_RIS_TBTORIS_S 8
#define GPTIMER_RIS_TAMRIS 0x00000010 // GPTM Timer A match raw
// interrupt
#define GPTIMER_RIS_TAMRIS_M 0x00000010
#define GPTIMER_RIS_TAMRIS_S 4
#define GPTIMER_RIS_CAERIS 0x00000004 // GPTM Timer A capture event raw
// interrupt
#define GPTIMER_RIS_CAERIS_M 0x00000004
#define GPTIMER_RIS_CAERIS_S 2
#define GPTIMER_RIS_CAMRIS 0x00000002 // GPTM Timer A capture match raw
// interrupt
#define GPTIMER_RIS_CAMRIS_M 0x00000002
#define GPTIMER_RIS_CAMRIS_S 1
#define GPTIMER_RIS_TATORIS 0x00000001 // GPTM Timer A time-out raw
// interrupt
#define GPTIMER_RIS_TATORIS_M 0x00000001
#define GPTIMER_RIS_TATORIS_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_MIS register.
//
//*****************************************************************************
#define GPTIMER_MIS_TBMMIS 0x00000800 // GPTM Timer B match masked
// interrupt
#define GPTIMER_MIS_TBMMIS_M 0x00000800
#define GPTIMER_MIS_TBMMIS_S 11
#define GPTIMER_MIS_CBEMIS 0x00000400 // GPTM Timer B capture event
// masked interrupt
#define GPTIMER_MIS_CBEMIS_M 0x00000400
#define GPTIMER_MIS_CBEMIS_S 10
#define GPTIMER_MIS_CBMMIS 0x00000200 // GPTM Timer B capture match
// masked interrupt
#define GPTIMER_MIS_CBMMIS_M 0x00000200
#define GPTIMER_MIS_CBMMIS_S 9
#define GPTIMER_MIS_TBTOMIS 0x00000100 // GPTM Timer B time-out masked
// interrupt
#define GPTIMER_MIS_TBTOMIS_M 0x00000100
#define GPTIMER_MIS_TBTOMIS_S 8
#define GPTIMER_MIS_TAMRIS 0x00000010 // GPTM Timer A match raw
// interrupt
#define GPTIMER_MIS_TAMRIS_M 0x00000010
#define GPTIMER_MIS_TAMRIS_S 4
#define GPTIMER_MIS_CAEMIS 0x00000004 // GPTM Timer A capture event raw
// interrupt
#define GPTIMER_MIS_CAEMIS_M 0x00000004
#define GPTIMER_MIS_CAEMIS_S 2
#define GPTIMER_MIS_CAMMIS 0x00000002 // GPTM Timer A capture match raw
// interrupt
#define GPTIMER_MIS_CAMMIS_M 0x00000002
#define GPTIMER_MIS_CAMMIS_S 1
#define GPTIMER_MIS_TATOMIS 0x00000001 // GPTM Timer A time-out raw
// interrupt
#define GPTIMER_MIS_TATOMIS_M 0x00000001
#define GPTIMER_MIS_TATOMIS_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_ICR register.
//
//*****************************************************************************
#define GPTIMER_ICR_WUECINT 0x00010000 // GPTM write update error
// interrupt clear
#define GPTIMER_ICR_WUECINT_M 0x00010000
#define GPTIMER_ICR_WUECINT_S 16
#define GPTIMER_ICR_TBMCINT 0x00000800 // GPTM Timer B match interrupt
// clear
#define GPTIMER_ICR_TBMCINT_M 0x00000800
#define GPTIMER_ICR_TBMCINT_S 11
#define GPTIMER_ICR_CBECINT 0x00000400 // GPTM Timer B capture event
// Interrupt clear
#define GPTIMER_ICR_CBECINT_M 0x00000400
#define GPTIMER_ICR_CBECINT_S 10
#define GPTIMER_ICR_CBMCINT 0x00000200 // GPTM Timer B capture match
// interrupt clear
#define GPTIMER_ICR_CBMCINT_M 0x00000200
#define GPTIMER_ICR_CBMCINT_S 9
#define GPTIMER_ICR_TBTOCINT 0x00000100 // GPTM Timer B time-out interrupt
// clear
#define GPTIMER_ICR_TBTOCINT_M 0x00000100
#define GPTIMER_ICR_TBTOCINT_S 8
#define GPTIMER_ICR_TAMCINT 0x00000010 // GPTM Timer A match interrupt
// clear
#define GPTIMER_ICR_TAMCINT_M 0x00000010
#define GPTIMER_ICR_TAMCINT_S 4
#define GPTIMER_ICR_CAECINT 0x00000004 // GPTM Timer A capture event
// Interrupt clear
#define GPTIMER_ICR_CAECINT_M 0x00000004
#define GPTIMER_ICR_CAECINT_S 2
#define GPTIMER_ICR_CAMCINT 0x00000002 // GPTM Timer A capture match
// interrupt clear
#define GPTIMER_ICR_CAMCINT_M 0x00000002
#define GPTIMER_ICR_CAMCINT_S 1
#define GPTIMER_ICR_TATOCINT 0x00000001 // GPTM Timer A time-out interrupt
// clear
#define GPTIMER_ICR_TATOCINT_M 0x00000001
#define GPTIMER_ICR_TATOCINT_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the
// GPTIMER_O_TAILR register.
//
//*****************************************************************************
#define GPTIMER_TAILR_TAILR_M 0xFFFFFFFF // GPTM A interval load register
#define GPTIMER_TAILR_TAILR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the
// GPTIMER_O_TBILR register.
//
//*****************************************************************************
#define GPTIMER_TBILR_TBILR_M 0x0000FFFF // GPTM B interval load register
#define GPTIMER_TBILR_TBILR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the
// GPTIMER_O_TAMATCHR register.
//
//*****************************************************************************
#define GPTIMER_TAMATCHR_TAMR_M 0xFFFFFFFF // GPTM Timer A match register
#define GPTIMER_TAMATCHR_TAMR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the
// GPTIMER_O_TBMATCHR register.
//
//*****************************************************************************
#define GPTIMER_TBMATCHR_TBMR_M 0x0000FFFF // GPTM Timer B match register
#define GPTIMER_TBMATCHR_TBMR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TAPR register.
//
//*****************************************************************************
#define GPTIMER_TAPR_TAPSR_M 0x000000FF // GPTM Timer A prescale
#define GPTIMER_TAPR_TAPSR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TBPR register.
//
//*****************************************************************************
#define GPTIMER_TBPR_TBPSR_M 0x000000FF // GPTM Timer B prescale
#define GPTIMER_TBPR_TBPSR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the
// GPTIMER_O_TAPMR register.
//
//*****************************************************************************
#define GPTIMER_TAPMR_TAPSR_M 0x000000FF // GPTM Timer A prescale match
#define GPTIMER_TAPMR_TAPSR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the
// GPTIMER_O_TBPMR register.
//
//*****************************************************************************
#define GPTIMER_TBPMR_TBPSR_M 0x000000FF // GPTM Timer B prescale match
#define GPTIMER_TBPMR_TBPSR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TAR register.
//
//*****************************************************************************
#define GPTIMER_TAR_TAR_M 0xFFFFFFFF // GPTM Timer A register
#define GPTIMER_TAR_TAR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TBR register.
//
//*****************************************************************************
#define GPTIMER_TBR_TBR_M 0x0000FFFF // GPTM Timer B register
#define GPTIMER_TBR_TBR_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TAV register.
//
//*****************************************************************************
#define GPTIMER_TAV_TAV_M 0xFFFFFFFF // GPTM Timer A register
#define GPTIMER_TAV_TAV_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TBV register.
//
//*****************************************************************************
#define GPTIMER_TBV_PRE_M 0x00FF0000 // GPTM Timer B prescale register
// (16-bit mode)
#define GPTIMER_TBV_PRE_S 16
#define GPTIMER_TBV_TBV_M 0x0000FFFF // GPTM Timer B register
#define GPTIMER_TBV_TBV_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TAPS register.
//
//*****************************************************************************
#define GPTIMER_TAPS_PSS_M 0x0000FFFF // GPTM Timer A prescaler
#define GPTIMER_TAPS_PSS_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TBPS register.
//
//*****************************************************************************
#define GPTIMER_TBPS_PSS_M 0x0000FFFF // GPTM Timer B prescaler
#define GPTIMER_TBPS_PSS_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TAPV register.
//
//*****************************************************************************
#define GPTIMER_TAPV_PSV_M 0x0000FFFF // GPTM Timer A prescaler value
#define GPTIMER_TAPV_PSV_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_TBPV register.
//
//*****************************************************************************
#define GPTIMER_TBPV_PSV_M 0x0000FFFF // GPTM Timer B prescaler value
#define GPTIMER_TBPV_PSV_S 0
//*****************************************************************************
//
// The following are defines for the bit fields in the GPTIMER_O_PP register.
//
//*****************************************************************************
#define GPTIMER_PP_ALTCLK 0x00000040 // Alternate clock source 0: Timer
// is not capable of using an
// alternate clock. 1: Timer is
// capable of using an alternate
// clock.
#define GPTIMER_PP_ALTCLK_M 0x00000040
#define GPTIMER_PP_ALTCLK_S 6
#define GPTIMER_PP_SYNCNT 0x00000020 // Synchronized start 0: Timer is
// not capable of synchronizing the
// count value with other timers.
// 1: Timer is capable of
// synchronizing the count value
// with other timers.
#define GPTIMER_PP_SYNCNT_M 0x00000020
#define GPTIMER_PP_SYNCNT_S 5
#define GPTIMER_PP_CHAIN 0x00000010 // Chain with other timers 0:
// Timer is not capable of chaining
// with previously numbered Timers.
// 1: Timer is capable of chaining
// with previously numbered timers.
#define GPTIMER_PP_CHAIN_M 0x00000010
#define GPTIMER_PP_CHAIN_S 4
#define GPTIMER_PP_SIZE_M 0x0000000F // Timer size 0: Timer A and Timer
// B are 16 bits wide with 8-bit
// prescale. 1: Timer A and Timer B
// are 32 bits wide with 16-bit
// prescale.
#define GPTIMER_PP_SIZE_S 0
#endif // __HW_GPTIMER_H__