From: Hans de Goede <hdegoede@redhat.com>
To: Maximilian Luz <luzmaximilian@gmail.com>
Cc: Mark Gross <mgross@linux.intel.com>,
platform-driver-x86@vger.kernel.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH v3 0/6] platform/surface: Add Surface Aggregator device registry
Date: Thu, 4 Mar 2021 12:00:48 +0100 [thread overview]
Message-ID: <50854143-032e-95f2-e3e1-b85590a0265b@redhat.com> (raw)
In-Reply-To: <20210212115439.1525216-1-luzmaximilian@gmail.com>
Hi,
On 2/12/21 12:54 PM, Maximilian Luz wrote:
> The Surface System Aggregator Module (SSAM) subsystem provides various
> functionalities, which are separated by spreading them across multiple
> devices and corresponding drivers. Parts of that functionality / some of
> those devices, however, can (as far as we currently know) not be
> auto-detected by conventional means. While older (specifically 5th- and
> 6th-)generation models do advertise most of their functionality via
> standard platform devices in ACPI, newer generations do not.
>
> As we are currently also not aware of any feasible way to query said
> functionalities dynamically, this poses a problem. There is, however, a
> device in ACPI that seems to be used by Windows for identifying
> different Surface models: The Windows Surface Integration Device (WSID).
> This device seems to have a HID corresponding to the overall set of
> functionalities SSAM provides for the associated model.
>
> This series introduces a device registry based on software nodes and
> device hubs to solve this problem. The registry is intended to contain
> all required non-detectable information.
>
> The platform hub driver is loaded against the WSID device and
> instantiates and manages SSAM devices based on the information provided
> by the registry for the given WSID HID of the Surface model. All new
> devices created by this hub added as child devices to this hub.
>
> In addition, a base hub is introduced to manage devices associated with
> the detachable base part of the Surface Book 3, as this requires special
> handling (i.e. devices need to be removed when the base is removed).
> Again, all devices created by the base hub (i.e. associated with the
> base) are added as child devices to this hub.
>
> In total, this will yield the following device structure
>
> WSID
> |- SSAM device 1 (physical device)
> |- SSAM device 2 (physical device)
> |- SSAM device 3 (physical device)
> |- ...
> \- SSAM base hub (virtual device)
> |- SSAM base device 1 (physical device)
> |- SSAM base device 2 (physical device)
> |- ...
>
> While software nodes seem to be well suited for this approach due to
> extensibility, they still need to be hard-coded, so I'm open for ideas
> on how this could be improved.
Thank you for your patch-series, I've applied the series to my
review-hans branch:
https://git.kernel.org/pub/scm/linux/kernel/git/pdx86/platform-drivers-x86.git/log/?h=review-hans
Note it will show up in my review-hans branch once I've pushed my
local branch there, which might take a while.
Once I've run some tests on this branch the patches there will be
added to the platform-drivers-x86/for-next branch and eventually
will be included in the pdx86 pull-request to Linus for the next
merge-window.
Regards,
Hans
>
> Changes in v2:
> - Fix Kconfig dependency
>
> Changes in v3:
> - Fix use of lockdep_assert_held()
>
> Maximilian Luz (6):
> platform/surface: Set up Surface Aggregator device registry
> platform/surface: aggregator_registry: Add base device hub
> platform/surface: aggregator_registry: Add battery subsystem devices
> platform/surface: aggregator_registry: Add platform profile device
> platform/surface: aggregator_registry: Add DTX device
> platform/surface: aggregator_registry: Add HID subsystem devices
>
> MAINTAINERS | 1 +
> drivers/platform/surface/Kconfig | 27 +
> drivers/platform/surface/Makefile | 1 +
> .../surface/surface_aggregator_registry.c | 641 ++++++++++++++++++
> 4 files changed, 670 insertions(+)
> create mode 100644 drivers/platform/surface/surface_aggregator_registry.c
>
prev parent reply other threads:[~2021-03-04 11:03 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-02-12 11:54 [PATCH v3 0/6] platform/surface: Add Surface Aggregator device registry Maximilian Luz
2021-02-12 11:54 ` [PATCH v3 1/6] platform/surface: Set up " Maximilian Luz
2021-02-12 11:54 ` [PATCH v3 2/6] platform/surface: aggregator_registry: Add base device hub Maximilian Luz
2021-02-12 11:54 ` [PATCH v3 3/6] platform/surface: aggregator_registry: Add battery subsystem devices Maximilian Luz
2021-02-12 11:54 ` [PATCH v3 4/6] platform/surface: aggregator_registry: Add platform profile device Maximilian Luz
2021-02-12 11:54 ` [PATCH v3 5/6] platform/surface: aggregator_registry: Add DTX device Maximilian Luz
2021-02-12 11:54 ` [PATCH v3 6/6] platform/surface: aggregator_registry: Add HID subsystem devices Maximilian Luz
2021-03-04 11:00 ` Hans de Goede [this message]
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=50854143-032e-95f2-e3e1-b85590a0265b@redhat.com \
--to=hdegoede@redhat.com \
--cc=linux-kernel@vger.kernel.org \
--cc=luzmaximilian@gmail.com \
--cc=mgross@linux.intel.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox