Currently for SVE ACLE builtins, single tests are used to verify both
clang code generation (when the feature is available) and semantic
error/warning messages (when the feature is unavailable). This
patch moves the semantic testing into dedicated Sema tests.
Details
Diff Detail
Event Timeline
clang/test/Sema/aarch64-sve-intrinsics/acle_sve_imm.cpp | ||
---|---|---|
277 | I think these are strictly already tested with the above tests which tests their range, but I guess it can't hurt to keep them. | |
413 | This isn't strictly an immediate test, but it has to live somewhere so I'm okay with it being here. | |
433 | nit: can you add a comment here that says // Test type checks on svpattern and svprfop enums. | |
436 | nit: maybe wrap this in SVE_ACLE_FUNC as well to match the rest of this file, or remove the SVE_ACLE_FUNC from the test-case below. |
Addressed nits
clang/test/Sema/aarch64-sve-intrinsics/acle_sve_bfloat.cpp | ||
---|---|---|
10 | Does it make sense to test the overloaded forms here? They weren't tested in the original files, and since the test would look like e.g. SVE_ACLE_FUNC(svcreate2,_bf16,,)(bf16, bf16), if the overload run line has +sve but not +bf16 then the overloaded form svcreate2(bf16, bf16) doesn't give an error about the intrinsic being undeclared, it gives errors about the params of test_bfloat() not being known types |
clang/test/Sema/aarch64-sve-intrinsics/acle_sve_bfloat.cpp | ||
---|---|---|
10 | Good point, I didn't realise that the bfloat types aren't available when the +bf16 attribute isn't passed in. In that case, I agree it's best to keep it as-is. |
Can you wrap these in SVE_ACLE_FUNC and add an extra RUN line? (similar to my request on D124850)