mirror of
https://github.com/intel/llvm.git
synced 2026-01-26 03:56:16 +08:00
Fix two crashes on value dependent expressions (shift and null-pointer check).
- Doug, please check. - PR4940. llvm-svn: 82129
This commit is contained in:
@@ -1626,6 +1626,9 @@ bool Expr::isIntegerConstantExpr(llvm::APSInt &Result, ASTContext &Ctx,
|
||||
/// integer constant expression with the value zero, or if this is one that is
|
||||
/// cast to void*.
|
||||
bool Expr::isNullPointerConstant(ASTContext &Ctx) const {
|
||||
// Ignore value dependent expressions.
|
||||
if (isValueDependent())
|
||||
return true;
|
||||
// Strip off a cast to void*, if it exists. Except in C++.
|
||||
if (const ExplicitCastExpr *CE = dyn_cast<ExplicitCastExpr>(this)) {
|
||||
if (!Ctx.getLangOptions().CPlusPlus) {
|
||||
|
||||
@@ -4339,7 +4339,8 @@ QualType Sema::CheckShiftOperands(Expr *&lex, Expr *&rex, SourceLocation Loc,
|
||||
// Sanity-check shift operands
|
||||
llvm::APSInt Right;
|
||||
// Check right/shifter operand
|
||||
if (rex->isIntegerConstantExpr(Right, Context)) {
|
||||
if (!rex->isValueDependent() &&
|
||||
rex->isIntegerConstantExpr(Right, Context)) {
|
||||
if (Right.isNegative())
|
||||
Diag(Loc, diag::warn_shift_negative) << rex->getSourceRange();
|
||||
else {
|
||||
|
||||
44
clang/test/SemaCXX/value-dependent-exprs.cpp
Normal file
44
clang/test/SemaCXX/value-dependent-exprs.cpp
Normal file
@@ -0,0 +1,44 @@
|
||||
// RUN: clang-cc -verify %s
|
||||
|
||||
template <unsigned I>
|
||||
class C0 {
|
||||
static const int iv0 = 1 << I;
|
||||
|
||||
enum {
|
||||
A = I,
|
||||
B = I + 1
|
||||
};
|
||||
|
||||
struct s0 {
|
||||
int a : I;
|
||||
int b[I];
|
||||
};
|
||||
|
||||
void f0(int *p) {
|
||||
if (p == I) {
|
||||
}
|
||||
}
|
||||
|
||||
#if 0
|
||||
// FIXME: Not sure whether we care about these.
|
||||
void f1(int *a)
|
||||
__attribute__((nonnull(1 + I)))
|
||||
__attribute__((constructor(1 + I)))
|
||||
__attribute__((destructor(1 + I)))
|
||||
__attribute__((sentinel(1 + I, 2 + I))),
|
||||
__attribute__((reqd_work_group_size(1 + I, 2 + I, 3 + I))),
|
||||
__attribute__((format_arg(1 + I))),
|
||||
__attribute__((aligned(1 + I))),
|
||||
__attribute__((regparm(1 + I)));
|
||||
|
||||
typedef int int_a0 __attribute__((address_space(1 + B)));
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
// FIXME: This doesn't work. PR4996.
|
||||
int f2() {
|
||||
return __builtin_choose_expr(I, 1, 2);
|
||||
}
|
||||
#endif
|
||||
|
||||
};
|
||||
Reference in New Issue
Block a user