blob: cefaff591865468166241b2d53ebb2a809db770b [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
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080018#include <linux/regulator/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>
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080025
Jay Chokshi06fa7542011-12-07 13:09:17 -080026/*
27 * TODO: When physical 8930/PM8038 hardware becomes
28 * available, remove this block.
29 */
30#ifndef MSM8930_PHASE_2
31#include <linux/mfd/pm8xxx/pm8921.h>
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080032#define PM8921_GPIO_BASE NR_GPIO_IRQS
33#define PM8921_GPIO_PM_TO_SYS(pm_gpio) (pm_gpio - 1 + PM8921_GPIO_BASE)
34#define PM8921_MPP_BASE (PM8921_GPIO_BASE + PM8921_NR_GPIOS)
35#define PM8921_MPP_PM_TO_SYS(pm_gpio) (pm_gpio - 1 + PM8921_MPP_BASE)
Jay Chokshi06fa7542011-12-07 13:09:17 -080036#endif
37
38/* Macros assume PMIC GPIOs and MPPs start at 1 */
39#define PM8038_GPIO_BASE NR_GPIO_IRQS
40#define PM8038_GPIO_PM_TO_SYS(pm_gpio) (pm_gpio - 1 + PM8038_GPIO_BASE)
41#define PM8038_MPP_BASE (PM8038_GPIO_BASE + PM8038_NR_GPIOS)
42#define PM8038_MPP_PM_TO_SYS(pm_gpio) (pm_gpio - 1 + PM8038_MPP_BASE)
43#define PM8038_IRQ_BASE (NR_MSM_IRQS + NR_GPIO_IRQS)
44
45/*
46 * TODO: When physical 8930/PM8038 hardware becomes
47 * available, replace this block with 8930/pm8038 regulator
48 * declarations.
49 */
50#ifndef MSM8930_PHASE_2
David Collins75016742011-12-02 15:04:25 -080051extern struct pm8xxx_regulator_platform_data
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080052 msm_pm8921_regulator_pdata[] __devinitdata;
53
54extern int msm_pm8921_regulator_pdata_len __devinitdata;
55
Jay Chokshi06fa7542011-12-07 13:09:17 -080056extern struct gpio_regulator_platform_data
57 msm_gpio_regulator_pdata[] __devinitdata;
58
59extern struct rpm_regulator_platform_data msm_rpm_regulator_pdata __devinitdata;
Jay Chokshi06fa7542011-12-07 13:09:17 -080060
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080061#define GPIO_VREG_ID_EXT_5V 0
62#define GPIO_VREG_ID_EXT_L2 1
63#define GPIO_VREG_ID_EXT_3P3V 2
David Collins1d4061b2011-12-06 15:36:40 -080064#endif
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080065
David Collinsb4558422012-01-05 10:50:49 -080066extern struct regulator_init_data msm8930_saw_regulator_core0_pdata;
67extern struct regulator_init_data msm8930_saw_regulator_core1_pdata;
68
David Collins1d4061b2011-12-06 15:36:40 -080069extern struct pm8xxx_regulator_platform_data
70 msm8930_pm8038_regulator_pdata[] __devinitdata;
71
72extern int msm8930_pm8038_regulator_pdata_len __devinitdata;
73
74#define MSM8930_GPIO_VREG_ID_EXT_5V 0
75#define MSM8930_GPIO_VREG_ID_EXT_OTG_SW 1
76
77extern struct gpio_regulator_platform_data
78 msm8930_gpio_regulator_pdata[] __devinitdata;
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080079
David Collins8af872e2012-01-06 11:31:56 -080080extern struct rpm_regulator_platform_data
81 msm8930_rpm_regulator_pdata __devinitdata;
82
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080083#if defined(CONFIG_GPIO_SX150X) || defined(CONFIG_GPIO_SX150X_MODULE)
84enum {
Jay Chokshi06fa7542011-12-07 13:09:17 -080085 GPIO_EXPANDER_IRQ_BASE = (PM8038_IRQ_BASE + PM8038_NR_IRQS),
86 GPIO_EXPANDER_GPIO_BASE = (PM8038_MPP_BASE + PM8038_NR_MPPS),
Stepan Moskovchenko39236d72011-11-30 17:42:23 -080087 /* CAM Expander */
88 GPIO_CAM_EXPANDER_BASE = GPIO_EXPANDER_GPIO_BASE,
89 GPIO_CAM_GP_STROBE_READY = GPIO_CAM_EXPANDER_BASE,
90 GPIO_CAM_GP_AFBUSY,
91 GPIO_CAM_GP_STROBE_CE,
92 GPIO_CAM_GP_CAM1MP_XCLR,
93 GPIO_CAM_GP_CAMIF_RESET_N,
94 GPIO_CAM_GP_XMT_FLASH_INT,
95 GPIO_CAM_GP_LED_EN1,
96 GPIO_CAM_GP_LED_EN2,
97
98};
99#endif
100
101enum {
102 SX150X_CAM,
103};
104
105#endif
106
107extern struct sx150x_platform_data msm8930_sx150x_data[];
Kevin Chan09f4e662011-12-16 08:17:02 -0800108extern struct msm_camera_board_info msm8930_camera_board_info;
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800109void msm8930_init_cam(void);
110void msm8930_init_fb(void);
111void msm8930_init_pmic(void);
Jay Chokshi06fa7542011-12-07 13:09:17 -0800112
113/*
114 * TODO: When physical 8930/PM8038 hardware becomes
115 * available, remove this block or add the config
116 * option.
117 */
118#ifndef MSM8930_PHASE_2
119void msm8960_init_pmic(void);
120void msm8960_pm8921_gpio_mpp_init(void);
121#endif
122
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800123void msm8930_init_mmc(void);
Stepan Moskovchenko3b09bf52011-12-06 20:40:53 -0800124int msm8930_init_gpiomux(void);
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800125void msm8930_allocate_fb_region(void);
Jay Chokshi06fa7542011-12-07 13:09:17 -0800126void msm8930_pm8038_gpio_mpp_init(void);
Huaibin Yanga5419422011-12-08 23:52:10 -0800127void msm8930_mdp_writeback(struct memtype_reserve *reserve_table);
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800128
Stepan Moskovchenko3b09bf52011-12-06 20:40:53 -0800129#define PLATFORM_IS_CHARM25() \
130 (machine_is_msm8930_cdp() && \
131 (socinfo_get_platform_subtype() == 1) \
132 )
133
Stepan Moskovchenko39236d72011-11-30 17:42:23 -0800134#define MSM_8930_GSBI4_QUP_I2C_BUS_ID 4
135#define MSM_8930_GSBI3_QUP_I2C_BUS_ID 3
136#define MSM_8930_GSBI10_QUP_I2C_BUS_ID 10