Received: by 2002:a05:6a10:d5a5:0:0:0:0 with SMTP id gn37csp732462pxb; Wed, 6 Oct 2021 14:16:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwXbKoWtMe4CDjrYxOOl8S8EOA/YdA4ZsE0mYolvSM0aDe0r1CEHKAJdVIcztJsBindHT68 X-Received: by 2002:a50:fc86:: with SMTP id f6mr685764edq.283.1633555001309; Wed, 06 Oct 2021 14:16:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633555001; cv=none; d=google.com; s=arc-20160816; b=UvXZKydheJz3K4FYNIY75M74QWvjfROVm33T4gk+7mBJiIiRE4AD6sj1g9hrp9yXfm k4SB/boBkedunND8kAy9DFJ1H1us4mohNOIml1kV7BPmSVry849CCQFNET4/Dv46wLZU dKAbmO9mW8/q8MZehTyBIZTCKyHoXFBEiGy18eIiXEeFsq2nXcjUHoaxosUbjJXWzT3h RGa6R78Z/cZ31Xod/Y632KHCVbXYlDlFJEWS6NRAgXyApk9tDeui3XnyqYe/ZwDGd8X0 jjzEa08BnIF447NLsFvESnKkz8miOmfML4MR9fwevzvVXuOHrJxxgNIjY11ExvXvUoCk 2rZg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=o0cs0AX5nwq+IUf+CKObBfgaJgmuJRgoStffvFAIT10=; b=naH0NX6d6f8ad9qmMp2mFcWHGTYSK2NPs4l+Qx1mYuDfFP37pC/n3lT2sOpORGk+kD qnpgkfsXVFyd2cKeey0bGlHpzfJ/h24WrT68YULLgznHofjbjOJ2kARoZ/X6YvjcuKmM fu/J/t5figxkeq9VlK0miaAKy8wykRbOhPlarsN+9r+0nz/kfz4FyVm9goIcoVH4qkm0 Zib3jChRzLXXTqirVmxUQOd4/jeLpt1uZBGCVyh3Da070wVG5VM0vPAmnY6AyOzmAa/q +aLBJluF7lfSllmtvpxFicHlUtHMK1ZBqhvVIxca6mr1vg356hh5XBEq21xnIFpJBQZU gyOg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=OAAHbT16; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y11si30211609edj.69.2021.10.06.14.16.17; Wed, 06 Oct 2021 14:16:41 -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=@gmail.com header.s=20210112 header.b=OAAHbT16; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239618AbhJFVQ0 (ORCPT + 99 others); Wed, 6 Oct 2021 17:16:26 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47888 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239591AbhJFVQZ (ORCPT ); Wed, 6 Oct 2021 17:16:25 -0400 Received: from mail-lf1-x131.google.com (mail-lf1-x131.google.com [IPv6:2a00:1450:4864:20::131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1A20BC061746; Wed, 6 Oct 2021 14:14:33 -0700 (PDT) Received: by mail-lf1-x131.google.com with SMTP id r19so14857340lfe.10; Wed, 06 Oct 2021 14:14:33 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=o0cs0AX5nwq+IUf+CKObBfgaJgmuJRgoStffvFAIT10=; b=OAAHbT16tXECghgQaYpBDvaBg2nyBCHmtuMyvDSLSTbuObskqWOWorhnE8GXhvyO1P Bn8A+jUBY+Hq5L0nIx22XuRHtWkBK8UW1aLeRHBCefSUfXdhaYPQAKLssy6jZKCTDPxq OuYscwLfHiEBxKSN7pEAEtHJlzcaimxesa44SVQW0YCpj0qYJNneKlMBzctNoocz4ITJ VLxjAWxLdAX08DniG2ajG9YPUowE5Inf0Vtvp7bs6ZdboMQY6blXurlo0smoYncTZQ5t rw5V35NzcSMJgcQCw0DJs/tH0fAF9zeUo7FIdEgb52Z5b5ZJr0WNe8OnId+CPYq6ATlB 3Q5Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=o0cs0AX5nwq+IUf+CKObBfgaJgmuJRgoStffvFAIT10=; b=dHKgwl05ahWi5cU9Hiyl4YYu0neWI9FXFRCKzhBcVeC9fpThuIrBw3SPwKNI8YCBVA 5QhIczpMas1JvybyfTI8eWMvo9ZLN3ZCUmAjKMZ1u8TKMwU/x+zMWBLfwZam4m4LKn1T 1WVjninNjaI6DH9md/EMlItLR0L7LkRsE5Mu1GQk8EBRCFLa+hS++354PxCR97YtJVIs PRUVGWX2d066aKL1AqrGhvQTnAQ4DzW7DElmb8dZNY5yrcnlG6MrcPnZlROGs4v0jAPD XrOhNnukeq0CR0BDM/L/tRUijvMy89v+UpKBcV8aZQrwr8i7xBOXZa8XbG+74hrtHKT3 zUqg== X-Gm-Message-State: AOAM531NxcdUtxp3DzpJ+oZqoFD1mFyFP+7tzseG/avl+qCQSxYfiL2I 2/Sfj7qNzDwQsxf15/BCZZU= X-Received: by 2002:a05:6512:3c95:: with SMTP id h21mr371551lfv.128.1633554871471; Wed, 06 Oct 2021 14:14:31 -0700 (PDT) Received: from [192.168.2.145] (79-139-163-57.dynamic.spd-mgts.ru. [79.139.163.57]) by smtp.googlemail.com with ESMTPSA id t18sm2356186lfl.219.2021.10.06.14.14.30 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 06 Oct 2021 14:14:31 -0700 (PDT) Subject: Re: [PATCH v13 06/35] clk: tegra: Support runtime PM and power domain To: Ulf Hansson Cc: Thierry Reding , Jonathan Hunter , Viresh Kumar , Stephen Boyd , Peter De Schrijver , Mikko Perttunen , Peter Chen , Lee Jones , =?UTF-8?Q?Uwe_Kleine-K=c3=b6nig?= , Nishanth Menon , Adrian Hunter , Michael Turquette , Linux Kernel Mailing List , linux-tegra , Linux PM , Linux USB List , linux-staging@lists.linux.dev, linux-pwm@vger.kernel.org, linux-mmc , dri-devel , DTML , linux-clk , Mark Brown , Vignesh Raghavendra , Richard Weinberger , Miquel Raynal , Lucas Stach , Stefan Agner , Mauro Carvalho Chehab , David Heidelberg References: <20210926224058.1252-1-digetx@gmail.com> <20210926224058.1252-7-digetx@gmail.com> <24101cd6-d3f5-1e74-db39-145ecd30418b@gmail.com> <4bdba8a2-4b9b-ed7d-e6ca-9218d8200a85@gmail.com> <74a47158-e2e4-5fd0-3f37-0b50d4ead4d9@gmail.com> From: Dmitry Osipenko Message-ID: Date: Thu, 7 Oct 2021 00:14:29 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 06.10.2021 15:43, Ulf Hansson пишет: > On Wed, 6 Oct 2021 at 00:43, Dmitry Osipenko wrote: >> >> 06.10.2021 01:19, Dmitry Osipenko пишет: >> ... >>> I reproduced the OFF problem by removing the clk prepare/unprepare from >>> the suspend/resume of the clk driver and making some extra changes to >>> clock tree topology and etc to trigger the problem on Nexus 7. >>> >>> tegra-pmc 7000e400.pmc: failed to turn off PM domain heg: -13 >>> >>> It happens from genpd_suspend_noirq() -> tegra_genpd_power_off() -> clk >>> -> GENPD -> I2C -> runtime-pm. >>> >>> -13 is EACCES, it comes from the runtime PM of I2C device. RPM is >>> prohibited/disabled during late (NOIRQ) suspend by the drivers core. >> >> My bad, I double-checked and it's not I2C RPM that is failing now, but >> the clock's RPM [1], which is also unavailable during NOIRQ. > > Yes, that sounds reasonable. > > You would then need a similar patch for the tegra clock driver as I > suggested for tegra I2C driver. That should solve the problem, I > think. > >> >> [1] >> https://elixir.free-electrons.com/linux/v5.15-rc4/source/drivers/clk/clk.c#L116 >> >> Previously it was I2C RPM that was failing in a similar way, but code >> changed a tad since that time. > > Alright. In any case, as long as the devices gets suspended in the > correct order, I think it should be fine to cook a patch along the > lines of what I suggest for the I2C driver as well. > > It should work, I think. Although, maybe you want to avoid runtime > resuming the I2C device, unless it's the device belonging to the PMIC > interface, if there is a way to distinguish that for the driver. Ulf, thank you very much for the suggestions! I was thinking about this all once again and concluded that the simplest variant will be to just remove the suspend ops from the clk driver since neither of PLLs require high voltage. We now have voltage bumped to a nominal level during suspend by Tegra's regulator-coupler driver and it's much higher than voltage needed by PLLs. So the problem I was trying to work around doesn't really exist anymore.