xref: /openbmc/qemu/tests/qtest/fuzz-e1000e-test.c (revision 2e3408b3cc7de4e87a9adafc8c19bfce3abec947)
17d6a4f12SPhilippe Mathieu-Daudé /*
27d6a4f12SPhilippe Mathieu-Daudé  * QTest testcase for e1000e device generated by fuzzer
37d6a4f12SPhilippe Mathieu-Daudé  *
47d6a4f12SPhilippe Mathieu-Daudé  * Copyright (c) 2021 Red Hat, Inc.
57d6a4f12SPhilippe Mathieu-Daudé  *
67d6a4f12SPhilippe Mathieu-Daudé  * SPDX-License-Identifier: GPL-2.0-or-later
77d6a4f12SPhilippe Mathieu-Daudé  */
87d6a4f12SPhilippe Mathieu-Daudé 
97d6a4f12SPhilippe Mathieu-Daudé #include "qemu/osdep.h"
107d6a4f12SPhilippe Mathieu-Daudé 
11*907b5105SMarc-André Lureau #include "libqtest.h"
127d6a4f12SPhilippe Mathieu-Daudé 
137d6a4f12SPhilippe Mathieu-Daudé /*
147d6a4f12SPhilippe Mathieu-Daudé  * https://bugs.launchpad.net/qemu/+bug/1879531
157d6a4f12SPhilippe Mathieu-Daudé  */
test_lp1879531_eth_get_rss_ex_dst_addr(void)167d6a4f12SPhilippe Mathieu-Daudé static void test_lp1879531_eth_get_rss_ex_dst_addr(void)
177d6a4f12SPhilippe Mathieu-Daudé {
187d6a4f12SPhilippe Mathieu-Daudé     QTestState *s;
197d6a4f12SPhilippe Mathieu-Daudé 
207d6a4f12SPhilippe Mathieu-Daudé     s = qtest_init("-nographic -monitor none -serial none -M pc-q35-5.0");
217d6a4f12SPhilippe Mathieu-Daudé 
227d6a4f12SPhilippe Mathieu-Daudé     qtest_outl(s, 0xcf8, 0x80001010);
237d6a4f12SPhilippe Mathieu-Daudé     qtest_outl(s, 0xcfc, 0xe1020000);
247d6a4f12SPhilippe Mathieu-Daudé     qtest_outl(s, 0xcf8, 0x80001004);
257d6a4f12SPhilippe Mathieu-Daudé     qtest_outw(s, 0xcfc, 0x7);
267d6a4f12SPhilippe Mathieu-Daudé     qtest_writeb(s, 0x25, 0x86);
277d6a4f12SPhilippe Mathieu-Daudé     qtest_writeb(s, 0x26, 0xdd);
287d6a4f12SPhilippe Mathieu-Daudé     qtest_writeb(s, 0x4f, 0x2b);
297d6a4f12SPhilippe Mathieu-Daudé 
307d6a4f12SPhilippe Mathieu-Daudé     qtest_writel(s, 0xe1020030, 0x190002e1);
317d6a4f12SPhilippe Mathieu-Daudé     qtest_writew(s, 0xe102003a, 0x0807);
327d6a4f12SPhilippe Mathieu-Daudé     qtest_writel(s, 0xe1020048, 0x12077cdd);
337d6a4f12SPhilippe Mathieu-Daudé     qtest_writel(s, 0xe1020400, 0xba077cdd);
347d6a4f12SPhilippe Mathieu-Daudé     qtest_writel(s, 0xe1020420, 0x190002e1);
357d6a4f12SPhilippe Mathieu-Daudé     qtest_writel(s, 0xe1020428, 0x3509d807);
367d6a4f12SPhilippe Mathieu-Daudé     qtest_writeb(s, 0xe1020438, 0xe2);
377d6a4f12SPhilippe Mathieu-Daudé     qtest_writeb(s, 0x4f, 0x2b);
387d6a4f12SPhilippe Mathieu-Daudé     qtest_quit(s);
397d6a4f12SPhilippe Mathieu-Daudé }
407d6a4f12SPhilippe Mathieu-Daudé 
main(int argc,char ** argv)417d6a4f12SPhilippe Mathieu-Daudé int main(int argc, char **argv)
427d6a4f12SPhilippe Mathieu-Daudé {
437d6a4f12SPhilippe Mathieu-Daudé     const char *arch = qtest_get_arch();
447d6a4f12SPhilippe Mathieu-Daudé 
457d6a4f12SPhilippe Mathieu-Daudé     g_test_init(&argc, &argv, NULL);
467d6a4f12SPhilippe Mathieu-Daudé 
477d6a4f12SPhilippe Mathieu-Daudé     if (strcmp(arch, "i386") == 0 || strcmp(arch, "x86_64") == 0) {
487d6a4f12SPhilippe Mathieu-Daudé         qtest_add_func("fuzz/test_lp1879531_eth_get_rss_ex_dst_addr",
497d6a4f12SPhilippe Mathieu-Daudé                        test_lp1879531_eth_get_rss_ex_dst_addr);
507d6a4f12SPhilippe Mathieu-Daudé     }
517d6a4f12SPhilippe Mathieu-Daudé 
527d6a4f12SPhilippe Mathieu-Daudé     return g_test_run();
537d6a4f12SPhilippe Mathieu-Daudé }
54