ACPICA: Add macros to access pointer to next object in the descriptor list
authorJung-uk Kim <jkim@FreeBSD.org>
Fri, 8 Mar 2013 09:21:54 +0000 (09:21 +0000)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Mon, 11 Mar 2013 23:45:04 +0000 (00:45 +0100)
Signed-off-by: Jung-uk Kim <jkim@FreeBSD.org>
Signed-off-by: Bob Moore <robert.moore@intel.com>
Signed-off-by: Lv Zheng <lv.zheng@intel.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/acpi/acpica/acmacros.h
drivers/acpi/acpica/utcache.c

index ed7943b9044f997fbe5b53e3012694bbe1318062..8b7ca40c4eb5b4c61ee7518caad3c91a326690be 100644 (file)
  * where a pointer to an object of type union acpi_operand_object can also
  * appear. This macro is used to distinguish them.
  *
- * The "Descriptor" field is the first field in both structures.
+ * The "DescriptorType" field is the second field in both structures.
  */
+#define ACPI_GET_DESCRIPTOR_PTR(d)      (((union acpi_descriptor *)(void *)(d))->common.common_pointer)
+#define ACPI_SET_DESCRIPTOR_PTR(d, o)   (((union acpi_descriptor *)(void *)(d))->common.common_pointer = o)
 #define ACPI_GET_DESCRIPTOR_TYPE(d)     (((union acpi_descriptor *)(void *)(d))->common.descriptor_type)
 #define ACPI_SET_DESCRIPTOR_TYPE(d, t)  (((union acpi_descriptor *)(void *)(d))->common.descriptor_type = t)
 
index 2de22fbacf4b5b99da87a91e78d2a65e5b83784e..a877a9647fd97648f64bceea44611cc9f136cdee 100644 (file)
@@ -127,9 +127,7 @@ acpi_status acpi_os_purge_cache(struct acpi_memory_list * cache)
 
                /* Delete and unlink one cached state object */
 
-               next =
-                   ((struct acpi_object_common *)cache->list_head)->
-                   next_object;
+               next = ACPI_GET_DESCRIPTOR_PTR(cache->list_head);
                ACPI_FREE(cache->list_head);
 
                cache->list_head = next;
@@ -219,8 +217,7 @@ acpi_os_release_object(struct acpi_memory_list * cache, void *object)
 
                /* Put the object at the head of the cache list */
 
-               ((struct acpi_object_common *)object)->next_object =
-                   cache->list_head;
+               ACPI_SET_DESCRIPTOR_PTR(object, cache->list_head);
                cache->list_head = object;
                cache->current_depth++;
 
@@ -268,8 +265,7 @@ void *acpi_os_acquire_object(struct acpi_memory_list *cache)
                /* There is an object available, use it */
 
                object = cache->list_head;
-               cache->list_head =
-                   ((struct acpi_object_common *)object)->next_object;
+               cache->list_head = ACPI_GET_DESCRIPTOR_PTR(object);
 
                cache->current_depth--;