blob: 183bf2ba42ed3a7d207758f0366afd6b1ba402dd [file] [log] [blame]
Sriram Dash92623672016-06-13 09:58:34 +05301/*
2 * Freescale USB Controller
3 *
4 * Copyright 2013 Freescale Semiconductor, Inc.
5 *
6 * SPDX-License-Identifier: GPL-2.0+
7 */
8
9#include <common.h>
10#include <fsl_errata.h>
11#include<fsl_usb.h>
12
13/* USB Erratum Checking code */
14#if defined(CONFIG_PPC) || defined(CONFIG_ARM)
15bool has_dual_phy(void)
16{
17 u32 svr = get_svr();
18 u32 soc = SVR_SOC_VER(svr);
19
20 switch (soc) {
21#ifdef CONFIG_PPC
22 case SVR_T1023:
23 case SVR_T1024:
24 case SVR_T1013:
25 case SVR_T1014:
26 return IS_SVR_REV(svr, 1, 0);
27 case SVR_T1040:
28 case SVR_T1042:
29 case SVR_T1020:
30 case SVR_T1022:
31 case SVR_T2080:
32 case SVR_T2081:
33 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 1, 1);
34 case SVR_T4240:
35 case SVR_T4160:
36 case SVR_T4080:
37 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 2, 0);
38#endif
39 }
40
41 return false;
42}
43
44bool has_erratum_a006261(void)
45{
46 u32 svr = get_svr();
47 u32 soc = SVR_SOC_VER(svr);
48
49 switch (soc) {
50#ifdef CONFIG_PPC
51 case SVR_P1010:
52 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 2, 0);
53 case SVR_P2041:
54 case SVR_P2040:
55 return IS_SVR_REV(svr, 1, 0) ||
56 IS_SVR_REV(svr, 1, 1) || IS_SVR_REV(svr, 2, 1);
57 case SVR_P3041:
58 return IS_SVR_REV(svr, 1, 0) ||
59 IS_SVR_REV(svr, 1, 1) ||
60 IS_SVR_REV(svr, 2, 0) || IS_SVR_REV(svr, 2, 1);
61 case SVR_P5010:
62 case SVR_P5020:
63 case SVR_P5021:
64 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 2, 0);
65 case SVR_T4240:
66 case SVR_T4160:
67 case SVR_T4080:
68 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 2, 0);
69 case SVR_T1040:
70 return IS_SVR_REV(svr, 1, 0);
71 case SVR_T2080:
72 case SVR_T2081:
73 return IS_SVR_REV(svr, 1, 0);
74 case SVR_P5040:
75 return IS_SVR_REV(svr, 1, 0);
76#endif
77 }
78
79 return false;
80}
81
82bool has_erratum_a007075(void)
83{
84 u32 svr = get_svr();
85 u32 soc = SVR_SOC_VER(svr);
86
87 switch (soc) {
88#ifdef CONFIG_PPC
89 case SVR_B4860:
90 case SVR_B4420:
91 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 2, 0);
92 case SVR_P1010:
93 return IS_SVR_REV(svr, 1, 0);
94 case SVR_P4080:
95 return IS_SVR_REV(svr, 2, 0) || IS_SVR_REV(svr, 3, 0);
96#endif
97 }
98 return false;
99}
100
101bool has_erratum_a007798(void)
102{
103#ifdef CONFIG_PPC
104 return SVR_SOC_VER(get_svr()) == SVR_T4240 &&
105 IS_SVR_REV(get_svr(), 2, 0);
106#endif
107 return false;
108}
109
110bool has_erratum_a007792(void)
111{
112 u32 svr = get_svr();
113 u32 soc = SVR_SOC_VER(svr);
114
115 switch (soc) {
116#ifdef CONFIG_PPC
117 case SVR_T4240:
118 case SVR_T4160:
119 case SVR_T4080:
120 return IS_SVR_REV(svr, 2, 0);
121 case SVR_T1024:
122 case SVR_T1023:
123 return IS_SVR_REV(svr, 1, 0);
124 case SVR_T1040:
125 case SVR_T1042:
126 case SVR_T1020:
127 case SVR_T1022:
128 case SVR_T2080:
129 case SVR_T2081:
130 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 1, 1);
131#endif
132 }
133 return false;
134}
135
136bool has_erratum_a005697(void)
137{
138 u32 svr = get_svr();
139 u32 soc = SVR_SOC_VER(svr);
140
141 switch (soc) {
142#ifdef CONFIG_PPC
143 case SVR_9131:
144 case SVR_9132:
145 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 1, 1);
146#endif
147 }
148 return false;
149}
150
151bool has_erratum_a004477(void)
152{
153 u32 svr = get_svr();
154 u32 soc = SVR_SOC_VER(svr);
155
156 switch (soc) {
157#ifdef CONFIG_PPC
158 case SVR_P1010:
159 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 2, 0);
160 case SVR_P1022:
161 case SVR_9131:
162 case SVR_9132:
163 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 1, 1);
164 case SVR_P2020:
165 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 2, 0) ||
166 IS_SVR_REV(svr, 2, 1);
167 case SVR_B4860:
168 case SVR_B4420:
169 return IS_SVR_REV(svr, 1, 0) || IS_SVR_REV(svr, 2, 0);
170 case SVR_P4080:
171 return IS_SVR_REV(svr, 2, 0) || IS_SVR_REV(svr, 3, 0);
172#endif
173 }
174
175 return false;
176}
177
Sriram Dashef53b8c2016-06-13 09:58:36 +0530178bool has_erratum_a008751(void)
179{
180 u32 svr = get_svr();
181 u32 soc = SVR_SOC_VER(svr);
182
183 switch (soc) {
184#ifdef CONFIG_ARM64
Prabhakar Kushwaha49cdce12016-06-24 13:48:13 +0530185 case SVR_LS2080A:
186 case SVR_LS2085A:
Sriram Dashef53b8c2016-06-13 09:58:36 +0530187 return IS_SVR_REV(svr, 1, 0);
188#endif
189 }
190 return false;
191}
192
Sriram Dash92623672016-06-13 09:58:34 +0530193#endif