From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from phobos.denx.de (phobos.denx.de [85.214.62.61]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 7EF13CDD541 for ; Wed, 18 Sep 2024 15:24:51 +0000 (UTC) Received: from h2850616.stratoserver.net (localhost [IPv6:::1]) by phobos.denx.de (Postfix) with ESMTP id DC7D688F82; Wed, 18 Sep 2024 17:22:32 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=pass (p=quarantine dis=none) header.from=9elements.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=u-boot-bounces@lists.denx.de Authentication-Results: phobos.denx.de; dkim=pass (2048-bit key; secure) header.d=9elements.com header.i=@9elements.com header.b="WtYf84I9"; dkim-atps=neutral Received: by phobos.denx.de (Postfix, from userid 109) id 195B588F60; Wed, 18 Sep 2024 17:22:31 +0200 (CEST) Received: from mail-ed1-x52e.google.com (mail-ed1-x52e.google.com [IPv6:2a00:1450:4864:20::52e]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits)) (No client certificate requested) by phobos.denx.de (Postfix) with ESMTPS id 2399B88F48 for ; Wed, 18 Sep 2024 17:22:29 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=pass (p=quarantine dis=none) header.from=9elements.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=patrick.rudolph@9elements.com Received: by mail-ed1-x52e.google.com with SMTP id 4fb4d7f45d1cf-5c42e7adbddso6145661a12.2 for ; Wed, 18 Sep 2024 08:22:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=9elements.com; s=google; t=1726672948; x=1727277748; darn=lists.denx.de; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=P2/C6o+QfR6WRuY4aohbmH/2Y2Pyr9XHlq4Kz++xeYg=; b=WtYf84I9h1cWwz7Q5eOsco3G2AJTKJLSmRjKuRJeAVVVltPDwHXdQFRR6lQ6CXGupR 80hF9pW24cFUDp2eSwJp4dy5XTWp4XYSwAKf4LxufrTOFfcJLn+JhrWv4jd+sWFCOTG9 vByQJepBe9Gv/Dl7V9VGTI1+BT0+K8eHUACQRAazeraqvEXGxgxkoKYcd+eLiWCskcaN M/pg1Tue8VSosuKzW3SOqHansN4Z5i3gAE+JrBOu37UGOG6DbZ2x5gRXArD9dAFgzPp0 /rMT2Gkzdu4gcaa8D69lWOCLaI4jrGUjzIO5kYXelEylCC8atDHNN6rGX/cac0vsBvf1 qorA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1726672948; x=1727277748; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=P2/C6o+QfR6WRuY4aohbmH/2Y2Pyr9XHlq4Kz++xeYg=; b=NrYeZi0idIDaRnM400nCH5ng1iMvoC5iu3tZSUojoyPNW9B4JHI7yiPo6qu/IMqbh9 enZVUai3UhVLtMBE/55eHriqF37sO37Nul1gC7GP6zOLxRGC4UXWvkCbd8Irdi56WkbV xZM0u432y/UFVkDuEsyw56HLZNWcXmEZrCRTHUT/XRaLc0qu7wBbJ3lz1uFsrXcfRp05 RSsE8944G0GM0vKdmdKMAt5b/wMxI0KFMfbA+3vLIw3g+aBiPgiMVfqIOLRnBayxbo6I K4R/bQqObSILmjSvzPWiKqS7Hp7YctSwR0RA5Z8nIdlDziVHa91v0PjDBlqQ/tZw06eW UXew== X-Gm-Message-State: AOJu0YzDzP8W2hB5AKFGuwdsbMVtHvU6vER9eNiBK4WP+sj07YVgNt9K tvjpav/sNqWGmHpc2eyryFGmb8L4sF6V9VrLJppfUSBgZKwLPri1Sjypphr13T+DlPwCD76vlzK g X-Google-Smtp-Source: AGHT+IEuND/OzdF7Fkj72rw7yadEe2cBexHOZ5fC9zpcJXKOGZGXIW5frxGujz7z80nNE9hGbBZ7hQ== X-Received: by 2002:a17:907:96aa:b0:a86:9107:4c2f with SMTP id a640c23a62f3a-a9048045065mr1980001266b.41.1726672948507; Wed, 18 Sep 2024 08:22:28 -0700 (PDT) Received: from fedora.sec.9e.network (ip-037-049-067-221.um09.pools.vodafone-ip.de. [37.49.67.221]) by smtp.gmail.com with ESMTPSA id a640c23a62f3a-a90610967b0sm599791266b.42.2024.09.18.08.22.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 18 Sep 2024 08:22:28 -0700 (PDT) From: Patrick Rudolph To: u-boot@lists.denx.de, Bin Meng Cc: Patrick Rudolph , Marek Vasut , Tom Rini Subject: [PATCH v4 16/35] drivers: usb: Add generic XHCI Date: Wed, 18 Sep 2024 17:20:20 +0200 Message-ID: <20240918152136.3395170-17-patrick.rudolph@9elements.com> X-Mailer: git-send-email 2.46.0 In-Reply-To: <20240918152136.3395170-1-patrick.rudolph@9elements.com> References: <20240918152136.3395170-1-patrick.rudolph@9elements.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.39 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" X-Virus-Scanned: clamav-milter 0.103.8 at phobos.denx.de X-Virus-Status: Clean Add support for the generic XHCI driver that contains no SoC specific code. It can be used on platforms that simply work out of the box, like on emulated platforms. TEST: Booted on QEMU sbsa machine using the generic xhci driver. Signed-off-by: Patrick Rudolph Reviewed-by: Marek Vasut Cc: Tom Rini Cc: Marek Vasut --- Changelog v3: - Drop weak board_xhci_enable() Changelog v4: - Use dev_dbg() instead of debug() --- drivers/usb/host/Kconfig | 8 ++++ drivers/usb/host/Makefile | 1 + drivers/usb/host/xhci-generic.c | 77 +++++++++++++++++++++++++++++++++ 3 files changed, 86 insertions(+) create mode 100644 drivers/usb/host/xhci-generic.c diff --git a/drivers/usb/host/Kconfig b/drivers/usb/host/Kconfig index 6e10b629a3..bb5893d56d 100644 --- a/drivers/usb/host/Kconfig +++ b/drivers/usb/host/Kconfig @@ -68,6 +68,14 @@ config USB_XHCI_MVEBU SoCs, which includes Armada8K, Armada3700 and other Armada family SoCs. +config USB_XHCI_GENERIC + bool "Generic SoC USB 3.0 support" + depends on OF_CONTROL + default n + help + Choose this option to add support for USB 3.0 driver for SoCs + that do not need platform specific code, like on emulated targets. + config USB_XHCI_OCTEON bool "Support for Marvell Octeon family on-chip xHCI USB controller" depends on ARCH_OCTEON diff --git a/drivers/usb/host/Makefile b/drivers/usb/host/Makefile index 8dad36f936..9e880195ec 100644 --- a/drivers/usb/host/Makefile +++ b/drivers/usb/host/Makefile @@ -50,6 +50,7 @@ obj-$(CONFIG_USB_XHCI_EXYNOS) += xhci-exynos5.o obj-$(CONFIG_USB_XHCI_FSL) += xhci-fsl.o obj-$(CONFIG_USB_XHCI_MTK) += xhci-mtk.o obj-$(CONFIG_USB_XHCI_MVEBU) += xhci-mvebu.o +obj-$(CONFIG_USB_XHCI_GENERIC) += xhci-generic.o obj-$(CONFIG_USB_XHCI_OMAP) += xhci-omap.o obj-$(CONFIG_USB_XHCI_PCI) += xhci-pci.o obj-$(CONFIG_USB_XHCI_RCAR) += xhci-rcar.o diff --git a/drivers/usb/host/xhci-generic.c b/drivers/usb/host/xhci-generic.c new file mode 100644 index 0000000000..5131f37991 --- /dev/null +++ b/drivers/usb/host/xhci-generic.c @@ -0,0 +1,77 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* + * Copyright (C) 2024 9elements GmbH + * + * GENERIC USB HOST xHCI Controller + */ + +#include +#include +#include +#include +#include +#include + +#include + +struct generic_xhci_plat { + fdt_addr_t hcd_base; +}; + +/** + * Contains pointers to register base addresses + * for the usb controller. + */ +struct generic_xhci { + struct xhci_ctrl ctrl; /* Needs to come first in this struct! */ + struct usb_plat usb_plat; + struct xhci_hccr *hcd; +}; + +static int xhci_usb_probe(struct udevice *dev) +{ + struct generic_xhci_plat *plat = dev_get_plat(dev); + struct generic_xhci *ctx = dev_get_priv(dev); + struct xhci_hcor *hcor; + int len; + + ctx->hcd = (struct xhci_hccr *)phys_to_virt(plat->hcd_base); + len = HC_LENGTH(xhci_readl(&ctx->hcd->cr_capbase)); + hcor = (struct xhci_hcor *)((uintptr_t)ctx->hcd + len); + + return xhci_register(dev, ctx->hcd, hcor); +} + +static int xhci_usb_of_to_plat(struct udevice *dev) +{ + struct generic_xhci_plat *plat = dev_get_plat(dev); + + /* + * Get the base address for XHCI controller from the device node + */ + plat->hcd_base = dev_read_addr(dev); + if (plat->hcd_base == FDT_ADDR_T_NONE) { + dev_dbg(dev, "Can't get the XHCI register base address\n"); + return -ENXIO; + } + + return 0; +} + +static const struct udevice_id xhci_usb_ids[] = { + { .compatible = "generic-xhci" }, + { } +}; + +U_BOOT_DRIVER(usb_xhci) = { + .name = "xhci_generic", + .id = UCLASS_USB, + .of_match = xhci_usb_ids, + .of_to_plat = xhci_usb_of_to_plat, + .probe = xhci_usb_probe, + .remove = xhci_deregister, + .ops = &xhci_usb_ops, + .plat_auto = sizeof(struct generic_xhci_plat), + .priv_auto = sizeof(struct generic_xhci), + .flags = DM_FLAG_ALLOC_PRIV_DMA, +}; -- 2.46.0