mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-19 03:06:35 +00:00
58acb1dd2c
This adds a bunch of patches for the v6.1 Gemini kernel. For v5.15 this was down to a single upstream patch, but for kernel v6.2 I reworked the USB code for FOTG210, so instead of carrying over the half-baked and incomplete patch from v5.15 I just backported all the v6.2 patches, 31 in total, as it creates full device USB mode for e.g. D-Link DNS-313. Signed-off-by: Linus Walleij <linus.walleij@linaro.org> Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
68 lines
2.3 KiB
Diff
68 lines
2.3 KiB
Diff
From d5a026cc8306ccd3e99e1455c87e38f8e6fa18df Mon Sep 17 00:00:00 2001
|
|
From: Linus Walleij <linus.walleij@linaro.org>
|
|
Date: Mon, 7 Nov 2022 00:05:06 +0100
|
|
Subject: [PATCH 01/29] usb: phy: phy-gpio-vbus-usb: Add device tree probing
|
|
|
|
Make it possible to probe the GPIO VBUS detection driver
|
|
from the device tree compatible for GPIO USB B connectors.
|
|
|
|
Since this driver is using the "gpio-usb-b-connector"
|
|
compatible, it is important to discern it from the role
|
|
switch connector driver (which does not provide a phy),
|
|
so we add some Kconfig text and depend on !USB_CONN_GPIO.
|
|
|
|
Cc: Rob Herring <robh@kernel.org>
|
|
Cc: Prashant Malani <pmalani@chromium.org>
|
|
Cc: Felipe Balbi <balbi@kernel.org>
|
|
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
|
|
Link: https://lore.kernel.org/r/20221106230506.1646101-1-linus.walleij@linaro.org
|
|
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
|
|
---
|
|
--- a/drivers/usb/phy/Kconfig
|
|
+++ b/drivers/usb/phy/Kconfig
|
|
@@ -93,12 +93,16 @@ config USB_GPIO_VBUS
|
|
tristate "GPIO based peripheral-only VBUS sensing 'transceiver'"
|
|
depends on GPIOLIB || COMPILE_TEST
|
|
depends on USB_GADGET || !USB_GADGET # if USB_GADGET=m, this can't be 'y'
|
|
+ depends on !USB_CONN_GPIO
|
|
select USB_PHY
|
|
help
|
|
Provides simple GPIO VBUS sensing for controllers with an
|
|
internal transceiver via the usb_phy interface, and
|
|
optionally control of a D+ pullup GPIO as well as a VBUS
|
|
- current limit regulator.
|
|
+ current limit regulator. This driver is for devices that do
|
|
+ NOT support role switch. OTG devices that can do role switch
|
|
+ (master/peripheral) shall use the USB based connection
|
|
+ detection driver USB_CONN_GPIO.
|
|
|
|
config OMAP_OTG
|
|
tristate "OMAP USB OTG controller driver"
|
|
--- a/drivers/usb/phy/phy-gpio-vbus-usb.c
|
|
+++ b/drivers/usb/phy/phy-gpio-vbus-usb.c
|
|
@@ -366,12 +366,24 @@ static const struct dev_pm_ops gpio_vbus
|
|
|
|
MODULE_ALIAS("platform:gpio-vbus");
|
|
|
|
+/*
|
|
+ * NOTE: this driver matches against "gpio-usb-b-connector" for
|
|
+ * devices that do NOT support role switch.
|
|
+ */
|
|
+static const struct of_device_id gpio_vbus_of_match[] = {
|
|
+ {
|
|
+ .compatible = "gpio-usb-b-connector",
|
|
+ },
|
|
+ {},
|
|
+};
|
|
+
|
|
static struct platform_driver gpio_vbus_driver = {
|
|
.driver = {
|
|
.name = "gpio-vbus",
|
|
#ifdef CONFIG_PM
|
|
.pm = &gpio_vbus_dev_pm_ops,
|
|
#endif
|
|
+ .of_match_table = gpio_vbus_of_match,
|
|
},
|
|
.probe = gpio_vbus_probe,
|
|
.remove = gpio_vbus_remove,
|