michael.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * Copyright (c) 1996, 2003 VIA Networking Technologies, Inc.
  3. * All rights reserved.
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License along
  16. * with this program; if not, write to the Free Software Foundation, Inc.,
  17. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
  18. *
  19. *
  20. * File: Michael.h
  21. *
  22. * Purpose: Reference implementation for Michael
  23. * written by Niels Ferguson
  24. *
  25. * Author: Kyle Hsu
  26. *
  27. * Date: Jan 2, 2003
  28. *
  29. */
  30. #ifndef __MICHAEL_H__
  31. #define __MICHAEL_H__
  32. #include <linux/types.h>
  33. void MIC_vInit(u32 dwK0, u32 dwK1);
  34. void MIC_vUnInit(void);
  35. /* Append bytes to the message to be MICed */
  36. void MIC_vAppend(unsigned char *src, unsigned int nBytes);
  37. /* Get the MIC result. Destination should accept 8 bytes of result. */
  38. /* This also resets the message to empty. */
  39. void MIC_vGetMIC(u32 *pdwL, u32 *pdwR);
  40. /* Rotation functions on 32 bit values */
  41. #define ROL32(A, n) \
  42. (((A) << (n)) | (((A)>>(32-(n))) & ((1UL << (n)) - 1)))
  43. #define ROR32(A, n) ROL32((A), 32-(n))
  44. #endif /*__MICHAEL_H__ */