Use C-parser on seL4 based application
Hi, I have been trying to reuse the seL4 verification framework to verify a toy example I built on seL4, and I am currently stuck on the c-parser step. I am trying to use c-parser to parse the example I built, then conduct refinement verification. The toy example is a normal c project, which includes `sel4.h`. From this thread: https://lists.sel4.systems/hyperkitty/list/devel@sel4.systems/thread/3QYNFY4... I learned that I am supposed to do $ ./isabelle/bin/isabelle jedit -d . -l CParser toy.thy And the toy.thy file is supposed to begin with `install_C_file("toy.c")`. However, since toy.c includes sel4.h, I am not sure how to preprocess it before I put it into toy.thy. I know the standalone c-parser can have a -I flag to include in all the dependency directories, but it cannot open an interactive window. (From my understanding, the standalone c-parser seems to be only a checking tool) I also know that when sel4 is parsed into HOL, it is preprocessed into a single c file `kernel_all.c_pp`, which is later parsed. I am not sure if the preprocessor tool can be reused for other applications as well. My question is summarized as: 1. Is there a way to add an include directory in interactive CParser? 2. If not, can I reuse the preprocessing approach for sel4 to preprocess my application to a singleton file that can be parsed by c-parser? Any help will be appreciated! Thanks, Ru
Hi Ru, the file l4v/tools/c-parser/testfiles/parse_include.thy has an example of how to do this. The Isabelle commands in the theory file there are: external_file "includes/test_include2.h" external_file "parse_include.c" new_C_include_dir "includes" install_C_file "parse_include.c" In the seL4 verification, there is a bit more to the invocation of the preprocessor, so we do this separately via the command line (in the build system) and concatenate the output of the preprocessor for all C files to make extra sure the theorem prover is seeing the same input as the compiler. These are just regular gcc or clang command line invocations, nothing specific to do with Isabelle. Cheers, Gerwin
On 15 Oct 2023, at 13:55, r2ji@uwaterloo.ca wrote:
Hi,
I have been trying to reuse the seL4 verification framework to verify a toy example I built on seL4, and I am currently stuck on the c-parser step. I am trying to use c-parser to parse the example I built, then conduct refinement verification. The toy example is a normal c project, which includes `sel4.h`.
From this thread: https://lists.sel4.systems/hyperkitty/list/devel@sel4.systems/thread/3QYNFY4... I learned that I am supposed to do
$ ./isabelle/bin/isabelle jedit -d . -l CParser toy.thy And the toy.thy file is supposed to begin with `install_C_file("toy.c")`.
However, since toy.c includes sel4.h, I am not sure how to preprocess it before I put it into toy.thy. I know the standalone c-parser can have a -I flag to include in all the dependency directories, but it cannot open an interactive window. (From my understanding, the standalone c-parser seems to be only a checking tool)
I also know that when sel4 is parsed into HOL, it is preprocessed into a single c file `kernel_all.c_pp`, which is later parsed. I am not sure if the preprocessor tool can be reused for other applications as well.
My question is summarized as: 1. Is there a way to add an include directory in interactive CParser? 2. If not, can I reuse the preprocessing approach for sel4 to preprocess my application to a singleton file that can be parsed by c-parser?
Any help will be appreciated!
Thanks, Ru _______________________________________________ Devel mailing list -- devel@sel4.systems To unsubscribe send an email to devel-leave@sel4.systems
Hi, I have a follow up question on this question. The `toy.c` file I have has`#include<sel4/sel4.h>` from `libsel4/include`. Therefore, in order to install_C_file "toy.c" I added all the required dependencies according to the error prompts, here is the result: ``` theory passwd imports "CParser.CTranslation" begin new_C_include_dir "my_repo/kernel/libsel4/include" new_C_include_dir "my_repo/build/kernel/autoconf" new_C_include_dir "my_repo/build/libsel4/sel4_arch_include/x86_64" new_C_include_dir "my_repo/build/kernel/gen_config" new_C_include_dir "my_repo/kernel/libsel4/mode_include/64" new_C_include_dir "my_repo/build/libsel4/sel4_arch_include/x86_64" new_C_include_dir "my_repo/build/libsel4/include" new_C_include_dir "my_repo/build/libsel4/arch_include/x86" new_C_include_dir "my_repo/kernel/libsel4/sel4_plat_include/pc99" new_C_include_dir "my_repo/projects/sel4runtime/include" new_C_include_dir "my_repo/libsel4/gen_config" new_C_include_dir "my_repo/verification/l4v/spec/cspec/c/build/X64/gen_config" new_C_include_dir "my_repo/kernel/libsel4/arch_include/x86" new_C_include_dir "my_repo/kernel/libsel4/sel4_arch_include/x86_64" new_C_include_dir "my_repo/projects/sel4-example" external_file "my_repo/projects/sel4-example/roottask.c" install_C_file "my_repo/projects/sel4-example/roottask.c" thm passwd_global_addresses.main_body_def end ``` However, I got an error that I am not able to understand: ``` install_C_file - my_repo/kernel/libsel4/include/sel4/simple_types.h:37.29-37.29: syntax error: inserting LCURLY ``` I have tested my toy.c example before and it is able to be simulated. I am wondering is it possible that this error is caused by the C file mentioned is not a StrictC subset? Which means if I include `sel4/sel4.h` I have to do the preprocessing as that in seL4 verification. If that is the case, am I able to integrate `kernel_all.c_pp` to my application? I hid some of the details of the organization of sel4-example I constructed, but I hope the information provided here is enough to find something. Any suggestion will be appreciated!
participants (2)
-
Gerwin Klein
-
r2ji@uwaterloo.ca