.. | .. |
---|
| 1 | +// SPDX-License-Identifier: GPL-2.0-only |
---|
1 | 2 | /* |
---|
2 | 3 | * atalk_proc.c - proc support for Appletalk |
---|
3 | 4 | * |
---|
4 | 5 | * Copyright(c) Arnaldo Carvalho de Melo <acme@conectiva.com.br> |
---|
5 | | - * |
---|
6 | | - * This program is free software; you can redistribute it and/or modify it |
---|
7 | | - * under the terms of the GNU General Public License as published by the |
---|
8 | | - * Free Software Foundation, version 2. |
---|
9 | 6 | */ |
---|
10 | 7 | |
---|
11 | 8 | #include <linux/init.h> |
---|
.. | .. |
---|
210 | 207 | .show = atalk_seq_socket_show, |
---|
211 | 208 | }; |
---|
212 | 209 | |
---|
213 | | -static struct proc_dir_entry *atalk_proc_dir; |
---|
214 | | - |
---|
215 | 210 | int __init atalk_proc_init(void) |
---|
216 | 211 | { |
---|
217 | | - struct proc_dir_entry *p; |
---|
218 | | - int rc = -ENOMEM; |
---|
| 212 | + if (!proc_mkdir("atalk", init_net.proc_net)) |
---|
| 213 | + return -ENOMEM; |
---|
219 | 214 | |
---|
220 | | - atalk_proc_dir = proc_mkdir("atalk", init_net.proc_net); |
---|
221 | | - if (!atalk_proc_dir) |
---|
| 215 | + if (!proc_create_seq("atalk/interface", 0444, init_net.proc_net, |
---|
| 216 | + &atalk_seq_interface_ops)) |
---|
222 | 217 | goto out; |
---|
223 | 218 | |
---|
224 | | - p = proc_create_seq("interface", 0444, atalk_proc_dir, |
---|
225 | | - &atalk_seq_interface_ops); |
---|
226 | | - if (!p) |
---|
227 | | - goto out_interface; |
---|
| 219 | + if (!proc_create_seq("atalk/route", 0444, init_net.proc_net, |
---|
| 220 | + &atalk_seq_route_ops)) |
---|
| 221 | + goto out; |
---|
228 | 222 | |
---|
229 | | - p = proc_create_seq("route", 0444, atalk_proc_dir, |
---|
230 | | - &atalk_seq_route_ops); |
---|
231 | | - if (!p) |
---|
232 | | - goto out_route; |
---|
| 223 | + if (!proc_create_seq("atalk/socket", 0444, init_net.proc_net, |
---|
| 224 | + &atalk_seq_socket_ops)) |
---|
| 225 | + goto out; |
---|
233 | 226 | |
---|
234 | | - p = proc_create_seq("socket", 0444, atalk_proc_dir, |
---|
235 | | - &atalk_seq_socket_ops); |
---|
236 | | - if (!p) |
---|
237 | | - goto out_socket; |
---|
| 227 | + if (!proc_create_seq_private("atalk/arp", 0444, init_net.proc_net, |
---|
| 228 | + &aarp_seq_ops, |
---|
| 229 | + sizeof(struct aarp_iter_state), NULL)) |
---|
| 230 | + goto out; |
---|
238 | 231 | |
---|
239 | | - p = proc_create_seq_private("arp", 0444, atalk_proc_dir, &aarp_seq_ops, |
---|
240 | | - sizeof(struct aarp_iter_state), NULL); |
---|
241 | | - if (!p) |
---|
242 | | - goto out_arp; |
---|
| 232 | + return 0; |
---|
243 | 233 | |
---|
244 | | - rc = 0; |
---|
245 | 234 | out: |
---|
246 | | - return rc; |
---|
247 | | -out_arp: |
---|
248 | | - remove_proc_entry("socket", atalk_proc_dir); |
---|
249 | | -out_socket: |
---|
250 | | - remove_proc_entry("route", atalk_proc_dir); |
---|
251 | | -out_route: |
---|
252 | | - remove_proc_entry("interface", atalk_proc_dir); |
---|
253 | | -out_interface: |
---|
254 | | - remove_proc_entry("atalk", init_net.proc_net); |
---|
255 | | - goto out; |
---|
| 235 | + remove_proc_subtree("atalk", init_net.proc_net); |
---|
| 236 | + return -ENOMEM; |
---|
256 | 237 | } |
---|
257 | 238 | |
---|
258 | 239 | void atalk_proc_exit(void) |
---|
259 | 240 | { |
---|
260 | | - remove_proc_entry("interface", atalk_proc_dir); |
---|
261 | | - remove_proc_entry("route", atalk_proc_dir); |
---|
262 | | - remove_proc_entry("socket", atalk_proc_dir); |
---|
263 | | - remove_proc_entry("arp", atalk_proc_dir); |
---|
264 | | - remove_proc_entry("atalk", init_net.proc_net); |
---|
| 241 | + remove_proc_subtree("atalk", init_net.proc_net); |
---|
265 | 242 | } |
---|