driving a 2-DSI panel whose 2 links need receive command simultaneously.
 - interrupt-parent: phandle to the MDP block if the interrupt signal is routed
   through MDP block
+- pinctrl-names: the pin control state names; should contain "default"
+- pinctrl-0: the default pinctrl state (active)
+- pinctrl-n: the "sleep" pinctrl state
 
 DSI PHY:
 Required properties:
                qcom,master-dsi;
                qcom,sync-dual-dsi;
 
+               pinctrl-names = "default", "sleep";
+               pinctrl-0 = <&mdss_dsi_active>;
+               pinctrl-1 = <&mdss_dsi_suspend>;
+
                panel: panel@0 {
                        compatible = "sharp,lq101r1sx01";
                        reg = <0>;
 
 #include <linux/of_device.h>
 #include <linux/of_gpio.h>
 #include <linux/of_irq.h>
+#include <linux/pinctrl/consumer.h>
 #include <linux/regulator/consumer.h>
 #include <linux/spinlock.h>
 #include <video/mipi_display.h>
                goto fail_disable_reg;
        }
 
+       ret = pinctrl_pm_select_default_state(&msm_host->pdev->dev);
+       if (ret) {
+               pr_err("%s: failed to set pinctrl default state, %d\n",
+                       __func__, ret);
+               goto fail_disable_clk;
+       }
+
        dsi_timing_setup(msm_host);
        dsi_sw_reset(msm_host);
        dsi_ctrl_config(msm_host, true, clk_pre, clk_post);
 
        return 0;
 
+fail_disable_clk:
+       dsi_clk_ctrl(msm_host, 0);
 fail_disable_reg:
        dsi_host_regulator_disable(msm_host);
 unlock_ret:
        if (msm_host->disp_en_gpio)
                gpiod_set_value(msm_host->disp_en_gpio, 0);
 
+       pinctrl_pm_select_sleep_state(&msm_host->pdev->dev);
+
        msm_dsi_manager_phy_disable(msm_host->id);
 
        dsi_clk_ctrl(msm_host, 0);