mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			229 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			Systemverilog
		
	
	
	
	
	
			
		
		
	
	
			229 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			Systemverilog
		
	
	
	
	
	
| //////////////////////////////////////////
 | |
| // config.vh
 | |
| //
 | |
| // Written: David_Harris@hmc.edu 4 January 2021
 | |
| // Modified: Jordan Carlin jcarlin@hmc.edu 14 May 2024
 | |
| //
 | |
| // Purpose: Specify which features of Wally are enabled and set
 | |
| //          configuration parameters
 | |
| // 
 | |
| // 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.
 | |
| ////////////////////////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| `include "BranchPredictorType.vh"
 | |
| 
 | |
| // RV32 or RV64: XLEN = 32 or 64
 | |
| localparam XLEN = 32'd32;
 | |
| 
 | |
| // IEEE 754 compliance
 | |
| localparam IEEE754 = 0;
 | |
| 
 | |
| // RISC-V configuration per specification
 | |
| // Base instruction set (defaults to I if E is not supported)
 | |
| localparam logic E_SUPPORTED = 0;
 | |
| 
 | |
| // Integer instruction set extensions
 | |
| localparam logic ZIFENCEI_SUPPORTED = 1; // Instruction-Fetch fence
 | |
| localparam logic ZICSR_SUPPORTED    = 1; // CSR Instructions
 | |
| localparam logic ZICCLSM_SUPPORTED  = 0; // Misaligned loads/stores
 | |
| localparam logic ZICOND_SUPPORTED   = 0; // Integer conditional operations
 | |
| 
 | |
| // Multiplication & division extensions
 | |
| // M implies (and in the configuration file requires) Zmmul
 | |
| localparam logic M_SUPPORTED     = 1;
 | |
| localparam logic ZMMUL_SUPPORTED = 1;
 | |
| 
 | |
| // Atomic extensions
 | |
| // A extension is Zaamo + Zalrsc
 | |
| localparam logic ZAAMO_SUPPORTED  = 0;
 | |
| localparam logic ZALRSC_SUPPORTED = 0;
 | |
| 
 | |
| // Bit manipulation extensions
 | |
| // B extension is Zba + Zbb + Zbs
 | |
| localparam logic ZBA_SUPPORTED = 0;
 | |
| localparam logic ZBB_SUPPORTED = 0;
 | |
| localparam logic ZBS_SUPPORTED = 0;
 | |
| localparam logic ZBC_SUPPORTED = 0;
 | |
| 
 | |
| // Scalar crypto extensions
 | |
| // Zkn is all 6 of these
 | |
| localparam logic ZBKB_SUPPORTED = 0;
 | |
| localparam logic ZBKC_SUPPORTED = 0;
 | |
| localparam logic ZBKX_SUPPORTED = 0;
 | |
| localparam logic ZKND_SUPPORTED = 0;
 | |
| localparam logic ZKNE_SUPPORTED = 0;
 | |
| localparam logic ZKNH_SUPPORTED = 0;
 | |
| 
 | |
| // Compressed extensions
 | |
| // C extension is Zca + Zcf (if RV32 and F supported) + Zcd (if D supported)
 | |
| // All compressed extensions require Zca
 | |
| localparam logic ZCA_SUPPORTED = 1;
 | |
| localparam logic ZCB_SUPPORTED = 0;
 | |
| localparam logic ZCF_SUPPORTED = 0; // RV32 only, requires F
 | |
| localparam logic ZCD_SUPPORTED = 0; // requires D
 | |
| 
 | |
| // Floating point extensions
 | |
| localparam logic F_SUPPORTED   = 0;
 | |
| localparam logic D_SUPPORTED   = 0;
 | |
| localparam logic Q_SUPPORTED   = 0;
 | |
| localparam logic ZFH_SUPPORTED = 0;
 | |
| localparam logic ZFA_SUPPORTED = 0;
 | |
| 
 | |
| // privilege modes
 | |
| localparam logic S_SUPPORTED = 1; // Supervisor mode
 | |
| localparam logic U_SUPPORTED = 1; // User mode
 | |
| 
 | |
| // Supervisor level extensions
 | |
| localparam logic SSTC_SUPPORTED = 0; // Supervisor-mode timer interrupts
 | |
| 
 | |
| // Hardware performance counters
 | |
| localparam logic ZICNTR_SUPPORTED = 1;
 | |
| localparam logic ZIHPM_SUPPORTED  = 1;
 | |
| localparam COUNTERS = 12'd32;
 | |
| 
 | |
| // Cache-management operation extensions
 | |
| localparam logic ZICBOM_SUPPORTED = 0;
 | |
| localparam logic ZICBOZ_SUPPORTED = 0;
 | |
| localparam logic ZICBOP_SUPPORTED = 0;
 | |
| 
 | |
| // Virtual memory extensions
 | |
| localparam logic SVPBMT_SUPPORTED  = 0;
 | |
| localparam logic SVNAPOT_SUPPORTED = 0;
 | |
| localparam logic SVINVAL_SUPPORTED = 0;
 | |
| localparam logic SVADU_SUPPORTED   = 0;
 | |
| 
 | |
| 
 | |
| // LSU microarchitectural Features
 | |
| localparam logic BUS_SUPPORTED = 1;
 | |
| localparam logic DCACHE_SUPPORTED = 0;
 | |
| localparam logic ICACHE_SUPPORTED = 0;
 | |
| localparam logic VIRTMEM_SUPPORTED = 0;
 | |
| localparam logic VECTORED_INTERRUPTS_SUPPORTED = 1;
 | |
