Hello Rui, Thank you for adding me to the cc. * Zhang Rui <rui.zhang@xxxxxxxxx>: > cc Alex Chiang. > > On Tue, 2010-10-26 at 10:06 +0800, Zhang Rui wrote: > > ACPI table sysfs I/F is broken by commit > > > > 78f1699659963fff97975df44db6d5dbe7218e55 > > Author: Alex Chiang <achiang@xxxxxx> > > Date: Sun Dec 20 12:19:09 2009 -0700 > > ACPI: processor: call _PDC early > > > > because dynamic SSDT tables may be loaded in _PDC, > > before installing the ACPI table handler. > > As a result, the sysfs I/F of these dynamic tables are > > located at /sys/firmware/acpi/tables instead of > > /sys/firmware/acpi/tables/dynamic, which is not true. > > > > Invoke acpi_sysfs_init() before acpi_early_processor_set_pdc(), > > so that the table handler is installed before any dynamic tables loaded. You are right; I wasn't careful when I wrote 78f169965996, and forgot to verify that dynamically loaded tables should appear in /sys/firmware/acpi/tables/dynamic. I see that the interface was introduced by 4658e4ef9d252 in February 2009, so I should have been aware of it. I think it will be easier for future developers to be aware of the ACPI sysfs interfaces if they were documented. I see that the file Documentation/ABI/testing/sysfs-firmware-acpi exists, but does not describe many of the interfaces in sysfs. Do you want to write a documentation patch, or shall I? Also, I think Bjorn had some opinions on acpi_early_processor_set_pdc(): https://bugzilla.kernel.org/show_bug.cgi?id=14824#c7 Your current patch is fine for fixing the immediate problem you notice, but perhaps you should explore the ideas that Bjorn wrote in his last comment, and then we can get rid of this ugly bit altogether. Acked-by: Alex Chiang <achiang@xxxxxxxxxxxxx> Thanks, /ac > > > > https://bugzilla.kernel.org/show_bug.cgi?id=21142 > > > > CC: Dennis Jansen <dennis.jansen@xxxxxx> > > CC: Alex Chiang <achiang@xxxxxx> > > Signed-off-by: Zhang Rui <rui.zhang@xxxxxxxxx> > > --- > > drivers/acpi/bus.c | 7 ++++++- > > 1 file changed, 6 insertions(+), 1 deletion(-) > > > > Index: linux-2.6/drivers/acpi/bus.c > > =================================================================== > > --- linux-2.6.orig/drivers/acpi/bus.c > > +++ linux-2.6/drivers/acpi/bus.c > > @@ -935,6 +935,12 @@ static int __init acpi_bus_init(void) > > goto error1; > > } > > > > + /* > > + * _PDC control method may load dynamic SSDT tables, > > + * and we need to install the table handler before that. > > + */ > > + acpi_sysfs_init(); > > + > > acpi_early_processor_set_pdc(); > > > > /* > > @@ -1026,7 +1032,6 @@ static int __init acpi_init(void) > > acpi_scan_init(); > > acpi_ec_init(); > > acpi_power_init(); > > - acpi_sysfs_init(); > > acpi_debugfs_init(); > > acpi_sleep_proc_init(); > > acpi_wakeup_device_init(); > > > > > > -- > > To unsubscribe from this list: send the line "unsubscribe linux-acpi" in > > the body of a message to majordomo@xxxxxxxxxxxxxxx > > More majordomo info at http://vger.kernel.org/majordomo-info.html > > -- To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html