1070b0f08SJorge Ramirez-Ortiz /*
2*4379a3e9SToshiyuki Ogasahara * Copyright (c) 2015-2021, 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>
909d40e0eSAntonio Nino Diaz
1009d40e0eSAntonio Nino Diaz #include <lib/utils_def.h>
1109d40e0eSAntonio Nino Diaz
12070b0f08SJorge Ramirez-Ortiz #include <iic_dvfs.h>
1309d40e0eSAntonio Nino Diaz
14070b0f08SJorge Ramirez-Ortiz #include "board.h"
15070b0f08SJorge Ramirez-Ortiz
16070b0f08SJorge Ramirez-Ortiz #ifndef BOARD_DEFAULT
17bfbf5df4SMarek Vasut #if (RCAR_LSI == RCAR_D3)
18bfbf5df4SMarek Vasut #define BOARD_DEFAULT (BOARD_DRAAK << BOARD_CODE_SHIFT)
19bfbf5df4SMarek Vasut #elif (RCAR_LSI == RCAR_E3)
20070b0f08SJorge Ramirez-Ortiz #define BOARD_DEFAULT (BOARD_EBISU << BOARD_CODE_SHIFT)
21b709fe9cSValentine Barshak #elif (RCAR_LSI == RCAR_V3M)
22b709fe9cSValentine Barshak #define BOARD_DEFAULT (BOARD_EAGLE << BOARD_CODE_SHIFT)
23070b0f08SJorge Ramirez-Ortiz #else
24070b0f08SJorge Ramirez-Ortiz #define BOARD_DEFAULT (BOARD_SALVATOR_X << BOARD_CODE_SHIFT)
25070b0f08SJorge Ramirez-Ortiz #endif
26070b0f08SJorge Ramirez-Ortiz #endif
27070b0f08SJorge Ramirez-Ortiz
28070b0f08SJorge Ramirez-Ortiz #define BOARD_CODE_MASK (0xF8)
29070b0f08SJorge Ramirez-Ortiz #define BOARD_REV_MASK (0x07)
30070b0f08SJorge Ramirez-Ortiz #define BOARD_CODE_SHIFT (0x03)
31070b0f08SJorge Ramirez-Ortiz #define BOARD_ID_UNKNOWN (0xFF)
32070b0f08SJorge Ramirez-Ortiz
33*4379a3e9SToshiyuki Ogasahara #define SXS_ID { 0x10U, 0x11U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
34070b0f08SJorge Ramirez-Ortiz #define SX_ID { 0x10U, 0x11U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
35*4379a3e9SToshiyuki Ogasahara #define SKP_ID { 0x10U, 0x10U, 0x20U, 0x21U, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
360fdfe245SYusuke Goda #define SK_ID { 0x10U, 0x30U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
37070b0f08SJorge Ramirez-Ortiz #define EB4_ID { 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
38070b0f08SJorge Ramirez-Ortiz #define EB_ID { 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
39bfbf5df4SMarek Vasut #define DR_ID { 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
40b709fe9cSValentine Barshak #define EA_ID { 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
41070b0f08SJorge Ramirez-Ortiz #define KK_ID { 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU }
42070b0f08SJorge Ramirez-Ortiz
43070b0f08SJorge Ramirez-Ortiz const char *g_board_tbl[] = {
44070b0f08SJorge Ramirez-Ortiz [BOARD_STARTER_KIT_PRE] = "Starter Kit Premier",
45070b0f08SJorge Ramirez-Ortiz [BOARD_STARTER_KIT] = "Starter Kit",
46070b0f08SJorge Ramirez-Ortiz [BOARD_SALVATOR_XS] = "Salvator-XS",
47070b0f08SJorge Ramirez-Ortiz [BOARD_SALVATOR_X] = "Salvator-X",
48070b0f08SJorge Ramirez-Ortiz [BOARD_EBISU_4D] = "Ebisu-4D",
49070b0f08SJorge Ramirez-Ortiz [BOARD_KRIEK] = "Kriek",
50070b0f08SJorge Ramirez-Ortiz [BOARD_EBISU] = "Ebisu",
51bfbf5df4SMarek Vasut [BOARD_DRAAK] = "Draak",
52b709fe9cSValentine Barshak [BOARD_EAGLE] = "Eagle",
53070b0f08SJorge Ramirez-Ortiz [BOARD_UNKNOWN] = "unknown"
54070b0f08SJorge Ramirez-Ortiz };
55070b0f08SJorge Ramirez-Ortiz
rcar_get_board_type(uint32_t * type,uint32_t * rev)56070b0f08SJorge Ramirez-Ortiz int32_t rcar_get_board_type(uint32_t *type, uint32_t *rev)
57070b0f08SJorge Ramirez-Ortiz {
58070b0f08SJorge Ramirez-Ortiz int32_t ret = 0;
59070b0f08SJorge Ramirez-Ortiz const uint8_t board_tbl[][8] = {
60070b0f08SJorge Ramirez-Ortiz [BOARD_STARTER_KIT_PRE] = SKP_ID,
61070b0f08SJorge Ramirez-Ortiz [BOARD_SALVATOR_XS] = SXS_ID,
62070b0f08SJorge Ramirez-Ortiz [BOARD_STARTER_KIT] = SK_ID,
63070b0f08SJorge Ramirez-Ortiz [BOARD_SALVATOR_X] = SX_ID,
64070b0f08SJorge Ramirez-Ortiz [BOARD_EBISU_4D] = EB4_ID,
65070b0f08SJorge Ramirez-Ortiz [BOARD_EBISU] = EB_ID,
66bfbf5df4SMarek Vasut [BOARD_DRAAK] = DR_ID,
67b709fe9cSValentine Barshak [BOARD_EAGLE] = EA_ID,
68070b0f08SJorge Ramirez-Ortiz [BOARD_KRIEK] = KK_ID,
69070b0f08SJorge Ramirez-Ortiz };
70070b0f08SJorge Ramirez-Ortiz static uint8_t board_id = BOARD_ID_UNKNOWN;
71070b0f08SJorge Ramirez-Ortiz
72070b0f08SJorge Ramirez-Ortiz if (board_id != BOARD_ID_UNKNOWN)
73070b0f08SJorge Ramirez-Ortiz goto get_type;
74070b0f08SJorge Ramirez-Ortiz
75070b0f08SJorge Ramirez-Ortiz #if PMIC_ROHM_BD9571
76070b0f08SJorge Ramirez-Ortiz /* Board ID detection from EEPROM */
77070b0f08SJorge Ramirez-Ortiz ret = rcar_iic_dvfs_receive(EEPROM, BOARD_ID, &board_id);
78070b0f08SJorge Ramirez-Ortiz if (ret) {
79070b0f08SJorge Ramirez-Ortiz board_id = BOARD_ID_UNKNOWN;
80070b0f08SJorge Ramirez-Ortiz goto get_type;
81070b0f08SJorge Ramirez-Ortiz }
82070b0f08SJorge Ramirez-Ortiz
83070b0f08SJorge Ramirez-Ortiz if (board_id == BOARD_ID_UNKNOWN)
84070b0f08SJorge Ramirez-Ortiz board_id = BOARD_DEFAULT;
85070b0f08SJorge Ramirez-Ortiz #else
86070b0f08SJorge Ramirez-Ortiz board_id = BOARD_DEFAULT;
87070b0f08SJorge Ramirez-Ortiz #endif
88070b0f08SJorge Ramirez-Ortiz
89070b0f08SJorge Ramirez-Ortiz get_type:
90070b0f08SJorge Ramirez-Ortiz *type = ((uint32_t) board_id & BOARD_CODE_MASK) >> BOARD_CODE_SHIFT;
91070b0f08SJorge Ramirez-Ortiz
92070b0f08SJorge Ramirez-Ortiz if (*type >= ARRAY_SIZE(board_tbl)) {
93070b0f08SJorge Ramirez-Ortiz /* no revision information, set Rev0.0. */
94070b0f08SJorge Ramirez-Ortiz *rev = 0;
95070b0f08SJorge Ramirez-Ortiz return ret;
96070b0f08SJorge Ramirez-Ortiz }
97070b0f08SJorge Ramirez-Ortiz
98070b0f08SJorge Ramirez-Ortiz *rev = board_tbl[*type][(uint8_t) (board_id & BOARD_REV_MASK)];
99070b0f08SJorge Ramirez-Ortiz
100070b0f08SJorge Ramirez-Ortiz return ret;
101070b0f08SJorge Ramirez-Ortiz }
102