From ebc540f1db98a7826653ec1e2c7f4199f637ebeb Mon Sep 17 00:00:00 2001 From: Dmitry Torokhov Date: Tue, 18 Sep 2007 22:46:50 -0700 Subject: [PATCH] --- yaml --- r: 65037 b: refs/heads/master c: 4f01a757e75f2a3cab2bab89c4176498963946b9 h: refs/heads/master i: 65035: 4f6fd67deef0ba0d85259d145a4db67eabbee1fe v: v3 --- [refs] | 2 +- trunk/drivers/base/core.c | 29 +++++++++++++++++++++++------ 2 files changed, 24 insertions(+), 7 deletions(-) diff --git a/[refs] b/[refs] index 7b94c9b793e1..07b6356fda40 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 508a92741a105e2e3d466cd727fb73154ebf08de +refs/heads/master: 4f01a757e75f2a3cab2bab89c4176498963946b9 diff --git a/trunk/drivers/base/core.c b/trunk/drivers/base/core.c index e6738bcbe5a9..6de33d7a29ba 100644 --- a/trunk/drivers/base/core.c +++ b/trunk/drivers/base/core.c @@ -679,14 +679,26 @@ static int device_add_class_symlinks(struct device *dev) goto out_subsys; } if (dev->parent) { - error = sysfs_create_link(&dev->kobj, &dev->parent->kobj, - "device"); - if (error) - goto out_busid; #ifdef CONFIG_SYSFS_DEPRECATED { - char * class_name = make_class_name(dev->class->name, - &dev->kobj); + struct device *parent = dev->parent; + char *class_name; + + /* + * In old sysfs stacked class devices had 'device' + * link pointing to real device instead of parent + */ + while (parent->class && !parent->bus && parent->parent) + parent = parent->parent; + + error = sysfs_create_link(&dev->kobj, + &parent->kobj, + "device"); + if (error) + goto out_busid; + + class_name = make_class_name(dev->class->name, + &dev->kobj); if (class_name) error = sysfs_create_link(&dev->parent->kobj, &dev->kobj, class_name); @@ -694,6 +706,11 @@ static int device_add_class_symlinks(struct device *dev) if (error) goto out_device; } +#else + error = sysfs_create_link(&dev->kobj, &dev->parent->kobj, + "device"); + if (error) + goto out_busid; #endif } return 0;