mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-03 15:53:54 -06:00
ahci-test: test atapi read_cd with bcl, nb_sectors = 0
Commit 9ef2e93f
introduced the concept of tagging ATAPI commands as
NONDATA, but this introduced a regression for certain commands better
described as CONDDATA. read_cd is such a command that both requires
a non-zero BCL if a transfer size is set, but is perfectly content to
accept a zero BCL if the transfer size is 0.
This test adds a regression test for the case where BCL and nb_sectors
are both 0.
Flesh out the CDROM tests by:
(1) Allowing the test to specify a BCL
(2) Allowing the buffer comparison test to compare a 0-size buffer
(3) Fix the BCL specification in libqos (It is LE, not BE)
(4) Add a nice human-readable message for future SCSI command additions
Signed-off-by: John Snow <jsnow@redhat.com>
Reviewed-by: Kevin Wolf <kwolf@redhat.com>
Message-id: 1477970211-25754-4-git-send-email-jsnow@redhat.com
[Line length edit --js]
Signed-off-by: John Snow <jsnow@redhat.com>
This commit is contained in:
parent
53c05e6c20
commit
ebde93bf9a
3 changed files with 60 additions and 21 deletions
|
@ -1473,8 +1473,13 @@ static int ahci_cb_cmp_buff(AHCIQState *ahci, AHCICommand *cmd,
|
|||
const AHCIOpts *opts)
|
||||
{
|
||||
unsigned char *tx = opts->opaque;
|
||||
unsigned char *rx = g_malloc0(opts->size);
|
||||
unsigned char *rx;
|
||||
|
||||
if (!opts->size) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
rx = g_malloc0(opts->size);
|
||||
bufread(opts->buffer, rx, opts->size);
|
||||
g_assert_cmphex(memcmp(tx, rx, opts->size), ==, 0);
|
||||
g_free(rx);
|
||||
|
@ -1482,7 +1487,8 @@ static int ahci_cb_cmp_buff(AHCIQState *ahci, AHCICommand *cmd,
|
|||
return 0;
|
||||
}
|
||||
|
||||
static void ahci_test_cdrom(int nsectors, bool dma)
|
||||
static void ahci_test_cdrom(int nsectors, bool dma, uint8_t cmd,
|
||||
bool override_bcl, uint16_t bcl)
|
||||
{
|
||||
AHCIQState *ahci;
|
||||
unsigned char *tx;
|
||||
|
@ -1493,6 +1499,8 @@ static void ahci_test_cdrom(int nsectors, bool dma)
|
|||
.atapi = true,
|
||||
.atapi_dma = dma,
|
||||
.post_cb = ahci_cb_cmp_buff,
|
||||
.set_bcl = override_bcl,
|
||||
.bcl = bcl,
|
||||
};
|
||||
uint64_t iso_size = ATAPI_SECTOR_SIZE * (nsectors + 1);
|
||||
|
||||
|
@ -1506,7 +1514,7 @@ static void ahci_test_cdrom(int nsectors, bool dma)
|
|||
"-device ide-cd,drive=drive0 ", iso);
|
||||
|
||||
/* Build & Send AHCI command */
|
||||
ahci_exec(ahci, ahci_port_select(ahci), CMD_ATAPI_READ_10, &opts);
|
||||
ahci_exec(ahci, ahci_port_select(ahci), cmd, &opts);
|
||||
|
||||
/* Cleanup */
|
||||
g_free(tx);
|
||||
|
@ -1514,24 +1522,36 @@ static void ahci_test_cdrom(int nsectors, bool dma)
|
|||
remove_iso(fd, iso);
|
||||
}
|
||||
|
||||
static void ahci_test_cdrom_read10(int nsectors, bool dma)
|
||||
{
|
||||
ahci_test_cdrom(nsectors, dma, CMD_ATAPI_READ_10, false, 0);
|
||||
}
|
||||
|
||||
static void test_cdrom_dma(void)
|
||||
{
|
||||
ahci_test_cdrom(1, true);
|
||||
ahci_test_cdrom_read10(1, true);
|
||||
}
|
||||
|
||||
static void test_cdrom_dma_multi(void)
|
||||
{
|
||||
ahci_test_cdrom(3, true);
|
||||
ahci_test_cdrom_read10(3, true);
|
||||
}
|
||||
|
||||
static void test_cdrom_pio(void)
|
||||
{
|
||||
ahci_test_cdrom(1, false);
|
||||
ahci_test_cdrom_read10(1, false);
|
||||
}
|
||||
|
||||
static void test_cdrom_pio_multi(void)
|
||||
{
|
||||
ahci_test_cdrom(3, false);
|
||||
ahci_test_cdrom_read10(3, false);
|
||||
}
|
||||
|
||||
/* Regression test: Test that a READ_CD command with a BCL of 0 but a size of 0
|
||||
* completes as a NOP instead of erroring out. */
|
||||
static void test_atapi_bcl(void)
|
||||
{
|
||||
ahci_test_cdrom(0, false, CMD_ATAPI_READ_CD, true, 0);
|
||||
}
|
||||
|
||||
/******************************************************************************/
|
||||
|
@ -1823,6 +1843,8 @@ int main(int argc, char **argv)
|
|||
qtest_add_func("/ahci/cdrom/pio/single", test_cdrom_pio);
|
||||
qtest_add_func("/ahci/cdrom/pio/multi", test_cdrom_pio_multi);
|
||||
|
||||
qtest_add_func("/ahci/cdrom/pio/bcl", test_atapi_bcl);
|
||||
|
||||
ret = g_test_run();
|
||||
|
||||
/* Cleanup */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue