diff options
Diffstat (limited to 'arch/sparc64/kernel')
| -rw-r--r-- | arch/sparc64/kernel/head.S | 35 | ||||
| -rw-r--r-- | arch/sparc64/kernel/mdesc.c | 6 | ||||
| -rw-r--r-- | arch/sparc64/kernel/prom.c | 6 | ||||
| -rw-r--r-- | arch/sparc64/kernel/trampoline.S | 33 |
4 files changed, 68 insertions, 12 deletions
diff --git a/arch/sparc64/kernel/head.S b/arch/sparc64/kernel/head.S index 63144ad476f6..c4147ad8677b 100644 --- a/arch/sparc64/kernel/head.S +++ b/arch/sparc64/kernel/head.S | |||
| @@ -98,7 +98,7 @@ sparc64_boot: | |||
| 98 | .globl prom_boot_mapped_pc, prom_boot_mapping_mode | 98 | .globl prom_boot_mapped_pc, prom_boot_mapping_mode |
| 99 | .globl prom_boot_mapping_phys_high, prom_boot_mapping_phys_low | 99 | .globl prom_boot_mapping_phys_high, prom_boot_mapping_phys_low |
| 100 | .globl prom_compatible_name, prom_cpu_path, prom_cpu_compatible | 100 | .globl prom_compatible_name, prom_cpu_path, prom_cpu_compatible |
| 101 | .globl is_sun4v, sun4v_chip_type | 101 | .globl is_sun4v, sun4v_chip_type, prom_set_trap_table_name |
| 102 | prom_peer_name: | 102 | prom_peer_name: |
| 103 | .asciz "peer" | 103 | .asciz "peer" |
| 104 | prom_compatible_name: | 104 | prom_compatible_name: |
| @@ -121,6 +121,8 @@ prom_map_name: | |||
| 121 | .asciz "map" | 121 | .asciz "map" |
| 122 | prom_unmap_name: | 122 | prom_unmap_name: |
| 123 | .asciz "unmap" | 123 | .asciz "unmap" |
| 124 | prom_set_trap_table_name: | ||
| 125 | .asciz "SUNW,set-trap-table" | ||
| 124 | prom_sun4v_name: | 126 | prom_sun4v_name: |
| 125 | .asciz "sun4v" | 127 | .asciz "sun4v" |
| 126 | prom_niagara_prefix: | 128 | prom_niagara_prefix: |
| @@ -691,15 +693,38 @@ setup_trap_table: | |||
| 691 | sethi %hi(kern_base), %g3 | 693 | sethi %hi(kern_base), %g3 |
| 692 | ldx [%g3 + %lo(kern_base)], %g3 | 694 | ldx [%g3 + %lo(kern_base)], %g3 |
| 693 | add %g2, %g3, %o1 | 695 | add %g2, %g3, %o1 |
| 696 | sethi %hi(sparc64_ttable_tl0), %o0 | ||
| 694 | 697 | ||
| 695 | call prom_set_trap_table_sun4v | 698 | set prom_set_trap_table_name, %g2 |
| 696 | sethi %hi(sparc64_ttable_tl0), %o0 | 699 | stx %g2, [%sp + 2047 + 128 + 0x00] |
| 700 | mov 2, %g2 | ||
| 701 | stx %g2, [%sp + 2047 + 128 + 0x08] | ||
| 702 | mov 0, %g2 | ||
| 703 | stx %g2, [%sp + 2047 + 128 + 0x10] | ||
| 704 | stx %o0, [%sp + 2047 + 128 + 0x18] | ||
| 705 | stx %o1, [%sp + 2047 + 128 + 0x20] | ||
| 706 | sethi %hi(p1275buf), %g2 | ||
| 707 | or %g2, %lo(p1275buf), %g2 | ||
| 708 | ldx [%g2 + 0x08], %o1 | ||
| 709 | call %o1 | ||
| 710 | add %sp, (2047 + 128), %o0 | ||
| 697 | 711 | ||
| 698 | ba,pt %xcc, 2f | 712 | ba,pt %xcc, 2f |
| 699 | nop | 713 | nop |
| 700 | 714 | ||
| 701 | 1: call prom_set_trap_table | 715 | 1: sethi %hi(sparc64_ttable_tl0), %o0 |
| 702 | sethi %hi(sparc64_ttable_tl0), %o0 | 716 | set prom_set_trap_table_name, %g2 |
| 717 | stx %g2, [%sp + 2047 + 128 + 0x00] | ||
| 718 | mov 1, %g2 | ||
| 719 | stx %g2, [%sp + 2047 + 128 + 0x08] | ||
| 720 | mov 0, %g2 | ||
| 721 | stx %g2, [%sp + 2047 + 128 + 0x10] | ||
| 722 | stx %o0, [%sp + 2047 + 128 + 0x18] | ||
| 723 | sethi %hi(p1275buf), %g2 | ||
| 724 | or %g2, %lo(p1275buf), %g2 | ||
| 725 | ldx [%g2 + 0x08], %o1 | ||
| 726 | call %o1 | ||
| 727 | add %sp, (2047 + 128), %o0 | ||
| 703 | 728 | ||
| 704 | /* Start using proper page size encodings in ctx register. */ | 729 | /* Start using proper page size encodings in ctx register. */ |
| 705 | 2: sethi %hi(sparc64_kern_pri_context), %g3 | 730 | 2: sethi %hi(sparc64_kern_pri_context), %g3 |
diff --git a/arch/sparc64/kernel/mdesc.c b/arch/sparc64/kernel/mdesc.c index 9f22e4ff6015..856659bb1311 100644 --- a/arch/sparc64/kernel/mdesc.c +++ b/arch/sparc64/kernel/mdesc.c | |||
| @@ -777,8 +777,12 @@ void __devinit mdesc_fill_in_cpu_data(cpumask_t mask) | |||
| 777 | cpuid = *id; | 777 | cpuid = *id; |
| 778 | 778 | ||
| 779 | #ifdef CONFIG_SMP | 779 | #ifdef CONFIG_SMP |
| 780 | if (cpuid >= NR_CPUS) | 780 | if (cpuid >= NR_CPUS) { |
| 781 | printk(KERN_WARNING "Ignoring CPU %d which is " | ||
| 782 | ">= NR_CPUS (%d)\n", | ||
| 783 | cpuid, NR_CPUS); | ||
| 781 | continue; | 784 | continue; |
| 785 | } | ||
| 782 | if (!cpu_isset(cpuid, mask)) | 786 | if (!cpu_isset(cpuid, mask)) |
| 783 | continue; | 787 | continue; |
| 784 | #else | 788 | #else |
diff --git a/arch/sparc64/kernel/prom.c b/arch/sparc64/kernel/prom.c index d1a78c976cef..0614dff63d7c 100644 --- a/arch/sparc64/kernel/prom.c +++ b/arch/sparc64/kernel/prom.c | |||
| @@ -1583,8 +1583,12 @@ static void __init of_fill_in_cpu_data(void) | |||
| 1583 | ncpus_probed++; | 1583 | ncpus_probed++; |
| 1584 | 1584 | ||
| 1585 | #ifdef CONFIG_SMP | 1585 | #ifdef CONFIG_SMP |
| 1586 | if (cpuid >= NR_CPUS) | 1586 | if (cpuid >= NR_CPUS) { |
| 1587 | printk(KERN_WARNING "Ignoring CPU %d which is " | ||
| 1588 | ">= NR_CPUS (%d)\n", | ||
| 1589 | cpuid, NR_CPUS); | ||
| 1587 | continue; | 1590 | continue; |
| 1591 | } | ||
| 1588 | #else | 1592 | #else |
| 1589 | /* On uniprocessor we only want the values for the | 1593 | /* On uniprocessor we only want the values for the |
| 1590 | * real physical cpu the kernel booted onto, however | 1594 | * real physical cpu the kernel booted onto, however |
diff --git a/arch/sparc64/kernel/trampoline.S b/arch/sparc64/kernel/trampoline.S index 9533a25ce5d2..04e81dda13d0 100644 --- a/arch/sparc64/kernel/trampoline.S +++ b/arch/sparc64/kernel/trampoline.S | |||
| @@ -345,7 +345,7 @@ after_lock_tlb: | |||
| 345 | sethi %hi(tramp_stack), %g1 | 345 | sethi %hi(tramp_stack), %g1 |
| 346 | or %g1, %lo(tramp_stack), %g1 | 346 | or %g1, %lo(tramp_stack), %g1 |
| 347 | add %g1, TRAMP_STACK_SIZE, %g1 | 347 | add %g1, TRAMP_STACK_SIZE, %g1 |
| 348 | sub %g1, STACKFRAME_SZ + STACK_BIAS, %sp | 348 | sub %g1, STACKFRAME_SZ + STACK_BIAS + 256, %sp |
| 349 | mov 0, %fp | 349 | mov 0, %fp |
| 350 | 350 | ||
| 351 | /* Put garbage in these registers to trap any access to them. */ | 351 | /* Put garbage in these registers to trap any access to them. */ |
| @@ -411,15 +411,38 @@ after_lock_tlb: | |||
| 411 | sethi %hi(kern_base), %g3 | 411 | sethi %hi(kern_base), %g3 |
| 412 | ldx [%g3 + %lo(kern_base)], %g3 | 412 | ldx [%g3 + %lo(kern_base)], %g3 |
| 413 | add %g2, %g3, %o1 | 413 | add %g2, %g3, %o1 |
| 414 | sethi %hi(sparc64_ttable_tl0), %o0 | ||
| 414 | 415 | ||
| 415 | call prom_set_trap_table_sun4v | 416 | set prom_set_trap_table_name, %g2 |
| 416 | sethi %hi(sparc64_ttable_tl0), %o0 | 417 | stx %g2, [%sp + 2047 + 128 + 0x00] |
| 418 | mov 2, %g2 | ||
| 419 | stx %g2, [%sp + 2047 + 128 + 0x08] | ||
| 420 | mov 0, %g2 | ||
| 421 | stx %g2, [%sp + 2047 + 128 + 0x10] | ||
| 422 | stx %o0, [%sp + 2047 + 128 + 0x18] | ||
| 423 | stx %o1, [%sp + 2047 + 128 + 0x20] | ||
| 424 | sethi %hi(p1275buf), %g2 | ||
| 425 | or %g2, %lo(p1275buf), %g2 | ||
| 426 | ldx [%g2 + 0x08], %o1 | ||
| 427 | call %o1 | ||
| 428 | add %sp, (2047 + 128), %o0 | ||
| 417 | 429 | ||
| 418 | ba,pt %xcc, 2f | 430 | ba,pt %xcc, 2f |
| 419 | nop | 431 | nop |
| 420 | 432 | ||
| 421 | 1: call prom_set_trap_table | 433 | 1: sethi %hi(sparc64_ttable_tl0), %o0 |
| 422 | sethi %hi(sparc64_ttable_tl0), %o0 | 434 | set prom_set_trap_table_name, %g2 |
| 435 | stx %g2, [%sp + 2047 + 128 + 0x00] | ||
| 436 | mov 1, %g2 | ||
| 437 | stx %g2, [%sp + 2047 + 128 + 0x08] | ||
| 438 | mov 0, %g2 | ||
| 439 | stx %g2, [%sp + 2047 + 128 + 0x10] | ||
| 440 | stx %o0, [%sp + 2047 + 128 + 0x18] | ||
| 441 | sethi %hi(p1275buf), %g2 | ||
| 442 | or %g2, %lo(p1275buf), %g2 | ||
| 443 | ldx [%g2 + 0x08], %o1 | ||
| 444 | call %o1 | ||
| 445 | add %sp, (2047 + 128), %o0 | ||
| 423 | 446 | ||
| 424 | 2: ldx [%l0], %g6 | 447 | 2: ldx [%l0], %g6 |
| 425 | ldx [%g6 + TI_TASK], %g4 | 448 | ldx [%g6 + TI_TASK], %g4 |
