* [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch
@ 2022-01-13 17:07 Lucas Tanure
2022-01-13 17:07 ` [PATCH 2/5] ALSA: hda: cs35l41: Add calls to newly added test key function Lucas Tanure
` (4 more replies)
0 siblings, 5 replies; 14+ messages in thread
From: Lucas Tanure @ 2022-01-13 17:07 UTC (permalink / raw)
To: Rafael J . Wysocki, Len Brown, Hans de Goede, Mark Gross,
Jaroslav Kysela, Takashi Iwai
Cc: alsa-devel, linux-acpi, patches, platform-driver-x86,
linux-kernel, Charles Keepax, Lucas Tanure
From: Charles Keepax <ckeepax@opensource.cirrus.com>
regmap_register_patch can't be used to apply the probe sequence as a
patch is already registers with the regmap by
cs35l41_register_errata_patch and only a single patch can be attached to
a single regmap. The driver doesn't currently rely on a cache sync to
re-apply this probe sequence so simply switch it to a multi write.
Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com>
Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com>
---
sound/pci/hda/cs35l41_hda.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/sound/pci/hda/cs35l41_hda.c b/sound/pci/hda/cs35l41_hda.c
index 30b40d865863..c47c5f0b4e59 100644
--- a/sound/pci/hda/cs35l41_hda.c
+++ b/sound/pci/hda/cs35l41_hda.c
@@ -480,7 +480,7 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i
acpi_hw_cfg = NULL;
if (cs35l41->reg_seq->probe) {
- ret = regmap_register_patch(cs35l41->regmap, cs35l41->reg_seq->probe,
+ ret = regmap_multi_reg_write(cs35l41->regmap, cs35l41->reg_seq->probe,
cs35l41->reg_seq->num_probe);
if (ret) {
dev_err(cs35l41->dev, "Fail to apply probe reg patch: %d\n", ret);
--
2.34.1
^ permalink raw reply related [flat|nested] 14+ messages in thread* [PATCH 2/5] ALSA: hda: cs35l41: Add calls to newly added test key function 2022-01-13 17:07 [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch Lucas Tanure @ 2022-01-13 17:07 ` Lucas Tanure 2022-01-14 16:14 ` Cezary Rojewski 2022-01-13 17:07 ` [PATCH 3/5] ALSA: hda: cs35l41: Move cs35l41* calls to its own symbol namespace Lucas Tanure ` (3 subsequent siblings) 4 siblings, 1 reply; 14+ messages in thread From: Lucas Tanure @ 2022-01-13 17:07 UTC (permalink / raw) To: Rafael J . Wysocki, Len Brown, Hans de Goede, Mark Gross, Jaroslav Kysela, Takashi Iwai Cc: alsa-devel, linux-acpi, patches, platform-driver-x86, linux-kernel, Charles Keepax, Lucas Tanure From: Charles Keepax <ckeepax@opensource.cirrus.com> The test key now needs to be manually held when calling cs35l41_register_errata_patch, after patch: 'commit f517ba4924ad ("ASoC: cs35l41: Add support for hibernate memory retention mode")' Add the missing function calls to this driver. Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com> Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> --- sound/pci/hda/cs35l41_hda.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/sound/pci/hda/cs35l41_hda.c b/sound/pci/hda/cs35l41_hda.c index c47c5f0b4e59..509a380f9be7 100644 --- a/sound/pci/hda/cs35l41_hda.c +++ b/sound/pci/hda/cs35l41_hda.c @@ -463,6 +463,10 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i goto err; } + ret = cs35l41_test_key_unlock(cs35l41->dev, cs35l41->regmap); + if (ret) + goto err; + ret = cs35l41_register_errata_patch(cs35l41->dev, cs35l41->regmap, reg_revid); if (ret) goto err; @@ -473,6 +477,10 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i goto err; } + ret = cs35l41_test_key_lock(cs35l41->dev, cs35l41->regmap); + if (ret) + goto err; + ret = cs35l41_hda_apply_properties(cs35l41, acpi_hw_cfg); if (ret) goto err; -- 2.34.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
* Re: [PATCH 2/5] ALSA: hda: cs35l41: Add calls to newly added test key function 2022-01-13 17:07 ` [PATCH 2/5] ALSA: hda: cs35l41: Add calls to newly added test key function Lucas Tanure @ 2022-01-14 16:14 ` Cezary Rojewski 0 siblings, 0 replies; 14+ messages in thread From: Cezary Rojewski @ 2022-01-14 16:14 UTC (permalink / raw) To: Lucas Tanure, Rafael J . Wysocki, Len Brown, Hans de Goede, Mark Gross, Jaroslav Kysela, Takashi Iwai Cc: alsa-devel, linux-acpi, patches, platform-driver-x86, linux-kernel, Charles Keepax On 2022-01-13 6:07 PM, Lucas Tanure wrote: > From: Charles Keepax <ckeepax@opensource.cirrus.com> > > The test key now needs to be manually held when calling > cs35l41_register_errata_patch, after patch: > > 'commit f517ba4924ad ("ASoC: cs35l41: Add support for > hibernate memory retention mode")' > > Add the missing function calls to this driver. > > Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com> > Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> Judging by the commit's message, this patch is a fix for a previously added commit so appropriate 'Fixes' tag could prove helpful here. > sound/pci/hda/cs35l41_hda.c | 8 ++++++++ > 1 file changed, 8 insertions(+) > > diff --git a/sound/pci/hda/cs35l41_hda.c b/sound/pci/hda/cs35l41_hda.c > index c47c5f0b4e59..509a380f9be7 100644 > --- a/sound/pci/hda/cs35l41_hda.c > +++ b/sound/pci/hda/cs35l41_hda.c > @@ -463,6 +463,10 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i > goto err; > } > > + ret = cs35l41_test_key_unlock(cs35l41->dev, cs35l41->regmap); > + if (ret) > + goto err; > + > ret = cs35l41_register_errata_patch(cs35l41->dev, cs35l41->regmap, reg_revid); > if (ret) > goto err; > @@ -473,6 +477,10 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i > goto err; > } > > + ret = cs35l41_test_key_lock(cs35l41->dev, cs35l41->regmap); > + if (ret) > + goto err; > + > ret = cs35l41_hda_apply_properties(cs35l41, acpi_hw_cfg); > if (ret) > goto err; > ^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH 3/5] ALSA: hda: cs35l41: Move cs35l41* calls to its own symbol namespace 2022-01-13 17:07 [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch Lucas Tanure 2022-01-13 17:07 ` [PATCH 2/5] ALSA: hda: cs35l41: Add calls to newly added test key function Lucas Tanure @ 2022-01-13 17:07 ` Lucas Tanure 2022-01-13 17:07 ` [PATCH 4/5] ALSA: hda: cs35l41: Tidyup code and add default cases Lucas Tanure ` (2 subsequent siblings) 4 siblings, 0 replies; 14+ messages in thread From: Lucas Tanure @ 2022-01-13 17:07 UTC (permalink / raw) To: Rafael J . Wysocki, Len Brown, Hans de Goede, Mark Gross, Jaroslav Kysela, Takashi Iwai Cc: alsa-devel, linux-acpi, patches, platform-driver-x86, linux-kernel, Lucas Tanure Create own namespace and avoid polluting the global namespace Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> --- sound/pci/hda/cs35l41_hda.c | 5 ++--- sound/pci/hda/cs35l41_hda_i2c.c | 1 + sound/pci/hda/cs35l41_hda_spi.c | 1 + 3 files changed, 4 insertions(+), 3 deletions(-) diff --git a/sound/pci/hda/cs35l41_hda.c b/sound/pci/hda/cs35l41_hda.c index 509a380f9be7..c4f25e48dcc0 100644 --- a/sound/pci/hda/cs35l41_hda.c +++ b/sound/pci/hda/cs35l41_hda.c @@ -514,7 +514,7 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i return ret; } -EXPORT_SYMBOL_GPL(cs35l41_hda_probe); +EXPORT_SYMBOL_NS_GPL(cs35l41_hda_probe, SND_HDA_SCODEC_CS35L41); int cs35l41_hda_remove(struct device *dev) { @@ -528,8 +528,7 @@ int cs35l41_hda_remove(struct device *dev) return 0; } -EXPORT_SYMBOL_GPL(cs35l41_hda_remove); - +EXPORT_SYMBOL_NS_GPL(cs35l41_hda_remove, SND_HDA_SCODEC_CS35L41); MODULE_DESCRIPTION("CS35L41 HDA Driver"); MODULE_AUTHOR("Lucas Tanure, Cirrus Logic Inc, <tanureal@opensource.cirrus.com>"); diff --git a/sound/pci/hda/cs35l41_hda_i2c.c b/sound/pci/hda/cs35l41_hda_i2c.c index 4a9462fb5c14..eeb387853ee3 100644 --- a/sound/pci/hda/cs35l41_hda_i2c.c +++ b/sound/pci/hda/cs35l41_hda_i2c.c @@ -62,5 +62,6 @@ static struct i2c_driver cs35l41_i2c_driver = { module_i2c_driver(cs35l41_i2c_driver); MODULE_DESCRIPTION("HDA CS35L41 driver"); +MODULE_IMPORT_NS(SND_HDA_SCODEC_CS35L41); MODULE_AUTHOR("Lucas Tanure <tanureal@opensource.cirrus.com>"); MODULE_LICENSE("GPL"); diff --git a/sound/pci/hda/cs35l41_hda_spi.c b/sound/pci/hda/cs35l41_hda_spi.c index 77426e96c58f..15345a72b9d1 100644 --- a/sound/pci/hda/cs35l41_hda_spi.c +++ b/sound/pci/hda/cs35l41_hda_spi.c @@ -59,5 +59,6 @@ static struct spi_driver cs35l41_spi_driver = { module_spi_driver(cs35l41_spi_driver); MODULE_DESCRIPTION("HDA CS35L41 driver"); +MODULE_IMPORT_NS(SND_HDA_SCODEC_CS35L41); MODULE_AUTHOR("Lucas Tanure <tanureal@opensource.cirrus.com>"); MODULE_LICENSE("GPL"); -- 2.34.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
* [PATCH 4/5] ALSA: hda: cs35l41: Tidyup code and add default cases 2022-01-13 17:07 [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch Lucas Tanure 2022-01-13 17:07 ` [PATCH 2/5] ALSA: hda: cs35l41: Add calls to newly added test key function Lucas Tanure 2022-01-13 17:07 ` [PATCH 3/5] ALSA: hda: cs35l41: Move cs35l41* calls to its own symbol namespace Lucas Tanure @ 2022-01-13 17:07 ` Lucas Tanure 2022-01-14 13:04 ` Lucas tanure 2022-01-14 16:15 ` Takashi Iwai 2022-01-13 17:07 ` [PATCH 5/5] ACPI / scan: Create platform device for CLSA0100 Lucas Tanure 2022-01-14 16:06 ` [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch Cezary Rojewski 4 siblings, 2 replies; 14+ messages in thread From: Lucas Tanure @ 2022-01-13 17:07 UTC (permalink / raw) To: Rafael J . Wysocki, Len Brown, Hans de Goede, Mark Gross, Jaroslav Kysela, Takashi Iwai Cc: alsa-devel, linux-acpi, patches, platform-driver-x86, linux-kernel, Lucas Tanure Clean up the code, plus adding default cases for switch and dev_err_probe use. Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> --- sound/pci/hda/cs35l41_hda.c | 109 ++++++++++++++++---------------- sound/pci/hda/cs35l41_hda.h | 2 +- sound/pci/hda/cs35l41_hda_i2c.c | 1 - sound/pci/hda/cs35l41_hda_spi.c | 1 - 4 files changed, 57 insertions(+), 56 deletions(-) diff --git a/sound/pci/hda/cs35l41_hda.c b/sound/pci/hda/cs35l41_hda.c index c4f25e48dcc0..cb8331587c17 100644 --- a/sound/pci/hda/cs35l41_hda.c +++ b/sound/pci/hda/cs35l41_hda.c @@ -1,6 +1,6 @@ // SPDX-License-Identifier: GPL-2.0 // -// cs35l41.c -- CS35l41 ALSA HDA audio driver +// CS35l41 ALSA HDA audio driver // // Copyright 2021 Cirrus Logic, Inc. // @@ -17,19 +17,19 @@ #include "cs35l41_hda.h" static const struct reg_sequence cs35l41_hda_config[] = { - { CS35L41_PLL_CLK_CTRL, 0x00000430 }, //3200000Hz, BCLK Input, PLL_REFCLK_EN = 1 - { CS35L41_GLOBAL_CLK_CTRL, 0x00000003 }, //GLOBAL_FS = 48 kHz - { CS35L41_SP_ENABLES, 0x00010000 }, //ASP_RX1_EN = 1 - { CS35L41_SP_RATE_CTRL, 0x00000021 }, //ASP_BCLK_FREQ = 3.072 MHz - { CS35L41_SP_FORMAT, 0x20200200 }, //24 bits, I2S, BCLK Slave, FSYNC Slave - { CS35L41_DAC_PCM1_SRC, 0x00000008 }, //DACPCM1_SRC = ASPRX1 - { CS35L41_AMP_DIG_VOL_CTRL, 0x00000000 }, //AMP_VOL_PCM 0.0 dB - { CS35L41_AMP_GAIN_CTRL, 0x00000084 }, //AMP_GAIN_PCM 4.5 dB - { CS35L41_PWR_CTRL2, 0x00000001 }, //AMP_EN = 1 + { CS35L41_PLL_CLK_CTRL, 0x00000430 }, // 3200000Hz, BCLK Input, PLL_REFCLK_EN = 1 + { CS35L41_GLOBAL_CLK_CTRL, 0x00000003 }, // GLOBAL_FS = 48 kHz + { CS35L41_SP_ENABLES, 0x00010000 }, // ASP_RX1_EN = 1 + { CS35L41_SP_RATE_CTRL, 0x00000021 }, // ASP_BCLK_FREQ = 3.072 MHz + { CS35L41_SP_FORMAT, 0x20200200 }, // 24 bits, I2S, BCLK Slave, FSYNC Slave + { CS35L41_DAC_PCM1_SRC, 0x00000008 }, // DACPCM1_SRC = ASPRX1 + { CS35L41_AMP_DIG_VOL_CTRL, 0x00000000 }, // AMP_VOL_PCM 0.0 dB + { CS35L41_AMP_GAIN_CTRL, 0x00000084 }, // AMP_GAIN_PCM 4.5 dB + { CS35L41_PWR_CTRL2, 0x00000001 }, // AMP_EN = 1 }; static const struct reg_sequence cs35l41_hda_start_bst[] = { - { CS35L41_PWR_CTRL2, 0x00000021 }, //BST_EN = 10, AMP_EN = 1 + { CS35L41_PWR_CTRL2, 0x00000021 }, // BST_EN = 10, AMP_EN = 1 { CS35L41_PWR_CTRL1, 0x00000001, 3000}, // set GLOBAL_EN = 1 }; @@ -60,7 +60,7 @@ static const struct reg_sequence cs35l41_stop_ext_vspk[] = { { 0x00000040, 0x00000055 }, { 0x00000040, 0x000000AA }, { 0x00007438, 0x00585941 }, - { 0x00002014, 0x00000000, 3000}, //set GLOBAL_EN = 0 + { 0x00002014, 0x00000000, 3000}, // set GLOBAL_EN = 0 { 0x0000742C, 0x00000009 }, { 0x00007438, 0x00580941 }, { 0x00011008, 0x00000001 }, @@ -78,7 +78,7 @@ static const struct reg_sequence cs35l41_safe_to_active[] = { { 0x0000742C, 0x0000000F }, { 0x0000742C, 0x00000079 }, { 0x00007438, 0x00585941 }, - { CS35L41_PWR_CTRL1, 0x00000001, 2000 }, //GLOBAL_EN = 1 + { CS35L41_PWR_CTRL1, 0x00000001, 2000 }, // GLOBAL_EN = 1 { 0x0000742C, 0x000000F9 }, { 0x00007438, 0x00580941 }, { 0x00000040, 0x000000CC }, @@ -89,8 +89,8 @@ static const struct reg_sequence cs35l41_active_to_safe[] = { { 0x00000040, 0x00000055 }, { 0x00000040, 0x000000AA }, { 0x00007438, 0x00585941 }, - { CS35L41_AMP_DIG_VOL_CTRL, 0x0000A678 }, //AMP_VOL_PCM Mute - { CS35L41_PWR_CTRL2, 0x00000000 }, //AMP_EN = 0 + { CS35L41_AMP_DIG_VOL_CTRL, 0x0000A678 }, // AMP_VOL_PCM Mute + { CS35L41_PWR_CTRL2, 0x00000000 }, // AMP_EN = 0 { CS35L41_PWR_CTRL1, 0x00000000 }, { 0x0000742C, 0x00000009, 2000 }, { 0x00007438, 0x00580941 }, @@ -161,11 +161,13 @@ static void cs35l41_hda_playback_hook(struct device *dev, int action) if (reg_seq->close) ret = regmap_multi_reg_write(reg, reg_seq->close, reg_seq->num_close); break; + default: + ret = -EINVAL; + break; } if (ret) dev_warn(cs35l41->dev, "Failed to apply multi reg write: %d\n", ret); - } static int cs35l41_hda_channel_map(struct device *dev, unsigned int tx_num, unsigned int *tx_slot, @@ -182,20 +184,19 @@ static int cs35l41_hda_bind(struct device *dev, struct device *master, void *mas struct cs35l41_hda *cs35l41 = dev_get_drvdata(dev); struct hda_component *comps = master_data; - if (comps && cs35l41->index >= 0 && cs35l41->index < HDA_MAX_COMPONENTS) - comps = &comps[cs35l41->index]; - else + if (!comps || cs35l41->index < 0 || cs35l41->index >= HDA_MAX_COMPONENTS) return -EINVAL; - if (!comps->dev) { - comps->dev = dev; - strscpy(comps->name, dev_name(dev), sizeof(comps->name)); - comps->playback_hook = cs35l41_hda_playback_hook; - comps->set_channel_map = cs35l41_hda_channel_map; - return 0; - } + comps = &comps[cs35l41->index]; + if (comps->dev) + return -EBUSY; + + comps->dev = dev; + strscpy(comps->name, dev_name(dev), sizeof(comps->name)); + comps->playback_hook = cs35l41_hda_playback_hook; + comps->set_channel_map = cs35l41_hda_channel_map; - return -EBUSY; + return 0; } static void cs35l41_hda_unbind(struct device *dev, struct device *master, void *master_data) @@ -235,6 +236,8 @@ static int cs35l41_hda_apply_properties(struct cs35l41_hda *cs35l41, regmap_update_bits(cs35l41->regmap, CS35L41_GPIO_PAD_CONTROL, CS35L41_GPIO1_CTRL_MASK, 2 << CS35L41_GPIO1_CTRL_SHIFT); break; + default: + return -EINVAL; } switch (hw_cfg->gpio2_func) { @@ -242,6 +245,8 @@ static int cs35l41_hda_apply_properties(struct cs35l41_hda *cs35l41, regmap_update_bits(cs35l41->regmap, CS35L41_GPIO_PAD_CONTROL, CS35L41_GPIO2_CTRL_MASK, 2 << CS35L41_GPIO2_CTRL_SHIFT); break; + default: + return -EINVAL; } if (internal_boost) { @@ -256,11 +261,7 @@ static int cs35l41_hda_apply_properties(struct cs35l41_hda *cs35l41, cs35l41->reg_seq = &cs35l41_hda_reg_seq_ext_bst; } - ret = cs35l41_hda_channel_map(cs35l41->dev, 0, NULL, 1, (unsigned int *)&hw_cfg->spk_pos); - if (ret) - return ret; - - return 0; + return cs35l41_hda_channel_map(cs35l41->dev, 0, NULL, 1, (unsigned int *)&hw_cfg->spk_pos); } static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *cs35l41, @@ -269,7 +270,7 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c struct cs35l41_hda_hw_config *hw_cfg; u32 values[HDA_MAX_COMPONENTS]; struct acpi_device *adev; - struct device *acpi_dev; + struct device *physdev; char *property; size_t nval; int i, ret; @@ -280,11 +281,11 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c return ERR_PTR(-ENODEV); } - acpi_dev = get_device(acpi_get_first_physical_node(adev)); + physdev = get_device(acpi_get_first_physical_node(adev)); acpi_dev_put(adev); property = "cirrus,dev-index"; - ret = device_property_count_u32(acpi_dev, property); + ret = device_property_count_u32(physdev, property); if (ret <= 0) goto no_acpi_dsd; @@ -294,7 +295,7 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c } nval = ret; - ret = device_property_read_u32_array(acpi_dev, property, values, nval); + ret = device_property_read_u32_array(physdev, property, values, nval); if (ret) goto err; @@ -311,7 +312,9 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c goto err; } - /* No devm_ version as CLSA0100, in no_acpi_dsd case, can't use devm version */ + /* To use the same release code for all laptop variants we can't use devm_ version of + * gpiod_get here, as CLSA010* don't have a fully functional bios with an _DSD node + */ cs35l41->reset_gpio = fwnode_gpiod_get_index(&adev->fwnode, "reset", cs35l41->index, GPIOD_OUT_LOW, "cs35l41-reset"); @@ -322,46 +325,46 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c } property = "cirrus,speaker-position"; - ret = device_property_read_u32_array(acpi_dev, property, values, nval); + ret = device_property_read_u32_array(physdev, property, values, nval); if (ret) goto err_free; hw_cfg->spk_pos = values[cs35l41->index]; property = "cirrus,gpio1-func"; - ret = device_property_read_u32_array(acpi_dev, property, values, nval); + ret = device_property_read_u32_array(physdev, property, values, nval); if (ret) goto err_free; hw_cfg->gpio1_func = values[cs35l41->index]; property = "cirrus,gpio2-func"; - ret = device_property_read_u32_array(acpi_dev, property, values, nval); + ret = device_property_read_u32_array(physdev, property, values, nval); if (ret) goto err_free; hw_cfg->gpio2_func = values[cs35l41->index]; property = "cirrus,boost-peak-milliamp"; - ret = device_property_read_u32_array(acpi_dev, property, values, nval); + ret = device_property_read_u32_array(physdev, property, values, nval); if (ret == 0) hw_cfg->bst_ipk = values[cs35l41->index]; property = "cirrus,boost-ind-nanohenry"; - ret = device_property_read_u32_array(acpi_dev, property, values, nval); + ret = device_property_read_u32_array(physdev, property, values, nval); if (ret == 0) hw_cfg->bst_ind = values[cs35l41->index]; property = "cirrus,boost-cap-microfarad"; - ret = device_property_read_u32_array(acpi_dev, property, values, nval); + ret = device_property_read_u32_array(physdev, property, values, nval); if (ret == 0) hw_cfg->bst_cap = values[cs35l41->index]; - put_device(acpi_dev); + put_device(physdev); return hw_cfg; err_free: kfree(hw_cfg); err: - put_device(acpi_dev); + put_device(physdev); dev_err(cs35l41->dev, "Failed property %s: %d\n", property, ret); return ERR_PTR(ret); @@ -370,18 +373,18 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c /* * Device CLSA0100 doesn't have _DSD so a gpiod_get by the label reset won't work. * And devices created by i2c-multi-instantiate don't have their device struct pointing to - * the correct fwnode, so acpi_dev must be used here + * the correct fwnode, so acpi_dev must be used here. * And devm functions expect that the device requesting the resource has the correct - * fwnode + * fwnode. */ if (strncmp(hid, "CLSA0100", 8) != 0) return ERR_PTR(-EINVAL); /* check I2C address to assign the index */ cs35l41->index = id == 0x40 ? 0 : 1; - cs35l41->reset_gpio = gpiod_get_index(acpi_dev, NULL, 0, GPIOD_OUT_HIGH); + cs35l41->reset_gpio = gpiod_get_index(physdev, NULL, 0, GPIOD_OUT_HIGH); cs35l41->vspk_always_on = true; - put_device(acpi_dev); + put_device(physdev); return NULL; } @@ -416,8 +419,7 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i if (ret == -EBUSY) { dev_info(cs35l41->dev, "Reset line busy, assuming shared reset\n"); } else { - if (ret != -EPROBE_DEFER) - dev_err(cs35l41->dev, "Failed to get reset GPIO: %d\n", ret); + dev_err_probe(cs35l41->dev, ret, "Failed to get reset GPIO: %d\n", ret); goto err; } } @@ -437,7 +439,8 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i ret = regmap_read(cs35l41->regmap, CS35L41_IRQ1_STATUS3, &int_sts); if (ret || (int_sts & CS35L41_OTP_BOOT_ERR)) { - dev_err(cs35l41->dev, "OTP Boot error\n"); + dev_err(cs35l41->dev, "OTP Boot status %x error: %d\n", + int_sts & CS35L41_OTP_BOOT_ERR, ret); ret = -EIO; goto err; } @@ -489,7 +492,7 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i if (cs35l41->reg_seq->probe) { ret = regmap_multi_reg_write(cs35l41->regmap, cs35l41->reg_seq->probe, - cs35l41->reg_seq->num_probe); + cs35l41->reg_seq->num_probe); if (ret) { dev_err(cs35l41->dev, "Fail to apply probe reg patch: %d\n", ret); goto err; diff --git a/sound/pci/hda/cs35l41_hda.h b/sound/pci/hda/cs35l41_hda.h index 76c69a8a22f6..640afc98b686 100644 --- a/sound/pci/hda/cs35l41_hda.h +++ b/sound/pci/hda/cs35l41_hda.h @@ -1,6 +1,6 @@ /* SPDX-License-Identifier: GPL-2.0 * - * cs35l41_hda.h -- CS35L41 ALSA HDA audio driver + * CS35L41 ALSA HDA audio driver * * Copyright 2021 Cirrus Logic, Inc. * diff --git a/sound/pci/hda/cs35l41_hda_i2c.c b/sound/pci/hda/cs35l41_hda_i2c.c index eeb387853ee3..c2397dc53e78 100644 --- a/sound/pci/hda/cs35l41_hda_i2c.c +++ b/sound/pci/hda/cs35l41_hda_i2c.c @@ -58,7 +58,6 @@ static struct i2c_driver cs35l41_i2c_driver = { .probe = cs35l41_hda_i2c_probe, .remove = cs35l41_hda_i2c_remove, }; - module_i2c_driver(cs35l41_i2c_driver); MODULE_DESCRIPTION("HDA CS35L41 driver"); diff --git a/sound/pci/hda/cs35l41_hda_spi.c b/sound/pci/hda/cs35l41_hda_spi.c index 15345a72b9d1..36815ab4e461 100644 --- a/sound/pci/hda/cs35l41_hda_spi.c +++ b/sound/pci/hda/cs35l41_hda_spi.c @@ -55,7 +55,6 @@ static struct spi_driver cs35l41_spi_driver = { .probe = cs35l41_hda_spi_probe, .remove = cs35l41_hda_spi_remove, }; - module_spi_driver(cs35l41_spi_driver); MODULE_DESCRIPTION("HDA CS35L41 driver"); -- 2.34.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
* Re: [PATCH 4/5] ALSA: hda: cs35l41: Tidyup code and add default cases 2022-01-13 17:07 ` [PATCH 4/5] ALSA: hda: cs35l41: Tidyup code and add default cases Lucas Tanure @ 2022-01-14 13:04 ` Lucas tanure 2022-01-14 16:15 ` Takashi Iwai 1 sibling, 0 replies; 14+ messages in thread From: Lucas tanure @ 2022-01-14 13:04 UTC (permalink / raw) To: Rafael J . Wysocki, Len Brown, Hans de Goede, Mark Gross, Jaroslav Kysela, Takashi Iwai Cc: alsa-devel, linux-acpi, patches, platform-driver-x86, linux-kernel On 1/13/22 17:07, Lucas Tanure wrote: > Clean up the code, plus adding default cases for switch > and dev_err_probe use. > > Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> > --- > sound/pci/hda/cs35l41_hda.c | 109 ++++++++++++++++---------------- > sound/pci/hda/cs35l41_hda.h | 2 +- > sound/pci/hda/cs35l41_hda_i2c.c | 1 - > sound/pci/hda/cs35l41_hda_spi.c | 1 - > 4 files changed, 57 insertions(+), 56 deletions(-) > > diff --git a/sound/pci/hda/cs35l41_hda.c b/sound/pci/hda/cs35l41_hda.c > index c4f25e48dcc0..cb8331587c17 100644 > --- a/sound/pci/hda/cs35l41_hda.c > +++ b/sound/pci/hda/cs35l41_hda.c > @@ -1,6 +1,6 @@ > // SPDX-License-Identifier: GPL-2.0 > // > -// cs35l41.c -- CS35l41 ALSA HDA audio driver > +// CS35l41 ALSA HDA audio driver > // > // Copyright 2021 Cirrus Logic, Inc. > // > @@ -17,19 +17,19 @@ > #include "cs35l41_hda.h" > > static const struct reg_sequence cs35l41_hda_config[] = { > - { CS35L41_PLL_CLK_CTRL, 0x00000430 }, //3200000Hz, BCLK Input, PLL_REFCLK_EN = 1 > - { CS35L41_GLOBAL_CLK_CTRL, 0x00000003 }, //GLOBAL_FS = 48 kHz > - { CS35L41_SP_ENABLES, 0x00010000 }, //ASP_RX1_EN = 1 > - { CS35L41_SP_RATE_CTRL, 0x00000021 }, //ASP_BCLK_FREQ = 3.072 MHz > - { CS35L41_SP_FORMAT, 0x20200200 }, //24 bits, I2S, BCLK Slave, FSYNC Slave > - { CS35L41_DAC_PCM1_SRC, 0x00000008 }, //DACPCM1_SRC = ASPRX1 > - { CS35L41_AMP_DIG_VOL_CTRL, 0x00000000 }, //AMP_VOL_PCM 0.0 dB > - { CS35L41_AMP_GAIN_CTRL, 0x00000084 }, //AMP_GAIN_PCM 4.5 dB > - { CS35L41_PWR_CTRL2, 0x00000001 }, //AMP_EN = 1 > + { CS35L41_PLL_CLK_CTRL, 0x00000430 }, // 3200000Hz, BCLK Input, PLL_REFCLK_EN = 1 > + { CS35L41_GLOBAL_CLK_CTRL, 0x00000003 }, // GLOBAL_FS = 48 kHz > + { CS35L41_SP_ENABLES, 0x00010000 }, // ASP_RX1_EN = 1 > + { CS35L41_SP_RATE_CTRL, 0x00000021 }, // ASP_BCLK_FREQ = 3.072 MHz > + { CS35L41_SP_FORMAT, 0x20200200 }, // 24 bits, I2S, BCLK Slave, FSYNC Slave > + { CS35L41_DAC_PCM1_SRC, 0x00000008 }, // DACPCM1_SRC = ASPRX1 > + { CS35L41_AMP_DIG_VOL_CTRL, 0x00000000 }, // AMP_VOL_PCM 0.0 dB > + { CS35L41_AMP_GAIN_CTRL, 0x00000084 }, // AMP_GAIN_PCM 4.5 dB > + { CS35L41_PWR_CTRL2, 0x00000001 }, // AMP_EN = 1 > }; > > static const struct reg_sequence cs35l41_hda_start_bst[] = { > - { CS35L41_PWR_CTRL2, 0x00000021 }, //BST_EN = 10, AMP_EN = 1 > + { CS35L41_PWR_CTRL2, 0x00000021 }, // BST_EN = 10, AMP_EN = 1 > { CS35L41_PWR_CTRL1, 0x00000001, 3000}, // set GLOBAL_EN = 1 > }; > > @@ -60,7 +60,7 @@ static const struct reg_sequence cs35l41_stop_ext_vspk[] = { > { 0x00000040, 0x00000055 }, > { 0x00000040, 0x000000AA }, > { 0x00007438, 0x00585941 }, > - { 0x00002014, 0x00000000, 3000}, //set GLOBAL_EN = 0 > + { 0x00002014, 0x00000000, 3000}, // set GLOBAL_EN = 0 > { 0x0000742C, 0x00000009 }, > { 0x00007438, 0x00580941 }, > { 0x00011008, 0x00000001 }, > @@ -78,7 +78,7 @@ static const struct reg_sequence cs35l41_safe_to_active[] = { > { 0x0000742C, 0x0000000F }, > { 0x0000742C, 0x00000079 }, > { 0x00007438, 0x00585941 }, > - { CS35L41_PWR_CTRL1, 0x00000001, 2000 }, //GLOBAL_EN = 1 > + { CS35L41_PWR_CTRL1, 0x00000001, 2000 }, // GLOBAL_EN = 1 > { 0x0000742C, 0x000000F9 }, > { 0x00007438, 0x00580941 }, > { 0x00000040, 0x000000CC }, > @@ -89,8 +89,8 @@ static const struct reg_sequence cs35l41_active_to_safe[] = { > { 0x00000040, 0x00000055 }, > { 0x00000040, 0x000000AA }, > { 0x00007438, 0x00585941 }, > - { CS35L41_AMP_DIG_VOL_CTRL, 0x0000A678 }, //AMP_VOL_PCM Mute > - { CS35L41_PWR_CTRL2, 0x00000000 }, //AMP_EN = 0 > + { CS35L41_AMP_DIG_VOL_CTRL, 0x0000A678 }, // AMP_VOL_PCM Mute > + { CS35L41_PWR_CTRL2, 0x00000000 }, // AMP_EN = 0 > { CS35L41_PWR_CTRL1, 0x00000000 }, > { 0x0000742C, 0x00000009, 2000 }, > { 0x00007438, 0x00580941 }, > @@ -161,11 +161,13 @@ static void cs35l41_hda_playback_hook(struct device *dev, int action) > if (reg_seq->close) > ret = regmap_multi_reg_write(reg, reg_seq->close, reg_seq->num_close); > break; > + default: > + ret = -EINVAL; > + break; > } > > if (ret) > dev_warn(cs35l41->dev, "Failed to apply multi reg write: %d\n", ret); > - > } > > static int cs35l41_hda_channel_map(struct device *dev, unsigned int tx_num, unsigned int *tx_slot, > @@ -182,20 +184,19 @@ static int cs35l41_hda_bind(struct device *dev, struct device *master, void *mas > struct cs35l41_hda *cs35l41 = dev_get_drvdata(dev); > struct hda_component *comps = master_data; > > - if (comps && cs35l41->index >= 0 && cs35l41->index < HDA_MAX_COMPONENTS) > - comps = &comps[cs35l41->index]; > - else > + if (!comps || cs35l41->index < 0 || cs35l41->index >= HDA_MAX_COMPONENTS) > return -EINVAL; > > - if (!comps->dev) { > - comps->dev = dev; > - strscpy(comps->name, dev_name(dev), sizeof(comps->name)); > - comps->playback_hook = cs35l41_hda_playback_hook; > - comps->set_channel_map = cs35l41_hda_channel_map; > - return 0; > - } > + comps = &comps[cs35l41->index]; > + if (comps->dev) > + return -EBUSY; > + > + comps->dev = dev; > + strscpy(comps->name, dev_name(dev), sizeof(comps->name)); > + comps->playback_hook = cs35l41_hda_playback_hook; > + comps->set_channel_map = cs35l41_hda_channel_map; > > - return -EBUSY; > + return 0; > } > > static void cs35l41_hda_unbind(struct device *dev, struct device *master, void *master_data) > @@ -235,6 +236,8 @@ static int cs35l41_hda_apply_properties(struct cs35l41_hda *cs35l41, > regmap_update_bits(cs35l41->regmap, CS35L41_GPIO_PAD_CONTROL, > CS35L41_GPIO1_CTRL_MASK, 2 << CS35L41_GPIO1_CTRL_SHIFT); > break; > + default: > + return -EINVAL; > } > > switch (hw_cfg->gpio2_func) { > @@ -242,6 +245,8 @@ static int cs35l41_hda_apply_properties(struct cs35l41_hda *cs35l41, > regmap_update_bits(cs35l41->regmap, CS35L41_GPIO_PAD_CONTROL, > CS35L41_GPIO2_CTRL_MASK, 2 << CS35L41_GPIO2_CTRL_SHIFT); > break; > + default: > + return -EINVAL; This default option introduces issues some laptops. A new version of this series will be sent. > } > > if (internal_boost) { > @@ -256,11 +261,7 @@ static int cs35l41_hda_apply_properties(struct cs35l41_hda *cs35l41, > cs35l41->reg_seq = &cs35l41_hda_reg_seq_ext_bst; > } > > - ret = cs35l41_hda_channel_map(cs35l41->dev, 0, NULL, 1, (unsigned int *)&hw_cfg->spk_pos); > - if (ret) > - return ret; > - > - return 0; > + return cs35l41_hda_channel_map(cs35l41->dev, 0, NULL, 1, (unsigned int *)&hw_cfg->spk_pos); > } > > static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *cs35l41, > @@ -269,7 +270,7 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c > struct cs35l41_hda_hw_config *hw_cfg; > u32 values[HDA_MAX_COMPONENTS]; > struct acpi_device *adev; > - struct device *acpi_dev; > + struct device *physdev; > char *property; > size_t nval; > int i, ret; > @@ -280,11 +281,11 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c > return ERR_PTR(-ENODEV); > } > > - acpi_dev = get_device(acpi_get_first_physical_node(adev)); > + physdev = get_device(acpi_get_first_physical_node(adev)); > acpi_dev_put(adev); > > property = "cirrus,dev-index"; > - ret = device_property_count_u32(acpi_dev, property); > + ret = device_property_count_u32(physdev, property); > if (ret <= 0) > goto no_acpi_dsd; > > @@ -294,7 +295,7 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c > } > nval = ret; > > - ret = device_property_read_u32_array(acpi_dev, property, values, nval); > + ret = device_property_read_u32_array(physdev, property, values, nval); > if (ret) > goto err; > > @@ -311,7 +312,9 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c > goto err; > } > > - /* No devm_ version as CLSA0100, in no_acpi_dsd case, can't use devm version */ > + /* To use the same release code for all laptop variants we can't use devm_ version of > + * gpiod_get here, as CLSA010* don't have a fully functional bios with an _DSD node > + */ > cs35l41->reset_gpio = fwnode_gpiod_get_index(&adev->fwnode, "reset", cs35l41->index, > GPIOD_OUT_LOW, "cs35l41-reset"); > > @@ -322,46 +325,46 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c > } > > property = "cirrus,speaker-position"; > - ret = device_property_read_u32_array(acpi_dev, property, values, nval); > + ret = device_property_read_u32_array(physdev, property, values, nval); > if (ret) > goto err_free; > hw_cfg->spk_pos = values[cs35l41->index]; > > property = "cirrus,gpio1-func"; > - ret = device_property_read_u32_array(acpi_dev, property, values, nval); > + ret = device_property_read_u32_array(physdev, property, values, nval); > if (ret) > goto err_free; > hw_cfg->gpio1_func = values[cs35l41->index]; > > property = "cirrus,gpio2-func"; > - ret = device_property_read_u32_array(acpi_dev, property, values, nval); > + ret = device_property_read_u32_array(physdev, property, values, nval); > if (ret) > goto err_free; > hw_cfg->gpio2_func = values[cs35l41->index]; > > property = "cirrus,boost-peak-milliamp"; > - ret = device_property_read_u32_array(acpi_dev, property, values, nval); > + ret = device_property_read_u32_array(physdev, property, values, nval); > if (ret == 0) > hw_cfg->bst_ipk = values[cs35l41->index]; > > property = "cirrus,boost-ind-nanohenry"; > - ret = device_property_read_u32_array(acpi_dev, property, values, nval); > + ret = device_property_read_u32_array(physdev, property, values, nval); > if (ret == 0) > hw_cfg->bst_ind = values[cs35l41->index]; > > property = "cirrus,boost-cap-microfarad"; > - ret = device_property_read_u32_array(acpi_dev, property, values, nval); > + ret = device_property_read_u32_array(physdev, property, values, nval); > if (ret == 0) > hw_cfg->bst_cap = values[cs35l41->index]; > > - put_device(acpi_dev); > + put_device(physdev); > > return hw_cfg; > > err_free: > kfree(hw_cfg); > err: > - put_device(acpi_dev); > + put_device(physdev); > dev_err(cs35l41->dev, "Failed property %s: %d\n", property, ret); > > return ERR_PTR(ret); > @@ -370,18 +373,18 @@ static struct cs35l41_hda_hw_config *cs35l41_hda_read_acpi(struct cs35l41_hda *c > /* > * Device CLSA0100 doesn't have _DSD so a gpiod_get by the label reset won't work. > * And devices created by i2c-multi-instantiate don't have their device struct pointing to > - * the correct fwnode, so acpi_dev must be used here > + * the correct fwnode, so acpi_dev must be used here. > * And devm functions expect that the device requesting the resource has the correct > - * fwnode > + * fwnode. > */ > if (strncmp(hid, "CLSA0100", 8) != 0) > return ERR_PTR(-EINVAL); > > /* check I2C address to assign the index */ > cs35l41->index = id == 0x40 ? 0 : 1; > - cs35l41->reset_gpio = gpiod_get_index(acpi_dev, NULL, 0, GPIOD_OUT_HIGH); > + cs35l41->reset_gpio = gpiod_get_index(physdev, NULL, 0, GPIOD_OUT_HIGH); > cs35l41->vspk_always_on = true; > - put_device(acpi_dev); > + put_device(physdev); > > return NULL; > } > @@ -416,8 +419,7 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i > if (ret == -EBUSY) { > dev_info(cs35l41->dev, "Reset line busy, assuming shared reset\n"); > } else { > - if (ret != -EPROBE_DEFER) > - dev_err(cs35l41->dev, "Failed to get reset GPIO: %d\n", ret); > + dev_err_probe(cs35l41->dev, ret, "Failed to get reset GPIO: %d\n", ret); > goto err; > } > } > @@ -437,7 +439,8 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i > > ret = regmap_read(cs35l41->regmap, CS35L41_IRQ1_STATUS3, &int_sts); > if (ret || (int_sts & CS35L41_OTP_BOOT_ERR)) { > - dev_err(cs35l41->dev, "OTP Boot error\n"); > + dev_err(cs35l41->dev, "OTP Boot status %x error: %d\n", > + int_sts & CS35L41_OTP_BOOT_ERR, ret); > ret = -EIO; > goto err; > } > @@ -489,7 +492,7 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i > > if (cs35l41->reg_seq->probe) { > ret = regmap_multi_reg_write(cs35l41->regmap, cs35l41->reg_seq->probe, > - cs35l41->reg_seq->num_probe); > + cs35l41->reg_seq->num_probe); > if (ret) { > dev_err(cs35l41->dev, "Fail to apply probe reg patch: %d\n", ret); > goto err; > diff --git a/sound/pci/hda/cs35l41_hda.h b/sound/pci/hda/cs35l41_hda.h > index 76c69a8a22f6..640afc98b686 100644 > --- a/sound/pci/hda/cs35l41_hda.h > +++ b/sound/pci/hda/cs35l41_hda.h > @@ -1,6 +1,6 @@ > /* SPDX-License-Identifier: GPL-2.0 > * > - * cs35l41_hda.h -- CS35L41 ALSA HDA audio driver > + * CS35L41 ALSA HDA audio driver > * > * Copyright 2021 Cirrus Logic, Inc. > * > diff --git a/sound/pci/hda/cs35l41_hda_i2c.c b/sound/pci/hda/cs35l41_hda_i2c.c > index eeb387853ee3..c2397dc53e78 100644 > --- a/sound/pci/hda/cs35l41_hda_i2c.c > +++ b/sound/pci/hda/cs35l41_hda_i2c.c > @@ -58,7 +58,6 @@ static struct i2c_driver cs35l41_i2c_driver = { > .probe = cs35l41_hda_i2c_probe, > .remove = cs35l41_hda_i2c_remove, > }; > - > module_i2c_driver(cs35l41_i2c_driver); > > MODULE_DESCRIPTION("HDA CS35L41 driver"); > diff --git a/sound/pci/hda/cs35l41_hda_spi.c b/sound/pci/hda/cs35l41_hda_spi.c > index 15345a72b9d1..36815ab4e461 100644 > --- a/sound/pci/hda/cs35l41_hda_spi.c > +++ b/sound/pci/hda/cs35l41_hda_spi.c > @@ -55,7 +55,6 @@ static struct spi_driver cs35l41_spi_driver = { > .probe = cs35l41_hda_spi_probe, > .remove = cs35l41_hda_spi_remove, > }; > - > module_spi_driver(cs35l41_spi_driver); > > MODULE_DESCRIPTION("HDA CS35L41 driver"); ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH 4/5] ALSA: hda: cs35l41: Tidyup code and add default cases 2022-01-13 17:07 ` [PATCH 4/5] ALSA: hda: cs35l41: Tidyup code and add default cases Lucas Tanure 2022-01-14 13:04 ` Lucas tanure @ 2022-01-14 16:15 ` Takashi Iwai 1 sibling, 0 replies; 14+ messages in thread From: Takashi Iwai @ 2022-01-14 16:15 UTC (permalink / raw) To: Lucas Tanure Cc: Rafael J . Wysocki, Len Brown, Hans de Goede, Mark Gross, Jaroslav Kysela, Takashi Iwai, alsa-devel, linux-acpi, patches, platform-driver-x86, linux-kernel On Thu, 13 Jan 2022 18:07:27 +0100, Lucas Tanure wrote: > > Clean up the code, plus adding default cases for switch > and dev_err_probe use. Please split to patches. There are too much mixed up of changes for different goals. There is difference between a white-space cleanup or such (that is, no significant change of the resultant binary), a cleanup with a better API usage, and a code refactoring. And, the addition of the missing default case is rather the fix, not a clean up... thanks, Takashi ^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH 5/5] ACPI / scan: Create platform device for CLSA0100 2022-01-13 17:07 [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch Lucas Tanure ` (2 preceding siblings ...) 2022-01-13 17:07 ` [PATCH 4/5] ALSA: hda: cs35l41: Tidyup code and add default cases Lucas Tanure @ 2022-01-13 17:07 ` Lucas Tanure 2022-01-14 16:19 ` Takashi Iwai 2022-01-14 16:06 ` [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch Cezary Rojewski 4 siblings, 1 reply; 14+ messages in thread From: Lucas Tanure @ 2022-01-13 17:07 UTC (permalink / raw) To: Rafael J . Wysocki, Len Brown, Hans de Goede, Mark Gross, Jaroslav Kysela, Takashi Iwai Cc: alsa-devel, linux-acpi, patches, platform-driver-x86, linux-kernel, Lucas Tanure The ACPI device with CLSA0100 is a sound card with multiple instances of CS35L41 connected by I2C to the main CPU. We add an ID to the i2c_multi_instantiate_idsi list to enumerate all I2C slaves correctly. Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> --- drivers/acpi/scan.c | 2 ++ drivers/platform/x86/i2c-multi-instantiate.c | 8 ++++++++ 2 files changed, 10 insertions(+) diff --git a/drivers/acpi/scan.c b/drivers/acpi/scan.c index c215bc8723d0..2a68031d953e 100644 --- a/drivers/acpi/scan.c +++ b/drivers/acpi/scan.c @@ -1753,6 +1753,8 @@ static bool acpi_device_enumeration_by_parent(struct acpi_device *device) */ {"BCM4752", }, {"LNV4752", }, + /* Non-conforming _HID for Cirrus Logic already released */ + {"CLSA0100", }, {} }; diff --git a/drivers/platform/x86/i2c-multi-instantiate.c b/drivers/platform/x86/i2c-multi-instantiate.c index 4956a1df5b90..a51a74933fa9 100644 --- a/drivers/platform/x86/i2c-multi-instantiate.c +++ b/drivers/platform/x86/i2c-multi-instantiate.c @@ -147,6 +147,12 @@ static const struct i2c_inst_data int3515_data[] = { {} }; +static const struct i2c_inst_data cs35l41_hda[] = { + { "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, + { "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, + {} +}; + /* * Note new device-ids must also be added to i2c_multi_instantiate_ids in * drivers/acpi/scan.c: acpi_device_enumeration_by_parent(). @@ -155,6 +161,8 @@ static const struct acpi_device_id i2c_multi_inst_acpi_ids[] = { { "BSG1160", (unsigned long)bsg1160_data }, { "BSG2150", (unsigned long)bsg2150_data }, { "INT3515", (unsigned long)int3515_data }, + /* Non-conforming _HID for Cirrus Logic already released */ + { "CLSA0100", (unsigned long)cs35l41_hda }, { } }; MODULE_DEVICE_TABLE(acpi, i2c_multi_inst_acpi_ids); -- 2.34.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
* Re: [PATCH 5/5] ACPI / scan: Create platform device for CLSA0100 2022-01-13 17:07 ` [PATCH 5/5] ACPI / scan: Create platform device for CLSA0100 Lucas Tanure @ 2022-01-14 16:19 ` Takashi Iwai 2022-01-14 17:51 ` Rafael J. Wysocki 0 siblings, 1 reply; 14+ messages in thread From: Takashi Iwai @ 2022-01-14 16:19 UTC (permalink / raw) To: Lucas Tanure Cc: Rafael J . Wysocki, Len Brown, Hans de Goede, Mark Gross, Jaroslav Kysela, Takashi Iwai, alsa-devel, linux-acpi, patches, platform-driver-x86, linux-kernel On Thu, 13 Jan 2022 18:07:28 +0100, Lucas Tanure wrote: > > The ACPI device with CLSA0100 is a sound card with > multiple instances of CS35L41 connected by I2C to > the main CPU. > > We add an ID to the i2c_multi_instantiate_idsi list > to enumerate all I2C slaves correctly. > > Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> I think it's better to merge this from sound git tree together with others in the patch set, presumably for rc1. It'd be great if ACPI people can take a review and give an ack/nack. Thanks! Takashi > --- > drivers/acpi/scan.c | 2 ++ > drivers/platform/x86/i2c-multi-instantiate.c | 8 ++++++++ > 2 files changed, 10 insertions(+) > > diff --git a/drivers/acpi/scan.c b/drivers/acpi/scan.c > index c215bc8723d0..2a68031d953e 100644 > --- a/drivers/acpi/scan.c > +++ b/drivers/acpi/scan.c > @@ -1753,6 +1753,8 @@ static bool acpi_device_enumeration_by_parent(struct acpi_device *device) > */ > {"BCM4752", }, > {"LNV4752", }, > + /* Non-conforming _HID for Cirrus Logic already released */ > + {"CLSA0100", }, > {} > }; > > diff --git a/drivers/platform/x86/i2c-multi-instantiate.c b/drivers/platform/x86/i2c-multi-instantiate.c > index 4956a1df5b90..a51a74933fa9 100644 > --- a/drivers/platform/x86/i2c-multi-instantiate.c > +++ b/drivers/platform/x86/i2c-multi-instantiate.c > @@ -147,6 +147,12 @@ static const struct i2c_inst_data int3515_data[] = { > {} > }; > > +static const struct i2c_inst_data cs35l41_hda[] = { > + { "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, > + { "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, > + {} > +}; > + > /* > * Note new device-ids must also be added to i2c_multi_instantiate_ids in > * drivers/acpi/scan.c: acpi_device_enumeration_by_parent(). > @@ -155,6 +161,8 @@ static const struct acpi_device_id i2c_multi_inst_acpi_ids[] = { > { "BSG1160", (unsigned long)bsg1160_data }, > { "BSG2150", (unsigned long)bsg2150_data }, > { "INT3515", (unsigned long)int3515_data }, > + /* Non-conforming _HID for Cirrus Logic already released */ > + { "CLSA0100", (unsigned long)cs35l41_hda }, > { } > }; > MODULE_DEVICE_TABLE(acpi, i2c_multi_inst_acpi_ids); > -- > 2.34.1 > ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH 5/5] ACPI / scan: Create platform device for CLSA0100 2022-01-14 16:19 ` Takashi Iwai @ 2022-01-14 17:51 ` Rafael J. Wysocki 2022-01-14 18:56 ` Hans de Goede 0 siblings, 1 reply; 14+ messages in thread From: Rafael J. Wysocki @ 2022-01-14 17:51 UTC (permalink / raw) To: Takashi Iwai, Hans de Goede Cc: Lucas Tanure, Rafael J . Wysocki, Len Brown, Mark Gross, Jaroslav Kysela, Takashi Iwai, moderated list:SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEM..., ACPI Devel Maling List, patches, Platform Driver, Linux Kernel Mailing List On Fri, Jan 14, 2022 at 5:19 PM Takashi Iwai <tiwai@suse.de> wrote: > > On Thu, 13 Jan 2022 18:07:28 +0100, > Lucas Tanure wrote: > > > > The ACPI device with CLSA0100 is a sound card with > > multiple instances of CS35L41 connected by I2C to > > the main CPU. > > > > We add an ID to the i2c_multi_instantiate_idsi list > > to enumerate all I2C slaves correctly. > > > > Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> > > I think it's better to merge this from sound git tree together with > others in the patch set, presumably for rc1. > > It'd be great if ACPI people can take a review and give an ack/nack. Hans, what do you think? > > --- > > drivers/acpi/scan.c | 2 ++ > > drivers/platform/x86/i2c-multi-instantiate.c | 8 ++++++++ > > 2 files changed, 10 insertions(+) > > > > diff --git a/drivers/acpi/scan.c b/drivers/acpi/scan.c > > index c215bc8723d0..2a68031d953e 100644 > > --- a/drivers/acpi/scan.c > > +++ b/drivers/acpi/scan.c > > @@ -1753,6 +1753,8 @@ static bool acpi_device_enumeration_by_parent(struct acpi_device *device) > > */ > > {"BCM4752", }, > > {"LNV4752", }, > > + /* Non-conforming _HID for Cirrus Logic already released */ > > + {"CLSA0100", }, > > {} > > }; > > > > diff --git a/drivers/platform/x86/i2c-multi-instantiate.c b/drivers/platform/x86/i2c-multi-instantiate.c > > index 4956a1df5b90..a51a74933fa9 100644 > > --- a/drivers/platform/x86/i2c-multi-instantiate.c > > +++ b/drivers/platform/x86/i2c-multi-instantiate.c > > @@ -147,6 +147,12 @@ static const struct i2c_inst_data int3515_data[] = { > > {} > > }; > > > > +static const struct i2c_inst_data cs35l41_hda[] = { > > + { "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, > > + { "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, > > + {} > > +}; > > + > > /* > > * Note new device-ids must also be added to i2c_multi_instantiate_ids in > > * drivers/acpi/scan.c: acpi_device_enumeration_by_parent(). > > @@ -155,6 +161,8 @@ static const struct acpi_device_id i2c_multi_inst_acpi_ids[] = { > > { "BSG1160", (unsigned long)bsg1160_data }, > > { "BSG2150", (unsigned long)bsg2150_data }, > > { "INT3515", (unsigned long)int3515_data }, > > + /* Non-conforming _HID for Cirrus Logic already released */ > > + { "CLSA0100", (unsigned long)cs35l41_hda }, > > { } > > }; > > MODULE_DEVICE_TABLE(acpi, i2c_multi_inst_acpi_ids); > > -- > > 2.34.1 > > ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH 5/5] ACPI / scan: Create platform device for CLSA0100 2022-01-14 17:51 ` Rafael J. Wysocki @ 2022-01-14 18:56 ` Hans de Goede 2022-01-15 6:59 ` Takashi Iwai 0 siblings, 1 reply; 14+ messages in thread From: Hans de Goede @ 2022-01-14 18:56 UTC (permalink / raw) To: Rafael J. Wysocki, Takashi Iwai Cc: Lucas Tanure, Len Brown, Mark Gross, Jaroslav Kysela, Takashi Iwai, moderated list:SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEM..., ACPI Devel Maling List, patches, Platform Driver, Linux Kernel Mailing List Hi, On 1/14/22 18:51, Rafael J. Wysocki wrote: > On Fri, Jan 14, 2022 at 5:19 PM Takashi Iwai <tiwai@suse.de> wrote: >> >> On Thu, 13 Jan 2022 18:07:28 +0100, >> Lucas Tanure wrote: >>> >>> The ACPI device with CLSA0100 is a sound card with >>> multiple instances of CS35L41 connected by I2C to >>> the main CPU. >>> >>> We add an ID to the i2c_multi_instantiate_idsi list >>> to enumerate all I2C slaves correctly. >>> >>> Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> >> >> I think it's better to merge this from sound git tree together with >> others in the patch set, presumably for rc1. >> >> It'd be great if ACPI people can take a review and give an ack/nack. > > Hans, what do you think? This patch (5/5) applies on top of: https://lore.kernel.org/linux-acpi/20211210154050.3713-1-sbinding@opensource.cirrus.com/ Which still needs some work and which really should be merged through the ACPI tree. IMHO it would be best to simply drop this (5/5) from this series and move it to the v3 of the series which I've linked to above. 1-4 can be merged through the alsa tree independently of 5/5 AFAIK. Regards, Hans > >>> --- >>> drivers/acpi/scan.c | 2 ++ >>> drivers/platform/x86/i2c-multi-instantiate.c | 8 ++++++++ >>> 2 files changed, 10 insertions(+) >>> >>> diff --git a/drivers/acpi/scan.c b/drivers/acpi/scan.c >>> index c215bc8723d0..2a68031d953e 100644 >>> --- a/drivers/acpi/scan.c >>> +++ b/drivers/acpi/scan.c >>> @@ -1753,6 +1753,8 @@ static bool acpi_device_enumeration_by_parent(struct acpi_device *device) >>> */ >>> {"BCM4752", }, >>> {"LNV4752", }, >>> + /* Non-conforming _HID for Cirrus Logic already released */ >>> + {"CLSA0100", }, >>> {} >>> }; >>> >>> diff --git a/drivers/platform/x86/i2c-multi-instantiate.c b/drivers/platform/x86/i2c-multi-instantiate.c >>> index 4956a1df5b90..a51a74933fa9 100644 >>> --- a/drivers/platform/x86/i2c-multi-instantiate.c >>> +++ b/drivers/platform/x86/i2c-multi-instantiate.c >>> @@ -147,6 +147,12 @@ static const struct i2c_inst_data int3515_data[] = { >>> {} >>> }; >>> >>> +static const struct i2c_inst_data cs35l41_hda[] = { >>> + { "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, >>> + { "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, >>> + {} >>> +}; >>> + >>> /* >>> * Note new device-ids must also be added to i2c_multi_instantiate_ids in >>> * drivers/acpi/scan.c: acpi_device_enumeration_by_parent(). >>> @@ -155,6 +161,8 @@ static const struct acpi_device_id i2c_multi_inst_acpi_ids[] = { >>> { "BSG1160", (unsigned long)bsg1160_data }, >>> { "BSG2150", (unsigned long)bsg2150_data }, >>> { "INT3515", (unsigned long)int3515_data }, >>> + /* Non-conforming _HID for Cirrus Logic already released */ >>> + { "CLSA0100", (unsigned long)cs35l41_hda }, >>> { } >>> }; >>> MODULE_DEVICE_TABLE(acpi, i2c_multi_inst_acpi_ids); >>> -- >>> 2.34.1 >>> > ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH 5/5] ACPI / scan: Create platform device for CLSA0100 2022-01-14 18:56 ` Hans de Goede @ 2022-01-15 6:59 ` Takashi Iwai 2022-01-17 10:47 ` tanureal 0 siblings, 1 reply; 14+ messages in thread From: Takashi Iwai @ 2022-01-15 6:59 UTC (permalink / raw) To: Hans de Goede Cc: Rafael J. Wysocki, Lucas Tanure, Len Brown, Mark Gross, Jaroslav Kysela, Takashi Iwai, moderated list:SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEM..., ACPI Devel Maling List, patches, Platform Driver, Linux Kernel Mailing List On Fri, 14 Jan 2022 19:56:04 +0100, Hans de Goede wrote: > > Hi, > > On 1/14/22 18:51, Rafael J. Wysocki wrote: > > On Fri, Jan 14, 2022 at 5:19 PM Takashi Iwai <tiwai@suse.de> wrote: > >> > >> On Thu, 13 Jan 2022 18:07:28 +0100, > >> Lucas Tanure wrote: > >>> > >>> The ACPI device with CLSA0100 is a sound card with > >>> multiple instances of CS35L41 connected by I2C to > >>> the main CPU. > >>> > >>> We add an ID to the i2c_multi_instantiate_idsi list > >>> to enumerate all I2C slaves correctly. > >>> > >>> Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> > >> > >> I think it's better to merge this from sound git tree together with > >> others in the patch set, presumably for rc1. > >> > >> It'd be great if ACPI people can take a review and give an ack/nack. > > > > Hans, what do you think? > > This patch (5/5) applies on top of: > > https://lore.kernel.org/linux-acpi/20211210154050.3713-1-sbinding@opensource.cirrus.com/ > > Which still needs some work and which really should be merged > through the ACPI tree. IMHO it would be best to simply drop > this (5/5) from this series and move it to the v3 of the > series which I've linked to above. > > 1-4 can be merged through the alsa tree independently of 5/5 AFAIK. OK, that's fine. Lucas, could you submit v3 patches in the suggested way? thanks, Takashi ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH 5/5] ACPI / scan: Create platform device for CLSA0100 2022-01-15 6:59 ` Takashi Iwai @ 2022-01-17 10:47 ` tanureal 0 siblings, 0 replies; 14+ messages in thread From: tanureal @ 2022-01-17 10:47 UTC (permalink / raw) To: Takashi Iwai, Hans de Goede, Rafael J. Wysocki, Len Brown, Mark Gross, Jaroslav Kysela, Takashi Iwai, SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEM..., ACPI Devel Maling List, patches, Platform Driver, Linux Kernel Mailing List On 1/15/22 6:59 AM, Takashi Iwai <tiwai@suse.de> wrote: > On Fri, 14 Jan 2022 19:56:04 +0100, > Hans de Goede wrote: > > > > Hi, > > > > On 1/14/22 18:51, Rafael J. Wysocki wrote: > >> On Fri, Jan 14, 2022 at 5:19 PM Takashi Iwai <tiwai@suse.de> wrote: > >>> > >>> On Thu, 13 Jan 2022 18:07:28 +0100, > >>> Lucas Tanure wrote: > >>>> > >>>> The ACPI device with CLSA0100 is a sound card with > >>>> multiple instances of CS35L41 connected by I2C to > >>>> the main CPU. > >>>> > >>>> We add an ID to the i2c_multi_instantiate_idsi list > >>>> to enumerate all I2C slaves correctly. > >>>> > >>>> Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> > >>> > >>> I think it's better to merge this from sound git tree together with > >>> others in the patch set, presumably for rc1. > >>> > >>> It'd be great if ACPI people can take a review and give an ack/nack. > >> > >> Hans, what do you think? > > > > This patch (5/5) applies on top of: > > > > https://lore.kernel.org/linux-acpi/20211210154050.3713-1-sbinding@opensource.cirrus.com/ > > > > Which still needs some work and which really should be merged > > through the ACPI tree. IMHO it would be best to simply drop > > this (5/5) from this series and move it to the v3 of the > > series which I've linked to above. > > > > 1-4 can be merged through the alsa tree independently of 5/5 AFAIK. > > OK, that's fine. > > Lucas, could you submit v3 patches in the suggested way? Yes, we will do that. Thanks > > > thanks, > > Takashi > ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch 2022-01-13 17:07 [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch Lucas Tanure ` (3 preceding siblings ...) 2022-01-13 17:07 ` [PATCH 5/5] ACPI / scan: Create platform device for CLSA0100 Lucas Tanure @ 2022-01-14 16:06 ` Cezary Rojewski 4 siblings, 0 replies; 14+ messages in thread From: Cezary Rojewski @ 2022-01-14 16:06 UTC (permalink / raw) To: Lucas Tanure, Rafael J . Wysocki, Len Brown, Hans de Goede, Mark Gross, Jaroslav Kysela, Takashi Iwai Cc: alsa-devel, linux-acpi, patches, platform-driver-x86, linux-kernel, Charles Keepax On 2022-01-13 6:07 PM, Lucas Tanure wrote: > From: Charles Keepax <ckeepax@opensource.cirrus.com> > > regmap_register_patch can't be used to apply the probe sequence as a > patch is already registers with the regmap by > cs35l41_register_errata_patch and only a single patch can be attached to > a single regmap. The driver doesn't currently rely on a cache sync to > re-apply this probe sequence so simply switch it to a multi write. > > Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com> > Signed-off-by: Lucas Tanure <tanureal@opensource.cirrus.com> Please correct me if I'm wrong, but this change looks like a fix for the previously added commit: ALSA: hda: cs35l41: Add support for CS35L41 in HDA systems and so it would be good to append appropriate 'Fixes' tag here. > --- > sound/pci/hda/cs35l41_hda.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/sound/pci/hda/cs35l41_hda.c b/sound/pci/hda/cs35l41_hda.c > index 30b40d865863..c47c5f0b4e59 100644 > --- a/sound/pci/hda/cs35l41_hda.c > +++ b/sound/pci/hda/cs35l41_hda.c > @@ -480,7 +480,7 @@ int cs35l41_hda_probe(struct device *dev, const char *device_name, int id, int i > acpi_hw_cfg = NULL; > > if (cs35l41->reg_seq->probe) { > - ret = regmap_register_patch(cs35l41->regmap, cs35l41->reg_seq->probe, > + ret = regmap_multi_reg_write(cs35l41->regmap, cs35l41->reg_seq->probe, > cs35l41->reg_seq->num_probe); > if (ret) { > dev_err(cs35l41->dev, "Fail to apply probe reg patch: %d\n", ret); > ^ permalink raw reply [flat|nested] 14+ messages in thread
end of thread, other threads:[~2022-01-17 10:48 UTC | newest] Thread overview: 14+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2022-01-13 17:07 [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch Lucas Tanure 2022-01-13 17:07 ` [PATCH 2/5] ALSA: hda: cs35l41: Add calls to newly added test key function Lucas Tanure 2022-01-14 16:14 ` Cezary Rojewski 2022-01-13 17:07 ` [PATCH 3/5] ALSA: hda: cs35l41: Move cs35l41* calls to its own symbol namespace Lucas Tanure 2022-01-13 17:07 ` [PATCH 4/5] ALSA: hda: cs35l41: Tidyup code and add default cases Lucas Tanure 2022-01-14 13:04 ` Lucas tanure 2022-01-14 16:15 ` Takashi Iwai 2022-01-13 17:07 ` [PATCH 5/5] ACPI / scan: Create platform device for CLSA0100 Lucas Tanure 2022-01-14 16:19 ` Takashi Iwai 2022-01-14 17:51 ` Rafael J. Wysocki 2022-01-14 18:56 ` Hans de Goede 2022-01-15 6:59 ` Takashi Iwai 2022-01-17 10:47 ` tanureal 2022-01-14 16:06 ` [PATCH 1/5] ALSA: hda: cs35l41: Avoid overwriting register patch Cezary Rojewski
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).