* [Qemu-devel] [PATCH v2 1/2] Acceptance tests: use linux-3.6 and set vm memory to 4GiB
@ 2019-01-28 1:15 Li Zhijian
2019-01-28 1:15 ` [Qemu-devel] [PATCH v2 2/2] Acceptance tests: expect boot to extract 2GiB+ initrd with linux-v4.16 Li Zhijian
` (2 more replies)
0 siblings, 3 replies; 5+ messages in thread
From: Li Zhijian @ 2019-01-28 1:15 UTC (permalink / raw)
To: qemu-devel
Cc: Li Zhijian, Wainer dos Santos Moschetta, Caio Carrara,
Cleber Rosa, Eduardo Habkost, Philippe Mathieu-Daudé
QEMU have already supported to load up to 4G initrd if the sepcified memory is
enough and XLF_CAN_BE_LOADED_ABOVE_4G is set by guest kernel
linux-3.6 kernel shipped by Fedora-18 cannot support xldflags so that it
cannot support loading more than 2GiB initrd
CC: Wainer dos Santos Moschetta <wainersm@redhat.com>
CC: Caio Carrara <ccarrara@redhat.com>
CC: Cleber Rosa <crosa@redhat.com>
CC: Eduardo Habkost <ehabkost@redhat.com>
CC: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Li Zhijian <lizhijian@cn.fujitsu.com>
---
V2: fix typos
---
tests/acceptance/linux_initrd.py | 14 ++++++++------
1 file changed, 8 insertions(+), 6 deletions(-)
diff --git a/tests/acceptance/linux_initrd.py b/tests/acceptance/linux_initrd.py
index 737355c..b283715 100644
--- a/tests/acceptance/linux_initrd.py
+++ b/tests/acceptance/linux_initrd.py
@@ -24,14 +24,16 @@ class LinuxInitrd(Test):
timeout = 60
- def test_with_2gib_file_should_exit_error_msg(self):
+ def test_with_2gib_file_should_exit_error_msg_with_linux_v3_6(self):
"""
Pretends to boot QEMU with an initrd file with size of 2GiB
and expect it exits with error message.
+ Fedora-18 shipped with linux-3.6 which have not supported xloadflags
+ cannot support more than 2GiB initrd.
"""
- kernel_url = ('https://mirrors.kernel.org/fedora/releases/28/'
- 'Everything/x86_64/os/images/pxeboot/vmlinuz')
- kernel_hash = '238e083e114c48200f80d889f7e32eeb2793e02a'
+ kernel_url = ('https://archives.fedoraproject.org/pub/archive/fedora/li'
+ 'nux/releases/18/Fedora/x86_64/os/images/pxeboot/vmlinuz')
+ kernel_hash = '41464f68efe42b9991250bed86c7081d2ccdbb21'
kernel_path = self.fetch_asset(kernel_url, asset_hash=kernel_hash)
max_size = 2 * (1024 ** 3) - 1
@@ -39,8 +41,8 @@ class LinuxInitrd(Test):
initrd.seek(max_size)
initrd.write(b'\0')
initrd.flush()
- cmd = "%s -kernel %s -initrd %s" % (self.qemu_bin, kernel_path,
- initrd.name)
+ cmd = "%s -kernel %s -initrd %s -m 4096" % (
+ self.qemu_bin, kernel_path, initrd.name)
res = run(cmd, ignore_status=True)
self.assertEqual(res.exit_status, 1)
expected_msg = r'.*initrd is too large.*max: \d+, need %s.*' % (
--
2.7.4
^ permalink raw reply related [flat|nested] 5+ messages in thread
* [Qemu-devel] [PATCH v2 2/2] Acceptance tests: expect boot to extract 2GiB+ initrd with linux-v4.16
2019-01-28 1:15 [Qemu-devel] [PATCH v2 1/2] Acceptance tests: use linux-3.6 and set vm memory to 4GiB Li Zhijian
@ 2019-01-28 1:15 ` Li Zhijian
2019-02-22 17:28 ` Cleber Rosa
2019-01-30 17:14 ` [Qemu-devel] [PATCH v2 1/2] Acceptance tests: use linux-3.6 and set vm memory to 4GiB Wainer dos Santos Moschetta
2019-02-22 17:27 ` Cleber Rosa
2 siblings, 1 reply; 5+ messages in thread
From: Li Zhijian @ 2019-01-28 1:15 UTC (permalink / raw)
To: qemu-devel
Cc: Li Zhijian, Wainer dos Santos Moschetta, Caio Carrara,
Cleber Rosa, Eduardo Habkost, Philippe Mathieu-Daudé
XLF_CAN_BE_LOADED_ABOVE_4G is set on vmlinuz shipped by Fedora-28 so that
it's allowed to be loaded below 4 GB address.
timeout is updated to 5 minutes as well since we need more time to load a
large initrd to the guest
CC: Wainer dos Santos Moschetta <wainersm@redhat.com>
CC: Caio Carrara <ccarrara@redhat.com>
CC: Cleber Rosa <crosa@redhat.com>
CC: Eduardo Habkost <ehabkost@redhat.com>
CC: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Li Zhijian <lizhijian@cn.fujitsu.com>
---
V2: fix typos
---
tests/acceptance/linux_initrd.py | 37 ++++++++++++++++++++++++++++++++++++-
1 file changed, 36 insertions(+), 1 deletion(-)
diff --git a/tests/acceptance/linux_initrd.py b/tests/acceptance/linux_initrd.py
index b283715..29f5b06 100644
--- a/tests/acceptance/linux_initrd.py
+++ b/tests/acceptance/linux_initrd.py
@@ -8,6 +8,7 @@
# This work is licensed under the terms of the GNU GPL, version 2 or
# later. See the COPYING file in the top-level directory.
+import logging
import tempfile
from avocado.utils.process import run
@@ -22,7 +23,7 @@ class LinuxInitrd(Test):
:avocado: tags=x86_64
"""
- timeout = 60
+ timeout = 300
def test_with_2gib_file_should_exit_error_msg_with_linux_v3_6(self):
"""
@@ -48,3 +49,37 @@ class LinuxInitrd(Test):
expected_msg = r'.*initrd is too large.*max: \d+, need %s.*' % (
max_size + 1)
self.assertRegex(res.stderr_text, expected_msg)
+
+ def test_with_2gib_file_should_work_with_linux_v4_16(self):
+ """
+ QEMU has supported up to 4 GiB initrd for recent kernel
+ Expect guest can reach 'Unpacking initramfs...'
+ """
+ kernel_url = ('https://mirrors.kernel.org/fedora/releases/28/'
+ 'Everything/x86_64/os/images/pxeboot/vmlinuz')
+ kernel_hash = '238e083e114c48200f80d889f7e32eeb2793e02a'
+ kernel_path = self.fetch_asset(kernel_url, asset_hash=kernel_hash)
+ max_size = 2 * (1024 ** 3) + 1
+
+ with tempfile.NamedTemporaryFile() as initrd:
+ initrd.seek(max_size)
+ initrd.write(b'\0')
+ initrd.flush()
+
+ self.vm.set_machine('pc')
+ self.vm.set_console()
+ kernel_command_line = 'console=ttyS0'
+ self.vm.add_args('-kernel', kernel_path,
+ '-append', kernel_command_line,
+ '-initrd', initrd.name,
+ '-m', '5120')
+ self.vm.launch()
+ console = self.vm.console_socket.makefile()
+ console_logger = logging.getLogger('console')
+ while True:
+ msg = console.readline()
+ console_logger.debug(msg.strip())
+ if 'Unpacking initramfs...' in msg:
+ break
+ if 'Kernel panic - not syncing' in msg:
+ self.fail("Kernel panic reached")
--
2.7.4
^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [Qemu-devel] [PATCH v2 1/2] Acceptance tests: use linux-3.6 and set vm memory to 4GiB
2019-01-28 1:15 [Qemu-devel] [PATCH v2 1/2] Acceptance tests: use linux-3.6 and set vm memory to 4GiB Li Zhijian
2019-01-28 1:15 ` [Qemu-devel] [PATCH v2 2/2] Acceptance tests: expect boot to extract 2GiB+ initrd with linux-v4.16 Li Zhijian
@ 2019-01-30 17:14 ` Wainer dos Santos Moschetta
2019-02-22 17:27 ` Cleber Rosa
2 siblings, 0 replies; 5+ messages in thread
From: Wainer dos Santos Moschetta @ 2019-01-30 17:14 UTC (permalink / raw)
To: Li Zhijian, qemu-devel
Cc: Caio Carrara, Cleber Rosa, Eduardo Habkost,
Philippe Mathieu-Daudé, Paolo Bonzini
On 01/27/2019 11:15 PM, Li Zhijian wrote:
> QEMU have already supported to load up to 4G initrd if the sepcified memory is
> enough and XLF_CAN_BE_LOADED_ABOVE_4G is set by guest kernel
>
> linux-3.6 kernel shipped by Fedora-18 cannot support xldflags so that it
> cannot support loading more than 2GiB initrd
>
> CC: Wainer dos Santos Moschetta <wainersm@redhat.com>
> CC: Caio Carrara <ccarrara@redhat.com>
> CC: Cleber Rosa <crosa@redhat.com>
> CC: Eduardo Habkost <ehabkost@redhat.com>
> CC: Philippe Mathieu-Daudé <philmd@redhat.com>
> Signed-off-by: Li Zhijian <lizhijian@cn.fujitsu.com>
>
> ---
> V2: fix typos
> ---
> tests/acceptance/linux_initrd.py | 14 ++++++++------
> 1 file changed, 8 insertions(+), 6 deletions(-)
Reviewed-by: Wainer dos Santos Moschetta <wainersm@redhat.com>
Note to maintainers: the patch 02 implements a test case for
https://www.mail-archive.com/qemu-devel@nongnu.org/msg588166.html which
is in Paolo's queue already.
- Wainer
>
> diff --git a/tests/acceptance/linux_initrd.py b/tests/acceptance/linux_initrd.py
> index 737355c..b283715 100644
> --- a/tests/acceptance/linux_initrd.py
> +++ b/tests/acceptance/linux_initrd.py
> @@ -24,14 +24,16 @@ class LinuxInitrd(Test):
>
> timeout = 60
>
> - def test_with_2gib_file_should_exit_error_msg(self):
> + def test_with_2gib_file_should_exit_error_msg_with_linux_v3_6(self):
> """
> Pretends to boot QEMU with an initrd file with size of 2GiB
> and expect it exits with error message.
> + Fedora-18 shipped with linux-3.6 which have not supported xloadflags
> + cannot support more than 2GiB initrd.
> """
> - kernel_url = ('https://mirrors.kernel.org/fedora/releases/28/'
> - 'Everything/x86_64/os/images/pxeboot/vmlinuz')
> - kernel_hash = '238e083e114c48200f80d889f7e32eeb2793e02a'
> + kernel_url = ('https://archives.fedoraproject.org/pub/archive/fedora/li'
> + 'nux/releases/18/Fedora/x86_64/os/images/pxeboot/vmlinuz')
> + kernel_hash = '41464f68efe42b9991250bed86c7081d2ccdbb21'
> kernel_path = self.fetch_asset(kernel_url, asset_hash=kernel_hash)
> max_size = 2 * (1024 ** 3) - 1
>
> @@ -39,8 +41,8 @@ class LinuxInitrd(Test):
> initrd.seek(max_size)
> initrd.write(b'\0')
> initrd.flush()
> - cmd = "%s -kernel %s -initrd %s" % (self.qemu_bin, kernel_path,
> - initrd.name)
> + cmd = "%s -kernel %s -initrd %s -m 4096" % (
> + self.qemu_bin, kernel_path, initrd.name)
> res = run(cmd, ignore_status=True)
> self.assertEqual(res.exit_status, 1)
> expected_msg = r'.*initrd is too large.*max: \d+, need %s.*' % (
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [Qemu-devel] [PATCH v2 1/2] Acceptance tests: use linux-3.6 and set vm memory to 4GiB
2019-01-28 1:15 [Qemu-devel] [PATCH v2 1/2] Acceptance tests: use linux-3.6 and set vm memory to 4GiB Li Zhijian
2019-01-28 1:15 ` [Qemu-devel] [PATCH v2 2/2] Acceptance tests: expect boot to extract 2GiB+ initrd with linux-v4.16 Li Zhijian
2019-01-30 17:14 ` [Qemu-devel] [PATCH v2 1/2] Acceptance tests: use linux-3.6 and set vm memory to 4GiB Wainer dos Santos Moschetta
@ 2019-02-22 17:27 ` Cleber Rosa
2 siblings, 0 replies; 5+ messages in thread
From: Cleber Rosa @ 2019-02-22 17:27 UTC (permalink / raw)
To: Li Zhijian, qemu-devel
Cc: Eduardo Habkost, Caio Carrara, Wainer dos Santos Moschetta,
Philippe Mathieu-Daudé
On 1/27/19 8:15 PM, Li Zhijian wrote:
> QEMU have already supported to load up to 4G initrd if the sepcified memory is
> enough and XLF_CAN_BE_LOADED_ABOVE_4G is set by guest kernel
>
> linux-3.6 kernel shipped by Fedora-18 cannot support xldflags so that it
> cannot support loading more than 2GiB initrd
>
> CC: Wainer dos Santos Moschetta <wainersm@redhat.com>
> CC: Caio Carrara <ccarrara@redhat.com>
> CC: Cleber Rosa <crosa@redhat.com>
> CC: Eduardo Habkost <ehabkost@redhat.com>
> CC: Philippe Mathieu-Daudé <philmd@redhat.com>
> Signed-off-by: Li Zhijian <lizhijian@cn.fujitsu.com>
>
Reviewed-by: Cleber Rosa <crosa@redhat.com>
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [Qemu-devel] [PATCH v2 2/2] Acceptance tests: expect boot to extract 2GiB+ initrd with linux-v4.16
2019-01-28 1:15 ` [Qemu-devel] [PATCH v2 2/2] Acceptance tests: expect boot to extract 2GiB+ initrd with linux-v4.16 Li Zhijian
@ 2019-02-22 17:28 ` Cleber Rosa
0 siblings, 0 replies; 5+ messages in thread
From: Cleber Rosa @ 2019-02-22 17:28 UTC (permalink / raw)
To: Li Zhijian, qemu-devel
Cc: Eduardo Habkost, Caio Carrara, Wainer dos Santos Moschetta,
Philippe Mathieu-Daudé
On 1/27/19 8:15 PM, Li Zhijian wrote:
> XLF_CAN_BE_LOADED_ABOVE_4G is set on vmlinuz shipped by Fedora-28 so that
> it's allowed to be loaded below 4 GB address.
>
> timeout is updated to 5 minutes as well since we need more time to load a
> large initrd to the guest
>
> CC: Wainer dos Santos Moschetta <wainersm@redhat.com>
> CC: Caio Carrara <ccarrara@redhat.com>
> CC: Cleber Rosa <crosa@redhat.com>
> CC: Eduardo Habkost <ehabkost@redhat.com>
> CC: Philippe Mathieu-Daudé <philmd@redhat.com>
> Signed-off-by: Li Zhijian <lizhijian@cn.fujitsu.com>
>
Reviewed-by: Cleber Rosa <crosa@redhat.com>
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2019-02-22 17:28 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-01-28 1:15 [Qemu-devel] [PATCH v2 1/2] Acceptance tests: use linux-3.6 and set vm memory to 4GiB Li Zhijian
2019-01-28 1:15 ` [Qemu-devel] [PATCH v2 2/2] Acceptance tests: expect boot to extract 2GiB+ initrd with linux-v4.16 Li Zhijian
2019-02-22 17:28 ` Cleber Rosa
2019-01-30 17:14 ` [Qemu-devel] [PATCH v2 1/2] Acceptance tests: use linux-3.6 and set vm memory to 4GiB Wainer dos Santos Moschetta
2019-02-22 17:27 ` Cleber Rosa
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).