From ccef9ef51073dac630247180cba0591af5382d6b Mon Sep 17 00:00:00 2001 From: Daniel Berlin Date: Mon, 16 Jul 2001 20:02:08 +0000 Subject: [PATCH] gcse.c: Update comment at top. * gcse.c: Update comment at top. Update comment on mem handling. mem_last_set, mem_first_set, mem_set_in_block: gone. Declaration of reg_set_info: gone. (oprs_unchanged_p): Don't use mem_*set_* anymore. They are pointless with load_killed_in_block_p (they are *more* conservative then it, not less, and less accurate). (oprs_not_set_p): Ditto. (alloc_gcse_mem): Don't allocate mem_set_in_block (free_gcse_mem): Don't free it, either. (record_last_mem_set_info): Update comment in front, remove mem_*set_* stuff. Note the reason we don't handle stores directly here. (compute_hash_table): Update comments to reflect reality. Remove mem_*set_* references. (reset_opr_set_tables): Remove mem_*set_* references. (mark_call): Ditto. (mark_set): Ditto. Also remove double sets of bitmaps for REG's. (mark_clobber): Ditto (on both parts, we double set here too). (expr_killed_p): Remove mem_set_in_block test. (compute_transp): Remove mem_set_in_block test. From-SVN: r44055 --- gcc/ChangeLog | 22 ++++++++++++++++ gcc/gcse.c | 70 +++------------------------------------------------ 2 files changed, 25 insertions(+), 67 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 87407cc8023..ef999bf7f7d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -28,6 +28,28 @@ Mon Jul 16 18:07:07 2001 J"orn Rennecke 2001-07-16 Daniel Berlin + * gcse.c: Update comment at top. + Update comment on mem handling. + mem_last_set, mem_first_set, mem_set_in_block: gone. + Declaration of reg_set_info: gone. + (oprs_unchanged_p): Don't use mem_*set_* anymore. They are + pointless with load_killed_in_block_p (they are *more* + conservative then it, not less, and less accurate). + (oprs_not_set_p): Ditto. + (alloc_gcse_mem): Don't allocate mem_set_in_block + (free_gcse_mem): Don't free it, either. + (record_last_mem_set_info): Update comment in front, remove + mem_*set_* stuff. Note the reason we don't handle stores directly + here. + (compute_hash_table): Update comments to reflect reality. Remove + mem_*set_* references. + (reset_opr_set_tables): Remove mem_*set_* references. + (mark_call): Ditto. + (mark_set): Ditto. Also remove double sets of bitmaps for REG's. + (mark_clobber): Ditto (on both parts, we double set here too). + (expr_killed_p): Remove mem_set_in_block test. + (compute_transp): Remove mem_set_in_block test. + * ssa-ccp.c: (optimize_unexecutable_edges): Add note about removal of edge, and removal of phi alternative to dump file. (ssa_ccp_substitute_constants): Add note about register now being diff --git a/gcc/gcse.c b/gcc/gcse.c index 9834a6b6aa6..c4fe5bb97dc 100644 --- a/gcc/gcse.c +++ b/gcc/gcse.c @@ -24,7 +24,6 @@ Boston, MA 02111-1307, USA. */ - do rough calc of how many regs are needed in each block, and a rough calc of how many regs are available in each class and use that to throttle back the code in cases where RTX_COST is minimal. - - dead store elimination - a store to the same address as a load does not kill the load if the source of the store is also the destination of the load. Handling this allows more load motion, particularly out of loops. @@ -497,16 +496,6 @@ static rtx * modify_mem_list; /* This array parallels modify_mem_list, but is kept canonicalized. */ static rtx * canon_modify_mem_list; - -/* For each block, non-zero if memory is set in that block. - This is computed during hash table computation and is used by - expr_killed_p and compute_transp. - ??? Handling of memory is very simple, we don't make any attempt - to optimize things (later). - ??? This can be computed by compute_sets since the information - doesn't change. */ -static char *mem_set_in_block; - /* Various variables for statistics gathering. */ /* Memory used in a pass. @@ -1032,7 +1021,6 @@ alloc_gcse_mem (f) /* Allocate vars to track sets of regs, memory per block. */ reg_set_in_block = (sbitmap *) sbitmap_vector_alloc (n_basic_blocks, max_gcse_regno); - mem_set_in_block = (char *) gmalloc (n_basic_blocks); /* Allocate array to keep a list of insns which modify memory in each basic block. */ modify_mem_list = (rtx *) gmalloc (n_basic_blocks * sizeof (rtx *)); @@ -1052,7 +1040,6 @@ free_gcse_mem () free (reg_set_bitmap); sbitmap_vector_free (reg_set_in_block); - free (mem_set_in_block); /* re-Cache any INSN_LIST nodes we have allocated. */ { int i; @@ -1317,15 +1304,6 @@ compute_sets (f) static int *reg_first_set; static int *reg_last_set; -/* While computing "first/last set" info, this is the CUID of first/last insn - to set memory or -1 if not set. `mem_last_set' is also used when - performing GCSE to record whether memory has been set since the beginning - of the block. - - Note that handling of memory is very simple, we don't make any attempt - to optimize things (later). */ -static int mem_first_set; -static int mem_last_set; /* See whether X, the source of a set, is something we want to consider for GCSE. */ @@ -1409,12 +1387,6 @@ oprs_unchanged_p (x, insn, avail_p) if (load_killed_in_block_p (BLOCK_FOR_INSN (insn), INSN_CUID (insn), x, avail_p)) return 0; - if (avail_p && mem_last_set != NEVER_SET - && mem_last_set >= INSN_CUID (insn)) - return 0; - else if (! avail_p && mem_first_set != NEVER_SET - && mem_first_set < INSN_CUID (insn)) - return 0; else return oprs_unchanged_p (XEXP (x, 0), insn, avail_p); @@ -2410,7 +2382,6 @@ canon_list_insert (dest, unused1, v_insn) alloc_INSN_LIST (dest, canon_modify_mem_list[BLOCK_NUM (insn)]); } -/* Record memory first/last/block set information for INSN. */ /* Record memory modification information for INSN. We do not actually care about the memory location(s) that are set, or even how they are set (consider a CALL_INSN). We merely need to record which insns modify memory. */ @@ -2419,11 +2390,8 @@ static void record_last_mem_set_info (insn) rtx insn; { - if (mem_first_set == NEVER_SET) - mem_first_set = INSN_CUID (insn); - - mem_last_set = INSN_CUID (insn); - mem_set_in_block[BLOCK_NUM (insn)] = 1; + /* load_killed_in_block_p will handle the case of calls clobbering + everything. */ modify_mem_list[BLOCK_NUM (insn)] = alloc_INSN_LIST (insn, modify_mem_list[BLOCK_NUM (insn)]); @@ -2486,12 +2454,9 @@ compute_hash_table (set_p) /* While we compute the hash table we also compute a bit array of which registers are set in which blocks. - We also compute which blocks set memory, in the absence of aliasing - support [which is TODO]. ??? This isn't needed during const/copy propagation, but it's cheap to compute. Later. */ sbitmap_vector_zero (reg_set_in_block, n_basic_blocks); - memset ((char *) mem_set_in_block, 0, n_basic_blocks); /* re-Cache any INSN_LIST nodes we have allocated. */ { @@ -2519,14 +2484,12 @@ compute_hash_table (set_p) /* First pass over the instructions records information used to determine when registers and memory are first and last set. - ??? The mem_set_in_block and hard-reg reg_set_in_block computation + ??? hard-reg reg_set_in_block computation could be moved to compute_sets since they currently don't change. */ for (i = 0; i < max_gcse_regno; i++) reg_first_set[i] = reg_last_set[i] = NEVER_SET; - mem_first_set = NEVER_SET; - mem_last_set = NEVER_SET; for (insn = BLOCK_HEAD (bb); insn && insn != NEXT_INSN (BLOCK_END (bb)); @@ -2747,7 +2710,6 @@ reset_opr_set_tables () /* Also keep a record of the last instruction to modify memory. For now this is very trivial, we only record whether any memory location has been modified. */ - mem_last_set = 0; { int i; @@ -2794,8 +2756,6 @@ oprs_not_set_p (x, insn) if (load_killed_in_block_p (BLOCK_FOR_INSN (insn), INSN_CUID (insn), x, 0)) return 0; - if (mem_last_set != 0) - return 0; else return oprs_not_set_p (XEXP (x, 0), insn); @@ -2834,7 +2794,6 @@ static void mark_call (insn) rtx insn; { - mem_last_set = INSN_CUID (insn); if (! CONST_CALL_P (insn)) record_last_mem_set_info (insn); } @@ -2858,11 +2817,6 @@ mark_set (pat, insn) else if (GET_CODE (dest) == MEM) record_last_mem_set_info (insn); - if (GET_CODE (dest) == REG) - SET_BIT (reg_set_bitmap, REGNO (dest)); - else if (GET_CODE (dest) == MEM) - mem_last_set = INSN_CUID (insn); - if (GET_CODE (SET_SRC (pat)) == CALL) mark_call (insn); } @@ -2878,10 +2832,6 @@ mark_clobber (pat, insn) while (GET_CODE (clob) == SUBREG || GET_CODE (clob) == STRICT_LOW_PART) clob = XEXP (clob, 0); - if (GET_CODE (clob) == REG) - SET_BIT (reg_set_bitmap, REGNO (clob)); - else - mem_last_set = INSN_CUID (insn); if (GET_CODE (clob) == REG) SET_BIT (reg_set_bitmap, REGNO (clob)); else @@ -3121,8 +3071,6 @@ expr_killed_p (x, bb) case MEM: if (load_killed_in_block_p (bb, get_max_uid () + 1, x, 0)) return 1; - if (mem_set_in_block[bb->index]) - return 1; else return expr_killed_p (XEXP (x, 0), bb); @@ -3825,18 +3773,6 @@ compute_transp (x, indx, bmap, set_p) list_entry = XEXP (list_entry, 1); } } - if (set_p) - { - for (bb = 0; bb < n_basic_blocks; bb++) - if (mem_set_in_block[bb]) - SET_BIT (bmap[bb], indx); - } - else - { - for (bb = 0; bb < n_basic_blocks; bb++) - if (mem_set_in_block[bb]) - RESET_BIT (bmap[bb], indx); - } x = XEXP (x, 0); goto repeat;