aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mmc/core
diff options
context:
space:
mode:
authorLukas Czerner <lczerner@redhat.com>2014-06-18 07:18:07 -0400
committerUlf Hansson <ulf.hansson@linaro.org>2014-07-26 05:13:39 -0400
commit5204d00f06ac9af4ef9c469cce7f9bbe179739b1 (patch)
treeca75ded1e602effb1e55174ef6b908a2504dc6a8 /drivers/mmc/core
parent6096d7a8c185f9267d6873ba770feb4948899e79 (diff)
mmc: Do not advertise secure discard if it is blacklisted
Currently when the device secure discard implementation is blacklisted (MMC_QUIRK_SEC_ERASE_TRIM_BROKEN quirk is set) instead of secure discard we're going to do normal discard, which is wrong. When the secure discard is known to be broken we should just disallow it entirely and not advertise this functionality to the user. Fix it. Also move mmc_fixup_device() in from of mmc_blk_alloc() so we can get quirks set before we attempt to set queue information. Signed-off-by: Lukas Czerner <lczerner@redhat.com> Acked-by: Jaehoon Chung <jh80.chung@samsung.com> Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
Diffstat (limited to 'drivers/mmc/core')
-rw-r--r--drivers/mmc/core/core.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/mmc/core/core.c b/drivers/mmc/core/core.c
index 7dc0c85fdb60..d03a080fb9cd 100644
--- a/drivers/mmc/core/core.c
+++ b/drivers/mmc/core/core.c
@@ -2102,7 +2102,8 @@ EXPORT_SYMBOL(mmc_can_sanitize);
2102 2102
2103int mmc_can_secure_erase_trim(struct mmc_card *card) 2103int mmc_can_secure_erase_trim(struct mmc_card *card)
2104{ 2104{
2105 if (card->ext_csd.sec_feature_support & EXT_CSD_SEC_ER_EN) 2105 if ((card->ext_csd.sec_feature_support & EXT_CSD_SEC_ER_EN) &&
2106 !(card->quirks & MMC_QUIRK_SEC_ERASE_TRIM_BROKEN))
2106 return 1; 2107 return 1;
2107 return 0; 2108 return 0;
2108} 2109}