| 
									
										
										
										
											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:		absmi.c							 * | 
					
						
							|  |  |  | * Last rev:								 * | 
					
						
							|  |  |  | * mods:									 * | 
					
						
							|  |  |  | * comments:	Portable abstract machine interpreter includes           * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef SCCS
 | 
					
						
							|  |  |  | static char SccsId[] = "%W% %G%"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* SCCS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-07 23:55:16 +01:00
										 |  |  | #if NATIVE_EXECUTION
 | 
					
						
							|  |  |  | /* just a stub */ | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define	  EXEC_NATIVE(X)
 | 
					
						
							|  |  |  | #define	  MAX_INVOCATION 1024
 | 
					
						
							|  |  |  | #define	  Yapc_Compile(P) 0
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * Macros for register manipulation                             * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Machine and compiler dependent definitions | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #ifdef __GNUC__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef hppa
 | 
					
						
							|  |  |  | #define SHADOW_P       1
 | 
					
						
							|  |  |  | #define SHADOW_Y       1
 | 
					
						
							|  |  |  | #define SHADOW_REGS    1
 | 
					
						
							|  |  |  | #define USE_PREFETCH   1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __alpha
 | 
					
						
							|  |  |  | #define SHADOW_P       1
 | 
					
						
							|  |  |  | #define SHADOW_Y       1
 | 
					
						
							|  |  |  | #define SHADOW_REGS    1
 | 
					
						
							|  |  |  | #define USE_PREFETCH   1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef mips
 | 
					
						
							|  |  |  | #define SHADOW_P       1
 | 
					
						
							|  |  |  | #define SHADOW_Y       1
 | 
					
						
							|  |  |  | #define SHADOW_REGS    1
 | 
					
						
							|  |  |  | #define USE_PREFETCH   1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-23 00:20:14 +00:00
										 |  |  | #if defined(_POWER) || defined(__POWERPC__)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define SHADOW_P       1
 | 
					
						
							|  |  |  | #define SHADOW_REGS    1
 | 
					
						
							|  |  |  | #define USE_PREFETCH   1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef i386
 | 
					
						
							|  |  |  | #define      Y_IN_MEM  1
 | 
					
						
							|  |  |  | #define      S_IN_MEM  1
 | 
					
						
							|  |  |  | #define     TR_IN_MEM  1
 | 
					
						
							|  |  |  | #define HAVE_FEW_REGS  1
 | 
					
						
							|  |  |  | #define LIMITED_PREFETCH   1
 | 
					
						
							|  |  |  | #ifdef BP_FREE
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * Use bp as PREG for X86 machines		               * | 
					
						
							| 
									
										
										
										
											2014-02-10 23:31:33 +00:00
										 |  |  | ********************************************Term*******************/ | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #if defined(IN_ABSMI_C)
 | 
					
						
							| 
									
										
										
										
											2004-10-28 20:12:23 +00:00
										 |  |  | register struct yami* P1REG asm ("bp"); /* can't use yamop before Yap.h */ | 
					
						
							|  |  |  | #define PREG P1REG
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #define NEEDS_TO_SET_PC 1
 | 
					
						
							|  |  |  | #endif /* BP_FREE */
 | 
					
						
							|  |  |  | #endif /* i386 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-16 12:12:23 +01:00
										 |  |  | #ifdef sparc
 | 
					
						
							|  |  |  | #define SHADOW_P       1
 | 
					
						
							|  |  |  | #ifdef BP_FREE
 | 
					
						
							|  |  |  | #undef BP_FREE
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #define S_IN_MEM       1
 | 
					
						
							|  |  |  | #define      Y_IN_MEM  1
 | 
					
						
							|  |  |  | #define     TR_IN_MEM  1
 | 
					
						
							|  |  |  | #endif /* sparc_ */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-27 16:31:20 +00:00
										 |  |  | #if defined(__arm__) || defined(__thumb__)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define Y_IN_MEM       1
 | 
					
						
							|  |  |  | #define S_IN_MEM       1
 | 
					
						
							|  |  |  | #define TR_IN_MEM      1
 | 
					
						
							|  |  |  | #define HAVE_FEW_REGS  1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 13:28:57 +00:00
										 |  |  | #ifdef __x86_64__
 | 
					
						
							|  |  |  | #define SHADOW_P       1
 | 
					
						
							| 
									
										
										
										
											2010-01-27 11:00:25 +00:00
										 |  |  | #ifdef BP_FREE
 | 
					
						
							|  |  |  | #undef BP_FREE
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2006-02-01 13:28:57 +00:00
										 |  |  | #define SHADOW_S       1
 | 
					
						
							| 
									
										
										
										
											2010-01-27 11:00:25 +00:00
										 |  |  | //#define SHADOW_Y       1
 | 
					
						
							| 
									
										
										
										
											2007-10-28 00:54:09 +00:00
										 |  |  | #define S_IN_MEM       1
 | 
					
						
							| 
									
										
										
										
											2006-02-01 13:28:57 +00:00
										 |  |  | #define      Y_IN_MEM  1
 | 
					
						
							|  |  |  | #define     TR_IN_MEM  1
 | 
					
						
							| 
									
										
										
										
											2011-10-02 19:55:22 -03:00
										 |  |  | #define LIMITED_PREFETCH   1
 | 
					
						
							| 
									
										
										
										
											2006-02-01 13:28:57 +00:00
										 |  |  | #endif /* __x86_64__ */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else /* other compilers */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define S_IN_MEM       1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This works for xlc under AIX 3.2.5 */ | 
					
						
							|  |  |  | #ifdef _IBMR2
 | 
					
						
							|  |  |  | #define SHADOW_P       1
 | 
					
						
							|  |  |  | #define SHADOW_REGS    1
 | 
					
						
							|  |  |  | #define SHADOW_S       1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef i386
 | 
					
						
							|  |  |  | #define Y_IN_MEM       1
 | 
					
						
							|  |  |  | #define S_IN_MEM       1
 | 
					
						
							|  |  |  | #define TR_IN_MEM      1
 | 
					
						
							|  |  |  | #define HAVE_FEW_REGS  1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef mips
 | 
					
						
							|  |  |  | #define SHADOW_P       1
 | 
					
						
							|  |  |  | #define SHADOW_Y       1
 | 
					
						
							|  |  |  | #define SHADOW_S       1
 | 
					
						
							|  |  |  | #define SHADOW_CP      1
 | 
					
						
							|  |  |  | #define SHADOW_HB      1
 | 
					
						
							|  |  |  | #define USE_PREFETCH   1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef _HPUX_SOURCE
 | 
					
						
							|  |  |  | #define SHADOW_P       1
 | 
					
						
							|  |  |  | #define SHADOW_Y       1
 | 
					
						
							|  |  |  | #define SHADOW_S       1
 | 
					
						
							|  |  |  | #define SHADOW_CP      1
 | 
					
						
							|  |  |  | #define SHADOW_HB      1
 | 
					
						
							|  |  |  | #define USE_PREFETCH   1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* __GNUC__ */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "Yap.h"
 | 
					
						
							|  |  |  | #include "clause.h"
 | 
					
						
							|  |  |  | #include "eval.h"
 | 
					
						
							|  |  |  | #ifdef HAVE_STRING_H
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef YAPOR
 | 
					
						
							|  |  |  | #include "or.macros.h"
 | 
					
						
							|  |  |  | #endif	/* YAPOR */
 | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef USE_SYSTEM_MALLOC
 | 
					
						
							| 
									
										
										
										
											2009-10-23 14:22:17 +01:00
										 |  |  | #include "YapHeap.h"
 | 
					
						
							| 
									
										
										
										
											2004-02-05 16:57:02 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef TABLING
 | 
					
						
							|  |  |  | #include "tab.macros.h"
 | 
					
						
							|  |  |  | #endif /* TABLING */
 | 
					
						
							|  |  |  | #ifdef LOW_LEVEL_TRACER
 | 
					
						
							|  |  |  | #include "tracer.h"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-11-15 01:10:25 +00:00
										 |  |  | #include "pl-shared.h"
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef DEBUG
 | 
					
						
							|  |  |  | /**********************************************************************
 | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  *                 Debugging Auxiliary variables                      * | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  **********************************************************************/ | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if PUSH_REGS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * Trick to copy REGS into absmi local environment              * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* regp is a global variable */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-30 20:42:14 +02:00
										 |  |  | INLINE_ONLY inline EXTERN void | 
					
						
							|  |  |  | init_absmi_regs(REGSTORE * absmi_regs); | 
					
						
							| 
									
										
										
										
											2012-06-29 22:44:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-30 20:42:14 +02:00
										 |  |  | INLINE_ONLY inline EXTERN void | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | init_absmi_regs(REGSTORE * absmi_regs) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   memcpy(absmi_regs, Yap_regp, sizeof(REGSTORE)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-30 20:42:14 +02:00
										 |  |  | INLINE_ONLY inline EXTERN void | 
					
						
							|  |  |  | restore_absmi_regs(REGSTORE * old_regs); | 
					
						
							| 
									
										
										
										
											2012-06-29 22:44:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-30 20:42:14 +02:00
										 |  |  | INLINE_ONLY inline EXTERN void | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | restore_absmi_regs(REGSTORE * old_regs) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   memcpy(old_regs, Yap_regp, sizeof(REGSTORE)); | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  | #ifdef THREADS
 | 
					
						
							| 
									
										
										
										
											2004-02-06 17:22:24 +00:00
										 |  |  |   pthread_setspecific(Yap_yaamregs_key, (void *)old_regs); | 
					
						
							| 
									
										
										
										
											2011-05-09 19:55:06 +01:00
										 |  |  |   LOCAL_ThreadHandle.current_yaam_regs = old_regs; | 
					
						
							| 
									
										
										
										
											2013-11-15 01:10:25 +00:00
										 |  |  |   LOCAL_PL_local_data_p->reg_cache = old_regs; | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_regp = old_regs; | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | #endif /* PUSH_REGS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*****************************************************************
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Machine Dependent stuff  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ******************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef LONG_LIVED_REGISTERS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define BEGP(TMP)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ENDP(TMP)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define BEGD(TMP)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ENDD(TMP)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define BEGP(TMP) { register CELL *TMP
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ENDP(TMP) }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define BEGD(TMP) { register CELL TMP
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ENDD(TMP) }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* LONG_LIVED_REGISTERS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define BEGCHO(TMP) { register choiceptr TMP
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ENDCHO(TMP) }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | * YREG is usually, but not always, a register. This affects       * | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | * choicepoints                                                 * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if Y_IN_MEM
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #define CACHE_Y(A) { register CELL *S_YREG = ((CELL *)(A))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #define ENDCACHE_Y() YREG = S_YREG; }
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #define B_YREG   ((choiceptr)(S_YREG))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #define S_YREG   (YREG)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #define B_YREG ((choiceptr)(YREG))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #define CACHE_Y(A) { YREG = ((CELL *)(A))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define ENDCACHE_Y() }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if Y_IN_MEM
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #define CACHE_Y_AS_ENV(A) { register CELL *ENV_YREG = (A)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-13 23:35:37 -05:00
										 |  |  | #define FETCH_Y_FROM_ENV(A) ENV_YREG = (A)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #define WRITEBACK_Y_AS_ENV()   YREG = ENV_YREG
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define ENDCACHE_Y_AS_ENV() }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #define saveregs_and_ycache() YREG = ENV_YREG; saveregs()
 | 
					
						
							| 
									
										
										
										
											2003-10-28 01:16:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #define setregs_and_ycache() ENV_YREG = YREG; setregs()
 | 
					
						
							| 
									
										
										
										
											2003-10-28 01:16:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #define ENV_YREG (YREG)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define WRITEBACK_Y_AS_ENV()   
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #define CACHE_Y_AS_ENV(A) { YREG = (A)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-13 23:35:37 -05:00
										 |  |  | #define FETCH_Y_FROM_ENV(A) (A)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define ENDCACHE_Y_AS_ENV() }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-10-28 01:16:03 +00:00
										 |  |  | #define saveregs_and_ycache() saveregs()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define setregs_and_ycache() setregs()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if S_IN_MEM
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CACHE_A1()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CACHED_A1()	ARG1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CACHE_A1()	(SREG = (CELL *)ARG1)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CACHED_A1()	((CELL)SREG)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* S_IN_MEM */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * TR is usually, but not always, a register. This affects      * | 
					
						
							|  |  |  | * backtracking                                                 * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CACHE_TR(A) { register tr_fr_ptr S_TR = (A)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define RESTORE_TR()    TR = S_TR
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ENDCACHE_TR() }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * S is usually, but not always, a register (X86 machines).     * | 
					
						
							|  |  |  | * This affects unification instructions                        * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if S_IN_MEM
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* jump through hoops because idiotic gcc will go and read S from
 | 
					
						
							|  |  |  |    memory every time it uses S :-( */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CACHE_S() { register CELL * S_SREG;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ENDCACHE_S() }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define READ_IN_S() S_SREG = SREG
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* do nothing if you are on a decent machine */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CACHE_S() {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ENDCACHE_S() }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define READ_IN_S()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define S_SREG  SREG
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define WRITEBACK_S(X) SREG = (X)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*****************************************************************
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    End of Machine Dependent stuff  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ******************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*****************************************************************
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Prefetch is a technique to obtain the place to jump to before actually | 
					
						
							|  |  |  |    executing instructions. It can speed up some machines, by having the | 
					
						
							|  |  |  |    next opcode in place before it is actually required for jumping. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ******************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if USE_THREADED_CODE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define DO_PREFETCH(TYPE) to_go = (void *)(NEXTOP(PREG,TYPE)->opc)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-30 01:06:09 +01:00
										 |  |  | #define DO_PREFETCH_W(TYPE) to_go = (void *)(NEXTOP(PREG,TYPE)->y_u.o.opcw)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-02 19:55:22 -03:00
										 |  |  | #if LIMITED_PREFETCH||USE_PREFETCH
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_START_PREFETCH(TYPE) \
 | 
					
						
							|  |  |  |  { register void *to_go; DO_PREFETCH(TYPE) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_LOOKAHEAD(WHAT) \
 | 
					
						
							|  |  |  |  { register void *to_go = (void *)(WHAT) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_START_PREFETCH_W(TYPE) \
 | 
					
						
							|  |  |  |  { register void *to_go; DO_PREFETCH_W(TYPE) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_START_PREFETCH(TYPE) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_START_PREFETCH_W(TYPE) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_LOOKAHEAD(WHERE) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef USE_PREFETCH
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define START_PREFETCH(TYPE) ALWAYS_START_PREFETCH(TYPE)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define START_PREFETCH_W(TYPE) ALWAYS_START_PREFETCH_W(TYPE)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define INIT_PREFETCH() \
 | 
					
						
							|  |  |  |      { register void *to_go; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PREFETCH_OP(X) \
 | 
					
						
							|  |  |  |      to_go = (void *)((X)->opc); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define START_PREFETCH(TYPE) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define START_PREFETCH_W(TYPE) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define INIT_PREFETCH() {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PREFETCH_OP(X)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif	/* USE_PREFETCH */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else /* USE_THREADED_CODE */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_START_PREFETCH(TYPE) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_START_PREFETCH_W(TYPE) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_LOOKAHEAD(WHERE) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define START_PREFETCH(TYPE) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define START_PREFETCH_W(TYPE) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define INIT_PREFETCH() {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PREFETCH_OP(X)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* USE_THREADED_CODE */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_END_PREFETCH() }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_END_PREFETCH_W() }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define END_PREFETCH() }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define END_PREFETCH_W() }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*****************************************************************
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   How to jump to the next abstract machine instruction | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ******************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if USE_THREADED_CODE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define JMP(Lab)  goto *Lab 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define JMPNext()						\
 | 
					
						
							|  |  |  | 	JMP((void *)(PREG->opc)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define JMPNextW()						\
 | 
					
						
							| 
									
										
										
										
											2014-05-30 01:06:09 +01:00
										 |  |  | 	JMP((void *)(PREG->y_u.o.opcw)) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-02 19:55:22 -03:00
										 |  |  | #if USE_THREADED_CODE && (LIMITED_PREFETCH || USE_PREFETCH)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_GONext() JMP(to_go)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_GONextW() JMP(to_go)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_GONext() JMPNext()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_GONextW() JMPNextW()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef USE_PREFETCH
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define GONext() ALWAYS_GONext() 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GONextW() ALWAYS_GONextW() 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GONext() JMPNext()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GONextW() JMPNextW()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* USE_PREFETCH */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define Op(Label,Type)	 Label:{ START_PREFETCH(Type)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define OpW(Label,Type)	 Label: { START_PREFETCH_W(Type)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define BOp(Label,Type)	 Label: {
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define PBOp(Label,Type) Label: { INIT_PREFETCH()
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define OpRW(Label,Type) Label: {
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #else /* do not use threaded code */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define JMPNext()	goto nextop
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define JMPNextW()	goto nextop_write
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GONext()	JMPNext()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GONextW()	JMPNextW()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_GONext() GONext()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ALWAYS_GONextW() GONextW()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define Op(Label,Type)	 case _##Label: { START_PREFETCH(Type)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define OpW(Label,Type)	 case  _##Label: { START_PREFETCH_W(Type)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define BOp(Label,Type)	 case _##Label: {
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define PBOp(Label,Type) case _##Label: { INIT_PREFETCH()
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define OpRW(Label,Type) case _##Label: {
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define ENDOp() END_PREFETCH() }
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define ENDOpW() END_PREFETCH_W() }
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define ENDOpRW() }
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define ENDBOp() }
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-17 14:10:42 +00:00
										 |  |  | #define ENDPBOp() END_PREFETCH() }
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**********************************************************************
 | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  *                           PC manipulation                          * | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  **********************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * How to set up and move a PC in a nice and disciplined way | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef CELL label; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* move PC */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ADJ(P,x)    (P)+ADJUST(sizeof(x))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Lookup PredEntry Structure | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define pred_entry(X)		((PredEntry *)(Unsigned(X)-(CELL)(&(((PredEntry *)NULL)->StateOfPred))))
 | 
					
						
							|  |  |  | #define pred_entry_from_code(X)		((PredEntry *)(Unsigned(X)-(CELL)(&(((PredEntry *)NULL)->CodeOfPred))))
 | 
					
						
							|  |  |  | #define PredFromDefCode(X)	((PredEntry *)(Unsigned(X)-(CELL)(&(((PredEntry *)NULL)->OpcodeOfPred))))
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | #define PredFromExpandCode(X)	((PredEntry *)(Unsigned(X)-(CELL)(&(((PredEntry *)NULL)->cs.p_code.ExpandCode))))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define PredCode(X)		pred_entry(X)->CodeOfPred
 | 
					
						
							|  |  |  | #define PredOpCode(X)		pred_entry(X)->OpcodeOfPred
 | 
					
						
							|  |  |  | #define TruePredCode(X)		pred_entry(X)->TrueCodeOfPred
 | 
					
						
							|  |  |  | #define PredFunctor(X)		pred_entry(X)->FunctorOfPred
 | 
					
						
							|  |  |  | #define PredArity(X)		pred_entry(X)->ArityOfPE
 | 
					
						
							|  |  |  | #define Module(X)		pred_entry(X)->ModuleOfPred
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define FlagOff(Mask,w) !(Mask&w)
 | 
					
						
							|  |  |  | #define FlagOn(Mask,w) (Mask&w)
 | 
					
						
							|  |  |  | #define ResetFlag(Mask,w) w &= ~Mask
 | 
					
						
							|  |  |  | #define SetFlag(Mask,w) w |= Mask
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**********************************************************************
 | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  *                         X register access                          * | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  **********************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if PRECOMPUTE_REGADDRESS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define XREG(I)		(*(CELL *)(I))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define XREG(I)		XREGS[I]
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-23 02:23:51 +00:00
										 |  |  | #endif /* PRECOMPUTE_REGADDRESS */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-23 00:20:14 +00:00
										 |  |  | /* The Unification Stack is the Auxiliary stack */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define SP0 ((CELL *)AuxTop)
 | 
					
						
							|  |  |  | #define SP  AuxSp
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**********************************************************************
 | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  *                         RWREG Manipulatio                          * | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  **********************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define READ_MODE     1
 | 
					
						
							|  |  |  | #define WRITE_MODE    0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**********************************************************************
 | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  *Setting Temporary Copies of Often Used WAM registers for efficiency * | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  **********************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef SHADOW_P
 | 
					
						
							|  |  |  | #define NEEDS_TO_SET_PC 1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 
 | 
					
						
							|  |  |  |  * First, the PC | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #ifdef NEEDS_TO_SET_PC
 | 
					
						
							|  |  |  | #define set_pc()	PREG = P
 | 
					
						
							|  |  |  | #define save_pc()	P = PREG
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define set_pc()
 | 
					
						
							|  |  |  | #define save_pc()
 | 
					
						
							|  |  |  | #define PREG            (P)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 
 | 
					
						
							|  |  |  |  * Next, Y | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef SHADOW_Y
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #define set_y()		YREG = YENV
 | 
					
						
							|  |  |  | #define save_y()	YENV = YREG
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define set_y()
 | 
					
						
							|  |  |  | #define save_y()
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #define YREG            YENV
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 
 | 
					
						
							|  |  |  |  * Next, CP | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef SHADOW_CP
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define set_cp()	CPREG = CP
 | 
					
						
							|  |  |  | #define save_cp()	CP = CPREG
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define set_cp()
 | 
					
						
							|  |  |  | #define save_cp()
 | 
					
						
							|  |  |  | #define CPREG           CP
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Say which registers must be saved at register entry and register
 | 
					
						
							|  |  |  |  * exit */ | 
					
						
							|  |  |  | #define setregs()                     \
 | 
					
						
							|  |  |  | 	set_hb();                     \ | 
					
						
							|  |  |  | 	set_cp();                     \ | 
					
						
							|  |  |  | 	set_pc();                     \ | 
					
						
							|  |  |  |         set_y() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-28 00:54:09 +00:00
										 |  |  | #define saveregs()                    \
 | 
					
						
							|  |  |  | 	save_hb();                    \ | 
					
						
							|  |  |  | 	save_cp();                    \ | 
					
						
							|  |  |  | 	save_pc();                    \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |         save_y() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-30 16:47:22 +00:00
										 |  |  | #if BP_FREE
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* if we are using BP as a local register, we must save it whenever we leave absmi.c */ | 
					
						
							|  |  |  | #define always_save_pc()          save_pc()
 | 
					
						
							|  |  |  | #define always_set_pc()           set_pc()
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define always_save_pc()
 | 
					
						
							|  |  |  | #define always_set_pc()
 | 
					
						
							|  |  |  | #endif /* BP_FREE */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /************************************************************
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Macros to check the limits of stacks | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | *************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_SIGSEGV
 | 
					
						
							|  |  |  | /* for the moment I don't know how to handle trail overflows
 | 
					
						
							|  |  |  |    in a pure Windows environment  | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #if !defined(_MSC_VER) && !defined(__MINGW32__) && !defined(THREADS) && !defined(YAPOR) && !defined(USE_SYSTEM_MALLOC) && !USE_DL_MALLOC
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define OS_HANDLES_TR_OVERFLOW 1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef OS_HANDLES_TR_OVERFLOW
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | #define check_trail(x)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-17 09:18:27 +00:00
										 |  |  | #define check_trail_in_indexing(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-02 21:01:14 -03:00
										 |  |  | #define check_trail(x) if (__builtin_expect((Unsigned(CurrentTrailTop) < Unsigned(x)),0)) \
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 			goto notrailleft | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-02 21:01:14 -03:00
										 |  |  | #define check_trail_in_indexing(x) if (__builtin_expect((Unsigned(CurrentTrailTop) < Unsigned(x)),0)) \
 | 
					
						
							| 
									
										
										
										
											2007-10-17 09:18:27 +00:00
										 |  |  | 			goto notrailleft_from_index | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-30 15:32:59 +01:00
										 |  |  | #if (defined(YAPOR_SBA) && defined(YAPOR)) || defined(TABLING)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define check_stack(Label, GLOB)                             \
 | 
					
						
							| 
									
										
										
										
											2011-10-02 21:01:14 -03:00
										 |  |  |   if (__builtin_expect( ((Int)(Unsigned(YOUNGEST_CP((choiceptr)ENV_YREG,B_FZ)) - Unsigned(YOUNGEST_H(H_FZ,GLOB))) < CreepFlag), 0)  ) goto Label | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define check_stack(Label, GLOB)                             \
 | 
					
						
							| 
									
										
										
										
											2011-10-02 21:01:14 -03:00
										 |  |  |   if  (__builtin_expect(((Int)(Unsigned(ENV_YREG) - Unsigned(GLOB)) < CreepFlag ), 0) ) goto Label | 
					
						
							| 
									
										
										
										
											2011-03-30 15:32:59 +01:00
										 |  |  | #endif /* YAPOR_SBA && YAPOR */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * Macros for choice point manipulation                         * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * Store variable number of arguments in a choice point         * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | /***
 | 
					
						
							|  |  |  |    pt1 points at the new choice point, | 
					
						
							|  |  |  |    pt0 points at XREGS[i] | 
					
						
							|  |  |  |    d0 is a counter | 
					
						
							|  |  |  |    The macro just pushes the arguments one by one to the local stack. | 
					
						
							|  |  |  | ***/ | 
					
						
							|  |  |  | #define store_args(arity)                                         \
 | 
					
						
							|  |  |  |                  BEGP(pt0);                                       \ | 
					
						
							|  |  |  | 		 pt0 = XREGS+(arity);                             \ | 
					
						
							|  |  |  | 		 while ( pt0 > XREGS )                            \ | 
					
						
							|  |  |  |                    { register CELL x = pt0[0];                    \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                      S_YREG = S_YREG-1;			          \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                      --pt0;                                       \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                      (S_YREG)[0] = x;	                          \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 		   }                                              \ | 
					
						
							|  |  |  |                  ENDP(pt0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define store_at_least_one_arg(arity)                             \
 | 
					
						
							|  |  |  |                  BEGP(pt0);                                       \ | 
					
						
							|  |  |  | 		 pt0 = XREGS+(arity);                             \ | 
					
						
							| 
									
										
										
										
											2011-10-02 19:55:22 -03:00
										 |  |  |                  do { CELL x = pt0[0];                   \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                      S_YREG = (S_YREG)-1;			          \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                      --pt0;                                       \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                      (S_YREG)[0] = x;	                          \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 		   }                                              \ | 
					
						
							|  |  |  | 		 while ( pt0 > XREGS );                           \ | 
					
						
							|  |  |  |                  ENDP(pt0) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-02 16:18:09 -03:00
										 |  |  | #if LOW_LEVEL_TRACER && 0
 | 
					
						
							| 
									
										
										
										
											2011-05-04 10:11:41 +01:00
										 |  |  | #define COUNT_CPS() LOCAL_total_choicepoints++
 | 
					
						
							| 
									
										
										
										
											2011-02-08 21:02:10 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define COUNT_CPS()
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * Do the bulk of work in creating a choice-point               * | 
					
						
							|  |  |  | * AP: alternative pointer                                      * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * The macro just sets pt1 to point to the base of the choicepoint | 
					
						
							|  |  |  |  * and then fills in all the necessary fields | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #ifdef DEPTH_LIMIT
 | 
					
						
							|  |  |  | #define store_yaam_reg_cpdepth(CPTR) (CPTR)->cp_depth = DEPTH
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define store_yaam_reg_cpdepth(CPTR)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define store_yaam_regs(AP,I) \
 | 
					
						
							| 
									
										
										
										
											2009-03-03 10:04:13 +00:00
										 |  |  |                  { /* Jump to CP_BASE */                         \ | 
					
						
							| 
									
										
										
										
											2011-02-08 21:02:10 +00:00
										 |  |  | 		   COUNT_CPS();					       \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                    S_YREG = (CELL *)((choiceptr)((S_YREG)-(I))-1);     \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                    /* Save Information */                        \ | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  | 		   HBREG = HR;                                    \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                    B_YREG->cp_tr = TR;				 \ | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  |                    B_YREG->cp_h  = HR;				 \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                    B_YREG->cp_b  = B;				 \ | 
					
						
							| 
									
										
										
										
											2009-03-03 10:04:13 +00:00
										 |  |  |                    store_yaam_reg_cpdepth(B_YREG);               \ | 
					
						
							|  |  |  |                    B_YREG->cp_cp = CPREG;			 \ | 
					
						
							|  |  |  |                    B_YREG->cp_ap = AP;				 \ | 
					
						
							|  |  |  |                    B_YREG->cp_env= ENV;				 \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define store_yaam_regs_for_either(AP,d0) \
 | 
					
						
							| 
									
										
										
										
											2011-02-08 21:02:10 +00:00
										 |  |  |                 COUNT_CPS();					 \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                  pt1 --; /* Jump to CP_BASE */		         \ | 
					
						
							|  |  |  |                  /* Save Information */                          \ | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  | 		 HBREG = HR;                                      \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                  pt1->cp_tr = TR;	                         \ | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  |                  pt1->cp_h = HR;		                         \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 		 pt1->cp_b = B;		                         \ | 
					
						
							|  |  |  |                  store_yaam_reg_cpdepth(pt1);                    \ | 
					
						
							|  |  |  |                  pt1->cp_cp = d0;                                \ | 
					
						
							| 
									
										
										
										
											2002-12-27 16:53:09 +00:00
										 |  |  |                  pt1->cp_ap = AP;                                \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 		 pt1->cp_env = ENV; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * Place B as the new place to cut to                           * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | #define	  set_cut(E,B) (E)[E_CB] = (CELL)(B)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * Restore WAM registers from a choice point                    * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef DEPTH_LIMIT
 | 
					
						
							|  |  |  | #define restore_yaam_reg_cpdepth(CPTR) DEPTH = (CPTR)->cp_depth
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define restore_yaam_reg_cpdepth(CPTR)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef YAPOR
 | 
					
						
							|  |  |  | #define YAPOR_update_alternative(CUR_ALT, NEW_ALT)  \
 | 
					
						
							|  |  |  | 	  if (SCH_top_shared_cp(B)) {               \ | 
					
						
							|  |  |  | 	    SCH_new_alternative(CUR_ALT, NEW_ALT);  \ | 
					
						
							|  |  |  | 	  } else | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define YAPOR_update_alternative(CUR_ALT, NEW_ALT)
 | 
					
						
							|  |  |  | #endif /* YAPOR */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-07-04 16:48:54 +00:00
										 |  |  | #if defined(FROZEN_STACKS) && !defined(BFZ_TRAIL_SCHEME)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define SET_BB(V)    BBREG = (V)
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define SET_BB(V)
 | 
					
						
							| 
									
										
										
										
											2003-11-05 18:55:03 +00:00
										 |  |  | #endif /* FROZEN_STACKS && !BFZ_TRAIL_SCHEME */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-07-04 16:48:54 +00:00
										 |  |  | #ifdef FROZEN_STACKS
 | 
					
						
							| 
									
										
										
										
											2011-03-30 15:32:59 +01:00
										 |  |  | #ifdef YAPOR_SBA
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define PROTECT_FROZEN_H(CPTR)                                  \
 | 
					
						
							|  |  |  |        ((Unsigned((Int)((CPTR)->cp_h)-(Int)(H_FZ)) <            \ | 
					
						
							|  |  |  | 	 Unsigned((Int)(B_FZ)-(Int)(H_FZ))) ?                   \ | 
					
						
							|  |  |  | 	(CPTR)->cp_h : H_FZ) | 
					
						
							|  |  |  | #define PROTECT_FROZEN_B(CPTR)                                  \
 | 
					
						
							|  |  |  |        ((Unsigned((Int)(CPTR)-(Int)(H_FZ)) <                    \ | 
					
						
							|  |  |  | 	 Unsigned((Int)(B_FZ)-(Int)(H_FZ)))  ?                  \ | 
					
						
							|  |  |  | 	(CPTR) : B_FZ) | 
					
						
							|  |  |  | 	 /*
 | 
					
						
							|  |  |  | #define PROTECT_FROZEN_H(CPTR) ((CPTR)->cp_h > H_FZ && (CPTR)->cp_h < (CELL *)B_FZ ? (CPTR)->cp_h : H_FZ )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PROTECT_FROZEN_B(CPTR)  ((CPTR) < B_FZ && (CPTR) > (choiceptr)H_FZ ? (CPTR) : B_FZ )
 | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2003-11-05 18:55:03 +00:00
										 |  |  | #else /* TABLING */
 | 
					
						
							|  |  |  | #define PROTECT_FROZEN_B(CPTR)  (YOUNGER_CP(CPTR, B_FZ) ? CPTR        : B_FZ)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define PROTECT_FROZEN_H(CPTR)  (((CPTR)->cp_h > H_FZ) ? (CPTR)->cp_h : H_FZ)
 | 
					
						
							| 
									
										
										
										
											2011-03-30 15:32:59 +01:00
										 |  |  | #endif /* YAPOR_SBA */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2005-11-15 00:50:49 +00:00
										 |  |  | #define PROTECT_FROZEN_B(CPTR)  (CPTR)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define PROTECT_FROZEN_H(CPTR)  (CPTR)->cp_h
 | 
					
						
							| 
									
										
										
										
											2003-11-05 18:55:03 +00:00
										 |  |  | #endif /* FROZEN_STACKS */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define restore_yaam_regs(AP)                                    \
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                  { register CELL *x1 = B_YREG->cp_env;	         \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                    register yamop *x2;				 \ | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  |                    HR = HBREG = PROTECT_FROZEN_H(B_YREG);            \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 		   restore_yaam_reg_cpdepth(B_YREG);	         \ | 
					
						
							|  |  |  |                    CPREG  = B_YREG->cp_cp;		                 \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 		   /* AP may depend on H */			 \ | 
					
						
							|  |  |  | 		   x2 = (yamop *)AP;		                 \ | 
					
						
							|  |  |  |                    ENV    = x1;                                  \ | 
					
						
							|  |  |  |                    YAPOR_update_alternative(PREG, x2)            \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                    B_YREG->cp_ap = x2;                              \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * Restore variable number of arguments from a choice point     * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | #define restore_args(Nargs)                                        \
 | 
					
						
							|  |  |  |                  BEGD(d0);                                         \ | 
					
						
							|  |  |  |                  d0 = Nargs;                                       \ | 
					
						
							|  |  |  |                  BEGP(pt0);                                        \ | 
					
						
							|  |  |  |                  BEGP(pt1);                                        \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                  pt1 = (CELL *)(B_YREG+1)+d0;                         \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                  pt0 = XREGS+1+d0;                                 \ | 
					
						
							|  |  |  | 	         while (pt0 > XREGS +1 )                           \ | 
					
						
							|  |  |  |                    { register CELL x = pt1[-1];                    \ | 
					
						
							|  |  |  |                      --pt0;                                        \ | 
					
						
							|  |  |  |                      --pt1;                                        \ | 
					
						
							|  |  |  |                      *pt0   = x;                                   \ | 
					
						
							|  |  |  | 		   }                                               \ | 
					
						
							|  |  |  |                  ENDP(pt1);                                        \ | 
					
						
							|  |  |  |                  ENDP(pt0);                                        \ | 
					
						
							|  |  |  |                  ENDD(d0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define restore_at_least_one_arg(Nargs)                            \
 | 
					
						
							|  |  |  |                  BEGD(d0);                                         \ | 
					
						
							|  |  |  |                  d0 = Nargs;                                       \ | 
					
						
							|  |  |  |                  BEGP(pt0);                                        \ | 
					
						
							|  |  |  |                  BEGP(pt1);                                        \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                  pt1 = (CELL *)(B_YREG+1)+d0;                         \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                  pt0 = XREGS+1+d0;                                 \ | 
					
						
							|  |  |  |                  do { register CELL x = pt1[-1];                   \ | 
					
						
							|  |  |  |                      --pt0;                                        \ | 
					
						
							|  |  |  |                      --pt1;                                        \ | 
					
						
							|  |  |  |                      *pt0   = x;                                   \ | 
					
						
							|  |  |  | 		   }                                               \ | 
					
						
							|  |  |  | 	         while (pt0 > XREGS +1 );                          \ | 
					
						
							|  |  |  |                  ENDP(pt1);                                        \ | 
					
						
							|  |  |  |                  ENDP(pt0);                                        \ | 
					
						
							|  |  |  |                  ENDD(d0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /***************************************************************
 | 
					
						
							|  |  |  | * Execute trust to release YAAM registers and pop choice point * | 
					
						
							|  |  |  | ***************************************************************/ | 
					
						
							|  |  |  | #ifdef DEPTH_LIMIT
 | 
					
						
							|  |  |  | #define pop_yaam_reg_cpdepth(CPTR) DEPTH = (CPTR)->cp_depth
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define pop_yaam_reg_cpdepth(CPTR)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef TABLING
 | 
					
						
							| 
									
										
										
										
											2009-07-31 08:31:17 -05:00
										 |  |  | #define TABLING_close_alt(CPTR) (CPTR)->cp_ap = NULL
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define TABLING_close_alt(CPTR)
 | 
					
						
							|  |  |  | #endif /* TABLING */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define pop_yaam_regs()                                           \
 | 
					
						
							| 
									
										
										
										
											2004-06-09 03:30:29 +00:00
										 |  |  |                  {                                                \ | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  |                    HR = PROTECT_FROZEN_H(B_YREG);                  \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 		   B = B_YREG->cp_b;	                          \ | 
					
						
							|  |  |  |                    pop_yaam_reg_cpdepth(B_YREG);                  \ | 
					
						
							|  |  |  | 		   CPREG = B_YREG->cp_cp;		          \ | 
					
						
							| 
									
										
										
										
											2004-06-09 03:30:29 +00:00
										 |  |  | 		   ENV = B_YREG->cp_env;			  \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                    TABLING_close_alt(B_YREG);	                  \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                    HBREG = PROTECT_FROZEN_H(B);		          \ | 
					
						
							|  |  |  |                  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define pop_args(NArgs)                                           \
 | 
					
						
							|  |  |  |                  BEGD(d0);                                        \ | 
					
						
							|  |  |  |                  d0 = (NArgs);                                    \ | 
					
						
							|  |  |  |                  BEGP(pt0);                                       \ | 
					
						
							|  |  |  |                  BEGP(pt1);                                       \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                  S_YREG = (CELL *)(B_YREG+1);                     \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                  pt0 = XREGS + 1 ;                                \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                  pt1 = S_YREG ;                                   \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 		 while (pt0 < XREGS+1+d0)                         \ | 
					
						
							|  |  |  |                    { register CELL x = pt1[0];                    \ | 
					
						
							|  |  |  |                      pt1++;                                       \ | 
					
						
							|  |  |  |                      pt0++;                                       \ | 
					
						
							|  |  |  |                      pt0[-1] = x;                                 \ | 
					
						
							|  |  |  | 		   }                                              \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                  S_YREG = pt1;					  \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                  ENDP(pt1);                                       \ | 
					
						
							|  |  |  |                  ENDP(pt0);                                       \ | 
					
						
							|  |  |  |                  ENDD(d0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define pop_at_least_one_arg(NArgs)                               \
 | 
					
						
							|  |  |  |                  BEGD(d0);                                        \ | 
					
						
							|  |  |  |                  d0 = (NArgs);                                    \ | 
					
						
							|  |  |  |                  BEGP(pt0);                                       \ | 
					
						
							|  |  |  |                  BEGP(pt1);                                       \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                  pt1 = (CELL *)(B_YREG+1);                        \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                  pt0 = XREGS + 1 ;                                \ | 
					
						
							|  |  |  |                  do { register CELL x = pt1[0];                   \ | 
					
						
							|  |  |  |                      pt1++;                                       \ | 
					
						
							|  |  |  |                      pt0++;                                       \ | 
					
						
							|  |  |  |                      pt0[-1] = x;                                 \ | 
					
						
							|  |  |  | 		   }                                              \ | 
					
						
							|  |  |  | 		 while (pt0 < XREGS+1+d0);                        \ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |                  S_YREG = pt1;	                                  \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |                  ENDP(pt1);                                       \ | 
					
						
							|  |  |  |                  ENDP(pt0);                                       \ | 
					
						
							|  |  |  |                  ENDD(d0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**********************************************************************
 | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  *                    failure and backtracking                        * | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  **********************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Failure can be called from two routines.
 | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * If from within the emulator, we should jump to the label fail. | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * If from within the complex-term unification routine, we should jump | 
					
						
							|  |  |  |  * to the label "cufail". | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define FAIL()	goto fail
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**********************************************************************
 | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  *                      unification routines                          * | 
					
						
							|  |  |  |  *                                                                    * | 
					
						
							|  |  |  |  **********************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define UnifyGlobalCells(a, b)                                    \
 | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  |   if ((b) > (a)) {                                                \ | 
					
						
							| 
									
										
										
										
											2011-03-19 10:25:23 +00:00
										 |  |  |     if (GlobalIsAttVar(b) && !GlobalIsAttVar(a)) {                    \ | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  |       Bind_Global((a),(CELL)(b));                                 \ | 
					
						
							|  |  |  |     } else {                                                      \ | 
					
						
							|  |  |  |       Bind_Global((b),(CELL)(a));                                 \ | 
					
						
							|  |  |  |     }                                                             \ | 
					
						
							|  |  |  |   } else if ((b) < (a)) {                                         \ | 
					
						
							| 
									
										
										
										
											2011-03-19 10:25:23 +00:00
										 |  |  |     if (GlobalIsAttVar(a) && !GlobalIsAttVar(b)) {                    \ | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  |       Bind_Global((b),(CELL)(a));                                 \ | 
					
						
							|  |  |  |     } else {                                                      \ | 
					
						
							|  |  |  |       Bind_Global((a),(CELL)(b));                                 \ | 
					
						
							|  |  |  |     }                                                             \ | 
					
						
							|  |  |  |   }                                                                | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define UnifyGlobalCellToCell(b, a)	                          \
 | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  | if ((a) < HR) { /* two globals */				  \ | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  |   UnifyGlobalCells(a,b);					  \ | 
					
						
							| 
									
										
										
										
											2011-03-19 10:25:23 +00:00
										 |  |  | } else {							  \ | 
					
						
							|  |  |  |       Bind_Local((a),(CELL)(b));				  \ | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define UnifyCells(a, b)		                          \
 | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  | if ((a) < HR) { /* at least one global */			  \ | 
					
						
							|  |  |  |   if ((b) > HR) { Bind_Local((b),(CELL)(a)); }			  \ | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  |   else { UnifyGlobalCells(a,b); }				  \ | 
					
						
							|  |  |  | } else {                                                          \ | 
					
						
							|  |  |  |   if ((b) > (a)) { Bind_Local((a),(CELL)(b)); }			  \ | 
					
						
							|  |  |  |   else if ((a) > (b)) {						  \ | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  |     if ((b) < HR) { Bind_Local((a),(CELL)(b)); }                   \ | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  |     else { Bind_Local((b),(CELL)(a)); }			          \ | 
					
						
							|  |  |  |   }								  \ | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* unify two complex terms.
 | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * I use two stacks: one keeps the visited terms, and the other keeps the | 
					
						
							|  |  |  |  * terms to visit. | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * The terms-to-visit stack is used to implement traditional | 
					
						
							|  |  |  |  * recursion. The visited-terms-stack is used to link structures already | 
					
						
							|  |  |  |  * visited and allows unification of infinite terms | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define UNWIND_CUNIF()                                        \
 | 
					
						
							|  |  |  |          while (visited < AuxSp) {                            \ | 
					
						
							|  |  |  |             pt1 = (CELL *)visited[0];                         \ | 
					
						
							|  |  |  |             *pt1 = visited[1];                                \ | 
					
						
							|  |  |  |             visited += 2;                                     \ | 
					
						
							|  |  |  |          } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define UNWIND_CUNIF()
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define UnifyBound_TEST_ATTACHED(f,d0,pt0,d1)                          \
 | 
					
						
							|  |  |  |  if (IsExtensionFunctor(f)) {                                          \ | 
					
						
							|  |  |  |    if (unify_extension(f, d0, RepAppl(d0), d1))                        \ | 
					
						
							|  |  |  |         { GONext(); }                                                  \ | 
					
						
							|  |  |  |       else                                                             \ | 
					
						
							|  |  |  |         { FAIL(); }                                                    \ | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define UnifyBound(d0,d1)                                              \
 | 
					
						
							|  |  |  |   if (d0 == d1) GONext();                                              \ | 
					
						
							|  |  |  |   if (IsPairTerm(d0)) {                                                \ | 
					
						
							| 
									
										
										
										
											2008-03-26 14:37:08 +00:00
										 |  |  |     register CELL *ipt0, *ipt1;                                        \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     if (!IsPairTerm(d1)) { FAIL(); }                                   \ | 
					
						
							| 
									
										
										
										
											2008-03-26 14:37:08 +00:00
										 |  |  |     ipt0 = RepPair(d0);                                                \ | 
					
						
							|  |  |  |     ipt1 = RepPair(d1);                                                \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     save_hb();							       \ | 
					
						
							|  |  |  |     always_save_pc();						       \ | 
					
						
							| 
									
										
										
										
											2008-03-26 14:37:08 +00:00
										 |  |  |     if (IUnify_complex(ipt0-1,ipt0+1,ipt1-1)) {always_set_pc(); GONext();}\ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     else { FAIL(); }                                                   \ | 
					
						
							|  |  |  |   } else if (IsApplTerm(d0)) {                                         \ | 
					
						
							| 
									
										
										
										
											2008-03-26 14:37:08 +00:00
										 |  |  |     register CELL *ipt0, *ipt1;                                        \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     register Functor f;                                                \ | 
					
						
							|  |  |  |     if (!IsApplTerm(d1)) { FAIL(); }                                   \ | 
					
						
							| 
									
										
										
										
											2008-03-26 14:37:08 +00:00
										 |  |  |     ipt0 = RepAppl(d0);                                                \ | 
					
						
							|  |  |  |     ipt1 = RepAppl(d1);                                                \ | 
					
						
							|  |  |  |     f = (Functor)*ipt0;                                                \ | 
					
						
							|  |  |  |     if (f != (Functor)*ipt1) { FAIL(); }                               \ | 
					
						
							|  |  |  |     UnifyBound_TEST_ATTACHED(f,d0,ipt0,d1);                            \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     d0 = ArityOfFunctor(f);                                            \ | 
					
						
							|  |  |  |     always_save_pc();						       \ | 
					
						
							|  |  |  |     save_hb();							       \ | 
					
						
							| 
									
										
										
										
											2008-03-26 14:37:08 +00:00
										 |  |  |     if (IUnify_complex(ipt0, ipt0+d0, ipt1)) {always_set_pc(); GONext();} \ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     else { FAIL(); }                                                   \ | 
					
						
							|  |  |  |   }                                                                    \ | 
					
						
							|  |  |  |   else { FAIL(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 
 | 
					
						
							|  |  |  |  * Next, HB | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef SHADOW_HB
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #undef HBREG
 | 
					
						
							|  |  |  | #define set_hb()	HBREG = HB
 | 
					
						
							|  |  |  | #define save_hb()	HB = HBREG
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define set_hb()
 | 
					
						
							|  |  |  | #define save_hb()
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | typedef struct unif_record { | 
					
						
							|  |  |  |   CELL *ptr; | 
					
						
							|  |  |  |   Term old; | 
					
						
							|  |  |  | } unif_record; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | typedef struct v_record { | 
					
						
							| 
									
										
										
										
											2009-05-22 15:21:14 -05:00
										 |  |  |   CELL *start0; | 
					
						
							|  |  |  |   CELL *end0; | 
					
						
							|  |  |  |   CELL *start1; | 
					
						
							|  |  |  |   Term old; | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | } v_record; | 
					
						
							| 
									
										
										
										
											2009-05-22 15:21:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | #if defined(IN_ABSMI_C) || defined(IN_UNIFY_C)
 | 
					
						
							| 
									
										
										
										
											2003-11-12 12:33:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | static int  | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | IUnify_complex(CELL *pt0, CELL *pt0_end, CELL *pt1) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef THREADS
 | 
					
						
							| 
									
										
										
										
											2004-02-05 16:57:02 +00:00
										 |  |  | #undef Yap_REGS
 | 
					
						
							|  |  |  |   register REGSTORE *regp = Yap_regp; | 
					
						
							|  |  |  | #define Yap_REGS (*regp)
 | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #elif defined(SHADOW_REGS)
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #if defined(B) || defined(TR)
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   register REGSTORE *regp = &Yap_REGS; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | #define Yap_REGS (*regp)
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #endif /* defined(B) || defined(TR) || defined(HB) */
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef SHADOW_HB
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |   register CELL *HBREG = HB; | 
					
						
							|  |  |  | #endif /* SHADOW_HB */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  |   struct unif_record  *unif = (struct unif_record *)AuxBase; | 
					
						
							|  |  |  |   struct v_record *to_visit  = (struct v_record *)AuxSp; | 
					
						
							|  |  |  | #define unif_base ((struct unif_record *)AuxBase)
 | 
					
						
							|  |  |  | #define to_visit_base ((struct v_record *)AuxSp)
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | loop: | 
					
						
							|  |  |  |   while (pt0 < pt0_end) { | 
					
						
							|  |  |  |     register CELL *ptd0 = pt0+1;  | 
					
						
							|  |  |  |     register CELL d0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ++pt1; | 
					
						
							|  |  |  |     pt0 = ptd0; | 
					
						
							|  |  |  |     d0 = *ptd0; | 
					
						
							|  |  |  |     deref_head(d0, unify_comp_unk); | 
					
						
							|  |  |  |   unify_comp_nvar: | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       register CELL *ptd1 = pt1; | 
					
						
							|  |  |  |       register CELL d1 = *ptd1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       deref_head(d1, unify_comp_nvar_unk); | 
					
						
							|  |  |  |     unify_comp_nvar_nvar: | 
					
						
							|  |  |  |       if (d0 == d1) | 
					
						
							|  |  |  | 	continue; | 
					
						
							|  |  |  |       if (IsPairTerm(d0)) { | 
					
						
							|  |  |  | 	if (!IsPairTerm(d1)) { | 
					
						
							|  |  |  | 	  goto cufail; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	/* now link the two structures so that no one else will */ | 
					
						
							|  |  |  | 	/* come here */ | 
					
						
							|  |  |  | 	/* store the terms to visit */ | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | 	if (RATIONAL_TREES || pt0 < pt0_end) { | 
					
						
							| 
									
										
										
										
											2009-05-22 15:21:14 -05:00
										 |  |  | 	  to_visit --; | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  | 	  unif++; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	  if ((void *)to_visit < (void *)unif) { | 
					
						
							| 
									
										
										
										
											2009-05-22 21:33:09 -05:00
										 |  |  | 	    CELL **urec = (CELL **)unif; | 
					
						
							| 
									
										
										
										
											2012-03-15 22:37:13 +00:00
										 |  |  | 	    to_visit = (struct v_record *)Yap_shift_visit((CELL **)to_visit, &urec, NULL); | 
					
						
							| 
									
										
										
										
											2009-05-22 21:33:09 -05:00
										 |  |  | 	    unif = (struct unif_record *)urec; | 
					
						
							| 
									
										
										
										
											2004-02-05 16:57:02 +00:00
										 |  |  | 	  } | 
					
						
							| 
									
										
										
										
											2009-05-22 15:21:14 -05:00
										 |  |  | 	  to_visit->start0 = pt0; | 
					
						
							|  |  |  | 	  to_visit->end0 = pt0_end; | 
					
						
							|  |  |  | 	  to_visit->start1 = pt1; | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  | 	  unif[-1].old = *pt0; | 
					
						
							|  |  |  | 	  unif[-1].ptr = pt0; | 
					
						
							|  |  |  | 	  *pt0 = d1; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	pt0_end = (pt0 = RepPair(d0) - 1) + 2; | 
					
						
							|  |  |  | 	pt1 = RepPair(d1) - 1; | 
					
						
							|  |  |  | 	continue; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (IsApplTerm(d0)) { | 
					
						
							|  |  |  | 	register Functor f; | 
					
						
							|  |  |  | 	register CELL *ap2, *ap3; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!IsApplTerm(d1)) { | 
					
						
							|  |  |  | 	  goto cufail; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	/* store the terms to visit */ | 
					
						
							|  |  |  | 	ap2 = RepAppl(d0); | 
					
						
							|  |  |  | 	ap3 = RepAppl(d1); | 
					
						
							|  |  |  | 	f = (Functor) (*ap2); | 
					
						
							|  |  |  | 	/* compare functors */ | 
					
						
							|  |  |  | 	if (f != (Functor) *ap3) | 
					
						
							|  |  |  | 	  goto cufail; | 
					
						
							|  |  |  | 	if (IsExtensionFunctor(f)) { | 
					
						
							|  |  |  | 	  if (unify_extension(f, d0, ap2, d1)) | 
					
						
							|  |  |  | 	    continue; | 
					
						
							|  |  |  | 	  goto cufail; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	/* now link the two structures so that no one else will */ | 
					
						
							|  |  |  | 	/* come here */ | 
					
						
							|  |  |  | 	/* store the terms to visit */ | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | 	if (RATIONAL_TREES || pt0 < pt0_end) { | 
					
						
							| 
									
										
										
										
											2009-05-22 15:21:14 -05:00
										 |  |  | 	  to_visit --; | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  | 	  unif++; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	  if ((void *)to_visit < (void *)unif) { | 
					
						
							| 
									
										
										
										
											2009-05-22 21:33:09 -05:00
										 |  |  | 	    CELL **urec = (CELL **)unif; | 
					
						
							| 
									
										
										
										
											2012-03-15 22:37:13 +00:00
										 |  |  | 	    to_visit = (struct v_record *)Yap_shift_visit((CELL **)to_visit, &urec, NULL); | 
					
						
							| 
									
										
										
										
											2009-05-22 21:33:09 -05:00
										 |  |  | 	    unif = (struct unif_record *)urec; | 
					
						
							| 
									
										
										
										
											2004-02-05 16:57:02 +00:00
										 |  |  | 	  } | 
					
						
							| 
									
										
										
										
											2009-05-22 15:21:14 -05:00
										 |  |  | 	  to_visit->start0 = pt0; | 
					
						
							|  |  |  | 	  to_visit->end0 = pt0_end; | 
					
						
							|  |  |  | 	  to_visit->start1 = pt1; | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  | 	  unif[-1].old = *pt0; | 
					
						
							|  |  |  | 	  unif[-1].ptr = pt0; | 
					
						
							|  |  |  | 	  *pt0 = d1; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	d0 = ArityOfFunctor(f); | 
					
						
							|  |  |  | 	pt0 = ap2; | 
					
						
							|  |  |  | 	pt0_end = ap2 + d0; | 
					
						
							|  |  |  | 	pt1 = ap3; | 
					
						
							|  |  |  | 	continue; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       goto cufail; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       derefa_body(d1, ptd1, unify_comp_nvar_unk, unify_comp_nvar_nvar); | 
					
						
							|  |  |  | 	/* d1 and pt2 have the unbound value, whereas d0 is bound */ | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  |       Bind_Global(ptd1, d0); | 
					
						
							|  |  |  |       continue; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     derefa_body(d0, ptd0, unify_comp_unk, unify_comp_nvar); | 
					
						
							|  |  |  |     /* first arg var */ | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       register CELL d1; | 
					
						
							|  |  |  |       register CELL *ptd1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       ptd1 = pt1; | 
					
						
							|  |  |  |       d1 = ptd1[0]; | 
					
						
							|  |  |  |       /* pt2 is unbound */ | 
					
						
							|  |  |  |       deref_head(d1, unify_comp_var_unk); | 
					
						
							|  |  |  |     unify_comp_var_nvar: | 
					
						
							|  |  |  |       /* pt2 is unbound and d1 is bound */ | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  |       Bind_Global(ptd0, d1); | 
					
						
							|  |  |  |       continue; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       derefa_body(d1, ptd1, unify_comp_var_unk, unify_comp_var_nvar); | 
					
						
							|  |  |  |       /* ptd0 and ptd1 are unbound */ | 
					
						
							|  |  |  |       UnifyGlobalCells(ptd0, ptd1); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   /* Do we still have compound terms to visit */ | 
					
						
							| 
									
										
										
										
											2004-02-05 16:57:02 +00:00
										 |  |  |   if (to_visit < to_visit_base) { | 
					
						
							| 
									
										
										
										
											2009-05-22 15:21:14 -05:00
										 |  |  |     pt0 = to_visit->start0; | 
					
						
							|  |  |  |     pt0_end = to_visit->end0; | 
					
						
							|  |  |  |     pt1 = to_visit->start1; | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  |     to_visit++; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |     goto loop; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  |   /* restore bindigs */ | 
					
						
							|  |  |  |   while (unif-- != unif_base) { | 
					
						
							|  |  |  |     CELL *pt0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pt0 = unif->ptr; | 
					
						
							|  |  |  |     *pt0 = unif->old; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-05-22 15:21:14 -05:00
										 |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | cufail: | 
					
						
							|  |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  |   /* restore bindigs */ | 
					
						
							|  |  |  |   while (unif-- != unif_base) { | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |     CELL *pt0; | 
					
						
							| 
									
										
										
										
											2009-05-22 15:21:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  |     pt0 = unif->ptr; | 
					
						
							|  |  |  |     *pt0 = unif->old; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-05-22 15:21:14 -05:00
										 |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef THREADS
 | 
					
						
							| 
									
										
										
										
											2004-02-05 16:57:02 +00:00
										 |  |  | #undef Yap_REGS
 | 
					
						
							|  |  |  | #define Yap_REGS (*Yap_regp)  
 | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #elif defined(SHADOW_REGS)
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #if defined(B) || defined(TR)
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | #undef Yap_REGS
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #endif /* defined(B) || defined(TR) */
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-15 14:16:38 +00:00
										 |  |  | /*  don't pollute name space */ | 
					
						
							|  |  |  | #undef to_visit_base
 | 
					
						
							| 
									
										
										
										
											2009-05-22 18:35:24 -05:00
										 |  |  | #undef unif_base
 | 
					
						
							| 
									
										
										
										
											2005-08-15 14:16:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #if defined(IN_ABSMI_C) || defined(IN_INLINES_C)
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static int  | 
					
						
							|  |  |  | iequ_complex(register CELL *pt0, register CELL *pt0_end, | 
					
						
							|  |  |  | 	       register CELL *pt1 | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | CACHE_REGS | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | #ifdef THREADS
 | 
					
						
							|  |  |  | #undef Yap_REGS
 | 
					
						
							|  |  |  |   register REGSTORE *regp = Yap_regp; | 
					
						
							|  |  |  | #define Yap_REGS (*regp)
 | 
					
						
							|  |  |  | #elif defined(SHADOW_REGS)
 | 
					
						
							|  |  |  | #if defined(B) || defined(TR)
 | 
					
						
							|  |  |  |   register REGSTORE *regp = &Yap_REGS; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | #define Yap_REGS (*regp)
 | 
					
						
							|  |  |  | #endif /* defined(B) || defined(TR) || defined(HB) */
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | #ifdef SHADOW_HB
 | 
					
						
							|  |  |  |   register CELL *HBREG = HB; | 
					
						
							|  |  |  | #endif /* SHADOW_HB */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   struct unif_record  *unif = (struct unif_record *)AuxBase; | 
					
						
							|  |  |  |   struct v_record *to_visit  = (struct v_record *)AuxSp; | 
					
						
							|  |  |  | #define unif_base ((struct unif_record *)AuxBase)
 | 
					
						
							|  |  |  | #define to_visit_base ((struct v_record *)AuxSp)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | loop: | 
					
						
							|  |  |  |   while (pt0 < pt0_end) { | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |     register CELL *ptd0 = pt0+1;  | 
					
						
							|  |  |  |     register CELL d0; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ++pt1; | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |     pt0 = ptd0; | 
					
						
							|  |  |  |     d0 = *ptd0; | 
					
						
							|  |  |  |     deref_head(d0, iequ_comp_unk); | 
					
						
							|  |  |  |   iequ_comp_nvar: | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |       register CELL *ptd1 = pt1; | 
					
						
							|  |  |  |       register CELL d1 = *ptd1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |       deref_head(d1, iequ_comp_nvar_unk); | 
					
						
							|  |  |  |     iequ_comp_nvar_nvar: | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |       if (d0 == d1) | 
					
						
							|  |  |  | 	continue; | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |       if (IsPairTerm(d0)) { | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	if (!IsPairTerm(d1)) { | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | 	  goto cufail; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	/* now link the two structures so that no one else will */ | 
					
						
							|  |  |  | 	/* come here */ | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | 	/* store the terms to visit */ | 
					
						
							|  |  |  | 	if (RATIONAL_TREES || pt0 < pt0_end) { | 
					
						
							|  |  |  | 	  to_visit --; | 
					
						
							|  |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  | 	  unif++; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	  if ((void *)to_visit < (void *)unif) { | 
					
						
							|  |  |  | 	    CELL **urec = (CELL **)unif; | 
					
						
							| 
									
										
										
										
											2012-03-15 22:37:13 +00:00
										 |  |  | 	    to_visit = (struct v_record *)Yap_shift_visit((CELL **)to_visit, &urec, NULL); | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | 	    unif = (struct unif_record *)urec; | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	  to_visit->start0 = pt0; | 
					
						
							|  |  |  | 	  to_visit->end0 = pt0_end; | 
					
						
							|  |  |  | 	  to_visit->start1 = pt1; | 
					
						
							|  |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  | 	  unif[-1].old = *pt0; | 
					
						
							|  |  |  | 	  unif[-1].ptr = pt0; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	  *pt0 = d1; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	pt0_end = (pt0 = RepPair(d0) - 1) + 2; | 
					
						
							|  |  |  | 	pt1 = RepPair(d1) - 1; | 
					
						
							|  |  |  | 	continue; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |       if (IsApplTerm(d0)) { | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	register Functor f; | 
					
						
							|  |  |  | 	register CELL *ap2, *ap3; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!IsApplTerm(d1)) { | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | 	  goto cufail; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | 	/* store the terms to visit */ | 
					
						
							|  |  |  | 	ap2 = RepAppl(d0); | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	ap3 = RepAppl(d1); | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | 	f = (Functor) (*ap2); | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	/* compare functors */ | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | 	if (f != (Functor) *ap3) | 
					
						
							|  |  |  | 	  goto cufail; | 
					
						
							|  |  |  | 	if (IsExtensionFunctor(f)) { | 
					
						
							|  |  |  | 	  if (unify_extension(f, d0, ap2, d1)) | 
					
						
							|  |  |  | 	    continue; | 
					
						
							|  |  |  | 	  goto cufail; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	/* now link the two structures so that no one else will */ | 
					
						
							|  |  |  | 	/* come here */ | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | 	/* store the terms to visit */ | 
					
						
							|  |  |  | 	if (RATIONAL_TREES || pt0 < pt0_end) { | 
					
						
							|  |  |  | 	  to_visit --; | 
					
						
							|  |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  | 	  unif++; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	  if ((void *)to_visit < (void *)unif) { | 
					
						
							|  |  |  | 	    CELL **urec = (CELL **)unif; | 
					
						
							| 
									
										
										
										
											2012-03-15 22:37:13 +00:00
										 |  |  | 	    to_visit = (struct v_record *)Yap_shift_visit((CELL **)to_visit, &urec, NULL); | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | 	    unif = (struct unif_record *)urec; | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	  to_visit->start0 = pt0; | 
					
						
							|  |  |  | 	  to_visit->end0 = pt0_end; | 
					
						
							|  |  |  | 	  to_visit->start1 = pt1; | 
					
						
							|  |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  | 	  unif[-1].old = *pt0; | 
					
						
							|  |  |  | 	  unif[-1].ptr = pt0; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 	  *pt0 = d1; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	d0 = ArityOfFunctor(f); | 
					
						
							|  |  |  | 	pt0 = ap2; | 
					
						
							|  |  |  | 	pt0_end = ap2 + d0; | 
					
						
							|  |  |  | 	pt1 = ap3; | 
					
						
							|  |  |  | 	continue; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |       goto cufail; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       derefa_body(d1, ptd1, iequ_comp_nvar_unk, iequ_comp_nvar_nvar); | 
					
						
							|  |  |  | 	/* d1 and pt2 have the unbound value, whereas d0 is bound */ | 
					
						
							|  |  |  |       goto cufail; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |     derefa_body(d0, ptd0, iequ_comp_unk, iequ_comp_nvar); | 
					
						
							|  |  |  |     /* first arg var */ | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |       register CELL d1; | 
					
						
							|  |  |  |       register CELL *ptd1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |       ptd1 = pt1; | 
					
						
							|  |  |  |       d1 = ptd1[0]; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |       /* pt2 is unbound */ | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |       deref_head(d1, iequ_comp_var_unk); | 
					
						
							|  |  |  |     iequ_comp_var_nvar: | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |       /* pt2 is unbound and d1 is bound */ | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |       goto cufail; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |       derefa_body(d1, ptd1, iequ_comp_var_unk, iequ_comp_var_nvar); | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |       /* pt2 and pt3 are unbound */ | 
					
						
							|  |  |  |       if (ptd0 == ptd1) | 
					
						
							|  |  |  | 	continue; | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |       goto cufail; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   /* Do we still have compound terms to visit */ | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  |   if (to_visit < to_visit_base) { | 
					
						
							|  |  |  |     pt0 = to_visit->start0; | 
					
						
							|  |  |  |     pt0_end = to_visit->end0; | 
					
						
							|  |  |  |     pt1 = to_visit->start1; | 
					
						
							|  |  |  |     to_visit++; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  |     goto loop; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-07-29 22:36:30 +01:00
										 |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  |   /* restore bindigs */ | 
					
						
							|  |  |  |   while (unif-- != unif_base) { | 
					
						
							|  |  |  |     CELL *pt0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pt0 = unif->ptr; | 
					
						
							|  |  |  |     *pt0 = unif->old; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | cufail: | 
					
						
							|  |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  |   /* restore bindigs */ | 
					
						
							|  |  |  |   while (unif-- != unif_base) { | 
					
						
							|  |  |  |     CELL *pt0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pt0 = unif->ptr; | 
					
						
							|  |  |  |     *pt0 = unif->old; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   return FALSE; | 
					
						
							|  |  |  | #ifdef THREADS
 | 
					
						
							|  |  |  | #undef Yap_REGS
 | 
					
						
							|  |  |  | #define Yap_REGS (*Yap_regp)  
 | 
					
						
							|  |  |  | #elif defined(SHADOW_REGS)
 | 
					
						
							|  |  |  | #if defined(B) || defined(TR)
 | 
					
						
							|  |  |  | #undef Yap_REGS
 | 
					
						
							|  |  |  | #endif /* defined(B) || defined(TR) */
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static inline wamreg | 
					
						
							|  |  |  | Yap_regnotoreg(UInt regnbr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if PRECOMPUTE_REGADDRESS
 | 
					
						
							|  |  |  |   return (wamreg)(XREGS + regnbr); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #if MSHIFTOFFS
 | 
					
						
							|  |  |  |   return regnbr; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   return CELLSIZE*regnbr; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* ALIGN_LONGS */
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline UInt | 
					
						
							|  |  |  | Yap_regtoregno(wamreg reg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if PRECOMPUTE_REGADDRESS
 | 
					
						
							|  |  |  |   return ((CELL *)reg)-XREGS; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #if MSHIFTOFFS
 | 
					
						
							|  |  |  |   return reg; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   return reg/CELLSIZE; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* ALIGN_LONGS */
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef DEPTH_LIMIT
 | 
					
						
							|  |  |  | #define check_depth(DEPTH, ap) \
 | 
					
						
							|  |  |  | 	  if ((DEPTH) <= MkIntTerm(1)) {/* I assume Module==0 is prolog */ \ | 
					
						
							|  |  |  | 	    if ((ap)->ModuleOfPred) {\ | 
					
						
							|  |  |  | 	      if ((DEPTH) == MkIntTerm(0))\ | 
					
						
							|  |  |  | 		FAIL(); \ | 
					
						
							|  |  |  | 	      else (DEPTH) = RESET_DEPTH();\ | 
					
						
							|  |  |  | 	    } \ | 
					
						
							|  |  |  | 	  } else if ((ap)->ModuleOfPred)\ | 
					
						
							|  |  |  | 	    (DEPTH) -= MkIntConstant(2); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2003-09-25 00:48:04 +00:00
										 |  |  | #define check_depth(DEPTH, ap)
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-02-05 16:57:02 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if defined(THREADS) || defined(YAPOR)
 | 
					
						
							|  |  |  | #define copy_jmp_address(X) (PREG_ADDR = &(X))
 | 
					
						
							|  |  |  | #define copy_jmp_addressa(X) (PREG_ADDR = (yamop **)(X))
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define copy_jmp_address(X) 
 | 
					
						
							|  |  |  | #define copy_jmp_addressa(X) 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-09-18 17:35:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-14 11:29:20 -08:00
										 |  |  | static inline void | 
					
						
							| 
									
										
										
										
											2012-12-13 18:12:50 +00:00
										 |  |  | prune(choiceptr cp USES_REGS) | 
					
						
							| 
									
										
										
										
											2011-02-14 11:29:20 -08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-07-13 17:36:26 +01:00
										 |  |  | #ifdef YAPOR
 | 
					
						
							|  |  |  |   CUT_prune_to(cp); | 
					
						
							|  |  |  | #endif /* YAPOR */
 | 
					
						
							| 
									
										
										
										
											2011-02-14 11:29:20 -08:00
										 |  |  |   if (SHOULD_CUT_UP_TO(B,cp)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       if (ASP > (CELL *)PROTECT_FROZEN_B(B)) | 
					
						
							|  |  |  | 	ASP = (CELL *)PROTECT_FROZEN_B(B); | 
					
						
							|  |  |  |       while (B->cp_b < cp) { | 
					
						
							| 
									
										
										
										
											2011-02-15 05:54:19 -08:00
										 |  |  | 	if (POP_CHOICE_POINT(B->cp_b)) | 
					
						
							| 
									
										
										
										
											2011-02-14 11:29:20 -08:00
										 |  |  | 	  { | 
					
						
							|  |  |  | 	    POP_EXECUTE(); | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	B = B->cp_b; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-02-15 05:54:19 -08:00
										 |  |  |       if (POP_CHOICE_POINT(B->cp_b)) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  POP_EXECUTE(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-02-15 18:14:18 +00:00
										 |  |  |       /* cut ! */ | 
					
						
							| 
									
										
										
										
											2011-02-14 11:29:20 -08:00
										 |  |  | #ifdef TABLING
 | 
					
						
							| 
									
										
										
										
											2011-02-15 05:54:19 -08:00
										 |  |  |       abolish_incomplete_subgoals(B); | 
					
						
							| 
									
										
										
										
											2011-02-14 11:29:20 -08:00
										 |  |  | #endif /* TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-02-15 05:54:19 -08:00
										 |  |  |       HB = PROTECT_FROZEN_H(B->cp_b); | 
					
						
							| 
									
										
										
										
											2011-02-14 11:29:20 -08:00
										 |  |  | #include "trim_trail.h"
 | 
					
						
							| 
									
										
										
										
											2011-02-15 05:54:19 -08:00
										 |  |  |       B = B->cp_b; | 
					
						
							|  |  |  |       SET_BB(PROTECT_FROZEN_B(B)); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-02-14 11:29:20 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-15 15:40:47 +01:00
										 |  |  | #if YAPOR
 | 
					
						
							|  |  |  | #define INITIALIZE_PERMVAR(PTR, V) Bind_Local((PTR), (V))
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define INITIALIZE_PERMVAR(PTR, V) *(PTR) = (V)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-27 12:35:07 +02:00
										 |  |  | /* l1: bind a, l2 bind b, l3 no binding */ | 
					
						
							|  |  |  | #define UnifyAndTrailCells(a, b)                                            \
 | 
					
						
							|  |  |  |      if((a) > (b)) {                                                        \ | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  |        if ((a) < HR) { *(a) = (CELL)(b); DO_TRAIL((a),(CELL)(b)); }	    \ | 
					
						
							|  |  |  |        else if ((b) <= HR) { *(a) =(CELL)(b); DO_TRAIL((a),(CELL)(b));}	   \ | 
					
						
							| 
									
										
										
										
											2011-10-27 12:35:07 +02:00
										 |  |  |        else { *(b) = (CELL)(a);  DO_TRAIL((b),(CELL)(a)); }		    \ | 
					
						
							|  |  |  |      } else if((a) < (b)){                                                  \ | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  |        if ((b) <= HR) { *(b) = (CELL)(a); DO_TRAIL((b),(CELL)(a)); }         \ | 
					
						
							|  |  |  |        else if ((a) <= HR) { *(b) = (CELL) (a); DO_TRAIL((b),(CELL)(a));}    \ | 
					
						
							| 
									
										
										
										
											2011-10-27 12:35:07 +02:00
										 |  |  |        else { *(a) = (CELL) (b);  DO_TRAIL((a),(CELL)(b));}                 \ | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-14 12:35:18 +00:00
										 |  |  | #ifdef SHADOW_S
 | 
					
						
							| 
									
										
										
										
											2013-12-12 14:24:40 +00:00
										 |  |  | #define PROCESS_INT( F, C ) \
 | 
					
						
							|  |  |  |       BEGD(d0); \ | 
					
						
							| 
									
										
										
										
											2013-12-14 12:35:18 +00:00
										 |  |  |       Yap_REGS.S_ = SREG; \ | 
					
						
							| 
									
										
										
										
											2013-12-12 14:24:40 +00:00
										 |  |  |       saveregs(); \ | 
					
						
							|  |  |  |       d0 = F ( PASS_REGS1 );\ | 
					
						
							|  |  |  |       setregs(); \ | 
					
						
							| 
									
										
										
										
											2013-12-14 12:35:18 +00:00
										 |  |  |       SREG = Yap_REGS.S_; \ | 
					
						
							| 
									
										
										
										
											2013-12-12 14:24:40 +00:00
										 |  |  |       if (!d0) FAIL(); \ | 
					
						
							|  |  |  |       if (d0 == 2) goto C; \ | 
					
						
							|  |  |  |       JMPNext(); \ | 
					
						
							|  |  |  |       ENDD(d0); | 
					
						
							| 
									
										
										
										
											2013-12-14 12:35:18 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define PROCESS_INT( F, C ) \
 | 
					
						
							|  |  |  |       BEGD(d0); \ | 
					
						
							|  |  |  |       saveregs(); \ | 
					
						
							|  |  |  |       d0 = F ( PASS_REGS1 );\ | 
					
						
							|  |  |  |       setregs(); \ | 
					
						
							|  |  |  |       if (!d0) FAIL(); \ | 
					
						
							|  |  |  |       if (d0 == 2) goto C; \ | 
					
						
							|  |  |  |       JMPNext(); \ | 
					
						
							|  |  |  |       ENDD(d0); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-12-12 14:24:40 +00:00
										 |  |  | 
 |