According to JEDEC 7.8.2, mmc_erase_timeout calculation should be follow: 1. Secure erase timeout = 300ms * ERASE_TIMEOUT_MULT * SEC_ERASE_MULT 2. Secure trim timeout = 300ms * ERASE_TIMEOUT_MULT * SEC_TRIM_MULT 3. Trim timeout = 300ms * TRIM_MULT 4. Erase timeout: a. if ERASE_GROUP_DEF is true: Erase timeout = 300ms * ERASE_TIMEOUT_MULT b. if ERASE_GROUP_DEF is false: Erase timeout = write block delay Signed-off-by: Chuanxiao Dong <chuanxiao.dong@xxxxxxxxx> --- drivers/mmc/core/core.c | 42 +++++++++++++++++++++++++++++------------- 1 files changed, 29 insertions(+), 13 deletions(-) diff --git a/drivers/mmc/core/core.c b/drivers/mmc/core/core.c index 14f262e..d9d6d1c 100644 --- a/drivers/mmc/core/core.c +++ b/drivers/mmc/core/core.c @@ -1405,12 +1405,36 @@ static unsigned int mmc_mmc_erase_timeout(struct mmc_card *card, { unsigned int erase_timeout; - if (card->ext_csd.erase_group_def & 1) { - /* High Capacity Erase Group Size uses HC timeouts */ - if (arg == MMC_TRIM_ARG) - erase_timeout = card->ext_csd.trim_timeout; + /* + * JEDEC 7.8.2 + * + * 1. Secure erase/trim timeout is calculated absed on Erase Timeout + * and additional SEC_ERASE_MULT/SEC_TRIM_MULT. + * So secure erase/trim timeout = ERASE Timeout * SEC_ERASE_MULT/ + * SEC_TRIM_MULT. + * ERASE Timeout = 300ms * ERASE_TIMEOUT_MULT + * + * 2. trim timeout is calculated based on the TRIM_MULT factor. + * So trim timeout = 300ms * TRIM_MULT + * + * 3. erase timeout calculation: + * a. if ERASE_GROUP_DEF is enabled, ERASE_TIMEOUT_MULT should be + * used to calculate erase timeout, so: + * erase timeout = 300 * ERASE_TIMEOUT_MULT + * b. if ERASE_GROUP_DEF is diabled, the duration of an erase + * command will be the number of Erase blocks to be erased + * multiplied by the block write delay. + */ + if (arg & MMC_SECURE_ARGS) { + erase_timeout = card->ext_csd.hc_erase_timeout; + if (arg == MMC_SECURE_ERASE_ARG) + erase_timeout *= card->ext_csd.sec_erase_mult; else - erase_timeout = card->ext_csd.hc_erase_timeout; + erase_timeout *= card->ext_csd.sec_trim_mult; + } else if (arg & MMC_TRIM_ARGS) { + erase_timeout = card->ext_csd.trim_timeout; + } else if (card->ext_csd.erase_group_def & 1) { + erase_timeout = card->ext_csd.hc_erase_timeout; } else { /* CSD Erase Group Size uses write timeout */ unsigned int mult = (10 << card->csd.r2w_factor); @@ -1441,14 +1465,6 @@ static unsigned int mmc_mmc_erase_timeout(struct mmc_card *card, erase_timeout = 1; } - /* Multiplier for secure operations */ - if (arg & MMC_SECURE_ARGS) { - if (arg == MMC_SECURE_ERASE_ARG) - erase_timeout *= card->ext_csd.sec_erase_mult; - else - erase_timeout *= card->ext_csd.sec_trim_mult; - } - erase_timeout *= qty; /* -- 1.7.1 -- To unsubscribe from this list: send the line "unsubscribe linux-mmc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html