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

TOMOYO Linux Cross Reference
Linux/arch/csky/kernel/probes/ftrace.c

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/csky/kernel/probes/ftrace.c (Architecture sparc) and /arch/i386/kernel/probes/ftrace.c (Architecture i386)


  1 // SPDX-License-Identifier: GPL-2.0                 1 
  2                                                   
  3 #include <linux/kprobes.h>                        
  4                                                   
  5 /* Ftrace callback handler for kprobes -- call    
  6 void kprobe_ftrace_handler(unsigned long ip, u    
  7                            struct ftrace_ops *    
  8 {                                                 
  9         int bit;                                  
 10         bool lr_saver = false;                    
 11         struct kprobe *p;                         
 12         struct kprobe_ctlblk *kcb;                
 13         struct pt_regs *regs;                     
 14                                                   
 15         if (unlikely(kprobe_ftrace_disabled))     
 16                 return;                           
 17                                                   
 18         bit = ftrace_test_recursion_trylock(ip    
 19         if (bit < 0)                              
 20                 return;                           
 21                                                   
 22         regs = ftrace_get_regs(fregs);            
 23         p = get_kprobe((kprobe_opcode_t *)ip);    
 24         if (!p) {                                 
 25                 p = get_kprobe((kprobe_opcode_    
 26                 if (unlikely(!p) || kprobe_dis    
 27                         goto out;                 
 28                 lr_saver = true;                  
 29         }                                         
 30                                                   
 31         kcb = get_kprobe_ctlblk();                
 32         if (kprobe_running()) {                   
 33                 kprobes_inc_nmissed_count(p);     
 34         } else {                                  
 35                 unsigned long orig_ip = instru    
 36                                                   
 37                 if (lr_saver)                     
 38                         ip -= MCOUNT_INSN_SIZE    
 39                 instruction_pointer_set(regs,     
 40                 __this_cpu_write(current_kprob    
 41                 kcb->kprobe_status = KPROBE_HI    
 42                 if (!p->pre_handler || !p->pre    
 43                         /*                        
 44                          * Emulate singlestep     
 45                          * as if there is a no    
 46                          */                       
 47                         instruction_pointer_se    
 48                                 (unsigned long    
 49                         if (unlikely(p->post_h    
 50                                 kcb->kprobe_st    
 51                                 p->post_handle    
 52                         }                         
 53                         instruction_pointer_se    
 54                 }                                 
 55                 /*                                
 56                  * If pre_handler returns !0,     
 57                  * skip emulating post_handler    
 58                  */                               
 59                 __this_cpu_write(current_kprob    
 60         }                                         
 61 out:                                              
 62         ftrace_test_recursion_unlock(bit);        
 63 }                                                 
 64 NOKPROBE_SYMBOL(kprobe_ftrace_handler);           
 65                                                   
 66 int arch_prepare_kprobe_ftrace(struct kprobe *    
 67 {                                                 
 68         p->ainsn.api.insn = NULL;                 
 69         return 0;                                 
 70 }                                                 
 71                                                   

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