llvm-project/clang/test/CodeGen/X86/x86_64-arguments-win32.c
Antonio Frighetto 9e0c06d708 [clang][CodeGen] Set dead_on_return when passing arguments indirectly
Let Clang emit `dead_on_return` attribute on pointer arguments
that are passed indirectly, namely, large aggregates that the
ABI mandates be passed by value; thus, the parameter is destroyed
within the callee. Writes to such arguments are not observable by
the caller after the callee returns.

This should desirably enable further MemCpyOpt/DSE optimizations.

Previous discussion: https://discourse.llvm.org/t/rfc-add-dead-on-return-attribute/86871.
2025-07-18 11:50:18 +02:00

32 lines
1.1 KiB
C

// RUN: %clang_cc1 -w -triple x86_64-pc-win32 -emit-llvm -o - %s | FileCheck %s
// To be ABI compatible with code generated by MSVC, there shouldn't be any
// sign/zero extensions on types smaller than 64bit.
// CHECK-LABEL: define dso_local void @f1(i8 noundef %a)
void f1(char a) {}
// CHECK-LABEL: define dso_local void @f2(i8 noundef %a)
void f2(unsigned char a) {}
// CHECK-LABEL: define dso_local void @f3(i16 noundef %a)
void f3(short a) {}
// CHECK-LABEL: define dso_local void @f4(i16 noundef %a)
void f4(unsigned short a) {}
// For ABI compatibility with ICC, _Complex should be passed/returned
// as if it were a struct with two elements.
// CHECK-LABEL: define dso_local void @f5(i64 noundef %a.coerce)
void f5(_Complex float a) {}
// CHECK-LABEL: define dso_local void @f6(ptr dead_on_return noundef %a)
void f6(_Complex double a) {}
// CHECK-LABEL: define dso_local i64 @f7()
_Complex float f7(void) { return 1.0; }
// CHECK-LABEL: define dso_local void @f8(ptr dead_on_unwind noalias writable sret({ double, double }) align 8 %agg.result)
_Complex double f8(void) { return 1.0; }