diff --git a/CHANGELOG.md b/CHANGELOG.md
index 844f8473b..d6c883b86 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -29,6 +29,8 @@ mimpid = 0x01040312 -> Version 01.04.03.12 -> v1.4.3.12
| Date | Version | Comment | Ticket |
|:----:|:-------:|:--------|:------:|
+| 29.12.2024 | 1.10.8.4 | :warning: rename `SYSINFO.MEM -> SYSINFO.MISC`; add new `SYSINFO-MISC` entry for number of CPU cores (hardwired to one) | [#1134](https://github.com/stnolting/neorv32/pull/1134) |
+| 29.12.2024 | 1.10.8.3 | :bug: fix incorrect HPM counter sizes if `HPM_CNT_WIDTH = 64` | [#1128](https://github.com/stnolting/neorv32/pull/1128) |
| 27.12.2024 | 1.10.8.2 | add out-of-band signals to internal request bus | [#1131](https://github.com/stnolting/neorv32/pull/1131) |
| 27.12.2024 | 1.10.8.1 | :warning: replace MTIME by CLINT; :warning: remove `HART_ID` generic | [#1130](https://github.com/stnolting/neorv32/pull/1130) |
| 26.12.2024 | [**:rocket:1.10.8**](https://github.com/stnolting/neorv32/releases/tag/v1.10.8) | **New release** | |
diff --git a/docs/datasheet/soc_sysinfo.adoc b/docs/datasheet/soc_sysinfo.adoc
index 575183db8..83b181932 100644
--- a/docs/datasheet/soc_sysinfo.adoc
+++ b/docs/datasheet/soc_sysinfo.adoc
@@ -42,14 +42,14 @@ to take into account a dynamic frequency scaling of the processor.
[options="header",grid="all"]
|=======================
| Address | Name [C] | R/W | Description
-| `0xfffe0000` | `CLK` | r/w | clock frequency in Hz (initialized from top's `CLOCK_FREQUENCY` generic)
-| `0xfffe0004` | `MEM[4]` | r/- | internal memory configuration (see <<_sysinfo_memory_configuration>>)
-| `0xfffe0008` | `SOC` | r/- | specific SoC configuration (see <<_sysinfo_soc_configuration>>)
-| `0xfffe000c` | `CACHE` | r/- | cache configuration information (see <<_sysinfo_cache_configuration>>)
+| `0xfffe0000` | `CLK` | r/w | clock frequency in Hz (initialized from top's `CLOCK_FREQUENCY` generic)
+| `0xfffe0004` | `MISC[4]` | r/- | miscellaneous system configurations (see <<_sysinfo_miscellaneous_configuration>>)
+| `0xfffe0008` | `SOC` | r/- | specific SoC configuration (see <<_sysinfo_soc_configuration>>)
+| `0xfffe000c` | `CACHE` | r/- | cache configuration information (see <<_sysinfo_cache_configuration>>)
|=======================
-===== SYSINFO - Memory Configuration
+===== SYSINFO - Miscellaneous Configuration
[NOTE]
Bit fields in this register are set to all-zero if the according memory system is not implemented.
@@ -59,10 +59,10 @@ Bit fields in this register are set to all-zero if the according memory system i
[options="header",grid="all"]
|=======================
| Byte | Name [C] | Description
-| `0` | `SYSINFO_MEM_IMEM` | _log2_(internal IMEM size in bytes), via top's `MEM_INT_IMEM_SIZE` generic
-| `1` | `SYSINFO_MEM_DMEM` | _log2_(internal DMEM size in bytes), via top's `MEM_INT_DMEM_SIZE` generic
-| `2` | - | _reserved_, read as zero
-| `3` | `SYSINFO_MEM_BOOT` | boot mode configuration, via top's `BOOT_MODE_SELECT` generic (see <<_boot_configuration>>))
+| `0` | `SYSINFO_MISC_IMEM` | _log2_(internal IMEM size in bytes), via top's `MEM_INT_IMEM_SIZE` generic
+| `1` | `SYSINFO_MISC_DMEM` | _log2_(internal DMEM size in bytes), via top's `MEM_INT_DMEM_SIZE` generic
+| `2` | `SYSINFO_MISC_HART` | number of physical CPU cores ("harts")
+| `3` | `SYSINFO_MISC_BOOT` | boot mode configuration, via top's `BOOT_MODE_SELECT` generic (see <<_boot_configuration>>))
|=======================
@@ -110,8 +110,12 @@ Bit fields in this register are set to all-zero if the according memory system i
===== SYSINFO - Cache Configuration
-[NOTE]
-Bit fields in this register are set to all-zero if the according cache is not implemented.
+The SYSINFO cache register provides information about the configuration of the processor caches:
+
+* <<_processor_internal_instruction_cache_icache>>
+* <<_processor_internal_data_cache_dcache>>
+* <<_execute_in_place_module_xip>> cache (XIP-CACHE)
+* <<_processor_external_bus_interface_xbus>> cache (XBUS-CACHE)
.SYSINFO `CACHE` Bits
[cols="^1,<10,<10"]
diff --git a/docs/datasheet/soc_xbus.adoc b/docs/datasheet/soc_xbus.adoc
index 837999d42..64760fb1c 100644
--- a/docs/datasheet/soc_xbus.adoc
+++ b/docs/datasheet/soc_xbus.adoc
@@ -110,7 +110,7 @@ It compatible to the the AXI4 `ARPROT` and `AWPROT` signals.
* `xbus_tag_o(2)` **I**: access is an **instruction** fetch when set; access is a data access when cleared
-**External Bus Cache (X-CACHE)**
+**External Bus Cache (XBUS-CACHE)**
The XBUS interface provides an optional internal cache that can be used to buffer processor-external accesses.
The x-cache is enabled via the `XBUS_CACHE_EN` generic. The total size of the cache is split into the number of
diff --git a/rtl/core/neorv32_bus.vhd b/rtl/core/neorv32_bus.vhd
index bf03d9224..df37c77d5 100644
--- a/rtl/core/neorv32_bus.vhd
+++ b/rtl/core/neorv32_bus.vhd
@@ -1,8 +1,5 @@
-- ================================================================================ --
--- NEORV32 SoC - Processor Bus Infrastructure: Prioritizing 2-to-1 Bus Switch --
--- -------------------------------------------------------------------------------- --
--- Allows to access a single device bus X by two controller ports A and B. --
--- Controller port A has priority over controller port B. --
+-- NEORV32 SoC - Processor Bus Infrastructure: 2-to-1 Bus Switch --
-- -------------------------------------------------------------------------------- --
-- The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 --
-- Copyright (c) NEORV32 contributors. --
diff --git a/rtl/core/neorv32_cpu_control.vhd b/rtl/core/neorv32_cpu_control.vhd
index 1ddfaf71d..bf1a1fe1b 100644
--- a/rtl/core/neorv32_cpu_control.vhd
+++ b/rtl/core/neorv32_cpu_control.vhd
@@ -115,7 +115,7 @@ architecture neorv32_cpu_control_rtl of neorv32_cpu_control is
-- HPM counter auto-configuration --
constant hpm_num_c : natural := cond_sel_natural_f(RISCV_ISA_Zihpm, HPM_NUM_CNTS, 0);
constant hpm_cnt_lo_width_c : natural := min_natural_f(HPM_CNT_WIDTH, 32); -- size low word
- constant hpm_cnt_hi_width_c : natural := (HPM_CNT_WIDTH / 32) * (HPM_CNT_WIDTH rem 32); -- size high word
+ constant hpm_cnt_hi_width_c : natural := HPM_CNT_WIDTH - hpm_cnt_lo_width_c; -- size high word
-- instruction fetch engine --
type fetch_engine_state_t is (IF_RESTART, IF_REQUEST, IF_PENDING);
diff --git a/rtl/core/neorv32_cpu_pmp.vhd b/rtl/core/neorv32_cpu_pmp.vhd
index daf22ce85..5f2dc6fcc 100644
--- a/rtl/core/neorv32_cpu_pmp.vhd
+++ b/rtl/core/neorv32_cpu_pmp.vhd
@@ -251,10 +251,9 @@ begin
region_gen:
for r in 0 to NUM_REGIONS-1 generate
- -- naturally-aligned address mask --
+ -- NAPOT address mask --
nap_mode_enable:
if NAP_EN generate
-
-- compute address masks for NAPOT mode --
addr_mask_napot(r)(pmp_lsb_c) <= '0';
addr_mask_napot_gen:
@@ -275,9 +274,15 @@ begin
end if;
end if;
end process addr_masking;
-
end generate; -- /nap_mode_enable
+ -- NAPOT disabled --
+ nap_mode_disable:
+ if not NAP_EN generate
+ addr_mask_napot <= (others => (others => '0'));
+ addr_mask <= (others => (others => '0'));
+ end generate;
+
-- check region address match --
-- NA4 and NAPOT --
diff --git a/rtl/core/neorv32_debug_auth.vhd b/rtl/core/neorv32_debug_auth.vhd
index c264cf98e..efe5b0b3b 100644
--- a/rtl/core/neorv32_debug_auth.vhd
+++ b/rtl/core/neorv32_debug_auth.vhd
@@ -1,5 +1,5 @@
-- ================================================================================ --
--- NEORV32 SoC - RISC-V-Compatible Authentication Module for the On-Chip Debugger --
+-- NEORV32 OCD - RISC-V-Compatible Authentication Module for the On-Chip Debugger --
-- -------------------------------------------------------------------------------- --
-- Note that this module (in its default state) just provides a very simple and --
-- UNSECURE authentication mechanism that is meant as an example to showcase the --
@@ -39,7 +39,7 @@ end neorv32_debug_auth;
architecture neorv32_debug_auth_rtl of neorv32_debug_auth is
- signal authenticated : std_ulogic;
+ signal authenticated_q : std_ulogic;
begin
@@ -53,12 +53,12 @@ begin
dm_controller: process(rstn_i, clk_i)
begin
if (rstn_i = '0') then
- authenticated <= '0';
+ authenticated_q <= '0';
elsif rising_edge(clk_i) then
if (enable_i = '0') then
- authenticated <= '0'; -- clear authentication when disabled
+ authenticated_q <= '0'; -- clear authentication when disabled
elsif (we_i = '1') then
- authenticated <= wdata_i(0); -- just write a 1 to authenticate
+ authenticated_q <= wdata_i(0); -- just write a "1" to authenticate
end if;
end if;
end process dm_controller;
@@ -67,7 +67,7 @@ begin
busy_o <= '0'; -- this simple authenticator is always ready
-- authentication passed --
- valid_o <= authenticated;
+ valid_o <= authenticated_q;
-- read data --
rdata_o <= (others => '0'); -- there is nothing to read here
diff --git a/rtl/core/neorv32_debug_dtm.vhd b/rtl/core/neorv32_debug_dtm.vhd
index 8b97e53b0..901025afe 100644
--- a/rtl/core/neorv32_debug_dtm.vhd
+++ b/rtl/core/neorv32_debug_dtm.vhd
@@ -1,5 +1,5 @@
-- ================================================================================ --
--- NEORV32 SoC - RISC-V-Compatible Debug Transport Module (DTM) --
+-- NEORV32 OCD - RISC-V-Compatible Debug Transport Module (DTM) --
-- -------------------------------------------------------------------------------- --
-- Compatible to RISC-V debug spec. versions 0.13 and 1.0. --
-- -------------------------------------------------------------------------------- --
@@ -111,7 +111,7 @@ begin
tap_sync.tdi <= tap_sync.tdi_ff(2);
- -- Tap Control FSM ------------------------------------------------------------------------
+ -- JTAG Tap Control FSM -------------------------------------------------------------------
-- -------------------------------------------------------------------------------------------
tap_control: process(rstn_i, clk_i)
begin
diff --git a/rtl/core/neorv32_package.vhd b/rtl/core/neorv32_package.vhd
index 0910d5cc6..79e790f17 100644
--- a/rtl/core/neorv32_package.vhd
+++ b/rtl/core/neorv32_package.vhd
@@ -29,7 +29,7 @@ package neorv32_package is
-- Architecture Constants -----------------------------------------------------------------
-- -------------------------------------------------------------------------------------------
- constant hw_version_c : std_ulogic_vector(31 downto 0) := x"01100802"; -- hardware version
+ constant hw_version_c : std_ulogic_vector(31 downto 0) := x"01100804"; -- hardware version
constant archid_c : natural := 19; -- official RISC-V architecture ID
constant XLEN : natural := 32; -- native data path width
diff --git a/rtl/core/neorv32_sysinfo.vhd b/rtl/core/neorv32_sysinfo.vhd
index 65f5003b0..168eea9d6 100644
--- a/rtl/core/neorv32_sysinfo.vhd
+++ b/rtl/core/neorv32_sysinfo.vhd
@@ -17,6 +17,7 @@ use neorv32.neorv32_package.all;
entity neorv32_sysinfo is
generic (
+ NUM_HARTS : natural; -- number of physical CPU cores
CLOCK_FREQUENCY : natural; -- clock frequency of clk_i in Hz
BOOT_MODE_SELECT : natural; -- boot configuration select (default = 0 = bootloader)
INT_BOOTLOADER_EN : boolean; -- boot configuration: true = boot explicit bootloader; false = boot from int/ext (I)MEM
@@ -106,7 +107,7 @@ begin
-- SYSINFO(1): Misc --
sysinfo(1)(7 downto 0) <= std_ulogic_vector(to_unsigned(index_size_f(MEM_INT_IMEM_SIZE), 8)); -- log2(IMEM size)
sysinfo(1)(15 downto 8) <= std_ulogic_vector(to_unsigned(index_size_f(MEM_INT_DMEM_SIZE), 8)); -- log2(DMEM size)
- sysinfo(1)(23 downto 16) <= (others => '0'); -- reserved
+ sysinfo(1)(23 downto 16) <= std_ulogic_vector(to_unsigned(NUM_HARTS, 8)); -- number of physical CPU cores
sysinfo(1)(31 downto 24) <= std_ulogic_vector(to_unsigned(BOOT_MODE_SELECT, 8)); -- boot configuration
-- SYSINFO(2): SoC Configuration --
diff --git a/rtl/core/neorv32_top.vhd b/rtl/core/neorv32_top.vhd
index 0f9638941..319ebb0d4 100644
--- a/rtl/core/neorv32_top.vhd
+++ b/rtl/core/neorv32_top.vhd
@@ -1593,6 +1593,7 @@ begin
if io_sysinfo_en_c generate
neorv32_sysinfo_inst: entity neorv32.neorv32_sysinfo
generic map (
+ NUM_HARTS => 1,
CLOCK_FREQUENCY => CLOCK_FREQUENCY,
BOOT_MODE_SELECT => BOOT_MODE_SELECT,
INT_BOOTLOADER_EN => bootrom_en_c,
diff --git a/sw/bootloader/bootloader.c b/sw/bootloader/bootloader.c
index fdc1da2f9..ce411d9ea 100644
--- a/sw/bootloader/bootloader.c
+++ b/sw/bootloader/bootloader.c
@@ -305,9 +305,9 @@ int main(void) {
PRINT_TEXT("\nSOC: ");
PRINT_XNUM(NEORV32_SYSINFO->SOC);
PRINT_TEXT("\nIMEM: ");
- PRINT_XNUM((uint32_t)(1 << NEORV32_SYSINFO->MEM[SYSINFO_MEM_IMEM]) & 0xFFFFFFFCUL);
+ PRINT_XNUM((uint32_t)(1 << NEORV32_SYSINFO->MISC[SYSINFO_MISC_IMEM]) & 0xFFFFFFFCUL);
PRINT_TEXT("\nDMEM: ");
- PRINT_XNUM((uint32_t)(1 << NEORV32_SYSINFO->MEM[SYSINFO_MEM_DMEM]) & 0xFFFFFFFCUL);
+ PRINT_XNUM((uint32_t)(1 << NEORV32_SYSINFO->MISC[SYSINFO_MISC_DMEM]) & 0xFFFFFFFCUL);
PRINT_TEXT("\n");
diff --git a/sw/lib/include/neorv32_sysinfo.h b/sw/lib/include/neorv32_sysinfo.h
index 58d775b34..e15b9a580 100644
--- a/sw/lib/include/neorv32_sysinfo.h
+++ b/sw/lib/include/neorv32_sysinfo.h
@@ -25,21 +25,21 @@
/**@{*/
/** SYSINFO module prototype */
typedef volatile struct __attribute__((packed,aligned(4))) {
- uint32_t CLK; /**< offset 0: Clock speed in Hz */
- const uint8_t MEM[4]; /**< offset 4: Internal memory sizes (#NEORV32_SYSINFO_MEM_enum) */
- const uint32_t SOC; /**< offset 8: SoC features (#NEORV32_SYSINFO_SOC_enum) */
- const uint32_t CACHE; /**< offset 12: Cache configuration (#NEORV32_SYSINFO_CACHE_enum) */
+ uint32_t CLK; /**< offset 0: Clock speed in Hz */
+ const uint8_t MISC[4]; /**< offset 4: Miscellaneous system configurations (#NEORV32_SYSINFO_MISC_enum) */
+ const uint32_t SOC; /**< offset 8: SoC features (#NEORV32_SYSINFO_SOC_enum) */
+ const uint32_t CACHE; /**< offset 12: Cache configuration (#NEORV32_SYSINFO_CACHE_enum) */
} neorv32_sysinfo_t;
/** SYSINFO module hardware access (#neorv32_sysinfo_t) */
#define NEORV32_SYSINFO ((neorv32_sysinfo_t*) (NEORV32_SYSINFO_BASE))
-/** NEORV32_SYSINFO.MEM (r/-): Memory configuration (sizes) */
-enum NEORV32_SYSINFO_MEM_enum {
- SYSINFO_MEM_IMEM = 0, /**< SYSINFO_MEM byte 0 (r/-): log2(internal IMEM size in bytes) (via MEM_INT_IMEM_SIZE generic) */
- SYSINFO_MEM_DMEM = 1, /**< SYSINFO_MEM byte 1 (r/-): log2(internal DMEM size in bytes) (via MEM_INT_DMEM_SIZE generic) */
- SYSINFO_MEM_res = 2, /**< SYSINFO_MEM byte 2 (r/-): reserved, read as zero */
- SYSINFO_MEM_BOOT = 3 /**< SYSINFO_MEM byte 3 (r/-): boot mode configuration (via BOOT_MODE_SELECT generic) */
+/** NEORV32_SYSINFO.MISC (r/-): Miscellaneous system configurations */
+enum NEORV32_SYSINFO_MISC_enum {
+ SYSINFO_MISC_IMEM = 0, /**< SYSINFO_MISC byte 0 (r/-): log2(internal IMEM size in bytes) (via MEM_INT_IMEM_SIZE generic) */
+ SYSINFO_MISC_DMEM = 1, /**< SYSINFO_MISC byte 1 (r/-): log2(internal DMEM size in bytes) (via MEM_INT_DMEM_SIZE generic) */
+ SYSINFO_MISC_HART = 2, /**< SYSINFO_MISC byte 2 (r/-): number of physical CPU cores ("harts") */
+ SYSINFO_MISC_BOOT = 3 /**< SYSINFO_MISC byte 3 (r/-): boot mode configuration (via BOOT_MODE_SELECT generic) */
};
/** NEORV32_SYSINFO.SOC (r/-): Implemented processor devices/features */
diff --git a/sw/lib/source/neorv32_rte.c b/sw/lib/source/neorv32_rte.c
index 5698f4eae..1cb1fffb2 100644
--- a/sw/lib/source/neorv32_rte.c
+++ b/sw/lib/source/neorv32_rte.c
@@ -399,6 +399,8 @@ void neorv32_rte_print_hw_config(void) {
if (neorv32_cpu_csr_read(CSR_MXISA) & (1 << CSR_MXISA_IS_SIM)) { neorv32_uart0_printf("yes\n"); }
else { neorv32_uart0_printf("no\n"); }
+ neorv32_uart0_printf("CPU cores (harts): %u\n", (uint32_t)NEORV32_SYSINFO->MISC[SYSINFO_MISC_HART]);
+
neorv32_uart0_printf("Clock speed: %u Hz\n", neorv32_sysinfo_get_clk());
neorv32_uart0_printf("Clock gating: ");
@@ -527,7 +529,7 @@ void neorv32_rte_print_hw_config(void) {
}
neorv32_uart0_printf("\nBoot configuration: ");
- int boot_config = (int)(NEORV32_SYSINFO->MEM[SYSINFO_MEM_BOOT]);
+ int boot_config = (int)(NEORV32_SYSINFO->MISC[SYSINFO_MISC_BOOT]);
switch (boot_config) {
case 0: neorv32_uart0_printf("boot via bootloader (0)\n"); break;
case 1: neorv32_uart0_printf("boot from custom address (1)\n"); break;
@@ -538,7 +540,7 @@ void neorv32_rte_print_hw_config(void) {
// internal IMEM
neorv32_uart0_printf("Internal IMEM: ");
if (NEORV32_SYSINFO->SOC & (1 << SYSINFO_SOC_MEM_INT_IMEM)) {
- neorv32_uart0_printf("%u bytes\n", (uint32_t)(1 << NEORV32_SYSINFO->MEM[SYSINFO_MEM_IMEM]) & 0xFFFFFFFCUL);
+ neorv32_uart0_printf("%u bytes\n", (uint32_t)(1 << NEORV32_SYSINFO->MISC[SYSINFO_MISC_IMEM]) & 0xFFFFFFFCUL);
}
else {
neorv32_uart0_printf("none\n");
@@ -547,7 +549,7 @@ void neorv32_rte_print_hw_config(void) {
// internal DMEM
neorv32_uart0_printf("Internal DMEM: ");
if (NEORV32_SYSINFO->SOC & (1 << SYSINFO_SOC_MEM_INT_DMEM)) {
- neorv32_uart0_printf("%u bytes\n", (uint32_t)(1 << NEORV32_SYSINFO->MEM[SYSINFO_MEM_DMEM]) & 0xFFFFFFFCUL);
+ neorv32_uart0_printf("%u bytes\n", (uint32_t)(1 << NEORV32_SYSINFO->MISC[SYSINFO_MISC_DMEM]) & 0xFFFFFFFCUL);
}
else {
neorv32_uart0_printf("none\n");
diff --git a/sw/svd/neorv32.svd b/sw/svd/neorv32.svd
index 9172ba4d5..356a415c1 100644
--- a/sw/svd/neorv32.svd
+++ b/sw/svd/neorv32.svd
@@ -1745,14 +1745,14 @@
MEM
- Memory configuration (sizes)
+ Miscellaneous system configurations
0x04
read-only
- SYSINFO_MEM_IMEM[7:0]log2(IMEM size in bytes)
- SYSINFO_MEM_DMEM[15:8]log2(DMEM size in bytes)
- SYSINFO_MEM_res[23:16]yet unused
- SYSINFO_MEM_BOOT[31:24]Boot mode configuration select
+ SYSINFO_MISC_IMEM[7:0]log2(IMEM size in bytes)
+ SYSINFO_MISC_DMEM[15:8]log2(DMEM size in bytes)
+ SYSINFO_MISC_HART[23:16]Number of physical CPU cores
+ SYSINFO_MISC_BOOT[31:24]Boot mode configuration select