xref: /openbmc/u-boot/arch/arm/mach-mvebu/serdes/axp/high_speed_env_lib.c (revision 83d290c56fab2d38cd1ab4c4cc7099559c1d5046)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Copyright (C) Marvell International Ltd. and its affiliates
4  */
5 
6 #include <common.h>
7 #include <i2c.h>
8 #include <spl.h>
9 #include <asm/io.h>
10 #include <asm/arch/cpu.h>
11 #include <asm/arch/soc.h>
12 
13 #include "high_speed_env_spec.h"
14 #include "board_env_spec.h"
15 
16 #define	SERDES_VERSION	"2.1.5"
17 #define ENDED_OK	"High speed PHY - Ended Successfully\n"
18 
19 static const u8 serdes_cfg[][SERDES_LAST_UNIT] = BIN_SERDES_CFG;
20 
21 extern MV_BIN_SERDES_CFG *serdes_info_tbl[];
22 
23 extern u8 rd78460gp_twsi_dev[];
24 extern u8 db88f78xx0rev2_twsi_dev[];
25 
26 u32 pex_cfg_read(u32 pex_if, u32 bus, u32 dev, u32 func, u32 offs);
27 int pex_local_bus_num_set(u32 pex_if, u32 bus_num);
28 int pex_local_dev_num_set(u32 pex_if, u32 dev_num);
29 
30 #define MV_BOARD_PEX_MODULE_ADDR		0x23
31 #define MV_BOARD_PEX_MODULE_ID			1
32 #define MV_BOARD_ETM_MODULE_ID			2
33 
34 #define	PEX_MODULE_DETECT		1
35 #define	ETM_MODULE_DETECT               2
36 
37 #define PEX_MODE_GET(satr)		((satr & 0x6) >> 1)
38 #define PEX_CAPABILITY_GET(satr)	(satr & 1)
39 #define MV_PEX_UNIT_TO_IF(pex_unit)	((pex_unit < 3) ? (pex_unit * 4) : 9)
40 
41 /* Static parametes */
42 static int config_module;
43 static int switch_module;
44 
45 /* Local function */
board_id_get(void)46 static u32 board_id_get(void)
47 {
48 #if defined(CONFIG_DB_88F78X60)
49 	return DB_88F78XX0_BP_ID;
50 #elif defined(CONFIG_RD_88F78460_SERVER)
51 	return RD_78460_SERVER_ID;
52 #elif defined(CONFIG_RD_78460_SERVER_REV2)
53 	return RD_78460_SERVER_REV2_ID;
54 #elif defined(CONFIG_DB_78X60_PCAC)
55 	return DB_78X60_PCAC_ID;
56 #elif defined(CONFIG_DB_88F78X60_REV2)
57 	return DB_88F78XX0_BP_REV2_ID;
58 #elif defined(CONFIG_RD_78460_NAS)
59 	return RD_78460_NAS_ID;
60 #elif defined(CONFIG_DB_78X60_AMC)
61 	return DB_78X60_AMC_ID;
62 #elif defined(CONFIG_DB_78X60_PCAC_REV2)
63 	return DB_78X60_PCAC_REV2_ID;
64 #elif defined(CONFIG_DB_784MP_GP)
65 	return DB_784MP_GP_ID;
66 #elif defined(CONFIG_RD_78460_CUSTOMER)
67 	return RD_78460_CUSTOMER_ID;
68 #else
69 	/*
70 	 * Return 0 here for custom board as this should not be used
71 	 * for custom boards.
72 	 */
73 	return 0;
74 #endif
75 }
76 
board_sat_r_get(u8 dev_num,u8 reg)77 __weak u8 board_sat_r_get(u8 dev_num, u8 reg)
78 {
79 	u8 data;
80 	u8 *dev;
81 	u32 board_id = board_id_get();
82 	int ret;
83 
84 	switch (board_id) {
85 	case DB_78X60_AMC_ID:
86 	case DB_78X60_PCAC_REV2_ID:
87 	case RD_78460_CUSTOMER_ID:
88 	case RD_78460_SERVER_ID:
89 	case RD_78460_SERVER_REV2_ID:
90 	case DB_78X60_PCAC_ID:
91 		return (0x1 << 1) | 1;
92 	case FPGA_88F78XX0_ID:
93 	case RD_78460_NAS_ID:
94 		return (0x0 << 1) | 1;
95 	case DB_784MP_GP_ID:
96 		dev = rd78460gp_twsi_dev;
97 
98 		break;
99 	case DB_88F78XX0_BP_ID:
100 	case DB_88F78XX0_BP_REV2_ID:
101 		dev = db88f78xx0rev2_twsi_dev;
102 		break;
103 
104 	default:
105 		return 0;
106 	}
107 
108 	/* Read MPP module ID */
109 	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE);
110 	ret = i2c_read(dev[dev_num], 0, 1, (u8 *)&data, 1);
111 	if (ret)
112 		return MV_ERROR;
113 
114 	return data;
115 }
116 
board_modules_scan(void)117 static int board_modules_scan(void)
118 {
119 	u8 val;
120 	u32 board_id = board_id_get();
121 	int ret;
122 
123 	/* Perform scan only for DB board */
124 	if ((board_id == DB_88F78XX0_BP_ID) ||
125 	    (board_id == DB_88F78XX0_BP_REV2_ID)) {
126 		/* reset modules flags */
127 		config_module = 0;
128 
129 		i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE);
130 
131 		/* SERDES module (only PEX model is supported now) */
132 		ret = i2c_read(MV_BOARD_PEX_MODULE_ADDR, 0, 1, (u8 *)&val, 1);
133 		if (ret)
134 			return MV_ERROR;
135 
136 		if (val == MV_BOARD_PEX_MODULE_ID)
137 			config_module = PEX_MODULE_DETECT;
138 		if (val == MV_BOARD_ETM_MODULE_ID)
139 			config_module = ETM_MODULE_DETECT;
140 	} else if (board_id == RD_78460_NAS_ID) {
141 		switch_module = 0;
142 		if ((reg_read(GPP_DATA_IN_REG(2)) & MV_GPP66) == 0x0)
143 			switch_module = 1;
144 	}
145 
146 	return MV_OK;
147 }
148 
pex_max_unit_get(void)149 u32 pex_max_unit_get(void)
150 {
151 	/*
152 	 * TODO:
153 	 * Right now only MV78460 is supported. Other SoC's might need
154 	 * a different value here.
155 	 */
156 	return MV_PEX_MAX_UNIT;
157 }
158 
pex_max_if_get(void)159 u32 pex_max_if_get(void)
160 {
161 	/*
162 	 * TODO:
163 	 * Right now only MV78460 is supported. Other SoC's might need
164 	 * a different value here.
165 	 */
166 	return MV_PEX_MAX_IF;
167 }
168 
board_cpu_freq_get(void)169 u8 board_cpu_freq_get(void)
170 {
171 	u32 sar;
172 	u32 sar_msb;
173 
174 	sar = reg_read(MPP_SAMPLE_AT_RESET(0));
175 	sar_msb = reg_read(MPP_SAMPLE_AT_RESET(1));
176 	return ((sar_msb & 0x100000) >> 17) | ((sar & 0xe00000) >> 21);
177 }
178 
board_serdes_cfg_get(u8 pex_mode)179 __weak MV_BIN_SERDES_CFG *board_serdes_cfg_get(u8 pex_mode)
180 {
181 	u32 board_id;
182 	u32 serdes_cfg_val = 0;	/* default */
183 
184 	board_id = board_id_get();
185 
186 	switch (board_id) {
187 	case DB_784MP_GP_ID:
188 		serdes_cfg_val = 0;
189 		break;
190 	}
191 
192 	return &serdes_info_tbl[board_id - BOARD_ID_BASE][serdes_cfg_val];
193 }
194 
ctrl_model_get(void)195 u16 ctrl_model_get(void)
196 {
197 	/*
198 	 * SoC version can't be autodetected. So we need to rely on a define
199 	 * from the config system here.
200 	 */
201 #if defined(CONFIG_MV78230)
202 	return MV_78230_DEV_ID;
203 #elif defined(CONFIG_MV78260)
204 	return MV_78260_DEV_ID;
205 #else
206 	return MV_78460_DEV_ID;
207 #endif
208 }
209 
get_line_cfg(u32 line_num,MV_BIN_SERDES_CFG * info)210 u32 get_line_cfg(u32 line_num, MV_BIN_SERDES_CFG *info)
211 {
212 	if (line_num < 8)
213 		return (info->line0_7 >> (line_num << 2)) & 0xF;
214 	else
215 		return (info->line8_15 >> ((line_num - 8) << 2)) & 0xF;
216 }
217 
serdes_max_lines_get(void)218 static int serdes_max_lines_get(void)
219 {
220 	switch (ctrl_model_get()) {
221 	case MV_78230_DEV_ID:
222 		return 7;
223 	case MV_78260_DEV_ID:
224 		return 12;
225 	case MV_78460_DEV_ID:
226 		return 16;
227 	}
228 
229 	return 0;
230 }
231 
232 /*
233  * Tests have shown that on some boards the default width of the
234  * configuration pulse for the PEX link detection might lead to
235  * non-established PCIe links (link down). Especially under certain
236  * conditions (higher temperature) and with specific PCIe devices.
237  * To enable a board-specific detection pulse width this weak
238  * array "serdes_pex_pulse_width[4]" is introduced which can be
239  * overwritten if needed by a board-specific version. If the board
240  * code does not provide a non-weak version of this variable, the
241  * default value will be used. So nothing is changed from the
242  * current setup on the supported board.
243  */
244 __weak u8 serdes_pex_pulse_width[4] = { 2, 2, 2, 2 };
245 
serdes_phy_config(void)246 int serdes_phy_config(void)
247 {
248 	int status = MV_OK;
249 	u32 line_cfg;
250 	u8 line_num;
251 	/* addr/value for each line @ every setup step */
252 	u32 addr[16][11], val[16][11];
253 	u8 pex_unit, pex_line_num;
254 	u8 sgmii_port = 0;
255 	u32 tmp;
256 	u32 in_direct;
257 	u8 max_serdes_lines;
258 	MV_BIN_SERDES_CFG *info;
259 	u8 satr11;
260 	u8 sata_port;
261 	u8 freq;
262 	u8 device_rev;
263 	u32 rx_high_imp_mode;
264 	u16 ctrl_mode;
265 	u32 pex_if;
266 	u32 pex_if_num;
267 
268 	/*
269 	 * Get max. serdes lines count
270 	 */
271 	max_serdes_lines = serdes_max_lines_get();
272 	if (max_serdes_lines == 0)
273 		return MV_OK;
274 
275 	satr11 = board_sat_r_get(1, 1);
276 	if ((u8) MV_ERROR == (u8) satr11)
277 		return MV_ERROR;
278 
279 	board_modules_scan();
280 	memset(addr, 0, sizeof(addr));
281 	memset(val, 0, sizeof(val));
282 
283 	/* Check if DRAM is already initialized  */
284 	if (reg_read(REG_BOOTROM_ROUTINE_ADDR) &
285 	    (1 << REG_BOOTROM_ROUTINE_DRAM_INIT_OFFS)) {
286 		DEBUG_INIT_S("High speed PHY - Version: ");
287 		DEBUG_INIT_S(SERDES_VERSION);
288 		DEBUG_INIT_S(" - 2nd boot - Skip\n");
289 		return MV_OK;
290 	}
291 	DEBUG_INIT_S("High speed PHY - Version: ");
292 	DEBUG_INIT_S(SERDES_VERSION);
293 	DEBUG_INIT_S(" (COM-PHY-V20)\n");
294 
295 	/*
296 	 * AVS :  disable AVS for frequency less than 1333
297 	 */
298 	freq = board_cpu_freq_get();
299 	device_rev = mv_ctrl_rev_get();
300 
301 	if (device_rev == 2) {	/*   for B0 only */
302 		u32 cpu_avs;
303 		u8 fabric_freq;
304 		cpu_avs = reg_read(CPU_AVS_CONTROL2_REG);
305 		DEBUG_RD_REG(CPU_AVS_CONTROL2_REG, cpu_avs);
306 		cpu_avs &= ~(1 << 9);
307 
308 		if ((0x4 == freq) || (0xB == freq)) {
309 			u32 tmp2;
310 
311 			tmp2 = reg_read(CPU_AVS_CONTROL0_REG);
312 			DEBUG_RD_REG(CPU_AVS_CONTROL0_REG, tmp2);
313 			/* cpu upper limit = 1.1V  cpu lower limit = 0.9125V  */
314 			tmp2 |= 0x0FF;
315 			reg_write(CPU_AVS_CONTROL0_REG, tmp2);
316 			DEBUG_WR_REG(CPU_AVS_CONTROL0_REG, tmp2);
317 			cpu_avs |= (1 << 9);	/* cpu avs enable */
318 			cpu_avs |= (1 << 18);	/* AvsAvddDetEn enable  */
319 			fabric_freq = (reg_read(MPP_SAMPLE_AT_RESET(0)) &
320 				       SAR0_FABRIC_FREQ_MASK) >> SAR0_FABRIC_FREQ_OFFSET;
321 			if ((0xB == freq) && (5 == fabric_freq)) {
322 				u32 core_avs;
323 
324 				core_avs = reg_read(CORE_AVS_CONTROL_0REG);
325 				DEBUG_RD_REG(CORE_AVS_CONTROL_0REG, core_avs);
326 
327 				/*
328 				 * Set core lower limit = 0.9V &
329 				 * core upper limit = 0.9125V
330 				 */
331 				core_avs &= ~(0xff);
332 				core_avs |= 0x0E;
333 				reg_write(CORE_AVS_CONTROL_0REG, core_avs);
334 				DEBUG_WR_REG(CORE_AVS_CONTROL_0REG, core_avs);
335 
336 				core_avs = reg_read(CORE_AVS_CONTROL_2REG);
337 				DEBUG_RD_REG(CORE_AVS_CONTROL_2REG, core_avs);
338 				core_avs |= (1 << 9);	/*  core AVS enable  */
339 				reg_write(CORE_AVS_CONTROL_2REG, core_avs);
340 				DEBUG_WR_REG(CORE_AVS_CONTROL_2REG, core_avs);
341 
342 				tmp2 = reg_read(GENERAL_PURPOSE_RESERVED0_REG);
343 				DEBUG_RD_REG(GENERAL_PURPOSE_RESERVED0_REG,
344 					     tmp2);
345 				tmp2 |= 0x1;	/*  AvsCoreAvddDetEn enable   */
346 				reg_write(GENERAL_PURPOSE_RESERVED0_REG, tmp2);
347 				DEBUG_WR_REG(GENERAL_PURPOSE_RESERVED0_REG,
348 					     tmp2);
349 			}
350 		}
351 		reg_write(CPU_AVS_CONTROL2_REG, cpu_avs);
352 		DEBUG_WR_REG(CPU_AVS_CONTROL2_REG, cpu_avs);
353 	}
354 
355 	info = board_serdes_cfg_get(PEX_MODE_GET(satr11));
356 
357 	if (info == NULL) {
358 		DEBUG_INIT_S("Hight speed PHY Error #1\n");
359 		return MV_ERROR;
360 	}
361 	DEBUG_INIT_FULL_S("info->line0_7= 0x");
362 	DEBUG_INIT_FULL_D(info->line0_7, 8);
363 	DEBUG_INIT_FULL_S("   info->line8_15= 0x");
364 	DEBUG_INIT_FULL_D(info->line8_15, 8);
365 	DEBUG_INIT_FULL_S("\n");
366 
367 	if (config_module & ETM_MODULE_DETECT) {	/* step 0.9 ETM */
368 		DEBUG_INIT_FULL_S("ETM module detect Step 0.9:\n");
369 		reg_write(SERDES_LINE_MUX_REG_0_7, 0x11111111);
370 		DEBUG_WR_REG(SERDES_LINE_MUX_REG_0_7, 0x11111111);
371 		info->pex_mode[1] = PEX_BUS_DISABLED;	/* pex unit 1 is configure for ETM */
372 		mdelay(100);
373 		reg_write(PEX_PHY_ACCESS_REG(1), (0x002 << 16) | 0xf44d);	/* SETM0 - start calibration         */
374 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(1), (0x002 << 16) | 0xf44d);	/* SETM0 - start calibration         */
375 		reg_write(PEX_PHY_ACCESS_REG(1), (0x302 << 16) | 0xf44d);	/* SETM1 - start calibration         */
376 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(1), (0x302 << 16) | 0xf44d);	/* SETM1 - start calibration         */
377 		reg_write(PEX_PHY_ACCESS_REG(1), (0x001 << 16) | 0xf801);	/* SETM0 - SATA mode & 25MHz ref clk */
378 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(1), (0x001 << 16) | 0xf801);	/* SETM0 - SATA mode & 25MHz ref clk */
379 		reg_write(PEX_PHY_ACCESS_REG(1), (0x301 << 16) | 0xf801);	/* SETM1 - SATA mode & 25MHz ref clk */
380 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(1), (0x301 << 16) | 0xf801);	/* SETM1 - SATA mode & 25MHz ref clk */
381 		reg_write(PEX_PHY_ACCESS_REG(1), (0x011 << 16) | 0x0BFF);	/* SETM0 - G3 full swing AMP         */
382 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(1), (0x011 << 16) | 0x0BFF);	/* SETM0 - G3 full swing AMP         */
383 		reg_write(PEX_PHY_ACCESS_REG(1), (0x311 << 16) | 0x0BFF);	/* SETM1 - G3 full swing AMP         */
384 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(1), (0x311 << 16) | 0x0BFF);	/* SETM1 - G3 full swing AMP         */
385 		reg_write(PEX_PHY_ACCESS_REG(1), (0x023 << 16) | 0x0800);	/* SETM0 - 40 data bit width         */
386 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(1), (0x023 << 16) | 0x0800);	/* SETM0 - 40 data bit width         */
387 		reg_write(PEX_PHY_ACCESS_REG(1), (0x323 << 16) | 0x0800);	/* SETM1 - 40 data bit width         */
388 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(1), (0x323 << 16) | 0x0800);	/* SETM1 - 40 data bit width         */
389 		reg_write(PEX_PHY_ACCESS_REG(1), (0x046 << 16) | 0x0400);	/* lane0(serdes4)                    */
390 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(1), (0x046 << 16) | 0x0400);	/* lane0(serdes4)                    */
391 		reg_write(PEX_PHY_ACCESS_REG(1), (0x346 << 16) | 0x0400);	/* lane3(serdes7)                    */
392 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(1), (0x346 << 16) | 0x0400);	/* lane3(serdes7)                    */
393 	}
394 
395 	/* STEP -1 [PEX-Only] First phase of PEX-PIPE Configuration: */
396 	DEBUG_INIT_FULL_S("Step 1: First phase of PEX-PIPE Configuration\n");
397 	for (pex_unit = 0; pex_unit < pex_max_unit_get(); pex_unit++) {
398 		if (info->pex_mode[pex_unit] == PEX_BUS_DISABLED)
399 			continue;
400 
401 		/* 1.   GLOB_CLK_CTRL Reset and Clock Control */
402 		reg_write(PEX_PHY_ACCESS_REG(pex_unit), (0xC1 << 16) | 0x25);
403 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit), (0xC1 << 16) | 0x25);
404 
405 		/* 2.   GLOB_TEST_CTRL Test Mode Control */
406 		if (info->pex_mode[pex_unit] == PEX_BUS_MODE_X4) {
407 			reg_write(PEX_PHY_ACCESS_REG(pex_unit),
408 				  (0xC2 << 16) | 0x200);
409 			DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit),
410 				     (0xC2 << 16) | 0x200);
411 		}
412 
413 		/* 3.   GLOB_CLK_SRC_LO Clock Source Low */
414 		if (info->pex_mode[pex_unit] == PEX_BUS_MODE_X1) {
415 			reg_write(PEX_PHY_ACCESS_REG(pex_unit),
416 				  (0xC3 << 16) | 0x0F);
417 			DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit),
418 				     (0xC3 << 16) | 0x0F);
419 		}
420 
421 		reg_write(PEX_PHY_ACCESS_REG(pex_unit), (0xC5 << 16) | 0x11F);
422 		DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit),
423 			     (0xC5 << 16) | 0x11F);
424 	}
425 
426 	/*
427 	 * 2 Configure the desire PIN_PHY_GEN and do power down to the PU_PLL,
428 	 * PU_RX,PU_TX. (bits[12:5])
429 	 */
430 	DEBUG_INIT_FULL_S("Step 2: Configure the desire PIN_PHY_GEN\n");
431 	for (line_num = 0; line_num < max_serdes_lines; line_num++) {
432 		line_cfg = get_line_cfg(line_num, info);
433 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_UNCONNECTED])
434 			continue;
435 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_PEX])
436 			continue;
437 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SATA]) {
438 			switch (line_num) {
439 			case 4:
440 			case 6:
441 				sata_port = 0;
442 				break;
443 			case 5:
444 				sata_port = 1;
445 				break;
446 			default:
447 				DEBUG_INIT_C
448 				    ("SATA port error for serdes line: ",
449 				     line_num, 2);
450 				return MV_ERROR;
451 			}
452 			tmp = reg_read(SATA_LP_PHY_EXT_CTRL_REG(sata_port));
453 			DEBUG_RD_REG(SATA_LP_PHY_EXT_CTRL_REG(sata_port), tmp);
454 			tmp &= ~((0x1ff << 5) | 0x7);
455 			tmp |= ((info->bus_speed & (1 << line_num)) != 0) ?
456 				(0x11 << 5) : 0x0;
457 
458 			reg_write(SATA_LP_PHY_EXT_CTRL_REG(sata_port), tmp);
459 			DEBUG_WR_REG(SATA_LP_PHY_EXT_CTRL_REG(sata_port), tmp);
460 		}
461 
462 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_QSGMII]) {
463 			/*
464 			 * 4) Configure the desire PIN_PHY_GEN and do power
465 			 * down to the PU_PLL,PU_RX,PU_TX. (bits[12:5])
466 			 */
467 			tmp = reg_read(SGMII_SERDES_CFG_REG(0));
468 			DEBUG_RD_REG(SGMII_SERDES_CFG_REG(0), tmp);
469 			tmp &= ~((0x1ff << 5) | 0x7);
470 			tmp |= 0x660;
471 			reg_write(SGMII_SERDES_CFG_REG(0), tmp);
472 			DEBUG_WR_REG(SGMII_SERDES_CFG_REG(0), tmp);
473 			continue;
474 		}
475 
476 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII0])
477 			sgmii_port = 0;
478 		else if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII1])
479 			sgmii_port = 1;
480 		else if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII2])
481 			sgmii_port = 2;
482 		else if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII3])
483 			sgmii_port = 3;
484 		else
485 			continue;
486 
487 		tmp = reg_read(SGMII_SERDES_CFG_REG(sgmii_port));
488 		DEBUG_RD_REG(SGMII_SERDES_CFG_REG(sgmii_port), tmp);
489 		tmp &= ~((0x1ff << 5) | 0x7);
490 		tmp |= (((info->bus_speed & (1 << line_num)) != 0) ?
491 			(0x88 << 5) : (0x66 << 5));
492 		reg_write(SGMII_SERDES_CFG_REG(sgmii_port), tmp);
493 		DEBUG_WR_REG(SGMII_SERDES_CFG_REG(sgmii_port), tmp);
494 	}
495 
496 	/* Step 3 - QSGMII enable */
497 	DEBUG_INIT_FULL_S("Step 3 QSGMII enable\n");
498 	for (line_num = 0; line_num < max_serdes_lines; line_num++) {
499 		line_cfg = get_line_cfg(line_num, info);
500 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_QSGMII]) {
501 			/* QSGMII Active bit set to true */
502 			tmp = reg_read(QSGMII_CONTROL_1_REG);
503 			DEBUG_RD_REG(QSGMII_CONTROL_1_REG, tmp);
504 			tmp |= (1 << 30);
505 #ifdef ERRATA_GL_6572255
506 			tmp |= (1 << 27);
507 #endif
508 			reg_write(QSGMII_CONTROL_1_REG, tmp);
509 			DEBUG_WR_REG(QSGMII_CONTROL_1_REG, tmp);
510 		}
511 	}
512 
513 	/* Step 4 - configure SERDES MUXes */
514 	DEBUG_INIT_FULL_S("Step 4: Configure SERDES MUXes\n");
515 	if (config_module & ETM_MODULE_DETECT) {
516 		reg_write(SERDES_LINE_MUX_REG_0_7, 0x40041111);
517 		DEBUG_WR_REG(SERDES_LINE_MUX_REG_0_7, 0x40041111);
518 	} else {
519 		reg_write(SERDES_LINE_MUX_REG_0_7, info->line0_7);
520 		DEBUG_WR_REG(SERDES_LINE_MUX_REG_0_7, info->line0_7);
521 	}
522 	reg_write(SERDES_LINE_MUX_REG_8_15, info->line8_15);
523 	DEBUG_WR_REG(SERDES_LINE_MUX_REG_8_15, info->line8_15);
524 
525 	/* Step 5: Activate the RX High Impedance Mode  */
526 	DEBUG_INIT_FULL_S("Step 5: Activate the RX High Impedance Mode\n");
527 	rx_high_imp_mode = 0x8080;
528 	if (device_rev == 2)	/*   for B0 only */
529 		rx_high_imp_mode |= 4;
530 
531 	for (line_num = 0; line_num < max_serdes_lines; line_num++) {
532 		/* for each serdes lane */
533 		DEBUG_INIT_FULL_S("SERDES  ");
534 		DEBUG_INIT_FULL_D_10(line_num, 2);
535 		line_cfg = get_line_cfg(line_num, info);
536 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_UNCONNECTED]) {
537 			DEBUG_INIT_FULL_S(" unconnected ***\n");
538 			continue;
539 		}
540 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_PEX]) {
541 			pex_unit = line_num >> 2;
542 			pex_line_num = line_num % 4;
543 			DEBUG_INIT_FULL_S(" - PEX unit ");
544 			DEBUG_INIT_FULL_D_10(pex_unit, 1);
545 			DEBUG_INIT_FULL_S(" line=  ");
546 			DEBUG_INIT_FULL_D_10(pex_line_num, 1);
547 			DEBUG_INIT_FULL_S("\n");
548 
549 			/* Needed for PEX_PHY_ACCESS_REG macro */
550 			if ((line_num > 7) &&
551 			    (info->pex_mode[3] == PEX_BUS_MODE_X8))
552 				/* lines 8 - 15 are belong to PEX3 in x8 mode */
553 				pex_unit = 3;
554 
555 			if (info->pex_mode[pex_unit] == PEX_BUS_DISABLED)
556 				continue;
557 
558 			/*
559 			 * 8)  Activate the RX High Impedance Mode field
560 			 * (bit [2]) in register /PCIe_USB Control (Each MAC
561 			 * contain different Access to reach its
562 			 * Serdes-Regfile).
563 			 * [PEX-Only] Set bit[12]: The analog part latches idle
564 			 * if PU_TX = 1 and PU_PLL =1.
565 			 */
566 
567 			/* Termination enable */
568 			if (info->pex_mode[pex_unit] == PEX_BUS_MODE_X1) {
569 				in_direct = (0x48 << 16) | (pex_line_num << 24) |
570 					0x1000 | rx_high_imp_mode;	/* x1 */
571 			} else if ((info->pex_mode[pex_unit] ==
572 				    PEX_BUS_MODE_X4) && (pex_line_num == 0))
573 				in_direct = (0x48 << 16) | (pex_line_num << 24) |
574 					0x1000 | (rx_high_imp_mode & 0xff);	/* x4 */
575 			else
576 				in_direct = 0;
577 
578 			if (in_direct) {
579 				reg_write(PEX_PHY_ACCESS_REG(pex_unit),
580 					  in_direct);
581 				DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit),
582 					     in_direct);
583 			}
584 
585 			continue;
586 		}
587 
588 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SATA]) {
589 			/*
590 			 * port 0 for serdes lines 4,6,  and port 1 for
591 			 * serdes lines 5
592 			 */
593 			sata_port = line_num & 1;
594 			DEBUG_INIT_FULL_S(" - SATA port  ");
595 			DEBUG_INIT_FULL_D_10(sata_port, 2);
596 			DEBUG_INIT_FULL_S("\n");
597 			reg_write(SATA_COMPHY_CTRL_REG(sata_port),
598 				  rx_high_imp_mode);
599 			DEBUG_WR_REG(SATA_COMPHY_CTRL_REG(sata_port),
600 				     rx_high_imp_mode);
601 			continue;
602 		}
603 
604 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_QSGMII]) {
605 			DEBUG_INIT_FULL_S(" - QSGMII\n");
606 			reg_write(SGMII_COMPHY_CTRL_REG(0), rx_high_imp_mode);
607 			DEBUG_WR_REG(SGMII_COMPHY_CTRL_REG(0),
608 				     rx_high_imp_mode);
609 			continue;
610 		}
611 
612 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII0])
613 			sgmii_port = 0;
614 		else if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII1])
615 			sgmii_port = 1;
616 		else if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII2])
617 			sgmii_port = 2;
618 		else if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII3])
619 			sgmii_port = 3;
620 		else
621 			continue;
622 		DEBUG_INIT_FULL_S(" - SGMII port  ");
623 		DEBUG_INIT_FULL_D_10(sgmii_port, 2);
624 		DEBUG_INIT_FULL_S("\n");
625 		reg_write(SGMII_COMPHY_CTRL_REG(sgmii_port), rx_high_imp_mode);
626 		DEBUG_WR_REG(SGMII_COMPHY_CTRL_REG(sgmii_port),
627 			     rx_high_imp_mode);
628 	}			/* for each serdes lane */
629 
630 	/* Step 6 [PEX-Only] PEX-Main configuration (X4 or X1): */
631 	DEBUG_INIT_FULL_S("Step 6: [PEX-Only] PEX-Main configuration (X4 or X1)\n");
632 	tmp = reg_read(SOC_CTRL_REG);
633 	DEBUG_RD_REG(SOC_CTRL_REG, tmp);
634 	tmp &= 0x200;
635 	if (info->pex_mode[0] == PEX_BUS_MODE_X1)
636 		tmp |= PCIE0_QUADX1_EN;
637 	if (info->pex_mode[1] == PEX_BUS_MODE_X1)
638 		tmp |= PCIE1_QUADX1_EN;
639 	if (((reg_read(MPP_SAMPLE_AT_RESET(0)) & PEX_CLK_100MHZ_MASK) >>
640 	     PEX_CLK_100MHZ_OFFSET) == 0x1)
641 		tmp |= (PCIE0_CLK_OUT_EN_MASK | PCIE1_CLK_OUT_EN_MASK);
642 
643 	reg_write(SOC_CTRL_REG, tmp);
644 	DEBUG_WR_REG(SOC_CTRL_REG, tmp);
645 
646 	/* 6.2 PCI Express Link Capabilities */
647 	DEBUG_INIT_FULL_S("Step 6.2: [PEX-Only] PCI Express Link Capabilities\n");
648 
649 	for (line_num = 0; line_num < max_serdes_lines; line_num++) {
650 		line_cfg = get_line_cfg(line_num, info);
651 
652 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_PEX]) {
653 			/*
654 			 * PCI Express Control
655 			 * 0xX1A00 [0]:
656 			 * 0x0 X4-Link.
657 			 * 0x1 X1-Link
658 			 */
659 			pex_unit = line_num >> 2;
660 			pex_if = MV_SERDES_NUM_TO_PEX_NUM(line_num);
661 			if (info->pex_mode[pex_unit] == PEX_BUS_DISABLED)
662 				continue;
663 
664 			/*  set Common Clock Configuration */
665 			tmp = reg_read(PEX_LINK_CTRL_STATUS_REG(pex_if));
666 			DEBUG_RD_REG(PEX_LINK_CTRL_STATUS_REG(pex_if), tmp);
667 			tmp |= (1 << 6);
668 			reg_write(PEX_LINK_CTRL_STATUS_REG(pex_if), tmp);
669 			DEBUG_WR_REG(PEX_LINK_CTRL_STATUS_REG(pex_if), tmp);
670 
671 			tmp = reg_read(PEX_LINK_CAPABILITIES_REG(pex_if));
672 			DEBUG_RD_REG(PEX_LINK_CAPABILITIES_REG(pex_if), tmp);
673 			tmp &= ~(0x3FF);
674 			if (info->pex_mode[pex_unit] == PEX_BUS_MODE_X1)
675 				tmp |= (0x1 << 4);
676 			if (info->pex_mode[pex_unit] == PEX_BUS_MODE_X4)
677 				tmp |= (0x4 << 4);
678 			if (0 == PEX_CAPABILITY_GET(satr11))
679 				tmp |= 0x1;
680 			else
681 				tmp |= 0x2;
682 			DEBUG_INIT_FULL_S("Step 6.2: PEX ");
683 			DEBUG_INIT_FULL_D(pex_if, 1);
684 			DEBUG_INIT_FULL_C(" set GEN", (tmp & 3), 1);
685 			reg_write(PEX_LINK_CAPABILITIES_REG(pex_if), tmp);
686 			DEBUG_WR_REG(PEX_LINK_CAPABILITIES_REG(pex_if), tmp);
687 
688 			/*
689 			 * If pex is X4, no need to pass thru the other
690 			 * 3X1 serdes lines
691 			 */
692 			if (info->pex_mode[pex_unit] == PEX_BUS_MODE_X4)
693 				line_num += 3;
694 		}
695 	}
696 
697 	/*
698 	 * Step 7 [PEX-X4 Only] To create PEX-Link that contain 4-lanes you
699 	 * need to config the register SOC_Misc/General Purpose2
700 	 * (Address= 182F8)
701 	 */
702 	DEBUG_INIT_FULL_S("Step 7: [PEX-X4 Only] To create PEX-Link\n");
703 	tmp = reg_read(GEN_PURP_RES_2_REG);
704 	DEBUG_RD_REG(GEN_PURP_RES_2_REG, tmp);
705 
706 	tmp &= 0xFFFF0000;
707 	if (info->pex_mode[0] == PEX_BUS_MODE_X4)
708 		tmp |= 0x0000000F;
709 
710 	if (info->pex_mode[1] == PEX_BUS_MODE_X4)
711 		tmp |= 0x000000F0;
712 
713 	if (info->pex_mode[2] == PEX_BUS_MODE_X4)
714 		tmp |= 0x00000F00;
715 
716 	if (info->pex_mode[3] == PEX_BUS_MODE_X4)
717 		tmp |= 0x0000F000;
718 
719 	reg_write(GEN_PURP_RES_2_REG, tmp);
720 	DEBUG_WR_REG(GEN_PURP_RES_2_REG, tmp);
721 
722 	/* Steps  8 , 9 ,10 - use prepared REG addresses and values */
723 	DEBUG_INIT_FULL_S("Steps 7,8,9,10 and 11\n");
724 
725 	/* Prepare PHY parameters for each step according to  MUX selection */
726 	for (line_num = 0; line_num < max_serdes_lines; line_num++) {
727 		/* for each serdes lane */
728 
729 		line_cfg = get_line_cfg(line_num, info);
730 
731 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_UNCONNECTED])
732 			continue;
733 
734 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_PEX]) {
735 			pex_unit = line_num >> 2;
736 			pex_line_num = line_num % 4;
737 
738 			if (info->pex_mode[pex_unit] == PEX_BUS_DISABLED)
739 				continue;
740 			/*
741 			 * 8)   Configure the desire PHY_MODE (bits [7:5])
742 			 * and REF_FREF_SEL (bits[4:0]) in the register Power
743 			 * and PLL Control (Each MAC contain different Access
744 			 * to reach its Serdes-Regfile).
745 			 */
746 			if (((info->pex_mode[pex_unit] == PEX_BUS_MODE_X4) &&
747 			     (0 == pex_line_num))
748 			    || ((info->pex_mode[pex_unit] == PEX_BUS_MODE_X1))) {
749 				reg_write(PEX_PHY_ACCESS_REG(pex_unit),
750 					  (0x01 << 16) | (pex_line_num << 24) |
751 					  0xFC60);
752 				DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit),
753 					     (0x01 << 16) | (pex_line_num << 24)
754 					     | 0xFC60);
755 				/*
756 				 * Step 8.1: [PEX-Only] Configure Max PLL Rate
757 				 * (bit 8 in  KVCO Calibration Control and
758 				 * bits[10:9] in
759 				 */
760 				/* Use Maximum PLL Rate(Bit 8) */
761 				reg_write(PEX_PHY_ACCESS_REG(pex_unit),
762 					  (0x02 << 16) | (1 << 31) |
763 					  (pex_line_num << 24)); /* read command */
764 				DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit),
765 					     (0x02 << 16) | (1 << 31) |
766 					     (pex_line_num << 24));
767 				tmp = reg_read(PEX_PHY_ACCESS_REG(pex_unit));
768 				DEBUG_RD_REG(PEX_PHY_ACCESS_REG(pex_unit), tmp);
769 				tmp &= ~(1 << 31);
770 				tmp |= (1 << 8);
771 				reg_write(PEX_PHY_ACCESS_REG(pex_unit), tmp);
772 				DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit), tmp);
773 
774 				/* Use Maximum PLL Rate(Bits [10:9]) */
775 				reg_write(PEX_PHY_ACCESS_REG(pex_unit),
776 					  (0x81 << 16) | (1 << 31) |
777 					  (pex_line_num << 24)); /* read command */
778 				DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit),
779 					     (0x81 << 16) | (1 << 31) |
780 					     (pex_line_num << 24));
781 				tmp = reg_read(PEX_PHY_ACCESS_REG(pex_unit));
782 				DEBUG_RD_REG(PEX_PHY_ACCESS_REG(pex_unit), tmp);
783 				tmp &= ~(1 << 31);
784 				tmp |= (3 << 9);
785 				reg_write(PEX_PHY_ACCESS_REG(pex_unit), tmp);
786 				DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit), tmp);
787 			}
788 
789 			continue;
790 		}
791 
792 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SATA]) {
793 			/*
794 			 * Port 0 for serdes lines 4,6,  and port 1 for serdes
795 			 * lines 5
796 			 */
797 			sata_port = line_num & 1;
798 
799 			/*
800 			 * 8) Configure the desire PHY_MODE (bits [7:5]) and
801 			 * REF_FREF_SEL (bits[4:0]) in the register Power
802 			 * and PLL Control (Each MAC contain different Access
803 			 * to reach its Serdes-Regfile).
804 			 */
805 			reg_write(SATA_PWR_PLL_CTRL_REG(sata_port), 0xF801);
806 			DEBUG_WR_REG(SATA_PWR_PLL_CTRL_REG(sata_port), 0xF801);
807 
808 			/*  9)  Configure the desire SEL_BITS  */
809 			reg_write(SATA_DIG_LP_ENA_REG(sata_port), 0x400);
810 			DEBUG_WR_REG(SATA_DIG_LP_ENA_REG(sata_port), 0x400);
811 
812 			/* 10)  Configure the desire REFCLK_SEL */
813 
814 			reg_write(SATA_REF_CLK_SEL_REG(sata_port), 0x400);
815 			DEBUG_WR_REG(SATA_REF_CLK_SEL_REG(sata_port), 0x400);
816 
817 			/* 11)  Power up to the PU_PLL,PU_RX,PU_TX.   */
818 			tmp = reg_read(SATA_LP_PHY_EXT_CTRL_REG(sata_port));
819 			DEBUG_RD_REG(SATA_LP_PHY_EXT_CTRL_REG(sata_port), tmp);
820 			tmp |= 7;
821 			reg_write(SATA_LP_PHY_EXT_CTRL_REG(sata_port), tmp);
822 			DEBUG_WR_REG(SATA_LP_PHY_EXT_CTRL_REG(sata_port), tmp);
823 
824 			continue;
825 		}
826 
827 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_QSGMII]) {
828 			/*
829 			 * 8)   Configure the desire PHY_MODE (bits [7:5])
830 			 * and REF_FREF_SEL (bits[4:0]) in the register
831 			 */
832 			reg_write(SGMII_PWR_PLL_CTRL_REG(0), 0xF881);
833 			DEBUG_WR_REG(SGMII_PWR_PLL_CTRL_REG(0), 0xF881);
834 
835 			/*
836 			 * 9)   Configure the desire SEL_BITS (bits [11:0]
837 			 * in register
838 			 */
839 			reg_write(SGMII_DIG_LP_ENA_REG(0), 0x400);
840 			DEBUG_WR_REG(SGMII_DIG_LP_ENA_REG(0), 0x400);
841 
842 			/*
843 			 * 10)  Configure the desire REFCLK_SEL (bit [10])
844 			 * in register
845 			 */
846 			reg_write(SGMII_REF_CLK_SEL_REG(0), 0x400);
847 			DEBUG_WR_REG(SGMII_REF_CLK_SEL_REG(0), 0x400);
848 
849 			/* 11)  Power up to the PU_PLL,PU_RX,PU_TX.  */
850 			tmp = reg_read(SGMII_SERDES_CFG_REG(0));
851 			DEBUG_RD_REG(SGMII_SERDES_CFG_REG(0), tmp);
852 			tmp |= 7;
853 			reg_write(SGMII_SERDES_CFG_REG(0), tmp);
854 			DEBUG_WR_REG(SGMII_SERDES_CFG_REG(0), tmp);
855 			continue;
856 		}
857 
858 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII0])
859 			sgmii_port = 0;
860 		else if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII1])
861 			sgmii_port = 1;
862 		else if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII2])
863 			sgmii_port = 2;
864 		else if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SGMII3])
865 			sgmii_port = 3;
866 		else
867 			continue;
868 
869 		/*
870 		 * 8)   Configure the desire PHY_MODE (bits [7:5]) and
871 		 * REF_FREF_SEL (bits[4:0]) in the register
872 		 */
873 		reg_write(SGMII_PWR_PLL_CTRL_REG(sgmii_port), 0xF881);
874 		DEBUG_WR_REG(SGMII_PWR_PLL_CTRL_REG(sgmii_port), 0xF881);
875 
876 		/* 9)   Configure the desire SEL_BITS (bits [11:0] in register */
877 		reg_write(SGMII_DIG_LP_ENA_REG(sgmii_port), 0);
878 		DEBUG_WR_REG(SGMII_DIG_LP_ENA_REG(sgmii_port), 0);
879 
880 		/* 10)  Configure the desire REFCLK_SEL (bit [10]) in register  */
881 		reg_write(SGMII_REF_CLK_SEL_REG(sgmii_port), 0x400);
882 		DEBUG_WR_REG(SGMII_REF_CLK_SEL_REG(sgmii_port), 0x400);
883 
884 		/* 11)  Power up to the PU_PLL,PU_RX,PU_TX.  */
885 		tmp = reg_read(SGMII_SERDES_CFG_REG(sgmii_port));
886 		DEBUG_RD_REG(SGMII_SERDES_CFG_REG(sgmii_port), tmp);
887 		tmp |= 7;
888 		reg_write(SGMII_SERDES_CFG_REG(sgmii_port), tmp);
889 		DEBUG_WR_REG(SGMII_SERDES_CFG_REG(sgmii_port), tmp);
890 
891 	}			/* for each serdes lane */
892 
893 	/* Step 12 [PEX-Only] Last phase of PEX-PIPE Configuration */
894 	DEBUG_INIT_FULL_S("Steps 12: [PEX-Only] Last phase of PEX-PIPE Configuration\n");
895 	for (line_num = 0; line_num < max_serdes_lines; line_num++) {
896 		/* for each serdes lane */
897 
898 		line_cfg = get_line_cfg(line_num, info);
899 
900 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_UNCONNECTED])
901 			continue;
902 
903 		if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_PEX]) {
904 			pex_unit = line_num >> 2;
905 			pex_line_num = line_num % 4;
906 			if (0 == pex_line_num) {
907 				/*
908 				 * Configure the detection pulse with before
909 				 * the reset is deasserted
910 				 */
911 
912 				/* Read the old value (indirect access) */
913 				reg_write(PEX_PHY_ACCESS_REG(pex_unit),
914 					  (0x48 << 16) | (1 << 31) |
915 					  (pex_line_num << 24));
916 				tmp = reg_read(PEX_PHY_ACCESS_REG(pex_unit));
917 				tmp &= ~(1 << 31);	/* Clear read */
918 				tmp &= ~(3 << 6);	/* Mask width */
919 				/* Insert new detection pulse width */
920 				tmp |= serdes_pex_pulse_width[pex_unit] << 6;
921 				/* Write value back */
922 				reg_write(PEX_PHY_ACCESS_REG(pex_unit), tmp);
923 
924 				reg_write(PEX_PHY_ACCESS_REG(pex_unit),
925 					  (0xC1 << 16) | 0x24);
926 				DEBUG_WR_REG(PEX_PHY_ACCESS_REG(pex_unit),
927 					     (0xC1 << 16) | 0x24);
928 			}
929 		}
930 	}
931 
932 	/*--------------------------------------------------------------*/
933 	/* Step 13: Wait 15ms before checking results */
934 	DEBUG_INIT_FULL_S("Steps 13: Wait 15ms before checking results");
935 	mdelay(15);
936 	tmp = 20;
937 	while (tmp) {
938 		status = MV_OK;
939 		for (line_num = 0; line_num < max_serdes_lines; line_num++) {
940 			u32 tmp;
941 			line_cfg = get_line_cfg(line_num, info);
942 			if (line_cfg ==
943 			    serdes_cfg[line_num][SERDES_UNIT_UNCONNECTED])
944 				continue;
945 
946 			if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_PEX])
947 				continue;
948 
949 			if (line_cfg == serdes_cfg[line_num][SERDES_UNIT_SATA]) {
950 				/*
951 				 * Port 0 for serdes lines 4,6,  and port 1
952 				 * for serdes lines 5
953 				 */
954 				sata_port = line_num & 1;
955 
956 				tmp =
957 				    reg_read(SATA_LP_PHY_EXT_STAT_REG
958 					     (sata_port));
959 				DEBUG_RD_REG(SATA_LP_PHY_EXT_STAT_REG
960 					     (sata_port), tmp);
961 				if ((tmp & 0x7) != 0x7)
962 					status = MV_ERROR;
963 				continue;
964 			}
965 
966 			if (line_cfg ==
967 			    serdes_cfg[line_num][SERDES_UNIT_QSGMII]) {
968 				tmp = reg_read(SGMII_SERDES_STAT_REG(0));
969 				DEBUG_RD_REG(SGMII_SERDES_STAT_REG(0), tmp);
970 				if ((tmp & 0x7) != 0x7)
971 					status = MV_ERROR;
972 				continue;
973 			}
974 
975 			if (line_cfg ==
976 			    serdes_cfg[line_num][SERDES_UNIT_SGMII0])
977 				sgmii_port = 0;
978 			else if (line_cfg ==
979 				 serdes_cfg[line_num][SERDES_UNIT_SGMII1])
980 				sgmii_port = 1;
981 			else if (line_cfg ==
982 				 serdes_cfg[line_num][SERDES_UNIT_SGMII2])
983 				sgmii_port = 2;
984 			else if (line_cfg ==
985 				 serdes_cfg[line_num][SERDES_UNIT_SGMII3])
986 				sgmii_port = 3;
987 			else
988 				continue;
989 
990 			tmp = reg_read(SGMII_SERDES_STAT_REG(sgmii_port));
991 			DEBUG_RD_REG(SGMII_SERDES_STAT_REG(sgmii_port), tmp);
992 			if ((tmp & 0x7) != 0x7)
993 				status = MV_ERROR;
994 		}
995 
996 		if (status == MV_OK)
997 			break;
998 		mdelay(5);
999 		tmp--;
1000 	}
1001 
1002 	/*
1003 	 * Step14 [PEX-Only]  In order to configure RC/EP mode please write
1004 	 * to register 0x0060 bits
1005 	 */
1006 	DEBUG_INIT_FULL_S("Steps 14: [PEX-Only]  In order to configure\n");
1007 	for (pex_unit = 0; pex_unit < pex_max_unit_get(); pex_unit++) {
1008 		if (info->pex_mode[pex_unit] == PEX_BUS_DISABLED)
1009 			continue;
1010 		tmp =
1011 		    reg_read(PEX_CAPABILITIES_REG(MV_PEX_UNIT_TO_IF(pex_unit)));
1012 		DEBUG_RD_REG(PEX_CAPABILITIES_REG(MV_PEX_UNIT_TO_IF(pex_unit)),
1013 			     tmp);
1014 		tmp &= ~(0xf << 20);
1015 		if (info->pex_type == MV_PEX_ROOT_COMPLEX)
1016 			tmp |= (0x4 << 20);
1017 		else
1018 			tmp |= (0x1 << 20);
1019 		reg_write(PEX_CAPABILITIES_REG(MV_PEX_UNIT_TO_IF(pex_unit)),
1020 			  tmp);
1021 		DEBUG_WR_REG(PEX_CAPABILITIES_REG(MV_PEX_UNIT_TO_IF(pex_unit)),
1022 			     tmp);
1023 	}
1024 
1025 	/*
1026 	 * Step 15 [PEX-Only] Only for EP mode set to Zero bits 19 and 16 of
1027 	 * register 0x1a60
1028 	 */
1029 	DEBUG_INIT_FULL_S("Steps 15: [PEX-Only]  In order to configure\n");
1030 	for (pex_unit = 0; pex_unit < pex_max_unit_get(); pex_unit++) {
1031 		if (info->pex_mode[pex_unit] == PEX_BUS_DISABLED)
1032 			continue;
1033 		if (info->pex_type == MV_PEX_END_POINT) {
1034 			tmp =
1035 			    reg_read(PEX_DBG_CTRL_REG
1036 				     (MV_PEX_UNIT_TO_IF(pex_unit)));
1037 			DEBUG_RD_REG(PEX_DBG_CTRL_REG
1038 				     (MV_PEX_UNIT_TO_IF(pex_unit)), tmp);
1039 			tmp &= 0xfff6ffff;
1040 			reg_write(PEX_DBG_CTRL_REG(MV_PEX_UNIT_TO_IF(pex_unit)),
1041 				  tmp);
1042 			DEBUG_WR_REG(PEX_DBG_CTRL_REG
1043 				     (MV_PEX_UNIT_TO_IF(pex_unit)), tmp);
1044 		}
1045 	}
1046 
1047 	if (info->serdes_m_phy_change) {
1048 		MV_SERDES_CHANGE_M_PHY *serdes_m_phy_change;
1049 		u32 bus_speed;
1050 		for (line_num = 0; line_num < max_serdes_lines; line_num++) {
1051 			line_cfg = get_line_cfg(line_num, info);
1052 			if (line_cfg ==
1053 			    serdes_cfg[line_num][SERDES_UNIT_UNCONNECTED])
1054 				continue;
1055 			serdes_m_phy_change = info->serdes_m_phy_change;
1056 			bus_speed = info->bus_speed & (1 << line_num);
1057 			while (serdes_m_phy_change->type !=
1058 			       SERDES_UNIT_UNCONNECTED) {
1059 				switch (serdes_m_phy_change->type) {
1060 				case SERDES_UNIT_PEX:
1061 					if (line_cfg != SERDES_UNIT_PEX)
1062 						break;
1063 					pex_unit = line_num >> 2;
1064 					pex_line_num = line_num % 4;
1065 					if (info->pex_mode[pex_unit] ==
1066 					    PEX_BUS_DISABLED)
1067 						break;
1068 					if ((info->pex_mode[pex_unit] ==
1069 					     PEX_BUS_MODE_X4) && pex_line_num)
1070 						break;
1071 
1072 					if (bus_speed) {
1073 						reg_write(PEX_PHY_ACCESS_REG
1074 							  (pex_unit),
1075 							  (pex_line_num << 24) |
1076 							  serdes_m_phy_change->val_hi_speed);
1077 						DEBUG_WR_REG(PEX_PHY_ACCESS_REG
1078 							     (pex_unit),
1079 							     (pex_line_num <<
1080 							      24) |
1081 							     serdes_m_phy_change->val_hi_speed);
1082 					} else {
1083 						reg_write(PEX_PHY_ACCESS_REG
1084 							  (pex_unit),
1085 							  (pex_line_num << 24) |
1086 							  serdes_m_phy_change->val_low_speed);
1087 						DEBUG_WR_REG(PEX_PHY_ACCESS_REG
1088 							     (pex_unit),
1089 							     (pex_line_num <<
1090 							      24) |
1091 							     serdes_m_phy_change->val_low_speed);
1092 					}
1093 					break;
1094 				case SERDES_UNIT_SATA:
1095 					if (line_cfg != SERDES_UNIT_SATA)
1096 						break;
1097 					/*
1098 					 * Port 0 for serdes lines 4,6,  and
1099 					 * port 1 for serdes lines 5
1100 					 */
1101 					sata_port = line_num & 1;
1102 					if (bus_speed) {
1103 						reg_write(SATA_BASE_REG
1104 							  (sata_port) |
1105 							  serdes_m_phy_change->reg_hi_speed,
1106 							  serdes_m_phy_change->val_hi_speed);
1107 						DEBUG_WR_REG(SATA_BASE_REG
1108 							     (sata_port) |
1109 							     serdes_m_phy_change->reg_hi_speed,
1110 							     serdes_m_phy_change->val_hi_speed);
1111 					} else {
1112 						reg_write(SATA_BASE_REG
1113 							  (sata_port) |
1114 							  serdes_m_phy_change->reg_low_speed,
1115 							  serdes_m_phy_change->val_low_speed);
1116 						DEBUG_WR_REG(SATA_BASE_REG
1117 							     (sata_port) |
1118 							     serdes_m_phy_change->reg_low_speed,
1119 							     serdes_m_phy_change->val_low_speed);
1120 					}
1121 					break;
1122 				case SERDES_UNIT_SGMII0:
1123 				case SERDES_UNIT_SGMII1:
1124 				case SERDES_UNIT_SGMII2:
1125 				case SERDES_UNIT_SGMII3:
1126 					if (line_cfg == serdes_cfg[line_num]
1127 					    [SERDES_UNIT_SGMII0])
1128 						sgmii_port = 0;
1129 					else if (line_cfg ==
1130 						 serdes_cfg[line_num]
1131 						 [SERDES_UNIT_SGMII1])
1132 						sgmii_port = 1;
1133 					else if (line_cfg ==
1134 						 serdes_cfg[line_num]
1135 						 [SERDES_UNIT_SGMII2])
1136 						sgmii_port = 2;
1137 					else if (line_cfg ==
1138 						 serdes_cfg[line_num]
1139 						 [SERDES_UNIT_SGMII3])
1140 						sgmii_port = 3;
1141 					else
1142 						break;
1143 					if (bus_speed) {
1144 						reg_write(MV_ETH_REGS_BASE
1145 							  (sgmii_port) |
1146 							  serdes_m_phy_change->reg_hi_speed,
1147 							  serdes_m_phy_change->val_hi_speed);
1148 						DEBUG_WR_REG(MV_ETH_REGS_BASE
1149 							     (sgmii_port) |
1150 							     serdes_m_phy_change->reg_hi_speed,
1151 							     serdes_m_phy_change->val_hi_speed);
1152 					} else {
1153 						reg_write(MV_ETH_REGS_BASE
1154 							  (sgmii_port) |
1155 							  serdes_m_phy_change->reg_low_speed,
1156 							  serdes_m_phy_change->val_low_speed);
1157 						DEBUG_WR_REG(MV_ETH_REGS_BASE
1158 							     (sgmii_port) |
1159 							     serdes_m_phy_change->reg_low_speed,
1160 							     serdes_m_phy_change->val_low_speed);
1161 					}
1162 					break;
1163 				case SERDES_UNIT_QSGMII:
1164 					if (line_cfg != SERDES_UNIT_QSGMII)
1165 						break;
1166 					if (bus_speed) {
1167 						reg_write
1168 						    (serdes_m_phy_change->reg_hi_speed,
1169 						     serdes_m_phy_change->val_hi_speed);
1170 						DEBUG_WR_REG
1171 						    (serdes_m_phy_change->reg_hi_speed,
1172 						     serdes_m_phy_change->val_hi_speed);
1173 					} else {
1174 						reg_write
1175 						    (serdes_m_phy_change->reg_low_speed,
1176 						     serdes_m_phy_change->val_low_speed);
1177 						DEBUG_WR_REG
1178 						    (serdes_m_phy_change->reg_low_speed,
1179 						     serdes_m_phy_change->val_low_speed);
1180 					}
1181 					break;
1182 				default:
1183 					break;
1184 				}
1185 				serdes_m_phy_change++;
1186 			}
1187 		}
1188 	}
1189 
1190 	/* Step 16 [PEX-Only] Training Enable */
1191 	DEBUG_INIT_FULL_S("Steps 16: [PEX-Only] Training Enable");
1192 	tmp = reg_read(SOC_CTRL_REG);
1193 	DEBUG_RD_REG(SOC_CTRL_REG, tmp);
1194 	tmp &= ~(0x0F);
1195 	for (pex_unit = 0; pex_unit < pex_max_unit_get(); pex_unit++) {
1196 		reg_write(PEX_CAUSE_REG(pex_unit), 0);
1197 		DEBUG_WR_REG(PEX_CAUSE_REG(pex_unit), 0);
1198 		if (info->pex_mode[pex_unit] != PEX_BUS_DISABLED)
1199 			tmp |= (0x1 << pex_unit);
1200 	}
1201 	reg_write(SOC_CTRL_REG, tmp);
1202 	DEBUG_WR_REG(SOC_CTRL_REG, tmp);
1203 
1204 	/* Step 17: Speed change to target speed and width */
1205 	{
1206 		u32 tmp_reg, tmp_pex_reg;
1207 		u32 addr;
1208 		u32 first_busno, next_busno;
1209 		u32 max_link_width = 0;
1210 		u32 neg_link_width = 0;
1211 		pex_if_num = pex_max_if_get();
1212 		mdelay(150);
1213 		DEBUG_INIT_FULL_C("step 17: max_if= 0x", pex_if_num, 1);
1214 		next_busno = 0;
1215 		for (pex_if = 0; pex_if < pex_if_num; pex_if++) {
1216 			line_num = (pex_if <= 8) ? pex_if : 12;
1217 			line_cfg = get_line_cfg(line_num, info);
1218 			if (line_cfg != serdes_cfg[line_num][SERDES_UNIT_PEX])
1219 				continue;
1220 			pex_unit = (pex_if < 9) ? (pex_if >> 2) : 3;
1221 			DEBUG_INIT_FULL_S("step 17:  PEX");
1222 			DEBUG_INIT_FULL_D(pex_if, 1);
1223 			DEBUG_INIT_FULL_C("  pex_unit= ", pex_unit, 1);
1224 
1225 			if (info->pex_mode[pex_unit] == PEX_BUS_DISABLED) {
1226 				DEBUG_INIT_FULL_C("PEX disabled interface ",
1227 						  pex_if, 1);
1228 				if (pex_if < 8)
1229 					pex_if += 3;
1230 				continue;
1231 			}
1232 			first_busno = next_busno;
1233 			if ((info->pex_type == MV_PEX_END_POINT) &&
1234 			    (0 == pex_if)) {
1235 				if ((pex_if < 8) && (info->pex_mode[pex_unit] ==
1236 						     PEX_BUS_MODE_X4))
1237 					pex_if += 3;
1238 				continue;
1239 			}
1240 
1241 			tmp = reg_read(PEX_DBG_STATUS_REG(pex_if));
1242 			DEBUG_RD_REG(PEX_DBG_STATUS_REG(pex_if), tmp);
1243 			if ((tmp & 0x7f) == 0x7e) {
1244 				next_busno++;
1245 				tmp = reg_read(PEX_LINK_CAPABILITIES_REG(pex_if));
1246 				max_link_width = tmp;
1247 				DEBUG_RD_REG((PEX_LINK_CAPABILITIES_REG
1248 					      (pex_if)), tmp);
1249 				max_link_width = ((max_link_width >> 4) & 0x3F);
1250 				neg_link_width =
1251 				    reg_read(PEX_LINK_CTRL_STATUS_REG(pex_if));
1252 				DEBUG_RD_REG((PEX_LINK_CTRL_STATUS_REG(pex_if)),
1253 					     neg_link_width);
1254 				neg_link_width = ((neg_link_width >> 20) & 0x3F);
1255 				if (max_link_width > neg_link_width) {
1256 					tmp &= ~(0x3F << 4);
1257 					tmp |= (neg_link_width << 4);
1258 					reg_write(PEX_LINK_CAPABILITIES_REG
1259 						  (pex_if), tmp);
1260 					DEBUG_WR_REG((PEX_LINK_CAPABILITIES_REG
1261 						      (pex_if)), tmp);
1262 					mdelay(1);	/* wait 1ms before reading  capability for speed */
1263 					DEBUG_INIT_S("PEX");
1264 					DEBUG_INIT_D(pex_if, 1);
1265 					DEBUG_INIT_C(": change width to X",
1266 						     neg_link_width, 1);
1267 				}
1268 				tmp_pex_reg =
1269 				    reg_read((PEX_CFG_DIRECT_ACCESS
1270 					      (pex_if,
1271 					       PEX_LINK_CAPABILITY_REG)));
1272 				DEBUG_RD_REG((PEX_CFG_DIRECT_ACCESS
1273 					      (pex_if,
1274 					       PEX_LINK_CAPABILITY_REG)),
1275 					     tmp_pex_reg);
1276 				tmp_pex_reg &= (0xF);
1277 				if (tmp_pex_reg == 0x2) {
1278 					tmp_reg =
1279 					    (reg_read
1280 					     (PEX_CFG_DIRECT_ACCESS
1281 					      (pex_if,
1282 					       PEX_LINK_CTRL_STAT_REG)) &
1283 					     0xF0000) >> 16;
1284 					DEBUG_RD_REG(PEX_CFG_DIRECT_ACCESS
1285 						     (pex_if,
1286 						      PEX_LINK_CTRL_STAT_REG),
1287 						     tmp_pex_reg);
1288 					/* check if the link established is GEN1 */
1289 					if (tmp_reg == 0x1) {
1290 						pex_local_bus_num_set(pex_if,
1291 								      first_busno);
1292 						pex_local_dev_num_set(pex_if,
1293 								      1);
1294 
1295 						DEBUG_INIT_FULL_S("** Link is Gen1, check the EP capability\n");
1296 						/* link is Gen1, check the EP capability */
1297 						addr =
1298 						    pex_cfg_read(pex_if,
1299 								 first_busno, 0,
1300 								 0,
1301 								 0x34) & 0xFF;
1302 						DEBUG_INIT_FULL_C("pex_cfg_read: return addr=0x%x",
1303 						     addr, 4);
1304 						if (addr == 0xff) {
1305 							DEBUG_INIT_FULL_C("pex_cfg_read: return 0xff -->PEX (%d): Detected No Link.",
1306 									  pex_if, 1);
1307 							continue;
1308 						}
1309 						while ((pex_cfg_read
1310 							(pex_if, first_busno, 0,
1311 							 0,
1312 							 addr) & 0xFF) !=
1313 						       0x10) {
1314 							addr =
1315 							    (pex_cfg_read
1316 							     (pex_if,
1317 							      first_busno, 0, 0,
1318 							      addr) & 0xFF00) >>
1319 							    8;
1320 						}
1321 						if ((pex_cfg_read
1322 						     (pex_if, first_busno, 0, 0,
1323 						      addr + 0xC) & 0xF) >=
1324 						    0x2) {
1325 							tmp =
1326 							    reg_read
1327 							    (PEX_LINK_CTRL_STATUS2_REG
1328 							     (pex_if));
1329 							DEBUG_RD_REG
1330 							    (PEX_LINK_CTRL_STATUS2_REG
1331 							     (pex_if), tmp);
1332 							tmp &= ~(0x1 | 1 << 1);
1333 							tmp |= (1 << 1);
1334 							reg_write
1335 							    (PEX_LINK_CTRL_STATUS2_REG
1336 							     (pex_if), tmp);
1337 							DEBUG_WR_REG
1338 							    (PEX_LINK_CTRL_STATUS2_REG
1339 							     (pex_if), tmp);
1340 
1341 							tmp =
1342 							    reg_read
1343 							    (PEX_CTRL_REG
1344 							     (pex_if));
1345 							DEBUG_RD_REG
1346 							    (PEX_CTRL_REG
1347 							     (pex_if), tmp);
1348 							tmp |= (1 << 10);
1349 							reg_write(PEX_CTRL_REG
1350 								  (pex_if),
1351 								  tmp);
1352 							DEBUG_WR_REG
1353 							    (PEX_CTRL_REG
1354 							     (pex_if), tmp);
1355 							mdelay(10);	/* We need to wait 10ms before reading the PEX_DBG_STATUS_REG in order not to read the status of the former state */
1356 							DEBUG_INIT_FULL_S
1357 							    ("Gen2 client!\n");
1358 						} else {
1359 							DEBUG_INIT_FULL_S
1360 							    ("GEN1 client!\n");
1361 						}
1362 					}
1363 				}
1364 			} else {
1365 				DEBUG_INIT_FULL_S("PEX");
1366 				DEBUG_INIT_FULL_D(pex_if, 1);
1367 				DEBUG_INIT_FULL_S(" : Detected No Link. Status Reg(0x");
1368 				DEBUG_INIT_FULL_D(PEX_DBG_STATUS_REG(pex_if),
1369 						  8);
1370 				DEBUG_INIT_FULL_C(") = 0x", tmp, 8);
1371 			}
1372 
1373 			if ((pex_if < 8) &&
1374 			    (info->pex_mode[pex_unit] == PEX_BUS_MODE_X4))
1375 				pex_if += 3;
1376 		}
1377 	}
1378 
1379 	/* Step 18: update pex DEVICE ID */
1380 	{
1381 		u32 devId;
1382 		pex_if_num = pex_max_if_get();
1383 		ctrl_mode = ctrl_model_get();
1384 		for (pex_if = 0; pex_if < pex_if_num; pex_if++) {
1385 			pex_unit = (pex_if < 9) ? (pex_if >> 2) : 3;
1386 			if (info->pex_mode[pex_unit] == PEX_BUS_DISABLED) {
1387 				if ((pex_if < 8) &&
1388 				    (info->pex_mode[pex_unit] == PEX_BUS_MODE_X4))
1389 					pex_if += 3;
1390 				continue;
1391 			}
1392 
1393 			devId = reg_read(PEX_CFG_DIRECT_ACCESS(
1394 						 pex_if, PEX_DEVICE_AND_VENDOR_ID));
1395 			devId &= 0xFFFF;
1396 			devId |= ((ctrl_mode << 16) & 0xffff0000);
1397 			DEBUG_INIT_FULL_S("Update Device ID PEX");
1398 			DEBUG_INIT_FULL_D(pex_if, 1);
1399 			DEBUG_INIT_FULL_D(devId, 8);
1400 			DEBUG_INIT_FULL_S("\n");
1401 			reg_write(PEX_CFG_DIRECT_ACCESS
1402 				  (pex_if, PEX_DEVICE_AND_VENDOR_ID), devId);
1403 			if ((pex_if < 8) &&
1404 			    (info->pex_mode[pex_unit] == PEX_BUS_MODE_X4))
1405 				pex_if += 3;
1406 		}
1407 		DEBUG_INIT_FULL_S("Update PEX Device ID 0x");
1408 		DEBUG_INIT_FULL_D(ctrl_mode, 4);
1409 		DEBUG_INIT_FULL_S("0\n");
1410 	}
1411 	tmp = reg_read(PEX_DBG_STATUS_REG(0));
1412 	DEBUG_RD_REG(PEX_DBG_STATUS_REG(0), tmp);
1413 
1414 	DEBUG_INIT_S(ENDED_OK);
1415 	return MV_OK;
1416 }
1417 
1418 /* PEX configuration space read write */
1419 
1420 /*
1421  * pex_cfg_read - Read from configuration space
1422  *
1423  * DESCRIPTION:
1424  *       This function performs a 32 bit read from PEX configuration space.
1425  *       It supports both type 0 and type 1 of Configuration Transactions
1426  *       (local and over bridge). In order to read from local bus segment, use
1427  *       bus number retrieved from mvPexLocalBusNumGet(). Other bus numbers
1428  *       will result configuration transaction of type 1 (over bridge).
1429  *
1430  * INPUT:
1431  *       pex_if   - PEX interface number.
1432  *       bus     - PEX segment bus number.
1433  *       dev     - PEX device number.
1434  *       func    - Function number.
1435  *       offss - Register offset.
1436  *
1437  * OUTPUT:
1438  *       None.
1439  *
1440  * RETURN:
1441  *       32bit register data, 0xffffffff on error
1442  *
1443  */
pex_cfg_read(u32 pex_if,u32 bus,u32 dev,u32 func,u32 offs)1444 u32 pex_cfg_read(u32 pex_if, u32 bus, u32 dev, u32 func, u32 offs)
1445 {
1446 	u32 pex_data = 0;
1447 	u32 local_dev, local_bus;
1448 	u32 val;
1449 
1450 	if (pex_if >= MV_PEX_MAX_IF)
1451 		return 0xFFFFFFFF;
1452 
1453 	if (dev >= MAX_PEX_DEVICES) {
1454 		DEBUG_INIT_C("pex_cfg_read: ERR. device number illigal ", dev,
1455 			     1);
1456 		return 0xFFFFFFFF;
1457 	}
1458 
1459 	if (func >= MAX_PEX_FUNCS) {
1460 		DEBUG_INIT_C("pex_cfg_read: ERR. function num illigal ", func,
1461 			     1);
1462 		return 0xFFFFFFFF;
1463 	}
1464 
1465 	if (bus >= MAX_PEX_BUSSES) {
1466 		DEBUG_INIT_C("pex_cfg_read: ERR. bus number illigal ", bus, 1);
1467 		return MV_ERROR;
1468 	}
1469 	val = reg_read(PEX_STATUS_REG(pex_if));
1470 
1471 	local_dev =
1472 	    ((val & PXSR_PEX_DEV_NUM_MASK) >> PXSR_PEX_DEV_NUM_OFFS);
1473 	local_bus =
1474 	    ((val & PXSR_PEX_BUS_NUM_MASK) >> PXSR_PEX_BUS_NUM_OFFS);
1475 
1476 	/* Speed up the process. In case on no link, return MV_ERROR */
1477 	if ((dev != local_dev) || (bus != local_bus)) {
1478 		pex_data = reg_read(PEX_STATUS_REG(pex_if));
1479 
1480 		if ((pex_data & PXSR_DL_DOWN))
1481 			return MV_ERROR;
1482 	}
1483 
1484 	/*
1485 	 * In PCI Express we have only one device number
1486 	 * and this number is the first number we encounter else that the
1487 	 * local_dev spec pex define return on config read/write on any device
1488 	 */
1489 	if (bus == local_bus) {
1490 		if (local_dev == 0) {
1491 			/*
1492 			 * If local dev is 0 then the first number we encounter
1493 			 * after 0 is 1
1494 			 */
1495 			if ((dev != 1) && (dev != local_dev))
1496 				return MV_ERROR;
1497 		} else {
1498 			/*
1499 			 * If local dev is not 0 then the first number we
1500 			 * encounter is 0
1501 			 */
1502 			if ((dev != 0) && (dev != local_dev))
1503 				return MV_ERROR;
1504 		}
1505 	}
1506 
1507 	/* Creating PEX address to be passed */
1508 	pex_data = (bus << PXCAR_BUS_NUM_OFFS);
1509 	pex_data |= (dev << PXCAR_DEVICE_NUM_OFFS);
1510 	pex_data |= (func << PXCAR_FUNC_NUM_OFFS);
1511 	pex_data |= (offs & PXCAR_REG_NUM_MASK);	/* lgacy register space */
1512 	/* extended register space */
1513 	pex_data |= (((offs & PXCAR_REAL_EXT_REG_NUM_MASK) >>
1514 		     PXCAR_REAL_EXT_REG_NUM_OFFS) << PXCAR_EXT_REG_NUM_OFFS);
1515 
1516 	pex_data |= PXCAR_CONFIG_EN;
1517 
1518 	/* Write the address to the PEX configuration address register */
1519 	reg_write(PEX_CFG_ADDR_REG(pex_if), pex_data);
1520 
1521 	/*
1522 	 * In order to let the PEX controller absorbed the address of the read
1523 	 * transaction we perform a validity check that the address was written
1524 	 */
1525 	if (pex_data != reg_read(PEX_CFG_ADDR_REG(pex_if)))
1526 		return MV_ERROR;
1527 
1528 	/* cleaning Master Abort */
1529 	reg_bit_set(PEX_CFG_DIRECT_ACCESS(pex_if, PEX_STATUS_AND_COMMAND),
1530 		    PXSAC_MABORT);
1531 	/* Read the Data returned in the PEX Data register */
1532 	pex_data = reg_read(PEX_CFG_DATA_REG(pex_if));
1533 
1534 	DEBUG_INIT_FULL_C(" --> ", pex_data, 4);
1535 
1536 	return pex_data;
1537 }
1538 
1539 /*
1540  * pex_local_bus_num_set - Set PEX interface local bus number.
1541  *
1542  * DESCRIPTION:
1543  *       This function sets given PEX interface its local bus number.
1544  *       Note: In case the PEX interface is PEX-X, the information is read-only.
1545  *
1546  * INPUT:
1547  *       pex_if  - PEX interface number.
1548  *       bus_num - Bus number.
1549  *
1550  * OUTPUT:
1551  *       None.
1552  *
1553  * RETURN:
1554  *       MV_NOT_ALLOWED in case PEX interface is PEX-X.
1555  *		MV_BAD_PARAM on bad parameters ,
1556  *       otherwise MV_OK
1557  *
1558  */
pex_local_bus_num_set(u32 pex_if,u32 bus_num)1559 int pex_local_bus_num_set(u32 pex_if, u32 bus_num)
1560 {
1561 	u32 val;
1562 
1563 	if (bus_num >= MAX_PEX_BUSSES) {
1564 		DEBUG_INIT_C("pex_local_bus_num_set: ERR. bus number illigal %d\n",
1565 		     bus_num, 4);
1566 		return MV_ERROR;
1567 	}
1568 
1569 	val = reg_read(PEX_STATUS_REG(pex_if));
1570 	val &= ~PXSR_PEX_BUS_NUM_MASK;
1571 	val |= (bus_num << PXSR_PEX_BUS_NUM_OFFS) & PXSR_PEX_BUS_NUM_MASK;
1572 	reg_write(PEX_STATUS_REG(pex_if), val);
1573 
1574 	return MV_OK;
1575 }
1576 
1577 /*
1578  * pex_local_dev_num_set - Set PEX interface local device number.
1579  *
1580  * DESCRIPTION:
1581  *       This function sets given PEX interface its local device number.
1582  *       Note: In case the PEX interface is PEX-X, the information is read-only.
1583  *
1584  * INPUT:
1585  *       pex_if  - PEX interface number.
1586  *       dev_num - Device number.
1587  *
1588  * OUTPUT:
1589  *       None.
1590  *
1591  * RETURN:
1592  *       MV_NOT_ALLOWED in case PEX interface is PEX-X.
1593  *		MV_BAD_PARAM on bad parameters ,
1594  *       otherwise MV_OK
1595  *
1596  */
pex_local_dev_num_set(u32 pex_if,u32 dev_num)1597 int pex_local_dev_num_set(u32 pex_if, u32 dev_num)
1598 {
1599 	u32 val;
1600 
1601 	if (pex_if >= MV_PEX_MAX_IF)
1602 		return MV_BAD_PARAM;
1603 
1604 	val = reg_read(PEX_STATUS_REG(pex_if));
1605 	val &= ~PXSR_PEX_DEV_NUM_MASK;
1606 	val |= (dev_num << PXSR_PEX_DEV_NUM_OFFS) & PXSR_PEX_DEV_NUM_MASK;
1607 	reg_write(PEX_STATUS_REG(pex_if), val);
1608 
1609 	return MV_OK;
1610 }
1611