Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp5342875ybl; Tue, 27 Aug 2019 03:13:05 -0700 (PDT) X-Google-Smtp-Source: APXvYqwG8r50l76syvNWJbHoc4GUVvSpu7qR27DiDZisDWItyhnh3uM1XArFSRe8DeWPkIQTvVow X-Received: by 2002:a17:902:a607:: with SMTP id u7mr23743124plq.43.1566900785373; Tue, 27 Aug 2019 03:13:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566900785; cv=none; d=google.com; s=arc-20160816; b=QNxwoXzvQu0Rc8VrmeKhHtVNpdMoX71OBM9nshBPQhuzkgHfQ64nclQNeGETZtrXps bGGCUimbUgg6dIQLq1za7/upvarYCaBQidUOfuNv6RhNPgJjS5cQJGuQCHKsbjRT/qX6 kiHrUfTluQYYnN5cAIj6EhHC45t7AMhFpnMw7SASmVG0j8eZ3QrgBNelAEE/IWzJr1XO f7PgjJU1ShVLIiJHf8Jo/AjsZaXD9kHjaDYguJhu/855NtGPoaKa7V/z9daC1iDRcUCc jREOqwD6iYsV+06CONT3HJ308aSLZZzaTeiFWIiCXuACMY7vCs2CG0ykep2VUZiilcZo 0XSg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:organization:autocrypt:openpgp:from:references:cc:to :subject:dkim-signature; bh=tkna0aUhgXF1vo9IZYq7Jw+bvzmL4pUu5WAhq5klAu0=; b=x4a6Fk2BXP4Gm4x33pUKd1GubknUXnpIVXj+TkOR78LGFQfa3SoMbzm1qfMpjf7JDF vpVaFnIiYcaQAptms1jco6lf85VEerSsBAT7Lh7LsmI17mw4IkYXl0YgpzZfvJXqNXOY bZyGmtb4Iy/YsE3PXIs40UyYBMK1uBRbUnG0Q1dBlPJNvMhXQegoYk/jpQbFjpNUACHy CEtOFo3dOedL9HR005kDBcdCioq+DNP17dd50Od+ddXjwI50p65i0aATGo0/B2dPW9fs Bng8gdBw4GXQ0TfHLs12saHoCDMaJsIQqd6uPkkS+OET0c7fHR0yNqDVlcIOZ5C8qXZm THlQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b="iy6c/gCG"; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b16si11401655pgh.296.2019.08.27.03.12.49; Tue, 27 Aug 2019 03:13:05 -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=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b="iy6c/gCG"; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729419AbfH0KL2 (ORCPT + 99 others); Tue, 27 Aug 2019 06:11:28 -0400 Received: from mail-wr1-f68.google.com ([209.85.221.68]:37235 "EHLO mail-wr1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727048AbfH0KL1 (ORCPT ); Tue, 27 Aug 2019 06:11:27 -0400 Received: by mail-wr1-f68.google.com with SMTP id z11so18201550wrt.4 for ; Tue, 27 Aug 2019 03:11:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=subject:to:cc:references:from:openpgp:autocrypt:organization :message-id:date:user-agent:mime-version:in-reply-to :content-language:content-transfer-encoding; bh=tkna0aUhgXF1vo9IZYq7Jw+bvzmL4pUu5WAhq5klAu0=; b=iy6c/gCGD3tlntcjbXE8i8cDx2WqH1+FISQOdrBZGhElQxxj6aefO+zvKk+WsyTk5z oFrWdHy43zTwG2w08QYuPYWq78YVXkMaFxq0G119k+2WcKU56VTBa4BHMTRsEhV/pGFM vJqAkTWJpx4lmRqqm8l6pihTGS7OkoEly4EWuYFWyLOMFibtv8OZFhuODUypCB/zaFj/ R7Wj5QnTAtcINBjYhxA4KVInc4mJibs+V3DQlpSSjW8khUfJSmPNFT7DtFWlmNQZpgAh zcY4CDwHTcEJTrYL6YIPincVhogOaSGYE1/mUZJIneV1Hjxgh+D8mF5l9+iVPcSYBpe5 ZrnA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:openpgp:autocrypt :organization:message-id:date:user-agent:mime-version:in-reply-to :content-language:content-transfer-encoding; bh=tkna0aUhgXF1vo9IZYq7Jw+bvzmL4pUu5WAhq5klAu0=; b=jXVuOjIaOUtHjPFnSX63rgd32n8DGcEJYPpGGuqrWU3kT/pQkd/yuFPBYQBN5VnVX3 U9fS/kio91t+ShGA1iq1WEsHo2A/NsXuaiKTyEuinJuW8uKIGo/p6APQHlVM/dXsAbnw jij2AfmSg7FHyzMvjnSpXq8ngMmW9MRn1dMWQLbbS0Y2ESCY8gXmiBWeEfSP6nno4Cha rQ83FBxYRuSrCM7zMv3x+t/k02eYIGNoW85jU3ORllnwRb+zjv9TOR9IE8KGt4TvNcEw DLRc6U37YU5HlgV1C5kK+j7bjWSsxi9rFa0YzxXoGNrBAzlQDV6S8iJ0/dswTRJIV669 9eLQ== X-Gm-Message-State: APjAAAUrP1RjKO7NCi8cIc2mTfhke/Tkr3mPJASK+Xrudd2TTdArvV68 HXK+ktvwz1bUc0sp1DltP59EfA== X-Received: by 2002:adf:e885:: with SMTP id d5mr3284141wrm.15.1566900683512; Tue, 27 Aug 2019 03:11:23 -0700 (PDT) Received: from [10.1.2.12] (lmontsouris-657-1-212-31.w90-63.abo.wanadoo.fr. [90.63.244.31]) by smtp.gmail.com with ESMTPSA id q3sm2899956wma.48.2019.08.27.03.11.22 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 27 Aug 2019 03:11:22 -0700 (PDT) Subject: Re: [PATCH v2 2/5] soc: amlogic: Add support for Everything-Else power domains controller To: Martin Blumenstingl Cc: khilman@baylibre.com, ulf.hansson@linaro.org, linux-amlogic@lists.infradead.org, linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org References: <20190823090418.17148-1-narmstrong@baylibre.com> <20190823090418.17148-3-narmstrong@baylibre.com> From: Neil Armstrong Openpgp: preference=signencrypt Autocrypt: addr=narmstrong@baylibre.com; prefer-encrypt=mutual; keydata= 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 ZaTUOEkgIor5losDrePdPgE= Organization: Baylibre Message-ID: <25e60f94-9be1-76b0-147f-abdd2d01872f@baylibre.com> Date: Tue, 27 Aug 2019 12:11:22 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 27/08/2019 00:40, Martin Blumenstingl wrote: > Hi Neil, > > On Mon, Aug 26, 2019 at 10:10 AM Neil Armstrong wrote: >> >> On 25/08/2019 23:10, Martin Blumenstingl wrote: >>> Hi Neil, >>> >>> thank you for this update >>> I haven't tried this on the 32-bit SoCs yet, but I am confident that I >>> can make it work by "just" adding the SoC specific bits! >>> >>> On Fri, Aug 23, 2019 at 11:06 AM Neil Armstrong wrote: >>> [...] >>>> +/* AO Offsets */ >>>> + >>>> +#define AO_RTI_GEN_PWR_SLEEP0 (0x3a << 2) >>>> +#define AO_RTI_GEN_PWR_ISO0 (0x3b << 2) >>>> + >>>> +/* HHI Offsets */ >>>> + >>>> +#define HHI_MEM_PD_REG0 (0x40 << 2) >>>> +#define HHI_VPU_MEM_PD_REG0 (0x41 << 2) >>>> +#define HHI_VPU_MEM_PD_REG1 (0x42 << 2) >>>> +#define HHI_VPU_MEM_PD_REG3 (0x43 << 2) >>>> +#define HHI_VPU_MEM_PD_REG4 (0x44 << 2) >>>> +#define HHI_AUDIO_MEM_PD_REG0 (0x45 << 2) >>>> +#define HHI_NANOQ_MEM_PD_REG0 (0x46 << 2) >>>> +#define HHI_NANOQ_MEM_PD_REG1 (0x47 << 2) >>>> +#define HHI_VPU_MEM_PD_REG2 (0x4d << 2) >>> should we switch to the actual register offsets like we did in the >>> clock drivers? >> >> I find it simpler to refer to the numbers in the documentation... > OK, I have no strong preference here > for the 32-bit SoCs I will need to use the offsets based on the > "amlogic,meson8b-pmu", "syscon" [0], so these will be magic anyways > > [...] >>>> +#define VPU_HHI_MEMPD(__reg) \ >>>> + { __reg, BIT(8) }, \ >>>> + { __reg, BIT(9) }, \ >>>> + { __reg, BIT(10) }, \ >>>> + { __reg, BIT(11) }, \ >>>> + { __reg, BIT(12) }, \ >>>> + { __reg, BIT(13) }, \ >>>> + { __reg, BIT(14) }, \ >>>> + { __reg, BIT(15) } >>> the Amlogic implementation from buildroot-openlinux-A113-201901 (the >>> latest one I have) >>> kernel/aml-4.9/drivers/amlogic/media/vout/hdmitx/hdmi_tx_20/hw/hdmi_tx_hw.c >>> uses: >>> hd_set_reg_bits(P_HHI_MEM_PD_REG0, 0, 8, 8) >>> that basically translates to: GENMASK(15, 8) (which means we could >>> drop this macro) >>> >>> the datasheet also states: 15~8 [...] HDMI memory PD (as a single >>> 8-bit wide register) >> >> Yep, but the actual code setting the VPU power domain is in u-boot : >> >> drivers/vpu/aml_vpu_power_init.c: >> 108 for (i = 8; i < 16; i++) { >> 109 vpu_hiu_setb(HHI_MEM_PD_REG0, 0, i, 1); >> 110 udelay(5); >> 111 } >> >> the linux code is like never used here, my preference goes to the u-boot code >> implementation. > I see, let's keep your implementation then > >>> >>> [...] >>>> +static struct meson_ee_pwrc_domain_desc g12a_pwrc_domains[] = { >>>> + [PWRC_G12A_VPU_ID] = VPU_PD("VPU", &g12a_pwrc_vpu, g12a_pwrc_mem_vpu, >>>> + pwrc_ee_get_power, 11, 2), >>>> + [PWRC_G12A_ETH_ID] = MEM_PD("ETH", g12a_pwrc_mem_eth), >>>> +}; >>>> + >>>> +static struct meson_ee_pwrc_domain_desc sm1_pwrc_domains[] = { >>>> + [PWRC_SM1_VPU_ID] = VPU_PD("VPU", &sm1_pwrc_vpu, sm1_pwrc_mem_vpu, >>>> + pwrc_ee_get_power, 11, 2), >>>> + [PWRC_SM1_NNA_ID] = TOP_PD("NNA", &sm1_pwrc_nna, sm1_pwrc_mem_nna, >>>> + pwrc_ee_get_power), >>>> + [PWRC_SM1_USB_ID] = TOP_PD("USB", &sm1_pwrc_usb, sm1_pwrc_mem_usb, >>>> + pwrc_ee_get_power), >>>> + [PWRC_SM1_PCIE_ID] = TOP_PD("PCI", &sm1_pwrc_pci, sm1_pwrc_mem_pcie, >>>> + pwrc_ee_get_power), >>>> + [PWRC_SM1_GE2D_ID] = TOP_PD("GE2D", &sm1_pwrc_ge2d, sm1_pwrc_mem_ge2d, >>>> + pwrc_ee_get_power), >>>> + [PWRC_SM1_AUDIO_ID] = MEM_PD("AUDIO", sm1_pwrc_mem_audio), >>>> + [PWRC_SM1_ETH_ID] = MEM_PD("ETH", g12a_pwrc_mem_eth), >>>> +}; >>> my impression: I find this hard to read as it merges the TOP and >>> Memory PD domains from above, adding some seemingly random "11, 2" for >>> the VPU PD as well as pwrc_ee_get_power for some of the power domains >>> personally I like the way we describe clk_regmap because it's easy to >>> read (even though it adds a bit of boilerplate). I'm not sure if we >>> can make it work here, but this (not compile tested) is what I have in >>> mind (I chose two random power domains): >>> [PWRC_SM1_VPU_ID] = { >>> .name = "VPU", >>> .top_pd = SM1_EE_PD(8), >>> .mem_pds = { >>> VPU_MEMPD(HHI_VPU_MEM_PD_REG0), >>> VPU_MEMPD(HHI_VPU_MEM_PD_REG1), >>> VPU_MEMPD(HHI_VPU_MEM_PD_REG2), >>> VPU_MEMPD(HHI_VPU_MEM_PD_REG3), >>> { HHI_VPU_MEM_PD_REG4, GENMASK(1, 0) }, >>> { HHI_VPU_MEM_PD_REG4, GENMASK(3, 2) }, >>> { HHI_VPU_MEM_PD_REG4, GENMASK(5, 4) }, >>> { HHI_VPU_MEM_PD_REG4, GENMASK(7, 6) }, >>> { HHI_MEM_PD_REG0, GENMASK(15, 8) }, >>> }, >>> .num_mem_pds = 9, >>> .reset_names_count = 11, >>> .clk_names_count = 2, >>> }, >>> [PWRC_SM1_ETH_ID] = { >>> .name = "ETH", >>> .mem_pds = { HHI_MEM_PD_REG0, GENMASK(3, 2) }, >>> .num_mem_pds = 1, >>> }, >>> ... >>> >>> I'd like to get Kevin's feedback on this >>> what you have right now is probably good enough for the initial >>> version of this driver. I'm bringing this discussion up because we >>> will add support for more SoCs to this driver (we migrate GX over to >>> it and I want to add 32-bit SoC support, which probably means at least >>> Meson8 - assuming they kept the power domains identical between >>> Meson8/8b/8m2). >> >> I find it more compact, but nothing is set in stone, you can refactor this as >> will when adding meson8 support, no problems here. > OK. if Kevin (or someone else) has feedback on this then I don't have > to waste time if it turns out that it's not a great idea ;) > >>> >>> [...] >>>> +struct meson_ee_pwrc_domain { >>>> + struct generic_pm_domain base; >>>> + bool enabled; >>>> + struct meson_ee_pwrc *pwrc; >>>> + struct meson_ee_pwrc_domain_desc desc; >>>> + struct clk_bulk_data *clks; >>>> + int num_clks; >>>> + struct reset_control *rstc; >>>> + int num_rstc; >>>> +}; >>>> + >>>> +struct meson_ee_pwrc { >>>> + struct regmap *regmap_ao; >>>> + struct regmap *regmap_hhi; >>>> + struct meson_ee_pwrc_domain *domains; >>>> + struct genpd_onecell_data xlate; >>>> +}; >>> (my impressions on this: I was surprised to find more structs down >>> here, I expected them to be together with the other structs further >>> up) >> >> These are the "live" structures, opposed to the static structures defining the >> data and these are allocated and filled a probe time. > I see, thanks for the explanation > >> I dislike changing static global data at runtime, this is why I clearly separated both. > I didn't mean to make them static - the thing that caught my eye was > that some of the structs are defined at the top of the driver while > these two are define much further down > I am used to having all struct definitions in one place I'll let Kevin leave his feedback on this aswell. > >>> >>>> +static bool pwrc_ee_get_power(struct meson_ee_pwrc_domain *pwrc_domain) >>>> +{ >>>> + u32 reg; >>>> + >>>> + regmap_read(pwrc_domain->pwrc->regmap_ao, >>>> + pwrc_domain->desc.top_pd->sleep_reg, ®); >>>> + >>>> + return (reg & pwrc_domain->desc.top_pd->sleep_mask); >>> should this also check for top_pd->iso_* as well as mem_pd->*? >>> if the top_pd part was optional we could even use the get_power >>> callback for *all* power domains in this driver (right now audio and >>> Ethernet don't have any get_power callback) >> >> We could, but how should we handle if one unexpected bit is set ? No idea... > hmm, I see > if we need it for other power domains then we can still implement it, > so it's good for now > > [...] >>> bonus question: what about the video decoder power domains? >>> here is an example from vdec_1_start >>> (drivers/staging/media/meson/vdec/vdec_1.c): >>> /* Enable power for VDEC_1 */ >>> regmap_update_bits(core->regmap_ao, AO_RTI_GEN_PWR_SLEEP0, >>> GEN_PWR_VDEC_1, 0); >>> usleep_range(10, 20); >>> [...] >>> /* enable VDEC Memories */ >>> amvdec_write_dos(core, DOS_MEM_PD_VDEC, 0); >>> /* Remove VDEC1 Isolation */ >>> regmap_write(core->regmap_ao, AO_RTI_GEN_PWR_ISO0, 0); >>> >>> (my point here is that it mixes video decoder "DOS" registers with >>> AO_RTI_GEN_PWR registers) >>> do we also want to add support for these "DOS" power domains to the >>> meson-ee-pwrc driver? >>> what about the AO_RTI_GEN_PWR part then - should we keep management >>> for the video decoder power domain bits in AO_RTI_GEN_PWR as part of >>> the video decoder driver? >> >> I left the decoders power domains aside so we can discuss it later on, >> we should expose multiple power domains, but the driver would need to >> be changed to support multiple power domains. But will loose the ability >> to enable/disable each domain at will unless it created a sub-device for >> each decoder and attaches the domain to to each device and use runtime pm. >> >> It's simpler to discuss it later on ! > OK - does this mean you and/or Maxime have "discuss decoder power > domains" on your (long) TODO-list or do you want me to open this > discussion after this driver is merged? Both I think, let this be an open discussion ! Neil > > > Martin > > > [0] https://www.kernel.org/doc/Documentation/devicetree/bindings/arm/amlogic/pmu.txt >