llvm-project/llvm/test/CodeGen/AVR/sign-extension.ll
Fangrui Song 9ef1d37ffb [AVR,test] Change llc -march= to -mtriple=
Similar to 806761a7629df268c8aed49657aeccffa6bca449

-mtriple= specifies the full target triple while -march= merely sets the
architecture part of the default target triple, leaving a target triple which
may not make sense.

Therefore, -march= is error-prone and not recommended for tests without a target
triple. The issue has been benign as we recognize avr-apple-darwin as ELF instead
of rejecting it outrightly.
2024-12-15 10:26:33 -08:00

72 lines
1.4 KiB
LLVM

; RUN: llc -mtriple=avr -verify-machineinstrs < %s | FileCheck %s
define i8 @sign_extended_1_to_8(i1) {
; CHECK-LABEL: sign_extended_1_to_8
entry-block:
%1 = sext i1 %0 to i8
ret i8 %1
}
define i16 @sign_extended_1_to_16(i1) {
; CHECK-LABEL: sign_extended_1_to_16
entry-block:
%1 = sext i1 %0 to i16
ret i16 %1
}
define i16 @sign_extended_8_to_16(i8) {
; CHECK-LABEL: sign_extended_8_to_16
entry-block:
%1 = sext i8 %0 to i16
ret i16 %1
}
define i32 @sign_extended_1_to_32(i1) {
; CHECK-LABEL: sign_extended_1_to_32
entry-block:
%1 = sext i1 %0 to i32
ret i32 %1
}
define i32 @sign_extended_8_to_32(i8) {
; CHECK-LABEL: sign_extended_8_to_32
entry-block:
%1 = sext i8 %0 to i32
ret i32 %1
}
define i32 @sign_extended_16_to_32(i16) {
; CHECK-LABEL: sign_extended_16_to_32
entry-block:
%1 = sext i16 %0 to i32
ret i32 %1
}
define i64 @sign_extended_1_to_64(i1) {
; CHECK-LABEL: sign_extended_1_to_64
entry-block:
%1 = sext i1 %0 to i64
ret i64 %1
}
define i64 @sign_extended_8_to_64(i8) {
; CHECK-LABEL: sign_extended_8_to_64
entry-block:
%1 = sext i8 %0 to i64
ret i64 %1
}
define i64 @sign_extended_16_to_64(i16) {
; CHECK-LABEL: sign_extended_16_to_64
entry-block:
%1 = sext i16 %0 to i64
ret i64 %1
}
define i64 @sign_extended_32_to_64(i32) {
; CHECK-LABEL: sign_extended_32_to_64
entry-block:
%1 = sext i32 %0 to i64
ret i64 %1
}