From: Takashi Iwai <tiwai@suse.de>
To: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Cc: Shenghao Ding <shenghao-ding@ti.com>,
robh+dt@kernel.org, lgirdwood@gmail.com, perex@perex.cz,
kevin-lu@ti.com, 13916275206@139.com,
alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org,
liam.r.girdwood@intel.com, mengdong.lin@intel.com,
baojun.xu@ti.com, thomas.gfeller@q-drop.com, peeyush@ti.com,
navada@ti.com, broonie@kernel.org, gentuser@gmail.com
Subject: Re: [PATCH v3 1/2] ALSA: hda/tas2781: Add tas2781 HDA driver
Date: Sun, 20 Aug 2023 11:35:49 +0200 [thread overview]
Message-ID: <87il9a9hu2.wl-tiwai@suse.de> (raw)
In-Reply-To: <9f910785-e856-1539-e3e4-c9817af5fe67@linux.intel.com>
On Fri, 18 Aug 2023 18:30:42 +0200,
Pierre-Louis Bossart wrote:
>
> The code doesn't look too bad but needs a bit more work. There are quite
> a few error handling issues, pm_runtime needs to be revisited and
> ACPI/EFI as well.
>
> > +enum calib_data {
>
> tas2781_calib_data?
Well, as long as it's a local stuff, a suffix isn't really needed.
If it makes thing too confusing, it should be named properly, of
course, though.
> > +static int tas2781_read_acpi(struct tasdevice_priv *p, const char *hid)
> > +{
> > + struct acpi_device *adev;
> > + struct device *physdev;
> > + LIST_HEAD(resources);
> > + const char *sub;
> > + int ret;
> > +
> > + adev = acpi_dev_get_first_match_dev(hid, NULL, -1);
> > + if (!adev) {
> > + dev_err(p->dev,
> > + "Failed to find an ACPI device for %s\n", hid);
> > + return -ENODEV;
> > + }
>
> [1] need to take care of a resource leak here
Right, and that's rather a typo at the end of the function...
> > +err:
> > + dev_err(p->dev, "read acpi error, ret: %d\n", ret);
> > + put_device(physdev);
... this must be put_device(adev) instead physdev.
> > +static void tas2781_hda_playback_hook(struct device *dev, int action)
> > +{
> > + struct tasdevice_priv *tas_priv = dev_get_drvdata(dev);
> > +
> > + dev_dbg(tas_priv->dev, "%s: action = %d\n", __func__, action);
> > + switch (action) {
> > + case HDA_GEN_PCM_ACT_OPEN:
> > + pm_runtime_get_sync(dev);
>
> test if this actually works?
To be fair, most of driver codes don't check it, including the
HD-audio core. (Actually, over 900 of 1300 calls have no check in the
whole tree.)
It implies that forcing the check in each place is moot; rather the
helper needs to be coded not to fail, IMO.
> > +static int tasdevice_hda_clamp(int val, int max)
> > +{
> > + if (val > max)
> > + val = max;
> > +
> > + if (val < 0)
> > + val = 0;
> > + return val;
> > +}
>
> I've seen that macro in the TAS2783 code as well, that sounds like a
> good helper function to share?
There is already clamp() macro, and I guess it can be replaced with
clamp(val, 0, max).
> > +
> > + comps->dev = dev;
> > +
> > + strscpy(comps->name, dev_name(dev), sizeof(comps->name));
> > +
> > + ret = tascodec_init(tas_priv, codec, tasdev_fw_ready);
> > + if (ret)
> > + return ret;
>
> need to do a put_autosuspend below, this is leaking a refcount.
Right, that needs an obvious leak. Let's fix it.
> > +static int tas2781_system_suspend(struct device *dev)
> > +{
> > + struct tasdevice_priv *tas_priv = dev_get_drvdata(dev);
> > + int ret;
> > +
> > + dev_dbg(tas_priv->dev, "System Suspend\n");
> > +
> > + ret = pm_runtime_force_suspend(dev);
> > + if (ret)
> > + return ret;
>
> that's usually the other way around, for system suspend you either want
> the device to be pm_runtime active, or if it's already suspended do nothing.
>
> This is very odd to me.
This is a normal procedure, as stated in pm_runtime_force_suspend()
definition:
/**
* pm_runtime_force_suspend - Force a device into suspend state if needed.
....
* Typically this function may be invoked from a system suspend callback to make
* sure the device is put into low power state and it should only be used during
* system-wide PM transitions to sleep states. It assumes that the analogous
* pm_runtime_force_resume() will be used to resume the device.
thanks,
Takashi
next prev parent reply other threads:[~2023-08-20 9:37 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-08-18 8:55 [PATCH v3 1/2] ALSA: hda/tas2781: Add tas2781 HDA driver Shenghao Ding
2023-08-18 8:55 ` [PATCH v3 2/2] " Shenghao Ding
2023-08-18 16:00 ` Pierre-Louis Bossart
2023-08-18 17:01 ` Andy Shevchenko
2023-08-20 9:16 ` Takashi Iwai
2023-08-21 9:06 ` Andy Shevchenko
2023-08-21 9:14 ` Takashi Iwai
2023-08-21 9:26 ` Andy Shevchenko
2023-08-18 16:30 ` [PATCH v3 1/2] " Pierre-Louis Bossart
2023-08-20 9:35 ` Takashi Iwai [this message]
2023-08-21 14:43 ` Pierre-Louis Bossart
2023-08-21 14:57 ` Takashi Iwai
2023-08-21 15:04 ` Pierre-Louis Bossart
-- strict thread matches above, loose matches on Subject: below --
2023-08-17 8:26 Shenghao Ding
2023-08-17 13:39 ` kernel test robot
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=87il9a9hu2.wl-tiwai@suse.de \
--to=tiwai@suse.de \
--cc=13916275206@139.com \
--cc=alsa-devel@alsa-project.org \
--cc=baojun.xu@ti.com \
--cc=broonie@kernel.org \
--cc=gentuser@gmail.com \
--cc=kevin-lu@ti.com \
--cc=lgirdwood@gmail.com \
--cc=liam.r.girdwood@intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mengdong.lin@intel.com \
--cc=navada@ti.com \
--cc=peeyush@ti.com \
--cc=perex@perex.cz \
--cc=pierre-louis.bossart@linux.intel.com \
--cc=robh+dt@kernel.org \
--cc=shenghao-ding@ti.com \
--cc=thomas.gfeller@q-drop.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.