xref: /rk3399_ARM-atf/drivers/renesas/rcar/board/board.c (revision 09d40e0e08283a249e7dce0e106c07c5141f9b7e)
1070b0f08SJorge Ramirez-Ortiz /*
2070b0f08SJorge Ramirez-Ortiz  * Copyright (c) 2015-2018, Renesas Electronics Corporation. All rights
3070b0f08SJorge Ramirez-Ortiz  * reserved.
4070b0f08SJorge Ramirez-Ortiz  *
5070b0f08SJorge Ramirez-Ortiz  * SPDX-License-Identifier: BSD-3-Clause
6070b0f08SJorge Ramirez-Ortiz  */
7070b0f08SJorge Ramirez-Ortiz 
8070b0f08SJorge Ramirez-Ortiz #include <stdint.h>
9*09d40e0eSAntonio Nino Diaz 
10*09d40e0eSAntonio Nino Diaz #include <lib/utils_def.h>
11*09d40e0eSAntonio Nino Diaz 
12070b0f08SJorge Ramirez-Ortiz #include <iic_dvfs.h>
13*09d40e0eSAntonio Nino Diaz 
14070b0f08SJorge Ramirez-Ortiz #include "board.h"
15070b0f08SJorge Ramirez-Ortiz 
16070b0f08SJorge Ramirez-Ortiz #ifndef BOARD_DEFAULT
17070b0f08SJorge Ramirez-Ortiz #if (RCAR_LSI == RCAR_E3)
18070b0f08SJorge Ramirez-Ortiz #define BOARD_DEFAULT		(BOARD_EBISU << BOARD_CODE_SHIFT)
19070b0f08SJorge Ramirez-Ortiz #else
20070b0f08SJorge Ramirez-Ortiz #define BOARD_DEFAULT		(BOARD_SALVATOR_X << BOARD_CODE_SHIFT)
21070b0f08SJorge Ramirez-Ortiz #endif
22070b0f08SJorge Ramirez-Ortiz #endif
23070b0f08SJorge Ramirez-Ortiz 
24070b0f08SJorge Ramirez-Ortiz #define BOARD_CODE_MASK		(0xF8)
25070b0f08SJorge Ramirez-Ortiz #define BOARD_REV_MASK		(0x07)
26070b0f08SJorge Ramirez-Ortiz #define BOARD_CODE_SHIFT	(0x03)
27070b0f08SJorge Ramirez-Ortiz #define BOARD_ID_UNKNOWN	(0xFF)
28070b0f08SJorge Ramirez-Ortiz 
29070b0f08SJorge Ramirez-Ortiz #define SXS_ID	{ 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
30070b0f08SJorge Ramirez-Ortiz #define SX_ID	{ 0x10U, 0x11U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
31070b0f08SJorge Ramirez-Ortiz #define SKP_ID	{ 0x10U, 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
32070b0f08SJorge Ramirez-Ortiz #define SK_ID	{ 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
33070b0f08SJorge Ramirez-Ortiz #define EB4_ID	{ 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
34070b0f08SJorge Ramirez-Ortiz #define EB_ID	{ 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
35070b0f08SJorge Ramirez-Ortiz #define KK_ID	{ 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
36070b0f08SJorge Ramirez-Ortiz 
37070b0f08SJorge Ramirez-Ortiz const char *g_board_tbl[] = {
38070b0f08SJorge Ramirez-Ortiz 	[BOARD_STARTER_KIT_PRE] = "Starter Kit Premier",
39070b0f08SJorge Ramirez-Ortiz 	[BOARD_STARTER_KIT] = "Starter Kit",
40070b0f08SJorge Ramirez-Ortiz 	[BOARD_SALVATOR_XS] = "Salvator-XS",
41070b0f08SJorge Ramirez-Ortiz 	[BOARD_SALVATOR_X] = "Salvator-X",
42070b0f08SJorge Ramirez-Ortiz 	[BOARD_EBISU_4D] = "Ebisu-4D",
43070b0f08SJorge Ramirez-Ortiz 	[BOARD_KRIEK] = "Kriek",
44070b0f08SJorge Ramirez-Ortiz 	[BOARD_EBISU] = "Ebisu",
45070b0f08SJorge Ramirez-Ortiz 	[BOARD_UNKNOWN] = "unknown"
46070b0f08SJorge Ramirez-Ortiz };
47070b0f08SJorge Ramirez-Ortiz 
48070b0f08SJorge Ramirez-Ortiz int32_t rcar_get_board_type(uint32_t *type, uint32_t *rev)
49070b0f08SJorge Ramirez-Ortiz {
50070b0f08SJorge Ramirez-Ortiz 	int32_t ret = 0;
51070b0f08SJorge Ramirez-Ortiz 	const uint8_t board_tbl[][8] = {
52070b0f08SJorge Ramirez-Ortiz 		[BOARD_STARTER_KIT_PRE] = SKP_ID,
53070b0f08SJorge Ramirez-Ortiz 		[BOARD_SALVATOR_XS] = SXS_ID,
54070b0f08SJorge Ramirez-Ortiz 		[BOARD_STARTER_KIT] = SK_ID,
55070b0f08SJorge Ramirez-Ortiz 		[BOARD_SALVATOR_X] = SX_ID,
56070b0f08SJorge Ramirez-Ortiz 		[BOARD_EBISU_4D] = EB4_ID,
57070b0f08SJorge Ramirez-Ortiz 		[BOARD_EBISU] = EB_ID,
58070b0f08SJorge Ramirez-Ortiz 		[BOARD_KRIEK] = KK_ID,
59070b0f08SJorge Ramirez-Ortiz 	};
60070b0f08SJorge Ramirez-Ortiz 	static uint8_t board_id = BOARD_ID_UNKNOWN;
61070b0f08SJorge Ramirez-Ortiz 
62070b0f08SJorge Ramirez-Ortiz 	if (board_id != BOARD_ID_UNKNOWN)
63070b0f08SJorge Ramirez-Ortiz 		goto get_type;
64070b0f08SJorge Ramirez-Ortiz 
65070b0f08SJorge Ramirez-Ortiz #if PMIC_ROHM_BD9571
66070b0f08SJorge Ramirez-Ortiz 	/* Board ID detection from EEPROM */
67070b0f08SJorge Ramirez-Ortiz 	ret = rcar_iic_dvfs_receive(EEPROM, BOARD_ID, &board_id);
68070b0f08SJorge Ramirez-Ortiz 	if (ret) {
69070b0f08SJorge Ramirez-Ortiz 		board_id = BOARD_ID_UNKNOWN;
70070b0f08SJorge Ramirez-Ortiz 		goto get_type;
71070b0f08SJorge Ramirez-Ortiz 	}
72070b0f08SJorge Ramirez-Ortiz 
73070b0f08SJorge Ramirez-Ortiz 	if (board_id == BOARD_ID_UNKNOWN)
74070b0f08SJorge Ramirez-Ortiz 		board_id = BOARD_DEFAULT;
75070b0f08SJorge Ramirez-Ortiz #else
76070b0f08SJorge Ramirez-Ortiz 	board_id = BOARD_DEFAULT;
77070b0f08SJorge Ramirez-Ortiz #endif
78070b0f08SJorge Ramirez-Ortiz 
79070b0f08SJorge Ramirez-Ortiz get_type:
80070b0f08SJorge Ramirez-Ortiz 	*type = ((uint32_t) board_id & BOARD_CODE_MASK) >> BOARD_CODE_SHIFT;
81070b0f08SJorge Ramirez-Ortiz 
82070b0f08SJorge Ramirez-Ortiz 	if (*type >= ARRAY_SIZE(board_tbl)) {
83070b0f08SJorge Ramirez-Ortiz 		/* no revision information, set Rev0.0. */
84070b0f08SJorge Ramirez-Ortiz 		*rev = 0;
85070b0f08SJorge Ramirez-Ortiz 		return ret;
86070b0f08SJorge Ramirez-Ortiz 	}
87070b0f08SJorge Ramirez-Ortiz 
88070b0f08SJorge Ramirez-Ortiz 	*rev = board_tbl[*type][(uint8_t) (board_id & BOARD_REV_MASK)];
89070b0f08SJorge Ramirez-Ortiz 
90070b0f08SJorge Ramirez-Ortiz 	return ret;
91070b0f08SJorge Ramirez-Ortiz }
92