assume, assert, enforce, @safe
Daniel Gibson via Digitalmars-d
digitalmars-d at puremagic.com
Thu Jul 31 15:21:46 PDT 2014
Am 31.07.2014 23:59, schrieb Walter Bright:
> On 7/31/2014 10:40 AM, Daniel Gibson wrote:
>> It's a major PITA to debug problems that only happen in release builds.
>
> Debugging optimized code was a well known problem even back in the 70's.
> Nobody has solved it, and nobody wants unoptimized code.
>
Yeah, and because of this I'd like optimizations not to cause different
behavior if at all possible to keep these kind of bugs as low as possible.
And I agree with your stance on those fine-grained optimization switches
from your other post. GCC currently has 191 flags the influence
optimization[1] (+ a version that negates them for most), and I don't
understand what most of them do, so it would be hard for me to decide
which optimizations I want and which I don't want.
However, what about an extra flag for "unsafe" optimizations?
I'd like the compiler to do inlining, replacing int multiplications with
powers of two with shifts and other "safe" optimizations that don't
change the semantics of my program (see the examples in the post you
quoted), but I *don't* want it to e.g. remove writes to memory that
isn't read afterwards or make assumptions based on assertions (that are
disabled in the current compile mode).
And maybe a warning mode that tells me about "dead"/"superfluous" code
that would be eliminated in an optimized build so I can check if that
would break anything for me in that respect without trying to understand
the asm output would be helpful.
Cheers,
Daniel
[1] according to $ gcc-4.8 --help=optimizer | grep "^ -" | wc -l
More information about the Digitalmars-d
mailing list