]> git.proxmox.com Git - mirror_qemu.git/commit - target/mips/helper.c
target/mips: Add CP0_Ebase.WG (write gate) support
authorJames Hogan <james.hogan@imgtec.com>
Tue, 18 Jul 2017 11:55:49 +0000 (12:55 +0100)
committerYongbok Kim <yongbok.kim@imgtec.com>
Thu, 20 Jul 2017 21:42:26 +0000 (22:42 +0100)
commit74dbf824a1313b6064bbebb981a7440951d70896
treeecd1b2ca5ee642293b08e9527fbece6fa6298188
parent9658e4c342e6ae0d775101f8f6bb6efb16789af1
target/mips: Add CP0_Ebase.WG (write gate) support

Add support for the CP0_EBase.WG bit, which allows upper bits to be
written (bits 31:30 on MIPS32, or bits 63:30 on MIPS64), along with the
CP0_Config5.CV bit to control whether the exception vector for Cache
Error exceptions is forced into KSeg1.

This is necessary on MIPS32 to support Segmentation Control and Enhanced
Virtual Addressing (EVA) extensions (where KSeg1 addresses may not
represent an unmapped uncached segment).

It is also useful on MIPS64 to allow the exception base to reside in
XKPhys, and possibly out of range of KSEG0 and KSEG1.

Signed-off-by: James Hogan <james.hogan@imgtec.com>
Cc: Yongbok Kim <yongbok.kim@imgtec.com>
Cc: Aurelien Jarno <aurelien@aurel32.net>
Reviewed-by: Yongbok Kim <yongbok.kim@imgtec.com>
[yongbok.kim@imgtec.com:
  minor changes]
Signed-off-by: Yongbok Kim <yongbok.kim@imgtec.com>
target/mips/cpu.h
target/mips/helper.c
target/mips/machine.c
target/mips/op_helper.c
target/mips/translate.c
target/mips/translate_init.c