------- Comment #3 from hubicka at ucw dot cz 2008-01-07 23:46 ------- Subject: Re: New: Inlining heuristics issue
Hi, I am testing the attached patch. It simply accounts two instructions for each case label, I guess it does not make much sense to try to do something smarter until we move lowering of swithc constructs to tree level. Interestingly enough the function manages to be small when just one switch is accounted. I wonder if removing "* 2" still fixes the real testcase (ie the extreme growth is caused by too much of cascaded inlining). The inlining costs are quite biassed not taking into account the cost of address operations assuming that real work dominates the CPU time, that is probably still the case but we get to extreme side cases like this in other metricts.. Honza Index: tree-inline.c =================================================================== *** tree-inline.c (revision 131386) --- tree-inline.c (working copy) *************** estimate_num_insns_1 (tree *tp, int *wal *** 2387,2395 **** break; case SWITCH_EXPR: ! /* TODO: Cost of a switch should be derived from the number of ! branches. */ ! d->count += d->weights->switch_cost; break; /* Few special cases of expensive operations. This is useful --- 2387,2400 ---- break; case SWITCH_EXPR: ! /* Take into account cost of the switch + guess 2 conditional jumps for ! each case label. ! ! TODO: once switch expansion algorithm is sufficiently separated ! from RTL expansion, we might ask it for real cost of the switch ! construct. */ ! d->count += (d->weights->switch_cost ! + TREE_VEC_LENGTH (SWITCH_LABELS (x)) * 2); break; /* Few special cases of expensive operations. This is useful -- http://gcc.gnu.org/bugzilla/show_bug.cgi?id=34708