qom/cpu: atomically clear the tb_jmp_cache

The ThreadSanitizer rightly complains that something initialised with a
normal access is later updated and read atomically.

Backports commit ce7cf6a973f4b614162b9518954d441fa5e32fc6 from qemu
This commit is contained in:
Alex Bennée 2018-02-26 05:08:12 -05:00 committed by Lioncash
parent 12d7e946a1
commit e1cf9ca84a
No known key found for this signature in database
GPG key ID: 4E3C3CC1031BA9C7

View file

@ -155,6 +155,7 @@ void cpu_reset(CPUState *cpu)
static void cpu_common_reset(CPUState *cpu)
{
CPUClass *cc = CPU_GET_CLASS(cpu->uc, cpu);
int i;
if (qemu_loglevel_mask(CPU_LOG_RESET)) {
qemu_log("CPU Reset (CPU %d)\n", cpu->cpu_index);
@ -170,7 +171,10 @@ static void cpu_common_reset(CPUState *cpu)
cpu->can_do_io = 0;
cpu->exception_index = -1;
cpu->crash_occurred = false;
memset(cpu->tb_jmp_cache, 0, TB_JMP_CACHE_SIZE * sizeof(void *));
for (i = 0; i < TB_JMP_CACHE_SIZE; ++i) {
atomic_set(&cpu->tb_jmp_cache[i], NULL);
}
}
static bool cpu_common_has_work(CPUState *cs)