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
...@@ -113,7 +123,8 @@ Here are the installation steps in detail: ...@@ -113,7 +123,8 @@ Here are the installation steps in detail:
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
...@@ -121,7 +132,8 @@ Here are the installation steps in detail: ...@@ -121,7 +132,8 @@ Here are the installation steps in detail:
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
----------------------- -----------------------
...@@ -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.
...@@ -54,6 +64,7 @@ Command line parameters ...@@ -54,6 +64,7 @@ Command line parameters
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;
...@@ -75,13 +86,17 @@ Command line parameters ...@@ -75,13 +86,17 @@ Command line parameters
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.
...@@ -121,5 +136,5 @@ debugfs entries ...@@ -121,5 +136,5 @@ debugfs entries
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
...@@ -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
......
=============================
S/390 driver model interfaces S/390 driver model interfaces
----------------------------- =============================
1. CCW devices 1. CCW devices
-------------- --------------
...@@ -8,9 +9,9 @@ All devices which can be addressed by means of ccws are called 'CCW devices' - ...@@ -8,9 +9,9 @@ All devices which can be addressed by means of ccws are called 'CCW devices' -
even if they aren't actually driven by ccws. even if they aren't actually driven by ccws.
All ccw devices are accessed via a subchannel, this is reflected in the All ccw devices are accessed via a subchannel, this is reflected in the
structures under devices/: structures under devices/::
devices/ devices/
- system/ - system/
- css0/ - css0/
- 0.0.0000/0.0.0815/ - 0.0.0000/0.0.0815/
...@@ -35,14 +36,18 @@ be found under bus/ccw/devices/. ...@@ -35,14 +36,18 @@ be found under bus/ccw/devices/.
All ccw devices export some data via sysfs. All ccw devices export some data via sysfs.
cutype: The control unit type / model. cutype:
The control unit type / model.
devtype: The device type / model, if applicable. devtype:
The device type / model, if applicable.
availability: Can be 'good' or 'boxed'; 'no path' or 'no device' for availability:
Can be 'good' or 'boxed'; 'no path' or 'no device' for
disconnected devices. disconnected devices.
online: An interface to set the device online and offline. online:
An interface to set the device online and offline.
In the special case of the device being disconnected (see the In the special case of the device being disconnected (see the
notify function under 1.2), piping 0 to online will forcibly delete notify function under 1.2), piping 0 to online will forcibly delete
the device. the device.
...@@ -52,9 +57,11 @@ The device drivers can add entries to export per-device data and interfaces. ...@@ -52,9 +57,11 @@ The device drivers can add entries to export per-device data and interfaces.
There is also some data exported on a per-subchannel basis (see under There is also some data exported on a per-subchannel basis (see under
bus/css/devices/): bus/css/devices/):
chpids: Via which chpids the device is connected. chpids:
Via which chpids the device is connected.
pimpampom: The path installed, path available and path operational masks. pimpampom:
The path installed, path available and path operational masks.
There also might be additional data, for example for block devices. There also might be additional data, for example for block devices.
...@@ -74,9 +81,9 @@ b. After a. has been performed, if necessary, the device is finally brought up ...@@ -74,9 +81,9 @@ b. After a. has been performed, if necessary, the device is finally brought up
------------------------------------ ------------------------------------
The basic struct ccw_device and struct ccw_driver data structures can be found The basic struct ccw_device and struct ccw_driver data structures can be found
under include/asm/ccwdev.h. under include/asm/ccwdev.h::
struct ccw_device { struct ccw_device {
spinlock_t *ccwlock; spinlock_t *ccwlock;
struct ccw_device_private *private; struct ccw_device_private *private;
struct ccw_device_id id; struct ccw_device_id id;
...@@ -87,9 +94,9 @@ struct ccw_device { ...@@ -87,9 +94,9 @@ struct ccw_device {
void (*handler) (struct ccw_device *dev, unsigned long intparm, void (*handler) (struct ccw_device *dev, unsigned long intparm,
struct irb *irb); struct irb *irb);
}; };
struct ccw_driver { struct ccw_driver {
struct module *owner; struct module *owner;
struct ccw_device_id *ids; struct ccw_device_id *ids;
int (*probe) (struct ccw_device *); int (*probe) (struct ccw_device *);
...@@ -99,16 +106,16 @@ struct ccw_driver { ...@@ -99,16 +106,16 @@ struct ccw_driver {
int (*notify) (struct ccw_device *, int); int (*notify) (struct ccw_device *, int);
struct device_driver driver; struct device_driver driver;
char *name; char *name;
}; };
The 'private' field contains data needed for internal i/o operation only, and The 'private' field contains data needed for internal i/o operation only, and
is not available to the device driver. is not available to the device driver.
Each driver should declare in a MODULE_DEVICE_TABLE into which CU types/models Each driver should declare in a MODULE_DEVICE_TABLE into which CU types/models
and/or device types/models it is interested. This information can later be found and/or device types/models it is interested. This information can later be found
in the struct ccw_device_id fields: in the struct ccw_device_id fields::
struct ccw_device_id { struct ccw_device_id {
__u16 match_flags; __u16 match_flags;
__u16 cu_type; __u16 cu_type;
...@@ -117,34 +124,50 @@ struct ccw_device_id { ...@@ -117,34 +124,50 @@ struct ccw_device_id {
__u8 dev_model; __u8 dev_model;
unsigned long driver_info; unsigned long driver_info;
}; };
The functions in ccw_driver should be used in the following way: The functions in ccw_driver should be used in the following way:
probe: This function is called by the device layer for each device the driver
probe:
This function is called by the device layer for each device the driver
is interested in. The driver should only allocate private structures is interested in. The driver should only allocate private structures
to put in dev->driver_data and create attributes (if needed). Also, to put in dev->driver_data and create attributes (if needed). Also,
the interrupt handler (see below) should be set here. the interrupt handler (see below) should be set here.
int (*probe) (struct ccw_device *cdev); ::
int (*probe) (struct ccw_device *cdev);
Parameters: cdev - the device to be probed. Parameters:
cdev
- the device to be probed.
remove: This function is called by the device layer upon removal of the driver, remove:
This function is called by the device layer upon removal of the driver,
the device or the module. The driver should perform cleanups here. the device or the module. The driver should perform cleanups here.
int (*remove) (struct ccw_device *cdev); ::
Parameters: cdev - the device to be removed. int (*remove) (struct ccw_device *cdev);
Parameters:
cdev
- the device to be removed.
set_online: This function is called by the common I/O layer when the device is
set_online:
This function is called by the common I/O layer when the device is
activated via the 'online' attribute. The driver should finally activated via the 'online' attribute. The driver should finally
setup and activate the device here. setup and activate the device here.
int (*set_online) (struct ccw_device *); ::
int (*set_online) (struct ccw_device *);
Parameters: cdev - the device to be activated. The common layer has Parameters:
cdev
- the device to be activated. The common layer has
verified that the device is not already online. verified that the device is not already online.
...@@ -152,15 +175,22 @@ set_offline: This function is called by the common I/O layer when the device is ...@@ -152,15 +175,22 @@ set_offline: This function is called by the common I/O layer when the device is
de-activated via the 'online' attribute. The driver should shut de-activated via the 'online' attribute. The driver should shut
down the device, but not de-allocate its private data. down the device, but not de-allocate its private data.
int (*set_offline) (struct ccw_device *); ::
int (*set_offline) (struct ccw_device *);
Parameters: cdev - the device to be deactivated. The common layer has Parameters:
cdev
- the device to be deactivated. The common layer has
verified that the device is online. verified that the device is online.
notify: This function is called by the common I/O layer for some state changes notify:
This function is called by the common I/O layer for some state changes
of the device. of the device.
Signalled to the driver are: Signalled to the driver are:
* In online state, device detached (CIO_GONE) or last path gone * In online state, device detached (CIO_GONE) or last path gone
(CIO_NO_PATH). The driver must return !0 to keep the device; for (CIO_NO_PATH). The driver must return !0 to keep the device; for
return code 0, the device will be deleted as usual (also when no return code 0, the device will be deleted as usual (also when no
...@@ -174,10 +204,16 @@ notify: This function is called by the common I/O layer for some state changes ...@@ -174,10 +204,16 @@ notify: This function is called by the common I/O layer for some state changes
wants the device back: !0 for keeping, 0 to make the device being wants the device back: !0 for keeping, 0 to make the device being
removed and re-registered. removed and re-registered.
int (*notify) (struct ccw_device *, int); ::
int (*notify) (struct ccw_device *, int);
Parameters:
cdev
- the device whose state changed.
Parameters: cdev - the device whose state changed. event
event - the event that happened. This can be one of CIO_GONE, - the event that happened. This can be one of CIO_GONE,
CIO_NO_PATH or CIO_OPER. CIO_NO_PATH or CIO_OPER.
The handler field of the struct ccw_device is meant to be set to the interrupt The handler field of the struct ccw_device is meant to be set to the interrupt
...@@ -189,7 +225,9 @@ before the driver is called, and is deregistered during set_offline() after the ...@@ -189,7 +225,9 @@ before the driver is called, and is deregistered during set_offline() after the
driver has been called. Also, after registering / before deregistering, path driver has been called. Also, after registering / before deregistering, path
grouping resp. disbanding of the path group (if applicable) are performed. grouping resp. disbanding of the path group (if applicable) are performed.
void (*handler) (struct ccw_device *dev, unsigned long intparm, struct irb *irb); ::
void (*handler) (struct ccw_device *dev, unsigned long intparm, struct irb *irb);
Parameters: dev - the device the handler is called for Parameters: dev - the device the handler is called for
intparm - the intparm which allows the device driver to identify intparm - the intparm which allows the device driver to identify
...@@ -237,18 +275,22 @@ only the logical state and not the physical state, since we cannot track the ...@@ -237,18 +275,22 @@ only the logical state and not the physical state, since we cannot track the
latter consistently due to lacking machine support (we don't need to be aware latter consistently due to lacking machine support (we don't need to be aware
of it anyway). of it anyway).
status - Can be 'online' or 'offline'. status
- Can be 'online' or 'offline'.
Piping 'on' or 'off' sets the chpid logically online/offline. Piping 'on' or 'off' sets the chpid logically online/offline.
Piping 'on' to an online chpid triggers path reprobing for all devices Piping 'on' to an online chpid triggers path reprobing for all devices
the chpid connects to. This can be used to force the kernel to re-use the chpid connects to. This can be used to force the kernel to re-use
a channel path the user knows to be online, but the machine hasn't a channel path the user knows to be online, but the machine hasn't
created a machine check for. created a machine check for.
type - The physical type of the channel path. type
- The physical type of the channel path.
shared - Whether the channel path is shared. shared
- Whether the channel path is shared.
cmg - The channel measurement group. cmg
- The channel measurement group.
3. System devices 3. System devices
----------------- -----------------
...@@ -279,9 +321,8 @@ Netiucv connections show up under devices/iucv/ as "netiucv<ifnum>". The interfa ...@@ -279,9 +321,8 @@ Netiucv connections show up under devices/iucv/ as "netiucv<ifnum>". The interfa
number is assigned sequentially to the connections defined via the 'connection' number is assigned sequentially to the connections defined via the 'connection'
attribute. attribute.
user - shows the connection partner. user
- shows the connection partner.
buffer - maximum buffer size.
Pipe to it to change buffer size.
buffer
- maximum buffer size. Pipe to it to change buffer size.
: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,14 +177,18 @@ As with most char devices, error conditions are indicated by returning a ...@@ -165,14 +177,18 @@ 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:
copy_to_user failed, read data is invalid and the application should
discard the data read since the last successful read with 0 size. discard the data read since the last successful read with 0 size.
EAGAIN: occurs on a non-blocking read if there is no data available at the EAGAIN:
occurs on a non-blocking read if there is no data available at the
moment. There is no data missing or corrupted, just try again or rather moment. There is no data missing or corrupted, just try again or rather
use polling for non-blocking reads. use polling for non-blocking reads.
EOVERFLOW: message limit reached, the data read since the last successful EOVERFLOW:
message limit reached, the data read since the last successful
read with 0 size is valid but subsequent records may be missing. 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
...@@ -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
==================================
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