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