phy-ti-pipe3.c 14.9 KB
Newer Older
1
/*
2
 * phy-ti-pipe3 - PIPE3 PHY driver.
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
 *
 * Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.com
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * Author: Kishon Vijay Abraham I <kishon@ti.com>
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 */

#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/slab.h>
22
#include <linux/phy/phy.h>
23 24 25
#include <linux/of.h>
#include <linux/clk.h>
#include <linux/err.h>
26
#include <linux/io.h>
27 28
#include <linux/pm_runtime.h>
#include <linux/delay.h>
29
#include <linux/phy/omap_control_phy.h>
30
#include <linux/of_platform.h>
31
#include <linux/spinlock.h>
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48

#define	PLL_STATUS		0x00000004
#define	PLL_GO			0x00000008
#define	PLL_CONFIGURATION1	0x0000000C
#define	PLL_CONFIGURATION2	0x00000010
#define	PLL_CONFIGURATION3	0x00000014
#define	PLL_CONFIGURATION4	0x00000020

#define	PLL_REGM_MASK		0x001FFE00
#define	PLL_REGM_SHIFT		0x9
#define	PLL_REGM_F_MASK		0x0003FFFF
#define	PLL_REGM_F_SHIFT	0x0
#define	PLL_REGN_MASK		0x000001FE
#define	PLL_REGN_SHIFT		0x1
#define	PLL_SELFREQDCO_MASK	0x0000000E
#define	PLL_SELFREQDCO_SHIFT	0x1
#define	PLL_SD_MASK		0x0003FC00
49
#define	PLL_SD_SHIFT		10
50
#define	SET_PLL_GO		0x1
51 52
#define PLL_LDOPWDN		BIT(15)
#define PLL_TICOPWDN		BIT(16)
53 54 55 56 57
#define	PLL_LOCK		0x2
#define	PLL_IDLE		0x1

/*
 * This is an Empirical value that works, need to confirm the actual
58 59
 * value required for the PIPE3PHY_PLL_CONFIGURATION2.PLL_IDLE status
 * to be correctly reflected in the PIPE3PHY_PLL_STATUS register.
60
 */
61 62
#define PLL_IDLE_TIME	100	/* in milliseconds */
#define PLL_LOCK_TIME	100	/* in milliseconds */
63

64 65 66 67 68 69 70 71
struct pipe3_dpll_params {
	u16	m;
	u8	n;
	u8	freq:3;
	u8	sd;
	u32	mf;
};

72 73 74 75 76
struct pipe3_dpll_map {
	unsigned long rate;
	struct pipe3_dpll_params params;
};

77 78 79 80 81 82
struct ti_pipe3 {
	void __iomem		*pll_ctrl_base;
	struct device		*dev;
	struct device		*control_dev;
	struct clk		*wkupclk;
	struct clk		*sys_clk;
83
	struct clk		*refclk;
84
	struct clk		*div_clk;
85
	struct pipe3_dpll_map	*dpll_map;
86 87
	bool			enabled;
	spinlock_t		lock;	/* serialize clock enable/disable */
88 89
	/* the below flag is needed specifically for SATA */
	bool			refclk_enabled;
90 91
};

92
static struct pipe3_dpll_map dpll_map_usb[] = {
93 94 95 96 97 98
	{12000000, {1250, 5, 4, 20, 0} },	/* 12 MHz */
	{16800000, {3125, 20, 4, 20, 0} },	/* 16.8 MHz */
	{19200000, {1172, 8, 4, 20, 65537} },	/* 19.2 MHz */
	{20000000, {1000, 7, 4, 10, 0} },	/* 20 MHz */
	{26000000, {1250, 12, 4, 20, 0} },	/* 26 MHz */
	{38400000, {3125, 47, 4, 20, 92843} },	/* 38.4 MHz */
99 100 101 102 103 104 105 106 107 108 109
	{ },					/* Terminator */
};

