};
 
 #define QCOM_PCIE_2_3_3_MAX_CLOCKS             5
+#define QCOM_PCIE_2_3_3_MAX_RESETS             7
 struct qcom_pcie_resources_2_3_3 {
        struct clk_bulk_data clks[QCOM_PCIE_2_3_3_MAX_CLOCKS];
-       struct reset_control *rst[7];
+       struct reset_control_bulk_data rst[QCOM_PCIE_2_3_3_MAX_RESETS];
 };
 
 #define QCOM_PCIE_2_4_0_MAX_CLOCKS     4
        struct qcom_pcie_resources_2_3_3 *res = &pcie->res.v2_3_3;
        struct dw_pcie *pci = pcie->pci;
        struct device *dev = pci->dev;
-       int i;
-       const char *rst_names[] = { "axi_m", "axi_s", "pipe",
-                                   "axi_m_sticky", "sticky",
-                                   "ahb", "sleep", };
        int ret;
 
        res->clks[0].id = "iface";
        if (ret < 0)
                return ret;
 
-       for (i = 0; i < ARRAY_SIZE(rst_names); i++) {
-               res->rst[i] = devm_reset_control_get(dev, rst_names[i]);
-               if (IS_ERR(res->rst[i]))
-                       return PTR_ERR(res->rst[i]);
-       }
+       res->rst[0].id = "axi_m";
+       res->rst[1].id = "axi_s";
+       res->rst[2].id = "pipe";
+       res->rst[3].id = "axi_m_sticky";
+       res->rst[4].id = "sticky";
+       res->rst[5].id = "ahb";
+       res->rst[6].id = "sleep";
+
+       ret = devm_reset_control_bulk_get_exclusive(dev, ARRAY_SIZE(res->rst), res->rst);
+       if (ret < 0)
+               return ret;
 
        return 0;
 }
        struct qcom_pcie_resources_2_3_3 *res = &pcie->res.v2_3_3;
        struct dw_pcie *pci = pcie->pci;
        struct device *dev = pci->dev;
-       int i, ret;
+       int ret;
 
-       for (i = 0; i < ARRAY_SIZE(res->rst); i++) {
-               ret = reset_control_assert(res->rst[i]);
-               if (ret) {
-                       dev_err(dev, "reset #%d assert failed (%d)\n", i, ret);
-                       return ret;
-               }
+       ret = reset_control_bulk_assert(ARRAY_SIZE(res->rst), res->rst);
+       if (ret < 0) {
+               dev_err(dev, "cannot assert resets\n");
+               return ret;
        }
 
        usleep_range(2000, 2500);
 
-       for (i = 0; i < ARRAY_SIZE(res->rst); i++) {
-               ret = reset_control_deassert(res->rst[i]);
-               if (ret) {
-                       dev_err(dev, "reset #%d deassert failed (%d)\n", i,
-                               ret);
-                       return ret;
-               }
+       ret = reset_control_bulk_deassert(ARRAY_SIZE(res->rst), res->rst);
+       if (ret < 0) {
+               dev_err(dev, "cannot deassert resets\n");
+               return ret;
        }
 
        /*
         * Not checking for failure, will anyway return
         * the original failure in 'ret'.
         */
-       for (i = 0; i < ARRAY_SIZE(res->rst); i++)
-               reset_control_assert(res->rst[i]);
+       reset_control_bulk_assert(ARRAY_SIZE(res->rst), res->rst);
 
        return ret;
 }