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

1123 lines
54 KiB
C

/******************************************************************************
* Filename: hw_cpu_itm_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_CPU_ITM_H__
#define __HW_CPU_ITM_H__
//*****************************************************************************
//
// This section defines the register offsets of
// CPU_ITM component
//
//*****************************************************************************
// Stimulus Port 0
#define CPU_ITM_O_STIM0 0x00000000
// Stimulus Port 1
#define CPU_ITM_O_STIM1 0x00000004
// Stimulus Port 2
#define CPU_ITM_O_STIM2 0x00000008
// Stimulus Port 3
#define CPU_ITM_O_STIM3 0x0000000C
// Stimulus Port 4
#define CPU_ITM_O_STIM4 0x00000010
// Stimulus Port 5
#define CPU_ITM_O_STIM5 0x00000014
// Stimulus Port 6
#define CPU_ITM_O_STIM6 0x00000018
// Stimulus Port 7
#define CPU_ITM_O_STIM7 0x0000001C
// Stimulus Port 8
#define CPU_ITM_O_STIM8 0x00000020
// Stimulus Port 9
#define CPU_ITM_O_STIM9 0x00000024
// Stimulus Port 10
#define CPU_ITM_O_STIM10 0x00000028
// Stimulus Port 11
#define CPU_ITM_O_STIM11 0x0000002C
// Stimulus Port 12
#define CPU_ITM_O_STIM12 0x00000030
// Stimulus Port 13
#define CPU_ITM_O_STIM13 0x00000034
// Stimulus Port 14
#define CPU_ITM_O_STIM14 0x00000038
// Stimulus Port 15
#define CPU_ITM_O_STIM15 0x0000003C
// Stimulus Port 16
#define CPU_ITM_O_STIM16 0x00000040
// Stimulus Port 17
#define CPU_ITM_O_STIM17 0x00000044
// Stimulus Port 18
#define CPU_ITM_O_STIM18 0x00000048
// Stimulus Port 19
#define CPU_ITM_O_STIM19 0x0000004C
// Stimulus Port 20
#define CPU_ITM_O_STIM20 0x00000050
// Stimulus Port 21
#define CPU_ITM_O_STIM21 0x00000054
// Stimulus Port 22
#define CPU_ITM_O_STIM22 0x00000058
// Stimulus Port 23
#define CPU_ITM_O_STIM23 0x0000005C
// Stimulus Port 24
#define CPU_ITM_O_STIM24 0x00000060
// Stimulus Port 25
#define CPU_ITM_O_STIM25 0x00000064
// Stimulus Port 26
#define CPU_ITM_O_STIM26 0x00000068
// Stimulus Port 27
#define CPU_ITM_O_STIM27 0x0000006C
// Stimulus Port 28
#define CPU_ITM_O_STIM28 0x00000070
// Stimulus Port 29
#define CPU_ITM_O_STIM29 0x00000074
// Stimulus Port 30
#define CPU_ITM_O_STIM30 0x00000078
// Stimulus Port 31
#define CPU_ITM_O_STIM31 0x0000007C
// Trace Enable
#define CPU_ITM_O_TER 0x00000E00
// Trace Privilege
#define CPU_ITM_O_TPR 0x00000E40
// Trace Control
#define CPU_ITM_O_TCR 0x00000E80
// Lock Access
#define CPU_ITM_O_LAR 0x00000FB0
// Lock Status
#define CPU_ITM_O_LSR 0x00000FB4
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM0
//
//*****************************************************************************
// Field: [31:0] STIM0
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA0 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM0_STIM0_W 32
#define CPU_ITM_STIM0_STIM0_M 0xFFFFFFFF
#define CPU_ITM_STIM0_STIM0_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM1
//
//*****************************************************************************
// Field: [31:0] STIM1
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA1 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM1_STIM1_W 32
#define CPU_ITM_STIM1_STIM1_M 0xFFFFFFFF
#define CPU_ITM_STIM1_STIM1_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM2
//
//*****************************************************************************
// Field: [31:0] STIM2
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA2 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM2_STIM2_W 32
#define CPU_ITM_STIM2_STIM2_M 0xFFFFFFFF
#define CPU_ITM_STIM2_STIM2_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM3
//
//*****************************************************************************
// Field: [31:0] STIM3
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA3 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM3_STIM3_W 32
#define CPU_ITM_STIM3_STIM3_M 0xFFFFFFFF
#define CPU_ITM_STIM3_STIM3_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM4
//
//*****************************************************************************
// Field: [31:0] STIM4
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA4 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM4_STIM4_W 32
#define CPU_ITM_STIM4_STIM4_M 0xFFFFFFFF
#define CPU_ITM_STIM4_STIM4_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM5
//
//*****************************************************************************
// Field: [31:0] STIM5
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA5 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM5_STIM5_W 32
#define CPU_ITM_STIM5_STIM5_M 0xFFFFFFFF
#define CPU_ITM_STIM5_STIM5_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM6
//
//*****************************************************************************
// Field: [31:0] STIM6
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA6 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM6_STIM6_W 32
#define CPU_ITM_STIM6_STIM6_M 0xFFFFFFFF
#define CPU_ITM_STIM6_STIM6_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM7
//
//*****************************************************************************
// Field: [31:0] STIM7
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA7 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM7_STIM7_W 32
#define CPU_ITM_STIM7_STIM7_M 0xFFFFFFFF
#define CPU_ITM_STIM7_STIM7_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM8
//
//*****************************************************************************
// Field: [31:0] STIM8
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA8 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM8_STIM8_W 32
#define CPU_ITM_STIM8_STIM8_M 0xFFFFFFFF
#define CPU_ITM_STIM8_STIM8_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM9
//
//*****************************************************************************
// Field: [31:0] STIM9
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA9 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM9_STIM9_W 32
#define CPU_ITM_STIM9_STIM9_M 0xFFFFFFFF
#define CPU_ITM_STIM9_STIM9_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM10
//
//*****************************************************************************
// Field: [31:0] STIM10
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA10 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM10_STIM10_W 32
#define CPU_ITM_STIM10_STIM10_M 0xFFFFFFFF
#define CPU_ITM_STIM10_STIM10_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM11
//
//*****************************************************************************
// Field: [31:0] STIM11
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA11 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM11_STIM11_W 32
#define CPU_ITM_STIM11_STIM11_M 0xFFFFFFFF
#define CPU_ITM_STIM11_STIM11_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM12
//
//*****************************************************************************
// Field: [31:0] STIM12
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA12 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM12_STIM12_W 32
#define CPU_ITM_STIM12_STIM12_M 0xFFFFFFFF
#define CPU_ITM_STIM12_STIM12_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM13
//
//*****************************************************************************
// Field: [31:0] STIM13
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA13 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM13_STIM13_W 32
#define CPU_ITM_STIM13_STIM13_M 0xFFFFFFFF
#define CPU_ITM_STIM13_STIM13_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM14
//
//*****************************************************************************
// Field: [31:0] STIM14
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA14 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM14_STIM14_W 32
#define CPU_ITM_STIM14_STIM14_M 0xFFFFFFFF
#define CPU_ITM_STIM14_STIM14_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM15
//
//*****************************************************************************
// Field: [31:0] STIM15
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA15 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM15_STIM15_W 32
#define CPU_ITM_STIM15_STIM15_M 0xFFFFFFFF
#define CPU_ITM_STIM15_STIM15_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM16
//
//*****************************************************************************
// Field: [31:0] STIM16
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA16 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM16_STIM16_W 32
#define CPU_ITM_STIM16_STIM16_M 0xFFFFFFFF
#define CPU_ITM_STIM16_STIM16_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM17
//
//*****************************************************************************
// Field: [31:0] STIM17
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA17 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM17_STIM17_W 32
#define CPU_ITM_STIM17_STIM17_M 0xFFFFFFFF
#define CPU_ITM_STIM17_STIM17_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM18
//
//*****************************************************************************
// Field: [31:0] STIM18
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA18 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM18_STIM18_W 32
#define CPU_ITM_STIM18_STIM18_M 0xFFFFFFFF
#define CPU_ITM_STIM18_STIM18_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM19
//
//*****************************************************************************
// Field: [31:0] STIM19
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA19 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM19_STIM19_W 32
#define CPU_ITM_STIM19_STIM19_M 0xFFFFFFFF
#define CPU_ITM_STIM19_STIM19_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM20
//
//*****************************************************************************
// Field: [31:0] STIM20
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA20 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM20_STIM20_W 32
#define CPU_ITM_STIM20_STIM20_M 0xFFFFFFFF
#define CPU_ITM_STIM20_STIM20_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM21
//
//*****************************************************************************
// Field: [31:0] STIM21
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA21 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM21_STIM21_W 32
#define CPU_ITM_STIM21_STIM21_M 0xFFFFFFFF
#define CPU_ITM_STIM21_STIM21_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM22
//
//*****************************************************************************
// Field: [31:0] STIM22
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA22 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM22_STIM22_W 32
#define CPU_ITM_STIM22_STIM22_M 0xFFFFFFFF
#define CPU_ITM_STIM22_STIM22_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM23
//
//*****************************************************************************
// Field: [31:0] STIM23
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA23 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM23_STIM23_W 32
#define CPU_ITM_STIM23_STIM23_M 0xFFFFFFFF
#define CPU_ITM_STIM23_STIM23_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM24
//
//*****************************************************************************
// Field: [31:0] STIM24
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA24 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM24_STIM24_W 32
#define CPU_ITM_STIM24_STIM24_M 0xFFFFFFFF
#define CPU_ITM_STIM24_STIM24_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM25
//
//*****************************************************************************
// Field: [31:0] STIM25
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA25 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM25_STIM25_W 32
#define CPU_ITM_STIM25_STIM25_M 0xFFFFFFFF
#define CPU_ITM_STIM25_STIM25_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM26
//
//*****************************************************************************
// Field: [31:0] STIM26
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA26 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM26_STIM26_W 32
#define CPU_ITM_STIM26_STIM26_M 0xFFFFFFFF
#define CPU_ITM_STIM26_STIM26_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM27
//
//*****************************************************************************
// Field: [31:0] STIM27
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA27 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM27_STIM27_W 32
#define CPU_ITM_STIM27_STIM27_M 0xFFFFFFFF
#define CPU_ITM_STIM27_STIM27_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM28
//
//*****************************************************************************
// Field: [31:0] STIM28
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA28 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM28_STIM28_W 32
#define CPU_ITM_STIM28_STIM28_M 0xFFFFFFFF
#define CPU_ITM_STIM28_STIM28_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM29
//
//*****************************************************************************
// Field: [31:0] STIM29
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA29 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM29_STIM29_W 32
#define CPU_ITM_STIM29_STIM29_M 0xFFFFFFFF
#define CPU_ITM_STIM29_STIM29_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM30
//
//*****************************************************************************
// Field: [31:0] STIM30
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA30 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM30_STIM30_W 32
#define CPU_ITM_STIM30_STIM30_M 0xFFFFFFFF
#define CPU_ITM_STIM30_STIM30_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_STIM31
//
//*****************************************************************************
// Field: [31:0] STIM31
//
// A write to this location causes data to be written into the FIFO if
// TER.STIMENA31 is set. Reading from the stimulus port returns the FIFO status
// in bit [0]: 0 = full, 1 = not full. The polled FIFO interface does not
// provide an atomic read-modify-write, so it's users responsibility to ensure
// exclusive read-modify-write if this ITM port is used concurrently by
// interrupts or other threads.
#define CPU_ITM_STIM31_STIM31_W 32
#define CPU_ITM_STIM31_STIM31_M 0xFFFFFFFF
#define CPU_ITM_STIM31_STIM31_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_TER
//
//*****************************************************************************
// Field: [31] STIMENA31
//
// Bit mask to enable tracing on ITM stimulus port 31.
#define CPU_ITM_TER_STIMENA31 0x80000000
#define CPU_ITM_TER_STIMENA31_BITN 31
#define CPU_ITM_TER_STIMENA31_M 0x80000000
#define CPU_ITM_TER_STIMENA31_S 31
// Field: [30] STIMENA30
//
// Bit mask to enable tracing on ITM stimulus port 30.
#define CPU_ITM_TER_STIMENA30 0x40000000
#define CPU_ITM_TER_STIMENA30_BITN 30
#define CPU_ITM_TER_STIMENA30_M 0x40000000
#define CPU_ITM_TER_STIMENA30_S 30
// Field: [29] STIMENA29
//
// Bit mask to enable tracing on ITM stimulus port 29.
#define CPU_ITM_TER_STIMENA29 0x20000000
#define CPU_ITM_TER_STIMENA29_BITN 29
#define CPU_ITM_TER_STIMENA29_M 0x20000000
#define CPU_ITM_TER_STIMENA29_S 29
// Field: [28] STIMENA28
//
// Bit mask to enable tracing on ITM stimulus port 28.
#define CPU_ITM_TER_STIMENA28 0x10000000
#define CPU_ITM_TER_STIMENA28_BITN 28
#define CPU_ITM_TER_STIMENA28_M 0x10000000
#define CPU_ITM_TER_STIMENA28_S 28
// Field: [27] STIMENA27
//
// Bit mask to enable tracing on ITM stimulus port 27.
#define CPU_ITM_TER_STIMENA27 0x08000000
#define CPU_ITM_TER_STIMENA27_BITN 27
#define CPU_ITM_TER_STIMENA27_M 0x08000000
#define CPU_ITM_TER_STIMENA27_S 27
// Field: [26] STIMENA26
//
// Bit mask to enable tracing on ITM stimulus port 26.
#define CPU_ITM_TER_STIMENA26 0x04000000
#define CPU_ITM_TER_STIMENA26_BITN 26
#define CPU_ITM_TER_STIMENA26_M 0x04000000
#define CPU_ITM_TER_STIMENA26_S 26
// Field: [25] STIMENA25
//
// Bit mask to enable tracing on ITM stimulus port 25.
#define CPU_ITM_TER_STIMENA25 0x02000000
#define CPU_ITM_TER_STIMENA25_BITN 25
#define CPU_ITM_TER_STIMENA25_M 0x02000000
#define CPU_ITM_TER_STIMENA25_S 25
// Field: [24] STIMENA24
//
// Bit mask to enable tracing on ITM stimulus port 24.
#define CPU_ITM_TER_STIMENA24 0x01000000
#define CPU_ITM_TER_STIMENA24_BITN 24
#define CPU_ITM_TER_STIMENA24_M 0x01000000
#define CPU_ITM_TER_STIMENA24_S 24
// Field: [23] STIMENA23
//
// Bit mask to enable tracing on ITM stimulus port 23.
#define CPU_ITM_TER_STIMENA23 0x00800000
#define CPU_ITM_TER_STIMENA23_BITN 23
#define CPU_ITM_TER_STIMENA23_M 0x00800000
#define CPU_ITM_TER_STIMENA23_S 23
// Field: [22] STIMENA22
//
// Bit mask to enable tracing on ITM stimulus port 22.
#define CPU_ITM_TER_STIMENA22 0x00400000
#define CPU_ITM_TER_STIMENA22_BITN 22
#define CPU_ITM_TER_STIMENA22_M 0x00400000
#define CPU_ITM_TER_STIMENA22_S 22
// Field: [21] STIMENA21
//
// Bit mask to enable tracing on ITM stimulus port 21.
#define CPU_ITM_TER_STIMENA21 0x00200000
#define CPU_ITM_TER_STIMENA21_BITN 21
#define CPU_ITM_TER_STIMENA21_M 0x00200000
#define CPU_ITM_TER_STIMENA21_S 21
// Field: [20] STIMENA20
//
// Bit mask to enable tracing on ITM stimulus port 20.
#define CPU_ITM_TER_STIMENA20 0x00100000
#define CPU_ITM_TER_STIMENA20_BITN 20
#define CPU_ITM_TER_STIMENA20_M 0x00100000
#define CPU_ITM_TER_STIMENA20_S 20
// Field: [19] STIMENA19
//
// Bit mask to enable tracing on ITM stimulus port 19.
#define CPU_ITM_TER_STIMENA19 0x00080000
#define CPU_ITM_TER_STIMENA19_BITN 19
#define CPU_ITM_TER_STIMENA19_M 0x00080000
#define CPU_ITM_TER_STIMENA19_S 19
// Field: [18] STIMENA18
//
// Bit mask to enable tracing on ITM stimulus port 18.
#define CPU_ITM_TER_STIMENA18 0x00040000
#define CPU_ITM_TER_STIMENA18_BITN 18
#define CPU_ITM_TER_STIMENA18_M 0x00040000
#define CPU_ITM_TER_STIMENA18_S 18
// Field: [17] STIMENA17
//
// Bit mask to enable tracing on ITM stimulus port 17.
#define CPU_ITM_TER_STIMENA17 0x00020000
#define CPU_ITM_TER_STIMENA17_BITN 17
#define CPU_ITM_TER_STIMENA17_M 0x00020000
#define CPU_ITM_TER_STIMENA17_S 17
// Field: [16] STIMENA16
//
// Bit mask to enable tracing on ITM stimulus port 16.
#define CPU_ITM_TER_STIMENA16 0x00010000
#define CPU_ITM_TER_STIMENA16_BITN 16
#define CPU_ITM_TER_STIMENA16_M 0x00010000
#define CPU_ITM_TER_STIMENA16_S 16
// Field: [15] STIMENA15
//
// Bit mask to enable tracing on ITM stimulus port 15.
#define CPU_ITM_TER_STIMENA15 0x00008000
#define CPU_ITM_TER_STIMENA15_BITN 15
#define CPU_ITM_TER_STIMENA15_M 0x00008000
#define CPU_ITM_TER_STIMENA15_S 15
// Field: [14] STIMENA14
//
// Bit mask to enable tracing on ITM stimulus port 14.
#define CPU_ITM_TER_STIMENA14 0x00004000
#define CPU_ITM_TER_STIMENA14_BITN 14
#define CPU_ITM_TER_STIMENA14_M 0x00004000
#define CPU_ITM_TER_STIMENA14_S 14
// Field: [13] STIMENA13
//
// Bit mask to enable tracing on ITM stimulus port 13.
#define CPU_ITM_TER_STIMENA13 0x00002000
#define CPU_ITM_TER_STIMENA13_BITN 13
#define CPU_ITM_TER_STIMENA13_M 0x00002000
#define CPU_ITM_TER_STIMENA13_S 13
// Field: [12] STIMENA12
//
// Bit mask to enable tracing on ITM stimulus port 12.
#define CPU_ITM_TER_STIMENA12 0x00001000
#define CPU_ITM_TER_STIMENA12_BITN 12
#define CPU_ITM_TER_STIMENA12_M 0x00001000
#define CPU_ITM_TER_STIMENA12_S 12
// Field: [11] STIMENA11
//
// Bit mask to enable tracing on ITM stimulus port 11.
#define CPU_ITM_TER_STIMENA11 0x00000800
#define CPU_ITM_TER_STIMENA11_BITN 11
#define CPU_ITM_TER_STIMENA11_M 0x00000800
#define CPU_ITM_TER_STIMENA11_S 11
// Field: [10] STIMENA10
//
// Bit mask to enable tracing on ITM stimulus port 10.
#define CPU_ITM_TER_STIMENA10 0x00000400
#define CPU_ITM_TER_STIMENA10_BITN 10
#define CPU_ITM_TER_STIMENA10_M 0x00000400
#define CPU_ITM_TER_STIMENA10_S 10
// Field: [9] STIMENA9
//
// Bit mask to enable tracing on ITM stimulus port 9.
#define CPU_ITM_TER_STIMENA9 0x00000200
#define CPU_ITM_TER_STIMENA9_BITN 9
#define CPU_ITM_TER_STIMENA9_M 0x00000200
#define CPU_ITM_TER_STIMENA9_S 9
// Field: [8] STIMENA8
//
// Bit mask to enable tracing on ITM stimulus port 8.
#define CPU_ITM_TER_STIMENA8 0x00000100
#define CPU_ITM_TER_STIMENA8_BITN 8
#define CPU_ITM_TER_STIMENA8_M 0x00000100
#define CPU_ITM_TER_STIMENA8_S 8
// Field: [7] STIMENA7
//
// Bit mask to enable tracing on ITM stimulus port 7.
#define CPU_ITM_TER_STIMENA7 0x00000080
#define CPU_ITM_TER_STIMENA7_BITN 7
#define CPU_ITM_TER_STIMENA7_M 0x00000080
#define CPU_ITM_TER_STIMENA7_S 7
// Field: [6] STIMENA6
//
// Bit mask to enable tracing on ITM stimulus port 6.
#define CPU_ITM_TER_STIMENA6 0x00000040
#define CPU_ITM_TER_STIMENA6_BITN 6
#define CPU_ITM_TER_STIMENA6_M 0x00000040
#define CPU_ITM_TER_STIMENA6_S 6
// Field: [5] STIMENA5
//
// Bit mask to enable tracing on ITM stimulus port 5.
#define CPU_ITM_TER_STIMENA5 0x00000020
#define CPU_ITM_TER_STIMENA5_BITN 5
#define CPU_ITM_TER_STIMENA5_M 0x00000020
#define CPU_ITM_TER_STIMENA5_S 5
// Field: [4] STIMENA4
//
// Bit mask to enable tracing on ITM stimulus port 4.
#define CPU_ITM_TER_STIMENA4 0x00000010
#define CPU_ITM_TER_STIMENA4_BITN 4
#define CPU_ITM_TER_STIMENA4_M 0x00000010
#define CPU_ITM_TER_STIMENA4_S 4
// Field: [3] STIMENA3
//
// Bit mask to enable tracing on ITM stimulus port 3.
#define CPU_ITM_TER_STIMENA3 0x00000008
#define CPU_ITM_TER_STIMENA3_BITN 3
#define CPU_ITM_TER_STIMENA3_M 0x00000008
#define CPU_ITM_TER_STIMENA3_S 3
// Field: [2] STIMENA2
//
// Bit mask to enable tracing on ITM stimulus port 2.
#define CPU_ITM_TER_STIMENA2 0x00000004
#define CPU_ITM_TER_STIMENA2_BITN 2
#define CPU_ITM_TER_STIMENA2_M 0x00000004
#define CPU_ITM_TER_STIMENA2_S 2
// Field: [1] STIMENA1
//
// Bit mask to enable tracing on ITM stimulus port 1.
#define CPU_ITM_TER_STIMENA1 0x00000002
#define CPU_ITM_TER_STIMENA1_BITN 1
#define CPU_ITM_TER_STIMENA1_M 0x00000002
#define CPU_ITM_TER_STIMENA1_S 1
// Field: [0] STIMENA0
//
// Bit mask to enable tracing on ITM stimulus port 0.
#define CPU_ITM_TER_STIMENA0 0x00000001
#define CPU_ITM_TER_STIMENA0_BITN 0
#define CPU_ITM_TER_STIMENA0_M 0x00000001
#define CPU_ITM_TER_STIMENA0_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_TPR
//
//*****************************************************************************
// Field: [3:0] PRIVMASK
//
// Bit mask to enable unprivileged (User) access to ITM stimulus ports:
//
// Bit [0] enables stimulus ports 0, 1, ..., and 7.
// Bit [1] enables stimulus ports 8, 9, ..., and 15.
// Bit [2] enables stimulus ports 16, 17, ..., and 23.
// Bit [3] enables stimulus ports 24, 25, ..., and 31.
//
// 0: User access allowed to stimulus ports
// 1: Privileged access only to stimulus ports
#define CPU_ITM_TPR_PRIVMASK_W 4
#define CPU_ITM_TPR_PRIVMASK_M 0x0000000F
#define CPU_ITM_TPR_PRIVMASK_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_TCR
//
//*****************************************************************************
// Field: [23] BUSY
//
// Set when ITM events present and being drained.
#define CPU_ITM_TCR_BUSY 0x00800000
#define CPU_ITM_TCR_BUSY_BITN 23
#define CPU_ITM_TCR_BUSY_M 0x00800000
#define CPU_ITM_TCR_BUSY_S 23
// Field: [22:16] ATBID
//
// Trace Bus ID for CoreSight system. Optional identifier for multi-source
// trace stream formatting. If multi-source trace is in use, this field must be
// written with a non-zero value.
#define CPU_ITM_TCR_ATBID_W 7
#define CPU_ITM_TCR_ATBID_M 0x007F0000
#define CPU_ITM_TCR_ATBID_S 16
// Field: [9:8] TSPRESCALE
//
// Timestamp prescaler
// ENUMs:
// DIV64 Divide by 64
// DIV16 Divide by 16
// DIV4 Divide by 4
// NOPRESCALING No prescaling
#define CPU_ITM_TCR_TSPRESCALE_W 2
#define CPU_ITM_TCR_TSPRESCALE_M 0x00000300
#define CPU_ITM_TCR_TSPRESCALE_S 8
#define CPU_ITM_TCR_TSPRESCALE_DIV64 0x00000300
#define CPU_ITM_TCR_TSPRESCALE_DIV16 0x00000200
#define CPU_ITM_TCR_TSPRESCALE_DIV4 0x00000100
#define CPU_ITM_TCR_TSPRESCALE_NOPRESCALING 0x00000000
// Field: [4] SWOENA
//
// Enables asynchronous clocking of the timestamp counter (when TSENA = 1). If
// TSENA = 0, writing this bit to 1 does not enable asynchronous clocking of
// the timestamp counter.
//
// 0x0: Mode disabled. Timestamp counter uses system clock from the core and
// counts continuously.
// 0x1: Timestamp counter uses lineout (data related) clock from TPIU
// interface. The timestamp counter is held in reset while the output line is
// idle.
#define CPU_ITM_TCR_SWOENA 0x00000010
#define CPU_ITM_TCR_SWOENA_BITN 4
#define CPU_ITM_TCR_SWOENA_M 0x00000010
#define CPU_ITM_TCR_SWOENA_S 4
// Field: [3] DWTENA
//
// Enables the DWT stimulus (hardware event packet emission to the TPIU from
// the DWT)
#define CPU_ITM_TCR_DWTENA 0x00000008
#define CPU_ITM_TCR_DWTENA_BITN 3
#define CPU_ITM_TCR_DWTENA_M 0x00000008
#define CPU_ITM_TCR_DWTENA_S 3
// Field: [2] SYNCENA
//
// Enables synchronization packet transmission for a synchronous TPIU.
// CPU_DWT:CTRL.SYNCTAP must be configured for the correct synchronization
// speed.
#define CPU_ITM_TCR_SYNCENA 0x00000004
#define CPU_ITM_TCR_SYNCENA_BITN 2
#define CPU_ITM_TCR_SYNCENA_M 0x00000004
#define CPU_ITM_TCR_SYNCENA_S 2
// Field: [1] TSENA
//
// Enables differential timestamps. Differential timestamps are emitted when a
// packet is written to the FIFO with a non-zero timestamp counter, and when
// the timestamp counter overflows. Timestamps are emitted during idle times
// after a fixed number of two million cycles. This provides a time reference
// for packets and inter-packet gaps. If SWOENA (bit [4]) is set, timestamps
// are triggered by activity on the internal trace bus only. In this case there
// is no regular timestamp output when the ITM is idle.
#define CPU_ITM_TCR_TSENA 0x00000002
#define CPU_ITM_TCR_TSENA_BITN 1
#define CPU_ITM_TCR_TSENA_M 0x00000002
#define CPU_ITM_TCR_TSENA_S 1
// Field: [0] ITMENA
//
// Enables ITM. This is the master enable, and must be set before ITM Stimulus
// and Trace Enable registers can be written.
#define CPU_ITM_TCR_ITMENA 0x00000001
#define CPU_ITM_TCR_ITMENA_BITN 0
#define CPU_ITM_TCR_ITMENA_M 0x00000001
#define CPU_ITM_TCR_ITMENA_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_LAR
//
//*****************************************************************************
// Field: [31:0] LOCK_ACCESS
//
// A privileged write of 0xC5ACCE55 enables more write access to Control
// Registers TER, TPR and TCR. An invalid write removes write access.
#define CPU_ITM_LAR_LOCK_ACCESS_W 32
#define CPU_ITM_LAR_LOCK_ACCESS_M 0xFFFFFFFF
#define CPU_ITM_LAR_LOCK_ACCESS_S 0
//*****************************************************************************
//
// Register: CPU_ITM_O_LSR
//
//*****************************************************************************
// Field: [2] BYTEACC
//
// Reads 0 which means 8-bit lock access is not be implemented.
#define CPU_ITM_LSR_BYTEACC 0x00000004
#define CPU_ITM_LSR_BYTEACC_BITN 2
#define CPU_ITM_LSR_BYTEACC_M 0x00000004
#define CPU_ITM_LSR_BYTEACC_S 2
// Field: [1] ACCESS
//
// Write access to component is blocked. All writes are ignored, reads are
// permitted.
#define CPU_ITM_LSR_ACCESS 0x00000002
#define CPU_ITM_LSR_ACCESS_BITN 1
#define CPU_ITM_LSR_ACCESS_M 0x00000002
#define CPU_ITM_LSR_ACCESS_S 1
// Field: [0] PRESENT
//
// Indicates that a lock mechanism exists for this component.
#define CPU_ITM_LSR_PRESENT 0x00000001
#define CPU_ITM_LSR_PRESENT_BITN 0
#define CPU_ITM_LSR_PRESENT_M 0x00000001
#define CPU_ITM_LSR_PRESENT_S 0
#endif // __CPU_ITM__