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

TOMOYO Linux Cross Reference
Linux/arch/powerpc/kernel/reloc_64.S

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/powerpc/kernel/reloc_64.S (Architecture sparc) and /arch/m68k/kernel/reloc_64.S (Architecture m68k)


  1 /* SPDX-License-Identifier: GPL-2.0-or-later *    
  2 /*                                                
  3  * Code to process dynamic relocations in the     
  4  *                                                
  5  * Copyright 2008 Paul Mackerras, IBM Corp.       
  6  */                                               
  7                                                   
  8 #include <asm/ppc_asm.h>                          
  9                                                   
 10 RELA = 7                                          
 11 RELASZ = 8                                        
 12 RELAENT = 9                                       
 13 R_PPC64_RELATIVE = 22                             
 14 R_PPC64_UADDR64 = 43                              
 15                                                   
 16 /*                                                
 17  * r3 = desired final address of kernel           
 18  */                                               
 19 _GLOBAL(relocate)                                 
 20         mflr    r0                                
 21         bcl     20,31,$+4                         
 22 0:      mflr    r12             /* r12 has run    
 23         mtlr    r0                                
 24         ld      r11,(p_dyn - 0b)(r12)             
 25         add     r11,r11,r12     /* r11 has run    
 26         ld      r9,(p_rela - 0b)(r12)             
 27         add     r9,r9,r12       /* r9 has runt    
 28         ld      r10,(p_st - 0b)(r12)              
 29         add     r10,r10,r12     /* r10 has run    
 30         ld      r4,(p_sym - 0b)(r12)              
 31         add     r4,r4,r12       /* r4 has runt    
 32                                                   
 33         /*                                        
 34          * Scan the dynamic section for the RE    
 35          */                                       
 36         li      r7,0                              
 37         li      r8,0                              
 38 .Ltags:                                           
 39         ld      r6,0(r11)       /* get tag */     
 40         cmpdi   r6,0                              
 41         beq     .Lend_of_list           /* end    
 42         cmpdi   r6,RELA                           
 43         bne     2f                                
 44         ld      r7,8(r11)       /* get RELA po    
 45         b       4f                                
 46 2:      cmpdi   r6,RELASZ                         
 47         bne     3f                                
 48         ld      r8,8(r11)       /* get RELASZ     
 49         b       4f                                
 50 3:      cmpdi   r6,RELAENT                        
 51         bne     4f                                
 52         ld      r12,8(r11)      /* get RELAENT    
 53 4:      addi    r11,r11,16                        
 54         b       .Ltags                            
 55 .Lend_of_list:                                    
 56         cmpdi   r7,0            /* check we ha    
 57         cmpdi   cr1,r8,0                          
 58         beq     .Lout                             
 59         beq     cr1,.Lout                         
 60         cmpdi   r12,0                             
 61         beq     .Lout                             
 62                                                   
 63         /*                                        
 64          * Work out linktime address of _stext    
 65          * relocation offset to be applied.       
 66          * cur_offset [r7] = rela.run [r9] - r    
 67          * _stext.link [r10] = _stext.run [r10    
 68          * final_offset [r3] = _stext.final [r    
 69          */                                       
 70         subf    r7,r7,r9        /* cur_offset     
 71         subf    r10,r7,r10                        
 72         subf    r3,r10,r3       /* final_offse    
 73                                                   
 74         /*                                        
 75          * Run through the list of relocations    
 76          * R_PPC64_RELATIVE and R_PPC64_UADDR6    
 77          */                                       
 78         divd    r8,r8,r12       /* RELASZ / RE    
 79         mtctr   r8                                
 80 .Lrels: ld      r0,8(r9)                /* ELF    
 81         cmpdi   r0,R_PPC64_RELATIVE               
 82         bne     .Luaddr64                         
 83         ld      r6,0(r9)        /* reloc->r_of    
 84         ld      r0,16(r9)       /* reloc->r_ad    
 85         b       .Lstore                           
 86 .Luaddr64:                                        
 87         srdi    r5,r0,32        /* ELF64_R_SYM    
 88         clrldi  r0,r0,32                          
 89         cmpdi   r0,R_PPC64_UADDR64                
 90         bne     .Lnext                            
 91         ld      r6,0(r9)                          
 92         ld      r0,16(r9)                         
 93         mulli   r5,r5,24        /* 24 == sizeo    
 94         add     r5,r5,r4        /* elf64_sym[E    
 95         ld      r5,8(r5)                          
 96         add     r0,r0,r5                          
 97 .Lstore:                                          
 98         add     r0,r0,r3                          
 99         stdx    r0,r7,r6                          
100 .Lnext:                                           
101         add     r9,r9,r12                         
102         bdnz    .Lrels                            
103 .Lout:                                            
104         blr                                       
105                                                   
106 .balign 8                                         
107 p_dyn:  .8byte  __dynamic_start - 0b              
108 p_rela: .8byte  __rela_dyn_start - 0b             
109 p_sym:          .8byte __dynamic_symtab - 0b      
110 p_st:   .8byte  _stext - 0b                       
111                                                   
                                                      

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