diff --git a/llvm/test/CodeGen/LoongArch/ir-instruction/and.ll b/llvm/test/CodeGen/LoongArch/ir-instruction/and.ll --- a/llvm/test/CodeGen/LoongArch/ir-instruction/and.ll +++ b/llvm/test/CodeGen/LoongArch/ir-instruction/and.ll @@ -424,3 +424,25 @@ %i = xor i64 %g, %h ret i64 %i } + +define i32 @and_add_lsr(i32 %x, i32 %y) { +; LA32-LABEL: and_add_lsr: +; LA32: # %bb.0: +; LA32-NEXT: ori $a2, $zero, 4095 +; LA32-NEXT: add.w $a0, $a0, $a2 +; LA32-NEXT: srli.w $a1, $a1, 20 +; LA32-NEXT: and $a0, $a1, $a0 +; LA32-NEXT: ret +; +; LA64-LABEL: and_add_lsr: +; LA64: # %bb.0: +; LA64-NEXT: ori $a2, $zero, 4095 +; LA64-NEXT: add.d $a0, $a0, $a2 +; LA64-NEXT: bstrpick.d $a1, $a1, 31, 20 +; LA64-NEXT: and $a0, $a1, $a0 +; LA64-NEXT: ret + %1 = add i32 %x, 4095 + %2 = lshr i32 %y, 20 + %r = and i32 %2, %1 + ret i32 %r +}