1 /* Copyright (C) 2012,2016 Matthew Fluet.
2 * Copyright (C) 1999-2007 Henry Cejtin, Matthew Fluet, Suresh
3 * Jagannathan, and Stephen Weeks.
4 * Copyright (C) 1997-2000 NEC Research Institute.
6 * MLton is released under a BSD-style license.
7 * See the file MLton-LICENSE for details.
10 #if (defined (MLTON_GC_INTERNAL_TYPES))
13 * Array objects have the following layout:
18 * ( (non heap-pointers)* :: (heap pointers)* )*
20 * The counter word is used by mark compact GC. The length word is
21 * the number of elements in the array. Array elements have the same
22 * individual layout as normal objects, omitting the header word.
25 #define GC_ARRLEN_TYPE__(z) uint ## z ## _t
26 #define GC_ARRLEN_TYPE_(z) GC_ARRLEN_TYPE__(z)
27 #define GC_ARRLEN_TYPE GC_ARRLEN_TYPE_(GC_MODEL_ARRLEN_SIZE)
28 typedef GC_ARRLEN_TYPE GC_arrayLength
;
29 #define GC_ARRAY_LENGTH_SIZE sizeof(GC_arrayLength)
30 #define PRIxARRLEN__(z) PRIx ## z
31 #define PRIxARRLEN_(z) PRIxARRLEN__(z)
32 #define PRIxARRLEN PRIxARRLEN_(GC_MODEL_ARRLEN_SIZE)
33 #define FMTARRLEN "%"PRIxARRLEN
34 typedef GC_arrayLength GC_arrayCounter
;
35 #define GC_ARRAY_COUNTER_SIZE sizeof(GC_arrayCounter)
36 #define PRIxARRCTR PRIxARRLEN
37 #define FMTARRCTR "%"PRIxARRCTR
38 #define GC_ARRAY_METADATA_SIZE (GC_ARRAY_COUNTER_SIZE + GC_ARRAY_LENGTH_SIZE + GC_HEADER_SIZE)
40 COMPILE_TIME_ASSERT(sizeof_header__le__sizeof_arrlen
,
41 sizeof(GC_header
) <= sizeof(GC_arrayLength
));
42 COMPILE_TIME_ASSERT(sizeof_arrlen__eq__sizeof_arrctr
,
43 sizeof(GC_arrayLength
) == sizeof(GC_arrayCounter
));
46 #endif /* (defined (MLTON_GC_INTERNAL_TYPES)) */
48 #if (defined (MLTON_GC_INTERNAL_FUNCS))
50 static inline GC_arrayLength
* getArrayLengthp (pointer a
);
51 static inline GC_arrayLength
getArrayLength (pointer a
);
52 static inline GC_arrayCounter
* getArrayCounterp (pointer a
);
53 static inline GC_arrayCounter
getArrayCounter (pointer a
);
56 static inline pointer
indexArrayAtObjptrIndex (GC_state s
, pointer a
,
57 GC_arrayCounter arrayIndex
,
58 uint32_t objptrIndex
);
61 #endif /* (defined (MLTON_GC_INTERNAL_FUNCS)) */
63 PRIVATE
uintmax_t GC_getArrayLength (pointer a
);
64 PRIVATE
void GC_arrayCopy (GC_state s
, pointer ad
, size_t ds
, pointer as
, size_t ss
, size_t l
);