mirror of
https://github.com/FreeRTOS/FreeRTOS-Kernel.git
synced 2025-12-11 22:25:14 -05:00
59 lines
No EOL
1.7 KiB
C
59 lines
No EOL
1.7 KiB
C
#ifndef VERIFAST_PORT_CONTRACTS_H
|
|
#define VERIFAST_PORT_CONTRACTS_H
|
|
|
|
|
|
// We want our proofs to hold for an arbitrary number of cores.
|
|
/* TODO: Can we use the original function `get_core_num` instead without
|
|
* adding the contract inside the pico sdk file (platform.h)?
|
|
*/
|
|
#undef portGET_CORE_ID
|
|
#define portGET_CORE_ID() VF__get_core_num()
|
|
|
|
/* FreeRTOS core id is always zero based.*/
|
|
static uint VF__get_core_num(void);
|
|
//@ requires true;
|
|
/*@ ensures 0 <= result &*& result < configNUM_CORES &*&
|
|
result == coreID_f();
|
|
@*/
|
|
|
|
/*@
|
|
// Allow reference to core id in proofs.
|
|
fixpoint uint coreID_f();
|
|
|
|
lemma void coreID_f_range();
|
|
requires true;
|
|
ensures 0 <= coreID_f() &*& coreID_f() < configNUM_CORES;
|
|
@*/
|
|
|
|
|
|
|
|
|
|
#undef portDISABLE_INTERRUPTS
|
|
#define portDISABLE_INTERRUPTS VF__portDISABLE_INTERRUPTS
|
|
uint32_t VF__portDISABLE_INTERRUPTS();
|
|
//@ requires interruptState_p(?coreID, ?state);
|
|
/*@ ensures result == state &*&
|
|
interruptState_p(coreID, ?newState) &*&
|
|
interruptsDisabled_f(newState) == true;
|
|
@*/
|
|
|
|
#undef portRESTORE_INTERRUPTS
|
|
#define portRESTORE_INTERRUPTS(ulState) VF__portRESTORE_INTERRUPTS(ulState)
|
|
void VF__portRESTORE_INTERRUPTS(uint32_t state);
|
|
//@ requires interruptState_p(?coreID, _);
|
|
/*@ ensures interruptState_p(coreID, state);
|
|
@*/
|
|
|
|
#undef portGET_TASK_LOCK
|
|
#define portGET_TASK_LOCK VF__portGET_TASK_LOCK
|
|
void VF__portGET_TASK_LOCK();
|
|
//@ requires [?f]taskLock() &*& locked(nil);
|
|
//@ ensures taskLockInv() &*& locked( cons( pair(f, taskLockID_f), nil) );
|
|
|
|
#undef portGET_ISR_LOCK
|
|
#define portGET_ISR_LOCK VF__portGET_ISR_LOCK
|
|
void VF__portGET_ISR_LOCK();
|
|
//@ requires [?f]isrLock() &*& locked(?heldLocks);
|
|
//@ ensures isrLockInv() &*& locked( cons( pair(f, isrLockID_f), heldLocks) );
|
|
|
|
#endif /* VERIFAST_PORT_CONTRACTS_H */ |