xref: /netbsd-src/external/gpl3/gcc.old/dist/libgfortran/intrinsics/signal.c (revision 4c3eb207d36f67d31994830c0a694161fc1ca39b)
1627f7eb2Smrg /* Implementation of the SIGNAL and ALARM g77 intrinsics
2*4c3eb207Smrg    Copyright (C) 2005-2020 Free Software Foundation, Inc.
3627f7eb2Smrg    Contributed by François-Xavier Coudert <coudert@clipper.ens.fr>
4627f7eb2Smrg 
5627f7eb2Smrg This file is part of the GNU Fortran runtime library (libgfortran).
6627f7eb2Smrg 
7627f7eb2Smrg Libgfortran is free software; you can redistribute it and/or
8627f7eb2Smrg modify it under the terms of the GNU General Public
9627f7eb2Smrg License as published by the Free Software Foundation; either
10627f7eb2Smrg version 3 of the License, or (at your option) any later version.
11627f7eb2Smrg 
12627f7eb2Smrg Libgfortran is distributed in the hope that it will be useful,
13627f7eb2Smrg but WITHOUT ANY WARRANTY; without even the implied warranty of
14627f7eb2Smrg MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15627f7eb2Smrg GNU General Public License for more details.
16627f7eb2Smrg 
17627f7eb2Smrg Under Section 7 of GPL version 3, you are granted additional
18627f7eb2Smrg permissions described in the GCC Runtime Library Exception, version
19627f7eb2Smrg 3.1, as published by the Free Software Foundation.
20627f7eb2Smrg 
21627f7eb2Smrg You should have received a copy of the GNU General Public License and
22627f7eb2Smrg a copy of the GCC Runtime Library Exception along with this program;
23627f7eb2Smrg see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
24627f7eb2Smrg <http://www.gnu.org/licenses/>.  */
25627f7eb2Smrg 
26627f7eb2Smrg #include "libgfortran.h"
27627f7eb2Smrg 
28627f7eb2Smrg #ifdef HAVE_UNISTD_H
29627f7eb2Smrg #include <unistd.h>
30627f7eb2Smrg #endif
31627f7eb2Smrg 
32627f7eb2Smrg #include <signal.h>
33627f7eb2Smrg 
34627f7eb2Smrg #ifdef HAVE_INTTYPES_H
35627f7eb2Smrg #include <inttypes.h>
36627f7eb2Smrg #endif
37627f7eb2Smrg 
38627f7eb2Smrg #include <errno.h>
39627f7eb2Smrg 
40627f7eb2Smrg /* SIGNAL subroutine with PROCEDURE as handler  */
41627f7eb2Smrg extern void signal_sub (int *, void (*)(int), int *);
42627f7eb2Smrg iexport_proto(signal_sub);
43627f7eb2Smrg 
44627f7eb2Smrg void
signal_sub(int * number,void (* handler)(int),int * status)45627f7eb2Smrg signal_sub (int *number, void (*handler)(int), int *status)
46627f7eb2Smrg {
47627f7eb2Smrg   intptr_t ret;
48627f7eb2Smrg 
49627f7eb2Smrg   if (status != NULL)
50627f7eb2Smrg     {
51627f7eb2Smrg       ret = (intptr_t) signal (*number, handler);
52627f7eb2Smrg       *status = (int) ret;
53627f7eb2Smrg     }
54627f7eb2Smrg   else
55627f7eb2Smrg     signal (*number, handler);
56627f7eb2Smrg }
57627f7eb2Smrg iexport(signal_sub);
58627f7eb2Smrg 
59627f7eb2Smrg 
60627f7eb2Smrg /* SIGNAL subroutine with INTEGER as handler  */
61627f7eb2Smrg extern void signal_sub_int (int *, int *, int *);
62627f7eb2Smrg iexport_proto(signal_sub_int);
63627f7eb2Smrg 
64627f7eb2Smrg void
signal_sub_int(int * number,int * handler,int * status)65627f7eb2Smrg signal_sub_int (int *number, int *handler, int *status)
66627f7eb2Smrg {
67627f7eb2Smrg   intptr_t ptr = *handler, ret;
68627f7eb2Smrg 
69627f7eb2Smrg   if (status != NULL)
70627f7eb2Smrg     {
71627f7eb2Smrg       ret = (intptr_t) signal (*number, (void (*)(int)) ptr);
72627f7eb2Smrg       *status = (int) ret;
73627f7eb2Smrg     }
74627f7eb2Smrg   else
75627f7eb2Smrg     signal (*number, (void (*)(int)) ptr);
76627f7eb2Smrg }
77627f7eb2Smrg iexport(signal_sub_int);
78627f7eb2Smrg 
79627f7eb2Smrg 
80627f7eb2Smrg /* SIGNAL function with PROCEDURE as handler  */
81627f7eb2Smrg extern int signal_func (int *, void (*)(int));
82627f7eb2Smrg iexport_proto(signal_func);
83627f7eb2Smrg 
84627f7eb2Smrg int
signal_func(int * number,void (* handler)(int))85627f7eb2Smrg signal_func (int *number, void (*handler)(int))
86627f7eb2Smrg {
87627f7eb2Smrg   int status;
88627f7eb2Smrg   signal_sub (number, handler, &status);
89627f7eb2Smrg   return status;
90627f7eb2Smrg }
91627f7eb2Smrg iexport(signal_func);
92627f7eb2Smrg 
93627f7eb2Smrg 
94627f7eb2Smrg /* SIGNAL function with INTEGER as handler  */
95627f7eb2Smrg extern int signal_func_int (int *, int *);
96627f7eb2Smrg iexport_proto(signal_func_int);
97627f7eb2Smrg 
98627f7eb2Smrg int
signal_func_int(int * number,int * handler)99627f7eb2Smrg signal_func_int (int *number, int *handler)
100627f7eb2Smrg {
101627f7eb2Smrg   int status;
102627f7eb2Smrg   signal_sub_int (number, handler, &status);
103627f7eb2Smrg   return status;
104627f7eb2Smrg }
105627f7eb2Smrg iexport(signal_func_int);
106627f7eb2Smrg 
107627f7eb2Smrg 
108627f7eb2Smrg 
109627f7eb2Smrg /* ALARM intrinsic with PROCEDURE as handler  */
110627f7eb2Smrg extern void alarm_sub_i4 (int *, void (*)(int), GFC_INTEGER_4 *);
111627f7eb2Smrg iexport_proto(alarm_sub_i4);
112627f7eb2Smrg 
113627f7eb2Smrg void
alarm_sub_i4(int * seconds,void (* handler)(int),GFC_INTEGER_4 * status)114627f7eb2Smrg alarm_sub_i4 (int * seconds __attribute__ ((unused)),
115627f7eb2Smrg 	      void (*handler)(int) __attribute__ ((unused)),
116627f7eb2Smrg 	      GFC_INTEGER_4 *status)
117627f7eb2Smrg {
118627f7eb2Smrg #if defined (SIGALRM) && defined (HAVE_ALARM)
119627f7eb2Smrg   if (status != NULL)
120627f7eb2Smrg     {
121627f7eb2Smrg       if (signal (SIGALRM, handler) == SIG_ERR)
122627f7eb2Smrg 	*status = -1;
123627f7eb2Smrg       else
124627f7eb2Smrg 	*status = alarm (*seconds);
125627f7eb2Smrg     }
126627f7eb2Smrg   else
127627f7eb2Smrg     {
128627f7eb2Smrg       signal (SIGALRM, handler);
129627f7eb2Smrg       alarm (*seconds);
130627f7eb2Smrg     }
131627f7eb2Smrg #else
132627f7eb2Smrg   errno = ENOSYS;
133627f7eb2Smrg   if (status != NULL)
134627f7eb2Smrg     *status = -1;
135627f7eb2Smrg #endif
136627f7eb2Smrg }
137627f7eb2Smrg iexport(alarm_sub_i4);
138627f7eb2Smrg 
139627f7eb2Smrg 
140627f7eb2Smrg extern void alarm_sub_i8 (int *, void (*)(int), GFC_INTEGER_8 *);
141627f7eb2Smrg iexport_proto(alarm_sub_i8);
142627f7eb2Smrg 
143627f7eb2Smrg void
alarm_sub_i8(int * seconds,void (* handler)(int),GFC_INTEGER_8 * status)144627f7eb2Smrg alarm_sub_i8 (int *seconds __attribute__ ((unused)),
145627f7eb2Smrg 	      void (*handler)(int) __attribute__ ((unused)),
146627f7eb2Smrg 	      GFC_INTEGER_8 *status)
147627f7eb2Smrg {
148627f7eb2Smrg #if defined (SIGALRM) && defined (HAVE_ALARM)
149627f7eb2Smrg   if (status != NULL)
150627f7eb2Smrg     {
151627f7eb2Smrg       if (signal (SIGALRM, handler) == SIG_ERR)
152627f7eb2Smrg 	*status = -1;
153627f7eb2Smrg       else
154627f7eb2Smrg 	*status = alarm (*seconds);
155627f7eb2Smrg     }
156627f7eb2Smrg   else
157627f7eb2Smrg     {
158627f7eb2Smrg       signal (SIGALRM, handler);
159627f7eb2Smrg       alarm (*seconds);
160627f7eb2Smrg     }
161627f7eb2Smrg #else
162627f7eb2Smrg   errno = ENOSYS;
163627f7eb2Smrg   if (status != NULL)
164627f7eb2Smrg     *status = -1;
165627f7eb2Smrg #endif
166627f7eb2Smrg }
167627f7eb2Smrg iexport(alarm_sub_i8);
168627f7eb2Smrg 
169627f7eb2Smrg 
170627f7eb2Smrg /* ALARM intrinsic with INTEGER as handler  */
171627f7eb2Smrg extern void alarm_sub_int_i4 (int *, int *, GFC_INTEGER_4 *);
172627f7eb2Smrg iexport_proto(alarm_sub_int_i4);
173627f7eb2Smrg 
174627f7eb2Smrg void
alarm_sub_int_i4(int * seconds,int * handler,GFC_INTEGER_4 * status)175627f7eb2Smrg alarm_sub_int_i4 (int *seconds __attribute__ ((unused)),
176627f7eb2Smrg 		  int *handler __attribute__ ((unused)),
177627f7eb2Smrg 		  GFC_INTEGER_4 *status)
178627f7eb2Smrg {
179627f7eb2Smrg #if defined (SIGALRM) && defined (HAVE_ALARM)
180627f7eb2Smrg   if (status != NULL)
181627f7eb2Smrg     {
182627f7eb2Smrg       if (signal (SIGALRM, (void (*)(int)) (intptr_t) *handler) == SIG_ERR)
183627f7eb2Smrg 	*status = -1;
184627f7eb2Smrg       else
185627f7eb2Smrg 	*status = alarm (*seconds);
186627f7eb2Smrg     }
187627f7eb2Smrg   else
188627f7eb2Smrg     {
189627f7eb2Smrg       signal (SIGALRM, (void (*)(int)) (intptr_t) *handler);
190627f7eb2Smrg       alarm (*seconds);
191627f7eb2Smrg     }
192627f7eb2Smrg #else
193627f7eb2Smrg   errno = ENOSYS;
194627f7eb2Smrg   if (status != NULL)
195627f7eb2Smrg     *status = -1;
196627f7eb2Smrg #endif
197627f7eb2Smrg }
198627f7eb2Smrg iexport(alarm_sub_int_i4);
199627f7eb2Smrg 
200627f7eb2Smrg 
201627f7eb2Smrg extern void alarm_sub_int_i8 (int *, int *, GFC_INTEGER_8 *);
202627f7eb2Smrg iexport_proto(alarm_sub_int_i8);
203627f7eb2Smrg 
204627f7eb2Smrg void
alarm_sub_int_i8(int * seconds,int * handler,GFC_INTEGER_8 * status)205627f7eb2Smrg alarm_sub_int_i8 (int *seconds __attribute__ ((unused)),
206627f7eb2Smrg 		  int *handler __attribute__ ((unused)),
207627f7eb2Smrg 		  GFC_INTEGER_8 *status)
208627f7eb2Smrg {
209627f7eb2Smrg #if defined (SIGALRM) && defined (HAVE_ALARM)
210627f7eb2Smrg   if (status != NULL)
211627f7eb2Smrg     {
212627f7eb2Smrg       if (signal (SIGALRM, (void (*)(int)) (intptr_t) *handler) == SIG_ERR)
213627f7eb2Smrg 	*status = -1;
214627f7eb2Smrg       else
215627f7eb2Smrg 	*status = alarm (*seconds);
216627f7eb2Smrg     }
217627f7eb2Smrg   else
218627f7eb2Smrg     {
219627f7eb2Smrg       signal (SIGALRM, (void (*)(int)) (intptr_t) *handler);
220627f7eb2Smrg       alarm (*seconds);
221627f7eb2Smrg     }
222627f7eb2Smrg #else
223627f7eb2Smrg   errno = ENOSYS;
224627f7eb2Smrg   if (status != NULL)
225627f7eb2Smrg     *status = -1;
226627f7eb2Smrg #endif
227627f7eb2Smrg }
228627f7eb2Smrg iexport(alarm_sub_int_i8);
229627f7eb2Smrg 
230