1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
|
/* Copyright (C) 2012 Matthew Fluet.
* Copyright (C) 1999-2006 Henry Cejtin, Matthew Fluet, Suresh
* Jagannathan, and Stephen Weeks.
* Copyright (C) 1997-2000 NEC Research Institute.
*
* MLton is released under a BSD-style license.
* See the file MLton-LICENSE for details.
*/
/* getArrayLengthp (p)
*
* Returns a pointer to the length for the array pointed to by p.
*/
GC_arrayLength* getArrayLengthp (pointer a) {
return (GC_arrayLength*)(a
- GC_HEADER_SIZE
- GC_ARRAY_LENGTH_SIZE);
}
/* getArrayLength (p)
*
* Returns the length for the array pointed to by p.
*/
GC_arrayLength getArrayLength (pointer a) {
return *(getArrayLengthp (a));
}
uintmax_t GC_getArrayLength (pointer a) {
return ((uintmax_t)(getArrayLength (a)));
}
/* getArrayCounterp (p)
*
* Returns a pointer to the counter for the array pointed to by p.
*/
GC_arrayCounter* getArrayCounterp (pointer a) {
return (GC_arrayCounter*)(a
- GC_HEADER_SIZE
- GC_ARRAY_LENGTH_SIZE
- GC_ARRAY_COUNTER_SIZE);
}
/* getArrayCounter (p)
*
* Returns the counter for the array pointed to by p.
*/
GC_arrayCounter getArrayCounter (pointer a) {
return *(getArrayCounterp (a));
}
#if ASSERT
pointer indexArrayAtObjptrIndex (GC_state s, pointer a,
GC_arrayCounter arrayIndex,
uint32_t objptrIndex) {
GC_header header;
uint16_t bytesNonObjptrs;
uint16_t numObjptrs;
GC_objectTypeTag tag;
header = getHeader (a);
splitHeader(s, header, &tag, NULL, &bytesNonObjptrs, &numObjptrs);
assert (tag == ARRAY_TAG);
return a
+ (arrayIndex * (bytesNonObjptrs + (numObjptrs * OBJPTR_SIZE)))
+ bytesNonObjptrs
+ (objptrIndex * OBJPTR_SIZE);
}
#endif
|