blob: 9ba6a7ed693451597c6b0e13f9bfc8d09e47a8e8 [file] [log] [blame]
Masahiro Yamada323d1f92015-09-22 00:27:39 +09001/*
Masahiro Yamadae27d6c72017-01-21 18:05:26 +09002 * Copyright (C) 2017 Socionext Inc.
3 * Author: Masahiro Yamada <yamada.masahiro@socionext.com>
Masahiro Yamada323d1f92015-09-22 00:27:39 +09004 *
5 * SPDX-License-Identifier: GPL-2.0+
6 */
7
Masahiro Yamadae27d6c72017-01-21 18:05:26 +09008#ifndef __UNIPHIER_SOC_INFO_H__
9#define __UNIPHIER_SOC_INFO_H__
Masahiro Yamada323d1f92015-09-22 00:27:39 +090010
Masahiro Yamadaee8ef5a2017-01-21 18:05:27 +090011#include <linux/kernel.h>
12#include <linux/stddef.h>
13
Masahiro Yamadae27d6c72017-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 Yamada2c2ab3d2017-01-21 18:05:31 +090022#define UNIPHIER_PXS3_ID 0x35
Masahiro Yamada323d1f92015-09-22 00:27:39 +090023
Masahiro Yamadae27d6c72017-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 Yamada323d1f92015-09-22 00:27:39 +090027
Masahiro Yamadaee8ef5a2017-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 Yamadae27d6c72017-01-21 18:05:26 +090043#endif /* __UNIPHIER_SOC_INFO_H__ */