summaryrefslogtreecommitdiff
path: root/tests/rtc-test.c
diff options
context:
space:
mode:
authorBlue Swirl <blauwirbel@gmail.com>2012-04-15 07:36:49 +0000
committerBlue Swirl <blauwirbel@gmail.com>2012-04-19 18:14:55 +0000
commit85215d419b17aeedbfe93ff8d739b27937f72739 (patch)
tree89716aeb9a447b63affeac5bbb6ce4617cb0e4a5 /tests/rtc-test.c
parent51006bbc45bc74977ae538190a53df2af534acb9 (diff)
downloadqemu-85215d419b17aeedbfe93ff8d739b27937f72739.tar.gz
qtest: add register fuzzing to RTC test
Reviewed-by: Anthony Liguori <aliguori@us.ibm.com> Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
Diffstat (limited to 'tests/rtc-test.c')
-rw-r--r--tests/rtc-test.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/tests/rtc-test.c b/tests/rtc-test.c
index 983a980bab..f23ac3a6cf 100644
--- a/tests/rtc-test.c
+++ b/tests/rtc-test.c
@@ -240,6 +240,22 @@ static void alarm_time(void)
g_assert(cmos_read(RTC_REG_C) == 0);
}
+/* success if no crash or abort */
+static void fuzz_registers(void)
+{
+ unsigned int i;
+
+ for (i = 0; i < 1000; i++) {
+ uint8_t reg, val;
+
+ reg = (uint8_t)g_test_rand_int_range(0, 16);
+ val = (uint8_t)g_test_rand_int_range(0, 256);
+
+ cmos_write(reg, val);
+ cmos_read(reg);
+ }
+}
+
int main(int argc, char **argv)
{
QTestState *s = NULL;
@@ -253,6 +269,7 @@ int main(int argc, char **argv)
qtest_add_func("/rtc/bcd/check-time", bcd_check_time);
qtest_add_func("/rtc/dec/check-time", dec_check_time);
qtest_add_func("/rtc/alarm-time", alarm_time);
+ qtest_add_func("/rtc/fuzz-registers", fuzz_registers);
ret = g_test_run();
if (s) {