150acfb2bSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */ 25d8544e2SPalmer Dabbelt /* 35d8544e2SPalmer Dabbelt * Copyright (C) 2015 Regents of the University of California 45d8544e2SPalmer Dabbelt */ 55d8544e2SPalmer Dabbelt 65d8544e2SPalmer Dabbelt #ifndef _ASM_RISCV_CSR_H 75d8544e2SPalmer Dabbelt #define _ASM_RISCV_CSR_H 85d8544e2SPalmer Dabbelt 9a3182c91SAnup Patel #include <asm/asm.h> 10d6f5f6e9SAnup Patel #include <linux/bits.h> 115d8544e2SPalmer Dabbelt 125d8544e2SPalmer Dabbelt /* Status register flags */ 131125203cSChristoph Hellwig #define SR_SIE _AC(0x00000002, UL) /* Supervisor Interrupt Enable */ 14a4c3733dSChristoph Hellwig #define SR_MIE _AC(0x00000008, UL) /* Machine Interrupt Enable */ 151125203cSChristoph Hellwig #define SR_SPIE _AC(0x00000020, UL) /* Previous Supervisor IE */ 16a4c3733dSChristoph Hellwig #define SR_MPIE _AC(0x00000080, UL) /* Previous Machine IE */ 171125203cSChristoph Hellwig #define SR_SPP _AC(0x00000100, UL) /* Previously Supervisor */ 18a4c3733dSChristoph Hellwig #define SR_MPP _AC(0x00001800, UL) /* Previously Machine */ 19196a14d4SAnup Patel #define SR_SUM _AC(0x00040000, UL) /* Supervisor User Memory Access */ 205d8544e2SPalmer Dabbelt 215d8544e2SPalmer Dabbelt #define SR_FS _AC(0x00006000, UL) /* Floating-point Status */ 225d8544e2SPalmer Dabbelt #define SR_FS_OFF _AC(0x00000000, UL) 235d8544e2SPalmer Dabbelt #define SR_FS_INITIAL _AC(0x00002000, UL) 245d8544e2SPalmer Dabbelt #define SR_FS_CLEAN _AC(0x00004000, UL) 255d8544e2SPalmer Dabbelt #define SR_FS_DIRTY _AC(0x00006000, UL) 265d8544e2SPalmer Dabbelt 27b5665d2aSGreentime Hu #define SR_VS _AC(0x00000600, UL) /* Vector Status */ 28b5665d2aSGreentime Hu #define SR_VS_OFF _AC(0x00000000, UL) 29b5665d2aSGreentime Hu #define SR_VS_INITIAL _AC(0x00000200, UL) 30b5665d2aSGreentime Hu #define SR_VS_CLEAN _AC(0x00000400, UL) 31b5665d2aSGreentime Hu #define SR_VS_DIRTY _AC(0x00000600, UL) 32b5665d2aSGreentime Hu 335d8544e2SPalmer Dabbelt #define SR_XS _AC(0x00018000, UL) /* Extension Status */ 345d8544e2SPalmer Dabbelt #define SR_XS_OFF _AC(0x00000000, UL) 355d8544e2SPalmer Dabbelt #define SR_XS_INITIAL _AC(0x00008000, UL) 365d8544e2SPalmer Dabbelt #define SR_XS_CLEAN _AC(0x00010000, UL) 375d8544e2SPalmer Dabbelt #define SR_XS_DIRTY _AC(0x00018000, UL) 385d8544e2SPalmer Dabbelt 39b5665d2aSGreentime Hu #define SR_FS_VS (SR_FS | SR_VS) /* Vector and Floating-Point Unit */ 40b5665d2aSGreentime Hu 415d8544e2SPalmer Dabbelt #ifndef CONFIG_64BIT 42b5665d2aSGreentime Hu #define SR_SD _AC(0x80000000, UL) /* FS/VS/XS dirty */ 435d8544e2SPalmer Dabbelt #else 44b5665d2aSGreentime Hu #define SR_SD _AC(0x8000000000000000, UL) /* FS/VS/XS dirty */ 455d8544e2SPalmer Dabbelt #endif 465d8544e2SPalmer Dabbelt 47dfb0bfa7SGuo Ren #ifdef CONFIG_64BIT 48dfb0bfa7SGuo Ren #define SR_UXL _AC(0x300000000, UL) /* XLEN mask for U-mode */ 49dfb0bfa7SGuo Ren #define SR_UXL_32 _AC(0x100000000, UL) /* XLEN = 32 for U-mode */ 50dfb0bfa7SGuo Ren #define SR_UXL_64 _AC(0x200000000, UL) /* XLEN = 64 for U-mode */ 51dfb0bfa7SGuo Ren #endif 52dfb0bfa7SGuo Ren 537549cdf5SChristoph Hellwig /* SATP flags */ 54196a14d4SAnup Patel #ifndef CONFIG_64BIT 557549cdf5SChristoph Hellwig #define SATP_PPN _AC(0x003FFFFF, UL) 567549cdf5SChristoph Hellwig #define SATP_MODE_32 _AC(0x80000000, UL) 572776421eSDaniel Henrique Barboza #define SATP_MODE_SHIFT 31 5865d4b9c5SAnup Patel #define SATP_ASID_BITS 9 5965d4b9c5SAnup Patel #define SATP_ASID_SHIFT 22 6065d4b9c5SAnup Patel #define SATP_ASID_MASK _AC(0x1FF, UL) 615d8544e2SPalmer Dabbelt #else 627549cdf5SChristoph Hellwig #define SATP_PPN _AC(0x00000FFFFFFFFFFF, UL) 637549cdf5SChristoph Hellwig #define SATP_MODE_39 _AC(0x8000000000000000, UL) 64e8a62cc2SAlexandre Ghiti #define SATP_MODE_48 _AC(0x9000000000000000, UL) 65011f09d1SQinglin Pan #define SATP_MODE_57 _AC(0xa000000000000000, UL) 662776421eSDaniel Henrique Barboza #define SATP_MODE_SHIFT 60 6765d4b9c5SAnup Patel #define SATP_ASID_BITS 16 6865d4b9c5SAnup Patel #define SATP_ASID_SHIFT 44 6965d4b9c5SAnup Patel #define SATP_ASID_MASK _AC(0xFFFF, UL) 705d8544e2SPalmer Dabbelt #endif 715d8544e2SPalmer Dabbelt 72a4c3733dSChristoph Hellwig /* Exception cause high bit - is an interrupt if set */ 73a4c3733dSChristoph Hellwig #define CAUSE_IRQ_FLAG (_AC(1, UL) << (__riscv_xlen - 1)) 746dcaf004SAnup Patel 75a4c3733dSChristoph Hellwig /* Interrupt causes (minus the high bit) */ 766dcaf004SAnup Patel #define IRQ_S_SOFT 1 773f2401f4SAnup Patel #define IRQ_VS_SOFT 2 786dcaf004SAnup Patel #define IRQ_M_SOFT 3 796dcaf004SAnup Patel #define IRQ_S_TIMER 5 803f2401f4SAnup Patel #define IRQ_VS_TIMER 6 816dcaf004SAnup Patel #define IRQ_M_TIMER 7 826dcaf004SAnup Patel #define IRQ_S_EXT 9 833f2401f4SAnup Patel #define IRQ_VS_EXT 10 846dcaf004SAnup Patel #define IRQ_M_EXT 11 85d6f5f6e9SAnup Patel #define IRQ_S_GEXT 12 864905ec2fSAtish Patra #define IRQ_PMU_OVF 13 87d6f5f6e9SAnup Patel #define IRQ_LOCAL_MAX (IRQ_PMU_OVF + 1) 88d6f5f6e9SAnup Patel #define IRQ_LOCAL_MASK GENMASK((IRQ_LOCAL_MAX - 1), 0) 895d8544e2SPalmer Dabbelt 90a4c3733dSChristoph Hellwig /* Exception causes */ 915d8544e2SPalmer Dabbelt #define EXC_INST_MISALIGNED 0 925d8544e2SPalmer Dabbelt #define EXC_INST_ACCESS 1 933f2401f4SAnup Patel #define EXC_INST_ILLEGAL 2 945d8544e2SPalmer Dabbelt #define EXC_BREAKPOINT 3 9519bff88eSwchen #define EXC_LOAD_MISALIGNED 4 965d8544e2SPalmer Dabbelt #define EXC_LOAD_ACCESS 5 9719bff88eSwchen #define EXC_STORE_MISALIGNED 6 985d8544e2SPalmer Dabbelt #define EXC_STORE_ACCESS 7 995d8544e2SPalmer Dabbelt #define EXC_SYSCALL 8 1003f2401f4SAnup Patel #define EXC_HYPERVISOR_SYSCALL 9 1013f2401f4SAnup Patel #define EXC_SUPERVISOR_SYSCALL 10 1025d8544e2SPalmer Dabbelt #define EXC_INST_PAGE_FAULT 12 1035d8544e2SPalmer Dabbelt #define EXC_LOAD_PAGE_FAULT 13 1045d8544e2SPalmer Dabbelt #define EXC_STORE_PAGE_FAULT 15 1053f2401f4SAnup Patel #define EXC_INST_GUEST_PAGE_FAULT 20 1063f2401f4SAnup Patel #define EXC_LOAD_GUEST_PAGE_FAULT 21 1073f2401f4SAnup Patel #define EXC_VIRTUAL_INST_FAULT 22 1083f2401f4SAnup Patel #define EXC_STORE_GUEST_PAGE_FAULT 23 1095d8544e2SPalmer Dabbelt 110c68a9032SGreentime Hu /* PMP configuration */ 111c68a9032SGreentime Hu #define PMP_R 0x01 112c68a9032SGreentime Hu #define PMP_W 0x02 113c68a9032SGreentime Hu #define PMP_X 0x04 114c68a9032SGreentime Hu #define PMP_A 0x18 115c68a9032SGreentime Hu #define PMP_A_TOR 0x08 116c68a9032SGreentime Hu #define PMP_A_NA4 0x10 117c68a9032SGreentime Hu #define PMP_A_NAPOT 0x18 118c68a9032SGreentime Hu #define PMP_L 0x80 119c68a9032SGreentime Hu 1203f2401f4SAnup Patel /* HSTATUS flags */ 1213f2401f4SAnup Patel #ifdef CONFIG_64BIT 1223f2401f4SAnup Patel #define HSTATUS_VSXL _AC(0x300000000, UL) 1233f2401f4SAnup Patel #define HSTATUS_VSXL_SHIFT 32 1243f2401f4SAnup Patel #endif 1253f2401f4SAnup Patel #define HSTATUS_VTSR _AC(0x00400000, UL) 1263f2401f4SAnup Patel #define HSTATUS_VTW _AC(0x00200000, UL) 1273f2401f4SAnup Patel #define HSTATUS_VTVM _AC(0x00100000, UL) 1283f2401f4SAnup Patel #define HSTATUS_VGEIN _AC(0x0003f000, UL) 1293f2401f4SAnup Patel #define HSTATUS_VGEIN_SHIFT 12 1303f2401f4SAnup Patel #define HSTATUS_HU _AC(0x00000200, UL) 1313f2401f4SAnup Patel #define HSTATUS_SPVP _AC(0x00000100, UL) 1323f2401f4SAnup Patel #define HSTATUS_SPV _AC(0x00000080, UL) 1333f2401f4SAnup Patel #define HSTATUS_GVA _AC(0x00000040, UL) 1343f2401f4SAnup Patel #define HSTATUS_VSBE _AC(0x00000020, UL) 1353f2401f4SAnup Patel 1363f2401f4SAnup Patel /* HGATP flags */ 1373f2401f4SAnup Patel #define HGATP_MODE_OFF _AC(0, UL) 1383f2401f4SAnup Patel #define HGATP_MODE_SV32X4 _AC(1, UL) 1393f2401f4SAnup Patel #define HGATP_MODE_SV39X4 _AC(8, UL) 1403f2401f4SAnup Patel #define HGATP_MODE_SV48X4 _AC(9, UL) 141b4bbb95eSAnup Patel #define HGATP_MODE_SV57X4 _AC(10, UL) 1423f2401f4SAnup Patel 1433f2401f4SAnup Patel #define HGATP32_MODE_SHIFT 31 1443f2401f4SAnup Patel #define HGATP32_VMID_SHIFT 22 145e290dbb7SAnup Patel #define HGATP32_VMID GENMASK(28, 22) 146e290dbb7SAnup Patel #define HGATP32_PPN GENMASK(21, 0) 1473f2401f4SAnup Patel 1483f2401f4SAnup Patel #define HGATP64_MODE_SHIFT 60 1493f2401f4SAnup Patel #define HGATP64_VMID_SHIFT 44 150e290dbb7SAnup Patel #define HGATP64_VMID GENMASK(57, 44) 151e290dbb7SAnup Patel #define HGATP64_PPN GENMASK(43, 0) 1523f2401f4SAnup Patel 1533f2401f4SAnup Patel #define HGATP_PAGE_SHIFT 12 1543f2401f4SAnup Patel 1553f2401f4SAnup Patel #ifdef CONFIG_64BIT 1563f2401f4SAnup Patel #define HGATP_PPN HGATP64_PPN 1573f2401f4SAnup Patel #define HGATP_VMID_SHIFT HGATP64_VMID_SHIFT 158e290dbb7SAnup Patel #define HGATP_VMID HGATP64_VMID 1593f2401f4SAnup Patel #define HGATP_MODE_SHIFT HGATP64_MODE_SHIFT 1603f2401f4SAnup Patel #else 1613f2401f4SAnup Patel #define HGATP_PPN HGATP32_PPN 1623f2401f4SAnup Patel #define HGATP_VMID_SHIFT HGATP32_VMID_SHIFT 163e290dbb7SAnup Patel #define HGATP_VMID HGATP32_VMID 1643f2401f4SAnup Patel #define HGATP_MODE_SHIFT HGATP32_MODE_SHIFT 1653f2401f4SAnup Patel #endif 1663f2401f4SAnup Patel 1673f2401f4SAnup Patel /* VSIP & HVIP relation */ 1683f2401f4SAnup Patel #define VSIP_TO_HVIP_SHIFT (IRQ_VS_SOFT - IRQ_S_SOFT) 1693f2401f4SAnup Patel #define VSIP_VALID_MASK ((_AC(1, UL) << IRQ_S_SOFT) | \ 1703f2401f4SAnup Patel (_AC(1, UL) << IRQ_S_TIMER) | \ 1713f2401f4SAnup Patel (_AC(1, UL) << IRQ_S_EXT)) 1723f2401f4SAnup Patel 173d6f5f6e9SAnup Patel /* AIA CSR bits */ 174d6f5f6e9SAnup Patel #define TOPI_IID_SHIFT 16 175d6f5f6e9SAnup Patel #define TOPI_IID_MASK GENMASK(11, 0) 176d6f5f6e9SAnup Patel #define TOPI_IPRIO_MASK GENMASK(7, 0) 177d6f5f6e9SAnup Patel #define TOPI_IPRIO_BITS 8 178d6f5f6e9SAnup Patel 179d6f5f6e9SAnup Patel #define TOPEI_ID_SHIFT 16 180d6f5f6e9SAnup Patel #define TOPEI_ID_MASK GENMASK(10, 0) 181d6f5f6e9SAnup Patel #define TOPEI_PRIO_MASK GENMASK(10, 0) 182d6f5f6e9SAnup Patel 183d6f5f6e9SAnup Patel #define ISELECT_IPRIO0 0x30 184d6f5f6e9SAnup Patel #define ISELECT_IPRIO15 0x3f 185d6f5f6e9SAnup Patel #define ISELECT_MASK GENMASK(8, 0) 186d6f5f6e9SAnup Patel 187d6f5f6e9SAnup Patel #define HVICTL_VTI BIT(30) 188d6f5f6e9SAnup Patel #define HVICTL_IID GENMASK(27, 16) 189d6f5f6e9SAnup Patel #define HVICTL_IID_SHIFT 16 190d6f5f6e9SAnup Patel #define HVICTL_DPR BIT(9) 191d6f5f6e9SAnup Patel #define HVICTL_IPRIOM BIT(8) 192d6f5f6e9SAnup Patel #define HVICTL_IPRIO GENMASK(7, 0) 193d6f5f6e9SAnup Patel 1946bb2e00eSAnup Patel /* xENVCFG flags */ 1956bb2e00eSAnup Patel #define ENVCFG_STCE (_AC(1, ULL) << 63) 1966bb2e00eSAnup Patel #define ENVCFG_PBMTE (_AC(1, ULL) << 62) 1976bb2e00eSAnup Patel #define ENVCFG_CBZE (_AC(1, UL) << 7) 1986bb2e00eSAnup Patel #define ENVCFG_CBCFE (_AC(1, UL) << 6) 1996bb2e00eSAnup Patel #define ENVCFG_CBIE_SHIFT 4 2006bb2e00eSAnup Patel #define ENVCFG_CBIE (_AC(0x3, UL) << ENVCFG_CBIE_SHIFT) 2016bb2e00eSAnup Patel #define ENVCFG_CBIE_ILL _AC(0x0, UL) 2026bb2e00eSAnup Patel #define ENVCFG_CBIE_FLUSH _AC(0x1, UL) 2036bb2e00eSAnup Patel #define ENVCFG_CBIE_INV _AC(0x3, UL) 2046bb2e00eSAnup Patel #define ENVCFG_FIOM _AC(0x1, UL) 2056bb2e00eSAnup Patel 206a4c3733dSChristoph Hellwig /* symbolic CSR names: */ 207a3182c91SAnup Patel #define CSR_CYCLE 0xc00 208a3182c91SAnup Patel #define CSR_TIME 0xc01 209a3182c91SAnup Patel #define CSR_INSTRET 0xc02 210c631121dSAtish Patra #define CSR_HPMCOUNTER3 0xc03 211c631121dSAtish Patra #define CSR_HPMCOUNTER4 0xc04 212c631121dSAtish Patra #define CSR_HPMCOUNTER5 0xc05 213c631121dSAtish Patra #define CSR_HPMCOUNTER6 0xc06 214c631121dSAtish Patra #define CSR_HPMCOUNTER7 0xc07 215c631121dSAtish Patra #define CSR_HPMCOUNTER8 0xc08 216c631121dSAtish Patra #define CSR_HPMCOUNTER9 0xc09 217c631121dSAtish Patra #define CSR_HPMCOUNTER10 0xc0a 218c631121dSAtish Patra #define CSR_HPMCOUNTER11 0xc0b 219c631121dSAtish Patra #define CSR_HPMCOUNTER12 0xc0c 220c631121dSAtish Patra #define CSR_HPMCOUNTER13 0xc0d 221c631121dSAtish Patra #define CSR_HPMCOUNTER14 0xc0e 222c631121dSAtish Patra #define CSR_HPMCOUNTER15 0xc0f 223c631121dSAtish Patra #define CSR_HPMCOUNTER16 0xc10 224c631121dSAtish Patra #define CSR_HPMCOUNTER17 0xc11 225c631121dSAtish Patra #define CSR_HPMCOUNTER18 0xc12 226c631121dSAtish Patra #define CSR_HPMCOUNTER19 0xc13 227c631121dSAtish Patra #define CSR_HPMCOUNTER20 0xc14 228c631121dSAtish Patra #define CSR_HPMCOUNTER21 0xc15 229c631121dSAtish Patra #define CSR_HPMCOUNTER22 0xc16 230c631121dSAtish Patra #define CSR_HPMCOUNTER23 0xc17 231c631121dSAtish Patra #define CSR_HPMCOUNTER24 0xc18 232c631121dSAtish Patra #define CSR_HPMCOUNTER25 0xc19 233c631121dSAtish Patra #define CSR_HPMCOUNTER26 0xc1a 234c631121dSAtish Patra #define CSR_HPMCOUNTER27 0xc1b 235c631121dSAtish Patra #define CSR_HPMCOUNTER28 0xc1c 236c631121dSAtish Patra #define CSR_HPMCOUNTER29 0xc1d 237c631121dSAtish Patra #define CSR_HPMCOUNTER30 0xc1e 238c631121dSAtish Patra #define CSR_HPMCOUNTER31 0xc1f 239a4c3733dSChristoph Hellwig #define CSR_CYCLEH 0xc80 240a4c3733dSChristoph Hellwig #define CSR_TIMEH 0xc81 241a4c3733dSChristoph Hellwig #define CSR_INSTRETH 0xc82 242c631121dSAtish Patra #define CSR_HPMCOUNTER3H 0xc83 243c631121dSAtish Patra #define CSR_HPMCOUNTER4H 0xc84 244c631121dSAtish Patra #define CSR_HPMCOUNTER5H 0xc85 245c631121dSAtish Patra #define CSR_HPMCOUNTER6H 0xc86 246c631121dSAtish Patra #define CSR_HPMCOUNTER7H 0xc87 247c631121dSAtish Patra #define CSR_HPMCOUNTER8H 0xc88 248c631121dSAtish Patra #define CSR_HPMCOUNTER9H 0xc89 249c631121dSAtish Patra #define CSR_HPMCOUNTER10H 0xc8a 250c631121dSAtish Patra #define CSR_HPMCOUNTER11H 0xc8b 251c631121dSAtish Patra #define CSR_HPMCOUNTER12H 0xc8c 252c631121dSAtish Patra #define CSR_HPMCOUNTER13H 0xc8d 253c631121dSAtish Patra #define CSR_HPMCOUNTER14H 0xc8e 254c631121dSAtish Patra #define CSR_HPMCOUNTER15H 0xc8f 255c631121dSAtish Patra #define CSR_HPMCOUNTER16H 0xc90 256c631121dSAtish Patra #define CSR_HPMCOUNTER17H 0xc91 257c631121dSAtish Patra #define CSR_HPMCOUNTER18H 0xc92 258c631121dSAtish Patra #define CSR_HPMCOUNTER19H 0xc93 259c631121dSAtish Patra #define CSR_HPMCOUNTER20H 0xc94 260c631121dSAtish Patra #define CSR_HPMCOUNTER21H 0xc95 261c631121dSAtish Patra #define CSR_HPMCOUNTER22H 0xc96 262c631121dSAtish Patra #define CSR_HPMCOUNTER23H 0xc97 263c631121dSAtish Patra #define CSR_HPMCOUNTER24H 0xc98 264c631121dSAtish Patra #define CSR_HPMCOUNTER25H 0xc99 265c631121dSAtish Patra #define CSR_HPMCOUNTER26H 0xc9a 266c631121dSAtish Patra #define CSR_HPMCOUNTER27H 0xc9b 267c631121dSAtish Patra #define CSR_HPMCOUNTER28H 0xc9c 268c631121dSAtish Patra #define CSR_HPMCOUNTER29H 0xc9d 269c631121dSAtish Patra #define CSR_HPMCOUNTER30H 0xc9e 270c631121dSAtish Patra #define CSR_HPMCOUNTER31H 0xc9f 271a4c3733dSChristoph Hellwig 2724905ec2fSAtish Patra #define CSR_SSCOUNTOVF 0xda0 273a3182c91SAnup Patel 274a3182c91SAnup Patel #define CSR_SSTATUS 0x100 275a3182c91SAnup Patel #define CSR_SIE 0x104 276a3182c91SAnup Patel #define CSR_STVEC 0x105 277a3182c91SAnup Patel #define CSR_SCOUNTEREN 0x106 2781b0a08a4SAndrew Jones #define CSR_SENVCFG 0x10a 279a3182c91SAnup Patel #define CSR_SSCRATCH 0x140 280a3182c91SAnup Patel #define CSR_SEPC 0x141 281a3182c91SAnup Patel #define CSR_SCAUSE 0x142 282a3182c91SAnup Patel #define CSR_STVAL 0x143 283a3182c91SAnup Patel #define CSR_SIP 0x144 284a3182c91SAnup Patel #define CSR_SATP 0x180 285a4c3733dSChristoph Hellwig 286bf952a29SAtish Patra #define CSR_STIMECMP 0x14D 287bf952a29SAtish Patra #define CSR_STIMECMPH 0x15D 288bf952a29SAtish Patra 289d6f5f6e9SAnup Patel /* Supervisor-Level Window to Indirectly Accessed Registers (AIA) */ 290d6f5f6e9SAnup Patel #define CSR_SISELECT 0x150 291d6f5f6e9SAnup Patel #define CSR_SIREG 0x151 292d6f5f6e9SAnup Patel 293d6f5f6e9SAnup Patel /* Supervisor-Level Interrupts (AIA) */ 294d6f5f6e9SAnup Patel #define CSR_STOPEI 0x15c 295d6f5f6e9SAnup Patel #define CSR_STOPI 0xdb0 296d6f5f6e9SAnup Patel 297d6f5f6e9SAnup Patel /* Supervisor-Level High-Half CSRs (AIA) */ 298d6f5f6e9SAnup Patel #define CSR_SIEH 0x114 299d6f5f6e9SAnup Patel #define CSR_SIPH 0x154 300d6f5f6e9SAnup Patel 3013f2401f4SAnup Patel #define CSR_VSSTATUS 0x200 3023f2401f4SAnup Patel #define CSR_VSIE 0x204 3033f2401f4SAnup Patel #define CSR_VSTVEC 0x205 3043f2401f4SAnup Patel #define CSR_VSSCRATCH 0x240 3053f2401f4SAnup Patel #define CSR_VSEPC 0x241 3063f2401f4SAnup Patel #define CSR_VSCAUSE 0x242 3073f2401f4SAnup Patel #define CSR_VSTVAL 0x243 3083f2401f4SAnup Patel #define CSR_VSIP 0x244 3093f2401f4SAnup Patel #define CSR_VSATP 0x280 310bf952a29SAtish Patra #define CSR_VSTIMECMP 0x24D 311bf952a29SAtish Patra #define CSR_VSTIMECMPH 0x25D 3123f2401f4SAnup Patel 3133f2401f4SAnup Patel #define CSR_HSTATUS 0x600 3143f2401f4SAnup Patel #define CSR_HEDELEG 0x602 3153f2401f4SAnup Patel #define CSR_HIDELEG 0x603 3163f2401f4SAnup Patel #define CSR_HIE 0x604 3173f2401f4SAnup Patel #define CSR_HTIMEDELTA 0x605 3183f2401f4SAnup Patel #define CSR_HCOUNTEREN 0x606 3193f2401f4SAnup Patel #define CSR_HGEIE 0x607 3206bb2e00eSAnup Patel #define CSR_HENVCFG 0x60a 3213f2401f4SAnup Patel #define CSR_HTIMEDELTAH 0x615 3226bb2e00eSAnup Patel #define CSR_HENVCFGH 0x61a 3233f2401f4SAnup Patel #define CSR_HTVAL 0x643 3243f2401f4SAnup Patel #define CSR_HIP 0x644 3253f2401f4SAnup Patel #define CSR_HVIP 0x645 3263f2401f4SAnup Patel #define CSR_HTINST 0x64a 3273f2401f4SAnup Patel #define CSR_HGATP 0x680 3283f2401f4SAnup Patel #define CSR_HGEIP 0xe12 3293f2401f4SAnup Patel 330d6f5f6e9SAnup Patel /* Virtual Interrupts and Interrupt Priorities (H-extension with AIA) */ 331d6f5f6e9SAnup Patel #define CSR_HVIEN 0x608 332d6f5f6e9SAnup Patel #define CSR_HVICTL 0x609 333d6f5f6e9SAnup Patel #define CSR_HVIPRIO1 0x646 334d6f5f6e9SAnup Patel #define CSR_HVIPRIO2 0x647 335d6f5f6e9SAnup Patel 336d6f5f6e9SAnup Patel /* VS-Level Window to Indirectly Accessed Registers (H-extension with AIA) */ 337d6f5f6e9SAnup Patel #define CSR_VSISELECT 0x250 338d6f5f6e9SAnup Patel #define CSR_VSIREG 0x251 339d6f5f6e9SAnup Patel 340d6f5f6e9SAnup Patel /* VS-Level Interrupts (H-extension with AIA) */ 341d6f5f6e9SAnup Patel #define CSR_VSTOPEI 0x25c 342d6f5f6e9SAnup Patel #define CSR_VSTOPI 0xeb0 343d6f5f6e9SAnup Patel 344d6f5f6e9SAnup Patel /* Hypervisor and VS-Level High-Half CSRs (H-extension with AIA) */ 345d6f5f6e9SAnup Patel #define CSR_HIDELEGH 0x613 346d6f5f6e9SAnup Patel #define CSR_HVIENH 0x618 347d6f5f6e9SAnup Patel #define CSR_HVIPH 0x655 348d6f5f6e9SAnup Patel #define CSR_HVIPRIO1H 0x656 349d6f5f6e9SAnup Patel #define CSR_HVIPRIO2H 0x657 350d6f5f6e9SAnup Patel #define CSR_VSIEH 0x214 351d6f5f6e9SAnup Patel #define CSR_VSIPH 0x254 352d6f5f6e9SAnup Patel 353a4c3733dSChristoph Hellwig #define CSR_MSTATUS 0x300 3549e806356SChristoph Hellwig #define CSR_MISA 0x301 355d6f5f6e9SAnup Patel #define CSR_MIDELEG 0x303 356a4c3733dSChristoph Hellwig #define CSR_MIE 0x304 357a4c3733dSChristoph Hellwig #define CSR_MTVEC 0x305 3586bb2e00eSAnup Patel #define CSR_MENVCFG 0x30a 3596bb2e00eSAnup Patel #define CSR_MENVCFGH 0x31a 360a4c3733dSChristoph Hellwig #define CSR_MSCRATCH 0x340 361a4c3733dSChristoph Hellwig #define CSR_MEPC 0x341 362a4c3733dSChristoph Hellwig #define CSR_MCAUSE 0x342 363a4c3733dSChristoph Hellwig #define CSR_MTVAL 0x343 364a4c3733dSChristoph Hellwig #define CSR_MIP 0x344 365c68a9032SGreentime Hu #define CSR_PMPCFG0 0x3a0 366c68a9032SGreentime Hu #define CSR_PMPADDR0 0x3b0 3676f4eea90SVincent Chen #define CSR_MVENDORID 0xf11 3686f4eea90SVincent Chen #define CSR_MARCHID 0xf12 3696f4eea90SVincent Chen #define CSR_MIMPID 0xf13 370accb9dbcSDamien Le Moal #define CSR_MHARTID 0xf14 371a4c3733dSChristoph Hellwig 372d6f5f6e9SAnup Patel /* Machine-Level Window to Indirectly Accessed Registers (AIA) */ 373d6f5f6e9SAnup Patel #define CSR_MISELECT 0x350 374d6f5f6e9SAnup Patel #define CSR_MIREG 0x351 375d6f5f6e9SAnup Patel 376d6f5f6e9SAnup Patel /* Machine-Level Interrupts (AIA) */ 377d6f5f6e9SAnup Patel #define CSR_MTOPEI 0x35c 378d6f5f6e9SAnup Patel #define CSR_MTOPI 0xfb0 379d6f5f6e9SAnup Patel 380d6f5f6e9SAnup Patel /* Virtual Interrupts for Supervisor Level (AIA) */ 381d6f5f6e9SAnup Patel #define CSR_MVIEN 0x308 382d6f5f6e9SAnup Patel #define CSR_MVIP 0x309 383d6f5f6e9SAnup Patel 384d6f5f6e9SAnup Patel /* Machine-Level High-Half CSRs (AIA) */ 385d6f5f6e9SAnup Patel #define CSR_MIDELEGH 0x313 386d6f5f6e9SAnup Patel #define CSR_MIEH 0x314 387d6f5f6e9SAnup Patel #define CSR_MVIENH 0x318 388d6f5f6e9SAnup Patel #define CSR_MVIPH 0x319 389d6f5f6e9SAnup Patel #define CSR_MIPH 0x354 390d6f5f6e9SAnup Patel 391b5665d2aSGreentime Hu #define CSR_VSTART 0x8 392b5665d2aSGreentime Hu #define CSR_VCSR 0xf 393b5665d2aSGreentime Hu #define CSR_VL 0xc20 394b5665d2aSGreentime Hu #define CSR_VTYPE 0xc21 395b5665d2aSGreentime Hu #define CSR_VLENB 0xc22 396b5665d2aSGreentime Hu 397a4c3733dSChristoph Hellwig #ifdef CONFIG_RISCV_M_MODE 398a4c3733dSChristoph Hellwig # define CSR_STATUS CSR_MSTATUS 399a4c3733dSChristoph Hellwig # define CSR_IE CSR_MIE 400a4c3733dSChristoph Hellwig # define CSR_TVEC CSR_MTVEC 401*52fffb4aSSamuel Holland # define CSR_ENVCFG CSR_MENVCFG 402a4c3733dSChristoph Hellwig # define CSR_SCRATCH CSR_MSCRATCH 403a4c3733dSChristoph Hellwig # define CSR_EPC CSR_MEPC 404a4c3733dSChristoph Hellwig # define CSR_CAUSE CSR_MCAUSE 405a4c3733dSChristoph Hellwig # define CSR_TVAL CSR_MTVAL 406a4c3733dSChristoph Hellwig # define CSR_IP CSR_MIP 407a4c3733dSChristoph Hellwig 408d6f5f6e9SAnup Patel # define CSR_IEH CSR_MIEH 409d6f5f6e9SAnup Patel # define CSR_ISELECT CSR_MISELECT 410d6f5f6e9SAnup Patel # define CSR_IREG CSR_MIREG 411d6f5f6e9SAnup Patel # define CSR_IPH CSR_MIPH 412d6f5f6e9SAnup Patel # define CSR_TOPEI CSR_MTOPEI 413d6f5f6e9SAnup Patel # define CSR_TOPI CSR_MTOPI 414d6f5f6e9SAnup Patel 415a4c3733dSChristoph Hellwig # define SR_IE SR_MIE 416a4c3733dSChristoph Hellwig # define SR_PIE SR_MPIE 417a4c3733dSChristoph Hellwig # define SR_PP SR_MPP 418a4c3733dSChristoph Hellwig 4192f3035daSPaul Walmsley # define RV_IRQ_SOFT IRQ_M_SOFT 4202f3035daSPaul Walmsley # define RV_IRQ_TIMER IRQ_M_TIMER 4212f3035daSPaul Walmsley # define RV_IRQ_EXT IRQ_M_EXT 422a4c3733dSChristoph Hellwig #else /* CONFIG_RISCV_M_MODE */ 423a4c3733dSChristoph Hellwig # define CSR_STATUS CSR_SSTATUS 424a4c3733dSChristoph Hellwig # define CSR_IE CSR_SIE 425a4c3733dSChristoph Hellwig # define CSR_TVEC CSR_STVEC 426*52fffb4aSSamuel Holland # define CSR_ENVCFG CSR_SENVCFG 427a4c3733dSChristoph Hellwig # define CSR_SCRATCH CSR_SSCRATCH 428a4c3733dSChristoph Hellwig # define CSR_EPC CSR_SEPC 429a4c3733dSChristoph Hellwig # define CSR_CAUSE CSR_SCAUSE 430a4c3733dSChristoph Hellwig # define CSR_TVAL CSR_STVAL 431a4c3733dSChristoph Hellwig # define CSR_IP CSR_SIP 432a4c3733dSChristoph Hellwig 433d6f5f6e9SAnup Patel # define CSR_IEH CSR_SIEH 434d6f5f6e9SAnup Patel # define CSR_ISELECT CSR_SISELECT 435d6f5f6e9SAnup Patel # define CSR_IREG CSR_SIREG 436d6f5f6e9SAnup Patel # define CSR_IPH CSR_SIPH 437d6f5f6e9SAnup Patel # define CSR_TOPEI CSR_STOPEI 438d6f5f6e9SAnup Patel # define CSR_TOPI CSR_STOPI 439d6f5f6e9SAnup Patel 440a4c3733dSChristoph Hellwig # define SR_IE SR_SIE 441a4c3733dSChristoph Hellwig # define SR_PIE SR_SPIE 442a4c3733dSChristoph Hellwig # define SR_PP SR_SPP 443a4c3733dSChristoph Hellwig 4442f3035daSPaul Walmsley # define RV_IRQ_SOFT IRQ_S_SOFT 4452f3035daSPaul Walmsley # define RV_IRQ_TIMER IRQ_S_TIMER 4462f3035daSPaul Walmsley # define RV_IRQ_EXT IRQ_S_EXT 4474905ec2fSAtish Patra # define RV_IRQ_PMU IRQ_PMU_OVF 4484905ec2fSAtish Patra # define SIP_LCOFIP (_AC(0x1, UL) << IRQ_PMU_OVF) 4494905ec2fSAtish Patra 4504905ec2fSAtish Patra #endif /* !CONFIG_RISCV_M_MODE */ 451a4c3733dSChristoph Hellwig 452a4c3733dSChristoph Hellwig /* IE/IP (Supervisor/Machine Interrupt Enable/Pending) flags */ 4532f3035daSPaul Walmsley #define IE_SIE (_AC(0x1, UL) << RV_IRQ_SOFT) 4542f3035daSPaul Walmsley #define IE_TIE (_AC(0x1, UL) << RV_IRQ_TIMER) 4552f3035daSPaul Walmsley #define IE_EIE (_AC(0x1, UL) << RV_IRQ_EXT) 456a3182c91SAnup Patel 4575d8544e2SPalmer Dabbelt #ifndef __ASSEMBLY__ 4585d8544e2SPalmer Dabbelt 4595d8544e2SPalmer Dabbelt #define csr_swap(csr, val) \ 4605d8544e2SPalmer Dabbelt ({ \ 4615d8544e2SPalmer Dabbelt unsigned long __v = (unsigned long)(val); \ 462a3182c91SAnup Patel __asm__ __volatile__ ("csrrw %0, " __ASM_STR(csr) ", %1"\ 4635d8544e2SPalmer Dabbelt : "=r" (__v) : "rK" (__v) \ 4645d8544e2SPalmer Dabbelt : "memory"); \ 4655d8544e2SPalmer Dabbelt __v; \ 4665d8544e2SPalmer Dabbelt }) 4675d8544e2SPalmer Dabbelt 4685d8544e2SPalmer Dabbelt #define csr_read(csr) \ 4695d8544e2SPalmer Dabbelt ({ \ 4705d8544e2SPalmer Dabbelt register unsigned long __v; \ 471a3182c91SAnup Patel __asm__ __volatile__ ("csrr %0, " __ASM_STR(csr) \ 4725d8544e2SPalmer Dabbelt : "=r" (__v) : \ 4735d8544e2SPalmer Dabbelt : "memory"); \ 4745d8544e2SPalmer Dabbelt __v; \ 4755d8544e2SPalmer Dabbelt }) 4765d8544e2SPalmer Dabbelt 4775d8544e2SPalmer Dabbelt #define csr_write(csr, val) \ 4785d8544e2SPalmer Dabbelt ({ \ 4795d8544e2SPalmer Dabbelt unsigned long __v = (unsigned long)(val); \ 480a3182c91SAnup Patel __asm__ __volatile__ ("csrw " __ASM_STR(csr) ", %0" \ 4815d8544e2SPalmer Dabbelt : : "rK" (__v) \ 4825d8544e2SPalmer Dabbelt : "memory"); \ 4835d8544e2SPalmer Dabbelt }) 4845d8544e2SPalmer Dabbelt 4855d8544e2SPalmer Dabbelt #define csr_read_set(csr, val) \ 4865d8544e2SPalmer Dabbelt ({ \ 4875d8544e2SPalmer Dabbelt unsigned long __v = (unsigned long)(val); \ 488a3182c91SAnup Patel __asm__ __volatile__ ("csrrs %0, " __ASM_STR(csr) ", %1"\ 4895d8544e2SPalmer Dabbelt : "=r" (__v) : "rK" (__v) \ 4905d8544e2SPalmer Dabbelt : "memory"); \ 4915d8544e2SPalmer Dabbelt __v; \ 4925d8544e2SPalmer Dabbelt }) 4935d8544e2SPalmer Dabbelt 4945d8544e2SPalmer Dabbelt #define csr_set(csr, val) \ 4955d8544e2SPalmer Dabbelt ({ \ 4965d8544e2SPalmer Dabbelt unsigned long __v = (unsigned long)(val); \ 497a3182c91SAnup Patel __asm__ __volatile__ ("csrs " __ASM_STR(csr) ", %0" \ 4985d8544e2SPalmer Dabbelt : : "rK" (__v) \ 4995d8544e2SPalmer Dabbelt : "memory"); \ 5005d8544e2SPalmer Dabbelt }) 5015d8544e2SPalmer Dabbelt 5025d8544e2SPalmer Dabbelt #define csr_read_clear(csr, val) \ 5035d8544e2SPalmer Dabbelt ({ \ 5045d8544e2SPalmer Dabbelt unsigned long __v = (unsigned long)(val); \ 505a3182c91SAnup Patel __asm__ __volatile__ ("csrrc %0, " __ASM_STR(csr) ", %1"\ 5065d8544e2SPalmer Dabbelt : "=r" (__v) : "rK" (__v) \ 5075d8544e2SPalmer Dabbelt : "memory"); \ 5085d8544e2SPalmer Dabbelt __v; \ 5095d8544e2SPalmer Dabbelt }) 5105d8544e2SPalmer Dabbelt 5115d8544e2SPalmer Dabbelt #define csr_clear(csr, val) \ 5125d8544e2SPalmer Dabbelt ({ \ 5135d8544e2SPalmer Dabbelt unsigned long __v = (unsigned long)(val); \ 514a3182c91SAnup Patel __asm__ __volatile__ ("csrc " __ASM_STR(csr) ", %0" \ 5155d8544e2SPalmer Dabbelt : : "rK" (__v) \ 5165d8544e2SPalmer Dabbelt : "memory"); \ 5175d8544e2SPalmer Dabbelt }) 5185d8544e2SPalmer Dabbelt 5195d8544e2SPalmer Dabbelt #endif /* __ASSEMBLY__ */ 5205d8544e2SPalmer Dabbelt 5215d8544e2SPalmer Dabbelt #endif /* _ASM_RISCV_CSR_H */ 522