mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-26 03:33:28 +00:00 
			
		
		
		
	target/riscv: Fix hgeie, hgeip
We failed to write into *val for these read functions; replace them with read_zero. Only warn about unsupported non-zero value when writing a non-zero value. Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Bin Meng <bmeng.cn@gmail.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Message-id: 20210823195529.560295-18-richard.henderson@linaro.org Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
This commit is contained in:
		
							parent
							
								
									33979526ca
								
							
						
					
					
						commit
						377cbb4bdb
					
				| @ -1124,17 +1124,12 @@ static RISCVException write_hcounteren(CPURISCVState *env, int csrno, | ||||
|     return RISCV_EXCP_NONE; | ||||
| } | ||||
| 
 | ||||
| static RISCVException read_hgeie(CPURISCVState *env, int csrno, | ||||
|                                  target_ulong *val) | ||||
| { | ||||
|     qemu_log_mask(LOG_UNIMP, "No support for a non-zero GEILEN."); | ||||
|     return RISCV_EXCP_NONE; | ||||
| } | ||||
| 
 | ||||
| static RISCVException write_hgeie(CPURISCVState *env, int csrno, | ||||
|                                   target_ulong val) | ||||
| { | ||||
|     qemu_log_mask(LOG_UNIMP, "No support for a non-zero GEILEN."); | ||||
|     if (val) { | ||||
|         qemu_log_mask(LOG_UNIMP, "No support for a non-zero GEILEN."); | ||||
|     } | ||||
|     return RISCV_EXCP_NONE; | ||||
| } | ||||
| 
 | ||||
| @ -1165,17 +1160,12 @@ static RISCVException write_htinst(CPURISCVState *env, int csrno, | ||||
|     return RISCV_EXCP_NONE; | ||||
| } | ||||
| 
 | ||||
| static RISCVException read_hgeip(CPURISCVState *env, int csrno, | ||||
|                                  target_ulong *val) | ||||
| { | ||||
|     qemu_log_mask(LOG_UNIMP, "No support for a non-zero GEILEN."); | ||||
|     return RISCV_EXCP_NONE; | ||||
| } | ||||
| 
 | ||||
| static RISCVException write_hgeip(CPURISCVState *env, int csrno, | ||||
|                                   target_ulong val) | ||||
| { | ||||
|     qemu_log_mask(LOG_UNIMP, "No support for a non-zero GEILEN."); | ||||
|     if (val) { | ||||
|         qemu_log_mask(LOG_UNIMP, "No support for a non-zero GEILEN."); | ||||
|     } | ||||
|     return RISCV_EXCP_NONE; | ||||
| } | ||||
| 
 | ||||
| @ -1601,10 +1591,10 @@ riscv_csr_operations csr_ops[CSR_TABLE_SIZE] = { | ||||
|     [CSR_HIP]         = { "hip",         hmode,   NULL,   NULL,     rmw_hip           }, | ||||
|     [CSR_HIE]         = { "hie",         hmode,   read_hie,         write_hie         }, | ||||
|     [CSR_HCOUNTEREN]  = { "hcounteren",  hmode,   read_hcounteren,  write_hcounteren  }, | ||||
|     [CSR_HGEIE]       = { "hgeie",       hmode,   read_hgeie,       write_hgeie       }, | ||||
|     [CSR_HGEIE]       = { "hgeie",       hmode,   read_zero,        write_hgeie       }, | ||||
|     [CSR_HTVAL]       = { "htval",       hmode,   read_htval,       write_htval       }, | ||||
|     [CSR_HTINST]      = { "htinst",      hmode,   read_htinst,      write_htinst      }, | ||||
|     [CSR_HGEIP]       = { "hgeip",       hmode,   read_hgeip,       write_hgeip       }, | ||||
|     [CSR_HGEIP]       = { "hgeip",       hmode,   read_zero,        write_hgeip       }, | ||||
|     [CSR_HGATP]       = { "hgatp",       hmode,   read_hgatp,       write_hgatp       }, | ||||
|     [CSR_HTIMEDELTA]  = { "htimedelta",  hmode,   read_htimedelta,  write_htimedelta  }, | ||||
|     [CSR_HTIMEDELTAH] = { "htimedeltah", hmode32, read_htimedeltah, write_htimedeltah }, | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Richard Henderson
						Richard Henderson