| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2021-08-31 16:36:01 +05:30
										 |  |  |  * RISC-V ACLINT (Advanced Core Local Interruptor) interface | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2016-2017 Sagar Karandikar, sagark@eecs.berkeley.edu | 
					
						
							|  |  |  |  * Copyright (c) 2017 SiFive, Inc. | 
					
						
							| 
									
										
										
										
											2021-08-31 16:36:01 +05:30
										 |  |  |  * Copyright (c) 2021 Western Digital Corporation or its affiliates. | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  |  * | 
					
						
							|  |  |  |  * 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/>.
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-31 16:36:01 +05:30
										 |  |  | #ifndef HW_RISCV_ACLINT_H
 | 
					
						
							|  |  |  | #define HW_RISCV_ACLINT_H
 | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-12 07:23:31 +02:00
										 |  |  | #include "hw/sysbus.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-31 16:36:01 +05:30
										 |  |  | #define TYPE_RISCV_ACLINT_MTIMER "riscv.aclint.mtimer"
 | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-31 16:36:01 +05:30
										 |  |  | #define RISCV_ACLINT_MTIMER(obj) \
 | 
					
						
							|  |  |  |     OBJECT_CHECK(RISCVAclintMTimerState, (obj), TYPE_RISCV_ACLINT_MTIMER) | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-31 16:36:01 +05:30
										 |  |  | typedef struct RISCVAclintMTimerState { | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     SysBusDevice parent_obj; | 
					
						
							| 
									
										
										
										
											2022-04-20 16:08:59 +08:00
										 |  |  |     uint64_t time_delta; | 
					
						
							| 
									
										
										
										
											2022-08-24 15:13:55 -07:00
										 |  |  |     uint64_t *timecmp; | 
					
						
							|  |  |  |     QEMUTimer **timers; | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  |     MemoryRegion mmio; | 
					
						
							| 
									
										
										
										
											2020-05-14 15:51:31 +05:30
										 |  |  |     uint32_t hartid_base; | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  |     uint32_t num_harts; | 
					
						
							|  |  |  |     uint32_t timecmp_base; | 
					
						
							|  |  |  |     uint32_t time_base; | 
					
						
							|  |  |  |     uint32_t aperture_size; | 
					
						
							| 
									
										
										
										
											2020-09-01 09:39:10 +08:00
										 |  |  |     uint32_t timebase_freq; | 
					
						
							| 
									
										
										
										
											2021-08-30 15:34:36 +10:00
										 |  |  |     qemu_irq *timer_irqs; | 
					
						
							| 
									
										
										
										
											2021-08-31 16:36:01 +05:30
										 |  |  | } RISCVAclintMTimerState; | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-31 16:36:01 +05:30
										 |  |  | DeviceState *riscv_aclint_mtimer_create(hwaddr addr, hwaddr size, | 
					
						
							|  |  |  |     uint32_t hartid_base, uint32_t num_harts, | 
					
						
							| 
									
										
										
										
											2020-09-01 09:39:10 +08:00
										 |  |  |     uint32_t timecmp_base, uint32_t time_base, uint32_t timebase_freq, | 
					
						
							|  |  |  |     bool provide_rdtime); | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-31 16:36:01 +05:30
										 |  |  | #define TYPE_RISCV_ACLINT_SWI "riscv.aclint.swi"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define RISCV_ACLINT_SWI(obj) \
 | 
					
						
							|  |  |  |     OBJECT_CHECK(RISCVAclintSwiState, (obj), TYPE_RISCV_ACLINT_SWI) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct RISCVAclintSwiState { | 
					
						
							|  |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     SysBusDevice parent_obj; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  |     MemoryRegion mmio; | 
					
						
							|  |  |  |     uint32_t hartid_base; | 
					
						
							|  |  |  |     uint32_t num_harts; | 
					
						
							|  |  |  |     uint32_t sswi; | 
					
						
							|  |  |  |     qemu_irq *soft_irqs; | 
					
						
							|  |  |  | } RISCVAclintSwiState; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DeviceState *riscv_aclint_swi_create(hwaddr addr, uint32_t hartid_base, | 
					
						
							|  |  |  |     uint32_t num_harts, bool sswi); | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-03 14:30:07 +13:00
										 |  |  | enum { | 
					
						
							| 
									
										
										
										
											2021-08-31 16:36:01 +05:30
										 |  |  |     RISCV_ACLINT_DEFAULT_MTIMECMP      = 0x0, | 
					
						
							|  |  |  |     RISCV_ACLINT_DEFAULT_MTIME         = 0x7ff8, | 
					
						
							|  |  |  |     RISCV_ACLINT_DEFAULT_MTIMER_SIZE   = 0x8000, | 
					
						
							|  |  |  |     RISCV_ACLINT_DEFAULT_TIMEBASE_FREQ = 10000000, | 
					
						
							|  |  |  |     RISCV_ACLINT_MAX_HARTS             = 4095, | 
					
						
							|  |  |  |     RISCV_ACLINT_SWI_SIZE              = 0x4000 | 
					
						
							| 
									
										
										
										
											2018-03-03 14:30:07 +13:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-03 01:31:12 +13:00
										 |  |  | #endif
 |