platform_bootable_recovery/minzip/SysUtil.h
Doug Zongker 99916f0496 do verification and extraction on memory, not files
Changes minzip and recovery's file signature verification to work on
memory regions, rather than files.

For packages which are regular files, install.cpp now mmap()s them
into memory and then passes the mapped memory to the verifier and to
the minzip library.

Support for files which are raw block maps (which will be used when we
have packages written to encrypted data partitions) is present but
largely untested so far.

Bug: 12188746
Change-Id: I12cc3e809834745a489dd9d4ceb558cbccdc3f71
2014-01-16 13:29:28 -08:00

52 lines
1.1 KiB
C

/*
* Copyright 2006 The Android Open Source Project
*
* System utilities.
*/
#ifndef _MINZIP_SYSUTIL
#define _MINZIP_SYSUTIL
#include <stdio.h>
#include <sys/types.h>
#ifdef __cplusplus
extern "C" {
#endif
typedef struct MappedRange {
void* addr;
size_t length;
} MappedRange;
/*
* Use this to keep track of mapped segments.
*/
typedef struct MemMapping {
unsigned char* addr; /* start of data */
size_t length; /* length of data */
int range_count;
MappedRange* ranges;
} MemMapping;
/*
* Map a file into a private, read-only memory segment. If 'fn'
* begins with an '@' character, it is a map of blocks to be mapped,
* otherwise it is treated as an ordinary file.
*
* On success, "pMap" is filled in, and zero is returned.
*/
int sysMapFile(const char* fn, MemMapping* pMap);
/*
* Release the pages associated with a shared memory segment.
*
* This does not free "pMap"; it just releases the memory.
*/
void sysReleaseMap(MemMapping* pMap);
#ifdef __cplusplus
}
#endif
#endif /*_MINZIP_SYSUTIL*/