diff options
-rw-r--r-- | compiler/cmm/SMRep.hs | 4 | ||||
-rw-r--r-- | compiler/codeGen/StgCmmPrim.hs | 8 | ||||
-rw-r--r-- | includes/Cmm.h | 4 | ||||
-rw-r--r-- | includes/rts/storage/ClosureMacros.h | 12 | ||||
-rw-r--r-- | includes/rts/storage/Closures.h | 13 | ||||
-rw-r--r-- | rts/Adjustor.c | 6 | ||||
-rw-r--r-- | rts/CheckUnload.c | 2 | ||||
-rw-r--r-- | rts/Disassembler.c | 2 | ||||
-rw-r--r-- | rts/Interpreter.c | 4 | ||||
-rw-r--r-- | rts/PrimOps.cmm | 42 | ||||
-rw-r--r-- | rts/Printer.c | 4 | ||||
-rw-r--r-- | rts/ProfHeap.c | 2 | ||||
-rw-r--r-- | rts/sm/Compact.c | 2 | ||||
-rw-r--r-- | rts/sm/Evac.c | 2 | ||||
-rw-r--r-- | rts/sm/Sanity.c | 2 | ||||
-rw-r--r-- | rts/sm/Scav.c | 2 | ||||
-rw-r--r-- | utils/deriveConstants/DeriveConstants.hs | 6 |
17 files changed, 55 insertions, 62 deletions
diff --git a/compiler/cmm/SMRep.hs b/compiler/cmm/SMRep.hs index ca272fc984..6c0076122e 100644 --- a/compiler/cmm/SMRep.hs +++ b/compiler/cmm/SMRep.hs @@ -317,12 +317,12 @@ minClosureSize dflags = fixedHdrSizeW dflags + mIN_PAYLOAD_SIZE dflags arrWordsHdrSize :: DynFlags -> ByteOff arrWordsHdrSize dflags - = fixedHdrSize dflags + sIZEOF_StgArrWords_NoHdr dflags + = fixedHdrSize dflags + sIZEOF_StgArrBytes_NoHdr dflags arrWordsHdrSizeW :: DynFlags -> WordOff arrWordsHdrSizeW dflags = fixedHdrSizeW dflags + - (sIZEOF_StgArrWords_NoHdr dflags `quot` wORD_SIZE dflags) + (sIZEOF_StgArrBytes_NoHdr dflags `quot` wORD_SIZE dflags) arrPtrsHdrSize :: DynFlags -> ByteOff arrPtrsHdrSize dflags diff --git a/compiler/codeGen/StgCmmPrim.hs b/compiler/codeGen/StgCmmPrim.hs index e7b709f5ba..4400d72639 100644 --- a/compiler/codeGen/StgCmmPrim.hs +++ b/compiler/codeGen/StgCmmPrim.hs @@ -318,17 +318,17 @@ emitPrimOp dflags [] WriteMutVarOp [mutv,var] [(CmmReg (CmmGlobal BaseReg), AddrHint), (mutv,AddrHint)] -- #define sizzeofByteArrayzh(r,a) \ --- r = ((StgArrWords *)(a))->bytes +-- r = ((StgArrBytes *)(a))->bytes emitPrimOp dflags [res] SizeofByteArrayOp [arg] = emit $ mkAssign (CmmLocal res) (cmmLoadIndexW dflags arg (fixedHdrSizeW dflags) (bWord dflags)) -- #define sizzeofMutableByteArrayzh(r,a) \ --- r = ((StgArrWords *)(a))->bytes +-- r = ((StgArrBytes *)(a))->bytes emitPrimOp dflags [res] SizeofMutableByteArrayOp [arg] = emitPrimOp dflags [res] SizeofByteArrayOp [arg] -- #define getSizzeofMutableByteArrayzh(r,a) \ --- r = ((StgArrWords *)(a))->bytes +-- r = ((StgArrBytes *)(a))->bytes emitPrimOp dflags [res] GetSizeofMutableByteArrayOp [arg] = emitAssign (CmmLocal res) (cmmLoadIndexW dflags arg (fixedHdrSizeW dflags) (bWord dflags)) @@ -1640,7 +1640,7 @@ doNewByteArrayOp res_r n = do base <- allocHeapClosure rep info_ptr curCCS [ (mkIntExpr dflags n, - hdr_size + oFFSET_StgArrWords_bytes dflags) + hdr_size + oFFSET_StgArrBytes_bytes dflags) ] emit $ mkAssign (CmmLocal res_r) base diff --git a/includes/Cmm.h b/includes/Cmm.h index 908a3763ca..20d6e56228 100644 --- a/includes/Cmm.h +++ b/includes/Cmm.h @@ -540,10 +540,10 @@ -------------------------------------------------------------------------- */ /* The offset of the payload of an array */ -#define BYTE_ARR_CTS(arr) ((arr) + SIZEOF_StgArrWords) +#define BYTE_ARR_CTS(arr) ((arr) + SIZEOF_StgArrBytes) /* The number of words allocated in an array payload */ -#define BYTE_ARR_WDS(arr) ROUNDUP_BYTES_TO_WDS(StgArrWords_bytes(arr)) +#define BYTE_ARR_WDS(arr) ROUNDUP_BYTES_TO_WDS(StgArrBytes_bytes(arr)) /* Getting/setting the info pointer of a closure */ #define SET_INFO(p,info) StgHeader_info(p) = info diff --git a/includes/rts/storage/ClosureMacros.h b/includes/rts/storage/ClosureMacros.h index 64e549a641..a914059a5c 100644 --- a/includes/rts/storage/ClosureMacros.h +++ b/includes/rts/storage/ClosureMacros.h @@ -314,13 +314,13 @@ EXTERN_INLINE StgOffset pap_sizeW( StgPAP* x ); EXTERN_INLINE StgOffset pap_sizeW( StgPAP* x ) { return PAP_sizeW(x->n_args); } -EXTERN_INLINE StgWord arr_words_words( StgArrWords* x); -EXTERN_INLINE StgWord arr_words_words( StgArrWords* x) +EXTERN_INLINE StgWord arr_words_words( StgArrBytes* x); +EXTERN_INLINE StgWord arr_words_words( StgArrBytes* x) { return ROUNDUP_BYTES_TO_WDS(x->bytes); } -EXTERN_INLINE StgOffset arr_words_sizeW( StgArrWords* x ); -EXTERN_INLINE StgOffset arr_words_sizeW( StgArrWords* x ) -{ return sizeofW(StgArrWords) + arr_words_words(x); } +EXTERN_INLINE StgOffset arr_words_sizeW( StgArrBytes* x ); +EXTERN_INLINE StgOffset arr_words_sizeW( StgArrBytes* x ) +{ return sizeofW(StgArrBytes) + arr_words_words(x); } EXTERN_INLINE StgOffset mut_arr_ptrs_sizeW( StgMutArrPtrs* x ); EXTERN_INLINE StgOffset mut_arr_ptrs_sizeW( StgMutArrPtrs* x ) @@ -381,7 +381,7 @@ closure_sizeW_ (StgClosure *p, StgInfoTable *info) case IND_PERM: return sizeofW(StgInd); case ARR_WORDS: - return arr_words_sizeW((StgArrWords *)p); + return arr_words_sizeW((StgArrBytes *)p); case MUT_ARR_PTRS_CLEAN: case MUT_ARR_PTRS_DIRTY: case MUT_ARR_PTRS_FROZEN: diff --git a/includes/rts/storage/Closures.h b/includes/rts/storage/Closures.h index d872868a86..2ce1a27b23 100644 --- a/includes/rts/storage/Closures.h +++ b/includes/rts/storage/Closures.h @@ -135,18 +135,11 @@ typedef struct StgBlockingQueue_ { struct MessageBlackHole_ *queue; } StgBlockingQueue; -/* This struct should be called StgArrBytes rather than StgArrWords. - * - * One might be very tempted to store the number of words in the bytes field, - * but the garbage collector will erase your data then. - * - * It's name is for historical reasons, see #3800 - */ typedef struct { StgHeader header; StgWord bytes; StgWord payload[FLEXIBLE_ARRAY]; -} StgArrWords; // TODO: s/StgArrWords/StgArrBytes (#8552) +} StgArrBytes; typedef struct { StgHeader header; @@ -243,8 +236,8 @@ typedef struct _StgCFinalizerList { typedef struct { StgHeader header; - StgArrWords *instrs; /* a pointer to an ArrWords */ - StgArrWords *literals; /* a pointer to an ArrWords */ + StgArrBytes *instrs; /* a pointer to an ArrWords */ + StgArrBytes *literals; /* a pointer to an ArrWords */ StgMutArrPtrs *ptrs; /* a pointer to a MutArrPtrs */ StgHalfWord arity; /* arity of this BCO */ StgHalfWord size; /* size of this BCO (in words) */ diff --git a/rts/Adjustor.c b/rts/Adjustor.c index 83d5a73cf5..ca157661e8 100644 --- a/rts/Adjustor.c +++ b/rts/Adjustor.c @@ -250,15 +250,15 @@ typedef struct _IA64FunDesc { static void * stgAllocStable(size_t size_in_bytes, StgStablePtr *stable) { - StgArrWords* arr; + StgArrBytes* arr; nat data_size_in_words, total_size_in_words; /* round up to a whole number of words */ data_size_in_words = ROUNDUP_BYTES_TO_WDS(size_in_bytes); - total_size_in_words = sizeofW(StgArrWords) + data_size_in_words; + total_size_in_words = sizeofW(StgArrBytes) + data_size_in_words; /* allocate and fill it in */ - arr = (StgArrWords *)allocate(total_size_in_words); + arr = (StgArrBytes *)allocate(total_size_in_words); SET_ARR_HDR(arr, &stg_ARR_WORDS_info, CCCS, size_in_bytes); /* obtain a stable ptr */ diff --git a/rts/CheckUnload.c b/rts/CheckUnload.c index 34f976db4d..7802754445 100644 --- a/rts/CheckUnload.c +++ b/rts/CheckUnload.c @@ -188,7 +188,7 @@ static void searchHeapBlocks (HashTable *addrs, bdescr *bd) case ARR_WORDS: prim = rtsTrue; - size = arr_words_sizeW((StgArrWords*)p); + size = arr_words_sizeW((StgArrBytes*)p); break; case MUT_ARR_PTRS_CLEAN: diff --git a/rts/Disassembler.c b/rts/Disassembler.c index f6e2c93b82..7e3529bb7f 100644 --- a/rts/Disassembler.c +++ b/rts/Disassembler.c @@ -33,7 +33,7 @@ disInstr ( StgBCO *bco, int pc ) StgWord16* instrs = (StgWord16*)(bco->instrs->payload); - StgArrWords* literal_arr = bco->literals; + StgArrBytes* literal_arr = bco->literals; StgWord* literals = (StgWord*)(&literal_arr->payload[0]); StgMutArrPtrs* ptrs_arr = bco->ptrs; diff --git a/rts/Interpreter.c b/rts/Interpreter.c index 8a608ec1ba..573e4991f7 100644 --- a/rts/Interpreter.c +++ b/rts/Interpreter.c @@ -843,7 +843,7 @@ run_BCO: case bci_BRK_FUN: { int arg1_brk_array, arg2_array_index, arg3_freeVars; - StgArrWords *breakPoints; + StgArrBytes *breakPoints; int returning_from_break; // are we resuming execution from a breakpoint? // if yes, then don't break this time around StgClosure *ioAction; // the io action to run at a breakpoint @@ -864,7 +864,7 @@ run_BCO: // and continue executing if (!returning_from_break) { - breakPoints = (StgArrWords *) BCO_PTR(arg1_brk_array); + breakPoints = (StgArrBytes *) BCO_PTR(arg1_brk_array); // stop the current thread if either the // "rts_stop_next_breakpoint" flag is true OR if the diff --git a/rts/PrimOps.cmm b/rts/PrimOps.cmm index 26a67167bc..f44519d4d3 100644 --- a/rts/PrimOps.cmm +++ b/rts/PrimOps.cmm @@ -57,11 +57,11 @@ stg_newByteArrayzh ( W_ n ) MAYBE_GC_N(stg_newByteArrayzh, n); payload_words = ROUNDUP_BYTES_TO_WDS(n); - words = BYTES_TO_WDS(SIZEOF_StgArrWords) + payload_words; + words = BYTES_TO_WDS(SIZEOF_StgArrBytes) + payload_words; ("ptr" p) = ccall allocate(MyCapability() "ptr",words); - TICK_ALLOC_PRIM(SIZEOF_StgArrWords,WDS(payload_words),0); + TICK_ALLOC_PRIM(SIZEOF_StgArrBytes,WDS(payload_words),0); SET_HDR(p, stg_ARR_WORDS_info, CCCS); - StgArrWords_bytes(p) = n; + StgArrBytes_bytes(p) = n; return (p); } @@ -80,7 +80,7 @@ stg_newPinnedByteArrayzh ( W_ n ) payload_words = ROUNDUP_BYTES_TO_WDS(bytes); /* When we actually allocate memory, we need to allow space for the header: */ - bytes = bytes + SIZEOF_StgArrWords; + bytes = bytes + SIZEOF_StgArrBytes; /* And we want to align to BA_ALIGN bytes, so we need to allow space to shift up to BA_ALIGN - 1 bytes: */ bytes = bytes + BA_ALIGN - 1; @@ -88,14 +88,14 @@ stg_newPinnedByteArrayzh ( W_ n ) words = ROUNDUP_BYTES_TO_WDS(bytes); ("ptr" p) = ccall allocatePinned(MyCapability() "ptr", words); - TICK_ALLOC_PRIM(SIZEOF_StgArrWords,WDS(payload_words),0); + TICK_ALLOC_PRIM(SIZEOF_StgArrBytes,WDS(payload_words),0); /* Now we need to move p forward so that the payload is aligned to BA_ALIGN bytes: */ - p = p + ((-p - SIZEOF_StgArrWords) & BA_MASK); + p = p + ((-p - SIZEOF_StgArrBytes) & BA_MASK); SET_HDR(p, stg_ARR_WORDS_info, CCCS); - StgArrWords_bytes(p) = n; + StgArrBytes_bytes(p) = n; return (p); } @@ -118,7 +118,7 @@ stg_newAlignedPinnedByteArrayzh ( W_ n, W_ alignment ) /* When we actually allocate memory, we need to allow space for the header: */ - bytes = bytes + SIZEOF_StgArrWords; + bytes = bytes + SIZEOF_StgArrBytes; /* And we want to align to <alignment> bytes, so we need to allow space to shift up to <alignment - 1> bytes: */ bytes = bytes + alignment - 1; @@ -126,15 +126,15 @@ stg_newAlignedPinnedByteArrayzh ( W_ n, W_ alignment ) words = ROUNDUP_BYTES_TO_WDS(bytes); ("ptr" p) = ccall allocatePinned(MyCapability() "ptr", words); - TICK_ALLOC_PRIM(SIZEOF_StgArrWords,WDS(payload_words),0); + TICK_ALLOC_PRIM(SIZEOF_StgArrBytes,WDS(payload_words),0); /* Now we need to move p forward so that the payload is aligned to <alignment> bytes. Note that we are assuming that <alignment> is a power of 2, which is technically not guaranteed */ - p = p + ((-p - SIZEOF_StgArrWords) & (alignment - 1)); + p = p + ((-p - SIZEOF_StgArrBytes) & (alignment - 1)); SET_HDR(p, stg_ARR_WORDS_info, CCCS); - StgArrWords_bytes(p) = n; + StgArrBytes_bytes(p) = n; return (p); } @@ -143,11 +143,11 @@ stg_shrinkMutableByteArrayzh ( gcptr mba, W_ new_size ) // MutableByteArray# s -> Int# -> State# s -> State# s { ASSERT(new_size >= 0); - ASSERT(new_size <= StgArrWords_bytes(mba)); + ASSERT(new_size <= StgArrBytes_bytes(mba)); - OVERWRITING_CLOSURE_OFS(mba, (BYTES_TO_WDS(SIZEOF_StgArrWords) + + OVERWRITING_CLOSURE_OFS(mba, (BYTES_TO_WDS(SIZEOF_StgArrBytes) + ROUNDUP_BYTES_TO_WDS(new_size))); - StgArrWords_bytes(mba) = new_size; + StgArrBytes_bytes(mba) = new_size; LDV_RECORD_CREATE(mba); return (); @@ -169,9 +169,9 @@ stg_resizzeMutableByteArrayzh ( gcptr mba, W_ new_size ) new_size_wds = ROUNDUP_BYTES_TO_WDS(new_size); if (new_size_wds <= BYTE_ARR_WDS(mba)) { - OVERWRITING_CLOSURE_OFS(mba, (BYTES_TO_WDS(SIZEOF_StgArrWords) + + OVERWRITING_CLOSURE_OFS(mba, (BYTES_TO_WDS(SIZEOF_StgArrBytes) + new_size_wds)); - StgArrWords_bytes(mba) = new_size; + StgArrBytes_bytes(mba) = new_size; LDV_RECORD_CREATE(mba); return (mba); @@ -186,7 +186,7 @@ stg_resizzeMutableByteArrayzh ( gcptr mba, W_ new_size ) // copy over old content prim %memcpy(BYTE_ARR_CTS(new_mba), BYTE_ARR_CTS(mba), - StgArrWords_bytes(mba), SIZEOF_W); + StgArrBytes_bytes(mba), SIZEOF_W); return (new_mba); } @@ -199,7 +199,7 @@ stg_casIntArrayzh( gcptr arr, W_ ind, W_ old, W_ new ) { W_ p, h; - p = arr + SIZEOF_StgArrWords + WDS(ind); + p = arr + SIZEOF_StgArrBytes + WDS(ind); (h) = ccall cas(p, old, new); return(h); @@ -1927,7 +1927,7 @@ stg_newBCOzh ( P_ instrs, i = 0; for: if (i < BYTE_ARR_WDS(bitmap_arr)) { - StgBCO_bitmap(bco,i) = StgArrWords_payload(bitmap_arr,i); + StgBCO_bitmap(bco,i) = StgArrBytes_payload(bitmap_arr,i); i = i + 1; goto for; } @@ -1988,7 +1988,7 @@ stg_unpackClosurezh ( P_ closure ) out: W_ ptrs_arr_sz, ptrs_arr_cards, nptrs_arr_sz; - nptrs_arr_sz = SIZEOF_StgArrWords + WDS(nptrs); + nptrs_arr_sz = SIZEOF_StgArrBytes + WDS(nptrs); ptrs_arr_cards = mutArrPtrsCardWords(ptrs); ptrs_arr_sz = SIZEOF_StgMutArrPtrs + WDS(ptrs) + WDS(ptrs_arr_cards); @@ -2016,7 +2016,7 @@ for: is promoted. */ SET_HDR(nptrs_arr, stg_ARR_WORDS_info, CCCS); - StgArrWords_bytes(nptrs_arr) = WDS(nptrs); + StgArrBytes_bytes(nptrs_arr) = WDS(nptrs); p = 0; for2: if(p < nptrs) { diff --git a/rts/Printer.c b/rts/Printer.c index 2396707aae..637cd9a861 100644 --- a/rts/Printer.c +++ b/rts/Printer.c @@ -297,8 +297,8 @@ printClosure( StgClosure *obj ) { StgWord i; debugBelch("ARR_WORDS(\""); - for (i=0; i<arr_words_words((StgArrWords *)obj); i++) - debugBelch("%" FMT_Word, (W_)((StgArrWords *)obj)->payload[i]); + for (i=0; i<arr_words_words((StgArrBytes *)obj); i++) + debugBelch("%" FMT_Word, (W_)((StgArrBytes *)obj)->payload[i]); debugBelch("\")\n"); break; } diff --git a/rts/ProfHeap.c b/rts/ProfHeap.c index 25112a7e1e..0259a191eb 100644 --- a/rts/ProfHeap.c +++ b/rts/ProfHeap.c @@ -1023,7 +1023,7 @@ heapCensusChain( Census *census, bdescr *bd ) case ARR_WORDS: prim = rtsTrue; - size = arr_words_sizeW((StgArrWords*)p); + size = arr_words_sizeW((StgArrBytes*)p); break; case MUT_ARR_PTRS_CLEAN: diff --git a/rts/sm/Compact.c b/rts/sm/Compact.c index 4ee88da11c..81bf036f83 100644 --- a/rts/sm/Compact.c +++ b/rts/sm/Compact.c @@ -670,7 +670,7 @@ thread_obj (StgInfoTable *info, StgPtr p) return thread_AP((StgAP *)p); case ARR_WORDS: - return p + arr_words_sizeW((StgArrWords *)p); + return p + arr_words_sizeW((StgArrBytes *)p); case MUT_ARR_PTRS_CLEAN: case MUT_ARR_PTRS_DIRTY: diff --git a/rts/sm/Evac.c b/rts/sm/Evac.c index bc8cb9ad13..579e788535 100644 --- a/rts/sm/Evac.c +++ b/rts/sm/Evac.c @@ -684,7 +684,7 @@ loop: case ARR_WORDS: // just copy the block - copy(p,info,q,arr_words_sizeW((StgArrWords *)q),gen_no); + copy(p,info,q,arr_words_sizeW((StgArrBytes *)q),gen_no); return; case MUT_ARR_PTRS_CLEAN: diff --git a/rts/sm/Sanity.c b/rts/sm/Sanity.c index e7a8401145..2541ba15a2 100644 --- a/rts/sm/Sanity.c +++ b/rts/sm/Sanity.c @@ -388,7 +388,7 @@ checkClosure( StgClosure* p ) } case ARR_WORDS: - return arr_words_sizeW((StgArrWords *)p); + return arr_words_sizeW((StgArrBytes *)p); case MUT_ARR_PTRS_CLEAN: case MUT_ARR_PTRS_DIRTY: diff --git a/rts/sm/Scav.c b/rts/sm/Scav.c index dfad0bef58..c441a3d3cc 100644 --- a/rts/sm/Scav.c +++ b/rts/sm/Scav.c @@ -637,7 +637,7 @@ scavenge_block (bdescr *bd) case ARR_WORDS: // nothing to follow - p += arr_words_sizeW((StgArrWords *)p); + p += arr_words_sizeW((StgArrBytes *)p); break; case MUT_ARR_PTRS_CLEAN: diff --git a/utils/deriveConstants/DeriveConstants.hs b/utils/deriveConstants/DeriveConstants.hs index 65635506e2..00a9c1a4ed 100644 --- a/utils/deriveConstants/DeriveConstants.hs +++ b/utils/deriveConstants/DeriveConstants.hs @@ -412,9 +412,9 @@ wanteds = concat ,closureSize Both "StgSmallMutArrPtrs" ,closureField Both "StgSmallMutArrPtrs" "ptrs" - ,closureSize Both "StgArrWords" - ,closureField Both "StgArrWords" "bytes" - ,closurePayload C "StgArrWords" "payload" + ,closureSize Both "StgArrBytes" + ,closureField Both "StgArrBytes" "bytes" + ,closurePayload C "StgArrBytes" "payload" ,closureField C "StgTSO" "_link" ,closureField C "StgTSO" "global_link" |