diff options
author | Matt Turner <[email protected]> | 2014-06-25 10:51:30 -0700 |
---|---|---|
committer | Matt Turner <[email protected]> | 2014-07-01 08:55:51 -0700 |
commit | d6bb8bb7ce50dfec83e6be88fc21bb63315d516a (patch) | |
tree | 6e60593a9186998cc0820f15ac706936c7a2f527 | |
parent | 22cd9173295e2212e355db514bfc52138d03079d (diff) |
mesa: Add and use foreach_list_typed_safe.
Acked-by: Ian Romanick <[email protected]>
-rw-r--r-- | src/glsl/list.h | 9 | ||||
-rw-r--r-- | src/mesa/drivers/dri/i965/intel_mipmap_tree.c | 4 |
2 files changed, 10 insertions, 3 deletions
diff --git a/src/glsl/list.h b/src/glsl/list.h index 77e3aaf26e4..b7221cb7c7f 100644 --- a/src/glsl/list.h +++ b/src/glsl/list.h @@ -630,4 +630,13 @@ inline void exec_node::insert_before(exec_list *before) (__node)->__field.next != NULL; \ (__node) = exec_node_data(__type, (__node)->__field.next, __field)) +#define foreach_list_typed_safe(__type, __node, __field, __list) \ + for (__type * __node = \ + exec_node_data(__type, (__list)->head, __field), \ + * __next = \ + exec_node_data(__type, (__node)->__field.next, __field); \ + __next != NULL; \ + __node = __next, __next = \ + exec_node_data(__type, (__next)->__field.next, __field)) + #endif /* LIST_CONTAINER_H */ diff --git a/src/mesa/drivers/dri/i965/intel_mipmap_tree.c b/src/mesa/drivers/dri/i965/intel_mipmap_tree.c index a45f1dd0404..07e798264a4 100644 --- a/src/mesa/drivers/dri/i965/intel_mipmap_tree.c +++ b/src/mesa/drivers/dri/i965/intel_mipmap_tree.c @@ -1506,9 +1506,7 @@ intel_miptree_all_slices_resolve(struct brw_context *brw, { bool did_resolve = false; - foreach_list_safe(node, &mt->hiz_map) { - struct intel_resolve_map *map = (struct intel_resolve_map *)node; - + foreach_list_typed_safe(struct intel_resolve_map, map, link, &mt->hiz_map) { if (map->need != need) continue; |