cregit-Linux how code gets into the kernel

Release 4.14 arch/s390/include/asm/jump_label.h

/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _ASM_S390_JUMP_LABEL_H

#define _ASM_S390_JUMP_LABEL_H

#ifndef __ASSEMBLY__

#include <linux/types.h>
#include <linux/stringify.h>


#define JUMP_LABEL_NOP_SIZE 6

#define JUMP_LABEL_NOP_OFFSET 2

/*
 * We use a brcl 0,2 instruction for jump labels at compile time so it
 * can be easily distinguished from a hotpatch generated instruction.
 */

static __always_inline bool arch_static_branch(struct static_key *key, bool branch) { asm_volatile_goto("0: brcl 0,"__stringify(JUMP_LABEL_NOP_OFFSET)"\n" ".pushsection __jump_table, \"aw\"\n" ".balign 8\n" ".quad 0b, %l[label], %0\n" ".popsection\n" : : "X" (&((char *)key)[branch]) : : label); return false; label: return true; }

Contributors

PersonTokensPropCommitsCommitProp
Peter Zijlstra2748.21%116.67%
Jan Glauber1119.64%116.67%
Ingo Molnar1017.86%233.33%
Heiko Carstens814.29%233.33%
Total56100.00%6100.00%


static __always_inline bool arch_static_branch_jump(struct static_key *key, bool branch) { asm_volatile_goto("0: brcl 15, %l[label]\n" ".pushsection __jump_table, \"aw\"\n" ".balign 8\n" ".quad 0b, %l[label], %0\n" ".popsection\n" : : "X" (&((char *)key)[branch]) : : label); return false; label: return true; }

Contributors

PersonTokensPropCommitsCommitProp
Peter Zijlstra3772.55%133.33%
Jan Glauber815.69%133.33%
Ingo Molnar611.76%133.33%
Total51100.00%3100.00%

typedef unsigned long jump_label_t; struct jump_entry { jump_label_t code; jump_label_t target; jump_label_t key; }; #endif /* __ASSEMBLY__ */ #endif

Overall Contributors

PersonTokensPropCommitsCommitProp
Peter Zijlstra6441.03%111.11%
Jan Glauber5132.69%111.11%
Ingo Molnar1811.54%222.22%
Heiko Carstens138.33%222.22%
Anton Blanchard63.85%111.11%
Jason Baron31.92%111.11%
Greg Kroah-Hartman10.64%111.11%
Total156100.00%9100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.