/* * AppArmor security module * * This file contains AppArmor resource limits function definitions. * * Copyright (C) 1998-2008 Novell/SUSE * Copyright 2009-2010 Canonical Ltd. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation, version 2 of the * License. */ #ifndef __AA_RESOURCE_H #define __AA_RESOURCE_H #include <linux/resource.h> #include <linux/sched.h> #include "apparmorfs.h" struct aa_profile; /* struct aa_rlimit - rlimit settings for the profile * @mask: which hard limits to set * @limits: rlimit values that override task limits * * AppArmor rlimits are used to set confined task rlimits. Only the * limits specified in @mask will be controlled by apparmor. */ struct aa_rlimit { unsigned int mask; struct rlimit limits[RLIM_NLIMITS]; }; extern struct aa_fs_entry aa_fs_entry_rlimit[]; int aa_map_resource(int resource); int aa_task_setrlimit(struct aa_profile *profile, struct task_struct *, unsigned int resource, struct rlimit *new_rlim); void __aa_transition_rlimits(struct aa_profile *old, struct aa_profile *new); static inline void aa_free_rlimit_rules(struct aa_rlimit *rlims) { /* NOP */ } #endif /* __AA_RESOURCE_H */