------- Comment #24 from rakdver at atrey dot karlin dot mff dot cuni dot cz  
2006-07-13 09:03 -------
Subject: Re:  poor optimization choices when iterating over a std::string
(probably not c++-specific)

> > > However, ch isn't just copying the loop header; it is also
> > > copying the *entire body of the loop*, which nothing can fix. I call
> > > that a clear bug.
> >
> > how do you define a loop header?
> 
> I was under the impression it was just the one basic block called out
> in the .ch dump, e.g.
> 
> ;; Loop 1
> ;;  header 6, latch 5
> ;;  depth 1, level 1, outer 0
> 
> -- basic block 6 happens to contain just the code from the syntactic
> loop condition.  Andrew informs me that this is wrong, and that in
> this case the header is the entire loop, but I will come back at that
> with 'ch should never be duplicating the entire loop; if the header is
> the entire loop, it should do something more sensible, like duplicate
> just the first basic block or something.'

currently, we stop once the copied region is too large.  This means that
on "normal" loops that have a body that does something, we won't copy
whole loop.  Of course, any heuristics will have cases when it won't
perform ideally.


-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=28364

Reply via email to