mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-03 19:32:35 +00:00
Sema: Ensure that __c11_atomic_fetch_add has a pointer to complete type
Pointer arithmetic is only makes sense if the pointee type is complete. This fixes PR22361. llvm-svn: 227295
This commit is contained in:
parent
b81dfa6378
commit
e85cff84b9
@ -1404,6 +1404,11 @@ ExprResult Sema::SemaAtomicOpsOverloaded(ExprResult TheCallResult,
|
||||
<< IsC11 << Ptr->getType() << Ptr->getSourceRange();
|
||||
return ExprError();
|
||||
}
|
||||
if (IsC11 && ValType->isPointerType() &&
|
||||
RequireCompleteType(Ptr->getLocStart(), ValType->getPointeeType(),
|
||||
diag::err_incomplete_type)) {
|
||||
return ExprError();
|
||||
}
|
||||
} else if (IsN && !ValType->isIntegerType() && !ValType->isPointerType()) {
|
||||
// For __atomic_*_n operations, the value type must be a scalar integral or
|
||||
// pointer type which is 1, 2, 4, 8 or 16 bytes in length.
|
||||
|
@ -49,7 +49,7 @@ char i8;
|
||||
short i16;
|
||||
int i32;
|
||||
int __attribute__((vector_size(8))) i64;
|
||||
struct Incomplete *incomplete;
|
||||
struct Incomplete *incomplete; // expected-note {{forward declaration of 'struct Incomplete'}}
|
||||
|
||||
_Static_assert(__atomic_is_lock_free(1, &i8), "");
|
||||
_Static_assert(__atomic_is_lock_free(1, &i64), "");
|
||||
@ -268,6 +268,10 @@ void memory_checks(_Atomic(int) *Ap, int *p, int val) {
|
||||
(void)__c11_atomic_fetch_add(Ap, 1, memory_order_acq_rel);
|
||||
(void)__c11_atomic_fetch_add(Ap, 1, memory_order_seq_cst);
|
||||
|
||||
(void)__c11_atomic_fetch_add(
|
||||
(struct Incomplete * _Atomic *)0, // expected-error {{incomplete type 'struct Incomplete'}}
|
||||
1, memory_order_seq_cst);
|
||||
|
||||
(void)__c11_atomic_init(Ap, val);
|
||||
(void)__c11_atomic_init(Ap, val);
|
||||
(void)__c11_atomic_init(Ap, val);
|
||||
|
Loading…
Reference in New Issue
Block a user