2022-08-15 23:13:05 +03: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 17:49:40 +03:00
|
|
|
#include "qemu/rcu.h"
|
|
|
|
#include "exec/cpu-common.h"
|
|
|
|
|
2022-08-15 23:13:05 +03:00
|
|
|
#define TB_JMP_CACHE_BITS 12
|
|
|
|
#define TB_JMP_CACHE_SIZE (1 << TB_JMP_CACHE_BITS)
|
|
|
|
|
|
|
|
/*
|
2024-01-22 18:34:09 +03: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 23:13:05 +03:00
|
|
|
*/
|
2024-05-02 18:14:42 +03:00
|
|
|
typedef struct CPUJumpCache {
|
2023-01-24 21:01:18 +03:00
|
|
|
struct rcu_head rcu;
|
2022-08-15 23:13:05 +03:00
|
|
|
struct {
|
|
|
|
TranslationBlock *tb;
|
2023-06-21 16:56:28 +03:00
|
|
|
vaddr pc;
|
2022-08-15 23:13:05 +03:00
|
|
|
} array[TB_JMP_CACHE_SIZE];
|
2024-05-02 18:14:42 +03:00
|
|
|
} CPUJumpCache;
|
2022-08-15 23:13:05 +03:00
|
|
|
|
|
|
|
#endif /* ACCEL_TCG_TB_JMP_CACHE_H */
|