#!/bin/sh

export_top_env()
{
	export suite='phoronix-test-suite'
	export testcase='phoronix-test-suite'
	export category='benchmark'
	export rootfs='inn:/export/debian-full-x86_64'
	export run_on_local_disk=true
	export need_x=true
	export timeout='2h'
	export job_origin='/lkp/lkp/.src-20181017-163631/allot/cyclic:default:linux-next:master/intel12/phoronix-test-suite-needx.yaml'
	export queue='validate'
	export testbox='intel12'
	export tbox_group='intel12'
	export submit_id='5bcca4040b9a93c41515cc42'
	export job_file='/lkp/jobs/scheduled/intel12/phoronix-test-suite-true-tesseract-1.1.0-performance-debian-full-x86_64-e62016662d0971f63dd4c1a482aeb7ca53df8aca-20181022-50197-1iebpyy-3.yaml'
	export id='782e144670276a34c4f895d99aa76e9868a2788d'
	export model='Nehalem EP'
	export nr_node=2
	export nr_cpu=16
	export memory='48G'
	export hdd_partitions=
	export swap_partitions='LABEL=SWAP'
	export rootfs_partition='LABEL=LKP-ROOTFS'
	export brand='Intel(R) Xeon(R) CPU X5570 @ 2.93GHz'
	export kernel_cmd='console=ttyS1,115200 console=tty0'
	export commit='e62016662d0971f63dd4c1a482aeb7ca53df8aca'
	export kconfig='x86_64-rhel-7.2'
	export compiler='gcc-7'
	export enqueue_time='2018-10-22 00:06:29 +0800'
	export _id='5bcca4050b9a93c41515cc44'
	export _rt='/result/phoronix-test-suite/true-tesseract-1.1.0-performance/intel12/debian-full-x86_64/x86_64-rhel-7.2/gcc-7/e62016662d0971f63dd4c1a482aeb7ca53df8aca'
	export user='lkp'
	export head_commit='4794a36bf08dfa89fe636e5080db9d8350e255dd'
	export base_commit='6bf4ca7fbc85d80446ac01c0d1d77db4d91a6d84'
	export branch='linux-next/master'
	export result_root='/result/phoronix-test-suite/true-tesseract-1.1.0-performance/intel12/debian-full-x86_64/x86_64-rhel-7.2/gcc-7/e62016662d0971f63dd4c1a482aeb7ca53df8aca/3'
	export LKP_SERVER='inn'
	export max_uptime=1322.8
	export initrd='/osimage/initramfs/initramfs.cgz'
	export bootloader_append='root=LABEL=LKP-ROOTFS
rootflags=subvol=debian-full-x86_64
remote_rootfs=inn:/export/debian-full-x86_64
user=lkp
job=/lkp/jobs/scheduled/intel12/phoronix-test-suite-true-tesseract-1.1.0-performance-debian-full-x86_64-e62016662d0971f63dd4c1a482aeb7ca53df8aca-20181022-50197-1iebpyy-3.yaml
ARCH=x86_64
kconfig=x86_64-rhel-7.2
branch=linux-next/master
commit=e62016662d0971f63dd4c1a482aeb7ca53df8aca
BOOT_IMAGE=/pkg/linux/x86_64-rhel-7.2/gcc-7/e62016662d0971f63dd4c1a482aeb7ca53df8aca/vmlinuz-4.19.0-rc3-00022-ge620166
max_uptime=1322
RESULT_ROOT=/result/phoronix-test-suite/true-tesseract-1.1.0-performance/intel12/debian-full-x86_64/x86_64-rhel-7.2/gcc-7/e62016662d0971f63dd4c1a482aeb7ca53df8aca/3
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
console=tty0
earlyprintk=ttyS0,115200
console=ttyS0,115200
vga=normal
rw'
	export modules_initrd='/pkg/linux/x86_64-rhel-7.2/gcc-7/e62016662d0971f63dd4c1a482aeb7ca53df8aca/modules.cgz'
	export bm_initrd='/osimage/pkg/debian-full-x86_64/turbostat-x86_64.cgz'
	export lkp_initrd='/lkp/lkp/lkp-x86_64.cgz'
	export site='inn'
	export LKP_CGI_PORT=80
	export LKP_CIFS_PORT=139
	export repeat_to=4
	export kernel='/pkg/linux/x86_64-rhel-7.2/gcc-7/e62016662d0971f63dd4c1a482aeb7ca53df8aca/vmlinuz-4.19.0-rc3-00022-ge620166'
	export dequeue_time='2018-10-22 00:19:12 +0800'
	export job_initrd='/lkp/jobs/scheduled/intel12/phoronix-test-suite-true-tesseract-1.1.0-performance-debian-full-x86_64-e62016662d0971f63dd4c1a482aeb7ca53df8aca-20181022-50197-1iebpyy-3.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_setup $LKP_SRC/setup/cpufreq_governor 'performance'

	run_monitor $LKP_SRC/monitors/wrapper kmsg
	run_monitor $LKP_SRC/monitors/no-stdout/wrapper boot-time
	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/no-stdout/wrapper perf-profile
	run_monitor $LKP_SRC/monitors/wrapper oom-killer
	run_monitor $LKP_SRC/monitors/plain/watchdog

	run_test test='tesseract-1.1.0' $LKP_SRC/tests/wrapper phoronix-test-suite
}

extract_stats()
{
	$LKP_SRC/stats/wrapper phoronix-test-suite
	$LKP_SRC/stats/wrapper kmsg
	$LKP_SRC/stats/wrapper boot-time
	$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 perf-profile

	$LKP_SRC/stats/wrapper time phoronix-test-suite.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
}

"$@"