USB fixes for 3.16-rc5
Here are some small USB fixes, PHY driver fixes (they ended up in this tree for lack of somewhere else to put them), and some new USB device ids. Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 iEYEABECAAYFAlPBnZAACgkQMUfUDdst+ynTkACgwma2Ccj7DJl3g1zFEtM0h8ki 8RYAnirwiO0p1B7gIKlDIgGs25JIwN61 =tNZ2 -----END PGP SIGNATURE----- Merge tag 'usb-3.16-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb Pull USB fixes from Greg KH: "Here are some small USB fixes, PHY driver fixes (they ended up in this tree for lack of somewhere else to put them), and some new USB device ids" * tag 'usb-3.16-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb: phy: omap-usb2: Balance pm_runtime_enable() on probe failure and remove phy: core: Fix error path in phy_create() drivers: phy: phy-samsung-usb2.c: Add missing MODULE_DEVICE_TABLE phy: omap-usb2: fix devm_ioremap_resource error detection code phy: sun4i: depend on RESET_CONTROLLER USB: serial: ftdi_sio: Add Infineon Triboard USB: ftdi_sio: Add extra PID. usb: option: Add ID for Telewell TW-LTE 4G v2 USB: cp210x: add support for Corsair usb dongle
This commit is contained in:
commit
6b458ac195
@ -112,6 +112,7 @@ config PHY_EXYNOS5250_SATA
|
|||||||
config PHY_SUN4I_USB
|
config PHY_SUN4I_USB
|
||||||
tristate "Allwinner sunxi SoC USB PHY driver"
|
tristate "Allwinner sunxi SoC USB PHY driver"
|
||||||
depends on ARCH_SUNXI && HAS_IOMEM && OF
|
depends on ARCH_SUNXI && HAS_IOMEM && OF
|
||||||
|
depends on RESET_CONTROLLER
|
||||||
select GENERIC_PHY
|
select GENERIC_PHY
|
||||||
help
|
help
|
||||||
Enable this to support the transceiver that is part of Allwinner
|
Enable this to support the transceiver that is part of Allwinner
|
||||||
|
@ -614,8 +614,9 @@ struct phy *phy_create(struct device *dev, const struct phy_ops *ops,
|
|||||||
return phy;
|
return phy;
|
||||||
|
|
||||||
put_dev:
|
put_dev:
|
||||||
put_device(&phy->dev);
|
put_device(&phy->dev); /* calls phy_release() which frees resources */
|
||||||
ida_remove(&phy_ida, phy->id);
|
return ERR_PTR(ret);
|
||||||
|
|
||||||
free_phy:
|
free_phy:
|
||||||
kfree(phy);
|
kfree(phy);
|
||||||
return ERR_PTR(ret);
|
return ERR_PTR(ret);
|
||||||
@ -799,7 +800,7 @@ static void phy_release(struct device *dev)
|
|||||||
|
|
||||||
phy = to_phy(dev);
|
phy = to_phy(dev);
|
||||||
dev_vdbg(dev, "releasing '%s'\n", dev_name(dev));
|
dev_vdbg(dev, "releasing '%s'\n", dev_name(dev));
|
||||||
ida_remove(&phy_ida, phy->id);
|
ida_simple_remove(&phy_ida, phy->id);
|
||||||
kfree(phy);
|
kfree(phy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -233,8 +233,8 @@ static int omap_usb2_probe(struct platform_device *pdev)
|
|||||||
if (phy_data->flags & OMAP_USB2_CALIBRATE_FALSE_DISCONNECT) {
|
if (phy_data->flags & OMAP_USB2_CALIBRATE_FALSE_DISCONNECT) {
|
||||||
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
||||||
phy->phy_base = devm_ioremap_resource(&pdev->dev, res);
|
phy->phy_base = devm_ioremap_resource(&pdev->dev, res);
|
||||||
if (!phy->phy_base)
|
if (IS_ERR(phy->phy_base))
|
||||||
return -ENOMEM;
|
return PTR_ERR(phy->phy_base);
|
||||||
phy->flags |= OMAP_USB2_CALIBRATE_FALSE_DISCONNECT;
|
phy->flags |= OMAP_USB2_CALIBRATE_FALSE_DISCONNECT;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -262,7 +262,6 @@ static int omap_usb2_probe(struct platform_device *pdev)
|
|||||||
otg->phy = &phy->phy;
|
otg->phy = &phy->phy;
|
||||||
|
|
||||||
platform_set_drvdata(pdev, phy);
|
platform_set_drvdata(pdev, phy);
|
||||||
pm_runtime_enable(phy->dev);
|
|
||||||
|
|
||||||
generic_phy = devm_phy_create(phy->dev, &ops, NULL);
|
generic_phy = devm_phy_create(phy->dev, &ops, NULL);
|
||||||
if (IS_ERR(generic_phy))
|
if (IS_ERR(generic_phy))
|
||||||
@ -270,10 +269,13 @@ static int omap_usb2_probe(struct platform_device *pdev)
|
|||||||
|
|
||||||
phy_set_drvdata(generic_phy, phy);
|
phy_set_drvdata(generic_phy, phy);
|
||||||
|
|
||||||
|
pm_runtime_enable(phy->dev);
|
||||||
phy_provider = devm_of_phy_provider_register(phy->dev,
|
phy_provider = devm_of_phy_provider_register(phy->dev,
|
||||||
of_phy_simple_xlate);
|
of_phy_simple_xlate);
|
||||||
if (IS_ERR(phy_provider))
|
if (IS_ERR(phy_provider)) {
|
||||||
|
pm_runtime_disable(phy->dev);
|
||||||
return PTR_ERR(phy_provider);
|
return PTR_ERR(phy_provider);
|
||||||
|
}
|
||||||
|
|
||||||
phy->wkupclk = devm_clk_get(phy->dev, "wkupclk");
|
phy->wkupclk = devm_clk_get(phy->dev, "wkupclk");
|
||||||
if (IS_ERR(phy->wkupclk)) {
|
if (IS_ERR(phy->wkupclk)) {
|
||||||
@ -317,6 +319,7 @@ static int omap_usb2_remove(struct platform_device *pdev)
|
|||||||
if (!IS_ERR(phy->optclk))
|
if (!IS_ERR(phy->optclk))
|
||||||
clk_unprepare(phy->optclk);
|
clk_unprepare(phy->optclk);
|
||||||
usb_remove_phy(&phy->phy);
|
usb_remove_phy(&phy->phy);
|
||||||
|
pm_runtime_disable(phy->dev);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -107,6 +107,7 @@ static const struct of_device_id samsung_usb2_phy_of_match[] = {
|
|||||||
#endif
|
#endif
|
||||||
{ },
|
{ },
|
||||||
};
|
};
|
||||||
|
MODULE_DEVICE_TABLE(of, samsung_usb2_phy_of_match);
|
||||||
|
|
||||||
static int samsung_usb2_phy_probe(struct platform_device *pdev)
|
static int samsung_usb2_phy_probe(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
|
@ -153,6 +153,7 @@ static const struct usb_device_id id_table[] = {
|
|||||||
{ USB_DEVICE(0x1843, 0x0200) }, /* Vaisala USB Instrument Cable */
|
{ USB_DEVICE(0x1843, 0x0200) }, /* Vaisala USB Instrument Cable */
|
||||||
{ USB_DEVICE(0x18EF, 0xE00F) }, /* ELV USB-I2C-Interface */
|
{ USB_DEVICE(0x18EF, 0xE00F) }, /* ELV USB-I2C-Interface */
|
||||||
{ USB_DEVICE(0x1ADB, 0x0001) }, /* Schweitzer Engineering C662 Cable */
|
{ USB_DEVICE(0x1ADB, 0x0001) }, /* Schweitzer Engineering C662 Cable */
|
||||||
|
{ USB_DEVICE(0x1B1C, 0x1C00) }, /* Corsair USB Dongle */
|
||||||
{ USB_DEVICE(0x1BE3, 0x07A6) }, /* WAGO 750-923 USB Service Cable */
|
{ USB_DEVICE(0x1BE3, 0x07A6) }, /* WAGO 750-923 USB Service Cable */
|
||||||
{ USB_DEVICE(0x1E29, 0x0102) }, /* Festo CPX-USB */
|
{ USB_DEVICE(0x1E29, 0x0102) }, /* Festo CPX-USB */
|
||||||
{ USB_DEVICE(0x1E29, 0x0501) }, /* Festo CMSP */
|
{ USB_DEVICE(0x1E29, 0x0501) }, /* Festo CMSP */
|
||||||
|
@ -720,7 +720,8 @@ static const struct usb_device_id id_table_combined[] = {
|
|||||||
{ USB_DEVICE(FTDI_VID, FTDI_ACG_HFDUAL_PID) },
|
{ USB_DEVICE(FTDI_VID, FTDI_ACG_HFDUAL_PID) },
|
||||||
{ USB_DEVICE(FTDI_VID, FTDI_YEI_SERVOCENTER31_PID) },
|
{ USB_DEVICE(FTDI_VID, FTDI_YEI_SERVOCENTER31_PID) },
|
||||||
{ USB_DEVICE(FTDI_VID, FTDI_THORLABS_PID) },
|
{ USB_DEVICE(FTDI_VID, FTDI_THORLABS_PID) },
|
||||||
{ USB_DEVICE(TESTO_VID, TESTO_USB_INTERFACE_PID) },
|
{ USB_DEVICE(TESTO_VID, TESTO_1_PID) },
|
||||||
|
{ USB_DEVICE(TESTO_VID, TESTO_3_PID) },
|
||||||
{ USB_DEVICE(FTDI_VID, FTDI_GAMMA_SCOUT_PID) },
|
{ USB_DEVICE(FTDI_VID, FTDI_GAMMA_SCOUT_PID) },
|
||||||
{ USB_DEVICE(FTDI_VID, FTDI_TACTRIX_OPENPORT_13M_PID) },
|
{ USB_DEVICE(FTDI_VID, FTDI_TACTRIX_OPENPORT_13M_PID) },
|
||||||
{ USB_DEVICE(FTDI_VID, FTDI_TACTRIX_OPENPORT_13S_PID) },
|
{ USB_DEVICE(FTDI_VID, FTDI_TACTRIX_OPENPORT_13S_PID) },
|
||||||
@ -944,6 +945,8 @@ static const struct usb_device_id id_table_combined[] = {
|
|||||||
{ USB_DEVICE(BRAINBOXES_VID, BRAINBOXES_US_842_2_PID) },
|
{ USB_DEVICE(BRAINBOXES_VID, BRAINBOXES_US_842_2_PID) },
|
||||||
{ USB_DEVICE(BRAINBOXES_VID, BRAINBOXES_US_842_3_PID) },
|
{ USB_DEVICE(BRAINBOXES_VID, BRAINBOXES_US_842_3_PID) },
|
||||||
{ USB_DEVICE(BRAINBOXES_VID, BRAINBOXES_US_842_4_PID) },
|
{ USB_DEVICE(BRAINBOXES_VID, BRAINBOXES_US_842_4_PID) },
|
||||||
|
/* Infineon Devices */
|
||||||
|
{ USB_DEVICE_INTERFACE_NUMBER(INFINEON_VID, INFINEON_TRIBOARD_PID, 1) },
|
||||||
{ } /* Terminating entry */
|
{ } /* Terminating entry */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -583,6 +583,12 @@
|
|||||||
#define RATOC_VENDOR_ID 0x0584
|
#define RATOC_VENDOR_ID 0x0584
|
||||||
#define RATOC_PRODUCT_ID_USB60F 0xb020
|
#define RATOC_PRODUCT_ID_USB60F 0xb020
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Infineon Technologies
|
||||||
|
*/
|
||||||
|
#define INFINEON_VID 0x058b
|
||||||
|
#define INFINEON_TRIBOARD_PID 0x0028 /* DAS JTAG TriBoard TC1798 V1.0 */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Acton Research Corp.
|
* Acton Research Corp.
|
||||||
*/
|
*/
|
||||||
@ -798,7 +804,8 @@
|
|||||||
* Submitted by Colin Leroy
|
* Submitted by Colin Leroy
|
||||||
*/
|
*/
|
||||||
#define TESTO_VID 0x128D
|
#define TESTO_VID 0x128D
|
||||||
#define TESTO_USB_INTERFACE_PID 0x0001
|
#define TESTO_1_PID 0x0001
|
||||||
|
#define TESTO_3_PID 0x0003
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Mobility Electronics products.
|
* Mobility Electronics products.
|
||||||
|
@ -1487,6 +1487,8 @@ static const struct usb_device_id option_ids[] = {
|
|||||||
.driver_info = (kernel_ulong_t)&net_intf2_blacklist },
|
.driver_info = (kernel_ulong_t)&net_intf2_blacklist },
|
||||||
{ USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1426, 0xff, 0xff, 0xff), /* ZTE MF91 */
|
{ USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1426, 0xff, 0xff, 0xff), /* ZTE MF91 */
|
||||||
.driver_info = (kernel_ulong_t)&net_intf2_blacklist },
|
.driver_info = (kernel_ulong_t)&net_intf2_blacklist },
|
||||||
|
{ USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1428, 0xff, 0xff, 0xff), /* Telewell TW-LTE 4G v2 */
|
||||||
|
.driver_info = (kernel_ulong_t)&net_intf2_blacklist },
|
||||||
{ USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1533, 0xff, 0xff, 0xff) },
|
{ USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1533, 0xff, 0xff, 0xff) },
|
||||||
{ USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1534, 0xff, 0xff, 0xff) },
|
{ USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1534, 0xff, 0xff, 0xff) },
|
||||||
{ USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1535, 0xff, 0xff, 0xff) },
|
{ USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x1535, 0xff, 0xff, 0xff) },
|
||||||
|
Loading…
x
Reference in New Issue
Block a user