ATAPI: Replace DEBUG_IDE_ATAPI with tracing events
As part of the ongoing effort to modernize the tracing facilities for the IDE family of devices, remove PRINTFs in the ATAPI device with actual tracing events. Signed-off-by: John Snow <jsnow@redhat.com> Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Message-id: 20170901001502.29915-5-jsnow@redhat.com Signed-off-by: John Snow <jsnow@redhat.com>
This commit is contained in:
parent
1787efc3d2
commit
82a13ff821
@ -27,6 +27,7 @@
|
|||||||
#include "hw/ide/internal.h"
|
#include "hw/ide/internal.h"
|
||||||
#include "hw/scsi/scsi.h"
|
#include "hw/scsi/scsi.h"
|
||||||
#include "sysemu/block-backend.h"
|
#include "sysemu/block-backend.h"
|
||||||
|
#include "trace.h"
|
||||||
|
|
||||||
#define ATAPI_SECTOR_BITS (2 + BDRV_SECTOR_BITS)
|
#define ATAPI_SECTOR_BITS (2 + BDRV_SECTOR_BITS)
|
||||||
#define ATAPI_SECTOR_SIZE (1 << ATAPI_SECTOR_BITS)
|
#define ATAPI_SECTOR_SIZE (1 << ATAPI_SECTOR_BITS)
|
||||||
@ -116,9 +117,7 @@ cd_read_sector_sync(IDEState *s)
|
|||||||
block_acct_start(blk_get_stats(s->blk), &s->acct,
|
block_acct_start(blk_get_stats(s->blk), &s->acct,
|
||||||
ATAPI_SECTOR_SIZE, BLOCK_ACCT_READ);
|
ATAPI_SECTOR_SIZE, BLOCK_ACCT_READ);
|
||||||
|
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_cd_read_sector_sync(s->lba);
|
||||||
printf("cd_read_sector_sync: lba=%d\n", s->lba);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
switch (s->cd_sector_size) {
|
switch (s->cd_sector_size) {
|
||||||
case 2048:
|
case 2048:
|
||||||
@ -152,9 +151,7 @@ static void cd_read_sector_cb(void *opaque, int ret)
|
|||||||
{
|
{
|
||||||
IDEState *s = opaque;
|
IDEState *s = opaque;
|
||||||
|
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_cd_read_sector_cb(s->lba, ret);
|
||||||
printf("cd_read_sector_cb: lba=%d ret=%d\n", s->lba, ret);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
block_acct_failed(blk_get_stats(s->blk), &s->acct);
|
block_acct_failed(blk_get_stats(s->blk), &s->acct);
|
||||||
@ -188,9 +185,7 @@ static int cd_read_sector(IDEState *s)
|
|||||||
s->iov.iov_len = ATAPI_SECTOR_SIZE;
|
s->iov.iov_len = ATAPI_SECTOR_SIZE;
|
||||||
qemu_iovec_init_external(&s->qiov, &s->iov, 1);
|
qemu_iovec_init_external(&s->qiov, &s->iov, 1);
|
||||||
|
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_cd_read_sector(s->lba);
|
||||||
printf("cd_read_sector: lba=%d\n", s->lba);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
block_acct_start(blk_get_stats(s->blk), &s->acct,
|
block_acct_start(blk_get_stats(s->blk), &s->acct,
|
||||||
ATAPI_SECTOR_SIZE, BLOCK_ACCT_READ);
|
ATAPI_SECTOR_SIZE, BLOCK_ACCT_READ);
|
||||||
@ -213,9 +208,7 @@ void ide_atapi_cmd_ok(IDEState *s)
|
|||||||
|
|
||||||
void ide_atapi_cmd_error(IDEState *s, int sense_key, int asc)
|
void ide_atapi_cmd_error(IDEState *s, int sense_key, int asc)
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_ide_atapi_cmd_error(s, sense_key, asc);
|
||||||
printf("atapi_cmd_error: sense=0x%x asc=0x%x\n", sense_key, asc);
|
|
||||||
#endif
|
|
||||||
s->error = sense_key << 4;
|
s->error = sense_key << 4;
|
||||||
s->status = READY_STAT | ERR_STAT;
|
s->status = READY_STAT | ERR_STAT;
|
||||||
s->nsector = (s->nsector & ~7) | ATAPI_INT_REASON_IO | ATAPI_INT_REASON_CD;
|
s->nsector = (s->nsector & ~7) | ATAPI_INT_REASON_IO | ATAPI_INT_REASON_CD;
|
||||||
@ -252,19 +245,14 @@ static uint16_t atapi_byte_count_limit(IDEState *s)
|
|||||||
void ide_atapi_cmd_reply_end(IDEState *s)
|
void ide_atapi_cmd_reply_end(IDEState *s)
|
||||||
{
|
{
|
||||||
int byte_count_limit, size, ret;
|
int byte_count_limit, size, ret;
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_ide_atapi_cmd_reply_end(s, s->packet_transfer_size,
|
||||||
printf("reply: tx_size=%d elem_tx_size=%d index=%d\n",
|
s->elementary_transfer_size,
|
||||||
s->packet_transfer_size,
|
s->io_buffer_index);
|
||||||
s->elementary_transfer_size,
|
|
||||||
s->io_buffer_index);
|
|
||||||
#endif
|
|
||||||
if (s->packet_transfer_size <= 0) {
|
if (s->packet_transfer_size <= 0) {
|
||||||
/* end of transfer */
|
/* end of transfer */
|
||||||
ide_atapi_cmd_ok(s);
|
ide_atapi_cmd_ok(s);
|
||||||
ide_set_irq(s->bus);
|
ide_set_irq(s->bus);
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_ide_atapi_cmd_reply_end_eot(s, s->status);
|
||||||
printf("end of transfer, status=0x%x\n", s->status);
|
|
||||||
#endif
|
|
||||||
} else {
|
} else {
|
||||||
/* see if a new sector must be read */
|
/* see if a new sector must be read */
|
||||||
if (s->lba != -1 && s->io_buffer_index >= s->cd_sector_size) {
|
if (s->lba != -1 && s->io_buffer_index >= s->cd_sector_size) {
|
||||||
@ -300,9 +288,7 @@ void ide_atapi_cmd_reply_end(IDEState *s)
|
|||||||
/* a new transfer is needed */
|
/* a new transfer is needed */
|
||||||
s->nsector = (s->nsector & ~7) | ATAPI_INT_REASON_IO;
|
s->nsector = (s->nsector & ~7) | ATAPI_INT_REASON_IO;
|
||||||
byte_count_limit = atapi_byte_count_limit(s);
|
byte_count_limit = atapi_byte_count_limit(s);
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_ide_atapi_cmd_reply_end_bcl(s, byte_count_limit);
|
||||||
printf("byte_count_limit=%d\n", byte_count_limit);
|
|
||||||
#endif
|
|
||||||
size = s->packet_transfer_size;
|
size = s->packet_transfer_size;
|
||||||
if (size > byte_count_limit) {
|
if (size > byte_count_limit) {
|
||||||
/* byte count limit must be even if this case */
|
/* byte count limit must be even if this case */
|
||||||
@ -324,9 +310,7 @@ void ide_atapi_cmd_reply_end(IDEState *s)
|
|||||||
ide_transfer_start(s, s->io_buffer + s->io_buffer_index - size,
|
ide_transfer_start(s, s->io_buffer + s->io_buffer_index - size,
|
||||||
size, ide_atapi_cmd_reply_end);
|
size, ide_atapi_cmd_reply_end);
|
||||||
ide_set_irq(s->bus);
|
ide_set_irq(s->bus);
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_ide_atapi_cmd_reply_end_new(s, s->status);
|
||||||
printf("status=0x%x\n", s->status);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -368,9 +352,7 @@ static void ide_atapi_cmd_read_pio(IDEState *s, int lba, int nb_sectors,
|
|||||||
|
|
||||||
static void ide_atapi_cmd_check_status(IDEState *s)
|
static void ide_atapi_cmd_check_status(IDEState *s)
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_ide_atapi_cmd_check_status(s);
|
||||||
printf("atapi_cmd_check_status\n");
|
|
||||||
#endif
|
|
||||||
s->error = MC_ERR | (UNIT_ATTENTION << 4);
|
s->error = MC_ERR | (UNIT_ATTENTION << 4);
|
||||||
s->status = ERR_STAT;
|
s->status = ERR_STAT;
|
||||||
s->nsector = 0;
|
s->nsector = 0;
|
||||||
@ -477,10 +459,8 @@ static void ide_atapi_cmd_read_dma(IDEState *s, int lba, int nb_sectors,
|
|||||||
static void ide_atapi_cmd_read(IDEState *s, int lba, int nb_sectors,
|
static void ide_atapi_cmd_read(IDEState *s, int lba, int nb_sectors,
|
||||||
int sector_size)
|
int sector_size)
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_ide_atapi_cmd_read(s, s->atapi_dma ? "dma" : "pio",
|
||||||
printf("read %s: LBA=%d nb_sectors=%d\n", s->atapi_dma ? "dma" : "pio",
|
lba, nb_sectors);
|
||||||
lba, nb_sectors);
|
|
||||||
#endif
|
|
||||||
if (s->atapi_dma) {
|
if (s->atapi_dma) {
|
||||||
ide_atapi_cmd_read_dma(s, lba, nb_sectors, sector_size);
|
ide_atapi_cmd_read_dma(s, lba, nb_sectors, sector_size);
|
||||||
} else {
|
} else {
|
||||||
@ -1330,16 +1310,18 @@ void ide_atapi_cmd(IDEState *s)
|
|||||||
uint8_t *buf = s->io_buffer;
|
uint8_t *buf = s->io_buffer;
|
||||||
const struct AtapiCmd *cmd = &atapi_cmd_table[s->io_buffer[0]];
|
const struct AtapiCmd *cmd = &atapi_cmd_table[s->io_buffer[0]];
|
||||||
|
|
||||||
#ifdef DEBUG_IDE_ATAPI
|
trace_ide_atapi_cmd(s, s->io_buffer[0]);
|
||||||
{
|
|
||||||
|
if (trace_event_get_state_backends(TRACE_IDE_ATAPI_CMD_PACKET)) {
|
||||||
|
/* Each pretty-printed byte needs two bytes and a space; */
|
||||||
|
char *ppacket = g_malloc(ATAPI_PACKET_SIZE * 3 + 1);
|
||||||
int i;
|
int i;
|
||||||
printf("ATAPI limit=0x%x packet:", s->lcyl | (s->hcyl << 8));
|
for (i = 0; i < ATAPI_PACKET_SIZE; i++) {
|
||||||
for(i = 0; i < ATAPI_PACKET_SIZE; i++) {
|
sprintf(ppacket + (i * 3), "%02x ", buf[i]);
|
||||||
printf(" %02x", buf[i]);
|
|
||||||
}
|
}
|
||||||
printf("\n");
|
trace_ide_atapi_cmd_packet(s, s->lcyl | (s->hcyl << 8), ppacket);
|
||||||
|
g_free(ppacket);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If there's a UNIT_ATTENTION condition pending, only command flagged with
|
* If there's a UNIT_ATTENTION condition pending, only command flagged with
|
||||||
|
@ -38,3 +38,18 @@ bmdma_write(uint64_t addr, uint64_t val) "bmdma: writeb 0x%"PRIx64" : 0x%02"PRIx
|
|||||||
# hw/ide/via.c
|
# hw/ide/via.c
|
||||||
bmdma_read_via(uint64_t addr, uint32_t val) "bmdma: readb 0x%"PRIx64" : 0x%02x"
|
bmdma_read_via(uint64_t addr, uint32_t val) "bmdma: readb 0x%"PRIx64" : 0x%02x"
|
||||||
bmdma_write_via(uint64_t addr, uint64_t val) "bmdma: writeb 0x%"PRIx64" : 0x%02"PRIx64
|
bmdma_write_via(uint64_t addr, uint64_t val) "bmdma: writeb 0x%"PRIx64" : 0x%02"PRIx64
|
||||||
|
|
||||||
|
# hw/ide/atapi.c
|
||||||
|
cd_read_sector_sync(int lba) "lba=%d"
|
||||||
|
cd_read_sector_cb(int lba, int ret) "lba=%d ret=%d"
|
||||||
|
cd_read_sector(int lba) "lba=%d"
|
||||||
|
ide_atapi_cmd_error(void *s, int sense_key, int asc) "IDEState: %p; sense=0x%x asc=0x%x"
|
||||||
|
ide_atapi_cmd_reply_end(void *s, int tx_size, int elem_tx_size, int32_t index) "IDEState %p; reply: tx_size=%d elem_tx_size=%d index=%"PRId32
|
||||||
|
ide_atapi_cmd_reply_end_eot(void *s, int status) "IDEState: %p; end of transfer, status=0x%x"
|
||||||
|
ide_atapi_cmd_reply_end_bcl(void *s, int bcl) "IDEState: %p; byte_count_limit=%d"
|
||||||
|
ide_atapi_cmd_reply_end_new(void *s, int status) "IDEState: %p; new transfer started, status=0x%x"
|
||||||
|
ide_atapi_cmd_check_status(void *s) "IDEState: %p"
|
||||||
|
ide_atapi_cmd_read(void *s, const char *method, int lba, int nb_sectors) "IDEState: %p; read %s: LBA=%d nb_sectors=%d"
|
||||||
|
ide_atapi_cmd(void *s, uint8_t cmd) "IDEState: %p; cmd: 0x%02x"
|
||||||
|
# Warning: Verbose
|
||||||
|
ide_atapi_cmd_packet(void *s, uint16_t limit, const char *packet) "IDEState: %p; limit=0x%x packet: %s"
|
||||||
|
@ -14,7 +14,6 @@
|
|||||||
#include "block/scsi.h"
|
#include "block/scsi.h"
|
||||||
|
|
||||||
/* debug IDE devices */
|
/* debug IDE devices */
|
||||||
//#define DEBUG_IDE_ATAPI
|
|
||||||
//#define DEBUG_AIO
|
//#define DEBUG_AIO
|
||||||
#define USE_DMA_CDROM
|
#define USE_DMA_CDROM
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user