summaryrefslogtreecommitdiff
path: root/FreeRTOS-Plus/Test/CBMC/proofs/DNS/DNSlookup/DNSlookup_harness.c
diff options
context:
space:
mode:
Diffstat (limited to 'FreeRTOS-Plus/Test/CBMC/proofs/DNS/DNSlookup/DNSlookup_harness.c')
-rw-r--r--FreeRTOS-Plus/Test/CBMC/proofs/DNS/DNSlookup/DNSlookup_harness.c32
1 files changed, 32 insertions, 0 deletions
diff --git a/FreeRTOS-Plus/Test/CBMC/proofs/DNS/DNSlookup/DNSlookup_harness.c b/FreeRTOS-Plus/Test/CBMC/proofs/DNS/DNSlookup/DNSlookup_harness.c
new file mode 100644
index 000000000..5b725c4ca
--- /dev/null
+++ b/FreeRTOS-Plus/Test/CBMC/proofs/DNS/DNSlookup/DNSlookup_harness.c
@@ -0,0 +1,32 @@
+/* FreeRTOS includes. */
+#include "FreeRTOS.h"
+#include "queue.h"
+#include "list.h"
+
+/* FreeRTOS+TCP includes. */
+#include "FreeRTOS_IP.h"
+#include "FreeRTOS_DNS.h"
+#include "FreeRTOS_IP_Private.h"
+
+/* This assumes that the length of the hostname is bounded by MAX_HOSTNAME_LEN. */
+void *safeMalloc(size_t xWantedSize) {
+ if(xWantedSize == 0) {
+ return NULL;
+ }
+ uint8_t byte;
+ return byte ? malloc(xWantedSize) : NULL;
+}
+
+void harness() {
+ if(ipconfigUSE_DNS_CACHE != 0) {
+ size_t len;
+ __CPROVER_assume(len >= 0 && len <= MAX_HOSTNAME_LEN);
+ char *pcHostName = safeMalloc(len); /* malloc is replaced by safeMalloc */
+ if (len && pcHostName) {
+ pcHostName[len-1] = NULL;
+ }
+ if (pcHostName) { /* guarding against NULL pointer */
+ FreeRTOS_dnslookup(pcHostName);
+ }
+ }
+}