I may not quite understand what you are asking for, but I will try. It seems like we already have much of what you want/need, so maybe I'm missing something. > So what I would like to have, in general terms, is something like > acpi_walk_resources() split into three parts: > > (1) One that processes the _CRS output and creates a list of > struct acpi_resource objects for us to play with. I suppose > it's OK if that's just a buffer filled with resource objects, > but a linked list might be more convenient. > This sounds like AcpiGetCurrentResources. It executes _CRS and formats the data into acpi_resource objects. > (2) One that allows us to access (read/write) resources in the > list returned by (1). We don't need to open code walking > the list and I probably wouldn't event want to do that. What > we need is to be able to walk the same list for a number of > times and possibly to modify values in the resource objects > if there are conflicts. This sounds like AcpiWalkResources. I suppose a possible issue is that currently, AcpiWalkResources actually invokes the _CRS, _PRS, or _AEI method on behalf of the caller. It might make more sense to allow the caller to pass in the resource buffer returned from a call to _CRS, etc. > > (3) One allowing us to free the list returned by (1) if not needed > any more. > AcpiGetCurrentResources: Currently, everything is returned in a single buffer to minimize the number of allocations. A buffer you can free when you are done with it. I think I saw where you mentioned that you cannot copy this buffer because of internal pointers to other areas of the buffer. Yes. However, we can build linked lists all day if you really want them :-) > And it would be great if we could take the list returned by (1), modify > the resources in it and feed it back to _SRS (after conversion back to the > format that _SRS understands). > AcpiSetCurrentResources. The AML debugger already has a command that illustrates the use of the various resource interfaces, see dbcmds.c > Thanks, > Rafael Bob > -----Original Message----- > From: Rafael J. Wysocki [mailto:rjw@xxxxxxx] > Sent: Tuesday, November 13, 2012 12:44 PM > To: Moore, Robert > Cc: Mika Westerberg; mathias.nyman@xxxxxxxxxxxxxxx; linux- > acpi@xxxxxxxxxxxxxxx; linux-kernel@xxxxxxxxxxxxxxx; lenb@xxxxxxxxxx; > Wysocki, Rafael J; broonie@xxxxxxxxxxxxxxxxxxxxxxxxxxx; > grant.likely@xxxxxxxxxxxx; linus.walleij@xxxxxxxxxx; khali@xxxxxxxxxxxx; > Bjorn Helgaas; Zheng, Lv > Subject: Re: [PATCH 3/3] ACPI: Evaluate _CRS while creating device node > objects > > On Tuesday, November 13, 2012 04:34:07 PM Moore, Robert wrote: > > > I suppose we can just do acpi_get_current_resources() and play with > > > the buffer returned by it. That won't be nice, but still better > > > than what we have. > > > > A couple of the reasons we created the ACPICA resource manager was to: > > 1) Simplify host access to the various resource fields, especially > packed flags. > > 2) Avoid alignment issues, especially on machines that don't support > misaligned transfers. > > That's fine. > > > If there are issues with the current resource manager, we can discuss > them. > > But I would hope that you really don't want to be fussing around with > > the raw data coming back from the AML. > > No, I don't. :-) > > I'd like to be able to do more things with struct acpi_resource objects. > > Pretty much the output of acpi_get_current_resources() is what I'm > interested in, but there doesn't seem to be any convenient way to access > things in the return buffer from the outside of ACPICA now. > > > It is not pretty and we have gone to some lengths to make the entire > > conversion table-driven to minimize bugs and simplify maintenance. > > OK > > So what I would like to have, in general terms, is something like > acpi_walk_resources() split into three parts: > > (1) One that processes the _CRS output and creates a list of > struct acpi_resource objects for us to play with. I suppose > it's OK if that's just a buffer filled with resource objects, > but a linked list might be more convenient. > > (2) One that allows us to access (read/write) resources in the > list returned by (1). We don't need to open code walking > the list and I probably wouldn't event want to do that. What > we need is to be able to walk the same list for a number of > times and possibly to modify values in the resource objects > if there are conflicts. > > (3) One allowing us to free the list returned by (1) if not needed > any more. > > And it would be great if we could take the list returned by (1), modify > the resources in it and feed it back to _SRS (after conversion back to the > format that _SRS understands). > > Thanks, > Rafael > > > > > -----Original Message----- > > > From: Mika Westerberg [mailto:mika.westerberg@xxxxxxxxxxxxxxx] > > > Sent: Monday, November 12, 2012 11:12 PM > > > To: Rafael J. Wysocki > > > Cc: mathias.nyman@xxxxxxxxxxxxxxx; linux-acpi@xxxxxxxxxxxxxxx; > > > linux- kernel@xxxxxxxxxxxxxxx; lenb@xxxxxxxxxx; Wysocki, Rafael J; > > > broonie@xxxxxxxxxxxxxxxxxxxxxxxxxxx; grant.likely@xxxxxxxxxxxx; > > > linus.walleij@xxxxxxxxxx; khali@xxxxxxxxxxxx; Bjorn Helgaas; Moore, > > > Robert > > > Subject: Re: [PATCH 3/3] ACPI: Evaluate _CRS while creating device > > > node objects > > > > > > On Mon, Nov 12, 2012 at 10:03:56PM +0100, Rafael J. Wysocki wrote: > > > > > > +static acpi_status acpi_bus_add_resource(struct acpi_resource > *res, > > > > > > + void *context) > > > > > > +{ > > > > > > + struct list_head *list = context; > > > > > > + struct acpi_resource_list_entry *entry; > > > > > > + > > > > > > + entry = kzalloc(sizeof(*entry), GFP_KERNEL); > > > > > > + if (!entry) > > > > > > + return AE_NO_MEMORY; > > > > > > + > > > > > > + entry->resource = *res; > > > > > > > > > > This does not work well with all resource types - specifically > > > > > those that contain pointers, like acpi_resource_gpio and > > > acpi_resource_source. > > > > > > > > Good point. > > > > > > > > Well, this pretty much means we can't copy those things. > > > > > > Yeah. I only noticed this yesterday when I tested the GPIO > > > translation in a custom driver (since it uses the acpi_resource_gpio). > > > > > > > > The memory for the resources gets freed once > > > > > acpi_walk_resources() is > > > done. > > > > > > > > I know that. > > > > > > > > Having to evaluate _CRS and creating a buffer, converting the > > > > output into ACPI resources and so on every time we need to look > > > > into the device's current resources is totally inefficient. We > > > > _need_ to cache > > > the _CRS output. > > > > > > I agree and besides having adev->resources is much easier to use > > > than calling acpi_walk_resources() everytime. > > > > > > > Now, because of the pointers in certain types of resources, we > > > > can't make copies of the resource objects used by > > > > acpi_walk_resources() which makes that function totally unuseful to > us. > > > > > > > > I suppose we can just do acpi_get_current_resources() and play > > > > with the buffer returned by it. That won't be nice, but still > > > > better than what we have. > > > > > > I don't know any better option. > > > > > > Thanks. > > > -- > I speak only for myself. > Rafael J. Wysocki, Intel Open Source Technology Center. ��.n��������+%������w��{.n�����{�����ܨ}���Ơz�j:+v�����w����ޙ��&�)ߡ�a����z�ޗ���ݢj��w�f