aboutsummaryrefslogtreecommitdiff
path: root/docs/specs/vmw_pvscsi-spec.rst
blob: b6f434a4187c873d18d37674ab4ceace2556c69d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
==============================
VMWare PVSCSI Device Interface
==============================

..
   Created by Dmitry Fleytman (dmitry@daynix.com), Daynix Computing LTD.

This document describes the VMWare PVSCSI device interface specification,
based on the source code of the PVSCSI Linux driver from kernel 3.0.4.

Overview
========

The interface is based on a memory area shared between hypervisor and VM.
The memory area is obtained by driver as a device IO memory resource of
``PVSCSI_MEM_SPACE_SIZE`` length.
The shared memory consists of a registers area and a rings area.
The registers area is used to raise hypervisor interrupts and issue device
commands. The rings area is used to transfer data descriptors and SCSI
commands from VM to hypervisor and to transfer messages produced by
hypervisor to VM. Data itself is transferred via virtual scatter-gather DMA.

PVSCSI Device Registers
=======================

The length of the registers area is 1 page
(``PVSCSI_MEM_SPACE_COMMAND_NUM_PAGES``).  The structure of the
registers area is described by the ``PVSCSIRegOffset`` enum.  There
are registers to issue device commands (with optional short data),
issue device interrupts, and control interrupt masking.

PVSCSI Device Rings
===================

There are three rings in shared memory:

Request ring (``struct PVSCSIRingReqDesc *req_ring``)
    ring for OS to device requests

Completion ring (``struct PVSCSIRingCmpDesc *cmp_ring``)
    ring for device request completions

Message ring (``struct PVSCSIRingMsgDesc *msg_ring``)
    ring for messages from device. This ring is optional and the
    guest might not configure it.

There is a control area (``struct PVSCSIRingsState *rings_state``)
used to control rings operation.

PVSCSI Device to Host Interrupts
================================

The following interrupt types are supported by the PVSCSI device:

Completion interrupts (completion ring notifications):

- ``PVSCSI_INTR_CMPL_0``
- ``PVSCSI_INTR_CMPL_1``

Message interrupts (message ring notifications):

- ``PVSCSI_INTR_MSG_0``
- ``PVSCSI_INTR_MSG_1``

Interrupts are controlled via the ``PVSCSI_REG_OFFSET_INTR_MASK``
register.  If a bit is set it means the interrupt is enabled, and if
it is clear then the interrupt is disabled.

The interrupt modes supported are legacy, MSI and MSI-X.
In the case of legacy interrupts, the ``PVSCSI_REG_OFFSET_INTR_STATUS``
register is used to check which interrupt has arrived.  Interrupts are
acknowledged when the corresponding bit is written to the interrupt
status register.

PVSCSI Device Operation Sequences
=================================

Startup sequence
----------------

a. Issue ``PVSCSI_CMD_ADAPTER_RESET`` command
b. Windows driver reads interrupt status register here
c. Issue ``PVSCSI_CMD_SETUP_MSG_RING`` command with no additional data,
   check status and disable device messages if error returned
   (Omitted if device messages disabled by driver configuration)
d. Issue ``PVSCSI_CMD_SETUP_RINGS`` command, provide rings configuration
   as ``struct PVSCSICmdDescSetupRings``
e. Issue ``PVSCSI_CMD_SETUP_MSG_RING`` command again, provide
   rings configuration as ``struct PVSCSICmdDescSetupMsgRing``
f. Unmask completion and message (if device messages enabled) interrupts

Shutdown sequence
-----------------

a. Mask interrupts
b. Flush request ring using ``PVSCSI_REG_OFFSET_KICK_NON_RW_IO``
c. Issue ``PVSCSI_CMD_ADAPTER_RESET`` command

Send request
------------

a. Fill next free request ring descriptor
b. Issue ``PVSCSI_REG_OFFSET_KICK_RW_IO`` for R/W operations
   or ``PVSCSI_REG_OFFSET_KICK_NON_RW_IO`` for other operations

Abort command
-------------

a. Issue ``PVSCSI_CMD_ABORT_CMD`` command

Request completion processing
-----------------------------

a. Upon completion interrupt arrival process completion
   and message (if enabled) rings