OpenOCD
arm_coresight.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
2 
3 /*
4  * General info from:
5  * ARM CoreSight Architecture Specification v3.0 IHI0029E
6  */
7 
8 #ifndef OPENOCD_TARGET_ARM_CORESIGHT_H
9 #define OPENOCD_TARGET_ARM_CORESIGHT_H
10 
11 #include <stdbool.h>
12 #include <stdint.h>
13 
14 #include <helper/bits.h>
15 
16 #define ARM_CS_ALIGN (0x1000)
17 
18 /* mandatory registers */
19 #define ARM_CS_PIDR0 (0xFE0)
20 #define ARM_CS_PIDR1 (0xFE4)
21 #define ARM_CS_PIDR2 (0xFE8)
22 #define ARM_CS_PIDR3 (0xFEC)
23 #define ARM_CS_PIDR4 (0xFD0)
24 #define ARM_CS_PIDR5 (0xFD4)
25 #define ARM_CS_PIDR6 (0xFD8)
26 #define ARM_CS_PIDR7 (0xFDC)
27 
28 /* lock/unlock registers on most(?) CS devices */
29 #define ARM_CS_LAR (0xFB0)
30 #define ARM_CS_LSR (0xFB4)
31 #define ARM_CS_LSR_SLI BIT(0)
32 #define ARM_CS_LSR_SLK BIT(1)
33 #define ARM_CS_AUTHSTATUS (0xFB8)
34 
35 #define ARM_CS_LAR_UNLOCK_KEY (0xC5ACCE55)
36 
37 /*
38  * When PIDR bit JEDEC is zero, only the lowers 7 bits of DESIGNER are valid
39  * and represent a legacy ASCII Identity Code.
40  */
41 #define ARM_CS_PIDR_PART(pidr) ((pidr) & 0x0FFF)
42 #define ARM_CS_PIDR_DESIGNER(pidr) \
43 ({ \
44  typeof(pidr) _x = (pidr); \
45  ((_x >> 25) & 0x780) | ((_x >> 12) & 0x7F); \
46 })
47 #define ARM_CS_PIDR_JEDEC BIT(19)
48 #define ARM_CS_PIDR_SIZE(pidr) (((pidr) >> 36) & 0x000F)
49 
50 #define ARM_CS_CIDR0 (0xFF0)
51 #define ARM_CS_CIDR1 (0xFF4)
52 #define ARM_CS_CIDR2 (0xFF8)
53 #define ARM_CS_CIDR3 (0xFFC)
54 
55 #define ARM_CS_CIDR_CLASS_MASK (0x0000F000)
56 #define ARM_CS_CIDR_CLASS(cidr) (((cidr) >> 12) & 0x000F)
57 #define ARM_CS_CLASS_0X1_ROM_TABLE (0x1)
58 #define ARM_CS_CLASS_0X9_CS_COMPONENT (0x9)
59 
60 static inline bool is_valid_arm_cs_cidr(uint32_t cidr)
61 {
62  return (cidr & ~ARM_CS_CIDR_CLASS_MASK) == 0xB105000D;
63 }
64 
65 /* Class 0x9 only registers */
66 #define ARM_CS_C9_DEVARCH (0xFBC)
67 
68 #define ARM_CS_C9_DEVARCH_ARCHID_MASK (0x0000FFFF)
69 #define ARM_CS_C9_DEVARCH_ARCHID_SHIFT (0)
70 #define ARM_CS_C9_DEVARCH_REVISION_MASK (0x000F0000)
71 #define ARM_CS_C9_DEVARCH_REVISION_SHIFT (16)
72 #define ARM_CS_C9_DEVARCH_PRESENT BIT(20)
73 #define ARM_CS_C9_DEVARCH_ARCHITECT_MASK (0xFFE00000)
74 #define ARM_CS_C9_DEVARCH_ARCHITECT_SHIFT (21)
75 #define ARM_CS_C9_DEVARCH_REVISION(devarch) \
76  (((devarch) & ARM_CS_C9_DEVARCH_REVISION_MASK) >> ARM_CS_C9_DEVARCH_REVISION_SHIFT)
77 #define ARM_CS_C9_DEVARCH_ARCHITECT(devarch) \
78  (((devarch) & ARM_CS_C9_DEVARCH_ARCHITECT_MASK) >> ARM_CS_C9_DEVARCH_ARCHITECT_SHIFT)
79 
80 #define ARM_CS_C9_DEVID (0xFC8)
81 
82 #define ARM_CS_C9_DEVID_FORMAT_MASK (0x0000000F)
83 #define ARM_CS_C9_DEVID_FORMAT_32BIT (0)
84 #define ARM_CS_C9_DEVID_FORMAT_64BIT (1)
85 #define ARM_CS_C9_DEVID_SYSMEM_MASK BIT(4)
86 #define ARM_CS_C9_DEVID_PRR_MASK BIT(5)
87 #define ARM_CS_C9_DEVID_CP_MASK BIT(5)
88 
89 #define ARM_CS_C9_DEVTYPE (0xFCC)
90 
91 #define ARM_CS_C9_DEVTYPE_MAJOR_MASK (0x0000000F)
92 #define ARM_CS_C9_DEVTYPE_MAJOR_SHIFT (0)
93 #define ARM_CS_C9_DEVTYPE_SUB_MASK (0x000000F0)
94 #define ARM_CS_C9_DEVTYPE_SUB_SHIFT (4)
95 
96 #define ARM_CS_C9_DEVTYPE_MASK (0x000000FF)
97 #define ARM_CS_C9_DEVTYPE_CORE_DEBUG (0x00000015)
98 
99 /* Class 0x1 only registers */
100 #define ARM_CS_C1_MEMTYPE ARM_CS_C9_DEVTYPE
101 
102 #define ARM_CS_C1_MEMTYPE_SYSMEM_MASK BIT(0)
103 
104 /* The coding of ROM entry present differs between Class 0x9 and Class 0x1,
105  * but we can simplify the whole management */
106 #define ARM_CS_ROMENTRY_PRESENT BIT(0)
107 #define ARM_CS_ROMENTRY_OFFSET_MASK (0xFFFFF000U)
108 
109 #endif /* OPENOCD_TARGET_ARM_CORESIGHT_H */
static bool is_valid_arm_cs_cidr(uint32_t cidr)
Definition: arm_coresight.h:60
#define ARM_CS_CIDR_CLASS_MASK
Definition: arm_coresight.h:55