From f92a6ddf7d90d8caa69882239f1a5c7a8fbbfc0c Mon Sep 17 00:00:00 2001 From: iceman1001 Date: Mon, 1 Jan 2018 14:28:53 +0100 Subject: [PATCH] FIX: 'hf iclass' - sneaky fread bug. thanks to @bettse who found it --- client/loclass/ikeys.c | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/client/loclass/ikeys.c b/client/loclass/ikeys.c index 861cc10e8..0ae739b65 100644 --- a/client/loclass/ikeys.c +++ b/client/loclass/ikeys.c @@ -675,23 +675,22 @@ int doTestsWithKnownInputs() { return errors; } -int readKeyFile(uint8_t key[8]) { - int retval = 1; +static bool readKeyFile(uint8_t key[8]) { + bool retval = false; FILE *f = fopen("iclass_key.bin", "rb"); if (!f) - return 0; + return retval; - size_t bytes_read = fread(key, sizeof(uint8_t), 8, f); - if ( bytes_read == 1) - retval = 0; + size_t bytes_read = fread(key, sizeof(uint8_t), sizeof(key), f); + if ( bytes_read == sizeof(key)) + retval = true; if (f) fclose(f); return retval; } -int doKeyTests(uint8_t debuglevel) -{ +int doKeyTests(uint8_t debuglevel) { debug_print = debuglevel; prnlog("[+] Checking if the master key is present (iclass_key.bin)...");