You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Checked C seems to allow the bounds of a variable p local to a function f to depend on a global variable x. If f calls a function that changes x, then p is not consistent with the new value of x, which can lead to a spatial safety violation. Example:
#pragma CHECKED_SCOPE on
#include<stdlib.h>size_tglobal_len;
voidchange_global_len(void) {
global_len=100000000;
}
intmain(void) {
global_len=100;
_Array_ptr<char>local_ptr : count(global_len) =malloc<char>(global_len);
// Doing this directly would cause a compile error.//global_len = 100000000;// No error, and local_ptr no longer meets its declared bound.change_global_len();
for (size_ti=0; i<global_len; i++)
local_ptr[i]++; // SIGSEGVreturn0;
}
The text was updated successfully, but these errors were encountered:
The Checked C specification does not allow this. See Section 3.6.2 of version 0.9 of the spec for the discussion. This check is not enforced by the Checked C compiler, however.
I believe the logic is there, but we turned it off because one of our early benchmark programs from the Olden benchmark site (em3d) contained local variables with bounds that are declared global variables. The fix is to turn the check back on and change the Checked C version of the benchmark program.
This issue was copied from checkedc/checkedc-clang#1192
Checked C seems to allow the bounds of a variable
p
local to a functionf
to depend on a global variablex
. Iff
calls a function that changesx
, thenp
is not consistent with the new value ofx
, which can lead to a spatial safety violation. Example:The text was updated successfully, but these errors were encountered: