]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
usb: typec: tcpci_rt1711h: Drop unnecessary VID/PID/DID checks
authorAlexey Charkov <alchark@flipper.net>
Wed, 18 Mar 2026 14:32:56 +0000 (18:32 +0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 30 Mar 2026 14:53:11 +0000 (16:53 +0200)
Existing checks for VID/PID/DID in the driver are redundant since the
driver is already matched to the device via I2C device ID and OF
compatible strings, and they preclude the use of fallback compatibles.

Remove them to make the driver slimmer and adding new clones easier.

Reviewed-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
Signed-off-by: Alexey Charkov <alchark@flipper.net>
Link: https://patch.msgid.link/20260318-husb311-v4-4-69e029255430@flipper.net
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/typec/tcpm/tcpci_rt1711h.c

index 37cf55ad74f84b79e05c349a5e5cf9217dadca66..4b3e4e22a82e803d9f63e8c73904c885fbf03177 100644 (file)
 #include <linux/regmap.h>
 #include <linux/regulator/consumer.h>
 
-#define RT1711H_VID            0x29CF
-#define ET7304_VID             0x6DCF
-#define RT1711H_PID            0x1711
-#define RT1711H_DID            0x2171
-#define RT1715_DID             0x2173
-#define ET7304_DID             0x2173
-
 #define RT1711H_PHYCTRL1       0x80
 #define RT1711H_PHYCTRL2       0x81
 
@@ -57,8 +50,6 @@
 
 struct rt1711h_chip_info {
        u32 rxdz_sel;
-       u16 vid;
-       u16 did;
        bool enable_pd30_extended_message;
 };
 
@@ -304,35 +295,6 @@ static int rt1711h_sw_reset(struct rt1711h_chip *chip)
        return 0;
 }
 
-static int rt1711h_check_revision(struct i2c_client *i2c, struct rt1711h_chip *chip)
-{
-       int ret;
-
-       ret = i2c_smbus_read_word_data(i2c, TCPC_VENDOR_ID);
-       if (ret < 0)
-               return ret;
-       if (ret != chip->info->vid) {
-               dev_err(&i2c->dev, "vid is not correct, 0x%04x\n", ret);
-               return -ENODEV;
-       }
-       ret = i2c_smbus_read_word_data(i2c, TCPC_PRODUCT_ID);
-       if (ret < 0)
-               return ret;
-       if (ret != RT1711H_PID) {
-               dev_err(&i2c->dev, "pid is not correct, 0x%04x\n", ret);
-               return -ENODEV;
-       }
-       ret = i2c_smbus_read_word_data(i2c, TCPC_BCD_DEV);
-       if (ret < 0)
-               return ret;
-       if (ret != chip->info->did) {
-               dev_err(&i2c->dev, "did is not correct, 0x%04x\n", ret);
-               return -ENODEV;
-       }
-       dev_dbg(&i2c->dev, "did is 0x%04x\n", ret);
-       return ret;
-}
-
 static int rt1711h_probe(struct i2c_client *client)
 {
        int ret;
@@ -349,12 +311,6 @@ static int rt1711h_probe(struct i2c_client *client)
 
        chip->info = i2c_get_match_data(client);
 
-       ret = rt1711h_check_revision(client, chip);
-       if (ret < 0) {
-               dev_err(&client->dev, "check vid/pid fail\n");
-               return ret;
-       }
-
        chip->data.regmap = devm_regmap_init_i2c(client,
                                                 &rt1711h_regmap_config);
        if (IS_ERR(chip->data.regmap))
@@ -408,27 +364,16 @@ static void rt1711h_remove(struct i2c_client *client)
        tcpci_unregister_port(chip->tcpci);
 }
 
-static const struct rt1711h_chip_info et7304 = {
-       .rxdz_sel = RT1711H_BMCIO_RXDZSEL,
-       .vid = ET7304_VID,
-       .did = ET7304_DID,
-       .enable_pd30_extended_message = true,
-};
-
 static const struct rt1711h_chip_info rt1711h = {
-       .vid = RT1711H_VID,
-       .did = RT1711H_DID,
 };
 
 static const struct rt1711h_chip_info rt1715 = {
        .rxdz_sel = RT1711H_BMCIO_RXDZSEL,
-       .vid = RT1711H_VID,
-       .did = RT1715_DID,
        .enable_pd30_extended_message = true,
 };
 
 static const struct i2c_device_id rt1711h_id[] = {
-       { "et7304", (kernel_ulong_t)&et7304 },
+       { "et7304", (kernel_ulong_t)&rt1715 },
        { "rt1711h", (kernel_ulong_t)&rt1711h },
        { "rt1715", (kernel_ulong_t)&rt1715 },
        {}
@@ -436,7 +381,7 @@ static const struct i2c_device_id rt1711h_id[] = {
 MODULE_DEVICE_TABLE(i2c, rt1711h_id);
 
 static const struct of_device_id rt1711h_of_match[] = {
-       { .compatible = "etekmicro,et7304", .data = &et7304 },
+       { .compatible = "etekmicro,et7304", .data = &rt1715 },
        { .compatible = "richtek,rt1711h", .data = &rt1711h },
        { .compatible = "richtek,rt1715", .data = &rt1715 },
        {}