diff options
| author | Michael D. Adams <t-madams@microsoft.com> | 2007-06-27 15:01:33 +0000 | 
|---|---|---|
| committer | Michael D. Adams <t-madams@microsoft.com> | 2007-06-27 15:01:33 +0000 | 
| commit | 207802589da0d23c3f16195f453b24a1e46e322d (patch) | |
| tree | 2a17423ada08e5a890b17132440dda10c4f860bc /compiler/codeGen/CgProf.hs | |
| parent | bb5c3f58b1da850b68e0745766f2786e538b5fbf (diff) | |
| download | haskell-207802589da0d23c3f16195f453b24a1e46e322d.tar.gz | |
Added pointerhood to LocalReg
This version should compile but is still incomplete as it introduces
potential bugs at the places marked 'TODO FIXME NOW'.
It is being recorded to help keep track of changes.
Diffstat (limited to 'compiler/codeGen/CgProf.hs')
| -rw-r--r-- | compiler/codeGen/CgProf.hs | 26 | 
1 files changed, 13 insertions, 13 deletions
| diff --git a/compiler/codeGen/CgProf.hs b/compiler/codeGen/CgProf.hs index bc5473a6e5..3ba9d059fe 100644 --- a/compiler/codeGen/CgProf.hs +++ b/compiler/codeGen/CgProf.hs @@ -155,9 +155,9 @@ emitCCS ccs = push_em (ccsExpr ccs') (reverse cc's)  	push_em ccs [] = return ccs  	push_em ccs (cc:rest) = do -  	  tmp <- newTemp wordRep +  	  tmp <- newNonPtrTemp wordRep -- TODO FIXME NOW  	  pushCostCentre tmp ccs cc -	  push_em (CmmReg tmp) rest +	  push_em (CmmReg (CmmLocal tmp)) rest  ccsExpr :: CostCentreStack -> CmmExpr  ccsExpr ccs @@ -349,14 +349,14 @@ sizeof_ccs_words  emitRegisterCC :: CostCentre -> Code  emitRegisterCC cc = do -  { tmp <- newTemp cIntRep +  { tmp <- newNonPtrTemp cIntRep    ; stmtsC [       CmmStore (cmmOffsetB cc_lit oFFSET_CostCentre_link)  		 (CmmLoad cC_LIST wordRep),       CmmStore cC_LIST cc_lit, -     CmmAssign tmp (CmmLoad cC_ID cIntRep), -     CmmStore (cmmOffsetB cc_lit oFFSET_CostCentre_ccID) (CmmReg tmp), -     CmmStore cC_ID (cmmRegOffB tmp 1) +     CmmAssign (CmmLocal tmp) (CmmLoad cC_ID cIntRep), +     CmmStore (cmmOffsetB cc_lit oFFSET_CostCentre_ccID) (CmmReg (CmmLocal tmp)), +     CmmStore cC_ID (cmmRegOffB (CmmLocal tmp) 1)     ]    }    where @@ -368,14 +368,14 @@ emitRegisterCC cc = do  emitRegisterCCS :: CostCentreStack -> Code  emitRegisterCCS ccs = do -  { tmp <- newTemp cIntRep +  { tmp <- newNonPtrTemp cIntRep    ; stmtsC [       CmmStore (cmmOffsetB ccs_lit oFFSET_CostCentreStack_prevStack)   			(CmmLoad cCS_LIST wordRep),       CmmStore cCS_LIST ccs_lit, -     CmmAssign tmp (CmmLoad cCS_ID cIntRep), -     CmmStore (cmmOffsetB ccs_lit oFFSET_CostCentreStack_ccsID) (CmmReg tmp), -     CmmStore cCS_ID (cmmRegOffB tmp 1) +     CmmAssign (CmmLocal tmp) (CmmLoad cCS_ID cIntRep), +     CmmStore (cmmOffsetB ccs_lit oFFSET_CostCentreStack_ccsID) (CmmReg (CmmLocal tmp)), +     CmmStore cCS_ID (cmmRegOffB (CmmLocal tmp) 1)     ]    }    where @@ -395,14 +395,14 @@ emitSetCCC :: CostCentre -> Code  emitSetCCC cc    | not opt_SccProfilingOn = nopC    | otherwise = do  -    tmp <- newTemp wordRep +    tmp <- newNonPtrTemp wordRep -- TODO FIXME NOW      ASSERT( sccAbleCostCentre cc )        pushCostCentre tmp curCCS cc -    stmtC (CmmStore curCCSAddr (CmmReg tmp)) +    stmtC (CmmStore curCCSAddr (CmmReg (CmmLocal tmp)))      when (isSccCountCostCentre cc) $   	stmtC (bumpSccCount curCCS) -pushCostCentre :: CmmReg -> CmmExpr -> CostCentre -> Code +pushCostCentre :: LocalReg -> CmmExpr -> CostCentre -> Code  pushCostCentre result ccs cc    = emitRtsCallWithResult result PtrHint  	SLIT("PushCostCentre") [(ccs,PtrHint),  | 
