Files
libaaruformat/src/close.c

118 lines
3.6 KiB
C
Raw Normal View History

// /***************************************************************************
// The Disc Image Chef
// ----------------------------------------------------------------------------
//
// Filename : close.c
// Author(s) : Natalia Portillo <claunia@claunia.com>
//
// Component : libdicformat.
//
// --[ Description ] ----------------------------------------------------------
//
// Handles closing DiscImageChef format disk images.
//
// --[ License ] --------------------------------------------------------------
//
// This library is free software; you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as
// published by the Free Software Foundation; either version 2.1 of the
// License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, see <http://www.gnu.org/licenses/>.
//
// ----------------------------------------------------------------------------
// Copyright © 2011-2019 Natalia Portillo
// ****************************************************************************/
#include <stdio.h>
#include <dicformat.h>
#include <malloc.h>
#include <errno.h>
#include <sys/mman.h>
int close(void *context)
{
if(context == NULL)
{
errno = EINVAL;
return -1;
}
dicformatContext *ctx = context;
// Not a libdicformat context
if(ctx->magic != DIC_MAGIC)
{
errno = EINVAL;
return -1;
}
// This may do nothing if imageStream is NULL, but as the behaviour is undefined, better sure than sorry
if(ctx->imageStream != NULL)
fclose(ctx->imageStream);
free(ctx->sectorPrefix);
free(ctx->sectorPrefixCorrected);
free(ctx->sectorSuffix);
free(ctx->sectorSuffixCorrected);
free(ctx->sectorSubchannel);
free(ctx->mode2Subheaders);
2019-03-17 23:01:54 +00:00
if(ctx->mediaTagsTail != NULL)
{
dataLinkedList *mediaTag = ctx->mediaTagsTail;
while(mediaTag->previous != NULL)
{
free(mediaTag->data);
mediaTag = mediaTag->previous;
free(mediaTag->next);
}
}
if(ctx->mediaTagsHead != NULL)
{
free(ctx->mediaTagsHead->data);
free(ctx->mediaTagsHead);
}
if(!ctx->inMemoryDdt)
{
munmap(ctx->userDataDdt, ctx->mappedMemoryDdtSize);
}
2019-03-17 23:25:45 +00:00
free(ctx->sectorPrefixDdt);
free(ctx->sectorSuffixDdt);
2019-03-17 23:41:07 +00:00
free(ctx->metadataBlock);
2019-03-18 00:10:24 +00:00
free(ctx->trackEntries);
2019-03-18 22:06:10 +00:00
free(ctx->cicmBlock);
2019-03-17 23:41:07 +00:00
2019-03-20 00:23:30 +00:00
if(ctx->dumpHardwareEntriesWithData != NULL)
{
for(int i = 0; i < ctx->dumpHardwareHeader.entries; i++)
{
free(ctx->dumpHardwareEntriesWithData[i].extents);
free(ctx->dumpHardwareEntriesWithData[i].manufacturer);
free(ctx->dumpHardwareEntriesWithData[i].model);
free(ctx->dumpHardwareEntriesWithData[i].revision);
free(ctx->dumpHardwareEntriesWithData[i].firmware);
free(ctx->dumpHardwareEntriesWithData[i].serial);
free(ctx->dumpHardwareEntriesWithData[i].softwareName);
free(ctx->dumpHardwareEntriesWithData[i].softwareVersion);
free(ctx->dumpHardwareEntriesWithData[i].softwareOperatingSystem);
}
}
2019-03-31 14:56:03 +01:00
free(ctx->readableSectorTags);
free(context);
return 0;
}