xref: /freebsd/sys/arm/nvidia/tegra_ahci.c (revision 315ee00f)
1 /*-
2  * Copyright (c) 2016 Michal Meloun <mmel@FreeBSD.org>
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24  * SUCH DAMAGE.
25  */
26 
27 #include <sys/cdefs.h>
28 /*
29  * AHCI driver for Tegra SoCs.
30  */
31 #include <sys/param.h>
32 #include <sys/module.h>
33 #include <sys/systm.h>
34 #include <sys/bus.h>
35 #include <sys/conf.h>
36 #include <sys/endian.h>
37 #include <sys/kernel.h>
38 #include <sys/lock.h>
39 #include <sys/malloc.h>
40 #include <sys/mutex.h>
41 #include <sys/rman.h>
42 
43 #include <machine/bus.h>
44 #include <machine/resource.h>
45 
46 #include <dev/ahci/ahci.h>
47 #include <dev/extres/clk/clk.h>
48 #include <dev/extres/hwreset/hwreset.h>
49 #include <dev/extres/phy/phy.h>
50 #include <dev/extres/regulator/regulator.h>
51 #include <dev/fdt/fdt_pinctrl.h>
52 #include <dev/ofw/ofw_bus.h>
53 #include <dev/ofw/ofw_bus_subr.h>
54 
55 #include <arm/nvidia/tegra_efuse.h>
56 #include <arm/nvidia/tegra_pmc.h>
57 
58 
59 #define	SATA_CONFIGURATION			0x180
60 #define  SATA_CONFIGURATION_CLK_OVERRIDE		(1U << 31)
61 #define	 SATA_CONFIGURATION_EN_FPCI			(1  <<  0)
62 
63 #define	SATA_FPCI_BAR5				0x94
64 #define	 SATA_FPCI_BAR_START(x)				(((x) & 0xFFFFFFF) << 4)
65 #define	 SATA_FPCI_BAR_ACCESS_TYPE			(1 << 0)
66 
67 #define	SATA_INTR_MASK				0x188
68 #define	SATA_INTR_MASK_IP_INT_MASK			(1 << 16)
69 
70 #define	SCFG_OFFSET				0x1000
71 
72 #define	T_SATA0_CFG_1				0x04
73 #define	 T_SATA0_CFG_1_IO_SPACE				(1 << 0)
74 #define	 T_SATA0_CFG_1_MEMORY_SPACE			(1 << 1)
75 #define	 T_SATA0_CFG_1_BUS_MASTER			(1 << 2)
76 #define	 T_SATA0_CFG_1_SERR				(1 << 8)
77 
78 #define	T_SATA0_CFG_9				0x24
79 #define	 T_SATA0_CFG_9_BASE_ADDRESS_SHIFT		13
80 
81 #define	T_SATA0_CFG_35				0x94
82 #define	 T_SATA0_CFG_35_IDP_INDEX_MASK			(0x7ff << 2)
83 #define	 T_SATA0_CFG_35_IDP_INDEX			(0x2a << 2)
84 
85 #define	T_SATA0_AHCI_IDP1			0x98
86 #define	 T_SATA0_AHCI_IDP1_DATA				0x400040
87 
88 #define	T_SATA0_CFG_PHY_1			0x12c
89 #define	 T_SATA0_CFG_PHY_1_PADS_IDDQ_EN			(1 << 23)
90 #define	 T_SATA0_CFG_PHY_1_PAD_PLL_IDDQ_EN		(1 << 22)
91 
92 #define	T_SATA0_NVOOB				0x114
93 #define	 T_SATA0_NVOOB_SQUELCH_FILTER_LENGTH_MASK	(0x3 << 26)
94 #define	 T_SATA0_NVOOB_SQUELCH_FILTER_LENGTH		(0x3 << 26)
95 #define	 T_SATA0_NVOOB_SQUELCH_FILTER_MODE_MASK		(0x3 << 24)
96 #define	 T_SATA0_NVOOB_SQUELCH_FILTER_MODE		(0x1 << 24)
97 #define	 T_SATA0_NVOOB_COMMA_CNT_MASK			(0xff << 16)
98 #define	 T_SATA0_NVOOB_COMMA_CNT			(0x07 << 16)
99 
100 #define	T_SATA0_CFG_PHY				0x120
101 #define	 T_SATA0_CFG_PHY_MASK_SQUELCH			(1 << 24)
102 #define	 T_SATA0_CFG_PHY_USE_7BIT_ALIGN_DET_FOR_SPD	(1 << 11)
103 
104 #define	T_SATA0_CFG2NVOOB_2			0x134
105 #define	 T_SATA0_CFG2NVOOB_2_COMWAKE_IDLE_CNT_LOW_MASK	(0x1ff << 18)
106 #define	 T_SATA0_CFG2NVOOB_2_COMWAKE_IDLE_CNT_LOW	(0xc << 18)
107 
108 #define	T_SATA0_AHCI_HBA_CAP_BKDR		0x300
109 #define	 T_SATA0_AHCI_HBA_CAP_BKDR_SNCQ			(1 << 30)
110 #define	 T_SATA0_AHCI_HBA_CAP_BKDR_SUPP_PM		(1 << 17)
111 #define	 T_SATA0_AHCI_HBA_CAP_BKDR_SALP			(1 << 26)
112 #define	 T_SATA0_AHCI_HBA_CAP_BKDR_SLUMBER_ST_CAP	(1 << 14)
113 #define	 T_SATA0_AHCI_HBA_CAP_BKDR_PARTIAL_ST_CAP	(1 << 13)
114 
115 #define	T_SATA0_BKDOOR_CC			0x4a4
116 #define	 T_SATA0_BKDOOR_CC_CLASS_CODE_MASK		(0xffff << 16)
117 #define	 T_SATA0_BKDOOR_CC_CLASS_CODE			(0x0106 << 16)
118 #define	 T_SATA0_BKDOOR_CC_PROG_IF_MASK			(0xff << 8)
119 #define	 T_SATA0_BKDOOR_CC_PROG_IF			(0x01 << 8)
120 
121 #define	T_SATA0_CFG_SATA			0x54c
122 #define	 T_SATA0_CFG_SATA_BACKDOOR_PROG_IF_EN		(1 << 12)
123 
124 #define	T_SATA0_CFG_MISC			0x550
125 #define	T_SATA0_INDEX				0x680
126 
127 #define	T_SATA0_CHX_PHY_CTRL1_GEN1		0x690
128 #define	 T_SATA0_CHX_PHY_CTRL1_GEN1_TX_PEAK_MASK	0xff
129 #define	 T_SATA0_CHX_PHY_CTRL1_GEN1_TX_PEAK_SHIFT	8
130 #define	 T_SATA0_CHX_PHY_CTRL1_GEN1_TX_AMP_MASK		0xff
131 #define	 T_SATA0_CHX_PHY_CTRL1_GEN1_TX_AMP_SHIFT	0
132 
133 #define	T_SATA0_CHX_PHY_CTRL1_GEN2		0x694
134 #define	 T_SATA0_CHX_PHY_CTRL1_GEN2_TX_PEAK_MASK	0xff
135 #define	 T_SATA0_CHX_PHY_CTRL1_GEN2_TX_PEAK_SHIFT	12
136 #define	 T_SATA0_CHX_PHY_CTRL1_GEN2_TX_AMP_MASK		0xff
137 #define	 T_SATA0_CHX_PHY_CTRL1_GEN2_TX_AMP_SHIFT	0
138 
139 #define	T_SATA0_CHX_PHY_CTRL2			0x69c
140 #define	 T_SATA0_CHX_PHY_CTRL2_CDR_CNTL_GEN1		0x23
141 
142 #define	T_SATA0_CHX_PHY_CTRL11			0x6d0
143 #define	 T_SATA0_CHX_PHY_CTRL11_GEN2_RX_EQ		(0x2800 << 16)
144 
145 #define T_SATA0_CHX_PHY_CTRL17			0x6e8
146 #define T_SATA0_CHX_PHY_CTRL18			0x6ec
147 #define T_SATA0_CHX_PHY_CTRL20			0x6f4
148 #define T_SATA0_CHX_PHY_CTRL21			0x6f8
149 
150 #define	FUSE_SATA_CALIB				0x124
151 #define	FUSE_SATA_CALIB_MASK			0x3
152 
153 #define	SATA_AUX_MISC_CNTL			0x1108
154 #define	SATA_AUX_PAD_PLL_CTRL_0			0x1120
155 #define	SATA_AUX_PAD_PLL_CTRL_1			0x1124
156 #define	SATA_AUX_PAD_PLL_CTRL_2			0x1128
157 #define	SATA_AUX_PAD_PLL_CTRL_3			0x112c
158 
159 #define	T_AHCI_HBA_CCC_PORTS			0x0018
160 #define	T_AHCI_HBA_CAP_BKDR			0x00A0
161 #define	 T_AHCI_HBA_CAP_BKDR_S64A			(1 << 31)
162 #define	 T_AHCI_HBA_CAP_BKDR_SNCQ			(1 << 30)
163 #define	 T_AHCI_HBA_CAP_BKDR_SSNTF			(1 << 29)
164 #define	 T_AHCI_HBA_CAP_BKDR_SMPS			(1 << 28)
165 #define	 T_AHCI_HBA_CAP_BKDR_SUPP_STG_SPUP		(1 << 27)
166 #define	 T_AHCI_HBA_CAP_BKDR_SALP			(1 << 26)
167 #define	 T_AHCI_HBA_CAP_BKDR_SAL			(1 << 25)
168 #define	 T_AHCI_HBA_CAP_BKDR_SUPP_CLO			(1 << 24)
169 #define	 T_AHCI_HBA_CAP_BKDR_INTF_SPD_SUPP(x)		(((x) & 0xF) << 20)
170 #define	 T_AHCI_HBA_CAP_BKDR_SUPP_NONZERO_OFFSET	(1 << 19)
171 #define	 T_AHCI_HBA_CAP_BKDR_SUPP_AHCI_ONLY		(1 << 18)
172 #define	 T_AHCI_HBA_CAP_BKDR_SUPP_PM			(1 << 17)
173 #define	 T_AHCI_HBA_CAP_BKDR_FIS_SWITCHING		(1 << 16)
174 #define	 T_AHCI_HBA_CAP_BKDR_PIO_MULT_DRQ_BLK		(1 << 15)
175 #define	 T_AHCI_HBA_CAP_BKDR_SLUMBER_ST_CAP		(1 << 14)
176 #define	 T_AHCI_HBA_CAP_BKDR_PARTIAL_ST_CAP		(1 << 13)
177 #define	 T_AHCI_HBA_CAP_BKDR_NUM_CMD_SLOTS(x)		(((x) & 0x1F) <<  8)
178 #define	 T_AHCI_HBA_CAP_BKDR_CMD_CMPL_COALESING		(1 <<  7)
179 #define	 T_AHCI_HBA_CAP_BKDR_ENCL_MGMT_SUPP		(1 <<  6)
180 #define	 T_AHCI_HBA_CAP_BKDR_EXT_SATA			(1 <<  5)
181 #define	 T_AHCI_HBA_CAP_BKDR_NUM_PORTS(x)		(((x) & 0xF) <<  0)
182 
183 #define	T_AHCI_PORT_BKDR			0x0170
184 
185 #define	 T_AHCI_PORT_BKDR_PXDEVSLP_DETO_OVERRIDE_VAL(x)	(((x) & 0xFF) << 24)
186 #define	 T_AHCI_PORT_BKDR_PXDEVSLP_MDAT_OVERRIDE_VAL(x)	(((x) & 0x1F) << 16)
187 #define	 T_AHCI_PORT_BKDR_PXDEVSLP_DETO_OVERRIDE	(1 << 15)
188 #define	 T_AHCI_PORT_BKDR_PXDEVSLP_MDAT_OVERRIDE	(1 << 14)
189 #define	 T_AHCI_PORT_BKDR_PXDEVSLP_DM(x)		(((x) & 0xF) << 10)
190 #define	 T_AHCI_PORT_BKDR_PORT_UNCONNECTED		(1 <<  9)
191 #define	 T_AHCI_PORT_BKDR_CLK_CLAMP_CTRL_CLAMP_THIS_CH	(1 <<  8)
192 #define	 T_AHCI_PORT_BKDR_CLK_CLAMP_CTRL_TXRXCLK_UNCLAMP (1 <<  7)
193 #define	 T_AHCI_PORT_BKDR_CLK_CLAMP_CTRL_TXRXCLK_CLAMP	(1 <<  6)
194 #define	 T_AHCI_PORT_BKDR_CLK_CLAMP_CTRL_DEVCLK_UNCLAMP	(1 <<  5)
195 #define	 T_AHCI_PORT_BKDR_CLK_CLAMP_CTRL_DEVCLK_CLAMP	(1 <<  4)
196 #define	 T_AHCI_PORT_BKDR_HOTPLUG_CAP			(1 <<  3)
197 #define	 T_AHCI_PORT_BKDR_MECH_SWITCH			(1 <<  2)
198 #define	 T_AHCI_PORT_BKDR_COLD_PRSN_DET			(1 <<  1)
199 #define	 T_AHCI_PORT_BKDR_EXT_SATA_SUPP			(1 <<  0)
200 
201 /* AUX registers */
202 #define	SATA_AUX_MISC_CNTL_1			0x008
203 #define	 SATA_AUX_MISC_CNTL_1_DEVSLP_OVERRIDE		(1 << 17)
204 #define	 SATA_AUX_MISC_CNTL_1_SDS_SUPPORT		(1 << 13)
205 #define	 SATA_AUX_MISC_CNTL_1_DESO_SUPPORT		(1 << 15)
206 
207 #define	AHCI_WR4(_sc, _r, _v)	bus_write_4((_sc)->ctlr.r_mem, (_r), (_v))
208 #define	AHCI_RD4(_sc, _r)	bus_read_4((_sc)->ctlr.r_mem, (_r))
209 #define	SATA_WR4(_sc, _r, _v)	bus_write_4((_sc)->sata_mem, (_r), (_v))
210 #define	SATA_RD4(_sc, _r)	bus_read_4((_sc)->sata_mem, (_r))
211 
212 struct sata_pad_calibration {
213 	uint32_t gen1_tx_amp;
214 	uint32_t gen1_tx_peak;
215 	uint32_t gen2_tx_amp;
216 	uint32_t gen2_tx_peak;
217 };
218 
219 static const struct sata_pad_calibration tegra124_pad_calibration[] = {
220 	{0x18, 0x04, 0x18, 0x0a},
221 	{0x0e, 0x04, 0x14, 0x0a},
222 	{0x0e, 0x07, 0x1a, 0x0e},
223 	{0x14, 0x0e, 0x1a, 0x0e},
224 };
225 
226 struct ahci_soc;
227 struct tegra_ahci_sc {
228 	struct ahci_controller	ctlr;	/* Must be first */
229 	device_t		dev;
230 	struct ahci_soc		*soc;
231 	struct resource		*sata_mem;
232 	struct resource		*aux_mem;
233 	clk_t			clk_sata;
234 	clk_t			clk_sata_oob;
235 	clk_t			clk_pll_e;
236 	clk_t			clk_cml;
237 	hwreset_t		hwreset_sata;
238 	hwreset_t		hwreset_sata_oob;
239 	hwreset_t		hwreset_sata_cold;
240 	regulator_t		regulators[16];		/* Safe maximum */
241 	phy_t			phy;
242 };
243 
244 struct ahci_soc {
245 	char 	**regulator_names;
246 	int	(*init)(struct tegra_ahci_sc *sc);
247 };
248 
249 /* Tegra 124 config. */
250 static char *tegra124_reg_names[] = {
251 	"hvdd-supply",
252 	"vddio-supply",
253 	"avdd-supply",
254 	"target-5v-supply",
255 	"target-12v-supply",
256 	NULL
257 };
258 
259 static int tegra124_ahci_init(struct tegra_ahci_sc *sc);
260 static struct ahci_soc tegra124_soc = {
261 	.regulator_names = tegra124_reg_names,
262 	.init = tegra124_ahci_init,
263 };
264 
265 /* Tegra 210 config. */
266 static char *tegra210_reg_names[] = {
267 	NULL
268 };
269 
270 static struct ahci_soc tegra210_soc = {
271 	.regulator_names = tegra210_reg_names,
272 };
273 
274 
275 static struct ofw_compat_data compat_data[] = {
276 	{"nvidia,tegra124-ahci", (uintptr_t)&tegra124_soc},
277 	{"nvidia,tegra210-ahci", (uintptr_t)&tegra210_soc},
278 	{NULL,			0}
279 };
280 
281 static int
282 get_fdt_resources(struct tegra_ahci_sc *sc, phandle_t node)
283 {
284 	int i, rv;
285 
286 	/* Regulators. */
287 	for (i = 0; sc->soc->regulator_names[i] != NULL; i++) {
288 		if (i >= nitems(sc->regulators)) {
289 			device_printf(sc->dev,
290 			    "Too many regulators present in DT.\n");
291 			return (EOVERFLOW);
292 		}
293 		rv = regulator_get_by_ofw_property(sc->dev, 0,
294 		    sc->soc->regulator_names[i], sc->regulators + i);
295 		if (rv != 0) {
296 			device_printf(sc->dev,
297 			    "Cannot get '%s' regulator\n",
298 			    sc->soc->regulator_names[i]);
299 			return (ENXIO);
300 		}
301 	}
302 
303 	/* Resets. */
304 	rv = hwreset_get_by_ofw_name(sc->dev, 0, "sata", &sc->hwreset_sata );
305 	if (rv != 0) {
306 		device_printf(sc->dev, "Cannot get 'sata' reset\n");
307 		return (ENXIO);
308 	}
309 	rv = hwreset_get_by_ofw_name(sc->dev, 0, "sata-oob",
310 	    &sc->hwreset_sata_oob);
311 	if (rv != 0) {
312 		device_printf(sc->dev, "Cannot get 'sata oob' reset\n");
313 		return (ENXIO);
314 	}
315 	rv = hwreset_get_by_ofw_name(sc->dev, 0, "sata-cold",
316 	    &sc->hwreset_sata_cold);
317 	if (rv != 0) {
318 		device_printf(sc->dev, "Cannot get 'sata cold' reset\n");
319 		return (ENXIO);
320 	}
321 
322 	/* Phy */
323 	rv = phy_get_by_ofw_name(sc->dev, 0, "sata-0", &sc->phy);
324 	if (rv != 0) {
325 		rv = phy_get_by_ofw_idx(sc->dev, 0, 0, &sc->phy);
326 		if (rv != 0) {
327 			device_printf(sc->dev, "Cannot get 'sata' phy\n");
328 			return (ENXIO);
329 		}
330 	}
331 
332 	/* Clocks. */
333 	rv = clk_get_by_ofw_name(sc->dev, 0, "sata", &sc->clk_sata);
334 	if (rv != 0) {
335 		device_printf(sc->dev, "Cannot get 'sata' clock\n");
336 		return (ENXIO);
337 	}
338 	rv = clk_get_by_ofw_name(sc->dev, 0, "sata-oob", &sc->clk_sata_oob);
339 	if (rv != 0) {
340 		device_printf(sc->dev, "Cannot get 'sata oob' clock\n");
341 		return (ENXIO);
342 	}
343 	/* These are optional */
344 	rv = clk_get_by_ofw_name(sc->dev, 0, "cml1", &sc->clk_cml);
345 	if (rv != 0)
346 		sc->clk_cml = NULL;
347 
348 	rv = clk_get_by_ofw_name(sc->dev, 0, "pll_e", &sc->clk_pll_e);
349 	if (rv != 0)
350 		sc->clk_pll_e = NULL;
351 	return (0);
352 }
353 
354 static int
355 enable_fdt_resources(struct tegra_ahci_sc *sc)
356 {
357 	int i, rv;
358 
359 	/* Enable regulators. */
360 	for (i = 0; i < nitems(sc->regulators); i++) {
361 		if (sc->regulators[i] == NULL)
362 			continue;
363 		rv = regulator_enable(sc->regulators[i]);
364 		if (rv != 0) {
365 			device_printf(sc->dev,
366 			    "Cannot enable '%s' regulator\n",
367 			    sc->soc->regulator_names[i]);
368 			return (rv);
369 		}
370 	}
371 
372 	/* Stop clocks */
373 	clk_stop(sc->clk_sata);
374 	clk_stop(sc->clk_sata_oob);
375 	tegra_powergate_power_off(TEGRA_POWERGATE_SAX);
376 
377 	rv = hwreset_assert(sc->hwreset_sata);
378 	if (rv != 0) {
379 		device_printf(sc->dev, "Cannot assert 'sata' reset\n");
380 		return (rv);
381 	}
382 	rv = hwreset_assert(sc->hwreset_sata_oob);
383 	if (rv != 0) {
384 		device_printf(sc->dev, "Cannot assert 'sata oob' reset\n");
385 		return (rv);
386 	}
387 
388 	rv = hwreset_assert(sc->hwreset_sata_cold);
389 	if (rv != 0) {
390 		device_printf(sc->dev, "Cannot assert 'sata cold' reset\n");
391 		return (rv);
392 	}
393 	rv = tegra_powergate_sequence_power_up(TEGRA_POWERGATE_SAX,
394 	    sc->clk_sata, sc->hwreset_sata);
395 	if (rv != 0) {
396 		device_printf(sc->dev, "Cannot enable 'SAX' powergate\n");
397 		return (rv);
398 	}
399 
400 	rv = clk_enable(sc->clk_sata_oob);
401 	if (rv != 0) {
402 		device_printf(sc->dev, "Cannot enable 'sata oob' clock\n");
403 		return (rv);
404 	}
405 	if (sc->clk_cml != NULL) {
406 		rv = clk_enable(sc->clk_cml);
407 		if (rv != 0) {
408 			device_printf(sc->dev, "Cannot enable 'cml' clock\n");
409 			return (rv);
410 		}
411 	}
412 	if (sc->clk_pll_e != NULL) {
413 		rv = clk_enable(sc->clk_pll_e);
414 		if (rv != 0) {
415 			device_printf(sc->dev, "Cannot enable 'pll e' clock\n");
416 			return (rv);
417 		}
418 	}
419 
420 	rv = hwreset_deassert(sc->hwreset_sata_cold);
421 	if (rv != 0) {
422 		device_printf(sc->dev, "Cannot unreset 'sata cold' reset\n");
423 		return (rv);
424 	}
425 	rv = hwreset_deassert(sc->hwreset_sata_oob);
426 	if (rv != 0) {
427 		device_printf(sc->dev, "Cannot unreset 'sata oob' reset\n");
428 		return (rv);
429 	}
430 
431 	rv = phy_enable(sc->phy);
432 	if (rv != 0) {
433 		device_printf(sc->dev, "Cannot enable SATA phy\n");
434 		return (rv);
435 	}
436 
437 	return (0);
438 }
439 
440 static int
441 tegra124_ahci_init(struct tegra_ahci_sc *sc)
442 {
443 	uint32_t val;
444 	const struct sata_pad_calibration *calib;
445 
446 	/* Pad calibration. */
447 	val = tegra_fuse_read_4(FUSE_SATA_CALIB);
448 	calib = tegra124_pad_calibration + (val & FUSE_SATA_CALIB_MASK);
449 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_INDEX, 1);
450 
451 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_CHX_PHY_CTRL1_GEN1);
452 	val &= ~(T_SATA0_CHX_PHY_CTRL1_GEN1_TX_AMP_MASK <<
453 	    T_SATA0_CHX_PHY_CTRL1_GEN1_TX_AMP_SHIFT);
454 	val &= ~(T_SATA0_CHX_PHY_CTRL1_GEN1_TX_PEAK_MASK <<
455 	    T_SATA0_CHX_PHY_CTRL1_GEN1_TX_PEAK_SHIFT);
456 	val |= calib->gen1_tx_amp << T_SATA0_CHX_PHY_CTRL1_GEN1_TX_AMP_SHIFT;
457 	val |= calib->gen1_tx_peak << T_SATA0_CHX_PHY_CTRL1_GEN1_TX_PEAK_SHIFT;
458 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CHX_PHY_CTRL1_GEN1, val);
459 
460 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_CHX_PHY_CTRL1_GEN2);
461 	val &= ~(T_SATA0_CHX_PHY_CTRL1_GEN2_TX_AMP_MASK <<
462 	    T_SATA0_CHX_PHY_CTRL1_GEN2_TX_AMP_SHIFT);
463 	val &= ~(T_SATA0_CHX_PHY_CTRL1_GEN2_TX_PEAK_MASK <<
464 	    T_SATA0_CHX_PHY_CTRL1_GEN2_TX_PEAK_SHIFT);
465 	val |= calib->gen2_tx_amp << T_SATA0_CHX_PHY_CTRL1_GEN2_TX_AMP_SHIFT;
466 	val |= calib->gen2_tx_peak << T_SATA0_CHX_PHY_CTRL1_GEN2_TX_PEAK_SHIFT;
467 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CHX_PHY_CTRL1_GEN2, val);
468 
469 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CHX_PHY_CTRL11,
470 	    T_SATA0_CHX_PHY_CTRL11_GEN2_RX_EQ);
471 
472 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CHX_PHY_CTRL2,
473 	    T_SATA0_CHX_PHY_CTRL2_CDR_CNTL_GEN1);
474 
475 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_INDEX, 0);
476 
477 	return (0);
478 }
479 
480 static int
481 tegra_ahci_ctrl_init(struct tegra_ahci_sc *sc)
482 {
483 	uint32_t val;
484 	int rv;
485 
486 	/* Enable SATA MMIO. */
487 	val = SATA_RD4(sc, SATA_FPCI_BAR5);
488 	val &= ~SATA_FPCI_BAR_START(~0);
489 	val |= SATA_FPCI_BAR_START(0x10000);
490 	val |= SATA_FPCI_BAR_ACCESS_TYPE;
491 	SATA_WR4(sc, SATA_FPCI_BAR5, val);
492 
493 	/* Enable FPCI access */
494 	val = SATA_RD4(sc, SATA_CONFIGURATION);
495 	val |= SATA_CONFIGURATION_EN_FPCI;
496 	SATA_WR4(sc, SATA_CONFIGURATION, val);
497 
498 	/* Recommended electrical settings for phy */
499 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CHX_PHY_CTRL17, 0x55010000);
500 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CHX_PHY_CTRL18, 0x55010000);
501 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CHX_PHY_CTRL20, 0x1);
502 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CHX_PHY_CTRL21, 0x1);
503 
504 	/* SQUELCH and Gen3 */
505 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_CFG_PHY);
506 	val |= T_SATA0_CFG_PHY_MASK_SQUELCH;
507 	val &= ~T_SATA0_CFG_PHY_USE_7BIT_ALIGN_DET_FOR_SPD;
508 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CFG_PHY, val);
509 
510 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_NVOOB);
511 	val &= ~T_SATA0_NVOOB_COMMA_CNT_MASK;
512 	val &= ~T_SATA0_NVOOB_SQUELCH_FILTER_LENGTH_MASK;
513 	val &= ~T_SATA0_NVOOB_SQUELCH_FILTER_MODE_MASK;
514 	val |= T_SATA0_NVOOB_COMMA_CNT;
515 	val |= T_SATA0_NVOOB_SQUELCH_FILTER_LENGTH;
516 	val |= T_SATA0_NVOOB_SQUELCH_FILTER_MODE;
517 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_NVOOB, val);
518 
519 	 /* Setup COMWAKE_IDLE_CNT */
520 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_CFG2NVOOB_2);
521 	val &= ~T_SATA0_CFG2NVOOB_2_COMWAKE_IDLE_CNT_LOW_MASK;
522 	val |= T_SATA0_CFG2NVOOB_2_COMWAKE_IDLE_CNT_LOW;
523 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CFG2NVOOB_2, val);
524 
525 	if (sc->soc->init != NULL) {
526 		rv = sc->soc->init(sc);
527 		if (rv != 0) {
528 			device_printf(sc->dev,
529 			    "SOC specific intialization failed: %d\n", rv);
530 			return (rv);
531 		}
532 	}
533 
534 	/* Enable backdoor programming. */
535 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_CFG_SATA);
536 	val |= T_SATA0_CFG_SATA_BACKDOOR_PROG_IF_EN;
537 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CFG_SATA, val);
538 
539 	/* Set device class and interface */
540 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_BKDOOR_CC);
541 	val &= ~T_SATA0_BKDOOR_CC_CLASS_CODE_MASK;
542 	val &= ~T_SATA0_BKDOOR_CC_PROG_IF_MASK;
543 	val |= T_SATA0_BKDOOR_CC_CLASS_CODE;
544 	val |= T_SATA0_BKDOOR_CC_PROG_IF;
545 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_BKDOOR_CC, val);
546 
547 	/* Enable LPM capabilities  */
548 	val = SATA_RD4(sc, SCFG_OFFSET +  T_SATA0_AHCI_HBA_CAP_BKDR);
549 	val |= T_SATA0_AHCI_HBA_CAP_BKDR_PARTIAL_ST_CAP;
550 	val |= T_SATA0_AHCI_HBA_CAP_BKDR_SLUMBER_ST_CAP;
551 	val |= T_SATA0_AHCI_HBA_CAP_BKDR_SALP;
552 	val |= T_SATA0_AHCI_HBA_CAP_BKDR_SUPP_PM;
553 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_AHCI_HBA_CAP_BKDR, val);
554 
555 	/* Disable backdoor programming. */
556 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_CFG_SATA);
557 	val &= ~T_SATA0_CFG_SATA_BACKDOOR_PROG_IF_EN;
558 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CFG_SATA, val);
559 
560 	/* SATA Second Level Clock Gating */
561 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_CFG_35);
562 	val &= ~T_SATA0_CFG_35_IDP_INDEX_MASK;
563 	val |= T_SATA0_CFG_35_IDP_INDEX;
564 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CFG_35, val);
565 
566 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_AHCI_IDP1, 0x400040);
567 
568 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_CFG_PHY_1);
569 	val |= T_SATA0_CFG_PHY_1_PADS_IDDQ_EN;
570 	val |= T_SATA0_CFG_PHY_1_PAD_PLL_IDDQ_EN;
571 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CFG_PHY_1, val);
572 
573 	/*
574 	 * Indicate Sata only has the capability to enter DevSleep
575 	 * from slumber link.
576 	 */
577 	if (sc->aux_mem != NULL) {
578 		val = bus_read_4(sc->aux_mem, SATA_AUX_MISC_CNTL_1);
579 		val |= SATA_AUX_MISC_CNTL_1_DESO_SUPPORT;
580 		bus_write_4(sc->aux_mem, SATA_AUX_MISC_CNTL_1, val);
581 	}
582 
583 	/* Enable IPFS Clock Gating */
584 	val = SATA_RD4(sc, SCFG_OFFSET + SATA_CONFIGURATION);
585 	val &= ~SATA_CONFIGURATION_CLK_OVERRIDE;
586 	SATA_WR4(sc, SCFG_OFFSET + SATA_CONFIGURATION, val);
587 
588 
589 	/* Enable IO & memory access, bus master mode */
590 	val = SATA_RD4(sc, SCFG_OFFSET + T_SATA0_CFG_1);
591 	val |= T_SATA0_CFG_1_IO_SPACE;
592 	val |= T_SATA0_CFG_1_MEMORY_SPACE;
593 	val |= T_SATA0_CFG_1_BUS_MASTER;
594 	val |= T_SATA0_CFG_1_SERR;
595 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CFG_1, val);
596 
597 	/* AHCI bar */
598 	SATA_WR4(sc, SCFG_OFFSET + T_SATA0_CFG_9,
599 	    0x08000 << T_SATA0_CFG_9_BASE_ADDRESS_SHIFT);
600 
601 	/* Unmask  interrupts. */
602 	val = SATA_RD4(sc, SATA_INTR_MASK);
603 	val |= SATA_INTR_MASK_IP_INT_MASK;
604 	SATA_WR4(sc, SATA_INTR_MASK, val);
605 
606 	return (0);
607 }
608 
609 static int
610 tegra_ahci_ctlr_reset(device_t dev)
611 {
612 	struct tegra_ahci_sc *sc;
613 	int rv;
614 	uint32_t reg;
615 
616 	sc = device_get_softc(dev);
617 	rv = ahci_ctlr_reset(dev);
618 	if (rv != 0)
619 		return (0);
620 	AHCI_WR4(sc, T_AHCI_HBA_CCC_PORTS, 1);
621 
622 	/* Overwrite AHCI capabilites. */
623 	reg  = AHCI_RD4(sc, T_AHCI_HBA_CAP_BKDR);
624 	reg &= ~T_AHCI_HBA_CAP_BKDR_NUM_PORTS(~0);
625 	reg |= T_AHCI_HBA_CAP_BKDR_NUM_PORTS(0);
626 	reg |= T_AHCI_HBA_CAP_BKDR_EXT_SATA;
627 	reg |= T_AHCI_HBA_CAP_BKDR_CMD_CMPL_COALESING;
628 	reg |= T_AHCI_HBA_CAP_BKDR_FIS_SWITCHING;
629 	reg |= T_AHCI_HBA_CAP_BKDR_SUPP_PM;
630 	reg |= T_AHCI_HBA_CAP_BKDR_SUPP_CLO;
631 	reg |= T_AHCI_HBA_CAP_BKDR_SUPP_STG_SPUP;
632 	AHCI_WR4(sc, T_AHCI_HBA_CAP_BKDR, reg);
633 
634 	/* Overwrite AHCI portcapabilites. */
635 	reg  = AHCI_RD4(sc, T_AHCI_PORT_BKDR);
636 	reg |= T_AHCI_PORT_BKDR_COLD_PRSN_DET;
637 	reg |= T_AHCI_PORT_BKDR_HOTPLUG_CAP;
638 	reg |= T_AHCI_PORT_BKDR_EXT_SATA_SUPP;
639 	AHCI_WR4(sc, T_AHCI_PORT_BKDR, reg);
640 
641 	return (0);
642 }
643 
644 static int
645 tegra_ahci_probe(device_t dev)
646 {
647 
648 	if (!ofw_bus_status_okay(dev))
649 		return (ENXIO);
650 
651 	if (!ofw_bus_search_compatible(dev, compat_data)->ocd_data)
652 		return (ENXIO);
653 
654 	device_set_desc_copy(dev, "AHCI SATA controller");
655 	return (BUS_PROBE_DEFAULT);
656 }
657 
658 static int
659 tegra_ahci_attach(device_t dev)
660 {
661 	struct tegra_ahci_sc *sc;
662 	struct ahci_controller *ctlr;
663 	phandle_t node;
664 	int rv, rid;
665 
666 	sc = device_get_softc(dev);
667 	sc->dev = dev;
668 	ctlr = &sc->ctlr;
669 	node = ofw_bus_get_node(dev);
670 	sc->soc = (struct ahci_soc *)ofw_bus_search_compatible(dev,
671 	    compat_data)->ocd_data;
672 
673 	ctlr->r_rid = 0;
674 	ctlr->r_mem = bus_alloc_resource_any(dev, SYS_RES_MEMORY,
675 	    &ctlr->r_rid, RF_ACTIVE);
676 	if (ctlr->r_mem == NULL)
677 		return (ENXIO);
678 
679 	rid = 1;
680 	sc->sata_mem = bus_alloc_resource_any(dev, SYS_RES_MEMORY,
681 	    &rid, RF_ACTIVE);
682 	if (sc->sata_mem == NULL) {
683 		rv = ENXIO;
684 		goto fail;
685 	}
686 
687 	/* Aux is optionall */
688 	rid = 2;
689 	sc->aux_mem = bus_alloc_resource_any(dev, SYS_RES_MEMORY,
690 	    &rid, RF_ACTIVE);
691 
692 	rv = get_fdt_resources(sc, node);
693 	if (rv != 0) {
694 		device_printf(sc->dev, "Failed to allocate FDT resource(s)\n");
695 		goto fail;
696 	}
697 
698 	rv = enable_fdt_resources(sc);
699 	if (rv != 0) {
700 		device_printf(sc->dev, "Failed to enable FDT resource(s)\n");
701 		goto fail;
702 	}
703 	rv = tegra_ahci_ctrl_init(sc);
704 	if (rv != 0) {
705 		device_printf(sc->dev, "Failed to initialize controller)\n");
706 		goto fail;
707 	}
708 
709 	/* Setup controller defaults. */
710 	ctlr->msi = 0;
711 	ctlr->numirqs = 1;
712 	ctlr->ccc = 0;
713 
714 	/* Reset controller. */
715 	rv = tegra_ahci_ctlr_reset(dev);
716 	if (rv != 0)
717 		goto fail;
718 	rv = ahci_attach(dev);
719 	return (rv);
720 
721 fail:
722 	/* XXX FDT  stuff */
723 	if (sc->sata_mem != NULL)
724 		bus_release_resource(dev, SYS_RES_MEMORY, 1, sc->sata_mem);
725 	if (ctlr->r_mem != NULL)
726 		bus_release_resource(dev, SYS_RES_MEMORY, ctlr->r_rid,
727 		    ctlr->r_mem);
728 	return (rv);
729 }
730 
731 static int
732 tegra_ahci_detach(device_t dev)
733 {
734 
735 	ahci_detach(dev);
736 	return (0);
737 }
738 
739 static int
740 tegra_ahci_suspend(device_t dev)
741 {
742 	struct tegra_ahci_sc *sc = device_get_softc(dev);
743 
744 	bus_generic_suspend(dev);
745 	/* Disable interupts, so the state change(s) doesn't trigger. */
746 	ATA_OUTL(sc->ctlr.r_mem, AHCI_GHC,
747 	     ATA_INL(sc->ctlr.r_mem, AHCI_GHC) & (~AHCI_GHC_IE));
748 	return (0);
749 }
750 
751 static int
752 tegra_ahci_resume(device_t dev)
753 {
754 	int res;
755 
756 	if ((res = tegra_ahci_ctlr_reset(dev)) != 0)
757 		return (res);
758 	ahci_ctlr_setup(dev);
759 	return (bus_generic_resume(dev));
760 }
761 
762 static device_method_t tegra_ahci_methods[] = {
763 	DEVMETHOD(device_probe,		tegra_ahci_probe),
764 	DEVMETHOD(device_attach,	tegra_ahci_attach),
765 	DEVMETHOD(device_detach,	tegra_ahci_detach),
766 	DEVMETHOD(device_suspend,	tegra_ahci_suspend),
767 	DEVMETHOD(device_resume,	tegra_ahci_resume),
768 	DEVMETHOD(bus_print_child,	ahci_print_child),
769 	DEVMETHOD(bus_alloc_resource,	ahci_alloc_resource),
770 	DEVMETHOD(bus_release_resource,	ahci_release_resource),
771 	DEVMETHOD(bus_setup_intr,	ahci_setup_intr),
772 	DEVMETHOD(bus_teardown_intr,	ahci_teardown_intr),
773 	DEVMETHOD(bus_child_location,	ahci_child_location),
774 	DEVMETHOD(bus_get_dma_tag,	ahci_get_dma_tag),
775 
776 	DEVMETHOD_END
777 };
778 
779 static DEFINE_CLASS_0(ahci, tegra_ahci_driver, tegra_ahci_methods,
780     sizeof(struct tegra_ahci_sc));
781 DRIVER_MODULE(tegra_ahci, simplebus, tegra_ahci_driver, NULL, NULL);
782