esp.h

来自「xen虚拟机源代码安装包」· C头文件 代码 · 共 121 行

H
121
字号
/* * Copyright (C) 2004, 2005 Mike Wray <mike.wray@hp.com> * * 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; either version 2 of the License, or (at your * option) any later version. *  * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free software Foundation, Inc., * 59 Temple Place, suite 330, Boston, MA 02111-1307 USA * */#ifndef __VNET_ESP_H__#define __VNET_ESP_H__#ifdef __KERNEL__#include <linux/config.h>#include <linux/types.h>#include <linux/crypto.h>#else#include "sys_kernel.h"struct crypto_tfm;#endif/** Header used by IPSEC ESP (Encapsulated Security Payload). */typedef struct ESPHdr {    /** The spi (security parameters index). */    u32 spi;    /** Sequence number. */    u32 seq;    /* Variable length data (depends on crypto suite).       Mind the 64 bit alignment! */    u8  data[0];} ESPHdr;/** Padding trailer used by IPSEC ESP. * Follows the padding itself with the padding length and the * protocol being encapsulated. */typedef struct ESPPadding {    u8 pad_n;    u8 protocol;} ESPPadding;/** Size of the esp header (spi and seq). */static const int ESP_HDR_N = sizeof(ESPHdr);/** Size of the esp pad and next protocol field. */static const int ESP_PAD_N = sizeof(ESPPadding);enum {    SASTATE_VOID,    SASTATE_ACQUIRE,    SASTATE_VALID,    SASTATE_ERROR,    SASTATE_EXPIRED,    SASTATE_DEAD,};struct ESPState;/** A cipher instance. */typedef struct ESPCipher {    /** Cipher key. */    u8 *key;    /** Key size (bytes). */    int key_n;    /** Initialization vector (IV). */    u8 *iv;    /** IV size (bytes). */    int iv_n;    /** Block size for padding (bytes). */    int pad_n;    /** Cipher block size (bytes). */    int block_n;    /** Cipher crypto transform. */    struct crypto_tfm *tfm;} ESPCipher;/** A digest instance. */typedef struct ESPDigest {    /** Digest key. */    u8 *key;    /** Key size (bytes) */    int key_n;    /** ICV size used (bytes). */    u8 icv_n;    /** Full ICV size when computed (bytes). */    u8 icv_full_n;    /** Working storage for computing ICV. */    u8 *icv_tmp;    /** Function used to compute ICV (e.g. HMAC). */    void (*icv)(struct ESPState *esp,                struct sk_buff *skb,                int offset,                int len,                u8 *icv);    /** Digest crypto transform (e.g. SHA). */    struct crypto_tfm *tfm;} ESPDigest;typedef struct ESPState {    struct ESPCipher cipher;    struct ESPDigest digest;} ESPState;extern int esp_module_init(void);extern void esp_module_exit(void);#endif /* !__VNET_ESP_H__ */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?