#include <linux/pci.h>
 #include <linux/mmc/mmc.h>
 #include <linux/delay.h>
+#include <linux/of.h>
 #include "sdhci.h"
 #include "sdhci-pci.h"
 #include "cqhci.h"
 #define PCI_GLI_9755_PECONF   0x44
 #define   PCI_GLI_9755_LFCLK    GENMASK(14, 12)
 #define   PCI_GLI_9755_DMACLK   BIT(29)
+#define   PCI_GLI_9755_INVERT_CD  BIT(30)
+#define   PCI_GLI_9755_INVERT_WP  BIT(31)
 
 #define PCI_GLI_9755_CFG2          0x48
 #define   PCI_GLI_9755_CFG2_L1DLY    GENMASK(28, 24)
        gl9755_wt_on(pdev);
 
        pci_read_config_dword(pdev, PCI_GLI_9755_PECONF, &value);
+       /*
+        * Apple ARM64 platforms using these chips may have
+        * inverted CD/WP detection.
+        */
+       if (of_property_read_bool(pdev->dev.of_node, "cd-inverted"))
+               value |= PCI_GLI_9755_INVERT_CD;
+       if (of_property_read_bool(pdev->dev.of_node, "wp-inverted"))
+               value |= PCI_GLI_9755_INVERT_WP;
        value &= ~PCI_GLI_9755_LFCLK;
        value &= ~PCI_GLI_9755_DMACLK;
        pci_write_config_dword(pdev, PCI_GLI_9755_PECONF, value);