Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp2520400yba; Mon, 15 Apr 2019 13:27:50 -0700 (PDT) X-Google-Smtp-Source: APXvYqylO1UW09IcaOsVbI1oDkgQVLs8BdUC87Pt0JV5qm8z2GpyUI2ERjE39GT4WHjt4DYlYnZZ X-Received: by 2002:a63:c64a:: with SMTP id x10mr68063475pgg.12.1555360070010; Mon, 15 Apr 2019 13:27:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555360070; cv=none; d=google.com; s=arc-20160816; b=E7ns8ZpD4S999k6gtM/foO+RRnquebHyalFKpyIhsrXtb+JGIyEDuhnuXR44q1VXGc tXylzYRF2MOrgUhGw2u3VRno0FIhSE5ARaZ9oCTjFo+5V0mpDhsf317mv28XABglsy8G X3w9b4xfy73VAjrMDrYoKL7xPWPbcSzvBio57abyz1ouj0GQpGafvO3HQ1M0aOHSIvRx k2aGZAU6ZSz1R7GG6V6tSDkXm7F9Fr9mcd28nFW8wwHAR1H5rnPlC0H14up4lc7WvQ4w GY+rdXbkgSq34tJZnjESSkGjXN9LkPOpqJGXPO5TzgR5/ouT8vV1r+pS+mbfJtnGt3oL 0MWw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:references :in-reply-to:message-id:date:subject:cc:to:from:dkim-signature; bh=UUudUSBlAB0Dd8op/UfBKTDdoZ7S4V14eWqKXbWKWbE=; b=HjVXsg0s73930vT/A+yeIzjTwVUYlevEwi/WxFSWQYdsO0kxCHQDSM2Y1FJl59BuQd DO/s6FolVe3jHW60eZx6rAHBerlhnK8lVydDj7q9HeLMvv54m7ndY9sPRs1GemjLu91K oJ/hbOBbtkoILAPwRg/P8mbIDMLdnGFwLeunMDdAzdGEAGgITlV973Mu0r9HXg6DeOt9 ejDTrYVOVy1kWhWcmls5unCMuZREHfe80/WjXYBsZDivJYO8huHlTtrC6GhlYo9hZKOc gn5aLzSh9qUzg0ze2SBSpT7BjwqbukJtmmihntaI7iPY+XhHL3uxVUlaf7knYWa4Guhd SQlw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@synopsys.com header.s=mail header.b="H/NcfGZX"; 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=NONE sp=NONE dis=NONE) header.from=synopsys.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g4si43694351plp.196.2019.04.15.13.27.34; Mon, 15 Apr 2019 13:27:49 -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=@synopsys.com header.s=mail header.b="H/NcfGZX"; 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=NONE sp=NONE dis=NONE) header.from=synopsys.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728178AbfDOSm5 (ORCPT + 99 others); Mon, 15 Apr 2019 14:42:57 -0400 Received: from smtprelay2.synopsys.com ([198.182.60.111]:55458 "EHLO smtprelay.synopsys.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727256AbfDOSm4 (ORCPT ); Mon, 15 Apr 2019 14:42:56 -0400 Received: from mailhost1.synopsys.com (mailhost1.synopsys.com [10.12.238.239]) by smtprelay.synopsys.com (Postfix) with ESMTP id 29C4510C0AF2; Mon, 15 Apr 2019 11:42:56 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=synopsys.com; s=mail; t=1555353776; bh=wX6fVVw/1LVztXtlfWLPbksI1sg7Ijps62PR35UWDH8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:In-Reply-To: References:From; b=H/NcfGZXC86NP4ju/iq88b9/N+E/NelFMWvB+dm9B7AdTeh30G/O4OvKG7Jld24R4 Vndqt+QCIaBa/MsuFHj8SlLuBGSqnILFkGHD+Zab+Mu82yM/0+h8YZ5gegvP+gZIyo xC00My1Rr/Qh3B4Mflcj7K2z1OdWkRSWQN4+J2CI0YEaXqcrzwLADsXcv+rPZk3R6Y V4Ah/1oPSnBgTOLQjg0KfsD85EqulEKnj6Fei9mS3qMockdQObHbwSBEKdNcpnq0Mm M2Ms62Nw46r6nJS2c29918omon+CC7R8YCzFWROi16yZSykTFYP31+xOS29fZAoq46 a4m3QU5Odct4A== Received: from de02dwia024.internal.synopsys.com (de02dwia024.internal.synopsys.com [10.225.19.81]) by mailhost1.synopsys.com (Postfix) with ESMTP id D853C5B62; Mon, 15 Apr 2019 11:42:54 -0700 (PDT) From: Vitor Soares To: vitor.soares@synopsys.com Cc: Vitor Soares , Boris Brezillon , stable@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 1/3] i3c: fix i2c and i3c scl rate by bus mode Date: Mon, 15 Apr 2019 20:42:45 +0200 Message-Id: <05fdeea79db83970e9ecb0d7045b4dd98f206f06.1555350118.git.vitor.soares@synopsys.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: References: In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently in case of mixed slow bus topologie and all i2c devices support FM+ speed, the i3c subsystem limite the SCL to FM speed. Also in case on mixed slow bus mode the max speed for both i2c or i3c transfers is FM or FM+. This patch fix the definition of i2c and i3c scl rate based on bus topologie and LVR[4] if no user input. In case of mixed slow mode the i3c scl rate is overridden. Fixes: 3a379bbcea0a ("i3c: Add core I3C infrastructure") Signed-off-by: Vitor Soares Cc: Boris Brezillon Cc: Cc: --- drivers/i3c/master.c | 39 +++++++++++++++++++++++++-------------- 1 file changed, 25 insertions(+), 14 deletions(-) diff --git a/drivers/i3c/master.c b/drivers/i3c/master.c index 909c2ad..1c4a86a 100644 --- a/drivers/i3c/master.c +++ b/drivers/i3c/master.c @@ -564,20 +564,30 @@ static const struct device_type i3c_masterdev_type = { .groups = i3c_masterdev_groups, }; -int i3c_bus_set_mode(struct i3c_bus *i3cbus, enum i3c_bus_mode mode) +int i3c_bus_set_mode(struct i3c_bus *i3cbus, enum i3c_bus_mode mode, + unsigned long i2c_scl_rate) { i3cbus->mode = mode; - if (!i3cbus->scl_rate.i3c) - i3cbus->scl_rate.i3c = I3C_BUS_TYP_I3C_SCL_RATE; - - if (!i3cbus->scl_rate.i2c) { - if (i3cbus->mode == I3C_BUS_MODE_MIXED_SLOW) - i3cbus->scl_rate.i2c = I3C_BUS_I2C_FM_SCL_RATE; - else - i3cbus->scl_rate.i2c = I3C_BUS_I2C_FM_PLUS_SCL_RATE; + switch (i3cbus->mode) { + case I3C_BUS_MODE_PURE: + if (!i3cbus->scl_rate.i3c) + i3cbus->scl_rate.i3c = I3C_BUS_TYP_I3C_SCL_RATE; + break; + case I3C_BUS_MODE_MIXED_FAST: + if (!i3cbus->scl_rate.i3c) + i3cbus->scl_rate.i3c = I3C_BUS_TYP_I3C_SCL_RATE; + if (!i3cbus->scl_rate.i2c) + i3cbus->scl_rate.i2c = i2c_scl_rate; + break; + case I3C_BUS_MODE_MIXED_SLOW: + if (!i3cbus->scl_rate.i2c) + i3cbus->scl_rate.i2c = i2c_scl_rate; + i3cbus->scl_rate.i3c = i3cbus->scl_rate.i2c; + break; + default: + return -EINVAL; } - /* * I3C/I2C frequency may have been overridden, check that user-provided * values are not exceeding max possible frequency. @@ -1980,9 +1990,6 @@ of_i3c_master_add_i2c_boardinfo(struct i3c_master_controller *master, /* LVR is encoded in reg[2]. */ boardinfo->lvr = reg[2]; - if (boardinfo->lvr & I3C_LVR_I2C_FM_MODE) - master->bus.scl_rate.i2c = I3C_BUS_I2C_FM_SCL_RATE; - list_add_tail(&boardinfo->node, &master->boardinfo.i2c); of_node_get(node); @@ -2432,6 +2439,7 @@ int i3c_master_register(struct i3c_master_controller *master, const struct i3c_master_controller_ops *ops, bool secondary) { + unsigned long i2c_scl_rate = I3C_BUS_I2C_FM_PLUS_SCL_RATE; struct i3c_bus *i3cbus = i3c_master_get_bus(master); enum i3c_bus_mode mode = I3C_BUS_MODE_PURE; struct i2c_dev_boardinfo *i2cbi; @@ -2481,9 +2489,12 @@ int i3c_master_register(struct i3c_master_controller *master, ret = -EINVAL; goto err_put_dev; } + + if (i2cbi->lvr & I3C_LVR_I2C_FM_MODE) + i2c_scl_rate = I3C_BUS_I2C_FM_SCL_RATE; } - ret = i3c_bus_set_mode(i3cbus, mode); + ret = i3c_bus_set_mode(i3cbus, mode, i2c_scl_rate); if (ret) goto err_put_dev; -- 2.7.4