diff mbox series

[kvm-unit-tests,2/2] x86: Create ISO images according to unittests.cfg

Message ID 20210604023453.905512-2-yi.sun@intel.com (mailing list archive)
State New, archived
Headers show
Series [kvm-unit-tests,1/2] x86: Build ISO images from x86/*.elf | expand

Commit Message

Yi Sun June 4, 2021, 2:34 a.m. UTC
Create ISO image according to the configure file unittests.cfg,
where describes the parameters of each test case.

Signed-off-by: Yi Sun <yi.sun@intel.com>

Comments

Nadav Amit June 4, 2021, 3:06 a.m. UTC | #1
> On Jun 3, 2021, at 7:34 PM, Yi Sun <yi.sun@intel.com> wrote:
> 
> Create ISO image according to the configure file unittests.cfg,
> where describes the parameters of each test case.
> 

Looks cool!

> diff --git a/x86/create_iso.sh b/x86/create_iso.sh
> new file mode 100755
> index 0000000..8486be7
> --- /dev/null
> +++ b/x86/create_iso.sh
> @@ -0,0 +1,71 @@
> +#!/bin/bash
> +set -e
> +config_file=$1
> +
> +opts=
> +extra_params=
> +kernel=
> +smp=
> +testname=
> +
> +
> +grub_cfg() {
> +
> +	kernel_elf=$1
> +	kernel_para=$2
> +
> +	cat << EOF
> +set timeout=0
> +set default=0
> +
> +
> +menuentry "${kernel_elf}" {
> +    multiboot /boot/${kernel_elf} ${kernel_para}

Any chance you can add an optional “module” command here, that
would be configurable as a parameter to create_iso.sh?

I use such a command to provide parameters that kvm-unit-tests
usually gets from the “firmware" (and therefore are not available
in certain environments). 

The “module” can look something like:
	NR_CPUS=56
	MEMSIZE=4096
	TEST_DEVICE=0
	BOOTLOADER=1 

(kvm-unit-tests already knows to use these values)

This “module" would need to be copied into build/isofiles/boot as
well.
Yi Sun June 4, 2021, 12:32 p.m. UTC | #2
Hi Nadav,

Let me confirm if  I got what you meant. Do you want the grub entry look like following? 
Take case memory as an example:
Add module command line taking '/boot/module' as its parameter, meanwhile package the file 'module' in the folder?

menuentry "memory.elf" {
    multiboot /boot/memory.elf  tscdeadline_immed
    module   /boot/module    # Add one line like this ?
}

Thanks
    --Sun, Yi

> -----Original Message-----
> From: Nadav Amit <nadav.amit@gmail.com>
> Sent: Friday, June 4, 2021 11:06
> To: Sun, Yi <yi.sun@intel.com>
> Cc: kvm@vger.kernel.org
> Subject: Re: [kvm-unit-tests PATCH 2/2] x86: Create ISO images according to
> unittests.cfg
> 
> 
> 
> > On Jun 3, 2021, at 7:34 PM, Yi Sun <yi.sun@intel.com> wrote:
> >
> > Create ISO image according to the configure file unittests.cfg, where
> > describes the parameters of each test case.
> >
> 
> Looks cool!
> 
> > diff --git a/x86/create_iso.sh b/x86/create_iso.sh new file mode
> > 100755 index 0000000..8486be7
> > --- /dev/null
> > +++ b/x86/create_iso.sh
> > @@ -0,0 +1,71 @@
> > +#!/bin/bash
> > +set -e
> > +config_file=$1
> > +
> > +opts=
> > +extra_params=
> > +kernel=
> > +smp=
> > +testname=
> > +
> > +
> > +grub_cfg() {
> > +
> > +	kernel_elf=$1
> > +	kernel_para=$2
> > +
> > +	cat << EOF
> > +set timeout=0
> > +set default=0
> > +
> > +
> > +menuentry "${kernel_elf}" {
> > +    multiboot /boot/${kernel_elf} ${kernel_para}
> 
> Any chance you can add an optional “module” command here, that would be
> configurable as a parameter to create_iso.sh?
> 
> I use such a command to provide parameters that kvm-unit-tests usually gets
> from the “firmware" (and therefore are not available in certain
> environments).
> 
> The “module” can look something like:
> 	NR_CPUS=56
> 	MEMSIZE=4096
> 	TEST_DEVICE=0
> 	BOOTLOADER=1
> 
> (kvm-unit-tests already knows to use these values)
> 
> This “module" would need to be copied into build/isofiles/boot as well.
Nadav Amit June 4, 2021, 5:08 p.m. UTC | #3
> On Jun 4, 2021, at 5:32 AM, Sun, Yi <yi.sun@intel.com> wrote:
> 
> Hi Nadav,
> 
> Let me confirm if  I got what you meant. Do you want the grub entry look like following? 
> Take case memory as an example:
> Add module command line taking '/boot/module' as its parameter, meanwhile package the file 'module' in the folder?
> 
> menuentry "memory.elf" {
>    multiboot /boot/memory.elf  tscdeadline_immed
>    module   /boot/module    # Add one line like this ?
> }

Yes. The entry should look exactly like that.

Just to make sure we are on the same page, the “module” should be provided as a second parameter for the script. The additional “module” entry should only be added if a second parameter is provided.

Thanks,
Nadav
Yi Sun June 4, 2021, 5:13 p.m. UTC | #4
Ok, get it now. Send you the second version soon.

Thanks
    --Sun, Yi

> -----Original Message-----
> From: Nadav Amit <nadav.amit@gmail.com>
> Sent: Saturday, June 5, 2021 01:09
> To: Sun, Yi <yi.sun@intel.com>
> Cc: kvm@vger.kernel.org
> Subject: Re: [kvm-unit-tests PATCH 2/2] x86: Create ISO images according to
> unittests.cfg
> 
> 
> 
> > On Jun 4, 2021, at 5:32 AM, Sun, Yi <yi.sun@intel.com> wrote:
> >
> > Hi Nadav,
> >
> > Let me confirm if  I got what you meant. Do you want the grub entry look
> like following?
> > Take case memory as an example:
> > Add module command line taking '/boot/module' as its parameter,
> meanwhile package the file 'module' in the folder?
> >
> > menuentry "memory.elf" {
> >    multiboot /boot/memory.elf  tscdeadline_immed
> >    module   /boot/module    # Add one line like this ?
> > }
> 
> Yes. The entry should look exactly like that.
> 
> Just to make sure we are on the same page, the “module” should be
> provided as a second parameter for the script. The additional “module” entry
> should only be added if a second parameter is provided.
> 
> Thanks,
> Nadav
diff mbox series

Patch

diff --git a/x86/create_iso.sh b/x86/create_iso.sh
new file mode 100755
index 0000000..8486be7
--- /dev/null
+++ b/x86/create_iso.sh
@@ -0,0 +1,71 @@ 
+#!/bin/bash
+set -e
+config_file=$1
+
+opts=
+extra_params=
+kernel=
+smp=
+testname=
+
+
+grub_cfg() {
+
+	kernel_elf=$1
+	kernel_para=$2
+
+	cat << EOF
+set timeout=0
+set default=0
+
+
+menuentry "${kernel_elf}" {
+    multiboot /boot/${kernel_elf} ${kernel_para}
+    boot
+}
+EOF
+
+}
+
+create_iso() {
+	case_name=$1
+	kernel_elf=$2
+	kernel_params=$3
+	if [ -f $kernel_elf ]; then
+		rm -rf build/isofiles
+		mkdir -p build/isofiles/boot/grub
+
+		cp $kernel_elf build/isofiles/boot/
+		grub_cfg ${kernel_elf##*/} $kernel_params> build/isofiles/boot/grub/grub.cfg
+
+		rm -rf ${testname}.iso
+		grub-mkrescue -o ${case_name}.iso build/isofiles 2> /dev/null
+		[ $? == 0 ] && echo "Creating ISO for case: ${case_name}"
+	fi
+}
+
+nline=`wc $config_file | cut -d' ' -f 2`
+
+while read -r line; do
+	if [[ "$line" =~ ^\[(.*)\]$ || $nline == 1 ]]; then
+		rematch=${BASH_REMATCH[1]}
+		if [[ "${testname}" != "" ]]; then
+			create_iso $testname ${kernel}.elf $extra_params
+		fi
+		testname=$rematch
+
+	elif [[ $line =~ ^file\ *=\ *(.*)\.flat$ ]]; then
+		kernel=${BASH_REMATCH[1]}
+	elif [[ $line =~ ^smp\ *=\ *(.*)$ ]]; then
+		smp=${BASH_REMATCH[1]}
+	elif [[ $line =~ ^extra_params\ *=\ *(.*)$ ]]; then
+		opts=${BASH_REMATCH[1]}
+		if [[ "$opts" =~ .*append\ (.*)$ ]]; then
+			extra_params=${BASH_REMATCH[1]}
+		fi
+	elif [[ $line =~ ^groups\ *=\ *(.*)$ ]]; then
+		groups=${BASH_REMATCH[1]}
+	fi
+	(( nline -= 1))
+
+done < $config_file