hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/*
 * (C) Copyright 2022 Rockchip Electronics Co., Ltd
 *
 * SPDX-License-Identifier:     GPL-2.0+
 */
 
#include <common.h>
#include <asm/arch/chip_info.h>
 
/*
 * rk3066 chip info:    {0x33303041, 0x32303131, 0x31313131, 0x56313031} - 300A20111111V101
 * rk3168 chip info:    {0x33303042, 0x32303132, 0x31303031, 0x56313030} - 300B20121011V100
 * rk3036 chip info:    {0x33303141, 0x32303134, 0x30343231, 0x56313031} - 301A20140421V101
 * rk3188 chip info:    {0x33313042, 0x32303132, 0x31313330, 0x56313030} - 310B20121130V100
 * rk3188_plus chip info:{0x33313042, 0x32303133, 0x30313331, 0x56313031} - 310B20130131V101
 * rk312x chip info:    {0x33313043, 0x32303134, 0x30343239, 0x56313030} - 310C20140429V100
 * rk312xb chip info:    {0x33313044, 0x32303134, 0x30373330, 0x56313030} - 310D20140730V100
 * rk3126c chip info:    {0x33313044, 0x32303137, 0x30343137, 0x56323030} - 310D20170417V200
 * rk3288 chip info:    {0x33323041, 0x32303133, 0x31313136, 0x56313030} - 320A20131116V100
 * rk322x chip info:    {0x33323042, 0x32303135, 0x31313136, 0x56313030} - 320B20151116V100
 * rk3368 chip info:    {0x33333041, 0x32303134, 0x30393238, 0x56313030} - 330A20140928V100
 * rk3366 chip info:    {0x33333042, 0x32303135, 0x30363234, 0x56313030} - 330B20150624V100
 * rk3399 chip info:    {0x33333043, 0x32303136, 0x30313138, 0x56313030} - 330B20160118V100
 * rk322xh chip info:    {0x33323043, 0x32303136, 0x31313031, 0x56313030} - 320C20161101V100
 * rk3326 chip info:    {0x33333044, 0x32303137, 0x31323134, 0x56313030} - 330D20171214V100
 * rk3308 chip info:    {0x33333045, 0x32303138, 0x30323033, 0x56313030} - 330E20180203V100
 * rv1126 chip info:    {0x42303131, 0x39313032, 0x37303131, 0x30303156}
 */
 
static int rockchip_get_chip_info(unsigned int chip_info[])
{
   if (chip_info == NULL)
       return -EINVAL;
 
#if defined(CONFIG_ROCKCHIP_RK3036)
   chip_info[0] = 0x33303041;
#elif defined(CONFIG_ROCKCHIP_RK3188)
   chip_info[0] = 0x33313042;
#elif defined(CONFIG_ROCKCHIP_RK3126)
   chip_info[0] = 0x33313044;
#elif defined(CONFIG_ROCKCHIP_RK322X)
   chip_info[0] = 0x33323042;
#elif defined(CONFIG_ROCKCHIP_RK3288)
   chip_info[0] = 0x33323041;
#elif defined(CONFIG_ROCKCHIP_RK3308)
   chip_info[0] = 0x33333038;
#elif defined(CONFIG_ROCKCHIP_RK3328)
   chip_info[0] = 0x33323043;
   chip_info[3] = 0x56313030;
#elif defined(CONFIG_ROCKCHIP_RK3368)
   chip_info[0] = 0x33333041;
   chip_info[3] = 0x56313030;
#elif defined(CONFIG_ROCKCHIP_RK3399)
   chip_info[0] = 0x33333043;
   chip_info[3] = 0x56313030;
 
/*
 * Must check CONFIG_ROCKCHIP_RK3326 first! Because RK3326 board defconfig
 * will contains both CONFIG_ROCKCHIP_RK3326 and CONFIG_ROCKCHIP_PX30, we
 * would like treat the board as RK3326.
 */
#elif defined(CONFIG_ROCKCHIP_RK3326)
   chip_info[0] = 0x33333236;
#elif defined(CONFIG_ROCKCHIP_PX30)
   chip_info[0] = 0x50583330;
#elif defined(CONFIG_ROCKCHIP_RK3528)
   chip_info[0] = 0x33353238;
#elif defined(CONFIG_ROCKCHIP_RK3562)
   chip_info[0] = 0x33353632;
#elif defined(CONFIG_ROCKCHIP_RK3568)
   chip_info[0] = 0x33353638;
#elif defined(CONFIG_ROCKCHIP_RK3588)
   chip_info[0] = 0x33353838;
#endif
 
   return 0;
}
 
int rockchip_rockusb_get_chip_info(unsigned int chip_info[])
{
   int err;
 
   err = rockchip_get_chip_info(chip_info);
   if (!err) {
   /* Fixup chip info for RockUsb */
#if defined(CONFIG_ROCKCHIP_RK3036)
       chip_info[0] = 0x33303341;
#elif defined(CONFIG_ROCKCHIP_RK3126) || defined(CONFIG_ROCKCHIP_RK3128)
       chip_info[0] = 0x33313241;
#elif defined(CONFIG_ROCKCHIP_RK322X)
#if defined(CONFIG_ROCKCHIP_RK3128X)
       chip_info[0] = 0x33313258;
#else
       chip_info[0] = 0x33323241;
#endif
#elif defined(CONFIG_ROCKCHIP_RK3328)
       chip_info[0] = 0x33323248;
#elif defined(CONFIG_ROCKCHIP_RK3399)
       chip_info[0] = 0x33333043;
#elif defined(CONFIG_ROCKCHIP_RK1808)
       chip_info[0] = 0x31383041;
#elif defined(CONFIG_ROCKCHIP_RV1126)
       chip_info[0] = 0x31313236;
#elif defined(CONFIG_ROCKCHIP_RV1106)
       chip_info[0] = 0x31313036;
#endif
   }
 
   return err;
}