artiq/artiq/compiler
whitequark 8a908a7656 llvm_ir_generator: do not use 'coldcc' calling convention.
First, this calling convention doesn't actually exist in OR1K
and trying to use it in Asserts build causes an UNREACHABLE.

Second, I tried to introduce it and it does not appear to produce
any measurable benefit: not only OR1K has a ton of CSRs but also
it is quite hard, if not realistically impossible, to produce
the kind of register pressure that would be relieved by sparing
a few more CSRs for our exception raising function calls, since
temporaries don't have to be preserved before a noreturn call
and spilling over ten registers across an exceptional edge
is not something that the code we care about would do.

Third, it produces measurable drawbacks: it inflates code size
of check:* functions by adding spills. Of course, this could be
alleviated by making __artiq_raise coldcc as well, but what's
the point anyway?
2016-03-29 15:19:46 +00:00
..
algorithms compiler: do not associate SSA values with iodelay even when inlining. 2015-12-25 15:02:33 +08:00
analyses compiler: implement kernel constant attributes. 2016-03-27 16:10:07 +00:00
testbench compiler: refuse to embed a function from another core device. 2016-03-18 02:01:14 +00:00
transforms llvm_ir_generator: do not use 'coldcc' calling convention. 2016-03-29 15:19:46 +00:00
validators compiler: make quoted functions independent of outer environment. 2016-03-26 20:46:45 +00:00
__init__.py compiler: pull in dependencies in more finely grained way (fixes #181). 2015-11-24 17:32:04 +08:00
asttyped.py compiler: allow specifying per-function "fast-math" flags. 2016-03-28 21:44:08 +00:00
builtins.py Implement dumb 'with parallel' (#265). 2016-02-22 13:51:08 +00:00
embedding.py compiler: allow specifying per-function "fast-math" flags. 2016-03-28 21:44:08 +00:00
iodelay.py compiler.iodelay: correctly fold max(0, [0, ]...). 2015-11-24 00:46:55 +08:00
ir.py compiler: allow specifying per-function "fast-math" flags. 2016-03-28 21:44:08 +00:00
module.py compiler: implement kernel constant attributes. 2016-03-27 16:10:07 +00:00
prelude.py Bring back target print function. 2016-03-18 04:42:06 +00:00
targets.py compiler: fix ARTIQ_DUMP_ELF. 2016-03-29 13:03:49 +00:00
types.py compiler: allow specifying per-function "fast-math" flags. 2016-03-28 21:44:08 +00:00