From 8cda128c1eff8556505ff27117a68ad8cecaa228 Mon Sep 17 00:00:00 2001 From: "Yaxun (Sam) Liu" Date: Tue, 14 Feb 2023 09:52:42 -0500 Subject: [PATCH] [clang]Fix warning for signed conversion on LP64 Currently clang emits warning with -Wconversion for the following code on LP64 system e.g. x86_64-unknown-linux-gnu: long foo(long x) { return 1LL<isInteger() && TargetBT && + TargetBT->isInteger() && + Source->isSignedIntegerType() == Target->isSignedIntegerType()) { + return; + } + unsigned DiagID = diag::warn_impcast_integer_sign; // Traditionally, gcc has warned about this under -Wsign-compare. diff --git a/clang/test/Sema/sign-conversion.c b/clang/test/Sema/sign-conversion.c index 4b1ee75..e96ab18 100644 --- a/clang/test/Sema/sign-conversion.c +++ b/clang/test/Sema/sign-conversion.c @@ -1,8 +1,14 @@ // RUN: %clang_cc1 -fsyntax-only -verify -Wsign-conversion %s +// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -fsyntax-only -verify -Wsign-conversion %s +// RUN: %clang_cc1 -triple x86_64-pc-windows-msvc -fsyntax-only -verify -Wsign-conversion %s // PR9345: make a subgroup of -Wconversion for signedness changes void test(int x) { unsigned t0 = x; // expected-warning {{implicit conversion changes signedness}} unsigned t1 = (t0 == 5 ? x : 0); // expected-warning {{operand of ? changes signedness}} + + // Clang has special treatment for left shift of literal '1'. + // Make sure there is no diagnostics. + long t2 = 1LL << x; } -- 2.7.4