You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
79 lines
2.0 KiB
79 lines
2.0 KiB
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*
|
|
* Digital Voice Modem - Hotspot Firmware
|
|
* GPLv2 Open Source. Use is subject to license terms.
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* @package DVM / Hotspot Firmware
|
|
* @derivedfrom MMDVM_HS (https://github.com/g4klx/MMDVM_HS)
|
|
* @license GPLv2 License (https://opensource.org/licenses/GPL-2.0)
|
|
*
|
|
* Copyright (C) 2015,2020 Jonathan Naylor, G4KLX
|
|
* Copyright (C) 2017 Andy Uribe, CA6JAU
|
|
*
|
|
*/
|
|
#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
|
|
// ---------------------------------------------------------------------------
|
|
|
|
/* Returns the count of bits in the passed 8 byte value. */
|
|
|
|
uint8_t countBits8(uint8_t bits)
|
|
{
|
|
return BITS_TABLE[bits];
|
|
}
|
|
|
|
/* Returns the count of bits in the passed 16 byte value. */
|
|
|
|
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;
|
|
}
|
|
|
|
/* Returns the count of bits in the passed 32 byte value. */
|
|
|
|
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;
|
|
}
|
|
|
|
/* Returns the count of bits in the passed 64 byte value. */
|
|
|
|
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;
|
|
}
|