diff options
Diffstat (limited to 'net/ax25/ax25_uid.c')
| -rw-r--r-- | net/ax25/ax25_uid.c | 25 |
1 files changed, 4 insertions, 21 deletions
diff --git a/net/ax25/ax25_uid.c b/net/ax25/ax25_uid.c index 832bcf092a01..9f13f6eefcba 100644 --- a/net/ax25/ax25_uid.c +++ b/net/ax25/ax25_uid.c | |||
| @@ -146,31 +146,13 @@ int ax25_uid_ioctl(int cmd, struct sockaddr_ax25 *sax) | |||
| 146 | static void *ax25_uid_seq_start(struct seq_file *seq, loff_t *pos) | 146 | static void *ax25_uid_seq_start(struct seq_file *seq, loff_t *pos) |
| 147 | __acquires(ax25_uid_lock) | 147 | __acquires(ax25_uid_lock) |
| 148 | { | 148 | { |
| 149 | struct ax25_uid_assoc *pt; | ||
| 150 | struct hlist_node *node; | ||
| 151 | int i = 1; | ||
| 152 | |||
| 153 | read_lock(&ax25_uid_lock); | 149 | read_lock(&ax25_uid_lock); |
| 154 | 150 | return seq_hlist_start_head(&ax25_uid_list, *pos); | |
| 155 | if (*pos == 0) | ||
| 156 | return SEQ_START_TOKEN; | ||
| 157 | |||
| 158 | ax25_uid_for_each(pt, node, &ax25_uid_list) { | ||
| 159 | if (i == *pos) | ||
| 160 | return pt; | ||
| 161 | ++i; | ||
| 162 | } | ||
| 163 | return NULL; | ||
| 164 | } | 151 | } |
| 165 | 152 | ||
| 166 | static void *ax25_uid_seq_next(struct seq_file *seq, void *v, loff_t *pos) | 153 | static void *ax25_uid_seq_next(struct seq_file *seq, void *v, loff_t *pos) |
| 167 | { | 154 | { |
| 168 | ++*pos; | 155 | return seq_hlist_next(v, &ax25_uid_list, pos); |
| 169 | if (v == SEQ_START_TOKEN) | ||
| 170 | return ax25_uid_list.first; | ||
| 171 | else | ||
| 172 | return hlist_entry(((ax25_uid_assoc *)v)->uid_node.next, | ||
| 173 | ax25_uid_assoc, uid_node); | ||
| 174 | } | 156 | } |
| 175 | 157 | ||
| 176 | static void ax25_uid_seq_stop(struct seq_file *seq, void *v) | 158 | static void ax25_uid_seq_stop(struct seq_file *seq, void *v) |
| @@ -186,8 +168,9 @@ static int ax25_uid_seq_show(struct seq_file *seq, void *v) | |||
| 186 | if (v == SEQ_START_TOKEN) | 168 | if (v == SEQ_START_TOKEN) |
| 187 | seq_printf(seq, "Policy: %d\n", ax25_uid_policy); | 169 | seq_printf(seq, "Policy: %d\n", ax25_uid_policy); |
| 188 | else { | 170 | else { |
| 189 | struct ax25_uid_assoc *pt = v; | 171 | struct ax25_uid_assoc *pt; |
| 190 | 172 | ||
| 173 | pt = hlist_entry(v, struct ax25_uid_assoc, uid_node); | ||
| 191 | seq_printf(seq, "%6d %s\n", pt->uid, ax2asc(buf, &pt->call)); | 174 | seq_printf(seq, "%6d %s\n", pt->uid, ax2asc(buf, &pt->call)); |
| 192 | } | 175 | } |
| 193 | return 0; | 176 | return 0; |
