aboutsummaryrefslogtreecommitdiff
path: root/src/target/arm_coresight.h
blob: 58139dcdbe9ab4694e7125f53ac6551c10ab8838 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
/* SPDX-License-Identifier: GPL-2.0-or-later */

/*
 * General info from:
 * ARM CoreSight Architecture Specification v3.0 IHI0029E
 */

#ifndef OPENOCD_TARGET_ARM_CORESIGHT_H
#define OPENOCD_TARGET_ARM_CORESIGHT_H

#include <stdbool.h>
#include <stdint.h>

#include <helper/bits.h>

#define ARM_CS_ALIGN                            (0x1000)

/* mandatory registers */
#define ARM_CS_PIDR0                            (0xFE0)
#define ARM_CS_PIDR1                            (0xFE4)
#define ARM_CS_PIDR2                            (0xFE8)
#define ARM_CS_PIDR3                            (0xFEC)
#define ARM_CS_PIDR4                            (0xFD0)
#define ARM_CS_PIDR5                            (0xFD4)
#define ARM_CS_PIDR6                            (0xFD8)
#define ARM_CS_PIDR7                            (0xFDC)

/*
 * When PIDR bit JEDEC is zero, only the lowers 7 bits of DESIGNER are valid
 * and represent a legacy ASCII Identity Code.
 */
#define ARM_CS_PIDR_PART(pidr)                  ((pidr) & 0x0FFF)
#define ARM_CS_PIDR_DESIGNER(pidr)              \
({                                              \
	typeof(pidr) _x = (pidr);                   \
	((_x >> 25) & 0x780) | ((_x >> 12) & 0x7F); \
})
#define ARM_CS_PIDR_JEDEC                       BIT(19)
#define ARM_CS_PIDR_SIZE(pidr)                  (((pidr) >> 36) & 0x000F)

#define ARM_CS_CIDR0                            (0xFF0)
#define ARM_CS_CIDR1                            (0xFF4)
#define ARM_CS_CIDR2                            (0xFF8)
#define ARM_CS_CIDR3                            (0xFFC)

#define ARM_CS_CIDR_CLASS_MASK                  (0x0000F000)
#define ARM_CS_CIDR_CLASS(cidr)                 (((cidr) >> 12) & 0x000F)
#define ARM_CS_CLASS_0X1_ROM_TABLE              (0x1)
#define ARM_CS_CLASS_0X9_CS_COMPONENT           (0x9)

static inline bool is_valid_arm_cs_cidr(uint32_t cidr)
{
	return (cidr & ~ARM_CS_CIDR_CLASS_MASK) == 0xB105000D;
}

/* Class 0x9 only registers */
#define ARM_CS_C9_DEVARCH                       (0xFBC)

#define ARM_CS_C9_DEVARCH_ARCHID_MASK           (0x0000FFFF)
#define ARM_CS_C9_DEVARCH_ARCHID_SHIFT          (0)
#define ARM_CS_C9_DEVARCH_REVISION_MASK         (0x000F0000)
#define ARM_CS_C9_DEVARCH_REVISION_SHIFT        (16)
#define ARM_CS_C9_DEVARCH_PRESENT               BIT(20)
#define ARM_CS_C9_DEVARCH_ARCHITECT_MASK        (0xFFE00000)
#define ARM_CS_C9_DEVARCH_ARCHITECT_SHIFT       (21)
#define ARM_CS_C9_DEVARCH_REVISION(devarch)     \
	(((devarch) & ARM_CS_C9_DEVARCH_REVISION_MASK) >> ARM_CS_C9_DEVARCH_REVISION_SHIFT)
#define ARM_CS_C9_DEVARCH_ARCHITECT(devarch)    \
	(((devarch) & ARM_CS_C9_DEVARCH_ARCHITECT_MASK) >> ARM_CS_C9_DEVARCH_ARCHITECT_SHIFT)

#define ARM_CS_C9_DEVID                         (0xFC8)

#define ARM_CS_C9_DEVID_FORMAT_MASK             (0x0000000F)
#define ARM_CS_C9_DEVID_FORMAT_32BIT            (0)
#define ARM_CS_C9_DEVID_FORMAT_64BIT            (1)
#define ARM_CS_C9_DEVID_SYSMEM_MASK             BIT(4)
#define ARM_CS_C9_DEVID_PRR_MASK                BIT(5)
#define ARM_CS_C9_DEVID_CP_MASK                 BIT(5)

#define ARM_CS_C9_DEVTYPE                       (0xFCC)

#define ARM_CS_C9_DEVTYPE_MAJOR_MASK            (0x0000000F)
#define ARM_CS_C9_DEVTYPE_MAJOR_SHIFT           (0)
#define ARM_CS_C9_DEVTYPE_SUB_MASK              (0x000000F0)
#define ARM_CS_C9_DEVTYPE_SUB_SHIFT             (4)

#define ARM_CS_C9_DEVTYPE_MASK                  (0x000000FF)
#define ARM_CS_C9_DEVTYPE_CORE_DEBUG            (0x00000015)

/* Class 0x1 only registers */
#define ARM_CS_C1_MEMTYPE                       ARM_CS_C9_DEVTYPE

#define ARM_CS_C1_MEMTYPE_SYSMEM_MASK           BIT(0)

/* The coding of ROM entry present differs between Class 0x9 and Class 0x1,
 * but we can simplify the whole management */
#define ARM_CS_ROMENTRY_PRESENT                 BIT(0)
#define ARM_CS_ROMENTRY_OFFSET_MASK             (0xFFFFF000U)

#endif /* OPENOCD_TARGET_ARM_CORESIGHT_H */