From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-wr1-f51.google.com (mail-wr1-f51.google.com [209.85.221.51]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id DAF201B5EB2 for ; Mon, 9 Sep 2024 13:04:29 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.221.51 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725887072; cv=none; b=jz3Dx4nB6gEr7pe7TPC1AyyMGd8IXb0MpM/h/bmGaylIZ8ufsCytitZpwmuOIIazeNS/Hu5rg5tQRbPAuwAzu6c9kBTVpZ3SzriyyiwYx6vcJMvkD60WrsGShDvFfkABsnY+lD6/JxgI/uFhKhgA8nyca3KSrPwJ5Lqt80t4Nwo= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725887072; c=relaxed/simple; bh=lx2CYDYSR1CbT/CmMmbFTKQTc/fLR1QO5Ubs+QXtE/I=; h=Message-ID:Date:MIME-Version:From:Subject:To:Cc:References: In-Reply-To:Content-Type; b=S2ODLAXRnIq/61x9tg+As7DgDl7FZTIoedCD6BY6nZzW94guZAnF/TH+d8WADLVKH82ETuc6UNSefHszFYpGqaYqvKjvy8ecTOGKtwJrNFF9VS1tn3zXsWMeCSLLFys7R//tP+WaUjYlQGd6yOUcEB2KIesdiL4/34ZZTvkv/8c= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linaro.org; spf=pass smtp.mailfrom=linaro.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b=atZ9rt2l; arc=none smtp.client-ip=209.85.221.51 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linaro.org Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=linaro.org Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b="atZ9rt2l" Received: by mail-wr1-f51.google.com with SMTP id ffacd0b85a97d-3787ddbd5a2so2516153f8f.0 for ; Mon, 09 Sep 2024 06:04:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1725887068; x=1726491868; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:organization:autocrypt :content-language:references:cc:to:subject:reply-to:from:user-agent :mime-version:date:message-id:from:to:cc:subject:date:message-id :reply-to; bh=n5JRzxSbj4JDQk1DvAF0xquTVL5OLgOLKN07OgcC5X4=; b=atZ9rt2lAnSRS/EyOlWjpUghBJRVwnVmX/Dmg7PJ5wJ3oICEMd88FJPpq8XRSwV/AU c87d4fRjnkMm+mUs9W40jPzH7Tb32pVdc6WWttJMGIWd94DTl32PzrSm4nLxX7kNhpxu BEkvDpKfDrnV4LCkGcopE8LORDGJrKmuShbbwB/16Sk6NfqoyuKXC29MvyQMOsr0/8CV xHtvbVNjgLc344lYXFjp0sN+6dGZPS56L+emA8PUA9nPBmGC/mdsz2ba52MMvoWTEqyN tK8m6DHIF6P09EGXHJ0Wa/MoDHYFYqSNI2CRM7Z134fwdGYzaUhfiqUBkOXbF/FUkKdR eTiw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1725887068; x=1726491868; h=content-transfer-encoding:in-reply-to:organization:autocrypt :content-language:references:cc:to:subject:reply-to:from:user-agent :mime-version:date:message-id:x-gm-message-state:from:to:cc:subject :date:message-id:reply-to; bh=n5JRzxSbj4JDQk1DvAF0xquTVL5OLgOLKN07OgcC5X4=; b=Bfi2bU0Ftyy9TUemlp4dUyN9zYQimCl7SWCzLPPOQvCOCdlLg3VLO6fadzfPlkCk1v P0urLv80qPGnQItN07XD1eRJ1W8nnE8MbN6lWwu6ggq/4/Opgs+QjJIIIf8v26gvyK63 aFic98sTQ9voiUd07CyHUDGh9dwpj+NMQEVAcFctHej6pW2SHM41pef4DeuEB44aNrEx AAXZFI1t/ra5r2YLumXZRiS10yYbv0hwRV9qdFgMPMUc1B00tJl1p7O2QWQzDm4TU604 jqi4G+lhPYOri/V5oGVWWLGkplLrS/HFPQfllaicKR+5anMLBAYDDZQktI974iAh9V9h nIOQ== X-Forwarded-Encrypted: i=1; AJvYcCW3Hy3iQpexGBAtYDVDJFpvgjEB2yIzV5ed4+aDYhy6pVvT5RSQYVxo67AXQ3wW33pPoN9LEPBVYAD4@vger.kernel.org X-Gm-Message-State: AOJu0YzlUlXGl65nAJUVCyt/6aQI4SyMq7FEWmu0o6UxMl1/9E2dQ9qB fv1wT6s7rhBbCIcnnCM2S0oEBRtrCkVIJL/ea7DhUNsl/ycW44DSqx9NlzXJIig= X-Google-Smtp-Source: AGHT+IH3gxY1z/lOYMSHoUdy0ssWQK8afuRORmstaN/fY3SrpIwZPg8k+EH1IZysvKPtqjBSYN/Q8Q== X-Received: by 2002:a05:6000:a84:b0:35f:122e:bd8c with SMTP id ffacd0b85a97d-378895ca7fbmr7310933f8f.17.1725887067538; Mon, 09 Sep 2024 06:04:27 -0700 (PDT) Received: from ?IPV6:2a01:e0a:982:cbb0:63a3:6883:a358:b850? ([2a01:e0a:982:cbb0:63a3:6883:a358:b850]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-378956d2ee6sm5973948f8f.83.2024.09.09.06.04.26 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 09 Sep 2024 06:04:27 -0700 (PDT) Message-ID: <3dddd226-c726-434e-8828-c12f76a71752@linaro.org> Date: Mon, 9 Sep 2024 15:04:26 +0200 Precedence: bulk X-Mailing-List: devicetree@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird From: neil.armstrong@linaro.org Reply-To: neil.armstrong@linaro.org Subject: Re: [PATCH v2 4/4] i2c: i2c-qcom-geni: Enable i2c controller sharing between two subsystems To: Mukesh Kumar Savaliya , konrad.dybcio@linaro.org, andersson@kernel.org, andi.shyti@kernel.org, linux-arm-msm@vger.kernel.org, dmaengine@vger.kernel.org, linux-kernel@vger.kernel.org, linux-i2c@vger.kernel.org, conor+dt@kernel.org, agross@kernel.org, devicetree@vger.kernel.org, vkoul@kernel.org, linux@treblig.org, dan.carpenter@linaro.org, Frank.Li@nxp.com, konradybcio@kernel.org Cc: quic_vdadhani@quicinc.com References: <20240906191438.4104329-1-quic_msavaliy@quicinc.com> <20240906191438.4104329-5-quic_msavaliy@quicinc.com> <3bd27b6d-74b8-4f7b-b3eb-64682442bbda@quicinc.com> Content-Language: en-US, fr Autocrypt: addr=neil.armstrong@linaro.org; keydata= xsBNBE1ZBs8BCAD78xVLsXPwV/2qQx2FaO/7mhWL0Qodw8UcQJnkrWmgTFRobtTWxuRx8WWP GTjuhvbleoQ5Cxjr+v+1ARGCH46MxFP5DwauzPekwJUD5QKZlaw/bURTLmS2id5wWi3lqVH4 BVF2WzvGyyeV1o4RTCYDnZ9VLLylJ9bneEaIs/7cjCEbipGGFlfIML3sfqnIvMAxIMZrvcl9 qPV2k+KQ7q+aXavU5W+yLNn7QtXUB530Zlk/d2ETgzQ5FLYYnUDAaRl+8JUTjc0CNOTpCeik 80TZcE6f8M76Xa6yU8VcNko94Ck7iB4vj70q76P/J7kt98hklrr85/3NU3oti3nrIHmHABEB AAHNKk5laWwgQXJtc3Ryb25nIDxuZWlsLmFybXN0cm9uZ0BsaW5hcm8ub3JnPsLAkQQTAQoA OwIbIwULCQgHAwUVCgkICwUWAgMBAAIeAQIXgBYhBInsPQWERiF0UPIoSBaat7Gkz/iuBQJk Q5wSAhkBAAoJEBaat7Gkz/iuyhMIANiD94qDtUTJRfEW6GwXmtKWwl/mvqQtaTtZID2dos04 YqBbshiJbejgVJjy+HODcNUIKBB3PSLaln4ltdsV73SBcwUNdzebfKspAQunCM22Mn6FBIxQ GizsMLcP/0FX4en9NaKGfK6ZdKK6kN1GR9YffMJd2P08EO8mHowmSRe/ExAODhAs9W7XXExw UNCY4pVJyRPpEhv373vvff60bHxc1k/FF9WaPscMt7hlkbFLUs85kHtQAmr8pV5Hy9ezsSRa GzJmiVclkPc2BY592IGBXRDQ38urXeM4nfhhvqA50b/nAEXc6FzqgXqDkEIwR66/Gbp0t3+r yQzpKRyQif3OwE0ETVkGzwEIALyKDN/OGURaHBVzwjgYq+ZtifvekdrSNl8TIDH8g1xicBYp QTbPn6bbSZbdvfeQPNCcD4/EhXZuhQXMcoJsQQQnO4vwVULmPGgtGf8PVc7dxKOeta+qUh6+ SRh3vIcAUFHDT3f/Zdspz+e2E0hPV2hiSvICLk11qO6cyJE13zeNFoeY3ggrKY+IzbFomIZY 4yG6xI99NIPEVE9lNBXBKIlewIyVlkOaYvJWSV+p5gdJXOvScNN1epm5YHmf9aE2ZjnqZGoM Mtsyw18YoX9BqMFInxqYQQ3j/HpVgTSvmo5ea5qQDDUaCsaTf8UeDcwYOtgI8iL4oHcsGtUX oUk33HEAEQEAAcLAXwQYAQIACQUCTVkGzwIbDAAKCRAWmrexpM/4rrXiB/sGbkQ6itMrAIfn M7IbRuiSZS1unlySUVYu3SD6YBYnNi3G5EpbwfBNuT3H8//rVvtOFK4OD8cRYkxXRQmTvqa3 3eDIHu/zr1HMKErm+2SD6PO9umRef8V82o2oaCLvf4WeIssFjwB0b6a12opuRP7yo3E3gTCS KmbUuLv1CtxKQF+fUV1cVaTPMyT25Od+RC1K+iOR0F54oUJvJeq7fUzbn/KdlhA8XPGzwGRy 4zcsPWvwnXgfe5tk680fEKZVwOZKIEuJC3v+/yZpQzDvGYJvbyix0lHnrCzq43WefRHI5XTT QbM0WUIBIcGmq38+OgUsMYu4NzLu7uZFAcmp6h8g Organization: Linaro In-Reply-To: <3bd27b6d-74b8-4f7b-b3eb-64682442bbda@quicinc.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit On 09/09/2024 11:18, Mukesh Kumar Savaliya wrote: > Hi Neil, > > On 9/9/2024 2:24 PM, neil.armstrong@linaro.org wrote: >> Hi, >> >> On 06/09/2024 21:14, Mukesh Kumar Savaliya wrote: >>> Add support to share I2C SE by two Subsystems in a mutually exclusive way. >>> Use  "qcom,shared-se" flag in a particular i2c instance node if the >>> usecase requires i2c controller to be shared. >>> >>> I2C driver just need to mark first_msg and last_msg flag to help indicate >>> GPI driver to  take lock and unlock TRE there by protecting from concurrent >>> access from other EE or Subsystem. >>> >>> gpi_create_i2c_tre() function at gpi.c will take care of adding Lock and >>> Unlock TRE for the respective transfer operations. >>> >>> Since the GPIOs are also shared for the i2c bus between two SS, do not >>> touch GPIO configuration during runtime suspend and only turn off the >>> clocks. This will allow other SS to continue to transfer the data >>> without any disturbance over the IO lines. >> >> This doesn't answer my question about what would be the behavior if one >> use uses, for example, GPI DMA, and the Linux kernel FIFO mode or SE DMA ? >> > Shared usecase is not supported for non GSI mode (FIFO and DMA), it should be static usecase. Dynamic sharing from two clients of two subsystems is only for GSI mode. Hope this helps ? Sure, this is why I proposed on v1 cover letter reply to add: ==============><===================================================================== diff --git a/drivers/i2c/busses/i2c-qcom-geni.c b/drivers/i2c/busses/i2c-qcom-geni.c index ee2e431601a6..a15825ea56de 100644 --- a/drivers/i2c/busses/i2c-qcom-geni.c +++ b/drivers/i2c/busses/i2c-qcom-geni.c @@ -885,7 +885,7 @@ static int geni_i2c_probe(struct platform_device *pdev) else fifo_disable = readl_relaxed(gi2c->se.base + GENI_IF_DISABLE_RO) & FIFO_IF_DISABLE; - if (fifo_disable) { + if (gi2c->is_shared || fifo_disable) { /* FIFO is disabled, so we can only use GPI DMA */ gi2c->gpi_mode = true; ret = setup_gpi_dma(gi2c); ==============><===================================================================== Thanks, Neil >> Because it seems to "fix" only the GPI DMA shared case. >> >> Neil >> >>> >>> Signed-off-by: Mukesh Kumar Savaliya >>> --- >>>   drivers/i2c/busses/i2c-qcom-geni.c | 29 ++++++++++++++++++++++------- >>>   1 file changed, 22 insertions(+), 7 deletions(-) >>> >>> diff --git a/drivers/i2c/busses/i2c-qcom-geni.c b/drivers/i2c/busses/i2c-qcom-geni.c >>> index eebb0cbb6ca4..ee2e431601a6 100644 >>> --- a/drivers/i2c/busses/i2c-qcom-geni.c >>> +++ b/drivers/i2c/busses/i2c-qcom-geni.c >>> @@ -1,5 +1,6 @@ >>>   // SPDX-License-Identifier: GPL-2.0 >>>   // Copyright (c) 2017-2018, The Linux Foundation. All rights reserved. >>> +// Copyright (c) 2024 Qualcomm Innovation Center, Inc. All rights reserved. >>>   #include >>>   #include >>> @@ -99,6 +100,7 @@ struct geni_i2c_dev { >>>       struct dma_chan *rx_c; >>>       bool gpi_mode; >>>       bool abort_done; >>> +    bool is_shared; >>>   }; >>>   struct geni_i2c_desc { >>> @@ -602,6 +604,7 @@ static int geni_i2c_gpi_xfer(struct geni_i2c_dev *gi2c, struct i2c_msg msgs[], i >>>       peripheral.clk_div = itr->clk_div; >>>       peripheral.set_config = 1; >>>       peripheral.multi_msg = false; >>> +    peripheral.shared_se = gi2c->is_shared; >>>       for (i = 0; i < num; i++) { >>>           gi2c->cur = &msgs[i]; >>> @@ -612,6 +615,8 @@ static int geni_i2c_gpi_xfer(struct geni_i2c_dev *gi2c, struct i2c_msg msgs[], i >>>           if (i < num - 1) >>>               peripheral.stretch = 1; >>> +        peripheral.first_msg = (i == 0); >>> +        peripheral.last_msg = (i == num - 1); >>>           peripheral.addr = msgs[i].addr; >>>           ret =  geni_i2c_gpi(gi2c, &msgs[i], &config, >>> @@ -631,8 +636,11 @@ static int geni_i2c_gpi_xfer(struct geni_i2c_dev *gi2c, struct i2c_msg msgs[], i >>>           dma_async_issue_pending(gi2c->tx_c); >>>           time_left = wait_for_completion_timeout(&gi2c->done, XFER_TIMEOUT); >>> -        if (!time_left) >>> +        if (!time_left) { >>> +            dev_err(gi2c->se.dev, "I2C timeout gpi flags:%d addr:0x%x\n", >>> +                        gi2c->cur->flags, gi2c->cur->addr); >>>               gi2c->err = -ETIMEDOUT; >>> +        } >>>           if (gi2c->err) { >>>               ret = gi2c->err; >>> @@ -800,6 +808,11 @@ static int geni_i2c_probe(struct platform_device *pdev) >>>           gi2c->clk_freq_out = KHZ(100); >>>       } >>> +    if (of_property_read_bool(pdev->dev.of_node, "qcom,shared-se")) { >>> +        gi2c->is_shared = true; >>> +        dev_dbg(&pdev->dev, "Shared SE Usecase\n"); >>> +    } >>> + >>>       if (has_acpi_companion(dev)) >>>           ACPI_COMPANION_SET(&gi2c->adap.dev, ACPI_COMPANION(dev)); >>> @@ -962,14 +975,16 @@ static int __maybe_unused geni_i2c_runtime_suspend(struct device *dev) >>>       struct geni_i2c_dev *gi2c = dev_get_drvdata(dev); >>>       disable_irq(gi2c->irq); >>> -    ret = geni_se_resources_off(&gi2c->se); >>> -    if (ret) { >>> -        enable_irq(gi2c->irq); >>> -        return ret; >>> - >>> +    if (gi2c->is_shared) { >>> +        geni_se_clks_off(&gi2c->se); >>>       } else { >>> -        gi2c->suspended = 1; >>> +        ret = geni_se_resources_off(&gi2c->se); >>> +        if (ret) { >>> +            enable_irq(gi2c->irq); >>> +            return ret; >>> +        } >>>       } >>> +    gi2c->suspended = 1; >>>       clk_disable_unprepare(gi2c->core_clk); >> >>