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> 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) 21*b709fe9cSValentine Barshak #elif (RCAR_LSI == RCAR_V3M) 22*b709fe9cSValentine 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 33070b0f08SJorge Ramirez-Ortiz #define SXS_ID { 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU } 34070b0f08SJorge Ramirez-Ortiz #define SX_ID { 0x10U, 0x11U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU } 35070b0f08SJorge Ramirez-Ortiz #define SKP_ID { 0x10U, 0x10U, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU, 0xFFU } 36070b0f08SJorge Ramirez-Ortiz #define SK_ID { 0x10U, 0xFFU, 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 } 40*b709fe9cSValentine 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", 52*b709fe9cSValentine Barshak [BOARD_EAGLE] = "Eagle", 53070b0f08SJorge Ramirez-Ortiz [BOARD_UNKNOWN] = "unknown" 54070b0f08SJorge Ramirez-Ortiz }; 55070b0f08SJorge Ramirez-Ortiz 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, 67*b709fe9cSValentine 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