static struct pipe3_dpll_map dpll_map_sata[] = {
	{12000000, {1000, 7, 4, 6, 0} },	/* 12 MHz */
	{16800000, {714, 7, 4, 6, 0} },		/* 16.8 MHz */
	{19200000, {625, 7, 4, 6, 0} },		/* 19.2 MHz */
	{20000000, {600, 7, 4, 6, 0} },		/* 20 MHz */
	{26000000, {461, 7, 4, 6, 0} },		/* 26 MHz */
	{38400000, {312, 7, 4, 6, 0} },		/* 38.4 MHz */
	{ },					/* Terminator */
110 111
};

112 113 114 115 116 117 118 119 120 121 122
static inline u32 ti_pipe3_readl(void __iomem *addr, unsigned offset)
{
	return __raw_readl(addr + offset);
}

static inline void ti_pipe3_writel(void __iomem *addr, unsigned offset,
	u32 data)
{
	__raw_writel(data, addr + offset);
}

123
static struct pipe3_dpll_params *ti_pipe3_get_dpll_params(struct ti_pipe3 *phy)
124
{
125 126
	unsigned long rate;
	struct pipe3_dpll_map *dpll_map = phy->dpll_map;
127

128 129 130 131 132
	rate = clk_get_rate(phy->sys_clk);

	for (; dpll_map->rate; dpll_map++) {
		if (rate == dpll_map->rate)
			return &dpll_map->params;
133 134
	}

135 136
	dev_err(phy->dev, "No DPLL configuration for %lu Hz SYS CLK\n", rate);

137
	return NULL;
138 139
}

140 141 142 143
static int ti_pipe3_power_off(struct phy *x)
{
	struct ti_pipe3 *phy = phy_get_drvdata(x);

144
	omap_control_phy_power(phy->control_dev, 0);
145 146 147 148 149

	return 0;
}

static int ti_pipe3_power_on(struct phy *x)
150
{
151
	struct ti_pipe3 *phy = phy_get_drvdata(x);
152

153
	omap_control_phy_power(phy->control_dev, 1);
154 155 156 157

	return 0;
}

158
static int ti_pipe3_dpll_wait_lock(struct ti_pipe3 *phy)
159 160 161 162
{
	u32		val;
	unsigned long	timeout;

163
	timeout = jiffies + msecs_to_jiffies(PLL_LOCK_TIME);
164
	do {
165
		cpu_relax();
166
		val = ti_pipe3_readl(phy->pll_ctrl_base, PLL_STATUS);
167 168
		if (val & PLL_LOCK)
			break;
169 170 171 172 173 174 175 176
	} while (!time_after(jiffies, timeout));

	if (!(val & PLL_LOCK)) {
		dev_err(phy->dev, "DPLL failed to lock\n");
		return -EBUSY;
	}

	return 0;
177 178
}

179
static int ti_pipe3_dpll_program(struct ti_pipe3 *phy)
180 181
{
	u32			val;
182
	struct pipe3_dpll_params *dpll_params;
183

184 185
	dpll_params = ti_pipe3_get_dpll_params(phy);
	if (!dpll_params)
186 187
		return -EINVAL;

188
	val = ti_pipe3_readl(phy->pll_ctrl_base, PLL_CONFIGURATION1);
189
	val &= ~PLL_REGN_MASK;
190
	val |= dpll_params->n << PLL_REGN_SHIFT;
191
	ti_pipe3_writel(phy->pll_ctrl_base, PLL_CONFIGURATION1, val);
192

193
	val = ti_pipe3_readl(phy->pll_ctrl_base, PLL_CONFIGURATION2);
194
	val &= ~PLL_SELFREQDCO_MASK;
195
	val |= dpll_params->freq << PLL_SELFREQDCO_SHIFT;
196
	ti_pipe3_writel(phy->pll_ctrl_base, PLL_CONFIGURATION2, val);
197

198
	val = ti_pipe3_readl(phy->pll_ctrl_base, PLL_CONFIGURATION1);
199
	val &= ~PLL_REGM_MASK;
200
	val |= dpll_params->m << PLL_REGM_SHIFT;
201
	ti_pipe3_writel(phy->pll_ctrl_base, PLL_CONFIGURATION1, val);
202

203
	val = ti_pipe3_readl(phy->pll_ctrl_base, PLL_CONFIGURATION4);
204
	val &= ~PLL_REGM_F_MASK;
205
	val |= dpll_params->mf << PLL_REGM_F_SHIFT;
206
	ti_pipe3_writel(phy->pll_ctrl_base, PLL_CONFIGURATION4, val);
207

208
	val = ti_pipe3_readl(phy->pll_ctrl_base, PLL_CONFIGURATION3);
209
	val &= ~PLL_SD_MASK;
210
	val |= dpll_params->sd << PLL_SD_SHIFT;
211
	ti_pipe3_writel(phy->pll_ctrl_base, PLL_CONFIGURATION3, val);
212

213
	ti_pipe3_writel(phy->pll_ctrl_base, PLL_GO, SET_PLL_GO);
214

215
	return ti_pipe3_dpll_wait_lock(phy);
216 217
}

218
static int ti_pipe3_init(struct phy *x)
219
{
220
	struct ti_pipe3 *phy = phy_get_drvdata(x);
221 222
	u32 val;
	int ret = 0;
223

224 225 226 227 228
	/*
	 * Set pcie_pcs register to 0x96 for proper functioning of phy
	 * as recommended in AM572x TRM SPRUHZ6, section 18.5.2.2, table
	 * 18-1804.
	 */
229
	if (of_device_is_compatible(phy->dev->of_node, "ti,phy-pipe3-pcie")) {
230
		omap_control_pcie_pcs(phy->control_dev, 0x96);
231
		return 0;
232
	}
233

234 235 236 237 238 239 240
	/* Bring it out of IDLE if it is IDLE */
	val = ti_pipe3_readl(phy->pll_ctrl_base, PLL_CONFIGURATION2);
	if (val & PLL_IDLE) {
		val &= ~PLL_IDLE;
		ti_pipe3_writel(phy->pll_ctrl_base, PLL_CONFIGURATION2, val);
		ret = ti_pipe3_dpll_wait_lock(phy);
	}
241

242 243 244 245 246
	/* Program the DPLL only if not locked */
	val = ti_pipe3_readl(phy->pll_ctrl_base, PLL_STATUS);
	if (!(val & PLL_LOCK))
		if (ti_pipe3_dpll_program(phy))
			return -EINVAL;
247

248
	return ret;
249 250
}

251 252 253 254 255 256
static int ti_pipe3_exit(struct phy *x)
{
	struct ti_pipe3 *phy = phy_get_drvdata(x);
	u32 val;
	unsigned long timeout;

257 258 259 260 261
	/* SATA DPLL can't be powered down due to Errata i783 and PCIe
	 * does not have internal DPLL
	 */
	if (of_device_is_compatible(phy->dev->of_node, "ti,phy-pipe3-sata") ||
	    of_device_is_compatible(phy->dev->of_node, "ti,phy-pipe3-pcie"))
262 263
		return 0;

264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285
	/* Put DPLL in IDLE mode */
	val = ti_pipe3_readl(phy->pll_ctrl_base, PLL_CONFIGURATION2);
	val |= PLL_IDLE;
	ti_pipe3_writel(phy->pll_ctrl_base, PLL_CONFIGURATION2, val);

	/* wait for LDO and Oscillator to power down */
	timeout = jiffies + msecs_to_jiffies(PLL_IDLE_TIME);
	do {
		cpu_relax();
		val = ti_pipe3_readl(phy->pll_ctrl_base, PLL_STATUS);
		if ((val & PLL_TICOPWDN) && (val & PLL_LDOPWDN))
			break;
	} while (!time_after(jiffies, timeout));

	if (!(val & PLL_TICOPWDN) || !(val & PLL_LDOPWDN)) {
		dev_err(phy->dev, "Failed to power down: PLL_STATUS 0x%x\n",
			val);
		return -EBUSY;
	}

	return 0;
}
286 287
static struct phy_ops ops = {
	.init		= ti_pipe3_init,
288
	.exit		= ti_pipe3_exit,
289 290 291 292 293
	.power_on	= ti_pipe3_power_on,
	.power_off	= ti_pipe3_power_off,
	.owner		= THIS_MODULE,
};

