diff options
author | Steven J. Hill <Steven.Hill@imgtec.com> | 2013-03-25 14:22:59 -0400 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2013-05-09 11:55:19 -0400 |
commit | 1658f914ff91c3bf572d5ddae3773720f6803d20 (patch) | |
tree | 6a7e13a9ac7d7d978e41eb7a8e47b769b4f44290 | |
parent | 01be057b33f52f094bff3a79a93d9ca99e27483d (diff) |
MIPS: microMIPS: Disable LL/SC and fix linker bug.
Partially revert commit e0c14a260d66ba35935600d6435940a566fe806b
and turn off LL/SC when building a pure microMIPS kernel. This is
a temporary fix until the cmpxchg assembly macro functions are
re-written to not use the HI/LO registers in address calculations.
Also add .insn in selected user access functions which would
otherwise produce ISA mode jump incompatibilities. This is also a
temporary fix.
Signed-off-by: Steven J. Hill <Steven.Hill@imgtec.com>
-rw-r--r-- | arch/mips/include/asm/mach-sead3/cpu-feature-overrides.h | 4 | ||||
-rw-r--r-- | arch/mips/include/asm/uaccess.h | 14 |
2 files changed, 16 insertions, 2 deletions
diff --git a/arch/mips/include/asm/mach-sead3/cpu-feature-overrides.h b/arch/mips/include/asm/mach-sead3/cpu-feature-overrides.h index 193c0912d38e..bfbd7035d4c5 100644 --- a/arch/mips/include/asm/mach-sead3/cpu-feature-overrides.h +++ b/arch/mips/include/asm/mach-sead3/cpu-feature-overrides.h | |||
@@ -28,7 +28,11 @@ | |||
28 | /* #define cpu_has_prefetch ? */ | 28 | /* #define cpu_has_prefetch ? */ |
29 | #define cpu_has_mcheck 1 | 29 | #define cpu_has_mcheck 1 |
30 | /* #define cpu_has_ejtag ? */ | 30 | /* #define cpu_has_ejtag ? */ |
31 | #ifdef CONFIG_CPU_MICROMIPS | ||
32 | #define cpu_has_llsc 0 | ||
33 | #else | ||
31 | #define cpu_has_llsc 1 | 34 | #define cpu_has_llsc 1 |
35 | #endif | ||
32 | /* #define cpu_has_vtag_icache ? */ | 36 | /* #define cpu_has_vtag_icache ? */ |
33 | /* #define cpu_has_dc_aliases ? */ | 37 | /* #define cpu_has_dc_aliases ? */ |
34 | /* #define cpu_has_ic_fills_f_dc ? */ | 38 | /* #define cpu_has_ic_fills_f_dc ? */ |
diff --git a/arch/mips/include/asm/uaccess.h b/arch/mips/include/asm/uaccess.h index bd87e36bf26a..1c9edd63dda7 100644 --- a/arch/mips/include/asm/uaccess.h +++ b/arch/mips/include/asm/uaccess.h | |||
@@ -261,6 +261,7 @@ do { \ | |||
261 | __asm__ __volatile__( \ | 261 | __asm__ __volatile__( \ |
262 | "1: " insn " %1, %3 \n" \ | 262 | "1: " insn " %1, %3 \n" \ |
263 | "2: \n" \ | 263 | "2: \n" \ |
264 | " .insn \n" \ | ||
264 | " .section .fixup,\"ax\" \n" \ | 265 | " .section .fixup,\"ax\" \n" \ |
265 | "3: li %0, %4 \n" \ | 266 | "3: li %0, %4 \n" \ |
266 | " j 2b \n" \ | 267 | " j 2b \n" \ |
@@ -287,7 +288,9 @@ do { \ | |||
287 | __asm__ __volatile__( \ | 288 | __asm__ __volatile__( \ |
288 | "1: lw %1, (%3) \n" \ | 289 | "1: lw %1, (%3) \n" \ |
289 | "2: lw %D1, 4(%3) \n" \ | 290 | "2: lw %D1, 4(%3) \n" \ |
290 | "3: .section .fixup,\"ax\" \n" \ | 291 | "3: \n" \ |
292 | " .insn \n" \ | ||
293 | " .section .fixup,\"ax\" \n" \ | ||
291 | "4: li %0, %4 \n" \ | 294 | "4: li %0, %4 \n" \ |
292 | " move %1, $0 \n" \ | 295 | " move %1, $0 \n" \ |
293 | " move %D1, $0 \n" \ | 296 | " move %D1, $0 \n" \ |
@@ -355,6 +358,7 @@ do { \ | |||
355 | __asm__ __volatile__( \ | 358 | __asm__ __volatile__( \ |
356 | "1: " insn " %z2, %3 # __put_user_asm\n" \ | 359 | "1: " insn " %z2, %3 # __put_user_asm\n" \ |
357 | "2: \n" \ | 360 | "2: \n" \ |
361 | " .insn \n" \ | ||
358 | " .section .fixup,\"ax\" \n" \ | 362 | " .section .fixup,\"ax\" \n" \ |
359 | "3: li %0, %4 \n" \ | 363 | "3: li %0, %4 \n" \ |
360 | " j 2b \n" \ | 364 | " j 2b \n" \ |
@@ -373,6 +377,7 @@ do { \ | |||
373 | "1: sw %2, (%3) # __put_user_asm_ll32 \n" \ | 377 | "1: sw %2, (%3) # __put_user_asm_ll32 \n" \ |
374 | "2: sw %D2, 4(%3) \n" \ | 378 | "2: sw %D2, 4(%3) \n" \ |
375 | "3: \n" \ | 379 | "3: \n" \ |
380 | " .insn \n" \ | ||
376 | " .section .fixup,\"ax\" \n" \ | 381 | " .section .fixup,\"ax\" \n" \ |
377 | "4: li %0, %4 \n" \ | 382 | "4: li %0, %4 \n" \ |
378 | " j 3b \n" \ | 383 | " j 3b \n" \ |
@@ -524,6 +529,7 @@ do { \ | |||
524 | __asm__ __volatile__( \ | 529 | __asm__ __volatile__( \ |
525 | "1: " insn " %1, %3 \n" \ | 530 | "1: " insn " %1, %3 \n" \ |
526 | "2: \n" \ | 531 | "2: \n" \ |
532 | " .insn \n" \ | ||
527 | " .section .fixup,\"ax\" \n" \ | 533 | " .section .fixup,\"ax\" \n" \ |
528 | "3: li %0, %4 \n" \ | 534 | "3: li %0, %4 \n" \ |
529 | " j 2b \n" \ | 535 | " j 2b \n" \ |
@@ -549,7 +555,9 @@ do { \ | |||
549 | "1: ulw %1, (%3) \n" \ | 555 | "1: ulw %1, (%3) \n" \ |
550 | "2: ulw %D1, 4(%3) \n" \ | 556 | "2: ulw %D1, 4(%3) \n" \ |
551 | " move %0, $0 \n" \ | 557 | " move %0, $0 \n" \ |
552 | "3: .section .fixup,\"ax\" \n" \ | 558 | "3: \n" \ |
559 | " .insn \n" \ | ||
560 | " .section .fixup,\"ax\" \n" \ | ||
553 | "4: li %0, %4 \n" \ | 561 | "4: li %0, %4 \n" \ |
554 | " move %1, $0 \n" \ | 562 | " move %1, $0 \n" \ |
555 | " move %D1, $0 \n" \ | 563 | " move %D1, $0 \n" \ |
@@ -616,6 +624,7 @@ do { \ | |||
616 | __asm__ __volatile__( \ | 624 | __asm__ __volatile__( \ |
617 | "1: " insn " %z2, %3 # __put_user_unaligned_asm\n" \ | 625 | "1: " insn " %z2, %3 # __put_user_unaligned_asm\n" \ |
618 | "2: \n" \ | 626 | "2: \n" \ |
627 | " .insn \n" \ | ||
619 | " .section .fixup,\"ax\" \n" \ | 628 | " .section .fixup,\"ax\" \n" \ |
620 | "3: li %0, %4 \n" \ | 629 | "3: li %0, %4 \n" \ |
621 | " j 2b \n" \ | 630 | " j 2b \n" \ |
@@ -634,6 +643,7 @@ do { \ | |||
634 | "1: sw %2, (%3) # __put_user_unaligned_asm_ll32 \n" \ | 643 | "1: sw %2, (%3) # __put_user_unaligned_asm_ll32 \n" \ |
635 | "2: sw %D2, 4(%3) \n" \ | 644 | "2: sw %D2, 4(%3) \n" \ |
636 | "3: \n" \ | 645 | "3: \n" \ |
646 | " .insn \n" \ | ||
637 | " .section .fixup,\"ax\" \n" \ | 647 | " .section .fixup,\"ax\" \n" \ |
638 | "4: li %0, %4 \n" \ | 648 | "4: li %0, %4 \n" \ |
639 | " j 3b \n" \ | 649 | " j 3b \n" \ |