rc5.h 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /* rc5.h */
  2. /*
  3. This file is part of the ARM-Crypto-Lib.
  4. Copyright (C) 2008 Daniel Otte (daniel.otte@rub.de)
  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 3 of the License, or
  8. (at your option) any later version.
  9. This program is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. GNU General Public License for more details.
  13. You should have received a copy of the GNU General Public License
  14. along with this program. If not, see <http://www.gnu.org/licenses/>.
  15. */
  16. /* rc5.h a C implementation of RC5 for ARM microcontrollers
  17. *
  18. * author: Daniel Otte
  19. * email: daniel.otte@rub.de
  20. * license: GPLv3
  21. *
  22. * this implementation is limited to 64bit blocks and a maximum of 255 rounds
  23. *
  24. */
  25. #ifndef RC5_H_
  26. #define RC5_H_
  27. #include <stdint.h>
  28. #include <stdlib.h> /* malloc() & free() */
  29. #include <string.h> /* memset() & memcpy() */
  30. typedef struct rc5_ctx_st {
  31. uint8_t rounds;
  32. uint32_t *s;
  33. }rc5_ctx_t;
  34. void rc5_enc(void* buffer, const rc5_ctx_t* ctx);
  35. void rc5_dec(void* buffer, const rc5_ctx_t* ctx);
  36. void rc5_init(void* key, uint16_t keysize_b, uint8_t rounds, rc5_ctx_t* ctx);
  37. void rc5_free(rc5_ctx_t* ctx);
  38. #endif /*RC5_H_*/