sphinx.addnodesdocument)}( rawsourcechildren]( translations LanguagesNode)}(hhh](h pending_xref)}(hhh]docutils.nodesTextChinese (Simplified)}parenthsba attributes}(ids]classes]names]dupnames]backrefs] refdomainstdreftypedoc reftarget#/translations/zh_CN/driver-api/scsimodnameN classnameN refexplicitutagnamehhh ubh)}(hhh]hChinese (Traditional)}hh2sbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget#/translations/zh_TW/driver-api/scsimodnameN classnameN refexplicituh1hhh ubh)}(hhh]hItalian}hhFsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget#/translations/it_IT/driver-api/scsimodnameN classnameN refexplicituh1hhh ubh)}(hhh]hJapanese}hhZsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget#/translations/ja_JP/driver-api/scsimodnameN classnameN refexplicituh1hhh ubh)}(hhh]hKorean}hhnsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget#/translations/ko_KR/driver-api/scsimodnameN classnameN refexplicituh1hhh ubh)}(hhh]hSpanish}hhsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget#/translations/sp_SP/driver-api/scsimodnameN classnameN refexplicituh1hhh ubeh}(h]h ]h"]h$]h&]current_languageEnglishuh1h hh _documenthsourceNlineNubhsection)}(hhh](htitle)}(hSCSI Interfaces Guideh]hSCSI Interfaces Guide}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhh=/var/lib/git/docbuild/linux/Documentation/driver-api/scsi.rsthKubh field_list)}(hhh](hfield)}(hhh](h field_name)}(hAuthorh]hAuthor}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhhKubh field_body)}(hJames Bottomleyh]h paragraph)}(hhh]hJames Bottomley}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhhubah}(h]h ]h"]h$]h&]uh1hhhubeh}(h]h ]h"]h$]h&]uh1hhhhKhhhhubh)}(hhh](h)}(hAuthorh]hAuthor}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhhKubh)}(h Rob Landley h]h)}(h Rob Landleyh]h Rob Landley}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjubah}(h]h ]h"]h$]h&]uh1hhhubeh}(h]h ]h"]h$]h&]uh1hhhhKhhhhubeh}(h]h ]h"]h$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h Introductionh]h Introduction}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hhhhhK ubh)}(hhh](h)}(hProtocol vs bush]hProtocol vs bus}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hhhhhK ubh)}(hXOnce upon a time, the Small Computer Systems Interface defined both a parallel I/O bus and a data protocol to connect a wide variety of peripherals (disk drives, tape drives, modems, printers, scanners, optical drives, test equipment, and medical devices) to a host computer.h]hXOnce upon a time, the Small Computer Systems Interface defined both a parallel I/O bus and a data protocol to connect a wide variety of peripherals (disk drives, tape drives, modems, printers, scanners, optical drives, test equipment, and medical devices) to a host computer.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj8hhubh)}(hAlthough the old parallel (fast/wide/ultra) SCSI bus has largely fallen out of use, the SCSI command set is more widely used than ever to communicate with devices over a number of different busses.h]hAlthough the old parallel (fast/wide/ultra) SCSI bus has largely fallen out of use, the SCSI command set is more widely used than ever to communicate with devices over a number of different busses.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj8hhubh)}(hThe `SCSI protocol `__ is a big-endian peer-to-peer packet based protocol. SCSI commands are 6, 10, 12, or 16 bytes long, often followed by an associated data payload.h](hThe }(hjehhhNhNubh reference)}(h2`SCSI protocol `__h]h SCSI protocol}(hjohhhNhNubah}(h]h ]h"]h$]h&]name SCSI protocolrefurihttps://www.t10.org/scsi-3.htmuh1jmhjeubh is a big-endian peer-to-peer packet based protocol. SCSI commands are 6, 10, 12, or 16 bytes long, often followed by an associated data payload.}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhj8hhubh)}(hXvSCSI commands can be transported over just about any kind of bus, and are the default protocol for storage devices attached to USB, SATA, SAS, Fibre Channel, FireWire, and ATAPI devices. SCSI packets are also commonly exchanged over Infiniband, TCP/IP (`iSCSI `__), even `Parallel ports `__.h](hSCSI commands can be transported over just about any kind of bus, and are the default protocol for storage devices attached to USB, SATA, SAS, Fibre Channel, FireWire, and ATAPI devices. SCSI packets are also commonly exchanged over Infiniband, TCP/IP (}(hjhhhNhNubjn)}(h/`iSCSI `__h]hiSCSI}(hjhhhNhNubah}(h]h ]h"]h$]h&]nameiSCSIj#https://en.wikipedia.org/wiki/ISCSIuh1jmhjubh), even }(hjhhhNhNubjn)}(hA`Parallel ports `__h]hParallel ports}(hjhhhNhNubah}(h]h ]h"]h$]h&]nameParallel portsj,http://cyberelk.net/tim/parport/parscsi.htmluh1jmhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhj8hhubeh}(h]protocol-vs-busah ]h"]protocol vs busah$]h&]uh1hhj'hhhhhK ubh)}(hhh](h)}(h"Design of the Linux SCSI subsystemh]h"Design of the Linux SCSI subsystem}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhK#ubh)}(hXThe SCSI subsystem uses a three layer design, with upper, mid, and low layers. Every operation involving the SCSI subsystem (such as reading a sector from a disk) uses one driver at each of the 3 levels: one upper layer driver, one lower layer driver, and the SCSI midlayer.h]hXThe SCSI subsystem uses a three layer design, with upper, mid, and low layers. Every operation involving the SCSI subsystem (such as reading a sector from a disk) uses one driver at each of the 3 levels: one upper layer driver, one lower layer driver, and the SCSI midlayer.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK%hjhhubh)}(hThe SCSI upper layer provides the interface between userspace and the kernel, in the form of block and char device nodes for I/O and ioctl(). The SCSI lower layer contains drivers for specific hardware devices.h]hThe SCSI upper layer provides the interface between userspace and the kernel, in the form of block and char device nodes for I/O and ioctl(). The SCSI lower layer contains drivers for specific hardware devices.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK*hjhhubh)}(hXaIn between is the SCSI mid-layer, analogous to a network routing layer such as the IPv4 stack. The SCSI mid-layer routes a packet based data protocol between the upper layer's /dev nodes and the corresponding devices in the lower layer. It manages command queues, provides error handling and power management functions, and responds to ioctl() requests.h]hXcIn between is the SCSI mid-layer, analogous to a network routing layer such as the IPv4 stack. The SCSI mid-layer routes a packet based data protocol between the upper layer’s /dev nodes and the corresponding devices in the lower layer. It manages command queues, provides error handling and power management functions, and responds to ioctl() requests.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK.hjhhubeh}(h]"design-of-the-linux-scsi-subsystemah ]h"]"design of the linux scsi subsystemah$]h&]uh1hhj'hhhhhK#ubeh}(h] introductionah ]h"] introductionah$]h&]uh1hhhhhhhhK ubh)}(hhh](h)}(hSCSI upper layerh]hSCSI upper layer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhK6ubh)}(hMThe upper layer supports the user-kernel interface by providing device nodes.h]hMThe upper layer supports the user-kernel interface by providing device nodes.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK8hjhhubh)}(hhh](h)}(hsd (SCSI Disk)h]hsd (SCSI Disk)}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hhhhhKhj5hhubeh}(h] sd-scsi-diskah ]h"]sd (scsi disk)ah$]h&]uh1hhjhhhhhK` to use as a cursor ``shost`` the :c:type:`struct scsi_host ` to iterate over **Description** Iterator that returns each device attached to **shost**. This loop takes a reference on each device and releases it at the end. If you break out of the loop, you must call scsi_device_put(sdev).h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjzubj#)}(hhh](j()}(hK``sdev`` the :c:type:`struct scsi_device ` to use as a cursor h](j.)}(h``sdev``h]j4)}(hjh]hsdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjubjJ)}(hhh]h)}(hAthe :c:type:`struct scsi_device ` to use as a cursorh](hthe }(hjhhhNhNubh)}(h*:c:type:`struct scsi_device `h]j4)}(hjh]hstruct scsi_device}(hjhhhNhNubah}(h]h ](xrefjc-typeeh"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]refdocdriver-api/scsi refdomainjreftypetype refexplicitrefwarn c:parent_keysphinx.domains.c LookupKey)}data]sb reftarget scsi_deviceuh1hhjhMhjubh to use as a cursor}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubj()}(hE``shost`` the :c:type:`struct scsi_host ` to iterate over h](j.)}(h ``shost``h]j4)}(hjh]hshost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjubjJ)}(hhh]h)}(h:the :c:type:`struct scsi_host ` to iterate overh](hthe }(hjhhhNhNubh)}(h&:c:type:`struct scsi_host `h]j4)}(hj)h]hstruct scsi_host}(hj+hhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hj'ubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjj scsi_hostuh1hhjhMhjubh to iterate over}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubeh}(h]h ]h"]h$]h&]uh1j"hjzubh)}(h**Description**h]j)}(hjdh]h Description}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjzubh)}(hIterator that returns each device attached to **shost**. This loop takes a reference on each device and releases it at the end. If you break out of the loop, you must call scsi_device_put(sdev).h](h.Iterator that returns each device attached to }(hjzhhhNhNubj)}(h **shost**h]hshost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubh. This loop takes a reference on each device and releases it at the end. If you break out of the loop, you must call scsi_device_put(sdev).}(hjzhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjzubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj"hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!__shost_for_each_device (C macro)c.__shost_for_each_devicehNtauh1j3hj"hhhNhNubjE)}(hhh](jJ)}(h__shost_for_each_deviceh]jP)}(h__shost_for_each_deviceh]jy)}(h__shost_for_each_deviceh]j)}(hjh]h__shost_for_each_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMubah}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1jDhhhj"hNhNubh)}(h)``__shost_for_each_device (sdev, shost)``h]j4)}(hjh]h%__shost_for_each_device (sdev, shost)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhj"hhubj`)}(h.iterate over all devices of a host (UNLOCKED) h]h)}(h-iterate over all devices of a host (UNLOCKED)h]h-iterate over all devices of a host (UNLOCKED)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjubah}(h]h ]h"]h$]h&]uh1j_hjhMhj"hhubj)}(hX**Parameters** ``sdev`` the :c:type:`struct scsi_device ` to use as a cursor ``shost`` the :c:type:`struct scsi_host ` to iterate over **Description** Iterator that returns each device attached to **shost**. It does _not_ take a reference on the scsi_device, so the whole loop must be protected by shost->host_lock. **Note** The only reason to use this is because you need to access the device list in interrupt context. Otherwise you really want to use shost_for_each_device instead.h](h)}(h**Parameters**h]j)}(hj&h]h Parameters}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhj ubj#)}(hhh](j()}(hK``sdev`` the :c:type:`struct scsi_device ` to use as a cursor h](j.)}(h``sdev``h]j4)}(hjEh]hsdev}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjCubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhj?ubjJ)}(hhh]h)}(hAthe :c:type:`struct scsi_device ` to use as a cursorh](hthe }(hj^hhhNhNubh)}(h*:c:type:`struct scsi_device `h]j4)}(hjhh]hstruct scsi_device}(hjjhhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hjfubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjj scsi_deviceuh1hhjZhMhj^ubh to use as a cursor}(hj^hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjZhMhj[ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j'hjZhMhj<ubj()}(hE``shost`` the :c:type:`struct scsi_host ` to iterate over h](j.)}(h ``shost``h]j4)}(hjh]hshost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjubjJ)}(hhh]h)}(h:the :c:type:`struct scsi_host ` to iterate overh](hthe }(hjhhhNhNubh)}(h&:c:type:`struct scsi_host `h]j4)}(hjh]hstruct scsi_host}(hjhhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjj scsi_hostuh1hhjhMhjubh to iterate over}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhj<ubeh}(h]h ]h"]h$]h&]uh1j"hj ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhj ubh)}(hIterator that returns each device attached to **shost**. It does _not_ take a reference on the scsi_device, so the whole loop must be protected by shost->host_lock.h](h.Iterator that returns each device attached to }(hjhhhNhNubj)}(h **shost**h]hshost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhn. It does _not_ take a reference on the scsi_device, so the whole loop must be protected by shost->host_lock.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhj ubh)}(h**Note**h]j)}(hj8h]hNote}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhj ubh)}(hThe only reason to use this is because you need to access the device list in interrupt context. Otherwise you really want to use shost_for_each_device instead.h]hThe only reason to use this is because you need to access the device list in interrupt context. Otherwise you really want to use shost_for_each_device instead.}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj"hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@%scsi_device_supports_vpd (C function)c.scsi_device_supports_vpdhNtauh1j3hj"hhhNhNubjE)}(hhh](jJ)}(h7int scsi_device_supports_vpd (struct scsi_device *sdev)h]jP)}(h6int scsi_device_supports_vpd(struct scsi_device *sdev)h](hdesc_sig_keyword_type)}(hinth]hint}(hjhhhNhNubah}(h]h ]ktah"]h$]h&]uh1j}hjyhhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjyhhhjhMubjy)}(hscsi_device_supports_vpdh]j)}(hscsi_device_supports_vpdh]hscsi_device_supports_vpd}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjyhhhjhMubhdesc_parameterlist)}(h(struct scsi_device *sdev)h]hdesc_parameter)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftype identifier reftargetjmodnameN classnameNjj)}j]j ASTIdentifier)}jjsbc.scsi_device_supports_vpdasbuh1hhjubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubhdesc_sig_punctuation)}(h*h]h*}(hj hhhNhNubah}(h]h ]pah"]h$]h&]uh1j hjubj)}(hsdevh]hsdev}(hj! hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjyhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjuhhhjhMubah}(h]jpah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjrhhubj)}(hhh]h)}(h#test if a device supports VPD pagesh]h#test if a device supports VPD pages}(hjK hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjH hhubah}(h]h ]h"]h$]h&]uh1jhjrhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjc jjc jjjuh1jDhhhj"hNhNubj)}(hX%**Parameters** ``struct scsi_device *sdev`` the :c:type:`struct scsi_device ` to test **Description** If the 'try_vpd_pages' flag is set it takes precedence. Otherwise we will assume VPD pages are supported if the SCSI level is at least SPC-3 and 'skip_vpd_pages' is not set.h](h)}(h**Parameters**h]j)}(hjm h]h Parameters}(hjo hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjk ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjg ubj#)}(hhh]j()}(hT``struct scsi_device *sdev`` the :c:type:`struct scsi_device ` to test h](j.)}(h``struct scsi_device *sdev``h]j4)}(hj h]hstruct scsi_device *sdev}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhj ubjJ)}(hhh]h)}(h6the :c:type:`struct scsi_device ` to testh](hthe }(hj hhhNhNubh)}(h*:c:type:`struct scsi_device `h]j4)}(hj h]hstruct scsi_device}(hj hhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjj scsi_deviceuh1hhj hMhj ubh to test}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj hMhj ubah}(h]h ]h"]h$]h&]uh1j"hjg ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjg ubh)}(hIf the 'try_vpd_pages' flag is set it takes precedence. Otherwise we will assume VPD pages are supported if the SCSI level is at least SPC-3 and 'skip_vpd_pages' is not set.h]hIf the ‘try_vpd_pages’ flag is set it takes precedence. Otherwise we will assume VPD pages are supported if the SCSI level is at least SPC-3 and ‘skip_vpd_pages’ is not set.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:93: ./include/scsi/scsi_device.hhMhjg ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj"hhhNhNubeh}(h]include-scsi-scsi-device-hah ]h"]include/scsi/scsi_device.hah$]h&]uh1hhjhhhhhK[ubh)}(hhh](h)}(hdrivers/scsi/scsi.ch]hdrivers/scsi/scsi.c}(hj! hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hhhhhKaubh)}(h Main file for the SCSI midlayer.h]h Main file for the SCSI midlayer.}(hj/ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKchj hhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@$scsi_change_queue_depth (C function)c.scsi_change_queue_depthhNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(hAint scsi_change_queue_depth (struct scsi_device *sdev, int depth)h]jP)}(h@int scsi_change_queue_depth(struct scsi_device *sdev, int depth)h](j~)}(hinth]hint}(hjV hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjR hhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKubjh)}(h h]h }(hje hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjR hhhjd hKubjy)}(hscsi_change_queue_depthh]j)}(hscsi_change_queue_depthh]hscsi_change_queue_depth}(hjw hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjs ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjR hhhjd hKubj)}(h%(struct scsi_device *sdev, int depth)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j)}jjy sbc.scsi_change_queue_depthasbuh1hhj ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj )}(hj h]h*}(hj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj ubj)}(hsdevh]hsdev}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h int depthh](j~)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj)}(hdepthh]hdepth}(hj! hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhjR hhhjd hKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjN hhhjd hKubah}(h]jI ah ](jjeh"]h$]h&]jj)jhuh1jIhjd hKhjK hhubj)}(hhh]h)}(hchange a device's queue depthh]hchange a device’s queue depth}(hjK hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjH hhubah}(h]h ]h"]h$]h&]uh1jhjK hhhjd hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjc jjc jjjuh1jDhhhj hNhNubj)}(h**Parameters** ``struct scsi_device *sdev`` SCSI Device in question ``int depth`` number of commands allowed to be queued to the driver **Description** Sets the device queue depth and returns the new value.h](h)}(h**Parameters**h]j)}(hjm h]h Parameters}(hjo hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjk ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjg ubj#)}(hhh](j()}(h5``struct scsi_device *sdev`` SCSI Device in question h](j.)}(h``struct scsi_device *sdev``h]j4)}(hj h]hstruct scsi_device *sdev}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhj ubjJ)}(hhh]h)}(hSCSI Device in questionh]hSCSI Device in question}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj hKhj ubj()}(hD``int depth`` number of commands allowed to be queued to the driver h](j.)}(h ``int depth``h]j4)}(hj h]h int depth}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhj ubjJ)}(hhh]h)}(h5number of commands allowed to be queued to the driverh]h5number of commands allowed to be queued to the driver}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj hKhj ubeh}(h]h ]h"]h$]h&]uh1j"hjg ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjg ubh)}(h6Sets the device queue depth and returns the new value.h]h6Sets the device queue depth and returns the new value.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjg ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"scsi_track_queue_full (C function)c.scsi_track_queue_fullhNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(h?int scsi_track_queue_full (struct scsi_device *sdev, int depth)h]jP)}(h>int scsi_track_queue_full(struct scsi_device *sdev, int depth)h](j~)}(hinth]hint}(hjE hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjA hhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKubjh)}(h h]h }(hjT hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjA hhhjS hKubjy)}(hscsi_track_queue_fullh]j)}(hscsi_track_queue_fullh]hscsi_track_queue_full}(hjf hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjb ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjA hhhjS hKubj)}(h%(struct scsi_device *sdev, int depth)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~ ubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j)}jjh sbc.scsi_track_queue_fullasbuh1hhj~ ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~ ubj )}(hj h]h*}(hj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj~ ubj)}(hsdevh]hsdev}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj~ ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjz ubj)}(h int depthh](j~)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj)}(hdepthh]hdepth}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjz ubeh}(h]h ]h"]h$]h&]jjuh1jhjA hhhjS hKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj= hhhjS hKubah}(h]j8 ah ](jjeh"]h$]h&]jj)jhuh1jIhjS hKhj: hhubj)}(hhh]h)}(h-track QUEUE_FULL events to adjust queue depthh]h-track QUEUE_FULL events to adjust queue depth}(hj: hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhj7 hhubah}(h]h ]h"]h$]h&]uh1jhj: hhhjS hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjR jjR jjjuh1jDhhhj hNhNubj)}(hX**Parameters** ``struct scsi_device *sdev`` SCSI Device in question ``int depth`` Current number of outstanding SCSI commands on this device, not counting the one returned as QUEUE_FULL. **Description** This function will track successive QUEUE_FULL events on a specific SCSI device to determine if and when there is a need to adjust the queue depth on the device. Lock Status: None held on entry **Return** 0 - No change needed, >0 - Adjust queue depth to this new depth, -1 - Drop back to untagged operation using host->cmd_per_lun as the untagged command depth **Notes** Low level drivers may call this at any time and we will do "The Right Thing." We are interrupt context safe.h](h)}(h**Parameters**h]j)}(hj\ h]h Parameters}(hj^ hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZ ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjV ubj#)}(hhh](j()}(h5``struct scsi_device *sdev`` SCSI Device in question h](j.)}(h``struct scsi_device *sdev``h]j4)}(hj{ h]hstruct scsi_device *sdev}(hj} hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjy ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhju ubjJ)}(hhh]h)}(hSCSI Device in questionh]hSCSI Device in question}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1jIhju ubeh}(h]h ]h"]h$]h&]uh1j'hj hKhjr ubj()}(hw``int depth`` Current number of outstanding SCSI commands on this device, not counting the one returned as QUEUE_FULL. h](j.)}(h ``int depth``h]j4)}(hj h]h int depth}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhj ubjJ)}(hhh]h)}(hhCurrent number of outstanding SCSI commands on this device, not counting the one returned as QUEUE_FULL.h]hhCurrent number of outstanding SCSI commands on this device, not counting the one returned as QUEUE_FULL.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhj ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj hKhjr ubeh}(h]h ]h"]h$]h&]uh1j"hjV ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjV ubj#)}(hhh]j()}(hThis function will track successive QUEUE_FULL events on a specific SCSI device to determine if and when there is a need to adjust the queue depth on the device. h](j.)}(h:This function will track successive QUEUE_FULL events on ah]h:This function will track successive QUEUE_FULL events on a}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhj ubjJ)}(hhh]h)}(hfspecific SCSI device to determine if and when there is a need to adjust the queue depth on the device.h]hfspecific SCSI device to determine if and when there is a need to adjust the queue depth on the device.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubah}(h]h ]h"]h$]h&]uh1j"hjV ubh)}(hLock Status: None held on entryh]hLock Status: None held on entry}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjV ubh)}(h **Return**h]j)}(hjQh]hReturn}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjV ubj#)}(hhh]j()}(h0 - No change needed, >0 - Adjust queue depth to this new depth, -1 - Drop back to untagged operation using host->cmd_per_lun as the untagged command depth h](j.)}(h@0 - No change needed, >0 - Adjust queue depth to this new depth,h]h@0 - No change needed, >0 - Adjust queue depth to this new depth,}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjjubjJ)}(hhh]j#)}(hhh]j()}(h[-1 - Drop back to untagged operation using host->cmd_per_lun as the untagged command depth h](j.)}(h<-1 - Drop back to untagged operation using host->cmd_per_lunh]h<-1 - Drop back to untagged operation using host->cmd_per_lun}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j-hj|hKhjubjJ)}(hhh]h)}(has the untagged command depthh]has the untagged command depth}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj|hKhjubah}(h]h ]h"]h$]h&]uh1j"hj}ubah}(h]h ]h"]h$]h&]uh1jIhjjubeh}(h]h ]h"]h$]h&]uh1j'hj|hKhjgubah}(h]h ]h"]h$]h&]uh1j"hjV ubh)}(h **Notes**h]j)}(hjh]hNotes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjV ubj#)}(hhh]j()}(hmLow level drivers may call this at any time and we will do "The Right Thing." We are interrupt context safe.h](j.)}(h:Low level drivers may call this at any time and we will doh]h:Low level drivers may call this at any time and we will do}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjubjJ)}(hhh]h)}(h2"The Right Thing." We are interrupt context safe.h]h6“The Right Thing.” We are interrupt context safe.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubah}(h]h ]h"]h$]h&]uh1j"hjV ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_get_vpd_page (C function)c.scsi_get_vpd_pagehNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(hZint scsi_get_vpd_page (struct scsi_device *sdev, u8 page, unsigned char *buf, int buf_len)h]jP)}(hYint scsi_get_vpd_page(struct scsi_device *sdev, u8 page, unsigned char *buf, int buf_len)h](j~)}(hinth]hint}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj8hhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMubjh)}(h h]h }(hjKhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj8hhhjJhMubjy)}(hscsi_get_vpd_pageh]j)}(hscsi_get_vpd_pageh]hscsi_get_vpd_page}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjYubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj8hhhjJhMubj)}(hD(struct scsi_device *sdev, u8 page, unsigned char *buf, int buf_len)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjuubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjuubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jj_sbc.scsi_get_vpd_pageasbuh1hhjuubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjuubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjuubj)}(hsdevh]hsdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjuubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjqubj)}(hu8 pageh](h)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.scsi_get_vpd_pageasbuh1hhjubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hpageh]hpage}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjqubj)}(hunsigned char *bufh](j~)}(hunsignedh]hunsigned}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj/ubjh)}(h h]h }(hjAhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj/ubj~)}(hcharh]hchar}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj/ubjh)}(h h]h }(hj]hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj/ubj )}(hj h]h*}(hjkhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj/ubj)}(hbufh]hbuf}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj/ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjqubj)}(h int buf_lenh](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hbuf_lenh]hbuf_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjqubeh}(h]h ]h"]h$]h&]jjuh1jhj8hhhjJhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj4hhhjJhMubah}(h]j/ah ](jjeh"]h$]h&]jj)jhuh1jIhjJhMhj1hhubj)}(hhh]h)}(h)Get Vital Product Data from a SCSI deviceh]h)Get Vital Product Data from a SCSI device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj1hhhjJhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhj hNhNubj)}(hX;**Parameters** ``struct scsi_device *sdev`` The device to ask ``u8 page`` Which Vital Product Data to return ``unsigned char *buf`` where to store the VPD ``int buf_len`` number of bytes in the VPD buffer area **Description** SCSI devices may optionally supply Vital Product Data. Each 'page' of VPD is defined in the appropriate SCSI document (eg SPC, SBC). If the device supports this VPD page, this routine fills **buf** with the data from that page and return 0. If the VPD page is not supported or its content cannot be retrieved, -EINVAL is returned.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjubj#)}(hhh](j()}(h/``struct scsi_device *sdev`` The device to ask h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjubjJ)}(hhh]h)}(hThe device to askh]hThe device to ask}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hMhj.ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj-hMhjubj()}(h/``u8 page`` Which Vital Product Data to return h](j.)}(h ``u8 page``h]j4)}(hjQh]hu8 page}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjOubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjKubjJ)}(hhh]h)}(h"Which Vital Product Data to returnh]h"Which Vital Product Data to return}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjgubah}(h]h ]h"]h$]h&]uh1jIhjKubeh}(h]h ]h"]h$]h&]uh1j'hjfhMhjubj()}(h.``unsigned char *buf`` where to store the VPD h](j.)}(h``unsigned char *buf``h]j4)}(hjh]hunsigned char *buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjubjJ)}(hhh]h)}(hwhere to store the VPDh]hwhere to store the VPD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubj()}(h7``int buf_len`` number of bytes in the VPD buffer area h](j.)}(h``int buf_len``h]j4)}(hjh]h int buf_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjubjJ)}(hhh]h)}(h&number of bytes in the VPD buffer areah]h&number of bytes in the VPD buffer area}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjubh)}(hXKSCSI devices may optionally supply Vital Product Data. Each 'page' of VPD is defined in the appropriate SCSI document (eg SPC, SBC). If the device supports this VPD page, this routine fills **buf** with the data from that page and return 0. If the VPD page is not supported or its content cannot be retrieved, -EINVAL is returned.h](hSCSI devices may optionally supply Vital Product Data. Each ‘page’ of VPD is defined in the appropriate SCSI document (eg SPC, SBC). If the device supports this VPD page, this routine fills }(hjhhhNhNubj)}(h**buf**h]hbuf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh with the data from that page and return 0. If the VPD page is not supported or its content cannot be retrieved, -EINVAL is returned.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_report_opcode (C function)c.scsi_report_opcodehNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(hint scsi_report_opcode (struct scsi_device *sdev, unsigned char *buffer, unsigned int len, unsigned char opcode, unsigned short sa)h]jP)}(hint scsi_report_opcode(struct scsi_device *sdev, unsigned char *buffer, unsigned int len, unsigned char opcode, unsigned short sa)h](j~)}(hinth]hint}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjQhhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM"ubjh)}(h h]h }(hjdhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjQhhhjchM"ubjy)}(hscsi_report_opcodeh]j)}(hscsi_report_opcodeh]hscsi_report_opcode}(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjrubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjQhhhjchM"ubj)}(hl(struct scsi_device *sdev, unsigned char *buffer, unsigned int len, unsigned char opcode, unsigned short sa)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjxsbc.scsi_report_opcodeasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hsdevh]hsdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned char *bufferh](j~)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj~)}(hcharh]hchar}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hj.hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hj<hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hbufferh]hbuffer}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int lenh](j~)}(hunsignedh]hunsigned}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj^ubjh)}(h h]h }(hjphhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj^ubj~)}(hinth]hint}(hj~hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj^ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj^ubj)}(hlenh]hlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned char opcodeh](j~)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj~)}(hcharh]hchar}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hopcodeh]hopcode}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned short sah](j~)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj~)}(hshorth]hshort}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hj.hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hsah]hsa}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjQhhhjchM"ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjMhhhjchM"ubah}(h]jHah ](jjeh"]h$]h&]jj)jhuh1jIhjchM"hjJhhubj)}(hhh]h)}(h(Find out if a given command is supportedh]h(Find out if a given command is supported}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM"hjchhubah}(h]h ]h"]h$]h&]uh1jhjJhhhjchM"ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj~jj~jjjuh1jDhhhj hNhNubj)}(hXs**Parameters** ``struct scsi_device *sdev`` scsi device to query ``unsigned char *buffer`` scratch buffer (must be at least 20 bytes long) ``unsigned int len`` length of buffer ``unsigned char opcode`` opcode for the command to look up ``unsigned short sa`` service action for the command to look up **Description** Uses the REPORT SUPPORTED OPERATION CODES to check support for the command identified with **opcode** and **sa**. If the command does not have a service action, **sa** must be 0. Returns -EINVAL if RSOC fails, 0 if the command is not supported and 1 if the device claims to support the command.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM&hjubj#)}(hhh](j()}(h2``struct scsi_device *sdev`` scsi device to query h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM#hjubjJ)}(hhh]h)}(hscsi device to queryh]hscsi device to query}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM#hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM#hjubj()}(hJ``unsigned char *buffer`` scratch buffer (must be at least 20 bytes long) h](j.)}(h``unsigned char *buffer``h]j4)}(hjh]hunsigned char *buffer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM$hjubjJ)}(hhh]h)}(h/scratch buffer (must be at least 20 bytes long)h]h/scratch buffer (must be at least 20 bytes long)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM$hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM$hjubj()}(h&``unsigned int len`` length of buffer h](j.)}(h``unsigned int len``h]j4)}(hjh]hunsigned int len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM%hjubjJ)}(hhh]h)}(hlength of bufferh]hlength of buffer}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hM%hj/ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj.hM%hjubj()}(h;``unsigned char opcode`` opcode for the command to look up h](j.)}(h``unsigned char opcode``h]j4)}(hjRh]hunsigned char opcode}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjPubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM&hjLubjJ)}(hhh]h)}(h!opcode for the command to look uph]h!opcode for the command to look up}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghM&hjhubah}(h]h ]h"]h$]h&]uh1jIhjLubeh}(h]h ]h"]h$]h&]uh1j'hjghM&hjubj()}(h@``unsigned short sa`` service action for the command to look up h](j.)}(h``unsigned short sa``h]j4)}(hjh]hunsigned short sa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM'hjubjJ)}(hhh]h)}(h)service action for the command to look uph]h)service action for the command to look up}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM'hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM'hjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM)hjubh)}(hX&Uses the REPORT SUPPORTED OPERATION CODES to check support for the command identified with **opcode** and **sa**. If the command does not have a service action, **sa** must be 0. Returns -EINVAL if RSOC fails, 0 if the command is not supported and 1 if the device claims to support the command.h](h[Uses the REPORT SUPPORTED OPERATION CODES to check support for the command identified with }(hjhhhNhNubj)}(h **opcode**h]hopcode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and }(hjhhhNhNubj)}(h**sa**h]hsa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh1. If the command does not have a service action, }(hjhhhNhNubj)}(h**sa**h]hsa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh must be 0. Returns -EINVAL if RSOC fails, 0 if the command is not supported and 1 if the device claims to support the command.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM)hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_device_get (C function)c.scsi_device_gethNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(h.int scsi_device_get (struct scsi_device *sdev)h]jP)}(h-int scsi_device_get(struct scsi_device *sdev)h](j~)}(hinth]hint}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj=hhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM ubjh)}(h h]h }(hjPhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj=hhhjOhM ubjy)}(hscsi_device_geth]j)}(hscsi_device_geth]hscsi_device_get}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj^ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj=hhhjOhM ubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjzubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjdsbc.scsi_device_getasbuh1hhjzubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjzubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjzubj)}(hsdevh]hsdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvubah}(h]h ]h"]h$]h&]jjuh1jhj=hhhjOhM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj9hhhjOhM ubah}(h]j4ah ](jjeh"]h$]h&]jj)jhuh1jIhjOhM hj6hhubj)}(hhh]h)}(h,get an additional reference to a scsi_deviceh]h,get an additional reference to a scsi_device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhj6hhhjOhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhj hNhNubj)}(hX**Parameters** ``struct scsi_device *sdev`` device to get a reference to **Description** Gets a reference to the scsi_device and increments the use count of the underlying LLDD module. You must hold host_lock of the parent Scsi_Host or already have a reference when calling this. This will fail if a device is deleted or cancelled, or when the LLD module is in the process of being unloaded.h](h)}(h**Parameters**h]j)}(hj#h]h Parameters}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM hjubj#)}(hhh]j()}(h:``struct scsi_device *sdev`` device to get a reference to h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjBh]hstruct scsi_device *sdev}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj@ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM hj<ubjJ)}(hhh]h)}(hdevice to get a reference toh]hdevice to get a reference to}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhM hjXubah}(h]h ]h"]h$]h&]uh1jIhj<ubeh}(h]h ]h"]h$]h&]uh1j'hjWhM hj9ubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hj}h]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM hjubh)}(hGets a reference to the scsi_device and increments the use count of the underlying LLDD module. You must hold host_lock of the parent Scsi_Host or already have a reference when calling this.h]hGets a reference to the scsi_device and increments the use count of the underlying LLDD module. You must hold host_lock of the parent Scsi_Host or already have a reference when calling this.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM hjubh)}(hoThis will fail if a device is deleted or cancelled, or when the LLD module is in the process of being unloaded.h]hoThis will fail if a device is deleted or cancelled, or when the LLD module is in the process of being unloaded.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_device_put (C function)c.scsi_device_puthNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(h/void scsi_device_put (struct scsi_device *sdev)h]jP)}(h.void scsi_device_put(struct scsi_device *sdev)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM%ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM%ubjy)}(hscsi_device_puth]j)}(hscsi_device_puth]hscsi_device_put}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhM%ubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj.modnameN classnameNjj)}j]j)}jjsbc.scsi_device_putasbuh1hhj ubjh)}(h h]h }(hjLhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj )}(hj h]h*}(hjZhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj ubj)}(hsdevh]hsdev}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM%ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM%ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhM%hjhhubj)}(hhh]h)}(h$release a reference to a scsi_deviceh]h$release a reference to a scsi_device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM%hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM%ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhj hNhNubj)}(h**Parameters** ``struct scsi_device *sdev`` device to release a reference on. **Description** Release a reference to the scsi_device and decrements the use count of the underlying LLDD module. The device is freed once the last user vanishes.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM)hjubj#)}(hhh]j()}(h?``struct scsi_device *sdev`` device to release a reference on. h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM&hjubjJ)}(hhh]h)}(h!device to release a reference on.h]h!device to release a reference on.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM&hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM&hjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hj h]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM(hjubh)}(hRelease a reference to the scsi_device and decrements the use count of the underlying LLDD module. The device is freed once the last user vanishes.h]hRelease a reference to the scsi_device and decrements the use count of the underlying LLDD module. The device is freed once the last user vanishes.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chM(hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@$starget_for_each_device (C function)c.starget_for_each_devicehNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(hpvoid starget_for_each_device (struct scsi_target *starget, void *data, void (*fn)(struct scsi_device *, void *))h]jP)}(hmvoid starget_for_each_device(struct scsi_target *starget, void *data, void (*fn)(struct scsi_device*, void*))h](j~)}(hvoidh]hvoid}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjNhhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMOubjh)}(h h]h }(hjahhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjNhhhj`hMOubjy)}(hstarget_for_each_deviceh]j)}(hstarget_for_each_deviceh]hstarget_for_each_device}(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjoubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjNhhhj`hMOubj)}(hQ(struct scsi_target *starget, void *data, void (*fn)(struct scsi_device*, void*))h](j)}(hstruct scsi_target *stargeth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_targeth]h scsi_target}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjusbc.starget_for_each_deviceasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hstargeth]hstarget}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h void *datah](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hdatah]hdata}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h&void (*fn)(struct scsi_device*, void*)h](j~)}(hvoidh]hvoid}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj?ubjh)}(h h]h }(hjQhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj?ubj )}(h(h]h(}(hj_hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj?ubj )}(hj h]h*}(hjmhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj?ubj)}(hfnh]hfn}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj?ubj )}(h)h]h)}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj?ubj )}(hjah]h(}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj?ubjV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj?ubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.starget_for_each_deviceasbuh1hhj?ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj?ubj )}(h,h]h,}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj?ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj?ubj~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj?ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj?ubj )}(hjh]h)}(hj#hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj?ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjNhhhj`hMOubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjJhhhj`hMOubah}(h]jEah ](jjeh"]h$]h&]jj)jhuh1jIhj`hMOhjGhhubj)}(hhh]h)}(h&helper to walk all devices of a targeth]h&helper to walk all devices of a target}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMOhjIhhubah}(h]h ]h"]h$]h&]uh1jhjGhhhj`hMOubeh}(h]h ](jfunctioneh"]h$]h&]jjjjdjjdjjjuh1jDhhhj hNhNubj)}(hX**Parameters** ``struct scsi_target *starget`` target whose devices we want to iterate over. ``void *data`` Opaque passed to each function call. ``void (*fn)(struct scsi_device *, void *)`` Function to call on each device **Description** This traverses over each device of **starget**. The devices have a reference that must be released by scsi_host_put when breaking out of the loop.h](h)}(h**Parameters**h]j)}(hjnh]h Parameters}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMShjhubj#)}(hhh](j()}(hN``struct scsi_target *starget`` target whose devices we want to iterate over. h](j.)}(h``struct scsi_target *starget``h]j4)}(hjh]hstruct scsi_target *starget}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMPhjubjJ)}(hhh]h)}(h-target whose devices we want to iterate over.h]h-target whose devices we want to iterate over.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMPhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMPhjubj()}(h4``void *data`` Opaque passed to each function call. h](j.)}(h``void *data``h]j4)}(hjh]h void *data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMQhjubjJ)}(hhh]h)}(h$Opaque passed to each function call.h]h$Opaque passed to each function call.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMQhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMQhjubj()}(hM``void (*fn)(struct scsi_device *, void *)`` Function to call on each device h](j.)}(h,``void (*fn)(struct scsi_device *, void *)``h]j4)}(hjh]h(void (*fn)(struct scsi_device *, void *)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMRhjubjJ)}(hhh]h)}(hFunction to call on each deviceh]hFunction to call on each device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMRhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMRhjubeh}(h]h ]h"]h$]h&]uh1j"hjhubh)}(h**Description**h]j)}(hj:h]h Description}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMThjhubh)}(hThis traverses over each device of **starget**. The devices have a reference that must be released by scsi_host_put when breaking out of the loop.h](h#This traverses over each device of }(hjPhhhNhNubj)}(h **starget**h]hstarget}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubhe. The devices have a reference that must be released by scsi_host_put when breaking out of the loop.}(hjPhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMThjhubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@&__starget_for_each_device (C function)c.__starget_for_each_devicehNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(hrvoid __starget_for_each_device (struct scsi_target *starget, void *data, void (*fn)(struct scsi_device *, void *))h]jP)}(hovoid __starget_for_each_device(struct scsi_target *starget, void *data, void (*fn)(struct scsi_device*, void*))h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMgubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMgubjy)}(h__starget_for_each_deviceh]j)}(h__starget_for_each_deviceh]h__starget_for_each_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMgubj)}(hQ(struct scsi_target *starget, void *data, void (*fn)(struct scsi_device*, void*))h](j)}(hstruct scsi_target *stargeth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_targeth]h scsi_target}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.__starget_for_each_deviceasbuh1hhjubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hstargeth]hstarget}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h void *datah](j~)}(hvoidh]hvoid}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj<ubjh)}(h h]h }(hjNhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj<ubj )}(hj h]h*}(hj\hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj<ubj)}(hdatah]hdata}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj<ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h&void (*fn)(struct scsi_device*, void*)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj~ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~ubj )}(hjah]h(}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj~ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj~ubj)}(hfnh]hfn}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj~ubj )}(hjh]h)}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj~ubj )}(hjah]h(}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj~ubjV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~ubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.__starget_for_each_deviceasbuh1hhj~ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj~ubj )}(hjh]h,}(hj)hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj~ubjh)}(h h]h }(hj6hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~ubj~)}(hvoidh]hvoid}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj~ubj )}(hj h]h*}(hjRhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj~ubj )}(hjh]h)}(hj_hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMgubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMgubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMghjhhubj)}(hhh]h)}(h1helper to walk all devices of a target (UNLOCKED)h]h1helper to walk all devices of a target (UNLOCKED)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMghjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMgubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhj hNhNubj)}(hXd**Parameters** ``struct scsi_target *starget`` target whose devices we want to iterate over. ``void *data`` parameter for callback **fn\(\)** ``void (*fn)(struct scsi_device *, void *)`` callback function that is invoked for each device **Description** This traverses over each device of **starget**. It does _not_ take a reference on the scsi_device, so the whole loop must be protected by shost->host_lock. **Note** The only reason why drivers would want to use this is because they need to access the device list in irq context. Otherwise you really want to use starget_for_each_device instead.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMkhjubj#)}(hhh](j()}(hN``struct scsi_target *starget`` target whose devices we want to iterate over. h](j.)}(h``struct scsi_target *starget``h]j4)}(hjh]hstruct scsi_target *starget}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhhjubjJ)}(hhh]h)}(h-target whose devices we want to iterate over.h]h-target whose devices we want to iterate over.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhhjubj()}(h1``void *data`` parameter for callback **fn\(\)** h](j.)}(h``void *data``h]j4)}(hjh]h void *data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMihjubjJ)}(hhh]h)}(h!parameter for callback **fn\(\)**h](hparameter for callback }(hjhhhNhNubj)}(h **fn\(\)**h]hfn()}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhMihjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMihjubj()}(h_``void (*fn)(struct scsi_device *, void *)`` callback function that is invoked for each device h](j.)}(h,``void (*fn)(struct scsi_device *, void *)``h]j4)}(hjIh]h(void (*fn)(struct scsi_device *, void *)}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjGubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMjhjCubjJ)}(hhh]h)}(h1callback function that is invoked for each deviceh]h1callback function that is invoked for each device}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hMjhj_ubah}(h]h ]h"]h$]h&]uh1jIhjCubeh}(h]h ]h"]h$]h&]uh1j'hj^hMjhjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMlhjubh)}(hThis traverses over each device of **starget**. It does _not_ take a reference on the scsi_device, so the whole loop must be protected by shost->host_lock.h](h#This traverses over each device of }(hjhhhNhNubj)}(h **starget**h]hstarget}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhn. It does _not_ take a reference on the scsi_device, so the whole loop must be protected by shost->host_lock.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMlhjubh)}(h**Note**h]j)}(hjh]hNote}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMphjubh)}(hThe only reason why drivers would want to use this is because they need to access the device list in irq context. Otherwise you really want to use starget_for_each_device instead.h]hThe only reason why drivers would want to use this is because they need to access the device list in irq context. Otherwise you really want to use starget_for_each_device instead.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMphjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@+__scsi_device_lookup_by_target (C function) c.__scsi_device_lookup_by_targethNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(hZstruct scsi_device * __scsi_device_lookup_by_target (struct scsi_target *starget, u64 lun)h]jP)}(hXstruct scsi_device *__scsi_device_lookup_by_target(struct scsi_target *starget, u64 lun)h](jV)}(hjYh]hstruct}(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhj hMubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj! hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj# modnameN classnameNjj)}j]j)}j__scsi_device_lookup_by_targetsb c.__scsi_device_lookup_by_targetasbuh1hhjhhhj hMubjh)}(h h]h }(hjB hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhj hMubj )}(hj h]h*}(hjP hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjhhhj hMubjy)}(h__scsi_device_lookup_by_targeth]j)}(hj? h]h__scsi_device_lookup_by_target}(hja hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj] ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhj hMubj)}(h&(struct scsi_target *starget, u64 lun)h](j)}(hstruct scsi_target *stargeth](jV)}(hjYh]hstruct}(hj| hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjx ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjx ubh)}(hhh]j)}(h scsi_targeth]h scsi_target}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j= c.__scsi_device_lookup_by_targetasbuh1hhjx ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjx ubj )}(hj h]h*}(hj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjx ubj)}(hstargeth]hstarget}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjx ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjt ubj)}(hu64 lunh](h)}(hhh]j)}(hu64h]hu64}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j= c.__scsi_device_lookup_by_targetasbuh1hhj ubjh)}(h h]h }(hj !hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj)}(hlunh]hlun}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjt ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhj hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhj hMhjhhubj)}(hhh]h)}(h)find a device given the target (UNLOCKED)h]h)find a device given the target (UNLOCKED)}(hjE!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjB!hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj]!jj]!jjjuh1jDhhhj hNhNubj)}(hXV**Parameters** ``struct scsi_target *starget`` SCSI target pointer ``u64 lun`` SCSI Logical Unit Number **Description** Looks up the scsi_device with the specified **lun** for a given **starget**. The returned scsi_device does not have an additional reference. You must hold the host's host_lock over this call and any access to the returned scsi_device. A scsi_device in state SDEV_DEL is skipped. **Note** The only reason why drivers should use this is because they need to access the device list in irq context. Otherwise you really want to use scsi_device_lookup_by_target instead.h](h)}(h**Parameters**h]j)}(hjg!h]h Parameters}(hji!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhje!ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhja!ubj#)}(hhh](j()}(h4``struct scsi_target *starget`` SCSI target pointer h](j.)}(h``struct scsi_target *starget``h]j4)}(hj!h]hstruct scsi_target *starget}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj!ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj!ubjJ)}(hhh]h)}(hSCSI target pointerh]hSCSI target pointer}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMhj!ubah}(h]h ]h"]h$]h&]uh1jIhj!ubeh}(h]h ]h"]h$]h&]uh1j'hj!hMhj}!ubj()}(h%``u64 lun`` SCSI Logical Unit Number h](j.)}(h ``u64 lun``h]j4)}(hj!h]hu64 lun}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj!ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj!ubjJ)}(hhh]h)}(hSCSI Logical Unit Numberh]hSCSI Logical Unit Number}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMhj!ubah}(h]h ]h"]h$]h&]uh1jIhj!ubeh}(h]h ]h"]h$]h&]uh1j'hj!hMhj}!ubeh}(h]h ]h"]h$]h&]uh1j"hja!ubh)}(h**Description**h]j)}(hj!h]h Description}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhja!ubh)}(hXLooks up the scsi_device with the specified **lun** for a given **starget**. The returned scsi_device does not have an additional reference. You must hold the host's host_lock over this call and any access to the returned scsi_device. A scsi_device in state SDEV_DEL is skipped.h](h,Looks up the scsi_device with the specified }(hj"hhhNhNubj)}(h**lun**h]hlun}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubh for a given }(hj"hhhNhNubj)}(h **starget**h]hstarget}(hj*"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubh. The returned scsi_device does not have an additional reference. You must hold the host’s host_lock over this call and any access to the returned scsi_device. A scsi_device in state SDEV_DEL is skipped.}(hj"hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhja!ubh)}(h**Note**h]j)}(hjE"h]hNote}(hjG"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjC"ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhja!ubh)}(hThe only reason why drivers should use this is because they need to access the device list in irq context. Otherwise you really want to use scsi_device_lookup_by_target instead.h]hThe only reason why drivers should use this is because they need to access the device list in irq context. Otherwise you really want to use scsi_device_lookup_by_target instead.}(hj["hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhja!ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@)scsi_device_lookup_by_target (C function)c.scsi_device_lookup_by_targethNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(hXstruct scsi_device * scsi_device_lookup_by_target (struct scsi_target *starget, u64 lun)h]jP)}(hVstruct scsi_device *scsi_device_lookup_by_target(struct scsi_target *starget, u64 lun)h](jV)}(hjYh]hstruct}(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"hhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMubjh)}(h h]h }(hj"hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj"hhhj"hMubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj"ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj"modnameN classnameNjj)}j]j)}jscsi_device_lookup_by_targetsbc.scsi_device_lookup_by_targetasbuh1hhj"hhhj"hMubjh)}(h h]h }(hj"hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj"hhhj"hMubj )}(hj h]h*}(hj"hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj"hhhj"hMubjy)}(hscsi_device_lookup_by_targeth]j)}(hj"h]hscsi_device_lookup_by_target}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj"ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj"hhhj"hMubj)}(h&(struct scsi_target *starget, u64 lun)h](j)}(hstruct scsi_target *stargeth](jV)}(hjYh]hstruct}(hj#hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj#ubjh)}(h h]h }(hj#hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj#ubh)}(hhh]j)}(h scsi_targeth]h scsi_target}(hj"#hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj#ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj$#modnameN classnameNjj)}j]j"c.scsi_device_lookup_by_targetasbuh1hhj#ubjh)}(h h]h }(hj@#hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj#ubj )}(hj h]h*}(hjN#hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj#ubj)}(hstargeth]hstarget}(hj[#hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj#ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"ubj)}(hu64 lunh](h)}(hhh]j)}(hu64h]hu64}(hjw#hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjt#ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjy#modnameN classnameNjj)}j]j"c.scsi_device_lookup_by_targetasbuh1hhjp#ubjh)}(h h]h }(hj#hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjp#ubj)}(hlunh]hlun}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjp#ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"ubeh}(h]h ]h"]h$]h&]jjuh1jhj"hhhj"hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj"hhhj"hMubah}(h]j}"ah ](jjeh"]h$]h&]jj)jhuh1jIhj"hMhj"hhubj)}(hhh]h)}(hfind a device given the targeth]hfind a device given the target}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj#hhubah}(h]h ]h"]h$]h&]uh1jhj"hhhj"hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj#jj#jjjuh1jDhhhj hNhNubj)}(hXK**Parameters** ``struct scsi_target *starget`` SCSI target pointer ``u64 lun`` SCSI Logical Unit Number **Description** Looks up the scsi_device with the specified **lun** for a given **starget**. The returned scsi_device has an additional reference that needs to be released with scsi_device_put once you're done with it.h](h)}(h**Parameters**h]j)}(hj#h]h Parameters}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj#ubj#)}(hhh](j()}(h4``struct scsi_target *starget`` SCSI target pointer h](j.)}(h``struct scsi_target *starget``h]j4)}(hj$h]hstruct scsi_target *starget}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj $ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj$ubjJ)}(hhh]h)}(hSCSI target pointerh]hSCSI target pointer}(hj'$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#$hMhj$$ubah}(h]h ]h"]h$]h&]uh1jIhj$ubeh}(h]h ]h"]h$]h&]uh1j'hj#$hMhj$ubj()}(h%``u64 lun`` SCSI Logical Unit Number h](j.)}(h ``u64 lun``h]j4)}(hjG$h]hu64 lun}(hjI$hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjE$ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjA$ubjJ)}(hhh]h)}(hSCSI Logical Unit Numberh]hSCSI Logical Unit Number}(hj`$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\$hMhj]$ubah}(h]h ]h"]h$]h&]uh1jIhjA$ubeh}(h]h ]h"]h$]h&]uh1j'hj\$hMhj$ubeh}(h]h ]h"]h$]h&]uh1j"hj#ubh)}(h**Description**h]j)}(hj$h]h Description}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj#ubh)}(hLooks up the scsi_device with the specified **lun** for a given **starget**. The returned scsi_device has an additional reference that needs to be released with scsi_device_put once you're done with it.h](h,Looks up the scsi_device with the specified }(hj$hhhNhNubj)}(h**lun**h]hlun}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubh for a given }(hj$hhhNhNubj)}(h **starget**h]hstarget}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubh. The returned scsi_device has an additional reference that needs to be released with scsi_device_put once you’re done with it.}(hj$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!__scsi_device_lookup (C function)c.__scsi_device_lookuphNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(hcstruct scsi_device * __scsi_device_lookup (struct Scsi_Host *shost, uint channel, uint id, u64 lun)h]jP)}(hastruct scsi_device *__scsi_device_lookup(struct Scsi_Host *shost, uint channel, uint id, u64 lun)h](jV)}(hjYh]hstruct}(hj$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$hhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMubjh)}(h h]h }(hj$hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj$hhhj$hMubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj %hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj%ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj %modnameN classnameNjj)}j]j)}j__scsi_device_lookupsbc.__scsi_device_lookupasbuh1hhj$hhhj$hMubjh)}(h h]h }(hj+%hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj$hhhj$hMubj )}(hj h]h*}(hj9%hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj$hhhj$hMubjy)}(h__scsi_device_lookuph]j)}(hj(%h]h__scsi_device_lookup}(hjJ%hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjF%ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj$hhhj$hMubj)}(h9(struct Scsi_Host *shost, uint channel, uint id, u64 lun)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hje%hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhja%ubjh)}(h h]h }(hjr%hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghja%ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj%ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj%modnameN classnameNjj)}j]j&%c.__scsi_device_lookupasbuh1hhja%ubjh)}(h h]h }(hj%hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghja%ubj )}(hj h]h*}(hj%hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hja%ubj)}(hshosth]hshost}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hja%ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]%ubj)}(h uint channelh](h)}(hhh]j)}(huinth]huint}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj%ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj%modnameN classnameNjj)}j]j&%c.__scsi_device_lookupasbuh1hhj%ubjh)}(h h]h }(hj%hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj%ubj)}(hchannelh]hchannel}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj%ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]%ubj)}(huint idh](h)}(hhh]j)}(huinth]huint}(hj &hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj"&modnameN classnameNjj)}j]j&%c.__scsi_device_lookupasbuh1hhj&ubjh)}(h h]h }(hj>&hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj&ubj)}(hidh]hid}(hjL&hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]%ubj)}(hu64 lunh](h)}(hhh]j)}(hu64h]hu64}(hjh&hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hje&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjj&modnameN classnameNjj)}j]j&%c.__scsi_device_lookupasbuh1hhja&ubjh)}(h h]h }(hj&hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghja&ubj)}(hlunh]hlun}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hja&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]%ubeh}(h]h ]h"]h$]h&]jjuh1jhj$hhhj$hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj$hhhj$hMubah}(h]j$ah ](jjeh"]h$]h&]jj)jhuh1jIhj$hMhj$hhubj)}(hhh]h)}(h'find a device given the host (UNLOCKED)h]h'find a device given the host (UNLOCKED)}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj&hhubah}(h]h ]h"]h$]h&]uh1jhj$hhhj$hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj&jj&jjjuh1jDhhhj hNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` SCSI host pointer ``uint channel`` SCSI channel (zero if only one channel) ``uint id`` SCSI target number (physical unit number) ``u64 lun`` SCSI Logical Unit Number **Description** Looks up the scsi_device with the specified **channel**, **id**, **lun** for a given host. The returned scsi_device does not have an additional reference. You must hold the host's host_lock over this call and any access to the returned scsi_device. **Note** The only reason why drivers would want to use this is because they need to access the device list in irq context. Otherwise you really want to use scsi_device_lookup instead.h](h)}(h**Parameters**h]j)}(hj&h]h Parameters}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj&ubj#)}(hhh](j()}(h.``struct Scsi_Host *shost`` SCSI host pointer h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj&h]hstruct Scsi_Host *shost}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj&ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj&ubjJ)}(hhh]h)}(hSCSI host pointerh]hSCSI host pointer}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hMhj'ubah}(h]h ]h"]h$]h&]uh1jIhj&ubeh}(h]h ]h"]h$]h&]uh1j'hj'hMhj&ubj()}(h9``uint channel`` SCSI channel (zero if only one channel) h](j.)}(h``uint channel``h]j4)}(hj8'h]h uint channel}(hj:'hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj6'ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj2'ubjJ)}(hhh]h)}(h'SCSI channel (zero if only one channel)h]h'SCSI channel (zero if only one channel)}(hjQ'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjM'hMhjN'ubah}(h]h ]h"]h$]h&]uh1jIhj2'ubeh}(h]h ]h"]h$]h&]uh1j'hjM'hMhj&ubj()}(h6``uint id`` SCSI target number (physical unit number) h](j.)}(h ``uint id``h]j4)}(hjq'h]huint id}(hjs'hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjo'ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjk'ubjJ)}(hhh]h)}(h)SCSI target number (physical unit number)h]h)SCSI target number (physical unit number)}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hMhj'ubah}(h]h ]h"]h$]h&]uh1jIhjk'ubeh}(h]h ]h"]h$]h&]uh1j'hj'hMhj&ubj()}(h%``u64 lun`` SCSI Logical Unit Number h](j.)}(h ``u64 lun``h]j4)}(hj'h]hu64 lun}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj'ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj'ubjJ)}(hhh]h)}(hSCSI Logical Unit Numberh]hSCSI Logical Unit Number}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hMhj'ubah}(h]h ]h"]h$]h&]uh1jIhj'ubeh}(h]h ]h"]h$]h&]uh1j'hj'hMhj&ubeh}(h]h ]h"]h$]h&]uh1j"hj&ubh)}(h**Description**h]j)}(hj'h]h Description}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj&ubh)}(hLooks up the scsi_device with the specified **channel**, **id**, **lun** for a given host. The returned scsi_device does not have an additional reference. You must hold the host's host_lock over this call and any access to the returned scsi_device.h](h,Looks up the scsi_device with the specified }(hj'hhhNhNubj)}(h **channel**h]hchannel}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubh, }(hj'hhhNhNubj)}(h**id**h]hid}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubh, }hj'sbj)}(h**lun**h]hlun}(hj'(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubh for a given host. The returned scsi_device does not have an additional reference. You must hold the host’s host_lock over this call and any access to the returned scsi_device.}(hj'hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj&ubh)}(h**Note**h]j)}(hjB(h]hNote}(hjD(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@(ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj&ubh)}(hThe only reason why drivers would want to use this is because they need to access the device list in irq context. Otherwise you really want to use scsi_device_lookup instead.h]hThe only reason why drivers would want to use this is because they need to access the device list in irq context. Otherwise you really want to use scsi_device_lookup instead.}(hjX(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj&ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_device_lookup (C function)c.scsi_device_lookuphNtauh1j3hj hhhNhNubjE)}(hhh](jJ)}(hastruct scsi_device * scsi_device_lookup (struct Scsi_Host *shost, uint channel, uint id, u64 lun)h]jP)}(h_struct scsi_device *scsi_device_lookup(struct Scsi_Host *shost, uint channel, uint id, u64 lun)h](jV)}(hjYh]hstruct}(hj(hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(hhhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMubjh)}(h h]h }(hj(hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj(hhhj(hMubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj(modnameN classnameNjj)}j]j)}jscsi_device_lookupsbc.scsi_device_lookupasbuh1hhj(hhhj(hMubjh)}(h h]h }(hj(hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj(hhhj(hMubj )}(hj h]h*}(hj(hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj(hhhj(hMubjy)}(hscsi_device_lookuph]j)}(hj(h]hscsi_device_lookup}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj(hhhj(hMubj)}(h9(struct Scsi_Host *shost, uint channel, uint id, u64 lun)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(ubjh)}(h h]h }(hj)hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj(ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj!)modnameN classnameNjj)}j]j(c.scsi_device_lookupasbuh1hhj(ubjh)}(h h]h }(hj=)hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj(ubj )}(hj h]h*}(hjK)hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj(ubj)}(hshosth]hshost}(hjX)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(h uint channelh](h)}(hhh]j)}(huinth]huint}(hjt)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjq)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjv)modnameN classnameNjj)}j]j(c.scsi_device_lookupasbuh1hhjm)ubjh)}(h h]h }(hj)hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjm)ubj)}(hchannelh]hchannel}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjm)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(huint idh](h)}(hhh]j)}(huinth]huint}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj)modnameN classnameNjj)}j]j(c.scsi_device_lookupasbuh1hhj)ubjh)}(h h]h }(hj)hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj)ubj)}(hidh]hid}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(hu64 lunh](h)}(hhh]j)}(hu64h]hu64}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj*ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*modnameN classnameNjj)}j]j(c.scsi_device_lookupasbuh1hhj)ubjh)}(h h]h }(hj"*hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj)ubj)}(hlunh]hlun}(hj0*hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubeh}(h]h ]h"]h$]h&]jjuh1jhj(hhhj(hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj(hhhj(hMubah}(h]jz(ah ](jjeh"]h$]h&]jj)jhuh1jIhj(hMhj|(hhubj)}(hhh]h)}(hfind a device given the hosth]hfind a device given the host}(hjZ*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjW*hhubah}(h]h ]h"]h$]h&]uh1jhj|(hhhj(hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjr*jjr*jjjuh1jDhhhj hNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` SCSI host pointer ``uint channel`` SCSI channel (zero if only one channel) ``uint id`` SCSI target number (physical unit number) ``u64 lun`` SCSI Logical Unit Number **Description** Looks up the scsi_device with the specified **channel**, **id**, **lun** for a given host. The returned scsi_device has an additional reference that needs to be released with scsi_device_put once you're done with it.h](h)}(h**Parameters**h]j)}(hj|*h]h Parameters}(hj~*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjz*ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjv*ubj#)}(hhh](j()}(h.``struct Scsi_Host *shost`` SCSI host pointer h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj*h]hstruct Scsi_Host *shost}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj*ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj*ubjJ)}(hhh]h)}(hSCSI host pointerh]hSCSI host pointer}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hMhj*ubah}(h]h ]h"]h$]h&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j'hj*hMhj*ubj()}(h9``uint channel`` SCSI channel (zero if only one channel) h](j.)}(h``uint channel``h]j4)}(hj*h]h uint channel}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj*ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj*ubjJ)}(hhh]h)}(h'SCSI channel (zero if only one channel)h]h'SCSI channel (zero if only one channel)}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hMhj*ubah}(h]h ]h"]h$]h&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j'hj*hMhj*ubj()}(h6``uint id`` SCSI target number (physical unit number) h](j.)}(h ``uint id``h]j4)}(hj +h]huint id}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj +ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj+ubjJ)}(hhh]h)}(h)SCSI target number (physical unit number)h]h)SCSI target number (physical unit number)}(hj&+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"+hMhj#+ubah}(h]h ]h"]h$]h&]uh1jIhj+ubeh}(h]h ]h"]h$]h&]uh1j'hj"+hMhj*ubj()}(h%``u64 lun`` SCSI Logical Unit Number h](j.)}(h ``u64 lun``h]j4)}(hjF+h]hu64 lun}(hjH+hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjD+ubah}(h]h ]h"]h$]h&]uh1j-hT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhj@+ubjJ)}(hhh]h)}(hSCSI Logical Unit Numberh]hSCSI Logical Unit Number}(hj_+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[+hMhj\+ubah}(h]h ]h"]h$]h&]uh1jIhj@+ubeh}(h]h ]h"]h$]h&]uh1j'hj[+hMhj*ubeh}(h]h ]h"]h$]h&]uh1j"hjv*ubh)}(h**Description**h]j)}(hj+h]h Description}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjv*ubh)}(hLooks up the scsi_device with the specified **channel**, **id**, **lun** for a given host. The returned scsi_device has an additional reference that needs to be released with scsi_device_put once you're done with it.h](h,Looks up the scsi_device with the specified }(hj+hhhNhNubj)}(h **channel**h]hchannel}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubh, }(hj+hhhNhNubj)}(h**id**h]hid}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubh, }hj+sbj)}(h**lun**h]hlun}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubh for a given host. The returned scsi_device has an additional reference that needs to be released with scsi_device_put once you’re done with it.}(hj+hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:101: ./drivers/scsi/scsi.chMhjv*ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubeh}(h]drivers-scsi-scsi-cah ]h"]drivers/scsi/scsi.cah$]h&]uh1hhjhhhhhKaubh)}(hhh](h)}(hdrivers/scsi/scsicam.ch]hdrivers/scsi/scsicam.c}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+hhhhhKiubh)}(h`SCSI Common Access Method `__ support functions, for use with HDIO_GETGEO, etc.h](jn)}(hR`SCSI Common Access Method `__h]hSCSI Common Access Method}(hj,hhhNhNubah}(h]h ]h"]h$]h&]nameSCSI Common Access Methodj2http://www.t10.org/ftp/t10/drafts/cam/cam-r12b.pdfuh1jmhj+ubh2 support functions, for use with HDIO_GETGEO, etc.}(hj+hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKkhj+hhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_bios_ptable (C function)c.scsi_bios_ptablehNtauh1j3hj+hhhNhNubjE)}(hhh](jJ)}(h;unsigned char * scsi_bios_ptable (struct block_device *dev)h]jP)}(h9unsigned char *scsi_bios_ptable(struct block_device *dev)h](j~)}(hunsignedh]hunsigned}(hj4,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj0,hhhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKubjh)}(h h]h }(hjC,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj0,hhhjB,hKubj~)}(hcharh]hchar}(hjQ,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj0,hhhjB,hKubjh)}(h h]h }(hj_,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj0,hhhjB,hKubj )}(hj h]h*}(hjm,hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj0,hhhjB,hKubjy)}(hscsi_bios_ptableh]j)}(hscsi_bios_ptableh]hscsi_bios_ptable}(hj~,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjz,ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj0,hhhjB,hKubj)}(h(struct block_device *dev)h]j)}(hstruct block_device *devh](jV)}(hjYh]hstruct}(hj,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj,ubjh)}(h h]h }(hj,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj,ubh)}(hhh]j)}(h block_deviceh]h block_device}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj,ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj,modnameN classnameNjj)}j]j)}jj,sbc.scsi_bios_ptableasbuh1hhj,ubjh)}(h h]h }(hj,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj,ubj )}(hj h]h*}(hj,hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj,ubj)}(hdevh]hdev}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,ubah}(h]h ]h"]h$]h&]jjuh1jhj0,hhhjB,hKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj,,hhhjB,hKubah}(h]j',ah ](jjeh"]h$]h&]jj)jhuh1jIhjB,hKhj),hhubj)}(hhh]h)}(h6Read PC partition table out of first sector of device.h]h6Read PC partition table out of first sector of device.}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj-hhubah}(h]h ]h"]h$]h&]uh1jhj),hhhjB,hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj5-jj5-jjjuh1jDhhhj+hNhNubj)}(hX **Parameters** ``struct block_device *dev`` from this device **Description** Reads the first sector from the device and returns ``0x42`` bytes starting at offset ``0x1be``. **Return** partition table in kmalloc(GFP_KERNEL) memory, or NULL on error.h](h)}(h**Parameters**h]j)}(hj?-h]h Parameters}(hjA-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=-ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj9-ubj#)}(hhh]j()}(h.``struct block_device *dev`` from this device h](j.)}(h``struct block_device *dev``h]j4)}(hj^-h]hstruct block_device *dev}(hj`-hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj\-ubah}(h]h ]h"]h$]h&]uh1j-hW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhjX-ubjJ)}(hhh]h)}(hfrom this deviceh]hfrom this device}(hjw-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjs-hKhjt-ubah}(h]h ]h"]h$]h&]uh1jIhjX-ubeh}(h]h ]h"]h$]h&]uh1j'hjs-hKhjU-ubah}(h]h ]h"]h$]h&]uh1j"hj9-ubh)}(h**Description**h]j)}(hj-h]h Description}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj9-ubj#)}(hhh]j()}(h`Reads the first sector from the device and returns ``0x42`` bytes starting at offset ``0x1be``. h](j.)}(hAReads the first sector from the device and returns ``0x42`` bytesh](h3Reads the first sector from the device and returns }(hj-hhhNhNubj4)}(h``0x42``h]h0x42}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj-ubh bytes}(hj-hhhNhNubeh}(h]h ]h"]h$]h&]uh1j-hW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj-ubjJ)}(hhh]h)}(hstarting at offset ``0x1be``.h](hstarting at offset }(hj-hhhNhNubj4)}(h ``0x1be``h]h0x1be}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj-ubh.}(hj-hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj-hKhj-ubah}(h]h ]h"]h$]h&]uh1jIhj-ubeh}(h]h ]h"]h$]h&]uh1j'hj-hKhj-ubah}(h]h ]h"]h$]h&]uh1j"hj9-ubh)}(h **Return**h]j)}(hj.h]hReturn}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj .ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK hj9-ubh)}(h@partition table in kmalloc(GFP_KERNEL) memory, or NULL on error.h]h@partition table in kmalloc(GFP_KERNEL) memory, or NULL on error.}(hj$.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj9-ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj+hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_partsize (C function)c.scsi_partsizehNtauh1j3hj+hhhNhNubjE)}(hhh](jJ)}(hNbool scsi_partsize (struct block_device *bdev, sector_t capacity, int geom[3])h]jP)}(hMbool scsi_partsize(struct block_device *bdev, sector_t capacity, int geom[3])h](j~)}(hboolh]hbool}(hjS.hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjO.hhhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK2ubjh)}(h h]h }(hjb.hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjO.hhhja.hK2ubjy)}(h scsi_partsizeh]j)}(h scsi_partsizeh]h scsi_partsize}(hjt.hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjp.ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjO.hhhja.hK2ubj)}(h;(struct block_device *bdev, sector_t capacity, int geom[3])h](j)}(hstruct block_device *bdevh](jV)}(hjYh]hstruct}(hj.hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.ubjh)}(h h]h }(hj.hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj.ubh)}(hhh]j)}(h block_deviceh]h block_device}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj.ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj.modnameN classnameNjj)}j]j)}jjv.sbc.scsi_partsizeasbuh1hhj.ubjh)}(h h]h }(hj.hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj.ubj )}(hj h]h*}(hj.hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj.ubj)}(hbdevh]hbdev}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj.ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubj)}(hsector_t capacityh](h)}(hhh]j)}(hsector_th]hsector_t}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj/ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj/modnameN classnameNjj)}j]j.c.scsi_partsizeasbuh1hhj.ubjh)}(h h]h }(hj#/hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj.ubj)}(hcapacityh]hcapacity}(hj1/hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj.ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubj)}(h int geom[3]h](j~)}(hinth]hint}(hjJ/hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjF/ubjh)}(h h]h }(hjX/hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjF/ubj)}(hgeomh]hgeom}(hjf/hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjF/ubj )}(h[h]h[}(hjt/hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjF/ubhdesc_sig_literal_number)}(h3h]h3}(hj/hhhNhNubah}(h]h ]mah"]h$]h&]uh1j/hjF/ubj )}(h]h]h]}(hj/hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjF/ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubeh}(h]h ]h"]h$]h&]jjuh1jhjO.hhhja.hK2ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjK.hhhja.hK2ubah}(h]jF.ah ](jjeh"]h$]h&]jj)jhuh1jIhja.hK2hjH.hhubj)}(hhh]h)}(h5Parse cylinders/heads/sectors from PC partition tableh]h5Parse cylinders/heads/sectors from PC partition table}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK2hj/hhubah}(h]h ]h"]h$]h&]uh1jhjH.hhhja.hK2ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj/jj/jjjuh1jDhhhj+hNhNubj)}(hXl**Parameters** ``struct block_device *bdev`` block device to parse ``sector_t capacity`` size of the disk in sectors ``int geom[3]`` output in form of [hds, cylinders, sectors] **Description** Determine the BIOS mapping/geometry used to create the partition table, storing the results in **geom**. **Return** ``false`` on failure, ``true`` on success.h](h)}(h**Parameters**h]j)}(hj/h]h Parameters}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK6hj/ubj#)}(hhh](j()}(h4``struct block_device *bdev`` block device to parse h](j.)}(h``struct block_device *bdev``h]j4)}(hj/h]hstruct block_device *bdev}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj/ubah}(h]h ]h"]h$]h&]uh1j-hW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK3hj/ubjJ)}(hhh]h)}(hblock device to parseh]hblock device to parse}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hK3hj0ubah}(h]h ]h"]h$]h&]uh1jIhj/ubeh}(h]h ]h"]h$]h&]uh1j'hj0hK3hj/ubj()}(h2``sector_t capacity`` size of the disk in sectors h](j.)}(h``sector_t capacity``h]j4)}(hj70h]hsector_t capacity}(hj90hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj50ubah}(h]h ]h"]h$]h&]uh1j-hW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK4hj10ubjJ)}(hhh]h)}(hsize of the disk in sectorsh]hsize of the disk in sectors}(hjP0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjL0hK4hjM0ubah}(h]h ]h"]h$]h&]uh1jIhj10ubeh}(h]h ]h"]h$]h&]uh1j'hjL0hK4hj/ubj()}(h<``int geom[3]`` output in form of [hds, cylinders, sectors] h](j.)}(h``int geom[3]``h]j4)}(hjp0h]h int geom[3]}(hjr0hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjn0ubah}(h]h ]h"]h$]h&]uh1j-hW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK5hjj0ubjJ)}(hhh]h)}(h+output in form of [hds, cylinders, sectors]h]h+output in form of [hds, cylinders, sectors]}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hK5hj0ubah}(h]h ]h"]h$]h&]uh1jIhjj0ubeh}(h]h ]h"]h$]h&]uh1j'hj0hK5hj/ubeh}(h]h ]h"]h$]h&]uh1j"hj/ubh)}(h**Description**h]j)}(hj0h]h Description}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK7hj/ubh)}(hhDetermine the BIOS mapping/geometry used to create the partition table, storing the results in **geom**.h](h_Determine the BIOS mapping/geometry used to create the partition table, storing the results in }(hj0hhhNhNubj)}(h**geom**h]hgeom}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubh.}(hj0hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK7hj/ubh)}(h **Return**h]j)}(hj0h]hReturn}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK:hj/ubh)}(h*``false`` on failure, ``true`` on success.h](j4)}(h ``false``h]hfalse}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj0ubh on failure, }(hj0hhhNhNubj4)}(h``true``h]htrue}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj0ubh on success.}(hj0hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chK:hj/ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj+hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsicam_bios_param (C function)c.scsicam_bios_paramhNtauh1j3hj+hhhNhNubjE)}(hhh](jJ)}(hNint scsicam_bios_param (struct block_device *bdev, sector_t capacity, int *ip)h]jP)}(hMint scsicam_bios_param(struct block_device *bdev, sector_t capacity, int *ip)h](j~)}(hinth]hint}(hjI1hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjE1hhhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKubjh)}(h h]h }(hjX1hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjE1hhhjW1hKubjy)}(hscsicam_bios_paramh]j)}(hscsicam_bios_paramh]hscsicam_bios_param}(hjj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjf1ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjE1hhhjW1hKubj)}(h7(struct block_device *bdev, sector_t capacity, int *ip)h](j)}(hstruct block_device *bdevh](jV)}(hjYh]hstruct}(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubjh)}(h h]h }(hj1hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj1ubh)}(hhh]j)}(h block_deviceh]h block_device}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj1ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj1modnameN classnameNjj)}j]j)}jjl1sbc.scsicam_bios_paramasbuh1hhj1ubjh)}(h h]h }(hj1hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj1ubj )}(hj h]h*}(hj1hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj1ubj)}(hbdevh]hbdev}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj1ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~1ubj)}(hsector_t capacityh](h)}(hhh]j)}(hsector_th]hsector_t}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj1ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj1modnameN classnameNjj)}j]j1c.scsicam_bios_paramasbuh1hhj1ubjh)}(h h]h }(hj2hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj1ubj)}(hcapacityh]hcapacity}(hj'2hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj1ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~1ubj)}(hint *iph](j~)}(hinth]hint}(hj@2hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj<2ubjh)}(h h]h }(hjN2hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj<2ubj )}(hj h]h*}(hj\2hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj<2ubj)}(hiph]hip}(hji2hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj<2ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~1ubeh}(h]h ]h"]h$]h&]jjuh1jhjE1hhhjW1hKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjA1hhhjW1hKubah}(h]j<1ah ](jjeh"]h$]h&]jj)jhuh1jIhjW1hKhj>1hhubj)}(hhh]h)}(h8Determine geometry of a disk in cylinders/heads/sectors.h]h8Determine geometry of a disk in cylinders/heads/sectors.}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj2hhubah}(h]h ]h"]h$]h&]uh1jhj>1hhhjW1hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj2jj2jjjuh1jDhhhj+hNhNubj)}(hX**Parameters** ``struct block_device *bdev`` which device ``sector_t capacity`` size of the disk in sectors ``int *ip`` return value: ip[0]=heads, ip[1]=sectors, ip[2]=cylinders **Description** determine the BIOS mapping/geometry used for a drive in a SCSI-CAM system, storing the results in ip as required by the HDIO_GETGEO ioctl(). **Return** -1 on failure, 0 on success.h](h)}(h**Parameters**h]j)}(hj2h]h Parameters}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj2ubj#)}(hhh](j()}(h+``struct block_device *bdev`` which device h](j.)}(h``struct block_device *bdev``h]j4)}(hj2h]hstruct block_device *bdev}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj2ubah}(h]h ]h"]h$]h&]uh1j-hW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj2ubjJ)}(hhh]h)}(h which deviceh]h which device}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hKhj2ubah}(h]h ]h"]h$]h&]uh1jIhj2ubeh}(h]h ]h"]h$]h&]uh1j'hj2hKhj2ubj()}(h2``sector_t capacity`` size of the disk in sectors h](j.)}(h``sector_t capacity``h]j4)}(hj 3h]hsector_t capacity}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj 3ubah}(h]h ]h"]h$]h&]uh1j-hW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj3ubjJ)}(hhh]h)}(hsize of the disk in sectorsh]hsize of the disk in sectors}(hj&3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"3hKhj#3ubah}(h]h ]h"]h$]h&]uh1jIhj3ubeh}(h]h ]h"]h$]h&]uh1j'hj"3hKhj2ubj()}(hF``int *ip`` return value: ip[0]=heads, ip[1]=sectors, ip[2]=cylinders h](j.)}(h ``int *ip``h]j4)}(hjF3h]hint *ip}(hjH3hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjD3ubah}(h]h ]h"]h$]h&]uh1j-hW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj@3ubjJ)}(hhh]h)}(h9return value: ip[0]=heads, ip[1]=sectors, ip[2]=cylindersh]h9return value: ip[0]=heads, ip[1]=sectors, ip[2]=cylinders}(hj_3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[3hKhj\3ubah}(h]h ]h"]h$]h&]uh1jIhj@3ubeh}(h]h ]h"]h$]h&]uh1j'hj[3hKhj2ubeh}(h]h ]h"]h$]h&]uh1j"hj2ubh)}(h**Description**h]j)}(hj3h]h Description}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj2ubj#)}(hhh]j()}(hdetermine the BIOS mapping/geometry used for a drive in a SCSI-CAM system, storing the results in ip as required by the HDIO_GETGEO ioctl(). h](j.)}(h9determine the BIOS mapping/geometry used for a drive in ah]h9determine the BIOS mapping/geometry used for a drive in a}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1j-hW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj3ubjJ)}(hhh]h)}(hRSCSI-CAM system, storing the results in ip as required by the HDIO_GETGEO ioctl().h]hRSCSI-CAM system, storing the results in ip as required by the HDIO_GETGEO ioctl().}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj3ubah}(h]h ]h"]h$]h&]uh1jIhj3ubeh}(h]h ]h"]h$]h&]uh1j'hj3hKhj3ubah}(h]h ]h"]h$]h&]uh1j"hj2ubh)}(h **Return**h]j)}(hj3h]hReturn}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj2ubh)}(h-1 on failure, 0 on success.h]h-1 on failure, 0 on success.}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:111: ./drivers/scsi/scsicam.chKhj2ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj+hhhNhNubeh}(h]drivers-scsi-scsicam-cah ]h"]drivers/scsi/scsicam.cah$]h&]uh1hhjhhhhhKiubh)}(hhh](h)}(hdrivers/scsi/scsi_error.ch]hdrivers/scsi/scsi_error.c}(hj 4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hhhhhKsubh)}(h,Common SCSI error/timeout handling routines.h]h,Common SCSI error/timeout handling routines.}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKuhj4hhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_schedule_eh (C function)c.scsi_schedule_ehhNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(h/void scsi_schedule_eh (struct Scsi_Host *shost)h]jP)}(h.void scsi_schedule_eh(struct Scsi_Host *shost)h](j~)}(hvoidh]hvoid}(hj?4hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj;4hhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chKMubjh)}(h h]h }(hjN4hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj;4hhhjM4hKMubjy)}(hscsi_schedule_ehh]j)}(hscsi_schedule_ehh]hscsi_schedule_eh}(hj`4hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj\4ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj;4hhhjM4hKMubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj|4hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjx4ubjh)}(h h]h }(hj4hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjx4ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj4ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj4modnameN classnameNjj)}j]j)}jjb4sbc.scsi_schedule_ehasbuh1hhjx4ubjh)}(h h]h }(hj4hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjx4ubj )}(hj h]h*}(hj4hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjx4ubj)}(hshosth]hshost}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjx4ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjt4ubah}(h]h ]h"]h$]h&]jjuh1jhj;4hhhjM4hKMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj74hhhjM4hKMubah}(h]j24ah ](jjeh"]h$]h&]jj)jhuh1jIhjM4hKMhj44hhubj)}(hhh]h)}(hschedule EH for SCSI hosth]hschedule EH for SCSI host}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chKMhj4hhubah}(h]h ]h"]h$]h&]uh1jhj44hhhjM4hKMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj5jj5jjjuh1jDhhhj4hNhNubj)}(h**Parameters** ``struct Scsi_Host *shost`` SCSI host to invoke error handling on. **Description** Schedule SCSI EH without scmd.h](h)}(h**Parameters**h]j)}(hj!5h]h Parameters}(hj#5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chKQhj5ubj#)}(hhh]j()}(hC``struct Scsi_Host *shost`` SCSI host to invoke error handling on. h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj@5h]hstruct Scsi_Host *shost}(hjB5hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj>5ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chKNhj:5ubjJ)}(hhh]h)}(h&SCSI host to invoke error handling on.h]h&SCSI host to invoke error handling on.}(hjY5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjU5hKNhjV5ubah}(h]h ]h"]h$]h&]uh1jIhj:5ubeh}(h]h ]h"]h$]h&]uh1j'hjU5hKNhj75ubah}(h]h ]h"]h$]h&]uh1j"hj5ubh)}(h**Description**h]j)}(hj{5h]h Description}(hj}5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjy5ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chKPhj5ubh)}(hSchedule SCSI EH without scmd.h]hSchedule SCSI EH without scmd.}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chKPhj5ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj4hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@.scsi_block_when_processing_errors (C function)#c.scsi_block_when_processing_errorshNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(h@int scsi_block_when_processing_errors (struct scsi_device *sdev)h]jP)}(h?int scsi_block_when_processing_errors(struct scsi_device *sdev)h](j~)}(hinth]hint}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj5hhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMvubjh)}(h h]h }(hj5hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj5hhhj5hMvubjy)}(h!scsi_block_when_processing_errorsh]j)}(h!scsi_block_when_processing_errorsh]h!scsi_block_when_processing_errors}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj5ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj5hhhj5hMvubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hj5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5ubjh)}(h h]h }(hj 6hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj5ubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj6ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj6modnameN classnameNjj)}j]j)}jj5sb#c.scsi_block_when_processing_errorsasbuh1hhj5ubjh)}(h h]h }(hj;6hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj5ubj )}(hj h]h*}(hjI6hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj5ubj)}(hsdevh]hsdev}(hjV6hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj5ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubah}(h]h ]h"]h$]h&]jjuh1jhj5hhhj5hMvubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj5hhhj5hMvubah}(h]j5ah ](jjeh"]h$]h&]jj)jhuh1jIhj5hMvhj5hhubj)}(hhh]h)}(hPrevent cmds from being queued.h]hPrevent cmds from being queued.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMvhj}6hhubah}(h]h ]h"]h$]h&]uh1jhj5hhhj5hMvubeh}(h]h ](jfunctioneh"]h$]h&]jjjj6jj6jjjuh1jDhhhj4hNhNubj)}(hX;**Parameters** ``struct scsi_device *sdev`` Device on which we are performing recovery. **Description** We block until the host is out of error recovery, and then check to see whether the host or the device is offline. Return value: 0 when dev was taken offline by error recovery. 1 OK to proceed.h](h)}(h**Parameters**h]j)}(hj6h]h Parameters}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMzhj6ubj#)}(hhh]j()}(hI``struct scsi_device *sdev`` Device on which we are performing recovery. h](j.)}(h``struct scsi_device *sdev``h]j4)}(hj6h]hstruct scsi_device *sdev}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj6ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMwhj6ubjJ)}(hhh]h)}(h+Device on which we are performing recovery.h]h+Device on which we are performing recovery.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMwhj6ubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j'hj6hMwhj6ubah}(h]h ]h"]h$]h&]uh1j"hj6ubh)}(h**Description**h]j)}(hj6h]h Description}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMyhj6ubj`)}(hsWe block until the host is out of error recovery, and then check to see whether the host or the device is offline. h]h)}(hrWe block until the host is out of error recovery, and then check to see whether the host or the device is offline.h]hrWe block until the host is out of error recovery, and then check to see whether the host or the device is offline.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMyhj7ubah}(h]h ]h"]h$]h&]uh1j_hj$7hMyhj6ubj#)}(hhh]j()}(hNReturn value: 0 when dev was taken offline by error recovery. 1 OK to proceed.h](j.)}(h Return value:h]h Return value:}(hj27hhhNhNubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM|hj.7ubjJ)}(hhh]h)}(h@0 when dev was taken offline by error recovery. 1 OK to proceed.h]h@0 when dev was taken offline by error recovery. 1 OK to proceed.}(hjD7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM}hjA7ubah}(h]h ]h"]h$]h&]uh1jIhj.7ubeh}(h]h ]h"]h$]h&]uh1j'hj@7hM|hj+7ubah}(h]h ]h"]h$]h&]uh1j"hj6ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj4hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_check_sense (C function)c.scsi_check_sensehNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(h?enum scsi_disposition scsi_check_sense (struct scsi_cmnd *scmd)h]jP)}(h>enum scsi_disposition scsi_check_sense(struct scsi_cmnd *scmd)h](jV)}(henumh]henum}(hj7hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj7hhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMubjh)}(h h]h }(hj7hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj7hhhj7hMubh)}(hhh]j)}(hscsi_dispositionh]hscsi_disposition}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj7ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj7modnameN classnameNjj)}j]j)}jscsi_check_sensesbc.scsi_check_senseasbuh1hhj7hhhj7hMubjh)}(h h]h }(hj7hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj7hhhj7hMubjy)}(hscsi_check_senseh]j)}(hj7h]hscsi_check_sense}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj7ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj7hhhj7hMubj)}(h(struct scsi_cmnd *scmd)h]j)}(hstruct scsi_cmnd *scmdh](jV)}(hjYh]hstruct}(hj7hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj7ubjh)}(h h]h }(hj8hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj7ubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj8ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj8modnameN classnameNjj)}j]j7c.scsi_check_senseasbuh1hhj7ubjh)}(h h]h }(hj/8hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj7ubj )}(hj h]h*}(hj=8hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj7ubj)}(hscmdh]hscmd}(hjJ8hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj7ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj7ubah}(h]h ]h"]h$]h&]jjuh1jhj7hhhj7hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj}7hhhj7hMubah}(h]jx7ah ](jjeh"]h$]h&]jj)jhuh1jIhj7hMhjz7hhubj)}(hhh]h)}(hExamine scsi cmd senseh]hExamine scsi cmd sense}(hjt8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjq8hhubah}(h]h ]h"]h$]h&]uh1jhjz7hhhj7hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj8jj8jjjuh1jDhhhj4hNhNubj)}(hX**Parameters** ``struct scsi_cmnd *scmd`` Cmd to have sense checked. **Description** Return value: SUCCESS or FAILED or NEEDS_RETRY or ADD_TO_MLQUEUE **Notes** When a deferred error is detected the current command has not been executed and needs retrying.h](h)}(h**Parameters**h]j)}(hj8h]h Parameters}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj8ubj#)}(hhh]j()}(h6``struct scsi_cmnd *scmd`` Cmd to have sense checked. h](j.)}(h``struct scsi_cmnd *scmd``h]j4)}(hj8h]hstruct scsi_cmnd *scmd}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj8ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj8ubjJ)}(hhh]h)}(hCmd to have sense checked.h]hCmd to have sense checked.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hMhj8ubah}(h]h ]h"]h$]h&]uh1jIhj8ubeh}(h]h ]h"]h$]h&]uh1j'hj8hMhj8ubah}(h]h ]h"]h$]h&]uh1j"hj8ubh)}(h**Description**h]j)}(hj8h]h Description}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj8ubj#)}(hhh]j()}(hAReturn value: SUCCESS or FAILED or NEEDS_RETRY or ADD_TO_MLQUEUE h](j.)}(h Return value:h]h Return value:}(hj 9hhhNhNubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj 9ubjJ)}(hhh]h)}(h2SUCCESS or FAILED or NEEDS_RETRY or ADD_TO_MLQUEUEh]h2SUCCESS or FAILED or NEEDS_RETRY or ADD_TO_MLQUEUE}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hMhj9ubah}(h]h ]h"]h$]h&]uh1jIhj 9ubeh}(h]h ]h"]h$]h&]uh1j'hj9hMhj9ubah}(h]h ]h"]h$]h&]uh1j"hj8ubh)}(h **Notes**h]j)}(hjA9h]hNotes}(hjC9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?9ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj8ubj`)}(h_When a deferred error is detected the current command has not been executed and needs retrying.h]h)}(h_When a deferred error is detected the current command has not been executed and needs retrying.h]h_When a deferred error is detected the current command has not been executed and needs retrying.}(hj[9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjW9ubah}(h]h ]h"]h$]h&]uh1j_hji9hMhj8ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj4hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_eh_prep_cmnd (C function)c.scsi_eh_prep_cmndhNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(hvoid scsi_eh_prep_cmnd (struct scsi_cmnd *scmd, struct scsi_eh_save *ses, unsigned char *cmnd, int cmnd_size, unsigned sense_bytes)h]jP)}(hvoid scsi_eh_prep_cmnd(struct scsi_cmnd *scmd, struct scsi_eh_save *ses, unsigned char *cmnd, int cmnd_size, unsigned sense_bytes)h](j~)}(hvoidh]hvoid}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj9hhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMubjh)}(h h]h }(hj9hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj9hhhj9hMubjy)}(hscsi_eh_prep_cmndh]j)}(hscsi_eh_prep_cmndh]hscsi_eh_prep_cmnd}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj9ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj9hhhj9hMubj)}(hl(struct scsi_cmnd *scmd, struct scsi_eh_save *ses, unsigned char *cmnd, int cmnd_size, unsigned sense_bytes)h](j)}(hstruct scsi_cmnd *scmdh](jV)}(hjYh]hstruct}(hj9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj9ubjh)}(h h]h }(hj9hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj9ubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj9ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj9modnameN classnameNjj)}j]j)}jj9sbc.scsi_eh_prep_cmndasbuh1hhj9ubjh)}(h h]h }(hj :hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj9ubj )}(hj h]h*}(hj:hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj9ubj)}(hscmdh]hscmd}(hj&:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj9ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubj)}(hstruct scsi_eh_save *sesh](jV)}(hjYh]hstruct}(hj?:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj;:ubjh)}(h h]h }(hjL:hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj;:ubh)}(hhh]j)}(h scsi_eh_saveh]h scsi_eh_save}(hj]:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjZ:ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj_:modnameN classnameNjj)}j]j:c.scsi_eh_prep_cmndasbuh1hhj;:ubjh)}(h h]h }(hj{:hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj;:ubj )}(hj h]h*}(hj:hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj;:ubj)}(hsesh]hses}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj;:ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubj)}(hunsigned char *cmndh](j~)}(hunsignedh]hunsigned}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj:ubjh)}(h h]h }(hj:hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj:ubj~)}(hcharh]hchar}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj:ubjh)}(h h]h }(hj:hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj:ubj )}(hj h]h*}(hj:hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj:ubj)}(hcmndh]hcmnd}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj:ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubj)}(h int cmnd_sizeh](j~)}(hinth]hint}(hj ;hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj ;ubjh)}(h h]h }(hj;hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ;ubj)}(h cmnd_sizeh]h cmnd_size}(hj);hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ;ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubj)}(hunsigned sense_bytesh](j~)}(hunsignedh]hunsigned}(hjB;hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj>;ubjh)}(h h]h }(hjP;hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>;ubj)}(h sense_bytesh]h sense_bytes}(hj^;hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj>;ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubeh}(h]h ]h"]h$]h&]jjuh1jhj9hhhj9hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj9hhhj9hMubah}(h]j9ah ](jjeh"]h$]h&]jj)jhuh1jIhj9hMhj9hhubj)}(hhh]h)}(h2Save a scsi command info as part of error recoveryh]h2Save a scsi command info as part of error recovery}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj;hhubah}(h]h ]h"]h$]h&]uh1jhj9hhhj9hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj;jj;jjjuh1jDhhhj4hNhNubj)}(hX **Parameters** ``struct scsi_cmnd *scmd`` SCSI command structure to hijack ``struct scsi_eh_save *ses`` structure to save restore information ``unsigned char *cmnd`` CDB to send. Can be NULL if no new cmnd is needed ``int cmnd_size`` size in bytes of **cmnd** (must be <= MAX_COMMAND_SIZE) ``unsigned sense_bytes`` size of sense data to copy. or 0 (if != 0 **cmnd** is ignored) **Description** This function is used to save a scsi command information before re-execution as part of the error recovery process. If **sense_bytes** is 0 the command sent must be one that does not transfer any data. If **sense_bytes** != 0 **cmnd** is ignored and this functions sets up a REQUEST_SENSE command and cmnd buffers to read **sense_bytes** into **scmd->sense_buffer**.h](h)}(h**Parameters**h]j)}(hj;h]h Parameters}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj;ubj#)}(hhh](j()}(h<``struct scsi_cmnd *scmd`` SCSI command structure to hijack h](j.)}(h``struct scsi_cmnd *scmd``h]j4)}(hj;h]hstruct scsi_cmnd *scmd}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj;ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj;ubjJ)}(hhh]h)}(h SCSI command structure to hijackh]h SCSI command structure to hijack}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;hMhj;ubah}(h]h ]h"]h$]h&]uh1jIhj;ubeh}(h]h ]h"]h$]h&]uh1j'hj;hMhj;ubj()}(hC``struct scsi_eh_save *ses`` structure to save restore information h](j.)}(h``struct scsi_eh_save *ses``h]j4)}(hj<h]hstruct scsi_eh_save *ses}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj<ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj;ubjJ)}(hhh]h)}(h%structure to save restore informationh]h%structure to save restore information}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hMhj<ubah}(h]h ]h"]h$]h&]uh1jIhj;ubeh}(h]h ]h"]h$]h&]uh1j'hj<hMhj;ubj()}(hJ``unsigned char *cmnd`` CDB to send. Can be NULL if no new cmnd is needed h](j.)}(h``unsigned char *cmnd``h]j4)}(hj;<h]hunsigned char *cmnd}(hj=<hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj9<ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj5<ubjJ)}(hhh]h)}(h1CDB to send. Can be NULL if no new cmnd is neededh]h1CDB to send. Can be NULL if no new cmnd is needed}(hjT<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjP<hMhjQ<ubah}(h]h ]h"]h$]h&]uh1jIhj5<ubeh}(h]h ]h"]h$]h&]uh1j'hjP<hMhj;ubj()}(hJ``int cmnd_size`` size in bytes of **cmnd** (must be <= MAX_COMMAND_SIZE) h](j.)}(h``int cmnd_size``h]j4)}(hjt<h]h int cmnd_size}(hjv<hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjr<ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjn<ubjJ)}(hhh]h)}(h7size in bytes of **cmnd** (must be <= MAX_COMMAND_SIZE)h](hsize in bytes of }(hj<hhhNhNubj)}(h**cmnd**h]hcmnd}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubh (must be <= MAX_COMMAND_SIZE)}(hj<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj<hMhj<ubah}(h]h ]h"]h$]h&]uh1jIhjn<ubeh}(h]h ]h"]h$]h&]uh1j'hj<hMhj;ubj()}(hX``unsigned sense_bytes`` size of sense data to copy. or 0 (if != 0 **cmnd** is ignored) h](j.)}(h``unsigned sense_bytes``h]j4)}(hj<h]hunsigned sense_bytes}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj<ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj<ubjJ)}(hhh]h)}(h>size of sense data to copy. or 0 (if != 0 **cmnd** is ignored)h](h*size of sense data to copy. or 0 (if != 0 }(hj<hhhNhNubj)}(h**cmnd**h]hcmnd}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubh is ignored)}(hj<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj<hMhj<ubah}(h]h ]h"]h$]h&]uh1jIhj<ubeh}(h]h ]h"]h$]h&]uh1j'hj<hMhj;ubeh}(h]h ]h"]h$]h&]uh1j"hj;ubh)}(h**Description**h]j)}(hj =h]h Description}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj =ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj;ubh)}(hXpThis function is used to save a scsi command information before re-execution as part of the error recovery process. If **sense_bytes** is 0 the command sent must be one that does not transfer any data. If **sense_bytes** != 0 **cmnd** is ignored and this functions sets up a REQUEST_SENSE command and cmnd buffers to read **sense_bytes** into **scmd->sense_buffer**.h](hxThis function is used to save a scsi command information before re-execution as part of the error recovery process. If }(hj"=hhhNhNubj)}(h**sense_bytes**h]h sense_bytes}(hj*=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"=ubhH is 0 the command sent must be one that does not transfer any data. If }(hj"=hhhNhNubj)}(h**sense_bytes**h]h sense_bytes}(hj<=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"=ubh != 0 }(hj"=hhhNhNubj)}(h**cmnd**h]hcmnd}(hjN=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"=ubhX is ignored and this functions sets up a REQUEST_SENSE command and cmnd buffers to read }(hj"=hhhNhNubj)}(h**sense_bytes**h]h sense_bytes}(hj`=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"=ubh into }(hj"=hhhNhNubj)}(h**scmd->sense_buffer**h]hscmd->sense_buffer}(hjr=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"=ubh.}(hj"=hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj;ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj4hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!scsi_eh_restore_cmnd (C function)c.scsi_eh_restore_cmndhNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(hLvoid scsi_eh_restore_cmnd (struct scsi_cmnd* scmd, struct scsi_eh_save *ses)h]jP)}(hKvoid scsi_eh_restore_cmnd(struct scsi_cmnd *scmd, struct scsi_eh_save *ses)h](j~)}(hvoidh]hvoid}(hj=hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj=hhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMcubjh)}(h h]h }(hj=hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj=hhhj=hMcubjy)}(hscsi_eh_restore_cmndh]j)}(hscsi_eh_restore_cmndh]hscsi_eh_restore_cmnd}(hj=hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj=ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj=hhhj=hMcubj)}(h2(struct scsi_cmnd *scmd, struct scsi_eh_save *ses)h](j)}(hstruct scsi_cmnd *scmdh](jV)}(hjYh]hstruct}(hj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=ubjh)}(h h]h }(hj=hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj=ubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj>ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj>modnameN classnameNjj)}j]j)}jj=sbc.scsi_eh_restore_cmndasbuh1hhj=ubjh)}(h h]h }(hj&>hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj=ubj )}(hj h]h*}(hj4>hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj=ubj)}(hscmdh]hscmd}(hjA>hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj=ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj=ubj)}(hstruct scsi_eh_save *sesh](jV)}(hjYh]hstruct}(hjZ>hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjV>ubjh)}(h h]h }(hjg>hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjV>ubh)}(hhh]j)}(h scsi_eh_saveh]h scsi_eh_save}(hjx>hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hju>ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjz>modnameN classnameNjj)}j]j">c.scsi_eh_restore_cmndasbuh1hhjV>ubjh)}(h h]h }(hj>hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjV>ubj )}(hj h]h*}(hj>hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjV>ubj)}(hsesh]hses}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjV>ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj=ubeh}(h]h ]h"]h$]h&]jjuh1jhj=hhhj=hMcubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj=hhhj=hMcubah}(h]j=ah ](jjeh"]h$]h&]jj)jhuh1jIhj=hMchj=hhubj)}(hhh]h)}(h5Restore a scsi command info as part of error recoveryh]h5Restore a scsi command info as part of error recovery}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMchj>hhubah}(h]h ]h"]h$]h&]uh1jhj=hhhj=hMcubeh}(h]h ](jfunctioneh"]h$]h&]jjjj>jj>jjjuh1jDhhhj4hNhNubj)}(h**Parameters** ``struct scsi_cmnd* scmd`` SCSI command structure to restore ``struct scsi_eh_save *ses`` saved information from a coresponding call to scsi_eh_prep_cmnd **Description** Undo any damage done by above scsi_eh_prep_cmnd().h](h)}(h**Parameters**h]j)}(hj>h]h Parameters}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMghj>ubj#)}(hhh](j()}(h=``struct scsi_cmnd* scmd`` SCSI command structure to restore h](j.)}(h``struct scsi_cmnd* scmd``h]j4)}(hj?h]hstruct scsi_cmnd* scmd}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj?ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMdhj?ubjJ)}(hhh]h)}(h!SCSI command structure to restoreh]h!SCSI command structure to restore}(hj5?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1?hMdhj2?ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j'hj1?hMdhj?ubj()}(h]``struct scsi_eh_save *ses`` saved information from a coresponding call to scsi_eh_prep_cmnd h](j.)}(h``struct scsi_eh_save *ses``h]j4)}(hjU?h]hstruct scsi_eh_save *ses}(hjW?hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjS?ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMehjO?ubjJ)}(hhh]h)}(h?saved information from a coresponding call to scsi_eh_prep_cmndh]h?saved information from a coresponding call to scsi_eh_prep_cmnd}(hjn?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjj?hMehjk?ubah}(h]h ]h"]h$]h&]uh1jIhjO?ubeh}(h]h ]h"]h$]h&]uh1j'hjj?hMehj?ubeh}(h]h ]h"]h$]h&]uh1j"hj>ubh)}(h**Description**h]j)}(hj?h]h Description}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMghj>ubh)}(h2Undo any damage done by above scsi_eh_prep_cmnd().h]h2Undo any damage done by above scsi_eh_prep_cmnd().}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMghj>ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj4hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_eh_finish_cmd (C function)c.scsi_eh_finish_cmdhNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(hJvoid scsi_eh_finish_cmd (struct scsi_cmnd *scmd, struct list_head *done_q)h]jP)}(hIvoid scsi_eh_finish_cmd(struct scsi_cmnd *scmd, struct list_head *done_q)h](j~)}(hvoidh]hvoid}(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj?hhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMubjh)}(h h]h }(hj?hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj?hhhj?hMubjy)}(hscsi_eh_finish_cmdh]j)}(hscsi_eh_finish_cmdh]hscsi_eh_finish_cmd}(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj?ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj?hhhj?hMubj)}(h2(struct scsi_cmnd *scmd, struct list_head *done_q)h](j)}(hstruct scsi_cmnd *scmdh](jV)}(hjYh]hstruct}(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@ubjh)}(h h]h }(hj@hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj@ubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hj0@hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj-@ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj2@modnameN classnameNjj)}j]j)}jj?sbc.scsi_eh_finish_cmdasbuh1hhj@ubjh)}(h h]h }(hjP@hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj@ubj )}(hj h]h*}(hj^@hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj@ubj)}(hscmdh]hscmd}(hjk@hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj@ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj @ubj)}(hstruct list_head *done_qh](jV)}(hjYh]hstruct}(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@ubjh)}(h h]h }(hj@hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj@ubh)}(hhh]j)}(h list_headh]h list_head}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj@ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj@modnameN classnameNjj)}j]jL@c.scsi_eh_finish_cmdasbuh1hhj@ubjh)}(h h]h }(hj@hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj@ubj )}(hj h]h*}(hj@hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj@ubj)}(hdone_qh]hdone_q}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj@ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj @ubeh}(h]h ]h"]h$]h&]jjuh1jhj?hhhj?hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj?hhhj?hMubah}(h]j?ah ](jjeh"]h$]h&]jj)jhuh1jIhj?hMhj?hhubj)}(hhh]h)}(h&Handle a cmd that eh is finished with.h]h&Handle a cmd that eh is finished with.}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjAhhubah}(h]h ]h"]h$]h&]uh1jhj?hhhj?hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjAjjAjjjuh1jDhhhj4hNhNubj)}(hX**Parameters** ``struct scsi_cmnd *scmd`` Original SCSI cmd that eh has finished. ``struct list_head *done_q`` Queue for processed commands. **Notes** We don't want to use the normal command completion while we are are still handling errors - it may cause other commands to be queued, and that would disturb what we are doing. Thus we really want to keep a list of pending commands for final completion, and once we are ready to leave error handling we handle completion for real.h](h)}(h**Parameters**h]j)}(hj'Ah]h Parameters}(hj)AhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%Aubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM hj!Aubj#)}(hhh](j()}(hC``struct scsi_cmnd *scmd`` Original SCSI cmd that eh has finished. h](j.)}(h``struct scsi_cmnd *scmd``h]j4)}(hjFAh]hstruct scsi_cmnd *scmd}(hjHAhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjDAubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj@AubjJ)}(hhh]h)}(h'Original SCSI cmd that eh has finished.h]h'Original SCSI cmd that eh has finished.}(hj_AhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[AhMhj\Aubah}(h]h ]h"]h$]h&]uh1jIhj@Aubeh}(h]h ]h"]h$]h&]uh1j'hj[AhMhj=Aubj()}(h;``struct list_head *done_q`` Queue for processed commands. h](j.)}(h``struct list_head *done_q``h]j4)}(hjAh]hstruct list_head *done_q}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj}Aubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM hjyAubjJ)}(hhh]h)}(hQueue for processed commands.h]hQueue for processed commands.}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhM hjAubah}(h]h ]h"]h$]h&]uh1jIhjyAubeh}(h]h ]h"]h$]h&]uh1j'hjAhM hj=Aubeh}(h]h ]h"]h$]h&]uh1j"hj!Aubh)}(h **Notes**h]j)}(hjAh]hNotes}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM hj!Aubj`)}(hXJWe don't want to use the normal command completion while we are are still handling errors - it may cause other commands to be queued, and that would disturb what we are doing. Thus we really want to keep a list of pending commands for final completion, and once we are ready to leave error handling we handle completion for real.h]h)}(hXJWe don't want to use the normal command completion while we are are still handling errors - it may cause other commands to be queued, and that would disturb what we are doing. Thus we really want to keep a list of pending commands for final completion, and once we are ready to leave error handling we handle completion for real.h]hXLWe don’t want to use the normal command completion while we are are still handling errors - it may cause other commands to be queued, and that would disturb what we are doing. Thus we really want to keep a list of pending commands for final completion, and once we are ready to leave error handling we handle completion for real.}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM hjAubah}(h]h ]h"]h$]h&]uh1j_hjAhM hj!Aubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj4hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_eh_get_sense (C function)c.scsi_eh_get_sensehNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(hJint scsi_eh_get_sense (struct list_head *work_q, struct list_head *done_q)h]jP)}(hIint scsi_eh_get_sense(struct list_head *work_q, struct list_head *done_q)h](j~)}(hinth]hint}(hj BhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjBhhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMubjh)}(h h]h }(hjBhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjBhhhjBhMubjy)}(hscsi_eh_get_senseh]j)}(hscsi_eh_get_senseh]hscsi_eh_get_sense}(hj*BhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj&Bubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjBhhhjBhMubj)}(h4(struct list_head *work_q, struct list_head *done_q)h](j)}(hstruct list_head *work_qh](jV)}(hjYh]hstruct}(hjFBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBBubjh)}(h h]h }(hjSBhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjBBubh)}(hhh]j)}(h list_headh]h list_head}(hjdBhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjaBubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjfBmodnameN classnameNjj)}j]j)}jj,Bsbc.scsi_eh_get_senseasbuh1hhjBBubjh)}(h h]h }(hjBhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjBBubj )}(hj h]h*}(hjBhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjBBubj)}(hwork_qh]hwork_q}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjBBubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj>Bubj)}(hstruct list_head *done_qh](jV)}(hjYh]hstruct}(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBubjh)}(h h]h }(hjBhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjBubh)}(hhh]j)}(h list_headh]h list_head}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjBubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjBmodnameN classnameNjj)}j]jBc.scsi_eh_get_senseasbuh1hhjBubjh)}(h h]h }(hjBhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjBubj )}(hj h]h*}(hjChhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjBubj)}(hdone_qh]hdone_q}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjBubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj>Bubeh}(h]h ]h"]h$]h&]jjuh1jhjBhhhjBhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjBhhhjBhMubah}(h]jAah ](jjeh"]h$]h&]jj)jhuh1jIhjBhMhjAhhubj)}(hhh]h)}(hGet device sense data.h]hGet device sense data.}(hj9ChhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj6Chhubah}(h]h ]h"]h$]h&]uh1jhjAhhhjBhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjQCjjQCjjjuh1jDhhhj4hNhNubj)}(hX**Parameters** ``struct list_head *work_q`` Queue of commands to process. ``struct list_head *done_q`` Queue of processed commands. **Description** See if we need to request sense information. if so, then get it now, so we have a better idea of what to do. **Notes** This has the unfortunate side effect that if a shost adapter does not automatically request sense information, we end up shutting it down before we request it. All drivers should request sense information internally these days, so for now all I have to say is tough noogies if you end up in here. XXX: Long term this code should go away, but that needs an audit of all LLDDs first.h](h)}(h**Parameters**h]j)}(hj[Ch]h Parameters}(hj]ChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYCubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjUCubj#)}(hhh](j()}(h;``struct list_head *work_q`` Queue of commands to process. h](j.)}(h``struct list_head *work_q``h]j4)}(hjzCh]hstruct list_head *work_q}(hj|ChhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjxCubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjtCubjJ)}(hhh]h)}(hQueue of commands to process.h]hQueue of commands to process.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChMhjCubah}(h]h ]h"]h$]h&]uh1jIhjtCubeh}(h]h ]h"]h$]h&]uh1j'hjChMhjqCubj()}(h:``struct list_head *done_q`` Queue of processed commands. h](j.)}(h``struct list_head *done_q``h]j4)}(hjCh]hstruct list_head *done_q}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjCubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjCubjJ)}(hhh]h)}(hQueue of processed commands.h]hQueue of processed commands.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChMhjCubah}(h]h ]h"]h$]h&]uh1jIhjCubeh}(h]h ]h"]h$]h&]uh1j'hjChMhjqCubeh}(h]h ]h"]h$]h&]uh1j"hjUCubh)}(h**Description**h]j)}(hjCh]h Description}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjUCubj`)}(hnSee if we need to request sense information. if so, then get it now, so we have a better idea of what to do. h]h)}(hmSee if we need to request sense information. if so, then get it now, so we have a better idea of what to do.h]hmSee if we need to request sense information. if so, then get it now, so we have a better idea of what to do.}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjDubah}(h]h ]h"]h$]h&]uh1j_hjDhMhjUCubh)}(h **Notes**h]j)}(hjDh]hNotes}(hj!DhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM hjUCubj`)}(hXThis has the unfortunate side effect that if a shost adapter does not automatically request sense information, we end up shutting it down before we request it. All drivers should request sense information internally these days, so for now all I have to say is tough noogies if you end up in here. XXX: Long term this code should go away, but that needs an audit of all LLDDs first.h](h)}(hThis has the unfortunate side effect that if a shost adapter does not automatically request sense information, we end up shutting it down before we request it.h]hThis has the unfortunate side effect that if a shost adapter does not automatically request sense information, we end up shutting it down before we request it.}(hj9DhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM!hj5Dubh)}(hAll drivers should request sense information internally these days, so for now all I have to say is tough noogies if you end up in here.h]hAll drivers should request sense information internally these days, so for now all I have to say is tough noogies if you end up in here.}(hjHDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM%hj5Dubj#)}(hhh]j()}(hTXXX: Long term this code should go away, but that needs an audit of all LLDDs first.h](j.)}(hCXXX: Long term this code should go away, but that needs an audit ofh]hCXXX: Long term this code should go away, but that needs an audit of}(hj^DhhhNhNubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM(hjZDubjJ)}(hhh]h)}(hall LLDDs first.h]hall LLDDs first.}(hjpDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM)hjmDubah}(h]h ]h"]h$]h&]uh1jIhjZDubeh}(h]h ]h"]h$]h&]uh1j'hjlDhM(hjWDubah}(h]h ]h"]h$]h&]uh1j"hj5Dubeh}(h]h ]h"]h$]h&]uh1j_hjGDhM!hjUCubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj4hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_eh_ready_devs (C function)c.scsi_eh_ready_devshNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(hevoid scsi_eh_ready_devs (struct Scsi_Host *shost, struct list_head *work_q, struct list_head *done_q)h]jP)}(hdvoid scsi_eh_ready_devs(struct Scsi_Host *shost, struct list_head *work_q, struct list_head *done_q)h](j~)}(hvoidh]hvoid}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjDhhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMubjh)}(h h]h }(hjDhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjDhhhjDhMubjy)}(hscsi_eh_ready_devsh]j)}(hscsi_eh_ready_devsh]hscsi_eh_ready_devs}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjDubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjDhhhjDhMubj)}(hM(struct Scsi_Host *shost, struct list_head *work_q, struct list_head *done_q)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjDhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjDubjh)}(h h]h }(hjEhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjDubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjEmodnameN classnameNjj)}j]j)}jjDsbc.scsi_eh_ready_devsasbuh1hhjDubjh)}(h h]h }(hj2EhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjDubj )}(hj h]h*}(hj@EhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjDubj)}(hshosth]hshost}(hjMEhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjDubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjDubj)}(hstruct list_head *work_qh](jV)}(hjYh]hstruct}(hjfEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjbEubjh)}(h h]h }(hjsEhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjbEubh)}(hhh]j)}(h list_headh]h list_head}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjEmodnameN classnameNjj)}j]j.Ec.scsi_eh_ready_devsasbuh1hhjbEubjh)}(h h]h }(hjEhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjbEubj )}(hj h]h*}(hjEhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjbEubj)}(hwork_qh]hwork_q}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjbEubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjDubj)}(hstruct list_head *done_qh](jV)}(hjYh]hstruct}(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjEubjh)}(h h]h }(hjEhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjEubh)}(hhh]j)}(h list_headh]h list_head}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjEmodnameN classnameNjj)}j]j.Ec.scsi_eh_ready_devsasbuh1hhjEubjh)}(h h]h }(hjFhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjEubj )}(hj h]h*}(hj FhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjEubj)}(hdone_qh]hdone_q}(hj-FhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjDubeh}(h]h ]h"]h$]h&]jjuh1jhjDhhhjDhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjDhhhjDhMubah}(h]jDah ](jjeh"]h$]h&]jj)jhuh1jIhjDhMhjDhhubj)}(hhh]h)}(h,check device ready state and recover if not.h]h,check device ready state and recover if not.}(hjWFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjTFhhubah}(h]h ]h"]h$]h&]uh1jhjDhhhjDhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjoFjjoFjjjuh1jDhhhj4hNhNubj)}(h**Parameters** ``struct Scsi_Host *shost`` host to be recovered. ``struct list_head *work_q`` :c:type:`list_head` for pending commands. ``struct list_head *done_q`` :c:type:`list_head` for processed commands.h](h)}(h**Parameters**h]j)}(hjyFh]h Parameters}(hj{FhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwFubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjsFubj#)}(hhh](j()}(h2``struct Scsi_Host *shost`` host to be recovered. h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjFh]hstruct Scsi_Host *shost}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjFubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjFubjJ)}(hhh]h)}(hhost to be recovered.h]hhost to be recovered.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhMhjFubah}(h]h ]h"]h$]h&]uh1jIhjFubeh}(h]h ]h"]h$]h&]uh1j'hjFhMhjFubj()}(hG``struct list_head *work_q`` :c:type:`list_head` for pending commands. h](j.)}(h``struct list_head *work_q``h]j4)}(hjFh]hstruct list_head *work_q}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjFubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjFubjJ)}(hhh]h)}(h):c:type:`list_head` for pending commands.h](h)}(h:c:type:`list_head`h]j4)}(hjFh]h list_head}(hjFhhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hjFubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjj list_headuh1hhjFhMhjFubh for pending commands.}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjFhMhjFubah}(h]h ]h"]h$]h&]uh1jIhjFubeh}(h]h ]h"]h$]h&]uh1j'hjFhMhjFubj()}(hH``struct list_head *done_q`` :c:type:`list_head` for processed commands.h](j.)}(h``struct list_head *done_q``h]j4)}(hj)Gh]hstruct list_head *done_q}(hj+GhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj'Gubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj#GubjJ)}(hhh]h)}(h+:c:type:`list_head` for processed commands.h](h)}(h:c:type:`list_head`h]j4)}(hjHGh]h list_head}(hjJGhhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hjFGubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjj list_headuh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjBGubh for processed commands.}(hjBGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjeGhMhj?Gubah}(h]h ]h"]h$]h&]uh1jIhj#Gubeh}(h]h ]h"]h$]h&]uh1j'hj>GhMhjFubeh}(h]h ]h"]h$]h&]uh1j"hjsFubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj4hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!scsi_eh_flush_done_q (C function)c.scsi_eh_flush_done_qhNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(h4void scsi_eh_flush_done_q (struct list_head *done_q)h]jP)}(h3void scsi_eh_flush_done_q(struct list_head *done_q)h](j~)}(hvoidh]hvoid}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjGhhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMubjh)}(h h]h }(hjGhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjGhhhjGhMubjy)}(hscsi_eh_flush_done_qh]j)}(hscsi_eh_flush_done_qh]hscsi_eh_flush_done_q}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjGubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjGhhhjGhMubj)}(h(struct list_head *done_q)h]j)}(hstruct list_head *done_qh](jV)}(hjYh]hstruct}(hjGhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjGubjh)}(h h]h }(hjGhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjGubh)}(hhh]j)}(h list_headh]h list_head}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjGubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjGmodnameN classnameNjj)}j]j)}jjGsbc.scsi_eh_flush_done_qasbuh1hhjGubjh)}(h h]h }(hjHhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjGubj )}(hj h]h*}(hj+HhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjGubj)}(hdone_qh]hdone_q}(hj8HhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjGubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjGubah}(h]h ]h"]h$]h&]jjuh1jhjGhhhjGhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjGhhhjGhMubah}(h]jGah ](jjeh"]h$]h&]jj)jhuh1jIhjGhMhjGhhubj)}(hhh]h)}(h(finish processed commands or retry them.h]h(finish processed commands or retry them.}(hjbHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj_Hhhubah}(h]h ]h"]h$]h&]uh1jhjGhhhjGhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjzHjjzHjjjuh1jDhhhj4hNhNubj)}(hO**Parameters** ``struct list_head *done_q`` list_head of processed commands.h](h)}(h**Parameters**h]j)}(hjHh]h Parameters}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhj~Hubj#)}(hhh]j()}(h=``struct list_head *done_q`` list_head of processed commands.h](j.)}(h``struct list_head *done_q``h]j4)}(hjHh]hstruct list_head *done_q}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjHubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjHubjJ)}(hhh]h)}(h list_head of processed commands.h]h list_head of processed commands.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMhjHubah}(h]h ]h"]h$]h&]uh1jIhjHubeh}(h]h ]h"]h$]h&]uh1j'hjHhMhjHubah}(h]h ]h"]h$]h&]uh1j"hj~Hubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj4hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"scsi_report_bus_reset (C function)c.scsi_report_bus_resethNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(hAvoid scsi_report_bus_reset (struct Scsi_Host *shost, int channel)h]jP)}(h@void scsi_report_bus_reset(struct Scsi_Host *shost, int channel)h](j~)}(hvoidh]hvoid}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjHhhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMS ubjh)}(h h]h }(hj IhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjHhhhj IhMS ubjy)}(hscsi_report_bus_reseth]j)}(hscsi_report_bus_reseth]hscsi_report_bus_reset}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjIubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjHhhhj IhMS ubj)}(h&(struct Scsi_Host *shost, int channel)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj:IhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj6Iubjh)}(h h]h }(hjGIhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj6Iubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjXIhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjUIubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjZImodnameN classnameNjj)}j]j)}jj Isbc.scsi_report_bus_resetasbuh1hhj6Iubjh)}(h h]h }(hjxIhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj6Iubj )}(hj h]h*}(hjIhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj6Iubj)}(hshosth]hshost}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj6Iubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2Iubj)}(h int channelh](j~)}(hinth]hint}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjIubjh)}(h h]h }(hjIhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjIubj)}(hchannelh]hchannel}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjIubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2Iubeh}(h]h ]h"]h$]h&]jjuh1jhjHhhhj IhMS ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjHhhhj IhMS ubah}(h]jHah ](jjeh"]h$]h&]jj)jhuh1jIhj IhMS hjHhhubj)}(hhh]h)}(hreport bus reset observedh]hreport bus reset observed}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMS hjIhhubah}(h]h ]h"]h$]h&]uh1jhjHhhhj IhMS ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj Jjj Jjjjuh1jDhhhj4hNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` Host in question ``int channel`` channel on which reset was observed. **Description** Utility function used by low-level drivers to report that they have observed a bus reset on the bus being handled. Lock status: Host lock must be held. **Return** Nothing **Notes** This only needs to be called if the reset is one which originates from an unknown location. Resets originated by the mid-level itself don't need to call this, but there should be no harm. The main purpose of this is to make sure that a CHECK_CONDITION is properly treated.h](h)}(h**Parameters**h]j)}(hjJh]h Parameters}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMW hjJubj#)}(hhh](j()}(h-``struct Scsi_Host *shost`` Host in question h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj3Jh]hstruct Scsi_Host *shost}(hj5JhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj1Jubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMX hj-JubjJ)}(hhh]h)}(hHost in questionh]hHost in question}(hjLJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHJhMX hjIJubah}(h]h ]h"]h$]h&]uh1jIhj-Jubeh}(h]h ]h"]h$]h&]uh1j'hjHJhMX hj*Jubj()}(h5``int channel`` channel on which reset was observed. h](j.)}(h``int channel``h]j4)}(hjlJh]h int channel}(hjnJhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjjJubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMY hjfJubjJ)}(hhh]h)}(h$channel on which reset was observed.h]h$channel on which reset was observed.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhMY hjJubah}(h]h ]h"]h$]h&]uh1jIhjfJubeh}(h]h ]h"]h$]h&]uh1j'hjJhMY hj*Jubeh}(h]h ]h"]h$]h&]uh1j"hjJubh)}(h**Description**h]j)}(hjJh]h Description}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM[ hjJubh)}(hrUtility function used by low-level drivers to report that they have observed a bus reset on the bus being handled.h]hrUtility function used by low-level drivers to report that they have observed a bus reset on the bus being handled.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMT hjJubh)}(h$Lock status: Host lock must be held.h]h$Lock status: Host lock must be held.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMW hjJubh)}(h **Return**h]j)}(hjJh]hReturn}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMY hjJubh)}(hNothingh]hNothing}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM[ hjJubh)}(h **Notes**h]j)}(hjKh]hNotes}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM] hjJubj#)}(hhh]j()}(hXThis only needs to be called if the reset is one which originates from an unknown location. Resets originated by the mid-level itself don't need to call this, but there should be no harm. The main purpose of this is to make sure that a CHECK_CONDITION is properly treated.h](j.)}(h6This only needs to be called if the reset is one whichh]h6This only needs to be called if the reset is one which}(hj!KhhhNhNubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMd hjKubjJ)}(hhh](h)}(horiginates from an unknown location. Resets originated by the mid-level itself don't need to call this, but there should be no harm.h]horiginates from an unknown location. Resets originated by the mid-level itself don’t need to call this, but there should be no harm.}(hj3KhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chM` hj0Kubh)}(hTThe main purpose of this is to make sure that a CHECK_CONDITION is properly treated.h]hTThe main purpose of this is to make sure that a CHECK_CONDITION is properly treated.}(hjBKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/KhMd hj0Kubeh}(h]h ]h"]h$]h&]uh1jIhjKubeh}(h]h ]h"]h$]h&]uh1j'hj/KhMd hjKubah}(h]h ]h"]h$]h&]uh1j"hjJubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj4hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@%scsi_report_device_reset (C function)c.scsi_report_device_resethNtauh1j3hj4hhhNhNubjE)}(hhh](jJ)}(hPvoid scsi_report_device_reset (struct Scsi_Host *shost, int channel, int target)h]jP)}(hOvoid scsi_report_device_reset(struct Scsi_Host *shost, int channel, int target)h](j~)}(hvoidh]hvoid}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj~KhhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMs ubjh)}(h h]h }(hjKhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~KhhhjKhMs ubjy)}(hscsi_report_device_reseth]j)}(hscsi_report_device_reseth]hscsi_report_device_reset}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjKubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj~KhhhjKhMs ubj)}(h2(struct Scsi_Host *shost, int channel, int target)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjKubjh)}(h h]h }(hjKhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjKubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjKubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjKmodnameN classnameNjj)}j]j)}jjKsbc.scsi_report_device_resetasbuh1hhjKubjh)}(h h]h }(hjKhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjKubj )}(hj h]h*}(hj LhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjKubj)}(hshosth]hshost}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjKubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjKubj)}(h int channelh](j~)}(hinth]hint}(hj1LhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj-Lubjh)}(h h]h }(hj?LhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj-Lubj)}(hchannelh]hchannel}(hjMLhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj-Lubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjKubj)}(h int targeth](j~)}(hinth]hint}(hjfLhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjbLubjh)}(h h]h }(hjtLhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjbLubj)}(htargeth]htarget}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjbLubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjKubeh}(h]h ]h"]h$]h&]jjuh1jhj~KhhhjKhMs ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjzKhhhjKhMs ubah}(h]juKah ](jjeh"]h$]h&]jj)jhuh1jIhjKhMs hjwKhhubj)}(hhh]h)}(hreport device reset observedh]hreport device reset observed}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMs hjLhhubah}(h]h ]h"]h$]h&]uh1jhjwKhhhjKhMs ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjLjjLjjjuh1jDhhhj4hNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` Host in question ``int channel`` channel on which reset was observed ``int target`` target on which reset was observed **Description** Utility function used by low-level drivers to report that they have observed a device reset on the device being handled. Lock status: Host lock must be held **Return** Nothing **Notes** This only needs to be called if the reset is one which originates from an unknown location. Resets originated by the mid-level itself don't need to call this, but there should be no harm. The main purpose of this is to make sure that a CHECK_CONDITION is properly treated.h](h)}(h**Parameters**h]j)}(hjLh]h Parameters}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMw hjLubj#)}(hhh](j()}(h-``struct Scsi_Host *shost`` Host in question h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjLh]hstruct Scsi_Host *shost}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjLubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMx hjLubjJ)}(hhh]h)}(hHost in questionh]hHost in question}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhMx hjMubah}(h]h ]h"]h$]h&]uh1jIhjLubeh}(h]h ]h"]h$]h&]uh1j'hjMhMx hjLubj()}(h4``int channel`` channel on which reset was observed h](j.)}(h``int channel``h]j4)}(hj&Mh]h int channel}(hj(MhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj$Mubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:119: ./drivers/scsi/scsi_error.chMy hj MubjJ)}(hhh]h)}(h#channel on which reset was observedh]h#channel on which reset was observed}(hj?MhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;MhMy hjcompatible. The scsi_static_device_list entries are added with **compatible** 1 and **clfags** NULL. **Return** 0 OK, -error on failure.h](h)}(h**Parameters**h]j)}(hj]Sh]h Parameters}(hj_ShhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[Subah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMShjWSubj#)}(hhh](j()}(hP``int compatible`` if true, null terminate short strings. Otherwise space pad. h](j.)}(h``int compatible``h]j4)}(hj|Sh]hint compatible}(hj~ShhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjzSubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMPhjvSubjJ)}(hhh]h)}(h``blist_flags_t flags`` if strflags NULL, use this flag value h](j.)}(h``blist_flags_t flags``h]j4)}(hj`Th]hblist_flags_t flags}(hjbThhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj^Tubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMThjZTubjJ)}(hhh]h)}(h%if strflags NULL, use this flag valueh]h%if strflags NULL, use this flag value}(hjyThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuThMThjvTubah}(h]h ]h"]h$]h&]uh1jIhjZTubeh}(h]h ]h"]h$]h&]uh1j'hjuThMThjsSubj()}(h2``enum scsi_devinfo_key key`` specify list to use h](j.)}(h``enum scsi_devinfo_key key``h]j4)}(hjTh]henum scsi_devinfo_key key}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjTubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMUhjTubjJ)}(hhh]h)}(hspecify list to useh]hspecify list to use}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThMUhjTubah}(h]h ]h"]h$]h&]uh1jIhjTubeh}(h]h ]h"]h$]h&]uh1j'hjThMUhjsSubeh}(h]h ]h"]h$]h&]uh1j"hjWSubh)}(h**Description**h]j)}(hjTh]h Description}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMWhjWSubj`)}(hX,Create and add one dev_info entry for **vendor**, **model**, **strflags** or **flag** in list specified by **key**. If **compatible**, add to the tail of the list, do not space pad, and set devinfo->compatible. The scsi_static_device_list entries are added with **compatible** 1 and **clfags** NULL. h]h)}(hX+Create and add one dev_info entry for **vendor**, **model**, **strflags** or **flag** in list specified by **key**. If **compatible**, add to the tail of the list, do not space pad, and set devinfo->compatible. The scsi_static_device_list entries are added with **compatible** 1 and **clfags** NULL.h](h&Create and add one dev_info entry for }(hjThhhNhNubj)}(h **vendor**h]hvendor}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubh, }(hjThhhNhNubj)}(h **model**h]hmodel}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubh, }(hjThhhNhNubj)}(h **strflags**h]hstrflags}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubh or }(hjThhhNhNubj)}(h**flag**h]hflag}(hj,UhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubh in list specified by }(hjThhhNhNubj)}(h**key**h]hkey}(hj>UhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubh. If }(hjThhhNhNubj)}(h**compatible**h]h compatible}(hjPUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubh, add to the tail of the list, do not space pad, and set devinfo->compatible. The scsi_static_device_list entries are added with }(hjThhhNhNubj)}(h**compatible**h]h compatible}(hjbUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubh 1 and }(hjThhhNhNubj)}(h **clfags**h]hclfags}(hjtUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubh NULL.}(hjThhhNhNubeh}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMWhjTubah}(h]h ]h"]h$]h&]uh1j_hjUhMWhjWSubh)}(h **Return**h]j)}(hjUh]hReturn}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM]hjWSubh)}(h0 OK, -error on failure.h]h0 OK, -error on failure.}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM^hjWSubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj QhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@(scsi_get_device_flags_keyed (C function)c.scsi_get_device_flags_keyedhNtauh1j3hj QhhhNhNubjE)}(hhh](jJ)}(hblist_flags_t scsi_get_device_flags_keyed (struct scsi_device *sdev, const unsigned char *vendor, const unsigned char *model, enum scsi_devinfo_key key)h]jP)}(hblist_flags_t scsi_get_device_flags_keyed(struct scsi_device *sdev, const unsigned char *vendor, const unsigned char *model, enum scsi_devinfo_key key)h](h)}(hhh]j)}(h blist_flags_th]h blist_flags_t}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjUubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjUmodnameN classnameNjj)}j]j)}jscsi_get_device_flags_keyedsbc.scsi_get_device_flags_keyedasbuh1hhjUhhh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM2ubjh)}(h h]h }(hjUhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjUhhhjUhM2ubjy)}(hscsi_get_device_flags_keyedh]j)}(hjUh]hscsi_get_device_flags_keyed}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj Vubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjUhhhjUhM2ubj)}(hn(struct scsi_device *sdev, const unsigned char *vendor, const unsigned char *model, enum scsi_devinfo_key key)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hj,VhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(Vubjh)}(h h]h }(hj9VhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj(Vubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjJVhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjGVubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjLVmodnameN classnameNjj)}j]jUc.scsi_get_device_flags_keyedasbuh1hhj(Vubjh)}(h h]h }(hjhVhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj(Vubj )}(hj h]h*}(hjvVhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj(Vubj)}(hsdevh]hsdev}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(Vubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj$Vubj)}(hconst unsigned char *vendorh](jV)}(hjNh]hconst}(hjVhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjVubjh)}(h h]h }(hjVhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjVubj~)}(hunsignedh]hunsigned}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjVubjh)}(h h]h }(hjVhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjVubj~)}(hcharh]hchar}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjVubjh)}(h h]h }(hjVhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjVubj )}(hj h]h*}(hjVhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjVubj)}(hvendorh]hvendor}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjVubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj$Vubj)}(hconst unsigned char *modelh](jV)}(hjNh]hconst}(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjWubjh)}(h h]h }(hj"WhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjWubj~)}(hunsignedh]hunsigned}(hj0WhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjWubjh)}(h h]h }(hj>WhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjWubj~)}(hcharh]hchar}(hjLWhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjWubjh)}(h h]h }(hjZWhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjWubj )}(hj h]h*}(hjhWhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjWubj)}(hmodelh]hmodel}(hjuWhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjWubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj$Vubj)}(henum scsi_devinfo_key keyh](jV)}(hj7h]henum}(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjWubjh)}(h h]h }(hjWhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjWubh)}(hhh]j)}(hscsi_devinfo_keyh]hscsi_devinfo_key}(hjWhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjWubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjWmodnameN classnameNjj)}j]jUc.scsi_get_device_flags_keyedasbuh1hhjWubjh)}(h h]h }(hjWhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjWubj)}(hkeyh]hkey}(hjWhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjWubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj$Vubeh}(h]h ]h"]h$]h&]jjuh1jhjUhhhjUhM2ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjUhhhjUhM2ubah}(h]jUah ](jjeh"]h$]h&]jj)jhuh1jIhjUhM2hjUhhubj)}(hhh]h)}(h6get device specific flags from the dynamic device listh]h6get device specific flags from the dynamic device list}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM2hjWhhubah}(h]h ]h"]h$]h&]uh1jhjUhhhjUhM2ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjXjjXjjjuh1jDhhhj QhNhNubj)}(hX**Parameters** ``struct scsi_device *sdev`` :c:type:`scsi_device` to get flags for ``const unsigned char *vendor`` vendor name ``const unsigned char *model`` model name ``enum scsi_devinfo_key key`` list to look up **Description** Search the scsi_dev_info_list specified by **key** for an entry matching **vendor** and **model**, if found, return the matching flags value, else return the host or global default settings. Called during scan time.h](h)}(h**Parameters**h]j)}(hj$Xh]h Parameters}(hj&XhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"Xubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM6hjXubj#)}(hhh](j()}(hD``struct scsi_device *sdev`` :c:type:`scsi_device` to get flags for h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjCXh]hstruct scsi_device *sdev}(hjEXhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjAXubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM3hj=XubjJ)}(hhh]h)}(h&:c:type:`scsi_device` to get flags forh](h)}(h:c:type:`scsi_device`h]j4)}(hjbXh]h scsi_device}(hjdXhhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hj`Xubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjj scsi_deviceuh1hhjXXhM3hj\Xubh to get flags for}(hj\XhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjXXhM3hjYXubah}(h]h ]h"]h$]h&]uh1jIhj=Xubeh}(h]h ]h"]h$]h&]uh1j'hjXXhM3hj:Xubj()}(h,``const unsigned char *vendor`` vendor name h](j.)}(h``const unsigned char *vendor``h]j4)}(hjXh]hconst unsigned char *vendor}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjXubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM4hjXubjJ)}(hhh]h)}(h vendor nameh]h vendor name}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhM4hjXubah}(h]h ]h"]h$]h&]uh1jIhjXubeh}(h]h ]h"]h$]h&]uh1j'hjXhM4hj:Xubj()}(h*``const unsigned char *model`` model name h](j.)}(h``const unsigned char *model``h]j4)}(hjXh]hconst unsigned char *model}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjXubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM5hjXubjJ)}(hhh]h)}(h model nameh]h model name}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhM5hjXubah}(h]h ]h"]h$]h&]uh1jIhjXubeh}(h]h ]h"]h$]h&]uh1j'hjXhM5hj:Xubj()}(h.``enum scsi_devinfo_key key`` list to look up h](j.)}(h``enum scsi_devinfo_key key``h]j4)}(hj Yh]henum scsi_devinfo_key key}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj Yubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM6hjYubjJ)}(hhh]h)}(hlist to look uph]hlist to look up}(hj&YhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"YhM6hj#Yubah}(h]h ]h"]h$]h&]uh1jIhjYubeh}(h]h ]h"]h$]h&]uh1j'hj"YhM6hj:Xubeh}(h]h ]h"]h$]h&]uh1j"hjXubh)}(h**Description**h]j)}(hjHYh]h Description}(hjJYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFYubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM8hjXubj`)}(hSearch the scsi_dev_info_list specified by **key** for an entry matching **vendor** and **model**, if found, return the matching flags value, else return the host or global default settings. Called during scan time.h]h)}(hSearch the scsi_dev_info_list specified by **key** for an entry matching **vendor** and **model**, if found, return the matching flags value, else return the host or global default settings. Called during scan time.h](h+Search the scsi_dev_info_list specified by }(hjbYhhhNhNubj)}(h**key**h]hkey}(hjjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbYubh for an entry matching }(hjbYhhhNhNubj)}(h **vendor**h]hvendor}(hj|YhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbYubh and }(hjbYhhhNhNubj)}(h **model**h]hmodel}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbYubhv, if found, return the matching flags value, else return the host or global default settings. Called during scan time.}(hjbYhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chM8hj^Yubah}(h]h ]h"]h$]h&]uh1j_hjYhM8hjXubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj QhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@#scsi_dev_info_add_list (C function)c.scsi_dev_info_add_listhNtauh1j3hj QhhhNhNubjE)}(hhh](jJ)}(hHint scsi_dev_info_add_list (enum scsi_devinfo_key key, const char *name)h]jP)}(hGint scsi_dev_info_add_list(enum scsi_devinfo_key key, const char *name)h](j~)}(hinth]hint}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjYhhh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMubjh)}(h h]h }(hjYhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjYhhhjYhMubjy)}(hscsi_dev_info_add_listh]j)}(hscsi_dev_info_add_listh]hscsi_dev_info_add_list}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjYubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjYhhhjYhMubj)}(h-(enum scsi_devinfo_key key, const char *name)h](j)}(henum scsi_devinfo_key keyh](jV)}(hj7h]henum}(hj ZhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZubjh)}(h h]h }(hjZhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjZubh)}(hhh]j)}(hscsi_devinfo_keyh]hscsi_devinfo_key}(hj(ZhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj%Zubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*ZmodnameN classnameNjj)}j]j)}jjYsbc.scsi_dev_info_add_listasbuh1hhjZubjh)}(h h]h }(hjHZhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjZubj)}(hkeyh]hkey}(hjVZhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjZubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZubj)}(hconst char *nameh](jV)}(hjNh]hconst}(hjoZhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjkZubjh)}(h h]h }(hj|ZhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjkZubj~)}(hcharh]hchar}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjkZubjh)}(h h]h }(hjZhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjkZubj )}(hj h]h*}(hjZhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjkZubj)}(hnameh]hname}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjkZubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZubeh}(h]h ]h"]h$]h&]jjuh1jhjYhhhjYhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjYhhhjYhMubah}(h]jYah ](jjeh"]h$]h&]jj)jhuh1jIhjYhMhjYhhubj)}(hhh]h)}(hadd a new devinfo listh]hadd a new devinfo list}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhjZhhubah}(h]h ]h"]h$]h&]uh1jhjYhhhjYhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjZjjZjjjuh1jDhhhj QhNhNubj)}(hX&**Parameters** ``enum scsi_devinfo_key key`` key of the list to add ``const char *name`` Name of the list to add (for /proc/scsi/device_info) **Description** Adds the requested list, returns zero on success, -EEXIST if the key is already registered to a list, or other error on failure.h](h)}(h**Parameters**h]j)}(hjZh]h Parameters}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhjZubj#)}(hhh](j()}(h5``enum scsi_devinfo_key key`` key of the list to add h](j.)}(h``enum scsi_devinfo_key key``h]j4)}(hj[h]henum scsi_devinfo_key key}(hj [hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj[ubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhj[ubjJ)}(hhh]h)}(hkey of the list to addh]hkey of the list to add}(hj7[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3[hMhj4[ubah}(h]h ]h"]h$]h&]uh1jIhj[ubeh}(h]h ]h"]h$]h&]uh1j'hj3[hMhj[ubj()}(hJ``const char *name`` Name of the list to add (for /proc/scsi/device_info) h](j.)}(h``const char *name``h]j4)}(hjW[h]hconst char *name}(hjY[hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjU[ubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhjQ[ubjJ)}(hhh]h)}(h4Name of the list to add (for /proc/scsi/device_info)h]h4Name of the list to add (for /proc/scsi/device_info)}(hjp[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjl[hMhjm[ubah}(h]h ]h"]h$]h&]uh1jIhjQ[ubeh}(h]h ]h"]h$]h&]uh1j'hjl[hMhj[ubeh}(h]h ]h"]h$]h&]uh1j"hjZubh)}(h**Description**h]j)}(hj[h]h Description}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhjZubh)}(hAdds the requested list, returns zero on success, -EEXIST if the key is already registered to a list, or other error on failure.h]hAdds the requested list, returns zero on success, -EEXIST if the key is already registered to a list, or other error on failure.}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhjZubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj QhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@&scsi_dev_info_remove_list (C function)c.scsi_dev_info_remove_listhNtauh1j3hj QhhhNhNubjE)}(hhh](jJ)}(h9int scsi_dev_info_remove_list (enum scsi_devinfo_key key)h]jP)}(h8int scsi_dev_info_remove_list(enum scsi_devinfo_key key)h](j~)}(hinth]hint}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj[hhh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMubjh)}(h h]h }(hj[hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj[hhhj[hMubjy)}(hscsi_dev_info_remove_listh]j)}(hscsi_dev_info_remove_listh]hscsi_dev_info_remove_list}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj[ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj[hhhj[hMubj)}(h(enum scsi_devinfo_key key)h]j)}(henum scsi_devinfo_key keyh](jV)}(hj7h]henum}(hj\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\ubjh)}(h h]h }(hj!\hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj\ubh)}(hhh]j)}(hscsi_devinfo_keyh]hscsi_devinfo_key}(hj2\hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj/\ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj4\modnameN classnameNjj)}j]j)}jj[sbc.scsi_dev_info_remove_listasbuh1hhj\ubjh)}(h h]h }(hjR\hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj\ubj)}(hkeyh]hkey}(hj`\hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj\ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj \ubah}(h]h ]h"]h$]h&]jjuh1jhj[hhhj[hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj[hhhj[hMubah}(h]j[ah ](jjeh"]h$]h&]jj)jhuh1jIhj[hMhj[hhubj)}(hhh]h)}(hdestroy an added devinfo listh]hdestroy an added devinfo list}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhj\hhubah}(h]h ]h"]h$]h&]uh1jhj[hhhj[hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj\jj\jjjuh1jDhhhj QhNhNubj)}(h**Parameters** ``enum scsi_devinfo_key key`` key of the list to destroy **Description** Iterates over the entire list first, freeing all the values, then frees the list itself. Returns 0 on success or -EINVAL if the key can't be found.h](h)}(h**Parameters**h]j)}(hj\h]h Parameters}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhj\ubj#)}(hhh]j()}(h9``enum scsi_devinfo_key key`` key of the list to destroy h](j.)}(h``enum scsi_devinfo_key key``h]j4)}(hj\h]henum scsi_devinfo_key key}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj\ubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhj\ubjJ)}(hhh]h)}(hkey of the list to destroyh]hkey of the list to destroy}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hMhj\ubah}(h]h ]h"]h$]h&]uh1jIhj\ubeh}(h]h ]h"]h$]h&]uh1j'hj\hMhj\ubah}(h]h ]h"]h$]h&]uh1j"hj\ubh)}(h**Description**h]j)}(hj]h]h Description}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhj\ubh)}(hIterates over the entire list first, freeing all the values, then frees the list itself. Returns 0 on success or -EINVAL if the key can't be found.h]hIterates over the entire list first, freeing all the values, then frees the list itself. Returns 0 on success or -EINVAL if the key can’t be found.}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:128: ./drivers/scsi/scsi_devinfo.chMhj\ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj QhhhNhNubeh}(h]drivers-scsi-scsi-devinfo-cah ]h"]drivers/scsi/scsi_devinfo.cah$]h&]uh1hhjhhhhhK{ubh)}(hhh](h)}(hdrivers/scsi/scsi_ioctl.ch]hdrivers/scsi/scsi_ioctl.c}(hj=]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:]hhhhhKubh)}(h&Handle ioctl() calls for SCSI devices.h]h&Handle ioctl() calls for SCSI devices.}(hjK]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj:]hhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@$scsi_set_medium_removal (C function)c.scsi_set_medium_removalhNtauh1j3hj:]hhhNhNubjE)}(hhh](jJ)}(hBint scsi_set_medium_removal (struct scsi_device *sdev, char state)h]jP)}(hAint scsi_set_medium_removal(struct scsi_device *sdev, char state)h](j~)}(hinth]hint}(hjr]hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjn]hhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chKubjh)}(h h]h }(hj]hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjn]hhhj]hKubjy)}(hscsi_set_medium_removalh]j)}(hscsi_set_medium_removalh]hscsi_set_medium_removal}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj]ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjn]hhhj]hKubj)}(h&(struct scsi_device *sdev, char state)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]ubjh)}(h h]h }(hj]hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj]ubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj]modnameN classnameNjj)}j]j)}jj]sbc.scsi_set_medium_removalasbuh1hhj]ubjh)}(h h]h }(hj]hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj]ubj )}(hj h]h*}(hj]hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj]ubj)}(hsdevh]hsdev}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj]ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubj)}(h char stateh](j~)}(hcharh]hchar}(hj!^hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj^ubjh)}(h h]h }(hj/^hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj^ubj)}(hstateh]hstate}(hj=^hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubeh}(h]h ]h"]h$]h&]jjuh1jhjn]hhhj]hKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjj]hhhj]hKubah}(h]je]ah ](jjeh"]h$]h&]jj)jhuh1jIhj]hKhjg]hhubj)}(hhh]h)}(h/send command to allow or prevent medium removalh]h/send command to allow or prevent medium removal}(hjg^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chKhjd^hhubah}(h]h ]h"]h$]h&]uh1jhjg]hhhj]hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj^jj^jjjuh1jDhhhj:]hNhNubj)}(hXG**Parameters** ``struct scsi_device *sdev`` target scsi device ``char state`` removal state to set (prevent or allow) **Return** * ``0`` if **sdev** is not removable or not lockable or successful. * non-``0`` is a SCSI result code if > 0 or kernel error code if < 0. * Sets **sdev->locked** to the new state on success.h](h)}(h**Parameters**h]j)}(hj^h]h Parameters}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chKhj^ubj#)}(hhh](j()}(h0``struct scsi_device *sdev`` target scsi device h](j.)}(h``struct scsi_device *sdev``h]j4)}(hj^h]hstruct scsi_device *sdev}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj^ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chKhj^ubjJ)}(hhh]h)}(htarget scsi deviceh]htarget scsi device}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hKhj^ubah}(h]h ]h"]h$]h&]uh1jIhj^ubeh}(h]h ]h"]h$]h&]uh1j'hj^hKhj^ubj()}(h7``char state`` removal state to set (prevent or allow) h](j.)}(h``char state``h]j4)}(hj^h]h char state}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj^ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chKhj^ubjJ)}(hhh]h)}(h'removal state to set (prevent or allow)h]h'removal state to set (prevent or allow)}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hKhj^ubah}(h]h ]h"]h$]h&]uh1jIhj^ubeh}(h]h ]h"]h$]h&]uh1j'hj^hKhj^ubeh}(h]h ]h"]h$]h&]uh1j"hj^ubh)}(h **Return**h]j)}(hj_h]hReturn}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chKhj^ubh bullet_list)}(hhh](h list_item)}(hA``0`` if **sdev** is not removable or not lockable or successful.h]h)}(hj;_h](j4)}(h``0``h]h0}(hj@_hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj=_ubh if }(hj=_hhhNhNubj)}(h**sdev**h]hsdev}(hjR_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=_ubh0 is not removable or not lockable or successful.}(hj=_hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chKhj9_ubah}(h]h ]h"]h$]h&]uh1j7_hj4_ubj8_)}(hCnon-``0`` is a SCSI result code if > 0 or kernel error code if < 0.h]h)}(hjs_h](hnon-}(hju_hhhNhNubj4)}(h``0``h]h0}(hj|_hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hju_ubh: is a SCSI result code if > 0 or kernel error code if < 0.}(hju_hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chKhjq_ubah}(h]h ]h"]h$]h&]uh1j7_hj4_ubj8_)}(h2Sets **sdev->locked** to the new state on success.h]h)}(hj_h](hSets }(hj_hhhNhNubj)}(h**sdev->locked**h]h sdev->locked}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubh to the new state on success.}(hj_hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chKhj_ubah}(h]h ]h"]h$]h&]uh1j7_hj4_ubeh}(h]h ]h"]h$]h&]bulletj uh1j2_hjj_hKhj^ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj:]hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_cmd_allowed (C function)c.scsi_cmd_allowedhNtauh1j3hj:]hhhNhNubjE)}(hhh](jJ)}(h?bool scsi_cmd_allowed (unsigned char *cmd, bool open_for_write)h]jP)}(h>bool scsi_cmd_allowed(unsigned char *cmd, bool open_for_write)h](j~)}(hjU.h]hbool}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj_hhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMubjh)}(h h]h }(hj_hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj_hhhj_hMubjy)}(hscsi_cmd_allowedh]j)}(hscsi_cmd_allowedh]hscsi_cmd_allowed}(hj `hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj`ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj_hhhj_hMubj)}(h)(unsigned char *cmd, bool open_for_write)h](j)}(hunsigned char *cmdh](j~)}(hunsignedh]hunsigned}(hj(`hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj$`ubjh)}(h h]h }(hj6`hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj$`ubj~)}(hcharh]hchar}(hjD`hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj$`ubjh)}(h h]h }(hjR`hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj$`ubj )}(hj h]h*}(hj``hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj$`ubj)}(hcmdh]hcmd}(hjm`hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj$`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj `ubj)}(hbool open_for_writeh](j~)}(hjU.h]hbool}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj`ubjh)}(h h]h }(hj`hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj`ubj)}(hopen_for_writeh]hopen_for_write}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj `ubeh}(h]h ]h"]h$]h&]jjuh1jhj_hhhj_hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj_hhhj_hMubah}(h]j_ah ](jjeh"]h$]h&]jj)jhuh1jIhj_hMhj_hhubj)}(hhh]h)}(h&Check if the given command is allowed.h]h&Check if the given command is allowed.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhj`hhubah}(h]h ]h"]h$]h&]uh1jhj_hhhj_hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj`jj`jjjuh1jDhhhj:]hNhNubj)}(hXj**Parameters** ``unsigned char *cmd`` SCSI command to check ``bool open_for_write`` is the file / block device opened for writing? **Description** Only a subset of commands are allowed for unprivileged users. Commands used to format the media, update the firmware, etc. are not permitted. **Return** ``true`` if the cmd is allowed, otherwise **false**.h](h)}(h**Parameters**h]j)}(hj`h]h Parameters}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhj`ubj#)}(hhh](j()}(h-``unsigned char *cmd`` SCSI command to check h](j.)}(h``unsigned char *cmd``h]j4)}(hj ah]hunsigned char *cmd}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj aubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhjaubjJ)}(hhh]h)}(hSCSI command to checkh]hSCSI command to check}(hj%ahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!ahMhj"aubah}(h]h ]h"]h$]h&]uh1jIhjaubeh}(h]h ]h"]h$]h&]uh1j'hj!ahMhjaubj()}(hG``bool open_for_write`` is the file / block device opened for writing? h](j.)}(h``bool open_for_write``h]j4)}(hjEah]hbool open_for_write}(hjGahhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjCaubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhj?aubjJ)}(hhh]h)}(h.is the file / block device opened for writing?h]h.is the file / block device opened for writing?}(hj^ahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZahMhj[aubah}(h]h ]h"]h$]h&]uh1jIhj?aubeh}(h]h ]h"]h$]h&]uh1j'hjZahMhjaubeh}(h]h ]h"]h$]h&]uh1j"hj`ubh)}(h**Description**h]j)}(hjah]h Description}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~aubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhj`ubh)}(hOnly a subset of commands are allowed for unprivileged users. Commands used to format the media, update the firmware, etc. are not permitted.h]hOnly a subset of commands are allowed for unprivileged users. Commands used to format the media, update the firmware, etc. are not permitted.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhj`ubh)}(h **Return**h]j)}(hjah]hReturn}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chM hj`ubh)}(h4``true`` if the cmd is allowed, otherwise **false**.h](j4)}(h``true``h]htrue}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjaubh" if the cmd is allowed, otherwise }(hjahhhNhNubj)}(h **false**h]hfalse}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubh.}(hjahhhNhNubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chM hj`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj:]hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_ioctl (C function) c.scsi_ioctlhNtauh1j3hj:]hhhNhNubjE)}(hhh](jJ)}(hYint scsi_ioctl (struct scsi_device *sdev, bool open_for_write, int cmd, void __user *arg)h]jP)}(hXint scsi_ioctl(struct scsi_device *sdev, bool open_for_write, int cmd, void __user *arg)h](j~)}(hinth]hint}(hj bhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjbhhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMeubjh)}(h h]h }(hjbhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjbhhhjbhMeubjy)}(h scsi_ioctlh]j)}(h scsi_ioctlh]h scsi_ioctl}(hj-bhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj)bubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjbhhhjbhMeubj)}(hJ(struct scsi_device *sdev, bool open_for_write, int cmd, void __user *arg)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjIbhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjEbubjh)}(h h]h }(hjVbhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjEbubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjgbhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjdbubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjibmodnameN classnameNjj)}j]j)}jj/bsb c.scsi_ioctlasbuh1hhjEbubjh)}(h h]h }(hjbhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjEbubj )}(hj h]h*}(hjbhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjEbubj)}(hsdevh]hsdev}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEbubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjAbubj)}(hbool open_for_writeh](j~)}(hjU.h]hbool}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjbubjh)}(h h]h }(hjbhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjbubj)}(hopen_for_writeh]hopen_for_write}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjbubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjAbubj)}(hint cmdh](j~)}(hinth]hint}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjbubjh)}(h h]h }(hjbhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjbubj)}(hcmdh]hcmd}(hj chhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjbubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjAbubj)}(hvoid __user *argh](j~)}(hvoidh]hvoid}(hj$chhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj cubjh)}(h h]h }(hj2chhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj cubh__user}(hj chhhNhNubjh)}(h h]h }(hjDchhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj cubj )}(hj h]h*}(hjRchhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj cubj)}(hargh]harg}(hj_chhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj cubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjAbubeh}(h]h ]h"]h$]h&]jjuh1jhjbhhhjbhMeubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjbhhhjbhMeubah}(h]jaah ](jjeh"]h$]h&]jj)jhuh1jIhjbhMehjbhhubj)}(hhh]h)}(hDispatch ioctl to scsi deviceh]hDispatch ioctl to scsi device}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMehjchhubah}(h]h ]h"]h$]h&]uh1jhjbhhhjbhMeubeh}(h]h ](jfunctioneh"]h$]h&]jjjjcjjcjjjuh1jDhhhj:]hNhNubj)}(hX**Parameters** ``struct scsi_device *sdev`` scsi device receiving ioctl ``bool open_for_write`` is the file / block device opened for writing? ``int cmd`` which ioctl is it ``void __user *arg`` data associated with ioctl **Description** The scsi_ioctl() function differs from most ioctls in that it does not take a major/minor number as the dev field. Rather, it takes a pointer to a :c:type:`struct scsi_device `. **Return** varies depending on the **cmd**h](h)}(h**Parameters**h]j)}(hjch]h Parameters}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMihjcubj#)}(hhh](j()}(h9``struct scsi_device *sdev`` scsi device receiving ioctl h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjch]hstruct scsi_device *sdev}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjcubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMfhjcubjJ)}(hhh]h)}(hscsi device receiving ioctlh]hscsi device receiving ioctl}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchMfhjcubah}(h]h ]h"]h$]h&]uh1jIhjcubeh}(h]h ]h"]h$]h&]uh1j'hjchMfhjcubj()}(hG``bool open_for_write`` is the file / block device opened for writing? h](j.)}(h``bool open_for_write``h]j4)}(hjdh]hbool open_for_write}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjdubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMghjcubjJ)}(hhh]h)}(h.is the file / block device opened for writing?h]h.is the file / block device opened for writing?}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhMghjdubah}(h]h ]h"]h$]h&]uh1jIhjcubeh}(h]h ]h"]h$]h&]uh1j'hjdhMghjcubj()}(h``int cmd`` which ioctl is it h](j.)}(h ``int cmd``h]j4)}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj:dubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhhj6dubjJ)}(hhh]h)}(hwhich ioctl is ith]hwhich ioctl is it}(hjUdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQdhMhhjRdubah}(h]h ]h"]h$]h&]uh1jIhj6dubeh}(h]h ]h"]h$]h&]uh1j'hjQdhMhhjcubj()}(h0``void __user *arg`` data associated with ioctl h](j.)}(h``void __user *arg``h]j4)}(hjudh]hvoid __user *arg}(hjwdhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjsdubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMihjodubjJ)}(hhh]h)}(hdata associated with ioctlh]hdata associated with ioctl}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhMihjdubah}(h]h ]h"]h$]h&]uh1jIhjodubeh}(h]h ]h"]h$]h&]uh1j'hjdhMihjcubeh}(h]h ]h"]h$]h&]uh1j"hjcubh)}(h**Description**h]j)}(hjdh]h Description}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMkhjcubh)}(hThe scsi_ioctl() function differs from most ioctls in that it does not take a major/minor number as the dev field. Rather, it takes a pointer to a :c:type:`struct scsi_device `.h](hThe scsi_ioctl() function differs from most ioctls in that it does not take a major/minor number as the dev field. Rather, it takes a pointer to a }(hjdhhhNhNubh)}(h*:c:type:`struct scsi_device `h]j4)}(hjdh]hstruct scsi_device}(hjdhhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hjdubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjj scsi_deviceuh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMkhjdubh.}(hjdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjdhMkhjcubh)}(h **Return**h]j)}(hjdh]hReturn}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMohjcubh)}(hvaries depending on the **cmd**h](hvaries depending on the }(hjehhhNhNubj)}(h**cmd**h]hcmd}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMohjcubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj:]hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@4scsi_ioctl_block_when_processing_errors (C function))c.scsi_ioctl_block_when_processing_errorshNtauh1j3hj:]hhhNhNubjE)}(hhh](jJ)}(h\int scsi_ioctl_block_when_processing_errors (struct scsi_device *sdev, int cmd, bool ndelay)h]jP)}(h[int scsi_ioctl_block_when_processing_errors(struct scsi_device *sdev, int cmd, bool ndelay)h](j~)}(hinth]hint}(hjMehhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjIehhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMubjh)}(h h]h }(hj\ehhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjIehhhj[ehMubjy)}(h'scsi_ioctl_block_when_processing_errorsh]j)}(h'scsi_ioctl_block_when_processing_errorsh]h'scsi_ioctl_block_when_processing_errors}(hjnehhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjjeubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjIehhhj[ehMubj)}(h0(struct scsi_device *sdev, int cmd, bool ndelay)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjeubjh)}(h h]h }(hjehhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjeubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjeubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjemodnameN classnameNjj)}j]j)}jjpesb)c.scsi_ioctl_block_when_processing_errorsasbuh1hhjeubjh)}(h h]h }(hjehhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjeubj )}(hj h]h*}(hjehhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjeubj)}(hsdevh]hsdev}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjeubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(hint cmdh](j~)}(hinth]hint}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjeubjh)}(h h]h }(hj fhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjeubj)}(hcmdh]hcmd}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjeubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(h bool ndelayh](j~)}(hjU.h]hbool}(hj1fhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj-fubjh)}(h h]h }(hj>fhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj-fubj)}(hndelayh]hndelay}(hjLfhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj-fubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubeh}(h]h ]h"]h$]h&]jjuh1jhjIehhhj[ehMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjEehhhj[ehMubah}(h]j@eah ](jjeh"]h$]h&]jj)jhuh1jIhj[ehMhjBehhubj)}(hhh]h)}(h"prevent commands from being queuedh]h"prevent commands from being queued}(hjvfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhjsfhhubah}(h]h ]h"]h$]h&]uh1jhjBehhhj[ehMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjfjjfjjjuh1jDhhhj:]hNhNubj)}(hX **Parameters** ``struct scsi_device *sdev`` target scsi device ``int cmd`` which ioctl is it ``bool ndelay`` no delay (non-blocking) **Description** We can process a reset even when a device isn't fully operable. **Return** ``0`` on success, <0 error code.h](h)}(h**Parameters**h]j)}(hjfh]h Parameters}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhjfubj#)}(hhh](j()}(h0``struct scsi_device *sdev`` target scsi device h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjfh]hstruct scsi_device *sdev}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjfubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhjfubjJ)}(hhh]h)}(htarget scsi deviceh]htarget scsi device}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjfubah}(h]h ]h"]h$]h&]uh1jIhjfubeh}(h]h ]h"]h$]h&]uh1j'hjfhMhjfubj()}(h``int cmd`` which ioctl is it h](j.)}(h ``int cmd``h]j4)}(hjfh]hint cmd}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjfubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhjfubjJ)}(hhh]h)}(hwhich ioctl is ith]hwhich ioctl is it}(hj ghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghMhjgubah}(h]h ]h"]h$]h&]uh1jIhjfubeh}(h]h ]h"]h$]h&]uh1j'hjghMhjfubj()}(h(``bool ndelay`` no delay (non-blocking) h](j.)}(h``bool ndelay``h]j4)}(hj)gh]h bool ndelay}(hj+ghhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj'gubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhj#gubjJ)}(hhh]h)}(hno delay (non-blocking)h]hno delay (non-blocking)}(hjBghhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>ghMhj?gubah}(h]h ]h"]h$]h&]uh1jIhj#gubeh}(h]h ]h"]h$]h&]uh1j'hj>ghMhjfubeh}(h]h ]h"]h$]h&]uh1j"hjfubh)}(h**Description**h]j)}(hjdgh]h Description}(hjfghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbgubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhjfubh)}(h?We can process a reset even when a device isn't fully operable.h]hAWe can process a reset even when a device isn’t fully operable.}(hjzghhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhjfubh)}(h **Return**h]j)}(hjgh]hReturn}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhjfubh)}(h ``0`` on success, <0 error code.h](j4)}(h``0``h]h0}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjgubh on success, <0 error code.}(hjghhhNhNubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:136: ./drivers/scsi/scsi_ioctl.chMhjfubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj:]hhhNhNubeh}(h]drivers-scsi-scsi-ioctl-cah ]h"]drivers/scsi/scsi_ioctl.cah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hdrivers/scsi/scsi_lib.ch]hdrivers/scsi/scsi_lib.c}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghhhhhKubh)}(hSCSI queuing library.h]hSCSI queuing library.}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjghhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@(scsi_failures_reset_retries (C function)c.scsi_failures_reset_retrieshNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hAvoid scsi_failures_reset_retries (struct scsi_failures *failures)h]jP)}(h@void scsi_failures_reset_retries(struct scsi_failures *failures)h](j~)}(hvoidh]hvoid}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chKubjh)}(h h]h }(hjhhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhhjhhKubjy)}(hscsi_failures_reset_retriesh]j)}(hscsi_failures_reset_retriesh]hscsi_failures_reset_retries}(hj&hhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj"hubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhhjhhKubj)}(h (struct scsi_failures *failures)h]j)}(hstruct scsi_failures *failuresh](jV)}(hjYh]hstruct}(hjBhhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>hubjh)}(h h]h }(hjOhhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>hubh)}(hhh]j)}(h scsi_failuresh]h scsi_failures}(hj`hhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj]hubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjbhmodnameN classnameNjj)}j]j)}jj(hsbc.scsi_failures_reset_retriesasbuh1hhj>hubjh)}(h h]h }(hjhhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>hubj )}(hj h]h*}(hjhhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj>hubj)}(hfailuresh]hfailures}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj>hubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:hubah}(h]h ]h"]h$]h&]jjuh1jhjhhhhjhhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjghhhjhhKubah}(h]jgah ](jjeh"]h$]h&]jj)jhuh1jIhjhhKhjghhubj)}(hhh]h)}(hreset all failures to zeroh]hreset all failures to zero}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chKhjhhhubah}(h]h ]h"]h$]h&]uh1jhjghhhjhhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjhjjhjjjuh1jDhhhjghNhNubj)}(h**Parameters** ``struct scsi_failures *failures`` :c:type:`struct scsi_failures ` with specific failure modes seth](h)}(h**Parameters**h]j)}(hjhh]h Parameters}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chKhjhubj#)}(hhh]j()}(hq``struct scsi_failures *failures`` :c:type:`struct scsi_failures ` with specific failure modes seth](j.)}(h"``struct scsi_failures *failures``h]j4)}(hjih]hstruct scsi_failures *failures}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjiubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chKhjiubjJ)}(hhh]h)}(hN:c:type:`struct scsi_failures ` with specific failure modes seth](h)}(h.:c:type:`struct scsi_failures `h]j4)}(hj%ih]hstruct scsi_failures}(hj'ihhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hj#iubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjj scsi_failuresuh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chKhjiubh with specific failure modes set}(hjihhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjBihKhjiubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j'hjihKhjhubah}(h]h ]h"]h$]h&]uh1j"hjhubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_execute_cmd (C function)c.scsi_execute_cmdhNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hint scsi_execute_cmd (struct scsi_device *sdev, const unsigned char *cmd, blk_opf_t opf, void *buffer, unsigned int bufflen, int timeout, int ml_retries, const struct scsi_exec_args *args)h]jP)}(hint scsi_execute_cmd(struct scsi_device *sdev, const unsigned char *cmd, blk_opf_t opf, void *buffer, unsigned int bufflen, int timeout, int ml_retries, const struct scsi_exec_args *args)h](j~)}(hinth]hint}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj{ihhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMubjh)}(h h]h }(hjihhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{ihhhjihMubjy)}(hscsi_execute_cmdh]j)}(hscsi_execute_cmdh]hscsi_execute_cmd}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjiubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj{ihhhjihMubj)}(h(struct scsi_device *sdev, const unsigned char *cmd, blk_opf_t opf, void *buffer, unsigned int bufflen, int timeout, int ml_retries, const struct scsi_exec_args *args)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjihhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjiubjh)}(h h]h }(hjihhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjiubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjiubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjimodnameN classnameNjj)}j]j)}jjisbc.scsi_execute_cmdasbuh1hhjiubjh)}(h h]h }(hjihhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjiubj )}(hj h]h*}(hjjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjiubj)}(hsdevh]hsdev}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjiubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubj)}(hconst unsigned char *cmdh](jV)}(hjNh]hconst}(hj.jhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj*jubjh)}(h h]h }(hj;jhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj*jubj~)}(hunsignedh]hunsigned}(hjIjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj*jubjh)}(h h]h }(hjWjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj*jubj~)}(hcharh]hchar}(hjejhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj*jubjh)}(h h]h }(hjsjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj*jubj )}(hj h]h*}(hjjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj*jubj)}(hcmdh]hcmd}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj*jubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubj)}(h blk_opf_t opfh](h)}(hhh]j)}(h blk_opf_th]h blk_opf_t}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjmodnameN classnameNjj)}j]jic.scsi_execute_cmdasbuh1hhjjubjh)}(h h]h }(hjjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjjubj)}(hopfh]hopf}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubj)}(h void *bufferh](j~)}(hvoidh]hvoid}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjjubjh)}(h h]h }(hjjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjjubj )}(hj h]h*}(hj khhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjjubj)}(hbufferh]hbuffer}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubj)}(hunsigned int bufflenh](j~)}(hunsignedh]hunsigned}(hj1khhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj-kubjh)}(h h]h }(hj?khhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj-kubj~)}(hinth]hint}(hjMkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj-kubjh)}(h h]h }(hj[khhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj-kubj)}(hbufflenh]hbufflen}(hjikhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj-kubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubj)}(h int timeouth](j~)}(hinth]hint}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj~kubjh)}(h h]h }(hjkhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~kubj)}(htimeouth]htimeout}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj~kubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubj)}(hint ml_retriesh](j~)}(hinth]hint}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1)j}hjkubjh)}(h h]h }(hjkhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjkubj)}(h ml_retriesh]h ml_retries}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjkubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubj)}(h!const struct scsi_exec_args *argsh](jV)}(hjNh]hconst}(hjkhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjkubjh)}(h h]h }(hjkhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjkubjV)}(hjYh]hstruct}(hjlhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjkubjh)}(h h]h }(hjlhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjkubh)}(hhh]j)}(hscsi_exec_argsh]hscsi_exec_args}(hj%lhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj"lubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj'lmodnameN classnameNjj)}j]jic.scsi_execute_cmdasbuh1hhjkubjh)}(h h]h }(hjClhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjkubj )}(hj h]h*}(hjQlhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjkubj)}(hargsh]hargs}(hj^lhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjkubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubeh}(h]h ]h"]h$]h&]jjuh1jhj{ihhhjihMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjwihhhjihMubah}(h]jriah ](jjeh"]h$]h&]jj)jhuh1jIhjihMhjtihhubj)}(hhh]h)}(h&insert request and wait for the resulth]h&insert request and wait for the result}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjlhhubah}(h]h ]h"]h$]h&]uh1jhjtihhhjihMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjljjljjjuh1jDhhhjghNhNubj)}(hXC**Parameters** ``struct scsi_device *sdev`` scsi_device ``const unsigned char *cmd`` scsi command ``blk_opf_t opf`` block layer request cmd_flags ``void *buffer`` data buffer ``unsigned int bufflen`` len of buffer ``int timeout`` request timeout in HZ ``int ml_retries`` number of times SCSI midlayer will retry request ``const struct scsi_exec_args *args`` Optional args. See struct definition for field descriptions **Description** Returns the scsi_cmnd result field if a command was executed, or a negative Linux error code if we didn't get that far.h](h)}(h**Parameters**h]j)}(hjlh]h Parameters}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjlubj#)}(hhh](j()}(h)``struct scsi_device *sdev`` scsi_device h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjlh]hstruct scsi_device *sdev}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjlubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjlubjJ)}(hhh]h)}(h scsi_deviceh]h scsi_device}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhjlubah}(h]h ]h"]h$]h&]uh1jIhjlubeh}(h]h ]h"]h$]h&]uh1j'hjlhMhjlubj()}(h*``const unsigned char *cmd`` scsi command h](j.)}(h``const unsigned char *cmd``h]j4)}(hjmh]hconst unsigned char *cmd}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjmubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjlubjJ)}(hhh]h)}(h scsi commandh]h scsi command}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhMhjmubah}(h]h ]h"]h$]h&]uh1jIhjlubeh}(h]h ]h"]h$]h&]uh1j'hjmhMhjlubj()}(h0``blk_opf_t opf`` block layer request cmd_flags h](j.)}(h``blk_opf_t opf``h]j4)}(hj;mh]h blk_opf_t opf}(hj=mhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj9mubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj5mubjJ)}(hhh]h)}(hblock layer request cmd_flagsh]hblock layer request cmd_flags}(hjTmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPmhMhjQmubah}(h]h ]h"]h$]h&]uh1jIhj5mubeh}(h]h ]h"]h$]h&]uh1j'hjPmhMhjlubj()}(h``void *buffer`` data buffer h](j.)}(h``void *buffer``h]j4)}(hjtmh]h void *buffer}(hjvmhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjrmubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjnmubjJ)}(hhh]h)}(h data bufferh]h data buffer}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhMhjmubah}(h]h ]h"]h$]h&]uh1jIhjnmubeh}(h]h ]h"]h$]h&]uh1j'hjmhMhjlubj()}(h'``unsigned int bufflen`` len of buffer h](j.)}(h``unsigned int bufflen``h]j4)}(hjmh]hunsigned int bufflen}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjmubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjmubjJ)}(hhh]h)}(h len of bufferh]h len of buffer}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhMhjmubah}(h]h ]h"]h$]h&]uh1jIhjmubeh}(h]h ]h"]h$]h&]uh1j'hjmhMhjlubj()}(h&``int timeout`` request timeout in HZ h](j.)}(h``int timeout``h]j4)}(hjmh]h int timeout}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjmubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjmubjJ)}(hhh]h)}(hrequest timeout in HZh]hrequest timeout in HZ}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhMhjmubah}(h]h ]h"]h$]h&]uh1jIhjmubeh}(h]h ]h"]h$]h&]uh1j'hjmhMhjlubj()}(hD``int ml_retries`` number of times SCSI midlayer will retry request h](j.)}(h``int ml_retries``h]j4)}(hjnh]hint ml_retries}(hj!nhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjnubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjnubjJ)}(hhh]h)}(h0number of times SCSI midlayer will retry requesth]h0number of times SCSI midlayer will retry request}(hj8nhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4nhM hj5nubah}(h]h ]h"]h$]h&]uh1jIhjnubeh}(h]h ]h"]h$]h&]uh1j'hj4nhM hjlubj()}(hb``const struct scsi_exec_args *args`` Optional args. See struct definition for field descriptions h](j.)}(h%``const struct scsi_exec_args *args``h]j4)}(hjXnh]h!const struct scsi_exec_args *args}(hjZnhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjVnubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM!hjRnubjJ)}(hhh]h)}(h;Optional args. See struct definition for field descriptionsh]h;Optional args. See struct definition for field descriptions}(hjqnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmnhM!hjnnubah}(h]h ]h"]h$]h&]uh1jIhjRnubeh}(h]h ]h"]h$]h&]uh1j'hjmnhM!hjlubeh}(h]h ]h"]h$]h&]uh1j"hjlubh)}(h**Description**h]j)}(hjnh]h Description}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM#hjlubh)}(hwReturns the scsi_cmnd result field if a command was executed, or a negative Linux error code if we didn't get that far.h]hyReturns the scsi_cmnd result field if a command was executed, or a negative Linux error code if we didn’t get that far.}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM#hjlubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@ scsi_alloc_sgtables (C function)c.scsi_alloc_sgtableshNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(h8blk_status_t scsi_alloc_sgtables (struct scsi_cmnd *cmd)h]jP)}(h7blk_status_t scsi_alloc_sgtables(struct scsi_cmnd *cmd)h](h)}(hhh]j)}(h blk_status_th]h blk_status_t}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjnubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjnmodnameN classnameNjj)}j]j)}jscsi_alloc_sgtablessbc.scsi_alloc_sgtablesasbuh1hhjnhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMUubjh)}(h h]h }(hjnhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjnhhhjnhMUubjy)}(hscsi_alloc_sgtablesh]j)}(hjnh]hscsi_alloc_sgtables}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj oubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjnhhhjnhMUubj)}(h(struct scsi_cmnd *cmd)h]j)}(hstruct scsi_cmnd *cmdh](jV)}(hjYh]hstruct}(hj*ohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&oubjh)}(h h]h }(hj7ohhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj&oubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hjHohhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEoubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjJomodnameN classnameNjj)}j]jnc.scsi_alloc_sgtablesasbuh1hhj&oubjh)}(h h]h }(hjfohhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj&oubj )}(hj h]h*}(hjtohhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj&oubj)}(hcmdh]hcmd}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj&oubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"oubah}(h]h ]h"]h$]h&]jjuh1jhjnhhhjnhMUubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjnhhhjnhMUubah}(h]jnah ](jjeh"]h$]h&]jj)jhuh1jIhjnhMUhjnhhubj)}(hhh]h)}(h7Allocate and initialize data and integrity scatterlistsh]h7Allocate and initialize data and integrity scatterlists}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMUhjohhubah}(h]h ]h"]h$]h&]uh1jhjnhhhjnhMUubeh}(h]h ](jfunctioneh"]h$]h&]jjjjojjojjjuh1jDhhhjghNhNubj)}(hXQ**Parameters** ``struct scsi_cmnd *cmd`` SCSI command data structure to initialize. **Description** Initializes **cmd->sdb** and also **cmd->prot_sdb** if data integrity is enabled for **cmd**. **Return** * BLK_STS_OK - on success * BLK_STS_RESOURCE - if the failure is retryable * BLK_STS_IOERR - if the failure is fatalh](h)}(h**Parameters**h]j)}(hjoh]h Parameters}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMYhjoubj#)}(hhh]j()}(hE``struct scsi_cmnd *cmd`` SCSI command data structure to initialize. h](j.)}(h``struct scsi_cmnd *cmd``h]j4)}(hjoh]hstruct scsi_cmnd *cmd}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjoubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMVhjoubjJ)}(hhh]h)}(h*SCSI command data structure to initialize.h]h*SCSI command data structure to initialize.}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphMVhjpubah}(h]h ]h"]h$]h&]uh1jIhjoubeh}(h]h ]h"]h$]h&]uh1j'hjphMVhjoubah}(h]h ]h"]h$]h&]uh1j"hjoubh)}(h**Description**h]j)}(hj'ph]h Description}(hj)phhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%pubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMXhjoubh)}(h]Initializes **cmd->sdb** and also **cmd->prot_sdb** if data integrity is enabled for **cmd**.h](h Initializes }(hj=phhhNhNubj)}(h **cmd->sdb**h]hcmd->sdb}(hjEphhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=pubh and also }(hj=phhhNhNubj)}(h**cmd->prot_sdb**h]h cmd->prot_sdb}(hjWphhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=pubh" if data integrity is enabled for }(hj=phhhNhNubj)}(h**cmd**h]hcmd}(hjiphhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=pubh.}(hj=phhhNhNubeh}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMXhjoubh)}(h **Return**h]j)}(hjph]hReturn}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM[hjoubj3_)}(hhh](j8_)}(hBLK_STS_OK - on successh]h)}(hjph]hBLK_STS_OK - on success}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM[hjpubah}(h]h ]h"]h$]h&]uh1j7_hjpubj8_)}(h.BLK_STS_RESOURCE - if the failure is retryableh]h)}(hjph]h.BLK_STS_RESOURCE - if the failure is retryable}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM\hjpubah}(h]h ]h"]h$]h&]uh1j7_hjpubj8_)}(h*BLK_STS_IOERR - if the failure is fatalh]h)}(hjph]h*BLK_STS_IOERR - if the failure is fatal}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM]hjpubah}(h]h ]h"]h$]h&]uh1j7_hjpubeh}(h]h ]h"]h$]h&]j_j uh1j2_hjphM[hjoubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_alloc_request (C function)c.scsi_alloc_requesthNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hfstruct request * scsi_alloc_request (struct request_queue *q, blk_opf_t opf, blk_mq_req_flags_t flags)h]jP)}(hdstruct request *scsi_alloc_request(struct request_queue *q, blk_opf_t opf, blk_mq_req_flags_t flags)h](jV)}(hjYh]hstruct}(hj qhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMubjh)}(h h]h }(hjqhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjqhhhjqhMubh)}(hhh]j)}(hrequesth]hrequest}(hj*qhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj'qubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj,qmodnameN classnameNjj)}j]j)}jscsi_alloc_requestsbc.scsi_alloc_requestasbuh1hhjqhhhjqhMubjh)}(h h]h }(hjKqhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjqhhhjqhMubj )}(hj h]h*}(hjYqhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjqhhhjqhMubjy)}(hscsi_alloc_requesth]j)}(hjHqh]hscsi_alloc_request}(hjjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjfqubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjqhhhjqhMubj)}(hB(struct request_queue *q, blk_opf_t opf, blk_mq_req_flags_t flags)h](j)}(hstruct request_queue *qh](jV)}(hjYh]hstruct}(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubjh)}(h h]h }(hjqhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjqubh)}(hhh]j)}(h request_queueh]h request_queue}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjqubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqmodnameN classnameNjj)}j]jFqc.scsi_alloc_requestasbuh1hhjqubjh)}(h h]h }(hjqhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjqubj )}(hj h]h*}(hjqhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjqubj)}(hqh]hq}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjqubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj}qubj)}(h blk_opf_t opfh](h)}(hhh]j)}(h blk_opf_th]h blk_opf_t}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjqubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqmodnameN classnameNjj)}j]jFqc.scsi_alloc_requestasbuh1hhjqubjh)}(h h]h }(hjrhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjqubj)}(hopfh]hopf}(hj$rhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjqubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj}qubj)}(hblk_mq_req_flags_t flagsh](h)}(hhh]j)}(hblk_mq_req_flags_th]hblk_mq_req_flags_t}(hj@rhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj=rubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjBrmodnameN classnameNjj)}j]jFqc.scsi_alloc_requestasbuh1hhj9rubjh)}(h h]h }(hj^rhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj9rubj)}(hflagsh]hflags}(hjlrhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj9rubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj}qubeh}(h]h ]h"]h$]h&]jjuh1jhjqhhhjqhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjqhhhjqhMubah}(h]jpah ](jjeh"]h$]h&]jj)jhuh1jIhjqhMhjqhhubj)}(hhh]h)}(hIallocate a block request and partially initialize its :c:type:`scsi_cmnd`h](h6allocate a block request and partially initialize its }(hjrhhhNhNubh)}(h:c:type:`scsi_cmnd`h]j4)}(hjrh]h scsi_cmnd}(hjrhhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hjrubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjj)}j]jFqc.scsi_alloc_requestasbj scsi_cmnduh1hhjhhKhjrubeh}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjrhhubah}(h]h ]h"]h$]h&]uh1jhjqhhhjqhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjrjjrjjjuh1jDhhhjghNhNubj)}(hX**Parameters** ``struct request_queue *q`` the device's request queue ``blk_opf_t opf`` the request operation code ``blk_mq_req_flags_t flags`` block layer allocation flags **Return** :c:type:`struct request ` pointer on success or ``NULL`` on failureh](h)}(h**Parameters**h]j)}(hjrh]h Parameters}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjrubj#)}(hhh](j()}(h7``struct request_queue *q`` the device's request queue h](j.)}(h``struct request_queue *q``h]j4)}(hjrh]hstruct request_queue *q}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjrubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjrubjJ)}(hhh]h)}(hthe device's request queueh]hthe device’s request queue}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshMhjsubah}(h]h ]h"]h$]h&]uh1jIhjrubeh}(h]h ]h"]h$]h&]uh1j'hjshMhjrubj()}(h-``blk_opf_t opf`` the request operation code h](j.)}(h``blk_opf_t opf``h]j4)}(hj4sh]h blk_opf_t opf}(hj6shhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj2subah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj.subjJ)}(hhh]h)}(hthe request operation codeh]hthe request operation code}(hjMshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIshMhjJsubah}(h]h ]h"]h$]h&]uh1jIhj.subeh}(h]h ]h"]h$]h&]uh1j'hjIshMhjrubj()}(h:``blk_mq_req_flags_t flags`` block layer allocation flags h](j.)}(h``blk_mq_req_flags_t flags``h]j4)}(hjmsh]hblk_mq_req_flags_t flags}(hjoshhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjksubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjgsubjJ)}(hhh]h)}(hblock layer allocation flagsh]hblock layer allocation flags}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshMhjsubah}(h]h ]h"]h$]h&]uh1jIhjgsubeh}(h]h ]h"]h$]h&]uh1j'hjshMhjrubeh}(h]h ]h"]h$]h&]uh1j"hjrubh)}(h **Return**h]j)}(hjsh]hReturn}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjrubh)}(hL:c:type:`struct request ` pointer on success or ``NULL`` on failureh](h)}(h":c:type:`struct request `h]j4)}(hjsh]hstruct request}(hjshhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hjsubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjjrequestuh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjsubh pointer on success or }(hjshhhNhNubj4)}(h``NULL``h]hNULL}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjsubh on failure}(hjshhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjshMhjrubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@#scsi_device_from_queue (C function)c.scsi_device_from_queuehNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hEstruct scsi_device * scsi_device_from_queue (struct request_queue *q)h]jP)}(hCstruct scsi_device *scsi_device_from_queue(struct request_queue *q)h](jV)}(hjYh]hstruct}(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjthhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM>ubjh)}(h h]h }(hj,thhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjthhhj+thM>ubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj=thhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj:tubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj?tmodnameN classnameNjj)}j]j)}jscsi_device_from_queuesbc.scsi_device_from_queueasbuh1hhjthhhj+thM>ubjh)}(h h]h }(hj^thhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjthhhj+thM>ubj )}(hj h]h*}(hjlthhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjthhhj+thM>ubjy)}(hscsi_device_from_queueh]j)}(hj[th]hscsi_device_from_queue}(hj}thhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjytubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjthhhj+thM>ubj)}(h(struct request_queue *q)h]j)}(hstruct request_queue *qh](jV)}(hjYh]hstruct}(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjtubjh)}(h h]h }(hjthhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjtubh)}(hhh]j)}(h request_queueh]h request_queue}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjtubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjtmodnameN classnameNjj)}j]jYtc.scsi_device_from_queueasbuh1hhjtubjh)}(h h]h }(hjthhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjtubj )}(hj h]h*}(hjthhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjtubj)}(hjqh]hq}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjtubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjtubah}(h]h ]h"]h$]h&]jjuh1jhjthhhj+thM>ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjthhhj+thM>ubah}(h]jtah ](jjeh"]h$]h&]jj)jhuh1jIhj+thM>hjthhubj)}(hhh]h)}(h+return sdev associated with a request_queueh]h+return sdev associated with a request_queue}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM>hjuhhubah}(h]h ]h"]h$]h&]uh1jhjthhhj+thM>ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj0ujj0ujjjuh1jDhhhjghNhNubj)}(h**Parameters** ``struct request_queue *q`` The request queue to return the sdev from **Description** Return the sdev associated with a request queue or NULL if the request_queue does not reference a SCSI device.h](h)}(h**Parameters**h]j)}(hj:uh]h Parameters}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:xubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMlhj6xubj#)}(hhh]j()}(h-``struct Scsi_Host *shost`` host in question h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj[xh]hstruct Scsi_Host *shost}(hj]xhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjYxubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMjhjUxubjJ)}(hhh]h)}(hhost in questionh]hhost in question}(hjtxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjpxhMjhjqxubah}(h]h ]h"]h$]h&]uh1jIhjUxubeh}(h]h ]h"]h$]h&]uh1j'hjpxhMjhjRxubah}(h]h ]h"]h$]h&]uh1j"hj6xubh)}(h**Description**h]j)}(hjxh]h Description}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMlhj6xubh)}(hX#There is no timer nor any other means by which the requests get unblocked other than the low-level driver calling scsi_unblock_requests(). This is done as an API function so that changes to the internals of the scsi mid-layer won't require wholesale changes to drivers that use this feature.h]hX%There is no timer nor any other means by which the requests get unblocked other than the low-level driver calling scsi_unblock_requests(). This is done as an API function so that changes to the internals of the scsi mid-layer won’t require wholesale changes to drivers that use this feature.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMlhj6xubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_mode_select (C function)c.scsi_mode_selecthNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hint scsi_mode_select (struct scsi_device *sdev, int pf, int sp, unsigned char *buffer, int len, int timeout, int retries, struct scsi_mode_data *data, struct scsi_sense_hdr *sshdr)h]jP)}(hint scsi_mode_select(struct scsi_device *sdev, int pf, int sp, unsigned char *buffer, int len, int timeout, int retries, struct scsi_mode_data *data, struct scsi_sense_hdr *sshdr)h](j~)}(hinth]hint}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjxhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM~ubjh)}(h h]h }(hjxhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjxhhhjxhM~ubjy)}(hscsi_mode_selecth]j)}(hscsi_mode_selecth]hscsi_mode_select}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjxubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjxhhhjxhM~ubj)}(h(struct scsi_device *sdev, int pf, int sp, unsigned char *buffer, int len, int timeout, int retries, struct scsi_mode_data *data, struct scsi_sense_hdr *sshdr)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubjh)}(h h]h }(hj%yhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjyubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj6yhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj3yubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj8ymodnameN classnameNjj)}j]j)}jjxsbc.scsi_mode_selectasbuh1hhjyubjh)}(h h]h }(hjVyhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjyubj )}(hj h]h*}(hjdyhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjyubj)}(hsdevh]hsdev}(hjqyhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubj)}(hint pfh](j~)}(hinth]hint}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjyubjh)}(h h]h }(hjyhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjyubj)}(hpfh]hpf}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubj)}(hint sph](j~)}(hinth]hint}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjyubjh)}(h h]h }(hjyhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjyubj)}(hsph]hsp}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubj)}(hunsigned char *bufferh](j~)}(hunsignedh]hunsigned}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjyubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjyubj~)}(hcharh]hchar}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjyubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjyubj )}(hj h]h*}(hj,zhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjyubj)}(hbufferh]hbuffer}(hj9zhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubj)}(hint lenh](j~)}(hinth]hint}(hjRzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjNzubjh)}(h h]h }(hj`zhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjNzubj)}(hlenh]hlen}(hjnzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjNzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubj)}(h int timeouth](j~)}(hinth]hint}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjzubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjzubj)}(htimeouth]htimeout}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubj)}(h int retriesh](j~)}(hinth]hint}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjzubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjzubj)}(hretriesh]hretries}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubj)}(hstruct scsi_mode_data *datah](jV)}(hjYh]hstruct}(hjzhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjzubh)}(hhh]j)}(hscsi_mode_datah]hscsi_mode_data}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj {ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj{modnameN classnameNjj)}j]jRyc.scsi_mode_selectasbuh1hhjzubjh)}(h h]h }(hj-{hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjzubj )}(hj h]h*}(hj;{hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjzubj)}(hdatah]hdata}(hjH{hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubj)}(hstruct scsi_sense_hdr *sshdrh](jV)}(hjYh]hstruct}(hja{hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]{ubjh)}(h h]h }(hjn{hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj]{ubh)}(hhh]j)}(hscsi_sense_hdrh]hscsi_sense_hdr}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj|{ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj{modnameN classnameNjj)}j]jRyc.scsi_mode_selectasbuh1hhj]{ubjh)}(h h]h }(hj{hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj]{ubj )}(hj h]h*}(hj{hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj]{ubj)}(hsshdrh]hsshdr}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj]{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubeh}(h]h ]h"]h$]h&]jjuh1jhjxhhhjxhM~ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjxhhhjxhM~ubah}(h]jxah ](jjeh"]h$]h&]jj)jhuh1jIhjxhM~hjxhhubj)}(hhh]h)}(hissue a mode selecth]hissue a mode select}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM~hj{hhubah}(h]h ]h"]h$]h&]uh1jhjxhhhjxhM~ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj{jj{jjjuh1jDhhhjghNhNubj)}(hX**Parameters** ``struct scsi_device *sdev`` SCSI device to be queried ``int pf`` Page format bit (1 == standard, 0 == vendor specific) ``int sp`` Save page bit (0 == don't save, 1 == save) ``unsigned char *buffer`` request buffer (may not be smaller than eight bytes) ``int len`` length of request buffer. ``int timeout`` command timeout ``int retries`` number of retries before failing ``struct scsi_mode_data *data`` returns a structure abstracting the mode header data ``struct scsi_sense_hdr *sshdr`` place to put sense data (or NULL if no sense to be collected). must be SCSI_SENSE_BUFFERSIZE big. Returns zero if successful; negative error number or scsi status on errorh](h)}(h**Parameters**h]j)}(hj|h]h Parameters}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj{ubj#)}(hhh](j()}(h7``struct scsi_device *sdev`` SCSI device to be queried h](j.)}(h``struct scsi_device *sdev``h]j4)}(hj#|h]hstruct scsi_device *sdev}(hj%|hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj!|ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj|ubjJ)}(hhh]h)}(hSCSI device to be queriedh]hSCSI device to be queried}(hj<|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8|hMhj9|ubah}(h]h ]h"]h$]h&]uh1jIhj|ubeh}(h]h ]h"]h$]h&]uh1j'hj8|hMhj|ubj()}(hA``int pf`` Page format bit (1 == standard, 0 == vendor specific) h](j.)}(h ``int pf``h]j4)}(hj\|h]hint pf}(hj^|hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjZ|ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjV|ubjJ)}(hhh]h)}(h5Page format bit (1 == standard, 0 == vendor specific)h]h5Page format bit (1 == standard, 0 == vendor specific)}(hju|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjq|hMhjr|ubah}(h]h ]h"]h$]h&]uh1jIhjV|ubeh}(h]h ]h"]h$]h&]uh1j'hjq|hMhj|ubj()}(h6``int sp`` Save page bit (0 == don't save, 1 == save) h](j.)}(h ``int sp``h]j4)}(hj|h]hint sp}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj|ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj|ubjJ)}(hhh]h)}(h*Save page bit (0 == don't save, 1 == save)h]h,Save page bit (0 == don’t save, 1 == save)}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMhj|ubah}(h]h ]h"]h$]h&]uh1jIhj|ubeh}(h]h ]h"]h$]h&]uh1j'hj|hMhj|ubj()}(hO``unsigned char *buffer`` request buffer (may not be smaller than eight bytes) h](j.)}(h``unsigned char *buffer``h]j4)}(hj|h]hunsigned char *buffer}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj|ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj|ubjJ)}(hhh]h)}(h4request buffer (may not be smaller than eight bytes)h]h4request buffer (may not be smaller than eight bytes)}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMhj|ubah}(h]h ]h"]h$]h&]uh1jIhj|ubeh}(h]h ]h"]h$]h&]uh1j'hj|hMhj|ubj()}(h&``int len`` length of request buffer. h](j.)}(h ``int len``h]j4)}(hj}h]hint len}(hj }hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj}ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj}ubjJ)}(hhh]h)}(hlength of request buffer.h]hlength of request buffer.}(hj }hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hMhj}ubah}(h]h ]h"]h$]h&]uh1jIhj}ubeh}(h]h ]h"]h$]h&]uh1j'hj}hMhj|ubj()}(h ``int timeout`` command timeout h](j.)}(h``int timeout``h]j4)}(hj@}h]h int timeout}(hjB}hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj>}ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj:}ubjJ)}(hhh]h)}(hcommand timeouth]hcommand timeout}(hjY}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjU}hMhjV}ubah}(h]h ]h"]h$]h&]uh1jIhj:}ubeh}(h]h ]h"]h$]h&]uh1j'hjU}hMhj|ubj()}(h1``int retries`` number of retries before failing h](j.)}(h``int retries``h]j4)}(hjy}h]h int retries}(hj{}hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjw}ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjs}ubjJ)}(hhh]h)}(h number of retries before failingh]h number of retries before failing}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hMhj}ubah}(h]h ]h"]h$]h&]uh1jIhjs}ubeh}(h]h ]h"]h$]h&]uh1j'hj}hMhj|ubj()}(hU``struct scsi_mode_data *data`` returns a structure abstracting the mode header data h](j.)}(h``struct scsi_mode_data *data``h]j4)}(hj}h]hstruct scsi_mode_data *data}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj}ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj}ubjJ)}(hhh]h)}(h4returns a structure abstracting the mode header datah]h4returns a structure abstracting the mode header data}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hMhj}ubah}(h]h ]h"]h$]h&]uh1jIhj}ubeh}(h]h ]h"]h$]h&]uh1j'hj}hMhj|ubj()}(h``struct scsi_sense_hdr *sshdr`` place to put sense data (or NULL if no sense to be collected). must be SCSI_SENSE_BUFFERSIZE big. Returns zero if successful; negative error number or scsi status on errorh](j.)}(h ``struct scsi_sense_hdr *sshdr``h]j4)}(hj}h]hstruct scsi_sense_hdr *sshdr}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj}ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj}ubjJ)}(hhh](h)}(haplace to put sense data (or NULL if no sense to be collected). must be SCSI_SENSE_BUFFERSIZE big.h]haplace to put sense data (or NULL if no sense to be collected). must be SCSI_SENSE_BUFFERSIZE big.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj~ubh)}(hIReturns zero if successful; negative error number or scsi status on errorh]hIReturns zero if successful; negative error number or scsi status on error}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hMhj~ubeh}(h]h ]h"]h$]h&]uh1jIhj}ubeh}(h]h ]h"]h$]h&]uh1j'hj~hMhj|ubeh}(h]h ]h"]h$]h&]uh1j"hj{ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_mode_sense (C function)c.scsi_mode_sensehNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hint scsi_mode_sense (struct scsi_device *sdev, int dbd, int modepage, int subpage, unsigned char *buffer, int len, int timeout, int retries, struct scsi_mode_data *data, struct scsi_sense_hdr *sshdr)h]jP)}(hint scsi_mode_sense(struct scsi_device *sdev, int dbd, int modepage, int subpage, unsigned char *buffer, int len, int timeout, int retries, struct scsi_mode_data *data, struct scsi_sense_hdr *sshdr)h](j~)}(hinth]hint}(hjS~hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjO~hhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMubjh)}(h h]h }(hjb~hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjO~hhhja~hMubjy)}(hscsi_mode_senseh]j)}(hscsi_mode_senseh]hscsi_mode_sense}(hjt~hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjp~ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjO~hhhja~hMubj)}(h(struct scsi_device *sdev, int dbd, int modepage, int subpage, unsigned char *buffer, int len, int timeout, int retries, struct scsi_mode_data *data, struct scsi_sense_hdr *sshdr)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubjh)}(h h]h }(hj~hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~ubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj~hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj~ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj~modnameN classnameNjj)}j]j)}jjv~sbc.scsi_mode_senseasbuh1hhj~ubjh)}(h h]h }(hj~hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~ubj )}(hj h]h*}(hj~hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj~ubj)}(hsdevh]hsdev}(hj~hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(hint dbdh](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj~ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~ubj)}(hdbdh]hdbd}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(h int modepageh](j~)}(hinth]hint}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj3ubjh)}(h h]h }(hjEhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj3ubj)}(hmodepageh]hmodepage}(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj3ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(h int subpageh](j~)}(hinth]hint}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhubj)}(hsubpageh]hsubpage}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjhubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(hunsigned char *bufferh](j~)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj~)}(hcharh]hchar}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hbufferh]hbuffer}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(hint lenh](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hlenh]hlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(h int timeouth](j~)}(hinth]hint}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj0ubjh)}(h h]h }(hjBhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj0ubj)}(htimeouth]htimeout}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj0ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(h int retriesh](j~)}(hinth]hint}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjeubjh)}(h h]h }(hjwhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjeubj)}(hretriesh]hretries}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjeubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(hstruct scsi_mode_data *datah](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hscsi_mode_datah]hscsi_mode_data}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j~c.scsi_mode_senseasbuh1hhjubjh)}(h h]h }(hjڀhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hdatah]hdata}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(hstruct scsi_sense_hdr *sshdrh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubh)}(hhh]j)}(hscsi_sense_hdrh]hscsi_sense_hdr}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj.modnameN classnameNjj)}j]j~c.scsi_mode_senseasbuh1hhj ubjh)}(h h]h }(hjJhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj )}(hj h]h*}(hjXhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj ubj)}(hsshdrh]hsshdr}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubeh}(h]h ]h"]h$]h&]jjuh1jhjO~hhhja~hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjK~hhhja~hMubah}(h]jF~ah ](jjeh"]h$]h&]jj)jhuh1jIhja~hMhjH~hhubj)}(hhh]h)}(hCissue a mode sense, falling back from 10 to six bytes if necessary.h]hCissue a mode sense, falling back from 10 to six bytes if necessary.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjH~hhhja~hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjghNhNubj)}(hX**Parameters** ``struct scsi_device *sdev`` SCSI device to be queried ``int dbd`` set to prevent mode sense from returning block descriptors ``int modepage`` mode page being requested ``int subpage`` sub-page of the mode page being requested ``unsigned char *buffer`` request buffer (may not be smaller than eight bytes) ``int len`` length of request buffer. ``int timeout`` command timeout ``int retries`` number of retries before failing ``struct scsi_mode_data *data`` returns a structure abstracting the mode header data ``struct scsi_sense_hdr *sshdr`` place to put sense data (or NULL if no sense to be collected). must be SCSI_SENSE_BUFFERSIZE big. Returns zero if successful, or a negative error number on failureh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjubj#)}(hhh](j()}(h7``struct scsi_device *sdev`` SCSI device to be queried h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjЁh]hstruct scsi_device *sdev}(hjҁhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj΁ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjʁubjJ)}(hhh]h)}(hSCSI device to be queriedh]hSCSI device to be queried}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjʁubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjǁubj()}(hG``int dbd`` set to prevent mode sense from returning block descriptors h](j.)}(h ``int dbd``h]j4)}(hj h]hint dbd}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjubjJ)}(hhh]h)}(h:set to prevent mode sense from returning block descriptorsh]h:set to prevent mode sense from returning block descriptors}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjǁubj()}(h+``int modepage`` mode page being requested h](j.)}(h``int modepage``h]j4)}(hjBh]h int modepage}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj@ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj<ubjJ)}(hhh]h)}(hmode page being requestedh]hmode page being requested}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhMhjXubah}(h]h ]h"]h$]h&]uh1jIhj<ubeh}(h]h ]h"]h$]h&]uh1j'hjWhMhjǁubj()}(h:``int subpage`` sub-page of the mode page being requested h](j.)}(h``int subpage``h]j4)}(hj{h]h int subpage}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjyubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjuubjJ)}(hhh]h)}(h)sub-page of the mode page being requestedh]h)sub-page of the mode page being requested}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjuubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjǁubj()}(hO``unsigned char *buffer`` request buffer (may not be smaller than eight bytes) h](j.)}(h``unsigned char *buffer``h]j4)}(hjh]hunsigned char *buffer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjubjJ)}(hhh]h)}(h4request buffer (may not be smaller than eight bytes)h]h4request buffer (may not be smaller than eight bytes)}(hj͂hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjɂhMhjʂubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjɂhMhjǁubj()}(h&``int len`` length of request buffer. h](j.)}(h ``int len``h]j4)}(hjh]hint len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjubjJ)}(hhh]h)}(hlength of request buffer.h]hlength of request buffer.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjǁubj()}(h ``int timeout`` command timeout h](j.)}(h``int timeout``h]j4)}(hj&h]h int timeout}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj$ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj ubjJ)}(hhh]h)}(hcommand timeouth]hcommand timeout}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;hMhj<ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj;hMhjǁubj()}(h1``int retries`` number of retries before failing h](j.)}(h``int retries``h]j4)}(hj_h]h int retries}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj]ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjYubjJ)}(hhh]h)}(h number of retries before failingh]h number of retries before failing}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthMhjuubah}(h]h ]h"]h$]h&]uh1jIhjYubeh}(h]h ]h"]h$]h&]uh1j'hjthMhjǁubj()}(hU``struct scsi_mode_data *data`` returns a structure abstracting the mode header data h](j.)}(h``struct scsi_mode_data *data``h]j4)}(hjh]hstruct scsi_mode_data *data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjubjJ)}(hhh]h)}(h4returns a structure abstracting the mode header datah]h4returns a structure abstracting the mode header data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjǁubj()}(h``struct scsi_sense_hdr *sshdr`` place to put sense data (or NULL if no sense to be collected). must be SCSI_SENSE_BUFFERSIZE big. Returns zero if successful, or a negative error number on failureh](j.)}(h ``struct scsi_sense_hdr *sshdr``h]j4)}(hjуh]hstruct scsi_sense_hdr *sshdr}(hjӃhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjσubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhj˃ubjJ)}(hhh](h)}(haplace to put sense data (or NULL if no sense to be collected). must be SCSI_SENSE_BUFFERSIZE big.h]haplace to put sense data (or NULL if no sense to be collected). must be SCSI_SENSE_BUFFERSIZE big.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjubh)}(hAReturns zero if successful, or a negative error number on failureh]hAReturns zero if successful, or a negative error number on failure}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMhjubeh}(h]h ]h"]h$]h&]uh1jIhj˃ubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjǁubeh}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!scsi_test_unit_ready (C function)c.scsi_test_unit_readyhNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hkint scsi_test_unit_ready (struct scsi_device *sdev, int timeout, int retries, struct scsi_sense_hdr *sshdr)h]jP)}(hjint scsi_test_unit_ready(struct scsi_device *sdev, int timeout, int retries, struct scsi_sense_hdr *sshdr)h](j~)}(hinth]hint}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj6hhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMV ubjh)}(h h]h }(hjIhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj6hhhjHhMV ubjy)}(hscsi_test_unit_readyh]j)}(hscsi_test_unit_readyh]hscsi_test_unit_ready}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjWubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj6hhhjHhMV ubj)}(hR(struct scsi_device *sdev, int timeout, int retries, struct scsi_sense_hdr *sshdr)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjwhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjsubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjsubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jj]sbc.scsi_test_unit_readyasbuh1hhjsubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjsubj )}(hj h]h*}(hjÄhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjsubj)}(hsdevh]hsdev}(hjЄhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjsubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjoubj)}(h int timeouth](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(htimeouth]htimeout}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjoubj)}(h int retriesh](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hj,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hretriesh]hretries}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjoubj)}(hstruct scsi_sense_hdr *sshdrh](jV)}(hjYh]hstruct}(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjOubjh)}(h h]h }(hj`hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjOubh)}(hhh]j)}(hscsi_sense_hdrh]hscsi_sense_hdr}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjnubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjsmodnameN classnameNjj)}j]jc.scsi_test_unit_readyasbuh1hhjOubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjOubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjOubj)}(hsshdrh]hsshdr}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjOubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjoubeh}(h]h ]h"]h$]h&]jjuh1jhj6hhhjHhMV ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj2hhhjHhMV ubah}(h]j-ah ](jjeh"]h$]h&]jj)jhuh1jIhjHhMV hj/hhubj)}(hhh]h)}(htest if unit is readyh]htest if unit is ready}(hjԅhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMV hjхhhubah}(h]h ]h"]h$]h&]uh1jhj/hhhjHhMV ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjghNhNubj)}(hXs**Parameters** ``struct scsi_device *sdev`` scsi device to change the state of. ``int timeout`` command timeout ``int retries`` number of retries before failing ``struct scsi_sense_hdr *sshdr`` outpout pointer for decoded sense information. Returns zero if unsuccessful or an error if TUR failed. For removable media, UNIT_ATTENTION sets ->changed flag.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMZ hjubj#)}(hhh](j()}(hA``struct scsi_device *sdev`` scsi device to change the state of. h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMW hjubjJ)}(hhh]h)}(h#scsi device to change the state of.h]h#scsi device to change the state of.}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hMW hj+ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj*hMW hj ubj()}(h ``int timeout`` command timeout h](j.)}(h``int timeout``h]j4)}(hjNh]h int timeout}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjLubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMX hjHubjJ)}(hhh]h)}(hcommand timeouth]hcommand timeout}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchMX hjdubah}(h]h ]h"]h$]h&]uh1jIhjHubeh}(h]h ]h"]h$]h&]uh1j'hjchMX hj ubj()}(h1``int retries`` number of retries before failing h](j.)}(h``int retries``h]j4)}(hjh]h int retries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMY hjubjJ)}(hhh]h)}(h number of retries before failingh]h number of retries before failing}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMY hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMY hj ubj()}(h``struct scsi_sense_hdr *sshdr`` outpout pointer for decoded sense information. Returns zero if unsuccessful or an error if TUR failed. For removable media, UNIT_ATTENTION sets ->changed flag.h](j.)}(h ``struct scsi_sense_hdr *sshdr``h]j4)}(hjh]hstruct scsi_sense_hdr *sshdr}(hj†hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM\ hjubjJ)}(hhh](h)}(h.outpout pointer for decoded sense information.h]h.outpout pointer for decoded sense information.}(hjنhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMZ hjֆubh)}(hqReturns zero if unsuccessful or an error if TUR failed. For removable media, UNIT_ATTENTION sets ->changed flag.h]hqReturns zero if unsuccessful or an error if TUR failed. For removable media, UNIT_ATTENTION sets ->changed flag.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjՆhM\ hjֆubeh}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjՆhM\ hj ubeh}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"scsi_device_set_state (C function)c.scsi_device_set_statehNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hRint scsi_device_set_state (struct scsi_device *sdev, enum scsi_device_state state)h]jP)}(hQint scsi_device_set_state(struct scsi_device *sdev, enum scsi_device_state state)h](j~)}(hinth]hint}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj$hhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMz ubjh)}(h h]h }(hj7hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj$hhhj6hMz ubjy)}(hscsi_device_set_stateh]j)}(hscsi_device_set_stateh]hscsi_device_set_state}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj$hhhj6hMz ubj)}(h8(struct scsi_device *sdev, enum scsi_device_state state)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjaubjh)}(h h]h }(hjrhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjaubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjKsbc.scsi_device_set_stateasbuh1hhjaubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjaubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjaubj)}(hsdevh]hsdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjaubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubj)}(henum scsi_device_state stateh](jV)}(hj7h]henum}(hjׇhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjӇubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjӇubh)}(hhh]j)}(hscsi_device_stateh]hscsi_device_state}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.scsi_device_set_stateasbuh1hhjӇubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjӇubj)}(hstateh]hstate}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjӇubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubeh}(h]h ]h"]h$]h&]jjuh1jhj$hhhj6hMz ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj hhhj6hMz ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhj6hMz hjhhubj)}(hhh]h)}(h5Take the given device through the device state model.h]h5Take the given device through the device state model.}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMz hjHhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj6hMz ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjcjjcjjjuh1jDhhhjghNhNubj)}(h**Parameters** ``struct scsi_device *sdev`` scsi device to change the state of. ``enum scsi_device_state state`` state to change to. Returns zero if successful or an error if the requested transition is illegal.h](h)}(h**Parameters**h]j)}(hjmh]h Parameters}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM~ hjgubj#)}(hhh](j()}(hA``struct scsi_device *sdev`` scsi device to change the state of. h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM{ hjubjJ)}(hhh]h)}(h#scsi device to change the state of.h]h#scsi device to change the state of.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM{ hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM{ hjubj()}(h``enum scsi_device_state state`` state to change to. Returns zero if successful or an error if the requested transition is illegal.h](j.)}(h ``enum scsi_device_state state``h]j4)}(hjňh]henum scsi_device_state state}(hjLjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjÈubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM~ hjubjJ)}(hhh](h)}(hstate to change to.h]hstate to change to.}(hjވhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM| hjۈubh)}(hNReturns zero if successful or an error if the requested transition is illegal.h]hNReturns zero if successful or an error if the requested transition is illegal.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjڈhM~ hjۈubeh}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjڈhM~ hjubeh}(h]h ]h"]h$]h&]uh1j"hjgubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sdev_evt_send (C function)c.sdev_evt_sendhNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hEvoid sdev_evt_send (struct scsi_device *sdev, struct scsi_event *evt)h]jP)}(hDvoid sdev_evt_send(struct scsi_device *sdev, struct scsi_event *evt)h](j~)}(hvoidh]hvoid}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj)hhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMR ubjh)}(h h]h }(hj<hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj)hhhj;hMR ubjy)}(h sdev_evt_sendh]j)}(h sdev_evt_sendh]h sdev_evt_send}(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjJubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj)hhhj;hMR ubj)}(h2(struct scsi_device *sdev, struct scsi_event *evt)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjfubjh)}(h h]h }(hjwhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjfubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjPsbc.sdev_evt_sendasbuh1hhjfubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjfubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjfubj)}(hsdevh]hsdev}(hjÉhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjfubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjbubj)}(hstruct scsi_event *evth](jV)}(hjYh]hstruct}(hj܉hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj؉ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj؉ubh)}(hhh]j)}(h scsi_eventh]h scsi_event}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.sdev_evt_sendasbuh1hhj؉ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj؉ubj )}(hj h]h*}(hj&hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj؉ubj)}(hevth]hevt}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj؉ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjbubeh}(h]h ]h"]h$]h&]jjuh1jhj)hhhj;hMR ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj%hhhj;hMR ubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1jIhj;hMR hj"hhubj)}(hhh]h)}(h$send asserted event to uevent threadh]h$send asserted event to uevent thread}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMR hjZhhubah}(h]h ]h"]h$]h&]uh1jhj"hhhj;hMR ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjujjujjjuh1jDhhhjghNhNubj)}(h**Parameters** ``struct scsi_device *sdev`` scsi_device event occurred on ``struct scsi_event *evt`` event to send Assert scsi device event asynchronously.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMV hjyubj#)}(hhh](j()}(h;``struct scsi_device *sdev`` scsi_device event occurred on h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMS hjubjJ)}(hhh]h)}(hscsi_device event occurred onh]hscsi_device event occurred on}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMS hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMS hjubj()}(hR``struct scsi_event *evt`` event to send Assert scsi device event asynchronously.h](j.)}(h``struct scsi_event *evt``h]j4)}(hj׊h]hstruct scsi_event *evt}(hjيhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjՊubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMU hjъubjJ)}(hhh](h)}(h event to sendh]h event to send}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMT hjubh)}(h(Assert scsi device event asynchronously.h]h(Assert scsi device event asynchronously.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMV hjubeh}(h]h ]h"]h$]h&]uh1jIhjъubeh}(h]h ]h"]h$]h&]uh1j'hjhMU hjubeh}(h]h ]h"]h$]h&]uh1j"hjyubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sdev_evt_alloc (C function)c.sdev_evt_allochNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hTstruct scsi_event * sdev_evt_alloc (enum scsi_device_event evt_type, gfp_t gfpflags)h]jP)}(hRstruct scsi_event *sdev_evt_alloc(enum scsi_device_event evt_type, gfp_t gfpflags)h](jV)}(hjYh]hstruct}(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj<hhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMn ubjh)}(h h]h }(hjNhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj<hhhjMhMn ubh)}(hhh]j)}(h scsi_eventh]h scsi_event}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj\ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjamodnameN classnameNjj)}j]j)}jsdev_evt_allocsbc.sdev_evt_allocasbuh1hhj<hhhjMhMn ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj<hhhjMhMn ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj<hhhjMhMn ubjy)}(hsdev_evt_alloch]j)}(hj}h]hsdev_evt_alloc}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj<hhhjMhMn ubj)}(h1(enum scsi_device_event evt_type, gfp_t gfpflags)h](j)}(henum scsi_device_event evt_typeh](jV)}(hj7h]henum}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjNjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hscsi_device_eventh]hscsi_device_event}(hj؋hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjՋubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjڋmodnameN classnameNjj)}j]j{c.sdev_evt_allocasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hevt_typeh]hevt_type}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hgfp_t gfpflagsh](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj"modnameN classnameNjj)}j]j{c.sdev_evt_allocasbuh1hhjubjh)}(h h]h }(hj>hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hgfpflagsh]hgfpflags}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj<hhhjMhMn ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj8hhhjMhMn ubah}(h]j3ah ](jjeh"]h$]h&]jj)jhuh1jIhjMhMn hj5hhubj)}(hhh]h)}(hallocate a new scsi eventh]hallocate a new scsi event}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMn hjshhubah}(h]h ]h"]h$]h&]uh1jhj5hhhjMhMn ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjghNhNubj)}(h**Parameters** ``enum scsi_device_event evt_type`` type of event to allocate ``gfp_t gfpflags`` GFP flags for allocation Allocates and returns a new scsi_event.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMr hjubj#)}(hhh](j()}(h>``enum scsi_device_event evt_type`` type of event to allocate h](j.)}(h#``enum scsi_device_event evt_type``h]j4)}(hjh]henum scsi_device_event evt_type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMo hjubjJ)}(hhh]h)}(htype of event to allocateh]htype of event to allocate}(hjЌhhhNhNubah}(h]h ]h"]h$]h&]uh1hhǰhMo hj͌ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hǰhMo hjubj()}(hT``gfp_t gfpflags`` GFP flags for allocation Allocates and returns a new scsi_event.h](j.)}(h``gfp_t gfpflags``h]j4)}(hjh]hgfp_t gfpflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMq hjubjJ)}(hhh](h)}(hGFP flags for allocationh]hGFP flags for allocation}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMp hjubh)}(h'Allocates and returns a new scsi_event.h]h'Allocates and returns a new scsi_event.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMr hjubeh}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMq hjubeh}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!sdev_evt_send_simple (C function)c.sdev_evt_send_simplehNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hevoid sdev_evt_send_simple (struct scsi_device *sdev, enum scsi_device_event evt_type, gfp_t gfpflags)h]jP)}(hdvoid sdev_evt_send_simple(struct scsi_device *sdev, enum scsi_device_event evt_type, gfp_t gfpflags)h](j~)}(hvoidh]hvoid}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjUhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM ubjh)}(h h]h }(hjhhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjUhhhjghM ubjy)}(hsdev_evt_send_simpleh]j)}(hsdev_evt_send_simpleh]hsdev_evt_send_simple}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjvubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjUhhhjghM ubj)}(hK(struct scsi_device *sdev, enum scsi_device_event evt_type, gfp_t gfpflags)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jj|sbc.sdev_evt_send_simpleasbuh1hhjubjh)}(h h]h }(hjԍhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hsdevh]hsdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(henum scsi_device_event evt_typeh](jV)}(hj7h]henum}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hscsi_device_eventh]hscsi_device_event}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj#ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj(modnameN classnameNjj)}j]jЍc.sdev_evt_send_simpleasbuh1hhjubjh)}(h h]h }(hjDhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hevt_typeh]hevt_type}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hgfp_t gfpflagsh](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjkubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjpmodnameN classnameNjj)}j]jЍc.sdev_evt_send_simpleasbuh1hhjgubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjgubj)}(hgfpflagsh]hgfpflags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjgubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjUhhhjghM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjQhhhjghM ubah}(h]jLah ](jjeh"]h$]h&]jj)jhuh1jIhjghM hjNhhubj)}(hhh]h)}(h$send asserted event to uevent threadh]h$send asserted event to uevent thread}(hjĎhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjNhhhjghM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj܎jj܎jjjuh1jDhhhjghNhNubj)}(h**Parameters** ``struct scsi_device *sdev`` scsi_device event occurred on ``enum scsi_device_event evt_type`` type of event to send ``gfp_t gfpflags`` GFP flags for allocation Assert scsi device event asynchronously, given an event type.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubj#)}(hhh](j()}(h;``struct scsi_device *sdev`` scsi_device event occurred on h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubjJ)}(hhh]h)}(hscsi_device event occurred onh]hscsi_device event occurred on}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjubj()}(h:``enum scsi_device_event evt_type`` type of event to send h](j.)}(h#``enum scsi_device_event evt_type``h]j4)}(hj>h]henum scsi_device_event evt_type}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj<ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj8ubjJ)}(hhh]h)}(htype of event to sendh]htype of event to send}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShM hjTubah}(h]h ]h"]h$]h&]uh1jIhj8ubeh}(h]h ]h"]h$]h&]uh1j'hjShM hjubj()}(hj``gfp_t gfpflags`` GFP flags for allocation Assert scsi device event asynchronously, given an event type.h](j.)}(h``gfp_t gfpflags``h]j4)}(hjwh]hgfp_t gfpflags}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjuubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjqubjJ)}(hhh](h)}(hGFP flags for allocationh]hGFP flags for allocation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubh)}(h=Assert scsi device event asynchronously, given an event type.h]h=Assert scsi device event asynchronously, given an event type.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubeh}(h]h ]h"]h$]h&]uh1jIhjqubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjubeh}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@ scsi_device_quiesce (C function)c.scsi_device_quiescehNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(h2int scsi_device_quiesce (struct scsi_device *sdev)h]jP)}(h1int scsi_device_quiesce(struct scsi_device *sdev)h](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj܏hhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj܏hhhjhM ubjy)}(hscsi_device_quiesceh]j)}(hscsi_device_quiesceh]hscsi_device_quiesce}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj܏hhhjhM ubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hj*hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj8ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj=modnameN classnameNjj)}j]j)}jjsbc.scsi_device_quiesceasbuh1hhjubjh)}(h h]h }(hj[hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjihhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hsdevh]hsdev}(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhj܏hhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj؏hhhjhM ubah}(h]jӏah ](jjeh"]h$]h&]jj)jhuh1jIhjhM hjՏhhubj)}(hhh]h)}(h+Block all commands except power management.h]h+Block all commands except power management.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjՏhhhjhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjghNhNubj)}(hX**Parameters** ``struct scsi_device *sdev`` scsi device to quiesce. This works by trying to transition to the SDEV_QUIESCE state (which must be a legal transition). When the device is in this state, only power management requests will be accepted, all others will be deferred. Must be called with user context, may sleep. Returns zero if unsuccessful or an error if not.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjĐhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubj#)}(hhh]j()}(hXg``struct scsi_device *sdev`` scsi device to quiesce. This works by trying to transition to the SDEV_QUIESCE state (which must be a legal transition). When the device is in this state, only power management requests will be accepted, all others will be deferred. Must be called with user context, may sleep. Returns zero if unsuccessful or an error if not.h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjߐubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjېubjJ)}(hhh](h)}(hscsi device to quiesce.h]hscsi device to quiesce.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubh)}(hThis works by trying to transition to the SDEV_QUIESCE state (which must be a legal transition). When the device is in this state, only power management requests will be accepted, all others will be deferred.h]hThis works by trying to transition to the SDEV_QUIESCE state (which must be a legal transition). When the device is in this state, only power management requests will be accepted, all others will be deferred.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubh)}(h,Must be called with user context, may sleep.h]h,Must be called with user context, may sleep.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubh)}(h0Returns zero if unsuccessful or an error if not.h]h0Returns zero if unsuccessful or an error if not.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubeh}(h]h ]h"]h$]h&]uh1jIhjېubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjؐubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_device_resume (C function)c.scsi_device_resumehNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(h2void scsi_device_resume (struct scsi_device *sdev)h]jP)}(h1void scsi_device_resume(struct scsi_device *sdev)h](j~)}(hvoidh]hvoid}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjdhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM ubjh)}(h h]h }(hjwhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjdhhhjvhM ubjy)}(hscsi_device_resumeh]j)}(hscsi_device_resumeh]hscsi_device_resume}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjdhhhjvhM ubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjÑhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjőmodnameN classnameNjj)}j]j)}jjsbc.scsi_device_resumeasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hsdevh]hsdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjdhhhjvhM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj`hhhjvhM ubah}(h]j[ah ](jjeh"]h$]h&]jj)jhuh1jIhjvhM hj]hhubj)}(hhh]h)}(h2Restart user issued commands to a quiesced device.h]h2Restart user issued commands to a quiesced device.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj%hhubah}(h]h ]h"]h$]h&]uh1jhj]hhhjvhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj@jj@jjjuh1jDhhhjghNhNubj)}(h**Parameters** ``struct scsi_device *sdev`` scsi device to resume. Moves the device from quiesced back to running and restarts the queues. Must be called with user context, may sleep.h](h)}(h**Parameters**h]j)}(hjJh]h Parameters}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjDubj#)}(hhh]j()}(h``struct scsi_device *sdev`` scsi device to resume. Moves the device from quiesced back to running and restarts the queues. Must be called with user context, may sleep.h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjih]hstruct scsi_device *sdev}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjgubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjcubjJ)}(hhh](h)}(hscsi device to resume.h]hscsi device to resume.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubh)}(hGMoves the device from quiesced back to running and restarts the queues.h]hGMoves the device from quiesced back to running and restarts the queues.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubh)}(h,Must be called with user context, may sleep.h]h,Must be called with user context, may sleep.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubeh}(h]h ]h"]h$]h&]uh1jIhjcubeh}(h]h ]h"]h$]h&]uh1j'hj~hM hj`ubah}(h]h ]h"]h$]h&]uh1j"hjDubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@.scsi_internal_device_block_nowait (C function)#c.scsi_internal_device_block_nowaithNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(h@int scsi_internal_device_block_nowait (struct scsi_device *sdev)h]jP)}(h?int scsi_internal_device_block_nowait(struct scsi_device *sdev)h](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjݒhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM, ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjݒhhhjhM, ubjy)}(h!scsi_internal_device_block_nowaith]j)}(h!scsi_internal_device_block_nowaith]h!scsi_internal_device_block_nowait}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjݒhhhjhM, ubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hj+hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj9ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj>modnameN classnameNjj)}j]j)}jjsb#c.scsi_internal_device_block_nowaitasbuh1hhjubjh)}(h h]h }(hj\hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hsdevh]hsdev}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjݒhhhjhM, ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjْhhhjhM, ubah}(h]jԒah ](jjeh"]h$]h&]jj)jhuh1jIhjhM, hj֒hhubj)}(hhh]h)}(h)try to transition to the SDEV_BLOCK stateh]h)try to transition to the SDEV_BLOCK state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM, hjhhubah}(h]h ]h"]h$]h&]uh1jhj֒hhhjhM, ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjghNhNubj)}(hX**Parameters** ``struct scsi_device *sdev`` device to block **Description** Pause SCSI command processing on the specified device. Does not sleep. Returns zero if successful or a negative error code upon failure. **Notes** This routine transitions the device to the SDEV_BLOCK state (which must be a legal transition). When the device is in this state, command processing is paused until the device leaves the SDEV_BLOCK state. See also scsi_internal_device_unblock_nowait().h](h)}(h**Parameters**h]j)}(hjÓh]h Parameters}(hjœhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM0 hjubj#)}(hhh]j()}(h-``struct scsi_device *sdev`` device to block h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM- hjܓubjJ)}(hhh]h)}(hdevice to blockh]hdevice to block}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM- hjubah}(h]h ]h"]h$]h&]uh1jIhjܓubeh}(h]h ]h"]h$]h&]uh1j'hjhM- hjٓubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM/ hjubh)}(hFPause SCSI command processing on the specified device. Does not sleep.h]hFPause SCSI command processing on the specified device. Does not sleep.}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM/ hjubh)}(hAReturns zero if successful or a negative error code upon failure.h]hAReturns zero if successful or a negative error code upon failure.}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM1 hjubh)}(h **Notes**h]j)}(hjSh]hNotes}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM3 hjubh)}(hThis routine transitions the device to the SDEV_BLOCK state (which must be a legal transition). When the device is in this state, command processing is paused until the device leaves the SDEV_BLOCK state. See also scsi_internal_device_unblock_nowait().h]hThis routine transitions the device to the SDEV_BLOCK state (which must be a legal transition). When the device is in this state, command processing is paused until the device leaves the SDEV_BLOCK state. See also scsi_internal_device_unblock_nowait().}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM3 hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@0scsi_internal_device_unblock_nowait (C function)%c.scsi_internal_device_unblock_nowaithNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hdint scsi_internal_device_unblock_nowait (struct scsi_device *sdev, enum scsi_device_state new_state)h]jP)}(hcint scsi_internal_device_unblock_nowait(struct scsi_device *sdev, enum scsi_device_state new_state)h](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMn ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMn ubjy)}(h#scsi_internal_device_unblock_nowaith]j)}(h#scsi_internal_device_unblock_nowaith]h#scsi_internal_device_unblock_nowait}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMn ubj)}(h<(struct scsi_device *sdev, enum scsi_device_state new_state)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjՔhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjєubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjєubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsb%c.scsi_internal_device_unblock_nowaitasbuh1hhjєubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjєubj )}(hj h]h*}(hj!hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjєubj)}(hsdevh]hsdev}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjєubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj͔ubj)}(h enum scsi_device_state new_stateh](jV)}(hj7h]henum}(hjGhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCubjh)}(h h]h }(hjThhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjCubh)}(hhh]j)}(hscsi_device_stateh]hscsi_device_state}(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjbubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjgmodnameN classnameNjj)}j]j%c.scsi_internal_device_unblock_nowaitasbuh1hhjCubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjCubj)}(h new_stateh]h new_state}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjCubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj͔ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMn ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMn ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMn hjhhubj)}(hhh]h)}(h%resume a device after a block requesth]h%resume a device after a block request}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMn hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMn ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjӕjjӕjjjuh1jDhhhjghNhNubj)}(hX**Parameters** ``struct scsi_device *sdev`` device to resume ``enum scsi_device_state new_state`` state to set the device to after unblocking **Description** Restart the device queue for a previously suspended SCSI device. Does not sleep. Returns zero if successful or a negative error code upon failure. **Notes** This routine transitions the device to the SDEV_RUNNING state or to one of the offline states (which must be a legal transition) allowing the midlayer to goose the queue for this device.h](h)}(h**Parameters**h]j)}(hjݕh]h Parameters}(hjߕhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjەubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMr hjוubj#)}(hhh](j()}(h.``struct scsi_device *sdev`` device to resume h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMo hjubjJ)}(hhh]h)}(hdevice to resumeh]hdevice to resume}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMo hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMo hjubj()}(hQ``enum scsi_device_state new_state`` state to set the device to after unblocking h](j.)}(h$``enum scsi_device_state new_state``h]j4)}(hj5h]h enum scsi_device_state new_state}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj3ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMp hj/ubjJ)}(hhh]h)}(h+state to set the device to after unblockingh]h+state to set the device to after unblocking}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhMp hjKubah}(h]h ]h"]h$]h&]uh1jIhj/ubeh}(h]h ]h"]h$]h&]uh1j'hjJhMp hjubeh}(h]h ]h"]h$]h&]uh1j"hjוubh)}(h**Description**h]j)}(hjph]h Description}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMr hjוubh)}(hPRestart the device queue for a previously suspended SCSI device. Does not sleep.h]hPRestart the device queue for a previously suspended SCSI device. Does not sleep.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMr hjוubh)}(hAReturns zero if successful or a negative error code upon failure.h]hAReturns zero if successful or a negative error code upon failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMu hjוubh)}(h **Notes**h]j)}(hjh]hNotes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMw hjוubh)}(hThis routine transitions the device to the SDEV_RUNNING state or to one of the offline states (which must be a legal transition) allowing the midlayer to goose the queue for this device.h]hThis routine transitions the device to the SDEV_RUNNING state or to one of the offline states (which must be a legal transition) allowing the midlayer to goose the queue for this device.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMw hjוubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_block_targets (C function)c.scsi_block_targetshNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hEvoid scsi_block_targets (struct Scsi_Host *shost, struct device *dev)h]jP)}(hDvoid scsi_block_targets(struct Scsi_Host *shost, struct device *dev)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM ubjy)}(hscsi_block_targetsh]j)}(hscsi_block_targetsh]hscsi_block_targets}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhM ubj)}(h-(struct Scsi_Host *shost, struct device *dev)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj(hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubjh)}(h h]h }(hj5hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj$ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjCubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjHmodnameN classnameNjj)}j]j)}jjsbc.scsi_block_targetsasbuh1hhj$ubjh)}(h h]h }(hjfhhhNhNubah}(h]h ]jtah"]h$]h&]uh1*jghj$ubj )}(hj h]h*}(hjthhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj$ubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hstruct device *devh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hdeviceh]hdevice}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jbc.scsi_block_targetsasbuh1hhjubjh)}(h h]h }(hj֗hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM ubah}(h]jޖah ](jjeh"]h$]h&]jj)jhuh1jIhjhM hjhhubj)}(hhh]h)}(h5transition all SCSI child devices to SDEV_BLOCK stateh]h5transition all SCSI child devices to SDEV_BLOCK state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj3jj3jjjuh1jDhhhjghNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` the Scsi_Host to which this device belongs ``struct device *dev`` a parent device of one or more scsi_target devices **Description** Iterate over all children of **dev**, which should be scsi_target devices, and switch all subordinate scsi devices to SDEV_BLOCK state. Wait for ongoing scsi_queue_rq() calls to finish. May sleep. **Note** **dev** must not itself be a scsi_target device.h](h)}(h**Parameters**h]j)}(hj=h]h Parameters}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj7ubj#)}(hhh](j()}(hG``struct Scsi_Host *shost`` the Scsi_Host to which this device belongs h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj\h]hstruct Scsi_Host *shost}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjZubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjVubjJ)}(hhh]h)}(h*the Scsi_Host to which this device belongsh]h*the Scsi_Host to which this device belongs}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhM hjrubah}(h]h ]h"]h$]h&]uh1jIhjVubeh}(h]h ]h"]h$]h&]uh1j'hjqhM hjSubj()}(hJ``struct device *dev`` a parent device of one or more scsi_target devices h](j.)}(h``struct device *dev``h]j4)}(hjh]hstruct device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubjJ)}(hhh]h)}(h2a parent device of one or more scsi_target devicesh]h2a parent device of one or more scsi_target devices}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjSubeh}(h]h ]h"]h$]h&]uh1j"hj7ubh)}(h**Description**h]j)}(hjИh]h Description}(hjҘhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjΘubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj7ubh)}(hIterate over all children of **dev**, which should be scsi_target devices, and switch all subordinate scsi devices to SDEV_BLOCK state. Wait for ongoing scsi_queue_rq() calls to finish. May sleep.h](hIterate over all children of }(hjhhhNhNubj)}(h**dev**h]hdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh, which should be scsi_target devices, and switch all subordinate scsi devices to SDEV_BLOCK state. Wait for ongoing scsi_queue_rq() calls to finish. May sleep.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj7ubh)}(h**Note**h]j)}(hj h]hNote}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj7ubh)}(h0**dev** must not itself be a scsi_target device.h](j)}(h**dev**h]hdev}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh) must not itself be a scsi_target device.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj7ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_host_block (C function)c.scsi_host_blockhNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(h-int scsi_host_block (struct Scsi_Host *shost)h]jP)}(h,int scsi_host_block(struct Scsi_Host *shost)h](j~)}(hinth]hint}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjXhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM ubjh)}(h h]h }(hjkhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjXhhhjjhM ubjy)}(hscsi_host_blockh]j)}(hscsi_host_blockh]hscsi_host_block}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjyubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjXhhhjjhM ubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.scsi_host_blockasbuh1hhjubjh)}(h h]h }(hjיhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjXhhhjjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjThhhjjhM ubah}(h]jOah ](jjeh"]h$]h&]jj)jhuh1jIhjjhM hjQhhubj)}(hhh]h)}(h;Try to transition all logical units to the SDEV_BLOCK stateh]h;Try to transition all logical units to the SDEV_BLOCK state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjQhhhjjhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj4jj4jjjuh1jDhhhjghNhNubj)}(hX **Parameters** ``struct Scsi_Host *shost`` device to block **Description** Pause SCSI command processing for all logical units associated with the SCSI host and wait until pending scsi_queue_rq() calls have finished. Returns zero if successful or a negative error code upon failure.h](h)}(h**Parameters**h]j)}(hj>h]h Parameters}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj8ubj#)}(hhh]j()}(h,``struct Scsi_Host *shost`` device to block h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj]h]hstruct Scsi_Host *shost}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj[ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjWubjJ)}(hhh]h)}(hdevice to blockh]hdevice to block}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrhM hjsubah}(h]h ]h"]h$]h&]uh1jIhjWubeh}(h]h ]h"]h$]h&]uh1j'hjrhM hjTubah}(h]h ]h"]h$]h&]uh1j"hj8ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj8ubh)}(hPause SCSI command processing for all logical units associated with the SCSI host and wait until pending scsi_queue_rq() calls have finished.h]hPause SCSI command processing for all logical units associated with the SCSI host and wait until pending scsi_queue_rq() calls have finished.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj8ubh)}(hAReturns zero if successful or a negative error code upon failure.h]hAReturns zero if successful or a negative error code upon failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj8ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@ scsi_kmap_atomic_sg (C function)c.scsi_kmap_atomic_sghNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(h_void * scsi_kmap_atomic_sg (struct scatterlist *sgl, int sg_count, size_t *offset, size_t *len)h]jP)}(h]void *scsi_kmap_atomic_sg(struct scatterlist *sgl, int sg_count, size_t *offset, size_t *len)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM+ ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM+ ubj )}(hj h]h*}(hj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjhhhjhM+ ubjy)}(hscsi_kmap_atomic_sgh]j)}(hscsi_kmap_atomic_sgh]hscsi_kmap_atomic_sg}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhM+ ubj)}(hD(struct scatterlist *sgl, int sg_count, size_t *offset, size_t *len)h](j)}(hstruct scatterlist *sglh](jV)}(hjYh]hstruct}(hj6hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2ubjh)}(h h]h }(hjChhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj2ubh)}(hhh]j)}(h scatterlisth]h scatterlist}(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjQubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjVmodnameN classnameNjj)}j]j)}jjsbc.scsi_kmap_atomic_sgasbuh1hhj2ubjh)}(h h]h }(hjthhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj2ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj2ubj)}(hsglh]hsgl}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj2ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubj)}(h int sg_counth](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hsg_counth]hsg_count}(hjěhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubj)}(hsize_t *offseth](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjݛubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jpc.scsi_kmap_atomic_sgasbuh1hhjٛubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjٛubj )}(hj h]h*}(hj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjٛubj)}(hoffseth]hoffset}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjٛubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubj)}(h size_t *lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj2ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj7modnameN classnameNjj)}j]jpc.scsi_kmap_atomic_sgasbuh1hhj.ubjh)}(h h]h }(hjShhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj.ubj )}(hj h]h*}(hjahhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj.ubj)}(hlenh]hlen}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj.ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM+ ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM+ ubah}(h]jߚah ](jjeh"]h$]h&]jj)jhuh1jIhjhM+ hjhhubj)}(hhh]h)}(h$find and atomically map an sg-elemnth]h$find and atomically map an sg-elemnt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM+ hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM+ ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjghNhNubj)}(hXO**Parameters** ``struct scatterlist *sgl`` scatter-gather list ``int sg_count`` number of segments in sg ``size_t *offset`` offset in bytes into sg, on return offset into the mapped area ``size_t *len`` bytes to map, on return number of bytes mapped **Description** Returns virtual address of the start of the mapped pageh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM/ hjubj#)}(hhh](j()}(h0``struct scatterlist *sgl`` scatter-gather list h](j.)}(h``struct scatterlist *sgl``h]j4)}(hjٜh]hstruct scatterlist *sgl}(hjۜhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjלubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM, hjӜubjJ)}(hhh]h)}(hscatter-gather listh]hscatter-gather list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM, hjubah}(h]h ]h"]h$]h&]uh1jIhjӜubeh}(h]h ]h"]h$]h&]uh1j'hjhM, hjМubj()}(h*``int sg_count`` number of segments in sg h](j.)}(h``int sg_count``h]j4)}(hjh]h int sg_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM- hj ubjJ)}(hhh]h)}(hnumber of segments in sgh]hnumber of segments in sg}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM- hj(ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj'hM- hjМubj()}(hR``size_t *offset`` offset in bytes into sg, on return offset into the mapped area h](j.)}(h``size_t *offset``h]j4)}(hjKh]hsize_t *offset}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjIubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM. hjEubjJ)}(hhh]h)}(h>offset in bytes into sg, on return offset into the mapped areah]h>offset in bytes into sg, on return offset into the mapped area}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hM. hjaubah}(h]h ]h"]h$]h&]uh1jIhjEubeh}(h]h ]h"]h$]h&]uh1j'hj`hM. hjМubj()}(h?``size_t *len`` bytes to map, on return number of bytes mapped h](j.)}(h``size_t *len``h]j4)}(hjh]h size_t *len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM/ hj~ubjJ)}(hhh]h)}(h.bytes to map, on return number of bytes mappedh]h.bytes to map, on return number of bytes mapped}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM/ hjubah}(h]h ]h"]h$]h&]uh1jIhj~ubeh}(h]h ]h"]h$]h&]uh1j'hjhM/ hjМubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM1 hjubh)}(h7Returns virtual address of the start of the mapped pageh]h7Returns virtual address of the start of the mapped page}(hj՝hhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM1 hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"scsi_kunmap_atomic_sg (C function)c.scsi_kunmap_atomic_sghNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(h'void scsi_kunmap_atomic_sg (void *virt)h]jP)}(h&void scsi_kunmap_atomic_sg(void *virt)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM] ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM] ubjy)}(hscsi_kunmap_atomic_sgh]j)}(hscsi_kunmap_atomic_sgh]hscsi_kunmap_atomic_sg}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj!ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhM] ubj)}(h (void *virt)h]j)}(h void *virth](j~)}(hvoidh]hvoid}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj=ubjh)}(h h]h }(hjOhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj=ubj )}(hj h]h*}(hj]hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj=ubj)}(hvirth]hvirt}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj=ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM] ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM] ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhM] hjhhubj)}(hhh]h)}(hNatomically unmap a virtual address, previously mapped with scsi_kmap_atomic_sgh]hNatomically unmap a virtual address, previously mapped with scsi_kmap_atomic_sg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM] hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM] ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjghNhNubj)}(h?**Parameters** ``void *virt`` virtual address to be unmappedh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMa hjubj#)}(hhh]j()}(h-``void *virt`` virtual address to be unmappedh](j.)}(h``void *virt``h]j4)}(hj՞h]h void *virt}(hjמhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjӞubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMc hjϞubjJ)}(hhh]h)}(hvirtual address to be unmappedh]hvirtual address to be unmapped}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM^ hjubah}(h]h ]h"]h$]h&]uh1jIhjϞubeh}(h]h ]h"]h$]h&]uh1j'hjhMc hj̞ubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_vpd_lun_id (C function)c.scsi_vpd_lun_idhNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hGint scsi_vpd_lun_id (struct scsi_device *sdev, char *id, size_t id_len)h]jP)}(hFint scsi_vpd_lun_id(struct scsi_device *sdev, char *id, size_t id_len)h](j~)}(hinth]hint}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj+hhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM ubjh)}(h h]h }(hj>hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj+hhhj=hM ubjy)}(hscsi_vpd_lun_idh]j)}(hscsi_vpd_lun_idh]hscsi_vpd_lun_id}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjLubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj+hhhj=hM ubj)}(h3(struct scsi_device *sdev, char *id, size_t id_len)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjlhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhubjh)}(h h]h }(hjyhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjRsbc.scsi_vpd_lun_idasbuh1hhjhubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjhubj)}(hsdevh]hsdev}(hjşhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjhubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjdubj)}(hchar *idh](j~)}(hcharh]hchar}(hjޟhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjڟubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjڟubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjڟubj)}(hidh]hid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjڟubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjdubj)}(h size_t id_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj%modnameN classnameNjj)}j]jc.scsi_vpd_lun_idasbuh1hhjubjh)}(h h]h }(hjAhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hid_lenh]hid_len}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjdubeh}(h]h ]h"]h$]h&]jjuh1jhj+hhhj=hM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj'hhhj=hM ubah}(h]j"ah ](jjeh"]h$]h&]jj)jhuh1jIhj=hM hj$hhubj)}(hhh]h)}(h%return a unique device identificationh]h%return a unique device identification}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjvhhubah}(h]h ]h"]h$]h&]uh1jhj$hhhj=hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjghNhNubj)}(hX**Parameters** ``struct scsi_device *sdev`` SCSI device ``char *id`` buffer for the identification ``size_t id_len`` length of the buffer **Description** Copies a unique device identification into **id** based on the information in the VPD page 0x83 of the device. The string will be formatted as a SCSI name string. Returns the length of the identification or error on failure. If the identifier is longer than the supplied buffer the actual identifier length is returned and the buffer is not zero-padded.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubj#)}(hhh](j()}(h)``struct scsi_device *sdev`` SCSI device h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubjJ)}(hhh]h)}(h SCSI deviceh]h SCSI device}(hjӠhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjϠhM hjРubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjϠhM hjubj()}(h+``char *id`` buffer for the identification h](j.)}(h ``char *id``h]j4)}(hjh]hchar *id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubjJ)}(hhh]h)}(hbuffer for the identificationh]hbuffer for the identification}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjubj()}(h'``size_t id_len`` length of the buffer h](j.)}(h``size_t id_len``h]j4)}(hj,h]h size_t id_len}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj*ubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hj&ubjJ)}(hhh]h)}(hlength of the bufferh]hlength of the buffer}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhM hjBubah}(h]h ]h"]h$]h&]uh1jIhj&ubeh}(h]h ]h"]h$]h&]uh1j'hjAhM hjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjgh]h Description}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubh)}(hCopies a unique device identification into **id** based on the information in the VPD page 0x83 of the device. The string will be formatted as a SCSI name string.h](h+Copies a unique device identification into }(hj}hhhNhNubj)}(h**id**h]hid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubhq based on the information in the VPD page 0x83 of the device. The string will be formatted as a SCSI name string.}(hj}hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubh)}(hReturns the length of the identification or error on failure. If the identifier is longer than the supplied buffer the actual identifier length is returned and the buffer is not zero-padded.h]hReturns the length of the identification or error on failure. If the identifier is longer than the supplied buffer the actual identifier length is returned and the buffer is not zero-padded.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_vpd_tpg_id (C function)c.scsi_vpd_tpg_idhNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(h;int scsi_vpd_tpg_id (struct scsi_device *sdev, int *rel_id)h]jP)}(h:int scsi_vpd_tpg_id(struct scsi_device *sdev, int *rel_id)h](j~)}(hinth]hint}(hj͡hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjɡhhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM> ubjh)}(h h]h }(hjܡhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjɡhhhjۡhM> ubjy)}(hscsi_vpd_tpg_idh]j)}(hscsi_vpd_tpg_idh]hscsi_vpd_tpg_id}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjɡhhhjۡhM> ubj)}(h'(struct scsi_device *sdev, int *rel_id)h](j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj%ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*modnameN classnameNjj)}j]j)}jjsbc.scsi_vpd_tpg_idasbuh1hhjubjh)}(h h]h }(hjHhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjVhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hsdevh]hsdev}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int *rel_idh](j~)}(hinth]hint}(hj|hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjxubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjxubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjxubj)}(hrel_idh]hrel_id}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjxubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjɡhhhjۡhM> ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjšhhhjۡhM> ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjۡhM> hj¡hhubj)}(hhh]h)}(h%return a target port group identifierh]h%return a target port group identifier}(hjϢhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM> hj̢hhubah}(h]h ]h"]h$]h&]uh1jhj¡hhhjۡhM> ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjghNhNubj)}(hXm**Parameters** ``struct scsi_device *sdev`` SCSI device ``int *rel_id`` pointer to return relative target port in if not ``NULL`` **Description** Returns the Target Port Group identifier from the information from VPD page 0x83 of the device. Optionally sets **rel_id** to the relative target port on success. **Return** the identifier or error on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMB hjubj#)}(hhh](j()}(h)``struct scsi_device *sdev`` SCSI device h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM? hj ubjJ)}(hhh]h)}(h SCSI deviceh]h SCSI device}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hM? hj&ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj%hM? hjubj()}(hJ``int *rel_id`` pointer to return relative target port in if not ``NULL`` h](j.)}(h``int *rel_id``h]j4)}(hjIh]h int *rel_id}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjGubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chM@ hjCubjJ)}(hhh]h)}(h9pointer to return relative target port in if not ``NULL``h](h1pointer to return relative target port in if not }(hjbhhhNhNubj4)}(h``NULL``h]hNULL}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjbubeh}(h]h ]h"]h$]h&]uh1hhj^hM@ hj_ubah}(h]h ]h"]h$]h&]uh1jIhjCubeh}(h]h ]h"]h$]h&]uh1j'hj^hM@ hjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMB hjubh)}(hReturns the Target Port Group identifier from the information from VPD page 0x83 of the device. Optionally sets **rel_id** to the relative target port on success.h](hpReturns the Target Port Group identifier from the information from VPD page 0x83 of the device. Optionally sets }(hjhhhNhNubj)}(h **rel_id**h]hrel_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh( to the relative target port on success.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMB hjubh)}(h **Return**h]j)}(hjˣh]hReturn}(hjͣhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjɣubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMF hjubh)}(h#the identifier or error on failure.h]h#the identifier or error on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMF hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_build_sense (C function)c.scsi_build_sensehNtauh1j3hjghhhNhNubjE)}(hhh](jJ)}(hQvoid scsi_build_sense (struct scsi_cmnd *scmd, int desc, u8 key, u8 asc, u8 ascq)h]jP)}(hPvoid scsi_build_sense(struct scsi_cmnd *scmd, int desc, u8 key, u8 asc, u8 ascq)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj hhhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMo ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj hhhjhMo ubjy)}(hscsi_build_senseh]j)}(hscsi_build_senseh]hscsi_build_sense}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj-ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj hhhjhMo ubj)}(h;(struct scsi_cmnd *scmd, int desc, u8 key, u8 asc, u8 ascq)h](j)}(hstruct scsi_cmnd *scmdh](jV)}(hjYh]hstruct}(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjIubjh)}(h h]h }(hjZhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjIubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjhubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmmodnameN classnameNjj)}j]j)}jj3sbc.scsi_build_senseasbuh1hhjIubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjIubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjIubj)}(hscmdh]hscmd}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjIubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjEubj)}(hint desch](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjͤhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hdesch]hdesc}(hjۤhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjEubj)}(hu8 keyh](h)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.scsi_build_senseasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hkeyh]hkey}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjEubj)}(hu8 asch](h)}(hhh]j)}(hu8h]hu8}(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj<ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjAmodnameN classnameNjj)}j]jc.scsi_build_senseasbuh1hhj8ubjh)}(h h]h }(hj]hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj8ubj)}(hasch]hasc}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjEubj)}(hu8 ascqh](h)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.scsi_build_senseasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hascqh]hascq}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjEubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhjhMo ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMo ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMo hjhhubj)}(hhh]h)}(hbuild sense data for a commandh]hbuild sense data for a command}(hjݥhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMo hjڥhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMo ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjghNhNubj)}(hX**Parameters** ``struct scsi_cmnd *scmd`` scsi command for which the sense should be formatted ``int desc`` Sense format (non-zero == descriptor format, 0 == fixed format) ``u8 key`` Sense key ``u8 asc`` Additional sense code ``u8 ascq`` Additional sense code qualifierh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMs hjubj#)}(hhh](j()}(hP``struct scsi_cmnd *scmd`` scsi command for which the sense should be formatted h](j.)}(h``struct scsi_cmnd *scmd``h]j4)}(hjh]hstruct scsi_cmnd *scmd}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMp hjubjJ)}(hhh]h)}(h4scsi command for which the sense should be formattedh]h4scsi command for which the sense should be formatted}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMp hj4ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj3hMp hjubj()}(hM``int desc`` Sense format (non-zero == descriptor format, 0 == fixed format) h](j.)}(h ``int desc``h]j4)}(hjWh]hint desc}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjUubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMr hjQubjJ)}(hhh]h)}(h?Sense format (non-zero == descriptor format, 0 == fixed format)h]h?Sense format (non-zero == descriptor format, 0 == fixed format)}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMq hjmubah}(h]h ]h"]h$]h&]uh1jIhjQubeh}(h]h ]h"]h$]h&]uh1j'hjlhMr hjubj()}(h``u8 key`` Sense key h](j.)}(h ``u8 key``h]j4)}(hjh]hu8 key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMs hjubjJ)}(hhh]h)}(h Sense keyh]h Sense key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMs hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMs hjubj()}(h!``u8 asc`` Additional sense code h](j.)}(h ``u8 asc``h]j4)}(hjʦh]hu8 asc}(hj̦hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjȦubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMt hjĦubjJ)}(hhh]h)}(hAdditional sense codeh]hAdditional sense code}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjߦhMt hjubah}(h]h ]h"]h$]h&]uh1jIhjĦubeh}(h]h ]h"]h$]h&]uh1j'hjߦhMt hjubj()}(h+``u8 ascq`` Additional sense code qualifierh](j.)}(h ``u8 ascq``h]j4)}(hjh]hu8 ascq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMv hjubjJ)}(hhh]h)}(hAdditional sense code qualifierh]hAdditional sense code qualifier}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:144: ./drivers/scsi/scsi_lib.chMu hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMv hjubeh}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjghhhNhNubeh}(h]drivers-scsi-scsi-lib-cah ]h"]drivers/scsi/scsi_lib.cah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hdrivers/scsi/scsi_lib_dma.ch]hdrivers/scsi/scsi_lib_dma.c}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhhhhhKubh)}(hMSCSI library functions depending on DMA (map and unmap scatter-gather lists).h]hMSCSI library functions depending on DMA (map and unmap scatter-gather lists).}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjLhhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_dma_map (C function)c.scsi_dma_maphNtauh1j3hjLhhhNhNubjE)}(hhh](jJ)}(h(int scsi_dma_map (struct scsi_cmnd *cmd)h]jP)}(h'int scsi_dma_map(struct scsi_cmnd *cmd)h](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhKubjy)}(h scsi_dma_maph]j)}(h scsi_dma_maph]h scsi_dma_map}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhKubj)}(h(struct scsi_cmnd *cmd)h]j)}(hstruct scsi_cmnd *cmdh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjΧhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hjߧhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjܧubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.scsi_dma_mapasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hcmdh]hcmd}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj|hhhjhKubah}(h]jwah ](jjeh"]h$]h&]jj)jhuh1jIhjhKhjyhhubj)}(hhh]h)}(h.perform DMA mapping against command's sg listsh]h0perform DMA mapping against command’s sg lists}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chKhjAhhubah}(h]h ]h"]h$]h&]uh1jhjyhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj\jj\jjjuh1jDhhhjLhNhNubj)}(h**Parameters** ``struct scsi_cmnd *cmd`` scsi command **Description** Returns the number of sg lists actually used, zero if the sg lists is NULL, or -ENOMEM if the mapping failed.h](h)}(h**Parameters**h]j)}(hjfh]h Parameters}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chKhj`ubj#)}(hhh]j()}(h'``struct scsi_cmnd *cmd`` scsi command h](j.)}(h``struct scsi_cmnd *cmd``h]j4)}(hjh]hstruct scsi_cmnd *cmd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chKhjubjJ)}(hhh]h)}(h scsi commandh]h scsi command}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhj|ubah}(h]h ]h"]h$]h&]uh1j"hj`ubh)}(h**Description**h]j)}(hjh]h Description}(hj¨hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chKhj`ubh)}(hmReturns the number of sg lists actually used, zero if the sg lists is NULL, or -ENOMEM if the mapping failed.h]hmReturns the number of sg lists actually used, zero if the sg lists is NULL, or -ENOMEM if the mapping failed.}(hj֨hhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chKhj`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjLhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_dma_unmap (C function)c.scsi_dma_unmaphNtauh1j3hjLhhhNhNubjE)}(hhh](jJ)}(h+void scsi_dma_unmap (struct scsi_cmnd *cmd)h]jP)}(h*void scsi_dma_unmap(struct scsi_cmnd *cmd)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chK(ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhK(ubjy)}(hscsi_dma_unmaph]j)}(hscsi_dma_unmaph]hscsi_dma_unmap}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj"ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhK(ubj)}(h(struct scsi_cmnd *cmd)h]j)}(hstruct scsi_cmnd *cmdh](jV)}(hjYh]hstruct}(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>ubjh)}(h h]h }(hjOhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>ubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjbmodnameN classnameNjj)}j]j)}jj(sbc.scsi_dma_unmapasbuh1hhj>ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj>ubj)}(hcmdh]hcmd}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj>ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhK(ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhK(ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhK(hjhhubj)}(hhh]h)}(h/unmap command's sg lists mapped by scsi_dma_maph]h1unmap command’s sg lists mapped by scsi_dma_map}(hjũhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chK(hj©hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhK(ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjݩjjݩjjjuh1jDhhhjLhNhNubj)}(h8**Parameters** ``struct scsi_cmnd *cmd`` scsi commandh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chK,hjubj#)}(hhh]j()}(h&``struct scsi_cmnd *cmd`` scsi commandh](j.)}(h``struct scsi_cmnd *cmd``h]j4)}(hjh]hstruct scsi_cmnd *cmd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chK.hjubjJ)}(hhh]h)}(h scsi commandh]h scsi command}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:153: ./drivers/scsi/scsi_lib_dma.chK)hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhK.hjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjLhhhNhNubeh}(h]drivers-scsi-scsi-lib-dma-cah ]h"]drivers/scsi/scsi_lib_dma.cah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hdrivers/scsi/scsi_proc.ch]hdrivers/scsi/scsi_proc.c}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOhhhhhKubh)}(hThe functions in this file provide an interface between the PROC file system and the SCSI device drivers It is mainly used for debugging, statistics and to pass information directly to the lowlevel driver. I.E. plumbing to manage /proc/scsi/\*h]hThe functions in this file provide an interface between the PROC file system and the SCSI device drivers It is mainly used for debugging, statistics and to pass information directly to the lowlevel driver. I.E. plumbing to manage /proc/scsi/*}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjOhhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_proc_entry (C struct)c.scsi_proc_entryhNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(hscsi_proc_entryh]jP)}(hstruct scsi_proc_entryh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhKubjy)}(hscsi_proc_entryh]j)}(hjh]hscsi_proc_entry}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhKubah}(h]jzah ](jjeh"]h$]h&]jj)jhuh1jIhjhKhj|hhubj)}(hhh]h)}(h*(host template, SCSI proc dir) associationh]h*(host template, SCSI proc dir) association}(hjɪhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chK3hjƪhhubah}(h]h ]h"]h$]h&]uh1jhj|hhhjhKubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1jDhhhjOhNhNubj)}(hX**Definition**:: struct scsi_proc_entry { struct list_head entry; const struct scsi_host_template *sht; struct proc_dir_entry *proc_dir; unsigned int present; }; **Members** ``entry`` entry in scsi_proc_list. ``sht`` SCSI host template associated with the procfs directory. ``proc_dir`` procfs directory associated with the SCSI host template. ``present`` Number of SCSI hosts instantiated for **sht**.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chK7hjubj)}(hstruct scsi_proc_entry { struct list_head entry; const struct scsi_host_template *sht; struct proc_dir_entry *proc_dir; unsigned int present; };h]hstruct scsi_proc_entry { struct list_head entry; const struct scsi_host_template *sht; struct proc_dir_entry *proc_dir; unsigned int present; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chK9hjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chK@hjubj#)}(hhh](j()}(h#``entry`` entry in scsi_proc_list. h](j.)}(h ``entry``h]j4)}(hj6h]hentry}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj4ubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chK5hj0ubjJ)}(hhh]h)}(hentry in scsi_proc_list.h]hentry in scsi_proc_list.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhK5hjLubah}(h]h ]h"]h$]h&]uh1jIhj0ubeh}(h]h ]h"]h$]h&]uh1j'hjKhK5hj-ubj()}(hA``sht`` SCSI host template associated with the procfs directory. h](j.)}(h``sht``h]j4)}(hjoh]hsht}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjmubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chK6hjiubjJ)}(hhh]h)}(h8SCSI host template associated with the procfs directory.h]h8SCSI host template associated with the procfs directory.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK6hjubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j'hjhK6hj-ubj()}(hF``proc_dir`` procfs directory associated with the SCSI host template. h](j.)}(h ``proc_dir``h]j4)}(hjh]hproc_dir}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chK7hjubjJ)}(hhh]h)}(h8procfs directory associated with the SCSI host template.h]h8procfs directory associated with the SCSI host template.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK7hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhK7hj-ubj()}(h:``present`` Number of SCSI hosts instantiated for **sht**.h](j.)}(h ``present``h]j4)}(hjh]hpresent}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj߫ubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chK7hj۫ubjJ)}(hhh]h)}(h.Number of SCSI hosts instantiated for **sht**.h](h&Number of SCSI hosts instantiated for }(hjhhhNhNubj)}(h**sht**h]hsht}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chK8hjubah}(h]h ]h"]h$]h&]uh1jIhj۫ubeh}(h]h ]h"]h$]h&]uh1j'hjhK7hj-ubeh}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@#scsi_template_proc_dir (C function)c.scsi_template_proc_dirhNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(hUstruct proc_dir_entry * scsi_template_proc_dir (const struct scsi_host_template *sht)h]jP)}(hSstruct proc_dir_entry *scsi_template_proc_dir(const struct scsi_host_template *sht)h](jV)}(hjYh]hstruct}(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjIhhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKubjh)}(h h]h }(hj[hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjIhhhjZhKubh)}(hhh]j)}(hproc_dir_entryh]hproc_dir_entry}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjiubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjnmodnameN classnameNjj)}j]j)}jscsi_template_proc_dirsbc.scsi_template_proc_dirasbuh1hhjIhhhjZhKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjIhhhjZhKubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjIhhhjZhKubjy)}(hscsi_template_proc_dirh]j)}(hjh]hscsi_template_proc_dir}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjIhhhjZhKubj)}(h&(const struct scsi_host_template *sht)h]j)}(h$const struct scsi_host_template *shth](jV)}(hjNh]hconst}(hjǬhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjìubjh)}(h h]h }(hjԬhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjìubjV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjìubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjìubh)}(hhh]j)}(hscsi_host_templateh]hscsi_host_template}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.scsi_template_proc_dirasbuh1hhjìubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjìubj )}(hj h]h*}(hj,hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjìubj)}(hshth]hsht}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjìubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjIhhhjZhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjEhhhjZhKubah}(h]j@ah ](jjeh"]h$]h&]jj)jhuh1jIhjZhKhjBhhubj)}(hhh]h)}(h/returns the procfs dir for a SCSI host templateh]h/returns the procfs dir for a SCSI host template}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhj`hhubah}(h]h ]h"]h$]h&]uh1jhjBhhhjZhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj{jj{jjjuh1jDhhhjOhNhNubj)}(hV**Parameters** ``const struct scsi_host_template *sht`` SCSI host template pointer.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubj#)}(hhh]j()}(hD``const struct scsi_host_template *sht`` SCSI host template pointer.h](j.)}(h(``const struct scsi_host_template *sht``h]j4)}(hjh]h$const struct scsi_host_template *sht}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubjJ)}(hhh]h)}(hSCSI host template pointer.h]hSCSI host template pointer.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"scsi_proc_hostdir_add (C function)c.scsi_proc_hostdir_addhNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(h@int scsi_proc_hostdir_add (const struct scsi_host_template *sht)h]jP)}(h?int scsi_proc_hostdir_add(const struct scsi_host_template *sht)h](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhj hKubjy)}(hscsi_proc_hostdir_addh]j)}(hscsi_proc_hostdir_addh]hscsi_proc_hostdir_add}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhj hKubj)}(h&(const struct scsi_host_template *sht)h]j)}(h$const struct scsi_host_template *shth](jV)}(hjNh]hconst}(hj;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj7ubjh)}(h h]h }(hjHhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj7ubjV)}(hjYh]hstruct}(hjVhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj7ubjh)}(h h]h }(hjchhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj7ubh)}(hhh]j)}(hscsi_host_templateh]hscsi_host_template}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjqubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjvmodnameN classnameNjj)}j]j)}jj!sbc.scsi_proc_hostdir_addasbuh1hhj7ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj7ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj7ubj)}(hshth]hsht}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj7ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj3ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhj hKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhj hKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhj hKhjhhubj)}(hhh]h)}(h)Create directory in /proc for a scsi hosth]h)Create directory in /proc for a scsi host}(hjٮhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhj֮hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjOhNhNubj)}(h**Parameters** ``const struct scsi_host_template *sht`` owner of this directory **Description** Sets sht->proc_dir to the new directory.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubj#)}(hhh]j()}(hA``const struct scsi_host_template *sht`` owner of this directory h](j.)}(h(``const struct scsi_host_template *sht``h]j4)}(hjh]h$const struct scsi_host_template *sht}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubjJ)}(hhh]h)}(howner of this directoryh]howner of this directory}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hKhj0ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj/hKhjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjUh]h Description}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubh)}(h(Sets sht->proc_dir to the new directory.h]h(Sets sht->proc_dir to the new directory.}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!scsi_proc_hostdir_rm (C function)c.scsi_proc_hostdir_rmhNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(h@void scsi_proc_hostdir_rm (const struct scsi_host_template *sht)h]jP)}(h?void scsi_proc_hostdir_rm(const struct scsi_host_template *sht)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhKubjy)}(hscsi_proc_hostdir_rmh]j)}(hscsi_proc_hostdir_rmh]hscsi_proc_hostdir_rm}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhKubj)}(h&(const struct scsi_host_template *sht)h]j)}(h$const struct scsi_host_template *shth](jV)}(hjNh]hconst}(hjׯhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjӯubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjӯubjV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjӯubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjӯubh)}(hhh]j)}(hscsi_host_templateh]hscsi_host_template}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.scsi_proc_hostdir_rmasbuh1hhjӯubjh)}(h h]h }(hj0hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjӯubj )}(hj h]h*}(hj>hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjӯubj)}(hshth]hsht}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjӯubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjϯubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhKhjhhubj)}(hhh]h)}(h)remove directory in /proc for a scsi hosth]h)remove directory in /proc for a scsi host}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjrhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjOhNhNubj)}(hM**Parameters** ``const struct scsi_host_template *sht`` owner of directoryh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubj#)}(hhh]j()}(h;``const struct scsi_host_template *sht`` owner of directoryh](j.)}(h(``const struct scsi_host_template *sht``h]j4)}(hjh]h$const struct scsi_host_template *sht}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubjJ)}(hhh]h)}(howner of directoryh]howner of directory}(hjϰhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhj̰ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj˰hKhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_proc_host_add (C function)c.scsi_proc_host_addhNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(h1void scsi_proc_host_add (struct Scsi_Host *shost)h]jP)}(h0void scsi_proc_host_add(struct Scsi_Host *shost)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj hhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj hhhjhKubjy)}(hscsi_proc_host_addh]j)}(hscsi_proc_host_addh]hscsi_proc_host_add}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj-ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj hhhjhKubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjIubjh)}(h h]h }(hjZhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjIubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjhubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmmodnameN classnameNjj)}j]j)}jj3sbc.scsi_proc_host_addasbuh1hhjIubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjIubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjIubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjIubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjEubah}(h]h ]h"]h$]h&]jjuh1jhj hhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhKhjhhubj)}(hhh]h)}(h0Add entry for this host to appropriate /proc dirh]h0Add entry for this host to appropriate /proc dir}(hjбhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjͱhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjOhNhNubj)}(h9**Parameters** ``struct Scsi_Host *shost`` host to addh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubj#)}(hhh]j()}(h'``struct Scsi_Host *shost`` host to addh](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhj ubjJ)}(hhh]h)}(h host to addh]h host to add}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhj'ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj&hKhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_proc_host_rm (C function)c.scsi_proc_host_rmhNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(h0void scsi_proc_host_rm (struct Scsi_Host *shost)h]jP)}(h/void scsi_proc_host_rm(struct Scsi_Host *shost)h](j~)}(hvoidh]hvoid}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjghhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjghhhjyhKubjy)}(hscsi_proc_host_rmh]j)}(hscsi_proc_host_rmh]hscsi_proc_host_rm}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjghhhjyhKubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjƲhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjòubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjȲmodnameN classnameNjj)}j]j)}jjsbc.scsi_proc_host_rmasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjghhhjyhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjchhhjyhKubah}(h]j^ah ](jjeh"]h$]h&]jj)jhuh1jIhjyhKhj`hhubj)}(hhh]h)}(h#remove this host's entry from /proch]h%remove this host’s entry from /proc}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhj(hhubah}(h]h ]h"]h$]h&]uh1jhj`hhhjyhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjCjjCjjjuh1jDhhhjOhNhNubj)}(h8**Parameters** ``struct Scsi_Host *shost`` which hosth](h)}(h**Parameters**h]j)}(hjMh]h Parameters}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjGubj#)}(hhh]j()}(h&``struct Scsi_Host *shost`` which hosth](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjlh]hstruct Scsi_Host *shost}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjfubjJ)}(hhh]h)}(h which hosth]h which host}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhjubah}(h]h ]h"]h$]h&]uh1jIhjfubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjcubah}(h]h ]h"]h$]h&]uh1j"hjGubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"proc_print_scsidevice (C function)c.proc_print_scsidevicehNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(h:int proc_print_scsidevice (struct device *dev, void *data)h]jP)}(h9int proc_print_scsidevice(struct device *dev, void *data)h](j~)}(hinth]hint}(hjƳhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj³hhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM ubjh)}(h h]h }(hjճhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj³hhhjԳhM ubjy)}(hproc_print_scsideviceh]j)}(hproc_print_scsideviceh]hproc_print_scsidevice}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj³hhhjԳhM ubj)}(h (struct device *dev, void *data)h](j)}(hstruct device *devh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hdeviceh]hdevice}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj#modnameN classnameNjj)}j]j)}jjsbc.proc_print_scsideviceasbuh1hhjubjh)}(h h]h }(hjAhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjOhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hdevh]hdev}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h void *datah](j~)}(hvoidh]hvoid}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjqubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjqubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjqubj)}(hdatah]hdata}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjqubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj³hhhjԳhM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjԳhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjԳhM hjhhubj)}(hhh]h)}(hreturn data about this hosth]hreturn data about this host}(hjȴhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM hjŴhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjԳhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjOhNhNubj)}(h**Parameters** ``struct device *dev`` A scsi device ``void *data`` :c:type:`struct seq_file ` to output to. **Description** prints Host, Channel, Id, Lun, Vendor, Model, Rev, Type, and revision.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjubj#)}(hhh](j()}(h%``struct device *dev`` A scsi device h](j.)}(h``struct device *dev``h]j4)}(hj h]hstruct device *dev}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM hjubjJ)}(hhh]h)}(h A scsi deviceh]h A scsi device}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjubj()}(hB``void *data`` :c:type:`struct seq_file ` to output to. h](j.)}(h``void *data``h]j4)}(hjBh]h void *data}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj@ubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM hj<ubjJ)}(hhh]h)}(h2:c:type:`struct seq_file ` to output to.h](h)}(h$:c:type:`struct seq_file `h]j4)}(hjah]hstruct seq_file}(hjchhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hj_ubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjjseq_fileuh1hhjWhM hj[ubh to output to.}(hj[hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjWhM hjXubah}(h]h ]h"]h$]h&]uh1jIhj<ubeh}(h]h ]h"]h$]h&]uh1j'hjWhM hjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjubh)}(hFprints Host, Channel, Id, Lun, Vendor, Model, Rev, Type, and revision.h]hFprints Host, Channel, Id, Lun, Vendor, Model, Rev, Type, and revision.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@#scsi_add_single_device (C function)c.scsi_add_single_devicehNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(hGint scsi_add_single_device (uint host, uint channel, uint id, uint lun)h]jP)}(hFint scsi_add_single_device(uint host, uint channel, uint id, uint lun)h](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjݵhhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMDubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjݵhhhjhMDubjy)}(hscsi_add_single_deviceh]j)}(hscsi_add_single_deviceh]hscsi_add_single_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjݵhhhjhMDubj)}(h,(uint host, uint channel, uint id, uint lun)h](j)}(h uint hosth](h)}(hhh]j)}(huinth]huint}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj#modnameN classnameNjj)}j]j)}jjsbc.scsi_add_single_deviceasbuh1hhjubjh)}(h h]h }(hjAhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hhosth]hhost}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h uint channelh](h)}(hhh]j)}(huinth]huint}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjhubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmmodnameN classnameNjj)}j]j=c.scsi_add_single_deviceasbuh1hhjdubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjdubj)}(hchannelh]hchannel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjdubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(huint idh](h)}(hhh]j)}(huinth]huint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j=c.scsi_add_single_deviceasbuh1hhjubjh)}(h h]h }(hjѶhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hidh]hid}(hj߶hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(huint lunh](h)}(hhh]j)}(huinth]huint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j=c.scsi_add_single_deviceasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hlunh]hlun}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjݵhhhjhMDubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjٵhhhjhMDubah}(h]jԵah ](jjeh"]h$]h&]jj)jhuh1jIhjhMDhjֵhhubj)}(hhh]h)}(h/Respond to user request to probe for/add deviceh]h/Respond to user request to probe for/add device}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMDhjNhhubah}(h]h ]h"]h$]h&]uh1jhjֵhhhjhMDubeh}(h]h ](jfunctioneh"]h$]h&]jjjjijjijjjuh1jDhhhjOhNhNubj)}(hX**Parameters** ``uint host`` user-supplied decimal integer ``uint channel`` user-supplied decimal integer ``uint id`` user-supplied decimal integer ``uint lun`` user-supplied decimal integer **Description** called by writing "scsi add-single-device" to /proc/scsi/scsi. does scsi_host_lookup() and either user_scan() if that transport type supports it, or else scsi_scan_host_selected() **Note** this seems to be aimed exclusively at SCSI parallel busses.h](h)}(h**Parameters**h]j)}(hjsh]h Parameters}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMHhjmubj#)}(hhh](j()}(h,``uint host`` user-supplied decimal integer h](j.)}(h ``uint host``h]j4)}(hjh]h uint host}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMEhjubjJ)}(hhh]h)}(huser-supplied decimal integerh]huser-supplied decimal integer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMEhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMEhjubj()}(h/``uint channel`` user-supplied decimal integer h](j.)}(h``uint channel``h]j4)}(hj˷h]h uint channel}(hjͷhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjɷubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMFhjŷubjJ)}(hhh]h)}(huser-supplied decimal integerh]huser-supplied decimal integer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMFhjubah}(h]h ]h"]h$]h&]uh1jIhjŷubeh}(h]h ]h"]h$]h&]uh1j'hjhMFhjubj()}(h*``uint id`` user-supplied decimal integer h](j.)}(h ``uint id``h]j4)}(hjh]huint id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMGhjubjJ)}(hhh]h)}(huser-supplied decimal integerh]huser-supplied decimal integer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMGhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMGhjubj()}(h+``uint lun`` user-supplied decimal integer h](j.)}(h ``uint lun``h]j4)}(hj=h]huint lun}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj;ubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMHhj7ubjJ)}(hhh]h)}(huser-supplied decimal integerh]huser-supplied decimal integer}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhMHhjSubah}(h]h ]h"]h$]h&]uh1jIhj7ubeh}(h]h ]h"]h$]h&]uh1j'hjRhMHhjubeh}(h]h ]h"]h$]h&]uh1j"hjmubh)}(h**Description**h]j)}(hjxh]h Description}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMJhjmubh)}(h>called by writing "scsi add-single-device" to /proc/scsi/scsi.h]hBcalled by writing “scsi add-single-device” to /proc/scsi/scsi.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMJhjmubh)}(htdoes scsi_host_lookup() and either user_scan() if that transport type supports it, or else scsi_scan_host_selected()h]htdoes scsi_host_lookup() and either user_scan() if that transport type supports it, or else scsi_scan_host_selected()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMLhjmubh)}(h**Note**h]j)}(hjh]hNote}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMOhjmubh)}(h;this seems to be aimed exclusively at SCSI parallel busses.h]h;this seems to be aimed exclusively at SCSI parallel busses.}(hjĸhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMOhjmubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@&scsi_remove_single_device (C function)c.scsi_remove_single_devicehNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(hJint scsi_remove_single_device (uint host, uint channel, uint id, uint lun)h]jP)}(hIint scsi_remove_single_device(uint host, uint channel, uint id, uint lun)h](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMeubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMeubjy)}(hscsi_remove_single_deviceh]j)}(hscsi_remove_single_deviceh]hscsi_remove_single_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMeubj)}(h,(uint host, uint channel, uint id, uint lun)h](j)}(h uint hosth](h)}(hhh]j)}(huinth]huint}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj0ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj5modnameN classnameNjj)}j]j)}jjsbc.scsi_remove_single_deviceasbuh1hhj,ubjh)}(h h]h }(hjShhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj,ubj)}(hhosth]hhost}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(h uint channelh](h)}(hhh]j)}(huinth]huint}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjzubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jOc.scsi_remove_single_deviceasbuh1hhjvubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjvubj)}(hchannelh]hchannel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjvubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(huint idh](h)}(hhh]j)}(huinth]huint}(hjŹhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj¹ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjǹmodnameN classnameNjj)}j]jOc.scsi_remove_single_deviceasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hidh]hid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(huint lunh](h)}(hhh]j)}(huinth]huint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jOc.scsi_remove_single_deviceasbuh1hhjubjh)}(h h]h }(hj+hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hlunh]hlun}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMeubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMeubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMehjhhubj)}(hhh]h)}(h*Respond to user request to remove a deviceh]h*Respond to user request to remove a device}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMehj`hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMeubeh}(h]h ](jfunctioneh"]h$]h&]jjjj{jj{jjjuh1jDhhhjOhNhNubj)}(hXT**Parameters** ``uint host`` user-supplied decimal integer ``uint channel`` user-supplied decimal integer ``uint id`` user-supplied decimal integer ``uint lun`` user-supplied decimal integer **Description** called by writing "scsi remove-single-device" to /proc/scsi/scsi. Does a scsi_device_lookup() and scsi_remove_device()h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMihjubj#)}(hhh](j()}(h,``uint host`` user-supplied decimal integer h](j.)}(h ``uint host``h]j4)}(hjh]h uint host}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMfhjubjJ)}(hhh]h)}(huser-supplied decimal integerh]huser-supplied decimal integer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMfhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMfhjubj()}(h/``uint channel`` user-supplied decimal integer h](j.)}(h``uint channel``h]j4)}(hjݺh]h uint channel}(hjߺhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjۺubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMghj׺ubjJ)}(hhh]h)}(huser-supplied decimal integerh]huser-supplied decimal integer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMghjubah}(h]h ]h"]h$]h&]uh1jIhj׺ubeh}(h]h ]h"]h$]h&]uh1j'hjhMghjubj()}(h*``uint id`` user-supplied decimal integer h](j.)}(h ``uint id``h]j4)}(hjh]huint id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhhjubjJ)}(hhh]h)}(huser-supplied decimal integerh]huser-supplied decimal integer}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+hMhhj,ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj+hMhhjubj()}(h+``uint lun`` user-supplied decimal integer h](j.)}(h ``uint lun``h]j4)}(hjOh]huint lun}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjMubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMihjIubjJ)}(hhh]h)}(huser-supplied decimal integerh]huser-supplied decimal integer}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhMihjeubah}(h]h ]h"]h$]h&]uh1jIhjIubeh}(h]h ]h"]h$]h&]uh1j'hjdhMihjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMkhjubh)}(hwcalled by writing "scsi remove-single-device" to /proc/scsi/scsi. Does a scsi_device_lookup() and scsi_remove_device()h]h{called by writing “scsi remove-single-device” to /proc/scsi/scsi. Does a scsi_device_lookup() and scsi_remove_device()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMkhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@proc_scsi_write (C function)c.proc_scsi_writehNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(h`ssize_t proc_scsi_write (struct file *file, const char __user *buf, size_t length, loff_t *ppos)h]jP)}(h_ssize_t proc_scsi_write(struct file *file, const char __user *buf, size_t length, loff_t *ppos)h](h)}(hhh]j)}(hssize_th]hssize_t}(hjһhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjϻubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjԻmodnameN classnameNjj)}j]j)}jproc_scsi_writesbc.proc_scsi_writeasbuh1hhj˻hhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj˻hhhjhMubjy)}(hproc_scsi_writeh]j)}(hjh]hproc_scsi_write}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj˻hhhjhMubj)}(hH(struct file *file, const char __user *buf, size_t length, loff_t *ppos)h](j)}(hstruct file *fileh](jV)}(hjYh]hstruct}(hj!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hj.hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hfileh]hfile}(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj<ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjAmodnameN classnameNjj)}j]jc.proc_scsi_writeasbuh1hhjubjh)}(h h]h }(hj]hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjkhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hfileh]hfile}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst char __user *bufh](jV)}(hjNh]hconst}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj~)}(hcharh]hchar}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh__user}(hjhhhNhNubjh)}(h h]h }(hj̼hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjڼhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hbufh]hbuf}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h size_t lengthh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.proc_scsi_writeasbuh1hhjubjh)}(h h]h }(hj!hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hlengthh]hlength}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h loff_t *pposh](h)}(hhh]j)}(hloff_th]hloff_t}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjHubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjMmodnameN classnameNjj)}j]jc.proc_scsi_writeasbuh1hhjDubjh)}(h h]h }(hjihhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjDubj )}(hj h]h*}(hjwhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjDubj)}(hpposh]hppos}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjDubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj˻hhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjǻhhhjhMubah}(h]j»ah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjĻhhubj)}(hhh]h)}(h handle writes to /proc/scsi/scsih]h handle writes to /proc/scsi/scsi}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjĻhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjƽjjƽjjjuh1jDhhhjOhNhNubj)}(hX**Parameters** ``struct file *file`` not used ``const char __user *buf`` buffer to write ``size_t length`` length of buf, at most PAGE_SIZE ``loff_t *ppos`` not used **Description** this provides a legacy mechanism to add or remove devices by Host, Channel, ID, and Lun. To use, "echo 'scsi add-single-device 0 1 2 3' > /proc/scsi/scsi" or "echo 'scsi remove-single-device 0 1 2 3' > /proc/scsi/scsi" with "0 1 2 3" replaced by the Host, Channel, Id, and Lun. **Note** this seems to be aimed at parallel SCSI. Most modern busses (USB, SATA, Firewire, Fibre Channel, etc) dynamically assign these values to provide a unique identifier and nothing more.h](h)}(h**Parameters**h]j)}(hjнh]h Parameters}(hjҽhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjνubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjʽubj#)}(hhh](j()}(h``struct file *file`` not used h](j.)}(h``struct file *file``h]j4)}(hjh]hstruct file *file}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjubjJ)}(hhh]h)}(hnot usedh]hnot used}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubj()}(h+``const char __user *buf`` buffer to write h](j.)}(h``const char __user *buf``h]j4)}(hj(h]hconst char __user *buf}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj&ubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhj"ubjJ)}(hhh]h)}(hbuffer to writeh]hbuffer to write}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hMhj>ubah}(h]h ]h"]h$]h&]uh1jIhj"ubeh}(h]h ]h"]h$]h&]uh1j'hj=hMhjubj()}(h3``size_t length`` length of buf, at most PAGE_SIZE h](j.)}(h``size_t length``h]j4)}(hjah]h size_t length}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj_ubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhj[ubjJ)}(hhh]h)}(h length of buf, at most PAGE_SIZEh]h length of buf, at most PAGE_SIZE}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMhjwubah}(h]h ]h"]h$]h&]uh1jIhj[ubeh}(h]h ]h"]h$]h&]uh1j'hjvhMhjubj()}(h``loff_t *ppos`` not used h](j.)}(h``loff_t *ppos``h]j4)}(hjh]h loff_t *ppos}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjubjJ)}(hhh]h)}(hnot usedh]hnot used}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubeh}(h]h ]h"]h$]h&]uh1j"hjʽubh)}(h**Description**h]j)}(hjվh]h Description}(hj׾hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjӾubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjʽubh)}(hXthis provides a legacy mechanism to add or remove devices by Host, Channel, ID, and Lun. To use, "echo 'scsi add-single-device 0 1 2 3' > /proc/scsi/scsi" or "echo 'scsi remove-single-device 0 1 2 3' > /proc/scsi/scsi" with "0 1 2 3" replaced by the Host, Channel, Id, and Lun.h]hX*this provides a legacy mechanism to add or remove devices by Host, Channel, ID, and Lun. To use, “echo ‘scsi add-single-device 0 1 2 3’ > /proc/scsi/scsi” or “echo ‘scsi remove-single-device 0 1 2 3’ > /proc/scsi/scsi” with “0 1 2 3” replaced by the Host, Channel, Id, and Lun.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjʽubh)}(h**Note**h]j)}(hjh]hNote}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjʽubh)}(hthis seems to be aimed at parallel SCSI. Most modern busses (USB, SATA, Firewire, Fibre Channel, etc) dynamically assign these values to provide a unique identifier and nothing more.h]hthis seems to be aimed at parallel SCSI. Most modern busses (USB, SATA, Firewire, Fibre Channel, etc) dynamically assign these values to provide a unique identifier and nothing more.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjʽubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@proc_scsi_open (C function)c.proc_scsi_openhNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(h;int proc_scsi_open (struct inode *inode, struct file *file)h]jP)}(h:int proc_scsi_open(struct inode *inode, struct file *file)h](j~)}(hinth]hint}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj=hhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM ubjh)}(h h]h }(hjPhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj=hhhjOhM ubjy)}(hproc_scsi_openh]j)}(hproc_scsi_openh]hproc_scsi_open}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj^ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj=hhhjOhM ubj)}(h((struct inode *inode, struct file *file)h](j)}(hstruct inode *inodeh](jV)}(hjYh]hstruct}(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjzubh)}(hhh]j)}(hinodeh]hinode}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjdsbc.proc_scsi_openasbuh1hhjzubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjzubj )}(hj h]h*}(hjʿhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjzubj)}(hinodeh]hinode}(hj׿hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvubj)}(hstruct file *fileh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hfileh]hfile}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.proc_scsi_openasbuh1hhjubjh)}(h h]h }(hj,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hj:hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hfileh]hfile}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvubeh}(h]h ]h"]h$]h&]jjuh1jhj=hhhjOhM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj9hhhjOhM ubah}(h]j4ah ](jjeh"]h$]h&]jj)jhuh1jIhjOhM hj6hhubj)}(hhh]h)}(h glue functionh]h glue function}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM hjnhhubah}(h]h ]h"]h$]h&]uh1jhj6hhhjOhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjOhNhNubj)}(h**Parameters** ``struct inode *inode`` not used ``struct file *file`` passed to single_open() **Description** Associates proc_scsi_show with this fileh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjubj#)}(hhh](j()}(h!``struct inode *inode`` not used h](j.)}(h``struct inode *inode``h]j4)}(hjh]hstruct inode *inode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM hjubjJ)}(hhh]h)}(hnot usedh]hnot used}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjubj()}(h.``struct file *file`` passed to single_open() h](j.)}(h``struct file *file``h]j4)}(hjh]hstruct file *file}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM hjubjJ)}(hhh]h)}(hpassed to single_open()h]hpassed to single_open()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hj&h]h Description}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjubh)}(h(Associates proc_scsi_show with this fileh]h(Associates proc_scsi_show with this file}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_init_procfs (C function)c.scsi_init_procfshNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(hint scsi_init_procfs (void)h]jP)}(hint scsi_init_procfs(void)h](j~)}(hinth]hint}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjghhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM#ubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjghhhjyhM#ubjy)}(hscsi_init_procfsh]j)}(hscsi_init_procfsh]hscsi_init_procfs}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjghhhjyhM#ubj)}(h(void)h]j)}(hvoidh]j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubah}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjghhhjyhM#ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjchhhjyhM#ubah}(h]j^ah ](jjeh"]h$]h&]jj)jhuh1jIhjyhM#hj`hhubj)}(hhh]h)}(h#create scsi and scsi/scsi in procfsh]h#create scsi and scsi/scsi in procfs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM#hjhhubah}(h]h ]h"]h$]h&]uh1jhj`hhhjyhM#ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjOhNhNubj)}(h'**Parameters** ``void`` no argumentsh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM'hjubj#)}(hhh]j()}(h``void`` no argumentsh](j.)}(h``void``h]j4)}(hjh]hvoid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM)hj ubjJ)}(hhh]h)}(h no argumentsh]h no arguments}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhj)ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj(hM)hj ubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_exit_procfs (C function)c.scsi_exit_procfshNtauh1j3hjOhhhNhNubjE)}(hhh](jJ)}(hvoid scsi_exit_procfs (void)h]jP)}(hvoid scsi_exit_procfs(void)h](j~)}(hvoidh]hvoid}(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjihhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM:ubjh)}(h h]h }(hj|hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjihhhj{hM:ubjy)}(hscsi_exit_procfsh]j)}(hscsi_exit_procfsh]hscsi_exit_procfs}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjihhhj{hM:ubj)}(h(void)h]j)}(hvoidh]j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubah}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjihhhj{hM:ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjehhhj{hM:ubah}(h]j`ah ](jjeh"]h$]h&]jj)jhuh1jIhj{hM:hjbhhubj)}(hhh]h)}(h%Remove scsi/scsi and scsi from procfsh]h%Remove scsi/scsi and scsi from procfs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM:hjhhubah}(h]h ]h"]h$]h&]uh1jhjbhhhj{hM:ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjOhNhNubj)}(h'**Parameters** ``void`` no argumentsh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM>hjubj#)}(hhh]j()}(h``void`` no argumentsh](j.)}(h``void``h]j4)}(hjh]hvoid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chM@hjubjJ)}(hhh]h)}(h no argumentsh]h no arguments}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:164: ./drivers/scsi/scsi_proc.chKhj+ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj*hM@hj ubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubeh}(h]drivers-scsi-scsi-proc-cah ]h"]drivers/scsi/scsi_proc.cah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hdrivers/scsi/scsi_netlink.ch]hdrivers/scsi/scsi_netlink.c}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hhhhhKubh)}(hXInfrastructure to provide async events from transports to userspace via netlink, using a single NETLINK_SCSITRANSPORT protocol for all transports. See `the original patch submission `__ for more details.h](hInfrastructure to provide async events from transports to userspace via netlink, using a single NETLINK_SCSITRANSPORT protocol for all transports. See }(hjohhhNhNubjn)}(hu`the original patch submission `__h]hthe original patch submission}(hjwhhhNhNubah}(h]h ]h"]h$]h&]namethe original patch submissionjQhttps://lore.kernel.org/linux-scsi/1155070439.6275.5.camel@localhost.localdomain/uh1jmhjoubh for more details.}(hjohhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhj^hhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_nl_rcv_msg (C function)c.scsi_nl_rcv_msghNtauh1j3hj^hhhNhNubjE)}(hhh](jJ)}(h*void scsi_nl_rcv_msg (struct sk_buff *skb)h]jP)}(h)void scsi_nl_rcv_msg(struct sk_buff *skb)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhKubjy)}(hscsi_nl_rcv_msgh]j)}(hscsi_nl_rcv_msgh]hscsi_nl_rcv_msg}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhKubj)}(h(struct sk_buff *skb)h]j)}(hstruct sk_buff *skbh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.scsi_nl_rcv_msgasbuh1hhjubjh)}(h h]h }(hj&hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hj4hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hskbh]hskb}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhKhjhhubj)}(hhh]h)}(hReceive message handler.h]hReceive message handler.}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjhhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhj^hNhNubj)}(h**Parameters** ``struct sk_buff *skb`` socket receive buffer **Description** Extracts message from a receive buffer. Validates message header and calls appropriate transport message handlerh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjubj#)}(hhh]j()}(h.``struct sk_buff *skb`` socket receive buffer h](j.)}(h``struct sk_buff *skb``h]j4)}(hjh]hstruct sk_buff *skb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjubjJ)}(hhh]h)}(hsocket receive bufferh]hsocket receive buffer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjubj#)}(hhh]j()}(hpExtracts message from a receive buffer. Validates message header and calls appropriate transport message handlerh](j.)}(h'Extracts message from a receive buffer.h]h'Extracts message from a receive buffer.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjubjJ)}(hhh]h)}(hHValidates message header and calls appropriate transport message handlerh]hHValidates message header and calls appropriate transport message handler}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_netlink_init (C function)c.scsi_netlink_inithNtauh1j3hj^hhhNhNubjE)}(hhh](jJ)}(hvoid scsi_netlink_init (void)h]jP)}(hvoid scsi_netlink_init(void)h](j~)}(hvoidh]hvoid}(hjWhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjShhh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKkubjh)}(h h]h }(hjfhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjShhhjehKkubjy)}(hscsi_netlink_inith]j)}(hscsi_netlink_inith]hscsi_netlink_init}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjtubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjShhhjehKkubj)}(h(void)h]j)}(hvoidh]j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubah}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjShhhjehKkubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjOhhhjehKkubah}(h]jJah ](jjeh"]h$]h&]jj)jhuh1jIhjehKkhjLhhubj)}(hhh]h)}(hKCalled by SCSI subsystem to initialize the SCSI transport netlink interfaceh]hKCalled by SCSI subsystem to initialize the SCSI transport netlink interface}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKkhjhhubah}(h]h ]h"]h$]h&]uh1jhjLhhhjehKkubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhj^hNhNubj)}(h'**Parameters** ``void`` no argumentsh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKohjubj#)}(hhh]j()}(h``void`` no argumentsh](j.)}(h``void``h]j4)}(hjh]hvoid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKqhjubjJ)}(hhh]h)}(h no argumentsh]h no arguments}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKqhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_netlink_exit (C function)c.scsi_netlink_exithNtauh1j3hj^hhhNhNubjE)}(hhh](jJ)}(hvoid scsi_netlink_exit (void)h]jP)}(hvoid scsi_netlink_exit(void)h](j~)}(hvoidh]hvoid}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjUhhh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKubjh)}(h h]h }(hjhhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjUhhhjghKubjy)}(hscsi_netlink_exith]j)}(hscsi_netlink_exith]hscsi_netlink_exit}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjvubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjUhhhjghKubj)}(h(void)h]j)}(hvoidh]j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubah}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjUhhhjghKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjQhhhjghKubah}(h]jLah ](jjeh"]h$]h&]jj)jhuh1jIhjghKhjNhhubj)}(hhh]h)}(hHCalled by SCSI subsystem to disable the SCSI transport netlink interfaceh]hHCalled by SCSI subsystem to disable the SCSI transport netlink interface}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjhhubah}(h]h ]h"]h$]h&]uh1jhjNhhhjghKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhj^hNhNubj)}(h'**Parameters** ``void`` no argumentsh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjubj#)}(hhh]j()}(h``void`` no argumentsh](j.)}(h``void``h]j4)}(hjh]hvoid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjubjJ)}(hhh]h)}(h no argumentsh]h no arguments}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:175: ./drivers/scsi/scsi_netlink.chKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^hhhNhNubeh}(h]drivers-scsi-scsi-netlink-cah ]h"]drivers/scsi/scsi_netlink.cah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hdrivers/scsi/scsi_scan.ch]hdrivers/scsi/scsi_scan.c}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhhhhhKubh)}(hX5Scan a host to determine which (if any) devices are attached. The general scanning/probing algorithm is as follows, exceptions are made to it depending on device specific flags, compilation options, and global variable (boot or module load time) settings. A specific LUN is scanned via an INQUIRY command; if the LUN has a device attached, a scsi_device is allocated and setup for it. For every id of every channel on the given host, start by scanning LUN 0. Skip hosts that don't respond at all to a scan of LUN 0. Otherwise, if LUN 0 has a device attached, allocate and setup a scsi_device for it. If target is SCSI-3 or up, issue a REPORT LUN, and scan all of the LUNs returned by the REPORT LUN; else, sequentially scan LUNs up until some maximum is reached, or a LUN is seen that cannot have a device attached to it.h]hX7Scan a host to determine which (if any) devices are attached. The general scanning/probing algorithm is as follows, exceptions are made to it depending on device specific flags, compilation options, and global variable (boot or module load time) settings. A specific LUN is scanned via an INQUIRY command; if the LUN has a device attached, a scsi_device is allocated and setup for it. For every id of every channel on the given host, start by scanning LUN 0. Skip hosts that don’t respond at all to a scan of LUN 0. Otherwise, if LUN 0 has a device attached, allocate and setup a scsi_device for it. If target is SCSI-3 or up, issue a REPORT LUN, and scan all of the LUNs returned by the REPORT LUN; else, sequentially scan LUNs up until some maximum is reached, or a LUN is seen that cannot have a device attached to it.}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjJhhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@)scsi_sanitize_inquiry_string (C function)c.scsi_sanitize_inquiry_stringhNtauh1j3hjJhhhNhNubjE)}(hhh](jJ)}(h=void scsi_sanitize_inquiry_string (unsigned char *s, int len)h]jP)}(hubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:194: ./drivers/scsi/scsi_scan.chMihj:ubjJ)}(hhh]h)}(h. Scan at least LUN 0, and possibly all LUNs on the target id.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:194: ./drivers/scsi/scsi_scan.chMhjubh)}(hmFirst try a REPORT LUN scan, if that does not scan the target, do a sequential scan of LUNs on the target id.h]hmFirst try a REPORT LUN scan, if that does not scan the target, do a sequential scan of LUNs on the target id.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:194: ./drivers/scsi/scsi_scan.chMhjubeh}(h]h ]h"]h$]h&]uh1j_hjhMhj%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjJhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_scan_host (C function)c.scsi_scan_hosthNtauh1j3hjJhhhNhNubjE)}(hhh](jJ)}(h-void scsi_scan_host (struct Scsi_Host *shost)h]jP)}(h,void scsi_scan_host(struct Scsi_Host *shost)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:194: ./drivers/scsi/scsi_scan.chMubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhj hMubjy)}(hscsi_scan_hosth]j)}(hscsi_scan_hosth]hscsi_scan_host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhj hMubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj7ubjh)}(h h]h }(hjHhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj7ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjVubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj[modnameN classnameNjj)}j]j)}jj!sbc.scsi_scan_hostasbuh1hhj7ubjh)}(h h]h }(hjyhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj7ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj7ubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj7ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj3ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhj hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhj hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhj hMhjhhubj)}(hhh]h)}(hscan the given adapterh]hscan the given adapter}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:194: ./drivers/scsi/scsi_scan.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjJhNhNubj)}(hp**Parameters** ``struct Scsi_Host *shost`` adapter to scan **Notes** Should be called after scsi_add_host()h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:194: ./drivers/scsi/scsi_scan.chMhjubj#)}(hhh]j()}(h,``struct Scsi_Host *shost`` adapter to scan h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:194: ./drivers/scsi/scsi_scan.chMhjubjJ)}(hhh]h)}(hadapter to scanh]hadapter to scan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h **Notes**h]j)}(hj:h]hNotes}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:194: ./drivers/scsi/scsi_scan.chMhjubh)}(h&Should be called after scsi_add_host()h]h&Should be called after scsi_add_host()}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:194: ./drivers/scsi/scsi_scan.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjJhhhNhNubeh}(h]drivers-scsi-scsi-scan-cah ]h"]drivers/scsi/scsi_scan.cah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hdrivers/scsi/scsi_sysctl.ch]hdrivers/scsi/scsi_sysctl.c}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhhhhhKubh)}(hrSet up the sysctl entry: "/dev/scsi/logging_level" (DEV_SCSI_LOGGING_LEVEL) which sets/returns scsi_logging_level.h]hvSet up the sysctl entry: “/dev/scsi/logging_level” (DEV_SCSI_LOGGING_LEVEL) which sets/returns scsi_logging_level.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjnhhubeh}(h]drivers-scsi-scsi-sysctl-cah ]h"]drivers/scsi/scsi_sysctl.cah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hdrivers/scsi/scsi_sysfs.ch]hdrivers/scsi/scsi_sysfs.c}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(hSCSI sysfs interface routines.h]hSCSI sysfs interface routines.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_remove_device (C function)c.scsi_remove_devicehNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h2void scsi_remove_device (struct scsi_device *sdev)h]jP)}(h1void scsi_remove_device(struct scsi_device *sdev)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMubjy)}(hscsi_remove_deviceh]j)}(hscsi_remove_deviceh]hscsi_remove_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj%ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*modnameN classnameNjj)}j]j)}jjsbc.scsi_remove_deviceasbuh1hhjubjh)}(h h]h }(hjHhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjVhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hsdevh]hsdev}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjhhubj)}(hhh]h)}(h%unregister a device from the scsi bush]h%unregister a device from the scsi bus}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hH**Parameters** ``struct scsi_device *sdev`` scsi_device to unregisterh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chMhjubj#)}(hhh]j()}(h6``struct scsi_device *sdev`` scsi_device to unregisterh](j.)}(h``struct scsi_device *sdev``h]j4)}(hjh]hstruct scsi_device *sdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chMhjubjJ)}(hhh]h)}(hscsi_device to unregisterh]hscsi_device to unregister}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_remove_target (C function)c.scsi_remove_targethNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h,void scsi_remove_target (struct device *dev)h]jP)}(h+void scsi_remove_target(struct device *dev)h](j~)}(hvoidh]hvoid}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj$hhhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chM(ubjh)}(h h]h }(hj7hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj$hhhj6hM(ubjy)}(hscsi_remove_targeth]j)}(hscsi_remove_targeth]hscsi_remove_target}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj$hhhj6hM(ubj)}(h(struct device *dev)h]j)}(hstruct device *devh](jV)}(hjYh]hstruct}(hjehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjaubjh)}(h h]h }(hjrhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjaubh)}(hhh]j)}(hdeviceh]hdevice}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjKsbc.scsi_remove_targetasbuh1hhjaubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjaubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjaubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjaubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubah}(h]h ]h"]h$]h&]jjuh1jhj$hhhj6hM(ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj hhhj6hM(ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhj6hM(hjhhubj)}(hhh]h)}(h*try to remove a target and all its devicesh]h*try to remove a target and all its devices}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chM(hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj6hM(ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(h**Parameters** ``struct device *dev`` generic starget or parent of generic stargets to be removed **Note** This is slightly racy. It is possible that if the user requests the addition of another device then the target won't be removed.h](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chM,hjubj#)}(hhh]j()}(hS``struct device *dev`` generic starget or parent of generic stargets to be removed h](j.)}(h``struct device *dev``h]j4)}(hj)h]hstruct device *dev}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj'ubah}(h]h ]h"]h$]h&]uh1j-hZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chM)hj#ubjJ)}(hhh]h)}(h;generic starget or parent of generic stargets to be removedh]h;generic starget or parent of generic stargets to be removed}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hM)hj?ubah}(h]h ]h"]h$]h&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j'hj>hM)hj ubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Note**h]j)}(hjdh]hNote}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chM+hjubh)}(hThis is slightly racy. It is possible that if the user requests the addition of another device then the target won't be removed.h]hThis is slightly racy. It is possible that if the user requests the addition of another device then the target won’t be removed.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:208: ./drivers/scsi/scsi_sysfs.chM+hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h]drivers-scsi-scsi-sysfs-cah ]h"]drivers/scsi/scsi_sysfs.cah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hdrivers/scsi/hosts.ch]hdrivers/scsi/hosts.c}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(h%mid to lowlevel SCSI driver interfaceh]h%mid to lowlevel SCSI driver interface}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_remove_host (C function)c.scsi_remove_hosthNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h/void scsi_remove_host (struct Scsi_Host *shost)h]jP)}(h.void scsi_remove_host(struct Scsi_Host *shost)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhKubjy)}(hscsi_remove_hosth]j)}(hscsi_remove_hosth]hscsi_remove_host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhKubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj-modnameN classnameNjj)}j]j)}jjsbc.scsi_remove_hostasbuh1hhj ubjh)}(h h]h }(hjKhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj )}(hj h]h*}(hjYhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj ubj)}(hshosth]hshost}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhKhjhhubj)}(hhh]h)}(hremove a scsi hosth]hremove a scsi host}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hP**Parameters** ``struct Scsi_Host *shost`` a pointer to a scsi host to removeh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjubj#)}(hhh]j()}(h>``struct Scsi_Host *shost`` a pointer to a scsi host to removeh](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjubjJ)}(hhh]h)}(h"a pointer to a scsi host to removeh]h"a pointer to a scsi host to remove}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@#scsi_add_host_with_dma (C function)c.scsi_add_host_with_dmahNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h`int scsi_add_host_with_dma (struct Scsi_Host *shost, struct device *dev, struct device *dma_dev)h]jP)}(h_int scsi_add_host_with_dma(struct Scsi_Host *shost, struct device *dev, struct device *dma_dev)h](j~)}(hinth]hint}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj'hhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKubjh)}(h h]h }(hj:hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj'hhhj9hKubjy)}(hscsi_add_host_with_dmah]j)}(hscsi_add_host_with_dmah]hscsi_add_host_with_dma}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjHubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj'hhhj9hKubj)}(hE(struct Scsi_Host *shost, struct device *dev, struct device *dma_dev)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubjh)}(h h]h }(hjuhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjdubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjNsbc.scsi_add_host_with_dmaasbuh1hhjdubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjdubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjdubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjdubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubj)}(hstruct device *devh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hdeviceh]hdevice}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.scsi_add_host_with_dmaasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hj$hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hdevh]hdev}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubj)}(hstruct device *dma_devh](jV)}(hjYh]hstruct}(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubjh)}(h h]h }(hjWhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjFubh)}(hhh]j)}(hdeviceh]hdevice}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjeubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjmodnameN classnameNjj)}j]jc.scsi_add_host_with_dmaasbuh1hhjFubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjFubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjFubj)}(hdma_devh]hdma_dev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjFubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubeh}(h]h ]h"]h$]h&]jjuh1jhj'hhhj9hKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj#hhhj9hKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhj9hKhj hhubj)}(hhh]h)}(hadd a scsi host with dma deviceh]hadd a scsi host with dma device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjhhubah}(h]h ]h"]h$]h&]uh1jhj hhhj9hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` scsi host pointer to add ``struct device *dev`` a struct device of type scsi class ``struct device *dma_dev`` dma device for the host **Note** You rarely need to worry about this unless you're in a virtualised host environments, so use the simpler scsi_add_host() function instead. **Description** Return value: 0 on success / != 0 for errorh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjubj#)}(hhh](j()}(h5``struct Scsi_Host *shost`` scsi host pointer to add h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj h]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjubjJ)}(hhh]h)}(hscsi host pointer to addLh]hscsi host pointer to add}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hKhj"ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj!hKhjubj()}(h:``struct device *dev`` a struct device of type scsi class h](j.)}(h``struct device *dev``h]j4)}(hjEh]hstruct device *dev}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjCubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhj?ubjJ)}(hhh]h)}(h"a struct device of type scsi classh]h"a struct device of type scsi class}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhKhj[ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j'hjZhKhjubj()}(h3``struct device *dma_dev`` dma device for the host h](j.)}(h``struct device *dma_dev``h]j4)}(hj~h]hstruct device *dma_dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj|ubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjxubjJ)}(hhh]h)}(hdma device for the hosth]hdma device for the host}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjxubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Note**h]j)}(hjh]hNote}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjubh)}(hYou rarely need to worry about this unless you're in a virtualised host environments, so use the simpler scsi_add_host() function instead.h]hYou rarely need to worry about this unless you’re in a virtualised host environments, so use the simpler scsi_add_host() function instead.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjubj#)}(hhh]j()}(h+Return value: 0 on success / != 0 for errorh](j.)}(h Return value:h]h Return value:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhjubjJ)}(hhh]h)}(h0 on success / != 0 for errorh]h0 on success / != 0 for error}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chKhj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj hKhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_host_alloc (C function)c.scsi_host_allochNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hWstruct Scsi_Host * scsi_host_alloc (const struct scsi_host_template *sht, int privsize)h]jP)}(hUstruct Scsi_Host *scsi_host_alloc(const struct scsi_host_template *sht, int privsize)h](jV)}(hjYh]hstruct}(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLhhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM|ubjh)}(h h]h }(hj^hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjLhhhj]hM|ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjlubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqmodnameN classnameNjj)}j]j)}jscsi_host_allocsbc.scsi_host_allocasbuh1hhjLhhhj]hM|ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjLhhhj]hM|ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjLhhhj]hM|ubjy)}(hscsi_host_alloch]j)}(hjh]hscsi_host_alloc}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjLhhhj]hM|ubj)}(h4(const struct scsi_host_template *sht, int privsize)h](j)}(h$const struct scsi_host_template *shth](jV)}(hjNh]hconst}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubjV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hscsi_host_templateh]hscsi_host_template}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.scsi_host_allocasbuh1hhjubjh)}(h h]h }(hj!hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hj/hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshth]hsht}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int privsizeh](j~)}(hinth]hint}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjQubjh)}(h h]h }(hjchhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjQubj)}(hprivsizeh]hprivsize}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjQubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjLhhhj]hM|ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjHhhhj]hM|ubah}(h]jCah ](jjeh"]h$]h&]jj)jhuh1jIhj]hM|hjEhhubj)}(hhh]h)}(h®ister a scsi host adapter instance.h]h®ister a scsi host adapter instance.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM|hjhhubah}(h]h ]h"]h$]h&]uh1jhjEhhhj]hM|ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hXr**Parameters** ``const struct scsi_host_template *sht`` pointer to scsi host template ``int privsize`` extra bytes to allocate for driver **Note** Allocate a new Scsi_Host and perform basic initialization. The host is not published to the scsi midlayer until scsi_add_host is called. **Description** Return value: Pointer to a new Scsi_Hosth](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubj#)}(hhh](j()}(hG``const struct scsi_host_template *sht`` pointer to scsi host template h](j.)}(h(``const struct scsi_host_template *sht``h]j4)}(hjh]h$const struct scsi_host_template *sht}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM}hjubjJ)}(hhh]h)}(hpointer to scsi host templateh]hpointer to scsi host template}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM}hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM}hjubj()}(h4``int privsize`` extra bytes to allocate for driver h](j.)}(h``int privsize``h]j4)}(hjh]h int privsize}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM~hjubjJ)}(hhh]h)}(h"extra bytes to allocate for driverh]h"extra bytes to allocate for driver}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hM~hj+ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj*hM~hjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Note**h]j)}(hjPh]hNote}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubj`)}(hAllocate a new Scsi_Host and perform basic initialization. The host is not published to the scsi midlayer until scsi_add_host is called. h]h)}(hAllocate a new Scsi_Host and perform basic initialization. The host is not published to the scsi midlayer until scsi_add_host is called.h]hAllocate a new Scsi_Host and perform basic initialization. The host is not published to the scsi midlayer until scsi_add_host is called.}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjfubah}(h]h ]h"]h$]h&]uh1j_hjxhMhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubj#)}(hhh]j()}(h(Return value: Pointer to a new Scsi_Hosth](j.)}(h Return value:h]h Return value:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubjJ)}(hhh]h)}(hPointer to a new Scsi_Hosth]hPointer to a new Scsi_Host}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_host_lookup (C function)c.scsi_host_lookuphNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h:struct Scsi_Host * scsi_host_lookup (unsigned int hostnum)h]jP)}(h8struct Scsi_Host *scsi_host_lookup(unsigned int hostnum)h](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM-ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM-ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jscsi_host_lookupsbc.scsi_host_lookupasbuh1hhjhhhjhM-ubjh)}(h h]h }(hj1hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM-ubj )}(hj h]h*}(hj?hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjhhhjhM-ubjy)}(hscsi_host_lookuph]j)}(hj.h]hscsi_host_lookup}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjLubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhM-ubj)}(h(unsigned int hostnum)h]j)}(hunsigned int hostnumh](j~)}(hunsignedh]hunsigned}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjgubjh)}(h h]h }(hjyhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjgubj~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjgubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjgubj)}(hhostnumh]hhostnum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjgubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjcubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM-ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM-ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhM-hjhhubj)}(hhh]h)}(h)get a reference to a Scsi_Host by host noh]h)get a reference to a Scsi_Host by host no}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM-hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM-ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hX:**Parameters** ``unsigned int hostnum`` host number to locate **Description** Return value: A pointer to located Scsi_Host or NULL. The caller must do a scsi_host_put() to drop the reference that scsi_host_get() took. The put_device() below dropped the reference from class_find_device().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM1hjubj#)}(hhh]j()}(h/``unsigned int hostnum`` host number to locate h](j.)}(h``unsigned int hostnum``h]j4)}(hjh]hunsigned int hostnum}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM.hjubjJ)}(hhh]h)}(hhost number to locateh]hhost number to locate}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hM.hj$ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj#hM.hjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjIh]h Description}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM0hjubj#)}(hhh]j()}(hReturn value: A pointer to located Scsi_Host or NULL. The caller must do a scsi_host_put() to drop the reference that scsi_host_get() took. The put_device() below dropped the reference from class_find_device().h](j.)}(h Return value:h]h Return value:}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM4hjbubjJ)}(hhh](h)}(h'A pointer to located Scsi_Host or NULL.h]h'A pointer to located Scsi_Host or NULL.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM1hjuubh)}(hThe caller must do a scsi_host_put() to drop the reference that scsi_host_get() took. The put_device() below dropped the reference from class_find_device().h]hThe caller must do a scsi_host_put() to drop the reference that scsi_host_get() took. The put_device() below dropped the reference from class_find_device().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM3hjuubeh}(h]h ]h"]h$]h&]uh1jIhjbubeh}(h]h ]h"]h$]h&]uh1j'hjthM4hj_ubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_host_get (C function)c.scsi_host_gethNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h:struct Scsi_Host * scsi_host_get (struct Scsi_Host *shost)h]jP)}(h8struct Scsi_Host *scsi_host_get(struct Scsi_Host *shost)h](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMGubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMGubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}j scsi_host_getsbc.scsi_host_getasbuh1hhjhhhjhMGubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMGubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjhhhjhMGubjy)}(h scsi_host_geth]j)}(hjh]h scsi_host_get}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj#ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMGubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>ubjh)}(h h]h }(hjOhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjbmodnameN classnameNjj)}j]jc.scsi_host_getasbuh1hhj>ubjh)}(h h]h }(hj~hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj>ubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj>ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMGubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMGubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMGhjhhubj)}(hhh]h)}(hinc a Scsi_Host ref counth]hinc a Scsi_Host ref count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMGhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMGubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hJ**Parameters** ``struct Scsi_Host *shost`` Pointer to Scsi_Host to inc.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMKhjubj#)}(hhh]j()}(h8``struct Scsi_Host *shost`` Pointer to Scsi_Host to inc.h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMMhjubjJ)}(hhh]h)}(hPointer to Scsi_Host to inc.h]hPointer to Scsi_Host to inc.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMHhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMMhjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_host_busy (C function)c.scsi_host_busyhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h,int scsi_host_busy (struct Scsi_Host *shost)h]jP)}(h+int scsi_host_busy(struct Scsi_Host *shost)h](j~)}(hinth]hint}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjZhhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM_ubjh)}(h h]h }(hjmhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjZhhhjlhM_ubjy)}(hscsi_host_busyh]j)}(hscsi_host_busyh]hscsi_host_busy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj{ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjZhhhjlhM_ubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.scsi_host_busyasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjZhhhjlhM_ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjVhhhjlhM_ubah}(h]jQah ](jjeh"]h$]h&]jj)jhuh1jIhjlhM_hjShhubj)}(hhh]h)}(hReturn the host busy counterh]hReturn the host busy counter}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM_hjhhubah}(h]h ]h"]h$]h&]uh1jhjShhhjlhM_ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj6jj6jjjuh1jDhhhjhNhNubj)}(hJ**Parameters** ``struct Scsi_Host *shost`` Pointer to Scsi_Host to inc.h](h)}(h**Parameters**h]j)}(hj@h]h Parameters}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMchj:ubj#)}(hhh]j()}(h8``struct Scsi_Host *shost`` Pointer to Scsi_Host to inc.h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj_h]hstruct Scsi_Host *shost}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj]ubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMehjYubjJ)}(hhh]h)}(hPointer to Scsi_Host to inc.h]hPointer to Scsi_Host to inc.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chM`hjuubah}(h]h ]h"]h$]h&]uh1jIhjYubeh}(h]h ]h"]h$]h&]uh1j'hjthMehjVubah}(h]h ]h"]h$]h&]uh1j"hj:ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_host_put (C function)c.scsi_host_puthNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h,void scsi_host_put (struct Scsi_Host *shost)h]jP)}(h+void scsi_host_put(struct Scsi_Host *shost)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMmubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMmubjy)}(h scsi_host_puth]j)}(h scsi_host_puth]h scsi_host_put}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMmubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.scsi_host_putasbuh1hhjubjh)}(h h]h }(hj4hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjBhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMmubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMmubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMmhjhhubj)}(hhh]h)}(hdec a Scsi_Host ref counth]hdec a Scsi_Host ref count}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMmhjvhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMmubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hJ**Parameters** ``struct Scsi_Host *shost`` Pointer to Scsi_Host to dec.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMqhjubj#)}(hhh]j()}(h8``struct Scsi_Host *shost`` Pointer to Scsi_Host to dec.h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMshjubjJ)}(hhh]h)}(hPointer to Scsi_Host to dec.h]hPointer to Scsi_Host to dec.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMnhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMshjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_queue_work (C function)c.scsi_queue_workhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hGint scsi_queue_work (struct Scsi_Host *shost, struct work_struct *work)h]jP)}(hFint scsi_queue_work(struct Scsi_Host *shost, struct work_struct *work)h](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMubjh)}(h h]h }(hj#hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhj"hMubjy)}(hscsi_queue_workh]j)}(hscsi_queue_workh]hscsi_queue_work}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj1ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhj"hMubj)}(h3(struct Scsi_Host *shost, struct work_struct *work)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjQhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjMubjh)}(h h]h }(hj^hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjMubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjlubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqmodnameN classnameNjj)}j]j)}jj7sbc.scsi_queue_workasbuh1hhjMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjMubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjMubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjMubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubj)}(hstruct work_struct *workh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h work_structh]h work_struct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.scsi_queue_workasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hworkh]hwork}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj"hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj hhhj"hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhj"hMhj hhubj)}(hhh]h)}(h&Queue work to the Scsi_Host workqueue.h]h&Queue work to the Scsi_Host workqueue.}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjAhhubah}(h]h ]h"]h$]h&]uh1jhj hhhj"hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj\jj\jjjuh1jDhhhjhNhNubj)}(hX **Parameters** ``struct Scsi_Host *shost`` Pointer to Scsi_Host. ``struct work_struct *work`` Work to queue for execution. **Description** Return value: 1 - work queued for execution 0 - work is already queued -EINVAL - work queue doesn't existh](h)}(h**Parameters**h]j)}(hjfh]h Parameters}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhj`ubj#)}(hhh](j()}(h2``struct Scsi_Host *shost`` Pointer to Scsi_Host. h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubjJ)}(hhh]h)}(hPointer to Scsi_Host.h]hPointer to Scsi_Host.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhj|ubj()}(h:``struct work_struct *work`` Work to queue for execution. h](j.)}(h``struct work_struct *work``h]j4)}(hjh]hstruct work_struct *work}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubjJ)}(hhh]h)}(hWork to queue for execution.h]hWork to queue for execution.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhj|ubeh}(h]h ]h"]h$]h&]uh1j"hj`ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhj`ubj#)}(hhh]j()}(hiReturn value: 1 - work queued for execution 0 - work is already queued -EINVAL - work queue doesn't existh](j.)}(h Return value:h]h Return value:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubjJ)}(hhh]h)}(h[1 - work queued for execution 0 - work is already queued -EINVAL - work queue doesn't existh]h]1 - work queued for execution 0 - work is already queued -EINVAL - work queue doesn’t exist}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhj%ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj$hMhjubah}(h]h ]h"]h$]h&]uh1j"hj`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_flush_work (C function)c.scsi_flush_workhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h.void scsi_flush_work (struct Scsi_Host *shost)h]jP)}(h-void scsi_flush_work(struct Scsi_Host *shost)h](j~)}(hvoidh]hvoid}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjehhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMubjh)}(h h]h }(hjxhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjehhhjwhMubjy)}(hscsi_flush_workh]j)}(hscsi_flush_workh]hscsi_flush_work}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjehhhjwhMubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.scsi_flush_workasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjehhhjwhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjahhhjwhMubah}(h]j\ah ](jjeh"]h$]h&]jj)jhuh1jIhjwhMhj^hhubj)}(hhh]h)}(hFlush a Scsi_Host's workqueue.h]h Flush a Scsi_Host’s workqueue.}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhj&hhubah}(h]h ]h"]h$]h&]uh1jhj^hhhjwhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjAjjAjjjuh1jDhhhjhNhNubj)}(hC**Parameters** ``struct Scsi_Host *shost`` Pointer to Scsi_Host.h](h)}(h**Parameters**h]j)}(hjKh]h Parameters}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjEubj#)}(hhh]j()}(h1``struct Scsi_Host *shost`` Pointer to Scsi_Host.h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjjh]hstruct Scsi_Host *shost}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjhubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjdubjJ)}(hhh]h)}(hPointer to Scsi_Host.h]hPointer to Scsi_Host.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubah}(h]h ]h"]h$]h&]uh1jIhjdubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjaubah}(h]h ]h"]h$]h&]uh1j"hjEubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@,scsi_host_complete_all_commands (C function)!c.scsi_host_complete_all_commandshNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h\void scsi_host_complete_all_commands (struct Scsi_Host *shost, enum scsi_host_status status)h]jP)}(h[void scsi_host_complete_all_commands(struct Scsi_Host *shost, enum scsi_host_status status)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMubjy)}(hscsi_host_complete_all_commandsh]j)}(hscsi_host_complete_all_commandsh]hscsi_host_complete_all_commands}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMubj)}(h7(struct Scsi_Host *shost, enum scsi_host_status status)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj!modnameN classnameNjj)}j]j)}jjsb!c.scsi_host_complete_all_commandsasbuh1hhjubjh)}(h h]h }(hj?hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjMhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(henum scsi_host_status statush](jV)}(hj7h]henum}(hjshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjoubh)}(hhh]j)}(hscsi_host_statush]hscsi_host_status}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j;!c.scsi_host_complete_all_commandsasbuh1hhjoubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjoubj)}(hstatush]hstatus}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjoubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjhhubj)}(hhh]h)}(hTerminate all running commandsh]hTerminate all running commands}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` Scsi Host on which commands should be terminated ``enum scsi_host_status status`` Status to be set for the terminated commands **Description** There is no protection against modification of the number of outstanding commands. It is the responsibility of the caller to ensure that concurrent I/O submission and/or completion is stopped when calling this function.h](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubj#)}(hhh](j()}(hM``struct Scsi_Host *shost`` Scsi Host on which commands should be terminated h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj(h]hstruct Scsi_Host *shost}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj&ubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhj"ubjJ)}(hhh]h)}(h0Scsi Host on which commands should be terminatedh]h0Scsi Host on which commands should be terminated}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hMhj>ubah}(h]h ]h"]h$]h&]uh1jIhj"ubeh}(h]h ]h"]h$]h&]uh1j'hj=hMhjubj()}(hN``enum scsi_host_status status`` Status to be set for the terminated commands h](j.)}(h ``enum scsi_host_status status``h]j4)}(hjah]henum scsi_host_status status}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj_ubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhj[ubjJ)}(hhh]h)}(h,Status to be set for the terminated commandsh]h,Status to be set for the terminated commands}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMhjwubah}(h]h ]h"]h$]h&]uh1jIhj[ubeh}(h]h ]h"]h$]h&]uh1j'hjvhMhjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubh)}(hThere is no protection against modification of the number of outstanding commands. It is the responsibility of the caller to ensure that concurrent I/O submission and/or completion is stopped when calling this function.h]hThere is no protection against modification of the number of outstanding commands. It is the responsibility of the caller to ensure that concurrent I/O submission and/or completion is stopped when calling this function.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@ scsi_host_busy_iter (C function)c.scsi_host_busy_iterhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hfvoid scsi_host_busy_iter (struct Scsi_Host *shost, bool (*fn)(struct scsi_cmnd *, void *), void *priv)h]jP)}(hcvoid scsi_host_busy_iter(struct Scsi_Host *shost, bool (*fn)(struct scsi_cmnd*, void*), void *priv)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMubjy)}(hscsi_host_busy_iterh]j)}(hscsi_host_busy_iterh]hscsi_host_busy_iter}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMubj)}(hK(struct Scsi_Host *shost, bool (*fn)(struct scsi_cmnd*, void*), void *priv)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hj+hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj9ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj>modnameN classnameNjj)}j]j)}jjsbc.scsi_host_busy_iterasbuh1hhjubjh)}(h h]h }(hj\hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h$bool (*fn)(struct scsi_cmnd*, void*)h](j~)}(hjU.h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hjah]h(}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hfnh]hfn}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubj )}(hjh]h)}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj )}(hjah]h(}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubjV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]jXc.scsi_host_busy_iterasbuh1hhjubj )}(hj h]h*}(hj)hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj )}(hjh]h,}(hj6hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubjh)}(h h]h }(hjChhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj~)}(hvoidh]hvoid}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubj )}(hj h]h*}(hj_hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj )}(hjh]h)}(hjlhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h void *privh](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hprivh]hpriv}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjhhubj)}(hhh]h)}(hIterate over all busy commandsh]hIterate over all busy commands}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hX:**Parameters** ``struct Scsi_Host *shost`` Pointer to Scsi_Host. ``bool (*fn)(struct scsi_cmnd *, void *)`` Function to call on each busy command ``void *priv`` Data pointer passed to **fn** **Description** If locking against concurrent command completions is required ithas to be provided by the callerh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubj#)}(hhh](j()}(h2``struct Scsi_Host *shost`` Pointer to Scsi_Host. h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubjJ)}(hhh]h)}(hPointer to Scsi_Host.h]hPointer to Scsi_Host.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hMhj.ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj-hMhjubj()}(hQ``bool (*fn)(struct scsi_cmnd *, void *)`` Function to call on each busy command h](j.)}(h*``bool (*fn)(struct scsi_cmnd *, void *)``h]j4)}(hjQh]h&bool (*fn)(struct scsi_cmnd *, void *)}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjOubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjKubjJ)}(hhh]h)}(h%Function to call on each busy commandh]h%Function to call on each busy command}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjgubah}(h]h ]h"]h$]h&]uh1jIhjKubeh}(h]h ]h"]h$]h&]uh1j'hjfhMhjubj()}(h-``void *priv`` Data pointer passed to **fn** h](j.)}(h``void *priv``h]j4)}(hjh]h void *priv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubjJ)}(hhh]h)}(hData pointer passed to **fn**h](hData pointer passed to }(hjhhhNhNubj)}(h**fn**h]hfn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubh)}(h`If locking against concurrent command completions is required ithas to be provided by the callerh]h`If locking against concurrent command completions is required ithas to be provided by the caller}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:216: ./drivers/scsi/hosts.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h]drivers-scsi-hosts-cah ]h"]drivers/scsi/hosts.cah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hdrivers/scsi/scsi_common.ch]hdrivers/scsi/scsi_common.c}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(hgeneral support functionsh]hgeneral support functions}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_device_type (C function)c.scsi_device_typehNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h-const char * scsi_device_type (unsigned type)h]jP)}(h+const char *scsi_device_type(unsigned type)h](jV)}(hjNh]hconst}(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj;hhh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chK5ubjh)}(h h]h }(hjMhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj;hhhjLhK5ubj~)}(hcharh]hchar}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj;hhhjLhK5ubjh)}(h h]h }(hjihhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj;hhhjLhK5ubj )}(hj h]h*}(hjwhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj;hhhjLhK5ubjy)}(hscsi_device_typeh]j)}(hscsi_device_typeh]hscsi_device_type}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj;hhhjLhK5ubj)}(h(unsigned type)h]j)}(h unsigned typeh](j~)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(htypeh]htype}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhj;hhhjLhK5ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj7hhhjLhK5ubah}(h]j2ah ](jjeh"]h$]h&]jj)jhuh1jIhjLhK5hj4hhubj)}(hhh]h)}(h-Return 17-char string indicating device type.h]h-Return 17-char string indicating device type.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chK5hjhhubah}(h]h ]h"]h$]h&]uh1jhj4hhhjLhK5ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(h:**Parameters** ``unsigned type`` type number to look uph](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chK9hjubj#)}(hhh]j()}(h(``unsigned type`` type number to look uph](j.)}(h``unsigned type``h]j4)}(hj+h]h unsigned type}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj)ubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chK;hj%ubjJ)}(hhh]h)}(htype number to look uph]htype number to look up}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chK6hjAubah}(h]h ]h"]h$]h&]uh1jIhj%ubeh}(h]h ]h"]h$]h&]uh1j'hj@hK;hj"ubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsilun_to_int (C function)c.scsilun_to_inthNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h-u64 scsilun_to_int (struct scsi_lun *scsilun)h]jP)}(h,u64 scsilun_to_int(struct scsi_lun *scsilun)h](h)}(hhh]j)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jscsilun_to_intsbc.scsilun_to_intasbuh1hhjhhh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKoubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhKoubjy)}(hscsilun_to_inth]j)}(hjh]hscsilun_to_int}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhKoubj)}(h(struct scsi_lun *scsilun)h]j)}(hstruct scsi_lun *scsilunh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hscsi_lunh]hscsi_lun}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.scsilun_to_intasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hj!hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hscsilunh]hscsilun}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKoubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj}hhhjhKoubah}(h]jxah ](jjeh"]h$]h&]jj)jhuh1jIhjhKohjzhhubj)}(hhh]h)}(hconvert a scsi_lun to an inth]hconvert a scsi_lun to an int}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKohjUhhubah}(h]h ]h"]h$]h&]uh1jhjzhhhjhKoubeh}(h]h ](jfunctioneh"]h$]h&]jjjjpjjpjjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``struct scsi_lun *scsilun`` struct scsi_lun to be converted. **Description** Convert **scsilun** from a struct scsi_lun to a four-byte host byte-ordered integer, and return the result. The caller must check for truncation before using this function. **Notes** For a description of the LUN format, post SCSI-3 see the SCSI Architecture Model, for SCSI-3 see the SCSI Controller Commands. Given a struct scsi_lun of: d2 04 0b 03 00 00 00 00, this function returns the integer: 0x0b03d204 This encoding will return a standard integer LUN for LUNs smaller than 256, which typically use a single level LUN structure with addressing method 0.h](h)}(h**Parameters**h]j)}(hjzh]h Parameters}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKshjtubj#)}(hhh]j()}(h>``struct scsi_lun *scsilun`` struct scsi_lun to be converted. h](j.)}(h``struct scsi_lun *scsilun``h]j4)}(hjh]hstruct scsi_lun *scsilun}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKphjubjJ)}(hhh]h)}(h struct scsi_lun to be converted.h]h struct scsi_lun to be converted.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKphjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKphjubah}(h]h ]h"]h$]h&]uh1j"hjtubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKrhjtubj`)}(hConvert **scsilun** from a struct scsi_lun to a four-byte host byte-ordered integer, and return the result. The caller must check for truncation before using this function. h]h)}(hConvert **scsilun** from a struct scsi_lun to a four-byte host byte-ordered integer, and return the result. The caller must check for truncation before using this function.h](hConvert }(hjhhhNhNubj)}(h **scsilun**h]hscsilun}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh from a struct scsi_lun to a four-byte host byte-ordered integer, and return the result. The caller must check for truncation before using this function.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKrhjubah}(h]h ]h"]h$]h&]uh1j_hjhKrhjtubh)}(h **Notes**h]j)}(hjh]hNotes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKvhjtubj`)}(hXzFor a description of the LUN format, post SCSI-3 see the SCSI Architecture Model, for SCSI-3 see the SCSI Controller Commands. Given a struct scsi_lun of: d2 04 0b 03 00 00 00 00, this function returns the integer: 0x0b03d204 This encoding will return a standard integer LUN for LUNs smaller than 256, which typically use a single level LUN structure with addressing method 0.h](h)}(h~For a description of the LUN format, post SCSI-3 see the SCSI Architecture Model, for SCSI-3 see the SCSI Controller Commands.h]h~For a description of the LUN format, post SCSI-3 see the SCSI Architecture Model, for SCSI-3 see the SCSI Controller Commands.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKwhj-ubh)}(hbGiven a struct scsi_lun of: d2 04 0b 03 00 00 00 00, this function returns the integer: 0x0b03d204h]hbGiven a struct scsi_lun of: d2 04 0b 03 00 00 00 00, this function returns the integer: 0x0b03d204}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKzhj-ubh)}(hThis encoding will return a standard integer LUN for LUNs smaller than 256, which typically use a single level LUN structure with addressing method 0.h]hThis encoding will return a standard integer LUN for LUNs smaller than 256, which typically use a single level LUN structure with addressing method 0.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chK}hj-ubeh}(h]h ]h"]h$]h&]uh1j_hj?hKwhjtubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@int_to_scsilun (C function)c.int_to_scsilunhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h7void int_to_scsilun (u64 lun, struct scsi_lun *scsilun)h]jP)}(h6void int_to_scsilun(u64 lun, struct scsi_lun *scsilun)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhKubjy)}(hint_to_scsilunh]j)}(hint_to_scsilunh]hint_to_scsilun}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhKubj)}(h#(u64 lun, struct scsi_lun *scsilun)h](j)}(hu64 lunh](h)}(hhh]j)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.int_to_scsilunasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hlunh]hlun}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct scsi_lun *scsilunh](jV)}(hjYh]hstruct}(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hscsi_lunh]hscsi_lun}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj+modnameN classnameNjj)}j]jc.int_to_scsilunasbuh1hhjubjh)}(h h]h }(hjGhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjUhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hscsilunh]hscsilun}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj|hhhjhKubah}(h]jwah ](jjeh"]h$]h&]jj)jhuh1jIhjhKhjyhhubj)}(hhh]h)}(hreverts an int into a scsi_lunh]hreverts an int into a scsi_lun}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjhhubah}(h]h ]h"]h$]h&]uh1jhjyhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``u64 lun`` integer to be reverted ``struct scsi_lun *scsilun`` struct scsi_lun to be set. **Description** Reverts the functionality of the scsilun_to_int, which packed an 8-byte lun value into an int. This routine unpacks the int back into the lun value. **Notes** Given an integer : 0x0b03d204, this function returns a struct scsi_lun of: d2 04 0b 03 00 00 00 00h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubj#)}(hhh](j()}(h#``u64 lun`` integer to be reverted h](j.)}(h ``u64 lun``h]j4)}(hjh]hu64 lun}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubjJ)}(hhh]h)}(hinteger to be revertedh]hinteger to be reverted}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubj()}(h8``struct scsi_lun *scsilun`` struct scsi_lun to be set. h](j.)}(h``struct scsi_lun *scsilun``h]j4)}(hjh]hstruct scsi_lun *scsilun}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubjJ)}(hhh]h)}(hstruct scsi_lun to be set.h]hstruct scsi_lun to be set.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjAh]h Description}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubj`)}(hReverts the functionality of the scsilun_to_int, which packed an 8-byte lun value into an int. This routine unpacks the int back into the lun value. h]h)}(hReverts the functionality of the scsilun_to_int, which packed an 8-byte lun value into an int. This routine unpacks the int back into the lun value.h]hReverts the functionality of the scsilun_to_int, which packed an 8-byte lun value into an int. This routine unpacks the int back into the lun value.}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjWubah}(h]h ]h"]h$]h&]uh1j_hjihKhjubh)}(h **Notes**h]j)}(hjrh]hNotes}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubj`)}(hbGiven an integer : 0x0b03d204, this function returns a struct scsi_lun of: d2 04 0b 03 00 00 00 00h]h)}(hbGiven an integer : 0x0b03d204, this function returns a struct scsi_lun of: d2 04 0b 03 00 00 00 00h]hbGiven an integer : 0x0b03d204, this function returns a struct scsi_lun of: d2 04 0b 03 00 00 00 00}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubah}(h]h ]h"]h$]h&]uh1j_hjhKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!scsi_normalize_sense (C function)c.scsi_normalize_sensehNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h\bool scsi_normalize_sense (const u8 *sense_buffer, int sb_len, struct scsi_sense_hdr *sshdr)h]jP)}(h[bool scsi_normalize_sense(const u8 *sense_buffer, int sb_len, struct scsi_sense_hdr *sshdr)h](j~)}(hjU.h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhKubjy)}(hscsi_normalize_senseh]j)}(hscsi_normalize_senseh]hscsi_normalize_sense}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhKubj)}(hB(const u8 *sense_buffer, int sb_len, struct scsi_sense_hdr *sshdr)h](j)}(hconst u8 *sense_bufferh](jV)}(hjNh]hconst}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.scsi_normalize_senseasbuh1hhjubjh)}(h h]h }(hj;hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjIhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(h sense_bufferh]h sense_buffer}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int sb_lenh](j~)}(hinth]hint}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjkubjh)}(h h]h }(hj}hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjkubj)}(hsb_lenh]hsb_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjkubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct scsi_sense_hdr *sshdrh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hscsi_sense_hdrh]hscsi_sense_hdr}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j7c.scsi_normalize_senseasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hsshdrh]hsshdr}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhKhjhhubj)}(hhh]h)}(h_normalize main elements from either fixed or descriptor sense data format into a common format.h]h_normalize main elements from either fixed or descriptor sense data format into a common format.}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhj"hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj=jj=jjjuh1jDhhhjhNhNubj)}(hXy**Parameters** ``const u8 *sense_buffer`` byte array containing sense data returned by device ``int sb_len`` number of valid bytes in sense_buffer ``struct scsi_sense_hdr *sshdr`` pointer to instance of structure that common elements are written to. **Notes** The "main elements" from sense data are: response_code, sense_key, asc, ascq and additional_length (only for descriptor format). Typically this function can be called after a device has responded to a SCSI command with the CHECK_CONDITION status. **Description** Return value: true if valid sense data information found, else false;h](h)}(h**Parameters**h]j)}(hjGh]h Parameters}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjAubj#)}(hhh](j()}(hO``const u8 *sense_buffer`` byte array containing sense data returned by device h](j.)}(h``const u8 *sense_buffer``h]j4)}(hjfh]hconst u8 *sense_buffer}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjdubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhj`ubjJ)}(hhh]h)}(h3byte array containing sense data returned by deviceh]h3byte array containing sense data returned by device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hKhj|ubah}(h]h ]h"]h$]h&]uh1jIhj`ubeh}(h]h ]h"]h$]h&]uh1j'hj{hKhj]ubj()}(h5``int sb_len`` number of valid bytes in sense_buffer h](j.)}(h``int sb_len``h]j4)}(hjh]h int sb_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubjJ)}(hhh]h)}(h%number of valid bytes in sense_bufferh]h%number of valid bytes in sense_buffer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhj]ubj()}(hg``struct scsi_sense_hdr *sshdr`` pointer to instance of structure that common elements are written to. h](j.)}(h ``struct scsi_sense_hdr *sshdr``h]j4)}(hjh]hstruct scsi_sense_hdr *sshdr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubjJ)}(hhh]h)}(hEpointer to instance of structure that common elements are written to.h]hEpointer to instance of structure that common elements are written to.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhj]ubeh}(h]h ]h"]h$]h&]uh1j"hjAubh)}(h **Notes**h]j)}(hjh]hNotes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjAubj`)}(hThe "main elements" from sense data are: response_code, sense_key, asc, ascq and additional_length (only for descriptor format). Typically this function can be called after a device has responded to a SCSI command with the CHECK_CONDITION status. h](h)}(hThe "main elements" from sense data are: response_code, sense_key, asc, ascq and additional_length (only for descriptor format).h]hThe “main elements” from sense data are: response_code, sense_key, asc, ascq and additional_length (only for descriptor format).}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhj*ubh)}(huTypically this function can be called after a device has responded to a SCSI command with the CHECK_CONDITION status.h]huTypically this function can be called after a device has responded to a SCSI command with the CHECK_CONDITION status.}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhj*ubeh}(h]h ]h"]h$]h&]uh1j_hj<hKhjAubh)}(h**Description**h]j)}(hjTh]h Description}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjAubj#)}(hhh]j()}(hEReturn value: true if valid sense data information found, else false;h](j.)}(h Return value:h]h Return value:}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjmubjJ)}(hhh]h)}(h7true if valid sense data information found, else false;h]h7true if valid sense data information found, else false;}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubah}(h]h ]h"]h$]h&]uh1jIhjmubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjjubah}(h]h ]h"]h$]h&]uh1j"hjAubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!scsi_sense_desc_find (C function)c.scsi_sense_desc_findhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hTconst u8 * scsi_sense_desc_find (const u8 * sense_buffer, int sb_len, int desc_type)h]jP)}(hQconst u8 *scsi_sense_desc_find(const u8 *sense_buffer, int sb_len, int desc_type)h](jV)}(hjNh]hconst}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhKubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jscsi_sense_desc_findsbc.scsi_sense_desc_findasbuh1hhjhhhjhKubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhKubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjhhhjhKubjy)}(hscsi_sense_desc_findh]j)}(hjh]hscsi_sense_desc_find}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhKubj)}(h3(const u8 *sense_buffer, int sb_len, int desc_type)h](j)}(hconst u8 *sense_bufferh](jV)}(hjNh]hconst}(hj>hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:ubjh)}(h h]h }(hjKhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj:ubh)}(hhh]j)}(hu8h]hu8}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjYubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj^modnameN classnameNjj)}j]jc.scsi_sense_desc_findasbuh1hhj:ubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj:ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj:ubj)}(h sense_bufferh]h sense_buffer}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj:ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj6ubj)}(h int sb_lenh](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hsb_lenh]hsb_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj6ubj)}(h int desc_typeh](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(h desc_typeh]h desc_type}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj6ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhKhjhhubj)}(hhh]h)}(hCsearch for a given descriptor type in descriptor sense data format.h]hCsearch for a given descriptor type in descriptor sense data format.}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhj&hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjAjjAjjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``const u8 * sense_buffer`` byte array of descriptor format sense data ``int sb_len`` number of valid bytes in sense_buffer ``int desc_type`` value of descriptor type to find (e.g. 0 -> information) **Notes** only valid when sense data is in descriptor format **Description** Return value: pointer to start of (first) descriptor if found else NULLh](h)}(h**Parameters**h]j)}(hjKh]h Parameters}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjEubj#)}(hhh](j()}(hG``const u8 * sense_buffer`` byte array of descriptor format sense data h](j.)}(h``const u8 * sense_buffer``h]j4)}(hjjh]hconst u8 * sense_buffer}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjhubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjdubjJ)}(hhh]h)}(h*byte array of descriptor format sense datah]h*byte array of descriptor format sense data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjdubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjaubj()}(h5``int sb_len`` number of valid bytes in sense_buffer h](j.)}(h``int sb_len``h]j4)}(hjh]h int sb_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubjJ)}(hhh]h)}(h%number of valid bytes in sense_bufferh]h%number of valid bytes in sense_buffer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjaubj()}(hK``int desc_type`` value of descriptor type to find (e.g. 0 -> information) h](j.)}(h``int desc_type``h]j4)}(hjh]h int desc_type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubjJ)}(hhh]h)}(h8value of descriptor type to find (e.g. 0 -> information)h]h8value of descriptor type to find (e.g. 0 -> information)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjaubeh}(h]h ]h"]h$]h&]uh1j"hjEubh)}(h **Notes**h]j)}(hjh]hNotes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjEubj`)}(h3only valid when sense data is in descriptor format h]h)}(h2only valid when sense data is in descriptor formath]h2only valid when sense data is in descriptor format}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhj.ubah}(h]h ]h"]h$]h&]uh1j_hj@hKhjEubh)}(h**Description**h]j)}(hjIh]h Description}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjEubj#)}(hhh]j()}(hGReturn value: pointer to start of (first) descriptor if found else NULLh](j.)}(h Return value:h]h Return value:}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjbubjJ)}(hhh]h)}(h9pointer to start of (first) descriptor if found else NULLh]h9pointer to start of (first) descriptor if found else NULL}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chKhjuubah}(h]h ]h"]h$]h&]uh1jIhjbubeh}(h]h ]h"]h$]h&]uh1j'hjthKhj_ubah}(h]h ]h"]h$]h&]uh1j"hjEubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@$scsi_build_sense_buffer (C function)c.scsi_build_sense_bufferhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hIvoid scsi_build_sense_buffer (int desc, u8 *buf, u8 key, u8 asc, u8 ascq)h]jP)}(hHvoid scsi_build_sense_buffer(int desc, u8 *buf, u8 key, u8 asc, u8 ascq)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMubjy)}(hscsi_build_sense_bufferh]j)}(hscsi_build_sense_bufferh]hscsi_build_sense_buffer}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMubj)}(h,(int desc, u8 *buf, u8 key, u8 asc, u8 ascq)h](j)}(hint desch](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hdesch]hdesc}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu8 *bufh](h)}(hhh]j)}(hu8h]hu8}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj+ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj0modnameN classnameNjj)}j]j)}jjsbc.scsi_build_sense_bufferasbuh1hhj'ubjh)}(h h]h }(hjNhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj'ubj )}(hj h]h*}(hj\hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj'ubj)}(hbufh]hbuf}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj'ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu8 keyh](h)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jJc.scsi_build_sense_bufferasbuh1hhj~ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj~ubj)}(hkeyh]hkey}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu8 asch](h)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jJc.scsi_build_sense_bufferasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hasch]hasc}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu8 ascqh](h)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jJc.scsi_build_sense_bufferasbuh1hhjubjh)}(h h]h }(hj3hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hascqh]hascq}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjhhubj)}(hhh]h)}(hbuild sense data in a bufferh]hbuild sense data in a buffer}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMhjhhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(h**Parameters** ``int desc`` Sense format (non-zero == descriptor format, 0 == fixed format) ``u8 *buf`` Where to build sense data ``u8 key`` Sense key ``u8 asc`` Additional sense code ``u8 ascq`` Additional sense code qualifierh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMhjubj#)}(hhh](j()}(hM``int desc`` Sense format (non-zero == descriptor format, 0 == fixed format) h](j.)}(h ``int desc``h]j4)}(hjh]hint desc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMhjubjJ)}(hhh]h)}(h?Sense format (non-zero == descriptor format, 0 == fixed format)h]h?Sense format (non-zero == descriptor format, 0 == fixed format)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubj()}(h&``u8 *buf`` Where to build sense data h](j.)}(h ``u8 *buf``h]j4)}(hjh]hu8 *buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMhjubjJ)}(hhh]h)}(hWhere to build sense datah]hWhere to build sense data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubj()}(h``u8 key`` Sense key h](j.)}(h ``u8 key``h]j4)}(hjh]hu8 key}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMhjubjJ)}(hhh]h)}(h Sense keyh]h Sense key}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hMhj5ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj4hMhjubj()}(h!``u8 asc`` Additional sense code h](j.)}(h ``u8 asc``h]j4)}(hjXh]hu8 asc}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjVubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMhjRubjJ)}(hhh]h)}(hAdditional sense codeh]hAdditional sense code}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhMhjnubah}(h]h ]h"]h$]h&]uh1jIhjRubeh}(h]h ]h"]h$]h&]uh1j'hjmhMhjubj()}(h+``u8 ascq`` Additional sense code qualifierh](j.)}(h ``u8 ascq``h]j4)}(hjh]hu8 ascq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMhjubjJ)}(hhh]h)}(hAdditional sense code qualifierh]hAdditional sense code qualifier}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubeh}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@'scsi_set_sense_information (C function)c.scsi_set_sense_informationhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h?int scsi_set_sense_information (u8 *buf, int buf_len, u64 info)h]jP)}(h>int scsi_set_sense_information(u8 *buf, int buf_len, u64 info)h](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM/ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM/ubjy)}(hscsi_set_sense_informationh]j)}(hscsi_set_sense_informationh]hscsi_set_sense_information}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhM/ubj)}(h (u8 *buf, int buf_len, u64 info)h](j)}(hu8 *bufh](h)}(hhh]j)}(hu8h]hu8}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj-modnameN classnameNjj)}j]j)}jjsbc.scsi_set_sense_informationasbuh1hhj$ubjh)}(h h]h }(hjKhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj$ubj )}(hj h]h*}(hjYhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj$ubj)}(hbufh]hbuf}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h int buf_lenh](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj{ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{ubj)}(hbuf_lenh]hbuf_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hu64 infoh](h)}(hhh]j)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jGc.scsi_set_sense_informationasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hinfoh]hinfo}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM/ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM/ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhM/hjhhubj)}(hhh]h)}(h:set the information field in a formatted sense data bufferh]h:set the information field in a formatted sense data buffer}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM/hj hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM/ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj%jj%jjjuh1jDhhhjhNhNubj)}(h**Parameters** ``u8 *buf`` Where to build sense data ``int buf_len`` buffer length ``u64 info`` 64-bit information value to be set **Description** Return value: 0 on success or -EINVAL for invalid sense buffer lengthh](h)}(h**Parameters**h]j)}(hj/h]h Parameters}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM3hj)ubj#)}(hhh](j()}(h&``u8 *buf`` Where to build sense data h](j.)}(h ``u8 *buf``h]j4)}(hjNh]hu8 *buf}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjLubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM1hjHubjJ)}(hhh]h)}(hWhere to build sense datah]hWhere to build sense data}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchM1hjdubah}(h]h ]h"]h$]h&]uh1jIhjHubeh}(h]h ]h"]h$]h&]uh1j'hjchM1hjEubj()}(h``int buf_len`` buffer length h](j.)}(h``int buf_len``h]j4)}(hjh]h int buf_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM2hjubjJ)}(hhh]h)}(h buffer lengthh]h buffer length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM2hjEubj()}(h0``u64 info`` 64-bit information value to be set h](j.)}(h ``u64 info``h]j4)}(hjh]hu64 info}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM3hjubjJ)}(hhh]h)}(h"64-bit information value to be seth]h"64-bit information value to be set}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM3hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM3hjEubeh}(h]h ]h"]h$]h&]uh1j"hj)ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM5hj)ubj#)}(hhh]j()}(hEReturn value: 0 on success or -EINVAL for invalid sense buffer lengthh](j.)}(h Return value:h]h Return value:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM5hjubjJ)}(hhh]h)}(h70 on success or -EINVAL for invalid sense buffer lengthh]h70 on success or -EINVAL for invalid sense buffer length}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM6hj'ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj&hM5hjubah}(h]h ]h"]h$]h&]uh1j"hj)ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@)scsi_set_sense_field_pointer (C function)c.scsi_set_sense_field_pointerhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hOint scsi_set_sense_field_pointer (u8 *buf, int buf_len, u16 fp, u8 bp, bool cd)h]jP)}(hNint scsi_set_sense_field_pointer(u8 *buf, int buf_len, u16 fp, u8 bp, bool cd)h](j~)}(hinth]hint}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjghhh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM_ubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjghhhjyhM_ubjy)}(hscsi_set_sense_field_pointerh]j)}(hscsi_set_sense_field_pointerh]hscsi_set_sense_field_pointer}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjghhhjyhM_ubj)}(h.(u8 *buf, int buf_len, u16 fp, u8 bp, bool cd)h](j)}(hu8 *bufh](h)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.scsi_set_sense_field_pointerasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hbufh]hbuf}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int buf_lenh](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hbuf_lenh]hbuf_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu16 fph](h)}(hhh]j)}(hu16h]hu16}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj4ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj9modnameN classnameNjj)}j]jc.scsi_set_sense_field_pointerasbuh1hhj0ubjh)}(h h]h }(hjUhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj0ubj)}(hfph]hfp}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj0ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu8 bph](h)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj|ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.scsi_set_sense_field_pointerasbuh1hhjxubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjxubj)}(hbph]hbp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjxubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hbool cdh](j~)}(hjU.h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hcdh]hcd}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjghhhjyhM_ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjchhhjyhM_ubah}(h]j^ah ](jjeh"]h$]h&]jj)jhuh1jIhjyhM_hj`hhubj)}(hhh]h)}(hUset the field pointer sense key specific information in a formatted sense data bufferh]hUset the field pointer sense key specific information in a formatted sense data buffer}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chM_hjhhubah}(h]h ]h"]h$]h&]uh1jhj`hhhjyhM_ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj!jj!jjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``u8 *buf`` Where to build sense data ``int buf_len`` buffer length ``u16 fp`` field pointer to be set ``u8 bp`` bit pointer to be set ``bool cd`` command/data bit **Description** Return value: 0 on success or -EINVAL for invalid sense buffer lengthh](h)}(h**Parameters**h]j)}(hj+h]h Parameters}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMchj%ubj#)}(hhh](j()}(h&``u8 *buf`` Where to build sense data h](j.)}(h ``u8 *buf``h]j4)}(hjJh]hu8 *buf}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjHubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMahjDubjJ)}(hhh]h)}(hWhere to build sense datah]hWhere to build sense data}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMahj`ubah}(h]h ]h"]h$]h&]uh1jIhjDubeh}(h]h ]h"]h$]h&]uh1j'hj_hMahjAubj()}(h``int buf_len`` buffer length h](j.)}(h``int buf_len``h]j4)}(hjh]h int buf_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMbhj}ubjJ)}(hhh]h)}(h buffer lengthh]h buffer length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMbhjubah}(h]h ]h"]h$]h&]uh1jIhj}ubeh}(h]h ]h"]h$]h&]uh1j'hjhMbhjAubj()}(h#``u16 fp`` field pointer to be set h](j.)}(h ``u16 fp``h]j4)}(hjh]hu16 fp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMchjubjJ)}(hhh]h)}(hfield pointer to be seth]hfield pointer to be set}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMchjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMchjAubj()}(h ``u8 bp`` bit pointer to be set h](j.)}(h ``u8 bp``h]j4)}(hjh]hu8 bp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMdhjubjJ)}(hhh]h)}(hbit pointer to be seth]hbit pointer to be set}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMdhj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj hMdhjAubj()}(h``bool cd`` command/data bit h](j.)}(h ``bool cd``h]j4)}(hj.h]hbool cd}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj,ubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMehj(ubjJ)}(hhh]h)}(hcommand/data bith]hcommand/data bit}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChMehjDubah}(h]h ]h"]h$]h&]uh1jIhj(ubeh}(h]h ]h"]h$]h&]uh1j'hjChMehjAubeh}(h]h ]h"]h$]h&]uh1j"hj%ubh)}(h**Description**h]j)}(hjih]h Description}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMghj%ubj#)}(hhh]j()}(hEReturn value: 0 on success or -EINVAL for invalid sense buffer lengthh](j.)}(h Return value:h]h Return value:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j-h[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMghjubjJ)}(hhh]h)}(h70 on success or -EINVAL for invalid sense buffer lengthh]h70 on success or -EINVAL for invalid sense buffer length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:224: ./drivers/scsi/scsi_common.chMhhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMghjubah}(h]h ]h"]h$]h&]uh1j"hj%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h]drivers-scsi-scsi-common-cah ]h"]drivers/scsi/scsi_common.cah$]h&]uh1hhjhhhhhKubeh}(h]scsi-midlayer-implementationah ]h"]scsi midlayer implementationah$]h&]uh1hhjhhhhhKXubh)}(hhh](h)}(hTransport classesh]hTransport classes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(hxTransport classes are service libraries for drivers in the SCSI lower layer, which expose transport attributes in sysfs.h]hxTransport classes are service libraries for drivers in the SCSI lower layer, which expose transport attributes in sysfs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hhh](h)}(hFibre Channel transporth]hFibre Channel transport}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(hYThe file drivers/scsi/scsi_transport_fc.c defines transport attributes for Fibre Channel.h]hYThe file drivers/scsi/scsi_transport_fc.c defines transport attributes for Fibre Channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@ fc_get_event_number (C function)c.fc_get_event_numberhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hu32 fc_get_event_number (void)h]jP)}(hu32 fc_get_event_number(void)h](h)}(hhh]j)}(hu32h]hu32}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj'ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj,modnameN classnameNjj)}j]j)}jfc_get_event_numbersbc.fc_get_event_numberasbuh1hhj#hhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMubjh)}(h h]h }(hjLhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj#hhhjKhMubjy)}(hfc_get_event_numberh]j)}(hjHh]hfc_get_event_number}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjZubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj#hhhjKhMubj)}(h(void)h]j)}(hvoidh]j~)}(hvoidh]hvoid}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjuubah}(h]h ]h"]h$]h&]noemphjjuh1jhjqubah}(h]h ]h"]h$]h&]jjuh1jhj#hhhjKhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjKhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjKhMhjhhubj)}(hhh]h)}(h*Obtain the next sequential FC event numberh]h*Obtain the next sequential FC event number}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjKhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(h**Parameters** ``void`` no arguments **Notes** We could have inlined this, but it would have required fc_event_seq to be exposed. For now, live with the subroutine call. Atomic used to avoid lock/unlock...h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjubj#)}(hhh]j()}(h``void`` no arguments h](j.)}(h``void``h]j4)}(hjh]hvoid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chKhjubjJ)}(hhh]h)}(h no argumentsh]h no arguments}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhKhjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h **Notes**h]j)}(hjh]hNotes}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chKhjubj`)}(hWe could have inlined this, but it would have required fc_event_seq to be exposed. For now, live with the subroutine call. Atomic used to avoid lock/unlock...h]h)}(hWe could have inlined this, but it would have required fc_event_seq to be exposed. For now, live with the subroutine call. Atomic used to avoid lock/unlock...h]hWe could have inlined this, but it would have required fc_event_seq to be exposed. For now, live with the subroutine call. Atomic used to avoid lock/unlock...}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj5ubah}(h]h ]h"]h$]h&]uh1j_hjGhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"fc_host_post_fc_event (C function)c.fc_host_post_fc_eventhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hvoid fc_host_post_fc_event (struct Scsi_Host *shost, u32 event_number, enum fc_host_event_code event_code, u32 data_len, char *data_buf, u64 vendor_id)h]jP)}(hvoid fc_host_post_fc_event(struct Scsi_Host *shost, u32 event_number, enum fc_host_event_code event_code, u32 data_len, char *data_buf, u64 vendor_id)h](j~)}(hvoidh]hvoid}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM ubjh)}(h h]h }(hj}hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjjhhhj|hM ubjy)}(hfc_host_post_fc_eventh]j)}(hfc_host_post_fc_eventh]hfc_host_post_fc_event}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjjhhhj|hM ubj)}(h|(struct Scsi_Host *shost, u32 event_number, enum fc_host_event_code event_code, u32 data_len, char *data_buf, u64 vendor_id)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.fc_host_post_fc_eventasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu32 event_numberh](h)}(hhh]j)}(hu32h]hu32}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj"modnameN classnameNjj)}j]jc.fc_host_post_fc_eventasbuh1hhjubjh)}(h h]h }(hj>hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(h event_numberh]h event_number}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h"enum fc_host_event_code event_codeh](jV)}(hj7h]henum}(hjehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjaubjh)}(h h]h }(hjrhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjaubh)}(hhh]j)}(hfc_host_event_codeh]hfc_host_event_code}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.fc_host_post_fc_eventasbuh1hhjaubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjaubj)}(h event_codeh]h event_code}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjaubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u32 data_lenh](h)}(hhh]j)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.fc_host_post_fc_eventasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hdata_lenh]hdata_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hchar *data_bufh](j~)}(hcharh]hchar}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj )}(hj h]h*}(hj,hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj ubj)}(hdata_bufh]hdata_buf}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u64 vendor_idh](h)}(hhh]j)}(hu64h]hu64}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjRubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjWmodnameN classnameNjj)}j]jc.fc_host_post_fc_eventasbuh1hhjNubjh)}(h h]h }(hjshhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjNubj)}(h vendor_idh]h vendor_id}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjNubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjjhhhj|hM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjfhhhj|hM ubah}(h]jaah ](jjeh"]h$]h&]jj)jhuh1jIhj|hM hjchhubj)}(hhh]h)}(h9routine to do the work of posting an event on an fc_host.h]h9routine to do the work of posting an event on an fc_host.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjchhhj|hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` host the event occurred on ``u32 event_number`` fc event number obtained from get_fc_event_number() ``enum fc_host_event_code event_code`` fc_host event being posted ``u32 data_len`` amount, in bytes, of event data ``char *data_buf`` pointer to event data ``u64 vendor_id`` value for Vendor id **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubj#)}(hhh](j()}(h7``struct Scsi_Host *shost`` host the event occurred on h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubjJ)}(hhh]h)}(hhost the event occurred onh]hhost the event occurred on}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjubj()}(hI``u32 event_number`` fc event number obtained from get_fc_event_number() h](j.)}(h``u32 event_number``h]j4)}(hj%h]hu32 event_number}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj#ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubjJ)T}(hhh]h)}(h3fc event number obtained from get_fc_event_number()h]h3fc event number obtained from get_fc_event_number()}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hM hj;ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj:hM hjubj()}(hB``enum fc_host_event_code event_code`` fc_host event being posted h](j.)}(h&``enum fc_host_event_code event_code``h]j4)}(hj^h]h"enum fc_host_event_code event_code}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj\ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjXubjJ)}(hhh]h)}(hfc_host event being postedh]hfc_host event being posted}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshM hjtubah}(h]h ]h"]h$]h&]uh1jIhjXubeh}(h]h ]h"]h$]h&]uh1j'hjshM hjubj()}(h1``u32 data_len`` amount, in bytes, of event data h](j.)}(h``u32 data_len``h]j4)}(hjh]h u32 data_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjubjJ)}(hhh]h)}(hamount, in bytes, of event datah]hamount, in bytes, of event data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubj()}(h)``char *data_buf`` pointer to event data h](j.)}(h``char *data_buf``h]j4)}(hjh]hchar *data_buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjubjJ)}(hhh]h)}(hpointer to event datah]hpointer to event data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubj()}(h&``u64 vendor_id`` value for Vendor id h](j.)}(h``u64 vendor_id``h]j4)}(hj h]h u64 vendor_id}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjubjJ)}(hhh]h)}(hvalue for Vendor idh]hvalue for Vendor id}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h **Notes**h]j)}(hjDh]hNotes}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hj\h]h0This routine assumes no locks are held on entry.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjZubah}(h]h ]h"]h$]h&]uh1j_hjkhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@fc_host_post_event (C function)c.fc_host_post_eventhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hwvoid fc_host_post_event (struct Scsi_Host *shost, u32 event_number, enum fc_host_event_code event_code, u32 event_data)h]jP)}(hvvoid fc_host_post_event(struct Scsi_Host *shost, u32 event_number, enum fc_host_event_code event_code, u32 event_data)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMWubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMWubjy)}(hfc_host_post_eventh]j)}(hfc_host_post_eventh]hfc_host_post_event}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMWubj)}(h_(struct Scsi_Host *shost, u32 event_number, enum fc_host_event_code event_code, u32 event_data)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.fc_host_post_eventasbuh1hhjubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu32 event_numberh](h)}(hhh]j)}(hu32h]hu32}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjAubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjFmodnameN classnameNjj)}j]j c.fc_host_post_eventasbuh1hhj=ubjh)}(h h]h }(hjbhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj=ubj)}(h event_numberh]h event_number}(hjphhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj=ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h"enum fc_host_event_code event_codeh](jV)}(hj7h]henum}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hfc_host_event_codeh]hfc_host_event_code}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j c.fc_host_post_eventasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(h event_codeh]h event_code}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu32 event_datah](h)}(hhh]j)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j c.fc_host_post_eventasbuh1hhjubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(h event_datah]h event_data}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMWubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMWubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMWhjhhubj)}(hhh]h)}(h%called to post an even on an fc_host.h]h%called to post an even on an fc_host.}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMWhjBhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMWubeh}(h]h ](jfunctioneh"]h$]h&]jjjj]jj]jjjuh1jDhhhjhNhNubj)}(hX[**Parameters** ``struct Scsi_Host *shost`` host the event occurred on ``u32 event_number`` fc event number obtained from get_fc_event_number() ``enum fc_host_event_code event_code`` fc_host event being posted ``u32 event_data`` 32bits of data for the event being posted **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hjgh]h Parameters}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM[hjaubj#)}(hhh](j()}(h7``struct Scsi_Host *shost`` host the event occurred on h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMXhjubjJ)}(hhh]h)}(hhost the event occurred onh]hhost the event occurred on}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMXhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMXhj}ubj()}(hI``u32 event_number`` fc event number obtained from get_fc_event_number() h](j.)}(h``u32 event_number``h]j4)}(hjh]hu32 event_number}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMYhjubjJ)}(hhh]h)}(h3fc event number obtained from get_fc_event_number()h]h3fc event number obtained from get_fc_event_number()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMYhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMYhj}ubj()}(hB``enum fc_host_event_code event_code`` fc_host event being posted h](j.)}(h&``enum fc_host_event_code event_code``h]j4)}(hjh]h"enum fc_host_event_code event_code}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMZhjubjJ)}(hhh]h)}(hfc_host event being postedh]hfc_host event being posted}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMZhj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj hMZhj}ubj()}(h=``u32 event_data`` 32bits of data for the event being posted h](j.)}(h``u32 event_data``h]j4)}(hj1 h]hu32 event_data}(hj3 hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj/ ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM[hj+ ubjJ)}(hhh]h)}(h)32bits of data for the event being postedh]h)32bits of data for the event being posted}(hjJ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjF hM[hjG ubah}(h]h ]h"]h$]h&]uh1jIhj+ ubeh}(h]h ]h"]h$]h&]uh1j'hjF hM[hj}ubeh}(h]h ]h"]h$]h&]uh1j"hjaubh)}(h **Notes**h]j)}(hjl h]hNotes}(hjn hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjj ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM]hjaubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hj h]h0This routine assumes no locks are held on entry.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM]hj ubah}(h]h ]h"]h$]h&]uh1j_hj hM]hjaubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@&fc_host_post_vendor_event (C function)c.fc_host_post_vendor_eventhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hxvoid fc_host_post_vendor_event (struct Scsi_Host *shost, u32 event_number, u32 data_len, char * data_buf, u64 vendor_id)h]jP)}(hvvoid fc_host_post_vendor_event(struct Scsi_Host *shost, u32 event_number, u32 data_len, char *data_buf, u64 vendor_id)h](j~)}(hvoidh]hvoid}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj hhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMkubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj hhhj hMkubjy)}(hfc_host_post_vendor_eventh]j)}(hfc_host_post_vendor_eventh]hfc_host_post_vendor_event}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj hhhj hMkubj)}(hX(struct Scsi_Host *shost, u32 event_number, u32 data_len, char *data_buf, u64 vendor_id)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j)}jj sbc.fc_host_post_vendor_eventasbuh1hhj ubjh)}(h h]h }(hj5 hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj )}(hj h]h*}(hjC hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj ubj)}(hshosth]hshost}(hjP hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hu32 event_numberh](h)}(hhh]j)}(hu32h]hu32}(hjl hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hji ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjn modnameN classnameNjj)}j]j1 c.fc_host_post_vendor_eventasbuh1hhje ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghje ubj)}(h event_numberh]h event_number}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hje ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h u32 data_lenh](h)}(hhh]j)}(hu32h]hu32}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j1 c.fc_host_post_vendor_eventasbuh1hhj ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj)}(hdata_lenh]hdata_len}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hchar *data_bufh](j~)}(hcharh]hchar}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj )}(hj h]h*}(hj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj ubj)}(hdata_bufh]hdata_buf}(hj" hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h u64 vendor_idh](h)}(hhh]j)}(hu64h]hu64}(hj> hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj; ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj@ modnameN classnameNjj)}j]j1 c.fc_host_post_vendor_eventasbuh1hhj7 ubjh)}(h h]h }(hj\ hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj7 ubj)}(h vendor_idh]h vendor_id}(hjj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj7 ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhj hMkubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj hhhj hMkubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1jIhj hMkhj hhubj)}(hhh]h)}(h2called to post a vendor unique event on an fc_hosth]h2called to post a vendor unique event on an fc_host}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMkhj hhubah}(h]h ]h"]h$]h&]uh1jhj hhhj hMkubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jj jjjuh1jDhhhjhNhNubj)}(hXf**Parameters** ``struct Scsi_Host *shost`` host the event occurred on ``u32 event_number`` fc event number obtained from get_fc_event_number() ``u32 data_len`` amount, in bytes, of vendor unique data ``char * data_buf`` pointer to vendor unique data ``u64 vendor_id`` Vendor id **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMohj ubj#)}(hhh](j()}(h7``struct Scsi_Host *shost`` host the event occurred on h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj h]hstruct Scsi_Host *shost}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMmhj ubjJ)}(hhh]h)}(hhost the event occurred onh]hhost the event occurred on}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMmhj ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj hMmhj ubj()}(hI``u32 event_number`` fc event number obtained from get_fc_event_number() h](j.)}(h``u32 event_number``h]j4)}(hj h]hu32 event_number}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMnhj ubjJ)}(hhh]h)}(h3fc event number obtained from get_fc_event_number()h]h3fc event number obtained from get_fc_event_number()}(hj' hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj# hMnhj$ ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj# hMnhj ubj()}(h9``u32 data_len`` amount, in bytes, of vendor unique data h](j.)}(h``u32 data_len``h]j4)}(hjG h]h u32 data_len}(hjI hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjE ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMohjA ubjJ)}(hhh]h)}(h'amount, in bytes, of vendor unique datah]h'amount, in bytes, of vendor unique data}(hj` hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\ hMohj] ubah}(h]h ]h"]h$]h&]uh1jIhjA ubeh}(h]h ]h"]h$]h&]uh1j'hj\ hMohj ubj()}(h2``char * data_buf`` pointer to vendor unique data h](j.)}(h``char * data_buf``h]j4)}(hj h]hchar * data_buf}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj~ ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMphjz ubjJ)}(hhh]h)}(hpointer to vendor unique datah]hpointer to vendor unique data}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMphj ubah}(h]h ]h"]h$]h&]uh1jIhjz ubeh}(h]h ]h"]h$]h&]uh1j'hj hMphj ubj()}(h``u64 vendor_id`` Vendor id h](j.)}(h``u64 vendor_id``h]j4)}(hj h]h u64 vendor_id}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMqhj ubjJ)}(hhh]h)}(h Vendor idh]h Vendor id}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMqhj ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj hMqhj ubeh}(h]h ]h"]h$]h&]uh1j"hj ubh)}(h **Notes**h]j)}(hj h]hNotes}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMshj ubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hj h]h0This routine assumes no locks are held on entry.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMshj ubah}(h]h ]h"]h$]h&]uh1j_hj hMshj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"fc_find_rport_by_wwpn (C function)c.fc_find_rport_by_wwpnhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hKstruct fc_rport * fc_find_rport_by_wwpn (struct Scsi_Host *shost, u64 wwpn)h]jP)}(hIstruct fc_rport *fc_find_rport_by_wwpn(struct Scsi_Host *shost, u64 wwpn)h](jV)}(hjYh]hstruct}(hjB hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj> hhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMubjh)}(h h]h }(hjP hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj> hhhjO hMubh)}(hhh]j)}(hfc_rporth]hfc_rport}(hja hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj^ ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjc modnameN classnameNjj)}j]j)}jfc_find_rport_by_wwpnsbc.fc_find_rport_by_wwpnasbuh1hhj> hhhjO hMubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj> hhhjO hMubj )}(hj h]h*}(hj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj> hhhjO hMubjy)}(hfc_find_rport_by_wwpnh]j)}(hj h]hfc_find_rport_by_wwpn}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj> hhhjO hMubj)}(h#(struct Scsi_Host *shost, u64 wwpn)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j} c.fc_find_rport_by_wwpnasbuh1hhj ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj ubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hu64 wwpnh](h)}(hhh]j)}(hu64h]hu64}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj,ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj1modnameN classnameNjj)}j]j} c.fc_find_rport_by_wwpnasbuh1hhj(ubjh)}(h h]h }(hjMhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj(ubj)}(hwwpnh]hwwpn}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhj> hhhjO hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj: hhhjO hMubah}(h]j5 ah ](jjeh"]h$]h&]jj)jhuh1jIhjO hMhj7 hhubj)}(hhh]h)}(h*find the fc_rport pointer for a given wwpnh]h*find the fc_rport pointer for a given wwpn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj7 hhhjO hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(h**Parameters** ``struct Scsi_Host *shost`` host the fc_rport is associated with ``u64 wwpn`` wwpn of the fc_rport device **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjubj#)}(hhh](j()}(hA``struct Scsi_Host *shost`` host the fc_rport is associated with h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjubjJ)}(hhh]h)}(h$host the fc_rport is associated withh]h$host the fc_rport is associated with}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubj()}(h)``u64 wwpn`` wwpn of the fc_rport device h](j.)}(h ``u64 wwpn``h]j4)}(hjh]hu64 wwpn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjubjJ)}(hhh]h)}(hwwpn of the fc_rport deviceh]hwwpn of the fc_rport device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h **Notes**h]j)}(hj:h]hNotes}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hjRh]h0This routine assumes no locks are held on entry.}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjPubah}(h]h ]h"]h$]h&]uh1j_hjahMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@fc_host_fpin_rcv (C function)c.fc_host_fpin_rcvhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hcvoid fc_host_fpin_rcv (struct Scsi_Host *shost, u32 fpin_len, char *fpin_buf, u8 event_acknowledge)h]jP)}(hbvoid fc_host_fpin_rcv(struct Scsi_Host *shost, u32 fpin_len, char *fpin_buf, u8 event_acknowledge)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMyubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMyubjy)}(hfc_host_fpin_rcvh]j)}(hfc_host_fpin_rcvh]hfc_host_fpin_rcv}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMyubj)}(hM(struct Scsi_Host *shost, u32 fpin_len, char *fpin_buf, u8 event_acknowledge)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.fc_host_fpin_rcvasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u32 fpin_lenh](h)}(hhh]j)}(hu32h]hu32}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj7ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj<modnameN classnameNjj)}j]jc.fc_host_fpin_rcvasbuh1hhj3ubjh)}(h h]h }(hjXhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj3ubj)}(hfpin_lenh]hfpin_len}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj3ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hchar *fpin_bufh](j~)}(hcharh]hchar}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj{ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj{ubj)}(hfpin_bufh]hfpin_buf}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu8 event_acknowledgeh](h)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.fc_host_fpin_rcvasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hevent_acknowledgeh]hevent_acknowledge}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMyubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMyubah}(h]j{ah ](jjeh"]h$]h&]jj)jhuh1jIhjhMyhj}hhubj)}(hhh]h)}(h#routine to process a received FPIN.h]h#routine to process a received FPIN.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMyhjhhubah}(h]h ]h"]h$]h&]uh1jhj}hhhjhMyubeh}(h]h ](jfunctioneh"]h$]h&]jjjj2jj2jjjuh1jDhhhjhNhNubj)}(hX+**Parameters** ``struct Scsi_Host *shost`` host the FPIN was received on ``u32 fpin_len`` length of FPIN payload, in bytes ``char *fpin_buf`` pointer to FPIN payload ``u8 event_acknowledge`` 1, if LLDD handles this event. **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hj<h]h Parameters}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM}hj6ubj#)}(hhh](j()}(h:``struct Scsi_Host *shost`` host the FPIN was received on h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj[h]hstruct Scsi_Host *shost}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjYubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMzhjUubjJ)}(hhh]h)}(hhost the FPIN was received onh]hhost the FPIN was received on}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphMzhjqubah}(h]h ]h"]h$]h&]uh1jIhjUubeh}(h]h ]h"]h$]h&]uh1j'hjphMzhjRubj()}(h2``u32 fpin_len`` length of FPIN payload, in bytes h](j.)}(h``u32 fpin_len``h]j4)}(hjh]h u32 fpin_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM{hjubjJ)}(hhh]h)}(h length of FPIN payload, in bytesh]h length of FPIN payload, in bytes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM{hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM{hjRubj()}(h+``char *fpin_buf`` pointer to FPIN payload h](j.)}(h``char *fpin_buf``h]j4)}(hjh]hchar *fpin_buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM|hjubjJ)}(hhh]h)}(hpointer to FPIN payloadh]hpointer to FPIN payload}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM|hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM|hjRubj()}(h8``u8 event_acknowledge`` 1, if LLDD handles this event. h](j.)}(h``u8 event_acknowledge``h]j4)}(hjh]hu8 event_acknowledge}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM}hjubjJ)}(hhh]h)}(h1, if LLDD handles this event.h]h1, if LLDD handles this event.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM}hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM}hjRubeh}(h]h ]h"]h$]h&]uh1j"hj6ubh)}(h **Notes**h]j)}(hjAh]hNotes}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj6ubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hjYh]h0This routine assumes no locks are held on entry.}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM~hjWubah}(h]h ]h"]h$]h&]uh1j_hjhhM~hj6ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@fc_eh_timed_out (C function)c.fc_eh_timed_outhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hAenum scsi_timeout_action fc_eh_timed_out (struct scsi_cmnd *scmd)h]jP)}(h@enum scsi_timeout_action fc_eh_timed_out(struct scsi_cmnd *scmd)h](jV)}(hj7h]henum}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM ubh)}(hhh]j)}(hscsi_timeout_actionh]hscsi_timeout_action}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jfc_eh_timed_outsbc.fc_eh_timed_outasbuh1hhjhhhjhM ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM ubjy)}(hfc_eh_timed_outh]j)}(hjh]hfc_eh_timed_out}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhM ubj)}(h(struct scsi_cmnd *scmd)h]j)}(hstruct scsi_cmnd *scmdh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.fc_eh_timed_outasbuh1hhjubjh)}(h h]h }(hj8hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjFhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hscmdh]hscmd}(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhM hjhhubj)}(hhh]h)}(h*FC Transport I/O timeout intercept handlerh]h*FC Transport I/O timeout intercept handler}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjzhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``struct scsi_cmnd *scmd`` The SCSI command which timed out **Description** This routine protects against error handlers getting invoked while a rport is in a blocked state, typically due to a temporarily loss of connectivity. If the error handlers are allowed to proceed, requests to abort i/o, reset the target, etc will likely fail as there is no way to communicate with the device to perform the requested function. These failures may result in the midlayer taking the device offline, requiring manual intervention to restore operation. This routine, called whenever an i/o times out, validates the state of the underlying rport. If the rport is blocked, it returns EH_RESET_TIMER, which will continue to reschedule the timeout. Eventually, either the device will return, or devloss_tmo will fire, and when the timeout then fires, it will be handled normally. If the rport is not blocked, normal error handling continues. **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubj#)}(hhh]j()}(h<``struct scsi_cmnd *scmd`` The SCSI command which timed out h](j.)}(h``struct scsi_cmnd *scmd``h]j4)}(hjh]hstruct scsi_cmnd *scmd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubjJ)}(hhh]h)}(h The SCSI command which timed outh]h The SCSI command which timed out}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubh)}(hXThis routine protects against error handlers getting invoked while a rport is in a blocked state, typically due to a temporarily loss of connectivity. If the error handlers are allowed to proceed, requests to abort i/o, reset the target, etc will likely fail as there is no way to communicate with the device to perform the requested function. These failures may result in the midlayer taking the device offline, requiring manual intervention to restore operation.h]hXThis routine protects against error handlers getting invoked while a rport is in a blocked state, typically due to a temporarily loss of connectivity. If the error handlers are allowed to proceed, requests to abort i/o, reset the target, etc will likely fail as there is no way to communicate with the device to perform the requested function. These failures may result in the midlayer taking the device offline, requiring manual intervention to restore operation.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubh)}(hXThis routine, called whenever an i/o times out, validates the state of the underlying rport. If the rport is blocked, it returns EH_RESET_TIMER, which will continue to reschedule the timeout. Eventually, either the device will return, or devloss_tmo will fire, and when the timeout then fires, it will be handled normally. If the rport is not blocked, normal error handling continues.h]hXThis routine, called whenever an i/o times out, validates the state of the underlying rport. If the rport is blocked, it returns EH_RESET_TIMER, which will continue to reschedule the timeout. Eventually, either the device will return, or devloss_tmo will fire, and when the timeout then fires, it will be handled normally. If the rport is not blocked, normal error handling continues.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubh)}(h **Notes**h]j)}(hj/h]hNotes}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hjGh]h0This routine assumes no locks are held on entry.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjEubah}(h]h ]h"]h$]h&]uh1j_hjVhM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@fc_remove_host (C function)c.fc_remove_hosthNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h-void fc_remove_host (struct Scsi_Host *shost)h]jP)}(h,void fc_remove_host(struct Scsi_Host *shost)h](j~)}(hvoidh]hvoid}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjyhhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM+ ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjyhhhjhM+ ubjy)}(hfc_remove_hosth]j)}(hfc_remove_hosth]hfc_remove_host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjyhhhjhM+ ubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.fc_remove_hostasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjyhhhjhM+ ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjuhhhjhM+ ubah}(h]jpah ](jjeh"]h$]h&]jj)jhuh1jIhjhM+ hjrhhubj)}(hhh]h)}(hFcalled to terminate any fc_transport-related elements for a scsi host.h]hFcalled to terminate any fc_transport-related elements for a scsi host.}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM+ hj:hhubah}(h]h ]h"]h$]h&]uh1jhjrhhhjhM+ ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjUjjUjjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` Which :c:type:`Scsi_Host` **Description** This routine is expected to be called immediately preceding the a driver's call to scsi_remove_host(). WARNING: A driver utilizing the fc_transport, which fails to call this routine prior to scsi_remove_host(), will leave dangling objects in /sys/class/fc_remote_ports. Access to any of these objects can result in a system crash !!! **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hj_h]h Parameters}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM/ hjYubj#)}(hhh]j()}(h6``struct Scsi_Host *shost`` Which :c:type:`Scsi_Host` h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj~h]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj|ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM, hjxubjJ)}(hhh]h)}(hWhich :c:type:`Scsi_Host`h](hWhich }(hjhhhNhNubh)}(h:c:type:`Scsi_Host`h]j4)}(hjh]h Scsi_Host}(hjhhhNhNubah}(h]h ](jjc-typeeh"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]refdocj refdomainjreftypetype refexplicitrefwarnjjj Scsi_Hostuh1hhjhM, hjubeh}(h]h ]h"]h$]h&]uh1hhjhM, hjubah}(h]h ]h"]h$]h&]uh1jIhjxubeh}(h]h ]h"]h$]h&]uh1j'hjhM, hjuubah}(h]h ]h"]h$]h&]uh1j"hjYubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM. hjYubh)}(hfThis routine is expected to be called immediately preceding the a driver's call to scsi_remove_host().h]hhThis routine is expected to be called immediately preceding the a driver’s call to scsi_remove_host().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM. hjYubj#)}(hhh]j()}(hWARNING: A driver utilizing the fc_transport, which fails to call this routine prior to scsi_remove_host(), will leave dangling objects in /sys/class/fc_remote_ports. Access to any of these objects can result in a system crash !!! h](j.)}(hAWARNING: A driver utilizing the fc_transport, which fails to callh]hAWARNING: A driver utilizing the fc_transport, which fails to call}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM4 hjubjJ)}(hhh]h)}(hthis routine prior to scsi_remove_host(), will leave dangling objects in /sys/class/fc_remote_ports. Access to any of these objects can result in a system crash !!!h]hthis routine prior to scsi_remove_host(), will leave dangling objects in /sys/class/fc_remote_ports. Access to any of these objects can result in a system crash !!!}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM2 hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM4 hjubah}(h]h ]h"]h$]h&]uh1j"hjYubh)}(h **Notes**h]j)}(hj9h]hNotes}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM6 hjYubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hjQh]h0This routine assumes no locks are held on entry.}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM6 hjOubah}(h]h ]h"]h$]h&]uh1j_hj`hM6 hjYubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@fc_remote_port_add (C function)c.fc_remote_port_addhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hmstruct fc_rport * fc_remote_port_add (struct Scsi_Host *shost, int channel, struct fc_rport_identifiers *ids)h]jP)}(hkstruct fc_rport *fc_remote_port_add(struct Scsi_Host *shost, int channel, struct fc_rport_identifiers *ids)h](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM? ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM? ubh)}(hhh]j)}(hfc_rporth]hfc_rport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jfc_remote_port_addsbc.fc_remote_port_addasbuh1hhjhhhjhM? ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM? ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjhhhjhM? ubjy)}(hfc_remote_port_addh]j)}(hjh]hfc_remote_port_add}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhM? ubj)}(hH(struct Scsi_Host *shost, int channel, struct fc_rport_identifiers *ids)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj!modnameN classnameNjj)}j]jc.fc_remote_port_addasbuh1hhjubjh)}(h h]h }(hj=hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjKhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int channelh](j~)}(hinth]hint}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjmubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjmubj)}(hchannelh]hchannel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjmubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h struct fc_rport_identifiers *idsh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hfc_rport_identifiersh]hfc_rport_identifiers}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.fc_remote_port_addasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hidsh]hids}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM? ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM? ubah}(h]jzah ](jjeh"]h$]h&]jj)jhuh1jIhjhM? hj|hhubj)}(hhh]h)}(h9notify fc transport of the existence of a remote FC port.h]h9notify fc transport of the existence of a remote FC port.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM? hj$hhubah}(h]h ]h"]h$]h&]uh1jhj|hhhjhM? ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj?jj?jjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` scsi host the remote port is connected to. ``int channel`` Channel on shost port connected to. ``struct fc_rport_identifiers *ids`` The world wide names, fc address, and FC4 port roles for the remote port. **Description** The LLDD calls this routine to notify the transport of the existence of a remote port. The LLDD provides the unique identifiers (wwpn,wwn) of the port, it's FC address (port_id), and the FC4 roles that are active for the port. For ports that are FCP targets (aka scsi targets), the FC transport maintains consistent target id bindings on behalf of the LLDD. A consistent target id binding is an assignment of a target id to a remote port identifier, which persists while the scsi host is attached. The remote port can disappear, then later reappear, and it's target id assignment remains the same. This allows for shifts in FC addressing (if binding by wwpn or wwnn) with no apparent changes to the scsi subsystem which is based on scsi host number and target id values. Bindings are only valid during the attachment of the scsi host. If the host detaches, then later re-attaches, target id bindings may change. This routine is responsible for returning a remote port structure. The routine will search the list of remote ports it maintains internally on behalf of consistent target id mappings. If found, the remote port structure will be reused. Otherwise, a new remote port structure will be allocated. Whenever a remote port is allocated, a new fc_remote_port class device is created. Should not be called from interrupt context. **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hjIh]h Parameters}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMC hjCubj#)}(hhh](j()}(hG``struct Scsi_Host *shost`` scsi host the remote port is connected to. h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjhh]hstruct Scsi_Host *shost}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjfubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM@ hjbubjJ)}(hhh]h)}(h*scsi host the remote port is connected to.h]h*scsi host the remote port is connected to.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hM@ hj~ubah}(h]h ]h"]h$]h&]uh1jIhjbubeh}(h]h ]h"]h$]h&]uh1j'hj}hM@ hj_ubj()}(h4``int channel`` Channel on shost port connected to. h](j.)}(h``int channel``h]j4)}(hjh]h int channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMA hjubjJ)}(hhh]h)}(h#Channel on shost port connected to.h]h#Channel on shost port connected to.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMA hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMA hj_ubj()}(ho``struct fc_rport_identifiers *ids`` The world wide names, fc address, and FC4 port roles for the remote port. h](j.)}(h$``struct fc_rport_identifiers *ids``h]j4)}(hjh]h struct fc_rport_identifiers *ids}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMC hjubjJ)}(hhh]h)}(hIThe world wide names, fc address, and FC4 port roles for the remote port.h]hIThe world wide names, fc address, and FC4 port roles for the remote port.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMB hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMC hj_ubeh}(h]h ]h"]h$]h&]uh1j"hjCubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chME hjCubh)}(hThe LLDD calls this routine to notify the transport of the existence of a remote port. The LLDD provides the unique identifiers (wwpn,wwn) of the port, it's FC address (port_id), and the FC4 roles that are active for the port.h]hThe LLDD calls this routine to notify the transport of the existence of a remote port. The LLDD provides the unique identifiers (wwpn,wwn) of the port, it’s FC address (port_id), and the FC4 roles that are active for the port.}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chME hjCubh)}(hXFor ports that are FCP targets (aka scsi targets), the FC transport maintains consistent target id bindings on behalf of the LLDD. A consistent target id binding is an assignment of a target id to a remote port identifier, which persists while the scsi host is attached. The remote port can disappear, then later reappear, and it's target id assignment remains the same. This allows for shifts in FC addressing (if binding by wwpn or wwnn) with no apparent changes to the scsi subsystem which is based on scsi host number and target id values. Bindings are only valid during the attachment of the scsi host. If the host detaches, then later re-attaches, target id bindings may change.h]hXFor ports that are FCP targets (aka scsi targets), the FC transport maintains consistent target id bindings on behalf of the LLDD. A consistent target id binding is an assignment of a target id to a remote port identifier, which persists while the scsi host is attached. The remote port can disappear, then later reappear, and it’s target id assignment remains the same. This allows for shifts in FC addressing (if binding by wwpn or wwnn) with no apparent changes to the scsi subsystem which is based on scsi host number and target id values. Bindings are only valid during the attachment of the scsi host. If the host detaches, then later re-attaches, target id bindings may change.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMJ hjCubh)}(hX%This routine is responsible for returning a remote port structure. The routine will search the list of remote ports it maintains internally on behalf of consistent target id mappings. If found, the remote port structure will be reused. Otherwise, a new remote port structure will be allocated.h]hX%This routine is responsible for returning a remote port structure. The routine will search the list of remote ports it maintains internally on behalf of consistent target id mappings. If found, the remote port structure will be reused. Otherwise, a new remote port structure will be allocated.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMV hjCubh)}(hRWhenever a remote port is allocated, a new fc_remote_port class device is created.h]hRWhenever a remote port is allocated, a new fc_remote_port class device is created.}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM\ hjCubh)}(h,Should not be called from interrupt context.h]h,Should not be called from interrupt context.}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM_ hjCubh)}(h **Notes**h]j)}(hjyh]hNotes}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMa hjCubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hjh]h0This routine assumes no locks are held on entry.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMa hjubah}(h]h ]h"]h$]h&]uh1j_hjhMa hjCubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"fc_remote_port_delete (C function)c.fc_remote_port_deletehNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h3void fc_remote_port_delete (struct fc_rport *rport)h]jP)}(h2void fc_remote_port_delete(struct fc_rport *rport)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM ubjy)}(hfc_remote_port_deleteh]j)}(hfc_remote_port_deleteh]hfc_remote_port_delete}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhM ubj)}(h(struct fc_rport *rport)h]j)}(hstruct fc_rport *rporth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hfc_rporth]hfc_rport}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj$modnameN classnameNjj)}j]j)}jjsbc.fc_remote_port_deleteasbuh1hhjubjh)}(h h]h }(hjBhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjPhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hrporth]hrport}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhM hjhhubj)}(hhh]h)}(hGnotifies the fc transport that a remote port is no longer in existence.h]hGnotifies the fc transport that a remote port is no longer in existence.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjhNhNubj)}(hX **Parameters** ``struct fc_rport *rport`` The remote port that no longer exists **Description** The LLDD calls this routine to notify the transport that a remote port is no longer part of the topology. Note: Although a port may no longer be part of the topology, it may persist in the remote ports displayed by the fc_host. We do this under 2 conditions: 1) If the port was a scsi target, we delay its deletion by "blocking" it. This allows the port to temporarily disappear, then reappear without disrupting the SCSI device tree attached to it. During the "blocked" period the port will still exist. 2) If the port was a scsi target and disappears for longer than we expect, we'll delete the port and the tear down the SCSI device tree attached to it. However, we want to semi-persist the target id assigned to that port if it eventually does exist. The port structure will remain (although with minimal information) so that the target id bindings also remain. If the remote port is not an FCP Target, it will be fully torn down and deallocated, including the fc_remote_port class device. If the remote port is an FCP Target, the port will be placed in a temporary blocked state. From the LLDD's perspective, the rport no longer exists. From the SCSI midlayer's perspective, the SCSI target exists, but all sdevs on it are blocked from further I/O. The following is then expected. If the remote port does not return (signaled by a LLDD call to fc_remote_port_add()) within the dev_loss_tmo timeout, then the scsi target is removed - killing all outstanding i/o and removing the scsi devices attached to it. The port structure will be marked Not Present and be partially cleared, leaving only enough information to recognize the remote port relative to the scsi target id binding if it later appears. The port will remain as long as there is a valid binding (e.g. until the user changes the binding type or unloads the scsi host with the binding). If the remote port returns within the dev_loss_tmo value (and matches according to the target id binding type), the port structure will be reused. If it is no longer a SCSI target, the target will be torn down. If it continues to be a SCSI target, then the target will be unblocked (allowing i/o to be resumed), and a scan will be activated to ensure that all luns are detected. Called from normal process context only - cannot be called from interrupt. **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubj#)}(hhh]j()}(hA``struct fc_rport *rport`` The remote port that no longer exists h](j.)}(h``struct fc_rport *rport``h]j4)}(hjh]hstruct fc_rport *rport}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubjJ)}(hhh]h)}(h%The remote port that no longer existsh]h%The remote port that no longer exists}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubh)}(hXThe LLDD calls this routine to notify the transport that a remote port is no longer part of the topology. Note: Although a port may no longer be part of the topology, it may persist in the remote ports displayed by the fc_host. We do this under 2 conditions:h]hXThe LLDD calls this routine to notify the transport that a remote port is no longer part of the topology. Note: Although a port may no longer be part of the topology, it may persist in the remote ports displayed by the fc_host. We do this under 2 conditions:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubhenumerated_list)}(hhh](j8_)}(hIf the port was a scsi target, we delay its deletion by "blocking" it. This allows the port to temporarily disappear, then reappear without disrupting the SCSI device tree attached to it. During the "blocked" period the port will still exist. h]h)}(hIf the port was a scsi target, we delay its deletion by "blocking" it. This allows the port to temporarily disappear, then reappear without disrupting the SCSI device tree attached to it. During the "blocked" period the port will still exist.h]hIf the port was a scsi target, we delay its deletion by “blocking” it. This allows the port to temporarily disappear, then reappear without disrupting the SCSI device tree attached to it. During the “blocked” period the port will still exist.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM$ hj-ubah}(h]h ]h"]h$]h&]uh1j7_hj*ubj8_)}(hXfIf the port was a scsi target and disappears for longer than we expect, we'll delete the port and the tear down the SCSI device tree attached to it. However, we want to semi-persist the target id assigned to that port if it eventually does exist. The port structure will remain (although with minimal information) so that the target id bindings also remain. h]h)}(hXeIf the port was a scsi target and disappears for longer than we expect, we'll delete the port and the tear down the SCSI device tree attached to it. However, we want to semi-persist the target id assigned to that port if it eventually does exist. The port structure will remain (although with minimal information) so that the target id bindings also remain.h]hXgIf the port was a scsi target and disappears for longer than we expect, we’ll delete the port and the tear down the SCSI device tree attached to it. However, we want to semi-persist the target id assigned to that port if it eventually does exist. The port structure will remain (although with minimal information) so that the target id bindings also remain.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM) hjFubah}(h]h ]h"]h$]h&]uh1j7_hj*ubeh}(h]h ]h"]h$]h&]enumtypearabicprefixhsuffixjuh1j(hjubh)}(hIf the remote port is not an FCP Target, it will be fully torn down and deallocated, including the fc_remote_port class device.h]hIf the remote port is not an FCP Target, it will be fully torn down and deallocated, including the fc_remote_port class device.}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM0 hjubh)}(hX#If the remote port is an FCP Target, the port will be placed in a temporary blocked state. From the LLDD's perspective, the rport no longer exists. From the SCSI midlayer's perspective, the SCSI target exists, but all sdevs on it are blocked from further I/O. The following is then expected.h]hX'If the remote port is an FCP Target, the port will be placed in a temporary blocked state. From the LLDD’s perspective, the rport no longer exists. From the SCSI midlayer’s perspective, the SCSI target exists, but all sdevs on it are blocked from further I/O. The following is then expected.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM3 hjubj`)}(hXIf the remote port does not return (signaled by a LLDD call to fc_remote_port_add()) within the dev_loss_tmo timeout, then the scsi target is removed - killing all outstanding i/o and removing the scsi devices attached to it. The port structure will be marked Not Present and be partially cleared, leaving only enough information to recognize the remote port relative to the scsi target id binding if it later appears. The port will remain as long as there is a valid binding (e.g. until the user changes the binding type or unloads the scsi host with the binding). If the remote port returns within the dev_loss_tmo value (and matches according to the target id binding type), the port structure will be reused. If it is no longer a SCSI target, the target will be torn down. If it continues to be a SCSI target, then the target will be unblocked (allowing i/o to be resumed), and a scan will be activated to ensure that all luns are detected. h](h)}(hX6If the remote port does not return (signaled by a LLDD call to fc_remote_port_add()) within the dev_loss_tmo timeout, then the scsi target is removed - killing all outstanding i/o and removing the scsi devices attached to it. The port structure will be marked Not Present and be partially cleared, leaving only enough information to recognize the remote port relative to the scsi target id binding if it later appears. The port will remain as long as there is a valid binding (e.g. until the user changes the binding type or unloads the scsi host with the binding).h]hX6If the remote port does not return (signaled by a LLDD call to fc_remote_port_add()) within the dev_loss_tmo timeout, then the scsi target is removed - killing all outstanding i/o and removing the scsi devices attached to it. The port structure will be marked Not Present and be partially cleared, leaving only enough information to recognize the remote port relative to the scsi target id binding if it later appears. The port will remain as long as there is a valid binding (e.g. until the user changes the binding type or unloads the scsi host with the binding).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM9 hjubh)}(hXzIf the remote port returns within the dev_loss_tmo value (and matches according to the target id binding type), the port structure will be reused. If it is no longer a SCSI target, the target will be torn down. If it continues to be a SCSI target, then the target will be unblocked (allowing i/o to be resumed), and a scan will be activated to ensure that all luns are detected.h]hXzIf the remote port returns within the dev_loss_tmo value (and matches according to the target id binding type), the port structure will be reused. If it is no longer a SCSI target, the target will be torn down. If it continues to be a SCSI target, then the target will be unblocked (allowing i/o to be resumed), and a scan will be activated to ensure that all luns are detected.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMC hjubeh}(h]h ]h"]h$]h&]uh1j_hjhM9 hjubh)}(hJCalled from normal process context only - cannot be called from interrupt.h]hJCalled from normal process context only - cannot be called from interrupt.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMJ hjubh)}(h **Notes**h]j)}(hjh]hNotes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chML hjubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hjh]h0This routine assumes no locks are held on entry.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chML hjubah}(h]h ]h"]h$]h&]uh1j_hjhML hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@#fc_remote_port_rolechg (C function)c.fc_remote_port_rolechghNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h?void fc_remote_port_rolechg (struct fc_rport *rport, u32 roles)h]jP)}(h>void fc_remote_port_rolechg(struct fc_rport *rport, u32 roles)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj hhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj hhhjhM ubjy)}(hfc_remote_port_rolechgh]j)}(hfc_remote_port_rolechgh]hfc_remote_port_rolechg}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj+ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj hhhjhM ubj)}(h#(struct fc_rport *rport, u32 roles)h](j)}(hstruct fc_rport *rporth](jV)}(hjYh]hstruct}(hjKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjGubjh)}(h h]h }(hjXhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjGubh)}(hhh]j)}(hfc_rporth]hfc_rport}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjfubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjkmodnameN classnameNjj)}j]j)}jj1sbc.fc_remote_port_rolechgasbuh1hhjGubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjGubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjGubj)}(hrporth]hrport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjGubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjCubj)}(h u32 rolesh](h)}(hhh]j)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.fc_remote_port_rolechgasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hrolesh]hroles}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjCubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhM hjhhubj)}(hhh]h)}(hFnotifies the fc transport that the roles on a remote may have changed.h]hFnotifies the fc transport that the roles on a remote may have changed.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj.jj.jjjuh1jDhhhjhNhNubj)}(hX**Parameters** ``struct fc_rport *rport`` The remote port that changed. ``u32 roles`` New roles for this port. **Description** The LLDD calls this routine to notify the transport that the roles on a remote port may have changed. The largest effect of this is if a port now becomes a FCP Target, it must be allocated a scsi target id. If the port is no longer a FCP target, any scsi target id value assigned to it will persist in case the role changes back to include FCP Target. No changes in the scsi midlayer will be invoked if the role changes (in the expectation that the role will be resumed. If it doesn't normal error processing will take place). Should not be called from interrupt context. **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hj8h]h Parameters}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hj2ubj#)}(hhh](j()}(h9``struct fc_rport *rport`` The remote port that changed. h](j.)}(h``struct fc_rport *rport``h]j4)}(hjWh]hstruct fc_rport *rport}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjUubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjQubjJ)}(hhh]h)}(hThe remote port that changed.h]hThe remote port that changed.}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhM hjmubah}(h]h ]h"]h$]h&]uh1jIhjQubeh}(h]h ]h"]h$]h&]uh1j'hjlhM hjNubj()}(h'``u32 roles`` New roles for this port. h](j.)}(h ``u32 roles``h]j4)}(hjh]h u32 roles}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubjJ)}(hhh]h)}(hNew roles for this port.h]hNew roles for this port.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhM hjNubeh}(h]h ]h"]h$]h&]uh1j"hj2ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hj2ubh)}(hXThe LLDD calls this routine to notify the transport that the roles on a remote port may have changed. The largest effect of this is if a port now becomes a FCP Target, it must be allocated a scsi target id. If the port is no longer a FCP target, any scsi target id value assigned to it will persist in case the role changes back to include FCP Target. No changes in the scsi midlayer will be invoked if the role changes (in the expectation that the role will be resumed. If it doesn't normal error processing will take place).h]hXThe LLDD calls this routine to notify the transport that the roles on a remote port may have changed. The largest effect of this is if a port now becomes a FCP Target, it must be allocated a scsi target id. If the port is no longer a FCP target, any scsi target id value assigned to it will persist in case the role changes back to include FCP Target. No changes in the scsi midlayer will be invoked if the role changes (in the expectation that the role will be resumed. If it doesn’t normal error processing will take place).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hj2ubh)}(h,Should not be called from interrupt context.h]h,Should not be called from interrupt context.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hj2ubh)}(h **Notes**h]j)}(hjh]hNotes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hj2ubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hjh]h0This routine assumes no locks are held on entry.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM hjubah}(h]h ]h"]h$]h&]uh1j_hj(hM hj2ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@fc_block_rport (C function)c.fc_block_rporthNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h+int fc_block_rport (struct fc_rport *rport)h]jP)}(h*int fc_block_rport(struct fc_rport *rport)h](j~)}(hinth]hint}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjKhhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMubjh)}(h h]h }(hj^hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjKhhhj]hMubjy)}(hfc_block_rporth]j)}(hfc_block_rporth]hfc_block_rport}(hjphhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjlubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjKhhhj]hMubj)}(h(struct fc_rport *rport)h]j)}(hstruct fc_rport *rporth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hfc_rporth]hfc_rport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjrsbc.fc_block_rportasbuh1hhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hrporth]hrport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjKhhhj]hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjGhhhj]hMubah}(h]jBah ](jjeh"]h$]h&]jj)jhuh1jIhj]hMhjDhhubj)}(hhh]h)}(h*Block SCSI eh thread for blocked fc_rport.h]h*Block SCSI eh thread for blocked fc_rport.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj hhubah}(h]h ]h"]h$]h&]uh1jhjDhhhj]hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj'jj'jjjuh1jDhhhjhNhNubj)}(hX?**Parameters** ``struct fc_rport *rport`` Remote port that scsi_eh is trying to recover. **Description** This routine can be called from a FC LLD scsi_eh callback. It blocks the scsi_eh thread until the fc_rport leaves the FC_PORTSTATE_BLOCKED, or the fast_io_fail_tmo fires. This is necessary to avoid the scsi_eh failing recovery actions for blocked rports which would lead to offlined SCSI devices. **Return** 0 if the fc_rport left the state FC_PORTSTATE_BLOCKED. FAST_IO_FAIL if the fast_io_fail_tmo fired, this should be passed back to scsi_eh.h](h)}(h**Parameters**h]j)}(hj1h]h Parameters}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj+ubj#)}(hhh]j()}(hJ``struct fc_rport *rport`` Remote port that scsi_eh is trying to recover. h](j.)}(h``struct fc_rport *rport``h]j4)}(hjPh]hstruct fc_rport *rport}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjNubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjJubjJ)}(hhh]h)}(h.Remote port that scsi_eh is trying to recover.h]h.Remote port that scsi_eh is trying to recover.}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMhjfubah}(h]h ]h"]h$]h&]uh1jIhjJubeh}(h]h ]h"]h$]h&]uh1j'hjehMhjGubah}(h]h ]h"]h$]h&]uh1j"hj+ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj+ubh)}(hX(This routine can be called from a FC LLD scsi_eh callback. It blocks the scsi_eh thread until the fc_rport leaves the FC_PORTSTATE_BLOCKED, or the fast_io_fail_tmo fires. This is necessary to avoid the scsi_eh failing recovery actions for blocked rports which would lead to offlined SCSI devices.h]hX(This routine can be called from a FC LLD scsi_eh callback. It blocks the scsi_eh thread until the fc_rport leaves the FC_PORTSTATE_BLOCKED, or the fast_io_fail_tmo fires. This is necessary to avoid the scsi_eh failing recovery actions for blocked rports which would lead to offlined SCSI devices.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj+ubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj+ubj#)}(hhh]j()}(h0 if the fc_rport left the state FC_PORTSTATE_BLOCKED. FAST_IO_FAIL if the fast_io_fail_tmo fired, this should be passed back to scsi_eh.h](j.)}(h60 if the fc_rport left the state FC_PORTSTATE_BLOCKED.h]h60 if the fc_rport left the state FC_PORTSTATE_BLOCKED.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhjubjJ)}(hhh]h)}(hRFAST_IO_FAIL if the fast_io_fail_tmo fired, this should be passed back to scsi_eh.h]hRFAST_IO_FAIL if the fast_io_fail_tmo fired, this should be passed back to scsi_eh.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubah}(h]h ]h"]h$]h&]uh1j"hj+ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@fc_block_scsi_eh (C function)c.fc_block_scsi_ehhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h-int fc_block_scsi_eh (struct scsi_cmnd *cmnd)h]jP)}(h,int fc_block_scsi_eh(struct scsi_cmnd *cmnd)h](j~)}(hinth]hint}(hj! hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj hhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMubjh)}(h h]h }(hj0 hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj hhhj/ hMubjy)}(hfc_block_scsi_ehh]j)}(hfc_block_scsi_ehh]hfc_block_scsi_eh}(hjB hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj> ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj hhhj/ hMubj)}(h(struct scsi_cmnd *cmnd)h]j)}(hstruct scsi_cmnd *cmndh](jV)}(hjYh]hstruct}(hj^ hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZ ubjh)}(h h]h }(hjk hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjZ ubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hj| hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjy ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj~ modnameN classnameNjj)}j]j)}jjD sbc.fc_block_scsi_ehasbuh1hhjZ ubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjZ ubj )}(hj h]h*}(hj hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjZ ubj)}(hcmndh]hcmnd}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjZ ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjV ubah}(h]h ]h"]h$]h&]jjuh1jhj hhhj/ hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj hhhj/ hMubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1jIhj/ hMhj hhubj)}(hhh]h)}(h)Block SCSI eh thread for blocked fc_rporth]h)Block SCSI eh thread for blocked fc_rport}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj hhubah}(h]h ]h"]h$]h&]uh1jhj hhhj/ hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jj jjjuh1jDhhhjhNhNubj)}(hX?**Parameters** ``struct scsi_cmnd *cmnd`` SCSI command that scsi_eh is trying to recover **Description** This routine can be called from a FC LLD scsi_eh callback. It blocks the scsi_eh thread until the fc_rport leaves the FC_PORTSTATE_BLOCKED, or the fast_io_fail_tmo fires. This is necessary to avoid the scsi_eh failing recovery actions for blocked rports which would lead to offlined SCSI devices. **Return** 0 if the fc_rport left the state FC_PORTSTATE_BLOCKED. FAST_IO_FAIL if the fast_io_fail_tmo fired, this should be passed back to scsi_eh.h](h)}(h**Parameters**h]j)}(hj!h]h Parameters}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj ubj#)}(hhh]j()}(hJ``struct scsi_cmnd *cmnd`` SCSI command that scsi_eh is trying to recover h](j.)}(h``struct scsi_cmnd *cmnd``h]j4)}(hj"!h]hstruct scsi_cmnd *cmnd}(hj$!hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj !ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj!ubjJ)}(hhh]h)}(h.SCSI command that scsi_eh is trying to recoverh]h.SCSI command that scsi_eh is trying to recover}(hj;!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7!hMhj8!ubah}(h]h ]h"]h$]h&]uh1jIhj!ubeh}(h]h ]h"]h$]h&]uh1j'hj7!hMhj!ubah}(h]h ]h"]h$]h&]uh1j"hj ubh)}(h**Description**h]j)}(hj]!h]h Description}(hj_!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[!ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj ubh)}(hX(This routine can be called from a FC LLD scsi_eh callback. It blocks the scsi_eh thread until the fc_rport leaves the FC_PORTSTATE_BLOCKED, or the fast_io_fail_tmo fires. This is necessary to avoid the scsi_eh failing recovery actions for blocked rports which would lead to offlined SCSI devices.h]hX(This routine can be called from a FC LLD scsi_eh callback. It blocks the scsi_eh thread until the fc_rport leaves the FC_PORTSTATE_BLOCKED, or the fast_io_fail_tmo fires. This is necessary to avoid the scsi_eh failing recovery actions for blocked rports which would lead to offlined SCSI devices.}(hjs!hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj ubh)}(h **Return**h]j)}(hj!h]hReturn}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj ubj#)}(hhh]j()}(h0 if the fc_rport left the state FC_PORTSTATE_BLOCKED. FAST_IO_FAIL if the fast_io_fail_tmo fired, this should be passed back to scsi_eh.h](j.)}(h60 if the fc_rport left the state FC_PORTSTATE_BLOCKED.h]h60 if the fc_rport left the state FC_PORTSTATE_BLOCKED.}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMhj!ubjJ)}(hhh]h)}(hRFAST_IO_FAIL if the fast_io_fail_tmo fired, this should be passed back to scsi_eh.h]hRFAST_IO_FAIL if the fast_io_fail_tmo fired, this should be passed back to scsi_eh.}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMhj!ubah}(h]h ]h"]h$]h&]uh1jIhj!ubeh}(h]h ]h"]h$]h&]uh1j'hj!hMhj!ubah}(h]h ]h"]h$]h&]uh1j"hj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@fc_vport_create (C function)c.fc_vport_createhNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(hjstruct fc_vport * fc_vport_create (struct Scsi_Host *shost, int channel, struct fc_vport_identifiers *ids)h]jP)}(hhstruct fc_vport *fc_vport_create(struct Scsi_Host *shost, int channel, struct fc_vport_identifiers *ids)h](jV)}(hjYh]hstruct}(hj!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj!hhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMaubjh)}(h h]h }(hj"hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj!hhhj"hMaubh)}(hhh]j)}(hfc_vporth]hfc_vport}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj"ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj"modnameN classnameNjj)}j]j)}jfc_vport_createsbc.fc_vport_createasbuh1hhj!hhhj"hMaubjh)}(h h]h }(hj3"hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj!hhhj"hMaubj )}(hj h]h*}(hjA"hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj!hhhj"hMaubjy)}(hfc_vport_createh]j)}(hj0"h]hfc_vport_create}(hjR"hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjN"ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj!hhhj"hMaubj)}(hH(struct Scsi_Host *shost, int channel, struct fc_vport_identifiers *ids)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjm"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhji"ubjh)}(h h]h }(hjz"hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghji"ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj"ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj"modnameN classnameNjj)}j]j."c.fc_vport_createasbuh1hhji"ubjh)}(h h]h }(hj"hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghji"ubj )}(hj h]h*}(hj"hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hji"ubj)}(hshosth]hshost}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hji"ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhje"ubj)}(h int channelh](j~)}(hinth]hint}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj"ubjh)}(h h]h }(hj"hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj"ubj)}(hchannelh]hchannel}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj"ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhje"ubj)}(h struct fc_vport_identifiers *idsh](jV)}(hjYh]hstruct}(hj#hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj#ubjh)}(h h]h }(hj#hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj#ubh)}(hhh]j)}(hfc_vport_identifiersh]hfc_vport_identifiers}(hj0#hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj-#ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj2#modnameN classnameNjj)}j]j."c.fc_vport_createasbuh1hhj#ubjh)}(h h]h }(hjN#hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj#ubj )}(hj h]h*}(hj\#hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj#ubj)}(hidsh]hids}(hji#hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj#ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhje"ubeh}(h]h ]h"]h$]h&]jjuh1jhj!hhhj"hMaubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj!hhhj"hMaubah}(h]j!ah ](jjeh"]h$]h&]jj)jhuh1jIhj"hMahj!hhubj)}(hhh]h)}(h.Admin App or LLDD requests creation of a vporth]h.Admin App or LLDD requests creation of a vport}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMahj#hhubah}(h]h ]h"]h$]h&]uh1jhj!hhhj"hMaubeh}(h]h ](jfunctioneh"]h$]h&]jjjj#jj#jjjuh1jDhhhjhNhNubj)}(hX<**Parameters** ``struct Scsi_Host *shost`` scsi host the virtual port is connected to. ``int channel`` channel on shost port connected to. ``struct fc_vport_identifiers *ids`` The world wide names, FC4 port roles, etc for the virtual port. **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hj#h]h Parameters}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMehj#ubj#)}(hhh](j()}(hH``struct Scsi_Host *shost`` scsi host the virtual port is connected to. h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj#h]hstruct Scsi_Host *shost}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj#ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMbhj#ubjJ)}(hhh]h)}(h+scsi host the virtual port is connected to.h]h+scsi host the virtual port is connected to.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hMbhj#ubah}(h]h ]h"]h$]h&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j'hj#hMbhj#ubj()}(h4``int channel`` channel on shost port connected to. h](j.)}(h``int channel``h]j4)}(hj $h]h int channel}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj $ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMchj$ubjJ)}(hhh]h)}(h#channel on shost port connected to.h]h#channel on shost port connected to.}(hj&$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"$hMchj#$ubah}(h]h ]h"]h$]h&]uh1jIhj$ubeh}(h]h ]h"]h$]h&]uh1j'hj"$hMchj#ubj()}(he``struct fc_vport_identifiers *ids`` The world wide names, FC4 port roles, etc for the virtual port. h](j.)}(h$``struct fc_vport_identifiers *ids``h]j4)}(hjF$h]h struct fc_vport_identifiers *ids}(hjH$hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjD$ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMehj@$ubjJ)}(hhh]h)}(h?The world wide names, FC4 port roles, etc for the virtual port.h]h?The world wide names, FC4 port roles, etc for the virtual port.}(hj_$hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMdhj\$ubah}(h]h ]h"]h$]h&]uh1jIhj@$ubeh}(h]h ]h"]h$]h&]uh1j'hj[$hMehj#ubeh}(h]h ]h"]h$]h&]uh1j"hj#ubh)}(h **Notes**h]j)}(hj$h]hNotes}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMghj#ubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hj$h]h0This routine assumes no locks are held on entry.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMghj$ubah}(h]h ]h"]h$]h&]uh1j_hj$hMghj#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@fc_vport_terminate (C function)c.fc_vport_terminatehNtauh1j3hjhhhNhNubjE)}(hhh](jJ)}(h/int fc_vport_terminate (struct fc_vport *vport)h]jP)}(h.int fc_vport_terminate(struct fc_vport *vport)h](j~)}(hinth]hint}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj$hhha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMxubjh)}(h h]h }(hj$hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj$hhhj$hMxubjy)}(hfc_vport_terminateh]j)}(hfc_vport_terminateh]hfc_vport_terminate}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj$ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj$hhhj$hMxubj)}(h(struct fc_vport *vport)h]j)}(hstruct fc_vport *vporth](jV)}(hjYh]hstruct}(hj %hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj %ubjh)}(h h]h }(hj%hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj %ubh)}(hhh]j)}(hfc_vporth]hfc_vport}(hj+%hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(%ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj-%modnameN classnameNjj)}j]j)}jj$sbc.fc_vport_terminateasbuh1hhj %ubjh)}(h h]h }(hjK%hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj %ubj )}(hj h]h*}(hjY%hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj %ubj)}(hvporth]hvport}(hjf%hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj %ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj%ubah}(h]h ]h"]h$]h&]jjuh1jhj$hhhj$hMxubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj$hhhj$hMxubah}(h]j$ah ](jjeh"]h$]h&]jj)jhuh1jIhj$hMxhj$hhubj)}(hhh]h)}(h1Admin App or LLDD requests termination of a vporth]h1Admin App or LLDD requests termination of a vport}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMxhj%hhubah}(h]h ]h"]h$]h&]uh1jhj$hhhj$hMxubeh}(h]h ](jfunctioneh"]h$]h&]jjjj%jj%jjjuh1jDhhhjhNhNubj)}(hX **Parameters** ``struct fc_vport *vport`` fc_vport to be terminated **Description** Calls the LLDD vport_delete() function, then deallocates and removes the vport from the shost and object tree. **Notes** This routine assumes no locks are held on entry.h](h)}(h**Parameters**h]j)}(hj%h]h Parameters}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM|hj%ubj#)}(hhh]j()}(h5``struct fc_vport *vport`` fc_vport to be terminated h](j.)}(h``struct fc_vport *vport``h]j4)}(hj%h]hstruct fc_vport *vport}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj%ubah}(h]h ]h"]h$]h&]uh1j-ha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chMyhj%ubjJ)}(hhh]h)}(hfc_vport to be terminatedh]hfc_vport to be terminated}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hMyhj%ubah}(h]h ]h"]h$]h&]uh1jIhj%ubeh}(h]h ]h"]h$]h&]uh1j'hj%hMyhj%ubah}(h]h ]h"]h$]h&]uh1j"hj%ubh)}(h**Description**h]j)}(hj &h]h Description}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj &ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM{hj%ubh)}(hnCalls the LLDD vport_delete() function, then deallocates and removes the vport from the shost and object tree.h]hnCalls the LLDD vport_delete() function, then deallocates and removes the vport from the shost and object tree.}(hj"&hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM{hj%ubh)}(h **Notes**h]j)}(hj3&h]hNotes}(hj5&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1&ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM~hj%ubj`)}(h0This routine assumes no locks are held on entry.h]h)}(hjK&h]h0This routine assumes no locks are held on entry.}(hjM&hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:239: ./drivers/scsi/scsi_transport_fc.chM~hjI&ubah}(h]h ]h"]h$]h&]uh1j_hjZ&hM~hj%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h]fibre-channel-transportah ]h"]fibre channel transportah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hiSCSI transport classh]hiSCSI transport class}(hjs&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjp&hhhhhKubh)}(hThe file drivers/scsi/scsi_transport_iscsi.c defines transport attributes for the iSCSI class, which sends SCSI packets over TCP/IP connections.h]hThe file drivers/scsi/scsi_transport_iscsi.c defines transport attributes for the iSCSI class, which sends SCSI packets over TCP/IP connections.}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjp&hhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"iscsi_lookup_endpoint (C function)c.iscsi_lookup_endpointhNtauh1j3hjp&hhhNhNubjE)}(hhh](jJ)}(h:struct iscsi_endpoint * iscsi_lookup_endpoint (u64 handle)h]jP)}(h8struct iscsi_endpoint *iscsi_lookup_endpoint(u64 handle)h](jV)}(hjYh]hstruct}(hj&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&hhhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMubjh)}(h h]h }(hj&hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj&hhhj&hMubh)}(hhh]j)}(hiscsi_endpointh]hiscsi_endpoint}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj&modnameN classnameNjj)}j]j)}jiscsi_lookup_endpointsbc.iscsi_lookup_endpointasbuh1hhj&hhhj&hMubjh)}(h h]h }(hj&hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj&hhhj&hMubj )}(hj h]h*}(hj&hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj&hhhj&hMubjy)}(hiscsi_lookup_endpointh]j)}(hj&h]hiscsi_lookup_endpoint}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj'ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj&hhhj&hMubj)}(h (u64 handle)h]j)}(h u64 handleh](h)}(hhh]j)}(hu64h]hu64}(hj%'hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj"'ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj''modnameN classnameNjj)}j]j&c.iscsi_lookup_endpointasbuh1hhj'ubjh)}(h h]h }(hjC'hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj'ubj)}(hhandleh]hhandle}(hjQ'hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj'ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj'ubah}(h]h ]h"]h$]h&]jjuh1jhj&hhhj&hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj&hhhj&hMubah}(h]j&ah ](jjeh"]h$]h&]jj)jhuh1jIhj&hMhj&hhubj)}(hhh]h)}(hget ep from handleh]hget ep from handle}(hj{'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhjx'hhubah}(h]h ]h"]h$]h&]uh1jhj&hhhj&hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj'jj'jjjuh1jDhhhjp&hNhNubj)}(hg**Parameters** ``u64 handle`` endpoint handle **Description** Caller must do a iscsi_put_endpoint.h](h)}(h**Parameters**h]j)}(hj'h]h Parameters}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj'ubj#)}(hhh]j()}(h``u64 handle`` endpoint handle h](j.)}(h``u64 handle``h]j4)}(hj'h]h u64 handle}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj'ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj'ubjJ)}(hhh]h)}(hendpoint handleh]hendpoint handle}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hMhj'ubah}(h]h ]h"]h$]h&]uh1jIhj'ubeh}(h]h ]h"]h$]h&]uh1j'hj'hMhj'ubah}(h]h ]h"]h$]h&]uh1j"hj'ubh)}(h**Description**h]j)}(hj'h]h Description}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj'ubh)}(h$Caller must do a iscsi_put_endpoint.h]h$Caller must do a iscsi_put_endpoint.}(hj (hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj'ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjp&hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@(iscsi_create_flashnode_sess (C function)c.iscsi_create_flashnode_sesshNtauh1j3hjp&hhhNhNubjE)}(hhh](jJ)}(hstruct iscsi_bus_flash_session * iscsi_create_flashnode_sess (struct Scsi_Host *shost, int index, struct iscsi_transport *transport, int dd_size)h]jP)}(hstruct iscsi_bus_flash_session *iscsi_create_flashnode_sess(struct Scsi_Host *shost, int index, struct iscsi_transport *transport, int dd_size)h](jV)}(hjYh]hstruct}(hj<(hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8(hhhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMubjh)}(h h]h }(hjJ(hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj8(hhhjI(hMubh)}(hhh]j)}(hiscsi_bus_flash_sessionh]hiscsi_bus_flash_session}(hj[(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjX(ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj](modnameN classnameNjj)}j]j)}jiscsi_create_flashnode_sesssbc.iscsi_create_flashnode_sessasbuh1hhj8(hhhjI(hMubjh)}(h h]h }(hj|(hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj8(hhhjI(hMubj )}(hj h]h*}(hj(hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj8(hhhjI(hMubjy)}(hiscsi_create_flashnode_sessh]j)}(hjy(h]hiscsi_create_flashnode_sess}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj8(hhhjI(hMubj)}(hT(struct Scsi_Host *shost, int index, struct iscsi_transport *transport, int dd_size)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj(hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(ubjh)}(h h]h }(hj(hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj(ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj(modnameN classnameNjj)}j]jw(c.iscsi_create_flashnode_sessasbuh1hhj(ubjh)}(h h]h }(hj(hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj(ubj )}(hj h]h*}(hj)hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj(ubj)}(hshosth]hshost}(hj )hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj(ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(h int indexh](j~)}(hinth]hint}(hj&)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj")ubjh)}(h h]h }(hj4)hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj")ubj)}(hindexh]hindex}(hjB)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj")ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(h!struct iscsi_transport *transporth](jV)}(hjYh]hstruct}(hj[)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjW)ubjh)}(h h]h }(hjh)hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjW)ubh)}(hhh]j)}(hiscsi_transporth]hiscsi_transport}(hjy)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjv)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj{)modnameN classnameNjj)}j]jw(c.iscsi_create_flashnode_sessasbuh1hhjW)ubjh)}(h h]h }(hj)hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjW)ubj )}(hj h]h*}(hj)hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjW)ubj)}(h transporth]h transport}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjW)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubj)}(h int dd_sizeh](j~)}(hinth]hint}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj)ubjh)}(h h]h }(hj)hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj)ubj)}(hdd_sizeh]hdd_size}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj(ubeh}(h]h ]h"]h$]h&]jjuh1jhj8(hhhjI(hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj4(hhhjI(hMubah}(h]j/(ah ](jjeh"]h$]h&]jj)jhuh1jIhjI(hMhj1(hhubj)}(hhh]h)}(h$Add flashnode session entry in sysfsh]h$Add flashnode session entry in sysfs}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj*hhubah}(h]h ]h"]h$]h&]uh1jhj1(hhhjI(hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj)*jj)*jjjuh1jDhhhjp&hNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` pointer to host data ``int index`` index of flashnode to add in sysfs ``struct iscsi_transport *transport`` pointer to transport data ``int dd_size`` total size to allocate **Description** Adds a sysfs entry for the flashnode session attributes **Return** pointer to allocated flashnode sess on success ``NULL`` on failureh](h)}(h**Parameters**h]j)}(hj3*h]h Parameters}(hj5*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1*ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj-*ubj#)}(hhh](j()}(h1``struct Scsi_Host *shost`` pointer to host data h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjR*h]hstruct Scsi_Host *shost}(hjT*hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjP*ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhjL*ubjJ)}(hhh]h)}(hpointer to host datah]hpointer to host data}(hjk*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjg*hMhjh*ubah}(h]h ]h"]h$]h&]uh1jIhjL*ubeh}(h]h ]h"]h$]h&]uh1j'hjg*hMhjI*ubj()}(h1``int index`` index of flashnode to add in sysfs h](j.)}(h ``int index``h]j4)}(hj*h]h int index}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj*ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj*ubjJ)}(hhh]h)}(h"index of flashnode to add in sysfsh]h"index of flashnode to add in sysfs}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hMhj*ubah}(h]h ]h"]h$]h&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j'hj*hMhjI*ubj()}(h@``struct iscsi_transport *transport`` pointer to transport data h](j.)}(h%``struct iscsi_transport *transport``h]j4)}(hj*h]h!struct iscsi_transport *transport}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj*ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj*ubjJ)}(hhh]h)}(hpointer to transport datah]hpointer to transport data}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hMhj*ubah}(h]h ]h"]h$]h&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j'hj*hMhjI*ubj()}(h'``int dd_size`` total size to allocate h](j.)}(h``int dd_size``h]j4)}(hj*h]h int dd_size}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj*ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj*ubjJ)}(hhh]h)}(htotal size to allocateh]htotal size to allocate}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+hMhj+ubah}(h]h ]h"]h$]h&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j'hj+hMhjI*ubeh}(h]h ]h"]h$]h&]uh1j"hj-*ubh)}(h**Description**h]j)}(hj8+h]h Description}(hj:+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6+ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj-*ubh)}(h7Adds a sysfs entry for the flashnode session attributesh]h7Adds a sysfs entry for the flashnode session attributes}(hjN+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj-*ubh)}(h **Return**h]j)}(hj_+h]hReturn}(hja+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]+ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj-*ubj`)}(hBpointer to allocated flashnode sess on success ``NULL`` on failureh]h)}(hBpointer to allocated flashnode sess on success ``NULL`` on failureh](h/pointer to allocated flashnode sess on success }(hjy+hhhNhNubj4)}(h``NULL``h]hNULL}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjy+ubh on failure}(hjy+hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhju+ubah}(h]h ]h"]h$]h&]uh1j_hj+hMhj-*ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjp&hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@(iscsi_create_flashnode_conn (C function)c.iscsi_create_flashnode_connhNtauh1j3hjp&hhhNhNubjE)}(hhh](jJ)}(hstruct iscsi_bus_flash_conn * iscsi_create_flashnode_conn (struct Scsi_Host *shost, struct iscsi_bus_flash_session *fnode_sess, struct iscsi_transport *transport, int dd_size)h]jP)}(hstruct iscsi_bus_flash_conn *iscsi_create_flashnode_conn(struct Scsi_Host *shost, struct iscsi_bus_flash_session *fnode_sess, struct iscsi_transport *transport, int dd_size)h](jV)}(hjYh]hstruct}(hj+hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj+hhhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMubjh)}(h h]h }(hj+hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj+hhhj+hMubh)}(hhh]j)}(hiscsi_bus_flash_connh]hiscsi_bus_flash_conn}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj+ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj+modnameN classnameNjj)}j]j)}jiscsi_create_flashnode_connsbc.iscsi_create_flashnode_connasbuh1hhj+hhhj+hMubjh)}(h h]h }(hj,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj+hhhj+hMubj )}(hj h]h*}(hj,hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj+hhhj+hMubjy)}(hiscsi_create_flashnode_connh]j)}(hj+h]hiscsi_create_flashnode_conn}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj,ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj+hhhj+hMubj)}(hu(struct Scsi_Host *shost, struct iscsi_bus_flash_session *fnode_sess, struct iscsi_transport *transport, int dd_size)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj:,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj6,ubjh)}(h h]h }(hjG,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj6,ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjX,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjU,ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjZ,modnameN classnameNjj)}j]j+c.iscsi_create_flashnode_connasbuh1hhj6,ubjh)}(h h]h }(hjv,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj6,ubj )}(hj h]h*}(hj,hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj6,ubj)}(hshosth]hshost}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj6,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2,ubj)}(h*struct iscsi_bus_flash_session *fnode_sessh](jV)}(hjYh]hstruct}(hj,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj,ubjh)}(h h]h }(hj,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj,ubh)}(hhh]j)}(hiscsi_bus_flash_sessionh]hiscsi_bus_flash_session}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj,ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj,modnameN classnameNjj)}j]j+c.iscsi_create_flashnode_connasbuh1hhj,ubjh)}(h h]h }(hj,hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj,ubj )}(hj h]h*}(hj,hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj,ubj)}(h fnode_sessh]h fnode_sess}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2,ubj)}(h!struct iscsi_transport *transporth](jV)}(hjYh]hstruct}(hj-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubjh)}(h h]h }(hj'-hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj-ubh)}(hhh]j)}(hiscsi_transporth]hiscsi_transport}(hj8-hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj5-ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj:-modnameN classnameNjj)}j]j+c.iscsi_create_flashnode_connasbuh1hhj-ubjh)}(h h]h }(hjV-hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj-ubj )}(hj h]h*}(hjd-hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj-ubj)}(h transporth]h transport}(hjq-hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2,ubj)}(h int dd_sizeh](j~)}(hinth]hint}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj-ubjh)}(h h]h }(hj-hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj-ubj)}(hdd_sizeh]hdd_size}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2,ubeh}(h]h ]h"]h$]h&]jjuh1jhj+hhhj+hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj+hhhj+hMubah}(h]j+ah ](jjeh"]h$]h&]jj)jhuh1jIhj+hMhj+hhubj)}(hhh]h)}(h!Add flashnode conn entry in sysfsh]h!Add flashnode conn entry in sysfs}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj-hhubah}(h]h ]h"]h$]h&]uh1jhj+hhhj+hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj-jj-jjjuh1jDhhhjp&hNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` pointer to host data ``struct iscsi_bus_flash_session *fnode_sess`` pointer to the parent flashnode session entry ``struct iscsi_transport *transport`` pointer to transport data ``int dd_size`` total size to allocate **Description** Adds a sysfs entry for the flashnode connection attributes **Return** pointer to allocated flashnode conn on success ``NULL`` on failureh](h)}(h**Parameters**h]j)}(hj-h]h Parameters}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj-ubj#)}(hhh](j()}(h1``struct Scsi_Host *shost`` pointer to host data h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj.h]hstruct Scsi_Host *shost}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj.ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj .ubjJ)}(hhh]h)}(hpointer to host datah]hpointer to host data}(hj*.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&.hMhj'.ubah}(h]h ]h"]h$]h&]uh1jIhj .ubeh}(h]h ]h"]h$]h&]uh1j'hj&.hMhj.ubj()}(h]``struct iscsi_bus_flash_session *fnode_sess`` pointer to the parent flashnode session entry h](j.)}(h.``struct iscsi_bus_flash_session *fnode_sess``h]j4)}(hjJ.h]h*struct iscsi_bus_flash_session *fnode_sess}(hjL.hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjH.ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhjD.ubjJ)}(hhh]h)}(h-pointer to the parent flashnode session entryh]h-pointer to the parent flashnode session entry}(hjc.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_.hMhj`.ubah}(h]h ]h"]h$]h&]uh1jIhjD.ubeh}(h]h ]h"]h$]h&]uh1j'hj_.hMhj.ubj()}(h@``struct iscsi_transport *transport`` pointer to transport data h](j.)}(h%``struct iscsi_transport *transport``h]j4)}(hj.h]h!struct iscsi_transport *transport}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj.ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj}.ubjJ)}(hhh]h)}(hpointer to transport datah]hpointer to transport data}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hMhj.ubah}(h]h ]h"]h$]h&]uh1jIhj}.ubeh}(h]h ]h"]h$]h&]uh1j'hj.hMhj.ubj()}(h'``int dd_size`` total size to allocate h](j.)}(h``int dd_size``h]j4)}(hj.h]h int dd_size}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj.ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj.ubjJ)}(hhh]h)}(htotal size to allocateh]htotal size to allocate}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hMhj.ubah}(h]h ]h"]h$]h&]uh1jIhj.ubeh}(h]h ]h"]h$]h&]uh1j'hj.hMhj.ubeh}(h]h ]h"]h$]h&]uh1j"hj-ubh)}(h**Description**h]j)}(hj.h]h Description}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj-ubh)}(h:Adds a sysfs entry for the flashnode connection attributesh]h:Adds a sysfs entry for the flashnode connection attributes}(hj /hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj-ubh)}(h **Return**h]j)}(hj/h]hReturn}(hj /hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj-ubj`)}(hBpointer to allocated flashnode conn on success ``NULL`` on failureh]h)}(hBpointer to allocated flashnode conn on success ``NULL`` on failureh](h/pointer to allocated flashnode conn on success }(hj8/hhhNhNubj4)}(h``NULL``h]hNULL}(hj@/hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj8/ubh on failure}(hj8/hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj4/ubah}(h]h ]h"]h$]h&]uh1j_hjX/hMhj-ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjp&hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@&iscsi_find_flashnode_sess (C function)c.iscsi_find_flashnode_sesshNtauh1j3hjp&hhhNhNubjE)}(hhh](jJ)}(hhstruct device * iscsi_find_flashnode_sess (struct Scsi_Host *shost, const void *data, device_match_t fn)h]jP)}(hfstruct device *iscsi_find_flashnode_sess(struct Scsi_Host *shost, const void *data, device_match_t fn)h](jV)}(hjYh]hstruct}(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{/hhhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMcubjh)}(h h]h }(hj/hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{/hhhj/hMcubh)}(hhh]j)}(hdeviceh]hdevice}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj/ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj/modnameN classnameNjj)}j]j)}jiscsi_find_flashnode_sesssbc.iscsi_find_flashnode_sessasbuh1hhj{/hhhj/hMcubjh)}(h h]h }(hj/hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{/hhhj/hMcubj )}(hj h]h*}(hj/hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj{/hhhj/hMcubjy)}(hiscsi_find_flashnode_sessh]j)}(hj/h]hiscsi_find_flashnode_sess}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj/ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj{/hhhj/hMcubj)}(h>(struct Scsi_Host *shost, const void *data, device_match_t fn)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/ubjh)}(h h]h }(hj0hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj/ubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj0ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj0modnameN classnameNjj)}j]j/c.iscsi_find_flashnode_sessasbuh1hhj/ubjh)}(h h]h }(hj50hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj/ubj )}(hj h]h*}(hjC0hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj/ubj)}(hshosth]hshost}(hjP0hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj/ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj/ubj)}(hconst void *datah](jV)}(hjNh]hconst}(hji0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhje0ubjh)}(h h]h }(hjv0hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghje0ubj~)}(hvoidh]hvoid}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hje0ubjh)}(h h]h }(hj0hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghje0ubj )}(hj h]h*}(hj0hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hje0ubj)}(hdatah]hdata}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hje0ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj/ubj)}(hdevice_match_t fnh](h)}(hhh]j)}(hdevice_match_th]hdevice_match_t}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj0ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj0modnameN classnameNjj)}j]j/c.iscsi_find_flashnode_sessasbuh1hhj0ubjh)}(h h]h }(hj0hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj0ubj)}(hfnh]hfn}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj0ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj/ubeh}(h]h ]h"]h$]h&]jjuh1jhj{/hhhj/hMcubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjw/hhhj/hMcubah}(h]jr/ah ](jjeh"]h$]h&]jj)jhuh1jIhj/hMchjt/hhubj)}(hhh]h)}(hfinds flashnode session entryh]hfinds flashnode session entry}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMchj1hhubah}(h]h ]h"]h$]h&]uh1jhjt/hhhj/hMcubeh}(h]h ](jfunctioneh"]h$]h&]jjjj71jj71jjjuh1jDhhhjp&hNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` pointer to host data ``const void *data`` pointer to data containing value to use for comparison ``device_match_t fn`` function pointer that does actual comparison **Description** Finds the flashnode session object comparing the data passed using logic defined in passed function pointer **Return** pointer to found flashnode session device object on success ``NULL`` on failureh](h)}(h**Parameters**h]j)}(hjA1h]h Parameters}(hjC1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?1ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMghj;1ubj#)}(hhh](j()}(h1``struct Scsi_Host *shost`` pointer to host data h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hj`1h]hstruct Scsi_Host *shost}(hjb1hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj^1ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMdhjZ1ubjJ)}(hhh]h)}(hpointer to host datah]hpointer to host data}(hjy1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhju1hMdhjv1ubah}(h]h ]h"]h$]h&]uh1jIhjZ1ubeh}(h]h ]h"]h$]h&]uh1j'hju1hMdhjW1ubj()}(hL``const void *data`` pointer to data containing value to use for comparison h](j.)}(h``const void *data``h]j4)}(hj1h]hconst void *data}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj1ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMehj1ubjJ)}(hhh]h)}(h6pointer to data containing value to use for comparisonh]h6pointer to data containing value to use for comparison}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hMehj1ubah}(h]h ]h"]h$]h&]uh1jIhj1ubeh}(h]h ]h"]h$]h&]uh1j'hj1hMehjW1ubj()}(hC``device_match_t fn`` function pointer that does actual comparison h](j.)}(h``device_match_t fn``h]j4)}(hj1h]hdevice_match_t fn}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj1ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMfhj1ubjJ)}(hhh]h)}(h,function pointer that does actual comparisonh]h,function pointer that does actual comparison}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hMfhj1ubah}(h]h ]h"]h$]h&]uh1jIhj1ubeh}(h]h ]h"]h$]h&]uh1j'hj1hMfhjW1ubeh}(h]h ]h"]h$]h&]uh1j"hj;1ubh)}(h**Description**h]j)}(hj 2h]h Description}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj 2ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhhj;1ubh)}(hkFinds the flashnode session object comparing the data passed using logic defined in passed function pointerh]hkFinds the flashnode session object comparing the data passed using logic defined in passed function pointer}(hj#2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhhj;1ubh)}(h **Return**h]j)}(hj42h]hReturn}(hj62hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj22ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMkhj;1ubj`)}(hOpointer to found flashnode session device object on success ``NULL`` on failureh]h)}(hOpointer to found flashnode session device object on success ``NULL`` on failureh](hvoid iscsi_unblock_session (struct iscsi_cls_session *session)h]jP)}(h=void iscsi_unblock_session(struct iscsi_cls_session *session)h](j~)}(hvoidh]hvoid}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj9hhhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMubjh)}(h h]h }(hj&9hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj9hhhj%9hMubjy)}(hiscsi_unblock_sessionh]j)}(hiscsi_unblock_sessionh]hiscsi_unblock_session}(hj89hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj49ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj9hhhj%9hMubj)}(h#(struct iscsi_cls_session *session)h]j)}(h!struct iscsi_cls_session *sessionh](jV)}(hjYh]hstruct}(hjT9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjP9ubjh)}(h h]h }(hja9hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjP9ubh)}(hhh]j)}(hiscsi_cls_sessionh]hiscsi_cls_session}(hjr9hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjo9ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjt9modnameN classnameNjj)}j]j)}jj:9sbc.iscsi_unblock_sessionasbuh1hhjP9ubjh)}(h h]h }(hj9hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjP9ubj )}(hj h]h*}(hj9hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjP9ubj)}(hsessionh]hsession}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjP9ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjL9ubah}(h]h ]h"]h$]h&]jjuh1jhj9hhhj%9hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj9hhhj%9hMubah}(h]j 9ah ](jjeh"]h$]h&]jj)jhuh1jIhj%9hMhj 9hhubj)}(hhh]h)}(h(set a session as logged in and start IO.h]h(set a session as logged in and start IO.}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj9hhubah}(h]h ]h"]h$]h&]uh1jhj 9hhhj%9hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj9jj9jjjuh1jDhhhjp&hNhNubj)}(h}**Parameters** ``struct iscsi_cls_session *session`` iscsi session **Description** Mark a session as ready to accept IO.h](h)}(h**Parameters**h]j)}(hj9h]h Parameters}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj9ubj#)}(hhh]j()}(h4``struct iscsi_cls_session *session`` iscsi session h](j.)}(h%``struct iscsi_cls_session *session``h]j4)}(hj:h]h!struct iscsi_cls_session *session}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj:ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj:ubjJ)}(hhh]h)}(h iscsi sessionh]h iscsi session}(hj1:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-:hMhj.:ubah}(h]h ]h"]h$]h&]uh1jIhj:ubeh}(h]h ]h"]h$]h&]uh1j'hj-:hMhj:ubah}(h]h ]h"]h$]h&]uh1j"hj9ubh)}(h**Description**h]j)}(hjS:h]h Description}(hjU:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQ:ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj9ubh)}(h%Mark a session as ready to accept IO.h]h%Mark a session as ready to accept IO.}(hji:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMhj9ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjp&hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@(iscsi_force_destroy_session (C function)c.iscsi_force_destroy_sessionhNtauh1j3hjp&hhhNhNubjE)}(hhh](jJ)}(hDvoid iscsi_force_destroy_session (struct iscsi_cls_session *session)h]jP)}(hCvoid iscsi_force_destroy_session(struct iscsi_cls_session *session)h](j~)}(hvoidh]hvoid}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj:hhhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM9 ubjh)}(h h]h }(hj:hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj:hhhj:hM9 ubjy)}(hiscsi_force_destroy_sessionh]j)}(hiscsi_force_destroy_sessionh]hiscsi_force_destroy_session}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj:ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj:hhhj:hM9 ubj)}(h#(struct iscsi_cls_session *session)h]j)}(h!struct iscsi_cls_session *sessionh](jV)}(hjYh]hstruct}(hj:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:ubjh)}(h h]h }(hj:hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj:ubh)}(hhh]j)}(hiscsi_cls_sessionh]hiscsi_cls_session}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj:ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj:modnameN classnameNjj)}j]j)}jj:sbc.iscsi_force_destroy_sessionasbuh1hhj:ubjh)}(h h]h }(hj;hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj:ubj )}(hj h]h*}(hj!;hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj:ubj)}(hsessionh]hsession}(hj.;hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj:ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubah}(h]h ]h"]h$]h&]jjuh1jhj:hhhj:hM9 ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj:hhhj:hM9 ubah}(h]j:ah ](jjeh"]h$]h&]jj)jhuh1jIhj:hM9 hj:hhubj)}(hhh]h)}(h!destroy a session from the kernelh]h!destroy a session from the kernel}(hjX;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM9 hjU;hhubah}(h]h ]h"]h$]h&]uh1jhj:hhhj:hM9 ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjp;jjp;jjjuh1jDhhhjp&hNhNubj)}(h**Parameters** ``struct iscsi_cls_session *session`` session to destroy **Description** Force the destruction of a session from the kernel. This should only be used when userspace is no longer running during system shutdown.h](h)}(h**Parameters**h]j)}(hjz;h]h Parameters}(hj|;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjx;ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM= hjt;ubj#)}(hhh]j()}(h9``struct iscsi_cls_session *session`` session to destroy h](j.)}(h%``struct iscsi_cls_session *session``h]j4)}(hj;h]h!struct iscsi_cls_session *session}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj;ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM: hj;ubjJ)}(hhh]h)}(hsession to destroyh]hsession to destroy}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;hM: hj;ubah}(h]h ]h"]h$]h&]uh1jIhj;ubeh}(h]h ]h"]h$]h&]uh1j'hj;hM: hj;ubah}(h]h ]h"]h$]h&]uh1j"hjt;ubh)}(h**Description**h]j)}(hj;h]h Description}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM< hjt;ubh)}(hForce the destruction of a session from the kernel. This should only be used when userspace is no longer running during system shutdown.h]hForce the destruction of a session from the kernel. This should only be used when userspace is no longer running during system shutdown.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM< hjt;ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjp&hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@iscsi_alloc_conn (C function)c.iscsi_alloc_connhNtauh1j3hjp&hhhNhNubjE)}(hhh](jJ)}(hgstruct iscsi_cls_conn * iscsi_alloc_conn (struct iscsi_cls_session *session, int dd_size, uint32_t cid)h]jP)}(hestruct iscsi_cls_conn *iscsi_alloc_conn(struct iscsi_cls_session *session, int dd_size, uint32_t cid)h](jV)}(hjYh]hstruct}(hj<hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj<hhhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM` ubjh)}(h h]h }(hj'<hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj<hhhj&<hM` ubh)}(hhh]j)}(hiscsi_cls_connh]hiscsi_cls_conn}(hj8<hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj5<ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj:<modnameN classnameNjj)}j]j)}jiscsi_alloc_connsbc.iscsi_alloc_connasbuh1hhj<hhhj&<hM` ubjh)}(h h]h }(hjY<hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj<hhhj&<hM` ubj )}(hj h]h*}(hjg<hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj<hhhj&<hM` ubjy)}(hiscsi_alloc_connh]j)}(hjV<h]hiscsi_alloc_conn}(hjx<hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjt<ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj<hhhj&<hM` ubj)}(h>(struct iscsi_cls_session *session, int dd_size, uint32_t cid)h](j)}(h!struct iscsi_cls_session *sessionh](jV)}(hjYh]hstruct}(hj<hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj<ubjh)}(h h]h }(hj<hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj<ubh)}(hhh]j)}(hiscsi_cls_sessionh]hiscsi_cls_session}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj<ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj<modnameN classnameNjj)}j]jT<c.iscsi_alloc_connasbuh1hhj<ubjh)}(h h]h }(hj<hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj<ubj )}(hj h]h*}(hj<hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj<ubj)}(hsessionh]hsession}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj<ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj<ubj)}(h int dd_sizeh](j~)}(hinth]hint}(hj=hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj<ubjh)}(h h]h }(hj=hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj<ubj)}(hdd_sizeh]hdd_size}(hj=hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj<ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj<ubj)}(h uint32_t cidh](h)}(hhh]j)}(huint32_th]huint32_t}(hj;=hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj8=ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj==modnameN classnameNjj)}j]jT<c.iscsi_alloc_connasbuh1hhj4=ubjh)}(h h]h }(hjY=hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj4=ubj)}(hcidh]hcid}(hjg=hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj4=ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj<ubeh}(h]h ]h"]h$]h&]jjuh1jhj<hhhj&<hM` ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj<hhhj&<hM` ubah}(h]j <ah ](jjeh"]h$]h&]jj)jhuh1jIhj&<hM` hj<hhubj)}(hhh]h)}(halloc iscsi class connectionh]halloc iscsi class connection}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM` hj=hhubah}(h]h ]h"]h$]h&]uh1jhj<hhhj&<hM` ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj=jj=jjjuh1jDhhhjp&hNhNubj)}(h**Parameters** ``struct iscsi_cls_session *session`` iscsi cls session ``int dd_size`` private driver data size ``uint32_t cid`` connection idh](h)}(h**Parameters**h]j)}(hj=h]h Parameters}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMd hj=ubj#)}(hhh](j()}(h8``struct iscsi_cls_session *session`` iscsi cls session h](j.)}(h%``struct iscsi_cls_session *session``h]j4)}(hj=h]h!struct iscsi_cls_session *session}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj=ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMa hj=ubjJ)}(hhh]h)}(hiscsi cls sessionh]hiscsi cls session}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hMa hj=ubah}(h]h ]h"]h$]h&]uh1jIhj=ubeh}(h]h ]h"]h$]h&]uh1j'hj=hMa hj=ubj()}(h)``int dd_size`` private driver data size h](j.)}(h``int dd_size``h]j4)}(hj >h]h int dd_size}(hj >hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj >ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMb hj>ubjJ)}(hhh]h)}(hprivate driver data sizeh]hprivate driver data size}(hj$>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj >hMb hj!>ubah}(h]h ]h"]h$]h&]uh1jIhj>ubeh}(h]h ]h"]h$]h&]uh1j'hj >hMb hj=ubj()}(h``uint32_t cid`` connection idh](j.)}(h``uint32_t cid``h]j4)}(hjD>h]h uint32_t cid}(hjF>hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjB>ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMd hj>>ubjJ)}(hhh]h)}(h connection idh]h connection id}(hj]>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chMc hjZ>ubah}(h]h ]h"]h$]h&]uh1jIhj>>ubeh}(h]h ]h"]h$]h&]uh1j'hjY>hMd hj=ubeh}(h]h ]h"]h$]h&]uh1j"hj=ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjp&hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@iscsi_add_conn (C function)c.iscsi_add_connhNtauh1j3hjp&hhhNhNubjE)}(hhh](jJ)}(h0int iscsi_add_conn (struct iscsi_cls_conn *conn)h]jP)}(h/int iscsi_add_conn(struct iscsi_cls_conn *conn)h](j~)}(hinth]hint}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj>hhhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM ubjh)}(h h]h }(hj>hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>hhhj>hM ubjy)}(hiscsi_add_connh]j)}(hiscsi_add_connh]hiscsi_add_conn}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj>ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj>hhhj>hM ubj)}(h(struct iscsi_cls_conn *conn)h]j)}(hstruct iscsi_cls_conn *connh](jV)}(hjYh]hstruct}(hj>hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>ubjh)}(h h]h }(hj>hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>ubh)}(hhh]j)}(hiscsi_cls_connh]hiscsi_cls_conn}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj>ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj>modnameN classnameNjj)}j]j)}jj>sbc.iscsi_add_connasbuh1hhj>ubjh)}(h h]h }(hj?hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>ubj )}(hj h]h*}(hj'?hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj>ubj)}(hconnh]hconn}(hj4?hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj>ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj>ubah}(h]h ]h"]h$]h&]jjuh1jhj>hhhj>hM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj>hhhj>hM ubah}(h]j>ah ](jjeh"]h$]h&]jj)jhuh1jIhj>hM hj>hhubj)}(hhh]h)}(hadd iscsi class connectionh]hadd iscsi class connection}(hj^?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM hj[?hhubah}(h]h ]h"]h$]h&]uh1jhj>hhhj>hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjv?jjv?jjjuh1jDhhhjp&hNhNubj)}(h**Parameters** ``struct iscsi_cls_conn *conn`` iscsi cls connection **Description** This will expose iscsi_cls_conn to sysfs so make sure the related resources for sysfs attributes are initialized before calling this.h](h)}(h**Parameters**h]j)}(hj?h]h Parameters}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~?ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM hjz?ubj#)}(hhh]j()}(h5``struct iscsi_cls_conn *conn`` iscsi cls connection h](j.)}(h``struct iscsi_cls_conn *conn``h]j4)}(hj?h]hstruct iscsi_cls_conn *conn}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj?ubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM hj?ubjJ)}(hhh]h)}(hiscsi cls connectionh]hiscsi cls connection}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hM hj?ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j'hj?hM hj?ubah}(h]h ]h"]h$]h&]uh1j"hjz?ubh)}(h**Description**h]j)}(hj?h]h Description}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM hjz?ubh)}(hThis will expose iscsi_cls_conn to sysfs so make sure the related resources for sysfs attributes are initialized before calling this.h]hThis will expose iscsi_cls_conn to sysfs so make sure the related resources for sysfs attributes are initialized before calling this.}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM hjz?ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjp&hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@iscsi_remove_conn (C function)c.iscsi_remove_connhNtauh1j3hjp&hhhNhNubjE)}(hhh](jJ)}(h4void iscsi_remove_conn (struct iscsi_cls_conn *conn)h]jP)}(h3void iscsi_remove_conn(struct iscsi_cls_conn *conn)h](j~)}(hvoidh]hvoid}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj@hhhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM ubjh)}(h h]h }(hj.@hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj@hhhj-@hM ubjy)}(hiscsi_remove_connh]j)}(hiscsi_remove_connh]hiscsi_remove_conn}(hj@@hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj<@ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj@hhhj-@hM ubj)}(h(struct iscsi_cls_conn *conn)h]j)}(hstruct iscsi_cls_conn *connh](jV)}(hjYh]hstruct}(hj\@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjX@ubjh)}(h h]h }(hji@hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjX@ubh)}(hhh]j)}(hiscsi_cls_connh]hiscsi_cls_conn}(hjz@hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjw@ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj|@modnameN classnameNjj)}j]j)}jjB@sbc.iscsi_remove_connasbuh1hhjX@ubjh)}(h h]h }(hj@hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjX@ubj )}(hj h]h*}(hj@hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjX@ubj)}(hconnh]hconn}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjX@ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjT@ubah}(h]h ]h"]h$]h&]jjuh1jhj@hhhj-@hM ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj@hhhj-@hM ubah}(h]j@ah ](jjeh"]h$]h&]jj)jhuh1jIhj-@hM hj@hhubj)}(hhh]h)}(h(remove iscsi class connection from sysfsh]h(remove iscsi class connection from sysfs}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM hj@hhubah}(h]h ]h"]h$]h&]uh1jhj@hhhj-@hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj@jj@jjjuh1jDhhhjp&hNhNubj)}(h**Parameters** ``struct iscsi_cls_conn *conn`` iscsi cls connection **Description** Remove iscsi_cls_conn from sysfs, and wait for previous read/write of iscsi_cls_conn's attributes in sysfs to finish.h](h)}(h**Parameters**h]j)}(hjAh]h Parameters}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM hj@ubj#)}(hhh]j()}(h5``struct iscsi_cls_conn *conn`` iscsi cls connection h](j.)}(h``struct iscsi_cls_conn *conn``h]j4)}(hj Ah]hstruct iscsi_cls_conn *conn}(hj"AhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjAubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM hjAubjJ)}(hhh]h)}(hiscsi cls connectionh]hiscsi cls connection}(hj9AhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5AhM hj6Aubah}(h]h ]h"]h$]h&]uh1jIhjAubeh}(h]h ]h"]h$]h&]uh1j'hj5AhM hjAubah}(h]h ]h"]h$]h&]uh1j"hj@ubh)}(h**Description**h]j)}(hj[Ah]h Description}(hj]AhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYAubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM hj@ubh)}(huRemove iscsi_cls_conn from sysfs, and wait for previous read/write of iscsi_cls_conn's attributes in sysfs to finish.h]hwRemove iscsi_cls_conn from sysfs, and wait for previous read/write of iscsi_cls_conn’s attributes in sysfs to finish.}(hjqAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM hj@ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjp&hhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@ iscsi_session_event (C function)c.iscsi_session_eventhNtauh1j3hjp&hhhNhNubjE)}(hhh](jJ)}(hVint iscsi_session_event (struct iscsi_cls_session *session, enum iscsi_uevent_e event)h]jP)}(hUint iscsi_session_event(struct iscsi_cls_session *session, enum iscsi_uevent_e event)h](j~)}(hinth]hint}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjAhhhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM$ ubjh)}(h h]h }(hjAhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjAhhhjAhM$ ubjy)}(hiscsi_session_eventh]j)}(hiscsi_session_eventh]hiscsi_session_event}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjAubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjAhhhjAhM$ ubj)}(h>(struct iscsi_cls_session *session, enum iscsi_uevent_e event)h](j)}(h!struct iscsi_cls_session *sessionh](jV)}(hjYh]hstruct}(hjAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAubjh)}(h h]h }(hjAhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjAubh)}(hhh]j)}(hiscsi_cls_sessionh]hiscsi_cls_session}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjAubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjAmodnameN classnameNjj)}j]j)}jjAsbc.iscsi_session_eventasbuh1hhjAubjh)}(h h]h }(hjBhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjAubj )}(hj h]h*}(hj)BhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjAubj)}(hsessionh]hsession}(hj6BhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjAubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjAubj)}(henum iscsi_uevent_e eventh](jV)}(hj7h]henum}(hjOBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjKBubjh)}(h h]h }(hj\BhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjKBubh)}(hhh]j)}(hiscsi_uevent_eh]hiscsi_uevent_e}(hjmBhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjjBubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjoBmodnameN classnameNjj)}j]jBc.iscsi_session_eventasbuh1hhjKBubjh)}(h h]h }(hjBhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjKBubj)}(heventh]hevent}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjKBubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjAubeh}(h]h ]h"]h$]h&]jjuh1jhjAhhhjAhM$ ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjAhhhjAhM$ ubah}(h]jAah ](jjeh"]h$]h&]jj)jhuh1jIhjAhM$ hjAhhubj)}(hhh]h)}(h$send session destr. completion eventh]h$send session destr. completion event}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM$ hjBhhubah}(h]h ]h"]h$]h&]uh1jhjAhhhjAhM$ ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjBjjBjjjuh1jDhhhjp&hNhNubj)}(hz**Parameters** ``struct iscsi_cls_session *session`` iscsi class session ``enum iscsi_uevent_e event`` type of eventh](h)}(h**Parameters**h]j)}(hjBh]h Parameters}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM( hjBubj#)}(hhh](j()}(h:``struct iscsi_cls_session *session`` iscsi class session h](j.)}(h%``struct iscsi_cls_session *session``h]j4)}(hjCh]h!struct iscsi_cls_session *session}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjCubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM% hjBubjJ)}(hhh]h)}(hiscsi class sessionh]hiscsi class session}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChM% hjCubah}(h]h ]h"]h$]h&]uh1jIhjBubeh}(h]h ]h"]h$]h&]uh1j'hjChM% hjBubj()}(h+``enum iscsi_uevent_e event`` type of eventh](j.)}(h``enum iscsi_uevent_e event``h]j4)}(hj=Ch]henum iscsi_uevent_e event}(hj?ChhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj;Cubah}(h]h ]h"]h$]h&]uh1j-hd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM' hj7CubjJ)}(hhh]h)}(h type of eventh]h type of event}(hjVChhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:249: ./drivers/scsi/scsi_transport_iscsi.chM& hjSCubah}(h]h ]h"]h$]h&]uh1jIhj7Cubeh}(h]h ]h"]h$]h&]uh1j'hjRChM' hjBubeh}(h]h ]h"]h$]h&]uh1j"hjBubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjp&hhhNhNubeh}(h]iscsi-transport-classah ]h"]iscsi transport classah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(h*Serial Attached SCSI (SAS) transport classh]h*Serial Attached SCSI (SAS) transport class}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChhhhhKubh)}(hThe file drivers/scsi/scsi_transport_sas.c defines transport attributes for Serial Attached SCSI, a variant of SATA aimed at large high-end systems.h]hThe file drivers/scsi/scsi_transport_sas.c defines transport attributes for Serial Attached SCSI, a variant of SATA aimed at large high-end systems.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjChhubh)}(hThe SAS transport class contains common code to deal with SAS HBAs, an approximated representation of SAS topologies in the driver model, and various sysfs attributes to expose these topologies and management interfaces to userspace.h]hThe SAS transport class contains common code to deal with SAS HBAs, an approximated representation of SAS topologies in the driver model, and various sysfs attributes to expose these topologies and management interfaces to userspace.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjChhubh)}(hXIn addition to the basic SCSI core objects this transport class introduces two additional intermediate objects: The SAS PHY as represented by struct sas_phy defines an "outgoing" PHY on a SAS HBA or Expander, and the SAS remote PHY represented by struct sas_rphy defines an "incoming" PHY on a SAS Expander or end device. Note that this is purely a software concept, the underlying hardware for a PHY and a remote PHY is the exactly the same.h]hXIn addition to the basic SCSI core objects this transport class introduces two additional intermediate objects: The SAS PHY as represented by struct sas_phy defines an “outgoing” PHY on a SAS HBA or Expander, and the SAS remote PHY represented by struct sas_rphy defines an “incoming” PHY on a SAS Expander or end device. Note that this is purely a software concept, the underlying hardware for a PHY and a remote PHY is the exactly the same.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjChhubh)}(hThere is no concept of a SAS port in this code, users can see what PHYs form a wide port based on the port_identifier attribute, which is the same for all PHYs in a port.h]hThere is no concept of a SAS port in this code, users can see what PHYs form a wide port based on the port_identifier attribute, which is the same for all PHYs in a port.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjChhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@ sas_remove_children (C function)c.sas_remove_childrenhNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h-void sas_remove_children (struct device *dev)h]jP)}(h,void sas_remove_children(struct device *dev)h](j~)}(hvoidh]hvoid}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjChhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM%ubjh)}(h h]h }(hjChhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjChhhjChM%ubjy)}(hsas_remove_childrenh]j)}(hsas_remove_childrenh]hsas_remove_children}(hj DhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjDubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjChhhjChM%ubj)}(h(struct device *dev)h]j)}(hstruct device *devh](jV)}(hjYh]hstruct}(hj%DhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj!Dubjh)}(h h]h }(hj2DhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj!Dubh)}(hhh]j)}(hdeviceh]hdevice}(hjCDhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj@Dubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjEDmodnameN classnameNjj)}j]j)}jj Dsbc.sas_remove_childrenasbuh1hhj!Dubjh)}(h h]h }(hjcDhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj!Dubj )}(hj h]h*}(hjqDhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj!Dubj)}(hdevh]hdev}(hj~DhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj!Dubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjDubah}(h]h ]h"]h$]h&]jjuh1jhjChhhjChM%ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjChhhjChM%ubah}(h]jCah ](jjeh"]h$]h&]jj)jhuh1jIhjChM%hjChhubj)}(hhh]h)}(h'tear down a devices SAS data structuresh]h'tear down a devices SAS data structures}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM%hjDhhubah}(h]h ]h"]h$]h&]uh1jhjChhhjChM%ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjDjjDjjjuh1jDhhhjChNhNubj)}(h**Parameters** ``struct device *dev`` device belonging to the sas object **Description** Removes all SAS PHYs and remote PHYs for a given objecth](h)}(h**Parameters**h]j)}(hjDh]h Parameters}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM)hjDubj#)}(hhh]j()}(h:``struct device *dev`` device belonging to the sas object h](j.)}(h``struct device *dev``h]j4)}(hjDh]hstruct device *dev}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjDubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM&hjDubjJ)}(hhh]h)}(h"device belonging to the sas objecth]h"device belonging to the sas object}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDhM&hjDubah}(h]h ]h"]h$]h&]uh1jIhjDubeh}(h]h ]h"]h$]h&]uh1j'hjDhM&hjDubah}(h]h ]h"]h$]h&]uh1j"hjDubh)}(h**Description**h]j)}(hj$Eh]h Description}(hj&EhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"Eubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM(hjDubh)}(h7Removes all SAS PHYs and remote PHYs for a given objecth]h7Removes all SAS PHYs and remote PHYs for a given object}(hj:EhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM(hjDubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_remove_host (C function)c.sas_remove_hosthNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h.void sas_remove_host (struct Scsi_Host *shost)h]jP)}(h-void sas_remove_host(struct Scsi_Host *shost)h](j~)}(hvoidh]hvoid}(hjiEhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjeEhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM2ubjh)}(h h]h }(hjxEhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjeEhhhjwEhM2ubjy)}(hsas_remove_hosth]j)}(hsas_remove_hosth]hsas_remove_host}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjeEhhhjwEhM2ubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjEubjh)}(h h]h }(hjEhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjEubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjEmodnameN classnameNjj)}j]j)}jjEsbc.sas_remove_hostasbuh1hhjEubjh)}(h h]h }(hjEhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjEubj )}(hj h]h*}(hjEhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjEubj)}(hshosth]hshost}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjEubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjEubah}(h]h ]h"]h$]h&]jjuh1jhjeEhhhjwEhM2ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjaEhhhjwEhM2ubah}(h]j\Eah ](jjeh"]h$]h&]jj)jhuh1jIhjwEhM2hj^Ehhubj)}(hhh]h)}(h+tear down a Scsi_Host's SAS data structuresh]h-tear down a Scsi_Host’s SAS data structures}(hj)FhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM2hj&Fhhubah}(h]h ]h"]h$]h&]uh1jhj^EhhhjwEhM2ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjAFjjAFjjjuh1jDhhhjChNhNubj)}(hX**Parameters** ``struct Scsi_Host *shost`` Scsi Host that is torn down **Description** Removes all SAS PHYs and remote PHYs for a given Scsi_Host and remove the Scsi_Host as well. **Note** Do not call scsi_remove_host() on the Scsi_Host any more, as it is already removed.h](h)}(h**Parameters**h]j)}(hjKFh]h Parameters}(hjMFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIFubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM6hjEFubj#)}(hhh]j()}(h8``struct Scsi_Host *shost`` Scsi Host that is torn down h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjjFh]hstruct Scsi_Host *shost}(hjlFhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjhFubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM3hjdFubjJ)}(hhh]h)}(hScsi Host that is torn downh]hScsi Host that is torn down}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhM3hjFubah}(h]h ]h"]h$]h&]uh1jIhjdFubeh}(h]h ]h"]h$]h&]uh1j'hjFhM3hjaFubah}(h]h ]h"]h$]h&]uh1j"hjEFubh)}(h**Description**h]j)}(hjFh]h Description}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM5hjEFubh)}(h\Removes all SAS PHYs and remote PHYs for a given Scsi_Host and remove the Scsi_Host as well.h]h\Removes all SAS PHYs and remote PHYs for a given Scsi_Host and remove the Scsi_Host as well.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM5hjEFubh)}(h**Note**h]j)}(hjFh]hNote}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM8hjEFubh)}(hSDo not call scsi_remove_host() on the Scsi_Host any more, as it is already removed.h]hSDo not call scsi_remove_host() on the Scsi_Host any more, as it is already removed.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM8hjEFubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_get_address (C function)c.sas_get_addresshNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h.u64 sas_get_address (struct scsi_device *sdev)h]jP)}(h-u64 sas_get_address(struct scsi_device *sdev)h](h)}(hhh]j)}(hu64h]hu64}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjGubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjGmodnameN classnameNjj)}j]j)}jsas_get_addresssbc.sas_get_addressasbuh1hhj Ghhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMCubjh)}(h h]h }(hj6GhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj Ghhhj5GhMCubjy)}(hsas_get_addressh]j)}(hj2Gh]hsas_get_address}(hjHGhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjDGubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj Ghhhj5GhMCubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjcGhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_Gubjh)}(h h]h }(hjpGhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj_Gubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj~Gubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjGmodnameN classnameNjj)}j]j0Gc.sas_get_addressasbuh1hhj_Gubjh)}(h h]h }(hjGhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj_Gubj )}(hj h]h*}(hjGhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj_Gubj)}(hsdevh]hsdev}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj_Gubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj[Gubah}(h]h ]h"]h$]h&]jjuh1jhj Ghhhj5GhMCubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj Ghhhj5GhMCubah}(h]jGah ](jjeh"]h$]h&]jj)jhuh1jIhj5GhMChjGhhubj)}(hhh]h)}(h$return the SAS address of the deviceh]h$return the SAS address of the device}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMChjGhhubah}(h]h ]h"]h$]h&]uh1jhjGhhhj5GhMCubeh}(h]h ](jfunctioneh"]h$]h&]jjjjGjjGjjjuh1jDhhhjChNhNubj)}(hw**Parameters** ``struct scsi_device *sdev`` scsi device **Description** Returns the SAS address of the scsi deviceh](h)}(h**Parameters**h]j)}(hjHh]h Parameters}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMGhjHubj#)}(hhh]j()}(h)``struct scsi_device *sdev`` scsi device h](j.)}(h``struct scsi_device *sdev``h]j4)}(hj%Hh]hstruct scsi_device *sdev}(hj'HhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj#Hubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMDhjHubjJ)}(hhh]h)}(h scsi deviceh]h scsi device}(hj>HhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:HhMDhj;Hubah}(h]h ]h"]h$]h&]uh1jIhjHubeh}(h]h ]h"]h$]h&]uh1j'hj:HhMDhjHubah}(h]h ]h"]h$]h&]uh1j"hjHubh)}(h**Description**h]j)}(hj`Hh]h Description}(hjbHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^Hubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMFhjHubh)}(h*Returns the SAS address of the scsi deviceh]h*Returns the SAS address of the scsi device}(hjvHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMFhjHubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_tlr_supported (C function)c.sas_tlr_supportedhNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h9unsigned int sas_tlr_supported (struct scsi_device *sdev)h]jP)}(h8unsigned int sas_tlr_supported(struct scsi_device *sdev)h](j~)}(hunsignedh]hunsigned}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjHhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMQubjh)}(h h]h }(hjHhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjHhhhjHhMQubj~)}(hinth]hint}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjHhhhjHhMQubjh)}(h h]h }(hjHhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjHhhhjHhMQubjy)}(hsas_tlr_supportedh]j)}(hsas_tlr_supportedh]hsas_tlr_supported}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjHubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjHhhhjHhMQubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjHhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHubjh)}(h h]h }(hj IhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjHubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjIubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjImodnameN classnameNjj)}j]j)}jjHsbc.sas_tlr_supportedasbuh1hhjHubjh)}(h h]h }(hjJhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMwubjh)}(h h]h }(hjQJhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>JhhhjPJhMwubjy)}(hsas_disable_tlrh]j)}(hsas_disable_tlrh]hsas_disable_tlr}(hjcJhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj_Jubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj>JhhhjPJhMwubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{Jubjh)}(h h]h }(hjJhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{Jubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjJubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjJmodnameN classnameNjj)}j]j)}jjeJsbc.sas_disable_tlrasbuh1hhj{Jubjh)}(h h]h }(hjJhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{Jubj )}(hj h]h*}(hjJhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj{Jubj)}(hsdevh]hsdev}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj{Jubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjwJubah}(h]h ]h"]h$]h&]jjuh1jhj>JhhhjPJhMwubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj:JhhhjPJhMwubah}(h]j5Jah ](jjeh"]h$]h&]jj)jhuh1jIhjPJhMwhj7Jhhubj)}(hhh]h)}(hsetting TLR flagsh]hsetting TLR flags}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMwhjJhhubah}(h]h ]h"]h$]h&]uh1jhj7JhhhjPJhMwubeh}(h]h ](jfunctioneh"]h$]h&]jjjjKjjKjjjuh1jDhhhjChNhNubj)}(hq**Parameters** ``struct scsi_device *sdev`` scsi device struct **Description** Seting tlr_enabled flag to 0.h](h)}(h**Parameters**h]j)}(hj$Kh]h Parameters}(hj&KhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"Kubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM{hjKubj#)}(hhh]j()}(h0``struct scsi_device *sdev`` scsi device struct h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjCKh]hstruct scsi_device *sdev}(hjEKhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjAKubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMxhj=KubjJ)}(hhh]h)}(hscsi device structh]hscsi device struct}(hj\KhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXKhMxhjYKubah}(h]h ]h"]h$]h&]uh1jIhj=Kubeh}(h]h ]h"]h$]h&]uh1j'hjXKhMxhj:Kubah}(h]h ]h"]h$]h&]uh1j"hjKubh)}(h**Description**h]j)}(hj~Kh]h Description}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|Kubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMzhjKubh)}(hSeting tlr_enabled flag to 0.h]hSeting tlr_enabled flag to 0.}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMzhjKubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_enable_tlr (C function)c.sas_enable_tlrhNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h.void sas_enable_tlr (struct scsi_device *sdev)h]jP)}(h-void sas_enable_tlr(struct scsi_device *sdev)h](j~)}(hvoidh]hvoid}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjKhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMubjh)}(h h]h }(hjKhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjKhhhjKhMubjy)}(hsas_enable_tlrh]j)}(hsas_enable_tlrh]hsas_enable_tlr}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjKubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjKhhhjKhMubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjLhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjKubjh)}(h h]h }(hj LhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjKubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjLubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj LmodnameN classnameNjj)}j]j)}jjKsbc.sas_enable_tlrasbuh1hhjKubjh)}(h h]h }(hj>LhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjKubj )}(hj h]h*}(hjLLhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjKubj)}(hsdevh]hsdev}(hjYLhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjKubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjKubah}(h]h ]h"]h$]h&]jjuh1jhjKhhhjKhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjKhhhjKhMubah}(h]jKah ](jjeh"]h$]h&]jj)jhuh1jIhjKhMhjKhhubj)}(hhh]h)}(hsetting TLR flagsh]hsetting TLR flags}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjLhhubah}(h]h ]h"]h$]h&]uh1jhjKhhhjKhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjLjjLjjjuh1jDhhhjChNhNubj)}(hn**Parameters** ``struct scsi_device *sdev`` scsi device struct **Description** Seting tlr_enabled flag 1.h](h)}(h**Parameters**h]j)}(hjLh]h Parameters}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjLubj#)}(hhh]j()}(h0``struct scsi_device *sdev`` scsi device struct h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjLh]hstruct scsi_device *sdev}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjLubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjLubjJ)}(hhh]h)}(hscsi device structh]hscsi device struct}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMhjLubah}(h]h ]h"]h$]h&]uh1jIhjLubeh}(h]h ]h"]h$]h&]uh1j'hjLhMhjLubah}(h]h ]h"]h$]h&]uh1j"hjLubh)}(h**Description**h]j)}(hjLh]h Description}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjLubh)}(hSeting tlr_enabled flag 1.h]hSeting tlr_enabled flag 1.}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjLubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@'sas_ata_ncq_prio_supported (C function)c.sas_ata_ncq_prio_supportedhNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h:bool sas_ata_ncq_prio_supported (struct scsi_device *sdev)h]jP)}(h9bool sas_ata_ncq_prio_supported(struct scsi_device *sdev)h](j~)}(hjU.h]hbool}(hjDMhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj@Mhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMubjh)}(h h]h }(hjRMhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj@MhhhjQMhMubjy)}(hsas_ata_ncq_prio_supportedh]j)}(hsas_ata_ncq_prio_supportedh]hsas_ata_ncq_prio_supported}(hjdMhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj`Mubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj@MhhhjQMhMubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj|Mubjh)}(h h]h }(hjMhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj|Mubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjMubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjMmodnameN classnameNjj)}j]j)}jjfMsbc.sas_ata_ncq_prio_supportedasbuh1hhj|Mubjh)}(h h]h }(hjMhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj|Mubj )}(hj h]h*}(hjMhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj|Mubj)}(hsdevh]hsdev}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj|Mubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjxMubah}(h]h ]h"]h$]h&]jjuh1jhj@MhhhjQMhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjNubjJ)}(hhh]h)}(h SCSI deviceh]h SCSI device}(hj]NhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYNhMhjZNubah}(h]h ]h"]h$]h&]uh1jIhj>Nubeh}(h]h ]h"]h$]h&]uh1j'hjYNhMhj;Nubah}(h]h ]h"]h$]h&]uh1j"hjNubh)}(h**Description**h]j)}(hjNh]h Description}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}Nubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjNubh)}(hCheck if an ATA device supports NCQ priority using VPD page 89h (ATA Information). Since this VPD page is implemented only for ATA devices, this function always returns false for SCSI devices.h]hCheck if an ATA device supports NCQ priority using VPD page 89h (ATA Information). Since this VPD page is implemented only for ATA devices, this function always returns false for SCSI devices.}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjNubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_phy_alloc (C function)c.sas_phy_allochNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(hBstruct sas_phy * sas_phy_alloc (struct device *parent, int number)h]jP)}(h@struct sas_phy *sas_phy_alloc(struct device *parent, int number)h](jV)}(hjYh]hstruct}(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMubjh)}(h h]h }(hjNhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjNhhhjNhMubh)}(hhh]j)}(hsas_phyh]hsas_phy}(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjNubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjNmodnameN classnameNjj)}j]j)}j sas_phy_allocsbc.sas_phy_allocasbuh1hhjNhhhjNhMubjh)}(h h]h }(hjOhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjNhhhjNhMubj )}(hj h]h*}(hjOhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjNhhhjNhMubjy)}(h sas_phy_alloch]j)}(hjOh]h sas_phy_alloc}(hj#OhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjOubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjNhhhjNhMubj)}(h#(struct device *parent, int number)h](j)}(hstruct device *parenth](jV)}(hjYh]hstruct}(hj>OhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:Oubjh)}(h h]h }(hjKOhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj:Oubh)}(hhh]j)}(hdeviceh]hdevice}(hj\OhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjYOubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj^OmodnameN classnameNjj)}j]jNc.sas_phy_allocasbuh1hhj:Oubjh)}(h h]h }(hjzOhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj:Oubj )}(hj h]h*}(hjOhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj:Oubj)}(hparenth]hparent}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj:Oubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj6Oubj)}(h int numberh](j~)}(hinth]hint}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjOubjh)}(h h]h }(hjOhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjOubj)}(hnumberh]hnumber}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjOubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj6Oubeh}(h]h ]h"]h$]h&]jjuh1jhjNhhhjNhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjNhhhjNhMubah}(h]jNah ](jjeh"]h$]h&]jj)jhuh1jIhjNhMhjNhhubj)}(hhh]h)}(h,allocates and initialize a SAS PHY structureh]h,allocates and initialize a SAS PHY structure}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjOhhubah}(h]h ]h"]h$]h&]uh1jhjNhhhjNhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj Pjj Pjjjuh1jDhhhjChNhNubj)}(hXP**Parameters** ``struct device *parent`` Parent device ``int number`` Phy index **Description** Allocates an SAS PHY structure. It will be added in the device tree below the device specified by **parent**, which has to be either a Scsi_Host or sas_rphy. **Return** SAS PHY allocated or ``NULL`` if the allocation failed.h](h)}(h**Parameters**h]j)}(hjPh]h Parameters}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjPubj#)}(hhh](j()}(h(``struct device *parent`` Parent device h](j.)}(h``struct device *parent``h]j4)}(hj5Ph]hstruct device *parent}(hj7PhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj3Pubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj/PubjJ)}(hhh]h)}(h Parent deviceh]h Parent device}(hjNPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJPhMhjKPubah}(h]h ]h"]h$]h&]uh1jIhj/Pubeh}(h]h ]h"]h$]h&]uh1j'hjJPhMhj,Pubj()}(h``int number`` Phy index h](j.)}(h``int number``h]j4)}(hjnPh]h int number}(hjpPhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjlPubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjhPubjJ)}(hhh]h)}(h Phy indexh]h Phy index}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjPubah}(h]h ]h"]h$]h&]uh1jIhjhPubeh}(h]h ]h"]h$]h&]uh1j'hjPhMhj,Pubeh}(h]h ]h"]h$]h&]uh1j"hjPubh)}(h**Description**h]j)}(hjPh]h Description}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjPubh)}(hAllocates an SAS PHY structure. It will be added in the device tree below the device specified by **parent**, which has to be either a Scsi_Host or sas_rphy.h](hcAllocates an SAS PHY structure. It will be added in the device tree below the device specified by }(hjPhhhNhNubj)}(h **parent**h]hparent}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubh1, which has to be either a Scsi_Host or sas_rphy.}(hjPhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjPubh)}(h **Return**h]j)}(hjPh]hReturn}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjPubj`)}(h7SAS PHY allocated or ``NULL`` if the allocation failed.h]h)}(hjPh](hSAS PHY allocated or }(hjPhhhNhNubj4)}(h``NULL``h]hNULL}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjPubh if the allocation failed.}(hjPhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjPubah}(h]h ]h"]h$]h&]uh1j_hjQhMhjPubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_phy_add (C function) c.sas_phy_addhNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h%int sas_phy_add (struct sas_phy *phy)h]jP)}(h$int sas_phy_add(struct sas_phy *phy)h](j~)}(hinth]hint}(hjBQhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj>Qhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMubjh)}(h h]h }(hjQQhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj>QhhhjPQhMubjy)}(h sas_phy_addh]j)}(h sas_phy_addh]h sas_phy_add}(hjcQhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj_Qubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj>QhhhjPQhMubj)}(h(struct sas_phy *phy)h]j)}(hstruct sas_phy *phyh](jV)}(hjYh]hstruct}(hjQhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{Qubjh)}(h h]h }(hjQhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{Qubh)}(hhh]j)}(hsas_phyh]hsas_phy}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjQubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjQmodnameN classnameNjj)}j]j)}jjeQsb c.sas_phy_addasbuh1hhj{Qubjh)}(h h]h }(hjQhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{Qubj )}(hj h]h*}(hjQhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj{Qubj)}(hphyh]hphy}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj{Qubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjwQubah}(h]h ]h"]h$]h&]jjuh1jhj>QhhhjPQhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj:QhhhjPQhMubah}(h]j5Qah ](jjeh"]h$]h&]jj)jhuh1jIhjPQhMhj7Qhhubj)}(hhh]h)}(h%add a SAS PHY to the device hierarchyh]h%add a SAS PHY to the device hierarchy}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjQhhubah}(h]h ]h"]h$]h&]uh1jhj7QhhhjPQhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjRjjRjjjuh1jDhhhjChNhNubj)}(h~**Parameters** ``struct sas_phy *phy`` The PHY to be added **Description** Publishes a SAS PHY to the rest of the system.h](h)}(h**Parameters**h]j)}(hj$Rh]h Parameters}(hj&RhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"Rubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjRubj#)}(hhh]j()}(h,``struct sas_phy *phy`` The PHY to be added h](j.)}(h``struct sas_phy *phy``h]j4)}(hjCRh]hstruct sas_phy *phy}(hjERhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjARubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj=RubjJ)}(hhh]h)}(hThe PHY to be addedh]hThe PHY to be added}(hj\RhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXRhMhjYRubah}(h]h ]h"]h$]h&]uh1jIhj=Rubeh}(h]h ]h"]h$]h&]uh1j'hjXRhMhj:Rubah}(h]h ]h"]h$]h&]uh1j"hjRubh)}(h**Description**h]j)}(hj~Rh]h Description}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|Rubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjRubh)}(h.Publishes a SAS PHY to the rest of the system.h]h.Publishes a SAS PHY to the rest of the system.}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjRubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_phy_free (C function)c.sas_phy_freehNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h'void sas_phy_free (struct sas_phy *phy)h]jP)}(h&void sas_phy_free(struct sas_phy *phy)h](j~)}(hvoidh]hvoid}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjRhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMubjh)}(h h]h }(hjRhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjRhhhjRhMubjy)}(h sas_phy_freeh]j)}(h sas_phy_freeh]h sas_phy_free}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjRubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjRhhhjRhMubj)}(h(struct sas_phy *phy)h]j)}(hstruct sas_phy *phyh](jV)}(hjYh]hstruct}(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRubjh)}(h h]h }(hj ShhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjRubh)}(hhh]j)}(hsas_phyh]hsas_phy}(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjSubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj SmodnameN classnameNjj)}j]j)}jjRsbc.sas_phy_freeasbuh1hhjRubjh)}(h h]h }(hj>ShhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjRubj )}(hj h]h*}(hjLShhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjRubj)}(hphyh]hphy}(hjYShhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjRubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjRubah}(h]h ]h"]h$]h&]jjuh1jhjRhhhjRhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjRhhhjRhMubah}(h]jRah ](jjeh"]h$]h&]jj)jhuh1jIhjRhMhjRhhubj)}(hhh]h)}(hfree a SAS PHYh]hfree a SAS PHY}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjShhubah}(h]h ]h"]h$]h&]uh1jhjRhhhjRhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjSjjSjjjuh1jDhhhjChNhNubj)}(h**Parameters** ``struct sas_phy *phy`` SAS PHY to free **Description** Frees the specified SAS PHY. **Note** This function must only be called on a PHY that has not successfully been added using sas_phy_add().h](h)}(h**Parameters**h]j)}(hjSh]h Parameters}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjSubj#)}(hhh]j()}(h(``struct sas_phy *phy`` SAS PHY to free h](j.)}(h``struct sas_phy *phy``h]j4)}(hjSh]hstruct sas_phy *phy}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjSubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjSubjJ)}(hhh]h)}(hSAS PHY to freeh]hSAS PHY to free}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShMhjSubah}(h]h ]h"]h$]h&]uh1jIhjSubeh}(h]h ]h"]h$]h&]uh1j'hjShMhjSubah}(h]h ]h"]h$]h&]uh1j"hjSubh)}(h**Description**h]j)}(hjSh]h Description}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjSubh)}(hFrees the specified SAS PHY.h]hFrees the specified SAS PHY.}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjSubh)}(h**Note**h]j)}(hj&Th]hNote}(hj(ThhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$Tubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjSubj`)}(hdThis function must only be called on a PHY that has not successfully been added using sas_phy_add().h]h)}(hdThis function must only be called on a PHY that has not successfully been added using sas_phy_add().h]hdThis function must only be called on a PHY that has not successfully been added using sas_phy_add().}(hj@ThhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj\hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj+\hhhj=\hMubjy)}(h sas_port_addh]j)}(h sas_port_addh]h sas_port_add}(hjP\hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjL\ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj+\hhhj=\hMubj)}(h(struct sas_port *port)h]j)}(hstruct sas_port *porth](jV)}(hjYh]hstruct}(hjl\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjh\ubjh)}(h h]h }(hjy\hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjh\ubh)}(hhh]j)}(hsas_porth]hsas_port}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj\ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj\modnameN classnameNjj)}j]j)}jjR\sbc.sas_port_addasbuh1hhjh\ubjh)}(h h]h }(hj\hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjh\ubj )}(hj h]h*}(hj\hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjh\ubj)}(hporth]hport}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjh\ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjd\ubah}(h]h ]h"]h$]h&]jjuh1jhj+\hhhj=\hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj'\hhhj=\hMubah}(h]j"\ah ](jjeh"]h$]h&]jj)jhuh1jIhj=\hMhj$\hhubj)}(hhh]h)}(h&add a SAS port to the device hierarchyh]h&add a SAS port to the device hierarchy}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj\hhubah}(h]h ]h"]h$]h&]uh1jhj$\hhhj=\hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj]jj]jjjuh1jDhhhjChNhNubj)}(hy**Parameters** ``struct sas_port *port`` port to be added **Description** publishes a port to the rest of the systemh](h)}(h**Parameters**h]j)}(hj]h]h Parameters}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj ]ubj#)}(hhh]j()}(h+``struct sas_port *port`` port to be added h](j.)}(h``struct sas_port *port``h]j4)}(hj0]h]hstruct sas_port *port}(hj2]hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj.]ubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj*]ubjJ)}(hhh]h)}(hport to be addedh]hport to be added}(hjI]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjE]hMhjF]ubah}(h]h ]h"]h$]h&]uh1jIhj*]ubeh}(h]h ]h"]h$]h&]uh1j'hjE]hMhj']ubah}(h]h ]h"]h$]h&]uh1j"hj ]ubh)}(h**Description**h]j)}(hjk]h]h Description}(hjm]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhji]ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj ]ubh)}(h*publishes a port to the rest of the systemh]h*publishes a port to the rest of the system}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj ]ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_port_free (C function)c.sas_port_freehNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h*void sas_port_free (struct sas_port *port)h]jP)}(h)void sas_port_free(struct sas_port *port)h](j~)}(hvoidh]hvoid}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj]hhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMubjh)}(h h]h }(hj]hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj]hhhj]hMubjy)}(h sas_port_freeh]j)}(h sas_port_freeh]h sas_port_free}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj]ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj]hhhj]hMubj)}(h(struct sas_port *port)h]j)}(hstruct sas_port *porth](jV)}(hjYh]hstruct}(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]ubjh)}(h h]h }(hj]hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj]ubh)}(hhh]j)}(hsas_porth]hsas_port}(hj ^hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj^ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj ^modnameN classnameNjj)}j]j)}jj]sbc.sas_port_freeasbuh1hhj]ubjh)}(h h]h }(hj+^hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj]ubj )}(hj h]h*}(hj9^hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj]ubj)}(hporth]hport}(hjF^hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj]ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubah}(h]h ]h"]h$]h&]jjuh1jhj]hhhj]hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj]hhhj]hMubah}(h]j]ah ](jjeh"]h$]h&]jj)jhuh1jIhj]hMhj]hhubj)}(hhh]h)}(hfree a SAS PORTh]hfree a SAS PORT}(hjp^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjm^hhubah}(h]h ]h"]h$]h&]uh1jhj]hhhj]hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj^jj^jjjuh1jDhhhjChNhNubj)}(h**Parameters** ``struct sas_port *port`` SAS PORT to free **Description** Frees the specified SAS PORT. **Note** This function must only be called on a PORT that has not successfully been added using sas_port_add().h](h)}(h**Parameters**h]j)}(hj^h]h Parameters}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj^ubj#)}(hhh]j()}(h+``struct sas_port *port`` SAS PORT to free h](j.)}(h``struct sas_port *port``h]j4)}(hj^h]hstruct sas_port *port}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj^ubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj^ubjJ)}(hhh]h)}(hSAS PORT to freeh]hSAS PORT to free}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hMhj^ubah}(h]h ]h"]h$]h&]uh1jIhj^ubeh}(h]h ]h"]h$]h&]uh1j'hj^hMhj^ubah}(h]h ]h"]h$]h&]uh1j"hj^ubh)}(h**Description**h]j)}(hj^h]h Description}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj^ubh)}(hFrees the specified SAS PORT.h]hFrees the specified SAS PORT.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj^ubh)}(h**Note**h]j)}(hj_h]hNote}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj^ubj`)}(hfThis function must only be called on a PORT that has not successfully been added using sas_port_add().h]h)}(hfThis function must only be called on a PORT that has not successfully been added using sas_port_add().h]hfThis function must only be called on a PORT that has not successfully been added using sas_port_add().}(hj-_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj)_ubah}(h]h ]h"]h$]h&]uh1j_hj;_hMhj^ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_port_delete (C function)c.sas_port_deletehNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h,void sas_port_delete (struct sas_port *port)h]jP)}(h+void sas_port_delete(struct sas_port *port)h](j~)}(hvoidh]hvoid}(hjb_hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj^_hhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMubjh)}(h h]h }(hjq_hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj^_hhhjp_hMubjy)}(hsas_port_deleteh]j)}(hsas_port_deleteh]hsas_port_delete}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj_ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj^_hhhjp_hMubj)}(h(struct sas_port *port)h]j)}(hstruct sas_port *porth](jV)}(hjYh]hstruct}(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubjh)}(h h]h }(hj_hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj_ubh)}(hhh]j)}(hsas_porth]hsas_port}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj_ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj_modnameN classnameNjj)}j]j)}jj_sbc.sas_port_deleteasbuh1hhj_ubjh)}(h h]h }(hj_hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj_ubj )}(hj h]h*}(hj_hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj_ubj)}(hporth]hport}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj_ubah}(h]h ]h"]h$]h&]jjuh1jhj^_hhhjp_hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjZ_hhhjp_hMubah}(h]jU_ah ](jjeh"]h$]h&]jj)jhuh1jIhjp_hMhjW_hhubj)}(hhh]h)}(hremove SAS PORTh]hremove SAS PORT}(hj"`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj`hhubah}(h]h ]h"]h$]h&]uh1jhjW_hhhjp_hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj:`jj:`jjjuh1jDhhhjChNhNubj)}(h**Parameters** ``struct sas_port *port`` SAS PORT to remove **Description** Removes the specified SAS PORT. If the SAS PORT has an associated phys, unlink them from the port as well.h](h)}(h**Parameters**h]j)}(hjD`h]h Parameters}(hjF`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjB`ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj>`ubj#)}(hhh]j()}(h-``struct sas_port *port`` SAS PORT to remove h](j.)}(h``struct sas_port *port``h]j4)}(hjc`h]hstruct sas_port *port}(hje`hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hja`ubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj]`ubjJ)}(hhh]h)}(hSAS PORT to removeh]hSAS PORT to remove}(hj|`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjx`hMhjy`ubah}(h]h ]h"]h$]h&]uh1jIhj]`ubeh}(h]h ]h"]h$]h&]uh1j'hjx`hMhjZ`ubah}(h]h ]h"]h$]h&]uh1j"hj>`ubh)}(h**Description**h]j)}(hj`h]h Description}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj>`ubh)}(hkRemoves the specified SAS PORT. If the SAS PORT has an associated phys, unlink them from the port as well.h]hkRemoves the specified SAS PORT. If the SAS PORT has an associated phys, unlink them from the port as well.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhj>`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@scsi_is_sas_port (C function)c.scsi_is_sas_porthNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h/int scsi_is_sas_port (const struct device *dev)h]jP)}(h.int scsi_is_sas_port(const struct device *dev)h](j~)}(hinth]hint}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj`hhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMubjh)}(h h]h }(hj`hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj`hhhj`hMubjy)}(hscsi_is_sas_porth]j)}(hscsi_is_sas_porth]hscsi_is_sas_port}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjaubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj`hhhj`hMubj)}(h(const struct device *dev)h]j)}(hconst struct device *devh](jV)}(hjNh]hconst}(hj ahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjaubjh)}(h h]h }(hj-ahhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjaubjV)}(hjYh]hstruct}(hj;ahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjaubjh)}(h h]h }(hjHahhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjaubh)}(hhh]j)}(hdeviceh]hdevice}(hjYahhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjVaubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj[amodnameN classnameNjj)}j]j)}jjasbc.scsi_is_sas_portasbuh1hhjaubjh)}(h h]h }(hjyahhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjaubj )}(hj h]h*}(hjahhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjaubj)}(hdevh]hdev}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjaubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjaubah}(h]h ]h"]h$]h&]jjuh1jhj`hhhj`hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj`hhhj`hMubah}(h]j`ah ](jjeh"]h$]h&]jj)jhuh1jIhj`hMhj`hhubj)}(hhh]h)}(h.check if a struct device represents a SAS porth]h.check if a struct device represents a SAS port}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjahhubah}(h]h ]h"]h$]h&]uh1jhj`hhhj`hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjajjajjjuh1jDhhhjChNhNubj)}(h**Parameters** ``const struct device *dev`` device to check **Return** ``1`` if the device represents a SAS Port, ``0`` elseh](h)}(h**Parameters**h]j)}(hjah]h Parameters}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjaubj#)}(hhh]j()}(h-``const struct device *dev`` device to check h](j.)}(h``const struct device *dev``h]j4)}(hjah]hconst struct device *dev}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjaubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjaubjJ)}(hhh]h)}(hdevice to checkh]hdevice to check}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhMhjbubah}(h]h ]h"]h$]h&]uh1jIhjaubeh}(h]h ]h"]h$]h&]uh1j'hjbhMhjaubah}(h]h ]h"]h$]h&]uh1j"hjaubh)}(h **Return**h]j)}(hj:bh]hReturn}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj:dhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM?ubjh)}(h h]h }(hjMdhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj:dhhhjLdhM?ubjy)}(hsas_port_add_phyh]j)}(hsas_port_add_phyh]hsas_port_add_phy}(hj_dhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj[dubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj:dhhhjLdhM?ubj)}(h,(struct sas_port *port, struct sas_phy *phy)h](j)}(hstruct sas_port *porth](jV)}(hjYh]hstruct}(hj{dhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjwdubjh)}(h h]h }(hjdhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjwdubh)}(hhh]j)}(hsas_porth]hsas_port}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjdubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjdmodnameN classnameNjj)}j]j)}jjadsbc.sas_port_add_phyasbuh1hhjwdubjh)}(h h]h }(hjdhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjwdubj )}(hj h]h*}(hjdhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjwdubj)}(hporth]hport}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjwdubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsdubj)}(hstruct sas_phy *phyh](jV)}(hjYh]hstruct}(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubjh)}(h h]h }(hjdhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjdubh)}(hhh]j)}(hsas_phyh]hsas_phy}(hj ehhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjeubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj emodnameN classnameNjj)}j]jdc.sas_port_add_phyasbuh1hhjdubjh)}(h h]h }(hj)ehhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjdubj )}(hj h]h*}(hj7ehhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjdubj)}(hphyh]hphy}(hjDehhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjdubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsdubeh}(h]h ]h"]h$]h&]jjuh1jhj:dhhhjLdhM?ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj6dhhhjLdhM?ubah}(h]j1dah ](jjeh"]h$]h&]jj)jhuh1jIhjLdhM?hj3dhhubj)}(hhh]h)}(h-add another phy to a port to form a wide porth]h-add another phy to a port to form a wide port}(hjnehhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM?hjkehhubah}(h]h ]h"]h$]h&]uh1jhj3dhhhjLdhM?ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjejjejjjuh1jDhhhjChNhNubj)}(hX**Parameters** ``struct sas_port *port`` port to add the phy to ``struct sas_phy *phy`` phy to add **Description** When a port is initially created, it is empty (has no phys). All ports must have at least one phy to operated, and all wide ports must have at least two. The current code makes no difference between ports and wide ports, but the only object that can be connected to a remote device is a port, so ports must be formed on all devices with phys if they're connected to anything.h](h)}(h**Parameters**h]j)}(hjeh]h Parameters}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMChjeubj#)}(hhh](j()}(h1``struct sas_port *port`` port to add the phy to h](j.)}(h``struct sas_port *port``h]j4)}(hjeh]hstruct sas_port *port}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjeubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM@hjeubjJ)}(hhh]h)}(hport to add the phy toh]hport to add the phy to}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehM@hjeubah}(h]h ]h"]h$]h&]uh1jIhjeubeh}(h]h ]h"]h$]h&]uh1j'hjehM@hjeubj()}(h#``struct sas_phy *phy`` phy to add h](j.)}(h``struct sas_phy *phy``h]j4)}(hjeh]hstruct sas_phy *phy}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjeubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMAhjeubjJ)}(hhh]h)}(h phy to addh]h phy to add}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMAhjeubah}(h]h ]h"]h$]h&]uh1jIhjeubeh}(h]h ]h"]h$]h&]uh1j'hjehMAhjeubeh}(h]h ]h"]h$]h&]uh1j"hjeubh)}(h**Description**h]j)}(hj#fh]h Description}(hj%fhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!fubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMChjeubh)}(hXyWhen a port is initially created, it is empty (has no phys). All ports must have at least one phy to operated, and all wide ports must have at least two. The current code makes no difference between ports and wide ports, but the only object that can be connected to a remote device is a port, so ports must be formed on all devices with phys if they're connected to anything.h]hX{When a port is initially created, it is empty (has no phys). All ports must have at least one phy to operated, and all wide ports must have at least two. The current code makes no difference between ports and wide ports, but the only object that can be connected to a remote device is a port, so ports must be formed on all devices with phys if they’re connected to anything.}(hj9fhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMChjeubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@ sas_port_delete_phy (C function)c.sas_port_delete_phyhNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(hEvoid sas_port_delete_phy (struct sas_port *port, struct sas_phy *phy)h]jP)}(hDvoid sas_port_delete_phy(struct sas_port *port, struct sas_phy *phy)h](j~)}(hvoidh]hvoid}(hjhfhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjdfhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMeubjh)}(h h]h }(hjwfhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjdfhhhjvfhMeubjy)}(hsas_port_delete_phyh]j)}(hsas_port_delete_phyh]hsas_port_delete_phy}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjfubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjdfhhhjvfhMeubj)}(h,(struct sas_port *port, struct sas_phy *phy)h](j)}(hstruct sas_port *porth](jV)}(hjYh]hstruct}(hjfhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjfubjh)}(h h]h }(hjfhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjfubh)}(hhh]j)}(hsas_porth]hsas_port}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjfubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjfmodnameN classnameNjj)}j]j)}jjfsbc.sas_port_delete_phyasbuh1hhjfubjh)}(h h]h }(hjfhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjfubj )}(hj h]h*}(hjfhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjfubj)}(hporth]hport}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjfubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjfubj)}(hstruct sas_phy *phyh](jV)}(hjYh]hstruct}(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjgubjh)}(h h]h }(hj$ghhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjgubh)}(hhh]j)}(hsas_phyh]hsas_phy}(hj5ghhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj2gubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj7gmodnameN classnameNjj)}j]jfc.sas_port_delete_phyasbuh1hhjgubjh)}(h h]h }(hjSghhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjgubj )}(hj h]h*}(hjaghhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjgubj)}(hphyh]hphy}(hjnghhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjgubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjfubeh}(h]h ]h"]h$]h&]jjuh1jhjdfhhhjvfhMeubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj`fhhhjvfhMeubah}(h]j[fah ](jjeh"]h$]h&]jj)jhuh1jIhjvfhMehj]fhhubj)}(hhh]h)}(h%remove a phy from a port or wide porth]h%remove a phy from a port or wide port}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMehjghhubah}(h]h ]h"]h$]h&]uh1jhj]fhhhjvfhMeubeh}(h]h ](jfunctioneh"]h$]h&]jjjjgjjgjjjuh1jDhhhjChNhNubj)}(hX**Parameters** ``struct sas_port *port`` port to remove the phy from ``struct sas_phy *phy`` phy to remove **Description** This operation is used for tearing down ports again. It must be done to every port or wide port before calling sas_port_delete.h](h)}(h**Parameters**h]j)}(hjgh]h Parameters}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMihjgubj#)}(hhh](j()}(h6``struct sas_port *port`` port to remove the phy from h](j.)}(h``struct sas_port *port``h]j4)}(hjgh]hstruct sas_port *port}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjgubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMfhjgubjJ)}(hhh]h)}(hport to remove the phy fromh]hport to remove the phy from}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghMfhjgubah}(h]h ]h"]h$]h&]uh1jIhjgubeh}(h]h ]h"]h$]h&]uh1j'hjghMfhjgubj()}(h&``struct sas_phy *phy`` phy to remove h](j.)}(h``struct sas_phy *phy``h]j4)}(hjhh]hstruct sas_phy *phy}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjhubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMghj hubjJ)}(hhh]h)}(h phy to removeh]h phy to remove}(hj+hhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hhMghj(hubah}(h]h ]h"]h$]h&]uh1jIhj hubeh}(h]h ]h"]h$]h&]uh1j'hj'hhMghjgubeh}(h]h ]h"]h$]h&]uh1j"hjgubh)}(h**Description**h]j)}(hjMhh]h Description}(hjOhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKhubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMihjgubh)}(hThis operation is used for tearing down ports again. It must be done to every port or wide port before calling sas_port_delete.h]hThis operation is used for tearing down ports again. It must be done to every port or wide port before calling sas_port_delete.}(hjchhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMihjgubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!sas_end_device_alloc (C function)c.sas_end_device_allochNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h@struct sas_rphy * sas_end_device_alloc (struct sas_port *parent)h]jP)}(h>struct sas_rphy *sas_end_device_alloc(struct sas_port *parent)h](jV)}(hjYh]hstruct}(hjhhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMubjh)}(h h]h }(hjhhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhhjhhMubh)}(hhh]j)}(hsas_rphyh]hsas_rphy}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjhubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjhmodnameN classnameNjj)}j]j)}jsas_end_device_allocsbc.sas_end_device_allocasbuh1hhjhhhhjhhMubjh)}(h h]h }(hjhhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhhjhhMubj )}(hj h]h*}(hjhhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjhhhhjhhMubjy)}(hsas_end_device_alloch]j)}(hjhh]hsas_end_device_alloc}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjhubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhhjhhMubj)}(h(struct sas_port *parent)h]j)}(hstruct sas_port *parenth](jV)}(hjYh]hstruct}(hj ihhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjiubjh)}(h h]h }(hjihhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjiubh)}(hhh]j)}(hsas_porth]hsas_port}(hj*ihhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj'iubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj,imodnameN classnameNjj)}j]jhc.sas_end_device_allocasbuh1hhjiubjh)}(h h]h }(hjHihhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjiubj )}(hj h]h*}(hjVihhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjiubj)}(hparenth]hparent}(hjcihhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjiubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubah}(h]h ]h"]h$]h&]jjuh1jhjhhhhjhhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhhjhhMubah}(h]jhah ](jjeh"]h$]h&]jj)jhuh1jIhjhhMhjhhhubj)}(hhh]h)}(h"allocate an rphy for an end deviceh]h"allocate an rphy for an end device}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjihhubah}(h]h ]h"]h$]h&]uh1jhjhhhhjhhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjijjijjjuh1jDhhhjChNhNubj)}(h**Parameters** ``struct sas_port *parent`` which port **Description** Allocates an SAS remote PHY structure, connected to **parent**. **Return** SAS PHY allocated or ``NULL`` if the allocation failed.h](h)}(h**Parameters**h]j)}(hjih]h Parameters}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjiubj#)}(hhh]j()}(h'``struct sas_port *parent`` which port h](j.)}(h``struct sas_port *parent``h]j4)}(hjih]hstruct sas_port *parent}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjiubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjiubjJ)}(hhh]h)}(h which porth]h which port}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j'hjihMhjiubah}(h]h ]h"]h$]h&]uh1j"hjiubh)}(h**Description**h]j)}(hj jh]h Description}(hj jhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjiubh)}(h?Allocates an SAS remote PHY structure, connected to **parent**.h](h4Allocates an SAS remote PHY structure, connected to }(hjjhhhNhNubj)}(h **parent**h]hparent}(hj'jhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubh.}(hjjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjiubh)}(h **Return**h]j)}(hjBjh]hReturn}(hjDjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@jubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjiubj`)}(h7SAS PHY allocated or ``NULL`` if the allocation failed.h]h)}(hjZjh](hSAS PHY allocated or }(hj\jhhhNhNubj4)}(h``NULL``h]hNULL}(hjcjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj\jubh if the allocation failed.}(hj\jhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMhjXjubah}(h]h ]h"]h$]h&]uh1j_hj{jhMhjiubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_expander_alloc (C function)c.sas_expander_allochNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(hYstruct sas_rphy * sas_expander_alloc (struct sas_port *parent, enum sas_device_type type)h]jP)}(hWstruct sas_rphy *sas_expander_alloc(struct sas_port *parent, enum sas_device_type type)h](jV)}(hjYh]hstruct}(hjjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjjhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMubjh)}(h h]h }(hjjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjjhhhjjhMubh)}(hhh]j)}(hsas_rphyh]hsas_rphy}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjmodnameN classnameNjj)}j]j)}jsas_expander_allocsbc.sas_expander_allocasbuh1hhjjhhhjjhMubjh)}(h h]h }(hjjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjjhhhjjhMubj )}(hj h]h*}(hjjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjjhhhjjhMubjy)}(hsas_expander_alloch]j)}(hjjh]hsas_expander_alloc}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjjhhhjjhMubj)}(h4(struct sas_port *parent, enum sas_device_type type)h](j)}(hstruct sas_port *parenth](jV)}(hjYh]hstruct}(hjkhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjkubjh)}(h h]h }(hj)khhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjkubh)}(hhh]j)}(hsas_porth]hsas_port}(hj:khhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj7kubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqhhubah}(h]h ]h"]h$]h&]uh1jhjvphhhjphMOubeh}(h]h ](jfunctioneh"]h$]h&]jjjjYqjjYqjjjuh1jDhhhjChNhNubj)}(h**Parameters** ``struct sas_rphy *rphy`` SAS remote PHY to remove and free **Description** Removes the specified SAS remote PHY and frees it.h](h)}(h**Parameters**h]j)}(hjcqh]h Parameters}(hjeqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaqubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMShj]qubj#)}(hhh]j()}(h<``struct sas_rphy *rphy`` SAS remote PHY to remove and free h](j.)}(h``struct sas_rphy *rphy``h]j4)}(hjqh]hstruct sas_rphy *rphy}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjqubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMPhj|qubjJ)}(hhh]h)}(h!SAS remote PHY to remove and freeh]h!SAS remote PHY to remove and free}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhMPhjqubah}(h]h ]h"]h$]h&]uh1jIhj|qubeh}(h]h ]h"]h$]h&]uh1j'hjqhMPhjyqubah}(h]h ]h"]h$]h&]uh1j"hj]qubh)}(h**Description**h]j)}(hjqh]h Description}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMRhj]qubh)}(h2Removes the specified SAS remote PHY and frees it.h]h2Removes the specified SAS remote PHY and frees it.}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMRhj]qubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@sas_rphy_unlink (C function)c.sas_rphy_unlinkhNtauh1j3hjChhhNhNubjE)}(hhh](jJ)}(h,void sas_rphy_unlink (struct sas_rphy *rphy)h]jP)}(h+void sas_rphy_unlink(struct sas_rphy *rphy)h](j~)}(hvoidh]hvoid}(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjqhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM]ubjh)}(h h]h }(hjrhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjqhhhjrhM]ubjy)}(hsas_rphy_unlinkh]j)}(hsas_rphy_unlinkh]hsas_rphy_unlink}(hj#rhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjrubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjqhhhjrhM]ubj)}(h(struct sas_rphy *rphy)h]j)}(hstruct sas_rphy *rphyh](jV)}(hjYh]hstruct}(hj?rhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj;rubjh)}(h h]h }(hjLrhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj;rubh)}(hhh]j)}(hsas_rphyh]hsas_rphy}(hj]rhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjZrubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj_rmodnameN classnameNjj)}j]j)}jj%rsbc.sas_rphy_unlinkasbuh1hhj;rubjh)}(h h]h }(hj}rhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj;rubj )}(hj h]h*}(hjrhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj;rubj)}(hrphyh]hrphy}(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj;rubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj7rubah}(h]h ]h"]h$]h&]jjuh1jhjqhhhjrhM]ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjqhhhjrhM]ubah}(h]jqah ](jjeh"]h$]h&]jj)jhuh1jIhjrhM]hjqhhubj)}(hhh]h)}(hunlink SAS remote PHYh]hunlink SAS remote PHY}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM]hjrhhubah}(h]h ]h"]h$]h&]uh1jhjqhhhjrhM]ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjrjjrjjjuh1jDhhhjChNhNubj)}(h**Parameters** ``struct sas_rphy *rphy`` SAS remote phy to unlink from its parent port **Description** Removes port reference to an rphyh](h)}(h**Parameters**h]j)}(hjrh]h Parameters}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMahjrubj#)}(hhh]j()}(hH``struct sas_rphy *rphy`` SAS remote phy to unlink from its parent port h](j.)}(h``struct sas_rphy *rphy``h]j4)}(hjsh]hstruct sas_rphy *rphy}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjsubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM^hjrubjJ)}(hhh]h)}(h-SAS remote phy to unlink from its parent porth]h-SAS remote phy to unlink from its parent port}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshM^hjsubah}(h]h ]h"]h$]h&]uh1jIhjrubeh}(h]h ]h"]h$]h&]uh1j'hjshM^hjrubah}(h]h ]h"]h$]h&]uh1j"hjrubh)}(h**Description**h]j)}(hj>sh]h Description}(hj@shhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvoid sas_release_transport (struct scsi_transport_template *t)h]jP)}(h=void sas_release_transport(struct scsi_transport_template *t)h](j~)}(hvoidh]hvoid}(hj_xhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj[xhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMZubjh)}(h h]h }(hjnxhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj[xhhhjmxhMZubjy)}(hsas_release_transporth]j)}(hsas_release_transporth]hsas_release_transport}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj|xubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj[xhhhjmxhMZubj)}(h#(struct scsi_transport_template *t)h]j)}(h!struct scsi_transport_template *th](jV)}(hjYh]hstruct}(hjxhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjxubjh)}(h h]h }(hjxhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjxubh)}(hhh]j)}(hscsi_transport_templateh]hscsi_transport_template}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjxubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjxmodnameN classnameNjj)}j]j)}jjxsbc.sas_release_transportasbuh1hhjxubjh)}(h h]h }(hjxhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjxubj )}(hj h]h*}(hjxhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjxubj)}(hth]ht}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjxubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjxubah}(h]h ]h"]h$]h&]jjuh1jhj[xhhhjmxhMZubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjWxhhhjmxhMZubah}(h]jRxah ](jjeh"]h$]h&]jj)jhuh1jIhjmxhMZhjTxhhubj)}(hhh]h)}(h'release SAS transport template instanceh]h'release SAS transport template instance}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chMZhjyhhubah}(h]h ]h"]h$]h&]uh1jhjTxhhhjmxhMZubeh}(h]h ](jfunctioneh"]h$]h&]jjjj7yjj7yjjjuh1jDhhhjChNhNubj)}(hS**Parameters** ``struct scsi_transport_template *t`` transport template instanceh](h)}(h**Parameters**h]j)}(hjAyh]h Parameters}(hjCyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?yubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM^hj;yubj#)}(hhh]j()}(hA``struct scsi_transport_template *t`` transport template instanceh](j.)}(h%``struct scsi_transport_template *t``h]j4)}(hj`yh]h!struct scsi_transport_template *t}(hjbyhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj^yubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM`hjZyubjJ)}(hhh]h)}(htransport template instanceh]htransport template instance}(hjyyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:276: ./drivers/scsi/scsi_transport_sas.chM[hjvyubah}(h]h ]h"]h$]h&]uh1jIhjZyubeh}(h]h ]h"]h$]h&]uh1j'hjuyhM`hjWyubah}(h]h ]h"]h$]h&]uh1j"hj;yubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjChhhNhNubeh}(h](serial-attached-scsi-sas-transport-classah ]h"]*serial attached scsi (sas) transport classah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hSATA transport classh]hSATA transport class}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhhhhhMubh)}(hcThe SATA transport is handled by libata, which has its own book of documentation in this directory.h]hcThe SATA transport is handled by libata, which has its own book of documentation in this directory.}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjyhhubeh}(h]sata-transport-classah ]h"]sata transport classah$]h&]uh1hhjhhhhhMubh)}(hhh](h)}(h#Parallel SCSI (SPI) transport classh]h#Parallel SCSI (SPI) transport class}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhhhhhMubh)}(hvThe file drivers/scsi/scsi_transport_spi.c defines transport attributes for traditional (fast/wide/ultra) SCSI busses.h]hvThe file drivers/scsi/scsi_transport_spi.c defines transport attributes for traditional (fast/wide/ultra) SCSI busses.}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM hjyhhubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@spi_dv_device (C function)c.spi_dv_devicehNtauh1j3hjyhhhNhNubjE)}(hhh](jJ)}(h-void spi_dv_device (struct scsi_device *sdev)h]jP)}(h,void spi_dv_device(struct scsi_device *sdev)h](j~)}(hvoidh]hvoid}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjzhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chMubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjzhhhjzhMubjy)}(h spi_dv_deviceh]j)}(h spi_dv_deviceh]h spi_dv_device}(hj)zhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj%zubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjzhhhjzhMubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hjEzhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAzubjh)}(h h]h }(hjRzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjAzubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hjczhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj`zubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjezmodnameN classnameNjj)}j]j)}jj+zsbc.spi_dv_deviceasbuh1hhjAzubjh)}(h h]h }(hjzhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjAzubj )}(hj h]h*}(hjzhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjAzubj)}(hsdevh]hsdev}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjAzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj=zubah}(h]h ]h"]h$]h&]jjuh1jhjzhhhjzhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjzhhhjzhMubah}(h]jyah ](jjeh"]h$]h&]jj)jhuh1jIhjzhMhjyhhubj)}(hhh]h)}(h"Do Domain Validation on the deviceh]h"Do Domain Validation on the device}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chMhjzhhubah}(h]h ]h"]h$]h&]uh1jhjyhhhjzhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjzjjzjjjuh1jDhhhjyhNhNubj)}(hXB**Parameters** ``struct scsi_device *sdev`` scsi device to validate Performs the domain validation on the given device in the current execution thread. Since DV operations may sleep, the current thread must have user context. Also no SCSI related locks that would deadlock I/O issued by the DV may be held.h](h)}(h**Parameters**h]j)}(hjzh]h Parameters}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chMhjzubj#)}(hhh]j()}(hX&``struct scsi_device *sdev`` scsi device to validate Performs the domain validation on the given device in the current execution thread. Since DV operations may sleep, the current thread must have user context. Also no SCSI related locks that would deadlock I/O issued by the DV may be held.h](j.)}(h``struct scsi_device *sdev``h]j4)}(hj {h]hstruct scsi_device *sdev}(hj {hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj{ubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chMhj{ubjJ)}(hhh](h)}(hscsi device to validateh]hscsi device to validate}(hj"{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chMhj{ubh)}(hPerforms the domain validation on the given device in the current execution thread. Since DV operations may sleep, the current thread must have user context. Also no SCSI related locks that would deadlock I/O issued by the DV may be held.h]hPerforms the domain validation on the given device in the current execution thread. Since DV operations may sleep, the current thread must have user context. Also no SCSI related locks that would deadlock I/O issued by the DV may be held.}(hj1{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chMhj{ubeh}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j'hj{hMhj{ubah}(h]h ]h"]h$]h&]uh1j"hjzubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjyhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@#spi_schedule_dv_device (C function)c.spi_schedule_dv_devicehNtauh1j3hjyhhhNhNubjE)}(hhh](jJ)}(h6void spi_schedule_dv_device (struct scsi_device *sdev)h]jP)}(h5void spi_schedule_dv_device(struct scsi_device *sdev)h](j~)}(hvoidh]hvoid}(hjr{hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjn{hhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chM?ubjh)}(h h]h }(hj{hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjn{hhhj{hM?ubjy)}(hspi_schedule_dv_deviceh]j)}(hspi_schedule_dv_deviceh]hspi_schedule_dv_device}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj{ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjn{hhhj{hM?ubj)}(h(struct scsi_device *sdev)h]j)}(hstruct scsi_device *sdevh](jV)}(hjYh]hstruct}(hj{hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubjh)}(h h]h }(hj{hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{ubh)}(hhh]j)}(h scsi_deviceh]h scsi_device}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj{ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj{modnameN classnameNjj)}j]j)}jj{sbc.spi_schedule_dv_deviceasbuh1hhj{ubjh)}(h h]h }(hj{hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj{ubj )}(hj h]h*}(hj{hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj{ubj)}(hsdevh]hsdev}(hj|hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubah}(h]h ]h"]h$]h&]jjuh1jhjn{hhhj{hM?ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjj{hhhj{hM?ubah}(h]je{ah ](jjeh"]h$]h&]jj)jhuh1jIhj{hM?hjg{hhubj)}(hhh]h)}(h1schedule domain validation to occur on the deviceh]h1schedule domain validation to occur on the device}(hj2|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chM?hj/|hhubah}(h]h ]h"]h$]h&]uh1jhjg{hhhj{hM?ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjJ|jjJ|jjjuh1jDhhhjyhNhNubj)}(hX **Parameters** ``struct scsi_device *sdev`` The device to validate Identical to spi_dv_device() above, except that the DV will be scheduled to occur in a workqueue later. All memory allocations are atomic, so may be called from any context including those holding SCSI locks.h](h)}(h**Parameters**h]j)}(hjT|h]h Parameters}(hjV|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjR|ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chMChjN|ubj#)}(hhh]j()}(hX``struct scsi_device *sdev`` The device to validate Identical to spi_dv_device() above, except that the DV will be scheduled to occur in a workqueue later. All memory allocations are atomic, so may be called from any context including those holding SCSI locks.h](j.)}(h``struct scsi_device *sdev``h]j4)}(hjs|h]hstruct scsi_device *sdev}(hju|hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjq|ubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chMDhjm|ubjJ)}(hhh](h)}(hThe device to validateh]hThe device to validate}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chM@hj|ubh)}(hIdentical to spi_dv_device() above, except that the DV will be scheduled to occur in a workqueue later. All memory allocations are atomic, so may be called from any context including those holding SCSI locks.h]hIdentical to spi_dv_device() above, except that the DV will be scheduled to occur in a workqueue later. All memory allocations are atomic, so may be called from any context including those holding SCSI locks.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:291: ./drivers/scsi/scsi_transport_spi.chMBhj|ubeh}(h]h ]h"]h$]h&]uh1jIhjm|ubeh}(h]h ]h"]h$]h&]uh1j'hj|hMDhjj|ubah}(h]h ]h"]h$]h&]uh1j"hjN|ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjyhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@'spi_display_xfer_agreement (C function)c.spi_display_xfer_agreementhNtauh1j3hjyhhhNhNubjE)}(hhh](jJ)}(h=void spi_display_xfer_agreement (struct scsi_target *starget)h]jP)}(h(int reconnect_delay, int fast_io_fail_tmo, long dev_loss_tmo)h](j)}(hint reconnect_delayh](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj߀ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj߀ubj)}(hreconnect_delayh]hreconnect_delay}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj߀ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjۀubj)}(hint fast_io_fail_tmoh](j~)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjubjh)}(h h]h }(hj&hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj)}(hfast_io_fail_tmoh]hfast_io_fail_tmo}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjۀubj)}(hlong dev_loss_tmoh](j~)}(hlongh]hlong}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjIubjh)}(h h]h }(hj[hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjIubj)}(h dev_loss_tmoh]h dev_loss_tmo}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjIubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjۀubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKHubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhKHubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhKHhjhhubj)}(hhh]h)}(h"check timeout combination validityh]h"check timeout combination validity}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chKHhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKHubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjnhNhNubj)}(hX**Parameters** ``int reconnect_delay`` Reconnect delay in seconds. ``int fast_io_fail_tmo`` Fast I/O fail timeout in seconds. ``long dev_loss_tmo`` Device loss timeout in seconds. **Description** The combination of the timeout parameters must be such that SCSI commands are finished in a reasonable time. Hence do not allow the fast I/O fail timeout to exceed SCSI_DEVICE_BLOCK_MAX_TIMEOUT nor allow dev_loss_tmo to exceed that limit if failing I/O fast has been disabled. Furthermore, these parameters must be such that multipath can detect failed paths timely. Hence do not allow all three parameters to be disabled simultaneously.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chKLhjubj#)}(hhh](j()}(h4``int reconnect_delay`` Reconnect delay in seconds. h](j.)}(h``int reconnect_delay``h]j4)}(hjԁh]hint reconnect_delay}(hjցhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjҁubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chKIhj΁ubjJ)}(hhh]h)}(hReconnect delay in seconds.h]hReconnect delay in seconds.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKIhjubah}(h]h ]h"]h$]h&]uh1jIhj΁ubeh}(h]h ]h"]h$]h&]uh1j'hjhKIhjˁubj()}(h;``int fast_io_fail_tmo`` Fast I/O fail timeout in seconds. h](j.)}(h``int fast_io_fail_tmo``h]j4)}(hj h]hint fast_io_fail_tmo}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chKJhjubjJ)}(hhh]h)}(h!Fast I/O fail timeout in seconds.h]h!Fast I/O fail timeout in seconds.}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hKJhj#ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj"hKJhjˁubj()}(h6``long dev_loss_tmo`` Device loss timeout in seconds. h](j.)}(h``long dev_loss_tmo``h]j4)}(hjFh]hlong dev_loss_tmo}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjDubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chKKhj@ubjJ)}(hhh]h)}(hDevice loss timeout in seconds.h]hDevice loss timeout in seconds.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hKKhj\ubah}(h]h ]h"]h$]h&]uh1jIhj@ubeh}(h]h ]h"]h$]h&]uh1j'hj[hKKhjˁubeh}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chKMhjubh)}(hXThe combination of the timeout parameters must be such that SCSI commands are finished in a reasonable time. Hence do not allow the fast I/O fail timeout to exceed SCSI_DEVICE_BLOCK_MAX_TIMEOUT nor allow dev_loss_tmo to exceed that limit if failing I/O fast has been disabled. Furthermore, these parameters must be such that multipath can detect failed paths timely. Hence do not allow all three parameters to be disabled simultaneously.h]hXThe combination of the timeout parameters must be such that SCSI commands are finished in a reasonable time. Hence do not allow the fast I/O fail timeout to exceed SCSI_DEVICE_BLOCK_MAX_TIMEOUT nor allow dev_loss_tmo to exceed that limit if failing I/O fast has been disabled. Furthermore, these parameters must be such that multipath can detect failed paths timely. Hence do not allow all three parameters to be disabled simultaneously.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chKMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@%srp_start_tl_fail_timers (C function)c.srp_start_tl_fail_timershNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(h7void srp_start_tl_fail_timers (struct srp_rport *rport)h]jP)}(h6void srp_start_tl_fail_timers(struct srp_rport *rport)h](j~)}(hvoidh]hvoid}(hjƂhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj‚hhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMubjh)}(h h]h }(hjՂhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj‚hhhjԂhMubjy)}(hsrp_start_tl_fail_timersh]j)}(hsrp_start_tl_fail_timersh]hsrp_start_tl_fail_timers}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj‚hhhjԂhMubj)}(h(struct srp_rport *rport)h]j)}(hstruct srp_rport *rporth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h srp_rporth]h srp_rport}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj#modnameN classnameNjj)}j]j)}jjsbc.srp_start_tl_fail_timersasbuh1hhjubjh)}(h h]h }(hjAhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjOhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hrporth]hrport}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhj‚hhhjԂhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjԂhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjԂhMhjhhubj)}(hhh]h)}(h(start the transport layer failure timersh]h(start the transport layer failure timers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjԂhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjnhNhNubj)}(h**Parameters** ``struct srp_rport *rport`` SRP target port. **Description** Start the transport layer fast I/O failure and device loss timers. Do not modify a timer that was already started.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubj#)}(hhh]j()}(h-``struct srp_rport *rport`` SRP target port. h](j.)}(h``struct srp_rport *rport``h]j4)}(hjǃh]hstruct srp_rport *rport}(hjɃhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjŃubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubjJ)}(hhh]h)}(hSRP target port.h]hSRP target port.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj܃hMhj݃ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj܃hMhjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubh)}(hrStart the transport layer fast I/O failure and device loss timers. Do not modify a timer that was already started.h]hrStart the transport layer fast I/O failure and device loss timers. Do not modify a timer that was already started.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@ srp_reconnect_rport (C function)c.srp_reconnect_rporthNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(h1int srp_reconnect_rport (struct srp_rport *rport)h]jP)}(h0int srp_reconnect_rport(struct srp_rport *rport)h](j~)}(hinth]hint}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjChhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMubjh)}(h h]h }(hjVhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjChhhjUhMubjy)}(hsrp_reconnect_rporth]j)}(hsrp_reconnect_rporth]hsrp_reconnect_rport}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjdubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjChhhjUhMubj)}(h(struct srp_rport *rport)h]j)}(hstruct srp_rport *rporth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h srp_rporth]h srp_rport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjjsbc.srp_reconnect_rportasbuh1hhjubjh)}(h h]h }(hj„hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjЄhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hrporth]hrport}(hj݄hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|ubah}(h]h ]h"]h$]h&]jjuh1jhjChhhjUhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhj?hhhjUhMubah}(h]j:ah ](jjeh"]h$]h&]jj)jhuh1jIhjUhMhj<hhubj)}(hhh]h)}(hreconnect to an SRP target porth]hreconnect to an SRP target port}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj<hhhjUhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjnhNhNubj)}(hX%**Parameters** ``struct srp_rport *rport`` SRP target port. **Description** Blocks SCSI command queueing before invoking reconnect() such that queuecommand() won't be invoked concurrently with reconnect() from outside the SCSI EH. This is important since a reconnect() implementation may reallocate resources needed by queuecommand(). **Notes** - This function neither waits until outstanding requests have finished nor tries to abort these. It is the responsibility of the reconnect() function to finish outstanding commands before reconnecting to the target port. - It is the responsibility of the caller to ensure that the resources reallocated by the reconnect() function won't be used while this function is in progress. One possible strategy is to invoke this function from the context of the SCSI EH thread only. Another possible strategy is to lock the rport mutex inside each SCSI LLD callback that can be invoked by the SCSI EH (the scsi_host_template.eh_*() functions and also the scsi_host_template.queuecommand() function).h](h)}(h**Parameters**h]j)}(hj)h]h Parameters}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj#ubj#)}(hhh]j()}(h-``struct srp_rport *rport`` SRP target port. h](j.)}(h``struct srp_rport *rport``h]j4)}(hjHh]hstruct srp_rport *rport}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjFubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjBubjJ)}(hhh]h)}(hSRP target port.h]hSRP target port.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hMhj^ubah}(h]h ]h"]h$]h&]uh1jIhjBubeh}(h]h ]h"]h$]h&]uh1j'hj]hMhj?ubah}(h]h ]h"]h$]h&]uh1j"hj#ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj#ubh)}(hXBlocks SCSI command queueing before invoking reconnect() such that queuecommand() won't be invoked concurrently with reconnect() from outside the SCSI EH. This is important since a reconnect() implementation may reallocate resources needed by queuecommand().h]hXBlocks SCSI command queueing before invoking reconnect() such that queuecommand() won’t be invoked concurrently with reconnect() from outside the SCSI EH. This is important since a reconnect() implementation may reallocate resources needed by queuecommand().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj#ubh)}(h **Notes**h]j)}(hjh]hNotes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj#ubj3_)}(hhh](j8_)}(hThis function neither waits until outstanding requests have finished nor tries to abort these. It is the responsibility of the reconnect() function to finish outstanding commands before reconnecting to the target port.h]h)}(hThis function neither waits until outstanding requests have finished nor tries to abort these. It is the responsibility of the reconnect() function to finish outstanding commands before reconnecting to the target port.h]hThis function neither waits until outstanding requests have finished nor tries to abort these. It is the responsibility of the reconnect() function to finish outstanding commands before reconnecting to the target port.}(hjDžhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjÅubah}(h]h ]h"]h$]h&]uh1j7_hjubj8_)}(hXIt is the responsibility of the caller to ensure that the resources reallocated by the reconnect() function won't be used while this function is in progress. One possible strategy is to invoke this function from the context of the SCSI EH thread only. Another possible strategy is to lock the rport mutex inside each SCSI LLD callback that can be invoked by the SCSI EH (the scsi_host_template.eh_*() functions and also the scsi_host_template.queuecommand() function).h]h)}(hXIt is the responsibility of the caller to ensure that the resources reallocated by the reconnect() function won't be used while this function is in progress. One possible strategy is to invoke this function from the context of the SCSI EH thread only. Another possible strategy is to lock the rport mutex inside each SCSI LLD callback that can be invoked by the SCSI EH (the scsi_host_template.eh_*() functions and also the scsi_host_template.queuecommand() function).h]hXIt is the responsibility of the caller to ensure that the resources reallocated by the reconnect() function won’t be used while this function is in progress. One possible strategy is to invoke this function from the context of the SCSI EH thread only. Another possible strategy is to lock the rport mutex inside each SCSI LLD callback that can be invoked by the SCSI EH (the scsi_host_template.eh_*() functions and also the scsi_host_template.queuecommand() function).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chM hj܅ubah}(h]h ]h"]h$]h&]uh1j7_hjubeh}(h]h ]h"]h$]h&]j_-uh1j2_hjՅhMhj#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@srp_timed_out (C function)c.srp_timed_outhNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(h?enum scsi_timeout_action srp_timed_out (struct scsi_cmnd *scmd)h]jP)}(h>enum scsi_timeout_action srp_timed_out(struct scsi_cmnd *scmd)h](jV)}(hj7h]henum}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMQubjh)}(h h]h }(hj*hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhj)hMQubh)}(hhh]j)}(hscsi_timeout_actionh]hscsi_timeout_action}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj8ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj=modnameN classnameNjj)}j]j)}j srp_timed_outsbc.srp_timed_outasbuh1hhjhhhj)hMQubjh)}(h h]h }(hj\hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhj)hMQubjy)}(h srp_timed_outh]j)}(hjYh]h srp_timed_out}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhj)hMQubj)}(h(struct scsi_cmnd *scmd)h]j)}(hstruct scsi_cmnd *scmdh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h scsi_cmndh]h scsi_cmnd}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jWc.srp_timed_outasbuh1hhjubjh)}(h h]h }(hjņhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjӆhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hscmdh]hscmd}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhj)hMQubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhj)hMQubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhj)hMQhjhhubj)}(hhh]h)}(h.SRP transport intercept of the SCSI timeout EHh]h.SRP transport intercept of the SCSI timeout EH}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMQhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj)hMQubeh}(h]h ](jfunctioneh"]h$]h&]jjjj"jj"jjjuh1jDhhhjnhNhNubj)}(hXh**Parameters** ``struct scsi_cmnd *scmd`` SCSI command. **Description** If a timeout occurs while an rport is in the blocked state, ask the SCSI EH to continue waiting (SCSI_EH_RESET_TIMER). Otherwise let the SCSI core handle the timeout (SCSI_EH_NOT_HANDLED). **Note** This function is called from soft-IRQ context and with the request queue lock held.h](h)}(h**Parameters**h]j)}(hj,h]h Parameters}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMUhj&ubj#)}(hhh]j()}(h)``struct scsi_cmnd *scmd`` SCSI command. h](j.)}(h``struct scsi_cmnd *scmd``h]j4)}(hjKh]hstruct scsi_cmnd *scmd}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjIubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMRhjEubjJ)}(hhh]h)}(h SCSI command.h]h SCSI command.}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hMRhjaubah}(h]h ]h"]h$]h&]uh1jIhjEubeh}(h]h ]h"]h$]h&]uh1j'hj`hMRhjBubah}(h]h ]h"]h$]h&]uh1j"hj&ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMThj&ubh)}(hIf a timeout occurs while an rport is in the blocked state, ask the SCSI EH to continue waiting (SCSI_EH_RESET_TIMER). Otherwise let the SCSI core handle the timeout (SCSI_EH_NOT_HANDLED).h]hIf a timeout occurs while an rport is in the blocked state, ask the SCSI EH to continue waiting (SCSI_EH_RESET_TIMER). Otherwise let the SCSI core handle the timeout (SCSI_EH_NOT_HANDLED).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMThj&ubh)}(h**Note**h]j)}(hjh]hNote}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMXhj&ubh)}(hSThis function is called from soft-IRQ context and with the request queue lock held.h]hSThis function is called from soft-IRQ context and with the request queue lock held.}(hjÇhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMXhj&ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@srp_rport_get (C function)c.srp_rport_gethNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(h,void srp_rport_get (struct srp_rport *rport)h]jP)}(h+void srp_rport_get(struct srp_rport *rport)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMubjy)}(h srp_rport_geth]j)}(h srp_rport_geth]h srp_rport_get}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMubj)}(h(struct srp_rport *rport)h]j)}(hstruct srp_rport *rporth](jV)}(hjYh]hstruct}(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj+ubjh)}(h h]h }(hj<hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj+ubh)}(hhh]j)}(h srp_rporth]h srp_rport}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjJubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjOmodnameN classnameNjj)}j]j)}jjsbc.srp_rport_getasbuh1hhj+ubjh)}(h h]h }(hjmhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj+ubj )}(hj h]h*}(hj{hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj+ubj)}(hrporth]hrport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj+ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj'ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjhhubj)}(hhh]h)}(hincrement rport reference counth]hincrement rport reference count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjʈjjʈjjjuh1jDhhhjnhNhNubj)}(h>**Parameters** ``struct srp_rport *rport`` SRP target port.h](h)}(h**Parameters**h]j)}(hjԈh]h Parameters}(hjֈhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj҈ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjΈubj#)}(hhh]j()}(h,``struct srp_rport *rport`` SRP target port.h](j.)}(h``struct srp_rport *rport``h]j4)}(hjh]hstruct srp_rport *rport}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubjJ)}(hhh]h)}(hSRP target port.h]hSRP target port.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubah}(h]h ]h"]h$]h&]uh1j"hjΈubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@srp_rport_put (C function)c.srp_rport_puthNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(h,void srp_rport_put (struct srp_rport *rport)h]jP)}(h+void srp_rport_put(struct srp_rport *rport)h](j~)}(hvoidh]hvoid}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjIhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMubjh)}(h h]h }(hj\hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjIhhhj[hMubjy)}(h srp_rport_puth]j)}(h srp_rport_puth]h srp_rport_put}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjIhhhj[hMubj)}(h(struct srp_rport *rport)h]j)}(hstruct srp_rport *rporth](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h srp_rporth]h srp_rport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjpsbc.srp_rport_putasbuh1hhjubjh)}(h h]h }(hjȉhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hj։hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hrporth]hrport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjIhhhj[hMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjEhhhj[hMubah}(h]j@ah ](jjeh"]h$]h&]jj)jhuh1jIhj[hMhjBhhubj)}(hhh]h)}(hdecrement rport reference counth]hdecrement rport reference count}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj hhubah}(h]h ]h"]h$]h&]uh1jhjBhhhj[hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj%jj%jjjuh1jDhhhjnhNhNubj)}(h>**Parameters** ``struct srp_rport *rport`` SRP target port.h](h)}(h**Parameters**h]j)}(hj/h]h Parameters}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj)ubj#)}(hhh]j()}(h,``struct srp_rport *rport`` SRP target port.h](j.)}(h``struct srp_rport *rport``h]j4)}(hjNh]hstruct srp_rport *rport}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjLubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjHubjJ)}(hhh]h)}(hSRP target port.h]hSRP target port.}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjdubah}(h]h ]h"]h$]h&]uh1jIhjHubeh}(h]h ]h"]h$]h&]uh1j'hjchMhjEubah}(h]h ]h"]h$]h&]uh1j"hj)ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@srp_rport_add (C function)c.srp_rport_addhNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(h]struct srp_rport * srp_rport_add (struct Scsi_Host *shost, struct srp_rport_identifiers *ids)h]jP)}(h[struct srp_rport *srp_rport_add(struct Scsi_Host *shost, struct srp_rport_identifiers *ids)h](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMubh)}(hhh]j)}(h srp_rporth]h srp_rport}(hjNJhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjĊubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjɊmodnameN classnameNjj)}j]j)}j srp_rport_addsbc.srp_rport_addasbuh1hhjhhhjhMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjhhhjhMubjy)}(h srp_rport_addh]j)}(hjh]h srp_rport_add}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMubj)}(h<(struct Scsi_Host *shost, struct srp_rport_identifiers *ids)h](j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hj/hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj=ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjBmodnameN classnameNjj)}j]jc.srp_rport_addasbuh1hhjubjh)}(h h]h }(hj^hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjlhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hshosth]hshost}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h!struct srp_rport_identifiers *idsh](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hsrp_rport_identifiersh]hsrp_rport_identifiers}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.srp_rport_addasbuh1hhjubjh)}(h h]h }(hj΋hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hj܋hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hidsh]hids}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjhhubj)}(hhh]h)}(h-add a SRP remote port to the device hierarchyh]h-add a SRP remote port to the device hierarchy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj+jj+jjjuh1jDhhhjnhNhNubj)}(h**Parameters** ``struct Scsi_Host *shost`` scsi host the remote port is connected to. ``struct srp_rport_identifiers *ids`` The port id for the remote port. **Description** Publishes a port to the rest of the system.h](h)}(h**Parameters**h]j)}(hj5h]h Parameters}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj/ubj#)}(hhh](j()}(hG``struct Scsi_Host *shost`` scsi host the remote port is connected to. h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjTh]hstruct Scsi_Host *shost}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjRubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjNubjJ)}(hhh]h)}(h*scsi host the remote port is connected to.h]h*scsi host the remote port is connected to.}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjjubah}(h]h ]h"]h$]h&]uh1jIhjNubeh}(h]h ]h"]h$]h&]uh1j'hjihMhjKubj()}(hG``struct srp_rport_identifiers *ids`` The port id for the remote port. h](j.)}(h%``struct srp_rport_identifiers *ids``h]j4)}(hjh]h!struct srp_rport_identifiers *ids}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubjJ)}(hhh]h)}(h The port id for the remote port.h]h The port id for the remote port.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjKubeh}(h]h ]h"]h$]h&]uh1j"hj/ubh)}(h**Description**h]j)}(hjȌh]h Description}(hjʌhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjƌubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj/ubh)}(h+Publishes a port to the rest of the system.h]h+Publishes a port to the rest of the system.}(hjތhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj/ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@srp_rport_del (C function)c.srp_rport_delhNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(h,void srp_rport_del (struct srp_rport *rport)h]jP)}(h+void srp_rport_del(struct srp_rport *rport)h](j~)}(hvoidh]hvoid}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj hhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj hhhjhMubjy)}(h srp_rport_delh]j)}(h srp_rport_delh]h srp_rport_del}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj*ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj hhhjhMubj)}(h(struct srp_rport *rport)h]j)}(hstruct srp_rport *rporth](jV)}(hjYh]hstruct}(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubjh)}(h h]h }(hjWhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjFubh)}(hhh]j)}(h srp_rporth]h srp_rport}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjeubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjmodnameN classnameNjj)}j]j)}jj0sbc.srp_rport_delasbuh1hhjFubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjFubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjFubj)}(hrporth]hrport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjFubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubah}(h]h ]h"]h$]h&]jjuh1jhj hhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjhhubj)}(hhh]h)}(hremove a SRP remote porth]hremove a SRP remote port}(hj͍hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjʍhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjnhNhNubj)}(h**Parameters** ``struct srp_rport *rport`` SRP remote port to remove **Description** Removes the specified SRP remote port.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubj#)}(hhh]j()}(h6``struct srp_rport *rport`` SRP remote port to remove h](j.)}(h``struct srp_rport *rport``h]j4)}(hjh]hstruct srp_rport *rport}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj ubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubjJ)}(hhh]h)}(hSRP remote port to removeh]hSRP remote port to remove}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hMhj$ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hj#hMhjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjIh]h Description}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubh)}(h&Removes the specified SRP remote port.h]h&Removes the specified SRP remote port.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@srp_remove_host (C function)c.srp_remove_hosthNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(h.void srp_remove_host (struct Scsi_Host *shost)h]jP)}(h-void srp_remove_host(struct Scsi_Host *shost)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hjhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhMubjy)}(hsrp_remove_hosth]j)}(hsrp_remove_hosth]hsrp_remove_host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhMubj)}(h(struct Scsi_Host *shost)h]j)}(hstruct Scsi_Host *shosth](jV)}(hjYh]hstruct}(hjˎhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjǎubjh)}(h h]h }(hj؎hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjǎubh)}(hhh]j)}(h Scsi_Hosth]h Scsi_Host}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsbc.srp_remove_hostasbuh1hhjǎubjh)}(h h]h }(hj hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjǎubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjǎubj)}(hshosth]hshost}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjǎubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjÎubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjhhubj)}(hhh]h)}(h+tear down a Scsi_Host's SRP data structuresh]h-tear down a Scsi_Host’s SRP data structures}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjKhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjfjjfjjjuh1jDhhhjnhNhNubj)}(h**Parameters** ``struct Scsi_Host *shost`` Scsi Host that is torn down **Description** Removes all SRP remote ports for a given Scsi_Host. Must be called just before scsi_remove_host for SRP HBAs.h](h)}(h**Parameters**h]j)}(hjph]h Parameters}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chM hjjubj#)}(hhh]j()}(h8``struct Scsi_Host *shost`` Scsi Host that is torn down h](j.)}(h``struct Scsi_Host *shost``h]j4)}(hjh]hstruct Scsi_Host *shost}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubjJ)}(hhh]h)}(hScsi Host that is torn downh]hScsi Host that is torn down}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j'hjhMhjubah}(h]h ]h"]h$]h&]uh1j"hjjubh)}(h**Description**h]j)}(hjʏh]h Description}(hj̏hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjȏubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjjubh)}(hmRemoves all SRP remote ports for a given Scsi_Host. Must be called just before scsi_remove_host for SRP HBAs.h]hmRemoves all SRP remote ports for a given Scsi_Host. Must be called just before scsi_remove_host for SRP HBAs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"srp_stop_rport_timers (C function)c.srp_stop_rport_timershNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(h4void srp_stop_rport_timers (struct srp_rport *rport)h]jP)}(h3void srp_stop_rport_timers(struct srp_rport *rport)h](j~)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj hhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj hhhjhMubjy)}(hsrp_stop_rport_timersh]j)}(hsrp_stop_rport_timersh]hsrp_stop_rport_timers}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj,ubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj hhhjhMubj)}(h(struct srp_rport *rport)h]j)}(hstruct srp_rport *rporth](jV)}(hjYh]hstruct}(hjLhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHubjh)}(h h]h }(hjYhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjHubh)}(hhh]j)}(h srp_rporth]h srp_rport}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjgubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjlmodnameN classnameNjj)}j]j)}jj2sbc.srp_stop_rport_timersasbuh1hhjHubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjHubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjHubj)}(hrporth]hrport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjHubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjDubah}(h]h ]h"]h$]h&]jjuh1jhj hhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhMhjhhubj)}(hhh]h)}(h(stop the transport layer recovery timersh]h(stop the transport layer recovery timers}(hjϐhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj̐hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjnhNhNubj)}(hX**Parameters** ``struct srp_rport *rport`` SRP remote port for which to stop the timers. **Description** Must be called after srp_remove_host() and scsi_remove_host(). The caller must hold a reference on the rport (rport->dev) and on the SCSI host (rport->dev.parent).h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubj#)}(hhh]j()}(hJ``struct srp_rport *rport`` SRP remote port for which to stop the timers. h](j.)}(h``struct srp_rport *rport``h]j4)}(hjh]hstruct srp_rport *rport}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhj ubjJ)}(hhh]h)}(h-SRP remote port for which to stop the timers.h]h-SRP remote port for which to stop the timers.}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hMhj&ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj%hMhjubah}(h]h ]h"]h$]h&]uh1j"hjubh)}(h**Description**h]j)}(hjKh]h Description}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubh)}(hMust be called after srp_remove_host() and scsi_remove_host(). The caller must hold a reference on the rport (rport->dev) and on the SCSI host (rport->dev.parent).h]hMust be called after srp_remove_host() and scsi_remove_host(). The caller must hold a reference on the rport (rport->dev) and on the SCSI host (rport->dev.parent).}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@!srp_attach_transport (C function)c.srp_attach_transporthNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(hXstruct scsi_transport_template * srp_attach_transport (struct srp_function_template *ft)h]jP)}(hVstruct scsi_transport_template *srp_attach_transport(struct srp_function_template *ft)h](jV)}(hjYh]hstruct}(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chM(ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM(ubh)}(hhh]j)}(hscsi_transport_templateh]hscsi_transport_template}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jsrp_attach_transportsbc.srp_attach_transportasbuh1hhjhhhjhM(ubjh)}(h h]h }(hjБhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjhhhjhM(ubj )}(hj h]h*}(hjޑhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjhhhjhM(ubjy)}(hsrp_attach_transporth]j)}(hj͑h]hsrp_attach_transport}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubah}(h]h ](jjeh"]h$]h&]jjuh1jxhjhhhjhM(ubj)}(h"(struct srp_function_template *ft)h]j)}(h struct srp_function_template *fth](jV)}(hjYh]hstruct}(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubh)}(hhh]j)}(hsrp_function_templateh]hsrp_function_template}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj%ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*modnameN classnameNjj)}j]jˑc.srp_attach_transportasbuh1hhjubjh)}(h h]h }(hjFhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghjubj )}(hj h]h*}(hjThhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hfth]hft}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM(ubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhjhM(ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhjhM(hjhhubj)}(hhh]h)}(h"instantiate SRP transport templateh]h"instantiate SRP transport template}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chM(hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM(ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjnhNhNubj)}(h\**Parameters** ``struct srp_function_template *ft`` SRP transport class function templateh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chM,hjubj#)}(hhh]j()}(hJ``struct srp_function_template *ft`` SRP transport class function templateh](j.)}(h$``struct srp_function_template *ft``h]j4)}(hj̒h]h struct srp_function_template *ft}(hjΒhhhNhNubah}(h]h ]h"]h$]h&]uh1j3hjʒubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chM.hjƒubjJ)}(hhh]h)}(h%SRP transport class function templateh]h%SRP transport class function template}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chM)hjubah}(h]h ]h"]h$]h&]uh1jIhjƒubeh}(h]h ]h"]h$]h&]uh1j'hjhM.hjÒubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubj4)}(hhh]h}(h]h ]h"]h$]h&]entries](j@"srp_release_transport (C function)c.srp_release_transporthNtauh1j3hjnhhhNhNubjE)}(hhh](jJ)}(h>void srp_release_transport (struct scsi_transport_template *t)h]jP)}(h=void srp_release_transport(struct scsi_transport_template *t)h](j~)}(hvoidh]hvoid}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1j}hj"hhhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMZubjh)}(h h]h }(hj5hhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj"hhhj4hMZubjy)}(hsrp_release_transporth]j)}(hsrp_release_transporth]hsrp_release_transport}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hjCubah}(h]h ](jjeh"]h$]h&]jjuh1jxhj"hhhj4hMZubj)}(h#(struct scsi_transport_template *t)h]j)}(h!struct scsi_transport_template *th](jV)}(hjYh]hstruct}(hjchhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubjh)}(h h]h }(hjphhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj_ubh)}(hhh]j)}(hscsi_transport_templateh]hscsi_transport_template}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj~ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)}jjIsbc.srp_release_transportasbuh1hhj_ubjh)}(h h]h }(hjhhhNhNubah}(h]h ]jtah"]h$]h&]uh1jghj_ubj )}(hj h]h*}(hjhhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj_ubj)}(hjxh]ht}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1j~hj_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj[ubah}(h]h ]h"]h$]h&]jjuh1jhj"hhhj4hMZubeh}(h]h ]h"]h$]h&]jjjuh1jOjjhjhhhj4hMZubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jIhj4hMZhjhhubj)}(hhh]h)}(h'release SRP transport template instanceh]h'release SRP transport template instance}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chMZhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj4hMZubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1jDhhhjnhNhNubj)}(hS**Parameters** ``struct scsi_transport_template *t`` transport template instanceh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chM^hjubj#)}(hhh]j()}(hA``struct scsi_transport_template *t`` transport template instanceh](j.)}(h%``struct scsi_transport_template *t``h]j4)}(hj&h]h!struct scsi_transport_template *t}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1j3hj$ubah}(h]h ]h"]h$]h&]uh1j-hb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chM`hj ubjJ)}(hhh]h)}(htransport template instanceh]htransport template instance}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/driver-api/scsi:300: ./drivers/scsi/scsi_transport_srp.chM[hj<ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j'hj;hM`hjubah}(h]h ]h"]h$]h&]uh1j"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjnhhhNhNubeh}(h]scsi-rdma-srp-transport-classah ]h"]scsi rdma (srp) transport classah$]h&]uh1hhjhhhhhM'ubeh}(h]transport-classesah ]h"]transport classesah$]h&]uh1hhjhhhhhKubeh}(h]scsi-mid-layerah ]h"]scsi mid layerah$]h&]uh1hhhhhhhhKUubh)}(hhh](h)}(hSCSI lower layerh]hSCSI lower layer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhM0ubh)}(hhh](h)}(h Host Bus Adapter transport typesh]h Host Bus Adapter transport types}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhM3ubh)}(hMany modern device controllers use the SCSI command set as a protocol to communicate with their devices through many different types of physical connections.h]hMany modern device controllers use the SCSI command set as a protocol to communicate with their devices through many different types of physical connections.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM5hjhhubh)}(hIn SCSI language a bus capable of carrying SCSI commands is called a "transport", and a controller connecting to such a bus is called a "host bus adapter" (HBA).h]hIn SCSI language a bus capable of carrying SCSI commands is called a “transport”, and a controller connecting to such a bus is called a “host bus adapter” (HBA).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM9hjhhubh)}(hhh](h)}(hDebug transporth]hDebug transport}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhM>ubh)}(hX(The file drivers/scsi/scsi_debug.c simulates a host adapter with a variable number of disks (or disk like devices) attached, sharing a common amount of RAM. Does a lot of checking to make sure that we are not getting blocks mixed up, and panics the kernel if anything out of the ordinary is seen.h]hX(The file drivers/scsi/scsi_debug.c simulates a host adapter with a variable number of disks (or disk like devices) attached, sharing a common amount of RAM. Does a lot of checking to make sure that we are not getting blocks mixed up, and panics the kernel if anything out of the ordinary is seen.}(hjΔhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM@hjhhubh)}(hWTo be more realistic, the simulated devices have the transport attributes of SAS disks.h]hWTo be more realistic, the simulated devices have the transport attributes of SAS disks.}(hjܔhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMFhjhhubh)}(h;For documentation see http://sg.danny.cz/sg/scsi_debug.htmlh](hFor documentation see }(hjhhhNhNubjn)}(h%http://sg.danny.cz/sg/scsi_debug.htmlh]h%http://sg.danny.cz/sg/scsi_debug.html}(hjhhhNhNubah}(h]h ]h"]h$]h&]refurijuh1jmhjubeh}(h]h ]h"]h$]h&]uh1hhhhMIhjhhubeh}(h]debug-transportah ]h"]debug transportah$]h&]uh1hhjhhhhhM>ubh)}(hhh](h)}(htodoh]htodo}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhMLubh)}(hParallel (fast/wide/ultra) SCSI, USB, SATA, SAS, Fibre Channel, FireWire, ATAPI devices, Infiniband, Parallel ports, netlink...h]hParallel (fast/wide/ultra) SCSI, USB, SATA, SAS, Fibre Channel, FireWire, ATAPI devices, Infiniband, Parallel ports, netlink...}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMNhjhhubeh}(h]todoah ]h"]todoah$]h&]uh1hhjhhhhhMLubeh}(h] host-bus-adapter-transport-typesah ]h"] host bus adapter transport typesah$]h&]uh1hhjhhhhhM3ubeh}(h]scsi-lower-layerah ]h"]scsi lower layerah$]h&]uh1hhhhhhhhM0ubeh}(h]scsi-interfaces-guideah ]h"]scsi interfaces guideah$]h&]uh1hhhhhhhhKubeh}(h]h ]h"]h$]h&]sourcehuh1hcurrent_sourceN current_lineNsettingsdocutils.frontendValues)}(hN generatorN datestampN source_linkN source_urlN toc_backlinksentryfootnote_backlinksK sectnum_xformKstrip_commentsNstrip_elements_with_classesN strip_classesN report_levelK halt_levelKexit_status_levelKdebugNwarning_streamN tracebackinput_encoding utf-8-siginput_encoding_error_handlerstrictoutput_encodingutf-8output_encoding_error_handlerjqerror_encodingutf-8error_encoding_error_handlerbackslashreplace language_codeenrecord_dependenciesNconfigN id_prefixhauto_id_prefixid dump_settingsNdump_internalsNdump_transformsNdump_pseudo_xmlNexpose_internalsNstrict_visitorN_disable_configN_sourceh _destinationN _config_files]7/var/lib/git/docbuild/linux/Documentation/docutils.confafile_insertion_enabled raw_enabledKline_length_limitM'pep_referencesN pep_base_urlhttps://peps.python.org/pep_file_url_templatepep-%04drfc_referencesN rfc_base_url&https://datatracker.ietf.org/doc/html/ tab_widthKtrim_footnote_reference_spacesyntax_highlightlong smart_quotessmartquotes_locales]character_level_inline_markupdoctitle_xform docinfo_xformKsectsubtitle_xform image_loadinglinkembed_stylesheetcloak_email_addressessection_self_linkenvNubreporterNindirect_targets]substitution_defs}substitution_names}refnames}refids}nameids}(jKjHjjjjj jjjjYjVjj}jjjjjjj|jyjjj j j+j+j4j4j QjQj7]j4]jgjgjIjFjLjIj[jXjGjDjkjhjjjjjjjjjtjqjm&jj&jCjCjyjyjyjyjkjhjljijCj@j;j8j j j3j0u nametypes}(jKjjj jjYjjjjj|jj j+j4j Qj7]jgjIjLj[jGjkjjjjjtjm&jCjyjyjkjljCj;j j3uh}(jHhjj'jj8jjjjjVj5j}j\jjjjjjjyjjjj j"jBjKjj jjjpjuj+j jI jN j8 j= j/j4jHjMj4j9jjjEjJjjjjj}"j"j$j$jz(j(j4j+j',j,,jF.jK.j<1jA1jQj4j24j74j5j5jx7j}7j9j9j=j=j?j?jAjBjDjDjGjGjHjHjuKjzKjhNjmNj4]j Qj8Qj=QjUjUjYjYj[j[jgj:]je]jj]j_j_jajbj@ejEejFjgjgjgjrijwijnjnjpjqjtjtjujujMwjRwjxjxjF~jK~j-j2jj j j%j3j8jLjQjӏj؏j[j`jԒjْjjjޖjjOjTjߚjjjj"j'jjšjjjIjLjwj|jjjXjOjzjj@jEjjjjjjj^jcjjjԵjٵjjj»jǻj4j9j^jcj`jejDj^jjjJjOjLjQjhjJjujzjZj_jjjjjjnjjjjjj jjjjjj#jCjHjjjjjQjVjjjj j\jajjjjjjj2j7jxj}jwj|jjjjjjjjj^jcjqjjj&jjjjajfjjj j j5 j: j{jjjjpjujzjjjjjjBjGj j j!j!j$j$jCjp&j&j&j/(j4(j+j+jr/jw/j2j2j4j4j6j 6j7j7j 9j9j:j:j <j<j>j>j@j@jAjAjyjCjCjCj\EjaEjGj GjHjHj5Jj:JjKjKj7Mj