diff options
author | Jon Mason <jdmason@kudzu.us> | 2019-03-05 17:32:19 -0500 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2019-03-12 11:57:41 -0700 |
commit | 6acb45106dafaf6895ad1fb086b6977c256518f6 (patch) | |
tree | 536f137b75f4af05410a0819d4d205255c32bda0 /meta | |
parent | 40c065800f0e84a860dc71f7690c596748b11a21 (diff) | |
download | poky-6acb45106dafaf6895ad1fb086b6977c256518f6.tar.gz |
qemuarm: Swap for an arm7ve (A15) configuration
Add new QEMU BSP for a Arm Cortex-A15 system and use this as qemuarm,
moving the old armv5te Versatile PB based machine to qemuarmv5.
The new machine uses the QEMU virt machine type, which should be
faster to emulate and updates the qemuarm support to a modern
architecture.
(From OE-Core rev: 6fc70eb4f3494bee2be10ee24fe3ea1c8b5ff988)
Signed-off-by: Jon Mason <jdmason@kudzu.us>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta')
-rw-r--r-- | meta/conf/machine/qemuarm.conf | 34 | ||||
-rw-r--r-- | meta/conf/machine/qemuarmv5.conf | 23 | ||||
-rw-r--r-- | meta/recipes-kernel/linux/linux-yocto-rt_4.19.bb | 2 | ||||
-rw-r--r-- | meta/recipes-kernel/linux/linux-yocto-rt_5.0.bb | 2 | ||||
-rw-r--r-- | meta/recipes-kernel/linux/linux-yocto-tiny_4.19.bb | 2 | ||||
-rw-r--r-- | meta/recipes-kernel/linux/linux-yocto-tiny_5.0.bb | 2 | ||||
-rw-r--r-- | meta/recipes-kernel/linux/linux-yocto_4.19.bb | 2 | ||||
-rw-r--r-- | meta/recipes-kernel/linux/linux-yocto_5.0.bb | 2 |
8 files changed, 52 insertions, 17 deletions
diff --git a/meta/conf/machine/qemuarm.conf b/meta/conf/machine/qemuarm.conf index a544312627..9555046189 100644 --- a/meta/conf/machine/qemuarm.conf +++ b/meta/conf/machine/qemuarm.conf | |||
@@ -1,21 +1,33 @@ | |||
1 | #@TYPE: Machine | 1 | #@TYPE: Machine |
2 | #@NAME: arm_versatile_926ejs | 2 | #@NAME: generic Arm Cortex-A15 machine |
3 | #@DESCRIPTION: arm_versatile_926ejs | 3 | #@DESCRIPTION: Machine configuration for running a generic armv7 |
4 | 4 | ||
5 | require conf/machine/include/tune-cortexa15.inc | ||
5 | require conf/machine/include/qemu.inc | 6 | require conf/machine/include/qemu.inc |
6 | require conf/machine/include/tune-arm926ejs.inc | ||
7 | #require conf/machine/include/tune-arm1136jf-s.inc | ||
8 | 7 | ||
9 | KERNEL_IMAGETYPE = "zImage" | 8 | KERNEL_IMAGETYPE = "zImage" |
10 | 9 | ||
11 | SERIAL_CONSOLES ?= "115200;ttyAMA0 115200;ttyAMA1" | 10 | SERIAL_CONSOLES ?= "115200;ttyAMA0 115200;hvc0" |
12 | 11 | ||
13 | # For runqemu | 12 | # For runqemu |
14 | QB_SYSTEM_NAME = "qemu-system-arm" | 13 | QB_SYSTEM_NAME = "qemu-system-arm" |
15 | QB_MACHINE = "-machine versatilepb" | 14 | QB_MEM = "-m 512" |
16 | QB_KERNEL_CMDLINE_APPEND = "console=ttyAMA0,115200 console=tty" | 15 | QB_MACHINE = "-machine virt" |
17 | QB_OPT_APPEND = "-show-cursor -usb -device usb-tablet" | 16 | QB_CPU = "-cpu cortex-a15" |
18 | # Add the 'virtio-rng-pci' device otherwise the guest may run out of entropy | 17 | # Standard Serial console |
18 | QB_KERNEL_CMDLINE_APPEND = "console=ttyAMA0" | ||
19 | # For graphics to work we need to define the VGA device as well as the necessary USB devices | ||
20 | QB_OPT_APPEND = "-show-cursor -device VGA,edid=on" | ||
21 | QB_OPT_APPEND += "-device qemu-xhci -device usb-tablet -device usb-kbd" | ||
22 | # Add the virtio RNG | ||
19 | QB_OPT_APPEND += "-object rng-random,filename=/dev/urandom,id=rng0 -device virtio-rng-pci,rng=rng0" | 23 | QB_OPT_APPEND += "-object rng-random,filename=/dev/urandom,id=rng0 -device virtio-rng-pci,rng=rng0" |
20 | PREFERRED_VERSION_linux-yocto ??= "4.18%" | 24 | # Virtio Networking support |
21 | QB_DTB = "${@oe.utils.version_less_or_equal('PREFERRED_VERSION_linux-yocto', '4.7', '', 'zImage-versatile-pb.dtb', d)}" | 25 | QB_TAP_OPT = "-netdev tap,id=net0,ifname=@TAP@,script=no,downscript=no" |
26 | QB_NETWORK_DEVICE = "-device virtio-net-device,netdev=net0,mac=@MAC@" | ||
27 | # Virtio block device | ||
28 | QB_ROOTFS_OPT = "-drive id=disk0,file=@ROOTFS@,if=none,format=raw -device virtio-blk-device,drive=disk0" | ||
29 | # Virtio serial console | ||
30 | QB_SERIAL_OPT = "-device virtio-serial-device -chardev null,id=virtcon -device virtconsole,chardev=virtcon" | ||
31 | QB_TCPSERIAL_OPT = "-device virtio-serial-device -chardev socket,id=virtcon,port=@PORT@,host=127.0.0.1 -device virtconsole,chardev=virtcon" | ||
32 | |||
33 | KMACHINE_qemuarm = "qemuarma15" | ||
diff --git a/meta/conf/machine/qemuarmv5.conf b/meta/conf/machine/qemuarmv5.conf new file mode 100644 index 0000000000..5f90accc24 --- /dev/null +++ b/meta/conf/machine/qemuarmv5.conf | |||
@@ -0,0 +1,23 @@ | |||
1 | #@TYPE: Machine | ||
2 | #@NAME: arm_versatile_926ejs | ||
3 | #@DESCRIPTION: arm_versatile_926ejs | ||
4 | |||
5 | require conf/machine/include/qemu.inc | ||
6 | require conf/machine/include/tune-arm926ejs.inc | ||
7 | #require conf/machine/include/tune-arm1136jf-s.inc | ||
8 | |||
9 | KERNEL_IMAGETYPE = "zImage" | ||
10 | |||
11 | SERIAL_CONSOLES ?= "115200;ttyAMA0 115200;ttyAMA1" | ||
12 | |||
13 | # For runqemu | ||
14 | QB_SYSTEM_NAME = "qemu-system-arm" | ||
15 | QB_MACHINE = "-machine versatilepb" | ||
16 | QB_KERNEL_CMDLINE_APPEND = "console=ttyAMA0,115200 console=tty" | ||
17 | QB_OPT_APPEND = "-show-cursor -usb -device usb-tablet" | ||
18 | # Add the 'virtio-rng-pci' device otherwise the guest may run out of entropy | ||
19 | QB_OPT_APPEND += "-object rng-random,filename=/dev/urandom,id=rng0 -device virtio-rng-pci,rng=rng0" | ||
20 | PREFERRED_VERSION_linux-yocto ??= "4.18%" | ||
21 | QB_DTB = "${@oe.utils.version_less_or_equal('PREFERRED_VERSION_linux-yocto', '4.7', '', 'zImage-versatile-pb.dtb', d)}" | ||
22 | |||
23 | KMACHINE_qemuarmv5 = "qemuarm" \ No newline at end of file | ||
diff --git a/meta/recipes-kernel/linux/linux-yocto-rt_4.19.bb b/meta/recipes-kernel/linux/linux-yocto-rt_4.19.bb index 07dc5b77a1..36761b9943 100644 --- a/meta/recipes-kernel/linux/linux-yocto-rt_4.19.bb +++ b/meta/recipes-kernel/linux/linux-yocto-rt_4.19.bb | |||
@@ -31,7 +31,7 @@ KCONF_BSP_AUDIT_LEVEL = "2" | |||
31 | 31 | ||
32 | LINUX_KERNEL_TYPE = "preempt-rt" | 32 | LINUX_KERNEL_TYPE = "preempt-rt" |
33 | 33 | ||
34 | COMPATIBLE_MACHINE = "(qemux86|qemux86-64|qemuarm|qemuarm64|qemuppc|qemumips)" | 34 | COMPATIBLE_MACHINE = "(qemux86|qemux86-64|qemuarm|qemuarma15|qemuarm64|qemuppc|qemumips)" |
35 | 35 | ||
36 | KERNEL_DEVICETREE_qemuarm = "versatile-pb.dtb" | 36 | KERNEL_DEVICETREE_qemuarm = "versatile-pb.dtb" |
37 | 37 | ||
diff --git a/meta/recipes-kernel/linux/linux-yocto-rt_5.0.bb b/meta/recipes-kernel/linux/linux-yocto-rt_5.0.bb index 8629e5a867..2487da88d2 100644 --- a/meta/recipes-kernel/linux/linux-yocto-rt_5.0.bb +++ b/meta/recipes-kernel/linux/linux-yocto-rt_5.0.bb | |||
@@ -31,7 +31,7 @@ KCONF_BSP_AUDIT_LEVEL = "2" | |||
31 | 31 | ||
32 | LINUX_KERNEL_TYPE = "preempt-rt" | 32 | LINUX_KERNEL_TYPE = "preempt-rt" |
33 | 33 | ||
34 | COMPATIBLE_MACHINE = "(qemux86|qemux86-64|qemuarm|qemuarm64|qemuppc|qemumips)" | 34 | COMPATIBLE_MACHINE = "(qemux86|qemux86-64|qemuarm|qemuarmv5|qemuarm64|qemuppc|qemumips)" |
35 | 35 | ||
36 | KERNEL_DEVICETREE_qemuarm = "versatile-pb.dtb" | 36 | KERNEL_DEVICETREE_qemuarm = "versatile-pb.dtb" |
37 | 37 | ||
diff --git a/meta/recipes-kernel/linux/linux-yocto-tiny_4.19.bb b/meta/recipes-kernel/linux/linux-yocto-tiny_4.19.bb index c6d1594a82..52dbabd7a4 100644 --- a/meta/recipes-kernel/linux/linux-yocto-tiny_4.19.bb +++ b/meta/recipes-kernel/linux/linux-yocto-tiny_4.19.bb | |||
@@ -24,7 +24,7 @@ PV = "${LINUX_VERSION}+git${SRCPV}" | |||
24 | SRC_URI = "git://git.yoctoproject.org/linux-yocto.git;branch=${KBRANCH};name=machine \ | 24 | SRC_URI = "git://git.yoctoproject.org/linux-yocto.git;branch=${KBRANCH};name=machine \ |
25 | git://git.yoctoproject.org/yocto-kernel-cache;type=kmeta;name=meta;branch=yocto-4.19;destsuffix=${KMETA}" | 25 | git://git.yoctoproject.org/yocto-kernel-cache;type=kmeta;name=meta;branch=yocto-4.19;destsuffix=${KMETA}" |
26 | 26 | ||
27 | COMPATIBLE_MACHINE = "qemux86|qemux86-64|qemuarm" | 27 | COMPATIBLE_MACHINE = "qemux86|qemux86-64|qemuarm|qemuarma15" |
28 | 28 | ||
29 | # Functionality flags | 29 | # Functionality flags |
30 | KERNEL_FEATURES = "" | 30 | KERNEL_FEATURES = "" |
diff --git a/meta/recipes-kernel/linux/linux-yocto-tiny_5.0.bb b/meta/recipes-kernel/linux/linux-yocto-tiny_5.0.bb index 086b53bbbe..04b319f1ca 100644 --- a/meta/recipes-kernel/linux/linux-yocto-tiny_5.0.bb +++ b/meta/recipes-kernel/linux/linux-yocto-tiny_5.0.bb | |||
@@ -24,7 +24,7 @@ PV = "${LINUX_VERSION}+git${SRCPV}" | |||
24 | SRC_URI = "git://git.yoctoproject.org/linux-yocto.git;branch=${KBRANCH};name=machine \ | 24 | SRC_URI = "git://git.yoctoproject.org/linux-yocto.git;branch=${KBRANCH};name=machine \ |
25 | git://git.yoctoproject.org/yocto-kernel-cache;type=kmeta;name=meta;branch=yocto-5.0;destsuffix=${KMETA}" | 25 | git://git.yoctoproject.org/yocto-kernel-cache;type=kmeta;name=meta;branch=yocto-5.0;destsuffix=${KMETA}" |
26 | 26 | ||
27 | COMPATIBLE_MACHINE = "qemux86|qemux86-64|qemuarm" | 27 | COMPATIBLE_MACHINE = "qemux86|qemux86-64|qemuarm|qemuarmv5" |
28 | 28 | ||
29 | # Functionality flags | 29 | # Functionality flags |
30 | KERNEL_FEATURES = "" | 30 | KERNEL_FEATURES = "" |
diff --git a/meta/recipes-kernel/linux/linux-yocto_4.19.bb b/meta/recipes-kernel/linux/linux-yocto_4.19.bb index b7e71395e6..aca9f15404 100644 --- a/meta/recipes-kernel/linux/linux-yocto_4.19.bb +++ b/meta/recipes-kernel/linux/linux-yocto_4.19.bb | |||
@@ -38,7 +38,7 @@ KCONF_BSP_AUDIT_LEVEL = "2" | |||
38 | 38 | ||
39 | KERNEL_DEVICETREE_qemuarm = "versatile-pb.dtb" | 39 | KERNEL_DEVICETREE_qemuarm = "versatile-pb.dtb" |
40 | 40 | ||
41 | COMPATIBLE_MACHINE = "qemuarm|qemuarm64|qemux86|qemuppc|qemumips|qemumips64|qemux86-64" | 41 | COMPATIBLE_MACHINE = "qemuarm|qemuarma15|qemuarm64|qemux86|qemuppc|qemumips|qemumips64|qemux86-64" |
42 | 42 | ||
43 | # Functionality flags | 43 | # Functionality flags |
44 | KERNEL_EXTRA_FEATURES ?= "features/netfilter/netfilter.scc" | 44 | KERNEL_EXTRA_FEATURES ?= "features/netfilter/netfilter.scc" |
diff --git a/meta/recipes-kernel/linux/linux-yocto_5.0.bb b/meta/recipes-kernel/linux/linux-yocto_5.0.bb index ab8e5aff50..787710d860 100644 --- a/meta/recipes-kernel/linux/linux-yocto_5.0.bb +++ b/meta/recipes-kernel/linux/linux-yocto_5.0.bb | |||
@@ -40,7 +40,7 @@ KCONF_BSP_AUDIT_LEVEL = "2" | |||
40 | 40 | ||
41 | KERNEL_DEVICETREE_qemuarm = "versatile-pb.dtb" | 41 | KERNEL_DEVICETREE_qemuarm = "versatile-pb.dtb" |
42 | 42 | ||
43 | COMPATIBLE_MACHINE = "qemuarm|qemuarm64|qemux86|qemuppc|qemumips|qemumips64|qemux86-64" | 43 | COMPATIBLE_MACHINE = "qemuarm|qemuarmv5|qemuarm64|qemux86|qemuppc|qemumips|qemumips64|qemux86-64" |
44 | 44 | ||
45 | # Functionality flags | 45 | # Functionality flags |
46 | KERNEL_EXTRA_FEATURES ?= "features/netfilter/netfilter.scc" | 46 | KERNEL_EXTRA_FEATURES ?= "features/netfilter/netfilter.scc" |