@@ -927,3 +927,77 @@ void foo34() {
927
927
// OGCG: %[[A_IMAG_PTR:.*]] = getelementptr inbounds nuw { float, float }, ptr %[[A_ADDR]], i32 0, i32 1
928
928
// OGCG: store float 1.000000e+00, ptr %[[A_REAL_PTR]], align 8
929
929
// OGCG: store float 2.000000e+00, ptr %[[A_IMAG_PTR]], align 4
930
+
931
+ void foo35 () {
932
+ _Float16 _Complex a;
933
+ _Float16 real = __real__ a;
934
+ }
935
+
936
+ // CIR: %[[A_ADDR:.*]] = cir.alloca !cir.complex<!cir.f16>, !cir.ptr<!cir.complex<!cir.f16>>, ["a"]
937
+ // CIR: %[[REAL_ADDR:.*]] = cir.alloca !cir.f16, !cir.ptr<!cir.f16>, ["real", init]
938
+ // CIR: %[[TMP_A:.*]] = cir.load{{.*}} %[[A_ADDR]] : !cir.ptr<!cir.complex<!cir.f16>>, !cir.complex<!cir.f16>
939
+ // CIR: %[[A_REAL:.*]] = cir.complex.real %[[TMP_A]] : !cir.complex<!cir.f16> -> !cir.f16
940
+ // CIR: %[[A_IMAG:.*]] = cir.complex.imag %[[TMP_A]] : !cir.complex<!cir.f16> -> !cir.f16
941
+ // CIR: %[[A_REAL_F32:.*]] = cir.cast(floating, %[[A_REAL]] : !cir.f16), !cir.float
942
+ // CIR: %[[A_IMAG_F32:.*]] = cir.cast(floating, %[[A_IMAG]] : !cir.f16), !cir.float
943
+ // CIR: %[[A_COMPLEX_F32:.*]] = cir.complex.create %[[A_REAL_F32]], %[[A_IMAG_F32]] : !cir.float -> !cir.complex<!cir.float>
944
+ // CIR: %[[A_REAL_F32:.*]] = cir.complex.real %[[A_COMPLEX_F32]] : !cir.complex<!cir.float> -> !cir.float
945
+ // CIR: %[[A_REAL_F16:.*]] = cir.cast(floating, %[[A_REAL_F32]] : !cir.float), !cir.f16
946
+ // CIR: cir.store{{.*}} %[[A_REAL_F16]], %[[REAL_ADDR]] : !cir.f16, !cir.ptr<!cir.f16>
947
+
948
+ // LLVM: %[[A_ADDR:.*]] = alloca { half, half }, i64 1, align 2
949
+ // LLVM: %[[REAL_ADDR:.*]] = alloca half, i64 1, align 2
950
+ // LLVM: %[[TMP_A:.*]] = load { half, half }, ptr %[[A_ADDR]], align 2
951
+ // LLVM: %[[A_REAL:.*]] = extractvalue { half, half } %[[TMP_A]], 0
952
+ // LLVM: %[[A_IMAG:.*]] = extractvalue { half, half } %[[TMP_A]], 1
953
+ // LLVM: %[[A_REAL_F32:.*]] = fpext half %[[A_REAL]] to float
954
+ // LLVM: %[[A_IMAG_F32:.*]] = fpext half %[[A_IMAG]] to float
955
+ // LLVM: %[[TMP_A_COMPLEX_F32:.*]] = insertvalue { float, float } {{.*}}, float %[[A_REAL_F32]], 0
956
+ // LLVM: %[[A_COMPLEX_F32:.*]] = insertvalue { float, float } %[[TMP_A_COMPLEX_F32]], float %[[A_IMAG_F32]], 1
957
+ // LLVM: %[[A_REAL_F16:.*]] = fptrunc float %[[A_REAL_F32]] to half
958
+ // LLVM: store half %[[A_REAL_F16]], ptr %[[REAL_ADDR]], align 2
959
+
960
+ // OGCG: %[[A_ADDR:.*]] = alloca { half, half }, align 2
961
+ // OGCG: %[[REAL_ADDR:.*]] = alloca half, align 2
962
+ // OGCG: %[[A_REAL_PTR:.*]] = getelementptr inbounds nuw { half, half }, ptr %[[A_ADDR]], i32 0, i32 0
963
+ // OGCG: %[[A_REAL:.*]] = load half, ptr %[[A_REAL_PTR]], align 2
964
+ // OGCG: %[[A_REAL_F32:.*]] = fpext half %[[A_REAL]] to float
965
+ // OGCG: %[[A_REAL_F16:.*]] = fptrunc float %[[A_REAL_F32]] to half
966
+ // OGCG: store half %[[A_REAL_F16]], ptr %[[REAL_ADDR]], align 2
967
+
968
+ void foo36 () {
969
+ _Float16 _Complex a;
970
+ _Float16 imag = __imag__ a;
971
+ }
972
+
973
+ // CIR: %[[A_ADDR:.*]] = cir.alloca !cir.complex<!cir.f16>, !cir.ptr<!cir.complex<!cir.f16>>, ["a"]
974
+ // CIR: %[[IMAG_ADDR:.*]] = cir.alloca !cir.f16, !cir.ptr<!cir.f16>, ["imag", init]
975
+ // CIR: %[[TMP_A:.*]] = cir.load{{.*}} %[[A_ADDR]] : !cir.ptr<!cir.complex<!cir.f16>>, !cir.complex<!cir.f16>
976
+ // CIR: %[[A_REAL:.*]] = cir.complex.real %[[TMP_A]] : !cir.complex<!cir.f16> -> !cir.f16
977
+ // CIR: %[[A_IMAG:.*]] = cir.complex.imag %[[TMP_A]] : !cir.complex<!cir.f16> -> !cir.f16
978
+ // CIR: %[[A_REAL_F32:.*]] = cir.cast(floating, %[[A_REAL]] : !cir.f16), !cir.float
979
+ // CIR: %[[A_IMAG_F32:.*]] = cir.cast(floating, %[[A_IMAG]] : !cir.f16), !cir.float
980
+ // CIR: %[[A_COMPLEX_F32:.*]] = cir.complex.create %[[A_REAL_F32]], %[[A_IMAG_F32]] : !cir.float -> !cir.complex<!cir.float>
981
+ // CIR: %[[A_IMAG_F32:.*]] = cir.complex.imag %[[A_COMPLEX_F32]] : !cir.complex<!cir.float> -> !cir.float
982
+ // CIR: %[[A_IMAG_F16:.*]] = cir.cast(floating, %[[A_IMAG_F32]] : !cir.float), !cir.f16
983
+ // CIR: cir.store{{.*}} %[[A_IMAG_F16]], %[[IMAG_ADDR]] : !cir.f16, !cir.ptr<!cir.f16>
984
+
985
+ // LLVM: %[[A_ADDR:.*]] = alloca { half, half }, i64 1, align 2
986
+ // LLVM: %[[IMAG_ADDR:.*]] = alloca half, i64 1, align 2
987
+ // LLVM: %[[TMP_A:.*]] = load { half, half }, ptr %[[A_ADDR]], align 2
988
+ // LLVM: %[[A_REAL:.*]] = extractvalue { half, half } %[[TMP_A]], 0
989
+ // LLVM: %[[A_IMAG:.*]] = extractvalue { half, half } %[[TMP_A]], 1
990
+ // LLVM: %[[A_REAL_F32:.*]] = fpext half %[[A_REAL]] to float
991
+ // LLVM: %[[A_IMAG_F32:.*]] = fpext half %[[A_IMAG]] to float
992
+ // LLVM: %[[TMP_A_COMPLEX_F32:.*]] = insertvalue { float, float } {{.*}}, float %[[A_REAL_F32]], 0
993
+ // LLVM: %[[A_COMPLEX_F32:.*]] = insertvalue { float, float } %[[TMP_A_COMPLEX_F32]], float %[[A_IMAG_F32]], 1
994
+ // LLVM: %[[A_IMAG_F16:.*]] = fptrunc float %[[A_IMAG_F32]] to half
995
+ // LLVM: store half %[[A_IMAG_F16]], ptr %[[IMAG_ADDR]], align 2
996
+
997
+ // OGCG: %[[A_ADDR:.*]] = alloca { half, half }, align 2
998
+ // OGCG: %[[IMAG_ADDR:.*]] = alloca half, align 2
999
+ // OGCG: %[[A_IMAG_PTR:.*]] = getelementptr inbounds nuw { half, half }, ptr %[[A_ADDR]], i32 0, i32 1
1000
+ // OGCG: %[[A_IMAG:.*]] = load half, ptr %[[A_IMAG_PTR]], align 2
1001
+ // OGCG: %[[A_IMAG_F32:.*]] = fpext half %[[A_IMAG]] to float
1002
+ // OGCG: %[[A_IMAG_F16:.*]] = fptrunc float %[[A_IMAG_F32]] to half
1003
+ // OGCG: store half %[[A_IMAG_F16]], ptr %[[IMAG_ADDR]], align 2
0 commit comments