diff options
-rw-r--r-- | arch/mips/dec/time.c | 5 | ||||
-rw-r--r-- | arch/mips/kernel/csrc-ioasic.c | 6 | ||||
-rw-r--r-- | arch/mips/kernel/relocate_kernel.S | 6 | ||||
-rw-r--r-- | arch/mips/kernel/setup.c | 99 | ||||
-rw-r--r-- | arch/mips/mm/init.c | 1 |
5 files changed, 61 insertions, 56 deletions
diff --git a/arch/mips/dec/time.c b/arch/mips/dec/time.c index ea57f39e6736..56ebc7f2bede 100644 --- a/arch/mips/dec/time.c +++ b/arch/mips/dec/time.c | |||
@@ -126,12 +126,13 @@ int rtc_mips_set_mmss(unsigned long nowtime) | |||
126 | void __init plat_time_init(void) | 126 | void __init plat_time_init(void) |
127 | { | 127 | { |
128 | u32 start, end; | 128 | u32 start, end; |
129 | int i = HZ / 10; | 129 | int i = HZ / 8; |
130 | 130 | ||
131 | /* Set up the rate of periodic DS1287 interrupts. */ | 131 | /* Set up the rate of periodic DS1287 interrupts. */ |
132 | ds1287_set_base_clock(HZ); | 132 | ds1287_set_base_clock(HZ); |
133 | 133 | ||
134 | if (cpu_has_counter) { | 134 | if (cpu_has_counter) { |
135 | ds1287_timer_state(); | ||
135 | while (!ds1287_timer_state()) | 136 | while (!ds1287_timer_state()) |
136 | ; | 137 | ; |
137 | 138 | ||
@@ -143,7 +144,7 @@ void __init plat_time_init(void) | |||
143 | 144 | ||
144 | end = read_c0_count(); | 145 | end = read_c0_count(); |
145 | 146 | ||
146 | mips_hpt_frequency = (end - start) * 10; | 147 | mips_hpt_frequency = (end - start) * 8; |
147 | printk(KERN_INFO "MIPS counter frequency %dHz\n", | 148 | printk(KERN_INFO "MIPS counter frequency %dHz\n", |
148 | mips_hpt_frequency); | 149 | mips_hpt_frequency); |
149 | } else if (IOASIC) | 150 | } else if (IOASIC) |
diff --git a/arch/mips/kernel/csrc-ioasic.c b/arch/mips/kernel/csrc-ioasic.c index 0654bff9b69c..87e88feb4a25 100644 --- a/arch/mips/kernel/csrc-ioasic.c +++ b/arch/mips/kernel/csrc-ioasic.c | |||
@@ -41,9 +41,9 @@ void __init dec_ioasic_clocksource_init(void) | |||
41 | { | 41 | { |
42 | unsigned int freq; | 42 | unsigned int freq; |
43 | u32 start, end; | 43 | u32 start, end; |
44 | int i = HZ / 10; | 44 | int i = HZ / 8; |
45 | |||
46 | 45 | ||
46 | ds1287_timer_state(); | ||
47 | while (!ds1287_timer_state()) | 47 | while (!ds1287_timer_state()) |
48 | ; | 48 | ; |
49 | 49 | ||
@@ -55,7 +55,7 @@ void __init dec_ioasic_clocksource_init(void) | |||
55 | 55 | ||
56 | end = dec_ioasic_hpt_read(&clocksource_dec); | 56 | end = dec_ioasic_hpt_read(&clocksource_dec); |
57 | 57 | ||
58 | freq = (end - start) * 10; | 58 | freq = (end - start) * 8; |
59 | printk(KERN_INFO "I/O ASIC clock frequency %dHz\n", freq); | 59 | printk(KERN_INFO "I/O ASIC clock frequency %dHz\n", freq); |
60 | 60 | ||
61 | clocksource_dec.rating = 200 + freq / 10000000; | 61 | clocksource_dec.rating = 200 + freq / 10000000; |
diff --git a/arch/mips/kernel/relocate_kernel.S b/arch/mips/kernel/relocate_kernel.S index 43d2d78d3287..74bab9ddd0e1 100644 --- a/arch/mips/kernel/relocate_kernel.S +++ b/arch/mips/kernel/relocate_kernel.S | |||
@@ -26,6 +26,12 @@ process_entry: | |||
26 | PTR_L s2, (s0) | 26 | PTR_L s2, (s0) |
27 | PTR_ADD s0, s0, SZREG | 27 | PTR_ADD s0, s0, SZREG |
28 | 28 | ||
29 | /* | ||
30 | * In case of a kdump/crash kernel, the indirection page is not | ||
31 | * populated as the kernel is directly copied to a reserved location | ||
32 | */ | ||
33 | beqz s2, done | ||
34 | |||
29 | /* destination page */ | 35 | /* destination page */ |
30 | and s3, s2, 0x1 | 36 | and s3, s2, 0x1 |
31 | beq s3, zero, 1f | 37 | beq s3, zero, 1f |
diff --git a/arch/mips/kernel/setup.c b/arch/mips/kernel/setup.c index c7f90519e58c..c538d6e01b7b 100644 --- a/arch/mips/kernel/setup.c +++ b/arch/mips/kernel/setup.c | |||
@@ -552,6 +552,52 @@ static void __init arch_mem_addpart(phys_t mem, phys_t end, int type) | |||
552 | add_memory_region(mem, size, type); | 552 | add_memory_region(mem, size, type); |
553 | } | 553 | } |
554 | 554 | ||
555 | #ifdef CONFIG_KEXEC | ||
556 | static inline unsigned long long get_total_mem(void) | ||
557 | { | ||
558 | unsigned long long total; | ||
559 | |||
560 | total = max_pfn - min_low_pfn; | ||
561 | return total << PAGE_SHIFT; | ||
562 | } | ||
563 | |||
564 | static void __init mips_parse_crashkernel(void) | ||
565 | { | ||
566 | unsigned long long total_mem; | ||
567 | unsigned long long crash_size, crash_base; | ||
568 | int ret; | ||
569 | |||
570 | total_mem = get_total_mem(); | ||
571 | ret = parse_crashkernel(boot_command_line, total_mem, | ||
572 | &crash_size, &crash_base); | ||
573 | if (ret != 0 || crash_size <= 0) | ||
574 | return; | ||
575 | |||
576 | crashk_res.start = crash_base; | ||
577 | crashk_res.end = crash_base + crash_size - 1; | ||
578 | } | ||
579 | |||
580 | static void __init request_crashkernel(struct resource *res) | ||
581 | { | ||
582 | int ret; | ||
583 | |||
584 | ret = request_resource(res, &crashk_res); | ||
585 | if (!ret) | ||
586 | pr_info("Reserving %ldMB of memory at %ldMB for crashkernel\n", | ||
587 | (unsigned long)((crashk_res.end - | ||
588 | crashk_res.start + 1) >> 20), | ||
589 | (unsigned long)(crashk_res.start >> 20)); | ||
590 | } | ||
591 | #else /* !defined(CONFIG_KEXEC) */ | ||
592 | static void __init mips_parse_crashkernel(void) | ||
593 | { | ||
594 | } | ||
595 | |||
596 | static void __init request_crashkernel(struct resource *res) | ||
597 | { | ||
598 | } | ||
599 | #endif /* !defined(CONFIG_KEXEC) */ | ||
600 | |||
555 | static void __init arch_mem_init(char **cmdline_p) | 601 | static void __init arch_mem_init(char **cmdline_p) |
556 | { | 602 | { |
557 | extern void plat_mem_setup(void); | 603 | extern void plat_mem_setup(void); |
@@ -608,6 +654,8 @@ static void __init arch_mem_init(char **cmdline_p) | |||
608 | BOOTMEM_DEFAULT); | 654 | BOOTMEM_DEFAULT); |
609 | } | 655 | } |
610 | #endif | 656 | #endif |
657 | |||
658 | mips_parse_crashkernel(); | ||
611 | #ifdef CONFIG_KEXEC | 659 | #ifdef CONFIG_KEXEC |
612 | if (crashk_res.start != crashk_res.end) | 660 | if (crashk_res.start != crashk_res.end) |
613 | reserve_bootmem(crashk_res.start, | 661 | reserve_bootmem(crashk_res.start, |
@@ -620,52 +668,6 @@ static void __init arch_mem_init(char **cmdline_p) | |||
620 | paging_init(); | 668 | paging_init(); |
621 | } | 669 | } |
622 | 670 | ||
623 | #ifdef CONFIG_KEXEC | ||
624 | static inline unsigned long long get_total_mem(void) | ||
625 | { | ||
626 | unsigned long long total; | ||
627 | |||
628 | total = max_pfn - min_low_pfn; | ||
629 | return total << PAGE_SHIFT; | ||
630 | } | ||
631 | |||
632 | static void __init mips_parse_crashkernel(void) | ||
633 | { | ||
634 | unsigned long long total_mem; | ||
635 | unsigned long long crash_size, crash_base; | ||
636 | int ret; | ||
637 | |||
638 | total_mem = get_total_mem(); | ||
639 | ret = parse_crashkernel(boot_command_line, total_mem, | ||
640 | &crash_size, &crash_base); | ||
641 | if (ret != 0 || crash_size <= 0) | ||
642 | return; | ||
643 | |||
644 | crashk_res.start = crash_base; | ||
645 | crashk_res.end = crash_base + crash_size - 1; | ||
646 | } | ||
647 | |||
648 | static void __init request_crashkernel(struct resource *res) | ||
649 | { | ||
650 | int ret; | ||
651 | |||
652 | ret = request_resource(res, &crashk_res); | ||
653 | if (!ret) | ||
654 | pr_info("Reserving %ldMB of memory at %ldMB for crashkernel\n", | ||
655 | (unsigned long)((crashk_res.end - | ||
656 | crashk_res.start + 1) >> 20), | ||
657 | (unsigned long)(crashk_res.start >> 20)); | ||
658 | } | ||
659 | #else /* !defined(CONFIG_KEXEC) */ | ||
660 | static void __init mips_parse_crashkernel(void) | ||
661 | { | ||
662 | } | ||
663 | |||
664 | static void __init request_crashkernel(struct resource *res) | ||
665 | { | ||
666 | } | ||
667 | #endif /* !defined(CONFIG_KEXEC) */ | ||
668 | |||
669 | static void __init resource_init(void) | 671 | static void __init resource_init(void) |
670 | { | 672 | { |
671 | int i; | 673 | int i; |
@@ -678,11 +680,6 @@ static void __init resource_init(void) | |||
678 | data_resource.start = __pa_symbol(&_etext); | 680 | data_resource.start = __pa_symbol(&_etext); |
679 | data_resource.end = __pa_symbol(&_edata) - 1; | 681 | data_resource.end = __pa_symbol(&_edata) - 1; |
680 | 682 | ||
681 | /* | ||
682 | * Request address space for all standard RAM. | ||
683 | */ | ||
684 | mips_parse_crashkernel(); | ||
685 | |||
686 | for (i = 0; i < boot_mem_map.nr_map; i++) { | 683 | for (i = 0; i < boot_mem_map.nr_map; i++) { |
687 | struct resource *res; | 684 | struct resource *res; |
688 | unsigned long start, end; | 685 | unsigned long start, end; |
diff --git a/arch/mips/mm/init.c b/arch/mips/mm/init.c index 4e73f10a7519..e205ef598e97 100644 --- a/arch/mips/mm/init.c +++ b/arch/mips/mm/init.c | |||
@@ -254,6 +254,7 @@ void copy_from_user_page(struct vm_area_struct *vma, | |||
254 | SetPageDcacheDirty(page); | 254 | SetPageDcacheDirty(page); |
255 | } | 255 | } |
256 | } | 256 | } |
257 | EXPORT_SYMBOL_GPL(copy_from_user_page); | ||
257 | 258 | ||
258 | void __init fixrange_init(unsigned long start, unsigned long end, | 259 | void __init fixrange_init(unsigned long start, unsigned long end, |
259 | pgd_t *pgd_base) | 260 | pgd_t *pgd_base) |