virtio-scsi: trace events
Add trace events for virtio command and response tracing. Signed-off-by: Hannes Reinecke <hare@suse.de> Message-Id: <20201116183114.55703-2-hare@suse.de> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
3eacf70bb5
commit
eb8cb3d9dc
hw/scsi
@ -294,6 +294,15 @@ lsi_awoken(void) "Woken by SIGP"
|
|||||||
lsi_reg_read(const char *name, int offset, uint8_t ret) "Read reg %s 0x%x = 0x%02x"
|
lsi_reg_read(const char *name, int offset, uint8_t ret) "Read reg %s 0x%x = 0x%02x"
|
||||||
lsi_reg_write(const char *name, int offset, uint8_t val) "Write reg %s 0x%x = 0x%02x"
|
lsi_reg_write(const char *name, int offset, uint8_t val) "Write reg %s 0x%x = 0x%02x"
|
||||||
|
|
||||||
|
# virtio-scsi.c
|
||||||
|
virtio_scsi_cmd_req(int lun, uint32_t tag, uint8_t cmd) "virtio_scsi_cmd_req lun=%u tag=0x%x cmd=0x%x"
|
||||||
|
virtio_scsi_cmd_resp(int lun, uint32_t tag, int response, uint8_t status) "virtio_scsi_cmd_resp lun=%u tag=0x%x response=%d status=0x%x"
|
||||||
|
virtio_scsi_tmf_req(int lun, uint32_t tag, int subtype) "virtio_scsi_tmf_req lun=%u tag=0x%x subtype=%d"
|
||||||
|
virtio_scsi_tmf_resp(int lun, uint32_t tag, int response) "virtio_scsi_tmf_resp lun=%u tag=0x%x response=%d"
|
||||||
|
virtio_scsi_an_req(int lun, uint32_t event_requested) "virtio_scsi_an_req lun=%u event_requested=0x%x"
|
||||||
|
virtio_scsi_an_resp(int lun, int response) "virtio_scsi_an_resp lun=%u response=%d"
|
||||||
|
virtio_scsi_event(int lun, int event, int reason) "virtio_scsi_event lun=%u event=%d reason=%d"
|
||||||
|
|
||||||
# scsi-disk.c
|
# scsi-disk.c
|
||||||
scsi_disk_check_condition(uint32_t tag, uint8_t key, uint8_t asc, uint8_t ascq) "Command complete tag=0x%x sense=%d/%d/%d"
|
scsi_disk_check_condition(uint32_t tag, uint8_t key, uint8_t asc, uint8_t ascq) "Command complete tag=0x%x sense=%d/%d/%d"
|
||||||
scsi_disk_read_complete(uint32_t tag, size_t size) "Data ready tag=0x%x len=%zd"
|
scsi_disk_read_complete(uint32_t tag, size_t size) "Data ready tag=0x%x len=%zd"
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#include "scsi/constants.h"
|
#include "scsi/constants.h"
|
||||||
#include "hw/virtio/virtio-bus.h"
|
#include "hw/virtio/virtio-bus.h"
|
||||||
#include "hw/virtio/virtio-access.h"
|
#include "hw/virtio/virtio-access.h"
|
||||||
|
#include "trace.h"
|
||||||
|
|
||||||
static inline int virtio_scsi_get_lun(uint8_t *lun)
|
static inline int virtio_scsi_get_lun(uint8_t *lun)
|
||||||
{
|
{
|
||||||
@ -239,7 +240,11 @@ static void virtio_scsi_cancel_notify(Notifier *notifier, void *data)
|
|||||||
notifier);
|
notifier);
|
||||||
|
|
||||||
if (--n->tmf_req->remaining == 0) {
|
if (--n->tmf_req->remaining == 0) {
|
||||||
virtio_scsi_complete_req(n->tmf_req);
|
VirtIOSCSIReq *req = n->tmf_req;
|
||||||
|
|
||||||
|
trace_virtio_scsi_tmf_resp(virtio_scsi_get_lun(req->req.tmf.lun),
|
||||||
|
req->req.tmf.tag, req->resp.tmf.response);
|
||||||
|
virtio_scsi_complete_req(req);
|
||||||
}
|
}
|
||||||
g_free(n);
|
g_free(n);
|
||||||
}
|
}
|
||||||
@ -273,6 +278,9 @@ static int virtio_scsi_do_tmf(VirtIOSCSI *s, VirtIOSCSIReq *req)
|
|||||||
req->req.tmf.subtype =
|
req->req.tmf.subtype =
|
||||||
virtio_tswap32(VIRTIO_DEVICE(s), req->req.tmf.subtype);
|
virtio_tswap32(VIRTIO_DEVICE(s), req->req.tmf.subtype);
|
||||||
|
|
||||||
|
trace_virtio_scsi_tmf_req(virtio_scsi_get_lun(req->req.tmf.lun),
|
||||||
|
req->req.tmf.tag, req->req.tmf.subtype);
|
||||||
|
|
||||||
switch (req->req.tmf.subtype) {
|
switch (req->req.tmf.subtype) {
|
||||||
case VIRTIO_SCSI_T_TMF_ABORT_TASK:
|
case VIRTIO_SCSI_T_TMF_ABORT_TASK:
|
||||||
case VIRTIO_SCSI_T_TMF_QUERY_TASK:
|
case VIRTIO_SCSI_T_TMF_QUERY_TASK:
|
||||||
@ -429,11 +437,23 @@ static void virtio_scsi_handle_ctrl_req(VirtIOSCSI *s, VirtIOSCSIReq *req)
|
|||||||
virtio_scsi_bad_req(req);
|
virtio_scsi_bad_req(req);
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
|
req->req.an.event_requested =
|
||||||
|
virtio_tswap32(VIRTIO_DEVICE(s), req->req.an.event_requested);
|
||||||
|
trace_virtio_scsi_an_req(virtio_scsi_get_lun(req->req.an.lun),
|
||||||
|
req->req.an.event_requested);
|
||||||
req->resp.an.event_actual = 0;
|
req->resp.an.event_actual = 0;
|
||||||
req->resp.an.response = VIRTIO_SCSI_S_OK;
|
req->resp.an.response = VIRTIO_SCSI_S_OK;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (r == 0) {
|
if (r == 0) {
|
||||||
|
if (type == VIRTIO_SCSI_T_TMF)
|
||||||
|
trace_virtio_scsi_tmf_resp(virtio_scsi_get_lun(req->req.tmf.lun),
|
||||||
|
req->req.tmf.tag,
|
||||||
|
req->resp.tmf.response);
|
||||||
|
else if (type == VIRTIO_SCSI_T_AN_QUERY ||
|
||||||
|
type == VIRTIO_SCSI_T_AN_SUBSCRIBE)
|
||||||
|
trace_virtio_scsi_an_resp(virtio_scsi_get_lun(req->req.an.lun),
|
||||||
|
req->resp.an.response);
|
||||||
virtio_scsi_complete_req(req);
|
virtio_scsi_complete_req(req);
|
||||||
} else {
|
} else {
|
||||||
assert(r == -EINPROGRESS);
|
assert(r == -EINPROGRESS);
|
||||||
@ -469,6 +489,10 @@ static void virtio_scsi_handle_ctrl(VirtIODevice *vdev, VirtQueue *vq)
|
|||||||
|
|
||||||
static void virtio_scsi_complete_cmd_req(VirtIOSCSIReq *req)
|
static void virtio_scsi_complete_cmd_req(VirtIOSCSIReq *req)
|
||||||
{
|
{
|
||||||
|
trace_virtio_scsi_cmd_resp(virtio_scsi_get_lun(req->req.cmd.lun),
|
||||||
|
req->req.cmd.tag,
|
||||||
|
req->resp.cmd.response,
|
||||||
|
req->resp.cmd.status);
|
||||||
/* Sense data is not in req->resp and is copied separately
|
/* Sense data is not in req->resp and is copied separately
|
||||||
* in virtio_scsi_command_complete.
|
* in virtio_scsi_command_complete.
|
||||||
*/
|
*/
|
||||||
@ -566,6 +590,8 @@ static int virtio_scsi_handle_cmd_req_prepare(VirtIOSCSI *s, VirtIOSCSIReq *req)
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
trace_virtio_scsi_cmd_req(virtio_scsi_get_lun(req->req.cmd.lun),
|
||||||
|
req->req.cmd.tag, req->req.cmd.cdb[0]);
|
||||||
|
|
||||||
d = virtio_scsi_device_get(s, req->req.cmd.lun);
|
d = virtio_scsi_device_get(s, req->req.cmd.lun);
|
||||||
if (!d) {
|
if (!d) {
|
||||||
@ -767,6 +793,8 @@ void virtio_scsi_push_event(VirtIOSCSI *s, SCSIDevice *dev,
|
|||||||
}
|
}
|
||||||
evt->lun[3] = dev->lun & 0xFF;
|
evt->lun[3] = dev->lun & 0xFF;
|
||||||
}
|
}
|
||||||
|
trace_virtio_scsi_event(virtio_scsi_get_lun(evt->lun), event, reason);
|
||||||
|
|
||||||
virtio_scsi_complete_req(req);
|
virtio_scsi_complete_req(req);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user