qtest/ahci: halted NCQ test
Signed-off-by: John Snow <jsnow@redhat.com> Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com> Message-id: 1435767578-32743-10-git-send-email-jsnow@redhat.com
This commit is contained in:
parent
e08a98357b
commit
7f6cf5ee12
@ -1200,13 +1200,13 @@ static void test_migrate_ncq(void)
|
||||
}
|
||||
|
||||
/**
|
||||
* DMA Error Test
|
||||
* Halted IO Error Test
|
||||
*
|
||||
* Simulate an error on first write, Try to write a pattern,
|
||||
* Confirm the VM has stopped, resume the VM, verify command
|
||||
* has completed, then read back the data and verify.
|
||||
*/
|
||||
static void test_halted_dma(void)
|
||||
static void ahci_halted_io_test(uint8_t cmd_read, uint8_t cmd_write)
|
||||
{
|
||||
AHCIQState *ahci;
|
||||
uint8_t port;
|
||||
@ -1241,7 +1241,7 @@ static void test_halted_dma(void)
|
||||
memwrite(ptr, tx, bufsize);
|
||||
|
||||
/* Attempt to write (and fail) */
|
||||
cmd = ahci_guest_io_halt(ahci, port, CMD_WRITE_DMA,
|
||||
cmd = ahci_guest_io_halt(ahci, port, cmd_write,
|
||||
ptr, bufsize, 0);
|
||||
|
||||
/* Attempt to resume the command */
|
||||
@ -1249,7 +1249,7 @@ static void test_halted_dma(void)
|
||||
ahci_free(ahci, ptr);
|
||||
|
||||
/* Read back and verify */
|
||||
ahci_io(ahci, port, CMD_READ_DMA, rx, bufsize, 0);
|
||||
ahci_io(ahci, port, cmd_read, rx, bufsize, 0);
|
||||
g_assert_cmphex(memcmp(tx, rx, bufsize), ==, 0);
|
||||
|
||||
/* Cleanup and go home */
|
||||
@ -1258,6 +1258,16 @@ static void test_halted_dma(void)
|
||||
g_free(tx);
|
||||
}
|
||||
|
||||
static void test_halted_dma(void)
|
||||
{
|
||||
ahci_halted_io_test(CMD_READ_DMA, CMD_WRITE_DMA);
|
||||
}
|
||||
|
||||
static void test_halted_ncq(void)
|
||||
{
|
||||
ahci_halted_io_test(READ_FPDMA_QUEUED, WRITE_FPDMA_QUEUED);
|
||||
}
|
||||
|
||||
/**
|
||||
* DMA Error Migration Test
|
||||
*
|
||||
@ -1677,6 +1687,7 @@ int main(int argc, char **argv)
|
||||
|
||||
qtest_add_func("/ahci/io/ncq/simple", test_ncq_simple);
|
||||
qtest_add_func("/ahci/migrate/ncq/simple", test_migrate_ncq);
|
||||
qtest_add_func("/ahci/io/ncq/retry", test_halted_ncq);
|
||||
|
||||
ret = g_test_run();
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user