mirror of https://gitee.com/openkylin/linux.git
phy: for 4.2-rc6
*) Fix compiler error when sun4i usb phy driver is built as module *) Fix SATA Lockup issue in dra7 SoC Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com> -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.11 (GNU/Linux) iQIcBAABAgAGBQJVwOpCAAoJEA5ceFyATYLZTikP/17trNhiyCOL8s0ok1pbBR+B 9ilzq7dOuVPrQUdvJycpH6DdajsuUN0GzzftjkN2h96v2ck2yVb8RgnhPB2aGKJm Nb/UTPgX1GUaRNQ/iZaKvDtSUjxQm3JWIaf06hC8rvd0D0k4WOvMxYJpHbGliBOf EPps3LZtnZn89htJniOUSDByrigTvfeWpKzU2guafoIEURNf6wGEYcCxOlYw9ST6 W8LnSA5kkc3beRaGkNSzoQfq3zFJKF+8mPDARoiX6hBg+3oe9RmodIBKpD2Vl08k Y0eXtXhICxxqlGqRL71gfRXWDqNY9aMhXS0A/dyNvX2tDnXXNQF/Rjsxs+EPR0Td tFrwU/IzySmlCj4hrCEvImZnk1whe/kvsoHSXY7HSSVlXVQ/Nv5DulfxC8A8Nwx6 v6fj3+3jwJRJnQgs1/PwYGpYFDh4L7dJRWKULjiilXeyhT9UJlH1IknjK1lhNdxg lIEEgckNTnBoU0cnW/7FEdbqnt562DLiZYSmXwKHffPrY4nCaaOMKz+Y0WAs+StW A+tDe+myPElGmJ01N8MF3QRpXFSdH8/06OJl5W4KhBXKMZXikMq2yZ4SpVdTiYfp 4Nyiv1lblqwslESl3ru6KbcjUGkamnTXKA5p6u5/D5l+ACXgYkKsNZFN4gRwXpKi J/VGHy/PTOBo0W1saBuS =j6wu -----END PGP SIGNATURE----- Merge tag 'phy-for-4.2-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/kishon/linux-phy into usb-linus Kishon writes: phy: for 4.2-rc6 *) Fix compiler error when sun4i usb phy driver is built as module *) Fix SATA Lockup issue in dra7 SoC Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
This commit is contained in:
commit
0a1b6f6319
|
@ -82,6 +82,9 @@ Optional properties:
|
||||||
- id: If there are multiple instance of the same type, in order to
|
- id: If there are multiple instance of the same type, in order to
|
||||||
differentiate between each instance "id" can be used (e.g., multi-lane PCIe
|
differentiate between each instance "id" can be used (e.g., multi-lane PCIe
|
||||||
PHY). If "id" is not provided, it is set to default value of '1'.
|
PHY). If "id" is not provided, it is set to default value of '1'.
|
||||||
|
- syscon-pllreset: Handle to system control region that contains the
|
||||||
|
CTRL_CORE_SMA_SW_0 register and register offset to the CTRL_CORE_SMA_SW_0
|
||||||
|
register that contains the SATA_PLL_SOFT_RESET bit. Only valid for sata_phy.
|
||||||
|
|
||||||
This is usually a subnode of ocp2scp to which it is connected.
|
This is usually a subnode of ocp2scp to which it is connected.
|
||||||
|
|
||||||
|
@ -100,3 +103,16 @@ usb3phy@4a084400 {
|
||||||
"sysclk",
|
"sysclk",
|
||||||
"refclk";
|
"refclk";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
sata_phy: phy@4A096000 {
|
||||||
|
compatible = "ti,phy-pipe3-sata";
|
||||||
|
reg = <0x4A096000 0x80>, /* phy_rx */
|
||||||
|
<0x4A096400 0x64>, /* phy_tx */
|
||||||
|
<0x4A096800 0x40>; /* pll_ctrl */
|
||||||
|
reg-names = "phy_rx", "phy_tx", "pll_ctrl";
|
||||||
|
ctrl-module = <&omap_control_sata>;
|
||||||
|
clocks = <&sys_clkin1>, <&sata_ref_clk>;
|
||||||
|
clock-names = "sysclk", "refclk";
|
||||||
|
syscon-pllreset = <&scm_conf 0x3fc>;
|
||||||
|
#phy-cells = <0>;
|
||||||
|
};
|
||||||
|
|
|
@ -1140,6 +1140,7 @@ sata_phy: phy@4A096000 {
|
||||||
ctrl-module = <&omap_control_sata>;
|
ctrl-module = <&omap_control_sata>;
|
||||||
clocks = <&sys_clkin1>, <&sata_ref_clk>;
|
clocks = <&sys_clkin1>, <&sata_ref_clk>;
|
||||||
clock-names = "sysclk", "refclk";
|
clock-names = "sysclk", "refclk";
|
||||||
|
syscon-pllreset = <&scm_conf 0x3fc>;
|
||||||
#phy-cells = <0>;
|
#phy-cells = <0>;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -212,6 +212,7 @@ void sun4i_usb_phy_set_squelch_detect(struct phy *_phy, bool enabled)
|
||||||
|
|
||||||
sun4i_usb_phy_write(phy, PHY_SQUELCH_DETECT, enabled ? 0 : 2, 2);
|
sun4i_usb_phy_write(phy, PHY_SQUELCH_DETECT, enabled ? 0 : 2, 2);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(sun4i_usb_phy_set_squelch_detect);
|
||||||
|
|
||||||
static struct phy_ops sun4i_usb_phy_ops = {
|
static struct phy_ops sun4i_usb_phy_ops = {
|
||||||
.init = sun4i_usb_phy_init,
|
.init = sun4i_usb_phy_init,
|
||||||
|
|
|
@ -28,6 +28,8 @@
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
#include <linux/phy/omap_control_phy.h>
|
#include <linux/phy/omap_control_phy.h>
|
||||||
#include <linux/of_platform.h>
|
#include <linux/of_platform.h>
|
||||||
|
#include <linux/mfd/syscon.h>
|
||||||
|
#include <linux/regmap.h>
|
||||||
|
|
||||||
#define PLL_STATUS 0x00000004
|
#define PLL_STATUS 0x00000004
|
||||||
#define PLL_GO 0x00000008
|
#define PLL_GO 0x00000008
|
||||||
|
@ -52,6 +54,8 @@
|
||||||
#define PLL_LOCK 0x2
|
#define PLL_LOCK 0x2
|
||||||
#define PLL_IDLE 0x1
|
#define PLL_IDLE 0x1
|
||||||
|
|
||||||
|
#define SATA_PLL_SOFT_RESET BIT(18)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This is an Empirical value that works, need to confirm the actual
|
* This is an Empirical value that works, need to confirm the actual
|
||||||
* value required for the PIPE3PHY_PLL_CONFIGURATION2.PLL_IDLE status
|
* value required for the PIPE3PHY_PLL_CONFIGURATION2.PLL_IDLE status
|
||||||
|
@ -82,6 +86,9 @@ struct ti_pipe3 {
|
||||||
struct clk *refclk;
|
struct clk *refclk;
|
||||||
struct clk *div_clk;
|
struct clk *div_clk;
|
||||||
struct pipe3_dpll_map *dpll_map;
|
struct pipe3_dpll_map *dpll_map;
|
||||||
|
struct regmap *dpll_reset_syscon; /* ctrl. reg. acces */
|
||||||
|
unsigned int dpll_reset_reg; /* reg. index within syscon */
|
||||||
|
bool sata_refclk_enabled;
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct pipe3_dpll_map dpll_map_usb[] = {
|
static struct pipe3_dpll_map dpll_map_usb[] = {
|
||||||
|
@ -249,8 +256,11 @@ static int ti_pipe3_exit(struct phy *x)
|
||||||
u32 val;
|
u32 val;
|
||||||
unsigned long timeout;
|
unsigned long timeout;
|
||||||
|
|
||||||
/* SATA DPLL can't be powered down due to Errata i783 */
|
/* If dpll_reset_syscon is not present we wont power down SATA DPLL
|
||||||
if (of_device_is_compatible(phy->dev->of_node, "ti,phy-pipe3-sata"))
|
* due to Errata i783
|
||||||
|
*/
|
||||||
|
if (of_device_is_compatible(phy->dev->of_node, "ti,phy-pipe3-sata") &&
|
||||||
|
!phy->dpll_reset_syscon)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* PCIe doesn't have internal DPLL */
|
/* PCIe doesn't have internal DPLL */
|
||||||
|
@ -276,6 +286,14 @@ static int ti_pipe3_exit(struct phy *x)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* i783: SATA needs control bit toggle after PLL unlock */
|
||||||
|
if (of_device_is_compatible(phy->dev->of_node, "ti,phy-pipe3-sata")) {
|
||||||
|
regmap_update_bits(phy->dpll_reset_syscon, phy->dpll_reset_reg,
|
||||||
|
SATA_PLL_SOFT_RESET, SATA_PLL_SOFT_RESET);
|
||||||
|
regmap_update_bits(phy->dpll_reset_syscon, phy->dpll_reset_reg,
|
||||||
|
SATA_PLL_SOFT_RESET, 0);
|
||||||
|
}
|
||||||
|
|
||||||
ti_pipe3_disable_clocks(phy);
|
ti_pipe3_disable_clocks(phy);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -350,6 +368,21 @@ static int ti_pipe3_probe(struct platform_device *pdev)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
phy->wkupclk = ERR_PTR(-ENODEV);
|
phy->wkupclk = ERR_PTR(-ENODEV);
|
||||||
|
phy->dpll_reset_syscon = syscon_regmap_lookup_by_phandle(node,
|
||||||
|
"syscon-pllreset");
|
||||||
|
if (IS_ERR(phy->dpll_reset_syscon)) {
|
||||||
|
dev_info(&pdev->dev,
|
||||||
|
"can't get syscon-pllreset, sata dpll won't idle\n");
|
||||||
|
phy->dpll_reset_syscon = NULL;
|
||||||
|
} else {
|
||||||
|
if (of_property_read_u32_index(node,
|
||||||
|
"syscon-pllreset", 1,
|
||||||
|
&phy->dpll_reset_reg)) {
|
||||||
|
dev_err(&pdev->dev,
|
||||||
|
"couldn't get pllreset reg. offset\n");
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (of_device_is_compatible(node, "ti,phy-pipe3-pcie")) {
|
if (of_device_is_compatible(node, "ti,phy-pipe3-pcie")) {
|
||||||
|
@ -402,10 +435,16 @@ static int ti_pipe3_probe(struct platform_device *pdev)
|
||||||
|
|
||||||
platform_set_drvdata(pdev, phy);
|
platform_set_drvdata(pdev, phy);
|
||||||
pm_runtime_enable(phy->dev);
|
pm_runtime_enable(phy->dev);
|
||||||
/* Prevent auto-disable of refclk for SATA PHY due to Errata i783 */
|
|
||||||
if (of_device_is_compatible(node, "ti,phy-pipe3-sata"))
|
/*
|
||||||
if (!IS_ERR(phy->refclk))
|
* Prevent auto-disable of refclk for SATA PHY due to Errata i783
|
||||||
|
*/
|
||||||
|
if (of_device_is_compatible(node, "ti,phy-pipe3-sata")) {
|
||||||
|
if (!IS_ERR(phy->refclk)) {
|
||||||
clk_prepare_enable(phy->refclk);
|
clk_prepare_enable(phy->refclk);
|
||||||
|
phy->sata_refclk_enabled = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
generic_phy = devm_phy_create(phy->dev, NULL, &ops);
|
generic_phy = devm_phy_create(phy->dev, NULL, &ops);
|
||||||
if (IS_ERR(generic_phy))
|
if (IS_ERR(generic_phy))
|
||||||
|
@ -472,8 +511,18 @@ static void ti_pipe3_disable_clocks(struct ti_pipe3 *phy)
|
||||||
{
|
{
|
||||||
if (!IS_ERR(phy->wkupclk))
|
if (!IS_ERR(phy->wkupclk))
|
||||||
clk_disable_unprepare(phy->wkupclk);
|
clk_disable_unprepare(phy->wkupclk);
|
||||||
if (!IS_ERR(phy->refclk))
|
if (!IS_ERR(phy->refclk)) {
|
||||||
clk_disable_unprepare(phy->refclk);
|
clk_disable_unprepare(phy->refclk);
|
||||||
|
/*
|
||||||
|
* SATA refclk needs an additional disable as we left it
|
||||||
|
* on in probe to avoid Errata i783
|
||||||
|
*/
|
||||||
|
if (phy->sata_refclk_enabled) {
|
||||||
|
clk_disable_unprepare(phy->refclk);
|
||||||
|
phy->sata_refclk_enabled = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!IS_ERR(phy->div_clk))
|
if (!IS_ERR(phy->div_clk))
|
||||||
clk_disable_unprepare(phy->div_clk);
|
clk_disable_unprepare(phy->div_clk);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue