Function report |
Source Code:fs\splice.c |
Create Date:2022-07-28 20:11:28 |
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
| home page | Tree |
| Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:For lack of a better implementation, implement vmsplice() to userspace* as a simple copy of the pipes pages to the user iov.
Proto:static long vmsplice_to_user(struct file *file, struct iov_iter *iter, unsigned int flags)
Type:long
Parameter:
| Type | Parameter | Name |
|---|---|---|
| struct file * | file | |
| struct iov_iter * | iter | |
| unsigned int | flags |
| 1281 | pipe = After the inode slimming patch, i_pipe/i_bdev/i_cdev share the same* location, so checking ->i_pipe is not enough to verify that this is a* pipe. |
| 1282 | struct splice_desc sd = {maining length = iov_iter_count(iter), splice flags = flags, cookie = iter} |
| 1287 | ret = 0 |
| 1292 | If maining length Then |
| 1295 | pipe_unlock(pipe) |
| 1298 | Return ret |
| Name | Describe |
|---|---|
| do_vmsplice | Note that vmsplice only really supports true splicing _from_ user memory* to a pipe, not the other way around. Splicing from user memory is a simple* operation that can be supported without any funky alignment restrictions* or nasty vm tricks |
| Source code conversion tool public plug-in interface | X |
|---|---|
| Support c/c++/esqlc/java Oracle/Informix/Mysql Plug-in can realize: logical Report Code generation and batch code conversion |