#!/bin/sh

export_top_env()
{
	export suite='ltp'
	export testcase='ltp'
	export category='functional'
	export need_memory='4G'
	export job_origin='ltp-part2.yaml'
	export queue_cmdline_keys='branch
commit
kbuild_queue_analysis
force_schedule'
	export queue='validate'
	export testbox='lkp-ivb-d01'
	export tbox_group='lkp-ivb-d01'
	export job_file='/lkp/jobs/queued/validate/lkp-ivb-d01/ltp-sched_cfs_bandwidth01-debian-12-x86_64-20240206.cgz-2d46cf7c51bd-20240731-18143-2ud8y5-3.yaml'
	export id='49046282e977c7d1b77288c0db90d9f740357648'
	export queuer_version='/zday/lkp'
	export model='Ivy Bridge'
	export nr_node=1
	export nr_cpu=8
	export memory='16G'
	export nr_ssd_partitions=1
	export nr_hdd_partitions=4
	export ssd_partitions='/dev/disk/by-id/ata-INTEL_SSDSC2BB800G4_PHWL42040066800RGN-part2'
	export hdd_partitions='/dev/disk/by-id/ata-WDC_WD10EACS-22D6B0_WD-WCAU45298688-part*'
	export rootfs_partition='/dev/disk/by-id/ata-INTEL_SSDSC2BB800G4_PHWL42040066800RGN-part1'
	export brand='Intel(R) Core(TM) i7-3770K CPU @ 3.50GHz'
	export commit='2d46cf7c51bdf9bdda81c6e876abf36a6492f37d'
	export netconsole_port=6672
	export ucode='0x21'
	export need_kconfig_hw='{"PTP_1588_CLOCK"=>"y"}
{"IGB"=>"y"}
{"E1000E"=>"y"}
SATA_AHCI
DRM_I915'
	export need_kconfig='BLK_DEV_LOOP
{"CAN"=>"m"}
{"CAN_DEV"=>"m"}
{"CAN_RAW"=>"m"}
{"CAN_VCAN"=>"m"}
{"MINIX_FS"=>"m"}
{"EXPERT"=>"y"}
{"CHECKPOINT_RESTORE"=>"y"}'
	export initrds='linux_headers'
	export kconfig='x86_64-rhel-8.3-ltp'
	export enqueue_time='2024-07-31 15:08:01 +0800'
	export _rt='/result/ltp/sched_cfs_bandwidth01/lkp-ivb-d01/debian-12-x86_64-20240206.cgz/x86_64-rhel-8.3-ltp/gcc-13/2d46cf7c51bdf9bdda81c6e876abf36a6492f37d'
	export compiler='gcc-13'
	export head_commit='9e23d7ded3aa3f6bf61d0b672948a0550859c7d6'
	export base_commit='0c3836482481200ead7b416ca80c68a29cfdaabd'
	export branch='peterz-queue/sched/scx'
	export rootfs='debian-12-x86_64-20240206.cgz'
	export user='lkp'
	export LKP_SERVER='internal-lkp-server'
	export scheduler_version='/lkp/lkp/.src-20240730-165003'
	export arch='x86_64'
	export max_uptime=6000
	export initrd='/osimage/debian/debian-12-x86_64-20240206.cgz'
	export bootloader_append='root=/dev/ram0
RESULT_ROOT=/result/ltp/sched_cfs_bandwidth01/lkp-ivb-d01/debian-12-x86_64-20240206.cgz/x86_64-rhel-8.3-ltp/gcc-13/2d46cf7c51bdf9bdda81c6e876abf36a6492f37d/3
BOOT_IMAGE=/pkg/linux/x86_64-rhel-8.3-ltp/gcc-13/2d46cf7c51bdf9bdda81c6e876abf36a6492f37d/vmlinuz-6.10.0-12040-g2d46cf7c51bd
branch=peterz-queue/sched/scx
job=/lkp/jobs/scheduled/lkp-ivb-d01/ltp-sched_cfs_bandwidth01-debian-12-x86_64-20240206.cgz-2d46cf7c51bd-20240731-18143-2ud8y5-3.yaml
user=lkp
ARCH=x86_64
kconfig=x86_64-rhel-8.3-ltp
commit=2d46cf7c51bdf9bdda81c6e876abf36a6492f37d
nmi_watchdog=0
intremap=posted_msi
max_uptime=6000
LKP_SERVER=internal-lkp-server
nokaslr
selinux=0
debug
apic=debug
sysrq_always_enabled
rcupdate.rcu_cpu_stall_timeout=100
net.ifnames=0
printk.devkmsg=on
panic=-1
softlockup_panic=1
nmi_watchdog=panic
oops=panic
load_ramdisk=2
prompt_ramdisk=0
drbd.minor_count=8
systemd.log_level=err
ignore_loglevel
console=tty0
earlyprintk=ttyS0,115200
console=ttyS0,115200
vga=normal
rw'
	export modules_initrd='/pkg/linux/x86_64-rhel-8.3-ltp/gcc-13/2d46cf7c51bdf9bdda81c6e876abf36a6492f37d/modules.cgz'
	export linux_headers_initrd='/pkg/linux/x86_64-rhel-8.3-ltp/gcc-13/2d46cf7c51bdf9bdda81c6e876abf36a6492f37d/linux-headers.cgz'
	export bm_initrd='/osimage/deps/debian-12-x86_64-20240206.cgz/lkp_20240216.cgz,/osimage/deps/debian-12-x86_64-20240206.cgz/rsync-rootfs_20240301.cgz,/osimage/deps/debian-12-x86_64-20240206.cgz/ltp_20240727.cgz,/osimage/pkg/debian-12-x86_64-20240206.cgz/ltp-x86_64-14c1f76-1_20240727.cgz,/osimage/deps/debian-12-x86_64-20240206.cgz/hw_20240216.cgz'
	export ucode_initrd='/osimage/ucode/intel-ucode-20230906.cgz'
	export lkp_initrd='/osimage/user/lkp/lkp-x86_64.cgz'
	export site='inn'
	export LKP_CGI_PORT=80
	export LKP_CIFS_PORT=139
	export job_initrd='/lkp/jobs/scheduled/lkp-ivb-d01/ltp-sched_cfs_bandwidth01-debian-12-x86_64-20240206.cgz-2d46cf7c51bd-20240731-18143-2ud8y5-3.cgz'
	export last_kernel='6.10.0-wt-ath-28009-g9e23d7ded3aa'
	export acpi_rsdp=
	export repeat_to=6
	export kbuild_queue_analysis=1
	export force_schedule=1
	export kernel='/pkg/linux/x86_64-rhel-8.3-ltp/gcc-13/2d46cf7c51bdf9bdda81c6e876abf36a6492f37d/vmlinuz-6.10.0-12040-g2d46cf7c51bd'
	export result_root='/result/ltp/sched_cfs_bandwidth01/lkp-ivb-d01/debian-12-x86_64-20240206.cgz/x86_64-rhel-8.3-ltp/gcc-13/2d46cf7c51bdf9bdda81c6e876abf36a6492f37d/3'

	[ -n "$LKP_SRC" ] ||
	export LKP_SRC=/lkp/${user:-lkp}/src
}

