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

From: Alex Williamson
Date: Tue Sep 21 2004 - 15:41:37 EST


On Tue, 2004-09-21 at 21:58 +0200, Pavel Machek wrote:
> Hi!
>
> > > > All pointers are actually interpreted as offsets into the buffer for
> > > > this interface. They are not actually pointers. I believe the 32bit
> > > > emulation problem is limited to an ILP32 application generating data
> > > > structures appropriate for an LP64 kernel. While difficult, it can be
> > > > done.
> > >
> > > If this involves patching the application - no it cannot be done.
> > > The 64bit kernel is supposed to run vanilla 32bit user land.
> > >
> > > Please find some other solution for this. An ioctl doesn't sound that bad.
> >
> > Please read the rest of my response to Pavel, I don't think we're on
> > the same page as to the extent of this problem. There is no application
> > yet, we're in the process of architecting the interface to it right now.
> > Is it impossible to expect an ILP32 application to generate LP64 data
> > structures? Perhaps the LP64 kernel interface could be made smart
> > enough to digest ILP32 data structures as Arjan suggests.
>
> You can be pretty sure someone, somewhere will bypass that library,
> hardcode types into application, and break it on 64-bit platform.

Ok, I'll try to prototype something that uses data model independent
structures. Using the kernel headers was convenient, but probably not
advisable.

> If I were you, I'd just replace read and write with ioctl, and leave
> the rest of design as it was. If we find that someone who bypasses
> your userspace library, at least we have a way to deal with it. (And
> "cat a file and kill machine" issue is gone, too).

Again, I don't think that solves the problem (and there's no ioctl
support in sysfs). The pointer in the command structure is easy to work
around, nothing uses it and data could easily be stuffed after the
architected entries. Switching to an ioctl would not solve the problem
of passing ACPI data back and forth. We don't just want to execute
methods, we want to be able to provide arguments and get data back.
That data is where I see the biggest 32/64 bit issue. I'll switch to an
evaluate on write model, but I'm not sold that an ioctl would solve
enough problems to be worth it. Is anyone even open to adding ioctls to
sysfs bin files? 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/