Bluetooth jdy33 setup minor fixes (#4834)

* bluetoth: only HC05 needs equal sign in AT+NAME command

* bluetooth: returt on all param errors

* bluetooth setup: return on fail and request
This commit is contained in:
Andrey G 2022-11-27 16:47:02 +03:00 committed by GitHub
parent 0d1120ca13
commit 64371e0f3a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 8 additions and 3 deletions

View File

@ -121,9 +121,9 @@ static void runCommands() {
if (chThdShouldTerminateX() || (baudIdx == efi::size(baudRates))) { if (chThdShouldTerminateX() || (baudIdx == efi::size(baudRates))) {
if (baudIdx == efi::size(baudRates)) { if (baudIdx == efi::size(baudRates)) {
efiPrintf("Failed to find current BT module baudrate"); efiPrintf("Failed to find current BT module baudrate");
return;
} }
tsChannel->start(engineConfiguration->tunerStudioSerialSpeed); tsChannel->start(engineConfiguration->tunerStudioSerialSpeed);
return;
} }
efiPrintf("Restarting at %d", baudRates[baudIdx]); efiPrintf("Restarting at %d", baudRates[baudIdx]);
@ -192,14 +192,17 @@ static void runCommands() {
chThdSleepMilliseconds(10); // safety chThdSleepMilliseconds(10); // safety
tsChannel->start(baudRates[setBaudIdx]); tsChannel->start(baudRates[setBaudIdx]);
chsnprintf(tmp, sizeof(tmp), "AT+NAME=%s\r\n", btName); if (btModuleType == BLUETOOTH_HC_05)
chsnprintf(tmp, sizeof(tmp), "AT+NAME=%s\r\n", btName);
else
chsnprintf(tmp, sizeof(tmp), "AT+NAME%s\r\n", btName);
btWrite(tmp); btWrite(tmp);
if (btWaitOk() != 0) { if (btWaitOk() != 0) {
goto cmdFailed; goto cmdFailed;
} }
if (btModuleType == BLUETOOTH_JDY_3x) { if (btModuleType == BLUETOOTH_JDY_3x) {
/* BLE broadcast name */ /* BLE broadcast name */
chsnprintf(tmp, sizeof(tmp), "AT+NAMB=%s\r\n", btName); chsnprintf(tmp, sizeof(tmp), "AT+NAMB%s\r\n", btName);
btWrite(tmp); btWrite(tmp);
if (btWaitOk() != 0) { if (btWaitOk() != 0) {
goto cmdFailed; goto cmdFailed;
@ -308,10 +311,12 @@ void bluetoothStart(bluetooth_module_e moduleType, const char *baudRate, const c
// 3) check pin code // 3) check pin code
if (strlen(pinCode) != 4) { if (strlen(pinCode) != 4) {
efiPrintf("Wrong <pincode> parameter! 4 digits expected! %s", usage); efiPrintf("Wrong <pincode> parameter! 4 digits expected! %s", usage);
return;
} }
for (int i = 0; i < 4; i++) { for (int i = 0; i < 4; i++) {
if (!isdigit(pinCode[i])) { if (!isdigit(pinCode[i])) {
efiPrintf("<pincode> should contain digits only %s", usage); efiPrintf("<pincode> should contain digits only %s", usage);
return;
} }
} }