mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-08 03:30:22 +00:00
a017ce21ba
Revert "Remove default in fully-covered switch (to fix Clang -Werror -Wcovered-switch-default)" Revert "R600: Add carry and borrow instructions. Use them to implement UADDO/USUBO" Revert "LegalizeDAG: Try to use Overflow operations when expanding ADD/SUB" Using overflow operations fails CodeGen/Generic/2011-07-07-ScheduleDAGCrash.ll on hexagon, nvptx, and r600. Revert while I investigate. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@234768 91177308-0d34-0410-b5e6-96231b3b80d8
20 lines
553 B
LLVM
20 lines
553 B
LLVM
; RUN: llc < %s -march=nvptx -mcpu=sm_20 | FileCheck %s
|
|
|
|
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v16:16:16-v32:32:32-v64:64:64-v128:128:128-n16:32:64"
|
|
|
|
|
|
|
|
define void @foo(i64 %a, i64 %add, i128* %retptr) {
|
|
; CHECK: add.s64
|
|
; CHECK: setp.lt.u64
|
|
; CHECK: setp.lt.u64
|
|
; CHECK: selp.b64
|
|
; CHECK: selp.b64
|
|
; CHECK: add.s64
|
|
%t1 = sext i64 %a to i128
|
|
%add2 = zext i64 %add to i128
|
|
%val = add i128 %t1, %add2
|
|
store i128 %val, i128* %retptr
|
|
ret void
|
|
}
|