reset_control_put(data);
 }
 
+static void __iomem *qmp_usb_iomap(struct device *dev, struct device_node *np,
+               int index, bool exclusive)
+{
+       struct resource res;
+
+       if (!exclusive) {
+               if (of_address_to_resource(np, index, &res))
+                       return IOMEM_ERR_PTR(-EINVAL);
+
+               return devm_ioremap(dev, res.start, resource_size(&res));
+       }
+
+       return devm_of_iomap(dev, np, index, NULL);
+}
+
 static
 int qcom_qmp_phy_create(struct device *dev, struct device_node *np, int id,
                        void __iomem *serdes, const struct qmp_phy_cfg *cfg)
        struct qmp_phy *qphy;
        const struct phy_ops *ops;
        char prop_name[MAX_PROP_NAME];
+       bool exclusive = true;
        int ret;
 
+       /*
+        * FIXME: These bindings should be fixed to not rely on overlapping
+        *        mappings for PCS.
+        */
+       if (of_device_is_compatible(dev->of_node, "qcom,sdx65-qmp-usb3-uni-phy"))
+               exclusive = false;
+       if (of_device_is_compatible(dev->of_node, "qcom,sm8350-qmp-usb3-uni-phy"))
+               exclusive = false;
+
        qphy = devm_kzalloc(dev, sizeof(*qphy), GFP_KERNEL);
        if (!qphy)
                return -ENOMEM;
        if (IS_ERR(qphy->rx))
                return PTR_ERR(qphy->rx);
 
-       qphy->pcs = devm_of_iomap(dev, np, 2, NULL);
+       qphy->pcs = qmp_usb_iomap(dev, np, 2, exclusive);
        if (IS_ERR(qphy->pcs))
                return PTR_ERR(qphy->pcs);