1. 02 7月, 2011 3 次提交
  2. 28 6月, 2011 2 次提交
  3. 27 6月, 2011 8 次提交
  4. 04 6月, 2011 4 次提交
  5. 29 5月, 2011 1 次提交
  6. 24 5月, 2011 3 次提交
  7. 08 5月, 2011 1 次提交
  8. 24 3月, 2011 1 次提交
  9. 07 3月, 2011 1 次提交
  10. 20 1月, 2011 2 次提交
  11. 12 1月, 2011 1 次提交
  12. 10 1月, 2011 4 次提交
  13. 08 1月, 2011 3 次提交
    • A
      tcg/mips: fix branch target change during code retranslation · d43ffce1
      Aurelien Jarno 提交于
      TCG on MIPS was trying to avoid changing the branch offset, but didn't
      due to a stupid typo. Fix it.
      Signed-off-by: NAurelien Jarno <aurelien@aurel32.net>
      d43ffce1
    • A
      tcg/arm: fix qemu_st64 for big endian targets · 9a3abc21
      Aurelien Jarno 提交于
      Due to a typo, qemu_st64 doesn't properly byteswap the 32-bit low word of
      a 64 bit word before saving it. This patch fixes that.
      Acked-by: NAndrzej Zaborowski <balrogg@gmail.com>
      Signed-off-by: NAurelien Jarno <aurelien@aurel32.net>
      9a3abc21
    • A
      tcg/arm: fix branch target change during code retranslation · c69806ab
      Aurelien Jarno 提交于
      QEMU uses code retranslation to restore the CPU state when an exception
      happens. For it to work the retranslation must not modify the generated
      code. This is what is currently implemented in ARM TCG.
      
      However on CPU that don't have icache/dcache/memory synchronised like
      ARM, this requirement is stronger and code retranslation must not modify
      the generated code "atomically", as the cache line might be flushed
      at any moment (interrupt, exception, task switching), even if not
      triggered by QEMU. The probability for this to happen is very low, and
      depends on cache size and associativiy, machine load, interrupts, so the
      symptoms are might happen randomly.
      
      This requirement is currently not followed in tcg/arm, for the
      load/store code, which basically has the following structure:
        1) tlb access code is written
        2) conditional fast path code is written
        3) branch is written with a temporary target
        4) slow path code is written
        5) branch target is updated
      The cache lines corresponding to the retranslated code is not flushed
      after code retranslation as the generated code is supposed to be the
      same. However if the cache line corresponding to the branch instruction
      is flushed between step 3 and 5, and is not flushed again before the
      code is executed again, the branch target is wrong. In the guest, the
      symptoms are MMU page fault at a random addresses, which leads to
      kernel page fault or segmentation faults.
      
      The patch fixes this issue by avoiding writing the branch target until
      it is known, that is by writing only the branch instruction first, and
      later only the offset.
      
      This fixes booting linux guests on ARM hosts (tested: arm, i386, mips,
      mipsel, sh4, sparc).
      Acked-by: NEdgar E. Iglesias <edgar.iglesias@gmail.com>
      Signed-off-by: NAurelien Jarno <aurelien@aurel32.net>
      c69806ab
  14. 02 12月, 2010 6 次提交