Use CBMC XML output to enable VSCode debugger (#912)

Prior to this commit, CBMC would emit logging information in plain text
format, which does not contain information required for the CBMC VSCode
debugger. This commit makes CBMC use XML instead of plain text.

Co-authored-by: Mark Tuttle <tuttle@acm.org>
pull/910/head^2
Kareem Khazem 2 years ago committed by GitHub
parent 2ec3cb5a0f
commit c7b3124565
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -119,8 +119,8 @@ goto:
# Ignore the return code for CBMC, so that we can still generate the # Ignore the return code for CBMC, so that we can still generate the
# report if the proof failed. If the proof failed, we separately fail # report if the proof failed. If the proof failed, we separately fail
# the entire job using the check-cbmc-result rule. # the entire job using the check-cbmc-result rule.
cbmc.txt: $(ENTRY).goto cbmc.xml: $(ENTRY).goto
-cbmc $(CBMCFLAGS) $(SOLVER) --unwinding-assertions --trace @RULE_INPUT@ > $@ 2>&1 -cbmc $(CBMCFLAGS) $(SOLVER) --unwinding-assertions --trace --xml-ui @RULE_INPUT@ > $@ 2>&1
property.xml: $(ENTRY).goto property.xml: $(ENTRY).goto
cbmc $(CBMCFLAGS) --unwinding-assertions --show-properties --xml-ui @RULE_INPUT@ > $@ 2>&1 cbmc $(CBMCFLAGS) --unwinding-assertions --show-properties --xml-ui @RULE_INPUT@ > $@ 2>&1
@ -128,28 +128,27 @@ property.xml: $(ENTRY).goto
coverage.xml: $(ENTRY).goto coverage.xml: $(ENTRY).goto
cbmc $(CBMCFLAGS) --cover location --xml-ui @RULE_INPUT@ > $@ 2>&1 cbmc $(CBMCFLAGS) --cover location --xml-ui @RULE_INPUT@ > $@ 2>&1
cbmc: cbmc.txt cbmc: cbmc.xml
property: property.xml property: property.xml
coverage: coverage.xml coverage: coverage.xml
report: cbmc.txt property.xml coverage.xml report: cbmc.xml property.xml coverage.xml
$(VIEWER) \ $(VIEWER) \
--goto $(ENTRY).goto \ --goto $(ENTRY).goto \
--srcdir $(FREERTOS) \ --srcdir $(FREERTOS) \
--htmldir html \ --reportdir html \
--srcexclude "(.@FORWARD_SLASH@Demo)" \ --result cbmc.xml \
--result cbmc.txt \
--property property.xml \ --property property.xml \
--block coverage.xml --coverage coverage.xml
# This rule depends only on cbmc.txt and has no dependents, so it will # This rule depends only on cbmc.xml and has no dependents, so it will
# not block the report from being generated if it fails. This rule is # not block the report from being generated if it fails. This rule is
# intended to fail if and only if the CBMC safety check that emits # intended to fail if and only if the CBMC safety check that emits
# cbmc.txt yielded a proof failure. # cbmc.xml yielded a proof failure.
check-cbmc-result: cbmc.txt check-cbmc-result: cbmc.xml
grep -e "^VERIFICATION SUCCESSFUL" $^ grep -e "<cprover-status>SUCCESS</cprover-status>" $^
# ____________________________________________________________________ # ____________________________________________________________________
# Rules # Rules
@ -159,7 +158,7 @@ check-cbmc-result: cbmc.txt
clean: clean:
@RM@ $(OBJS) $(ENTRY).goto @RM@ $(OBJS) $(ENTRY).goto
@RM@ $(ENTRY)[0-9].goto $(ENTRY)[0-9].txt @RM@ $(ENTRY)[0-9].goto $(ENTRY)[0-9].txt
@RM@ cbmc.txt property.xml coverage.xml TAGS TAGS-* @RM@ cbmc.xml property.xml coverage.xml TAGS TAGS-*
@RM@ *~ \#* @RM@ *~ \#*
@RM@ queue_datastructure.h @RM@ queue_datastructure.h

Loading…
Cancel
Save