@@ -4967,6 +4967,13 @@ static const char * const nand_ecc_modes[] = {
[NAND_ECC_ON_DIE] = "on-die",
};
+static const char * const nand_ecc_engine_providers[] = {
+ [NAND_ECC_ENGINE_NONE] = "none",
+ [NAND_ECC_ENGINE_SOFT] = "soft",
+ [NAND_ECC_ENGINE_CONTROLLER] = "hw",
+ [NAND_ECC_ENGINE_ON_DIE] = "on-die",
+};
+
static const char * const nand_ecc_placement[] = {
[NAND_ECC_PLACEMENT_INTERLEAVED] = "interleaved",
};
@@ -92,6 +92,22 @@ enum nand_ecc_mode {
NAND_ECC_ON_DIE,
};
+/**
+ * enum nand_ecc_engine_type - NAND ECC engine type/provider
+ * @NAND_ECC_ENGINE_INVALID: Invalid value
+ * @NAND_ECC_ENGINE_NONE: No ECC correction
+ * @NAND_ECC_ENGINE_SOFT: Software ECC correction
+ * @NAND_ECC_ENGINE_CONTROLLER: Hardware controller ECC correction
+ * @NAND_ECC_ENGINE_ON_DIE: On chip hardware ECC correction
+ */
+enum nand_ecc_engine_type {
+ NAND_ECC_ENGINE_INVALID,
+ NAND_ECC_ENGINE_NONE,
+ NAND_ECC_ENGINE_SOFT,
+ NAND_ECC_ENGINE_CONTROLLER,
+ NAND_ECC_ENGINE_ON_DIE,
+};
+
/**
* enum nand_ecc_placement - NAND ECC placement
* @NAND_ECC_PLACEMENT_FREE: The driver can decide where to put ECC bytes.