remove CX_LINKED_LIST_SWAP_SBO_SIZE - fixes #551

2 weeks ago

author
Mike Becker <universe@uap-core.de>
date
Tue, 07 Jan 2025 18:37:07 +0100 (2 weeks ago)
changeset 1113
dce04550fbef
parent 1112
22dc2163fffd
child 1114
ad5eeb256242

remove CX_LINKED_LIST_SWAP_SBO_SIZE - fixes #551

CHANGELOG file | annotate | diff | comparison | revisions
docs/src/install.md file | annotate | diff | comparison | revisions
src/cx/linked_list.h file | annotate | diff | comparison | revisions
src/linked_list.c file | annotate | diff | comparison | revisions
tests/test_list.c file | annotate | diff | comparison | revisions
--- a/CHANGELOG	Tue Jan 07 00:12:46 2025 +0100
+++ b/CHANGELOG	Tue Jan 07 18:37:07 2025 +0100
@@ -37,6 +37,7 @@
  * removes CMake
  * removes GTest dependency
  * removes flags to disable SBO in tests
+ * removes CX_LINKED_LIST_SWAP_SBO_SIZE (it's not really an optimization for linked lists)
  * fixes cx_strcmp() and cx_strcasecmp() not being useful for lexicographic ordering
  * fixes cx_hash_key_cxstr() evaluating the argument twice
  * fixes wrong link from UCX 2 documentation to UCX 3 documentation
--- a/docs/src/install.md	Tue Jan 07 00:12:46 2025 +0100
+++ b/docs/src/install.md	Tue Jan 07 18:37:07 2025 +0100
@@ -26,8 +26,6 @@
 --------------------------------- --------------------------------------------------------------------- ----------
 CX_ARRAY_SWAP_SBO_SIZE            The maximum item size in an array list that uses SBO.                 128
 
-CX_LINKED_LIST_SWAP_SBO_SIZE      The maximum item size that uses SBO swap instead of relinking.        128
-
 CX_LINKED_LIST_SORT_SBO_SIZE      The maximum list size that uses SBO during sort.                      1024
 
 CX_PRINTF_SBO_SIZE                The maximum string length printf.h uses stack memory for.             512
--- a/src/cx/linked_list.h	Tue Jan 07 00:12:46 2025 +0100
+++ b/src/cx/linked_list.h	Tue Jan 07 18:37:07 2025 +0100
@@ -44,12 +44,6 @@
 #endif
 
 /**
- * The maximum item size that uses SBO swap instead of relinking.
- *
- */
-extern const unsigned cx_linked_list_swap_sbo_size;
-
-/**
  * Allocates a linked list for storing elements with @p elem_size bytes each.
  *
  * If @p elem_size is #CX_STORE_POINTERS, the created list stores pointers instead of
--- a/src/linked_list.c	Tue Jan 07 00:12:46 2025 +0100
+++ b/src/linked_list.c	Tue Jan 07 18:37:07 2025 +0100
@@ -811,11 +811,6 @@
     list->collection.size = 0;
 }
 
-#ifndef CX_LINKED_LIST_SWAP_SBO_SIZE
-#define CX_LINKED_LIST_SWAP_SBO_SIZE 128
-#endif
-const unsigned cx_linked_list_swap_sbo_size = CX_LINKED_LIST_SWAP_SBO_SIZE;
-
 static int cx_ll_swap(
         struct cx_list_s *list,
         size_t i,
@@ -894,41 +889,33 @@
         }
     }
 
-    if (list->collection.elem_size > CX_LINKED_LIST_SWAP_SBO_SIZE) {
-        cx_linked_list_node *prev = nleft->prev;
-        cx_linked_list_node *next = nright->next;
-        cx_linked_list_node *midstart = nleft->next;
-        cx_linked_list_node *midend = nright->prev;
+    cx_linked_list_node *prev = nleft->prev;
+    cx_linked_list_node *next = nright->next;
+    cx_linked_list_node *midstart = nleft->next;
+    cx_linked_list_node *midend = nright->prev;
 
-        if (prev == NULL) {
-            ll->begin = nright;
-        } else {
-            prev->next = nright;
-        }
-        nright->prev = prev;
-        if (midstart == nright) {
-            // special case: both nodes are adjacent
-            nright->next = nleft;
-            nleft->prev = nright;
-        } else {
-            // likely case: a chain is between the two nodes
-            nright->next = midstart;
-            midstart->prev = nright;
-            midend->next = nleft;
-            nleft->prev = midend;
-        }
-        nleft->next = next;
-        if (next == NULL) {
-            ll->end = nleft;
-        } else {
-            next->prev = nleft;
-        }
+    if (prev == NULL) {
+        ll->begin = nright;
+    } else {
+        prev->next = nright;
+    }
+    nright->prev = prev;
+    if (midstart == nright) {
+        // special case: both nodes are adjacent
+        nright->next = nleft;
+        nleft->prev = nright;
     } else {
-        // swap payloads to avoid relinking
-        char buf[CX_LINKED_LIST_SWAP_SBO_SIZE];
-        memcpy(buf, nleft->payload, list->collection.elem_size);
-        memcpy(nleft->payload, nright->payload, list->collection.elem_size);
-        memcpy(nright->payload, buf, list->collection.elem_size);
+        // likely case: a chain is between the two nodes
+        nright->next = midstart;
+        midstart->prev = nright;
+        midend->next = nleft;
+        nleft->prev = midend;
+    }
+    nleft->next = next;
+    if (next == NULL) {
+        ll->end = nleft;
+    } else {
+        next->prev = nleft;
     }
 
     return 0;
--- a/tests/test_list.c	Tue Jan 07 00:12:46 2025 +0100
+++ b/tests/test_list.c	Tue Jan 07 18:37:07 2025 +0100
@@ -1608,12 +1608,6 @@
     }
 })
 
-CX_TEST(test_list_ll_swap_no_sbo) {
-    set_up_combo
-        CxList *list = cxLinkedListCreate(alloc, cx_cmp_int, 2*cx_linked_list_swap_sbo_size);
-        CX_TEST_CALL_SUBROUTINE(test_list_verify_swap, list, false);
-    tear_down_combo
-}
 CX_TEST(test_list_arl_swap_no_sbo) {
     set_up_combo
         CxList *list = cxArrayListCreate(alloc, cx_cmp_int, 2*cx_array_swap_sbo_size, 8);
@@ -2033,7 +2027,6 @@
     cx_test_register(suite, test_list_pll_at);
     cx_test_register(suite, test_list_ll_swap);
     cx_test_register(suite, test_list_pll_swap);
-    cx_test_register(suite, test_list_ll_swap_no_sbo);
     cx_test_register(suite, test_list_ll_find);
     cx_test_register(suite, test_list_pll_find);
     cx_test_register(suite, test_list_ll_sort);

mercurial