1 // SPDX-License-Identifier: GPL-2.0 1 2 /* 3 * Procfs support for lockd 4 * 5 * Copyright (c) 2014 Jeff Layton <jlayton@pri 6 */ 7 8 #include <linux/fs.h> 9 #include <linux/proc_fs.h> 10 #include <linux/module.h> 11 #include <linux/nsproxy.h> 12 #include <net/net_namespace.h> 13 14 #include "netns.h" 15 #include "procfs.h" 16 17 /* 18 * We only allow strings that start with 'Y', 19 */ 20 static ssize_t 21 nlm_end_grace_write(struct file *file, const c 22 loff_t *pos) 23 { 24 char *data; 25 struct lockd_net *ln = net_generic(cur 26 loc 27 28 if (size < 1) 29 return -EINVAL; 30 31 data = simple_transaction_get(file, bu 32 if (IS_ERR(data)) 33 return PTR_ERR(data); 34 35 switch(data[0]) { 36 case 'Y': 37 case 'y': 38 case '1': 39 locks_end_grace(&ln->lockd_man 40 break; 41 default: 42 return -EINVAL; 43 } 44 45 return size; 46 } 47 48 static ssize_t 49 nlm_end_grace_read(struct file *file, char __u 50 loff_t *pos) 51 { 52 struct lockd_net *ln = net_generic(cur 53 loc 54 char resp[3]; 55 56 resp[0] = list_empty(&ln->lockd_manage 57 resp[1] = '\n'; 58 resp[2] = '\0'; 59 60 return simple_read_from_buffer(buf, si 61 } 62 63 static const struct proc_ops lockd_end_grace_p 64 .proc_write = nlm_end_grace_write, 65 .proc_read = nlm_end_grace_read, 66 .proc_lseek = default_llseek, 67 .proc_release = simple_transaction_r 68 }; 69 70 int __init 71 lockd_create_procfs(void) 72 { 73 struct proc_dir_entry *entry; 74 75 entry = proc_mkdir("fs/lockd", NULL); 76 if (!entry) 77 return -ENOMEM; 78 entry = proc_create("nlm_end_grace", S 79 &lockd_end_grace_p 80 if (!entry) { 81 remove_proc_entry("fs/lockd", 82 return -ENOMEM; 83 } 84 return 0; 85 } 86 87 void __exit 88 lockd_remove_procfs(void) 89 { 90 remove_proc_entry("fs/lockd/nlm_end_gr 91 remove_proc_entry("fs/lockd", NULL); 92 } 93
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.