diff options
author | Sachin Kamat <sachin.kamat@linaro.org> | 2013-04-04 01:55:10 -0400 |
---|---|---|
committer | Chris Ball <cjb@laptop.org> | 2013-04-04 10:18:05 -0400 |
commit | f2f942ce4a800b2179a5a5023922517b875a6787 (patch) | |
tree | cb51ecaa40e251ad5401e406398ac1f3b1f6dfe6 /drivers/mmc/host | |
parent | b0dd099ceb04146b68aa7109bcd426dc74cb64ac (diff) |
mmc: dw_mmc: Check return value of regulator_enable
regulator_enable() is declared with __must_check attribute.
Hence check the return value to ensure that the regulator is enabled.
Fixes the following warning:
drivers/mmc/host/dw_mmc.c:2461:19: warning:
ignoring return value of ‘regulator_enable’, declared with attribute
warn_unused_result [-Wunused-result]
drivers/mmc/host/dw_mmc.c: In function ‘dw_mci_init_slot’:
drivers/mmc/host/dw_mmc.c:1994:19: warning:
ignoring return value of ‘regulator_enable’, declared with attribute
warn_unused_result [-Wunused-result]
Signed-off-by: Sachin Kamat <sachin.kamat@linaro.org>
Acked-by: Jaehoon Chung <jh80.chung@samsung.com>
Acked-by: Seungwon Jeon <tgih.jun@samsung.com>
Signed-off-by: Chris Ball <cjb@laptop.org>
Diffstat (limited to 'drivers/mmc/host')
-rw-r--r-- | drivers/mmc/host/dw_mmc.c | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/drivers/mmc/host/dw_mmc.c b/drivers/mmc/host/dw_mmc.c index c6caedc2e847..a63766a0bfcd 100644 --- a/drivers/mmc/host/dw_mmc.c +++ b/drivers/mmc/host/dw_mmc.c | |||
@@ -1997,8 +1997,14 @@ static int dw_mci_init_slot(struct dw_mci *host, unsigned int id) | |||
1997 | if (IS_ERR(host->vmmc)) { | 1997 | if (IS_ERR(host->vmmc)) { |
1998 | pr_info("%s: no vmmc regulator found\n", mmc_hostname(mmc)); | 1998 | pr_info("%s: no vmmc regulator found\n", mmc_hostname(mmc)); |
1999 | host->vmmc = NULL; | 1999 | host->vmmc = NULL; |
2000 | } else | 2000 | } else { |
2001 | regulator_enable(host->vmmc); | 2001 | ret = regulator_enable(host->vmmc); |
2002 | if (ret) { | ||
2003 | dev_err(host->dev, | ||
2004 | "failed to enable regulator: %d\n", ret); | ||
2005 | goto err_setup_bus; | ||
2006 | } | ||
2007 | } | ||
2002 | 2008 | ||
2003 | if (dw_mci_get_cd(mmc)) | 2009 | if (dw_mci_get_cd(mmc)) |
2004 | set_bit(DW_MMC_CARD_PRESENT, &slot->flags); | 2010 | set_bit(DW_MMC_CARD_PRESENT, &slot->flags); |
@@ -2464,8 +2470,14 @@ int dw_mci_resume(struct dw_mci *host) | |||
2464 | { | 2470 | { |
2465 | int i, ret; | 2471 | int i, ret; |
2466 | 2472 | ||
2467 | if (host->vmmc) | 2473 | if (host->vmmc) { |
2468 | regulator_enable(host->vmmc); | 2474 | ret = regulator_enable(host->vmmc); |
2475 | if (ret) { | ||
2476 | dev_err(host->dev, | ||
2477 | "failed to enable regulator: %d\n", ret); | ||
2478 | return ret; | ||
2479 | } | ||
2480 | } | ||
2469 | 2481 | ||
2470 | if (!mci_wait_reset(host->dev, host)) { | 2482 | if (!mci_wait_reset(host->dev, host)) { |
2471 | ret = -ENODEV; | 2483 | ret = -ENODEV; |