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

TOMOYO Linux Cross Reference
Linux/arch/arm/mach-spear/platsmp.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/arm/mach-spear/platsmp.c (Architecture m68k) and /arch/mips/mach-spear/platsmp.c (Architecture mips)


  1 // SPDX-License-Identifier: GPL-2.0-only            1 
  2 /*                                                
  3  * arch/arm/mach-spear13xx/platsmp.c              
  4  *                                                
  5  * based upon linux/arch/arm/mach-realview/pla    
  6  *                                                
  7  * Copyright (C) 2012 ST Microelectronics Ltd.    
  8  * Shiraz Hashim <shiraz.linux.kernel@gmail.co    
  9  */                                               
 10                                                   
 11 #include <linux/delay.h>                          
 12 #include <linux/jiffies.h>                        
 13 #include <linux/io.h>                             
 14 #include <linux/smp.h>                            
 15 #include <asm/cacheflush.h>                       
 16 #include <asm/smp_scu.h>                          
 17 #include "spear.h"                                
 18 #include "generic.h"                              
 19                                                   
 20 /* XXX spear_pen_release is cargo culted code     
 21 volatile int spear_pen_release = -1;              
 22                                                   
 23 /*                                                
 24  * XXX CARGO CULTED CODE - DO NOT COPY XXX        
 25  *                                                
 26  * Write spear_pen_release in a way that is gu    
 27  * all observers, irrespective of whether they    
 28  * or not.  This is necessary for the hotplug     
 29  */                                               
 30 static void spear_write_pen_release(int val)      
 31 {                                                 
 32         spear_pen_release = val;                  
 33         smp_wmb();                                
 34         sync_cache_w(&spear_pen_release);         
 35 }                                                 
 36                                                   
 37 static DEFINE_SPINLOCK(boot_lock);                
 38                                                   
 39 static void __iomem *scu_base = IOMEM(VA_SCU_B    
 40                                                   
 41 static void spear13xx_secondary_init(unsigned     
 42 {                                                 
 43         /*                                        
 44          * let the primary processor know we'r    
 45          * pen, then head off into the C entry    
 46          */                                       
 47         spear_write_pen_release(-1);              
 48                                                   
 49         /*                                        
 50          * Synchronise with the boot thread.      
 51          */                                       
 52         spin_lock(&boot_lock);                    
 53         spin_unlock(&boot_lock);                  
 54 }                                                 
 55                                                   
 56 static int spear13xx_boot_secondary(unsigned i    
 57 {                                                 
 58         unsigned long timeout;                    
 59                                                   
 60         /*                                        
 61          * set synchronisation state between t    
 62          * and the secondary one                  
 63          */                                       
 64         spin_lock(&boot_lock);                    
 65                                                   
 66         /*                                        
 67          * The secondary processor is waiting     
 68          * the holding pen - release it, then     
 69          * that it has been released by resett    
 70          *                                        
 71          * Note that "spear_pen_release" is th    
 72          * "cpu" is Linux's internal ID.          
 73          */                                       
 74         spear_write_pen_release(cpu);             
 75                                                   
 76         timeout = jiffies + (1 * HZ);             
 77         while (time_before(jiffies, timeout))     
 78                 smp_rmb();                        
 79                 if (spear_pen_release == -1)      
 80                         break;                    
 81                                                   
 82                 udelay(10);                       
 83         }                                         
 84                                                   
 85         /*                                        
 86          * now the secondary core is starting     
 87          * calibrations, then wait for it to f    
 88          */                                       
 89         spin_unlock(&boot_lock);                  
 90                                                   
 91         return spear_pen_release != -1 ? -ENOS    
 92 }                                                 
 93                                                   
 94 /*                                                
 95  * Initialise the CPU possible map early - thi    
 96  * which may be present or become present in t    
 97  */                                               
 98 static void __init spear13xx_smp_init_cpus(voi    
 99 {                                                 
100         unsigned int i, ncores = scu_get_core_    
101                                                   
102         if (ncores > nr_cpu_ids) {                
103                 pr_warn("SMP: %u cores greater    
104                         ncores, nr_cpu_ids);      
105                 ncores = nr_cpu_ids;              
106         }                                         
107                                                   
108         for (i = 0; i < ncores; i++)              
109                 set_cpu_possible(i, true);        
110 }                                                 
111                                                   
112 static void __init spear13xx_smp_prepare_cpus(    
113 {                                                 
114                                                   
115         scu_enable(scu_base);                     
116                                                   
117         /*                                        
118          * Write the address of secondary star    
119          * (presently it is in SRAM). The Boot    
120          * soft interrupt, and then the second    
121          */                                       
122         __raw_writel(__pa_symbol(spear13xx_sec    
123 }                                                 
124                                                   
125 const struct smp_operations spear13xx_smp_ops     
126        .smp_init_cpus           = spear13xx_sm    
127        .smp_prepare_cpus        = spear13xx_sm    
128        .smp_secondary_init      = spear13xx_se    
129        .smp_boot_secondary      = spear13xx_bo    
130 #ifdef CONFIG_HOTPLUG_CPU                         
131        .cpu_die                 = spear13xx_cp    
132 #endif                                            
133 };                                                
134                                                   

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