[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 16/37] contrib/plugins/cache: fix 32-bit build
From: |
Alex Bennée |
Subject: |
[PULL 16/37] contrib/plugins/cache: fix 32-bit build |
Date: |
Fri, 17 Jan 2025 13:42:35 +0000 |
From: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20241217224306.2900490-7-pierrick.bouvier@linaro.org>
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Message-Id: <20250116160306.1709518-17-alex.bennee@linaro.org>
diff --git a/contrib/plugins/cache.c b/contrib/plugins/cache.c
index 512ef6776b..7baff86860 100644
--- a/contrib/plugins/cache.c
+++ b/contrib/plugins/cache.c
@@ -208,7 +208,7 @@ static int fifo_get_first_block(Cache *cache, int set)
static void fifo_update_on_miss(Cache *cache, int set, int blk_idx)
{
GQueue *q = cache->sets[set].fifo_queue;
- g_queue_push_head(q, GINT_TO_POINTER(blk_idx));
+ g_queue_push_head(q, (gpointer)(intptr_t) blk_idx);
}
static void fifo_destroy(Cache *cache)
@@ -471,13 +471,8 @@ static void vcpu_tb_trans(qemu_plugin_id_t id, struct
qemu_plugin_tb *tb)
n_insns = qemu_plugin_tb_n_insns(tb);
for (i = 0; i < n_insns; i++) {
struct qemu_plugin_insn *insn = qemu_plugin_tb_get_insn(tb, i);
- uint64_t effective_addr;
-
- if (sys) {
- effective_addr = (uint64_t) qemu_plugin_insn_haddr(insn);
- } else {
- effective_addr = (uint64_t) qemu_plugin_insn_vaddr(insn);
- }
+ uint64_t effective_addr = sys ? (uintptr_t)
qemu_plugin_insn_haddr(insn) :
+ qemu_plugin_insn_vaddr(insn);
/*
* Instructions might get translated multiple times, we do not create
@@ -485,14 +480,13 @@ static void vcpu_tb_trans(qemu_plugin_id_t id, struct
qemu_plugin_tb *tb)
* entry from the hash table and register it for the callback again.
*/
g_mutex_lock(&hashtable_lock);
- data = g_hash_table_lookup(miss_ht, GUINT_TO_POINTER(effective_addr));
+ data = g_hash_table_lookup(miss_ht, &effective_addr);
if (data == NULL) {
data = g_new0(InsnData, 1);
data->disas_str = qemu_plugin_insn_disas(insn);
data->symbol = qemu_plugin_insn_symbol(insn);
data->addr = effective_addr;
- g_hash_table_insert(miss_ht, GUINT_TO_POINTER(effective_addr),
- (gpointer) data);
+ g_hash_table_insert(miss_ht, &data->addr, data);
}
g_mutex_unlock(&hashtable_lock);
@@ -853,7 +847,7 @@ int qemu_plugin_install(qemu_plugin_id_t id, const
qemu_info_t *info,
qemu_plugin_register_vcpu_tb_trans_cb(id, vcpu_tb_trans);
qemu_plugin_register_atexit_cb(id, plugin_exit, NULL);
- miss_ht = g_hash_table_new_full(NULL, g_direct_equal, NULL, insn_free);
+ miss_ht = g_hash_table_new_full(g_int64_hash, g_int64_equal, NULL,
insn_free);
return 0;
}
--
2.39.5
- [PULL 05/37] semihosting/arm-compat: Include missing 'cpu.h' header, (continued)
- [PULL 05/37] semihosting/arm-compat: Include missing 'cpu.h' header, Alex Bennée, 2025/01/17
- [PULL 01/37] semihosting: add guest_error logging for failed opens, Alex Bennée, 2025/01/17
- [PULL 11/37] tests/tcg/plugins/insn: remove unused callback parameter, Alex Bennée, 2025/01/17
- [PULL 08/37] system/vl: more error exit into config enumeration code, Alex Bennée, 2025/01/17
- [PULL 13/37] tests/tcg/plugins/syscall: fix 32-bit build, Alex Bennée, 2025/01/17
- [PULL 02/37] semihosting/uaccess: Briefly document returned values, Alex Bennée, 2025/01/17
- [PULL 07/37] semihosting/meson: Build config.o and console.o once, Alex Bennée, 2025/01/17
- [PULL 21/37] configure: reenable plugins by default for 32-bit hosts, Alex Bennée, 2025/01/17
- [PULL 03/37] semihosting/syscalls: Include missing 'exec/cpu-defs.h' header, Alex Bennée, 2025/01/17
- [PULL 18/37] contrib/plugins/cflow: fix 32-bit build, Alex Bennée, 2025/01/17
- [PULL 16/37] contrib/plugins/cache: fix 32-bit build,
Alex Bennée <=
- [PULL 17/37] contrib/plugins/hotblocks: fix 32-bit build, Alex Bennée, 2025/01/17
- [PULL 10/37] system: propagate Error to gdbserver_start (and other device setups), Alex Bennée, 2025/01/17
- [PULL 15/37] contrib/plugins/stoptrigger: fix 32-bit build, Alex Bennée, 2025/01/17
- [PULL 23/37] win32: remove usage of attribute gcc_struct, Alex Bennée, 2025/01/17
- [PULL 12/37] contrib/plugins/howvec: ensure we don't regress if this plugin is extended, Alex Bennée, 2025/01/17
- [PULL 36/37] docs: add a glossary, Alex Bennée, 2025/01/17
- [PULL 30/37] include/exec: remove warning_printed from MemoryRegion, Alex Bennée, 2025/01/17
- [PULL 29/37] include/exec: fix some copy and paste errors in kdoc, Alex Bennée, 2025/01/17
- [PULL 14/37] tests/tcg/plugins/mem: fix 32-bit build, Alex Bennée, 2025/01/17
- [PULL 27/37] editorconfig: update for perl scripts, Alex Bennée, 2025/01/17