/** * Digital Voice Modem - DSP Firmware (Hotspot) * GPLv2 Open Source. Use is subject to license terms. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * @package DVM / DSP Firmware (Hotspot) * */ // // Based on code from the MMDVM_HS project. (https://github.com/juribeparada/MMDVM_HS) // Licensed under the GPLv2 License (https://opensource.org/licenses/GPL-2.0) // /* * Copyright (C) 2015,2020 by Jonathan Naylor G4KLX * Copyright (C) 2017 by Andy Uribe CA6JAU * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include "Utils.h" // --------------------------------------------------------------------------- // Constants/Macros // --------------------------------------------------------------------------- const uint8_t BITS_TABLE[] = { # define B2(n) n, n+1, n+1, n+2 # define B4(n) B2(n), B2(n+1), B2(n+1), B2(n+2) # define B6(n) B4(n), B4(n+1), B4(n+1), B4(n+2) B6(0), B6(1), B6(1), B6(2) }; // --------------------------------------------------------------------------- // Global Functions // --------------------------------------------------------------------------- uint8_t countBits8(uint8_t bits) { return BITS_TABLE[bits]; } uint8_t countBits16(uint16_t bits) { uint8_t* p = (uint8_t*)&bits; uint8_t n = 0U; n += BITS_TABLE[p[0U]]; n += BITS_TABLE[p[1U]]; return n; } uint8_t countBits32(uint32_t bits) { uint8_t* p = (uint8_t*)&bits; uint8_t n = 0U; n += BITS_TABLE[p[0U]]; n += BITS_TABLE[p[1U]]; n += BITS_TABLE[p[2U]]; n += BITS_TABLE[p[3U]]; return n; } uint8_t countBits64(uint64_t bits) { uint8_t* p = (uint8_t*)&bits; uint8_t n = 0U; n += BITS_TABLE[p[0U]]; n += BITS_TABLE[p[1U]]; n += BITS_TABLE[p[2U]]; n += BITS_TABLE[p[3U]]; n += BITS_TABLE[p[4U]]; n += BITS_TABLE[p[5U]]; n += BITS_TABLE[p[6U]]; n += BITS_TABLE[p[7U]]; return n; }