Всем привет, экспериментирую с примером BLE для esp32. Сам пример

работает отлично, но стоит добавить в него отправку в характеристику значения с пина, всё резко ломается:

diff --git a/src/main.rs b/src/main.rs
index ffd493a..87f0458 100644
--- a/src/main.rs
+ b/src/main.rs
@@ -42,6 +42,7 @@ fn main() -> ! {

let io = IO::new(peripherals.GPIO, peripherals.IO_MUX);
let button = io.pins.gpio0.into_pull_down_input();
+ let pin = io.pins.gpio23.into_pull_down_input();

let mut debounce_cnt = 500;

@@ -83,6 +84,7 @@ fn main() -> ! {

let mut rf3 = |_offset: usize, data: &mut [u8]| {
data[..5].copy_from_slice(&b"Hola!"[..]);
+ data[0] = pin.is_low().unwrap() as u8;
5
};
let mut wf3 = |offset: usize, data: &[u8]| {


Когда я пытаюсь подключиться к плате по bluetooth через bluez, она обрывает подключение или таймаутится. В логах при этом вообще ничего нет. Это плата кривая или всё же мои руки?

17 ответов

24 просмотра
Белый-Кит Автор вопроса

По симптоматике похожий ишью есть и в idf: https://github.com/espressif/esp-idf/issues/10222

Форматирование у тебя какое-то небесное 👀. Яб сделал строку, а потом в байтики конвертил

Белый-Кит Автор вопроса
Roman Samusevich
Форматирование у тебя какое-то небесное 👀. Яб сдел...

Да, форматирование с телефона странно выглядит очень

Белый-Кит Автор вопроса
Roman Samusevich
Форматирование у тебя какое-то небесное 👀. Яб сдел...

Там походу реально какие-то беды в стеке espressif с этим примером, я вокруг сообщения в логах нашёл сразу несколько issue с богатой историей и непонятным статусом

Белый-Кит Автор вопроса
Roman Samusevich
Я не про вид в телеге, а код

А, ну это патч просто, наверное стоило как-то по-другому его оформить, но я не придумал как

Да про это 😂, ладно, пофиг

Белый-Кит Автор вопроса
Roman Samusevich
screenshot Да про это 😂, ладно, пофиг

А, да сделано максимально тупо, лишь бы заработало) Не ожидал, что на таких базовых вещах начнутся проблемы

Белый Кит
А, да сделано максимально тупо, лишь бы заработало...

Я не уверен что конечно в данном фрагменте, но мало ли

а попробуй data[0] = pin.is_low().unwrap() as u8 + b'0' Может ноль в начале слайса как то влияет. пальцем в небо :)

Белый-Кит Автор вопроса
Vitaly
а попробуй data[0] = pin.is_low().unwrap() as u8 ...

Про нуль-терминатор забыл как-то, попробую, спасибо!

Белый-Кит Автор вопроса
Vitaly
а попробуй data[0] = pin.is_low().unwrap() as u8 ...

О_о, это сработало! Удивительно ещё, что один раз мне всё же удалось подключиться и считать этот ноль, но почти всегда всё ломалось.

Белый Кит
О_о, это сработало! Удивительно ещё, что один раз ...

убийца - нуль-терминатор, значит раст тут не причем, ееее 😆

Vitaly
убийца - нуль-терминатор, значит раст тут не приче...

Это был приквел (0-я часть терминатора). Но ее так никто и не увидел. Пленку зажевало

Белый-Кит Автор вопроса
Белый Кит
О_о, это сработало! Удивительно ещё, что один раз ...

И всё же сработало не до конца. Падать стало значительно реже, но не перестало.

Похожие вопросы

Обсуждают сегодня

Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
5
А в каком формате фреймы? Сам формат сейчас придумываешь, или что-то готовое нужно распарсить?
Okhsunrog
5
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Раз начали говорить про embassy, то присоединюсь со своими парой вопросов. 1) Есть ли сопоставимые аналоги для асинхронного кода в emdebbed? 2) Можно ли внутри задач embassy ...
NI_isx
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Карта сайта