60 lines
2.0 KiB
JSON
60 lines
2.0 KiB
JSON
#
|
|
# FreeRTOS memory safety proofs with CBMC.
|
|
# Copyright (C) 2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
#
|
|
# Permission is hereby granted, free of charge, to any person
|
|
# obtaining a copy of this software and associated documentation
|
|
# files (the "Software"), to deal in the Software without
|
|
# restriction, including without limitation the rights to use, copy,
|
|
# modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
# of the Software, and to permit persons to whom the Software is
|
|
# furnished to do so, subject to the following conditions:
|
|
#
|
|
# The above copyright notice and this permission notice shall be
|
|
# included in all copies or substantial portions of the Software.
|
|
#
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
# BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
# ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
# SOFTWARE.
|
|
#
|
|
# http://aws.amazon.com/freertos
|
|
# http://www.FreeRTOS.org
|
|
#
|
|
|
|
{
|
|
"ENTRY": "QueueSemaphoreTake",
|
|
|
|
# This bound on queue size is needed to bound a loop in prvUnlockQueue
|
|
"QUEUE_BOUND": 5,
|
|
|
|
"CBMCFLAGS": [
|
|
"--unwind 2",
|
|
"--signed-overflow-check",
|
|
"--unsigned-overflow-check",
|
|
"--nondet-static",
|
|
"--unwindset prvUnlockQueue.0:{QUEUE_BOUND},prvUnlockQueue.1:{QUEUE_BOUND},xQueueSemaphoreTake.0:3"
|
|
],
|
|
"OBJS": [
|
|
"$(ENTRY)_harness.goto",
|
|
"$(FREERTOS)/Source/queue.goto",
|
|
"$(FREERTOS)/Source/list.goto",
|
|
"$(FREERTOS)/Test/CBMC/proofs/CBMCStubLibrary/tasksStubs.goto"
|
|
],
|
|
"DEF": [
|
|
"configUSE_TRACE_FACILITY=0",
|
|
"configGENERATE_RUN_TIME_STATS=0",
|
|
"PRV_UNLOCK_QUEUE_BOUND={QUEUE_BOUND}"
|
|
],
|
|
"INC": [
|
|
"."
|
|
],
|
|
"GENERATE_HEADER": [
|
|
"queue_datastructure.h"
|
|
]
|
|
}
|