294 295 296 297
#ifdef CONFIG_OF
static const struct of_device_id ti_pipe3_id_table[];
#endif

298
static int ti_pipe3_probe(struct platform_device *pdev)
299
{
300 301 302
	struct ti_pipe3 *phy;
	struct phy *generic_phy;
	struct phy_provider *phy_provider;
303 304 305 306
	struct resource *res;
	struct device_node *node = pdev->dev.of_node;
	struct device_node *control_node;
	struct platform_device *control_pdev;
307
	const struct of_device_id *match;
308
	struct clk *clk;
309 310

	phy = devm_kzalloc(&pdev->dev, sizeof(*phy), GFP_KERNEL);
311
	if (!phy)
312
		return -ENOMEM;
313

314
	phy->dev		= &pdev->dev;
315
	spin_lock_init(&phy->lock);
316

317 318 319 320 321
	if (!of_device_is_compatible(node, "ti,phy-pipe3-pcie")) {
		match = of_match_device(of_match_ptr(ti_pipe3_id_table),
					&pdev->dev);
		if (!match)
			return -EINVAL;
322

323 324 325 326 327
		phy->dpll_map = (struct pipe3_dpll_map *)match->data;
		if (!phy->dpll_map) {
			dev_err(&pdev->dev, "no DPLL data\n");
			return -EINVAL;
		}
328

329 330 331 332 333
		res = platform_get_resource_byname(pdev, IORESOURCE_MEM,
						   "pll_ctrl");
		phy->pll_ctrl_base = devm_ioremap_resource(&pdev->dev, res);
		if (IS_ERR(phy->pll_ctrl_base))
			return PTR_ERR(phy->pll_ctrl_base);
334

335 336 337 338 339 340
		phy->sys_clk = devm_clk_get(phy->dev, "sysclk");
		if (IS_ERR(phy->sys_clk)) {
			dev_err(&pdev->dev, "unable to get sysclk\n");
			return -EINVAL;
		}
	}
341

342 343 344 345 346 347 348 349 350 351
	phy->refclk = devm_clk_get(phy->dev, "refclk");
	if (IS_ERR(phy->refclk)) {
		dev_err(&pdev->dev, "unable to get refclk\n");
		/* older DTBs have missing refclk in SATA PHY
		 * so don't bail out in case of SATA PHY.
		 */
		if (!of_device_is_compatible(node, "ti,phy-pipe3-sata"))
			return PTR_ERR(phy->refclk);
	}

352
	if (!of_device_is_compatible(node, "ti,phy-pipe3-sata")) {
353 354 355 356 357 358 359
		phy->wkupclk = devm_clk_get(phy->dev, "wkupclk");
		if (IS_ERR(phy->wkupclk)) {
			dev_err(&pdev->dev, "unable to get wkupclk\n");
			return PTR_ERR(phy->wkupclk);
		}
	} else {
		phy->wkupclk = ERR_PTR(-ENODEV);
360 361
	}

362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391
	if (of_device_is_compatible(node, "ti,phy-pipe3-pcie")) {

		clk = devm_clk_get(phy->dev, "dpll_ref");
		if (IS_ERR(clk)) {
			dev_err(&pdev->dev, "unable to get dpll ref clk\n");
			return PTR_ERR(clk);
		}
		clk_set_rate(clk, 1500000000);

		clk = devm_clk_get(phy->dev, "dpll_ref_m2");
		if (IS_ERR(clk)) {
			dev_err(&pdev->dev, "unable to get dpll ref m2 clk\n");
			return PTR_ERR(clk);
		}
		clk_set_rate(clk, 100000000);

		clk = devm_clk_get(phy->dev, "phy-div");
		if (IS_ERR(clk)) {
			dev_err(&pdev->dev, "unable to get phy-div clk\n");
			return PTR_ERR(clk);
		}
		clk_set_rate(clk, 100000000);

		phy->div_clk = devm_clk_get(phy->dev, "div-clk");
		if (IS_ERR(phy->div_clk)) {
			dev_err(&pdev->dev, "unable to get div-clk\n");
			return PTR_ERR(phy->div_clk);
		}
	} else {
		phy->div_clk = ERR_PTR(-ENODEV);
392 393
	}

394 395 396 397
	control_node = of_parse_phandle(node, "ctrl-module", 0);
	if (!control_node) {
		dev_err(&pdev->dev, "Failed to get control device phandle\n");
		return -EINVAL;
398
	}
399

400 401 402 403 404 405 406
	control_pdev = of_find_device_by_node(control_node);
	if (!control_pdev) {
		dev_err(&pdev->dev, "Failed to get control device\n");
		return -EINVAL;
	}

	phy->control_dev = &control_pdev->dev;
407

408
	omap_control_phy_power(phy->control_dev, 0);
409 410 411

	platform_set_drvdata(pdev, phy);
	pm_runtime_enable(phy->dev);
412

413
	generic_phy = devm_phy_create(phy->dev, NULL, &ops);
414 415 416 417 418 419 420 421 422
	if (IS_ERR(generic_phy))
		return PTR_ERR(generic_phy);

	phy_set_drvdata(generic_phy, phy);
	phy_provider = devm_of_phy_provider_register(phy->dev,
			of_phy_simple_xlate);
	if (IS_ERR(phy_provider))
		return PTR_ERR(phy_provider);

423 424 425 426 427
	pm_runtime_get(&pdev->dev);

	return 0;
}

