Frama-c:如何使用va_list和va_arg证明可变参数的理由?

问题描述 投票:0回答:1

[当前,我使用的是Frama-C 19版,并在各种参数上苦苦挣扎。例如)

  #include <stdarg.h>
  #include <stddef.h>

  void vars2(int n, va_list args) {
    for (size_t i = 0; i < n; ++i) {
        int tmp = va_arg(args, int);
    }
  };

 void vars(int n, ...) {
   va_list args;
   va_start(args, n);
   vars2(n, args);
   va_end(args);
 };

 int main(void) {
   vars(5, 1, 2, 3, 4, 5);
   return 0;
 }

[我正在收到'[eva:alarm] main.c:6的警告:警告:超出范围。断言\ valid_read(args)'。有什么办法可以在上面的代码中为args编写前提条件?我试图将其转换为void和int,但并没有太大帮助。非常感谢您的提前帮助。

BRs载在]

[当前,我使用的是Frama-C 19版,并在各种参数上苦苦挣扎。例如)#include #include void vars2(int n,va_list args){for(...

variadic-functions specifications frama-c formal-verification preconditions
1个回答
0
投票

您的示例是正确的,并且警告与可变参数功能无关。简单地提高分析精度就足以使Eva分别探索每个循环迭代并获得精确的结果。例如:

© www.soinside.com 2019 - 2024. All rights reserved.