|  | ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 | 
|  | ; RUN: llc -mtriple=xtensa -O1 -mattr=+windowed -verify-machineinstrs < %s \ | 
|  | ; RUN:   | FileCheck %s -check-prefix=XTENSA | 
|  |  | 
|  | ; Check placement of first 6 arguments in registers and 7th argument on stack | 
|  | define dso_local i32 @test1(i32 noundef %a, i32 noundef %b, i32 noundef %c, i32 noundef %d, i32 noundef %e, i32 noundef %f, ptr nocapture noundef readonly byval(i32) align 4 %p) { | 
|  | ; XTENSA-LABEL: test1: | 
|  | ; XTENSA:         .cfi_startproc | 
|  | ; XTENSA-NEXT:  # %bb.0: | 
|  | ; XTENSA-NEXT:    entry a1, 32 | 
|  | ; XTENSA-NEXT:    .cfi_def_cfa_offset 32 | 
|  | ; XTENSA-NEXT:    add a8, a7, a2 | 
|  | ; XTENSA-NEXT:    l32i a9, a1, 32 | 
|  | ; XTENSA-NEXT:    add a2, a8, a9 | 
|  | ; XTENSA-NEXT:    retw | 
|  | %l = load i32, ptr %p, align 4 | 
|  | %sum = add nsw i32 %f, %a | 
|  | %1 = add nsw i32 %sum, %l | 
|  | ret i32 %1 | 
|  | } | 
|  |  | 
|  | ; Check placement of second i64 argument in registers | 
|  | define dso_local i32 @test2(i32 noundef %a, i64 noundef %b, i32 noundef %c) { | 
|  | ; XTENSA-LABEL: test2: | 
|  | ; XTENSA:         .cfi_startproc | 
|  | ; XTENSA-NEXT:  # %bb.0: | 
|  | ; XTENSA-NEXT:    entry a1, 32 | 
|  | ; XTENSA-NEXT:    .cfi_def_cfa_offset 32 | 
|  | ; XTENSA-NEXT:    add a8, a6, a2 | 
|  | ; XTENSA-NEXT:    add a2, a8, a4 | 
|  | ; XTENSA-NEXT:    retw | 
|  | %tr = trunc i64 %b to i32 | 
|  | %sum = add nsw i32 %c, %a | 
|  | %1 = add nsw i32 %sum, %tr | 
|  | ret i32 %1 | 
|  | } | 
|  |  | 
|  | ; Check placement of first argument typeof i8 in register | 
|  | define dso_local i32 @test3(i8 noundef signext %a, i64 noundef %b, i32 noundef %c) { | 
|  | ; XTENSA-LABEL: test3: | 
|  | ; XTENSA:         .cfi_startproc | 
|  | ; XTENSA-NEXT:  # %bb.0: | 
|  | ; XTENSA-NEXT:    entry a1, 32 | 
|  | ; XTENSA-NEXT:    .cfi_def_cfa_offset 32 | 
|  | ; XTENSA-NEXT:    add a8, a2, a6 | 
|  | ; XTENSA-NEXT:    add a2, a8, a4 | 
|  | ; XTENSA-NEXT:    retw | 
|  | %tr = trunc i64 %b to i32 | 
|  | %se = sext i8 %a to i32 | 
|  | %sum = add nsw i32 %se, %c | 
|  | %1 = add nsw i32 %sum, %tr | 
|  | ret i32 %1 | 
|  | } | 
|  |  | 
|  | ; Check placement of 4th argument typeof i64 on stack | 
|  | define dso_local i32 @test4(i8 noundef signext %a, i64 noundef %b, i32 noundef %c, ptr nocapture noundef readonly byval(i64) align 8 %p) { | 
|  | ; XTENSA-LABEL: test4: | 
|  | ; XTENSA:         .cfi_startproc | 
|  | ; XTENSA-NEXT:  # %bb.0: | 
|  | ; XTENSA-NEXT:    entry a1, 32 | 
|  | ; XTENSA-NEXT:    .cfi_def_cfa_offset 32 | 
|  | ; XTENSA-NEXT:    add a8, a2, a6 | 
|  | ; XTENSA-NEXT:    add a8, a8, a4 | 
|  | ; XTENSA-NEXT:    l32i a9, a1, 32 | 
|  | ; XTENSA-NEXT:    add a2, a8, a9 | 
|  | ; XTENSA-NEXT:    retw | 
|  | %l = load i64, ptr %p, align 8 | 
|  | %tr1 = trunc i64 %b to i32 | 
|  | %tr2 = trunc i64 %l to i32 | 
|  | %se = sext i8 %a to i32 | 
|  | %sum1 = add nsw i32 %se, %c | 
|  | %sum2 = add nsw i32 %sum1, %tr1 | 
|  | %1 = add nsw i32 %sum2, %tr2 | 
|  | ret i32 %1 | 
|  | } | 
|  |  | 
|  | ; Check placement of 128 bit structure on registers | 
|  | define dso_local i32 @test5([4 x i32] %a, i32 noundef %b) { | 
|  | ; XTENSA-LABEL: test5: | 
|  | ; XTENSA:         .cfi_startproc | 
|  | ; XTENSA-NEXT:  # %bb.0: | 
|  | ; XTENSA-NEXT:    entry a1, 32 | 
|  | ; XTENSA-NEXT:    .cfi_def_cfa_offset 32 | 
|  | ; XTENSA-NEXT:    add a2, a2, a6 | 
|  | ; XTENSA-NEXT:    retw | 
|  | %ev = extractvalue [4 x i32] %a, 0 | 
|  | %1 = add nsw i32 %ev, %b | 
|  | ret i32 %1 | 
|  | } | 
|  |  | 
|  | ; Check placement of 128 bit structure on stack | 
|  | define dso_local i32 @test6(i32 noundef %a, [4 x i32] %b) { | 
|  | ; XTENSA-LABEL: test6: | 
|  | ; XTENSA:         .cfi_startproc | 
|  | ; XTENSA-NEXT:  # %bb.0: | 
|  | ; XTENSA-NEXT:    entry a1, 32 | 
|  | ; XTENSA-NEXT:    .cfi_def_cfa_offset 32 | 
|  | ; XTENSA-NEXT:    add a2, a3, a2 | 
|  | ; XTENSA-NEXT:    retw | 
|  | %ev = extractvalue [4 x i32] %b, 0 | 
|  | %1 = add nsw i32 %ev, %a | 
|  | ret i32 %1 | 
|  | } |