'the' has a tendency to double up; squash them back down. Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com> Reviewed-by: Alex Bennée <alex.bennee@linaro.org> Reviewed-by: Laurent Vivier <laurent@vivier.eu> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Message-Id: <20191104185202.102504-1-dgilbert@redhat.com> [lv: removed disas/libvixl/vixl/invalset.h change] Signed-off-by: Laurent Vivier <laurent@vivier.eu>
		
			
				
	
	
		
			84 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| ..
 | |
| 
 | |
| ======================================
 | |
| Persistent reservation helper protocol
 | |
| ======================================
 | |
| 
 | |
| QEMU's SCSI passthrough devices, ``scsi-block`` and ``scsi-generic``,
 | |
| can delegate implementation of persistent reservations to an external
 | |
| (and typically privileged) program.  Persistent Reservations allow
 | |
| restricting access to block devices to specific initiators in a shared
 | |
| storage setup.
 | |
| 
 | |
| For a more detailed reference please refer to the SCSI Primary
 | |
| Commands standard, specifically the section on Reservations and the
 | |
| "PERSISTENT RESERVE IN" and "PERSISTENT RESERVE OUT" commands.
 | |
| 
 | |
| This document describes the socket protocol used between QEMU's
 | |
| ``pr-manager-helper`` object and the external program.
 | |
| 
 | |
| .. contents::
 | |
| 
 | |
| Connection and initialization
 | |
| -----------------------------
 | |
| 
 | |
| All data transmitted on the socket is big-endian.
 | |
| 
 | |
| After connecting to the helper program's socket, the helper starts a simple
 | |
| feature negotiation process by writing four bytes corresponding to
 | |
| the features it exposes (``supported_features``).  QEMU reads it,
 | |
| then writes four bytes corresponding to the desired features of the
 | |
| helper program (``requested_features``).
 | |
| 
 | |
| If a bit is 1 in ``requested_features`` and 0 in ``supported_features``,
 | |
| the corresponding feature is not supported by the helper and the connection
 | |
| is closed.  On the other hand, it is acceptable for a bit to be 0 in
 | |
| ``requested_features`` and 1 in ``supported_features``; in this case,
 | |
| the helper will not enable the feature.
 | |
| 
 | |
| Right now no feature is defined, so the two parties always write four
 | |
| zero bytes.
 | |
| 
 | |
| Command format
 | |
| --------------
 | |
| 
 | |
| It is invalid to send multiple commands concurrently on the same
 | |
| socket.  It is however possible to connect multiple sockets to the
 | |
| helper and send multiple commands to the helper for one or more
 | |
| file descriptors.
 | |
| 
 | |
| A command consists of a request and a response.  A request consists
 | |
| of a 16-byte SCSI CDB.  A file descriptor must be passed to the helper
 | |
| together with the SCSI CDB using ancillary data.
 | |
| 
 | |
| The CDB has the following limitations:
 | |
| 
 | |
| - the command (stored in the first byte) must be one of 0x5E
 | |
|   (PERSISTENT RESERVE IN) or 0x5F (PERSISTENT RESERVE OUT).
 | |
| 
 | |
| - the allocation length (stored in bytes 7-8 of the CDB for PERSISTENT
 | |
|   RESERVE IN) or parameter list length (stored in bytes 5-8 of the CDB
 | |
|   for PERSISTENT RESERVE OUT) is limited to 8 KiB.
 | |
| 
 | |
| For PERSISTENT RESERVE OUT, the parameter list is sent right after the
 | |
| CDB.  The length of the parameter list is taken from the CDB itself.
 | |
| 
 | |
| The helper's reply has the following structure:
 | |
| 
 | |
| - 4 bytes for the SCSI status
 | |
| 
 | |
| - 4 bytes for the payload size (nonzero only for PERSISTENT RESERVE IN
 | |
|   and only if the SCSI status is 0x00, i.e. GOOD)
 | |
| 
 | |
| - 96 bytes for the SCSI sense data
 | |
| 
 | |
| - if the size is nonzero, the payload follows
 | |
| 
 | |
| The sense data is always sent to keep the protocol simple, even though
 | |
| it is only valid if the SCSI status is CHECK CONDITION (0x02).
 | |
| 
 | |
| The payload size is always less than or equal to the allocation length
 | |
| specified in the CDB for the PERSISTENT RESERVE IN command.
 | |
| 
 | |
| If the protocol is violated, the helper closes the socket.
 |