~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/xtensa/include/asm/irqflags.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /*
  2  * Xtensa IRQ flags handling functions
  3  *
  4  * This file is subject to the terms and conditions of the GNU General Public
  5  * License.  See the file "COPYING" in the main directory of this archive
  6  * for more details.
  7  *
  8  * Copyright (C) 2001 - 2005 Tensilica Inc.
  9  * Copyright (C) 2015 Cadence Design Systems Inc.
 10  */
 11 
 12 #ifndef _XTENSA_IRQFLAGS_H
 13 #define _XTENSA_IRQFLAGS_H
 14 
 15 #include <linux/stringify.h>
 16 #include <linux/types.h>
 17 #include <asm/processor.h>
 18 
 19 static inline unsigned long arch_local_save_flags(void)
 20 {
 21         unsigned long flags;
 22         asm volatile("rsr %0, ps" : "=a" (flags));
 23         return flags;
 24 }
 25 
 26 static inline unsigned long arch_local_irq_save(void)
 27 {
 28         unsigned long flags;
 29 #if XTENSA_FAKE_NMI
 30 #if defined(CONFIG_DEBUG_MISC) && (LOCKLEVEL | TOPLEVEL) >= XCHAL_DEBUGLEVEL
 31         unsigned long tmp;
 32 
 33         asm volatile("rsr       %0, ps\t\n"
 34                      "extui     %1, %0, 0, 4\t\n"
 35                      "bgei      %1, "__stringify(LOCKLEVEL)", 1f\t\n"
 36                      "rsil      %0, "__stringify(LOCKLEVEL)"\n"
 37                      "1:"
 38                      : "=a" (flags), "=a" (tmp) :: "memory");
 39 #else
 40         asm volatile("rsr       %0, ps\t\n"
 41                      "or        %0, %0, %1\t\n"
 42                      "xsr       %0, ps\t\n"
 43                      "rsync"
 44                      : "=&a" (flags) : "a" (LOCKLEVEL) : "memory");
 45 #endif
 46 #else
 47         asm volatile("rsil      %0, "__stringify(LOCKLEVEL)
 48                      : "=a" (flags) :: "memory");
 49 #endif
 50         return flags;
 51 }
 52 
 53 static inline void arch_local_irq_disable(void)
 54 {
 55         arch_local_irq_save();
 56 }
 57 
 58 static inline void arch_local_irq_enable(void)
 59 {
 60         unsigned long flags;
 61         asm volatile("rsil %0, 0" : "=a" (flags) :: "memory");
 62 }
 63 
 64 static inline void arch_local_irq_restore(unsigned long flags)
 65 {
 66         asm volatile("wsr %0, ps; rsync"
 67                      :: "a" (flags) : "memory");
 68 }
 69 
 70 static inline bool arch_irqs_disabled_flags(unsigned long flags)
 71 {
 72 #if XCHAL_EXCM_LEVEL < LOCKLEVEL || (1 << PS_EXCM_BIT) < LOCKLEVEL
 73 #error "XCHAL_EXCM_LEVEL and 1<<PS_EXCM_BIT must be no less than LOCKLEVEL"
 74 #endif
 75         return (flags & (PS_INTLEVEL_MASK | (1 << PS_EXCM_BIT))) >= LOCKLEVEL;
 76 }
 77 
 78 static inline bool arch_irqs_disabled(void)
 79 {
 80         return arch_irqs_disabled_flags(arch_local_save_flags());
 81 }
 82 
 83 #endif /* _XTENSA_IRQFLAGS_H */
 84 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php