Path: blob/master/test/hotspot/jtreg/vmTestbase/nsk/jvmti/GetCurrentThreadCpuTimerInfo/curthrtimerinfo001.java
40948 views
/*1* Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223package nsk.jvmti.GetCurrentThreadCpuTimerInfo;2425import java.io.PrintStream;2627import nsk.share.*;28import nsk.share.jvmti.*;2930/** Debuggee class for this test. */31public class curthrtimerinfo001 extends DebugeeClass {3233/** Load native library if required. */34static {35loadLibrary("curthrtimerinfo001");36}3738/** Run test from command line. */39public static void main(String argv[]) {40argv = nsk.share.jvmti.JVMTITest.commonInit(argv);4142// JCK-compatible exit43System.exit(run(argv, System.out) + Consts.JCK_STATUS_BASE);44}4546/** Run test from JCK-compatible environment. */47public static int run(String argv[], PrintStream out) {48return new curthrtimerinfo001().runIt(argv, out);49}5051/* =================================================================== */5253// scaffold objects54ArgumentHandler argHandler = null;55Log log = null;56long timeout = 0;57int status = Consts.TEST_PASSED;5859/** Run debuggee. */60public int runIt(String argv[], PrintStream out) {61argHandler = new ArgumentHandler(argv);62log = new Log(out, argHandler);63timeout = argHandler.getWaitTime() * 60 * 1000; // milliseconds6465curthrtimerinfo001Thread thread = new curthrtimerinfo001Thread("TestedThread");6667// sync before thread started68log.display("Sync: tested thread created");69status = checkStatus(status);7071// start and finish tested thread72try {73thread.start();74thread.join();75} catch (InterruptedException e) {76throw new Failure("Main thread interrupted while waiting for tested thread:\n\t"77+ e);78}7980// sync after thread finished81log.display("Sync: tested thread started and finished");82status = checkStatus(status);8384return status;85}86}8788/* =================================================================== */8990/** Class for tested thread. */91class curthrtimerinfo001Thread extends Thread {92/** Make thread with specific name. */93public curthrtimerinfo001Thread(String name) {94super(name);95}9697/** Run some code. */98public void run() {99// do something100int n = 1000;101int s = 0;102for (int i = 0; i < n; i++) {103if (i % 2 == 0) {104s += i * 10;105} else {106s -= i * 10;107}108}109}110}111112113