summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCyril Bur <cyril.bur@au1.ibm.com>2018-03-19 15:54:15 +1100
committerStewart Smith <stewart@linux.vnet.ibm.com>2018-03-27 14:51:38 +1100
commit3c3b809cb8ba8c440353a0f0849f8c37e5f1ca1d (patch)
tree2ef31f8cd2150bfcd0f714267d7ee78480d8339a
parent4599a8bdf9de5a011273844c6f4872eb2585cd72 (diff)
downloadtalos-skiboot-3c3b809cb8ba8c440353a0f0849f8c37e5f1ca1d.tar.gz
talos-skiboot-3c3b809cb8ba8c440353a0f0849f8c37e5f1ca1d.zip
libstb/create-container: munmap() signature file address
I also couldn't ignore that the same function had both a void *infile and a char *inFile. The inFile variable is clearly a filename, why not call it that. Fixes: CID 263054 and 263051 Signed-off-by: Cyril Bur <cyril.bur@au1.ibm.com> Signed-off-by: Stewart Smith <stewart@linux.vnet.ibm.com>
-rw-r--r--libstb/container.h4
-rw-r--r--libstb/create-container.c36
2 files changed, 21 insertions, 19 deletions
diff --git a/libstb/container.h b/libstb/container.h
index c125bc1a..0d0acb23 100644
--- a/libstb/container.h
+++ b/libstb/container.h
@@ -149,9 +149,9 @@ int parse_stb_container(const void* data, size_t len, struct parsed_stb_containe
void stb_print_data(const void *data, size_t len);
-void getPublicKeyRaw(ecc_key_t *pubkeyraw, char *inFile);
+void getPublicKeyRaw(ecc_key_t *pubkeyraw, char *filename);
-void getSigRaw(ecc_signature_t *sigraw, char *inFile);
+void getSigRaw(ecc_signature_t *sigraw, char *filename);
void writeHdr(void *ph, const char *outFile, int hdr_type);
diff --git a/libstb/create-container.c b/libstb/create-container.c
index 4207e1c0..d9f377fb 100644
--- a/libstb/create-container.c
+++ b/libstb/create-container.c
@@ -55,23 +55,23 @@ int wrap = 100;
void usage(int status);
-void getPublicKeyRaw(ecc_key_t *pubkeyraw, char *inFile)
+void getPublicKeyRaw(ecc_key_t *pubkeyraw, char *filename)
{
EVP_PKEY* pkey;
unsigned char pubkeyData[1 + 2 * EC_COORDBYTES];
- FILE *fp = fopen(inFile, "r");
+ FILE *fp = fopen(filename, "r");
if (!fp)
- die(EX_NOINPUT, "Cannot open key file: %s: %s", inFile, strerror(errno));
+ die(EX_NOINPUT, "Cannot open key file: %s: %s", filename, strerror(errno));
if ((pkey = PEM_read_PrivateKey(fp, NULL, NULL, NULL))) {
- debug_msg("File \"%s\" is a PEM private key", inFile);
+ debug_msg("File \"%s\" is a PEM private key", filename);
fclose(fp);
} else {
fclose(fp);
- fp = fopen(inFile, "r");
+ fp = fopen(filename, "r");
if ((pkey = PEM_read_PUBKEY(fp, NULL, NULL, NULL))) {
- debug_msg("File \"%s\" is a PEM public key", inFile);
+ debug_msg("File \"%s\" is a PEM public key", filename);
}
fclose(fp);
}
@@ -110,13 +110,13 @@ void getPublicKeyRaw(ecc_key_t *pubkeyraw, char *inFile)
struct stat s;
void *infile = NULL;
- fdin = open(inFile, O_RDONLY);
+ fdin = open(filename, O_RDONLY);
if (fdin <= 0)
- die(EX_NOINPUT, "Cannot open key file: %s: %s", inFile, strerror(errno));
+ die(EX_NOINPUT, "Cannot open key file: %s: %s", filename, strerror(errno));
r = fstat(fdin, &s);
if (r != 0)
- die(EX_NOINPUT, "Cannot stat key file: %s", inFile);
+ die(EX_NOINPUT, "Cannot stat key file: %s", filename);
if (s.st_size == 1 + 2 * EC_COORDBYTES)
infile = mmap(NULL, s.st_size, PROT_READ, MAP_PRIVATE, fdin, 0);
@@ -126,12 +126,13 @@ void getPublicKeyRaw(ecc_key_t *pubkeyraw, char *inFile)
if (!infile || (*(unsigned char*) infile != 0x04)) {
die(EX_DATAERR,
"File \"%s\" is not in expected format (private or public key in PEM, or public key RAW)",
- inFile);
+ filename);
}
else
- debug_msg("File \"%s\" is a RAW public key", inFile);
+ debug_msg("File \"%s\" is a RAW public key", filename);
memcpy(pubkeyData, infile, sizeof(ecc_key_t) + 1);
+ munmap(infile, s.st_size);
}
// Remove the leading byte
@@ -140,7 +141,7 @@ void getPublicKeyRaw(ecc_key_t *pubkeyraw, char *inFile)
return;
}
-void getSigRaw(ecc_signature_t *sigraw, char *inFile)
+void getSigRaw(ecc_signature_t *sigraw, char *filename)
{
int fdin;
struct stat s;
@@ -151,13 +152,13 @@ void getSigRaw(ecc_signature_t *sigraw, char *inFile)
unsigned char outbuf[2 * EC_COORDBYTES];
ECDSA_SIG* signature;
- fdin = open(inFile, O_RDONLY);
+ fdin = open(filename, O_RDONLY);
if (fdin <= 0)
- die(EX_NOINPUT, "Cannot open sig file: %s: %s", inFile, strerror(errno));
+ die(EX_NOINPUT, "Cannot open sig file: %s: %s", filename, strerror(errno));
r = fstat(fdin, &s);
if (r != 0)
- die(EX_NOINPUT, "Cannot stat sig file: %s", inFile);
+ die(EX_NOINPUT, "Cannot stat sig file: %s", filename);
infile = mmap(NULL, s.st_size, PROT_READ, MAP_PRIVATE, fdin, 0);
if (!infile)
@@ -167,13 +168,13 @@ void getSigRaw(ecc_signature_t *sigraw, char *inFile)
if (s.st_size == 2 * EC_COORDBYTES) {
/* The file is a p521 signature in RAW format. */
- debug_msg("File \"%s\" is a RAW signature", inFile);
+ debug_msg("File \"%s\" is a RAW signature", filename);
memcpy(sigraw, infile, sizeof(ecc_signature_t));
}
else {
/* Assume the file is a p521 signature in DER format.
* Convert the DER to a signature object, then extract the RAW. */
- debug_msg("File \"%s\" is a DER signature", inFile);
+ debug_msg("File \"%s\" is a DER signature", filename);
signature = d2i_ECDSA_SIG(NULL,
(const unsigned char **) &infile, 7 + 2 * EC_COORDBYTES);
@@ -198,6 +199,7 @@ void getSigRaw(ecc_signature_t *sigraw, char *inFile)
ECDSA_SIG_free(signature);
}
+ munmap(infile, s.st_size);
return;
}
OpenPOWER on IntegriCloud