From: David Gibson <david@gibson.dropbear.id.au>
To: peter.maydell@linaro.org
Cc: agraf@suse.de, qemu-ppc@nongnu.org, qemu-devel@nongnu.org,
Thomas Huth <thuth@redhat.com>,
David Gibson <david@gibson.dropbear.id.au>
Subject: [Qemu-devel] [PULL 02/29] tests: Test IPv6 and ppc64 in the PXE tester
Date: Thu, 6 Oct 2016 23:02:48 +1100 [thread overview]
Message-ID: <1475755395-27307-3-git-send-email-david@gibson.dropbear.id.au> (raw)
In-Reply-To: <1475755395-27307-1-git-send-email-david@gibson.dropbear.id.au>
From: Thomas Huth <thuth@redhat.com>
The firmware of the pseries machine, SLOF, is able to load files via
IPv6 networking, too. So to test both, network bootloading on ppc64
and IPv6 (via Slirp) , let's add some PXE tests for this environment,
too. Since we can not use the normal x86 boot sector for network boot
loading, we use a simple Forth script on ppc64 instead.
Signed-off-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
---
tests/Makefile.include | 1 +
tests/boot-sector.c | 9 +++++++++
tests/pxe-test.c | 22 +++++++++++++++-------
3 files changed, 25 insertions(+), 7 deletions(-)
diff --git a/tests/Makefile.include b/tests/Makefile.include
index 8162f6f..77d42d7 100644
--- a/tests/Makefile.include
+++ b/tests/Makefile.include
@@ -271,6 +271,7 @@ check-qtest-ppc64-y += tests/drive_del-test$(EXESUF)
check-qtest-ppc64-y += tests/postcopy-test$(EXESUF)
check-qtest-ppc64-y += tests/boot-serial-test$(EXESUF)
check-qtest-ppc64-y += tests/rtas-test$(EXESUF)
+check-qtest-ppc64-y += tests/pxe-test$(EXESUF)
check-qtest-sh4-y = tests/endianness-test$(EXESUF)
diff --git a/tests/boot-sector.c b/tests/boot-sector.c
index 3ffe298..e3193c0 100644
--- a/tests/boot-sector.c
+++ b/tests/boot-sector.c
@@ -77,6 +77,15 @@ int boot_sector_init(const char *fname)
fprintf(stderr, "Couldn't open \"%s\": %s", fname, strerror(errno));
return 1;
}
+
+ /* For Open Firmware based system, we can use a Forth script instead */
+ if (strcmp(qtest_get_arch(), "ppc64") == 0) {
+ memset(boot_sector, ' ', sizeof boot_sector);
+ sprintf((char *)boot_sector, "\\ Bootscript\n%x %x c! %x %x c!\n",
+ LOW(SIGNATURE), BOOT_SECTOR_ADDRESS + SIGNATURE_OFFSET,
+ HIGH(SIGNATURE), BOOT_SECTOR_ADDRESS + SIGNATURE_OFFSET + 1);
+ }
+
fwrite(boot_sector, 1, sizeof boot_sector, f);
fclose(f);
return 0;
diff --git a/tests/pxe-test.c b/tests/pxe-test.c
index b2cc355..0bdb7a1 100644
--- a/tests/pxe-test.c
+++ b/tests/pxe-test.c
@@ -21,14 +21,14 @@
static const char *disk = "tests/pxe-test-disk.raw";
-static void test_pxe_one(const char *params)
+static void test_pxe_one(const char *params, bool ipv6)
{
char *args;
- args = g_strdup_printf("-machine accel=tcg "
- "-netdev user,id=" NETNAME ",tftp=./,bootfile=%s "
- "%s ",
- disk, params);
+ args = g_strdup_printf("-machine accel=tcg -boot order=n "
+ "-netdev user,id=" NETNAME ",tftp=./,bootfile=%s,"
+ "ipv4=%s,ipv6=%s %s", disk, ipv6 ? "off" : "on",
+ ipv6 ? "on" : "off", params);
qtest_start(args);
boot_sector_test();
@@ -38,12 +38,17 @@ static void test_pxe_one(const char *params)
static void test_pxe_e1000(void)
{
- test_pxe_one("-device e1000,netdev=" NETNAME);
+ test_pxe_one("-device e1000,netdev=" NETNAME, false);
}
static void test_pxe_virtio_pci(void)
{
- test_pxe_one("-device virtio-net-pci,netdev=" NETNAME);
+ test_pxe_one("-device virtio-net-pci,netdev=" NETNAME, false);
+}
+
+static void test_pxe_spapr_vlan(void)
+{
+ test_pxe_one("-vga none -device spapr-vlan,netdev=" NETNAME, true);
}
int main(int argc, char *argv[])
@@ -60,6 +65,9 @@ int main(int argc, char *argv[])
if (strcmp(arch, "i386") == 0 || strcmp(arch, "x86_64") == 0) {
qtest_add_func("pxe/e1000", test_pxe_e1000);
qtest_add_func("pxe/virtio", test_pxe_virtio_pci);
+ } else if (strcmp(arch, "ppc64") == 0) {
+ qtest_add_func("pxe/virtio", test_pxe_virtio_pci);
+ qtest_add_func("pxe/spapr-vlan", test_pxe_spapr_vlan);
}
ret = g_test_run();
boot_sector_cleanup(disk);
--
2.7.4
next prev parent reply other threads:[~2016-10-06 12:03 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-10-06 12:02 [Qemu-devel] [PULL 00/29] ppc-for-2.8 queue 20161006 David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 01/29] spapr_vscsi: fix build error introduced by f19661c8 David Gibson
2016-10-06 12:02 ` David Gibson [this message]
2016-10-06 12:02 ` [Qemu-devel] [PULL 03/29] pseries: Add 2.8 machine type, set up compatibility macros David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 04/29] hw/ppc/spapr: Move code related to "ibm, pa-features" to a separate function David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 05/29] hw/ppc/spapr: Fix the selection of the processor features David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 06/29] ppc: Check the availability of transactional memory David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 07/29] target-ppc: Implement mfvsrld instruction David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 08/29] target-ppc: Implement mtvsrdd instruction David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 09/29] target-ppc: improve lxvw4x implementation David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 10/29] target-ppc: improve stxvw4x implementation David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 11/29] target-ppc: add lxvh8x instruction David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 12/29] target-ppc: add stxvh8x instruction David Gibson
2016-10-06 12:02 ` [Qemu-devel] [PULL 13/29] target-ppc: add lxvb16x instruction David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 14/29] target-ppc: add stxvb16x instruction David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 15/29] target-ppc: fix invalid mask - cmpl, bctar David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 16/29] target-ppc: add vector compare not equal instructions David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 17/29] target-ppc: add vclzlsbb/vctzlsbb instructions David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 18/29] target-ppc: Implement mtvsrws instruction David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 19/29] MAINTAINERS: Add two more ppc related files David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 20/29] target-ppc/kvm: Add a wrapper function to check for KVM-PR David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 21/29] target-ppc/kvm: Enable transactional memory on POWER8 with KVM-HV, too David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 22/29] target-ppc: fix vmx instruction type/type2 David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 23/29] libqos: add PPC64 PCI support David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 24/29] libqos: add PCI management in qtest_vboot()/qtest_shutdown() David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 25/29] libqos: use generic qtest_shutdown() David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 26/29] tests: enable ohci/uhci/xhci tests on PPC64 David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 27/29] spapr: fix check of cpu alias name in spapr_get_cpu_core_type() David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 28/29] tests/pxe: Use -nodefaults to speed up ppc64/ipv6 pxe test David Gibson
2016-10-06 12:03 ` [Qemu-devel] [PULL 29/29] hw/ppc/spapr: Use POWER8 by default for the pseries-2.8 machine David Gibson
2016-10-06 13:35 ` [Qemu-devel] [PULL 00/29] ppc-for-2.8 queue 20161006 Peter Maydell
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1475755395-27307-3-git-send-email-david@gibson.dropbear.id.au \
--to=david@gibson.dropbear.id.au \
--cc=agraf@suse.de \
--cc=peter.maydell@linaro.org \
--cc=qemu-devel@nongnu.org \
--cc=qemu-ppc@nongnu.org \
--cc=thuth@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).