]> git.proxmox.com Git - mirror_qemu.git/commit - monitor.c
Great PowerPC emulation code resynchronisation and improvments:
authorj_mayer <j_mayer@c046a42c-6fe2-441c-8c8c-71466251a162>
Wed, 7 Mar 2007 08:32:30 +0000 (08:32 +0000)
committerj_mayer <j_mayer@c046a42c-6fe2-441c-8c8c-71466251a162>
Wed, 7 Mar 2007 08:32:30 +0000 (08:32 +0000)
commit76a66253e5e48f1744f689041c1c21cedcaff630
treec1003bd73ab8e2cbfe4a05c5b3f497bc2573fa4e
parent1c7b3754f68382941a1921e578ead25d97d116fb
Great PowerPC emulation code resynchronisation and improvments:
- Add status file to make regression tracking easier
- Move all micro-operations helpers definitions into a separate header:
  should never be seen outside of op.c
- Update copyrights
- Add new / missing PowerPC CPU definitions
- Add definitions for PowerPC BookE
- Add support for PowerPC 6xx/7xx software driven TLBs
  Allow use of PowerPC 603 as an example
- Add preliminary code for POWER, POWER2, PowerPC 403, 405, 440, 601, 602
  and BookE support
- Avoid compiling priviledged only resources support for user-mode emulation
- Remove unused helpers / micro-ops / dead code
- Add instructions usage statistics dump: useful to figure which instructions
  need strong optimizations.
- Micro-operation fixes:
  * add missing RETURN in some micro-ops
  * fix prototypes
  * use softfloat routines for all floating-point operations
  * fix tlbie instruction
  * move some huge micro-operations into helpers
- emulation fixes:
  * fix inverted opcodes for fcmpo / fcmpu
  * condition register update is always to be done after the whole
    instruction has completed
  * add missing NIP updates when calling helpers that may generate an
    exception
- optimizations and improvments:
  * optimize very often used instructions (li, mr, rlwixx...)
  * remove specific micro-ops for rarely used instructions
  * add routines for addresses computations to avoid bugs due to multiple
    different implementations
  * fix TB linking: do not reset T0 at the end of every TB.

git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2473 c046a42c-6fe2-441c-8c8c-71466251a162
19 files changed:
cpu-all.h
gdbstub.c
hw/ppc.c
linux-user/main.c
monitor.c
target-ppc/STATUS [new file with mode: 0644]
target-ppc/cpu.h
target-ppc/exec.h
target-ppc/helper.c
target-ppc/mfrom_table.c [new file with mode: 0644]
target-ppc/mfrom_table_gen.c [new file with mode: 0644]
target-ppc/op.c
target-ppc/op_helper.c
target-ppc/op_helper.h [new file with mode: 0644]
target-ppc/op_helper_mem.h
target-ppc/op_mem.h
target-ppc/op_template.h
target-ppc/translate.c
target-ppc/translate_init.c