#
08bcdc58 |
| 05-Oct-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Move all object label init/destroy routines to the head of the entry points to better match the entry point ordering in mac_policy.h. Big diff, no functional change; merge from the MAC tree.
Obtaine
Move all object label init/destroy routines to the head of the entry points to better match the entry point ordering in mac_policy.h. Big diff, no functional change; merge from the MAC tree.
Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Laboratories
show more ...
|
#
ea599aa0 |
| 05-Oct-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Synch from TrustedBSD MAC tree:
- If a policy isn't registered when a policy module unloads, silently succeed.
- Hold the policy list lock across more of the validity tests to avoid races.
Obt
Synch from TrustedBSD MAC tree:
- If a policy isn't registered when a policy module unloads, silently succeed.
- Hold the policy list lock across more of the validity tests to avoid races.
Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Laboratories
show more ...
|
#
226b96fb |
| 05-Oct-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Cosmetic line wrap synchronization.
|
#
b2f0927a |
| 05-Oct-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Push the debugging obect label counters into security.mac.debug.counters rather than directly under security.mac.debug.
Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Labo
Push the debugging obect label counters into security.mac.debug.counters rather than directly under security.mac.debug.
Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Laboratories
show more ...
|
#
96adb909 |
| 05-Oct-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Begin another merge from the TrustedBSD MAC branch:
- Change mpo_init_foo(obj, label) and mpo_destroy_foo(obj, label) policy entry points to mpo_init_foo_label(label) and mpo_destroy_foo_label(l
Begin another merge from the TrustedBSD MAC branch:
- Change mpo_init_foo(obj, label) and mpo_destroy_foo(obj, label) policy entry points to mpo_init_foo_label(label) and mpo_destroy_foo_label(label). This will permit the use of the same entry points for holding temporary type-specific label during internalization and externalization, as well as for caching purposes. - Because of this, break out mpo_{init,destroy}_socket() and mpo_{init,destroy}_mount() into seperate entry points for socket main/peer labels and mount main/fs labels. - Since the prototype for label initialization is the same across almost all entry points, implement these entry points using common implementations for Biba, MLS, and Test, reducing the number of almost identical looking functions.
This simplifies policy implementation, as well as preparing us for the merge of the new flexible userland API for managing labels on objects.
Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Laboratories
show more ...
|
#
92dbb82a |
| 02-Oct-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Add a new MAC entry point, mac_thread_userret(td), which permits policy modules to perform MAC-related events when a thread returns to user space. This is required for policies that have floating pr
Add a new MAC entry point, mac_thread_userret(td), which permits policy modules to perform MAC-related events when a thread returns to user space. This is required for policies that have floating process labels, as it's not always possible to acquire the process lock at arbitrary points in the stack during system call processing; process labels might represent traditional authentication data, process history information, or other data.
LOMAC will use this entry point to perform the process label update prior to the thread returning to userspace, when plugged into the MAC framework.
Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Laboratories
show more ...
|
#
328048bc |
| 01-Oct-2002 |
Poul-Henning Kamp <phk@FreeBSD.org> |
Remember to include "opt_devfs.h" so we get any relevant changes to NDEVFSINO before we include devfs.h.
Spotted by: FlexeLint
|
#
1aa37f53 |
| 01-Oct-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Improve locking of pipe mutexes in the context of MAC:
(1) Where previously the pipe mutex was selectively grabbed during pipe_ioctl(), now always grab it and then release if if not needed.
Improve locking of pipe mutexes in the context of MAC:
(1) Where previously the pipe mutex was selectively grabbed during pipe_ioctl(), now always grab it and then release if if not needed. This protects the call to mac_check_pipe_ioctl() to make sure the label remains consistent. (Note: it looks like sigio locking may be incorrect for fgetown() since we call it not-by-reference and sigio locking assumes call by reference).
(2) In pipe_stat(), lock the pipe if MAC is compiled in so that the call to mac_check_pipe_stat() gets a locked pipe to protect label consistency. We still release the lock before returning actual stat() data, risking inconsistency, but apparently our pipe locking model accepts that risk.
(3) In various pipe MAC authorization checks, assert that the pipe lock is held.
(4) Grab the lock when performing a pipe relabel operation, and assert it a little deeper in the stack.
Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Laboratories
show more ...
|
#
6be0c25e |
| 01-Oct-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Push 'security.mac.debug_label_fallback' behind options MAC_DEBUG.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
|
#
c031391b |
| 30-Sep-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Add tunables for the existing sysctl twiddles for pipe and vm enforcement so they can be disabled prior to kernel start.
Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Lab
Add tunables for the existing sysctl twiddles for pipe and vm enforcement so they can be disabled prior to kernel start.
Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Laboratories
show more ...
|
#
cc51a2b5 |
| 19-Sep-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Remove un-needed stack variable 'ops'.
Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Laboratories
|
#
ca7850c3 |
| 18-Sep-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Add a toggle to disable VM enforcement.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
|
#
b88c98f6 |
| 18-Sep-2002 |
Robert Watson <rwatson@FreeBSD.org> |
At the cost of seeming a little gauche, make use of more traditional alphabetization for mac_enforce_pipe sysctl.
Obtained from: TrustedBSD Project Sponsored by: DAPRA, NAI Labs
|
#
06be2aaa |
| 14-Sep-2002 |
Nate Lawson <njl@FreeBSD.org> |
Remove all use of vnode->v_tag, replacing with appropriate substitutes. v_tag is now const char * and should only be used for debugging.
Additionally: 1. All users of VT_NTS now check vfsconf->vf_ty
Remove all use of vnode->v_tag, replacing with appropriate substitutes. v_tag is now const char * and should only be used for debugging.
Additionally: 1. All users of VT_NTS now check vfsconf->vf_type VFCF_NETWORK 2. The user of VT_PROCFS now checks for the new flag VV_PROCDEP, which is propagated by pseudofs to all child vnodes if the fs sets PFS_PROCDEP.
Suggested by: phk Reviewed by: bde, rwatson (earlier version)
show more ...
|
#
c0f39905 |
| 09-Sep-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Add security.mac.mmap_revocation, a flag indicating whether we should revoke access to memory maps on a process label change.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
|
#
16140035 |
| 09-Sep-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Minor code sync to MAC tree: push Giant locking up from mac_cred_mmapped_drop_perms() to the caller.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
|
#
b656366b |
| 05-Sep-2002 |
Bruce Evans <bde@FreeBSD.org> |
Include <sys/malloc.h> instead of depending on namespace pollution 2 layers deep in <sys/proc.h> or <sys/vnode.h>.
Removed unused includes.
Fixed some printf format errors (1 fatal on i386's; 1 fat
Include <sys/malloc.h> instead of depending on namespace pollution 2 layers deep in <sys/proc.h> or <sys/vnode.h>.
Removed unused includes.
Fixed some printf format errors (1 fatal on i386's; 1 fatal on alphas; 1 not fatal on any supported machine).
show more ...
|
#
e5cb5e37 |
| 19-Aug-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Close a race in process label changing opened due to dropping the proc locking when revoking access to mmaps. Instead, perform this later once we've changed the process label (hold onto a reference
Close a race in process label changing opened due to dropping the proc locking when revoking access to mmaps. Instead, perform this later once we've changed the process label (hold onto a reference to the new cred so that we don't lose it when we release the process lock if another thread changes the credential).
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
show more ...
|
#
177142e4 |
| 19-Aug-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Pass active_cred and file_cred into the MAC framework explicitly for mac_check_vnode_{poll,read,stat,write}(). Pass in fp->f_cred when calling these checks with a struct file available. Otherwise,
Pass active_cred and file_cred into the MAC framework explicitly for mac_check_vnode_{poll,read,stat,write}(). Pass in fp->f_cred when calling these checks with a struct file available. Otherwise, pass NOCRED. All currently MAC policies use active_cred, but could now offer the cached credential semantic used for the base system security model.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
show more ...
|
#
27f2eac7 |
| 19-Aug-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Provide an implementation of mac_syscall() so that security modules can offer new services without reserving system call numbers, or augmented versions of existing services. User code requests a tar
Provide an implementation of mac_syscall() so that security modules can offer new services without reserving system call numbers, or augmented versions of existing services. User code requests a target policy by name, and specifies the policy-specific API plus target. This is required in particular for our port of SELinux/FLASK to the MAC framework since it offers additional security services.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
show more ...
|
#
c024c3ee |
| 19-Aug-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Break out mac_check_pipe_op() into component check entry points: mac_check_pipe_poll(), mac_check_pipe_read(), mac_check_pipe_stat(), and mac_check_pipe_write(). This is improves consistency with ot
Break out mac_check_pipe_op() into component check entry points: mac_check_pipe_poll(), mac_check_pipe_read(), mac_check_pipe_stat(), and mac_check_pipe_write(). This is improves consistency with other access control entry points and permits security modules to only control the object methods that they are interested in, avoiding switch statements.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
show more ...
|
#
7f724f8b |
| 19-Aug-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Break out mac_check_vnode_op() into three seperate checks: mac_check_vnode_poll(), mac_check_vnode_read(), mac_check_vnode_write(). This improves the consistency with other existing vnode checks, and
Break out mac_check_vnode_op() into three seperate checks: mac_check_vnode_poll(), mac_check_vnode_read(), mac_check_vnode_write(). This improves the consistency with other existing vnode checks, and allows policies to avoid implementing switch statements to determine what operations they do and do not want to authorize.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
show more ...
|
#
b12baf55 |
| 19-Aug-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Assert process locks in proces-related access control checks.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
|
#
851704bb |
| 19-Aug-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Add a missing vnode assertion for the exec() check.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
|
#
f050add5 |
| 16-Aug-2002 |
Robert Watson <rwatson@FreeBSD.org> |
Wrap maintenance of varios nmac{objectname} counters in MAC_DEBUG so we can avoid the cost of a large number of atomic operations if we're not interested in the object count statistics.
Obtained fro
Wrap maintenance of varios nmac{objectname} counters in MAC_DEBUG so we can avoid the cost of a large number of atomic operations if we're not interested in the object count statistics.
Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
show more ...
|