Received: by 2002:ac0:8c8e:0:0:0:0:0 with SMTP id r14csp597616ima; Wed, 6 Feb 2019 05:25:27 -0800 (PST) X-Google-Smtp-Source: AHgI3Iblp8NDuTjHfQy5qUVGdIzwKjfuF6VrLWQLR7TE7abXoVF6ZOSAfT0L61xAEArZXsT3hJtA X-Received: by 2002:a63:e74e:: with SMTP id j14mr9638187pgk.449.1549459527747; Wed, 06 Feb 2019 05:25:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549459527; cv=none; d=google.com; s=arc-20160816; b=k45UlCAmAE/aS5YLYcTwGX5aI740RJXbTPr/2z/5fiHGclfLszhbwBOo/FA3Tc6KiP 4ORPGqbducfcdyIn3whf981gT0Ipb98bucBrC55ZRK2CfB5Z1Q2MFtfVzexB4FSKLd3Q ATP+kLr/Bb1GXhehmvS1mGM/KeujKik8o/FGzeaLp455hlUKdxPSxWY435b4qUDdWuxf DX0M5MwpU6btekjIiNmmKLamNVvEoDORHzp2yDhTtIx+lWjoC4Jee9ki8i5yLLLv1j6x HjvL6YLotXDH/lxqlfIhKjb2aW24c0CZ113hFpBCqSs7JY28JoYkSGlOrRidoUwU7yws nZeA== 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; bh=TXXYn5mQRWp0hciR7xS/LR8p+/g55/oaTsoEcTW7fcA=; b=FEEy68IfKVfotORgz9tYrWlR+/N0T7NN89gJaEs4CeV0h83nUGg/ks+FMQS8xZDcqq urobPfDWFh2z6Juun87if22k+RUQ02kbusU+Xjy/O3HnBjIkPEC6rVIhORDlu56JYFH1 wqCtEwHWogpniszOXizGfqr+9raQE557uL1ZrTHlTROMmRA9qjgVunkrGBlZJrVbRt/P oCJRM4MuUNJf6zOIAuUvNK26rydWqzKCzOBMSZfOYcJ+lRfMvsbk4Ct31s74crT39cBG WUhGjQFVIJ+pY7BuF1s4jWktFkaU95cOjbStMoKp1/zJ8NY1kGoNFCugfb5dP94colH3 PP5A== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id z9si2616270pgf.54.2019.02.06.05.25.12; Wed, 06 Feb 2019 05:25:27 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731127AbfBFNXi (ORCPT + 99 others); Wed, 6 Feb 2019 08:23:38 -0500 Received: from mga03.intel.com ([134.134.136.65]:26739 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726716AbfBFNRo (ORCPT ); Wed, 6 Feb 2019 08:17:44 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga007.fm.intel.com ([10.253.24.52]) by orsmga103.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 06 Feb 2019 05:17:41 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,340,1544515200"; d="scan'208";a="120384276" Received: from black.fi.intel.com ([10.237.72.28]) by fmsmga007.fm.intel.com with ESMTP; 06 Feb 2019 05:17:39 -0800 Received: by black.fi.intel.com (Postfix, from userid 1001) id 66C29E7; Wed, 6 Feb 2019 15:17:38 +0200 (EET) From: Mika Westerberg To: linux-kernel@vger.kernel.org Cc: Michael Jamet , Yehezkel Bernat , Andreas Noever , Lukas Wunner , "David S . Miller" , Mika Westerberg , Andy Shevchenko , netdev@vger.kernel.org Subject: [PATCH v2 00/28] thunderbolt: Software connection manager improvements Date: Wed, 6 Feb 2019 16:17:10 +0300 Message-Id: <20190206131738.43696-1-mika.westerberg@linux.intel.com> X-Mailer: git-send-email 2.20.1 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 Hi, Software connection manager (drivers/thunderbolt/tb.c) is used on older Apple hardware with Light Ridge, Cactus Ridge or Falcon Ridge controllers to create PCIe tunnels when a Thunderbolt device is connected. Currently only one PCIe tunnel is supported. On newer Alpine Ridge based Apple systems the driver starts the firmware which then takes care creating tunnels. This series improves the software connection manager so that it will support: - Full PCIe daisy chains (up to 6 devices) - Display Port tunneling - P2P networking We also add support for Titan Ridge based Apple systems where we can use the same flows than with Alpine Ridge to start the firmware. Note in order to prevent possible DMA attacks on these systems we should make sure IOMMU is enabled. One option is to force dmar_platform_optin() return true on Apple hardware. However, it is not part of this series. I'm trusting people using Linux on such systems to take care of it. :-) Previous version of the patch series can be viewed here: https://lkml.org/lkml/2019/1/29/924 Changes from v1: * Added ACK from David * Add constant (TMU_ACCESS_EN) for BIT(20) when TMU access is enabled. We keep it in cap.c close to the LR/ER workaround. Also we enable/disable only during capability walk. If it turns we need to have it enabled elsewhere we can move it to switch.c and enable just once during switch enumeration. * Use 0 to mean no cap_adap instead of negative value. This follows cap_phy. * Use correct PCI IDs (_BRIDGE) in the last patch where we start firmware on Titan Ridge. It wrongly used NHI PCI IDs in v1. Mika Westerberg (28): net: thunderbolt: Unregister ThunderboltIP protocol handler when suspending thunderbolt: Do not allocate switch if depth is greater than 6 thunderbolt: Enable TMU access when accessing port space on legacy devices thunderbolt: Add dummy read after port capability list walk on Light Ridge thunderbolt: Move LC specific functionality into a separate file thunderbolt: Configure lanes when switch is initialized thunderbolt: Set sleep bit when suspending switch thunderbolt: Properly disable path thunderbolt: Cache adapter specific capability offset into struct port thunderbolt: Rename tunnel_pci to tunnel thunderbolt: Generalize tunnel creation functionality thunderbolt: Add functions for allocating and releasing hop IDs thunderbolt: Add helper function to iterate from one port to another thunderbolt: Extend tunnel creation to more than 2 adjacent switches thunderbolt: Deactivate all paths before restarting them thunderbolt: Discover preboot PCIe paths the boot firmware established thunderbolt: Add support for full PCIe daisy chains thunderbolt: Scan only valid NULL adapter ports in hotplug thunderbolt: Generalize port finding routines to support all port types thunderbolt: Rework NFC credits handling thunderbolt: Add support for Display Port tunnels thunderbolt: Run tb_xdp_handle_request() in system workqueue thunderbolt: Add XDomain UUID exchange support thunderbolt: Add support for DMA tunnels thunderbolt: Make tb_switch_alloc() return ERR_PTR() thunderbolt: Add support for XDomain connections thunderbolt: Make rest of the logging to happen at debug level thunderbolt: Start firmware on Titan Ridge Apple systems drivers/net/thunderbolt.c | 3 + drivers/thunderbolt/Makefile | 4 +- drivers/thunderbolt/cap.c | 90 +++- drivers/thunderbolt/ctl.c | 2 +- drivers/thunderbolt/icm.c | 15 +- drivers/thunderbolt/lc.c | 179 ++++++++ drivers/thunderbolt/path.c | 326 +++++++++++++-- drivers/thunderbolt/switch.c | 466 ++++++++++++++++++--- drivers/thunderbolt/tb.c | 529 ++++++++++++++++++------ drivers/thunderbolt/tb.h | 67 ++- drivers/thunderbolt/tb_msgs.h | 11 + drivers/thunderbolt/tb_regs.h | 50 ++- drivers/thunderbolt/tunnel.c | 681 +++++++++++++++++++++++++++++++ drivers/thunderbolt/tunnel.h | 75 ++++ drivers/thunderbolt/tunnel_pci.c | 226 ---------- drivers/thunderbolt/tunnel_pci.h | 31 -- drivers/thunderbolt/xdomain.c | 142 ++++++- include/linux/thunderbolt.h | 8 + 18 files changed, 2389 insertions(+), 516 deletions(-) create mode 100644 drivers/thunderbolt/lc.c create mode 100644 drivers/thunderbolt/tunnel.c create mode 100644 drivers/thunderbolt/tunnel.h delete mode 100644 drivers/thunderbolt/tunnel_pci.c delete mode 100644 drivers/thunderbolt/tunnel_pci.h -- 2.20.1