2023-05-24 17:44:42 +00:00
|
|
|
//////////////////////////////////////////
|
2023-10-16 20:49:09 +00:00
|
|
|
// config.vh
|
2023-05-24 17:44:42 +00:00
|
|
|
//
|
|
|
|
// Written: David_Harris@hmc.edu 4 January 2021
|
|
|
|
// Modified:
|
|
|
|
//
|
|
|
|
// Purpose: Specify which features are configured
|
|
|
|
// Macros to determine which modes are supported based on MISA
|
|
|
|
//
|
|
|
|
// A component of the Wally configurable RISC-V project.
|
|
|
|
//
|
|
|
|
// Copyright (C) 2021 Harvey Mudd College & Oklahoma State University
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1
|
|
|
|
//
|
|
|
|
// Licensed under the Solderpad Hardware License v 2.1 (the “License”); you may not use this file
|
|
|
|
// except in compliance with the License, or, at your option, the Apache License version 2.0. You
|
|
|
|
// may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// https://solderpad.org/licenses/SHL-2.1/
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, any work distributed under the
|
|
|
|
// License is distributed on an “AS IS” BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
|
|
|
|
// either express or implied. See the License for the specific language governing permissions
|
|
|
|
// and limitations under the License.
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2023-05-26 21:00:14 +00:00
|
|
|
`include "BranchPredictorType.vh"
|
|
|
|
|
2023-05-24 17:44:42 +00:00
|
|
|
// RV32 or RV64: XLEN = 32 or 64
|
|
|
|
localparam XLEN = 32'd32;
|
|
|
|
|
|
|
|
// IEEE 754 compliance
|
|
|
|
localparam IEEE754 = 0;
|
|
|
|
|
|
|
|
localparam MISA = (32'h00000104 | 1 << 20 | 1 << 18 | 1 << 12);
|
|
|
|
localparam ZICSR_SUPPORTED = 1;
|
|
|
|
localparam ZIFENCEI_SUPPORTED = 1;
|
|
|
|
localparam COUNTERS = 12'd32;
|
2023-06-09 16:35:51 +00:00
|
|
|
localparam ZICNTR_SUPPORTED = 1;
|
|
|
|
localparam ZIHPM_SUPPORTED = 1;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam ZFH_SUPPORTED = 0;
|
2024-01-15 21:24:57 +00:00
|
|
|
localparam ZFA_SUPPORTED = 0;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam SSTC_SUPPORTED = 0;
|
2023-06-09 21:40:01 +00:00
|
|
|
localparam ZICBOM_SUPPORTED = 0;
|
|
|
|
localparam ZICBOZ_SUPPORTED = 0;
|
|
|
|
localparam ZICBOP_SUPPORTED = 0;
|
2023-10-27 18:07:23 +00:00
|
|
|
localparam ZICCLSM_SUPPORTED = 0;
|
2024-01-11 15:37:15 +00:00
|
|
|
localparam ZICOND_SUPPORTED = 0;
|
2023-06-09 21:40:01 +00:00
|
|
|
localparam SVPBMT_SUPPORTED = 0;
|
2023-08-25 02:44:46 +00:00
|
|
|
localparam SVNAPOT_SUPPORTED = 0;
|
2023-07-13 09:41:17 +00:00
|
|
|
localparam SVINVAL_SUPPORTED = 0;
|
2023-05-24 17:44:42 +00:00
|
|
|
|
|
|
|
// LSU microarchitectural Features
|
|
|
|
localparam BUS_SUPPORTED = 1;
|
|
|
|
localparam DCACHE_SUPPORTED = 0;
|
|
|
|
localparam ICACHE_SUPPORTED = 0;
|
|
|
|
localparam VIRTMEM_SUPPORTED = 0;
|
|
|
|
localparam VECTORED_INTERRUPTS_SUPPORTED = 1;
|
|
|
|
localparam BIGENDIAN_SUPPORTED = 0;
|
|
|
|
|
|
|
|
// TLB configuration. Entries should be a power of 2
|
|
|
|
localparam ITLB_ENTRIES = 32'd0;
|
|
|
|
localparam DTLB_ENTRIES = 32'd0;
|
|
|
|
|
|
|
|
// Cache configuration. Sizes should be a power of two
|
|
|
|
// typical configuration 4 ways, 4096 bytes per way, 256 bit or more lines
|
|
|
|
localparam DCACHE_NUMWAYS = 32'd4;
|
|
|
|
localparam DCACHE_WAYSIZEINBYTES = 32'd4096;
|
|
|
|
localparam DCACHE_LINELENINBITS = 32'd512;
|
|
|
|
localparam ICACHE_NUMWAYS = 32'd4;
|
|
|
|
localparam ICACHE_WAYSIZEINBYTES = 32'd4096;
|
|
|
|
localparam ICACHE_LINELENINBITS = 32'd512;
|
2023-12-18 18:50:49 +00:00
|
|
|
localparam CACHE_SRAMLEN = 32'd128;
|
2023-05-24 17:44:42 +00:00
|
|
|
|
|
|
|
// Integer Divider Configuration
|
|
|
|
// IDIV_BITSPERCYCLE must be 1, 2, or 4
|
|
|
|
localparam IDIV_BITSPERCYCLE = 32'd2;
|
|
|
|
localparam IDIV_ON_FPU = 0;
|
|
|
|
|
|
|
|
// Legal number of PMP entries are 0, 16, or 64
|
|
|
|
localparam PMP_ENTRIES = 32'd0;
|
|
|
|
|
|
|
|
// Address space
|
2023-06-09 14:28:24 +00:00
|
|
|
localparam logic [63:0] RESET_VECTOR = 64'h80000000;
|
2023-05-24 17:44:42 +00:00
|
|
|
|
|
|
|
// WFI Timeout Wait
|
|
|
|
localparam WFI_TIMEOUT_BIT = 32'd16;
|
|
|
|
|
|
|
|
// Peripheral Addresses
|
|
|
|
// Peripheral memory space extends from BASE to BASE+RANGE
|
|
|
|
// Range should be a thermometer code with 0's in the upper bits and 1s in the lower bits
|
|
|
|
localparam DTIM_SUPPORTED = 1'b1;
|
2023-06-09 14:28:24 +00:00
|
|
|
localparam logic [63:0] DTIM_BASE = 64'h80000000;
|
|
|
|
localparam logic [63:0] DTIM_RANGE = 64'h007FFFFF;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam IROM_SUPPORTED = 1'b1;
|
2023-06-09 14:28:24 +00:00
|
|
|
localparam logic [63:0] IROM_BASE = 64'h80000000;
|
|
|
|
localparam logic [63:0] IROM_RANGE = 64'h007FFFFF;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam BOOTROM_SUPPORTED = 1'b0;
|
2023-06-09 14:28:24 +00:00
|
|
|
localparam logic [63:0] BOOTROM_BASE = 64'h00001000;
|
|
|
|
localparam logic [63:0] BOOTROM_RANGE = 64'h00000FFF;
|
2023-11-13 23:20:26 +00:00
|
|
|
localparam BOOTROM_PRELOAD = 1'b0;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam UNCORE_RAM_SUPPORTED = 1'b0;
|
2023-06-09 14:28:24 +00:00
|
|
|
localparam logic [63:0] UNCORE_RAM_BASE = 64'h80000000;
|
|
|
|
localparam logic [63:0] UNCORE_RAM_RANGE = 64'h07FFFFFF;
|
2023-11-13 23:20:26 +00:00
|
|
|
localparam UNCORE_RAM_PRELOAD = 1'b0;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam EXT_MEM_SUPPORTED = 1'b0;
|
2023-06-09 14:28:24 +00:00
|
|
|
localparam logic [63:0] EXT_MEM_BASE = 64'h80000000;
|
|
|
|
localparam logic [63:0] EXT_MEM_RANGE = 64'h07FFFFFF;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam CLINT_SUPPORTED = 1'b1;
|
2023-06-09 14:28:24 +00:00
|
|
|
localparam logic [63:0] CLINT_BASE = 64'h02000000;
|
|
|
|
localparam logic [63:0] CLINT_RANGE = 64'h0000FFFF;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam GPIO_SUPPORTED = 1'b1;
|
2023-06-09 14:28:24 +00:00
|
|
|
localparam logic [63:0] GPIO_BASE = 64'h10060000;
|
|
|
|
localparam logic [63:0] GPIO_RANGE = 64'h000000FF;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam UART_SUPPORTED = 1'b1;
|
2023-06-09 14:28:24 +00:00
|
|
|
localparam logic [63:0] UART_BASE = 64'h10000000;
|
|
|
|
localparam logic [63:0] UART_RANGE = 64'h00000007;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam PLIC_SUPPORTED = 1'b1;
|
2023-06-09 14:28:24 +00:00
|
|
|
localparam logic [63:0] PLIC_BASE = 64'h0C000000;
|
|
|
|
localparam logic [63:0] PLIC_RANGE = 64'h03FFFFFF;
|
2023-07-24 20:55:22 +00:00
|
|
|
localparam SDC_SUPPORTED = 1'b0;
|
|
|
|
localparam logic [63:0] SDC_BASE = 64'h00013000;
|
|
|
|
localparam logic [63:0] SDC_RANGE = 64'h0000007F;
|
2023-10-12 20:36:57 +00:00
|
|
|
localparam SPI_SUPPORTED = 1'b1;
|
|
|
|
localparam logic [63:0] SPI_BASE = 64'h10040000;
|
|
|
|
localparam logic [63:0] SPI_RANGE = 64'h00000FFF;
|
2023-05-24 17:44:42 +00:00
|
|
|
|
|
|
|
// Bus Interface width
|
|
|
|
localparam AHBW = 32'd32;
|
|
|
|
|
|
|
|
// Test modes
|
|
|
|
|
|
|
|
// Tie GPIO outputs back to inputs
|
|
|
|
localparam GPIO_LOOPBACK_TEST = 1;
|
2023-10-12 20:36:57 +00:00
|
|
|
localparam SPI_LOOPBACK_TEST = 1;
|
2023-05-24 17:44:42 +00:00
|
|
|
|
|
|
|
// Hardware configuration
|
|
|
|
localparam UART_PRESCALE = 32'd1;
|
|
|
|
|
|
|
|
// Interrupt configuration
|
|
|
|
localparam PLIC_NUM_SRC = 32'd10;
|
|
|
|
// comment out the following if >=32 sources
|
|
|
|
localparam PLIC_NUM_SRC_LT_32 = (PLIC_NUM_SRC < 32);
|
|
|
|
localparam PLIC_GPIO_ID = 32'd3;
|
|
|
|
localparam PLIC_UART_ID = 32'd10;
|
2023-10-12 20:36:57 +00:00
|
|
|
localparam PLIC_SPI_ID = 32'd6;
|
2023-07-21 22:43:45 +00:00
|
|
|
localparam PLIC_SDC_ID = 32'd9;
|
2023-05-24 17:44:42 +00:00
|
|
|
|
|
|
|
localparam BPRED_SUPPORTED = 0;
|
2023-07-18 20:07:10 +00:00
|
|
|
localparam BPRED_TYPE = `BP_GSHARE; // BP_GSHARE_BASIC, BP_GLOBAL, BP_GLOBAL_BASIC, BP_TWOBIT
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam BPRED_SIZE = 32'd10;
|
2023-05-24 23:02:22 +00:00
|
|
|
localparam BPRED_NUM_LHR = 32'd6;
|
2023-05-24 17:44:42 +00:00
|
|
|
localparam BTB_SIZE = 32'd10;
|
2023-09-27 17:25:05 +00:00
|
|
|
localparam RAS_SIZE = 32'd16;
|
2023-05-24 17:44:42 +00:00
|
|
|
|
|
|
|
localparam SVADU_SUPPORTED = 0;
|
|
|
|
localparam ZMMUL_SUPPORTED = 0;
|
|
|
|
|
|
|
|
// FPU division architecture
|
|
|
|
localparam RADIX = 32'h4;
|
|
|
|
localparam DIVCOPIES = 32'h4;
|
|
|
|
|
|
|
|
// bit manipulation
|
|
|
|
localparam ZBA_SUPPORTED = 0;
|
|
|
|
localparam ZBB_SUPPORTED = 0;
|
|
|
|
localparam ZBC_SUPPORTED = 0;
|
|
|
|
localparam ZBS_SUPPORTED = 0;
|
|
|
|
|
2023-10-04 19:28:12 +00:00
|
|
|
// New compressed instructions
|
|
|
|
localparam ZCB_SUPPORTED = 0;
|
|
|
|
localparam ZCA_SUPPORTED = 0;
|
|
|
|
localparam ZCF_SUPPORTED = 0;
|
|
|
|
localparam ZCD_SUPPORTED = 0;
|
|
|
|
|
2023-05-24 17:44:42 +00:00
|
|
|
// Memory synthesis configuration
|
|
|
|
localparam USE_SRAM = 0;
|
|
|
|
|
2023-07-30 12:22:39 +00:00
|
|
|
`include "config-shared.vh"
|