You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
45 lines
1.0 KiB
45 lines
1.0 KiB
#ifndef _COMPAT_H_
|
|
#define _COMPAT_H_
|
|
|
|
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,26)
|
|
#define trylock_page(page) (!TestSetPageLocked(page))
|
|
#endif
|
|
|
|
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,27)
|
|
static inline struct dentry *d_obtain_alias(struct inode *inode)
|
|
{
|
|
struct dentry *d;
|
|
|
|
if (!inode)
|
|
return NULL;
|
|
if (IS_ERR(inode))
|
|
return ERR_CAST(inode);
|
|
|
|
d = d_alloc_anon(inode);
|
|
if (!d)
|
|
iput(inode);
|
|
return d;
|
|
}
|
|
#endif
|
|
|
|
/*
|
|
* Even if AppArmor isn't enabled, it still has different prototypes.
|
|
* Add more distro/version pairs here to declare which has AppArmor applied.
|
|
*/
|
|
#if defined(CONFIG_SUSE_KERNEL)
|
|
# if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,22)
|
|
# define REMOVE_SUID_PATH 1
|
|
# endif
|
|
#endif
|
|
|
|
/*
|
|
* catch any other distros that have patched in apparmor. This isn't
|
|
* 100% reliable because it won't catch people that hand compile their
|
|
* own distro kernels without apparmor compiled in. But, it is better
|
|
* than nothing.
|
|
*/
|
|
#ifdef CONFIG_SECURITY_APPARMOR
|
|
# define REMOVE_SUID_PATH 1
|
|
#endif
|
|
|
|
#endif /* _COMPAT_H_ */
|
|
|