forked from rbowler/spinhawk
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathREADME.ECPSVM
172 lines (113 loc) · 6.4 KB
/
README.ECPSVM
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
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
ECPS:VM : Extended Control Program Support : VM/370
- AND -
Extended VM Assists - Partial Privop Simulation And Virtual Interval Timer
************ CHANGE LOG ****************
07/07/03 : Changed description for configuration and commands
ECPS:VM changed to ECPSVM (config)
ecpsvm changed to ecpsvm (command)
- PARTIAL IMPLEMENTATION DOCUMENTATION -
*************************
Affected operating systems :
VM/370 Release 6 (PTFs required - PLC 029 works fine)
up to
VM/SP 6 (with or without HPO option)
--- VM/XA SF, VM/XA SP, VM/ESA and z/VM do NOT use these Assists,
but rely on the SIE instruction to perform some of these functions.
A VM/SP Guest (or VM/370 Guest with 4K Storage key updates) running under
[z/]VM[/[XA|ESA]] will NOT have access to either the CP assists or VM Assists.
The ECPS:VM Feature is disabled when running under SIE.
************************
How to enable VM Assists :
In the HERCULES.CNF file, in the configuration section :
ECPSVM YES|NO|LEVEL n (where n is the requested level.)
If "YES" is specified, the most appropriate level is returned (Level 20)
n Doesn't affect the operations of the assist but what level is reported to
the program.
- CAUTION - Use the 'n' form is not recommended, and is only provided
for engineering use.
**********
New panel command : 'ecpsvm'
Subcommands :
ecpsvm stats : Shows ECPS:VM Call/Hit statistics
ecpsvm enable/disable feature : Enable/Disable named feature
ecpsvm help : (guess)
ecpsvm debug [feature|ALL|CPASSIST|VMASSIST] : Turn on debugging messages for a specific feature
ecpsvm nodebug [feature|ALL|CPASSIST|VMASSIST] : Turn off...
ecpsvm level [nn] : Force ECPS:VM to report a certain support level
(or display the current support level)
NOTE : ecpsvm disable does NOT entirelly disables CP ASSISTS. If it did (i.e. generate a program interrupt whenever a E6xx instruction is invoked) VM would abend immediatelly. Rather, ommit the ECPSVM statement in the configuration file.
To determine the feature names, type "ecpsvm enable ALL".
All the enabled features will be listed.
the ecpsvm command is NOT case sensitive
**********
Determining if the assist is used by VM :
Use the 2 following CLASS A commands :
CP QUERY CPASSIST
CP QUERY SASSIST
Both queries should return 'ON'.
Also use the following CLASS G Command :
CP QUERY SET
2nd line should indicate :
ASSIST ON SVC TMR
***********
Technical information
the CP Assists provides The VM SCP with various microcoded instructions to shorten the supervisor pathlength. All microcoded instructions are priviledged instructions and have an opcode of E6xx. They are native representation of what the SCP would do in a similar case. For all cases where the assist is not able to resolve a situation, the E6XX instructions resolve to a no-op, thus leaving the responsability of the task to the original CP Code.
The VM Assists alters the behaviour of certain priviledged instructions when executed in problem state (controled by the Problem State bit in the PSW) either by completely simulating the instruction (when feasable), Branching directly to the CP support module for that instruction (therefore bypassing Program interruption processing and instruction decoding), or generating a Program interruption otherwise.
The VM Virtual Interval Timer assist allows updating of a Virtual Machine virtual interval timer directly by the microcode.
Both CP And VM Assists are controled by real Control Register 6 which control availability, and behaviour of the assists.
************
Troubleshooting
In the event that a certain CP or VM Assist disrupts normal operations, it is possible to selectivelly disable each discrete component. The best method is to disable ALL VM and CP Assists (Except STEVL and SSM if done prior to IPL) and to enable each feature until the problem occurs. If it is unknown whether the problem lies in the VM or CP Assist, it is also possible to enable/disable the entire group of assists.
See the EVM ENA|DISA Commands.
EVM STA allows to see how often each assist is invoked. The hit and hit ration makes it possible to determine how effective the assists are.
A Low hit ratio may be normal in some situations (for example, the LPSW Hit ration will be very low when running VM under VM, because most PSW switches cannot be resolved by the assist)
A Low invocation count simply shows that in THAT particular situation, the related assist is not used often (For example, there are very few LCTLs when running CMS).
Some assists are just invoked once at IPL (STEVL). This is normal behaviour.
************
Implemented Assists :
CP ASSISTS :
FREEX, FRETX (CP Free Storage management)
DISP0, DISP1, DISP2 (CP Dispatching)
PGLOCK, PGULOCK (Real frame locking/unlocking)
TRANBRNG, TRANLOCK (Virtual frame addressing/locking)
SCNRU, SCNVU (Real/Virtual Device control block scan)
STEVL (Store ECPS:VM support level)
VM ASSISTS :
Virtual Interval Timer
LPSW Simulation
SSM Simulation
SVC Simulation
LCTL Simulation
Non-Implemented assists :
CP ASSISTS :
FREE/FRET : (Original (up to level 19)
CP Storage Management - replaced by FREEX/FRETX)
CCWGN, DFCCW, DNCCW, UXCCW : CCW/CSW Translation assists (Soon)
LCSPG : Locate Changed Shared Page (Soon)
VIPT, VIST : Virtual Translation Page/Segment Invalidation (Soon)
LINK/RETURN (SVC 8/SVC 12) (Soon)
Prefered Machine Assists (Insufficient information)
.. Maybe others ...
VM ASSISTS :
V=R Shadow Table Bypass assists (Including LRA instruction)
(note : The V=R Shadow Table Bypass assist is a feature which requires the guest program
to be aware of the feature (Page 0 Relocation))
SIO (In progress - Partial sim)
DIAG (In progress - Partial sim)
IUCV (In Progress - Partial sim - VM/SP4 or later only)
STxSM (Almost never invoked - ECMODE Only)
ISK/SSK/ISKE/SSKE/IVSK (Extended Key Ops assist)
VM Assists for MVS
.. Maybe others ...
*****************
BUGS & Caveats :
ECPS:VM will NOT work in an AP or MP system. An AP or MP generated system
locks the control blocks being manipulated by the assisted functions
(VMBLOK, RDEVBLOK, VDEVBLOK, etc..). However, the current ECPS:VM
implementation doesn't lock any of those structures. Therefore, CP will
fairly quickly abend because it will find some of the control blocks
to not have been locked when they should (various LOKXXX abends).
Consequently, ECPS:VM must be disabled when a AP or MP system is used.
*****************
Have Fun,
--Ivan