428
static int ti_pipe3_remove(struct platform_device *pdev)
429 430 431 432 433 434 435 436
{
	if (!pm_runtime_suspended(&pdev->dev))
		pm_runtime_put(&pdev->dev);
	pm_runtime_disable(&pdev->dev);

	return 0;
}

437
#ifdef CONFIG_PM
438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460
static int ti_pipe3_enable_refclk(struct ti_pipe3 *phy)
{
	if (!IS_ERR(phy->refclk) && !phy->refclk_enabled) {
		int ret;

		ret = clk_prepare_enable(phy->refclk);
		if (ret) {
			dev_err(phy->dev, "Failed to enable refclk %d\n", ret);
			return ret;
		}
		phy->refclk_enabled = true;
	}

	return 0;
}

static void ti_pipe3_disable_refclk(struct ti_pipe3 *phy)
{
	if (!IS_ERR(phy->refclk))
		clk_disable_unprepare(phy->refclk);

	phy->refclk_enabled = false;
}
461

462
static int ti_pipe3_enable_clocks(struct ti_pipe3 *phy)
463
{
464 465
	int ret = 0;
	unsigned long flags;
466

467 468 469
	spin_lock_irqsave(&phy->lock, flags);
	if (phy->enabled)
		goto err1;
470

471 472 473
	ret = ti_pipe3_enable_refclk(phy);
	if (ret)
		goto err1;
474

475 476 477 478 479 480
	if (!IS_ERR(phy->wkupclk)) {
		ret = clk_prepare_enable(phy->wkupclk);
		if (ret) {
			dev_err(phy->dev, "Failed to enable wkupclk %d\n", ret);
			goto err2;
		}
481 482
	}

483 484 485 486 487 488 489
	if (!IS_ERR(phy->div_clk)) {
		ret = clk_prepare_enable(phy->div_clk);
		if (ret) {
			dev_err(phy->dev, "Failed to enable div_clk %d\n", ret);
			goto err3;
		}
	}
490 491 492

	phy->enabled = true;
	spin_unlock_irqrestore(&phy->lock, flags);
493 494
	return 0;

495 496 497 498
err3:
	if (!IS_ERR(phy->wkupclk))
		clk_disable_unprepare(phy->wkupclk);

499
err2:
500 501
	if (!IS_ERR(phy->refclk))
		clk_disable_unprepare(phy->refclk);
502

503
	ti_pipe3_disable_refclk(phy);
504
err1:
505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520
	spin_unlock_irqrestore(&phy->lock, flags);
	return ret;
}

