ksphinx.addnodesdocument)}( rawsourcechildren]( translations LanguagesNode)}(hhh](h pending_xref)}(hhh]docutils.nodesTextChinese (Simplified)}parenthsba attributes}(ids]classes]names]dupnames]backrefs] refdomainstdreftypedoc reftarget!/translations/zh_CN/core-api/listmodnameN classnameN refexplicitutagnamehhh ubh)}(hhh]hChinese (Traditional)}hh2sbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget!/translations/zh_TW/core-api/listmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hItalian}hhFsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget!/translations/it_IT/core-api/listmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hJapanese}hhZsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget!/translations/ja_JP/core-api/listmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hKorean}hhnsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget!/translations/ko_KR/core-api/listmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hSpanish}hhsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget!/translations/sp_SP/core-api/listmodnameN classnameN refexplicituh1hhh ubeh}(h]h ]h"]h$]h&]current_languageEnglishuh1h hh _documenthsourceNlineNubhcomment)}(h!SPDX-License-Identifier: GPL-2.0+h]h!SPDX-License-Identifier: GPL-2.0+}hhsbah}(h]h ]h"]h$]h&] xml:spacepreserveuh1hhhhhh;/var/lib/git/docbuild/linux/Documentation/core-api/list.rsthKubhsection)}(hhh](htitle)}(hLinked Lists in Linuxh]hLinked Lists in Linux}(hhhhhNhNubah}(h]h ]h"]h$]h&]refidid1uh1hhhhhhhhKubh field_list)}(hhh]hfield)}(hhh](h field_name)}(hAuthorh]hAuthor}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhhKubh field_body)}(h6Nicolas Frattaroli h]h paragraph)}(h5Nicolas Frattaroli h](hNicolas Frattaroli <}(hhhhhNhNubh reference)}(h nicolas.frattaroli@collabora.comh]h nicolas.frattaroli@collabora.com}(hhhhhNhNubah}(h]h ]h"]h$]h&]refuri'mailto:nicolas.frattaroli@collabora.comuh1hhhubh>}(hhhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhhubah}(h]h ]h"]h$]h&]uh1hhhubeh}(h]h ]h"]h$]h&]uh1hhhhKhhhhubah}(h]h ]h"]h$]h&]uh1hhhhhhhhKubhtopic)}(h Contents h](h)}(hContentsh]hContents}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hhhK ubh bullet_list)}(hhh]h list_item)}(hhh](h)}(hhh]h)}(hhh]hLinked Lists in Linux}(hjDhhhNhNubah}(h]hah ]h"]h$]h&]refidlinked-lists-in-linuxuh1hhjAubah}(h]h ]h"]h$]h&]uh1hhj>ubj8)}(hhh](j=)}(hhh]h)}(hhh]h)}(hhh]h Introduction}(hjbhhhNhNubah}(h]id2ah ]h"]h$]h&]refid introductionuh1hhj_ubah}(h]h ]h"]h$]h&]uh1hhj\ubah}(h]h ]h"]h$]h&]uh1j<hjYubj=)}(hhh](h)}(hhh]h)}(hhh]h+Linux implementation of doubly linked lists}(hjhhhNhNubah}(h]id3ah ]h"]h$]h&]refid+linux-implementation-of-doubly-linked-listsuh1hhjubah}(h]h ]h"]h$]h&]uh1hhj~ubj8)}(hhh](j=)}(hhh]h)}(hhh]h)}(hhh]hDeclaring a node}(hjhhhNhNubah}(h]id4ah ]h"]h$]h&]refiddeclaring-a-nodeuh1hhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]h!Declaring and initializing a list}(hjhhhNhNubah}(h]id5ah ]h"]h$]h&]refid!declaring-and-initializing-a-listuh1hhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]hAdding nodes to the list}(hjhhhNhNubah}(h]id6ah ]h"]h$]h&]refidadding-nodes-to-the-listuh1hhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]hTraversing the list}(hj hhhNhNubah}(h]id7ah ]h"]h$]h&]refidtraversing-the-listuh1hhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]hRemoving nodes from the list}(hj+hhhNhNubah}(h]id8ah ]h"]h$]h&]refidremoving-nodes-from-the-listuh1hhj(ubah}(h]h ]h"]h$]h&]uh1hhj%ubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]h Traversing whilst removing nodes}(hjMhhhNhNubah}(h]id9ah ]h"]h$]h&]refid traversing-whilst-removing-nodesuh1hhjJubah}(h]h ]h"]h$]h&]uh1hhjGubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]hCutting a list}(hjohhhNhNubah}(h]id10ah ]h"]h$]h&]refidcutting-a-listuh1hhjlubah}(h]h ]h"]h$]h&]uh1hhjiubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]h Moving entries and partial lists}(hjhhhNhNubah}(h]id11ah ]h"]h$]h&]refid moving-entries-and-partial-listsuh1hhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]hRotating entries}(hjhhhNhNubah}(h]id12ah ]h"]h$]h&]refidrotating-entriesuh1hhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]hSwapping entries}(hjhhhNhNubah}(h]id13ah ]h"]h$]h&]refidswapping-entriesuh1hhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]hSplicing two lists together}(hjhhhNhNubah}(h]id14ah ]h"]h$]h&]refidsplicing-two-lists-togetheruh1hhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]hConcurrency considerations}(hjhhhNhNubah}(h]id15ah ]h"]h$]h&]refidconcurrency-considerationsuh1hhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]uh1j<hjubj=)}(hhh]h)}(hhh]h)}(hhh]hFurther reading}(hj;hhhNhNubah}(h]id16ah ]h"]h$]h&]refidfurther-readinguh1hhj8ubah}(h]h ]h"]h$]h&]uh1hhj5ubah}(h]h ]h"]h$]h&]uh1j<hjubeh}(h]h ]h"]h$]h&]uh1j7hj~ubeh}(h]h ]h"]h$]h&]uh1j<hjYubj=)}(hhh]h)}(hhh]h)}(hhh]h Full List API}(hjihhhNhNubah}(h]id17ah ]h"]h$]h&]refid full-list-apiuh1hhjfubah}(h]h ]h"]h$]h&]uh1hhjcubah}(h]h ]h"]h$]h&]uh1j<hjYubeh}(h]h ]h"]h$]h&]uh1j7hj>ubeh}(h]h ]h"]h$]h&]uh1j<hj9ubah}(h]h ]h"]h$]h&]uh1j7hj%hhhNhNubeh}(h]contentsah ]contentsah"]contentsah$]h&]uh1j#hhhK hhhhubh)}(hhh](h)}(h Introductionh]h Introduction}(hjhhhNhNubah}(h]h ]h"]h$]h&]hjkuh1hhjhhhhhK ubh)}(hX<Linked lists are one of the most basic data structures used in many programs. The Linux kernel implements several different flavours of linked lists. The purpose of this document is not to explain linked lists in general, but to show new kernel developers how to use the Linux kernel implementations of linked lists.h]hX<Linked lists are one of the most basic data structures used in many programs. The Linux kernel implements several different flavours of linked lists. The purpose of this document is not to explain linked lists in general, but to show new kernel developers how to use the Linux kernel implementations of linked lists.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hXPlease note that while linked lists certainly are ubiquitous, they are rarely the best data structure to use in cases where a simple array doesn't already suffice. In particular, due to their poor data locality, linked lists are a bad choice in situations where performance may be of consideration. Familiarizing oneself with other in-kernel generic data structures, especially for concurrent accesses, is highly encouraged.h]hXPlease note that while linked lists certainly are ubiquitous, they are rarely the best data structure to use in cases where a simple array doesn’t already suffice. In particular, due to their poor data locality, linked lists are a bad choice in situations where performance may be of consideration. Familiarizing oneself with other in-kernel generic data structures, especially for concurrent accesses, is highly encouraged.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubeh}(h]jqah ]h"] introductionah$]h&]uh1hhhhhhhhK ubh)}(hhh](h)}(h+Linux implementation of doubly linked listsh]h+Linux implementation of doubly linked lists}(hjhhhNhNubah}(h]h ]h"]h$]h&]hjuh1hhjhhhhhKubh)}(h`Linux's linked list implementations can be used by including the header file ````.h](hOLinux’s linked list implementations can be used by including the header file }(hjhhhNhNubhliteral)}(h````h]h}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hThe doubly-linked list will likely be the most familiar to many readers. It's a list that can efficiently be traversed forwards and backwards.h]hThe doubly-linked list will likely be the most familiar to many readers. It’s a list that can efficiently be traversed forwards and backwards.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK!hjhhubh)}(hXThe Linux kernel's doubly-linked list is circular in nature. This means that to get from the head node to the tail, we can just travel one edge backwards. Similarly, to get from the tail node to the head, we can simply travel forwards "beyond" the tail and arrive back at the head.h]hXThe Linux kernel’s doubly-linked list is circular in nature. This means that to get from the head node to the tail, we can just travel one edge backwards. Similarly, to get from the tail node to the head, we can simply travel forwards “beyond” the tail and arrive back at the head.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK$hjhhubh)}(hhh](h)}(hDeclaring a nodeh]hDeclaring a node}(hj&hhhNhNubah}(h]h ]h"]h$]h&]hjuh1hhj#hhhhhK*ubh)}(hA node in a doubly-linked list is declared by adding a struct list_head member to the data structure you wish to be contained in the list:h]hA node in a doubly-linked list is declared by adding a struct list_head member to the data structure you wish to be contained in the list:}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK,hj#hhubh literal_block)}(hstruct clown { unsigned long long shoe_size; const char *name; struct list_head node; /* the aforementioned member */ };h]hstruct clown { unsigned long long shoe_size; const char *name; struct list_head node; /* the aforementioned member */ };}hjDsbah}(h]h ]h"]h$]h&]hhforcelanguagechighlight_args}uh1jBhhhK/hj#hhubh)}(hXZThis may be an unfamiliar approach to some, as the classical explanation of a linked list is a list node data structure with pointers to the previous and next list node, as well the payload data. Linux chooses this approach because it allows for generic list modification code regardless of what data structure is contained within the list. Since the struct list_head member is not a pointer but part of the data structure proper, the container_of() pattern can be used by the list implementation to access the payload data regardless of its type, while staying oblivious to what said type actually is.h]hXZThis may be an unfamiliar approach to some, as the classical explanation of a linked list is a list node data structure with pointers to the previous and next list node, as well the payload data. Linux chooses this approach because it allows for generic list modification code regardless of what data structure is contained within the list. Since the struct list_head member is not a pointer but part of the data structure proper, the container_of() pattern can be used by the list implementation to access the payload data regardless of its type, while staying oblivious to what said type actually is.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK7hj#hhubeh}(h]jah ]h"]declaring a nodeah$]h&]uh1hhjhhhhhK*ubh)}(hhh](h)}(h!Declaring and initializing a listh]h!Declaring and initializing a list}(hjohhhNhNubah}(h]h ]h"]h$]h&]hjuh1hhjlhhhhhKAubh)}(hA doubly-linked list can then be declared as just another struct list_head, and initialized with the LIST_HEAD_INIT() macro during initial assignment, or with the INIT_LIST_HEAD() function later:h]hA doubly-linked list can then be declared as just another struct list_head, and initialized with the LIST_HEAD_INIT() macro during initial assignment, or with the INIT_LIST_HEAD() function later:}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKChjlhhubjC)}(hXstruct clown_car { int tyre_pressure[4]; struct list_head clowns; /* Looks like a node! */ }; /* ... Somewhere later in our driver ... */ static int circus_init(struct circus_priv *circus) { struct clown_car other_car = { .tyre_pressure = {10, 12, 11, 9}, .clowns = LIST_HEAD_INIT(other_car.clowns) }; INIT_LIST_HEAD(&circus->car.clowns); return 0; }h]hXstruct clown_car { int tyre_pressure[4]; struct list_head clowns; /* Looks like a node! */ }; /* ... Somewhere later in our driver ... */ static int circus_init(struct circus_priv *circus) { struct clown_car other_car = { .tyre_pressure = {10, 12, 11, 9}, .clowns = LIST_HEAD_INIT(other_car.clowns) }; INIT_LIST_HEAD(&circus->car.clowns); return 0; }}hjsbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhKGhjlhhubh)}(hA further point of confusion to some may be that the list itself doesn't really have its own type. The concept of the entire linked list and a struct list_head member that points to other entries in the list are one and the same.h]hA further point of confusion to some may be that the list itself doesn’t really have its own type. The concept of the entire linked list and a struct list_head member that points to other entries in the list are one and the same.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK\hjlhhubeh}(h]jah ]h"]!declaring and initializing a listah$]h&]uh1hhjhhhhhKAubh)}(hhh](h)}(hAdding nodes to the listh]hAdding nodes to the list}(hjhhhNhNubah}(h]h ]h"]h$]h&]hjuh1hhjhhhhhKbubh)}(hFAdding a node to the linked list is done through the list_add() macro.h]hFAdding a node to the linked list is done through the list_add() macro.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKdhjhhubh)}(hTWe'll return to our clown car example to illustrate how nodes get added to the list:h]hVWe’ll return to our clown car example to illustrate how nodes get added to the list:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKfhjhhubjC)}(hXstatic int circus_fill_car(struct circus_priv *circus) { struct clown_car *car = &circus->car; struct clown *grock; struct clown *dimitri; /* State 1 */ grock = kzalloc(sizeof(*grock), GFP_KERNEL); if (!grock) return -ENOMEM; grock->name = "Grock"; grock->shoe_size = 1000; /* Note that we're adding the "node" member */ list_add(&grock->node, &car->clowns); /* State 2 */ dimitri = kzalloc(sizeof(*dimitri), GFP_KERNEL); if (!dimitri) return -ENOMEM; dimitri->name = "Dimitri"; dimitri->shoe_size = 50; list_add(&dimitri->node, &car->clowns); /* State 3 */ return 0; }h]hXstatic int circus_fill_car(struct circus_priv *circus) { struct clown_car *car = &circus->car; struct clown *grock; struct clown *dimitri; /* State 1 */ grock = kzalloc(sizeof(*grock), GFP_KERNEL); if (!grock) return -ENOMEM; grock->name = "Grock"; grock->shoe_size = 1000; /* Note that we're adding the "node" member */ list_add(&grock->node, &car->clowns); /* State 2 */ dimitri = kzalloc(sizeof(*dimitri), GFP_KERNEL); if (!dimitri) return -ENOMEM; dimitri->name = "Dimitri"; dimitri->shoe_size = 50; list_add(&dimitri->node, &car->clowns); /* State 3 */ return 0; }}hjsbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhKihjhhubh)}(h/In State 1, our list of clowns is still empty::h]h.In State 1, our list of clowns is still empty:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubjC)}(hB .------. v | .--------. | | clowns |--' '--------'h]hB .------. v | .--------. | | clowns |--' '--------'}hjsbah}(h]h ]h"]h$]h&]hhuh1jBhhhKhjhhubh)}(hThis diagram shows the singular "clowns" node pointing at itself. In this diagram, and all following diagrams, only the forward edges are shown, to aid in clarity.h]hThis diagram shows the singular “clowns” node pointing at itself. In this diagram, and all following diagrams, only the forward edges are shown, to aid in clarity.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(h3In State 2, we've added Grock after the list head::h]h4In State 2, we’ve added Grock after the list head:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubjC)}(h .--------------------. v | .--------. .-------. | | clowns |---->| Grock |--' '--------' '-------'h]h .--------------------. v | .--------. .-------. | | clowns |---->| Grock |--' '--------' '-------'}hj#sbah}(h]h ]h"]h$]h&]hhuh1jBhhhKhjhhubh)}(hThis diagram shows the "clowns" node pointing at a new node labeled "Grock". The Grock node is pointing back at the "clowns" node.h]hThis diagram shows the “clowns” node pointing at a new node labeled “Grock”. The Grock node is pointing back at the “clowns” node.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hQIn State 3, we've added Dimitri after the list head, resulting in the following::h]hRIn State 3, we’ve added Dimitri after the list head, resulting in the following:}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubjC)}(h .------------------------------------. v | .--------. .---------. .-------. | | clowns |---->| Dimitri |---->| Grock |--' '--------' '---------' '-------'h]h .------------------------------------. v | .--------. .---------. .-------. | | clowns |---->| Dimitri |---->| Grock |--' '--------' '---------' '-------'}hjMsbah}(h]h ]h"]h$]h&]hhuh1jBhhhKhjhhubh)}(hThis diagram shows the "clowns" node pointing at a new node labeled "Dimitri", which then points at the node labeled "Grock". The "Grock" node still points back at the "clowns" node.h]hThis diagram shows the “clowns” node pointing at a new node labeled “Dimitri”, which then points at the node labeled “Grock”. The “Grock” node still points back at the “clowns” node.}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hIf we wanted to have Dimitri inserted at the end of the list instead, we'd use list_add_tail(). Our code would then look like this:h]hIf we wanted to have Dimitri inserted at the end of the list instead, we’d use list_add_tail(). Our code would then look like this:}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubjC)}(hstatic int circus_fill_car(struct circus_priv *circus) { /* ... */ list_add_tail(&dimitri->node, &car->clowns); /* State 3b */ return 0; }h]hstatic int circus_fill_car(struct circus_priv *circus) { /* ... */ list_add_tail(&dimitri->node, &car->clowns); /* State 3b */ return 0; }}hjwsbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhKhjhhubh)}(h$This results in the following list::h]h#This results in the following list:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubjC)}(h .------------------------------------. v | .--------. .-------. .---------. | | clowns |---->| Grock |---->| Dimitri |--' '--------' '-------' '---------'h]h .------------------------------------. v | .--------. .-------. .---------. | | clowns |---->| Grock |---->| Dimitri |--' '--------' '-------' '---------'}hjsbah}(h]h ]h"]h$]h&]hhuh1jBhhhKhjhhubh)}(hThis diagram shows the "clowns" node pointing at the node labeled "Grock", which points at the new node labeled "Dimitri". The node labeled "Dimitri" points back at the "clowns" node.h]hThis diagram shows the “clowns” node pointing at the node labeled “Grock”, which points at the new node labeled “Dimitri”. The node labeled “Dimitri” points back at the “clowns” node.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubeh}(h]jah ]h"]adding nodes to the listah$]h&]uh1hhjhhhhhKbubh)}(hhh](h)}(hTraversing the listh]hTraversing the list}(hjhhhNhNubah}(h]h ]h"]h$]h&]hjuh1hhjhhhhhKubh)}(hXTo iterate the list, we can loop through all nodes within the list with list_for_each().h]hXTo iterate the list, we can loop through all nodes within the list with list_for_each().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hJIn our clown example, this results in the following somewhat awkward code:h]hJIn our clown example, this results in the following somewhat awkward code:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubjC)}(hXstatic unsigned long long circus_get_max_shoe_size(struct circus_priv *circus) { unsigned long long res = 0; struct clown *e; struct list_head *cur; list_for_each(cur, &circus->car.clowns) { e = list_entry(cur, struct clown, node); if (e->shoe_size > res) res = e->shoe_size; } return res; }h]hXstatic unsigned long long circus_get_max_shoe_size(struct circus_priv *circus) { unsigned long long res = 0; struct clown *e; struct list_head *cur; list_for_each(cur, &circus->car.clowns) { e = list_entry(cur, struct clown, node); if (e->shoe_size > res) res = e->shoe_size; } return res; }}hjsbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhKhjhhubh)}(hThe list_entry() macro internally uses the aforementioned container_of() to retrieve the data structure instance that ``node`` is a member of.h](hvThe list_entry() macro internally uses the aforementioned container_of() to retrieve the data structure instance that }(hjhhhNhNubj)}(h``node``h]hnode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh is a member of.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hXBNote how the additional list_entry() call is a little awkward here. It's only there because we're iterating through the ``node`` members, but we really want to iterate through the payload, i.e. the ``struct clown`` that contains each node's struct list_head. For this reason, there is a second macro: list_for_each_entry()h](h|Note how the additional list_entry() call is a little awkward here. It’s only there because we’re iterating through the }(hjhhhNhNubj)}(h``node``h]hnode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhF members, but we really want to iterate through the payload, i.e. the }(hjhhhNhNubj)}(h``struct clown``h]h struct clown}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhn that contains each node’s struct list_head. For this reason, there is a second macro: list_for_each_entry()}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(h6Using it would change our code to something like this:h]h6Using it would change our code to something like this:}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubjC)}(hX?static unsigned long long circus_get_max_shoe_size(struct circus_priv *circus) { unsigned long long res = 0; struct clown *e; list_for_each_entry(e, &circus->car.clowns, node) { if (e->shoe_size > res) res = e->shoe_size; } return res; }h]hX?static unsigned long long circus_get_max_shoe_size(struct circus_priv *circus) { unsigned long long res = 0; struct clown *e; list_for_each_entry(e, &circus->car.clowns, node) { if (e->shoe_size > res) res = e->shoe_size; } return res; }}hjSsbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhKhjhhubh)}(hXThis eliminates the need for the list_entry() step, and our loop cursor is now of the type of our payload. The macro is given the member name that corresponds to the list's struct list_head within the clown data structure so that it can still walk the list.h]hXThis eliminates the need for the list_entry() step, and our loop cursor is now of the type of our payload. The macro is given the member name that corresponds to the list’s struct list_head within the clown data structure so that it can still walk the list.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubeh}(h]jah ]h"]traversing the listah$]h&]uh1hhjhhhhhKubh)}(hhh](h)}(hRemoving nodes from the listh]hRemoving nodes from the list}(hjzhhhNhNubah}(h]h ]h"]h$]h&]hj4uh1hhjwhhhhhMubh)}(hThe list_del() function can be used to remove entries from the list. It not only removes the given entry from the list, but poisons the entry's ``prev`` and ``next`` pointers, so that unintended use of the entry after removal does not go unnoticed.h](hThe list_del() function can be used to remove entries from the list. It not only removes the given entry from the list, but poisons the entry’s }(hjhhhNhNubj)}(h``prev``h]hprev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and }(hjhhhNhNubj)}(h``next``h]hnext}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhS pointers, so that unintended use of the entry after removal does not go unnoticed.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhjwhhubh)}(h@We can extend our previous example to remove one of the entries:h]h@We can extend our previous example to remove one of the entries:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM hjwhhubjC)}(hstatic int circus_fill_car(struct circus_priv *circus) { /* ... */ list_add(&dimitri->node, &car->clowns); /* State 3 */ list_del(&dimitri->node); /* State 4 */ return 0; }h]hstatic int circus_fill_car(struct circus_priv *circus) { /* ... */ list_add(&dimitri->node, &car->clowns); /* State 3 */ list_del(&dimitri->node); /* State 4 */ return 0; }}hjsbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhM hjwhhubh)}(h"The result of this would be this::h]h!The result of this would be this:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjwhhubjC)}(h .--------------------. v | .--------. .-------. | .---------. | clowns |---->| Grock |--' | Dimitri | '--------' '-------' '---------'h]h .--------------------. v | .--------. .-------. | .---------. | clowns |---->| Grock |--' | Dimitri | '--------' '-------' '---------'}hjsbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhjwhhubh)}(hThis diagram shows the "clowns" node pointing at the node labeled "Grock", which points back at the "clowns" node. Off to the side is a lone node labeled "Dimitri", which has no arrows pointing anywhere.h]hThis diagram shows the “clowns” node pointing at the node labeled “Grock”, which points back at the “clowns” node. Off to the side is a lone node labeled “Dimitri”, which has no arrows pointing anywhere.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM%hjwhhubh)}(hNote how the Dimitri node does not point to itself; its pointers are intentionally set to a "poison" value that the list code refuses to traverse.h]hNote how the Dimitri node does not point to itself; its pointers are intentionally set to a “poison” value that the list code refuses to traverse.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM)hjwhhubh)}(hIf we wanted to reinitialize the removed node instead to make it point at itself again like an empty list head, we can use list_del_init() instead:h]hIf we wanted to reinitialize the removed node instead to make it point at itself again like an empty list head, we can use list_del_init() instead:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM,hjwhhubjC)}(hstatic int circus_fill_car(struct circus_priv *circus) { /* ... */ list_add(&dimitri->node, &car->clowns); /* State 3 */ list_del_init(&dimitri->node); /* State 4b */ return 0; }h]hstatic int circus_fill_car(struct circus_priv *circus) { /* ... */ list_add(&dimitri->node, &car->clowns); /* State 3 */ list_del_init(&dimitri->node); /* State 4b */ return 0; }}hjsbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhM/hjwhhubh)}(h;This results in the deleted node pointing to itself again::h]h:This results in the deleted node pointing to itself again:}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM@hjwhhubjC)}(h .--------------------. .-------. v | v | .--------. .-------. | .---------. | | clowns |---->| Grock |--' | Dimitri |--' '--------' '-------' '---------'h]h .--------------------. .-------. v | v | .--------. .-------. | .---------. | | clowns |---->| Grock |--' | Dimitri |--' '--------' '-------' '---------'}hj:sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMBhjwhhubh)}(hThis diagram shows the "clowns" node pointing at the node labeled "Grock", which points back at the "clowns" node. Off to the side is a lone node labeled "Dimitri", which points to itself.h]hThis diagram shows the “clowns” node pointing at the node labeled “Grock”, which points back at the “clowns” node. Off to the side is a lone node labeled “Dimitri”, which points to itself.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMHhjwhhubeh}(h]j:ah ]h"]removing nodes from the listah$]h&]uh1hhjhhhhhMubh)}(hhh](h)}(h Traversing whilst removing nodesh]h Traversing whilst removing nodes}(hj`hhhNhNubah}(h]h ]h"]h$]h&]hjVuh1hhj]hhhhhMMubh)}(hX Deleting entries while we're traversing the list will cause problems if we use list_for_each() and list_for_each_entry(), as deleting the current entry would modify the ``next`` pointer of it, which means the traversal can't properly advance to the next list entry.h](hDeleting entries while we’re traversing the list will cause problems if we use list_for_each() and list_for_each_entry(), as deleting the current entry would modify the }(hjnhhhNhNubj)}(h``next``h]hnext}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubhZ pointer of it, which means the traversal can’t properly advance to the next list entry.}(hjnhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMOhj]hhubh)}(hThere is a solution to this however: list_for_each_safe() and list_for_each_entry_safe(). These take an additional parameter of a pointer to a struct list_head to use as temporary storage for the next entry during iteration, solving the issue.h]hThere is a solution to this however: list_for_each_safe() and list_for_each_entry_safe(). These take an additional parameter of a pointer to a struct list_head to use as temporary storage for the next entry during iteration, solving the issue.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMThj]hhubh)}(hAn example of how to use it:h]hAn example of how to use it:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMYhj]hhubjC)}(hXMstatic void circus_eject_insufficient_clowns(struct circus_priv *circus) { struct clown *e; struct clown *n; /* temporary storage for safe iteration */ list_for_each_entry_safe(e, n, &circus->car.clowns, node) { if (e->shoe_size < 500) list_del(&e->node); } }h]hXMstatic void circus_eject_insufficient_clowns(struct circus_priv *circus) { struct clown *e; struct clown *n; /* temporary storage for safe iteration */ list_for_each_entry_safe(e, n, &circus->car.clowns, node) { if (e->shoe_size < 500) list_del(&e->node); } }}hjsbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhM[hj]hhubh)}(hProper memory management (i.e. freeing the deleted node while making sure nothing still references it) in this case is left as an exercise to the reader.h]hProper memory management (i.e. freeing the deleted node while making sure nothing still references it) in this case is left as an exercise to the reader.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhhj]hhubeh}(h]j\ah ]h"] traversing whilst removing nodesah$]h&]uh1hhjhhhhhMMubh)}(hhh](h)}(hCutting a listh]hCutting a list}(hjhhhNhNubah}(h]h ]h"]h$]h&]hjxuh1hhjhhhhhMlubh)}(hThere are two helper functions to cut lists with. Both take elements from the list ``head``, and replace the contents of the list ``list``.h](hSThere are two helper functions to cut lists with. Both take elements from the list }(hjhhhNhNubj)}(h``head``h]hhead}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh', and replace the contents of the list }(hjhhhNhNubj)}(h``list``h]hlist}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMnhjhhubh)}(hThe first such function is list_cut_position(). It removes all list entries from ``head`` up to and including ``entry``, placing them in ``list`` instead.h](hQThe first such function is list_cut_position(). It removes all list entries from }(hjhhhNhNubj)}(h``head``h]hhead}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh up to and including }(hjhhhNhNubj)}(h ``entry``h]hentry}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh, placing them in }(hjhhhNhNubj)}(h``list``h]hlist}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh instead.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMqhjhhubh)}(h@In this example, it's assumed we start with the following list::h]hAIn this example, it’s assumed we start with the following list:}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMthjhhubjC)}(hXd .----------------------------------------------------------------. v | .--------. .-------. .---------. .-----. .---------. | | clowns |---->| Grock |---->| Dimitri |---->| Pic |---->| Alfredo |--' '--------' '-------' '---------' '-----' '---------'h]hXd .----------------------------------------------------------------. v | .--------. .-------. .---------. .-----. .---------. | | clowns |---->| Grock |---->| Dimitri |---->| Pic |---->| Alfredo |--' '--------' '-------' '---------' '-----' '---------'}hjcsbah}(h]h ]h"]h$]h&]hhuh1jBhhhMvhjhhubh)}(hWith the following code, every clown up to and including "Pic" is moved from the "clowns" list head to a separate struct list_head initialized at local stack variable ``retirement``:h](hWith the following code, every clown up to and including “Pic” is moved from the “clowns” list head to a separate struct list_head initialized at local stack variable }(hjqhhhNhNubj)}(h``retirement``h]h retirement}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubh:}(hjqhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhM|hjhhubjC)}(hXzstatic void circus_retire_clowns(struct circus_priv *circus) { struct list_head retirement = LIST_HEAD_INIT(retirement); struct clown *grock, *dimitri, *pic, *alfredo; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ list_cut_position(&retirement, &car->clowns, &pic->node); /* State 1 */ }h]hXzstatic void circus_retire_clowns(struct circus_priv *circus) { struct list_head retirement = LIST_HEAD_INIT(retirement); struct clown *grock, *dimitri, *pic, *alfredo; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ list_cut_position(&retirement, &car->clowns, &pic->node); /* State 1 */ }}hjsbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhMhjhhubh)}(h2The resulting ``car->clowns`` list would be this::h](hThe resulting }(hjhhhNhNubj)}(h``car->clowns``h]h car->clowns}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh list would be this:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhjhhubjC)}(h .----------------------. v | .--------. .---------. | | clowns |---->| Alfredo |--' '--------' '---------'h]h .----------------------. v | .--------. .---------. | | clowns |---->| Alfredo |--' '--------' '---------'}hjsbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhjhhubh)}(hDMeanwhile, the ``retirement`` list is transformed to the following::h](hMeanwhile, the }(hjhhhNhNubj)}(h``retirement``h]h retirement}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh& list is transformed to the following:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhjhhubjC)}(hX( .--------------------------------------------------. v | .------------. .-------. .---------. .-----. | | retirement |---->| Grock |---->| Dimitri |---->| Pic |--' '------------' '-------' '---------' '-----'h]hX( .--------------------------------------------------. v | .------------. .-------. .---------. .-----. | | retirement |---->| Grock |---->| Dimitri |---->| Pic |--' '------------' '-------' '---------' '-----'}hjsbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhjhhubh)}(hX The second function, list_cut_before(), is much the same, except it cuts before the ``entry`` node, i.e. it removes all list entries from ``head`` up to but excluding ``entry``, placing them in ``list`` instead. This example assumes the same initial starting list as the previous example:h](hTThe second function, list_cut_before(), is much the same, except it cuts before the }(hjhhhNhNubj)}(h ``entry``h]hentry}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh- node, i.e. it removes all list entries from }(hjhhhNhNubj)}(h``head``h]hhead}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh up to but excluding }(hjhhhNhNubj)}(h ``entry``h]hentry}(hj( hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh, placing them in }(hjhhhNhNubj)}(h``list``h]hlist}(hj: hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhV instead. This example assumes the same initial starting list as the previous example:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhjhhubjC)}(hXystatic void circus_retire_clowns(struct circus_priv *circus) { struct list_head retirement = LIST_HEAD_INIT(retirement); struct clown *grock, *dimitri, *pic, *alfredo; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ list_cut_before(&retirement, &car->clowns, &pic->node); /* State 1b */ }h]hXystatic void circus_retire_clowns(struct circus_priv *circus) { struct list_head retirement = LIST_HEAD_INIT(retirement); struct clown *grock, *dimitri, *pic, *alfredo; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ list_cut_before(&retirement, &car->clowns, &pic->node); /* State 1b */ }}hjR sbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhMhjhhubh)}(h2The resulting ``car->clowns`` list would be this::h](hThe resulting }(hja hhhNhNubj)}(h``car->clowns``h]h car->clowns}(hji hhhNhNubah}(h]h ]h"]h$]h&]uh1jhja ubh list would be this:}(hja hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhjhhubjC)}(h .----------------------------------. v | .--------. .-----. .---------. | | clowns |---->| Pic |---->| Alfredo |--' '--------' '-----' '---------'h]h .----------------------------------. v | .--------. .-----. .---------. | | clowns |---->| Pic |---->| Alfredo |--' '--------' '-----' '---------'}hj sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhjhhubh)}(hDMeanwhile, the ``retirement`` list is transformed to the following::h](hMeanwhile, the }(hj hhhNhNubj)}(h``retirement``h]h retirement}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh& list is transformed to the following:}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhjhhubjC)}(h .--------------------------------------. v | .------------. .-------. .---------. | | retirement |---->| Grock |---->| Dimitri |--' '------------' '-------' '---------'h]h .--------------------------------------. v | .------------. .-------. .---------. | | retirement |---->| Grock |---->| Dimitri |--' '------------' '-------' '---------'}hj sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhjhhubh)}(h~It should be noted that both functions will destroy links to any existing nodes in the destination ``struct list_head *list``.h](hcIt should be noted that both functions will destroy links to any existing nodes in the destination }(hj hhhNhNubj)}(h``struct list_head *list``h]hstruct list_head *list}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhjhhubeh}(h]j~ah ]h"]cutting a listah$]h&]uh1hhjhhhhhMlubh)}(hhh](h)}(h Moving entries and partial listsh]h Moving entries and partial lists}(hj hhhNhNubah}(h]h ]h"]h$]h&]hjuh1hhj hhhhhMubh)}(hThe list_move() and list_move_tail() functions can be used to move an entry from one list to another, to either the start or end respectively.h]hThe list_move() and list_move_tail() functions can be used to move an entry from one list to another, to either the start or end respectively.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubh)}(hIn the following example, we'll assume we start with two lists ("clowns" and "sidewalk" in the following initial state "State 0"::h]hIn the following example, we’ll assume we start with two lists (“clowns” and “sidewalk” in the following initial state “State 0”:}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubjC)}(hX .----------------------------------------------------------------. v | .--------. .-------. .---------. .-----. .---------. | | clowns |---->| Grock |---->| Dimitri |---->| Pic |---->| Alfredo |--' '--------' '-------' '---------' '-----' '---------' .-------------------. v | .----------. .-----. | | sidewalk |---->| Pio |--' '----------' '-----'h]hX .----------------------------------------------------------------. v | .--------. .-------. .---------. .-----. .---------. | | clowns |---->| Grock |---->| Dimitri |---->| Pic |---->| Alfredo |--' '--------' '-------' '---------' '-----' '---------' .-------------------. v | .----------. .-----. | | sidewalk |---->| Pio |--' '----------' '-----'}hj sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhj hhubh)}(h5We apply the following example code to the two lists:h]h5We apply the following example code to the two lists:}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubjC)}(hXstatic void circus_clowns_exit_car(struct circus_priv *circus) { struct list_head sidewalk = LIST_HEAD_INIT(sidewalk); struct clown *grock, *dimitri, *pic, *alfredo, *pio; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ /* State 0 */ list_move(&pic->node, &sidewalk); /* State 1 */ list_move_tail(&dimitri->node, &sidewalk); /* State 2 */ }h]hXstatic void circus_clowns_exit_car(struct circus_priv *circus) { struct list_head sidewalk = LIST_HEAD_INIT(sidewalk); struct clown *grock, *dimitri, *pic, *alfredo, *pio; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ /* State 0 */ list_move(&pic->node, &sidewalk); /* State 1 */ list_move_tail(&dimitri->node, &sidewalk); /* State 2 */ }}hj- sbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhMhj hhubh)}(h2In State 1, we arrive at the following situation::h]h1In State 1, we arrive at the following situation:}(hj< hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubjC)}(hX* .-----------------------------------------------------. | | v | .--------. .-------. .---------. .---------. | | clowns |---->| Grock |---->| Dimitri |---->| Alfredo |--' '--------' '-------' '---------' '---------' .-------------------------------. v | .----------. .-----. .-----. | | sidewalk |---->| Pic |---->| Pio |--' '----------' '-----' '-----'h]hX* .-----------------------------------------------------. | | v | .--------. .-------. .---------. .---------. | | clowns |---->| Grock |---->| Dimitri |---->| Alfredo |--' '--------' '-------' '---------' '---------' .-------------------------------. v | .----------. .-----. .-----. | | sidewalk |---->| Pic |---->| Pio |--' '----------' '-----' '-----'}hjJ sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhj hhubh)}(haIn State 2, after we've moved Dimitri to the tail of sidewalk, the situation changes as follows::h]hbIn State 2, after we’ve moved Dimitri to the tail of sidewalk, the situation changes as follows:}(hjX hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubjC)}(hX .-------------------------------------. | | v | .--------. .-------. .---------. | | clowns |---->| Grock |---->| Alfredo |--' '--------' '-------' '---------' .-----------------------------------------------. v | .----------. .-----. .-----. .---------. | | sidewalk |---->| Pic |---->| Pio |---->| Dimitri |--' '----------' '-----' '-----' '---------'h]hX .-------------------------------------. | | v | .--------. .-------. .---------. | | clowns |---->| Grock |---->| Alfredo |--' '--------' '-------' '---------' .-----------------------------------------------. v | .----------. .-----. .-----. .---------. | | sidewalk |---->| Pic |---->| Pio |---->| Dimitri |--' '----------' '-----' '-----' '---------'}hjf sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhj hhubh)}(hX*As long as the source and destination list head are part of the same list, we can also efficiently bulk move a segment of the list to the tail end of the list. We continue the previous example by adding a list_bulk_move_tail() after State 2, moving Pic and Pio to the tail end of the sidewalk list.h]hX*As long as the source and destination list head are part of the same list, we can also efficiently bulk move a segment of the list to the tail end of the list. We continue the previous example by adding a list_bulk_move_tail() after State 2, moving Pic and Pio to the tail end of the sidewalk list.}(hjt hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubjC)}(hX static void circus_clowns_exit_car(struct circus_priv *circus) { struct list_head sidewalk = LIST_HEAD_INIT(sidewalk); struct clown *grock, *dimitri, *pic, *alfredo, *pio; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ /* State 0 */ list_move(&pic->node, &sidewalk); /* State 1 */ list_move_tail(&dimitri->node, &sidewalk); /* State 2 */ list_bulk_move_tail(&sidewalk, &pic->node, &pio->node); /* State 3 */ }h]hX static void circus_clowns_exit_car(struct circus_priv *circus) { struct list_head sidewalk = LIST_HEAD_INIT(sidewalk); struct clown *grock, *dimitri, *pic, *alfredo, *pio; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ /* State 0 */ list_move(&pic->node, &sidewalk); /* State 1 */ list_move_tail(&dimitri->node, &sidewalk); /* State 2 */ list_bulk_move_tail(&sidewalk, &pic->node, &pio->node); /* State 3 */ }}hj sbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhMhj hhubh)}(hkFor the sake of brevity, only the altered "sidewalk" list at State 3 is depicted in the following diagram::h]hnFor the sake of brevity, only the altered “sidewalk” list at State 3 is depicted in the following diagram:}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM/hj hhubjC)}(hX .-----------------------------------------------. v | .----------. .---------. .-----. .-----. | | sidewalk |---->| Dimitri |---->| Pic |---->| Pio |--' '----------' '---------' '-----' '-----'h]hX .-----------------------------------------------. v | .----------. .---------. .-----. .-----. | | sidewalk |---->| Dimitri |---->| Pic |---->| Pio |--' '----------' '---------' '-----' '-----'}hj sbah}(h]h ]h"]h$]h&]hhuh1jBhhhM2hj hhubh)}(hX Do note that list_bulk_move_tail() does not do any checking as to whether all three supplied ``struct list_head *`` parameters really do belong to the same list. If you use it outside the constraints the documentation gives, then the result is a matter between you and the implementation.h](h]Do note that list_bulk_move_tail() does not do any checking as to whether all three supplied }(hj hhhNhNubj)}(h``struct list_head *``h]hstruct list_head *}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh parameters really do belong to the same list. If you use it outside the constraints the documentation gives, then the result is a matter between you and the implementation.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhM8hj hhubeh}(h]jah ]h"] moving entries and partial listsah$]h&]uh1hhjhhhhhMubh)}(hhh](h)}(hRotating entriesh]hRotating entries}(hj hhhNhNubah}(h]h ]h"]h$]h&]hjuh1hhj hhhhhM>ubh)}(hA common write operation on lists, especially when using them as queues, is to rotate it. A list rotation means entries at the front are sent to the back.h]hA common write operation on lists, especially when using them as queues, is to rotate it. A list rotation means entries at the front are sent to the back.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM@hj hhubh)}(hXFFor rotation, Linux provides us with two functions: list_rotate_left() and list_rotate_to_front(). The former can be pictured like a bicycle chain, taking the entry after the supplied ``struct list_head *`` and moving it to the tail, which in essence means the entire list, due to its circular nature, rotates by one position.h](hFor rotation, Linux provides us with two functions: list_rotate_left() and list_rotate_to_front(). The former can be pictured like a bicycle chain, taking the entry after the supplied }(hj hhhNhNubj)}(h``struct list_head *``h]hstruct list_head *}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubhx and moving it to the tail, which in essence means the entire list, due to its circular nature, rotates by one position.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMChj hhubh)}(hThe latter, list_rotate_to_front(), takes the same concept one step further: instead of advancing the list by one entry, it advances it *until* the specified entry is the new front.h](hThe latter, list_rotate_to_front(), takes the same concept one step further: instead of advancing the list by one entry, it advances it }(hj hhhNhNubhemphasis)}(h*until*h]huntil}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j hj ubh& the specified entry is the new front.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMIhj hhubh)}(hIIn the following example, our starting state, State 0, is the following::h]hHIn the following example, our starting state, State 0, is the following:}(hj5 hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMMhj hhubjC)}(hXj .-----------------------------------------------------------------. v | .--------. .-------. .---------. .-----. .---------. .-----. | | clowns |-->| Grock |-->| Dimitri |-->| Pic |-->| Alfredo |-->| Pio |-' '--------' '-------' '---------' '-----' '---------' '-----'h]hXj .-----------------------------------------------------------------. v | .--------. .-------. .---------. .-----. .---------. .-----. | | clowns |-->| Grock |-->| Dimitri |-->| Pic |-->| Alfredo |-->| Pio |-' '--------' '-------' '---------' '-----' '---------' '-----'}hjC sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMOhj hhubh)}(hKThe example code being used to demonstrate list rotations is the following:h]hKThe example code being used to demonstrate list rotations is the following:}(hjQ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMUhj hhubjC)}(hXstatic void circus_clowns_rotate(struct circus_priv *circus) { struct clown *grock, *dimitri, *pic, *alfredo, *pio; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ /* State 0 */ list_rotate_left(&car->clowns); /* State 1 */ list_rotate_to_front(&alfredo->node, &car->clowns); /* State 2 */ }h]hXstatic void circus_clowns_rotate(struct circus_priv *circus) { struct clown *grock, *dimitri, *pic, *alfredo, *pio; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ /* State 0 */ list_rotate_left(&car->clowns); /* State 1 */ list_rotate_to_front(&alfredo->node, &car->clowns); /* State 2 */ }}hj_ sbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhMWhj hhubh)}(h2In State 1, we arrive at the following situation::h]h1In State 1, we arrive at the following situation:}(hjn hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMlhj hhubjC)}(hXj .-----------------------------------------------------------------. v | .--------. .---------. .-----. .---------. .-----. .-------. | | clowns |-->| Dimitri |-->| Pic |-->| Alfredo |-->| Pio |-->| Grock |-' '--------' '---------' '-----' '---------' '-----' '-------'h]hXj .-----------------------------------------------------------------. v | .--------. .---------. .-----. .---------. .-----. .-------. | | clowns |-->| Dimitri |-->| Pic |-->| Alfredo |-->| Pio |-->| Grock |-' '--------' '---------' '-----' '---------' '-----' '-------'}hj| sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMnhj hhubh)}(hQNext, after the list_rotate_to_front() call, we arrive in the following State 2::h]hPNext, after the list_rotate_to_front() call, we arrive in the following State 2:}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMthj hhubjC)}(hXj .-----------------------------------------------------------------. v | .--------. .---------. .-----. .-------. .---------. .-----. | | clowns |-->| Alfredo |-->| Pio |-->| Grock |-->| Dimitri |-->| Pic |-' '--------' '---------' '-----' '-------' '---------' '-----'h]hXj .-----------------------------------------------------------------. v | .--------. .---------. .-----. .-------. .---------. .-----. | | clowns |-->| Alfredo |-->| Pio |-->| Grock |-->| Dimitri |-->| Pic |-' '--------' '---------' '-----' '-------' '---------' '-----'}hj sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMwhj hhubh)}(huAs is hopefully evident from the diagrams, the entries in front of "Alfredo" were cycled to the tail end of the list.h]hyAs is hopefully evident from the diagrams, the entries in front of “Alfredo” were cycled to the tail end of the list.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM}hj hhubeh}(h]jah ]h"]rotating entriesah$]h&]uh1hhjhhhhhM>ubh)}(hhh](h)}(hSwapping entriesh]hSwapping entries}(hj hhhNhNubah}(h]h ]h"]h$]h&]hjuh1hhj hhhhhMubh)}(hPAnother common operation is that two entries need to be swapped with each other.h]hPAnother common operation is that two entries need to be swapped with each other.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubh)}(h-For this, Linux provides us with list_swap().h]h-For this, Linux provides us with list_swap().}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubh)}(h|In the following example, we have a list with three entries, and swap two of them. This is our starting state in "State 0"::h]hIn the following example, we have a list with three entries, and swap two of them. This is our starting state in “State 0”:}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubjC)}(h .-----------------------------------------. v | .--------. .-------. .---------. .-----. | | clowns |-->| Grock |-->| Dimitri |-->| Pic |-' '--------' '-------' '---------' '-----'7h]h .-----------------------------------------. v | .--------. .-------. .---------. .-----. | | clowns |-->| Grock |-->| Dimitri |-->| Pic |-' '--------' '-------' '---------' '-----'}hj sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhj hhubjC)}(hX0static void circus_clowns_swap(struct circus_priv *circus) { struct clown *grock, *dimitri, *pic; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ /* State 0 */ list_swap(&dimitri->node, &pic->node); /* State 1 */ }h]hX0static void circus_clowns_swap(struct circus_priv *circus) { struct clown *grock, *dimitri, *pic; struct clown_car *car = &circus->car; /* ... clown initialization, list adding ... */ /* State 0 */ list_swap(&dimitri->node, &pic->node); /* State 1 */ }}hj sbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhMhj hhubh)}(h0The resulting list at State 1 is the following::h]h/The resulting list at State 1 is the following:}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubjC)}(h .-----------------------------------------. v | .--------. .-------. .-----. .---------. | | clowns |-->| Grock |-->| Pic |-->| Dimitri |-' '--------' '-------' '-----' '---------'h]h .-----------------------------------------. v | .--------. .-------. .-----. .---------. | | clowns |-->| Grock |-->| Pic |-->| Dimitri |-' '--------' '-------' '-----' '---------'}hj! sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhj hhubh)}(hZAs is evident by comparing the diagrams, the "Pic" and "Dimitri" nodes have traded places.h]hbAs is evident by comparing the diagrams, the “Pic” and “Dimitri” nodes have traded places.}(hj/ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj hhubeh}(h]jah ]h"]swapping entriesah$]h&]uh1hhjhhhhhMubh)}(hhh](h)}(hSplicing two lists togetherh]hSplicing two lists together}(hjG hhhNhNubah}(h]h ]h"]h$]h&]hjuh1hhjD hhhhhMubh)}(hSay we have two lists, in the following example one represented by a list head we call "knie" and one we call "stey". In a hypothetical circus acquisition, the two list of clowns should be spliced together. The following is our situation in "State 0"::h]hXSay we have two lists, in the following example one represented by a list head we call “knie” and one we call “stey”. In a hypothetical circus acquisition, the two list of clowns should be spliced together. The following is our situation in “State 0”:}(hjU hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjD hhubjC)}(hX .-----------------------------------------. | | v | .------. .-------. .---------. .-----. | | knie |-->| Grock |-->| Dimitri |-->| Pic |--' '------' '-------' '---------' '-----' .-----------------------------. v | .------. .---------. .-----. | | stey |-->| Alfredo |-->| Pio |--' '------' '---------' '-----'h]hX .-----------------------------------------. | | v | .------. .-------. .---------. .-----. | | knie |-->| Grock |-->| Dimitri |-->| Pic |--' '------' '-------' '---------' '-----' .-----------------------------. v | .------. .---------. .-----. | | stey |-->| Alfredo |-->| Pio |--' '------' '---------' '-----'}hjc sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhjD hhubh)}(haThe function to splice these two lists together is list_splice(). Our example code is as follows:h]haThe function to splice these two lists together is list_splice(). Our example code is as follows:}(hjq hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjD hhubjC)}(hXKstatic void circus_clowns_splice(void) { struct clown *grock, *dimitri, *pic, *alfredo, *pio; struct list_head knie = LIST_HEAD_INIT(knie); struct list_head stey = LIST_HEAD_INIT(stey); /* ... Clown allocation and initialization here ... */ list_add_tail(&grock->node, &knie); list_add_tail(&dimitri->node, &knie); list_add_tail(&pic->node, &knie); list_add_tail(&alfredo->node, &stey); list_add_tail(&pio->node, &stey); /* State 0 */ list_splice(&stey, &dimitri->node); /* State 1 */ }h]hXKstatic void circus_clowns_splice(void) { struct clown *grock, *dimitri, *pic, *alfredo, *pio; struct list_head knie = LIST_HEAD_INIT(knie); struct list_head stey = LIST_HEAD_INIT(stey); /* ... Clown allocation and initialization here ... */ list_add_tail(&grock->node, &knie); list_add_tail(&dimitri->node, &knie); list_add_tail(&pic->node, &knie); list_add_tail(&alfredo->node, &stey); list_add_tail(&pio->node, &stey); /* State 0 */ list_splice(&stey, &dimitri->node); /* State 1 */ }}hj sbah}(h]h ]h"]h$]h&]hhjRjSjTjU}uh1jBhhhMhjD hhubh)}(hThe list_splice() call here adds all the entries in ``stey`` to the list ``dimitri``'s ``node`` list_head is in, after the ``node`` of ``dimitri``. A somewhat surprising diagram of the resulting "State 1" follows::h](h4The list_splice() call here adds all the entries in }(hj hhhNhNubj)}(h``stey``h]hstey}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh to the list }(hj hhhNhNubj)}(h ``dimitri``h]hdimitri}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh’s }(hj hhhNhNubj)}(h``node``h]hnode}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh list_head is in, after the }(hj hhhNhNubj)}(h``node``h]hnode}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh of }(hj hhhNhNubj)}(h ``dimitri``h]hdimitri}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubhG. A somewhat surprising diagram of the resulting “State 1” follows:}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhjD hhubjC)}(hX1 .-----------------------------------------------------------------. | | v | .------. .-------. .---------. .---------. .-----. .-----. | | knie |-->| Grock |-->| Dimitri |-->| Alfredo |-->| Pio |-->| Pic |--' '------' '-------' '---------' '---------' '-----' '-----' ^ .-------------------------------' | .------. | | stey |--' '------'h]hX1 .-----------------------------------------------------------------. | | v | .------. .-------. .---------. .---------. .-----. .-----. | | knie |-->| Grock |-->| Dimitri |-->| Alfredo |-->| Pio |-->| Pic |--' '------' '-------' '---------' '---------' '-----' '-----' ^ .-------------------------------' | .------. | | stey |--' '------'}hj sbah}(h]h ]h"]h$]h&]hhuh1jBhhhMhjD hhubh)}(hTraversing the ``stey`` list no longer results in correct behavior. A call of list_for_each() on ``stey`` results in an infinite loop, as it never returns back to the ``stey`` list head.h](hTraversing the }(hj hhhNhNubj)}(h``stey``h]hstey}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubhJ list no longer results in correct behavior. A call of list_for_each() on }(hj hhhNhNubj)}(h``stey``h]hstey}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh> results in an infinite loop, as it never returns back to the }(hj hhhNhNubj)}(h``stey``h]hstey}(hj0 hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh list head.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhjD hhubh)}(hThis is because list_splice() did not reinitialize the list_head it took entries from, leaving its pointer pointing into what is now a different list.h]hThis is because list_splice() did not reinitialize the list_head it took entries from, leaving its pointer pointing into what is now a different list.}(hjH hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjD hhubh)}(hIf we want to avoid this situation, list_splice_init() can be used. It does the same thing as list_splice(), except reinitalizes the donor list_head after the transplant.h]hIf we want to avoid this situation, list_splice_init() can be used. It does the same thing as list_splice(), except reinitalizes the donor list_head after the transplant.}(hjV hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjD hhubeh}(h]jah ]h"]splicing two lists togetherah$]h&]uh1hhjhhhhhMubh)}(hhh](h)}(hConcurrency considerationsh]hConcurrency considerations}(hjn hhhNhNubah}(h]h ]h"]h$]h&]hj"uh1hhjk hhhhhMubh)}(hXDConcurrent access and modification of a list needs to be protected with a lock in most cases. Alternatively and preferably, one may use the RCU primitives for lists in read-mostly use-cases, where read accesses to the list are common but modifications to the list less so. See Documentation/RCU/listRCU.rst for more details.h]hXDConcurrent access and modification of a list needs to be protected with a lock in most cases. Alternatively and preferably, one may use the RCU primitives for lists in read-mostly use-cases, where read accesses to the list are common but modifications to the list less so. See Documentation/RCU/listRCU.rst for more details.}(hj| hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjk hhubeh}(h]j(ah ]h"]concurrency considerationsah$]h&]uh1hhjhhhhhMubh)}(hhh](h)}(hFurther readingh]hFurther reading}(hj hhhNhNubah}(h]h ]h"]h$]h&]hjDuh1hhj hhhhhMubj8)}(hhh]j=)}(hl`How does the kernel implements Linked Lists? - KernelNewbies `_ h]h)}(hk`How does the kernel implements Linked Lists? - KernelNewbies `_h](h)}(hj h]hh]h}(h]9how-does-the-kernel-implements-linked-lists-kernelnewbiesah ]h"]`'s links to point to itself h]h)}(hNinitialize a :c:type:`struct list_head `'s links to point to itselfh](h initialize a }(hjhhhNhNubh)}(h&:c:type:`struct list_head `h]j)}(hjh]hstruct list_head}(hjhhhNhNubah}(h]h ](xrefjTc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdoc core-api/list refdomainjTreftypetype refexplicitrefwarn c:parent_keysphinx.domains.c LookupKey)}data]sb reftarget list_headuh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubh’s links to point to itself}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjhKhj hhubh container)}(h0**Parameters** ``name`` name of the list_headh](h)}(h**Parameters**h]hstrong)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubhdefinition_list)}(hhh]hdefinition_list_item)}(h``name`` name of the list_headh](hterm)}(h``name``h]j)}(hjh]hname}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubh definition)}(hhh]h)}(hname of the list_headh]hname of the list_head}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jLIST_HEAD (C macro) c.LIST_HEADhNtauh1jhj hhhNhNubj)}(hhh](j)}(h LIST_HEADh]j)}(h LIST_HEADh]j$)}(h LIST_HEADh]j*)}(hjTh]h LIST_HEAD}(hj^hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjZubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjVhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjRhhhjqhKubah}(h]jMah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjqhKhjOhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjOhhhjqhKubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijjjjjkjljmuh1jhhhj hNhNubh)}(h``LIST_HEAD (name)``h]j)}(hjh]hLIST_HEAD (name)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhK hj hhubj)}(hRdefinition of a :c:type:`struct list_head ` with initialization values h]h)}(hQdefinition of a :c:type:`struct list_head ` with initialization valuesh](hdefinition of a }(hjhhhNhNubh)}(h&:c:type:`struct list_head `h]j)}(hjh]hstruct list_head}(hjhhhNhNubah}(h]h ](jjTc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj refdomainjTreftypetype refexplicitrefwarnjjj list_headuh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubh with initialization values}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjhKhj hhubj)}(h0**Parameters** ``name`` name of the list_headh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhK"hjubj)}(hhh]j)}(h``name`` name of the list_headh](j)}(h``name``h]j)}(hjh]hname}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhK$hjubj)}(hhh]h)}(hname of the list_headh]hname of the list_head}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhK$hjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jINIT_LIST_HEAD (C function)c.INIT_LIST_HEADhNtauh1jhj hhhNhNubj)}(hhh](j)}(h,void INIT_LIST_HEAD (struct list_head *list)h]j)}(h+void INIT_LIST_HEAD(struct list_head *list)h](hdesc_sig_keyword_type)}(hvoidh]hvoid}(hjchhhNhNubah}(h]h ]ktah"]h$]h&]uh1jahj]hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhK%ubhdesc_sig_space)}(h h]h }(hjuhhhNhNubah}(h]h ]wah"]h$]h&]uh1jshj]hhhjrhK%ubj$)}(hINIT_LIST_HEADh]j*)}(hINIT_LIST_HEADh]hINIT_LIST_HEAD}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj]hhhjrhK%ubhdesc_parameterlist)}(h(struct list_head *list)h]hdesc_parameter)}(hstruct list_head *listh](hdesc_sig_keyword)}(hstructh]hstruct}(hjhhhNhNubah}(h]h ]kah"]h$]h&]uh1jhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubh)}(hhh]j*)}(h list_headh]h list_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ]h"]h$]h&] refdomainjTreftype identifier reftargetjmodnameN classnameNjj)}j]j ASTIdentifier)}jjsbc.INIT_LIST_HEADasbuh1hhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubhdesc_sig_punctuation)}(hj h]h*}(hjhhhNhNubah}(h]h ]pah"]h$]h&]uh1jhjubj*)}(hlisth]hlist}(hj hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubah}(h]h ]h"]h$]h&]hhuh1jhj]hhhjrhK%ubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjYhhhjrhK%ubah}(h]jTah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjrhK%hjVhhubjW)}(hhh]h)}(h Initialize a list_head structureh]h Initialize a list_head structure}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhK%hj2hhubah}(h]h ]h"]h$]h&]uh1jVhjVhhhjrhK%ubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijMjjjMjkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *list`` list_head structure to be initialized. **Description** Initializes the list_head to point to itself. If it is a list header, the result is an empty list.h](h)}(h**Parameters**h]j)}(hjWh]h Parameters}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhK)hjQubj)}(hhh]j)}(hB``struct list_head *list`` list_head structure to be initialized. h](j)}(h``struct list_head *list``h]j)}(hjvh]hstruct list_head *list}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhK&hjpubj)}(hhh]h)}(h&list_head structure to be initialized.h]h&list_head structure to be initialized.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK&hjubah}(h]h ]h"]h$]h&]uh1jhjpubeh}(h]h ]h"]h$]h&]uh1jhjhK&hjmubah}(h]h ]h"]h$]h&]uh1jhjQubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhK(hjQubh)}(hcInitializes the list_head to point to itself. If it is a list header, the result is an empty list.h]hcInitializes the list_head to point to itself. If it is a list header, the result is an empty list.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhK'hjQubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_add (C function) c.list_addhNtauh1jhj hhhNhNubj)}(hhh](j)}(h=void list_add (struct list_head *new, struct list_head *head)h]j)}(hjjj>jkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *new`` new entry to be added ``struct list_head *head`` list head to add it after **Description** Insert a new entry after the specified head. This is good for implementing stacks.h](h)}(h**Parameters**h]j)}(hjHh]h Parameters}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjBubj)}(hhh](j)}(h0``struct list_head *new`` new entry to be added h](j)}(h``struct list_head *new``h]j)}(hjgh]hstruct list_head *new}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjaubj)}(hhh]h)}(hnew entry to be addedh]hnew entry to be added}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hKhj}ubah}(h]h ]h"]h$]h&]uh1jhjaubeh}(h]h ]h"]h$]h&]uh1jhj|hKhj^ubj)}(h5``struct list_head *head`` list head to add it after h](j)}(h``struct list_head *head``h]j)}(hjh]hstruct list_head *head}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubj)}(hhh]h)}(hlist head to add it afterh]hlist head to add it after}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhj^ubeh}(h]h ]h"]h$]h&]uh1jhjBubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjBubh)}(hRInsert a new entry after the specified head. This is good for implementing stacks.h]hRInsert a new entry after the specified head. This is good for implementing stacks.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjBubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_add_tail (C function)c.list_add_tailhNtauh1jhj hhhNhNubj)}(hhh](j)}(hBvoid list_add_tail (struct list_head *new, struct list_head *head)h]j)}(hAvoid list_add_tail(struct list_head *new, struct list_head *head)h](jb)}(hvoidh]hvoid}(hj hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKubjt)}(h h]h }(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjhhhj.hKubj$)}(h list_add_tailh]j*)}(h list_add_tailh]h list_add_tail}(hjAhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj=ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjhhhj.hKubj)}(h/(struct list_head *new, struct list_head *head)h](j)}(hstruct list_head *newh](j)}(hjh]hstruct}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYubjt)}(h h]h }(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjYubh)}(hhh]j*)}(h list_headh]h list_head}(hj{hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjxubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj}modnameN classnameNjj)}j]j)}jjCsbc.list_add_tailasbuh1hhjYubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjYubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYubj*)}(hnewh]hnew}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjYubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjUubj)}(hstruct list_head *headh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubh)}(hhh]j*)}(h list_headh]h list_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]jc.list_add_tailasbuh1hhjubjt)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj*)}(hheadh]hhead}(hj&hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjUubeh}(h]h ]h"]h$]h&]hhuh1jhjhhhj.hKubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhj.hKubah}(h]jah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj.hKhjhhubjW)}(hhh]h)}(hadd a new entryh]hadd a new entry}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjMhhubah}(h]h ]h"]h$]h&]uh1jVhjhhhj.hKubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijhjjjhjkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *new`` new entry to be added ``struct list_head *head`` list head to add it before **Description** Insert a new entry before the specified head. This is useful for implementing queues.h](h)}(h**Parameters**h]j)}(hjrh]h Parameters}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjlubj)}(hhh](j)}(h0``struct list_head *new`` new entry to be added h](j)}(h``struct list_head *new``h]j)}(hjh]hstruct list_head *new}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubj)}(hhh]h)}(hnew entry to be addedh]hnew entry to be added}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h6``struct list_head *head`` list head to add it before h](j)}(h``struct list_head *head``h]j)}(hjh]hstruct list_head *head}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubj)}(hhh]h)}(hlist head to add it beforeh]hlist head to add it before}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubeh}(h]h ]h"]h$]h&]uh1jhjlubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjlubh)}(hUInsert a new entry before the specified head. This is useful for implementing queues.h]hUInsert a new entry before the specified head. This is useful for implementing queues.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjlubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_del (C function) c.list_delhNtauh1jhj hhhNhNubj)}(hhh](j)}(h'void list_del (struct list_head *entry)h]j)}(h&void list_del(struct list_head *entry)h](jb)}(hvoidh]hvoid}(hjJhhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjFhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKubjt)}(h h]h }(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjFhhhjXhKubj$)}(hlist_delh]j*)}(hlist_delh]hlist_del}(hjkhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjgubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjFhhhjXhKubj)}(h(struct list_head *entry)h]j)}(hstruct list_head *entryh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubh)}(hhh]j*)}(h list_headh]h list_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]j)}jjmsb c.list_delasbuh1hhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj*)}(hentryh]hentry}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubah}(h]h ]h"]h$]h&]hhuh1jhjFhhhjXhKubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjBhhhjXhKubah}(h]j=ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjXhKhj?hhubjW)}(hhh]h)}(hdeletes entry from list.h]hdeletes entry from list.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jVhj?hhhjXhKubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij"jjj"jkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *entry`` the element to delete from the list. **Note** list_empty() on entry does not return true after this, the entry is in an undefined state.h](h)}(h**Parameters**h]j)}(hj,h]h Parameters}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhj&ubj)}(hhh]j)}(hA``struct list_head *entry`` the element to delete from the list. h](j)}(h``struct list_head *entry``h]j)}(hjKh]hstruct list_head *entry}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjEubj)}(hhh]h)}(h$the element to delete from the list.h]h$the element to delete from the list.}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hKhjaubah}(h]h ]h"]h$]h&]uh1jhjEubeh}(h]h ]h"]h$]h&]uh1jhj`hKhjBubah}(h]h ]h"]h$]h&]uh1jhj&ubh)}(h**Note**h]j)}(hjh]hNote}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhj&ubh)}(hZlist_empty() on entry does not return true after this, the entry is in an undefined state.h]hZlist_empty() on entry does not return true after this, the entry is in an undefined state.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhj&ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_replace (C function)c.list_replacehNtauh1jhj hhhNhNubj)}(hhh](j)}(h@void list_replace (struct list_head *old, struct list_head *new)h]j)}(h?void list_replace(struct list_head *old, struct list_head *new)h](jb)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjhhhjhKubj$)}(h list_replaceh]j*)}(h list_replaceh]h list_replace}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjhhhjhKubj)}(h.(struct list_head *old, struct list_head *new)h](j)}(hstruct list_head *oldh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubh)}(hhh]j*)}(h list_headh]h list_head}(hj&hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj#ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj(modnameN classnameNjj)}j]j)}jjsbc.list_replaceasbuh1hhjubjt)}(h h]h }(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubj)}(hj h]h*}(hjThhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj*)}(holdh]hold}(hjahhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubj)}(hstruct list_head *newh](j)}(hjh]hstruct}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjvubh)}(hhh]j*)}(h list_headh]h list_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]jBc.list_replaceasbuh1hhjvubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjvubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvubj*)}(hnewh]hnew}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjvubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubeh}(h]h ]h"]h$]h&]hhuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhKubah}(h]jah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjhKhjhhubjW)}(hhh]h)}(hreplace old entry by new oneh]hreplace old entry by new one}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jVhjhhhjhKubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijjjjjkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *old`` the element to be replaced ``struct list_head *new`` the new element to insert **Description** If **old** was empty, it will be overwritten.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubj)}(hhh](j)}(h5``struct list_head *old`` the element to be replaced h](j)}(h``struct list_head *old``h]j)}(hj<h]hstruct list_head *old}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhj6ubj)}(hhh]h)}(hthe element to be replacedh]hthe element to be replaced}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhKhjRubah}(h]h ]h"]h$]h&]uh1jhj6ubeh}(h]h ]h"]h$]h&]uh1jhjQhKhj3ubj)}(h4``struct list_head *new`` the new element to insert h](j)}(h``struct list_head *new``h]j)}(hjuh]hstruct list_head *new}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjoubj)}(hhh]h)}(hthe new element to inserth]hthe new element to insert}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjoubeh}(h]h ]h"]h$]h&]uh1jhjhKhj3ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubh)}(h-If **old** was empty, it will be overwritten.h](hIf }(hjhhhNhNubj)}(h**old**h]hold}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh# was empty, it will be overwritten.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_replace_init (C function)c.list_replace_inithNtauh1jhj hhhNhNubj)}(hhh](j)}(hEvoid list_replace_init (struct list_head *old, struct list_head *new)h]j)}(hDvoid list_replace_init(struct list_head *old, struct list_head *new)h](jb)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjhhhjhMubj$)}(hlist_replace_inith]j*)}(hlist_replace_inith]hlist_replace_init}(hj(hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj$ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjhhhjhMubj)}(h.(struct list_head *old, struct list_head *new)h](j)}(hstruct list_head *oldh](j)}(hjh]hstruct}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubjt)}(h h]h }(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj@ubh)}(hhh]j*)}(h list_headh]h list_head}(hjbhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj_ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjdmodnameN classnameNjj)}j]j)}jj*sbc.list_replace_initasbuh1hhj@ubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj@ubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubj*)}(holdh]hold}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj@ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj<ubj)}(hstruct list_head *newh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubh)}(hhh]j*)}(h list_headh]h list_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]j~c.list_replace_initasbuh1hhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj*)}(hnewh]hnew}(hj hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj<ubeh}(h]h ]h"]h$]h&]hhuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhMubah}(h]jah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjhMhjhhubjW)}(hhh]h)}(h7replace old entry by new one and initialize the old oneh]h7replace old entry by new one and initialize the old one}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj4hhubah}(h]h ]h"]h$]h&]uh1jVhjhhhjhMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijOjjjOjkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *old`` the element to be replaced ``struct list_head *new`` the new element to insert **Description** If **old** was empty, it will be overwritten.h](h)}(h**Parameters**h]j)}(hjYh]h Parameters}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjSubj)}(hhh](j)}(h5``struct list_head *old`` the element to be replaced h](j)}(h``struct list_head *old``h]j)}(hjxh]hstruct list_head *old}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjrubj)}(hhh]h)}(hthe element to be replacedh]hthe element to be replaced}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjrubeh}(h]h ]h"]h$]h&]uh1jhjhMhjoubj)}(h4``struct list_head *new`` the new element to insert h](j)}(h``struct list_head *new``h]j)}(hjh]hstruct list_head *new}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh]h)}(hthe new element to inserth]hthe new element to insert}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjoubeh}(h]h ]h"]h$]h&]uh1jhjSubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjSubh)}(h-If **old** was empty, it will be overwritten.h](hIf }(hjhhhNhNubj)}(h**old**h]hold}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh# was empty, it will be overwritten.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjSubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_swap (C function) c.list_swaphNtauh1jhj hhhNhNubj)}(hhh](j)}(hCvoid list_swap (struct list_head *entry1, struct list_head *entry2)h]j)}(hBvoid list_swap(struct list_head *entry1, struct list_head *entry2)h](jb)}(hvoidh]hvoid}(hjChhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj?hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj?hhhjQhMubj$)}(h list_swaph]j*)}(h list_swaph]h list_swap}(hjdhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj`ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj?hhhjQhMubj)}(h4(struct list_head *entry1, struct list_head *entry2)h](j)}(hstruct list_head *entry1h](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|ubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj|ubh)}(hhh]j*)}(h list_headh]h list_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]j)}jjfsb c.list_swapasbuh1hhj|ubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj|ubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|ubj*)}(hentry1h]hentry1}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj|ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjxubj)}(hstruct list_head *entry2h](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubh)}(hhh]j*)}(h list_headh]h list_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]j c.list_swapasbuh1hhjubjt)}(h h]h }(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubj)}(hj h]h*}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj*)}(hentry2h]hentry2}(hjIhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjxubeh}(h]h ]h"]h$]h&]hhuh1jhj?hhhjQhMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj;hhhjQhMubah}(h]j6ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjQhMhj8hhubjW)}(hhh]h)}(hAreplace entry1 with entry2 and re-add entry1 at entry2's positionh]hCreplace entry1 with entry2 and re-add entry1 at entry2’s position}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjphhubah}(h]h ]h"]h$]h&]uh1jVhj8hhhjQhMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijjjjjkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *entry1`` the location to place entry2 ``struct list_head *entry2`` the location to place entry1h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh](j)}(h:``struct list_head *entry1`` the location to place entry2 h](j)}(h``struct list_head *entry1``h]j)}(hjh]hstruct list_head *entry1}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh]h)}(hthe location to place entry2h]hthe location to place entry2}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h9``struct list_head *entry2`` the location to place entry1h](j)}(h``struct list_head *entry2``h]j)}(hjh]hstruct list_head *entry2}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh]h)}(hthe location to place entry1h]hthe location to place entry1}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_del_init (C function)c.list_del_inithNtauh1jhj hhhNhNubj)}(hhh](j)}(h,void list_del_init (struct list_head *entry)h]j)}(h+void list_del_init(struct list_head *entry)h](jb)}(hvoidh]hvoid}(hjGhhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjChhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM"ubjt)}(h h]h }(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjChhhjUhM"ubj$)}(h list_del_inith]j*)}(h list_del_inith]h list_del_init}(hjhhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjdubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjChhhjUhM"ubj)}(h(struct list_head *entry)h]j)}(hstruct list_head *entryh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubh)}(hhh]j*)}(h list_headh]h list_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]j)}jjjsbc.list_del_initasbuh1hhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj*)}(hentryh]hentry}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj|ubah}(h]h ]h"]h$]h&]hhuh1jhjChhhjUhM"ubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj?hhhjUhM"ubah}(h]j:ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjUhM"hj<hhubjW)}(hhh]h)}(h,deletes entry from list and reinitialize it.h]h,deletes entry from list and reinitialize it.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM"hjhhubah}(h]h ]h"]h$]h&]uh1jVhj<hhhjUhM"ubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijjjjjkjljmuh1jhhhj hNhNubj)}(hR**Parameters** ``struct list_head *entry`` the element to delete from the list.h](h)}(h**Parameters**h]j)}(hj)h]h Parameters}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM&hj#ubj)}(hhh]j)}(h@``struct list_head *entry`` the element to delete from the list.h](j)}(h``struct list_head *entry``h]j)}(hjHh]hstruct list_head *entry}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM(hjBubj)}(hhh]h)}(h$the element to delete from the list.h]h$the element to delete from the list.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM#hj^ubah}(h]h ]h"]h$]h&]uh1jhjBubeh}(h]h ]h"]h$]h&]uh1jhj]hM(hj?ubah}(h]h ]h"]h$]h&]uh1jhj#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_move (C function) c.list_movehNtauh1jhj hhhNhNubj)}(hhh](j)}(h?void list_move (struct list_head *list, struct list_head *head)h]j)}(h>void list_move(struct list_head *list, struct list_head *head)h](jb)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM,ubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjhhhjhM,ubj$)}(h list_moveh]j*)}(h list_moveh]h list_move}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjhhhjhM,ubj)}(h0(struct list_head *list, struct list_head *head)h](j)}(hstruct list_head *listh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubh)}(hhh]j*)}(h list_headh]h list_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]j)}jjsb c.list_moveasbuh1hhjubjt)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubj)}(hj h]h*}(hj+ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj*)}(hlisth]hlist}(hj8 hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubj)}(hstruct list_head *headh](j)}(hjh]hstruct}(hjQ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjM ubjt)}(h h]h }(hj^ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjM ubh)}(hhh]j*)}(h list_headh]h list_head}(hjo hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjl ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjq modnameN classnameNjj)}j]j c.list_moveasbuh1hhjM ubjt)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjM ubj)}(hj h]h*}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjM ubj*)}(hheadh]hhead}(hj hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjM ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubeh}(h]h ]h"]h$]h&]hhuh1jhjhhhjhM,ubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhM,ubah}(h]jah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjhM,hjhhubjW)}(hhh]h)}(h.delete from one list and add as another's headh]h0delete from one list and add as another’s head}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM,hj hhubah}(h]h ]h"]h$]h&]uh1jVhjhhhjhM,ubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij jjj jkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *list`` the entry to move ``struct list_head *head`` the head that will precede our entryh](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM0hj ubj)}(hhh](j)}(h-``struct list_head *list`` the entry to move h](j)}(h``struct list_head *list``h]j)}(hj!h]hstruct list_head *list}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM-hj !ubj)}(hhh]h)}(hthe entry to moveh]hthe entry to move}(hj,!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(!hM-hj)!ubah}(h]h ]h"]h$]h&]uh1jhj !ubeh}(h]h ]h"]h$]h&]uh1jhj(!hM-hj !ubj)}(h?``struct list_head *head`` the head that will precede our entryh](j)}(h``struct list_head *head``h]j)}(hjL!h]hstruct list_head *head}(hjN!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJ!ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM/hjF!ubj)}(hhh]h)}(h$the head that will precede our entryh]h$the head that will precede our entry}(hje!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM.hjb!ubah}(h]h ]h"]h$]h&]uh1jhjF!ubeh}(h]h ]h"]h$]h&]uh1jhja!hM/hj !ubeh}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_move_tail (C function)c.list_move_tailhNtauh1jhj hhhNhNubj)}(hhh](j)}(hDvoid list_move_tail (struct list_head *list, struct list_head *head)h]j)}(hCvoid list_move_tail(struct list_head *list, struct list_head *head)h](jb)}(hvoidh]hvoid}(hj!hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj!hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM7ubjt)}(h h]h }(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj!hhhj!hM7ubj$)}(hlist_move_tailh]j*)}(hlist_move_tailh]hlist_move_tail}(hj!hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj!ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj!hhhj!hM7ubj)}(h0(struct list_head *list, struct list_head *head)h](j)}(hstruct list_head *listh](j)}(hjh]hstruct}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubjt)}(h h]h }(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj!ubh)}(hhh]j*)}(h list_headh]h list_head}(hj"hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj!ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj"modnameN classnameNjj)}j]j)}jj!sbc.list_move_tailasbuh1hhj!ubjt)}(h h]h }(hj!"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj!ubj)}(hj h]h*}(hj/"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubj*)}(hlisth]hlist}(hj<"hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj!ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj!ubj)}(hstruct list_head *headh](j)}(hjh]hstruct}(hjU"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQ"ubjt)}(h h]h }(hjb"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjQ"ubh)}(hhh]j*)}(h list_headh]h list_head}(hjs"hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjp"ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetju"modnameN classnameNjj)}j]j"c.list_move_tailasbuh1hhjQ"ubjt)}(h h]h }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjQ"ubj)}(hj h]h*}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQ"ubj*)}(hheadh]hhead}(hj"hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjQ"ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj!ubeh}(h]h ]h"]h$]h&]hhuh1jhj!hhhj!hM7ubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj!hhhj!hM7ubah}(h]j!ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj!hM7hj!hhubjW)}(hhh]h)}(h.delete from one list and add as another's tailh]h0delete from one list and add as another’s tail}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM7hj"hhubah}(h]h ]h"]h$]h&]uh1jVhj!hhhj!hM7ubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij"jjj"jkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *list`` the entry to move ``struct list_head *head`` the head that will follow our entryh](h)}(h**Parameters**h]j)}(hj"h]h Parameters}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM;hj"ubj)}(hhh](j)}(h-``struct list_head *list`` the entry to move h](j)}(h``struct list_head *list``h]j)}(hj#h]hstruct list_head *list}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM8hj#ubj)}(hhh]h)}(hthe entry to moveh]hthe entry to move}(hj0#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,#hM8hj-#ubah}(h]h ]h"]h$]h&]uh1jhj#ubeh}(h]h ]h"]h$]h&]uh1jhj,#hM8hj#ubj)}(h>``struct list_head *head`` the head that will follow our entryh](j)}(h``struct list_head *head``h]j)}(hjP#h]hstruct list_head *head}(hjR#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjN#ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM:hjJ#ubj)}(hhh]h)}(h#the head that will follow our entryh]h#the head that will follow our entry}(hji#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM9hjf#ubah}(h]h ]h"]h$]h&]uh1jhjJ#ubeh}(h]h ]h"]h$]h&]uh1jhje#hM:hj#ubeh}(h]h ]h"]h$]h&]uh1jhj"ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j list_bulk_move_tail (C function)c.list_bulk_move_tailhNtauh1jhj hhhNhNubj)}(hhh](j)}(hbvoid list_bulk_move_tail (struct list_head *head, struct list_head *first, struct list_head *last)h]j)}(havoid list_bulk_move_tail(struct list_head *head, struct list_head *first, struct list_head *last)h](jb)}(hvoidh]hvoid}(hj#hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj#hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMCubjt)}(h h]h }(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj#hhhj#hMCubj$)}(hlist_bulk_move_tailh]j*)}(hlist_bulk_move_tailh]hlist_bulk_move_tail}(hj#hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj#ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj#hhhj#hMCubj)}(hI(struct list_head *head, struct list_head *first, struct list_head *last)h](j)}(hstruct list_head *headh](j)}(hjh]hstruct}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubjt)}(h h]h }(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj#ubh)}(hhh]j*)}(h list_headh]h list_head}(hj$hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj$ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj$modnameN classnameNjj)}j]j)}jj#sbc.list_bulk_move_tailasbuh1hhj#ubjt)}(h h]h }(hj%$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj#ubj)}(hj h]h*}(hj3$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#ubj*)}(hheadh]hhead}(hj@$hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj#ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj#ubj)}(hstruct list_head *firsth](j)}(hjh]hstruct}(hjY$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjU$ubjt)}(h h]h }(hjf$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjU$ubh)}(hhh]j*)}(h list_headh]h list_head}(hjw$hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjt$ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjy$modnameN classnameNjj)}j]j!$c.list_bulk_move_tailasbuh1hhjU$ubjt)}(h h]h }(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjU$ubj)}(hj h]h*}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjU$ubj*)}(hfirsth]hfirst}(hj$hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjU$ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj#ubj)}(hstruct list_head *lasth](j)}(hjh]hstruct}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubjt)}(h h]h }(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj$ubh)}(hhh]j*)}(h list_headh]h list_head}(hj$hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj$ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj$modnameN classnameNjj)}j]j!$c.list_bulk_move_tailasbuh1hhj$ubjt)}(h h]h }(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj$ubj)}(hj h]h*}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubj*)}(hlasth]hlast}(hj %hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj$ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj#ubeh}(h]h ]h"]h$]h&]hhuh1jhj#hhhj#hMCubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj#hhhj#hMCubah}(h]j#ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj#hMChj#hhubjW)}(hhh]h)}(h'move a subsection of a list to its tailh]h'move a subsection of a list to its tail}(hjJ%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMChjG%hhubah}(h]h ]h"]h$]h&]uh1jVhj#hhhj#hMCubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijb%jjjb%jkjljmuh1jhhhj hNhNubj)}(hXb**Parameters** ``struct list_head *head`` the head that will follow our entry ``struct list_head *first`` first entry to move ``struct list_head *last`` last entry to move, can be the same as first **Description** Move all entries between **first** and including **last** before **head**. All three entries must belong to the same linked list.h](h)}(h**Parameters**h]j)}(hjl%h]h Parameters}(hjn%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjj%ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMGhjf%ubj)}(hhh](j)}(h?``struct list_head *head`` the head that will follow our entry h](j)}(h``struct list_head *head``h]j)}(hj%h]hstruct list_head *head}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMDhj%ubj)}(hhh]h)}(h#the head that will follow our entryh]h#the head that will follow our entry}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hMDhj%ubah}(h]h ]h"]h$]h&]uh1jhj%ubeh}(h]h ]h"]h$]h&]uh1jhj%hMDhj%ubj)}(h0``struct list_head *first`` first entry to move h](j)}(h``struct list_head *first``h]j)}(hj%h]hstruct list_head *first}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMEhj%ubj)}(hhh]h)}(hfirst entry to moveh]hfirst entry to move}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hMEhj%ubah}(h]h ]h"]h$]h&]uh1jhj%ubeh}(h]h ]h"]h$]h&]uh1jhj%hMEhj%ubj)}(hH``struct list_head *last`` last entry to move, can be the same as first h](j)}(h``struct list_head *last``h]j)}(hj%h]hstruct list_head *last}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMFhj%ubj)}(hhh]h)}(h,last entry to move, can be the same as firsth]h,last entry to move, can be the same as first}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMFhj&ubah}(h]h ]h"]h$]h&]uh1jhj%ubeh}(h]h ]h"]h$]h&]uh1jhj&hMFhj%ubeh}(h]h ]h"]h$]h&]uh1jhjf%ubh)}(h**Description**h]j)}(hj8&h]h Description}(hj:&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6&ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMHhjf%ubh)}(hMove all entries between **first** and including **last** before **head**. All three entries must belong to the same linked list.h](hMove all entries between }(hjN&hhhNhNubj)}(h **first**h]hfirst}(hjV&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjN&ubh and including }(hjN&hhhNhNubj)}(h**last**h]hlast}(hjh&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjN&ubh before }(hjN&hhhNhNubj)}(h**head**h]hhead}(hjz&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjN&ubh8. All three entries must belong to the same linked list.}(hjN&hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMGhjf%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_is_first (C function)c.list_is_firsthNtauh1jhj hhhNhNubj)}(hhh](j)}(hNint list_is_first (const struct list_head *list, const struct list_head *head)h]j)}(hMint list_is_first(const struct list_head *list, const struct list_head *head)h](jb)}(hinth]hint}(hj&hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj&hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMZubjt)}(h h]h }(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj&hhhj&hMZubj$)}(h list_is_firsth]j*)}(h list_is_firsth]h list_is_first}(hj&hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj&ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj&hhhj&hMZubj)}(h<(const struct list_head *list, const struct list_head *head)h](j)}(hconst struct list_head *listh](j)}(hconsth]hconst}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubjt)}(h h]h }(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj&ubj)}(hjh]hstruct}(hj 'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubjt)}(h h]h }(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj&ubh)}(hhh]j*)}(h list_headh]h list_head}(hj*'hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj''ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj,'modnameN classnameNjj)}j]j)}jj&sbc.list_is_firstasbuh1hhj&ubjt)}(h h]h }(hjJ'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj&ubj)}(hj h]h*}(hjX'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubj*)}(hlisth]hlist}(hje'hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj&ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj&ubj)}(hconst struct list_head *headh](j)}(hj&h]hconst}(hj~'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz'ubjt)}(h h]h }(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjz'ubj)}(hjh]hstruct}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz'ubjt)}(h h]h }(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjz'ubh)}(hhh]j*)}(h list_headh]h list_head}(hj'hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj'ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj'modnameN classnameNjj)}j]jF'c.list_is_firstasbuh1hhjz'ubjt)}(h h]h }(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjz'ubj)}(hj h]h*}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz'ubj*)}(hheadh]hhead}(hj'hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjz'ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj&ubeh}(h]h ]h"]h$]h&]hhuh1jhj&hhhj&hMZubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj&hhhj&hMZubah}(h]j&ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj&hMZhj&hhubjW)}(hhh]j8)}(hhh]j=)}(h:tests whether **list** is the first entry in list **head**h]h)}(hj(h](htests whether }(hj!(hhhNhNubj)}(h**list**h]hlist}(hj((hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!(ubh is the first entry in list }(hj!(hhhNhNubj)}(h**head**h]hhead}(hj:(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!(ubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMZhj(ubah}(h]h ]h"]h$]h&]uh1j<hj(hhhjN(hNubah}(h]h ]h"]h$]h&]j -uh1j7hjN(hMZhj(hhubah}(h]h ]h"]h$]h&]uh1jVhj&hhhj&hMZubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjije(jjje(jkjljmuh1jhhhj hNhNubj)}(h}**Parameters** ``const struct list_head *list`` the entry to test ``const struct list_head *head`` the head of the listh](h)}(h**Parameters**h]j)}(hjo(h]h Parameters}(hjq(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjm(ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM^hji(ubj)}(hhh](j)}(h3``const struct list_head *list`` the entry to test h](j)}(h ``const struct list_head *list``h]j)}(hj(h]hconst struct list_head *list}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM[hj(ubj)}(hhh]h)}(hthe entry to testh]hthe entry to test}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(hM[hj(ubah}(h]h ]h"]h$]h&]uh1jhj(ubeh}(h]h ]h"]h$]h&]uh1jhj(hM[hj(ubj)}(h5``const struct list_head *head`` the head of the listh](j)}(h ``const struct list_head *head``h]j)}(hj(h]hconst struct list_head *head}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM]hj(ubj)}(hhh]h)}(hthe head of the listh]hthe head of the list}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM\hj(ubah}(h]h ]h"]h$]h&]uh1jhj(ubeh}(h]h ]h"]h$]h&]uh1jhj(hM]hj(ubeh}(h]h ]h"]h$]h&]uh1jhji(ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_is_last (C function)c.list_is_lasthNtauh1jhj hhhNhNubj)}(hhh](j)}(hMint list_is_last (const struct list_head *list, const struct list_head *head)h]j)}(hLint list_is_last(const struct list_head *list, const struct list_head *head)h](jb)}(hinth]hint}(hj!)hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj)hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMdubjt)}(h h]h }(hj0)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj)hhhj/)hMdubj$)}(h list_is_lasth]j*)}(h list_is_lasth]h list_is_last}(hjB)hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj>)ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj)hhhj/)hMdubj)}(h<(const struct list_head *list, const struct list_head *head)h](j)}(hconst struct list_head *listh](j)}(hj&h]hconst}(hj^)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZ)ubjt)}(h h]h }(hjk)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjZ)ubj)}(hjh]hstruct}(hjy)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZ)ubjt)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjZ)ubh)}(hhh]j*)}(h list_headh]h list_head}(hj)hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj)ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj)modnameN classnameNjj)}j]j)}jjD)sbc.list_is_lastasbuh1hhjZ)ubjt)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjZ)ubj)}(hj h]h*}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZ)ubj*)}(hlisth]hlist}(hj)hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjZ)ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjV)ubj)}(hconst struct list_head *headh](j)}(hj&h]hconst}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubjt)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj)ubj)}(hjh]hstruct}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubjt)}(h h]h }(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj)ubh)}(hhh]j*)}(h list_headh]h list_head}(hj$*hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj!*ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj&*modnameN classnameNjj)}j]j)c.list_is_lastasbuh1hhj)ubjt)}(h h]h }(hjB*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj)ubj)}(hj h]h*}(hjP*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubj*)}(hheadh]hhead}(hj]*hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj)ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjV)ubeh}(h]h ]h"]h$]h&]hhuh1jhj)hhhj/)hMdubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj)hhhj/)hMdubah}(h]j)ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj/)hMdhj)hhubjW)}(hhh]h)}(h9tests whether **list** is the last entry in list **head**h](htests whether }(hj*hhhNhNubj)}(h**list**h]hlist}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubh is the last entry in list }(hj*hhhNhNubj)}(h**head**h]hhead}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMdhj*hhubah}(h]h ]h"]h$]h&]uh1jVhj)hhhj/)hMdubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij*jjj*jkjljmuh1jhhhj hNhNubj)}(h}**Parameters** ``const struct list_head *list`` the entry to test ``const struct list_head *head`` the head of the listh](h)}(h**Parameters**h]j)}(hj*h]h Parameters}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhhj*ubj)}(hhh](j)}(h3``const struct list_head *list`` the entry to test h](j)}(h ``const struct list_head *list``h]j)}(hj*h]hconst struct list_head *list}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMehj*ubj)}(hhh]h)}(hthe entry to testh]hthe entry to test}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hMehj*ubah}(h]h ]h"]h$]h&]uh1jhj*ubeh}(h]h ]h"]h$]h&]uh1jhj*hMehj*ubj)}(h5``const struct list_head *head`` the head of the listh](j)}(h ``const struct list_head *head``h]j)}(hj!+h]hconst struct list_head *head}(hj#+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMghj+ubj)}(hhh]h)}(hthe head of the listh]hthe head of the list}(hj:+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMfhj7+ubah}(h]h ]h"]h$]h&]uh1jhj+ubeh}(h]h ]h"]h$]h&]uh1jhj6+hMghj*ubeh}(h]h ]h"]h$]h&]uh1jhj*ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_is_head (C function)c.list_is_headhNtauh1jhj hhhNhNubj)}(hhh](j)}(hMint list_is_head (const struct list_head *list, const struct list_head *head)h]j)}(hLint list_is_head(const struct list_head *list, const struct list_head *head)h](jb)}(hinth]hint}(hj{+hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjw+hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMnubjt)}(h h]h }(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjw+hhhj+hMnubj$)}(h list_is_headh]j*)}(h list_is_headh]h list_is_head}(hj+hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj+ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjw+hhhj+hMnubj)}(h<(const struct list_head *list, const struct list_head *head)h](j)}(hconst struct list_head *listh](j)}(hj&h]hconst}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubjt)}(h h]h }(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj+ubj)}(hjh]hstruct}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubjt)}(h h]h }(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj+ubh)}(hhh]j*)}(h list_headh]h list_head}(hj+hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj+ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj+modnameN classnameNjj)}j]j)}jj+sbc.list_is_headasbuh1hhj+ubjt)}(h h]h }(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj+ubj)}(hj h]h*}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubj*)}(hlisth]hlist}(hj,,hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj+ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj+ubj)}(hconst struct list_head *headh](j)}(hj&h]hconst}(hjE,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjA,ubjt)}(h h]h }(hjR,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjA,ubj)}(hjh]hstruct}(hj`,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjA,ubjt)}(h h]h }(hjm,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjA,ubh)}(hhh]j*)}(h list_headh]h list_head}(hj~,hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj{,ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj,modnameN classnameNjj)}j]j ,c.list_is_headasbuh1hhjA,ubjt)}(h h]h }(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjA,ubj)}(hj h]h*}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjA,ubj*)}(hheadh]hhead}(hj,hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjA,ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj+ubeh}(h]h ]h"]h$]h&]hhuh1jhjw+hhhj+hMnubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjs+hhhj+hMnubah}(h]jn+ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj+hMnhjp+hhubjW)}(hhh]h)}(h+tests whether **list** is the list **head**h](htests whether }(hj,hhhNhNubj)}(h**list**h]hlist}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubh is the list }(hj,hhhNhNubj)}(h**head**h]hhead}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMnhj,hhubah}(h]h ]h"]h$]h&]uh1jVhjp+hhhj+hMnubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij-jjj-jkjljmuh1jhhhj hNhNubj)}(h}**Parameters** ``const struct list_head *list`` the entry to test ``const struct list_head *head`` the head of the listh](h)}(h**Parameters**h]j)}(hj#-h]h Parameters}(hj%-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!-ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMrhj-ubj)}(hhh](j)}(h3``const struct list_head *list`` the entry to test h](j)}(h ``const struct list_head *list``h]j)}(hjB-h]hconst struct list_head *list}(hjD-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@-ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMohj<-ubj)}(hhh]h)}(hthe entry to testh]hthe entry to test}(hj[-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjW-hMohjX-ubah}(h]h ]h"]h$]h&]uh1jhj<-ubeh}(h]h ]h"]h$]h&]uh1jhjW-hMohj9-ubj)}(h5``const struct list_head *head`` the head of the listh](j)}(h ``const struct list_head *head``h]j)}(hj{-h]hconst struct list_head *head}(hj}-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjy-ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMqhju-ubj)}(hhh]h)}(hthe head of the listh]hthe head of the list}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMphj-ubah}(h]h ]h"]h$]h&]uh1jhju-ubeh}(h]h ]h"]h$]h&]uh1jhj-hMqhj9-ubeh}(h]h ]h"]h$]h&]uh1jhj-ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_empty (C function) c.list_emptyhNtauh1jhj hhhNhNubj)}(hhh](j)}(h-int list_empty (const struct list_head *head)h]j)}(h,int list_empty(const struct list_head *head)h](jb)}(hinth]hint}(hj-hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj-hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMxubjt)}(h h]h }(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj-hhhj-hMxubj$)}(h list_emptyh]j*)}(h list_emptyh]h list_empty}(hj-hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj-ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj-hhhj-hMxubj)}(h(const struct list_head *head)h]j)}(hconst struct list_head *headh](j)}(hj&h]hconst}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.ubjt)}(h h]h }(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj.ubj)}(hjh]hstruct}(hj-.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.ubjt)}(h h]h }(hj:.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj.ubh)}(hhh]j*)}(h list_headh]h list_head}(hjK.hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjH.ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjM.modnameN classnameNjj)}j]j)}jj-sb c.list_emptyasbuh1hhj.ubjt)}(h h]h }(hjk.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj.ubj)}(hj h]h*}(hjy.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.ubj*)}(hheadh]hhead}(hj.hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj.ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj .ubah}(h]h ]h"]h$]h&]hhuh1jhj-hhhj-hMxubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj-hhhj-hMxubah}(h]j-ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj-hMxhj-hhubjW)}(hhh]h)}(htests whether a list is emptyh]htests whether a list is empty}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMxhj.hhubah}(h]h ]h"]h$]h&]uh1jVhj-hhhj-hMxubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij.jjj.jkjljmuh1jhhhj hNhNubj)}(hD**Parameters** ``const struct list_head *head`` the list to test.h](h)}(h**Parameters**h]j)}(hj.h]h Parameters}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM|hj.ubj)}(hhh]j)}(h2``const struct list_head *head`` the list to test.h](j)}(h ``const struct list_head *head``h]j)}(hj.h]hconst struct list_head *head}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM~hj.ubj)}(hhh]h)}(hthe list to test.h]hthe list to test.}(hj /hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMyhj/ubah}(h]h ]h"]h$]h&]uh1jhj.ubeh}(h]h ]h"]h$]h&]uh1jhj/hM~hj.ubah}(h]h ]h"]h$]h&]uh1jhj.ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j"list_del_init_careful (C function)c.list_del_init_carefulhNtauh1jhj hhhNhNubj)}(hhh](j)}(h4void list_del_init_careful (struct list_head *entry)h]j)}(h3void list_del_init_careful(struct list_head *entry)h](jb)}(hvoidh]hvoid}(hjK/hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjG/hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hjZ/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjG/hhhjY/hMubj$)}(hlist_del_init_carefulh]j*)}(hlist_del_init_carefulh]hlist_del_init_careful}(hjl/hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjh/ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjG/hhhjY/hMubj)}(h(struct list_head *entry)h]j)}(hstruct list_head *entryh](j)}(hjh]hstruct}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubjt)}(h h]h }(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj/ubh)}(hhh]j*)}(h list_headh]h list_head}(hj/hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj/ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj/modnameN classnameNjj)}j]j)}jjn/sbc.list_del_init_carefulasbuh1hhj/ubjt)}(h h]h }(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj/ubj)}(hj h]h*}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubj*)}(hentryh]hentry}(hj/hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj/ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj/ubah}(h]h ]h"]h$]h&]hhuh1jhjG/hhhjY/hMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjC/hhhjY/hMubah}(h]j>/ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjY/hMhj@/hhubjW)}(hhh]h)}(h,deletes entry from list and reinitialize it.h]h,deletes entry from list and reinitialize it.}(hj 0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj0hhubah}(h]h ]h"]h$]h&]uh1jVhj@/hhhjY/hMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij#0jjj#0jkjljmuh1jhhhj hNhNubj)}(hX**Parameters** ``struct list_head *entry`` the element to delete from the list. **Description** This is the same as list_del_init(), except designed to be used together with list_empty_careful() in a way to guarantee ordering of other memory operations. Any memory operations done before a list_del_init_careful() are guaranteed to be visible after a list_empty_careful() test.h](h)}(h**Parameters**h]j)}(hj-0h]h Parameters}(hj/0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+0ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj'0ubj)}(hhh]j)}(hA``struct list_head *entry`` the element to delete from the list. h](j)}(h``struct list_head *entry``h]j)}(hjL0h]hstruct list_head *entry}(hjN0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJ0ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjF0ubj)}(hhh]h)}(h$the element to delete from the list.h]h$the element to delete from the list.}(hje0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhja0hMhjb0ubah}(h]h ]h"]h$]h&]uh1jhjF0ubeh}(h]h ]h"]h$]h&]uh1jhja0hMhjC0ubah}(h]h ]h"]h$]h&]uh1jhj'0ubh)}(h**Description**h]j)}(hj0h]h Description}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj'0ubh)}(hThis is the same as list_del_init(), except designed to be used together with list_empty_careful() in a way to guarantee ordering of other memory operations.h]hThis is the same as list_del_init(), except designed to be used together with list_empty_careful() in a way to guarantee ordering of other memory operations.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj'0ubh)}(h{Any memory operations done before a list_del_init_careful() are guaranteed to be visible after a list_empty_careful() test.h]h{Any memory operations done before a list_del_init_careful() are guaranteed to be visible after a list_empty_careful() test.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj'0ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_empty_careful (C function)c.list_empty_carefulhNtauh1jhj hhhNhNubj)}(hhh](j)}(h5int list_empty_careful (const struct list_head *head)h]j)}(h4int list_empty_careful(const struct list_head *head)h](jb)}(hinth]hint}(hj0hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj0hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj0hhhj0hMubj$)}(hlist_empty_carefulh]j*)}(hlist_empty_carefulh]hlist_empty_careful}(hj0hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj0ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj0hhhj0hMubj)}(h(const struct list_head *head)h]j)}(hconst struct list_head *headh](j)}(hj&h]hconst}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ubjt)}(h h]h }(hj%1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj1ubj)}(hjh]hstruct}(hj31hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ubjt)}(h h]h }(hj@1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj1ubh)}(hhh]j*)}(h list_headh]h list_head}(hjQ1hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjN1ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjS1modnameN classnameNjj)}j]j)}jj0sbc.list_empty_carefulasbuh1hhj1ubjt)}(h h]h }(hjq1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj1ubj)}(hj h]h*}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ubj*)}(hheadh]hhead}(hj1hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj1ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj1ubah}(h]h ]h"]h$]h&]hhuh1jhj0hhhj0hMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj0hhhj0hMubah}(h]j0ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj0hMhj0hhubjW)}(hhh]h)}(h4tests whether a list is empty and not being modifiedh]h4tests whether a list is empty and not being modified}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj1hhubah}(h]h ]h"]h$]h&]uh1jVhj0hhhj0hMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij1jjj1jkjljmuh1jhhhj hNhNubj)}(hX**Parameters** ``const struct list_head *head`` the list to test **Description** tests whether a list is empty _and_ checks that no other CPU might be in the process of modifying either member (next or prev) **NOTE** using list_empty_careful() without synchronization can only be safe if the only activity that can happen to the list entry is list_del_init(). Eg. it cannot be used if another CPU could re-list_add() it.h](h)}(h**Parameters**h]j)}(hj1h]h Parameters}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj1ubj)}(hhh]j)}(h2``const struct list_head *head`` the list to test h](j)}(h ``const struct list_head *head``h]j)}(hj1h]hconst struct list_head *head}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj1ubj)}(hhh]h)}(hthe list to testh]hthe list to test}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj 2hMhj 2ubah}(h]h ]h"]h$]h&]uh1jhj1ubeh}(h]h ]h"]h$]h&]uh1jhj 2hMhj1ubah}(h]h ]h"]h$]h&]uh1jhj1ubh)}(h**Description**h]j)}(hj22h]h Description}(hj42hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj02ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj1ubh)}(h~tests whether a list is empty _and_ checks that no other CPU might be in the process of modifying either member (next or prev)h]h~tests whether a list is empty _and_ checks that no other CPU might be in the process of modifying either member (next or prev)}(hjH2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj1ubh)}(h**NOTE**h]j)}(hjY2h]hNOTE}(hj[2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjW2ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj1ubh)}(husing list_empty_careful() without synchronization can only be safe if the only activity that can happen to the list entry is list_del_init(). Eg. it cannot be used if another CPU could re-list_add() it.h]husing list_empty_careful() without synchronization can only be safe if the only activity that can happen to the list entry is list_del_init(). Eg. it cannot be used if another CPU could re-list_add() it.}(hjo2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj1ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_rotate_left (C function)c.list_rotate_lefthNtauh1jhj hhhNhNubj)}(hhh](j)}(h.void list_rotate_left (struct list_head *head)h]j)}(h-void list_rotate_left(struct list_head *head)h](jb)}(hvoidh]hvoid}(hj2hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj2hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj2hhhj2hMubj$)}(hlist_rotate_lefth]j*)}(hlist_rotate_lefth]hlist_rotate_left}(hj2hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj2ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj2hhhj2hMubj)}(h(struct list_head *head)h]j)}(hstruct list_head *headh](j)}(hjh]hstruct}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubjt)}(h h]h }(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj2ubh)}(hhh]j*)}(h list_headh]h list_head}(hj2hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj2ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj2modnameN classnameNjj)}j]j)}jj2sbc.list_rotate_leftasbuh1hhj2ubjt)}(h h]h }(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj2ubj)}(hj h]h*}(hj'3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj2ubj*)}(hheadh]hhead}(hj43hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj2ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj2ubah}(h]h ]h"]h$]h&]hhuh1jhj2hhhj2hMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj2hhhj2hMubah}(h]j2ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj2hMhj2hhubjW)}(hhh]h)}(hrotate the list to the lefth]hrotate the list to the left}(hj^3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj[3hhubah}(h]h ]h"]h$]h&]uh1jVhj2hhhj2hMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijv3jjjv3jkjljmuh1jhhhj hNhNubj)}(hA**Parameters** ``struct list_head *head`` the head of the listh](h)}(h**Parameters**h]j)}(hj3h]h Parameters}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~3ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjz3ubj)}(hhh]j)}(h/``struct list_head *head`` the head of the listh](j)}(h``struct list_head *head``h]j)}(hj3h]hstruct list_head *head}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj3ubj)}(hhh]h)}(hthe head of the listh]hthe head of the list}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj3ubah}(h]h ]h"]h$]h&]uh1jhj3ubeh}(h]h ]h"]h$]h&]uh1jhj3hMhj3ubah}(h]h ]h"]h$]h&]uh1jhjz3ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j!list_rotate_to_front (C function)c.list_rotate_to_fronthNtauh1jhj hhhNhNubj)}(hhh](j)}(hJvoid list_rotate_to_front (struct list_head *list, struct list_head *head)h]j)}(hIvoid list_rotate_to_front(struct list_head *list, struct list_head *head)h](jb)}(hvoidh]hvoid}(hj3hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj3hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj3hhhj4hMubj$)}(hlist_rotate_to_fronth]j*)}(hlist_rotate_to_fronth]hlist_rotate_to_front}(hj4hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj4ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj3hhhj4hMubj)}(h0(struct list_head *list, struct list_head *head)h](j)}(hstruct list_head *listh](j)}(hjh]hstruct}(hj64hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj24ubjt)}(h h]h }(hjC4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj24ubh)}(hhh]j*)}(h list_headh]h list_head}(hjT4hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjQ4ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjV4modnameN classnameNjj)}j]j)}jj4sbc.list_rotate_to_frontasbuh1hhj24ubjt)}(h h]h }(hjt4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj24ubj)}(hj h]h*}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj24ubj*)}(hlisth]hlist}(hj4hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj24ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj.4ubj)}(hstruct list_head *headh](j)}(hjh]hstruct}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubjt)}(h h]h }(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj4ubh)}(hhh]j*)}(h list_headh]h list_head}(hj4hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj4ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj4modnameN classnameNjj)}j]jp4c.list_rotate_to_frontasbuh1hhj4ubjt)}(h h]h }(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj4ubj)}(hj h]h*}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubj*)}(hheadh]hhead}(hj4hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj4ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj.4ubeh}(h]h ]h"]h$]h&]hhuh1jhj3hhhj4hMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj3hhhj4hMubah}(h]j3ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj4hMhj3hhubjW)}(hhh]h)}(hRotate list to specific item.h]hRotate list to specific item.}(hj)5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj&5hhubah}(h]h ]h"]h$]h&]uh1jVhj3hhhj4hMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijA5jjjA5jkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *list`` The desired new front of the list. ``struct list_head *head`` The head of the list. **Description** Rotates list so that **list** becomes the new front of the list.h](h)}(h**Parameters**h]j)}(hjK5h]h Parameters}(hjM5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjI5ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjE5ubj)}(hhh](j)}(h>``struct list_head *list`` The desired new front of the list. h](j)}(h``struct list_head *list``h]j)}(hjj5h]hstruct list_head *list}(hjl5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjh5ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjd5ubj)}(hhh]h)}(h"The desired new front of the list.h]h"The desired new front of the list.}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hMhj5ubah}(h]h ]h"]h$]h&]uh1jhjd5ubeh}(h]h ]h"]h$]h&]uh1jhj5hMhja5ubj)}(h1``struct list_head *head`` The head of the list. h](j)}(h``struct list_head *head``h]j)}(hj5h]hstruct list_head *head}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj5ubj)}(hhh]h)}(hThe head of the list.h]hThe head of the list.}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hMhj5ubah}(h]h ]h"]h$]h&]uh1jhj5ubeh}(h]h ]h"]h$]h&]uh1jhj5hMhja5ubeh}(h]h ]h"]h$]h&]uh1jhjE5ubh)}(h**Description**h]j)}(hj5h]h Description}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjE5ubh)}(h@Rotates list so that **list** becomes the new front of the list.h](hRotates list so that }(hj5hhhNhNubj)}(h**list**h]hlist}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubh# becomes the new front of the list.}(hj5hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjE5ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_is_singular (C function)c.list_is_singularhNtauh1jhj hhhNhNubj)}(hhh](j)}(h3int list_is_singular (const struct list_head *head)h]j)}(h2int list_is_singular(const struct list_head *head)h](jb)}(hinth]hint}(hj56hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj16hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hjD6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj16hhhjC6hMubj$)}(hlist_is_singularh]j*)}(hlist_is_singularh]hlist_is_singular}(hjV6hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjR6ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj16hhhjC6hMubj)}(h(const struct list_head *head)h]j)}(hconst struct list_head *headh](j)}(hj&h]hconst}(hjr6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjn6ubjt)}(h h]h }(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjn6ubj)}(hjh]hstruct}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjn6ubjt)}(h h]h }(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjn6ubh)}(hhh]j*)}(h list_headh]h list_head}(hj6hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj6ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj6modnameN classnameNjj)}j]j)}jjX6sbc.list_is_singularasbuh1hhjn6ubjt)}(h h]h }(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjn6ubj)}(hj h]h*}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjn6ubj*)}(hheadh]hhead}(hj6hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjn6ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjj6ubah}(h]h ]h"]h$]h&]hhuh1jhj16hhhjC6hMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj-6hhhjC6hMubah}(h]j(6ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjC6hMhj*6hhubjW)}(hhh]h)}(h(tests whether a list has just one entry.h]h(tests whether a list has just one entry.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj 7hhubah}(h]h ]h"]h$]h&]uh1jVhj*6hhhjC6hMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij(7jjj(7jkjljmuh1jhhhj hNhNubj)}(hD**Parameters** ``const struct list_head *head`` the list to test.h](h)}(h**Parameters**h]j)}(hj27h]h Parameters}(hj47hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj07ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj,7ubj)}(hhh]j)}(h2``const struct list_head *head`` the list to test.h](j)}(h ``const struct list_head *head``h]j)}(hjQ7h]hconst struct list_head *head}(hjS7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjO7ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjK7ubj)}(hhh]h)}(hthe list to test.h]hthe list to test.}(hjj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjg7ubah}(h]h ]h"]h$]h&]uh1jhjK7ubeh}(h]h ]h"]h$]h&]uh1jhjf7hMhjH7ubah}(h]h ]h"]h$]h&]uh1jhj,7ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_cut_position (C function)c.list_cut_positionhNtauh1jhj hhhNhNubj)}(hhh](j)}(h`void list_cut_position (struct list_head *list, struct list_head *head, struct list_head *entry)h]j)}(h_void list_cut_position(struct list_head *list, struct list_head *head, struct list_head *entry)h](jb)}(hvoidh]hvoid}(hj7hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj7hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj7hhhj7hMubj$)}(hlist_cut_positionh]j*)}(hlist_cut_positionh]hlist_cut_position}(hj7hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj7ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj7hhhj7hMubj)}(hI(struct list_head *list, struct list_head *head, struct list_head *entry)h](j)}(hstruct list_head *listh](j)}(hjh]hstruct}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubjt)}(h h]h }(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj7ubh)}(hhh]j*)}(h list_headh]h list_head}(hj8hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj8ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj8modnameN classnameNjj)}j]j)}jj7sbc.list_cut_positionasbuh1hhj7ubjt)}(h h]h }(hj&8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj7ubj)}(hj h]h*}(hj48hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubj*)}(hlisth]hlist}(hjA8hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj7ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj7ubj)}(hstruct list_head *headh](j)}(hjh]hstruct}(hjZ8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjV8ubjt)}(h h]h }(hjg8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjV8ubh)}(hhh]j*)}(h list_headh]h list_head}(hjx8hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hju8ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjz8modnameN classnameNjj)}j]j"8c.list_cut_positionasbuh1hhjV8ubjt)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjV8ubj)}(hj h]h*}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjV8ubj*)}(hheadh]hhead}(hj8hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjV8ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj7ubj)}(hstruct list_head *entryh](j)}(hjh]hstruct}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubjt)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj8ubh)}(hhh]j*)}(h list_headh]h list_head}(hj8hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj8ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj8modnameN classnameNjj)}j]j"8c.list_cut_positionasbuh1hhj8ubjt)}(h h]h }(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj8ubj)}(hj h]h*}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj*)}(hentryh]hentry}(hj!9hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj8ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj7ubeh}(h]h ]h"]h$]h&]hhuh1jhj7hhhj7hMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj7hhhj7hMubah}(h]j7ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj7hMhj7hhubjW)}(hhh]h)}(hcut a list into twoh]hcut a list into two}(hjK9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjH9hhubah}(h]h ]h"]h$]h&]uh1jVhj7hhhj7hMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijc9jjjc9jkjljmuh1jhhhj hNhNubj)}(hX**Parameters** ``struct list_head *list`` a new list to add all removed entries ``struct list_head *head`` a list with entries ``struct list_head *entry`` an entry within head, could be the head itself and if so we won't cut the list **Description** This helper moves the initial part of **head**, up to and including **entry**, from **head** to **list**. You should pass on **entry** an element you know is on **head**. **list** should be an empty list or a list you do not care about losing its data.h](h)}(h**Parameters**h]j)}(hjm9h]h Parameters}(hjo9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjk9ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjg9ubj)}(hhh](j)}(hA``struct list_head *list`` a new list to add all removed entries h](j)}(h``struct list_head *list``h]j)}(hj9h]hstruct list_head *list}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj9ubj)}(hhh]h)}(h%a new list to add all removed entriesh]h%a new list to add all removed entries}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hMhj9ubah}(h]h ]h"]h$]h&]uh1jhj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hMhj9ubj)}(h/``struct list_head *head`` a list with entries h](j)}(h``struct list_head *head``h]j)}(hj9h]hstruct list_head *head}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj9ubj)}(hhh]h)}(ha list with entriesh]ha list with entries}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hMhj9ubah}(h]h ]h"]h$]h&]uh1jhj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hMhj9ubj)}(hk``struct list_head *entry`` an entry within head, could be the head itself and if so we won't cut the list h](j)}(h``struct list_head *entry``h]j)}(hj9h]hstruct list_head *entry}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj9ubj)}(hhh]h)}(hNan entry within head, could be the head itself and if so we won't cut the listh]hPan entry within head, could be the head itself and if so we won’t cut the list}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj:ubah}(h]h ]h"]h$]h&]uh1jhj9ubeh}(h]h ]h"]h$]h&]uh1jhj:hMhj9ubeh}(h]h ]h"]h$]h&]uh1jhjg9ubh)}(h**Description**h]j)}(hj::h]h Description}(hj<:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8:ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjg9ubh)}(hThis helper moves the initial part of **head**, up to and including **entry**, from **head** to **list**. You should pass on **entry** an element you know is on **head**. **list** should be an empty list or a list you do not care about losing its data.h](h&This helper moves the initial part of }(hjP:hhhNhNubj)}(h**head**h]hhead}(hjX:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP:ubh, up to and including }(hjP:hhhNhNubj)}(h **entry**h]hentry}(hjj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP:ubh, from }(hjP:hhhNhNubj)}(h**head**h]hhead}(hj|:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP:ubh to }(hjP:hhhNhNubj)}(h**list**h]hlist}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP:ubh. You should pass on }(hjP:hhhNhNubj)}(h **entry**h]hentry}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP:ubh an element you know is on }(hjP:hhhNhNubj)}(h**head**h]hhead}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP:ubh. }(hjP:hhhNhNubj)}(h**list**h]hlist}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP:ubhI should be an empty list or a list you do not care about losing its data.}(hjP:hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjg9ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_cut_before (C function)c.list_cut_beforehNtauh1jhj hhhNhNubj)}(hhh](j)}(h^void list_cut_before (struct list_head *list, struct list_head *head, struct list_head *entry)h]j)}(h]void list_cut_before(struct list_head *list, struct list_head *head, struct list_head *entry)h](jb)}(hvoidh]hvoid}(hj:hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj:hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hj ;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj:hhhj ;hMubj$)}(hlist_cut_beforeh]j*)}(hlist_cut_beforeh]hlist_cut_before}(hj;hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj;ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj:hhhj ;hMubj)}(hI(struct list_head *list, struct list_head *head, struct list_head *entry)h](j)}(hstruct list_head *listh](j)}(hjh]hstruct}(hj:;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6;ubjt)}(h h]h }(hjG;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj6;ubh)}(hhh]j*)}(h list_headh]h list_head}(hjX;hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjU;ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjZ;modnameN classnameNjj)}j]j)}jj ;sbc.list_cut_beforeasbuh1hhj6;ubjt)}(h h]h }(hjx;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj6;ubj)}(hj h]h*}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6;ubj*)}(hlisth]hlist}(hj;hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj6;ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj2;ubj)}(hstruct list_head *headh](j)}(hjh]hstruct}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj;ubjt)}(h h]h }(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj;ubh)}(hhh]j*)}(h list_headh]h list_head}(hj;hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj;ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj;modnameN classnameNjj)}j]jt;c.list_cut_beforeasbuh1hhj;ubjt)}(h h]h }(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj;ubj)}(hj h]h*}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj;ubj*)}(hheadh]hhead}(hj<hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj;ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj2;ubj)}(hstruct list_head *entryh](j)}(hjh]hstruct}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<ubjt)}(h h]h }(hj)<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj<ubh)}(hhh]j*)}(h list_headh]h list_head}(hj:<hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj7<ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj<<modnameN classnameNjj)}j]jt;c.list_cut_beforeasbuh1hhj<ubjt)}(h h]h }(hjX<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj<ubj)}(hj h]h*}(hjf<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<ubj*)}(hentryh]hentry}(hjs<hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj<ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj2;ubeh}(h]h ]h"]h$]h&]hhuh1jhj:hhhj ;hMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj:hhhj ;hMubah}(h]j:ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj ;hMhj:hhubjW)}(hhh]h)}(h'cut a list into two, before given entryh]h'cut a list into two, before given entry}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj<hhubah}(h]h ]h"]h$]h&]uh1jVhj:hhhj ;hMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij<jjj<jkjljmuh1jhhhj hNhNubj)}(hX,**Parameters** ``struct list_head *list`` a new list to add all removed entries ``struct list_head *head`` a list with entries ``struct list_head *entry`` an entry within head, could be the head itself **Description** This helper moves the initial part of **head**, up to but excluding **entry**, from **head** to **list**. You should pass in **entry** an element you know is on **head**. **list** should be an empty list or a list you do not care about losing its data. If **entry** == **head**, all entries on **head** are moved to **list**.h](h)}(h**Parameters**h]j)}(hj<h]h Parameters}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj<ubj)}(hhh](j)}(hA``struct list_head *list`` a new list to add all removed entries h](j)}(h``struct list_head *list``h]j)}(hj<h]hstruct list_head *list}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj<ubj)}(hhh]h)}(h%a new list to add all removed entriesh]h%a new list to add all removed entries}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hMhj<ubah}(h]h ]h"]h$]h&]uh1jhj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hMhj<ubj)}(h/``struct list_head *head`` a list with entries h](j)}(h``struct list_head *head``h]j)}(hj=h]hstruct list_head *head}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj=ubj)}(hhh]h)}(ha list with entriesh]ha list with entries}(hj0=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,=hMhj-=ubah}(h]h ]h"]h$]h&]uh1jhj=ubeh}(h]h ]h"]h$]h&]uh1jhj,=hMhj<ubj)}(hK``struct list_head *entry`` an entry within head, could be the head itself h](j)}(h``struct list_head *entry``h]j)}(hjP=h]hstruct list_head *entry}(hjR=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjN=ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjJ=ubj)}(hhh]h)}(h.an entry within head, could be the head itselfh]h.an entry within head, could be the head itself}(hji=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhje=hMhjf=ubah}(h]h ]h"]h$]h&]uh1jhjJ=ubeh}(h]h ]h"]h$]h&]uh1jhje=hMhj<ubeh}(h]h ]h"]h$]h&]uh1jhj<ubh)}(h**Description**h]j)}(hj=h]h Description}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj<ubh)}(hXGThis helper moves the initial part of **head**, up to but excluding **entry**, from **head** to **list**. You should pass in **entry** an element you know is on **head**. **list** should be an empty list or a list you do not care about losing its data. If **entry** == **head**, all entries on **head** are moved to **list**.h](h&This helper moves the initial part of }(hj=hhhNhNubj)}(h**head**h]hhead}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubh, up to but excluding }(hj=hhhNhNubj)}(h **entry**h]hentry}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubh, from }(hj=hhhNhNubj)}(h**head**h]hhead}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubh to }(hj=hhhNhNubj)}(h**list**h]hlist}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubh. You should pass in }(hj=hhhNhNubj)}(h **entry**h]hentry}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubh an element you know is on }(hj=hhhNhNubj)}(h**head**h]hhead}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubh. }(hj=hhhNhNubj)}(h**list**h]hlist}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubhM should be an empty list or a list you do not care about losing its data. If }(hj=hhhNhNubj)}(h **entry**h]hentry}(hj'>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubh == }(hj=hhhNhNubj)}(h**head**h]hhead}(hj9>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubh, all entries on }(hj=hhhNhNubj)}(h**head**h]hhead}(hjK>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubh are moved to }(hj=hhhNhNubj)}(h**list**h]hlist}(hj]>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubh.}(hj=hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj<ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_splice (C function) c.list_splicehNtauh1jhj hhhNhNubj)}(hhh](j)}(hGvoid list_splice (const struct list_head *list, struct list_head *head)h]j)}(hFvoid list_splice(const struct list_head *list, struct list_head *head)h](jb)}(hvoidh]hvoid}(hj>hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj>hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM"ubjt)}(h h]h }(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj>hhhj>hM"ubj$)}(h list_spliceh]j*)}(h list_spliceh]h list_splice}(hj>hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj>ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj>hhhj>hM"ubj)}(h6(const struct list_head *list, struct list_head *head)h](j)}(hconst struct list_head *listh](j)}(hj&h]hconst}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>ubjt)}(h h]h }(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj>ubj)}(hjh]hstruct}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>ubjt)}(h h]h }(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj>ubh)}(hhh]j*)}(h list_headh]h list_head}(hj ?hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj ?ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj?modnameN classnameNjj)}j]j)}jj>sb c.list_spliceasbuh1hhj>ubjt)}(h h]h }(hj,?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj>ubj)}(hj h]h*}(hj:?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>ubj*)}(hlisth]hlist}(hjG?hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj>ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj>ubj)}(hstruct list_head *headh](j)}(hjh]hstruct}(hj`?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\?ubjt)}(h h]h }(hjm?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj\?ubh)}(hhh]j*)}(h list_headh]h list_head}(hj~?hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj{?ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj?modnameN classnameNjj)}j]j(? c.list_spliceasbuh1hhj\?ubjt)}(h h]h }(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj\?ubj)}(hj h]h*}(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\?ubj*)}(hheadh]hhead}(hj?hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj\?ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj>ubeh}(h]h ]h"]h$]h&]hhuh1jhj>hhhj>hM"ubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj>hhhj>hM"ubah}(h]j>ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj>hM"hj>hhubjW)}(hhh]h)}(h+join two lists, this is designed for stacksh]h+join two lists, this is designed for stacks}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM"hj?hhubah}(h]h ]h"]h$]h&]uh1jVhj>hhhj>hM"ubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij?jjj?jkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``const struct list_head *list`` the new list to add. ``struct list_head *head`` the place to add it in the first list.h](h)}(h**Parameters**h]j)}(hj@h]h Parameters}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM&hj?ubj)}(hhh](j)}(h6``const struct list_head *list`` the new list to add. h](j)}(h ``const struct list_head *list``h]j)}(hj"@h]hconst struct list_head *list}(hj$@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj @ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM#hj@ubj)}(hhh]h)}(hthe new list to add.h]hthe new list to add.}(hj;@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7@hM#hj8@ubah}(h]h ]h"]h$]h&]uh1jhj@ubeh}(h]h ]h"]h$]h&]uh1jhj7@hM#hj@ubj)}(hA``struct list_head *head`` the place to add it in the first list.h](j)}(h``struct list_head *head``h]j)}(hj[@h]hstruct list_head *head}(hj]@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjY@ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM%hjU@ubj)}(hhh]h)}(h&the place to add it in the first list.h]h&the place to add it in the first list.}(hjt@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM$hjq@ubah}(h]h ]h"]h$]h&]uh1jhjU@ubeh}(h]h ]h"]h$]h&]uh1jhjp@hM%hj@ubeh}(h]h ]h"]h$]h&]uh1jhj?ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_splice_tail (C function)c.list_splice_tailhNtauh1jhj hhhNhNubj)}(hhh](j)}(hFvoid list_splice_tail (struct list_head *list, struct list_head *head)h]j)}(hEvoid list_splice_tail(struct list_head *list, struct list_head *head)h](jb)}(hvoidh]hvoid}(hj@hhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj@hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM.ubjt)}(h h]h }(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj@hhhj@hM.ubj$)}(hlist_splice_tailh]j*)}(hlist_splice_tailh]hlist_splice_tail}(hj@hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj@ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj@hhhj@hM.ubj)}(h0(struct list_head *list, struct list_head *head)h](j)}(hstruct list_head *listh](j)}(hjh]hstruct}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubjt)}(h h]h }(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj@ubh)}(hhh]j*)}(h list_headh]h list_head}(hjAhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj Aubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjAmodnameN classnameNjj)}j]j)}jj@sbc.list_splice_tailasbuh1hhj@ubjt)}(h h]h }(hj0AhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj@ubj)}(hj h]h*}(hj>AhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubj*)}(hlisth]hlist}(hjKAhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj@ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj@ubj)}(hstruct list_head *headh](j)}(hjh]hstruct}(hjdAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`Aubjt)}(h h]h }(hjqAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj`Aubh)}(hhh]j*)}(h list_headh]h list_head}(hjAhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjAubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjAmodnameN classnameNjj)}j]j,Ac.list_splice_tailasbuh1hhj`Aubjt)}(h h]h }(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj`Aubj)}(hj h]h*}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`Aubj*)}(hheadh]hhead}(hjAhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj`Aubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj@ubeh}(h]h ]h"]h$]h&]hhuh1jhj@hhhj@hM.ubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj@hhhj@hM.ubah}(h]j@ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj@hM.hj@hhubjW)}(hhh]h)}(h'join two lists, each list being a queueh]h'join two lists, each list being a queue}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM.hjAhhubah}(h]h ]h"]h$]h&]uh1jVhj@hhhj@hM.ubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijAjjjAjkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *list`` the new list to add. ``struct list_head *head`` the place to add it in the first list.h](h)}(h**Parameters**h]j)}(hjBh]h Parameters}(hj BhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM2hjBubj)}(hhh](j)}(h0``struct list_head *list`` the new list to add. h](j)}(h``struct list_head *list``h]j)}(hj&Bh]hstruct list_head *list}(hj(BhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$Bubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM/hj Bubj)}(hhh]h)}(hthe new list to add.h]hthe new list to add.}(hj?BhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;BhM/hjhjDubj)}(hhh](j)}(h0``struct list_head *list`` the new list to add. h](j)}(h``struct list_head *list``h]j)}(hj*Dh]hstruct list_head *list}(hj,DhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(Dubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM;hj$Dubj)}(hhh]h)}(hthe new list to add.h]hthe new list to add.}(hjCDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?DhM;hj@Dubah}(h]h ]h"]h$]h&]uh1jhj$Dubeh}(h]h ]h"]h$]h&]uh1jhj?DhM;hj!Dubj)}(hB``struct list_head *head`` the place to add it in the first list. h](j)}(h``struct list_head *head``h]j)}(hjcDh]hstruct list_head *head}(hjeDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaDubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM<hj]Dubj)}(hhh]h)}(h&the place to add it in the first list.h]h&the place to add it in the first list.}(hj|DhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxDhM<hjyDubah}(h]h ]h"]h$]h&]uh1jhj]Dubeh}(h]h ]h"]h$]h&]uh1jhjxDhM<hj!Dubeh}(h]h ]h"]h$]h&]uh1jhjDubh)}(h**Description**h]j)}(hjDh]h Description}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM>hjDubh)}(h%The list at **list** is reinitialisedh](h The list at }(hjDhhhNhNubj)}(h**list**h]hlist}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubh is reinitialised}(hjDhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM=hjDubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j"list_splice_tail_init (C function)c.list_splice_tail_inithNtauh1jhj hhhNhNubj)}(hhh](j)}(hKvoid list_splice_tail_init (struct list_head *list, struct list_head *head)h]j)}(hJvoid list_splice_tail_init(struct list_head *list, struct list_head *head)h](jb)}(hvoidh]hvoid}(hjDhhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjDhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMJubjt)}(h h]h }(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjDhhhjEhMJubj$)}(hlist_splice_tail_inith]j*)}(hlist_splice_tail_inith]hlist_splice_tail_init}(hjEhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjEubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjDhhhjEhMJubj)}(h0(struct list_head *list, struct list_head *head)h](j)}(hstruct list_head *listh](j)}(hjh]hstruct}(hj2EhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.Eubjt)}(h h]h }(hj?EhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj.Eubh)}(hhh]j*)}(h list_headh]h list_head}(hjPEhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjMEubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjREmodnameN classnameNjj)}j]j)}jjEsbc.list_splice_tail_initasbuh1hhj.Eubjt)}(h h]h }(hjpEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj.Eubj)}(hj h]h*}(hj~EhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.Eubj*)}(hlisth]hlist}(hjEhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj.Eubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj*Eubj)}(hstruct list_head *headh](j)}(hjh]hstruct}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjEubjt)}(h h]h }(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjEubh)}(hhh]j*)}(h list_headh]h list_head}(hjEhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjEubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjEmodnameN classnameNjj)}j]jlEc.list_splice_tail_initasbuh1hhjEubjt)}(h h]h }(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjEubj)}(hj h]h*}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjEubj*)}(hheadh]hhead}(hjEhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjEubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj*Eubeh}(h]h ]h"]h$]h&]hhuh1jhjDhhhjEhMJubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjDhhhjEhMJubah}(h]jDah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjEhMJhjDhhubjW)}(hhh]h)}(h0join two lists and reinitialise the emptied listh]h0join two lists and reinitialise the emptied list}(hj%FhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMJhj"Fhhubah}(h]h ]h"]h$]h&]uh1jVhjDhhhjEhMJubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij=Fjjj=Fjkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct list_head *list`` the new list to add. ``struct list_head *head`` the place to add it in the first list. **Description** Each of the lists is a queue. The list at **list** is reinitialisedh](h)}(h**Parameters**h]j)}(hjGFh]h Parameters}(hjIFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEFubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMNhjAFubj)}(hhh](j)}(h0``struct list_head *list`` the new list to add. h](j)}(h``struct list_head *list``h]j)}(hjfFh]hstruct list_head *list}(hjhFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdFubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMKhj`Fubj)}(hhh]h)}(hthe new list to add.h]hthe new list to add.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{FhMKhj|Fubah}(h]h ]h"]h$]h&]uh1jhj`Fubeh}(h]h ]h"]h$]h&]uh1jhj{FhMKhj]Fubj)}(hB``struct list_head *head`` the place to add it in the first list. h](j)}(h``struct list_head *head``h]j)}(hjFh]hstruct list_head *head}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMLhjFubj)}(hhh]h)}(h&the place to add it in the first list.h]h&the place to add it in the first list.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhMLhjFubah}(h]h ]h"]h$]h&]uh1jhjFubeh}(h]h ]h"]h$]h&]uh1jhjFhMLhj]Fubeh}(h]h ]h"]h$]h&]uh1jhjAFubh)}(h**Description**h]j)}(hjFh]h Description}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMNhjAFubh)}(hCEach of the lists is a queue. The list at **list** is reinitialisedh](h*Each of the lists is a queue. The list at }(hjFhhhNhNubj)}(h**list**h]hlist}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubh is reinitialised}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMMhjAFubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_entry (C macro) c.list_entryhNtauh1jhj hhhNhNubj)}(hhh](j)}(h list_entryh]j)}(h list_entryh]j$)}(h list_entryh]j*)}(hj+Gh]h list_entry}(hj5GhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj1Gubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj-GhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM[ubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj)GhhhjHGhM[ubah}(h]j$Gah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjHGhM[hj&GhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhj&GhhhjHGhM[ubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijaGjjjaGjkjljmuh1jhhhj hNhNubh)}(h"``list_entry (ptr, type, member)``h]j)}(hjgGh]hlist_entry (ptr, type, member)}(hjiGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeGubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM]hj hhubj)}(hget the struct for this entry h]h)}(hget the struct for this entryh]hget the struct for this entry}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM[hj}Gubah}(h]h ]h"]h$]h&]uh1jhjGhM[hj hhubj)}(h**Parameters** ``ptr`` the :c:type:`struct list_head ` pointer. ``type`` the type of the struct this is embedded in. ``member`` the name of the list_head within the struct.h](h)}(h**Parameters**h]j)}(hjGh]h Parameters}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM_hjGubj)}(hhh](j)}(h<``ptr`` the :c:type:`struct list_head ` pointer. h](j)}(h``ptr``h]j)}(hjGh]hptr}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM\hjGubj)}(hhh]h)}(h3the :c:type:`struct list_head ` pointer.h](hthe }(hjGhhhNhNubh)}(h&:c:type:`struct list_head `h]j)}(hjGh]hstruct list_head}(hjGhhhNhNubah}(h]h ](jjTc-typeeh"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]refdocj refdomainjTreftypetype refexplicitrefwarnjjj list_headuh1hhjGhM\hjGubh pointer.}(hjGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjGhM\hjGubah}(h]h ]h"]h$]h&]uh1jhjGubeh}(h]h ]h"]h$]h&]uh1jhjGhM\hjGubj)}(h5``type`` the type of the struct this is embedded in. h](j)}(h``type``h]j)}(hjHh]htype}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM]hjHubj)}(hhh]h)}(h+the type of the struct this is embedded in.h]h+the type of the struct this is embedded in.}(hj0HhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,HhM]hj-Hubah}(h]h ]h"]h$]h&]uh1jhjHubeh}(h]h ]h"]h$]h&]uh1jhj,HhM]hjGubj)}(h7``member`` the name of the list_head within the struct.h](j)}(h ``member``h]j)}(hjPHh]hmember}(hjRHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNHubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM_hjJHubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjiHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM^hjfHubah}(h]h ]h"]h$]h&]uh1jhjJHubeh}(h]h ]h"]h$]h&]uh1jhjeHhM_hjGubeh}(h]h ]h"]h$]h&]uh1jhjGubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_first_entry (C macro)c.list_first_entryhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_first_entryh]j)}(hlist_first_entryh]j$)}(hlist_first_entryh]j*)}(hjHh]hlist_first_entry}(hjHhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjHubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjHhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMdubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjHhhhjHhMdubah}(h]jHah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjHhMdhjHhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjHhhhjHhMdubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijHjjjHjkjljmuh1jhhhj hNhNubh)}(h(``list_first_entry (ptr, type, member)``h]j)}(hjHh]h$list_first_entry (ptr, type, member)}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMfhj hhubj)}(h"get the first element from a list h]h)}(h!get the first element from a listh]h!get the first element from a list}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMdhjHubah}(h]h ]h"]h$]h&]uh1jhjIhMdhj hhubj)}(h**Parameters** ``ptr`` the list head to take the element from. ``type`` the type of the struct this is embedded in. ``member`` the name of the list_head within the struct. **Description** Note, that list is expected to be not empty.h](h)}(h**Parameters**h]j)}(hjIh]h Parameters}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhhjIubj)}(hhh](j)}(h0``ptr`` the list head to take the element from. h](j)}(h``ptr``h]j)}(hj4Ih]hptr}(hj6IhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2Iubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMehj.Iubj)}(hhh]h)}(h'the list head to take the element from.h]h'the list head to take the element from.}(hjMIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIIhMehjJIubah}(h]h ]h"]h$]h&]uh1jhj.Iubeh}(h]h ]h"]h$]h&]uh1jhjIIhMehj+Iubj)}(h5``type`` the type of the struct this is embedded in. h](j)}(h``type``h]j)}(hjmIh]htype}(hjoIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkIubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMfhjgIubj)}(hhh]h)}(h+the type of the struct this is embedded in.h]h+the type of the struct this is embedded in.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhMfhjIubah}(h]h ]h"]h$]h&]uh1jhjgIubeh}(h]h ]h"]h$]h&]uh1jhjIhMfhj+Iubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjIh]hmember}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMghjIubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhMghjIubah}(h]h ]h"]h$]h&]uh1jhjIubeh}(h]h ]h"]h$]h&]uh1jhjIhMghj+Iubeh}(h]h ]h"]h$]h&]uh1jhjIubh)}(h**Description**h]j)}(hjIh]h Description}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMihjIubh)}(h,Note, that list is expected to be not empty.h]h,Note, that list is expected to be not empty.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhhjIubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_last_entry (C macro)c.list_last_entryhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_last_entryh]j)}(hlist_last_entryh]j$)}(hlist_last_entryh]j*)}(hj Jh]hlist_last_entry}(hj*JhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj&Jubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj"JhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMoubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjJhhhj=JhMoubah}(h]jJah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj=JhMohjJhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjJhhhj=JhMoubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijVJjjjVJjkjljmuh1jhhhj hNhNubh)}(h'``list_last_entry (ptr, type, member)``h]j)}(hj\Jh]h#list_last_entry (ptr, type, member)}(hj^JhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZJubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMqhj hhubj)}(h!get the last element from a list h]h)}(h get the last element from a listh]h get the last element from a list}(hjvJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMohjrJubah}(h]h ]h"]h$]h&]uh1jhjJhMohj hhubj)}(h**Parameters** ``ptr`` the list head to take the element from. ``type`` the type of the struct this is embedded in. ``member`` the name of the list_head within the struct. **Description** Note, that list is expected to be not empty.h](h)}(h**Parameters**h]j)}(hjJh]h Parameters}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMshjJubj)}(hhh](j)}(h0``ptr`` the list head to take the element from. h](j)}(h``ptr``h]j)}(hjJh]hptr}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMphjJubj)}(hhh]h)}(h'the list head to take the element from.h]h'the list head to take the element from.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhMphjJubah}(h]h ]h"]h$]h&]uh1jhjJubeh}(h]h ]h"]h$]h&]uh1jhjJhMphjJubj)}(h5``type`` the type of the struct this is embedded in. h](j)}(h``type``h]j)}(hjJh]htype}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMqhjJubj)}(hhh]h)}(h+the type of the struct this is embedded in.h]h+the type of the struct this is embedded in.}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhMqhjJubah}(h]h ]h"]h$]h&]uh1jhjJubeh}(h]h ]h"]h$]h&]uh1jhjJhMqhjJubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hj"Kh]hmember}(hj$KhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Kubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMrhjKubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hj;KhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7KhMrhj8Kubah}(h]h ]h"]h$]h&]uh1jhjKubeh}(h]h ]h"]h$]h&]uh1jhj7KhMrhjJubeh}(h]h ]h"]h$]h&]uh1jhjJubh)}(h**Description**h]j)}(hj]Kh]h Description}(hj_KhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[Kubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMthjJubh)}(h,Note, that list is expected to be not empty.h]h,Note, that list is expected to be not empty.}(hjsKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMshjJubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j"list_first_entry_or_null (C macro)c.list_first_entry_or_nullhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_first_entry_or_nullh]j)}(hlist_first_entry_or_nullh]j$)}(hlist_first_entry_or_nullh]j*)}(hjKh]hlist_first_entry_or_null}(hjKhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjKubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjKhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMzubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjKhhhjKhMzubah}(h]jKah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjKhMzhjKhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjKhhhjKhMzubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijKjjjKjkjljmuh1jhhhj hNhNubh)}(h0``list_first_entry_or_null (ptr, type, member)``h]j)}(hjKh]h,list_first_entry_or_null (ptr, type, member)}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM|hj hhubj)}(h"get the first element from a list h]h)}(h!get the first element from a listh]h!get the first element from a list}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMzhjKubah}(h]h ]h"]h$]h&]uh1jhjLhMzhj hhubj)}(h**Parameters** ``ptr`` the list head to take the element from. ``type`` the type of the struct this is embedded in. ``member`` the name of the list_head within the struct. **Description** Note that if the list is empty, it returns NULL.h](h)}(h**Parameters**h]j)}(hj Lh]h Parameters}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Lubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM~hjLubj)}(hhh](j)}(h0``ptr`` the list head to take the element from. h](j)}(h``ptr``h]j)}(hj,Lh]hptr}(hj.LhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*Lubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM{hj&Lubj)}(hhh]h)}(h'the list head to take the element from.h]h'the list head to take the element from.}(hjELhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjALhM{hjBLubah}(h]h ]h"]h$]h&]uh1jhj&Lubeh}(h]h ]h"]h$]h&]uh1jhjALhM{hj#Lubj)}(h5``type`` the type of the struct this is embedded in. h](j)}(h``type``h]j)}(hjeLh]htype}(hjgLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcLubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM|hj_Lubj)}(hhh]h)}(h+the type of the struct this is embedded in.h]h+the type of the struct this is embedded in.}(hj~LhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzLhM|hj{Lubah}(h]h ]h"]h$]h&]uh1jhj_Lubeh}(h]h ]h"]h$]h&]uh1jhjzLhM|hj#Lubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjLh]hmember}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM}hjLubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhM}hjLubah}(h]h ]h"]h$]h&]uh1jhjLubeh}(h]h ]h"]h$]h&]uh1jhjLhM}hj#Lubeh}(h]h ]h"]h$]h&]uh1jhjLubh)}(h**Description**h]j)}(hjLh]h Description}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjLubh)}(h0Note that if the list is empty, it returns NULL.h]h0Note that if the list is empty, it returns NULL.}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM~hjLubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j!list_last_entry_or_null (C macro)c.list_last_entry_or_nullhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_last_entry_or_nullh]j)}(hlist_last_entry_or_nullh]j$)}(hlist_last_entry_or_nullh]j*)}(hjMh]hlist_last_entry_or_null}(hj"MhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjMubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjMhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjMhhhj5MhMubah}(h]jMah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj5MhMhjMhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjMhhhj5MhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijNMjjjNMjkjljmuh1jhhhj hNhNubh)}(h/``list_last_entry_or_null (ptr, type, member)``h]j)}(hjTMh]h+list_last_entry_or_null (ptr, type, member)}(hjVMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRMubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(h!get the last element from a list h]h)}(h get the last element from a listh]h get the last element from a list}(hjnMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjjMubah}(h]h ]h"]h$]h&]uh1jhj|MhMhj hhubj)}(h**Parameters** ``ptr`` the list head to take the element from. ``type`` the type of the struct this is embedded in. ``member`` the name of the list_head within the struct. **Description** Note that if the list is empty, it returns NULL.h](h)}(h**Parameters**h]j)}(hjMh]h Parameters}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjMubj)}(hhh](j)}(h0``ptr`` the list head to take the element from. h](j)}(h``ptr``h]j)}(hjMh]hptr}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjMubj)}(hhh]h)}(h'the list head to take the element from.h]h'the list head to take the element from.}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhMhjMubah}(h]h ]h"]h$]h&]uh1jhjMubeh}(h]h ]h"]h$]h&]uh1jhjMhMhjMubj)}(h5``type`` the type of the struct this is embedded in. h](j)}(h``type``h]j)}(hjMh]htype}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjMubj)}(hhh]h)}(h+the type of the struct this is embedded in.h]h+the type of the struct this is embedded in.}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhMhjMubah}(h]h ]h"]h$]h&]uh1jhjMubeh}(h]h ]h"]h$]h&]uh1jhjMhMhjMubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjNh]hmember}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjNubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hj3NhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/NhMhj0Nubah}(h]h ]h"]h$]h&]uh1jhjNubeh}(h]h ]h"]h$]h&]uh1jhj/NhMhjMubeh}(h]h ]h"]h$]h&]uh1jhjMubh)}(h**Description**h]j)}(hjUNh]h Description}(hjWNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjMubh)}(h0Note that if the list is empty, it returns NULL.h]h0Note that if the list is empty, it returns NULL.}(hjkNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjMubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_next_entry (C macro)c.list_next_entryhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_next_entryh]j)}(hlist_next_entryh]j$)}(hlist_next_entryh]j*)}(hjNh]hlist_next_entry}(hjNhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjNubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjNhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjNhhhjNhMubah}(h]jNah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjNhMhjNhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjNhhhjNhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijNjjjNjkjljmuh1jhhhj hNhNubh)}(h!``list_next_entry (pos, member)``h]j)}(hjNh]hlist_next_entry (pos, member)}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(hget the next element in list h]h)}(hget the next element in listh]hget the next element in list}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjNubah}(h]h ]h"]h$]h&]uh1jhjNhMhj hhubj)}(hi**Parameters** ``pos`` the type * to cursor ``member`` the name of the list_head within the struct.h](h)}(h**Parameters**h]j)}(hjOh]h Parameters}(hjOhhhNh"Nubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjNubj)}(hhh](j)}(h``pos`` the type * to cursor h](j)}(h``pos``h]j)}(hj$Oh]hpos}(hj&OhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"Oubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjOubj)}(hhh]h)}(hthe type * to cursorh]hthe type * to cursor}(hj=OhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9OhMhj:Oubah}(h]h ]h"]h$]h&]uh1jhjOubeh}(h]h ]h"]h$]h&]uh1jhj9OhMhjOubj)}(h7``member`` the name of the list_head within the struct.h](j)}(h ``member``h]j)}(hj]Oh]hmember}(hj_OhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[Oubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjWOubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjvOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjsOubah}(h]h ]h"]h$]h&]uh1jhjWOubeh}(h]h ]h"]h$]h&]uh1jhjrOhMhjOubeh}(h]h ]h"]h$]h&]uh1jhjNubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j"list_next_entry_circular (C macro)c.list_next_entry_circularhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_next_entry_circularh]j)}(hlist_next_entry_circularh]j$)}(hlist_next_entry_circularh]j*)}(hjOh]hlist_next_entry_circular}(hjOhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjOubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjOhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjOhhhjOhMubah}(h]jOah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjOhMhjOhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjOhhhjOhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijOjjjOjkjljmuh1jhhhj hNhNubh)}(h0``list_next_entry_circular (pos, head, member)``h]j)}(hjOh]h,list_next_entry_circular (pos, head, member)}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(hget the next element in list h]h)}(hget the next element in listh]hget the next element in list}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjPubah}(h]h ]h"]h$]h&]uh1jhjPhMhj hhubj)}(hX**Parameters** ``pos`` the type * to cursor. ``head`` the list head to take the element from. ``member`` the name of the list_head within the struct. **Description** Wraparound if pos is the last element (return the first element). Note, that list is expected to be not empty.h](h)}(h**Parameters**h]j)}(hj"Ph]h Parameters}(hj$PhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Pubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjPubj)}(hhh](j)}(h``pos`` the type * to cursor. h](j)}(h``pos``h]j)}(hjAPh]hpos}(hjCPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?Pubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj;Pubj)}(hhh]h)}(hthe type * to cursor.h]hthe type * to cursor.}(hjZPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVPhMhjWPubah}(h]h ]h"]h$]h&]uh1jhj;Pubeh}(h]h ]h"]h$]h&]uh1jhjVPhMhj8Pubj)}(h1``head`` the list head to take the element from. h](j)}(h``head``h]j)}(hjzPh]hhead}(hj|PhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxPubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjtPubj)}(hhh]h)}(h'the list head to take the element from.h]h'the list head to take the element from.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjPubah}(h]h ]h"]h$]h&]uh1jhjtPubeh}(h]h ]h"]h$]h&]uh1jhjPhMhj8Pubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjPh]hmember}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjPubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjPubah}(h]h ]h"]h$]h&]uh1jhjPubeh}(h]h ]h"]h$]h&]uh1jhjPhMhj8Pubeh}(h]h ]h"]h$]h&]uh1jhjPubh)}(h**Description**h]j)}(hjPh]h Description}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjPubh)}(hnWraparound if pos is the last element (return the first element). Note, that list is expected to be not empty.h]hnWraparound if pos is the last element (return the first element). Note, that list is expected to be not empty.}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjPubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_prev_entry (C macro)c.list_prev_entryhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_prev_entryh]j)}(hlist_prev_entryh]j$)}(hlist_prev_entryh]j*)}(hj-Qh]hlist_prev_entry}(hj7QhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj3Qubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj/QhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj+QhhhjJQhMubah}(h]j&Qah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjJQhMhj(QhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhj(QhhhjJQhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijcQjjjcQjkjljmuh1jhhhj hNhNubh)}(h!``list_prev_entry (pos, member)``h]j)}(hjiQh]hlist_prev_entry (pos, member)}(hjkQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgQubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(hget the prev element in list h]h)}(hget the prev element in listh]hget the prev element in list}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjQubah}(h]h ]h"]h$]h&]uh1jhjQhMhj hhubj)}(hi**Parameters** ``pos`` the type * to cursor ``member`` the name of the list_head within the struct.h](h)}(h**Parameters**h]j)}(hjQh]h Parameters}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjQubj)}(hhh](j)}(h``pos`` the type * to cursor h](j)}(h``pos``h]j)}(hjQh]hpos}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjQubj)}(hhh]h)}(hthe type * to cursorh]hthe type * to cursor}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhMhjQubah}(h]h ]h"]h$]h&]uh1jhjQubeh}(h]h ]h"]h$]h&]uh1jhjQhMhjQubj)}(h7``member`` the name of the list_head within the struct.h](j)}(h ``member``h]j)}(hjQh]hmember}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjQubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj Rubah}(h]h ]h"]h$]h&]uh1jhjQubeh}(h]h ]h"]h$]h&]uh1jhj RhMhjQubeh}(h]h ]h"]h$]h&]uh1jhjQubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j"list_prev_entry_circular (C macro)c.list_prev_entry_circularhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_prev_entry_circularh]j)}(hlist_prev_entry_circularh]j$)}(hlist_prev_entry_circularh]j*)}(hjJRh]hlist_prev_entry_circular}(hjTRhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjPRubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjLRhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjHRhhhjgRhMubah}(h]jCRah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjgRhMhjERhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjERhhhjgRhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijRjjjRjkjljmuh1jhhhj hNhNubh)}(h0``list_prev_entry_circular (pos, head, member)``h]j)}(hjRh]h,list_prev_entry_circular (pos, head, member)}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(hget the prev element in list h]h)}(hget the prev element in listh]hget the prev element in list}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjRubah}(h]h ]h"]h$]h&]uh1jhjRhMhj hhubj)}(hX**Parameters** ``pos`` the type * to cursor. ``head`` the list head to take the element from. ``member`` the name of the list_head within the struct. **Description** Wraparound if pos is the first element (return the last element). Note, that list is expected to be not empty.h](h)}(h**Parameters**h]j)}(hjRh]h Parameters}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjRubj)}(hhh](j)}(h``pos`` the type * to cursor. h](j)}(h``pos``h]j)}(hjRh]hpos}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjRubj)}(hhh]h)}(hthe type * to cursor.h]hthe type * to cursor.}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhMhjRubah}(h]h ]h"]h$]h&]uh1jhjRubeh}(h]h ]h"]h$]h&]uh1jhjRhMhjRubj)}(h1``head`` the list head to take the element from. h](j)}(h``head``h]j)}(hjSh]hhead}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj Subj)}(hhh]h)}(h'the list head to take the element from.h]h'the list head to take the element from.}(hj,ShhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(ShMhj)Subah}(h]h ]h"]h$]h&]uh1jhj Subeh}(h]h ]h"]h$]h&]uh1jhj(ShMhjRubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjLSh]hmember}(hjNShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJSubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjFSubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjeShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjaShMhjbSubah}(h]h ]h"]h$]h&]uh1jhjFSubeh}(h]h ]h"]h$]h&]uh1jhjaShMhjRubeh}(h]h ]h"]h$]h&]uh1jhjRubh)}(h**Description**h]j)}(hjSh]h Description}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjRubh)}(hnWraparound if pos is the first element (return the last element). Note, that list is expected to be not empty.h]hnWraparound if pos is the first element (return the last element). Note, that list is expected to be not empty.}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjRubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_for_each (C macro)c.list_for_eachhNtauh1jhj hhhNhNubj)}(hhh](j)}(h list_for_eachh]j)}(h list_for_eachh]j$)}(h list_for_eachh]j*)}(hjSh]h list_for_each}(hjShhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjSubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjShhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjShhhjShMubah}(h]jSah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjShMhjShhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjShhhjShMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijSjjjSjkjljmuh1jhhhj hNhNubh)}(h``list_for_each (pos, head)``h]j)}(hjTh]hlist_for_each (pos, head)}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(hiterate over a list h]h)}(hiterate over a listh]hiterate over a list}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjTubah}(h]h ]h"]h$]h&]uh1jhj*ThMhj hhubj)}(h**Parameters** ``pos`` the :c:type:`struct list_head ` to use as a loop cursor. ``head`` the head for your list.h](h)}(h**Parameters**h]j)}(hj7Th]h Parameters}(hj9ThhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5Tubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj1Tubj)}(hhh](j)}(hL``pos`` the :c:type:`struct list_head ` to use as a loop cursor. h](j)}(h``pos``h]j)}(hjVTh]hpos}(hjXThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTTubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjPTubj)}(hhh]h)}(hCthe :c:type:`struct list_head ` to use as a loop cursor.h](hthe }(hjoThhhNhNubh)}(h&:c:type:`struct list_head `h]j)}(hjyTh]hstruct list_head}(hj{ThhhNhNubah}(h]h ](jjTc-typeeh"]h$]h&]uh1jhjwTubah}(h]h ]h"]h$]h&]refdocj refdomainjTreftypetype refexplicitrefwarnjjj list_headuh1hhjkThMhjoTubh to use as a loop cursor.}(hjoThhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjkThMhjlTubah}(h]h ]h"]h$]h&]uh1jhjPTubeh}(h]h ]h"]h$]h&]uh1jhjkThMhjMTubj)}(h ``head`` the head for your list.h](j)}(h``head``h]j)}(hjTh]hhead}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjTubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjTubah}(h]h ]h"]h$]h&]uh1jhjTubeh}(h]h ]h"]h$]h&]uh1jhjThMhjMTubeh}(h]h ]h"]h$]h&]uh1jhj1Tubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j list_for_each_continue (C macro)c.list_for_each_continuehNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_for_each_continueh]j)}(hlist_for_each_continueh]j$)}(hlist_for_each_continueh]j*)}(hjUh]hlist_for_each_continue}(hjUhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj Uubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjUhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjUhhhj#UhMubah}(h]jTah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj#UhMhjUhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjUhhhj#UhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjij` to use as a loop cursor. ``head`` the head for your list. **Description** Continue to iterate over a list, continuing after the current position.h](h)}(h**Parameters**h]j)}(hjwUh]h Parameters}(hjyUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuUubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjqUubj)}(hhh](j)}(hL``pos`` the :c:type:`struct list_head ` to use as a loop cursor. h](j)}(h``pos``h]j)}(hjUh]hpos}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjUubj)}(hhh]h)}(hCthe :c:type:`struct list_head ` to use as a loop cursor.h](hthe }(hjUhhhNhNubh)}(h&:c:type:`struct list_head `h]j)}(hjUh]hstruct list_head}(hjUhhhNhNubah}(h]h ](jjTc-typeeh"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]refdocj refdomainjTreftypetype refexplicitrefwarnjjj list_headuh1hhjUhMhjUubh to use as a loop cursor.}(hjUhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjUhMhjUubah}(h]h ]h"]h$]h&]uh1jhjUubeh}(h]h ]h"]h$]h&]uh1jhjUhMhjUubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjUh]hhead}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjUubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hj VhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhMhjVubah}(h]h ]h"]h$]h&]uh1jhjUubeh}(h]h ]h"]h$]h&]uh1jhjVhMhjUubeh}(h]h ]h"]h$]h&]uh1jhjqUubh)}(h**Description**h]j)}(hj-Vh]h Description}(hj/VhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+Vubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjqUubh)}(hGContinue to iterate over a list, continuing after the current position.h]hGContinue to iterate over a list, continuing after the current position.}(hjCVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjqUubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_for_each_prev (C macro)c.list_for_each_prevhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_for_each_prevh]j)}(hlist_for_each_prevh]j$)}(hlist_for_each_prevh]j*)}(hjlVh]hlist_for_each_prev}(hjvVhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjrVubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjnVhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjjVhhhjVhMubah}(h]jeVah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjVhMhjgVhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjgVhhhjVhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijVjjjVjkjljmuh1jhhhj hNhNubh)}(h"``list_for_each_prev (pos, head)``h]j)}(hjVh]hlist_for_each_prev (pos, head)}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(hiterate over a list backwards h]h)}(hiterate over a list backwardsh]hiterate over a list backwards}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjVubah}(h]h ]h"]h$]h&]uh1jhjVhMhj hhubj)}(h**Parameters** ``pos`` the :c:type:`struct list_head ` to use as a loop cursor. ``head`` the head for your list.h](h)}(h**Parameters**h]j)}(hjVh]h Parameters}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjVubj)}(hhh](j)}(hL``pos`` the :c:type:`struct list_head ` to use as a loop cursor. h](j)}(h``pos``h]j)}(hjVh]hpos}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjVubj)}(hhh]h)}(hCthe :c:type:`struct list_head ` to use as a loop cursor.h](hthe }(hjWhhhNhNubh)}(h&:c:type:`struct list_head `h]j)}(hjWh]hstruct list_head}(hj!WhhhNhNubah}(h]h ](jjTc-typeeh"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]refdocj refdomainjTreftypetype refexplicitrefwarnjjj list_headuh1hhjWhMhjWubh to use as a loop cursor.}(hjWhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjWhMhjWubah}(h]h ]h"]h$]h&]uh1jhjVubeh}(h]h ]h"]h$]h&]uh1jhjWhMhjVubj)}(h ``head`` the head for your list.h](j)}(h``head``h]j)}(hjXWh]hhead}(hjZWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVWubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjRWubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hjqWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjnWubah}(h]h ]h"]h$]h&]uh1jhjRWubeh}(h]h ]h"]h$]h&]uh1jhjmWhMhjVubeh}(h]h ]h"]h$]h&]uh1jhjVubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_for_each_safe (C macro)c.list_for_each_safehNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_for_each_safeh]j)}(hlist_for_each_safeh]j$)}(hlist_for_each_safeh]j*)}(hjWh]hlist_for_each_safe}(hjWhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjWubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjWhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjWhhhjWhMubah}(h]jWah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjWhMhjWhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjWhhhjWhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijWjjjWjkjljmuh1jhhhj hNhNubh)}(h%``list_for_each_safe (pos, n, head)``h]j)}(hjWh]h!list_for_each_safe (pos, n, head)}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(h7iterate over a list safe against removal of list entry h]h)}(h6iterate over a list safe against removal of list entryh]h6iterate over a list safe against removal of list entry}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjWubah}(h]h ]h"]h$]h&]uh1jhjXhMhj hhubj)}(h**Parameters** ``pos`` the :c:type:`struct list_head ` to use as a loop cursor. ``n`` another :c:type:`struct list_head ` to use as temporary storage ``head`` the head for your list.h](h)}(h**Parameters**h]j)}(hjXh]h Parameters}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjXubj)}(hhh](j)}(hL``pos`` the :c:type:`struct list_head ` to use as a loop cursor. h](j)}(h``pos``h]j)}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:Xubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj6Xubj)}(hhh]h)}(hCthe :c:type:`struct list_head ` to use as a loop cursor.h](hthe }(hjUXhhhNhNubh)}(h&:c:type:`struct list_head `h]j)}(hj_Xh]hstruct list_head}(hjaXhhhNhNubah}(h]h ](jjTc-typeeh"]h$]h&]uh1jhj]Xubah}(h]h ]h"]h$]h&]refdocj refdomainjTreftypetype refexplicitrefwarnjjj list_headuh1hhjQXhMhjUXubh to use as a loop cursor.}(hjUXhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjQXhMhjRXubah}(h]h ]h"]h$]h&]uh1jhj6Xubeh}(h]h ]h"]h$]h&]uh1jhjQXhMhj3Xubj)}(hQ``n`` another :c:type:`struct list_head ` to use as temporary storage h](j)}(h``n``h]j)}(hjXh]hn}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjXubj)}(hhh]h)}(hJanother :c:type:`struct list_head ` to use as temporary storageh](hanother }(hjXhhhNhNubh)}(h&:c:type:`struct list_head `h]j)}(hjXh]hstruct list_head}(hjXhhhNhNubah}(h]h ](jjTc-typeeh"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]refdocj refdomainjTreftypetype refexplicitrefwarnjjj list_headuh1hhjXhMhjXubh to use as temporary storage}(hjXhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjXhMhjXubah}(h]h ]h"]h$]h&]uh1jhjXubeh}(h]h ]h"]h$]h&]uh1jhjXhMhj3Xubj)}(h ``head`` the head for your list.h](j)}(h``head``h]j)}(hjXh]hhead}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjXubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hj YhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj Yubah}(h]h ]h"]h$]h&]uh1jhjXubeh}(h]h ]h"]h$]h&]uh1jhj YhMhj3Xubeh}(h]h ]h"]h$]h&]uh1jhjXubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j!list_for_each_prev_safe (C macro)c.list_for_each_prev_safehNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_for_each_prev_safeh]j)}(hlist_for_each_prev_safeh]j$)}(hlist_for_each_prev_safeh]j*)}(hjHYh]hlist_for_each_prev_safe}(hjRYhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjNYubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjJYhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjFYhhhjeYhMubah}(h]jAYah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjeYhMhjCYhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjCYhhhjeYhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjij~Yjjj~Yjkjljmuh1jhhhj hNhNubh)}(h*``list_for_each_prev_safe (pos, n, head)``h]j)}(hjYh]h&list_for_each_prev_safe (pos, n, head)}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(hAiterate over a list backwards safe against removal of list entry h]h)}(h@iterate over a list backwards safe against removal of list entryh]h@iterate over a list backwards safe against removal of list entry}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjYubah}(h]h ]h"]h$]h&]uh1jhjYhMhj hhubj)}(h**Parameters** ``pos`` the :c:type:`struct list_head ` to use as a loop cursor. ``n`` another :c:type:`struct list_head ` to use as temporary storage ``head`` the head for your list.h](h)}(h**Parameters**h]j)}(hjYh]h Parameters}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjYubj)}(hhh](j)}(hL``pos`` the :c:type:`struct list_head ` to use as a loop cursor. h](j)}(h``pos``h]j)}(hjYh]hpos}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjYubj)}(hhh]h)}(hCthe :c:type:`struct list_head ` to use as a loop cursor.h](hthe }(hjYhhhNhNubh)}(h&:c:type:`struct list_head `h]j)}(hjYh]hstruct list_head}(hjYhhhNhNubah}(h]h ](jjTc-typeeh"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]refdocj refdomainjTreftypetype refexplicitrefwarnjjj list_headuh1hhjYhMhjYubh to use as a loop cursor.}(hjYhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjYhMhjYubah}(h]h ]h"]h$]h&]uh1jhjYubeh}(h]h ]h"]h$]h&]uh1jhjYhMhjYubj)}(hQ``n`` another :c:type:`struct list_head ` to use as temporary storage h](j)}(h``n``h]j)}(hj4Zh]hn}(hj6ZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2Zubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj.Zubj)}(hhh]h)}(hJanother :c:type:`struct list_head ` to use as temporary storageh](hanother }(hjMZhhhNhNubh)}(h&:c:type:`struct list_head `h]j)}(hjWZh]hstruct list_head}(hjYZhhhNhNubah}(h]h ](jjTc-typeeh"]h$]h&]uh1jhjUZubah}(h]h ]h"]h$]h&]refdocj refdomainjTreftypetype refexplicitrefwarnjjj list_headuh1hhjIZhMhjMZubh to use as temporary storage}(hjMZhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjIZhMhjJZubah}(h]h ]h"]h$]h&]uh1jhj.Zubeh}(h]h ]h"]h$]h&]uh1jhjIZhMhjYubj)}(h ``head`` the head for your list.h](j)}(h``head``h]j)}(hjZh]hhead}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjZubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjZubah}(h]h ]h"]h$]h&]uh1jhjZubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjYubeh}(h]h ]h"]h$]h&]uh1jhjYubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_count_nodes (C function)c.list_count_nodeshNtauh1jhj hhhNhNubj)}(hhh](j)}(h0size_t list_count_nodes (struct list_head *head)h]j)}(h/size_t list_count_nodes(struct list_head *head)h](h)}(hhh]j*)}(hsize_th]hsize_t}(hjZhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjZubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjZmodnameN classnameNjj)}j]j)}jlist_count_nodessbc.list_count_nodesasbuh1hhjZhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjZhhhj[hMubj$)}(hlist_count_nodesh]j*)}(hj [h]hlist_count_nodes}(hj![hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj[ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjZhhhj[hMubj)}(h(struct list_head *head)h]j)}(hstruct list_head *headh](j)}(hjh]hstruct}(hj<[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8[ubjt)}(h h]h }(hjI[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj8[ubh)}(hhh]j*)}(h list_headh]h list_head}(hjZ[hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjW[ubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetj\[modnameN classnameNjj)}j]j [c.list_count_nodesasbuh1hhj8[ubjt)}(h h]h }(hjx[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj8[ubj)}(hj h]h*}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8[ubj*)}(hheadh]hhead}(hj[hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj8[ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj4[ubah}(h]h ]h"]h$]h&]hhuh1jhjZhhhj[hMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjZhhhj[hMubah}(h]jZah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj[hMhjZhhubjW)}(hhh]h)}(hcount nodes in the listh]hcount nodes in the list}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj[hhubah}(h]h ]h"]h$]h&]uh1jVhjZhhhj[hMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij[jjj[jkjljmuh1jhhhj hNhNubj)}(hD**Parameters** ``struct list_head *head`` the head for your list.h](h)}(h**Parameters**h]j)}(hj[h]h Parameters}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj[ubj)}(hhh]j)}(h2``struct list_head *head`` the head for your list.h](j)}(h``struct list_head *head``h]j)}(hj[h]hstruct list_head *head}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj[ubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj\ubah}(h]h ]h"]h$]h&]uh1jhj[ubeh}(h]h ]h"]h$]h&]uh1jhj\hMhj[ubah}(h]h ]h"]h$]h&]uh1jhj[ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_entry_is_head (C macro)c.list_entry_is_headhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_entry_is_headh]j)}(hlist_entry_is_headh]j$)}(hlist_entry_is_headh]j*)}(hjR\h]hlist_entry_is_head}(hj\\hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjX\ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjT\hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjP\hhhjo\hMubah}(h]jK\ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjo\hMhjM\hhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjM\hhhjo\hMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjij\jjj\jkjljmuh1jhhhj hNhNubh)}(h*``list_entry_is_head (pos, head, member)``h]j)}(hj\h]h&list_entry_is_head (pos, head, member)}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(h1test if the entry points to the head of the list h]h)}(h0test if the entry points to the head of the listh]h0test if the entry points to the head of the list}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj\ubah}(h]h ]h"]h$]h&]uh1jhj\hMhj hhubj)}(h**Parameters** ``pos`` the type * to cursor ``head`` the head for your list. ``member`` the name of the list_head within the struct.h](h)}(h**Parameters**h]j)}(hj\h]h Parameters}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj\ubj)}(hhh](j)}(h``pos`` the type * to cursor h](j)}(h``pos``h]j)}(hj\h]hpos}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj\ubj)}(hhh]h)}(hthe type * to cursorh]hthe type * to cursor}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hMhj\ubah}(h]h ]h"]h$]h&]uh1jhj\ubeh}(h]h ]h"]h$]h&]uh1jhj\hMhj\ubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hj]h]hhead}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj]ubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hj4]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0]hMhj1]ubah}(h]h ]h"]h$]h&]uh1jhj]ubeh}(h]h ]h"]h$]h&]uh1jhj0]hMhj\ubj)}(h7``member`` the name of the list_head within the struct.h](j)}(h ``member``h]j)}(hjT]h]hmember}(hjV]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjR]ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjN]ubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjm]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjj]ubah}(h]h ]h"]h$]h&]uh1jhjN]ubeh}(h]h ]h"]h$]h&]uh1jhji]hMhj\ubeh}(h]h ]h"]h$]h&]uh1jhj\ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_for_each_entry (C macro)c.list_for_each_entryhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_for_each_entryh]j)}(hlist_for_each_entryh]j$)}(hlist_for_each_entryh]j*)}(hj]h]hlist_for_each_entry}(hj]hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj]ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj]hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj]hhhj]hMubah}(h]j]ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj]hMhj]hhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhj]hhhj]hMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjij]jjj]jkjljmuh1jhhhj hNhNubh)}(h+``list_for_each_entry (pos, head, member)``h]j)}(hj]h]h'list_for_each_entry (pos, head, member)}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM hj hhubj)}(h iterate over list of given type h]h)}(hiterate over list of given typeh]hiterate over list of given type}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj]ubah}(h]h ]h"]h$]h&]uh1jhj ^hMhj hhubj)}(h**Parameters** ``pos`` the type * to use as a loop cursor. ``head`` the head for your list. ``member`` the name of the list_head within the struct.h](h)}(h**Parameters**h]j)}(hj^h]h Parameters}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM hj^ubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hj8^h]hpos}(hj:^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6^ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM hj2^ubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjQ^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjM^hM hjN^ubah}(h]h ]h"]h$]h&]uh1jhj2^ubeh}(h]h ]h"]h$]h&]uh1jhjM^hM hj/^ubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjq^h]hhead}(hjs^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjo^ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM hjk^ubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hM hj^ubah}(h]h ]h"]h$]h&]uh1jhjk^ubeh}(h]h ]h"]h$]h&]uh1jhj^hM hj/^ubj)}(h7``member`` the name of the list_head within the struct.h](j)}(h ``member``h]j)}(hj^h]hmember}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM hj^ubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM hj^ubah}(h]h ]h"]h$]h&]uh1jhj^ubeh}(h]h ]h"]h$]h&]uh1jhj^hM hj/^ubeh}(h]h ]h"]h$]h&]uh1jhj^ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j%list_for_each_entry_reverse (C macro)c.list_for_each_entry_reversehNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_for_each_entry_reverseh]j)}(hlist_for_each_entry_reverseh]j$)}(hlist_for_each_entry_reverseh]j*)}(hj^h]hlist_for_each_entry_reverse}(hj_hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj_ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj_hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj^hhhj_hMubah}(h]j^ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj_hMhj^hhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhj^hhhj_hMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjij4_jjj4_jkjljmuh1jhhhj hNhNubh)}(h3``list_for_each_entry_reverse (pos, head, member)``h]j)}(hj:_h]h/list_for_each_entry_reverse (pos, head, member)}(hj<_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8_ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(h+iterate backwards over list of given type. h]h)}(h*iterate backwards over list of given type.h]h*iterate backwards over list of given type.}(hjT_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjP_ubah}(h]h ]h"]h$]h&]uh1jhjb_hMhj hhubj)}(h**Parameters** ``pos`` the type * to use as a loop cursor. ``head`` the head for your list. ``member`` the name of the list_head within the struct.h](h)}(h**Parameters**h]j)}(hjo_h]h Parameters}(hjq_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjm_ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhji_ubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hj_h]hpos}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj_ubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMhj_ubah}(h]h ]h"]h$]h&]uh1jhj_ubeh}(h]h ]h"]h$]h&]uh1jhj_hMhj_ubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hj_h]hhead}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj_ubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMhj_ubah}(h]h ]h"]h$]h&]uh1jhj_ubeh}(h]h ]h"]h$]h&]uh1jhj_hMhj_ubj)}(h7``member`` the name of the list_head within the struct.h](j)}(h ``member``h]j)}(hj`h]hmember}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj_ubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj`ubah}(h]h ]h"]h$]h&]uh1jhj_ubeh}(h]h ]h"]h$]h&]uh1jhj`hMhj_ubeh}(h]h ]h"]h$]h&]uh1jhji_ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_prepare_entry (C macro)c.list_prepare_entryhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_prepare_entryh]j)}(hlist_prepare_entryh]j$)}(hlist_prepare_entryh]j*)}(hjT`h]hlist_prepare_entry}(hj^`hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjZ`ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjV`hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjR`hhhjq`hMubah}(h]jM`ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjq`hMhjO`hhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjO`hhhjq`hMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjij`jjj`jkjljmuh1jhhhj hNhNubh)}(h*``list_prepare_entry (pos, head, member)``h]j)}(hj`h]h&list_prepare_entry (pos, head, member)}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM hj hhubj)}(h>prepare a pos entry for use in list_for_each_entry_continue() h]h)}(h=prepare a pos entry for use in list_for_each_entry_continue()h]h=prepare a pos entry for use in list_for_each_entry_continue()}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj`ubah}(h]h ]h"]h$]h&]uh1jhj`hMhj hhubj)}(h**Parameters** ``pos`` the type * to use as a start point ``head`` the head of the list ``member`` the name of the list_head within the struct. **Description** Prepares a pos entry for use as a start point in list_for_each_entry_continue().h](h)}(h**Parameters**h]j)}(hj`h]h Parameters}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM"hj`ubj)}(hhh](j)}(h+``pos`` the type * to use as a start point h](j)}(h``pos``h]j)}(hj`h]hpos}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj`ubj)}(hhh]h)}(h"the type * to use as a start pointh]h"the type * to use as a start point}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hMhj`ubah}(h]h ]h"]h$]h&]uh1jhj`ubeh}(h]h ]h"]h$]h&]uh1jhj`hMhj`ubj)}(h``head`` the head of the list h](j)}(h``head``h]j)}(hjah]hhead}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM hjaubj)}(hhh]h)}(hthe head of the listh]hthe head of the list}(hj6ahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2ahM hj3aubah}(h]h ]h"]h$]h&]uh1jhjaubeh}(h]h ]h"]h$]h&]uh1jhj2ahM hj`ubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjVah]hmember}(hjXahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTaubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM!hjPaubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjoahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkahM!hjlaubah}(h]h ]h"]h$]h&]uh1jhjPaubeh}(h]h ]h"]h$]h&]uh1jhjkahM!hj`ubeh}(h]h ]h"]h$]h&]uh1jhj`ubh)}(h**Description**h]j)}(hjah]h Description}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM#hj`ubh)}(hPPrepares a pos entry for use as a start point in list_for_each_entry_continue().h]hPPrepares a pos entry for use as a start point in list_for_each_entry_continue().}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM"hj`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j&list_for_each_entry_continue (C macro)c.list_for_each_entry_continuehNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_for_each_entry_continueh]j)}(hlist_for_each_entry_continueh]j$)}(hlist_for_each_entry_continueh]j*)}(hjah]hlist_for_each_entry_continue}(hjahhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjaubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjahhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM)ubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjahhhjahM)ubah}(h]jaah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjahM)hjahhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjahhhjahM)ubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijbjjjbjkjljmuh1jhhhj hNhNubh)}(h4``list_for_each_entry_continue (pos, head, member)``h]j)}(hj bh]h0list_for_each_entry_continue (pos, head, member)}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj bubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM+hj hhubj)}(h+continue iteration over list of given type h]h)}(h*continue iteration over list of given typeh]h*continue iteration over list of given type}(hj&bhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM)hj"bubah}(h]h ]h"]h$]h&]uh1jhj4bhM)hj hhubj)}(hX**Parameters** ``pos`` the type * to use as a loop cursor. ``head`` the head for your list. ``member`` the name of the list_head within the struct. **Description** Continue to iterate over list of given type, continuing after the current position.h](h)}(h**Parameters**h]j)}(hjAbh]h Parameters}(hjCbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?bubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM-hj;bubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hj`bh]hpos}(hjbbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^bubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM*hjZbubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjybhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjubhM*hjvbubah}(h]h ]h"]h$]h&]uh1jhjZbubeh}(h]h ]h"]h$]h&]uh1jhjubhM*hjWbubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjbh]hhead}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM+hjbubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhM+hjbubah}(h]h ]h"]h$]h&]uh1jhjbubeh}(h]h ]h"]h$]h&]uh1jhjbhM+hjWbubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjbh]hmember}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM,hjbubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhM,hjbubah}(h]h ]h"]h$]h&]uh1jhjbubeh}(h]h ]h"]h$]h&]uh1jhjbhM,hjWbubeh}(h]h ]h"]h$]h&]uh1jhj;bubh)}(h**Description**h]j)}(hj ch]h Description}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj cubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM.hj;bubh)}(hSContinue to iterate over list of given type, continuing after the current position.h]hSContinue to iterate over list of given type, continuing after the current position.}(hj#chhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM-hj;bubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j.list_for_each_entry_continue_reverse (C macro)&c.list_for_each_entry_continue_reversehNtauh1jhj hhhNhNubj)}(hhh](j)}(h$list_for_each_entry_continue_reverseh]j)}(h$list_for_each_entry_continue_reverseh]j$)}(h$list_for_each_entry_continue_reverseh]j*)}(hjLch]h$list_for_each_entry_continue_reverse}(hjVchhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjRcubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjNchhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM7ubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjJchhhjichM7ubah}(h]jEcah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjichM7hjGchhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjGchhhjichM7ubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijcjjjcjkjljmuh1jhhhj hNhNubh)}(h<``list_for_each_entry_continue_reverse (pos, head, member)``h]j)}(hjch]h8list_for_each_entry_continue_reverse (pos, head, member)}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM9hj hhubj)}(h'iterate backwards from the given point h]h)}(h&iterate backwards from the given pointh]h&iterate backwards from the given point}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM7hjcubah}(h]h ]h"]h$]h&]uh1jhjchM7hj hhubj)}(hX **Parameters** ``pos`` the type * to use as a loop cursor. ``head`` the head for your list. ``member`` the name of the list_head within the struct. **Description** Start to iterate over list of given type backwards, continuing after the current position.h](h)}(h**Parameters**h]j)}(hjch]h Parameters}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM;hjcubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hjch]hpos}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM8hjcubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchM8hjcubah}(h]h ]h"]h$]h&]uh1jhjcubeh}(h]h ]h"]h$]h&]uh1jhjchM8hjcubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjdh]hhead}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM9hjdubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hj.dhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*dhM9hj+dubah}(h]h ]h"]h$]h&]uh1jhjdubeh}(h]h ]h"]h$]h&]uh1jhj*dhM9hjcubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjNdh]hmember}(hjPdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLdubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM:hjHdubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjgdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjcdhM:hjddubah}(h]h ]h"]h$]h&]uh1jhjHdubeh}(h]h ]h"]h$]h&]uh1jhjcdhM:hjcubeh}(h]h ]h"]h$]h&]uh1jhjcubh)}(h**Description**h]j)}(hjdh]h Description}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM<hjcubh)}(hZStart to iterate over list of given type backwards, continuing after the current position.h]hZStart to iterate over list of given type backwards, continuing after the current position.}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM;hjcubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j"list_for_each_entry_from (C macro)c.list_for_each_entry_fromhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_for_each_entry_fromh]j)}(hlist_for_each_entry_fromh]j$)}(hlist_for_each_entry_fromh]j*)}(hjdh]hlist_for_each_entry_from}(hjdhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjdubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjdhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMEubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjdhhhjdhMEubah}(h]jdah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjdhMEhjdhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjdhhhjdhMEubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijdjjjdjkjljmuh1jhhhj hNhNubh)}(h0``list_for_each_entry_from (pos, head, member)``h]j)}(hjeh]h,list_for_each_entry_from (pos, head, member)}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMGhj hhubj)}(h7iterate over list of given type from the current point h]h)}(h6iterate over list of given type from the current pointh]h6iterate over list of given type from the current point}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMEhjeubah}(h]h ]h"]h$]h&]uh1jhj,ehMEhj hhubj)}(h**Parameters** ``pos`` the type * to use as a loop cursor. ``head`` the head for your list. ``member`` the name of the list_head within the struct. **Description** Iterate over list of given type, continuing from current position.h](h)}(h**Parameters**h]j)}(hj9eh]h Parameters}(hj;ehhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7eubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMIhj3eubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hjXeh]hpos}(hjZehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVeubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMFhjReubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjqehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmehMFhjneubah}(h]h ]h"]h$]h&]uh1jhjReubeh}(h]h ]h"]h$]h&]uh1jhjmehMFhjOeubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjeh]hhead}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMGhjeubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMGhjeubah}(h]h ]h"]h$]h&]uh1jhjeubeh}(h]h ]h"]h$]h&]uh1jhjehMGhjOeubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjeh]hmember}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMHhjeubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMHhjeubah}(h]h ]h"]h$]h&]uh1jhjeubeh}(h]h ]h"]h$]h&]uh1jhjehMHhjOeubeh}(h]h ]h"]h$]h&]uh1jhj3eubh)}(h**Description**h]j)}(hjfh]h Description}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMJhj3eubh)}(hBIterate over list of given type, continuing from current position.h]hBIterate over list of given type, continuing from current position.}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMIhj3eubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j*list_for_each_entry_from_reverse (C macro)"c.list_for_each_entry_from_reversehNtauh1jhj hhhNhNubj)}(hhh](j)}(h list_for_each_entry_from_reverseh]j)}(h list_for_each_entry_from_reverseh]j$)}(h list_for_each_entry_from_reverseh]j*)}(hjDfh]h list_for_each_entry_from_reverse}(hjNfhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjJfubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjFfhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMQubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjBfhhhjafhMQubah}(h]j=fah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjafhMQhj?fhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhj?fhhhjafhMQubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijzfjjjzfjkjljmuh1jhhhj hNhNubh)}(h8``list_for_each_entry_from_reverse (pos, head, member)``h]j)}(hjfh]h4list_for_each_entry_from_reverse (pos, head, member)}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~fubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMShj hhubj)}(hAiterate backwards over list of given type from the current point h]h)}(h@iterate backwards over list of given type from the current pointh]h@iterate backwards over list of given type from the current point}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMQhjfubah}(h]h ]h"]h$]h&]uh1jhjfhMQhj hhubj)}(h**Parameters** ``pos`` the type * to use as a loop cursor. ``head`` the head for your list. ``member`` the name of the list_head within the struct. **Description** Iterate backwards over list of given type, continuing from current position.h](h)}(h**Parameters**h]j)}(hjfh]h Parameters}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMUhjfubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hjfh]hpos}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMShjfubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMShjfubah}(h]h ]h"]h$]h&]uh1jhjfubeh}(h]h ]h"]h$]h&]uh1jhjfhMShjfubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hj gh]hhead}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhj gubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMThjgubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hj&ghhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"ghMThj#gubah}(h]h ]h"]h$]h&]uh1jhjgubeh}(h]h ]h"]h$]h&]uh1jhj"ghMThjfubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjFgh]hmember}(hjHghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDgubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMUhj@gubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hj_ghhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[ghMUhj\gubah}(h]h ]h"]h$]h&]uh1jhj@gubeh}(h]h ]h"]h$]h&]uh1jhj[ghMUhjfubeh}(h]h ]h"]h$]h&]uh1jhjfubh)}(h**Description**h]j)}(hjgh]h Description}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMWhjfubh)}(hLIterate backwards over list of given type, continuing from current position.h]hLIterate backwards over list of given type, continuing from current position.}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMVhjfubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j"list_for_each_entry_safe (C macro)c.list_for_each_entry_safehNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_for_each_entry_safeh]j)}(hlist_for_each_entry_safeh]j$)}(hlist_for_each_entry_safeh]j*)}(hjgh]hlist_for_each_entry_safe}(hjghhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjgubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjghhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM^ubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjghhhjghM^ubah}(h]jgah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjghM^hjghhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjghhhjghM^ubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijgjjjgjkjljmuh1jhhhj hNhNubh)}(h3``list_for_each_entry_safe (pos, n, head, member)``h]j)}(hjgh]h/list_for_each_entry_safe (pos, n, head, member)}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM`hj hhubj)}(hCiterate over list of given type safe against removal of list entry h]h)}(hBiterate over list of given type safe against removal of list entryh]hBiterate over list of given type safe against removal of list entry}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM^hjhubah}(h]h ]h"]h$]h&]uh1jhj$hhM^hj hhubj)}(h**Parameters** ``pos`` the type * to use as a loop cursor. ``n`` another type * to use as temporary storage ``head`` the head for your list. ``member`` the name of the list_head within the struct.h](h)}(h**Parameters**h]j)}(hj1hh]h Parameters}(hj3hhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/hubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMbhj+hubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hjPhh]hpos}(hjRhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNhubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM_hjJhubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjihhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehhM_hjfhubah}(h]h ]h"]h$]h&]uh1jhjJhubeh}(h]h ]h"]h$]h&]uh1jhjehhM_hjGhubj)}(h1``n`` another type * to use as temporary storage h](j)}(h``n``h]j)}(hjhh]hn}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM`hjhubj)}(hhh]h)}(h*another type * to use as temporary storageh]h*another type * to use as temporary storage}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhM`hjhubah}(h]h ]h"]h$]h&]uh1jhjhubeh}(h]h ]h"]h$]h&]uh1jhjhhM`hjGhubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjhh]hhead}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMahjhubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMahjhubah}(h]h ]h"]h$]h&]uh1jhjhubeh}(h]h ]h"]h$]h&]uh1jhjhhMahjGhubj)}(h7``member`` the name of the list_head within the struct.h](j)}(h ``member``h]j)}(hjhh]hmember}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMchjhubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMbhjiubah}(h]h ]h"]h$]h&]uh1jhjhubeh}(h]h ]h"]h$]h&]uh1jhjihMchjGhubeh}(h]h ]h"]h$]h&]uh1jhj+hubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j+list_for_each_entry_safe_continue (C macro)#c.list_for_each_entry_safe_continuehNtauh1jhj hhhNhNubj)}(hhh](j)}(h!list_for_each_entry_safe_continueh]j)}(h!list_for_each_entry_safe_continueh]j$)}(h!list_for_each_entry_safe_continueh]j*)}(hjOih]h!list_for_each_entry_safe_continue}(hjYihhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjUiubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjQihhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMkubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjMihhhjlihMkubah}(h]jHiah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjlihMkhjJihhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjJihhhjlihMkubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijijjjijkjljmuh1jhhhj hNhNubh)}(h<``list_for_each_entry_safe_continue (pos, n, head, member)``h]j)}(hjih]h8list_for_each_entry_safe_continue (pos, n, head, member)}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMmhj hhubj)}(h-continue list iteration safe against removal h]h)}(h,continue list iteration safe against removalh]h,continue list iteration safe against removal}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMkhjiubah}(h]h ]h"]h$]h&]uh1jhjihMkhj hhubj)}(hXG**Parameters** ``pos`` the type * to use as a loop cursor. ``n`` another type * to use as temporary storage ``head`` the head for your list. ``member`` the name of the list_head within the struct. **Description** Iterate over list of given type, continuing after current point, safe against removal of list entry.h](h)}(h**Parameters**h]j)}(hjih]h Parameters}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMohjiubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hjih]hpos}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMlhjiubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMlhjiubah}(h]h ]h"]h$]h&]uh1jhjiubeh}(h]h ]h"]h$]h&]uh1jhjihMlhjiubj)}(h1``n`` another type * to use as temporary storage h](j)}(h``n``h]j)}(hjjh]hn}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMmhjjubj)}(hhh]h)}(h*another type * to use as temporary storageh]h*another type * to use as temporary storage}(hj1jhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-jhMmhj.jubah}(h]h ]h"]h$]h&]uh1jhjjubeh}(h]h ]h"]h$]h&]uh1jhj-jhMmhjiubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjQjh]hhead}(hjSjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMnhjKjubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hjjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfjhMnhjgjubah}(h]h ]h"]h$]h&]uh1jhjKjubeh}(h]h ]h"]h$]h&]uh1jhjfjhMnhjiubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjjh]hmember}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMohjjubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhMohjjubah}(h]h ]h"]h$]h&]uh1jhjjubeh}(h]h ]h"]h$]h&]uh1jhjjhMohjiubeh}(h]h ]h"]h$]h&]uh1jhjiubh)}(h**Description**h]j)}(hjjh]h Description}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMqhjiubh)}(hdIterate over list of given type, continuing after current point, safe against removal of list entry.h]hdIterate over list of given type, continuing after current point, safe against removal of list entry.}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMphjiubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j'list_for_each_entry_safe_from (C macro)c.list_for_each_entry_safe_fromhNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_for_each_entry_safe_fromh]j)}(hlist_for_each_entry_safe_fromh]j$)}(hlist_for_each_entry_safe_fromh]j*)}(hjkh]hlist_for_each_entry_safe_from}(hjkhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj kubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjkhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM{ubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjkhhhj!khM{ubah}(h]jjah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj!khM{hjjhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjjhhhj!khM{ubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjij:kjjj:kjkjljmuh1jhhhj hNhNubh)}(h8``list_for_each_entry_safe_from (pos, n, head, member)``h]j)}(hj@kh]h4list_for_each_entry_safe_from (pos, n, head, member)}(hjBkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>kubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM}hj hhubj)}(h:iterate over list from current point safe against removal h]h)}(h9iterate over list from current point safe against removalh]h9iterate over list from current point safe against removal}(hjZkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM{hjVkubah}(h]h ]h"]h$]h&]uh1jhjhkhM{hj hhubj)}(hX:**Parameters** ``pos`` the type * to use as a loop cursor. ``n`` another type * to use as temporary storage ``head`` the head for your list. ``member`` the name of the list_head within the struct. **Description** Iterate over list of given type from current point, safe against removal of list entry.h](h)}(h**Parameters**h]j)}(hjukh]h Parameters}(hjwkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjskubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjokubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hjkh]hpos}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM|hjkubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhM|hjkubah}(h]h ]h"]h$]h&]uh1jhjkubeh}(h]h ]h"]h$]h&]uh1jhjkhM|hjkubj)}(h1``n`` another type * to use as temporary storage h](j)}(h``n``h]j)}(hjkh]hn}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM}hjkubj)}(hhh]h)}(h*another type * to use as temporary storageh]h*another type * to use as temporary storage}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhM}hjkubah}(h]h ]h"]h$]h&]uh1jhjkubeh}(h]h ]h"]h$]h&]uh1jhjkhM}hjkubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjlh]hhead}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhM~hjlubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhM~hjlubah}(h]h ]h"]h$]h&]uh1jhjlubeh}(h]h ]h"]h$]h&]uh1jhjlhM~hjkubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hj?lh]hmember}(hjAlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=lubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj9lubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjXlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjTlhMhjUlubah}(h]h ]h"]h$]h&]uh1jhj9lubeh}(h]h ]h"]h$]h&]uh1jhjTlhMhjkubeh}(h]h ]h"]h$]h&]uh1jhjokubh)}(h**Description**h]j)}(hjzlh]h Description}(hj|lhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxlubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjokubh)}(hWIterate over list of given type from current point, safe against removal of list entry.h]hWIterate over list of given type from current point, safe against removal of list entry.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjokubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j*list_for_each_entry_safe_reverse (C macro)"c.list_for_each_entry_safe_reversehNtauh1jhj hhhNhNubj)}(hhh](j)}(h list_for_each_entry_safe_reverseh]j)}(h list_for_each_entry_safe_reverseh]j$)}(h list_for_each_entry_safe_reverseh]j*)}(hjlh]h list_for_each_entry_safe_reverse}(hjlhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjlubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjlhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjlhhhjlhMubah}(h]jlah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjlhMhjlhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjlhhhjlhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijljjjljkjljmuh1jhhhj hNhNubh)}(h;``list_for_each_entry_safe_reverse (pos, n, head, member)``h]j)}(hjlh]h7list_for_each_entry_safe_reverse (pos, n, head, member)}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(h1iterate backwards over list safe against removal h]h)}(h0iterate backwards over list safe against removalh]h0iterate backwards over list safe against removal}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj mubah}(h]h ]h"]h$]h&]uh1jhjmhMhj hhubj)}(hX1**Parameters** ``pos`` the type * to use as a loop cursor. ``n`` another type * to use as temporary storage ``head`` the head for your list. ``member`` the name of the list_head within the struct. **Description** Iterate backwards over list of given type, safe against removal of list entry.h](h)}(h**Parameters**h]j)}(hj*mh]h Parameters}(hj,mhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(mubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj$mubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hjImh]hpos}(hjKmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGmubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjCmubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjbmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^mhMhj_mubah}(h]h ]h"]h$]h&]uh1jhjCmubeh}(h]h ]h"]h$]h&]uh1jhj^mhMhj@mubj)}(h1``n`` another type * to use as temporary storage h](j)}(h``n``h]j)}(hjmh]hn}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj|mubj)}(hhh]h)}(h*another type * to use as temporary storageh]h*another type * to use as temporary storage}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhMhjmubah}(h]h ]h"]h$]h&]uh1jhj|mubeh}(h]h ]h"]h$]h&]uh1jhjmhMhj@mubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjmh]hhead}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjmubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhMhjmubah}(h]h ]h"]h$]h&]uh1jhjmubeh}(h]h ]h"]h$]h&]uh1jhjmhMhj@mubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjmh]hmember}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjmubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hj nhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj nhMhj nubah}(h]h ]h"]h$]h&]uh1jhjmubeh}(h]h ]h"]h$]h&]uh1jhj nhMhj@mubeh}(h]h ]h"]h$]h&]uh1jhj$mubh)}(h**Description**h]j)}(hj/nh]h Description}(hj1nhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-nubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj$mubh)}(hNIterate backwards over list of given type, safe against removal of list entry.h]hNIterate backwards over list of given type, safe against removal of list entry.}(hjEnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj$mubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jlist_safe_reset_next (C macro)c.list_safe_reset_nexthNtauh1jhj hhhNhNubj)}(hhh](j)}(hlist_safe_reset_nexth]j)}(hlist_safe_reset_nexth]j$)}(hlist_safe_reset_nexth]j*)}(hjnnh]hlist_safe_reset_next}(hjxnhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjtnubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjpnhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjlnhhhjnhMubah}(h]jgnah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjnhMhjinhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjinhhhjnhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijnjjjnjkjljmuh1jhhhj hNhNubh)}(h)``list_safe_reset_next (pos, n, member)``h]j)}(hjnh]h%list_safe_reset_next (pos, n, member)}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(h,reset a stale list_for_each_entry_safe loop h]h)}(h+reset a stale list_for_each_entry_safe looph]h+reset a stale list_for_each_entry_safe loop}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjnubah}(h]h ]h"]h$]h&]uh1jhjnhMhj hhubj)}(hX)**Parameters** ``pos`` the loop cursor used in the list_for_each_entry_safe loop ``n`` temporary storage used in list_for_each_entry_safe ``member`` the name of the list_head within the struct. **Description** list_safe_reset_next is not safe to use in general if the list may be modified concurrently (eg. the lock is dropped in the loop body). An exception to this is if the cursor element (pos) is pinned in the list, and list_safe_reset_next is called after re-taking the lock and before completing the current iteration of the loop body.h](h)}(h**Parameters**h]j)}(hjnh]h Parameters}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjnubj)}(hhh](j)}(hB``pos`` the loop cursor used in the list_for_each_entry_safe loop h](j)}(h``pos``h]j)}(hjnh]hpos}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjnubj)}(hhh]h)}(h9the loop cursor used in the list_for_each_entry_safe looph]h9the loop cursor used in the list_for_each_entry_safe loop}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjoubah}(h]h ]h"]h$]h&]uh1jhjnubeh}(h]h ]h"]h$]h&]uh1jhjohMhjnubj)}(h9``n`` temporary storage used in list_for_each_entry_safe h](j)}(h``n``h]j)}(hj7oh]hn}(hj9ohhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5oubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj1oubj)}(hhh]h)}(h2temporary storage used in list_for_each_entry_safeh]h2temporary storage used in list_for_each_entry_safe}(hjPohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLohMhjMoubah}(h]h ]h"]h$]h&]uh1jhj1oubeh}(h]h ]h"]h$]h&]uh1jhjLohMhjnubj)}(h8``member`` the name of the list_head within the struct. h](j)}(h ``member``h]j)}(hjpoh]hmember}(hjrohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnoubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjjoubj)}(hhh]h)}(h,the name of the list_head within the struct.h]h,the name of the list_head within the struct.}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjoubah}(h]h ]h"]h$]h&]uh1jhjjoubeh}(h]h ]h"]h$]h&]uh1jhjohMhjnubeh}(h]h ]h"]h$]h&]uh1jhjnubh)}(h**Description**h]j)}(hjoh]h Description}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjnubh)}(hXLlist_safe_reset_next is not safe to use in general if the list may be modified concurrently (eg. the lock is dropped in the loop body). An exception to this is if the cursor element (pos) is pinned in the list, and list_safe_reset_next is called after re-taking the lock and before completing the current iteration of the loop body.h]hXLlist_safe_reset_next is not safe to use in general if the list may be modified concurrently (eg. the lock is dropped in the loop body). An exception to this is if the cursor element (pos) is pinned in the list, and list_safe_reset_next is called after re-taking the lock and before completing the current iteration of the loop body.}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjnubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jhlist_unhashed (C function)c.hlist_unhashedhNtauh1jhj hhhNhNubj)}(hhh](j)}(h/int hlist_unhashed (const struct hlist_node *h)h]j)}(h.int hlist_unhashed(const struct hlist_node *h)h](jb)}(hinth]hint}(hjohhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjohhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjohhhjohMubj$)}(hhlist_unhashedh]j*)}(hhlist_unhashedh]hhlist_unhashed}(hjphhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj pubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjohhhjohMubj)}(h(const struct hlist_node *h)h]j)}(hconst struct hlist_node *hh](j)}(hj&h]hconst}(hj-phhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)pubjt)}(h h]h }(hj:phhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj)pubj)}(hjh]hstruct}(hjHphhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)pubjt)}(h h]h }(hjUphhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj)pubh)}(hhh]j*)}(h hlist_nodeh]h hlist_node}(hjfphhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjcpubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjhpmodnameN classnameNjj)}j]j)}jjpsbc.hlist_unhashedasbuh1hhj)pubjt)}(h h]h }(hjphhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj)pubj)}(hj h]h*}(hjphhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)pubj*)}(hhh]hh}(hjphhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj)pubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj%pubah}(h]h ]h"]h$]h&]hhuh1jhjohhhjohMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjohhhjohMubah}(h]joah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjohMhjohhubjW)}(hhh]h)}(h2Has node been removed from list and reinitialized?h]h2Has node been removed from list and reinitialized?}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjphhubah}(h]h ]h"]h$]h&]uh1jVhjohhhjohMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijpjjjpjkjljmuh1jhhhj hNhNubj)}(hX **Parameters** ``const struct hlist_node *h`` Node to be checked **Description** Not that not all removal functions will leave a node in unhashed state. For example, hlist_nulls_del_init_rcu() does leave the node in unhashed state, but hlist_nulls_del() does not.h](h)}(h**Parameters**h]j)}(hjph]h Parameters}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjpubj)}(hhh]j)}(h2``const struct hlist_node *h`` Node to be checked h](j)}(h``const struct hlist_node *h``h]j)}(hj qh]hconst struct hlist_node *h}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj qubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjqubj)}(hhh]h)}(hNode to be checkedh]hNode to be checked}(hj%qhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!qhMhj"qubah}(h]h ]h"]h$]h&]uh1jhjqubeh}(h]h ]h"]h$]h&]uh1jhj!qhMhjqubah}(h]h ]h"]h$]h&]uh1jhjpubh)}(h**Description**h]j)}(hjGqh]h Description}(hjIqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEqubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjpubh)}(hNot that not all removal functions will leave a node in unhashed state. For example, hlist_nulls_del_init_rcu() does leave the node in unhashed state, but hlist_nulls_del() does not.h]hNot that not all removal functions will leave a node in unhashed state. For example, hlist_nulls_del_init_rcu() does leave the node in unhashed state, but hlist_nulls_del() does not.}(hj]qhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjpubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j$hlist_unhashed_lockless (C function)c.hlist_unhashed_locklesshNtauh1jhj hhhNhNubj)}(hhh](j)}(h8int hlist_unhashed_lockless (const struct hlist_node *h)h]j)}(h7int hlist_unhashed_lockless(const struct hlist_node *h)h](jb)}(hinth]hint}(hjqhhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjqhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjqhhhjqhMubj$)}(hhlist_unhashed_locklessh]j*)}(hhlist_unhashed_locklessh]hhlist_unhashed_lockless}(hjqhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjqubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjqhhhjqhMubj)}(h(const struct hlist_node *h)h]j)}(hconst struct hlist_node *hh](j)}(hj&h]hconst}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjqubjt)}(h h]h }(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjqubj)}(hjh]hstruct}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjqubjt)}(h h]h }(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjqubh)}(hhh]j*)}(h hlist_nodeh]h hlist_node}(hjrhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjqubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjrmodnameN classnameNjj)}j]j)}jjqsbc.hlist_unhashed_locklessasbuh1hhjqubjt)}(h h]h }(hj"rhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjqubj)}(hj h]h*}(hj0rhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjqubj*)}(hjph]hh}(hj=rhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjqubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjqubah}(h]h ]h"]h$]h&]hhuh1jhjqhhhjqhMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjqhhhjqhMubah}(h]jqah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjqhMhjqhhubjW)}(hhh]h)}(h*Version of hlist_unhashed for lockless useh]h*Version of hlist_unhashed for lockless use}(hjfrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjcrhhubah}(h]h ]h"]h$]h&]uh1jVhjqhhhjqhMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij~rjjj~rjkjljmuh1jhhhj hNhNubj)}(hX**Parameters** ``const struct hlist_node *h`` Node to be checked **Description** This variant of hlist_unhashed() must be used in lockless contexts to avoid potential load-tearing. The READ_ONCE() is paired with the various WRITE_ONCE() in hlist helpers that are defined below.h](h)}(h**Parameters**h]j)}(hjrh]h Parameters}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjrubj)}(hhh]j)}(h2``const struct hlist_node *h`` Node to be checked h](j)}(h``const struct hlist_node *h``h]j)}(hjrh]hconst struct hlist_node *h}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjrubj)}(hhh]h)}(hNode to be checkedh]hNode to be checked}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrhMhjrubah}(h]h ]h"]h$]h&]uh1jhjrubeh}(h]h ]h"]h$]h&]uh1jhjrhMhjrubah}(h]h ]h"]h$]h&]uh1jhjrubh)}(h**Description**h]j)}(hjrh]h Description}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjrubh)}(hThis variant of hlist_unhashed() must be used in lockless contexts to avoid potential load-tearing. The READ_ONCE() is paired with the various WRITE_ONCE() in hlist helpers that are defined below.h]hThis variant of hlist_unhashed() must be used in lockless contexts to avoid potential load-tearing. The READ_ONCE() is paired with the various WRITE_ONCE() in hlist helpers that are defined below.}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjrubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jhlist_empty (C function) c.hlist_emptyhNtauh1jhj hhhNhNubj)}(hhh](j)}(h,int hlist_empty (const struct hlist_head *h)h]j)}(h+int hlist_empty(const struct hlist_head *h)h](jb)}(hinth]hint}(hj'shhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahj#shhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hj6shhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj#shhhj5shMubj$)}(h hlist_emptyh]j*)}(h hlist_emptyh]h hlist_empty}(hjHshhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjDsubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj#shhhj5shMubj)}(h(const struct hlist_head *h)h]j)}(hconst struct hlist_head *hh](j)}(hj&h]hconst}(hjdshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`subjt)}(h h]h }(hjqshhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj`subj)}(hjh]hstruct}(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`subjt)}(h h]h }(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj`subh)}(hhh]j*)}(h hlist_headh]h hlist_head}(hjshhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjsubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjsmodnameN classnameNjj)}j]j)}jjJssb c.hlist_emptyasbuh1hhj`subjt)}(h h]h }(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj`subj)}(hj h]h*}(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`subj*)}(hjph]hh}(hjshhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj`subeh}(h]h ]h"]h$]h&]noemphhhuh1jhj\subah}(h]h ]h"]h$]h&]hhuh1jhj#shhhj5shMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjshhhj5shMubah}(h]jsah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj5shMhjshhubjW)}(hhh]h)}(h5Is the specified hlist_head structure an empty hlist?h]h5Is the specified hlist_head structure an empty hlist?}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjshhubah}(h]h ]h"]h$]h&]uh1jVhjshhhj5shMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijtjjjtjkjljmuh1jhhhj hNhNubj)}(hD**Parameters** ``const struct hlist_head *h`` Structure to check.h](h)}(h**Parameters**h]j)}(hj#th]h Parameters}(hj%thhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!tubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjtubj)}(hhh]j)}(h2``const struct hlist_head *h`` Structure to check.h](j)}(h``const struct hlist_head *h``h]j)}(hjBth]hconst struct hlist_head *h}(hjDthhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@tubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjc.hlist_is_singular_nodeasbuh1hhjqubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjqubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjqubj*)}(hjph]hh}(hj́hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjqubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubeh}(h]h ]h"]h$]h&]hhuh1jhjĀhhhjՀhMHubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjՀhMHubah}(h]jah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjՀhMHhjhhubjW)}(hhh]h)}(h0is node the only element of the specified hlist?h]h0is node the only element of the specified hlist?}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMHhjhhubah}(h]h ]h"]h$]h&]uh1jVhjhhhjՀhMHubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij jjj jkjljmuh1jhhhj hNhNubj)}(hX**Parameters** ``struct hlist_node *n`` Node to check for singularity. ``struct hlist_head *h`` Header for potentially singular list. **Description** Check whether the node is the only node of the head without accessing head, thus avoiding unnecessary cache misses.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMLhjubj)}(hhh](j)}(h8``struct hlist_node *n`` Node to check for singularity. h](j)}(h``struct hlist_node *n``h]j)}(hj6h]hstruct hlist_node *n}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMIhj0ubj)}(hhh]h)}(hNode to check for singularity.h]hNode to check for singularity.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhMIhjLubah}(h]h ]h"]h$]h&]uh1jhj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhMIhj-ubj)}(h?``struct hlist_head *h`` Header for potentially singular list. h](j)}(h``struct hlist_head *h``h]j)}(hjoh]hstruct hlist_head *h}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMJhjiubj)}(hhh]h)}(h%Header for potentially singular list.h]h%Header for potentially singular list.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMJhjubah}(h]h ]h"]h$]h&]uh1jhjiubeh}(h]h ]h"]h$]h&]uh1jhjhMJhj-ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMLhjubh)}(hsCheck whether the node is the only node of the head without accessing head, thus avoiding unnecessary cache misses.h]hsCheck whether the node is the only node of the head without accessing head, thus avoiding unnecessary cache misses.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jhlist_move_list (C function)c.hlist_move_listhNtauh1jhj hhhNhNubj)}(hhh](j)}(hEvoid hlist_move_list (struct hlist_head *old, struct hlist_head *new)h]j)}(hDvoid hlist_move_list(struct hlist_head *old, struct hlist_head *new)h](jb)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMVubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjhhhjhMVubj$)}(hhlist_move_listh]j*)}(hhlist_move_listh]hhlist_move_list}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjhhhjhMVubj)}(h0(struct hlist_head *old, struct hlist_head *new)h](j)}(hstruct hlist_head *oldh](j)}(hjh]hstruct}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubjt)}(h h]h }(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj(ubh)}(hhh]j*)}(h hlist_headh]h hlist_head}(hjJhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjGubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjLmodnameN classnameNjj)}j]j)}jjsbc.hlist_move_listasbuh1hhj(ubjt)}(h h]h }(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj(ubj)}(hj h]h*}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubj*)}(holdh]hold}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj(ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj$ubj)}(hstruct hlist_head *newh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubh)}(hhh]j*)}(h hlist_headh]h hlist_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]jfc.hlist_move_listasbuh1hhjubjt)}(h h]h }(hjڃhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj*)}(hnewh]hnew}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhj$ubeh}(h]h ]h"]h$]h&]hhuh1jhjhhhjhMVubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhMVubah}(h]jah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjhMVhjhhubjW)}(hhh]h)}(h Move an hlisth]h Move an hlist}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMVhjhhubah}(h]h ]h"]h$]h&]uh1jVhjhhhjhMVubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij7jjj7jkjljmuh1jhhhj hNhNubj)}(h**Parameters** ``struct hlist_head *old`` hlist_head for old list. ``struct hlist_head *new`` hlist_head for new list. **Description** Move a list from one list head to another. Fixup the pprev reference of the first entry if it exists.h](h)}(h**Parameters**h]j)}(hjAh]h Parameters}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMZhj;ubj)}(hhh](j)}(h4``struct hlist_head *old`` hlist_head for old list. h](j)}(h``struct hlist_head *old``h]j)}(hj`h]hstruct hlist_head *old}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMWhjZubj)}(hhh]h)}(hhlist_head for old list.h]hhlist_head for old list.}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhMWhjvubah}(h]h ]h"]h$]h&]uh1jhjZubeh}(h]h ]h"]h$]h&]uh1jhjuhMWhjWubj)}(h4``struct hlist_head *new`` hlist_head for new list. h](j)}(h``struct hlist_head *new``h]j)}(hjh]hstruct hlist_head *new}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMXhjubj)}(hhh]h)}(hhlist_head for new list.h]hhlist_head for new list.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMXhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMXhjWubeh}(h]h ]h"]h$]h&]uh1jhj;ubh)}(h**Description**h]j)}(hjԄh]h Description}(hjքhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj҄ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMZhj;ubh)}(heMove a list from one list head to another. Fixup the pprev reference of the first entry if it exists.h]heMove a list from one list head to another. Fixup the pprev reference of the first entry if it exists.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMYhj;ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jhlist_splice_init (C function)c.hlist_splice_inithNtauh1jhj hhhNhNubj)}(hhh](j)}(h`void hlist_splice_init (struct hlist_head *from, struct hlist_node *last, struct hlist_head *to)h]j)}(h_void hlist_splice_init(struct hlist_head *from, struct hlist_node *last, struct hlist_head *to)h](jb)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jnah"]h$]h&]uh1jahjhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMgubjt)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjhhhj'hMgubj$)}(hhlist_splice_inith]j*)}(hhlist_splice_inith]hhlist_splice_init}(hj:hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj6ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjhhhj'hMgubj)}(hI(struct hlist_head *from, struct hlist_node *last, struct hlist_head *to)h](j)}(hstruct hlist_head *fromh](j)}(hjh]hstruct}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubjt)}(h h]h }(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjRubh)}(hhh]j*)}(h hlist_headh]h hlist_head}(hjthhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjqubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjvmodnameN classnameNjj)}j]j)}jj<sbc.hlist_splice_initasbuh1hhjRubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjRubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubj*)}(hfromh]hfrom}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjRubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjNubj)}(hstruct hlist_node *lasth](j)}(hjh]hstruct}(hjȅhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjąubjt)}(h h]h }(hjՅhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjąubh)}(hhh]j*)}(h hlist_nodeh]h hlist_node}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]jc.hlist_splice_initasbuh1hhjąubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjąubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjąubj*)}(hlasth]hlast}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjąubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjNubj)}(hstruct hlist_head *toh](j)}(hjh]hstruct}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubjt)}(h h]h }(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj4ubh)}(hhh]j*)}(h hlist_headh]h hlist_head}(hjVhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjSubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjXmodnameN classnameNjj)}j]jc.hlist_splice_initasbuh1hhj4ubjt)}(h h]h }(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jshj4ubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubj*)}(htoh]hto}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj4ubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjNubeh}(h]h ]h"]h$]h&]hhuh1jhjhhhj'hMgubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhj'hMgubah}(h]j ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj'hMghjhhubjW)}(hhh]h)}(h)move all entries from one list to anotherh]h)move all entries from one list to another}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMghjhhubah}(h]h ]h"]h$]h&]uh1jVhjhhhj'hMgubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjijцjjjцjkjljmuh1jhhhj hNhNubj)}(hX/**Parameters** ``struct hlist_head *from`` hlist_head from which entries will be moved ``struct hlist_node *last`` last entry on the **from** list ``struct hlist_head *to`` hlist_head to which entries will be moved **Description** **to** can be empty, **from** must contain at least **last**.h](h)}(h**Parameters**h]j)}(hjۆh]h Parameters}(hj݆hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjنubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMkhjՆubj)}(hhh](j)}(hH``struct hlist_head *from`` hlist_head from which entries will be moved h](j)}(h``struct hlist_head *from``h]j)}(hjh]hstruct hlist_head *from}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhhjubj)}(hhh]h)}(h+hlist_head from which entries will be movedh]h+hlist_head from which entries will be moved}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhhjubj)}(h<``struct hlist_node *last`` last entry on the **from** list h](j)}(h``struct hlist_node *last``h]j)}(hj3h]hstruct hlist_node *last}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMihj-ubj)}(hhh]h)}(hlast entry on the **from** listh](hlast entry on the }(hjLhhhNhNubj)}(h**from**h]hfrom}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubh list}(hjLhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjHhMihjIubah}(h]h ]h"]h$]h&]uh1jhj-ubeh}(h]h ]h"]h$]h&]uh1jhjHhMihjubj)}(hD``struct hlist_head *to`` hlist_head to which entries will be moved h](j)}(h``struct hlist_head *to``h]j)}(hj~h]hstruct hlist_head *to}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMjhjxubj)}(hhh]h)}(h)hlist_head to which entries will be movedh]h)hlist_head to which entries will be moved}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMjhjubah}(h]h ]h"]h$]h&]uh1jhjxubeh}(h]h ]h"]h$]h&]uh1jhjhMjhjubeh}(h]h ]h"]h$]h&]uh1jhjՆubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMlhjՆubh)}(h=**to** can be empty, **from** must contain at least **last**.h](j)}(h**to**h]hto}(hjӇhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjχubh can be empty, }(hjχhhhNhNubj)}(h**from**h]hfrom}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjχubh must contain at least }(hjχhhhNhNubj)}(h**last**h]hlast}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjχubh.}(hjχhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMkhjՆubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jhlist_for_each_entry (C macro)c.hlist_for_each_entryhNtauh1jhj hhhNhNubj)}(hhh](j)}(hhlist_for_each_entryh]j)}(hhlist_for_each_entryh]j$)}(hhlist_for_each_entryh]j*)}(hj*h]hhlist_for_each_entry}(hj4hhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hj0ubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hj,hhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj(hhhjGhMubah}(h]j#ah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjGhMhj%hhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhj%hhhjGhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjij`jjj`jkjljmuh1jhhhj hNhNubh)}(h,``hlist_for_each_entry (pos, head, member)``h]j)}(hjfh]h(hlist_for_each_entry (pos, head, member)}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(h iterate over list of given type h]h)}(hiterate over list of given typeh]hiterate over list of given type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj|ubah}(h]h ]h"]h$]h&]uh1jhjhMhj hhubj)}(h**Parameters** ``pos`` the type * to use as a loop cursor. ``head`` the head for your list. ``member`` the name of the hlist_node within the struct.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hjh]hpos}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjӈhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjψhMhjЈubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjψhMhjubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjh]hhead}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhj ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h8``member`` the name of the hlist_node within the struct.h](j)}(h ``member``h]j)}(hj,h]hmember}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj&ubj)}(hhh]h)}(h-the name of the hlist_node within the struct.h]h-the name of the hlist_node within the struct.}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjBubah}(h]h ]h"]h$]h&]uh1jhj&ubeh}(h]h ]h"]h$]h&]uh1jhjAhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j'hlist_for_each_entry_continue (C macro)c.hlist_for_each_entry_continuehNtauh1jhj hhhNhNubj)}(hhh](j)}(hhlist_for_each_entry_continueh]j)}(hhlist_for_each_entry_continueh]j$)}(hhlist_for_each_entry_continueh]j*)}(hjh]hhlist_for_each_entry_continue}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhj~hhhjhMubah}(h]jyah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjhMhj{hhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhj{hhhjhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijjjjjkjljmuh1jhhhj hNhNubh)}(h/``hlist_for_each_entry_continue (pos, member)``h]j)}(hjh]h+hlist_for_each_entry_continue (pos, member)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(h4iterate over a hlist continuing after current point h]h)}(h3iterate over a hlist continuing after current pointh]h3iterate over a hlist continuing after current point}(hj։hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj҉ubah}(h]h ]h"]h$]h&]uh1jhjhMhj hhubj)}(hy**Parameters** ``pos`` the type * to use as a loop cursor. ``member`` the name of the hlist_node within the struct.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hjh]hpos}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj ubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hMhj&ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jhj%hMhjubj)}(h8``member`` the name of the hlist_node within the struct.h](j)}(h ``member``h]j)}(hjIh]hmember}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjCubj)}(hhh]h)}(h-the name of the hlist_node within the struct.h]h-the name of the hlist_node within the struct.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj_ubah}(h]h ]h"]h$]h&]uh1jhjCubeh}(h]h ]h"]h$]h&]uh1jhj^hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j#hlist_for_each_entry_from (C macro)c.hlist_for_each_entry_fromhNtauh1jhj hhhNhNubj)}(hhh](j)}(hhlist_for_each_entry_fromh]j)}(hhlist_for_each_entry_fromh]j$)}(hhlist_for_each_entry_fromh]j*)}(hjh]hhlist_for_each_entry_from}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhjhMubah}(h]jah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjhMhjhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjhhhjhMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijӊjjjӊjkjljmuh1jhhhj hNhNubh)}(h+``hlist_for_each_entry_from (pos, member)``h]j)}(hjيh]h'hlist_for_each_entry_from (pos, member)}(hjۊhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj׊ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(h3iterate over a hlist continuing from current point h]h)}(h2iterate over a hlist continuing from current pointh]h2iterate over a hlist continuing from current point}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubah}(h]h ]h"]h$]h&]uh1jhjhMhj hhubj)}(hy**Parameters** ``pos`` the type * to use as a loop cursor. ``member`` the name of the hlist_node within the struct.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hj-h]hpos}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj'ubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhMhjCubah}(h]h ]h"]h$]h&]uh1jhj'ubeh}(h]h ]h"]h$]h&]uh1jhjBhMhj$ubj)}(h8``member`` the name of the hlist_node within the struct.h](j)}(h ``member``h]j)}(hjfh]hmember}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj`ubj)}(hhh]h)}(h-the name of the hlist_node within the struct.h]h-the name of the hlist_node within the struct.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj|ubah}(h]h ]h"]h$]h&]uh1jhj`ubeh}(h]h ]h"]h$]h&]uh1jhj{hMhj$ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](j#hlist_for_each_entry_safe (C macro)c.hlist_for_each_entry_safehNtauh1jhj hhhNhNubj)}(hhh](j)}(hhlist_for_each_entry_safeh]j)}(hhlist_for_each_entry_safeh]j$)}(hhlist_for_each_entry_safeh]j*)}(hjh]hhlist_for_each_entry_safe}(hjċhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubah}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjhhhj׋hMubah}(h]jah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhj׋hMhjhhubjW)}(hhh]h}(h]h ]h"]h$]h&]uh1jVhjhhhj׋hMubeh}(h]h ](jTmacroeh"]h$]h&]jhjTjijjjjjkjljmuh1jhhhj hNhNubh)}(h4``hlist_for_each_entry_safe (pos, n, head, member)``h]j)}(hjh]h0hlist_for_each_entry_safe (pos, n, head, member)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj hhubj)}(hCiterate over list of given type safe against removal of list entry h]h)}(hBiterate over list of given type safe against removal of list entryh]hBiterate over list of given type safe against removal of list entry}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj ubah}(h]h ]h"]h$]h&]uh1jhjhMhj hhubj)}(h**Parameters** ``pos`` the type * to use as a loop cursor. ``n`` a :c:type:`struct hlist_node ` to use as temporary storage ``head`` the head for your list. ``member`` the name of the hlist_node within the struct.h](h)}(h**Parameters**h]j)}(hj+h]h Parameters}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj%ubj)}(hhh](j)}(h,``pos`` the type * to use as a loop cursor. h](j)}(h``pos``h]j)}(hjJh]hpos}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjDubj)}(hhh]h)}(h#the type * to use as a loop cursor.h]h#the type * to use as a loop cursor.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMhj`ubah}(h]h ]h"]h$]h&]uh1jhjDubeh}(h]h ]h"]h$]h&]uh1jhj_hMhjAubj)}(hM``n`` a :c:type:`struct hlist_node ` to use as temporary storage h](j)}(h``n``h]j)}(hjh]hn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj}ubj)}(hhh]h)}(hFa :c:type:`struct hlist_node ` to use as temporary storageh](ha }(hjhhhNhNubh)}(h(:c:type:`struct hlist_node `h]j)}(hjh]hstruct hlist_node}(hjhhhNhNubah}(h]h ](jjTc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocj refdomainjTreftypetype refexplicitrefwarnjjj hlist_nodeuh1hhjhMhjubh to use as temporary storage}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhj}ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjAubj)}(h!``head`` the head for your list. h](j)}(h``head``h]j)}(hjߌh]hhead}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj݌ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjٌubj)}(hhh]h)}(hthe head for your list.h]hthe head for your list.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjٌubeh}(h]h ]h"]h$]h&]uh1jhjhMhjAubj)}(h8``member`` the name of the hlist_node within the struct.h](j)}(h ``member``h]j)}(hjh]hmember}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh]h)}(h-the name of the hlist_node within the struct.h]h-the name of the hlist_node within the struct.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhj.ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhj-hMhjAubeh}(h]h ]h"]h$]h&]uh1jhj%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubj)}(hhh]h}(h]h ]h"]h$]h&]entries](jhlist_count_nodes (C function)c.hlist_count_nodeshNtauh1jhj hhhNhNubj)}(hhh](j)}(h2size_t hlist_count_nodes (struct hlist_head *head)h]j)}(h1size_t hlist_count_nodes(struct hlist_head *head)h](h)}(hhh]j*)}(hsize_th]hsize_t}(hjuhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjrubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjwmodnameN classnameNjj)}j]j)}jhlist_count_nodessbc.hlist_count_nodesasbuh1hhjnhhhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjnhhhjhMubj$)}(hhlist_count_nodesh]j*)}(hjh]hhlist_count_nodes}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubah}(h]h ](j<j=eh"]h$]h&]hhuh1j#hjnhhhjhMubj)}(h(struct hlist_head *head)h]j)}(hstruct hlist_head *headh](j)}(hjh]hstruct}(hjčhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjt)}(h h]h }(hjэhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubh)}(hhh]j*)}(h hlist_headh]h hlist_head}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjߍubah}(h]h ]h"]h$]h&] refdomainjTreftypej reftargetjmodnameN classnameNjj)}j]jc.hlist_count_nodesasbuh1hhjubjt)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jshjubj)}(hj h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj*)}(hheadh]hhead}(hjhhhNhNubah}(h]h ]j5ah"]h$]h&]uh1j)hjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubah}(h]h ]h"]h$]h&]hhuh1jhjnhhhjhMubeh}(h]h ]h"]h$]h&]hhjHuh1jjIjJhjjhhhjhMubah}(h]jeah ](jNjOeh"]h$]h&]jSjT)jUhuh1jhjhMhjghhubjW)}(hhh]h)}(hcount nodes in the hlisth]hcount nodes in the hlist}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjBhhubah}(h]h ]h"]h$]h&]uh1jVhjghhhjhMubeh}(h]h ](jTfunctioneh"]h$]h&]jhjTjij]jjj]jkjljmuh1jhhhj hNhNubj)}(hF**Parameters** ``struct hlist_head *head`` the head for your hlist.h](h)}(h**Parameters**h]j)}(hjgh]h Parameters}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjaubj)}(hhh]j)}(h4``struct hlist_head *head`` the head for your hlist.h](j)}(h``struct hlist_head *head``h]j)}(hjh]hstruct hlist_head *head}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubj)}(hhh]h)}(hthe head for your hlist.h]hthe head for your hlist.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/core-api/list:775: ./include/linux/list.hhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj}ubah}(h]h ]h"]h$]h&]uh1jhjaubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj hhhNhNubeh}(h]jxah ]h"] full list apiah$]h&]uh1hhhhhhhhMubeh}(h]jRah ]h"]linked lists in linuxah$]h&]uh1hhhhhhhhKubeh}(h]h ]h"]h$]h&]sourcehuh1hcurrent_sourceN current_lineNsettingsdocutils.frontendValues)}(hN generatorN datestampN source_linkN source_urlN toc_backlinksentryfootnote_backlinksK sectnum_xformKstrip_commentsNstrip_elements_with_classesN strip_classesN report_levelK halt_levelKexit_status_levelKdebugNwarning_streamN tracebackinput_encoding utf-8-siginput_encoding_error_handlerstrictoutput_encodingutf-8output_encoding_error_handlerjerror_encodingutf-8error_encoding_error_handlerbackslashreplace language_codeenrecord_dependenciesNconfigN id_prefixhauto_id_prefixid dump_settingsNdump_internalsNdump_transformsNdump_pseudo_xmlNexpose_internalsNstrict_visitorN_disable_configN_sourceh _destinationN _config_files]7/var/lib/git/docbuild/linux/Documentation/docutils.confafile_insertion_enabled raw_enabledKline_length_limitM'pep_referencesN pep_base_urlhttps://peps.python.org/pep_file_url_templatepep-%04drfc_referencesN rfc_base_url&https://datatracker.ietf.org/doc/html/ tab_widthKtrim_footnote_reference_spacesyntax_highlightlong smart_quotessmartquotes_locales]character_level_inline_markupdoctitle_xform docinfo_xformKsectsubtitle_xform image_loadinglinkembed_stylesheetcloak_email_addressessection_self_linkenvNubreporterNindirect_targets]substitution_defs}substitution_names}refnames}refids}nameids}(jҎjRjjjjqj jjijjjjjjtjjZj:jj\j j~j jj jjA jjh jj j(j jJj j jˎjxu nametypes}(jҎjjj jijjjtjZjj j j jA jh j j j jˎuh}(jRhjj%jqjjjjj#jjljjjjj:jwj\j]j~jjj jj jj jjD j(jk jJj j j jxj jjjMjRjTjYjjjjj=jBjjjjj6j;j:j?jjj!j!j#j#j&j&j)j)jn+js+j-j-j>/jC/j0j0j2j2j3j3j(6j-6j7j7j:j:j>j>j@j@jBjBjDjDj$Gj)GjHjHjJjJjKjKjMjMjNjNjOjOj&Qj+QjCRjHRjSjSjTjUjeVjjVjWjWjAYjFYjZjZjK\jP\j]j]j^j^jM`jR`jajajEcjJcjdjdj=fjBfjgjgjHijMijjjkjljljgnjlnjojojqjqjsjsjtjtj!vj&vjwjwjyjyj{j{j}j}jajfjjjjj jj#j(jyj~jjjjjejjhjDjkjbjjjjjjjjjj j4j+jVjMjxjojjjjjjjjj"jjDj;jrjiu footnote_refs} citation_refs} autofootnotes]autofootnote_refs]symbol_footnotes]symbol_footnote_refs] footnotes] citations]autofootnote_startKsymbol_footnote_startK id_counter collectionsCounter}jKsRparse_messages]transform_messages] transformerN include_log] decorationNhhub.