; RUN: llc < %s | FileCheck %s | |
target datalayout = "e-m:e-p:32:32-i1:8:32-i8:8:32-i16:16:32-i64:64-v128:64:128-a:0:32-n32-S64" | |
target triple = "thumbv7--linux-gnueabihf" | |
; CHECK-LABEL: f: | |
; CHECK: bic | |
define void @f(i32* nocapture %b, i32* nocapture %c, i32 %a) { | |
%1 = and i32 %a, -4096 | |
store i32 %1, i32* %c, align 4 | |
%2 = and i32 %a, 4095 | |
%3 = or i32 %2, 4096 | |
%4 = load i32, i32* %b, align 4 | |
%5 = add nsw i32 %4, %3 | |
store i32 %5, i32* %b, align 4 | |
ret void | |
} |