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