Commit 8b4a503d authored by Mauro Carvalho Chehab's avatar Mauro Carvalho Chehab Committed by Heiko Carstens

docs: s390: convert docs to ReST and rename to *.rst

Convert all text files with s390 documentation to ReST format.

Tried to preserve as much as possible the original document
format. Still, some of the files required some work in order
for it to be visible on both plain text and after converted
to html.

The conversion is actually:
  - add blank lines and identation in order to identify paragraphs;
  - fix tables markups;
  - add some lists markups;
  - mark literal blocks;
  - adjust title markups.

At its new index.rst, let's add a :orphan: while this is not linked to
the main index.rst file, in order to avoid build warnings.
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+samsung@kernel.org>
Signed-off-by: default avatarHeiko Carstens <heiko.carstens@de.ibm.com>
parent dc3988f4
...@@ -478,7 +478,7 @@ ...@@ -478,7 +478,7 @@
others). others).
ccw_timeout_log [S390] ccw_timeout_log [S390]
See Documentation/s390/CommonIO for details. See Documentation/s390/common_io.rst for details.
cgroup_disable= [KNL] Disable a particular controller cgroup_disable= [KNL] Disable a particular controller
Format: {name of the controller(s) to disable} Format: {name of the controller(s) to disable}
...@@ -516,7 +516,7 @@ ...@@ -516,7 +516,7 @@
/selinux/checkreqprot. /selinux/checkreqprot.
cio_ignore= [S390] cio_ignore= [S390]
See Documentation/s390/CommonIO for details. See Documentation/s390/common_io.rst for details.
clk_ignore_unused clk_ignore_unused
[CLK] [CLK]
Prevents the clock framework from automatically gating Prevents the clock framework from automatically gating
......
...@@ -27,7 +27,7 @@ not strictly considered I/O devices. They are considered here as well, ...@@ -27,7 +27,7 @@ not strictly considered I/O devices. They are considered here as well,
although they are not the focus of this document. although they are not the focus of this document.
Some additional information can also be found in the kernel source under Some additional information can also be found in the kernel source under
Documentation/s390/driver-model.txt. Documentation/s390/driver-model.rst.
The css bus The css bus
=========== ===========
...@@ -38,7 +38,7 @@ into several categories: ...@@ -38,7 +38,7 @@ into several categories:
* Standard I/O subchannels, for use by the system. They have a child * Standard I/O subchannels, for use by the system. They have a child
device on the ccw bus and are described below. device on the ccw bus and are described below.
* I/O subchannels bound to the vfio-ccw driver. See * I/O subchannels bound to the vfio-ccw driver. See
Documentation/s390/vfio-ccw.txt. Documentation/s390/vfio-ccw.rst.
* Message subchannels. No Linux driver currently exists. * Message subchannels. No Linux driver currently exists.
* CHSC subchannels (at most one). The chsc subchannel driver can be used * CHSC subchannels (at most one). The chsc subchannel driver can be used
to send asynchronous chsc commands. to send asynchronous chsc commands.
......
===============================
IBM 3270 Display System support IBM 3270 Display System support
===============================
This file describes the driver that supports local channel attachment This file describes the driver that supports local channel attachment
of IBM 3270 devices. It consists of three sections: of IBM 3270 devices. It consists of three sections:
* Introduction * Introduction
* Installation * Installation
* Operation * Operation
INTRODUCTION. Introduction
============
This paper describes installing and operating 3270 devices under This paper describes installing and operating 3270 devices under
Linux/390. A 3270 device is a block-mode rows-and-columns terminal of Linux/390. A 3270 device is a block-mode rows-and-columns terminal of
...@@ -17,12 +21,12 @@ twenty and thirty years ago. ...@@ -17,12 +21,12 @@ twenty and thirty years ago.
You may have 3270s in-house and not know it. If you're using the You may have 3270s in-house and not know it. If you're using the
VM-ESA operating system, define a 3270 to your virtual machine by using VM-ESA operating system, define a 3270 to your virtual machine by using
the command "DEF GRAF <hex-address>" This paper presumes you will be the command "DEF GRAF <hex-address>" This paper presumes you will be
defining four 3270s with the CP/CMS commands defining four 3270s with the CP/CMS commands:
DEF GRAF 620 - DEF GRAF 620
DEF GRAF 621 - DEF GRAF 621
DEF GRAF 622 - DEF GRAF 622
DEF GRAF 623 - DEF GRAF 623
Your network connection from VM-ESA allows you to use x3270, tn3270, or Your network connection from VM-ESA allows you to use x3270, tn3270, or
another 3270 emulator, started from an xterm window on your PC or another 3270 emulator, started from an xterm window on your PC or
...@@ -34,7 +38,8 @@ This paper covers installation of the driver and operation of a ...@@ -34,7 +38,8 @@ This paper covers installation of the driver and operation of a
dialed-in x3270. dialed-in x3270.
INSTALLATION. Installation
============
You install the driver by installing a patch, doing a kernel build, and You install the driver by installing a patch, doing a kernel build, and
running the configuration script (config3270.sh, in this directory). running the configuration script (config3270.sh, in this directory).
...@@ -59,13 +64,15 @@ Use #CP TERM CONMODE 3270 to change it to 3270. If you generate only ...@@ -59,13 +64,15 @@ Use #CP TERM CONMODE 3270 to change it to 3270. If you generate only
at boot time to a 3270 if it is a 3215. at boot time to a 3270 if it is a 3215.
In brief, these are the steps: In brief, these are the steps:
1. Install the tub3270 patch 1. Install the tub3270 patch
2. (If a module) add a line to a file in /etc/modprobe.d/*.conf 2. (If a module) add a line to a file in `/etc/modprobe.d/*.conf`
3. (If VM) define devices with DEF GRAF 3. (If VM) define devices with DEF GRAF
4. Reboot 4. Reboot
5. Configure 5. Configure
To test that everything works, assuming VM and x3270, To test that everything works, assuming VM and x3270,
1. Bring up an x3270 window. 1. Bring up an x3270 window.
2. Use the DIAL command in that window. 2. Use the DIAL command in that window.
3. You should immediately see a Linux login screen. 3. You should immediately see a Linux login screen.
...@@ -74,7 +81,8 @@ Here are the installation steps in detail: ...@@ -74,7 +81,8 @@ Here are the installation steps in detail:
1. The 3270 driver is a part of the official Linux kernel 1. The 3270 driver is a part of the official Linux kernel
source. Build a tree with the kernel source and any necessary source. Build a tree with the kernel source and any necessary
patches. Then do patches. Then do::
make oldconfig make oldconfig
(If you wish to disable 3215 console support, edit (If you wish to disable 3215 console support, edit
.config; change CONFIG_TN3215's value to "n"; .config; change CONFIG_TN3215's value to "n";
...@@ -84,20 +92,22 @@ Here are the installation steps in detail: ...@@ -84,20 +92,22 @@ Here are the installation steps in detail:
make modules_install make modules_install
2. (Perform this step only if you have configured tub3270 as a 2. (Perform this step only if you have configured tub3270 as a
module.) Add a line to a file /etc/modprobe.d/*.conf to automatically module.) Add a line to a file `/etc/modprobe.d/*.conf` to automatically
load the driver when it's needed. With this line added, you will see load the driver when it's needed. With this line added, you will see
login prompts appear on your 3270s as soon as boot is complete (or login prompts appear on your 3270s as soon as boot is complete (or
with emulated 3270s, as soon as you dial into your vm guest using the with emulated 3270s, as soon as you dial into your vm guest using the
command "DIAL <vmguestname>"). Since the line-mode major number is command "DIAL <vmguestname>"). Since the line-mode major number is
227, the line to add should be: 227, the line to add should be::
alias char-major-227 tub3270 alias char-major-227 tub3270
3. Define graphic devices to your vm guest machine, if you 3. Define graphic devices to your vm guest machine, if you
haven't already. Define them before you reboot (reipl): haven't already. Define them before you reboot (reipl):
DEFINE GRAF 620
DEFINE GRAF 621 - DEFINE GRAF 620
DEFINE GRAF 622 - DEFINE GRAF 621
DEFINE GRAF 623 - DEFINE GRAF 622
- DEFINE GRAF 623
4. Reboot. The reboot process scans hardware devices, including 4. Reboot. The reboot process scans hardware devices, including
3270s, and this enables the tub3270 driver once loaded to respond 3270s, and this enables the tub3270 driver once loaded to respond
...@@ -107,21 +117,23 @@ Here are the installation steps in detail: ...@@ -107,21 +117,23 @@ Here are the installation steps in detail:
5. Run the 3270 configuration script config3270. It is 5. Run the 3270 configuration script config3270. It is
distributed in this same directory, Documentation/s390, as distributed in this same directory, Documentation/s390, as
config3270.sh. Inspect the output script it produces, config3270.sh. Inspect the output script it produces,
/tmp/mkdev3270, and then run that script. This will create the /tmp/mkdev3270, and then run that script. This will create the
necessary character special device files and make the necessary necessary character special device files and make the necessary
changes to /etc/inittab. changes to /etc/inittab.
Then notify /sbin/init that /etc/inittab has changed, by issuing Then notify /sbin/init that /etc/inittab has changed, by issuing
the telinit command with the q operand: the telinit command with the q operand::
cd Documentation/s390 cd Documentation/s390
sh config3270.sh sh config3270.sh
sh /tmp/mkdev3270 sh /tmp/mkdev3270
telinit q telinit q
This should be sufficient for your first time. If your 3270 This should be sufficient for your first time. If your 3270
configuration has changed and you're reusing config3270, you configuration has changed and you're reusing config3270, you
should follow these steps: should follow these steps::
Change 3270 configuration Change 3270 configuration
Reboot Reboot
Run config3270 and /tmp/mkdev3270 Run config3270 and /tmp/mkdev3270
...@@ -132,8 +144,10 @@ Here are the testing steps in detail: ...@@ -132,8 +144,10 @@ Here are the testing steps in detail:
1. Bring up an x3270 window, or use an actual hardware 3278 or 1. Bring up an x3270 window, or use an actual hardware 3278 or
3279, or use the 3270 emulator of your choice. You would be 3279, or use the 3270 emulator of your choice. You would be
running the emulator on your PC or workstation. You would use running the emulator on your PC or workstation. You would use
the command, for example, the command, for example::
x3270 vm-esa-domain-name & x3270 vm-esa-domain-name &
if you wanted a 3278 Model 4 with 43 rows of 80 columns, the if you wanted a 3278 Model 4 with 43 rows of 80 columns, the
default model number. The driver does not take advantage of default model number. The driver does not take advantage of
extended attributes. extended attributes.
...@@ -144,7 +158,8 @@ Here are the testing steps in detail: ...@@ -144,7 +158,8 @@ Here are the testing steps in detail:
2. Use the DIAL command instead of the LOGIN command to connect 2. Use the DIAL command instead of the LOGIN command to connect
to one of the virtual 3270s you defined with the DEF GRAF to one of the virtual 3270s you defined with the DEF GRAF
commands: commands::
dial my-vm-guest-name dial my-vm-guest-name
3. You should immediately see a login prompt from your 3. You should immediately see a login prompt from your
...@@ -171,14 +186,17 @@ Here are the testing steps in detail: ...@@ -171,14 +186,17 @@ Here are the testing steps in detail:
Wrong major number? Wrong minor number? There's your Wrong major number? Wrong minor number? There's your
problem! problem!
D. Do you get the message D. Do you get the message::
"HCPDIA047E my-vm-guest-name 0620 does not exist"? "HCPDIA047E my-vm-guest-name 0620 does not exist"?
If so, you must issue the command "DEF GRAF 620" from your VM If so, you must issue the command "DEF GRAF 620" from your VM
3215 console and then reboot the system. 3215 console and then reboot the system.
OPERATION. OPERATION.
==========
The driver defines three areas on the 3270 screen: the log area, the The driver defines three areas on the 3270 screen: the log area, the
input area, and the status area. input area, and the status area.
...@@ -203,8 +221,10 @@ which indicates no scrolling will occur. (If you hit ENTER with "Linux ...@@ -203,8 +221,10 @@ which indicates no scrolling will occur. (If you hit ENTER with "Linux
Running" and nothing typed, the application receives a newline.) Running" and nothing typed, the application receives a newline.)
You may change the scrolling timeout value. For example, the following You may change the scrolling timeout value. For example, the following
command line: command line::
echo scrolltime=60 > /proc/tty/driver/tty3270 echo scrolltime=60 > /proc/tty/driver/tty3270
changes the scrolling timeout value to 60 sec. Set scrolltime to 0 if changes the scrolling timeout value to 60 sec. Set scrolltime to 0 if
you wish to prevent scrolling entirely. you wish to prevent scrolling entirely.
...@@ -228,7 +248,8 @@ cause an EOF also by typing "^D" and hitting ENTER. ...@@ -228,7 +248,8 @@ cause an EOF also by typing "^D" and hitting ENTER.
No PF key is preassigned to cause a job suspension, but you may cause a No PF key is preassigned to cause a job suspension, but you may cause a
job suspension by typing "^Z" and hitting ENTER. You may wish to job suspension by typing "^Z" and hitting ENTER. You may wish to
assign this function to a PF key. To make PF7 cause job suspension, assign this function to a PF key. To make PF7 cause job suspension,
execute the command: execute the command::
echo pf7=^z > /proc/tty/driver/tty3270 echo pf7=^z > /proc/tty/driver/tty3270
If the input you type does not end with the two characters "^n", the If the input you type does not end with the two characters "^n", the
...@@ -243,8 +264,10 @@ command is entered into the stack only when the input area is not made ...@@ -243,8 +264,10 @@ command is entered into the stack only when the input area is not made
invisible (such as for password entry) and it is not identical to the invisible (such as for password entry) and it is not identical to the
current top entry. PF10 rotates backward through the command stack; current top entry. PF10 rotates backward through the command stack;
PF11 rotates forward. You may assign the backward function to any PF PF11 rotates forward. You may assign the backward function to any PF
key (or PA key, for that matter), say, PA3, with the command: key (or PA key, for that matter), say, PA3, with the command::
echo -e pa3=\\033k > /proc/tty/driver/tty3270 echo -e pa3=\\033k > /proc/tty/driver/tty3270
This assigns the string ESC-k to PA3. Similarly, the string ESC-j This assigns the string ESC-k to PA3. Similarly, the string ESC-j
performs the forward function. (Rationale: In bash with vi-mode line performs the forward function. (Rationale: In bash with vi-mode line
editing, ESC-k and ESC-j retrieve backward and forward history. editing, ESC-k and ESC-j retrieve backward and forward history.
...@@ -252,15 +275,19 @@ Suggestions welcome.) ...@@ -252,15 +275,19 @@ Suggestions welcome.)
Is a stack size of twenty commands not to your liking? Change it on Is a stack size of twenty commands not to your liking? Change it on
the fly. To change to saving the last 100 commands, execute the the fly. To change to saving the last 100 commands, execute the
command: command::
echo recallsize=100 > /proc/tty/driver/tty3270 echo recallsize=100 > /proc/tty/driver/tty3270
Have a command you issue frequently? Assign it to a PF or PA key! Use Have a command you issue frequently? Assign it to a PF or PA key! Use
the command the command::
echo pf24="mkdir foobar; cd foobar" > /proc/tty/driver/tty3270
echo pf24="mkdir foobar; cd foobar" > /proc/tty/driver/tty3270
to execute the commands mkdir foobar and cd foobar immediately when you to execute the commands mkdir foobar and cd foobar immediately when you
hit PF24. Want to see the command line first, before you execute it? hit PF24. Want to see the command line first, before you execute it?
Use the -n option of the echo command: Use the -n option of the echo command::
echo -n pf24="mkdir foo; cd foo" > /proc/tty/driver/tty3270 echo -n pf24="mkdir foo; cd foo" > /proc/tty/driver/tty3270
......
S/390 common I/O-Layer - command line parameters, procfs and debugfs entries ======================
============================================================================ S/390 common I/O-Layer
======================
command line parameters, procfs and debugfs entries
===================================================
Command line parameters Command line parameters
----------------------- -----------------------
...@@ -13,7 +17,7 @@ Command line parameters ...@@ -13,7 +17,7 @@ Command line parameters
device := {all | [!]ipldev | [!]condev | [!]<devno> | [!]<devno>-<devno>} device := {all | [!]ipldev | [!]condev | [!]<devno> | [!]<devno>-<devno>}
The given devices will be ignored by the common I/O-layer; no detection The given devices will be ignored by the common I/O-layer; no detection
and device sensing will be done on any of those devices. The subchannel to and device sensing will be done on any of those devices. The subchannel to
which the device in question is attached will be treated as if no device was which the device in question is attached will be treated as if no device was
attached. attached.
...@@ -28,14 +32,20 @@ Command line parameters ...@@ -28,14 +32,20 @@ Command line parameters
keywords can be used to refer to the CCW based boot device and CCW console keywords can be used to refer to the CCW based boot device and CCW console
device respectively (these are probably useful only when combined with the '!' device respectively (these are probably useful only when combined with the '!'
operator). The '!' operator will cause the I/O-layer to _not_ ignore a device. operator). The '!' operator will cause the I/O-layer to _not_ ignore a device.
The command line is parsed from left to right. The command line
is parsed from left to right.
For example::
For example,
cio_ignore=0.0.0023-0.0.0042,0.0.4711 cio_ignore=0.0.0023-0.0.0042,0.0.4711
will ignore all devices ranging from 0.0.0023 to 0.0.0042 and the device will ignore all devices ranging from 0.0.0023 to 0.0.0042 and the device
0.0.4711, if detected. 0.0.4711, if detected.
As another example,
As another example::
cio_ignore=all,!0.0.4711,!0.0.fd00-0.0.fd02 cio_ignore=all,!0.0.4711,!0.0.fd00-0.0.fd02
will ignore all devices but 0.0.4711, 0.0.fd00, 0.0.fd01, 0.0.fd02. will ignore all devices but 0.0.4711, 0.0.fd00, 0.0.fd01, 0.0.fd02.
By default, no devices are ignored. By default, no devices are ignored.
...@@ -48,40 +58,45 @@ Command line parameters ...@@ -48,40 +58,45 @@ Command line parameters
Lists the ranges of devices (by bus id) which are ignored by common I/O. Lists the ranges of devices (by bus id) which are ignored by common I/O.
You can un-ignore certain or all devices by piping to /proc/cio_ignore. You can un-ignore certain or all devices by piping to /proc/cio_ignore.
"free all" will un-ignore all ignored devices, "free all" will un-ignore all ignored devices,
"free <device range>, <device range>, ..." will un-ignore the specified "free <device range>, <device range>, ..." will un-ignore the specified
devices. devices.
For example, if devices 0.0.0023 to 0.0.0042 and 0.0.4711 are ignored, For example, if devices 0.0.0023 to 0.0.0042 and 0.0.4711 are ignored,
- echo free 0.0.0030-0.0.0032 > /proc/cio_ignore - echo free 0.0.0030-0.0.0032 > /proc/cio_ignore
will un-ignore devices 0.0.0030 to 0.0.0032 and will leave devices 0.0.0023 will un-ignore devices 0.0.0030 to 0.0.0032 and will leave devices 0.0.0023
to 0.0.002f, 0.0.0033 to 0.0.0042 and 0.0.4711 ignored; to 0.0.002f, 0.0.0033 to 0.0.0042 and 0.0.4711 ignored;
- echo free 0.0.0041 > /proc/cio_ignore will furthermore un-ignore device - echo free 0.0.0041 > /proc/cio_ignore will furthermore un-ignore device
0.0.0041; 0.0.0041;
- echo free all > /proc/cio_ignore will un-ignore all remaining ignored - echo free all > /proc/cio_ignore will un-ignore all remaining ignored
devices. devices.
When a device is un-ignored, device recognition and sensing is performed and When a device is un-ignored, device recognition and sensing is performed and
the device driver will be notified if possible, so the device will become the device driver will be notified if possible, so the device will become
available to the system. Note that un-ignoring is performed asynchronously. available to the system. Note that un-ignoring is performed asynchronously.
You can also add ranges of devices to be ignored by piping to You can also add ranges of devices to be ignored by piping to
/proc/cio_ignore; "add <device range>, <device range>, ..." will ignore the /proc/cio_ignore; "add <device range>, <device range>, ..." will ignore the
specified devices. specified devices.
Note: While already known devices can be added to the list of devices to be Note: While already known devices can be added to the list of devices to be
ignored, there will be no effect on then. However, if such a device ignored, there will be no effect on then. However, if such a device
disappears and then reappears, it will then be ignored. To make disappears and then reappears, it will then be ignored. To make
known devices go away, you need the "purge" command (see below). known devices go away, you need the "purge" command (see below).
For example, For example::
"echo add 0.0.a000-0.0.accc, 0.0.af00-0.0.afff > /proc/cio_ignore" "echo add 0.0.a000-0.0.accc, 0.0.af00-0.0.afff > /proc/cio_ignore"
will add 0.0.a000-0.0.accc and 0.0.af00-0.0.afff to the list of ignored will add 0.0.a000-0.0.accc and 0.0.af00-0.0.afff to the list of ignored
devices. devices.
You can remove already known but now ignored devices via You can remove already known but now ignored devices via::
"echo purge > /proc/cio_ignore" "echo purge > /proc/cio_ignore"
All devices ignored but still registered and not online (= not in use) All devices ignored but still registered and not online (= not in use)
will be deregistered and thus removed from the system. will be deregistered and thus removed from the system.
...@@ -115,11 +130,11 @@ debugfs entries ...@@ -115,11 +130,11 @@ debugfs entries
Various debug messages from the common I/O-layer. Various debug messages from the common I/O-layer.
- /sys/kernel/debug/s390dbf/cio_trace/hex_ascii - /sys/kernel/debug/s390dbf/cio_trace/hex_ascii
Logs the calling of functions in the common I/O-layer and, if applicable, Logs the calling of functions in the common I/O-layer and, if applicable,
which subchannel they were called for, as well as dumps of some data which subchannel they were called for, as well as dumps of some data
structures (like irb in an error case). structures (like irb in an error case).
The level of logging can be changed to be more or less verbose by piping to The level of logging can be changed to be more or less verbose by piping to
/sys/kernel/debug/s390dbf/cio_*/level a number between 0 and 6; see the /sys/kernel/debug/s390dbf/cio_*/level a number between 0 and 6; see the
documentation on the S/390 debug feature (Documentation/s390/s390dbf.txt) documentation on the S/390 debug feature (Documentation/s390/s390dbf.rst)
for details. for details.
==================
DASD device driver DASD device driver
==================
S/390's disk devices (DASDs) are managed by Linux via the DASD device S/390's disk devices (DASDs) are managed by Linux via the DASD device
driver. It is valid for all types of DASDs and represents them to driver. It is valid for all types of DASDs and represents them to
...@@ -14,14 +16,14 @@ parameters are to be given in hexadecimal notation without a leading ...@@ -14,14 +16,14 @@ parameters are to be given in hexadecimal notation without a leading
If you supply kernel parameters the different instances are processed If you supply kernel parameters the different instances are processed
in order of appearance and a minor number is reserved for any device in order of appearance and a minor number is reserved for any device
covered by the supplied range up to 64 volumes. Additional DASDs are covered by the supplied range up to 64 volumes. Additional DASDs are
ignored. If you do not supply the 'dasd=' kernel parameter at all, the ignored. If you do not supply the 'dasd=' kernel parameter at all, the
DASD driver registers all supported DASDs of your system to a minor DASD driver registers all supported DASDs of your system to a minor
number in ascending order of the subchannel number. number in ascending order of the subchannel number.
The driver currently supports ECKD-devices and there are stubs for The driver currently supports ECKD-devices and there are stubs for
support of the FBA and CKD architectures. For the FBA architecture support of the FBA and CKD architectures. For the FBA architecture
only some smart data structures are missing to make the support only some smart data structures are missing to make the support
complete. complete.
We performed our testing on 3380 and 3390 type disks of different We performed our testing on 3380 and 3390 type disks of different
sizes, under VM and on the bare hardware (LPAR), using internal disks sizes, under VM and on the bare hardware (LPAR), using internal disks
of the multiprise as well as a RAMAC virtual array. Disks exported by of the multiprise as well as a RAMAC virtual array. Disks exported by
...@@ -34,19 +36,22 @@ accessibility of the DASD from other OSs. In a later stage we will ...@@ -34,19 +36,22 @@ accessibility of the DASD from other OSs. In a later stage we will
provide support of partitions, maybe VTOC oriented or using a kind of provide support of partitions, maybe VTOC oriented or using a kind of
partition table in the label record. partition table in the label record.
USAGE Usage
=====
-Low-level format (?CKD only) -Low-level format (?CKD only)
For using an ECKD-DASD as a Linux harddisk you have to low-level For using an ECKD-DASD as a Linux harddisk you have to low-level
format the tracks by issuing the BLKDASDFORMAT-ioctl on that format the tracks by issuing the BLKDASDFORMAT-ioctl on that
device. This will erase any data on that volume including IBM volume device. This will erase any data on that volume including IBM volume
labels, VTOCs etc. The ioctl may take a 'struct format_data *' or labels, VTOCs etc. The ioctl may take a `struct format_data *` or
'NULL' as an argument. 'NULL' as an argument::
typedef struct {
typedef struct {
int start_unit; int start_unit;
int stop_unit; int stop_unit;
int blksize; int blksize;
} format_data_t; } format_data_t;
When a NULL argument is passed to the BLKDASDFORMAT ioctl the whole When a NULL argument is passed to the BLKDASDFORMAT ioctl the whole
disk is formatted to a blocksize of 1024 bytes. Otherwise start_unit disk is formatted to a blocksize of 1024 bytes. Otherwise start_unit
and stop_unit are the first and last track to be formatted. If and stop_unit are the first and last track to be formatted. If
...@@ -56,17 +61,23 @@ up to the last track. blksize can be any power of two between 512 and ...@@ -56,17 +61,23 @@ up to the last track. blksize can be any power of two between 512 and
1kB blocks anyway and you gain approx. 50% of capacity increasing your 1kB blocks anyway and you gain approx. 50% of capacity increasing your
blksize from 512 byte to 1kB. blksize from 512 byte to 1kB.
-Make a filesystem Make a filesystem
=================
Then you can mk??fs the filesystem of your choice on that volume or Then you can mk??fs the filesystem of your choice on that volume or
partition. For reasons of sanity you should build your filesystem on partition. For reasons of sanity you should build your filesystem on
the partition /dev/dd?1 instead of the whole volume. You only lose 3kB the partition /dev/dd?1 instead of the whole volume. You only lose 3kB
but may be sure that you can reuse your data after introduction of a but may be sure that you can reuse your data after introduction of a
real partition table. real partition table.
BUGS: Bugs
====
- Performance sometimes is rather low because we don't fully exploit clustering - Performance sometimes is rather low because we don't fully exploit clustering
TODO-List: TODO-List
=========
- Add IBM'S Disk layout to genhd - Add IBM'S Disk layout to genhd
- Enhance driver to use more than one major number - Enhance driver to use more than one major number
- Enable usage as a module - Enable usage as a module
......
This source diff could not be displayed because it is too large. You can view the blob instead.
:orphan:
=================
s390 Architecture
=================
.. toctree::
:maxdepth: 1
cds
3270
debugging390
driver-model
monreader
qeth
s390dbf
vfio-ap
vfio-ccw
zfcpdump
dasd
common_io
text_files
.. only:: subproject and html
Indices
=======
* :ref:`genindex`
=================================================
Linux API for read access to z/VM Monitor Records
=================================================
Date : 2004-Nov-26 Date : 2004-Nov-26
Author: Gerald Schaefer (geraldsc@de.ibm.com) Author: Gerald Schaefer (geraldsc@de.ibm.com)
Linux API for read access to z/VM Monitor Records
=================================================
Description Description
=========== ===========
This item delivers a new Linux API in the form of a misc char device that is This item delivers a new Linux API in the form of a misc char device that is
usable from user space and allows read access to the z/VM Monitor Records usable from user space and allows read access to the z/VM Monitor Records
collected by the *MONITOR System Service of z/VM. collected by the `*MONITOR` System Service of z/VM.
User Requirements User Requirements
================= =================
The z/VM guest on which you want to access this API needs to be configured in The z/VM guest on which you want to access this API needs to be configured in
order to allow IUCV connections to the *MONITOR service, i.e. it needs the order to allow IUCV connections to the `*MONITOR` service, i.e. it needs the
IUCV *MONITOR statement in its user entry. If the monitor DCSS to be used is IUCV `*MONITOR` statement in its user entry. If the monitor DCSS to be used is
restricted (likely), you also need the NAMESAVE <DCSS NAME> statement. restricted (likely), you also need the NAMESAVE <DCSS NAME> statement.
This item will use the IUCV device driver to access the z/VM services, so you This item will use the IUCV device driver to access the z/VM services, so you
need a kernel with IUCV support. You also need z/VM version 4.4 or 5.1. need a kernel with IUCV support. You also need z/VM version 4.4 or 5.1.
...@@ -50,7 +52,9 @@ Your guest virtual storage has to end below the starting address of the DCSS ...@@ -50,7 +52,9 @@ Your guest virtual storage has to end below the starting address of the DCSS
and you have to specify the "mem=" kernel parameter in your parmfile with a and you have to specify the "mem=" kernel parameter in your parmfile with a
value greater than the ending address of the DCSS. value greater than the ending address of the DCSS.
Example: DEF STOR 140M Example::
DEF STOR 140M
This defines 140MB storage size for your guest, the parameter "mem=160M" is This defines 140MB storage size for your guest, the parameter "mem=160M" is
added to the parmfile. added to the parmfile.
...@@ -66,24 +70,27 @@ kernel, the kernel parameter "monreader.mondcss=<DCSS NAME>" can be specified ...@@ -66,24 +70,27 @@ kernel, the kernel parameter "monreader.mondcss=<DCSS NAME>" can be specified
in the parmfile. in the parmfile.
The default name for the DCSS is "MONDCSS" if none is specified. In case that The default name for the DCSS is "MONDCSS" if none is specified. In case that
there are other users already connected to the *MONITOR service (e.g. there are other users already connected to the `*MONITOR` service (e.g.
Performance Toolkit), the monitor DCSS is already defined and you have to use Performance Toolkit), the monitor DCSS is already defined and you have to use
the same DCSS. The CP command Q MONITOR (Class E privileged) shows the name the same DCSS. The CP command Q MONITOR (Class E privileged) shows the name
of the monitor DCSS, if already defined, and the users connected to the of the monitor DCSS, if already defined, and the users connected to the
*MONITOR service. `*MONITOR` service.
Refer to the "z/VM Performance" book (SC24-6109-00) on how to create a monitor Refer to the "z/VM Performance" book (SC24-6109-00) on how to create a monitor
DCSS if your z/VM doesn't have one already, you need Class E privileges to DCSS if your z/VM doesn't have one already, you need Class E privileges to
define and save a DCSS. define and save a DCSS.
Example: Example:
-------- --------
modprobe monreader mondcss=MYDCSS
::
modprobe monreader mondcss=MYDCSS
This loads the module and sets the DCSS name to "MYDCSS". This loads the module and sets the DCSS name to "MYDCSS".
NOTE: NOTE:
----- -----
This API provides no interface to control the *MONITOR service, e.g. specify This API provides no interface to control the `*MONITOR` service, e.g. specify
which data should be collected. This can be done by the CP command MONITOR which data should be collected. This can be done by the CP command MONITOR
(Class E privileged), see "CP Command and Utility Reference". (Class E privileged), see "CP Command and Utility Reference".
...@@ -98,6 +105,7 @@ If your distribution does not support udev, a device node will not be created ...@@ -98,6 +105,7 @@ If your distribution does not support udev, a device node will not be created
automatically and you have to create it manually after loading the module. automatically and you have to create it manually after loading the module.
Therefore you need to know the major and minor numbers of the device. These Therefore you need to know the major and minor numbers of the device. These
numbers can be found in /sys/class/misc/monreader/dev. numbers can be found in /sys/class/misc/monreader/dev.
Typing cat /sys/class/misc/monreader/dev will give an output of the form Typing cat /sys/class/misc/monreader/dev will give an output of the form
<major>:<minor>. The device node can be created via the mknod command, enter <major>:<minor>. The device node can be created via the mknod command, enter
mknod <name> c <major> <minor>, where <name> is the name of the device node mknod <name> c <major> <minor>, where <name> is the name of the device node
...@@ -105,10 +113,13 @@ to be created. ...@@ -105,10 +113,13 @@ to be created.
Example: Example:
-------- --------
# modprobe monreader
# cat /sys/class/misc/monreader/dev ::
10:63
# mknod /dev/monreader c 10 63 # modprobe monreader
# cat /sys/class/misc/monreader/dev
10:63
# mknod /dev/monreader c 10 63
This loads the module with the default monitor DCSS (MONDCSS) and creates a This loads the module with the default monitor DCSS (MONDCSS) and creates a
device node. device node.
...@@ -133,20 +144,21 @@ last byte of data. The start address is needed to handle "end-of-frame" records ...@@ -133,20 +144,21 @@ last byte of data. The start address is needed to handle "end-of-frame" records
correctly (domain 1, record 13), i.e. it can be used to determine the record correctly (domain 1, record 13), i.e. it can be used to determine the record
start offset relative to a 4K page (frame) boundary. start offset relative to a 4K page (frame) boundary.
See "Appendix A: *MONITOR" in the "z/VM Performance" document for a description See "Appendix A: `*MONITOR`" in the "z/VM Performance" document for a description
of the monitor control element layout. The layout of the monitor records can of the monitor control element layout. The layout of the monitor records can
be found here (z/VM 5.1): http://www.vm.ibm.com/pubs/mon510/index.html be found here (z/VM 5.1): http://www.vm.ibm.com/pubs/mon510/index.html
The layout of the data stream provided by the monreader device is as follows: The layout of the data stream provided by the monreader device is as follows::
...
<0 byte read> ...
<first MCE> \ <0 byte read>
<first set of records> | <first MCE> \
... |- data set <first set of records> |
<last MCE> | ... |- data set
<last set of records> / <last MCE> |
<0 byte read> <last set of records> /
... <0 byte read>
...
There may be more than one combination of MCE and corresponding record set There may be more than one combination of MCE and corresponding record set
within one data set and the end of each data set is indicated by a successful within one data set and the end of each data set is indicated by a successful
...@@ -165,15 +177,19 @@ As with most char devices, error conditions are indicated by returning a ...@@ -165,15 +177,19 @@ As with most char devices, error conditions are indicated by returning a
negative value for the number of bytes read. In this case, the errno variable negative value for the number of bytes read. In this case, the errno variable
indicates the error condition: indicates the error condition:
EIO: reply failed, read data is invalid and the application EIO:
reply failed, read data is invalid and the application
should discard the data read since the last successful read with 0 size. should discard the data read since the last successful read with 0 size.
EFAULT: copy_to_user failed, read data is invalid and the application should EFAULT:
discard the data read since the last successful read with 0 size. copy_to_user failed, read data is invalid and the application should
EAGAIN: occurs on a non-blocking read if there is no data available at the discard the data read since the last successful read with 0 size.
moment. There is no data missing or corrupted, just try again or rather EAGAIN:
use polling for non-blocking reads. occurs on a non-blocking read if there is no data available at the
EOVERFLOW: message limit reached, the data read since the last successful moment. There is no data missing or corrupted, just try again or rather
read with 0 size is valid but subsequent records may be missing. use polling for non-blocking reads.
EOVERFLOW:
message limit reached, the data read since the last successful
read with 0 size is valid but subsequent records may be missing.
In the last case (EOVERFLOW) there may be missing data, in the first two cases In the last case (EOVERFLOW) there may be missing data, in the first two cases
(EIO, EFAULT) there will be missing data. It's up to the application if it will (EIO, EFAULT) there will be missing data. It's up to the application if it will
...@@ -183,7 +199,7 @@ Open: ...@@ -183,7 +199,7 @@ Open:
----- -----
Only one user is allowed to open the char device. If it is already in use, the Only one user is allowed to open the char device. If it is already in use, the
open function will fail (return a negative value) and set errno to EBUSY. open function will fail (return a negative value) and set errno to EBUSY.
The open function may also fail if an IUCV connection to the *MONITOR service The open function may also fail if an IUCV connection to the `*MONITOR` service
cannot be established. In this case errno will be set to EIO and an error cannot be established. In this case errno will be set to EIO and an error
message with an IPUSER SEVER code will be printed into syslog. The IPUSER SEVER message with an IPUSER SEVER code will be printed into syslog. The IPUSER SEVER
codes are described in the "z/VM Performance" book, Appendix A. codes are described in the "z/VM Performance" book, Appendix A.
...@@ -194,4 +210,3 @@ As soon as the device is opened, incoming messages will be accepted and they ...@@ -194,4 +210,3 @@ As soon as the device is opened, incoming messages will be accepted and they
will account for the message limit, i.e. opening the device without reading will account for the message limit, i.e. opening the device without reading
from it will provoke the "message limit reached" error (EOVERFLOW error code) from it will provoke the "message limit reached" error (EOVERFLOW error code)
eventually. eventually.
=============================
IBM s390 QDIO Ethernet Driver IBM s390 QDIO Ethernet Driver
=============================
OSA and HiperSockets Bridge Port Support OSA and HiperSockets Bridge Port Support
========================================
Uevents Uevents
-------
To generate the events the device must be assigned a role of either To generate the events the device must be assigned a role of either
a primary or a secondary Bridge Port. For more information, see a primary or a secondary Bridge Port. For more information, see
...@@ -13,12 +17,15 @@ of some configured Bridge Port device on the channel changes, a udev ...@@ -13,12 +17,15 @@ of some configured Bridge Port device on the channel changes, a udev
event with ACTION=CHANGE is emitted on behalf of the corresponding event with ACTION=CHANGE is emitted on behalf of the corresponding
ccwgroup device. The event has the following attributes: ccwgroup device. The event has the following attributes:
BRIDGEPORT=statechange - indicates that the Bridge Port device changed BRIDGEPORT=statechange
indicates that the Bridge Port device changed
its state. its state.
ROLE={primary|secondary|none} - the role assigned to the port. ROLE={primary|secondary|none}
the role assigned to the port.
STATE={active|standby|inactive} - the newly assumed state of the port. STATE={active|standby|inactive}
the newly assumed state of the port.
When run on HiperSockets Bridge Capable Port hardware with host address When run on HiperSockets Bridge Capable Port hardware with host address
notifications enabled, a udev event with ACTION=CHANGE is emitted. notifications enabled, a udev event with ACTION=CHANGE is emitted.
...@@ -26,25 +33,32 @@ It is emitted on behalf of the corresponding ccwgroup device when a host ...@@ -26,25 +33,32 @@ It is emitted on behalf of the corresponding ccwgroup device when a host
or a VLAN is registered or unregistered on the network served by the device. or a VLAN is registered or unregistered on the network served by the device.
The event has the following attributes: The event has the following attributes:
BRIDGEDHOST={reset|register|deregister|abort} - host address BRIDGEDHOST={reset|register|deregister|abort}
host address
notifications are started afresh, a new host or VLAN is registered or notifications are started afresh, a new host or VLAN is registered or
deregistered on the Bridge Port HiperSockets channel, or address deregistered on the Bridge Port HiperSockets channel, or address
notifications are aborted. notifications are aborted.
VLAN=numeric-vlan-id - VLAN ID on which the event occurred. Not included VLAN=numeric-vlan-id
VLAN ID on which the event occurred. Not included
if no VLAN is involved in the event. if no VLAN is involved in the event.
MAC=xx:xx:xx:xx:xx:xx - MAC address of the host that is being registered MAC=xx:xx:xx:xx:xx:xx
MAC address of the host that is being registered
or deregistered from the HiperSockets channel. Not reported if the or deregistered from the HiperSockets channel. Not reported if the
event reports the creation or destruction of a VLAN. event reports the creation or destruction of a VLAN.
NTOK_BUSID=x.y.zzzz - device bus ID (CSSID, SSID and device number). NTOK_BUSID=x.y.zzzz
device bus ID (CSSID, SSID and device number).
NTOK_IID=xx - device IID. NTOK_IID=xx
device IID.
NTOK_CHPID=xx - device CHPID. NTOK_CHPID=xx
device CHPID.
NTOK_CHID=xxxx - device channel ID. NTOK_CHID=xxxx
device channel ID.
Note that the NTOK_* attributes refer to devices other than the one Note that the `NTOK_*` attributes refer to devices other than the one
connected to the system on which the OS is running. connected to the system on which the OS is running.
ibm 3270 changelog
------------------
.. include:: 3270.ChangeLog
:literal:
ibm 3270 config3270.sh
----------------------
.. literalinclude:: config3270.sh
:language: shell
==================================
vfio-ccw: the basic infrastructure vfio-ccw: the basic infrastructure
================================== ==================================
...@@ -11,9 +12,11 @@ virtual machine, while vfio is the means. ...@@ -11,9 +12,11 @@ virtual machine, while vfio is the means.
Different than other hardware architectures, s390 has defined a unified Different than other hardware architectures, s390 has defined a unified
I/O access method, which is so called Channel I/O. It has its own access I/O access method, which is so called Channel I/O. It has its own access
patterns: patterns:
- Channel programs run asynchronously on a separate (co)processor. - Channel programs run asynchronously on a separate (co)processor.
- The channel subsystem will access any memory designated by the caller - The channel subsystem will access any memory designated by the caller
in the channel program directly, i.e. there is no iommu involved. in the channel program directly, i.e. there is no iommu involved.
Thus when we introduce vfio support for these devices, we realize it Thus when we introduce vfio support for these devices, we realize it
with a mediated device (mdev) implementation. The vfio mdev will be with a mediated device (mdev) implementation. The vfio mdev will be
added to an iommu group, so as to make itself able to be managed by the added to an iommu group, so as to make itself able to be managed by the
...@@ -24,6 +27,7 @@ to perform I/O instructions. ...@@ -24,6 +27,7 @@ to perform I/O instructions.
This document does not intend to explain the s390 I/O architecture in This document does not intend to explain the s390 I/O architecture in
every detail. More information/reference could be found here: every detail. More information/reference could be found here:
- A good start to know Channel I/O in general: - A good start to know Channel I/O in general:
https://en.wikipedia.org/wiki/Channel_I/O https://en.wikipedia.org/wiki/Channel_I/O
- s390 architecture: - s390 architecture:
...@@ -80,6 +84,7 @@ until interrupted. The I/O completion result is received by the ...@@ -80,6 +84,7 @@ until interrupted. The I/O completion result is received by the
interrupt handler in the form of interrupt response block (IRB). interrupt handler in the form of interrupt response block (IRB).
Back to vfio-ccw, in short: Back to vfio-ccw, in short:
- ORBs and channel programs are built in guest kernel (with guest - ORBs and channel programs are built in guest kernel (with guest
physical addresses). physical addresses).
- ORBs and channel programs are passed to the host kernel. - ORBs and channel programs are passed to the host kernel.
...@@ -106,6 +111,7 @@ it gets sent to hardware. ...@@ -106,6 +111,7 @@ it gets sent to hardware.
Within this implementation, we have two drivers for two types of Within this implementation, we have two drivers for two types of
devices: devices:
- The vfio_ccw driver for the physical subchannel device. - The vfio_ccw driver for the physical subchannel device.
This is an I/O subchannel driver for the real subchannel device. It This is an I/O subchannel driver for the real subchannel device. It
realizes a group of callbacks and registers to the mdev framework as a realizes a group of callbacks and registers to the mdev framework as a
...@@ -137,7 +143,7 @@ devices: ...@@ -137,7 +143,7 @@ devices:
vfio_pin_pages and a vfio_unpin_pages interfaces from the vfio iommu vfio_pin_pages and a vfio_unpin_pages interfaces from the vfio iommu
backend for the physical devices to pin and unpin pages by demand. backend for the physical devices to pin and unpin pages by demand.
Below is a high Level block diagram. Below is a high Level block diagram::
+-------------+ +-------------+
| | | |
...@@ -158,6 +164,7 @@ Below is a high Level block diagram. ...@@ -158,6 +164,7 @@ Below is a high Level block diagram.
+-------------+ +-------------+
The process of how these work together. The process of how these work together.
1. vfio_ccw.ko drives the physical I/O subchannel, and registers the 1. vfio_ccw.ko drives the physical I/O subchannel, and registers the
physical device (with callbacks) to mdev framework. physical device (with callbacks) to mdev framework.
When vfio_ccw probing the subchannel device, it registers device When vfio_ccw probing the subchannel device, it registers device
...@@ -178,17 +185,17 @@ vfio-ccw I/O region ...@@ -178,17 +185,17 @@ vfio-ccw I/O region
An I/O region is used to accept channel program request from user An I/O region is used to accept channel program request from user
space and store I/O interrupt result for user space to retrieve. The space and store I/O interrupt result for user space to retrieve. The
definition of the region is: definition of the region is::
struct ccw_io_region { struct ccw_io_region {
#define ORB_AREA_SIZE 12 #define ORB_AREA_SIZE 12
__u8 orb_area[ORB_AREA_SIZE]; __u8 orb_area[ORB_AREA_SIZE];
#define SCSW_AREA_SIZE 12 #define SCSW_AREA_SIZE 12
__u8 scsw_area[SCSW_AREA_SIZE]; __u8 scsw_area[SCSW_AREA_SIZE];
#define IRB_AREA_SIZE 96 #define IRB_AREA_SIZE 96
__u8 irb_area[IRB_AREA_SIZE]; __u8 irb_area[IRB_AREA_SIZE];
__u32 ret_code; __u32 ret_code;
} __packed; } __packed;
While starting an I/O request, orb_area should be filled with the While starting an I/O request, orb_area should be filled with the
guest ORB, and scsw_area should be filled with the SCSW of the Virtual guest ORB, and scsw_area should be filled with the SCSW of the Virtual
...@@ -205,7 +212,7 @@ vfio-ccw follows what vfio-pci did on the s390 platform and uses ...@@ -205,7 +212,7 @@ vfio-ccw follows what vfio-pci did on the s390 platform and uses
vfio-iommu-type1 as the vfio iommu backend. vfio-iommu-type1 as the vfio iommu backend.
* CCW translation APIs * CCW translation APIs
A group of APIs (start with 'cp_') to do CCW translation. The CCWs A group of APIs (start with `cp_`) to do CCW translation. The CCWs
passed in by a user space program are organized with their guest passed in by a user space program are organized with their guest
physical memory addresses. These APIs will copy the CCWs into kernel physical memory addresses. These APIs will copy the CCWs into kernel
space, and assemble a runnable kernel channel program by updating the space, and assemble a runnable kernel channel program by updating the
...@@ -217,12 +224,14 @@ vfio-iommu-type1 as the vfio iommu backend. ...@@ -217,12 +224,14 @@ vfio-iommu-type1 as the vfio iommu backend.
This driver utilizes the CCW translation APIs and introduces This driver utilizes the CCW translation APIs and introduces
vfio_ccw, which is the driver for the I/O subchannel devices you want vfio_ccw, which is the driver for the I/O subchannel devices you want
to pass through. to pass through.
vfio_ccw implements the following vfio ioctls: vfio_ccw implements the following vfio ioctls::
VFIO_DEVICE_GET_INFO VFIO_DEVICE_GET_INFO
VFIO_DEVICE_GET_IRQ_INFO VFIO_DEVICE_GET_IRQ_INFO
VFIO_DEVICE_GET_REGION_INFO VFIO_DEVICE_GET_REGION_INFO
VFIO_DEVICE_RESET VFIO_DEVICE_RESET
VFIO_DEVICE_SET_IRQS VFIO_DEVICE_SET_IRQS
This provides an I/O region, so that the user space program can pass a This provides an I/O region, so that the user space program can pass a
channel program to the kernel, to do further CCW translation before channel program to the kernel, to do further CCW translation before
issuing them to a real device. issuing them to a real device.
...@@ -236,32 +245,49 @@ bit more detail how an I/O request triggered by the QEMU guest will be ...@@ -236,32 +245,49 @@ bit more detail how an I/O request triggered by the QEMU guest will be
handled (without error handling). handled (without error handling).
Explanation: Explanation:
Q1-Q7: QEMU side process.
K1-K5: Kernel side process.
Q1. Get I/O region info during initialization. - Q1-Q7: QEMU side process.
Q2. Setup event notifier and handler to handle I/O completion. - K1-K5: Kernel side process.
Q1.
Get I/O region info during initialization.
Q2.
Setup event notifier and handler to handle I/O completion.
... ... ... ...
Q3. Intercept a ssch instruction. Q3.
Q4. Write the guest channel program and ORB to the I/O region. Intercept a ssch instruction.
K1. Copy from guest to kernel. Q4.
K2. Translate the guest channel program to a host kernel space Write the guest channel program and ORB to the I/O region.
channel program, which becomes runnable for a real device.
K3. With the necessary information contained in the orb passed in K1.
by QEMU, issue the ccwchain to the device. Copy from guest to kernel.
K4. Return the ssch CC code. K2.
Q5. Return the CC code to the guest. Translate the guest channel program to a host kernel space
channel program, which becomes runnable for a real device.
K3.
With the necessary information contained in the orb passed in
by QEMU, issue the ccwchain to the device.
K4.
Return the ssch CC code.
Q5.
Return the CC code to the guest.
... ... ... ...
K5. Interrupt handler gets the I/O result and write the result to K5.
the I/O region. Interrupt handler gets the I/O result and write the result to
K6. Signal QEMU to retrieve the result. the I/O region.
Q6. Get the signal and event handler reads out the result from the I/O K6.
Signal QEMU to retrieve the result.
Q6.
Get the signal and event handler reads out the result from the I/O
region. region.
Q7. Update the irb for the guest. Q7.
Update the irb for the guest.
Limitations Limitations
----------- -----------
...@@ -295,6 +321,6 @@ Reference ...@@ -295,6 +321,6 @@ Reference
1. ESA/s390 Principles of Operation manual (IBM Form. No. SA22-7832) 1. ESA/s390 Principles of Operation manual (IBM Form. No. SA22-7832)
2. ESA/390 Common I/O Device Commands manual (IBM Form. No. SA22-7204) 2. ESA/390 Common I/O Device Commands manual (IBM Form. No. SA22-7204)
3. https://en.wikipedia.org/wiki/Channel_I/O 3. https://en.wikipedia.org/wiki/Channel_I/O
4. Documentation/s390/cds.txt 4. Documentation/s390/cds.rst
5. Documentation/vfio.txt 5. Documentation/vfio.txt
6. Documentation/vfio-mediated-device.txt 6. Documentation/vfio-mediated-device.txt
==================================
The s390 SCSI dump tool (zfcpdump) The s390 SCSI dump tool (zfcpdump)
==================================
System z machines (z900 or higher) provide hardware support for creating system System z machines (z900 or higher) provide hardware support for creating system
dumps on SCSI disks. The dump process is initiated by booting a dump tool, which dumps on SCSI disks. The dump process is initiated by booting a dump tool, which
......
...@@ -13703,7 +13703,7 @@ L: linux-s390@vger.kernel.org ...@@ -13703,7 +13703,7 @@ L: linux-s390@vger.kernel.org
L: kvm@vger.kernel.org L: kvm@vger.kernel.org
S: Supported S: Supported
F: drivers/s390/cio/vfio_ccw* F: drivers/s390/cio/vfio_ccw*
F: Documentation/s390/vfio-ccw.txt F: Documentation/s390/vfio-ccw.rst
F: include/uapi/linux/vfio_ccw.h F: include/uapi/linux/vfio_ccw.h
S390 ZCRYPT DRIVER S390 ZCRYPT DRIVER
...@@ -13723,7 +13723,7 @@ S: Supported ...@@ -13723,7 +13723,7 @@ S: Supported
F: drivers/s390/crypto/vfio_ap_drv.c F: drivers/s390/crypto/vfio_ap_drv.c
F: drivers/s390/crypto/vfio_ap_private.h F: drivers/s390/crypto/vfio_ap_private.h
F: drivers/s390/crypto/vfio_ap_ops.c F: drivers/s390/crypto/vfio_ap_ops.c
F: Documentation/s390/vfio-ap.txt F: Documentation/s390/vfio-ap.rst
S390 ZFCP DRIVER S390 ZFCP DRIVER
M: Steffen Maier <maier@linux.ibm.com> M: Steffen Maier <maier@linux.ibm.com>
......
...@@ -810,9 +810,9 @@ config CRASH_DUMP ...@@ -810,9 +810,9 @@ config CRASH_DUMP
Crash dump kernels are loaded in the main kernel with kexec-tools Crash dump kernels are loaded in the main kernel with kexec-tools
into a specially reserved region and then later executed after into a specially reserved region and then later executed after
a crash by kdump/kexec. a crash by kdump/kexec.
Refer to <file:Documentation/s390/zfcpdump.txt> for more details on this. Refer to <file:Documentation/s390/zfcpdump.rst> for more details on this.
This option also enables s390 zfcpdump. This option also enables s390 zfcpdump.
See also <file:Documentation/s390/zfcpdump.txt> See also <file:Documentation/s390/zfcpdump.rst>
endmenu endmenu
......
...@@ -152,7 +152,7 @@ static inline debug_entry_t *debug_text_event(debug_info_t *id, int level, ...@@ -152,7 +152,7 @@ static inline debug_entry_t *debug_text_event(debug_info_t *id, int level,
/* /*
* IMPORTANT: Use "%s" in sprintf format strings with care! Only pointers are * IMPORTANT: Use "%s" in sprintf format strings with care! Only pointers are
* stored in the s390dbf. See Documentation/s390/s390dbf.txt for more details! * stored in the s390dbf. See Documentation/s390/s390dbf.rst for more details!
*/ */
extern debug_entry_t * extern debug_entry_t *
__debug_sprintf_event(debug_info_t *id, int level, char *string, ...) __debug_sprintf_event(debug_info_t *id, int level, char *string, ...)
...@@ -210,7 +210,7 @@ static inline debug_entry_t *debug_text_exception(debug_info_t *id, int level, ...@@ -210,7 +210,7 @@ static inline debug_entry_t *debug_text_exception(debug_info_t *id, int level,
/* /*
* IMPORTANT: Use "%s" in sprintf format strings with care! Only pointers are * IMPORTANT: Use "%s" in sprintf format strings with care! Only pointers are
* stored in the s390dbf. See Documentation/s390/s390dbf.txt for more details! * stored in the s390dbf. See Documentation/s390/s390dbf.rst for more details!
*/ */
extern debug_entry_t * extern debug_entry_t *
__debug_sprintf_exception(debug_info_t *id, int level, char *string, ...) __debug_sprintf_exception(debug_info_t *id, int level, char *string, ...)
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
* dumps on SCSI disks (zfcpdump). The "zcore/mem" debugfs file shows the same * dumps on SCSI disks (zfcpdump). The "zcore/mem" debugfs file shows the same
* dump format as s390 standalone dumps. * dump format as s390 standalone dumps.
* *
* For more information please refer to Documentation/s390/zfcpdump.txt * For more information please refer to Documentation/s390/zfcpdump.rst
* *
* Copyright IBM Corp. 2003, 2008 * Copyright IBM Corp. 2003, 2008
* Author(s): Michael Holzheu * Author(s): Michael Holzheu
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment