From: Yassine Oudjana <yassine.oudjana@gmail.com>
To: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
Cc: Dmitry Torokhov <dmitry.torokhov@gmail.com>,
Rob Herring <robh@kernel.org>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Conor Dooley <conor+dt@kernel.org>,
Sen Chu <sen.chu@mediatek.com>,
Sean Wang <sean.wang@mediatek.com>,
Macpaul Lin <macpaul.lin@mediatek.com>,
Lee Jones <lee@kernel.org>,
Matthias Brugger <matthias.bgg@gmail.com>,
Liam Girdwood <lgirdwood@gmail.com>,
Mark Brown <broonie@kernel.org>,
jason-ch chen <Jason-ch.Chen@mediatek.com>,
Chen Zhong <chen.zhong@mediatek.com>,
Flora Fu <flora.fu@mediatek.com>,
Alexandre Mergnat <amergnat@baylibre.com>,
Yassine Oudjana <y.oudjana@protonmail.com>,
linux-input@vger.kernel.org, devicetree@vger.kernel.org,
linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org,
linux-arm-kernel@lists.infradead.org,
linux-mediatek@lists.infradead.org
Subject: Re: [PATCH 3/6] soc: mediatek: pwrap: Add support for MT6735 and MT6328 SoC/PMIC pair
Date: Mon, 21 Oct 2024 17:48:17 +0300 [thread overview]
Message-ID: <HSNPLS.P9M4WFJGIA0V2@gmail.com> (raw)
In-Reply-To: <b24d984f-c944-4faf-bce9-96052abb085b@collabora.com>
On Mon, Oct 21 2024 at 15:25:00 +02:00:00, AngeloGioacchino Del Regno
<angelogioacchino.delregno@collabora.com> wrote:
> Il 18/10/24 10:10, Yassine Oudjana ha scritto:
>> From: Yassine Oudjana <y.oudjana@protonmail.com>
>>
>> Add register definitions and configuration for the MT6735 SoC and the
>> MT6328 PMIC which are commonly paired and communicate through the
>> PMIC
>> wrapper.
>>
>> Note that the PMIC wrapper on MT6735M has a slightly different
>> register
>> map and is therefore NOT compatible with MT6735.
>>
>> Signed-off-by: Yassine Oudjana <y.oudjana@protonmail.com>
>> ---
>> drivers/soc/mediatek/mtk-pmic-wrap.c | 251
>> ++++++++++++++++++++++++++-
>> 1 file changed, 248 insertions(+), 3 deletions(-)
>>
>> diff --git a/drivers/soc/mediatek/mtk-pmic-wrap.c
>> b/drivers/soc/mediatek/mtk-pmic-wrap.c
>> index 9fdc0ef792026..b9e8dd2a5999d 100644
>> --- a/drivers/soc/mediatek/mtk-pmic-wrap.c
>> +++ b/drivers/soc/mediatek/mtk-pmic-wrap.c
>> @@ -3,6 +3,7 @@
>> * Copyright (c) 2014 MediaTek Inc.
>> * Author: Flora Fu, MediaTek
>> */
>> +
>> #include <linux/clk.h>
>> #include <linux/interrupt.h>
>> #include <linux/io.h>
>> @@ -100,7 +101,7 @@ enum dew_regs {
>> PWRAP_DEW_CIPHER_MODE,
>> PWRAP_DEW_CIPHER_SWRST,
>> \x7f- /* MT6323 only regs */
>> + /* MT6323 and MT6328 only regs */
>> PWRAP_DEW_CIPHER_EN,
>> PWRAP_DEW_RDDMY_NO,
>> \x7f@@ -121,8 +122,10 @@ enum dew_regs {
>> PWRAP_RG_SPI_CON13,
>> PWRAP_SPISLV_KEY,
>> \x7f- /* MT6359 only regs */
>> + /* MT6359 and MT6328 only regs */
>> PWRAP_DEW_CRC_SWRST,
>> +
>> + /* MT6359 only regs */
>> PWRAP_DEW_RG_EN_RECORD,
>> PWRAP_DEW_RECORD_CMD0,
>> PWRAP_DEW_RECORD_CMD1,
>> @@ -171,6 +174,23 @@ static const u32 mt6323_regs[] = {
>> [PWRAP_DEW_RDDMY_NO] = 0x01a4,
>> };
>> \x7f+static const u32 mt6328_regs[] = {
>> + [PWRAP_DEW_DIO_EN] = 0x02d4,
>> + [PWRAP_DEW_READ_TEST] = 0x02d6,
>> + [PWRAP_DEW_WRITE_TEST] = 0x02d8,
>> + [PWRAP_DEW_CRC_SWRST] = 0x02da,
>> + [PWRAP_DEW_CRC_EN] = 0x02dc,
>> + [PWRAP_DEW_CRC_VAL] = 0x02de,
>> + [PWRAP_DEW_MON_GRP_SEL] = 0x02e0,
>> + [PWRAP_DEW_CIPHER_KEY_SEL] = 0x02e2,
>> + [PWRAP_DEW_CIPHER_IV_SEL] = 0x02e4,
>> + [PWRAP_DEW_CIPHER_EN] = 0x02e6,
>> + [PWRAP_DEW_CIPHER_RDY] = 0x02e8,
>> + [PWRAP_DEW_CIPHER_MODE] = 0x02ea,
>> + [PWRAP_DEW_CIPHER_SWRST] = 0x02ec,
>> + [PWRAP_DEW_RDDMY_NO] = 0x02ee,
>> +};
>> +
>> static const u32 mt6331_regs[] = {
>> [PWRAP_DEW_DIO_EN] = 0x018c,
>> [PWRAP_DEW_READ_TEST] = 0x018e,
>> @@ -394,7 +414,7 @@ enum pwrap_regs {
>> PWRAP_ADC_RDATA_ADDR1,
>> PWRAP_ADC_RDATA_ADDR2,
>> \x7f- /* MT7622 only regs */
>> + /* MT7622 and MT6735 only regs */
>> PWRAP_STA,
>> PWRAP_CLR,
>> PWRAP_DVFS_ADR8,
>> @@ -417,6 +437,8 @@ enum pwrap_regs {
>> PWRAP_ADC_RDATA_ADDR,
>> PWRAP_GPS_STA,
>> PWRAP_SW_RST,
>> +
>> + /* MT7622 only regs */
>> PWRAP_DVFS_STEP_CTRL0,
>> PWRAP_DVFS_STEP_CTRL1,
>> PWRAP_DVFS_STEP_CTRL2,
>> @@ -481,6 +503,50 @@ enum pwrap_regs {
>> /* MT8516 only regs */
>> PWRAP_OP_TYPE,
>> PWRAP_MSB_FIRST,
>> +
>> + /* MT6735 only regs */
>> + PWRAP_WACS3_EN,
>> + PWRAP_INIT_DONE3,
>> + PWRAP_WACS3_CMD,
>> + PWRAP_WACS3_RDATA,
>> + PWRAP_WACS3_VLDCLR,
>
> Are you sure that you need the PWRAP_MD_ADC_xxxx registers in here?
>
> Since MD is relatively big on its own, I'm not sure how to proceed
> here.. it may
> make sense to split the MD part to a different array, or it may
> not... I do need
> to understand what's going on.
>
> Can you please point me at some reference code to look at, so that I
> can understand
> the situation a bit?
>
> Besides, I'm noticing that the "MD_ADC_RDATA_ADDR_R(x)" are
> sequential registers
> and that's on more than just MT6735: instead of having 32 more
> entries, it might
> make more sense to set only the first and declare the number (or
> size) of regs...
>
> Something like:
>
> enum pwrap_regs {
> .....
> PWRAP_MD_ADC_RDATA_ADDR_LATEST,
> PWRAP_MD_ADC_RDATA_ADDR_WP,
> PWRAP_MD_ADC_RDATA_ADDR_R0,
> PWRAP_MD_ADC_STA0,
> PWRAP_MD_ADC_STA1,
> PWRAP_MD_ADC_STA2
> };
>
> static const struct pmic_wrapper_type pwrap_mt6735 = {
> .regs = mt6735_regs,
> .num_md_addr = 32,
> [other stuff]
> };
>
> ...but again, please, if you can point me at an implementation that
> actually
> uses the R(x) registers, that'd be better ... so that we can choose
> the best
> option to add those in there.
>
> Everything else is great: good job :-)
>
> Cheers,
> Angelo
I just defined all the registers I could find. We aren't using them for
anything yet so it's also fine to keep them out for now.
It seems that in the downstream kernel they are only initialized once
and never accessed again. This is the only place I could find where
they are accessed:
https://gitlab.com/Tooniis/linux-samsung-grandpplte/-/blob/master/drivers/misc/mediatek/pmic_wrap/mt6735/pwrap_hal.c#L1254-1290
next prev parent reply other threads:[~2024-10-21 14:48 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-10-18 8:10 [PATCH 0/6] MediaTek MT6735+MT6328 SoC/PMIC pair base support Yassine Oudjana
2024-10-18 8:10 ` [PATCH 1/6] dt-bindings: mediatek: pwrap: Add MT6735 compatible Yassine Oudjana
2024-10-18 13:38 ` Rob Herring (Arm)
2024-10-21 13:25 ` AngeloGioacchino Del Regno
2024-10-18 8:10 ` [PATCH 2/6] dt-bindings: mfd: mediatek: mt6397: Add bindings for MT6328 Yassine Oudjana
2024-10-18 13:38 ` Rob Herring (Arm)
2024-10-21 13:25 ` AngeloGioacchino Del Regno
2024-10-31 16:19 ` Lee Jones
2024-11-19 13:50 ` Rob Herring
2024-10-18 8:10 ` [PATCH 3/6] soc: mediatek: pwrap: Add support for MT6735 and MT6328 SoC/PMIC pair Yassine Oudjana
2024-10-21 13:25 ` AngeloGioacchino Del Regno
2024-10-21 14:48 ` Yassine Oudjana [this message]
2024-10-22 9:44 ` AngeloGioacchino Del Regno
2024-11-06 11:30 ` Yassine Oudjana
2024-10-18 8:10 ` [PATCH 4/6] mfd: mt6397: Add initial support for MT6328 Yassine Oudjana
2024-10-21 13:24 ` AngeloGioacchino Del Regno
2024-10-21 14:39 ` Yassine Oudjana
2024-10-22 15:20 ` AngeloGioacchino Del Regno
2024-10-31 16:25 ` (subset) " Lee Jones
2024-10-18 8:10 ` [PATCH 5/6] regulator: Add driver for MediaTek MT6328 PMIC regulators Yassine Oudjana
2024-10-21 13:24 ` AngeloGioacchino Del Regno
2024-10-21 14:55 ` Yassine Oudjana
2024-10-22 9:49 ` AngeloGioacchino Del Regno
2024-10-22 16:31 ` Mark Brown
2024-10-18 8:10 ` [PATCH 6/6] Input: mtk-pmic-keys - Add support for MT6328 Yassine Oudjana
2024-10-18 19:09 ` Dmitry Torokhov
2024-10-21 13:24 ` AngeloGioacchino Del Regno
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=HSNPLS.P9M4WFJGIA0V2@gmail.com \
--to=yassine.oudjana@gmail.com \
--cc=Jason-ch.Chen@mediatek.com \
--cc=amergnat@baylibre.com \
--cc=angelogioacchino.delregno@collabora.com \
--cc=broonie@kernel.org \
--cc=chen.zhong@mediatek.com \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=dmitry.torokhov@gmail.com \
--cc=flora.fu@mediatek.com \
--cc=krzk+dt@kernel.org \
--cc=lee@kernel.org \
--cc=lgirdwood@gmail.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-input@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mediatek@lists.infradead.org \
--cc=linux-pm@vger.kernel.org \
--cc=macpaul.lin@mediatek.com \
--cc=matthias.bgg@gmail.com \
--cc=robh@kernel.org \
--cc=sean.wang@mediatek.com \
--cc=sen.chu@mediatek.com \
--cc=y.oudjana@protonmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).