Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp1003481imm; Sun, 2 Sep 2018 06:33:28 -0700 (PDT) X-Google-Smtp-Source: ANB0VdZdSmFylcgNzBL+7WMOq00N9ZGW3dqRN4vjpdUR51ZQMZnPLeofdW3ZE7O3/xfZlJC/48UQ X-Received: by 2002:a17:902:b58a:: with SMTP id a10-v6mr24379425pls.306.1535895208608; Sun, 02 Sep 2018 06:33:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535895208; cv=none; d=google.com; s=arc-20160816; b=ntF4hsUkPZIMXneeJeB75O5NFUmPuPlJWP63pcNe2GajV0Qs0axXFB2ni54DUHbjCb kEgDK3XOBFilaVh/KjzSoWZaRgZcolyhqP6KughMIuoSwldY1WMY2ggsnJNrPVX/2HKl KGSX+Jpdzu23hQdoYJGH9E8uo5VtG4+93YfdQkWuxoSewrBBMQxKMzxGuhA8Fj4ERkYW hMelzsI4m1mdyg2PmC37j0+xvXEsRf/Q6ztz3oMViPOs+5sCqcl7AjKpuB7obWIDLlKy jmFsLOm4OQcxeO+4lRG0qkf0Q5DXv5EGQ28kpuQZt+E+MgoM1VsdVg3Ruqs0G0GGkDBe nMZw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :spamdiagnosticmetadata:spamdiagnosticoutput:content-language :accept-language:in-reply-to:references:message-id:date:thread-index :thread-topic:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=cvUs/pz4fYOa8KmZEVYgSIgg7T/F/rpqhTL3kONKt1Y=; b=D55+pA0Prtxht/eFRXKZAfjwcVO1vF7aHJ4DaNGKH7Szdmz48Rg/SJwUwdQHMWPSnl QBM/uQKYV+dV9jYTQ50VfznliCTTN9ePU1bWZJgjGYCdWzpP6G6KD1dE6Z6la75/QEag fzTjSe0roJhJdFUQqybBy89U1fE8D4YDyorkHVaA2L4yHXGCU4LC9efZF+fQo613QvON OfTx4HR7OKsEX6olTP7OdQCnru7S1d2Ruiu2NGY4Op4n/8fIPjRsSuf99YxYVCK6STE4 UiFOU8t6PfFrmKQA+aX7xikQ+TZ4W50I4cw6xQSJ/W0VCNCE0WJ5kDtdvxHt++0mg7cv DbOA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@microsoft.com header.s=selector1 header.b="MXX3mz/U"; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l3-v6si14986263pld.501.2018.09.02.06.33.13; Sun, 02 Sep 2018 06:33:28 -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=@microsoft.com header.s=selector1 header.b="MXX3mz/U"; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728391AbeIBRUy (ORCPT + 99 others); Sun, 2 Sep 2018 13:20:54 -0400 Received: from mail-eopbgr680117.outbound.protection.outlook.com ([40.107.68.117]:50363 "EHLO NAM04-BN3-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728335AbeIBRUx (ORCPT ); Sun, 2 Sep 2018 13:20:53 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=cvUs/pz4fYOa8KmZEVYgSIgg7T/F/rpqhTL3kONKt1Y=; b=MXX3mz/UWwjZiD96iycb/ypEyEWsTP8BfwS1kvlizOlOS7ygDDVmSYcKZfLNQaKLg3eoTKCwsvlw1oa0fjV7SMJ8fK6USvhb750SFEb70wW6SvVbsJiTd6/TywzRq459cJDuQYuuseP2kYlrrk75hXTAVvNhJCOmYqlZlLvLstQ= Received: from CY4PR21MB0776.namprd21.prod.outlook.com (10.173.192.22) by CY4PR21MB0741.namprd21.prod.outlook.com (10.173.189.7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.1122.2; Sun, 2 Sep 2018 13:04:58 +0000 Received: from CY4PR21MB0776.namprd21.prod.outlook.com ([fe80::7c3a:eea8:1391:1611]) by CY4PR21MB0776.namprd21.prod.outlook.com ([fe80::7c3a:eea8:1391:1611%7]) with mapi id 15.20.1143.000; Sun, 2 Sep 2018 13:04:58 +0000 From: Sasha Levin To: "stable@vger.kernel.org" , "linux-kernel@vger.kernel.org" CC: Peter Rosin , Wolfram Sang , Sasha Levin Subject: [PATCH AUTOSEL 4.18 085/131] tpm/tpm_i2c_infineon: switch to i2c_lock_bus(..., I2C_LOCK_SEGMENT) Thread-Topic: [PATCH AUTOSEL 4.18 085/131] tpm/tpm_i2c_infineon: switch to i2c_lock_bus(..., I2C_LOCK_SEGMENT) Thread-Index: AQHUQr2ISDfoXTMMsEeDt++jixhOHw== Date: Sun, 2 Sep 2018 13:04:51 +0000 Message-ID: <20180902064601.183036-85-alexander.levin@microsoft.com> References: <20180902064601.183036-1-alexander.levin@microsoft.com> In-Reply-To: <20180902064601.183036-1-alexander.levin@microsoft.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [52.168.54.252] x-ms-publictraffictype: Email x-microsoft-exchange-diagnostics: 1;CY4PR21MB0741;6:77ye9CR9SedFOSvYLKUtmQmkIWeni1NvUqlS/LuS5bdMi0kTXYMgTH26RsoAp4A2WTWgCql6Oxt9hHn50lZvwtvlN6Ui3X6XF0DEAWEYby1lbLt5Z/0fBiuHOTx8LLLeu767i3J6Zr+QIl9Y0e89UFaVPXp+qaZYQIF51/9rJX8aGhhQPomk3t1JKrpYJykgr30jvMD8MkqjYZfsSbCIxUW/XcXHcw7L1EKEZkIXhihK9e2xjwQ29TBeKLTjjx5gKL/VEiFcFq61fJzIWcqUQtiWBIPZsB8nICrEUlRvrYE9dk+FOIOcm7Rb9NdF2qgD26UbJMSOJrzh8/M5xHykrjH4KE8qo8iQFwDOvhTn2+oNSAwJG39KxfSfILk092SfQwUOjVpjdWeyxo3QzPmREoaIND9w5Uy4VRWV9o9TaX0mkCdwle45H8bPPjx929PWb1MDhFyJB5oGCqHz5AXHHw==;5:IcTVIxvCrCCaCkaEdPsiwenf9KSPoFaoNtWholkbTfK68Kfxp3DtBsTQX65E0+A459fCvxMi20XWhUjGWCCmHm/XTDk8jZhO3X9LiTDb+ad1WyZ7YOnB6Q7G02RSPKwIDY4Ue28TzkOKf80yx+esKqoWJ6i9Pbqj+NRWOO6JJCk=;7:NQ4dvkRVFnnyCVAmujYpwSpXawvkIfKFgMENh7dKX5bMHP/8amd/64oj8pgaoci2zJS+Ao/3s8Y8WsGh9d4hzcb8+YoKb/J3ku5OmatzuFWvBP5bvXMP6PwB5w6Ip04lkSnourvzRGQvSYkdv5tPqKhuAnp4hbUwN4568hfLA5rIvIKk0dsJTFJ8i+zL4z1P+s7dOh9mZaqvHp3RM15IEKUF9FgBFlZ3OBRVnFyMYBwA9lx3cprQpngk1j7WRo7f x-ms-office365-filtering-correlation-id: c14ee241-ddfd-4952-152c-08d610d4af9b x-ms-office365-filtering-ht: Tenant x-microsoft-antispam: BCL:0;PCL:0;RULEID:(7020095)(4652040)(4534165)(4627221)(201703031133081)(201702281549075)(5600074)(711020)(4618075)(2017052603328)(7193020);SRVR:CY4PR21MB0741; x-ms-traffictypediagnostic: CY4PR21MB0741: authentication-results: spf=none (sender IP is ) smtp.mailfrom=Alexander.Levin@microsoft.com; x-microsoft-antispam-prvs: x-exchange-antispam-report-test: UriScan:(28532068793085)(89211679590171)(228905959029699); x-ms-exchange-senderadcheck: 1 x-exchange-antispam-report-cfa-test: BCL:0;PCL:0;RULEID:(8211001083)(6040522)(2401047)(8121501046)(5005006)(93006095)(93001095)(10201501046)(3231340)(944501410)(52105095)(2018427008)(3002001)(6055026)(149027)(150027)(6041310)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123562045)(20161123558120)(20161123564045)(20161123560045)(201708071742011)(7699049)(76991033);SRVR:CY4PR21MB0741;BCL:0;PCL:0;RULEID:;SRVR:CY4PR21MB0741; x-forefront-prvs: 078310077C x-forefront-antispam-report: SFV:NSPM;SFS:(10019020)(366004)(39860400002)(136003)(346002)(396003)(376002)(43544003)(199004)(189003)(97736004)(2906002)(186003)(26005)(256004)(14444005)(102836004)(11346002)(25786009)(476003)(486006)(2616005)(446003)(305945005)(66066001)(5250100002)(2501003)(7736002)(6506007)(8676002)(68736007)(76176011)(15760500003)(6666003)(99286004)(6486002)(105586002)(81156014)(81166006)(53936002)(5660300001)(22452003)(478600001)(6436002)(86362001)(14454004)(54906003)(36756003)(106356001)(110136005)(6512007)(4326008)(107886003)(217873002)(3846002)(2900100001)(316002)(8936002)(1076002)(10090500001)(6116002)(72206003)(86612001)(10290500003)(70780200001);DIR:OUT;SFP:1102;SCL:1;SRVR:CY4PR21MB0741;H:CY4PR21MB0776.namprd21.prod.outlook.com;FPR:;SPF:None;LANG:en;PTR:InfoNoRecords;A:1;MX:1; received-spf: None (protection.outlook.com: microsoft.com does not designate permitted sender hosts) x-microsoft-antispam-message-info: wjSVP9z1l8fb8UiXkTgw1pC11FQm79/cVG7MdW3RfP1f7we9po3Anx0XZjVa4ODa84eMEDpjzaUQ+t+7V5/MGCCED3YmJQtULxzAcabcoqMtN5I/brOpxx/0jtkU39ouDhHhR1ox4d01Wk11s6xqr4d7Q5EWfMvNv6bkNNpow0PL8Tqgs2pLcteK7HKa6rY87pQWfoASu7yvfNSzcaDTvFE47E4luxSgYhPfqBFiZlDVfcuMJlwdFOCz3Ccn2fI2PcaVntdE8Wj98Tq4HdxgCrdx9uYXkPnBboG/5AZ2lBzTt5nusEx0kMT/58vkxxKEckYOAmVYxdYl9vXEpNiFWtKngilmUR/H3ZaYDBMsc7U= spamdiagnosticoutput: 1:99 spamdiagnosticmetadata: NSPM Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-OriginatorOrg: microsoft.com X-MS-Exchange-CrossTenant-Network-Message-Id: c14ee241-ddfd-4952-152c-08d610d4af9b X-MS-Exchange-CrossTenant-originalarrivaltime: 02 Sep 2018 13:04:51.1560 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 72f988bf-86f1-41af-91ab-2d7cd011db47 X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY4PR21MB0741 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Peter Rosin [ Upstream commit bb853aac2c478ce78116128263801189408ad2a8 ] Locking the root adapter for __i2c_transfer will deadlock if the device sits behind a mux-locked I2C mux. Switch to the finer-grained i2c_lock_bus with the I2C_LOCK_SEGMENT flag. If the device does not sit behind a mux-locked mux, the two locking variants are equivalent. Signed-off-by: Peter Rosin Reviewed-by: Jarkko Sakkinen Tested-by: Alexander Steffen Signed-off-by: Wolfram Sang Signed-off-by: Sasha Levin --- drivers/char/tpm/tpm_i2c_infineon.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/drivers/char/tpm/tpm_i2c_infineon.c b/drivers/char/tpm/tpm_i2c= _infineon.c index 6116cd05e228..9086edc9066b 100644 --- a/drivers/char/tpm/tpm_i2c_infineon.c +++ b/drivers/char/tpm/tpm_i2c_infineon.c @@ -117,7 +117,7 @@ static int iic_tpm_read(u8 addr, u8 *buffer, size_t len= ) /* Lock the adapter for the duration of the whole sequence. */ if (!tpm_dev.client->adapter->algo->master_xfer) return -EOPNOTSUPP; - i2c_lock_adapter(tpm_dev.client->adapter); + i2c_lock_bus(tpm_dev.client->adapter, I2C_LOCK_SEGMENT); =20 if (tpm_dev.chip_type =3D=3D SLB9645) { /* use a combined read for newer chips @@ -192,7 +192,7 @@ static int iic_tpm_read(u8 addr, u8 *buffer, size_t len= ) } =20 out: - i2c_unlock_adapter(tpm_dev.client->adapter); + i2c_unlock_bus(tpm_dev.client->adapter, I2C_LOCK_SEGMENT); /* take care of 'guard time' */ usleep_range(SLEEP_DURATION_LOW, SLEEP_DURATION_HI); =20 @@ -224,7 +224,7 @@ static int iic_tpm_write_generic(u8 addr, u8 *buffer, s= ize_t len, =20 if (!tpm_dev.client->adapter->algo->master_xfer) return -EOPNOTSUPP; - i2c_lock_adapter(tpm_dev.client->adapter); + i2c_lock_bus(tpm_dev.client->adapter, I2C_LOCK_SEGMENT); =20 /* prepend the 'register address' to the buffer */ tpm_dev.buf[0] =3D addr; @@ -243,7 +243,7 @@ static int iic_tpm_write_generic(u8 addr, u8 *buffer, s= ize_t len, usleep_range(sleep_low, sleep_hi); } =20 - i2c_unlock_adapter(tpm_dev.client->adapter); + i2c_unlock_bus(tpm_dev.client->adapter, I2C_LOCK_SEGMENT); /* take care of 'guard time' */ usleep_range(SLEEP_DURATION_LOW, SLEEP_DURATION_HI); =20 --=20 2.17.1