Re: [PATCH] driver core: platform: Fix the usage of platform device name(pdev->name)

From: Greg KH
Date: Mon Apr 29 2019 - 13:50:28 EST


On Mon, Apr 29, 2019 at 05:07:56PM +0200, Krzysztof Kozlowski wrote:
> On Tue, 23 Apr 2019 at 05:36, Venkata Narendra Kumar Gutta
> <vnkgutta@xxxxxxxxxxxxxx> wrote:
> >
> > Platform core is using pdev->name as the platform device name to do
> > the binding of the devices with the drivers. But, when the platform
> > driver overrides the platform device name with dev_set_name(),
> > the pdev->name is pointing to a location which is freed and becomes
>
> If pdev->name is invalid then it should be removed/fixed. Why leaving
> it pointing to wrong place and changing the users to something else?
> This looks like either duct-tape for real problem.
>
> > an invalid parameter to do the binding match.
> >
> > use-after-free instance:
> >
> > [ 33.325013] BUG: KASAN: use-after-free in strcmp+0x8c/0xb0
> > [ 33.330646] Read of size 1 at addr ffffffc10beae600 by task modprobe
> > [ 33.339068] CPU: 5 PID: 518 Comm: modprobe Tainted:
> > G S W O 4.19.30+ #3
> > [ 33.346835] Hardware name: MTP (DT)
> > [ 33.350419] Call trace:
> > [ 33.352941] dump_backtrace+0x0/0x3b8
> > [ 33.356713] show_stack+0x24/0x30
> > [ 33.360119] dump_stack+0x160/0x1d8
> > [ 33.363709] print_address_description+0x84/0x2e0
> > [ 33.368549] kasan_report+0x26c/0x2d0
> > [ 33.372322] __asan_report_load1_noabort+0x2c/0x38
> > [ 33.377248] strcmp+0x8c/0xb0
> > [ 33.380306] platform_match+0x70/0x1f8
> > [ 33.384168] __driver_attach+0x78/0x3a0
> > [ 33.388111] bus_for_each_dev+0x13c/0x1b8
> > [ 33.392237] driver_attach+0x4c/0x58
> > [ 33.395910] bus_add_driver+0x350/0x560
> > [ 33.399854] driver_register+0x23c/0x328
> > [ 33.403886] __platform_driver_register+0xd0/0xe0
> >
> > So, use dev_name(&pdev->dev), which fetches the platform device name from
> > the kobject(dev->kobj->name) of the device instead of the pdev->name.
> >
> > Signed-off-by: Venkata Narendra Kumar Gutta <vnkgutta@xxxxxxxxxxxxxx>
> > ---
> > drivers/base/platform.c | 8 ++++----
> > 1 file changed, 4 insertions(+), 4 deletions(-)
> > diff --git a/drivers/base/platform.c b/drivers/base/platform.c
> > index dab0a5a..0e23aa2 100644
> > --- a/drivers/base/platform.c
> > +++ b/drivers/base/platform.c
> > @@ -888,7 +888,7 @@ static ssize_t modalias_show(struct device *dev, struct device_attribute *a,
> > if (len != -ENODEV)
> > return len;
> >
> > - len = snprintf(buf, PAGE_SIZE, "platform:%s\n", pdev->name);
> > + len = snprintf(buf, PAGE_SIZE, "platform:%s\n", dev_name(&pdev->dev));
> >
> > return (len >= PAGE_SIZE) ? (PAGE_SIZE - 1) : len;
> > }
> > @@ -964,7 +964,7 @@ static int platform_uevent(struct device *dev, struct kobj_uevent_env *env)
> > return rc;
> >
> > add_uevent_var(env, "MODALIAS=%s%s", PLATFORM_MODULE_PREFIX,
> > - pdev->name);
> > + dev_name(&pdev->dev));
>
> This is wrong fix and it causes ARM Vexpress board fail to boot under
> QEMU (but probably in real world as well). The problem is in not
> mached drivers. For example the pdev->name is "vexpress-syscfg" and
> dev_name(&pdev->dev) is "vexpress-syscfg.6.auto". The effect - none of
> AMBA devices are registered, including missing MMC device (mmci.c,
> arm,pl180).
>
> One can see the error of missing root device:
> [ 13.458982] VFS: Cannot open root device "mmcblk0" or
> unknown-block(0,0): error -6
>
> ... also before there is a warning like:
> [ 0.285029] ------------[ cut here ]------------
> [ 0.285507] WARNING: CPU: 0 PID: 1 at
> /home/krzk/dev/yocto-proceq/build/workspace/sources/linux-mainline-next/drivers/bus/vexpress-config.c:183
> vexpress_config_init+0x90/0xe0
> [ 0.285936] Modules linked in:
> [ 0.286251] CPU: 0 PID: 1 Comm: swapper Tainted: G W
> 5.1.0-rc6-next-20190429-g0593ae1f5df5 #27
> [ 0.286507] Hardware name: ARM-Versatile Express
> [ 0.286977] [<8010e05c>] (unwind_backtrace) from [<8010b76c>]
> (show_stack+0x10/0x14)
> [ 0.287219] [<8010b76c>] (show_stack) from [<8011ac64>] (__warn+0xf8/0x110)
> [ 0.287400] [<8011ac64>] (__warn) from [<8011ad94>]
> (warn_slowpath_null+0x40/0x48)
> [ 0.287579] [<8011ad94>] (warn_slowpath_null) from [<809151bc>]
> (vexpress_config_init+0x90/0xe0)
> [ 0.287811] [<809151bc>] (vexpress_config_init) from [<80102710>]
> (do_one_initcall+0x54/0x1b4)
> [ 0.288014] [<80102710>] (do_one_initcall) from [<80900e84>]
> (kernel_init_freeable+0x12c/0x1c8)
> [ 0.288214] [<80900e84>] (kernel_init_freeable) from [<80634048>]
> (kernel_init+0x8/0x110)
> [ 0.288388] [<80634048>] (kernel_init) from [<801010e8>]
> (ret_from_fork+0x14/0x2c)
> [ 0.288597] Exception stack(0x86835fb0 to 0x86835ff8)
> [ 0.288882] 5fa0: 00000000
> 00000000 00000000 00000000
> [ 0.289193] 5fc0: 00000000 00000000 00000000 00000000 00000000
> 00000000 00000000 00000000
> [ 0.289479] 5fe0: 00000000 00000000 00000000 00000000 00000013 00000000
> [ 0.289776] ---[ end trace 3f0995a2bae83983 ]---

Ick, that's not good, I've now reverted this patch from my tree, thanks
for letting me know.

greg k-h