-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Loading status checks…
Hashtable backend
Replace the ad-hoc arrays used to handle symbols with a hash table imprementation provided by `tommyds` [1], in hopes of improving overall performance of the relocation phase. * Add `tommyds` submodule, and integrate it with building and (hopefully) CI * Split `symbols` files into `symbols_lib` and `symbols_comp` for more modularity * Replace symbol storage in `symbols_*.h` with `tommyds` hashtable implementations [1] https://www.tommyds.it/doc/index.html
Showing
14 changed files
with
307 additions
and
185 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,3 +4,6 @@ | |
[submodule "third-party/tomlc99"] | ||
path = third-party/tomlc99 | ||
url = https://github.com/cktan/tomlc99 | ||
[submodule "third-party/tommyds"] | ||
path = third-party/tommyds | ||
url = [email protected]:amadvance/tommyds.git |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
#ifndef _CHERICOMP_SYMBOLS_COMP_H | ||
#define _CHERICOMP_SYMBOLS_COMP_H | ||
|
||
#include "symbols.h" | ||
#include "symbols_lib.h" | ||
|
||
typedef tommy_hashtable comp_symbol_list; | ||
typedef struct CompSymbol comp_symbol; | ||
|
||
/* Struct representing a wrapper around a LibDependencySymbol, in order to | ||
* facilitate compartment-level searching | ||
*/ | ||
struct CompSymbol | ||
{ | ||
struct LibDependencySymbol *sym_ref; | ||
size_t sym_lib_idx; | ||
tommy_node node; | ||
}; | ||
|
||
comp_symbol_list * | ||
comp_syms_init(); | ||
void | ||
comp_syms_clean(comp_symbol_list *); | ||
void | ||
comp_syms_clean_deep(comp_symbol_list *); | ||
void | ||
comp_syms_insert(comp_symbol *, comp_symbol_list *); | ||
comp_symbol * | ||
comp_syms_search(const char *, comp_symbol_list *); | ||
comp_symbol ** | ||
comp_syms_find_all(const char *, comp_symbol_list *); | ||
|
||
void update_comp_syms(comp_symbol_list*, lib_symbol_list *, const size_t); | ||
|
||
#endif // _CHERICOMP_SYMBOLS_COMP_H |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
#ifndef _CHERICOMP_SYMBOLS_LIB_H | ||
#define _CHERICOMP_SYMBOLS_LIB_H | ||
|
||
#include "symbols.h" | ||
|
||
typedef tommy_hashtable lib_symbol_list; | ||
typedef struct LibDependencySymbol lib_symbol; | ||
|
||
/* Struct representing a symbol entry of a dependency library | ||
*/ | ||
struct LibDependencySymbol | ||
{ | ||
char *sym_name; | ||
void *sym_offset; | ||
unsigned short sym_type; | ||
unsigned short sym_bind; | ||
uint16_t sym_shndx; | ||
tommy_node node; | ||
}; | ||
|
||
lib_symbol_list * | ||
lib_syms_init(); | ||
void | ||
lib_syms_clean(lib_symbol_list *); | ||
void | ||
lib_syms_clean_deep(lib_symbol_list *); | ||
void | ||
lib_syms_insert(lib_symbol *, lib_symbol_list *); | ||
lib_symbol * | ||
lib_syms_search(const char *, lib_symbol_list *); | ||
lib_symbol ** | ||
lib_syms_find_all(const char *, lib_symbol_list *); | ||
void | ||
lib_syms_print(lib_symbol_list*); | ||
|
||
#endif // _CHERICOMP_SYMBOLS_LIB_H |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
CFLAGS += --shared -fPIC | ||
|
||
TARGET = libtommyds.a | ||
SOURCES = tommy.c | ||
OBJECTS = $(SOURCES:.c=.o) | ||
|
||
all: $(TARGET) | ||
|
||
$(TARGET): $(OBJECTS) | ||
ar rcs $@ $^ |