function-overload.cu 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. // REQUIRES: x86-registered-target
  2. // REQUIRES: nvptx-registered-target
  3. // Make sure we handle target overloads correctly. Most of this is checked in
  4. // sema, but special functions like constructors and destructors are here.
  5. //
  6. // RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -emit-llvm -o - %s \
  7. // RUN: | FileCheck -check-prefix=CHECK-BOTH -check-prefix=CHECK-HOST %s
  8. // RUN: %clang_cc1 -triple nvptx64-nvidia-cuda -fcuda-is-device -emit-llvm -o - %s \
  9. // RUN: | FileCheck -check-prefix=CHECK-BOTH -check-prefix=CHECK-DEVICE %s
  10. #include "Inputs/cuda.h"
  11. // Check constructors/destructors for D/H functions
  12. int x;
  13. struct s_cd_dh {
  14. __host__ s_cd_dh() { x = 11; }
  15. __device__ s_cd_dh() { x = 12; }
  16. };
  17. struct s_cd_hd {
  18. __host__ __device__ s_cd_hd() { x = 31; }
  19. __host__ __device__ ~s_cd_hd() { x = 32; }
  20. };
  21. // CHECK-BOTH: define void @_Z7wrapperv
  22. #if defined(__CUDA_ARCH__)
  23. __device__
  24. #else
  25. __host__
  26. #endif
  27. void wrapper() {
  28. s_cd_dh scddh;
  29. // CHECK-BOTH: call void @_ZN7s_cd_dhC1Ev(
  30. s_cd_hd scdhd;
  31. // CHECK-BOTH: call void @_ZN7s_cd_hdC1Ev
  32. // CHECK-BOTH: call void @_ZN7s_cd_hdD1Ev(
  33. }
  34. // CHECK-BOTH: ret void
  35. // Now it's time to check what's been generated for the methods we used.
  36. // CHECK-BOTH: define linkonce_odr void @_ZN7s_cd_dhC2Ev(
  37. // CHECK-HOST: store i32 11,
  38. // CHECK-DEVICE: store i32 12,
  39. // CHECK-BOTH: ret void
  40. // CHECK-BOTH: define linkonce_odr void @_ZN7s_cd_hdC2Ev(
  41. // CHECK-BOTH: store i32 31,
  42. // CHECK-BOTH: ret void
  43. // CHECK-BOTH: define linkonce_odr void @_ZN7s_cd_hdD2Ev(
  44. // CHECK-BOTH: store i32 32,
  45. // CHECK-BOTH: ret void