Songmao Tian | 42d226c | 2007-06-06 14:52:38 +0800 | [diff] [blame] | 1 | /* |
| 2 | * This program is free software; you can redistribute it and/or modify it |
| 3 | * under the terms of the GNU General Public License as published by the |
| 4 | * Free Software Foundation; either version 2 of the License, or (at your |
| 5 | * option) any later version. |
| 6 | */ |
| 7 | #include <linux/fs.h> |
| 8 | #include <linux/fcntl.h> |
| 9 | #include <linux/mm.h> |
| 10 | |
Wu Zhangjin | bd92aa0 | 2009-07-02 23:22:36 +0800 | [diff] [blame] | 11 | #include <asm/bootinfo.h> |
| 12 | |
Wu Zhangjin | 5e983ff | 2009-07-02 23:23:03 +0800 | [diff] [blame] | 13 | #include <loongson.h> |
Wu Zhangjin | 85749d2 | 2009-07-02 23:26:45 +0800 | [diff] [blame] | 14 | #include <mem.h> |
Wu Zhangjin | 659da2b | 2009-10-16 14:17:15 +0800 | [diff] [blame] | 15 | #include <pci.h> |
Wu Zhangjin | bd92aa0 | 2009-07-02 23:22:36 +0800 | [diff] [blame] | 16 | |
| 17 | void __init prom_init_memory(void) |
| 18 | { |
| 19 | add_memory_region(0x0, (memsize << 20), BOOT_MEM_RAM); |
Wu Zhangjin | 659da2b | 2009-10-16 14:17:15 +0800 | [diff] [blame] | 20 | |
| 21 | add_memory_region(memsize << 20, LOONGSON_PCI_MEM_START - (memsize << |
| 22 | 20), BOOT_MEM_RESERVED); |
Wu Zhangjin | bd92aa0 | 2009-07-02 23:22:36 +0800 | [diff] [blame] | 23 | #ifdef CONFIG_64BIT |
Wu Zhangjin | 6f7a251 | 2009-11-06 18:45:05 +0800 | [diff] [blame^] | 24 | #ifdef CONFIG_CPU_LOONGSON2F |
| 25 | { |
| 26 | int bit; |
Wu Zhangjin | 659da2b | 2009-10-16 14:17:15 +0800 | [diff] [blame] | 27 | |
Wu Zhangjin | 6f7a251 | 2009-11-06 18:45:05 +0800 | [diff] [blame^] | 28 | bit = fls(memsize + highmemsize); |
| 29 | if (bit != ffs(memsize + highmemsize)) |
| 30 | bit += 20; |
| 31 | else |
| 32 | bit = bit + 20 - 1; |
Wu Zhangjin | 659da2b | 2009-10-16 14:17:15 +0800 | [diff] [blame] | 33 | |
Wu Zhangjin | 6f7a251 | 2009-11-06 18:45:05 +0800 | [diff] [blame^] | 34 | /* set cpu window3 to map CPU to DDR: 2G -> 2G */ |
| 35 | LOONGSON_ADDRWIN_CPUTODDR(ADDRWIN_WIN3, 0x80000000ul, |
| 36 | 0x80000000ul, (1 << bit)); |
| 37 | mmiowb(); |
| 38 | } |
| 39 | #endif /* CONFIG_CPU_LOONGSON2F */ |
| 40 | |
| 41 | if (highmemsize > 0) |
| 42 | add_memory_region(LOONGSON_HIGHMEM_START, |
| 43 | highmemsize << 20, BOOT_MEM_RAM); |
| 44 | |
| 45 | add_memory_region(LOONGSON_PCI_MEM_END + 1, LOONGSON_HIGHMEM_START - |
| 46 | LOONGSON_PCI_MEM_END - 1, BOOT_MEM_RESERVED); |
| 47 | |
| 48 | #endif /* CONFIG_64BIT */ |
Wu Zhangjin | bd92aa0 | 2009-07-02 23:22:36 +0800 | [diff] [blame] | 49 | } |
| 50 | |
Songmao Tian | 42d226c | 2007-06-06 14:52:38 +0800 | [diff] [blame] | 51 | /* override of arch/mips/mm/cache.c: __uncached_access */ |
| 52 | int __uncached_access(struct file *file, unsigned long addr) |
| 53 | { |
Christoph Hellwig | 6b2f3d1 | 2009-10-27 11:05:28 +0100 | [diff] [blame] | 54 | if (file->f_flags & O_DSYNC) |
Songmao Tian | 42d226c | 2007-06-06 14:52:38 +0800 | [diff] [blame] | 55 | return 1; |
| 56 | |
Songmao Tian | 42d226c | 2007-06-06 14:52:38 +0800 | [diff] [blame] | 57 | return addr >= __pa(high_memory) || |
Wu Zhangjin | 85749d2 | 2009-07-02 23:26:45 +0800 | [diff] [blame] | 58 | ((addr >= LOONGSON_MMIO_MEM_START) && |
| 59 | (addr < LOONGSON_MMIO_MEM_END)); |
Songmao Tian | 42d226c | 2007-06-06 14:52:38 +0800 | [diff] [blame] | 60 | } |