[PATCH 3.0-rc2] OMAP: ams-delta: fix broken uevent sysfs entries
Felipe Balbi
balbi at ti.com
Wed Jun 15 09:00:08 EDT 2011
Hi,
On Wed, Jun 15, 2011 at 02:53:01PM +0200, Janusz Krzysztofik wrote:
> > to me it sounds like missing __init/__exit annotations on the driver.
> > See ams-delta-leds for instance:
> >
> > static int ams_delta_led_probe(struct platform_device *pdev)
> > static int ams_delta_led_remove(struct platform_device *pdev)
> >
> > which means those drivers will have probe sitting outside or
> > .init.text and trying to reference name which sits in .init.text ???
> > Could that be the case here ?
>
> Missing or not, addig them didn't help.
ok...
> > But it could also be that the platform_device shouldn't be marked
> > __initdata.
>
> After either reverting one of commits mentioned, or applying my patch,
> a read from /sys/devices/platform/ams-delta-led/uevent, for example,
> returns:
>
> DRIVER=ams-delta-led
> MODALIAS=platform:ams-delta-led
>
> The code responsible for returning these strings can be found in
> drivers/base/core.c:
>
> static int dev_uevent(struct kset *kset, struct kobject *kobj,
> struct kobj_uevent_env *env)
> {
> struct device *dev = to_dev(kobj);
> ...
> if (dev->driver)
> add_uevent_var(env, "DRIVER=%s", dev->driver->name);
>
> /* have the bus specific function add its stuff */
> if (dev->bus && dev->bus->uevent) {
> retval = dev->bus->uevent(dev, env);
> ...
>
> The dev->bus->uevent for a platform device happens to sit in
> drivers/base/platform.c:
>
> static int platform_uevent(struct device *dev, struct kobj_uevent_env *env)
> {
> struct platform_device *pdev = to_platform_device(dev);
> ...
> add_uevent_var(env, "MODALIAS=%s%s", PLATFORM_MODULE_PREFIX,
> (pdev->id_entry) ? pdev->id_entry->name : pdev->name);
> ...
>
> For me, it looks like struct kobject, pointed to by kobj, being a member
> of struct device, which in turn happens to be a member of struct
> platform_device.
>
> AFAICU, there exist two sorts of platform devices from memory allocation
> point of view: those created with platform_device_alloc(), which
> allocates a memory where struct platform_device is kept, and those
> created with platfrom_device_add(), which is provided with a pointer to
> an already allocated platform device structure.
>
> I can't find any piece of code which makes a copy of a platfrom deivce
> structure content pointed to while platform_device_add() is called from
> a board or machine file, either directly or indirectly via
> platform_device_register() or platform_add_devices().
> Why should it be actually copied after all?.
true, it makes sense to remove __initdata from the platform_device
structures.
> Searching for an example usage of _initdata similiar to that introduced
> by commit bdc58fb950a3a1b0bc3cbd8e23d21ecdde2ac9a2, "arm: omap1: fix a
> bunch of section mismatches", I can find the following:
>
> $ grep -r "struct .* platform_device .* = {" .|grep "__initdata"|grep -v '*'
> ./arch/arm/mach-omap1/board-ams-delta.c:static struct platform_device ams_delta_kp_device __initdata = {
> ./arch/arm/mach-omap1/board-ams-delta.c:static struct platform_device ams_delta_lcd_device __initdata = {
> ./arch/arm/mach-omap1/board-ams-delta.c:static struct platform_device ams_delta_led_device __initdata = {
> ./arch/arm/mach-omap1/board-ams-delta.c:static struct platform_device ams_delta_camera_device __initdata = {
> ./arch/arm/mach-omap1/gpio7xx.c:static struct __initdata platform_device omap7xx_mpu_gpio = {
> ./arch/arm/mach-omap1/gpio7xx.c:static struct __initdata platform_device omap7xx_gpio1 = {
> ./arch/arm/mach-omap1/gpio7xx.c:static struct __initdata platform_device omap7xx_gpio2 = {
> ./arch/arm/mach-omap1/gpio7xx.c:static struct __initdata platform_device omap7xx_gpio3 = {
> ./arch/arm/mach-omap1/gpio7xx.c:static struct __initdata platform_device omap7xx_gpio4 = {
> ./arch/arm/mach-omap1/gpio7xx.c:static struct __initdata platform_device omap7xx_gpio5 = {
> ./arch/arm/mach-omap1/gpio7xx.c:static struct __initdata platform_device omap7xx_gpio6 = {
> ./arch/arm/mach-omap1/gpio15xx.c:static struct __initdata platform_device omap15xx_mpu_gpio = {
> ./arch/arm/mach-omap1/gpio15xx.c:static struct __initdata platform_device omap15xx_gpio = {
> ./arch/arm/mach-omap1/gpio16xx.c:static struct __initdata platform_device omap16xx_mpu_gpio = {
> ./arch/arm/mach-omap1/gpio16xx.c:static struct __initdata platform_device omap16xx_gpio1 = {
> ./arch/arm/mach-omap1/gpio16xx.c:static struct __initdata platform_device omap16xx_gpio2 = {
> ./arch/arm/mach-omap1/gpio16xx.c:static struct __initdata platform_device omap16xx_gpio3 = {
> ./arch/arm/mach-omap1/gpio16xx.c:static struct __initdata platform_device omap16xx_gpio4 = {
> ./arch/arm/mach-omap2/board-rx51-peripherals.c:static struct platform_device rx51_si4713_dev __initdata_or_module = {
>
> So, there is no single exact pattern found in the whole tree, and a few
> instances of similiar patterns of two kinds found only inside omap. If I
> follow any of the two, either moving '__initdata' in front of
> 'platform_device' or using '__initdata_or_module' instead, the problem
> no longer hits me (using my custom defconfig). However, the former seems
> not conformant to what one can learn from include/linux/init.h, so I
> suspect that placing __initdata like this can be a noop, while the
> latter means "can be init if no module support", which would probably
> still exhibit the problem if so configured.
>
> How would you like to have this corrected then?
I guess removing __initdata from all platoform_device structures is the
way to go. We need to find another way to silent the section mismatch
warnings.
--
balbi
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 490 bytes
Desc: Digital signature
URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20110615/28fc8be4/attachment.sig>
More information about the linux-arm-kernel
mailing list