60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync/* $Id$ */
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync/** @file
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * IPRT R0 Testcase - Timers, driver program.
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync */
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync/*
22ca45c3863de72dfa6ed4c31b712de13d61aa23vboxsync * Copyright (C) 2009-2014 Oracle Corporation
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync *
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * available from http://www.virtualbox.org. This file is free software;
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * you can redistribute it and/or modify it under the terms of the GNU
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * General Public License (GPL) as published by the Free Software
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync *
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * The contents of this file may alternatively be used under the terms
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * of the Common Development and Distribution License Version 1.0
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * VirtualBox OSE distribution, in which case the provisions of the
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * CDDL are applicable instead of those of the GPL.
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync *
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * You may elect to license modified versions of this file under the
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * terms and conditions of either the GPL or the CDDL or both.
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync */
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync/*******************************************************************************
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync* Header Files *
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync*******************************************************************************/
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#include <iprt/initterm.h>
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#include <iprt/err.h>
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#include <iprt/path.h>
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#include <iprt/param.h>
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#include <iprt/stream.h>
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#include <iprt/string.h>
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#include <iprt/test.h>
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#include <iprt/thread.h>
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#ifdef VBOX
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync# include <VBox/sup.h>
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync# include "tstRTR0Timer.h"
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#endif
7e3ff7c4e45ee1f8eb46a1aba9d2d8816d337c4avboxsync#include "tstRTR0CommonDriver.h"
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync/**
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync * Entry point.
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync */
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsyncextern "C" DECLEXPORT(int) TrustedMain(int argc, char **argv, char **envp)
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync{
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#ifndef VBOX
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync RTPrintf("tstRTR0Timer: SKIPPED\n");
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync return RTEXITCODE_SKIPPED;
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#else
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync /*
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * Init.
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync */
7e3ff7c4e45ee1f8eb46a1aba9d2d8816d337c4avboxsync RTEXITCODE rcExit = RTR3TestR0CommonDriverInit("tstRTR0Timer");
7e3ff7c4e45ee1f8eb46a1aba9d2d8816d337c4avboxsync if (rcExit != RTEXITCODE_SUCCESS)
7e3ff7c4e45ee1f8eb46a1aba9d2d8816d337c4avboxsync return rcExit;
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync if (argc == 2 && !strcmp(argv[1], "latency"))
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync {
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_LATENCY_OMNI, "Latency omni timer");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_LATENCY_OMNI_HIRES, "Latency omni hires timer");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync }
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync else
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync {
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync# if 1
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync /*
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync * Standard timers.
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync */
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_ONE_SHOT_BASIC, "Basic one shot");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_PERIODIC_BASIC, "Basic periodic");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync if (RTTestErrorCount(g_hTest) == 0)
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync {
9c9e7c794214b652d4bc5e3a5035466cee2fd1ccvboxsync# if 1
28d34e9bb91646a6f96c0841eeb0ea980df4c38dvboxsync# ifndef RT_OS_SOLARIS /* Solaris cannot call back into cyclic subsystem from a cyclic callback. */
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_ONE_SHOT_RESTART, "Restart one shot from callback");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_ONE_SHOT_DESTROY, "Destroy one shot from callback");
28d34e9bb91646a6f96c0841eeb0ea980df4c38dvboxsync# endif
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_PERIODIC_CSSD_LOOPS, "Create-start-stop-destroy loops");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync for (uint32_t i = 0; i <= 7; i++)
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTestWithArg(TSTRTR0TIMER_PERIODIC_CHANGE_INTERVAL, i, "Change interval from callback, variation %u", i);
533240a0b68828716de5ebea7afaf56720aa6ae7vboxsync# endif
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_ONE_SHOT_SPECIFIC, "One shot cpu specific");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_PERIODIC_SPECIFIC, "Periodic cpu specific");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_PERIODIC_OMNI, "Periodic omni timer");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync }
f5bed9e0fb53936fc0ff58a29ecf7293f107b5aavboxsync# endif
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync
f5bed9e0fb53936fc0ff58a29ecf7293f107b5aavboxsync# if 1
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync /*
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync * High resolution timers.
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync */
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_ONE_SHOT_BASIC_HIRES, "Basic hires one shot");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_PERIODIC_BASIC_HIRES, "Basic hires periodic");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync if (RTTestErrorCount(g_hTest) == 0)
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync {
9c9e7c794214b652d4bc5e3a5035466cee2fd1ccvboxsync# if 1
28d34e9bb91646a6f96c0841eeb0ea980df4c38dvboxsync# ifndef RT_OS_SOLARIS /* Solaris cannot call back into cyclic subsystem from a cyclic callback. */
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_ONE_SHOT_RESTART_HIRES, "Restart hires one shot from callback");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_ONE_SHOT_DESTROY_HIRES, "Destroy hires one shot from callback");
28d34e9bb91646a6f96c0841eeb0ea980df4c38dvboxsync# endif
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_PERIODIC_CSSD_LOOPS_HIRES, "Create-start-stop-destroy loops, hires");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync for (uint32_t i = 0; i <= 7; i++)
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTestWithArg(TSTRTR0TIMER_PERIODIC_CHANGE_INTERVAL, i, "Change interval from callback, hires, variation %u", i);
533240a0b68828716de5ebea7afaf56720aa6ae7vboxsync# endif
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_ONE_SHOT_SPECIFIC_HIRES, "One shot hires cpu specific");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_PERIODIC_SPECIFIC_HIRES, "Periodic hires cpu specific");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync RTR3TestR0SimpleTest(TSTRTR0TIMER_PERIODIC_OMNI, "Periodic omni hires timer");
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync }
f5bed9e0fb53936fc0ff58a29ecf7293f107b5aavboxsync# endif
72b8475aa6b56364852ae8c3e02cc1fb06cb9232vboxsync }
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync /*
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync * Done.
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync */
7e3ff7c4e45ee1f8eb46a1aba9d2d8816d337c4avboxsync return RTTestSummaryAndDestroy(g_hTest);
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync#endif
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync}
60b32e7ca2a75ab3f7e70c3a4bdcd7cfedf5be57vboxsync
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync#if !defined(VBOX_WITH_HARDENING) || !defined(RT_OS_WINDOWS)
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync/**
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync * Main entry point.
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync */
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsyncint main(int argc, char **argv, char **envp)
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync{
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync return TrustedMain(argc, argv, envp);
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync}
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync#endif
a0ed9c35186427ae0abbd14b1cfdf43bf2dc8659vboxsync