/* * Copyright 2003-2004, Axel Dörfler, axeld@pinc-software.de. * Copyright 2019, Adrien Destugues, pulkomandy@pulkomandy.tk. * Distributed under the terms of the MIT License. */ #ifndef _KERNEL_ARCH_RISCV64_CPU_H #define _KERNEL_ARCH_RISCV64_CPU_H #include #include #include #define CPU_MAX_CACHE_LEVEL 8 #define CACHE_LINE_SIZE 64 static inline bool get_ac() { return SstatusReg{.val = Sstatus()}.sum; } static inline void set_ac() { SetBitsSstatus(SstatusReg{.sum = 1}.val); } static inline void clear_ac() { ClearBitsSstatus(SstatusReg{.sum = 1}.val); } typedef struct arch_cpu_info { uint64 hartId; } arch_cpu_info; #ifdef __cplusplus extern "C" { #endif void __riscv64_setup_system_time(uint64 conversionFactor); static inline void arch_cpu_pause(void) { // TODO: CPU pause } static inline void arch_cpu_idle(void) { Wfi(); } #ifdef __cplusplus } #endif #endif /* _KERNEL_ARCH_RISCV64_CPU_H */