@@ -970,12 +970,25 @@ static int tmio_mmc_get_ro(struct mmc_host *mmc)
return ret;
}
+static int tmio_blk_size_workaround(struct mmc_card *card,
+ struct request *req, int blk_size)
+{
+ struct tmio_mmc_host *host = mmc_priv(card->host);
+ struct tmio_mmc_data *pdata = host->pdata;
+
+ if (pdata->blk_size_workaround)
+ return pdata->blk_size_workaround(card, req, blk_size);
+
+ return blk_size;
+}
+
static const struct mmc_host_ops tmio_mmc_ops = {
.request = tmio_mmc_request,
.set_ios = tmio_mmc_set_ios,
.get_ro = tmio_mmc_get_ro,
.get_cd = mmc_gpio_get_cd,
.enable_sdio_irq = tmio_mmc_enable_sdio_irq,
+ .blk_size_workaround = tmio_blk_size_workaround,
};
static int tmio_mmc_init_ocr(struct tmio_mmc_host *host)
@@ -1,10 +1,12 @@
#ifndef MFD_TMIO_H
#define MFD_TMIO_H
+#include <linux/blkdev.h>
#include <linux/device.h>
#include <linux/fb.h>
#include <linux/io.h>
#include <linux/jiffies.h>
+#include <linux/mmc/card.h>
#include <linux/platform_device.h>
#include <linux/pm_runtime.h>
@@ -142,6 +144,8 @@ struct tmio_mmc_data {
/* clock management callbacks */
int (*clk_enable)(struct platform_device *pdev, unsigned int *f);
void (*clk_disable)(struct platform_device *pdev);
+ int (*blk_size_workaround)(struct mmc_card *card,
+ struct request *req, int blk_size);
};
/*