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