/*
* Copyright (C) 2008 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
* Simple linear memory allocator.
*/
#ifndef _DALVIK_LINEARALLOC
#define _DALVIK_LINEARALLOC
/*
* If this is set, we create additional data structures and make many
* additional mprotect() calls.
* (this breaks the debugger because the debugBreakpointCount cannot be updated)
*/
#define ENFORCE_READ_ONLY false
/*
* Linear allocation state. We could tuck this into the start of the
* allocated region, but that would prevent us from sharing the rest of
* that first page.
*/
typedef struct LinearAllocHdr {
int curOffset; /* offset where next data goes */
pthread_mutex_t lock; /* controls updates to this struct */
char* mapAddr; /* start of mmap()ed region */
int mapLength; /* length of region */
int firstOffset; /* for chasing through */
short* writeRefCount; /* for ENFORCE_READ_ONLY */
} LinearAllocHdr;
/*
* Create a new alloc region.
*/
LinearAllocHdr* dvmLinearAllocCreate(Object* classLoader);
/*
* Destroy a region.
*/
void dvmLinearAllocDestroy(Object* classLoader);
/*
* Allocate a chunk of memory. The memory will be zeroed out.
*
* For ENFORCE_READ_ONLY, call dvmLinearReadOnly on the result.
*/
void* dvmLinearAlloc(Object* classLoader, size_t size);
/*
* Reallocate a chunk. The original storage is not released, but may be
* erased to aid debugging.
*
* For ENFORCE_READ_ONLY, call dvmLinearReadOnly on the result. Also, the
* caller should probably mark the "mem" argument read-only before calling.
*/
void* dvmLinearRealloc(Object* classLoader, void* mem, size_t newSize);
/* don't call these directly */
void dvmLinearSetReadOnly(Object* classLoader, void* mem);
void dvmLinearSetReadWrite(Object* classLoader, void* mem);
/*
* Mark a chunk of memory from Alloc or Realloc as read-only. This must
* be done after all changes to the block of memory have been made. This
* actually operates on a page granularity.
*/
INLINE void dvmLinearReadOnly(Object* classLoader, void* mem)
{
if (ENFORCE_READ_ONLY && mem != NULL)
dvmLinearSetReadOnly(classLoader, mem);
}
/*
* Make a chunk of memory writable again.
*/
INLINE void dvmLinearReadWrite(Object* classLoader, void* mem)
{
if (ENFORCE_READ_ONLY && mem != NULL)
dvmLinearSetReadWrite(classLoader, mem);
}
/*
* Free a chunk. Does not increase available storage, but the freed area
* may be erased to aid debugging.
*/
void dvmLinearFree(Object* classLoader, void* mem);
/*
* Helper function; allocates new storage and copies "str" into it.
*
* For ENFORCE_READ_ONLY, do *not* call dvmLinearReadOnly on the result.
* This is done automatically.
*/
char* dvmLinearStrdup(Object* classLoader, const char* str);
/*
* Dump the contents of a linear alloc area.
*/
void dvmLinearAllocDump(Object* classLoader);
/*
* Determine if [start, start+length) is contained in the in-use area of
* a single LinearAlloc. The full set of linear allocators is scanned.
*/
bool dvmLinearAllocContains(const void* start, size_t length);
#endif /*_DALVIK_LINEARALLOC*/