Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
43c9d459
Commit
43c9d459
authored
Jun 08, 2002
by
Martin Schwidefsky
Committed by
Linus Torvalds
Jun 08, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] s/390 patches for 2.5.20 (4 of 4).
Fourth and last part of the s/390 update. Docu stuff.
parent
10e294df
Changes
3
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
394 additions
and
123 deletions
+394
-123
Documentation/s390/CommonIO
Documentation/s390/CommonIO
+38
-32
Documentation/s390/Debugging390.txt
Documentation/s390/Debugging390.txt
+16
-3
Documentation/s390/cds.txt
Documentation/s390/cds.txt
+340
-88
No files found.
Documentation/s390/CommonIO
View file @
43c9d459
...
@@ -21,7 +21,8 @@ Command line parameters
...
@@ -21,7 +21,8 @@ Command line parameters
Default is on.
Default is on.
* cio_ignore = <range of device numbers>, <range of device numbers>, ...
* cio_ignore = <device number> | <range of device numbers>,
<device number> | <range of device numbers>, ...
The given device numbers will be ignored by the common I/O-layer; no detection
The given device numbers 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
...
@@ -41,45 +42,27 @@ Command line parameters
...
@@ -41,45 +42,27 @@ Command line parameters
By default, no devices are ignored.
By default, no devices are ignored.
* cio_proc_devinfo = yes | no
Determines whether the entries under /proc/deviceinfo/ (see below) should be
created. Since there are problems with systems with many devices attached, I
made it configurable.
Until the problems are dealt with, default is off.
/proc entries
/proc entries
-------------
-------------
* /proc/subchannels
* /proc/subchannels
Shows for each subchannel
This entry shows information on a per-subchannel basis.
The data is ordered in the following way:
- device number
- device number
- device type/model and if applicable control unit type/model
- subchannel number
- whether the device is in use
- device type/model (if applicable; if not, this is empty) and control unit
- path installed mask, path available mask, path operational mask and last
type/model
path used mask
- whether the device is in use (i. e. a device driver has requested ownership
- the channel path IDs (chpids)
and registered an interrupt handler)
- path installed mask (PIM), as reflected by last store subchannel
- path available mask (PAM), as reflected by last store subchannel
* /proc/deviceinfo/
- path operational mask (POM), as reflected by last store subchannel
- the channel path IDs (CHPIDs)
Shows in subdirectories for each device some characteristics:
- /proc/deviceinfo/<devno>/chpids:
All fields are separated by spaces, the chpids are in blocks of four chpids.
the channel path IDs
- /proc/deviceinfo/<devno>/in_use:
whether the device is in use
- /proc/deviceinfo/<devno>/sensedata:
the device type/model and if applicable control unit type/model of the
device
NOTE: Since the number of inodes which can be dynamically allocated by procfs
is limited, device entries will only be created up to a magic number of
devices. The kernel will utter a warning that not all entries can be
created. In this case, you shouldn't use "cio_proc_devinfo=yes" (see
above).
* /proc/cio_ignore
* /proc/cio_ignore
...
@@ -137,3 +120,26 @@ Command line parameters
...
@@ -137,3 +120,26 @@ Command line parameters
This entry counts how many times s390_process_IRQ has been called for each
This entry counts how many times s390_process_IRQ has been called for each
CPU. This info is in /proc/interrupts on other architectures.
CPU. This info is in /proc/interrupts on other architectures.
* /proc/chpids
This entry will only show up if you specified CONFIG_CHSC=y during kernel
config.
This entry serves a dual purpose:
- show which chpids are currently known to Linux and their status (online,
logically offline),
- toggling known chpids logically online/offline.
To toggle a known chpid logically offline, do an
echo off <chpid> > /proc/chpids
<chpid> is interpreted as hex, even if you omit the '0x'.
The chpid will be treated by Linux as if it were not online, which can mean
some devices will become unavailable.
You can toggle a logically offline chpid online again by
echo on <chpid> > /proc/chpids
If devices became unavailable by toggling the chpid logically offline, they
will become available again after you toggle the chpid online again.
Documentation/s390/Debugging390.txt
View file @
43c9d459
...
@@ -237,9 +237,10 @@ they go to 64 Bit.
...
@@ -237,9 +237,10 @@ they go to 64 Bit.
On 390 our limitations & strengths make us slightly different.
On 390 our limitations & strengths make us slightly different.
For backward compatibility we are only allowed use 31 bits (2GB)
For backward compatibility ( because of the psw address hi bit which
of our 32 bit addresses,however, we use entirely separate address
indicates whether we are in 31 or 24 bit mode ) we are only allowed
spaces for the user & kernel.
use 31 bits (2GB) of our 32 bit addresses. However,
we use entirely separate address spaces for the user & kernel.
This means we can support 2GB of non Extended RAM on s/390, & more
This means we can support 2GB of non Extended RAM on s/390, & more
with the Extended memory managment swap device &
with the Extended memory managment swap device &
...
@@ -1474,6 +1475,12 @@ Now display what gpr2 is pointing to
...
@@ -1474,6 +1475,12 @@ Now display what gpr2 is pointing to
D 00014CB4.20
D 00014CB4.20
V00014CB4 2F646576 2F636F6E 736F6C65 00001BF5
V00014CB4 2F646576 2F636F6E 736F6C65 00001BF5
V00014CC4 FC00014C B4001001 E0001000 B8070707
V00014CC4 FC00014C B4001001 E0001000 B8070707
Alternatively you can do the more elegant
D 0.20;BASE2
BASE2 telling VM to use GPR2 as the base register.
Now copy the text till the first 00 hex ( which is the end of the string
Now copy the text till the first 00 hex ( which is the end of the string
to an xterm & do hex2ascii on it.
to an xterm & do hex2ascii on it.
hex2ascii 2F646576 2F636F6E 736F6C65 00
hex2ascii 2F646576 2F636F6E 736F6C65 00
...
@@ -2124,6 +2131,12 @@ now do
...
@@ -2124,6 +2131,12 @@ now do
p/x (*(**$sp+56))&0x7fffffff
p/x (*(**$sp+56))&0x7fffffff
& so on.
& so on.
Another good trick to look at addresses on the stack if you've somehow lost
the backchain is.
x/500xa $sp
This displays anything the name of any known functions above the stack pointer
for 500 bytes.
Disassembling instructions without debug info
Disassembling instructions without debug info
---------------------------------------------
---------------------------------------------
gdb typically compains if there is a lack of debugging
gdb typically compains if there is a lack of debugging
...
...
Documentation/s390/cds.txt
View file @
43c9d459
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment