From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757139Ab2ECOYr (ORCPT ); Thu, 3 May 2012 10:24:47 -0400 Received: from comal.ext.ti.com ([198.47.26.152]:45708 "EHLO comal.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1757068Ab2ECOYl (ORCPT ); Thu, 3 May 2012 10:24:41 -0400 From: Venkatraman S To: , , , , CC: , , , , , , Venkatraman S Subject: [PATCH v2 09/16] mmc: core: Add MMC abort interface Date: Thu, 3 May 2012 19:53:08 +0530 Message-ID: <1336054995-22988-10-git-send-email-svenkatr@ti.com> X-Mailer: git-send-email 1.7.10.rc2 In-Reply-To: <1336054995-22988-1-git-send-email-svenkatr@ti.com> References: <1336054995-22988-1-git-send-email-svenkatr@ti.com> MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org HPI (and possibly other) procedures require that an ongoing mmc request issued to a controller be aborted in the middle of a transaction. Define a abort interface function to the controller so that individual host controllers can safely abort a request, stop the dma and cleanup their statemachine etc. The implementation is controller dependant Signed-off-by: Venkatraman S --- drivers/mmc/core/core.c | 8 ++++++++ include/linux/mmc/host.h | 1 + 2 files changed, 9 insertions(+) diff --git a/drivers/mmc/core/core.c b/drivers/mmc/core/core.c index b4152ca..3f0e927 100644 --- a/drivers/mmc/core/core.c +++ b/drivers/mmc/core/core.c @@ -328,6 +328,14 @@ static void mmc_post_req(struct mmc_host *host, struct mmc_request *mrq, } } +static int mmc_abort_req(struct mmc_host *host, struct mmc_request *req) +{ + if (host->ops->abort_req) + return host->ops->abort_req(host, req); + + return -ENOSYS; +} + /** * mmc_start_req - start a non-blocking request * @host: MMC host to start command diff --git a/include/linux/mmc/host.h b/include/linux/mmc/host.h index 0707d22..d700703 100644 --- a/include/linux/mmc/host.h +++ b/include/linux/mmc/host.h @@ -98,6 +98,7 @@ struct mmc_host_ops { int err); void (*pre_req)(struct mmc_host *host, struct mmc_request *req, bool is_first_req); + int (*abort_req)(struct mmc_host *host, struct mmc_request *req); void (*request)(struct mmc_host *host, struct mmc_request *req); /* * Avoid calling these three functions too often or in a "fast path", -- 1.7.10.rc2