summary refs log tree commit diff
path: root/src/test/codegen/issue-83623-SIMD-PartialEq.rs
blob: b22b7f52402dde3984447014b88e09d6f2bf7c84 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
// This test checks that jumps generated by logical operators can be optimized away

// compile-flags: -Copt-level=3
// only-64bit

#![crate_type="lib"]

pub struct Blueprint {
    pub fuel_tank_size: u32,
    pub payload: u32,
    pub wheel_diameter: u32,
    pub wheel_width: u32,
    pub storage: u32,
}

// && chains should not prevent SIMD optimizations for primitives
impl PartialEq for Blueprint{
    fn eq(&self, other: &Self)->bool{
       // CHECK-NOT: call{{.*}}bcmp
       // CHECK-NOT: call{{.*}}memcmp
       // CHECK-NOT: br {{.*}}
       self.fuel_tank_size == other.fuel_tank_size
            && self.payload == other.payload
            && self.wheel_diameter == other.wheel_diameter
            && self.wheel_width == other.wheel_width
            && self.storage == other.storage
    }
}

#[derive(PartialEq)]
pub struct Blueprint2 {
    pub fuel_tank_size: u32,
    pub payload: u32,
    pub wheel_diameter: u32,
    pub wheel_width: u32,
    pub storage: u32,
}

// Derived PartialEq should not generate jumps and should use SIMD
#[no_mangle]
pub fn partial_eq_should_not_jump(a: &Blueprint2, b:&Blueprint2)->bool{
    // CHECK-NOT: call{{.*}}bcmp
    // CHECK-NOT: call{{.*}}memcmp
    // CHECK-NOT: br {{.*}}
    a==b
}