mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-26 20:46:05 +00:00

This reverts commit 6911114d8cbed06a8a809c34ae07f4e3e89ab252. Broke the QEMU sanitizer bots due to a missing header dependency. This actually needs to be fixed on the bot-side, but for now reverting this patch until I can fix up the bot.
41 lines
1.3 KiB
C++
41 lines
1.3 KiB
C++
// RUN: %clangxx_scudo -fsized-deallocation %s -o %t
|
|
// RUN: %env_scudo_opts=DeleteSizeMismatch=1 %run %t gooddel 2>&1
|
|
// RUN: %env_scudo_opts=DeleteSizeMismatch=1 not %run %t baddel 2>&1 | FileCheck %s
|
|
// RUN: %env_scudo_opts=DeleteSizeMismatch=0 %run %t baddel 2>&1
|
|
// RUN: %env_scudo_opts=DeleteSizeMismatch=1 %run %t gooddelarr 2>&1
|
|
// RUN: %env_scudo_opts=DeleteSizeMismatch=1 not %run %t baddelarr 2>&1 | FileCheck %s
|
|
// RUN: %env_scudo_opts=DeleteSizeMismatch=0 %run %t baddelarr 2>&1
|
|
|
|
// Ensures that the sized delete operator errors out when the appropriate
|
|
// option is passed and the sizes do not match between allocation and
|
|
// deallocation functions.
|
|
|
|
#include <assert.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
#include <new>
|
|
|
|
int main(int argc, char **argv) {
|
|
assert(argc == 2);
|
|
if (!strcmp(argv[1], "gooddel")) {
|
|
long long *p = new long long;
|
|
operator delete(p, sizeof(long long));
|
|
}
|
|
if (!strcmp(argv[1], "baddel")) {
|
|
long long *p = new long long;
|
|
operator delete(p, 2);
|
|
}
|
|
if (!strcmp(argv[1], "gooddelarr")) {
|
|
char *p = new char[64];
|
|
operator delete[](p, 64);
|
|
}
|
|
if (!strcmp(argv[1], "baddelarr")) {
|
|
char *p = new char[63];
|
|
operator delete[](p, 64);
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
// CHECK: ERROR: invalid sized delete when deallocating address
|