blob: ad35dca27dcc9952b18c17e438a7087702143b25 [file] [log] [blame]
Greg Kroah-Hartman91980992008-10-28 14:48:09 -07001/*
2 *************************************************************************
3 * Ralink Tech Inc.
4 * 5F., No.36, Taiyuan St., Jhubei City,
5 * Hsinchu County 302,
6 * Taiwan, R.O.C.
7 *
8 * (c) Copyright 2002-2007, Ralink Technology, Inc.
9 *
10 * This program is free software; you can redistribute it and/or modify *
11 * it under the terms of the GNU General Public License as published by *
12 * the Free Software Foundation; either version 2 of the License, or *
13 * (at your option) any later version. *
14 * *
15 * This program is distributed in the hope that it will be useful, *
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
18 * GNU General Public License for more details. *
19 * *
20 * You should have received a copy of the GNU General Public License *
21 * along with this program; if not, write to the *
22 * Free Software Foundation, Inc., *
23 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
24 * *
25 *************************************************************************
26
27 Module Name:
28 rtmp_ckipmic.h
29
30 Abstract:
31
32 Revision History:
33 Who When What
34 -------- ---------- ----------------------------------------------
35 Name Date Modification logs
36*/
37#ifndef __RTMP_CKIPMIC_H__
38#define __RTMP_CKIPMIC_H__
39
Bartlomiej Zolnierkiewicz52b81c82009-12-11 12:23:14 -080040typedef struct _MIC_CONTEXT {
Greg Kroah-Hartman91980992008-10-28 14:48:09 -070041 /* --- MMH context */
Bartlomiej Zolnierkiewicz52b81c82009-12-11 12:23:14 -080042 UCHAR CK[16]; /* the key */
43 UCHAR coefficient[16]; /* current aes counter mode coefficients */
44 ULONGLONG accum; /* accumulated mic, reduced to u32 in final() */
45 UINT position; /* current position (byte offset) in message */
46 UCHAR part[4]; /* for conversion of message to u32 for mmh */
47} MIC_CONTEXT, *PMIC_CONTEXT;
Greg Kroah-Hartman91980992008-10-28 14:48:09 -070048
Bartlomiej Zolnierkiewicz52b81c82009-12-11 12:23:14 -080049VOID xor_128(IN PUCHAR a, IN PUCHAR b, OUT PUCHAR out);
Greg Kroah-Hartman91980992008-10-28 14:48:09 -070050
Bartlomiej Zolnierkiewicz52b81c82009-12-11 12:23:14 -080051UCHAR RTMPCkipSbox(IN UCHAR a);
Greg Kroah-Hartman91980992008-10-28 14:48:09 -070052
Bartlomiej Zolnierkiewicz52b81c82009-12-11 12:23:14 -080053VOID xor_32(IN PUCHAR a, IN PUCHAR b, OUT PUCHAR out);
Greg Kroah-Hartman91980992008-10-28 14:48:09 -070054
Bartlomiej Zolnierkiewicz52b81c82009-12-11 12:23:14 -080055VOID next_key(IN PUCHAR key, IN INT round);
Greg Kroah-Hartman91980992008-10-28 14:48:09 -070056
Bartlomiej Zolnierkiewicz52b81c82009-12-11 12:23:14 -080057VOID byte_sub(IN PUCHAR in, OUT PUCHAR out);
Greg Kroah-Hartman91980992008-10-28 14:48:09 -070058
Bartlomiej Zolnierkiewicz52b81c82009-12-11 12:23:14 -080059VOID shift_row(IN PUCHAR in, OUT PUCHAR out);
Greg Kroah-Hartman91980992008-10-28 14:48:09 -070060
Bartlomiej Zolnierkiewicz52b81c82009-12-11 12:23:14 -080061VOID mix_column(IN PUCHAR in, OUT PUCHAR out);
Greg Kroah-Hartman91980992008-10-28 14:48:09 -070062
Greg Kroah-Hartman91980992008-10-28 14:48:09 -070063#endif //__RTMP_CKIPMIC_H__