Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp4466138ybi; Tue, 11 Jun 2019 07:08:34 -0700 (PDT) X-Google-Smtp-Source: APXvYqwC4EPLi1M4mQ1WCNwPoMZcd3U9d4E68U7uIAcytSZCXQ7hJSlEBJj7FhMlNMOFziBupjnS X-Received: by 2002:a63:4185:: with SMTP id o127mr8934412pga.82.1560262114686; Tue, 11 Jun 2019 07:08:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560262114; cv=none; d=google.com; s=arc-20160816; b=XBzxkiSG67WBRc3lPD6tQ55MO4iVWx2+ou3lFt/8K6tVMSO8IFhTqz1NYBULb0X2fI wayDX9Ry4VmfktSQ0U2UGqxWdKRz9iZ6rLXnCfCciNqueZxxK5OvbXqKTe1eDYLVc5Wu fJeKWOypwFOqtP/6DGg/cjSPcNa7PYQdDFpx6damnemiEKbFatwXElyxJl7LEUzBUxZn E1ffD0AyIlesUTmpk5pDrT/+LXYRn6X0zyJ1IZPBVIjgfQ5DPRdxA/N2SpAjHSP9rfUS 7/3Qcq9c47d6ObSWYGlLn7BtRR+ifalo9cZJXDibjB2d6IU9BuIjgR1gdbdSjOPz3pmg pa1Q== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=vKGIIEZ1EWhF8d9VHamuiFuthqcJ8PCoZC+PlSBmz6w=; b=0kgwbH8ZYbhZc6LSdbICZl8soaTfRq/BO9plwMTmwawkcQ/+ns8PHQ4zOMCK0lwj4A ucOPfYoOspV8n/tkDQLTvtapqVdlUulF59MFZSg/22LfY+I15NPfcE9kq0WMXPJTgPkW Ux9mpMl7BbpXOoSoN9AEWbefyanLpns0LrHgSmM1T6G8DkFe8M3ARKY2+KXMoOwmrhnW qHHaFw4/+6I79tZn7KRDG8FClgSQfyPME+TsCiRSEW88t6Ua9XYKMM4RmnqUC6JfVl8B SZJHXAqzgI796/lncE7TVguJaMDe/tV11Pdyc6uGJAwGxWmjJ8RlzVxIkVWfUosqXw5C GuVA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=EzeY2hPj; 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 k3si587630pgh.434.2019.06.11.07.08.18; Tue, 11 Jun 2019 07:08:34 -0700 (PDT) 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 header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=EzeY2hPj; 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 S2391582AbfFKN6r (ORCPT + 99 others); Tue, 11 Jun 2019 09:58:47 -0400 Received: from mail-wm1-f66.google.com ([209.85.128.66]:38229 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387966AbfFKN6q (ORCPT ); Tue, 11 Jun 2019 09:58:46 -0400 Received: by mail-wm1-f66.google.com with SMTP id s15so3059243wmj.3 for ; Tue, 11 Jun 2019 06:58:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=vKGIIEZ1EWhF8d9VHamuiFuthqcJ8PCoZC+PlSBmz6w=; b=EzeY2hPjuYcKKephwbA2K1k8wINtGW9iU2baby+Xliqe1XCNSRPc1BDCV0c7P2Cfyq fiswGap6+7EHJyYD4nFTEmjDAndmmuLpxkj0z6N8Si5dC3jZyenH1cLi8DdmoDNfj4ba ARQ8YUjx20+dGQtgThBUX9sUMXH4R3nlFlzRiYIEV3Zey05eBOYBfJFFwmCPkmO9Gn1a uOoUwOPFvWqAhOOAmKWhhM2wZ98IENtfIHlORA/cK+Qf8dR8LC/pGpZmW1ELLdhHk+Pq ydAqAkXyQU1W/SahLXNTTwrpSDtKRdWPjj0lKnHPvnDVgef+NAYipXlO8rplYVr932Yj fiwA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=vKGIIEZ1EWhF8d9VHamuiFuthqcJ8PCoZC+PlSBmz6w=; b=G0jt2wcbb6Wu98LhU8hE1JrWTtII3425gngA5hWBCQM4JCtyWaLD5kxWK1LsxX1aA0 ddCoUygMCJWdPIhI/qcj2vd+8nYjGYWAE0EBTvxcjjBPtbke2aviTgjvZCp7trcDU9gS FOaKp/2CWg5jS7sWQZS1iArllIgXoH1D0tUA9Z19jzRImQ4x+F62yYtqNxzmAS8GiGYC FWWV09HISXBn1BOvUtEWtYJETI2Fhp9l6pmPJIXnDFw0Gb1Fyx4hQDRqo4C9ytFFR1Dd 35DlI+b1xAzn/MY5W/xYwtmLHLa7iuB4hQFylHweRJRwL/2wwNB2M5IRv3dLWeG17XYy dBVA== X-Gm-Message-State: APjAAAXuI+llcnCImSFuenUMf/OUQOe9EG64gM8lGjpZcqgjLQlOB2fZ CBmSqSL1cI+kSraTlcBPzeIEOA== X-Received: by 2002:a05:600c:389:: with SMTP id w9mr17129874wmd.139.1560261523914; Tue, 11 Jun 2019 06:58:43 -0700 (PDT) Received: from bender.baylibre.local (lmontsouris-657-1-212-31.w90-63.abo.wanadoo.fr. [90.63.244.31]) by smtp.gmail.com with ESMTPSA id c16sm12317446wrr.53.2019.06.11.06.58.43 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Tue, 11 Jun 2019 06:58:43 -0700 (PDT) From: Neil Armstrong To: balbi@kernel.org Cc: Neil Armstrong , linux-usb@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-amlogic@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH] usb: dwc3: meson-g12a: Add support for IRQ based OTG switching Date: Tue, 11 Jun 2019 15:58:42 +0200 Message-Id: <20190611135842.8396-1-narmstrong@baylibre.com> X-Mailer: git-send-email 2.21.0 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 Add support for the OTG ID change interrupt to switch between Host and Device mode. Tested on the Hardkernel Odroid-N2 board. Signed-off-by: Neil Armstrong --- drivers/usb/dwc3/dwc3-meson-g12a.c | 32 ++++++++++++++++++++++++++++-- 1 file changed, 30 insertions(+), 2 deletions(-) diff --git a/drivers/usb/dwc3/dwc3-meson-g12a.c b/drivers/usb/dwc3/dwc3-meson-g12a.c index 2aec31a2eacb..e5c5ad0d529e 100644 --- a/drivers/usb/dwc3/dwc3-meson-g12a.c +++ b/drivers/usb/dwc3/dwc3-meson-g12a.c @@ -348,6 +348,22 @@ static enum usb_role dwc3_meson_g12a_role_get(struct device *dev) USB_ROLE_HOST : USB_ROLE_DEVICE; } +static irqreturn_t dwc3_meson_g12a_irq_thread(int irq, void *data) +{ + struct dwc3_meson_g12a *priv = data; + enum phy_mode otg_id; + + otg_id = dwc3_meson_g12a_get_id(priv); + if (otg_id != priv->otg_phy_mode) { + if (dwc3_meson_g12a_otg_mode_set(priv, otg_id)) + dev_warn(priv->dev, "Failed to switch OTG mode\n"); + } + + regmap_update_bits(priv->regmap, USB_R5, USB_R5_ID_DIG_IRQ, 0); + + return IRQ_HANDLED; +} + static struct device *dwc3_meson_g12_find_child(struct device *dev, const char *compatible) { @@ -374,7 +390,7 @@ static int dwc3_meson_g12a_probe(struct platform_device *pdev) void __iomem *base; struct resource *res; enum phy_mode otg_id; - int ret, i; + int ret, i, irq; priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL); if (!priv) @@ -436,6 +452,19 @@ static int dwc3_meson_g12a_probe(struct platform_device *pdev) /* Get dr_mode */ priv->otg_mode = usb_get_dr_mode(dev); + if (priv->otg_mode == USB_DR_MODE_OTG) { + /* Ack irq before registering */ + regmap_update_bits(priv->regmap, USB_R5, + USB_R5_ID_DIG_IRQ, 0); + + irq = platform_get_irq(pdev, 0); + ret = devm_request_threaded_irq(&pdev->dev, irq, NULL, + dwc3_meson_g12a_irq_thread, + IRQF_ONESHOT, pdev->name, priv); + if (ret) + return ret; + } + dwc3_meson_g12a_usb_init(priv); /* Init PHYs */ @@ -460,7 +489,6 @@ static int dwc3_meson_g12a_probe(struct platform_device *pdev) /* Setup OTG mode corresponding to the ID pin */ if (priv->otg_mode == USB_DR_MODE_OTG) { - /* TOFIX Handle ID mode toggling via IRQ */ otg_id = dwc3_meson_g12a_get_id(priv); if (otg_id != priv->otg_phy_mode) { if (dwc3_meson_g12a_otg_mode_set(priv, otg_id)) -- 2.21.0