cachepc-qemu

Fork of AMDESE/qemu with changes for cachepc side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-qemu
Log | Files | Refs | Submodules | LICENSE | sfeed.txt

cacheflush.h (836B)


      1/*
      2 * Flush the host cpu caches.
      3 *
      4 * This work is licensed under the terms of the GNU GPL, version 2 or later.
      5 * See the COPYING file in the top-level directory.
      6 */
      7
      8#ifndef QEMU_CACHEFLUSH_H
      9#define QEMU_CACHEFLUSH_H
     10
     11/**
     12 * flush_idcache_range:
     13 * @rx: instruction address
     14 * @rw: data address
     15 * @len: length to flush
     16 *
     17 * Flush @len bytes of the data cache at @rw and the icache at @rx
     18 * to bring them in sync.  The two addresses may be different virtual
     19 * mappings of the same physical page(s).
     20 */
     21
     22#if defined(__i386__) || defined(__x86_64__) || defined(__s390__)
     23
     24static inline void flush_idcache_range(uintptr_t rx, uintptr_t rw, size_t len)
     25{
     26    /* icache is coherent and does not require flushing. */
     27}
     28
     29#else
     30
     31void flush_idcache_range(uintptr_t rx, uintptr_t rw, size_t len);
     32
     33#endif
     34
     35#endif /* QEMU_CACHEFLUSH_H */