Blame SOURCES/0180-cxl-lib-Maintain-decoders-in-id-order.patch

26ccd9
From 06ae7118aaa74aa2139004fa12b4910bc15236de Mon Sep 17 00:00:00 2001
26ccd9
From: Dan Williams <dan.j.williams@intel.com>
26ccd9
Date: Thu, 14 Jul 2022 10:02:21 -0700
26ccd9
Subject: [PATCH 180/217] cxl/lib: Maintain decoders in id order
26ccd9
26ccd9
Given that decoder instance order is fundamental to the DPA translation
26ccd9
sequence for endpoint decoders, enforce that cxl_decoder_for_each() returns
26ccd9
decoders in instance order. Otherwise, they show up in readddir() order
26ccd9
which is not predictable.
26ccd9
26ccd9
Add a list_add_sorted() to generically handle inserting into a sorted list.
26ccd9
26ccd9
Link: https://lore.kernel.org/r/165781814167.1555691.14895625637451030942.stgit@dwillia2-xfh.jf.intel.com
26ccd9
Reviewed-by: Davidlohr Bueso <dave@stgolabs.net>
26ccd9
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
26ccd9
Signed-off-by: Vishal Verma <vishal.l.verma@intel.com>
26ccd9
---
26ccd9
 cxl/lib/libcxl.c |  8 +++++++-
26ccd9
 util/list.h      | 39 +++++++++++++++++++++++++++++++++++++++
26ccd9
 2 files changed, 46 insertions(+), 1 deletion(-)
26ccd9
 create mode 100644 util/list.h
26ccd9
26ccd9
diff --git a/cxl/lib/libcxl.c b/cxl/lib/libcxl.c
26ccd9
index 6f4d64d..ea597f6 100644
26ccd9
--- a/cxl/lib/libcxl.c
26ccd9
+++ b/cxl/lib/libcxl.c
26ccd9
@@ -19,6 +19,7 @@
26ccd9
 #include <ccan/short_types/short_types.h>
26ccd9
 
26ccd9
 #include <util/log.h>
26ccd9
+#include <util/list.h>
26ccd9
 #include <util/size.h>
26ccd9
 #include <util/sysfs.h>
26ccd9
 #include <util/bitmap.h>
26ccd9
@@ -909,6 +910,11 @@ cxl_endpoint_get_memdev(struct cxl_endpoint *endpoint)
26ccd9
 	return NULL;
26ccd9
 }
26ccd9
 
26ccd9
+static int decoder_id_cmp(struct cxl_decoder *d1, struct cxl_decoder *d2)
26ccd9
+{
26ccd9
+	return d1->id - d2->id;
26ccd9
+}
26ccd9
+
26ccd9
 static void *add_cxl_decoder(void *parent, int id, const char *cxldecoder_base)
26ccd9
 {
26ccd9
 	const char *devname = devpath_to_devname(cxldecoder_base);
26ccd9
@@ -1050,7 +1056,7 @@ static void *add_cxl_decoder(void *parent, int id, const char *cxldecoder_base)
26ccd9
 			return decoder_dup;
26ccd9
 		}
26ccd9
 
26ccd9
-	list_add(&port->decoders, &decoder->list);
26ccd9
+	list_add_sorted(&port->decoders, decoder, list, decoder_id_cmp);
26ccd9
 
26ccd9
 	free(path);
26ccd9
 	return decoder;
26ccd9
diff --git a/util/list.h b/util/list.h
26ccd9
new file mode 100644
26ccd9
index 0000000..cb77271
26ccd9
--- /dev/null
26ccd9
+++ b/util/list.h
26ccd9
@@ -0,0 +1,39 @@
26ccd9
+/* SPDX-License-Identifier: GPL-2.0 */
26ccd9
+/* Copyright (C) 2022 Intel Corporation. All rights reserved. */
26ccd9
+#ifndef _NDCTL_LIST_H_
26ccd9
+#define _NDCTL_LIST_H_
26ccd9
+
26ccd9
+#include <ccan/list/list.h>
26ccd9
+
26ccd9
+#define list_add_sorted(head, n, node, cmp)                                    \
26ccd9
+	do {                                                                   \
26ccd9
+		struct list_head *__head = (head);                             \
26ccd9
+		typeof(n) __iter, __next;                                      \
26ccd9
+		typeof(n) __new = (n);                                         \
26ccd9
+                                                                               \
26ccd9
+		if (list_empty(__head)) {                                      \
26ccd9
+			list_add(__head, &__new->node);                        \
26ccd9
+			break;                                                 \
26ccd9
+		}                                                              \
26ccd9
+                                                                               \
26ccd9
+		list_for_each (__head, __iter, node) {                         \
26ccd9
+			if (cmp(__new, __iter) < 0) {                          \
26ccd9
+				list_add_before(__head, &__iter->node,         \
26ccd9
+						&__new->node);                 \
26ccd9
+				break;                                         \
26ccd9
+			}                                                      \
26ccd9
+			__next = list_next(__head, __iter, node);              \
26ccd9
+			if (!__next) {                                         \
26ccd9
+				list_add_after(__head, &__iter->node,          \
26ccd9
+					       &__new->node);                  \
26ccd9
+				break;                                         \
26ccd9
+			}                                                      \
26ccd9
+			if (cmp(__new, __next) < 0) {                          \
26ccd9
+				list_add_before(__head, &__next->node,         \
26ccd9
+						&__new->node);                 \
26ccd9
+				break;                                         \
26ccd9
+			}                                                      \
26ccd9
+		}                                                              \
26ccd9
+	} while (0)
26ccd9
+
26ccd9
+#endif /* _NDCTL_LIST_H_ */
26ccd9
-- 
26ccd9
2.27.0
26ccd9