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

TOMOYO Linux Cross Reference
Linux/arch/arm64/include/asm/syscall.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/arm64/include/asm/syscall.h (Version linux-6.12-rc7) and /arch/i386/include/asm-i386/syscall.h (Version linux-5.10.229)


  1 /* SPDX-License-Identifier: GPL-2.0-only */         1 
  2 /*                                                
  3  * Copyright (C) 2012 ARM Ltd.                    
  4  */                                               
  5 #ifndef __ASM_SYSCALL_H                           
  6 #define __ASM_SYSCALL_H                           
  7                                                   
  8 #include <uapi/linux/audit.h>                     
  9 #include <linux/compat.h>                         
 10 #include <linux/err.h>                            
 11                                                   
 12 typedef long (*syscall_fn_t)(const struct pt_r    
 13                                                   
 14 extern const syscall_fn_t sys_call_table[];       
 15                                                   
 16 #ifdef CONFIG_COMPAT                              
 17 extern const syscall_fn_t compat_sys_call_tabl    
 18 #endif                                            
 19                                                   
 20 static inline int syscall_get_nr(struct task_s    
 21                                  struct pt_reg    
 22 {                                                 
 23         return regs->syscallno;                   
 24 }                                                 
 25                                                   
 26 static inline void syscall_rollback(struct tas    
 27                                     struct pt_    
 28 {                                                 
 29         regs->regs[0] = regs->orig_x0;            
 30 }                                                 
 31                                                   
 32 static inline long syscall_get_return_value(st    
 33                                             st    
 34 {                                                 
 35         unsigned long val = regs->regs[0];        
 36                                                   
 37         if (is_compat_thread(task_thread_info(    
 38                 val = sign_extend64(val, 31);     
 39                                                   
 40         return val;                               
 41 }                                                 
 42                                                   
 43 static inline long syscall_get_error(struct ta    
 44                                      struct pt    
 45 {                                                 
 46         unsigned long error = syscall_get_retu    
 47                                                   
 48         return IS_ERR_VALUE(error) ? error : 0    
 49 }                                                 
 50                                                   
 51 static inline void syscall_set_return_value(st    
 52                                             st    
 53                                             in    
 54 {                                                 
 55         if (error)                                
 56                 val = error;                      
 57                                                   
 58         if (is_compat_thread(task_thread_info(    
 59                 val = lower_32_bits(val);         
 60                                                   
 61         regs->regs[0] = val;                      
 62 }                                                 
 63                                                   
 64 #define SYSCALL_MAX_ARGS 6                        
 65                                                   
 66 static inline void syscall_get_arguments(struc    
 67                                          struc    
 68                                          unsig    
 69 {                                                 
 70         args[0] = regs->orig_x0;                  
 71         args++;                                   
 72                                                   
 73         memcpy(args, &regs->regs[1], 5 * sizeo    
 74 }                                                 
 75                                                   
 76 /*                                                
 77  * We don't care about endianness (__AUDIT_ARC    
 78  * AArch64 has the same system calls both on l    
 79  */                                               
 80 static inline int syscall_get_arch(struct task    
 81 {                                                 
 82         if (is_compat_thread(task_thread_info(    
 83                 return AUDIT_ARCH_ARM;            
 84                                                   
 85         return AUDIT_ARCH_AARCH64;                
 86 }                                                 
 87                                                   
 88 int syscall_trace_enter(struct pt_regs *regs);    
 89 void syscall_trace_exit(struct pt_regs *regs);    
 90                                                   
 91 #endif  /* __ASM_SYSCALL_H */                     
 92                                                   

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