-
Notifications
You must be signed in to change notification settings - Fork 0
/
lists.c
85 lines (67 loc) · 1.74 KB
/
lists.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
// SPDX-License-Identifier: GPL-2.0-or-later
// Author: Marcos Paulo de Souza <marcos@mpdesouza.com>
#include <linux/list.h>
#include <linux/slab.h>
#include <linux/module.h>
static LIST_HEAD(mod_list);
/* simple_entry for testing purposes */
struct sentry {
struct list_head list;
int val;
};
static int lists_init(void)
{
struct sentry *se1, *se2, *se3, *cursor, *tmp;
se1 = kmalloc(sizeof(struct sentry), GFP_KERNEL);
if (!se1)
return -ENOMEM;
se1->val = 10;
list_add(&se1->list, &mod_list);
se2 = kmalloc(sizeof(struct sentry), GFP_KERNEL);
if (!se2) {
kfree(se1);
return -ENOMEM;
}
se2 = kmalloc(sizeof(struct sentry), GFP_KERNEL);
if (!se2) {
kfree(se1);
return -ENOMEM;
}
se2->val = 20;
list_add(&se2->list, &mod_list);
se3 = kmalloc(sizeof(struct sentry), GFP_KERNEL);
if (!se2) {
kfree(se2);
kfree(se1);
return -ENOMEM;
}
se3->val = 30;
list_add(&se3->list, &mod_list);
/* Shows the first entry, with val as 30 */
cursor = list_first_entry(&mod_list, struct sentry, list);
pr_info("First entry: %d\n", cursor->val);
/* Shows the last entry, with val as 10 */
cursor = list_last_entry(&mod_list, struct sentry, list);
pr_info("Last entry: %d\n", cursor->val);
/* Shows the second entry, with val as 20 */
cursor = list_prev_entry(cursor, list);
pr_info("Previous from last entry: %d\n", cursor->val);
/*
* Show that the list will be traversed from the last inserted node to
* the first one.
*/
pr_info("Traversing list\n");
list_for_each_entry_safe(cursor, tmp, &mod_list, list) {
pr_info("\t%d\n", cursor->val);
list_del(&cursor->list);
kfree(cursor);
}
return 0;
}
static void lists_exit(void)
{
}
module_init(lists_init);
module_exit(lists_exit);
MODULE_LICENSE("GPL");
MODULE_LICENSE("GPL");