mirror of
https://github.com/Qortal/Brooklyn.git
synced 2025-02-13 10:45:54 +00:00
* 0day explit mitigation * Memory corruption prevention * Privilege escalation prevention * Buffer over flow prevention * File System corruption defense * Thread escape prevention This may very well be the most intensive inclusion to BrooklynR. This will not be part of an x86 suite nor it will be released as tool kit. The security core toolkit will remain part of kernel base.
119 lines
2.7 KiB
C
119 lines
2.7 KiB
C
/*
|
|
* linux/include/linux/lockd/xdr.h
|
|
*
|
|
* XDR types for the NLM protocol
|
|
*
|
|
* Copyright (C) 1996 Olaf Kirch <okir@monad.swb.de>
|
|
*/
|
|
|
|
#ifndef LOCKD_XDR_H
|
|
#define LOCKD_XDR_H
|
|
|
|
#include <linux/fs.h>
|
|
#include <linux/nfs.h>
|
|
#include <linux/sunrpc/xdr.h>
|
|
|
|
#define SM_MAXSTRLEN 1024
|
|
#define SM_PRIV_SIZE 16
|
|
|
|
struct nsm_private {
|
|
unsigned char data[SM_PRIV_SIZE];
|
|
};
|
|
|
|
struct svc_rqst;
|
|
|
|
#define NLM_MAXCOOKIELEN 32
|
|
#define NLM_MAXSTRLEN 1024
|
|
|
|
#define nlm_granted cpu_to_be32(NLM_LCK_GRANTED)
|
|
#define nlm_lck_denied cpu_to_be32(NLM_LCK_DENIED)
|
|
#define nlm_lck_denied_nolocks cpu_to_be32(NLM_LCK_DENIED_NOLOCKS)
|
|
#define nlm_lck_blocked cpu_to_be32(NLM_LCK_BLOCKED)
|
|
#define nlm_lck_denied_grace_period cpu_to_be32(NLM_LCK_DENIED_GRACE_PERIOD)
|
|
|
|
#define nlm_drop_reply cpu_to_be32(30000)
|
|
|
|
/* Lock info passed via NLM */
|
|
struct nlm_lock {
|
|
char * caller;
|
|
unsigned int len; /* length of "caller" */
|
|
struct nfs_fh fh;
|
|
struct xdr_netobj oh;
|
|
u32 svid;
|
|
struct file_lock fl;
|
|
};
|
|
|
|
/*
|
|
* NLM cookies. Technically they can be 1K, but Linux only uses 8 bytes.
|
|
* FreeBSD uses 16, Apple Mac OS X 10.3 uses 20. Therefore we set it to
|
|
* 32 bytes.
|
|
*/
|
|
|
|
struct nlm_cookie
|
|
{
|
|
unsigned char data[NLM_MAXCOOKIELEN];
|
|
unsigned int len;
|
|
};
|
|
|
|
/*
|
|
* Generic lockd arguments for all but sm_notify
|
|
*/
|
|
struct nlm_args {
|
|
struct nlm_cookie cookie;
|
|
struct nlm_lock lock;
|
|
u32 block;
|
|
u32 reclaim;
|
|
u32 state;
|
|
u32 monitor;
|
|
u32 fsm_access;
|
|
u32 fsm_mode;
|
|
};
|
|
|
|
typedef struct nlm_args nlm_args;
|
|
|
|
/*
|
|
* Generic lockd result
|
|
*/
|
|
struct nlm_res {
|
|
struct nlm_cookie cookie;
|
|
__be32 status;
|
|
struct nlm_lock lock;
|
|
};
|
|
|
|
/*
|
|
* statd callback when client has rebooted
|
|
*/
|
|
struct nlm_reboot {
|
|
char *mon;
|
|
unsigned int len;
|
|
u32 state;
|
|
struct nsm_private priv;
|
|
};
|
|
|
|
/*
|
|
* Contents of statd callback when monitored host rebooted
|
|
*/
|
|
#define NLMSVC_XDRSIZE sizeof(struct nlm_args)
|
|
|
|
int nlmsvc_decode_testargs(void *, __be32 *, void *);
|
|
int nlmsvc_encode_testres(void *, __be32 *, void *);
|
|
int nlmsvc_decode_lockargs(void *, __be32 *, void *);
|
|
int nlmsvc_decode_cancargs(void *, __be32 *, void *);
|
|
int nlmsvc_decode_unlockargs(void *, __be32 *, void *);
|
|
int nlmsvc_encode_res(void *, __be32 *, void *);
|
|
int nlmsvc_decode_res(void *, __be32 *, void *);
|
|
int nlmsvc_encode_void(void *, __be32 *p, void *);
|
|
int nlmsvc_decode_void(void *, __be32 *, void *);
|
|
int nlmsvc_decode_shareargs(void *, __be32 *, void *);
|
|
int nlmsvc_encode_shareres(void *, __be32 *, void *);
|
|
int nlmsvc_decode_notify(void *, __be32 *, void *);
|
|
int nlmsvc_decode_reboot(void *, __be32 *, void *);
|
|
/*
|
|
int nlmclt_encode_testargs(void *, u32 *, void *);
|
|
int nlmclt_encode_lockargs(void *, u32 *, void *);
|
|
int nlmclt_encode_cancargs(void *, u32 *, void *);
|
|
int nlmclt_encode_unlockargs(void *, u32 *, void *);
|
|
*/
|
|
|
|
#endif /* LOCKD_XDR_H */
|