Skip to content

Commit e181560

Browse files
Update GB Link Camera 2.0 New Serial API closes #18
1 parent dc51657 commit e181560

File tree

5 files changed

+70
-125
lines changed

5 files changed

+70
-125
lines changed

flipper_companion_apps/applications/external/malveke_gb_link_camera/application.fam

+1-1
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@ App(
1010
],
1111
stack_size=1 * 1024,
1212
order=10,
13-
fap_version=[1,1],
13+
fap_version=[2,0],
1414
fap_libs=["assets"],
1515
fap_icon="icons/boilerplate_10px.png",
1616
fap_icon_assets="icons",

flipper_companion_apps/applications/external/malveke_gb_link_camera/link_camera.c

+2-75
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,6 @@
11
#include "link_camera.h"
22
#include <gui/elements.h>
33
#include <malveke_gb_link_camera_icons.h>
4-
// #include <u8g2_glue.h>
54

65
QRCode qrcode;
76
uint8_t qrcodeData[((((4 * 8 + 17) * (4 * 8 + 17)) + 7) / 8)];
@@ -21,52 +20,9 @@ static void view_draw_callback(Canvas *canvas, void *_model)
2120

2221
if (model->connected)
2322
{
24-
// canvas_draw_str_aligned(canvas, 128/2, 64/3, AlignCenter, AlignCenter, "Connected");
25-
// canvas_draw_str_aligned(canvas, 128/2, 64/2, AlignCenter, AlignCenter, model->ip);
26-
/*
27-
char ssid[64]; // Incrementa el tamaño a 64
28-
char password[64]; // Incrementa el tamaño a 64
29-
char qrstr[150]; // Deja qrstr con el tamaño actual
30-
snprintf(ssid, sizeof(ssid), "%s", "[MALVEKE] Flipper GB Camera");
31-
snprintf(password, sizeof(password), "%s", "12345678");
32-
snprintf(qrstr, sizeof(qrstr), "WIFI:S:%s;T:WPA2;P:%s;;", ssid, password);
33-
qrcode_initText(&qrcode, qrcodeData, 2, 0, qrstr);
34-
// canvas_draw_frame(canvas, 63, 63, 0, 0);
35-
36-
for (uint8_t y = 0; y < qrcode.size; y++) {
37-
// Cada módulo horizontal
38-
for (uint8_t x = 0; x < qrcode.size; x++) {
39-
if (qrcode_getModule(&qrcode, x, y)) {
40-
if(qrcode_getModule(&qrcode, x, y)) {
41-
// canvas_draw_dot(canvas, x, y);
42-
int scale = 2;
43-
// // Dibuja cada punto dos veces para escalar al doble
44-
canvas_draw_dot(canvas, (x * scale) + 2, (y * scale) + 4);
45-
canvas_draw_dot(canvas, (x * scale + 1) + 2, (y * scale) + 4);
46-
canvas_draw_dot(canvas, (x * scale) + 2, (y * scale + 1) + 4);
47-
canvas_draw_dot(canvas, (x * scale + 1) + 2, (y * scale + 1) + 4);
48-
}
49-
}
50-
}
51-
}
52-
canvas_set_font(canvas, FontPrimary);
53-
canvas_draw_str(canvas, 62, 11, "SSID");
54-
canvas_set_font(canvas, FontSecondary);
55-
// u8g2_SetFont(&canvas->fb, u8g2_font_5x7_tf); //u8g2_font_micro_tr);
56-
// canvas_set_font(canvas, FontBatteryPercent);
57-
canvas_draw_str(canvas, 62, 20, "[MALVEKE] Flipper GB Camera");
58-
canvas_set_font(canvas, FontPrimary);
59-
canvas_draw_str(canvas, 62, 30, "Password");
60-
canvas_set_font(canvas, FontSecondary);
61-
// canvas_set_font(canvas, u8g2_font_5x7_tf);
62-
canvas_draw_str(canvas, 62, 40, "12345678");
63-
64-
*/
6523
canvas_set_font(canvas, FontPrimary);
6624
canvas_draw_str(canvas, 2, 11, "SSID");
6725
canvas_set_font(canvas, FontSecondary);
68-
// u8g2_SetFont(&canvas->fb, u8g2_font_5x7_tf); //u8g2_font_micro_tr);
69-
// canvas_set_font(canvas, FontBatteryPercent);
7026
canvas_draw_str(canvas, 2, 20, "[MALVEKE] Flipper GB Cam");
7127
canvas_set_font(canvas, FontPrimary);
7228
canvas_draw_str(canvas, 2, 30, "Password");
@@ -91,16 +47,6 @@ static void view_draw_callback(Canvas *canvas, void *_model)
9147
elements_button_center(canvas, "Ok");
9248
}
9349

