blob: 32f974b82aa0b39bb83f550acd61cbaf486e5885 [file] [log] [blame]
Amol Jadica4f4c92011-01-13 20:19:34 -08001/*
2 * Copyright (c) 2009, Google Inc.
3 * All rights reserved.
4 * Copyright (c) 2009-2011, Code Aurora Forum. All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * * Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in
13 * the documentation and/or other materials provided with the
14 * distribution.
15 * * Neither the name of Google, Inc. nor the names of its contributors
16 * may be used to endorse or promote products derived from this
17 * software without specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
26 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
27 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
28 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
29 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 * SUCH DAMAGE.
31 */
32
33#include <debug.h>
34#include <lib/ptable.h>
35#include <smem.h>
36#include <platform/iomap.h>
Greg Griscod6250552011-06-29 14:40:23 -070037#include <mmc.h>
38#include <platform/timer.h>
Amol Jadica4f4c92011-01-13 20:19:34 -080039#include <reg.h>
Amol Jadi6db9fe32011-04-15 17:19:00 -070040#include <dev/keys.h>
Amol Jadi57abe4c2011-05-24 15:47:27 -070041#include <dev/pm8921.h>
Kinson Chikea646242011-09-01 13:53:16 -070042#include <dev/ssbi.h>
Amol Jadic52c8a32011-07-12 11:27:04 -070043#include <gsbi.h>
Greg Griscod2471ef2011-07-14 13:00:42 -070044#include <target.h>
Greg Grisco1073a5e2011-07-28 18:59:18 -070045#include <platform.h>
Ajay Dudani403bc492011-09-30 16:17:21 -070046#include <baseband.h>
Amol Jadica4f4c92011-01-13 20:19:34 -080047
Amol Jadi0c04df82011-10-14 17:40:21 -070048/* 8960 */
Amol Jadica4f4c92011-01-13 20:19:34 -080049#define LINUX_MACHTYPE_8960_SIM 3230
50#define LINUX_MACHTYPE_8960_RUMI3 3231
Shashank Mittald67508a2011-05-06 19:18:42 -070051#define LINUX_MACHTYPE_8960_CDP 3396
52#define LINUX_MACHTYPE_8960_MTP 3397
53#define LINUX_MACHTYPE_8960_FLUID 3398
54#define LINUX_MACHTYPE_8960_APQ 3399
Amir Samuelov6a9871b2011-07-31 14:38:05 +030055#define LINUX_MACHTYPE_8960_LIQUID 3535
Amol Jadi0c04df82011-10-14 17:40:21 -070056
57/* 8930 */
Ajay Dudani8decb502011-09-12 13:39:32 -070058#define LINUX_MACHTYPE_8930_CDP 3727
59#define LINUX_MACHTYPE_8930_MTP 3728
60#define LINUX_MACHTYPE_8930_FLUID 3729
Greg Griscod2471ef2011-07-14 13:00:42 -070061
Amol Jadi0c04df82011-10-14 17:40:21 -070062/* 8064 */
63#define LINUX_MACHTYPE_8064_SIM 3572
64#define LINUX_MACHTYPE_8064_RUMI3 3679
65
Amol Jadicd43ea02011-02-15 20:56:04 -080066extern void dmb(void);
Amol Jadi6db9fe32011-04-15 17:19:00 -070067extern void keypad_init(void);
Greg Griscod2471ef2011-07-14 13:00:42 -070068extern void panel_backlight_on(void);
Amol Jadicd43ea02011-02-15 20:56:04 -080069
Shashank Mittalda89a682011-03-14 19:18:38 -070070static unsigned mmc_sdc_base[] = { MSM_SDC1_BASE, MSM_SDC2_BASE, MSM_SDC3_BASE, MSM_SDC4_BASE};
71
Amol Jadi0c04df82011-10-14 17:40:21 -070072static uint32_t platform_id;
73static uint32_t target_id;
74
Amol Jadi57abe4c2011-05-24 15:47:27 -070075static pm8921_dev_t pmic;
76
Amol Jadi0c04df82011-10-14 17:40:21 -070077static void target_detect(void);
78static uint8_t get_uart_gsbi(void);
79
80void target_early_init(void)
81{
82 target_detect();
83
84#if WITH_DEBUG_UART
85 uart_init(get_uart_gsbi());
86#endif
87}
Amol Jadic52c8a32011-07-12 11:27:04 -070088
Shashank Mittal39503262011-07-19 11:41:35 -070089void shutdown_device(void)
90{
91 dprintf(CRITICAL, "Shutdown system.\n");
92 pm8921_config_reset_pwr_off(0);
93
94 /* Actually reset the chip */
95 writel(0, MSM_PSHOLD_CTL_SU);
96 mdelay(5000);
97
98 dprintf (CRITICAL, "Shutdown failed.\n");
99}
100
Amol Jadica4f4c92011-01-13 20:19:34 -0800101void target_init(void)
102{
Shashank Mittalda89a682011-03-14 19:18:38 -0700103 unsigned base_addr;
104 unsigned char slot;
Amol Jadi0c04df82011-10-14 17:40:21 -0700105
Amol Jadica4f4c92011-01-13 20:19:34 -0800106 dprintf(INFO, "target_init()\n");
107
Amol Jadi57abe4c2011-05-24 15:47:27 -0700108 /* Initialize PMIC driver */
Greg Griscod2471ef2011-07-14 13:00:42 -0700109 pmic.read = (pm8921_read_func) &pa1_ssbi2_read_bytes;
110 pmic.write = (pm8921_write_func) &pa1_ssbi2_write_bytes;
Amol Jadi57abe4c2011-05-24 15:47:27 -0700111
112 pm8921_init(&pmic);
Amol Jadi0c04df82011-10-14 17:40:21 -0700113
Amol Jadi6db9fe32011-04-15 17:19:00 -0700114 /* Keypad init */
115 keys_init();
116 keypad_init();
117
Kinson Chikce306ff2011-07-08 15:23:33 -0700118 /* Display splash screen if enabled */
119#if DISPLAY_SPLASH_SCREEN
Amol Jadi0c04df82011-10-14 17:40:21 -0700120 if((platform_id == MSM8960) || (platform_id == MSM8930))
121 {
122 panel_backlight_on();
123 display_init();
124 dprintf(SPEW, "Diplay initialized\n");
125 display_image_on_screen();
126 }
Kinson Chikce306ff2011-07-08 15:23:33 -0700127#endif
128
Shashank Mittalda89a682011-03-14 19:18:38 -0700129 /* Trying Slot 1 first */
130 slot = 1;
131 base_addr = mmc_sdc_base[slot-1];
132 if(mmc_boot_main(slot, base_addr))
Amol Jadica4f4c92011-01-13 20:19:34 -0800133 {
Shashank Mittalda89a682011-03-14 19:18:38 -0700134 /* Trying Slot 3 next */
135 slot = 3;
136 base_addr = mmc_sdc_base[slot-1];
137 if(mmc_boot_main(slot, base_addr))
138 {
139 dprintf(CRITICAL, "mmc init failed!");
140 ASSERT(0);
141 }
Amol Jadica4f4c92011-01-13 20:19:34 -0800142 }
143}
144
145unsigned board_machtype(void)
146{
Amol Jadi0c04df82011-10-14 17:40:21 -0700147 return target_id;
148}
149
150
151void target_detect(void)
152{
Shashank Mittalda89a682011-03-14 19:18:38 -0700153 struct smem_board_info_v6 board_info_v6;
154 unsigned int board_info_len = 0;
155 unsigned smem_status = 0;
156 unsigned format = 0;
Amol Jadi64c58c12011-05-11 13:40:25 -0700157 unsigned id = HW_PLATFORM_UNKNOWN;
Amol Jadica4f4c92011-01-13 20:19:34 -0800158
Shashank Mittald67508a2011-05-06 19:18:42 -0700159
Shashank Mittalda89a682011-03-14 19:18:38 -0700160 smem_status = smem_read_alloc_entry_offset(SMEM_BOARD_INFO_LOCATION,
161 &format, sizeof(format), 0);
162 if(!smem_status)
163 {
Amol Jadi64c58c12011-05-11 13:40:25 -0700164 if (format == 6)
Shashank Mittalda89a682011-03-14 19:18:38 -0700165 {
166 board_info_len = sizeof(board_info_v6);
167
168 smem_status = smem_read_alloc_entry(SMEM_BOARD_INFO_LOCATION,
169 &board_info_v6, board_info_len);
170 if(!smem_status)
171 {
172 id = board_info_v6.board_info_v3.hw_platform;
173 }
174 }
175 }
176
Amol Jadi0c04df82011-10-14 17:40:21 -0700177 platform_id = board_info_v6.board_info_v3.msm_id;
178
Amol Jadi64c58c12011-05-11 13:40:25 -0700179 /* Detect the board we are running on */
Amol Jadi0c04df82011-10-14 17:40:21 -0700180 if (platform_id == MSM8960)
Shashank Mittalda89a682011-03-14 19:18:38 -0700181 {
Ajay Dudani8decb502011-09-12 13:39:32 -0700182 switch(id)
183 {
184 case HW_PLATFORM_SURF:
Amol Jadi0c04df82011-10-14 17:40:21 -0700185 target_id = LINUX_MACHTYPE_8960_CDP;
Ajay Dudani8decb502011-09-12 13:39:32 -0700186 break;
187 case HW_PLATFORM_MTP:
Amol Jadi0c04df82011-10-14 17:40:21 -0700188 target_id = LINUX_MACHTYPE_8960_MTP;
Ajay Dudani8decb502011-09-12 13:39:32 -0700189 break;
190 case HW_PLATFORM_FLUID:
Amol Jadi0c04df82011-10-14 17:40:21 -0700191 target_id = LINUX_MACHTYPE_8960_FLUID;
Ajay Dudani8decb502011-09-12 13:39:32 -0700192 break;
193 case HW_PLATFORM_LIQUID:
Amol Jadi0c04df82011-10-14 17:40:21 -0700194 target_id = LINUX_MACHTYPE_8960_LIQUID;
Ajay Dudani8decb502011-09-12 13:39:32 -0700195 break;
196 default:
Amol Jadi0c04df82011-10-14 17:40:21 -0700197 target_id = LINUX_MACHTYPE_8960_CDP;
Ajay Dudani8decb502011-09-12 13:39:32 -0700198 }
199 }
Amol Jadi0c04df82011-10-14 17:40:21 -0700200 else if (platform_id == MSM8930)
Ajay Dudani8decb502011-09-12 13:39:32 -0700201 {
202 switch(id)
203 {
204 case HW_PLATFORM_SURF:
Amol Jadi0c04df82011-10-14 17:40:21 -0700205 target_id = LINUX_MACHTYPE_8930_CDP;
Ajay Dudani8decb502011-09-12 13:39:32 -0700206 break;
207 case HW_PLATFORM_MTP:
Amol Jadi0c04df82011-10-14 17:40:21 -0700208 target_id = LINUX_MACHTYPE_8930_MTP;
Ajay Dudani8decb502011-09-12 13:39:32 -0700209 break;
210 case HW_PLATFORM_FLUID:
Amol Jadi0c04df82011-10-14 17:40:21 -0700211 target_id = LINUX_MACHTYPE_8930_FLUID;
Ajay Dudani8decb502011-09-12 13:39:32 -0700212 break;
213 default:
Amol Jadi0c04df82011-10-14 17:40:21 -0700214 target_id = LINUX_MACHTYPE_8930_CDP;
Ajay Dudani8decb502011-09-12 13:39:32 -0700215 }
216 }
Amol Jadi0c04df82011-10-14 17:40:21 -0700217 else if (platform_id == APQ8064)
218 {
219 switch(id)
220 {
221 case HW_PLATFORM_SURF:
222 target_id = LINUX_MACHTYPE_8064_SIM;
223 break;
224 default:
225 target_id = LINUX_MACHTYPE_8064_RUMI3;
226 }
227 }
228 else
229 {
230 dprintf(CRITICAL, "platform_id (%d) is not identified.\n", platform_id);
231 ASSERT(0);
232 }
Amol Jadica4f4c92011-01-13 20:19:34 -0800233}
234
Ajay Dudani403bc492011-09-30 16:17:21 -0700235unsigned target_baseband()
236{
237 struct smem_board_info_v6 board_info_v6;
238 unsigned int board_info_len = 0;
239 unsigned smem_status = 0;
240 unsigned format = 0;
241 unsigned baseband = BASEBAND_MSM;
242
243 smem_status = smem_read_alloc_entry_offset(SMEM_BOARD_INFO_LOCATION,
244 &format, sizeof(format), 0);
245 if(!smem_status)
246 {
247 if (format >= 6)
248 {
249 board_info_len = sizeof(board_info_v6);
250
251 smem_status = smem_read_alloc_entry(SMEM_BOARD_INFO_LOCATION,
252 &board_info_v6, board_info_len);
253 if(!smem_status)
254 {
255 /* Check for LTE fused target. Default to MSM */
256 if (board_info_v6.platform_subtype == HW_PLATFORM_SUBTYPE_MDM)
257 baseband = BASEBAND_MDM;
258 else
259 baseband = BASEBAND_MSM;
260 }
261 }
262 }
263 return baseband;
264}
265
Amol Jadica4f4c92011-01-13 20:19:34 -0800266void reboot_device(unsigned reboot_reason)
267{
Shashank Mittal6239b162011-06-28 17:59:33 -0700268 /* Actually reset the chip */
Shashank Mittal39503262011-07-19 11:41:35 -0700269 pm8921_config_reset_pwr_off(1);
Shashank Mittal6239b162011-06-28 17:59:33 -0700270 writel(0, MSM_PSHOLD_CTL_SU);
Amol Jadica4f4c92011-01-13 20:19:34 -0800271 mdelay(10000);
Shashank Mittal39503262011-07-19 11:41:35 -0700272
Amol Jadica4f4c92011-01-13 20:19:34 -0800273 dprintf (CRITICAL, "Rebooting failed\n");
274 return;
275}
276
277unsigned check_reboot_mode(void)
278{
279 unsigned restart_reason = 0;
Amol Jadica4f4c92011-01-13 20:19:34 -0800280
281 /* Read reboot reason and scrub it */
Shashank Mittal0207df72011-06-15 15:20:43 -0700282 restart_reason = readl(RESTART_REASON_ADDR);
283 writel(0x00, RESTART_REASON_ADDR);
Amol Jadica4f4c92011-01-13 20:19:34 -0800284
285 return restart_reason;
286}
287
Ajay Dudani12091e22011-05-06 17:13:23 -0700288void target_serialno(unsigned char *buf)
289{
290 unsigned int serialno;
291 if(target_is_emmc_boot())
292 {
293 serialno = mmc_get_psn();
Ajay Dudanif63d02f2011-10-01 08:29:53 -0700294 snprintf((char *) buf, 13, "%x", serialno);
Ajay Dudani12091e22011-05-06 17:13:23 -0700295 }
296}
297
Amol Jadica4f4c92011-01-13 20:19:34 -0800298void target_battery_charging_enable(unsigned enable, unsigned disconnect)
299{
300}
Amol Jadi57abe4c2011-05-24 15:47:27 -0700301
302/* Do any target specific intialization needed before entering fastboot mode */
303void target_fastboot_init(void)
304{
305 /* Set the BOOT_DONE flag in PM8921 */
306 pm8921_boot_done();
307}
Amol Jadic52c8a32011-07-12 11:27:04 -0700308
Amol Jadi0c04df82011-10-14 17:40:21 -0700309uint8_t get_uart_gsbi(void)
Amol Jadic52c8a32011-07-12 11:27:04 -0700310{
Amol Jadi0c04df82011-10-14 17:40:21 -0700311 switch(target_id)
312 {
313 case LINUX_MACHTYPE_8960_SIM:
314 case LINUX_MACHTYPE_8960_RUMI3:
315 case LINUX_MACHTYPE_8960_CDP:
316 case LINUX_MACHTYPE_8960_MTP:
317 case LINUX_MACHTYPE_8960_FLUID:
318 case LINUX_MACHTYPE_8960_APQ:
319 case LINUX_MACHTYPE_8960_LIQUID:
320
321 return GSBI_ID_5;
322
323 case LINUX_MACHTYPE_8930_CDP:
324 case LINUX_MACHTYPE_8930_MTP:
325 case LINUX_MACHTYPE_8930_FLUID:
326
327 return GSBI_ID_5;
328
329 case LINUX_MACHTYPE_8064_SIM:
330 case LINUX_MACHTYPE_8064_RUMI3:
331
332 return GSBI_ID_3;
333
334 default:
335 dprintf(CRITICAL, "uart gsbi not defined for target: %d\n",
336 target_id);
337
338 ASSERT(0);
339 }
Amol Jadic52c8a32011-07-12 11:27:04 -0700340}