| 
									
										
										
										
											2020-04-23 11:30:50 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * QEMU RISC-V Board Compatible with OpenTitan FPGA platform | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2020 Western Digital | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or modify it | 
					
						
							|  |  |  |  * under the terms and conditions of the GNU General Public License, | 
					
						
							|  |  |  |  * version 2 or later, as published by the Free Software Foundation. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope it will be useful, but WITHOUT | 
					
						
							|  |  |  |  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | 
					
						
							|  |  |  |  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for | 
					
						
							|  |  |  |  * more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License along with | 
					
						
							|  |  |  |  * this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef HW_OPENTITAN_H
 | 
					
						
							|  |  |  | #define HW_OPENTITAN_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "hw/riscv/riscv_hart.h"
 | 
					
						
							| 
									
										
										
										
											2021-10-18 12:38:39 +10:00
										 |  |  | #include "hw/intc/sifive_plic.h"
 | 
					
						
							| 
									
										
										
										
											2020-04-23 14:08:45 -07:00
										 |  |  | #include "hw/char/ibex_uart.h"
 | 
					
						
							| 
									
										
										
										
											2021-06-18 17:28:01 +10:00
										 |  |  | #include "hw/timer/ibex_timer.h"
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | #include "qom/object.h"
 | 
					
						
							| 
									
										
										
										
											2020-04-23 11:30:50 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TYPE_RISCV_IBEX_SOC "riscv.lowrisc.ibex.soc"
 | 
					
						
							| 
									
										
										
										
											2020-09-16 14:25:19 -04:00
										 |  |  | OBJECT_DECLARE_SIMPLE_TYPE(LowRISCIbexSoCState, RISCV_IBEX_SOC) | 
					
						
							| 
									
										
										
										
											2020-04-23 11:30:50 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | struct LowRISCIbexSoCState { | 
					
						
							| 
									
										
										
										
											2020-04-23 11:30:50 -07:00
										 |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     SysBusDevice parent_obj; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  |     RISCVHartArrayState cpus; | 
					
						
							| 
									
										
										
										
											2021-10-18 12:38:39 +10:00
										 |  |  |     SiFivePLICState plic; | 
					
						
							| 
									
										
										
										
											2020-04-23 14:08:45 -07:00
										 |  |  |     IbexUartState uart; | 
					
						
							| 
									
										
										
										
											2021-06-18 17:28:01 +10:00
										 |  |  |     IbexTimerState timer; | 
					
						
							| 
									
										
										
										
											2020-04-23 18:40:57 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-23 11:30:50 -07:00
										 |  |  |     MemoryRegion flash_mem; | 
					
						
							|  |  |  |     MemoryRegion rom; | 
					
						
							| 
									
										
										
										
											2021-07-09 13:38:48 +10:00
										 |  |  |     MemoryRegion flash_alias; | 
					
						
							| 
									
										
										
										
											2020-09-03 16:43:22 -04:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2020-04-23 11:30:50 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | typedef struct OpenTitanState { | 
					
						
							|  |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     SysBusDevice parent_obj; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  |     LowRISCIbexSoCState soc; | 
					
						
							|  |  |  | } OpenTitanState; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum { | 
					
						
							| 
									
										
										
										
											2020-08-25 15:20:03 -04:00
										 |  |  |     IBEX_DEV_ROM, | 
					
						
							|  |  |  |     IBEX_DEV_RAM, | 
					
						
							|  |  |  |     IBEX_DEV_FLASH, | 
					
						
							| 
									
										
										
										
											2021-07-09 13:38:48 +10:00
										 |  |  |     IBEX_DEV_FLASH_VIRTUAL, | 
					
						
							| 
									
										
										
										
											2020-08-25 15:20:03 -04:00
										 |  |  |     IBEX_DEV_UART, | 
					
						
							|  |  |  |     IBEX_DEV_GPIO, | 
					
						
							|  |  |  |     IBEX_DEV_SPI, | 
					
						
							| 
									
										
										
										
											2020-12-14 17:56:54 -08:00
										 |  |  |     IBEX_DEV_I2C, | 
					
						
							|  |  |  |     IBEX_DEV_PATTGEN, | 
					
						
							| 
									
										
										
										
											2021-06-18 17:28:01 +10:00
										 |  |  |     IBEX_DEV_TIMER, | 
					
						
							| 
									
										
										
										
											2020-12-14 17:56:54 -08:00
										 |  |  |     IBEX_DEV_SENSOR_CTRL, | 
					
						
							|  |  |  |     IBEX_DEV_OTP_CTRL, | 
					
						
							| 
									
										
										
										
											2020-08-25 15:20:03 -04:00
										 |  |  |     IBEX_DEV_PWRMGR, | 
					
						
							|  |  |  |     IBEX_DEV_RSTMGR, | 
					
						
							|  |  |  |     IBEX_DEV_CLKMGR, | 
					
						
							|  |  |  |     IBEX_DEV_PINMUX, | 
					
						
							| 
									
										
										
										
											2020-12-14 17:56:54 -08:00
										 |  |  |     IBEX_DEV_PADCTRL, | 
					
						
							|  |  |  |     IBEX_DEV_USBDEV, | 
					
						
							|  |  |  |     IBEX_DEV_FLASH_CTRL, | 
					
						
							|  |  |  |     IBEX_DEV_PLIC, | 
					
						
							|  |  |  |     IBEX_DEV_AES, | 
					
						
							|  |  |  |     IBEX_DEV_HMAC, | 
					
						
							|  |  |  |     IBEX_DEV_KMAC, | 
					
						
							|  |  |  |     IBEX_DEV_KEYMGR, | 
					
						
							|  |  |  |     IBEX_DEV_CSRNG, | 
					
						
							|  |  |  |     IBEX_DEV_ENTROPY, | 
					
						
							|  |  |  |     IBEX_DEV_EDNO, | 
					
						
							|  |  |  |     IBEX_DEV_EDN1, | 
					
						
							| 
									
										
										
										
											2020-08-25 15:20:03 -04:00
										 |  |  |     IBEX_DEV_ALERT_HANDLER, | 
					
						
							|  |  |  |     IBEX_DEV_NMI_GEN, | 
					
						
							| 
									
										
										
										
											2020-12-14 17:56:54 -08:00
										 |  |  |     IBEX_DEV_OTBN, | 
					
						
							| 
									
										
										
										
											2021-07-09 13:38:39 +10:00
										 |  |  |     IBEX_DEV_PERI, | 
					
						
							| 
									
										
										
										
											2020-04-23 11:30:50 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-23 14:08:45 -07:00
										 |  |  | enum { | 
					
						
							| 
									
										
										
										
											2021-10-18 12:38:39 +10:00
										 |  |  |     IBEX_TIMER_TIMEREXPIRED0_0 = 126, | 
					
						
							| 
									
										
										
										
											2021-03-31 11:00:11 -04:00
										 |  |  |     IBEX_UART0_RX_PARITY_ERR_IRQ = 8, | 
					
						
							|  |  |  |     IBEX_UART0_RX_TIMEOUT_IRQ = 7, | 
					
						
							|  |  |  |     IBEX_UART0_RX_BREAK_ERR_IRQ = 6, | 
					
						
							|  |  |  |     IBEX_UART0_RX_FRAME_ERR_IRQ = 5, | 
					
						
							|  |  |  |     IBEX_UART0_RX_OVERFLOW_IRQ = 4, | 
					
						
							|  |  |  |     IBEX_UART0_TX_EMPTY_IRQ = 3, | 
					
						
							|  |  |  |     IBEX_UART0_RX_WATERMARK_IRQ = 2, | 
					
						
							|  |  |  |     IBEX_UART0_TX_WATERMARK_IRQ = 1, | 
					
						
							| 
									
										
										
										
											2020-04-23 14:08:45 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-23 11:30:50 -07:00
										 |  |  | #endif
 |