94-
// if (!model->initialized){
95-
// canvas_clear(canvas);
96-
// canvas_draw_icon(canvas, 74, 16, &I_DolphinCommon_56x48);
97-
// canvas_set_font(canvas, FontSecondary);
98-
// canvas_draw_str(canvas, 8, 12, "Waiting MALVEKE Board...");
99-
// // canvas_draw_str(canvas, 20, 24, "VCC - 3V3/5V");
100-
// // canvas_draw_str(canvas, 20, 34, "GND - GND");
101-
// // canvas_draw_str(canvas, 20, 44, "U0R - TX");
102-
// // canvas_draw_str(canvas, 20, 54, "U0T - RX");
103-
// }
10450
}
10551
static bool view_input_callback(InputEvent *event, void *context)
10652
{
@@ -133,8 +79,8 @@ static bool view_input_callback(InputEvent *event, void *context)
13379
model->initialized = true;
13480
},
13581
true);
136-
uart_tx((uint8_t *)("c"), 1);
137-
uart_tx((uint8_t *)("\n"), 1);
82+
uart_tx(instance->uart, (uint8_t *)("c"), 1);
83+
uart_tx(instance->uart, (uint8_t *)("\n"), 1);
13884

13985
}
14086
}
@@ -158,10 +104,8 @@ void handle_rx_data_cb(uint8_t *buf, size_t len, void *context)
158104
{
159105
furi_assert(context);
160106
UNUSED(len);
161-
// UNUSED(buf);
162107
LinkCameraApp *instance = (LinkCameraApp *)context;
163108

164-
// FURI_LOG_I("UART", "[in]: %s", (char*)buf);
165109
with_view_model(
166110
instance->view,
167111
LinkCameraModel * model,
@@ -243,21 +187,6 @@ static LinkCameraApp *link_camera_alloc()
243187
view_dispatcher_add_view(app->view_dispatcher, 0, app->view);
244188
view_dispatcher_switch_to_view(app->view_dispatcher, 0);
245189

246-
// furi_hal_power_disable_external_3_3v();
247-
// furi_delay_ms(100);
248-
// furi_hal_power_enable_external_3_3v();
249-
// furi_delay_ms(200);
250-
251-
// with_view_model(
252-
// app->view,
253-
// LinkCameraModel * model,
254-
// {
255-
// model->initialized = true;
256-
// },
257-
// true);
258-
// uart_tx((uint8_t*)("c"), 1);
259-
// uart_tx((uint8_t*)("\n"), 1);
260-
261190
return app;
262191
}
263192

@@ -269,7 +198,5 @@ int32_t link_camera_app(void *p)
269198
view_dispatcher_run(app->view_dispatcher);
270199
link_camera_free(app);
271200

272-
// furi_hal_power_disable_otg();
273-
274201
return 0;
275202
}

flipper_companion_apps/applications/external/malveke_gb_link_camera/link_camera.h

