提交 8b19f2b7 编写于 作者: E Eric Blake 提交者: Thomas Huth

tests/boot-sector: Drop dependence on global_qtest

As a general rule, we prefer avoiding implicit global state
because it makes code harder to safely copy and paste without
thinking about the global state.  Adjust the helper code to
use explicit state instead, and update all callers.

Fix some trailing whitespace while touching the file.
Signed-off-by: NEric Blake <eblake@redhat.com>
Reviewed-by: NThomas Huth <thuth@redhat.com>
Acked-by: NMichael S. Tsirkin <mst@redhat.com>
Signed-off-by: NThomas Huth <thuth@redhat.com>
上级 6a5c88f5
...@@ -668,7 +668,7 @@ static void test_acpi_one(const char *params, test_data *data) ...@@ -668,7 +668,7 @@ static void test_acpi_one(const char *params, test_data *data)
qtest_start(args); qtest_start(args);
boot_sector_test(); boot_sector_test(global_qtest);
data->tables = g_array_new(false, true, sizeof(AcpiSdtTable)); data->tables = g_array_new(false, true, sizeof(AcpiSdtTable));
test_acpi_rsdp_address(data); test_acpi_rsdp_address(data);
......
...@@ -130,7 +130,7 @@ int boot_sector_init(char *fname) ...@@ -130,7 +130,7 @@ int boot_sector_init(char *fname)
} }
/* Loop until signature in memory is OK. */ /* Loop until signature in memory is OK. */
void boot_sector_test(void) void boot_sector_test(QTestState *qts)
{ {
uint8_t signature_low; uint8_t signature_low;
uint8_t signature_high; uint8_t signature_high;
...@@ -146,8 +146,8 @@ void boot_sector_test(void) ...@@ -146,8 +146,8 @@ void boot_sector_test(void)
* instruction. * instruction.
*/ */
for (i = 0; i < TEST_CYCLES; ++i) { for (i = 0; i < TEST_CYCLES; ++i) {
signature_low = readb(SIGNATURE_ADDR); signature_low = qtest_readb(qts, SIGNATURE_ADDR);
signature_high = readb(SIGNATURE_ADDR + 1); signature_high = qtest_readb(qts, SIGNATURE_ADDR + 1);
signature = (signature_high << 8) | signature_low; signature = (signature_high << 8) | signature_low;
if (signature == SIGNATURE) { if (signature == SIGNATURE) {
break; break;
......
...@@ -14,11 +14,13 @@ ...@@ -14,11 +14,13 @@
#ifndef TEST_BOOT_SECTOR_H #ifndef TEST_BOOT_SECTOR_H
#define TEST_BOOT_SECTOR_H #define TEST_BOOT_SECTOR_H
#include "libqtest.h"
/* Create boot disk file. fname must be a suitable string for mkstemp() */ /* Create boot disk file. fname must be a suitable string for mkstemp() */
int boot_sector_init(char *fname); int boot_sector_init(char *fname);
/* Loop until signature in memory is OK. */ /* Loop until signature in memory is OK. */
void boot_sector_test(void); void boot_sector_test(QTestState *qts);
/* unlink boot disk file. */ /* unlink boot disk file. */
void boot_sector_cleanup(const char *fname); void boot_sector_cleanup(const char *fname);
......
...@@ -71,7 +71,7 @@ static void test_pxe_one(const testdef_t *test, bool ipv6) ...@@ -71,7 +71,7 @@ static void test_pxe_one(const testdef_t *test, bool ipv6)
test->model); test->model);
qtest_start(args); qtest_start(args);
boot_sector_test(); boot_sector_test(global_qtest);
qtest_quit(global_qtest); qtest_quit(global_qtest);
g_free(args); g_free(args);
} }
......
...@@ -45,7 +45,7 @@ static uint32_t acpi_find_vgia(void) ...@@ -45,7 +45,7 @@ static uint32_t acpi_find_vgia(void)
int i; int i;
/* Wait for guest firmware to finish and start the payload. */ /* Wait for guest firmware to finish and start the payload. */
boot_sector_test(); boot_sector_test(global_qtest);
/* Tables should be initialized now. */ /* Tables should be initialized now. */
rsdp_offset = acpi_find_rsdp_address(); rsdp_offset = acpi_find_rsdp_address();
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册