Commit de6e0f84 authored by Gabriel FERNANDEZ's avatar Gabriel FERNANDEZ Committed by Kishon Vijay Abraham I

phy: miphy28lp: Pass sysconfig register offsets via syscfg dt property.

Based on Arnds review comments here https://lkml.org/lkml/2014/11/13/161,
update the miphy28lp phy driver to access sysconfig register offsets via
syscfg dt property.

This is because the reg property should not be mixing address spaces like
it does currently for miphy28lp. This change then also aligns us to how other
platforms such as keystone and bcm7445 pass there syscon offsets via DT.

I have updated the miphy28lp phy driver same way as Peter's implementation.
Signed-off-by: default avatarGabriel Fernandez <gabriel.fernandez@linaro.org>
Signed-off-by: default avatarKishon Vijay Abraham I <kishon@ti.com>
parent 147fd9d6
...@@ -26,6 +26,7 @@ Required properties (port (child) node): ...@@ -26,6 +26,7 @@ Required properties (port (child) node):
filled in "reg". It can also contain the offset of the system configuration filled in "reg". It can also contain the offset of the system configuration
registers used as glue-logic to setup the device for SATA/PCIe or USB3 registers used as glue-logic to setup the device for SATA/PCIe or USB3
devices. devices.
- st,syscfg : Offset of the parent configuration register.
- resets : phandle to the parent reset controller. - resets : phandle to the parent reset controller.
- reset-names : Associated name must be "miphy-sw-rst". - reset-names : Associated name must be "miphy-sw-rst".
...@@ -54,18 +55,12 @@ example: ...@@ -54,18 +55,12 @@ example:
phy_port0: port@9b22000 { phy_port0: port@9b22000 {
reg = <0x9b22000 0xff>, reg = <0x9b22000 0xff>,
<0x9b09000 0xff>, <0x9b09000 0xff>,
<0x9b04000 0xff>, <0x9b04000 0xff>;
<0x114 0x4>, /* sysctrl MiPHY cntrl */
<0x818 0x4>, /* sysctrl MiPHY status*/
<0xe0 0x4>, /* sysctrl PCIe */
<0xec 0x4>; /* sysctrl SATA */
reg-names = "sata-up", reg-names = "sata-up",
"pcie-up", "pcie-up",
"pipew", "pipew";
"miphy-ctrl-glue",
"miphy-status-glue", st,syscfg = <0x114 0x818 0xe0 0xec>;
"pcie-glue",
"sata-glue";
#phy-cells = <1>; #phy-cells = <1>;
st,osc-rdy; st,osc-rdy;
reset-names = "miphy-sw-rst"; reset-names = "miphy-sw-rst";
...@@ -75,18 +70,13 @@ example: ...@@ -75,18 +70,13 @@ example:
phy_port1: port@9b2a000 { phy_port1: port@9b2a000 {
reg = <0x9b2a000 0xff>, reg = <0x9b2a000 0xff>,
<0x9b19000 0xff>, <0x9b19000 0xff>,
<0x9b14000 0xff>, <0x9b14000 0xff>;
<0x118 0x4>,
<0x81c 0x4>,
<0xe4 0x4>,
<0xf0 0x4>;
reg-names = "sata-up", reg-names = "sata-up",
"pcie-up", "pcie-up",
"pipew", "pipew";
"miphy-ctrl-glue",
"miphy-status-glue", st,syscfg = <0x118 0x81c 0xe4 0xf0>;
"pcie-glue",
"sata-glue";
#phy-cells = <1>; #phy-cells = <1>;
st,osc-force-ext; st,osc-force-ext;
reset-names = "miphy-sw-rst"; reset-names = "miphy-sw-rst";
...@@ -95,13 +85,12 @@ example: ...@@ -95,13 +85,12 @@ example:
phy_port2: port@8f95000 { phy_port2: port@8f95000 {
reg = <0x8f95000 0xff>, reg = <0x8f95000 0xff>,
<0x8f90000 0xff>, <0x8f90000 0xff>;
<0x11c 0x4>,
<0x820 0x4>;
reg-names = "pipew", reg-names = "pipew",
"usb3-up", "usb3-up";
"miphy-ctrl-glue",
"miphy-status-glue"; st,syscfg = <0x11c 0x820>;
#phy-cells = <1>; #phy-cells = <1>;
reset-names = "miphy-sw-rst"; reset-names = "miphy-sw-rst";
resets = <&softreset STIH407_MIPHY2_SOFTRESET>; resets = <&softreset STIH407_MIPHY2_SOFTRESET>;
...@@ -125,4 +114,4 @@ example: ...@@ -125,4 +114,4 @@ example:
Macro definitions for the supported miphy configuration can be found in: Macro definitions for the supported miphy configuration can be found in:
include/dt-bindings/phy/phy-miphy28lp.h include/dt-bindings/phy/phy.h
...@@ -194,6 +194,14 @@ ...@@ -194,6 +194,14 @@
#define MIPHY_SATA_BANK_NB 3 #define MIPHY_SATA_BANK_NB 3
#define MIPHY_PCIE_BANK_NB 2 #define MIPHY_PCIE_BANK_NB 2
enum {
SYSCFG_CTRL,
SYSCFG_STATUS,
SYSCFG_PCI,
SYSCFG_SATA,
SYSCFG_REG_MAX,
};
struct miphy28lp_phy { struct miphy28lp_phy {
struct phy *phy; struct phy *phy;
struct miphy28lp_dev *phydev; struct miphy28lp_dev *phydev;
...@@ -211,10 +219,7 @@ struct miphy28lp_phy { ...@@ -211,10 +219,7 @@ struct miphy28lp_phy {
u32 sata_gen; u32 sata_gen;
/* Sysconfig registers offsets needed to configure the device */ /* Sysconfig registers offsets needed to configure the device */
u32 syscfg_miphy_ctrl; u32 syscfg_reg[SYSCFG_REG_MAX];
u32 syscfg_miphy_status;
u32 syscfg_pci;
u32 syscfg_sata;
u8 type; u8 type;
}; };
...@@ -834,12 +839,12 @@ static int miphy_osc_is_ready(struct miphy28lp_phy *miphy_phy) ...@@ -834,12 +839,12 @@ static int miphy_osc_is_ready(struct miphy28lp_phy *miphy_phy)
if (!miphy_phy->osc_rdy) if (!miphy_phy->osc_rdy)
return 0; return 0;
if (!miphy_phy->syscfg_miphy_status) if (!miphy_phy->syscfg_reg[SYSCFG_STATUS])
return -EINVAL; return -EINVAL;
do { do {
regmap_read(miphy_dev->regmap, miphy_phy->syscfg_miphy_status, regmap_read(miphy_dev->regmap,
&val); miphy_phy->syscfg_reg[SYSCFG_STATUS], &val);
if ((val & MIPHY_OSC_RDY) != MIPHY_OSC_RDY) if ((val & MIPHY_OSC_RDY) != MIPHY_OSC_RDY)
cpu_relax(); cpu_relax();
...@@ -888,7 +893,7 @@ static int miphy28lp_setup(struct miphy28lp_phy *miphy_phy, u32 miphy_val) ...@@ -888,7 +893,7 @@ static int miphy28lp_setup(struct miphy28lp_phy *miphy_phy, u32 miphy_val)
int err; int err;
struct miphy28lp_dev *miphy_dev = miphy_phy->phydev; struct miphy28lp_dev *miphy_dev = miphy_phy->phydev;
if (!miphy_phy->syscfg_miphy_ctrl) if (!miphy_phy->syscfg_reg[SYSCFG_CTRL])
return -EINVAL; return -EINVAL;
err = reset_control_assert(miphy_phy->miphy_rst); err = reset_control_assert(miphy_phy->miphy_rst);
...@@ -900,7 +905,8 @@ static int miphy28lp_setup(struct miphy28lp_phy *miphy_phy, u32 miphy_val) ...@@ -900,7 +905,8 @@ static int miphy28lp_setup(struct miphy28lp_phy *miphy_phy, u32 miphy_val)
if (miphy_phy->osc_force_ext) if (miphy_phy->osc_force_ext)
miphy_val |= MIPHY_OSC_FORCE_EXT; miphy_val |= MIPHY_OSC_FORCE_EXT;
regmap_update_bits(miphy_dev->regmap, miphy_phy->syscfg_miphy_ctrl, regmap_update_bits(miphy_dev->regmap,
miphy_phy->syscfg_reg[SYSCFG_CTRL],
MIPHY_CTRL_MASK, miphy_val); MIPHY_CTRL_MASK, miphy_val);
err = reset_control_deassert(miphy_phy->miphy_rst); err = reset_control_deassert(miphy_phy->miphy_rst);
...@@ -917,8 +923,9 @@ static int miphy28lp_init_sata(struct miphy28lp_phy *miphy_phy) ...@@ -917,8 +923,9 @@ static int miphy28lp_init_sata(struct miphy28lp_phy *miphy_phy)
struct miphy28lp_dev *miphy_dev = miphy_phy->phydev; struct miphy28lp_dev *miphy_dev = miphy_phy->phydev;
int err, sata_conf = SATA_CTRL_SELECT_SATA; int err, sata_conf = SATA_CTRL_SELECT_SATA;
if ((!miphy_phy->syscfg_sata) || (!miphy_phy->syscfg_pci) if ((!miphy_phy->syscfg_reg[SYSCFG_SATA]) ||
|| (!miphy_phy->base)) (!miphy_phy->syscfg_reg[SYSCFG_PCI]) ||
(!miphy_phy->base))
return -EINVAL; return -EINVAL;
dev_info(miphy_dev->dev, "sata-up mode, addr 0x%p\n", miphy_phy->base); dev_info(miphy_dev->dev, "sata-up mode, addr 0x%p\n", miphy_phy->base);
...@@ -926,10 +933,11 @@ static int miphy28lp_init_sata(struct miphy28lp_phy *miphy_phy) ...@@ -926,10 +933,11 @@ static int miphy28lp_init_sata(struct miphy28lp_phy *miphy_phy)
/* Configure the glue-logic */ /* Configure the glue-logic */
sata_conf |= ((miphy_phy->sata_gen - SATA_GEN1) << SATA_SPDMODE); sata_conf |= ((miphy_phy->sata_gen - SATA_GEN1) << SATA_SPDMODE);
regmap_update_bits(miphy_dev->regmap, miphy_phy->syscfg_sata, regmap_update_bits(miphy_dev->regmap,
miphy_phy->syscfg_reg[SYSCFG_SATA],
SATA_CTRL_MASK, sata_conf); SATA_CTRL_MASK, sata_conf);
regmap_update_bits(miphy_dev->regmap, miphy_phy->syscfg_pci, regmap_update_bits(miphy_dev->regmap, miphy_phy->syscfg_reg[SYSCFG_PCI],
PCIE_CTRL_MASK, SATA_CTRL_SELECT_PCIE); PCIE_CTRL_MASK, SATA_CTRL_SELECT_PCIE);
/* MiPHY path and clocking init */ /* MiPHY path and clocking init */
...@@ -951,17 +959,19 @@ static int miphy28lp_init_pcie(struct miphy28lp_phy *miphy_phy) ...@@ -951,17 +959,19 @@ static int miphy28lp_init_pcie(struct miphy28lp_phy *miphy_phy)
struct miphy28lp_dev *miphy_dev = miphy_phy->phydev; struct miphy28lp_dev *miphy_dev = miphy_phy->phydev;
int err; int err;
if ((!miphy_phy->syscfg_sata) || (!miphy_phy->syscfg_pci) if ((!miphy_phy->syscfg_reg[SYSCFG_SATA]) ||
(!miphy_phy->syscfg_reg[SYSCFG_PCI])
|| (!miphy_phy->base) || (!miphy_phy->pipebase)) || (!miphy_phy->base) || (!miphy_phy->pipebase))
return -EINVAL; return -EINVAL;
dev_info(miphy_dev->dev, "pcie-up mode, addr 0x%p\n", miphy_phy->base); dev_info(miphy_dev->dev, "pcie-up mode, addr 0x%p\n", miphy_phy->base);
/* Configure the glue-logic */ /* Configure the glue-logic */
regmap_update_bits(miphy_dev->regmap, miphy_phy->syscfg_sata, regmap_update_bits(miphy_dev->regmap,
miphy_phy->syscfg_reg[SYSCFG_SATA],
SATA_CTRL_MASK, SATA_CTRL_SELECT_PCIE); SATA_CTRL_MASK, SATA_CTRL_SELECT_PCIE);
regmap_update_bits(miphy_dev->regmap, miphy_phy->syscfg_pci, regmap_update_bits(miphy_dev->regmap, miphy_phy->syscfg_reg[SYSCFG_PCI],
PCIE_CTRL_MASK, SYSCFG_PCIE_PCIE_VAL); PCIE_CTRL_MASK, SYSCFG_PCIE_PCIE_VAL);
/* MiPHY path and clocking init */ /* MiPHY path and clocking init */
...@@ -1156,7 +1166,8 @@ static int miphy28lp_probe_resets(struct device_node *node, ...@@ -1156,7 +1166,8 @@ static int miphy28lp_probe_resets(struct device_node *node,
static int miphy28lp_of_probe(struct device_node *np, static int miphy28lp_of_probe(struct device_node *np,
struct miphy28lp_phy *miphy_phy) struct miphy28lp_phy *miphy_phy)
{ {
struct resource res; int i;
u32 ctrlreg;
miphy_phy->osc_force_ext = miphy_phy->osc_force_ext =
of_property_read_bool(np, "st,osc-force-ext"); of_property_read_bool(np, "st,osc-force-ext");
...@@ -1175,18 +1186,10 @@ static int miphy28lp_of_probe(struct device_node *np, ...@@ -1175,18 +1186,10 @@ static int miphy28lp_of_probe(struct device_node *np,
if (!miphy_phy->sata_gen) if (!miphy_phy->sata_gen)
miphy_phy->sata_gen = SATA_GEN1; miphy_phy->sata_gen = SATA_GEN1;
if (!miphy28lp_get_resource_byname(np, "miphy-ctrl-glue", &res)) for (i = 0; i < SYSCFG_REG_MAX; i++) {
miphy_phy->syscfg_miphy_ctrl = res.start; if (!of_property_read_u32_index(np, "st,syscfg", i, &ctrlreg))
miphy_phy->syscfg_reg[i] = ctrlreg;
if (!miphy28lp_get_resource_byname(np, "miphy-status-glue", &res)) }
miphy_phy->syscfg_miphy_status = res.start;
if (!miphy28lp_get_resource_byname(np, "pcie-glue", &res))
miphy_phy->syscfg_pci = res.start;
if (!miphy28lp_get_resource_byname(np, "sata-glue", &res))
miphy_phy->syscfg_sata = res.start;
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment