crypt.h 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /*
  2. * crypt(3) implementation for uClibc
  3. *
  4. * The uClibc Library is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU Lesser General Public
  6. * License as published by the Free Software Foundation; either
  7. * version 2.1 of the License, or (at your option) any later version.
  8. *
  9. * The GNU C Library 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 GNU
  12. * Lesser General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU Lesser General Public
  15. * License along with the GNU C Library; if not, write to the Free
  16. * Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  17. * 02111-1307 USA.
  18. *
  19. */
  20. #ifndef _CRYPT_H
  21. #define _CRYPT_H 1
  22. #include <features.h>
  23. __BEGIN_DECLS
  24. /* Encrypt characters from KEY using salt to perturb the encryption method.
  25. * If salt begins with "$1$", md5 hashing is used instead of DES. */
  26. extern char *crypt (const char *__key, const char *__salt);
  27. /* Setup DES tables according KEY. */
  28. extern void setkey (const char *__key);
  29. /* Encrypt data in BLOCK in place if EDFLAG is zero; otherwise decrypt
  30. block in place. */
  31. extern void encrypt (char *__block, int __edflag);
  32. /* Reentrant versions of the functions above. The additional argument
  33. points to a structure where the results are placed in. */
  34. struct block {
  35. unsigned char b_data[64];
  36. };
  37. struct ordering {
  38. unsigned char o_data[64];
  39. };
  40. struct crypt_data
  41. {
  42. /* Stuff used by the des based routines */
  43. struct block key;
  44. const struct ordering *EP;
  45. /* Stuff used by the md5 based routines */
  46. char *p;
  47. const char *sp,*ep;
  48. };
  49. extern char *crypt_r (const char *__key, const char *__salt,
  50. struct crypt_data * __data);
  51. extern void setkey_r (const char *__key,
  52. struct crypt_data * __data);
  53. extern void encrypt_r (char *__block, int __edflag,
  54. struct crypt_data * __data);
  55. __END_DECLS
  56. #endif /* crypt.h */