diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2013-02-23 14:51:48 -0500 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2013-02-26 02:46:11 -0500 |
commit | 7bb307e894d51308aa0582a8c4cc5875bbc645b9 (patch) | |
tree | 8b8434fe4674fb47236c0d7ca2256e7afc29f208 | |
parent | 94e07a7590ae855bae0536c42b3086fadc7c83a8 (diff) |
export kernel_write(), convert open-coded instances
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r-- | drivers/mtd/nand/nandsim.c | 34 | ||||
-rw-r--r-- | fs/ecryptfs/read_write.c | 6 | ||||
-rw-r--r-- | fs/splice.c | 5 | ||||
-rw-r--r-- | include/linux/fs.h | 1 | ||||
-rw-r--r-- | kernel/sysctl_binary.c | 39 |
5 files changed, 24 insertions, 61 deletions
diff --git a/drivers/mtd/nand/nandsim.c b/drivers/mtd/nand/nandsim.c index 818b65c85d12..8f30d385bfa3 100644 --- a/drivers/mtd/nand/nandsim.c +++ b/drivers/mtd/nand/nandsim.c | |||
@@ -1408,40 +1408,32 @@ static void clear_memalloc(int memalloc) | |||
1408 | current->flags &= ~PF_MEMALLOC; | 1408 | current->flags &= ~PF_MEMALLOC; |
1409 | } | 1409 | } |
1410 | 1410 | ||
1411 | static ssize_t read_file(struct nandsim *ns, struct file *file, void *buf, size_t count, loff_t *pos) | 1411 | static ssize_t read_file(struct nandsim *ns, struct file *file, void *buf, size_t count, loff_t pos) |
1412 | { | 1412 | { |
1413 | mm_segment_t old_fs; | ||
1414 | ssize_t tx; | 1413 | ssize_t tx; |
1415 | int err, memalloc; | 1414 | int err, memalloc; |
1416 | 1415 | ||
1417 | err = get_pages(ns, file, count, *pos); | 1416 | err = get_pages(ns, file, count, pos); |
1418 | if (err) | 1417 | if (err) |
1419 | return err; | 1418 | return err; |
1420 | old_fs = get_fs(); | ||
1421 | set_fs(get_ds()); | ||
1422 | memalloc = set_memalloc(); | 1419 | memalloc = set_memalloc(); |
1423 | tx = vfs_read(file, (char __user *)buf, count, pos); | 1420 | tx = kernel_read(file, pos, buf, count); |
1424 | clear_memalloc(memalloc); | 1421 | clear_memalloc(memalloc); |
1425 | set_fs(old_fs); | ||
1426 | put_pages(ns); | 1422 | put_pages(ns); |
1427 | return tx; | 1423 | return tx; |
1428 | } | 1424 | } |
1429 | 1425 | ||
1430 | static ssize_t write_file(struct nandsim *ns, struct file *file, void *buf, size_t count, loff_t *pos) | 1426 | static ssize_t write_file(struct nandsim *ns, struct file *file, void *buf, size_t count, loff_t pos) |
1431 | { | 1427 | { |
1432 | mm_segment_t old_fs; | ||
1433 | ssize_t tx; | 1428 | ssize_t tx; |
1434 | int err, memalloc; | 1429 | int err, memalloc; |
1435 | 1430 | ||
1436 | err = get_pages(ns, file, count, *pos); | 1431 | err = get_pages(ns, file, count, pos); |
1437 | if (err) | 1432 | if (err) |
1438 | return err; | 1433 | return err; |
1439 | old_fs = get_fs(); | ||
1440 | set_fs(get_ds()); | ||
1441 | memalloc = set_memalloc(); | 1434 | memalloc = set_memalloc(); |
1442 | tx = vfs_write(file, (char __user *)buf, count, pos); | 1435 | tx = kernel_write(file, buf, count, pos); |
1443 | clear_memalloc(memalloc); | 1436 | clear_memalloc(memalloc); |
1444 | set_fs(old_fs); | ||
1445 | put_pages(ns); | 1437 | put_pages(ns); |
1446 | return tx; | 1438 | return tx; |
1447 | } | 1439 | } |
@@ -1511,7 +1503,7 @@ static void read_page(struct nandsim *ns, int num) | |||
1511 | if (do_read_error(ns, num)) | 1503 | if (do_read_error(ns, num)) |
1512 | return; | 1504 | return; |
1513 | pos = (loff_t)ns->regs.row * ns->geom.pgszoob + ns->regs.column + ns->regs.off; | 1505 | pos = (loff_t)ns->regs.row * ns->geom.pgszoob + ns->regs.column + ns->regs.off; |
1514 | tx = read_file(ns, ns->cfile, ns->buf.byte, num, &pos); | 1506 | tx = read_file(ns, ns->cfile, ns->buf.byte, num, pos); |
1515 | if (tx != num) { | 1507 | if (tx != num) { |
1516 | NS_ERR("read_page: read error for page %d ret %ld\n", ns->regs.row, (long)tx); | 1508 | NS_ERR("read_page: read error for page %d ret %ld\n", ns->regs.row, (long)tx); |
1517 | return; | 1509 | return; |
@@ -1573,7 +1565,7 @@ static int prog_page(struct nandsim *ns, int num) | |||
1573 | u_char *pg_off; | 1565 | u_char *pg_off; |
1574 | 1566 | ||
1575 | if (ns->cfile) { | 1567 | if (ns->cfile) { |
1576 | loff_t off, pos; | 1568 | loff_t off; |
1577 | ssize_t tx; | 1569 | ssize_t tx; |
1578 | int all; | 1570 | int all; |
1579 | 1571 | ||
@@ -1585,8 +1577,7 @@ static int prog_page(struct nandsim *ns, int num) | |||
1585 | memset(ns->file_buf, 0xff, ns->geom.pgszoob); | 1577 | memset(ns->file_buf, 0xff, ns->geom.pgszoob); |
1586 | } else { | 1578 | } else { |
1587 | all = 0; | 1579 | all = 0; |
1588 | pos = off; | 1580 | tx = read_file(ns, ns->cfile, pg_off, num, off); |
1589 | tx = read_file(ns, ns->cfile, pg_off, num, &pos); | ||
1590 | if (tx != num) { | 1581 | if (tx != num) { |
1591 | NS_ERR("prog_page: read error for page %d ret %ld\n", ns->regs.row, (long)tx); | 1582 | NS_ERR("prog_page: read error for page %d ret %ld\n", ns->regs.row, (long)tx); |
1592 | return -1; | 1583 | return -1; |
@@ -1595,16 +1586,15 @@ static int prog_page(struct nandsim *ns, int num) | |||
1595 | for (i = 0; i < num; i++) | 1586 | for (i = 0; i < num; i++) |
1596 | pg_off[i] &= ns->buf.byte[i]; | 1587 | pg_off[i] &= ns->buf.byte[i]; |
1597 | if (all) { | 1588 | if (all) { |
1598 | pos = (loff_t)ns->regs.row * ns->geom.pgszoob; | 1589 | loff_t pos = (loff_t)ns->regs.row * ns->geom.pgszoob; |
1599 | tx = write_file(ns, ns->cfile, ns->file_buf, ns->geom.pgszoob, &pos); | 1590 | tx = write_file(ns, ns->cfile, ns->file_buf, ns->geom.pgszoob, pos); |
1600 | if (tx != ns->geom.pgszoob) { | 1591 | if (tx != ns->geom.pgszoob) { |
1601 | NS_ERR("prog_page: write error for page %d ret %ld\n", ns->regs.row, (long)tx); | 1592 | NS_ERR("prog_page: write error for page %d ret %ld\n", ns->regs.row, (long)tx); |
1602 | return -1; | 1593 | return -1; |
1603 | } | 1594 | } |
1604 | ns->pages_written[ns->regs.row] = 1; | 1595 | ns->pages_written[ns->regs.row] = 1; |
1605 | } else { | 1596 | } else { |
1606 | pos = off; | 1597 | tx = write_file(ns, ns->cfile, pg_off, num, off); |
1607 | tx = write_file(ns, ns->cfile, pg_off, num, &pos); | ||
1608 | if (tx != num) { | 1598 | if (tx != num) { |
1609 | NS_ERR("prog_page: write error for page %d ret %ld\n", ns->regs.row, (long)tx); | 1599 | NS_ERR("prog_page: write error for page %d ret %ld\n", ns->regs.row, (long)tx); |
1610 | return -1; | 1600 | return -1; |
diff --git a/fs/ecryptfs/read_write.c b/fs/ecryptfs/read_write.c index b2a34a192f4f..6a160539cd23 100644 --- a/fs/ecryptfs/read_write.c +++ b/fs/ecryptfs/read_write.c | |||
@@ -40,16 +40,12 @@ int ecryptfs_write_lower(struct inode *ecryptfs_inode, char *data, | |||
40 | loff_t offset, size_t size) | 40 | loff_t offset, size_t size) |
41 | { | 41 | { |
42 | struct file *lower_file; | 42 | struct file *lower_file; |
43 | mm_segment_t fs_save; | ||
44 | ssize_t rc; | 43 | ssize_t rc; |
45 | 44 | ||
46 | lower_file = ecryptfs_inode_to_private(ecryptfs_inode)->lower_file; | 45 | lower_file = ecryptfs_inode_to_private(ecryptfs_inode)->lower_file; |
47 | if (!lower_file) | 46 | if (!lower_file) |
48 | return -EIO; | 47 | return -EIO; |
49 | fs_save = get_fs(); | 48 | rc = kernel_write(lower_file, data, size, offset); |
50 | set_fs(get_ds()); | ||
51 | rc = vfs_write(lower_file, data, size, &offset); | ||
52 | set_fs(fs_save); | ||
53 | mark_inode_dirty_sync(ecryptfs_inode); | 49 | mark_inode_dirty_sync(ecryptfs_inode); |
54 | return rc; | 50 | return rc; |
55 | } | 51 | } |
diff --git a/fs/splice.c b/fs/splice.c index 963213d56403..718bd0056384 100644 --- a/fs/splice.c +++ b/fs/splice.c | |||
@@ -569,7 +569,7 @@ static ssize_t kernel_readv(struct file *file, const struct iovec *vec, | |||
569 | return res; | 569 | return res; |
570 | } | 570 | } |
571 | 571 | ||
572 | static ssize_t kernel_write(struct file *file, const char *buf, size_t count, | 572 | ssize_t kernel_write(struct file *file, const char *buf, size_t count, |
573 | loff_t pos) | 573 | loff_t pos) |
574 | { | 574 | { |
575 | mm_segment_t old_fs; | 575 | mm_segment_t old_fs; |
@@ -578,11 +578,12 @@ static ssize_t kernel_write(struct file *file, const char *buf, size_t count, | |||
578 | old_fs = get_fs(); | 578 | old_fs = get_fs(); |
579 | set_fs(get_ds()); | 579 | set_fs(get_ds()); |
580 | /* The cast to a user pointer is valid due to the set_fs() */ | 580 | /* The cast to a user pointer is valid due to the set_fs() */ |
581 | res = vfs_write(file, (const char __user *)buf, count, &pos); | 581 | res = vfs_write(file, (__force const char __user *)buf, count, &pos); |
582 | set_fs(old_fs); | 582 | set_fs(old_fs); |
583 | 583 | ||
584 | return res; | 584 | return res; |
585 | } | 585 | } |
586 | EXPORT_SYMBOL(kernel_write); | ||
586 | 587 | ||
587 | ssize_t default_file_splice_read(struct file *in, loff_t *ppos, | 588 | ssize_t default_file_splice_read(struct file *in, loff_t *ppos, |
588 | struct pipe_inode_info *pipe, size_t len, | 589 | struct pipe_inode_info *pipe, size_t len, |
diff --git a/include/linux/fs.h b/include/linux/fs.h index c766afd1e684..d858363a7c17 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h | |||
@@ -2277,6 +2277,7 @@ static inline void i_readcount_inc(struct inode *inode) | |||
2277 | extern int do_pipe_flags(int *, int); | 2277 | extern int do_pipe_flags(int *, int); |
2278 | 2278 | ||
2279 | extern int kernel_read(struct file *, loff_t, char *, unsigned long); | 2279 | extern int kernel_read(struct file *, loff_t, char *, unsigned long); |
2280 | extern ssize_t kernel_write(struct file *, const char *, size_t, loff_t); | ||
2280 | extern struct file * open_exec(const char *); | 2281 | extern struct file * open_exec(const char *); |
2281 | 2282 | ||
2282 | /* fs/dcache.c -- generic fs support functions */ | 2283 | /* fs/dcache.c -- generic fs support functions */ |
diff --git a/kernel/sysctl_binary.c b/kernel/sysctl_binary.c index 5a6384450501..37f240fec37a 100644 --- a/kernel/sysctl_binary.c +++ b/kernel/sysctl_binary.c | |||
@@ -971,7 +971,6 @@ out: | |||
971 | static ssize_t bin_intvec(struct file *file, | 971 | static ssize_t bin_intvec(struct file *file, |
972 | void __user *oldval, size_t oldlen, void __user *newval, size_t newlen) | 972 | void __user *oldval, size_t oldlen, void __user *newval, size_t newlen) |
973 | { | 973 | { |
974 | mm_segment_t old_fs = get_fs(); | ||
975 | ssize_t copied = 0; | 974 | ssize_t copied = 0; |
976 | char *buffer; | 975 | char *buffer; |
977 | ssize_t result; | 976 | ssize_t result; |
@@ -984,13 +983,10 @@ static ssize_t bin_intvec(struct file *file, | |||
984 | if (oldval && oldlen) { | 983 | if (oldval && oldlen) { |
985 | unsigned __user *vec = oldval; | 984 | unsigned __user *vec = oldval; |
986 | size_t length = oldlen / sizeof(*vec); | 985 | size_t length = oldlen / sizeof(*vec); |
987 | loff_t pos = 0; | ||
988 | char *str, *end; | 986 | char *str, *end; |
989 | int i; | 987 | int i; |
990 | 988 | ||
991 | set_fs(KERNEL_DS); | 989 | result = kernel_read(file, 0, buffer, BUFSZ - 1); |
992 | result = vfs_read(file, buffer, BUFSZ - 1, &pos); | ||
993 | set_fs(old_fs); | ||
994 | if (result < 0) | 990 | if (result < 0) |
995 | goto out_kfree; | 991 | goto out_kfree; |
996 | 992 | ||
@@ -1017,7 +1013,6 @@ static ssize_t bin_intvec(struct file *file, | |||
1017 | if (newval && newlen) { | 1013 | if (newval && newlen) { |
1018 | unsigned __user *vec = newval; | 1014 | unsigned __user *vec = newval; |
1019 | size_t length = newlen / sizeof(*vec); | 1015 | size_t length = newlen / sizeof(*vec); |
1020 | loff_t pos = 0; | ||
1021 | char *str, *end; | 1016 | char *str, *end; |
1022 | int i; | 1017 | int i; |
1023 | 1018 | ||
@@ -1033,9 +1028,7 @@ static ssize_t bin_intvec(struct file *file, | |||
1033 | str += snprintf(str, end - str, "%lu\t", value); | 1028 | str += snprintf(str, end - str, "%lu\t", value); |
1034 | } | 1029 | } |
1035 | 1030 | ||
1036 | set_fs(KERNEL_DS); | 1031 | result = kernel_write(file, buffer, str - buffer, 0); |
1037 | result = vfs_write(file, buffer, str - buffer, &pos); | ||
1038 | set_fs(old_fs); | ||
1039 | if (result < 0) | 1032 | if (result < 0) |
1040 | goto out_kfree; | 1033 | goto out_kfree; |
1041 | } | 1034 | } |
@@ -1049,7 +1042,6 @@ out: | |||
1049 | static ssize_t bin_ulongvec(struct file *file, | 1042 | static ssize_t bin_ulongvec(struct file *file, |
1050 | void __user *oldval, size_t oldlen, void __user *newval, size_t newlen) | 1043 | void __user *oldval, size_t oldlen, void __user *newval, size_t newlen) |
1051 | { | 1044 | { |
1052 | mm_segment_t old_fs = get_fs(); | ||
1053 | ssize_t copied = 0; | 1045 | ssize_t copied = 0; |
1054 | char *buffer; | 1046 | char *buffer; |
1055 | ssize_t result; | 1047 | ssize_t result; |
@@ -1062,13 +1054,10 @@ static ssize_t bin_ulongvec(struct file *file, | |||
1062 | if (oldval && oldlen) { | 1054 | if (oldval && oldlen) { |
1063 | unsigned long __user *vec = oldval; | 1055 | unsigned long __user *vec = oldval; |
1064 | size_t length = oldlen / sizeof(*vec); | 1056 | size_t length = oldlen / sizeof(*vec); |
1065 | loff_t pos = 0; | ||
1066 | char *str, *end; | 1057 | char *str, *end; |
1067 | int i; | 1058 | int i; |
1068 | 1059 | ||
1069 | set_fs(KERNEL_DS); | 1060 | result = kernel_read(file, 0, buffer, BUFSZ - 1); |
1070 | result = vfs_read(file, buffer, BUFSZ - 1, &pos); | ||
1071 | set_fs(old_fs); | ||
1072 | if (result < 0) | 1061 | if (result < 0) |
1073 | goto out_kfree; | 1062 | goto out_kfree; |
1074 | 1063 | ||
@@ -1095,7 +1084,6 @@ static ssize_t bin_ulongvec(struct file *file, | |||
1095 | if (newval && newlen) { | 1084 | if (newval && newlen) { |
1096 | unsigned long __user *vec = newval; | 1085 | unsigned long __user *vec = newval; |
1097 | size_t length = newlen / sizeof(*vec); | 1086 | size_t length = newlen / sizeof(*vec); |
1098 | loff_t pos = 0; | ||
1099 | char *str, *end; | 1087 | char *str, *end; |
1100 | int i; | 1088 | int i; |
1101 | 1089 | ||
@@ -1111,9 +1099,7 @@ static ssize_t bin_ulongvec(struct file *file, | |||
1111 | str += snprintf(str, end - str, "%lu\t", value); | 1099 | str += snprintf(str, end - str, "%lu\t", value); |
1112 | } | 1100 | } |
1113 | 1101 | ||
1114 | set_fs(KERNEL_DS); | 1102 | result = kernel_write(file, buffer, str - buffer, 0); |
1115 | result = vfs_write(file, buffer, str - buffer, &pos); | ||
1116 | set_fs(old_fs); | ||
1117 | if (result < 0) | 1103 | if (result < 0) |
1118 | goto out_kfree; | 1104 | goto out_kfree; |
1119 | } | 1105 | } |
@@ -1127,19 +1113,15 @@ out: | |||
1127 | static ssize_t bin_uuid(struct file *file, | 1113 | static ssize_t bin_uuid(struct file *file, |
1128 | void __user *oldval, size_t oldlen, void __user *newval, size_t newlen) | 1114 | void __user *oldval, size_t oldlen, void __user *newval, size_t newlen) |
1129 | { | 1115 | { |
1130 | mm_segment_t old_fs = get_fs(); | ||
1131 | ssize_t result, copied = 0; | 1116 | ssize_t result, copied = 0; |
1132 | 1117 | ||
1133 | /* Only supports reads */ | 1118 | /* Only supports reads */ |
1134 | if (oldval && oldlen) { | 1119 | if (oldval && oldlen) { |
1135 | loff_t pos = 0; | ||
1136 | char buf[40], *str = buf; | 1120 | char buf[40], *str = buf; |
1137 | unsigned char uuid[16]; | 1121 | unsigned char uuid[16]; |
1138 | int i; | 1122 | int i; |
1139 | 1123 | ||
1140 | set_fs(KERNEL_DS); | 1124 | result = kernel_read(file, 0, buf, sizeof(buf) - 1); |
1141 | result = vfs_read(file, buf, sizeof(buf) - 1, &pos); | ||
1142 | set_fs(old_fs); | ||
1143 | if (result < 0) | 1125 | if (result < 0) |
1144 | goto out; | 1126 | goto out; |
1145 | 1127 | ||
@@ -1175,18 +1157,14 @@ out: | |||
1175 | static ssize_t bin_dn_node_address(struct file *file, | 1157 | static ssize_t bin_dn_node_address(struct file *file, |
1176 | void __user *oldval, size_t oldlen, void __user *newval, size_t newlen) | 1158 | void __user *oldval, size_t oldlen, void __user *newval, size_t newlen) |
1177 | { | 1159 | { |
1178 | mm_segment_t old_fs = get_fs(); | ||
1179 | ssize_t result, copied = 0; | 1160 | ssize_t result, copied = 0; |
1180 | 1161 | ||
1181 | if (oldval && oldlen) { | 1162 | if (oldval && oldlen) { |
1182 | loff_t pos = 0; | ||
1183 | char buf[15], *nodep; | 1163 | char buf[15], *nodep; |
1184 | unsigned long area, node; | 1164 | unsigned long area, node; |
1185 | __le16 dnaddr; | 1165 | __le16 dnaddr; |
1186 | 1166 | ||
1187 | set_fs(KERNEL_DS); | 1167 | result = kernel_read(file, 0, buf, sizeof(buf) - 1); |
1188 | result = vfs_read(file, buf, sizeof(buf) - 1, &pos); | ||
1189 | set_fs(old_fs); | ||
1190 | if (result < 0) | 1168 | if (result < 0) |
1191 | goto out; | 1169 | goto out; |
1192 | 1170 | ||
@@ -1215,7 +1193,6 @@ static ssize_t bin_dn_node_address(struct file *file, | |||
1215 | } | 1193 | } |
1216 | 1194 | ||
1217 | if (newval && newlen) { | 1195 | if (newval && newlen) { |
1218 | loff_t pos = 0; | ||
1219 | __le16 dnaddr; | 1196 | __le16 dnaddr; |
1220 | char buf[15]; | 1197 | char buf[15]; |
1221 | int len; | 1198 | int len; |
@@ -1232,9 +1209,7 @@ static ssize_t bin_dn_node_address(struct file *file, | |||
1232 | le16_to_cpu(dnaddr) >> 10, | 1209 | le16_to_cpu(dnaddr) >> 10, |
1233 | le16_to_cpu(dnaddr) & 0x3ff); | 1210 | le16_to_cpu(dnaddr) & 0x3ff); |
1234 | 1211 | ||
1235 | set_fs(KERNEL_DS); | 1212 | result = kernel_write(file, buf, len, 0); |
1236 | result = vfs_write(file, buf, len, &pos); | ||
1237 | set_fs(old_fs); | ||
1238 | if (result < 0) | 1213 | if (result < 0) |
1239 | goto out; | 1214 | goto out; |
1240 | } | 1215 | } |