mirror of
https://gitlab.freedesktop.org/mesa/drm.git
synced 2025-12-20 02:20:15 +01:00
amdgpu: add handle table implementation v2
The kernel handles are dense and the kernel always tries to use the
lowest free id. Use this to implement a more efficient handle table
by using a resizeable array instead of a hash.
v2: add handle_table_fini function, extra key checks,
fix typo in function name
Signed-off-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
Reviewed-and-Tested-by: Junwei Zhang <Jerry.Zhang@amd.com>
This commit is contained in:
parent
7aa1a51133
commit
52370cc6eb
3 changed files with 116 additions and 1 deletions
|
|
@ -10,7 +10,9 @@ LIBDRM_AMDGPU_FILES := \
|
|||
util_hash.c \
|
||||
util_hash.h \
|
||||
util_hash_table.c \
|
||||
util_hash_table.h
|
||||
util_hash_table.h \
|
||||
handle_table.c \
|
||||
handle_table.h
|
||||
|
||||
LIBDRM_AMDGPU_H_FILES := \
|
||||
amdgpu.h
|
||||
|
|
|
|||
72
amdgpu/handle_table.c
Normal file
72
amdgpu/handle_table.c
Normal file
|
|
@ -0,0 +1,72 @@
|
|||
/*
|
||||
* Copyright 2018 Advanced Micro Devices, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
*/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <errno.h>
|
||||
#include <unistd.h>
|
||||
#include "handle_table.h"
|
||||
#include "util_math.h"
|
||||
|
||||
drm_private int handle_table_insert(struct handle_table *table, uint32_t key,
|
||||
void *value)
|
||||
{
|
||||
if (key >= table->max_key) {
|
||||
uint32_t alignment = sysconf(_SC_PAGESIZE) / sizeof(void*);
|
||||
uint32_t max_key = ALIGN(key, alignment);
|
||||
void **values;
|
||||
|
||||
values = realloc(table->values, max_key * sizeof(void *));
|
||||
if (!values)
|
||||
return -ENOMEM;
|
||||
|
||||
memset(values + table->max_key, 0, (max_key - table->max_key) *
|
||||
sizeof(void *));
|
||||
|
||||
table->max_key = max_key;
|
||||
table->values = values;
|
||||
}
|
||||
table->values[key] = value;
|
||||
return 0;
|
||||
}
|
||||
|
||||
drm_private void handle_table_remove(struct handle_table *table, uint32_t key)
|
||||
{
|
||||
if (key < table->max_key)
|
||||
table->values[key] = NULL;
|
||||
}
|
||||
|
||||
drm_private void *handle_table_lookup(struct handle_table *table, uint32_t key)
|
||||
{
|
||||
if (key < table->max_key)
|
||||
return table->values[key];
|
||||
else
|
||||
return NULL;
|
||||
}
|
||||
|
||||
drm_private void handle_table_fini(struct handle_table *table)
|
||||
{
|
||||
free(table->values);
|
||||
table->max_key = 0;
|
||||
table->values = NULL;
|
||||
}
|
||||
41
amdgpu/handle_table.h
Normal file
41
amdgpu/handle_table.h
Normal file
|
|
@ -0,0 +1,41 @@
|
|||
/*
|
||||
* Copyright 2018 Advanced Micro Devices, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef _HANDLE_TABLE_H_
|
||||
#define _HANDLE_TABLE_H_
|
||||
|
||||
#include <stdint.h>
|
||||
#include "libdrm_macros.h"
|
||||
|
||||
struct handle_table {
|
||||
uint32_t max_key;
|
||||
void **values;
|
||||
};
|
||||
|
||||
drm_private int handle_table_insert(struct handle_table *table, uint32_t key,
|
||||
void *value);
|
||||
drm_private void handle_table_remove(struct handle_table *table, uint32_t key);
|
||||
drm_private void *handle_table_lookup(struct handle_table *table, uint32_t key);
|
||||
drm_private void handle_table_fini(struct handle_table *table);
|
||||
|
||||
#endif /* _HANDLE_TABLE_H_ */
|
||||
Loading…
Add table
Reference in a new issue