/opensource.apple.com/source/gcc_40/gcc_40-4061/libiberty/getruntime.c
C | 141 lines | 100 code | 15 blank | 26 comment | 0 complexity | 146f55695c36c8695010c9cf501e59be MD5 | raw file
Possible License(s): MPL-2.0-no-copyleft-exception, GPL-2.0, BSD-3-Clause, GPL-3.0, MPL-2.0, LGPL-2.0, LGPL-2.1, CC-BY-SA-3.0, IPL-1.0, ISC, AGPL-1.0, AGPL-3.0, JSON, Apache-2.0, 0BSD
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
- <head>
- <title>getruntime.c</title>
- <style type="text/css">
- .enscript-comment { font-style: italic; color: rgb(178,34,34); }
- .enscript-function-name { font-weight: bold; color: rgb(0,0,255); }
- .enscript-variable-name { font-weight: bold; color: rgb(184,134,11); }
- .enscript-keyword { font-weight: bold; color: rgb(160,32,240); }
- .enscript-reference { font-weight: bold; color: rgb(95,158,160); }
- .enscript-string { font-weight: bold; color: rgb(188,143,143); }
- .enscript-builtin { font-weight: bold; color: rgb(218,112,214); }
- .enscript-type { font-weight: bold; color: rgb(34,139,34); }
- .enscript-highlight { text-decoration: underline; color: 0; }
- </style>
- </head>
- <body id="top">
- <h1 style="margin:8px;" id="f1">getruntime.c <span style="font-weight: normal; font-size: 0.5em;">[<a href="?txt">plain text</a>]</span></h1>
- <hr/>
- <div></div>
- <pre>
- <span class="enscript-comment">/* Return time used so far, in microseconds.
- Copyright (C) 1994, 1999, 2002 Free Software Foundation, Inc.
- This file is part of the libiberty library.
- Libiberty is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
- Libiberty is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
- You should have received a copy of the GNU Library General Public
- License along with libiberty; see the file COPYING.LIB. If
- not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- Boston, MA 02111-1307, USA. */</span>
- #<span class="enscript-reference">include</span> <span class="enscript-string">"config.h"</span>
- #<span class="enscript-reference">include</span> <span class="enscript-string">"ansidecl.h"</span>
- #<span class="enscript-reference">include</span> <span class="enscript-string">"libiberty.h"</span>
- <span class="enscript-comment">/* On some systems (such as WindISS), you must include <sys/types.h>
- to get the definition of "time_t" before you include <time.h>. */</span>
- #<span class="enscript-reference">include</span> <span class="enscript-string"><sys/types.h></span>
- <span class="enscript-comment">/* There are several ways to get elapsed execution time; unfortunately no
- single way is available for all host systems, nor are there reliable
- ways to find out which way is correct for a given host. */</span>
- #<span class="enscript-reference">ifdef</span> <span class="enscript-variable-name">TIME_WITH_SYS_TIME</span>
- # <span class="enscript-reference">include</span> <span class="enscript-string"><sys/time.h></span>
- # <span class="enscript-reference">include</span> <span class="enscript-string"><time.h></span>
- #<span class="enscript-reference">else</span>
- # <span class="enscript-reference">if</span> <span class="enscript-variable-name">HAVE_SYS_TIME_H</span>
- # <span class="enscript-reference">include</span> <span class="enscript-string"><sys/time.h></span>
- # <span class="enscript-reference">else</span>
- # <span class="enscript-reference">ifdef</span> <span class="enscript-variable-name">HAVE_TIME_H</span>
- # <span class="enscript-reference">include</span> <span class="enscript-string"><time.h></span>
- # <span class="enscript-reference">endif</span>
- # <span class="enscript-reference">endif</span>
- #<span class="enscript-reference">endif</span>
- #<span class="enscript-reference">if</span> <span class="enscript-variable-name">defined</span> (<span class="enscript-variable-name">HAVE_GETRUSAGE</span>) && <span class="enscript-variable-name">defined</span> (<span class="enscript-variable-name">HAVE_SYS_RESOURCE_H</span>)
- #<span class="enscript-reference">include</span> <span class="enscript-string"><sys/resource.h></span>
- #<span class="enscript-reference">endif</span>
- #<span class="enscript-reference">ifdef</span> <span class="enscript-variable-name">HAVE_TIMES</span>
- #<span class="enscript-reference">ifdef</span> <span class="enscript-variable-name">HAVE_SYS_PARAM_H</span>
- #<span class="enscript-reference">include</span> <span class="enscript-string"><sys/param.h></span>
- #<span class="enscript-reference">endif</span>
- #<span class="enscript-reference">include</span> <span class="enscript-string"><sys/times.h></span>
- #<span class="enscript-reference">endif</span>
- #<span class="enscript-reference">ifdef</span> <span class="enscript-variable-name">HAVE_UNISTD_H</span>
- #<span class="enscript-reference">include</span> <span class="enscript-string"><unistd.h></span>
- #<span class="enscript-reference">endif</span>
- <span class="enscript-comment">/* This is a fallback; if wrong, it will likely make obviously wrong
- results. */</span>
- #<span class="enscript-reference">ifndef</span> <span class="enscript-variable-name">CLOCKS_PER_SEC</span>
- #<span class="enscript-reference">define</span> <span class="enscript-variable-name">CLOCKS_PER_SEC</span> 1
- #<span class="enscript-reference">endif</span>
- #<span class="enscript-reference">ifdef</span> <span class="enscript-variable-name">_SC_CLK_TCK</span>
- #<span class="enscript-reference">define</span> <span class="enscript-variable-name">GNU_HZ</span> sysconf(_SC_CLK_TCK)
- #<span class="enscript-reference">else</span>
- #<span class="enscript-reference">ifdef</span> <span class="enscript-variable-name">HZ</span>
- #<span class="enscript-reference">define</span> <span class="enscript-variable-name">GNU_HZ</span> HZ
- #<span class="enscript-reference">else</span>
- #<span class="enscript-reference">ifdef</span> <span class="enscript-variable-name">CLOCKS_PER_SEC</span>
- #<span class="enscript-reference">define</span> <span class="enscript-variable-name">GNU_HZ</span> CLOCKS_PER_SEC
- #<span class="enscript-reference">endif</span>
- #<span class="enscript-reference">endif</span>
- #<span class="enscript-reference">endif</span>
- <span class="enscript-comment">/*
- @deftypefn Replacement long get_run_time (void)
- Returns the time used so far, in microseconds. If possible, this is
- the time used by this process, else it is the elapsed time since the
- process started.
- @end deftypefn
- */</span>
- <span class="enscript-type">long</span>
- <span class="enscript-function-name">get_run_time</span> ()
- {
- #<span class="enscript-reference">if</span> <span class="enscript-variable-name">defined</span> (<span class="enscript-variable-name">HAVE_GETRUSAGE</span>) && <span class="enscript-variable-name">defined</span> (<span class="enscript-variable-name">HAVE_SYS_RESOURCE_H</span>)
- <span class="enscript-type">struct</span> rusage rusage;
- getrusage (0, &rusage);
- <span class="enscript-keyword">return</span> (rusage.ru_utime.tv_sec * 1000000 + rusage.ru_utime.tv_usec
- + rusage.ru_stime.tv_sec * 1000000 + rusage.ru_stime.tv_usec);
- #<span class="enscript-reference">else</span> <span class="enscript-comment">/* ! HAVE_GETRUSAGE */</span>
- #<span class="enscript-reference">ifdef</span> <span class="enscript-variable-name">HAVE_TIMES</span>
- <span class="enscript-type">struct</span> tms tms;
- times (&tms);
- <span class="enscript-keyword">return</span> (tms.tms_utime + tms.tms_stime) * (1000000 / GNU_HZ);
- #<span class="enscript-reference">else</span> <span class="enscript-comment">/* ! HAVE_TIMES */</span>
- <span class="enscript-comment">/* Fall back on clock and hope it's correctly implemented. */</span>
- <span class="enscript-type">const</span> <span class="enscript-type">long</span> clocks_per_sec = CLOCKS_PER_SEC;
- <span class="enscript-keyword">if</span> (clocks_per_sec <= 1000000)
- <span class="enscript-keyword">return</span> clock () * (1000000 / clocks_per_sec);
- <span class="enscript-keyword">else</span>
- <span class="enscript-keyword">return</span> clock () / clocks_per_sec;
- #<span class="enscript-reference">endif</span> <span class="enscript-comment">/* HAVE_TIMES */</span>
- #<span class="enscript-reference">endif</span> <span class="enscript-comment">/* HAVE_GETRUSAGE */</span>
- }
- </pre>
- <hr />
- </body></html>