SYNOPSIS

       setpci [options] devices operations...



DESCRIPTION

       setpci is a utility for querying and configuring PCI devices.

       All numbers are entered in hexadecimal notation.

       Root  privileges  are  necessary  for  almost all operations, excluding
       reads of the standard header of the configuration space on some operat-
       ing systems.  Please see lspci(8) for details on access rights.



OPTIONS

       -v     Tells  setpci  to  be  verbose  and display detailed information
              about configuration space accesses.

       -f     Tells setpci not to complain when there's nothing to do (when no
              devices  are  selected).   This  option  is  intended for use in
              widely-distributed configuration scripts  where  it's  uncertain
              whether the device in question is present in the machine or not.

       -D     `Demo mode' -- don't write anything to the configuration  regis-
              ters.   It's  useful  to try setpci -vD to see what your complex
              sequence of setpci operations does before you  actually  execute
              it.

       --version
              Shows setpci version. This option should be used stand-alone.



DEVICE SELECTION

       Before each sequence of operations you need to select which devices you
       wish that operation to affect.

       -s [[[[<domain>]:]<bus>]:][<slot>][.[<func>]]
              Show only devices in the specified domain (in case your  machine
              has  several  host  bridges,  they can either share a common bus
              number space or each of them can address a  PCI  domain  of  its
              own;  domains  are numbered from 0 to ffff), bus (0 to ff), slot
              (0 to 1f) and function (0 to 7).  Each component of  the  device
              address  can be omitted or set to "*", both meaning "any value".
              All numbers are hexadecimal.  E.g., "0:" means  all  devices  on
              bus  0,  "0"  means  all functions of device 0 on any bus, "0.3"
              selects third function of device 0 on all buses and  ".4"  shows
              only the fourth function of each device.

       -d [<vendor>]:[<device>]
              Select  devices  with  specified vendor and device ID. Both ID's
              are given in hexadecimal and may be omitted  or  given  as  "*",
              both meaning "any value".


REGISTER NAMES

       setpci knows the following configuration register names.  See  PCI  bus
       specifications  for  their  precise  meaning  or  consult  header.h  or
       /usr/include/linux/pci.h for a couple of comments.

       VENDOR_ID
       DEVICE_ID
       COMMAND
       STATUS
       REVISION
       CLASS_PROG
       CLASS_DEVICE
       CACHE_LINE_SIZE
       LATENCY_TIMER
       HEADER_TYPE
       BIST
       BASE_ADDRESS_0
       BASE_ADDRESS_1
       BASE_ADDRESS_2
       BASE_ADDRESS_3
       BASE_ADDRESS_4
       BASE_ADDRESS_5
       CARDBUS_CIS
       SUBSYSTEM_VENDOR_ID
       SUBSYSTEM_ID
       ROM_ADDRESS
       INTERRUPT_LINE
       INTERRUPT_PIN
       MIN_GNT
       MAX_LAT
       PRIMARY_BUS
       SECONDARY_BUS
       SUBORDINATE_BUS
       SEC_LATENCY_TIMER
       IO_BASE
       IO_LIMIT
       SEC_STATUS
       MEMORY_BASE
       MEMORY_LIMIT
       PREF_MEMORY_BASE
       PREF_MEMORY_LIMIT
       PREF_BASE_UPPER32
       PREF_LIMIT_UPPER32
       IO_BASE_UPPER16
       IO_LIMIT_UPPER16
       BRIDGE_ROM_ADDRESS
       BRIDGE_CONTROL
       CB_CARDBUS_BASE
       CB_CAPABILITIES
       CB_SEC_STATUS
       CB_BUS_NUMBER
       CB_IO_LIMIT_1_HI
       CB_SUBSYSTEM_VENDOR_ID
       CB_SUBSYSTEM_ID
       CB_LEGACY_MODE_BASE



PCILIB OPTIONS

       The PCI utilities use PCILIB (a portable  library  providing  platform-
       independent  functions  for  PCI configuration space access) to talk to
       the PCI cards. Please see lspci(8) for a list of  switches  controlling
       behavior of the library.



EXAMPLES

       `setpci -d *:* latency_timer=40' sets the latency timer to 64 (40 hexa-
       decimal).

       `setpci -s 0 device_id vendor_id' lists ID's of devices in  slot  0  in
       all buses.

       `setpci  -s  12:3.4  3c.l=1,2,3' writes longword 1 to register 3c, 2 to
       register 3d and 3 to register 3e of device at bus 12, slot 3,  function
       4.

       `setpci -s 13:8.4 40.b=50:d0,04:0c,ff' works on bus 13, device 8, func-
       tion 4: turns bit 7 off and bits 6 and 4 on in the  byte  register  40;
       turns  bit 3 off and bit 2 on in the byte register 41; sets byte regis-
       ter 42 to ff.



SEE ALSO

       lspci(8)



AUTHOR

       The PCI Utilities are maintained by Martin Mares <mj@ucw.cz>.



pciutils-2.2.8                  19 October 2007                      setpci(8)

Man(1) output converted with man2html