forked from mirrors/linux
		
	 06d0bbc6d0
			
		
	
	
		06d0bbc6d0
		
	
	
	
	
		
			
			Add a macro and some helper C functions for patching single asm instructions. The gas macro means we can do something like: 1: nop patch_site 1b, patch__foo Which is less visually distracting than defining a GLOBAL symbol at 1, and also doesn't pollute the symbol table which can confuse eg. perf. These are obviously similar to our existing feature sections, but are not automatically patched based on CPU/MMU features, rather they are designed to be manually patched by C code at some arbitrary point. Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
		
			
				
	
	
		
			18 lines
		
	
	
	
		
			397 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			18 lines
		
	
	
	
		
			397 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * Copyright 2018, Michael Ellerman, IBM Corporation.
 | |
|  */
 | |
| #ifndef _ASM_POWERPC_CODE_PATCHING_ASM_H
 | |
| #define _ASM_POWERPC_CODE_PATCHING_ASM_H
 | |
| 
 | |
| /* Define a "site" that can be patched */
 | |
| .macro patch_site label name
 | |
| 	.pushsection ".rodata"
 | |
| 	.balign 4
 | |
| 	.global \name
 | |
| \name:
 | |
| 	.4byte	\label - .
 | |
| 	.popsection
 | |
| .endm
 | |
| 
 | |
| #endif /* _ASM_POWERPC_CODE_PATCHING_ASM_H */
 |