.pmu_offset = 0x1004,
        .spare_offset = 0x1088,
 
-       .pd_names = { "mx", "cx" },
+       .pd_names = { "cx", "mx" },
        .vregs = (struct wcnss_vreg_info[]) {
-               { "vddmx", 950000, 1150000, 0 },
                { "vddcx", .super_turbo = true},
+               { "vddmx", 950000, 1150000, 0 },
                { "vddpx", 1800000, 1800000, 0 },
        },
        .num_pd_vregs = 2,
        .pmu_offset = 0x1004,
        .spare_offset = 0x1088,
 
-       .pd_names = { "mx", "cx" },
+       .pd_names = { "cx", "mx" },
        .vregs = (struct wcnss_vreg_info[]) {
-               { "vddmx", 1287500, 1287500, 0 },
                { "vddcx", .super_turbo = true },
+               { "vddmx", 1287500, 1287500, 0 },
                { "vddpx", 1800000, 1800000, 0 },
        },
        .num_pd_vregs = 2,
 static int wcnss_init_pds(struct qcom_wcnss *wcnss,
                          const char * const pd_names[WCNSS_MAX_PDS])
 {
+       struct device *dev = wcnss->dev;
        int i, ret;
 
+       /* Handle single power domain */
+       if (dev->pm_domain) {
+               wcnss->pds[0] = dev;
+               wcnss->num_pds = 1;
+               pm_runtime_enable(dev);
+               return 0;
+       }
+
        for (i = 0; i < WCNSS_MAX_PDS; i++) {
                if (!pd_names[i])
                        break;
 
 static void wcnss_release_pds(struct qcom_wcnss *wcnss)
 {
+       struct device *dev = wcnss->dev;
        int i;
 
+       /* Handle single power domain */
+       if (wcnss->num_pds == 1 && dev->pm_domain) {
+               pm_runtime_disable(dev);
+               return;
+       }
+
        for (i = 0; i < wcnss->num_pds; i++)
                dev_pm_domain_detach(wcnss->pds[i], false);
 }
         * the regulators for the power domains. For old device trees we need to
         * reserve extra space to manage them through the regulator interface.
         */
-       if (wcnss->num_pds)
-               info += num_pd_vregs;
-       else
+       if (wcnss->num_pds) {
+               info += wcnss->num_pds;
+               /* Handle single power domain case */
+               num_vregs += num_pd_vregs - wcnss->num_pds;
+       } else {
                num_vregs += num_pd_vregs;
+       }
 
        bulk = devm_kcalloc(wcnss->dev,
                            num_vregs, sizeof(struct regulator_bulk_data),