Re: [PATCH] ACPI: install ACPI table handler before any dynamic tables being loaded

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, 2010-10-26 at 13:06 +0800, Alex Chiang wrote:
> 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?
> 
good point. Yes, I'll update the Documentation. :)

> 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.
> 
agree. Making clear how EC works in windows is really helpful, not only
for this problem but also for other EC bugs as well.
As Alexey may not longer work on ACPI EC driver, I'll take a look at the
EC code and do some investigation on this area.

thanks,
rui

> 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


[Index of Archives]     [Linux IBM ACPI]     [Linux Power Management]     [Linux Kernel]     [Linux Laptop]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Video 4 Linux]     [Device Mapper]     [Linux Resources]

  Powered by Linux