run_job()
{
	echo $$ > $TMP/run-job.pid

	. $LKP_SRC/lib/http.sh
	. $LKP_SRC/lib/job.sh
	. $LKP_SRC/lib/env.sh

	export_top_env

	run_setup $LKP_SRC/setup/sanity-check

	run_monitor $LKP_SRC/monitors/wrapper kmsg
	run_monitor $LKP_SRC/monitors/wrapper heartbeat
	run_monitor $LKP_SRC/monitors/wrapper meminfo
	run_monitor $LKP_SRC/monitors/wrapper kmemleak
	run_monitor $LKP_SRC/monitors/wrapper oom-killer
	run_monitor $LKP_SRC/monitors/plain/watchdog

	run_test test='sched/cfs_bandwidth01' $LKP_SRC/tests/wrapper ltp
}

extract_stats()
{
	export stats_part_begin=
	export stats_part_end=

	env test='sched/cfs_bandwidth01' $LKP_SRC/stats/wrapper ltp
	$LKP_SRC/stats/wrapper kmsg
	$LKP_SRC/stats/wrapper meminfo
	$LKP_SRC/stats/wrapper kmemleak

	$LKP_SRC/stats/wrapper time ltp.time
	$LKP_SRC/stats/wrapper dmesg
	$LKP_SRC/stats/wrapper kmsg
	$LKP_SRC/stats/wrapper last_state
	$LKP_SRC/stats/wrapper stderr
	$LKP_SRC/stats/wrapper time
}

"$@"