git: eae90cac000e - 2024Q4 - graphics/mesa-devel: switch to upstream mremap fix
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Tue, 12 Nov 2024 00:21:31 UTC
The branch 2024Q4 has been updated by jbeich: URL: https://cgit.FreeBSD.org/ports/commit/?id=eae90cac000e958637e96902a8ce3f13e8bd4ae9 commit eae90cac000e958637e96902a8ce3f13e8bd4ae9 Author: Jan Beich <jbeich@FreeBSD.org> AuthorDate: 2024-11-12 00:13:35 +0000 Commit: Jan Beich <jbeich@FreeBSD.org> CommitDate: 2024-11-12 00:19:33 +0000 graphics/mesa-devel: switch to upstream mremap fix (cherry picked from commit b5f747edd92b087cf30af1edc70d9c067284e344) --- graphics/mesa-devel/Makefile | 3 + graphics/mesa-devel/distinfo | 4 + graphics/mesa-devel/files/patch-revert | 1075 -------------------------------- 3 files changed, 7 insertions(+), 1075 deletions(-) diff --git a/graphics/mesa-devel/Makefile b/graphics/mesa-devel/Makefile index 6ed24538d922..c238a284f338 100644 --- a/graphics/mesa-devel/Makefile +++ b/graphics/mesa-devel/Makefile @@ -1,6 +1,7 @@ PORTNAME= mesa DISTVERSION= 24.2-branchpoint-5103 DISTVERSIONSUFFIX= -gc108dfc930f +PORTREVISION= 1 CATEGORIES= graphics PKGNAMESUFFIX= -devel @@ -9,6 +10,8 @@ PATCHFILES+= 700efacda59c.patch:-p1:github PATCH_SITES+= ${GL_SITE}/${GL_ACCOUNT}/${GL_PROJECT}/-/commit/ PATCHFILES+= 2930dcbb3329.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/22246 PATCHFILES+= 11aaf934112c.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/22941 +PATCHFILES+= 36fa5115829c.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/32078 +PATCHFILES+= 582a0b01494c.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/32078 MAINTAINER= jbeich@FreeBSD.org COMMENT= Bleeding edge Mesa drivers (OpenCL, OpenGL, Vulkan) diff --git a/graphics/mesa-devel/distinfo b/graphics/mesa-devel/distinfo index 027e91e216a5..df2f164058f7 100644 --- a/graphics/mesa-devel/distinfo +++ b/graphics/mesa-devel/distinfo @@ -7,3 +7,7 @@ SHA256 (2930dcbb3329.patch) = f90ab77950ba1a56d165f0bc8a3cbd9c5f624bb5c67d1c7f33 SIZE (2930dcbb3329.patch) = 1638 SHA256 (11aaf934112c.patch) = 4408d8c0c4bf559ddf32ddbd06766f4fd28cc30b199a1991b20c89cf99bb9121 SIZE (11aaf934112c.patch) = 780 +SHA256 (36fa5115829c.patch) = 428e1e0073dda9d61f6d887379b4f46cfb5ce6c589a34a8f7af670c983663a62 +SIZE (36fa5115829c.patch) = 3792 +SHA256 (582a0b01494c.patch) = d7d28c7913429b6a477fedcaafc7ac3223ab95bc83c688a638bfb57005985e7f +SIZE (582a0b01494c.patch) = 20806 diff --git a/graphics/mesa-devel/files/patch-revert b/graphics/mesa-devel/files/patch-revert deleted file mode 100644 index cba4cbffdf09..000000000000 --- a/graphics/mesa-devel/files/patch-revert +++ /dev/null @@ -1,1075 +0,0 @@ -Revert https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/30988 -until https://gitlab.freedesktop.org/mesa/mesa/-/issues/12083 - ---- src/gallium/drivers/zink/ci/zink-anv-adl-fails.txt.orig 2024-10-30 21:04:20 UTC -+++ src/gallium/drivers/zink/ci/zink-anv-adl-fails.txt -@@ -77,6 +77,7 @@ glx@glx-multi-window-single-context,Fail - KHR-GL46.sparse_texture2_tests.SparseTexture2Commitment_texture_2d_multisample_rgb10_a2,Fail - - glx@glx-multi-window-single-context,Fail -+glx@glx-multithread-clearbuffer,Crash - glx@glx_arb_create_context_es2_profile@invalid opengl es version,Fail - glx@glx_arb_create_context_no_error@no error,Fail - glx@glx_arb_create_context_robustness@invalid reset notification strategy,Fail ---- src/gallium/drivers/zink/ci/zink-anv-adl-flakes.txt.orig 2024-10-30 21:04:20 UTC -+++ src/gallium/drivers/zink/ci/zink-anv-adl-flakes.txt -@@ -834,4 +834,3 @@ glx@glx-visuals-stencil -pixmap - wayland-dEQP-EGL.functional.wide_color.window_fp16_default_colorspace - - glx@glx-visuals-stencil -pixmap --glx@glx-multithread-clearbuffer ---- src/util/mesa_cache_db.c.orig 2024-10-30 21:04:20 UTC -+++ src/util/mesa_cache_db.c -@@ -16,7 +16,6 @@ - #include <stdlib.h> - #include <string.h> - #include <sys/file.h> --#include <sys/mman.h> - #include <unistd.h> - - #include "crc32.h" -@@ -51,6 +50,14 @@ struct PACKED mesa_index_db_file_entry { - uint64_t cache_db_file_offset; - }; - -+struct mesa_index_db_hash_entry { -+ uint64_t cache_db_file_offset; -+ uint64_t index_db_file_offset; -+ uint64_t last_access_time; -+ uint32_t size; -+ bool evicted; -+}; -+ - static inline bool mesa_db_seek_end(FILE *file) - { - return !fseek(file, 0, SEEK_END); -@@ -84,46 +91,21 @@ static bool - } - - static bool --mesa_db_reopen_file(struct mesa_cache_db_file *db_file); -- --static void --mesa_db_close_file(struct mesa_cache_db_file *db_file); -- --static int --mesa_db_flock(FILE *file, int op) --{ -- int ret; -- -- do { -- ret = flock(fileno(file), op); -- } while (ret < 0 && errno == EINTR); -- -- return ret; --} -- --static bool - mesa_db_lock(struct mesa_cache_db *db) - { - simple_mtx_lock(&db->flock_mtx); - -- if (!mesa_db_reopen_file(&db->index) || -- !mesa_db_reopen_file(&db->cache)) -- goto close_files; -+ if (flock(fileno(db->cache.file), LOCK_EX) == -1) -+ goto unlock_mtx; - -- if (mesa_db_flock(db->cache.file, LOCK_EX) < 0) -- goto close_files; -- -- if (mesa_db_flock(db->index.file, LOCK_EX) < 0) -+ if (flock(fileno(db->index.file), LOCK_EX) == -1) - goto unlock_cache; - - return true; - - unlock_cache: -- mesa_db_flock(db->cache.file, LOCK_UN); --close_files: -- mesa_db_close_file(&db->index); -- mesa_db_close_file(&db->cache); -- -+ flock(fileno(db->cache.file), LOCK_UN); -+unlock_mtx: - simple_mtx_unlock(&db->flock_mtx); - - return false; -@@ -132,12 +114,8 @@ mesa_db_unlock(struct mesa_cache_db *db) - static void - mesa_db_unlock(struct mesa_cache_db *db) - { -- mesa_db_flock(db->index.file, LOCK_UN); -- mesa_db_flock(db->cache.file, LOCK_UN); -- -- mesa_db_close_file(&db->index); -- mesa_db_close_file(&db->cache); -- -+ flock(fileno(db->index.file), LOCK_UN); -+ flock(fileno(db->cache.file), LOCK_UN); - simple_mtx_unlock(&db->flock_mtx); - } - -@@ -255,34 +233,6 @@ mesa_db_zap(struct mesa_cache_db *db) - return true; - } - --static struct mesa_index_db_file_entry * --mesa_db_index_entry_get(struct mesa_cache_db *db, size_t offset) --{ -- return (struct mesa_index_db_file_entry *) -- ((char*)db->index_entries + offset); --} -- --static void --mesa_db_index_entry_insert(struct mesa_cache_db *db, -- struct mesa_index_db_file_entry *index_entry) --{ -- size_t offset = (char*)index_entry - (char*)db->index_entries; -- -- offset += sizeof(struct mesa_db_file_header); -- _mesa_hash_table_u64_insert(db->index_db, index_entry->hash, (char*)(intptr_t)offset); --} -- --static struct mesa_index_db_file_entry * --mesa_db_index_entry_search(struct mesa_cache_db *db, uint64_t key) --{ -- size_t index_offset = (intptr_t)_mesa_hash_table_u64_search(db->index_db, key); -- -- if (!index_offset) -- return NULL; -- -- return mesa_db_index_entry_get(db, index_offset - sizeof(struct mesa_db_file_header)); --} -- - static bool - mesa_db_index_entry_valid(struct mesa_index_db_file_entry *entry) - { -@@ -297,104 +247,46 @@ static bool - } - - static bool --mesa_db_resize_index_entries(struct mesa_cache_db *db, off_t size) --{ -- int page_size = getpagesize(); -- size_t page_mask = page_size - 1; -- off_t old_num_pages, new_num_pages; -- -- if (db->index_entries_size == size) -- return true; -- -- new_num_pages = (size + page_mask) / page_size; -- -- if (size) { -- if (db->index_entries_size) { -- old_num_pages = (db->index_entries_size + page_mask) / page_size; -- -- if (new_num_pages != old_num_pages) { -- db->index_entries = mremap(db->index_entries, old_num_pages * page_size, -- new_num_pages * page_size, MREMAP_MAYMOVE); -- if (db->index_entries == MAP_FAILED) { -- fprintf(stderr, "%s: mremap failed with error %d (%s)\n", -- __func__, errno, strerror(errno)); -- goto error; -- } -- } -- } else { -- db->index_entries = mmap(NULL, new_num_pages * page_size, PROT_READ | PROT_WRITE, -- MAP_PRIVATE | MAP_ANONYMOUS | MAP_POPULATE, -1, 0); -- if (db->index_entries == MAP_FAILED) { -- fprintf(stderr, "%s: mmap failed with error %d (%s)\n", -- __func__, errno, strerror(errno)); -- goto error; -- } -- } -- } else { -- if (db->index_entries_size) { -- old_num_pages = (db->index_entries_size + page_mask) / page_size; -- -- munmap(db->index_entries, old_num_pages * page_size); -- } -- -- db->index_entries = NULL; -- } -- -- db->index_entries_size = size; -- return true; -- --error: -- _mesa_hash_table_u64_clear(db->index_db); -- db->index_entries = NULL; -- db->index_entries_size = 0; -- return false; --} -- --static bool - mesa_db_update_index(struct mesa_cache_db *db) - { -- struct mesa_index_db_file_entry *index_entry; -+ struct mesa_index_db_hash_entry *hash_entry; -+ struct mesa_index_db_file_entry index_entry; - size_t file_length; -- size_t old_entries, new_entries; -- int i; - - if (!mesa_db_seek_end(db->index.file)) - return false; - - file_length = ftell(db->index.file); -- if (file_length < db->index.offset) -- return false; - - if (!mesa_db_seek(db->index.file, db->index.offset)) - return false; - -- new_entries = (file_length - db->index.offset) / sizeof(*index_entry); -- if (!new_entries) -- return true; -+ while (db->index.offset < file_length) { -+ if (!mesa_db_read(db->index.file, &index_entry)) -+ break; - -- old_entries = db->index_entries_size / sizeof(*index_entry); -- -- if (!mesa_db_resize_index_entries(db, (old_entries + new_entries) * sizeof(*index_entry))) -- return false; -- -- _mesa_hash_table_reserve(db->index_db->table, old_entries + new_entries); -- -- index_entry = mesa_db_index_entry_get(db, old_entries * sizeof(*index_entry)); -- if (!mesa_db_read_data(db->index.file, index_entry, new_entries * sizeof(*index_entry))) -- return false; -- -- for (i = 0; i < new_entries; i++, index_entry++) { - /* Check whether the index entry looks valid or we have a corrupted DB */ -- if (!mesa_db_index_entry_valid(index_entry)) -+ if (!mesa_db_index_entry_valid(&index_entry)) - break; - -- mesa_db_index_entry_insert(db, index_entry); -+ hash_entry = ralloc(db->mem_ctx, struct mesa_index_db_hash_entry); -+ if (!hash_entry) -+ break; - -- db->index.offset += sizeof(*index_entry); -+ hash_entry->cache_db_file_offset = index_entry.cache_db_file_offset; -+ hash_entry->index_db_file_offset = db->index.offset; -+ hash_entry->last_access_time = index_entry.last_access_time; -+ hash_entry->size = index_entry.size; -+ -+ _mesa_hash_table_u64_insert(db->index_db, index_entry.hash, hash_entry); -+ -+ db->index.offset += sizeof(index_entry); - } - -- return mesa_db_seek(db->index.file, db->index.offset) && -- db->index.offset == file_length; -+ if (!mesa_db_seek(db->index.file, db->index.offset)) -+ return false; -+ -+ return db->index.offset == file_length; - } - - static void -@@ -403,8 +295,6 @@ mesa_db_hash_table_reset(struct mesa_cache_db *db) - _mesa_hash_table_u64_clear(db->index_db); - ralloc_free(db->mem_ctx); - db->mem_ctx = ralloc_context(NULL); -- -- mesa_db_resize_index_entries(db, 0); - } - - static bool -@@ -433,6 +323,10 @@ mesa_db_load(struct mesa_cache_db *db, bool reload) - !mesa_db_load_header(&db->index) || - db->cache.uuid != db->index.uuid) { - -+ /* This is unexpected to happen on reload, bail out */ -+ if (reload) -+ goto fail; -+ - if (!mesa_db_recreate_files(db)) - goto fail; - } else { -@@ -444,17 +338,9 @@ mesa_db_load(struct mesa_cache_db *db, bool reload) - if (reload) - mesa_db_hash_table_reset(db); - -- /* The update failed so we assume the files are corrupt and -- * recreate them. -- */ -- if (!mesa_db_update_index(db)) { -- mesa_db_recreate_files(db); -- db->index.offset = ftell(db->index.file); -+ if (!mesa_db_update_index(db)) -+ goto fail; - -- if (!mesa_db_update_index(db)) -- goto fail; -- } -- - if (!reload) - mesa_db_unlock(db); - -@@ -478,21 +364,10 @@ mesa_db_reload(struct mesa_cache_db *db) - return mesa_db_load(db, true); - } - --static FILE * --mesa_db_fopen(const char *path) -+static void -+touch_file(const char* path) - { -- /* The fopen("r+b") mode doesn't auto-create new file, hence we need to -- * explicitly create the file first. -- */ -- int fd = open(path, O_CREAT | O_CLOEXEC | O_RDWR, 0644); -- if (fd < 0) -- return NULL; -- -- FILE *f = fdopen(fd, "r+b"); -- if (!f) -- close(fd); -- -- return f; -+ close(open(path, O_CREAT | O_CLOEXEC, 0644)); - } - - static bool -@@ -503,7 +378,12 @@ mesa_db_open_file(struct mesa_cache_db_file *db_file, - if (asprintf(&db_file->path, "%s/%s", cache_path, filename) == -1) - return false; - -- db_file->file = mesa_db_fopen(db_file->path); -+ /* The fopen("r+b") mode doesn't auto-create new file, hence we need to -+ * explicitly create the file first. -+ */ -+ touch_file(db_file->path); -+ -+ db_file->file = fopen(db_file->path, "r+b"); - if (!db_file->file) { - free(db_file->path); - return false; -@@ -512,34 +392,10 @@ mesa_db_open_file(struct mesa_cache_db_file *db_file, - return true; - } - --static bool --mesa_db_reopen_file(struct mesa_cache_db_file *db_file) --{ -- if (db_file->file) -- return true; -- -- db_file->file = mesa_db_fopen(db_file->path); -- if (!db_file->file) -- return false; -- -- return true; --} -- - static void - mesa_db_close_file(struct mesa_cache_db_file *db_file) - { -- if (db_file->file) { -- fclose(db_file->file); -- db_file->file = NULL; -- } --} -- --static void --mesa_db_free_file(struct mesa_cache_db_file *db_file) --{ -- if (db_file->file) -- fclose(db_file->file); -- -+ fclose(db_file->file); - free(db_file->path); - } - -@@ -556,16 +412,11 @@ mesa_db_remove_file(struct mesa_cache_db_file *db_file - return true; - } - --struct sort_entry { -- struct mesa_index_db_file_entry *index_entry; -- bool evicted; --}; -- - static int - entry_sort_lru(const void *_a, const void *_b, void *arg) - { -- const struct mesa_index_db_file_entry *a = ((const struct sort_entry *)_a)->index_entry; -- const struct mesa_index_db_file_entry *b = ((const struct sort_entry *)_b)->index_entry; -+ const struct mesa_index_db_hash_entry *a = *((const struct mesa_index_db_hash_entry **)_a); -+ const struct mesa_index_db_hash_entry *b = *((const struct mesa_index_db_hash_entry **)_b); - - /* In practice it's unlikely that we will get two entries with the - * same timestamp, but technically it's possible to happen if OS -@@ -579,8 +430,8 @@ entry_sort_offset(const void *_a, const void *_b, void - static int - entry_sort_offset(const void *_a, const void *_b, void *arg) - { -- const struct mesa_index_db_file_entry *a = ((const struct sort_entry *)_a)->index_entry; -- const struct mesa_index_db_file_entry *b = ((const struct sort_entry *)_b)->index_entry; -+ const struct mesa_index_db_hash_entry *a = *((const struct mesa_index_db_hash_entry **)_a); -+ const struct mesa_index_db_hash_entry *b = *((const struct mesa_index_db_hash_entry **)_b); - struct mesa_cache_db *db = arg; - - /* Two entries will never have the identical offset, otherwise DB is -@@ -598,14 +449,14 @@ mesa_db_compact(struct mesa_cache_db *db, int64_t blob - - static bool - mesa_db_compact(struct mesa_cache_db *db, int64_t blob_size, -- struct mesa_index_db_file_entry *remove_entry) -+ struct mesa_index_db_hash_entry *remove_entry) - { - uint32_t num_entries, buffer_size = sizeof(struct mesa_index_db_file_entry); - struct mesa_db_file_header cache_header, index_header; - FILE *compacted_cache = NULL, *compacted_index = NULL; -- struct mesa_index_db_file_entry *index_entry; -- struct sort_entry *entries; -- bool success = false; -+ struct mesa_index_db_file_entry index_entry; -+ struct mesa_index_db_hash_entry **entries; -+ bool success = false, compact = false; - void *buffer = NULL; - unsigned int i = 0; - -@@ -614,15 +465,12 @@ mesa_db_compact(struct mesa_cache_db *db, int64_t blob - return false; - - num_entries = _mesa_hash_table_num_entries(db->index_db->table); -- if (!num_entries) -- return true; -- - entries = calloc(num_entries, sizeof(*entries)); - if (!entries) - return false; - -- compacted_cache = mesa_db_fopen(db->cache.path); -- compacted_index = mesa_db_fopen(db->index.path); -+ compacted_cache = fopen(db->cache.path, "r+b"); -+ compacted_index = fopen(db->index.path, "r+b"); - if (!compacted_cache || !compacted_index) - goto cleanup; - -@@ -634,18 +482,19 @@ mesa_db_compact(struct mesa_cache_db *db, int64_t blob - index_header.uuid != db->uuid) - goto cleanup; - -- for (i = 0, index_entry = db->index_entries; i < num_entries; i++, index_entry++) { -- entries[i].index_entry = index_entry; -- entries[i].evicted = index_entry == remove_entry; -- buffer_size = MAX2(buffer_size, blob_file_size(index_entry->size)); -+ hash_table_foreach(db->index_db->table, entry) { -+ entries[i] = entry->data; -+ entries[i]->evicted = (entries[i] == remove_entry); -+ buffer_size = MAX2(buffer_size, blob_file_size(entries[i]->size)); -+ i++; - } - - util_qsort_r(entries, num_entries, sizeof(*entries), - entry_sort_lru, db); - - for (i = 0; blob_size > 0 && i < num_entries; i++) { -- blob_size -= blob_file_size(entries[i].index_entry->size); -- entries[i].evicted = true; -+ blob_size -= blob_file_size(entries[i]->size); -+ entries[i]->evicted = true; - } - - util_qsort_r(entries, num_entries, sizeof(*entries), -@@ -665,38 +514,59 @@ mesa_db_compact(struct mesa_cache_db *db, int64_t blob - !mesa_db_write_header(&db->index, 0, false)) - goto cleanup; - -- /* Skip non-evicted entries at the start of the files */ -- for (i = 0; i < num_entries; i++) { -- if (entries[i].evicted) -- break; -- } -- - /* Sync the file pointers */ -- if (!mesa_db_seek(compacted_cache, entries[i].index_entry->cache_db_file_offset) || -- !mesa_db_seek(compacted_index, ftell(db->index.file) + -- i * sizeof(struct mesa_index_db_file_entry))) -+ if (!mesa_db_seek(compacted_cache, ftell(db->cache.file)) || -+ !mesa_db_seek(compacted_index, ftell(db->index.file))) - goto cleanup; - - /* Do the compaction */ -- for (; i < num_entries; i++) { -- struct mesa_index_db_file_entry *index_entry = entries[i].index_entry; -+ for (i = 0; i < num_entries; i++) { -+ blob_size = blob_file_size(entries[i]->size); - -- if (entries[i].evicted) -+ /* Sanity-check the cache-read offset */ -+ if (ftell(db->cache.file) != entries[i]->cache_db_file_offset) -+ goto cleanup; -+ -+ if (entries[i]->evicted) { -+ /* Jump over the evicted entry */ -+ if (!mesa_db_seek_cur(db->cache.file, blob_size) || -+ !mesa_db_seek_cur(db->index.file, sizeof(index_entry))) -+ goto cleanup; -+ -+ compact = true; - continue; -+ } - -- blob_size = blob_file_size(index_entry->size); -+ if (compact) { -+ /* Compact the cache file */ -+ if (!mesa_db_read_data(db->cache.file, buffer, blob_size) || -+ !mesa_db_cache_entry_valid(buffer) || -+ !mesa_db_write_data(compacted_cache, buffer, blob_size)) -+ goto cleanup; - -- /* Compact the cache file */ -- if (!mesa_db_seek(db->cache.file, index_entry->cache_db_file_offset) || -- !mesa_db_read_data(db->cache.file, buffer, blob_size) || -- !mesa_db_cache_entry_valid(buffer) || -- !mesa_db_write_data(compacted_cache, buffer, blob_size)) -- goto cleanup; -+ /* Compact the index file */ -+ if (!mesa_db_read(db->index.file, &index_entry) || -+ !mesa_db_index_entry_valid(&index_entry) || -+ index_entry.cache_db_file_offset != entries[i]->cache_db_file_offset || -+ index_entry.size != entries[i]->size) -+ goto cleanup; - -- index_entry->cache_db_file_offset = ftell(compacted_cache) - blob_size; -+ index_entry.cache_db_file_offset = ftell(compacted_cache) - blob_size; - -- if (!mesa_db_write(compacted_index, index_entry)) -- goto cleanup; -+ if (!mesa_db_write(compacted_index, &index_entry)) -+ goto cleanup; -+ } else { -+ /* Sanity-check the cache-write offset */ -+ if (ftell(compacted_cache) != entries[i]->cache_db_file_offset) -+ goto cleanup; -+ -+ /* Jump over the unchanged entry */ -+ if (!mesa_db_seek_cur(db->index.file, sizeof(index_entry)) || -+ !mesa_db_seek_cur(compacted_index, sizeof(index_entry)) || -+ !mesa_db_seek_cur(db->cache.file, blob_size) || -+ !mesa_db_seek_cur(compacted_cache, blob_size)) -+ goto cleanup; -+ } - } - - fflush(compacted_cache); -@@ -762,9 +632,9 @@ close_index: - - ralloc_free(db->mem_ctx); - close_index: -- mesa_db_free_file(&db->index); -+ mesa_db_close_file(&db->index); - close_cache: -- mesa_db_free_file(&db->cache); -+ mesa_db_close_file(&db->cache); - - return false; - } -@@ -792,14 +662,8 @@ mesa_cache_db_close(struct mesa_cache_db *db) - simple_mtx_destroy(&db->flock_mtx); - ralloc_free(db->mem_ctx); - -- mesa_db_resize_index_entries(db, 0); -- if (db->index_entries) { -- munmap(db->index_entries, 0); -- db->index_entries = NULL; -- } -- -- mesa_db_free_file(&db->index); -- mesa_db_free_file(&db->cache); -+ mesa_db_close_file(&db->index); -+ mesa_db_close_file(&db->cache); - } - - void -@@ -822,8 +686,8 @@ mesa_cache_db_read_entry(struct mesa_cache_db *db, - { - uint64_t hash = to_mesa_cache_db_hash(cache_key_160bit); - struct mesa_cache_db_file_entry cache_entry; -- struct mesa_index_db_file_entry *index_entry; -- long seek_pos; -+ struct mesa_index_db_file_entry index_entry; -+ struct mesa_index_db_hash_entry *hash_entry; - void *data = NULL; - - if (!mesa_db_lock(db)) -@@ -838,11 +702,11 @@ mesa_cache_db_read_entry(struct mesa_cache_db *db, - if (!mesa_db_update_index(db)) - goto fail_fatal; - -- index_entry = mesa_db_index_entry_search(db, hash); -- if (!index_entry) -+ hash_entry = _mesa_hash_table_u64_search(db->index_db, hash); -+ if (!hash_entry) - goto fail; - -- if (!mesa_db_seek(db->cache.file, index_entry->cache_db_file_offset) || -+ if (!mesa_db_seek(db->cache.file, hash_entry->cache_db_file_offset) || - !mesa_db_read(db->cache.file, &cache_entry) || - !mesa_db_cache_entry_valid(&cache_entry)) - goto fail_fatal; -@@ -858,13 +722,18 @@ mesa_cache_db_read_entry(struct mesa_cache_db *db, - util_hash_crc32(data, cache_entry.size) != cache_entry.crc) - goto fail_fatal; - -- index_entry->last_access_time = os_time_get_nano(); -+ if (!mesa_db_seek(db->index.file, hash_entry->index_db_file_offset) || -+ !mesa_db_read(db->index.file, &index_entry) || -+ !mesa_db_index_entry_valid(&index_entry) || -+ index_entry.cache_db_file_offset != hash_entry->cache_db_file_offset || -+ index_entry.size != hash_entry->size) -+ goto fail_fatal; - -- seek_pos = ((char*)index_entry - (char*)db->index_entries) + -- sizeof(struct mesa_db_file_header); -+ index_entry.last_access_time = os_time_get_nano(); -+ hash_entry->last_access_time = index_entry.last_access_time; - -- if (!mesa_db_seek(db->index.file, seek_pos) || -- !mesa_db_write(db->index.file, index_entry)) -+ if (!mesa_db_seek(db->index.file, hash_entry->index_db_file_offset) || -+ !mesa_db_write(db->index.file, &index_entry)) - goto fail_fatal; - - fflush(db->index.file); -@@ -904,9 +773,9 @@ mesa_cache_db_entry_write(struct mesa_cache_db *db, - const void *blob, size_t blob_size) - { - uint64_t hash = to_mesa_cache_db_hash(cache_key_160bit); -+ struct mesa_index_db_hash_entry *hash_entry = NULL; - struct mesa_cache_db_file_entry cache_entry; -- struct mesa_index_db_file_entry *index_entry; -- off_t index_offset; -+ struct mesa_index_db_file_entry index_entry; - - if (!mesa_db_lock(db)) - return false; -@@ -929,41 +798,46 @@ mesa_cache_db_entry_write(struct mesa_cache_db *db, - goto fail_fatal; - } - -- index_entry = mesa_db_index_entry_search(db, hash); -- if (index_entry) -+ hash_entry = _mesa_hash_table_u64_search(db->index_db, hash); -+ if (hash_entry) { -+ hash_entry = NULL; - goto fail; -+ } - - if (!mesa_db_seek_end(db->cache.file) || - !mesa_db_seek_end(db->index.file)) - goto fail_fatal; - -- index_offset = db->index_entries_size; -- if (!mesa_db_resize_index_entries(db, index_offset + sizeof(*index_entry))) -- goto fail; -- -- index_entry = mesa_db_index_entry_get(db, index_offset); -- - memcpy(cache_entry.key, cache_key_160bit, sizeof(cache_entry.key)); - cache_entry.crc = util_hash_crc32(blob, blob_size); - cache_entry.size = blob_size; - -- index_entry->hash = hash; -- index_entry->size = blob_size; -- index_entry->last_access_time = os_time_get_nano(); -- index_entry->cache_db_file_offset = ftell(db->cache.file); -+ index_entry.hash = hash; -+ index_entry.size = blob_size; -+ index_entry.last_access_time = os_time_get_nano(); -+ index_entry.cache_db_file_offset = ftell(db->cache.file); - -+ hash_entry = ralloc(db->mem_ctx, struct mesa_index_db_hash_entry); -+ if (!hash_entry) -+ goto fail; -+ -+ hash_entry->cache_db_file_offset = index_entry.cache_db_file_offset; -+ hash_entry->index_db_file_offset = ftell(db->index.file); -+ hash_entry->last_access_time = index_entry.last_access_time; -+ hash_entry->size = index_entry.size; -+ - if (!mesa_db_write(db->cache.file, &cache_entry) || - !mesa_db_write_data(db->cache.file, blob, blob_size) || -- !mesa_db_write(db->index.file, index_entry)) -+ !mesa_db_write(db->index.file, &index_entry)) - goto fail_fatal; - - fflush(db->cache.file); - fflush(db->index.file); - -- mesa_db_index_entry_insert(db, index_entry); -- - db->index.offset = ftell(db->index.file); - -+ _mesa_hash_table_u64_insert(db->index_db, hash, hash_entry); -+ - mesa_db_unlock(db); - - return true; -@@ -973,6 +847,9 @@ fail: - fail: - mesa_db_unlock(db); - -+ if (hash_entry) -+ ralloc_free(hash_entry); -+ - return false; - } - -@@ -982,7 +859,7 @@ mesa_cache_db_entry_remove(struct mesa_cache_db *db, - { - uint64_t hash = to_mesa_cache_db_hash(cache_key_160bit); - struct mesa_cache_db_file_entry cache_entry; -- struct mesa_index_db_file_entry *index_entry; -+ struct mesa_index_db_hash_entry *hash_entry; - - if (!mesa_db_lock(db)) - return NULL; -@@ -996,11 +873,11 @@ mesa_cache_db_entry_remove(struct mesa_cache_db *db, - if (!mesa_db_update_index(db)) - goto fail_fatal; - -- index_entry = mesa_db_index_entry_search(db, hash); -- if (!index_entry) -+ hash_entry = _mesa_hash_table_u64_search(db->index_db, hash); -+ if (!hash_entry) - goto fail; - -- if (!mesa_db_seek(db->cache.file, index_entry->cache_db_file_offset) || -+ if (!mesa_db_seek(db->cache.file, hash_entry->cache_db_file_offset) || - !mesa_db_read(db->cache.file, &cache_entry) || - !mesa_db_cache_entry_valid(&cache_entry)) - goto fail_fatal; -@@ -1008,7 +885,7 @@ mesa_cache_db_entry_remove(struct mesa_cache_db *db, - if (memcmp(cache_entry.key, cache_key_160bit, sizeof(cache_entry.key))) - goto fail; - -- if (!mesa_db_compact(db, 0, index_entry)) -+ if (!mesa_db_compact(db, 0, hash_entry)) - goto fail_fatal; - - mesa_db_unlock(db); -@@ -1066,8 +943,7 @@ mesa_cache_db_eviction_score(struct mesa_cache_db *db) - mesa_cache_db_eviction_score(struct mesa_cache_db *db) - { - int64_t eviction_size = mesa_cache_db_eviction_size(db); -- struct mesa_index_db_file_entry *index_entry; -- struct sort_entry *entries; -+ struct mesa_index_db_hash_entry **entries; - unsigned num_entries, i = 0; - double eviction_score = 0; - -@@ -1085,16 +961,15 @@ mesa_cache_db_eviction_score(struct mesa_cache_db *db) - if (!entries) - goto fail; - -- for (i = 0, index_entry = db->index_entries; i < num_entries; i++) -- entries[i].index_entry = index_entry++; -+ hash_table_foreach(db->index_db->table, entry) -+ entries[i++] = entry->data; - - util_qsort_r(entries, num_entries, sizeof(*entries), - entry_sort_lru, db); - - for (i = 0; eviction_size > 0 && i < num_entries; i++) { -- index_entry = entries[i].index_entry; -- uint64_t entry_age = os_time_get_nano() - index_entry->last_access_time; -- unsigned entry_size = blob_file_size(index_entry->size); -+ uint64_t entry_age = os_time_get_nano() - entries[i]->last_access_time; -+ unsigned entry_size = blob_file_size(entries[i]->size); - - /* Eviction score is a sum of weighted cache entry sizes, - * where weight doubles for each month of entry's age. ---- src/util/mesa_cache_db.h.orig 2024-10-30 21:04:20 UTC -+++ src/util/mesa_cache_db.h -@@ -32,8 +32,6 @@ struct mesa_cache_db { - struct hash_table_u64 *index_db; - struct mesa_cache_db_file cache; - struct mesa_cache_db_file index; -- void *index_entries; -- size_t index_entries_size; - uint64_t max_cache_size; - simple_mtx_t flock_mtx; - void *mem_ctx; ---- src/util/mesa_cache_db_multipart.c.orig 2024-10-30 21:04:20 UTC -+++ src/util/mesa_cache_db_multipart.c -@@ -18,109 +18,67 @@ mesa_cache_db_multipart_open(struct mesa_cache_db_mult - #if DETECT_OS_WINDOWS - return false; - #else -+ char *part_path = NULL; -+ unsigned int i; -+ - db->num_parts = debug_get_num_option("MESA_DISK_CACHE_DATABASE_NUM_PARTS", 50); -- db->cache_path = cache_path; -+ - db->parts = calloc(db->num_parts, sizeof(*db->parts)); - if (!db->parts) - return false; - -- simple_mtx_init(&db->lock, mtx_plain); -+ for (i = 0; i < db->num_parts; i++) { -+ bool db_opened = false; - -- return true; --#endif --} -+ if (asprintf(&part_path, "%s/part%u", cache_path, i) == -1) -+ goto close_db; - --static bool --mesa_cache_db_multipart_init_part_locked(struct mesa_cache_db_multipart *db, -- unsigned int part) --{ --#if DETECT_OS_WINDOWS -- return false; --#else -- struct mesa_cache_db *db_part; -- bool db_opened = false; -- char *part_path = NULL; -+ if (mkdir(part_path, 0755) == -1 && errno != EEXIST) -+ goto free_path; - -- if (db->parts[part]) -- return true; -+ /* DB opening may fail only in a case of a severe problem, -+ * like IO error. -+ */ -+ db_opened = mesa_cache_db_open(&db->parts[i], part_path); -+ if (!db_opened) -+ goto free_path; - -- if (asprintf(&part_path, "%s/part%u", db->cache_path, part) == -1) -- return false; -- -- if (mkdir(part_path, 0755) == -1 && errno != EEXIST) -- goto free_path; -- -- db_part = calloc(1, sizeof(*db_part)); -- if (!db_part) -- goto free_path; -- -- /* DB opening may fail only in a case of a severe problem, -- * like IO error. -- */ -- db_opened = mesa_cache_db_open(db_part, part_path); -- if (!db_opened) { -- free(db_part); -- goto free_path; -+ free(part_path); - } - -- if (db->max_cache_size) -- mesa_cache_db_set_size_limit(db_part, db->max_cache_size / db->num_parts); -- - /* remove old pre multi-part cache */ -- mesa_db_wipe_path(db->cache_path); -+ mesa_db_wipe_path(cache_path); - -- __sync_synchronize(); -+ return true; - -- db->parts[part] = db_part; -- - free_path: - free(part_path); -+close_db: -+ while (i--) -+ mesa_cache_db_close(&db->parts[i]); - -- return db_opened; -+ free(db->parts); -+ -+ return false; - #endif - } - --static bool --mesa_cache_db_multipart_init_part(struct mesa_cache_db_multipart *db, -- unsigned int part) --{ -- bool ret; -- -- if (db->parts[part]) -- return true; -- -- simple_mtx_lock(&db->lock); -- ret = mesa_cache_db_multipart_init_part_locked(db, part); -- simple_mtx_unlock(&db->lock); -- -- return ret; --} -- - void - mesa_cache_db_multipart_close(struct mesa_cache_db_multipart *db) - { -- while (db->num_parts--) { -- if (db->parts[db->num_parts]) { -- mesa_cache_db_close(db->parts[db->num_parts]); -- free(db->parts[db->num_parts]); -- } -- } -+ while (db->num_parts--) -+ mesa_cache_db_close(&db->parts[db->num_parts]); - - free(db->parts); -- simple_mtx_destroy(&db->lock); - } - - void - mesa_cache_db_multipart_set_size_limit(struct mesa_cache_db_multipart *db, *** 147 LINES SKIPPED ***