diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2019-07-17 11:58:04 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2019-07-17 11:58:04 -0400 |
commit | 57a8ec387e1441ea5e1232bc0749fb99a8cba7e7 (patch) | |
tree | b5fb03fc6bc5754de8b5b1f8b0e4f36d67c8315c /include/uapi/linux | |
parent | 0a8ad0ffa4d80a544f6cbff703bf6394339afcdf (diff) | |
parent | 43e11fa2d1d3b6e35629fa556eb7d571edba2010 (diff) |
Merge branch 'akpm' (patches from Andrew)
Merge more updates from Andrew Morton:
"VM:
- z3fold fixes and enhancements by Henry Burns and Vitaly Wool
- more accurate reclaimed slab caches calculations by Yafang Shao
- fix MAP_UNINITIALIZED UAPI symbol to not depend on config, by
Christoph Hellwig
- !CONFIG_MMU fixes by Christoph Hellwig
- new novmcoredd parameter to omit device dumps from vmcore, by
Kairui Song
- new test_meminit module for testing heap and pagealloc
initialization, by Alexander Potapenko
- ioremap improvements for huge mappings, by Anshuman Khandual
- generalize kprobe page fault handling, by Anshuman Khandual
- device-dax hotplug fixes and improvements, by Pavel Tatashin
- enable synchronous DAX fault on powerpc, by Aneesh Kumar K.V
- add pte_devmap() support for arm64, by Robin Murphy
- unify locked_vm accounting with a helper, by Daniel Jordan
- several misc fixes
core/lib:
- new typeof_member() macro including some users, by Alexey Dobriyan
- make BIT() and GENMASK() available in asm, by Masahiro Yamada
- changed LIST_POISON2 on x86_64 to 0xdead000000000122 for better
code generation, by Alexey Dobriyan
- rbtree code size optimizations, by Michel Lespinasse
- convert struct pid count to refcount_t, by Joel Fernandes
get_maintainer.pl:
- add --no-moderated switch to skip moderated ML's, by Joe Perches
misc:
- ptrace PTRACE_GET_SYSCALL_INFO interface
- coda updates
- gdb scripts, various"
[ Using merge message suggestion from Vlastimil Babka, with some editing - Linus ]
* emailed patches from Andrew Morton <akpm@linux-foundation.org>: (100 commits)
fs/select.c: use struct_size() in kmalloc()
mm: add account_locked_vm utility function
arm64: mm: implement pte_devmap support
mm: introduce ARCH_HAS_PTE_DEVMAP
mm: clean up is_device_*_page() definitions
mm/mmap: move common defines to mman-common.h
mm: move MAP_SYNC to asm-generic/mman-common.h
device-dax: "Hotremove" persistent memory that is used like normal RAM
mm/hotplug: make remove_memory() interface usable
device-dax: fix memory and resource leak if hotplug fails
include/linux/lz4.h: fix spelling and copy-paste errors in documentation
ipc/mqueue.c: only perform resource calculation if user valid
include/asm-generic/bug.h: fix "cut here" for WARN_ON for __WARN_TAINT architectures
scripts/gdb: add helpers to find and list devices
scripts/gdb: add lx-genpd-summary command
drivers/pps/pps.c: clear offset flags in PPS_SETPARAMS ioctl
kernel/pid.c: convert struct pid count to refcount_t
drivers/rapidio/devices/rio_mport_cdev.c: NUL terminate some strings
select: shift restore_saved_sigmask_unless() into poll_select_copy_remaining()
select: change do_poll() to return -ERESTARTNOHAND rather than -EINTR
...
Diffstat (limited to 'include/uapi/linux')
-rw-r--r-- | include/uapi/linux/coda.h | 56 | ||||
-rw-r--r-- | include/uapi/linux/coda_psdev.h | 28 | ||||
-rw-r--r-- | include/uapi/linux/ptrace.h | 35 |
3 files changed, 73 insertions, 46 deletions
diff --git a/include/uapi/linux/coda.h b/include/uapi/linux/coda.h index 695fade33c64..aa34c2dcae8d 100644 --- a/include/uapi/linux/coda.h +++ b/include/uapi/linux/coda.h | |||
@@ -86,10 +86,6 @@ typedef unsigned long long u_quad_t; | |||
86 | 86 | ||
87 | #define inline | 87 | #define inline |
88 | 88 | ||
89 | struct timespec { | ||
90 | long ts_sec; | ||
91 | long ts_nsec; | ||
92 | }; | ||
93 | #else /* DJGPP but not KERNEL */ | 89 | #else /* DJGPP but not KERNEL */ |
94 | #include <sys/time.h> | 90 | #include <sys/time.h> |
95 | typedef unsigned long long u_quad_t; | 91 | typedef unsigned long long u_quad_t; |
@@ -110,13 +106,6 @@ typedef unsigned long long u_quad_t; | |||
110 | #define cdev_t dev_t | 106 | #define cdev_t dev_t |
111 | #endif | 107 | #endif |
112 | 108 | ||
113 | #ifdef __CYGWIN32__ | ||
114 | struct timespec { | ||
115 | time_t tv_sec; /* seconds */ | ||
116 | long tv_nsec; /* nanoseconds */ | ||
117 | }; | ||
118 | #endif | ||
119 | |||
120 | #ifndef __BIT_TYPES_DEFINED__ | 109 | #ifndef __BIT_TYPES_DEFINED__ |
121 | #define __BIT_TYPES_DEFINED__ | 110 | #define __BIT_TYPES_DEFINED__ |
122 | typedef signed char int8_t; | 111 | typedef signed char int8_t; |
@@ -211,6 +200,11 @@ struct CodaFid { | |||
211 | */ | 200 | */ |
212 | enum coda_vtype { C_VNON, C_VREG, C_VDIR, C_VBLK, C_VCHR, C_VLNK, C_VSOCK, C_VFIFO, C_VBAD }; | 201 | enum coda_vtype { C_VNON, C_VREG, C_VDIR, C_VBLK, C_VCHR, C_VLNK, C_VSOCK, C_VFIFO, C_VBAD }; |
213 | 202 | ||
203 | struct coda_timespec { | ||
204 | int64_t tv_sec; /* seconds */ | ||
205 | long tv_nsec; /* nanoseconds */ | ||
206 | }; | ||
207 | |||
214 | struct coda_vattr { | 208 | struct coda_vattr { |
215 | long va_type; /* vnode type (for create) */ | 209 | long va_type; /* vnode type (for create) */ |
216 | u_short va_mode; /* files access mode and type */ | 210 | u_short va_mode; /* files access mode and type */ |
@@ -220,9 +214,9 @@ struct coda_vattr { | |||
220 | long va_fileid; /* file id */ | 214 | long va_fileid; /* file id */ |
221 | u_quad_t va_size; /* file size in bytes */ | 215 | u_quad_t va_size; /* file size in bytes */ |
222 | long va_blocksize; /* blocksize preferred for i/o */ | 216 | long va_blocksize; /* blocksize preferred for i/o */ |
223 | struct timespec va_atime; /* time of last access */ | 217 | struct coda_timespec va_atime; /* time of last access */ |
224 | struct timespec va_mtime; /* time of last modification */ | 218 | struct coda_timespec va_mtime; /* time of last modification */ |
225 | struct timespec va_ctime; /* time file changed */ | 219 | struct coda_timespec va_ctime; /* time file changed */ |
226 | u_long va_gen; /* generation number of file */ | 220 | u_long va_gen; /* generation number of file */ |
227 | u_long va_flags; /* flags defined for file */ | 221 | u_long va_flags; /* flags defined for file */ |
228 | cdev_t va_rdev; /* device special file represents */ | 222 | cdev_t va_rdev; /* device special file represents */ |
@@ -277,7 +271,8 @@ struct coda_statfs { | |||
277 | #define CODA_STATFS 34 | 271 | #define CODA_STATFS 34 |
278 | #define CODA_STORE 35 | 272 | #define CODA_STORE 35 |
279 | #define CODA_RELEASE 36 | 273 | #define CODA_RELEASE 36 |
280 | #define CODA_NCALLS 37 | 274 | #define CODA_ACCESS_INTENT 37 |
275 | #define CODA_NCALLS 38 | ||
281 | 276 | ||
282 | #define DOWNCALL(opcode) (opcode >= CODA_REPLACE && opcode <= CODA_PURGEFID) | 277 | #define DOWNCALL(opcode) (opcode >= CODA_REPLACE && opcode <= CODA_PURGEFID) |
283 | 278 | ||
@@ -287,7 +282,12 @@ struct coda_statfs { | |||
287 | 282 | ||
288 | #define CIOC_KERNEL_VERSION _IOWR('c', 10, size_t) | 283 | #define CIOC_KERNEL_VERSION _IOWR('c', 10, size_t) |
289 | 284 | ||
290 | #define CODA_KERNEL_VERSION 3 /* 128-bit file identifiers */ | 285 | // CODA_KERNEL_VERSION 0 /* don't care about kernel version number */ |
286 | // CODA_KERNEL_VERSION 1 /* The old venus 4.6 compatible interface */ | ||
287 | // CODA_KERNEL_VERSION 2 /* venus_lookup gets an extra parameter */ | ||
288 | // CODA_KERNEL_VERSION 3 /* 128-bit file identifiers */ | ||
289 | // CODA_KERNEL_VERSION 4 /* 64-bit timespec */ | ||
290 | #define CODA_KERNEL_VERSION 5 /* access intent support */ | ||
291 | 291 | ||
292 | /* | 292 | /* |
293 | * Venus <-> Coda RPC arguments | 293 | * Venus <-> Coda RPC arguments |
@@ -295,8 +295,8 @@ struct coda_statfs { | |||
295 | struct coda_in_hdr { | 295 | struct coda_in_hdr { |
296 | u_int32_t opcode; | 296 | u_int32_t opcode; |
297 | u_int32_t unique; /* Keep multiple outstanding msgs distinct */ | 297 | u_int32_t unique; /* Keep multiple outstanding msgs distinct */ |
298 | pid_t pid; | 298 | __kernel_pid_t pid; |
299 | pid_t pgid; | 299 | __kernel_pid_t pgid; |
300 | vuid_t uid; | 300 | vuid_t uid; |
301 | }; | 301 | }; |
302 | 302 | ||
@@ -642,6 +642,25 @@ struct coda_statfs_out { | |||
642 | struct coda_statfs stat; | 642 | struct coda_statfs stat; |
643 | }; | 643 | }; |
644 | 644 | ||
645 | #define CODA_ACCESS_TYPE_READ 1 | ||
646 | #define CODA_ACCESS_TYPE_WRITE 2 | ||
647 | #define CODA_ACCESS_TYPE_MMAP 3 | ||
648 | #define CODA_ACCESS_TYPE_READ_FINISH 4 | ||
649 | #define CODA_ACCESS_TYPE_WRITE_FINISH 5 | ||
650 | |||
651 | /* coda_access_intent: NO_OUT */ | ||
652 | struct coda_access_intent_in { | ||
653 | struct coda_in_hdr ih; | ||
654 | struct CodaFid VFid; | ||
655 | int count; | ||
656 | int pos; | ||
657 | int type; | ||
658 | }; | ||
659 | |||
660 | struct coda_access_intent_out { | ||
661 | struct coda_out_hdr out; | ||
662 | }; | ||
663 | |||
645 | /* | 664 | /* |
646 | * Occasionally, we don't cache the fid returned by CODA_LOOKUP. | 665 | * Occasionally, we don't cache the fid returned by CODA_LOOKUP. |
647 | * For instance, if the fid is inconsistent. | 666 | * For instance, if the fid is inconsistent. |
@@ -673,6 +692,7 @@ union inputArgs { | |||
673 | struct coda_open_by_fd_in coda_open_by_fd; | 692 | struct coda_open_by_fd_in coda_open_by_fd; |
674 | struct coda_open_by_path_in coda_open_by_path; | 693 | struct coda_open_by_path_in coda_open_by_path; |
675 | struct coda_statfs_in coda_statfs; | 694 | struct coda_statfs_in coda_statfs; |
695 | struct coda_access_intent_in coda_access_intent; | ||
676 | }; | 696 | }; |
677 | 697 | ||
678 | union outputArgs { | 698 | union outputArgs { |
diff --git a/include/uapi/linux/coda_psdev.h b/include/uapi/linux/coda_psdev.h deleted file mode 100644 index aa6623efd2dd..000000000000 --- a/include/uapi/linux/coda_psdev.h +++ /dev/null | |||
@@ -1,28 +0,0 @@ | |||
1 | /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ | ||
2 | #ifndef _UAPI__CODA_PSDEV_H | ||
3 | #define _UAPI__CODA_PSDEV_H | ||
4 | |||
5 | #include <linux/magic.h> | ||
6 | |||
7 | #define CODA_PSDEV_MAJOR 67 | ||
8 | #define MAX_CODADEVS 5 /* how many do we allow */ | ||
9 | |||
10 | |||
11 | /* messages between coda filesystem in kernel and Venus */ | ||
12 | struct upc_req { | ||
13 | struct list_head uc_chain; | ||
14 | caddr_t uc_data; | ||
15 | u_short uc_flags; | ||
16 | u_short uc_inSize; /* Size is at most 5000 bytes */ | ||
17 | u_short uc_outSize; | ||
18 | u_short uc_opcode; /* copied from data to save lookup */ | ||
19 | int uc_unique; | ||
20 | wait_queue_head_t uc_sleep; /* process' wait queue */ | ||
21 | }; | ||
22 | |||
23 | #define CODA_REQ_ASYNC 0x1 | ||
24 | #define CODA_REQ_READ 0x2 | ||
25 | #define CODA_REQ_WRITE 0x4 | ||
26 | #define CODA_REQ_ABORT 0x8 | ||
27 | |||
28 | #endif /* _UAPI__CODA_PSDEV_H */ | ||
diff --git a/include/uapi/linux/ptrace.h b/include/uapi/linux/ptrace.h index d5a1b8a492b9..a71b6e3b03eb 100644 --- a/include/uapi/linux/ptrace.h +++ b/include/uapi/linux/ptrace.h | |||
@@ -73,6 +73,41 @@ struct seccomp_metadata { | |||
73 | __u64 flags; /* Output: filter's flags */ | 73 | __u64 flags; /* Output: filter's flags */ |
74 | }; | 74 | }; |
75 | 75 | ||
76 | #define PTRACE_GET_SYSCALL_INFO 0x420e | ||
77 | #define PTRACE_SYSCALL_INFO_NONE 0 | ||
78 | #define PTRACE_SYSCALL_INFO_ENTRY 1 | ||
79 | #define PTRACE_SYSCALL_INFO_EXIT 2 | ||
80 | #define PTRACE_SYSCALL_INFO_SECCOMP 3 | ||
81 | |||
82 | struct ptrace_syscall_info { | ||
83 | __u8 op; /* PTRACE_SYSCALL_INFO_* */ | ||
84 | __u32 arch __attribute__((__aligned__(sizeof(__u32)))); | ||
85 | __u64 instruction_pointer; | ||
86 | __u64 stack_pointer; | ||
87 | union { | ||
88 | struct { | ||
89 | __u64 nr; | ||
90 | __u64 args[6]; | ||
91 | } entry; | ||
92 | struct { | ||
93 | __s64 rval; | ||
94 | __u8 is_error; | ||
95 | } exit; | ||
96 | struct { | ||
97 | __u64 nr; | ||
98 | __u64 args[6]; | ||
99 | __u32 ret_data; | ||
100 | } seccomp; | ||
101 | }; | ||
102 | }; | ||
103 | |||
104 | /* | ||
105 | * These values are stored in task->ptrace_message | ||
106 | * by tracehook_report_syscall_* to describe the current syscall-stop. | ||
107 | */ | ||
108 | #define PTRACE_EVENTMSG_SYSCALL_ENTRY 1 | ||
109 | #define PTRACE_EVENTMSG_SYSCALL_EXIT 2 | ||
110 | |||
76 | /* Read signals from a shared (process wide) queue */ | 111 | /* Read signals from a shared (process wide) queue */ |
77 | #define PTRACE_PEEKSIGINFO_SHARED (1 << 0) | 112 | #define PTRACE_PEEKSIGINFO_SHARED (1 << 0) |
78 | 113 | ||