cregit-Linux how code gets into the kernel

Release 4.11 arch/metag/include/asm/irqflags.h

/*
 * IRQ flags handling
 *
 * This file gets included from lowlevel asm headers too, to provide
 * wrapped versions of the local_irq_*() APIs, based on the
 * raw_local_irq_*() functions from the lowlevel headers.
 */
#ifndef _ASM_IRQFLAGS_H

#define _ASM_IRQFLAGS_H

#ifndef __ASSEMBLY__

#include <asm/core_reg.h>
#include <asm/metag_regs.h>


#define INTS_OFF_MASK TXSTATI_BGNDHALT_BIT

#ifdef CONFIG_SMP
extern unsigned int get_trigger_mask(void);
#else

extern unsigned int global_trigger_mask;


static inline unsigned int get_trigger_mask(void) { return global_trigger_mask; }

Contributors

PersonTokensPropCommitsCommitProp
James Hogan13100.00%1100.00%
Total13100.00%1100.00%

#endif
static inline unsigned long arch_local_save_flags(void) { return __core_reg_get(TXMASKI); }

Contributors

PersonTokensPropCommitsCommitProp
James Hogan16100.00%1100.00%
Total16100.00%1100.00%


static inline int arch_irqs_disabled_flags(unsigned long flags) { return (flags & ~INTS_OFF_MASK) == 0; }

Contributors

PersonTokensPropCommitsCommitProp
James Hogan21100.00%1100.00%
Total21100.00%1100.00%


static inline int arch_irqs_disabled(void) { unsigned long flags = arch_local_save_flags(); return arch_irqs_disabled_flags(flags); }

Contributors

PersonTokensPropCommitsCommitProp
James Hogan22100.00%1100.00%
Total22100.00%1100.00%


static inline unsigned long __irqs_disabled(void) { /* * We shouldn't enable exceptions if they are not already * enabled. This is required for chancalls to work correctly. */ return arch_local_save_flags() & INTS_OFF_MASK; }

Contributors

PersonTokensPropCommitsCommitProp
James Hogan17100.00%1100.00%
Total17100.00%1100.00%

/* * For spinlocks, etc: */
static inline unsigned long arch_local_irq_save(void) { unsigned long flags = __irqs_disabled(); asm volatile("SWAP %0,TXMASKI\n" : "=r" (flags) : "0" (flags) : "memory"); return flags; }

Contributors

PersonTokensPropCommitsCommitProp
James Hogan23100.00%1100.00%
Total23100.00%1100.00%


static inline void arch_local_irq_restore(unsigned long flags) { asm volatile("MOV TXMASKI,%0\n" : : "r" (flags) : "memory"); }

Contributors

PersonTokensPropCommitsCommitProp
James Hogan14100.00%1100.00%
Total14100.00%1100.00%


static inline void arch_local_irq_disable(void) { unsigned long flags = __irqs_disabled(); asm volatile("MOV TXMASKI,%0\n" : : "r" (flags) : "memory"); }

Contributors

PersonTokensPropCommitsCommitProp
James Hogan19100.00%1100.00%
Total19100.00%1100.00%

#ifdef CONFIG_SMP /* Avoid circular include dependencies through <linux/preempt.h> */ void arch_local_irq_enable(void); #else
static inline void arch_local_irq_enable(void) { arch_local_irq_restore(get_trigger_mask()); }

Contributors

PersonTokensPropCommitsCommitProp
James Hogan15100.00%1100.00%
Total15100.00%1100.00%

#endif #endif /* (__ASSEMBLY__) */ #endif /* !(_ASM_IRQFLAGS_H) */

Overall Contributors

PersonTokensPropCommitsCommitProp
James Hogan221100.00%2100.00%
Total221100.00%2100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.