mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 65a792e84f
			
		
	
	
		65a792e84f
		
	
	
	
	
		
			
			Add the arch-specific code to support jump label for TILE-Gx. This code shares NOP instruction with ftrace, so we move it to a common header file. Reviewed-by: Chris Metcalf <cmetcalf@ezchip.com> Signed-off-by: Zhigang Lu <zlu@ezchip.com> Signed-off-by: Chris Metcalf <cmetcalf@ezchip.com>
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright 2015 Tilera Corporation. All Rights Reserved.
 | |
|  *
 | |
|  *   This program is free software; you can redistribute it and/or
 | |
|  *   modify it under the terms of the GNU General Public License
 | |
|  *   as published by the Free Software Foundation, version 2.
 | |
|  *
 | |
|  *   This program is distributed in the hope that it will be useful, but
 | |
|  *   WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  *   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or
 | |
|  *   NON INFRINGEMENT.  See the GNU General Public License for
 | |
|  *   more details.
 | |
|  */
 | |
| 
 | |
| #ifndef _ASM_TILE_JUMP_LABEL_H
 | |
| #define _ASM_TILE_JUMP_LABEL_H
 | |
| 
 | |
| #include <arch/opcode.h>
 | |
| 
 | |
| #define JUMP_LABEL_NOP_SIZE	TILE_BUNDLE_SIZE_IN_BYTES
 | |
| 
 | |
| static __always_inline bool arch_static_branch(struct static_key *key,
 | |
| 					       bool branch)
 | |
| {
 | |
| 	asm_volatile_goto("1:\n\t"
 | |
| 		"nop" "\n\t"
 | |
| 		".pushsection __jump_table,  \"aw\"\n\t"
 | |
| 		".quad 1b, %l[l_yes], %0 + %1 \n\t"
 | |
| 		".popsection\n\t"
 | |
| 		: :  "i" (key), "i" (branch) : : l_yes);
 | |
| 	return false;
 | |
| l_yes:
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| static __always_inline bool arch_static_branch_jump(struct static_key *key,
 | |
| 						    bool branch)
 | |
| {
 | |
| 	asm_volatile_goto("1:\n\t"
 | |
| 		"j %l[l_yes]" "\n\t"
 | |
| 		".pushsection __jump_table,  \"aw\"\n\t"
 | |
| 		".quad 1b, %l[l_yes], %0 + %1 \n\t"
 | |
| 		".popsection\n\t"
 | |
| 		: :  "i" (key), "i" (branch) : : l_yes);
 | |
| 	return false;
 | |
| l_yes:
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| typedef u64 jump_label_t;
 | |
| 
 | |
| struct jump_entry {
 | |
| 	jump_label_t code;
 | |
| 	jump_label_t target;
 | |
| 	jump_label_t key;
 | |
| };
 | |
| 
 | |
| #endif /* _ASM_TILE_JUMP_LABEL_H */
 |