mirror of
https://github.com/Motorhead1991/qemu.git
synced 2026-01-05 22:17:40 -07:00
The current build structure for migration tests is confusing. There is
the tests/migration directory, which contains two different guest code
implementations, one for the qtests (a-b-{bootblock|kernel}.S) and
another for the guestperf script (stress.c). One uses a Makefile,
while the other uses meson.
The next patches will add a new qtests/migration/ directory to hold
qtest code which will make the situation even more confusing.
Move the guest code used by qtests into a new qtests/migration/
directory and rename the old one to tests/migration-stress.
Reviewed-by: Peter Xu <peterx@redhat.com>
Signed-off-by: Fabiano Rosas <farosas@suse.de>
74 lines
1.8 KiB
ArmAsm
74 lines
1.8 KiB
ArmAsm
#
|
|
# Copyright (c) 2018 Red Hat, Inc. and/or its affiliates
|
|
#
|
|
# Author:
|
|
# Wei Huang <wei@redhat.com>
|
|
#
|
|
# This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
# See the COPYING file in the top-level directory.
|
|
#
|
|
# Note: Please make sure the compiler compiles the assembly code below with
|
|
# pc-relative address. Also the branch instructions should use relative
|
|
# addresses only.
|
|
|
|
#include "../migration-test.h"
|
|
|
|
.section .text
|
|
|
|
.globl _start
|
|
|
|
_start:
|
|
/* disable MMU to use phys mem address */
|
|
mrs x0, sctlr_el1
|
|
bic x0, x0, #(1<<0)
|
|
msr sctlr_el1, x0
|
|
isb
|
|
|
|
/* traverse test memory region */
|
|
mov x0, #ARM_TEST_MEM_START
|
|
mov x1, #ARM_TEST_MEM_END
|
|
|
|
/* output char 'A' to PL011 */
|
|
mov w3, 'A'
|
|
mov x2, #ARM_MACH_VIRT_UART
|
|
strb w3, [x2]
|
|
|
|
/* clean up memory */
|
|
mov w3, #0
|
|
mov x4, x0
|
|
clean:
|
|
strb w3, [x4]
|
|
add x4, x4, #TEST_MEM_PAGE_SIZE
|
|
cmp x4, x1
|
|
ble clean
|
|
|
|
/* w5 keeps a counter so we can limit the output speed */
|
|
mov w5, #0
|
|
|
|
/* main body */
|
|
mainloop:
|
|
mov x4, x0
|
|
|
|
innerloop:
|
|
/* increment the first byte of each page by 1 */
|
|
ldrb w3, [x4]
|
|
add w3, w3, #1
|
|
strb w3, [x4]
|
|
|
|
/* make sure QEMU user space can see consistent data as MMU is off */
|
|
dc civac, x4
|
|
|
|
add x4, x4, #TEST_MEM_PAGE_SIZE
|
|
cmp x4, x1
|
|
blt innerloop
|
|
|
|
add w5, w5, #1
|
|
and w5, w5, #0x1f
|
|
cmp w5, #0
|
|
bne mainloop
|
|
|
|
/* output char 'B' to PL011 */
|
|
mov w3, 'B'
|
|
strb w3, [x2]
|
|
|
|
b mainloop
|