Re: [ACPI] Re: [PATCH/RFC] exposing ACPI objects in sysfs

From: Alex Williamson
Date: Fri Oct 15 2004 - 17:41:10 EST



Back for another round of discussions... We last left this at:

* The acpi_sysfs evaluate on read interface has problems (imagine
tar'ing up /sys/firmware/acpi...)
* No support for 32 bit apps on 64 bit kernels.

I played around with an evaluate on write approach, but couldn't come
up with anything I liked. I decided to go back to the ioctl dev_acpi
approach I proposed a few months ago. It's unfortunate that dev_acpi
doesn't take advantage of the sysfs namespace, but overall I think its
more functional. For instance, the sysfs interface didn't allow
operations on ACPI devices because they show up as directories in sysfs.
This isn't an issue with dev_acpi. I should have written up some new
documentation on dev_acpi, but the theory of operation hasn't changed
that much since my original post here:

http://groups.google.com/groups?selm=2paXA-7Li-7%40gated-at.bofh.it

Essentially, it boils down to write(2) parameters (if necessary),
ioctl(2) with a command and a structure containing ACPI path and return
buffer size, read(2) data returned (if any). I don't think I can
transfer all the data in the ioctl, the data structures are just too
complex. The ioctl now clearly defines the point at which we're
operating on ACPI namespace.

I finally got hit by the clue bat of what Andi was trying to describe
with the compatibility layer and found the ioctl32_conversion interface.
I've made use of these to allow a 32bit application to read and write
32bit data structures into the device file. Prior to calling into ACPI,
the ioctl32 interface converts the write data to native structures. On
the other side, native structures are converted to their 32bit
equivalent and stored in the read buffer. I've successfully run a 32bit
x86 binary of my test program on an ia64 system using this interface.

I've been building dev_acpi as a standalone module, so the makefiles
and test program are a little large for the mailing list. The current
revision is available here:

http://free.linux.hp.com/~awilliam/acpi/dev_acpi/dev_acpi-20041015.tar.bz2

(Sorry, the makefile is rather kludgey, but should be easy to get
working given a path to kernel source) I haven't tested much of the
32->64 bit compatibility path, but the 64->32 side seems to work fine.
The provided test program (acpitree) provides a tree listing of ACPI
namespace with the object type listed next to the name. Values of
strings and integers will be printed along with raw dumps of select
other "safe" objects. Standard disclaimers apply, this is all
development code. The driver could stand a good round or two of code
cleanup and far more testing, but I wanted to get some feedback on this
approach before spending too much time on it. Please take a look and
let me know what you think. Thanks,

Alex

--
Alex Williamson HP Linux & Open Source Lab

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/