162306a36Sopenharmony_ci/* 262306a36Sopenharmony_ci * This file is subject to the terms and conditions of the GNU General Public 362306a36Sopenharmony_ci * License. See the file "COPYING" in the main directory of this archive 462306a36Sopenharmony_ci * for more details. 562306a36Sopenharmony_ci * 662306a36Sopenharmony_ci * Copyright (c) 2010 Cavium Networks, Inc. 762306a36Sopenharmony_ci */ 862306a36Sopenharmony_ci#ifndef _ASM_MIPS_JUMP_LABEL_H 962306a36Sopenharmony_ci#define _ASM_MIPS_JUMP_LABEL_H 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci#define arch_jump_label_transform_static arch_jump_label_transform 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#ifndef __ASSEMBLY__ 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#include <linux/types.h> 1662306a36Sopenharmony_ci#include <asm/isa-rev.h> 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ci#define JUMP_LABEL_NOP_SIZE 4 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_ci#ifdef CONFIG_64BIT 2162306a36Sopenharmony_ci#define WORD_INSN ".dword" 2262306a36Sopenharmony_ci#else 2362306a36Sopenharmony_ci#define WORD_INSN ".word" 2462306a36Sopenharmony_ci#endif 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci#ifdef CONFIG_CPU_MICROMIPS 2762306a36Sopenharmony_ci# define B_INSN "b32" 2862306a36Sopenharmony_ci# define J_INSN "j32" 2962306a36Sopenharmony_ci#elif MIPS_ISA_REV >= 6 3062306a36Sopenharmony_ci# define B_INSN "bc" 3162306a36Sopenharmony_ci# define J_INSN "bc" 3262306a36Sopenharmony_ci#else 3362306a36Sopenharmony_ci# define B_INSN "b" 3462306a36Sopenharmony_ci# define J_INSN "j" 3562306a36Sopenharmony_ci#endif 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_cistatic __always_inline bool arch_static_branch(struct static_key *key, bool branch) 3862306a36Sopenharmony_ci{ 3962306a36Sopenharmony_ci asm goto("1:\t" B_INSN " 2f\n\t" 4062306a36Sopenharmony_ci "2:\t.insn\n\t" 4162306a36Sopenharmony_ci ".pushsection __jump_table, \"aw\"\n\t" 4262306a36Sopenharmony_ci WORD_INSN " 1b, %l[l_yes], %0\n\t" 4362306a36Sopenharmony_ci ".popsection\n\t" 4462306a36Sopenharmony_ci : : "i" (&((char *)key)[branch]) : : l_yes); 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci return false; 4762306a36Sopenharmony_cil_yes: 4862306a36Sopenharmony_ci return true; 4962306a36Sopenharmony_ci} 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_cistatic __always_inline bool arch_static_branch_jump(struct static_key *key, bool branch) 5262306a36Sopenharmony_ci{ 5362306a36Sopenharmony_ci asm goto("1:\t" J_INSN " %l[l_yes]\n\t" 5462306a36Sopenharmony_ci ".pushsection __jump_table, \"aw\"\n\t" 5562306a36Sopenharmony_ci WORD_INSN " 1b, %l[l_yes], %0\n\t" 5662306a36Sopenharmony_ci ".popsection\n\t" 5762306a36Sopenharmony_ci : : "i" (&((char *)key)[branch]) : : l_yes); 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ci return false; 6062306a36Sopenharmony_cil_yes: 6162306a36Sopenharmony_ci return true; 6262306a36Sopenharmony_ci} 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_ci#ifdef CONFIG_64BIT 6562306a36Sopenharmony_citypedef u64 jump_label_t; 6662306a36Sopenharmony_ci#else 6762306a36Sopenharmony_citypedef u32 jump_label_t; 6862306a36Sopenharmony_ci#endif 6962306a36Sopenharmony_ci 7062306a36Sopenharmony_cistruct jump_entry { 7162306a36Sopenharmony_ci jump_label_t code; 7262306a36Sopenharmony_ci jump_label_t target; 7362306a36Sopenharmony_ci jump_label_t key; 7462306a36Sopenharmony_ci}; 7562306a36Sopenharmony_ci 7662306a36Sopenharmony_ci#endif /* __ASSEMBLY__ */ 7762306a36Sopenharmony_ci#endif /* _ASM_MIPS_JUMP_LABEL_H */ 78