]> git.lizzy.rs Git - rust.git/commitdiff
auto merge of #7781 : dotdash/rust/glue, r=huonw
authorbors <bors@rust-lang.org>
Sun, 14 Jul 2013 12:55:22 +0000 (05:55 -0700)
committerbors <bors@rust-lang.org>
Sun, 14 Jul 2013 12:55:22 +0000 (05:55 -0700)
We used to have concrete types in glue functions, but the way we used
to implement that broke inlining of those functions. To fix that, we
converted all glue to just take an i8* and always casted to that type.

The problem with the old implementation was that we made a wrong
assumption about the glue functions, taking it for granted that they
always take an i8*, because that's the function type expected by the
TyDesc fields. Therefore, we always ended up with some kind of cast.

But actually, we can initially have the glue with concrete types and
only cast the functions to the generic type once we actually emit the
TyDesc data.

That means that for glue calls that can be statically resolved, we don't
need any casts, unless the glue uses a simplified type. In that case we
cast the argument. And for glue calls that are resolved at runtime, we
cast the argument to i8*, because that's what the glue function in the
TyDesc expects.

Since most of out glue calls are static, this saves a lot of bitcasts.
The size of the unoptimized librustc.ll goes down by 240k lines.


Trivial merge