Path: blob/master/runtime/bcutil/ROMClassHashTable.c
5985 views
/*******************************************************************************1* Copyright (c) 1991, 2014 IBM Corp. and others2*3* This program and the accompanying materials are made available under4* the terms of the Eclipse Public License 2.0 which accompanies this5* distribution and is available at https://www.eclipse.org/legal/epl-2.0/6* or the Apache License, Version 2.0 which accompanies this distribution and7* is available at https://www.apache.org/licenses/LICENSE-2.0.8*9* This Source Code may also be made available under the following10* Secondary Licenses when the conditions for such availability set11* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU12* General Public License, version 2 with the GNU Classpath13* Exception [1] and GNU General Public License, version 2 with the14* OpenJDK Assembly Exception [2].15*16* [1] https://www.gnu.org/software/classpath/license.html17* [2] http://openjdk.java.net/legal/assembly-exception.html18*19* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception20*******************************************************************************/2122#include "j9.h"23#include "j9port.h"24#include "j9protos.h"25#include "j9consts.h"26#include "bcutil_internal.h"2728typedef struct romClassTableQueryEntry {29J9ROMClass *romClass;30U_8 *charData;31UDATA length;32} romClassTableQueryEntry;3334typedef union romClassTableEntry {35UDATA tag;36J9ROMClass* romClass;37} romClassTableEntry;3839static void40romClassHashGetName(void *key, const U_8 **name, UDATA *nameLength)41{42romClassTableEntry *entry = (romClassTableEntry*)key;4344/* We can distinguish between the different types of entries by the first slot.45* Query entries always have a NULL romClass field, romClasses have a non-NULL field.46*/47if (entry->tag == 0) {48romClassTableQueryEntry *queryEntry = (romClassTableQueryEntry*)entry;4950*name = queryEntry->charData;51*nameLength = queryEntry->length;52} else {53J9UTF8 *className = J9ROMCLASS_CLASSNAME(entry->romClass);5455*name = J9UTF8_DATA(className);56*nameLength = J9UTF8_LENGTH(className);57}58}5960static UDATA61romClassHashEqualFn(void *leftKey, void *rightKey, void *userData)62{63const U_8 *leftName;64UDATA leftLength;65const U_8 *rightName;66UDATA rightLength;6768romClassHashGetName(leftKey, &leftName, &leftLength);69romClassHashGetName(rightKey, &rightName, &rightLength);7071return J9UTF8_DATA_EQUALS(leftName, leftLength, rightName, rightLength);72}7374static UDATA75romClassHashFn(void *key, void *userData)76{77const U_8 *name;78UDATA length;79UDATA hash;80UDATA i;8182romClassHashGetName(key, &name, &length);8384hash = 0;85for (i = 0; i < length; ++i) {86hash = (hash << 5) - hash + name[i];87}8889return hash;90}9192J9HashTable*93romClassHashTableNew(J9JavaVM *vm, U_32 initialSize)94{95J9HashTable *table;9697table = hashTableNew(OMRPORT_FROM_J9PORT(vm->portLibrary), J9_GET_CALLSITE(), initialSize,98sizeof(romClassTableEntry), sizeof(char *), J9HASH_TABLE_ALLOW_SIZE_OPTIMIZATION,99J9MEM_CATEGORY_CLASSES, romClassHashFn, romClassHashEqualFn, NULL, vm);100return table;101}102103void104romClassHashTableFree(J9HashTable *hashTable)105{106hashTableFree(hashTable);107}108109UDATA110romClassHashTableAdd(J9HashTable *hashTable, J9ROMClass *value)111{112UDATA result = 1; /* failure */113romClassTableEntry entry;114115entry.romClass = value;116if (NULL != hashTableAdd(hashTable, &entry)) {117result = 0; /* success */118}119120return result;121}122123J9ROMClass*124romClassHashTableFind(J9HashTable *hashTable, U_8 *className, UDATA classNameLength)125{126romClassTableQueryEntry entry;127romClassTableEntry *result;128129entry.romClass = NULL;130entry.charData = className;131entry.length = classNameLength;132result = (romClassTableEntry*)hashTableFind(hashTable, &entry);133if (NULL != result) {134return result->romClass;135} else {136return NULL;137}138}139140void141romClassHashTableReplace(J9HashTable *hashTable, J9ROMClass *originalClass, J9ROMClass *replacementClass)142{143romClassTableEntry *result;144romClassTableEntry original;145146original.romClass = originalClass;147148result = hashTableFind(hashTable, &original);149if ( (result != NULL) && (result->romClass == originalClass)) {150result->romClass = replacementClass;151}152}153154UDATA155romClassHashTableDelete(J9HashTable *hashTable, J9ROMClass *romClass)156{157romClassTableEntry entry;158159entry.romClass = romClass;160return hashTableRemove(hashTable, &entry);161}162163164