mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-16 09:32:43 +01:00
7db791476e
Signed-off-by: Jean Pierre Dudey <me@jeandudey.tech>
1687 lines
79 KiB
C
1687 lines
79 KiB
C
/******************************************************************************
|
|
* Filename: hw_gpt_h
|
|
* Revised: 2017-01-31 09:37:48 +0100 (Tue, 31 Jan 2017)
|
|
* Revision: 48345
|
|
*
|
|
* 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_GPT_H__
|
|
#define __HW_GPT_H__
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// This section defines the register offsets of
|
|
// GPT component
|
|
//
|
|
//*****************************************************************************
|
|
// Configuration
|
|
#define GPT_O_CFG 0x00000000
|
|
|
|
// Timer A Mode
|
|
#define GPT_O_TAMR 0x00000004
|
|
|
|
// Timer B Mode
|
|
#define GPT_O_TBMR 0x00000008
|
|
|
|
// Control
|
|
#define GPT_O_CTL 0x0000000C
|
|
|
|
// Synch Register
|
|
#define GPT_O_SYNC 0x00000010
|
|
|
|
// Interrupt Mask
|
|
#define GPT_O_IMR 0x00000018
|
|
|
|
// Raw Interrupt Status
|
|
#define GPT_O_RIS 0x0000001C
|
|
|
|
// Masked Interrupt Status
|
|
#define GPT_O_MIS 0x00000020
|
|
|
|
// Interrupt Clear
|
|
#define GPT_O_ICLR 0x00000024
|
|
|
|
// Timer A Interval Load Register
|
|
#define GPT_O_TAILR 0x00000028
|
|
|
|
// Timer B Interval Load Register
|
|
#define GPT_O_TBILR 0x0000002C
|
|
|
|
// Timer A Match Register
|
|
#define GPT_O_TAMATCHR 0x00000030
|
|
|
|
// Timer B Match Register
|
|
#define GPT_O_TBMATCHR 0x00000034
|
|
|
|
// Timer A Pre-scale
|
|
#define GPT_O_TAPR 0x00000038
|
|
|
|
// Timer B Pre-scale
|
|
#define GPT_O_TBPR 0x0000003C
|
|
|
|
// Timer A Pre-scale Match
|
|
#define GPT_O_TAPMR 0x00000040
|
|
|
|
// Timer B Pre-scale Match
|
|
#define GPT_O_TBPMR 0x00000044
|
|
|
|
// Timer A Register
|
|
#define GPT_O_TAR 0x00000048
|
|
|
|
// Timer B Register
|
|
#define GPT_O_TBR 0x0000004C
|
|
|
|
// Timer A Value
|
|
#define GPT_O_TAV 0x00000050
|
|
|
|
// Timer B Value
|
|
#define GPT_O_TBV 0x00000054
|
|
|
|
// Timer A Pre-scale Snap-shot
|
|
#define GPT_O_TAPS 0x0000005C
|
|
|
|
// Timer B Pre-scale Snap-shot
|
|
#define GPT_O_TBPS 0x00000060
|
|
|
|
// Timer A Pre-scale Value
|
|
#define GPT_O_TAPV 0x00000064
|
|
|
|
// Timer B Pre-scale Value
|
|
#define GPT_O_TBPV 0x00000068
|
|
|
|
// DMA Event
|
|
#define GPT_O_DMAEV 0x0000006C
|
|
|
|
// Peripheral Version
|
|
#define GPT_O_VERSION 0x00000FB0
|
|
|
|
// Combined CCP Output
|
|
#define GPT_O_ANDCCP 0x00000FB4
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_CFG
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [2:0] CFG
|
|
//
|
|
// GPT Configuration
|
|
// 0x2- 0x3 - Reserved
|
|
// 0x5- 0x7 - Reserved
|
|
// ENUMs:
|
|
// 16BIT_TIMER 16-bit timer configuration.
|
|
// Configure for two 16-bit
|
|
// timers.
|
|
// Also see TAMR.TAMR and
|
|
// TBMR.TBMR.
|
|
// 32BIT_TIMER 32-bit timer configuration
|
|
#define GPT_CFG_CFG_W 3
|
|
#define GPT_CFG_CFG_M 0x00000007
|
|
#define GPT_CFG_CFG_S 0
|
|
#define GPT_CFG_CFG_16BIT_TIMER 0x00000004
|
|
#define GPT_CFG_CFG_32BIT_TIMER 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TAMR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [15:13] TCACT
|
|
//
|
|
// Timer Compare Action Select
|
|
// ENUMs:
|
|
// CLRSET_ON_TO Clear CCP output pin immediately and set on
|
|
// Time-Out
|
|
// SETCLR_ON_TO Set CCP output pin immediately and clear on
|
|
// Time-Out
|
|
// CLRTOG_ON_TO Clear CCP output pin immediately and toggle on
|
|
// Time-Out
|
|
// SETTOG_ON_TO Set CCP output pin immediately and toggle on
|
|
// Time-Out
|
|
// SET_ON_TO Set CCP output pin on Time-Out
|
|
// CLR_ON_TO Clear CCP output pin on Time-Out
|
|
// TOG_ON_TO Toggle State on Time-Out
|
|
// DIS_CMP Disable compare operations
|
|
#define GPT_TAMR_TCACT_W 3
|
|
#define GPT_TAMR_TCACT_M 0x0000E000
|
|
#define GPT_TAMR_TCACT_S 13
|
|
#define GPT_TAMR_TCACT_CLRSET_ON_TO 0x0000E000
|
|
#define GPT_TAMR_TCACT_SETCLR_ON_TO 0x0000C000
|
|
#define GPT_TAMR_TCACT_CLRTOG_ON_TO 0x0000A000
|
|
#define GPT_TAMR_TCACT_SETTOG_ON_TO 0x00008000
|
|
#define GPT_TAMR_TCACT_SET_ON_TO 0x00006000
|
|
#define GPT_TAMR_TCACT_CLR_ON_TO 0x00004000
|
|
#define GPT_TAMR_TCACT_TOG_ON_TO 0x00002000
|
|
#define GPT_TAMR_TCACT_DIS_CMP 0x00000000
|
|
|
|
// Field: [12] TACINTD
|
|
//
|
|
// One-Shot/Periodic Interrupt Disable
|
|
// ENUMs:
|
|
// DIS_TO_INTR Time-out interrupt are disabled
|
|
// EN_TO_INTR Time-out interrupt function as normal
|
|
#define GPT_TAMR_TACINTD 0x00001000
|
|
#define GPT_TAMR_TACINTD_BITN 12
|
|
#define GPT_TAMR_TACINTD_M 0x00001000
|
|
#define GPT_TAMR_TACINTD_S 12
|
|
#define GPT_TAMR_TACINTD_DIS_TO_INTR 0x00001000
|
|
#define GPT_TAMR_TACINTD_EN_TO_INTR 0x00000000
|
|
|
|
// Field: [11] TAPLO
|
|
//
|
|
// GPTM Timer A PWM Legacy Operation
|
|
//
|
|
// 0 Legacy operation with CCP pin driven Low when the TAILR
|
|
// register is reloaded after the timer reaches 0.
|
|
//
|
|
// 1 CCP is driven High when the TAILR register is reloaded after the timer
|
|
// reaches 0.
|
|
//
|
|
// This bit is only valid in PWM mode.
|
|
// ENUMs:
|
|
// CCP_ON_TO CCP output pin is set to 1 on time-out
|
|
// LEGACY Legacy operation
|
|
#define GPT_TAMR_TAPLO 0x00000800
|
|
#define GPT_TAMR_TAPLO_BITN 11
|
|
#define GPT_TAMR_TAPLO_M 0x00000800
|
|
#define GPT_TAMR_TAPLO_S 11
|
|
#define GPT_TAMR_TAPLO_CCP_ON_TO 0x00000800
|
|
#define GPT_TAMR_TAPLO_LEGACY 0x00000000
|
|
|
|
// Field: [10] TAMRSU
|
|
//
|
|
// Timer A Match Register Update mode
|
|
//
|
|
// This bit defines when the TAMATCHR and TAPR registers are updated.
|
|
//
|
|
// If the timer is disabled (CTL.TAEN = 0) when this bit is set, TAMATCHR and
|
|
// TAPR are updated when the timer is enabled.
|
|
// If the timer is stalled (CTL.TASTALL = 1) when this bit is set, TAMATCHR and
|
|
// TAPR are updated according to the configuration of this bit.
|
|
// ENUMs:
|
|
// TOUPDATE Update TAMATCHR and TAPR, if used, on the next
|
|
// time-out.
|
|
// CYCLEUPDATE Update TAMATCHR and TAPR, if used, on the next
|
|
// cycle.
|
|
#define GPT_TAMR_TAMRSU 0x00000400
|
|
#define GPT_TAMR_TAMRSU_BITN 10
|
|
#define GPT_TAMR_TAMRSU_M 0x00000400
|
|
#define GPT_TAMR_TAMRSU_S 10
|
|
#define GPT_TAMR_TAMRSU_TOUPDATE 0x00000400
|
|
#define GPT_TAMR_TAMRSU_CYCLEUPDATE 0x00000000
|
|
|
|
// Field: [9] TAPWMIE
|
|
//
|
|
// GPTM Timer A PWM Interrupt Enable
|
|
// This bit enables interrupts in PWM mode on rising, falling, or both edges of
|
|
// the CCP output, as defined by the CTL.TAEVENT
|
|
// In addition, when this bit is set and a capture event occurs, Timer A
|
|
// automatically generates triggers to the DMA if the trigger capability is
|
|
// enabled by setting the CTL.TAOTE bit and the DMAEV.CAEDMAEN bit
|
|
// respectively.
|
|
//
|
|
// 0 Capture event interrupt is disabled.
|
|
// 1 Capture event interrupt is enabled.
|
|
// This bit is only valid in PWM mode.
|
|
// ENUMs:
|
|
// EN Interrupt is enabled. This bit is only valid in
|
|
// PWM mode.
|
|
// DIS Interrupt is disabled.
|
|
#define GPT_TAMR_TAPWMIE 0x00000200
|
|
#define GPT_TAMR_TAPWMIE_BITN 9
|
|
#define GPT_TAMR_TAPWMIE_M 0x00000200
|
|
#define GPT_TAMR_TAPWMIE_S 9
|
|
#define GPT_TAMR_TAPWMIE_EN 0x00000200
|
|
#define GPT_TAMR_TAPWMIE_DIS 0x00000000
|
|
|
|
// Field: [8] TAILD
|
|
//
|
|
// GPT Timer A PWM Interval Load Write
|
|
// ENUMs:
|
|
// TOUPDATE Update the TAR register with the value in the
|
|
// TAILR register on the next timeout. If the
|
|
// prescaler is used, update the TAPS register
|
|
// with the value in the TAPR register on the next
|
|
// timeout.
|
|
// CYCLEUPDATE Update the TAR register with the value in the
|
|
// TAILR register on the next clock cycle. If the
|
|
// pre-scaler is used, update the TAPS register
|
|
// with the value in the TAPR register on the next
|
|
// clock cycle.
|
|
#define GPT_TAMR_TAILD 0x00000100
|
|
#define GPT_TAMR_TAILD_BITN 8
|
|
#define GPT_TAMR_TAILD_M 0x00000100
|
|
#define GPT_TAMR_TAILD_S 8
|
|
#define GPT_TAMR_TAILD_TOUPDATE 0x00000100
|
|
#define GPT_TAMR_TAILD_CYCLEUPDATE 0x00000000
|
|
|
|
// Field: [7] TASNAPS
|
|
//
|
|
// GPT Timer A Snap-Shot Mode
|
|
// ENUMs:
|
|
// EN If Timer A is configured in the periodic mode, the
|
|
// actual free-running value of Timer A is loaded
|
|
// at the time-out event into the GPT Timer A
|
|
// (TAR) register.
|
|
// DIS Snap-shot mode is disabled.
|
|
#define GPT_TAMR_TASNAPS 0x00000080
|
|
#define GPT_TAMR_TASNAPS_BITN 7
|
|
#define GPT_TAMR_TASNAPS_M 0x00000080
|
|
#define GPT_TAMR_TASNAPS_S 7
|
|
#define GPT_TAMR_TASNAPS_EN 0x00000080
|
|
#define GPT_TAMR_TASNAPS_DIS 0x00000000
|
|
|
|
// Field: [6] TAWOT
|
|
//
|
|
// GPT Timer A Wait-On-Trigger
|
|
// ENUMs:
|
|
// WAIT If Timer A is enabled (CTL.TAEN = 1), 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 GPT
|
|
// Module 0, Timer A. This function is valid for
|
|
// one-shot, periodic, and PWM modes
|
|
// NOWAIT Timer A begins counting as soon as it is enabled.
|
|
#define GPT_TAMR_TAWOT 0x00000040
|
|
#define GPT_TAMR_TAWOT_BITN 6
|
|
#define GPT_TAMR_TAWOT_M 0x00000040
|
|
#define GPT_TAMR_TAWOT_S 6
|
|
#define GPT_TAMR_TAWOT_WAIT 0x00000040
|
|
#define GPT_TAMR_TAWOT_NOWAIT 0x00000000
|
|
|
|
// Field: [5] TAMIE
|
|
//
|
|
// GPT Timer A Match Interrupt Enable
|
|
// ENUMs:
|
|
// EN An interrupt is generated when the match value in
|
|
// TAMATCHR is reached in the one-shot and
|
|
// periodic modes.
|
|
// DIS The match interrupt is disabled for match events.
|
|
// Additionally, output triggers on match events
|
|
// are prevented.
|
|
#define GPT_TAMR_TAMIE 0x00000020
|
|
#define GPT_TAMR_TAMIE_BITN 5
|
|
#define GPT_TAMR_TAMIE_M 0x00000020
|
|
#define GPT_TAMR_TAMIE_S 5
|
|
#define GPT_TAMR_TAMIE_EN 0x00000020
|
|
#define GPT_TAMR_TAMIE_DIS 0x00000000
|
|
|
|
// Field: [4] TACDIR
|
|
//
|
|
// GPT Timer A Count Direction
|
|
// ENUMs:
|
|
// UP The timer counts up. When counting up, the timer
|
|
// starts from a value of 0x0.
|
|
// DOWN The timer counts down.
|
|
#define GPT_TAMR_TACDIR 0x00000010
|
|
#define GPT_TAMR_TACDIR_BITN 4
|
|
#define GPT_TAMR_TACDIR_M 0x00000010
|
|
#define GPT_TAMR_TACDIR_S 4
|
|
#define GPT_TAMR_TACDIR_UP 0x00000010
|
|
#define GPT_TAMR_TACDIR_DOWN 0x00000000
|
|
|
|
// Field: [3] TAAMS
|
|
//
|
|
// GPT Timer A Alternate Mode
|
|
//
|
|
// Note: To enable PWM mode, you must also clear TACM and then configure TAMR
|
|
// field to 0x2.
|
|
// ENUMs:
|
|
// PWM PWM mode is enabled
|
|
// CAP_COMP Capture/Compare mode is enabled.
|
|
#define GPT_TAMR_TAAMS 0x00000008
|
|
#define GPT_TAMR_TAAMS_BITN 3
|
|
#define GPT_TAMR_TAAMS_M 0x00000008
|
|
#define GPT_TAMR_TAAMS_S 3
|
|
#define GPT_TAMR_TAAMS_PWM 0x00000008
|
|
#define GPT_TAMR_TAAMS_CAP_COMP 0x00000000
|
|
|
|
// Field: [2] TACM
|
|
//
|
|
// GPT Timer A Capture Mode
|
|
// ENUMs:
|
|
// EDGTIME Edge-Time mode
|
|
// EDGCNT Edge-Count mode
|
|
#define GPT_TAMR_TACM 0x00000004
|
|
#define GPT_TAMR_TACM_BITN 2
|
|
#define GPT_TAMR_TACM_M 0x00000004
|
|
#define GPT_TAMR_TACM_S 2
|
|
#define GPT_TAMR_TACM_EDGTIME 0x00000004
|
|
#define GPT_TAMR_TACM_EDGCNT 0x00000000
|
|
|
|
// Field: [1:0] TAMR
|
|
//
|
|
// GPT Timer A 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 CFG register
|
|
// ENUMs:
|
|
// CAPTURE Capture mode
|
|
// PERIODIC Periodic Timer mode
|
|
// ONE_SHOT One-Shot Timer mode
|
|
#define GPT_TAMR_TAMR_W 2
|
|
#define GPT_TAMR_TAMR_M 0x00000003
|
|
#define GPT_TAMR_TAMR_S 0
|
|
#define GPT_TAMR_TAMR_CAPTURE 0x00000003
|
|
#define GPT_TAMR_TAMR_PERIODIC 0x00000002
|
|
#define GPT_TAMR_TAMR_ONE_SHOT 0x00000001
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TBMR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [15:13] TCACT
|
|
//
|
|
// Timer Compare Action Select
|
|
// ENUMs:
|
|
// CLRSET_ON_TO Clear CCP output pin immediately and set on
|
|
// Time-Out
|
|
// SETCLR_ON_TO Set CCP output pin immediately and clear on
|
|
// Time-Out
|
|
// CLRTOG_ON_TO Clear CCP output pin immediately and toggle on
|
|
// Time-Out
|
|
// SETTOG_ON_TO Set CCP output pin immediately and toggle on
|
|
// Time-Out
|
|
// SET_ON_TO Set CCP output pin on Time-Out
|
|
// CLR_ON_TO Clear CCP output pin on Time-Out
|
|
// TOG_ON_TO Toggle State on Time-Out
|
|
// DIS_CMP Disable compare operations
|
|
#define GPT_TBMR_TCACT_W 3
|
|
#define GPT_TBMR_TCACT_M 0x0000E000
|
|
#define GPT_TBMR_TCACT_S 13
|
|
#define GPT_TBMR_TCACT_CLRSET_ON_TO 0x0000E000
|
|
#define GPT_TBMR_TCACT_SETCLR_ON_TO 0x0000C000
|
|
#define GPT_TBMR_TCACT_CLRTOG_ON_TO 0x0000A000
|
|
#define GPT_TBMR_TCACT_SETTOG_ON_TO 0x00008000
|
|
#define GPT_TBMR_TCACT_SET_ON_TO 0x00006000
|
|
#define GPT_TBMR_TCACT_CLR_ON_TO 0x00004000
|
|
#define GPT_TBMR_TCACT_TOG_ON_TO 0x00002000
|
|
#define GPT_TBMR_TCACT_DIS_CMP 0x00000000
|
|
|
|
// Field: [12] TBCINTD
|
|
//
|
|
// One-Shot/Periodic Interrupt Mode
|
|
// ENUMs:
|
|
// DIS_TO_INTR Mask Time-Out Interrupt
|
|
// EN_TO_INTR Normal Time-Out Interrupt
|
|
#define GPT_TBMR_TBCINTD 0x00001000
|
|
#define GPT_TBMR_TBCINTD_BITN 12
|
|
#define GPT_TBMR_TBCINTD_M 0x00001000
|
|
#define GPT_TBMR_TBCINTD_S 12
|
|
#define GPT_TBMR_TBCINTD_DIS_TO_INTR 0x00001000
|
|
#define GPT_TBMR_TBCINTD_EN_TO_INTR 0x00000000
|
|
|
|
// Field: [11] TBPLO
|
|
//
|
|
// GPTM Timer B PWM Legacy Operation
|
|
//
|
|
// 0 Legacy operation with CCP pin driven Low when the TBILR
|
|
// register is reloaded after the timer reaches 0.
|
|
//
|
|
// 1 CCP is driven High when the TBILR register is reloaded after the timer
|
|
// reaches 0.
|
|
//
|
|
// This bit is only valid in PWM mode.
|
|
// ENUMs:
|
|
// CCP_ON_TO CCP output pin is set to 1 on time-out
|
|
// LEGACY Legacy operation
|
|
#define GPT_TBMR_TBPLO 0x00000800
|
|
#define GPT_TBMR_TBPLO_BITN 11
|
|
#define GPT_TBMR_TBPLO_M 0x00000800
|
|
#define GPT_TBMR_TBPLO_S 11
|
|
#define GPT_TBMR_TBPLO_CCP_ON_TO 0x00000800
|
|
#define GPT_TBMR_TBPLO_LEGACY 0x00000000
|
|
|
|
// Field: [10] TBMRSU
|
|
//
|
|
// Timer B Match Register Update mode
|
|
//
|
|
// This bit defines when the TBMATCHR and TBPR registers are updated
|
|
//
|
|
// If the timer is disabled (CTL.TBEN is clear) when this bit is set, TBMATCHR
|
|
// and TBPR are updated when the timer is enabled.
|
|
// If the timer is stalled (CTL.TBSTALL is set) when this bit is set, TBMATCHR
|
|
// and TBPR are updated according to the configuration of this bit.
|
|
// ENUMs:
|
|
// TOUPDATE Update TBMATCHR and TBPR, if used, on the next
|
|
// time-out.
|
|
// CYCLEUPDATE Update TBMATCHR and TBPR, if used, on the next
|
|
// cycle.
|
|
#define GPT_TBMR_TBMRSU 0x00000400
|
|
#define GPT_TBMR_TBMRSU_BITN 10
|
|
#define GPT_TBMR_TBMRSU_M 0x00000400
|
|
#define GPT_TBMR_TBMRSU_S 10
|
|
#define GPT_TBMR_TBMRSU_TOUPDATE 0x00000400
|
|
#define GPT_TBMR_TBMRSU_CYCLEUPDATE 0x00000000
|
|
|
|
// Field: [9] TBPWMIE
|
|
//
|
|
// GPTM Timer B PWM Interrupt Enable
|
|
// This bit enables interrupts in PWM mode on rising, falling, or both edges of
|
|
// the CCP output, as defined by the CTL.TBEVENT
|
|
// In addition, when this bit is set and a capture event occurs, Timer A
|
|
// automatically generates triggers to the DMA if the trigger capability is
|
|
// enabled by setting the CTL.TBOTE bit and the DMAEV.CBEDMAEN bit
|
|
// respectively.
|
|
//
|
|
// 0 Capture event interrupt is disabled.
|
|
// 1 Capture event interrupt is enabled.
|
|
// This bit is only valid in PWM mode.
|
|
// ENUMs:
|
|
// EN Interrupt is enabled. This bit is only valid in
|
|
// PWM mode.
|
|
// DIS Interrupt is disabled.
|
|
#define GPT_TBMR_TBPWMIE 0x00000200
|
|
#define GPT_TBMR_TBPWMIE_BITN 9
|
|
#define GPT_TBMR_TBPWMIE_M 0x00000200
|
|
#define GPT_TBMR_TBPWMIE_S 9
|
|
#define GPT_TBMR_TBPWMIE_EN 0x00000200
|
|
#define GPT_TBMR_TBPWMIE_DIS 0x00000000
|
|
|
|
// Field: [8] TBILD
|
|
//
|
|
// GPT Timer B PWM Interval Load Write
|
|
// ENUMs:
|
|
// TOUPDATE Update the TBR register with the value in the
|
|
// TBILR register on the next timeout. If the
|
|
// prescaler is used, update the TBPS register
|
|
// with the value in the TBPR register on the next
|
|
// timeout.
|
|
// CYCLEUPDATE Update the TBR register with the value in the
|
|
// TBILR register on the next clock cycle. If the
|
|
// pre-scaler is used, update the TBPS register
|
|
// with the value in the TBPR register on the next
|
|
// clock cycle.
|
|
#define GPT_TBMR_TBILD 0x00000100
|
|
#define GPT_TBMR_TBILD_BITN 8
|
|
#define GPT_TBMR_TBILD_M 0x00000100
|
|
#define GPT_TBMR_TBILD_S 8
|
|
#define GPT_TBMR_TBILD_TOUPDATE 0x00000100
|
|
#define GPT_TBMR_TBILD_CYCLEUPDATE 0x00000000
|
|
|
|
// Field: [7] TBSNAPS
|
|
//
|
|
// GPT Timer B Snap-Shot Mode
|
|
// ENUMs:
|
|
// EN If Timer B is configured in the periodic mode
|
|
// DIS Snap-shot mode is disabled.
|
|
#define GPT_TBMR_TBSNAPS 0x00000080
|
|
#define GPT_TBMR_TBSNAPS_BITN 7
|
|
#define GPT_TBMR_TBSNAPS_M 0x00000080
|
|
#define GPT_TBMR_TBSNAPS_S 7
|
|
#define GPT_TBMR_TBSNAPS_EN 0x00000080
|
|
#define GPT_TBMR_TBSNAPS_DIS 0x00000000
|
|
|
|
// Field: [6] TBWOT
|
|
//
|
|
// GPT Timer B Wait-On-Trigger
|
|
// ENUMs:
|
|
// WAIT If Timer B is enabled (CTL.TBEN is set), Timer B
|
|
// does not begin counting until it receives a
|
|
// trigger from the timer in the previous position
|
|
// in the daisy chain. This function is valid for
|
|
// one-shot, periodic, and PWM modes
|
|
// NOWAIT Timer B begins counting as soon as it is enabled.
|
|
#define GPT_TBMR_TBWOT 0x00000040
|
|
#define GPT_TBMR_TBWOT_BITN 6
|
|
#define GPT_TBMR_TBWOT_M 0x00000040
|
|
#define GPT_TBMR_TBWOT_S 6
|
|
#define GPT_TBMR_TBWOT_WAIT 0x00000040
|
|
#define GPT_TBMR_TBWOT_NOWAIT 0x00000000
|
|
|
|
// Field: [5] TBMIE
|
|
//
|
|
// GPT Timer B Match Interrupt Enable.
|
|
// ENUMs:
|
|
// EN An interrupt is generated when the match value in
|
|
// the TBMATCHR register is reached in the
|
|
// one-shot and periodic modes.
|
|
// DIS The match interrupt is disabled for match events.
|
|
// Additionally, output triggers on match events
|
|
// are prevented.
|
|
#define GPT_TBMR_TBMIE 0x00000020
|
|
#define GPT_TBMR_TBMIE_BITN 5
|
|
#define GPT_TBMR_TBMIE_M 0x00000020
|
|
#define GPT_TBMR_TBMIE_S 5
|
|
#define GPT_TBMR_TBMIE_EN 0x00000020
|
|
#define GPT_TBMR_TBMIE_DIS 0x00000000
|
|
|
|
// Field: [4] TBCDIR
|
|
//
|
|
// GPT Timer B Count Direction
|
|
// ENUMs:
|
|
// UP The timer counts up. When counting up, the timer
|
|
// starts from a value of 0x0.
|
|
// DOWN The timer counts down.
|
|
#define GPT_TBMR_TBCDIR 0x00000010
|
|
#define GPT_TBMR_TBCDIR_BITN 4
|
|
#define GPT_TBMR_TBCDIR_M 0x00000010
|
|
#define GPT_TBMR_TBCDIR_S 4
|
|
#define GPT_TBMR_TBCDIR_UP 0x00000010
|
|
#define GPT_TBMR_TBCDIR_DOWN 0x00000000
|
|
|
|
// Field: [3] TBAMS
|
|
//
|
|
// GPT Timer B Alternate Mode
|
|
//
|
|
// Note: To enable PWM mode, you must also clear TBCM bit and configure TBMR
|
|
// field to 0x2.
|
|
// ENUMs:
|
|
// PWM PWM mode is enabled
|
|
// CAP_COMP Capture/Compare mode is enabled.
|
|
#define GPT_TBMR_TBAMS 0x00000008
|
|
#define GPT_TBMR_TBAMS_BITN 3
|
|
#define GPT_TBMR_TBAMS_M 0x00000008
|
|
#define GPT_TBMR_TBAMS_S 3
|
|
#define GPT_TBMR_TBAMS_PWM 0x00000008
|
|
#define GPT_TBMR_TBAMS_CAP_COMP 0x00000000
|
|
|
|
// Field: [2] TBCM
|
|
//
|
|
// GPT Timer B Capture Mode
|
|
// ENUMs:
|
|
// EDGTIME Edge-Time mode
|
|
// EDGCNT Edge-Count mode
|
|
#define GPT_TBMR_TBCM 0x00000004
|
|
#define GPT_TBMR_TBCM_BITN 2
|
|
#define GPT_TBMR_TBCM_M 0x00000004
|
|
#define GPT_TBMR_TBCM_S 2
|
|
#define GPT_TBMR_TBCM_EDGTIME 0x00000004
|
|
#define GPT_TBMR_TBCM_EDGCNT 0x00000000
|
|
|
|
// Field: [1:0] TBMR
|
|
//
|
|
// GPT 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 CFG register
|
|
// ENUMs:
|
|
// CAPTURE Capture mode
|
|
// PERIODIC Periodic Timer mode
|
|
// ONE_SHOT One-Shot Timer mode
|
|
#define GPT_TBMR_TBMR_W 2
|
|
#define GPT_TBMR_TBMR_M 0x00000003
|
|
#define GPT_TBMR_TBMR_S 0
|
|
#define GPT_TBMR_TBMR_CAPTURE 0x00000003
|
|
#define GPT_TBMR_TBMR_PERIODIC 0x00000002
|
|
#define GPT_TBMR_TBMR_ONE_SHOT 0x00000001
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_CTL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [14] TBPWML
|
|
//
|
|
// GPT Timer B PWM Output Level
|
|
//
|
|
// 0: Output is unaffected.
|
|
// 1: Output is inverted.
|
|
// ENUMs:
|
|
// INVERTED Inverted
|
|
// NORMAL Not inverted
|
|
#define GPT_CTL_TBPWML 0x00004000
|
|
#define GPT_CTL_TBPWML_BITN 14
|
|
#define GPT_CTL_TBPWML_M 0x00004000
|
|
#define GPT_CTL_TBPWML_S 14
|
|
#define GPT_CTL_TBPWML_INVERTED 0x00004000
|
|
#define GPT_CTL_TBPWML_NORMAL 0x00000000
|
|
|
|
// Field: [11:10] TBEVENT
|
|
//
|
|
// GPT Timer B Event Mode
|
|
//
|
|
// The values in this register are defined as follows:
|
|
// Value Description
|
|
// 0x0 Positive edge
|
|
// 0x1 Negative edge
|
|
// 0x2 Reserved
|
|
// 0x3 Both edges
|
|
// Note: If PWM output inversion is enabled, edge detection interrupt
|
|
// behavior is reversed. Thus, if a positive-edge interrupt trigger
|
|
// has been set and the PWM inversion generates a postive
|
|
// edge, no event-trigger interrupt asserts. Instead, the interrupt
|
|
// is generated on the negative edge of the PWM signal.
|
|
// ENUMs:
|
|
// BOTH Both edges
|
|
// NEG Negative edge
|
|
// POS Positive edge
|
|
#define GPT_CTL_TBEVENT_W 2
|
|
#define GPT_CTL_TBEVENT_M 0x00000C00
|
|
#define GPT_CTL_TBEVENT_S 10
|
|
#define GPT_CTL_TBEVENT_BOTH 0x00000C00
|
|
#define GPT_CTL_TBEVENT_NEG 0x00000400
|
|
#define GPT_CTL_TBEVENT_POS 0x00000000
|
|
|
|
// Field: [9] TBSTALL
|
|
//
|
|
// GPT Timer B Stall Enable
|
|
// ENUMs:
|
|
// EN Timer B freezes counting while the processor is
|
|
// halted by the debugger.
|
|
// DIS Timer B continues counting while the processor is
|
|
// halted by the debugger.
|
|
#define GPT_CTL_TBSTALL 0x00000200
|
|
#define GPT_CTL_TBSTALL_BITN 9
|
|
#define GPT_CTL_TBSTALL_M 0x00000200
|
|
#define GPT_CTL_TBSTALL_S 9
|
|
#define GPT_CTL_TBSTALL_EN 0x00000200
|
|
#define GPT_CTL_TBSTALL_DIS 0x00000000
|
|
|
|
// Field: [8] TBEN
|
|
//
|
|
// GPT Timer B Enable
|
|
// ENUMs:
|
|
// EN Timer B is enabled and begins counting or the
|
|
// capture logic is enabled based on CFG register.
|
|
// DIS Timer B is disabled.
|
|
#define GPT_CTL_TBEN 0x00000100
|
|
#define GPT_CTL_TBEN_BITN 8
|
|
#define GPT_CTL_TBEN_M 0x00000100
|
|
#define GPT_CTL_TBEN_S 8
|
|
#define GPT_CTL_TBEN_EN 0x00000100
|
|
#define GPT_CTL_TBEN_DIS 0x00000000
|
|
|
|
// Field: [6] TAPWML
|
|
//
|
|
// GPT Timer A PWM Output Level
|
|
// ENUMs:
|
|
// INVERTED Inverted
|
|
// NORMAL Not inverted
|
|
#define GPT_CTL_TAPWML 0x00000040
|
|
#define GPT_CTL_TAPWML_BITN 6
|
|
#define GPT_CTL_TAPWML_M 0x00000040
|
|
#define GPT_CTL_TAPWML_S 6
|
|
#define GPT_CTL_TAPWML_INVERTED 0x00000040
|
|
#define GPT_CTL_TAPWML_NORMAL 0x00000000
|
|
|
|
// Field: [3:2] TAEVENT
|
|
//
|
|
// GPT Timer A Event Mode
|
|
//
|
|
// The values in this register are defined as follows:
|
|
// Value Description
|
|
// 0x0 Positive edge
|
|
// 0x1 Negative edge
|
|
// 0x2 Reserved
|
|
// 0x3 Both edges
|
|
// Note: If PWM output inversion is enabled, edge detection interrupt
|
|
// behavior is reversed. Thus, if a positive-edge interrupt trigger
|
|
// has been set and the PWM inversion generates a postive
|
|
// edge, no event-trigger interrupt asserts. Instead, the interrupt
|
|
// is generated on the negative edge of the PWM signal.
|
|
// ENUMs:
|
|
// BOTH Both edges
|
|
// NEG Negative edge
|
|
// POS Positive edge
|
|
#define GPT_CTL_TAEVENT_W 2
|
|
#define GPT_CTL_TAEVENT_M 0x0000000C
|
|
#define GPT_CTL_TAEVENT_S 2
|
|
#define GPT_CTL_TAEVENT_BOTH 0x0000000C
|
|
#define GPT_CTL_TAEVENT_NEG 0x00000004
|
|
#define GPT_CTL_TAEVENT_POS 0x00000000
|
|
|
|
// Field: [1] TASTALL
|
|
//
|
|
// GPT Timer A Stall Enable
|
|
// ENUMs:
|
|
// EN Timer A freezes counting while the processor is
|
|
// halted by the debugger.
|
|
// DIS Timer A continues counting while the processor is
|
|
// halted by the debugger.
|
|
#define GPT_CTL_TASTALL 0x00000002
|
|
#define GPT_CTL_TASTALL_BITN 1
|
|
#define GPT_CTL_TASTALL_M 0x00000002
|
|
#define GPT_CTL_TASTALL_S 1
|
|
#define GPT_CTL_TASTALL_EN 0x00000002
|
|
#define GPT_CTL_TASTALL_DIS 0x00000000
|
|
|
|
// Field: [0] TAEN
|
|
//
|
|
// GPT Timer A Enable
|
|
// ENUMs:
|
|
// EN Timer A is enabled and begins counting or the
|
|
// capture logic is enabled based on the CFG
|
|
// register.
|
|
// DIS Timer A is disabled.
|
|
#define GPT_CTL_TAEN 0x00000001
|
|
#define GPT_CTL_TAEN_BITN 0
|
|
#define GPT_CTL_TAEN_M 0x00000001
|
|
#define GPT_CTL_TAEN_S 0
|
|
#define GPT_CTL_TAEN_EN 0x00000001
|
|
#define GPT_CTL_TAEN_DIS 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_SYNC
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:6] SYNC3
|
|
//
|
|
// Synchronize GPT Timer 3.
|
|
// ENUMs:
|
|
// BOTH A timeout event for both Timer A and Timer B of
|
|
// GPT3 is triggered
|
|
// TIMERB A timeout event for Timer B of GPT3 is triggered
|
|
// TIMERA A timeout event for Timer A of GPT3 is triggered
|
|
// NOSYNC No Sync. GPT3 is not affected.
|
|
#define GPT_SYNC_SYNC3_W 2
|
|
#define GPT_SYNC_SYNC3_M 0x000000C0
|
|
#define GPT_SYNC_SYNC3_S 6
|
|
#define GPT_SYNC_SYNC3_BOTH 0x000000C0
|
|
#define GPT_SYNC_SYNC3_TIMERB 0x00000080
|
|
#define GPT_SYNC_SYNC3_TIMERA 0x00000040
|
|
#define GPT_SYNC_SYNC3_NOSYNC 0x00000000
|
|
|
|
// Field: [5:4] SYNC2
|
|
//
|
|
// Synchronize GPT Timer 2.
|
|
// ENUMs:
|
|
// BOTH A timeout event for both Timer A and Timer B of
|
|
// GPT2 is triggered
|
|
// TIMERB A timeout event for Timer B of GPT2 is triggered
|
|
// TIMERA A timeout event for Timer A of GPT2 is triggered
|
|
// NOSYNC No Sync. GPT2 is not affected.
|
|
#define GPT_SYNC_SYNC2_W 2
|
|
#define GPT_SYNC_SYNC2_M 0x00000030
|
|
#define GPT_SYNC_SYNC2_S 4
|
|
#define GPT_SYNC_SYNC2_BOTH 0x00000030
|
|
#define GPT_SYNC_SYNC2_TIMERB 0x00000020
|
|
#define GPT_SYNC_SYNC2_TIMERA 0x00000010
|
|
#define GPT_SYNC_SYNC2_NOSYNC 0x00000000
|
|
|
|
// Field: [3:2] SYNC1
|
|
//
|
|
// Synchronize GPT Timer 1
|
|
// ENUMs:
|
|
// BOTH A timeout event for both Timer A and Timer B of
|
|
// GPT1 is triggered
|
|
// TIMERB A timeout event for Timer B of GPT1 is triggered
|
|
// TIMERA A timeout event for Timer A of GPT1 is triggered
|
|
// NOSYNC No Sync. GPT1 is not affected.
|
|
#define GPT_SYNC_SYNC1_W 2
|
|
#define GPT_SYNC_SYNC1_M 0x0000000C
|
|
#define GPT_SYNC_SYNC1_S 2
|
|
#define GPT_SYNC_SYNC1_BOTH 0x0000000C
|
|
#define GPT_SYNC_SYNC1_TIMERB 0x00000008
|
|
#define GPT_SYNC_SYNC1_TIMERA 0x00000004
|
|
#define GPT_SYNC_SYNC1_NOSYNC 0x00000000
|
|
|
|
// Field: [1:0] SYNC0
|
|
//
|
|
// Synchronize GPT Timer 0
|
|
// ENUMs:
|
|
// BOTH A timeout event for both Timer A and Timer B of
|
|
// GPT0 is triggered
|
|
// TIMERB A timeout event for Timer B of GPT0 is triggered
|
|
// TIMERA A timeout event for Timer A of GPT0 is triggered
|
|
// NOSYNC No Sync. GPT0 is not affected.
|
|
#define GPT_SYNC_SYNC0_W 2
|
|
#define GPT_SYNC_SYNC0_M 0x00000003
|
|
#define GPT_SYNC_SYNC0_S 0
|
|
#define GPT_SYNC_SYNC0_BOTH 0x00000003
|
|
#define GPT_SYNC_SYNC0_TIMERB 0x00000002
|
|
#define GPT_SYNC_SYNC0_TIMERA 0x00000001
|
|
#define GPT_SYNC_SYNC0_NOSYNC 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_IMR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [13] DMABIM
|
|
//
|
|
// Enabling this bit will make the RIS.DMABRIS interrupt propagate to
|
|
// MIS.DMABMIS
|
|
// ENUMs:
|
|
// EN Enable Interrupt
|
|
// DIS Disable Interrupt
|
|
#define GPT_IMR_DMABIM 0x00002000
|
|
#define GPT_IMR_DMABIM_BITN 13
|
|
#define GPT_IMR_DMABIM_M 0x00002000
|
|
#define GPT_IMR_DMABIM_S 13
|
|
#define GPT_IMR_DMABIM_EN 0x00002000
|
|
#define GPT_IMR_DMABIM_DIS 0x00000000
|
|
|
|
// Field: [11] TBMIM
|
|
//
|
|
// Enabling this bit will make the RIS.TBMRIS interrupt propagate to MIS.TBMMIS
|
|
// ENUMs:
|
|
// EN Enable Interrupt
|
|
// DIS Disable Interrupt
|
|
#define GPT_IMR_TBMIM 0x00000800
|
|
#define GPT_IMR_TBMIM_BITN 11
|
|
#define GPT_IMR_TBMIM_M 0x00000800
|
|
#define GPT_IMR_TBMIM_S 11
|
|
#define GPT_IMR_TBMIM_EN 0x00000800
|
|
#define GPT_IMR_TBMIM_DIS 0x00000000
|
|
|
|
// Field: [10] CBEIM
|
|
//
|
|
// Enabling this bit will make the RIS.CBERIS interrupt propagate to MIS.CBEMIS
|
|
// ENUMs:
|
|
// EN Enable Interrupt
|
|
// DIS Disable Interrupt
|
|
#define GPT_IMR_CBEIM 0x00000400
|
|
#define GPT_IMR_CBEIM_BITN 10
|
|
#define GPT_IMR_CBEIM_M 0x00000400
|
|
#define GPT_IMR_CBEIM_S 10
|
|
#define GPT_IMR_CBEIM_EN 0x00000400
|
|
#define GPT_IMR_CBEIM_DIS 0x00000000
|
|
|
|
// Field: [9] CBMIM
|
|
//
|
|
// Enabling this bit will make the RIS.CBMRIS interrupt propagate to MIS.CBMMIS
|
|
// ENUMs:
|
|
// EN Enable Interrupt
|
|
// DIS Disable Interrupt
|
|
#define GPT_IMR_CBMIM 0x00000200
|
|
#define GPT_IMR_CBMIM_BITN 9
|
|
#define GPT_IMR_CBMIM_M 0x00000200
|
|
#define GPT_IMR_CBMIM_S 9
|
|
#define GPT_IMR_CBMIM_EN 0x00000200
|
|
#define GPT_IMR_CBMIM_DIS 0x00000000
|
|
|
|
// Field: [8] TBTOIM
|
|
//
|
|
// Enabling this bit will make the RIS.TBTORIS interrupt propagate to
|
|
// MIS.TBTOMIS
|
|
// ENUMs:
|
|
// EN Enable Interrupt
|
|
// DIS Disable Interrupt
|
|
#define GPT_IMR_TBTOIM 0x00000100
|
|
#define GPT_IMR_TBTOIM_BITN 8
|
|
#define GPT_IMR_TBTOIM_M 0x00000100
|
|
#define GPT_IMR_TBTOIM_S 8
|
|
#define GPT_IMR_TBTOIM_EN 0x00000100
|
|
#define GPT_IMR_TBTOIM_DIS 0x00000000
|
|
|
|
// Field: [5] DMAAIM
|
|
//
|
|
// Enabling this bit will make the RIS.DMAARIS interrupt propagate to
|
|
// MIS.DMAAMIS
|
|
// ENUMs:
|
|
// EN Enable Interrupt
|
|
// DIS Disable Interrupt
|
|
#define GPT_IMR_DMAAIM 0x00000020
|
|
#define GPT_IMR_DMAAIM_BITN 5
|
|
#define GPT_IMR_DMAAIM_M 0x00000020
|
|
#define GPT_IMR_DMAAIM_S 5
|
|
#define GPT_IMR_DMAAIM_EN 0x00000020
|
|
#define GPT_IMR_DMAAIM_DIS 0x00000000
|
|
|
|
// Field: [4] TAMIM
|
|
//
|
|
// Enabling this bit will make the RIS.TAMRIS interrupt propagate to MIS.TAMMIS
|
|
// ENUMs:
|
|
// EN Enable Interrupt
|
|
// DIS Disable Interrupt
|
|
#define GPT_IMR_TAMIM 0x00000010
|
|
#define GPT_IMR_TAMIM_BITN 4
|
|
#define GPT_IMR_TAMIM_M 0x00000010
|
|
#define GPT_IMR_TAMIM_S 4
|
|
#define GPT_IMR_TAMIM_EN 0x00000010
|
|
#define GPT_IMR_TAMIM_DIS 0x00000000
|
|
|
|
// Field: [2] CAEIM
|
|
//
|
|
// Enabling this bit will make the RIS.CAERIS interrupt propagate to MIS.CAEMIS
|
|
// ENUMs:
|
|
// EN Enable Interrupt
|
|
// DIS Disable Interrupt
|
|
#define GPT_IMR_CAEIM 0x00000004
|
|
#define GPT_IMR_CAEIM_BITN 2
|
|
#define GPT_IMR_CAEIM_M 0x00000004
|
|
#define GPT_IMR_CAEIM_S 2
|
|
#define GPT_IMR_CAEIM_EN 0x00000004
|
|
#define GPT_IMR_CAEIM_DIS 0x00000000
|
|
|
|
// Field: [1] CAMIM
|
|
//
|
|
// Enabling this bit will make the RIS.CAMRIS interrupt propagate to MIS.CAMMIS
|
|
// ENUMs:
|
|
// EN Enable Interrupt
|
|
// DIS Disable Interrupt
|
|
#define GPT_IMR_CAMIM 0x00000002
|
|
#define GPT_IMR_CAMIM_BITN 1
|
|
#define GPT_IMR_CAMIM_M 0x00000002
|
|
#define GPT_IMR_CAMIM_S 1
|
|
#define GPT_IMR_CAMIM_EN 0x00000002
|
|
#define GPT_IMR_CAMIM_DIS 0x00000000
|
|
|
|
// Field: [0] TATOIM
|
|
//
|
|
// Enabling this bit will make the RIS.TATORIS interrupt propagate to
|
|
// MIS.TATOMIS
|
|
// ENUMs:
|
|
// EN Enable Interrupt
|
|
// DIS Disable Interrupt
|
|
#define GPT_IMR_TATOIM 0x00000001
|
|
#define GPT_IMR_TATOIM_BITN 0
|
|
#define GPT_IMR_TATOIM_M 0x00000001
|
|
#define GPT_IMR_TATOIM_S 0
|
|
#define GPT_IMR_TATOIM_EN 0x00000001
|
|
#define GPT_IMR_TATOIM_DIS 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_RIS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [13] DMABRIS
|
|
//
|
|
// GPT Timer B DMA Done Raw Interrupt Status
|
|
//
|
|
// 0: Transfer has not completed
|
|
// 1: Transfer has completed
|
|
#define GPT_RIS_DMABRIS 0x00002000
|
|
#define GPT_RIS_DMABRIS_BITN 13
|
|
#define GPT_RIS_DMABRIS_M 0x00002000
|
|
#define GPT_RIS_DMABRIS_S 13
|
|
|
|
// Field: [11] TBMRIS
|
|
//
|
|
// GPT Timer B Match Raw Interrupt
|
|
//
|
|
// 0: The match value has not been reached
|
|
// 1: The match value is reached.
|
|
//
|
|
// TBMR.TBMIE is set, and the match values in TBMATCHR and optionally TBPMR
|
|
// have been reached when configured in one-shot or periodic mode.
|
|
#define GPT_RIS_TBMRIS 0x00000800
|
|
#define GPT_RIS_TBMRIS_BITN 11
|
|
#define GPT_RIS_TBMRIS_M 0x00000800
|
|
#define GPT_RIS_TBMRIS_S 11
|
|
|
|
// Field: [10] CBERIS
|
|
//
|
|
// GPT Timer B Capture Mode Event Raw Interrupt
|
|
//
|
|
// 0: The event has not occured.
|
|
// 1: The event has occured.
|
|
//
|
|
// This interrupt asserts when the subtimer is configured in Input Edge-Time
|
|
// mode
|
|
#define GPT_RIS_CBERIS 0x00000400
|
|
#define GPT_RIS_CBERIS_BITN 10
|
|
#define GPT_RIS_CBERIS_M 0x00000400
|
|
#define GPT_RIS_CBERIS_S 10
|
|
|
|
// Field: [9] CBMRIS
|
|
//
|
|
// GPT Timer B Capture Mode Match Raw Interrupt
|
|
//
|
|
// 0: The capture mode match for Timer B has not occurred.
|
|
// 1: A capture mode match has occurred for Timer B. This interrupt
|
|
// asserts when the values in the TBR and TBPR
|
|
// match the values in the TBMATCHR and TBPMR
|
|
// when configured in Input Edge-Time mode.
|
|
//
|
|
// This bit is cleared by writing a 1 to the ICLR.CBMCINT bit.
|
|
#define GPT_RIS_CBMRIS 0x00000200
|
|
#define GPT_RIS_CBMRIS_BITN 9
|
|
#define GPT_RIS_CBMRIS_M 0x00000200
|
|
#define GPT_RIS_CBMRIS_S 9
|
|
|
|
// Field: [8] TBTORIS
|
|
//
|
|
// GPT Timer B Time-out Raw Interrupt
|
|
//
|
|
// 0: Timer B has not timed out
|
|
// 1: Timer B has timed out.
|
|
//
|
|
// This interrupt is asserted when a one-shot or periodic mode timer reaches
|
|
// its count limit. The count limit is 0 or the value loaded into TBILR,
|
|
// depending on the count direction.
|
|
#define GPT_RIS_TBTORIS 0x00000100
|
|
#define GPT_RIS_TBTORIS_BITN 8
|
|
#define GPT_RIS_TBTORIS_M 0x00000100
|
|
#define GPT_RIS_TBTORIS_S 8
|
|
|
|
// Field: [5] DMAARIS
|
|
//
|
|
// GPT Timer A DMA Done Raw Interrupt Status
|
|
//
|
|
// 0: Transfer has not completed
|
|
// 1: Transfer has completed
|
|
#define GPT_RIS_DMAARIS 0x00000020
|
|
#define GPT_RIS_DMAARIS_BITN 5
|
|
#define GPT_RIS_DMAARIS_M 0x00000020
|
|
#define GPT_RIS_DMAARIS_S 5
|
|
|
|
// Field: [4] TAMRIS
|
|
//
|
|
// GPT Timer A Match Raw Interrupt
|
|
//
|
|
// 0: The match value has not been reached
|
|
// 1: The match value is reached.
|
|
//
|
|
// TAMR.TAMIE is set, and the match values in TAMATCHR and optionally TAPMR
|
|
// have been reached when configured in one-shot or periodic mode.
|
|
#define GPT_RIS_TAMRIS 0x00000010
|
|
#define GPT_RIS_TAMRIS_BITN 4
|
|
#define GPT_RIS_TAMRIS_M 0x00000010
|
|
#define GPT_RIS_TAMRIS_S 4
|
|
|
|
// Field: [2] CAERIS
|
|
//
|
|
// GPT Timer A Capture Mode Event Raw Interrupt
|
|
//
|
|
// 0: The event has not occured.
|
|
// 1: The event has occured.
|
|
//
|
|
// This interrupt asserts when the subtimer is configured in Input Edge-Time
|
|
// mode
|
|
#define GPT_RIS_CAERIS 0x00000004
|
|
#define GPT_RIS_CAERIS_BITN 2
|
|
#define GPT_RIS_CAERIS_M 0x00000004
|
|
#define GPT_RIS_CAERIS_S 2
|
|
|
|
// Field: [1] CAMRIS
|
|
//
|
|
// GPT Timer A Capture Mode Match Raw Interrupt
|
|
//
|
|
// 0: The capture mode match for Timer A has not occurred.
|
|
// 1: A capture mode match has occurred for Timer A. This interrupt
|
|
// asserts when the values in the TAR and TAPR
|
|
// match the values in the TAMATCHR and TAPMR
|
|
// when configured in Input Edge-Time mode.
|
|
//
|
|
// This bit is cleared by writing a 1 to the ICLR.CAMCINT bit.
|
|
#define GPT_RIS_CAMRIS 0x00000002
|
|
#define GPT_RIS_CAMRIS_BITN 1
|
|
#define GPT_RIS_CAMRIS_M 0x00000002
|
|
#define GPT_RIS_CAMRIS_S 1
|
|
|
|
// Field: [0] TATORIS
|
|
//
|
|
// GPT Timer A Time-out Raw Interrupt
|
|
//
|
|
// 0: Timer A has not timed out
|
|
// 1: Timer A has timed out.
|
|
//
|
|
// This interrupt is asserted when a one-shot or periodic mode timer reaches
|
|
// its count limit. The count limit is 0 or the value loaded into TAILR,
|
|
// depending on the count direction.
|
|
#define GPT_RIS_TATORIS 0x00000001
|
|
#define GPT_RIS_TATORIS_BITN 0
|
|
#define GPT_RIS_TATORIS_M 0x00000001
|
|
#define GPT_RIS_TATORIS_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_MIS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [13] DMABMIS
|
|
//
|
|
// 0: No interrupt or interrupt not enabled
|
|
// 1: RIS.DMABRIS = 1 && IMR.DMABIM = 1
|
|
#define GPT_MIS_DMABMIS 0x00002000
|
|
#define GPT_MIS_DMABMIS_BITN 13
|
|
#define GPT_MIS_DMABMIS_M 0x00002000
|
|
#define GPT_MIS_DMABMIS_S 13
|
|
|
|
// Field: [11] TBMMIS
|
|
//
|
|
// 0: No interrupt or interrupt not enabled
|
|
// 1: RIS.TBMRIS = 1 && IMR.TBMIM = 1
|
|
#define GPT_MIS_TBMMIS 0x00000800
|
|
#define GPT_MIS_TBMMIS_BITN 11
|
|
#define GPT_MIS_TBMMIS_M 0x00000800
|
|
#define GPT_MIS_TBMMIS_S 11
|
|
|
|
// Field: [10] CBEMIS
|
|
//
|
|
// 0: No interrupt or interrupt not enabled
|
|
// 1: RIS.CBERIS = 1 && IMR.CBEIM = 1
|
|
#define GPT_MIS_CBEMIS 0x00000400
|
|
#define GPT_MIS_CBEMIS_BITN 10
|
|
#define GPT_MIS_CBEMIS_M 0x00000400
|
|
#define GPT_MIS_CBEMIS_S 10
|
|
|
|
// Field: [9] CBMMIS
|
|
//
|
|
// 0: No interrupt or interrupt not enabled
|
|
// 1: RIS.CBMRIS = 1 && IMR.CBMIM = 1
|
|
#define GPT_MIS_CBMMIS 0x00000200
|
|
#define GPT_MIS_CBMMIS_BITN 9
|
|
#define GPT_MIS_CBMMIS_M 0x00000200
|
|
#define GPT_MIS_CBMMIS_S 9
|
|
|
|
// Field: [8] TBTOMIS
|
|
//
|
|
// 0: No interrupt or interrupt not enabled
|
|
// 1: RIS.TBTORIS = 1 && IMR.TBTOIM = 1
|
|
#define GPT_MIS_TBTOMIS 0x00000100
|
|
#define GPT_MIS_TBTOMIS_BITN 8
|
|
#define GPT_MIS_TBTOMIS_M 0x00000100
|
|
#define GPT_MIS_TBTOMIS_S 8
|
|
|
|
// Field: [5] DMAAMIS
|
|
//
|
|
// 0: No interrupt or interrupt not enabled
|
|
// 1: RIS.DMAARIS = 1 && IMR.DMAAIM = 1
|
|
#define GPT_MIS_DMAAMIS 0x00000020
|
|
#define GPT_MIS_DMAAMIS_BITN 5
|
|
#define GPT_MIS_DMAAMIS_M 0x00000020
|
|
#define GPT_MIS_DMAAMIS_S 5
|
|
|
|
// Field: [4] TAMMIS
|
|
//
|
|
// 0: No interrupt or interrupt not enabled
|
|
// 1: RIS.TAMRIS = 1 && IMR.TAMIM = 1
|
|
#define GPT_MIS_TAMMIS 0x00000010
|
|
#define GPT_MIS_TAMMIS_BITN 4
|
|
#define GPT_MIS_TAMMIS_M 0x00000010
|
|
#define GPT_MIS_TAMMIS_S 4
|
|
|
|
// Field: [2] CAEMIS
|
|
//
|
|
// 0: No interrupt or interrupt not enabled
|
|
// 1: RIS.CAERIS = 1 && IMR.CAEIM = 1
|
|
#define GPT_MIS_CAEMIS 0x00000004
|
|
#define GPT_MIS_CAEMIS_BITN 2
|
|
#define GPT_MIS_CAEMIS_M 0x00000004
|
|
#define GPT_MIS_CAEMIS_S 2
|
|
|
|
// Field: [1] CAMMIS
|
|
//
|
|
// 0: No interrupt or interrupt not enabled
|
|
// 1: RIS.CAMRIS = 1 && IMR.CAMIM = 1
|
|
#define GPT_MIS_CAMMIS 0x00000002
|
|
#define GPT_MIS_CAMMIS_BITN 1
|
|
#define GPT_MIS_CAMMIS_M 0x00000002
|
|
#define GPT_MIS_CAMMIS_S 1
|
|
|
|
// Field: [0] TATOMIS
|
|
//
|
|
// 0: No interrupt or interrupt not enabled
|
|
// 1: RIS.TATORIS = 1 && IMR.TATOIM = 1
|
|
#define GPT_MIS_TATOMIS 0x00000001
|
|
#define GPT_MIS_TATOMIS_BITN 0
|
|
#define GPT_MIS_TATOMIS_M 0x00000001
|
|
#define GPT_MIS_TATOMIS_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_ICLR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [13] DMABINT
|
|
//
|
|
// 0: Do nothing.
|
|
// 1: Clear RIS.DMABRIS and MIS.DMABMIS
|
|
#define GPT_ICLR_DMABINT 0x00002000
|
|
#define GPT_ICLR_DMABINT_BITN 13
|
|
#define GPT_ICLR_DMABINT_M 0x00002000
|
|
#define GPT_ICLR_DMABINT_S 13
|
|
|
|
// Field: [11] TBMCINT
|
|
//
|
|
// 0: Do nothing.
|
|
// 1: Clear RIS.TBMRIS and MIS.TBMMIS
|
|
#define GPT_ICLR_TBMCINT 0x00000800
|
|
#define GPT_ICLR_TBMCINT_BITN 11
|
|
#define GPT_ICLR_TBMCINT_M 0x00000800
|
|
#define GPT_ICLR_TBMCINT_S 11
|
|
|
|
// Field: [10] CBECINT
|
|
//
|
|
// 0: Do nothing.
|
|
// 1: Clear RIS.CBERIS and MIS.CBEMIS
|
|
#define GPT_ICLR_CBECINT 0x00000400
|
|
#define GPT_ICLR_CBECINT_BITN 10
|
|
#define GPT_ICLR_CBECINT_M 0x00000400
|
|
#define GPT_ICLR_CBECINT_S 10
|
|
|
|
// Field: [9] CBMCINT
|
|
//
|
|
// 0: Do nothing.
|
|
// 1: Clear RIS.CBMRIS and MIS.CBMMIS
|
|
#define GPT_ICLR_CBMCINT 0x00000200
|
|
#define GPT_ICLR_CBMCINT_BITN 9
|
|
#define GPT_ICLR_CBMCINT_M 0x00000200
|
|
#define GPT_ICLR_CBMCINT_S 9
|
|
|
|
// Field: [8] TBTOCINT
|
|
//
|
|
// 0: Do nothing.
|
|
// 1: Clear RIS.TBTORIS and MIS.TBTOMIS
|
|
#define GPT_ICLR_TBTOCINT 0x00000100
|
|
#define GPT_ICLR_TBTOCINT_BITN 8
|
|
#define GPT_ICLR_TBTOCINT_M 0x00000100
|
|
#define GPT_ICLR_TBTOCINT_S 8
|
|
|
|
// Field: [5] DMAAINT
|
|
//
|
|
// 0: Do nothing.
|
|
// 1: Clear RIS.DMAARIS and MIS.DMAAMIS
|
|
#define GPT_ICLR_DMAAINT 0x00000020
|
|
#define GPT_ICLR_DMAAINT_BITN 5
|
|
#define GPT_ICLR_DMAAINT_M 0x00000020
|
|
#define GPT_ICLR_DMAAINT_S 5
|
|
|
|
// Field: [4] TAMCINT
|
|
//
|
|
// 0: Do nothing.
|
|
// 1: Clear RIS.TAMRIS and MIS.TAMMIS
|
|
#define GPT_ICLR_TAMCINT 0x00000010
|
|
#define GPT_ICLR_TAMCINT_BITN 4
|
|
#define GPT_ICLR_TAMCINT_M 0x00000010
|
|
#define GPT_ICLR_TAMCINT_S 4
|
|
|
|
// Field: [2] CAECINT
|
|
//
|
|
// 0: Do nothing.
|
|
// 1: Clear RIS.CAERIS and MIS.CAEMIS
|
|
#define GPT_ICLR_CAECINT 0x00000004
|
|
#define GPT_ICLR_CAECINT_BITN 2
|
|
#define GPT_ICLR_CAECINT_M 0x00000004
|
|
#define GPT_ICLR_CAECINT_S 2
|
|
|
|
// Field: [1] CAMCINT
|
|
//
|
|
// 0: Do nothing.
|
|
// 1: Clear RIS.CAMRIS and MIS.CAMMIS
|
|
#define GPT_ICLR_CAMCINT 0x00000002
|
|
#define GPT_ICLR_CAMCINT_BITN 1
|
|
#define GPT_ICLR_CAMCINT_M 0x00000002
|
|
#define GPT_ICLR_CAMCINT_S 1
|
|
|
|
// Field: [0] TATOCINT
|
|
//
|
|
// 0: Do nothing.
|
|
// 1: Clear RIS.TATORIS and MIS.TATOMIS
|
|
#define GPT_ICLR_TATOCINT 0x00000001
|
|
#define GPT_ICLR_TATOCINT_BITN 0
|
|
#define GPT_ICLR_TATOCINT_M 0x00000001
|
|
#define GPT_ICLR_TATOCINT_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TAILR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [31:0] TAILR
|
|
//
|
|
// GPT Timer A Interval Load Register
|
|
//
|
|
// Writing this field loads the counter for Timer A. A read returns the current
|
|
// value of TAILR.
|
|
#define GPT_TAILR_TAILR_W 32
|
|
#define GPT_TAILR_TAILR_M 0xFFFFFFFF
|
|
#define GPT_TAILR_TAILR_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TBILR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [31:0] TBILR
|
|
//
|
|
// GPT Timer B Interval Load Register
|
|
//
|
|
// Writing this field loads the counter for Timer B. A read returns the current
|
|
// value of TBILR.
|
|
#define GPT_TBILR_TBILR_W 32
|
|
#define GPT_TBILR_TBILR_M 0xFFFFFFFF
|
|
#define GPT_TBILR_TBILR_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TAMATCHR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [31:0] TAMATCHR
|
|
//
|
|
// GPT Timer A Match Register
|
|
#define GPT_TAMATCHR_TAMATCHR_W 32
|
|
#define GPT_TAMATCHR_TAMATCHR_M 0xFFFFFFFF
|
|
#define GPT_TAMATCHR_TAMATCHR_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TBMATCHR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [15:0] TBMATCHR
|
|
//
|
|
// GPT Timer B Match Register
|
|
#define GPT_TBMATCHR_TBMATCHR_W 16
|
|
#define GPT_TBMATCHR_TBMATCHR_M 0x0000FFFF
|
|
#define GPT_TBMATCHR_TBMATCHR_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TAPR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:0] TAPSR
|
|
//
|
|
// Timer A Pre-scale.
|
|
//
|
|
// Prescaler ratio in one-shot and periodic count mode is TAPSR + 1, that is:
|
|
//
|
|
// 0: Prescaler ratio = 1
|
|
// 1: Prescaler ratio = 2
|
|
// 2: Prescaler ratio = 3
|
|
// ...
|
|
// 255: Prescaler ratio = 256
|
|
#define GPT_TAPR_TAPSR_W 8
|
|
#define GPT_TAPR_TAPSR_M 0x000000FF
|
|
#define GPT_TAPR_TAPSR_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TBPR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:0] TBPSR
|
|
//
|
|
// Timer B Pre-scale.
|
|
//
|
|
// Prescale ratio in one-shot and periodic count mode is TBPSR + 1, that is:
|
|
//
|
|
// 0: Prescaler ratio = 1
|
|
// 1: Prescaler ratio = 2
|
|
// 2: Prescaler ratio = 3
|
|
// ...
|
|
// 255: Prescaler ratio = 256
|
|
#define GPT_TBPR_TBPSR_W 8
|
|
#define GPT_TBPR_TBPSR_M 0x000000FF
|
|
#define GPT_TBPR_TBPSR_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TAPMR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:0] TAPSMR
|
|
//
|
|
// GPT Timer A Pre-scale Match. In 16 bit mode this field holds bits 23 to 16.
|
|
#define GPT_TAPMR_TAPSMR_W 8
|
|
#define GPT_TAPMR_TAPSMR_M 0x000000FF
|
|
#define GPT_TAPMR_TAPSMR_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TBPMR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:0] TBPSMR
|
|
//
|
|
// GPT Timer B Pre-scale Match Register. In 16 bit mode this field holds bits
|
|
// 23 to 16.
|
|
#define GPT_TBPMR_TBPSMR_W 8
|
|
#define GPT_TBPMR_TBPSMR_M 0x000000FF
|
|
#define GPT_TBPMR_TBPSMR_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TAR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [31:0] TAR
|
|
//
|
|
// GPT Timer A Register
|
|
//
|
|
// Based on the value in the register field TAMR.TAILD, this register is
|
|
// updated with the value from TAILR register either on the next cycle or on
|
|
// the next timeout.
|
|
//
|
|
// A read returns the current value of the Timer A Count Register, in all cases
|
|
// except for Input Edge count and Timer modes.
|
|
// In the Input Edge Count Mode, this register contains the number of edges
|
|
// that have occurred. In the Input Edge Time mode, this register contains the
|
|
// time at which the last edge event took place.
|
|
#define GPT_TAR_TAR_W 32
|
|
#define GPT_TAR_TAR_M 0xFFFFFFFF
|
|
#define GPT_TAR_TAR_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TBR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [31:0] TBR
|
|
//
|
|
// GPT Timer B Register
|
|
//
|
|
// Based on the value in the register field TBMR.TBILD, this register is
|
|
// updated with the value from TBILR register either on the next cycle or on
|
|
// the next timeout.
|
|
//
|
|
// A read returns the current value of the Timer B Count Register, in all cases
|
|
// except for Input Edge count and Timer modes.
|
|
// In the Input Edge Count Mode, this register contains the number of edges
|
|
// that have occurred. In the Input Edge Time mode, this register contains the
|
|
// time at which the last edge event took place.
|
|
#define GPT_TBR_TBR_W 32
|
|
#define GPT_TBR_TBR_M 0xFFFFFFFF
|
|
#define GPT_TBR_TBR_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TAV
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [31:0] TAV
|
|
//
|
|
// GPT Timer A Register
|
|
// A read returns the current, free-running value of Timer A in all modes.
|
|
// When written, the value written into this register is loaded into the
|
|
// TAR register on the next clock cycle.
|
|
// Note: In 16-bit mode, only the lower 16-bits of this
|
|
// register can be written with a new value. Writes to the prescaler bits have
|
|
// no effect
|
|
#define GPT_TAV_TAV_W 32
|
|
#define GPT_TAV_TAV_M 0xFFFFFFFF
|
|
#define GPT_TAV_TAV_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TBV
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [31:0] TBV
|
|
//
|
|
// GPT Timer B Register
|
|
// A read returns the current, free-running value of Timer B in all modes.
|
|
// When written, the value written into this register is loaded into the
|
|
// TBR register on the next clock cycle.
|
|
// Note: In 16-bit mode, only the lower 16-bits of this
|
|
// register can be written with a new value. Writes to the prescaler bits have
|
|
// no effect
|
|
#define GPT_TBV_TBV_W 32
|
|
#define GPT_TBV_TBV_M 0xFFFFFFFF
|
|
#define GPT_TBV_TBV_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TAPS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:0] PSS
|
|
//
|
|
// GPT Timer A Pre-scaler
|
|
#define GPT_TAPS_PSS_W 8
|
|
#define GPT_TAPS_PSS_M 0x000000FF
|
|
#define GPT_TAPS_PSS_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TBPS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:0] PSS
|
|
//
|
|
// GPT Timer B Pre-scaler
|
|
#define GPT_TBPS_PSS_W 8
|
|
#define GPT_TBPS_PSS_M 0x000000FF
|
|
#define GPT_TBPS_PSS_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TAPV
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:0] PSV
|
|
//
|
|
// GPT Timer A Pre-scaler Value
|
|
#define GPT_TAPV_PSV_W 8
|
|
#define GPT_TAPV_PSV_M 0x000000FF
|
|
#define GPT_TAPV_PSV_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_TBPV
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:0] PSV
|
|
//
|
|
// GPT Timer B Pre-scaler Value
|
|
#define GPT_TBPV_PSV_W 8
|
|
#define GPT_TBPV_PSV_M 0x000000FF
|
|
#define GPT_TBPV_PSV_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_DMAEV
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [11] TBMDMAEN
|
|
//
|
|
// GPT Timer B Match DMA Trigger Enable
|
|
#define GPT_DMAEV_TBMDMAEN 0x00000800
|
|
#define GPT_DMAEV_TBMDMAEN_BITN 11
|
|
#define GPT_DMAEV_TBMDMAEN_M 0x00000800
|
|
#define GPT_DMAEV_TBMDMAEN_S 11
|
|
|
|
// Field: [10] CBEDMAEN
|
|
//
|
|
// GPT Timer B Capture Event DMA Trigger Enable
|
|
#define GPT_DMAEV_CBEDMAEN 0x00000400
|
|
#define GPT_DMAEV_CBEDMAEN_BITN 10
|
|
#define GPT_DMAEV_CBEDMAEN_M 0x00000400
|
|
#define GPT_DMAEV_CBEDMAEN_S 10
|
|
|
|
// Field: [9] CBMDMAEN
|
|
//
|
|
// GPT Timer B Capture Match DMA Trigger Enable
|
|
#define GPT_DMAEV_CBMDMAEN 0x00000200
|
|
#define GPT_DMAEV_CBMDMAEN_BITN 9
|
|
#define GPT_DMAEV_CBMDMAEN_M 0x00000200
|
|
#define GPT_DMAEV_CBMDMAEN_S 9
|
|
|
|
// Field: [8] TBTODMAEN
|
|
//
|
|
// GPT Timer B Time-Out DMA Trigger Enable
|
|
#define GPT_DMAEV_TBTODMAEN 0x00000100
|
|
#define GPT_DMAEV_TBTODMAEN_BITN 8
|
|
#define GPT_DMAEV_TBTODMAEN_M 0x00000100
|
|
#define GPT_DMAEV_TBTODMAEN_S 8
|
|
|
|
// Field: [4] TAMDMAEN
|
|
//
|
|
// GPT Timer A Match DMA Trigger Enable
|
|
#define GPT_DMAEV_TAMDMAEN 0x00000010
|
|
#define GPT_DMAEV_TAMDMAEN_BITN 4
|
|
#define GPT_DMAEV_TAMDMAEN_M 0x00000010
|
|
#define GPT_DMAEV_TAMDMAEN_S 4
|
|
|
|
// Field: [2] CAEDMAEN
|
|
//
|
|
// GPT Timer A Capture Event DMA Trigger Enable
|
|
#define GPT_DMAEV_CAEDMAEN 0x00000004
|
|
#define GPT_DMAEV_CAEDMAEN_BITN 2
|
|
#define GPT_DMAEV_CAEDMAEN_M 0x00000004
|
|
#define GPT_DMAEV_CAEDMAEN_S 2
|
|
|
|
// Field: [1] CAMDMAEN
|
|
//
|
|
// GPT Timer A Capture Match DMA Trigger Enable
|
|
#define GPT_DMAEV_CAMDMAEN 0x00000002
|
|
#define GPT_DMAEV_CAMDMAEN_BITN 1
|
|
#define GPT_DMAEV_CAMDMAEN_M 0x00000002
|
|
#define GPT_DMAEV_CAMDMAEN_S 1
|
|
|
|
// Field: [0] TATODMAEN
|
|
//
|
|
// GPT Timer A Time-Out DMA Trigger Enable
|
|
#define GPT_DMAEV_TATODMAEN 0x00000001
|
|
#define GPT_DMAEV_TATODMAEN_BITN 0
|
|
#define GPT_DMAEV_TATODMAEN_M 0x00000001
|
|
#define GPT_DMAEV_TATODMAEN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_VERSION
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [31:0] VERSION
|
|
//
|
|
// Timer Revision.
|
|
#define GPT_VERSION_VERSION_W 32
|
|
#define GPT_VERSION_VERSION_M 0xFFFFFFFF
|
|
#define GPT_VERSION_VERSION_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: GPT_O_ANDCCP
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CCP_AND_EN
|
|
//
|
|
// Enables AND operation of the CCP outputs for timers A and B.
|
|
//
|
|
// 0 : PWM outputs of Timer A and Timer B are the internal generated PWM
|
|
// signals of the respective timers.
|
|
// 1 : PWM output of Timer A is ANDed version of Timer A and Timer B PWM
|
|
// signals and Timer B PWM ouput is Timer B PWM signal only.
|
|
#define GPT_ANDCCP_CCP_AND_EN 0x00000001
|
|
#define GPT_ANDCCP_CCP_AND_EN_BITN 0
|
|
#define GPT_ANDCCP_CCP_AND_EN_M 0x00000001
|
|
#define GPT_ANDCCP_CCP_AND_EN_S 0
|
|
|
|
|
|
#endif // __GPT__
|