Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / lldb / docs / use / qemu-testing.rst
blob6e282141864cc1d8e26e9ddfc3dd7c68810a0b00
1 Testing LLDB using QEMU
2 =======================
4 QEMU system mode emulation
5 --------------------------
7 QEMU can be used to test LLDB in an emulation environment in the absence of
8 actual hardware. This page describes instructions to help setup a QEMU emulation
9 environment for testing LLDB.
11 The scripts under llvm-project/lldb/scripts/lldb-test-qemu can quickly help
12 setup a virtual LLDB testing environment using QEMU. The scripts currently work
13 with Arm or AArch64, but support for other architectures can be added easily.
15 * **setup.sh** is used to build the Linux kernel image and QEMU system emulation executable(s) from source.
16 * **rootfs.sh** is used to generate Ubuntu root file system images to be used for QEMU system mode emulation.
17 * **run-qemu.sh** utilizes QEMU to boot a Linux kernel image with a root file system image.
19 Once we have booted our kernel we can run lldb-server in emulation environment.
20 Ubuntu Bionic/Focal x86_64 host was used to test these scripts instructions in this
21 document. Please update it according to your host distribution/architecture.
23 .. note::
24   Instructions on this page and QEMU helper scripts are verified on a Ubuntu Bionic/Focal (x86_64) host. Moreover, scripts require sudo/root permissions for installing dependencies and setting up QEMU host/guest network.
26 Given below are some examples of common use-cases of LLDB QEMU testing
27 helper scripts:
29 Create Ubuntu root file system image for QEMU system emulation with rootfs.sh
30 --------------------------------------------------------------------------------
32 **Example:** generate Ubuntu Bionic (armhf) rootfs image of size 1 GB
35   $ bash rootfs.sh --arch armhf --distro bionic --size 1G
37 **Example:** generate Ubuntu Focal (arm64) rootfs image of size 2 GB
40   $ bash rootfs.sh --arch arm64 --distro focal --size 2G
42 rootfs.sh has been tested for generating Ubuntu Bionic and Focal images but they can be used to generate rootfs images of other Debian Linux distribution.
44 rootfs.sh defaults username of generated image to your current username on host computer.
47 Build QEMU or cross compile Linux kernel from source using setup.sh
48 -----------------------------------------------------------------------
50 **Example:** Build QEMU binaries and Arm/AArch64 Linux kernel image
53 $ bash setup.sh --qemu --kernel arm
54 $ bash setup.sh --qemu --kernel arm64
56 **Example:** Build Linux kernel image only
59 $ bash setup.sh --kernel arm
60 $ bash setup.sh --kernel arm64
62 **Example:** Build qemu-system-arm and qemu-system-aarch64 binaries.
65 $ bash setup.sh --qemu
67 **Example:** Remove qemu.git, linux.git and linux.build from working directory
70 $ bash setup.sh --clean
73 Run QEMU Arm or AArch64 system emulation using run-qemu.sh
74 ----------------------------------------------------------
75 run-qemu.sh has following dependencies:
77 * Follow https://wiki.qemu.org/Documentation/Networking/NAT and set up bridge
78   networking for QEMU.
80 * Make sure /etc/qemu-ifup script is available with executable permissions.
82 * QEMU binaries must be built from source using setup.sh or provided via --qemu
83   commandline argument.
85 * Linux kernel image must be built from source using setup.sh or provided via
86   --kernel commandline argument.
88 * linux.build and qemu.git folder must be present in current directory if
89   setup.sh was used to build Linux kernel and QEMU binaries.
91 * --sve option will enable AArch64 SVE mode.
93 * --sme option will enable AArch64 SME mode (SME requires SVE, so this will also
94   be enabled).
96 * --mte option will enable AArch64 MTE (memory tagging) mode
97   (can be used on its own or in addition to --sve).
100 **Example:** Run QEMU Arm or AArch64 system emulation using run-qemu.sh
103   $ sudo bash run-qemu.sh --arch arm --rootfs <path of rootfs image>
104   $ sudo bash run-qemu.sh --arch arm64 --rootfs <path of rootfs image>
106 **Example:** Run QEMU with kernel image and qemu binary provided using commandline
109   $ sudo bash run-qemu.sh --arch arm64 --rootfs <path of rootfs image> \
110   --kernel <path of Linux kernel image> --qemu <path of QEMU binary>
113 Steps for running lldb-server in QEMU system emulation environment
114 ------------------------------------------------------------------
116 Using Bridge Networking
117 ***********************
119 * Make sure bridge networking is enabled between host machine and QEMU VM
121 * Find out ip address assigned to eth0 in emulation environment
123 * Setup ssh access between host machine and emulation environment
125 * Login emulation environment and install dependencies
129   $ sudo apt install python-dev libedit-dev libncurses5-dev libexpat1-dev
131 * Cross compile LLDB server for AArch64 Linux: Please visit https://lldb.llvm.org/resources/build.html for instructions on how to cross compile LLDB server.
133 * Transfer LLDB server executable to emulation environment
137   $ scp lldb-server username@ip-address-of-emulation-environment:/home/username
139 * Run lldb-server inside QEMU VM
141 * Try connecting to lldb-server running inside QEMU VM with selected ip:port
143 Without Bridge Networking
144 *************************
146 Without bridge networking you will have to forward individual ports from the VM
147 to the host (refer to QEMU's manuals for the specific options).
149 * At least one to connect to the intial ``lldb-server``.
150 * One more if you want to use ``lldb-server`` in ``platform mode``, and have it
151   start a ``gdbserver`` instance for you.
152 * A bunch more if you want to run tests against the ``lldb-server`` platform.
154 If you are doing either of the latter 2 you should also restrict what ports
155 ``lldb-server tries`` to use, otherwise it will randomly pick one that is almost
156 certainly not forwarded. An example of this is shown below.
160   $ lldb-server plaform --server --listen 0.0.0.0:54321 \
161     --min-gdbserver-port 49140 --max-gdbserver-port 49150
163 The result of this is that:
165 * ``lldb-server`` platform mode listens externally on port ``54321``.
167 * When it is asked to start a new gdbserver mode instance, it will use a port
168   in the range ``49140`` to ``49150``.
170 Your VM configuration should have ports ``54321``, and ``49140`` to ``49150``
171 forwarded for this to work.
173 .. note::
174   These options are used to create a "port map" within ``lldb-server``.
175   Unfortunately this map is not shared across all the processes it may create,
176   and across a few uses you may run out of valid ports. To work around this,
177   restart the platform every so often, especially after running a set of tests.