blob: 9ba6a7ed693451597c6b0e13f9bfc8d09e47a8e8 [file] [log] [blame]
Masahiro Yamada75f16f82015-09-22 00:27:39 +09001/*
Masahiro Yamada31649052017-01-21 18:05:26 +09002 * Copyright (C) 2017 Socionext Inc.
3 * Author: Masahiro Yamada <yamada.masahiro@socionext.com>
Masahiro Yamada75f16f82015-09-22 00:27:39 +09004 *
5 * SPDX-License-Identifier: GPL-2.0+
6 */
7
Masahiro Yamada31649052017-01-21 18:05:26 +09008#ifndef __UNIPHIER_SOC_INFO_H__
9#define __UNIPHIER_SOC_INFO_H__
Masahiro Yamada75f16f82015-09-22 00:27:39 +090010
Masahiro Yamada1b818982017-01-21 18:05:27 +090011#include <linux/kernel.h>
12#include <linux/stddef.h>
13
Masahiro Yamada31649052017-01-21 18:05:26 +090014#define UNIPHIER_LD4_ID 0x26
15#define UNIPHIER_PRO4_ID 0x28
16#define UNIPHIER_SLD8_ID 0x29
17#define UNIPHIER_PRO5_ID 0x2a
18#define UNIPHIER_PXS2_ID 0x2e
19#define UNIPHIER_LD6B_ID 0x2f
20#define UNIPHIER_LD11_ID 0x31
21#define UNIPHIER_LD20_ID 0x32
Masahiro Yamada133b1262017-01-21 18:05:31 +090022#define UNIPHIER_PXS3_ID 0x35
Masahiro Yamada75f16f82015-09-22 00:27:39 +090023
Masahiro Yamada31649052017-01-21 18:05:26 +090024unsigned int uniphier_get_soc_id(void);
25unsigned int uniphier_get_soc_model(void);
26unsigned int uniphier_get_soc_revision(void);
Masahiro Yamadaf637bdf2015-12-17 17:47:41 +090027
Masahiro Yamada1b818982017-01-21 18:05:27 +090028#define UNIPHIER_DEFINE_SOCDATA_FUNC(__func_name, __table) \
29static typeof(&__table[0]) __func_name(void) \
30{ \
31 unsigned int soc_id; \
32 int i; \
33 \
34 soc_id = uniphier_get_soc_id(); \
35 for (i = 0; i < ARRAY_SIZE(__table); i++) { \
36 if (__table[i].soc_id == soc_id) \
37 return &__table[i]; \
38 } \
39 \
40 return NULL; \
41}
42
Masahiro Yamada31649052017-01-21 18:05:26 +090043#endif /* __UNIPHIER_SOC_INFO_H__ */