2022-08-15 20:13:05 +00:00
|
|
|
/*
|
|
|
|
* The per-CPU TranslationBlock jump cache.
|
|
|
|
*
|
|
|
|
* Copyright (c) 2003 Fabrice Bellard
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ACCEL_TCG_TB_JMP_CACHE_H
|
|
|
|
#define ACCEL_TCG_TB_JMP_CACHE_H
|
|
|
|
|
2024-01-10 14:49:40 +00:00
|
|
|
#include "qemu/rcu.h"
|
|
|
|
#include "exec/cpu-common.h"
|
|
|
|
|
2022-08-15 20:13:05 +00:00
|
|
|
#define TB_JMP_CACHE_BITS 12
|
|
|
|
#define TB_JMP_CACHE_SIZE (1 << TB_JMP_CACHE_BITS)
|
|
|
|
|
|
|
|
/*
|
2024-01-22 15:34:09 +00:00
|
|
|
* Invalidated in parallel; all accesses to 'tb' must be atomic.
|
|
|
|
* A valid entry is read/written by a single CPU, therefore there is
|
|
|
|
* no need for qatomic_rcu_read() and pc is always consistent with a
|
|
|
|
* non-NULL value of 'tb'. Strictly speaking pc is only needed for
|
|
|
|
* CF_PCREL, but it's used always for simplicity.
|
2022-08-15 20:13:05 +00:00
|
|
|
*/
|
2024-05-02 15:14:42 +00:00
|
|
|
typedef struct CPUJumpCache {
|
2023-01-24 18:01:18 +00:00
|
|
|
struct rcu_head rcu;
|
2022-08-15 20:13:05 +00:00
|
|
|
struct {
|
|
|
|
TranslationBlock *tb;
|
2023-06-21 13:56:28 +00:00
|
|
|
vaddr pc;
|
2022-08-15 20:13:05 +00:00
|
|
|
} array[TB_JMP_CACHE_SIZE];
|
2024-05-02 15:14:42 +00:00
|
|
|
} CPUJumpCache;
|
2022-08-15 20:13:05 +00:00
|
|
|
|
|
|
|
#endif /* ACCEL_TCG_TB_JMP_CACHE_H */
|