-
Notifications
You must be signed in to change notification settings - Fork 14.9k
Open
Labels
good first issuehttps://github.com/llvm/llvm-project/contributehttps://github.com/llvm/llvm-project/contributellvm:SelectionDAGSelectionDAGISel as wellSelectionDAGISel as wellmissed-optimization
Description
It is a common idiom to check for unsigned underflow by doing a greater than compare between the difference and minuend:
#include <stdint.h>
uint64_t subIfNoUnderflow_clang(uint64_t a, uint64_t b) {
uint64_t diff = a - b;
return (diff > a)? a : diff;
}
Instead of using the carry flag, which is set by the subtraction, clang emits a compare instruction:
https://godbolt.org/z/ex5554M6P
subIfNoUnderflow_clang:
mov rax, rdi
sub rax, rsi
cmp rax, rdi
cmovae rax, rdi
ret
Ideally it should produce:
subIfNoUnderflow_ideal:
mov rax, rdi
sub rax, rsi
cmovb rax, rdi
ret
Related issues
Metadata
Metadata
Assignees
Labels
good first issuehttps://github.com/llvm/llvm-project/contributehttps://github.com/llvm/llvm-project/contributellvm:SelectionDAGSelectionDAGISel as wellSelectionDAGISel as wellmissed-optimization