diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2020-10-25 14:13:54 -0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2020-10-26 19:27:03 -0700 |
commit | 0d733747d1854614b750f1fe7afc26c75f5ecfe8 (patch) | |
tree | 2fff80ae0afb028c65e87029046143b63f2a8ec5 | |
parent | 77195ccb88aab66a5d138ca1e09324e482f897ac (diff) | |
download | subsurface-0d733747d1854614b750f1fe7afc26c75f5ecfe8.tar.gz |
cleanup: fix resource leak
Fixes CID 362078
Fixes CID 362081
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | core/datatrak.c | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/core/datatrak.c b/core/datatrak.c index 01a16210a..e1a62f582 100644 --- a/core/datatrak.c +++ b/core/datatrak.c @@ -602,9 +602,11 @@ static int wlog_header_parser (struct memblock *mem) } } +#define NOTES_LENGTH 256 +#define SUIT_LENGTH 26 static void wlog_compl_parser(struct memblock *wl_mem, struct dive *dt_dive, int dcount) { - int strlong = 256, tmp = 0, offset = 12 + (dcount * 850), + int tmp = 0, offset = 12 + (dcount * 850), pos_weight = offset + 256, pos_viz = offset + 258, pos_tank_init = offset + 266, @@ -616,9 +618,10 @@ static void wlog_compl_parser(struct memblock *wl_mem, struct dive *dt_dive, int * Extended notes string. Fixed length 256 bytes. 0 padded if not complete */ if (*(runner + offset)) { - wlog_notes = calloc(strlong + 1, 1); - wlog_notes = memcpy(wlog_notes, runner + offset, 256); - wlog_notes = to_utf8((unsigned char *) wlog_notes); + char wlog_notes_temp[NOTES_LENGTH + 1]; + wlog_notes_temp[NOTES_LENGTH] = 0; + (void)memcpy(wlog_notes_temp, runner + offset, NOTES_LENGTH); + wlog_notes = to_utf8((unsigned char *) wlog_notes_temp); } if (dt_dive->notes && wlog_notes) { buffer = calloc (strlen(dt_dive->notes) + strlen(wlog_notes) + 1, 1); @@ -664,11 +667,11 @@ static void wlog_compl_parser(struct memblock *wl_mem, struct dive *dt_dive, int * Dive suit, fixed length of 26 bytes, zero padded if shorter. * Expected to be preferred by the user if he did the work of setting it. */ - strlong = 26; if (*(runner + pos_suit)) { - wlog_suit = calloc(strlong, 1); - wlog_suit = memcpy(wlog_suit, runner + pos_suit, strlong); - wlog_suit = to_utf8((unsigned char *) wlog_suit); + char wlog_suit_temp[SUIT_LENGTH + 1]; + wlog_suit_temp[SUIT_LENGTH] = 0; + (void)memcpy(wlog_suit_temp, runner + pos_suit, SUIT_LENGTH); + wlog_suit = to_utf8((unsigned char *) wlog_suit_temp); } if (wlog_suit) dt_dive->suit = copy_string(wlog_suit); |