generic_mpih-lshift.c 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /* mpihelp-lshift.c - MPI helper functions
  3. * Copyright (C) 1994, 1996, 1998, 2001 Free Software Foundation, Inc.
  4. *
  5. * This file is part of GnuPG.
  6. *
  7. * Note: This code is heavily based on the GNU MP Library.
  8. * Actually it's the same code with only minor changes in the
  9. * way the data is stored; this is to support the abstraction
  10. * of an optional secure memory allocation which may be used
  11. * to avoid revealing of sensitive data due to paging etc.
  12. * The GNU MP Library itself is published under the LGPL;
  13. * however I decided to publish this code under the plain GPL.
  14. */
  15. #include "mpi-internal.h"
  16. /* Shift U (pointed to by UP and USIZE digits long) CNT bits to the left
  17. * and store the USIZE least significant digits of the result at WP.
  18. * Return the bits shifted out from the most significant digit.
  19. *
  20. * Argument constraints:
  21. * 1. 0 < CNT < BITS_PER_MP_LIMB
  22. * 2. If the result is to be written over the input, WP must be >= UP.
  23. */
  24. mpi_limb_t
  25. mpihelp_lshift(mpi_ptr_t wp, mpi_ptr_t up, mpi_size_t usize, unsigned int cnt)
  26. {
  27. mpi_limb_t high_limb, low_limb;
  28. unsigned sh_1, sh_2;
  29. mpi_size_t i;
  30. mpi_limb_t retval;
  31. sh_1 = cnt;
  32. wp += 1;
  33. sh_2 = BITS_PER_MPI_LIMB - sh_1;
  34. i = usize - 1;
  35. low_limb = up[i];
  36. retval = low_limb >> sh_2;
  37. high_limb = low_limb;
  38. while (--i >= 0) {
  39. low_limb = up[i];
  40. wp[i] = (high_limb << sh_1) | (low_limb >> sh_2);
  41. high_limb = low_limb;
  42. }
  43. wp[i] = high_limb << sh_1;
  44. return retval;
  45. }