mirror of
https://github.com/silenty4ng/uv-k5-firmware-chinese-lts
synced 2025-01-15 14:54:40 +00:00
F Lock change
This commit is contained in:
parent
07da68f946
commit
f4e3140743
15 changed files with 1575 additions and 1574 deletions
|
@ -20,51 +20,19 @@
|
||||||
</configurations>
|
</configurations>
|
||||||
</component>
|
</component>
|
||||||
<component name="ChangeListManager">
|
<component name="ChangeListManager">
|
||||||
<list default="true" id="cea36e80-e289-4d69-9030-7186d540ac0e" name="更改" comment="create">
|
<list default="true" id="cea36e80-e289-4d69-9030-7186d540ac0e" name="更改" comment="rebuild chinese">
|
||||||
<change afterPath="$PROJECT_DIR$/chinese.h" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/.idea/encodings.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/encodings.xml" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/CMakeLists.txt" beforeDir="false" afterPath="$PROJECT_DIR$/CMakeLists.txt" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/Dockerfile" beforeDir="false" afterPath="$PROJECT_DIR$/Dockerfile" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/Makefile" beforeDir="false" afterPath="$PROJECT_DIR$/Makefile" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/Makefile" beforeDir="false" afterPath="$PROJECT_DIR$/Makefile" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/app/action.c" beforeDir="false" afterPath="$PROJECT_DIR$/app/action.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/app/app.c" beforeDir="false" afterPath="$PROJECT_DIR$/app/app.c" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/app/app.c" beforeDir="false" afterPath="$PROJECT_DIR$/app/app.c" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/app/menu.c" beforeDir="false" afterPath="$PROJECT_DIR$/app/menu.c" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/app/common.c" beforeDir="false" afterPath="$PROJECT_DIR$/app/common.c" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/board.c" beforeDir="false" afterPath="$PROJECT_DIR$/board.c" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/debugging.h" beforeDir="false" afterPath="$PROJECT_DIR$/debugging.h" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/.cmake/api/v1/reply/cache-v2-e133ac29dbbc8b51f9f8.json" beforeDir="false" />
|
<change beforePath="$PROJECT_DIR$/driver/bk4819.c" beforeDir="false" afterPath="$PROJECT_DIR$/driver/bk4819.c" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/.cmake/api/v1/reply/cmakeFiles-v1-9ba3a415d1d17549d4f8.json" beforeDir="false" />
|
<change beforePath="$PROJECT_DIR$/driver/bk4819.h" beforeDir="false" afterPath="$PROJECT_DIR$/driver/bk4819.h" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/.cmake/api/v1/reply/codemodel-v2-886bf84a88b6efd9f87a.json" beforeDir="false" />
|
<change beforePath="$PROJECT_DIR$/payment/sponsors.md" beforeDir="false" afterPath="$PROJECT_DIR$/payment/sponsors.md" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/.cmake/api/v1/reply/index-2023-11-27T04-16-10-0515.json" beforeDir="false" />
|
<change beforePath="$PROJECT_DIR$/ui/status.c" beforeDir="false" afterPath="$PROJECT_DIR$/ui/status.c" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/.cmake/api/v1/reply/target-uv_k5_firmware_custom_0_17-Debug-25dfbe50397c72844ddd.json" beforeDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/CMakeCache.txt" beforeDir="false" afterPath="$PROJECT_DIR$/cmake-build-debug/CMakeCache.txt" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/CMakeFiles/Makefile.cmake" beforeDir="false" afterPath="$PROJECT_DIR$/cmake-build-debug/CMakeFiles/Makefile.cmake" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/CMakeFiles/clion-Debug-log.txt" beforeDir="false" afterPath="$PROJECT_DIR$/cmake-build-debug/CMakeFiles/clion-Debug-log.txt" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/CMakeFiles/uv_k5_firmware_custom_0_17.dir/compiler_depend.internal" beforeDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/CMakeFiles/uv_k5_firmware_custom_0_17.dir/compiler_depend.make" beforeDir="false" afterPath="$PROJECT_DIR$/cmake-build-debug/CMakeFiles/uv_k5_firmware_custom_0_17.dir/compiler_depend.make" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/cmake-build-debug/uv_k5_firmware_custom_0_17.cbp" beforeDir="false" afterPath="$PROJECT_DIR$/cmake-build-debug/uv_k5_firmware_custom_0_17.cbp" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/driver/backlight.c" beforeDir="false" afterPath="$PROJECT_DIR$/driver/backlight.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/font.c" beforeDir="false" afterPath="$PROJECT_DIR$/font.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/font.h" beforeDir="false" afterPath="$PROJECT_DIR$/font.h" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/settings.c" beforeDir="false" afterPath="$PROJECT_DIR$/settings.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/settings.h" beforeDir="false" afterPath="$PROJECT_DIR$/settings.h" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/ui/helper.c" beforeDir="false" afterPath="$PROJECT_DIR$/ui/helper.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/ui/main.c" beforeDir="false" afterPath="$PROJECT_DIR$/ui/main.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/ui/menu.c" beforeDir="false" afterPath="$PROJECT_DIR$/ui/menu.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/ui/menu.h" beforeDir="false" afterPath="$PROJECT_DIR$/ui/menu.h" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/ui/scanner.c" beforeDir="false" afterPath="$PROJECT_DIR$/ui/scanner.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/ui/welcome.c" beforeDir="false" afterPath="$PROJECT_DIR$/ui/welcome.c" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/chinese_array.txt" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/chinese_array.txt" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/cmake-build-debug/CMakeFiles/uv_k5font.dir/font.cpp.obj" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/cmake-build-debug/CMakeFiles/uv_k5font.dir/font.cpp.obj" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/cmake-build-debug/CMakeFiles/uv_k5font.dir/main.cpp.obj" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/cmake-build-debug/CMakeFiles/uv_k5font.dir/main.cpp.obj" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/cmake-build-debug/CMakeFiles/uv_k5font.dir/objects.a" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/cmake-build-debug/CMakeFiles/uv_k5font.dir/objects.a" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/cmake-build-debug/Testing/Temporary/LastTest.log" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/cmake-build-debug/Testing/Temporary/LastTest.log" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/cmake-build-debug/uv_k5font.exe" beforeDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/ee" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/ee" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/uv-k5font/ee" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/ee" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/font.cpp" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/font.cpp" afterDir="false" />
|
<change beforePath="$PROJECT_DIR$/uv-k5font/font.xlsx" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/font.xlsx" afterDir="false" />
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/font.h" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/font.h" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/main.cpp" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/main.cpp" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/name.txt" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/name.txt" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/name_out.txt" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/name_out.txt" afterDir="false" />
|
|
||||||
<change beforePath="$PROJECT_DIR$/uv-k5font/name_tmp.txt" beforeDir="false" afterPath="$PROJECT_DIR$/uv-k5font/name_tmp.txt" afterDir="false" />
|
|
||||||
</list>
|
</list>
|
||||||
<option name="SHOW_DIALOG" value="false" />
|
<option name="SHOW_DIALOG" value="false" />
|
||||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||||
|
@ -79,11 +47,11 @@
|
||||||
<option name="PUSH_AUTO_UPDATE" value="true" />
|
<option name="PUSH_AUTO_UPDATE" value="true" />
|
||||||
<option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
|
<option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
|
||||||
</component>
|
</component>
|
||||||
<component name="GitHubPullRequestSearchHistory"><![CDATA[{
|
<component name="GitHubPullRequestSearchHistory">{
|
||||||
"lastFilter": {
|
"lastFilter": {
|
||||||
"state": "OPEN"
|
"state": "OPEN"
|
||||||
}
|
}
|
||||||
}]]></component>
|
}</component>
|
||||||
<component name="GithubPullRequestsUISettings">
|
<component name="GithubPullRequestsUISettings">
|
||||||
<option name="selectedUrlAndAccountId">
|
<option name="selectedUrlAndAccountId">
|
||||||
<UrlAndAccount>
|
<UrlAndAccount>
|
||||||
|
@ -108,35 +76,35 @@
|
||||||
<option name="hideEmptyMiddlePackages" value="true" />
|
<option name="hideEmptyMiddlePackages" value="true" />
|
||||||
<option name="showLibraryContents" value="true" />
|
<option name="showLibraryContents" value="true" />
|
||||||
</component>
|
</component>
|
||||||
<component name="PropertiesComponent"><![CDATA[{
|
<component name="PropertiesComponent">{
|
||||||
"keyToString": {
|
"keyToString": {
|
||||||
"ASKED_ADD_EXTERNAL_FILES": "true",
|
"ASKED_ADD_EXTERNAL_FILES": "true",
|
||||||
"RunOnceActivity.OpenProjectViewOnStart": "true",
|
"RunOnceActivity.OpenProjectViewOnStart": "true",
|
||||||
"RunOnceActivity.ShowReadmeOnStart": "true",
|
"RunOnceActivity.ShowReadmeOnStart": "true",
|
||||||
"RunOnceActivity.cidr.known.project.marker": "true",
|
"RunOnceActivity.cidr.known.project.marker": "true",
|
||||||
"SHARE_PROJECT_CONFIGURATION_FILES": "true",
|
"SHARE_PROJECT_CONFIGURATION_FILES": "true",
|
||||||
"WebServerToolWindowFactoryState": "false",
|
"WebServerToolWindowFactoryState": "false",
|
||||||
"cf.first.check.clang-format": "false",
|
"cf.first.check.clang-format": "false",
|
||||||
"cidr.known.project.marker": "true",
|
"cidr.known.project.marker": "true",
|
||||||
"last_opened_file_path": "C:/Users/RUPC/Desktop/UV-K6/uv-k5-firmware-chinese",
|
"last_opened_file_path": "C:/Users/RUPC/Desktop/UV-K6/uv-k5-firmware-chinese",
|
||||||
"node.js.detected.package.eslint": "true",
|
"node.js.detected.package.eslint": "true",
|
||||||
"node.js.detected.package.tslint": "true",
|
"node.js.detected.package.tslint": "true",
|
||||||
"node.js.selected.package.eslint": "(autodetect)",
|
"node.js.selected.package.eslint": "(autodetect)",
|
||||||
"node.js.selected.package.tslint": "(autodetect)",
|
"node.js.selected.package.tslint": "(autodetect)",
|
||||||
"nodejs_package_manager_path": "npm",
|
"nodejs_package_manager_path": "npm",
|
||||||
"settings.editor.selected.configurable": "File.Encoding",
|
"settings.editor.selected.configurable": "File.Encoding",
|
||||||
"vue.rearranger.settings.migration": "true"
|
"vue.rearranger.settings.migration": "true"
|
||||||
}
|
}
|
||||||
}]]></component>
|
}</component>
|
||||||
<component name="RecentsManager">
|
<component name="RecentsManager">
|
||||||
<key name="CopyFile.RECENT_KEYS">
|
<key name="CopyFile.RECENT_KEYS">
|
||||||
<recent name="C:\Users\RUPC\Desktop\UV-K6\uv-k5-firmware-chinese" />
|
<recent name="C:\Users\RUPC\Desktop\UV-K6\uv-k5-firmware-chinese" />
|
||||||
</key>
|
</key>
|
||||||
</component>
|
</component>
|
||||||
<component name="RunManager">
|
<component name="RunManager">
|
||||||
<configuration default="true" type="CLionExternalRunConfiguration" factoryName="Application" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true">
|
<configuration default="true" type="CMakeRunConfiguration" factoryName="Application" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true">
|
||||||
<method v="2">
|
<method v="2">
|
||||||
<option name="CLION.EXTERNAL.BUILD" enabled="true" />
|
<option name="com.jetbrains.cidr.execution.CidrBuildBeforeRunTaskProvider$BuildBeforeRunTask" enabled="true" />
|
||||||
</method>
|
</method>
|
||||||
</configuration>
|
</configuration>
|
||||||
<configuration name="未命名" type="ShConfigurationType" nameIsGenerated="true">
|
<configuration name="未命名" type="ShConfigurationType" nameIsGenerated="true">
|
||||||
|
@ -170,7 +138,8 @@
|
||||||
<workItem from="1701228164424" duration="12580000" />
|
<workItem from="1701228164424" duration="12580000" />
|
||||||
<workItem from="1701243774198" duration="3118000" />
|
<workItem from="1701243774198" duration="3118000" />
|
||||||
<workItem from="1701269777451" duration="21031000" />
|
<workItem from="1701269777451" duration="21031000" />
|
||||||
<workItem from="1701325367312" duration="14298000" />
|
<workItem from="1701325367312" duration="22657000" />
|
||||||
|
<workItem from="1701413653518" duration="3544000" />
|
||||||
</task>
|
</task>
|
||||||
<task id="LOCAL-00001" summary="bug fix">
|
<task id="LOCAL-00001" summary="bug fix">
|
||||||
<created>1701136012311</created>
|
<created>1701136012311</created>
|
||||||
|
@ -270,7 +239,14 @@
|
||||||
<option name="project" value="LOCAL" />
|
<option name="project" value="LOCAL" />
|
||||||
<updated>1701326945551</updated>
|
<updated>1701326945551</updated>
|
||||||
</task>
|
</task>
|
||||||
<option name="localTasksCounter" value="15" />
|
<task id="LOCAL-00015" summary="rebuild chinese">
|
||||||
|
<created>1701353957333</created>
|
||||||
|
<option name="number" value="00015" />
|
||||||
|
<option name="presentableId" value="LOCAL-00015" />
|
||||||
|
<option name="project" value="LOCAL" />
|
||||||
|
<updated>1701353957333</updated>
|
||||||
|
</task>
|
||||||
|
<option name="localTasksCounter" value="16" />
|
||||||
<servers />
|
<servers />
|
||||||
</component>
|
</component>
|
||||||
<component name="TypeScriptGeneratedFilesManager">
|
<component name="TypeScriptGeneratedFilesManager">
|
||||||
|
@ -289,6 +265,7 @@
|
||||||
<MESSAGE value="lite create" />
|
<MESSAGE value="lite create" />
|
||||||
<MESSAGE value="lite aim" />
|
<MESSAGE value="lite aim" />
|
||||||
<MESSAGE value="create" />
|
<MESSAGE value="create" />
|
||||||
<option name="LAST_COMMIT_MESSAGE" value="create" />
|
<MESSAGE value="rebuild chinese" />
|
||||||
|
<option name="LAST_COMMIT_MESSAGE" value="rebuild chinese" />
|
||||||
</component>
|
</component>
|
||||||
</project>
|
</project>
|
|
@ -1,4 +1,4 @@
|
||||||
FROM archlinux:latest
|
FROM --platform=amd64 archlinux:latest
|
||||||
RUN pacman -Syyu base-devel --noconfirm
|
RUN pacman -Syyu base-devel --noconfirm
|
||||||
RUN pacman -Syyu arm-none-eabi-gcc --noconfirm
|
RUN pacman -Syyu arm-none-eabi-gcc --noconfirm
|
||||||
RUN pacman -Syyu arm-none-eabi-newlib --noconfirm
|
RUN pacman -Syyu arm-none-eabi-newlib --noconfirm
|
||||||
|
|
61
Makefile
61
Makefile
|
@ -2,11 +2,14 @@
|
||||||
# compile options (see README.md for descriptions)
|
# compile options (see README.md for descriptions)
|
||||||
# 0 = disable
|
# 0 = disable
|
||||||
# 1 = enable
|
# 1 = enable
|
||||||
#
|
|
||||||
|
# ---- COMPILER/LINKER OPTIONS ----
|
||||||
ENABLE_CLANG := 0
|
ENABLE_CLANG := 0
|
||||||
ENABLE_SWD := 0
|
ENABLE_SWD := 0
|
||||||
ENABLE_OVERLAY := 0
|
ENABLE_OVERLAY := 0
|
||||||
ENABLE_LTO := 1
|
ENABLE_LTO := 1
|
||||||
|
|
||||||
|
# ---- STOCK QUANSHENG FERATURES ----
|
||||||
ENABLE_UART := 1
|
ENABLE_UART := 1
|
||||||
ENABLE_AIRCOPY := 0
|
ENABLE_AIRCOPY := 0
|
||||||
ENABLE_FMRADIO := 1
|
ENABLE_FMRADIO := 1
|
||||||
|
@ -16,6 +19,9 @@ ENABLE_VOX := 1
|
||||||
ENABLE_ALARM := 0
|
ENABLE_ALARM := 0
|
||||||
ENABLE_TX1750 := 0
|
ENABLE_TX1750 := 0
|
||||||
ENABLE_PWRON_PASSWORD := 0
|
ENABLE_PWRON_PASSWORD := 0
|
||||||
|
ENABLE_DTMF_CALLING := 1
|
||||||
|
|
||||||
|
# ---- CUSTOM MODS ----
|
||||||
ENABLE_BIG_FREQ := 1
|
ENABLE_BIG_FREQ := 1
|
||||||
ENABLE_SMALL_BOLD := 1
|
ENABLE_SMALL_BOLD := 1
|
||||||
ENABLE_KEEP_MEM_NAME := 1
|
ENABLE_KEEP_MEM_NAME := 1
|
||||||
|
@ -39,11 +45,11 @@ ENABLE_REDUCE_LOW_MID_TX_POWER:= 0
|
||||||
ENABLE_BYP_RAW_DEMODULATORS := 0
|
ENABLE_BYP_RAW_DEMODULATORS := 0
|
||||||
ENABLE_BLMIN_TMP_OFF := 0
|
ENABLE_BLMIN_TMP_OFF := 0
|
||||||
ENABLE_SCAN_RANGES := 1
|
ENABLE_SCAN_RANGES := 1
|
||||||
ENABLE_DTMF_CALLING := 1
|
|
||||||
#############################################################
|
#############################################################
|
||||||
|
|
||||||
TARGET = firmware
|
TARGET = firmware
|
||||||
GIT_HASH := 111
|
|
||||||
$(info GIT_HASH = $(GIT_HASH))
|
|
||||||
ifeq ($(ENABLE_CLANG),1)
|
ifeq ($(ENABLE_CLANG),1)
|
||||||
# GCC's linker, ld, doesn't understand LLVM's generated bytecode
|
# GCC's linker, ld, doesn't understand LLVM's generated bytecode
|
||||||
ENABLE_LTO := 0
|
ENABLE_LTO := 0
|
||||||
|
@ -60,7 +66,6 @@ BSP_HEADERS := $(patsubst %.def,%.h,$(BSP_HEADERS))
|
||||||
|
|
||||||
OBJS =
|
OBJS =
|
||||||
# Startup files
|
# Startup files
|
||||||
|
|
||||||
OBJS += start.o
|
OBJS += start.o
|
||||||
OBJS += init.o
|
OBJS += init.o
|
||||||
ifeq ($(ENABLE_OVERLAY),1)
|
ifeq ($(ENABLE_OVERLAY),1)
|
||||||
|
@ -161,6 +166,20 @@ else
|
||||||
TOP := $(shell pwd)
|
TOP := $(shell pwd)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifdef OS # windows
|
||||||
|
RM = del /Q
|
||||||
|
FixPath = $(subst /,\,$1)
|
||||||
|
WHERE = where
|
||||||
|
NULL_OUTPUT = nul
|
||||||
|
else # unix
|
||||||
|
ifeq ($(shell uname), Linux)
|
||||||
|
RM = rm -f
|
||||||
|
FixPath = $1
|
||||||
|
WHERE = which
|
||||||
|
NULL_OUTPUT = /dev/null
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
AS = arm-none-eabi-gcc
|
AS = arm-none-eabi-gcc
|
||||||
|
|
||||||
CC =
|
CC =
|
||||||
|
@ -180,9 +199,16 @@ endif
|
||||||
OBJCOPY = arm-none-eabi-objcopy
|
OBJCOPY = arm-none-eabi-objcopy
|
||||||
SIZE = arm-none-eabi-size
|
SIZE = arm-none-eabi-size
|
||||||
|
|
||||||
|
AUTHOR_STRING := LOSEHU
|
||||||
# the user might not have/want git installed
|
# the user might not have/want git installed
|
||||||
# can set own version string here (max 7 chars)
|
# can set own version string here (max 7 chars)
|
||||||
#GIT_HASH := cn_all
|
ifneq (, $(shell $(WHERE) git))
|
||||||
|
VERSION_STRING := $(shell git describe --tags --exact-match 2>$(NULL_OUTPUT))
|
||||||
|
ifeq (, $(VERSION_STRING))
|
||||||
|
VERSION_STRING := $(shell git rev-parse --short HEAD)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
#VERSION_STRING := 230930b
|
||||||
|
|
||||||
|
|
||||||
ASFLAGS = -c -mcpu=cortex-m0
|
ASFLAGS = -c -mcpu=cortex-m0
|
||||||
|
@ -192,8 +218,7 @@ endif
|
||||||
|
|
||||||
CFLAGS =
|
CFLAGS =
|
||||||
ifeq ($(ENABLE_CLANG),0)
|
ifeq ($(ENABLE_CLANG),0)
|
||||||
CFLAGS += -Os -Wall -mcpu=cortex-m0 -fno-builtin -fshort-enums -fno-delete-null-pointer-checks -std=c11 -MMD
|
CFLAGS += -Os -Wall -Werror -mcpu=cortex-m0 -fno-builtin -fshort-enums -fno-delete-null-pointer-checks -std=c11 -MMD
|
||||||
#CFLAGS += -Os -Wall -Werror -mcpu=cortex-m0 -fno-builtin -fshort-enums -fno-delete-null-pointer-checks -std=c11 -MMD
|
|
||||||
#CFLAGS += -Os -Wall -Werror -mcpu=cortex-m0 -fno-builtin -fshort-enums -fno-delete-null-pointer-checks -std=c99 -MMD
|
#CFLAGS += -Os -Wall -Werror -mcpu=cortex-m0 -fno-builtin -fshort-enums -fno-delete-null-pointer-checks -std=c99 -MMD
|
||||||
#CFLAGS += -Os -Wall -Werror -mcpu=cortex-m0 -fno-builtin -fshort-enums -fno-delete-null-pointer-checks -std=gnu99 -MMD
|
#CFLAGS += -Os -Wall -Werror -mcpu=cortex-m0 -fno-builtin -fshort-enums -fno-delete-null-pointer-checks -std=gnu99 -MMD
|
||||||
#CFLAGS += -Os -Wall -Werror -mcpu=cortex-m0 -fno-builtin -fshort-enums -fno-delete-null-pointer-checks -std=gnu11 -MMD
|
#CFLAGS += -Os -Wall -Werror -mcpu=cortex-m0 -fno-builtin -fshort-enums -fno-delete-null-pointer-checks -std=gnu11 -MMD
|
||||||
|
@ -217,7 +242,7 @@ CFLAGS += -Wextra
|
||||||
#CFLAGS += -Wpedantic
|
#CFLAGS += -Wpedantic
|
||||||
|
|
||||||
CFLAGS += -DPRINTF_INCLUDE_CONFIG_H
|
CFLAGS += -DPRINTF_INCLUDE_CONFIG_H
|
||||||
CFLAGS += -DGIT_HASH=\"$(GIT_HASH)\"
|
CFLAGS += -DAUTHOR_STRING=\"$(AUTHOR_STRING)\" -DVERSION_STRING=\"$(VERSION_STRING)\"
|
||||||
|
|
||||||
ifeq ($(ENABLE_SPECTRUM),1)
|
ifeq ($(ENABLE_SPECTRUM),1)
|
||||||
CFLAGS += -DENABLE_SPECTRUM
|
CFLAGS += -DENABLE_SPECTRUM
|
||||||
|
@ -294,9 +319,6 @@ endif
|
||||||
ifeq ($(ENABLE_AM_FIX_SHOW_DATA),1)
|
ifeq ($(ENABLE_AM_FIX_SHOW_DATA),1)
|
||||||
CFLAGS += -DENABLE_AM_FIX_SHOW_DATA
|
CFLAGS += -DENABLE_AM_FIX_SHOW_DATA
|
||||||
endif
|
endif
|
||||||
ifeq ($(ENABLE_AM_FIX_TEST1),1)
|
|
||||||
CFLAGS += -DENABLE_AM_FIX_TEST1
|
|
||||||
endif
|
|
||||||
ifeq ($(ENABLE_SQUELCH_MORE_SENSITIVE),1)
|
ifeq ($(ENABLE_SQUELCH_MORE_SENSITIVE),1)
|
||||||
CFLAGS += -DENABLE_SQUELCH_MORE_SENSITIVE
|
CFLAGS += -DENABLE_SQUELCH_MORE_SENSITIVE
|
||||||
endif
|
endif
|
||||||
|
@ -336,6 +358,7 @@ endif
|
||||||
ifeq ($(ENABLE_DTMF_CALLING),1)
|
ifeq ($(ENABLE_DTMF_CALLING),1)
|
||||||
CFLAGS += -DENABLE_DTMF_CALLING
|
CFLAGS += -DENABLE_DTMF_CALLING
|
||||||
endif
|
endif
|
||||||
|
|
||||||
LDFLAGS =
|
LDFLAGS =
|
||||||
ifeq ($(ENABLE_CLANG),0)
|
ifeq ($(ENABLE_CLANG),0)
|
||||||
LDFLAGS += -mcpu=cortex-m0 -nostartfiles -Wl,-T,firmware.ld
|
LDFLAGS += -mcpu=cortex-m0 -nostartfiles -Wl,-T,firmware.ld
|
||||||
|
@ -367,17 +390,7 @@ LIBS =
|
||||||
|
|
||||||
DEPS = $(OBJS:.o=.d)
|
DEPS = $(OBJS:.o=.d)
|
||||||
|
|
||||||
ifdef OS
|
|
||||||
RM = del /Q
|
|
||||||
FixPath = $(subst /,\,$1)
|
|
||||||
WHERE = where
|
|
||||||
else
|
|
||||||
ifeq ($(shell uname), Linux)
|
|
||||||
RM = rm -f
|
|
||||||
FixPath = $1
|
|
||||||
WHERE = which
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifneq (, $(shell $(WHERE) python))
|
ifneq (, $(shell $(WHERE) python))
|
||||||
MY_PYTHON := python
|
MY_PYTHON := python
|
||||||
|
@ -402,7 +415,7 @@ else ifneq (,$(HAS_CRCMOD))
|
||||||
$(info !!!!!!!! run: pip install crcmod)
|
$(info !!!!!!!! run: pip install crcmod)
|
||||||
$(info )
|
$(info )
|
||||||
else
|
else
|
||||||
-$(MY_PYTHON) fw-pack.py $<.bin $(GIT_HASH) $<.packed.bin
|
-$(MY_PYTHON) fw-pack.py $<.bin $(AUTHOR_STRING) $(VERSION_STRING) $<.packed.bin
|
||||||
endif
|
endif
|
||||||
|
|
||||||
$(SIZE) $<
|
$(SIZE) $<
|
||||||
|
|
26
app/app.c
26
app/app.c
|
@ -507,6 +507,9 @@ void APP_StartListening(FUNCTION_Type_t Function, const bool reset_am_fix)
|
||||||
const uint8_t orig_pga = 6; // -3dB
|
const uint8_t orig_pga = 6; // -3dB
|
||||||
|
|
||||||
#ifdef ENABLE_AM_FIX
|
#ifdef ENABLE_AM_FIX
|
||||||
|
BK4819_SetAGC(gRxVfo->Modulation != MODULATION_AM || !gSetting_AM_fix);
|
||||||
|
|
||||||
|
|
||||||
if (gRxVfo->Modulation == MODULATION_AM && gSetting_AM_fix) { // AM RX mode
|
if (gRxVfo->Modulation == MODULATION_AM && gSetting_AM_fix) { // AM RX mode
|
||||||
if (reset_am_fix)
|
if (reset_am_fix)
|
||||||
AM_fix_reset(chan); // TODO: only reset it when moving channel/frequency
|
AM_fix_reset(chan); // TODO: only reset it when moving channel/frequency
|
||||||
|
@ -1781,11 +1784,18 @@ static void ProcessKey(KEY_Code_t Key, bool bKeyPressed, bool bKeyHeld)
|
||||||
// KEY_MENU has a special treatment here, because we want to pass hold event to ACTION_Handle
|
// KEY_MENU has a special treatment here, because we want to pass hold event to ACTION_Handle
|
||||||
// but we don't want it to complain when initial press happens
|
// but we don't want it to complain when initial press happens
|
||||||
// we want to react on realese instead
|
// we want to react on realese instead
|
||||||
else if (Key != KEY_SIDE1 && Key != KEY_SIDE2 && // pass side buttons
|
// KEY_MENU has a special treatment here, because we want to pass hold event to ACTION_Handle
|
||||||
!(Key == KEY_MENU && bKeyHeld)) // pass KEY_MENU held
|
// but we don't want it to complain when initial press happens
|
||||||
|
// we want to react on realese instead
|
||||||
|
else if ( // pass side buttons
|
||||||
|
!(Key == KEY_SIDE1 && !bKeyHeld)) // pass KEY_MENU held
|
||||||
{
|
{
|
||||||
if ((!bKeyPressed || bKeyHeld || (Key == KEY_MENU && bKeyPressed)) && // prevent released or held, prevent KEY_MENU pressed
|
// if (!(Key == KEY_SIDE1&&bKeyHeld)&&(!bKeyPressed || (Key == KEY_SIDE1 && bKeyPressed)) && // prevent released or held, prevent KEY_MENU pressed
|
||||||
!(Key == KEY_MENU && !bKeyPressed)) // pass KEY_MENU released
|
// !(Key == KEY_SIDE1 && !bKeyPressed)) // pass KEY_MENU released
|
||||||
|
// return;
|
||||||
|
if (!(Key == KEY_SIDE1) && !(bKeyPressed != 0))
|
||||||
|
|
||||||
|
// if (Key == KEY_SIDE1 == 0 && !bKeyPressed != 0) // pass KEY_MENU released
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// keypad is locked, tell the user
|
// keypad is locked, tell the user
|
||||||
|
@ -1809,6 +1819,11 @@ static void ProcessKey(KEY_Code_t Key, bool bKeyPressed, bool bKeyHeld)
|
||||||
bool bFlag = false;
|
bool bFlag = false;
|
||||||
if (Key == KEY_PTT)
|
if (Key == KEY_PTT)
|
||||||
{
|
{
|
||||||
|
// if(gEeprom.KEY_LOCK)
|
||||||
|
// {
|
||||||
|
// gKeypadLocked = 4; // 2 seconds
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
if (gPttWasPressed)
|
if (gPttWasPressed)
|
||||||
{
|
{
|
||||||
bFlag = bKeyHeld;
|
bFlag = bKeyHeld;
|
||||||
|
@ -1816,6 +1831,9 @@ static void ProcessKey(KEY_Code_t Key, bool bKeyPressed, bool bKeyHeld)
|
||||||
{
|
{
|
||||||
bFlag = true;
|
bFlag = true;
|
||||||
gPttWasPressed = false;
|
gPttWasPressed = false;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,8 @@ void COMMON_KeypadLockToggle()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
gEeprom.KEY_LOCK = !gEeprom.KEY_LOCK;
|
gEeprom.KEY_LOCK = !gEeprom.KEY_LOCK;
|
||||||
|
//按键锁定禁止发射 取消
|
||||||
|
// RADIO_SetVfoState(VFO_STATE_NORMAL);
|
||||||
|
|
||||||
gRequestSaveSettings = true;
|
gRequestSaveSettings = true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
@echo off
|
@echo off
|
||||||
docker build -t uvk5 .
|
docker build -t uvk5 .
|
||||||
docker run -v %CD%\compiled-firmware:/app/compiled-firmware uvk5 /bin/bash -c "cd /app && make clean && make && cp firmware* compiled-firmware/"
|
docker run --rm -v %CD%\compiled-firmware:/app/compiled-firmware uvk5 /bin/bash -c "cd /app && make clean && make && cp firmware* compiled-firmware/"
|
||||||
pause
|
pause
|
|
@ -1,3 +1,3 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
docker build -t uvk5 .
|
docker build -t uvk5 .
|
||||||
docker run -v ${PWD}/compiled-firmware:/app/compiled-firmware uvk5 /bin/bash -c "cd /app && make && cp firmware* compiled-firmware/"
|
docker run --rm -v ${PWD}/compiled-firmware:/app/compiled-firmware uvk5 /bin/bash -c "cd /app && make && cp firmware* compiled-firmware/"
|
|
@ -11,7 +11,14 @@ static inline void LogUart(char * str)
|
||||||
UART_Send(str, strlen(str));
|
UART_Send(str, strlen(str));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void LogPrint()
|
||||||
|
{
|
||||||
|
uint16_t rssi = BK4819_GetRSSI();
|
||||||
|
uint16_t reg7e = BK4819_ReadRegister(0x7E);
|
||||||
|
char buf[32];
|
||||||
|
sprintf(buf, "reg7E: %d %2d %6d %2d %d rssi: %d\n", (reg7e >> 15), (reg7e >> 12) & 0b111, (reg7e >> 5) & 0b1111111, (reg7e >> 2) & 0b111, (reg7e >> 0) & 0b11, rssi);
|
||||||
|
LogUart(buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
192
driver/bk4819.c
192
driver/bk4819.c
|
@ -25,12 +25,14 @@
|
||||||
#include "driver/systick.h"
|
#include "driver/systick.h"
|
||||||
|
|
||||||
#ifndef ARRAY_SIZE
|
#ifndef ARRAY_SIZE
|
||||||
#define ARRAY_SIZE(x) (sizeof(x) / sizeof(x[0]))
|
#define ARRAY_SIZE(x) (sizeof(x) / sizeof(x[0]))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static const uint16_t FSK_RogerTable[7] = {0xF1A2, 0x7446, 0x61A4, 0x6544, 0x4E8A, 0xE044, 0xEA84};
|
static const uint16_t FSK_RogerTable[7] = {0xF1A2, 0x7446, 0x61A4, 0x6544, 0x4E8A, 0xE044, 0xEA84};
|
||||||
|
|
||||||
static const uint8_t DTMF_TONE1_GAIN = 65;
|
static const uint8_t DTMF_TONE1_GAIN = 65;
|
||||||
static const uint8_t DTMF_TONE2_GAIN = 93;
|
static const uint8_t DTMF_TONE2_GAIN = 93;
|
||||||
|
|
||||||
static uint16_t gBK4819_GpioOutState;
|
static uint16_t gBK4819_GpioOutState;
|
||||||
|
|
||||||
bool gRxIdleMode;
|
bool gRxIdleMode;
|
||||||
|
@ -53,8 +55,8 @@ void BK4819_Init(void)
|
||||||
BK4819_WriteRegister(BK4819_REG_37, 0x1D0F);
|
BK4819_WriteRegister(BK4819_REG_37, 0x1D0F);
|
||||||
BK4819_WriteRegister(BK4819_REG_36, 0x0022);
|
BK4819_WriteRegister(BK4819_REG_36, 0x0022);
|
||||||
|
|
||||||
BK4819_DisableAGC();
|
BK4819_InitAGC();
|
||||||
// BK4819_EnableAGC();
|
BK4819_SetAGC(true);
|
||||||
|
|
||||||
BK4819_WriteRegister(BK4819_REG_19, 0b0001000001000001); // <15> MIC AGC 1 = disable 0 = enable
|
BK4819_WriteRegister(BK4819_REG_19, 0b0001000001000001); // <15> MIC AGC 1 = disable 0 = enable
|
||||||
|
|
||||||
|
@ -234,19 +236,46 @@ void BK4819_WriteU16(uint16_t Data)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void BK4819_DisableAGC()
|
void BK4819_SetAGC(bool enable)
|
||||||
{
|
{
|
||||||
// REG_10
|
uint16_t regVal = BK4819_ReadRegister(BK4819_REG_7E);
|
||||||
|
if(!(regVal & (1 << 15)) == enable)
|
||||||
|
return;
|
||||||
|
|
||||||
|
BK4819_WriteRegister(BK4819_REG_7E, (regVal & ~(1 << 15) & ~(0b111 << 12))
|
||||||
|
| (!enable << 15) // 0 AGC fix mode
|
||||||
|
| (3u << 12) // 3 AGC fix index
|
||||||
|
);
|
||||||
|
|
||||||
|
// if(enable) {
|
||||||
|
// BK4819_WriteRegister(BK4819_REG_7B, 0x8420);
|
||||||
|
// }
|
||||||
|
// else {
|
||||||
|
// BK4819_WriteRegister(BK4819_REG_7B, 0x318C);
|
||||||
|
|
||||||
|
// BK4819_WriteRegister(BK4819_REG_7C, 0x595E);
|
||||||
|
// BK4819_WriteRegister(BK4819_REG_20, 0x8DEF);
|
||||||
|
|
||||||
|
// for (uint8_t i = 0; i < 8; i++) {
|
||||||
|
// //BK4819_WriteRegister(BK4819_REG_06, ((i << 13) | 0x2500u) + 0x036u);
|
||||||
|
// BK4819_WriteRegister(BK4819_REG_06, (i & 7) << 13 | 0x4A << 7 | 0x36);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
}
|
||||||
|
|
||||||
|
void BK4819_InitAGC()
|
||||||
|
{
|
||||||
|
// REG_10, REG_11, REG_12 REG_13, REG_14
|
||||||
//
|
//
|
||||||
// 0x0038 Rx AGC Gain Table[0]. (Index Max->Min is 3,2,1,0,-1)
|
// Rx AGC Gain Table[]. (Index Max->Min is 3,2,1,0,-1)
|
||||||
//
|
//
|
||||||
// <15:10> ???
|
// <15:10> ???
|
||||||
//
|
//
|
||||||
// <9:8> LNA Gain Short
|
// <9:8> LNA Gain Short
|
||||||
// 3 = 0dB <<<
|
// 3 = 0dB <<< 1o11 read from spectrum reference manual
|
||||||
// 2 = -24dB // was -11
|
// 2 = -24dB -19 -11
|
||||||
// 1 = -30dB // was -16
|
// 1 = -30dB -24 -16
|
||||||
// 0 = -33dB // was -19
|
// 0 = -33dB -28 -19
|
||||||
//
|
//
|
||||||
// <7:5> LNA Gain
|
// <7:5> LNA Gain
|
||||||
// 7 = 0dB
|
// 7 = 0dB
|
||||||
|
@ -274,75 +303,18 @@ void BK4819_DisableAGC()
|
||||||
// 1 = -27dB
|
// 1 = -27dB
|
||||||
// 0 = -33dB
|
// 0 = -33dB
|
||||||
//
|
//
|
||||||
BK4819_WriteRegister(BK4819_REG_13, (3u << 8) | (5u << 5) | (3u << 3) | (6u << 0)); // 000000 11 101 11 110
|
|
||||||
|
|
||||||
BK4819_WriteRegister(BK4819_REG_12, 0x037B); // 000000 11 011 11 011
|
BK4819_WriteRegister(BK4819_REG_13, 0x03BE); // 0x03BE / 000000 11 101 11 110 / -7dB
|
||||||
BK4819_WriteRegister(BK4819_REG_11, 0x027B); // 000000 10 011 11 011
|
BK4819_WriteRegister(BK4819_REG_12, 0x037B); // 0x037B / 000000 11 011 11 011 / -24dB
|
||||||
BK4819_WriteRegister(BK4819_REG_10, 0x007A); // 000000 00 011 11 010
|
BK4819_WriteRegister(BK4819_REG_11, 0x027B); // 0x027B / 000000 10 011 11 011 / -43dB
|
||||||
BK4819_WriteRegister(BK4819_REG_14, 0x0019); // 000000 00 000 11 001
|
BK4819_WriteRegister(BK4819_REG_10, 0x007A); // 0x007A / 000000 00 011 11 010 / -58dB
|
||||||
|
BK4819_WriteRegister(BK4819_REG_14, 0x0019); // 0x0019 / 000000 00 000 11 001 / -79dB
|
||||||
BK4819_WriteRegister(BK4819_REG_49, 0x2A38);
|
BK4819_WriteRegister(BK4819_REG_49, (0 << 14) | (84 << 7) | (56 << 0)); //0x2A38 / 00 1010100 0111000 / 84, 56
|
||||||
BK4819_WriteRegister(BK4819_REG_7B, 0x8420);
|
BK4819_WriteRegister(BK4819_REG_7B, 0x8420);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void BK4819_EnableAGC()
|
|
||||||
{
|
|
||||||
// REG_10
|
|
||||||
//
|
|
||||||
// 0x0038 Rx AGC Gain Table[0]. (Index Max->Min is 3,2,1,0,-1)
|
|
||||||
//
|
|
||||||
// (15:10> ???
|
|
||||||
//
|
|
||||||
// <9:8> LNA Gain Short
|
|
||||||
// 3 = 0dB << original
|
|
||||||
// 2 = -24dB // was -11
|
|
||||||
// 1 = -30dB // was -16
|
|
||||||
// 0 = -33dB // was -19
|
|
||||||
//
|
|
||||||
// <7:5> LNA Gain
|
|
||||||
// 7 = 0dB
|
|
||||||
// 6 = -2dB
|
|
||||||
// 5 = -4dB
|
|
||||||
// 4 = -6dB
|
|
||||||
// 3 = -9dB
|
|
||||||
// 2 = -14dB << original
|
|
||||||
// 1 = -19dB
|
|
||||||
// 0 = -24dB
|
|
||||||
//
|
|
||||||
// <4:3> MIXER Gain
|
|
||||||
// 3 = 0dB << original
|
|
||||||
// 2 = -3dB
|
|
||||||
// 1 = -6dB
|
|
||||||
// 0 = -8dB
|
|
||||||
//
|
|
||||||
// <2:0> PGA Gain
|
|
||||||
// 7 = 0dB
|
|
||||||
// 6 = -3dB << original
|
|
||||||
// 5 = -6dB
|
|
||||||
// 4 = -9dB
|
|
||||||
// 3 = -15dB
|
|
||||||
// 2 = -21dB
|
|
||||||
// 1 = -27dB
|
|
||||||
// 0 = -33dB
|
|
||||||
//
|
|
||||||
BK4819_WriteRegister(BK4819_REG_13, (3u << 8) | (5u << 5) | (3u << 3) | (6u << 0));
|
|
||||||
|
|
||||||
BK4819_WriteRegister(BK4819_REG_12, 0x037C); // 000000 11 011 11 100
|
|
||||||
BK4819_WriteRegister(BK4819_REG_11, 0x027B); // 000000 10 011 11 011
|
|
||||||
BK4819_WriteRegister(BK4819_REG_10, 0x007A); // 000000 00 011 11 010
|
|
||||||
BK4819_WriteRegister(BK4819_REG_14, 0x0018); // 000000 00 000 11 000
|
|
||||||
|
|
||||||
BK4819_WriteRegister(BK4819_REG_49, 0x2A38);
|
|
||||||
BK4819_WriteRegister(BK4819_REG_7B, 0x318C);
|
|
||||||
|
|
||||||
BK4819_WriteRegister(BK4819_REG_7C, 0x595E);
|
|
||||||
BK4819_WriteRegister(BK4819_REG_20, 0x8DEF);
|
|
||||||
|
|
||||||
for (uint8_t i = 0; i < 8; i++) {
|
|
||||||
//BK4819_WriteRegister(BK4819_REG_06, ((i << 13) | 0x2500u) + 0x036u);
|
|
||||||
BK4819_WriteRegister(BK4819_REG_06, (i & 7) << 13 | 0x4A << 7 | 0x36);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void BK4819_ToggleGpioOut(BK4819_GPIO_PIN_t Pin, bool bSet)
|
void BK4819_ToggleGpioOut(BK4819_GPIO_PIN_t Pin, bool bSet)
|
||||||
{
|
{
|
||||||
|
@ -826,16 +798,18 @@ void BK4819_RX_TurnOn(void)
|
||||||
// Turn off everything
|
// Turn off everything
|
||||||
BK4819_WriteRegister(BK4819_REG_30, 0);
|
BK4819_WriteRegister(BK4819_REG_30, 0);
|
||||||
|
|
||||||
// Enable VCO Calibration
|
|
||||||
// Enable RX Link
|
BK4819_WriteRegister(BK4819_REG_30,
|
||||||
// Enable AF DAC
|
BK4819_REG_30_ENABLE_VCO_CALIB |
|
||||||
// Enable PLL/VCO
|
BK4819_REG_30_DISABLE_UNKNOWN |
|
||||||
// Disable PA Gain
|
BK4819_REG_30_ENABLE_RX_LINK |
|
||||||
// Disable MIC ADC
|
BK4819_REG_30_ENABLE_AF_DAC |
|
||||||
// Disable TX DSP
|
BK4819_REG_30_ENABLE_DISC_MODE |
|
||||||
// Enable RX DSP
|
BK4819_REG_30_ENABLE_PLL_VCO |
|
||||||
//
|
BK4819_REG_30_DISABLE_PA_GAIN |
|
||||||
BK4819_WriteRegister(BK4819_REG_30, 0b1011111111110001); // 1 0 1111 1 1 1111 0 0 0 1
|
BK4819_REG_30_DISABLE_MIC_ADC |
|
||||||
|
BK4819_REG_30_DISABLE_TX_DSP |
|
||||||
|
BK4819_REG_30_ENABLE_RX_DSP );
|
||||||
}
|
}
|
||||||
|
|
||||||
void BK4819_PickRXFilterPathBasedOnFrequency(uint32_t Frequency)
|
void BK4819_PickRXFilterPathBasedOnFrequency(uint32_t Frequency)
|
||||||
|
@ -986,6 +960,7 @@ void BK4819_EnableDTMF(void)
|
||||||
void BK4819_PlayTone(uint16_t Frequency, bool bTuningGainSwitch)
|
void BK4819_PlayTone(uint16_t Frequency, bool bTuningGainSwitch)
|
||||||
{
|
{
|
||||||
uint16_t ToneConfig = BK4819_REG_70_ENABLE_TONE1;
|
uint16_t ToneConfig = BK4819_REG_70_ENABLE_TONE1;
|
||||||
|
|
||||||
BK4819_EnterTxMute();
|
BK4819_EnterTxMute();
|
||||||
BK4819_SetAF(BK4819_AF_BEEP);
|
BK4819_SetAF(BK4819_AF_BEEP);
|
||||||
|
|
||||||
|
@ -1001,6 +976,7 @@ void BK4819_PlayTone(uint16_t Frequency, bool bTuningGainSwitch)
|
||||||
BK4819_WriteRegister(BK4819_REG_71, scale_freq(Frequency));
|
BK4819_WriteRegister(BK4819_REG_71, scale_freq(Frequency));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// level 0 ~ 127
|
||||||
void BK4819_PlaySingleTone(const unsigned int tone_Hz, const unsigned int delay, const unsigned int level, const bool play_speaker)
|
void BK4819_PlaySingleTone(const unsigned int tone_Hz, const unsigned int delay, const unsigned int level, const bool play_speaker)
|
||||||
{
|
{
|
||||||
BK4819_EnterTxMute();
|
BK4819_EnterTxMute();
|
||||||
|
@ -1013,9 +989,7 @@ void BK4819_PlaySingleTone(const unsigned int tone_Hz, const unsigned int delay,
|
||||||
else
|
else
|
||||||
BK4819_SetAF(BK4819_AF_MUTE);
|
BK4819_SetAF(BK4819_AF_MUTE);
|
||||||
|
|
||||||
// level 0 ~ 127
|
|
||||||
// BK4819_WriteRegister(BK4819_REG_70, BK4819_REG_70_ENABLE_TONE1 | (96u << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN));
|
|
||||||
// BK4819_WriteRegister(BK4819_REG_70, BK4819_REG_70_ENABLE_TONE1 | (28u << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN));
|
|
||||||
BK4819_WriteRegister(BK4819_REG_70, BK4819_REG_70_ENABLE_TONE1 | ((level & 0x7f) << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN));
|
BK4819_WriteRegister(BK4819_REG_70, BK4819_REG_70_ENABLE_TONE1 | ((level & 0x7f) << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN));
|
||||||
|
|
||||||
BK4819_EnableTXLink();
|
BK4819_EnableTXLink();
|
||||||
|
@ -1072,7 +1046,7 @@ void BK4819_TurnsOffTones_TurnsOnRX(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef ENABLE_AIRCOPY
|
#ifdef ENABLE_AIRCOPY
|
||||||
void BK4819_SetupAircopy(void)
|
void BK4819_SetupAircopy(void)
|
||||||
{
|
{
|
||||||
BK4819_WriteRegister(BK4819_REG_70, 0x00E0); // Enable Tone2, tuning gain 48
|
BK4819_WriteRegister(BK4819_REG_70, 0x00E0); // Enable Tone2, tuning gain 48
|
||||||
BK4819_WriteRegister(BK4819_REG_72, 0x3065); // Tone2 baudrate 1200
|
BK4819_WriteRegister(BK4819_REG_72, 0x3065); // Tone2 baudrate 1200
|
||||||
|
@ -1128,11 +1102,15 @@ void BK4819_ExitBypass(void)
|
||||||
// 0 ~ 7
|
// 0 ~ 7
|
||||||
// 0 = bypass DC filter
|
// 0 = bypass DC filter
|
||||||
//
|
//
|
||||||
BK4819_WriteRegister(BK4819_REG_7E, // 0x302E); // 0 011 000000 101 110
|
|
||||||
(0u << 15) | // 0 AGC fix mode
|
uint16_t regVal = BK4819_ReadRegister(BK4819_REG_7E);
|
||||||
(3u << 12) | // 3 AGC fix index
|
|
||||||
(5u << 3) | // 5 DC Filter band width for Tx (MIC In)
|
// 0x302E / 0 011 000000 101 110
|
||||||
(6u << 0)); // 6 DC Filter band width for Rx (I.F In)
|
BK4819_WriteRegister(BK4819_REG_7E, (regVal & ~(0b111 << 3))
|
||||||
|
|
||||||
|
| (5u << 3) // 5 DC Filter band width for Tx (MIC In)
|
||||||
|
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
void BK4819_PrepareTransmit(void)
|
void BK4819_PrepareTransmit(void)
|
||||||
|
@ -1209,11 +1187,10 @@ void BK4819_EnterDTMF_TX(bool bLocalLoopback)
|
||||||
|
|
||||||
BK4819_WriteRegister(BK4819_REG_70,
|
BK4819_WriteRegister(BK4819_REG_70,
|
||||||
BK4819_REG_70_MASK_ENABLE_TONE1 |
|
BK4819_REG_70_MASK_ENABLE_TONE1 |
|
||||||
// (83u << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN) |
|
|
||||||
(DTMF_TONE1_GAIN << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN) |
|
(DTMF_TONE1_GAIN << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN) |
|
||||||
BK4819_REG_70_MASK_ENABLE_TONE2 |
|
BK4819_REG_70_MASK_ENABLE_TONE2 |
|
||||||
// (83u << BK4819_REG_70_SHIFT_TONE2_TUNING_GAIN));
|
(DTMF_TONE2_GAIN << BK4819_REG_70_SHIFT_TONE2_TUNING_GAIN));
|
||||||
(DTMF_TONE2_GAIN << BK4819_REG_70_SHIFT_TONE2_TUNING_GAIN));
|
|
||||||
BK4819_EnableTXLink();
|
BK4819_EnableTXLink();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1251,10 +1228,8 @@ void BK4819_PlayDTMF(char Code)
|
||||||
switch (Code)
|
switch (Code)
|
||||||
{
|
{
|
||||||
case '0': tone1 = 941; tone2 = 1336; break;
|
case '0': tone1 = 941; tone2 = 1336; break;
|
||||||
// case '1': tone1 = 679; tone2 = 1209; break;
|
|
||||||
case '1': tone1 = 697; tone2 = 1209; break;
|
case '1': tone1 = 697; tone2 = 1209; break;
|
||||||
case '2': tone1 = 697; tone2 = 1336; break;
|
case '2': tone1 = 697; tone2 = 1336; break;
|
||||||
// case '3': tone1 = 679; tone2 = 1477; break;
|
|
||||||
case '3': tone1 = 697; tone2 = 1477; break;
|
case '3': tone1 = 697; tone2 = 1477; break;
|
||||||
case '4': tone1 = 770; tone2 = 1209; break;
|
case '4': tone1 = 770; tone2 = 1209; break;
|
||||||
case '5': tone1 = 770; tone2 = 1336; break;
|
case '5': tone1 = 770; tone2 = 1336; break;
|
||||||
|
@ -1262,7 +1237,6 @@ void BK4819_PlayDTMF(char Code)
|
||||||
case '7': tone1 = 852; tone2 = 1209; break;
|
case '7': tone1 = 852; tone2 = 1209; break;
|
||||||
case '8': tone1 = 852; tone2 = 1336; break;
|
case '8': tone1 = 852; tone2 = 1336; break;
|
||||||
case '9': tone1 = 852; tone2 = 1477; break;
|
case '9': tone1 = 852; tone2 = 1477; break;
|
||||||
// case 'A': tone1 = 679; tone2 = 1633; break;
|
|
||||||
case 'A': tone1 = 697; tone2 = 1633; break;
|
case 'A': tone1 = 697; tone2 = 1633; break;
|
||||||
case 'B': tone1 = 770; tone2 = 1633; break;
|
case 'B': tone1 = 770; tone2 = 1633; break;
|
||||||
case 'C': tone1 = 852; tone2 = 1633; break;
|
case 'C': tone1 = 852; tone2 = 1633; break;
|
||||||
|
@ -1324,8 +1298,8 @@ void BK4819_TransmitTone(bool bLocalLoopback, uint32_t Frequency)
|
||||||
//
|
//
|
||||||
// set the tone amplitude
|
// set the tone amplitude
|
||||||
//
|
//
|
||||||
// BK4819_WriteRegister(BK4819_REG_70, BK4819_REG_70_MASK_ENABLE_TONE1 | (96u << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN));
|
|
||||||
BK4819_WriteRegister(BK4819_REG_70, BK4819_REG_70_MASK_ENABLE_TONE1 | (66u << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN));
|
BK4819_WriteRegister(BK4819_REG_70, BK4819_REG_70_MASK_ENABLE_TONE1 | (66u << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN));
|
||||||
|
|
||||||
BK4819_WriteRegister(BK4819_REG_71, scale_freq(Frequency));
|
BK4819_WriteRegister(BK4819_REG_71, scale_freq(Frequency));
|
||||||
|
|
||||||
BK4819_SetAF(bLocalLoopback ? BK4819_AF_BEEP : BK4819_AF_MUTE);
|
BK4819_SetAF(bLocalLoopback ? BK4819_AF_BEEP : BK4819_AF_MUTE);
|
||||||
|
@ -1404,13 +1378,13 @@ void BK4819_EnableCDCSS(void)
|
||||||
|
|
||||||
void BK4819_EnableCTCSS(void)
|
void BK4819_EnableCTCSS(void)
|
||||||
{
|
{
|
||||||
#ifdef ENABLE_CTCSS_TAIL_PHASE_SHIFT
|
#ifdef ENABLE_CTCSS_TAIL_PHASE_SHIFT
|
||||||
//BK4819_GenTail(1); // 120° phase shift
|
//BK4819_GenTail(1); // 120° phase shift
|
||||||
BK4819_GenTail(2); // 180° phase shift
|
BK4819_GenTail(2); // 180° phase shift
|
||||||
//BK4819_GenTail(3); // 240° phase shift
|
//BK4819_GenTail(3); // 240° phase shift
|
||||||
#else
|
#else
|
||||||
BK4819_GenTail(4); // 55Hz tone freq
|
BK4819_GenTail(4); // 55Hz tone freq
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// REG_51
|
// REG_51
|
||||||
//
|
//
|
||||||
|
@ -1691,21 +1665,20 @@ void BK4819_PrepareFSKReceive(void)
|
||||||
|
|
||||||
void BK4819_PlayRoger(void)
|
void BK4819_PlayRoger(void)
|
||||||
{
|
{
|
||||||
#if 0
|
#if 0
|
||||||
const uint32_t tone1_Hz = 500;
|
const uint32_t tone1_Hz = 500;
|
||||||
const uint32_t tone2_Hz = 700;
|
const uint32_t tone2_Hz = 700;
|
||||||
#else
|
#else
|
||||||
// motorola type
|
// motorola type
|
||||||
const uint32_t tone1_Hz = 1540;
|
const uint32_t tone1_Hz = 1540;
|
||||||
const uint32_t tone2_Hz = 1310;
|
const uint32_t tone2_Hz = 1310;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
BK4819_EnterTxMute();
|
BK4819_EnterTxMute();
|
||||||
BK4819_SetAF(BK4819_AF_MUTE);
|
BK4819_SetAF(BK4819_AF_MUTE);
|
||||||
|
|
||||||
// BK4819_WriteRegister(BK4819_REG_70, BK4819_REG_70_ENABLE_TONE1 | (96u << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN));
|
|
||||||
|
|
||||||
BK4819_WriteRegister(BK4819_REG_70, BK4819_REG_70_ENABLE_TONE1 | (66u << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN));
|
BK4819_WriteRegister(BK4819_REG_70, BK4819_REG_70_ENABLE_TONE1 | (66u << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN));
|
||||||
|
|
||||||
BK4819_EnableTXLink();
|
BK4819_EnableTXLink();
|
||||||
SYSTEM_DelayMs(50);
|
SYSTEM_DelayMs(50);
|
||||||
|
|
||||||
|
@ -1785,12 +1758,13 @@ void BK4819_PlayDTMFEx(bool bLocalLoopback, char Code)
|
||||||
BK4819_EnterTxMute();
|
BK4819_EnterTxMute();
|
||||||
|
|
||||||
BK4819_SetAF(bLocalLoopback ? BK4819_AF_BEEP : BK4819_AF_MUTE);
|
BK4819_SetAF(bLocalLoopback ? BK4819_AF_BEEP : BK4819_AF_MUTE);
|
||||||
// BK4819_WriteRegister(BK4819_REG_70, 0xD3D3);
|
|
||||||
BK4819_WriteRegister(BK4819_REG_70,
|
BK4819_WriteRegister(BK4819_REG_70,
|
||||||
BK4819_REG_70_MASK_ENABLE_TONE1 |
|
BK4819_REG_70_MASK_ENABLE_TONE1 |
|
||||||
(DTMF_TONE1_GAIN << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN) |
|
(DTMF_TONE1_GAIN << BK4819_REG_70_SHIFT_TONE1_TUNING_GAIN) |
|
||||||
BK4819_REG_70_MASK_ENABLE_TONE2 |
|
BK4819_REG_70_MASK_ENABLE_TONE2 |
|
||||||
(DTMF_TONE2_GAIN << BK4819_REG_70_SHIFT_TONE2_TUNING_GAIN));
|
(DTMF_TONE2_GAIN << BK4819_REG_70_SHIFT_TONE2_TUNING_GAIN));
|
||||||
|
|
||||||
BK4819_EnableTXLink();
|
BK4819_EnableTXLink();
|
||||||
|
|
||||||
SYSTEM_DelayMs(50);
|
SYSTEM_DelayMs(50);
|
||||||
|
|
|
@ -72,8 +72,8 @@ void BK4819_SetRegValue(RegisterSpec s, uint16_t v);
|
||||||
void BK4819_WriteU8(uint8_t Data);
|
void BK4819_WriteU8(uint8_t Data);
|
||||||
void BK4819_WriteU16(uint16_t Data);
|
void BK4819_WriteU16(uint16_t Data);
|
||||||
|
|
||||||
void BK4819_EnableAGC();
|
void BK4819_SetAGC(bool enable);
|
||||||
void BK4819_DisableAGC();
|
void BK4819_InitAGC();
|
||||||
|
|
||||||
void BK4819_ToggleGpioOut(BK4819_GPIO_PIN_t Pin, bool bSet);
|
void BK4819_ToggleGpioOut(BK4819_GPIO_PIN_t Pin, bool bSet);
|
||||||
|
|
||||||
|
|
|
@ -20,10 +20,14 @@
|
||||||
|-----------|-------|-------:|------------|
|
|-----------|-------|-------:|------------|
|
||||||
| 忠 | 微信打赏 | ¥20.00 | 2023-11-19 |
|
| 忠 | 微信打赏 | ¥20.00 | 2023-11-19 |
|
||||||
| BG6SNG | 支付宝打赏 | ¥10.00 | 2023-11-20 |
|
| BG6SNG | 支付宝打赏 | ¥10.00 | 2023-11-20 |
|
||||||
| 江璐璐 | 支付宝打赏 | ¥10.00 | 2023-11-21
|
| 江璐璐 | 支付宝打赏 | ¥10.00 | 2023-11-21 |
|
||||||
| 济南黄河业余无线电 | 微信打赏 | ¥25.00 | 2023-11-22
|
| 济南黄河业余无线电 | 微信打赏 | ¥25.00 | 2023-11-22 |
|
||||||
| DE.BG9JAQ | 微信打赏 | ¥9.99 | 2023-11-22
|
| DE.BG9JAQ | 微信打赏 | ¥9.99 | 2023-11-22 |
|
||||||
| 姜先生 | 微信打赏 | ¥66.6 | 2023-11-28
|
| 姜先生 | 微信打赏 | ¥66.6 | 2023-11-28 |
|
||||||
|
| Hui-Shao | 支付宝打赏 | ¥10.0 | 2023-11-29|
|
||||||
|
| BI1OWT | 支付宝打赏 | ¥10.0 | 2023-12-01|
|
||||||
|
| 蛋 | 微信打赏 | ¥6.66 | 2023-12-01|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -154,9 +154,13 @@ void UI_DisplayStatus()
|
||||||
// KEY-LOCK indicator
|
// KEY-LOCK indicator
|
||||||
if (gEeprom.KEY_LOCK)
|
if (gEeprom.KEY_LOCK)
|
||||||
{
|
{
|
||||||
|
|
||||||
memmove(line + x, BITMAP_KeyLock, sizeof(BITMAP_KeyLock));
|
memmove(line + x, BITMAP_KeyLock, sizeof(BITMAP_KeyLock));
|
||||||
x += sizeof(BITMAP_KeyLock);
|
x += sizeof(BITMAP_KeyLock);
|
||||||
x1 = x;
|
x1 = x;
|
||||||
|
//按键锁定禁止发射
|
||||||
|
// RADIO_SetVfoState(VFO_STATE_TX_DISABLE);
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
if (gWasFKeyPressed)
|
if (gWasFKeyPressed)
|
||||||
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
!(A&&B)&&(!C || (A && C)) && !(A && !C)
|
||||||
|
|
Binary file not shown.
|
@ -4,7 +4,7 @@
|
||||||
#ifdef GIT_HASH
|
#ifdef GIT_HASH
|
||||||
#define VER GIT_HASH
|
#define VER GIT_HASH
|
||||||
#else
|
#else
|
||||||
#define VER "231004"
|
#define VER "102"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef ONE_OF_ELEVEN_VER
|
#ifndef ONE_OF_ELEVEN_VER
|
||||||
|
|
Loading…
Reference in a new issue