+1
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44
#include <gui/icon_i.h>
55
#include <storage/storage.h>
66
#include <gui/view_dispatcher.h>
7+
#include <expansion/expansion.h>
78
#include "cJSON.h"
89
#include "qrcode.h"
910
#include "uart.h"
Original file line numberDiff line numberDiff line change
@@ -1,23 +1,28 @@
11
#include "uart.h"
22

3-
#define UART_CH (FuriHalUartIdUSART1)
4-
#define LP_UART_CH (FuriHalUartIdLPUART1)
5-
#define BAUDRATE (115200)
3+
#define UART_CH (FuriHalSerialIdUsart)
4+
#define LP_UART_CH (FuriHalSerialIdLpuart)
5+
#define BAUDRATE (115200UL)
66

77
struct Uart {
88
void* app;
9-
FuriHalUartId channel;
109
FuriThread* rx_thread;
10+
FuriHalSerialHandle* serial_handle;
11+
FuriHalSerialId channel;
12+
FuriThread* worker_thread;
1113
FuriStreamBuffer* rx_stream;
1214
uint8_t rx_buf[RX_BUF_SIZE + 1];
1315
void (*handle_rx_data_cb)(uint8_t* buf, size_t len, void* context);
1416
};
1517

16-
1718
typedef enum {
1819
WorkerEvtStop = (1 << 0),
1920
WorkerEvtRxDone = (1 << 1),
20-
} WorkerEvtFlags;
21+
} WorkerEventFlags;
22+
23+
#define WORKER_ALL_RX_EVENTS (WorkerEvtStop | WorkerEvtRxDone)
24+
25+
2126

