[PATCH] D85157: [Sema] Add casting check for fixed to fixed point conversions
Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Fri Aug 7 05:59:21 PDT 2020
This revision was automatically updated to reflect the committed changes.
Closed by commit rG351aac098543: [Sema] Add casting check for fixed to fixed point conversions (authored by vabridgers, committed by einvbri <vince.a.bridgers at ericsson.com>).
Changed prior to commit:
https://reviews.llvm.org/D85157?vs=283858&id=283887#toc
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D85157/new/
https://reviews.llvm.org/D85157
Files:
clang/lib/Sema/SemaCast.cpp
clang/test/Sema/warn-bad-function-cast.c
Index: clang/test/Sema/warn-bad-function-cast.c
===================================================================
--- clang/test/Sema/warn-bad-function-cast.c
+++ clang/test/Sema/warn-bad-function-cast.c
@@ -1,4 +1,4 @@
-// RUN: %clang_cc1 %s -fsyntax-only -Wno-unused-value -Wbad-function-cast -triple x86_64-unknown-unknown -verify
+// RUN: %clang_cc1 %s -fsyntax-only -Wno-unused-value -Wbad-function-cast -ffixed-point -triple x86_64-unknown-unknown -verify
// rdar://9103192
void vf(void);
@@ -12,15 +12,20 @@
_Bool bf(void);
char *pf1(void);
int *pf2(void);
+_Fract ff1(void);
void
foo(void)
{
+
+ /* default, no cast, should always be ok */
+ ff1();
/* Casts to void types are always OK. */
(void)vf();
(void)if1();
(void)cf();
(const void)bf();
+ (void)ff1();
/* Casts to the same type or similar types are OK. */
(int)if1();
(long)if2();
@@ -32,6 +37,7 @@
(_Bool)bf();
(void *)pf1();
(char *)pf2();
+ (_Fract) ff1();
/* All following casts issue warning */
(float)if1(); /* expected-warning {{cast from function call of type 'int' to non-matching type 'float'}} */
(double)if2(); /* expected-warning {{cast from function call of type 'char' to non-matching type 'double'}} */
@@ -43,5 +49,7 @@
(int)bf(); /* expected-warning {{cast from function call of type '_Bool' to non-matching type 'int'}} */
(__SIZE_TYPE__)pf1(); /* expected-warning {{cast from function call of type 'char *' to non-matching type 'unsigned long'}} */
(__PTRDIFF_TYPE__)pf2(); /* expected-warning {{cast from function call of type 'int *' to non-matching type 'long'}} */
+ (_Fract) if1(); /* expected-warning{{cast from function call of type 'int' to non-matching type '_Fract'}} */
+ (int)ff1(); /* expected-warning{{cast from function call of type '_Fract' to non-matching type 'int'}} */
}
Index: clang/lib/Sema/SemaCast.cpp
===================================================================
--- clang/lib/Sema/SemaCast.cpp
+++ clang/lib/Sema/SemaCast.cpp
@@ -2657,6 +2657,8 @@
return;
if (SrcType->isComplexIntegerType() && DestType->isComplexIntegerType())
return;
+ if (SrcType->isFixedPointType() && DestType->isFixedPointType())
+ return;
Self.Diag(SrcExpr.get()->getExprLoc(),
diag::warn_bad_function_cast)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D85157.283887.patch
Type: text/x-patch
Size: 2334 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20200807/58edeafe/attachment.bin>
More information about the cfe-commits
mailing list