Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp1904323pxa; Thu, 6 Aug 2020 20:15:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwSFsaQKpuTI0Mp8cXNsOnwODe2N7bJdaH9huKvvjTHU59ne8e+q5eCNcpia6HgJsTMzmb3 X-Received: by 2002:aa7:d70a:: with SMTP id t10mr6841954edq.68.1596770155522; Thu, 06 Aug 2020 20:15:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596770155; cv=none; d=google.com; s=arc-20160816; b=eWq+0x05xjSwxLuK7TKpU58QoVS0C6JuGGQHcKO7DoR3NUZZ9V1UZ714y5TJOuWLie J+q/C5YA0+0mvWE6lHFSF6ZBjwL6ZdWiak/v7fs2tFdS9C96CmwuSURPHXOecArl+e+H kmfKbhefQ/jIQHro0peTv0Ji4ExBRcEYhANbJCHrUhiUhI0dyMzd8aQF4ciz9Gp/Poyv ArSr07pfNHDeChOs5ze0dw9IEwjgSmG9ag1NnGYmPlDbWjrHeLdKclFH3QpSgI+/LH1/ 5lXp/EeH4tHbdp7slqcwCeeUKoXY7MCTUCCoyqg9LZYWNUKq9PYuIzlKi5dERCpcFx0F Nk9A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:references:cc:to:from:subject; bh=6pJfOCjVj6hQbgZO0kcGHqWsN/R/wFr41mMvdHVndAA=; b=m4u4gSjsN/0BuDzWm9hJ4N3YR1ncyRACuU8sjAl1B1GQxGY/Cq/LCsb31h2uBvMUMK EIu11nHdattWKNDHZ57aAm1MkBKt5WpjHxp+GaBLjcognblyKe2bHP1ihXk1o6wSgYbs 8nLr6tCKWXjolH6MuFPxYk0a47ExYUDDlQDUFe2KLpsBkl3fwEgXcM7NOcFlaq+Qk7u2 OYr1x2+KPq0y2jwJpq5BwE/JSG0Q86ga8O7DZZ3mFcOKd71w+95qZTYVeCVR8ZuP/Tfl sCupNc4oNm+sNoherI6ykLQ523K4nThPP0DTVwhHVhvRq5DwnD4JDyHLyWUZ7V0CHXdN 1eCw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=UxEN48NT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id gs14si4389159ejb.615.2020.08.06.20.15.32; Thu, 06 Aug 2020 20:15:55 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=UxEN48NT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726635AbgHGDOj (ORCPT + 99 others); Thu, 6 Aug 2020 23:14:39 -0400 Received: from hqnvemgate26.nvidia.com ([216.228.121.65]:9244 "EHLO hqnvemgate26.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726038AbgHGDOi (ORCPT ); Thu, 6 Aug 2020 23:14:38 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate26.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Thu, 06 Aug 2020 20:14:24 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Thu, 06 Aug 2020 20:14:38 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Thu, 06 Aug 2020 20:14:38 -0700 Received: from [10.2.172.190] (10.124.1.5) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Fri, 7 Aug 2020 03:14:37 +0000 Subject: Re: [PATCH v9 08/10] gpu: host1x: mipi: Keep MIPI clock enabled and mutex locked till calibration done From: Sowjanya Komatineni To: Dmitry Osipenko , , , , , , , CC: , , , , References: <1596740494-19306-1-git-send-email-skomatineni@nvidia.com> <1596740494-19306-9-git-send-email-skomatineni@nvidia.com> <7ef2a6dd-d220-ff47-e6ef-7443a1779fae@nvidia.com> Message-ID: Date: Thu, 6 Aug 2020 20:14:41 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <7ef2a6dd-d220-ff47-e6ef-7443a1779fae@nvidia.com> X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL101.nvidia.com (172.20.187.10) To HQMAIL107.nvidia.com (172.20.187.13) Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: quoted-printable Content-Language: en-US DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1596770064; bh=6pJfOCjVj6hQbgZO0kcGHqWsN/R/wFr41mMvdHVndAA=; h=X-PGP-Universal:Subject:From:To:CC:References:Message-ID:Date: User-Agent:MIME-Version:In-Reply-To:X-Originating-IP: X-ClientProxiedBy:Content-Type:Content-Transfer-Encoding: Content-Language; b=UxEN48NThZ9Kv7QdDMbEimEYnq0rpfrlv1fJaMTY7zuzxKBvUlcMYErw3LyFyeRsz SgTbaayJWuK5Hj152SU/trClM7pSFOwN4QhVEoVK9tGTCLk2a+P3Tl9GpUlVnTAfxH XOgimo8/FrnsPHjmNtQWQG7A0ZH21wwyu7jBE6HkYTiZcf8sjtkfFoY6PkgS8qxlTD HM/KgRg1RIrEjwSQN6RiKQwgsnGbmKYoAhwwxZWpXfsD6xDmCTLTwlYc67eCOB57+E l2JF7b9MWiX6jkXRQGq/GB/G1irKC3wo2Y9wzaVAIH1xnLWw6EWy1x7cmEw4BbSgR+ RvNERFzfUgAZg== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 8/6/20 8:10 PM, Sowjanya Komatineni wrote: > > On 8/6/20 7:31 PM, Dmitry Osipenko wrote: >> 06.08.2020 22:01, Sowjanya Komatineni =D0=BF=D0=B8=D1=88=D0=B5=D1=82: >> ... >>> +int tegra_mipi_start_calibration(struct tegra_mipi_device *device) >>> =C2=A0 { >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 const struct tegra_mipi_soc *soc =3D dev= ice->mipi->soc; >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 unsigned int i; >>> @@ -381,12 +375,16 @@ int tegra_mipi_calibrate(struct=20 >>> tegra_mipi_device *device) >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 value |=3D MIPI_CAL_CTRL_START; >>> =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 tegra_mipi_writel(device->mipi, value, M= IPI_CAL_CTRL); >>> =C2=A0 -=C2=A0=C2=A0=C2=A0 mutex_unlock(&device->mipi->lock); >>> -=C2=A0=C2=A0=C2=A0 clk_disable(device->mipi->clk); >>> +=C2=A0=C2=A0=C2=A0 /* >>> +=C2=A0=C2=A0=C2=A0=C2=A0 * Wait for min 72uS to let calibration logic = finish calibration >>> +=C2=A0=C2=A0=C2=A0=C2=A0 * sequence codes before waiting for pads idle= state to apply the >>> +=C2=A0=C2=A0=C2=A0=C2=A0 * results. >>> +=C2=A0=C2=A0=C2=A0=C2=A0 */ >>> +=C2=A0=C2=A0=C2=A0 usleep_range(75, 80); >> Could you please explain why the ACTIVE bit can't be polled instead of >> using the fixed delay? Doesn't ACTIVE bit represents the state of the >> busy FSM? > > Based on internal discussion, ACTIVE bit gets cleared when all enabled=20 > pads calibration is done (same time as when DONE set to 1). > > Will request HW designer to look into design and confirm=C2=A0 exactly wh= en=20 > ACTIVE bit gets cleared. > > Will get back on this. > Verified with HW designer. above is correct. ACTIVE bit update happens=20 same time as DONE bit. Active =3D !(DONE) In case of calibration logic waiting for LP-11 where done bit does not=20 get set, ACTIVE will still be 1 and on next start trigger new=20 calibration will start > >