Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp4761167imu; Tue, 29 Jan 2019 07:07:11 -0800 (PST) X-Google-Smtp-Source: ALg8bN4yYWuuE6+TV6sS9U4mTqAiX00GhOER02llfsjOExk4TGpgEqPRIi+zKlxYS6eAKIyHn8eo X-Received: by 2002:a63:5320:: with SMTP id h32mr24045532pgb.414.1548774431639; Tue, 29 Jan 2019 07:07:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548774431; cv=none; d=google.com; s=arc-20160816; b=u1sRtxehJLVSJy5d9DPJemq3uMu9y9riW+sqxJ+qilf2rJ+EaM2Xs7vo0QisgSgtj0 bOio9lcFBV2rnIGdIx8JLJNoJm+BoA9dI7XAihduYw/YVPEud/PheDY2dw6jMWJ2fdj5 5ET73zL/ETAIj2BQWUpZ3egKACr12v3nPkEjf2KU16sk5vqqPX+ILEupt43Ottf0CNjP 3LIp+UBB4/dGe6OEbHd54HKCXOJ2l8K3/Yct+lRowpVAvLrbaHcHfAv/6QXTQM98mHWK rVSDQVVGeMQriW2pVKFxzdsq/hiIGxi82jU+wHMmdybrWikpM1d5LtvuoW0KRuAwQKik iMog== 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=sAm7F8AfZR0Q84kuWFBjESWQ9PI02jfVhpfin/LP5As=; b=dJaGUYnreEJVTHt1Zqwk4GlCYxXOPFyuuNQOHmkzgQcdkmrEJGJHqg69rithxg6GyE VP8sKQs4ei/UuqkymVvD4hziLgPkl+c+SJrY7qM0qSsqPUAreGaRqAa4syZ6Za5HnUON /pbx9McguBpwM9lnVaqCMB3FQ3BvqjjOgvBZ6Wlm5up6IxZBIAdZR28GpdEocKkLWi4o CWVSG8nXedkkaNpm+i4y+tZnDP+bkPANtxGZQ2JdoiV91q1Zco81Tr3WFEtEKYP2ocu0 cWdi5NS3ceQeldSnbnatMCDx+4x2Z/qmhXBIEHPgmYVwm71B+2Qh9i53EBrcRcLcCvcb GV+g== 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 23si36052746pfk.287.2019.01.29.07.06.52; Tue, 29 Jan 2019 07:07:11 -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 S1728862AbfA2PGM (ORCPT + 99 others); Tue, 29 Jan 2019 10:06:12 -0500 Received: from mga07.intel.com ([134.134.136.100]:7039 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727555AbfA2PBs (ORCPT ); Tue, 29 Jan 2019 10:01:48 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by orsmga105.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 29 Jan 2019 07:01:47 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.56,537,1539673200"; d="scan'208";a="142391781" Received: from black.fi.intel.com ([10.237.72.28]) by fmsmga001.fm.intel.com with ESMTP; 29 Jan 2019 07:01:44 -0800 Received: by black.fi.intel.com (Postfix, from userid 1001) id 17107D4; Tue, 29 Jan 2019 17:01:43 +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 00/28] thunderbolt: Software connection manager improvements Date: Tue, 29 Jan 2019 18:01:15 +0300 Message-Id: <20190129150143.12681-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. :-) The first patch is for the networking driver (to make it work on both software and firmware CM systems). I'm looking for either an ACK from the network maintainers so I can take it with the rest of the series via thunderbolt tree, or alternatively it can be picked directly into the networking tree as it is independent of the rest of the series. Thanks! 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 | 89 +++- 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 | 68 ++- 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