generic_mpih-rshift.c 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /* mpih-rshift.c - MPI helper functions
  2. * Copyright (C) 1994, 1996, 1998, 1999,
  3. * 2000, 2001 Free Software Foundation, Inc.
  4. *
  5. * This file is part of GNUPG
  6. *
  7. * GNUPG is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 2 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * GNUPG is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
  20. *
  21. * Note: This code is heavily based on the GNU MP Library.
  22. * Actually it's the same code with only minor changes in the
  23. * way the data is stored; this is to support the abstraction
  24. * of an optional secure memory allocation which may be used
  25. * to avoid revealing of sensitive data due to paging etc.
  26. * The GNU MP Library itself is published under the LGPL;
  27. * however I decided to publish this code under the plain GPL.
  28. */
  29. #include "mpi-internal.h"
  30. /* Shift U (pointed to by UP and USIZE limbs long) CNT bits to the right
  31. * and store the USIZE least significant limbs of the result at WP.
  32. * The bits shifted out to the right are returned.
  33. *
  34. * Argument constraints:
  35. * 1. 0 < CNT < BITS_PER_MP_LIMB
  36. * 2. If the result is to be written over the input, WP must be <= UP.
  37. */
  38. mpi_limb_t
  39. mpihelp_rshift(mpi_ptr_t wp, mpi_ptr_t up, mpi_size_t usize, unsigned cnt)
  40. {
  41. mpi_limb_t high_limb, low_limb;
  42. unsigned sh_1, sh_2;
  43. mpi_size_t i;
  44. mpi_limb_t retval;
  45. sh_1 = cnt;
  46. wp -= 1;
  47. sh_2 = BITS_PER_MPI_LIMB - sh_1;
  48. high_limb = up[0];
  49. retval = high_limb << sh_2;
  50. low_limb = high_limb;
  51. for (i = 1; i < usize; i++) {
  52. high_limb = up[i];
  53. wp[i] = (low_limb >> sh_1) | (high_limb << sh_2);
  54. low_limb = high_limb;
  55. }
  56. wp[i] = low_limb >> sh_1;
  57. return retval;
  58. }