about summary refs log tree commit diff
path: root/src/libbiguint/bu_addc.c
blob: cccc7a87b98fbe65e0a1bdd535ccce0cee25a01d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/* ISC license. */

/* OpenBSD needs that for EOVERFLOW. wtfbsdseriously */
#ifndef _BSD_SOURCE
#define _BSD_SOURCE
#endif

#include <errno.h>
#include <skalibs/uint32.h>
#include <skalibs/biguint.h>

int bu_addc (uint32 *c, unsigned int cn, uint32 const *a, unsigned int an, uint32 const *b, unsigned int bn, register int carry)
{
  register unsigned int i = 0 ;
  for (; i < cn ; i++)
  {
    register uint32 ai = (i < an) ? a[i] : 0 ;
    register uint32 bi = (i < bn) ? b[i] : 0 ;
    register uint32 ci = ai + bi + carry ;
    carry = (carry || bi) && (ci < ai) ;
    c[i] = ci ;
  }
  return carry ? (errno = EOVERFLOW, 0) : 1 ;
}