mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-26 20:31:42 +00:00 
			
		
		
		
	riscv: Set xPIE to 1 after xRET
When executing an xRET instruction, supposing xPP holds the value y, xIE is set to xPIE; the privilege mode is changed to y; xPIE is set to 1. But QEMU sets xPIE to 0 incorrectly. Signed-off-by: Yiting Wang <yiting.wang@windriver.com> Reviewed-by: Bin Meng <bmeng.cn@gmail.com> Tested-by: Bin Meng <bmeng.cn@gmail.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Signed-off-by: Palmer Dabbelt <palmerdabbelt@google.com>
This commit is contained in:
		
							parent
							
								
									bb8136df69
								
							
						
					
					
						commit
						a37f21c27d
					
				| @ -93,7 +93,7 @@ target_ulong helper_sret(CPURISCVState *env, target_ulong cpu_pc_deb) | ||||
|         env->priv_ver >= PRIV_VERSION_1_10_0 ? | ||||
|         MSTATUS_SIE : MSTATUS_UIE << prev_priv, | ||||
|         get_field(mstatus, MSTATUS_SPIE)); | ||||
|     mstatus = set_field(mstatus, MSTATUS_SPIE, 0); | ||||
|     mstatus = set_field(mstatus, MSTATUS_SPIE, 1); | ||||
|     mstatus = set_field(mstatus, MSTATUS_SPP, PRV_U); | ||||
|     riscv_cpu_set_mode(env, prev_priv); | ||||
|     env->mstatus = mstatus; | ||||
| @ -118,7 +118,7 @@ target_ulong helper_mret(CPURISCVState *env, target_ulong cpu_pc_deb) | ||||
|         env->priv_ver >= PRIV_VERSION_1_10_0 ? | ||||
|         MSTATUS_MIE : MSTATUS_UIE << prev_priv, | ||||
|         get_field(mstatus, MSTATUS_MPIE)); | ||||
|     mstatus = set_field(mstatus, MSTATUS_MPIE, 0); | ||||
|     mstatus = set_field(mstatus, MSTATUS_MPIE, 1); | ||||
|     mstatus = set_field(mstatus, MSTATUS_MPP, PRV_U); | ||||
|     riscv_cpu_set_mode(env, prev_priv); | ||||
|     env->mstatus = mstatus; | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Yiting Wang
						Yiting Wang