1*8f76bb7dSCy Schubert /* 2*8f76bb7dSCy Schubert * util/rfc_1982.c - RFC 1982 Serial Number Arithmetic 3*8f76bb7dSCy Schubert * 4*8f76bb7dSCy Schubert * Copyright (c) 2023, NLnet Labs. All rights reserved. 5*8f76bb7dSCy Schubert * 6*8f76bb7dSCy Schubert * This software is open source. 7*8f76bb7dSCy Schubert * 8*8f76bb7dSCy Schubert * Redistribution and use in source and binary forms, with or without 9*8f76bb7dSCy Schubert * modification, are permitted provided that the following conditions 10*8f76bb7dSCy Schubert * are met: 11*8f76bb7dSCy Schubert * 12*8f76bb7dSCy Schubert * Redistributions of source code must retain the above copyright notice, 13*8f76bb7dSCy Schubert * this list of conditions and the following disclaimer. 14*8f76bb7dSCy Schubert * 15*8f76bb7dSCy Schubert * Redistributions in binary form must reproduce the above copyright notice, 16*8f76bb7dSCy Schubert * this list of conditions and the following disclaimer in the documentation 17*8f76bb7dSCy Schubert * and/or other materials provided with the distribution. 18*8f76bb7dSCy Schubert * 19*8f76bb7dSCy Schubert * Neither the name of the NLNET LABS nor the names of its contributors may 20*8f76bb7dSCy Schubert * be used to endorse or promote products derived from this software without 21*8f76bb7dSCy Schubert * specific prior written permission. 22*8f76bb7dSCy Schubert * 23*8f76bb7dSCy Schubert * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 24*8f76bb7dSCy Schubert * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 25*8f76bb7dSCy Schubert * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 26*8f76bb7dSCy Schubert * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 27*8f76bb7dSCy Schubert * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 28*8f76bb7dSCy Schubert * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED 29*8f76bb7dSCy Schubert * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 30*8f76bb7dSCy Schubert * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 31*8f76bb7dSCy Schubert * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 32*8f76bb7dSCy Schubert * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 33*8f76bb7dSCy Schubert * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 34*8f76bb7dSCy Schubert */ 35*8f76bb7dSCy Schubert 36*8f76bb7dSCy Schubert /** 37*8f76bb7dSCy Schubert * \file 38*8f76bb7dSCy Schubert * 39*8f76bb7dSCy Schubert * This file contains functions for RFC 1982 serial number arithmetic. 40*8f76bb7dSCy Schubert */ 41*8f76bb7dSCy Schubert #include "config.h" 42*8f76bb7dSCy Schubert 43*8f76bb7dSCy Schubert int 44*8f76bb7dSCy Schubert compare_1982(uint32_t a, uint32_t b) 45*8f76bb7dSCy Schubert { 46*8f76bb7dSCy Schubert /* for 32 bit values */ 47*8f76bb7dSCy Schubert const uint32_t cutoff = ((uint32_t) 1 << (32 - 1)); 48*8f76bb7dSCy Schubert 49*8f76bb7dSCy Schubert if (a == b) { 50*8f76bb7dSCy Schubert return 0; 51*8f76bb7dSCy Schubert } else if ((a < b && b - a < cutoff) || (a > b && a - b > cutoff)) { 52*8f76bb7dSCy Schubert return -1; 53*8f76bb7dSCy Schubert } else { 54*8f76bb7dSCy Schubert return 1; 55*8f76bb7dSCy Schubert } 56*8f76bb7dSCy Schubert } 57*8f76bb7dSCy Schubert 58*8f76bb7dSCy Schubert uint32_t 59*8f76bb7dSCy Schubert subtract_1982(uint32_t a, uint32_t b) 60*8f76bb7dSCy Schubert { 61*8f76bb7dSCy Schubert /* for 32 bit values */ 62*8f76bb7dSCy Schubert const uint32_t cutoff = ((uint32_t) 1 << (32 - 1)); 63*8f76bb7dSCy Schubert 64*8f76bb7dSCy Schubert if(a == b) 65*8f76bb7dSCy Schubert return 0; 66*8f76bb7dSCy Schubert if(a < b && b - a < cutoff) { 67*8f76bb7dSCy Schubert return b-a; 68*8f76bb7dSCy Schubert } 69*8f76bb7dSCy Schubert if(a > b && a - b > cutoff) { 70*8f76bb7dSCy Schubert return ((uint32_t)0xffffffff) - (a-b-1); 71*8f76bb7dSCy Schubert } 72*8f76bb7dSCy Schubert /* wrong case, b smaller than a */ 73*8f76bb7dSCy Schubert return 0; 74*8f76bb7dSCy Schubert } 75