OSDN Git Service

mmc: core: Ensure cmd_completion is initialized
authorAdrian Hunter <adrian.hunter@intel.com>
Fri, 1 Dec 2017 12:55:30 +0000 (14:55 +0200)
committerUlf Hansson <ulf.hansson@linaro.org>
Mon, 11 Dec 2017 11:48:07 +0000 (12:48 +0100)
mmc_test now uses mmc_start_request() to test sending commands during
"ongoing" asynchronous transfers, i.e. tests:
Commands during non-blocking read - use Set Block Count (CMD23)
Commands during non-blocking write - use Set Block Count (CMD23)

mmc_start_request() was not initializing cmd_completion, but cmd_completion
is used by "ongoing" transfers, so move initialization of cmd_completion
into making mmc_start_request().

Fixes: cb39f61e9b1e ("mmc: core: Export a few functions needed for blkmq support")
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
drivers/mmc/core/core.c

index 617802f..455abbf 100644 (file)
@@ -348,6 +348,8 @@ int mmc_start_request(struct mmc_host *host, struct mmc_request *mrq)
 {
        int err;
 
+       init_completion(&mrq->cmd_completion);
+
        mmc_retune_hold(host);
 
        if (mmc_card_removed(host->card))
@@ -418,8 +420,6 @@ static int __mmc_start_data_req(struct mmc_host *host, struct mmc_request *mrq)
        mrq->done = mmc_wait_data_done;
        mrq->host = host;
 
-       init_completion(&mrq->cmd_completion);
-
        err = mmc_start_request(host, mrq);
        if (err) {
                mrq->cmd->error = err;
@@ -439,8 +439,6 @@ static int __mmc_start_req(struct mmc_host *host, struct mmc_request *mrq)
        init_completion(&mrq->completion);
        mrq->done = mmc_wait_done;
 
-       init_completion(&mrq->cmd_completion);
-
        err = mmc_start_request(host, mrq);
        if (err) {
                mrq->cmd->error = err;