From mboxrd@z Thu Jan 1 00:00:00 1970 From: Daniel Drake Date: Tue, 06 Nov 2007 17:51:22 +0000 Subject: Re: usb_id segfaulting on 2.6.23 Message-Id: <4730A99A.3010809@gentoo.org> MIME-Version: 1 Content-Type: multipart/mixed; boundary="------------000504080007010803020301" List-Id: References: <47135D33.7080805@gentoo.org> In-Reply-To: <47135D33.7080805@gentoo.org> To: linux-hotplug@vger.kernel.org This is a multi-part message in MIME format. --------------000504080007010803020301 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Alan Stern wrote: > Ah, okay. This is a known problem, a configuration-related issue. > The PM core doesn't create a device's /sys/.../power subdirectory > unless CONFIG_PM_SLEEP is set. In fact it should be created whenever > CONFIG_PM is set. > > I haven't had time to write a patch for this yet. Do you want to try? OK. Any comments on this before I sent it to the proper channels? Thanks, Daniel --------------000504080007010803020301 Content-Type: text/plain; name="power-sysfs.patch" Content-Transfer-Encoding: 7bit Content-Disposition: inline; filename="power-sysfs.patch" From: Daniel Drake Index: linux-2.6.24-rc1-git14/drivers/base/core.c =================================================================== --- linux-2.6.24-rc1-git14.orig/drivers/base/core.c +++ linux-2.6.24-rc1-git14/drivers/base/core.c @@ -770,6 +770,9 @@ int device_add(struct device *dev) error = device_add_attrs(dev); if (error) goto AttrsError; + error = dpm_sysfs_add(dev); + if (error) + goto PMsysfsError; error = device_pm_add(dev); if (error) goto PMError; @@ -797,11 +800,13 @@ int device_add(struct device *dev) return error; BusError: device_pm_remove(dev); - PMError: + PMsysfsError: if (dev->bus) blocking_notifier_call_chain(&dev->bus->bus_notifier, BUS_NOTIFY_DEL_DEVICE, dev); device_remove_attrs(dev); + PMError: + dpm_sysfs_remove(dev); AttrsError: device_remove_class_symlinks(dev); SymlinkError: Index: linux-2.6.24-rc1-git14/drivers/base/power/Makefile =================================================================== --- linux-2.6.24-rc1-git14.orig/drivers/base/power/Makefile +++ linux-2.6.24-rc1-git14/drivers/base/power/Makefile @@ -1,5 +1,6 @@ obj-y := shutdown.o -obj-$(CONFIG_PM_SLEEP) += main.o sysfs.o +obj-$(CONFIG_PM) += sysfs.o +obj-$(CONFIG_PM_SLEEP) += main.o obj-$(CONFIG_PM_TRACE) += trace.o ifeq ($(CONFIG_DEBUG_DRIVER),y) Index: linux-2.6.24-rc1-git14/drivers/base/power/power.h =================================================================== --- linux-2.6.24-rc1-git14.orig/drivers/base/power/power.h +++ linux-2.6.24-rc1-git14/drivers/base/power/power.h @@ -21,6 +21,22 @@ static inline struct device * to_device( extern int device_pm_add(struct device *); extern void device_pm_remove(struct device *); +#else /* CONFIG_PM_SLEEP */ + + +static inline int device_pm_add(struct device * dev) +{ + return 0; +} +static inline void device_pm_remove(struct device * dev) +{ + +} + +#endif + +#ifdef CONFIG_PM + /* * sysfs.c */ @@ -28,16 +44,16 @@ extern void device_pm_remove(struct devi extern int dpm_sysfs_add(struct device *); extern void dpm_sysfs_remove(struct device *); -#else /* CONFIG_PM_SLEEP */ - +#else /* CONFIG_PM */ -static inline int device_pm_add(struct device * dev) +static inline int dpm_sysfs_add(struct device * dev) { return 0; } -static inline void device_pm_remove(struct device * dev) +static inline void dpm_sysfs_remove(struct device * dev) { } -#endif +#endif /* CONFIG_PM */ + --------------000504080007010803020301 Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Content-Disposition: inline ------------------------------------------------------------------------- This SF.net email is sponsored by: Splunk Inc. Still grepping through log files to find problems? Stop. Now Search log events and configuration files using AJAX and a browser. Download your FREE copy of Splunk now >> http://get.splunk.com/ --------------000504080007010803020301 Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Content-Disposition: inline _______________________________________________ Linux-hotplug-devel mailing list http://linux-hotplug.sourceforge.net Linux-hotplug-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/linux-hotplug-devel --------------000504080007010803020301--