Fragile ABI

Michel Fortin michel.fortin at michelf.ca
Sat Aug 18 10:55:22 PDT 2012


On 2012-08-18 14:50:54 +0000, "R Grocott" <rgrocottbugzilla at gmail.com> said:

> Hey Michel, posted this question earlier in the thread, but I think you 
> might have missed it:
> 
>> The blog post I linked only talks about rewriting vtables at 
>> dynamic-link-time. Would it be possible to implement something similar 
>> for the sizes of structs and scope-classes, and the relative address of 
>> member variables? dsimcha's post has led me to realize that without 
>> these additional features, the ABI would still be quite fragile.
> 
> Long story short: Could your proposal realistically be extended to 
> support flexible sizeofs and member-variable offsets? I figure that 
> such a system might as well stabilize the entire class ABI, rather than 
> just vtables.
> 
> I would guess that flexible sizeofs would increase the runtime cost 
> only very slightly, but flexible member-variables might be more of an 
> issue. The cost could be minimized by looking up offsets only when 
> crossing a library boundary (say, when calling a template method on an 
> extern (D_FlexibleABI) class, or accessing a protected member variable 
> of same), but would that actually be possible?

Apple's Modern Objective-C runtime has a non-fragile ABI that extends 
to member variables which works very well. It could be implemented 
pretty much the same way in D. There would a very small runtime 
overhead for accessing member variables though: each time you access a 
member you need need first to read a runtime-initialized global 
variable giving you its offset.

As for structs, you could do it the same way, but I don't think you'd 
get enough benefit to compensate the drawback in performance and 
elsewhere. To truly have non-fragile structs you'd need to disable 
almost all compile-time introspection too. That would be very 
disruptive.

So I don't think it makes sense to have non-fragile structs.

By the way, did you take a look at the benchmarks?
<http://michelf.ca/blog/2009/vtable-benchmarking/>

-- 
Michel Fortin
michel.fortin at michelf.ca
http://michelf.ca/



More information about the Digitalmars-d mailing list