mirror of
https://github.com/mtrojnar/osslsigncode.git
synced 2025-04-04 17:00:11 -05:00
use msi_dirent_free() when failed to parse the MSI_DIRENT structure
This commit is contained in:
parent
77b2b30d1f
commit
5f60cc6563
19
msi.c
19
msi.c
@ -492,23 +492,19 @@ int msi_dirent_new(MSI_FILE *msi, MSI_ENTRY *entry, MSI_DIRENT *parent, MSI_DIRE
|
||||
|
||||
if (parent && !sk_MSI_DIRENT_push(parent->children, dirent)) {
|
||||
printf("Failed to insert MSI_DIRENT\n");
|
||||
sk_MSI_DIRENT_free(dirent->children);
|
||||
OPENSSL_free(dirent);
|
||||
return 0; /* FAILED */
|
||||
}
|
||||
|
||||
if (!recurse_entry(msi, entry->leftSiblingID, parent)
|
||||
|| !recurse_entry(msi, entry->rightSiblingID, parent)
|
||||
|| !recurse_entry(msi, entry->childID, dirent)) {
|
||||
printf("Failed to add a sibling or a child to the tree\n");
|
||||
sk_MSI_DIRENT_free(dirent->children);
|
||||
OPENSSL_free(dirent);
|
||||
return 0; /* FAILED */
|
||||
}
|
||||
|
||||
if (ret)
|
||||
*ret = dirent;
|
||||
|
||||
if (!recurse_entry(msi, entry->leftSiblingID, parent)
|
||||
|| !recurse_entry(msi, entry->rightSiblingID, parent)
|
||||
|| !recurse_entry(msi, entry->childID, dirent)) {
|
||||
printf("Failed to add a sibling or a child to the tree\n");
|
||||
return 0; /* FAILED */
|
||||
}
|
||||
|
||||
return 1; /* OK */
|
||||
}
|
||||
|
||||
@ -529,7 +525,6 @@ static int recurse_entry(MSI_FILE *msi, uint32_t entryID, MSI_DIRENT *parent)
|
||||
}
|
||||
|
||||
if (!msi_dirent_new(msi, node, parent, NULL)) {
|
||||
OPENSSL_free(node);
|
||||
return 0; /* FAILED */
|
||||
}
|
||||
|
||||
|
@ -2906,7 +2906,6 @@ static int verify_signature(SIGNATURE *signature, GLOBAL_OPTIONS *options)
|
||||
static int msi_verify_header(char *indata, uint32_t filesize, MSI_PARAMS *msiparams)
|
||||
{
|
||||
MSI_ENTRY *root;
|
||||
MSI_DIRENT *root_dir = NULL;
|
||||
|
||||
msiparams->msi = msi_file_new(indata, filesize);
|
||||
if (!msiparams->msi) {
|
||||
@ -2918,12 +2917,10 @@ static int msi_verify_header(char *indata, uint32_t filesize, MSI_PARAMS *msipar
|
||||
printf("Failed to get file entry\n");
|
||||
return 0; /* FAILED */
|
||||
}
|
||||
if (!msi_dirent_new(msiparams->msi, root, NULL, &root_dir)) {
|
||||
if (!msi_dirent_new(msiparams->msi, root, NULL, &(msiparams->dirent))) {
|
||||
printf("Failed to parse MSI_DIRENT struct\n");
|
||||
OPENSSL_free(root);
|
||||
return 0; /* FAILED */
|
||||
}
|
||||
msiparams->dirent = root_dir;
|
||||
|
||||
return 1; /* OK */
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user