Ayke van Laethem 131cddcba2
[AVR] Fix broken bitcast for aliases in non-zero address space
This was triggered by some code in picolibc. The minimal version looks
like this:

    double infinity(void) {
       return 5;
    }

    extern long double infinityl() __attribute__((__alias__("infinity")));

These two declarations have a different type (not because of the 'long
double', which is also 'double' in IR, but because infinityl has
variadic parameters). This led to a crash in the bitcast which assumed
address space 0.

Differential Revision: https://reviews.llvm.org/D138681
2022-11-27 15:27:42 +01:00

14 lines
479 B
C

// RUN: %clang_cc1 -triple avr-unknown-unknown -emit-llvm -o - %s | FileCheck %s
int mul(int a, int b) {
return a * b;
}
// CHECK: @multiply ={{.*}} alias i16 (i16, i16), ptr addrspace(1) @mul
int multiply(int x, int y) __attribute__((alias("mul")));
// Make sure the correct address space is used when creating an alias that needs
// a pointer cast.
// CHECK: @smallmul = alias i8 (i16, i16), ptr addrspace(1) @mul
char smallmul(int a, int b) __attribute__((alias("mul")));