linux/drivers/platform/surface
Maximilian Luz bc923d594d
platform/surface: aggregator: Fix warning when controller is destroyed in probe
There is a small window in ssam_serial_hub_probe() where the controller
is initialized but has not been started yet. Specifically, between
ssam_controller_init() and ssam_controller_start(). Any failure in this
window, for example caused by a failure of serdev_device_open(),
currently results in an incorrect warning being emitted.

In particular, any failure in this window results in the controller
being destroyed via ssam_controller_destroy(). This function checks the
state of the controller and, in an attempt to validate that the
controller has been cleanly shut down before we try and deallocate any
resources, emits a warning if that state is not SSAM_CONTROLLER_STOPPED.

However, since we have only just initialized the controller and have not
yet started it, its state is SSAM_CONTROLLER_INITIALIZED. Note that this
is the only point at which the controller has this state, as it will
change after we start the controller with ssam_controller_start() and
never revert back. Further, at this point no communication has taken
place and the sender and receiver threads have not been started yet (and
we may not even have an open serdev device either).

Therefore, it is perfectly safe to call ssam_controller_destroy() with a
state of SSAM_CONTROLLER_INITIALIZED. This, however, means that the
warning currently being emitted is incorrect. Fix it by extending the
check.

Fixes: c167b9c7e3 ("platform/surface: Add Surface Aggregator subsystem")
Signed-off-by: Maximilian Luz <luzmaximilian@gmail.com>
Link: https://lore.kernel.org/r/20240811124645.246016-1-luzmaximilian@gmail.com
Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
2024-08-13 11:20:19 +03:00
..
aggregator platform/surface: aggregator: Fix warning when controller is destroyed in probe 2024-08-13 11:20:19 +03:00
Kconfig platform/surface: aggregator: Move subsystem hub drivers to their own module 2022-07-02 11:23:25 +02:00
Makefile platform/surface: aggregator: Move subsystem hub drivers to their own module 2022-07-02 11:23:25 +02:00
surface3_power.c platform/surface: surface3_power: Switch back to use struct i2c_driver's .probe() 2023-06-13 12:32:16 +02:00
surface3-wmi.c platform/surface: surface3-wmi: Convert to platform remove callback returning void 2023-09-21 18:31:18 +02:00
surface_acpi_notify.c ACPI: utils: Introduce helper for _DEP list lookup 2023-12-19 18:25:00 +01:00
surface_aggregator_cdev.c platform/surface: aggregator-cdev: Convert to platform remove callback returning void 2023-09-21 18:31:19 +02:00
surface_aggregator_hub.c platform/surface: aggregator_registry: Fix target-ID of base-hub 2023-02-02 22:48:20 +01:00
surface_aggregator_registry.c platform/surface: aggregator_registry: Add support for Surface Laptop 6 2024-08-13 11:01:20 +03:00
surface_aggregator_tabletsw.c platform/surface: aggregator_tabletsw: Add support for book mode in POS subsystem 2023-05-30 11:20:30 +02:00
surface_dtx.c platform/surface: dtx: Convert to platform remove callback returning void 2023-09-21 18:31:19 +02:00
surface_gpe.c platform/surface: gpe: Convert to platform remove callback returning void 2023-09-21 18:31:19 +02:00
surface_hotplug.c platform/surface: hotplug: Convert to platform remove callback returning void 2023-09-21 18:31:19 +02:00
surface_platform_profile.c platform/surface: platform_profile: add fan profile switching 2024-03-25 15:55:29 +01:00
surfacepro3_button.c ACPI: make remove callback of ACPI driver void 2022-11-23 19:11:22 +01:00