In August 2012, Matthew Gretton-Dann checked a change into binutils
labelled "Error on obsolete & warn on deprecated registers", apparently as
part of ARMv8 support. Apparently, this was supposed to emit the message
"Warning: This coprocessor register access is deprecated in ARMv8" when
using certain mcr/mrc instructions and building for ARMv8. Unfortunately,
the message that is actually emitted appears to be '(null)', which is
less helpful in comparison.
Even more unfortunately, this is biting us on every single kernel
build with a new gas, because arch/arm/boot/compressed/head.S and some
other files in that directory are built with -march=all since kernel
commit 80cec14a8 "[ARM] Add -march=all to assembly file build in
arch/arm/boot/compressed" back in v2.6.28.
This patch reverts Russell's nice solution and instead marks the head.S
file to be built for armv7-a, which fortunately lets us build all
instructions in that file without warnings even on the broken binutils.
Without this patch, building anything results in:
arch/arm/boot/compressed/head.S: Assembler messages:
arch/arm/boot/compressed/head.S:565: Warning: (null)
arch/arm/boot/compressed/head.S:676: Warning: (null)
arch/arm/boot/compressed/head.S:698: Warning: (null)
arch/arm/boot/compressed/head.S:722: Warning: (null)
arch/arm/boot/compressed/head.S:726: Warning: (null)
arch/arm/boot/compressed/head.S:957: Warning: (null)
arch/arm/boot/compressed/head.S:996: Warning: (null)
arch/arm/boot/compressed/head.S:997: Warning: (null)
arch/arm/boot/compressed/head.S:1027: Warning: (null)
arch/arm/boot/compressed/head.S:1035: Warning: (null)
arch/arm/boot/compressed/head.S:1046: Warning: (null)
arch/arm/boot/compressed/head.S:1060: Warning: (null)
arch/arm/boot/compressed/head.S:1092: Warning: (null)
arch/arm/boot/compressed/head.S:1094: Warning: (null)
arch/arm/boot/compressed/head.S:1095: Warning: (null)
arch/arm/boot/compressed/head.S:1102: Warning: (null)
arch/arm/boot/compressed/head.S:1134: Warning: (null)
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Cc: stable@vger.kernel.org
Cc: Matthew Gretton-Dann <matthew.gretton-dann@arm.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
		
	
			
		
			
				
	
	
		
			49 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /* 
 | |
|  * linux/arch/arm/boot/compressed/head-sa1100.S
 | |
|  * 
 | |
|  * Copyright (C) 1999 Nicolas Pitre <nico@fluxnic.net>
 | |
|  * 
 | |
|  * SA1100 specific tweaks.  This is merged into head.S by the linker.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #include <linux/linkage.h>
 | |
| #include <asm/mach-types.h>
 | |
| 
 | |
| 		.section        ".start", "ax"
 | |
| 		.arch	armv4
 | |
| 
 | |
| __SA1100_start:
 | |
| 
 | |
| 		@ Preserve r8/r7 i.e. kernel entry values
 | |
| #ifdef CONFIG_SA1100_COLLIE
 | |
| 		mov	r7, #MACH_TYPE_COLLIE
 | |
| #endif
 | |
| #ifdef CONFIG_SA1100_SIMPAD
 | |
| 		@ UNTIL we've something like an open bootldr
 | |
| 		mov	r7, #MACH_TYPE_SIMPAD	@should be 87
 | |
| #endif
 | |
| 		mrc	p15, 0, r0, c1, c0, 0	@ read control reg
 | |
| 		ands	r0, r0, #0x0d
 | |
| 		beq	99f
 | |
| 
 | |
| 		@ Data cache might be active.
 | |
| 		@ Be sure to flush kernel binary out of the cache,
 | |
| 		@ whatever state it is, before it is turned off.
 | |
| 		@ This is done by fetching through currently executed
 | |
| 		@ memory to be sure we hit the same cache.
 | |
| 		bic	r2, pc, #0x1f
 | |
| 		add	r3, r2, #0x4000		@ 16 kb is quite enough...
 | |
| 1:		ldr	r0, [r2], #32
 | |
| 		teq	r2, r3
 | |
| 		bne	1b
 | |
| 		mcr	p15, 0, r0, c7, c10, 4	@ drain WB
 | |
| 		mcr	p15, 0, r0, c7, c7, 0	@ flush I & D caches
 | |
| 
 | |
| 		@ disabling MMU and caches
 | |
| 		mrc	p15, 0, r0, c1, c0, 0	@ read control reg
 | |
| 		bic	r0, r0, #0x0d		@ clear WB, DC, MMU
 | |
| 		bic	r0, r0, #0x1000		@ clear Icache
 | |
| 		mcr	p15, 0, r0, c1, c0, 0
 | |
| 99:
 |