Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2282195imu; Sun, 16 Dec 2018 22:04:29 -0800 (PST) X-Google-Smtp-Source: AFSGD/VPK4uQmASSn1xkn7Z1mtsRbdtoJO4RCVYik8iq/slzFTabkHnSRIH20wgiQ3xymXmQ4aFi X-Received: by 2002:a62:8096:: with SMTP id j144mr11948948pfd.140.1545026668888; Sun, 16 Dec 2018 22:04:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1545026668; cv=none; d=google.com; s=arc-20160816; b=TLey/dEo9WFAQcn//m/hZQDn/ko1aPOlrHMBf9nWThy8uEAsqqI5B04UDU4kDaJU50 VSmXUEZWYcBsdqjLGuAxfduqHXxEoJWzyH5E7hoJfww22Xwq0KYWU6D0O7y+CVdJEOBZ pa+BLtIEiC17xAy2Dp+tEkaQus1xL1maatUl988LhPIsNf4w/bXRlw29lTV9FZKRH/SI 6rpKbYDUWObEKC8NwVCwW83aI6reeH8pBysSqF+7ROeJ/aVRWzh0IVxTiYhs/kfrt2Cb GpUK4gDjXRiFUZRC3ffb4TUAR8aBydoi43G5dGQRm2pvt8PtvPBvU3cNR8vJB8K3hlOq Sg0g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=9LbxvySOADONzxWa3KQB+22vC0joCwIGvUaL3kMXNuE=; b=LuFyUG2/WzPNsL8SdDF98+AiMmxtVbxofnjJVK84NTYUKg0dYUyA0aylJTY/iBHhZe culjSRm/j918RNHIoukZU0HZhIqE8cY6djF1b7vjQdtF9oxDw/ESwSQRYhl856t9xoEo 6So0PbGHM4IXpQjdgecxhkPHuE4357hZxoBlfmnZFj/S6NlfDf1kWRaMlT+CrlLpLdC1 Ljj0QVdkdzoWND3wAFss394P0EtJjGif+U6RN67FYDXfnAa59FEgxU15ljgg/A1PpeYS d+FlEJPj/iM5vPmfgm75Ec3AAL7SQdYJUwleEyS9qqv54RlsRdaqzc4/he+5AarWyxWw 7HMA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=HGWhB+TN; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l7si10101751plg.390.2018.12.16.22.04.13; Sun, 16 Dec 2018 22:04:28 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=HGWhB+TN; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731546AbeLQGC7 (ORCPT + 99 others); Mon, 17 Dec 2018 01:02:59 -0500 Received: from perceval.ideasonboard.com ([213.167.242.64]:53906 "EHLO perceval.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731478AbeLQGC5 (ORCPT ); Mon, 17 Dec 2018 01:02:57 -0500 Received: from localhost.localdomain (unknown [96.44.9.229]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id CDF51E4C; Mon, 17 Dec 2018 07:02:54 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1545026576; bh=1cO5OcvmM7RlA7UDmMxrJSgFT3YVDjBpi+db/Hv7iDU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HGWhB+TN985fN5UH32G7NAIE2MA2YRCFzRRxNNzo9U3WZfGyHGxp2Ui8IuUGcqgcc 4UuM0YbApEo8jHCDDR9ohhpRPkeb+Y6m+YznOPXMn48tQaeFmzIvvj2LuR+UfT+BQE LL2p9p5XJDpqh+KhCw0QJhlul6+aSuFu3YFxCs/Y= From: Paul Elder To: laurent.pinchart@ideasonboard.com, kieran.bingham@ideasonboard.com Cc: Paul Elder , b-liu@ti.com, stern@rowland.harvard.edu, rogerq@ti.com, balbi@kernel.org, gregkh@linuxfoundation.org, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 5/6] usb: musb: gadget: implement optional explicit status stage Date: Mon, 17 Dec 2018 01:02:15 -0500 Message-Id: <20181217060216.26368-6-paul.elder@ideasonboard.com> X-Mailer: git-send-email 2.19.2 In-Reply-To: <20181217060216.26368-1-paul.elder@ideasonboard.com> References: <20181217060216.26368-1-paul.elder@ideasonboard.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Implement the mechanism for optional explicit status stage for the MUSB driver. This allows a function driver to specify what to reply for the status stage. The functionality for an implicit status stage is retained. Signed-off-by: Paul Elder v1 Reviewed-by: Laurent Pinchart v1 Acked-by: Bin Liu --- Changes from v1: - obvious change to implement v2 mechanism laid out by 4/6 of this series (send_response, and musb_g_ep0_send_response function has been removed, call to usb_gadget_control_complete has been added) - ep0_send_response's ack argument has been changed from stall - last_packet flag in ep0_rxstate has been removed, since it is equal to req != NULL drivers/usb/musb/musb_gadget.c | 1 + drivers/usb/musb/musb_gadget_ep0.c | 28 ++++++++++++++++++++++++++++ 2 files changed, 29 insertions(+) diff --git a/drivers/usb/musb/musb_gadget.c b/drivers/usb/musb/musb_gadget.c index d3f33f449445..d83315dd22b2 100644 --- a/drivers/usb/musb/musb_gadget.c +++ b/drivers/usb/musb/musb_gadget.c @@ -145,6 +145,7 @@ __acquires(ep->musb->lock) trace_musb_req_gb(req); usb_gadget_giveback_request(&req->ep->end_point, &req->request); + usb_gadget_control_complete(&musb->g, request->explicit_status); spin_lock(&musb->lock); ep->busy = busy; } diff --git a/drivers/usb/musb/musb_gadget_ep0.c b/drivers/usb/musb/musb_gadget_ep0.c index 91a5027b5c1f..b3da48f4c63c 100644 --- a/drivers/usb/musb/musb_gadget_ep0.c +++ b/drivers/usb/musb/musb_gadget_ep0.c @@ -458,6 +458,25 @@ __acquires(musb->lock) return handled; } +static int ep0_send_response(struct musb *musb, bool ack) +{ + void __iomem *regs = musb->control_ep->regs; + u16 ackpend; + + if (musb->ep0_state != MUSB_EP0_STAGE_RX && + musb->ep0_state != MUSB_EP0_STAGE_STATUSIN) + return -EINVAL; + + ackpend = MUSB_CSR0_P_DATAEND + | MUSB_CSR0_P_SVDRXPKTRDY + | (ack ? 0 : MUSB_CSR0_P_SENDSTALL); + + musb_ep_select(musb->mregs, 0); + musb_writew(regs, MUSB_CSR0, ackpend); + + return 0; +} + /* we have an ep0out data packet * Context: caller holds controller lock */ @@ -504,10 +523,13 @@ static void ep0_rxstate(struct musb *musb) if (req) { musb->ackpend = csr; musb_g_ep0_giveback(musb, req); + if (req->explicit_status) + return; if (!musb->ackpend) return; musb->ackpend = 0; } + musb_ep_select(musb->mregs, 0); musb_writew(regs, MUSB_CSR0, csr); } @@ -939,6 +961,12 @@ musb_g_ep0_queue(struct usb_ep *e, struct usb_request *r, gfp_t gfp_flags) case MUSB_EP0_STAGE_ACKWAIT: /* zero-length data */ status = 0; break; + case MUSB_EP0_STAGE_STATUSIN: + if (r->explicit_status) + status = ep0_send_response(musb, r->zero); + else + status = ep0_send_response(musb, 1); + goto cleanup; default: musb_dbg(musb, "ep0 request queued in state %d", musb->ep0_state); -- 2.19.2