ARM: SoC board updates for 3.14
This branch is reducing in size for every release since most board-related changes have started happening in devicetrees now. Still, we have some things going on here. * Renesas platforms are still adding a bit more legacy device support, something that should trail off shortly as they move to full DT. * We group most defconfig updates into this branch out of old habits * Removal of legacy OMAP2 platforms over to DT continues, and a handful of old code is being removed here. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.11 (GNU/Linux) iQIcBAABAgAGBQJS4VhpAAoJEIwa5zzehBx3dgMP/2qc+pY4Sx13x5gWMyj29kQd LF6JeGLbj3+F+brPh8nXg6feOcsqVN9lpQ7v4+u1tLv6XfYe5kzBTDwF9MFbZi4I lV9o4cehcZWjCEx+JIbg1MvuNUCU2k1H7HmDIiOQIuoL9j58f2ZywlH/HmLuo2iZ j5Aly006x0s1lUIDhw2w9PJZzzSRBfPr8hW8q+JdLZinlA5Nd4jSxDX0QoSZE+2t 2GJMb//Ej1KbLO7fcM6BImNtB0kz4xRkPvINJwh1xGHYKY0BzMCYS3K2zBgoeyut /olOK2xpnSjzcp1ToVQSAa7Mr1zbiyxQTKkqRHMnKyD/BTMzgoSVHxCA7yGYsCjz mc6AW4v1ucfvXrz0qPXd9fHCIYMyvn6PPv3DmRFU/tR3zJaakI2RvYZFaeyK3RIn 0NGwMQBe3gGIHFAK5Q9hrPyZtbtGicKHjd6eNrNIVeSyTi1njbviTFRHA5yMqWBL eHRM5KxCnp7+6ES61J0YCSF121/V3GT1rJyJnABl3B2UYj/qKXUBAJ2aPqCspWOG pcbI7fdeyV67YJvgrV5s8eO7HtPJs9KtOw7Fng4P4Kgjy2XLNfVhQRkaAwe4P914 HCtZfKCVe4xOWLFHDWApaRpfeOFXZgd0hLOG5jiAEhBRZbRALS044Ta9mAFKqQxx v0mqo85bCHixiFWz1UVc =wLdE -----END PGP SIGNATURE----- Merge tag 'boards-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc Pull ARM SoC board updates from Olof Johansson: "This branch is reducing in size for every release since most board-related changes have started happening in devicetrees now. Still, we have some things going on here. * Renesas platforms are still adding a bit more legacy device support, something that should trail off shortly as they move to full DT * We group most defconfig updates into this branch out of old habits * Removal of legacy OMAP2 platforms over to DT continues, and a handful of old code is being removed here" * tag 'boards-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc: (94 commits) ARM: dts: OMAP2: fix interrupt number for rng ARM: dts: Split omap3 pinmux core device ARM: dts: Add omap specific pinctrl defines to use padconf addresses ARM: bcm2835: bcm2835_defconfig updates ARM: msm_defconfig: Enable restart driver defconfig: msm_defconfig: Enable CONFIG_ARCH_MSM8974 ARM: msm: Add support for APQ8074 Dragonboard ARM: exynos_defconfig: Enable S2MPS11 voltage regulator ARM: tegra: Enable DRM panel support ARM: shmobile: mackerel: Fix USBHS pinconf entry ARM: shmobile: Let Koelsch multiplatform boot with Koelsch DTB ARM: shmobile: Let Lager multiplatform boot with Lager DTB ARM: shmobile: Remove non-multiplatform Koelsch reference support ARM: shmobile: Remove non-multiplatform Lager reference support ARM: shmobile: koelsch-reference: Instantiate clkdevs for SCIF and CMT ARM: shmobile: lager-reference: Instantiate clkdevs for SCIF and CMT ARM: shmobile: koelsch-reference: Remove duplicate CCF initialization ARM: shmobile: lager-reference: Enable multiplaform kernel support ARM: shmobile: armadillo: Set backlight enable GPIO ARM: shmobile: Koelsch: add Ether support ... Conflicts: arch/arm/mach-omap2/omap_hwmod_2xxx_ipblock_data.c
This commit is contained in:
commit
903a9f77d1
|
@ -669,7 +669,7 @@ config ARCH_MSM_NODT
|
|||
(clock and power control, etc).
|
||||
|
||||
config ARCH_SHMOBILE_LEGACY
|
||||
bool "Renesas SH-Mobile / R-Mobile (non-multiplatform)"
|
||||
bool "Renesas ARM SoCs (non-multiplatform)"
|
||||
select ARCH_SHMOBILE
|
||||
select ARM_PATCH_PHYS_VIRT
|
||||
select CLKDEV_LOOKUP
|
||||
|
@ -685,8 +685,9 @@ config ARCH_SHMOBILE_LEGACY
|
|||
select PM_GENERIC_DOMAINS if PM
|
||||
select SPARSE_IRQ
|
||||
help
|
||||
Support for Renesas's SH-Mobile and R-Mobile ARM platforms using
|
||||
a non-multiplatform kernel.
|
||||
Support for Renesas ARM SoC platforms using a non-multiplatform
|
||||
kernel. This includes the SH-Mobile, R-Mobile, EMMA-Mobile, R-Car
|
||||
and RZ families.
|
||||
|
||||
config ARCH_RPC
|
||||
bool "RiscPC"
|
||||
|
|
|
@ -119,7 +119,8 @@ dtb-$(CONFIG_ARCH_KIRKWOOD) += kirkwood-cloudbox.dtb \
|
|||
dtb-$(CONFIG_ARCH_MARCO) += marco-evb.dtb
|
||||
dtb-$(CONFIG_ARCH_MOXART) += moxart-uc7112lx.dtb
|
||||
dtb-$(CONFIG_ARCH_MSM) += qcom-msm8660-surf.dtb \
|
||||
qcom-msm8960-cdp.dtb
|
||||
qcom-msm8960-cdp.dtb \
|
||||
qcom-apq8074-dragonboard.dtb
|
||||
dtb-$(CONFIG_ARCH_MVEBU) += armada-370-db.dtb \
|
||||
armada-370-mirabox.dtb \
|
||||
armada-370-netgear-rn102.dtb \
|
||||
|
@ -188,12 +189,19 @@ dtb-$(CONFIG_ARCH_NSPIRE) += nspire-cx.dtb \
|
|||
nspire-tp.dtb \
|
||||
nspire-clp.dtb
|
||||
dtb-$(CONFIG_ARCH_OMAP2PLUS) += omap2420-h4.dtb \
|
||||
omap2430-sdp.dtb \
|
||||
omap2420-n800.dtb \
|
||||
omap2420-n810.dtb \
|
||||
omap2420-n810-wimax.dtb \
|
||||
omap3430-sdp.dtb \
|
||||
omap3-beagle.dtb \
|
||||
omap3-cm-t3730.dtb \
|
||||
omap3-sbc-t3730.dtb \
|
||||
omap3-devkit8000.dtb \
|
||||
omap3-beagle-xm.dtb \
|
||||
omap3-evm.dtb \
|
||||
omap3-evm-37xx.dtb \
|
||||
omap3-ldp.dtb \
|
||||
omap3-n900.dtb \
|
||||
omap3-n9.dtb \
|
||||
omap3-n950.dtb \
|
||||
|
@ -233,6 +241,7 @@ dtb-$(CONFIG_ARCH_S3C64XX) += s3c6410-mini6410.dtb \
|
|||
s3c6410-smdk6410.dtb
|
||||
dtb-$(CONFIG_ARCH_SHMOBILE_LEGACY) += emev2-kzm9d.dtb \
|
||||
r7s72100-genmai.dtb \
|
||||
r7s72100-genmai-reference.dtb \
|
||||
r8a7740-armadillo800eva.dtb \
|
||||
r8a7778-bockw.dtb \
|
||||
r8a7778-bockw-reference.dtb \
|
||||
|
@ -241,13 +250,15 @@ dtb-$(CONFIG_ARCH_SHMOBILE_LEGACY) += emev2-kzm9d.dtb \
|
|||
r8a7779-marzen-reference.dtb \
|
||||
r8a7791-koelsch.dtb \
|
||||
r8a7790-lager.dtb \
|
||||
r8a7790-lager-reference.dtb \
|
||||
sh73a0-kzm9g.dtb \
|
||||
sh73a0-kzm9g-reference.dtb \
|
||||
r8a73a4-ape6evm.dtb \
|
||||
r8a73a4-ape6evm-reference.dtb \
|
||||
sh7372-mackerel.dtb
|
||||
dtb-$(CONFIG_ARCH_SHMOBILE_MULTI) += emev2-kzm9d.dtb
|
||||
dtb-$(CONFIG_ARCH_SHMOBILE_MULTI) += emev2-kzm9d.dtb \
|
||||
r7s72100-genmai-reference.dtb \
|
||||
r8a7791-koelsch.dtb \
|
||||
r8a7790-lager.dtb
|
||||
dtb-$(CONFIG_ARCH_SOCFPGA) += socfpga_arria5_socdk.dtb \
|
||||
socfpga_cyclone5_socdk.dtb \
|
||||
socfpga_cyclone5_sockit.dtb \
|
||||
|
|
|
@ -17,6 +17,21 @@
|
|||
device_type = "memory";
|
||||
reg = <0x80000000 0x10000000>; /* 256 MB */
|
||||
};
|
||||
|
||||
vmmc_fixed: vmmc {
|
||||
compatible = "regulator-fixed";
|
||||
regulator-name = "vmmc_fixed";
|
||||
regulator-min-microvolt = <3300000>;
|
||||
regulator-max-microvolt = <3300000>;
|
||||
};
|
||||
};
|
||||
|
||||
&davinci_emac {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
&davinci_mdio {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
&i2c1 {
|
||||
|
@ -30,3 +45,17 @@
|
|||
&i2c3 {
|
||||
clock-frequency = <400000>;
|
||||
};
|
||||
|
||||
&mmc1 {
|
||||
vmmc-supply = <&vmmc_fixed>;
|
||||
bus-width = <4>;
|
||||
};
|
||||
|
||||
&mmc2 {
|
||||
status = "disabled";
|
||||
};
|
||||
|
||||
&mmc3 {
|
||||
status = "disabled";
|
||||
};
|
||||
|
||||
|
|
|
@ -145,7 +145,7 @@
|
|||
compatible = "ti,omap2-rng";
|
||||
ti,hwmods = "rng";
|
||||
reg = <0x480a0000 0x50>;
|
||||
interrupts = <36>;
|
||||
interrupts = <52>;
|
||||
};
|
||||
|
||||
sham: sham@480a4000 {
|
||||
|
|
|
@ -0,0 +1,8 @@
|
|||
/dts-v1/;
|
||||
|
||||
#include "omap2420-n8x0-common.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Nokia N800";
|
||||
compatible = "nokia,n800", "nokia,n8x0", "ti,omap2420", "ti,omap2";
|
||||
};
|
|
@ -0,0 +1,8 @@
|
|||
/dts-v1/;
|
||||
|
||||
#include "omap2420-n8x0-common.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Nokia N810 WiMax";
|
||||
compatible = "nokia,n810-wimax", "nokia,n8x0", "ti,omap2420", "ti,omap2";
|
||||
};
|
|
@ -0,0 +1,8 @@
|
|||
/dts-v1/;
|
||||
|
||||
#include "omap2420-n8x0-common.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Nokia N810";
|
||||
compatible = "nokia,n810", "nokia,n8x0", "ti,omap2420", "ti,omap2";
|
||||
};
|
|
@ -0,0 +1,99 @@
|
|||
#include "omap2420.dtsi"
|
||||
|
||||
/ {
|
||||
memory {
|
||||
device_type = "memory";
|
||||
reg = <0x80000000 0x8000000>; /* 128 MB */
|
||||
};
|
||||
|
||||
ocp {
|
||||
i2c@0 {
|
||||
compatible = "i2c-cbus-gpio";
|
||||
gpios = <&gpio3 2 0 /* gpio66 clk */
|
||||
&gpio3 1 0 /* gpio65 dat */
|
||||
&gpio3 0 0 /* gpio64 sel */
|
||||
>;
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
retu_mfd: retu@1 {
|
||||
compatible = "retu-mfd";
|
||||
interrupt-parent = <&gpio4>;
|
||||
interrupts = <12 IRQ_TYPE_EDGE_RISING>;
|
||||
reg = <0x1>;
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
&i2c1 {
|
||||
clock-frequency = <400000>;
|
||||
};
|
||||
|
||||
&i2c2 {
|
||||
clock-frequency = <400000>;
|
||||
};
|
||||
|
||||
&gpmc {
|
||||
ranges = <0 0 0x04000000 0x10000000>;
|
||||
|
||||
/* gpio-irq for dma: 26 */
|
||||
|
||||
onenand@0,0 {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <1>;
|
||||
reg = <0 0 0x10000000>;
|
||||
|
||||
gpmc,sync-read;
|
||||
gpmc,burst-length = <16>;
|
||||
gpmc,burst-read;
|
||||
gpmc,burst-wrap;
|
||||
gpmc,device-width = <2>;
|
||||
gpmc,mux-add-data = <2>;
|
||||
gpmc,cs-on-ns = <0>;
|
||||
gpmc,cs-rd-off-ns = <127>;
|
||||
gpmc,cs-wr-off-ns = <109>;
|
||||
gpmc,adv-on-ns = <0>;
|
||||
gpmc,adv-rd-off-ns = <18>;
|
||||
gpmc,adv-wr-off-ns = <18>;
|
||||
gpmc,oe-on-ns = <27>;
|
||||
gpmc,oe-off-ns = <127>;
|
||||
gpmc,we-on-ns = <27>;
|
||||
gpmc,we-off-ns = <72>;
|
||||
gpmc,rd-cycle-ns = <145>;
|
||||
gpmc,wr-cycle-ns = <136>;
|
||||
gpmc,access-ns = <118>;
|
||||
gpmc,page-burst-access-ns = <27>;
|
||||
gpmc,bus-turnaround-ns = <0>;
|
||||
gpmc,cycle2cycle-delay-ns = <0>;
|
||||
gpmc,wait-monitoring-ns = <0>;
|
||||
gpmc,clk-activation-ns = <9>;
|
||||
gpmc,sync-clk-ps = <27000>;
|
||||
|
||||
/* MTD partition table corresponding to old board-n8x0 file. */
|
||||
partition@0 {
|
||||
label = "bootloader";
|
||||
reg = <0x00000000 0x00020000>;
|
||||
read-only;
|
||||
};
|
||||
partition@1 {
|
||||
label = "config";
|
||||
reg = <0x00020000 0x00060000>;
|
||||
};
|
||||
partition@2 {
|
||||
label = "kernel";
|
||||
reg = <0x00080000 0x00200000>;
|
||||
};
|
||||
partition@3 {
|
||||
label = "initfs";
|
||||
reg = <0x00280000 0x00400000>;
|
||||
};
|
||||
partition@4 {
|
||||
label = "rootfs";
|
||||
reg = <0x00680000 0x0f980000>;
|
||||
};
|
||||
partition@5 {
|
||||
label = "omap2-onenand";
|
||||
reg = <0x00000000 0x10000000>;
|
||||
};
|
||||
};
|
||||
};
|
|
@ -0,0 +1,49 @@
|
|||
/*
|
||||
* Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.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.
|
||||
*/
|
||||
/dts-v1/;
|
||||
|
||||
#include "omap2430.dtsi"
|
||||
|
||||
/ {
|
||||
model = "TI OMAP2430 SDP";
|
||||
compatible = "ti,omap2430-sdp", "ti,omap2430", "ti,omap2";
|
||||
|
||||
memory {
|
||||
device_type = "memory";
|
||||
reg = <0x80000000 0x8000000>; /* 128 MB */
|
||||
};
|
||||
};
|
||||
|
||||
&i2c2 {
|
||||
clock-frequency = <100000>;
|
||||
|
||||
twl: twl@48 {
|
||||
reg = <0x48>;
|
||||
interrupts = <7>; /* SYS_NIRQ cascaded to intc */
|
||||
};
|
||||
};
|
||||
|
||||
#include "twl4030.dtsi"
|
||||
|
||||
&mmc1 {
|
||||
vmmc-supply = <&vmmc1>;
|
||||
bus-width = <4>;
|
||||
};
|
||||
|
||||
&gpmc {
|
||||
ranges = <5 0 0x08000000 0x01000000>;
|
||||
ethernet@gpmc {
|
||||
compatible = "smsc,lan91c94";
|
||||
interrupt-parent = <&gpio5>;
|
||||
interrupts = <21 IRQ_TYPE_LEVEL_LOW>; /* gpio149 */
|
||||
reg = <5 0x300 0xf>;
|
||||
bank-width = <2>;
|
||||
gpmc,mux-add-data;
|
||||
};
|
||||
};
|
||||
|
|
@ -99,7 +99,7 @@
|
|||
&omap3_pmx_core {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <
|
||||
&hsusbb2_pins
|
||||
&hsusb2_pins
|
||||
>;
|
||||
|
||||
uart3_pins: pinmux_uart3_pins {
|
||||
|
@ -109,20 +109,32 @@
|
|||
>;
|
||||
};
|
||||
|
||||
hsusbb2_pins: pinmux_hsusbb2_pins {
|
||||
hsusb2_pins: pinmux_hsusb2_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x5c0 (PIN_OUTPUT | MUX_MODE3) /* etk_d10.hsusb2_clk */
|
||||
0x5c2 (PIN_OUTPUT | MUX_MODE3) /* etk_d11.hsusb2_stp */
|
||||
0x5c4 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d12.hsusb2_dir */
|
||||
0x5c6 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d13.hsusb2_nxt */
|
||||
0x5c8 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d14.hsusb2_data0 */
|
||||
0x5cA (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d15.hsusb2_data1 */
|
||||
0x1a4 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi1_cs3.hsusb2_data2 */
|
||||
0x1a6 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_clk.hsusb2_data7 */
|
||||
0x1a8 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_simo.hsusb2_data4 */
|
||||
0x1aa (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_somi.hsusb2_data5 */
|
||||
0x1ac (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_cs0.hsusb2_data6 */
|
||||
0x1ae (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_cs1.hsusb2_data3 */
|
||||
OMAP3_CORE1_IOPAD(0x21d4, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi1_cs3.hsusb2_data2 */
|
||||
OMAP3_CORE1_IOPAD(0x21d6, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_clk.hsusb2_data7 */
|
||||
OMAP3_CORE1_IOPAD(0x21d8, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_simo.hsusb2_data4 */
|
||||
OMAP3_CORE1_IOPAD(0x21da, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_somi.hsusb2_data5 */
|
||||
OMAP3_CORE1_IOPAD(0x21dc, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_cs0.hsusb2_data6 */
|
||||
OMAP3_CORE1_IOPAD(0x21de, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_cs1.hsusb2_data3 */
|
||||
>;
|
||||
};
|
||||
};
|
||||
|
||||
&omap3_pmx_core2 {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <
|
||||
&hsusb2_2_pins
|
||||
>;
|
||||
|
||||
hsusb2_2_pins: pinmux_hsusb2_2_pins {
|
||||
pinctrl-single,pins = <
|
||||
OMAP3630_CORE2_IOPAD(0x25f0, PIN_OUTPUT | MUX_MODE3) /* etk_d10.hsusb2_clk */
|
||||
OMAP3630_CORE2_IOPAD(0x25f2, PIN_OUTPUT | MUX_MODE3) /* etk_d11.hsusb2_stp */
|
||||
OMAP3630_CORE2_IOPAD(0x25f4, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d12.hsusb2_dir */
|
||||
OMAP3630_CORE2_IOPAD(0x25f6, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d13.hsusb2_nxt */
|
||||
OMAP3630_CORE2_IOPAD(0x25f8, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d14.hsusb2_data0 */
|
||||
OMAP3630_CORE2_IOPAD(0x25fa, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d15.hsusb2_data1 */
|
||||
>;
|
||||
};
|
||||
};
|
||||
|
|
|
@ -93,23 +93,17 @@
|
|||
&omap3_pmx_core {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <
|
||||
&hsusbb2_pins
|
||||
&hsusb2_pins
|
||||
>;
|
||||
|
||||
hsusbb2_pins: pinmux_hsusbb2_pins {
|
||||
hsusb2_pins: pinmux_hsusb2_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x5c0 (PIN_OUTPUT | MUX_MODE3) /* etk_d10.hsusb2_clk */
|
||||
0x5c2 (PIN_OUTPUT | MUX_MODE3) /* etk_d11.hsusb2_stp */
|
||||
0x5c4 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d12.hsusb2_dir */
|
||||
0x5c6 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d13.hsusb2_nxt */
|
||||
0x5c8 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d14.hsusb2_data0 */
|
||||
0x5cA (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d15.hsusb2_data1 */
|
||||
0x1a4 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi1_cs3.hsusb2_data2 */
|
||||
0x1a6 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_clk.hsusb2_data7 */
|
||||
0x1a8 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_simo.hsusb2_data4 */
|
||||
0x1aa (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_somi.hsusb2_data5 */
|
||||
0x1ac (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_cs0.hsusb2_data6 */
|
||||
0x1ae (PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_cs1.hsusb2_data3 */
|
||||
OMAP3_CORE1_IOPAD(0x21d4, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi1_cs3.hsusb2_data2 */
|
||||
OMAP3_CORE1_IOPAD(0x21d6, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_clk.hsusb2_data7 */
|
||||
OMAP3_CORE1_IOPAD(0x21d8, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_simo.hsusb2_data4 */
|
||||
OMAP3_CORE1_IOPAD(0x21da, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_somi.hsusb2_data5 */
|
||||
OMAP3_CORE1_IOPAD(0x21dc, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_cs0.hsusb2_data6 */
|
||||
OMAP3_CORE1_IOPAD(0x21de, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_cs1.hsusb2_data3 */
|
||||
>;
|
||||
};
|
||||
|
||||
|
@ -121,6 +115,24 @@
|
|||
};
|
||||
};
|
||||
|
||||
&omap3_pmx_core2 {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <
|
||||
&hsusb2_2_pins
|
||||
>;
|
||||
|
||||
hsusb2_2_pins: pinmux_hsusb2_2_pins {
|
||||
pinctrl-single,pins = <
|
||||
OMAP3430_CORE2_IOPAD(0x25f0, PIN_OUTPUT | MUX_MODE3) /* etk_d10.hsusb2_clk */
|
||||
OMAP3430_CORE2_IOPAD(0x25f2, PIN_OUTPUT | MUX_MODE3) /* etk_d11.hsusb2_stp */
|
||||
OMAP3430_CORE2_IOPAD(0x25f4, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d12.hsusb2_dir */
|
||||
OMAP3430_CORE2_IOPAD(0x25f6, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d13.hsusb2_nxt */
|
||||
OMAP3430_CORE2_IOPAD(0x25f8, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d14.hsusb2_data0 */
|
||||
OMAP3430_CORE2_IOPAD(0x25fa, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d15.hsusb2_data1 */
|
||||
>;
|
||||
};
|
||||
};
|
||||
|
||||
&i2c1 {
|
||||
clock-frequency = <2600000>;
|
||||
|
||||
|
|
|
@ -0,0 +1,104 @@
|
|||
/*
|
||||
* Support for CompuLab CM-T3730
|
||||
*/
|
||||
/dts-v1/;
|
||||
|
||||
#include "omap36xx.dtsi"
|
||||
#include "omap3-cm-t3x30.dtsi"
|
||||
|
||||
/ {
|
||||
model = "CompuLab CM-T3730";
|
||||
compatible = "compulab,omap3-cm-t3730", "ti,omap36xx", "ti,omap3";
|
||||
|
||||
wl12xx_vmmc2: wl12xx_vmmc2 {
|
||||
compatible = "regulator-fixed";
|
||||
regulator-name = "vw1271";
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&wl12xx_gpio>;
|
||||
regulator-min-microvolt = <1800000>;
|
||||
regulator-max-microvolt = <1800000>;
|
||||
gpio = <&gpio3 9 GPIO_ACTIVE_HIGH>; /* gpio73 */
|
||||
startup-delay-us = <20000>;
|
||||
enable-active-high;
|
||||
};
|
||||
|
||||
wl12xx_vaux2: wl12xx_vaux2 {
|
||||
compatible = "regulator-fixed";
|
||||
regulator-name = "vwl1271_vaux2";
|
||||
regulator-min-microvolt = <1800000>;
|
||||
regulator-max-microvolt = <1800000>;
|
||||
vin-supply = <&vaux2>;
|
||||
};
|
||||
};
|
||||
|
||||
&omap3_pmx_core {
|
||||
mmc1_pins: pinmux_mmc1_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x114 (PIN_OUTPUT_PULLUP | MUX_MODE0) /* sdmmc1_clk.sdmmc1_clk */
|
||||
0x116 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_cmd.sdmmc1_cmd */
|
||||
0x118 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_dat0.sdmmc1_dat0 */
|
||||
0x11a (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_dat1.sdmmc1_dat1 */
|
||||
0x11c (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_dat2.sdmmc1_dat2 */
|
||||
0x11e (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_dat3.sdmmc1_dat3 */
|
||||
>;
|
||||
};
|
||||
|
||||
mmc2_pins: pinmux_mmc2_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x128 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_clk.sdmmc2_clk */
|
||||
0x12a (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_cmd.sdmmc2_cmd */
|
||||
0x12c (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat0.sdmmc2_dat0 */
|
||||
0x12e (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat1.sdmmc2_dat1 */
|
||||
0x130 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat2.sdmmc2_dat2 */
|
||||
0x132 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat3.sdmmc2_dat3 */
|
||||
>;
|
||||
};
|
||||
|
||||
smsc1_pins: pinmux_smsc1_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x88 (PIN_OUTPUT | MUX_MODE0) /* gpmc_ncs5.gpmc_ncs5 */
|
||||
0x16a (PIN_INPUT_PULLUP | MUX_MODE4) /* uart3_cts_rctx.gpio_163 */
|
||||
>;
|
||||
};
|
||||
|
||||
uart3_pins: pinmux_uart3_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x16e (PIN_INPUT | MUX_MODE0) /* uart3_rx_irrx.uart3_rx_irrx */
|
||||
0x170 (PIN_OUTPUT | MUX_MODE0) /* uart3_tx_irtx.uart3_tx_irtx */
|
||||
>;
|
||||
};
|
||||
|
||||
wl12xx_gpio: pinmux_wl12xx_gpio {
|
||||
pinctrl-single,pins = <
|
||||
0xb2 (PIN_OUTPUT | MUX_MODE4) /* dss_data3.gpio_73 */
|
||||
0x134 (PIN_INPUT | MUX_MODE4) /* sdmmc2_dat4.gpio_136 */
|
||||
>;
|
||||
};
|
||||
};
|
||||
|
||||
&mmc1 {
|
||||
vmmc-supply = <&vmmc1>;
|
||||
bus-width = <4>;
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&mmc1_pins>;
|
||||
};
|
||||
|
||||
&mmc2 {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&mmc2_pins>;
|
||||
vmmc-supply = <&wl12xx_vmmc2>;
|
||||
vmmc_aux-supply = <&wl12xx_vaux2>;
|
||||
non-removable;
|
||||
bus-width = <4>;
|
||||
cap-power-off-card;
|
||||
};
|
||||
|
||||
&smsc1 {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&smsc1_pins>;
|
||||
};
|
||||
|
||||
&uart3 {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&uart3_pins>;
|
||||
};
|
|
@ -0,0 +1,95 @@
|
|||
/*
|
||||
* Common support for CompuLab CM-T3530 and CM-T3730
|
||||
*/
|
||||
|
||||
/ {
|
||||
memory {
|
||||
device_type = "memory";
|
||||
reg = <0x80000000 0x10000000>; /* 256 MB */
|
||||
};
|
||||
|
||||
cpus {
|
||||
cpu@0 {
|
||||
cpu0-supply = <&vcc>;
|
||||
};
|
||||
};
|
||||
|
||||
leds {
|
||||
compatible = "gpio-leds";
|
||||
ledb {
|
||||
label = "cm-t35:green";
|
||||
gpios = <&gpio6 26 GPIO_ACTIVE_HIGH>; /* gpio186 */
|
||||
linux,default-trigger = "heartbeat";
|
||||
};
|
||||
};
|
||||
|
||||
vddvario: regulator-vddvario {
|
||||
compatible = "regulator-fixed";
|
||||
regulator-name = "vddvario";
|
||||
regulator-always-on;
|
||||
};
|
||||
|
||||
vdd33a: regulator-vdd33a {
|
||||
compatible = "regulator-fixed";
|
||||
regulator-name = "vdd33a";
|
||||
regulator-always-on;
|
||||
};
|
||||
};
|
||||
|
||||
&gpmc {
|
||||
ranges = <5 0 0x2c000000 0x01000000>;
|
||||
|
||||
smsc1: ethernet@5,0 {
|
||||
compatible = "smsc,lan9221", "smsc,lan9115";
|
||||
interrupt-parent = <&gpio6>;
|
||||
interrupts = <3 IRQ_TYPE_LEVEL_LOW>;
|
||||
reg = <5 0 0xff>;
|
||||
bank-width = <2>;
|
||||
gpmc,mux-add-data;
|
||||
gpmc,cs-on-ns = <0>;
|
||||
gpmc,cs-rd-off-ns = <186>;
|
||||
gpmc,cs-wr-off-ns = <186>;
|
||||
gpmc,adv-on-ns = <12>;
|
||||
gpmc,adv-rd-off-ns = <48>;
|
||||
gpmc,adv-wr-off-ns = <48>;
|
||||
gpmc,oe-on-ns = <54>;
|
||||
gpmc,oe-off-ns = <168>;
|
||||
gpmc,we-on-ns = <54>;
|
||||
gpmc,we-off-ns = <168>;
|
||||
gpmc,rd-cycle-ns = <186>;
|
||||
gpmc,wr-cycle-ns = <186>;
|
||||
gpmc,access-ns = <114>;
|
||||
gpmc,page-burst-access-ns = <6>;
|
||||
gpmc,bus-turnaround-ns = <12>;
|
||||
gpmc,cycle2cycle-delay-ns = <18>;
|
||||
gpmc,wr-data-mux-bus-ns = <90>;
|
||||
gpmc,wr-access-ns = <186>;
|
||||
gpmc,cycle2cycle-samecsen;
|
||||
gpmc,cycle2cycle-diffcsen;
|
||||
vddvario-supply = <&vddvario>;
|
||||
vdd33a-supply = <&vdd33a>;
|
||||
reg-io-width = <4>;
|
||||
smsc,save-mac-address;
|
||||
};
|
||||
};
|
||||
|
||||
&i2c1 {
|
||||
clock-frequency = <400000>;
|
||||
|
||||
twl: twl@48 {
|
||||
reg = <0x48>;
|
||||
interrupts = <7>; /* SYS_NIRQ cascaded to intc */
|
||||
interrupt-parent = <&intc>;
|
||||
};
|
||||
};
|
||||
|
||||
#include "twl4030.dtsi"
|
||||
#include "twl4030_omap3.dtsi"
|
||||
|
||||
&i2c3 {
|
||||
clock-frequency = <400000>;
|
||||
};
|
||||
|
||||
&twl_gpio {
|
||||
ti,use-leds;
|
||||
};
|
|
@ -133,8 +133,6 @@
|
|||
0x194 (PIN_INPUT | MUX_MODE0) /* i2c3_sda.i2c3_sda */
|
||||
>;
|
||||
};
|
||||
|
||||
leds_pins: pinmux_leds_pins { };
|
||||
};
|
||||
|
||||
&i2c1 {
|
||||
|
|
|
@ -66,28 +66,10 @@
|
|||
&omap3_pmx_core {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <
|
||||
&hsusbb1_pins
|
||||
&tfp410_pins
|
||||
&dss_pins
|
||||
>;
|
||||
|
||||
hsusbb1_pins: pinmux_hsusbb1_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x5aa (PIN_OUTPUT | MUX_MODE3) /* etk_ctl.hsusb1_clk */
|
||||
0x5a8 (PIN_OUTPUT | MUX_MODE3) /* etk_clk.hsusb1_stp */
|
||||
0x5bc (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d8.hsusb1_dir */
|
||||
0x5be (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d9.hsusb1_nxt */
|
||||
0x5ac (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d0.hsusb1_data0 */
|
||||
0x5ae (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d1.hsusb1_data1 */
|
||||
0x5b0 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d2.hsusb1_data2 */
|
||||
0x5b2 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d3.hsusb1_data7 */
|
||||
0x5b4 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d4.hsusb1_data4 */
|
||||
0x5b6 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d5.hsusb1_data5 */
|
||||
0x5b8 (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d6.hsusb1_data6 */
|
||||
0x5ba (PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d7.hsusb1_data3 */
|
||||
>;
|
||||
};
|
||||
|
||||
tfp410_pins: tfp410_dvi_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x196 (PIN_OUTPUT | MUX_MODE4) /* hdq_sio.gpio_170 */
|
||||
|
@ -128,12 +110,36 @@
|
|||
};
|
||||
};
|
||||
|
||||
&leds_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x5c4 (PIN_OUTPUT | MUX_MODE4) /* etk_d12.gpio_26 */
|
||||
0x5c6 (PIN_OUTPUT | MUX_MODE4) /* etk_d13.gpio_27 */
|
||||
0x5c8 (PIN_OUTPUT | MUX_MODE4) /* etk_d14.gpio_28 */
|
||||
&omap3_pmx_core2 {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <
|
||||
&hsusbb1_pins
|
||||
>;
|
||||
|
||||
hsusbb1_pins: pinmux_hsusbb1_pins {
|
||||
pinctrl-single,pins = <
|
||||
OMAP3630_CORE2_IOPAD(0x25da, PIN_OUTPUT | MUX_MODE3) /* etk_ctl.hsusb1_clk */
|
||||
OMAP3630_CORE2_IOPAD(0x25d8, PIN_OUTPUT | MUX_MODE3) /* etk_clk.hsusb1_stp */
|
||||
OMAP3630_CORE2_IOPAD(0x25ec, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d8.hsusb1_dir */
|
||||
OMAP3630_CORE2_IOPAD(0x25ee, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d9.hsusb1_nxt */
|
||||
OMAP3630_CORE2_IOPAD(0x25dc, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d0.hsusb1_data0 */
|
||||
OMAP3630_CORE2_IOPAD(0x25de, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d1.hsusb1_data1 */
|
||||
OMAP3630_CORE2_IOPAD(0x25e0, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d2.hsusb1_data2 */
|
||||
OMAP3630_CORE2_IOPAD(0x25e2, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d3.hsusb1_data7 */
|
||||
OMAP3630_CORE2_IOPAD(0x25e4, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d4.hsusb1_data4 */
|
||||
OMAP3630_CORE2_IOPAD(0x25e6, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d5.hsusb1_data5 */
|
||||
OMAP3630_CORE2_IOPAD(0x25e8, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d6.hsusb1_data6 */
|
||||
OMAP3630_CORE2_IOPAD(0x25ea, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d7.hsusb1_data3 */
|
||||
>;
|
||||
};
|
||||
|
||||
leds_pins: pinmux_leds_pins {
|
||||
pinctrl-single,pins = <
|
||||
OMAP3630_CORE2_IOPAD(0x25f4, PIN_OUTPUT | MUX_MODE4) /* etk_d12.gpio_26 */
|
||||
OMAP3630_CORE2_IOPAD(0x25f6, PIN_OUTPUT | MUX_MODE4) /* etk_d13.gpio_27 */
|
||||
OMAP3630_CORE2_IOPAD(0x25f8, PIN_OUTPUT | MUX_MODE4) /* etk_d14.gpio_28 */
|
||||
>;
|
||||
};
|
||||
};
|
||||
|
||||
&i2c3 {
|
||||
|
|
|
@ -46,10 +46,12 @@
|
|||
};
|
||||
};
|
||||
|
||||
&leds_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x5b0 (PIN_OUTPUT | MUX_MODE4) /* etk_d2.gpio_16 */
|
||||
>;
|
||||
&omap3_pmx_core2 {
|
||||
leds_pins: pinmux_leds_pins {
|
||||
pinctrl-single,pins = <
|
||||
OMAP3630_CORE2_IOPAD(0x25e0, PIN_OUTPUT | MUX_MODE4) /* etk_d2.gpio_16 */
|
||||
>;
|
||||
};
|
||||
};
|
||||
|
||||
&gpmc {
|
||||
|
|
|
@ -0,0 +1,231 @@
|
|||
/*
|
||||
* Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.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.
|
||||
*/
|
||||
/dts-v1/;
|
||||
|
||||
#include "omap34xx.dtsi"
|
||||
#include "omap-gpmc-smsc911x.dtsi"
|
||||
|
||||
/ {
|
||||
model = "TI OMAP3430 LDP (Zoom1 Labrador)";
|
||||
compatible = "ti,omap3-ldp", "ti,omap3";
|
||||
|
||||
memory {
|
||||
device_type = "memory";
|
||||
reg = <0x80000000 0x8000000>; /* 128 MB */
|
||||
};
|
||||
|
||||
cpus {
|
||||
cpu@0 {
|
||||
cpu0-supply = <&vcc>;
|
||||
};
|
||||
};
|
||||
|
||||
gpio_keys {
|
||||
compatible = "gpio-keys";
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&gpio_key_pins>;
|
||||
|
||||
key_enter {
|
||||
label = "enter";
|
||||
gpios = <&gpio4 5 GPIO_ACTIVE_LOW>; /* gpio101 */
|
||||
linux,code = <0x0107001c>; /* KEY_ENTER */
|
||||
gpio-key,wakeup;
|
||||
};
|
||||
|
||||
key_f1 {
|
||||
label = "f1";
|
||||
gpios = <&gpio4 6 GPIO_ACTIVE_LOW>; /* gpio102 */
|
||||
linux,code = <0x0303003b>; /* KEY_F1 */
|
||||
gpio-key,wakeup;
|
||||
};
|
||||
|
||||
key_f2 {
|
||||
label = "f2";
|
||||
gpios = <&gpio4 7 GPIO_ACTIVE_LOW>; /* gpio103 */
|
||||
linux,code = <0x0403003c>; /* KEY_F2 */
|
||||
gpio-key,wakeup;
|
||||
};
|
||||
|
||||
key_f3 {
|
||||
label = "f3";
|
||||
gpios = <&gpio4 8 GPIO_ACTIVE_LOW>; /* gpio104 */
|
||||
linux,code = <0x0503003d>; /* KEY_F3 */
|
||||
gpio-key,wakeup;
|
||||
};
|
||||
|
||||
key_f4 {
|
||||
label = "f4";
|
||||
gpios = <&gpio4 9 GPIO_ACTIVE_LOW>; /* gpio105 */
|
||||
linux,code = <0x0704003e>; /* KEY_F4 */
|
||||
gpio-key,wakeup;
|
||||
};
|
||||
|
||||
key_left {
|
||||
label = "left";
|
||||
gpios = <&gpio4 10 GPIO_ACTIVE_LOW>; /* gpio106 */
|
||||
linux,code = <0x04070069>; /* KEY_LEFT */
|
||||
gpio-key,wakeup;
|
||||
};
|
||||
|
||||
key_right {
|
||||
label = "right";
|
||||
gpios = <&gpio4 11 GPIO_ACTIVE_LOW>; /* gpio107 */
|
||||
linux,code = <0x0507006a>; /* KEY_RIGHT */
|
||||
gpio-key,wakeup;
|
||||
};
|
||||
|
||||
key_up {
|
||||
label = "up";
|
||||
gpios = <&gpio4 12 GPIO_ACTIVE_LOW>; /* gpio108 */
|
||||
linux,code = <0x06070067>; /* KEY_UP */
|
||||
gpio-key,wakeup;
|
||||
};
|
||||
|
||||
key_down {
|
||||
label = "down";
|
||||
gpios = <&gpio4 13 GPIO_ACTIVE_LOW>; /* gpio109 */
|
||||
linux,code = <0x0707006c>; /* KEY_DOWN */
|
||||
gpio-key,wakeup;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
&gpmc {
|
||||
ranges = <0 0 0x00000000 0x01000000>,
|
||||
<1 0 0x08000000 0x01000000>;
|
||||
|
||||
nand@0,0 {
|
||||
linux,mtd-name= "micron,nand";
|
||||
reg = <0 0 0>;
|
||||
nand-bus-width = <16>;
|
||||
ti,nand-ecc-opt = "bch8";
|
||||
|
||||
gpmc,sync-clk-ps = <0>;
|
||||
gpmc,cs-on-ns = <0>;
|
||||
gpmc,cs-rd-off-ns = <44>;
|
||||
gpmc,cs-wr-off-ns = <44>;
|
||||
gpmc,adv-on-ns = <6>;
|
||||
gpmc,adv-rd-off-ns = <34>;
|
||||
gpmc,adv-wr-off-ns = <44>;
|
||||
gpmc,we-off-ns = <40>;
|
||||
gpmc,oe-off-ns = <54>;
|
||||
gpmc,access-ns = <64>;
|
||||
gpmc,rd-cycle-ns = <82>;
|
||||
gpmc,wr-cycle-ns = <82>;
|
||||
gpmc,wr-access-ns = <40>;
|
||||
gpmc,wr-data-mux-bus-ns = <0>;
|
||||
|
||||
#address-cells = <1>;
|
||||
#size-cells = <1>;
|
||||
|
||||
partition@0 {
|
||||
label = "X-Loader";
|
||||
reg = <0 0x80000>;
|
||||
};
|
||||
partition@80000 {
|
||||
label = "U-Boot";
|
||||
reg = <0x80000 0x140000>;
|
||||
};
|
||||
partition@1c0000 {
|
||||
label = "Environment";
|
||||
reg = <0x1c0000 0x40000>;
|
||||
};
|
||||
partition@200000 {
|
||||
label = "Kernel";
|
||||
reg = <0x200000 0x1e00000>;
|
||||
};
|
||||
partition@2000000 {
|
||||
label = "Filesystem";
|
||||
reg = <0x2000000 0xe000000>;
|
||||
};
|
||||
};
|
||||
|
||||
ethernet@gpmc {
|
||||
interrupt-parent = <&gpio5>;
|
||||
interrupts = <24 IRQ_TYPE_LEVEL_LOW>;
|
||||
reg = <1 0 0xff>;
|
||||
};
|
||||
};
|
||||
|
||||
&i2c1 {
|
||||
clock-frequency = <2600000>;
|
||||
|
||||
twl: twl@48 {
|
||||
reg = <0x48>;
|
||||
interrupts = <7>; /* SYS_NIRQ cascaded to intc */
|
||||
interrupt-parent = <&intc>;
|
||||
};
|
||||
};
|
||||
|
||||
#include "twl4030.dtsi"
|
||||
#include "twl4030_omap3.dtsi"
|
||||
|
||||
&i2c2 {
|
||||
clock-frequency = <400000>;
|
||||
};
|
||||
|
||||
&i2c3 {
|
||||
clock-frequency = <400000>;
|
||||
};
|
||||
|
||||
&mmc1 {
|
||||
vmmc-supply = <&vmmc1>;
|
||||
bus-width = <4>;
|
||||
};
|
||||
|
||||
&omap3_pmx_core {
|
||||
gpio_key_pins: pinmux_gpio_key_pins {
|
||||
pinctrl-single,pins = <
|
||||
0xea (PIN_INPUT | MUX_MODE4) /* cam_d2.gpio_101 */
|
||||
0xec (PIN_INPUT | MUX_MODE4) /* cam_d3.gpio_102 */
|
||||
0xee (PIN_INPUT | MUX_MODE4) /* cam_d4.gpio_103 */
|
||||
0xf0 (PIN_INPUT | MUX_MODE4) /* cam_d5.gpio_104 */
|
||||
0xf2 (PIN_INPUT | MUX_MODE4) /* cam_d6.gpio_105 */
|
||||
0xf4 (PIN_INPUT | MUX_MODE4) /* cam_d7.gpio_106 */
|
||||
0xf6 (PIN_INPUT | MUX_MODE4) /* cam_d8.gpio_107 */
|
||||
0xf8 (PIN_INPUT | MUX_MODE4) /* cam_d9.gpio_108 */
|
||||
0xfa (PIN_INPUT | MUX_MODE4) /* cam_d10.gpio_109 */
|
||||
>;
|
||||
};
|
||||
|
||||
musb_pins: pinmux_musb_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x172 (PIN_INPUT | MUX_MODE0) /* hsusb0_clk.hsusb0_clk */
|
||||
0x17a (PIN_INPUT | MUX_MODE0) /* hsusb0_data0.hsusb0_data0 */
|
||||
0x17c (PIN_INPUT | MUX_MODE0) /* hsusb0_data1.hsusb0_data1 */
|
||||
0x17e (PIN_INPUT | MUX_MODE0) /* hsusb0_data2.hsusb0_data2 */
|
||||
0x180 (PIN_INPUT | MUX_MODE0) /* hsusb0_data3.hsusb0_data3 */
|
||||
0x182 (PIN_INPUT | MUX_MODE0) /* hsusb0_data4.hsusb0_data4 */
|
||||
0x184 (PIN_INPUT | MUX_MODE0) /* hsusb0_data5.hsusb0_data5 */
|
||||
0x186 (PIN_INPUT | MUX_MODE0) /* hsusb0_data6.hsusb0_data6 */
|
||||
0x188 (PIN_INPUT | MUX_MODE0) /* hsusb0_data7.hsusb0_data7 */
|
||||
0x176 (PIN_INPUT | MUX_MODE0) /* hsusb0_dir.hsusb0_dir */
|
||||
0x178 (PIN_INPUT | MUX_MODE0) /* hsusb0_nxt.hsusb0_nxt */
|
||||
0x174 (PIN_OUTPUT | MUX_MODE0) /* hsusb0_stp.hsusb0_stp */
|
||||
>;
|
||||
};
|
||||
};
|
||||
|
||||
&usb_otg_hs {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&musb_pins>;
|
||||
interface-type = <0>;
|
||||
usb-phy = <&usb2_phy>;
|
||||
mode = <3>;
|
||||
power = <50>;
|
||||
};
|
||||
|
||||
&vaux1 {
|
||||
/* Needed for ads7846 */
|
||||
regulator-name = "vcc";
|
||||
};
|
||||
|
||||
&vpll2 {
|
||||
/* Needed for DSS */
|
||||
regulator-name = "vdds_dsi";
|
||||
};
|
|
@ -0,0 +1,40 @@
|
|||
/*
|
||||
* Common support for CompuLab SB-T35 used on SBC-T3530, SBC-T3517 and SBC-T3730
|
||||
*/
|
||||
|
||||
&gpmc {
|
||||
ranges = <4 0 0x2d000000 0x01000000>;
|
||||
|
||||
smsc2: ethernet@4,0 {
|
||||
compatible = "smsc,lan9221", "smsc,lan9115";
|
||||
interrupt-parent = <&gpio3>;
|
||||
interrupts = <1 IRQ_TYPE_LEVEL_LOW>;
|
||||
reg = <4 0 0xff>;
|
||||
bank-width = <2>;
|
||||
gpmc,mux-add-data;
|
||||
gpmc,cs-on-ns = <0>;
|
||||
gpmc,cs-rd-off-ns = <186>;
|
||||
gpmc,cs-wr-off-ns = <186>;
|
||||
gpmc,adv-on-ns = <12>;
|
||||
gpmc,adv-rd-off-ns = <48>;
|
||||
gpmc,adv-wr-off-ns = <48>;
|
||||
gpmc,oe-on-ns = <54>;
|
||||
gpmc,oe-off-ns = <168>;
|
||||
gpmc,we-on-ns = <54>;
|
||||
gpmc,we-off-ns = <168>;
|
||||
gpmc,rd-cycle-ns = <186>;
|
||||
gpmc,wr-cycle-ns = <186>;
|
||||
gpmc,access-ns = <114>;
|
||||
gpmc,page-burst-access-ns = <6>;
|
||||
gpmc,bus-turnaround-ns = <12>;
|
||||
gpmc,cycle2cycle-delay-ns = <18>;
|
||||
gpmc,wr-data-mux-bus-ns = <90>;
|
||||
gpmc,wr-access-ns = <186>;
|
||||
gpmc,cycle2cycle-samecsen;
|
||||
gpmc,cycle2cycle-diffcsen;
|
||||
vddvario-supply = <&vddvario>;
|
||||
vdd33a-supply = <&vdd33a>;
|
||||
reg-io-width = <4>;
|
||||
smsc,save-mac-address;
|
||||
};
|
||||
};
|
|
@ -0,0 +1,30 @@
|
|||
/*
|
||||
* Suppport for CompuLab SBC-T3730 with CM-T3730
|
||||
*/
|
||||
|
||||
#include "omap3-cm-t3730.dts"
|
||||
#include "omap3-sb-t35.dtsi"
|
||||
|
||||
/ {
|
||||
model = "CompuLab SBC-T3730 with CM-T3730";
|
||||
compatible = "compulab,omap3-sbc-t3730", "compulab,omap3-cm-t3730", "ti,omap36xx", "ti,omap3";
|
||||
};
|
||||
|
||||
&gpmc {
|
||||
ranges = <5 0 0x2c000000 0x01000000>,
|
||||
<4 0 0x2d000000 0x01000000>;
|
||||
};
|
||||
|
||||
&smsc2 {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&smsc2_pins>;
|
||||
};
|
||||
|
||||
&omap3_pmx_core {
|
||||
smsc2_pins: pinmux_smsc2_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x86 (PIN_OUTPUT | MUX_MODE0) /* gpmc_ncs4.gpmc_ncs4 */
|
||||
0xa2 (PIN_INPUT_PULLUP | MUX_MODE4) /* gpmc_wait3.gpio_65 */
|
||||
>;
|
||||
};
|
||||
};
|
|
@ -80,13 +80,8 @@
|
|||
|
||||
mmc3_pins: pinmux_mmc3_pins {
|
||||
pinctrl-single,pins = <
|
||||
0x168 (PIN_INPUT | MUX_MODE4) /* mcbsp1_clkx.gpio_162 WLAN IRQ */
|
||||
0x1a0 (PIN_INPUT_PULLUP | MUX_MODE3) /* mcspi1_cs1.sdmmc3_cmd */
|
||||
0x5a8 (PIN_INPUT_PULLUP | MUX_MODE2) /* etk_clk.sdmmc3_clk */
|
||||
0x5b4 (PIN_INPUT_PULLUP | MUX_MODE2) /* etk_d4.sdmmc3_dat0 */
|
||||
0x5b6 (WAKEUP_EN | PIN_INPUT_PULLUP | MUX_MODE2) /* etk_d5.sdmmc3_dat1 */
|
||||
0x5b8 (PIN_INPUT_PULLUP | MUX_MODE2) /* etk_d6.sdmmc3_dat2 */
|
||||
0x5b2 (PIN_INPUT_PULLUP | MUX_MODE2) /* etk_d3.sdmmc3_dat3 */
|
||||
OMAP3_CORE1_IOPAD(0x2198, PIN_INPUT | MUX_MODE4) /* mcbsp1_clkx.gpio_162 WLAN IRQ */
|
||||
OMAP3_CORE1_IOPAD(0x21d0, PIN_INPUT_PULLUP | MUX_MODE3) /* mcspi1_cs1.sdmmc3_cmd */
|
||||
>;
|
||||
};
|
||||
|
||||
|
@ -125,6 +120,18 @@
|
|||
};
|
||||
};
|
||||
|
||||
&omap3_pmx_core2 {
|
||||
mmc3_2_pins: pinmux_mmc3_2_pins {
|
||||
pinctrl-single,pins = <
|
||||
OMAP3630_CORE2_IOPAD(0x25d8, PIN_INPUT_PULLUP | MUX_MODE2) /* etk_clk.sdmmc3_clk */
|
||||
OMAP3630_CORE2_IOPAD(0x25e4, PIN_INPUT_PULLUP | MUX_MODE2) /* etk_d4.sdmmc3_dat0 */
|
||||
OMAP3630_CORE2_IOPAD(0x25e6, WAKEUP_EN | PIN_INPUT_PULLUP | MUX_MODE2) /* etk_d5.sdmmc3_dat1 */
|
||||
OMAP3630_CORE2_IOPAD(0x25e8, PIN_INPUT_PULLUP | MUX_MODE2) /* etk_d6.sdmmc3_dat2 */
|
||||
OMAP3630_CORE2_IOPAD(0x25e2, PIN_INPUT_PULLUP | MUX_MODE2) /* etk_d3.sdmmc3_dat3 */
|
||||
>;
|
||||
};
|
||||
};
|
||||
|
||||
&omap3_pmx_wkup {
|
||||
wlan_host_wkup: pinmux_wlan_host_wkup_pins {
|
||||
pinctrl-single,pins = <
|
||||
|
@ -187,7 +194,7 @@
|
|||
bus-width = <4>;
|
||||
cap-power-off-card;
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&mmc3_pins>;
|
||||
pinctrl-0 = <&mmc3_pins &mmc3_2_pins>;
|
||||
};
|
||||
|
||||
&uart1 {
|
||||
|
|
|
@ -117,7 +117,7 @@
|
|||
|
||||
omap3_pmx_core: pinmux@48002030 {
|
||||
compatible = "ti,omap3-padconf", "pinctrl-single";
|
||||
reg = <0x48002030 0x05cc>;
|
||||
reg = <0x48002030 0x0238>;
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
#interrupt-cells = <1>;
|
||||
|
|
|
@ -25,4 +25,17 @@
|
|||
clock-latency = <300000>; /* From legacy driver */
|
||||
};
|
||||
};
|
||||
|
||||
ocp {
|
||||
omap3_pmx_core2: pinmux@480025d8 {
|
||||
compatible = "ti,omap3-padconf", "pinctrl-single";
|
||||
reg = <0x480025d8 0x24>;
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
#interrupt-cells = <1>;
|
||||
interrupt-controller;
|
||||
pinctrl-single,register-width = <16>;
|
||||
pinctrl-single,function-mask = <0xff1f>;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
|
|
@ -38,5 +38,16 @@
|
|||
ti,hwmods = "uart4";
|
||||
clock-frequency = <48000000>;
|
||||
};
|
||||
|
||||
omap3_pmx_core2: pinmux@480025a0 {
|
||||
compatible = "ti,omap3-padconf", "pinctrl-single";
|
||||
reg = <0x480025a0 0x5c>;
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
#interrupt-cells = <1>;
|
||||
interrupt-controller;
|
||||
pinctrl-single,register-width = <16>;
|
||||
pinctrl-single,function-mask = <0xff1f>;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
|
|
@ -0,0 +1,6 @@
|
|||
#include "qcom-msm8974.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Qualcomm APQ8074 Dragonboard";
|
||||
compatible = "qcom,apq8074-dragonboard", "qcom,apq8074";
|
||||
};
|
|
@ -0,0 +1,31 @@
|
|||
/*
|
||||
* Device Tree Source for the Genmai board
|
||||
*
|
||||
* Copyright (C) 2013 Renesas Solutions Corp.
|
||||
*
|
||||
* This file is licensed under the terms of the GNU General Public License
|
||||
* version 2. This program is licensed "as is" without any warranty of any
|
||||
* kind, whether express or implied.
|
||||
*/
|
||||
|
||||
/dts-v1/;
|
||||
/include/ "r7s72100.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Genmai";
|
||||
compatible = "renesas,genmai-reference", "renesas,r7s72100";
|
||||
|
||||
chosen {
|
||||
bootargs = "console=ttySC2,115200 ignore_loglevel rw root=/dev/nfs ip=dhcp";
|
||||
};
|
||||
|
||||
memory {
|
||||
device_type = "memory";
|
||||
reg = <0x08000000 0x08000000>;
|
||||
};
|
||||
|
||||
lbsc {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <1>;
|
||||
};
|
||||
};
|
|
@ -105,6 +105,7 @@ CONFIG_FB=y
|
|||
CONFIG_FB_SH_MOBILE_LCDC=y
|
||||
CONFIG_FB_SH_MOBILE_HDMI=y
|
||||
CONFIG_LCD_CLASS_DEVICE=y
|
||||
CONFIG_BACKLIGHT_PWM=y
|
||||
CONFIG_FRAMEBUFFER_CONSOLE=y
|
||||
CONFIG_FRAMEBUFFER_CONSOLE_DETECT_PRIMARY=y
|
||||
CONFIG_LOGO=y
|
||||
|
@ -130,6 +131,8 @@ CONFIG_DMADEVICES=y
|
|||
CONFIG_SH_DMAE=y
|
||||
CONFIG_UIO=y
|
||||
CONFIG_UIO_PDRV_GENIRQ=y
|
||||
CONFIG_PWM=y
|
||||
CONFIG_PWM_RENESAS_TPU=y
|
||||
# CONFIG_DNOTIFY is not set
|
||||
CONFIG_MSDOS_FS=y
|
||||
CONFIG_VFAT_FS=y
|
||||
|
|
|
@ -44,17 +44,26 @@ CONFIG_VFP=y
|
|||
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
|
||||
# CONFIG_SUSPEND is not set
|
||||
CONFIG_NET=y
|
||||
CONFIG_PACKET=y
|
||||
CONFIG_UNIX=y
|
||||
CONFIG_INET=y
|
||||
CONFIG_NETWORK_SECMARK=y
|
||||
# CONFIG_WIRELESS is not set
|
||||
CONFIG_NETFILTER=y
|
||||
CONFIG_CFG80211=y
|
||||
CONFIG_MAC80211=y
|
||||
CONFIG_DEVTMPFS=y
|
||||
CONFIG_DEVTMPFS_MOUNT=y
|
||||
# CONFIG_STANDALONE is not set
|
||||
# CONFIG_INPUT_MOUSEDEV is not set
|
||||
# CONFIG_INPUT_KEYBOARD is not set
|
||||
# CONFIG_INPUT_MOUSE is not set
|
||||
# CONFIG_SERIO is not set
|
||||
CONFIG_SCSI=y
|
||||
CONFIG_BLK_DEV_SD=y
|
||||
CONFIG_SCSI_MULTI_LUN=y
|
||||
CONFIG_SCSI_CONSTANTS=y
|
||||
CONFIG_SCSI_SCAN_ASYNC=y
|
||||
CONFIG_NETDEVICES=y
|
||||
CONFIG_USB_USBNET=y
|
||||
CONFIG_USB_NET_SMSC95XX=y
|
||||
CONFIG_ZD1211RW=y
|
||||
CONFIG_INPUT_EVDEV=y
|
||||
# CONFIG_LEGACY_PTYS is not set
|
||||
# CONFIG_DEVKMEM is not set
|
||||
CONFIG_SERIAL_AMBA_PL011=y
|
||||
|
@ -71,15 +80,13 @@ CONFIG_FB=y
|
|||
CONFIG_FB_SIMPLE=y
|
||||
CONFIG_FRAMEBUFFER_CONSOLE=y
|
||||
CONFIG_FRAMEBUFFER_CONSOLE_DETECT_PRIMARY=y
|
||||
# CONFIG_USB_SUPPORT is not set
|
||||
CONFIG_USB=y
|
||||
CONFIG_USB_STORAGE=y
|
||||
CONFIG_MMC=y
|
||||
CONFIG_MMC_SDHCI=y
|
||||
CONFIG_MMC_SDHCI_PLTFM=y
|
||||
CONFIG_MMC_SDHCI_BCM2835=y
|
||||
CONFIG_NEW_LEDS=y
|
||||
CONFIG_LEDS_CLASS=y
|
||||
CONFIG_LEDS_GPIO=y
|
||||
CONFIG_LEDS_TRIGGERS=y
|
||||
CONFIG_LEDS_TRIGGER_TIMER=y
|
||||
CONFIG_LEDS_TRIGGER_ONESHOT=y
|
||||
CONFIG_LEDS_TRIGGER_HEARTBEAT=y
|
||||
|
@ -88,6 +95,8 @@ CONFIG_LEDS_TRIGGER_GPIO=y
|
|||
CONFIG_LEDS_TRIGGER_DEFAULT_ON=y
|
||||
CONFIG_LEDS_TRIGGER_TRANSIENT=y
|
||||
CONFIG_LEDS_TRIGGER_CAMERA=y
|
||||
CONFIG_STAGING=y
|
||||
CONFIG_USB_DWC2=y
|
||||
# CONFIG_IOMMU_SUPPORT is not set
|
||||
CONFIG_EXT2_FS=y
|
||||
CONFIG_EXT2_FS_XATTR=y
|
||||
|
@ -109,20 +118,20 @@ CONFIG_NLS_ASCII=y
|
|||
CONFIG_NLS_ISO8859_1=y
|
||||
CONFIG_NLS_UTF8=y
|
||||
CONFIG_PRINTK_TIME=y
|
||||
CONFIG_BOOT_PRINTK_DELAY=y
|
||||
CONFIG_DYNAMIC_DEBUG=y
|
||||
CONFIG_DEBUG_INFO=y
|
||||
# CONFIG_ENABLE_WARN_DEPRECATED is not set
|
||||
# CONFIG_ENABLE_MUST_CHECK is not set
|
||||
CONFIG_UNUSED_SYMBOLS=y
|
||||
CONFIG_LOCKUP_DETECTOR=y
|
||||
CONFIG_DEBUG_INFO=y
|
||||
CONFIG_DEBUG_MEMORY_INIT=y
|
||||
CONFIG_BOOT_PRINTK_DELAY=y
|
||||
CONFIG_LOCKUP_DETECTOR=y
|
||||
CONFIG_SCHED_TRACER=y
|
||||
CONFIG_STACK_TRACER=y
|
||||
CONFIG_FUNCTION_PROFILER=y
|
||||
CONFIG_DYNAMIC_DEBUG=y
|
||||
CONFIG_TEST_KSTRTOX=y
|
||||
CONFIG_KGDB=y
|
||||
CONFIG_KGDB_KDB=y
|
||||
CONFIG_TEST_KSTRTOX=y
|
||||
CONFIG_STRICT_DEVMEM=y
|
||||
CONFIG_DEBUG_LL=y
|
||||
CONFIG_EARLY_PRINTK=y
|
||||
|
|
|
@ -27,12 +27,12 @@ CONFIG_HIGHMEM=y
|
|||
CONFIG_ZBOOT_ROM_TEXT=0x0
|
||||
CONFIG_ZBOOT_ROM_BSS=0x0
|
||||
CONFIG_ARM_APPENDED_DTB=y
|
||||
CONFIG_CMDLINE="console=ttySC0,115200 ignore_loglevel root=/dev/nfs ip=dhcp"
|
||||
CONFIG_CMDLINE_FORCE=y
|
||||
CONFIG_VFP=y
|
||||
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
|
||||
# CONFIG_SUSPEND is not set
|
||||
CONFIG_PM_RUNTIME=y
|
||||
CONFIG_NET=y
|
||||
CONFIG_PACKET=y
|
||||
CONFIG_UNIX=y
|
||||
CONFIG_INET=y
|
||||
CONFIG_IP_PNP=y
|
||||
|
@ -44,8 +44,6 @@ CONFIG_IP_PNP_DHCP=y
|
|||
# CONFIG_INET_DIAG is not set
|
||||
# CONFIG_IPV6 is not set
|
||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||
CONFIG_DEVTMPFS=y
|
||||
CONFIG_DEVTMPFS_MOUNT=y
|
||||
# CONFIG_STANDALONE is not set
|
||||
# CONFIG_PREVENT_FIRMWARE_BUILD is not set
|
||||
# CONFIG_FW_LOADER is not set
|
||||
|
@ -82,6 +80,7 @@ CONFIG_SERIAL_SH_SCI_CONSOLE=y
|
|||
# CONFIG_HWMON is not set
|
||||
CONFIG_I2C=y
|
||||
CONFIG_I2C_RCAR=y
|
||||
CONFIG_REGULATOR=y
|
||||
CONFIG_MEDIA_SUPPORT=y
|
||||
CONFIG_MEDIA_CAMERA_SUPPORT=y
|
||||
CONFIG_V4L_PLATFORM_DRIVERS=y
|
||||
|
@ -108,11 +107,12 @@ CONFIG_MMC_SDHI=y
|
|||
CONFIG_MMC_SH_MMCIF=y
|
||||
CONFIG_RTC_CLASS=y
|
||||
CONFIG_RTC_DRV_RX8581=y
|
||||
CONFIG_DMADEVICES=y
|
||||
CONFIG_RCAR_HPB_DMAE=y
|
||||
CONFIG_UIO=y
|
||||
CONFIG_UIO_PDRV_GENIRQ=y
|
||||
# CONFIG_IOMMU_SUPPORT is not set
|
||||
# CONFIG_DNOTIFY is not set
|
||||
# CONFIG_INOTIFY_USER is not set
|
||||
CONFIG_TMPFS=y
|
||||
# CONFIG_MISC_FILESYSTEMS is not set
|
||||
CONFIG_NFS_FS=y
|
||||
|
|
|
@ -13,7 +13,7 @@ CONFIG_S3C24XX_PWM=y
|
|||
CONFIG_ARCH_EXYNOS5=y
|
||||
CONFIG_MACH_EXYNOS4_DT=y
|
||||
CONFIG_SMP=y
|
||||
CONFIG_NR_CPUS=2
|
||||
CONFIG_NR_CPUS=8
|
||||
CONFIG_PREEMPT=y
|
||||
CONFIG_AEABI=y
|
||||
CONFIG_HIGHMEM=y
|
||||
|
@ -79,6 +79,7 @@ CONFIG_REGULATOR_FIXED_VOLTAGE=y
|
|||
CONFIG_REGULATOR_GPIO=y
|
||||
CONFIG_REGULATOR_MAX8997=y
|
||||
CONFIG_REGULATOR_MAX77686=y
|
||||
CONFIG_REGULATOR_S2MPS11=y
|
||||
CONFIG_REGULATOR_S5M8767=y
|
||||
CONFIG_REGULATOR_TPS65090=y
|
||||
CONFIG_FB=y
|
||||
|
|
|
@ -0,0 +1,116 @@
|
|||
CONFIG_SYSVIPC=y
|
||||
CONFIG_NO_HZ=y
|
||||
CONFIG_IKCONFIG=y
|
||||
CONFIG_IKCONFIG_PROC=y
|
||||
CONFIG_LOG_BUF_SHIFT=16
|
||||
CONFIG_CC_OPTIMIZE_FOR_SIZE=y
|
||||
CONFIG_SYSCTL_SYSCALL=y
|
||||
CONFIG_EMBEDDED=y
|
||||
CONFIG_PERF_EVENTS=y
|
||||
CONFIG_SLAB=y
|
||||
# CONFIG_LBDAF is not set
|
||||
# CONFIG_BLK_DEV_BSG is not set
|
||||
# CONFIG_IOSCHED_DEADLINE is not set
|
||||
# CONFIG_IOSCHED_CFQ is not set
|
||||
CONFIG_ARCH_SHMOBILE_LEGACY=y
|
||||
CONFIG_ARCH_R7S72100=y
|
||||
CONFIG_MACH_GENMAI=y
|
||||
# CONFIG_SH_TIMER_CMT is not set
|
||||
# CONFIG_SH_TIMER_MTU2 is not set
|
||||
# CONFIG_SH_TIMER_TMU is not set
|
||||
# CONFIG_EM_TIMER_STI is not set
|
||||
CONFIG_ARM_ERRATA_430973=y
|
||||
CONFIG_ARM_ERRATA_458693=y
|
||||
CONFIG_ARM_ERRATA_460075=y
|
||||
CONFIG_ARM_ERRATA_743622=y
|
||||
CONFIG_ARM_ERRATA_754322=y
|
||||
CONFIG_AEABI=y
|
||||
# CONFIG_OABI_COMPAT is not set
|
||||
CONFIG_FORCE_MAX_ZONEORDER=13
|
||||
CONFIG_ZBOOT_ROM_TEXT=0x0
|
||||
CONFIG_ZBOOT_ROM_BSS=0x0
|
||||
CONFIG_ARM_APPENDED_DTB=y
|
||||
CONFIG_KEXEC=y
|
||||
CONFIG_AUTO_ZRELADDR=y
|
||||
CONFIG_VFP=y
|
||||
CONFIG_NEON=y
|
||||
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
|
||||
CONFIG_PM_RUNTIME=y
|
||||
CONFIG_NET=y
|
||||
CONFIG_PACKET=y
|
||||
CONFIG_UNIX=y
|
||||
CONFIG_INET=y
|
||||
CONFIG_IP_PNP=y
|
||||
CONFIG_IP_PNP_DHCP=y
|
||||
# CONFIG_INET_XFRM_MODE_TRANSPORT is not set
|
||||
# CONFIG_INET_XFRM_MODE_TUNNEL is not set
|
||||
# CONFIG_INET_XFRM_MODE_BEET is not set
|
||||
# CONFIG_INET_LRO is not set
|
||||
# CONFIG_INET_DIAG is not set
|
||||
# CONFIG_IPV6 is not set
|
||||
# CONFIG_WIRELESS is not set
|
||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||
CONFIG_NETDEVICES=y
|
||||
# CONFIG_NET_CORE is not set
|
||||
# CONFIG_NET_VENDOR_ARC is not set
|
||||
# CONFIG_NET_CADENCE is not set
|
||||
# CONFIG_NET_VENDOR_BROADCOM is not set
|
||||
# CONFIG_NET_VENDOR_CIRRUS is not set
|
||||
# CONFIG_NET_VENDOR_FARADAY is not set
|
||||
# CONFIG_NET_VENDOR_INTEL is not set
|
||||
# CONFIG_NET_VENDOR_MARVELL is not set
|
||||
# CONFIG_NET_VENDOR_MICREL is not set
|
||||
# CONFIG_NET_VENDOR_NATSEMI is not set
|
||||
CONFIG_SH_ETH=y
|
||||
# CONFIG_NET_VENDOR_SEEQ is not set
|
||||
# CONFIG_NET_VENDOR_SMSC is not set
|
||||
# CONFIG_NET_VENDOR_STMICRO is not set
|
||||
# CONFIG_NET_VENDOR_VIA is not set
|
||||
# CONFIG_NET_VENDOR_WIZNET is not set
|
||||
# CONFIG_WLAN is not set
|
||||
# CONFIG_INPUT_MOUSEDEV_PSAUX is not set
|
||||
CONFIG_INPUT_EVDEV=y
|
||||
# CONFIG_KEYBOARD_ATKBD is not set
|
||||
# CONFIG_INPUT_MOUSE is not set
|
||||
# CONFIG_SERIO is not set
|
||||
# CONFIG_LEGACY_PTYS is not set
|
||||
CONFIG_SERIAL_SH_SCI=y
|
||||
CONFIG_SERIAL_SH_SCI_NR_UARTS=10
|
||||
CONFIG_SERIAL_SH_SCI_CONSOLE=y
|
||||
# CONFIG_HW_RANDOM is not set
|
||||
CONFIG_I2C_SH_MOBILE=y
|
||||
# CONFIG_HWMON is not set
|
||||
CONFIG_THERMAL=y
|
||||
CONFIG_RCAR_THERMAL=y
|
||||
CONFIG_REGULATOR=y
|
||||
CONFIG_REGULATOR_FIXED_VOLTAGE=y
|
||||
CONFIG_DRM=y
|
||||
CONFIG_DRM_RCAR_DU=y
|
||||
# CONFIG_USB_SUPPORT is not set
|
||||
CONFIG_MMC=y
|
||||
CONFIG_MMC_SDHI=y
|
||||
CONFIG_MMC_SH_MMCIF=y
|
||||
CONFIG_NEW_LEDS=y
|
||||
CONFIG_LEDS_CLASS=y
|
||||
CONFIG_RTC_CLASS=y
|
||||
CONFIG_DMADEVICES=y
|
||||
CONFIG_SH_DMAE=y
|
||||
# CONFIG_IOMMU_SUPPORT is not set
|
||||
# CONFIG_DNOTIFY is not set
|
||||
CONFIG_MSDOS_FS=y
|
||||
CONFIG_VFAT_FS=y
|
||||
CONFIG_TMPFS=y
|
||||
CONFIG_CONFIGFS_FS=y
|
||||
# CONFIG_MISC_FILESYSTEMS is not set
|
||||
CONFIG_NFS_FS=y
|
||||
CONFIG_NFS_V3_ACL=y
|
||||
CONFIG_NFS_V4=y
|
||||
CONFIG_NFS_V4_1=y
|
||||
CONFIG_ROOT_NFS=y
|
||||
CONFIG_NLS_CODEPAGE_437=y
|
||||
CONFIG_NLS_ISO8859_1=y
|
||||
# CONFIG_ENABLE_WARN_DEPRECATED is not set
|
||||
# CONFIG_ENABLE_MUST_CHECK is not set
|
||||
# CONFIG_ARM_UNWIND is not set
|
||||
# CONFIG_CRYPTO_ANSI_CPRNG is not set
|
||||
# CONFIG_CRYPTO_HW is not set
|
|
@ -27,6 +27,7 @@ CONFIG_PCI_MVEBU=y
|
|||
CONFIG_PREEMPT=y
|
||||
CONFIG_AEABI=y
|
||||
# CONFIG_OABI_COMPAT is not set
|
||||
CONFIG_HIGHMEM=y
|
||||
CONFIG_ZBOOT_ROM_TEXT=0x0
|
||||
CONFIG_ZBOOT_ROM_BSS=0x0
|
||||
CONFIG_CPU_FREQ=y
|
||||
|
|
|
@ -29,7 +29,29 @@ CONFIG_VFP=y
|
|||
CONFIG_NEON=y
|
||||
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
|
||||
CONFIG_PM_RUNTIME=y
|
||||
CONFIG_NET=y
|
||||
CONFIG_PACKET=y
|
||||
CONFIG_UNIX=y
|
||||
CONFIG_INET=y
|
||||
CONFIG_IP_PNP=y
|
||||
CONFIG_IP_PNP_DHCP=y
|
||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||
CONFIG_NETDEVICES=y
|
||||
# CONFIG_NET_VENDOR_ARC is not set
|
||||
# CONFIG_NET_CADENCE is not set
|
||||
# CONFIG_NET_VENDOR_BROADCOM is not set
|
||||
# CONFIG_NET_VENDOR_CIRRUS is not set
|
||||
# CONFIG_NET_VENDOR_FARADAY is not set
|
||||
# CONFIG_NET_VENDOR_INTEL is not set
|
||||
# CONFIG_NET_VENDOR_MARVELL is not set
|
||||
# CONFIG_NET_VENDOR_MICREL is not set
|
||||
# CONFIG_NET_VENDOR_NATSEMI is not set
|
||||
CONFIG_SH_ETH=y
|
||||
# CONFIG_NET_VENDOR_SEEQ is not set
|
||||
# CONFIG_NET_VENDOR_SMSC is not set
|
||||
# CONFIG_NET_VENDOR_STMICRO is not set
|
||||
# CONFIG_NET_VENDOR_VIA is not set
|
||||
# CONFIG_NET_VENDOR_WIZNET is not set
|
||||
# CONFIG_INPUT_MOUSEDEV_PSAUX is not set
|
||||
# CONFIG_INPUT_MOUSE is not set
|
||||
# CONFIG_LEGACY_PTYS is not set
|
||||
|
@ -45,10 +67,11 @@ CONFIG_NEW_LEDS=y
|
|||
CONFIG_LEDS_CLASS=y
|
||||
# CONFIG_IOMMU_SUPPORT is not set
|
||||
# CONFIG_DNOTIFY is not set
|
||||
# CONFIG_INOTIFY_USER is not set
|
||||
CONFIG_TMPFS=y
|
||||
CONFIG_CONFIGFS_FS=y
|
||||
# CONFIG_MISC_FILESYSTEMS is not set
|
||||
CONFIG_NFS_FS=y
|
||||
CONFIG_ROOT_NFS=y
|
||||
# CONFIG_ENABLE_WARN_DEPRECATED is not set
|
||||
# CONFIG_ENABLE_MUST_CHECK is not set
|
||||
# CONFIG_ARM_UNWIND is not set
|
||||
|
|
|
@ -32,6 +32,7 @@ CONFIG_FORCE_MAX_ZONEORDER=13
|
|||
CONFIG_ZBOOT_ROM_TEXT=0x0
|
||||
CONFIG_ZBOOT_ROM_BSS=0x0
|
||||
CONFIG_ARM_APPENDED_DTB=y
|
||||
CONFIG_AUTO_ZRELADDR=y
|
||||
CONFIG_VFP=y
|
||||
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
|
||||
CONFIG_PM_RUNTIME=y
|
||||
|
|
|
@ -80,7 +80,7 @@ CONFIG_SERIAL_SH_SCI_CONSOLE=y
|
|||
# CONFIG_HW_RANDOM is not set
|
||||
CONFIG_I2C=y
|
||||
CONFIG_I2C_GPIO=y
|
||||
CONFIG_I2C_SH_MOBILE=y
|
||||
CONFIG_I2C_RCAR=y
|
||||
CONFIG_GPIO_SH_PFC=y
|
||||
CONFIG_GPIOLIB=y
|
||||
CONFIG_GPIO_RCAR=y
|
||||
|
@ -89,6 +89,7 @@ CONFIG_THERMAL=y
|
|||
CONFIG_RCAR_THERMAL=y
|
||||
CONFIG_REGULATOR=y
|
||||
CONFIG_REGULATOR_FIXED_VOLTAGE=y
|
||||
CONFIG_REGULATOR_GPIO=y
|
||||
CONFIG_DRM=y
|
||||
CONFIG_DRM_RCAR_DU=y
|
||||
# CONFIG_USB_SUPPORT is not set
|
||||
|
|
|
@ -30,12 +30,12 @@ CONFIG_HIGHMEM=y
|
|||
CONFIG_ZBOOT_ROM_TEXT=0x0
|
||||
CONFIG_ZBOOT_ROM_BSS=0x0
|
||||
CONFIG_ARM_APPENDED_DTB=y
|
||||
CONFIG_CMDLINE="console=ttySC2,115200 earlyprintk=sh-sci.2,115200 ignore_loglevel root=/dev/nfs ip=on"
|
||||
CONFIG_CMDLINE_FORCE=y
|
||||
CONFIG_VFP=y
|
||||
CONFIG_KEXEC=y
|
||||
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
|
||||
CONFIG_PM_RUNTIME=y
|
||||
CONFIG_NET=y
|
||||
CONFIG_PACKET=y
|
||||
CONFIG_UNIX=y
|
||||
CONFIG_INET=y
|
||||
CONFIG_IP_PNP=y
|
||||
|
@ -43,8 +43,6 @@ CONFIG_IP_PNP_DHCP=y
|
|||
# CONFIG_IPV6 is not set
|
||||
# CONFIG_WIRELESS is not set
|
||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||
CONFIG_DEVTMPFS=y
|
||||
CONFIG_DEVTMPFS_MOUNT=y
|
||||
# CONFIG_STANDALONE is not set
|
||||
# CONFIG_PREVENT_FIRMWARE_BUILD is not set
|
||||
# CONFIG_FW_LOADER is not set
|
||||
|
@ -61,7 +59,6 @@ CONFIG_NETDEVICES=y
|
|||
# CONFIG_NET_VENDOR_MICREL is not set
|
||||
# CONFIG_NET_VENDOR_NATSEMI is not set
|
||||
# CONFIG_NET_VENDOR_SEEQ is not set
|
||||
CONFIG_SMC911X=y
|
||||
CONFIG_SMSC911X=y
|
||||
# CONFIG_NET_VENDOR_STMICRO is not set
|
||||
# CONFIG_WLAN is not set
|
||||
|
@ -106,11 +103,12 @@ CONFIG_USB_STORAGE=y
|
|||
CONFIG_NEW_LEDS=y
|
||||
CONFIG_LEDS_CLASS=y
|
||||
CONFIG_LEDS_GPIO=y
|
||||
CONFIG_DMADEVICES=y
|
||||
CONFIG_RCAR_HPB_DMAE=y
|
||||
CONFIG_UIO=y
|
||||
CONFIG_UIO_PDRV_GENIRQ=y
|
||||
# CONFIG_IOMMU_SUPPORT is not set
|
||||
# CONFIG_DNOTIFY is not set
|
||||
# CONFIG_INOTIFY_USER is not set
|
||||
CONFIG_TMPFS=y
|
||||
# CONFIG_MISC_FILESYSTEMS is not set
|
||||
CONFIG_NFS_FS=y
|
||||
|
|
|
@ -20,6 +20,7 @@ CONFIG_PARTITION_ADVANCED=y
|
|||
CONFIG_ARCH_MSM_DT=y
|
||||
CONFIG_ARCH_MSM8X60=y
|
||||
CONFIG_ARCH_MSM8960=y
|
||||
CONFIG_ARCH_MSM8974=y
|
||||
CONFIG_SMP=y
|
||||
CONFIG_PREEMPT=y
|
||||
CONFIG_AEABI=y
|
||||
|
@ -86,6 +87,8 @@ CONFIG_SPI=y
|
|||
CONFIG_DEBUG_GPIO=y
|
||||
CONFIG_GPIO_SYSFS=y
|
||||
CONFIG_POWER_SUPPLY=y
|
||||
CONFIG_POWER_RESET=y
|
||||
CONFIG_POWER_RESET_MSM=y
|
||||
CONFIG_THERMAL=y
|
||||
CONFIG_REGULATOR=y
|
||||
CONFIG_MEDIA_SUPPORT=y
|
||||
|
|
|
@ -72,6 +72,7 @@ CONFIG_NET_CALXEDA_XGMAC=y
|
|||
CONFIG_KS8851=y
|
||||
CONFIG_SMSC911X=y
|
||||
CONFIG_STMMAC_ETH=y
|
||||
CONFIG_ICPLUS_PHY=y
|
||||
CONFIG_MDIO_SUN4I=y
|
||||
CONFIG_TI_CPSW=y
|
||||
CONFIG_KEYBOARD_SPEAR=y
|
||||
|
@ -95,6 +96,8 @@ CONFIG_SERIAL_XILINX_PS_UART=y
|
|||
CONFIG_SERIAL_XILINX_PS_UART_CONSOLE=y
|
||||
CONFIG_SERIAL_FSL_LPUART=y
|
||||
CONFIG_SERIAL_FSL_LPUART_CONSOLE=y
|
||||
CONFIG_SERIAL_ST_ASC=y
|
||||
CONFIG_SERIAL_ST_ASC_CONSOLE=y
|
||||
CONFIG_I2C_DESIGNWARE_PLATFORM=y
|
||||
CONFIG_I2C_SIRF=y
|
||||
CONFIG_I2C_TEGRA=y
|
||||
|
|
|
@ -55,6 +55,8 @@ CONFIG_MTD_CFI_INTELEXT=y
|
|||
CONFIG_MTD_CFI_AMDSTD=y
|
||||
CONFIG_MTD_CFI_STAA=y
|
||||
CONFIG_MTD_PHYSMAP_OF=y
|
||||
CONFIG_MTD_NAND=y
|
||||
CONFIG_MTD_NAND_PXA3xx=y
|
||||
CONFIG_SERIAL_8250_DW=y
|
||||
CONFIG_GPIOLIB=y
|
||||
CONFIG_GPIO_SYSFS=y
|
||||
|
@ -69,6 +71,7 @@ CONFIG_USB_XHCI_HCD=y
|
|||
CONFIG_MMC=y
|
||||
CONFIG_MMC_MVSDIO=y
|
||||
CONFIG_NEW_LEDS=y
|
||||
CONFIG_LEDS_GPIO=y
|
||||
CONFIG_LEDS_CLASS=m
|
||||
CONFIG_LEDS_TRIGGERS=y
|
||||
CONFIG_LEDS_TRIGGER_TIMER=y
|
||||
|
|
|
@ -36,8 +36,8 @@ CONFIG_PCIEPORTBUS=y
|
|||
CONFIG_SMP=y
|
||||
CONFIG_PREEMPT=y
|
||||
CONFIG_AEABI=y
|
||||
# CONFIG_OABI_COMPAT is not set
|
||||
CONFIG_HIGHMEM=y
|
||||
CONFIG_CMA=y
|
||||
CONFIG_ZBOOT_ROM_TEXT=0x0
|
||||
CONFIG_ZBOOT_ROM_BSS=0x0
|
||||
CONFIG_KEXEC=y
|
||||
|
@ -63,7 +63,6 @@ CONFIG_INET_ESP=y
|
|||
# CONFIG_INET_LRO is not set
|
||||
# CONFIG_INET_DIAG is not set
|
||||
CONFIG_IPV6=y
|
||||
CONFIG_IPV6_PRIVACY=y
|
||||
CONFIG_IPV6_ROUTER_PREF=y
|
||||
CONFIG_IPV6_OPTIMISTIC_DAD=y
|
||||
CONFIG_INET6_AH=y
|
||||
|
@ -85,7 +84,6 @@ CONFIG_RFKILL_GPIO=y
|
|||
CONFIG_DEVTMPFS=y
|
||||
CONFIG_DEVTMPFS_MOUNT=y
|
||||
# CONFIG_FIRMWARE_IN_KERNEL is not set
|
||||
CONFIG_CMA=y
|
||||
CONFIG_DMA_CMA=y
|
||||
CONFIG_MTD=y
|
||||
CONFIG_MTD_M25P80=y
|
||||
|
@ -114,6 +112,7 @@ CONFIG_RT2800USB=m
|
|||
CONFIG_INPUT_EVDEV=y
|
||||
CONFIG_KEYBOARD_GPIO=y
|
||||
CONFIG_KEYBOARD_TEGRA=y
|
||||
CONFIG_KEYBOARD_CROS_EC=y
|
||||
CONFIG_MOUSE_PS2_ELANTECH=y
|
||||
CONFIG_INPUT_MISC=y
|
||||
CONFIG_INPUT_MPU3050=y
|
||||
|
@ -132,6 +131,7 @@ CONFIG_SPI=y
|
|||
CONFIG_SPI_TEGRA114=y
|
||||
CONFIG_SPI_TEGRA20_SFLASH=y
|
||||
CONFIG_SPI_TEGRA20_SLINK=y
|
||||
CONFIG_PINCTRL_AS3722=y
|
||||
CONFIG_PINCTRL_PALMAS=y
|
||||
CONFIG_GPIO_PCA953X_IRQ=y
|
||||
CONFIG_GPIO_PALMAS=y
|
||||
|
@ -143,6 +143,9 @@ CONFIG_CHARGER_TPS65090=y
|
|||
CONFIG_POWER_RESET=y
|
||||
CONFIG_POWER_RESET_GPIO=y
|
||||
CONFIG_SENSORS_LM90=y
|
||||
CONFIG_MFD_AS3722=y
|
||||
CONFIG_MFD_CROS_EC=y
|
||||
CONFIG_MFD_CROS_EC_SPI=y
|
||||
CONFIG_MFD_MAX8907=y
|
||||
CONFIG_MFD_PALMAS=y
|
||||
CONFIG_MFD_TPS65090=y
|
||||
|
@ -151,6 +154,7 @@ CONFIG_MFD_TPS65910=y
|
|||
CONFIG_REGULATOR=y
|
||||
CONFIG_REGULATOR_FIXED_VOLTAGE=y
|
||||
CONFIG_REGULATOR_VIRTUAL_CONSUMER=y
|
||||
CONFIG_REGULATOR_AS3722=y
|
||||
CONFIG_REGULATOR_GPIO=y
|
||||
CONFIG_REGULATOR_MAX8907=y
|
||||
CONFIG_REGULATOR_PALMAS=y
|
||||
|
@ -164,7 +168,8 @@ CONFIG_MEDIA_CAMERA_SUPPORT=y
|
|||
CONFIG_MEDIA_USB_SUPPORT=y
|
||||
CONFIG_USB_VIDEO_CLASS=m
|
||||
CONFIG_DRM=y
|
||||
CONFIG_TEGRA_HOST1X=y
|
||||
CONFIG_DRM_PANEL=y
|
||||
CONFIG_DRM_PANEL_SIMPLE=y
|
||||
CONFIG_DRM_TEGRA=y
|
||||
CONFIG_BACKLIGHT_LCD_SUPPORT=y
|
||||
# CONFIG_LCD_CLASS_DEVICE is not set
|
||||
|
@ -187,6 +192,7 @@ CONFIG_SND_SOC_TEGRA_WM8753=y
|
|||
CONFIG_SND_SOC_TEGRA_WM8903=y
|
||||
CONFIG_SND_SOC_TEGRA_TRIMSLICE=y
|
||||
CONFIG_SND_SOC_TEGRA_ALC5632=y
|
||||
CONFIG_SND_SOC_TEGRA_MAX98090=y
|
||||
CONFIG_USB=y
|
||||
CONFIG_USB_XHCI_HCD=y
|
||||
CONFIG_USB_EHCI_HCD=y
|
||||
|
@ -211,6 +217,7 @@ CONFIG_LEDS_TRIGGER_DEFAULT_ON=y
|
|||
CONFIG_LEDS_TRIGGER_TRANSIENT=y
|
||||
CONFIG_LEDS_TRIGGER_CAMERA=y
|
||||
CONFIG_RTC_CLASS=y
|
||||
CONFIG_RTC_DRV_AS3722=y
|
||||
CONFIG_RTC_DRV_MAX8907=y
|
||||
CONFIG_RTC_DRV_PALMAS=y
|
||||
CONFIG_RTC_DRV_TPS6586X=y
|
||||
|
@ -256,16 +263,15 @@ CONFIG_ROOT_NFS=y
|
|||
CONFIG_NLS_CODEPAGE_437=y
|
||||
CONFIG_NLS_ISO8859_1=y
|
||||
CONFIG_PRINTK_TIME=y
|
||||
CONFIG_DEBUG_INFO=y
|
||||
CONFIG_MAGIC_SYSRQ=y
|
||||
CONFIG_DEBUG_FS=y
|
||||
CONFIG_DEBUG_SLAB=y
|
||||
CONFIG_DEBUG_VM=y
|
||||
CONFIG_DETECT_HUNG_TASK=y
|
||||
CONFIG_SCHEDSTATS=y
|
||||
CONFIG_TIMER_STATS=y
|
||||
CONFIG_DEBUG_SLAB=y
|
||||
# CONFIG_DEBUG_PREEMPT is not set
|
||||
CONFIG_DEBUG_MUTEXES=y
|
||||
CONFIG_DEBUG_INFO=y
|
||||
CONFIG_DEBUG_VM=y
|
||||
CONFIG_DEBUG_SG=y
|
||||
CONFIG_DEBUG_LL=y
|
||||
CONFIG_EARLY_PRINTK=y
|
||||
|
|
|
@ -26,7 +26,16 @@ static const char * const msm_dt_match[] __initconst = {
|
|||
NULL
|
||||
};
|
||||
|
||||
static const char * const apq8074_dt_match[] __initconst = {
|
||||
"qcom,apq8074-dragonboard",
|
||||
NULL
|
||||
};
|
||||
|
||||
DT_MACHINE_START(MSM_DT, "Qualcomm MSM (Flattened Device Tree)")
|
||||
.smp = smp_ops(msm_smp_ops),
|
||||
.dt_compat = msm_dt_match,
|
||||
MACHINE_END
|
||||
|
||||
DT_MACHINE_START(APQ_DT, "Qualcomm MSM (Flattened Device Tree)")
|
||||
.dt_compat = apq8074_dt_match,
|
||||
MACHINE_END
|
||||
|
|
|
@ -192,19 +192,6 @@ config MACH_OMAP2_TUSB6010
|
|||
depends on ARCH_OMAP2 && SOC_OMAP2420
|
||||
default y if MACH_NOKIA_N8X0
|
||||
|
||||
config MACH_OMAP_H4
|
||||
bool "OMAP 2420 H4 board"
|
||||
depends on SOC_OMAP2420
|
||||
default y
|
||||
select OMAP_DEBUG_DEVICES
|
||||
select OMAP_PACKAGE_ZAF
|
||||
|
||||
config MACH_OMAP_2430SDP
|
||||
bool "OMAP 2430 SDP board"
|
||||
depends on SOC_OMAP2430
|
||||
default y
|
||||
select OMAP_PACKAGE_ZAC
|
||||
|
||||
config MACH_OMAP3_BEAGLE
|
||||
bool "OMAP3 BEAGLE board"
|
||||
depends on ARCH_OMAP3
|
||||
|
|
|
@ -66,8 +66,6 @@ obj-$(CONFIG_SOC_OMAP5) += omap4-restart.o
|
|||
obj-$(CONFIG_SOC_DRA7XX) += omap4-restart.o
|
||||
|
||||
# Pin multiplexing
|
||||
obj-$(CONFIG_SOC_OMAP2420) += mux2420.o
|
||||
obj-$(CONFIG_SOC_OMAP2430) += mux2430.o
|
||||
obj-$(CONFIG_ARCH_OMAP3) += mux34xx.o
|
||||
|
||||
# SMS/SDRC
|
||||
|
@ -237,8 +235,6 @@ obj-$(CONFIG_SOC_OMAP2420) += msdi.o
|
|||
|
||||
# Specific board support
|
||||
obj-$(CONFIG_MACH_OMAP_GENERIC) += board-generic.o pdata-quirks.o
|
||||
obj-$(CONFIG_MACH_OMAP_H4) += board-h4.o
|
||||
obj-$(CONFIG_MACH_OMAP_2430SDP) += board-2430sdp.o
|
||||
obj-$(CONFIG_MACH_OMAP3_BEAGLE) += board-omap3beagle.o
|
||||
obj-$(CONFIG_MACH_DEVKIT8000) += board-devkit8000.o
|
||||
obj-$(CONFIG_MACH_OMAP_LDP) += board-ldp.o
|
||||
|
|
|
@ -1,273 +0,0 @@
|
|||
/*
|
||||
* linux/arch/arm/mach-omap2/board-2430sdp.c
|
||||
*
|
||||
* Copyright (C) 2006 Texas Instruments
|
||||
*
|
||||
* Modified from mach-omap2/board-generic.c
|
||||
*
|
||||
* Initial Code : Based on a patch from Komal Shah and Richard Woodruff
|
||||
* Updated the Code for 2430 SDP : Syed Mohammed Khasim
|
||||
*
|
||||
* 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 <linux/kernel.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/mmc/host.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/i2c/twl.h>
|
||||
#include <linux/regulator/machine.h>
|
||||
#include <linux/err.h>
|
||||
#include <linux/clk.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/usb/phy.h>
|
||||
|
||||
#include <asm/mach-types.h>
|
||||
#include <asm/mach/arch.h>
|
||||
#include <asm/mach/map.h>
|
||||
|
||||
#include "common.h"
|
||||
#include "gpmc.h"
|
||||
#include "gpmc-smc91x.h"
|
||||
|
||||
#include <video/omapdss.h>
|
||||
#include <video/omap-panel-data.h>
|
||||
|
||||
#include "mux.h"
|
||||
#include "hsmmc.h"
|
||||
#include "common-board-devices.h"
|
||||
|
||||
#define SDP2430_CS0_BASE 0x04000000
|
||||
#define SECONDARY_LCD_GPIO 147
|
||||
|
||||
static struct mtd_partition sdp2430_partitions[] = {
|
||||
/* bootloader (U-Boot, etc) in first sector */
|
||||
{
|
||||
.name = "bootloader",
|
||||
.offset = 0,
|
||||
.size = SZ_256K,
|
||||
.mask_flags = MTD_WRITEABLE, /* force read-only */
|
||||
},
|
||||
/* bootloader params in the next sector */
|
||||
{
|
||||
.name = "params",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = SZ_128K,
|
||||
.mask_flags = 0,
|
||||
},
|
||||
/* kernel */
|
||||
{
|
||||
.name = "kernel",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = SZ_2M,
|
||||
.mask_flags = 0
|
||||
},
|
||||
/* file system */
|
||||
{
|
||||
.name = "filesystem",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = MTDPART_SIZ_FULL,
|
||||
.mask_flags = 0
|
||||
}
|
||||
};
|
||||
|
||||
static struct physmap_flash_data sdp2430_flash_data = {
|
||||
.width = 2,
|
||||
.parts = sdp2430_partitions,
|
||||
.nr_parts = ARRAY_SIZE(sdp2430_partitions),
|
||||
};
|
||||
|
||||
static struct resource sdp2430_flash_resource = {
|
||||
.start = SDP2430_CS0_BASE,
|
||||
.end = SDP2430_CS0_BASE + SZ_64M - 1,
|
||||
.flags = IORESOURCE_MEM,
|
||||
};
|
||||
|
||||
static struct platform_device sdp2430_flash_device = {
|
||||
.name = "physmap-flash",
|
||||
.id = 0,
|
||||
.dev = {
|
||||
.platform_data = &sdp2430_flash_data,
|
||||
},
|
||||
.num_resources = 1,
|
||||
.resource = &sdp2430_flash_resource,
|
||||
};
|
||||
|
||||
/* LCD */
|
||||
#define SDP2430_LCD_PANEL_BACKLIGHT_GPIO 91
|
||||
#define SDP2430_LCD_PANEL_ENABLE_GPIO 154
|
||||
|
||||
static const struct display_timing sdp2430_lcd_videomode = {
|
||||
.pixelclock = { 0, 5400000, 0 },
|
||||
|
||||
.hactive = { 0, 240, 0 },
|
||||
.hfront_porch = { 0, 3, 0 },
|
||||
.hback_porch = { 0, 39, 0 },
|
||||
.hsync_len = { 0, 3, 0 },
|
||||
|
||||
.vactive = { 0, 320, 0 },
|
||||
.vfront_porch = { 0, 2, 0 },
|
||||
.vback_porch = { 0, 7, 0 },
|
||||
.vsync_len = { 0, 1, 0 },
|
||||
|
||||
.flags = DISPLAY_FLAGS_HSYNC_LOW | DISPLAY_FLAGS_VSYNC_LOW |
|
||||
DISPLAY_FLAGS_DE_HIGH | DISPLAY_FLAGS_PIXDATA_POSEDGE,
|
||||
};
|
||||
|
||||
static struct panel_dpi_platform_data sdp2430_lcd_pdata = {
|
||||
.name = "lcd",
|
||||
.source = "dpi.0",
|
||||
|
||||
.data_lines = 16,
|
||||
|
||||
.display_timing = &sdp2430_lcd_videomode,
|
||||
|
||||
.enable_gpio = SDP2430_LCD_PANEL_ENABLE_GPIO,
|
||||
.backlight_gpio = SDP2430_LCD_PANEL_BACKLIGHT_GPIO,
|
||||
};
|
||||
|
||||
static struct platform_device sdp2430_lcd_device = {
|
||||
.name = "panel-dpi",
|
||||
.id = 0,
|
||||
.dev.platform_data = &sdp2430_lcd_pdata,
|
||||
};
|
||||
|
||||
static struct omap_dss_board_info sdp2430_dss_data = {
|
||||
.default_display_name = "lcd",
|
||||
};
|
||||
|
||||
static struct platform_device *sdp2430_devices[] __initdata = {
|
||||
&sdp2430_flash_device,
|
||||
&sdp2430_lcd_device,
|
||||
};
|
||||
|
||||
#if IS_ENABLED(CONFIG_SMC91X)
|
||||
|
||||
static struct omap_smc91x_platform_data board_smc91x_data = {
|
||||
.cs = 5,
|
||||
.gpio_irq = 149,
|
||||
.flags = GPMC_MUX_ADD_DATA | GPMC_TIMINGS_SMC91C96 |
|
||||
IORESOURCE_IRQ_LOWLEVEL,
|
||||
|
||||
};
|
||||
|
||||
static void __init board_smc91x_init(void)
|
||||
{
|
||||
omap_mux_init_gpio(149, OMAP_PIN_INPUT);
|
||||
gpmc_smc91x_init(&board_smc91x_data);
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
static inline void board_smc91x_init(void)
|
||||
{
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
static struct regulator_consumer_supply sdp2430_vmmc1_supplies[] = {
|
||||
REGULATOR_SUPPLY("vmmc", "omap_hsmmc.0"),
|
||||
};
|
||||
|
||||
/* VMMC1 for OMAP VDD_MMC1 (i/o) and MMC1 card */
|
||||
static struct regulator_init_data sdp2430_vmmc1 = {
|
||||
.constraints = {
|
||||
.min_uV = 1850000,
|
||||
.max_uV = 3150000,
|
||||
.valid_modes_mask = REGULATOR_MODE_NORMAL
|
||||
| REGULATOR_MODE_STANDBY,
|
||||
.valid_ops_mask = REGULATOR_CHANGE_VOLTAGE
|
||||
| REGULATOR_CHANGE_MODE
|
||||
| REGULATOR_CHANGE_STATUS,
|
||||
},
|
||||
.num_consumer_supplies = ARRAY_SIZE(sdp2430_vmmc1_supplies),
|
||||
.consumer_supplies = &sdp2430_vmmc1_supplies[0],
|
||||
};
|
||||
|
||||
static struct twl4030_gpio_platform_data sdp2430_gpio_data = {
|
||||
};
|
||||
|
||||
static struct twl4030_platform_data sdp2430_twldata = {
|
||||
/* platform_data for children goes here */
|
||||
.gpio = &sdp2430_gpio_data,
|
||||
.vmmc1 = &sdp2430_vmmc1,
|
||||
};
|
||||
|
||||
static struct i2c_board_info __initdata sdp2430_i2c1_boardinfo[] = {
|
||||
{
|
||||
I2C_BOARD_INFO("isp1301_omap", 0x2D),
|
||||
.flags = I2C_CLIENT_WAKE,
|
||||
},
|
||||
};
|
||||
|
||||
static int __init omap2430_i2c_init(void)
|
||||
{
|
||||
sdp2430_i2c1_boardinfo[0].irq = gpio_to_irq(78);
|
||||
omap_register_i2c_bus(1, 100, sdp2430_i2c1_boardinfo,
|
||||
ARRAY_SIZE(sdp2430_i2c1_boardinfo));
|
||||
omap_pmic_init(2, 100, "twl4030", 7 + OMAP_INTC_START,
|
||||
&sdp2430_twldata);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct omap2_hsmmc_info mmc[] __initdata = {
|
||||
{
|
||||
.mmc = 1,
|
||||
.caps = MMC_CAP_4_BIT_DATA,
|
||||
.gpio_cd = -EINVAL,
|
||||
.gpio_wp = -EINVAL,
|
||||
.ext_clock = 1,
|
||||
},
|
||||
{} /* Terminator */
|
||||
};
|
||||
|
||||
#ifdef CONFIG_OMAP_MUX
|
||||
static struct omap_board_mux board_mux[] __initdata = {
|
||||
{ .reg_offset = OMAP_MUX_TERMINATOR },
|
||||
};
|
||||
#endif
|
||||
|
||||
static void __init omap_2430sdp_init(void)
|
||||
{
|
||||
omap2430_mux_init(board_mux, OMAP_PACKAGE_ZAC);
|
||||
|
||||
omap2430_i2c_init();
|
||||
|
||||
platform_add_devices(sdp2430_devices, ARRAY_SIZE(sdp2430_devices));
|
||||
omap_serial_init();
|
||||
omap_sdrc_init(NULL, NULL);
|
||||
omap_hsmmc_init(mmc);
|
||||
|
||||
omap_mux_init_signal("usb0hs_stp", OMAP_PULL_ENA | OMAP_PULL_UP);
|
||||
usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb");
|
||||
usb_musb_init(NULL);
|
||||
|
||||
board_smc91x_init();
|
||||
|
||||
/* Turn off secondary LCD backlight */
|
||||
gpio_request_one(SECONDARY_LCD_GPIO, GPIOF_OUT_INIT_LOW,
|
||||
"Secondary LCD backlight");
|
||||
|
||||
omap_display_init(&sdp2430_dss_data);
|
||||
}
|
||||
|
||||
MACHINE_START(OMAP_2430SDP, "OMAP2430 sdp2430 board")
|
||||
/* Maintainer: Syed Khasim - Texas Instruments Inc */
|
||||
.atag_offset = 0x100,
|
||||
.reserve = omap_reserve,
|
||||
.map_io = omap243x_map_io,
|
||||
.init_early = omap2430_init_early,
|
||||
.init_irq = omap2_init_irq,
|
||||
.handle_irq = omap2_intc_handle_irq,
|
||||
.init_machine = omap_2430sdp_init,
|
||||
.init_late = omap2430_init_late,
|
||||
.init_time = omap2_sync32k_timer_init,
|
||||
.restart = omap2xxx_restart,
|
||||
MACHINE_END
|
|
@ -1,365 +0,0 @@
|
|||
/*
|
||||
* linux/arch/arm/mach-omap2/board-h4.c
|
||||
*
|
||||
* Copyright (C) 2005 Nokia Corporation
|
||||
* Author: Paul Mundt <paul.mundt@nokia.com>
|
||||
*
|
||||
* Modified from mach-omap/omap1/board-generic.c
|
||||
*
|
||||
* 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 <linux/gpio.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/workqueue.h>
|
||||
#include <linux/i2c.h>
|
||||
#include <linux/platform_data/at24.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/err.h>
|
||||
#include <linux/clk.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/input/matrix_keypad.h>
|
||||
#include <linux/mfd/menelaus.h>
|
||||
#include <linux/omap-dma.h>
|
||||
|
||||
#include <asm/mach-types.h>
|
||||
#include <asm/mach/arch.h>
|
||||
#include <asm/mach/map.h>
|
||||
|
||||
#include <video/omapdss.h>
|
||||
#include <video/omap-panel-data.h>
|
||||
|
||||
#include "common.h"
|
||||
#include "mux.h"
|
||||
#include "control.h"
|
||||
#include "gpmc.h"
|
||||
#include "gpmc-smc91x.h"
|
||||
|
||||
#define H4_FLASH_CS 0
|
||||
|
||||
#if defined(CONFIG_KEYBOARD_MATRIX) || defined(CONFIG_KEYBOARD_MATRIX_MODULE)
|
||||
static const uint32_t board_matrix_keys[] = {
|
||||
KEY(0, 0, KEY_LEFT),
|
||||
KEY(1, 0, KEY_RIGHT),
|
||||
KEY(2, 0, KEY_A),
|
||||
KEY(3, 0, KEY_B),
|
||||
KEY(4, 0, KEY_C),
|
||||
KEY(0, 1, KEY_DOWN),
|
||||
KEY(1, 1, KEY_UP),
|
||||
KEY(2, 1, KEY_E),
|
||||
KEY(3, 1, KEY_F),
|
||||
KEY(4, 1, KEY_G),
|
||||
KEY(0, 2, KEY_ENTER),
|
||||
KEY(1, 2, KEY_I),
|
||||
KEY(2, 2, KEY_J),
|
||||
KEY(3, 2, KEY_K),
|
||||
KEY(4, 2, KEY_3),
|
||||
KEY(0, 3, KEY_M),
|
||||
KEY(1, 3, KEY_N),
|
||||
KEY(2, 3, KEY_O),
|
||||
KEY(3, 3, KEY_P),
|
||||
KEY(4, 3, KEY_Q),
|
||||
KEY(0, 4, KEY_R),
|
||||
KEY(1, 4, KEY_4),
|
||||
KEY(2, 4, KEY_T),
|
||||
KEY(3, 4, KEY_U),
|
||||
KEY(4, 4, KEY_ENTER),
|
||||
KEY(0, 5, KEY_V),
|
||||
KEY(1, 5, KEY_W),
|
||||
KEY(2, 5, KEY_L),
|
||||
KEY(3, 5, KEY_S),
|
||||
KEY(4, 5, KEY_ENTER),
|
||||
};
|
||||
|
||||
static const struct matrix_keymap_data board_keymap_data = {
|
||||
.keymap = board_matrix_keys,
|
||||
.keymap_size = ARRAY_SIZE(board_matrix_keys),
|
||||
};
|
||||
|
||||
static unsigned int board_keypad_row_gpios[] = {
|
||||
88, 89, 124, 11, 6, 96
|
||||
};
|
||||
|
||||
static unsigned int board_keypad_col_gpios[] = {
|
||||
90, 91, 100, 36, 12, 97, 98
|
||||
};
|
||||
|
||||
static struct matrix_keypad_platform_data board_keypad_platform_data = {
|
||||
.keymap_data = &board_keymap_data,
|
||||
.row_gpios = board_keypad_row_gpios,
|
||||
.num_row_gpios = ARRAY_SIZE(board_keypad_row_gpios),
|
||||
.col_gpios = board_keypad_col_gpios,
|
||||
.num_col_gpios = ARRAY_SIZE(board_keypad_col_gpios),
|
||||
.active_low = 1,
|
||||
|
||||
.debounce_ms = 20,
|
||||
.col_scan_delay_us = 5,
|
||||
};
|
||||
|
||||
static struct platform_device board_keyboard = {
|
||||
.name = "matrix-keypad",
|
||||
.id = -1,
|
||||
.dev = {
|
||||
.platform_data = &board_keypad_platform_data,
|
||||
},
|
||||
};
|
||||
static void __init board_mkp_init(void)
|
||||
{
|
||||
omap_mux_init_gpio(88, OMAP_PULL_ENA | OMAP_PULL_UP);
|
||||
omap_mux_init_gpio(89, OMAP_PULL_ENA | OMAP_PULL_UP);
|
||||
omap_mux_init_gpio(124, OMAP_PULL_ENA | OMAP_PULL_UP);
|
||||
omap_mux_init_signal("mcbsp2_dr.gpio_11", OMAP_PULL_ENA | OMAP_PULL_UP);
|
||||
if (omap_has_menelaus()) {
|
||||
omap_mux_init_signal("sdrc_a14.gpio0",
|
||||
OMAP_PULL_ENA | OMAP_PULL_UP);
|
||||
omap_mux_init_signal("vlynq_rx0.gpio_15", 0);
|
||||
omap_mux_init_signal("gpio_98", 0);
|
||||
board_keypad_row_gpios[5] = 0;
|
||||
board_keypad_col_gpios[2] = 15;
|
||||
board_keypad_col_gpios[6] = 18;
|
||||
} else {
|
||||
omap_mux_init_signal("gpio_96", OMAP_PULL_ENA | OMAP_PULL_UP);
|
||||
omap_mux_init_signal("gpio_100", 0);
|
||||
omap_mux_init_signal("gpio_98", 0);
|
||||
}
|
||||
omap_mux_init_signal("gpio_90", 0);
|
||||
omap_mux_init_signal("gpio_91", 0);
|
||||
omap_mux_init_signal("gpio_36", 0);
|
||||
omap_mux_init_signal("mcbsp2_clkx.gpio_12", 0);
|
||||
omap_mux_init_signal("gpio_97", 0);
|
||||
|
||||
platform_device_register(&board_keyboard);
|
||||
}
|
||||
#else
|
||||
static inline void board_mkp_init(void)
|
||||
{
|
||||
}
|
||||
#endif
|
||||
|
||||
static struct mtd_partition h4_partitions[] = {
|
||||
/* bootloader (U-Boot, etc) in first sector */
|
||||
{
|
||||
.name = "bootloader",
|
||||
.offset = 0,
|
||||
.size = SZ_128K,
|
||||
.mask_flags = MTD_WRITEABLE, /* force read-only */
|
||||
},
|
||||
/* bootloader params in the next sector */
|
||||
{
|
||||
.name = "params",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = SZ_128K,
|
||||
.mask_flags = 0,
|
||||
},
|
||||
/* kernel */
|
||||
{
|
||||
.name = "kernel",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = SZ_2M,
|
||||
.mask_flags = 0
|
||||
},
|
||||
/* file system */
|
||||
{
|
||||
.name = "filesystem",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = MTDPART_SIZ_FULL,
|
||||
.mask_flags = 0
|
||||
}
|
||||
};
|
||||
|
||||
static struct physmap_flash_data h4_flash_data = {
|
||||
.width = 2,
|
||||
.parts = h4_partitions,
|
||||
.nr_parts = ARRAY_SIZE(h4_partitions),
|
||||
};
|
||||
|
||||
static struct resource h4_flash_resource = {
|
||||
.flags = IORESOURCE_MEM,
|
||||
};
|
||||
|
||||
static struct platform_device h4_flash_device = {
|
||||
.name = "physmap-flash",
|
||||
.id = 0,
|
||||
.dev = {
|
||||
.platform_data = &h4_flash_data,
|
||||
},
|
||||
.num_resources = 1,
|
||||
.resource = &h4_flash_resource,
|
||||
};
|
||||
|
||||
static const struct display_timing cm_t35_lcd_videomode = {
|
||||
.pixelclock = { 0, 6250000, 0 },
|
||||
|
||||
.hactive = { 0, 240, 0 },
|
||||
.hfront_porch = { 0, 15, 0 },
|
||||
.hback_porch = { 0, 60, 0 },
|
||||
.hsync_len = { 0, 15, 0 },
|
||||
|
||||
.vactive = { 0, 320, 0 },
|
||||
.vfront_porch = { 0, 1, 0 },
|
||||
.vback_porch = { 0, 1, 0 },
|
||||
.vsync_len = { 0, 1, 0 },
|
||||
|
||||
.flags = DISPLAY_FLAGS_HSYNC_HIGH | DISPLAY_FLAGS_VSYNC_HIGH |
|
||||
DISPLAY_FLAGS_DE_HIGH | DISPLAY_FLAGS_PIXDATA_POSEDGE,
|
||||
};
|
||||
|
||||
static struct panel_dpi_platform_data cm_t35_lcd_pdata = {
|
||||
.name = "lcd",
|
||||
.source = "dpi.0",
|
||||
|
||||
.data_lines = 16,
|
||||
|
||||
.display_timing = &cm_t35_lcd_videomode,
|
||||
|
||||
.enable_gpio = -1,
|
||||
.backlight_gpio = -1,
|
||||
};
|
||||
|
||||
static struct platform_device cm_t35_lcd_device = {
|
||||
.name = "panel-dpi",
|
||||
.id = 0,
|
||||
.dev.platform_data = &cm_t35_lcd_pdata,
|
||||
};
|
||||
|
||||
static struct platform_device *h4_devices[] __initdata = {
|
||||
&h4_flash_device,
|
||||
&cm_t35_lcd_device,
|
||||
};
|
||||
|
||||
static struct omap_dss_board_info h4_dss_data = {
|
||||
.default_display_name = "lcd",
|
||||
};
|
||||
|
||||
/* 2420 Sysboot setup (2430 is different) */
|
||||
static u32 get_sysboot_value(void)
|
||||
{
|
||||
return (omap_ctrl_readl(OMAP24XX_CONTROL_STATUS) &
|
||||
(OMAP2_SYSBOOT_5_MASK | OMAP2_SYSBOOT_4_MASK |
|
||||
OMAP2_SYSBOOT_3_MASK | OMAP2_SYSBOOT_2_MASK |
|
||||
OMAP2_SYSBOOT_1_MASK | OMAP2_SYSBOOT_0_MASK));
|
||||
}
|
||||
|
||||
/* H4-2420's always used muxed mode, H4-2422's always use non-muxed
|
||||
*
|
||||
* Note: OMAP-GIT doesn't correctly do is_cpu_omap2422 and is_cpu_omap2423
|
||||
* correctly. The macro needs to look at production_id not just hawkeye.
|
||||
*/
|
||||
static u32 is_gpmc_muxed(void)
|
||||
{
|
||||
u32 mux;
|
||||
mux = get_sysboot_value();
|
||||
if ((mux & 0xF) == 0xd)
|
||||
return 1; /* NAND config (could be either) */
|
||||
if (mux & 0x2) /* if mux'ed */
|
||||
return 1;
|
||||
else
|
||||
return 0;
|
||||
}
|
||||
|
||||
#if IS_ENABLED(CONFIG_SMC91X)
|
||||
|
||||
static struct omap_smc91x_platform_data board_smc91x_data = {
|
||||
.cs = 1,
|
||||
.gpio_irq = 92,
|
||||
.flags = GPMC_TIMINGS_SMC91C96 | IORESOURCE_IRQ_LOWLEVEL,
|
||||
};
|
||||
|
||||
static void __init board_smc91x_init(void)
|
||||
{
|
||||
if (is_gpmc_muxed())
|
||||
board_smc91x_data.flags |= GPMC_MUX_ADD_DATA;
|
||||
|
||||
omap_mux_init_gpio(board_smc91x_data.gpio_irq, OMAP_PIN_INPUT);
|
||||
gpmc_smc91x_init(&board_smc91x_data);
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
static inline void board_smc91x_init(void)
|
||||
{
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
static void __init h4_init_flash(void)
|
||||
{
|
||||
unsigned long base;
|
||||
|
||||
if (gpmc_cs_request(H4_FLASH_CS, SZ_64M, &base) < 0) {
|
||||
printk("Can't request GPMC CS for flash\n");
|
||||
return;
|
||||
}
|
||||
h4_flash_resource.start = base;
|
||||
h4_flash_resource.end = base + SZ_64M - 1;
|
||||
}
|
||||
|
||||
static struct at24_platform_data m24c01 = {
|
||||
.byte_len = SZ_1K / 8,
|
||||
.page_size = 16,
|
||||
};
|
||||
|
||||
static struct i2c_board_info __initdata h4_i2c_board_info[] = {
|
||||
{
|
||||
I2C_BOARD_INFO("isp1301_omap", 0x2d),
|
||||
},
|
||||
{ /* EEPROM on mainboard */
|
||||
I2C_BOARD_INFO("24c01", 0x52),
|
||||
.platform_data = &m24c01,
|
||||
},
|
||||
{ /* EEPROM on cpu card */
|
||||
I2C_BOARD_INFO("24c01", 0x57),
|
||||
.platform_data = &m24c01,
|
||||
},
|
||||
};
|
||||
|
||||
#ifdef CONFIG_OMAP_MUX
|
||||
static struct omap_board_mux board_mux[] __initdata = {
|
||||
{ .reg_offset = OMAP_MUX_TERMINATOR },
|
||||
};
|
||||
#endif
|
||||
|
||||
static void __init omap_h4_init(void)
|
||||
{
|
||||
omap2420_mux_init(board_mux, OMAP_PACKAGE_ZAF);
|
||||
|
||||
/*
|
||||
* Make sure the serial ports are muxed on at this point.
|
||||
* You have to mux them off in device drivers later on
|
||||
* if not needed.
|
||||
*/
|
||||
|
||||
board_mkp_init();
|
||||
h4_i2c_board_info[0].irq = gpio_to_irq(125);
|
||||
i2c_register_board_info(1, h4_i2c_board_info,
|
||||
ARRAY_SIZE(h4_i2c_board_info));
|
||||
|
||||
platform_add_devices(h4_devices, ARRAY_SIZE(h4_devices));
|
||||
omap_serial_init();
|
||||
omap_sdrc_init(NULL, NULL);
|
||||
h4_init_flash();
|
||||
board_smc91x_init();
|
||||
|
||||
omap_display_init(&h4_dss_data);
|
||||
}
|
||||
|
||||
MACHINE_START(OMAP_H4, "OMAP2420 H4 board")
|
||||
/* Maintainer: Paul Mundt <paul.mundt@nokia.com> */
|
||||
.atag_offset = 0x100,
|
||||
.reserve = omap_reserve,
|
||||
.map_io = omap242x_map_io,
|
||||
.init_early = omap2420_init_early,
|
||||
.init_irq = omap2_init_irq,
|
||||
.handle_irq = omap2_intc_handle_irq,
|
||||
.init_machine = omap_h4_init,
|
||||
.init_late = omap2420_init_late,
|
||||
.init_time = omap2_sync32k_timer_init,
|
||||
.restart = omap2xxx_restart,
|
||||
MACHINE_END
|
|
@ -21,7 +21,6 @@
|
|||
#include <linux/i2c.h>
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/usb/musb.h>
|
||||
#include <linux/platform_data/i2c-cbus-gpio.h>
|
||||
#include <linux/platform_data/spi-omap2-mcspi.h>
|
||||
#include <linux/platform_data/mtd-onenand-omap2.h>
|
||||
#include <linux/mfd/menelaus.h>
|
||||
|
@ -32,8 +31,7 @@
|
|||
|
||||
#include "common.h"
|
||||
#include "mmc.h"
|
||||
|
||||
#include "mux.h"
|
||||
#include "soc.h"
|
||||
#include "gpmc-onenand.h"
|
||||
|
||||
#define TUSB6010_ASYNC_CS 1
|
||||
|
@ -42,44 +40,30 @@
|
|||
#define TUSB6010_GPIO_ENABLE 0
|
||||
#define TUSB6010_DMACHAN 0x3f
|
||||
|
||||
#if defined(CONFIG_I2C_CBUS_GPIO) || defined(CONFIG_I2C_CBUS_GPIO_MODULE)
|
||||
static struct i2c_cbus_platform_data n8x0_cbus_data = {
|
||||
.clk_gpio = 66,
|
||||
.dat_gpio = 65,
|
||||
.sel_gpio = 64,
|
||||
};
|
||||
#define NOKIA_N810_WIMAX (1 << 2)
|
||||
#define NOKIA_N810 (1 << 1)
|
||||
#define NOKIA_N800 (1 << 0)
|
||||
|
||||
static struct platform_device n8x0_cbus_device = {
|
||||
.name = "i2c-cbus-gpio",
|
||||
.id = 3,
|
||||
.dev = {
|
||||
.platform_data = &n8x0_cbus_data,
|
||||
},
|
||||
};
|
||||
static u32 board_caps;
|
||||
|
||||
static struct i2c_board_info n8x0_i2c_board_info_3[] __initdata = {
|
||||
{
|
||||
I2C_BOARD_INFO("retu-mfd", 0x01),
|
||||
},
|
||||
};
|
||||
#define board_is_n800() (board_caps & NOKIA_N800)
|
||||
#define board_is_n810() (board_caps & NOKIA_N810)
|
||||
#define board_is_n810_wimax() (board_caps & NOKIA_N810_WIMAX)
|
||||
|
||||
static void __init n8x0_cbus_init(void)
|
||||
static void board_check_revision(void)
|
||||
{
|
||||
const int retu_irq_gpio = 108;
|
||||
if (of_have_populated_dt()) {
|
||||
if (of_machine_is_compatible("nokia,n800"))
|
||||
board_caps = NOKIA_N800;
|
||||
else if (of_machine_is_compatible("nokia,n810"))
|
||||
board_caps = NOKIA_N810;
|
||||
else if (of_machine_is_compatible("nokia,n810-wimax"))
|
||||
board_caps = NOKIA_N810_WIMAX;
|
||||
}
|
||||
|
||||
if (gpio_request_one(retu_irq_gpio, GPIOF_IN, "Retu IRQ"))
|
||||
return;
|
||||
irq_set_irq_type(gpio_to_irq(retu_irq_gpio), IRQ_TYPE_EDGE_RISING);
|
||||
n8x0_i2c_board_info_3[0].irq = gpio_to_irq(retu_irq_gpio);
|
||||
i2c_register_board_info(3, n8x0_i2c_board_info_3,
|
||||
ARRAY_SIZE(n8x0_i2c_board_info_3));
|
||||
platform_device_register(&n8x0_cbus_device);
|
||||
if (!board_caps)
|
||||
pr_err("Unknown board\n");
|
||||
}
|
||||
#else /* CONFIG_I2C_CBUS_GPIO */
|
||||
static void __init n8x0_cbus_init(void)
|
||||
{
|
||||
}
|
||||
#endif /* CONFIG_I2C_CBUS_GPIO */
|
||||
|
||||
#if defined(CONFIG_USB_MUSB_TUSB6010) || defined(CONFIG_USB_MUSB_TUSB6010_MODULE)
|
||||
/*
|
||||
|
@ -178,49 +162,6 @@ static struct spi_board_info n800_spi_board_info[] __initdata = {
|
|||
},
|
||||
};
|
||||
|
||||
#if defined(CONFIG_MTD_ONENAND_OMAP2) || \
|
||||
defined(CONFIG_MTD_ONENAND_OMAP2_MODULE)
|
||||
|
||||
static struct mtd_partition onenand_partitions[] = {
|
||||
{
|
||||
.name = "bootloader",
|
||||
.offset = 0,
|
||||
.size = 0x20000,
|
||||
.mask_flags = MTD_WRITEABLE, /* Force read-only */
|
||||
},
|
||||
{
|
||||
.name = "config",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = 0x60000,
|
||||
},
|
||||
{
|
||||
.name = "kernel",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = 0x200000,
|
||||
},
|
||||
{
|
||||
.name = "initfs",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = 0x400000,
|
||||
},
|
||||
{
|
||||
.name = "rootfs",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = MTDPART_SIZ_FULL,
|
||||
},
|
||||
};
|
||||
|
||||
static struct omap_onenand_platform_data board_onenand_data[] = {
|
||||
{
|
||||
.cs = 0,
|
||||
.gpio_irq = 26,
|
||||
.parts = onenand_partitions,
|
||||
.nr_parts = ARRAY_SIZE(onenand_partitions),
|
||||
.flags = ONENAND_SYNC_READ,
|
||||
}
|
||||
};
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_MENELAUS) && \
|
||||
(defined(CONFIG_MMC_OMAP) || defined(CONFIG_MMC_OMAP_MODULE))
|
||||
|
||||
|
@ -342,7 +283,7 @@ static void n810_set_power_emmc(struct device *dev,
|
|||
static int n8x0_mmc_set_power(struct device *dev, int slot, int power_on,
|
||||
int vdd)
|
||||
{
|
||||
if (machine_is_nokia_n800() || slot == 0)
|
||||
if (board_is_n800() || slot == 0)
|
||||
return n8x0_mmc_set_power_menelaus(dev, slot, power_on, vdd);
|
||||
|
||||
n810_set_power_emmc(dev, power_on);
|
||||
|
@ -388,7 +329,7 @@ static void n8x0_mmc_callback(void *data, u8 card_mask)
|
|||
{
|
||||
int bit, *openp, index;
|
||||
|
||||
if (machine_is_nokia_n800()) {
|
||||
if (board_is_n800()) {
|
||||
bit = 1 << 1;
|
||||
openp = &slot2_cover_open;
|
||||
index = 1;
|
||||
|
@ -421,7 +362,7 @@ static int n8x0_mmc_late_init(struct device *dev)
|
|||
if (r < 0)
|
||||
return r;
|
||||
|
||||
if (machine_is_nokia_n800())
|
||||
if (board_is_n800())
|
||||
vs2sel = 0;
|
||||
else
|
||||
vs2sel = 2;
|
||||
|
@ -444,7 +385,7 @@ static int n8x0_mmc_late_init(struct device *dev)
|
|||
if (r < 0)
|
||||
return r;
|
||||
|
||||
if (machine_is_nokia_n800()) {
|
||||
if (board_is_n800()) {
|
||||
bit = 1 << 1;
|
||||
openp = &slot2_cover_open;
|
||||
} else {
|
||||
|
@ -471,7 +412,7 @@ static void n8x0_mmc_shutdown(struct device *dev)
|
|||
{
|
||||
int vs2sel;
|
||||
|
||||
if (machine_is_nokia_n800())
|
||||
if (board_is_n800())
|
||||
vs2sel = 0;
|
||||
else
|
||||
vs2sel = 2;
|
||||
|
@ -486,7 +427,7 @@ static void n8x0_mmc_cleanup(struct device *dev)
|
|||
|
||||
gpio_free(N8X0_SLOT_SWITCH_GPIO);
|
||||
|
||||
if (machine_is_nokia_n810()) {
|
||||
if (board_is_n810()) {
|
||||
gpio_free(N810_EMMC_VSD_GPIO);
|
||||
gpio_free(N810_EMMC_VIO_GPIO);
|
||||
}
|
||||
|
@ -497,7 +438,7 @@ static void n8x0_mmc_cleanup(struct device *dev)
|
|||
* MMC controller2 is not in use.
|
||||
*/
|
||||
static struct omap_mmc_platform_data mmc1_data = {
|
||||
.nr_slots = 2,
|
||||
.nr_slots = 0,
|
||||
.switch_slot = n8x0_mmc_switch_slot,
|
||||
.init = n8x0_mmc_late_init,
|
||||
.cleanup = n8x0_mmc_cleanup,
|
||||
|
@ -537,7 +478,7 @@ static void __init n8x0_mmc_init(void)
|
|||
{
|
||||
int err;
|
||||
|
||||
if (machine_is_nokia_n810()) {
|
||||
if (board_is_n810()) {
|
||||
mmc1_data.slots[0].name = "external";
|
||||
|
||||
/*
|
||||
|
@ -555,7 +496,7 @@ static void __init n8x0_mmc_init(void)
|
|||
if (err)
|
||||
return;
|
||||
|
||||
if (machine_is_nokia_n810()) {
|
||||
if (board_is_n810()) {
|
||||
err = gpio_request_array(n810_emmc_gpios,
|
||||
ARRAY_SIZE(n810_emmc_gpios));
|
||||
if (err) {
|
||||
|
@ -564,11 +505,11 @@ static void __init n8x0_mmc_init(void)
|
|||
}
|
||||
}
|
||||
|
||||
mmc1_data.nr_slots = 2;
|
||||
mmc_data[0] = &mmc1_data;
|
||||
omap242x_init_mmc(mmc_data);
|
||||
}
|
||||
#else
|
||||
|
||||
static struct omap_mmc_platform_data mmc1_data;
|
||||
void __init n8x0_mmc_init(void)
|
||||
{
|
||||
}
|
||||
|
@ -650,109 +591,32 @@ static struct i2c_board_info n810_i2c_board_info_2[] __initdata = {
|
|||
},
|
||||
};
|
||||
|
||||
#ifdef CONFIG_OMAP_MUX
|
||||
static struct omap_board_mux board_mux[] __initdata = {
|
||||
/* I2S codec port pins for McBSP block */
|
||||
OMAP2420_MUX(EAC_AC_SCLK, OMAP_MUX_MODE1 | OMAP_PIN_INPUT),
|
||||
OMAP2420_MUX(EAC_AC_FS, OMAP_MUX_MODE1 | OMAP_PIN_INPUT),
|
||||
OMAP2420_MUX(EAC_AC_DIN, OMAP_MUX_MODE1 | OMAP_PIN_INPUT),
|
||||
OMAP2420_MUX(EAC_AC_DOUT, OMAP_MUX_MODE1 | OMAP_PIN_OUTPUT),
|
||||
{ .reg_offset = OMAP_MUX_TERMINATOR },
|
||||
};
|
||||
|
||||
static struct omap_device_pad serial2_pads[] __initdata = {
|
||||
{
|
||||
.name = "uart3_rx_irrx.uart3_rx_irrx",
|
||||
.flags = OMAP_DEVICE_PAD_REMUX | OMAP_DEVICE_PAD_WAKEUP,
|
||||
.enable = OMAP_MUX_MODE0,
|
||||
.idle = OMAP_MUX_MODE3 /* Mux as GPIO for idle */
|
||||
},
|
||||
};
|
||||
|
||||
static inline void board_serial_init(void)
|
||||
static int __init n8x0_late_initcall(void)
|
||||
{
|
||||
struct omap_board_data bdata;
|
||||
if (!board_caps)
|
||||
return -ENODEV;
|
||||
|
||||
bdata.flags = 0;
|
||||
bdata.pads = NULL;
|
||||
bdata.pads_cnt = 0;
|
||||
|
||||
bdata.id = 0;
|
||||
omap_serial_init_port(&bdata, NULL);
|
||||
|
||||
bdata.id = 1;
|
||||
omap_serial_init_port(&bdata, NULL);
|
||||
|
||||
bdata.id = 2;
|
||||
bdata.pads = serial2_pads;
|
||||
bdata.pads_cnt = ARRAY_SIZE(serial2_pads);
|
||||
omap_serial_init_port(&bdata, NULL);
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
static inline void board_serial_init(void)
|
||||
{
|
||||
omap_serial_init();
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
static void __init n8x0_init_machine(void)
|
||||
{
|
||||
omap2420_mux_init(board_mux, OMAP_PACKAGE_ZAC);
|
||||
/* FIXME: add n810 spi devices */
|
||||
spi_register_board_info(n800_spi_board_info,
|
||||
ARRAY_SIZE(n800_spi_board_info));
|
||||
omap_register_i2c_bus(1, 400, n8x0_i2c_board_info_1,
|
||||
ARRAY_SIZE(n8x0_i2c_board_info_1));
|
||||
omap_register_i2c_bus(2, 400, NULL, 0);
|
||||
if (machine_is_nokia_n810())
|
||||
i2c_register_board_info(2, n810_i2c_board_info_2,
|
||||
ARRAY_SIZE(n810_i2c_board_info_2));
|
||||
board_serial_init();
|
||||
omap_sdrc_init(NULL, NULL);
|
||||
gpmc_onenand_init(board_onenand_data);
|
||||
n8x0_mmc_init();
|
||||
n8x0_usb_init();
|
||||
n8x0_cbus_init();
|
||||
|
||||
return 0;
|
||||
}
|
||||
omap_late_initcall(n8x0_late_initcall);
|
||||
|
||||
MACHINE_START(NOKIA_N800, "Nokia N800")
|
||||
.atag_offset = 0x100,
|
||||
.reserve = omap_reserve,
|
||||
.map_io = omap242x_map_io,
|
||||
.init_early = omap2420_init_early,
|
||||
.init_irq = omap2_init_irq,
|
||||
.handle_irq = omap2_intc_handle_irq,
|
||||
.init_machine = n8x0_init_machine,
|
||||
.init_late = omap2420_init_late,
|
||||
.init_time = omap2_sync32k_timer_init,
|
||||
.restart = omap2xxx_restart,
|
||||
MACHINE_END
|
||||
/*
|
||||
* Legacy init pdata init for n8x0. Note that we want to follow the
|
||||
* I2C bus numbering starting at 0 for device tree like other omaps.
|
||||
*/
|
||||
void * __init n8x0_legacy_init(void)
|
||||
{
|
||||
board_check_revision();
|
||||
spi_register_board_info(n800_spi_board_info,
|
||||
ARRAY_SIZE(n800_spi_board_info));
|
||||
i2c_register_board_info(0, n8x0_i2c_board_info_1,
|
||||
ARRAY_SIZE(n8x0_i2c_board_info_1));
|
||||
if (board_is_n810())
|
||||
i2c_register_board_info(1, n810_i2c_board_info_2,
|
||||
ARRAY_SIZE(n810_i2c_board_info_2));
|
||||
|
||||
MACHINE_START(NOKIA_N810, "Nokia N810")
|
||||
.atag_offset = 0x100,
|
||||
.reserve = omap_reserve,
|
||||
.map_io = omap242x_map_io,
|
||||
.init_early = omap2420_init_early,
|
||||
.init_irq = omap2_init_irq,
|
||||
.handle_irq = omap2_intc_handle_irq,
|
||||
.init_machine = n8x0_init_machine,
|
||||
.init_late = omap2420_init_late,
|
||||
.init_time = omap2_sync32k_timer_init,
|
||||
.restart = omap2xxx_restart,
|
||||
MACHINE_END
|
||||
|
||||
MACHINE_START(NOKIA_N810_WIMAX, "Nokia N810 WiMAX")
|
||||
.atag_offset = 0x100,
|
||||
.reserve = omap_reserve,
|
||||
.map_io = omap242x_map_io,
|
||||
.init_early = omap2420_init_early,
|
||||
.init_irq = omap2_init_irq,
|
||||
.handle_irq = omap2_intc_handle_irq,
|
||||
.init_machine = n8x0_init_machine,
|
||||
.init_late = omap2420_init_late,
|
||||
.init_time = omap2_sync32k_timer_init,
|
||||
.restart = omap2xxx_restart,
|
||||
MACHINE_END
|
||||
return &mmc1_data;
|
||||
}
|
||||
|
|
|
@ -10,5 +10,6 @@ struct ads7846_platform_data;
|
|||
|
||||
void omap_ads7846_init(int bus_num, int gpio_pendown, int gpio_debounce,
|
||||
struct ads7846_platform_data *board_pdata);
|
||||
void *n8x0_legacy_init(void);
|
||||
|
||||
#endif /* __OMAP_COMMON_BOARD_DEVICES__ */
|
||||
|
|
|
@ -293,6 +293,7 @@ static inline void omap4_cpu_resume(void)
|
|||
#endif
|
||||
|
||||
void pdata_quirks_init(struct of_device_id *);
|
||||
void omap_auxdata_legacy_init(struct device *dev);
|
||||
void omap_pcs_legacy_init(int irq, void (*rearm)(void));
|
||||
|
||||
struct omap_sdrc_params;
|
||||
|
|
|
@ -88,72 +88,3 @@ int omap_msdi_reset(struct omap_hwmod *oh)
|
|||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_MMC_OMAP) || defined(CONFIG_MMC_OMAP_MODULE)
|
||||
|
||||
static inline void omap242x_mmc_mux(struct omap_mmc_platform_data
|
||||
*mmc_controller)
|
||||
{
|
||||
if ((mmc_controller->slots[0].switch_pin > 0) && \
|
||||
(mmc_controller->slots[0].switch_pin < OMAP_MAX_GPIO_LINES))
|
||||
omap_mux_init_gpio(mmc_controller->slots[0].switch_pin,
|
||||
OMAP_PIN_INPUT_PULLUP);
|
||||
if ((mmc_controller->slots[0].gpio_wp > 0) && \
|
||||
(mmc_controller->slots[0].gpio_wp < OMAP_MAX_GPIO_LINES))
|
||||
omap_mux_init_gpio(mmc_controller->slots[0].gpio_wp,
|
||||
OMAP_PIN_INPUT_PULLUP);
|
||||
|
||||
omap_mux_init_signal("sdmmc_cmd", 0);
|
||||
omap_mux_init_signal("sdmmc_clki", 0);
|
||||
omap_mux_init_signal("sdmmc_clko", 0);
|
||||
omap_mux_init_signal("sdmmc_dat0", 0);
|
||||
omap_mux_init_signal("sdmmc_dat_dir0", 0);
|
||||
omap_mux_init_signal("sdmmc_cmd_dir", 0);
|
||||
if (mmc_controller->slots[0].caps & MMC_CAP_4_BIT_DATA) {
|
||||
omap_mux_init_signal("sdmmc_dat1", 0);
|
||||
omap_mux_init_signal("sdmmc_dat2", 0);
|
||||
omap_mux_init_signal("sdmmc_dat3", 0);
|
||||
omap_mux_init_signal("sdmmc_dat_dir1", 0);
|
||||
omap_mux_init_signal("sdmmc_dat_dir2", 0);
|
||||
omap_mux_init_signal("sdmmc_dat_dir3", 0);
|
||||
}
|
||||
|
||||
/*
|
||||
* Use internal loop-back in MMC/SDIO Module Input Clock
|
||||
* selection
|
||||
*/
|
||||
if (mmc_controller->slots[0].internal_clock) {
|
||||
u32 v = omap_ctrl_readl(OMAP2_CONTROL_DEVCONF0);
|
||||
v |= (1 << 24);
|
||||
omap_ctrl_writel(v, OMAP2_CONTROL_DEVCONF0);
|
||||
}
|
||||
}
|
||||
|
||||
void __init omap242x_init_mmc(struct omap_mmc_platform_data **mmc_data)
|
||||
{
|
||||
struct platform_device *pdev;
|
||||
struct omap_hwmod *oh;
|
||||
int id = 0;
|
||||
char *oh_name = "msdi1";
|
||||
char *dev_name = "mmci-omap";
|
||||
|
||||
if (!mmc_data[0]) {
|
||||
pr_err("%s fails: Incomplete platform data\n", __func__);
|
||||
return;
|
||||
}
|
||||
|
||||
omap242x_mmc_mux(mmc_data[0]);
|
||||
|
||||
oh = omap_hwmod_lookup(oh_name);
|
||||
if (!oh) {
|
||||
pr_err("Could not look up %s\n", oh_name);
|
||||
return;
|
||||
}
|
||||
pdev = omap_device_build(dev_name, id, oh, mmc_data[0],
|
||||
sizeof(struct omap_mmc_platform_data));
|
||||
if (IS_ERR(pdev))
|
||||
WARN(1, "Can'd build omap_device for %s:%s.\n",
|
||||
dev_name, oh->name);
|
||||
}
|
||||
|
||||
#endif
|
||||
|
|
|
@ -7,8 +7,6 @@
|
|||
* published by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#include "mux2420.h"
|
||||
#include "mux2430.h"
|
||||
#include "mux34xx.h"
|
||||
|
||||
#define OMAP_MUX_TERMINATOR 0xffff
|
||||
|
|
|
@ -1,690 +0,0 @@
|
|||
/*
|
||||
* Copyright (C) 2010 Nokia
|
||||
* Copyright (C) 2010 Texas Instruments
|
||||
*
|
||||
* 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 <linux/module.h>
|
||||
#include <linux/init.h>
|
||||
|
||||
#include "mux.h"
|
||||
|
||||
#ifdef CONFIG_OMAP_MUX
|
||||
|
||||
#define _OMAP2420_MUXENTRY(M0, g, m0, m1, m2, m3, m4, m5, m6, m7) \
|
||||
{ \
|
||||
.reg_offset = (OMAP2420_CONTROL_PADCONF_##M0##_OFFSET), \
|
||||
.gpio = (g), \
|
||||
.muxnames = { m0, m1, m2, m3, m4, m5, m6, m7 }, \
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
#define _OMAP2420_MUXENTRY(M0, g, m0, m1, m2, m3, m4, m5, m6, m7) \
|
||||
{ \
|
||||
.reg_offset = (OMAP2420_CONTROL_PADCONF_##M0##_OFFSET), \
|
||||
.gpio = (g), \
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
#define _OMAP2420_BALLENTRY(M0, bb, bt) \
|
||||
{ \
|
||||
.reg_offset = (OMAP2420_CONTROL_PADCONF_##M0##_OFFSET), \
|
||||
.balls = { bb, bt }, \
|
||||
}
|
||||
|
||||
/*
|
||||
* Superset of all mux modes for omap2420
|
||||
*/
|
||||
static struct omap_mux __initdata omap2420_muxmodes[] = {
|
||||
_OMAP2420_MUXENTRY(CAM_D0, 54,
|
||||
"cam_d0", "hw_dbg2", "sti_dout", "gpio_54",
|
||||
NULL, NULL, "etk_d2", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_D1, 53,
|
||||
"cam_d1", "hw_dbg3", "sti_din", "gpio_53",
|
||||
NULL, NULL, "etk_d3", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_D2, 52,
|
||||
"cam_d2", "hw_dbg4", "mcbsp1_clkx", "gpio_52",
|
||||
NULL, NULL, "etk_d4", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_D3, 51,
|
||||
"cam_d3", "hw_dbg5", "mcbsp1_dr", "gpio_51",
|
||||
NULL, NULL, "etk_d5", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_D4, 50,
|
||||
"cam_d4", "hw_dbg6", "mcbsp1_fsr", "gpio_50",
|
||||
NULL, NULL, "etk_d6", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_D5, 49,
|
||||
"cam_d5", "hw_dbg7", "mcbsp1_clkr", "gpio_49",
|
||||
NULL, NULL, "etk_d7", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_D6, 0,
|
||||
"cam_d6", "hw_dbg8", NULL, NULL,
|
||||
NULL, NULL, "etk_d8", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_D7, 0,
|
||||
"cam_d7", "hw_dbg9", NULL, NULL,
|
||||
NULL, NULL, "etk_d9", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_D8, 54,
|
||||
"cam_d8", "hw_dbg10", NULL, "gpio_54",
|
||||
NULL, NULL, "etk_d10", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_D9, 53,
|
||||
"cam_d9", "hw_dbg11", NULL, "gpio_53",
|
||||
NULL, NULL, "etk_d11", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_HS, 55,
|
||||
"cam_hs", "hw_dbg1", "mcbsp1_dx", "gpio_55",
|
||||
NULL, NULL, "etk_d1", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_LCLK, 57,
|
||||
"cam_lclk", NULL, "mcbsp_clks", "gpio_57",
|
||||
NULL, NULL, "etk_c1", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_VS, 56,
|
||||
"cam_vs", "hw_dbg0", "mcbsp1_fsx", "gpio_56",
|
||||
NULL, NULL, "etk_d0", NULL),
|
||||
_OMAP2420_MUXENTRY(CAM_XCLK, 0,
|
||||
"cam_xclk", NULL, "sti_clk", NULL,
|
||||
NULL, NULL, "etk_c2", NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_ACBIAS, 48,
|
||||
"dss_acbias", NULL, "mcbsp2_fsx", "gpio_48",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_DATA10, 40,
|
||||
"dss_data10", NULL, NULL, "gpio_40",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_DATA11, 41,
|
||||
"dss_data11", NULL, NULL, "gpio_41",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_DATA12, 42,
|
||||
"dss_data12", NULL, NULL, "gpio_42",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_DATA13, 43,
|
||||
"dss_data13", NULL, NULL, "gpio_43",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_DATA14, 44,
|
||||
"dss_data14", NULL, NULL, "gpio_44",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_DATA15, 45,
|
||||
"dss_data15", NULL, NULL, "gpio_45",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_DATA16, 46,
|
||||
"dss_data16", NULL, NULL, "gpio_46",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_DATA17, 47,
|
||||
"dss_data17", NULL, NULL, "gpio_47",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_DATA8, 38,
|
||||
"dss_data8", NULL, NULL, "gpio_38",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(DSS_DATA9, 39,
|
||||
"dss_data9", NULL, NULL, "gpio_39",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(EAC_AC_DIN, 115,
|
||||
"eac_ac_din", "mcbsp2_dr", NULL, "gpio_115",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(EAC_AC_DOUT, 116,
|
||||
"eac_ac_dout", "mcbsp2_dx", NULL, "gpio_116",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(EAC_AC_FS, 114,
|
||||
"eac_ac_fs", "mcbsp2_fsx", NULL, "gpio_114",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(EAC_AC_MCLK, 117,
|
||||
"eac_ac_mclk", NULL, NULL, "gpio_117",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(EAC_AC_RST, 118,
|
||||
"eac_ac_rst", "eac_bt_din", NULL, "gpio_118",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(EAC_AC_SCLK, 113,
|
||||
"eac_ac_sclk", "mcbsp2_clkx", NULL, "gpio_113",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(EAC_BT_DIN, 73,
|
||||
"eac_bt_din", NULL, NULL, "gpio_73",
|
||||
NULL, NULL, "etk_d9", NULL),
|
||||
_OMAP2420_MUXENTRY(EAC_BT_DOUT, 74,
|
||||
"eac_bt_dout", NULL, "sti_clk", "gpio_74",
|
||||
NULL, NULL, "etk_d8", NULL),
|
||||
_OMAP2420_MUXENTRY(EAC_BT_FS, 72,
|
||||
"eac_bt_fs", NULL, NULL, "gpio_72",
|
||||
NULL, NULL, "etk_d10", NULL),
|
||||
_OMAP2420_MUXENTRY(EAC_BT_SCLK, 71,
|
||||
"eac_bt_sclk", NULL, NULL, "gpio_71",
|
||||
NULL, NULL, "etk_d11", NULL),
|
||||
_OMAP2420_MUXENTRY(GPIO_119, 119,
|
||||
"gpio_119", NULL, "sti_din", "gpio_119",
|
||||
NULL, "sys_boot0", "etk_d12", NULL),
|
||||
_OMAP2420_MUXENTRY(GPIO_120, 120,
|
||||
"gpio_120", NULL, "sti_dout", "gpio_120",
|
||||
"cam_d9", "sys_boot1", "etk_d13", NULL),
|
||||
_OMAP2420_MUXENTRY(GPIO_121, 121,
|
||||
"gpio_121", NULL, NULL, "gpio_121",
|
||||
"jtag_emu2", "sys_boot2", "etk_d14", NULL),
|
||||
_OMAP2420_MUXENTRY(GPIO_122, 122,
|
||||
"gpio_122", NULL, NULL, "gpio_122",
|
||||
"jtag_emu3", "sys_boot3", "etk_d15", NULL),
|
||||
_OMAP2420_MUXENTRY(GPIO_124, 124,
|
||||
"gpio_124", NULL, NULL, "gpio_124",
|
||||
NULL, "sys_boot5", NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPIO_125, 125,
|
||||
"gpio_125", "sys_jtagsel1", "sys_jtagsel2", "gpio_125",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPIO_36, 36,
|
||||
"gpio_36", NULL, NULL, "gpio_36",
|
||||
NULL, "sys_boot4", NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPIO_62, 62,
|
||||
"gpio_62", "uart1_rx", "usb1_dat", "gpio_62",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPIO_6, 6,
|
||||
"gpio_6", "tv_detpulse", NULL, "gpio_6",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_A10, 3,
|
||||
"gpmc_a10", NULL, "sys_ndmareq5", "gpio_3",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_A1, 12,
|
||||
"gpmc_a1", "dss_data18", NULL, "gpio_12",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_A2, 11,
|
||||
"gpmc_a2", "dss_data19", NULL, "gpio_11",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_A3, 10,
|
||||
"gpmc_a3", "dss_data20", NULL, "gpio_10",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_A4, 9,
|
||||
"gpmc_a4", "dss_data21", NULL, "gpio_9",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_A5, 8,
|
||||
"gpmc_a5", "dss_data22", NULL, "gpio_8",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_A6, 7,
|
||||
"gpmc_a6", "dss_data23", NULL, "gpio_7",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_A7, 6,
|
||||
"gpmc_a7", NULL, "sys_ndmareq2", "gpio_6",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_A8, 5,
|
||||
"gpmc_a8", NULL, "sys_ndmareq3", "gpio_5",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_A9, 4,
|
||||
"gpmc_a9", NULL, "sys_ndmareq4", "gpio_4",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_CLK, 21,
|
||||
"gpmc_clk", NULL, NULL, "gpio_21",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_D10, 18,
|
||||
"gpmc_d10", "ssi2_rdy_rx", NULL, "gpio_18",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_D11, 17,
|
||||
"gpmc_d11", "ssi2_flag_rx", NULL, "gpio_17",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_D12, 16,
|
||||
"gpmc_d12", "ssi2_dat_rx", NULL, "gpio_16",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_D13, 15,
|
||||
"gpmc_d13", "ssi2_rdy_tx", NULL, "gpio_15",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_D14, 14,
|
||||
"gpmc_d14", "ssi2_flag_tx", NULL, "gpio_14",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_D15, 13,
|
||||
"gpmc_d15", "ssi2_dat_tx", NULL, "gpio_13",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_D8, 20,
|
||||
"gpmc_d8", NULL, NULL, "gpio_20",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_D9, 19,
|
||||
"gpmc_d9", "ssi2_wake", NULL, "gpio_19",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_NBE0, 29,
|
||||
"gpmc_nbe0", NULL, NULL, "gpio_29",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_NBE1, 30,
|
||||
"gpmc_nbe1", NULL, NULL, "gpio_30",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_NCS1, 22,
|
||||
"gpmc_ncs1", NULL, NULL, "gpio_22",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_NCS2, 23,
|
||||
"gpmc_ncs2", NULL, NULL, "gpio_23",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_NCS3, 24,
|
||||
"gpmc_ncs3", "gpmc_io_dir", NULL, "gpio_24",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_NCS4, 25,
|
||||
"gpmc_ncs4", NULL, NULL, "gpio_25",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_NCS5, 26,
|
||||
"gpmc_ncs5", NULL, NULL, "gpio_26",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_NCS6, 27,
|
||||
"gpmc_ncs6", NULL, NULL, "gpio_27",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_NCS7, 28,
|
||||
"gpmc_ncs7", "gpmc_io_dir", "gpio_28", NULL,
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_NWP, 31,
|
||||
"gpmc_nwp", NULL, NULL, "gpio_31",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_WAIT1, 33,
|
||||
"gpmc_wait1", NULL, NULL, "gpio_33",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_WAIT2, 34,
|
||||
"gpmc_wait2", NULL, NULL, "gpio_34",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(GPMC_WAIT3, 35,
|
||||
"gpmc_wait3", NULL, NULL, "gpio_35",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(HDQ_SIO, 101,
|
||||
"hdq_sio", "usb2_tllse0", "sys_altclk", "gpio_101",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(I2C2_SCL, 99,
|
||||
"i2c2_scl", NULL, "gpt9_pwm_evt", "gpio_99",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(I2C2_SDA, 100,
|
||||
"i2c2_sda", NULL, "spi2_ncs1", "gpio_100",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(JTAG_EMU0, 127,
|
||||
"jtag_emu0", NULL, NULL, "gpio_127",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(JTAG_EMU1, 126,
|
||||
"jtag_emu1", NULL, NULL, "gpio_126",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MCBSP1_CLKR, 92,
|
||||
"mcbsp1_clkr", "ssi2_dat_tx", "vlynq_tx1", "gpio_92",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MCBSP1_CLKX, 98,
|
||||
"mcbsp1_clkx", "ssi2_wake", "vlynq_nla", "gpio_98",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MCBSP1_DR, 95,
|
||||
"mcbsp1_dr", "ssi2_dat_rx", "vlynq_rx1", "gpio_95",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MCBSP1_DX, 94,
|
||||
"mcbsp1_dx", "ssi2_rdy_tx", "vlynq_clk", "gpio_94",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MCBSP1_FSR, 93,
|
||||
"mcbsp1_fsr", "ssi2_flag_tx", "vlynq_tx0", "gpio_93",
|
||||
"spi2_ncs1", NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MCBSP1_FSX, 97,
|
||||
"mcbsp1_fsx", "ssi2_rdy_rx", NULL, "gpio_97",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MCBSP2_CLKX, 12,
|
||||
"mcbsp2_clkx", NULL, "dss_data23", "gpio_12",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MCBSP2_DR, 11,
|
||||
"mcbsp2_dr", NULL, "dss_data22", "gpio_11",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MCBSP_CLKS, 96,
|
||||
"mcbsp_clks", "ssi2_flag_rx", "vlynq_rx0", "gpio_96",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_CLKI, 59,
|
||||
"sdmmc_clki", "ms_clki", NULL, "gpio_59",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_CLKO, 0,
|
||||
"sdmmc_clko", "ms_clko", NULL, NULL,
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_CMD_DIR, 8,
|
||||
"sdmmc_cmd_dir", NULL, NULL, "gpio_8",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_CMD, 0,
|
||||
"sdmmc_cmd", "ms_bs", NULL, NULL,
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_DAT_DIR0, 7,
|
||||
"sdmmc_dat_dir0", "ms_dat0_dir", NULL, "gpio_7",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_DAT0, 0,
|
||||
"sdmmc_dat0", "ms_dat0", NULL, NULL,
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_DAT_DIR1, 78,
|
||||
"sdmmc_dat_dir1", "ms_datu_dir", "uart2_rts", "gpio_78",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_DAT1, 75,
|
||||
"sdmmc_dat1", "ms_dat1", NULL, "gpio_75",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_DAT_DIR2, 79,
|
||||
"sdmmc_dat_dir2", "ms_datu_dir", "uart2_tx", "gpio_79",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_DAT2, 76,
|
||||
"sdmmc_dat2", "ms_dat2", "uart2_cts", "gpio_76",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_DAT_DIR3, 80,
|
||||
"sdmmc_dat_dir3", "ms_datu_dir", "uart2_rx", "gpio_80",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(MMC_DAT3, 77,
|
||||
"sdmmc_dat3", "ms_dat3", NULL, "gpio_77",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SDRC_A12, 2,
|
||||
"sdrc_a12", NULL, NULL, "gpio_2",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SDRC_A13, 1,
|
||||
"sdrc_a13", NULL, NULL, "gpio_1",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SDRC_A14, 0,
|
||||
"sdrc_a14", NULL, NULL, "gpio_0",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SDRC_CKE1, 38,
|
||||
"sdrc_cke1", NULL, NULL, "gpio_38",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SDRC_NCS1, 37,
|
||||
"sdrc_ncs1", NULL, NULL, "gpio_37",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI1_CLK, 81,
|
||||
"spi1_clk", NULL, NULL, "gpio_81",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI1_NCS0, 84,
|
||||
"spi1_ncs0", NULL, NULL, "gpio_84",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI1_NCS1, 85,
|
||||
"spi1_ncs1", NULL, NULL, "gpio_85",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI1_NCS2, 86,
|
||||
"spi1_ncs2", NULL, NULL, "gpio_86",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI1_NCS3, 87,
|
||||
"spi1_ncs3", NULL, NULL, "gpio_87",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI1_SIMO, 82,
|
||||
"spi1_simo", NULL, NULL, "gpio_82",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI1_SOMI, 83,
|
||||
"spi1_somi", NULL, NULL, "gpio_83",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI2_CLK, 88,
|
||||
"spi2_clk", NULL, NULL, "gpio_88",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI2_NCS0, 91,
|
||||
"spi2_ncs0", "gpt12_pwm_evt", NULL, "gpio_91",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI2_SIMO, 89,
|
||||
"spi2_simo", "gpt10_pwm_evt", NULL, "gpio_89",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SPI2_SOMI, 90,
|
||||
"spi2_somi", "gpt11_pwm_evt", NULL, "gpio_90",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SSI1_DAT_RX, 63,
|
||||
"ssi1_dat_rx", "eac_md_sclk", NULL, "gpio_63",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SSI1_DAT_TX, 59,
|
||||
"ssi1_dat_tx", "uart1_tx", "usb1_se0", "gpio_59",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SSI1_FLAG_RX, 64,
|
||||
"ssi1_flag_rx", "eac_md_din", NULL, "gpio_64",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SSI1_FLAG_TX, 25,
|
||||
"ssi1_flag_tx", "uart1_rts", "usb1_rcv", "gpio_25",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SSI1_RDY_RX, 65,
|
||||
"ssi1_rdy_rx", "eac_md_dout", NULL, "gpio_65",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SSI1_RDY_TX, 61,
|
||||
"ssi1_rdy_tx", "uart1_cts", "usb1_txen", "gpio_61",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SSI1_WAKE, 66,
|
||||
"ssi1_wake", "eac_md_fs", NULL, "gpio_66",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SYS_CLKOUT, 123,
|
||||
"sys_clkout", NULL, NULL, "gpio_123",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SYS_CLKREQ, 52,
|
||||
"sys_clkreq", NULL, NULL, "gpio_52",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(SYS_NIRQ, 60,
|
||||
"sys_nirq", NULL, NULL, "gpio_60",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART1_CTS, 32,
|
||||
"uart1_cts", NULL, "dss_data18", "gpio_32",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART1_RTS, 8,
|
||||
"uart1_rts", NULL, "dss_data19", "gpio_8",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART1_RX, 10,
|
||||
"uart1_rx", NULL, "dss_data21", "gpio_10",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART1_TX, 9,
|
||||
"uart1_tx", NULL, "dss_data20", "gpio_9",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART2_CTS, 67,
|
||||
"uart2_cts", "usb1_rcv", "gpt9_pwm_evt", "gpio_67",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART2_RTS, 68,
|
||||
"uart2_rts", "usb1_txen", "gpt10_pwm_evt", "gpio_68",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART2_RX, 70,
|
||||
"uart2_rx", "usb1_dat", "gpt12_pwm_evt", "gpio_70",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART2_TX, 69,
|
||||
"uart2_tx", "usb1_se0", "gpt11_pwm_evt", "gpio_69",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART3_CTS_RCTX, 102,
|
||||
"uart3_cts_rctx", "uart3_rx_irrx", NULL, "gpio_102",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART3_RTS_SD, 103,
|
||||
"uart3_rts_sd", "uart3_tx_irtx", NULL, "gpio_103",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART3_RX_IRRX, 105,
|
||||
"uart3_rx_irrx", NULL, NULL, "gpio_105",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(UART3_TX_IRTX, 104,
|
||||
"uart3_tx_irtx", "uart3_cts_rctx", NULL, "gpio_104",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(USB0_DAT, 112,
|
||||
"usb0_dat", "uart3_rx_irrx", "uart2_rx", "gpio_112",
|
||||
"uart2_tx", NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(USB0_PUEN, 106,
|
||||
"usb0_puen", "mcbsp2_dx", NULL, "gpio_106",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(USB0_RCV, 109,
|
||||
"usb0_rcv", "mcbsp2_fsx", NULL, "gpio_109",
|
||||
"uart2_cts", NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(USB0_SE0, 111,
|
||||
"usb0_se0", "uart3_tx_irtx", "uart2_tx", "gpio_111",
|
||||
"uart2_rx", NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(USB0_TXEN, 110,
|
||||
"usb0_txen", "uart3_cts_rctx", "uart2_cts", "gpio_110",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(USB0_VM, 108,
|
||||
"usb0_vm", "mcbsp2_clkx", NULL, "gpio_108",
|
||||
"uart2_rx", NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(USB0_VP, 107,
|
||||
"usb0_vp", "mcbsp2_dr", NULL, "gpio_107",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(VLYNQ_CLK, 13,
|
||||
"vlynq_clk", "usb2_se0", "sys_ndmareq0", "gpio_13",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(VLYNQ_NLA, 58,
|
||||
"vlynq_nla", NULL, NULL, "gpio_58",
|
||||
"cam_d6", NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(VLYNQ_RX0, 15,
|
||||
"vlynq_rx0", "usb2_tllse0", NULL, "gpio_15",
|
||||
"cam_d7", NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(VLYNQ_RX1, 14,
|
||||
"vlynq_rx1", "usb2_rcv", "sys_ndmareq1", "gpio_14",
|
||||
"cam_d8", NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(VLYNQ_TX0, 17,
|
||||
"vlynq_tx0", "usb2_txen", NULL, "gpio_17",
|
||||
NULL, NULL, NULL, NULL),
|
||||
_OMAP2420_MUXENTRY(VLYNQ_TX1, 16,
|
||||
"vlynq_tx1", "usb2_dat", "sys_clkout2", "gpio_16",
|
||||
NULL, NULL, NULL, NULL),
|
||||
{ .reg_offset = OMAP_MUX_TERMINATOR },
|
||||
};
|
||||
|
||||
/*
|
||||
* Balls for 447-pin POP package
|
||||
*/
|
||||
#ifdef CONFIG_DEBUG_FS
|
||||
static struct omap_ball __initdata omap2420_pop_ball[] = {
|
||||
_OMAP2420_BALLENTRY(CAM_D0, "y4", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_D1, "y3", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_D2, "u7", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_D3, "ab3", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_D4, "v2", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_D5, "ad3", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_D6, "aa4", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_D7, "ab4", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_D8, "ac6", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_D9, "ac7", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_HS, "v4", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_LCLK, "ad6", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_VS, "p7", NULL),
|
||||
_OMAP2420_BALLENTRY(CAM_XCLK, "w4", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_ACBIAS, "ae8", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_DATA10, "ac12", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_DATA11, "ae11", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_DATA12, "ae13", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_DATA13, "ad13", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_DATA14, "ac13", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_DATA15, "y12", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_DATA16, "ad14", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_DATA17, "y13", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_DATA8, "ad11", NULL),
|
||||
_OMAP2420_BALLENTRY(DSS_DATA9, "ad12", NULL),
|
||||
_OMAP2420_BALLENTRY(EAC_AC_DIN, "ad19", NULL),
|
||||
_OMAP2420_BALLENTRY(EAC_AC_DOUT, "af22", NULL),
|
||||
_OMAP2420_BALLENTRY(EAC_AC_FS, "ad16", NULL),
|
||||
_OMAP2420_BALLENTRY(EAC_AC_MCLK, "y17", NULL),
|
||||
_OMAP2420_BALLENTRY(EAC_AC_RST, "ae22", NULL),
|
||||
_OMAP2420_BALLENTRY(EAC_AC_SCLK, "ac18", NULL),
|
||||
_OMAP2420_BALLENTRY(EAC_BT_DIN, "u8", NULL),
|
||||
_OMAP2420_BALLENTRY(EAC_BT_DOUT, "ad5", NULL),
|
||||
_OMAP2420_BALLENTRY(EAC_BT_FS, "w7", NULL),
|
||||
_OMAP2420_BALLENTRY(EAC_BT_SCLK, "ad4", NULL),
|
||||
_OMAP2420_BALLENTRY(GPIO_119, "af6", NULL),
|
||||
_OMAP2420_BALLENTRY(GPIO_120, "af4", NULL),
|
||||
_OMAP2420_BALLENTRY(GPIO_121, "ae6", NULL),
|
||||
_OMAP2420_BALLENTRY(GPIO_122, "w3", NULL),
|
||||
_OMAP2420_BALLENTRY(GPIO_124, "y19", NULL),
|
||||
_OMAP2420_BALLENTRY(GPIO_125, "ae24", NULL),
|
||||
_OMAP2420_BALLENTRY(GPIO_36, "y18", NULL),
|
||||
_OMAP2420_BALLENTRY(GPIO_6, "d6", NULL),
|
||||
_OMAP2420_BALLENTRY(GPIO_62, "ad18", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_A1, "m8", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_A10, "d5", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_A2, "w9", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_A3, "af10", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_A4, "w8", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_A5, "ae16", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_A6, "af9", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_A7, "e4", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_A8, "j7", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_A9, "ae18", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_CLK, "p1", "l1"),
|
||||
_OMAP2420_BALLENTRY(GPMC_D10, "t1", "n1"),
|
||||
_OMAP2420_BALLENTRY(GPMC_D11, "u2", "p2"),
|
||||
_OMAP2420_BALLENTRY(GPMC_D12, "u1", "p1"),
|
||||
_OMAP2420_BALLENTRY(GPMC_D13, "p2", "m1"),
|
||||
_OMAP2420_BALLENTRY(GPMC_D14, "h2", "j2"),
|
||||
_OMAP2420_BALLENTRY(GPMC_D15, "h1", "k2"),
|
||||
_OMAP2420_BALLENTRY(GPMC_D8, "v1", "r1"),
|
||||
_OMAP2420_BALLENTRY(GPMC_D9, "y1", "t1"),
|
||||
_OMAP2420_BALLENTRY(GPMC_NBE0, "af12", "aa10"),
|
||||
_OMAP2420_BALLENTRY(GPMC_NBE1, "u3", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_NCS1, "af14", "w1"),
|
||||
_OMAP2420_BALLENTRY(GPMC_NCS2, "g4", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_NCS3, "t8", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_NCS4, "h8", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_NCS5, "k3", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_NCS6, "m7", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_NCS7, "p3", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_NWP, "ae15", "y5"),
|
||||
_OMAP2420_BALLENTRY(GPMC_WAIT1, "ae20", "y8"),
|
||||
_OMAP2420_BALLENTRY(GPMC_WAIT2, "n2", NULL),
|
||||
_OMAP2420_BALLENTRY(GPMC_WAIT3, "t4", NULL),
|
||||
_OMAP2420_BALLENTRY(HDQ_SIO, "t23", NULL),
|
||||
_OMAP2420_BALLENTRY(I2C2_SCL, "l2", NULL),
|
||||
_OMAP2420_BALLENTRY(I2C2_SDA, "k19", NULL),
|
||||
_OMAP2420_BALLENTRY(JTAG_EMU0, "n24", NULL),
|
||||
_OMAP2420_BALLENTRY(JTAG_EMU1, "ac22", NULL),
|
||||
_OMAP2420_BALLENTRY(MCBSP1_CLKR, "y24", NULL),
|
||||
_OMAP2420_BALLENTRY(MCBSP1_CLKX, "t19", NULL),
|
||||
_OMAP2420_BALLENTRY(MCBSP1_DR, "u23", NULL),
|
||||
_OMAP2420_BALLENTRY(MCBSP1_DX, "r24", NULL),
|
||||
_OMAP2420_BALLENTRY(MCBSP1_FSR, "r20", NULL),
|
||||
_OMAP2420_BALLENTRY(MCBSP1_FSX, "r23", NULL),
|
||||
_OMAP2420_BALLENTRY(MCBSP2_CLKX, "t24", NULL),
|
||||
_OMAP2420_BALLENTRY(MCBSP2_DR, "p20", NULL),
|
||||
_OMAP2420_BALLENTRY(MCBSP_CLKS, "p23", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_CLKI, "c23", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_CLKO, "h23", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_CMD, "j23", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_CMD_DIR, "j24", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_DAT0, "h17", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_DAT_DIR0, "f23", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_DAT1, "g19", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_DAT_DIR1, "d23", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_DAT2, "h20", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_DAT_DIR2, "g23", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_DAT3, "d24", NULL),
|
||||
_OMAP2420_BALLENTRY(MMC_DAT_DIR3, "e23", NULL),
|
||||
_OMAP2420_BALLENTRY(SDRC_A12, "w26", "r21"),
|
||||
_OMAP2420_BALLENTRY(SDRC_A13, "w25", "aa15"),
|
||||
_OMAP2420_BALLENTRY(SDRC_A14, "aa26", "y12"),
|
||||
_OMAP2420_BALLENTRY(SDRC_CKE1, "ae25", "y13"),
|
||||
_OMAP2420_BALLENTRY(SDRC_NCS1, "y25", "t20"),
|
||||
_OMAP2420_BALLENTRY(SPI1_CLK, "y23", NULL),
|
||||
_OMAP2420_BALLENTRY(SPI1_NCS0, "w24", NULL),
|
||||
_OMAP2420_BALLENTRY(SPI1_NCS1, "w23", NULL),
|
||||
_OMAP2420_BALLENTRY(SPI1_NCS2, "v23", NULL),
|
||||
_OMAP2420_BALLENTRY(SPI1_NCS3, "u20", NULL),
|
||||
_OMAP2420_BALLENTRY(SPI1_SIMO, "h10", NULL),
|
||||
_OMAP2420_BALLENTRY(SPI1_SOMI, "v19", NULL),
|
||||
_OMAP2420_BALLENTRY(SPI2_CLK, "v24", NULL),
|
||||
_OMAP2420_BALLENTRY(SPI2_NCS0, "aa24", NULL),
|
||||
_OMAP2420_BALLENTRY(SPI2_SIMO, "u24", NULL),
|
||||
_OMAP2420_BALLENTRY(SPI2_SOMI, "v25", NULL),
|
||||
_OMAP2420_BALLENTRY(SSI1_DAT_RX, "w15", NULL),
|
||||
_OMAP2420_BALLENTRY(SSI1_DAT_TX, "w13", NULL),
|
||||
_OMAP2420_BALLENTRY(SSI1_FLAG_RX, "af11", NULL),
|
||||
_OMAP2420_BALLENTRY(SSI1_FLAG_TX, "ac15", NULL),
|
||||
_OMAP2420_BALLENTRY(SSI1_RDY_RX, "ac16", NULL),
|
||||
_OMAP2420_BALLENTRY(SSI1_RDY_TX, "af15", NULL),
|
||||
_OMAP2420_BALLENTRY(SSI1_WAKE, "ad15", NULL),
|
||||
_OMAP2420_BALLENTRY(SYS_CLKOUT, "ae19", NULL),
|
||||
_OMAP2420_BALLENTRY(SYS_CLKREQ, "ad20", NULL),
|
||||
_OMAP2420_BALLENTRY(SYS_NIRQ, "y20", NULL),
|
||||
_OMAP2420_BALLENTRY(UART1_CTS, "g20", NULL),
|
||||
_OMAP2420_BALLENTRY(UART1_RTS, "k20", NULL),
|
||||
_OMAP2420_BALLENTRY(UART1_RX, "t20", NULL),
|
||||
_OMAP2420_BALLENTRY(UART1_TX, "h12", NULL),
|
||||
_OMAP2420_BALLENTRY(UART2_CTS, "ac24", NULL),
|
||||
_OMAP2420_BALLENTRY(UART2_RTS, "w20", NULL),
|
||||
_OMAP2420_BALLENTRY(UART2_RX, "ad24", NULL),
|
||||
_OMAP2420_BALLENTRY(UART2_TX, "ab24", NULL),
|
||||
_OMAP2420_BALLENTRY(UART3_CTS_RCTX, "k24", NULL),
|
||||
_OMAP2420_BALLENTRY(UART3_RTS_SD, "m20", NULL),
|
||||
_OMAP2420_BALLENTRY(UART3_RX_IRRX, "h24", NULL),
|
||||
_OMAP2420_BALLENTRY(UART3_TX_IRTX, "g24", NULL),
|
||||
_OMAP2420_BALLENTRY(USB0_DAT, "j25", NULL),
|
||||
_OMAP2420_BALLENTRY(USB0_PUEN, "l23", NULL),
|
||||
_OMAP2420_BALLENTRY(USB0_RCV, "k23", NULL),
|
||||
_OMAP2420_BALLENTRY(USB0_SE0, "l24", NULL),
|
||||
_OMAP2420_BALLENTRY(USB0_TXEN, "m24", NULL),
|
||||
_OMAP2420_BALLENTRY(USB0_VM, "n23", NULL),
|
||||
_OMAP2420_BALLENTRY(USB0_VP, "m23", NULL),
|
||||
_OMAP2420_BALLENTRY(VLYNQ_CLK, "w12", NULL),
|
||||
_OMAP2420_BALLENTRY(VLYNQ_NLA, "ae10", NULL),
|
||||
_OMAP2420_BALLENTRY(VLYNQ_RX0, "ad7", NULL),
|
||||
_OMAP2420_BALLENTRY(VLYNQ_RX1, "w10", NULL),
|
||||
_OMAP2420_BALLENTRY(VLYNQ_TX0, "y15", NULL),
|
||||
_OMAP2420_BALLENTRY(VLYNQ_TX1, "w14", NULL),
|
||||
{ .reg_offset = OMAP_MUX_TERMINATOR },
|
||||
};
|
||||
#else
|
||||
#define omap2420_pop_ball NULL
|
||||
#endif
|
||||
|
||||
int __init omap2420_mux_init(struct omap_board_mux *board_subset, int flags)
|
||||
{
|
||||
struct omap_ball *package_balls = NULL;
|
||||
|
||||
switch (flags & OMAP_PACKAGE_MASK) {
|
||||
case OMAP_PACKAGE_ZAC:
|
||||
package_balls = omap2420_pop_ball;
|
||||
break;
|
||||
case OMAP_PACKAGE_ZAF:
|
||||
/* REVISIT: Please add data */
|
||||
default:
|
||||
pr_warning("%s: No ball data available for omap2420 package\n",
|
||||
__func__);
|
||||
}
|
||||
|
||||
return omap_mux_init("core", OMAP_MUX_REG_8BIT | OMAP_MUX_GPIO_IN_MODE3,
|
||||
OMAP2420_CONTROL_PADCONF_MUX_PBASE,
|
||||
OMAP2420_CONTROL_PADCONF_MUX_SIZE,
|
||||
omap2420_muxmodes, NULL, board_subset,
|
||||
package_balls);
|
||||
}
|
|
@ -1,282 +0,0 @@
|
|||
/*
|
||||
* Copyright (C) 2009 Nokia
|
||||
* Copyright (C) 2009 Texas Instruments
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#define OMAP2420_CONTROL_PADCONF_MUX_PBASE 0x48000030LU
|
||||
|
||||
#define OMAP2420_MUX(mode0, mux_value) \
|
||||
{ \
|
||||
.reg_offset = (OMAP2420_CONTROL_PADCONF_##mode0##_OFFSET), \
|
||||
.value = (mux_value), \
|
||||
}
|
||||
|
||||
/*
|
||||
* OMAP2420 CONTROL_PADCONF* register offsets for pin-muxing
|
||||
*
|
||||
* Extracted from the TRM. Add 0x48000030 to these values to get the
|
||||
* absolute addresses. The name in the macro is the mode-0 name of
|
||||
* the pin. NOTE: These registers are 8-bits wide.
|
||||
*/
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A14_OFFSET 0x000
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A13_OFFSET 0x001
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A12_OFFSET 0x002
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_BA1_OFFSET 0x003
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_BA0_OFFSET 0x004
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A11_OFFSET 0x005
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A10_OFFSET 0x006
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A9_OFFSET 0x007
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A8_OFFSET 0x008
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A7_OFFSET 0x009
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A6_OFFSET 0x00a
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A5_OFFSET 0x00b
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A4_OFFSET 0x00c
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A3_OFFSET 0x00d
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A2_OFFSET 0x00e
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A1_OFFSET 0x00f
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_A0_OFFSET 0x010
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D31_OFFSET 0x021
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D30_OFFSET 0x022
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D29_OFFSET 0x023
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D28_OFFSET 0x024
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D27_OFFSET 0x025
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D26_OFFSET 0x026
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D25_OFFSET 0x027
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D24_OFFSET 0x028
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D23_OFFSET 0x029
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D22_OFFSET 0x02a
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D21_OFFSET 0x02b
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D20_OFFSET 0x02c
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D19_OFFSET 0x02d
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D18_OFFSET 0x02e
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D17_OFFSET 0x02f
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D16_OFFSET 0x030
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D15_OFFSET 0x031
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D14_OFFSET 0x032
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D13_OFFSET 0x033
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D12_OFFSET 0x034
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D11_OFFSET 0x035
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D10_OFFSET 0x036
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D9_OFFSET 0x037
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D8_OFFSET 0x038
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D7_OFFSET 0x039
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D6_OFFSET 0x03a
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D5_OFFSET 0x03b
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D4_OFFSET 0x03c
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D3_OFFSET 0x03d
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D2_OFFSET 0x03e
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D1_OFFSET 0x03f
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_D0_OFFSET 0x040
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_A10_OFFSET 0x041
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_A9_OFFSET 0x042
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_A8_OFFSET 0x043
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_A7_OFFSET 0x044
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_A6_OFFSET 0x045
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_A5_OFFSET 0x046
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_A4_OFFSET 0x047
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_A3_OFFSET 0x048
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_A2_OFFSET 0x049
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_A1_OFFSET 0x04a
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D15_OFFSET 0x04b
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D14_OFFSET 0x04c
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D13_OFFSET 0x04d
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D12_OFFSET 0x04e
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D11_OFFSET 0x04f
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D10_OFFSET 0x050
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D9_OFFSET 0x051
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D8_OFFSET 0x052
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D7_OFFSET 0x053
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D6_OFFSET 0x054
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D5_OFFSET 0x055
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D4_OFFSET 0x056
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D3_OFFSET 0x057
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D2_OFFSET 0x058
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D1_OFFSET 0x059
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_D0_OFFSET 0x05a
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_CLK_OFFSET 0x05b
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NCS0_OFFSET 0x05c
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NCS1_OFFSET 0x05d
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NCS2_OFFSET 0x05e
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NCS3_OFFSET 0x05f
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NCS4_OFFSET 0x060
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NCS5_OFFSET 0x061
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NCS6_OFFSET 0x062
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NCS7_OFFSET 0x063
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NALE_ALE_OFFSET 0x064
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NOE_OFFSET 0x065
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NWE_OFFSET 0x066
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NBE0_OFFSET 0x067
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NBE1_OFFSET 0x068
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_NWP_OFFSET 0x069
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_WAIT0_OFFSET 0x06a
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_WAIT1_OFFSET 0x06b
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_WAIT2_OFFSET 0x06c
|
||||
#define OMAP2420_CONTROL_PADCONF_GPMC_WAIT3_OFFSET 0x06d
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_CLK_OFFSET 0x06e
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_NCLK_OFFSET 0x06f
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_NCS0_OFFSET 0x070
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_NCS1_OFFSET 0x071
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_CKE0_OFFSET 0x072
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_CKE1_OFFSET 0x073
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_NRAS_OFFSET 0x074
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_NCAS_OFFSET 0x075
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_NWE_OFFSET 0x076
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_DM0_OFFSET 0x077
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_DM1_OFFSET 0x078
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_DM2_OFFSET 0x079
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_DM3_OFFSET 0x07a
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_DQS0_OFFSET 0x07f
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_DQS1_OFFSET 0x080
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_DQS2_OFFSET 0x081
|
||||
#define OMAP2420_CONTROL_PADCONF_SDRC_DQS3_OFFSET 0x082
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA0_OFFSET 0x083
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA1_OFFSET 0x084
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA2_OFFSET 0x085
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA3_OFFSET 0x086
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA4_OFFSET 0x087
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA5_OFFSET 0x088
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA6_OFFSET 0x089
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA7_OFFSET 0x08a
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA8_OFFSET 0x08b
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA9_OFFSET 0x08c
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA10_OFFSET 0x08d
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA11_OFFSET 0x08e
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA12_OFFSET 0x08f
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA13_OFFSET 0x090
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA14_OFFSET 0x091
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA15_OFFSET 0x092
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA16_OFFSET 0x093
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_DATA17_OFFSET 0x094
|
||||
#define OMAP2420_CONTROL_PADCONF_UART1_CTS_OFFSET 0x095
|
||||
#define OMAP2420_CONTROL_PADCONF_UART1_RTS_OFFSET 0x096
|
||||
#define OMAP2420_CONTROL_PADCONF_UART1_TX_OFFSET 0x097
|
||||
#define OMAP2420_CONTROL_PADCONF_UART1_RX_OFFSET 0x098
|
||||
#define OMAP2420_CONTROL_PADCONF_MCBSP2_DR_OFFSET 0x099
|
||||
#define OMAP2420_CONTROL_PADCONF_MCBSP2_CLKX_OFFSET 0x09a
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_PCL_OFFSET 0x09b
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_VSYNC_OFFSET 0x09c
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_HSYNC_OFFSET 0x09d
|
||||
#define OMAP2420_CONTROL_PADCONF_DSS_ACBIAS_OFFSET 0x09e
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_D9_OFFSET 0x09f
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_D8_OFFSET 0x0a0
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_D7_OFFSET 0x0a1
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_D6_OFFSET 0x0a2
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_D5_OFFSET 0x0a3
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_D4_OFFSET 0x0a4
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_D3_OFFSET 0x0a5
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_D2_OFFSET 0x0a6
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_D1_OFFSET 0x0a7
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_D0_OFFSET 0x0a8
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_HS_OFFSET 0x0a9
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_VS_OFFSET 0x0aa
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_LCLK_OFFSET 0x0ab
|
||||
#define OMAP2420_CONTROL_PADCONF_CAM_XCLK_OFFSET 0x0ac
|
||||
#define OMAP2420_CONTROL_PADCONF_SSI1_DAT_TX_OFFSET 0x0ad
|
||||
#define OMAP2420_CONTROL_PADCONF_SSI1_FLAG_TX_OFFSET 0x0ae
|
||||
#define OMAP2420_CONTROL_PADCONF_SSI1_RDY_TX_OFFSET 0x0af
|
||||
#define OMAP2420_CONTROL_PADCONF_GPIO_62_OFFSET 0x0b0
|
||||
#define OMAP2420_CONTROL_PADCONF_SSI1_DAT_RX_OFFSET 0x0b1
|
||||
#define OMAP2420_CONTROL_PADCONF_SSI1_FLAG_RX_OFFSET 0x0b2
|
||||
#define OMAP2420_CONTROL_PADCONF_SSI1_RDY_RX_OFFSET 0x0b3
|
||||
#define OMAP2420_CONTROL_PADCONF_SSI1_WAKE_OFFSET 0x0b4
|
||||
#define OMAP2420_CONTROL_PADCONF_VLYNQ_CLK_OFFSET 0x0b5
|
||||
#define OMAP2420_CONTROL_PADCONF_VLYNQ_RX1_OFFSET 0x0b6
|
||||
#define OMAP2420_CONTROL_PADCONF_VLYNQ_RX0_OFFSET 0x0b7
|
||||
#define OMAP2420_CONTROL_PADCONF_VLYNQ_TX1_OFFSET 0x0b8
|
||||
#define OMAP2420_CONTROL_PADCONF_VLYNQ_TX0_OFFSET 0x0b9
|
||||
#define OMAP2420_CONTROL_PADCONF_VLYNQ_NLA_OFFSET 0x0ba
|
||||
#define OMAP2420_CONTROL_PADCONF_UART2_CTS_OFFSET 0x0bb
|
||||
#define OMAP2420_CONTROL_PADCONF_UART2_RTS_OFFSET 0x0bc
|
||||
#define OMAP2420_CONTROL_PADCONF_UART2_TX_OFFSET 0x0bd
|
||||
#define OMAP2420_CONTROL_PADCONF_UART2_RX_OFFSET 0x0be
|
||||
#define OMAP2420_CONTROL_PADCONF_EAC_BT_SCLK_OFFSET 0x0bf
|
||||
#define OMAP2420_CONTROL_PADCONF_EAC_BT_FS_OFFSET 0x0c0
|
||||
#define OMAP2420_CONTROL_PADCONF_EAC_BT_DIN_OFFSET 0x0c1
|
||||
#define OMAP2420_CONTROL_PADCONF_EAC_BT_DOUT_OFFSET 0x0c2
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_CLKO_OFFSET 0x0c3
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_CMD_OFFSET 0x0c4
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_DAT0_OFFSET 0x0c5
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_DAT1_OFFSET 0x0c6
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_DAT2_OFFSET 0x0c7
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_DAT3_OFFSET 0x0c8
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_DAT_DIR0_OFFSET 0x0c9
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_DAT_DIR1_OFFSET 0x0ca
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_DAT_DIR2_OFFSET 0x0cb
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_DAT_DIR3_OFFSET 0x0cc
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_CMD_DIR_OFFSET 0x0cd
|
||||
#define OMAP2420_CONTROL_PADCONF_MMC_CLKI_OFFSET 0x0ce
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI1_CLK_OFFSET 0x0cf
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI1_SIMO_OFFSET 0x0d0
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI1_SOMI_OFFSET 0x0d1
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI1_NCS0_OFFSET 0x0d2
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI1_NCS1_OFFSET 0x0d3
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI1_NCS2_OFFSET 0x0d4
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI1_NCS3_OFFSET 0x0d5
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI2_CLK_OFFSET 0x0d6
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI2_SIMO_OFFSET 0x0d7
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI2_SOMI_OFFSET 0x0d8
|
||||
#define OMAP2420_CONTROL_PADCONF_SPI2_NCS0_OFFSET 0x0d9
|
||||
#define OMAP2420_CONTROL_PADCONF_MCBSP1_CLKR_OFFSET 0x0da
|
||||
#define OMAP2420_CONTROL_PADCONF_MCBSP1_FSR_OFFSET 0x0db
|
||||
#define OMAP2420_CONTROL_PADCONF_MCBSP1_DX_OFFSET 0x0dc
|
||||
#define OMAP2420_CONTROL_PADCONF_MCBSP1_DR_OFFSET 0x0dd
|
||||
#define OMAP2420_CONTROL_PADCONF_MCBSP_CLKS_OFFSET 0x0de
|
||||
#define OMAP2420_CONTROL_PADCONF_MCBSP1_FSX_OFFSET 0x0df
|
||||
#define OMAP2420_CONTROL_PADCONF_MCBSP1_CLKX_OFFSET 0x0e0
|
||||
#define OMAP2420_CONTROL_PADCONF_I2C1_SCL_OFFSET 0x0e1
|
||||
#define OMAP2420_CONTROL_PADCONF_I2C1_SDA_OFFSET 0x0e2
|
||||
#define OMAP2420_CONTROL_PADCONF_I2C2_SCL_OFFSET 0x0e3
|
||||
#define OMAP2420_CONTROL_PADCONF_I2C2_SDA_OFFSET 0x0e4
|
||||
#define OMAP2420_CONTROL_PADCONF_HDQ_SIO_OFFSET 0x0e5
|
||||
#define OMAP2420_CONTROL_PADCONF_UART3_CTS_RCTX_OFFSET 0x0e6
|
||||
#define OMAP2420_CONTROL_PADCONF_UART3_RTS_SD_OFFSET 0x0e7
|
||||
#define OMAP2420_CONTROL_PADCONF_UART3_TX_IRTX_OFFSET 0x0e8
|
||||
#define OMAP2420_CONTROL_PADCONF_UART3_RX_IRRX_OFFSET 0x0e9
|
||||
#define OMAP2420_CONTROL_PADCONF_TV_CVBS_OFFSET 0x0ea
|
||||
#define OMAP2420_CONTROL_PADCONF_TV_VREF_OFFSET 0x0eb
|
||||
#define OMAP2420_CONTROL_PADCONF_TV_RREF_OFFSET 0x0ec
|
||||
#define OMAP2420_CONTROL_PADCONF_USB0_PUEN_OFFSET 0x0ed
|
||||
#define OMAP2420_CONTROL_PADCONF_USB0_VP_OFFSET 0x0ee
|
||||
#define OMAP2420_CONTROL_PADCONF_USB0_VM_OFFSET 0x0ef
|
||||
#define OMAP2420_CONTROL_PADCONF_USB0_RCV_OFFSET 0x0f0
|
||||
#define OMAP2420_CONTROL_PADCONF_USB0_TXEN_OFFSET 0x0f1
|
||||
#define OMAP2420_CONTROL_PADCONF_USB0_SE0_OFFSET 0x0f2
|
||||
#define OMAP2420_CONTROL_PADCONF_USB0_DAT_OFFSET 0x0f3
|
||||
#define OMAP2420_CONTROL_PADCONF_EAC_AC_SCLK_OFFSET 0x0f4
|
||||
#define OMAP2420_CONTROL_PADCONF_EAC_AC_FS_OFFSET 0x0f5
|
||||
#define OMAP2420_CONTROL_PADCONF_EAC_AC_DIN_OFFSET 0x0f6
|
||||
#define OMAP2420_CONTROL_PADCONF_EAC_AC_DOUT_OFFSET 0x0f7
|
||||
#define OMAP2420_CONTROL_PADCONF_EAC_AC_MCLK_OFFSET 0x0f8
|
||||
#define OMAP2420_CONTROL_PADCONF_EAC_AC_RST_OFFSET 0x0f9
|
||||
#define OMAP2420_CONTROL_PADCONF_SYS_NRESPWRON_OFFSET 0x0fa
|
||||
#define OMAP2420_CONTROL_PADCONF_SYS_NRESWARM_OFFSET 0x0fb
|
||||
#define OMAP2420_CONTROL_PADCONF_SYS_NIRQ_OFFSET 0x0fc
|
||||
#define OMAP2420_CONTROL_PADCONF_SYS_NV_OFFSET 0x0fd
|
||||
#define OMAP2420_CONTROL_PADCONF_GPIO_119_OFFSET 0x0fe
|
||||
#define OMAP2420_CONTROL_PADCONF_GPIO_120_OFFSET 0x0ff
|
||||
#define OMAP2420_CONTROL_PADCONF_GPIO_121_OFFSET 0x100
|
||||
#define OMAP2420_CONTROL_PADCONF_GPIO_122_OFFSET 0x101
|
||||
#define OMAP2420_CONTROL_PADCONF_SYS_32K_OFFSET 0x102
|
||||
#define OMAP2420_CONTROL_PADCONF_SYS_XTALIN_OFFSET 0x103
|
||||
#define OMAP2420_CONTROL_PADCONF_SYS_XTALOUT_OFFSET 0x104
|
||||
#define OMAP2420_CONTROL_PADCONF_GPIO_36_OFFSET 0x105
|
||||
#define OMAP2420_CONTROL_PADCONF_SYS_CLKREQ_OFFSET 0x106
|
||||
#define OMAP2420_CONTROL_PADCONF_SYS_CLKOUT_OFFSET 0x107
|
||||
#define OMAP2420_CONTROL_PADCONF_GPIO_6_OFFSET 0x108
|
||||
#define OMAP2420_CONTROL_PADCONF_GPIO_124_OFFSET 0x109
|
||||
#define OMAP2420_CONTROL_PADCONF_GPIO_125_OFFSET 0x10a
|
||||
#define OMAP2420_CONTROL_PADCONF_JTAG_EMU1_OFFSET 0x10b
|
||||
#define OMAP2420_CONTROL_PADCONF_JTAG_EMU0_OFFSET 0x10c
|
||||
#define OMAP2420_CONTROL_PADCONF_JTAG_NTRST_OFFSET 0x10d
|
||||
#define OMAP2420_CONTROL_PADCONF_JTAG_TCK_OFFSET 0x10e
|
||||
#define OMAP2420_CONTROL_PADCONF_JTAG_RTCK_OFFSET 0x10f
|
||||
#define OMAP2420_CONTROL_PADCONF_JTAG_TMS_OFFSET 0x110
|
||||
#define OMAP2420_CONTROL_PADCONF_JTAG_TDI_OFFSET 0x111
|
||||
#define OMAP2420_CONTROL_PADCONF_JTAG_TDO_OFFSET 0x112
|
||||
|
||||
#define OMAP2420_CONTROL_PADCONF_MUX_SIZE \
|
||||
(OMAP2420_CONTROL_PADCONF_JTAG_TDO_OFFSET + 0x1)
|
|
@ -1,793 +0,0 @@
|
|||
/*
|
||||
* Copyright (C) 2010 Nokia
|
||||
* Copyright (C) 2010 Texas Instruments
|
||||
*
|
||||
* 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 <linux/module.h>
|
||||
#include <linux/init.h>
|
||||
|
||||
#include "mux.h"
|
||||
|
||||
#ifdef CONFIG_OMAP_MUX
|
||||
|
||||
#define _OMAP2430_MUXENTRY(M0, g, m0, m1, m2, m3, m4, m5, m6, m7) \
|
||||
{ \
|
||||
.reg_offset = (OMAP2430_CONTROL_PADCONF_##M0##_OFFSET), \
|
||||
.gpio = (g), \
|
||||
.muxnames = { m0, m1, m2, m3, m4, m5, m6, m7 }, \
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
#define _OMAP2430_MUXENTRY(M0, g, m0, m1, m2, m3, m4, m5, m6, m7) \
|
||||
{ \
|
||||
.reg_offset = (OMAP2430_CONTROL_PADCONF_##M0##_OFFSET), \
|
||||
.gpio = (g), \
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
#define _OMAP2430_BALLENTRY(M0, bb, bt) \
|
||||
{ \
|
||||
.reg_offset = (OMAP2430_CONTROL_PADCONF_##M0##_OFFSET), \
|
||||
.balls = { bb, bt }, \
|
||||
}
|
||||
|
||||
/*
|
||||
* Superset of all mux modes for omap2430
|
||||
*/
|
||||
static struct omap_mux __initdata omap2430_muxmodes[] = {
|
||||
_OMAP2430_MUXENTRY(CAM_D0, 133,
|
||||
"cam_d0", "hw_dbg0", "sti_dout", "gpio_133",
|
||||
NULL, NULL, "etk_d2", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D10, 146,
|
||||
"cam_d10", NULL, NULL, "gpio_146",
|
||||
NULL, NULL, "etk_d12", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D11, 145,
|
||||
"cam_d11", NULL, NULL, "gpio_145",
|
||||
NULL, NULL, "etk_d13", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D1, 132,
|
||||
"cam_d1", "hw_dbg1", "sti_din", "gpio_132",
|
||||
NULL, NULL, "etk_d3", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D2, 129,
|
||||
"cam_d2", "hw_dbg2", "mcbsp1_clkx", "gpio_129",
|
||||
NULL, NULL, "etk_d4", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D3, 128,
|
||||
"cam_d3", "hw_dbg3", "mcbsp1_dr", "gpio_128",
|
||||
NULL, NULL, "etk_d5", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D4, 143,
|
||||
"cam_d4", "hw_dbg4", "mcbsp1_fsr", "gpio_143",
|
||||
NULL, NULL, "etk_d6", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D5, 112,
|
||||
"cam_d5", "hw_dbg5", "mcbsp1_clkr", "gpio_112",
|
||||
NULL, NULL, "etk_d7", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D6, 137,
|
||||
"cam_d6", "hw_dbg6", NULL, "gpio_137",
|
||||
NULL, NULL, "etk_d8", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D7, 136,
|
||||
"cam_d7", "hw_dbg7", NULL, "gpio_136",
|
||||
NULL, NULL, "etk_d9", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D8, 135,
|
||||
"cam_d8", "hw_dbg8", NULL, "gpio_135",
|
||||
NULL, NULL, "etk_d10", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_D9, 134,
|
||||
"cam_d9", "hw_dbg9", NULL, "gpio_134",
|
||||
NULL, NULL, "etk_d11", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_HS, 11,
|
||||
"cam_hs", "hw_dbg10", "mcbsp1_dx", "gpio_11",
|
||||
NULL, NULL, "etk_d1", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_LCLK, 0,
|
||||
"cam_lclk", NULL, "mcbsp_clks", NULL,
|
||||
NULL, NULL, "etk_c1", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_VS, 12,
|
||||
"cam_vs", "hw_dbg11", "mcbsp1_fsx", "gpio_12",
|
||||
NULL, NULL, "etk_d0", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(CAM_XCLK, 0,
|
||||
"cam_xclk", NULL, "sti_clk", NULL,
|
||||
NULL, NULL, "etk_c2", NULL),
|
||||
_OMAP2430_MUXENTRY(DSS_ACBIAS, 48,
|
||||
"dss_acbias", NULL, "mcbsp2_fsx", "gpio_48",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA0, 40,
|
||||
"dss_data0", "uart1_cts", NULL, "gpio_40",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA10, 128,
|
||||
"dss_data10", "sdi_data1n", NULL, "gpio_128",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA11, 129,
|
||||
"dss_data11", "sdi_data1p", NULL, "gpio_129",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA12, 130,
|
||||
"dss_data12", "sdi_data2n", NULL, "gpio_130",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA13, 131,
|
||||
"dss_data13", "sdi_data2p", NULL, "gpio_131",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA14, 132,
|
||||
"dss_data14", "sdi_data3n", NULL, "gpio_132",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA15, 133,
|
||||
"dss_data15", "sdi_data3p", NULL, "gpio_133",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA16, 46,
|
||||
"dss_data16", NULL, NULL, "gpio_46",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA17, 47,
|
||||
"dss_data17", NULL, NULL, "gpio_47",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA1, 41,
|
||||
"dss_data1", "uart1_rts", NULL, "gpio_41",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA2, 42,
|
||||
"dss_data2", "uart1_tx", NULL, "gpio_42",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA3, 43,
|
||||
"dss_data3", "uart1_rx", NULL, "gpio_43",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA4, 44,
|
||||
"dss_data4", "uart3_rx_irrx", NULL, "gpio_44",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA5, 45,
|
||||
"dss_data5", "uart3_tx_irtx", NULL, "gpio_45",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA6, 144,
|
||||
"dss_data6", NULL, NULL, "gpio_144",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA7, 147,
|
||||
"dss_data7", NULL, NULL, "gpio_147",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA8, 38,
|
||||
"dss_data8", NULL, NULL, "gpio_38",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_DATA9, 39,
|
||||
"dss_data9", NULL, NULL, "gpio_39",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(DSS_HSYNC, 110,
|
||||
"dss_hsync", NULL, NULL, "gpio_110",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_113, 113,
|
||||
"gpio_113", "mcbsp2_clkx", NULL, "gpio_113",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_114, 114,
|
||||
"gpio_114", "mcbsp2_fsx", NULL, "gpio_114",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_115, 115,
|
||||
"gpio_115", "mcbsp2_dr", NULL, "gpio_115",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_116, 116,
|
||||
"gpio_116", "mcbsp2_dx", NULL, "gpio_116",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_128, 128,
|
||||
"gpio_128", NULL, "sti_din", "gpio_128",
|
||||
NULL, "sys_boot0", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_129, 129,
|
||||
"gpio_129", NULL, "sti_dout", "gpio_129",
|
||||
NULL, "sys_boot1", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_130, 130,
|
||||
"gpio_130", NULL, NULL, "gpio_130",
|
||||
"jtag_emu2", "sys_boot2", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_131, 131,
|
||||
"gpio_131", NULL, NULL, "gpio_131",
|
||||
"jtag_emu3", "sys_boot3", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_132, 132,
|
||||
"gpio_132", NULL, NULL, "gpio_132",
|
||||
NULL, "sys_boot4", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_133, 133,
|
||||
"gpio_133", NULL, NULL, "gpio_133",
|
||||
NULL, "sys_boot5", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_134, 134,
|
||||
"gpio_134", "ccp_datn", NULL, "gpio_134",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_135, 135,
|
||||
"gpio_135", "ccp_datp", NULL, "gpio_135",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_136, 136,
|
||||
"gpio_136", "ccp_clkn", NULL, "gpio_136",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_137, 137,
|
||||
"gpio_137", "ccp_clkp", NULL, "gpio_137",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_138, 138,
|
||||
"gpio_138", "spi3_clk", NULL, "gpio_138",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_139, 139,
|
||||
"gpio_139", "spi3_cs0", "sys_ndmareq3", "gpio_139",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_140, 140,
|
||||
"gpio_140", "spi3_simo", "sys_ndmareq4", "gpio_140",
|
||||
NULL, NULL, "etk_d14", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_141, 141,
|
||||
"gpio_141", "spi3_somi", NULL, "gpio_141",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_142, 142,
|
||||
"gpio_142", "spi3_cs1", "sys_ndmareq2", "gpio_142",
|
||||
NULL, NULL, "etk_d15", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_148, 148,
|
||||
"gpio_148", "mcbsp5_fsx", NULL, "gpio_148",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_149, 149,
|
||||
"gpio_149", "mcbsp5_dx", NULL, "gpio_149",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_150, 150,
|
||||
"gpio_150", "mcbsp5_dr", NULL, "gpio_150",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_151, 151,
|
||||
"gpio_151", "sys_pwrok", NULL, "gpio_151",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_152, 152,
|
||||
"gpio_152", "uart1_cts", "sys_ndmareq1", "gpio_152",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_153, 153,
|
||||
"gpio_153", "uart1_rx", "sys_ndmareq0", "gpio_153",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_154, 154,
|
||||
"gpio_154", "mcbsp5_clkx", NULL, "gpio_154",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_63, 63,
|
||||
"gpio_63", "mcbsp4_clkx", NULL, "gpio_63",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_78, 78,
|
||||
"gpio_78", NULL, "uart2_rts", "gpio_78",
|
||||
"uart3_rts_sd", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_79, 79,
|
||||
"gpio_79", "secure_indicator", "uart2_tx", "gpio_79",
|
||||
"uart3_tx_irtx", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_7, 7,
|
||||
"gpio_7", NULL, "uart2_cts", "gpio_7",
|
||||
"uart3_cts_rctx", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPIO_80, 80,
|
||||
"gpio_80", NULL, "uart2_rx", "gpio_80",
|
||||
"uart3_rx_irrx", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_A10, 3,
|
||||
"gpmc_a10", NULL, "sys_ndmareq0", "gpio_3",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_A1, 31,
|
||||
"gpmc_a1", NULL, NULL, "gpio_31",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_A2, 30,
|
||||
"gpmc_a2", NULL, NULL, "gpio_30",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_A3, 29,
|
||||
"gpmc_a3", NULL, NULL, "gpio_29",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_A4, 49,
|
||||
"gpmc_a4", NULL, NULL, "gpio_49",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_A5, 53,
|
||||
"gpmc_a5", NULL, NULL, "gpio_53",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_A6, 52,
|
||||
"gpmc_a6", NULL, NULL, "gpio_52",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_A7, 6,
|
||||
"gpmc_a7", NULL, NULL, "gpio_6",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_A8, 5,
|
||||
"gpmc_a8", NULL, NULL, "gpio_5",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_A9, 4,
|
||||
"gpmc_a9", NULL, "sys_ndmareq1", "gpio_4",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_CLK, 21,
|
||||
"gpmc_clk", NULL, NULL, "gpio_21",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_D10, 18,
|
||||
"gpmc_d10", NULL, NULL, "gpio_18",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_D11, 57,
|
||||
"gpmc_d11", NULL, NULL, "gpio_57",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_D12, 77,
|
||||
"gpmc_d12", NULL, NULL, "gpio_77",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_D13, 76,
|
||||
"gpmc_d13", NULL, NULL, "gpio_76",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_D14, 55,
|
||||
"gpmc_d14", NULL, NULL, "gpio_55",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_D15, 54,
|
||||
"gpmc_d15", NULL, NULL, "gpio_54",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_D8, 20,
|
||||
"gpmc_d8", NULL, NULL, "gpio_20",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_D9, 19,
|
||||
"gpmc_d9", NULL, NULL, "gpio_19",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_NCS1, 22,
|
||||
"gpmc_ncs1", NULL, NULL, "gpio_22",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_NCS2, 23,
|
||||
"gpmc_ncs2", NULL, NULL, "gpio_23",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_NCS3, 24,
|
||||
"gpmc_ncs3", "gpmc_io_dir", NULL, "gpio_24",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_NCS4, 25,
|
||||
"gpmc_ncs4", NULL, NULL, "gpio_25",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_NCS5, 26,
|
||||
"gpmc_ncs5", NULL, NULL, "gpio_26",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_NCS6, 27,
|
||||
"gpmc_ncs6", NULL, NULL, "gpio_27",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_NCS7, 28,
|
||||
"gpmc_ncs7", "gpmc_io_dir", NULL, "gpio_28",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_WAIT1, 33,
|
||||
"gpmc_wait1", NULL, NULL, "gpio_33",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_WAIT2, 34,
|
||||
"gpmc_wait2", NULL, NULL, "gpio_34",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(GPMC_WAIT3, 35,
|
||||
"gpmc_wait3", NULL, NULL, "gpio_35",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(HDQ_SIO, 101,
|
||||
"hdq_sio", "usb2_tllse0", "sys_altclk", "gpio_101",
|
||||
"uart3_rx_irrx", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(I2C1_SCL, 50,
|
||||
"i2c1_scl", NULL, NULL, "gpio_50",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(I2C1_SDA, 51,
|
||||
"i2c1_sda", NULL, NULL, "gpio_51",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(I2C2_SCL, 99,
|
||||
"i2c2_scl", NULL, NULL, "gpio_99",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(I2C2_SDA, 100,
|
||||
"i2c2_sda", NULL, NULL, "gpio_100",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(JTAG_EMU0, 127,
|
||||
"jtag_emu0", "secure_indicator", NULL, "gpio_127",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(JTAG_EMU1, 126,
|
||||
"jtag_emu1", NULL, NULL, "gpio_126",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP1_CLKR, 92,
|
||||
"mcbsp1_clkr", "ssi2_dat_tx", NULL, "gpio_92",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP1_CLKX, 98,
|
||||
"mcbsp1_clkx", "ssi2_wake", NULL, "gpio_98",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP1_DR, 95,
|
||||
"mcbsp1_dr", "ssi2_dat_rx", NULL, "gpio_95",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP1_DX, 94,
|
||||
"mcbsp1_dx", "ssi2_rdy_tx", NULL, "gpio_94",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP1_FSR, 93,
|
||||
"mcbsp1_fsr", "ssi2_flag_tx", NULL, "gpio_93",
|
||||
"spi2_cs1", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP1_FSX, 97,
|
||||
"mcbsp1_fsx", "ssi2_rdy_rx", NULL, "gpio_97",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP2_CLKX, 147,
|
||||
"mcbsp2_clkx", "sdi_clkp", "dss_data23", "gpio_147",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP2_DR, 144,
|
||||
"mcbsp2_dr", "sdi_clkn", "dss_data22", "gpio_144",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP3_CLKX, 71,
|
||||
"mcbsp3_clkx", NULL, NULL, "gpio_71",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP3_DR, 73,
|
||||
"mcbsp3_dr", NULL, NULL, "gpio_73",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP3_DX, 74,
|
||||
"mcbsp3_dx", NULL, "sti_clk", "gpio_74",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP3_FSX, 72,
|
||||
"mcbsp3_fsx", NULL, NULL, "gpio_72",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(MCBSP_CLKS, 96,
|
||||
"mcbsp_clks", "ssi2_flag_rx", NULL, "gpio_96",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC1_CLKO, 0,
|
||||
"sdmmc1_clko", "ms_clko", NULL, NULL,
|
||||
NULL, "hw_dbg9", "hw_dbg3", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC1_CMD, 0,
|
||||
"sdmmc1_cmd", "ms_bs", NULL, NULL,
|
||||
NULL, "hw_dbg8", "hw_dbg2", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC1_DAT0, 0,
|
||||
"sdmmc1_dat0", "ms_dat0", NULL, NULL,
|
||||
NULL, "hw_dbg7", "hw_dbg1", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC1_DAT1, 75,
|
||||
"sdmmc1_dat1", "ms_dat1", NULL, "gpio_75",
|
||||
NULL, "hw_dbg6", "hw_dbg0", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC1_DAT2, 0,
|
||||
"sdmmc1_dat2", "ms_dat2", NULL, NULL,
|
||||
NULL, "hw_dbg5", "hw_dbg10", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC1_DAT3, 0,
|
||||
"sdmmc1_dat3", "ms_dat3", NULL, NULL,
|
||||
NULL, "hw_dbg4", "hw_dbg11", "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC2_CLKO, 13,
|
||||
"sdmmc2_clko", NULL, NULL, "gpio_13",
|
||||
NULL, "spi3_clk", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC2_CMD, 15,
|
||||
"sdmmc2_cmd", "usb2_rcv", NULL, "gpio_15",
|
||||
NULL, "spi3_simo", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC2_DAT0, 16,
|
||||
"sdmmc2_dat0", "usb2_tllse0", NULL, "gpio_16",
|
||||
NULL, "spi3_somi", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC2_DAT1, 58,
|
||||
"sdmmc2_dat1", "usb2_txen", NULL, "gpio_58",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC2_DAT2, 17,
|
||||
"sdmmc2_dat2", "usb2_dat", NULL, "gpio_17",
|
||||
NULL, "spi3_cs1", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDMMC2_DAT3, 14,
|
||||
"sdmmc2_dat3", "usb2_se0", NULL, "gpio_14",
|
||||
NULL, "spi3_cs0", NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDRC_A12, 2,
|
||||
"sdrc_a12", NULL, NULL, "gpio_2",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDRC_A13, 1,
|
||||
"sdrc_a13", NULL, NULL, "gpio_1",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDRC_A14, 0,
|
||||
"sdrc_a14", NULL, NULL, "gpio_0",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDRC_CKE1, 36,
|
||||
"sdrc_cke1", NULL, NULL, "gpio_36",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SDRC_NCS1, 37,
|
||||
"sdrc_ncs1", NULL, NULL, "gpio_37",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI1_CLK, 81,
|
||||
"spi1_clk", NULL, NULL, "gpio_81",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI1_CS0, 84,
|
||||
"spi1_cs0", NULL, NULL, "gpio_84",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI1_CS1, 85,
|
||||
"spi1_cs1", NULL, NULL, "gpio_85",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI1_CS2, 86,
|
||||
"spi1_cs2", NULL, NULL, "gpio_86",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI1_CS3, 87,
|
||||
"spi1_cs3", "spi2_cs1", NULL, "gpio_87",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI1_SIMO, 82,
|
||||
"spi1_simo", NULL, NULL, "gpio_82",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI1_SOMI, 83,
|
||||
"spi1_somi", NULL, NULL, "gpio_83",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI2_CLK, 88,
|
||||
"spi2_clk", "gpt9_pwm_evt", NULL, "gpio_88",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI2_CS0, 91,
|
||||
"spi2_cs0", "gpt12_pwm_evt", NULL, "gpio_91",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI2_SIMO, 89,
|
||||
"spi2_simo", "gpt10_pwm_evt", NULL, "gpio_89",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SPI2_SOMI, 90,
|
||||
"spi2_somi", "gpt11_pwm_evt", NULL, "gpio_90",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SSI1_DAT_RX, 62,
|
||||
"ssi1_dat_rx", "uart1_rx", "usb1_dat", "gpio_62",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SSI1_DAT_TX, 59,
|
||||
"ssi1_dat_tx", "uart1_tx", "usb1_se0", "gpio_59",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SSI1_FLAG_RX, 64,
|
||||
"ssi1_flag_rx", "mcbsp4_dr", NULL, "gpio_64",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SSI1_FLAG_TX, 60,
|
||||
"ssi1_flag_tx", "uart1_rts", "usb1_rcv", "gpio_60",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SSI1_RDY_RX, 65,
|
||||
"ssi1_rdy_rx", "mcbsp4_dx", NULL, "gpio_65",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SSI1_RDY_TX, 61,
|
||||
"ssi1_rdy_tx", "uart1_cts", "usb1_txen", "gpio_61",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SSI1_WAKE, 66,
|
||||
"ssi1_wake", "mcbsp4_fsx", NULL, "gpio_66",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SYS_CLKOUT, 111,
|
||||
"sys_clkout", NULL, NULL, "gpio_111",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SYS_DRM_MSECURE, 118,
|
||||
"sys_drm_msecure", NULL, "sys_ndmareq6", "gpio_118",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SYS_NIRQ0, 56,
|
||||
"sys_nirq0", NULL, NULL, "gpio_56",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(SYS_NIRQ1, 125,
|
||||
"sys_nirq1", NULL, "sys_ndmareq5", "gpio_125",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART1_CTS, 32,
|
||||
"uart1_cts", "sdi_vsync", "dss_data18", "gpio_32",
|
||||
"mcbsp5_clkx", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART1_RTS, 8,
|
||||
"uart1_rts", "sdi_hsync", "dss_data19", "gpio_8",
|
||||
"mcbsp5_fsx", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART1_RX, 10,
|
||||
"uart1_rx", "sdi_stp", "dss_data21", "gpio_10",
|
||||
"mcbsp5_dr", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART1_TX, 9,
|
||||
"uart1_tx", "sdi_den", "dss_data20", "gpio_9",
|
||||
"mcbsp5_dx", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART2_CTS, 67,
|
||||
"uart2_cts", "usb1_rcv", "gpt9_pwm_evt", "gpio_67",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART2_RTS, 68,
|
||||
"uart2_rts", "usb1_txen", "gpt10_pwm_evt", "gpio_68",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART2_RX, 70,
|
||||
"uart2_rx", "usb1_dat", "gpt12_pwm_evt", "gpio_70",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART2_TX, 69,
|
||||
"uart2_tx", "usb1_se0", "gpt11_pwm_evt", "gpio_69",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART3_CTS_RCTX, 102,
|
||||
"uart3_cts_rctx", "uart3_rx_irrx", NULL, "gpio_102",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART3_RTS_SD, 103,
|
||||
"uart3_rts_sd", "uart3_tx_irtx", NULL, "gpio_103",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART3_RX_IRRX, 105,
|
||||
"uart3_rx_irrx", NULL, NULL, "gpio_105",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(UART3_TX_IRTX, 104,
|
||||
"uart3_tx_irtx", "uart3_cts_rctx", NULL, "gpio_104",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_CLK, 120,
|
||||
"usb0hs_clk", NULL, NULL, "gpio_120",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_DATA0, 0,
|
||||
"usb0hs_data0", "uart3_tx_irtx", NULL, NULL,
|
||||
"usb0_txen", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_DATA1, 0,
|
||||
"usb0hs_data1", "uart3_rx_irrx", NULL, NULL,
|
||||
"usb0_dat", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_DATA2, 0,
|
||||
"usb0hs_data2", "uart3_rts_sd", NULL, NULL,
|
||||
"usb0_se0", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_DATA3, 106,
|
||||
"usb0hs_data3", NULL, "uart3_cts_rctx", "gpio_106",
|
||||
"usb0_puen", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_DATA4, 107,
|
||||
"usb0hs_data4", "mcbsp2_dr", NULL, "gpio_107",
|
||||
"usb0_vp", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_DATA5, 108,
|
||||
"usb0hs_data5", "mcbsp2_dx", NULL, "gpio_108",
|
||||
"usb0_vm", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_DATA6, 109,
|
||||
"usb0hs_data6", "mcbsp2_fsx", NULL, "gpio_109",
|
||||
"usb0_rcv", NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_DATA7, 124,
|
||||
"usb0hs_data7", "mcbsp2_clkx", NULL, "gpio_124",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_DIR, 121,
|
||||
"usb0hs_dir", NULL, NULL, "gpio_121",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_NXT, 123,
|
||||
"usb0hs_nxt", NULL, NULL, "gpio_123",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
_OMAP2430_MUXENTRY(USB0HS_STP, 122,
|
||||
"usb0hs_stp", NULL, NULL, "gpio_122",
|
||||
NULL, NULL, NULL, "safe_mode"),
|
||||
{ .reg_offset = OMAP_MUX_TERMINATOR },
|
||||
};
|
||||
|
||||
/*
|
||||
* Balls for POP package
|
||||
* 447-pin s-PBGA Package, 0.00mm Ball Pitch (Bottom)
|
||||
*/
|
||||
#ifdef CONFIG_DEBUG_FS
|
||||
static struct omap_ball __initdata omap2430_pop_ball[] = {
|
||||
_OMAP2430_BALLENTRY(CAM_D0, "t8", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D1, "t4", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D10, "r4", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D11, "w3", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D2, "r2", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D3, "u3", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D4, "u2", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D5, "v1", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D6, "t3", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D7, "r3", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D8, "u7", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_D9, "t7", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_HS, "p2", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_LCLK, "r7", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_VS, "n2", NULL),
|
||||
_OMAP2430_BALLENTRY(CAM_XCLK, "p3", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_ACBIAS, "y3", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA0, "v8", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA1, "w1", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA10, "k25", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA11, "j25", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA12, "k24", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA13, "j24", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA14, "h25", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA15, "g25", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA16, "ac3", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA17, "y7", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA2, "u8", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA3, "u4", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA4, "v3", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA5, "aa4", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA6, "w8", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA7, "y1", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA8, "aa2", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_DATA9, "ab4", NULL),
|
||||
_OMAP2430_BALLENTRY(DSS_HSYNC, "v2", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_113, "ad16", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_114, "ac10", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_115, "ad13", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_116, "ae15", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_128, "p1", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_129, "r1", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_130, "p7", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_131, "l8", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_132, "w24", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_133, "aa24", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_134, "ae12", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_135, "ae11", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_136, "ad12", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_137, "ad11", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_138, "y12", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_139, "ad17", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_140, "l7", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_141, "ac24", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_142, "m3", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_148, "af12", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_149, "k7", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_150, "m1", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_151, "ad14", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_152, "ad18", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_153, "u24", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_154, "ae16", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_63, "n3", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_7, "ac23", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_78, "ad10", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_79, "ae10", NULL),
|
||||
_OMAP2430_BALLENTRY(GPIO_80, "ae13", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_A1, "a9", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_A10, "g12", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_A2, "b8", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_A3, "g10", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_A4, "g11", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_A5, "a10", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_A6, "g13", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_A7, "a6", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_A8, "h1", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_A9, "c8", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_CLK, "n1", "l1"),
|
||||
_OMAP2430_BALLENTRY(GPMC_D10, "d1", "n1"),
|
||||
_OMAP2430_BALLENTRY(GPMC_D11, "d2", "p2"),
|
||||
_OMAP2430_BALLENTRY(GPMC_D12, "e1", "p1"),
|
||||
_OMAP2430_BALLENTRY(GPMC_D13, "e3", "m1"),
|
||||
_OMAP2430_BALLENTRY(GPMC_D14, "c7", "j2"),
|
||||
_OMAP2430_BALLENTRY(GPMC_D15, "f3", "k2"),
|
||||
_OMAP2430_BALLENTRY(GPMC_D8, "e2", "r1"),
|
||||
_OMAP2430_BALLENTRY(GPMC_D9, "ab1", "t1"),
|
||||
_OMAP2430_BALLENTRY(GPMC_NCS1, "ac1", "w1"),
|
||||
_OMAP2430_BALLENTRY(GPMC_NCS2, "c6", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_NCS3, "b9", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_NCS4, "b4", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_NCS5, "a4", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_NCS6, "f1", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_NCS7, "a7", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_WAIT1, "j1", "y8"),
|
||||
_OMAP2430_BALLENTRY(GPMC_WAIT2, "b7", NULL),
|
||||
_OMAP2430_BALLENTRY(GPMC_WAIT3, "g14", NULL),
|
||||
_OMAP2430_BALLENTRY(HDQ_SIO, "h20", NULL),
|
||||
_OMAP2430_BALLENTRY(I2C1_SCL, "y17", NULL),
|
||||
_OMAP2430_BALLENTRY(I2C1_SDA, "ac19", NULL),
|
||||
_OMAP2430_BALLENTRY(I2C2_SCL, "n7", NULL),
|
||||
_OMAP2430_BALLENTRY(I2C2_SDA, "m4", NULL),
|
||||
_OMAP2430_BALLENTRY(JTAG_EMU0, "e25", NULL),
|
||||
_OMAP2430_BALLENTRY(JTAG_EMU1, "e24", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP1_CLKR, "ab2", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP1_CLKX, "y9", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP1_DR, "af3", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP1_DX, "aa1", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP1_FSR, "ad5", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP1_FSX, "ab3", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP2_CLKX, "j26", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP2_DR, "k26", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP3_CLKX, "ac9", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP3_DR, "ae2", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP3_DX, "af4", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP3_FSX, "ae4", NULL),
|
||||
_OMAP2430_BALLENTRY(MCBSP_CLKS, "ad6", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC1_CLKO, "n23", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC1_CMD, "l23", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC1_DAT0, "m24", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC1_DAT1, "p23", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC1_DAT2, "t20", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC1_DAT3, "r20", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC2_CLKO, "v26", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC2_CMD, "w20", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC2_DAT0, "v23", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC2_DAT1, "y24", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC2_DAT2, "v25", NULL),
|
||||
_OMAP2430_BALLENTRY(SDMMC2_DAT3, "v24", NULL),
|
||||
_OMAP2430_BALLENTRY(SDRC_A12, "w26", "r21"),
|
||||
_OMAP2430_BALLENTRY(SDRC_A13, "af20", "aa15"),
|
||||
_OMAP2430_BALLENTRY(SDRC_A14, "af16", "y12"),
|
||||
_OMAP2430_BALLENTRY(SDRC_CKE1, "af15", "y13"),
|
||||
_OMAP2430_BALLENTRY(SDRC_NCS1, "aa25", "t20"),
|
||||
_OMAP2430_BALLENTRY(SPI1_CLK, "y18", NULL),
|
||||
_OMAP2430_BALLENTRY(SPI1_CS0, "u1", NULL),
|
||||
_OMAP2430_BALLENTRY(SPI1_CS1, "af19", NULL),
|
||||
_OMAP2430_BALLENTRY(SPI1_CS2, "ae19", NULL),
|
||||
_OMAP2430_BALLENTRY(SPI1_CS3, "h24", NULL),
|
||||
_OMAP2430_BALLENTRY(SPI1_SIMO, "ad15", NULL),
|
||||
_OMAP2430_BALLENTRY(SPI1_SOMI, "ae17", NULL),
|
||||
_OMAP2430_BALLENTRY(SPI2_CLK, "y20", NULL),
|
||||
_OMAP2430_BALLENTRY(SPI2_CS0, "y19", NULL),
|
||||
_OMAP2430_BALLENTRY(SPI2_SIMO, "ac20", NULL),
|
||||
_OMAP2430_BALLENTRY(SPI2_SOMI, "ad19", NULL),
|
||||
_OMAP2430_BALLENTRY(SSI1_DAT_RX, "aa26", NULL),
|
||||
_OMAP2430_BALLENTRY(SSI1_DAT_TX, "ad24", NULL),
|
||||
_OMAP2430_BALLENTRY(SSI1_FLAG_RX, "ad23", NULL),
|
||||
_OMAP2430_BALLENTRY(SSI1_FLAG_TX, "ab24", NULL),
|
||||
_OMAP2430_BALLENTRY(SSI1_RDY_RX, "ab25", NULL),
|
||||
_OMAP2430_BALLENTRY(SSI1_RDY_TX, "y25", NULL),
|
||||
_OMAP2430_BALLENTRY(SSI1_WAKE, "ac25", NULL),
|
||||
_OMAP2430_BALLENTRY(SYS_CLKOUT, "r25", NULL),
|
||||
_OMAP2430_BALLENTRY(SYS_DRM_MSECURE, "ae3", NULL),
|
||||
_OMAP2430_BALLENTRY(SYS_NIRQ0, "w25", NULL),
|
||||
_OMAP2430_BALLENTRY(SYS_NIRQ1, "ad21", NULL),
|
||||
_OMAP2430_BALLENTRY(UART1_CTS, "p24", NULL),
|
||||
_OMAP2430_BALLENTRY(UART1_RTS, "p25", NULL),
|
||||
_OMAP2430_BALLENTRY(UART1_RX, "n24", NULL),
|
||||
_OMAP2430_BALLENTRY(UART1_TX, "r24", NULL),
|
||||
_OMAP2430_BALLENTRY(UART2_CTS, "u25", NULL),
|
||||
_OMAP2430_BALLENTRY(UART2_RTS, "t23", NULL),
|
||||
_OMAP2430_BALLENTRY(UART2_RX, "t24", NULL),
|
||||
_OMAP2430_BALLENTRY(UART2_TX, "u20", NULL),
|
||||
_OMAP2430_BALLENTRY(UART3_CTS_RCTX, "m2", NULL),
|
||||
_OMAP2430_BALLENTRY(UART3_RTS_SD, "k2", NULL),
|
||||
_OMAP2430_BALLENTRY(UART3_RX_IRRX, "l3", NULL),
|
||||
_OMAP2430_BALLENTRY(UART3_TX_IRTX, "l2", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_CLK, "ae8", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_DATA0, "ad4", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_DATA1, "ae6", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_DATA2, "af9", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_DATA3, "ad9", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_DATA4, "y11", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_DATA5, "ad7", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_DATA6, "ae7", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_DATA7, "ac7", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_DIR, "ad8", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_NXT, "ae9", NULL),
|
||||
_OMAP2430_BALLENTRY(USB0HS_STP, "ae5", NULL),
|
||||
{ .reg_offset = OMAP_MUX_TERMINATOR },
|
||||
};
|
||||
#else
|
||||
#define omap2430_pop_ball NULL
|
||||
#endif
|
||||
|
||||
int __init omap2430_mux_init(struct omap_board_mux *board_subset, int flags)
|
||||
{
|
||||
struct omap_ball *package_balls = NULL;
|
||||
|
||||
switch (flags & OMAP_PACKAGE_MASK) {
|
||||
case OMAP_PACKAGE_ZAC:
|
||||
package_balls = omap2430_pop_ball;
|
||||
break;
|
||||
default:
|
||||
pr_warning("%s: No ball data available for omap2420 package\n",
|
||||
__func__);
|
||||
}
|
||||
|
||||
return omap_mux_init("core", OMAP_MUX_REG_8BIT | OMAP_MUX_GPIO_IN_MODE3,
|
||||
OMAP2430_CONTROL_PADCONF_MUX_PBASE,
|
||||
OMAP2430_CONTROL_PADCONF_MUX_SIZE,
|
||||
omap2430_muxmodes, NULL, board_subset,
|
||||
package_balls);
|
||||
}
|
|
@ -1,370 +0,0 @@
|
|||
/*
|
||||
* Copyright (C) 2009 Nokia
|
||||
* Copyright (C) 2009 Texas Instruments
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#define OMAP2430_CONTROL_PADCONF_MUX_PBASE 0x49002030LU
|
||||
|
||||
#define OMAP2430_MUX(mode0, mux_value) \
|
||||
{ \
|
||||
.reg_offset = (OMAP2430_CONTROL_PADCONF_##mode0##_OFFSET), \
|
||||
.value = (mux_value), \
|
||||
}
|
||||
|
||||
/*
|
||||
* OMAP2430 CONTROL_PADCONF* register offsets for pin-muxing
|
||||
*
|
||||
* Extracted from the TRM. Add 0x49002030 to these values to get the
|
||||
* absolute addresses. The name in the macro is the mode-0 name of
|
||||
* the pin. NOTE: These registers are 8-bits wide.
|
||||
*
|
||||
* Note that these defines use SDMMC instead of MMC for compatibility
|
||||
* with signal names used in 3630.
|
||||
*/
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_CLK_OFFSET 0x000
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NCS0_OFFSET 0x001
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NCS1_OFFSET 0x002
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NCS2_OFFSET 0x003
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NCS3_OFFSET 0x004
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NCS4_OFFSET 0x005
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NCS5_OFFSET 0x006
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NCS6_OFFSET 0x007
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NCS7_OFFSET 0x008
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NADV_ALE_OFFSET 0x009
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NOE_NRE_OFFSET 0x00a
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NWE_OFFSET 0x00b
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NBE0_CLE_OFFSET 0x00c
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NBE1_OFFSET 0x00d
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_NWP_OFFSET 0x00e
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_WAIT0_OFFSET 0x00f
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_WAIT1_OFFSET 0x010
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_WAIT2_OFFSET 0x011
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_WAIT3_OFFSET 0x012
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_CLK_OFFSET 0x013
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_NCLK_OFFSET 0x014
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_NCS0_OFFSET 0x015
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_NCS1_OFFSET 0x016
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_CKE0_OFFSET 0x017
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_CKE1_OFFSET 0x018
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_NRAS_OFFSET 0x019
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_NCAS_OFFSET 0x01a
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_NWE_OFFSET 0x01b
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_DM0_OFFSET 0x01c
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_DM1_OFFSET 0x01d
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_DM2_OFFSET 0x01e
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_DM3_OFFSET 0x01f
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_DQS0_OFFSET 0x020
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_DQS1_OFFSET 0x021
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_DQS2_OFFSET 0x022
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_DQS3_OFFSET 0x023
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A14_OFFSET 0x024
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A13_OFFSET 0x025
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A12_OFFSET 0x026
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_BA1_OFFSET 0x027
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_BA0_OFFSET 0x028
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A11_OFFSET 0x029
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A10_OFFSET 0x02a
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A9_OFFSET 0x02b
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A8_OFFSET 0x02c
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A7_OFFSET 0x02d
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A6_OFFSET 0x02e
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A5_OFFSET 0x02f
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A4_OFFSET 0x030
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A3_OFFSET 0x031
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A2_OFFSET 0x032
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A1_OFFSET 0x033
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_A0_OFFSET 0x034
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D31_OFFSET 0x035
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D30_OFFSET 0x036
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D29_OFFSET 0x037
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D28_OFFSET 0x038
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D27_OFFSET 0x039
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D26_OFFSET 0x03a
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D25_OFFSET 0x03b
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D24_OFFSET 0x03c
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D23_OFFSET 0x03d
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D22_OFFSET 0x03e
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D21_OFFSET 0x03f
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D20_OFFSET 0x040
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D19_OFFSET 0x041
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D18_OFFSET 0x042
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D17_OFFSET 0x043
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D16_OFFSET 0x044
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D15_OFFSET 0x045
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D14_OFFSET 0x046
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D13_OFFSET 0x047
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D12_OFFSET 0x048
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D11_OFFSET 0x049
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D10_OFFSET 0x04a
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D9_OFFSET 0x04b
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D8_OFFSET 0x04c
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D7_OFFSET 0x04d
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D6_OFFSET 0x04e
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D5_OFFSET 0x04f
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D4_OFFSET 0x050
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D3_OFFSET 0x051
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D2_OFFSET 0x052
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D1_OFFSET 0x053
|
||||
#define OMAP2430_CONTROL_PADCONF_SDRC_D0_OFFSET 0x054
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_A10_OFFSET 0x055
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_A9_OFFSET 0x056
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_A8_OFFSET 0x057
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_A7_OFFSET 0x058
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_A6_OFFSET 0x059
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_A5_OFFSET 0x05a
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_A4_OFFSET 0x05b
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_A3_OFFSET 0x05c
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_A2_OFFSET 0x05d
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_A1_OFFSET 0x05e
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D15_OFFSET 0x05f
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D14_OFFSET 0x060
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D13_OFFSET 0x061
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D12_OFFSET 0x062
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D11_OFFSET 0x063
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D10_OFFSET 0x064
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D9_OFFSET 0x065
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D8_OFFSET 0x066
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D7_OFFSET 0x067
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D6_OFFSET 0x068
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D5_OFFSET 0x069
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D4_OFFSET 0x06a
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D3_OFFSET 0x06b
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D2_OFFSET 0x06c
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D1_OFFSET 0x06d
|
||||
#define OMAP2430_CONTROL_PADCONF_GPMC_D0_OFFSET 0x06e
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA0_OFFSET 0x06f
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA1_OFFSET 0x070
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA2_OFFSET 0x071
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA3_OFFSET 0x072
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA4_OFFSET 0x073
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA5_OFFSET 0x074
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA6_OFFSET 0x075
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA7_OFFSET 0x076
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA8_OFFSET 0x077
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA9_OFFSET 0x078
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA10_OFFSET 0x079
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA11_OFFSET 0x07a
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA12_OFFSET 0x07b
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA13_OFFSET 0x07c
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA14_OFFSET 0x07d
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA15_OFFSET 0x07e
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA16_OFFSET 0x07f
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_DATA17_OFFSET 0x080
|
||||
#define OMAP2430_CONTROL_PADCONF_UART1_CTS_OFFSET 0x081
|
||||
#define OMAP2430_CONTROL_PADCONF_UART1_RTS_OFFSET 0x082
|
||||
#define OMAP2430_CONTROL_PADCONF_UART1_TX_OFFSET 0x083
|
||||
#define OMAP2430_CONTROL_PADCONF_UART1_RX_OFFSET 0x084
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP2_DR_OFFSET 0x085
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP2_CLKX_OFFSET 0x086
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_PCLK_OFFSET 0x087
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_VSYNC_OFFSET 0x088
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_HSYNC_OFFSET 0x089
|
||||
#define OMAP2430_CONTROL_PADCONF_DSS_ACBIAS_OFFSET 0x08a
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_NRESPWRON_OFFSET 0x08b
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_NRESWARM_OFFSET 0x08c
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_NIRQ0_OFFSET 0x08d
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_NIRQ1_OFFSET 0x08e
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_VMODE_OFFSET 0x08f
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_128_OFFSET 0x090
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_129_OFFSET 0x091
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_130_OFFSET 0x092
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_131_OFFSET 0x093
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_32K_OFFSET 0x094
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_XTALIN_OFFSET 0x095
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_XTALOUT_OFFSET 0x096
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_132_OFFSET 0x097
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_CLKREQ_OFFSET 0x098
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_CLKOUT_OFFSET 0x099
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_151_OFFSET 0x09a
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_133_OFFSET 0x09b
|
||||
#define OMAP2430_CONTROL_PADCONF_JTAG_EMU1_OFFSET 0x09c
|
||||
#define OMAP2430_CONTROL_PADCONF_JTAG_EMU0_OFFSET 0x09d
|
||||
#define OMAP2430_CONTROL_PADCONF_JTAG_NTRST_OFFSET 0x09e
|
||||
#define OMAP2430_CONTROL_PADCONF_JTAG_TCK_OFFSET 0x09f
|
||||
#define OMAP2430_CONTROL_PADCONF_JTAG_RTCK_OFFSET 0x0a0
|
||||
#define OMAP2430_CONTROL_PADCONF_JTAG_TMS_OFFSET 0x0a1
|
||||
#define OMAP2430_CONTROL_PADCONF_JTAG_TDI_OFFSET 0x0a2
|
||||
#define OMAP2430_CONTROL_PADCONF_JTAG_TDO_OFFSET 0x0a3
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D9_OFFSET 0x0a4
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D8_OFFSET 0x0a5
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D7_OFFSET 0x0a6
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D6_OFFSET 0x0a7
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D5_OFFSET 0x0a8
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D4_OFFSET 0x0a9
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D3_OFFSET 0x0aa
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D2_OFFSET 0x0ab
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D1_OFFSET 0x0ac
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D0_OFFSET 0x0ad
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_HS_OFFSET 0x0ae
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_VS_OFFSET 0x0af
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_LCLK_OFFSET 0x0b0
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_XCLK_OFFSET 0x0b1
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D11_OFFSET 0x0b2
|
||||
#define OMAP2430_CONTROL_PADCONF_CAM_D10_OFFSET 0x0b3
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_134_OFFSET 0x0b4
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_135_OFFSET 0x0b5
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_136_OFFSET 0x0b6
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_137_OFFSET 0x0b7
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_138_OFFSET 0x0b8
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_139_OFFSET 0x0b9
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_140_OFFSET 0x0ba
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_141_OFFSET 0x0bb
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_142_OFFSET 0x0bc
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_154_OFFSET 0x0bd
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_148_OFFSET 0x0be
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_149_OFFSET 0x0bf
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_150_OFFSET 0x0c0
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_152_OFFSET 0x0c1
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_153_OFFSET 0x0c2
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC1_CLKO_OFFSET 0x0c3
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC1_CMD_OFFSET 0x0c4
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC1_DAT0_OFFSET 0x0c5
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC1_DAT1_OFFSET 0x0c6
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC1_DAT2_OFFSET 0x0c7
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC1_DAT3_OFFSET 0x0c8
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC2_CLKO_OFFSET 0x0c9
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC2_DAT3_OFFSET 0x0ca
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC2_CMD_OFFSET 0x0cb
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC2_DAT0_OFFSET 0x0cc
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC2_DAT2_OFFSET 0x0cd
|
||||
#define OMAP2430_CONTROL_PADCONF_SDMMC2_DAT1_OFFSET 0x0ce
|
||||
#define OMAP2430_CONTROL_PADCONF_UART2_CTS_OFFSET 0x0cf
|
||||
#define OMAP2430_CONTROL_PADCONF_UART2_RTS_OFFSET 0x0d0
|
||||
#define OMAP2430_CONTROL_PADCONF_UART2_TX_OFFSET 0x0d1
|
||||
#define OMAP2430_CONTROL_PADCONF_UART2_RX_OFFSET 0x0d2
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP3_CLKX_OFFSET 0x0d3
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP3_FSX_OFFSET 0x0d4
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP3_DR_OFFSET 0x0d5
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP3_DX_OFFSET 0x0d6
|
||||
#define OMAP2430_CONTROL_PADCONF_SSI1_DAT_TX_OFFSET 0x0d7
|
||||
#define OMAP2430_CONTROL_PADCONF_SSI1_FLAG_TX_OFFSET 0x0d8
|
||||
#define OMAP2430_CONTROL_PADCONF_SSI1_RDY_TX_OFFSET 0x0d9
|
||||
#define OMAP2430_CONTROL_PADCONF_SSI1_DAT_RX_OFFSET 0x0da
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_63_OFFSET 0x0db
|
||||
#define OMAP2430_CONTROL_PADCONF_SSI1_FLAG_RX_OFFSET 0x0dc
|
||||
#define OMAP2430_CONTROL_PADCONF_SSI1_RDY_RX_OFFSET 0x0dd
|
||||
#define OMAP2430_CONTROL_PADCONF_SSI1_WAKE_OFFSET 0x0de
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI1_CLK_OFFSET 0x0df
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI1_SIMO_OFFSET 0x0e0
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI1_SOMI_OFFSET 0x0e1
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI1_CS0_OFFSET 0x0e2
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI1_CS1_OFFSET 0x0e3
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI1_CS2_OFFSET 0x0e4
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI1_CS3_OFFSET 0x0e5
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI2_CLK_OFFSET 0x0e6
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI2_SIMO_OFFSET 0x0e7
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI2_SOMI_OFFSET 0x0e8
|
||||
#define OMAP2430_CONTROL_PADCONF_SPI2_CS0_OFFSET 0x0e9
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP1_CLKR_OFFSET 0x0ea
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP1_FSR_OFFSET 0x0eb
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP1_DX_OFFSET 0x0ec
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP1_DR_OFFSET 0x0ed
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP_CLKS_OFFSET 0x0ee
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP1_FSX_OFFSET 0x0ef
|
||||
#define OMAP2430_CONTROL_PADCONF_MCBSP1_CLKX_OFFSET 0x0f0
|
||||
#define OMAP2430_CONTROL_PADCONF_I2C1_SCL_OFFSET 0x0f1
|
||||
#define OMAP2430_CONTROL_PADCONF_I2C1_SDA_OFFSET 0x0f2
|
||||
#define OMAP2430_CONTROL_PADCONF_I2C2_SCL_OFFSET 0x0f3
|
||||
#define OMAP2430_CONTROL_PADCONF_I2C2_SDA_OFFSET 0x0f4
|
||||
#define OMAP2430_CONTROL_PADCONF_HDQ_SIO_OFFSET 0x0f5
|
||||
#define OMAP2430_CONTROL_PADCONF_UART3_CTS_RCTX_OFFSET 0x0f6
|
||||
#define OMAP2430_CONTROL_PADCONF_UART3_RTS_SD_OFFSET 0x0f7
|
||||
#define OMAP2430_CONTROL_PADCONF_UART3_TX_IRTX_OFFSET 0x0f8
|
||||
#define OMAP2430_CONTROL_PADCONF_UART3_RX_IRRX_OFFSET 0x0f9
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_7_OFFSET 0x0fa
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_78_OFFSET 0x0fb
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_79_OFFSET 0x0fc
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_80_OFFSET 0x0fd
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_113_OFFSET 0x0fe
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_114_OFFSET 0x0ff
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_115_OFFSET 0x100
|
||||
#define OMAP2430_CONTROL_PADCONF_GPIO_116_OFFSET 0x101
|
||||
#define OMAP2430_CONTROL_PADCONF_SYS_DRM_MSECURE_OFFSET 0x102
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_DATA3_OFFSET 0x103
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_DATA4_OFFSET 0x104
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_DATA5_OFFSET 0x105
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_DATA6_OFFSET 0x106
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_DATA2_OFFSET 0x107
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_DATA0_OFFSET 0x108
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_DATA1_OFFSET 0x109
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_CLK_OFFSET 0x10a
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_DIR_OFFSET 0x10b
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_STP_OFFSET 0x10c
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_NXT_OFFSET 0x10d
|
||||
#define OMAP2430_CONTROL_PADCONF_USB0HS_DATA7_OFFSET 0x10e
|
||||
#define OMAP2430_CONTROL_PADCONF_TV_OUT_OFFSET 0x10f
|
||||
#define OMAP2430_CONTROL_PADCONF_TV_VREF_OFFSET 0x110
|
||||
#define OMAP2430_CONTROL_PADCONF_TV_RSET_OFFSET 0x111
|
||||
#define OMAP2430_CONTROL_PADCONF_TV_VFB_OFFSET 0x112
|
||||
#define OMAP2430_CONTROL_PADCONF_TV_DACOUT_OFFSET 0x113
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD0_OFFSET 0x114
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD1_OFFSET 0x115
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD2_OFFSET 0x116
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD3_OFFSET 0x117
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD4_OFFSET 0x118
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD5_OFFSET 0x119
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD6_OFFSET 0x11a
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD7_OFFSET 0x11b
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD8_OFFSET 0x11c
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD9_OFFSET 0x11d
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD10_OFFSET 0x11e
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD11_OFFSET 0x11f
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD12_OFFSET 0x120
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD13_OFFSET 0x121
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD14_OFFSET 0x122
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD15_OFFSET 0x123
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD16_OFFSET 0x124
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD17_OFFSET 0x125
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD18_OFFSET 0x126
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD19_OFFSET 0x127
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD20_OFFSET 0x128
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD21_OFFSET 0x129
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD22_OFFSET 0x12a
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD23_OFFSET 0x12b
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD24_OFFSET 0x12c
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD25_OFFSET 0x12d
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD26_OFFSET 0x12e
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD27_OFFSET 0x12f
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD28_OFFSET 0x130
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD29_OFFSET 0x131
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD30_OFFSET 0x132
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD31_OFFSET 0x133
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD32_OFFSET 0x134
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD33_OFFSET 0x135
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD34_OFFSET 0x136
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD35_OFFSET 0x137
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD36_OFFSET 0x138
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMCAD37_OFFSET 0x139
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMWRITE_OFFSET 0x13a
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DCLK26MI_OFFSET 0x13b
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DNRESPWRON1_OFFSET 0x13c
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DNRESWARM_OFFSET 0x13d
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DARM9NIRQ_OFFSET 0x13e
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DUMA2P6FIQ_OFFSET 0x13f
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DSPINT_OFFSET 0x140
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DFRINT_OFFSET 0x141
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DDMAREQ0_OFFSET 0x142
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DDMAREQ1_OFFSET 0x143
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DDMAREQ2_OFFSET 0x144
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DDMAREQ3_OFFSET 0x145
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DN3GTRST_OFFSET 0x146
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DN3GTDI_OFFSET 0x147
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DN3GTDO_OFFSET 0x148
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DN3GTMS_OFFSET 0x149
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DN3GTCK_OFFSET 0x14a
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DN3GRTCK_OFFSET 0x14b
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DMSTDBY_OFFSET 0x14c
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DSREAD_OFFSET 0x14d
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DSWAKEUP_OFFSET 0x14e
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DIDLEREQ_OFFSET 0x14f
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DIDLEACK_OFFSET 0x150
|
||||
#define OMAP2430_CONTROL_PADCONF_D2DSPARE0_OFFSET 0x151
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DSWRITE_OFFSET 0x152
|
||||
#define OMAP2430_CONTROL_PADCONF_AD2DMREAD_OFFSET 0x153
|
||||
|
||||
#define OMAP2430_CONTROL_PADCONF_MUX_SIZE \
|
||||
(OMAP2430_CONTROL_PADCONF_AD2DMREAD_OFFSET + 0x1)
|
|
@ -36,6 +36,7 @@
|
|||
#include <linux/of.h>
|
||||
#include <linux/notifier.h>
|
||||
|
||||
#include "common.h"
|
||||
#include "soc.h"
|
||||
#include "omap_device.h"
|
||||
#include "omap_hwmod.h"
|
||||
|
@ -204,6 +205,7 @@ static int _omap_device_notifier_call(struct notifier_block *nb,
|
|||
case BUS_NOTIFY_ADD_DEVICE:
|
||||
if (pdev->dev.of_node)
|
||||
omap_device_build_from_dt(pdev);
|
||||
omap_auxdata_legacy_init(dev);
|
||||
/* fall through */
|
||||
default:
|
||||
od = to_omap_device(pdev);
|
||||
|
|
|
@ -108,8 +108,6 @@ static struct omap_i2c_dev_attr i2c_dev_attr = {
|
|||
/* I2C1 */
|
||||
static struct omap_hwmod omap2420_i2c1_hwmod = {
|
||||
.name = "i2c1",
|
||||
.mpu_irqs = omap2_i2c1_mpu_irqs,
|
||||
.sdma_reqs = omap2_i2c1_sdma_reqs,
|
||||
.main_clk = "i2c1_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -133,8 +131,6 @@ static struct omap_hwmod omap2420_i2c1_hwmod = {
|
|||
/* I2C2 */
|
||||
static struct omap_hwmod omap2420_i2c2_hwmod = {
|
||||
.name = "i2c2",
|
||||
.mpu_irqs = omap2_i2c2_mpu_irqs,
|
||||
.sdma_reqs = omap2_i2c2_sdma_reqs,
|
||||
.main_clk = "i2c2_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -179,16 +175,9 @@ static struct omap_mbox_pdata omap2420_mailbox_attrs = {
|
|||
.info = omap2420_mailbox_info,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_irq_info omap2420_mailbox_irqs[] = {
|
||||
{ .name = "dsp", .irq = 26 + OMAP_INTC_START, },
|
||||
{ .name = "iva", .irq = 34 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2420_mailbox_hwmod = {
|
||||
.name = "mailbox",
|
||||
.class = &omap2xxx_mailbox_hwmod_class,
|
||||
.mpu_irqs = omap2420_mailbox_irqs,
|
||||
.main_clk = "mailboxes_ick",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -217,17 +206,9 @@ static struct omap_hwmod_opt_clk mcbsp_opt_clks[] = {
|
|||
};
|
||||
|
||||
/* mcbsp1 */
|
||||
static struct omap_hwmod_irq_info omap2420_mcbsp1_irqs[] = {
|
||||
{ .name = "tx", .irq = 59 + OMAP_INTC_START, },
|
||||
{ .name = "rx", .irq = 60 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2420_mcbsp1_hwmod = {
|
||||
.name = "mcbsp1",
|
||||
.class = &omap2420_mcbsp_hwmod_class,
|
||||
.mpu_irqs = omap2420_mcbsp1_irqs,
|
||||
.sdma_reqs = omap2_mcbsp1_sdma_reqs,
|
||||
.main_clk = "mcbsp1_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -243,17 +224,9 @@ static struct omap_hwmod omap2420_mcbsp1_hwmod = {
|
|||
};
|
||||
|
||||
/* mcbsp2 */
|
||||
static struct omap_hwmod_irq_info omap2420_mcbsp2_irqs[] = {
|
||||
{ .name = "tx", .irq = 62 + OMAP_INTC_START, },
|
||||
{ .name = "rx", .irq = 63 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2420_mcbsp2_hwmod = {
|
||||
.name = "mcbsp2",
|
||||
.class = &omap2420_mcbsp_hwmod_class,
|
||||
.mpu_irqs = omap2420_mcbsp2_irqs,
|
||||
.sdma_reqs = omap2_mcbsp2_sdma_reqs,
|
||||
.main_clk = "mcbsp2_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -283,22 +256,9 @@ static struct omap_hwmod_class omap2420_msdi_hwmod_class = {
|
|||
};
|
||||
|
||||
/* msdi1 */
|
||||
static struct omap_hwmod_irq_info omap2420_msdi1_irqs[] = {
|
||||
{ .irq = 83 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod_dma_info omap2420_msdi1_sdma_reqs[] = {
|
||||
{ .name = "tx", .dma_req = 61 }, /* OMAP24XX_DMA_MMC1_TX */
|
||||
{ .name = "rx", .dma_req = 62 }, /* OMAP24XX_DMA_MMC1_RX */
|
||||
{ .dma_req = -1 }
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2420_msdi1_hwmod = {
|
||||
.name = "msdi1",
|
||||
.class = &omap2420_msdi_hwmod_class,
|
||||
.mpu_irqs = omap2420_msdi1_irqs,
|
||||
.sdma_reqs = omap2420_msdi1_sdma_reqs,
|
||||
.main_clk = "mmc_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -315,7 +275,6 @@ static struct omap_hwmod omap2420_msdi1_hwmod = {
|
|||
/* HDQ1W/1-wire */
|
||||
static struct omap_hwmod omap2420_hdq1w_hwmod = {
|
||||
.name = "hdq1w",
|
||||
.mpu_irqs = omap2_hdq1w_mpu_irqs,
|
||||
.main_clk = "hdq_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -338,7 +297,6 @@ static struct omap_hwmod_ocp_if omap2420_l4_core__i2c1 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2420_i2c1_hwmod,
|
||||
.clk = "i2c1_ick",
|
||||
.addr = omap2_i2c1_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -347,7 +305,6 @@ static struct omap_hwmod_ocp_if omap2420_l4_core__i2c2 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2420_i2c2_hwmod,
|
||||
.clk = "i2c2_ick",
|
||||
.addr = omap2_i2c2_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -367,111 +324,51 @@ static struct omap_hwmod_ocp_if omap2420_l3__dsp = {
|
|||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2420_timer1_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x48028000,
|
||||
.pa_end = 0x48028000 + SZ_1K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
/* l4_wkup -> timer1 */
|
||||
static struct omap_hwmod_ocp_if omap2420_l4_wkup__timer1 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_timer1_hwmod,
|
||||
.clk = "gpt1_ick",
|
||||
.addr = omap2420_timer1_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_wkup -> wd_timer2 */
|
||||
static struct omap_hwmod_addr_space omap2420_wd_timer2_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x48022000,
|
||||
.pa_end = 0x4802207f,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2420_l4_wkup__wd_timer2 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_wd_timer2_hwmod,
|
||||
.clk = "mpu_wdt_ick",
|
||||
.addr = omap2420_wd_timer2_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_wkup -> gpio1 */
|
||||
static struct omap_hwmod_addr_space omap2420_gpio1_addr_space[] = {
|
||||
{
|
||||
.pa_start = 0x48018000,
|
||||
.pa_end = 0x480181ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2420_l4_wkup__gpio1 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_gpio1_hwmod,
|
||||
.clk = "gpios_ick",
|
||||
.addr = omap2420_gpio1_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_wkup -> gpio2 */
|
||||
static struct omap_hwmod_addr_space omap2420_gpio2_addr_space[] = {
|
||||
{
|
||||
.pa_start = 0x4801a000,
|
||||
.pa_end = 0x4801a1ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2420_l4_wkup__gpio2 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_gpio2_hwmod,
|
||||
.clk = "gpios_ick",
|
||||
.addr = omap2420_gpio2_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_wkup -> gpio3 */
|
||||
static struct omap_hwmod_addr_space omap2420_gpio3_addr_space[] = {
|
||||
{
|
||||
.pa_start = 0x4801c000,
|
||||
.pa_end = 0x4801c1ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2420_l4_wkup__gpio3 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_gpio3_hwmod,
|
||||
.clk = "gpios_ick",
|
||||
.addr = omap2420_gpio3_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_wkup -> gpio4 */
|
||||
static struct omap_hwmod_addr_space omap2420_gpio4_addr_space[] = {
|
||||
{
|
||||
.pa_start = 0x4801e000,
|
||||
.pa_end = 0x4801e1ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2420_l4_wkup__gpio4 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_gpio4_hwmod,
|
||||
.clk = "gpios_ick",
|
||||
.addr = omap2420_gpio4_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -496,7 +393,6 @@ static struct omap_hwmod_ocp_if omap2420_l4_core__dma_system = {
|
|||
static struct omap_hwmod_ocp_if omap2420_l4_core__mailbox = {
|
||||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2420_mailbox_hwmod,
|
||||
.addr = omap2_mailbox_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -505,7 +401,6 @@ static struct omap_hwmod_ocp_if omap2420_l4_core__mcbsp1 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2420_mcbsp1_hwmod,
|
||||
.clk = "mcbsp1_ick",
|
||||
.addr = omap2_mcbsp1_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -514,25 +409,14 @@ static struct omap_hwmod_ocp_if omap2420_l4_core__mcbsp2 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2420_mcbsp2_hwmod,
|
||||
.clk = "mcbsp2_ick",
|
||||
.addr = omap2xxx_mcbsp2_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2420_msdi1_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x4809c000,
|
||||
.pa_end = 0x4809c000 + SZ_128 - 1,
|
||||
.flags = ADDR_TYPE_RT,
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
/* l4_core -> msdi1 */
|
||||
static struct omap_hwmod_ocp_if omap2420_l4_core__msdi1 = {
|
||||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2420_msdi1_hwmod,
|
||||
.clk = "mmc_ick",
|
||||
.addr = omap2420_msdi1_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -541,36 +425,16 @@ static struct omap_hwmod_ocp_if omap2420_l4_core__hdq1w = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2420_hdq1w_hwmod,
|
||||
.clk = "hdq_ick",
|
||||
.addr = omap2_hdq1w_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
.flags = OMAP_FIREWALL_L4 | OCPIF_SWSUP_IDLE,
|
||||
};
|
||||
|
||||
|
||||
/* l4_wkup -> 32ksync_counter */
|
||||
static struct omap_hwmod_addr_space omap2420_counter_32k_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x48004000,
|
||||
.pa_end = 0x4800401f,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2420_gpmc_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x6800a000,
|
||||
.pa_end = 0x6800afff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2420_l4_wkup__counter_32k = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_counter_32k_hwmod,
|
||||
.clk = "sync_32k_ick",
|
||||
.addr = omap2420_counter_32k_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -578,7 +442,6 @@ static struct omap_hwmod_ocp_if omap2420_l3__gpmc = {
|
|||
.master = &omap2xxx_l3_main_hwmod,
|
||||
.slave = &omap2xxx_gpmc_hwmod,
|
||||
.clk = "core_l3_ck",
|
||||
.addr = omap2420_gpmc_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
|
|
@ -86,8 +86,6 @@ static struct omap_i2c_dev_attr i2c_dev_attr = {
|
|||
static struct omap_hwmod omap2430_i2c1_hwmod = {
|
||||
.name = "i2c1",
|
||||
.flags = HWMOD_16BIT_REG,
|
||||
.mpu_irqs = omap2_i2c1_mpu_irqs,
|
||||
.sdma_reqs = omap2_i2c1_sdma_reqs,
|
||||
.main_clk = "i2chs1_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -114,8 +112,6 @@ static struct omap_hwmod omap2430_i2c1_hwmod = {
|
|||
static struct omap_hwmod omap2430_i2c2_hwmod = {
|
||||
.name = "i2c2",
|
||||
.flags = HWMOD_16BIT_REG,
|
||||
.mpu_irqs = omap2_i2c2_mpu_irqs,
|
||||
.sdma_reqs = omap2_i2c2_sdma_reqs,
|
||||
.main_clk = "i2chs2_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -131,15 +127,9 @@ static struct omap_hwmod omap2430_i2c2_hwmod = {
|
|||
};
|
||||
|
||||
/* gpio5 */
|
||||
static struct omap_hwmod_irq_info omap243x_gpio5_irqs[] = {
|
||||
{ .irq = 33 + OMAP_INTC_START, }, /* INT_24XX_GPIO_BANK5 */
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2430_gpio5_hwmod = {
|
||||
.name = "gpio5",
|
||||
.flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
|
||||
.mpu_irqs = omap243x_gpio5_irqs,
|
||||
.main_clk = "gpio5_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -182,15 +172,9 @@ static struct omap_mbox_pdata omap2430_mailbox_attrs = {
|
|||
.info = omap2430_mailbox_info,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_irq_info omap2430_mailbox_irqs[] = {
|
||||
{ .irq = 26 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2430_mailbox_hwmod = {
|
||||
.name = "mailbox",
|
||||
.class = &omap2xxx_mailbox_hwmod_class,
|
||||
.mpu_irqs = omap2430_mailbox_irqs,
|
||||
.main_clk = "mailboxes_ick",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -205,27 +189,12 @@ static struct omap_hwmod omap2430_mailbox_hwmod = {
|
|||
};
|
||||
|
||||
/* mcspi3 */
|
||||
static struct omap_hwmod_irq_info omap2430_mcspi3_mpu_irqs[] = {
|
||||
{ .irq = 91 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod_dma_info omap2430_mcspi3_sdma_reqs[] = {
|
||||
{ .name = "tx0", .dma_req = 15 }, /* DMA_SPI3_TX0 */
|
||||
{ .name = "rx0", .dma_req = 16 }, /* DMA_SPI3_RX0 */
|
||||
{ .name = "tx1", .dma_req = 23 }, /* DMA_SPI3_TX1 */
|
||||
{ .name = "rx1", .dma_req = 24 }, /* DMA_SPI3_RX1 */
|
||||
{ .dma_req = -1 }
|
||||
};
|
||||
|
||||
static struct omap2_mcspi_dev_attr omap_mcspi3_dev_attr = {
|
||||
.num_chipselect = 2,
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2430_mcspi3_hwmod = {
|
||||
.name = "mcspi3",
|
||||
.mpu_irqs = omap2430_mcspi3_mpu_irqs,
|
||||
.sdma_reqs = omap2430_mcspi3_sdma_reqs,
|
||||
.main_clk = "mcspi3_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -259,16 +228,8 @@ static struct omap_hwmod_class usbotg_class = {
|
|||
};
|
||||
|
||||
/* usb_otg_hs */
|
||||
static struct omap_hwmod_irq_info omap2430_usbhsotg_mpu_irqs[] = {
|
||||
|
||||
{ .name = "mc", .irq = 92 + OMAP_INTC_START, },
|
||||
{ .name = "dma", .irq = 93 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2430_usbhsotg_hwmod = {
|
||||
.name = "usb_otg_hs",
|
||||
.mpu_irqs = omap2430_usbhsotg_mpu_irqs,
|
||||
.main_clk = "usbhs_ick",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -313,19 +274,9 @@ static struct omap_hwmod_opt_clk mcbsp_opt_clks[] = {
|
|||
};
|
||||
|
||||
/* mcbsp1 */
|
||||
static struct omap_hwmod_irq_info omap2430_mcbsp1_irqs[] = {
|
||||
{ .name = "tx", .irq = 59 + OMAP_INTC_START, },
|
||||
{ .name = "rx", .irq = 60 + OMAP_INTC_START, },
|
||||
{ .name = "ovr", .irq = 61 + OMAP_INTC_START, },
|
||||
{ .name = "common", .irq = 64 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2430_mcbsp1_hwmod = {
|
||||
.name = "mcbsp1",
|
||||
.class = &omap2430_mcbsp_hwmod_class,
|
||||
.mpu_irqs = omap2430_mcbsp1_irqs,
|
||||
.sdma_reqs = omap2_mcbsp1_sdma_reqs,
|
||||
.main_clk = "mcbsp1_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -341,18 +292,9 @@ static struct omap_hwmod omap2430_mcbsp1_hwmod = {
|
|||
};
|
||||
|
||||
/* mcbsp2 */
|
||||
static struct omap_hwmod_irq_info omap2430_mcbsp2_irqs[] = {
|
||||
{ .name = "tx", .irq = 62 + OMAP_INTC_START, },
|
||||
{ .name = "rx", .irq = 63 + OMAP_INTC_START, },
|
||||
{ .name = "common", .irq = 16 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2430_mcbsp2_hwmod = {
|
||||
.name = "mcbsp2",
|
||||
.class = &omap2430_mcbsp_hwmod_class,
|
||||
.mpu_irqs = omap2430_mcbsp2_irqs,
|
||||
.sdma_reqs = omap2_mcbsp2_sdma_reqs,
|
||||
.main_clk = "mcbsp2_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -368,18 +310,9 @@ static struct omap_hwmod omap2430_mcbsp2_hwmod = {
|
|||
};
|
||||
|
||||
/* mcbsp3 */
|
||||
static struct omap_hwmod_irq_info omap2430_mcbsp3_irqs[] = {
|
||||
{ .name = "tx", .irq = 89 + OMAP_INTC_START, },
|
||||
{ .name = "rx", .irq = 90 + OMAP_INTC_START, },
|
||||
{ .name = "common", .irq = 17 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2430_mcbsp3_hwmod = {
|
||||
.name = "mcbsp3",
|
||||
.class = &omap2430_mcbsp_hwmod_class,
|
||||
.mpu_irqs = omap2430_mcbsp3_irqs,
|
||||
.sdma_reqs = omap2_mcbsp3_sdma_reqs,
|
||||
.main_clk = "mcbsp3_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -395,24 +328,9 @@ static struct omap_hwmod omap2430_mcbsp3_hwmod = {
|
|||
};
|
||||
|
||||
/* mcbsp4 */
|
||||
static struct omap_hwmod_irq_info omap2430_mcbsp4_irqs[] = {
|
||||
{ .name = "tx", .irq = 54 + OMAP_INTC_START, },
|
||||
{ .name = "rx", .irq = 55 + OMAP_INTC_START, },
|
||||
{ .name = "common", .irq = 18 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod_dma_info omap2430_mcbsp4_sdma_chs[] = {
|
||||
{ .name = "rx", .dma_req = 20 },
|
||||
{ .name = "tx", .dma_req = 19 },
|
||||
{ .dma_req = -1 }
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2430_mcbsp4_hwmod = {
|
||||
.name = "mcbsp4",
|
||||
.class = &omap2430_mcbsp_hwmod_class,
|
||||
.mpu_irqs = omap2430_mcbsp4_irqs,
|
||||
.sdma_reqs = omap2430_mcbsp4_sdma_chs,
|
||||
.main_clk = "mcbsp4_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -428,24 +346,9 @@ static struct omap_hwmod omap2430_mcbsp4_hwmod = {
|
|||
};
|
||||
|
||||
/* mcbsp5 */
|
||||
static struct omap_hwmod_irq_info omap2430_mcbsp5_irqs[] = {
|
||||
{ .name = "tx", .irq = 81 + OMAP_INTC_START, },
|
||||
{ .name = "rx", .irq = 82 + OMAP_INTC_START, },
|
||||
{ .name = "common", .irq = 19 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod_dma_info omap2430_mcbsp5_sdma_chs[] = {
|
||||
{ .name = "rx", .dma_req = 22 },
|
||||
{ .name = "tx", .dma_req = 21 },
|
||||
{ .dma_req = -1 }
|
||||
};
|
||||
|
||||
static struct omap_hwmod omap2430_mcbsp5_hwmod = {
|
||||
.name = "mcbsp5",
|
||||
.class = &omap2430_mcbsp_hwmod_class,
|
||||
.mpu_irqs = omap2430_mcbsp5_irqs,
|
||||
.sdma_reqs = omap2430_mcbsp5_sdma_chs,
|
||||
.main_clk = "mcbsp5_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -478,17 +381,6 @@ static struct omap_hwmod_class omap2430_mmc_class = {
|
|||
};
|
||||
|
||||
/* MMC/SD/SDIO1 */
|
||||
static struct omap_hwmod_irq_info omap2430_mmc1_mpu_irqs[] = {
|
||||
{ .irq = 83 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod_dma_info omap2430_mmc1_sdma_reqs[] = {
|
||||
{ .name = "tx", .dma_req = 61 }, /* DMA_MMC1_TX */
|
||||
{ .name = "rx", .dma_req = 62 }, /* DMA_MMC1_RX */
|
||||
{ .dma_req = -1 }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_opt_clk omap2430_mmc1_opt_clks[] = {
|
||||
{ .role = "dbck", .clk = "mmchsdb1_fck" },
|
||||
};
|
||||
|
@ -500,8 +392,6 @@ static struct omap_mmc_dev_attr mmc1_dev_attr = {
|
|||
static struct omap_hwmod omap2430_mmc1_hwmod = {
|
||||
.name = "mmc1",
|
||||
.flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
|
||||
.mpu_irqs = omap2430_mmc1_mpu_irqs,
|
||||
.sdma_reqs = omap2430_mmc1_sdma_reqs,
|
||||
.opt_clks = omap2430_mmc1_opt_clks,
|
||||
.opt_clks_cnt = ARRAY_SIZE(omap2430_mmc1_opt_clks),
|
||||
.main_clk = "mmchs1_fck",
|
||||
|
@ -519,17 +409,6 @@ static struct omap_hwmod omap2430_mmc1_hwmod = {
|
|||
};
|
||||
|
||||
/* MMC/SD/SDIO2 */
|
||||
static struct omap_hwmod_irq_info omap2430_mmc2_mpu_irqs[] = {
|
||||
{ .irq = 86 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
static struct omap_hwmod_dma_info omap2430_mmc2_sdma_reqs[] = {
|
||||
{ .name = "tx", .dma_req = 47 }, /* DMA_MMC2_TX */
|
||||
{ .name = "rx", .dma_req = 48 }, /* DMA_MMC2_RX */
|
||||
{ .dma_req = -1 }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_opt_clk omap2430_mmc2_opt_clks[] = {
|
||||
{ .role = "dbck", .clk = "mmchsdb2_fck" },
|
||||
};
|
||||
|
@ -537,8 +416,6 @@ static struct omap_hwmod_opt_clk omap2430_mmc2_opt_clks[] = {
|
|||
static struct omap_hwmod omap2430_mmc2_hwmod = {
|
||||
.name = "mmc2",
|
||||
.flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
|
||||
.mpu_irqs = omap2430_mmc2_mpu_irqs,
|
||||
.sdma_reqs = omap2430_mmc2_sdma_reqs,
|
||||
.opt_clks = omap2430_mmc2_opt_clks,
|
||||
.opt_clks_cnt = ARRAY_SIZE(omap2430_mmc2_opt_clks),
|
||||
.main_clk = "mmchs2_fck",
|
||||
|
@ -557,7 +434,6 @@ static struct omap_hwmod omap2430_mmc2_hwmod = {
|
|||
/* HDQ1W/1-wire */
|
||||
static struct omap_hwmod omap2430_hdq1w_hwmod = {
|
||||
.name = "hdq1w",
|
||||
.mpu_irqs = omap2_hdq1w_mpu_irqs,
|
||||
.main_clk = "hdq_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -589,7 +465,6 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__i2c1 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_i2c1_hwmod,
|
||||
.clk = "i2c1_ick",
|
||||
.addr = omap2_i2c1_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -598,25 +473,14 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__i2c2 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_i2c2_hwmod,
|
||||
.clk = "i2c2_ick",
|
||||
.addr = omap2_i2c2_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2430_usbhsotg_addrs[] = {
|
||||
{
|
||||
.pa_start = OMAP243X_HS_BASE,
|
||||
.pa_end = OMAP243X_HS_BASE + SZ_4K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
/* l4_core ->usbhsotg interface */
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_core__usbhsotg = {
|
||||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_usbhsotg_hwmod,
|
||||
.clk = "usb_l4_ick",
|
||||
.addr = omap2430_usbhsotg_addrs,
|
||||
.user = OCP_USER_MPU,
|
||||
};
|
||||
|
||||
|
@ -625,7 +489,6 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__mmc1 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_mmc1_hwmod,
|
||||
.clk = "mmchs1_ick",
|
||||
.addr = omap2430_mmc1_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -634,7 +497,6 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__mmc2 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_mmc2_hwmod,
|
||||
.clk = "mmchs2_ick",
|
||||
.addr = omap2430_mmc2_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -643,7 +505,6 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__mcspi3 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_mcspi3_hwmod,
|
||||
.clk = "mcspi3_ick",
|
||||
.addr = omap2430_mcspi3_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -655,129 +516,59 @@ static struct omap_hwmod_ocp_if omap2430_l3__iva = {
|
|||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2430_timer1_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x49018000,
|
||||
.pa_end = 0x49018000 + SZ_1K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
/* l4_wkup -> timer1 */
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_wkup__timer1 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_timer1_hwmod,
|
||||
.clk = "gpt1_ick",
|
||||
.addr = omap2430_timer1_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_wkup -> wd_timer2 */
|
||||
static struct omap_hwmod_addr_space omap2430_wd_timer2_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x49016000,
|
||||
.pa_end = 0x4901607f,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_wkup__wd_timer2 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_wd_timer2_hwmod,
|
||||
.clk = "mpu_wdt_ick",
|
||||
.addr = omap2430_wd_timer2_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_wkup -> gpio1 */
|
||||
static struct omap_hwmod_addr_space omap2430_gpio1_addr_space[] = {
|
||||
{
|
||||
.pa_start = 0x4900C000,
|
||||
.pa_end = 0x4900C1ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_wkup__gpio1 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_gpio1_hwmod,
|
||||
.clk = "gpios_ick",
|
||||
.addr = omap2430_gpio1_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_wkup -> gpio2 */
|
||||
static struct omap_hwmod_addr_space omap2430_gpio2_addr_space[] = {
|
||||
{
|
||||
.pa_start = 0x4900E000,
|
||||
.pa_end = 0x4900E1ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_wkup__gpio2 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_gpio2_hwmod,
|
||||
.clk = "gpios_ick",
|
||||
.addr = omap2430_gpio2_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_wkup -> gpio3 */
|
||||
static struct omap_hwmod_addr_space omap2430_gpio3_addr_space[] = {
|
||||
{
|
||||
.pa_start = 0x49010000,
|
||||
.pa_end = 0x490101ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_wkup__gpio3 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_gpio3_hwmod,
|
||||
.clk = "gpios_ick",
|
||||
.addr = omap2430_gpio3_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_wkup -> gpio4 */
|
||||
static struct omap_hwmod_addr_space omap2430_gpio4_addr_space[] = {
|
||||
{
|
||||
.pa_start = 0x49012000,
|
||||
.pa_end = 0x490121ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_wkup__gpio4 = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_gpio4_hwmod,
|
||||
.clk = "gpios_ick",
|
||||
.addr = omap2430_gpio4_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
/* l4_core -> gpio5 */
|
||||
static struct omap_hwmod_addr_space omap2430_gpio5_addr_space[] = {
|
||||
{
|
||||
.pa_start = 0x480B6000,
|
||||
.pa_end = 0x480B61ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_core__gpio5 = {
|
||||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_gpio5_hwmod,
|
||||
.clk = "gpio5_ick",
|
||||
.addr = omap2430_gpio5_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -802,7 +593,6 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__dma_system = {
|
|||
static struct omap_hwmod_ocp_if omap2430_l4_core__mailbox = {
|
||||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_mailbox_hwmod,
|
||||
.addr = omap2_mailbox_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -811,7 +601,6 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__mcbsp1 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_mcbsp1_hwmod,
|
||||
.clk = "mcbsp1_ick",
|
||||
.addr = omap2_mcbsp1_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -820,64 +609,30 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__mcbsp2 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_mcbsp2_hwmod,
|
||||
.clk = "mcbsp2_ick",
|
||||
.addr = omap2xxx_mcbsp2_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2430_mcbsp3_addrs[] = {
|
||||
{
|
||||
.name = "mpu",
|
||||
.pa_start = 0x4808C000,
|
||||
.pa_end = 0x4808C0ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
/* l4_core -> mcbsp3 */
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_core__mcbsp3 = {
|
||||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_mcbsp3_hwmod,
|
||||
.clk = "mcbsp3_ick",
|
||||
.addr = omap2430_mcbsp3_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2430_mcbsp4_addrs[] = {
|
||||
{
|
||||
.name = "mpu",
|
||||
.pa_start = 0x4808E000,
|
||||
.pa_end = 0x4808E0ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
/* l4_core -> mcbsp4 */
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_core__mcbsp4 = {
|
||||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_mcbsp4_hwmod,
|
||||
.clk = "mcbsp4_ick",
|
||||
.addr = omap2430_mcbsp4_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2430_mcbsp5_addrs[] = {
|
||||
{
|
||||
.name = "mpu",
|
||||
.pa_start = 0x48096000,
|
||||
.pa_end = 0x480960ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
/* l4_core -> mcbsp5 */
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_core__mcbsp5 = {
|
||||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_mcbsp5_hwmod,
|
||||
.clk = "mcbsp5_ick",
|
||||
.addr = omap2430_mcbsp5_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -886,35 +641,15 @@ static struct omap_hwmod_ocp_if omap2430_l4_core__hdq1w = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2430_hdq1w_hwmod,
|
||||
.clk = "hdq_ick",
|
||||
.addr = omap2_hdq1w_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
.flags = OMAP_FIREWALL_L4 | OCPIF_SWSUP_IDLE,
|
||||
};
|
||||
|
||||
/* l4_wkup -> 32ksync_counter */
|
||||
static struct omap_hwmod_addr_space omap2430_counter_32k_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x49020000,
|
||||
.pa_end = 0x4902001f,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2430_gpmc_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x6e000000,
|
||||
.pa_end = 0x6e000fff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_ocp_if omap2430_l4_wkup__counter_32k = {
|
||||
.master = &omap2xxx_l4_wkup_hwmod,
|
||||
.slave = &omap2xxx_counter_32k_hwmod,
|
||||
.clk = "sync_32k_ick",
|
||||
.addr = omap2430_counter_32k_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -922,7 +657,6 @@ static struct omap_hwmod_ocp_if omap2430_l3__gpmc = {
|
|||
.master = &omap2xxx_l3_main_hwmod,
|
||||
.slave = &omap2xxx_gpmc_hwmod,
|
||||
.clk = "core_l3_ck",
|
||||
.addr = omap2430_gpmc_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
|
|
@ -20,142 +20,6 @@
|
|||
|
||||
#include "omap_hwmod_common_data.h"
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_uart1_addr_space[] = {
|
||||
{
|
||||
.pa_start = OMAP2_UART1_BASE,
|
||||
.pa_end = OMAP2_UART1_BASE + SZ_8K - 1,
|
||||
.flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT,
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_uart2_addr_space[] = {
|
||||
{
|
||||
.pa_start = OMAP2_UART2_BASE,
|
||||
.pa_end = OMAP2_UART2_BASE + SZ_1K - 1,
|
||||
.flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT,
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_uart3_addr_space[] = {
|
||||
{
|
||||
.pa_start = OMAP2_UART3_BASE,
|
||||
.pa_end = OMAP2_UART3_BASE + SZ_1K - 1,
|
||||
.flags = ADDR_MAP_ON_INIT | ADDR_TYPE_RT,
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_timer2_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x4802a000,
|
||||
.pa_end = 0x4802a000 + SZ_1K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_timer3_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x48078000,
|
||||
.pa_end = 0x48078000 + SZ_1K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_timer4_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x4807a000,
|
||||
.pa_end = 0x4807a000 + SZ_1K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_timer5_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x4807c000,
|
||||
.pa_end = 0x4807c000 + SZ_1K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_timer6_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x4807e000,
|
||||
.pa_end = 0x4807e000 + SZ_1K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_timer7_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x48080000,
|
||||
.pa_end = 0x48080000 + SZ_1K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_timer8_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x48082000,
|
||||
.pa_end = 0x48082000 + SZ_1K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_timer9_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x48084000,
|
||||
.pa_end = 0x48084000 + SZ_1K - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
struct omap_hwmod_addr_space omap2xxx_mcbsp2_addrs[] = {
|
||||
{
|
||||
.name = "mpu",
|
||||
.pa_start = 0x48076000,
|
||||
.pa_end = 0x480760ff,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2_rng_addr_space[] = {
|
||||
{
|
||||
.pa_start = 0x480a0000,
|
||||
.pa_end = 0x480a004f,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_sham_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x480a4000,
|
||||
.pa_end = 0x480a4000 + 0x64 - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_addr_space omap2xxx_aes_addrs[] = {
|
||||
{
|
||||
.pa_start = 0x480a6000,
|
||||
.pa_end = 0x480a6000 + 0x50 - 1,
|
||||
.flags = ADDR_TYPE_RT
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
/*
|
||||
* Common interconnect data
|
||||
*/
|
||||
|
@ -182,7 +46,7 @@ struct omap_hwmod_ocp_if omap2xxx_dss__l3 = {
|
|||
.omap2 = {
|
||||
.l3_perm_bit = OMAP2_L3_CORE_FW_CONNID_DSS,
|
||||
.flags = OMAP_FIREWALL_L3,
|
||||
}
|
||||
},
|
||||
},
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
@ -199,7 +63,6 @@ struct omap_hwmod_ocp_if omap2_l4_core__uart1 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_uart1_hwmod,
|
||||
.clk = "uart1_ick",
|
||||
.addr = omap2xxx_uart1_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -208,7 +71,6 @@ struct omap_hwmod_ocp_if omap2_l4_core__uart2 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_uart2_hwmod,
|
||||
.clk = "uart2_ick",
|
||||
.addr = omap2xxx_uart2_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -217,7 +79,6 @@ struct omap_hwmod_ocp_if omap2_l4_core__uart3 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_uart3_hwmod,
|
||||
.clk = "uart3_ick",
|
||||
.addr = omap2xxx_uart3_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -226,7 +87,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__mcspi1 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_mcspi1_hwmod,
|
||||
.clk = "mcspi1_ick",
|
||||
.addr = omap2_mcspi1_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -235,7 +95,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__mcspi2 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_mcspi2_hwmod,
|
||||
.clk = "mcspi2_ick",
|
||||
.addr = omap2_mcspi2_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -244,7 +103,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer2 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer2_hwmod,
|
||||
.clk = "gpt2_ick",
|
||||
.addr = omap2xxx_timer2_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -253,7 +111,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer3 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer3_hwmod,
|
||||
.clk = "gpt3_ick",
|
||||
.addr = omap2xxx_timer3_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -262,7 +119,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer4 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer4_hwmod,
|
||||
.clk = "gpt4_ick",
|
||||
.addr = omap2xxx_timer4_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -271,7 +127,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer5 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer5_hwmod,
|
||||
.clk = "gpt5_ick",
|
||||
.addr = omap2xxx_timer5_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -280,7 +135,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer6 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer6_hwmod,
|
||||
.clk = "gpt6_ick",
|
||||
.addr = omap2xxx_timer6_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -289,7 +143,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer7 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer7_hwmod,
|
||||
.clk = "gpt7_ick",
|
||||
.addr = omap2xxx_timer7_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -298,7 +151,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer8 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer8_hwmod,
|
||||
.clk = "gpt8_ick",
|
||||
.addr = omap2xxx_timer8_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -307,7 +159,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer9 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer9_hwmod,
|
||||
.clk = "gpt9_ick",
|
||||
.addr = omap2xxx_timer9_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -316,7 +167,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer10 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer10_hwmod,
|
||||
.clk = "gpt10_ick",
|
||||
.addr = omap2_timer10_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -325,7 +175,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer11 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer11_hwmod,
|
||||
.clk = "gpt11_ick",
|
||||
.addr = omap2_timer11_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -334,7 +183,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__timer12 = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_timer12_hwmod,
|
||||
.clk = "gpt12_ick",
|
||||
.addr = omap2xxx_timer12_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -348,7 +196,7 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__dss = {
|
|||
.omap2 = {
|
||||
.l4_fw_region = OMAP2420_L4_CORE_FW_DSS_CORE_REGION,
|
||||
.flags = OMAP_FIREWALL_L4,
|
||||
}
|
||||
},
|
||||
},
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
@ -363,7 +211,7 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__dss_dispc = {
|
|||
.omap2 = {
|
||||
.l4_fw_region = OMAP2420_L4_CORE_FW_DSS_DISPC_REGION,
|
||||
.flags = OMAP_FIREWALL_L4,
|
||||
}
|
||||
},
|
||||
},
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
@ -378,7 +226,7 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__dss_rfbi = {
|
|||
.omap2 = {
|
||||
.l4_fw_region = OMAP2420_L4_CORE_FW_DSS_CORE_REGION,
|
||||
.flags = OMAP_FIREWALL_L4,
|
||||
}
|
||||
},
|
||||
},
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
@ -393,7 +241,7 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__dss_venc = {
|
|||
.omap2 = {
|
||||
.l4_fw_region = OMAP2420_L4_CORE_FW_DSS_VENC_REGION,
|
||||
.flags = OMAP_FIREWALL_L4,
|
||||
}
|
||||
},
|
||||
},
|
||||
.flags = OCPIF_SWSUP_IDLE,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
|
@ -404,7 +252,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__rng = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_rng_hwmod,
|
||||
.clk = "rng_ick",
|
||||
.addr = omap2_rng_addr_space,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -413,7 +260,6 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__sham = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_sham_hwmod,
|
||||
.clk = "sha_ick",
|
||||
.addr = omap2xxx_sham_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
||||
|
@ -422,6 +268,5 @@ struct omap_hwmod_ocp_if omap2xxx_l4_core__aes = {
|
|||
.master = &omap2xxx_l4_core_hwmod,
|
||||
.slave = &omap2xxx_aes_hwmod,
|
||||
.clk = "aes_ick",
|
||||
.addr = omap2xxx_aes_addrs,
|
||||
.user = OCP_USER_MPU | OCP_USER_SDMA,
|
||||
};
|
||||
|
|
|
@ -20,14 +20,9 @@
|
|||
#include "prm-regbits-24xx.h"
|
||||
#include "wd_timer.h"
|
||||
|
||||
struct omap_hwmod_irq_info omap2xxx_timer12_mpu_irqs[] = {
|
||||
{ .irq = 48 + OMAP_INTC_START, },
|
||||
{ .irq = -1 },
|
||||
};
|
||||
|
||||
struct omap_hwmod_dma_info omap2xxx_dss_sdma_chs[] = {
|
||||
{ .name = "dispc", .dma_req = 5 },
|
||||
{ .dma_req = -1 }
|
||||
{ .dma_req = -1, },
|
||||
};
|
||||
|
||||
/*
|
||||
|
@ -219,14 +214,8 @@ struct omap_hwmod omap2xxx_l4_wkup_hwmod = {
|
|||
};
|
||||
|
||||
/* MPU */
|
||||
static struct omap_hwmod_irq_info omap2xxx_mpu_irqs[] = {
|
||||
{ .name = "pmu", .irq = 3 + OMAP_INTC_START },
|
||||
{ .irq = -1 }
|
||||
};
|
||||
|
||||
struct omap_hwmod omap2xxx_mpu_hwmod = {
|
||||
.name = "mpu",
|
||||
.mpu_irqs = omap2xxx_mpu_irqs,
|
||||
.class = &mpu_hwmod_class,
|
||||
.main_clk = "mpu_ck",
|
||||
};
|
||||
|
@ -256,7 +245,6 @@ static struct omap_timer_capability_dev_attr capability_dsp_dev_attr = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer1_hwmod = {
|
||||
.name = "timer1",
|
||||
.mpu_irqs = omap2_timer1_mpu_irqs,
|
||||
.main_clk = "gpt1_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -276,7 +264,6 @@ struct omap_hwmod omap2xxx_timer1_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer2_hwmod = {
|
||||
.name = "timer2",
|
||||
.mpu_irqs = omap2_timer2_mpu_irqs,
|
||||
.main_clk = "gpt2_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -295,7 +282,6 @@ struct omap_hwmod omap2xxx_timer2_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer3_hwmod = {
|
||||
.name = "timer3",
|
||||
.mpu_irqs = omap2_timer3_mpu_irqs,
|
||||
.main_clk = "gpt3_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -314,7 +300,6 @@ struct omap_hwmod omap2xxx_timer3_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer4_hwmod = {
|
||||
.name = "timer4",
|
||||
.mpu_irqs = omap2_timer4_mpu_irqs,
|
||||
.main_clk = "gpt4_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -333,7 +318,6 @@ struct omap_hwmod omap2xxx_timer4_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer5_hwmod = {
|
||||
.name = "timer5",
|
||||
.mpu_irqs = omap2_timer5_mpu_irqs,
|
||||
.main_clk = "gpt5_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -353,7 +337,6 @@ struct omap_hwmod omap2xxx_timer5_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer6_hwmod = {
|
||||
.name = "timer6",
|
||||
.mpu_irqs = omap2_timer6_mpu_irqs,
|
||||
.main_clk = "gpt6_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -373,7 +356,6 @@ struct omap_hwmod omap2xxx_timer6_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer7_hwmod = {
|
||||
.name = "timer7",
|
||||
.mpu_irqs = omap2_timer7_mpu_irqs,
|
||||
.main_clk = "gpt7_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -393,7 +375,6 @@ struct omap_hwmod omap2xxx_timer7_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer8_hwmod = {
|
||||
.name = "timer8",
|
||||
.mpu_irqs = omap2_timer8_mpu_irqs,
|
||||
.main_clk = "gpt8_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -413,7 +394,6 @@ struct omap_hwmod omap2xxx_timer8_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer9_hwmod = {
|
||||
.name = "timer9",
|
||||
.mpu_irqs = omap2_timer9_mpu_irqs,
|
||||
.main_clk = "gpt9_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -433,7 +413,6 @@ struct omap_hwmod omap2xxx_timer9_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer10_hwmod = {
|
||||
.name = "timer10",
|
||||
.mpu_irqs = omap2_timer10_mpu_irqs,
|
||||
.main_clk = "gpt10_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -453,7 +432,6 @@ struct omap_hwmod omap2xxx_timer10_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer11_hwmod = {
|
||||
.name = "timer11",
|
||||
.mpu_irqs = omap2_timer11_mpu_irqs,
|
||||
.main_clk = "gpt11_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -473,7 +451,6 @@ struct omap_hwmod omap2xxx_timer11_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_timer12_hwmod = {
|
||||
.name = "timer12",
|
||||
.mpu_irqs = omap2xxx_timer12_mpu_irqs,
|
||||
.main_clk = "gpt12_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -509,8 +486,6 @@ struct omap_hwmod omap2xxx_wd_timer2_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_uart1_hwmod = {
|
||||
.name = "uart1",
|
||||
.mpu_irqs = omap2_uart1_mpu_irqs,
|
||||
.sdma_reqs = omap2_uart1_sdma_reqs,
|
||||
.main_clk = "uart1_fck",
|
||||
.flags = DEBUG_OMAP2UART1_FLAGS | HWMOD_SWSUP_SIDLE_ACT,
|
||||
.prcm = {
|
||||
|
@ -529,8 +504,6 @@ struct omap_hwmod omap2xxx_uart1_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_uart2_hwmod = {
|
||||
.name = "uart2",
|
||||
.mpu_irqs = omap2_uart2_mpu_irqs,
|
||||
.sdma_reqs = omap2_uart2_sdma_reqs,
|
||||
.main_clk = "uart2_fck",
|
||||
.flags = DEBUG_OMAP2UART2_FLAGS | HWMOD_SWSUP_SIDLE_ACT,
|
||||
.prcm = {
|
||||
|
@ -549,8 +522,6 @@ struct omap_hwmod omap2xxx_uart2_hwmod = {
|
|||
|
||||
struct omap_hwmod omap2xxx_uart3_hwmod = {
|
||||
.name = "uart3",
|
||||
.mpu_irqs = omap2_uart3_mpu_irqs,
|
||||
.sdma_reqs = omap2_uart3_sdma_reqs,
|
||||
.main_clk = "uart3_fck",
|
||||
.flags = DEBUG_OMAP2UART3_FLAGS | HWMOD_SWSUP_SIDLE_ACT,
|
||||
.prcm = {
|
||||
|
@ -610,7 +581,7 @@ struct omap_hwmod omap2xxx_dss_dispc_hwmod = {
|
|||
},
|
||||
},
|
||||
.flags = HWMOD_NO_IDLEST,
|
||||
.dev_attr = &omap2_3_dss_dispc_dev_attr
|
||||
.dev_attr = &omap2_3_dss_dispc_dev_attr,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_opt_clk dss_rfbi_opt_clks[] = {
|
||||
|
@ -657,7 +628,6 @@ struct omap_gpio_dev_attr omap2xxx_gpio_dev_attr = {
|
|||
struct omap_hwmod omap2xxx_gpio1_hwmod = {
|
||||
.name = "gpio1",
|
||||
.flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
|
||||
.mpu_irqs = omap2_gpio1_irqs,
|
||||
.main_clk = "gpios_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -676,7 +646,6 @@ struct omap_hwmod omap2xxx_gpio1_hwmod = {
|
|||
struct omap_hwmod omap2xxx_gpio2_hwmod = {
|
||||
.name = "gpio2",
|
||||
.flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
|
||||
.mpu_irqs = omap2_gpio2_irqs,
|
||||
.main_clk = "gpios_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -695,7 +664,6 @@ struct omap_hwmod omap2xxx_gpio2_hwmod = {
|
|||
struct omap_hwmod omap2xxx_gpio3_hwmod = {
|
||||
.name = "gpio3",
|
||||
.flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
|
||||
.mpu_irqs = omap2_gpio3_irqs,
|
||||
.main_clk = "gpios_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -714,7 +682,6 @@ struct omap_hwmod omap2xxx_gpio3_hwmod = {
|
|||
struct omap_hwmod omap2xxx_gpio4_hwmod = {
|
||||
.name = "gpio4",
|
||||
.flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
|
||||
.mpu_irqs = omap2_gpio4_irqs,
|
||||
.main_clk = "gpios_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -736,8 +703,6 @@ static struct omap2_mcspi_dev_attr omap_mcspi1_dev_attr = {
|
|||
|
||||
struct omap_hwmod omap2xxx_mcspi1_hwmod = {
|
||||
.name = "mcspi1",
|
||||
.mpu_irqs = omap2_mcspi1_mpu_irqs,
|
||||
.sdma_reqs = omap2_mcspi1_sdma_reqs,
|
||||
.main_clk = "mcspi1_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -759,8 +724,6 @@ static struct omap2_mcspi_dev_attr omap_mcspi2_dev_attr = {
|
|||
|
||||
struct omap_hwmod omap2xxx_mcspi2_hwmod = {
|
||||
.name = "mcspi2",
|
||||
.mpu_irqs = omap2_mcspi2_mpu_irqs,
|
||||
.sdma_reqs = omap2_mcspi2_sdma_reqs,
|
||||
.main_clk = "mcspi2_fck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -795,15 +758,9 @@ struct omap_hwmod omap2xxx_counter_32k_hwmod = {
|
|||
};
|
||||
|
||||
/* gpmc */
|
||||
static struct omap_hwmod_irq_info omap2xxx_gpmc_irqs[] = {
|
||||
{ .irq = 20 + OMAP_INTC_START, },
|
||||
{ .irq = -1 }
|
||||
};
|
||||
|
||||
struct omap_hwmod omap2xxx_gpmc_hwmod = {
|
||||
.name = "gpmc",
|
||||
.class = &omap2xxx_gpmc_hwmod_class,
|
||||
.mpu_irqs = omap2xxx_gpmc_irqs,
|
||||
.main_clk = "gpmc_fck",
|
||||
/*
|
||||
* XXX HWMOD_INIT_NO_RESET should not be needed for this IP
|
||||
|
@ -840,14 +797,8 @@ static struct omap_hwmod_class omap2_rng_hwmod_class = {
|
|||
.sysc = &omap2_rng_sysc,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_irq_info omap2_rng_mpu_irqs[] = {
|
||||
{ .irq = 52 + OMAP_INTC_START, },
|
||||
{ .irq = -1 }
|
||||
};
|
||||
|
||||
struct omap_hwmod omap2xxx_rng_hwmod = {
|
||||
.name = "rng",
|
||||
.mpu_irqs = omap2_rng_mpu_irqs,
|
||||
.main_clk = "l4_ck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -884,20 +835,8 @@ static struct omap_hwmod_class omap2xxx_sham_class = {
|
|||
.sysc = &omap2_sham_sysc,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_irq_info omap2_sham_mpu_irqs[] = {
|
||||
{ .irq = 51 + OMAP_INTC_START, },
|
||||
{ .irq = -1 }
|
||||
};
|
||||
|
||||
static struct omap_hwmod_dma_info omap2_sham_sdma_chs[] = {
|
||||
{ .name = "rx", .dma_req = 13 },
|
||||
{ .dma_req = -1 }
|
||||
};
|
||||
|
||||
struct omap_hwmod omap2xxx_sham_hwmod = {
|
||||
.name = "sham",
|
||||
.mpu_irqs = omap2_sham_mpu_irqs,
|
||||
.sdma_reqs = omap2_sham_sdma_chs,
|
||||
.main_clk = "l4_ck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
@ -927,15 +866,8 @@ static struct omap_hwmod_class omap2xxx_aes_class = {
|
|||
.sysc = &omap2_aes_sysc,
|
||||
};
|
||||
|
||||
static struct omap_hwmod_dma_info omap2_aes_sdma_chs[] = {
|
||||
{ .name = "tx", .dma_req = 9 },
|
||||
{ .name = "rx", .dma_req = 10 },
|
||||
{ .dma_req = -1 }
|
||||
};
|
||||
|
||||
struct omap_hwmod omap2xxx_aes_hwmod = {
|
||||
.name = "aes",
|
||||
.sdma_reqs = omap2_aes_sdma_chs,
|
||||
.main_clk = "l4_ck",
|
||||
.prcm = {
|
||||
.omap2 = {
|
||||
|
|
|
@ -18,9 +18,6 @@
|
|||
#include "common.h"
|
||||
#include "display.h"
|
||||
|
||||
/* Common address space across OMAP2xxx */
|
||||
extern struct omap_hwmod_addr_space omap2xxx_mcbsp2_addrs[];
|
||||
|
||||
/* Common address space across OMAP2xxx/3xxx */
|
||||
extern struct omap_hwmod_addr_space omap2_i2c1_addr_space[];
|
||||
extern struct omap_hwmod_addr_space omap2_i2c2_addr_space[];
|
||||
|
@ -41,8 +38,6 @@ extern struct omap_hwmod_addr_space omap2_mcbsp1_addrs[];
|
|||
extern struct omap_hwmod_addr_space omap2_hdq1w_addr_space[];
|
||||
|
||||
/* Common IP block data across OMAP2xxx */
|
||||
extern struct omap_hwmod_irq_info omap2xxx_timer12_mpu_irqs[];
|
||||
extern struct omap_hwmod_dma_info omap2xxx_dss_sdma_chs[];
|
||||
extern struct omap_gpio_dev_attr omap2xxx_gpio_dev_attr;
|
||||
extern struct omap_hwmod omap2xxx_l3_main_hwmod;
|
||||
extern struct omap_hwmod omap2xxx_l4_core_hwmod;
|
||||
|
|
|
@ -8,6 +8,7 @@
|
|||
* published by the Free Software Foundation.
|
||||
*/
|
||||
#include <linux/clk.h>
|
||||
#include <linux/davinci_emac.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/kernel.h>
|
||||
|
@ -16,6 +17,7 @@
|
|||
|
||||
#include <linux/platform_data/pinctrl-single.h>
|
||||
|
||||
#include "am35xx.h"
|
||||
#include "common.h"
|
||||
#include "common-board-devices.h"
|
||||
#include "dss-common.h"
|
||||
|
@ -26,6 +28,9 @@ struct pdata_init {
|
|||
void (*fn)(void);
|
||||
};
|
||||
|
||||
struct of_dev_auxdata omap_auxdata_lookup[];
|
||||
static struct twl4030_gpio_platform_data twl_gpio_auxdata;
|
||||
|
||||
/*
|
||||
* Create alias for USB host PHY clock.
|
||||
* Remove this when clock phandle can be provided via DT
|
||||
|
@ -68,6 +73,15 @@ static inline void legacy_init_wl12xx(unsigned ref_clock,
|
|||
}
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_MACH_NOKIA_N8X0
|
||||
static void __init omap2420_n8x0_legacy_init(void)
|
||||
{
|
||||
omap_auxdata_lookup[0].platform_data = n8x0_legacy_init();
|
||||
}
|
||||
#else
|
||||
#define omap2420_n8x0_legacy_init NULL
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARCH_OMAP3
|
||||
static void __init hsmmc2_internal_input_clk(void)
|
||||
{
|
||||
|
@ -78,6 +92,33 @@ static void __init hsmmc2_internal_input_clk(void)
|
|||
omap_ctrl_writel(reg, OMAP343X_CONTROL_DEVCONF1);
|
||||
}
|
||||
|
||||
static int omap3_sbc_t3730_twl_callback(struct device *dev,
|
||||
unsigned gpio,
|
||||
unsigned ngpio)
|
||||
{
|
||||
int res;
|
||||
|
||||
res = gpio_request_one(gpio + 2, GPIOF_OUT_INIT_HIGH,
|
||||
"wlan rst");
|
||||
if (res)
|
||||
return res;
|
||||
|
||||
gpio_export(gpio, 0);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void __init omap3_sbc_t3730_twl_init(void)
|
||||
{
|
||||
twl_gpio_auxdata.setup = omap3_sbc_t3730_twl_callback;
|
||||
}
|
||||
|
||||
static void __init omap3_sbc_t3730_legacy_init(void)
|
||||
{
|
||||
legacy_init_wl12xx(WL12XX_REFCLOCK_38, 0, 136);
|
||||
omap_ads7846_init(1, 57, 0, NULL);
|
||||
}
|
||||
|
||||
static void __init omap3_igep0020_legacy_init(void)
|
||||
{
|
||||
omap3_igep2_display_init_of();
|
||||
|
@ -92,6 +133,42 @@ static void __init omap3_zoom_legacy_init(void)
|
|||
{
|
||||
legacy_init_wl12xx(WL12XX_REFCLOCK_26, 0, 162);
|
||||
}
|
||||
|
||||
static void am35xx_enable_emac_int(void)
|
||||
{
|
||||
u32 v;
|
||||
|
||||
v = omap_ctrl_readl(AM35XX_CONTROL_LVL_INTR_CLEAR);
|
||||
v |= (AM35XX_CPGMAC_C0_RX_PULSE_CLR | AM35XX_CPGMAC_C0_TX_PULSE_CLR |
|
||||
AM35XX_CPGMAC_C0_MISC_PULSE_CLR | AM35XX_CPGMAC_C0_RX_THRESH_CLR);
|
||||
omap_ctrl_writel(v, AM35XX_CONTROL_LVL_INTR_CLEAR);
|
||||
omap_ctrl_readl(AM35XX_CONTROL_LVL_INTR_CLEAR); /* OCP barrier */
|
||||
}
|
||||
|
||||
static void am35xx_disable_emac_int(void)
|
||||
{
|
||||
u32 v;
|
||||
|
||||
v = omap_ctrl_readl(AM35XX_CONTROL_LVL_INTR_CLEAR);
|
||||
v |= (AM35XX_CPGMAC_C0_RX_PULSE_CLR | AM35XX_CPGMAC_C0_TX_PULSE_CLR);
|
||||
omap_ctrl_writel(v, AM35XX_CONTROL_LVL_INTR_CLEAR);
|
||||
omap_ctrl_readl(AM35XX_CONTROL_LVL_INTR_CLEAR); /* OCP barrier */
|
||||
}
|
||||
|
||||
static struct emac_platform_data am35xx_emac_pdata = {
|
||||
.interrupt_enable = am35xx_enable_emac_int,
|
||||
.interrupt_disable = am35xx_disable_emac_int,
|
||||
};
|
||||
|
||||
static void __init am3517_evm_legacy_init(void)
|
||||
{
|
||||
u32 v;
|
||||
|
||||
v = omap_ctrl_readl(AM35XX_CONTROL_IP_SW_RESET);
|
||||
v &= ~AM35XX_CPGMACSS_SW_RST;
|
||||
omap_ctrl_writel(v, AM35XX_CONTROL_IP_SW_RESET);
|
||||
omap_ctrl_readl(AM35XX_CONTROL_IP_SW_RESET); /* OCP barrier */
|
||||
}
|
||||
#endif /* CONFIG_ARCH_OMAP3 */
|
||||
|
||||
#ifdef CONFIG_ARCH_OMAP4
|
||||
|
@ -125,10 +202,48 @@ void omap_pcs_legacy_init(int irq, void (*rearm)(void))
|
|||
pcs_pdata.rearm = rearm;
|
||||
}
|
||||
|
||||
/*
|
||||
* GPIOs for TWL are initialized by the I2C bus and need custom
|
||||
* handing until DSS has device tree bindings.
|
||||
*/
|
||||
void omap_auxdata_legacy_init(struct device *dev)
|
||||
{
|
||||
if (dev->platform_data)
|
||||
return;
|
||||
|
||||
if (strcmp("twl4030-gpio", dev_name(dev)))
|
||||
return;
|
||||
|
||||
dev->platform_data = &twl_gpio_auxdata;
|
||||
}
|
||||
|
||||
/*
|
||||
* Few boards still need auxdata populated before we populate
|
||||
* the dev entries in of_platform_populate().
|
||||
*/
|
||||
static struct pdata_init auxdata_quirks[] __initdata = {
|
||||
#ifdef CONFIG_SOC_OMAP2420
|
||||
{ "nokia,n800", omap2420_n8x0_legacy_init, },
|
||||
{ "nokia,n810", omap2420_n8x0_legacy_init, },
|
||||
{ "nokia,n810-wimax", omap2420_n8x0_legacy_init, },
|
||||
#endif
|
||||
#ifdef CONFIG_ARCH_OMAP3
|
||||
{ "compulab,omap3-sbc-t3730", omap3_sbc_t3730_twl_init, },
|
||||
#endif
|
||||
{ /* sentinel */ },
|
||||
};
|
||||
|
||||
struct of_dev_auxdata omap_auxdata_lookup[] __initdata = {
|
||||
#ifdef CONFIG_MACH_NOKIA_N8X0
|
||||
OF_DEV_AUXDATA("ti,omap2420-mmc", 0x4809c000, "mmci-omap.0", NULL),
|
||||
#endif
|
||||
#ifdef CONFIG_ARCH_OMAP3
|
||||
OF_DEV_AUXDATA("ti,omap3-padconf", 0x48002030, "48002030.pinmux", &pcs_pdata),
|
||||
OF_DEV_AUXDATA("ti,omap3-padconf", 0x48002a00, "48002a00.pinmux", &pcs_pdata),
|
||||
/* Only on am3517 */
|
||||
OF_DEV_AUXDATA("ti,davinci_mdio", 0x5c030000, "davinci_mdio.0", NULL),
|
||||
OF_DEV_AUXDATA("ti,am3517-emac", 0x5c000000, "davinci_emac.0",
|
||||
&am35xx_emac_pdata),
|
||||
#endif
|
||||
#ifdef CONFIG_ARCH_OMAP4
|
||||
OF_DEV_AUXDATA("ti,omap4-padconf", 0x4a100040, "4a100040.pinmux", &pcs_pdata),
|
||||
|
@ -137,14 +252,20 @@ struct of_dev_auxdata omap_auxdata_lookup[] __initdata = {
|
|||
{ /* sentinel */ },
|
||||
};
|
||||
|
||||
/*
|
||||
* Few boards still need to initialize some legacy devices with
|
||||
* platform data until the drivers support device tree.
|
||||
*/
|
||||
static struct pdata_init pdata_quirks[] __initdata = {
|
||||
#ifdef CONFIG_ARCH_OMAP3
|
||||
{ "compulab,omap3-sbc-t3730", omap3_sbc_t3730_legacy_init, },
|
||||
{ "nokia,omap3-n900", hsmmc2_internal_input_clk, },
|
||||
{ "nokia,omap3-n9", hsmmc2_internal_input_clk, },
|
||||
{ "nokia,omap3-n950", hsmmc2_internal_input_clk, },
|
||||
{ "isee,omap3-igep0020", omap3_igep0020_legacy_init, },
|
||||
{ "ti,omap3-evm-37xx", omap3_evm_legacy_init, },
|
||||
{ "ti,omap3-zoom3", omap3_zoom_legacy_init, },
|
||||
{ "ti,am3517-evm", am3517_evm_legacy_init, },
|
||||
#endif
|
||||
#ifdef CONFIG_ARCH_OMAP4
|
||||
{ "ti,omap4-sdp", omap4_sdp_legacy_init, },
|
||||
|
@ -156,14 +277,8 @@ static struct pdata_init pdata_quirks[] __initdata = {
|
|||
{ /* sentinel */ },
|
||||
};
|
||||
|
||||
void __init pdata_quirks_init(struct of_device_id *omap_dt_match_table)
|
||||
static void pdata_quirks_check(struct pdata_init *quirks)
|
||||
{
|
||||
struct pdata_init *quirks = pdata_quirks;
|
||||
|
||||
omap_sdrc_init(NULL, NULL);
|
||||
of_platform_populate(NULL, omap_dt_match_table,
|
||||
omap_auxdata_lookup, NULL);
|
||||
|
||||
while (quirks->compatible) {
|
||||
if (of_machine_is_compatible(quirks->compatible)) {
|
||||
if (quirks->fn)
|
||||
|
@ -173,3 +288,12 @@ void __init pdata_quirks_init(struct of_device_id *omap_dt_match_table)
|
|||
quirks++;
|
||||
}
|
||||
}
|
||||
|
||||
void __init pdata_quirks_init(struct of_device_id *omap_dt_match_table)
|
||||
{
|
||||
omap_sdrc_init(NULL, NULL);
|
||||
pdata_quirks_check(auxdata_quirks);
|
||||
of_platform_populate(NULL, omap_dt_match_table,
|
||||
omap_auxdata_lookup, NULL);
|
||||
pdata_quirks_check(pdata_quirks);
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@ config ARCH_SHMOBILE
|
|||
bool
|
||||
|
||||
config ARCH_SHMOBILE_MULTI
|
||||
bool "SH-Mobile Series" if ARCH_MULTI_V7
|
||||
bool "Renesas ARM SoCs" if ARCH_MULTI_V7
|
||||
depends on MMU
|
||||
select ARCH_SHMOBILE
|
||||
select CPU_V7
|
||||
|
@ -20,24 +20,47 @@ config ARCH_SHMOBILE_MULTI
|
|||
|
||||
if ARCH_SHMOBILE_MULTI
|
||||
|
||||
comment "SH-Mobile System Type"
|
||||
comment "Renesas ARM SoCs System Type"
|
||||
|
||||
config ARCH_EMEV2
|
||||
bool "Emma Mobile EV2"
|
||||
|
||||
comment "SH-Mobile Board Type"
|
||||
config ARCH_R7S72100
|
||||
bool "RZ/A1H (R7S72100)"
|
||||
|
||||
config ARCH_R8A7790
|
||||
bool "R-Car H2 (R8A77900)"
|
||||
select RENESAS_IRQC
|
||||
|
||||
config ARCH_R8A7791
|
||||
bool "R-Car M2 (R8A77910)"
|
||||
select RENESAS_IRQC
|
||||
|
||||
comment "Renesas ARM SoCs Board Type"
|
||||
|
||||
config MACH_GENMAI
|
||||
bool "Genmai board"
|
||||
depends on ARCH_R7S72100
|
||||
|
||||
config MACH_KOELSCH
|
||||
bool "Koelsch board"
|
||||
depends on ARCH_R8A7791
|
||||
|
||||
config MACH_KZM9D
|
||||
bool "KZM9D board"
|
||||
depends on ARCH_EMEV2
|
||||
select REGULATOR_FIXED_VOLTAGE if REGULATOR
|
||||
|
||||
comment "SH-Mobile System Configuration"
|
||||
config MACH_LAGER
|
||||
bool "Lager board"
|
||||
depends on ARCH_R8A7790
|
||||
|
||||
comment "Renesas ARM SoCs System Configuration"
|
||||
endif
|
||||
|
||||
if ARCH_SHMOBILE_LEGACY
|
||||
|
||||
comment "SH-Mobile System Type"
|
||||
comment "Renesas ARM SoCs System Type"
|
||||
|
||||
config ARCH_SH7372
|
||||
bool "SH-Mobile AP4 (SH7372)"
|
||||
|
@ -126,7 +149,7 @@ config ARCH_R7S72100
|
|||
select CPU_V7
|
||||
select SH_CLK_CPG
|
||||
|
||||
comment "SH-Mobile Board Type"
|
||||
comment "Renesas ARM SoCs Board Type"
|
||||
|
||||
config MACH_APE6EVM
|
||||
bool "APE6EVM board"
|
||||
|
@ -203,6 +226,17 @@ config MACH_GENMAI
|
|||
depends on ARCH_R7S72100
|
||||
select USE_OF
|
||||
|
||||
config MACH_GENMAI_REFERENCE
|
||||
bool "Genmai board - Reference Device Tree Implementation"
|
||||
depends on ARCH_R7S72100
|
||||
select USE_OF
|
||||
---help---
|
||||
Use reference implementation of Genmai board support
|
||||
which makes use of device tree at the expense
|
||||
of not supporting a number of devices.
|
||||
|
||||
This is intended to aid developers
|
||||
|
||||
config MACH_MARZEN
|
||||
bool "MARZEN board"
|
||||
depends on ARCH_R8A7779
|
||||
|
@ -228,17 +262,6 @@ config MACH_LAGER
|
|||
depends on ARCH_R8A7790
|
||||
select USE_OF
|
||||
|
||||
config MACH_LAGER_REFERENCE
|
||||
bool "Lager board - Reference Device Tree Implementation"
|
||||
depends on ARCH_R8A7790
|
||||
select USE_OF
|
||||
---help---
|
||||
Use reference implementation of Lager board support
|
||||
which makes use of device tree at the expense
|
||||
of not supporting a number of devices.
|
||||
|
||||
This is intended to aid developers
|
||||
|
||||
config MACH_KOELSCH
|
||||
bool "Koelsch board"
|
||||
depends on ARCH_R8A7791
|
||||
|
@ -269,7 +292,7 @@ config MACH_KZM9G_REFERENCE
|
|||
|
||||
This is intended to aid developers
|
||||
|
||||
comment "SH-Mobile System Configuration"
|
||||
comment "Renesas ARM SoCs System Configuration"
|
||||
|
||||
config CPU_HAS_INTEVT
|
||||
bool
|
||||
|
@ -294,8 +317,8 @@ config SHMOBILE_TIMER_HZ
|
|||
Allows the configuration of the timer frequency. It is customary
|
||||
to have the timer interrupt run at 1000 Hz or 100 Hz, but in the
|
||||
case of low timer frequencies other values may be more suitable.
|
||||
SH-Mobile systems using a 32768 Hz RCLK for clock events may want
|
||||
to select a HZ value such as 128 that can evenly divide RCLK.
|
||||
Renesas ARM SoC systems using a 32768 Hz RCLK for clock events may
|
||||
want to select a HZ value such as 128 that can evenly divide RCLK.
|
||||
A HZ value that does not divide evenly may cause timer drift.
|
||||
|
||||
config SH_TIMER_CMT
|
||||
|
|
|
@ -56,7 +56,10 @@ obj-$(CONFIG_ARCH_R8A7779) += pm-r8a7779.o
|
|||
|
||||
# Board objects
|
||||
ifdef CONFIG_ARCH_SHMOBILE_MULTI
|
||||
obj-$(CONFIG_MACH_GENMAI) += board-genmai-reference.o
|
||||
obj-$(CONFIG_MACH_KOELSCH) += board-koelsch-reference.o
|
||||
obj-$(CONFIG_MACH_KZM9D) += board-kzm9d-reference.o
|
||||
obj-$(CONFIG_MACH_LAGER) += board-lager-reference.o
|
||||
else
|
||||
obj-$(CONFIG_MACH_APE6EVM) += board-ape6evm.o
|
||||
obj-$(CONFIG_MACH_APE6EVM_REFERENCE) += board-ape6evm-reference.o
|
||||
|
@ -64,10 +67,10 @@ obj-$(CONFIG_MACH_MACKEREL) += board-mackerel.o
|
|||
obj-$(CONFIG_MACH_BOCKW) += board-bockw.o
|
||||
obj-$(CONFIG_MACH_BOCKW_REFERENCE) += board-bockw-reference.o
|
||||
obj-$(CONFIG_MACH_GENMAI) += board-genmai.o
|
||||
obj-$(CONFIG_MACH_GENMAI_REFERENCE) += board-genmai-reference.o
|
||||
obj-$(CONFIG_MACH_MARZEN) += board-marzen.o
|
||||
obj-$(CONFIG_MACH_MARZEN_REFERENCE) += board-marzen-reference.o
|
||||
obj-$(CONFIG_MACH_LAGER) += board-lager.o
|
||||
obj-$(CONFIG_MACH_LAGER_REFERENCE) += board-lager-reference.o
|
||||
obj-$(CONFIG_MACH_ARMADILLO800EVA) += board-armadillo800eva.o
|
||||
obj-$(CONFIG_MACH_ARMADILLO800EVA_REFERENCE) += board-armadillo800eva-reference.o
|
||||
obj-$(CONFIG_MACH_KOELSCH) += board-koelsch.o
|
||||
|
|
|
@ -6,12 +6,12 @@ loadaddr-$(CONFIG_MACH_ARMADILLO800EVA) += 0x40008000
|
|||
loadaddr-$(CONFIG_MACH_ARMADILLO800EVA_REFERENCE) += 0x40008000
|
||||
loadaddr-$(CONFIG_MACH_BOCKW) += 0x60008000
|
||||
loadaddr-$(CONFIG_MACH_BOCKW_REFERENCE) += 0x60008000
|
||||
loadaddr-$(CONFIG_MACH_GENMAI) += 0x8008000
|
||||
loadaddr-$(CONFIG_MACH_GENMAI) += 0x08008000
|
||||
loadaddr-$(CONFIG_MACH_GENMAI_REFERENCE) += 0x08008000
|
||||
loadaddr-$(CONFIG_MACH_KOELSCH) += 0x40008000
|
||||
loadaddr-$(CONFIG_MACH_KZM9G) += 0x41008000
|
||||
loadaddr-$(CONFIG_MACH_KZM9G_REFERENCE) += 0x41008000
|
||||
loadaddr-$(CONFIG_MACH_LAGER) += 0x40008000
|
||||
loadaddr-$(CONFIG_MACH_LAGER_REFERENCE) += 0x40008000
|
||||
loadaddr-$(CONFIG_MACH_MACKEREL) += 0x40008000
|
||||
loadaddr-$(CONFIG_MACH_MARZEN) += 0x60008000
|
||||
loadaddr-$(CONFIG_MACH_MARZEN_REFERENCE) += 0x60008000
|
||||
|
|
|
@ -423,7 +423,7 @@ static struct platform_pwm_backlight_data pwm_backlight_data = {
|
|||
.max_brightness = 255,
|
||||
.dft_brightness = 255,
|
||||
.pwm_period_ns = 33333, /* 30kHz */
|
||||
.enable_gpio = -1,
|
||||
.enable_gpio = 61,
|
||||
};
|
||||
|
||||
static struct platform_device pwm_backlight_device = {
|
||||
|
@ -963,7 +963,7 @@ static struct resource fsi_resources[] = {
|
|||
[0] = {
|
||||
.name = "FSI",
|
||||
.start = 0xfe1f0000,
|
||||
.end = 0xfe1f8400 - 1,
|
||||
.end = 0xfe1f0400 - 1,
|
||||
.flags = IORESOURCE_MEM,
|
||||
},
|
||||
[1] = {
|
||||
|
@ -1210,9 +1210,6 @@ static void __init eva_init(void)
|
|||
r8a7740_pinmux_init();
|
||||
r8a7740_meram_workaround();
|
||||
|
||||
/* LCDC0 */
|
||||
gpio_request_one(61, GPIOF_OUT_INIT_HIGH, NULL); /* LCDDON */
|
||||
|
||||
/* GETHER */
|
||||
gpio_request_one(18, GPIOF_OUT_INIT_HIGH, NULL); /* PHY_RST */
|
||||
|
||||
|
|
|
@ -30,9 +30,13 @@
|
|||
#define FPGA 0x18200000
|
||||
#define IRQ0MR 0x30
|
||||
#define COMCTLR 0x101c
|
||||
|
||||
#define PFC 0xfffc0000
|
||||
#define PUPR4 0x110
|
||||
static void __init bockw_init(void)
|
||||
{
|
||||
static void __iomem *fpga;
|
||||
void __iomem *fpga;
|
||||
void __iomem *pfc;
|
||||
|
||||
r8a7778_clock_init();
|
||||
r8a7778_init_irq_extpin_dt(1);
|
||||
|
@ -50,6 +54,19 @@ static void __init bockw_init(void)
|
|||
u16 val = ioread16(fpga + IRQ0MR);
|
||||
val &= ~(1 << 4); /* enable SMSC911x */
|
||||
iowrite16(val, fpga + IRQ0MR);
|
||||
|
||||
iounmap(fpga);
|
||||
}
|
||||
|
||||
pfc = ioremap_nocache(PFC, 0x200);
|
||||
if (pfc) {
|
||||
/*
|
||||
* FIXME
|
||||
*
|
||||
* SDHI CD/WP pin needs pull-up
|
||||
*/
|
||||
iowrite32(ioread32(pfc + PUPR4) | (3 << 26), pfc + PUPR4);
|
||||
iounmap(pfc);
|
||||
}
|
||||
|
||||
of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
|
||||
|
|
|
@ -117,6 +117,11 @@ static struct regulator_consumer_supply dummy_supplies[] = {
|
|||
REGULATOR_SUPPLY("vdd33a", "smsc911x"),
|
||||
};
|
||||
|
||||
static struct regulator_consumer_supply fixed3v3_power_consumers[] = {
|
||||
REGULATOR_SUPPLY("vmmc", "sh_mmcif"),
|
||||
REGULATOR_SUPPLY("vqmmc", "sh_mmcif"),
|
||||
};
|
||||
|
||||
static struct smsc911x_platform_config smsc911x_data __initdata = {
|
||||
.irq_polarity = SMSC911X_IRQ_POLARITY_ACTIVE_LOW,
|
||||
.irq_type = SMSC911X_IRQ_TYPE_PUSH_PULL,
|
||||
|
@ -272,7 +277,6 @@ static struct resource mmc_resources[] __initdata = {
|
|||
|
||||
static struct sh_mmcif_plat_data sh_mmcif_plat __initdata = {
|
||||
.sup_pclk = 0,
|
||||
.ocr = MMC_VDD_165_195 | MMC_VDD_32_33 | MMC_VDD_33_34,
|
||||
.caps = MMC_CAP_4_BIT_DATA |
|
||||
MMC_CAP_8_BIT_DATA |
|
||||
MMC_CAP_NEEDS_POLL,
|
||||
|
@ -329,11 +333,11 @@ static struct rsnd_ssi_platform_info rsnd_ssi[] = {
|
|||
RSND_SSI_UNUSED, /* SSI 1 */
|
||||
RSND_SSI_UNUSED, /* SSI 2 */
|
||||
RSND_SSI_SET(1, 0, gic_iid(0x85), RSND_SSI_PLAY),
|
||||
RSND_SSI_SET(2, 0, gic_iid(0x85), RSND_SSI_CLK_PIN_SHARE | RSND_SSI_CLK_FROM_ADG),
|
||||
RSND_SSI_SET(2, 0, gic_iid(0x85), RSND_SSI_CLK_PIN_SHARE),
|
||||
RSND_SSI_SET(0, 0, gic_iid(0x86), RSND_SSI_PLAY),
|
||||
RSND_SSI_SET(0, 0, gic_iid(0x86), 0),
|
||||
RSND_SSI_SET(3, 0, gic_iid(0x86), RSND_SSI_PLAY),
|
||||
RSND_SSI_SET(4, 0, gic_iid(0x86), RSND_SSI_CLK_PIN_SHARE | RSND_SSI_CLK_FROM_ADG),
|
||||
RSND_SSI_SET(4, 0, gic_iid(0x86), RSND_SSI_CLK_PIN_SHARE),
|
||||
};
|
||||
|
||||
static struct rsnd_scu_platform_info rsnd_scu[9] = {
|
||||
|
@ -615,6 +619,10 @@ static void __init bockw_init(void)
|
|||
&usb_phy_platform_data,
|
||||
sizeof(struct rcar_phy_platform_data));
|
||||
|
||||
regulator_register_fixed(0, dummy_supplies,
|
||||
ARRAY_SIZE(dummy_supplies));
|
||||
regulator_register_always_on(1, "fixed-3.3V", fixed3v3_power_consumers,
|
||||
ARRAY_SIZE(fixed3v3_power_consumers), 3300000);
|
||||
|
||||
/* for SMSC */
|
||||
fpga = ioremap_nocache(FPGA, SZ_1M);
|
||||
|
@ -630,9 +638,6 @@ static void __init bockw_init(void)
|
|||
val &= ~(1 << 4); /* enable SMSC911x */
|
||||
iowrite16(val, fpga + IRQ0MR);
|
||||
|
||||
regulator_register_fixed(0, dummy_supplies,
|
||||
ARRAY_SIZE(dummy_supplies));
|
||||
|
||||
platform_device_register_resndata(
|
||||
&platform_bus, "smsc911x", -1,
|
||||
smsc911x_resources, ARRAY_SIZE(smsc911x_resources),
|
||||
|
|
|
@ -0,0 +1,49 @@
|
|||
/*
|
||||
* Genmai board support
|
||||
*
|
||||
* Copyright (C) 2013 Renesas Solutions Corp.
|
||||
* Copyright (C) 2013 Magnus Damm
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; version 2 of the License.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*/
|
||||
|
||||
#include <linux/clk-provider.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/of_platform.h>
|
||||
#include <mach/common.h>
|
||||
#include <mach/r7s72100.h>
|
||||
#include <asm/mach-types.h>
|
||||
#include <asm/mach/arch.h>
|
||||
|
||||
static void __init genmai_add_standard_devices(void)
|
||||
{
|
||||
#ifdef CONFIG_COMMON_CLK
|
||||
of_clk_init(NULL);
|
||||
#else
|
||||
r7s72100_clock_init();
|
||||
#endif
|
||||
r7s72100_add_dt_devices();
|
||||
of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
|
||||
}
|
||||
|
||||
static const char * const genmai_boards_compat_dt[] __initconst = {
|
||||
"renesas,genmai-reference",
|
||||
NULL,
|
||||
};
|
||||
|
||||
DT_MACHINE_START(GENMAI_DT, "genmai")
|
||||
.init_early = r7s72100_init_early,
|
||||
.init_machine = genmai_add_standard_devices,
|
||||
.dt_compat = genmai_boards_compat_dt,
|
||||
MACHINE_END
|
|
@ -0,0 +1,79 @@
|
|||
/*
|
||||
* Koelsch board support - Reference DT implementation
|
||||
*
|
||||
* Copyright (C) 2013 Renesas Electronics Corporation
|
||||
* Copyright (C) 2013 Renesas Solutions Corp.
|
||||
* Copyright (C) 2013 Magnus Damm
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; version 2 of the License.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*/
|
||||
|
||||
#include <linux/clk.h>
|
||||
#include <linux/clkdev.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/of_platform.h>
|
||||
#include <mach/common.h>
|
||||
#include <mach/rcar-gen2.h>
|
||||
#include <mach/r8a7791.h>
|
||||
#include <asm/mach/arch.h>
|
||||
|
||||
static void __init koelsch_add_standard_devices(void)
|
||||
{
|
||||
#ifdef CONFIG_COMMON_CLK
|
||||
/*
|
||||
* This is a really crude hack to provide clkdev support to the SCIF
|
||||
* and CMT devices until they get moved to DT.
|
||||
*/
|
||||
static const char * const scif_names[] = {
|
||||
"scifa0", "scifa1", "scifb0", "scifb1", "scifb2", "scifa2",
|
||||
"scif0", "scif1", "scif2", "scif3", "scif4", "scif5", "scifa3",
|
||||
"scifa4", "scifa5",
|
||||
};
|
||||
struct clk *clk;
|
||||
unsigned int i;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(scif_names); ++i) {
|
||||
clk = clk_get(NULL, scif_names[i]);
|
||||
if (clk) {
|
||||
clk_register_clkdev(clk, NULL, "sh-sci.%u", i);
|
||||
clk_put(clk);
|
||||
}
|
||||
}
|
||||
|
||||
clk = clk_get(NULL, "cmt0");
|
||||
if (clk) {
|
||||
clk_register_clkdev(clk, NULL, "sh_cmt.0");
|
||||
clk_put(clk);
|
||||
}
|
||||
#else
|
||||
r8a7791_clock_init();
|
||||
#endif
|
||||
r8a7791_add_dt_devices();
|
||||
of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
|
||||
}
|
||||
|
||||
static const char * const koelsch_boards_compat_dt[] __initconst = {
|
||||
"renesas,koelsch",
|
||||
"renesas,koelsch-reference",
|
||||
NULL,
|
||||
};
|
||||
|
||||
DT_MACHINE_START(KOELSCH_DT, "koelsch")
|
||||
.smp = smp_ops(r8a7791_smp_ops),
|
||||
.init_early = r8a7791_init_early,
|
||||
.init_time = rcar_gen2_timer_init,
|
||||
.init_machine = koelsch_add_standard_devices,
|
||||
.init_late = shmobile_init_late,
|
||||
.dt_compat = koelsch_boards_compat_dt,
|
||||
MACHINE_END
|
|
@ -19,18 +19,205 @@
|
|||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*/
|
||||
|
||||
#include <linux/dma-mapping.h>
|
||||
#include <linux/gpio.h>
|
||||
#include <linux/gpio_keys.h>
|
||||
#include <linux/input.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/leds.h>
|
||||
#include <linux/phy.h>
|
||||
#include <linux/pinctrl/machine.h>
|
||||
#include <linux/platform_data/gpio-rcar.h>
|
||||
#include <linux/platform_data/rcar-du.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/sh_eth.h>
|
||||
#include <mach/common.h>
|
||||
#include <mach/irqs.h>
|
||||
#include <mach/r8a7791.h>
|
||||
#include <mach/rcar-gen2.h>
|
||||
#include <asm/mach-types.h>
|
||||
#include <asm/mach/arch.h>
|
||||
|
||||
/* DU */
|
||||
static struct rcar_du_encoder_data koelsch_du_encoders[] = {
|
||||
{
|
||||
.type = RCAR_DU_ENCODER_NONE,
|
||||
.output = RCAR_DU_OUTPUT_LVDS0,
|
||||
.connector.lvds.panel = {
|
||||
.width_mm = 210,
|
||||
.height_mm = 158,
|
||||
.mode = {
|
||||
.clock = 65000,
|
||||
.hdisplay = 1024,
|
||||
.hsync_start = 1048,
|
||||
.hsync_end = 1184,
|
||||
.htotal = 1344,
|
||||
.vdisplay = 768,
|
||||
.vsync_start = 771,
|
||||
.vsync_end = 777,
|
||||
.vtotal = 806,
|
||||
.flags = 0,
|
||||
},
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
static const struct rcar_du_platform_data koelsch_du_pdata __initconst = {
|
||||
.encoders = koelsch_du_encoders,
|
||||
.num_encoders = ARRAY_SIZE(koelsch_du_encoders),
|
||||
};
|
||||
|
||||
static const struct resource du_resources[] __initconst = {
|
||||
DEFINE_RES_MEM(0xfeb00000, 0x40000),
|
||||
DEFINE_RES_MEM_NAMED(0xfeb90000, 0x1c, "lvds.0"),
|
||||
DEFINE_RES_IRQ(gic_spi(256)),
|
||||
DEFINE_RES_IRQ(gic_spi(268)),
|
||||
};
|
||||
|
||||
static void __init koelsch_add_du_device(void)
|
||||
{
|
||||
struct platform_device_info info = {
|
||||
.name = "rcar-du-r8a7791",
|
||||
.id = -1,
|
||||
.res = du_resources,
|
||||
.num_res = ARRAY_SIZE(du_resources),
|
||||
.data = &koelsch_du_pdata,
|
||||
.size_data = sizeof(koelsch_du_pdata),
|
||||
.dma_mask = DMA_BIT_MASK(32),
|
||||
};
|
||||
|
||||
platform_device_register_full(&info);
|
||||
}
|
||||
|
||||
/* Ether */
|
||||
static const struct sh_eth_plat_data ether_pdata __initconst = {
|
||||
.phy = 0x1,
|
||||
.edmac_endian = EDMAC_LITTLE_ENDIAN,
|
||||
.phy_interface = PHY_INTERFACE_MODE_RMII,
|
||||
.ether_link_active_low = 1,
|
||||
};
|
||||
|
||||
static const struct resource ether_resources[] __initconst = {
|
||||
DEFINE_RES_MEM(0xee700000, 0x400),
|
||||
DEFINE_RES_IRQ(gic_spi(162)),
|
||||
};
|
||||
|
||||
/* LEDS */
|
||||
static struct gpio_led koelsch_leds[] = {
|
||||
{
|
||||
.name = "led8",
|
||||
.gpio = RCAR_GP_PIN(2, 21),
|
||||
.default_state = LEDS_GPIO_DEFSTATE_ON,
|
||||
}, {
|
||||
.name = "led7",
|
||||
.gpio = RCAR_GP_PIN(2, 20),
|
||||
.default_state = LEDS_GPIO_DEFSTATE_ON,
|
||||
}, {
|
||||
.name = "led6",
|
||||
.gpio = RCAR_GP_PIN(2, 19),
|
||||
.default_state = LEDS_GPIO_DEFSTATE_ON,
|
||||
},
|
||||
};
|
||||
|
||||
static const struct gpio_led_platform_data koelsch_leds_pdata __initconst = {
|
||||
.leds = koelsch_leds,
|
||||
.num_leds = ARRAY_SIZE(koelsch_leds),
|
||||
};
|
||||
|
||||
/* GPIO KEY */
|
||||
#define GPIO_KEY(c, g, d, ...) \
|
||||
{ .code = c, .gpio = g, .desc = d, .active_low = 1, \
|
||||
.wakeup = 1, .debounce_interval = 20 }
|
||||
|
||||
static struct gpio_keys_button gpio_buttons[] = {
|
||||
GPIO_KEY(KEY_4, RCAR_GP_PIN(5, 3), "SW2-pin4"),
|
||||
GPIO_KEY(KEY_3, RCAR_GP_PIN(5, 2), "SW2-pin3"),
|
||||
GPIO_KEY(KEY_2, RCAR_GP_PIN(5, 1), "SW2-pin2"),
|
||||
GPIO_KEY(KEY_1, RCAR_GP_PIN(5, 0), "SW2-pin1"),
|
||||
GPIO_KEY(KEY_G, RCAR_GP_PIN(7, 6), "SW36"),
|
||||
GPIO_KEY(KEY_F, RCAR_GP_PIN(7, 5), "SW35"),
|
||||
GPIO_KEY(KEY_E, RCAR_GP_PIN(7, 4), "SW34"),
|
||||
GPIO_KEY(KEY_D, RCAR_GP_PIN(7, 3), "SW33"),
|
||||
GPIO_KEY(KEY_C, RCAR_GP_PIN(7, 2), "SW32"),
|
||||
GPIO_KEY(KEY_B, RCAR_GP_PIN(7, 1), "SW31"),
|
||||
GPIO_KEY(KEY_A, RCAR_GP_PIN(7, 0), "SW30"),
|
||||
};
|
||||
|
||||
static const struct gpio_keys_platform_data koelsch_keys_pdata __initconst = {
|
||||
.buttons = gpio_buttons,
|
||||
.nbuttons = ARRAY_SIZE(gpio_buttons),
|
||||
};
|
||||
|
||||
static const struct pinctrl_map koelsch_pinctrl_map[] = {
|
||||
/* DU */
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("rcar-du-r8a7791", "pfc-r8a7791",
|
||||
"du_rgb666", "du"),
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("rcar-du-r8a7791", "pfc-r8a7791",
|
||||
"du_sync", "du"),
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("rcar-du-r8a7791", "pfc-r8a7791",
|
||||
"du_clk_out_0", "du"),
|
||||
/* Ether */
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("r8a7791-ether", "pfc-r8a7791",
|
||||
"eth_link", "eth"),
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("r8a7791-ether", "pfc-r8a7791",
|
||||
"eth_mdio", "eth"),
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("r8a7791-ether", "pfc-r8a7791",
|
||||
"eth_rmii", "eth"),
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("r8a7791-ether", "pfc-r8a7791",
|
||||
"intc_irq0", "intc"),
|
||||
/* SCIF0 (CN19: DEBUG SERIAL0) */
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("sh-sci.6", "pfc-r8a7791",
|
||||
"scif0_data_d", "scif0"),
|
||||
/* SCIF1 (CN20: DEBUG SERIAL1) */
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("sh-sci.7", "pfc-r8a7791",
|
||||
"scif1_data_d", "scif1"),
|
||||
};
|
||||
|
||||
static void __init koelsch_add_standard_devices(void)
|
||||
{
|
||||
r8a7791_clock_init();
|
||||
pinctrl_register_mappings(koelsch_pinctrl_map,
|
||||
ARRAY_SIZE(koelsch_pinctrl_map));
|
||||
r8a7791_pinmux_init();
|
||||
r8a7791_add_standard_devices();
|
||||
platform_device_register_resndata(&platform_bus, "r8a7791-ether", -1,
|
||||
ether_resources,
|
||||
ARRAY_SIZE(ether_resources),
|
||||
ðer_pdata, sizeof(ether_pdata));
|
||||
platform_device_register_data(&platform_bus, "leds-gpio", -1,
|
||||
&koelsch_leds_pdata,
|
||||
sizeof(koelsch_leds_pdata));
|
||||
platform_device_register_data(&platform_bus, "gpio-keys", -1,
|
||||
&koelsch_keys_pdata,
|
||||
sizeof(koelsch_keys_pdata));
|
||||
|
||||
koelsch_add_du_device();
|
||||
}
|
||||
|
||||
/*
|
||||
* Ether LEDs on the Koelsch board are named LINK and ACTIVE which corresponds
|
||||
* to non-default 01 setting of the Micrel KSZ8041 PHY control register 1 bits
|
||||
* 14-15. We have to set them back to 01 from the default 00 value each time
|
||||
* the PHY is reset. It's also important because the PHY's LED0 signal is
|
||||
* connected to SoC's ETH_LINK signal and in the PHY's default mode it will
|
||||
* bounce on and off after each packet, which we apparently want to avoid.
|
||||
*/
|
||||
static int koelsch_ksz8041_fixup(struct phy_device *phydev)
|
||||
{
|
||||
u16 phyctrl1 = phy_read(phydev, 0x1e);
|
||||
|
||||
phyctrl1 &= ~0xc000;
|
||||
phyctrl1 |= 0x4000;
|
||||
return phy_write(phydev, 0x1e, phyctrl1);
|
||||
}
|
||||
|
||||
static void __init koelsch_init(void)
|
||||
{
|
||||
koelsch_add_standard_devices();
|
||||
|
||||
if (IS_ENABLED(CONFIG_PHYLIB))
|
||||
phy_register_fixup_for_id("r8a7791-ether-ff:01",
|
||||
koelsch_ksz8041_fixup);
|
||||
}
|
||||
|
||||
static const char * const koelsch_boards_compat_dt[] __initconst = {
|
||||
|
@ -41,7 +228,8 @@ static const char * const koelsch_boards_compat_dt[] __initconst = {
|
|||
DT_MACHINE_START(KOELSCH_DT, "koelsch")
|
||||
.smp = smp_ops(r8a7791_smp_ops),
|
||||
.init_early = r8a7791_init_early,
|
||||
.init_machine = koelsch_add_standard_devices,
|
||||
.init_time = rcar_gen2_timer_init,
|
||||
.init_machine = koelsch_init,
|
||||
.init_late = shmobile_init_late,
|
||||
.dt_compat = koelsch_boards_compat_dt,
|
||||
MACHINE_END
|
||||
|
|
|
@ -18,20 +18,53 @@
|
|||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*/
|
||||
|
||||
#include <linux/clk.h>
|
||||
#include <linux/clkdev.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/of_platform.h>
|
||||
#include <mach/common.h>
|
||||
#include <mach/rcar-gen2.h>
|
||||
#include <mach/r8a7790.h>
|
||||
#include <asm/mach/arch.h>
|
||||
|
||||
static void __init lager_add_standard_devices(void)
|
||||
{
|
||||
#ifdef CONFIG_COMMON_CLK
|
||||
/*
|
||||
* This is a really crude hack to provide clkdev support to the SCIF
|
||||
* and CMT devices until they get moved to DT.
|
||||
*/
|
||||
static const char * const scif_names[] = {
|
||||
"scifa0", "scifa1", "scifb0", "scifb1",
|
||||
"scifb2", "scifa2", "scif0", "scif1",
|
||||
"hscif0", "hscif1",
|
||||
};
|
||||
struct clk *clk;
|
||||
unsigned int i;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(scif_names); ++i) {
|
||||
clk = clk_get(NULL, scif_names[i]);
|
||||
if (clk) {
|
||||
clk_register_clkdev(clk, NULL, "sh-sci.%u", i);
|
||||
clk_put(clk);
|
||||
}
|
||||
}
|
||||
|
||||
clk = clk_get(NULL, "cmt0");
|
||||
if (clk) {
|
||||
clk_register_clkdev(clk, NULL, "sh_cmt.0");
|
||||
clk_put(clk);
|
||||
}
|
||||
#else
|
||||
r8a7790_clock_init();
|
||||
#endif
|
||||
|
||||
r8a7790_add_dt_devices();
|
||||
of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
|
||||
}
|
||||
|
||||
static const char *lager_boards_compat_dt[] __initdata = {
|
||||
"renesas,lager",
|
||||
"renesas,lager-reference",
|
||||
NULL,
|
||||
};
|
||||
|
@ -41,5 +74,6 @@ DT_MACHINE_START(LAGER_DT, "lager")
|
|||
.init_early = r8a7790_init_early,
|
||||
.init_time = rcar_gen2_timer_init,
|
||||
.init_machine = lager_add_standard_devices,
|
||||
.init_late = shmobile_init_late,
|
||||
.dt_compat = lager_boards_compat_dt,
|
||||
MACHINE_END
|
||||
|
|
|
@ -31,7 +31,9 @@
|
|||
#include <linux/platform_data/rcar-du.h>
|
||||
#include <linux/platform_device.h>
|
||||
#include <linux/phy.h>
|
||||
#include <linux/regulator/driver.h>
|
||||
#include <linux/regulator/fixed.h>
|
||||
#include <linux/regulator/gpio-regulator.h>
|
||||
#include <linux/regulator/machine.h>
|
||||
#include <linux/sh_eth.h>
|
||||
#include <mach/common.h>
|
||||
|
@ -39,6 +41,11 @@
|
|||
#include <mach/r8a7790.h>
|
||||
#include <asm/mach-types.h>
|
||||
#include <asm/mach/arch.h>
|
||||
#include <linux/mtd/partitions.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#include <linux/spi/flash.h>
|
||||
#include <linux/spi/rspi.h>
|
||||
#include <linux/spi/spi.h>
|
||||
|
||||
/* DU */
|
||||
static struct rcar_du_encoder_data lager_du_encoders[] = {
|
||||
|
@ -120,7 +127,8 @@ static const struct gpio_led_platform_data lager_leds_pdata __initconst = {
|
|||
|
||||
/* GPIO KEY */
|
||||
#define GPIO_KEY(c, g, d, ...) \
|
||||
{ .code = c, .gpio = g, .desc = d, .active_low = 1 }
|
||||
{ .code = c, .gpio = g, .desc = d, .active_low = 1, \
|
||||
.wakeup = 1, .debounce_interval = 20 }
|
||||
|
||||
static struct gpio_keys_button gpio_buttons[] = {
|
||||
GPIO_KEY(KEY_4, RCAR_GP_PIN(1, 28), "SW2-pin4"),
|
||||
|
@ -140,6 +148,71 @@ static struct regulator_consumer_supply fixed3v3_power_consumers[] =
|
|||
REGULATOR_SUPPLY("vmmc", "sh_mmcif.1"),
|
||||
};
|
||||
|
||||
/*
|
||||
* SDHI regulator macro
|
||||
*
|
||||
** FIXME**
|
||||
* Lager board vqmmc is provided via DA9063 PMIC chip,
|
||||
* and we should use ${LINK}/drivers/mfd/da9063-* driver for it.
|
||||
* but, it doesn't have regulator support at this point.
|
||||
* It uses gpio-regulator for vqmmc as quick-hack.
|
||||
*/
|
||||
#define SDHI_REGULATOR(idx, vdd_pin, vccq_pin) \
|
||||
static struct regulator_consumer_supply vcc_sdhi##idx##_consumer = \
|
||||
REGULATOR_SUPPLY("vmmc", "sh_mobile_sdhi." #idx); \
|
||||
\
|
||||
static struct regulator_init_data vcc_sdhi##idx##_init_data = { \
|
||||
.constraints = { \
|
||||
.valid_ops_mask = REGULATOR_CHANGE_STATUS, \
|
||||
}, \
|
||||
.consumer_supplies = &vcc_sdhi##idx##_consumer, \
|
||||
.num_consumer_supplies = 1, \
|
||||
}; \
|
||||
\
|
||||
static const struct fixed_voltage_config vcc_sdhi##idx##_info __initconst = {\
|
||||
.supply_name = "SDHI" #idx "Vcc", \
|
||||
.microvolts = 3300000, \
|
||||
.gpio = vdd_pin, \
|
||||
.enable_high = 1, \
|
||||
.init_data = &vcc_sdhi##idx##_init_data, \
|
||||
}; \
|
||||
\
|
||||
static struct regulator_consumer_supply vccq_sdhi##idx##_consumer = \
|
||||
REGULATOR_SUPPLY("vqmmc", "sh_mobile_sdhi." #idx); \
|
||||
\
|
||||
static struct regulator_init_data vccq_sdhi##idx##_init_data = { \
|
||||
.constraints = { \
|
||||
.input_uV = 3300000, \
|
||||
.min_uV = 1800000, \
|
||||
.max_uV = 3300000, \
|
||||
.valid_ops_mask = REGULATOR_CHANGE_VOLTAGE | \
|
||||
REGULATOR_CHANGE_STATUS, \
|
||||
}, \
|
||||
.consumer_supplies = &vccq_sdhi##idx##_consumer, \
|
||||
.num_consumer_supplies = 1, \
|
||||
}; \
|
||||
\
|
||||
static struct gpio vccq_sdhi##idx##_gpio = \
|
||||
{ vccq_pin, GPIOF_OUT_INIT_HIGH, "vccq-sdhi" #idx }; \
|
||||
\
|
||||
static struct gpio_regulator_state vccq_sdhi##idx##_states[] = { \
|
||||
{ .value = 1800000, .gpios = 0 }, \
|
||||
{ .value = 3300000, .gpios = 1 }, \
|
||||
}; \
|
||||
\
|
||||
static const struct gpio_regulator_config vccq_sdhi##idx##_info __initconst = {\
|
||||
.supply_name = "vqmmc", \
|
||||
.gpios = &vccq_sdhi##idx##_gpio, \
|
||||
.nr_gpios = 1, \
|
||||
.states = vccq_sdhi##idx##_states, \
|
||||
.nr_states = ARRAY_SIZE(vccq_sdhi##idx##_states), \
|
||||
.type = REGULATOR_VOLTAGE, \
|
||||
.init_data = &vccq_sdhi##idx##_init_data, \
|
||||
};
|
||||
|
||||
SDHI_REGULATOR(0, RCAR_GP_PIN(5, 24), RCAR_GP_PIN(5, 29));
|
||||
SDHI_REGULATOR(2, RCAR_GP_PIN(5, 25), RCAR_GP_PIN(5, 30));
|
||||
|
||||
/* MMCIF */
|
||||
static const struct sh_mmcif_plat_data mmcif1_pdata __initconst = {
|
||||
.caps = MMC_CAP_8_BIT_DATA | MMC_CAP_NONREMOVABLE,
|
||||
|
@ -165,6 +238,59 @@ static const struct resource ether_resources[] __initconst = {
|
|||
DEFINE_RES_IRQ(gic_spi(162)),
|
||||
};
|
||||
|
||||
/* SPI Flash memory (Spansion S25FL512SAGMFIG11 64Mb) */
|
||||
static struct mtd_partition spi_flash_part[] = {
|
||||
/* Reserved for user loader program, read-only */
|
||||
{
|
||||
.name = "loader",
|
||||
.offset = 0,
|
||||
.size = SZ_256K,
|
||||
.mask_flags = MTD_WRITEABLE,
|
||||
},
|
||||
/* Reserved for user program, read-only */
|
||||
{
|
||||
.name = "user",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = SZ_4M,
|
||||
.mask_flags = MTD_WRITEABLE,
|
||||
},
|
||||
/* All else is writable (e.g. JFFS2) */
|
||||
{
|
||||
.name = "flash",
|
||||
.offset = MTDPART_OFS_APPEND,
|
||||
.size = MTDPART_SIZ_FULL,
|
||||
.mask_flags = 0,
|
||||
},
|
||||
};
|
||||
|
||||
static struct flash_platform_data spi_flash_data = {
|
||||
.name = "m25p80",
|
||||
.parts = spi_flash_part,
|
||||
.nr_parts = ARRAY_SIZE(spi_flash_part),
|
||||
.type = "s25fl512s",
|
||||
};
|
||||
|
||||
static const struct rspi_plat_data qspi_pdata __initconst = {
|
||||
.num_chipselect = 1,
|
||||
};
|
||||
|
||||
static const struct spi_board_info spi_info[] __initconst = {
|
||||
{
|
||||
.modalias = "m25p80",
|
||||
.platform_data = &spi_flash_data,
|
||||
.mode = SPI_MODE_0,
|
||||
.max_speed_hz = 30000000,
|
||||
.bus_num = 0,
|
||||
.chip_select = 0,
|
||||
},
|
||||
};
|
||||
|
||||
/* QSPI resource */
|
||||
static const struct resource qspi_resources[] __initconst = {
|
||||
DEFINE_RES_MEM(0xe6b10000, 0x1000),
|
||||
DEFINE_RES_IRQ(gic_spi(184)),
|
||||
};
|
||||
|
||||
static const struct pinctrl_map lager_pinctrl_map[] = {
|
||||
/* DU (CN10: ARGB0, CN13: LVDS) */
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("rcar-du-r8a7790", "pfc-r8a7790",
|
||||
|
@ -197,6 +323,9 @@ static const struct pinctrl_map lager_pinctrl_map[] = {
|
|||
|
||||
static void __init lager_add_standard_devices(void)
|
||||
{
|
||||
int fixed_regulator_idx = 0;
|
||||
int gpio_regulator_idx = 0;
|
||||
|
||||
r8a7790_clock_init();
|
||||
|
||||
pinctrl_register_mappings(lager_pinctrl_map,
|
||||
|
@ -210,7 +339,8 @@ static void __init lager_add_standard_devices(void)
|
|||
platform_device_register_data(&platform_bus, "gpio-keys", -1,
|
||||
&lager_keys_pdata,
|
||||
sizeof(lager_keys_pdata));
|
||||
regulator_register_always_on(0, "fixed-3.3V", fixed3v3_power_consumers,
|
||||
regulator_register_always_on(fixed_regulator_idx++,
|
||||
"fixed-3.3V", fixed3v3_power_consumers,
|
||||
ARRAY_SIZE(fixed3v3_power_consumers), 3300000);
|
||||
platform_device_register_resndata(&platform_bus, "sh_mmcif", 1,
|
||||
mmcif1_resources, ARRAY_SIZE(mmcif1_resources),
|
||||
|
@ -222,6 +352,22 @@ static void __init lager_add_standard_devices(void)
|
|||
ðer_pdata, sizeof(ether_pdata));
|
||||
|
||||
lager_add_du_device();
|
||||
|
||||
platform_device_register_resndata(&platform_bus, "qspi", 0,
|
||||
qspi_resources,
|
||||
ARRAY_SIZE(qspi_resources),
|
||||
&qspi_pdata, sizeof(qspi_pdata));
|
||||
spi_register_board_info(spi_info, ARRAY_SIZE(spi_info));
|
||||
|
||||
platform_device_register_data(&platform_bus, "reg-fixed-voltage", fixed_regulator_idx++,
|
||||
&vcc_sdhi0_info, sizeof(struct fixed_voltage_config));
|
||||
platform_device_register_data(&platform_bus, "reg-fixed-voltage", fixed_regulator_idx++,
|
||||
&vcc_sdhi2_info, sizeof(struct fixed_voltage_config));
|
||||
|
||||
platform_device_register_data(&platform_bus, "gpio-regulator", gpio_regulator_idx++,
|
||||
&vccq_sdhi0_info, sizeof(struct gpio_regulator_config));
|
||||
platform_device_register_data(&platform_bus, "gpio-regulator", gpio_regulator_idx++,
|
||||
&vccq_sdhi2_info, sizeof(struct gpio_regulator_config));
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -260,5 +406,6 @@ DT_MACHINE_START(LAGER_DT, "lager")
|
|||
.init_early = r8a7790_init_early,
|
||||
.init_time = rcar_gen2_timer_init,
|
||||
.init_machine = lager_init,
|
||||
.init_late = shmobile_init_late,
|
||||
.dt_compat = lager_boards_compat_dt,
|
||||
MACHINE_END
|
||||
|
|
|
@ -41,6 +41,7 @@
|
|||
#include <linux/mtd/physmap.h>
|
||||
#include <linux/mtd/sh_flctl.h>
|
||||
#include <linux/pinctrl/machine.h>
|
||||
#include <linux/pinctrl/pinconf-generic.h>
|
||||
#include <linux/platform_data/gpio_backlight.h>
|
||||
#include <linux/pm_clock.h>
|
||||
#include <linux/regulator/fixed.h>
|
||||
|
@ -548,9 +549,9 @@ static void __init hdmi_init_pm_clock(void)
|
|||
clk_get_rate(&sh7372_pllc2_clk));
|
||||
|
||||
rate = clk_round_rate(&sh7372_pllc2_clk, 594000000);
|
||||
if (rate < 0) {
|
||||
if (rate <= 0) {
|
||||
pr_err("Cannot get suitable rate: %ld\n", rate);
|
||||
ret = rate;
|
||||
ret = -EINVAL;
|
||||
goto out;
|
||||
}
|
||||
|
||||
|
@ -1311,6 +1312,10 @@ static struct i2c_board_info i2c1_devices[] = {
|
|||
},
|
||||
};
|
||||
|
||||
static unsigned long pin_pulldown_conf[] = {
|
||||
PIN_CONF_PACKED(PIN_CONFIG_BIAS_PULL_DOWN, 0),
|
||||
};
|
||||
|
||||
static const struct pinctrl_map mackerel_pinctrl_map[] = {
|
||||
/* ADXL34X */
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("1-0053", "pfc-sh7372",
|
||||
|
@ -1396,17 +1401,19 @@ static const struct pinctrl_map mackerel_pinctrl_map[] = {
|
|||
/* USBHS0 */
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("renesas_usbhs.0", "pfc-sh7372",
|
||||
"usb0_vbus", "usb0"),
|
||||
PIN_MAP_CONFIGS_GROUP_DEFAULT("renesas_usbhs.0", "pfc-sh7372",
|
||||
"usb0_vbus", pin_pulldown_conf),
|
||||
/* USBHS1 */
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("renesas_usbhs.1", "pfc-sh7372",
|
||||
"usb1_vbus", "usb1"),
|
||||
PIN_MAP_CONFIGS_GROUP_DEFAULT("renesas_usbhs.1", "pfc-sh7372",
|
||||
"usb1_vbus", pin_pulldown_conf),
|
||||
PIN_MAP_MUX_GROUP_DEFAULT("renesas_usbhs.1", "pfc-sh7372",
|
||||
"usb1_otg_id_0", "usb1"),
|
||||
};
|
||||
|
||||
#define GPIO_PORT9CR IOMEM(0xE6051009)
|
||||
#define GPIO_PORT10CR IOMEM(0xE605100A)
|
||||
#define GPIO_PORT167CR IOMEM(0xE60520A7)
|
||||
#define GPIO_PORT168CR IOMEM(0xE60520A8)
|
||||
#define SRCR4 IOMEM(0xe61580bc)
|
||||
#define USCCR1 IOMEM(0xE6058144)
|
||||
static void __init mackerel_init(void)
|
||||
|
@ -1446,12 +1453,6 @@ static void __init mackerel_init(void)
|
|||
|
||||
gpio_request_one(151, GPIOF_OUT_INIT_HIGH, NULL); /* LCDDON */
|
||||
|
||||
/* USBHS0 */
|
||||
gpio_request_pulldown(GPIO_PORT168CR); /* VBUS0_0 pull down */
|
||||
|
||||
/* USBHS1 */
|
||||
gpio_request_pulldown(GPIO_PORT167CR); /* VBUS0_1 pull down */
|
||||
|
||||
/* FSI2 port A (ak4643) */
|
||||
gpio_request_one(161, GPIOF_OUT_INIT_LOW, NULL); /* slave */
|
||||
|
||||
|
|
|
@ -26,23 +26,4 @@ static inline void __init gpio_direction_none(void __iomem * addr)
|
|||
__raw_writeb(0x00, addr);
|
||||
}
|
||||
|
||||
static inline void __init gpio_request_pullup(void __iomem * addr)
|
||||
{
|
||||
u8 data = __raw_readb(addr);
|
||||
|
||||
data &= 0x0F;
|
||||
data |= 0xC0;
|
||||
__raw_writeb(data, addr);
|
||||
}
|
||||
|
||||
static inline void __init gpio_request_pulldown(void __iomem * addr)
|
||||
{
|
||||
u8 data = __raw_readb(addr);
|
||||
|
||||
data &= 0x0F;
|
||||
data |= 0xA0;
|
||||
|
||||
__raw_writeb(data, addr);
|
||||
}
|
||||
|
||||
#endif /* __ASM_ARCH_GPIO_H */
|
||||
|
|
|
@ -49,5 +49,25 @@
|
|||
#define PIN_OFF_INPUT_PULLDOWN (OFF_EN | OFF_PULL_EN)
|
||||
#define PIN_OFF_WAKEUPENABLE WAKEUP_EN
|
||||
|
||||
/*
|
||||
* Macros to allow using the absolute physical address instead of the
|
||||
* padconf registers instead of the offset from padconf base.
|
||||
*/
|
||||
#define OMAP_IOPAD_OFFSET(pa, offset) (((pa) & 0xffff) - (offset))
|
||||
|
||||
#define OMAP2420_CORE_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x0030) (val)
|
||||
#define OMAP2430_CORE_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x2030) (val)
|
||||
#define OMAP3_CORE1_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x2030) (val)
|
||||
#define OMAP3430_CORE2_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x25d8) (val)
|
||||
#define OMAP3630_CORE2_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x25a0) (val)
|
||||
#define OMAP3_WKUP_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x2a00) (val)
|
||||
#define AM33XX_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x0800) (val)
|
||||
#define OMAP4_CORE_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x0040) (val)
|
||||
#define OMAP4_WKUP_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0xe040) (val)
|
||||
#define AM4372_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x0800) (val)
|
||||
#define OMAP5_CORE_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x2840) (val)
|
||||
#define OMAP5_WKUP_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0xc840) (val)
|
||||
#define DRA7XX_CORE_IOPAD(pa, val) OMAP_IOPAD_OFFSET((pa), 0x3400) (val)
|
||||
|
||||
#endif
|
||||
|
||||
|
|
|
@ -34,7 +34,6 @@
|
|||
* B : SSI direction
|
||||
*/
|
||||
#define RSND_SSI_CLK_PIN_SHARE (1 << 31)
|
||||
#define RSND_SSI_CLK_FROM_ADG (1 << 30) /* clock parent is master */
|
||||
#define RSND_SSI_SYNC (1 << 29) /* SSI34_sync etc */
|
||||
|
||||
#define RSND_SSI_PLAY (1 << 24)
|
||||
|
|
Loading…
Reference in New Issue