static void ti_pipe3_disable_clocks(struct ti_pipe3 *phy)
{
	unsigned long flags;

	spin_lock_irqsave(&phy->lock, flags);
	if (!phy->enabled) {
		spin_unlock_irqrestore(&phy->lock, flags);
		return;
	}

	if (!IS_ERR(phy->wkupclk))
		clk_disable_unprepare(phy->wkupclk);
521 522 523
	/* Don't disable refclk for SATA PHY due to Errata i783 */
	if (!of_device_is_compatible(phy->dev->of_node, "ti,phy-pipe3-sata"))
		ti_pipe3_disable_refclk(phy);
524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543
	if (!IS_ERR(phy->div_clk))
		clk_disable_unprepare(phy->div_clk);
	phy->enabled = false;
	spin_unlock_irqrestore(&phy->lock, flags);
}

static int ti_pipe3_runtime_suspend(struct device *dev)
{
	struct ti_pipe3	*phy = dev_get_drvdata(dev);

	ti_pipe3_disable_clocks(phy);
	return 0;
}

static int ti_pipe3_runtime_resume(struct device *dev)
{
	struct ti_pipe3	*phy = dev_get_drvdata(dev);
	int ret = 0;

	ret = ti_pipe3_enable_clocks(phy);
544 545 546
	return ret;
}

547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570
static int ti_pipe3_suspend(struct device *dev)
{
	struct ti_pipe3	*phy = dev_get_drvdata(dev);

	ti_pipe3_disable_clocks(phy);
	return 0;
}

static int ti_pipe3_resume(struct device *dev)
{
	struct ti_pipe3	*phy = dev_get_drvdata(dev);
	int ret;

	ret = ti_pipe3_enable_clocks(phy);
	if (ret)
		return ret;

	pm_runtime_disable(dev);
	pm_runtime_set_active(dev);
	pm_runtime_enable(dev);
	return 0;
}
#endif

571 572 573
static const struct dev_pm_ops ti_pipe3_pm_ops = {
	SET_RUNTIME_PM_OPS(ti_pipe3_runtime_suspend,
			   ti_pipe3_runtime_resume, NULL)
574
	SET_SYSTEM_SLEEP_PM_OPS(ti_pipe3_suspend, ti_pipe3_resume)
575 576 577
};

#ifdef CONFIG_OF
578
static const struct of_device_id ti_pipe3_id_table[] = {
579 580 581 582 583 584 585 586 587 588 589 590
	{
		.compatible = "ti,phy-usb3",
		.data = dpll_map_usb,
	},
	{
		.compatible = "ti,omap-usb3",
		.data = dpll_map_usb,
	},
	{
		.compatible = "ti,phy-pipe3-sata",
		.data = dpll_map_sata,
	},
591 592 593
	{
		.compatible = "ti,phy-pipe3-pcie",
	},
594 595
	{}
};
596
MODULE_DEVICE_TABLE(of, ti_pipe3_id_table);
597 598
#endif

599 600 601
static struct platform_driver ti_pipe3_driver = {
	.probe		= ti_pipe3_probe,
	.remove		= ti_pipe3_remove,
602
	.driver		= {
603
		.name	= "ti-pipe3",
604
		.pm	= &ti_pipe3_pm_ops,
605
		.of_match_table = of_match_ptr(ti_pipe3_id_table),
606 607 608
	},
};

609
module_platform_driver(ti_pipe3_driver);
610

611
MODULE_ALIAS("platform: ti_pipe3");
612
MODULE_AUTHOR("Texas Instruments Inc.");
613
MODULE_DESCRIPTION("TI PIPE3 phy driver");
614
MODULE_LICENSE("GPL v2");