git: eae90cac000e - 2024Q4 - graphics/mesa-devel: switch to upstream mremap fix

From: Jan Beich <jbeich_at_FreeBSD.org>
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 ***