hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
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
/*
 * MIPS Coherence Manager (CM) Register Definitions
 *
 * Copyright (c) 2016 Imagination Technologies Ltd.
 *
 * SPDX-License-Identifier:    GPL-2.0+
 */
#ifndef __MIPS_ASM_CM_H__
#define __MIPS_ASM_CM_H__
 
/* Global Control Register (GCR) offsets */
#define GCR_BASE            0x0008
#define GCR_BASE_UPPER            0x000c
#define GCR_REV                0x0030
#define GCR_L2_CONFIG            0x0130
#define GCR_L2_TAG_ADDR            0x0600
#define GCR_L2_TAG_ADDR_UPPER        0x0604
#define GCR_L2_TAG_STATE        0x0608
#define GCR_L2_TAG_STATE_UPPER        0x060c
#define GCR_L2_DATA            0x0610
#define GCR_L2_DATA_UPPER        0x0614
#define GCR_Cx_COHERENCE        0x2008
 
/* GCR_REV CM versions */
#define GCR_REV_CM3            0x0800
 
/* GCR_L2_CONFIG fields */
#define GCR_L2_CONFIG_ASSOC_SHIFT    0
#define GCR_L2_CONFIG_ASSOC_BITS    8
#define GCR_L2_CONFIG_LINESZ_SHIFT    8
#define GCR_L2_CONFIG_LINESZ_BITS    4
#define GCR_L2_CONFIG_SETSZ_SHIFT    12
#define GCR_L2_CONFIG_SETSZ_BITS    4
#define GCR_L2_CONFIG_BYPASS        (1 << 20)
 
/* GCR_Cx_COHERENCE */
#define GCR_Cx_COHERENCE_DOM_EN        (0xff << 0)
#define GCR_Cx_COHERENCE_EN        (0x1 << 0)
 
#ifndef __ASSEMBLY__
 
#include <asm/io.h>
 
static inline void *mips_cm_base(void)
{
   return (void *)CKSEG1ADDR(CONFIG_MIPS_CM_BASE);
}
 
static inline unsigned long mips_cm_l2_line_size(void)
{
   unsigned long l2conf, line_sz;
 
   l2conf = __raw_readl(mips_cm_base() + GCR_L2_CONFIG);
 
   line_sz = l2conf >> GCR_L2_CONFIG_LINESZ_SHIFT;
   line_sz &= GENMASK(GCR_L2_CONFIG_LINESZ_BITS - 1, 0);
   return line_sz ? (2 << line_sz) : 0;
}
 
#endif /* !__ASSEMBLY__ */
 
#endif /* __MIPS_ASM_CM_H__ */