summaryrefslogtreecommitdiff
path: root/drivers/phy/marvell/comphy_a3700.c
diff options
context:
space:
mode:
authorMarek BehĂșn <marek.behun@nic.cz>2018-04-24 17:21:17 +0200
committerStefan Roese <sr@denx.de>2018-05-14 10:00:15 +0200
commita2745c88032e27b16d0f78748175365601dd5107 (patch)
treeb6c37db092b3cead73bab0a7feceffbb02ea6982 /drivers/phy/marvell/comphy_a3700.c
parent1a9283ace571384b60b931567b0a6055acec27cc (diff)
phy: marvell: a3700: Use reg_set_indirect istead of 2 reg_sets
Create a special function for indirect register setting, reg_set_indirect, and use it instead of the two calls to reg_set. Signed-off-by: Marek Behun <marek.behun@nic.cz> Reviewed-by: Stefan Roese <sr@denx.de> Signed-off-by: Stefan Roese <sr@denx.de>
Diffstat (limited to 'drivers/phy/marvell/comphy_a3700.c')
-rw-r--r--drivers/phy/marvell/comphy_a3700.c32
1 files changed, 20 insertions, 12 deletions
diff --git a/drivers/phy/marvell/comphy_a3700.c b/drivers/phy/marvell/comphy_a3700.c
index a62d672e86..81f2b636e6 100644
--- a/drivers/phy/marvell/comphy_a3700.c
+++ b/drivers/phy/marvell/comphy_a3700.c
@@ -224,49 +224,57 @@ static int comphy_pcie_power_up(u32 speed, u32 invert)
}
/*
+ * reg_set_indirect
+ *
+ * return: void
+ */
+static void reg_set_indirect(u32 reg, u16 data, u16 mask)
+{
+ reg_set(rh_vsreg_addr, reg, 0xFFFFFFFF);
+ reg_set(rh_vsreg_data, data, mask);
+}
+
+/*
* comphy_sata_power_up
*
* return: 1 if PLL locked (OK), 0 otherwise (FAIL)
*/
static int comphy_sata_power_up(void)
{
- int ret;
+ int ret;
debug_enter();
/*
* 0. Swap SATA TX lines
*/
- reg_set(rh_vsreg_addr, vphy_sync_pattern_reg, 0xFFFFFFFF);
- reg_set(rh_vsreg_data, bs_txd_inv, bs_txd_inv);
+ reg_set_indirect(vphy_sync_pattern_reg, bs_txd_inv, bs_txd_inv);
/*
* 1. Select 40-bit data width width
*/
- reg_set(rh_vsreg_addr, vphy_loopback_reg0, 0xFFFFFFFF);
- reg_set(rh_vsreg_data, 0x800, bs_phyintf_40bit);
+ reg_set_indirect(vphy_loopback_reg0, 0x800, bs_phyintf_40bit);
/*
* 2. Select reference clock and PHY mode (SATA)
*/
- reg_set(rh_vsreg_addr, vphy_power_reg0, 0xFFFFFFFF);
if (get_ref_clk() == 40) {
- reg_set(rh_vsreg_data, 0x3, 0x00FF); /* 40 MHz */
+ /* 40 MHz */
+ reg_set_indirect(vphy_power_reg0, 0x3, 0x00FF);
} else {
- reg_set(rh_vsreg_data, 0x1, 0x00FF); /* 25 MHz */
+ /* 20 MHz */
+ reg_set_indirect(vphy_power_reg0, 0x1, 0x00FF);
}
/*
* 3. Use maximum PLL rate (no power save)
*/
- reg_set(rh_vsreg_addr, vphy_calctl_reg, 0xFFFFFFFF);
- reg_set(rh_vsreg_data, bs_max_pll_rate, bs_max_pll_rate);
+ reg_set_indirect(vphy_calctl_reg, bs_max_pll_rate, bs_max_pll_rate);
/*
* 4. Reset reserved bit (??)
*/
- reg_set(rh_vsreg_addr, vphy_reserve_reg, 0xFFFFFFFF);
- reg_set(rh_vsreg_data, 0, bs_phyctrl_frm_pin);
+ reg_set_indirect(vphy_reserve_reg, 0, bs_phyctrl_frm_pin);
/*
* 5. Set vendor-specific configuration (??)