2227
void uart_set_handle_rx_data_cb(
2328
Uart* uart,
@@ -26,17 +31,29 @@ void uart_set_handle_rx_data_cb(
2631
uart->handle_rx_data_cb = handle_rx_data_cb;
2732
}
2833

29-
#define WORKER_ALL_RX_EVENTS (WorkerEvtStop | WorkerEvtRxDone)
30-
31-
void uart_on_irq_cb(UartIrqEvent ev, uint8_t data, void* context) {
34+
static void wifi_marauder_uart_on_irq_cb(
35+
FuriHalSerialHandle* handle,
36+
FuriHalSerialRxEvent event,
37+
void* context) {
3238
Uart* uart = (Uart*)context;
3339

34-
if(ev == UartIrqEventRXNE) {
40+
if(event == FuriHalSerialRxEventData) {
41+
uint8_t data = furi_hal_serial_async_rx(handle);
3542
furi_stream_buffer_send(uart->rx_stream, &data, 1, 0);
3643
furi_thread_flags_set(furi_thread_get_id(uart->rx_thread), WorkerEvtRxDone);
3744
}
3845
}
3946

47+
static void uart_on_irq_cb(FuriHalSerialHandle* handle, FuriHalSerialRxEvent event, void* context) {
48+
Uart* uart = (Uart*)context;
49+
UNUSED(handle);
50+
51+
if(event & (FuriHalSerialRxEventData | FuriHalSerialRxEventIdle)) {
52+
uint8_t data = furi_hal_serial_async_rx(handle);
53+
furi_stream_buffer_send(uart->rx_stream, &data, 1, 0);
54+
furi_thread_flags_set(furi_thread_get_id(uart->rx_thread), WorkerEvtRxDone);
55+
}
56+
}
4057

4158
// Define una constante para el prefijo que estamos buscando
4259
#define JSON_PREFIX "JSON:"
@@ -50,26 +67,25 @@ static bool json_capture_active = false;
5067
// Prototipo de la función
5168
// static void process_json_buffer();
5269

53-
5470
static void process_json_buffer(void* context) {
5571
Uart* uart = (Uart*)context;
5672
// Agregamos el terminador nulo al final del buffer
5773
json_buffer[json_buffer_index] = '\0';
58-
if (uart->handle_rx_data_cb) {
59-
uart->handle_rx_data_cb((uint8_t *)json_buffer, json_buffer_index, uart->app);
74+
if(uart->handle_rx_data_cb) {
75+
uart->handle_rx_data_cb((uint8_t*)json_buffer, json_buffer_index, uart->app);
6076
memset(json_buffer, 0, sizeof(json_buffer));
6177
}
62-
78+
6379
// Reiniciamos el buffer
6480
json_buffer_index = 0;
6581
}
6682

6783
static void uart_echo_push_to_list(void* context, uint8_t data) {
6884
Uart* uart = (Uart*)context;
69-
if (!json_capture_active) {
70-
if (data == JSON_PREFIX[json_buffer_index]) {
85+
if(!json_capture_active) {
86+
if(data == JSON_PREFIX[json_buffer_index]) {
7187
json_buffer[json_buffer_index++] = data; // Agregar el carácter al buffer
72-
if (json_buffer_index == strlen(JSON_PREFIX)) {
88+
if(json_buffer_index == strlen(JSON_PREFIX)) {
7389
// Encontramos el prefijo, comenzamos a capturar
7490
json_buffer_index = 0;
7591
json_capture_active = true;
@@ -81,7 +97,7 @@ static void uart_echo_push_to_list(void* context, uint8_t data) {
8197
} else {
8298
// Capturamos caracteres hasta encontrar '\n'
8399
json_buffer[json_buffer_index++] = data;
84-
if (data == '\n') {
100+
if(data == '\n') {
85101
// Terminamos de capturar la línea, procesamos el buffer
86102
json_capture_active = false;
87103
process_json_buffer(uart);
@@ -93,7 +109,8 @@ static int32_t uart_worker(void* context) {
93109
Uart* uart = (Uart*)context;
94110

95111
while(1) {
96-
uint32_t events = furi_thread_flags_wait(WORKER_ALL_RX_EVENTS, FuriFlagWaitAny, FuriWaitForever);
112+
uint32_t events =
113+
furi_thread_flags_wait(WORKER_ALL_RX_EVENTS, FuriFlagWaitAny, FuriWaitForever);
97114
furi_check((events & FuriFlagError) == 0);
98115

99116
if(events & WorkerEvtStop) break;
@@ -103,17 +120,20 @@ static int32_t uart_worker(void* context) {
103120
do {
104121
uint8_t data[64];
105122
length = furi_stream_buffer_receive(uart->rx_stream, data, 64, 0);
106-
// FURI_LOG_I("UART", "[in]: %s", (char*)data);
123+
107124
if(length > 0) {
108125
for(size_t i = 0; i < length; i++) {
109126
uart_echo_push_to_list(uart, data[i]);
127+
// FURI_LOG_I("UART", "[in]: %c - %d", (const char)data[i], data[i]);
110128
}
111129
}
112130
} while(length > 0);
113131
} else if(uart->channel == LP_UART_CH) {
114-
size_t len = furi_stream_buffer_receive(uart->rx_stream, uart->rx_buf, RX_BUF_SIZE, 0);
132+
size_t len =
133+
furi_stream_buffer_receive(uart->rx_stream, uart->rx_buf, RX_BUF_SIZE, 0);
115134
if(len > 0) {
116-
if(uart->handle_rx_data_cb) uart->handle_rx_data_cb(uart->rx_buf, len, uart->app);
135+
if(uart->handle_rx_data_cb)
136+
uart->handle_rx_data_cb(uart->rx_buf, len, uart->app);
117137
}
118138
}
119139
}
@@ -122,19 +142,13 @@ static int32_t uart_worker(void* context) {
122142

123143
return 0;
124144
}
125-
126-
void uart_tx(uint8_t* data, size_t len) {
127-
furi_hal_uart_tx(UART_CH, data, len);
145+
void uart_tx(void* app, uint8_t* data, size_t len) {
146+
Uart* uart = (Uart*)app;
147+
furi_hal_serial_tx(uart->serial_handle, data, len);
128148
}
129149

130-
void lp_uart_tx(uint8_t* data, size_t len) {
131-
furi_hal_uart_tx(LP_UART_CH, data, len);
132-
}
133-
134-
Uart*
135-
_uart_init(void* app, FuriHalUartId channel, const char* thread_name) {
150+
Uart* _uart_init(void* app, FuriHalSerialId channel, const char* thread_name) {
136151
Uart* uart = (Uart*)malloc(sizeof(Uart));
137-
138152
uart->app = app;
139153
uart->channel = channel;
140154
uart->rx_stream = furi_stream_buffer_alloc(RX_BUF_SIZE, 1);
@@ -144,13 +158,18 @@ Uart*
144158
furi_thread_set_context(uart->rx_thread, uart);
145159
furi_thread_set_callback(uart->rx_thread, uart_worker);
146160
furi_thread_start(uart->rx_thread);
147-
if(channel == FuriHalUartIdUSART1) {
148-
furi_hal_console_disable();
149-
} else if(channel == FuriHalUartIdLPUART1) {
150-
furi_hal_uart_init(channel, BAUDRATE);
161+
uart->serial_handle = furi_hal_serial_control_acquire(channel);
162+
if(!uart->serial_handle) {
163+
furi_delay_ms(5000);
151164
}
152-
furi_hal_uart_set_br(channel, BAUDRATE);
153-
furi_hal_uart_set_irq_cb(channel, uart_on_irq_cb, uart);
165+
furi_check(uart->serial_handle);
166+
furi_hal_serial_init(uart->serial_handle, BAUDRATE);
167+
furi_hal_serial_async_rx_start(
168+
uart->serial_handle,
169+
channel == FuriHalSerialIdUsart ? uart_on_irq_cb : wifi_marauder_uart_on_irq_cb,
170+
uart,
171+
false);
172+
154173

155174
return uart;
156175
}
@@ -166,15 +185,12 @@ Uart* lp_uart_init(void* app) {
166185
void uart_free(Uart* uart) {
167186
furi_assert(uart);
168187

169-
furi_thread_flags_set(furi_thread_get_id(uart->rx_thread), WorkerEvtStop);
188+
furi_thread_flags_set(furi_thread_get_id(uart->rx_thread), WorkerEvtStop);
170189
furi_thread_join(uart->rx_thread);
171190
furi_thread_free(uart->rx_thread);
172191

173-
furi_hal_uart_set_irq_cb(uart->channel, NULL, NULL);
174-
if(uart->channel == FuriHalUartIdLPUART1) {
175-
furi_hal_uart_deinit(uart->channel);
176-
}
177-
furi_hal_console_enable();
192+
furi_hal_serial_deinit(uart->serial_handle);
193+
furi_hal_serial_control_release(uart->serial_handle);
178194

179195
free(uart);
180196
}

flipper_companion_apps/applications/external/malveke_gb_link_camera/uart.h

+6-5
Original file line numberDiff line numberDiff line change
@@ -3,16 +3,17 @@
33

44
#pragma once
55

6-
#include "furi_hal.h"
7-
6+
#include <furi.h>
7+
#include <furi_hal.h>
88

99
#define RX_BUF_SIZE (1024)
1010

1111
typedef struct Uart Uart;
1212

13-
void uart_set_handle_rx_data_cb(Uart* uart, void (*handle_rx_data_cb)(uint8_t* buf, size_t len, void* context));
14-
void uart_tx(uint8_t* data, size_t len);
15-
void lp_uart_tx(uint8_t* data, size_t len);
13+
void uart_set_handle_rx_data_cb(
14+
Uart* uart,
15+
void (*handle_rx_data_cb)(uint8_t* buf, size_t len, void* context));
16+
void uart_tx(void* app, uint8_t* data, size_t len);
1617
Uart* usart_init(void* app);
1718
Uart* lp_uart_init(void* app);
1819
void uart_free(Uart* uart);

0 commit comments

Comments
 (0)