From: Xiaojuan Yang <yangxiaojuan@loongson.cn>
To: qemu-devel@nongnu.org
Cc: mark.cave-ayland@ilande.co.uk, richard.henderson@linaro.org,
Song Gao <gaosong@loongson.cn>
Subject: [RFC PATCH v6 01/29] target/loongarch: Add system emulation introduction
Date: Fri, 25 Feb 2022 03:02:40 -0500 [thread overview]
Message-ID: <20220225080308.1405-2-yangxiaojuan@loongson.cn> (raw)
In-Reply-To: <20220225080308.1405-1-yangxiaojuan@loongson.cn>
Signed-off-by: Xiaojuan Yang <yangxiaojuan@loongson.cn>
Signed-off-by: Song Gao <gaosong@loongson.cn>
---
MAINTAINERS | 8 +++++++
docs/system/loongarch/loongson3.rst | 37 +++++++++++++++++++++++++++++
target/loongarch/README | 28 ++++++++++++++++++++++
3 files changed, 73 insertions(+)
create mode 100644 docs/system/loongarch/loongson3.rst
diff --git a/MAINTAINERS b/MAINTAINERS
index 568fb731f7..df3d738d17 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -1115,6 +1115,14 @@ F: hw/net/*i82596*
F: include/hw/net/lasi_82596.h
F: pc-bios/hppa-firmware.img
+LoongArch Machines
+------------------
+Virt
+M: Xiaojuan Yang <yangxiaojuan@loongson.cn>
+M: Song Gao <gaosong@loongson.cn>
+S: Maintained
+F: docs/system/loongarch/loongson3.rst
+
M68K Machines
-------------
an5206
diff --git a/docs/system/loongarch/loongson3.rst b/docs/system/loongarch/loongson3.rst
new file mode 100644
index 0000000000..367fff9d9d
--- /dev/null
+++ b/docs/system/loongarch/loongson3.rst
@@ -0,0 +1,37 @@
+loongson3 virt generic platform (``virt``)
+====================================================
+
+The ``virt`` machine use gpex host bridge, and there are some
+emulated devices on virt board, such as loongson7a RTC device,
+IOAPIC device, ACPI device and so on.
+
+Supported devices
+-----------------
+
+The ``virt`` machine supports:
+- Gpex host bridge
+- Ls7a RTC device
+- Ls7a IOAPIC device
+- Ls7a ACPI device
+- Fw_cfg device
+- PCI/PCIe devices
+- Memory device
+- CPU device. Type: Loongson-3A5000.
+
+CPU and machine Type
+--------------------
+
+The ``qemu-system-loongarch64`` provides emulation for virt
+machine. You can specify the machine type ``virt`` and
+cpu type ``Loongson-3A5000``.
+
+Boot options
+------------
+
+Now the ``virt`` machine can start using -bios parameter:
+
+.. code-block:: bash
+
+ $ qemu-system-loongarch64 -M virt -cpu Loongson-3A5000 -smp 2 -m 1G \
+ -display none -serial stdio \
+ -bios loongarch_bios.bin
diff --git a/target/loongarch/README b/target/loongarch/README
index 383db6cc15..de44d39561 100644
--- a/target/loongarch/README
+++ b/target/loongarch/README
@@ -71,6 +71,34 @@
./qemu-loongarch64 /opt/clfs/usr/bin/pwd
...
+- System emulation
+
+ Mainly emulate a virt 3A5000 board and ls7a bridge that is not exactly the same as the host.
+ 3A5000 support multiple interrupt cascading while here we just emulate the extioi interrupt
+ cascading. LS7A1000 host bridge support multiple devices, such as sata, gmac, uart, rtc
+ and so on. But we just realize the rtc. Others use the qemu common devices. It does not affect
+ the general use. We also introduced the emulation of devices at docs/system/loongarch/loongson3.rst.
+
+ You can compile the binaries by youself or just get all required binaries from the github for testing.
+
+ 1.Download kernel and the cross-tools.(vmlinux)
+
+ https://github.com/loongson/linux/tree/loongarch-next
+ https://github.com/loongson/build-tools/releases/latest/download/loongarch64-clfs-20211202-cross-tools.tar.xz
+
+ 2.Download uefi code.(loongarch_bios.bin)
+
+ https://github.com/loongson/edk2/tree/LoongArch
+ https://github.com/loongson/edk2-platforms
+
+ 3.Download the clfs-system and make a ramdisk with busybox.(ramdisk)
+
+ 4.Run with command,eg:
+
+ ./build/qemu-system-loongarch64 -m 4G -smp 4 --cpu Loongson-3A5000 --machine loongson3-ls7a -kernel ./vmlinux -initrd ./ramdisk -append "root=/dev/ram console=ttyS0,115200 rdinit=/sbin/init loglevel=8" -monitor tcp::4000,server,nowait -nographic
+
+All binaries can get from here directly:
+ git clone https://github.com/yangxiaojuan-loongson/qemu-binary
- Note.
We can get the latest LoongArch documents or LoongArch tools at https://github.com/loongson/
--
2.27.0
next prev parent reply other threads:[~2022-02-25 8:15 UTC|newest]
Thread overview: 36+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-02-25 8:02 [RFC PATCH v6 00/29] Add LoongArch softmmu support Xiaojuan Yang
2022-02-25 8:02 ` Xiaojuan Yang [this message]
2022-02-25 8:02 ` [RFC PATCH v6 02/29] target/loongarch: Add CSRs definition Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 03/29] target/loongarch: Add basic vmstate description of CPU Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 04/29] target/loongarch: Implement qmp_query_cpu_definitions() Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 05/29] target/loongarch: Add constant timer support Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 06/29] target/loongarch: Add MMU support for LoongArch CPU Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 07/29] target/loongarch: Add LoongArch CSR instruction Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 08/29] target/loongarch: Add LoongArch IOCSR instruction Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 09/29] target/loongarch: Add TLB instruction support Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 10/29] target/loongarch: Add other core instructions support Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 11/29] target/loongarch: Add LoongArch interrupt and exception handle Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 12/29] target/loongarch: Add timer related instructions support Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 13/29] target/loongarch: Add gdb support Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 14/29] hw/loongarch: Add support loongson3 virt machine type Xiaojuan Yang
2022-03-19 12:14 ` Mark Cave-Ayland
2022-02-25 8:02 ` [RFC PATCH v6 15/29] hw/loongarch: Add LoongArch cpu interrupt support(CPUINTC) Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 16/29] hw/loongarch: Add LoongArch ipi interrupt support(IPI) Xiaojuan Yang
2022-03-19 12:16 ` Mark Cave-Ayland
2022-02-25 8:02 ` [RFC PATCH v6 17/29] hw/intc: Add LoongArch ls7a interrupt controller support(PCH-PIC) Xiaojuan Yang
2022-03-19 12:20 ` Mark Cave-Ayland
2022-02-25 8:02 ` [RFC PATCH v6 18/29] hw/intc: Add LoongArch ls7a msi interrupt controller support(PCH-MSI) Xiaojuan Yang
2022-02-25 8:02 ` [RFC PATCH v6 19/29] hw/intc: Add LoongArch extioi interrupt controller(EIOINTC) Xiaojuan Yang
2022-03-19 12:25 ` Mark Cave-Ayland
2022-02-25 8:02 ` [RFC PATCH v6 20/29] hw/loongarch: Add irq hierarchy for the system Xiaojuan Yang
2022-02-25 8:03 ` [RFC PATCH v6 21/29] Enable common virtio pci support for LoongArch Xiaojuan Yang
2022-02-25 8:03 ` [RFC PATCH v6 22/29] hw/loongarch: Add some devices support for 3A5000 Xiaojuan Yang
2022-02-25 8:03 ` [RFC PATCH v6 23/29] hw/loongarch: Add LoongArch ls7a rtc device support Xiaojuan Yang
2022-03-19 12:35 ` Mark Cave-Ayland
2022-02-25 8:03 ` [RFC PATCH v6 24/29] hw/loongarch: Add default bios startup support Xiaojuan Yang
2022-02-25 8:03 ` [RFC PATCH v6 25/29] hw/loongarch: Add -kernel and -initrd options support Xiaojuan Yang
2022-02-25 8:03 ` [RFC PATCH v6 26/29] hw/loongarch: Add LoongArch smbios support Xiaojuan Yang
2022-02-25 8:03 ` [RFC PATCH v6 27/29] hw/loongarch: Add LoongArch acpi support Xiaojuan Yang
2022-02-25 8:03 ` [RFC PATCH v6 28/29] hw/loongarch: Add fdt support Xiaojuan Yang
2022-02-25 8:03 ` [RFC PATCH v6 29/29] tests/tcg/loongarch64: Add hello/memory test in loongarch64 system Xiaojuan Yang
2022-03-11 2:03 ` [RFC PATCH v6 00/29] Add LoongArch softmmu support yangxiaojuan
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=20220225080308.1405-2-yangxiaojuan@loongson.cn \
--to=yangxiaojuan@loongson.cn \
--cc=gaosong@loongson.cn \
--cc=mark.cave-ayland@ilande.co.uk \
--cc=qemu-devel@nongnu.org \
--cc=richard.henderson@linaro.org \
/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).