#include <linux/module.h>
#include <linux/dma-mapping.h>
#include <linux/mtd/mtd.h>
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5,9,0)
+#include <linux/mtd/nand.h>
+#endif
#include <linux/mtd/rawnand.h>
#include <linux/mtd/partitions.h>
#include <linux/platform_device.h>
break;
case NAND_CMD_PAGEPROG:
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5,9,0)
+ if (nand->ecc.engine_type == NAND_ECC_ENGINE_TYPE_ON_HOST) {
+#else
if (nand->ecc.mode == NAND_ECC_HW) {
+#endif
/* the data is already written */
break;
}
if (ret)
return ret;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5,9,0)
+ if (nand->ecc.engine_type == NAND_ECC_ENGINE_TYPE_ON_HOST) {
+#else
if (nand->ecc.mode == NAND_ECC_HW) {
+#endif
ret = ar934x_nfc_setup_hwecc(nfc);
if (ret)
return ret;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5,9,0)
+ } else if (nand->ecc.engine_type == NAND_ECC_ENGINE_TYPE_SOFT) {
+ dev_err(dev, "unknown ECC mode %d\n", nand->ecc.engine_type);
+#else
} else if (nand->ecc.mode != NAND_ECC_SOFT) {
dev_err(dev, "unknown ECC mode %d\n", nand->ecc.mode);
+#endif
return -EINVAL;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5,9,0)
+ } else if ((nand->ecc.algo != NAND_ECC_ALGO_BCH) &&
+ (nand->ecc.algo != NAND_ECC_ALGO_HAMMING)) {
+#else
} else if ((nand->ecc.algo != NAND_ECC_BCH) &&
(nand->ecc.algo != NAND_ECC_HAMMING)) {
+#endif
dev_err(dev, "unknown software ECC algo %d\n", nand->ecc.algo);
return -EINVAL;
}
nand->legacy.read_byte = ar934x_nfc_read_byte;
nand->legacy.write_buf = ar934x_nfc_write_buf;
nand->legacy.read_buf = ar934x_nfc_read_buf;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5,9,0)
+ nand->ecc.engine_type = NAND_ECC_ENGINE_TYPE_ON_HOST; /* default */
+#else
nand->ecc.mode = NAND_ECC_HW; /* default */
+#endif
nand->priv = nfc;
platform_set_drvdata(pdev, nfc);
nfc = platform_get_drvdata(pdev);
if (nfc) {
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5,8,0)
+ mtd_device_unregister(nand_to_mtd(&nfc->nand_chip));
+ nand_cleanup(&nfc->nand_chip);
+#else
nand_release(&nfc->nand_chip);
+#endif
ar934x_nfc_free_buf(nfc);
}