diff options
Diffstat (limited to 'kern/rdxtree.c')
-rw-r--r-- | kern/rdxtree.c | 30 |
1 files changed, 15 insertions, 15 deletions
diff --git a/kern/rdxtree.c b/kern/rdxtree.c index 77005b64..678ec176 100644 --- a/kern/rdxtree.c +++ b/kern/rdxtree.c @@ -238,7 +238,7 @@ rdxtree_node_insert(struct rdxtree_node *node, unsigned short index, assert(node->entries[index] == NULL); node->nr_entries++; - llsync_assign_ptr(node->entries[index], entry); + llsync_store_ptr(node->entries[index], entry); } static inline void @@ -255,7 +255,7 @@ rdxtree_node_remove(struct rdxtree_node *node, unsigned short index) assert(node->entries[index] != NULL); node->nr_entries--; - llsync_assign_ptr(node->entries[index], NULL); + llsync_store_ptr(node->entries[index], NULL); } static inline void * @@ -267,7 +267,7 @@ rdxtree_node_find(struct rdxtree_node *node, unsigned short *indexp) index = *indexp; while (index < ARRAY_SIZE(node->entries)) { - ptr = rdxtree_entry_addr(llsync_read_ptr(node->entries[index])); + ptr = rdxtree_entry_addr(llsync_load_ptr(node->entries[index])); if (ptr != NULL) { *indexp = index; @@ -355,7 +355,7 @@ rdxtree_shrink(struct rdxtree *tree) rdxtree_node_unlink(rdxtree_entry_addr(entry)); } - llsync_assign_ptr(tree->root, entry); + llsync_store_ptr(tree->root, entry); /* * There is still one valid entry (the first one) in this node. It @@ -410,7 +410,7 @@ rdxtree_grow(struct rdxtree *tree, rdxtree_key_t key) rdxtree_node_insert(node, 0, tree->root); tree->height++; - llsync_assign_ptr(tree->root, rdxtree_node_to_entry(node)); + llsync_store_ptr(tree->root, rdxtree_node_to_entry(node)); root = node; } while (new_height > tree->height); @@ -433,7 +433,7 @@ rdxtree_cleanup(struct rdxtree *tree, struct rdxtree_node *node) if (node->parent == NULL) { tree->height = 0; - llsync_assign_ptr(tree->root, NULL); + llsync_store_ptr(tree->root, NULL); rdxtree_node_schedule_destruction(node); break; } @@ -488,7 +488,7 @@ rdxtree_insert_common(struct rdxtree *tree, rdxtree_key_t key, return ERROR_BUSY; } - llsync_assign_ptr(tree->root, ptr); + llsync_store_ptr(tree->root, ptr); if (slotp != NULL) { *slotp = &tree->root; @@ -516,7 +516,7 @@ rdxtree_insert_common(struct rdxtree *tree, rdxtree_key_t key, } if (prev == NULL) { - llsync_assign_ptr(tree->root, rdxtree_node_to_entry(node)); + llsync_store_ptr(tree->root, rdxtree_node_to_entry(node)); } else { rdxtree_node_link(node, prev, index); rdxtree_node_insert_node(prev, index, node); @@ -565,7 +565,7 @@ rdxtree_insert_alloc_common(struct rdxtree *tree, void *ptr, if (unlikely(height == 0)) { if (tree->root == NULL) { - llsync_assign_ptr(tree->root, ptr); + llsync_store_ptr(tree->root, ptr); *keyp = 0; if (slotp != NULL) { @@ -661,7 +661,7 @@ rdxtree_remove(struct rdxtree *tree, rdxtree_key_t key) node = rdxtree_entry_addr(tree->root); if (unlikely(height == 0)) { - llsync_assign_ptr(tree->root, NULL); + llsync_store_ptr(tree->root, NULL); return node; } @@ -700,7 +700,7 @@ rdxtree_lookup_common(const struct rdxtree *tree, rdxtree_key_t key, unsigned short height, shift, index; void *entry; - entry = llsync_read_ptr(tree->root); + entry = llsync_load_ptr(tree->root); if (entry == NULL) { node = NULL; @@ -731,7 +731,7 @@ rdxtree_lookup_common(const struct rdxtree *tree, rdxtree_key_t key, prev = node; index = (unsigned short)(key >> shift) & RDXTREE_RADIX_MASK; - entry = llsync_read_ptr(node->entries[index]); + entry = llsync_load_ptr(node->entries[index]); node = rdxtree_entry_addr(entry); shift -= RDXTREE_RADIX; height--; @@ -755,7 +755,7 @@ rdxtree_replace_slot(void **slot, void *ptr) old = *slot; assert(old != NULL); rdxtree_assert_alignment(old); - llsync_assign_ptr(*slot, ptr); + llsync_store_ptr(*slot, ptr); return old; } @@ -767,7 +767,7 @@ rdxtree_walk_next(struct rdxtree *tree, struct rdxtree_iter *iter) rdxtree_key_t key; void *entry; - entry = llsync_read_ptr(tree->root); + entry = llsync_load_ptr(tree->root); if (entry == NULL) { return NULL; @@ -863,7 +863,7 @@ rdxtree_remove_all(struct rdxtree *tree) if (tree->height == 0) { if (tree->root != NULL) { - llsync_assign_ptr(tree->root, NULL); + llsync_store_ptr(tree->root, NULL); } return; |