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

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

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ 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.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /arch/s390/include/asm/irqflags.h (Architecture ppc) and /arch/sparc64/include/asm-sparc64/irqflags.h (Architecture sparc64)


  1 /* SPDX-License-Identifier: GPL-2.0 */              1 
  2 /*                                                
  3  *    Copyright IBM Corp. 2006, 2010              
  4  *    Author(s): Martin Schwidefsky <schwidefs    
  5  */                                               
  6                                                   
  7 #ifndef __ASM_IRQFLAGS_H                          
  8 #define __ASM_IRQFLAGS_H                          
  9                                                   
 10 #include <linux/types.h>                          
 11                                                   
 12 #define ARCH_IRQ_ENABLED        (3UL << (BITS_    
 13                                                   
 14 /* store then OR system mask. */                  
 15 #define __arch_local_irq_stosm(__or)              
 16 ({                                                
 17         unsigned long __mask;                     
 18         asm volatile(                             
 19                 "       stosm   %0,%1"            
 20                 : "=Q" (__mask) : "i" (__or) :    
 21         __mask;                                   
 22 })                                                
 23                                                   
 24 /* store then AND system mask. */                 
 25 #define __arch_local_irq_stnsm(__and)             
 26 ({                                                
 27         unsigned long __mask;                     
 28         asm volatile(                             
 29                 "       stnsm   %0,%1"            
 30                 : "=Q" (__mask) : "i" (__and)     
 31         __mask;                                   
 32 })                                                
 33                                                   
 34 /* set system mask. */                            
 35 static __always_inline void __arch_local_irq_s    
 36 {                                                 
 37         asm volatile("ssm   %0" : : "Q" (flags    
 38 }                                                 
 39                                                   
 40 #ifdef CONFIG_KMSAN                               
 41 #define arch_local_irq_attributes noinline not    
 42 #else                                             
 43 #define arch_local_irq_attributes __always_inl    
 44 #endif                                            
 45                                                   
 46 static arch_local_irq_attributes unsigned long    
 47 {                                                 
 48         return __arch_local_irq_stnsm(0xff);      
 49 }                                                 
 50                                                   
 51 static arch_local_irq_attributes unsigned long    
 52 {                                                 
 53         return __arch_local_irq_stnsm(0xfc);      
 54 }                                                 
 55                                                   
 56 static __always_inline void arch_local_irq_dis    
 57 {                                                 
 58         arch_local_irq_save();                    
 59 }                                                 
 60                                                   
 61 static arch_local_irq_attributes void arch_loc    
 62 {                                                 
 63         __arch_local_irq_stosm(0x01);             
 64 }                                                 
 65                                                   
 66 static arch_local_irq_attributes void arch_loc    
 67 {                                                 
 68         __arch_local_irq_stosm(0x03);             
 69 }                                                 
 70                                                   
 71 /* This only restores external and I/O interru    
 72 static __always_inline void arch_local_irq_res    
 73 {                                                 
 74         /* only disabled->disabled and disable    
 75         if (flags & ARCH_IRQ_ENABLED)             
 76                 arch_local_irq_enable();          
 77 }                                                 
 78                                                   
 79 static __always_inline bool arch_irqs_disabled    
 80 {                                                 
 81         return !(flags & ARCH_IRQ_ENABLED);       
 82 }                                                 
 83                                                   
 84 static __always_inline bool arch_irqs_disabled    
 85 {                                                 
 86         return arch_irqs_disabled_flags(arch_l    
 87 }                                                 
 88                                                   
 89 #endif /* __ASM_IRQFLAGS_H */                     
 90                                                   

~ [ 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