forked from riscv/riscv-profiles
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathold-m-profiles.adoc
116 lines (89 loc) · 4.09 KB
/
old-m-profiles.adoc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
////
This file contains text on M-mode profiles that was deleted from the proposal.
=== RVA20M64 Profile
The RVA20M64 profile is defined to help provide compatibilty for
application-processor platforms that specify an M-mode execution
environment for portable software.
NOTE: Most OS platforms will have no code specified to run in M-mode,
instead accessing lower-level platform services via abstract
environment calls from supervisor mode.
NOTE: M-mode will often inherently include implementation-specific
features in addition to the profile requirements.
==== RVA20M64 Mandatory Extensions
- All RVA20S64 mandatory extensions, _except_ F, D, and misaligned loads
and stores.
- Sm1p11
- mvendorid, marchid, and mimpid registers must be nonzero.
- mstatus.TVM, mstatus.TW, and mstatus.TSR must be writable.
- mtvec.MODE must be capable of holding the value 0 (Direct).
When mtvec.MODE=Direct,
mtvec.BASE must be capable of holding any valid four-byte-aligned address.
- medeleg bits 3, 8, 12, 13, and 15 must be writable.
- mideleg bits 1, 5, and 9 must be writable. mideleg bits 3, 7, and 11
must be read-only zero.
- For any mhpmcounter that is writable, the corresponding bit
in mcounteren must be writable.
- mtval must be written with the faulting virtual address for load, store, and
instruction page-fault, access-fault, and misaligned exceptions, and for
breakpoint exceptions other than those caused by execution of the EBREAK or
C.EBREAK instructions.
For illegal-instruction exceptions, mtval must be written with the faulting
instruction.
- PMP entries 0-3 must be implemented and must support modes OFF, NAPOT,
and TOR, with a granularity of at most 4 KiB.
==== RVA20M64 Supported Optional Extensions
- All RVA20S64 supported optional extensions
- F
- D
- Misaligned loads and stores
NOTE: There are other options and parameters in the privileged
architecture that should be detailed here.
==== RVA20M64 Unsupported Optional Extensions
- All RVA20S64 unsupported optional extensions
==== RVA20M64 Incompatible Extensions
- All RVA20S64 incompatible extensions
////
////
IGNORE this text
=== RVA22M64 Profile
==== RVA22M64 Mandatory Extensions
- All RVA22S64 mandatory extensions, _except_ F, D, and misaligned loads
and stores.
- Sm1p12
- mvendorid, marchid, and mimpid registers must be nonzero.
- mstatus.TVM, mstatus.TW, and mstatus.TSR must be writable.
- mstatus.MBE, mstatus.SBE, and mstatus.UBE must not be read-only 1.
- mtvec.MODE must be capable of holding the value 0 (Direct).
When mtvec.MODE=Direct,
mtvec.BASE must be capable of holding any valid four-byte-aligned address.
- medeleg bits 3, 8, 12, 13, and 15 must be writable.
- mideleg bits 1, 5, and 9 must be writable. mideleg bits 3, 7, and 11
must be read-only zero.
- For any mhpmcounter that is writable, the corresponding bits
in mcounteren and mcountinhibit must be writable.
- mtval must be written with the faulting virtual address for load, store, and
instruction page-fault, access-fault, and misaligned exceptions, and for
breakpoint exceptions other than those caused by execution of the EBREAK or
C.EBREAK instructions.
For illegal-instruction exceptions, mtval must be written with the faulting
instruction.
- PMP entries 0-3 must be implemented and must support modes OFF, NAPOT,
and TOR, with a granularity of at most 4 KiB.
If the hypervisor extension is implemented, the following are also mandatory:
- medeleg bits 10, 20, 21, 22, and 23 must additionally be writable.
- mtval2 must be written with the faulting guest physical address in all
circumstances permitted by the ISA.
==== RVA22M64 Supported Optional Extensions
- All RVA22S64 supported optional extensions
- F
- D
- Misaligned loads and stores
NOTE: Consider making Zicbom supported-optional here to facilitate
trap & emulate, for systems that use some out-of-band mechanism?
NOTE: There are options and parameters in the privileged architecture
that should be detailed here.
==== RVA22M64 Unsupported Optional Extensions
- All RVA22S64 unsupported optional extensions
==== RVA22M64 Incompatible Extensions
- All RVA22S64 incompatible extensions
////