if (!rcar_gen4_pcie_link_up(rcar)) {
printf("PCIE-%d: Link down\n", dev_seq(dev));
+ rcar_gen4_pcie_ltssm_control(rcar, false);
+ dm_gpio_set_value(&rcar->pe_rst, 1);
+ reset_assert(&rcar->pwr_rst);
+ clk_disable_unprepare(rcar->ref_clk);
return -ENODEV;
}
return 0;
}
+/**
+ * rcar_gen4_pcie_remove() - Stop the PCIe bus active link
+ * @dev: A pointer to the device being operated on
+ *
+ * Stop an active link on the PCIe bus and deconfigure the controller.
+ *
+ * Return: 0 on success, else -ENODEV
+ */
+static int rcar_gen4_pcie_remove(struct udevice *dev)
+{
+ struct rcar_gen4_pcie *rcar = dev_get_priv(dev);
+
+ rcar_gen4_pcie_ltssm_control(rcar, false);
+ dm_gpio_set_value(&rcar->pe_rst, 1);
+ reset_assert(&rcar->pwr_rst);
+ clk_disable_unprepare(rcar->ref_clk);
+
+ return 0;
+}
+
/**
* rcar_gen4_pcie_of_to_plat() - Translate from DT to device state
*
.ops = &rcar_gen4_pcie_ops,
.of_to_plat = rcar_gen4_pcie_of_to_plat,
.probe = rcar_gen4_pcie_probe,
+ .remove = rcar_gen4_pcie_remove,
.priv_auto = sizeof(struct rcar_gen4_pcie),
+ .flags = DM_FLAG_ACTIVE_DMA,
};