Received: by 2002:a05:6358:5282:b0:b5:90e7:25cb with SMTP id g2csp2919929rwa; Mon, 22 Aug 2022 16:59:24 -0700 (PDT) X-Google-Smtp-Source: AA6agR4DGqimlOLLqZWGyIhZzrAf5g7Sfxbch6Vgz9YOSusrJFoAdYtnBuKs21ua/ziuXRuo5Fl0 X-Received: by 2002:a65:6cc7:0:b0:42a:4d40:8dc1 with SMTP id g7-20020a656cc7000000b0042a4d408dc1mr13838139pgw.321.1661212763981; Mon, 22 Aug 2022 16:59:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1661212763; cv=none; d=google.com; s=arc-20160816; b=1LwNku9WkPc6usYUwZJiCaJmZ6gvyY+jfycs/lXfkZLZLXv8oA4zTXsWbAhVbBTXkQ D+EHoboQSjNbWRY/djJLGlcd+ReRYInX6e/g7wtfOFiX4rryAIJ7OfeWTidOgtC0ytdi W+YKZd87MH0kKU5yFl89jwK+X7C5ROSzdGfLQDwzG4Mhiu09dTjN2yhhTgMTDDQbk89E MpfIFzM4g/EqZmtiQ2IKE/eEbzmiMuQIpaPeH5WKfEhYnJr3vCTRdnfycjL58NllCflZ vUBJhGnaCmvHsrPdiMWHBqjJXfFjU0RQq6oQXp/O/ycxkOVK0/l02LeNII4jMH+oSs0w RZRw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=5mJdcZmCyt5CJjgTNsjJupljRT41bwkyF+7a5RDVkf4=; b=ZGX0ZZZxOygqKgtIhS2FdTM85taLKip3PHwMMRmtUfqcqJ8UN0zofViGNaQYaVaaxm jA8VVy7uM3mlp8WNph9P/13hk8yQTP54xtOfMnMJX+r36GtDHcrkA4rgE//f5zotKlwt 1txwHQShfvZUDpGJAm9f4Vt3hJnfes9P4beSAQhYJRH1/LWyhCR6aofu3teX4K82CqhP z48MvyKOk3CInUYUQjBA7gSb4NDtKEQRqvVzl3tXf8t4AFLVsKYnIup9JUgPAt3PhON+ XhyMuF1sDU1QyQtJfdPq3fNNYW3Tc3JOCybU5J9YPM2MygE+D3J4l53Uz7WSau1VAXyg q4/A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=sntech.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id u5-20020a637905000000b004299cef0a3esi14087442pgc.375.2022.08.22.16.59.13; Mon, 22 Aug 2022 16:59:23 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=sntech.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238693AbiHVXoF (ORCPT + 99 others); Mon, 22 Aug 2022 19:44:05 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47944 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235448AbiHVXoD (ORCPT ); Mon, 22 Aug 2022 19:44:03 -0400 Received: from gloria.sntech.de (gloria.sntech.de [185.11.138.130]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 95249E012; Mon, 22 Aug 2022 16:44:00 -0700 (PDT) Received: from ip5b412258.dynamic.kabel-deutschland.de ([91.65.34.88] helo=diego.localnet) by gloria.sntech.de with esmtpsa (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.94.2) (envelope-from ) id 1oQH5A-00013b-GV; Tue, 23 Aug 2022 01:43:48 +0200 From: Heiko =?ISO-8859-1?Q?St=FCbner?= To: Quentin Schulz , Ulf Hansson , "Rafael J. Wysocki" , Linus Walleij Cc: linux-gpio@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org, Quentin Schulz Subject: Re: [RFC PATCH 0/1] Making Rockchip IO domains dependency from other devices explicit Date: Tue, 23 Aug 2022 01:43:46 +0200 Message-ID: <2696616.PYKUYFuaPT@diego> In-Reply-To: References: <20220802095252.2486591-1-foss+kernel@0leil.net> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_PASS, T_SCC_BODY_TEXT_LINE,T_SPF_HELO_TEMPERROR autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Linus, Am Montag, 22. August 2022, 10:38:11 CEST schrieb Linus Walleij: > On Tue, Aug 2, 2022 at 11:53 AM Quentin Schulz wrote: > > > Some background on IO domains on Rockchip: > > > > On some Rockchip SoCs, some SoC pins are split in what are called IO > > domains. > > > > An IO domain is supplied power externally, by regulators from a PMIC for > > example. This external power supply is then used by the IO domain as > > "supply" for the IO pins if they are outputs. > > > > Each IO domain can configure which voltage the IO pins will be operating > > on (1.8V or 3.3V). > > > > There already exists an IO domain driver for Rockchip SoCs[1]. This > > driver allows to explicit the relationship between the external power > > supplies and IO domains[2]. This makes sure the regulators are enabled > > by the Linux kernel so the IO domains are supplied with power and > > correctly configured as per the supplied voltage. > > This driver is a regulator consumer and does not offer any other > > interface for device dependency. > > What makes me confused about the patch is the relationship, if any, > between this "IO domain" and generic power domains (genpd) that has > been worked on for ~10 years. > > I am worried that we are reinventing the world. In a nutshell, the Rockchip io-domains handle the voltages of specific pin-groups. I.e. mostly it is just switching between 1.8V and 3.3V . The voltage itself is always set in a (i2c-)regulator but there is a separate step necessary to tell the soc this information. 3.3 -> 1.8: set regulator to 1.8, tell io-domain "we're at 1.8 now" 1.8 -> 3.3: tell io-domain "3.3", set regulator to 3.3. There is supposedly a soc-health-issue if you set the regulator to 3.3 while the io-domain thinks it's at 1.8 . So the io-domain driver right now, just attaches to the regulator, catches the voltage-change events and sets the io-domain setting accordingly. What Quentin is trying to solve is a probe-dependency issue that can happen when stuff is built into the kernel, the regulator has probed the regulator using driver has probed, but the io.domain driver hasn't, as that also only attached to the regulator as described above. Heiko > While my intuitive feeling is that genpd power domains are only on-chip > and not considering off-chip pins, I am not so sure that it warrants > its own abstraction and want to know whether this can be retrofit into > genpd rather than inventing this? > > Documentation/devicetree/bindings/power/power-domain.yaml > include/linux/pm_domain.h > > Yours, > Linus Walleij >