mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-15 01:24:33 +00:00
d1aae06630
Let's use a wrapper struct for the auxiliary_device made in jh7110_reset_controller_register() so that we can stop casting iomem pointers. The casts trip up tools like sparse, and make for some awkward casts that are largely unnecessary. While we're here, change the allocation from devm and actually free the auxiliary_device memory in the release function. This avoids any use after free problems where the parent device driver is unbound from the device but the auxiliuary_device is still in use accessing devm freed memory. Cc: Tommaso Merciai <tomm.merciai@gmail.com> Cc: Emil Renner Berthing <emil.renner.berthing@canonical.com> Cc: Hal Feng <hal.feng@starfivetech.com> Cc: Conor Dooley <conor.dooley@microchip.com> Cc: Xingyu Wu <xingyu.wu@starfivetech.com> Reviewed-by: Conor Dooley <conor.dooley@microchip.com> Fixes: edab7204afe5 ("clk: starfive: Add StarFive JH7110 system clock driver") Signed-off-by: Stephen Boyd <sboyd@kernel.org> Link: https://lore.kernel.org/r/20230413205528.4044216-1-sboyd@kernel.org
18 lines
400 B
C
18 lines
400 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef __SOC_STARFIVE_RESET_JH71X0_H
|
|
#define __SOC_STARFIVE_RESET_JH71X0_H
|
|
|
|
#include <linux/auxiliary_bus.h>
|
|
#include <linux/compiler_types.h>
|
|
#include <linux/container_of.h>
|
|
|
|
struct jh71x0_reset_adev {
|
|
void __iomem *base;
|
|
struct auxiliary_device adev;
|
|
};
|
|
|
|
#define to_jh71x0_reset_adev(_adev) \
|
|
container_of((_adev), struct jh71x0_reset_adev, adev)
|
|
|
|
#endif
|