From: "Kurt Borja" <kuurtb@gmail.com>
To: "Andy Shevchenko" <andriy.shevchenko@intel.com>
Cc: platform-driver-x86@vger.kernel.org,
"Ilpo Järvinen" <ilpo.jarvinen@linux.intel.com>,
"Armin Wolf" <W_Armin@gmx.de>,
"Mario Limonciello" <mario.limonciello@amd.com>,
"Hans de Goede" <hdegoede@redhat.com>,
Dell.Client.Kernel@dell.com, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v10 11/14] platform/x86: Split the alienware-wmi driver
Date: Fri, 14 Feb 2025 17:21:00 -0500 [thread overview]
Message-ID: <D7SIOS9FABGO.1ZOTYZJ4PWMTA@gmail.com> (raw)
In-Reply-To: <Z6ufIQADzILVMusc@smile.fi.intel.com>
Hi Andy,
On Tue Feb 11, 2025 at 2:04 PM -05, Andy Shevchenko wrote:
> On Tue, Feb 11, 2025 at 12:59:53PM -0500, Kurt Borja wrote:
>> On Tue Feb 11, 2025 at 11:56 AM -05, Andy Shevchenko wrote:
>> > On Fri, Feb 07, 2025 at 10:46:07AM -0500, Kurt Borja wrote:
>
> ...
>
>> >> obj-$(CONFIG_ALIENWARE_WMI) += alienware-wmi.o
>> >> alienware-wmi-objs := alienware-wmi-base.o
>> >> +alienware-wmi-y += alienware-wmi-legacy.o
>> >> +alienware-wmi-y += alienware-wmi-wmax.o
>> >
>> > Oh my... it's even inconsistent!
>>
>> Again, this is an already used pattern:
>
>> https://elixir.bootlin.com/linux/v6.14-rc2/source/drivers/platform/x86/dell/Makefile#L14
>>
>> I add configuration entries later. Is the order of the changes wrong? or
>> is it the entire approach? Do other modules here need a fix?
>
> Again, it doesn't mean it's correct.
>
> Maybe other modules also need that, I don't remember, but you may `git log
> --no-merges --author="Andy" --grep objs` to see changes I made in the past.
Sorry!
Everything made more sense after reading the docs and checking your
commits.
I submitted a patch fixing this. Thank you for pointing it out!
>
> ...
>
>> >> + if (!ret) {
>> >> + if (out_data == 0)
>> >> + return sysfs_emit(buf, "[disabled] s5 s5_s4\n");
>> >> + else if (out_data == 1)
>> >> + return sysfs_emit(buf, "disabled [s5] s5_s4\n");
>> >> + else if (out_data == 2)
>> >> + return sysfs_emit(buf, "disabled s5 [s5_s4]\n");
>> >
>> > The whole code inherited same issues like redundant 'else'. Please, refactor.
>>
>> This is not my code, so a separate patch would be needed.
>
> Okay!
>
> ...
>
>> >> + if (strcmp(buf, "disabled\n") == 0)
>> >> + args.arg = 0;
>> >> + else if (strcmp(buf, "s5\n") == 0)
>> >> + args.arg = 1;
>> >> + else
>> >> + args.arg = 2;
>> >
>> > sysfs_match_string()
>>
>> Same as above.
>
> Same as above :-)
>
> ...
>
>> >> + if ((code & WMAX_THERMAL_TABLE_MASK) == WMAX_THERMAL_TABLE_USTT &&
>> >> + (code & WMAX_THERMAL_MODE_MASK) <= THERMAL_MODE_USTT_LOW_POWER)
>> >> + return true;
>> >> +
>> >> + return false;
>> >
>> > return ...
>> >
>> > but if you wish, this one is okay.
>>
>> This was done for readibility. Also this would require a different
>> patch.
>
> No need, I'm fine with the current approach, just to show the alternatives.
>
> ...
>
>> >> + ret = wmax_thermal_information(priv->wdev, WMAX_OPERATION_SYS_DESCRIPTION,
>> >> + 0, (u32 *) &sys_desc);
>> >
>> > How do you guarantee an alignment? Yes, it might be good for the specific
>> > hardware, but in general this is broken code.
>>
>> This is a good question. I'm not really sure how to fix this tho. Is it
>> fine to just pass a __packed struct? Also this would require another
>> patch.
>
> Usual approach here is to use one of get_unaligned_le32(), get_unaligned_be32()
> depending on the byte ordering.
>
>> >> + if (ret < 0)
>> >> + return ret;
>
> ...
>
>> >> + set_bit(profile, choices);
>> >
>> > Do you need it to be atomic?
>>
>> I don't think so. `choices` belongs to this thread only.
>
> So, __set_bit() will suffice then.
For some reason I thought `set_bit` was the non-atomic one. This is good
to know.
>
> ...
>
>> >> +void __exit alienware_wmax_wmi_exit(void)
>> >> +{
>> >> + wmi_driver_unregister(&alienware_wmax_wmi_driver);
>> >> +}
>> >
>> > Why not moving these boilerplate to ->probe() and use module_wmi_driver()?
>>
>> This 3 files are a single module and it has two WMI drivers so this
>> can't be used.
>
> Can it be split to two separate modules then?
These two WMI drivers share a lot of features on old alienware models.
Hence why I decided to link them together. IMO this bit of boilerplate
is a fair tradeoff.
Thank you again for your feedback. I was completely unaware of some
things you pointed out. I will implement your suggestions soon.
--
~ Kurt
next prev parent reply other threads:[~2025-02-14 22:21 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-02-07 15:45 [PATCH v10 00/14] platform/x86: alienware-wmi driver rework Kurt Borja
2025-02-07 15:45 ` [PATCH v10 01/14] platform/x86: alienware-wmi: Add a state container for LED control feature Kurt Borja
2025-02-07 15:45 ` [PATCH v10 02/14] platform/x86: alienware-wmi: Add WMI Drivers Kurt Borja
2025-02-11 16:30 ` Andy Shevchenko
2025-02-11 17:46 ` Kurt Borja
2025-02-11 18:51 ` Andy Shevchenko
2025-02-07 15:45 ` [PATCH v10 03/14] platform/x86: alienware-wmi: Add a state container for thermal control methods Kurt Borja
2025-02-07 15:46 ` [PATCH v10 04/14] platform/x86: alienware-wmi: Refactor LED " Kurt Borja
2025-02-11 16:33 ` Andy Shevchenko
2025-02-11 17:47 ` Kurt Borja
2025-02-07 15:46 ` [PATCH v10 05/14] platform/x86: alienware-wmi: Refactor hdmi, amplifier, deepslp methods Kurt Borja
2025-02-11 16:37 ` Andy Shevchenko
2025-02-11 17:51 ` Kurt Borja
2025-02-11 18:55 ` Andy Shevchenko
2025-02-07 15:46 ` [PATCH v10 06/14] platform/x86: alienware-wmi: Refactor thermal control methods Kurt Borja
2025-02-07 15:46 ` [PATCH v10 07/14] platform/x86: alienware-wmi: Split DMI table Kurt Borja
2025-02-11 16:39 ` Andy Shevchenko
2025-02-11 17:53 ` Kurt Borja
2025-02-07 15:46 ` [PATCH v10 08/14] MAINTAINERS: Update ALIENWARE WMI DRIVER entry Kurt Borja
2025-02-07 15:46 ` [PATCH v10 09/14] platform/x86: Rename alienware-wmi.c Kurt Borja
2025-02-11 16:41 ` Andy Shevchenko
2025-02-11 17:31 ` Kurt Borja
2025-02-11 18:50 ` Andy Shevchenko
2025-02-07 15:46 ` [PATCH v10 10/14] platform/x86: Add alienware-wmi.h Kurt Borja
2025-02-11 16:45 ` Andy Shevchenko
2025-02-11 16:51 ` Ilpo Järvinen
2025-02-11 17:19 ` Andy Shevchenko
2025-02-11 17:53 ` Kurt Borja
2025-02-07 15:46 ` [PATCH v10 11/14] platform/x86: Split the alienware-wmi driver Kurt Borja
2025-02-11 16:56 ` Andy Shevchenko
2025-02-11 17:59 ` Kurt Borja
2025-02-11 19:04 ` Andy Shevchenko
2025-02-14 22:21 ` Kurt Borja [this message]
2025-02-16 20:35 ` Andy Shevchenko
2025-02-07 15:46 ` [PATCH v10 12/14] platform/x86: dell: Modify Makefile alignment Kurt Borja
2025-02-11 16:56 ` Andy Shevchenko
2025-02-07 15:46 ` [PATCH v10 13/14] platform/x86: Update alienware-wmi config entries Kurt Borja
2025-02-07 15:46 ` [PATCH v10 14/14] platform/x86: alienware-wmi: Update header and module information Kurt Borja
2025-02-10 11:53 ` [PATCH v10 00/14] platform/x86: alienware-wmi driver rework Ilpo Järvinen
2025-02-10 13:48 ` Kurt Borja
2025-02-11 16:58 ` Andy Shevchenko
2025-02-11 18:09 ` Kurt Borja
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=D7SIOS9FABGO.1ZOTYZJ4PWMTA@gmail.com \
--to=kuurtb@gmail.com \
--cc=Dell.Client.Kernel@dell.com \
--cc=W_Armin@gmx.de \
--cc=andriy.shevchenko@intel.com \
--cc=hdegoede@redhat.com \
--cc=ilpo.jarvinen@linux.intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mario.limonciello@amd.com \
--cc=platform-driver-x86@vger.kernel.org \
/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.