<html><head><meta http-equiv="Content-Type" content="text/html charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><br><div><div>On Apr 10, 2013, at 3:33 PM, Chandler Carruth <<a href="mailto:chandlerc@google.com">chandlerc@google.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="font-family: Optima; font-size: medium; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; ">For folks who missed the discussion, I (and others) have pushed back against this because fundamentally the output of the compiler should be deterministic and stable, even if arbitrary. So encoding a particular arbitrary ordering, while annoying when updating, hasn't historically been a huge burden. It might be a huge burden if it occurs in a very large number of places causing very large churn on innocent changes, but so far it has only come up in a small enough number of places to not be a huge issue. (Register names on the other hand when hard coded did become such a burden, and we've moved to consistently not hard code registers where doing so doesn't make sense.)</div></blockquote></div><br><div>And now we are actively working on new scheduling models for ARM, x86, and PPC, and there is even a new MI scheduler.</div><div><br></div><div>It was a huge burden for me to fix all the hardcoded register names in test cases before switching register allocators. It will probably be just as much work for Andy to fix the hardcoded schedules. The sooner we can add this feature to FileCheck, the sooner people can start helping him with that task.</div><div><br></div><div>Stable output is vaguely defined for a rapidly evolving code generator, and it is a tertiary priority at best after code size and speed. We can test schedule stability in a handful test cases, sure, but spreading it over all 3600 codegen tests is an unreasonable maintenance burden to impose on backend developers.</div><div><br></div><div>/jakob</div><div><br></div></body></html>