Sudharsan Veeravalli 4c97c5131f
[RISCV] Add ISel patterns for Xqcilia instructions (#135724)
This patch adds instruction selection patterns for generating the long
immediate arithmetic instructions.

We prefer generating instructions that have a 26 bit immediate to a 32
bit immediate given that both are of the same size but the former might
be easier to register allocate for. Base RISC-V arithmetic instructions
will be preferred, when applicable.
2025-04-16 06:48:56 +05:30

109 lines
3.1 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; Test that we are able to generate the Xqcilia instructions
; RUN: llc < %s -mtriple=riscv32 | FileCheck %s -check-prefix=RV32I
; RUN: llc < %s -mtriple=riscv32 -mattr=+experimental-xqcilia | FileCheck %s -check-prefix=RV32XQCILIA
define i32 @add(i32 %a, i32 %b) {
; RV32I-LABEL: add:
; RV32I: # %bb.0:
; RV32I-NEXT: lui a2, 65536
; RV32I-NEXT: add a0, a0, a2
; RV32I-NEXT: lui a2, 573
; RV32I-NEXT: addi a2, a2, -1330
; RV32I-NEXT: add a1, a1, a2
; RV32I-NEXT: and a0, a1, a0
; RV32I-NEXT: addi a0, a0, 13
; RV32I-NEXT: ret
;
; RV32XQCILIA-LABEL: add:
; RV32XQCILIA: # %bb.0:
; RV32XQCILIA-NEXT: qc.e.addi a1, a1, 2345678
; RV32XQCILIA-NEXT: qc.e.addai a0, 268435456
; RV32XQCILIA-NEXT: and a0, a0, a1
; RV32XQCILIA-NEXT: addi a0, a0, 13
; RV32XQCILIA-NEXT: ret
%addai = add i32 %a, 268435456
%add = add i32 %b, 2345678
%and = and i32 %add, %addai
%res = add i32 %and, 13
ret i32 %res
}
define i32 @and(i32 %a, i32 %b) {
; RV32I-LABEL: and:
; RV32I: # %bb.0:
; RV32I-NEXT: lui a2, 65536
; RV32I-NEXT: and a0, a0, a2
; RV32I-NEXT: lui a2, 573
; RV32I-NEXT: addi a2, a2, -1330
; RV32I-NEXT: and a1, a1, a2
; RV32I-NEXT: srl a0, a1, a0
; RV32I-NEXT: andi a0, a0, 10
; RV32I-NEXT: ret
;
; RV32XQCILIA-LABEL: and:
; RV32XQCILIA: # %bb.0:
; RV32XQCILIA-NEXT: qc.e.andi a1, a1, 2345678
; RV32XQCILIA-NEXT: qc.e.andai a0, 268435456
; RV32XQCILIA-NEXT: srl a0, a1, a0
; RV32XQCILIA-NEXT: andi a0, a0, 10
; RV32XQCILIA-NEXT: ret
%andai = and i32 %a, 268435456
%and = and i32 %b, 2345678
%srl = lshr i32 %and, %andai
%res = and i32 %srl, 10
ret i32 %res
}
define i32 @or(i32 %a, i32 %b) {
; RV32I-LABEL: or:
; RV32I: # %bb.0:
; RV32I-NEXT: lui a2, 65536
; RV32I-NEXT: or a0, a0, a2
; RV32I-NEXT: lui a2, 573
; RV32I-NEXT: addi a2, a2, -1330
; RV32I-NEXT: or a1, a1, a2
; RV32I-NEXT: add a0, a1, a0
; RV32I-NEXT: ori a0, a0, 13
; RV32I-NEXT: ret
;
; RV32XQCILIA-LABEL: or:
; RV32XQCILIA: # %bb.0:
; RV32XQCILIA-NEXT: qc.e.ori a1, a1, 2345678
; RV32XQCILIA-NEXT: qc.e.orai a0, 268435456
; RV32XQCILIA-NEXT: add a0, a0, a1
; RV32XQCILIA-NEXT: ori a0, a0, 13
; RV32XQCILIA-NEXT: ret
%orai = or i32 %a, 268435456
%or = or i32 %b, 2345678
%add = add i32 %or, %orai
%res = or i32 %add, 13
ret i32 %res
}
define i32 @xor(i32 %a, i32 %b) {
; RV32I-LABEL: xor:
; RV32I: # %bb.0:
; RV32I-NEXT: lui a2, 65536
; RV32I-NEXT: xor a0, a0, a2
; RV32I-NEXT: lui a2, 573
; RV32I-NEXT: addi a2, a2, -1330
; RV32I-NEXT: xor a1, a1, a2
; RV32I-NEXT: add a0, a1, a0
; RV32I-NEXT: xori a0, a0, 13
; RV32I-NEXT: ret
;
; RV32XQCILIA-LABEL: xor:
; RV32XQCILIA: # %bb.0:
; RV32XQCILIA-NEXT: qc.e.xori a1, a1, 2345678
; RV32XQCILIA-NEXT: qc.e.xorai a0, 268435456
; RV32XQCILIA-NEXT: add a0, a0, a1
; RV32XQCILIA-NEXT: xori a0, a0, 13
; RV32XQCILIA-NEXT: ret
%xorai = xor i32 %a, 268435456
%xor = xor i32 %b, 2345678
%add = add i32 %xor, %xorai
%res = xor i32 %add, 13
ret i32 %res
}