diff options
author | Simon Marchi <simon.marchi@efficios.com> | 2024-11-04 13:27:32 -0500 |
---|---|---|
committer | Simon Marchi <simon.marchi@polymtl.ca> | 2024-11-25 22:07:03 -0500 |
commit | 020c5193ac86ac753441a3302b0f2bdc10d5c616 (patch) | |
tree | e0d9b67acc74a9c4e3da237475c1bee53f826beb /gdb/dwarf2/abbrev-table-cache.c | |
parent | d73b6fc032c9c3100867934929b3b23b2505e056 (diff) | |
download | gdb-020c5193ac86ac753441a3302b0f2bdc10d5c616.zip gdb-020c5193ac86ac753441a3302b0f2bdc10d5c616.tar.gz gdb-020c5193ac86ac753441a3302b0f2bdc10d5c616.tar.bz2 |
gdb: rename abbrev_cache to abbrev_table_cache
This cache holds `abbrev_table` objects, so I think it's clearer and
more consistent to name it `abbrev_table_cache`. Rename it and
everything that goes along with it.
Change-Id: I43448c0aa538dd2c3ae5efd2f7b3e7b827409d8c
Approved-By: Tom Tromey <tom@tromey.com>
Diffstat (limited to 'gdb/dwarf2/abbrev-table-cache.c')
-rw-r--r-- | gdb/dwarf2/abbrev-table-cache.c | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/gdb/dwarf2/abbrev-table-cache.c b/gdb/dwarf2/abbrev-table-cache.c new file mode 100644 index 0000000..c29cd09 --- /dev/null +++ b/gdb/dwarf2/abbrev-table-cache.c @@ -0,0 +1,63 @@ +/* DWARF 2 abbrev table cache + + Copyright (C) 2022-2024 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 <http://www.gnu.org/licenses/>. */ + +#include "dwarf2/abbrev-table-cache.h" + +/* Hash function for an abbrev table. */ + +hashval_t +abbrev_table_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_table_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_table_cache::abbrev_table_cache () + : m_tables (htab_create_alloc (20, hash_table, eq_table, + htab_delete_entry<abbrev_table>, + xcalloc, xfree)) +{ +} + +void +abbrev_table_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 (); +} |