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

TOMOYO Linux Cross Reference
Linux/arch/mips/bcm63xx/prom.c

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ 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.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /arch/mips/bcm63xx/prom.c (Version linux-6.11.5) and /arch/mips/bcm63xx/prom.c (Version linux-6.4.16)


  1 /*                                                  1 /*
  2  * This file is subject to the terms and condi      2  * This file is subject to the terms and conditions of the GNU General Public
  3  * License.  See the file "COPYING" in the mai      3  * License.  See the file "COPYING" in the main directory of this archive
  4  * for more details.                                4  * for more details.
  5  *                                                  5  *
  6  * Copyright (C) 2008 Maxime Bizon <mbizon@fre      6  * Copyright (C) 2008 Maxime Bizon <mbizon@freebox.fr>
  7  */                                                 7  */
  8                                                     8 
  9 #include <linux/init.h>                             9 #include <linux/init.h>
 10 #include <linux/memblock.h>                        10 #include <linux/memblock.h>
 11 #include <linux/smp.h>                             11 #include <linux/smp.h>
 12 #include <asm/bootinfo.h>                          12 #include <asm/bootinfo.h>
 13 #include <asm/bmips.h>                             13 #include <asm/bmips.h>
 14 #include <asm/smp-ops.h>                           14 #include <asm/smp-ops.h>
 15 #include <asm/mipsregs.h>                          15 #include <asm/mipsregs.h>
 16 #include <bcm63xx_board.h>                         16 #include <bcm63xx_board.h>
 17 #include <bcm63xx_cpu.h>                           17 #include <bcm63xx_cpu.h>
 18 #include <bcm63xx_io.h>                            18 #include <bcm63xx_io.h>
 19 #include <bcm63xx_regs.h>                          19 #include <bcm63xx_regs.h>
 20                                                    20 
 21 void __init prom_init(void)                        21 void __init prom_init(void)
 22 {                                                  22 {
 23         u32 reg, mask;                             23         u32 reg, mask;
 24                                                    24 
 25         /* Cache CBR addr before CPU/DMA setup << 
 26         bmips_cbr_addr = BMIPS_GET_CBR();      << 
 27                                                << 
 28         bcm63xx_cpu_init();                        25         bcm63xx_cpu_init();
 29                                                    26 
 30         /* stop any running watchdog */            27         /* stop any running watchdog */
 31         bcm_wdt_writel(WDT_STOP_1, WDT_CTL_REG     28         bcm_wdt_writel(WDT_STOP_1, WDT_CTL_REG);
 32         bcm_wdt_writel(WDT_STOP_2, WDT_CTL_REG     29         bcm_wdt_writel(WDT_STOP_2, WDT_CTL_REG);
 33                                                    30 
 34         /* disable all hardware blocks clock f     31         /* disable all hardware blocks clock for now */
 35         if (BCMCPU_IS_3368())                      32         if (BCMCPU_IS_3368())
 36                 mask = CKCTL_3368_ALL_SAFE_EN;     33                 mask = CKCTL_3368_ALL_SAFE_EN;
 37         else if (BCMCPU_IS_6328())                 34         else if (BCMCPU_IS_6328())
 38                 mask = CKCTL_6328_ALL_SAFE_EN;     35                 mask = CKCTL_6328_ALL_SAFE_EN;
 39         else if (BCMCPU_IS_6338())                 36         else if (BCMCPU_IS_6338())
 40                 mask = CKCTL_6338_ALL_SAFE_EN;     37                 mask = CKCTL_6338_ALL_SAFE_EN;
 41         else if (BCMCPU_IS_6345())                 38         else if (BCMCPU_IS_6345())
 42                 mask = CKCTL_6345_ALL_SAFE_EN;     39                 mask = CKCTL_6345_ALL_SAFE_EN;
 43         else if (BCMCPU_IS_6348())                 40         else if (BCMCPU_IS_6348())
 44                 mask = CKCTL_6348_ALL_SAFE_EN;     41                 mask = CKCTL_6348_ALL_SAFE_EN;
 45         else if (BCMCPU_IS_6358())                 42         else if (BCMCPU_IS_6358())
 46                 mask = CKCTL_6358_ALL_SAFE_EN;     43                 mask = CKCTL_6358_ALL_SAFE_EN;
 47         else if (BCMCPU_IS_6362())                 44         else if (BCMCPU_IS_6362())
 48                 mask = CKCTL_6362_ALL_SAFE_EN;     45                 mask = CKCTL_6362_ALL_SAFE_EN;
 49         else if (BCMCPU_IS_6368())                 46         else if (BCMCPU_IS_6368())
 50                 mask = CKCTL_6368_ALL_SAFE_EN;     47                 mask = CKCTL_6368_ALL_SAFE_EN;
 51         else                                       48         else
 52                 mask = 0;                          49                 mask = 0;
 53                                                    50 
 54         reg = bcm_perf_readl(PERF_CKCTL_REG);      51         reg = bcm_perf_readl(PERF_CKCTL_REG);
 55         reg &= ~mask;                              52         reg &= ~mask;
 56         bcm_perf_writel(reg, PERF_CKCTL_REG);      53         bcm_perf_writel(reg, PERF_CKCTL_REG);
 57                                                    54 
 58         /* do low level board init */              55         /* do low level board init */
 59         board_prom_init();                         56         board_prom_init();
 60                                                    57 
 61         /* set up SMP */                           58         /* set up SMP */
 62         if (!register_bmips_smp_ops()) {           59         if (!register_bmips_smp_ops()) {
 63                 /*                                 60                 /*
 64                  * BCM6328 might not have its      61                  * BCM6328 might not have its second CPU enabled, while BCM3368
 65                  * and BCM6358 need special ha     62                  * and BCM6358 need special handling for their shared TLB, so
 66                  * disable SMP for now.            63                  * disable SMP for now.
 67                  */                                64                  */
 68                 if (BCMCPU_IS_6328()) {            65                 if (BCMCPU_IS_6328()) {
 69                         reg = bcm_readl(BCM_63     66                         reg = bcm_readl(BCM_6328_OTP_BASE +
 70                                         OTP_US     67                                         OTP_USER_BITS_6328_REG(3));
 71                                                    68 
 72                         if (reg & OTP_6328_REG     69                         if (reg & OTP_6328_REG3_TP1_DISABLED)
 73                                 bmips_smp_enab     70                                 bmips_smp_enabled = 0;
 74                 } else if (BCMCPU_IS_3368() ||     71                 } else if (BCMCPU_IS_3368() || BCMCPU_IS_6358()) {
 75                         bmips_smp_enabled = 0;     72                         bmips_smp_enabled = 0;
 76                 }                                  73                 }
 77                                                    74 
 78                 if (!bmips_smp_enabled)            75                 if (!bmips_smp_enabled)
 79                         return;                    76                         return;
 80                                                    77 
 81                 /*                                 78                 /*
 82                  * The bootloader has set up t     79                  * The bootloader has set up the CPU1 reset vector at
 83                  * 0xa000_0200.                    80                  * 0xa000_0200.
 84                  * This conflicts with the spe     81                  * This conflicts with the special interrupt vector (IV).
 85                  * The bootloader has also set     82                  * The bootloader has also set up CPU1 to respond to the wrong
 86                  * IPI interrupt.                  83                  * IPI interrupt.
 87                  * Here we will start up CPU1      84                  * Here we will start up CPU1 in the background and ask it to
 88                  * reconfigure itself then go      85                  * reconfigure itself then go back to sleep.
 89                  */                                86                  */
 90                 memcpy((void *)0xa0000200, bmi     87                 memcpy((void *)0xa0000200, bmips_smp_movevec, 0x20);
 91                 __sync();                          88                 __sync();
 92                 set_c0_cause(C_SW0);               89                 set_c0_cause(C_SW0);
 93                 cpumask_set_cpu(1, &bmips_boot     90                 cpumask_set_cpu(1, &bmips_booted_mask);
 94                                                    91 
 95                 /*                                 92                 /*
 96                  * FIXME: we really should hav     93                  * FIXME: we really should have some sort of hazard barrier here
 97                  */                                94                  */
 98         }                                          95         }
 99 }                                                  96 }
100                                                    97 

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