/*
* 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.
*/
/*
* Manage async heap tasks.
*/
#ifndef _DALVIK_ALLOC_HEAP_WORKER
#define _DALVIK_ALLOC_HEAP_WORKER
/*
* Initialize any HeapWorker state that Heap.c
* cares about. This lets the GC start before the
* HeapWorker thread is initialized.
*/
void dvmInitializeHeapWorkerState(void);
/*
* Initialization. Starts/stops the worker thread.
*/
bool dvmHeapWorkerStartup(void);
void dvmHeapWorkerShutdown(void);
/*
* Tell the worker thread to wake up and do work.
* If shouldLock is false, the caller must have already
* acquired gDvm.heapWorkerLock.
*/
void dvmSignalHeapWorker(bool shouldLock);
/*
* Block until all pending heap worker work has finished.
*/
void dvmWaitForHeapWorkerIdle(void);
/*
* Does not return until any pending finalizers have been called.
* This may or may not happen in the context of the calling thread.
* No exceptions will escape.
*
* Used by zygote, which doesn't have a HeapWorker thread.
*/
void dvmRunFinalizationSync(void);
/*
* Requests that dvmHeapSourceTrim() be called no sooner
* than timeoutSec seconds from now. If timeoutSec
* is zero, any pending trim is cancelled.
*
* Caller must hold heapWorkerLock.
*/
void dvmScheduleHeapSourceTrim(size_t timeoutSec);
/* Make sure that the HeapWorker thread hasn't spent an inordinate
* amount of time inside interpreted code.
*
* Aborts the VM if the thread appears to be wedged.
*
* The caller must hold the heapWorkerLock.
*/
void dvmAssertHeapWorkerThreadRunning();
/*
* The type of operation for HeapWorker to perform on an object.
*/
typedef enum HeapWorkerOperation {
WORKER_FINALIZE = 0,
/* Required: (WORKER_CLEAR | WORKER_ENQUEUE) <= (4-1)
* These values will be stuffed in the low bits of a pointer.
*/
WORKER_CLEAR = (1<<0),
WORKER_ENQUEUE = (1<<1),
} HeapWorkerOperation;
/*
* Called by the worker thread to get the next object
* to finalize/enqueue/clear. Implemented in Heap.c.
*
* @param op The operation to perform on the returned object.
* Must be non-NULL.
* @return The object to operate on, or NULL.
*/
Object *dvmGetNextHeapWorkerObject(HeapWorkerOperation *op);
#endif /*_DALVIK_ALLOC_HEAP_WORKER*/