From: Kirill Batuzov Date: Thu, 2 Dec 2010 13:12:46 +0000 (+0300) Subject: Speedup 'tb_find_slow' by using the same heuristic as during memory page lookup X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=2c90fe2b71df2534884bce96d90cbfcc93aeedb8;p=qemu.git Speedup 'tb_find_slow' by using the same heuristic as during memory page lookup Move the last found TB to the head of the list so it will be found more quickly next time it will be looked for. Signed-off-by: Kirill Batuzov Signed-off-by: Pavel Yushchenko Signed-off-by: Blue Swirl --- diff --git a/cpu-exec.c b/cpu-exec.c index dbdfdccd8c..39e5eeaa8f 100644 --- a/cpu-exec.c +++ b/cpu-exec.c @@ -167,6 +167,12 @@ static TranslationBlock *tb_find_slow(target_ulong pc, tb = tb_gen_code(env, pc, cs_base, flags, 0); found: + /* Move the last found TB to the head of the list */ + if (likely(*ptb1)) { + *ptb1 = tb->phys_hash_next; + tb->phys_hash_next = tb_phys_hash[h]; + tb_phys_hash[h] = tb; + } /* we add the TB in the virtual pc hash table */ env->tb_jmp_cache[tb_jmp_cache_hash_func(pc)] = tb; return tb;