xref: /netbsd-src/external/gpl3/gcc.old/dist/libgfortran/intrinsics/cpu_time.c (revision 4c3eb207d36f67d31994830c0a694161fc1ca39b)
1627f7eb2Smrg /* Implementation of the CPU_TIME intrinsic.
2*4c3eb207Smrg    Copyright (C) 2003-2020 Free Software Foundation, Inc.
3627f7eb2Smrg 
4627f7eb2Smrg This file is part of the GNU Fortran runtime library (libgfortran).
5627f7eb2Smrg 
6627f7eb2Smrg Libgfortran is free software; you can redistribute it and/or
7627f7eb2Smrg modify it under the terms of the GNU General Public
8627f7eb2Smrg License as published by the Free Software Foundation; either
9627f7eb2Smrg version 3 of the License, or (at your option) any later version.
10627f7eb2Smrg 
11627f7eb2Smrg Libgfortran is distributed in the hope that it will be useful,
12627f7eb2Smrg but WITHOUT ANY WARRANTY; without even the implied warranty of
13627f7eb2Smrg MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14627f7eb2Smrg GNU General Public License for more details.
15627f7eb2Smrg 
16627f7eb2Smrg Under Section 7 of GPL version 3, you are granted additional
17627f7eb2Smrg permissions described in the GCC Runtime Library Exception, version
18627f7eb2Smrg 3.1, as published by the Free Software Foundation.
19627f7eb2Smrg 
20627f7eb2Smrg You should have received a copy of the GNU General Public License and
21627f7eb2Smrg a copy of the GCC Runtime Library Exception along with this program;
22627f7eb2Smrg see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
23627f7eb2Smrg <http://www.gnu.org/licenses/>.  */
24627f7eb2Smrg 
25627f7eb2Smrg #include "libgfortran.h"
26627f7eb2Smrg #include "time_1.h"
27627f7eb2Smrg 
28627f7eb2Smrg 
29627f7eb2Smrg static void
__cpu_time_1(long * sec,long * usec)30627f7eb2Smrg __cpu_time_1 (long *sec, long *usec)
31627f7eb2Smrg {
32627f7eb2Smrg   long user_sec, user_usec, system_sec, system_usec;
33627f7eb2Smrg   if (gf_cputime (&user_sec, &user_usec, &system_sec, &system_usec) == 0)
34627f7eb2Smrg     {
35627f7eb2Smrg       *sec = user_sec + system_sec;
36627f7eb2Smrg       *usec = user_usec + system_usec;
37627f7eb2Smrg     }
38627f7eb2Smrg   else
39627f7eb2Smrg     {
40627f7eb2Smrg       *sec = -1;
41627f7eb2Smrg       *usec = 0;
42627f7eb2Smrg     }
43627f7eb2Smrg }
44627f7eb2Smrg 
45627f7eb2Smrg 
46627f7eb2Smrg extern void cpu_time_4 (GFC_REAL_4 *);
47627f7eb2Smrg iexport_proto(cpu_time_4);
48627f7eb2Smrg 
cpu_time_4(GFC_REAL_4 * time)49627f7eb2Smrg void cpu_time_4 (GFC_REAL_4 *time)
50627f7eb2Smrg {
51627f7eb2Smrg   long sec, usec;
52627f7eb2Smrg   __cpu_time_1 (&sec, &usec);
53627f7eb2Smrg   *time = sec + usec * GFC_REAL_4_LITERAL(1.e-6);
54627f7eb2Smrg }
55627f7eb2Smrg iexport(cpu_time_4);
56627f7eb2Smrg 
57627f7eb2Smrg extern void cpu_time_8 (GFC_REAL_8 *);
58627f7eb2Smrg export_proto(cpu_time_8);
59627f7eb2Smrg 
cpu_time_8(GFC_REAL_8 * time)60627f7eb2Smrg void cpu_time_8 (GFC_REAL_8 *time)
61627f7eb2Smrg {
62627f7eb2Smrg   long sec, usec;
63627f7eb2Smrg   __cpu_time_1 (&sec, &usec);
64627f7eb2Smrg   *time = sec + usec * GFC_REAL_8_LITERAL(1.e-6);
65627f7eb2Smrg }
66627f7eb2Smrg 
67627f7eb2Smrg #ifdef HAVE_GFC_REAL_10
68627f7eb2Smrg extern void cpu_time_10 (GFC_REAL_10 *);
69627f7eb2Smrg export_proto(cpu_time_10);
70627f7eb2Smrg 
cpu_time_10(GFC_REAL_10 * time)71627f7eb2Smrg void cpu_time_10 (GFC_REAL_10 *time)
72627f7eb2Smrg {
73627f7eb2Smrg   long sec, usec;
74627f7eb2Smrg   __cpu_time_1 (&sec, &usec);
75627f7eb2Smrg   *time = sec + usec * GFC_REAL_10_LITERAL(1.e-6);
76627f7eb2Smrg }
77627f7eb2Smrg #endif
78627f7eb2Smrg 
79627f7eb2Smrg #ifdef HAVE_GFC_REAL_16
80627f7eb2Smrg extern void cpu_time_16 (GFC_REAL_16 *);
81627f7eb2Smrg export_proto(cpu_time_16);
82627f7eb2Smrg 
cpu_time_16(GFC_REAL_16 * time)83627f7eb2Smrg void cpu_time_16 (GFC_REAL_16 *time)
84627f7eb2Smrg {
85627f7eb2Smrg   long sec, usec;
86627f7eb2Smrg   __cpu_time_1 (&sec, &usec);
87627f7eb2Smrg   *time = sec + usec * GFC_REAL_16_LITERAL(1.e-6);
88627f7eb2Smrg }
89627f7eb2Smrg #endif
90627f7eb2Smrg 
91627f7eb2Smrg extern void second_sub (GFC_REAL_4 *);
92627f7eb2Smrg export_proto(second_sub);
93627f7eb2Smrg 
94627f7eb2Smrg void
second_sub(GFC_REAL_4 * s)95627f7eb2Smrg second_sub (GFC_REAL_4 *s)
96627f7eb2Smrg {
97627f7eb2Smrg   cpu_time_4 (s);
98627f7eb2Smrg }
99627f7eb2Smrg 
100627f7eb2Smrg extern GFC_REAL_4 second (void);
101627f7eb2Smrg export_proto(second);
102627f7eb2Smrg 
103627f7eb2Smrg GFC_REAL_4
second(void)104627f7eb2Smrg second (void)
105627f7eb2Smrg {
106627f7eb2Smrg   GFC_REAL_4 s;
107627f7eb2Smrg   cpu_time_4 (&s);
108627f7eb2Smrg   return s;
109627f7eb2Smrg }
110