]> www.pilppa.org Git - linux-2.6-omap-h63xx.git/blob - include/asm-ppc64/abs_addr.h
05414a9bfdd183aba40670351b48a73fef5ec394
[linux-2.6-omap-h63xx.git] / include / asm-ppc64 / abs_addr.h
1 #ifndef _ABS_ADDR_H
2 #define _ABS_ADDR_H
3
4 #include <linux/config.h>
5
6 /*
7  * c 2001 PPC 64 Team, IBM Corp
8  *
9  * This program is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU General Public License
11  * as published by the Free Software Foundation; either version
12  * 2 of the License, or (at your option) any later version.
13  */
14
15 #include <asm/types.h>
16 #include <asm/page.h>
17 #include <asm/prom.h>
18 #include <asm/lmb.h>
19
20 #ifdef CONFIG_MSCHUNKS
21
22 struct mschunks_map {
23         unsigned long num_chunks;
24         unsigned long chunk_size;
25         unsigned long chunk_shift;
26         unsigned long chunk_mask;
27         u32 *mapping;
28 };
29
30 extern struct mschunks_map mschunks_map;
31
32 /* Chunks are 256 KB */
33 #define MSCHUNKS_CHUNK_SHIFT    (18)
34 #define MSCHUNKS_CHUNK_SIZE     (1UL << MSCHUNKS_CHUNK_SHIFT)
35 #define MSCHUNKS_OFFSET_MASK    (MSCHUNKS_CHUNK_SIZE - 1)
36
37 static inline unsigned long chunk_to_addr(unsigned long chunk)
38 {
39         return chunk << MSCHUNKS_CHUNK_SHIFT;
40 }
41
42 static inline unsigned long addr_to_chunk(unsigned long addr)
43 {
44         return addr >> MSCHUNKS_CHUNK_SHIFT;
45 }
46
47 static inline unsigned long chunk_offset(unsigned long addr)
48 {
49         return addr & MSCHUNKS_OFFSET_MASK;
50 }
51
52 static inline unsigned long abs_chunk(unsigned long pchunk)
53 {
54         if (pchunk >= mschunks_map.num_chunks)
55                 return pchunk;
56
57         return mschunks_map.mapping[pchunk];
58 }
59
60 /* A macro so it can take pointers or unsigned long. */
61 #define phys_to_abs(pa)                                              \
62         ({ unsigned long _pa = (unsigned long)(pa);                          \
63            chunk_to_addr(abs_chunk(addr_to_chunk(_pa))) + chunk_offset(_pa); \
64         })
65
66 static inline unsigned long
67 physRpn_to_absRpn(unsigned long rpn)
68 {
69         unsigned long pa = rpn << PAGE_SHIFT;
70         unsigned long aa = phys_to_abs(pa);
71         return (aa >> PAGE_SHIFT);
72 }
73
74 /* A macro so it can take pointers or unsigned long. */
75 #define abs_to_phys(aa) lmb_abs_to_phys((unsigned long)(aa))
76
77 #else  /* !CONFIG_MSCHUNKS */
78
79 #define chunk_to_addr(chunk) ((unsigned long)(chunk))
80 #define addr_to_chunk(addr) (addr)
81 #define chunk_offset(addr) (0)
82 #define abs_chunk(pchunk) (pchunk)
83
84 #define phys_to_abs(pa) (pa)
85 #define physRpn_to_absRpn(rpn) (rpn)
86 #define abs_to_phys(aa) (aa)
87
88 #endif /* !CONFIG_MSCHUNKS */
89
90 /* Convenience macros */
91 #define virt_to_abs(va) phys_to_abs(__pa(va))
92 #define abs_to_virt(aa) __va(abs_to_phys(aa))
93
94 #endif /* _ABS_ADDR_H */