<p dir="ltr"><br>
On 2 Feb 2015 23:45, "Walter Bright via Digitalmars-d" <<a href="mailto:digitalmars-d@puremagic.com">digitalmars-d@puremagic.com</a>> wrote:<br>
><br>
> On 2/2/2015 2:30 PM, Johannes Pfau wrote:<br>
>><br>
>> I does: if the backend can't know that a value is known at compile time<br>
>> it cant use absolute addresses:<br>
>><br>
>> void test(ubyte* ptr)<br>
>> {<br>
>>      volatileLoad(ptr); //Can't use literal addressing might be runtime<br>
>>      value<br>
>> }<br>
>><br>
>> The context here is that pragma(address) allows avoiding one wrapper<br>
>> function. See below.<br>
><br>
><br>
> Again, that is simply an inlining issue.<br>
><br>
><br>
><br>
>> The pragma(address, 0x05) makes sure that the compiler backend always<br>
>> knows that PORTA is at 0x05.<br>
><br>
><br>
> Constant propagation and inlining do that. Both are standard optimizations that every compiler does. Adding language features on the presumption that compilers won't do that is like trying to fix the broken engine in your car by adding another engine in the trunk.<br>
><br>
><br>
><br>
>> -O mostly fixes performance problems, but adding an additional property<br>
>> function is still much uglier than declaring an extern variable with an<br>
>> address in many ways. (compiler bugs,<br>
><br>
><br>
> Language features should not be added because of compiler bugs.<br>
><br>
>> user-facing code,<br>
><br>
><br>
> Library wrapper types will be showing up more and more. How nice they are is up to the library designer.<br>
><br>
><br>
>> debug info, ...)<br>
><br>
><br>
> Symbolic debugging is always going to be an issue until there are debuggers that are better designed to work with D.<br>
></p>
<p dir="ltr">It's more a marriage than a one way street.  DMD still needs to produce the goods in order for debuggers to turn it into meaningful data. </p>
<p dir="ltr">Iain.</p>