134 lines
3.9 KiB
ReStructuredText
134 lines
3.9 KiB
ReStructuredText
|
.. SPDX-License-Identifier: GPL-2.0
|
||
|
|
||
|
=========
|
||
|
S/390 PCI
|
||
|
=========
|
||
|
|
||
|
Authors:
|
||
|
- Pierre Morel
|
||
|
|
||
|
Copyright, IBM Corp. 2020
|
||
|
|
||
|
|
||
|
Command line parameters and debugfs entries
|
||
|
===========================================
|
||
|
|
||
|
Command line parameters
|
||
|
-----------------------
|
||
|
|
||
|
* nomio
|
||
|
|
||
|
Do not use PCI Mapped I/O (MIO) instructions.
|
||
|
|
||
|
* norid
|
||
|
|
||
|
Ignore the RID field and force use of one PCI domain per PCI function.
|
||
|
|
||
|
debugfs entries
|
||
|
---------------
|
||
|
|
||
|
The S/390 debug feature (s390dbf) generates views to hold various debug results in sysfs directories of the form:
|
||
|
|
||
|
* /sys/kernel/debug/s390dbf/pci_*/
|
||
|
|
||
|
For example:
|
||
|
|
||
|
- /sys/kernel/debug/s390dbf/pci_msg/sprintf
|
||
|
Holds messages from the processing of PCI events, like machine check handling
|
||
|
and setting of global functionality, like UID checking.
|
||
|
|
||
|
Change the level of logging to be more or less verbose by piping
|
||
|
a number between 0 and 6 to /sys/kernel/debug/s390dbf/pci_*/level. For
|
||
|
details, see the documentation on the S/390 debug feature at
|
||
|
Documentation/s390/s390dbf.rst.
|
||
|
|
||
|
Sysfs entries
|
||
|
=============
|
||
|
|
||
|
Entries specific to zPCI functions and entries that hold zPCI information.
|
||
|
|
||
|
* /sys/bus/pci/slots/XXXXXXXX
|
||
|
|
||
|
The slot entries are set up using the function identifier (FID) of the
|
||
|
PCI function. The format depicted as XXXXXXXX above is 8 hexadecimal digits
|
||
|
with 0 padding and lower case hexadecimal digitis.
|
||
|
|
||
|
- /sys/bus/pci/slots/XXXXXXXX/power
|
||
|
|
||
|
A physical function that currently supports a virtual function cannot be
|
||
|
powered off until all virtual functions are removed with:
|
||
|
echo 0 > /sys/bus/pci/devices/XXXX:XX:XX.X/sriov_numvf
|
||
|
|
||
|
* /sys/bus/pci/devices/XXXX:XX:XX.X/
|
||
|
|
||
|
- function_id
|
||
|
A zPCI function identifier that uniquely identifies the function in the Z server.
|
||
|
|
||
|
- function_handle
|
||
|
Low-level identifier used for a configured PCI function.
|
||
|
It might be useful for debuging.
|
||
|
|
||
|
- pchid
|
||
|
Model-dependent location of the I/O adapter.
|
||
|
|
||
|
- pfgid
|
||
|
PCI function group ID, functions that share identical functionality
|
||
|
use a common identifier.
|
||
|
A PCI group defines interrupts, IOMMU, IOTLB, and DMA specifics.
|
||
|
|
||
|
- vfn
|
||
|
The virtual function number, from 1 to N for virtual functions,
|
||
|
0 for physical functions.
|
||
|
|
||
|
- pft
|
||
|
The PCI function type
|
||
|
|
||
|
- port
|
||
|
The port corresponds to the physical port the function is attached to.
|
||
|
It also gives an indication of the physical function a virtual function
|
||
|
is attached to.
|
||
|
|
||
|
- uid
|
||
|
The user identifier (UID) may be defined as part of the machine
|
||
|
configuration or the z/VM or KVM guest configuration. If the accompanying
|
||
|
uid_is_unique attribute is 1 the platform guarantees that the UID is unique
|
||
|
within that instance and no devices with the same UID can be attached
|
||
|
during the lifetime of the system.
|
||
|
|
||
|
- uid_is_unique
|
||
|
Indicates whether the user identifier (UID) is guaranteed to be and remain
|
||
|
unique within this Linux instance.
|
||
|
|
||
|
- pfip/segmentX
|
||
|
The segments determine the isolation of a function.
|
||
|
They correspond to the physical path to the function.
|
||
|
The more the segments are different, the more the functions are isolated.
|
||
|
|
||
|
Enumeration and hotplug
|
||
|
=======================
|
||
|
|
||
|
The PCI address consists of four parts: domain, bus, device and function,
|
||
|
and is of this form: DDDD:BB:dd.f
|
||
|
|
||
|
* When not using multi-functions (norid is set, or the firmware does not
|
||
|
support multi-functions):
|
||
|
|
||
|
- There is only one function per domain.
|
||
|
|
||
|
- The domain is set from the zPCI function's UID as defined during the
|
||
|
LPAR creation.
|
||
|
|
||
|
* When using multi-functions (norid parameter is not set),
|
||
|
zPCI functions are addressed differently:
|
||
|
|
||
|
- There is still only one bus per domain.
|
||
|
|
||
|
- There can be up to 256 functions per bus.
|
||
|
|
||
|
- The domain part of the address of all functions for
|
||
|
a multi-Function device is set from the zPCI function's UID as defined
|
||
|
in the LPAR creation for the function zero.
|
||
|
|
||
|
- New functions will only be ready for use after the function zero
|
||
|
(the function with devfn 0) has been enumerated.
|