From 3e53c7811a3c37992c7741d00a0cf1ae702c3fb0 Mon Sep 17 00:00:00 2001 From: Robert Clausecker Date: Wed, 19 Mar 2014 17:04:14 +0100 Subject: [PATCH] Check for NULL pointer in mifare_application_free() This changeset alters the return type of mifare_application_free() from void to int. This change is necessary to be able to inform the caller whether the call to malloc() inside mifare_application_find() failed. --- libfreefare/freefare.h | 2 +- libfreefare/mifare_application.c | 8 +++++++- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/libfreefare/freefare.h b/libfreefare/freefare.h index 85b79c6..b03ece2 100644 --- a/libfreefare/freefare.h +++ b/libfreefare/freefare.h @@ -171,7 +171,7 @@ void mad_free (Mad mad); MifareClassicSectorNumber *mifare_application_alloc (Mad mad, const MadAid aid, const size_t size); ssize_t mifare_application_read (MifareTag tag, Mad mad, const MadAid aid, void *buf, size_t nbytes, const MifareClassicKey key, const MifareClassicKeyType key_type); ssize_t mifare_application_write (MifareTag tag, Mad mad, const MadAid aid, const void *buf, size_t nbytes, const MifareClassicKey key, const MifareClassicKeyType key_type); -void mifare_application_free (Mad mad, const MadAid aid); +int mifare_application_free (Mad mad, const MadAid aid); MifareClassicSectorNumber *mifare_application_find (Mad mad, const MadAid aid); diff --git a/libfreefare/mifare_application.c b/libfreefare/mifare_application.c index 50e905f..b18d4b8 100644 --- a/libfreefare/mifare_application.c +++ b/libfreefare/mifare_application.c @@ -158,18 +158,24 @@ mifare_application_alloc (Mad mad, MadAid aid, size_t size) /* * Remove an application from a MAD. */ -void +int mifare_application_free (Mad mad, MadAid aid) { MifareClassicSectorNumber *sectors = mifare_application_find (mad, aid); MifareClassicSectorNumber *p = sectors; MadAid free_aid = { 0x00, 0x00 }; + + /* figure out if malloc() in mifare_application_find() failed */ + if (sectors == NULL) return count_aids (mad, aid) ? -1 : 0; + while (*p) { mad_set_aid (mad, *p, free_aid); p++; } free (sectors); + + return 0; }