xref: /rk3399_rockchip-uboot/arch/arm/mach-rockchip/chip_info.c (revision 4e72b3266b78595b835d5326b538aedd3bd0e034)
1c876650aSJoseph Chen /*
204e2aa7fSJoseph Chen  * (C) Copyright 2022 Rockchip Electronics Co., Ltd
3c876650aSJoseph Chen  *
4c876650aSJoseph Chen  * SPDX-License-Identifier:     GPL-2.0+
5c876650aSJoseph Chen  */
6c876650aSJoseph Chen 
7c876650aSJoseph Chen #include <common.h>
8c876650aSJoseph Chen #include <asm/arch/chip_info.h>
9c876650aSJoseph Chen 
10c876650aSJoseph Chen /*
11c876650aSJoseph Chen  * rk3066 chip info:	{0x33303041, 0x32303131, 0x31313131, 0x56313031} - 300A20111111V101
12c876650aSJoseph Chen  * rk3168 chip info:	{0x33303042, 0x32303132, 0x31303031, 0x56313030} - 300B20121011V100
13c876650aSJoseph Chen  * rk3036 chip info:	{0x33303141, 0x32303134, 0x30343231, 0x56313031} - 301A20140421V101
14c876650aSJoseph Chen  * rk3188 chip info:	{0x33313042, 0x32303132, 0x31313330, 0x56313030} - 310B20121130V100
15c876650aSJoseph Chen  * rk3188_plus chip info:{0x33313042, 0x32303133, 0x30313331, 0x56313031} - 310B20130131V101
16c876650aSJoseph Chen  * rk312x chip info:	{0x33313043, 0x32303134, 0x30343239, 0x56313030} - 310C20140429V100
17c876650aSJoseph Chen  * rk312xb chip info:	{0x33313044, 0x32303134, 0x30373330, 0x56313030} - 310D20140730V100
18c876650aSJoseph Chen  * rk3126c chip info:	{0x33313044, 0x32303137, 0x30343137, 0x56323030} - 310D20170417V200
19c876650aSJoseph Chen  * rk3288 chip info:	{0x33323041, 0x32303133, 0x31313136, 0x56313030} - 320A20131116V100
20c876650aSJoseph Chen  * rk322x chip info:	{0x33323042, 0x32303135, 0x31313136, 0x56313030} - 320B20151116V100
21c876650aSJoseph Chen  * rk3368 chip info:	{0x33333041, 0x32303134, 0x30393238, 0x56313030} - 330A20140928V100
22c876650aSJoseph Chen  * rk3366 chip info:	{0x33333042, 0x32303135, 0x30363234, 0x56313030} - 330B20150624V100
23c876650aSJoseph Chen  * rk3399 chip info:	{0x33333043, 0x32303136, 0x30313138, 0x56313030} - 330B20160118V100
24c876650aSJoseph Chen  * rk322xh chip info:	{0x33323043, 0x32303136, 0x31313031, 0x56313030} - 320C20161101V100
25c876650aSJoseph Chen  * rk3326 chip info:	{0x33333044, 0x32303137, 0x31323134, 0x56313030} - 330D20171214V100
26b7e6ff2cSAndy Yan  * rk3308 chip info:	{0x33333045, 0x32303138, 0x30323033, 0x56313030} - 330E20180203V100
271e25cba3SJoseph Chen  * rv1126 chip info:	{0x42303131, 0x39313032, 0x37303131, 0x30303156}
28c876650aSJoseph Chen  */
291e25cba3SJoseph Chen 
rockchip_get_chip_info(unsigned int chip_info[])301e25cba3SJoseph Chen static int rockchip_get_chip_info(unsigned int chip_info[])
31c876650aSJoseph Chen {
32c876650aSJoseph Chen 	if (chip_info == NULL)
33c876650aSJoseph Chen 		return -EINVAL;
34c876650aSJoseph Chen 
35c876650aSJoseph Chen #if defined(CONFIG_ROCKCHIP_RK3036)
36c876650aSJoseph Chen 	chip_info[0] = 0x33303041;
37c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3188)
38c876650aSJoseph Chen 	chip_info[0] = 0x33313042;
39c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3126)
40c876650aSJoseph Chen 	chip_info[0] = 0x33313044;
41c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK322X)
42c876650aSJoseph Chen 	chip_info[0] = 0x33323042;
43c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3288)
44c876650aSJoseph Chen 	chip_info[0] = 0x33323041;
45b7e6ff2cSAndy Yan #elif defined(CONFIG_ROCKCHIP_RK3308)
46329c8afbSAndy Yan 	chip_info[0] = 0x33333038;
47c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3328)
48c876650aSJoseph Chen 	chip_info[0] = 0x33323043;
49c876650aSJoseph Chen 	chip_info[3] = 0x56313030;
50c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3368)
51c876650aSJoseph Chen 	chip_info[0] = 0x33333041;
52c876650aSJoseph Chen 	chip_info[3] = 0x56313030;
53c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3399)
54c876650aSJoseph Chen 	chip_info[0] = 0x33333043;
55c876650aSJoseph Chen 	chip_info[3] = 0x56313030;
560d974949SJoseph Chen 
570d974949SJoseph Chen /*
580d974949SJoseph Chen  * Must check CONFIG_ROCKCHIP_RK3326 first! Because RK3326 board defconfig
590d974949SJoseph Chen  * will contains both CONFIG_ROCKCHIP_RK3326 and CONFIG_ROCKCHIP_PX30, we
600d974949SJoseph Chen  * would like treat the board as RK3326.
610d974949SJoseph Chen  */
620d974949SJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3326)
630d974949SJoseph Chen 	chip_info[0] = 0x33333236;
64c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_PX30)
650d974949SJoseph Chen 	chip_info[0] = 0x50583330;
66c6f7c1a3SJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3528)
67c6f7c1a3SJoseph Chen 	chip_info[0] = 0x33353238;
6856f7d184SJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3562)
6956f7d184SJoseph Chen 	chip_info[0] = 0x33353632;
70d982a3cdSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3568)
71d982a3cdSJoseph Chen 	chip_info[0] = 0x33353638;
72e1cfe1c9SJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3588)
73e1cfe1c9SJoseph Chen 	chip_info[0] = 0x33353838;
74bf72c9c9SXuhui Lin #elif defined(CONFIG_ROCKCHIP_RK3576)
75bf72c9c9SXuhui Lin 	chip_info[0] = 0x33353736;
7685e5c210SXuhui Lin #elif defined(CONFIG_ROCKCHIP_RK3506)
7785e5c210SXuhui Lin 	chip_info[0] = 0x33353046;
78c876650aSJoseph Chen #endif
79c876650aSJoseph Chen 
80c876650aSJoseph Chen 	return 0;
81c876650aSJoseph Chen }
82c876650aSJoseph Chen 
rockchip_rockusb_get_chip_info(unsigned int chip_info[])83c876650aSJoseph Chen int rockchip_rockusb_get_chip_info(unsigned int chip_info[])
84c876650aSJoseph Chen {
85c876650aSJoseph Chen 	int err;
86c876650aSJoseph Chen 
87c876650aSJoseph Chen 	err = rockchip_get_chip_info(chip_info);
88c876650aSJoseph Chen 	if (!err) {
89c876650aSJoseph Chen 	/* Fixup chip info for RockUsb */
90c876650aSJoseph Chen #if defined(CONFIG_ROCKCHIP_RK3036)
91c876650aSJoseph Chen 		chip_info[0] = 0x33303341;
92c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3126) || defined(CONFIG_ROCKCHIP_RK3128)
93c876650aSJoseph Chen 		chip_info[0] = 0x33313241;
94c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK322X)
95ad9ba815SJoseph Chen #if defined(CONFIG_ROCKCHIP_RK3128X)
96ad9ba815SJoseph Chen 		chip_info[0] = 0x33313258;
97ad9ba815SJoseph Chen #else
98c876650aSJoseph Chen 		chip_info[0] = 0x33323241;
99ad9ba815SJoseph Chen #endif
100c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3328)
101c876650aSJoseph Chen 		chip_info[0] = 0x33323248;
102c876650aSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK3399)
103c876650aSJoseph Chen 		chip_info[0] = 0x33333043;
1047bd9afa1SJoseph Chen #elif defined(CONFIG_ROCKCHIP_RK1808)
1057bd9afa1SJoseph Chen 		chip_info[0] = 0x31383041;
1061e25cba3SJoseph Chen #elif defined(CONFIG_ROCKCHIP_RV1126)
1071e25cba3SJoseph Chen 		chip_info[0] = 0x31313236;
108*4e72b326SXuhui Lin #elif defined(CONFIG_ROCKCHIP_RV1126B)
109*4e72b326SXuhui Lin 		chip_info[0] = 0x31313046;
11004e2aa7fSJoseph Chen #elif defined(CONFIG_ROCKCHIP_RV1106)
11104e2aa7fSJoseph Chen 		chip_info[0] = 0x31313036;
112c876650aSJoseph Chen #endif
113c876650aSJoseph Chen 	}
114c876650aSJoseph Chen 
115c876650aSJoseph Chen 	return err;
116c876650aSJoseph Chen }
117