xref: /rk3399_rockchip-uboot/arch/mips/include/asm/addrspace.h (revision b57843e68804c2d53d2cff2b8b2238e37b388faa)
1819833afSPeter Tyser /*
2819833afSPeter Tyser  * Copyright (C) 1996, 99 Ralf Baechle
3819833afSPeter Tyser  * Copyright (C) 2000, 2002  Maciej W. Rozycki
4819833afSPeter Tyser  * Copyright (C) 1990, 1999 by Silicon Graphics, Inc.
5*898582bdSDaniel Schwierzeck  *
6*898582bdSDaniel Schwierzeck  * SPDX-License-Identifier:	GPL-2.0
7819833afSPeter Tyser  */
8819833afSPeter Tyser #ifndef _ASM_ADDRSPACE_H
9819833afSPeter Tyser #define _ASM_ADDRSPACE_H
10819833afSPeter Tyser 
1123ff8633SDaniel Schwierzeck #include <spaces.h>
1223ff8633SDaniel Schwierzeck 
13819833afSPeter Tyser /*
14819833afSPeter Tyser  *  Configure language
15819833afSPeter Tyser  */
16819833afSPeter Tyser #ifdef __ASSEMBLY__
17819833afSPeter Tyser #define _ATYPE_
18819833afSPeter Tyser #define _ATYPE32_
19819833afSPeter Tyser #define _ATYPE64_
20819833afSPeter Tyser #define _CONST64_(x)	x
21819833afSPeter Tyser #else
22819833afSPeter Tyser #define _ATYPE_		__PTRDIFF_TYPE__
23819833afSPeter Tyser #define _ATYPE32_	int
24819833afSPeter Tyser #define _ATYPE64_	__s64
25819833afSPeter Tyser #ifdef CONFIG_64BIT
26819833afSPeter Tyser #define _CONST64_(x)	x ## L
27819833afSPeter Tyser #else
28819833afSPeter Tyser #define _CONST64_(x)	x ## LL
29819833afSPeter Tyser #endif
30819833afSPeter Tyser #endif
31819833afSPeter Tyser 
32819833afSPeter Tyser /*
33819833afSPeter Tyser  *  32-bit MIPS address spaces
34819833afSPeter Tyser  */
35819833afSPeter Tyser #ifdef __ASSEMBLY__
36819833afSPeter Tyser #define _ACAST32_
37819833afSPeter Tyser #define _ACAST64_
38819833afSPeter Tyser #else
39819833afSPeter Tyser #define _ACAST32_		(_ATYPE_)(_ATYPE32_)	/* widen if necessary */
40819833afSPeter Tyser #define _ACAST64_		(_ATYPE64_)		/* do _not_ narrow */
41819833afSPeter Tyser #endif
42819833afSPeter Tyser 
43819833afSPeter Tyser /*
44819833afSPeter Tyser  * Returns the kernel segment base of a given address
45819833afSPeter Tyser  */
46819833afSPeter Tyser #define KSEGX(a)		((_ACAST32_ (a)) & 0xe0000000)
47819833afSPeter Tyser 
48819833afSPeter Tyser /*
49819833afSPeter Tyser  * Returns the physical address of a CKSEGx / XKPHYS address
50819833afSPeter Tyser  */
51819833afSPeter Tyser #define CPHYSADDR(a)		((_ACAST32_(a)) & 0x1fffffff)
52819833afSPeter Tyser #define XPHYSADDR(a)		((_ACAST64_(a)) &			\
5323ff8633SDaniel Schwierzeck 				 _CONST64_(0x0000ffffffffffff))
54819833afSPeter Tyser 
55819833afSPeter Tyser #ifdef CONFIG_64BIT
56819833afSPeter Tyser 
57819833afSPeter Tyser /*
58819833afSPeter Tyser  * Memory segments (64bit kernel mode addresses)
59819833afSPeter Tyser  * The compatibility segments use the full 64-bit sign extended value.  Note
60819833afSPeter Tyser  * the R8000 doesn't have them so don't reference these in generic MIPS code.
61819833afSPeter Tyser  */
62819833afSPeter Tyser #define XKUSEG			_CONST64_(0x0000000000000000)
63819833afSPeter Tyser #define XKSSEG			_CONST64_(0x4000000000000000)
64819833afSPeter Tyser #define XKPHYS			_CONST64_(0x8000000000000000)
65819833afSPeter Tyser #define XKSEG			_CONST64_(0xc000000000000000)
66819833afSPeter Tyser #define CKSEG0			_CONST64_(0xffffffff80000000)
67819833afSPeter Tyser #define CKSEG1			_CONST64_(0xffffffffa0000000)
68819833afSPeter Tyser #define CKSSEG			_CONST64_(0xffffffffc0000000)
69819833afSPeter Tyser #define CKSEG3			_CONST64_(0xffffffffe0000000)
70819833afSPeter Tyser 
71819833afSPeter Tyser #define CKSEG0ADDR(a)		(CPHYSADDR(a) | CKSEG0)
72819833afSPeter Tyser #define CKSEG1ADDR(a)		(CPHYSADDR(a) | CKSEG1)
73819833afSPeter Tyser #define CKSEG2ADDR(a)		(CPHYSADDR(a) | CKSEG2)
74819833afSPeter Tyser #define CKSEG3ADDR(a)		(CPHYSADDR(a) | CKSEG3)
75819833afSPeter Tyser 
76819833afSPeter Tyser #else
77819833afSPeter Tyser 
78819833afSPeter Tyser #define CKSEG0ADDR(a)		(CPHYSADDR(a) | KSEG0)
79819833afSPeter Tyser #define CKSEG1ADDR(a)		(CPHYSADDR(a) | KSEG1)
80819833afSPeter Tyser #define CKSEG2ADDR(a)		(CPHYSADDR(a) | KSEG2)
81819833afSPeter Tyser #define CKSEG3ADDR(a)		(CPHYSADDR(a) | KSEG3)
82819833afSPeter Tyser 
83819833afSPeter Tyser /*
84819833afSPeter Tyser  * Map an address to a certain kernel segment
85819833afSPeter Tyser  */
86819833afSPeter Tyser #define KSEG0ADDR(a)		(CPHYSADDR(a) | KSEG0)
87819833afSPeter Tyser #define KSEG1ADDR(a)		(CPHYSADDR(a) | KSEG1)
88819833afSPeter Tyser #define KSEG2ADDR(a)		(CPHYSADDR(a) | KSEG2)
89819833afSPeter Tyser #define KSEG3ADDR(a)		(CPHYSADDR(a) | KSEG3)
90819833afSPeter Tyser 
91819833afSPeter Tyser /*
92819833afSPeter Tyser  * Memory segments (32bit kernel mode addresses)
93819833afSPeter Tyser  * These are the traditional names used in the 32-bit universe.
94819833afSPeter Tyser  */
95819833afSPeter Tyser #define KUSEG			0x00000000
96819833afSPeter Tyser #define KSEG0			0x80000000
97819833afSPeter Tyser #define KSEG1			0xa0000000
98819833afSPeter Tyser #define KSEG2			0xc0000000
99819833afSPeter Tyser #define KSEG3			0xe0000000
100819833afSPeter Tyser 
101819833afSPeter Tyser #define CKUSEG			0x00000000
102819833afSPeter Tyser #define CKSEG0			0x80000000
103819833afSPeter Tyser #define CKSEG1			0xa0000000
104819833afSPeter Tyser #define CKSEG2			0xc0000000
105819833afSPeter Tyser #define CKSEG3			0xe0000000
106819833afSPeter Tyser 
107819833afSPeter Tyser #endif
108819833afSPeter Tyser 
109819833afSPeter Tyser /*
110819833afSPeter Tyser  * Cache modes for XKPHYS address conversion macros
111819833afSPeter Tyser  */
112819833afSPeter Tyser #define K_CALG_COH_EXCL1_NOL2	0
113819833afSPeter Tyser #define K_CALG_COH_SHRL1_NOL2	1
114819833afSPeter Tyser #define K_CALG_UNCACHED		2
115819833afSPeter Tyser #define K_CALG_NONCOHERENT	3
116819833afSPeter Tyser #define K_CALG_COH_EXCL		4
117819833afSPeter Tyser #define K_CALG_COH_SHAREABLE	5
118819833afSPeter Tyser #define K_CALG_NOTUSED		6
119819833afSPeter Tyser #define K_CALG_UNCACHED_ACCEL	7
120819833afSPeter Tyser 
121819833afSPeter Tyser /*
122819833afSPeter Tyser  * 64-bit address conversions
123819833afSPeter Tyser  */
124819833afSPeter Tyser #define PHYS_TO_XKSEG_UNCACHED(p)	PHYS_TO_XKPHYS(K_CALG_UNCACHED, (p))
125819833afSPeter Tyser #define PHYS_TO_XKSEG_CACHED(p)		PHYS_TO_XKPHYS(K_CALG_COH_SHAREABLE, (p))
126819833afSPeter Tyser #define XKPHYS_TO_PHYS(p)		((p) & TO_PHYS_MASK)
127819833afSPeter Tyser #define PHYS_TO_XKPHYS(cm, a)		(_CONST64_(0x8000000000000000) | \
128819833afSPeter Tyser 					 (_CONST64_(cm) << 59) | (a))
129819833afSPeter Tyser 
130819833afSPeter Tyser /*
131819833afSPeter Tyser  * Returns the uncached address of a sdram address
132819833afSPeter Tyser  */
133819833afSPeter Tyser #ifndef __ASSEMBLY__
134819833afSPeter Tyser #if defined(CONFIG_SOC_AU1X00) || defined(CONFIG_TB0229)
135819833afSPeter Tyser /* We use a 36 bit physical address map here and
136819833afSPeter Tyser    cannot access physical memory directly from core */
137819833afSPeter Tyser #define UNCACHED_SDRAM(a) (((unsigned long)(a)) | 0x20000000)
138819833afSPeter Tyser #else	/* !CONFIG_SOC_AU1X00 */
139090854c8SZhi-zhou Zhang #define UNCACHED_SDRAM(a) CKSEG1ADDR(a)
140819833afSPeter Tyser #endif	/* CONFIG_SOC_AU1X00 */
141819833afSPeter Tyser #endif	/* __ASSEMBLY__ */
142819833afSPeter Tyser 
143819833afSPeter Tyser /*
144819833afSPeter Tyser  * The ultimate limited of the 64-bit MIPS architecture:  2 bits for selecting
145819833afSPeter Tyser  * the region, 3 bits for the CCA mode.  This leaves 59 bits of which the
146819833afSPeter Tyser  * R8000 implements most with its 48-bit physical address space.
147819833afSPeter Tyser  */
148819833afSPeter Tyser #define TO_PHYS_MASK	_CONST64_(0x07ffffffffffffff)	/* 2^^59 - 1 */
149819833afSPeter Tyser 
150819833afSPeter Tyser #ifndef CONFIG_CPU_R8000
151819833afSPeter Tyser 
152819833afSPeter Tyser /*
153819833afSPeter Tyser  * The R8000 doesn't have the 32-bit compat spaces so we don't define them
154819833afSPeter Tyser  * in order to catch bugs in the source code.
155819833afSPeter Tyser  */
156819833afSPeter Tyser 
157819833afSPeter Tyser #define COMPAT_K1BASE32		_CONST64_(0xffffffffa0000000)
158819833afSPeter Tyser #define PHYS_TO_COMPATK1(x)	((x) | COMPAT_K1BASE32) /* 32-bit compat k1 */
159819833afSPeter Tyser 
160819833afSPeter Tyser #endif
161819833afSPeter Tyser 
162819833afSPeter Tyser #define KDM_TO_PHYS(x)		(_ACAST64_ (x) & TO_PHYS_MASK)
163819833afSPeter Tyser #define PHYS_TO_K0(x)		(_ACAST64_ (x) | CAC_BASE)
164819833afSPeter Tyser 
165819833afSPeter Tyser #endif /* _ASM_ADDRSPACE_H */
166