/* * 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 #define TB_JMP_CACHE_BITS 12 #define TB_JMP_CACHE_SIZE (1 << TB_JMP_CACHE_BITS) /* * 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. */ struct CPUJumpCache { struct rcu_head rcu; struct { TranslationBlock *tb; vaddr pc; } array[TB_JMP_CACHE_SIZE]; }; #endif /* ACCEL_TCG_TB_JMP_CACHE_H */