mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-09 02:24:58 -06:00
* SCSI scanner support
* fixes to qemu-char and net exit * FreeBSD fixes * Other small bugfixes -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.22 (GNU/Linux) iQEcBAABAgAGBQJXhiZDAAoJEL/70l94x66DrGAH/10ZlIYugx6Ijn12qy3irmIC hbMY6HWjvPlk8ZpAcPa3UXNQvqhTwqhSMXRiwp9aNPlRUqrXnDXZapQunJveKSAn luLE8ISRKODz0W39qg6znyb4R1ipCGJWwjBCQmLWZuD7883JJ2DsykTATRx7yKQF qsq9r/DPBTfD3vnOCTbqp0GeB80UFleTNm+K7cct8M1+WzfiwKeVHk9CAKy0fkTH hS+YnV9UWYL6PR/w+uZ+2MfgH5er4X794+HaNbio0QJJbEZ2bsL4A3Prh7pUonN7 qJoCbT4W79scrnWQ40RbWRXOMfUk4J7gIMEZYar8z6NmqnamNZgxbWj3dv6pO+k= =sz/L -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/bonzini/tags/for-upstream' into staging * SCSI scanner support * fixes to qemu-char and net exit * FreeBSD fixes * Other small bugfixes # gpg: Signature made Wed 13 Jul 2016 12:30:11 BST # gpg: using RSA key 0xBFFBD25F78C7AE83 # gpg: Good signature from "Paolo Bonzini <bonzini@gnu.org>" # gpg: aka "Paolo Bonzini <pbonzini@redhat.com>" # Primary key fingerprint: 46F5 9FBD 57D6 12E7 BFD4 E2F7 7E15 100C CD36 69B1 # Subkey fingerprint: F133 3857 4B66 2389 866C 7682 BFFB D25F 78C7 AE83 * remotes/bonzini/tags/for-upstream: hostmem: detect host backend memory is being used properly hostmem: fix QEMU crash by 'info memdev' char: do not use atexit cleanup handler net: do not use atexit for cleanup slirp: use exit notifier for slirp_smb_cleanup tap: use an exit notifier to call down_script util: Fix MIN_NON_ZERO qemu-sockets: use qapi_free_SocketAddress in cleanup disas: avoid including everything in headers compiled from C++ json-streamer: fix double-free on exiting during a parse main-loop: check return value before using pointer Use "-s" instead of "--quiet" to resolve non-fatal build error on FreeBSD. scsi-bus: Use longer sense buffer with scanners scsi-bus: Add SCSI scanner support Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
190c93c982
18 changed files with 155 additions and 49 deletions
|
@ -461,6 +461,14 @@ static bool scsi_target_emulate_inquiry(SCSITargetReq *r)
|
|||
return true;
|
||||
}
|
||||
|
||||
static size_t scsi_sense_len(SCSIRequest *req)
|
||||
{
|
||||
if (req->dev->type == TYPE_SCANNER)
|
||||
return SCSI_SENSE_LEN_SCANNER;
|
||||
else
|
||||
return SCSI_SENSE_LEN;
|
||||
}
|
||||
|
||||
static int32_t scsi_target_send_command(SCSIRequest *req, uint8_t *buf)
|
||||
{
|
||||
SCSITargetReq *r = DO_UPCAST(SCSITargetReq, req, req);
|
||||
|
@ -477,7 +485,7 @@ static int32_t scsi_target_send_command(SCSIRequest *req, uint8_t *buf)
|
|||
}
|
||||
break;
|
||||
case REQUEST_SENSE:
|
||||
scsi_target_alloc_buf(&r->req, SCSI_SENSE_LEN);
|
||||
scsi_target_alloc_buf(&r->req, scsi_sense_len(req));
|
||||
r->len = scsi_device_get_sense(r->req.dev, r->buf,
|
||||
MIN(req->cmd.xfer, r->buf_len),
|
||||
(req->cmd.buf[1] & 1) == 0);
|
||||
|
@ -1132,6 +1140,29 @@ static int scsi_req_medium_changer_xfer(SCSICommand *cmd, SCSIDevice *dev, uint8
|
|||
return 0;
|
||||
}
|
||||
|
||||
static int scsi_req_scanner_length(SCSICommand *cmd, SCSIDevice *dev, uint8_t *buf)
|
||||
{
|
||||
switch (buf[0]) {
|
||||
/* Scanner commands */
|
||||
case OBJECT_POSITION:
|
||||
cmd->xfer = 0;
|
||||
break;
|
||||
case SCAN:
|
||||
cmd->xfer = buf[4];
|
||||
break;
|
||||
case READ_10:
|
||||
case SEND:
|
||||
case GET_WINDOW:
|
||||
case SET_WINDOW:
|
||||
cmd->xfer = buf[8] | (buf[7] << 8) | (buf[6] << 16);
|
||||
break;
|
||||
default:
|
||||
/* GET_DATA_BUFFER_STATUS xfer handled by scsi_req_xfer */
|
||||
return scsi_req_xfer(cmd, dev, buf);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void scsi_cmd_xfer_mode(SCSICommand *cmd)
|
||||
{
|
||||
|
@ -1178,6 +1209,11 @@ static void scsi_cmd_xfer_mode(SCSICommand *cmd)
|
|||
case SEND_DVD_STRUCTURE:
|
||||
case PERSISTENT_RESERVE_OUT:
|
||||
case MAINTENANCE_OUT:
|
||||
case SET_WINDOW:
|
||||
case SCAN:
|
||||
/* SCAN conflicts with START_STOP. START_STOP has cmd->xfer set to 0 for
|
||||
* non-scanner devices, so we only get here for SCAN and not for START_STOP.
|
||||
*/
|
||||
cmd->mode = SCSI_XFER_TO_DEV;
|
||||
break;
|
||||
case ATA_PASSTHROUGH_12:
|
||||
|
@ -1258,6 +1294,9 @@ int scsi_req_parse_cdb(SCSIDevice *dev, SCSICommand *cmd, uint8_t *buf)
|
|||
case TYPE_MEDIUM_CHANGER:
|
||||
rc = scsi_req_medium_changer_xfer(cmd, dev, buf);
|
||||
break;
|
||||
case TYPE_SCANNER:
|
||||
rc = scsi_req_scanner_length(cmd, dev, buf);
|
||||
break;
|
||||
default:
|
||||
rc = scsi_req_xfer(cmd, dev, buf);
|
||||
break;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue