Received: by 2002:a17:90a:37e8:0:0:0:0 with SMTP id v95csp8818634pjb; Tue, 1 Oct 2019 04:42:53 -0700 (PDT) X-Google-Smtp-Source: APXvYqzJp7ytS5V8cxVhQXevvF3ghsLsvDKoci8bEsTcD5i0qCiNbXnW5eGaJpVi/07rC70XI5RH X-Received: by 2002:a17:906:4d58:: with SMTP id b24mr23778988ejv.263.1569930173423; Tue, 01 Oct 2019 04:42:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569930173; cv=none; d=google.com; s=arc-20160816; b=TwVc4YUYAa5ew1AEF6MC26fKc7Nu3TsUHSvjRXPCGai4hQF4gc2w20PlIjTLfW8aM/ YwbMkh8S4lfowjCNl7t5/Y24rt1cFC2owjLruR67Xt7nVn2te06vHzCxiRNXui10liSZ M2HKf+oafY7GeXpBzOj1Tblc1X2LJH3p1icjC2PFlvYuD8X/LvS8ZLS/qXhP+yePLNN7 74hLvxf5Cklb6toLVovUsfGHQC0DR3z4r+JawyoGOl0Z819JZILD60doxvFrHd2jOUce lMc/ucveV+by1adXuYxUVvBkbYe+SbtwEbytvTVyEd89Vpgmmdk5bP/xoOAFU706Sizw Q9hA== 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; bh=LusObgz7lK1Fkoy9iPFFqIwXJUGVaS9nEybfG6coEds=; b=0tAly2M3ifjgQ9DxxEnU5qbihZ1HlaBA8MDzagXH7VivAA8hRyM/AZ2Ua2bqr/VdnU HHrq6exV5115vJqRfGFCcKiaEbs3Jovcth/ZTeertK2mNxgA3cCZDrfde2Yz7+uKP2fk unRPZ0pDx4a/GgZzYAG+PDl5Wv5GRoOyY3JJVdE4FMd2L0RXziA8vxpkNlJMK74OU0dU A2+V1P9+8DG8V0GbETFDmKcoJKDjJZBnSHnKbTDeqZwVCWfx76SurT6aApqA/IqMtSQc K/7MJTwfwexwoGmSMaL/H7uIuatDYRc7nMe1qSN+HRGs5GU3UssR7nvr6GKI7ixAWcbU 3n2Q== 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 d14si8656285ejr.358.2019.10.01.04.42.29; Tue, 01 Oct 2019 04:42:53 -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; 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 S1733282AbfJALj5 (ORCPT + 99 others); Tue, 1 Oct 2019 07:39:57 -0400 Received: from mga17.intel.com ([192.55.52.151]:27909 "EHLO mga17.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732568AbfJALik (ORCPT ); Tue, 1 Oct 2019 07:38:40 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga007.jf.intel.com ([10.7.209.58]) by fmsmga107.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 01 Oct 2019 04:38:38 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.64,571,1559545200"; d="scan'208";a="181663251" Received: from black.fi.intel.com ([10.237.72.28]) by orsmga007.jf.intel.com with ESMTP; 01 Oct 2019 04:38:35 -0700 Received: by black.fi.intel.com (Postfix, from userid 1001) id 3C8B0440; Tue, 1 Oct 2019 14:38:31 +0300 (EEST) From: Mika Westerberg To: linux-usb@vger.kernel.org Cc: Andreas Noever , Michael Jamet , Mika Westerberg , Yehezkel Bernat , Rajmohan Mani , Nicholas Johnson , Lukas Wunner , Greg Kroah-Hartman , Alan Stern , Mario.Limonciello@dell.com, Anthony Wong , linux-kernel@vger.kernel.org Subject: [RFC PATCH 08/22] thunderbolt: Add downstream PCIe port mappings for Alpine and Titan Ridge Date: Tue, 1 Oct 2019 14:38:16 +0300 Message-Id: <20191001113830.13028-9-mika.westerberg@linux.intel.com> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191001113830.13028-1-mika.westerberg@linux.intel.com> References: <20191001113830.13028-1-mika.westerberg@linux.intel.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 In order to keep PCIe hierarchies consistent across hotplugs, add hard-coded PCIe downstream port to Thunderbolt port for Alpine Ridge and Titan Ridge as well. Signed-off-by: Mika Westerberg --- drivers/thunderbolt/tb.c | 4 +++- drivers/thunderbolt/tb.h | 25 +++++++++++++++++++++++++ 2 files changed, 28 insertions(+), 1 deletion(-) diff --git a/drivers/thunderbolt/tb.c b/drivers/thunderbolt/tb.c index dbbe9afb9fb7..704455a4f763 100644 --- a/drivers/thunderbolt/tb.c +++ b/drivers/thunderbolt/tb.c @@ -344,10 +344,12 @@ static struct tb_port *tb_find_pcie_down(struct tb_switch *sw, * Hard-coded Thunderbolt port to PCIe down port mapping * per controller. */ - if (tb_switch_is_cr(sw)) + if (tb_switch_is_cr(sw) || tb_switch_is_ar(sw)) index = !phy_port ? 6 : 7; else if (tb_switch_is_fr(sw)) index = !phy_port ? 6 : 8; + else if (tb_switch_is_tr(sw)) + index = !phy_port ? 8 : 9; else goto out; diff --git a/drivers/thunderbolt/tb.h b/drivers/thunderbolt/tb.h index e641dcebd50a..dbab06551eaa 100644 --- a/drivers/thunderbolt/tb.h +++ b/drivers/thunderbolt/tb.h @@ -632,6 +632,31 @@ static inline bool tb_switch_is_fr(const struct tb_switch *sw) } } +static inline bool tb_switch_is_ar(const struct tb_switch *sw) +{ + switch (sw->config.device_id) { + case PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_2C_BRIDGE: + case PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_LP_BRIDGE: + case PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_C_4C_BRIDGE: + case PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_C_2C_BRIDGE: + return true; + default: + return false; + } +} + +static inline bool tb_switch_is_tr(const struct tb_switch *sw) +{ + switch (sw->config.device_id) { + case PCI_DEVICE_ID_INTEL_TITAN_RIDGE_2C_BRIDGE: + case PCI_DEVICE_ID_INTEL_TITAN_RIDGE_4C_BRIDGE: + case PCI_DEVICE_ID_INTEL_TITAN_RIDGE_DD_BRIDGE: + return true; + default: + return false; + } +} + /** * tb_switch_is_icm() - Is the switch handled by ICM firmware * @sw: Switch to check -- 2.23.0