sdio.o sdio_ops.o sdio_bus.o \
                                   sdio_cis.o sdio_io.o sdio_irq.o \
                                   quirks.o slot-gpio.o
-
+mmc_core-$(CONFIG_OF)          += pwrseq.o
 mmc_core-$(CONFIG_DEBUG_FS)    += debugfs.o
 
 #include "bus.h"
 #include "host.h"
 #include "sdio_bus.h"
+#include "pwrseq.h"
 
 #include "mmc_ops.h"
 #include "sd_ops.h"
 
        mmc_host_clk_hold(host);
 
+       mmc_pwrseq_pre_power_on(host);
+
        host->ios.vdd = fls(ocr) - 1;
        host->ios.power_mode = MMC_POWER_UP;
        /* Set initial state and call mmc_set_ios */
         */
        mmc_delay(10);
 
+       mmc_pwrseq_post_power_on(host);
+
        mmc_host_clk_release(host);
 }
 
 
        mmc_host_clk_hold(host);
 
+       mmc_pwrseq_power_off(host);
+
        host->ios.clock = 0;
        host->ios.vdd = 0;
 
 
 #include "core.h"
 #include "host.h"
 #include "slot-gpio.h"
+#include "pwrseq.h"
 
 #define cls_dev_to_mmc_host(d) container_of(d, struct mmc_host, class_dev)
 
                host->dsr_req = 0;
        }
 
-       return 0;
+       return mmc_pwrseq_alloc(host);
 }
 
 EXPORT_SYMBOL(mmc_of_parse);
  */
 void mmc_free_host(struct mmc_host *host)
 {
+       mmc_pwrseq_free(host);
        put_device(&host->class_dev);
 }
 
 
--- /dev/null
+/*
+ *  Copyright (C) 2014 Linaro Ltd
+ *
+ * Author: Ulf Hansson <ulf.hansson@linaro.org>
+ *
+ * License terms: GNU General Public License (GPL) version 2
+ *
+ *  MMC power sequence management
+ */
+#include <linux/mmc/host.h>
+
+#include "pwrseq.h"
+
+
+int mmc_pwrseq_alloc(struct mmc_host *host)
+{
+       return 0;
+}
+
+void mmc_pwrseq_pre_power_on(struct mmc_host *host)
+{
+       struct mmc_pwrseq *pwrseq = host->pwrseq;
+
+       if (pwrseq && pwrseq->ops && pwrseq->ops->pre_power_on)
+               pwrseq->ops->pre_power_on(host);
+}
+
+void mmc_pwrseq_post_power_on(struct mmc_host *host)
+{
+       struct mmc_pwrseq *pwrseq = host->pwrseq;
+
+       if (pwrseq && pwrseq->ops && pwrseq->ops->post_power_on)
+               pwrseq->ops->post_power_on(host);
+}
+
+void mmc_pwrseq_power_off(struct mmc_host *host)
+{
+       struct mmc_pwrseq *pwrseq = host->pwrseq;
+
+       if (pwrseq && pwrseq->ops && pwrseq->ops->power_off)
+               pwrseq->ops->power_off(host);
+}
+
+void mmc_pwrseq_free(struct mmc_host *host)
+{
+       struct mmc_pwrseq *pwrseq = host->pwrseq;
+
+       if (pwrseq && pwrseq->ops && pwrseq->ops->free)
+               pwrseq->ops->free(host);
+}
 
--- /dev/null
+/*
+ * Copyright (C) 2014 Linaro Ltd
+ *
+ * Author: Ulf Hansson <ulf.hansson@linaro.org>
+ *
+ * License terms: GNU General Public License (GPL) version 2
+ */
+#ifndef _MMC_CORE_PWRSEQ_H
+#define _MMC_CORE_PWRSEQ_H
+
+struct mmc_pwrseq_ops {
+       void (*pre_power_on)(struct mmc_host *host);
+       void (*post_power_on)(struct mmc_host *host);
+       void (*power_off)(struct mmc_host *host);
+       void (*free)(struct mmc_host *host);
+};
+
+struct mmc_pwrseq {
+       struct mmc_pwrseq_ops *ops;
+};
+
+#ifdef CONFIG_OF
+
+int mmc_pwrseq_alloc(struct mmc_host *host);
+void mmc_pwrseq_pre_power_on(struct mmc_host *host);
+void mmc_pwrseq_post_power_on(struct mmc_host *host);
+void mmc_pwrseq_power_off(struct mmc_host *host);
+void mmc_pwrseq_free(struct mmc_host *host);
+
+#else
+
+static inline int mmc_pwrseq_alloc(struct mmc_host *host) { return 0; }
+static inline void mmc_pwrseq_pre_power_on(struct mmc_host *host) {}
+static inline void mmc_pwrseq_post_power_on(struct mmc_host *host) {}
+static inline void mmc_pwrseq_power_off(struct mmc_host *host) {}
+static inline void mmc_pwrseq_free(struct mmc_host *host) {}
+
+#endif
+
+#endif
 
 };
 
 struct regulator;
+struct mmc_pwrseq;
 
 struct mmc_supply {
        struct regulator *vmmc;         /* Card power supply */
        struct device           class_dev;
        int                     index;
        const struct mmc_host_ops *ops;
+       struct mmc_pwrseq       *pwrseq;
        unsigned int            f_min;
        unsigned int            f_max;
        unsigned int            f_init;