]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
imx6: Remove AHCI device before boot OS
authorYe Li <ye.li@nxp.com>
Tue, 23 Jul 2019 03:51:25 +0000 (20:51 -0700)
committerStefano Babic <sbabic@denx.de>
Sat, 23 Jan 2021 10:30:31 +0000 (11:30 +0100)
Since we remove SATA device before boot OS, when AHCI is enabled, update
the codes to remove AHCI device.

Signed-off-by: Ye Li <ye.li@nxp.com>
Signed-off-by: Peng Fan <peng.fan@nxp.com>
arch/arm/mach-imx/cpu.c

index 425d0f03277ee590a04b000ade120dadd7b0de44..af0b7fbf7b44398614d90ad3601eea4b51e6e801 100644 (file)
@@ -24,6 +24,8 @@
 #include <ipu_pixfmt.h>
 #include <thermal.h>
 #include <sata.h>
+#include <dm/device-internal.h>
+#include <dm/uclass-internal.h>
 
 #ifdef CONFIG_FSL_ESDHC_IMX
 #include <fsl_esdhc_imx.h>
@@ -278,6 +280,20 @@ void arch_preboot_os(void)
 #if defined(CONFIG_PCIE_IMX) && !CONFIG_IS_ENABLED(DM_PCI)
        imx_pcie_remove();
 #endif
+
+#if defined(CONFIG_IMX_AHCI)
+       struct udevice *dev;
+       int rc;
+
+       rc = uclass_find_device(UCLASS_AHCI, 0, &dev);
+       if (!rc && dev) {
+               rc = device_remove(dev, DM_REMOVE_NORMAL);
+               if (rc)
+                       printf("Cannot remove SATA device '%s' (err=%d)\n",
+                               dev->name, rc);
+       }
+#endif
+
 #if defined(CONFIG_SATA)
        if (!is_mx6sdl()) {
                sata_remove(0);