// SPDX-License-Identifier: GPL-2.0 #include <linux/union_find.h> /** * uf_find - Find the root of a node and perform path compression * @node: the node to find the root of * * This function returns the root of the node by following the parent * pointers. It also performs path compression, making the tree shallower. * * Returns the root node of the set containing node. */ struct uf_node *uf_find(struct uf_node *node) { struct uf_node *parent; while (node->parent != node) { parent = node->parent; node->parent = parent->parent; node = parent; } return node; } /** * uf_union - Merge two sets, using union by rank * @node1: the first node * @node2: the second node * * This function merges the sets containing node1 and node2, by comparing * the ranks to keep the tree balanced. */ void uf_union(struct uf_node *node1, struct uf_node *node2) { struct uf_node *root1 = uf_find(node1); struct uf_node *root2 = uf_find(node2); if (root1 == root2) return; if (root1->rank < root2->rank) { root1->parent = root2; } else if (root1->rank > root2->rank) { root2->parent = root1; } else { root2->parent = root1; root1->rank++; } }