2 * Stub functions for the default security function pointers in case no
3 * security model is loaded.
5 * Copyright (C) 2001 WireX Communications, Inc <chris@wirex.com>
6 * Copyright (C) 2001-2002 Greg Kroah-Hartman <greg@kroah.com>
7 * Copyright (C) 2001 Networks Associates Technology, Inc <ssmalley@nai.com>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
17 #include <linux/capability.h>
18 #include <linux/kernel.h>
19 #include <linux/mman.h>
20 #include <linux/pagemap.h>
21 #include <linux/swap.h>
22 #include <linux/security.h>
23 #include <linux/skbuff.h>
24 #include <linux/netlink.h>
26 #include <linux/xattr.h>
27 #include <linux/hugetlb.h>
28 #include <linux/ptrace.h>
29 #include <linux/file.h>
31 static int dummy_ptrace (struct task_struct
*parent
, struct task_struct
*child
)
36 static int dummy_capget (struct task_struct
*target
, kernel_cap_t
* effective
,
37 kernel_cap_t
* inheritable
, kernel_cap_t
* permitted
)
39 if (target
->euid
== 0) {
40 cap_set_full(*permitted
);
41 cap_set_init_eff(*effective
);
43 cap_clear(*permitted
);
44 cap_clear(*effective
);
47 cap_clear(*inheritable
);
49 if (target
->fsuid
!= 0) {
50 *permitted
= cap_drop_fs_set(*permitted
);
51 *effective
= cap_drop_fs_set(*effective
);
56 static int dummy_capset_check (struct task_struct
*target
,
57 kernel_cap_t
* effective
,
58 kernel_cap_t
* inheritable
,
59 kernel_cap_t
* permitted
)
64 static void dummy_capset_set (struct task_struct
*target
,
65 kernel_cap_t
* effective
,
66 kernel_cap_t
* inheritable
,
67 kernel_cap_t
* permitted
)
72 static int dummy_acct (struct file
*file
)
77 static int dummy_capable (struct task_struct
*tsk
, int cap
)
79 if (cap_raised (tsk
->cap_effective
, cap
))
84 static int dummy_sysctl (ctl_table
* table
, int op
)
89 static int dummy_quotactl (int cmds
, int type
, int id
, struct super_block
*sb
)
94 static int dummy_quota_on (struct dentry
*dentry
)
99 static int dummy_syslog (int type
)
101 if ((type
!= 3 && type
!= 10) && current
->euid
)
106 static int dummy_settime(struct timespec
*ts
, struct timezone
*tz
)
108 if (!capable(CAP_SYS_TIME
))
113 static int dummy_vm_enough_memory(struct mm_struct
*mm
, long pages
)
115 int cap_sys_admin
= 0;
117 if (dummy_capable(current
, CAP_SYS_ADMIN
) == 0)
119 return __vm_enough_memory(mm
, pages
, cap_sys_admin
);
122 static int dummy_bprm_alloc_security (struct linux_binprm
*bprm
)
127 static void dummy_bprm_free_security (struct linux_binprm
*bprm
)
132 static void dummy_bprm_apply_creds (struct linux_binprm
*bprm
, int unsafe
)
134 if (bprm
->e_uid
!= current
->uid
|| bprm
->e_gid
!= current
->gid
) {
135 set_dumpable(current
->mm
, suid_dumpable
);
137 if ((unsafe
& ~LSM_UNSAFE_PTRACE_CAP
) && !capable(CAP_SETUID
)) {
138 bprm
->e_uid
= current
->uid
;
139 bprm
->e_gid
= current
->gid
;
143 current
->suid
= current
->euid
= current
->fsuid
= bprm
->e_uid
;
144 current
->sgid
= current
->egid
= current
->fsgid
= bprm
->e_gid
;
146 dummy_capget(current
, ¤t
->cap_effective
, ¤t
->cap_inheritable
, ¤t
->cap_permitted
);
149 static void dummy_bprm_post_apply_creds (struct linux_binprm
*bprm
)
154 static int dummy_bprm_set_security (struct linux_binprm
*bprm
)
159 static int dummy_bprm_check_security (struct linux_binprm
*bprm
)
164 static int dummy_bprm_secureexec (struct linux_binprm
*bprm
)
166 /* The new userland will simply use the value provided
167 in the AT_SECURE field to decide whether secure mode
168 is required. Hence, this logic is required to preserve
169 the legacy decision algorithm used by the old userland. */
170 return (current
->euid
!= current
->uid
||
171 current
->egid
!= current
->gid
);
174 static int dummy_sb_alloc_security (struct super_block
*sb
)
179 static void dummy_sb_free_security (struct super_block
*sb
)
184 static int dummy_sb_copy_data (struct file_system_type
*type
,
185 void *orig
, void *copy
)
190 static int dummy_sb_kern_mount (struct super_block
*sb
, void *data
)
195 static int dummy_sb_statfs (struct dentry
*dentry
)
200 static int dummy_sb_mount (char *dev_name
, struct nameidata
*nd
, char *type
,
201 unsigned long flags
, void *data
)
206 static int dummy_sb_check_sb (struct vfsmount
*mnt
, struct nameidata
*nd
)
211 static int dummy_sb_umount (struct vfsmount
*mnt
, int flags
)
216 static void dummy_sb_umount_close (struct vfsmount
*mnt
)
221 static void dummy_sb_umount_busy (struct vfsmount
*mnt
)
226 static void dummy_sb_post_remount (struct vfsmount
*mnt
, unsigned long flags
,
233 static void dummy_sb_post_addmount (struct vfsmount
*mnt
, struct nameidata
*nd
)
238 static int dummy_sb_pivotroot (struct nameidata
*old_nd
, struct nameidata
*new_nd
)
243 static void dummy_sb_post_pivotroot (struct nameidata
*old_nd
, struct nameidata
*new_nd
)
248 static int dummy_sb_get_mnt_opts(const struct super_block
*sb
, char ***mount_options
,
249 int **flags
, int *num_opts
)
251 *mount_options
= NULL
;
257 static int dummy_sb_set_mnt_opts(struct super_block
*sb
, char **mount_options
,
258 int *flags
, int num_opts
)
260 if (unlikely(num_opts
))
265 static void dummy_sb_clone_mnt_opts(const struct super_block
*oldsb
,
266 struct super_block
*newsb
)
271 static int dummy_inode_alloc_security (struct inode
*inode
)
276 static void dummy_inode_free_security (struct inode
*inode
)
281 static int dummy_inode_init_security (struct inode
*inode
, struct inode
*dir
,
282 char **name
, void **value
, size_t *len
)
287 static int dummy_inode_create (struct inode
*inode
, struct dentry
*dentry
,
293 static int dummy_inode_link (struct dentry
*old_dentry
, struct inode
*inode
,
294 struct dentry
*new_dentry
)
299 static int dummy_inode_unlink (struct inode
*inode
, struct dentry
*dentry
)
304 static int dummy_inode_symlink (struct inode
*inode
, struct dentry
*dentry
,
310 static int dummy_inode_mkdir (struct inode
*inode
, struct dentry
*dentry
,
316 static int dummy_inode_rmdir (struct inode
*inode
, struct dentry
*dentry
)
321 static int dummy_inode_mknod (struct inode
*inode
, struct dentry
*dentry
,
327 static int dummy_inode_rename (struct inode
*old_inode
,
328 struct dentry
*old_dentry
,
329 struct inode
*new_inode
,
330 struct dentry
*new_dentry
)
335 static int dummy_inode_readlink (struct dentry
*dentry
)
340 static int dummy_inode_follow_link (struct dentry
*dentry
,
341 struct nameidata
*nameidata
)
346 static int dummy_inode_permission (struct inode
*inode
, int mask
, struct nameidata
*nd
)
351 static int dummy_inode_setattr (struct dentry
*dentry
, struct iattr
*iattr
)
356 static int dummy_inode_getattr (struct vfsmount
*mnt
, struct dentry
*dentry
)
361 static void dummy_inode_delete (struct inode
*ino
)
366 static int dummy_inode_setxattr (struct dentry
*dentry
, char *name
, void *value
,
367 size_t size
, int flags
)
369 if (!strncmp(name
, XATTR_SECURITY_PREFIX
,
370 sizeof(XATTR_SECURITY_PREFIX
) - 1) &&
371 !capable(CAP_SYS_ADMIN
))
376 static void dummy_inode_post_setxattr (struct dentry
*dentry
, char *name
, void *value
,
377 size_t size
, int flags
)
381 static int dummy_inode_getxattr (struct dentry
*dentry
, char *name
)
386 static int dummy_inode_listxattr (struct dentry
*dentry
)
391 static int dummy_inode_removexattr (struct dentry
*dentry
, char *name
)
393 if (!strncmp(name
, XATTR_SECURITY_PREFIX
,
394 sizeof(XATTR_SECURITY_PREFIX
) - 1) &&
395 !capable(CAP_SYS_ADMIN
))
400 static int dummy_inode_need_killpriv(struct dentry
*dentry
)
405 static int dummy_inode_killpriv(struct dentry
*dentry
)
410 static int dummy_inode_getsecurity(const struct inode
*inode
, const char *name
, void **buffer
, bool alloc
)
415 static int dummy_inode_setsecurity(struct inode
*inode
, const char *name
, const void *value
, size_t size
, int flags
)
420 static int dummy_inode_listsecurity(struct inode
*inode
, char *buffer
, size_t buffer_size
)
425 static int dummy_file_permission (struct file
*file
, int mask
)
430 static int dummy_file_alloc_security (struct file
*file
)
435 static void dummy_file_free_security (struct file
*file
)
440 static int dummy_file_ioctl (struct file
*file
, unsigned int command
,
446 static int dummy_file_mmap (struct file
*file
, unsigned long reqprot
,
450 unsigned long addr_only
)
452 if ((addr
< mmap_min_addr
) && !capable(CAP_SYS_RAWIO
))
457 static int dummy_file_mprotect (struct vm_area_struct
*vma
,
458 unsigned long reqprot
,
464 static int dummy_file_lock (struct file
*file
, unsigned int cmd
)
469 static int dummy_file_fcntl (struct file
*file
, unsigned int cmd
,
475 static int dummy_file_set_fowner (struct file
*file
)
480 static int dummy_file_send_sigiotask (struct task_struct
*tsk
,
481 struct fown_struct
*fown
, int sig
)
486 static int dummy_file_receive (struct file
*file
)
491 static int dummy_dentry_open (struct file
*file
)
496 static int dummy_task_create (unsigned long clone_flags
)
501 static int dummy_task_alloc_security (struct task_struct
*p
)
506 static void dummy_task_free_security (struct task_struct
*p
)
511 static int dummy_task_setuid (uid_t id0
, uid_t id1
, uid_t id2
, int flags
)
516 static int dummy_task_post_setuid (uid_t id0
, uid_t id1
, uid_t id2
, int flags
)
518 dummy_capget(current
, ¤t
->cap_effective
, ¤t
->cap_inheritable
, ¤t
->cap_permitted
);
522 static int dummy_task_setgid (gid_t id0
, gid_t id1
, gid_t id2
, int flags
)
527 static int dummy_task_setpgid (struct task_struct
*p
, pid_t pgid
)
532 static int dummy_task_getpgid (struct task_struct
*p
)
537 static int dummy_task_getsid (struct task_struct
*p
)
542 static void dummy_task_getsecid (struct task_struct
*p
, u32
*secid
)
545 static int dummy_task_setgroups (struct group_info
*group_info
)
550 static int dummy_task_setnice (struct task_struct
*p
, int nice
)
555 static int dummy_task_setioprio (struct task_struct
*p
, int ioprio
)
560 static int dummy_task_getioprio (struct task_struct
*p
)
565 static int dummy_task_setrlimit (unsigned int resource
, struct rlimit
*new_rlim
)
570 static int dummy_task_setscheduler (struct task_struct
*p
, int policy
,
571 struct sched_param
*lp
)
576 static int dummy_task_getscheduler (struct task_struct
*p
)
581 static int dummy_task_movememory (struct task_struct
*p
)
586 static int dummy_task_wait (struct task_struct
*p
)
591 static int dummy_task_kill (struct task_struct
*p
, struct siginfo
*info
,
597 static int dummy_task_prctl (int option
, unsigned long arg2
, unsigned long arg3
,
598 unsigned long arg4
, unsigned long arg5
)
603 static void dummy_task_reparent_to_init (struct task_struct
*p
)
605 p
->euid
= p
->fsuid
= 0;
609 static void dummy_task_to_inode(struct task_struct
*p
, struct inode
*inode
)
612 static int dummy_ipc_permission (struct kern_ipc_perm
*ipcp
, short flag
)
617 static int dummy_msg_msg_alloc_security (struct msg_msg
*msg
)
622 static void dummy_msg_msg_free_security (struct msg_msg
*msg
)
627 static int dummy_msg_queue_alloc_security (struct msg_queue
*msq
)
632 static void dummy_msg_queue_free_security (struct msg_queue
*msq
)
637 static int dummy_msg_queue_associate (struct msg_queue
*msq
,
643 static int dummy_msg_queue_msgctl (struct msg_queue
*msq
, int cmd
)
648 static int dummy_msg_queue_msgsnd (struct msg_queue
*msq
, struct msg_msg
*msg
,
654 static int dummy_msg_queue_msgrcv (struct msg_queue
*msq
, struct msg_msg
*msg
,
655 struct task_struct
*target
, long type
,
661 static int dummy_shm_alloc_security (struct shmid_kernel
*shp
)
666 static void dummy_shm_free_security (struct shmid_kernel
*shp
)
671 static int dummy_shm_associate (struct shmid_kernel
*shp
, int shmflg
)
676 static int dummy_shm_shmctl (struct shmid_kernel
*shp
, int cmd
)
681 static int dummy_shm_shmat (struct shmid_kernel
*shp
, char __user
*shmaddr
,
687 static int dummy_sem_alloc_security (struct sem_array
*sma
)
692 static void dummy_sem_free_security (struct sem_array
*sma
)
697 static int dummy_sem_associate (struct sem_array
*sma
, int semflg
)
702 static int dummy_sem_semctl (struct sem_array
*sma
, int cmd
)
707 static int dummy_sem_semop (struct sem_array
*sma
,
708 struct sembuf
*sops
, unsigned nsops
, int alter
)
713 static int dummy_netlink_send (struct sock
*sk
, struct sk_buff
*skb
)
715 NETLINK_CB(skb
).eff_cap
= current
->cap_effective
;
719 static int dummy_netlink_recv (struct sk_buff
*skb
, int cap
)
721 if (!cap_raised (NETLINK_CB (skb
).eff_cap
, cap
))
726 #ifdef CONFIG_SECURITY_NETWORK
727 static int dummy_unix_stream_connect (struct socket
*sock
,
728 struct socket
*other
,
734 static int dummy_unix_may_send (struct socket
*sock
,
735 struct socket
*other
)
740 static int dummy_socket_create (int family
, int type
,
741 int protocol
, int kern
)
746 static int dummy_socket_post_create (struct socket
*sock
, int family
, int type
,
747 int protocol
, int kern
)
752 static int dummy_socket_bind (struct socket
*sock
, struct sockaddr
*address
,
758 static int dummy_socket_connect (struct socket
*sock
, struct sockaddr
*address
,
764 static int dummy_socket_listen (struct socket
*sock
, int backlog
)
769 static int dummy_socket_accept (struct socket
*sock
, struct socket
*newsock
)
774 static void dummy_socket_post_accept (struct socket
*sock
,
775 struct socket
*newsock
)
780 static int dummy_socket_sendmsg (struct socket
*sock
, struct msghdr
*msg
,
786 static int dummy_socket_recvmsg (struct socket
*sock
, struct msghdr
*msg
,
792 static int dummy_socket_getsockname (struct socket
*sock
)
797 static int dummy_socket_getpeername (struct socket
*sock
)
802 static int dummy_socket_setsockopt (struct socket
*sock
, int level
, int optname
)
807 static int dummy_socket_getsockopt (struct socket
*sock
, int level
, int optname
)
812 static int dummy_socket_shutdown (struct socket
*sock
, int how
)
817 static int dummy_socket_sock_rcv_skb (struct sock
*sk
, struct sk_buff
*skb
)
822 static int dummy_socket_getpeersec_stream(struct socket
*sock
, char __user
*optval
,
823 int __user
*optlen
, unsigned len
)
828 static int dummy_socket_getpeersec_dgram(struct socket
*sock
, struct sk_buff
*skb
, u32
*secid
)
833 static inline int dummy_sk_alloc_security (struct sock
*sk
, int family
, gfp_t priority
)
838 static inline void dummy_sk_free_security (struct sock
*sk
)
842 static inline void dummy_sk_clone_security (const struct sock
*sk
, struct sock
*newsk
)
846 static inline void dummy_sk_getsecid(struct sock
*sk
, u32
*secid
)
850 static inline void dummy_sock_graft(struct sock
* sk
, struct socket
*parent
)
854 static inline int dummy_inet_conn_request(struct sock
*sk
,
855 struct sk_buff
*skb
, struct request_sock
*req
)
860 static inline void dummy_inet_csk_clone(struct sock
*newsk
,
861 const struct request_sock
*req
)
865 static inline void dummy_inet_conn_established(struct sock
*sk
,
870 static inline void dummy_req_classify_flow(const struct request_sock
*req
,
874 #endif /* CONFIG_SECURITY_NETWORK */
876 #ifdef CONFIG_SECURITY_NETWORK_XFRM
877 static int dummy_xfrm_policy_alloc_security(struct xfrm_policy
*xp
,
878 struct xfrm_user_sec_ctx
*sec_ctx
)
883 static inline int dummy_xfrm_policy_clone_security(struct xfrm_policy
*old
, struct xfrm_policy
*new)
888 static void dummy_xfrm_policy_free_security(struct xfrm_policy
*xp
)
892 static int dummy_xfrm_policy_delete_security(struct xfrm_policy
*xp
)
897 static int dummy_xfrm_state_alloc_security(struct xfrm_state
*x
,
898 struct xfrm_user_sec_ctx
*sec_ctx
, u32 secid
)
903 static void dummy_xfrm_state_free_security(struct xfrm_state
*x
)
907 static int dummy_xfrm_state_delete_security(struct xfrm_state
*x
)
912 static int dummy_xfrm_policy_lookup(struct xfrm_policy
*xp
, u32 sk_sid
, u8 dir
)
917 static int dummy_xfrm_state_pol_flow_match(struct xfrm_state
*x
,
918 struct xfrm_policy
*xp
, struct flowi
*fl
)
923 static int dummy_xfrm_decode_session(struct sk_buff
*skb
, u32
*fl
, int ckall
)
928 #endif /* CONFIG_SECURITY_NETWORK_XFRM */
929 static int dummy_register_security (const char *name
, struct security_operations
*ops
)
934 static void dummy_d_instantiate (struct dentry
*dentry
, struct inode
*inode
)
939 static int dummy_getprocattr(struct task_struct
*p
, char *name
, char **value
)
944 static int dummy_setprocattr(struct task_struct
*p
, char *name
, void *value
, size_t size
)
949 static int dummy_secid_to_secctx(u32 secid
, char **secdata
, u32
*seclen
)
954 static int dummy_secctx_to_secid(char *secdata
, u32 seclen
, u32
*secid
)
959 static void dummy_release_secctx(char *secdata
, u32 seclen
)
964 static inline int dummy_key_alloc(struct key
*key
, struct task_struct
*ctx
,
970 static inline void dummy_key_free(struct key
*key
)
974 static inline int dummy_key_permission(key_ref_t key_ref
,
975 struct task_struct
*context
,
980 #endif /* CONFIG_KEYS */
982 struct security_operations dummy_security_ops
;
984 #define set_to_dummy_if_null(ops, function) \
986 if (!ops->function) { \
987 ops->function = dummy_##function; \
988 pr_debug("Had to override the " #function \
989 " security operation with the dummy one.\n");\
993 void security_fixup_ops (struct security_operations
*ops
)
995 set_to_dummy_if_null(ops
, ptrace
);
996 set_to_dummy_if_null(ops
, capget
);
997 set_to_dummy_if_null(ops
, capset_check
);
998 set_to_dummy_if_null(ops
, capset_set
);
999 set_to_dummy_if_null(ops
, acct
);
1000 set_to_dummy_if_null(ops
, capable
);
1001 set_to_dummy_if_null(ops
, quotactl
);
1002 set_to_dummy_if_null(ops
, quota_on
);
1003 set_to_dummy_if_null(ops
, sysctl
);
1004 set_to_dummy_if_null(ops
, syslog
);
1005 set_to_dummy_if_null(ops
, settime
);
1006 set_to_dummy_if_null(ops
, vm_enough_memory
);
1007 set_to_dummy_if_null(ops
, bprm_alloc_security
);
1008 set_to_dummy_if_null(ops
, bprm_free_security
);
1009 set_to_dummy_if_null(ops
, bprm_apply_creds
);
1010 set_to_dummy_if_null(ops
, bprm_post_apply_creds
);
1011 set_to_dummy_if_null(ops
, bprm_set_security
);
1012 set_to_dummy_if_null(ops
, bprm_check_security
);
1013 set_to_dummy_if_null(ops
, bprm_secureexec
);
1014 set_to_dummy_if_null(ops
, sb_alloc_security
);
1015 set_to_dummy_if_null(ops
, sb_free_security
);
1016 set_to_dummy_if_null(ops
, sb_copy_data
);
1017 set_to_dummy_if_null(ops
, sb_kern_mount
);
1018 set_to_dummy_if_null(ops
, sb_statfs
);
1019 set_to_dummy_if_null(ops
, sb_mount
);
1020 set_to_dummy_if_null(ops
, sb_check_sb
);
1021 set_to_dummy_if_null(ops
, sb_umount
);
1022 set_to_dummy_if_null(ops
, sb_umount_close
);
1023 set_to_dummy_if_null(ops
, sb_umount_busy
);
1024 set_to_dummy_if_null(ops
, sb_post_remount
);
1025 set_to_dummy_if_null(ops
, sb_post_addmount
);
1026 set_to_dummy_if_null(ops
, sb_pivotroot
);
1027 set_to_dummy_if_null(ops
, sb_post_pivotroot
);
1028 set_to_dummy_if_null(ops
, sb_get_mnt_opts
);
1029 set_to_dummy_if_null(ops
, sb_set_mnt_opts
);
1030 set_to_dummy_if_null(ops
, sb_clone_mnt_opts
);
1031 set_to_dummy_if_null(ops
, inode_alloc_security
);
1032 set_to_dummy_if_null(ops
, inode_free_security
);
1033 set_to_dummy_if_null(ops
, inode_init_security
);
1034 set_to_dummy_if_null(ops
, inode_create
);
1035 set_to_dummy_if_null(ops
, inode_link
);
1036 set_to_dummy_if_null(ops
, inode_unlink
);
1037 set_to_dummy_if_null(ops
, inode_symlink
);
1038 set_to_dummy_if_null(ops
, inode_mkdir
);
1039 set_to_dummy_if_null(ops
, inode_rmdir
);
1040 set_to_dummy_if_null(ops
, inode_mknod
);
1041 set_to_dummy_if_null(ops
, inode_rename
);
1042 set_to_dummy_if_null(ops
, inode_readlink
);
1043 set_to_dummy_if_null(ops
, inode_follow_link
);
1044 set_to_dummy_if_null(ops
, inode_permission
);
1045 set_to_dummy_if_null(ops
, inode_setattr
);
1046 set_to_dummy_if_null(ops
, inode_getattr
);
1047 set_to_dummy_if_null(ops
, inode_delete
);
1048 set_to_dummy_if_null(ops
, inode_setxattr
);
1049 set_to_dummy_if_null(ops
, inode_post_setxattr
);
1050 set_to_dummy_if_null(ops
, inode_getxattr
);
1051 set_to_dummy_if_null(ops
, inode_listxattr
);
1052 set_to_dummy_if_null(ops
, inode_removexattr
);
1053 set_to_dummy_if_null(ops
, inode_need_killpriv
);
1054 set_to_dummy_if_null(ops
, inode_killpriv
);
1055 set_to_dummy_if_null(ops
, inode_getsecurity
);
1056 set_to_dummy_if_null(ops
, inode_setsecurity
);
1057 set_to_dummy_if_null(ops
, inode_listsecurity
);
1058 set_to_dummy_if_null(ops
, file_permission
);
1059 set_to_dummy_if_null(ops
, file_alloc_security
);
1060 set_to_dummy_if_null(ops
, file_free_security
);
1061 set_to_dummy_if_null(ops
, file_ioctl
);
1062 set_to_dummy_if_null(ops
, file_mmap
);
1063 set_to_dummy_if_null(ops
, file_mprotect
);
1064 set_to_dummy_if_null(ops
, file_lock
);
1065 set_to_dummy_if_null(ops
, file_fcntl
);
1066 set_to_dummy_if_null(ops
, file_set_fowner
);
1067 set_to_dummy_if_null(ops
, file_send_sigiotask
);
1068 set_to_dummy_if_null(ops
, file_receive
);
1069 set_to_dummy_if_null(ops
, dentry_open
);
1070 set_to_dummy_if_null(ops
, task_create
);
1071 set_to_dummy_if_null(ops
, task_alloc_security
);
1072 set_to_dummy_if_null(ops
, task_free_security
);
1073 set_to_dummy_if_null(ops
, task_setuid
);
1074 set_to_dummy_if_null(ops
, task_post_setuid
);
1075 set_to_dummy_if_null(ops
, task_setgid
);
1076 set_to_dummy_if_null(ops
, task_setpgid
);
1077 set_to_dummy_if_null(ops
, task_getpgid
);
1078 set_to_dummy_if_null(ops
, task_getsid
);
1079 set_to_dummy_if_null(ops
, task_getsecid
);
1080 set_to_dummy_if_null(ops
, task_setgroups
);
1081 set_to_dummy_if_null(ops
, task_setnice
);
1082 set_to_dummy_if_null(ops
, task_setioprio
);
1083 set_to_dummy_if_null(ops
, task_getioprio
);
1084 set_to_dummy_if_null(ops
, task_setrlimit
);
1085 set_to_dummy_if_null(ops
, task_setscheduler
);
1086 set_to_dummy_if_null(ops
, task_getscheduler
);
1087 set_to_dummy_if_null(ops
, task_movememory
);
1088 set_to_dummy_if_null(ops
, task_wait
);
1089 set_to_dummy_if_null(ops
, task_kill
);
1090 set_to_dummy_if_null(ops
, task_prctl
);
1091 set_to_dummy_if_null(ops
, task_reparent_to_init
);
1092 set_to_dummy_if_null(ops
, task_to_inode
);
1093 set_to_dummy_if_null(ops
, ipc_permission
);
1094 set_to_dummy_if_null(ops
, msg_msg_alloc_security
);
1095 set_to_dummy_if_null(ops
, msg_msg_free_security
);
1096 set_to_dummy_if_null(ops
, msg_queue_alloc_security
);
1097 set_to_dummy_if_null(ops
, msg_queue_free_security
);
1098 set_to_dummy_if_null(ops
, msg_queue_associate
);
1099 set_to_dummy_if_null(ops
, msg_queue_msgctl
);
1100 set_to_dummy_if_null(ops
, msg_queue_msgsnd
);
1101 set_to_dummy_if_null(ops
, msg_queue_msgrcv
);
1102 set_to_dummy_if_null(ops
, shm_alloc_security
);
1103 set_to_dummy_if_null(ops
, shm_free_security
);
1104 set_to_dummy_if_null(ops
, shm_associate
);
1105 set_to_dummy_if_null(ops
, shm_shmctl
);
1106 set_to_dummy_if_null(ops
, shm_shmat
);
1107 set_to_dummy_if_null(ops
, sem_alloc_security
);
1108 set_to_dummy_if_null(ops
, sem_free_security
);
1109 set_to_dummy_if_null(ops
, sem_associate
);
1110 set_to_dummy_if_null(ops
, sem_semctl
);
1111 set_to_dummy_if_null(ops
, sem_semop
);
1112 set_to_dummy_if_null(ops
, netlink_send
);
1113 set_to_dummy_if_null(ops
, netlink_recv
);
1114 set_to_dummy_if_null(ops
, register_security
);
1115 set_to_dummy_if_null(ops
, d_instantiate
);
1116 set_to_dummy_if_null(ops
, getprocattr
);
1117 set_to_dummy_if_null(ops
, setprocattr
);
1118 set_to_dummy_if_null(ops
, secid_to_secctx
);
1119 set_to_dummy_if_null(ops
, secctx_to_secid
);
1120 set_to_dummy_if_null(ops
, release_secctx
);
1121 #ifdef CONFIG_SECURITY_NETWORK
1122 set_to_dummy_if_null(ops
, unix_stream_connect
);
1123 set_to_dummy_if_null(ops
, unix_may_send
);
1124 set_to_dummy_if_null(ops
, socket_create
);
1125 set_to_dummy_if_null(ops
, socket_post_create
);
1126 set_to_dummy_if_null(ops
, socket_bind
);
1127 set_to_dummy_if_null(ops
, socket_connect
);
1128 set_to_dummy_if_null(ops
, socket_listen
);
1129 set_to_dummy_if_null(ops
, socket_accept
);
1130 set_to_dummy_if_null(ops
, socket_post_accept
);
1131 set_to_dummy_if_null(ops
, socket_sendmsg
);
1132 set_to_dummy_if_null(ops
, socket_recvmsg
);
1133 set_to_dummy_if_null(ops
, socket_getsockname
);
1134 set_to_dummy_if_null(ops
, socket_getpeername
);
1135 set_to_dummy_if_null(ops
, socket_setsockopt
);
1136 set_to_dummy_if_null(ops
, socket_getsockopt
);
1137 set_to_dummy_if_null(ops
, socket_shutdown
);
1138 set_to_dummy_if_null(ops
, socket_sock_rcv_skb
);
1139 set_to_dummy_if_null(ops
, socket_getpeersec_stream
);
1140 set_to_dummy_if_null(ops
, socket_getpeersec_dgram
);
1141 set_to_dummy_if_null(ops
, sk_alloc_security
);
1142 set_to_dummy_if_null(ops
, sk_free_security
);
1143 set_to_dummy_if_null(ops
, sk_clone_security
);
1144 set_to_dummy_if_null(ops
, sk_getsecid
);
1145 set_to_dummy_if_null(ops
, sock_graft
);
1146 set_to_dummy_if_null(ops
, inet_conn_request
);
1147 set_to_dummy_if_null(ops
, inet_csk_clone
);
1148 set_to_dummy_if_null(ops
, inet_conn_established
);
1149 set_to_dummy_if_null(ops
, req_classify_flow
);
1150 #endif /* CONFIG_SECURITY_NETWORK */
1151 #ifdef CONFIG_SECURITY_NETWORK_XFRM
1152 set_to_dummy_if_null(ops
, xfrm_policy_alloc_security
);
1153 set_to_dummy_if_null(ops
, xfrm_policy_clone_security
);
1154 set_to_dummy_if_null(ops
, xfrm_policy_free_security
);
1155 set_to_dummy_if_null(ops
, xfrm_policy_delete_security
);
1156 set_to_dummy_if_null(ops
, xfrm_state_alloc_security
);
1157 set_to_dummy_if_null(ops
, xfrm_state_free_security
);
1158 set_to_dummy_if_null(ops
, xfrm_state_delete_security
);
1159 set_to_dummy_if_null(ops
, xfrm_policy_lookup
);
1160 set_to_dummy_if_null(ops
, xfrm_state_pol_flow_match
);
1161 set_to_dummy_if_null(ops
, xfrm_decode_session
);
1162 #endif /* CONFIG_SECURITY_NETWORK_XFRM */
1164 set_to_dummy_if_null(ops
, key_alloc
);
1165 set_to_dummy_if_null(ops
, key_free
);
1166 set_to_dummy_if_null(ops
, key_permission
);
1167 #endif /* CONFIG_KEYS */