MMDVM/DPMRDefines.h

121 lines
5.3 KiB
C

/*
* Copyright (C) 2016,2017,2018,2024 by Jonathan Naylor G4KLX
*
* 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.
*/
#if !defined(DPMRDEFINES_H)
#define DPMRDEFINES_H
const unsigned int DPMR_RADIO_SYMBOL_LENGTH = 10U; // At 24 kHz sample rate
const unsigned int DPMR_HEADER_FRAME_LENGTH_BITS = 312U;
const unsigned int DPMR_HEADER_FRAME_LENGTH_BYTES = DPMR_HEADER_FRAME_LENGTH_BITS / 8U;
const unsigned int DPMR_HEADER_FRAME_LENGTH_SYMBOLS = DPMR_HEADER_FRAME_LENGTH_BITS / 2U;
const unsigned int DPMR_HEADER_FRAME_LENGTH_SAMPLES = DPMR_HEADER_FRAME_LENGTH_SYMBOLS * DPMR_RADIO_SYMBOL_LENGTH;
const unsigned int DPMR_DATA_FRAME_LENGTH_BITS = 384U;
const unsigned int DPMR_DATA_FRAME_LENGTH_BYTES = DPMR_DATA_FRAME_LENGTH_BITS / 8U;
const unsigned int DPMR_DATA_FRAME_LENGTH_SYMBOLS = DPMR_DATA_FRAME_LENGTH_BITS / 2U;
const unsigned int DPMR_DATA_FRAME_LENGTH_SAMPLES = DPMR_DATA_FRAME_LENGTH_SYMBOLS * DPMR_RADIO_SYMBOL_LENGTH;
const unsigned int DPMR_END_FRAME_LENGTH_BITS = 96U;
const unsigned int DPMR_END_FRAME_LENGTH_BYTES = DPMR_END_FRAME_LENGTH_BITS / 8U;
const unsigned int DPMR_END_FRAME_LENGTH_SYMBOLS = DPMR_END_FRAME_LENGTH_BITS / 2U;
const unsigned int DPMR_END_FRAME_LENGTH_SAMPLES = DPMR_END_FRAME_LENGTH_SYMBOLS * DPMR_RADIO_SYMBOL_LENGTH;
const unsigned int DPMR_FS1_LENGTH_BITS = 48U;
const unsigned int DPMR_FS1_LENGTH_SYMBOLS = DPMR_FS1_LENGTH_BITS / 2U;
const unsigned int DPMR_FS1_LENGTH_SAMPLES = DPMR_FS1_LENGTH_SYMBOLS * DPMR_RADIO_SYMBOL_LENGTH;
const unsigned int DPMR_FS2_LENGTH_BITS = 24U;
const unsigned int DPMR_FS2_LENGTH_SYMBOLS = DPMR_FS2_LENGTH_BITS / 2U;
const unsigned int DPMR_FS2_LENGTH_SAMPLES = DPMR_FS2_LENGTH_SYMBOLS * DPMR_RADIO_SYMBOL_LENGTH;
const unsigned int DPMR_FS3_LENGTH_BITS = 24U;
const unsigned int DPMR_FS3_LENGTH_SYMBOLS = DPMR_FS3_LENGTH_BITS / 2U;
const unsigned int DPMR_FS3_LENGTH_SAMPLES = DPMR_FS3_LENGTH_SYMBOLS * DPMR_RADIO_SYMBOL_LENGTH;
const unsigned int DPMR_FS4_LENGTH_BITS = 48U;
const unsigned int DPMR_FS4_LENGTH_SYMBOLS = DPMR_FS4_LENGTH_BITS / 2U;
const unsigned int DPMR_FS4_LENGTH_SAMPLES = DPMR_FS4_LENGTH_SYMBOLS * DPMR_RADIO_SYMBOL_LENGTH;
const uint8_t DPMR_FS1_BYTES[] = {0x57U, 0xFFU, 0x5FU, 0x75U, 0xD5U, 0x77U};
const uint8_t DPMR_FS1_BYTES_LENGTH = 6U;
const uint8_t DPMR_FS2_BYTES[] = {0x5FU, 0xF7U, 0x7DU};
const uint8_t DPMR_FS2_BYTES_LENGTH = 3U;
const uint8_t DPMR_FS3_BYTES[] = {0x7DU, 0xDFU, 0xF5U};
const uint8_t DPMR_FS3_BYTES_LENGTH = 3U;
const uint8_t DPMR_FS4_BYTES[] = {0xFDU, 0x55U, 0xF5U, 0xDFU, 0x7FU, 0xDDU};
const uint8_t DPMR_FS4_BYTES_LENGTH = 6U;
const uint64_t DPMR_FS1_BITS = 0x000057FF5F75D577U;
const uint64_t DPMR_FS1_BITS_MASK = 0x0000FFFFFFFFFFFFU;
const uint64_t DPMR_FS2_BITS = 0x00000000005FF77DU;
const uint64_t DPMR_FS2_BITS_MASK = 0x0000000000FFFFFFU;
const uint64_t DPMR_FS3_BITS = 0x00000000007DDFF5U;
const uint64_t DPMR_FS3_BITS_MASK = 0x0000000000FFFFFFU;
const uint64_t DPMR_FS4_BITS = 0x0000FD55F5DF7FDDU;
const uint64_t DPMR_FS4_BITS_MASK = 0x0000FFFFFFFFFFFFU;
// FS1
// 5 5 F F 5 F 7 5 D 5 7 7
// 01 01 01 11 11 11 11 11 01 01 11 11 01 11 01 01 11 01 01 01 01 11 01 11
// +3 +3 +3 -3 -3 -3 -3 -3 +3 +3 -3 -3 +3 -3 +3 +3 -3 +3 +3 +3 +3 -3 +3 -3
const int8_t DPMR_FS1_SYMBOLS_VALUES[] = {+3, +3, +3, -3, -3, -3, -3, -3, +3, +3, -3, -3, +3, -3, +3, +3, -3, +3, +3, +3, +3, -3, +3, -3};
const uint32_t DPMR_FS1_SYMBOLS = 0x00E0CB7AU;
const uint32_t DPMR_FS1_SYMBOLS_MASK = 0x00FFFFFFU;
// FS2
// 5 F F 7 7 D
// 01 01 11 11 11 11 01 11 01 11 11 01
// +3 +3 -3 -3 -3 -3 +3 -3 +3 -3 -3 +3
const int8_t DPMR_FS2_SYMBOLS_VALUES[] = {+3, +3, -3, -3, -3, -3, +3, -3, +3, -3, -3, +3};
const uint32_t DPMR_FS2_SYMBOLS = 0x00000C29U;
const uint32_t DPMR_FS2_SYMBOLS_MASK = 0x00000FFFU;
// FS3
// 7 D D F F 5
// 01 11 11 01 11 01 11 11 11 11 01 01
// +3 -3 -3 +3 -3 +3 -3 -3 -3 -3 +3 +3
const int8_t DPMR_FS3_SYMBOLS_VALUES[] = {+3, -3, -3, +3, -3, +3, -3, -3, -3, -3, +3, +3};
const uint32_t DPMR_FS3_SYMBOLS = 0x00000943U;
const uint32_t DPMR_FS3_SYMBOLS_MASK = 0x00000FFFU;
// FS4
// F D 5 5 F 5 D F 7 F D D
// 11 11 11 01 01 01 01 01 11 11 01 01 11 01 11 11 01 11 11 11 11 01 11 01
// -3 -3 -3 +3 +3 +3 +3 +3 -3 -3 +3 +3 -3 +3 -3 -3 +3 -3 -3 -3 -3 +3 -3 +3
const int8_t DPMR_FS4_SYMBOLS_VALUES[] = {-3, -3, -3, +3, +3, +3, +3, +3, -3, -3, +3, +3, -3, +3, -3, -3, +3, -3, -3, -3, -3, +3, -3, +3};
const uint32_t DPMR_FS4_SYMBOLS = 0x001F3485U;
const uint32_t DPMR_FS4_SYMBOLS_MASK = 0x00FFFFFFU;
#endif