custom-uv-k5-firmware/misc.c

211 lines
4.7 KiB
C
Raw Normal View History

/* Copyright 2023 Dual Tachyon
* https://github.com/DualTachyon
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <string.h>
#include "misc.h"
const uint32_t *gUpperLimitFrequencyBandTable;
const uint32_t *gLowerLimitFrequencyBandTable;
bool gSetting_350TX;
bool gSetting_KILLED;
bool gSetting_200TX;
bool gSetting_500TX;
bool gSetting_350EN;
uint8_t gSetting_F_LOCK;
bool gSetting_ScrambleEnable;
uint8_t gSetting_F_LOCK;
uint32_t gCustomPasswordKey[4];
bool bIsCheckExistingPassword;
uint8_t gEEPROM_1EC0_0[8];
uint8_t gEEPROM_1EC0_1[8];
uint8_t gEEPROM_1EC0_2[8];
uint8_t gEEPROM_1EC0_3[8];
2023-08-26 19:13:18 +08:00
uint16_t gEEPROM_RSSI_CALIB[3][4];
uint16_t gEEPROM_1F8A;
uint16_t gEEPROM_1F8C;
uint8_t gMR_ChannelParameters[207];
2023-08-16 05:39:26 +08:00
volatile bool gNextTimeslice500ms;
2023-08-15 06:38:59 +08:00
volatile uint16_t g_2000032E;
volatile uint16_t g_2000033A;
2023-08-16 05:39:26 +08:00
volatile uint16_t gTxTimerCountdown = 1000;
2023-08-15 06:38:59 +08:00
volatile uint16_t g_20000342;
volatile uint16_t g_2000034C;
volatile uint16_t g_20000356;
2023-08-16 02:02:42 +08:00
uint16_t g_20000362;
uint8_t g_2000036B;
2023-08-26 18:20:06 +08:00
uint8_t gKeyLockCountdown;
uint8_t g_2000036D;
2023-08-14 19:28:09 +08:00
uint8_t g_2000036E;
uint8_t g_2000036F;
2023-08-14 19:28:09 +08:00
uint8_t g_20000370;
uint8_t g_20000371[2];
uint8_t g_20000373;
2023-08-14 19:28:09 +08:00
uint8_t g_20000375;
uint8_t g_20000376;
uint8_t g_20000377;
2023-08-15 21:24:40 +08:00
uint8_t gVFO_RSSI_Level[2];
2023-08-14 19:28:09 +08:00
uint8_t g_2000037E;
2023-08-26 18:20:06 +08:00
uint8_t gBatteryVoltageIndex;
2023-08-15 06:38:59 +08:00
volatile uint8_t g_20000381;
2023-08-16 02:02:42 +08:00
uint8_t g_20000382;
2023-08-15 00:30:30 +08:00
uint8_t g_20000383;
2023-08-14 19:28:09 +08:00
uint16_t g_2000038E;
2023-08-26 18:20:06 +08:00
uint8_t g_20000393;
bool g_20000394;
2023-08-24 20:55:40 +08:00
uint8_t gKeypadLocked;
2023-08-14 05:40:33 +08:00
uint8_t g_200003AA;
2023-08-16 06:46:09 +08:00
bool g_CDCSS_Lost;
bool g_CTCSS_Lost;
bool g_CxCSS_TAIL_Found;
bool g_VOX_Lost;
2023-08-14 05:40:33 +08:00
uint8_t g_200003B0;
2023-08-26 18:20:06 +08:00
uint8_t gFlashLightState;
uint8_t g_200003B3;
2023-08-14 19:28:09 +08:00
uint16_t g_200003B6;
2023-08-26 18:20:06 +08:00
uint16_t g_200003B8;
2023-08-14 19:28:09 +08:00
uint8_t g_200003BC;
uint8_t g_200003BD;
2023-08-14 19:28:09 +08:00
uint8_t g_200003BE;
2023-08-26 18:20:06 +08:00
bool g_200003C1;
uint8_t g_200003C3;
2023-08-26 18:20:06 +08:00
uint8_t g_200003C4;
uint16_t g_200003E2;
volatile uint16_t gFlashLightBlinkCounter;
uint8_t g_200003FD;
2023-08-14 19:28:09 +08:00
uint8_t g_20000400;
2023-08-15 21:24:40 +08:00
uint8_t g_20000410;
uint8_t g_20000411;
2023-08-16 02:02:42 +08:00
uint8_t g_20000413;
uint8_t g_20000415;
uint8_t g_20000416;
uint8_t g_2000041F;
2023-08-15 00:30:30 +08:00
uint8_t g_20000420;
2023-08-16 02:02:42 +08:00
uint8_t g_20000427;
2023-08-26 08:47:17 +08:00
bool gKeyBeingHeld;
bool gPttIsPressed;
2023-08-26 18:20:06 +08:00
uint8_t gPttDebounceCounter;
2023-08-16 06:54:04 +08:00
uint8_t gDTMF_WriteIndex;
2023-08-15 00:30:30 +08:00
uint8_t g_20000438;
2023-08-22 06:47:16 +08:00
uint8_t gMenuListCount;
2023-08-26 18:20:06 +08:00
uint8_t g_20000442;
2023-08-14 19:28:09 +08:00
uint8_t g_20000458;
2023-08-26 08:46:21 +08:00
uint8_t g_CxCSS_Type;
uint8_t g_CxCSS_Index;
2023-08-14 19:28:09 +08:00
uint8_t g_2000045C;
2023-08-26 18:20:06 +08:00
uint8_t g_2000045D;
uint8_t g_2000045F;
2023-08-14 19:28:09 +08:00
uint8_t g_20000461;
uint8_t g_20000464;
2023-08-26 18:20:06 +08:00
uint8_t gAircopySendCountdown;
uint8_t gFSKWriteIndex;
2023-08-16 02:02:42 +08:00
uint8_t g_20000474;
2023-08-24 20:55:40 +08:00
char g_20000D1C[15];
2023-08-16 06:54:04 +08:00
char gDTMF_Received[16];
2023-08-22 06:47:16 +08:00
bool gIsDtmfContactValid;
char gDTMF_ID[4];
char gDTMF_Contact0[4];
char gDTMF_Contact1[4];
2023-08-24 20:55:40 +08:00
uint8_t g_CalloutAndDTMF_State;
2023-08-14 05:40:33 +08:00
2023-08-14 19:28:09 +08:00
bool gIs_A_Scan;
bool gIsNoaaMode;
2023-08-15 18:14:43 +08:00
volatile bool gNextTimeslice;
2023-08-16 02:02:42 +08:00
uint8_t gNoaaChannel;
2023-08-14 19:28:09 +08:00
bool gUpdateDisplay;
2023-08-26 18:14:43 +08:00
uint8_t gFmRadioCountdown;
2023-08-14 19:28:09 +08:00
uint8_t gA_Scan_Channel;
uint8_t gDebounceCounter;
uint8_t gDTMF_AUTO_RESET_TIME;
uint8_t gF_LOCK;
char gNumberForPrintf[8];
uint8_t gNumberOffset;
2023-08-14 19:28:09 +08:00
uint8_t gScanChannel;
uint32_t gScanFrequency;
2023-08-15 21:24:40 +08:00
uint8_t gScanPauseMode;
2023-08-14 19:28:09 +08:00
uint8_t gScanState;
uint8_t gShowChPrefix;
2023-08-15 06:38:59 +08:00
volatile uint16_t gSystickCountdown2;
volatile uint8_t gSystickCountdown3;
volatile uint8_t gSystickCountdown4;
volatile uint16_t gSystickCountdown11;
volatile bool gSystickFlag0;
2023-08-16 05:39:26 +08:00
volatile bool gNextTimeslice40ms;
2023-08-15 06:38:59 +08:00
volatile bool gSystickFlag5;
2023-08-15 18:14:43 +08:00
volatile bool gBatterySaveCountdownExpired;
2023-08-15 06:38:59 +08:00
volatile bool gSystickFlag7;
volatile bool gSystickFlag8;
volatile bool gSystickFlag9;
volatile bool gSystickFlag10;
volatile bool gSystickFlag11;
volatile uint16_t ScanPauseDelayIn10msec;
2023-08-14 05:40:33 +08:00
2023-08-16 06:46:09 +08:00
// This probably should be signed! But Ghidra disgrees
uint16_t gFM_FrequencyDeviation;
uint16_t gCurrentRSSI;
2023-08-14 19:28:09 +08:00
// --------
2023-08-14 19:28:09 +08:00
void NUMBER_Append(char Digit)
{
if (gNumberOffset == 0) {
2023-08-14 07:08:50 +08:00
memset(gNumberForPrintf, 10, sizeof(gNumberForPrintf));
2023-08-14 06:54:06 +08:00
} else if (gNumberOffset >= sizeof(gNumberForPrintf)) {
return;
}
gNumberForPrintf[gNumberOffset++] = Digit;
}
2023-08-14 19:28:09 +08:00
void NUMBER_Get(char *pDigits, uint32_t *pInteger)
{
uint32_t Value;
uint32_t Multiplier;
uint8_t i;
Multiplier = 10000000;
Value = 0;
for (i = 0; i < 8; i++) {
if (pDigits[i] > 9) {
break;
}
Value += pDigits[i] * Multiplier;
Multiplier /= 10U;
}
*pInteger = Value;
}
2023-08-14 19:28:09 +08:00
void NUMBER_ToDigits(uint32_t Value, char *pDigits)
{
uint8_t i;
for (i = 0; i < 8; i++) {
uint32_t Result = Value / 10U;
pDigits[7 - i] = Value - (Result * 10U);
Value = Result;
}
}