00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045 #include <stdio.h>
00046 #include <signal.h>
00047 #include <stdlib.h>
00048 #include <ulocks.h>
00049 #include <unistd.h>
00050 #include "cmplrs/host.h"
00051
00052 int f77argc;
00053 char **f77argv;
00054 extern int __trap_fpe_override;
00055 extern void s_abort(void), MAIN__(void), f_exit(void);
00056
00057
00058 #pragma weak MAIN__ = ___MAIN__
00059
00060 extern void __mp_check_setup(void);
00061 #pragma weak __mp_check_setup
00062 static void (*__mp_ptr)() = __mp_check_setup;
00063
00064 static void sigdie(register char *, int32 );
00065
00066 static void sigfdie(void), sigidie(void), sigqdie(void), sigindie(void),
00067 sigtdie(void);
00068
00069 main(int argc, char **argv, char **arge)
00070 {
00071
00072 f77argc = argc;
00073 f77argv = argv;
00074 #ifdef sgi
00075
00076
00077
00078 if (! __trap_fpe_override )
00079 signal(SIGFPE, sigfdie);
00080 #else
00081 signal(SIGFPE, sigfdie);
00082 #endif
00083 signal(SIGIOT, sigidie);
00084 if( signal(SIGQUIT,sigqdie) == SIG_IGN ) signal(SIGQUIT, SIG_IGN);
00085 if( signal(SIGINT, sigindie) == SIG_IGN ) signal(SIGINT, SIG_IGN);
00086 signal(SIGTERM,sigtdie);
00087
00088
00089 if (__mp_ptr != 0) (*__mp_ptr)();
00090
00091 MAIN__();
00092 #ifndef FTN90_IO
00093 f_exit();
00094 #endif
00095 exit(0);
00096 return (0);
00097 }
00098
00099
00100 static void
00101 sigfdie(void)
00102 {
00103 sigdie("Floating Exception", 1);
00104 }
00105
00106
00107
00108 static void
00109 sigidie(void)
00110 {
00111 sigdie("IOT Trap", 1);
00112 }
00113
00114
00115 static void
00116 sigqdie(void)
00117 {
00118 sigdie("Quit signal", 1);
00119 }
00120
00121
00122
00123 static void
00124 sigindie(void)
00125 {
00126 sigdie("Interrupt", 0);
00127 }
00128
00129
00130
00131 static void
00132 sigtdie(void)
00133 {
00134 sigdie("Killed", 0);
00135 }
00136
00137
00138
00139 void
00140 sigdie(register char *s, int32 coredump)
00141 {
00142
00143 fprintf(stderr, "%s\n", s);
00144 fflush(stderr);
00145
00146 if(coredump)
00147 {
00148
00149 signal(SIGIOT, SIG_DFL);
00150 abort();
00151 }
00152 else
00153 {
00154 int gid;
00155 gid = getpgrp();
00156 signal(SIGINT, SIG_IGN );
00157 gid = kill( -gid, SIGINT );
00158 #ifndef FTN90_IO
00159 f_exit();
00160 #endif
00161 exit(1);
00162 }
00163 }
00164
00165 void
00166 f_abort(void)
00167 {
00168 s_abort();
00169 }
00170
00171
00172 void ___MAIN__(void)
00173 {
00174 fprintf(stderr, "No Fortran MAIN program to execute.\n");
00175 exit(1);
00176 }