2019-05-14 22:47:34 +08:00
.. SPDX-License-Identifier: GPL-2.0
===================
PCI Test User Guide
===================
:Author: Kishon Vijay Abraham I <kishon@ti.com>
2017-03-27 15:15:18 +05:30
This document is a guide to help users use pci-epf-test function driver
and pci_endpoint_test host driver for testing PCI. The list of steps to
be followed in the host side and EP side is given below.
2019-05-14 22:47:34 +08:00
Endpoint Device
===============
2017-03-27 15:15:18 +05:30
2019-05-14 22:47:34 +08:00
Endpoint Controller Devices
---------------------------
2017-03-27 15:15:18 +05:30
2019-05-14 22:47:34 +08:00
To find the list of endpoint controller devices in the system::
2017-03-27 15:15:18 +05:30
# ls /sys/class/pci_epc/
51000000.pcie_ep
2019-05-14 22:47:34 +08:00
If PCI_ENDPOINT_CONFIGFS is enabled::
2017-03-27 15:15:18 +05:30
# ls /sys/kernel/config/pci_ep/controllers
51000000.pcie_ep
2019-05-14 22:47:34 +08:00
Endpoint Function Drivers
-------------------------
To find the list of endpoint function drivers in the system::
2017-03-27 15:15:18 +05:30
# ls /sys/bus/pci-epf/drivers
pci_epf_test
2019-05-14 22:47:34 +08:00
If PCI_ENDPOINT_CONFIGFS is enabled::
2017-03-27 15:15:18 +05:30
# ls /sys/kernel/config/pci_ep/functions
pci_epf_test
2019-05-14 22:47:34 +08:00
Creating pci-epf-test Device
----------------------------
2017-03-27 15:15:18 +05:30
PCI endpoint function device can be created using the configfs. To create
2019-05-14 22:47:34 +08:00
pci-epf-test device, the following commands can be used::
2017-03-27 15:15:18 +05:30
# mount -t configfs none /sys/kernel/config
# cd /sys/kernel/config/pci_ep/
# mkdir functions/pci_epf_test/func1
The "mkdir func1" above creates the pci-epf-test function device that will
be probed by pci_epf_test driver.
The PCI endpoint framework populates the directory with the following
2019-05-14 22:47:34 +08:00
configurable fields::
2017-03-27 15:15:18 +05:30
# ls functions/pci_epf_test/func1
2018-07-19 10:32:19 +02:00
baseclass_code interrupt_pin progif_code subsys_id
cache_line_size msi_interrupts revid subsys_vendorid
deviceid msix_interrupts subclass_code vendorid
2017-03-27 15:15:18 +05:30
The PCI endpoint function driver populates these entries with default values
when the device is bound to the driver. The pci-epf-test driver populates
2019-05-14 22:47:34 +08:00
vendorid with 0xffff and interrupt_pin with 0x0001::
2017-03-27 15:15:18 +05:30
# cat functions/pci_epf_test/func1/vendorid
0xffff
# cat functions/pci_epf_test/func1/interrupt_pin
0x0001
2019-05-14 22:47:34 +08:00
Configuring pci-epf-test Device
-------------------------------
2017-03-27 15:15:18 +05:30
The user can configure the pci-epf-test device using configfs entry. In order
to change the vendorid and the number of MSI interrupts used by the function
2019-05-14 22:47:34 +08:00
device, the following commands can be used::
2017-03-27 15:15:18 +05:30
# echo 0x104c > functions/pci_epf_test/func1/vendorid
# echo 0xb500 > functions/pci_epf_test/func1/deviceid
# echo 16 > functions/pci_epf_test/func1/msi_interrupts
2018-07-19 10:32:19 +02:00
# echo 8 > functions/pci_epf_test/func1/msix_interrupts
2017-03-27 15:15:18 +05:30
2019-05-14 22:47:34 +08:00
Binding pci-epf-test Device to EP Controller
--------------------------------------------
2017-03-27 15:15:18 +05:30
In order for the endpoint function device to be useful, it has to be bound to
a PCI endpoint controller driver. Use the configfs to bind the function
2019-05-14 22:47:34 +08:00
device to one of the controller driver present in the system::
2017-03-27 15:15:18 +05:30
# ln -s functions/pci_epf_test/func1 controllers/51000000.pcie_ep/
Once the above step is completed, the PCI endpoint is ready to establish a link
with the host.
2019-05-14 22:47:34 +08:00
Start the Link
--------------
2017-03-27 15:15:18 +05:30
In order for the endpoint device to establish a link with the host, the _start_
2019-05-14 22:47:34 +08:00
field should be populated with '1'::
2017-03-27 15:15:18 +05:30
# echo 1 > controllers/51000000.pcie_ep/start
2019-05-14 22:47:34 +08:00
RootComplex Device
==================
lspci Output
------------
2017-03-27 15:15:18 +05:30
2019-05-14 22:47:34 +08:00
Note that the devices listed here correspond to the value populated in 1.4
above::
2017-03-27 15:15:18 +05:30
00:00.0 PCI bridge: Texas Instruments Device 8888 (rev 01)
01:00.0 Unassigned class [ff00]: Texas Instruments Device b500
2019-05-14 22:47:34 +08:00
Using Endpoint Test function Device
-----------------------------------
2017-03-27 15:15:18 +05:30
pcitest.sh added in tools/pci/ can be used to run all the default PCI endpoint
2019-05-14 22:47:34 +08:00
tests. To compile this tool the following commands should be used::
2017-03-27 15:15:18 +05:30
2018-08-23 13:55:15 +02:00
# cd <kernel-dir>
# make -C tools/pci
2019-05-14 22:47:34 +08:00
or if you desire to compile and install in your system::
2018-08-23 13:55:15 +02:00
# cd <kernel-dir>
# make -C tools/pci install
The tool and script will be located in <rootfs>/usr/bin/
2017-03-27 15:15:18 +05:30
2019-05-14 22:47:34 +08:00
pcitest.sh Output
~~~~~~~~~~~~~~~~~
::
2018-08-23 13:55:15 +02:00
# pcitest.sh
2017-03-27 15:15:18 +05:30
BAR tests
BAR0: OKAY
BAR1: OKAY
BAR2: OKAY
BAR3: OKAY
BAR4: NOT OKAY
BAR5: NOT OKAY
Interrupt tests
2018-07-19 10:32:21 +02:00
SET IRQ TYPE TO LEGACY: OKAY
2017-03-27 15:15:18 +05:30
LEGACY IRQ: NOT OKAY
2018-07-19 10:32:21 +02:00
SET IRQ TYPE TO MSI: OKAY
2017-03-27 15:15:18 +05:30
MSI1: OKAY
MSI2: OKAY
MSI3: OKAY
MSI4: OKAY
MSI5: OKAY
MSI6: OKAY
MSI7: OKAY
MSI8: OKAY
MSI9: OKAY
MSI10: OKAY
MSI11: OKAY
MSI12: OKAY
MSI13: OKAY
MSI14: OKAY
MSI15: OKAY
MSI16: OKAY
MSI17: NOT OKAY
MSI18: NOT OKAY
MSI19: NOT OKAY
MSI20: NOT OKAY
MSI21: NOT OKAY
MSI22: NOT OKAY
MSI23: NOT OKAY
MSI24: NOT OKAY
MSI25: NOT OKAY
MSI26: NOT OKAY
MSI27: NOT OKAY
MSI28: NOT OKAY
MSI29: NOT OKAY
MSI30: NOT OKAY
MSI31: NOT OKAY
MSI32: NOT OKAY
2018-07-19 10:32:21 +02:00
SET IRQ TYPE TO MSI-X: OKAY
MSI-X1: OKAY
MSI-X2: OKAY
MSI-X3: OKAY
MSI-X4: OKAY
MSI-X5: OKAY
MSI-X6: OKAY
MSI-X7: OKAY
MSI-X8: OKAY
MSI-X9: NOT OKAY
MSI-X10: NOT OKAY
MSI-X11: NOT OKAY
MSI-X12: NOT OKAY
MSI-X13: NOT OKAY
MSI-X14: NOT OKAY
MSI-X15: NOT OKAY
MSI-X16: NOT OKAY
2018-07-19 10:32:19 +02:00
[...]
2018-07-19 10:32:21 +02:00
MSI-X2047: NOT OKAY
MSI-X2048: NOT OKAY
2017-03-27 15:15:18 +05:30
Read Tests
2018-07-19 10:32:21 +02:00
SET IRQ TYPE TO MSI: OKAY
2017-03-27 15:15:18 +05:30
READ ( 1 bytes): OKAY
READ ( 1024 bytes): OKAY
READ ( 1025 bytes): OKAY
READ (1024000 bytes): OKAY
READ (1024001 bytes): OKAY
Write Tests
WRITE ( 1 bytes): OKAY
WRITE ( 1024 bytes): OKAY
WRITE ( 1025 bytes): OKAY
WRITE (1024000 bytes): OKAY
WRITE (1024001 bytes): OKAY
Copy Tests
COPY ( 1 bytes): OKAY
COPY ( 1024 bytes): OKAY
COPY ( 1025 bytes): OKAY
COPY (1024000 bytes): OKAY
COPY (1024001 bytes): OKAY