diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2019-05-08 13:03:52 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2019-05-08 13:03:52 -0400 |
commit | 132d68d37d33f1d0b9c1f507c8b4d64c27ecec8a (patch) | |
tree | b3c05972e5579e1574873fe745fb1358c62a269c /drivers/phy/rockchip | |
parent | 80f232121b69cc69a31ccb2b38c1665d770b0710 (diff) | |
parent | 3515468a87a47781f6af818773650513ff14656a (diff) |
Merge tag 'usb-5.2-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb
Pull USB/PHY updates from Greg KH:
"Here is the big set of USB and PHY driver patches for 5.2-rc1
There is the usual set of:
- USB gadget updates
- PHY driver updates and additions
- USB serial driver updates and fixes
- typec updates and new chips supported
- mtu3 driver updates
- xhci driver updates
- other tiny driver updates
Nothing really interesting, just constant forward progress.
All of these have been in linux-next for a while with no reported
issues. The usb-gadget and usb-serial trees were merged a bit "late",
but both of them had been in linux-next before they got merged here
last Friday"
* tag 'usb-5.2-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb: (206 commits)
USB: serial: f81232: implement break control
USB: serial: f81232: add high baud rate support
USB: serial: f81232: clear overrun flag
USB: serial: f81232: fix interrupt worker not stop
usb: dwc3: Rename DWC3_DCTL_LPM_ERRATA
usb: dwc3: Fix default lpm_nyet_threshold value
usb: dwc3: debug: Print GET_STATUS(device) tracepoint
usb: dwc3: Do core validation early on probe
usb: dwc3: gadget: Set lpm_capable
usb: gadget: atmel: tie wake lock to running clock
usb: gadget: atmel: support USB suspend
usb: gadget: atmel_usba_udc: simplify setting of interrupt-enabled mask
dwc2: gadget: Fix completed transfer size calculation in DDMA
usb: dwc2: Set lpm mode parameters depend on HW configuration
usb: dwc2: Fix channel disable flow
usb: dwc2: Set actual frame number for completed ISOC transfer
usb: gadget: do not use __constant_cpu_to_le16
usb: dwc2: gadget: Increase descriptors count for ISOC's
usb: introduce usb_ep_type_string() function
usb: dwc3: move synchronize_irq() out of the spinlock protected block
...
Diffstat (limited to 'drivers/phy/rockchip')
-rw-r--r-- | drivers/phy/rockchip/phy-rockchip-emmc.c | 30 |
1 files changed, 28 insertions, 2 deletions
diff --git a/drivers/phy/rockchip/phy-rockchip-emmc.c b/drivers/phy/rockchip/phy-rockchip-emmc.c index 19bf84f0bc67..b804c6bf4b55 100644 --- a/drivers/phy/rockchip/phy-rockchip-emmc.c +++ b/drivers/phy/rockchip/phy-rockchip-emmc.c | |||
@@ -87,6 +87,7 @@ struct rockchip_emmc_phy { | |||
87 | unsigned int reg_offset; | 87 | unsigned int reg_offset; |
88 | struct regmap *reg_base; | 88 | struct regmap *reg_base; |
89 | struct clk *emmcclk; | 89 | struct clk *emmcclk; |
90 | unsigned int drive_impedance; | ||
90 | }; | 91 | }; |
91 | 92 | ||
92 | static int rockchip_emmc_phy_power(struct phy *phy, bool on_off) | 93 | static int rockchip_emmc_phy_power(struct phy *phy, bool on_off) |
@@ -281,10 +282,10 @@ static int rockchip_emmc_phy_power_on(struct phy *phy) | |||
281 | { | 282 | { |
282 | struct rockchip_emmc_phy *rk_phy = phy_get_drvdata(phy); | 283 | struct rockchip_emmc_phy *rk_phy = phy_get_drvdata(phy); |
283 | 284 | ||
284 | /* Drive impedance: 50 Ohm */ | 285 | /* Drive impedance: from DTS */ |
285 | regmap_write(rk_phy->reg_base, | 286 | regmap_write(rk_phy->reg_base, |
286 | rk_phy->reg_offset + GRF_EMMCPHY_CON6, | 287 | rk_phy->reg_offset + GRF_EMMCPHY_CON6, |
287 | HIWORD_UPDATE(PHYCTRL_DR_50OHM, | 288 | HIWORD_UPDATE(rk_phy->drive_impedance, |
288 | PHYCTRL_DR_MASK, | 289 | PHYCTRL_DR_MASK, |
289 | PHYCTRL_DR_SHIFT)); | 290 | PHYCTRL_DR_SHIFT)); |
290 | 291 | ||
@@ -314,6 +315,26 @@ static const struct phy_ops ops = { | |||
314 | .owner = THIS_MODULE, | 315 | .owner = THIS_MODULE, |
315 | }; | 316 | }; |
316 | 317 | ||
318 | static u32 convert_drive_impedance_ohm(struct platform_device *pdev, u32 dr_ohm) | ||
319 | { | ||
320 | switch (dr_ohm) { | ||
321 | case 100: | ||
322 | return PHYCTRL_DR_100OHM; | ||
323 | case 66: | ||
324 | return PHYCTRL_DR_66OHM; | ||
325 | case 50: | ||
326 | return PHYCTRL_DR_50OHM; | ||
327 | case 40: | ||
328 | return PHYCTRL_DR_40OHM; | ||
329 | case 33: | ||
330 | return PHYCTRL_DR_33OHM; | ||
331 | } | ||
332 | |||
333 | dev_warn(&pdev->dev, "Invalid value %u for drive-impedance-ohm.\n", | ||
334 | dr_ohm); | ||
335 | return PHYCTRL_DR_50OHM; | ||
336 | } | ||
337 | |||
317 | static int rockchip_emmc_phy_probe(struct platform_device *pdev) | 338 | static int rockchip_emmc_phy_probe(struct platform_device *pdev) |
318 | { | 339 | { |
319 | struct device *dev = &pdev->dev; | 340 | struct device *dev = &pdev->dev; |
@@ -322,6 +343,7 @@ static int rockchip_emmc_phy_probe(struct platform_device *pdev) | |||
322 | struct phy_provider *phy_provider; | 343 | struct phy_provider *phy_provider; |
323 | struct regmap *grf; | 344 | struct regmap *grf; |
324 | unsigned int reg_offset; | 345 | unsigned int reg_offset; |
346 | u32 val; | ||
325 | 347 | ||
326 | if (!dev->parent || !dev->parent->of_node) | 348 | if (!dev->parent || !dev->parent->of_node) |
327 | return -ENODEV; | 349 | return -ENODEV; |
@@ -344,6 +366,10 @@ static int rockchip_emmc_phy_probe(struct platform_device *pdev) | |||
344 | 366 | ||
345 | rk_phy->reg_offset = reg_offset; | 367 | rk_phy->reg_offset = reg_offset; |
346 | rk_phy->reg_base = grf; | 368 | rk_phy->reg_base = grf; |
369 | rk_phy->drive_impedance = PHYCTRL_DR_50OHM; | ||
370 | |||
371 | if (!of_property_read_u32(dev->of_node, "drive-impedance-ohm", &val)) | ||
372 | rk_phy->drive_impedance = convert_drive_impedance_ohm(pdev, val); | ||
347 | 373 | ||
348 | generic_phy = devm_phy_create(dev, dev->of_node, &ops); | 374 | generic_phy = devm_phy_create(dev, dev->of_node, &ops); |
349 | if (IS_ERR(generic_phy)) { | 375 | if (IS_ERR(generic_phy)) { |