*/
 #include <linux/auxiliary_bus.h>
 #include <linux/bitfield.h>
+#include <linux/cleanup.h>
 #include <linux/module.h>
 #include <linux/of.h>
 #include <linux/of_device.h>
         * The USBC_CMD_WRITE_REQ ack doesn't identify the request, so wait for
         * one ack at a time.
         */
-       mutex_lock(&altmode->lock);
+       guard(mutex)(&altmode->lock);
 
        req.hdr.owner = cpu_to_le32(altmode->owner_id);
        req.hdr.type = cpu_to_le32(PMIC_GLINK_REQ_RESP);
        ret = pmic_glink_send(altmode->client, &req, sizeof(req));
        if (ret) {
                dev_err(altmode->dev, "failed to send altmode request: %#x (%d)\n", cmd, ret);
-               goto out_unlock;
+               return ret;
        }
 
        left = wait_for_completion_timeout(&altmode->pan_ack, 5 * HZ);
        if (!left) {
                dev_err(altmode->dev, "timeout waiting for altmode request ack for: %#x\n", cmd);
-               ret = -ETIMEDOUT;
+               return -ETIMEDOUT;
        }
 
-out_unlock:
-       mutex_unlock(&altmode->lock);
-       return ret;
+       return 0;
 }
 
 static void pmic_glink_altmode_enable_dp(struct pmic_glink_altmode *altmode,