From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753244Ab3FJJ3F (ORCPT ); Mon, 10 Jun 2013 05:29:05 -0400 Received: from eu1sys200aog114.obsmtp.com ([207.126.144.137]:39951 "EHLO eu1sys200aog114.obsmtp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752883Ab3FJJ27 (ORCPT ); Mon, 10 Jun 2013 05:28:59 -0400 From: Srinivas KANDAGATLA To: linux-arm-kernel@lists.infradead.org Cc: Andrew Morton , Arnd Bergmann , "David S. Miller" , devicetree-discuss@lists.ozlabs.org, Grant Likely , Greg Kroah-Hartman , John Stultz , Linus Walleij , linux@arm.linux.org.uk, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-serial@vger.kernel.org, Mark Brown , Mauro Carvalho Chehab , Olof Johansson , Rob Herring , Rob Landley , Samuel Ortiz , Srinivas Kandagatla , Stephen Gallimore , Stuart Menefy , Thomas Gleixner , Tony Prisk Subject: =?yes?q?=5BPATCH=20v2=2006/11=5D=20ARM=3Astixxxx=3A=20Add=20STiH415=20SOC=20support?= Date: Mon, 10 Jun 2013 10:26:21 +0100 Message-Id: <1370856381-6644-1-git-send-email-srinivas.kandagatla@st.com> X-Mailer: git-send-email 1.7.6.5 In-Reply-To: <1370855828-5318-1-git-send-email-srinivas.kandagatla@st.com> References: <1370855828-5318-1-git-send-email-srinivas.kandagatla@st.com> MIME-Version: 1.0 Content-Type: text/plain; charset=yes Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The STiH415 is the next generation of HD, AVC set-top box processors for satellite, cable, terrestrial and IP-STB markets. It is an ARM Cortex-A9 1.0 GHz, dual-core CPU. Signed-off-by: Srinivas Kandagatla CC: Stephen Gallimore CC: Stuart Menefy CC: Arnd Bergmann CC: Linus Walleij --- Documentation/arm/stixxxx/overview.txt | 33 +++ Documentation/arm/stixxxx/stih415-overview.txt | 12 + MAINTAINERS | 11 + arch/arm/Kconfig | 2 + arch/arm/Makefile | 1 + arch/arm/boot/dts/stih415-clock.dtsi | 38 +++ arch/arm/boot/dts/stih415-pinctrl.dtsi | 326 ++++++++++++++++++++++++ arch/arm/boot/dts/stih415.dtsi | 102 ++++++++ arch/arm/boot/dts/stih41x.dtsi | 38 +++ arch/arm/boot/dts/stixxxx-pincfg.h | 94 +++++++ arch/arm/mach-stixxxx/Kconfig | 45 ++++ arch/arm/mach-stixxxx/Makefile | 2 + arch/arm/mach-stixxxx/board-dt.c | 47 ++++ arch/arm/mach-stixxxx/headsmp.S | 44 ++++ arch/arm/mach-stixxxx/platsmp.c | 117 +++++++++ arch/arm/mach-stixxxx/smp.h | 19 ++ 16 files changed, 931 insertions(+), 0 deletions(-) create mode 100644 Documentation/arm/stixxxx/overview.txt create mode 100644 Documentation/arm/stixxxx/stih415-overview.txt create mode 100644 arch/arm/boot/dts/stih415-clock.dtsi create mode 100644 arch/arm/boot/dts/stih415-pinctrl.dtsi create mode 100644 arch/arm/boot/dts/stih415.dtsi create mode 100644 arch/arm/boot/dts/stih41x.dtsi create mode 100644 arch/arm/boot/dts/stixxxx-pincfg.h create mode 100644 arch/arm/mach-stixxxx/Kconfig create mode 100644 arch/arm/mach-stixxxx/Makefile create mode 100644 arch/arm/mach-stixxxx/board-dt.c create mode 100644 arch/arm/mach-stixxxx/headsmp.S create mode 100644 arch/arm/mach-stixxxx/platsmp.c create mode 100644 arch/arm/mach-stixxxx/smp.h diff --git a/Documentation/arm/stixxxx/overview.txt b/Documentation/arm/stixxxx/overview.txt new file mode 100644 index 0000000..a2f6390 --- /dev/null +++ b/Documentation/arm/stixxxx/overview.txt @@ -0,0 +1,33 @@ + STixxxx ARM Linux Overview + ========================== + +Introduction +------------ + + The ST Microelectronics Multimedia and Application Processors range of + CortexA9 System-on-Chip are supported by the 'STixxxx' platform of + ARM Linux. Currently STiH415, STiH416 SOCs are supported with both + B2000 and B2020 Reference boards. + + + configuration + ------------- + + A generic configuration is provided for both STiH415/416, and can be used as the + default by + make stih41x_defconfig + + Layout + ------ + All the files for multiple machine families (STiH415, STiH416, and STiG125) + are located in the platform code contained in arch/arm/mach-stixxxx + + There is a generic board board-dt.c in the mach folder which support + Flattened Device Tree, which means, It works with any compatible board with + Device Trees. + + + Document Author + --------------- + + Srinivas Kandagatla , (c) 2013 ST Microelectronics diff --git a/Documentation/arm/stixxxx/stih415-overview.txt b/Documentation/arm/stixxxx/stih415-overview.txt new file mode 100644 index 0000000..1c264b7 --- /dev/null +++ b/Documentation/arm/stixxxx/stih415-overview.txt @@ -0,0 +1,12 @@ + STiH415 Overview + ================ + +Introduction +------------ + + The STiH415 is the next generation of HD, AVC set-top box processors + for satellite, cable, terrestrial and IP-STB markets. + + Features + - ARM Cortex-A9 1.0 GHz, dual-core CPU + - SATA2×2,USB 2.0×3, PCIe, Gbit Ethernet MAC×2 diff --git a/MAINTAINERS b/MAINTAINERS index 250dc97..2aca7d2 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -1201,6 +1201,17 @@ M: Dinh Nguyen S: Maintained F: drivers/clk/socfpga/ +ARM/STIXXXX ARCHITECTURE +M: Srinivas Kandagatla +M: Stuart Menefy +L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers) +W: http://www.stlinux.com +S: Maintained +F: arch/arm/mach-stixxxx/ +F: drivers/pinctrl/pinctrl-stixxxx* +F: drivers/mfd/stixxxx-syscfg* +F: drivers/clocksource/global_timer.c + ARM/TECHNOLOGIC SYSTEMS TS7250 MACHINE SUPPORT M: Lennert Buytenhek L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers) diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 49d993c..790e321 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig @@ -989,6 +989,8 @@ source "arch/arm/mach-socfpga/Kconfig" source "arch/arm/mach-spear/Kconfig" +source "arch/arm/mach-stixxxx/Kconfig" + source "arch/arm/mach-s3c24xx/Kconfig" if ARCH_S3C64XX diff --git a/arch/arm/Makefile b/arch/arm/Makefile index 1ba358b..c876e0a 100644 --- a/arch/arm/Makefile +++ b/arch/arm/Makefile @@ -191,6 +191,7 @@ machine-$(CONFIG_ARCH_W90X900) += w90x900 machine-$(CONFIG_FOOTBRIDGE) += footbridge machine-$(CONFIG_ARCH_SOCFPGA) += socfpga machine-$(CONFIG_PLAT_SPEAR) += spear +machine-$(CONFIG_ARCH_STIXXXX) += stixxxx machine-$(CONFIG_ARCH_VIRT) += virt machine-$(CONFIG_ARCH_ZYNQ) += zynq machine-$(CONFIG_ARCH_SUNXI) += sunxi diff --git a/arch/arm/boot/dts/stih415-clock.dtsi b/arch/arm/boot/dts/stih415-clock.dtsi new file mode 100644 index 0000000..174c799 --- /dev/null +++ b/arch/arm/boot/dts/stih415-clock.dtsi @@ -0,0 +1,38 @@ +/* + * Copyright (C) 2013 STMicroelectronics (R&D) Limited + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ +/ { + clocks { + /* + * Fixed 30MHz oscillator input to SoC + */ + CLK_SYSIN: CLK_SYSIN { + #clock-cells = <0>; + compatible = "fixed-clock"; + clock-frequency = <30000000>; + }; + + /* + * ARM Peripheral clock for timers + */ + arm_periph_clk: arm_periph_clk { + #clock-cells = <0>; + compatible = "fixed-clock"; + clock-frequency = <500000000>; + }; + + /* + * Bootloader initialized system infrastructure clock for + * serial devices. + */ + CLKS_ICN_REG_0: CLKS_ICN_REG_0 { + #clock-cells = <0>; + compatible = "fixed-clock"; + clock-frequency = <100000000>; + }; + }; +}; diff --git a/arch/arm/boot/dts/stih415-pinctrl.dtsi b/arch/arm/boot/dts/stih415-pinctrl.dtsi new file mode 100644 index 0000000..c510f11 --- /dev/null +++ b/arch/arm/boot/dts/stih415-pinctrl.dtsi @@ -0,0 +1,326 @@ +/* + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * Author: Srinivas Kandagatla + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * publishhed by the Free Software Foundation. + */ +#include "stixxxx-pincfg.h" +/ { + + aliases { + gpio0 = &PIO0; + gpio1 = &PIO1; + gpio2 = &PIO2; + gpio3 = &PIO3; + gpio4 = &PIO4; + gpio5 = &PIO5; + gpio6 = &PIO6; + gpio7 = &PIO7; + gpio8 = &PIO8; + gpio9 = &PIO9; + gpio10 = &PIO10; + gpio11 = &PIO11; + gpio12 = &PIO12; + gpio13 = &PIO13; + gpio14 = &PIO14; + gpio15 = &PIO15; + gpio16 = &PIO16; + gpio17 = &PIO17; + gpio18 = &PIO18; + gpio19 = &PIO100; + gpio20 = &PIO101; + gpio21 = &PIO102; + gpio22 = &PIO103; + gpio23 = &PIO104; + gpio24 = &PIO105; + gpio25 = &PIO106; + gpio26 = &PIO107; + }; + + + soc { + pin-controller-sbc { + #address-cells = <1>; + #size-cells = <1>; + compatible = "st,stih415-pinctrl", "simple-bus"; + st,retime-in-delay = <0 500 1000 1500>; + st,retime-out-delay = <0 1000 2000 3000>; + st,syscfg = <&syscfg_sbc>; + st,syscfg-offsets = <0 5 7 9 16>; + ranges; + + PIO0: pinctrl@fe610000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe610000 0x100>; + st,bank-name = "PIO0"; + }; + + PIO1: pinctrl@fe611000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe611000 0x100>; + st,bank-name = "PIO1"; + }; + + PIO2: pinctrl@fe612000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe612000 0x100>; + st,bank-name = "PIO2"; + }; + + PIO3: pinctrl@fe613000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe613000 0x100>; + st,bank-name = "PIO3"; + + }; + + PIO4: pinctrl@fe614000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe614000 0x100>; + st,bank-name = "PIO4"; + }; + + sbc_serial1 { + pinctrl_sbc_serial1:sbc_serial1 { + st,function = ; + st,pins { + tx = <&PIO2 6 OUT>; + rx = <&PIO2 7 IN>; + }; + }; + }; + }; + + pin-controller-front { + #address-cells = <1>; + #size-cells = <1>; + compatible = "st,stih415-pinctrl", "simple-bus"; + st,retime-in-delay = <0 500 1000 1500>; + st,retime-out-delay = <0 1000 2000 3000>; + st,syscfg = <&syscfg_front>; + st,syscfg-offsets = <0 8 10 12 16>; + ranges; + + PIO5: pinctrl@fee00000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfee00000 0x100>; + st,bank-name = "PIO5"; + }; + PIO6: pinctrl@fee01000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfee01000 0x100>; + st,bank-name = "PIO6"; + }; + + PIO7: pinctrl@fee02000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfee02000 0x100>; + st,bank-name = "PIO7"; + }; + PIO8: pinctrl@fee03000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfee03000 0x100>; + st,bank-name = "PIO8"; + }; + PIO9: pinctrl@fee04000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfee04000 0x100>; + st,bank-name = "PIO9"; + }; + PIO10: pinctrl@fee05000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfee05000 0x100>; + st,bank-name = "PIO10"; + }; + PIO11: pinctrl@fee06000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfee06000 0x100>; + st,bank-name = "PIO11"; + }; + PIO12: pinctrl@fee07000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfee07000 0x100>; + st,bank-name = "PIO12"; + }; + }; + + pin-controller-rear { + #address-cells = <1>; + #size-cells = <1>; + compatible = "st,stih415-pinctrl", "simple-bus"; + st,retime-in-delay = <0 500 1000 1500>; + st,retime-out-delay = <0 1000 2000 3000>; + st,syscfg = <&syscfg_rear>; + st,syscfg-offsets = <0 6 8 10 38>; + ranges; + + PIO13: pinctrl@fe820000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe820000 0x100>; + st,bank-name = "PIO13"; + }; + PIO14: pinctrl@fe821000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe821000 0x100>; + st,bank-name = "PIO14"; + }; + PIO15: pinctrl@fe822000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe822000 0x100>; + st,bank-name = "PIO15"; + }; + PIO16: pinctrl@fe823000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe823000 0x100>; + st,bank-name = "PIO16"; + + }; + PIO17: pinctrl@fe824000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe824000 0x100>; + st,bank-name = "PIO17"; + + }; + PIO18: pinctrl@fe825000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfe825000 0x100>; + st,bank-name = "PIO18"; + + }; + + serial2 { + pinctrl_serial2: serial2-0 { + st,function = ; + st,pins { + tx = <&PIO17 4 OUT>; + rx = <&PIO17 5 IN>; + }; + }; + }; + + }; + + pin-controller-left { + #address-cells = <1>; + #size-cells = <1>; + compatible = "st,stih415-pinctrl", "simple-bus"; + st,retime-in-delay = <0 500 1000 1500>; + st,retime-out-delay = <0 1000 2000 3000>; + st,syscfg = <&syscfg_left>; + st,syscfg-offsets = <0 3 4 5 6>; + ranges; + + PIO100: pinctrl@fd6b0000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfd6b0000 0x100>; + st,bank-name = "PIO100"; + }; + PIO101: pinctrl@fd6b1000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfd6b1000 0x100>; + st,bank-name = "PIO101"; + + }; + PIO102: pinctrl@fd6b2000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfd6b2000 0x100>; + st,bank-name = "PIO102"; + + }; + + }; + + pin-controller-right { + #address-cells = <1>; + #size-cells = <1>; + compatible = "st,stih415-pinctrl", "simple-bus"; + st,retime-in-delay = <0 500 1000 1500>; + st,retime-out-delay = <0 1000 2000 3000>; + st,syscfg = <&syscfg_right>; + st,syscfg-offsets = <0 5 7 9 11>; + ranges; + + PIO103: pinctrl@fd330000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfd330000 0x100>; + st,bank-name = "PIO103"; + }; + PIO104: pinctrl@fd331000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfd331000 0x100>; + st,bank-name = "PIO104"; + }; + PIO105: pinctrl@fd332000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfd332000 0x100>; + st,bank-name = "PIO105"; + }; + PIO106: pinctrl@fd333000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfd333000 0x100>; + st,bank-name = "PIO106"; + }; + PIO107: pinctrl@fd334000 { + gpio-controller; + #gpio-cells = <1>; + compatible = "st,stixxxx-gpio"; + reg = <0xfd334000 0x100>; + st,bank-name = "PIO107"; + }; + }; + }; +}; diff --git a/arch/arm/boot/dts/stih415.dtsi b/arch/arm/boot/dts/stih415.dtsi new file mode 100644 index 0000000..6dcf5b4 --- /dev/null +++ b/arch/arm/boot/dts/stih415.dtsi @@ -0,0 +1,102 @@ +/* + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * Author: Srinivas Kandagatla + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * publishhed by the Free Software Foundation. + */ +#include "stih41x.dtsi" +#include "stih415-clock.dtsi" +#include "stih415-pinctrl.dtsi" +/ { + + L2: cache-controller { + compatible = "arm,pl310-cache"; + reg = <0xfffe2000 0x1000>; + arm,data-latency = <3 2 2>; + arm,tag-latency = <1 1 1>; + cache-unified; + cache-level = <2>; + }; + + soc { + #address-cells = <1>; + #size-cells = <1>; + interrupt-parent = <&intc>; + ranges; + compatible = "simple-bus"; + + syscfg_sbc: syscfg@fe600000{ + compatible = "st,stih415-syscfg"; + reg = <0xfe600000 0xb4>; + syscfg-range = <0 44>; + syscfg-name = "SYSCFG_SBC"; + }; + + syscfg_front: syscfg@fee10000{ + compatible = "st,stih415-syscfg"; + reg = <0xfee10000 0x194>; + syscfg-range = <100 100>; + syscfg-name = "SYSCFG_FRONT"; + }; + + syscfg_rear: syscfg@fe830000{ + compatible = "st,stih415-syscfg"; + reg = <0xfe830000 0x190>; + syscfg-range = <300 99>; + syscfg-name = "SYSCFG_REAR"; + }; + + /* MPE syscfgs */ + syscfg_left: syscfg@fd690000{ + compatible = "st,stih415-syscfg"; + reg = <0xfd690000 0x78>; + syscfg-range = <400 29>; + syscfg-name = "SYSCFG_LEFT"; + }; + + syscfg_right: syscfg@fd320000{ + compatible = "st,stih415-syscfg"; + reg = <0xfd320000 0x180>; + syscfg-range = <500 95>; + syscfg-name = "SYSCFG_RIGHT"; + }; + + syscfg_system: syscfg@fdde0000 { + compatible = "st,stih415-syscfg"; + reg = <0xfdde0000 0x15c>; + syscfg-range = <600 86>; + syscfg-name = "SYSCFG_SYSTEM"; + }; + + syscfg_lpm: syscfg@fe4b5100{ + compatible = "st,stih415-syscfg"; + reg = <0xfe4b5100 0x08>; + syscfg-range = <0 10>; + syscfg-name = "LPM_CFG_REGS"; + }; + + serial2: serial@fed32000 { + compatible = "st,asc"; + status = "disabled"; + reg = <0xfed32000 0x2c>; + interrupts = <0 197 0>; + pinctrl-names = "default"; + pinctrl-0 = <&pinctrl_serial2>; + clocks = <&CLKS_ICN_REG_0>; + }; + + /* SBC comms block ASCs in SASG1 */ + sbc_serial1: serial@fe531000 { + compatible = "st,asc"; + status = "disabled"; + reg = <0xfe531000 0x2c>; + interrupts = <0 210 0>; + clocks = <&CLK_SYSIN>; + pinctrl-names = "default"; + pinctrl-0 = <&pinctrl_sbc_serial1>; + }; + + }; +}; diff --git a/arch/arm/boot/dts/stih41x.dtsi b/arch/arm/boot/dts/stih41x.dtsi new file mode 100644 index 0000000..7321403 --- /dev/null +++ b/arch/arm/boot/dts/stih41x.dtsi @@ -0,0 +1,38 @@ +/ { + #address-cells = <1>; + #size-cells = <1>; + + cpus { + #address-cells = <1>; + #size-cells = <0>; + cpu@0 { + compatible = "arm,cortex-a9"; + reg = <0>; + }; + cpu@1 { + compatible = "arm,cortex-a9"; + reg = <1>; + }; + }; + + intc: interrupt-controller@fffe1000 { + compatible = "arm,cortex-a9-gic"; + #interrupt-cells = <3>; + interrupt-controller; + reg = <0xfffe1000 0x1000>, + <0xfffe0100 0x100>; + }; + + scu@fffe0000 { + compatible = "arm,cortex-a9-scu"; + reg = <0xfffe0000 0x1000>; + }; + + timer@fffe0200 { + interrupt-parent = <&intc>; + compatible = "arm,cortex-a9-global-timer"; + reg = <0xfffe0200 0x100>; + interrupts = <1 11 0x04>; + clocks = <&arm_periph_clk>; + }; +}; diff --git a/arch/arm/boot/dts/stixxxx-pincfg.h b/arch/arm/boot/dts/stixxxx-pincfg.h new file mode 100644 index 0000000..0dfaba0 --- /dev/null +++ b/arch/arm/boot/dts/stixxxx-pincfg.h @@ -0,0 +1,94 @@ +#ifndef _STIXXXX_PINCFG_H_ +#define _STIXXXX_PINCFG_H_ + +/* Alternate functions */ +#define ALT1 1 +#define ALT2 2 +#define ALT3 3 +#define ALT4 4 +#define ALT5 5 +#define ALT6 6 +#define ALT7 7 + +/* Output enable */ +#define OE_MASK 0x1 +#define OE_SHIFT 27 +#define OE (1 << OE_SHIFT) + +/* Pull Up */ +#define PU_MASK 0x1 +#define PU_SHIFT 26 +#define PU (1 << PU_SHIFT) + +/* Open Drain */ +#define OD_MASK 0x1 +#define OD_SHIFT 25 +#define OD (1 << OD_SHIFT) + +#define RT_MASK 0x1 +#define RT_SHIFT 23 +#define RT (1 << RT_SHIFT) + +#define INVERTCLK_MASK 0x1 +#define INVERTCLK_SHIFT 22 +#define INVERTCLK (1 << INVERTCLK_SHIFT) + +#define CLKNOTDATA_MASK 0x1 +#define CLKNOTDATA_SHIFT 21 +#define CLKNOTDATA (1 << CLKNOTDATA_SHIFT) + +#define DOUBLE_EDGE_MASK 0x1 +#define DOUBLE_EDGE_SHIFT 20 +#define DOUBLE_EDGE (1 << DOUBLE_EDGE_SHIFT) + +#define CLK_MASK 0x3 +#define CLK_SHIFT 18 +#define CLK_A (0 << CLK_SHIFT) +#define CLK_B (1 << CLK_SHIFT) +#define CLK_C (2 << CLK_SHIFT) +#define CLK_D (3 << CLK_SHIFT) + +/* User-frendly defines for Pin Direction */ + /* oe = 0, pu = 0, od = 0 */ +#define IN (0) + /* oe = 0, pu = 1, od = 0 */ +#define IN_PU (PU) + /* oe = 1, pu = 0, od = 0 */ +#define OUT (OE) + /* oe = 1, pu = 0, od = 1 */ +#define BIDIR (OE | OD) + /* oe = 1, pu = 1, od = 1 */ +#define BIDIR_PU (OE | PU | OD) + +/* RETIME_TYPE */ +/* + * B Mode + * Bypass retime with optional delay parameter + */ +#define BYPASS (0) +/* + * R0, R1, R0D, R1D modes + * single-edge data non inverted clock, retime data with clk + */ +#define SE_NICLK_IO (RT) +/* + * RIV0, RIV1, RIV0D, RIV1D modes + * single-edge data inverted clock, retime data with clk + */ +#define SE_ICLK_IO (RT | INVERTCLK) +/* + * R0E, R1E, R0ED, R1ED modes + * double-edge data, retime data with clk + */ +#define DE_IO (RT | DOUBLE_EDGE) +/* + * CIV0, CIV1 modes with inverted clock + * Retiming the clk pins will park clock & reduce the noise within the core. + */ +#define ICLK (RT | CLKNOTDATA | INVERTCLK) +/* + * CLK0, CLK1 modes with non-inverted clock + * Retiming the clk pins will park clock & reduce the noise within the core. + */ +#define NICLK (RT | CLKNOTDATA) +#endif /* _STIXXXX_PINCFG_H_ */ diff --git a/arch/arm/mach-stixxxx/Kconfig b/arch/arm/mach-stixxxx/Kconfig new file mode 100644 index 0000000..278d938 --- /dev/null +++ b/arch/arm/mach-stixxxx/Kconfig @@ -0,0 +1,45 @@ +menuconfig ARCH_STIXXXX + bool "STMicroelectronics Consumer Electronics SOCs with Device Trees" if ARCH_MULTI_V7 + select GENERIC_CLOCKEVENTS + select CLKDEV_LOOKUP + select ARM_GIC + select ARM_GLOBAL_TIMER + select MFD_STIXXXX_SYSCFG + select PINCTRL + select PINCTRL_STIXXXX + select MIGHT_HAVE_CACHE_L2X0 + select HAVE_SMP + select HAVE_ARM_SCU if SMP + select ARCH_REQUIRE_GPIOLIB + select ARM_ERRATA_720789 + select ARM_ERRATA_754322 + select PL310_ERRATA_753970 + select PL310_ERRATA_769419 + help + Include support for STiH41x SOCs like STiH415/416 using the device tree + for discovery + More information at Documentation/arm/STiH41x and + at Documentation/devicetree + + +if ARCH_STIXXXX + +config SOC_STIH415 + bool "STiH415 STMicroelectronics Consumer Electronics family" + default y + help + This enables support for STMicroelectronics Digital Consumer + Electronics family StiH415 parts, primarily targetted at set-top-box + and other digital audio/video applications using Flattned Device + Trees. + +config SOC_STIH416 + bool "STiH416 STMicroelectronics Consumer Electronics family" + default y + help + This enables support for STMicroelectronics Digital Consumer + Electronics family StiH416 parts, primarily targetted at set-top-box + and other digital audio/video applications using Flattened Device + Trees. + +endif diff --git a/arch/arm/mach-stixxxx/Makefile b/arch/arm/mach-stixxxx/Makefile new file mode 100644 index 0000000..50bf128 --- /dev/null +++ b/arch/arm/mach-stixxxx/Makefile @@ -0,0 +1,2 @@ +obj-$(CONFIG_SMP) += platsmp.o headsmp.o +obj-$(CONFIG_ARCH_STIXXXX) += board-dt.o diff --git a/arch/arm/mach-stixxxx/board-dt.c b/arch/arm/mach-stixxxx/board-dt.c new file mode 100644 index 0000000..52ce665 --- /dev/null +++ b/arch/arm/mach-stixxxx/board-dt.c @@ -0,0 +1,47 @@ +/* + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * Author(s): Srinivas Kandagatla + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ + +#include +#include +#include +#include +#include + +#include "smp.h" + +void __init stih41x_l2x0_init(void) +{ + u32 way_size = 0x4; + u32 aux_ctrl; + + aux_ctrl = (0x1 << L2X0_AUX_CTRL_SHARE_OVERRIDE_SHIFT) | + (0x1 << L2X0_AUX_CTRL_DATA_PREFETCH_SHIFT) | + (0x1 << L2X0_AUX_CTRL_INSTR_PREFETCH_SHIFT) | + (way_size << L2X0_AUX_CTRL_WAY_SIZE_SHIFT); + + l2x0_of_init(aux_ctrl, L2X0_AUX_CTRL_MASK); +} + +static void __init stih41x_timer_init(void) +{ + of_clk_init(NULL); + clocksource_of_init(); + stih41x_l2x0_init(); +} + +static const char *stih41x_dt_match[] __initdata = { + "st,stih415", + NULL +}; + +DT_MACHINE_START(STM, "STiH415 SoC with Flattened Device Tree") + .init_time = stih41x_timer_init, + .smp = smp_ops(stixxxx_smp_ops), + .dt_compat = stih41x_dt_match, +MACHINE_END diff --git a/arch/arm/mach-stixxxx/headsmp.S b/arch/arm/mach-stixxxx/headsmp.S new file mode 100644 index 0000000..3dd5c04 --- /dev/null +++ b/arch/arm/mach-stixxxx/headsmp.S @@ -0,0 +1,44 @@ +/* + * arch/arm/plat-stixxxx/headsmp.S + * + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * http://www.st.com + * + * Cloned from linux/arch/arm/mach-vexpress/headsmp.S + * + * Copyright (c) 2003 ARM Limited + * All Rights Reserved + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ +#include +#include + + __INIT + +/* + * ST specific entry point for secondary CPUs. This provides + * a "holding pen" into which all secondary cores are held until we're + * ready for them to initialise. + */ +ENTRY(stixxxx_secondary_startup) + mrc p15, 0, r0, c0, c0, 5 + and r0, r0, #15 + adr r4, 1f + ldmia r4, {r5, r6} + sub r4, r4, r5 + add r6, r6, r4 +pen: ldr r7, [r6] + cmp r7, r0 + bne pen + + /* + * we've been released from the holding pen: secondary_stack + * should now contain the SVC stack for this core + */ + b secondary_startup + +1: .long . + .long pen_release diff --git a/arch/arm/mach-stixxxx/platsmp.c b/arch/arm/mach-stixxxx/platsmp.c new file mode 100644 index 0000000..ffc40c0 --- /dev/null +++ b/arch/arm/mach-stixxxx/platsmp.c @@ -0,0 +1,117 @@ +/* + * arch/arm/plat-stixxxx/platsmp.c + * + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * http://www.st.com + * + * Cloned from linux/arch/arm/mach-vexpress/platsmp.c + * + * Copyright (C) 2002 ARM Ltd. + * All Rights Reserved + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include + +#include "smp.h" + +static void __cpuinit write_pen_release(int val) +{ + pen_release = val; + smp_wmb(); + __cpuc_flush_dcache_area((void *)&pen_release, sizeof(pen_release)); + outer_clean_range(__pa(&pen_release), __pa(&pen_release + 1)); +} + +static DEFINE_SPINLOCK(boot_lock); + +void __cpuinit stixxxx_secondary_init(unsigned int cpu) +{ + trace_hardirqs_off(); + + /* + * let the primary processor know we're out of the + * pen, then head off into the C entry point + */ + write_pen_release(-1); + + /* + * Synchronise with the boot thread. + */ + spin_lock(&boot_lock); + spin_unlock(&boot_lock); +} + +int __cpuinit stixxxx_boot_secondary(unsigned int cpu, struct task_struct *idle) +{ + unsigned long timeout; + + /* + * set synchronisation state between this boot processor + * and the secondary one + */ + spin_lock(&boot_lock); + + /* + * The secondary processor is waiting to be released from + * the holding pen - release it, then wait for it to flag + * that it has been released by resetting pen_release. + * + * Note that "pen_release" is the hardware CPU ID, whereas + * "cpu" is Linux's internal ID. + */ + write_pen_release(cpu_logical_map(cpu)); + + /* + * Send the secondary CPU a soft interrupt, thereby causing + * it to jump to the secondary entrypoint. + */ + arch_send_wakeup_ipi_mask(cpumask_of(cpu)); + + timeout = jiffies + (1 * HZ); + while (time_before(jiffies, timeout)) { + smp_rmb(); + if (pen_release == -1) + break; + + udelay(10); + } + + /* + * now the secondary core is starting up let it run its + * calibrations, then wait for it to finish + */ + spin_unlock(&boot_lock); + + return pen_release != -1 ? -ENOSYS : 0; +} + +void __init stixxxx_smp_prepare_cpus(unsigned int max_cpus) +{ + void __iomem *scu_base = NULL; + struct device_node *np = of_find_compatible_node( + NULL, NULL, "arm,cortex-a9-scu"); + if (np) { + scu_base = of_iomap(np, 0); + scu_enable(scu_base); + of_node_put(np); + } +} + +struct smp_operations __initdata stixxxx_smp_ops = { + .smp_prepare_cpus = stixxxx_smp_prepare_cpus, + .smp_secondary_init = stixxxx_secondary_init, + .smp_boot_secondary = stixxxx_boot_secondary, +}; diff --git a/arch/arm/mach-stixxxx/smp.h b/arch/arm/mach-stixxxx/smp.h new file mode 100644 index 0000000..c3e3d40 --- /dev/null +++ b/arch/arm/mach-stixxxx/smp.h @@ -0,0 +1,19 @@ +/* + * arch/arm/plat-stixxxx/platsmp.c + * + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * http://www.st.com + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ + +#ifndef __PLAT_SMP_H +#define __PLAT_SMP_H + +extern struct smp_operations stixxxx_smp_ops; +extern void __iomem *stixxxx_scu_base_addr; +extern void stixxxx_secondary_startup(void); + +#endif -- 1.7.6.5 From mboxrd@z Thu Jan 1 00:00:00 1970 From: Srinivas KANDAGATLA Subject: =?yes?q?=5BPATCH=20v2=2006/11=5D=20ARM=3Astixxxx=3A=20Add=20STiH415=20SOC=20support?= Date: Mon, 10 Jun 2013 10:26:21 +0100 Message-ID: <1370856381-6644-1-git-send-email-srinivas.kandagatla@st.com> References: <1370855828-5318-1-git-send-email-srinivas.kandagatla@st.com> Mime-Version: 1.0 Content-Type: text/plain; charset=yes Content-Transfer-Encoding: QUOTED-PRINTABLE Return-path: In-Reply-To: <1370855828-5318-1-git-send-email-srinivas.kandagatla@st.com> Sender: linux-serial-owner@vger.kernel.org To: linux-arm-kernel@lists.infradead.org Cc: Andrew Morton , Arnd Bergmann , "David S. Miller" , devicetree-discuss@lists.ozlabs.org, Grant Likely , Greg Kroah-Hartman , John Stultz , Linus Walleij , linux@arm.linux.org.uk, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-serial@vger.kernel.org, Mark Brown , Mauro Carvalho Chehab , Olof Johansson , Rob Herring , Rob Landley , Samuel Ortiz , Srinivas Kandagatla , Stephen Gallimore , Stuart Menefy , Thomas Gleixner , Tony Prisk List-Id: devicetree@vger.kernel.org The STiH415 is the next generation of HD, AVC set-top box processors fo= r satellite, cable, terrestrial and IP-STB markets. It is an ARM Cortex-A= 9 1.0 GHz, dual-core CPU. Signed-off-by: Srinivas Kandagatla CC: Stephen Gallimore CC: Stuart Menefy CC: Arnd Bergmann CC: Linus Walleij --- Documentation/arm/stixxxx/overview.txt | 33 +++ Documentation/arm/stixxxx/stih415-overview.txt | 12 + MAINTAINERS | 11 + arch/arm/Kconfig | 2 + arch/arm/Makefile | 1 + arch/arm/boot/dts/stih415-clock.dtsi | 38 +++ arch/arm/boot/dts/stih415-pinctrl.dtsi | 326 ++++++++++++++++= ++++++++ arch/arm/boot/dts/stih415.dtsi | 102 ++++++++ arch/arm/boot/dts/stih41x.dtsi | 38 +++ arch/arm/boot/dts/stixxxx-pincfg.h | 94 +++++++ arch/arm/mach-stixxxx/Kconfig | 45 ++++ arch/arm/mach-stixxxx/Makefile | 2 + arch/arm/mach-stixxxx/board-dt.c | 47 ++++ arch/arm/mach-stixxxx/headsmp.S | 44 ++++ arch/arm/mach-stixxxx/platsmp.c | 117 +++++++++ arch/arm/mach-stixxxx/smp.h | 19 ++ 16 files changed, 931 insertions(+), 0 deletions(-) create mode 100644 Documentation/arm/stixxxx/overview.txt create mode 100644 Documentation/arm/stixxxx/stih415-overview.txt create mode 100644 arch/arm/boot/dts/stih415-clock.dtsi create mode 100644 arch/arm/boot/dts/stih415-pinctrl.dtsi create mode 100644 arch/arm/boot/dts/stih415.dtsi create mode 100644 arch/arm/boot/dts/stih41x.dtsi create mode 100644 arch/arm/boot/dts/stixxxx-pincfg.h create mode 100644 arch/arm/mach-stixxxx/Kconfig create mode 100644 arch/arm/mach-stixxxx/Makefile create mode 100644 arch/arm/mach-stixxxx/board-dt.c create mode 100644 arch/arm/mach-stixxxx/headsmp.S create mode 100644 arch/arm/mach-stixxxx/platsmp.c create mode 100644 arch/arm/mach-stixxxx/smp.h diff --git a/Documentation/arm/stixxxx/overview.txt b/Documentation/arm= /stixxxx/overview.txt new file mode 100644 index 0000000..a2f6390 --- /dev/null +++ b/Documentation/arm/stixxxx/overview.txt @@ -0,0 +1,33 @@ + STixxxx ARM Linux Overview + =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D + +Introduction +------------ + + The ST Microelectronics Multimedia and Application Processors range = of + CortexA9 System-on-Chip are supported by the 'STixxxx' platform of + ARM Linux. Currently STiH415, STiH416 SOCs are supported with both + B2000 and B2020 Reference boards. + + + configuration + ------------- + + A generic configuration is provided for both STiH415/416, and can be= used as the + default by + make stih41x_defconfig + + Layout + ------ + All the files for multiple machine families (STiH415, STiH416, and S= TiG125) + are located in the platform code contained in arch/arm/mach-stixxxx + + There is a generic board board-dt.c in the mach folder which support + Flattened Device Tree, which means, It works with any compatible boa= rd with + Device Trees. + + + Document Author + --------------- + + Srinivas Kandagatla , (c) 2013 ST Microe= lectronics diff --git a/Documentation/arm/stixxxx/stih415-overview.txt b/Documenta= tion/arm/stixxxx/stih415-overview.txt new file mode 100644 index 0000000..1c264b7 --- /dev/null +++ b/Documentation/arm/stixxxx/stih415-overview.txt @@ -0,0 +1,12 @@ + STiH415 Overview + =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D + +Introduction +------------ + + The STiH415 is the next generation of HD, AVC set-top box processo= rs + for satellite, cable, terrestrial and IP-STB markets. + + Features + - ARM Cortex-A9 1.0 GHz, dual-core CPU + - SATA2=C3=972,USB 2.0=C3=973, PCIe, Gbit Ethernet MAC=C3=972 diff --git a/MAINTAINERS b/MAINTAINERS index 250dc97..2aca7d2 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -1201,6 +1201,17 @@ M: Dinh Nguyen S: Maintained F: drivers/clk/socfpga/ =20 +ARM/STIXXXX ARCHITECTURE +M: Srinivas Kandagatla +M: Stuart Menefy +L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers= ) +W: http://www.stlinux.com +S: Maintained +F: arch/arm/mach-stixxxx/ +F: drivers/pinctrl/pinctrl-stixxxx* +F: drivers/mfd/stixxxx-syscfg* +F: drivers/clocksource/global_timer.c + ARM/TECHNOLOGIC SYSTEMS TS7250 MACHINE SUPPORT M: Lennert Buytenhek L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers= ) diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 49d993c..790e321 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig @@ -989,6 +989,8 @@ source "arch/arm/mach-socfpga/Kconfig" =20 source "arch/arm/mach-spear/Kconfig" =20 +source "arch/arm/mach-stixxxx/Kconfig" + source "arch/arm/mach-s3c24xx/Kconfig" =20 if ARCH_S3C64XX diff --git a/arch/arm/Makefile b/arch/arm/Makefile index 1ba358b..c876e0a 100644 --- a/arch/arm/Makefile +++ b/arch/arm/Makefile @@ -191,6 +191,7 @@ machine-$(CONFIG_ARCH_W90X900) +=3D w90x900 machine-$(CONFIG_FOOTBRIDGE) +=3D footbridge machine-$(CONFIG_ARCH_SOCFPGA) +=3D socfpga machine-$(CONFIG_PLAT_SPEAR) +=3D spear +machine-$(CONFIG_ARCH_STIXXXX) +=3D stixxxx machine-$(CONFIG_ARCH_VIRT) +=3D virt machine-$(CONFIG_ARCH_ZYNQ) +=3D zynq machine-$(CONFIG_ARCH_SUNXI) +=3D sunxi diff --git a/arch/arm/boot/dts/stih415-clock.dtsi b/arch/arm/boot/dts/s= tih415-clock.dtsi new file mode 100644 index 0000000..174c799 --- /dev/null +++ b/arch/arm/boot/dts/stih415-clock.dtsi @@ -0,0 +1,38 @@ +/* + * Copyright (C) 2013 STMicroelectronics (R&D) Limited + * + * This program is free software; you can redistribute it and/or modif= y + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ +/ { + clocks { + /* + * Fixed 30MHz oscillator input to SoC + */ + CLK_SYSIN: CLK_SYSIN { + #clock-cells =3D <0>; + compatible =3D "fixed-clock"; + clock-frequency =3D <30000000>; + }; + + /* + * ARM Peripheral clock for timers + */ + arm_periph_clk: arm_periph_clk { + #clock-cells =3D <0>; + compatible =3D "fixed-clock"; + clock-frequency =3D <500000000>; + }; + + /* + * Bootloader initialized system infrastructure clock for + * serial devices. + */ + CLKS_ICN_REG_0: CLKS_ICN_REG_0 { + #clock-cells =3D <0>; + compatible =3D "fixed-clock"; + clock-frequency =3D <100000000>; + }; + }; +}; diff --git a/arch/arm/boot/dts/stih415-pinctrl.dtsi b/arch/arm/boot/dts= /stih415-pinctrl.dtsi new file mode 100644 index 0000000..c510f11 --- /dev/null +++ b/arch/arm/boot/dts/stih415-pinctrl.dtsi @@ -0,0 +1,326 @@ +/* + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * Author: Srinivas Kandagatla + * + * This program is free software; you can redistribute it and/or modif= y + * it under the terms of the GNU General Public License version 2 as + * publishhed by the Free Software Foundation. + */ +#include "stixxxx-pincfg.h" +/ { + + aliases { + gpio0 =3D &PIO0; + gpio1 =3D &PIO1; + gpio2 =3D &PIO2; + gpio3 =3D &PIO3; + gpio4 =3D &PIO4; + gpio5 =3D &PIO5; + gpio6 =3D &PIO6; + gpio7 =3D &PIO7; + gpio8 =3D &PIO8; + gpio9 =3D &PIO9; + gpio10 =3D &PIO10; + gpio11 =3D &PIO11; + gpio12 =3D &PIO12; + gpio13 =3D &PIO13; + gpio14 =3D &PIO14; + gpio15 =3D &PIO15; + gpio16 =3D &PIO16; + gpio17 =3D &PIO17; + gpio18 =3D &PIO18; + gpio19 =3D &PIO100; + gpio20 =3D &PIO101; + gpio21 =3D &PIO102; + gpio22 =3D &PIO103; + gpio23 =3D &PIO104; + gpio24 =3D &PIO105; + gpio25 =3D &PIO106; + gpio26 =3D &PIO107; + }; + + + soc { + pin-controller-sbc { + #address-cells =3D <1>; + #size-cells =3D <1>; + compatible =3D "st,stih415-pinctrl", "simple-bus"; + st,retime-in-delay =3D <0 500 1000 1500>; + st,retime-out-delay =3D <0 1000 2000 3000>; + st,syscfg =3D <&syscfg_sbc>; + st,syscfg-offsets =3D <0 5 7 9 16>; + ranges; + + PIO0: pinctrl@fe610000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe610000 0x100>; + st,bank-name =3D "PIO0"; + }; + + PIO1: pinctrl@fe611000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe611000 0x100>; + st,bank-name =3D "PIO1"; + }; + + PIO2: pinctrl@fe612000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe612000 0x100>; + st,bank-name =3D "PIO2"; + }; + + PIO3: pinctrl@fe613000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe613000 0x100>; + st,bank-name =3D "PIO3"; + + }; + + PIO4: pinctrl@fe614000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe614000 0x100>; + st,bank-name =3D "PIO4"; + }; + + sbc_serial1 { + pinctrl_sbc_serial1:sbc_serial1 { + st,function =3D ; + st,pins { + tx =3D <&PIO2 6 OUT>; + rx =3D <&PIO2 7 IN>; + }; + }; + }; + }; + + pin-controller-front { + #address-cells =3D <1>; + #size-cells =3D <1>; + compatible =3D "st,stih415-pinctrl", "simple-bus"; + st,retime-in-delay =3D <0 500 1000 1500>; + st,retime-out-delay =3D <0 1000 2000 3000>; + st,syscfg =3D <&syscfg_front>; + st,syscfg-offsets =3D <0 8 10 12 16>; + ranges; + + PIO5: pinctrl@fee00000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfee00000 0x100>; + st,bank-name =3D "PIO5"; + }; + PIO6: pinctrl@fee01000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfee01000 0x100>; + st,bank-name =3D "PIO6"; + }; + + PIO7: pinctrl@fee02000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfee02000 0x100>; + st,bank-name =3D "PIO7"; + }; + PIO8: pinctrl@fee03000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfee03000 0x100>; + st,bank-name =3D "PIO8"; + }; + PIO9: pinctrl@fee04000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfee04000 0x100>; + st,bank-name =3D "PIO9"; + }; + PIO10: pinctrl@fee05000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfee05000 0x100>; + st,bank-name =3D "PIO10"; + }; + PIO11: pinctrl@fee06000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfee06000 0x100>; + st,bank-name =3D "PIO11"; + }; + PIO12: pinctrl@fee07000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfee07000 0x100>; + st,bank-name =3D "PIO12"; + }; + }; + + pin-controller-rear { + #address-cells =3D <1>; + #size-cells =3D <1>; + compatible =3D "st,stih415-pinctrl", "simple-bus"; + st,retime-in-delay =3D <0 500 1000 1500>; + st,retime-out-delay =3D <0 1000 2000 3000>; + st,syscfg =3D <&syscfg_rear>; + st,syscfg-offsets =3D <0 6 8 10 38>; + ranges; + + PIO13: pinctrl@fe820000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe820000 0x100>; + st,bank-name =3D "PIO13"; + }; + PIO14: pinctrl@fe821000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe821000 0x100>; + st,bank-name =3D "PIO14"; + }; + PIO15: pinctrl@fe822000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe822000 0x100>; + st,bank-name =3D "PIO15"; + }; + PIO16: pinctrl@fe823000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe823000 0x100>; + st,bank-name =3D "PIO16"; + + }; + PIO17: pinctrl@fe824000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe824000 0x100>; + st,bank-name =3D "PIO17"; + + }; + PIO18: pinctrl@fe825000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfe825000 0x100>; + st,bank-name =3D "PIO18"; + + }; + + serial2 { + pinctrl_serial2: serial2-0 { + st,function =3D ; + st,pins { + tx =3D <&PIO17 4 OUT>; + rx =3D <&PIO17 5 IN>; + }; + }; + }; + + }; + + pin-controller-left { + #address-cells =3D <1>; + #size-cells =3D <1>; + compatible =3D "st,stih415-pinctrl", "simple-bus"; + st,retime-in-delay =3D <0 500 1000 1500>; + st,retime-out-delay =3D <0 1000 2000 3000>; + st,syscfg =3D <&syscfg_left>; + st,syscfg-offsets =3D <0 3 4 5 6>; + ranges; + + PIO100: pinctrl@fd6b0000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfd6b0000 0x100>; + st,bank-name =3D "PIO100"; + }; + PIO101: pinctrl@fd6b1000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfd6b1000 0x100>; + st,bank-name =3D "PIO101"; + + }; + PIO102: pinctrl@fd6b2000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfd6b2000 0x100>; + st,bank-name =3D "PIO102"; + + }; + + }; + + pin-controller-right { + #address-cells =3D <1>; + #size-cells =3D <1>; + compatible =3D "st,stih415-pinctrl", "simple-bus"; + st,retime-in-delay =3D <0 500 1000 1500>; + st,retime-out-delay =3D <0 1000 2000 3000>; + st,syscfg =3D <&syscfg_right>; + st,syscfg-offsets =3D <0 5 7 9 11>; + ranges; + + PIO103: pinctrl@fd330000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfd330000 0x100>; + st,bank-name =3D "PIO103"; + }; + PIO104: pinctrl@fd331000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfd331000 0x100>; + st,bank-name =3D "PIO104"; + }; + PIO105: pinctrl@fd332000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfd332000 0x100>; + st,bank-name =3D "PIO105"; + }; + PIO106: pinctrl@fd333000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfd333000 0x100>; + st,bank-name =3D "PIO106"; + }; + PIO107: pinctrl@fd334000 { + gpio-controller; + #gpio-cells =3D <1>; + compatible =3D "st,stixxxx-gpio"; + reg =3D <0xfd334000 0x100>; + st,bank-name =3D "PIO107"; + }; + }; + }; +}; diff --git a/arch/arm/boot/dts/stih415.dtsi b/arch/arm/boot/dts/stih415= =2Edtsi new file mode 100644 index 0000000..6dcf5b4 --- /dev/null +++ b/arch/arm/boot/dts/stih415.dtsi @@ -0,0 +1,102 @@ +/* + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * Author: Srinivas Kandagatla + * + * This program is free software; you can redistribute it and/or modif= y + * it under the terms of the GNU General Public License version 2 as + * publishhed by the Free Software Foundation. + */ +#include "stih41x.dtsi" +#include "stih415-clock.dtsi" +#include "stih415-pinctrl.dtsi" +/ { + + L2: cache-controller { + compatible =3D "arm,pl310-cache"; + reg =3D <0xfffe2000 0x1000>; + arm,data-latency =3D <3 2 2>; + arm,tag-latency =3D <1 1 1>; + cache-unified; + cache-level =3D <2>; + }; + + soc { + #address-cells =3D <1>; + #size-cells =3D <1>; + interrupt-parent =3D <&intc>; + ranges; + compatible =3D "simple-bus"; + + syscfg_sbc: syscfg@fe600000{ + compatible =3D "st,stih415-syscfg"; + reg =3D <0xfe600000 0xb4>; + syscfg-range =3D <0 44>; + syscfg-name =3D "SYSCFG_SBC"; + }; + + syscfg_front: syscfg@fee10000{ + compatible =3D "st,stih415-syscfg"; + reg =3D <0xfee10000 0x194>; + syscfg-range =3D <100 100>; + syscfg-name =3D "SYSCFG_FRONT"; + }; + + syscfg_rear: syscfg@fe830000{ + compatible =3D "st,stih415-syscfg"; + reg =3D <0xfe830000 0x190>; + syscfg-range =3D <300 99>; + syscfg-name =3D "SYSCFG_REAR"; + }; + + /* MPE syscfgs */ + syscfg_left: syscfg@fd690000{ + compatible =3D "st,stih415-syscfg"; + reg =3D <0xfd690000 0x78>; + syscfg-range =3D <400 29>; + syscfg-name =3D "SYSCFG_LEFT"; + }; + + syscfg_right: syscfg@fd320000{ + compatible =3D "st,stih415-syscfg"; + reg =3D <0xfd320000 0x180>; + syscfg-range =3D <500 95>; + syscfg-name =3D "SYSCFG_RIGHT"; + }; + + syscfg_system: syscfg@fdde0000 { + compatible =3D "st,stih415-syscfg"; + reg =3D <0xfdde0000 0x15c>; + syscfg-range =3D <600 86>; + syscfg-name =3D "SYSCFG_SYSTEM"; + }; + + syscfg_lpm: syscfg@fe4b5100{ + compatible =3D "st,stih415-syscfg"; + reg =3D <0xfe4b5100 0x08>; + syscfg-range =3D <0 10>; + syscfg-name =3D "LPM_CFG_REGS"; + }; + + serial2: serial@fed32000 { + compatible =3D "st,asc"; + status =3D "disabled"; + reg =3D <0xfed32000 0x2c>; + interrupts =3D <0 197 0>; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pinctrl_serial2>; + clocks =3D <&CLKS_ICN_REG_0>; + }; + + /* SBC comms block ASCs in SASG1 */ + sbc_serial1: serial@fe531000 { + compatible =3D "st,asc"; + status =3D "disabled"; + reg =3D <0xfe531000 0x2c>; + interrupts =3D <0 210 0>; + clocks =3D <&CLK_SYSIN>; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pinctrl_sbc_serial1>; + }; + + }; +}; diff --git a/arch/arm/boot/dts/stih41x.dtsi b/arch/arm/boot/dts/stih41x= =2Edtsi new file mode 100644 index 0000000..7321403 --- /dev/null +++ b/arch/arm/boot/dts/stih41x.dtsi @@ -0,0 +1,38 @@ +/ { + #address-cells =3D <1>; + #size-cells =3D <1>; + + cpus { + #address-cells =3D <1>; + #size-cells =3D <0>; + cpu@0 { + compatible =3D "arm,cortex-a9"; + reg =3D <0>; + }; + cpu@1 { + compatible =3D "arm,cortex-a9"; + reg =3D <1>; + }; + }; + + intc: interrupt-controller@fffe1000 { + compatible =3D "arm,cortex-a9-gic"; + #interrupt-cells =3D <3>; + interrupt-controller; + reg =3D <0xfffe1000 0x1000>, + <0xfffe0100 0x100>; + }; + + scu@fffe0000 { + compatible =3D "arm,cortex-a9-scu"; + reg =3D <0xfffe0000 0x1000>; + }; + + timer@fffe0200 { + interrupt-parent =3D <&intc>; + compatible =3D "arm,cortex-a9-global-timer"; + reg =3D <0xfffe0200 0x100>; + interrupts =3D <1 11 0x04>; + clocks =3D <&arm_periph_clk>; + }; +}; diff --git a/arch/arm/boot/dts/stixxxx-pincfg.h b/arch/arm/boot/dts/sti= xxxx-pincfg.h new file mode 100644 index 0000000..0dfaba0 --- /dev/null +++ b/arch/arm/boot/dts/stixxxx-pincfg.h @@ -0,0 +1,94 @@ +#ifndef _STIXXXX_PINCFG_H_ +#define _STIXXXX_PINCFG_H_ + +/* Alternate functions */ +#define ALT1 1 +#define ALT2 2 +#define ALT3 3 +#define ALT4 4 +#define ALT5 5 +#define ALT6 6 +#define ALT7 7 + +/* Output enable */ +#define OE_MASK 0x1 +#define OE_SHIFT 27 +#define OE (1 << OE_SHIFT) + +/* Pull Up */ +#define PU_MASK 0x1 +#define PU_SHIFT 26 +#define PU (1 << PU_SHIFT) + +/* Open Drain */ +#define OD_MASK 0x1 +#define OD_SHIFT 25 +#define OD (1 << OD_SHIFT) + +#define RT_MASK 0x1 +#define RT_SHIFT 23 +#define RT (1 << RT_SHIFT) + +#define INVERTCLK_MASK 0x1 +#define INVERTCLK_SHIFT 22 +#define INVERTCLK (1 << INVERTCLK_SHIFT) + +#define CLKNOTDATA_MASK 0x1 +#define CLKNOTDATA_SHIFT 21 +#define CLKNOTDATA (1 << CLKNOTDATA_SHIFT) + +#define DOUBLE_EDGE_MASK 0x1 +#define DOUBLE_EDGE_SHIFT 20 +#define DOUBLE_EDGE (1 << DOUBLE_EDGE_SHIFT) + +#define CLK_MASK 0x3 +#define CLK_SHIFT 18 +#define CLK_A (0 << CLK_SHIFT) +#define CLK_B (1 << CLK_SHIFT) +#define CLK_C (2 << CLK_SHIFT) +#define CLK_D (3 << CLK_SHIFT) + +/* User-frendly defines for Pin Direction */ + /* oe =3D 0, pu =3D 0, od =3D 0 */ +#define IN (0) + /* oe =3D 0, pu =3D 1, od =3D 0 */ +#define IN_PU (PU) + /* oe =3D 1, pu =3D 0, od =3D 0 */ +#define OUT (OE) + /* oe =3D 1, pu =3D 0, od =3D 1 */ +#define BIDIR (OE | OD) + /* oe =3D 1, pu =3D 1, od =3D 1 */ +#define BIDIR_PU (OE | PU | OD) + +/* RETIME_TYPE */ +/* + * B Mode + * Bypass retime with optional delay parameter + */ +#define BYPASS (0) +/* + * R0, R1, R0D, R1D modes + * single-edge data non inverted clock, retime data with clk + */ +#define SE_NICLK_IO (RT) +/* + * RIV0, RIV1, RIV0D, RIV1D modes + * single-edge data inverted clock, retime data with clk + */ +#define SE_ICLK_IO (RT | INVERTCLK) +/* + * R0E, R1E, R0ED, R1ED modes + * double-edge data, retime data with clk + */ +#define DE_IO (RT | DOUBLE_EDGE) +/* + * CIV0, CIV1 modes with inverted clock + * Retiming the clk pins will park clock & reduce the noise within the= core. + */ +#define ICLK (RT | CLKNOTDATA | INVERTCLK) +/* + * CLK0, CLK1 modes with non-inverted clock + * Retiming the clk pins will park clock & reduce the noise within the= core. + */ +#define NICLK (RT | CLKNOTDATA) +#endif /* _STIXXXX_PINCFG_H_ */ diff --git a/arch/arm/mach-stixxxx/Kconfig b/arch/arm/mach-stixxxx/Kcon= fig new file mode 100644 index 0000000..278d938 --- /dev/null +++ b/arch/arm/mach-stixxxx/Kconfig @@ -0,0 +1,45 @@ +menuconfig ARCH_STIXXXX + bool "STMicroelectronics Consumer Electronics SOCs with Device Trees"= if ARCH_MULTI_V7 + select GENERIC_CLOCKEVENTS + select CLKDEV_LOOKUP + select ARM_GIC + select ARM_GLOBAL_TIMER + select MFD_STIXXXX_SYSCFG + select PINCTRL + select PINCTRL_STIXXXX + select MIGHT_HAVE_CACHE_L2X0 + select HAVE_SMP + select HAVE_ARM_SCU if SMP + select ARCH_REQUIRE_GPIOLIB + select ARM_ERRATA_720789 + select ARM_ERRATA_754322 + select PL310_ERRATA_753970 + select PL310_ERRATA_769419 + help + Include support for STiH41x SOCs like STiH415/416 using the device = tree + for discovery + More information at Documentation/arm/STiH41x and + at Documentation/devicetree + + +if ARCH_STIXXXX + +config SOC_STIH415 + bool "STiH415 STMicroelectronics Consumer Electronics family" + default y + help + This enables support for STMicroelectronics Digital Consumer + Electronics family StiH415 parts, primarily targetted at set-top-bo= x + and other digital audio/video applications using Flattned Device + Trees. + +config SOC_STIH416 + bool "STiH416 STMicroelectronics Consumer Electronics family" + default y + help + This enables support for STMicroelectronics Digital Consumer + Electronics family StiH416 parts, primarily targetted at set-top-bo= x + and other digital audio/video applications using Flattened Device + Trees. + +endif diff --git a/arch/arm/mach-stixxxx/Makefile b/arch/arm/mach-stixxxx/Mak= efile new file mode 100644 index 0000000..50bf128 --- /dev/null +++ b/arch/arm/mach-stixxxx/Makefile @@ -0,0 +1,2 @@ +obj-$(CONFIG_SMP) +=3D platsmp.o headsmp.o +obj-$(CONFIG_ARCH_STIXXXX) +=3D board-dt.o diff --git a/arch/arm/mach-stixxxx/board-dt.c b/arch/arm/mach-stixxxx/b= oard-dt.c new file mode 100644 index 0000000..52ce665 --- /dev/null +++ b/arch/arm/mach-stixxxx/board-dt.c @@ -0,0 +1,47 @@ +/* + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * Author(s): Srinivas Kandagatla + * + * This program is free software; you can redistribute it and/or modif= y + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ + +#include +#include +#include +#include +#include + +#include "smp.h" + +void __init stih41x_l2x0_init(void) +{ + u32 way_size =3D 0x4; + u32 aux_ctrl; + + aux_ctrl =3D (0x1 << L2X0_AUX_CTRL_SHARE_OVERRIDE_SHIFT) | + (0x1 << L2X0_AUX_CTRL_DATA_PREFETCH_SHIFT) | + (0x1 << L2X0_AUX_CTRL_INSTR_PREFETCH_SHIFT) | + (way_size << L2X0_AUX_CTRL_WAY_SIZE_SHIFT); + + l2x0_of_init(aux_ctrl, L2X0_AUX_CTRL_MASK); +} + +static void __init stih41x_timer_init(void) +{ + of_clk_init(NULL); + clocksource_of_init(); + stih41x_l2x0_init(); +} + +static const char *stih41x_dt_match[] __initdata =3D { + "st,stih415", + NULL +}; + +DT_MACHINE_START(STM, "STiH415 SoC with Flattened Device Tree") + .init_time =3D stih41x_timer_init, + .smp =3D smp_ops(stixxxx_smp_ops), + .dt_compat =3D stih41x_dt_match, +MACHINE_END diff --git a/arch/arm/mach-stixxxx/headsmp.S b/arch/arm/mach-stixxxx/he= adsmp.S new file mode 100644 index 0000000..3dd5c04 --- /dev/null +++ b/arch/arm/mach-stixxxx/headsmp.S @@ -0,0 +1,44 @@ +/* + * arch/arm/plat-stixxxx/headsmp.S + * + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * http://www.st.com + * + * Cloned from linux/arch/arm/mach-vexpress/headsmp.S + * + * Copyright (c) 2003 ARM Limited + * All Rights Reserved + * + * This program is free software; you can redistribute it and/or modif= y + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ +#include +#include + + __INIT + +/* + * ST specific entry point for secondary CPUs. This provides + * a "holding pen" into which all secondary cores are held until we're + * ready for them to initialise. + */ +ENTRY(stixxxx_secondary_startup) + mrc p15, 0, r0, c0, c0, 5 + and r0, r0, #15 + adr r4, 1f + ldmia r4, {r5, r6} + sub r4, r4, r5 + add r6, r6, r4 +pen: ldr r7, [r6] + cmp r7, r0 + bne pen + + /* + * we've been released from the holding pen: secondary_stack + * should now contain the SVC stack for this core + */ + b secondary_startup + +1: .long . + .long pen_release diff --git a/arch/arm/mach-stixxxx/platsmp.c b/arch/arm/mach-stixxxx/pl= atsmp.c new file mode 100644 index 0000000..ffc40c0 --- /dev/null +++ b/arch/arm/mach-stixxxx/platsmp.c @@ -0,0 +1,117 @@ +/* + * arch/arm/plat-stixxxx/platsmp.c + * + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * http://www.st.com + * + * Cloned from linux/arch/arm/mach-vexpress/platsmp.c + * + * Copyright (C) 2002 ARM Ltd. + * All Rights Reserved + * + * This program is free software; you can redistribute it and/or modif= y + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include + +#include "smp.h" + +static void __cpuinit write_pen_release(int val) +{ + pen_release =3D val; + smp_wmb(); + __cpuc_flush_dcache_area((void *)&pen_release, sizeof(pen_release)); + outer_clean_range(__pa(&pen_release), __pa(&pen_release + 1)); +} + +static DEFINE_SPINLOCK(boot_lock); + +void __cpuinit stixxxx_secondary_init(unsigned int cpu) +{ + trace_hardirqs_off(); + + /* + * let the primary processor know we're out of the + * pen, then head off into the C entry point + */ + write_pen_release(-1); + + /* + * Synchronise with the boot thread. + */ + spin_lock(&boot_lock); + spin_unlock(&boot_lock); +} + +int __cpuinit stixxxx_boot_secondary(unsigned int cpu, struct task_str= uct *idle) +{ + unsigned long timeout; + + /* + * set synchronisation state between this boot processor + * and the secondary one + */ + spin_lock(&boot_lock); + + /* + * The secondary processor is waiting to be released from + * the holding pen - release it, then wait for it to flag + * that it has been released by resetting pen_release. + * + * Note that "pen_release" is the hardware CPU ID, whereas + * "cpu" is Linux's internal ID. + */ + write_pen_release(cpu_logical_map(cpu)); + + /* + * Send the secondary CPU a soft interrupt, thereby causing + * it to jump to the secondary entrypoint. + */ + arch_send_wakeup_ipi_mask(cpumask_of(cpu)); + + timeout =3D jiffies + (1 * HZ); + while (time_before(jiffies, timeout)) { + smp_rmb(); + if (pen_release =3D=3D -1) + break; + + udelay(10); + } + + /* + * now the secondary core is starting up let it run its + * calibrations, then wait for it to finish + */ + spin_unlock(&boot_lock); + + return pen_release !=3D -1 ? -ENOSYS : 0; +} + +void __init stixxxx_smp_prepare_cpus(unsigned int max_cpus) +{ + void __iomem *scu_base =3D NULL; + struct device_node *np =3D of_find_compatible_node( + NULL, NULL, "arm,cortex-a9-scu"); + if (np) { + scu_base =3D of_iomap(np, 0); + scu_enable(scu_base); + of_node_put(np); + } +} + +struct smp_operations __initdata stixxxx_smp_ops =3D { + .smp_prepare_cpus =3D stixxxx_smp_prepare_cpus, + .smp_secondary_init =3D stixxxx_secondary_init, + .smp_boot_secondary =3D stixxxx_boot_secondary, +}; diff --git a/arch/arm/mach-stixxxx/smp.h b/arch/arm/mach-stixxxx/smp.h new file mode 100644 index 0000000..c3e3d40 --- /dev/null +++ b/arch/arm/mach-stixxxx/smp.h @@ -0,0 +1,19 @@ +/* + * arch/arm/plat-stixxxx/platsmp.c + * + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * http://www.st.com + * + * This program is free software; you can redistribute it and/or modif= y + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ + +#ifndef __PLAT_SMP_H +#define __PLAT_SMP_H + +extern struct smp_operations stixxxx_smp_ops; +extern void __iomem *stixxxx_scu_base_addr; +extern void stixxxx_secondary_startup(void); + +#endif --=20 1.7.6.5 -- To unsubscribe from this list: send the line "unsubscribe linux-serial"= in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html