| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	 YAP Prolog 							 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	Yap Prolog was developed at NCCUP - Universidade do Porto	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * Copyright L.Damas, V.S.Costa and Universidade do Porto 1985-1997	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | ************************************************************************** | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * File:		sysbits.c						 * | 
					
						
							|  |  |  | * Last rev:	4/03/88							 * | 
					
						
							|  |  |  | * mods:									 * | 
					
						
							|  |  |  | * comments:	very much machine dependent routines			 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | #ifdef SCCS
 | 
					
						
							|  |  |  | static char SccsId[] = "%W% %G%"; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * In this routine we shall try to include the inevitably machine dependant | 
					
						
							| 
									
										
										
										
											2001-11-26 16:05:19 +00:00
										 |  |  |  * routines. These include, for the moment : Time, A rudimentary form of | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |  * signal handling, OS calls, | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Vitor Santos Costa, February 1987 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-17 03:42:14 +00:00
										 |  |  | /* windows.h does not like absmi.h, this
 | 
					
						
							|  |  |  |    should fix it for now */ | 
					
						
							|  |  |  | #include "absmi.h"
 | 
					
						
							|  |  |  | #include "yapio.h"
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #include "alloc.h"
 | 
					
						
							|  |  |  | #include <math.h>
 | 
					
						
							|  |  |  | #if STDC_HEADERS
 | 
					
						
							|  |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #if HAVE_WINDOWS_H
 | 
					
						
							|  |  |  | #include <windows.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_SYS_TIME_H && !defined(__MINGW32__) && !_MSC_VER
 | 
					
						
							|  |  |  | #include <sys/time.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_UNISTD_H
 | 
					
						
							|  |  |  | #include <unistd.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_WAIT_H && !defined(__MINGW32__) && !_MSC_VER
 | 
					
						
							|  |  |  | #include <sys/wait.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_STRING_H
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if !HAVE_STRNCAT
 | 
					
						
							|  |  |  | #define strncat(X,Y,Z) strcat(X,Y)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if !HAVE_STRNCPY
 | 
					
						
							|  |  |  | #define strncpy(X,Y,Z) strcpy(X,Y)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_GETPWNAM
 | 
					
						
							|  |  |  | #include <pwd.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_STAT_H
 | 
					
						
							|  |  |  | #include <sys/stat.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_TYPES_H
 | 
					
						
							|  |  |  | #include <sys/types.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_FCNTL_H
 | 
					
						
							|  |  |  | #include <fcntl.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-01-19 16:10:53 +00:00
										 |  |  | #if  _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #include <windows.h>
 | 
					
						
							|  |  |  | /* required for DLL compatibility */ | 
					
						
							|  |  |  | #if HAVE_DIRECT_H
 | 
					
						
							|  |  |  | #include <direct.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #include <io.h>
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #if HAVE_SYS_PARAM_H
 | 
					
						
							|  |  |  | #include <sys/param.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-06-12 17:25:28 +00:00
										 |  |  | #if HAVE_LIBREADLINE
 | 
					
						
							|  |  |  | #include <readline/readline.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | STATIC_PROTO (void InitPageSize, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (void InitTime, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (void InitWTime, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (Int p_sh, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (Int p_shell, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (Int p_system, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (Int p_mv, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (Int p_cd, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (Int p_getcwd, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (Int p_dir_sp, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (void InitRandom, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (Int p_srandom, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (Int p_alarm, (void)); | 
					
						
							| 
									
										
										
										
											2001-05-21 20:00:05 +00:00
										 |  |  | STATIC_PROTO (Int p_getenv, (void)); | 
					
						
							|  |  |  | STATIC_PROTO (Int p_putenv, (void)); | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | STATIC_PROTO (void  set_fpu_exceptions, (int)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef MACYAP
 | 
					
						
							|  |  |  | STATIC_PROTO (int chdir, (char *)); | 
					
						
							|  |  |  | /* #define signal	skel_signal */ | 
					
						
							|  |  |  | #endif /* MACYAP */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-23 02:28:31 +00:00
										 |  |  | #if  __simplescalar__
 | 
					
						
							|  |  |  | char yap_pwd[YAP_FILENAME_MAX]; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #if HAVE_SIGNAL
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int             snoozing = FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | STD_PROTO (void exit, (int)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #ifdef _WIN32
 | 
					
						
							|  |  |  | static void | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_WinError(char *yap_error) | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   char msg[256]; | 
					
						
							|  |  |  |   /* Error, we could not read time */ | 
					
						
							| 
									
										
										
										
											2004-08-11 16:14:55 +00:00
										 |  |  |      FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | 		  NULL, GetLastError(),  | 
					
						
							|  |  |  | 		  MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), msg, 256, | 
					
						
							|  |  |  | 		  NULL); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, "%s at %s", msg, yap_error); | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | } | 
					
						
							|  |  |  | #endif /* _WIN32 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define is_valid_env_char(C) ( ((C) >= 'a' && (C) <= 'z') || ((C) >= 'A' && \
 | 
					
						
							|  |  |  | 			       (C) <= 'Z') || (C) == '_' ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | static int | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | dir_separator (int ch) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifdef MAC
 | 
					
						
							|  |  |  |   return (ch == ':'); | 
					
						
							|  |  |  | #elif ATARI || _MSC_VER
 | 
					
						
							|  |  |  |   return (ch == '\\'); | 
					
						
							| 
									
										
										
										
											2002-10-17 01:37:46 +00:00
										 |  |  | #elif defined(__MINGW32__) || defined(__CYGWIN__)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return (ch == '\\' || ch == '/'); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   return (ch == '/'); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_dir_separator (int ch) | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   return dir_separator (ch); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | void | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_InitSysPath(void) { | 
					
						
							|  |  |  |   strncpy(Yap_FileNameBuf, SHARE_DIR, YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef MAC
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   strncat(Yap_FileNameBuf,":", YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif ATARI || _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   strncat(Yap_FileNameBuf,"\\", YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   strncat(Yap_FileNameBuf,"/", YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   strncat(Yap_FileNameBuf, "Yap", YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   Yap_PutValue(Yap_LookupAtom("system_library_directory"), | 
					
						
							|  |  |  | 	   MkAtomTerm(Yap_LookupAtom(Yap_FileNameBuf))); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_dir_sp (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifdef MAC
 | 
					
						
							|  |  |  |   Term t = MkIntTerm(':'); | 
					
						
							|  |  |  | #elif ATARI || _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  |   Term t = MkIntTerm('\\'); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   Term t = MkIntTerm('/'); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   return(Yap_unify_constant(ARG1,t)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitPageSize(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifdef _WIN32
 | 
					
						
							|  |  |  |   SYSTEM_INFO si; | 
					
						
							|  |  |  |   GetSystemInfo(&si); | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_page_size = si.dwPageSize; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif HAVE_UNISTD_H
 | 
					
						
							|  |  |  | #ifdef __FreeBSD__
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_page_size = getpagesize(); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif defined(_AIX)
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_page_size = sysconf(_SC_PAGE_SIZE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif !defined(_SC_PAGESIZE)
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_page_size = getpagesize(); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_page_size = sysconf(_SC_PAGESIZE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | bla bla | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef SIMICS
 | 
					
						
							|  |  |  | #ifdef HAVE_GETRUSAGE
 | 
					
						
							|  |  |  | #undef HAVE_GETRUSAGE
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef HAVE_TIMES
 | 
					
						
							|  |  |  | #undef HAVE_TIMES
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* SIMICS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef _WIN32
 | 
					
						
							|  |  |  | #if HAVE_GETRUSAGE
 | 
					
						
							|  |  |  | #undef HAVE_GETRUSAGE
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_GETRUSAGE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_SYS_TIMES_H
 | 
					
						
							|  |  |  | #include <sys/times.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_RESOURCE_H
 | 
					
						
							|  |  |  | #include <sys/resource.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | #if THREADS
 | 
					
						
							|  |  |  | #define StartOfTimes (*(ThreadHandle[worker_id].start_of_timesp))
 | 
					
						
							|  |  |  | #define last_time    (*(ThreadHandle[worker_id].last_timep))
 | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* since the point YAP was started */ | 
					
						
							|  |  |  | static struct timeval StartOfTimes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since last call to runtime */ | 
					
						
							|  |  |  | static struct timeval last_time; | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitTime (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct rusage   rusage; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | #if THREADS
 | 
					
						
							|  |  |  |   ThreadHandle[worker_id].start_of_timesp = (struct timeval *)malloc(sizeof(struct timeval)); | 
					
						
							|  |  |  |   ThreadHandle[worker_id].last_timep = (struct timeval *)malloc(sizeof(struct timeval)); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   getrusage(RUSAGE_SELF, &rusage); | 
					
						
							|  |  |  |   last_time.tv_sec = StartOfTimes.tv_sec = rusage.ru_utime.tv_sec; | 
					
						
							|  |  |  |   last_time.tv_usec = StartOfTimes.tv_usec = rusage.ru_utime.tv_usec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | UInt | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_cputime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |  struct rusage   rusage; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  getrusage(RUSAGE_SELF, &rusage); | 
					
						
							|  |  |  |  return((rusage.ru_utime.tv_sec - StartOfTimes.tv_sec)) * 1000 + | 
					
						
							|  |  |  |    ((rusage.ru_utime.tv_usec - StartOfTimes.tv_usec) / 1000); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_cputime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct rusage   rusage; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   getrusage(RUSAGE_SELF, &rusage); | 
					
						
							|  |  |  |   *now = (rusage.ru_utime.tv_sec - StartOfTimes.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (rusage.ru_utime.tv_usec - StartOfTimes.tv_usec) / 1000; | 
					
						
							|  |  |  |   *interval = (rusage.ru_utime.tv_sec - last_time.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (rusage.ru_utime.tv_usec - last_time.tv_usec) / 1000; | 
					
						
							|  |  |  |   last_time.tv_usec = rusage.ru_utime.tv_usec; | 
					
						
							|  |  |  |   last_time.tv_sec = rusage.ru_utime.tv_sec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #elif defined(_WIN32)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #ifdef __GNUC__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This is stolen from the Linux kernel.
 | 
					
						
							|  |  |  |    The problem is that mingw32 does not seem to have acces to div */ | 
					
						
							|  |  |  | #ifndef do_div
 | 
					
						
							|  |  |  | #define do_div(n,base) ({ \
 | 
					
						
							|  |  |  | 	unsigned long __upper, __low, __high, __mod; \ | 
					
						
							|  |  |  | 	asm("":"=a" (__low), "=d" (__high):"A" (n)); \ | 
					
						
							|  |  |  | 	__upper = __high; \ | 
					
						
							|  |  |  | 	if (__high) { \ | 
					
						
							|  |  |  | 		__upper = __high % (base); \ | 
					
						
							|  |  |  | 		__high = __high / (base); \ | 
					
						
							|  |  |  | 	} \ | 
					
						
							|  |  |  | 	asm("divl %2":"=a" (__low), "=d" (__mod):"rm" (base), "0" (__low), "1" (__upper)); \ | 
					
						
							|  |  |  | 	asm("":"=A" (n):"a" (__low),"d" (__high)); \ | 
					
						
							|  |  |  | 	__mod; \ | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #include <time.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | static FILETIME StartOfTimes, last_time; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  | static clock_t TimesStartOfTimes, Times_last_time; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitTime (void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |   HANDLE hProcess = GetCurrentProcess(); | 
					
						
							|  |  |  |   FILETIME CreationTime, ExitTime, KernelTime, UserTime; | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   if (!GetProcessTimes(hProcess, &CreationTime, &ExitTime, &KernelTime, &UserTime)) { | 
					
						
							|  |  |  |     /* WIN98 */ | 
					
						
							|  |  |  |     clock_t t; | 
					
						
							|  |  |  |     t = clock (); | 
					
						
							|  |  |  |     Times_last_time = TimesStartOfTimes = t; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     last_time.dwLowDateTime = UserTime.dwLowDateTime; | 
					
						
							|  |  |  |     last_time.dwHighDateTime = UserTime.dwHighDateTime; | 
					
						
							|  |  |  |     StartOfTimes.dwLowDateTime = UserTime.dwLowDateTime; | 
					
						
							|  |  |  |     StartOfTimes.dwHighDateTime = UserTime.dwHighDateTime; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | UInt | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_cputime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |   HANDLE hProcess = GetCurrentProcess(); | 
					
						
							|  |  |  |   FILETIME CreationTime, ExitTime, KernelTime, UserTime; | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   if (!GetProcessTimes(hProcess, &CreationTime, &ExitTime, &KernelTime, &UserTime)) { | 
					
						
							|  |  |  |     clock_t t; | 
					
						
							|  |  |  |     t = clock (); | 
					
						
							|  |  |  |     return(((t - TimesStartOfTimes)*1000) / CLOCKS_PER_SEC); | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #ifdef __GNUC__
 | 
					
						
							|  |  |  |     unsigned long long int t = | 
					
						
							|  |  |  |       *(unsigned long long int *)&UserTime -  | 
					
						
							|  |  |  |       *(unsigned long long int *)&StartOfTimes; | 
					
						
							| 
									
										
										
										
											2002-01-17 17:16:22 +00:00
										 |  |  |     do_div(t,10000); | 
					
						
							|  |  |  |     return((Int)t); | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |     __int64 t = *(__int64 *)&UserTime - *(__int64 *)&StartOfTimes; | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |     return((Int)(t/10000)); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_cputime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |   HANDLE hProcess = GetCurrentProcess(); | 
					
						
							|  |  |  |   FILETIME CreationTime, ExitTime, KernelTime, UserTime; | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   if (!GetProcessTimes(hProcess, &CreationTime, &ExitTime, &KernelTime, &UserTime)) { | 
					
						
							|  |  |  |     clock_t t; | 
					
						
							|  |  |  |     t = clock (); | 
					
						
							|  |  |  |     *now = ((t - TimesStartOfTimes)*1000) / CLOCKS_PER_SEC; | 
					
						
							|  |  |  |     *interval = (t - Times_last_time) * 1000 / CLOCKS_PER_SEC; | 
					
						
							|  |  |  |     Times_last_time = t; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #ifdef __GNUC__
 | 
					
						
							|  |  |  |     unsigned long long int t1 = | 
					
						
							|  |  |  |       *(unsigned long long int *)&UserTime - | 
					
						
							|  |  |  |       *(unsigned long long int *)&StartOfTimes; | 
					
						
							|  |  |  |     unsigned long long int t2 = | 
					
						
							|  |  |  |       *(unsigned long long int *)&UserTime - | 
					
						
							|  |  |  |       *(unsigned long long int *)&last_time; | 
					
						
							| 
									
										
										
										
											2002-01-17 17:16:22 +00:00
										 |  |  |     do_div(t1,10000); | 
					
						
							|  |  |  |     *now = (Int)t1; | 
					
						
							|  |  |  |     do_div(t2,10000); | 
					
						
							|  |  |  |     *interval = (Int)t2; | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |     __int64 t1 = *(__int64 *)&UserTime - *(__int64 *)&StartOfTimes; | 
					
						
							|  |  |  |     __int64 t2 = *(__int64 *)&UserTime - *(__int64 *)&last_time; | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |     *now = (Int)(t1/10000); | 
					
						
							|  |  |  |     *interval = (Int)(t2/10000); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     last_time.dwLowDateTime = UserTime.dwLowDateTime; | 
					
						
							|  |  |  |     last_time.dwHighDateTime = UserTime.dwHighDateTime; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #elif HAVE_TIMES
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if defined(_WIN32)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <time.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define TicksPerSec     CLOCKS_PER_SEC
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_SYS_TIMES_H
 | 
					
						
							|  |  |  | #include <sys/times.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-24 18:07:16 +00:00
										 |  |  | #if defined(__sun__) && (defined(__svr4__) || defined(__SVR4))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_LIMITS_H
 | 
					
						
							|  |  |  | #include <limits.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define TicksPerSec	CLK_TCK
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if defined(__alpha) || defined(__FreeBSD__) || defined(__linux__)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_TIME_H
 | 
					
						
							|  |  |  | #include <time.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define TicksPerSec	sysconf(_SC_CLK_TCK)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if !TMS_IN_SYS_TIME
 | 
					
						
							|  |  |  | #if HAVE_SYS_TIMES_H
 | 
					
						
							|  |  |  | #include <sys/times.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static clock_t StartOfTimes, last_time; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitTime (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct tms t; | 
					
						
							|  |  |  |   times (&t); | 
					
						
							|  |  |  |   last_time = StartOfTimes = t.tms_utime; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | UInt | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_cputime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct tms t; | 
					
						
							|  |  |  |   times(&t); | 
					
						
							|  |  |  |   return((t.tms_utime - StartOfTimes)*1000 / TicksPerSec); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_cputime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct tms t; | 
					
						
							|  |  |  |   times (&t); | 
					
						
							|  |  |  |   *now = ((t.tms_utime - StartOfTimes)*1000) / TicksPerSec; | 
					
						
							|  |  |  |   *interval = (t.tms_utime - last_time) * 1000 / TicksPerSec; | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |   last_time = t.tms_utime; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else /* HAVE_TIMES */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef SIMICS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <sys/time.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since the point YAP was started */ | 
					
						
							|  |  |  | static struct timeval StartOfTimes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since last call to runtime */ | 
					
						
							|  |  |  | static struct timeval last_time; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitTime (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct timeval   tp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   gettimeofday(&tp,NULL); | 
					
						
							|  |  |  |   last_time.tv_sec = StartOfTimes.tv_sec = tp.tv_sec; | 
					
						
							|  |  |  |   last_time.tv_usec = StartOfTimes.tv_usec = tp.tv_usec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | UInt | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_cputime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct timeval   tp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   gettimeofday(&tp,NULL); | 
					
						
							|  |  |  |   if (StartOfTimes.tv_usec > tp.tv_usec) | 
					
						
							|  |  |  |     return((tp.tv_sec - StartOfTimes.tv_sec - 1) * 1000 + | 
					
						
							|  |  |  | 	   (StartOfTimes.tv_usec - tp.tv_usec) /1000); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return((tp.tv_sec - StartOfTimes.tv_sec)) * 1000 + | 
					
						
							|  |  |  |       ((tp.tv_usec - StartOfTimes.tv_usec) / 1000); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_cputime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct timeval   tp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   gettimeofday(&tp,NULL); | 
					
						
							|  |  |  |   *now = (tp.tv_sec - StartOfTimes.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (tp.tv_usec - StartOfTimes.tv_usec) / 1000; | 
					
						
							|  |  |  |   *interval = (tp.tv_sec - last_time.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (tp.tv_usec - last_time.tv_usec) / 1000; | 
					
						
							|  |  |  |   last_time.tv_usec = tp.tv_usec; | 
					
						
							|  |  |  |   last_time.tv_sec = tp.tv_sec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* SIMICS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef COMMENTED_OUT
 | 
					
						
							|  |  |  | /* This code is not working properly. I left it here to help future ports */ | 
					
						
							|  |  |  | #ifdef MPW
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <files.h>
 | 
					
						
							|  |  |  | #include <Events.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define TicksPerSec 60.0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static double | 
					
						
							|  |  |  | real_cputime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (((double) TickCount ()) / TicksPerSec); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* MPW */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef LATTICE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "osbind.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static long *ptime; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | gettime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   *ptime = *(long *) 0x462; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static double | 
					
						
							|  |  |  | real_cputime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   long thetime; | 
					
						
							|  |  |  |   ptime = &thetime; | 
					
						
							|  |  |  |   xbios (38, gettime); | 
					
						
							|  |  |  |   return (((double) thetime) / (Getrez () == 2 ? 70 : 60)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* LATTICE */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef M_WILLIAMS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <osbind.h>
 | 
					
						
							|  |  |  | #include <xbios.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static long *ptime; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static long | 
					
						
							|  |  |  | readtime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (*((long *) 0x4ba)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static double | 
					
						
							|  |  |  | real_cputime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   long time; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   time = Supexec (readtime); | 
					
						
							|  |  |  |   return (time / 200.0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* M_WILLIAMS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef LIGHT
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #undef FALSE
 | 
					
						
							|  |  |  | #undef TRUE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <FileMgr.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define TicksPerSec 60.0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static double | 
					
						
							|  |  |  | real_cputime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (((double) TickCount ()) / TicksPerSec); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* LIGHT */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* COMMENTED_OUT */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* HAVE_GETRUSAGE */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_GETHRTIME
 | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_TIME_H
 | 
					
						
							|  |  |  | #include <time.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* since the point YAP was started */ | 
					
						
							|  |  |  | static hrtime_t StartOfWTimes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since last call to walltime */ | 
					
						
							|  |  |  | #define  LastWtime (*(hrtime_t *)ALIGN_YAPTYPE(LastWtimePtr,hrtime_t))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitWTime (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   StartOfWTimes = gethrtime(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitLastWtime(void) { | 
					
						
							|  |  |  |   /* ask for twice the space in order to guarantee alignment */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   LastWtimePtr = (void *)Yap_AllocCodeSpace(2*sizeof(hrtime_t)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   LastWtime = StartOfWTimes; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_walltime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   hrtime_t tp = gethrtime(); | 
					
						
							|  |  |  |   /* return time in milliseconds */ | 
					
						
							|  |  |  |   return((Int)((tp-StartOfWTimes)/((hrtime_t)1000000))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_walltime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   hrtime_t tp = gethrtime(); | 
					
						
							|  |  |  |   /* return time in milliseconds */ | 
					
						
							|  |  |  |   *now = (Int)((tp-StartOfWTimes)/((hrtime_t)1000000)); | 
					
						
							|  |  |  |   *interval = (Int)((tp-LastWtime)/((hrtime_t)1000000)); | 
					
						
							|  |  |  |   LastWtime = tp; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #elif HAVE_GETTIMEOFDAY
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since the point YAP was started */ | 
					
						
							|  |  |  | static struct timeval StartOfWTimes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since last call to walltime */ | 
					
						
							|  |  |  | #define LastWtime (*(struct timeval *)LastWtimePtr)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitWTime (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   gettimeofday(&StartOfWTimes,NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitLastWtime(void) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   LastWtimePtr = (void *)Yap_AllocCodeSpace(sizeof(struct timeval)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   LastWtime.tv_usec = StartOfWTimes.tv_usec; | 
					
						
							|  |  |  |   LastWtime.tv_sec = StartOfWTimes.tv_sec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_walltime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct timeval   tp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   gettimeofday(&tp,NULL); | 
					
						
							|  |  |  |   if (StartOfWTimes.tv_usec > tp.tv_usec) | 
					
						
							|  |  |  |     return((tp.tv_sec - StartOfWTimes.tv_sec - 1) * 1000 + | 
					
						
							|  |  |  | 	   (StartOfWTimes.tv_usec - tp.tv_usec) /1000); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return((tp.tv_sec - StartOfWTimes.tv_sec)) * 1000 + | 
					
						
							|  |  |  |       ((tp.tv_usec - LastWtime.tv_usec) / 1000); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_walltime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct timeval   tp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   gettimeofday(&tp,NULL); | 
					
						
							|  |  |  |   *now = (tp.tv_sec - StartOfWTimes.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (tp.tv_usec - StartOfWTimes.tv_usec) / 1000; | 
					
						
							|  |  |  |   *interval = (tp.tv_sec - LastWtime.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (tp.tv_usec - LastWtime.tv_usec) / 1000; | 
					
						
							|  |  |  |   LastWtime.tv_usec = tp.tv_usec; | 
					
						
							|  |  |  |   LastWtime.tv_sec = tp.tv_sec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #elif defined(_WIN32)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <sys/timeb.h>
 | 
					
						
							|  |  |  | #include <time.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since the point YAP was started */ | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | static struct _timeb StartOfWTimes; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* since last call to walltime */ | 
					
						
							|  |  |  | #define LastWtime (*(struct timeb *)LastWtimePtr)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitWTime (void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   _ftime(&StartOfWTimes); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitLastWtime(void) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   LastWtimePtr = (void *)Yap_AllocCodeSpace(sizeof(struct timeb)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   LastWtime.time = StartOfWTimes.time; | 
					
						
							|  |  |  |   LastWtime.millitm = StartOfWTimes.millitm; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_walltime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   struct _timeb   tp; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   _ftime(&tp); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   if (StartOfWTimes.millitm > tp.millitm) | 
					
						
							|  |  |  |     return((tp.time - StartOfWTimes.time - 1) * 1000 + | 
					
						
							|  |  |  | 	   (StartOfWTimes.millitm - tp.millitm)); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return((tp.time - StartOfWTimes.time)) * 1000 + | 
					
						
							|  |  |  |       ((tp.millitm - LastWtime.millitm) / 1000); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_walltime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   struct _timeb   tp; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   _ftime(&tp); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   *now = (tp.time - StartOfWTimes.time) * 1000 + | 
					
						
							|  |  |  |     (tp.millitm - StartOfWTimes.millitm); | 
					
						
							|  |  |  |   *interval = (tp.time - LastWtime.time) * 1000 + | 
					
						
							|  |  |  |     (tp.millitm - LastWtime.millitm) ; | 
					
						
							|  |  |  |   LastWtime.millitm = tp.millitm; | 
					
						
							|  |  |  |   LastWtime.time = tp.time; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #elif HAVE_TIMES
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static clock_t StartOfWTimes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define LastWtime (*(clock_t *)LastWtimePtr)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitWTime (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   StartOfWTimes = times(NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitLastWtime(void) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   LastWtimePtr = (void *)Yap_AllocCodeSpace(sizeof(clock_t)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   LastWtime = StartOfWTimes; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_walltime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   clock_t t; | 
					
						
							|  |  |  |   t = times(NULL); | 
					
						
							|  |  |  |   return ((t - StartOfWTimes)*1000 / TicksPerSec)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_walltime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   clock_t t; | 
					
						
							|  |  |  |   t = times(NULL); | 
					
						
							|  |  |  |   *now = ((t - StartOfWTimes)*1000) / TicksPerSec; | 
					
						
							|  |  |  |   *interval = (t - LastWtime) * 1000 / TicksPerSec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* HAVE_TIMES */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_TIME_H
 | 
					
						
							|  |  |  | #include <time.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | unsigned int current_seed; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitRandom (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   current_seed = (unsigned int) time (NULL); | 
					
						
							|  |  |  | #if HAVE_RANDOM
 | 
					
						
							|  |  |  |   srandom (current_seed); | 
					
						
							|  |  |  | #elif HAVE_RAND
 | 
					
						
							|  |  |  |   srand (current_seed); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | STD_PROTO (extern int rand, (void)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | double | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_random (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  | #if HAVE_RANDOM
 | 
					
						
							|  |  |  | /*  extern long random (); */ | 
					
						
							|  |  |  |   return (((double) random ()) / 0x7fffffffL /* 2**31-1 */); | 
					
						
							|  |  |  | #elif HAVE_RAND
 | 
					
						
							|  |  |  |   return (((double) (rand ()) / RAND_MAX)); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	"random not available in this configuration"); | 
					
						
							|  |  |  |   return (0.0); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_srandom (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   register Term t0 = Deref (ARG1); | 
					
						
							|  |  |  |   if (IsVarTerm (t0)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     return(Yap_unify(ARG1,MkIntegerTerm((Int)current_seed))); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   if(!IsNumTerm (t0)) | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   if (IsIntTerm (t0)) | 
					
						
							|  |  |  |     current_seed = (unsigned int) IntOfTerm (t0); | 
					
						
							|  |  |  |   else if (IsFloatTerm (t0)) | 
					
						
							|  |  |  |     current_seed  = (unsigned int) FloatOfTerm (t0); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     current_seed  = (unsigned int) LongIntOfTerm (t0); | 
					
						
							|  |  |  | #if HAVE_RANDOM
 | 
					
						
							|  |  |  |   srandom(current_seed); | 
					
						
							|  |  |  | #elif HAVE_RAND
 | 
					
						
							|  |  |  |   srand(current_seed); | 
					
						
							| 
									
										
										
										
											2002-08-18 23:18:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_SIGNAL
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <signal.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef MPW
 | 
					
						
							|  |  |  | #define signal	sigset
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SIGFPE	SIGDIV
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | STATIC_PROTO (void InitSignals, (void)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-24 18:07:16 +00:00
										 |  |  | #if (defined(__svr4__) || defined(__SVR4))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_SIGINFO_H
 | 
					
						
							|  |  |  | #include <siginfo.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_UCONTEXT_H
 | 
					
						
							|  |  |  | #include <sys/ucontext.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | STATIC_PROTO (void HandleSIGSEGV, (int, siginfo_t   *, ucontext_t *)); | 
					
						
							|  |  |  | STATIC_PROTO (void HandleMatherr,  (int, siginfo_t   *, ucontext_t *)); | 
					
						
							|  |  |  | STATIC_PROTO (void my_signal_info, (int, void (*)(int, siginfo_t  *, ucontext_t *))); | 
					
						
							|  |  |  | STATIC_PROTO (void my_signal, (int, void (*)(int, siginfo_t  *, ucontext_t *))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This routine believes there is a continuous space starting from the
 | 
					
						
							|  |  |  |    HeapBase and ending on TrailTop */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | HandleSIGSEGV(int   sig,   siginfo_t   *sip, ucontext_t *uap) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2004-02-05 16:57:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-05 03:37:01 +00:00
										 |  |  | #if !USE_SYSTEM_MALLOC
 | 
					
						
							| 
									
										
										
										
											2005-02-08 04:05:39 +00:00
										 |  |  |   if ( | 
					
						
							|  |  |  |       sip->si_code != SI_NOINFO && | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       sip->si_code == SEGV_MAPERR && | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       (void *)(sip->si_addr) > (void *)(Yap_HeapBase) && | 
					
						
							| 
									
										
										
										
											2004-06-05 03:37:01 +00:00
										 |  |  |       (void *)(sip->si_addr) < (void *)(Yap_TrailTop+64 * 1024L)) { | 
					
						
							| 
									
										
										
										
											2004-12-28 22:20:37 +00:00
										 |  |  |     Yap_growtrail(64 * 1024L, TRUE); | 
					
						
							| 
									
										
										
										
											2004-06-05 03:37:01 +00:00
										 |  |  |   }  else | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       Yap_Error(FATAL_ERROR, TermNil, | 
					
						
							|  |  |  | 		"likely bug in YAP, segmentation violation at %p", sip->si_addr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | HandleMatherr(int  sig, siginfo_t *sip, ucontext_t *uap) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   yap_error_number error_no; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* reset the registers so that we don't have trash in abstract machine */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   switch(sip->si_code) { | 
					
						
							|  |  |  |   case FPE_INTDIV: | 
					
						
							|  |  |  |     error_no = EVALUATION_ERROR_ZERO_DIVISOR; | 
					
						
							|  |  |  |     break; | 
					
						
							|  |  |  |   case FPE_INTOVF: | 
					
						
							|  |  |  |     error_no = EVALUATION_ERROR_INT_OVERFLOW; | 
					
						
							|  |  |  |     break; | 
					
						
							|  |  |  |   case FPE_FLTDIV: | 
					
						
							|  |  |  |     error_no = EVALUATION_ERROR_ZERO_DIVISOR; | 
					
						
							|  |  |  |     break; | 
					
						
							|  |  |  |   case FPE_FLTOVF: | 
					
						
							|  |  |  |     error_no = EVALUATION_ERROR_FLOAT_OVERFLOW; | 
					
						
							|  |  |  |     break; | 
					
						
							|  |  |  |   case FPE_FLTUND: | 
					
						
							|  |  |  |     error_no = EVALUATION_ERROR_FLOAT_UNDERFLOW; | 
					
						
							|  |  |  |     break; | 
					
						
							|  |  |  |   case FPE_FLTRES: | 
					
						
							|  |  |  |   case FPE_FLTINV: | 
					
						
							|  |  |  |   case FPE_FLTSUB: | 
					
						
							|  |  |  |   default: | 
					
						
							|  |  |  |     error_no = EVALUATION_ERROR_UNDEFINED; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   set_fpu_exceptions(0); | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_Error(error_no, TermNil, ""); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | my_signal_info(int sig, void (*handler)(int, siginfo_t  *, ucontext_t *)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct sigaction sigact; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sigact.sa_handler = handler; | 
					
						
							|  |  |  |   sigemptyset(&sigact.sa_mask); | 
					
						
							| 
									
										
										
										
											2001-08-08 21:17:27 +00:00
										 |  |  |   sigact.sa_flags = SA_SIGINFO; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   sigaction(sig,&sigact,NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | my_signal(int sig, void (*handler)(int, siginfo_t *, ucontext_t *)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct sigaction sigact; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sigact.sa_handler=handler; | 
					
						
							|  |  |  |   sigemptyset(&sigact.sa_mask); | 
					
						
							| 
									
										
										
										
											2001-08-08 21:17:27 +00:00
										 |  |  |   sigact.sa_flags = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   sigaction(sig,&sigact,NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-02-08 04:05:39 +00:00
										 |  |  | #elif defined(__linux__)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | STATIC_PROTO (RETSIGTYPE HandleMatherr, (int)); | 
					
						
							|  |  |  | STATIC_PROTO (RETSIGTYPE HandleSIGSEGV, (int,siginfo_t *,void *)); | 
					
						
							|  |  |  | STATIC_PROTO (void my_signal_info, (int, void (*)(int,siginfo_t *,void *))); | 
					
						
							|  |  |  | STATIC_PROTO (void my_signal, (int, void (*)(int))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /******** Handling floating point errors *******************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* old code, used to work with matherror(), deprecated now:
 | 
					
						
							|  |  |  |   char err_msg[256]; | 
					
						
							|  |  |  |   switch (x->type) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     case DOMAIN: | 
					
						
							|  |  |  |     case SING: | 
					
						
							|  |  |  |       Yap_Error(EVALUATION_ERROR_UNDEFINED, TermNil, "%s", x->name); | 
					
						
							|  |  |  |       return(0); | 
					
						
							|  |  |  |     case OVERFLOW: | 
					
						
							|  |  |  |       Yap_Error(EVALUATION_ERROR_FLOAT_OVERFLOW, TermNil, "%s", x->name); | 
					
						
							|  |  |  |       return(0); | 
					
						
							|  |  |  |     case UNDERFLOW: | 
					
						
							|  |  |  |       Yap_Error(EVALUATION_ERROR_FLOAT_UNDERFLOW, TermNil, "%s", x->name); | 
					
						
							|  |  |  |       return(0); | 
					
						
							|  |  |  |     case PLOSS: | 
					
						
							|  |  |  |     case TLOSS: | 
					
						
							|  |  |  |       Yap_Error(EVALUATION_ERROR_UNDEFINED, TermNil, "%s(%g) = %g", x->name, | 
					
						
							|  |  |  | 	       x->arg1, x->retval); | 
					
						
							|  |  |  |       return(0); | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |       Yap_Error(EVALUATION_ERROR_UNDEFINED, TermNil, NULL); | 
					
						
							|  |  |  |       return(0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_FENV_H
 | 
					
						
							|  |  |  | #include <fenv.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static RETSIGTYPE | 
					
						
							|  |  |  | HandleMatherr(int sig) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if HAVE_FETESTEXCEPT
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* This should work in Linux, but it doesn't seem to. */ | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   int raised = fetestexcept(FE_ALL_EXCEPT); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (raised & FE_OVERFLOW) { | 
					
						
							|  |  |  |     Yap_matherror = EVALUATION_ERROR_FLOAT_OVERFLOW; | 
					
						
							|  |  |  |   } else if (raised & (FE_INVALID|FE_INEXACT)) { | 
					
						
							|  |  |  |     Yap_matherror = EVALUATION_ERROR_UNDEFINED; | 
					
						
							|  |  |  |   } else if (raised & FE_DIVBYZERO) { | 
					
						
							|  |  |  |     Yap_matherror = EVALUATION_ERROR_ZERO_DIVISOR; | 
					
						
							|  |  |  |   } else if (raised & FE_UNDERFLOW) { | 
					
						
							|  |  |  |     Yap_matherror = EVALUATION_ERROR_FLOAT_UNDERFLOW; | 
					
						
							|  |  |  |   } else | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     Yap_matherror = EVALUATION_ERROR_UNDEFINED; | 
					
						
							|  |  |  |   /* something very bad happened on the way to the forum */ | 
					
						
							|  |  |  |   set_fpu_exceptions(FALSE); | 
					
						
							|  |  |  |   Yap_Error(Yap_matherror, TermNil, ""); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | SearchForTrailFault(siginfo_t *siginfo) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   void *ptr = siginfo->si_addr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* If the TRAIL is very close to the top of mmaped allocked space,
 | 
					
						
							|  |  |  |      then we can try increasing the TR space and restarting the | 
					
						
							|  |  |  |      instruction. In the worst case, the system will | 
					
						
							|  |  |  |      crash again | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | #if  OS_HANDLES_TR_OVERFLOW && !USE_SYSTEM_MALLOC
 | 
					
						
							|  |  |  |   if ((ptr > (void *)Yap_TrailTop-1024  &&  | 
					
						
							| 
									
										
										
										
											2005-05-26 18:26:27 +00:00
										 |  |  |        TR < (tr_fr_ptr) Yap_TrailTop+(64*1024))) { | 
					
						
							| 
									
										
										
										
											2005-02-08 04:05:39 +00:00
										 |  |  |     if (!Yap_growtrail(64*1024, TRUE)) { | 
					
						
							|  |  |  |       Yap_Error(OUT_OF_TRAIL_ERROR, TermNil, "YAP failed to reserve %ld bytes in growtrail", 64*1024L); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     /* just in case, make sure the OS keeps the signal handler. */ | 
					
						
							|  |  |  |     /*    my_signal_info(SIGSEGV, HandleSIGSEGV); */ | 
					
						
							|  |  |  |   } else | 
					
						
							|  |  |  | #endif /* OS_HANDLES_TR_OVERFLOW */
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       Yap_Error(FATAL_ERROR, TermNil, | 
					
						
							| 
									
										
										
										
											2005-02-08 18:05:21 +00:00
										 |  |  | 		"tried to access illegal address %p!!!!", ptr); | 
					
						
							| 
									
										
										
										
											2005-02-08 04:05:39 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static RETSIGTYPE | 
					
						
							|  |  |  | HandleSIGSEGV(int   sig, siginfo_t *siginfo, void *context) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   if (Yap_PrologMode & ExtendStackMode) { | 
					
						
							|  |  |  |     Yap_Error(FATAL_ERROR, TermNil, "OS memory allocation crashed at address %p, bailing out\n",Yap_TrailTop); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   SearchForTrailFault(siginfo); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | my_signal_info(int sig, void (*handler)(int,siginfo_t *,void *)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct sigaction sigact; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sigact.sa_sigaction = handler; | 
					
						
							|  |  |  |   sigemptyset(&sigact.sa_mask); | 
					
						
							|  |  |  | #if HAVE_SIGINFO
 | 
					
						
							|  |  |  |   sigact.sa_flags = SA_SIGINFO; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   sigact.sa_flags = 0; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sigaction(sig,&sigact,NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | my_signal(int sig, void (*handler)(int)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct sigaction sigact; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sigact.sa_handler=handler; | 
					
						
							|  |  |  |   sigemptyset(&sigact.sa_mask); | 
					
						
							|  |  |  |   sigact.sa_flags = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sigaction(sig,&sigact,NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-09 17:19:36 +00:00
										 |  |  | #else /* if not (defined(__svr4__) || defined(__SVR4)) */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | STATIC_PROTO (RETSIGTYPE HandleMatherr, (int)); | 
					
						
							|  |  |  | STATIC_PROTO (RETSIGTYPE HandleSIGSEGV, (int)); | 
					
						
							|  |  |  | STATIC_PROTO (void my_signal_info, (int, void (*)(int))); | 
					
						
							|  |  |  | STATIC_PROTO (void my_signal, (int, void (*)(int))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /******** Handling floating point errors *******************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* old code, used to work with matherror(), deprecated now:
 | 
					
						
							|  |  |  |   char err_msg[256]; | 
					
						
							|  |  |  |   switch (x->type) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     case DOMAIN: | 
					
						
							|  |  |  |     case SING: | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       Yap_Error(EVALUATION_ERROR_UNDEFINED, TermNil, "%s", x->name); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       return(0); | 
					
						
							|  |  |  |     case OVERFLOW: | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       Yap_Error(EVALUATION_ERROR_FLOAT_OVERFLOW, TermNil, "%s", x->name); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       return(0); | 
					
						
							|  |  |  |     case UNDERFLOW: | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       Yap_Error(EVALUATION_ERROR_FLOAT_UNDERFLOW, TermNil, "%s", x->name); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       return(0); | 
					
						
							|  |  |  |     case PLOSS: | 
					
						
							|  |  |  |     case TLOSS: | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       Yap_Error(EVALUATION_ERROR_UNDEFINED, TermNil, "%s(%g) = %g", x->name, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	       x->arg1, x->retval); | 
					
						
							|  |  |  |       return(0); | 
					
						
							|  |  |  |     default: | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       Yap_Error(EVALUATION_ERROR_UNDEFINED, TermNil, NULL); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       return(0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_FENV_H
 | 
					
						
							|  |  |  | #include <fenv.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static RETSIGTYPE | 
					
						
							|  |  |  | HandleMatherr(int sig) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if HAVE_FETESTEXCEPT
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* This should work in Linux, but it doesn't seem to. */ | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   int raised = fetestexcept(FE_ALL_EXCEPT); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (raised & FE_OVERFLOW) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_matherror = EVALUATION_ERROR_FLOAT_OVERFLOW; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } else if (raised & (FE_INVALID|FE_INEXACT)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_matherror = EVALUATION_ERROR_UNDEFINED; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } else if (raised & FE_DIVBYZERO) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_matherror = EVALUATION_ERROR_ZERO_DIVISOR; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } else if (raised & FE_UNDERFLOW) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_matherror = EVALUATION_ERROR_FLOAT_UNDERFLOW; | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   } else | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_matherror = EVALUATION_ERROR_UNDEFINED; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   /* something very bad happened on the way to the forum */ | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   set_fpu_exceptions(FALSE); | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_Error(Yap_matherror, TermNil, ""); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | SearchForTrailFault(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   /* If the TRAIL is very close to the top of mmaped allocked space,
 | 
					
						
							|  |  |  |      then we can try increasing the TR space and restarting the | 
					
						
							|  |  |  |      instruction. In the worst case, the system will | 
					
						
							|  |  |  |      crash again | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | #ifdef DEBUG
 | 
					
						
							|  |  |  |   /*  fprintf(stderr,"Catching a sigsegv at %p with %p\n", TR, TrailTop); */ | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-02-05 16:57:02 +00:00
										 |  |  | #if  OS_HANDLES_TR_OVERFLOW && !USE_SYSTEM_MALLOC
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   if ((TR > (tr_fr_ptr)Yap_TrailTop-1024  &&  | 
					
						
							|  |  |  |        TR < (tr_fr_ptr)Yap_TrailTop+(64*1024))|| Yap_DBTrailOverflow()) { | 
					
						
							| 
									
										
										
										
											2003-02-12 13:20:52 +00:00
										 |  |  |     long trsize = 64*2014L; | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-04-30 12:57:21 +00:00
										 |  |  |     while ((CELL)TR > (CELL)Yap_TrailTop+trsize) { | 
					
						
							| 
									
										
										
										
											2003-02-12 13:20:52 +00:00
										 |  |  |       trsize += 64*2014L; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2004-12-28 22:20:37 +00:00
										 |  |  |     if (!Yap_growtrail(trsize, TRUE)) { | 
					
						
							| 
									
										
										
										
											2004-02-05 16:57:02 +00:00
										 |  |  |       Yap_Error(OUT_OF_TRAIL_ERROR, TermNil, "YAP failed to reserve %ld bytes in growtrail", 64*1024L); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     /* just in case, make sure the OS keeps the signal handler. */ | 
					
						
							|  |  |  |     /*    my_signal_info(SIGSEGV, HandleSIGSEGV); */ | 
					
						
							|  |  |  |   } else | 
					
						
							| 
									
										
										
										
											2002-10-21 22:52:36 +00:00
										 |  |  | #endif /* OS_HANDLES_TR_OVERFLOW */
 | 
					
						
							| 
									
										
										
										
											2005-03-01 22:25:09 +00:00
										 |  |  |     Yap_Error(INTERNAL_ERROR, TermNil, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	  "likely bug in YAP, segmentation violation"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static RETSIGTYPE | 
					
						
							|  |  |  | HandleSIGSEGV(int   sig) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   if (Yap_PrologMode & ExtendStackMode) { | 
					
						
							| 
									
										
										
										
											2004-10-26 20:16:18 +00:00
										 |  |  |     Yap_Error(FATAL_ERROR, TermNil, "OS memory allocation crashed at address %p, bailing out\n",Yap_TrailTop); | 
					
						
							| 
									
										
										
										
											2002-10-10 05:58:49 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   SearchForTrailFault(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  | #if HAVE_SIGACTION
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | my_signal_info(int sig, void (*handler)(int)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct sigaction sigact; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sigact.sa_handler = handler; | 
					
						
							|  |  |  |   sigemptyset(&sigact.sa_mask); | 
					
						
							| 
									
										
										
										
											2002-05-28 16:23:53 +00:00
										 |  |  | #if HAVE_SIGINFO
 | 
					
						
							| 
									
										
										
										
											2002-05-26 04:03:56 +00:00
										 |  |  |   sigact.sa_flags = SA_SIGINFO; | 
					
						
							| 
									
										
										
										
											2002-05-28 16:23:53 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  |   sigact.sa_flags = 0; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   sigaction(sig,&sigact,NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | my_signal(int sig, void (*handler)(int)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct sigaction sigact; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sigact.sa_handler=handler; | 
					
						
							|  |  |  |   sigemptyset(&sigact.sa_mask); | 
					
						
							| 
									
										
										
										
											2002-05-26 04:03:56 +00:00
										 |  |  |   sigact.sa_flags = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   sigaction(sig,&sigact,NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | my_signal(int sig, void (*handler)(int)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   signal(sig, handler); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | my_signal_info(sig, handler) | 
					
						
							|  |  |  | int sig; | 
					
						
							|  |  |  | void (*handler)(int); | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   if(signal(sig, handler) == SIG_ERR) | 
					
						
							|  |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif /* __linux__ */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-09 17:19:36 +00:00
										 |  |  | #endif /* (defined(__svr4__) || defined(__SVR4)) */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-12 17:25:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | static int | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  | InteractSIGINT(int ch) { | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   switch (ch) { | 
					
						
							|  |  |  |   case 'a': | 
					
						
							|  |  |  |     /* abort computation */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     if (Yap_PrologMode & ConsoleGetcMode) { | 
					
						
							|  |  |  |       Yap_PrologMode |= AbortMode; | 
					
						
							| 
									
										
										
										
											2002-02-12 18:24:21 +00:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       Yap_Error(PURE_ABORT, TermNil, ""); | 
					
						
							| 
									
										
										
										
											2002-02-12 18:24:21 +00:00
										 |  |  |       /* in case someone mangles the P register */ | 
					
						
							| 
									
										
										
										
											2005-12-23 00:20:14 +00:00
										 |  |  |       save_machine_regs(); | 
					
						
							| 
									
										
										
										
											2002-02-12 18:24:21 +00:00
										 |  |  | #if  _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  |       /* don't even think about trying this */ | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-10-08 14:32:42 +00:00
										 |  |  | #if PUSH_REGS
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       restore_absmi_regs(&Yap_standard_regs); | 
					
						
							| 
									
										
										
										
											2002-10-08 14:32:42 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       siglongjmp (Yap_RestartEnv, 1); | 
					
						
							| 
									
										
										
										
											2002-02-12 18:24:21 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2004-10-08 17:20:03 +00:00
										 |  |  |     return -1; | 
					
						
							| 
									
										
										
										
											2005-11-09 18:02:53 +00:00
										 |  |  |   case 'b': | 
					
						
							|  |  |  |     /* continue */ | 
					
						
							|  |  |  |     Yap_signal (YAP_BREAK_SIGNAL); | 
					
						
							|  |  |  |     return 1; | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   case 'c': | 
					
						
							|  |  |  |     /* continue */ | 
					
						
							| 
									
										
										
										
											2004-10-08 17:20:03 +00:00
										 |  |  |     return 1; | 
					
						
							| 
									
										
										
										
											2001-08-08 21:17:27 +00:00
										 |  |  |   case 'd': | 
					
						
							| 
									
										
										
										
											2004-10-08 17:20:03 +00:00
										 |  |  |     Yap_signal (YAP_DEBUG_SIGNAL); | 
					
						
							| 
									
										
										
										
											2001-08-08 21:17:27 +00:00
										 |  |  |     /* enter debug mode */ | 
					
						
							| 
									
										
										
										
											2004-10-08 17:20:03 +00:00
										 |  |  |     return 1; | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   case 'e': | 
					
						
							|  |  |  |     /* exit */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_exit(0); | 
					
						
							| 
									
										
										
										
											2004-10-08 17:20:03 +00:00
										 |  |  |     return -1; | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   case 't': | 
					
						
							|  |  |  |     /* start tracing */ | 
					
						
							| 
									
										
										
										
											2004-10-08 17:20:03 +00:00
										 |  |  |     Yap_signal (YAP_TRACE_SIGNAL); | 
					
						
							|  |  |  |     return 1; | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #ifdef LOW_LEVEL_TRACER
 | 
					
						
							|  |  |  |   case 'T': | 
					
						
							|  |  |  |     toggle_low_level_trace(); | 
					
						
							| 
									
										
										
										
											2004-10-08 17:20:03 +00:00
										 |  |  |     return 1; | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |   case 's': | 
					
						
							|  |  |  |     /* show some statistics */ | 
					
						
							| 
									
										
										
										
											2004-10-08 17:20:03 +00:00
										 |  |  |     Yap_signal (YAP_STATISTICS_SIGNAL); | 
					
						
							|  |  |  |     return 1; | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   case EOF: | 
					
						
							|  |  |  |     return(0); | 
					
						
							|  |  |  |     break; | 
					
						
							|  |  |  |   case 'h': | 
					
						
							|  |  |  |   case '?': | 
					
						
							|  |  |  |   default: | 
					
						
							|  |  |  |     /* show an helpful message */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     fprintf(Yap_stderr, "Please press one of:\n"); | 
					
						
							|  |  |  |     fprintf(Yap_stderr, "  a for abort\n  c for continue\n  d for debug\n"); | 
					
						
							|  |  |  |     fprintf(Yap_stderr, "  e for exit\n  s for statistics\n  t for trace\n"); | 
					
						
							| 
									
										
										
										
											2004-10-22 16:53:20 +00:00
										 |  |  |     fprintf(Yap_stderr, "  b for break\n"); | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |     return(0); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   This function talks to the user about a signal. We assume we are in | 
					
						
							|  |  |  |   the context of the main Prolog thread (trivial in Unix, but hard in WIN32) | 
					
						
							|  |  |  | */  | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | static int | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | ProcessSIGINT(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   int ch, out; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   do { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     ch = Yap_GetCharForSIGINT(); | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   } while (!(out = InteractSIGINT(ch))); | 
					
						
							|  |  |  |   return(out); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_ProcessSIGINT(void) | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   return ProcessSIGINT(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | /* This function is called from the signal handler to process signals.
 | 
					
						
							|  |  |  |    We assume we are within the context of the signal handler, whatever | 
					
						
							|  |  |  |    that might be | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | static RETSIGTYPE | 
					
						
							| 
									
										
										
										
											2001-09-24 18:07:16 +00:00
										 |  |  | #if (defined(__svr4__) || defined(__SVR4))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | HandleSIGINT (int sig, siginfo_t   *x, ucontext_t *y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | HandleSIGINT (int sig) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   my_signal(SIGINT, HandleSIGINT); | 
					
						
							| 
									
										
										
										
											2002-10-23 20:55:37 +00:00
										 |  |  |   /* do this before we act */ | 
					
						
							| 
									
										
										
										
											2001-06-27 13:22:30 +00:00
										 |  |  | #if HAVE_ISATTY
 | 
					
						
							|  |  |  |   if (!isatty(0)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(INTERRUPT_ERROR,MkIntTerm(SIGINT),NULL); | 
					
						
							| 
									
										
										
										
											2001-06-27 13:22:30 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   if (Yap_PrologMode & (CritMode|ConsoleGetcMode)) { | 
					
						
							|  |  |  |     Yap_PrologMode |= InterruptMode; | 
					
						
							| 
									
										
										
										
											2001-08-08 21:17:27 +00:00
										 |  |  | #if HAVE_LIBREADLINE
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     if (Yap_PrologMode & ConsoleGetcMode) { | 
					
						
							| 
									
										
										
										
											2001-09-21 14:22:32 +00:00
										 |  |  |       fprintf(stderr, "Action (h for help): "); | 
					
						
							| 
									
										
										
										
											2002-02-12 21:40:36 +00:00
										 |  |  |       rl_point = rl_end = 0; | 
					
						
							| 
									
										
										
										
											2001-09-24 14:06:06 +00:00
										 |  |  | #if HAVE_RL_SET_PROMPT
 | 
					
						
							| 
									
										
										
										
											2001-09-21 14:22:32 +00:00
										 |  |  |       rl_set_prompt("Action (h for help): "); | 
					
						
							| 
									
										
										
										
											2001-09-24 14:06:06 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-08-08 21:17:27 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-06-27 13:22:30 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef HAVE_SETBUF
 | 
					
						
							|  |  |  |   /* make sure we are not waiting for the end of line */ | 
					
						
							| 
									
										
										
										
											2001-08-08 21:17:27 +00:00
										 |  |  |   YP_setbuf (stdin, NULL); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-08-08 21:17:27 +00:00
										 |  |  |   if (snoozing) { | 
					
						
							|  |  |  |     snoozing = FALSE; | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   ProcessSIGINT(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if !defined(_WIN32)
 | 
					
						
							|  |  |  | /* this routine is called if the system activated the alarm */ | 
					
						
							|  |  |  | static RETSIGTYPE | 
					
						
							| 
									
										
										
										
											2001-09-24 18:07:16 +00:00
										 |  |  | #if (defined(__svr4__) || defined(__SVR4))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | HandleALRM (int s, siginfo_t   *x, ucontext_t *y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | HandleALRM(int s) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-08-13 09:19:00 +00:00
										 |  |  |   my_signal (SIGALRM, HandleALRM); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   /* force the system to creep */ | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  |   Yap_signal (YAP_ALARM_SIGNAL); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   /* now, say what is going on */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_PutValue(AtomAlarm, MkAtomTerm(AtomTrue)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-09 17:19:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |  * This function is called after a normal interrupt had been caught. | 
					
						
							|  |  |  |  * It allows 6 possibilities: abort, continue, trace, debug, help, exit. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #if !defined(LIGHT) && !_MSC_VER && !defined(__MINGW32__) && !defined(LIGHT) 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | static RETSIGTYPE | 
					
						
							| 
									
										
										
										
											2001-09-24 18:07:16 +00:00
										 |  |  | #if (defined(__svr4__) || defined(__SVR4))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | ReceiveSignal (int s, siginfo_t   *x, ucontext_t *y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | ReceiveSignal (int s) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   switch (s) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | #ifndef MPW
 | 
					
						
							|  |  |  |     case SIGFPE: | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |       set_fpu_exceptions(FALSE); | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       Yap_Error (SYSTEM_ERROR, TermNil, "floating point exception ]"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       break; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if !defined(LIGHT) && !defined(_WIN32)
 | 
					
						
							|  |  |  |       /* These signals are not handled by WIN32 and not the Macintosh */ | 
					
						
							|  |  |  |     case SIGQUIT: | 
					
						
							|  |  |  |     case SIGKILL: | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       Yap_Error(INTERRUPT_ERROR,MkIntTerm(s),NULL); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-01-15 15:44:57 +00:00
										 |  |  | #if defined(SIGUSR1)
 | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |     case SIGUSR1: | 
					
						
							|  |  |  |       /* force the system to creep */ | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  |       Yap_signal (YAP_USR1_SIGNAL); | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |       break; | 
					
						
							| 
									
										
										
										
											2002-01-15 15:44:57 +00:00
										 |  |  | #endif /* defined(SIGUSR1) */
 | 
					
						
							|  |  |  | #if defined(SIGUSR2)
 | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |     case SIGUSR2: | 
					
						
							|  |  |  |       /* force the system to creep */ | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  |       Yap_signal (YAP_USR2_SIGNAL); | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |       break; | 
					
						
							| 
									
										
										
										
											2002-01-15 15:44:57 +00:00
										 |  |  | #endif /* defined(SIGUSR2) */
 | 
					
						
							|  |  |  | #if defined(SIGHUP)
 | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |     case SIGHUP: | 
					
						
							|  |  |  |       /* force the system to creep */ | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  |       Yap_signal (YAP_HUP_SIGNAL); | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |       break; | 
					
						
							| 
									
										
										
										
											2002-01-15 15:44:57 +00:00
										 |  |  | #endif /* defined(SIGHUP) */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     default: | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       fprintf(Yap_stderr, "\n[ Unexpected signal ]\n"); | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |       exit (EXIT_FAILURE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #if (_MSC_VER || defined(__MINGW32__))
 | 
					
						
							|  |  |  | static BOOL WINAPI | 
					
						
							|  |  |  | MSCHandleSignal(DWORD dwCtrlType) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   switch(dwCtrlType) { | 
					
						
							|  |  |  |   case CTRL_C_EVENT: | 
					
						
							|  |  |  |   case CTRL_BREAK_EVENT: | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  |     Yap_signal(YAP_ALARM_SIGNAL); | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_PrologMode |= InterruptMode; | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |     return(TRUE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   default: | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |     return(FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* SIGINT can cause problems, if caught before full initialization */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitSignals (void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |   if (Yap_PrologShouldHandleInterrupts) { | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #if !defined(LIGHT) && !_MSC_VER && !defined(__MINGW32__) && !defined(LIGHT) 
 | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |     my_signal (SIGQUIT, ReceiveSignal); | 
					
						
							|  |  |  |     my_signal (SIGKILL, ReceiveSignal); | 
					
						
							|  |  |  |     my_signal (SIGUSR1, ReceiveSignal); | 
					
						
							|  |  |  |     my_signal (SIGUSR2, ReceiveSignal); | 
					
						
							|  |  |  |     my_signal (SIGHUP,  ReceiveSignal); | 
					
						
							|  |  |  |     my_signal (SIGALRM, HandleALRM); | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |     signal (SIGINT, SIG_IGN); | 
					
						
							|  |  |  |     SetConsoleCtrlHandler(MSCHandleSignal,TRUE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |     my_signal (SIGINT, HandleSIGINT); | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifndef MPW
 | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |     my_signal (SIGFPE, HandleMatherr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-09-08 22:06:45 +00:00
										 |  |  | #if HAVE_SIGSEGV && !defined(THREADS) 
 | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |     my_signal_info (SIGSEGV, HandleSIGSEGV); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef ACOW
 | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |     signal(SIGCHLD, SIG_IGN);  /* avoid ghosts */  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  | #if OS_HANDLES_TR_OVERFLOW
 | 
					
						
							|  |  |  | #if HAVE_SIGSEGV && !defined(THREADS)
 | 
					
						
							|  |  |  |     my_signal_info (SIGSEGV, HandleSIGSEGV); | 
					
						
							|  |  |  | #endif    
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* HAVE_SIGNAL */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* TrueFileName -> Finds the true name of a file */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __MINGW32__
 | 
					
						
							|  |  |  | #include <ctype.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | static int | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | volume_header(char *file) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  |   char *ch = file; | 
					
						
							|  |  |  |   int c; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   while ((c = ch[0]) != '\0') { | 
					
						
							|  |  |  |     if (isalnum(c)) ch++; | 
					
						
							|  |  |  |     else return(c == ':'); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   return(FALSE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_volume_header(char *file) | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   return volume_header(file); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							|  |  |  | TrueFileName (char *source, char *result, int in_lib) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   register int ch; | 
					
						
							|  |  |  |   register char *res0 = result, *work; | 
					
						
							|  |  |  |   char ares1[YAP_FILENAME_MAX], *res1 = ares1; | 
					
						
							|  |  |  |   char *var_name; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   result[0] = '\0'; | 
					
						
							|  |  |  | #if defined(__MINGW32__) || _MSC_VER
 | 
					
						
							|  |  |  |   /* step 0: replace / by \ */ | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     char *p = source, ch = p[0]; | 
					
						
							|  |  |  |     while (ch != '\0') { | 
					
						
							|  |  |  |       if (ch == '/') p[0] = '\\'; | 
					
						
							|  |  |  |       p++; | 
					
						
							|  |  |  |       ch = p[0]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   /* step 1: eating home information */ | 
					
						
							|  |  |  |   if (source[0] == '~') | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       if (dir_separator(source[1]) || source[1] == '\0') | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  char *s; | 
					
						
							|  |  |  | 	  source++; | 
					
						
							|  |  |  | #if defined(_WIN32)
 | 
					
						
							|  |  |  | 	  s = getenv("HOMEDRIVE"); | 
					
						
							|  |  |  | 	  if (s != NULL) | 
					
						
							|  |  |  | 	    strncpy (result, getenv ("HOMEDRIVE"), YAP_FILENAME_MAX); | 
					
						
							|  |  |  | 	  s = getenv("HOMEPATH"); | 
					
						
							|  |  |  | 	  if (s != NULL) | 
					
						
							|  |  |  | 	    strncpy (result, s, YAP_FILENAME_MAX); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 	  s = getenv ("HOME"); | 
					
						
							|  |  |  | 	  if (s != NULL) | 
					
						
							|  |  |  | 	    strncpy (result, s, YAP_FILENAME_MAX); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | #if HAVE_GETPWNAM
 | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  struct passwd *user_passwd; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	  source++; | 
					
						
							|  |  |  | 	  while (!dir_separator((*res0 = *source)) && *res0 != '\0') | 
					
						
							|  |  |  | 	    res0++, source++; | 
					
						
							|  |  |  | 	  *res0++ = '\0'; | 
					
						
							|  |  |  | 	  if ((user_passwd = getpwnam (result)) == NULL) | 
					
						
							|  |  |  | 	    { | 
					
						
							|  |  |  | 	      return(FALSE); | 
					
						
							|  |  |  | 	    } | 
					
						
							|  |  |  | 	  strncpy (result, user_passwd->pw_dir, YAP_FILENAME_MAX); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |       strncat (result, source, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     strncpy (result, source, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   /* step 2: handling environment variables in file names */ | 
					
						
							|  |  |  |   strncpy (ares1, result, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   res0 = result; | 
					
						
							|  |  |  |   while ((ch = *res1++)!=0) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       if (ch == '\\' && !dir_separator('\\')) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  ch = *res1++; | 
					
						
							|  |  |  | 	  if (ch == '\0') | 
					
						
							|  |  |  | 	    { | 
					
						
							|  |  |  | 	      *res0 = '\0'; | 
					
						
							|  |  |  | 	      break; | 
					
						
							|  |  |  | 	    } | 
					
						
							|  |  |  | 	  else | 
					
						
							|  |  |  | 	    *res0++ = ch; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |       if (ch != '$') | 
					
						
							|  |  |  | 	*res0++ = ch; | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  char env_var[256], *sptr = env_var; | 
					
						
							|  |  |  | 	  while (((ch = *res1)!=0) && is_valid_env_char (ch)) | 
					
						
							|  |  |  | 	    { | 
					
						
							|  |  |  | 	      res1++; | 
					
						
							|  |  |  | 	      *sptr++ = ch; | 
					
						
							|  |  |  | 	    } | 
					
						
							|  |  |  | 	  *sptr = '\0'; | 
					
						
							|  |  |  | 	  if ((var_name = (char *) getenv (env_var)) == NULL) | 
					
						
							|  |  |  | 	    { | 
					
						
							|  |  |  | 	      return(FALSE); | 
					
						
							|  |  |  | 	    } | 
					
						
							|  |  |  | 	  else | 
					
						
							|  |  |  | 	    while ((*res0 = *var_name++)!=0) | 
					
						
							|  |  |  | 	      res0++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   *res0 = '\0'; | 
					
						
							|  |  |  |   /* step 3: get the full file name */ | 
					
						
							|  |  |  |   if (!dir_separator(result[0]) && !volume_header(result)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if __simplescalar__
 | 
					
						
							|  |  |  |       /* does not implement getcwd */ | 
					
						
							| 
									
										
										
										
											2001-07-16 15:26:14 +00:00
										 |  |  |       strncpy(ares1,yap_pwd,YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif HAVE_GETCWD
 | 
					
						
							|  |  |  |       if (getcwd (ares1, YAP_FILENAME_MAX) == NULL) | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  | 	return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  |       if (getwd (ares1) == NULL) | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  | 	return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  |       strncat (ares1, "\\", YAP_FILENAME_MAX); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |       strncat (ares1, "/", YAP_FILENAME_MAX); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |       strncat (ares1, result, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |       if (in_lib) { | 
					
						
							|  |  |  | 	int tmpf; | 
					
						
							|  |  |  | 	if ((tmpf = open(ares1, O_RDONLY)) < 0) { | 
					
						
							|  |  |  | 	  /* not in current directory, let us try the library */ | 
					
						
							|  |  |  | 	  if  (Yap_LibDir != NULL) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | 	    strncpy(Yap_FileNameBuf, Yap_LibDir, YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_GETENV
 | 
					
						
							|  |  |  | 	  } else { | 
					
						
							|  |  |  | 	    char *yap_env = getenv("YAPLIBDIR"); | 
					
						
							|  |  |  | 	    if (yap_env != NULL) { | 
					
						
							|  |  |  | 	      strncpy(ares1, yap_env, YAP_FILENAME_MAX); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	    } else { | 
					
						
							|  |  |  | 	      strncpy(ares1, LIB_DIR, YAP_FILENAME_MAX); | 
					
						
							|  |  |  | 	    } | 
					
						
							|  |  |  | #if HAVE_GETENV
 | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  | 	  strncat(ares1,"\\", YAP_FILENAME_MAX); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 	  strncat(ares1,"/", YAP_FILENAME_MAX); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	  strncat(ares1,result, YAP_FILENAME_MAX); | 
					
						
							|  |  |  | 	  if ((tmpf = open(ares1, O_RDONLY)) >= 0) { | 
					
						
							|  |  |  | 	    close(tmpf); | 
					
						
							|  |  |  | 	    strncpy (result, ares1, YAP_FILENAME_MAX); | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 	  strncpy (result, ares1, YAP_FILENAME_MAX); | 
					
						
							|  |  |  | 	  close(tmpf); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  | 	strncpy (result, ares1, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   /* step 4: simplifying the file name */ | 
					
						
							|  |  |  |   work = result; | 
					
						
							|  |  |  |   while (*work != '\0') | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       char *new_work, *next_work; | 
					
						
							|  |  |  |       if (*work++ != '.') | 
					
						
							|  |  |  | 	continue; | 
					
						
							|  |  |  |       if (*work != '.') | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  if (!dir_separator(*work) || !dir_separator(work[-2])) | 
					
						
							|  |  |  | 	    continue; | 
					
						
							|  |  |  | 	  next_work = work + 1; | 
					
						
							|  |  |  | 	  new_work = --work; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  if (!dir_separator(work[1]) || !dir_separator(work[-2])) | 
					
						
							|  |  |  | 	    continue; | 
					
						
							|  |  |  | 	  next_work = work + 2; | 
					
						
							|  |  |  | 	  work -= 2; | 
					
						
							|  |  |  | 	  if (work == result) | 
					
						
							|  |  |  | 	    return (FALSE); | 
					
						
							|  |  |  | 	  while (!dir_separator(*--work) && work != result); | 
					
						
							|  |  |  | 	  if (work == result && !dir_separator(work[0])) | 
					
						
							|  |  |  | 	    return (FALSE); | 
					
						
							|  |  |  | 	  new_work = ++work; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |       while ((*new_work++ = *next_work++)!=0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_TrueFileName (char *source, char *result, int in_lib) | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   return TrueFileName (source, result, in_lib); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | static Int | 
					
						
							|  |  |  | p_getcwd(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if __simplescalar__
 | 
					
						
							|  |  |  |   /* does not implement getcwd */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   strncpy(Yap_FileNameBuf,yap_pwd,YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif HAVE_GETCWD
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   if (getcwd (Yap_FileNameBuf, YAP_FILENAME_MAX) == NULL) { | 
					
						
							|  |  |  | #if HAVE_STRERROR
 | 
					
						
							|  |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, ARG1, "%s in getcwd/1", strerror(errno)); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, ARG1, "in getcwd/1"); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   if (getwd (Yap_FileNameBuf) == NULL) { | 
					
						
							|  |  |  | #if HAVE_STRERROR
 | 
					
						
							|  |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, ARG1, "%s in getcwd/1", strerror(errno)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, ARG1, "in getcwd/1"); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   return Yap_unify(ARG1,MkAtomTerm(Yap_LookupAtom(Yap_FileNameBuf))); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Executes $SHELL under Prolog */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_sh (void) | 
					
						
							|  |  |  | {				/* sh				 */ | 
					
						
							|  |  |  | #ifdef HAVE_SYSTEM
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   char *shell; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   shell = (char *) getenv ("SHELL"); | 
					
						
							|  |  |  |   if (shell == NULL) | 
					
						
							|  |  |  |     shell = "/bin/sh"; | 
					
						
							|  |  |  |   if (system (shell) < 0) { | 
					
						
							|  |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, "%s in sh/0", strerror(errno)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, "in sh/0"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							|  |  |  |   register char *shell; | 
					
						
							|  |  |  |   shell = "msh -i"; | 
					
						
							|  |  |  |   system (shell); | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR,TermNil,"sh not available in this configuration"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return(FALSE); | 
					
						
							|  |  |  | #endif /* MSH */
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_shell (void) | 
					
						
							|  |  |  | {				/* '$shell'(+SystCommand)			 */ | 
					
						
							|  |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR,TermNil,"shell not available in this configuration"); | 
					
						
							|  |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #if HAVE_SYSTEM 
 | 
					
						
							|  |  |  |   char *shell; | 
					
						
							|  |  |  |   register int bourne = FALSE; | 
					
						
							|  |  |  |   Term t1 = Deref (ARG1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   shell = (char *) getenv ("SHELL"); | 
					
						
							|  |  |  |   if (!strcmp (shell, "/bin/sh")) | 
					
						
							|  |  |  |     bourne = TRUE; | 
					
						
							|  |  |  |   if (shell == NIL) | 
					
						
							|  |  |  |     bourne = TRUE; | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   /* Yap_CloseStreams(TRUE); */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   if (bourne) | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |     return (system (RepAtom(AtomOfTerm(t1))->StrOfAE) == 0); | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       int status = -1; | 
					
						
							|  |  |  |       int child = fork (); | 
					
						
							|  |  |  |       if (child == 0) | 
					
						
							|  |  |  | 	{			/* let the children go */ | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | 	  if (!execl (shell, shell, "-c", RepAtom(AtomOfTerm(t1))->StrOfAE , NULL)) { | 
					
						
							| 
									
										
										
										
											2005-07-06 15:10:18 +00:00
										 |  |  | 	    exit(-1); | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	  exit(TRUE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  |       {				/* put the father on wait */ | 
					
						
							|  |  |  | 	int result = child < 0 || | 
					
						
							|  |  |  | /* vsc:I am not sure this is used, Stevens say wait returns an integer.
 | 
					
						
							|  |  |  | #if NO_UNION_WAIT
 | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 	wait ((&status)) != child || | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 	wait ((union wait *) (&status)) != child || | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 	status == 0; | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | 	return result; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #else /* HAVE_SYSTEM */
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							|  |  |  |   register char *shell; | 
					
						
							|  |  |  |   shell = "msh -i"; | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   /* Yap_CloseStreams(); */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   system (shell); | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_Error (SYSTEM_ERROR,TermNil,"shell not available in this configuration"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return(FALSE); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* HAVE_SYSTEM */
 | 
					
						
							|  |  |  | #endif /* _MSC_VER */
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_system (void) | 
					
						
							|  |  |  | {				/* '$system'(+SystCommand)	       */ | 
					
						
							|  |  |  | #ifdef HAVE_SYSTEM
 | 
					
						
							|  |  |  |   Term t1 = Deref (ARG1); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   char *s; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR,t1,"argument to system/1 unbound"); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } else if (IsAtomTerm(t1)) { | 
					
						
							|  |  |  |     s = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     if (!Yap_GetName (Yap_FileNameBuf, YAP_FILENAME_MAX, t1)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM,t1,"argument to system/1"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     s = Yap_FileNameBuf; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   /* Yap_CloseStreams(TRUE); */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if _MSC_VER
 | 
					
						
							|  |  |  |   _flushall(); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   if (system (s)) { | 
					
						
							|  |  |  | #if HAVE_STRERROR
 | 
					
						
							|  |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR,t1,"%s in system(%s)", strerror(errno), s); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR,t1,"in system(%s)", s); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							|  |  |  |   register char *shell; | 
					
						
							|  |  |  |   shell = "msh -i"; | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   /* Yap_CloseStreams(); */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   system (shell); | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							| 
									
										
										
										
											2002-01-02 05:35:20 +00:00
										 |  |  | #undef command
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR,TermNil,"sh not available in this machine"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return(FALSE); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* HAVE_SYSTEM */
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Rename a file */ | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_mv (void) | 
					
						
							|  |  |  | {				/* rename(+OldName,+NewName)   */ | 
					
						
							|  |  |  | #if HAVE_LINK
 | 
					
						
							|  |  |  |   int r; | 
					
						
							|  |  |  |   char oldname[YAP_FILENAME_MAX], newname[YAP_FILENAME_MAX]; | 
					
						
							|  |  |  |   Term t1 = Deref (ARG1); | 
					
						
							|  |  |  |   Term t2 = Deref (ARG2); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "first argument to rename/2 unbound"); | 
					
						
							|  |  |  |   } else if (!IsAtomTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM, t1, "first argument to rename/2 not atom"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   if (IsVarTerm(t2)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t2, "second argument to rename/2 unbound"); | 
					
						
							|  |  |  |   } else if (!IsAtomTerm(t2)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM, t2, "second argument to rename/2 not atom"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   TrueFileName (RepAtom(AtomOfTerm(t1))->StrOfAE, oldname, FALSE); | 
					
						
							|  |  |  |   TrueFileName (RepAtom(AtomOfTerm(t2))->StrOfAE, newname, FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   if ((r = link (oldname, newname)) == 0 && (r = unlink (oldname)) != 0) | 
					
						
							|  |  |  |     unlink (newname); | 
					
						
							|  |  |  |   if (r != 0) { | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #if HAVE_STRERROR
 | 
					
						
							|  |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR,t2,"%s in rename(%s,%s)", strerror(errno),oldname,newname); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR,t2,"in rename(%s,%s)",oldname,newname); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR,TermNil,"rename/2 not available in this machine"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return (FALSE); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  | /* find the directory info from a file name */ | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_file_directory_name (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   char *chp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "first arg of file_directory_name/2"); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!IsAtomTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM, t1,  "first arg of file_directory_name/2"); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   TrueFileName (RepAtom(AtomOfTerm(t1))->StrOfAE,  Yap_FileNameBuf, FALSE); | 
					
						
							|  |  |  |   chp = Yap_FileNameBuf+strlen(Yap_FileNameBuf); | 
					
						
							|  |  |  |   while (!dir_separator(*--chp) && chp != Yap_FileNameBuf); | 
					
						
							|  |  |  |   if (chp == Yap_FileNameBuf) { | 
					
						
							|  |  |  |     return Yap_unify(MkAtomTerm(Yap_LookupAtom(".")),ARG2); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   *chp = '\0'; | 
					
						
							|  |  |  |   return Yap_unify(MkAtomTerm(Yap_LookupAtom(Yap_FileNameBuf)),ARG2); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* Change the working directory */ | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_cd (void) | 
					
						
							|  |  |  | {				/* cd(+NewD)			 */ | 
					
						
							|  |  |  |   Term t1 = Deref (ARG1); | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR,t1,"argument to cd/1 is not valid"); | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } else if (IsAtomTerm(t1)) { | 
					
						
							|  |  |  |     TrueFileName (RepAtom(AtomOfTerm(t1))->StrOfAE, Yap_FileNameBuf2, FALSE); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     if (t1 == TermNil) | 
					
						
							|  |  |  |       return TRUE; | 
					
						
							|  |  |  |     if (!Yap_GetName (Yap_FileNameBuf, YAP_FILENAME_MAX, t1)) { | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |       Yap_Error(TYPE_ERROR_ATOM,t1,"argument to cd/1 is not valid"); | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     TrueFileName (Yap_FileNameBuf, Yap_FileNameBuf2, FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  | #if HAVE_CHDIR
 | 
					
						
							| 
									
										
										
										
											2001-07-16 15:26:14 +00:00
										 |  |  | #if  __simplescalar__
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   strncpy(yap_pwd,Yap_FileNameBuf2,YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2001-07-16 15:26:14 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   if (chdir (Yap_FileNameBuf2) < 0) { | 
					
						
							| 
									
										
										
										
											2002-06-26 05:17:14 +00:00
										 |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, t1,  | 
					
						
							|  |  |  | 	"%s in cd(%s)", strerror(errno), Yap_FileNameBuf2); | 
					
						
							| 
									
										
										
										
											2002-06-26 05:17:14 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR,t1," in cd(%s)", Yap_FileNameBuf2); | 
					
						
							| 
									
										
										
										
											2002-06-26 05:17:14 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2002-06-26 05:17:14 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef MACYAP
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   return (!chdir (Yap_FileNameBuf2)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR,TermNil,"cd/1 not available in this machine"); | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef MAC
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_SetTextFile (name) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |      char *name; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifdef MACC
 | 
					
						
							|  |  |  |   SetFileType (name, 'TEXT'); | 
					
						
							|  |  |  |   SetFileSignature (name, 'EDIT'); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   FInfo f; | 
					
						
							|  |  |  |   FInfo *p = &f; | 
					
						
							|  |  |  |   GetFInfo (name, 0, p); | 
					
						
							|  |  |  |   p->fdType = 'TEXT'; | 
					
						
							|  |  |  | #ifdef MPW
 | 
					
						
							|  |  |  |   if (mpwshell) | 
					
						
							|  |  |  |     p->fdCreator = 'MPS\0'; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef LIGHT
 | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     p->fdCreator = 'EDIT'; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   SetFInfo (name, 0, p); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* return YAP's environment */ | 
					
						
							|  |  |  | static Int p_getenv(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if HAVE_GETENV
 | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1), to; | 
					
						
							|  |  |  |   char *s, *so; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	  "first arg of getenv/2"); | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } else if (!IsAtomTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_ATOM, t1, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	  "first arg of getenv/2"); | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } else s = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |   if ((so = getenv(s)) == NULL) | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   to = MkAtomTerm(Yap_LookupAtom(so)); | 
					
						
							|  |  |  |   return(Yap_unify_constant(ARG2,to)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	  "getenv not available in this configuration"); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* set a variable in YAP's environment */ | 
					
						
							|  |  |  | static Int p_putenv(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if HAVE_PUTENV
 | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1), t2 = Deref(ARG2); | 
					
						
							|  |  |  |   char *s, *s2, *p0, *p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	  "first arg to putenv/2"); | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } else if (!IsAtomTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_ATOM, t1, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	  "first arg to putenv/2"); | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } else s = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |   if (IsVarTerm(t2)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	  "second arg to putenv/2"); | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } else if (!IsAtomTerm(t2)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_ATOM, t2, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	  "second arg to putenv/2"); | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } else s2 = RepAtom(AtomOfTerm(t2))->StrOfAE; | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   p0 = p = Yap_AllocAtomSpace(strlen(s)+strlen(s2)+3); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while ((*p++ = *s++) != '\0'); | 
					
						
							|  |  |  |   p[-1] = '='; | 
					
						
							|  |  |  |   while ((*p++ = *s2++) != '\0'); | 
					
						
							|  |  |  |   if (putenv(p0) == 0) | 
					
						
							|  |  |  |     return(TRUE); | 
					
						
							|  |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, | 
					
						
							|  |  |  | 	"in putenv(%s)", strerror(errno), p0); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, | 
					
						
							|  |  |  | 	"in putenv(%s)", p0); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |   return (FALSE); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	  "putenv not available in this configuration"); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-07-05 20:23:21 +00:00
										 |  |  | /* set a variable in YAP's environment */ | 
					
						
							|  |  |  | static Int p_file_age(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   char *file_name = RepAtom(AtomOfTerm(Deref(ARG1)))->StrOfAE; | 
					
						
							| 
									
										
										
										
											2002-10-10 05:58:49 +00:00
										 |  |  |   if (strcmp(file_name,"user_input") == 0) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     return(Yap_unify(ARG2,MkIntTerm(-1))); | 
					
						
							| 
									
										
										
										
											2001-07-05 20:23:21 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2002-10-10 05:58:49 +00:00
										 |  |  | #if HAVE_LSTAT 
 | 
					
						
							|  |  |  |  { | 
					
						
							|  |  |  |    struct stat buf; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    if (lstat(file_name, &buf) == -1) { | 
					
						
							|  |  |  |      /* file does not exist, but was opened? Return -1 */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |      return(Yap_unify(ARG2, MkIntTerm(-1))); | 
					
						
							| 
									
										
										
										
											2002-10-10 05:58:49 +00:00
										 |  |  |    } | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |    return(Yap_unify(ARG2, MkIntegerTerm(buf.st_mtime))); | 
					
						
							| 
									
										
										
										
											2002-10-10 05:58:49 +00:00
										 |  |  |  } | 
					
						
							| 
									
										
										
										
											2001-07-05 20:23:21 +00:00
										 |  |  | #elif defined(__MINGW32__) || _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2002-10-10 05:58:49 +00:00
										 |  |  |   { | 
					
						
							|  |  |  |     struct _stat buf; | 
					
						
							| 
									
										
										
										
											2001-07-05 20:23:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-10 05:58:49 +00:00
										 |  |  |     if (_stat(file_name, &buf) != 0) { | 
					
						
							|  |  |  |       /* return an error number */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       return(Yap_unify(ARG2, MkIntTerm(-1))); | 
					
						
							| 
									
										
										
										
											2002-10-10 05:58:49 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     return(Yap_unify(ARG2, MkIntegerTerm(buf.st_mtime))); | 
					
						
							| 
									
										
										
										
											2001-07-05 20:23:21 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   return(Yap_unify(ARG2, MkIntTerm(-1))); | 
					
						
							| 
									
										
										
										
											2001-07-05 20:23:21 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* wrapper for alarm system call */ | 
					
						
							| 
									
										
										
										
											2002-01-17 22:12:09 +00:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-21 20:07:15 +00:00
										 |  |  | static DWORD WINAPI | 
					
						
							|  |  |  | DoTimerThread(LPVOID targ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   Int time = *(Int *)targ; | 
					
						
							|  |  |  |   HANDLE htimer; | 
					
						
							|  |  |  |   LARGE_INTEGER liDueTime; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   htimer = CreateWaitableTimer(NULL,FALSE,NULL); | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   liDueTime.QuadPart =  -10000000; | 
					
						
							|  |  |  |   liDueTime.QuadPart *=  time; | 
					
						
							| 
									
										
										
										
											2002-01-21 20:07:15 +00:00
										 |  |  |   /* Copy the relative time into a LARGE_INTEGER. */ | 
					
						
							|  |  |  |   if (SetWaitableTimer(htimer, &liDueTime,0,NULL,NULL,0) == 0) { | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (WaitForSingleObject(htimer, INFINITE) != WAIT_OBJECT_0) | 
					
						
							|  |  |  |     fprintf(stderr,"WaitForSingleObject failed (%ld)\n", GetLastError()); | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  |   Yap_signal (YAP_ALARM_SIGNAL); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   /* now, say what is going on */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_PutValue(AtomAlarm, MkAtomTerm(AtomTrue)); | 
					
						
							| 
									
										
										
										
											2002-01-21 20:07:15 +00:00
										 |  |  |   ExitThread(1); | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  | #if _MSC_VER
 | 
					
						
							|  |  |  |   return(0L); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2002-01-21 20:07:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_alarm(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   Term t = Deref(ARG1); | 
					
						
							|  |  |  |   if (IsVarTerm(t)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t, "alarm/2"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!IsIntegerTerm(t)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_INTEGER, t, "alarm/2"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     Term tout; | 
					
						
							| 
									
										
										
										
											2002-01-21 20:07:15 +00:00
										 |  |  |     Int time = IntegerOfTerm(t); | 
					
						
							| 
									
										
										
										
											2002-01-17 22:12:09 +00:00
										 |  |  |      | 
					
						
							|  |  |  |     if (time != 0) { | 
					
						
							| 
									
										
										
										
											2002-01-21 20:07:15 +00:00
										 |  |  |       DWORD dwThreadId;  | 
					
						
							|  |  |  |       HANDLE hThread;  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       hThread = CreateThread(  | 
					
						
							|  |  |  | 			     NULL,     /* no security attributes */ | 
					
						
							|  |  |  | 			     0,        /* use default stack size */  | 
					
						
							|  |  |  | 			     DoTimerThread, /* thread function */ | 
					
						
							|  |  |  | 			     (LPVOID)&time,  /* argument to thread function */ | 
					
						
							|  |  |  | 			     0,        /* use default creation flags  */ | 
					
						
							|  |  |  | 			     &dwThreadId);  /* returns the thread identifier */ | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  |       /* Check the return value for success. */ | 
					
						
							|  |  |  |       if (hThread == NULL) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | 	Yap_WinError("trying to use alarm"); | 
					
						
							| 
									
										
										
										
											2002-01-17 22:12:09 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     tout = MkIntegerTerm(0); | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     return(Yap_unify(ARG2,tout)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | #elif HAVE_ALARM
 | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     Int left; | 
					
						
							|  |  |  |     Term tout; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-08-13 09:19:00 +00:00
										 |  |  |     left = alarm(IntegerOfTerm(t)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     tout = MkIntegerTerm(left); | 
					
						
							| 
									
										
										
										
											2004-10-14 22:14:53 +00:00
										 |  |  |     return Yap_unify(ARG2,tout); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-08-18 23:18:18 +00:00
										 |  |  |   /* not actually trying to set the alarm */ | 
					
						
							|  |  |  |   if (IntegerOfTerm(t) == 0) | 
					
						
							| 
									
										
										
										
											2004-10-14 22:14:53 +00:00
										 |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	"alarm not available in this configuration"); | 
					
						
							|  |  |  |   return(FALSE); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_FPU_CONTROL_H
 | 
					
						
							|  |  |  | #include <fpu_control.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* by default Linux with glibc is IEEE compliant anyway..., but we will pretend it is not. */ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | static void | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | set_fpu_exceptions(int flag) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   if (flag) { | 
					
						
							|  |  |  | #if defined(__hpux)
 | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | # if HAVE_FESETTRAPENABLE
 | 
					
						
							|  |  |  | /* From HP-UX 11.0 onwards: */ | 
					
						
							|  |  |  |     fesettrapenable(FE_INVALID|FE_DIVBYZERO|FE_OVERFLOW|FE_UNDERFLOW); | 
					
						
							|  |  |  | # else
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Up until HP-UX 10.20: | 
					
						
							|  |  |  |   FP_X_INV   invalid operation exceptions | 
					
						
							|  |  |  |   FP_X_DZ    divide-by-zero exception | 
					
						
							|  |  |  |   FP_X_OFL   overflow exception | 
					
						
							|  |  |  |   FP_X_UFL   underflow exception | 
					
						
							|  |  |  |   FP_X_IMP   imprecise (inexact result) | 
					
						
							|  |  |  |   FP_X_CLEAR simply zero to clear all flags | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     fpsetmask(FP_X_INV|FP_X_DZ|FP_X_OFL|FP_X_UFL); | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | # endif
 | 
					
						
							|  |  |  | #endif /* __hpux */
 | 
					
						
							| 
									
										
										
										
											2002-02-11 20:22:15 +00:00
										 |  |  | #if HAVE_FPU_CONTROL_H && i386 && defined(__GNUC__)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     /* I shall ignore denormalization and precision errors */ | 
					
						
							|  |  |  |     int v = _FPU_IEEE & ~(_FPU_MASK_IM|_FPU_MASK_ZM|_FPU_MASK_OM|_FPU_MASK_UM); | 
					
						
							|  |  |  |     _FPU_SETCW(v); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_FETESTEXCEPT
 | 
					
						
							|  |  |  |     feclearexcept(FE_ALL_EXCEPT); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |     my_signal (SIGFPE, HandleMatherr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     /* do IEEE arithmetic in the way the big boys do */ | 
					
						
							|  |  |  | #if defined(__hpux)
 | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | # if HAVE_FESETTRAPENABLE
 | 
					
						
							|  |  |  |     fesettrapenable(FE_ALL_EXCEPT); | 
					
						
							|  |  |  | # else
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     fpsetmask(FP_X_CLEAR); | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | # endif
 | 
					
						
							|  |  |  | #endif /* __hpux */
 | 
					
						
							| 
									
										
										
										
											2002-02-11 20:22:15 +00:00
										 |  |  | #if HAVE_FPU_CONTROL_H && i386 && defined(__GNUC__)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     /* this will probably not work in older releases of Linux */ | 
					
						
							|  |  |  |     int v = _FPU_IEEE; | 
					
						
							|  |  |  |    _FPU_SETCW(v); | 
					
						
							|  |  |  | #endif    
 | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |     my_signal (SIGFPE, SIG_IGN); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | void | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_set_fpu_exceptions(int flag) | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   set_fpu_exceptions(flag); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  | static Int | 
					
						
							|  |  |  | p_set_fpu_exceptions(void) { | 
					
						
							|  |  |  |   if (yap_flags[LANGUAGE_MODE_FLAG] == 1) { | 
					
						
							|  |  |  |     set_fpu_exceptions(FALSE); /* can't make it work right */ | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     set_fpu_exceptions(FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   return(TRUE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-02-08 22:19:24 +00:00
										 |  |  | static Int | 
					
						
							|  |  |  | p_host_type(void) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Term out = MkAtomTerm(Yap_LookupAtom(HOST_ALIAS)); | 
					
						
							|  |  |  |   return(Yap_unify(out,ARG1)); | 
					
						
							| 
									
										
										
										
											2002-02-08 22:19:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-13 06:26:13 +00:00
										 |  |  | static Int | 
					
						
							|  |  |  | p_yap_home(void) { | 
					
						
							|  |  |  |   Term out = MkAtomTerm(Yap_LookupAtom(YAP_HOME_DIR)); | 
					
						
							|  |  |  |   return(Yap_unify(out,ARG1)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | static Int | 
					
						
							|  |  |  | p_env_separator(void) { | 
					
						
							|  |  |  | #if defined(_WIN32)
 | 
					
						
							|  |  |  |   return Yap_unify(MkIntegerTerm(';'),ARG1); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   return Yap_unify(MkIntegerTerm(':'),ARG1); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * This is responsable for the initialization of all machine dependant | 
					
						
							|  |  |  |  * predicates | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_InitSysbits (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2002-01-23 02:28:31 +00:00
										 |  |  | #if  __simplescalar__
 | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     char *pwd = getenv("PWD"); | 
					
						
							|  |  |  |     strncpy(yap_pwd,pwd,YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   InitPageSize(); | 
					
						
							|  |  |  |   InitWTime (); | 
					
						
							|  |  |  |   InitRandom (); | 
					
						
							|  |  |  |   /* let the caller control signals as it sees fit */ | 
					
						
							|  |  |  |   InitSignals (); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | void | 
					
						
							|  |  |  | Yap_InitTime(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   InitTime(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | void | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_ReInitWallTime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   InitWTime(); | 
					
						
							| 
									
										
										
										
											2004-12-02 06:06:47 +00:00
										 |  |  |   if (Yap_heap_regs->last_wtime != NULL)  | 
					
						
							|  |  |  |     Yap_FreeCodeSpace(Yap_heap_regs->last_wtime); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   InitLastWtime(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  | static Int | 
					
						
							|  |  |  | p_first_signal(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   LOCK(SignalLock); | 
					
						
							|  |  |  |   /* always do wakeups first, because you don't want to keep the
 | 
					
						
							|  |  |  |      non-backtrackable variable bad */ | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_WAKEUP_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_WAKEUP_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_wake_up"))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_ITI_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_ITI_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_iti"))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_INT_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_INT_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_int"))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_USR2_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_USR2_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_usr2"))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_USR1_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_USR1_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_usr1"))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_HUP_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_HUP_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_hup"))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_ALARM_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_ALARM_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_alarm"))); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2004-12-05 05:01:45 +00:00
										 |  |  |   if (ActiveSignals & YAP_DELAY_CREEP_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~(YAP_CREEP_SIGNAL|YAP_DELAY_CREEP_SIGNAL); | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_delay_creep"))); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  |   if (ActiveSignals & YAP_CREEP_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_CREEP_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_creep"))); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2004-10-08 17:20:03 +00:00
										 |  |  |   if (ActiveSignals & YAP_TRACE_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_TRACE_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_trace"))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_DEBUG_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_DEBUG_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_debug"))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_BREAK_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_BREAK_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_break"))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_STACK_DUMP_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_STACK_DUMP_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_stack_dump"))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_STATISTICS_SIGNAL) { | 
					
						
							|  |  |  |     ActiveSignals &= ~YAP_STATISTICS_SIGNAL; | 
					
						
							|  |  |  |     UNLOCK(SignalLock); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom("sig_statistics"))); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  |   UNLOCK(SignalLock); | 
					
						
							|  |  |  |   return FALSE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_continue_signals(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   /* hack to force the signal anew */ | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_ITI_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_ITI_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_INT_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_INT_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_USR2_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_USR2_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_USR1_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_USR1_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_HUP_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_HUP_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_ALARM_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_ALARM_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_CREEP_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_CREEP_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2004-12-05 05:01:45 +00:00
										 |  |  |   if (ActiveSignals & YAP_DELAY_CREEP_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_DELAY_CREEP_SIGNAL|YAP_CREEP_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2004-10-08 17:20:03 +00:00
										 |  |  |   if (ActiveSignals & YAP_TRACE_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_TRACE_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_DEBUG_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_DEBUG_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_BREAK_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_BREAK_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_STACK_DUMP_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_STACK_DUMP_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (ActiveSignals & YAP_STATISTICS_SIGNAL) { | 
					
						
							|  |  |  |     Yap_signal(YAP_STATISTICS_SIGNAL); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  |   return TRUE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | void | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_InitSysPreds(void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* can only do after heap is initialised */ | 
					
						
							|  |  |  |   InitLastWtime(); | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_InitCPred ("srandom", 1, p_srandom, SafePredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred ("sh", 0, p_sh, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |   Yap_InitCPred ("$shell", 1, p_shell, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   Yap_InitCPred ("system", 1, p_system, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred ("rename", 2, p_mv, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  |   Yap_InitCPred ("cd", 1, p_cd, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							| 
									
										
										
										
											2005-03-13 06:26:13 +00:00
										 |  |  |   Yap_InitCPred ("$yap_home", 1, p_yap_home, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |   Yap_InitCPred ("getcwd", 1, p_getcwd, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |   Yap_InitCPred ("$dir_separator", 1, p_dir_sp, SafePredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred ("$alarm", 2, p_alarm, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred ("$getenv", 2, p_getenv, SafePredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred ("$putenv", 2, p_putenv, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred ("$file_age", 2, p_file_age, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred ("$set_fpu_exceptions", 0, p_set_fpu_exceptions, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred ("$first_signal", 1, p_first_signal, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred ("$host_type", 1, p_host_type, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred ("$continue_signals", 0, p_continue_signals, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							| 
									
										
										
										
											2005-10-19 01:47:43 +00:00
										 |  |  |   Yap_InitCPred ("file_directory_name", 2, p_file_directory_name, SafePredFlag); | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  |   Yap_InitCPred ("$env_separator", 1, p_env_separator, SafePredFlag); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef VAX
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* avoid longjmp botch */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int vax_absmi_fp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     int eh; | 
					
						
							|  |  |  |     int flgs; | 
					
						
							|  |  |  |     int ap; | 
					
						
							|  |  |  |     int fp; | 
					
						
							|  |  |  |     int pc; | 
					
						
							|  |  |  |     int dummy1; | 
					
						
							|  |  |  |     int dummy2; | 
					
						
							|  |  |  |     int dummy3; | 
					
						
							|  |  |  |     int oldfp; | 
					
						
							|  |  |  |     int dummy4; | 
					
						
							|  |  |  |     int dummy5; | 
					
						
							|  |  |  |     int dummy6; | 
					
						
							|  |  |  |     int oldpc; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  *VaxFramePtr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | VaxFixFrame (dummy) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   int maxframes = 100; | 
					
						
							|  |  |  |   VaxFramePtr fp = (VaxFramePtr) (((int *) &dummy) - 6); | 
					
						
							|  |  |  |   while (--maxframes) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       fp = (VaxFramePtr) fp->fp; | 
					
						
							|  |  |  |       if (fp->flgs == 0) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  if (fp->oldfp >= ®S[6] && fp->oldfp < ®S[REG_SIZE]) | 
					
						
							|  |  |  | 	    fp->oldfp = vax_absmi_fp; | 
					
						
							|  |  |  | 	  return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #if defined(_WIN32)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-02-22 06:12:18 +00:00
										 |  |  | #include <windows.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | int WINAPI STD_PROTO(win_yap, (HANDLE, DWORD, LPVOID)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int WINAPI win_yap(HANDLE hinst, DWORD reason, LPVOID reserved) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   switch (reason)  | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     case DLL_PROCESS_ATTACH: | 
					
						
							|  |  |  |       break; | 
					
						
							|  |  |  |     case DLL_PROCESS_DETACH: | 
					
						
							|  |  |  |       break; | 
					
						
							|  |  |  |     case DLL_THREAD_ATTACH: | 
					
						
							|  |  |  |       break; | 
					
						
							|  |  |  |     case DLL_THREAD_DETACH: | 
					
						
							|  |  |  |       break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-02-08 22:19:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-02-12 17:09:17 +00:00
										 |  |  | #if (defined(YAPOR) || defined(THREADS)) && !defined(USE_PTHREAD_LOCKING)
 | 
					
						
							| 
									
										
										
										
											2002-10-21 22:14:29 +00:00
										 |  |  | #ifdef sparc
 | 
					
						
							|  |  |  | void STD_PROTO(rw_lock_voodoo,(void)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							|  |  |  | rw_lock_voodoo(void) { | 
					
						
							|  |  |  |   /* code taken from the Linux kernel, it handles shifting between locks */ | 
					
						
							|  |  |  |   /* Read/writer locks, as usual this is overly clever to make it as fast as possible. */ | 
					
						
							|  |  |  | 	/* caches... */ | 
					
						
							|  |  |  | 	__asm__ __volatile__( | 
					
						
							|  |  |  | "___rw_read_enter_spin_on_wlock:\n" | 
					
						
							|  |  |  | "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | "	be,a	___rw_read_enter\n" | 
					
						
							|  |  |  | "	 ldstub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | "	b	___rw_read_enter_spin_on_wlock\n" | 
					
						
							|  |  |  | "	 ldub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | "___rw_read_exit_spin_on_wlock:\n" | 
					
						
							|  |  |  | "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | "	be,a	___rw_read_exit\n" | 
					
						
							|  |  |  | "	 ldstub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | "	b	___rw_read_exit_spin_on_wlock\n" | 
					
						
							|  |  |  | "	 ldub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | "___rw_write_enter_spin_on_wlock:\n" | 
					
						
							|  |  |  | "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | "	be,a	___rw_write_enter\n" | 
					
						
							|  |  |  | "	 ldstub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | "	b	___rw_write_enter_spin_on_wlock\n" | 
					
						
							|  |  |  | "	 ld	[%g1], %g2\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "	.globl	___rw_read_enter\n" | 
					
						
							|  |  |  | "___rw_read_enter:\n" | 
					
						
							|  |  |  | "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | "	bne,a	___rw_read_enter_spin_on_wlock\n" | 
					
						
							|  |  |  | "	 ldub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | "	ld	[%g1], %g2\n" | 
					
						
							|  |  |  | "	add	%g2, 1, %g2\n" | 
					
						
							|  |  |  | "	st	%g2, [%g1]\n" | 
					
						
							|  |  |  | "	retl\n" | 
					
						
							|  |  |  | "	 mov	%g4, %o7\n" | 
					
						
							|  |  |  | "	.globl	___rw_read_exit\n" | 
					
						
							|  |  |  | "___rw_read_exit:\n" | 
					
						
							|  |  |  | "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | "	bne,a	___rw_read_exit_spin_on_wlock\n" | 
					
						
							|  |  |  | "	 ldub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | "	ld	[%g1], %g2\n" | 
					
						
							|  |  |  | "	sub	%g2, 0x1ff, %g2\n" | 
					
						
							|  |  |  | "	st	%g2, [%g1]\n" | 
					
						
							|  |  |  | "	retl\n" | 
					
						
							|  |  |  | "	 mov	%g4, %o7\n" | 
					
						
							|  |  |  | "	.globl	___rw_write_enter\n" | 
					
						
							|  |  |  | "___rw_write_enter:\n" | 
					
						
							|  |  |  | "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | "	bne	___rw_write_enter_spin_on_wlock\n" | 
					
						
							|  |  |  | "	 ld	[%g1], %g2\n" | 
					
						
							|  |  |  | "	andncc	%g2, 0xff, %g0\n" | 
					
						
							|  |  |  | "	bne,a	___rw_write_enter_spin_on_wlock\n" | 
					
						
							|  |  |  | "	 stb	%g0, [%g1 + 3]\n" | 
					
						
							|  |  |  | "	retl\n" | 
					
						
							|  |  |  | "	 mov	%g4, %o7\n" | 
					
						
							|  |  |  |    ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif /* sparc */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef i386
 | 
					
						
							|  |  |  | asm( | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ".align	4\n" | 
					
						
							|  |  |  | ".globl	__write_lock_failed\n" | 
					
						
							|  |  |  | "__write_lock_failed:\n" | 
					
						
							|  |  |  | "	lock;   addl	$" RW_LOCK_BIAS_STR ",(%eax)\n" | 
					
						
							|  |  |  | "1:	cmpl	$" RW_LOCK_BIAS_STR ",(%eax)\n" | 
					
						
							|  |  |  | "	jne	1b\n" | 
					
						
							|  |  |  | "	lock;   subl	$" RW_LOCK_BIAS_STR ",(%eax)\n" | 
					
						
							|  |  |  | "	jnz	__write_lock_failed\n" | 
					
						
							|  |  |  | "	ret\n" | 
					
						
							|  |  |  | ".align	4\n" | 
					
						
							|  |  |  | ".globl	__read_lock_failed\n" | 
					
						
							|  |  |  | "__read_lock_failed:\n" | 
					
						
							|  |  |  | "	lock ; incl	(%eax)\n" | 
					
						
							|  |  |  | "1:	cmpl	$1,(%eax)\n" | 
					
						
							|  |  |  | "	js	1b\n" | 
					
						
							|  |  |  | "	lock ; decl	(%eax)\n" | 
					
						
							|  |  |  | "	js	__read_lock_failed\n" | 
					
						
							|  |  |  | "	ret\n" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | #endif /* i386 */
 | 
					
						
							|  |  |  | #endif /* YAPOR || THREADS */
 |