/* DWARF 2 abbrev table cache Copyright (C) 2022-2023 Free Software Foundation, Inc. This file is part of GDB. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program 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 General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include "defs.h" #include "dwarf2/read.h" #include "dwarf2/abbrev-cache.h" /* Hash function for an abbrev table. */ hashval_t abbrev_cache::hash_table (const void *item) { const struct abbrev_table *table = (const struct abbrev_table *) item; return to_underlying (table->sect_off); } /* Comparison function for abbrev table. */ int abbrev_cache::eq_table (const void *lhs, const void *rhs) { const struct abbrev_table *l_table = (const struct abbrev_table *) lhs; const search_key *key = (const search_key *) rhs; return (l_table->section == key->section && l_table->sect_off == key->offset); } abbrev_cache::abbrev_cache () : m_tables (htab_create_alloc (20, hash_table, eq_table, htab_delete_entry, xcalloc, xfree)) { } void abbrev_cache::add (abbrev_table_up table) { /* We allow this as a convenience to the caller. */ if (table == nullptr) return; search_key key = { table->section, table->sect_off }; void **slot = htab_find_slot_with_hash (m_tables.get (), &key, to_underlying (table->sect_off), INSERT); /* If this one already existed, then it should have been reused. */ gdb_assert (*slot == nullptr); *slot = (void *) table.release (); }