mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-04-15 00:27:37 +07:00
intel_th: Fix activating a subdevice without a driver
If output subdevice driver is not loaded, activating it will try to call its ->activate method and crash. Fix this by explicitly checking for the driver. Signed-off-by: Alexander Shishkin <alexander.shishkin@linux.intel.com> Reviewed-by: Laurent Fert <laurent.fert@intel.com>
This commit is contained in:
parent
e8644e4c2a
commit
f18a9531f6
@ -183,7 +183,11 @@ static DEVICE_ATTR_RO(port);
|
|||||||
|
|
||||||
static int intel_th_output_activate(struct intel_th_device *thdev)
|
static int intel_th_output_activate(struct intel_th_device *thdev)
|
||||||
{
|
{
|
||||||
struct intel_th_driver *thdrv = to_intel_th_driver(thdev->dev.driver);
|
struct intel_th_driver *thdrv =
|
||||||
|
to_intel_th_driver_or_null(thdev->dev.driver);
|
||||||
|
|
||||||
|
if (!thdrv)
|
||||||
|
return -ENODEV;
|
||||||
|
|
||||||
if (thdrv->activate)
|
if (thdrv->activate)
|
||||||
return thdrv->activate(thdev);
|
return thdrv->activate(thdev);
|
||||||
@ -195,7 +199,11 @@ static int intel_th_output_activate(struct intel_th_device *thdev)
|
|||||||
|
|
||||||
static void intel_th_output_deactivate(struct intel_th_device *thdev)
|
static void intel_th_output_deactivate(struct intel_th_device *thdev)
|
||||||
{
|
{
|
||||||
struct intel_th_driver *thdrv = to_intel_th_driver(thdev->dev.driver);
|
struct intel_th_driver *thdrv =
|
||||||
|
to_intel_th_driver_or_null(thdev->dev.driver);
|
||||||
|
|
||||||
|
if (!thdrv)
|
||||||
|
return;
|
||||||
|
|
||||||
if (thdrv->deactivate)
|
if (thdrv->deactivate)
|
||||||
thdrv->deactivate(thdev);
|
thdrv->deactivate(thdev);
|
||||||
|
@ -151,6 +151,9 @@ struct intel_th_driver {
|
|||||||
#define to_intel_th_driver(_d) \
|
#define to_intel_th_driver(_d) \
|
||||||
container_of((_d), struct intel_th_driver, driver)
|
container_of((_d), struct intel_th_driver, driver)
|
||||||
|
|
||||||
|
#define to_intel_th_driver_or_null(_d) \
|
||||||
|
((_d) ? to_intel_th_driver(_d) : NULL)
|
||||||
|
|
||||||
static inline struct intel_th_device *
|
static inline struct intel_th_device *
|
||||||
to_intel_th_hub(struct intel_th_device *thdev)
|
to_intel_th_hub(struct intel_th_device *thdev)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user