[Issue 5563] New: Failed/succeeded inlining listing
d-bugmail at puremagic.com
d-bugmail at puremagic.com
Fri Feb 11 03:27:50 PST 2011
http://d.puremagic.com/issues/show_bug.cgi?id=5563
Summary: Failed/succeeded inlining listing
Product: D
Version: D2
Platform: All
OS/Version: All
Status: NEW
Severity: enhancement
Priority: P2
Component: DMD
AssignedTo: nobody at puremagic.com
ReportedBy: bearophile_hugs at eml.cc
--- Comment #0 from bearophile_hugs at eml.cc 2011-02-11 03:25:22 PST ---
Inlining is one of the most important performance optimizations, so an useful
information for the programmer is a list of failed/succeeded inlining points.
See:
http://www.digitalmars.com/webnews/newsgroups.php?art_group=digitalmars.D&article_id=129206
Taking a look at the produced asm is often enough to see where inlining has
happened or not, but a list shown by the compiler is simpler and quicker to
read and understand, for external automatic tools too.
When you compile CommonLisp with max optimization levels the compiler gives
many comments that explain why it isn't optimizing something, including some
forms of inlining, see for example:
http://shootout.alioth.debian.org/u32/program.php?test=fasta&lang=sbcl&id=3
Example of the comments:
; file: /home/dunham/shootout/bench/fasta/fasta.sbcl-3.sbcl
; in: DEFUN CUMSUM
; (CEILING (* +IM+ (INCF C X)))
; --> CEILING MULTIPLE-VALUE-BIND MULTIPLE-VALUE-CALL TRUNCATE LET
; ==>
; (SB-KERNEL:%UNARY-TRUNCATE/SINGLE-FLOAT SB-C::X)
;
; note: forced to do full call
; unable to do inline float truncate (cost 5) because:
; The result is a (VALUES INTEGER &OPTIONAL), not a (VALUES
; (SIGNED-BYTE 32)
&REST
; T).
; unable to do inline float truncate (cost 5) because:
; The result is a (VALUES INTEGER &OPTIONAL), not a (VALUES
; (UNSIGNED-BYTE 32)
; &REST T).
; --> CEILING MULTIPLE-VALUE-BIND MULTIPLE-VALUE-CALL TRUNCATE LET VALUES -
; ==>
; (SB-KERNEL:%SINGLE-FLOAT SB-C::RES)
;
; note: forced to do full call
; unable to do inline float coercion (cost 5) because:
; The first argument is a INTEGER, not a (SIGNED-BYTE 32).
; unable to do inline float coercion (cost 6) because:
; The first argument is a INTEGER, not a (UNSIGNED-BYTE 32).
...
Another similar kind of useful notes from the compiler:
http://d.puremagic.com/issues/show_bug.cgi?id=5070
--
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
More information about the Digitalmars-d-bugs
mailing list