| localparam logic 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;
 | |
| localparam CACHE_SRAMLEN = 32'd128;
 | |
| 
 | |
| // Integer Divider Configuration
 | |
| // IDIV_BITSPERCYCLE must be 1, 2, or 4
 | |
| localparam IDIV_BITSPERCYCLE = 32'd2;
 | |
| localparam logic IDIV_ON_FPU = 0;
 | |
| 
 | |
| // Legal number of PMP entries are 0, 16, or 64
 | |
| localparam PMP_ENTRIES = 32'd0;
 | |
| 
 | |
| // Address space
 | |
| localparam logic [63:0] RESET_VECTOR = 64'h80000000;
 | |
| 
 | |
| // WFI Timeout Wait
 | |
| localparam WFI_TIMEOUT_BIT = 32'd16;
 | |
| 
 | |
| // Peripheral Physical 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
 | |
| // *** each of these is `PA_BITS wide. is this paramaterizable INSIDE the config file?
 | |
| localparam logic DTIM_SUPPORTED = 1;
 | |
| localparam logic [63:0] DTIM_BASE        = 64'h80000000;
 | |
| localparam logic [63:0] DTIM_RANGE       = 64'h007FFFFF;
 | |
| localparam logic IROM_SUPPORTED = 1;
 | |
| localparam logic [63:0] IROM_BASE        = 64'h80000000;
 | |
| localparam logic [63:0] IROM_RANGE       = 64'h007FFFFF;
 | |
| localparam logic BOOTROM_SUPPORTED = 0;
 | |
| localparam logic [63:0] BOOTROM_BASE     = 64'h00001000;
 | |
| localparam logic [63:0] BOOTROM_RANGE    = 64'h00000FFF;
 | |
| localparam BOOTROM_PRELOAD = 1'b0;
 | |
| localparam logic UNCORE_RAM_SUPPORTED = 0;
 | |
| localparam logic [63:0] UNCORE_RAM_BASE  = 64'h80000000;
 | |
| localparam logic [63:0] UNCORE_RAM_RANGE = 64'h07FFFFFF;
 | |
| localparam UNCORE_RAM_PRELOAD = 1'b0;
 | |
| localparam logic EXT_MEM_SUPPORTED = 0;
 | |
| localparam logic [63:0] EXT_MEM_BASE     = 64'h80000000;
 | |
| localparam logic [63:0] EXT_MEM_RANGE    = 64'h07FFFFFF;
 | |
| localparam logic CLINT_SUPPORTED = 1;
 | |
| localparam logic [63:0] CLINT_BASE       = 64'h02000000;
 | |
| localparam logic [63:0] CLINT_RANGE      = 64'h0000FFFF;
 | |
| localparam logic GPIO_SUPPORTED = 1;
 | |
| localparam logic [63:0] GPIO_BASE        = 64'h10060000;
 | |
| localparam logic [63:0] GPIO_RANGE       = 64'h000000FF;
 | |
| localparam logic UART_SUPPORTED = 1;
 | |
| localparam logic [63:0] UART_BASE        = 64'h10000000;
 | |
| localparam logic [63:0] UART_RANGE       = 64'h00000007;
 | |
| localparam logic PLIC_SUPPORTED = 1;
 | |
| localparam logic [63:0] PLIC_BASE        = 64'h0C000000;
 | |
| localparam logic [63:0] PLIC_RANGE       = 64'h03FFFFFF;
 | |
| localparam logic SDC_SUPPORTED = 0;
 | |
| localparam logic [63:0] SDC_BASE         = 64'h00013000;
 | |
| localparam logic [63:0] SDC_RANGE        = 64'h0000007F;
 | |
| localparam logic SPI_SUPPORTED = 1;
 | |
| localparam logic [63:0] SPI_BASE         = 64'h10040000;
 | |
| localparam logic [63:0] SPI_RANGE        = 64'h00000FFF;
 | |
| 
 | |
| // Bus Interface width
 | |
| localparam AHBW = (XLEN);
 | |
| 
 | |
| // Test modes
 | |
| 
 | |
| // AHB 
 | |
| localparam RAM_LATENCY = 32'b0;
 | |
| localparam logic BURST_EN = 1;
 | |
| 
 | |
| // Tie GPIO outputs back to inputs
 | |
| localparam logic GPIO_LOOPBACK_TEST = 1;
 | |
| localparam logic SPI_LOOPBACK_TEST  = 1;
 | |
| 
 | |
| // 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;
 | |
| localparam PLIC_SPI_ID = 32'd6;
 | |
| localparam PLIC_SDC_ID = 32'd9;
 | |
| 
 | |
| // Branch prediction
 | |
| localparam logic BPRED_SUPPORTED = 0;
 | |
| localparam BPRED_TYPE = `BP_GSHARE; // BP_GSHARE_BASIC, BP_GLOBAL, BP_GLOBAL_BASIC, BP_TWOBIT
 | |
| localparam BPRED_SIZE = 32'd10;
 | |
| localparam BPRED_NUM_LHR = 32'd6;
 | |
| localparam BTB_SIZE = 32'd10;
 | |
| localparam RAS_SIZE = 32'd16;
 | |
| localparam INSTR_CLASS_PRED = 0;
 | |
| 
 | |
| // FPU division architecture
 | |
| localparam RADIX = 32'd4;
 | |
| localparam DIVCOPIES = 32'd4;
 | |
| 
 | |
| // Memory synthesis configuration
 | |
| localparam logic USE_SRAM = 0;
 | |
| 
 | |
| `include "config-shared.vh"
 |