From 351aac09854399dfb3abb581ef1762a9cd2e4991 Mon Sep 17 00:00:00 2001 From: Vince Bridgers Date: Mon, 3 Aug 2020 15:37:59 -0500 Subject: [PATCH] [Sema] Add casting check for fixed to fixed point conversions This change squelches the warning for a cast from fixed to fixed point conversions when -Wbad-function-cast is enabled. Fixes: cast from function call of type '_Fract' to non-matching type '_Fract' [-Wbad-function-cast] Reviewed By: bjope Differential Revision: https://reviews.llvm.org/D85157 --- clang/lib/Sema/SemaCast.cpp | 2 ++ clang/test/Sema/warn-bad-function-cast.c | 10 +++++++++- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/clang/lib/Sema/SemaCast.cpp b/clang/lib/Sema/SemaCast.cpp index 58cf3a1..9375276 100644 --- a/clang/lib/Sema/SemaCast.cpp +++ b/clang/lib/Sema/SemaCast.cpp @@ -2657,6 +2657,8 @@ static void DiagnoseBadFunctionCast(Sema &Self, const ExprResult &SrcExpr, return; if (SrcType->isComplexIntegerType() && DestType->isComplexIntegerType()) return; + if (SrcType->isFixedPointType() && DestType->isFixedPointType()) + return; Self.Diag(SrcExpr.get()->getExprLoc(), diag::warn_bad_function_cast) diff --git a/clang/test/Sema/warn-bad-function-cast.c b/clang/test/Sema/warn-bad-function-cast.c index 41a3f78..1b72074 100644 --- a/clang/test/Sema/warn-bad-function-cast.c +++ b/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 @@ enum e { E1 } ef(void); _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 @@ foo(void) (_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 @@ foo(void) (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'}} */ } -- 2.7.4