Skip to content

Commit

Permalink
Add more ways to jit_invalidate
Browse files Browse the repository at this point in the history
  • Loading branch information
Theodore Dubois committed Dec 21, 2020
1 parent 093041a commit 76c105b
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 17 deletions.
33 changes: 18 additions & 15 deletions jit/jit.c
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,6 @@ struct jit *jit_new(struct mmu *mmu) {
jit->mmu = mmu;
jit_resize_hash(jit, JIT_INITIAL_HASH_SIZE);
jit->page_hash = calloc(JIT_PAGE_HASH_SIZE, sizeof(*jit->page_hash));
for (size_t i = 0; i < JIT_PAGE_HASH_SIZE; i++) {
list_init(&jit->page_hash[i].blocks[0]);
list_init(&jit->page_hash[i].blocks[1]);
}
list_init(&jit->jetsam);
lock_init(&jit->lock);
wrlock_init(&jit->jetsam_lock);
Expand All @@ -48,22 +44,31 @@ static inline struct list *blocks_list(struct jit *jit, page_t page, int i) {
return &jit->page_hash[page % JIT_PAGE_HASH_SIZE].blocks[i];
}

void jit_invalidate_page(struct jit *jit, page_t page) {
void jit_invalidate_range(struct jit *jit, page_t start, page_t end) {
lock(&jit->lock);
struct jit_block *block, *tmp;
for (int i = 0; i <= 1; i++) {
struct list *blocks = blocks_list(jit, page, i);
if (list_null(blocks))
continue;
list_for_each_entry_safe(blocks, block, tmp, page[i]) {
jit_block_disconnect(jit, block);
block->is_jetsam = true;
list_add(&jit->jetsam, &block->jetsam);
for (page_t page = start; page < end; page++) {
for (int i = 0; i <= 1; i++) {
struct list *blocks = blocks_list(jit, page, i);
if (list_null(blocks))
continue;
list_for_each_entry_safe(blocks, block, tmp, page[i]) {
jit_block_disconnect(jit, block);
block->is_jetsam = true;
list_add(&jit->jetsam, &block->jetsam);
}
}
}
unlock(&jit->lock);
}

void jit_invalidate_page(struct jit *jit, page_t page) {
jit_invalidate_range(jit, page, page + 1);
}
void jit_invalidate_all(struct jit *jit) {
jit_invalidate_range(jit, 0, MEM_PAGES);
}

static void jit_resize_hash(struct jit *jit, size_t new_size) {
TRACE_(verbose, "%d resizing hash to %lu, using %lu bytes for gadgets\n", current ? current->pid : 0, new_size, jit->mem_used);
struct list *new_hash = calloc(new_size, sizeof(struct list));
Expand All @@ -89,8 +94,6 @@ static void jit_insert(struct jit *jit, struct jit_block *block) {
jit_resize_hash(jit, jit->hash_size * 2);

list_init_add(&jit->hash[block->addr % jit->hash_size], &block->chain);
if (blocks_list(jit, PAGE(block->addr), 0) == NULL)
return;
list_init_add(blocks_list(jit, PAGE(block->addr), 0), &block->page[0]);
if (PAGE(block->addr) != PAGE(block->end_addr))
list_init_add(blocks_list(jit, PAGE(block->end_addr), 1), &block->page[1]);
Expand Down
7 changes: 5 additions & 2 deletions jit/jit.h
Original file line number Diff line number Diff line change
Expand Up @@ -66,9 +66,12 @@ struct jit_block {
struct jit *jit_new(struct mmu *mmu);
void jit_free(struct jit *jit);

// Invalidate all jit blocks in the given page. Locks the jit. Should only be
// called by memory.c in conjunction with mem_changed.
// Invalidate all jit blocks in pages start (inclusive) to end (exclusive).
// Locks the jit. Should only be called by memory.c in conjunction with
// mem_changed.
void jit_invalidate_range(struct jit *jit, page_t start, page_t end);
void jit_invalidate_page(struct jit *jit, page_t page);
void jit_invalidate_all(struct jit *jit);

#endif

Expand Down

0 comments on commit 76c105b

Please sign in to comment.