#!/bin/sh

export_top_env()
{
	export suite='pft'
	export testcase='pft'
	export category='benchmark'
	export iterations=20
	export job_origin='/lkp/lkp/src/allot/rand/vm-vp-2G/pft.yaml'
	export testbox='vm-vp-2G-2'
	export tbox_group='vm-vp-2G'
	export kconfig='x86_64-nfsroot'
	export compiler='gcc-6'
	export queue='bisect'
	export branch='drm/drm-syncobj-sem'
	export commit='e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a'
	export repeat_to=2
	export submit_id='593792dc0b9a9382ad711400'
	export job_file='/lkp/scheduled/vm-vp-2G-2/pft-20x-debian-x86_64-2016-08-31.cgz-e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a-20170607-98989-1y9taeh-1.yaml'
	export id='6b015d8d3a77235f35e21e009b5f759699cc7b25'
	export model='qemu-system-x86_64 -enable-kvm -cpu Penryn'
	export nr_vm=4
	export nr_cpu=4
	export memory='2G'
	export hdd_partitions='/dev/vda /dev/vdb /dev/vdc /dev/vdd /dev/vde'
	export swap_partitions='/dev/vdf'
	export need_kconfig='CONFIG_KVM_GUEST=y'
	export ssh_base_port=23108
	export rootfs='debian-x86_64-2016-08-31.cgz'
	export enqueue_time='2017-06-07 13:45:01 +0800'
	export _id='593793ce0b9a9382ad711401'
	export _rt='/result/pft/20x/vm-vp-2G/debian-x86_64-2016-08-31.cgz/x86_64-nfsroot/gcc-6/e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a'
	export user='lkp'
	export result_root='/result/pft/20x/vm-vp-2G/debian-x86_64-2016-08-31.cgz/x86_64-nfsroot/gcc-6/e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a/1'
	export LKP_SERVER='inn'
	export max_uptime=1149.54
	export initrd='/osimage/debian/debian-x86_64-2016-08-31.cgz'
	export bootloader_append='root=/dev/ram0
user=lkp
job=/lkp/scheduled/vm-vp-2G-2/pft-20x-debian-x86_64-2016-08-31.cgz-e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a-20170607-98989-1y9taeh-1.yaml
ARCH=x86_64
kconfig=x86_64-nfsroot
branch=drm/drm-syncobj-sem
commit=e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a
BOOT_IMAGE=/pkg/linux/x86_64-nfsroot/gcc-6/e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a/vmlinuz-4.12.0-rc2-00001-ge1f8a89
max_uptime=1149
RESULT_ROOT=/result/pft/20x/vm-vp-2G/debian-x86_64-2016-08-31.cgz/x86_64-nfsroot/gcc-6/e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a/1
LKP_SERVER=inn
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
earlyprintk=ttyS0,115200
console=ttyS0,115200
console=tty0
vga=normal
rw'
	export lkp_initrd='/lkp/lkp/lkp-x86_64.cgz'
	export modules_initrd='/pkg/linux/x86_64-nfsroot/gcc-6/e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a/modules.cgz'
	export bm_initrd='/osimage/deps/debian-x86_64-2016-08-31.cgz/lkp_2017-05-01.cgz,/osimage/deps/debian-x86_64-2016-08-31.cgz/rsync-rootfs_2016-11-15.cgz,/osimage/deps/debian-x86_64-2016-08-31.cgz/run-ipconfig_2016-11-15.cgz,/osimage/deps/debian-x86_64-2016-08-31.cgz/perf_2017-06-03.cgz,/osimage/pkg/debian-x86_64-2016-08-31.cgz/perf-x86_64-c531577bcdac_2017-06-03.cgz,/osimage/deps/debian-x86_64-2016-08-31.cgz/pft_2016-11-15.cgz,/osimage/pkg/debian-x86_64-2016-08-31.cgz/pft-x86_64_2016-09-02.cgz,/osimage/deps/debian-x86_64-2016-08-31.cgz/iostat_2016-11-15.cgz,/osimage/deps/debian-x86_64-2016-08-31.cgz/turbostat_2016-11-15.cgz,/osimage/pkg/debian-x86_64-2016-08-31.cgz/turbostat-x86_64_2016-09-02.cgz'
	export site='inn'
	export LKP_CGI_PORT=80
	export LKP_CIFS_PORT=139
	export kernel='/pkg/linux/x86_64-nfsroot/gcc-6/e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a/vmlinuz-4.12.0-rc2-00001-ge1f8a89'
	export dequeue_time='2017-06-07 13:49:56 +0800'
	export job_initrd='/lkp/scheduled/vm-vp-2G-2/pft-20x-debian-x86_64-2016-08-31.cgz-e1f8a89c4f33f5b32cfb047f07fdf6d38cda854a-20170607-98989-1y9taeh-1.cgz'

	[ -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_monitor delay=30 $LKP_SRC/monitors/no-stdout/wrapper perf-profile
	run_monitor $LKP_SRC/monitors/wrapper kmsg
	run_monitor $LKP_SRC/monitors/wrapper iostat
	run_monitor $LKP_SRC/monitors/wrapper heartbeat
	run_monitor $LKP_SRC/monitors/wrapper vmstat
	run_monitor $LKP_SRC/monitors/wrapper numa-numastat
	run_monitor $LKP_SRC/monitors/wrapper numa-vmstat
	run_monitor $LKP_SRC/monitors/wrapper numa-meminfo
	run_monitor $LKP_SRC/monitors/wrapper proc-vmstat
	run_monitor $LKP_SRC/monitors/wrapper proc-stat
	run_monitor $LKP_SRC/monitors/wrapper meminfo
	run_monitor $LKP_SRC/monitors/wrapper slabinfo
	run_monitor $LKP_SRC/monitors/wrapper interrupts
	run_monitor $LKP_SRC/monitors/wrapper lock_stat
	run_monitor $LKP_SRC/monitors/wrapper latency_stats
	run_monitor $LKP_SRC/monitors/wrapper softirqs
	run_monitor $LKP_SRC/monitors/one-shot/wrapper bdi_dev_mapping
	run_monitor $LKP_SRC/monitors/wrapper diskstats
	run_monitor $LKP_SRC/monitors/wrapper nfsstat
	run_monitor $LKP_SRC/monitors/wrapper cpuidle
	run_monitor $LKP_SRC/monitors/wrapper cpufreq-stats
	run_monitor $LKP_SRC/monitors/wrapper turbostat
	run_monitor $LKP_SRC/monitors/wrapper sched_debug
	run_monitor $LKP_SRC/monitors/wrapper perf-stat
	run_monitor $LKP_SRC/monitors/wrapper mpstat
	run_monitor $LKP_SRC/monitors/wrapper oom-killer
	run_monitor $LKP_SRC/monitors/plain/watchdog
	run_monitor $LKP_SRC/monitors/wrapper nfs-hang

	run_test $LKP_SRC/tests/wrapper pft
}

extract_stats()
{
	$LKP_SRC/stats/wrapper perf-profile
	$LKP_SRC/stats/wrapper pft
	$LKP_SRC/stats/wrapper kmsg
	$LKP_SRC/stats/wrapper iostat
	$LKP_SRC/stats/wrapper vmstat
	$LKP_SRC/stats/wrapper numa-numastat
	$LKP_SRC/stats/wrapper numa-vmstat
	$LKP_SRC/stats/wrapper numa-meminfo
	$LKP_SRC/stats/wrapper proc-vmstat
	$LKP_SRC/stats/wrapper meminfo
	$LKP_SRC/stats/wrapper slabinfo
	$LKP_SRC/stats/wrapper interrupts
	$LKP_SRC/stats/wrapper lock_stat
	$LKP_SRC/stats/wrapper latency_stats
	$LKP_SRC/stats/wrapper softirqs
	$LKP_SRC/stats/wrapper diskstats
	$LKP_SRC/stats/wrapper nfsstat
	$LKP_SRC/stats/wrapper cpuidle
	$LKP_SRC/stats/wrapper turbostat
	$LKP_SRC/stats/wrapper sched_debug
	$LKP_SRC/stats/wrapper perf-stat
	$LKP_SRC/stats/wrapper mpstat

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

"$@"