@@ -268,7 +268,9 @@ void state_t::csr_init(processor_t* const proc, reg_t max_isa)
268268 (proc->extension_enabled (EXT_ZICFILP) ? MENVCFG_LPE : 0 ) |
269269 (proc->extension_enabled (EXT_ZICFISS) ? MENVCFG_SSE : 0 ) |
270270 (proc->extension_enabled (EXT_SSDBLTRP) ? MENVCFG_DTE : 0 );
271- menvcfg = std::make_shared<envcfg_csr_t >(proc, CSR_MENVCFG, menvcfg_mask, 0 );
271+ const reg_t menvcfg_init = (proc->extension_enabled (EXT_ZICBOM) ? MENVCFG_CBCFE | MENVCFG_CBIE : 0 ) |
272+ (proc->extension_enabled (EXT_ZICBOZ) ? MENVCFG_CBZE : 0 );
273+ menvcfg = std::make_shared<envcfg_csr_t >(proc, CSR_MENVCFG, menvcfg_mask, menvcfg_init);
272274 if (xlen == 32 ) {
273275 add_user_csr (CSR_MENVCFG, std::make_shared<rv32_low_csr_t >(proc, CSR_MENVCFG, menvcfg));
274276 add_user_csr (CSR_MENVCFGH, std::make_shared<rv32_high_csr_t >(proc, CSR_MENVCFGH, menvcfg));
@@ -280,7 +282,10 @@ void state_t::csr_init(processor_t* const proc, reg_t max_isa)
280282 (proc->extension_enabled (EXT_SSNPM) ? SENVCFG_PMM : 0 ) |
281283 (proc->extension_enabled (EXT_ZICFILP) ? SENVCFG_LPE : 0 ) |
282284 (proc->extension_enabled (EXT_ZICFISS) ? SENVCFG_SSE : 0 );
283- add_supervisor_csr (CSR_SENVCFG, senvcfg = std::make_shared<senvcfg_csr_t >(proc, CSR_SENVCFG, senvcfg_mask, 0 ));
285+ const reg_t senvcfg_init = (proc->extension_enabled (EXT_ZICBOM) ? SENVCFG_CBCFE | SENVCFG_CBIE : 0 ) |
286+ (proc->extension_enabled (EXT_ZICBOZ) ? SENVCFG_CBZE : 0 );
287+ add_supervisor_csr (CSR_SENVCFG, senvcfg = std::make_shared<senvcfg_csr_t >(proc, CSR_SENVCFG, senvcfg_mask, senvcfg_init));
288+
284289 const reg_t henvcfg_mask = (proc->extension_enabled (EXT_ZICBOM) ? HENVCFG_CBCFE | HENVCFG_CBIE : 0 ) |
285290 (proc->extension_enabled (EXT_ZICBOZ) ? HENVCFG_CBZE : 0 ) |
286291 (proc->extension_enabled (EXT_SSNPM) ? HENVCFG_PMM : 0 ) |
@@ -290,7 +295,9 @@ void state_t::csr_init(processor_t* const proc, reg_t max_isa)
290295 (proc->extension_enabled (EXT_ZICFILP) ? HENVCFG_LPE : 0 ) |
291296 (proc->extension_enabled (EXT_ZICFISS) ? HENVCFG_SSE : 0 ) |
292297 (proc->extension_enabled (EXT_SSDBLTRP) ? HENVCFG_DTE : 0 );
293- henvcfg = std::make_shared<henvcfg_csr_t >(proc, CSR_HENVCFG, henvcfg_mask, 0 , menvcfg);
298+ const reg_t henvcfg_init = (proc->extension_enabled (EXT_ZICBOM) ? HENVCFG_CBCFE | HENVCFG_CBIE : 0 ) |
299+ (proc->extension_enabled (EXT_ZICBOZ) ? HENVCFG_CBZE : 0 );
300+ henvcfg = std::make_shared<henvcfg_csr_t >(proc, CSR_HENVCFG, henvcfg_mask, henvcfg_init, menvcfg);
294301 if (xlen == 32 ) {
295302 add_hypervisor_csr (CSR_HENVCFG, std::make_shared<rv32_low_csr_t >(proc, CSR_HENVCFG, henvcfg));
296303 add_hypervisor_csr (CSR_HENVCFGH, std::make_shared<rv32_high_csr_t >(proc, CSR_HENVCFGH, henvcfg));
0 commit comments