aboutsummaryrefslogtreecommitdiff
path: root/platform/generic/include/eswin/eic770x.h
blob: 67764ec05402f2788d18f6d9d3395613f530dc84 (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
101
/*
 * SPDX-License-Identifier: BSD-2-Clause
 *
 * Copyright (c) 2025 Bo Gan <ganboing@gmail.com>
 *
 */

#ifndef __EIC770X_H__
#define __EIC770X_H__

#include <sbi/riscv_asm.h>

struct eic770x_board_override {
	struct sbi_system_reset_device *reset_dev;
};

/* CSRs */
#define EIC770X_CSR_BRPREDICT	0x7c0
#define EIC770X_CSR_FEAT0	0x7c1
#define EIC770X_CSR_FEAT1	0x7c2
#define EIC770X_CSR_L1_HWPF	0x7c3
#define EIC770X_CSR_L2_HWPF	0x7c4

/* Hart ID to core/die conversion */
#define CPU_CORE_BITS		2
#define CPU_CORE_MASK		((1 << CPU_CORE_BITS) - 1)
#define CPU_DIE_SHIFT		CPU_CORE_BITS
#define CPU_DIE_BITS		1
#define CPU_DIE_MASK		((1 << CPU_DIE_BITS) - 1)

#define hart_core(i)		((i) & CPU_CORE_MASK)
#define hart_die(i)		(((i) >> CPU_DIE_SHIFT) & CPU_DIE_MASK)
#define current_hart_core()	hart_core(current_hartid())
#define current_hart_die()	hart_die(current_hartid())

/* P550 Internal and System Port 0 */
#define EIC770X_P550INT_SIZE	0x20000000UL
#define EIC770X_P550INT_BASE(d)	(0UL + EIC770X_P550INT_SIZE * (d))
#define EIC770X_P550INT_LOCAL	EIC770X_P550INT_BASE(current_hart_die())
#define EIC770X_TL64D2D_OUT	(EIC770X_P550INT_LOCAL + 0x200000)
#define EIC770X_TL256D2D_OUT	(EIC770X_P550INT_LOCAL + 0x202000)
#define EIC770X_TL256D2D_IN	(EIC770X_P550INT_LOCAL + 0x204000)
#define EIC770X_L3_ZERO_SIZE	0x400000UL
#define EIC770X_L3_ZERO_BASE(d)	(EIC770X_P550INT_BASE(d) + 0x1a000000)
#define EIC770X_L3_ZERO_LOCAL	EIC770X_L3_ZERO_BASE(current_hart_die())
#define EIC770X_L3_ZERO_REMOTE	EIC770X_L3_ZERO_BASE(1 - current_hart_die())

#define EIC770X_SYSPORT_SIZE	0x20000000UL
#define EIC770X_SYSPORT_BASE(d)	(0x40000000UL + EIC770X_SYSPORT_SIZE * (d))
#define EIC770X_SYSPORT_LOCAL	EIC770X_SYSPORT_BASE(current_hart_die())

#define EIC770X_UART0		(EIC770X_SYSPORT_LOCAL + 0x10900000UL)
#define EIC770X_UART_SIZE	0x10000UL
#define EIC770X_UART(x)		(EIC770X_UART0 + EIC770X_UART_SIZE * (x))
#define EIC770X_UART_REG_SHIFT	2
#define EIC770X_UART_REG_WIDTH	4

#define EIC770X_SYSCRG		(EIC770X_SYSPORT_LOCAL + 0x11828000UL)
#define EIC770X_SYSCRG_LSPCLK0	(EIC770X_SYSCRG + 0x200UL)
#define EIC770X_SYSCRG_SYSCLK	(EIC770X_SYSCRG + 0x20cUL)
#define EIC770X_SYSCRG_RST	(EIC770X_SYSCRG + 0x300UL)
#define EIC770X_SYSCRG_RST_VAL	0x1AC0FFE6UL

/* Memory Ports */
#define EIC770X_MEMPORT_BASE	0x0080000000UL // 2G
#define EIC770X_MEMPORT_SIZE	0x7f80000000UL // +510G
#define EIC770X_MEMPORT_LIMIT	(EIC770X_MEMPORT_BASE + EIC770X_MEMPORT_SIZE)
#define EIC770X_D0_MEM_BASE	0x0080000000UL // 2G
#define EIC770X_D0_MEM_SIZE	0x0f80000000UL // +62G
#define EIC770X_D0_MEM_LIMIT	(EIC770X_D0_MEM_BASE + EIC770X_D0_MEM_SIZE)
#define EIC770X_D1_MEM_BASE	0x2000000000UL // 128G
#define EIC770X_D1_MEM_SIZE	0x1000000000UL // +64G
#define EIC770X_D1_MEM_LIMIT	(EIC770X_D1_MEM_BASE + EIC770X_D1_MEM_SIZE)
#define EIC770X_CACHED_BASE	(current_hart_die() ? \
				EIC770X_D1_MEM_BASE : \
				EIC770X_D0_MEM_BASE)

/* Uncached memory mapped in System Port 1 */
#define EIC770X_D0_UC_BASE	0xc000000000UL
#define EIC770X_D1_UC_BASE	0xe000000000UL
#define EIC770X_UNCACHED_BASE	(current_hart_die() ? \
				EIC770X_D1_UC_BASE : \
				EIC770X_D0_UC_BASE)

#define EIC770X_TO_UNCACHED(x)	((x) - EIC770X_CACHED_BASE + \
				EIC770X_UNCACHED_BASE)

/* Clock definitions */
#define EIC770X_XTAL_CLK_RATE	24000000UL
#define EIC770X_SPLL0_OUT1_RATE	1600000000UL
#define EIC770X_SPLL0_OUT2_RATE	800000000UL
#define EIC770X_SPLL0_OUT3_RATE	400000000UL
#define EIC770X_UART_CLK_BIT(x)	(1UL << ((x) + 17))
#define EIC770X_SYSCLK_SEL(x)	((x) & 1)
#define EIC770X_SYSCLK_DIV(x) 				\
	({ 						\
		uint32_t divisor = ((x) >> 4) & 7; 	\
		divisor > 2 ? divisor : 2; 		\
	})

#endif