Skip to content

Redundant comparisons are not eliminated #34259

@jrmuizel

Description

@jrmuizel
Bugzilla Link 34911
Version trunk
OS All
CC @sunfishcode,@rotateright

Extended Description

#include <stdlib.h>
int f(int x) {
if (x < 4)
exit(1);
if (x < 8)
exit(1);
if (x < 12)
exit(1);
if (x < 16)
exit(1);
return x + 5;
}

compiles to:

f(int): # @​f(int)
pushq %rax
cmpl $3, %edi
jle .LBB0_5
cmpl $7, %edi
jle .LBB0_5
cmpl $11, %edi
jle .LBB0_5
cmpl $15, %edi
jle .LBB0_5
addl $5, %edi
movl %edi, %eax
popq %rcx
retq
.LBB0_5:
movl $1, %edi
callq exit

compared to gcc's

f(int):
cmpl $15, %edi
jle .L7
leal 5(%rdi), %eax
ret
.L7:
subq $8, %rsp
movl $1, %edi
call exit

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions