LCOV - code coverage report
Current view: top level - lib/mpi - mpi-inline.h (source / functions) Hit Total Coverage
Test: combined.info Lines: 8 37 21.6 %
Date: 2022-04-01 13:59:58 Functions: 1 3 33.3 %
Branches: 2 24 8.3 %

           Branch data     Line data    Source code
       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                 :       4212 : 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                 :       4212 :         mpi_limb_t x;
      28                 :            : 
      29                 :       4212 :         x = *s1_ptr++;
      30                 :       4212 :         s2_limb += x;
      31                 :       4212 :         *res_ptr++ = s2_limb;
      32         [ -  + ]:       4212 :         if (s2_limb < x) {   /* sum is less than the left operand: handle carry */
      33         [ #  # ]:          0 :                 while (--s1_size) {
      34                 :          0 :                         x = *s1_ptr++ + 1;      /* add carry */
      35                 :          0 :                         *res_ptr++ = x; /* and store */
      36         [ #  # ]:          0 :                         if (x)  /* not 0 (no overflow): we can stop */
      37                 :          0 :                                 goto leave;
      38                 :            :                 }
      39                 :            :                 return 1;       /* return carry (size of s1 to small) */
      40                 :            :         }
      41                 :            : 
      42                 :       4212 : leave:
      43         [ -  + ]:       4212 :         if (res_ptr != s1_ptr) {        /* not the same variable */
      44                 :            :                 mpi_size_t i;   /* copy the rest */
      45         [ #  # ]:          0 :                 for (i = 0; i < s1_size - 1; i++)
      46                 :          0 :                         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                 :          0 : 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                 :          0 :         mpi_limb_t x;
      71                 :            : 
      72                 :          0 :         x = *s1_ptr++;
      73                 :          0 :         s2_limb = x - s2_limb;
      74                 :          0 :         *res_ptr++ = s2_limb;
      75         [ #  # ]:          0 :         if (s2_limb > x) {
      76         [ #  # ]:          0 :                 while (--s1_size) {
      77                 :          0 :                         x = *s1_ptr++;
      78                 :          0 :                         *res_ptr++ = x - 1;
      79         [ #  # ]:          0 :                         if (x)
      80                 :          0 :                                 goto leave;
      81                 :            :                 }
      82                 :            :                 return 1;
      83                 :            :         }
      84                 :            : 
      85                 :          0 : leave:
      86         [ #  # ]:          0 :         if (res_ptr != s1_ptr) {
      87                 :            :                 mpi_size_t i;
      88         [ #  # ]:          0 :                 for (i = 0; i < s1_size - 1; i++)
      89                 :          0 :                         res_ptr[i] = s1_ptr[i];
      90                 :            :         }
      91                 :            :         return 0;
      92                 :            : }
      93                 :            : 
      94                 :            : G10_MPI_INLINE_DECL mpi_limb_t
      95                 :          0 : 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                 :          0 :         mpi_limb_t cy = 0;
      99                 :            : 
     100         [ #  # ]:          0 :         if (s2_size)
     101                 :          0 :                 cy = mpihelp_sub_n(res_ptr, s1_ptr, s2_ptr, s2_size);
     102                 :            : 
     103         [ #  # ]:          0 :         if (s1_size - s2_size)
     104                 :          0 :                 cy = mpihelp_sub_1(res_ptr + s2_size, s1_ptr + s2_size,
     105                 :            :                                    s1_size - s2_size, cy);
     106                 :          0 :         return cy;
     107                 :            : }
     108                 :            : 
     109                 :            : #endif /*G10_MPI_INLINE_H */

Generated by: LCOV version 1.14