#ifndef _SECURITY_SMACK_H
#define _SECURITY_SMACK_H
#include <linux/capability.h>
#include <linux/spinlock.h>
#include <linux/lsm_hooks.h>
#include <linux/in.h>
#if IS_ENABLED(CONFIG_IPV6)
#include <linux/in6.h>
#endif
#include <net/netlabel.h>
#include <linux/list.h>
#include <linux/rculist.h>
#include <linux/lsm_audit.h>
#include <linux/msg.h>
#if IS_ENABLED(CONFIG_IPV6) && !defined(CONFIG_SECURITY_SMACK_NETFILTER)
#define SMACK_IPV6_PORT_LABELING …
#endif
#if IS_ENABLED(CONFIG_IPV6) && defined(CONFIG_SECURITY_SMACK_NETFILTER)
#define SMACK_IPV6_SECMARK_LABELING …
#endif
#define SMK_LABELLEN …
#define SMK_LONGLABEL …
struct smack_known { … };
#define SMK_CIPSOLEN …
struct superblock_smack { … };
#define SMK_SB_INITIALIZED …
#define SMK_SB_UNTRUSTED …
struct socket_smack { … };
#define SMK_NETLBL_UNSET …
#define SMK_NETLBL_UNLABELED …
#define SMK_NETLBL_LABELED …
#define SMK_NETLBL_REQSKB …
struct inode_smack { … };
struct task_smack { … };
#define SMK_INODE_INSTANT …
#define SMK_INODE_TRANSMUTE …
#define SMK_INODE_CHANGED …
#define SMK_INODE_IMPURE …
struct smack_rule { … };
struct smk_net4addr { … };
struct smk_net6addr { … };
struct smk_port_label { … };
struct smack_known_list_elem { … };
enum { … };
#define SMACK_DELETE_OPTION …
#define SMACK_CIPSO_OPTION …
#define SMACK_CIPSO_DOI_DEFAULT …
#define SMACK_CIPSO_DOI_INVALID …
#define SMACK_CIPSO_DIRECT_DEFAULT …
#define SMACK_CIPSO_MAPPED_DEFAULT …
#define SMACK_CIPSO_MAXLEVEL …
#define SMACK_CIPSO_MAXCATNUM …
#define SMACK_PTRACE_DEFAULT …
#define SMACK_PTRACE_EXACT …
#define SMACK_PTRACE_DRACONIAN …
#define SMACK_PTRACE_MAX …
#define MAY_TRANSMUTE …
#define MAY_LOCK …
#define MAY_BRINGUP …
#ifdef CONFIG_SECURITY_SMACK_APPEND_SIGNALS
#define MAY_DELIVER …
#else
#define MAY_DELIVER …
#endif
#define SMACK_BRINGUP_ALLOW …
#define SMACK_UNCONFINED_SUBJECT …
#define SMACK_UNCONFINED_OBJECT …
#define MAY_ANYREAD …
#define MAY_READWRITE …
#define MAY_NOT …
#define SMK_NUM_ACCESS_TYPE …
struct smack_audit_data { … };
struct smk_audit_info { … };
int smk_access_entry(char *, char *, struct list_head *);
int smk_access(struct smack_known *, struct smack_known *,
int, struct smk_audit_info *);
int smk_tskacc(struct task_smack *, struct smack_known *,
u32, struct smk_audit_info *);
int smk_curacc(struct smack_known *, u32, struct smk_audit_info *);
struct smack_known *smack_from_secid(const u32);
char *smk_parse_smack(const char *string, int len);
int smk_netlbl_mls(int, char *, struct netlbl_lsm_secattr *, int);
struct smack_known *smk_import_entry(const char *, int);
void smk_insert_entry(struct smack_known *skp);
struct smack_known *smk_find_entry(const char *);
bool smack_privileged(int cap);
bool smack_privileged_cred(int cap, const struct cred *cred);
void smk_destroy_label_list(struct list_head *list);
int smack_populate_secattr(struct smack_known *skp);
extern int smack_enabled __initdata;
extern int smack_cipso_direct;
extern int smack_cipso_mapped;
extern struct smack_known *smack_net_ambient;
extern struct smack_known *smack_syslog_label;
#ifdef CONFIG_SECURITY_SMACK_BRINGUP
extern struct smack_known *smack_unconfined;
#endif
extern int smack_ptrace_rule;
extern struct lsm_blob_sizes smack_blob_sizes;
extern struct smack_known smack_known_floor;
extern struct smack_known smack_known_hat;
extern struct smack_known smack_known_huh;
extern struct smack_known smack_known_star;
extern struct smack_known smack_known_web;
extern struct mutex smack_known_lock;
extern struct list_head smack_known_list;
extern struct list_head smk_net4addr_list;
extern struct list_head smk_net6addr_list;
extern struct mutex smack_onlycap_lock;
extern struct list_head smack_onlycap_list;
#define SMACK_HASH_SLOTS …
extern struct hlist_head smack_known_hash[SMACK_HASH_SLOTS];
extern struct kmem_cache *smack_rule_cache;
static inline struct task_smack *smack_cred(const struct cred *cred)
{ … }
static inline struct smack_known **smack_file(const struct file *file)
{ … }
static inline struct inode_smack *smack_inode(const struct inode *inode)
{ … }
static inline struct smack_known **smack_msg_msg(const struct msg_msg *msg)
{ … }
static inline struct smack_known **smack_ipc(const struct kern_ipc_perm *ipc)
{ … }
static inline struct superblock_smack *smack_superblock(
const struct super_block *superblock)
{ … }
static inline struct socket_smack *smack_sock(const struct sock *sock)
{ … }
#ifdef CONFIG_KEYS
static inline struct smack_known **smack_key(const struct key *key)
{ … }
#endif
static inline int smk_inode_transmutable(const struct inode *isp)
{ … }
static inline struct smack_known *smk_of_inode(const struct inode *isp)
{ … }
static inline struct smack_known *smk_of_task(const struct task_smack *tsp)
{ … }
static inline struct smack_known *smk_of_task_struct_obj(
const struct task_struct *t)
{ … }
static inline struct smack_known *smk_of_forked(const struct task_smack *tsp)
{ … }
static inline struct smack_known *smk_of_current(void)
{ … }
#define SMACK_AUDIT_DENIED …
#define SMACK_AUDIT_ACCEPT …
extern int log_policy;
void smack_log(char *subject_label, char *object_label,
int request,
int result, struct smk_audit_info *auditdata);
#ifdef CONFIG_AUDIT
static inline void smk_ad_init(struct smk_audit_info *a, const char *func,
char type)
{ … }
static inline void smk_ad_init_net(struct smk_audit_info *a, const char *func,
char type, struct lsm_network_audit *net)
{ … }
static inline void smk_ad_setfield_u_tsk(struct smk_audit_info *a,
struct task_struct *t)
{ … }
static inline void smk_ad_setfield_u_fs_path_dentry(struct smk_audit_info *a,
struct dentry *d)
{ … }
static inline void smk_ad_setfield_u_fs_inode(struct smk_audit_info *a,
struct inode *i)
{ … }
static inline void smk_ad_setfield_u_fs_path(struct smk_audit_info *a,
struct path p)
{ … }
static inline void smk_ad_setfield_u_net_sk(struct smk_audit_info *a,
struct sock *sk)
{ … }
#else
static inline void smk_ad_init(struct smk_audit_info *a, const char *func,
char type)
{
}
static inline void smk_ad_setfield_u_tsk(struct smk_audit_info *a,
struct task_struct *t)
{
}
static inline void smk_ad_setfield_u_fs_path_dentry(struct smk_audit_info *a,
struct dentry *d)
{
}
static inline void smk_ad_setfield_u_fs_inode(struct smk_audit_info *a,
struct inode *i)
{
}
static inline void smk_ad_setfield_u_fs_path(struct smk_audit_info *a,
struct path p)
{
}
static inline void smk_ad_setfield_u_net_sk(struct smk_audit_info *a,
struct sock *sk)
{
}
#endif
#endif