]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
usb: typec: Update sysfs when setting ops
authorAbhishek Pandit-Subedi <abhishekpandit@chromium.org>
Fri, 10 May 2024 20:12:42 +0000 (20:12 +0000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 4 Jun 2024 13:44:27 +0000 (15:44 +0200)
When adding altmode ops, update the sysfs group so that visibility is
also recalculated.

Reviewed-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
Reviewed-by: Benson Leung <bleung@chromium.org>
Signed-off-by: Abhishek Pandit-Subedi <abhishekpandit@chromium.org>
Signed-off-by: Jameson Thies <jthies@google.com>
Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Link: https://lore.kernel.org/r/20240510201244.2968152-3-jthies@google.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/typec/altmodes/displayport.c
drivers/usb/typec/class.c
drivers/usb/typec/ucsi/displayport.c
include/linux/usb/typec.h

index 596cd4806018b9a302e7d12248e25b2f719b3fa8..92cc1b13612084198fce715c6af317906f0599a5 100644 (file)
@@ -746,7 +746,7 @@ int dp_altmode_probe(struct typec_altmode *alt)
        dp->alt = alt;
 
        alt->desc = "DisplayPort";
-       alt->ops = &dp_altmode_ops;
+       typec_altmode_set_ops(alt, &dp_altmode_ops);
 
        if (plug) {
                plug->desc = "Displayport";
index 9610e647a8d48006e776019c1ddc9eb6a7fddd4a..9262fcd4144f85ab3f089f820c2063fbe634b0d1 100644 (file)
@@ -467,6 +467,22 @@ static const struct attribute_group *typec_altmode_groups[] = {
        NULL
 };
 
+/**
+ * typec_altmode_set_ops - Set ops for altmode
+ * @adev: Handle to the alternate mode
+ * @ops: Ops for the alternate mode
+ *
+ * After setting ops, attribute visiblity needs to be refreshed if the alternate
+ * mode can be activated.
+ */
+void typec_altmode_set_ops(struct typec_altmode *adev,
+                          const struct typec_altmode_ops *ops)
+{
+       adev->ops = ops;
+       sysfs_update_group(&adev->dev.kobj, &typec_altmode_group);
+}
+EXPORT_SYMBOL_GPL(typec_altmode_set_ops);
+
 static int altmode_id_get(struct device *dev)
 {
        struct ida *ids;
@@ -2317,7 +2333,7 @@ void typec_port_register_altmodes(struct typec_port *port,
                        continue;
                }
 
-               alt->ops = ops;
+               typec_altmode_set_ops(alt, ops);
                typec_altmode_set_drvdata(alt, drvdata);
                altmodes[index] = alt;
                index++;
index 8be92fc1d12c95c820f55c1479b8eb782bd85034..420af5139c70a3505e7aa9176108663481de4fe9 100644 (file)
@@ -333,7 +333,7 @@ struct typec_altmode *ucsi_register_displayport(struct ucsi_connector *con,
        dp->con = con;
        dp->alt = alt;
 
-       alt->ops = &ucsi_displayport_ops;
+       typec_altmode_set_ops(alt, &ucsi_displayport_ops);
        typec_altmode_set_drvdata(alt, dp);
 
        return alt;
index b35b427561ab53057de15d07110a8e306d6d77ef..549275f8ac1b385cf6ead37a06566cd2e6a4ba44 100644 (file)
@@ -167,6 +167,9 @@ struct typec_port *typec_altmode2port(struct typec_altmode *alt);
 
 void typec_altmode_update_active(struct typec_altmode *alt, bool active);
 
+void typec_altmode_set_ops(struct typec_altmode *alt,
+                          const struct typec_altmode_ops *ops);
+
 enum typec_plug_index {
        TYPEC_PLUG_SOP_P,
        TYPEC_PLUG_SOP_PP,