summaryrefslogtreecommitdiff
path: root/src/util/ralloc.c
diff options
context:
space:
mode:
authorCaio Oliveira <caio.oliveira@intel.com>2023-09-17 19:15:42 -0700
committerMarge Bot <emma+marge@anholt.net>2023-09-25 17:26:17 +0000
commit4519421db5f9863d380994cedafcd489ade9d715 (patch)
tree3bb56c06944651488bf0cf942e67361a8caa84b5 /src/util/ralloc.c
parent6764689e0e4f967039b9c77c729c9389ed42ac11 (diff)
downloadmesa-4519421db5f9863d380994cedafcd489ade9d715.tar.gz
mesa-4519421db5f9863d380994cedafcd489ade9d715.tar.bz2
mesa-4519421db5f9863d380994cedafcd489ade9d715.zip
util: Use linear parent to (r)allocated extra nodes
Instead of making all the nodes children of the same original ralloc_ctx, use that context just for the first node (which is the linear parent). The remaining nodes are (r)allocated using the first one. With that change, to free/steal, it is sufficient to apply the operation to the first node, which uses the underlying linked list between the nodes at ralloc level. And we can remove the 'next' pointer in linear_header, now unused. Reviewed-by: Marek Olšák <marek.olsak@amd.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/25280>
Diffstat (limited to 'src/util/ralloc.c')
-rw-r--r--src/util/ralloc.c35
1 files changed, 10 insertions, 25 deletions
diff --git a/src/util/ralloc.c b/src/util/ralloc.c
index cb5dcaa34a6..278d67115c1 100644
--- a/src/util/ralloc.c
+++ b/src/util/ralloc.c
@@ -948,8 +948,7 @@ gc_sweep_end(gc_ctx *ctx)
*
* The allocator uses a fixed-sized buffer with a monotonically increasing
* offset after each allocation. If the buffer is all used, another buffer
- * is allocated, sharing the same ralloc parent, so all buffers are at
- * the same level in the ralloc hierarchy.
+ * is allocated, using the linear parent node as ralloc parent.
*
* The linear parent node is always the first buffer and keeps track of all
* other buffers.
@@ -968,7 +967,6 @@ struct linear_header {
#endif
unsigned offset; /* points to the first unused byte in the buffer */
unsigned size; /* size of the buffer */
- struct linear_header *next; /* next buffer if we have more */
struct linear_header *latest; /* the only buffer that has free space */
/* After this structure, the buffer begins.
@@ -1017,7 +1015,6 @@ create_linear_node(void *ralloc_ctx, unsigned min_size)
#endif
node->offset = 0;
node->size = min_size;
- node->next = NULL;
node->latest = node;
return node;
}
@@ -1032,21 +1029,19 @@ linear_alloc_child(void *parent, unsigned size)
unsigned full_size;
assert(first->magic == LMAGIC);
- assert(!latest->next);
size = ALIGN_POT(size, SUBALLOC_ALIGNMENT);
full_size = sizeof(linear_size_chunk) + size;
if (unlikely(latest->offset + full_size > latest->size)) {
/* allocate a new node */
- void *ralloc_ctx = ralloc_parent_of_linear_parent(parent);
+ void *ralloc_ctx = first;
new_node = create_linear_node(ralloc_ctx, size);
if (unlikely(!new_node))
return NULL;
first->latest = new_node;
latest->latest = new_node;
- latest->next = new_node;
latest = new_node;
}
@@ -1100,37 +1095,27 @@ linear_zalloc_parent(void *parent, unsigned size)
void
linear_free_parent(void *ptr)
{
- linear_header *node;
-
if (unlikely(!ptr))
return;
- node = LINEAR_PARENT_TO_HEADER(ptr);
- assert(node->magic == LMAGIC);
-
- while (node) {
- void *ptr = node;
+ linear_header *first = LINEAR_PARENT_TO_HEADER(ptr);
+ assert(first->magic == LMAGIC);
- node = node->next;
- ralloc_free(ptr);
- }
+ /* Other nodes are ralloc children of the first node. */
+ ralloc_free(first);
}
void
ralloc_steal_linear_parent(void *new_ralloc_ctx, void *ptr)
{
- linear_header *node;
-
if (unlikely(!ptr))
return;
- node = LINEAR_PARENT_TO_HEADER(ptr);
- assert(node->magic == LMAGIC);
+ linear_header *first = LINEAR_PARENT_TO_HEADER(ptr);
+ assert(first->magic == LMAGIC);
- while (node) {
- ralloc_steal(new_ralloc_ctx, node);
- node = node->next;
- }
+ /* Other nodes are ralloc children of the first node. */
+ ralloc_steal(new_ralloc_ctx, first);
}
void *