mirror of
https://github.com/torvalds/linux.git
synced 2024-12-30 14:52:05 +00:00
8320062928
Move the AB8500 muxing and biasing settings over from the board file to the device tree, include it in the reference designs using the AB8500: HREF prior to v60, v60plus and Snowball. Set up these GPIO lines using hogs, just like in the board file. Cc: Patrice Chotard <patrice.chotard@st.com> Cc: Lee Jones <lee.jones@linaro.org> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
495 lines
10 KiB
Plaintext
495 lines
10 KiB
Plaintext
/*
|
|
* Copyright 2011 ST-Ericsson AB
|
|
*
|
|
* The code contained herein is licensed under the GNU General Public
|
|
* License. You may obtain a copy of the GNU General Public License
|
|
* Version 2 or later at the following locations:
|
|
*
|
|
* http://www.opensource.org/licenses/gpl-license.html
|
|
* http://www.gnu.org/copyleft/gpl.html
|
|
*/
|
|
|
|
/dts-v1/;
|
|
#include "ste-dbx5x0.dtsi"
|
|
#include "ste-href-ab8500.dtsi"
|
|
#include "ste-href-family-pinctrl.dtsi"
|
|
|
|
/ {
|
|
model = "Calao Systems Snowball platform with device tree";
|
|
compatible = "calaosystems,snowball-a9500", "st-ericsson,u9500";
|
|
|
|
memory {
|
|
reg = <0x00000000 0x20000000>;
|
|
};
|
|
|
|
en_3v3_reg: en_3v3 {
|
|
compatible = "regulator-fixed";
|
|
regulator-name = "en-3v3-fixed-supply";
|
|
regulator-min-microvolt = <3300000>;
|
|
regulator-max-microvolt = <3300000>;
|
|
/* AB8500 GPIOs start from 1 - offset 25 is GPIO26. */
|
|
gpio = <&ab8500_gpio 25 0x4>;
|
|
startup-delay-us = <5000>;
|
|
enable-active-high;
|
|
};
|
|
|
|
gpio_keys {
|
|
compatible = "gpio-keys";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
button@1 {
|
|
debounce_interval = <50>;
|
|
wakeup = <1>;
|
|
linux,code = <2>;
|
|
label = "userpb";
|
|
gpios = <&gpio1 0 0x4>;
|
|
};
|
|
button@2 {
|
|
debounce_interval = <50>;
|
|
wakeup = <1>;
|
|
linux,code = <3>;
|
|
label = "extkb1";
|
|
gpios = <&gpio4 23 0x4>;
|
|
};
|
|
button@3 {
|
|
debounce_interval = <50>;
|
|
wakeup = <1>;
|
|
linux,code = <4>;
|
|
label = "extkb2";
|
|
gpios = <&gpio4 24 0x4>;
|
|
};
|
|
button@4 {
|
|
debounce_interval = <50>;
|
|
wakeup = <1>;
|
|
linux,code = <5>;
|
|
label = "extkb3";
|
|
gpios = <&gpio5 1 0x4>;
|
|
};
|
|
button@5 {
|
|
debounce_interval = <50>;
|
|
wakeup = <1>;
|
|
linux,code = <6>;
|
|
label = "extkb4";
|
|
gpios = <&gpio5 2 0x4>;
|
|
};
|
|
};
|
|
|
|
leds {
|
|
compatible = "gpio-leds";
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&gpioled_snowball_mode>;
|
|
used-led {
|
|
label = "user_led";
|
|
gpios = <&gpio4 14 0x4>;
|
|
default-state = "on";
|
|
linux,default-trigger = "heartbeat";
|
|
};
|
|
};
|
|
|
|
soc {
|
|
usb_per5@a03e0000 {
|
|
pinctrl-names = "default", "sleep";
|
|
pinctrl-0 = <&musb_default_mode>;
|
|
pinctrl-1 = <&musb_sleep_mode>;
|
|
};
|
|
|
|
sound {
|
|
compatible = "stericsson,snd-soc-mop500";
|
|
|
|
stericsson,cpu-dai = <&msp1 &msp3>;
|
|
stericsson,audio-codec = <&codec>;
|
|
};
|
|
|
|
msp0: msp@80123000 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&msp0_default_mode>;
|
|
status = "okay";
|
|
};
|
|
|
|
msp1: msp@80124000 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&msp1_default_mode>;
|
|
status = "okay";
|
|
};
|
|
|
|
msp2: msp@80117000 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&msp2_default_mode>;
|
|
status = "okay";
|
|
};
|
|
|
|
msp3: msp@80125000 {
|
|
status = "okay";
|
|
};
|
|
|
|
external-bus@50000000 {
|
|
status = "okay";
|
|
|
|
ethernet@0 {
|
|
compatible = "smsc,lan9115";
|
|
reg = <0 0x10000>;
|
|
interrupts = <12 IRQ_TYPE_EDGE_RISING>;
|
|
interrupt-parent = <&gpio4>;
|
|
vdd33a-supply = <&en_3v3_reg>;
|
|
vddvario-supply = <&db8500_vape_reg>;
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <ð_snowball_mode>;
|
|
|
|
reg-shift = <1>;
|
|
reg-io-width = <2>;
|
|
smsc,force-internal-phy;
|
|
smsc,irq-active-high;
|
|
smsc,irq-push-pull;
|
|
|
|
clocks = <&prcc_pclk 3 0>;
|
|
};
|
|
};
|
|
|
|
vmmci: regulator-gpio {
|
|
gpios = <&gpio7 4 0x4>;
|
|
enable-gpio = <&gpio6 25 0x4>;
|
|
};
|
|
|
|
// External Micro SD slot
|
|
sdi0_per1@80126000 {
|
|
arm,primecell-periphid = <0x10480180>;
|
|
max-frequency = <100000000>;
|
|
bus-width = <4>;
|
|
mmc-cap-mmc-highspeed;
|
|
vmmc-supply = <&ab8500_ldo_aux3_reg>;
|
|
vqmmc-supply = <&vmmci>;
|
|
pinctrl-names = "default", "sleep";
|
|
pinctrl-0 = <&sdi0_default_mode>;
|
|
pinctrl-1 = <&sdi0_sleep_mode>;
|
|
|
|
cd-gpios = <&gpio6 26 0x4>; // 218
|
|
cd-inverted;
|
|
|
|
status = "okay";
|
|
};
|
|
|
|
// WLAN SDIO channel
|
|
sdi1_per2@80118000 {
|
|
arm,primecell-periphid = <0x10480180>;
|
|
max-frequency = <100000000>;
|
|
bus-width = <4>;
|
|
pinctrl-names = "default", "sleep";
|
|
pinctrl-0 = <&sdi1_default_mode>;
|
|
pinctrl-1 = <&sdi1_sleep_mode>;
|
|
|
|
status = "okay";
|
|
};
|
|
|
|
// Unused PoP eMMC - register and put it to sleep by default */
|
|
sdi2_per3@80005000 {
|
|
arm,primecell-periphid = <0x10480180>;
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&sdi2_sleep_mode>;
|
|
|
|
status = "okay";
|
|
};
|
|
|
|
// On-board eMMC
|
|
sdi4_per2@80114000 {
|
|
arm,primecell-periphid = <0x10480180>;
|
|
max-frequency = <100000000>;
|
|
bus-width = <8>;
|
|
mmc-cap-mmc-highspeed;
|
|
vmmc-supply = <&ab8500_ldo_aux2_reg>;
|
|
pinctrl-names = "default", "sleep";
|
|
pinctrl-0 = <&sdi4_default_mode>;
|
|
pinctrl-1 = <&sdi4_sleep_mode>;
|
|
|
|
status = "okay";
|
|
};
|
|
|
|
uart@80120000 {
|
|
pinctrl-names = "default", "sleep";
|
|
pinctrl-0 = <&uart0_default_mode>;
|
|
pinctrl-1 = <&uart0_sleep_mode>;
|
|
status = "okay";
|
|
};
|
|
|
|
uart@80121000 {
|
|
pinctrl-names = "default", "sleep";
|
|
pinctrl-0 = <&uart1_default_mode>;
|
|
pinctrl-1 = <&uart1_sleep_mode>;
|
|
status = "okay";
|
|
};
|
|
|
|
uart@80007000 {
|
|
pinctrl-names = "default", "sleep";
|
|
pinctrl-0 = <&uart2_default_mode>;
|
|
pinctrl-1 = <&uart2_sleep_mode>;
|
|
status = "okay";
|
|
};
|
|
|
|
i2c@80004000 {
|
|
pinctrl-names = "default","sleep";
|
|
pinctrl-0 = <&i2c0_default_mode>;
|
|
pinctrl-1 = <&i2c0_sleep_mode>;
|
|
};
|
|
|
|
i2c@80122000 {
|
|
pinctrl-names = "default","sleep";
|
|
pinctrl-0 = <&i2c1_default_mode>;
|
|
pinctrl-1 = <&i2c1_sleep_mode>;
|
|
};
|
|
|
|
i2c@80128000 {
|
|
pinctrl-names = "default","sleep";
|
|
pinctrl-0 = <&i2c2_default_mode>;
|
|
pinctrl-1 = <&i2c2_sleep_mode>;
|
|
};
|
|
|
|
i2c@80110000 {
|
|
pinctrl-names = "default","sleep";
|
|
pinctrl-0 = <&i2c3_default_mode>;
|
|
pinctrl-1 = <&i2c3_sleep_mode>;
|
|
};
|
|
|
|
ssp@80002000 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&ssp0_snowball_mode>;
|
|
};
|
|
|
|
cpufreq-cooling {
|
|
status = "okay";
|
|
};
|
|
|
|
prcmu@80157000 {
|
|
cpufreq {
|
|
status = "okay";
|
|
};
|
|
|
|
thermal@801573c0 {
|
|
num-trips = <4>;
|
|
|
|
trip0-temp = <70000>;
|
|
trip0-type = "active";
|
|
trip0-cdev-num = <1>;
|
|
trip0-cdev-name0 = "thermal-cpufreq-0";
|
|
|
|
trip1-temp = <75000>;
|
|
trip1-type = "active";
|
|
trip1-cdev-num = <1>;
|
|
trip1-cdev-name0 = "thermal-cpufreq-0";
|
|
|
|
trip2-temp = <80000>;
|
|
trip2-type = "active";
|
|
trip2-cdev-num = <1>;
|
|
trip2-cdev-name0 = "thermal-cpufreq-0";
|
|
|
|
trip3-temp = <85000>;
|
|
trip3-type = "critical";
|
|
trip3-cdev-num = <0>;
|
|
|
|
status = "okay";
|
|
};
|
|
|
|
ab8500 {
|
|
ab8500-gpio {
|
|
compatible = "stericsson,ab8500-gpio";
|
|
};
|
|
|
|
ext_regulators: ab8500-ext-regulators {
|
|
ab8500_ext1_reg: ab8500_ext1 {
|
|
regulator-name = "ab8500-ext-supply1";
|
|
};
|
|
|
|
ab8500_ext2_reg_reg: ab8500_ext2 {
|
|
regulator-name = "ab8500-ext-supply2";
|
|
};
|
|
|
|
ab8500_ext3_reg_reg: ab8500_ext3 {
|
|
regulator-name = "ab8500-ext-supply3";
|
|
};
|
|
};
|
|
|
|
ab8500-regulators {
|
|
ab8500_ldo_aux1_reg: ab8500_ldo_aux1 {
|
|
regulator-name = "V-DISPLAY";
|
|
};
|
|
|
|
ab8500_ldo_aux2_reg: ab8500_ldo_aux2 {
|
|
regulator-name = "V-eMMC1";
|
|
};
|
|
|
|
ab8500_ldo_aux3_reg: ab8500_ldo_aux3 {
|
|
regulator-name = "V-MMC-SD";
|
|
};
|
|
|
|
ab8500_ldo_intcore_reg: ab8500_ldo_intcore {
|
|
regulator-name = "V-INTCORE";
|
|
};
|
|
|
|
ab8500_ldo_tvout_reg: ab8500_ldo_tvout {
|
|
regulator-name = "V-TVOUT";
|
|
};
|
|
|
|
ab8500_ldo_usb_reg: ab8500_ldo_usb {
|
|
regulator-name = "dummy";
|
|
};
|
|
|
|
ab8500_ldo_audio_reg: ab8500_ldo_audio {
|
|
regulator-name = "V-AUD";
|
|
};
|
|
|
|
ab8500_ldo_anamic1_reg: ab8500_ldo_anamic1 {
|
|
regulator-name = "V-AMIC1";
|
|
};
|
|
|
|
ab8500_ldo_anamic2_reg: ab8500_ldo_anamic2 {
|
|
regulator-name = "V-AMIC2";
|
|
};
|
|
|
|
ab8500_ldo_dmic_reg: ab8500_ldo_dmic {
|
|
regulator-name = "V-DMIC";
|
|
};
|
|
|
|
ab8500_ldo_ana_reg: ab8500_ldo_ana {
|
|
regulator-name = "V-CSI/DSI";
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
pinctrl {
|
|
/*
|
|
* Set this up using hogs, as time goes by and as seems fit, these
|
|
* can be moved over to being controlled by respective device.
|
|
*/
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&accel_snowball_mode>,
|
|
<&magneto_snowball_mode>,
|
|
<&gbf_snowball_mode>,
|
|
<&wlan_snowball_mode>;
|
|
|
|
ethernet {
|
|
/*
|
|
* Mux in "SM" which is used for the
|
|
* SMSC911x Ethernet adapter
|
|
*/
|
|
eth_snowball_mode: eth_snowball {
|
|
snowball_mux {
|
|
ste,function = "sm";
|
|
ste,pins = "sm_b_1";
|
|
};
|
|
/* LAN IRQ pin */
|
|
snowball_cfg1 {
|
|
ste,pins = "GPIO140_B11";
|
|
ste,config = <&in_nopull>;
|
|
};
|
|
/* LAN reset pin */
|
|
snowball_cfg2 {
|
|
ste,pins = "GPIO141_C12";
|
|
ste,config = <&gpio_out_hi>;
|
|
};
|
|
|
|
};
|
|
};
|
|
sdi0 {
|
|
sdi0_default_mode: sdi0_default {
|
|
snowball_mux {
|
|
ste,function = "mc0";
|
|
ste,pins = "mc0dat31dir_a_1";
|
|
};
|
|
snowball_cfg1 {
|
|
ste,pins = "GPIO21_AB3"; /* DAT31DIR */
|
|
ste,config = <&out_hi>;
|
|
};
|
|
|
|
};
|
|
};
|
|
ssp0 {
|
|
ssp0_snowball_mode: ssp0_snowball_default {
|
|
snowball_mux {
|
|
ste,function = "ssp0";
|
|
ste,pins = "ssp0_a_1";
|
|
};
|
|
snowball_cfg1 {
|
|
ste,pins = "GPIO144_B13"; /* FRM */
|
|
ste,config = <&gpio_out_hi>;
|
|
};
|
|
snowball_cfg2 {
|
|
ste,pins = "GPIO145_C13"; /* RXD */
|
|
ste,config = <&in_pd>;
|
|
};
|
|
snowball_cfg3 {
|
|
ste,pins =
|
|
"GPIO146_D13", /* TXD */
|
|
"GPIO143_D12"; /* CLK */
|
|
ste,config = <&out_lo>;
|
|
};
|
|
|
|
};
|
|
};
|
|
gpio_led {
|
|
gpioled_snowball_mode: gpioled_default {
|
|
snowball_cfg1 {
|
|
ste,pins = "GPIO142_C11";
|
|
ste,config = <&gpio_out_hi>;
|
|
};
|
|
|
|
};
|
|
};
|
|
accelerometer {
|
|
accel_snowball_mode: accel_snowball {
|
|
/* Accelerometer lines */
|
|
snowball_cfg1 {
|
|
ste,pins =
|
|
"GPIO163_C20", /* ACCEL_IRQ1 */
|
|
"GPIO164_B21"; /* ACCEL_IRQ2 */
|
|
ste,config = <&gpio_in_pu>;
|
|
};
|
|
};
|
|
};
|
|
magnetometer {
|
|
magneto_snowball_mode: magneto_snowball {
|
|
snowball_cfg1 {
|
|
ste,pins = "GPIO165_C21"; /* MAG_DRDY */
|
|
ste,config = <&gpio_in_pu>;
|
|
};
|
|
};
|
|
};
|
|
gbf {
|
|
gbf_snowball_mode: gbf_snowball {
|
|
/*
|
|
* GBF (GPS, Bluetooth, FM-radio) interface,
|
|
* pull low to reset state
|
|
*/
|
|
snowball_cfg1 {
|
|
ste,pins = "GPIO171_D23"; /* GBF_ENA_RESET */
|
|
ste,config = <&gpio_out_lo>;
|
|
};
|
|
};
|
|
};
|
|
wlan {
|
|
wlan_snowball_mode: wlan_snowball {
|
|
/*
|
|
* Activate this mode with the WLAN chip.
|
|
* These are plain GPIO pins used by WLAN
|
|
*/
|
|
snowball_cfg1 {
|
|
ste,pins =
|
|
"GPIO161_D21", /* WLAN_PMU_EN */
|
|
"GPIO215_AH13"; /* WLAN_ENA */
|
|
ste,config = <&gpio_out_lo>;
|
|
};
|
|
snowball_cfg2 {
|
|
ste,pins = "GPIO216_AG12"; /* WLAN_IRQ */
|
|
ste,config = <&gpio_in_pu>;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
mcde@a0350000 {
|
|
pinctrl-names = "default", "sleep";
|
|
pinctrl-0 = <&lcd_default_mode>;
|
|
pinctrl-1 = <&lcd_sleep_mode>;
|
|
};
|
|
};
|
|
};
|