mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-04 08:15:44 +00:00
99c6bcf46d
More multiplatform enablement for ARM platforms. The ones converted in this branch are: - bcm2835 - cns3xxx - sirf - nomadik - msx - spear - tegra - ux500 We're getting close to having most of them converted! One of the larger platforms remaining is Samsung Exynos, and there are a bunch of supporting patches in this merge window for it. There was a patch in this branch to a early version of multiplatform conversion, but it ended up being reverted due to need of more bake time. The revert commit is part of the branch since it would have required rebasing multiple dependent branches and they were stable by then. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.11 (GNU/Linux) iQIcBAABAgAGBQJRgg99AAoJEIwa5zzehBx3n78P/j0w/8v+F4dM29ba5M/tqbFI e3wpeFykZ/HJH+FFIEYfIablpfHsLB0LEMh0dZmwHESFC6eR0RfGL2jOkpfcH9Ne 7B/JIFN4l1iwqqKCXf+QbYL6e8YFxlJkg6BIB4KhNgliQoO/ASP/8EbcgROYuxmN KPVdw9laUCCvb5Ogh2NWVAkBHhVGAEiqK20r4TQz8alI8RUmMleWM3o+wLBWVhOO d3gtYSfuFSbrJfbpKSdycLizoV/NekdOC1A9Ov9YuOdw8DzNbrThCRQtu0tIUgxN JjfnGlEJLsJS9SESfr8SYWxTuhe/lB2dGqjQPvRtl2HGBhbtTlnWfQ0k2ZHdeJuD J50SLrGA2gN9E5PlHJXjYk8uhhGIq8bNTJ//CtDkfKTq1D7PuHVEpEctsaz3BBbM U+x9zP2v4FB+yrZu8w+gkQY/wDgHsxj08mT6BK0+l8ePdyQV22CvwmM5XlJFI03x 5J0nLYiYfef+ZN9rGgVrQbn+yv+IEkE4DmeiscjeVJE5LVdVrDpYGfx7UA7V0UA7 i3KRVpNKuy1v7GJDnKlEBPkmB+vgXTRXUPDVCuC4n0Hi5PYj4es1gY6AoXGF90wm vtKxGr/2XDLP7Ro+m0OXMttSgQShnmbrbOngfkWcFwUmG7cB3SSUUOGKM+2LNnXM MJTqVhPjkZ2GYBi/J6S/ =4hSo -----END PGP SIGNATURE----- Merge tag 'multiplatform-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc Pull ARM SoC multiplatform updates from Olof Johansson: "More multiplatform enablement for ARM platforms. The ones converted in this branch are: - bcm2835 - cns3xxx - sirf - nomadik - msx - spear - tegra - ux500 We're getting close to having most of them converted! One of the larger platforms remaining is Samsung Exynos, and there are a bunch of supporting patches in this merge window for it. There was a patch in this branch to a early version of multiplatform conversion, but it ended up being reverted due to need of more bake time. The revert commit is part of the branch since it would have required rebasing multiple dependent branches and they were stable by then" * tag 'multiplatform-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc: (70 commits) mmc: sdhci-s3c: Fix operation on non-single image Samsung platforms clocksource: nomadik-mtu: fix up clocksource/timer Revert "ARM: exynos: enable multiplatform support" ARM: SPEAr13xx: Fix typo "ARCH_HAVE_CPUFREQ" ARM: exynos: enable multiplatform support rtc: s3c: make header file local mtd: onenand/samsung: make regs-onenand.h file local thermal/exynos: remove unnecessary header inclusions mmc: sdhci-s3c: remove platform dependencies ARM: samsung: move mfc device definition to s5p-dev-mfc.c ARM: exynos: move debug-macro.S to include/debug/ ARM: exynos: prepare for sparse IRQ ARM: exynos: introduce EXYNOS_ATAGS symbol ARM: tegra: build assembly files with -march=armv7-a ARM: Push selects for TWD/SCU into machine entries ARM: ux500: build hotplug.o for ARMv7-a ARM: ux500: move to multiplatform ARM: ux500: make remaining headers local ARM: ux500: make irqs.h local to platform ARM: ux500: get rid of <mach/[hardware|db8500-regs].h> ...
113 lines
4.3 KiB
C
113 lines
4.3 KiB
C
/*
|
|
* Copyright (C) ST-Ericsson SA 2010
|
|
*
|
|
* License terms: GNU General Public License (GPL) version 2
|
|
*/
|
|
|
|
#ifndef __BOARD_MOP500_H
|
|
#define __BOARD_MOP500_H
|
|
|
|
/* For NOMADIK_NR_GPIO */
|
|
#include "irqs.h"
|
|
#include <linux/platform_data/asoc-ux500-msp.h>
|
|
#include <linux/amba/mmci.h>
|
|
|
|
/* Snowball specific GPIO assignments, this board has no GPIO expander */
|
|
#define SNOWBALL_ACCEL_INT1_GPIO 163
|
|
#define SNOWBALL_ACCEL_INT2_GPIO 164
|
|
#define SNOWBALL_MAGNET_DRDY_GPIO 165
|
|
#define SNOWBALL_SDMMC_EN_GPIO 217
|
|
#define SNOWBALL_SDMMC_1V8_3V_GPIO 228
|
|
#define SNOWBALL_SDMMC_CD_GPIO 218
|
|
|
|
/* HREFv60-specific GPIO assignments, this board has no GPIO expander */
|
|
#define HREFV60_SDMMC_1V8_3V_GPIO 5
|
|
#define HREFV60_CAMERA_FLASH_ENABLE 21
|
|
#define HREFV60_MAGNET_DRDY_GPIO 32
|
|
#define HREFV60_DISP1_RST_GPIO 65
|
|
#define HREFV60_DISP2_RST_GPIO 66
|
|
#define HREFV60_ACCEL_INT1_GPIO 82
|
|
#define HREFV60_ACCEL_INT2_GPIO 83
|
|
#define HREFV60_SDMMC_CD_GPIO 95
|
|
#define HREFV60_XSHUTDOWN_SECONDARY_SENSOR 140
|
|
#define HREFV60_TOUCH_RST_GPIO 143
|
|
#define HREFV60_HAL_SW_GPIO 145
|
|
#define HREFV60_SDMMC_EN_GPIO 169
|
|
#define HREFV60_MMIO_XENON_CHARGE 170
|
|
#define HREFV60_PROX_SENSE_GPIO 217
|
|
|
|
/* MOP500 generic GPIOs */
|
|
#define CAMERA_FLASH_INT_PIN 7
|
|
#define CYPRESS_TOUCH_INT_PIN 84
|
|
#define XSHUTDOWN_PRIMARY_SENSOR 141
|
|
#define XSHUTDOWN_SECONDARY_SENSOR 142
|
|
#define CYPRESS_TOUCH_RST_GPIO 143
|
|
#define MOP500_HDMI_RST_GPIO 196
|
|
#define CYPRESS_SLAVE_SELECT_GPIO 216
|
|
|
|
/* GPIOs on the TC35892 expander */
|
|
#define MOP500_EGPIO(x) (NOMADIK_NR_GPIO + (x))
|
|
#define GPIO_MAGNET_DRDY MOP500_EGPIO(1)
|
|
#define GPIO_SDMMC_CD MOP500_EGPIO(3)
|
|
#define GPIO_CAMERA_FLASH_ENABLE MOP500_EGPIO(4)
|
|
#define GPIO_MMIO_XENON_CHARGE MOP500_EGPIO(5)
|
|
#define GPIO_PROX_SENSOR MOP500_EGPIO(7)
|
|
#define GPIO_HAL_SENSOR MOP500_EGPIO(8)
|
|
#define GPIO_ACCEL_INT1 MOP500_EGPIO(10)
|
|
#define GPIO_ACCEL_INT2 MOP500_EGPIO(11)
|
|
#define GPIO_BU21013_CS MOP500_EGPIO(13)
|
|
#define MOP500_DISP2_RST_GPIO MOP500_EGPIO(14)
|
|
#define MOP500_DISP1_RST_GPIO MOP500_EGPIO(15)
|
|
#define GPIO_SDMMC_EN MOP500_EGPIO(17)
|
|
#define GPIO_SDMMC_1V8_3V_SEL MOP500_EGPIO(18)
|
|
#define MOP500_EGPIO_END MOP500_EGPIO(24)
|
|
|
|
/*
|
|
* GPIOs on the AB8500 mixed-signals circuit
|
|
* Notice that we subtract 1 from the number passed into the macro, this is
|
|
* because the AB8500 GPIO pins are enumbered starting from 1, so the value in
|
|
* parens matches the GPIO pin number in the data sheet.
|
|
*/
|
|
#define MOP500_AB8500_PIN_GPIO(x) (MOP500_EGPIO_END + (x) - 1)
|
|
/*Snowball AB8500 GPIO */
|
|
#define SNOWBALL_VSMPS2_1V8_GPIO MOP500_AB8500_PIN_GPIO(1) /* SYSCLKREQ2/GPIO1 */
|
|
#define SNOWBALL_PM_GPIO1_GPIO MOP500_AB8500_PIN_GPIO(2) /* SYSCLKREQ3/GPIO2 */
|
|
#define SNOWBALL_WLAN_CLK_REQ_GPIO MOP500_AB8500_PIN_GPIO(3) /* SYSCLKREQ4/GPIO3 */
|
|
#define SNOWBALL_PM_GPIO4_GPIO MOP500_AB8500_PIN_GPIO(4) /* SYSCLKREQ6/GPIO4 */
|
|
#define SNOWBALL_EN_3V6_GPIO MOP500_AB8500_PIN_GPIO(16) /* PWMOUT3/GPIO16 */
|
|
#define SNOWBALL_PME_ETH_GPIO MOP500_AB8500_PIN_GPIO(24) /* SYSCLKREQ7/GPIO24 */
|
|
#define SNOWBALL_EN_3V3_ETH_GPIO MOP500_AB8500_PIN_GPIO(26) /* GPIO26 */
|
|
|
|
struct device;
|
|
struct i2c_board_info;
|
|
extern struct mmci_platform_data mop500_sdi0_data;
|
|
extern struct mmci_platform_data mop500_sdi1_data;
|
|
extern struct mmci_platform_data mop500_sdi2_data;
|
|
extern struct mmci_platform_data mop500_sdi4_data;
|
|
extern struct msp_i2s_platform_data msp0_platform_data;
|
|
extern struct msp_i2s_platform_data msp1_platform_data;
|
|
extern struct msp_i2s_platform_data msp2_platform_data;
|
|
extern struct msp_i2s_platform_data msp3_platform_data;
|
|
extern struct arm_pmu_platdata db8500_pmu_platdata;
|
|
extern struct amba_pl011_data uart0_plat;
|
|
extern struct amba_pl011_data uart1_plat;
|
|
extern struct amba_pl011_data uart2_plat;
|
|
extern struct pl022_ssp_controller ssp0_plat;
|
|
|
|
extern void mop500_sdi_init(struct device *parent);
|
|
extern void snowball_sdi_init(struct device *parent);
|
|
extern void hrefv60_sdi_init(struct device *parent);
|
|
extern void mop500_sdi_tc35892_init(struct device *parent);
|
|
void __init mop500_u8500uib_init(void);
|
|
void __init mop500_stuib_init(void);
|
|
void __init mop500_pinmaps_init(void);
|
|
void __init snowball_pinmaps_init(void);
|
|
void __init hrefv60_pinmaps_init(void);
|
|
void mop500_audio_init(struct device *parent);
|
|
void mop500_snowball_ethernet_clock_enable(void);
|
|
|
|
int __init mop500_uib_init(void);
|
|
void mop500_uib_i2c_add(int busnum, struct i2c_board_info *info,
|
|
unsigned n);
|
|
#endif
|