-consider-volatile-qualifier-on-fields
)Примите тот volatile
квалифицированные поля структуры могут иметь все возможные значения в любой точке в коде
Эта опция влияет на анализ Code Prover только.
Укажите, что верификация должна учесть volatile
спецификатор на полях структуры.
Пользовательский интерфейс (только десктопные решения): В вашей настройке проекта опция доступна на узле Verification Assumptions.
Командная строка и файл опций: Используйте опцию -consider-volatile-qualifier-on-fields
. Смотрите информацию о командной строке.
volatile
спецификатор на переменной указывает, что значение переменных может измениться между последовательными операциями, даже если вы явным образом не изменяете его в своем коде. Например, если var
volatile
переменная, последовательные операции res = var; res =var;
может привести к двум различным значениям var
быть считанным в res
.
Используйте эту опцию так, чтобы верификация эмулировала volatile
спецификатор для полей структуры. Если вы выбираете эту опцию, программное обеспечение принимает что volatile
поле структуры имеет полный спектр значений в любой точке в коде. Область значений определяется только по условию тип поля структуры.
Верификация рассматривает volatile
спецификатор на полях структуры.
В следующем примере верификация полагает что поле val1
может иметь все значения, допускал int
введите в любой точке в коде.
struct myStruct { volatile int val1; int val2; };
Даже если вы пишете определенное значение в val1
и считайте переменную в следующей операции, переменные результаты чтения в любом возможном значении.
struct myStruct myStructInstance;
myStructInstance.val1 = 1;
assert (myStructInstance.val1 == 1); // Assertion can fail
Верификация игнорирует volatile
спецификатор на полях структуры.
В следующем примере верификация игнорирует спецификатор на поле val1
.
struct myStruct { volatile int val1; int val2; };
Если вы пишете определенное значение в val1
и считайте переменную в следующей операции, переменные результаты чтения в том определенном значении.
struct myStruct myStructInstance;
myStructInstance.val1 = 1;
assert (myStructInstance.val1 == 1); // Assertion passes
Если ваши энергозависимые поля не представляют значения, считанные из оборудования, и вы не ожидаете, что их значения изменятся между последовательными операциями, отключат эту опцию. Вы используете volatile
спецификатор по некоторой другой причине и верификации не должен рассматривать полный спектр для значений полей.
Если вы включаете эту опцию, количество красных, серых, и зеленых регистраций вашего кода может уменьшиться. Количество оранжевых проверок может увеличиться.
В следующем примере красная или зеленая проверка превращается в оранжевый, или серая проверка уходит, когда опция используется. Рассмотрение volatile
спецификатор изменяет цвет проверки. Эти примеры используют следующее определение структуры:
struct myStruct { volatile int field1; int field2; };
Цвет без опции | Закончитесь без опции | Закончитесь с опцией |
---|---|---|
Зеленый | void main(){
struct myStruct structVal;
structVal.field1 = 1;
assert(structVal.field1 == 1);
} | void main(){
struct myStruct structVal;
structVal.field1 = 1;
assert(structVal.field1 ==1);
} |
Красный | void main(){
struct myStruct structVal;
structVal.field1 = 1;
assert(structVal.field1 != 1);
} | void main(){
struct myStruct structVal;
structVal.field1 = 1;
assert(structVal.field1 !=1);
} |
Серый | void main(){
struct myStruct structVal;
structVal.field1 = 1;
if (structVal.field1 != 1)
{
/* Perform operation */
}
} | void main(){ struct myStruct structVal; structVal.field1 = 1; if (structVal.field1 != 1) { /* Perform operation */ } } |
В Коде С++ опция также применяется к членам класса.
Параметр: -consider-volatile-qualifier-on-fields |
Значение по умолчанию: Off |
Пример (Code Prover): Polyspace Code Prover - источники |
Пример (Сервер Code Prover): сервер программы автоматического доказательства полипробела кода - источники |