| 
									
										
										
										
											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:		heapgc.c						 * | 
					
						
							|  |  |  | * Last rev:								 * | 
					
						
							|  |  |  | * mods:									 * | 
					
						
							|  |  |  | * comments:	Header for Global Stack garbage collector                * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-30 19:51:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* macros used by garbage collection */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if TAG_64BITS
 | 
					
						
							| 
									
										
										
										
											2010-05-11 12:25:49 +01:00
										 |  |  | #define MaskAdr		(~((CELL)0x7))
 | 
					
						
							| 
									
										
										
										
											2004-11-19 17:14:15 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* return pointer from object pointed to by ptr (remove tag & mark) */ | 
					
						
							|  |  |  | #ifdef TAGS_FAST_OPS
 | 
					
						
							|  |  |  | #define GET_NEXT(val)  ((CELL *)(IsVarTerm((val)) ?                          \
 | 
					
						
							|  |  |  |                                  (val) & MaskAdr :                           \ | 
					
						
							|  |  |  |                                  ( IsPairTerm((val)) ?                       \ | 
					
						
							|  |  |  | 			            Unsigned(RepPair((val))) & MaskAdr :     \ | 
					
						
							|  |  |  |                                     ( IsApplTerm((val)) ?                    \ | 
					
						
							|  |  |  |                                       Unsigned(RepAppl((val))) & MaskAdr :   \ | 
					
						
							|  |  |  |                                       (val) & MaskAdr                        \ | 
					
						
							|  |  |  |                                     )                                        \ | 
					
						
							|  |  |  |                                   )                                          \ | 
					
						
							|  |  |  |                                  )                                           \ | 
					
						
							|  |  |  |                         )  | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #ifdef  TAG_LOW_BITS_32
 | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | #define GET_NEXT(val)  ((CELL *) ((val) & ~LowTagBits))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define GET_NEXT(val)  ((CELL *) ((val) & MaskAdr))
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* is ptr a pointer to the heap? */ | 
					
						
							|  |  |  | #define ONHEAP(ptr) (CellPtr(ptr) >= H0  && CellPtr(ptr) < H)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* is ptr a pointer to code space? */ | 
					
						
							| 
									
										
										
										
											2004-04-22 20:07:07 +00:00
										 |  |  | #if USE_SYSTEM_MALLOC
 | 
					
						
							| 
									
										
										
										
											2011-05-23 16:19:47 +01:00
										 |  |  | #define ONCODE(ptr) (Addr(ptr) < LOCAL_GlobalBase || Addr(ptr) > LOCAL_TrailTop)
 | 
					
						
							| 
									
										
										
										
											2004-04-22 20:07:07 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | #define ONCODE(ptr) (Addr(ptr) < HeapTop && Addr(ptr) >= Yap_HeapBase)
 | 
					
						
							| 
									
										
										
										
											2004-04-22 20:07:07 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* is val pointing to something bound to the heap? */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-09-09 17:24:39 +00:00
										 |  |  | #define GCIsPrimitiveTerm(X)    (/* not really needed !IsVarTerm(X) && */ IsAtomOrIntTerm(X))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Does X point to an object in the heap */ | 
					
						
							|  |  |  | #define HEAP_PTR(val)    (!GCIsPrimitiveTerm(val) && ONHEAP(GET_NEXT(val)))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 
 | 
					
						
							|  |  |  |    Heap_trail_entry must be very careful. We are looking at a valid | 
					
						
							|  |  |  |    trail entry if: it was between H0 and HB or between B and LCLO | 
					
						
							|  |  |  |    (that is, if it was covered by choicepoints at the time), and if it | 
					
						
							|  |  |  |    was a heap pointer. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    We can join the two conditions: (H0 =< val < HB || ((B < val < LCL0) | 
					
						
							|  |  |  | 					&& H0 <= *DETAG(val) < H)) | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | #define HEAP_TRAIL_ENTRY(val) ((IsVarTerm(val)) &&                  \
 | 
					
						
							|  |  |  | 				((H0 <= CellPtr(val) && CellPtr(val)\ | 
					
						
							|  |  |  | 				< cp_H) ||                          \ | 
					
						
							|  |  |  | 			       (CellPtr(B) < CellPtr(val) && CellPtr(val) <= \ | 
					
						
							|  |  |  | 				LCL0 && HEAP_PTR(val)))) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-26 14:37:08 +00:00
										 |  |  | #define  MARK_BIT ((char)1)
 | 
					
						
							|  |  |  | #define RMARK_BIT ((char)2)
 | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-23 16:19:47 +01:00
										 |  |  | #define mcell(X)  LOCAL_bp[(X)-(CELL *)LOCAL_GlobalBase]
 | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | #define MARKED_PTR(P) MARKED_PTR__(P PASS_REGS) 
 | 
					
						
							|  |  |  | #define UNMARKED_MARK(P, BP) UNMARKED_MARK__(P, BP PASS_REGS) 
 | 
					
						
							|  |  |  | #define MARK(P) MARK__(P PASS_REGS) 
 | 
					
						
							|  |  |  | #define UNMARK(P) UNMARK__(P PASS_REGS) 
 | 
					
						
							|  |  |  | #define RMARK(P) RMARK__(P PASS_REGS) 
 | 
					
						
							|  |  |  | #define RMARKED(P) RMARKED__(P PASS_REGS) 
 | 
					
						
							|  |  |  | #define UNRMARK(P) UNRMARK__(P PASS_REGS) 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-26 18:26:27 +00:00
										 |  |  | static inline Int | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | MARKED_PTR__(CELL* ptr USES_REGS) | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   return mcell(ptr) & MARK_BIT; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-05 03:06:31 +00:00
										 |  |  | static inline Int | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | UNMARKED_MARK__(CELL* ptr, char *bp USES_REGS) | 
					
						
							| 
									
										
										
										
											2006-08-05 03:06:31 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-05-23 16:19:47 +01:00
										 |  |  |   Int pos = ptr - (CELL *)LOCAL_GlobalBase; | 
					
						
							| 
									
										
										
										
											2006-08-05 03:06:31 +00:00
										 |  |  |   char t = bp[pos]; | 
					
						
							|  |  |  |   if (t & MARK_BIT) { | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   bp[pos] = t | MARK_BIT; | 
					
						
							|  |  |  |   return FALSE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | static inline void | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | MARK__(CELL* ptr USES_REGS) | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-12-17 16:25:27 +00:00
										 |  |  |   Int pos = ptr - (CELL *)LOCAL_GlobalBase; | 
					
						
							|  |  |  |   char t = LOCAL_bp[pos]; | 
					
						
							|  |  |  |   LOCAL_bp[pos] = t | MARK_BIT; | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | UNMARK__(CELL* ptr USES_REGS) | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   mcell(ptr) = mcell(ptr) & ~MARK_BIT; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-05 03:06:31 +00:00
										 |  |  | /* not really that useful */ | 
					
						
							|  |  |  | #define MAY_UNMARK(X)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | #define UNMARK_CELL(X) (X)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | RMARK__(CELL* ptr USES_REGS) | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  |    mcell(ptr) = mcell(ptr) | RMARK_BIT; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | UNRMARK__(CELL* ptr USES_REGS) | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  |    mcell(ptr) = mcell(ptr) & ~RMARK_BIT; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline int | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | RMARKED__(CELL* ptr USES_REGS) | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2005-09-09 17:24:39 +00:00
										 |  |  |   return mcell(ptr) & RMARK_BIT; | 
					
						
							| 
									
										
										
										
											2004-09-16 17:29:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* is the object pointed to by ptr marked as in a relocation chain? */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if LONG_ADDRESSES
 | 
					
						
							|  |  |  | #ifdef TAG_LOW_BITS_32
 | 
					
						
							|  |  |  | #define TAG(X)         ((X) & LowTagBits)
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #ifdef TAG_64BITS
 | 
					
						
							|  |  |  | #define TAG(X)         ((X) & MKTAG(0x0,0x7))
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define TAG(X)         ((X) & 0x80000003L)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define TAG(X)         ((X) & 0x98000000L)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef CELL   *CELL_PTR; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ENVSIZE(E) 	EnvSize(((CELL *)E)[E_CP])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void  STD_PROTO(Yap_mark_variable, (CELL *)); | 
					
						
							|  |  |  | void  STD_PROTO(Yap_mark_external_reference, (CELL *)); | 
					
						
							|  |  |  | void  STD_PROTO(Yap_inc_mark_variable, (void)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |