[PATCH 0/2] lib: clarify comparison function requirements

From: Kuan-Wei Chiu
Date: Tue Dec 24 2024 - 11:39:44 EST


Add a detailed explanation in the sort_r/list_sort kernel doc comment
specifying that the comparison function must satisfy antisymmetry and
transitivity. These properties are essential for the sorting algorithm
to produce correct results.

Issues have arisen in the past [1][2][3][4] where comparison functions
violated the transitivity property, causing sorting algorithms to fail
to correctly order elements. While these requirements may seem
straightforward, they are commonly misunderstood or overlooked, leading
to bugs. Highlighting these properties in the documentation will help
prevent such mistakes in the future.

Link: https://lore.kernel.org/lkml/20240701205639.117194-1-visitorckw@xxxxxxxxx [1]
Link: https://lore.kernel.org/lkml/20241203202228.1274403-1-visitorckw@xxxxxxxxx [2]
Link: https://lore.kernel.org/lkml/20241209134226.1939163-1-visitorckw@xxxxxxxxx [3]
Link: https://lore.kernel.org/lkml/20241209145728.1975311-1-visitorckw@xxxxxxxxx [4]

Kuan-Wei Chiu (2):
lib/sort: clarify comparison function requirements in sort_r()
lib/list_sort: clarify comparison function requirements in sort_r()

lib/list_sort.c | 7 +++++++
lib/sort.c | 7 +++++++
2 files changed, 14 insertions(+)

--
2.34.1