root/include/uapi/linux/netfilter/xt_hashlimit.h
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
#ifndef _UAPI_XT_HASHLIMIT_H
#define _UAPI_XT_HASHLIMIT_H

#include <linux/types.h>
#include <linux/limits.h>
#include <linux/if.h>

/* timings are in milliseconds. */
#define XT_HASHLIMIT_SCALE 10000
#define XT_HASHLIMIT_SCALE_v2 1000000llu
/* 1/10,000 sec period => max of 10,000/sec.  Min rate is then 429490
 * seconds, or one packet every 59 hours.
 */

/* packet length accounting is done in 16-byte steps */
#define XT_HASHLIMIT_BYTE_SHIFT 4

/* details of this structure hidden by the implementation */
struct xt_hashlimit_htable;

enum {
        XT_HASHLIMIT_HASH_DIP           = 1 << 0,
        XT_HASHLIMIT_HASH_DPT           = 1 << 1,
        XT_HASHLIMIT_HASH_SIP           = 1 << 2,
        XT_HASHLIMIT_HASH_SPT           = 1 << 3,
        XT_HASHLIMIT_INVERT             = 1 << 4,
        XT_HASHLIMIT_BYTES              = 1 << 5,
        XT_HASHLIMIT_RATE_MATCH         = 1 << 6,
};

struct hashlimit_cfg {
        __u32 mode;       /* bitmask of XT_HASHLIMIT_HASH_* */
        __u32 avg;    /* Average secs between packets * scale */
        __u32 burst;  /* Period multiplier for upper limit. */

        /* user specified */
        __u32 size;             /* how many buckets */
        __u32 max;              /* max number of entries */
        __u32 gc_interval;      /* gc interval */
        __u32 expire;   /* when do entries expire? */
};

struct xt_hashlimit_info {
        char name [IFNAMSIZ];           /* name */
        struct hashlimit_cfg cfg;

        /* Used internally by the kernel */
        struct xt_hashlimit_htable *hinfo;
        union {
                void *ptr;
                struct xt_hashlimit_info *master;
        } u;
};

struct hashlimit_cfg1 {
        __u32 mode;       /* bitmask of XT_HASHLIMIT_HASH_* */
        __u32 avg;    /* Average secs between packets * scale */
        __u32 burst;  /* Period multiplier for upper limit. */

        /* user specified */
        __u32 size;             /* how many buckets */
        __u32 max;              /* max number of entries */
        __u32 gc_interval;      /* gc interval */
        __u32 expire;   /* when do entries expire? */

        __u8 srcmask, dstmask;
};

struct hashlimit_cfg2 {
        __u64 avg;              /* Average secs between packets * scale */
        __u64 burst;            /* Period multiplier for upper limit. */
        __u32 mode;             /* bitmask of XT_HASHLIMIT_HASH_* */

        /* user specified */
        __u32 size;             /* how many buckets */
        __u32 max;              /* max number of entries */
        __u32 gc_interval;      /* gc interval */
        __u32 expire;           /* when do entries expire? */

        __u8 srcmask, dstmask;
};

struct hashlimit_cfg3 {
        __u64 avg;              /* Average secs between packets * scale */
        __u64 burst;            /* Period multiplier for upper limit. */
        __u32 mode;             /* bitmask of XT_HASHLIMIT_HASH_* */

        /* user specified */
        __u32 size;             /* how many buckets */
        __u32 max;              /* max number of entries */
        __u32 gc_interval;      /* gc interval */
        __u32 expire;           /* when do entries expire? */

        __u32 interval;
        __u8 srcmask, dstmask;
};

struct xt_hashlimit_mtinfo1 {
        char name[IFNAMSIZ];
        struct hashlimit_cfg1 cfg;

        /* Used internally by the kernel */
        struct xt_hashlimit_htable *hinfo __attribute__((aligned(8)));
};

struct xt_hashlimit_mtinfo2 {
        char name[NAME_MAX];
        struct hashlimit_cfg2 cfg;

        /* Used internally by the kernel */
        struct xt_hashlimit_htable *hinfo __attribute__((aligned(8)));
};

struct xt_hashlimit_mtinfo3 {
        char name[NAME_MAX];
        struct hashlimit_cfg3 cfg;

        /* Used internally by the kernel */
        struct xt_hashlimit_htable *hinfo __attribute__((aligned(8)));
};

#endif /* _UAPI_XT_HASHLIMIT_H */