Rev 843 | Rev 970 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 843 | Rev 867 | ||
---|---|---|---|
Line 25... | Line 25... | ||
25 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
25 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
26 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
26 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
27 | */ |
27 | */ |
28 | 28 | ||
29 | #include <arch/mm/memory_init.h> |
29 | #include <arch/mm/memory_init.h> |
30 | #include <genarch/ofw/ofw.h> |
30 | #include <genarch/ofw/memory_init.h> |
31 | #include <panic.h> |
31 | #include <typedefs.h> |
32 | #include <mm/frame.h> |
- | |
33 | #include <align.h> |
- | |
34 | - | ||
35 | #define MEMMAP_MAX_RECORDS 32 |
- | |
36 | - | ||
37 | typedef struct { |
- | |
38 | __u32 start; |
- | |
39 | __u32 size; |
- | |
40 | } memmap_t; |
- | |
41 | - | ||
42 | static memmap_t memmap[MEMMAP_MAX_RECORDS]; |
- | |
43 | size_t total_mem = 0; |
- | |
44 | - | ||
45 | static void init_memmap(void) |
- | |
46 | { |
- | |
47 | int i; |
- | |
48 | - | ||
49 | phandle handle = ofw_find_device("/memory"); |
- | |
50 | if (handle == -1) |
- | |
51 | panic("No RAM\n"); |
- | |
52 | - | ||
53 | size_t ret = ofw_get_property(handle, "reg", &memmap, sizeof(memmap)); |
- | |
54 | if (ret == -1) |
- | |
55 | panic("Device /memory has no reg property\n"); |
- | |
56 | - | ||
57 | - | ||
58 | for (i = 0; i < MEMMAP_MAX_RECORDS; i++) { |
- | |
59 | if (memmap[i].size == 0) |
- | |
60 | break; |
- | |
61 | total_mem += memmap[i].size; |
- | |
62 | } |
- | |
63 | } |
- | |
64 | 32 | ||
65 | void preboot_read_config(void) |
33 | void preboot_read_config(void) |
66 | { |
34 | { |
67 | init_memmap(); |
35 | ofw_init_memmap(); |
68 | } |
36 | } |
69 | 37 | ||
70 | size_t get_memory_size(void) |
38 | size_t get_memory_size(void) |
71 | { |
39 | { |
72 | return total_mem; |
40 | return ofw_get_memory_size(); |
73 | } |
- | |
74 | - | ||
75 | void ppc_init_zones(void) |
- | |
76 | { |
- | |
77 | int i; |
- | |
78 | pfn_t confdata; |
- | |
79 | - | ||
80 | for (i = 0; i < MEMMAP_MAX_RECORDS; i++) { |
- | |
81 | if (memmap[i].size == 0) |
- | |
82 | break; |
- | |
83 | confdata = ADDR2PFN(memmap[i].start); |
- | |
84 | if (confdata == 0) |
- | |
85 | confdata = 2; |
- | |
86 | zone_create(ADDR2PFN(memmap[i].start), |
- | |
87 | SIZE2FRAMES(ALIGN_DOWN(memmap[i].size,PAGE_SIZE)), |
- | |
88 | confdata, 0); |
- | |
89 | } |
- | |
90 | } |
41 | } |