blob: c695ffc71f5c2458fd6630232f16a8b78059239b [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Paul Burtonb2b135d2016-09-21 11:18:53 +01002/*
3 * MIPS Coherence Manager (CM) Register Definitions
4 *
5 * Copyright (c) 2016 Imagination Technologies Ltd.
Paul Burtonb2b135d2016-09-21 11:18:53 +01006 */
7#ifndef __MIPS_ASM_CM_H__
8#define __MIPS_ASM_CM_H__
9
10/* Global Control Register (GCR) offsets */
Weijie Gao3a6cf2d2022-05-20 11:21:39 +080011#define GCR_CONFIG 0x0000
Paul Burtonb2b135d2016-09-21 11:18:53 +010012#define GCR_BASE 0x0008
13#define GCR_BASE_UPPER 0x000c
Weijie Gao3a6cf2d2022-05-20 11:21:39 +080014#define GCR_CONTROL 0x0010
15#define GCR_ACCESS 0x0020
Paul Burtonb2b135d2016-09-21 11:18:53 +010016#define GCR_REV 0x0030
Weijie Gao3a6cf2d2022-05-20 11:21:39 +080017#define GCR_GIC_BASE 0x0080
18#define GCR_CPC_BASE 0x0088
19#define GCR_REG0_BASE 0x0090
20#define GCR_REG0_MASK 0x0098
21#define GCR_REG1_BASE 0x00a0
22#define GCR_REG1_MASK 0x00a8
23#define GCR_REG2_BASE 0x00b0
24#define GCR_REG2_MASK 0x00b8
25#define GCR_REG3_BASE 0x00c0
26#define GCR_REG3_MASK 0x00c8
27#define GCR_CPC_STATUS 0x00f0
Paul Burton4baa0ab2016-09-21 11:18:54 +010028#define GCR_L2_CONFIG 0x0130
29#define GCR_L2_TAG_ADDR 0x0600
30#define GCR_L2_TAG_ADDR_UPPER 0x0604
31#define GCR_L2_TAG_STATE 0x0608
32#define GCR_L2_TAG_STATE_UPPER 0x060c
33#define GCR_L2_DATA 0x0610
34#define GCR_L2_DATA_UPPER 0x0614
Paul Burton79533542016-09-21 11:18:55 +010035#define GCR_Cx_COHERENCE 0x2008
Weijie Gao3a6cf2d2022-05-20 11:21:39 +080036#define GCR_Cx_OTHER 0x2018
37#define GCR_Cx_ID 0x2028
38#define GCR_CO_COHERENCE 0x4008
39
40/* GCR_CONFIG fields */
41#define GCR_CONFIG_NUM_CLUSTERS_SHIFT 23
42#define GCR_CONFIG_NUM_CLUSTERS (0x7f << 23)
43#define GCR_CONFIG_NUMIOCU_SHIFT 8
44#define GCR_CONFIG_NUMIOCU (0xff << 8)
45#define GCR_CONFIG_PCORES_SHIFT 0
46#define GCR_CONFIG_PCORES (0xff << 0)
47
48/* GCR_BASE fields */
49#define GCR_BASE_SHIFT 15
50#define CCA_DEFAULT_OVR_SHIFT 5
51#define CCA_DEFAULT_OVR_MASK (0x7 << 5)
52#define CCA_DEFAULT_OVREN (0x1 << 4)
53#define CM_DEFAULT_TARGET_SHIFT 0
54#define CM_DEFAULT_TARGET_MASK (0x3 << 0)
55
56/* GCR_CONTROL fields */
57#define GCR_CONTROL_SYNCCTL (0x1 << 16)
Paul Burtonb2b135d2016-09-21 11:18:53 +010058
59/* GCR_REV CM versions */
60#define GCR_REV_CM3 0x0800
61
Weijie Gao3a6cf2d2022-05-20 11:21:39 +080062/* GCR_GIC_BASE fields */
63#define GCR_GIC_BASE_ADDRMASK_SHIFT 7
64#define GCR_GIC_BASE_ADDRMASK (0x1ffffff << 7)
65#define GCR_GIC_EN (0x1 << 0)
66
67/* GCR_CPC_BASE fields */
68#define GCR_CPC_BASE_ADDRMASK_SHIFT 15
69#define GCR_CPC_BASE_ADDRMASK (0x1ffff << 15)
70#define GCR_CPC_EN (0x1 << 0)
71
72/* GCR_REGn_MASK fields */
73#define GCR_REGn_MASK_ADDRMASK_SHIFT 16
74#define GCR_REGn_MASK_ADDRMASK (0xffff << 16)
75#define GCR_REGn_MASK_CCAOVR_SHIFT 5
76#define GCR_REGn_MASK_CCAOVR (0x7 << 5)
77#define GCR_REGn_MASK_CCAOVREN (1 << 4)
78#define GCR_REGn_MASK_DROPL2 (1 << 2)
79#define GCR_REGn_MASK_CMTGT_SHIFT 0
80#define GCR_REGn_MASK_CMTGT (0x3 << 0)
81#define GCR_REGn_MASK_CMTGT_DISABLED 0x0
82#define GCR_REGn_MASK_CMTGT_MEM 0x1
83#define GCR_REGn_MASK_CMTGT_IOCU0 0x2
84#define GCR_REGn_MASK_CMTGT_IOCU1 0x3
85
86/* GCR_CPC_STATUS fields */
87#define GCR_CPC_EX (0x1 << 0)
88
Paul Burton4baa0ab2016-09-21 11:18:54 +010089/* GCR_L2_CONFIG fields */
90#define GCR_L2_CONFIG_ASSOC_SHIFT 0
91#define GCR_L2_CONFIG_ASSOC_BITS 8
92#define GCR_L2_CONFIG_LINESZ_SHIFT 8
93#define GCR_L2_CONFIG_LINESZ_BITS 4
94#define GCR_L2_CONFIG_SETSZ_SHIFT 12
95#define GCR_L2_CONFIG_SETSZ_BITS 4
96#define GCR_L2_CONFIG_BYPASS (1 << 20)
97
Paul Burton79533542016-09-21 11:18:55 +010098/* GCR_Cx_COHERENCE */
99#define GCR_Cx_COHERENCE_DOM_EN (0xff << 0)
100#define GCR_Cx_COHERENCE_EN (0x1 << 0)
101
Weijie Gao3a6cf2d2022-05-20 11:21:39 +0800102/* GCR_Cx_OTHER fields */
103#define GCR_Cx_OTHER_CORENUM_SHIFT 16
104#define GCR_Cx_OTHER_CORENUM (0xffff << 16)
105
Paul Burton4baa0ab2016-09-21 11:18:54 +0100106#ifndef __ASSEMBLY__
107
108#include <asm/io.h>
Simon Glasscd93d622020-05-10 11:40:13 -0600109#include <linux/bitops.h>
Paul Burton4baa0ab2016-09-21 11:18:54 +0100110
Simon Glassa8673922023-02-05 15:40:15 -0700111#if IS_ENABLED(CONFIG_MIPS_CM)
Paul Burton4baa0ab2016-09-21 11:18:54 +0100112static inline void *mips_cm_base(void)
113{
114 return (void *)CKSEG1ADDR(CONFIG_MIPS_CM_BASE);
115}
116
117static inline unsigned long mips_cm_l2_line_size(void)
118{
119 unsigned long l2conf, line_sz;
120
121 l2conf = __raw_readl(mips_cm_base() + GCR_L2_CONFIG);
122
123 line_sz = l2conf >> GCR_L2_CONFIG_LINESZ_SHIFT;
124 line_sz &= GENMASK(GCR_L2_CONFIG_LINESZ_BITS - 1, 0);
125 return line_sz ? (2 << line_sz) : 0;
126}
Stefan Roese2eed3dc2020-05-14 11:59:03 +0200127#else
128static inline void *mips_cm_base(void)
129{
130 return NULL;
131}
132
133static inline unsigned long mips_cm_l2_line_size(void)
134{
135 return 0;
136}
137#endif
Paul Burton4baa0ab2016-09-21 11:18:54 +0100138
139#endif /* !__ASSEMBLY__ */
140
Paul Burtonb2b135d2016-09-21 11:18:53 +0100141#endif /* __MIPS_ASM_CM_H__ */