Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5924557imu; Sun, 20 Jan 2019 23:33:07 -0800 (PST) X-Google-Smtp-Source: ALg8bN4TGXuR+w5YFtpC8aN55R1oB3kbD5Ezgks+sVkFTWXeP0H9A2XSvF9ZDVSgtZiF+e4adHqY X-Received: by 2002:a62:3943:: with SMTP id g64mr29183744pfa.114.1548055987360; Sun, 20 Jan 2019 23:33:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548055987; cv=none; d=google.com; s=arc-20160816; b=UmbgM/Q3mkQoYp7hNBXOJh0PvbqP3NIn0dE3WqZ5fbyyzHaSoQpEY75wYgVGjvJkcd 6kqm33ZX7BDHYUb21AS5w35IdejeIkruTPUcdwJxjsPB4seY8kiC0WqjzchLNEHIStEM PmpCu2fEOlBJVbJ0R259OcYRcFpEQOaFbT2IljDLVs/qRq8mis2uXJHICJq63Z/PMdE1 s5w6fLwwnUyR4flg/z/my5CQ6A1gUFQ8SH/CrJBSKEgcOQuVIKgC2xw6YcfnyLZU592U 9ECw4n4e2gzKs/Fzdio6O23txfafswfM9YPYvVLLLaM4KqC7QRnwj8rszG3UNENd5i06 xiQg== 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=5WTpniz+Roy574+siOScm/uvbtFCZZ81M4clmB6XmE4=; b=GExnwrCZiiPc4Eqm2JQxZQRckslLedVLjkVJgnrN4/HbtSnNkHcKUg8tK7klHxxebn ifvRLsG8NvrhmC/ea85ZNldHzYn2Z2BDqQi8uMSDPz+Co9PJifrSHOafIueUKZT5YAYU 4fbCrIcyrXJzC4Ulkf7gT1GMUNrb27lADWxVy80pVuYLRAak86okpUpLm8CxEavUMjw3 CsILHbgqdiyBw/0W6szNAA7q6FpeL9fuNFs+TzlupcpKqtbfZecgyQ2TRuovhpro1vnL D3/tDYr0+XcXWY8LdAKOOdaaXqemZgWYL8eF6HKbYjGz0W6E7uAR8AWeqTDnfOcr0NYV uybA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=bfxi6GSI; 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 w24si12087054pgj.582.2019.01.20.23.32.52; Sun, 20 Jan 2019 23:33:07 -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=bfxi6GSI; 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 S1728549AbfAUHbf (ORCPT + 99 others); Mon, 21 Jan 2019 02:31:35 -0500 Received: from perceval.ideasonboard.com ([213.167.242.64]:45900 "EHLO perceval.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728428AbfAUHbc (ORCPT ); Mon, 21 Jan 2019 02:31:32 -0500 Received: from localhost.localdomain (unknown [96.44.9.117]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id AE038E84; Sun, 20 Jan 2019 20:42:02 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1548013323; bh=GtxTuK6PvgSVaHvpvY/HNYD1Rdhl07FjU36F7MbAfsI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=bfxi6GSIEdmuVVSnaZFMhOZr5di43BLe1Dp7IVyz/oum3I7EWd7Pcmrfw5we0kE7S mRkXuHuTXoIMb+vlgkE9ZFXHZuU7AlaF20V+VL7q8TefqLNd76Sb7XvFLwIi+7DGzu Ovn8KflfVfGkhEOQ3DV22mfIiMZzpY08WFpsNuEo= 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 v6 5/6] usb: musb: gadget: implement optional explicit status stage Date: Sun, 20 Jan 2019 14:41:35 -0500 Message-Id: <20190120194136.21870-6-paul.elder@ideasonboard.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190120194136.21870-1-paul.elder@ideasonboard.com> References: <20190120194136.21870-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 v5: - giveback usb request to gadget driver after enqueueing for the status stage Changes from v4: - call usb_gadget_control_complete before usb_gadget_giveback_request - set musb ep0 state to statusin in ep0_send_ack - make sure to not double-write musb register in ep0_rxstate, since musb_g_ep0_giveback will take care of writing them No change from v3 Changes from v2: - update call to usb_gadget_control_complete to include status - since sending STALL from the function driver is now done with usb_ep_set_halt, there is no need for the internal ep0_send_response to take a stall/ack parameter; remove the parameter and make the function only send ack, and remove checking for the status reply in the usb_request for the status stage 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 | 2 ++ drivers/usb/musb/musb_gadget_ep0.c | 32 ++++++++++++++++++++++++++++-- 2 files changed, 32 insertions(+), 2 deletions(-) diff --git a/drivers/usb/musb/musb_gadget.c b/drivers/usb/musb/musb_gadget.c index ffe462a657b1..2a36bebf955d 100644 --- a/drivers/usb/musb/musb_gadget.c +++ b/drivers/usb/musb/musb_gadget.c @@ -144,6 +144,8 @@ __acquires(ep->musb->lock) unmap_dma_buffer(req, musb); trace_musb_req_gb(req); + if (req->ep->end_point.address == 0) + usb_gadget_control_complete(&musb->g, &req->request); usb_gadget_giveback_request(&req->ep->end_point, &req->request); 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..63c84488d51b 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_ack(struct musb *musb) +{ + void __iomem *regs = musb->control_ep->regs; + u16 csr; + + if (musb->ep0_state != MUSB_EP0_STAGE_RX && + musb->ep0_state != MUSB_EP0_STAGE_STATUSIN) + return -EINVAL; + + csr = MUSB_CSR0_P_DATAEND | MUSB_CSR0_P_SVDRXPKTRDY; + + musb_ep_select(musb->mregs, 0); + musb_writew(regs, MUSB_CSR0, csr); + + musb->ep0_state = MUSB_EP0_STAGE_STATUSIN; + + return 0; +} + /* we have an ep0out data packet * Context: caller holds controller lock */ @@ -504,12 +523,15 @@ 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; + } else { + musb_ep_select(musb->mregs, 0); + musb_writew(regs, MUSB_CSR0, csr); } - musb_ep_select(musb->mregs, 0); - musb_writew(regs, MUSB_CSR0, csr); } /* @@ -937,6 +959,7 @@ musb_g_ep0_queue(struct usb_ep *e, struct usb_request *r, gfp_t gfp_flags) case MUSB_EP0_STAGE_RX: /* control-OUT data */ case MUSB_EP0_STAGE_TX: /* control-IN data */ case MUSB_EP0_STAGE_ACKWAIT: /* zero-length data */ + case MUSB_EP0_STAGE_STATUSIN: status = 0; break; default: @@ -978,6 +1001,11 @@ musb_g_ep0_queue(struct usb_ep *e, struct usb_request *r, gfp_t gfp_flags) } else if (musb->ackpend) { musb_writew(regs, MUSB_CSR0, musb->ackpend); musb->ackpend = 0; + + /* status stage of OUT with data, issue IN status, then giveback */ + } else if (musb->ep0_state == MUSB_EP0_STAGE_STATUSIN) { + status = ep0_send_ack(musb); + musb_g_ep0_giveback(ep->musb, r); } cleanup: -- 2.20.1