blob: 9f6276cbb2bb1d2c1c28c3be88d1de9c5caf10ae [file] [log] [blame]
David Collinsb4558422012-01-05 10:50:49 -08001/* Copyright (c) 2011-2012, Code Aurora Forum. All rights reserved.
Stepan Moskovchenko39236d72011-11-30 17:42:23 -08002 *
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License version 2 and
5 * only version 2 as published by the Free Software Foundation.
6 *
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
11 */
12
13#ifndef __ARCH_ARM_MACH_MSM_BOARD_MSM8930_H
14#define __ARCH_ARM_MACH_MSM_BOARD_MSM8930_H
15
David Collinse92b76a2012-01-05 10:57:24 -080016#define MSM8930_PHASE_2
17
Steve Mucklef132c6c2012-06-06 18:30:57 -070018#include <linux/regulator/msm-gpio-regulator.h>
Jay Chokshi06fa7542011-12-07 13:09:17 -080019#include <linux/mfd/pm8xxx/pm8038.h>
Kevin Chan09f4e662011-12-16 08:17:02 -080020#include <linux/i2c.h>
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080021#include <linux/i2c/sx150x.h>
22#include <mach/irqs.h>
23#include <mach/rpm-regulator.h>
Huaibin Yanga5419422011-12-08 23:52:10 -080024#include <mach/msm_memtypes.h>
Laura Abbott532b2df2012-04-12 10:53:48 -070025#include <mach/msm_rtb.h>
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080026
Jay Chokshi06fa7542011-12-07 13:09:17 -080027/*
28 * TODO: When physical 8930/PM8038 hardware becomes
29 * available, remove this block.
30 */
31#ifndef MSM8930_PHASE_2
32#include <linux/mfd/pm8xxx/pm8921.h>
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080033#define PM8921_GPIO_BASE NR_GPIO_IRQS
34#define PM8921_GPIO_PM_TO_SYS(pm_gpio) (pm_gpio - 1 + PM8921_GPIO_BASE)
35#define PM8921_MPP_BASE (PM8921_GPIO_BASE + PM8921_NR_GPIOS)
36#define PM8921_MPP_PM_TO_SYS(pm_gpio) (pm_gpio - 1 + PM8921_MPP_BASE)
Jay Chokshi06fa7542011-12-07 13:09:17 -080037#endif
38
39/* Macros assume PMIC GPIOs and MPPs start at 1 */
40#define PM8038_GPIO_BASE NR_GPIO_IRQS
41#define PM8038_GPIO_PM_TO_SYS(pm_gpio) (pm_gpio - 1 + PM8038_GPIO_BASE)
42#define PM8038_MPP_BASE (PM8038_GPIO_BASE + PM8038_NR_GPIOS)
43#define PM8038_MPP_PM_TO_SYS(pm_gpio) (pm_gpio - 1 + PM8038_MPP_BASE)
44#define PM8038_IRQ_BASE (NR_MSM_IRQS + NR_GPIO_IRQS)
45
46/*
47 * TODO: When physical 8930/PM8038 hardware becomes
48 * available, replace this block with 8930/pm8038 regulator
49 * declarations.
50 */
51#ifndef MSM8930_PHASE_2
David Collins75016742011-12-02 15:04:25 -080052extern struct pm8xxx_regulator_platform_data
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080053 msm_pm8921_regulator_pdata[] __devinitdata;
54
55extern int msm_pm8921_regulator_pdata_len __devinitdata;
56
Jay Chokshi06fa7542011-12-07 13:09:17 -080057extern struct gpio_regulator_platform_data
58 msm_gpio_regulator_pdata[] __devinitdata;
59
60extern struct rpm_regulator_platform_data msm_rpm_regulator_pdata __devinitdata;
Jay Chokshi06fa7542011-12-07 13:09:17 -080061
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080062#define GPIO_VREG_ID_EXT_5V 0
63#define GPIO_VREG_ID_EXT_L2 1
64#define GPIO_VREG_ID_EXT_3P3V 2
David Collins1d4061b2011-12-06 15:36:40 -080065#endif
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080066
David Collinsb4558422012-01-05 10:50:49 -080067extern struct regulator_init_data msm8930_saw_regulator_core0_pdata;
68extern struct regulator_init_data msm8930_saw_regulator_core1_pdata;
69
David Collins1d4061b2011-12-06 15:36:40 -080070extern struct pm8xxx_regulator_platform_data
71 msm8930_pm8038_regulator_pdata[] __devinitdata;
72
73extern int msm8930_pm8038_regulator_pdata_len __devinitdata;
74
75#define MSM8930_GPIO_VREG_ID_EXT_5V 0
76#define MSM8930_GPIO_VREG_ID_EXT_OTG_SW 1
77
78extern struct gpio_regulator_platform_data
79 msm8930_gpio_regulator_pdata[] __devinitdata;
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080080
David Collins8af872e2012-01-06 11:31:56 -080081extern struct rpm_regulator_platform_data
82 msm8930_rpm_regulator_pdata __devinitdata;
83
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080084#if defined(CONFIG_GPIO_SX150X) || defined(CONFIG_GPIO_SX150X_MODULE)
85enum {
Jay Chokshi06fa7542011-12-07 13:09:17 -080086 GPIO_EXPANDER_IRQ_BASE = (PM8038_IRQ_BASE + PM8038_NR_IRQS),
87 GPIO_EXPANDER_GPIO_BASE = (PM8038_MPP_BASE + PM8038_NR_MPPS),
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080088 /* CAM Expander */
89 GPIO_CAM_EXPANDER_BASE = GPIO_EXPANDER_GPIO_BASE,
90 GPIO_CAM_GP_STROBE_READY = GPIO_CAM_EXPANDER_BASE,
91 GPIO_CAM_GP_AFBUSY,
92 GPIO_CAM_GP_STROBE_CE,
93 GPIO_CAM_GP_CAM1MP_XCLR,
94 GPIO_CAM_GP_CAMIF_RESET_N,
95 GPIO_CAM_GP_XMT_FLASH_INT,
96 GPIO_CAM_GP_LED_EN1,
97 GPIO_CAM_GP_LED_EN2,
98
99};
100#endif
101
102enum {
103 SX150X_CAM,
104};
105
106#endif
107
108extern struct sx150x_platform_data msm8930_sx150x_data[];
Kevin Chan09f4e662011-12-16 08:17:02 -0800109extern struct msm_camera_board_info msm8930_camera_board_info;
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800110void msm8930_init_cam(void);
111void msm8930_init_fb(void);
112void msm8930_init_pmic(void);
Arun Menonaabf2632012-02-24 15:30:47 -0800113extern void msm8930_add_vidc_device(void);
Jay Chokshi06fa7542011-12-07 13:09:17 -0800114
115/*
116 * TODO: When physical 8930/PM8038 hardware becomes
117 * available, remove this block or add the config
118 * option.
119 */
120#ifndef MSM8930_PHASE_2
121void msm8960_init_pmic(void);
122void msm8960_pm8921_gpio_mpp_init(void);
123#endif
124
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800125void msm8930_init_mmc(void);
Stepan Moskovchenko3b09bf52011-12-06 20:40:53 -0800126int msm8930_init_gpiomux(void);
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800127void msm8930_allocate_fb_region(void);
Jay Chokshi06fa7542011-12-07 13:09:17 -0800128void msm8930_pm8038_gpio_mpp_init(void);
Huaibin Yanga5419422011-12-08 23:52:10 -0800129void msm8930_mdp_writeback(struct memtype_reserve *reserve_table);
Sudhakara Rao Tentu8b5c8ed2012-03-05 14:48:41 +0530130void __init msm8930_init_gpu(void);
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800131
Stepan Moskovchenko3b09bf52011-12-06 20:40:53 -0800132#define PLATFORM_IS_CHARM25() \
133 (machine_is_msm8930_cdp() && \
134 (socinfo_get_platform_subtype() == 1) \
135 )
136
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800137#define MSM_8930_GSBI3_QUP_I2C_BUS_ID 3
Amy Malochee8de95d2012-02-23 10:40:25 -0800138#define MSM_8930_GSBI4_QUP_I2C_BUS_ID 4
139#define MSM_8930_GSBI9_QUP_I2C_BUS_ID 0
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800140#define MSM_8930_GSBI10_QUP_I2C_BUS_ID 10
Wentao Xuf59ce4e2012-05-22 17:30:13 -0400141#define MSM_8930_GSBI12_QUP_I2C_BUS_ID 12
Laura Abbott532b2df2012-04-12 10:53:48 -0700142
143extern struct msm_rtb_platform_data msm8930_rtb_pdata;
Laura Abbottf3173042012-05-29 15:23:18 -0700144extern struct msm_cache_dump_platform_data msm8930_cache_dump_pdata;