On Fri, May 10, 2024 at 02:50:56PM +0200, Richard Biener wrote: > But for example a reg-reg move when optimizing for speed could have > a zero associated cost.
Sure, but this is the way things always have been. I'm sure there are ways to change things so they become slightly easier to use, but that is not what we have now (or what we ever have had). > You might argue that's a bug since there's > an actual instruction and thus at least a size cost (and decode cost) > but then I've seen too much zero cost stuff in backends (like that > combine PR causing s390 backend making address-cost zero even > though it's just "same cost"). address_cost is something else entirely. Many backends have that set to 0 btw, and that means 0, not "unknown". It means all forms of address in valid machine instructions have the same execution (or size) costs. > IMO give we're dispatching to the rtx_cost hook eventually it needs > documenting there or alternatively catching zero and adjusting its > result there. Of course cost == 0 ? 1 : cost is wrong as it makes > zero vs. one the same cost - using cost + 1 when from rtx_cost > might be more correct, at least preserving relative costs. Most things should not use rtx_cost at all, only insn_cost. Taking the "cost" of any random RTL expression makes no sense at all. Neither conceptually, nor practically: it causes many problems, and solves none. Most things already use only insn_cost, if you have the appropriate hooks implemented in your backend (all one of them even). This is so much easier to use (you only need to recognise some big categories of instructions, for a typical target core, instead of eighty different RTX codes, and the combination of them), and gives way better results. Segher