mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-26 12:03:40 +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; |     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, | static RISCVException write_hgeie(CPURISCVState *env, int csrno, | ||||||
|                                   target_ulong val) |                                   target_ulong val) | ||||||
| { | { | ||||||
|  |     if (val) { | ||||||
|         qemu_log_mask(LOG_UNIMP, "No support for a non-zero GEILEN."); |         qemu_log_mask(LOG_UNIMP, "No support for a non-zero GEILEN."); | ||||||
|  |     } | ||||||
|     return RISCV_EXCP_NONE; |     return RISCV_EXCP_NONE; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -1165,17 +1160,12 @@ static RISCVException write_htinst(CPURISCVState *env, int csrno, | |||||||
|     return RISCV_EXCP_NONE; |     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, | static RISCVException write_hgeip(CPURISCVState *env, int csrno, | ||||||
|                                   target_ulong val) |                                   target_ulong val) | ||||||
| { | { | ||||||
|  |     if (val) { | ||||||
|         qemu_log_mask(LOG_UNIMP, "No support for a non-zero GEILEN."); |         qemu_log_mask(LOG_UNIMP, "No support for a non-zero GEILEN."); | ||||||
|  |     } | ||||||
|     return RISCV_EXCP_NONE; |     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_HIP]         = { "hip",         hmode,   NULL,   NULL,     rmw_hip           }, | ||||||
|     [CSR_HIE]         = { "hie",         hmode,   read_hie,         write_hie         }, |     [CSR_HIE]         = { "hie",         hmode,   read_hie,         write_hie         }, | ||||||
|     [CSR_HCOUNTEREN]  = { "hcounteren",  hmode,   read_hcounteren,  write_hcounteren  }, |     [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_HTVAL]       = { "htval",       hmode,   read_htval,       write_htval       }, | ||||||
|     [CSR_HTINST]      = { "htinst",      hmode,   read_htinst,      write_htinst      }, |     [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_HGATP]       = { "hgatp",       hmode,   read_hgatp,       write_hgatp       }, | ||||||
|     [CSR_HTIMEDELTA]  = { "htimedelta",  hmode,   read_htimedelta,  write_htimedelta  }, |     [CSR_HTIMEDELTA]  = { "htimedelta",  hmode,   read_htimedelta,  write_htimedelta  }, | ||||||
|     [CSR_HTIMEDELTAH] = { "htimedeltah", hmode32, read_htimedeltah, write_htimedeltah }, |     [CSR_HTIMEDELTAH] = { "htimedeltah", hmode32, read_htimedeltah, write_htimedeltah }, | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Richard Henderson
						Richard Henderson