~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/lib/crypto/mpi/mpi-inline.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0-or-later */
  2 /* mpi-inline.h  -  Internal to the Multi Precision Integers
  3  *      Copyright (C) 1994, 1996, 1998, 1999 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 
 16 #ifndef G10_MPI_INLINE_H
 17 #define G10_MPI_INLINE_H
 18 
 19 #ifndef G10_MPI_INLINE_DECL
 20 #define G10_MPI_INLINE_DECL  static inline
 21 #endif
 22 
 23 G10_MPI_INLINE_DECL mpi_limb_t
 24 mpihelp_add_1(mpi_ptr_t res_ptr, mpi_ptr_t s1_ptr,
 25               mpi_size_t s1_size, mpi_limb_t s2_limb)
 26 {
 27         mpi_limb_t x;
 28 
 29         x = *s1_ptr++;
 30         s2_limb += x;
 31         *res_ptr++ = s2_limb;
 32         if (s2_limb < x) {      /* sum is less than the left operand: handle carry */
 33                 while (--s1_size) {
 34                         x = *s1_ptr++ + 1;      /* add carry */
 35                         *res_ptr++ = x; /* and store */
 36                         if (x)  /* not 0 (no overflow): we can stop */
 37                                 goto leave;
 38                 }
 39                 return 1;       /* return carry (size of s1 to small) */
 40         }
 41 
 42 leave:
 43         if (res_ptr != s1_ptr) {        /* not the same variable */
 44                 mpi_size_t i;   /* copy the rest */
 45                 for (i = 0; i < s1_size - 1; i++)
 46                         res_ptr[i] = s1_ptr[i];
 47         }
 48         return 0;               /* no carry */
 49 }
 50 
 51 G10_MPI_INLINE_DECL mpi_limb_t
 52 mpihelp_add(mpi_ptr_t res_ptr, mpi_ptr_t s1_ptr, mpi_size_t s1_size,
 53             mpi_ptr_t s2_ptr, mpi_size_t s2_size)
 54 {
 55         mpi_limb_t cy = 0;
 56 
 57         if (s2_size)
 58                 cy = mpihelp_add_n(res_ptr, s1_ptr, s2_ptr, s2_size);
 59 
 60         if (s1_size - s2_size)
 61                 cy = mpihelp_add_1(res_ptr + s2_size, s1_ptr + s2_size,
 62                                    s1_size - s2_size, cy);
 63         return cy;
 64 }
 65 
 66 G10_MPI_INLINE_DECL mpi_limb_t
 67 mpihelp_sub_1(mpi_ptr_t res_ptr, mpi_ptr_t s1_ptr,
 68               mpi_size_t s1_size, mpi_limb_t s2_limb)
 69 {
 70         mpi_limb_t x;
 71 
 72         x = *s1_ptr++;
 73         s2_limb = x - s2_limb;
 74         *res_ptr++ = s2_limb;
 75         if (s2_limb > x) {
 76                 while (--s1_size) {
 77                         x = *s1_ptr++;
 78                         *res_ptr++ = x - 1;
 79                         if (x)
 80                                 goto leave;
 81                 }
 82                 return 1;
 83         }
 84 
 85 leave:
 86         if (res_ptr != s1_ptr) {
 87                 mpi_size_t i;
 88                 for (i = 0; i < s1_size - 1; i++)
 89                         res_ptr[i] = s1_ptr[i];
 90         }
 91         return 0;
 92 }
 93 
 94 G10_MPI_INLINE_DECL mpi_limb_t
 95 mpihelp_sub(mpi_ptr_t res_ptr, mpi_ptr_t s1_ptr, mpi_size_t s1_size,
 96             mpi_ptr_t s2_ptr, mpi_size_t s2_size)
 97 {
 98         mpi_limb_t cy = 0;
 99 
100         if (s2_size)
101                 cy = mpihelp_sub_n(res_ptr, s1_ptr, s2_ptr, s2_size);
102 
103         if (s1_size - s2_size)
104                 cy = mpihelp_sub_1(res_ptr + s2_size, s1_ptr + s2_size,
105                                    s1_size - s2_size, cy);
106         return cy;
107 }
108 
109 #endif /*G10_MPI_INLINE_H */
110 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php