Revision 3233f0d4

b/exec-all.h
205 205
#elif defined(__arm__)
206 206
static inline void tb_set_jmp_target1(unsigned long jmp_addr, unsigned long addr)
207 207
{
208
#if QEMU_GNUC_PREREQ(4, 1)
209
    void __clear_cache(char *beg, char *end);
210
#else
208 211
    register unsigned long _beg __asm ("a1");
209 212
    register unsigned long _end __asm ("a2");
210 213
    register unsigned long _flg __asm ("a3");
214
#endif
211 215

  
212 216
    /* we could use a ldr pc, [pc, #-4] kind of branch and avoid the flush */
213 217
    *(uint32_t *)jmp_addr |= ((addr - (jmp_addr + 8)) >> 2) & 0xffffff;
214 218

  
219
#if QEMU_GNUC_PREREQ(4, 1)
220
    __clear_cache((char *) jmp_addr, (char *) jmp_addr + 4);
221
#else
215 222
    /* flush icache */
216 223
    _beg = jmp_addr;
217 224
    _end = jmp_addr + 4;
218 225
    _flg = 0;
219 226
    __asm __volatile__ ("swi 0x9f0002" : : "r" (_beg), "r" (_end), "r" (_flg));
227
#endif
220 228
}
221 229
#endif
222 230

  
b/tcg/arm/tcg-target.h
69 69

  
70 70
static inline void flush_icache_range(unsigned long start, unsigned long stop)
71 71
{
72
#if QEMU_GNUC_PREREQ(4, 1)
73
    void __clear_cache(char *beg, char *end);
74
    __clear_cache((char *) start, (char *) stop);
75
#else
72 76
    register unsigned long _beg __asm ("a1") = start;
73 77
    register unsigned long _end __asm ("a2") = stop;
74 78
    register unsigned long _flg __asm ("a3") = 0;
75 79
    __asm __volatile__ ("swi 0x9f0002" : : "r" (_beg), "r" (_end), "r" (_flg));
80
#endif
76 81
}

Also available in: Unified diff