mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2025-12-12 12:42:30 +04:00
Compare commits
428 Commits
unlshd-059
...
nfcrefacto
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
18377185c7 | ||
|
|
ef09dcf8f8 | ||
|
|
bee1a6c18a | ||
|
|
b958bfd5c9 | ||
|
|
49dcf81743 | ||
|
|
16ffa2bf75 | ||
|
|
32e2cbe60a | ||
|
|
a7e6eb7fe4 | ||
|
|
33ed5ea1f2 | ||
|
|
c8c191c0a4 | ||
|
|
78af3214c3 | ||
|
|
e244bedd64 | ||
|
|
ebe95a92d1 | ||
|
|
5921eb3d27 | ||
|
|
9ed23799eb | ||
|
|
19f524ec43 | ||
|
|
085c90af40 | ||
|
|
0d94abf856 | ||
|
|
0131eb3aa2 | ||
|
|
bee48f483c | ||
|
|
47cc05dab4 | ||
|
|
aa06328516 | ||
|
|
7bd3bd7ea4 | ||
|
|
bf8984a225 | ||
|
|
bbe68d6ffc | ||
|
|
9af81ce8d0 | ||
|
|
c8180747db | ||
|
|
917410a0a8 | ||
|
|
176fb21f5f | ||
|
|
593b5fc098 | ||
|
|
0fe93fcfa4 | ||
|
|
cfaf745523 | ||
|
|
3d872cf37a | ||
|
|
844e0f10e5 | ||
|
|
92969ecc1f | ||
|
|
3bbb326c9c | ||
|
|
d92b0a82cc | ||
|
|
ac5abdbb1d | ||
|
|
2958e5cef3 | ||
|
|
35c903494c | ||
|
|
1b6295b2bf | ||
|
|
b93a06354f | ||
|
|
2d9090b2de | ||
|
|
e5b079f4ce | ||
|
|
1e5223c6ab | ||
|
|
29a1865ec3 | ||
|
|
8b8174b1b4 | ||
|
|
53245986ab | ||
|
|
b44bc718be | ||
|
|
8e3378b7b9 | ||
|
|
9e90948fc3 | ||
|
|
b87a8ca329 | ||
|
|
e664159188 | ||
|
|
9d6352e92f | ||
|
|
f45a5dff43 | ||
|
|
130fa43ad6 | ||
|
|
76e5a1c087 | ||
|
|
38792f2c93 | ||
|
|
4308a5e377 | ||
|
|
65a56cdb4a | ||
|
|
fbded1e4ee | ||
|
|
4ae9a02efa | ||
|
|
2c3b5ca43d | ||
|
|
b51b8eb843 | ||
|
|
40552e6837 | ||
|
|
9960328d3e | ||
|
|
3ac6aef6cf | ||
|
|
700cee3766 | ||
|
|
c1363a18cc | ||
|
|
016abe3273 | ||
|
|
5bf5826c88 | ||
|
|
62a4c0dd03 | ||
|
|
d47e5ca520 | ||
|
|
699078d5a5 | ||
|
|
8ebfda6b8c | ||
|
|
e7ea821650 | ||
|
|
0c2c74ae21 | ||
|
|
9898a5d0dd | ||
|
|
09f86f24fd | ||
|
|
57aa5e1620 | ||
|
|
ef01355297 | ||
|
|
14c0572368 | ||
|
|
50aaacd30d | ||
|
|
2f44fd6cac | ||
|
|
c924693a84 | ||
|
|
e739aeeb10 | ||
|
|
5031540a8f | ||
|
|
fc1ec55a40 | ||
|
|
a6bb9698ef | ||
|
|
63d7d46bd3 | ||
|
|
e1030e7999 | ||
|
|
8d1a4a5c69 | ||
|
|
cc5607d66f | ||
|
|
8666cdc5ef | ||
|
|
286dbfaf0b | ||
|
|
bf8357ee52 | ||
|
|
b98631c633 | ||
|
|
1891d54baf | ||
|
|
b80dfbe0c5 | ||
|
|
a73a83f04d | ||
|
|
3fbb9f24f8 | ||
|
|
a089aeb2bd | ||
|
|
182c8defb1 | ||
|
|
f46018b204 | ||
|
|
f7f9250e55 | ||
|
|
70b8823eb8 | ||
|
|
8f5ea2be83 | ||
|
|
abe0e34ace | ||
|
|
1f485be6e8 | ||
|
|
4368ff4294 | ||
|
|
338fc3afea | ||
|
|
fdc39f8473 | ||
|
|
931f4464c2 | ||
|
|
5901720681 | ||
|
|
e68ee9b47c | ||
|
|
ee24e4eb48 | ||
|
|
25af13e998 | ||
|
|
ac892f3d03 | ||
|
|
4d3a3070e4 | ||
|
|
6a2adf69e6 | ||
|
|
19ca956e7c | ||
|
|
1530c2b4f1 | ||
|
|
f0f2a6c11f | ||
|
|
8bfa9898e3 | ||
|
|
953a747b1a | ||
|
|
8835ef3598 | ||
|
|
cbc5d61ab7 | ||
|
|
e8210cd94d | ||
|
|
b6ff400587 | ||
|
|
91813831c6 | ||
|
|
c657eb8a40 | ||
|
|
091210c003 | ||
|
|
d4cad7b8c6 | ||
|
|
5949d7be1c | ||
|
|
ac3bd337a1 | ||
|
|
f09d364e95 | ||
|
|
7f474ed9c6 | ||
|
|
04c914d945 | ||
|
|
93ae4db35a | ||
|
|
2db719f35c | ||
|
|
e36b87ddd9 | ||
|
|
1c360ae110 | ||
|
|
44140caa2d | ||
|
|
15894235a9 | ||
|
|
fae8d91880 | ||
|
|
78446bab07 | ||
|
|
84e94e728c | ||
|
|
b2042fd044 | ||
|
|
67a681f8b8 | ||
|
|
eb2607f308 | ||
|
|
9f6fc6fe79 | ||
|
|
226e300a16 | ||
|
|
77d6c41914 | ||
|
|
d49246048d | ||
|
|
4705812d24 | ||
|
|
1c0276a0be | ||
|
|
abc4110198 | ||
|
|
99ba1b6a24 | ||
|
|
1fec80a533 | ||
|
|
53fffffd1b | ||
|
|
a90ebd7b53 | ||
|
|
b1b35e87f9 | ||
|
|
1df2fc035f | ||
|
|
45fd5ef9d8 | ||
|
|
dfd5233760 | ||
|
|
cfa95c757e | ||
|
|
600b2ce627 | ||
|
|
fdb9748acc | ||
|
|
d40f664342 | ||
|
|
8cbb757533 | ||
|
|
452e27b05e | ||
|
|
b3cce2351a | ||
|
|
1859b06b6a | ||
|
|
1653abe0ef | ||
|
|
c7b2e85e13 | ||
|
|
b24fba6ad7 | ||
|
|
ffc6f726f0 | ||
|
|
0eb06ba2b7 | ||
|
|
2a789ae1c1 | ||
|
|
062faa4a84 | ||
|
|
1cafa9a46b | ||
|
|
654b3245c2 | ||
|
|
99eb10d6e7 | ||
|
|
e878ed7547 | ||
|
|
ac4177c248 | ||
|
|
e6f9563bbc | ||
|
|
2b383ebcee | ||
|
|
cfc5caca63 | ||
|
|
9c6e20356f | ||
|
|
0b806c2360 | ||
|
|
ce89240f6f | ||
|
|
686fab7296 | ||
|
|
7d2deb5939 | ||
|
|
06a528f497 | ||
|
|
265d2592e7 | ||
|
|
72e6f5f59e | ||
|
|
3898e6e71d | ||
|
|
17269a5386 | ||
|
|
a2bcf67f7f | ||
|
|
bd2cfb55df | ||
|
|
0c7689831e | ||
|
|
ec9df8711a | ||
|
|
15c480b68a | ||
|
|
a8456208da | ||
|
|
7ecd5684cb | ||
|
|
832d861b9d | ||
|
|
7a0c896626 | ||
|
|
52b5966262 | ||
|
|
e5fdb2e069 | ||
|
|
5eeb672dd4 | ||
|
|
d8d2b360cb | ||
|
|
7531e18020 | ||
|
|
f218c41d83 | ||
|
|
7aa55ebc6c | ||
|
|
809418b9da | ||
|
|
b91f8d009e | ||
|
|
aa1c1fd905 | ||
|
|
cb5c5c08f6 | ||
|
|
c6be6f487a | ||
|
|
5eb045e25f | ||
|
|
04b2771e3b | ||
|
|
5bd868665e | ||
|
|
46e74b3823 | ||
|
|
a772408ee6 | ||
|
|
7b4d66f0f4 | ||
|
|
416a02fc5b | ||
|
|
cf74dd2599 | ||
|
|
66d26c16cd | ||
|
|
c3aa151712 | ||
|
|
c3d2a1f243 | ||
|
|
3491844d41 | ||
|
|
9ef1a4dfaa | ||
|
|
ce1336c0ed | ||
|
|
32fb94f5db | ||
|
|
f53246d40b | ||
|
|
d1f1635dd2 | ||
|
|
f93aab9b22 | ||
|
|
742c4ae834 | ||
|
|
6609a64307 | ||
|
|
09aabff55b | ||
|
|
0660329ae5 | ||
|
|
b5426197f5 | ||
|
|
940ec36a0b | ||
|
|
60182aa2cd | ||
|
|
56b5b35236 | ||
|
|
b368660d48 | ||
|
|
091d32ed7a | ||
|
|
52654d018e | ||
|
|
8df9947d42 | ||
|
|
d808884b97 | ||
|
|
6042254861 | ||
|
|
beeeb9bbdc | ||
|
|
4ade0fc76d | ||
|
|
15f92f765d | ||
|
|
821f03b230 | ||
|
|
ad723217e6 | ||
|
|
df5b2cbddd | ||
|
|
dc7517e5fd | ||
|
|
20593d56c0 | ||
|
|
27b2808ade | ||
|
|
ace0901125 | ||
|
|
991e58e405 | ||
|
|
e353433cd8 | ||
|
|
200c44bdca | ||
|
|
67a0136e81 | ||
|
|
2b5ad4f5af | ||
|
|
35cdefa1ca | ||
|
|
f14ed73dfd | ||
|
|
9bf1433334 | ||
|
|
35c413b8a6 | ||
|
|
34712b0c3b | ||
|
|
486542fe14 | ||
|
|
69debc36a0 | ||
|
|
2fabb0b589 | ||
|
|
c05a766651 | ||
|
|
ac9234563a | ||
|
|
b07b6dc857 | ||
|
|
c70edf6dc9 | ||
|
|
8a3d8bdee7 | ||
|
|
535bf35e23 | ||
|
|
362aa68038 | ||
|
|
f17b941f7d | ||
|
|
830eb0e5f6 | ||
|
|
38607d8dbe | ||
|
|
fe095df06a | ||
|
|
d728c140d8 | ||
|
|
4f6fd2e9bc | ||
|
|
e7c52828ea | ||
|
|
fea15bedd4 | ||
|
|
d7a579e713 | ||
|
|
26e5ae7476 | ||
|
|
2458cb2b96 | ||
|
|
3da9cb1b81 | ||
|
|
5924c3dd2c | ||
|
|
5cfc8fc536 | ||
|
|
03d3482357 | ||
|
|
0af8bd1e8b | ||
|
|
6330012b1d | ||
|
|
b1b00d4fa7 | ||
|
|
7a80aaa5c8 | ||
|
|
3584e0da46 | ||
|
|
e1c83692c3 | ||
|
|
3507c89dbb | ||
|
|
6e2bcd9d00 | ||
|
|
f73f369952 | ||
|
|
3990c93013 | ||
|
|
4d5a900352 | ||
|
|
e830dc1636 | ||
|
|
2d6bd46326 | ||
|
|
0805754589 | ||
|
|
d627b53510 | ||
|
|
69cabfb496 | ||
|
|
b235c8abe9 | ||
|
|
0934b3f791 | ||
|
|
fec80da3f4 | ||
|
|
e892c977f3 | ||
|
|
15ac511dea | ||
|
|
b90e2ca342 | ||
|
|
aad06fdd43 | ||
|
|
d4bc0cc10c | ||
|
|
0ecec8a711 | ||
|
|
9d7396ee63 | ||
|
|
a7f0f5ad27 | ||
|
|
146ae8c3bf | ||
|
|
aeadaef7c9 | ||
|
|
fb2c65721b | ||
|
|
830e202bb1 | ||
|
|
9e3868887c | ||
|
|
f18df25a96 | ||
|
|
7bd8846288 | ||
|
|
196edb5d05 | ||
|
|
8c0e0c78f2 | ||
|
|
71b610c87e | ||
|
|
4f148079d5 | ||
|
|
80c0301316 | ||
|
|
4d772ed67e | ||
|
|
ff17f33a36 | ||
|
|
9fb20438c7 | ||
|
|
28a05d8f6b | ||
|
|
773a5e382f | ||
|
|
4164932044 | ||
|
|
751cb9f5d6 | ||
|
|
8d8102b4f9 | ||
|
|
4b81046b6f | ||
|
|
f069cdb7e6 | ||
|
|
43ba76a37f | ||
|
|
3aad84aa70 | ||
|
|
dc2d12d468 | ||
|
|
09d5b3b1ed | ||
|
|
5f48968a05 | ||
|
|
3a36d5ea6d | ||
|
|
12d9b1069c | ||
|
|
7178bd20cf | ||
|
|
f75fcd4e34 | ||
|
|
498aee20a2 | ||
|
|
ee64a962d9 | ||
|
|
c40e4ba01e | ||
|
|
2702c00ba4 | ||
|
|
c976ff11bf | ||
|
|
fb63e53d9a | ||
|
|
1078625775 | ||
|
|
7027f6a4c4 | ||
|
|
a39ef50fdb | ||
|
|
d9e931b7b7 | ||
|
|
98d4309b61 | ||
|
|
00cdc3d1cb | ||
|
|
5bbee02704 | ||
|
|
8936c02487 | ||
|
|
e9f1af44f2 | ||
|
|
ab006361cc | ||
|
|
8c44dfb6af | ||
|
|
540862fbf2 | ||
|
|
1e4af1d550 | ||
|
|
4c771b66dc | ||
|
|
20a6aa078c | ||
|
|
3c298d7d83 | ||
|
|
e01e6f163c | ||
|
|
6f37f01b20 | ||
|
|
d11fdca903 | ||
|
|
e50cab3da1 | ||
|
|
49d2b31446 | ||
|
|
c1438ce850 | ||
|
|
0f61a8eb46 | ||
|
|
6ef1847e4d | ||
|
|
f70d2b5ae7 | ||
|
|
4951efff4d | ||
|
|
07f6859a80 | ||
|
|
d30510f700 | ||
|
|
becc8edd8c | ||
|
|
d09cf6c692 | ||
|
|
afa7bd7f79 | ||
|
|
eb54fef384 | ||
|
|
fe630362a8 | ||
|
|
66deaad4f4 | ||
|
|
500ca0758a | ||
|
|
74ffb02b56 | ||
|
|
c7648eb932 | ||
|
|
cf6706c42e | ||
|
|
a7aef0bfc2 | ||
|
|
3e8e999909 | ||
|
|
3a5ed704fd | ||
|
|
7a45db3881 | ||
|
|
9fd9dd85e3 | ||
|
|
313e9c3d89 | ||
|
|
c72531edc6 | ||
|
|
035e447009 | ||
|
|
be86b0f38a | ||
|
|
a677b2bcc2 | ||
|
|
17bcfee224 | ||
|
|
1536f7a643 | ||
|
|
67ca96ea96 | ||
|
|
fe7a1c2fcc | ||
|
|
aadb72af53 | ||
|
|
68eb1ecebb | ||
|
|
a2a4fa8cda | ||
|
|
5d21da1737 | ||
|
|
7413f707ed | ||
|
|
c6b6aec057 | ||
|
|
c3f7a0d128 | ||
|
|
2c656f9c49 | ||
|
|
913efab179 | ||
|
|
03b950999c | ||
|
|
62e817f183 | ||
|
|
0f9c6ba847 | ||
|
|
e698d6274f | ||
|
|
ff2e1acfdb | ||
|
|
d4ff1e3a50 | ||
|
|
58beca313d |
@@ -161,3 +161,17 @@ Max butthurt: 5
|
|||||||
Min level: 1
|
Min level: 1
|
||||||
Max level: 3
|
Max level: 3
|
||||||
Weight: 4
|
Weight: 4
|
||||||
|
|
||||||
|
Name: L1_Sad_song_128x64
|
||||||
|
Min butthurt: 8
|
||||||
|
Max butthurt: 13
|
||||||
|
Min level: 1
|
||||||
|
Max level: 3
|
||||||
|
Weight: 4
|
||||||
|
|
||||||
|
Name: L2_Coding_in_the_shell_128x64
|
||||||
|
Min butthurt: 0
|
||||||
|
Max butthurt: 12
|
||||||
|
Min level: 2
|
||||||
|
Max level: 3
|
||||||
|
Weight: 4
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
diff --git a/applications/services/notification/notification_app.c b/applications/services/notification/notification_app.c
|
diff --git a/applications/services/notification/notification_app.c b/applications/services/notification/notification_app.c
|
||||||
index 2f947fe..03c4c76 100644
|
index 5769ced..c5d3088 100644
|
||||||
--- a/applications/services/notification/notification_app.c
|
--- a/applications/services/notification/notification_app.c
|
||||||
+++ b/applications/services/notification/notification_app.c
|
+++ b/applications/services/notification/notification_app.c
|
||||||
@@ -9,6 +9,7 @@
|
@@ -9,6 +9,7 @@
|
||||||
@@ -10,7 +10,7 @@ index 2f947fe..03c4c76 100644
|
|||||||
|
|
||||||
#define TAG "NotificationSrv"
|
#define TAG "NotificationSrv"
|
||||||
|
|
||||||
@@ -579,6 +580,7 @@ int32_t notification_srv(void* p) {
|
@@ -589,6 +590,7 @@ int32_t notification_srv(void* p) {
|
||||||
break;
|
break;
|
||||||
case SaveSettingsMessage:
|
case SaveSettingsMessage:
|
||||||
notification_save_settings(app);
|
notification_save_settings(app);
|
||||||
@@ -19,7 +19,7 @@ index 2f947fe..03c4c76 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/applications/settings/notification_settings/notification_settings_app.c b/applications/settings/notification_settings/notification_settings_app.c
|
diff --git a/applications/settings/notification_settings/notification_settings_app.c b/applications/settings/notification_settings/notification_settings_app.c
|
||||||
index 565d4f1..bae9299 100644
|
index 1955012..19d953d 100644
|
||||||
--- a/applications/settings/notification_settings/notification_settings_app.c
|
--- a/applications/settings/notification_settings/notification_settings_app.c
|
||||||
+++ b/applications/settings/notification_settings/notification_settings_app.c
|
+++ b/applications/settings/notification_settings/notification_settings_app.c
|
||||||
@@ -3,6 +3,7 @@
|
@@ -3,6 +3,7 @@
|
||||||
@@ -30,10 +30,20 @@ index 565d4f1..bae9299 100644
|
|||||||
|
|
||||||
#define MAX_NOTIFICATION_SETTINGS 4
|
#define MAX_NOTIFICATION_SETTINGS 4
|
||||||
|
|
||||||
@@ -162,6 +163,14 @@ static void vibro_changed(VariableItem* item) {
|
@@ -20,6 +21,8 @@ static const NotificationSequence sequence_note_c = {
|
||||||
|
NULL,
|
||||||
|
};
|
||||||
|
|
||||||
|
+static VariableItem* temp_item;
|
||||||
|
+
|
||||||
|
#define CONTRAST_COUNT 11
|
||||||
|
const char* const contrast_text[CONTRAST_COUNT] = {
|
||||||
|
"-5",
|
||||||
|
@@ -156,6 +159,59 @@ static void vibro_changed(VariableItem* item) {
|
||||||
notification_message(app->notification, &sequence_single_vibro);
|
notification_message(app->notification, &sequence_single_vibro);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
+// Set RGB backlight color
|
||||||
+static void color_changed(VariableItem* item) {
|
+static void color_changed(VariableItem* item) {
|
||||||
+ NotificationAppSettings* app = variable_item_get_context(item);
|
+ NotificationAppSettings* app = variable_item_get_context(item);
|
||||||
+ uint8_t index = variable_item_get_current_value_index(item);
|
+ uint8_t index = variable_item_get_current_value_index(item);
|
||||||
@@ -41,31 +51,102 @@ index 565d4f1..bae9299 100644
|
|||||||
+ variable_item_set_current_value_text(item, rgb_backlight_get_color_text(index));
|
+ variable_item_set_current_value_text(item, rgb_backlight_get_color_text(index));
|
||||||
+ notification_message(app->notification, &sequence_display_backlight_on);
|
+ notification_message(app->notification, &sequence_display_backlight_on);
|
||||||
+}
|
+}
|
||||||
|
+
|
||||||
|
+// TODO: refactor and fix this
|
||||||
|
+static void color_set_custom_red(VariableItem* item) {
|
||||||
|
+ NotificationAppSettings* app = variable_item_get_context(item);
|
||||||
|
+ uint8_t index = variable_item_get_current_value_index(item);
|
||||||
|
+ rgb_backlight_set_custom_color(index, 0);
|
||||||
|
+ char valtext[4] = {};
|
||||||
|
+ snprintf(valtext, sizeof(valtext), "%d", index);
|
||||||
|
+ variable_item_set_current_value_text(item, valtext);
|
||||||
|
+ rgb_backlight_set_color(13);
|
||||||
|
+ rgb_backlight_update(app->notification->settings.display_brightness * 0xFF, true);
|
||||||
|
+ // Set to custom color explicitly
|
||||||
|
+ variable_item_set_current_value_index(temp_item, 13);
|
||||||
|
+ variable_item_set_current_value_text(temp_item, rgb_backlight_get_color_text(13));
|
||||||
|
+ notification_message(app->notification, &sequence_display_backlight_on);
|
||||||
|
+}
|
||||||
|
+static void color_set_custom_green(VariableItem* item) {
|
||||||
|
+ NotificationAppSettings* app = variable_item_get_context(item);
|
||||||
|
+ uint8_t index = variable_item_get_current_value_index(item);
|
||||||
|
+ rgb_backlight_set_custom_color(index, 1);
|
||||||
|
+ char valtext[4] = {};
|
||||||
|
+ snprintf(valtext, sizeof(valtext), "%d", index);
|
||||||
|
+ variable_item_set_current_value_text(item, valtext);
|
||||||
|
+ rgb_backlight_set_color(13);
|
||||||
|
+ rgb_backlight_update(app->notification->settings.display_brightness * 0xFF, true);
|
||||||
|
+ // Set to custom color explicitly
|
||||||
|
+ variable_item_set_current_value_index(temp_item, 13);
|
||||||
|
+ variable_item_set_current_value_text(temp_item, rgb_backlight_get_color_text(13));
|
||||||
|
+ notification_message(app->notification, &sequence_display_backlight_on);
|
||||||
|
+}
|
||||||
|
+static void color_set_custom_blue(VariableItem* item) {
|
||||||
|
+ NotificationAppSettings* app = variable_item_get_context(item);
|
||||||
|
+ uint8_t index = variable_item_get_current_value_index(item);
|
||||||
|
+ rgb_backlight_set_custom_color(index, 2);
|
||||||
|
+ char valtext[4] = {};
|
||||||
|
+ snprintf(valtext, sizeof(valtext), "%d", index);
|
||||||
|
+ variable_item_set_current_value_text(item, valtext);
|
||||||
|
+ rgb_backlight_set_color(13);
|
||||||
|
+ rgb_backlight_update(app->notification->settings.display_brightness * 0xFF, true);
|
||||||
|
+ // Set to custom color explicitly
|
||||||
|
+ variable_item_set_current_value_index(temp_item, 13);
|
||||||
|
+ variable_item_set_current_value_text(temp_item, rgb_backlight_get_color_text(13));
|
||||||
|
+ notification_message(app->notification, &sequence_display_backlight_on);
|
||||||
|
+}
|
||||||
+
|
+
|
||||||
static uint32_t notification_app_settings_exit(void* context) {
|
static uint32_t notification_app_settings_exit(void* context) {
|
||||||
UNUSED(context);
|
UNUSED(context);
|
||||||
return VIEW_NONE;
|
return VIEW_NONE;
|
||||||
@@ -187,7 +196,13 @@ static NotificationAppSettings* alloc_settings() {
|
@@ -180,8 +236,40 @@ static NotificationAppSettings* alloc_settings() {
|
||||||
|
variable_item_set_current_value_index(item, value_index);
|
||||||
variable_item_set_current_value_text(item, contrast_text[value_index]);
|
variable_item_set_current_value_text(item, contrast_text[value_index]);
|
||||||
|
|
||||||
item = variable_item_list_add(
|
+ // RGB Colors
|
||||||
- app->variable_item_list, "LCD Backlight", BACKLIGHT_COUNT, backlight_changed, app);
|
+ item = variable_item_list_add(
|
||||||
+ app->variable_item_list, "LCD Color", rgb_backlight_get_color_count(), color_changed, app);
|
+ app->variable_item_list, "LCD Color", rgb_backlight_get_color_count(), color_changed, app);
|
||||||
+ value_index = rgb_backlight_get_settings()->display_color_index;
|
+ value_index = rgb_backlight_get_settings()->display_color_index;
|
||||||
+ variable_item_set_current_value_index(item, value_index);
|
+ variable_item_set_current_value_index(item, value_index);
|
||||||
+ variable_item_set_current_value_text(item, rgb_backlight_get_color_text(value_index));
|
+ variable_item_set_current_value_text(item, rgb_backlight_get_color_text(value_index));
|
||||||
|
+ temp_item = item;
|
||||||
|
+
|
||||||
|
+ // Custom Color - REFACTOR THIS
|
||||||
|
+ item = variable_item_list_add(
|
||||||
|
+ app->variable_item_list, "Custom Red", 255, color_set_custom_red, app);
|
||||||
|
+ value_index = rgb_backlight_get_settings()->custom_r;
|
||||||
|
+ variable_item_set_current_value_index(item, value_index);
|
||||||
|
+ char valtext[4] = {};
|
||||||
|
+ snprintf(valtext, sizeof(valtext), "%d", value_index);
|
||||||
|
+ variable_item_set_current_value_text(item, valtext);
|
||||||
+
|
+
|
||||||
+ item = variable_item_list_add(
|
+ item = variable_item_list_add(
|
||||||
|
+ app->variable_item_list, "Custom Green", 255, color_set_custom_green, app);
|
||||||
|
+ value_index = rgb_backlight_get_settings()->custom_g;
|
||||||
|
+ variable_item_set_current_value_index(item, value_index);
|
||||||
|
+ snprintf(valtext, sizeof(valtext), "%d", value_index);
|
||||||
|
+ variable_item_set_current_value_text(item, valtext);
|
||||||
|
+
|
||||||
|
+ item = variable_item_list_add(
|
||||||
|
+ app->variable_item_list, "Custom Blue", 255, color_set_custom_blue, app);
|
||||||
|
+ value_index = rgb_backlight_get_settings()->custom_b;
|
||||||
|
+ variable_item_set_current_value_index(item, value_index);
|
||||||
|
+ snprintf(valtext, sizeof(valtext), "%d", value_index);
|
||||||
|
+ variable_item_set_current_value_text(item, valtext);
|
||||||
|
+ // End of RGB
|
||||||
|
+
|
||||||
|
item = variable_item_list_add(
|
||||||
|
- app->variable_item_list, "LCD Backlight", BACKLIGHT_COUNT, backlight_changed, app);
|
||||||
+ app->variable_item_list, "LCD Brightness", BACKLIGHT_COUNT, backlight_changed, app);
|
+ app->variable_item_list, "LCD Brightness", BACKLIGHT_COUNT, backlight_changed, app);
|
||||||
value_index = value_index_float(
|
value_index = value_index_float(
|
||||||
app->notification->settings.display_brightness, backlight_value, BACKLIGHT_COUNT);
|
app->notification->settings.display_brightness, backlight_value, BACKLIGHT_COUNT);
|
||||||
variable_item_set_current_value_index(item, value_index);
|
variable_item_set_current_value_index(item, value_index);
|
||||||
diff --git a/applications/settings/notification_settings/rgb_backlight.c b/applications/settings/notification_settings/rgb_backlight.c
|
diff --git a/applications/settings/notification_settings/rgb_backlight.c b/applications/settings/notification_settings/rgb_backlight.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 0000000..269b544
|
index 0000000..98f0d3a
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/applications/settings/notification_settings/rgb_backlight.c
|
+++ b/applications/settings/notification_settings/rgb_backlight.c
|
||||||
@@ -0,0 +1,171 @@
|
@@ -0,0 +1,217 @@
|
||||||
+/*
|
+/*
|
||||||
+ RGB backlight FlipperZero driver
|
+ RGB backlight FlipperZero driver
|
||||||
+ Copyright (C) 2022-2023 Victor Nikitchuk (https://github.com/quen0n)
|
+ Copyright (C) 2022-2023 Victor Nikitchuk (https://github.com/quen0n)
|
||||||
@@ -88,9 +169,9 @@ index 0000000..269b544
|
|||||||
+#include <furi_hal.h>
|
+#include <furi_hal.h>
|
||||||
+#include <storage/storage.h>
|
+#include <storage/storage.h>
|
||||||
+
|
+
|
||||||
+#define RGB_BACKLIGHT_SETTINGS_VERSION 5
|
+#define RGB_BACKLIGHT_SETTINGS_VERSION 6
|
||||||
+#define RGB_BACKLIGHT_SETTINGS_FILE_NAME ".rgb_backlight.settings"
|
+#define RGB_BACKLIGHT_SETTINGS_FILE_NAME ".rgb_backlight.settings"
|
||||||
+#define RGB_BACKLIGHT_SETTINGS_PATH EXT_PATH(RGB_BACKLIGHT_SETTINGS_FILE_NAME)
|
+#define RGB_BACKLIGHT_SETTINGS_PATH INT_PATH(RGB_BACKLIGHT_SETTINGS_FILE_NAME)
|
||||||
+
|
+
|
||||||
+#define COLOR_COUNT (sizeof(colors) / sizeof(RGBBacklightColor))
|
+#define COLOR_COUNT (sizeof(colors) / sizeof(RGBBacklightColor))
|
||||||
+
|
+
|
||||||
@@ -99,11 +180,14 @@ index 0000000..269b544
|
|||||||
+static RGBBacklightSettings rgb_settings = {
|
+static RGBBacklightSettings rgb_settings = {
|
||||||
+ .version = RGB_BACKLIGHT_SETTINGS_VERSION,
|
+ .version = RGB_BACKLIGHT_SETTINGS_VERSION,
|
||||||
+ .display_color_index = 0,
|
+ .display_color_index = 0,
|
||||||
|
+ .custom_r = 254,
|
||||||
|
+ .custom_g = 254,
|
||||||
|
+ .custom_b = 254,
|
||||||
+ .settings_is_loaded = false};
|
+ .settings_is_loaded = false};
|
||||||
+
|
+
|
||||||
+static const RGBBacklightColor colors[] = {
|
+static const RGBBacklightColor colors[] = {
|
||||||
+ {"Orange", 255, 79, 0},
|
+ {"Orange", 255, 60, 0},
|
||||||
+ {"Yellow", 255, 170, 0},
|
+ {"Yellow", 255, 144, 0},
|
||||||
+ {"Spring", 167, 255, 0},
|
+ {"Spring", 167, 255, 0},
|
||||||
+ {"Lime", 0, 255, 0},
|
+ {"Lime", 0, 255, 0},
|
||||||
+ {"Aqua", 0, 255, 127},
|
+ {"Aqua", 0, 255, 127},
|
||||||
@@ -114,7 +198,8 @@ index 0000000..269b544
|
|||||||
+ {"Magenta", 210, 0, 210},
|
+ {"Magenta", 210, 0, 210},
|
||||||
+ {"Pink", 255, 0, 127},
|
+ {"Pink", 255, 0, 127},
|
||||||
+ {"Red", 255, 0, 0},
|
+ {"Red", 255, 0, 0},
|
||||||
+ {"White", 140, 140, 140},
|
+ {"White", 254, 210, 200},
|
||||||
|
+ {"Custom", 0, 0, 0},
|
||||||
+};
|
+};
|
||||||
+
|
+
|
||||||
+uint8_t rgb_backlight_get_color_count(void) {
|
+uint8_t rgb_backlight_get_color_count(void) {
|
||||||
@@ -126,18 +211,28 @@ index 0000000..269b544
|
|||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
+void rgb_backlight_load_settings(void) {
|
+void rgb_backlight_load_settings(void) {
|
||||||
+ //Не загружать данные из внутренней памяти при загрузке в режиме DFU
|
+ // Do not load settings if we are in other boot modes than normal
|
||||||
+ FuriHalRtcBootMode bm = furi_hal_rtc_get_boot_mode();
|
+ if(furi_hal_rtc_get_boot_mode() != FuriHalRtcBootModeNormal) {
|
||||||
+ if(bm == FuriHalRtcBootModeDfu) {
|
|
||||||
+ rgb_settings.settings_is_loaded = true;
|
+ rgb_settings.settings_is_loaded = true;
|
||||||
+ return;
|
+ return;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
+ // Wait for all required services to start and create their records
|
||||||
|
+ uint8_t timeout = 0;
|
||||||
|
+ while(!furi_record_exists(RECORD_STORAGE)) {
|
||||||
|
+ timeout++;
|
||||||
|
+ if(timeout > 150) {
|
||||||
|
+ rgb_settings.settings_is_loaded = true;
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+ furi_delay_ms(5);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
+ RGBBacklightSettings settings;
|
+ RGBBacklightSettings settings;
|
||||||
+ File* file = storage_file_alloc(furi_record_open(RECORD_STORAGE));
|
+ File* file = storage_file_alloc(furi_record_open(RECORD_STORAGE));
|
||||||
+ const size_t settings_size = sizeof(RGBBacklightSettings);
|
+ const size_t settings_size = sizeof(RGBBacklightSettings);
|
||||||
+
|
+
|
||||||
+ FURI_LOG_I(TAG, "loading settings from \"%s\"", RGB_BACKLIGHT_SETTINGS_PATH);
|
+ FURI_LOG_D(TAG, "loading settings from \"%s\"", RGB_BACKLIGHT_SETTINGS_PATH);
|
||||||
+ bool fs_result =
|
+ bool fs_result =
|
||||||
+ storage_file_open(file, RGB_BACKLIGHT_SETTINGS_PATH, FSAM_READ, FSOM_OPEN_EXISTING);
|
+ storage_file_open(file, RGB_BACKLIGHT_SETTINGS_PATH, FSAM_READ, FSOM_OPEN_EXISTING);
|
||||||
+
|
+
|
||||||
@@ -150,7 +245,7 @@ index 0000000..269b544
|
|||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ if(fs_result) {
|
+ if(fs_result) {
|
||||||
+ FURI_LOG_I(TAG, "load success");
|
+ FURI_LOG_D(TAG, "load success");
|
||||||
+ if(settings.version != RGB_BACKLIGHT_SETTINGS_VERSION) {
|
+ if(settings.version != RGB_BACKLIGHT_SETTINGS_VERSION) {
|
||||||
+ FURI_LOG_E(
|
+ FURI_LOG_E(
|
||||||
+ TAG,
|
+ TAG,
|
||||||
@@ -175,7 +270,7 @@ index 0000000..269b544
|
|||||||
+ File* file = storage_file_alloc(furi_record_open(RECORD_STORAGE));
|
+ File* file = storage_file_alloc(furi_record_open(RECORD_STORAGE));
|
||||||
+ const size_t settings_size = sizeof(RGBBacklightSettings);
|
+ const size_t settings_size = sizeof(RGBBacklightSettings);
|
||||||
+
|
+
|
||||||
+ FURI_LOG_I(TAG, "saving settings to \"%s\"", RGB_BACKLIGHT_SETTINGS_PATH);
|
+ FURI_LOG_D(TAG, "saving settings to \"%s\"", RGB_BACKLIGHT_SETTINGS_PATH);
|
||||||
+
|
+
|
||||||
+ memcpy(&settings, &rgb_settings, settings_size);
|
+ memcpy(&settings, &rgb_settings, settings_size);
|
||||||
+
|
+
|
||||||
@@ -191,7 +286,7 @@ index 0000000..269b544
|
|||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ if(fs_result) {
|
+ if(fs_result) {
|
||||||
+ FURI_LOG_I(TAG, "save success");
|
+ FURI_LOG_D(TAG, "save success");
|
||||||
+ } else {
|
+ } else {
|
||||||
+ FURI_LOG_E(TAG, "save failed, %s", storage_file_get_error_desc(file));
|
+ FURI_LOG_E(TAG, "save failed, %s", storage_file_get_error_desc(file));
|
||||||
+ }
|
+ }
|
||||||
@@ -213,36 +308,68 @@ index 0000000..269b544
|
|||||||
+ rgb_settings.display_color_index = color_index;
|
+ rgb_settings.display_color_index = color_index;
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
+void rgb_backlight_update(uint8_t brightness) {
|
+void rgb_backlight_set_custom_color(uint8_t color, uint8_t index) {
|
||||||
|
+ if(index > 2) return;
|
||||||
|
+ if(index == 0) {
|
||||||
|
+ rgb_settings.custom_r = color;
|
||||||
|
+ } else if(index == 1) {
|
||||||
|
+ rgb_settings.custom_g = color;
|
||||||
|
+ } else if(index == 2) {
|
||||||
|
+ rgb_settings.custom_b = color;
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+void rgb_backlight_update(uint8_t brightness, bool bypass) {
|
||||||
+ if(!rgb_settings.settings_is_loaded) {
|
+ if(!rgb_settings.settings_is_loaded) {
|
||||||
+ rgb_backlight_load_settings();
|
+ rgb_backlight_load_settings();
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
+ if(!bypass) {
|
||||||
+ static uint8_t last_color_index = 255;
|
+ static uint8_t last_color_index = 255;
|
||||||
+ static uint8_t last_brightness = 123;
|
+ static uint8_t last_brightness = 123;
|
||||||
+
|
+
|
||||||
+ if(last_brightness == brightness && last_color_index == rgb_settings.display_color_index)
|
+ if(last_brightness == brightness && last_color_index == rgb_settings.display_color_index) {
|
||||||
+ return;
|
+ return;
|
||||||
|
+ }
|
||||||
+
|
+
|
||||||
+ last_brightness = brightness;
|
+ last_brightness = brightness;
|
||||||
+ last_color_index = rgb_settings.display_color_index;
|
+ last_color_index = rgb_settings.display_color_index;
|
||||||
|
+ }
|
||||||
+
|
+
|
||||||
+ for(uint8_t i = 0; i < SK6805_get_led_count(); i++) {
|
+ for(uint8_t i = 0; i < SK6805_get_led_count(); i++) {
|
||||||
|
+ if(rgb_settings.display_color_index == 13) {
|
||||||
|
+ uint8_t r = rgb_settings.custom_r * (brightness / 255.0f);
|
||||||
|
+ uint8_t g = rgb_settings.custom_g * (brightness / 255.0f);
|
||||||
|
+ uint8_t b = rgb_settings.custom_b * (brightness / 255.0f);
|
||||||
|
+
|
||||||
|
+ SK6805_set_led_color(i, r, g, b);
|
||||||
|
+ } else {
|
||||||
|
+ if((colors[rgb_settings.display_color_index].red == 0) &&
|
||||||
|
+ (colors[rgb_settings.display_color_index].green == 0) &&
|
||||||
|
+ (colors[rgb_settings.display_color_index].blue == 0)) {
|
||||||
|
+ uint8_t r = colors[0].red * (brightness / 255.0f);
|
||||||
|
+ uint8_t g = colors[0].green * (brightness / 255.0f);
|
||||||
|
+ uint8_t b = colors[0].blue * (brightness / 255.0f);
|
||||||
|
+
|
||||||
|
+ SK6805_set_led_color(i, r, g, b);
|
||||||
|
+ } else {
|
||||||
+ uint8_t r = colors[rgb_settings.display_color_index].red * (brightness / 255.0f);
|
+ uint8_t r = colors[rgb_settings.display_color_index].red * (brightness / 255.0f);
|
||||||
+ uint8_t g = colors[rgb_settings.display_color_index].green * (brightness / 255.0f);
|
+ uint8_t g = colors[rgb_settings.display_color_index].green * (brightness / 255.0f);
|
||||||
+ uint8_t b = colors[rgb_settings.display_color_index].blue * (brightness / 255.0f);
|
+ uint8_t b = colors[rgb_settings.display_color_index].blue * (brightness / 255.0f);
|
||||||
+
|
+
|
||||||
+ SK6805_set_led_color(i, r, g, b);
|
+ SK6805_set_led_color(i, r, g, b);
|
||||||
+ }
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
+
|
+
|
||||||
+ SK6805_update();
|
+ SK6805_update();
|
||||||
+}
|
+}
|
||||||
diff --git a/applications/settings/notification_settings/rgb_backlight.h b/applications/settings/notification_settings/rgb_backlight.h
|
diff --git a/applications/settings/notification_settings/rgb_backlight.h b/applications/settings/notification_settings/rgb_backlight.h
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 0000000..b63d223
|
index 0000000..68dacda
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/applications/settings/notification_settings/rgb_backlight.h
|
+++ b/applications/settings/notification_settings/rgb_backlight.h
|
||||||
@@ -0,0 +1,79 @@
|
@@ -0,0 +1,91 @@
|
||||||
+/*
|
+/*
|
||||||
+ RGB backlight FlipperZero driver
|
+ RGB backlight FlipperZero driver
|
||||||
+ Copyright (C) 2022-2023 Victor Nikitchuk (https://github.com/quen0n)
|
+ Copyright (C) 2022-2023 Victor Nikitchuk (https://github.com/quen0n)
|
||||||
@@ -274,6 +401,9 @@ index 0000000..b63d223
|
|||||||
+typedef struct {
|
+typedef struct {
|
||||||
+ uint8_t version;
|
+ uint8_t version;
|
||||||
+ uint8_t display_color_index;
|
+ uint8_t display_color_index;
|
||||||
|
+ uint8_t custom_r;
|
||||||
|
+ uint8_t custom_g;
|
||||||
|
+ uint8_t custom_b;
|
||||||
+ bool settings_is_loaded;
|
+ bool settings_is_loaded;
|
||||||
+} RGBBacklightSettings;
|
+} RGBBacklightSettings;
|
||||||
+
|
+
|
||||||
@@ -298,8 +428,9 @@ index 0000000..b63d223
|
|||||||
+ * @brief Применить текущие настройки RGB-подсветки
|
+ * @brief Применить текущие настройки RGB-подсветки
|
||||||
+ *
|
+ *
|
||||||
+ * @param brightness Яркость свечения (0-255)
|
+ * @param brightness Яркость свечения (0-255)
|
||||||
|
+ * @param bypass Применить настройки принудительно
|
||||||
+ */
|
+ */
|
||||||
+void rgb_backlight_update(uint8_t brightness);
|
+void rgb_backlight_update(uint8_t brightness, bool bypass);
|
||||||
+
|
+
|
||||||
+/**
|
+/**
|
||||||
+ * @brief Установить цвет RGB-подсветки
|
+ * @brief Установить цвет RGB-подсветки
|
||||||
@@ -309,6 +440,14 @@ index 0000000..b63d223
|
|||||||
+void rgb_backlight_set_color(uint8_t color_index);
|
+void rgb_backlight_set_color(uint8_t color_index);
|
||||||
+
|
+
|
||||||
+/**
|
+/**
|
||||||
|
+ * @brief Set custom color values by index - 0=R 1=G 2=B
|
||||||
|
+ *
|
||||||
|
+ * @param color - color value (0-255)
|
||||||
|
+ * @param index - color index (0-2) 0=R 1=G 2=B
|
||||||
|
+ */
|
||||||
|
+void rgb_backlight_set_custom_color(uint8_t color, uint8_t index);
|
||||||
|
+
|
||||||
|
+/**
|
||||||
+ * @brief Получить количество доступных цветов
|
+ * @brief Получить количество доступных цветов
|
||||||
+ *
|
+ *
|
||||||
+ * @return Число доступных вариантов цвета
|
+ * @return Число доступных вариантов цвета
|
||||||
@@ -324,7 +463,7 @@ index 0000000..b63d223
|
|||||||
+const char* rgb_backlight_get_color_text(uint8_t index);
|
+const char* rgb_backlight_get_color_text(uint8_t index);
|
||||||
\ No newline at end of file
|
\ No newline at end of file
|
||||||
diff --git a/firmware/targets/f7/furi_hal/furi_hal_light.c b/firmware/targets/f7/furi_hal/furi_hal_light.c
|
diff --git a/firmware/targets/f7/furi_hal/furi_hal_light.c b/firmware/targets/f7/furi_hal/furi_hal_light.c
|
||||||
index 83e1603..cad5b86 100644
|
index 83e1603..45798ca 100644
|
||||||
--- a/firmware/targets/f7/furi_hal/furi_hal_light.c
|
--- a/firmware/targets/f7/furi_hal/furi_hal_light.c
|
||||||
+++ b/firmware/targets/f7/furi_hal/furi_hal_light.c
|
+++ b/firmware/targets/f7/furi_hal/furi_hal_light.c
|
||||||
@@ -3,6 +3,7 @@
|
@@ -3,6 +3,7 @@
|
||||||
@@ -353,7 +492,7 @@ index 83e1603..cad5b86 100644
|
|||||||
- uint8_t prev = lp5562_get_channel_value(&furi_hal_i2c_handle_power, LP5562ChannelWhite);
|
- uint8_t prev = lp5562_get_channel_value(&furi_hal_i2c_handle_power, LP5562ChannelWhite);
|
||||||
- lp5562_execute_ramp(
|
- lp5562_execute_ramp(
|
||||||
- &furi_hal_i2c_handle_power, LP5562Engine1, LP5562ChannelWhite, prev, value, 100);
|
- &furi_hal_i2c_handle_power, LP5562Engine1, LP5562ChannelWhite, prev, value, 100);
|
||||||
+ rgb_backlight_update(value);
|
+ rgb_backlight_update(value, false);
|
||||||
+ } else {
|
+ } else {
|
||||||
+ furi_hal_i2c_acquire(&furi_hal_i2c_handle_power);
|
+ furi_hal_i2c_acquire(&furi_hal_i2c_handle_power);
|
||||||
+ if(light & LightRed) {
|
+ if(light & LightRed) {
|
||||||
|
|||||||
176
.drone.yml
176
.drone.yml
@@ -15,16 +15,42 @@ steps:
|
|||||||
- git submodule foreach git config --local gc.auto 0
|
- git submodule foreach git config --local gc.auto 0
|
||||||
- git log -1 --format='%H'
|
- git log -1 --format='%H'
|
||||||
|
|
||||||
- name: "Build firmware"
|
- name: "Build clean"
|
||||||
|
image: hfdj/fztools
|
||||||
|
pull: never
|
||||||
|
commands:
|
||||||
|
- export DIST_SUFFIX=${DRONE_TAG}c
|
||||||
|
- export WORKFLOW_BRANCH_OR_TAG=release-cfw
|
||||||
|
- export FORCE_NO_DIRTY=yes
|
||||||
|
- export FBT_GIT_SUBMODULE_SHALLOW=1
|
||||||
|
- rm -rf applications/main/clock_app/resources/apps/
|
||||||
|
- rm -rf build/
|
||||||
|
- rm -rf dist/
|
||||||
|
- rm -rf .sconsign.dblite
|
||||||
|
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
||||||
|
- mkdir artifacts-clean
|
||||||
|
- mv dist/f7-C/* artifacts-clean/
|
||||||
|
- ls -laS artifacts-clean
|
||||||
|
- ls -laS artifacts-clean/f7-update-${DRONE_TAG}c
|
||||||
|
environment:
|
||||||
|
FBT_TOOLS_CUSTOM_LINK:
|
||||||
|
from_secret: fbt_link
|
||||||
|
|
||||||
|
- name: "Build default"
|
||||||
image: hfdj/fztools
|
image: hfdj/fztools
|
||||||
pull: never
|
pull: never
|
||||||
commands:
|
commands:
|
||||||
- export DIST_SUFFIX=${DRONE_TAG}
|
- export DIST_SUFFIX=${DRONE_TAG}
|
||||||
- export WORKFLOW_BRANCH_OR_TAG=release-cfw
|
- export WORKFLOW_BRANCH_OR_TAG=release-cfw
|
||||||
- rm -rf assets/resources/apps/
|
- export FORCE_NO_DIRTY=yes
|
||||||
- rm -rf build/
|
- export FBT_GIT_SUBMODULE_SHALLOW=1
|
||||||
- rm -rf dist/
|
- wget https://github.com/xMasterX/all-the-plugins/releases/latest/download/all-the-apps-base.tgz
|
||||||
- rm -rf .sconsign.dblite
|
- tar zxvf all-the-apps-base.tgz
|
||||||
|
- cp -R base_pack_build/artifacts-base/* applications/main/clock_app/resources/apps/
|
||||||
|
- cp -R base_pack_build/apps_data/* applications/main/clock_app/resources/apps_data/
|
||||||
|
- rm -rf base_pack_build
|
||||||
|
- rm -rf all-the-apps-base.tgz
|
||||||
|
- rm -f build/f7-firmware-C/toolbox/version.*
|
||||||
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
||||||
- mkdir artifacts-default
|
- mkdir artifacts-default
|
||||||
- mv dist/f7-C/* artifacts-default/
|
- mv dist/f7-C/* artifacts-default/
|
||||||
@@ -38,12 +64,14 @@ steps:
|
|||||||
image: hfdj/fztools
|
image: hfdj/fztools
|
||||||
pull: never
|
pull: never
|
||||||
commands:
|
commands:
|
||||||
- git clone https://github.com/xMasterX/all-the-plugins.git
|
- wget https://github.com/xMasterX/all-the-plugins/releases/latest/download/all-the-apps-extra.tgz
|
||||||
- cp -R all-the-plugins/apps/* assets/resources/apps/
|
- tar zxvf all-the-apps-extra.tgz
|
||||||
- rm -rf all-the-plugins
|
- cp -R extra_pack_build/artifacts-extra/* applications/main/clock_app/resources/apps/
|
||||||
|
- rm -rf extra_pack_build
|
||||||
- export DIST_SUFFIX=${DRONE_TAG}e
|
- export DIST_SUFFIX=${DRONE_TAG}e
|
||||||
- export WORKFLOW_BRANCH_OR_TAG=release-cfw
|
- export WORKFLOW_BRANCH_OR_TAG=release-cfw
|
||||||
- export FORCE_NO_DIRTY=yes
|
- export FORCE_NO_DIRTY=yes
|
||||||
|
- export FBT_GIT_SUBMODULE_SHALLOW=1
|
||||||
- rm -f build/f7-firmware-C/toolbox/version.*
|
- rm -f build/f7-firmware-C/toolbox/version.*
|
||||||
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
||||||
- mkdir artifacts-extra-apps
|
- mkdir artifacts-extra-apps
|
||||||
@@ -62,6 +90,7 @@ steps:
|
|||||||
- export DIST_SUFFIX=${DRONE_TAG}r
|
- export DIST_SUFFIX=${DRONE_TAG}r
|
||||||
- export WORKFLOW_BRANCH_OR_TAG=release-cfw-rgb
|
- export WORKFLOW_BRANCH_OR_TAG=release-cfw-rgb
|
||||||
- export FORCE_NO_DIRTY=yes
|
- export FORCE_NO_DIRTY=yes
|
||||||
|
- export FBT_GIT_SUBMODULE_SHALLOW=1
|
||||||
- rm -f build/f7-firmware-C/toolbox/version.*
|
- rm -f build/f7-firmware-C/toolbox/version.*
|
||||||
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
||||||
- mkdir artifacts-rgb-patch
|
- mkdir artifacts-rgb-patch
|
||||||
@@ -80,10 +109,19 @@ steps:
|
|||||||
- git checkout -- .
|
- git checkout -- .
|
||||||
- rm -f assets/dolphin/external/manifest.txt
|
- rm -f assets/dolphin/external/manifest.txt
|
||||||
- cp .ci_files/anims_ofw.txt assets/dolphin/external/manifest.txt
|
- cp .ci_files/anims_ofw.txt assets/dolphin/external/manifest.txt
|
||||||
- rm -rf assets/resources/apps/
|
- rm -rf applications/main/clock_app/resources/apps/
|
||||||
- export DIST_SUFFIX=${DRONE_TAG}n
|
- export DIST_SUFFIX=${DRONE_TAG}n
|
||||||
- export WORKFLOW_BRANCH_OR_TAG=no-custom-anims
|
- export WORKFLOW_BRANCH_OR_TAG=no-custom-anims
|
||||||
- export FORCE_NO_DIRTY=yes
|
- export FORCE_NO_DIRTY=yes
|
||||||
|
- export FBT_GIT_SUBMODULE_SHALLOW=1
|
||||||
|
- rm -f build/f7-firmware-C/toolbox/version.*
|
||||||
|
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
||||||
|
- wget https://github.com/xMasterX/all-the-plugins/releases/latest/download/all-the-apps-base.tgz
|
||||||
|
- tar zxvf all-the-apps-base.tgz
|
||||||
|
- cp -R base_pack_build/artifacts-base/* applications/main/clock_app/resources/apps/
|
||||||
|
- cp -R base_pack_build/apps_data/* applications/main/clock_app/resources/apps_data/
|
||||||
|
- rm -rf base_pack_build
|
||||||
|
- rm -rf all-the-apps-base.tgz
|
||||||
- rm -f build/f7-firmware-C/toolbox/version.*
|
- rm -f build/f7-firmware-C/toolbox/version.*
|
||||||
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
||||||
- mkdir artifacts-ofw-anims
|
- mkdir artifacts-ofw-anims
|
||||||
@@ -93,6 +131,8 @@ steps:
|
|||||||
- sed -i 's/(version)/'${DRONE_TAG}'/g' CHANGELOG.md
|
- sed -i 's/(version)/'${DRONE_TAG}'/g' CHANGELOG.md
|
||||||
- echo '# [Install via Web Updater](https://lab.flipper.net/?url=https://unleashedflip.com/fw/${DRONE_TAG}/flipper-z-f7-update-'${DRONE_TAG}'.tgz&channel=release-cfw&version='${DRONE_TAG}')' >> CHANGELOG.md
|
- echo '# [Install via Web Updater](https://lab.flipper.net/?url=https://unleashedflip.com/fw/${DRONE_TAG}/flipper-z-f7-update-'${DRONE_TAG}'.tgz&channel=release-cfw&version='${DRONE_TAG}')' >> CHANGELOG.md
|
||||||
- echo '' >> CHANGELOG.md
|
- echo '' >> CHANGELOG.md
|
||||||
|
- echo '### [Version with only main apps - Install via Web Updater](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_TAG}'c.tgz&channel=release-cfw&version='${DRONE_TAG}'c)' >> CHANGELOG.md
|
||||||
|
- echo '' >> CHANGELOG.md
|
||||||
- echo '### [Version without custom animations - Install via Web Updater](https://lab.flipper.net/?url=https://unleashedflip.com/fw_no_anim/flipper-z-f7-update-'${DRONE_TAG}'n.tgz&channel=release-cfw&version='${DRONE_TAG}'n)' >> CHANGELOG.md
|
- echo '### [Version without custom animations - Install via Web Updater](https://lab.flipper.net/?url=https://unleashedflip.com/fw_no_anim/flipper-z-f7-update-'${DRONE_TAG}'n.tgz&channel=release-cfw&version='${DRONE_TAG}'n)' >> CHANGELOG.md
|
||||||
- echo '' >> CHANGELOG.md
|
- echo '' >> CHANGELOG.md
|
||||||
- echo '### [Version with RGB patch - only for hardware mod! - Install via Web Updater](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_TAG}'r.tgz&channel=release-cfw&version='${DRONE_TAG}'r)' >> CHANGELOG.md
|
- echo '### [Version with RGB patch - only for hardware mod! - Install via Web Updater](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_TAG}'r.tgz&channel=release-cfw&version='${DRONE_TAG}'r)' >> CHANGELOG.md
|
||||||
@@ -107,19 +147,23 @@ steps:
|
|||||||
commands:
|
commands:
|
||||||
- cp artifacts-extra-apps/flipper-z-f7-update-${DRONE_TAG}e.tgz .
|
- cp artifacts-extra-apps/flipper-z-f7-update-${DRONE_TAG}e.tgz .
|
||||||
- cp artifacts-rgb-patch/flipper-z-f7-update-${DRONE_TAG}r.tgz .
|
- cp artifacts-rgb-patch/flipper-z-f7-update-${DRONE_TAG}r.tgz .
|
||||||
|
- cp artifacts-clean/flipper-z-f7-update-${DRONE_TAG}c.tgz .
|
||||||
- cp artifacts-ofw-anims/flipper-z-f7-update-${DRONE_TAG}n.tgz .
|
- cp artifacts-ofw-anims/flipper-z-f7-update-${DRONE_TAG}n.tgz .
|
||||||
- cp artifacts-default/flipper-z-f7-update-${DRONE_TAG}.tgz .
|
- cp artifacts-default/flipper-z-f7-update-${DRONE_TAG}.tgz .
|
||||||
- zip -r artifacts-extra-apps/flipper-z-f7-update-${DRONE_TAG}e.zip artifacts-extra-apps/f7-update-${DRONE_TAG}e
|
- zip -r artifacts-extra-apps/flipper-z-f7-update-${DRONE_TAG}e.zip artifacts-extra-apps/f7-update-${DRONE_TAG}e
|
||||||
- zip -r artifacts-rgb-patch/flipper-z-f7-update-${DRONE_TAG}r.zip artifacts-rgb-patch/f7-update-${DRONE_TAG}r
|
- zip -r artifacts-rgb-patch/flipper-z-f7-update-${DRONE_TAG}r.zip artifacts-rgb-patch/f7-update-${DRONE_TAG}r
|
||||||
|
- zip -r artifacts-clean/flipper-z-f7-update-${DRONE_TAG}c.zip artifacts-clean/f7-update-${DRONE_TAG}c
|
||||||
- zip -r artifacts-ofw-anims/flipper-z-f7-update-${DRONE_TAG}n.zip artifacts-ofw-anims/f7-update-${DRONE_TAG}n
|
- zip -r artifacts-ofw-anims/flipper-z-f7-update-${DRONE_TAG}n.zip artifacts-ofw-anims/f7-update-${DRONE_TAG}n
|
||||||
- zip -r artifacts-default/flipper-z-f7-update-${DRONE_TAG}.zip artifacts-default/f7-update-${DRONE_TAG}
|
- zip -r artifacts-default/flipper-z-f7-update-${DRONE_TAG}.zip artifacts-default/f7-update-${DRONE_TAG}
|
||||||
- tar czpf artifacts-default/flipper-z-any-scripts-${DRONE_TAG}.tgz scripts
|
- tar czpf artifacts-default/flipper-z-any-scripts-${DRONE_TAG}.tgz scripts
|
||||||
- rm -rf artifacts-extra-apps/f7-update-${DRONE_TAG}
|
- rm -rf artifacts-extra-apps/f7-update-${DRONE_TAG}
|
||||||
- rm -rf artifacts-rgb-patch/f7-update-${DRONE_TAG}
|
- rm -rf artifacts-rgb-patch/f7-update-${DRONE_TAG}
|
||||||
|
- rm -rf artifacts-clean/f7-update-${DRONE_TAG}
|
||||||
- rm -rf artifacts-ofw-anims/f7-update-${DRONE_TAG}
|
- rm -rf artifacts-ofw-anims/f7-update-${DRONE_TAG}
|
||||||
- rm -rf artifacts-default/f7-update-${DRONE_TAG}
|
- rm -rf artifacts-default/f7-update-${DRONE_TAG}
|
||||||
- ls -laS artifacts-extra-apps
|
- ls -laS artifacts-extra-apps
|
||||||
- ls -laS artifacts-rgb-patch
|
- ls -laS artifacts-rgb-patch
|
||||||
|
- ls -laS artifacts-clean
|
||||||
- ls -laS artifacts-ofw-anims
|
- ls -laS artifacts-ofw-anims
|
||||||
- ls -laS artifacts-default
|
- ls -laS artifacts-default
|
||||||
- mv artifacts-default/ ${DRONE_TAG}
|
- mv artifacts-default/ ${DRONE_TAG}
|
||||||
@@ -191,6 +235,21 @@ steps:
|
|||||||
from_secret: dep_target_extra
|
from_secret: dep_target_extra
|
||||||
source: flipper-z-f7-update-${DRONE_TAG}r.tgz
|
source: flipper-z-f7-update-${DRONE_TAG}r.tgz
|
||||||
|
|
||||||
|
- name: "Upload clean version to updates srv"
|
||||||
|
image: appleboy/drone-scp:linux-amd64
|
||||||
|
settings:
|
||||||
|
host:
|
||||||
|
from_secret: dep_host
|
||||||
|
username:
|
||||||
|
from_secret: dep_user
|
||||||
|
password:
|
||||||
|
from_secret: dep_passwd
|
||||||
|
port:
|
||||||
|
from_secret: dep_port
|
||||||
|
target:
|
||||||
|
from_secret: dep_target_extra
|
||||||
|
source: flipper-z-f7-update-${DRONE_TAG}c.tgz
|
||||||
|
|
||||||
- name: "Do Github release"
|
- name: "Do Github release"
|
||||||
image: ddplugins/github-release
|
image: ddplugins/github-release
|
||||||
pull: never
|
pull: never
|
||||||
@@ -206,6 +265,7 @@ steps:
|
|||||||
- artifacts-ofw-anims/*.tgz
|
- artifacts-ofw-anims/*.tgz
|
||||||
- artifacts-extra-apps/*.tgz
|
- artifacts-extra-apps/*.tgz
|
||||||
- artifacts-rgb-patch/*.tgz
|
- artifacts-rgb-patch/*.tgz
|
||||||
|
- artifacts-clean/*.tgz
|
||||||
title: ${DRONE_TAG}
|
title: ${DRONE_TAG}
|
||||||
note: CHANGELOG.md
|
note: CHANGELOG.md
|
||||||
checksum:
|
checksum:
|
||||||
@@ -247,12 +307,15 @@ steps:
|
|||||||
[-How to install firmware-](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/HowToInstall.md)
|
[-How to install firmware-](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/HowToInstall.md)
|
||||||
|
|
||||||
|
|
||||||
[-Download latest extra apps pack-](https://github.com/xMasterX/all-the-plugins/archive/refs/heads/main.zip)
|
[-Download latest extra apps pack-](https://github.com/xMasterX/all-the-plugins/releases/latest)
|
||||||
|
|
||||||
|
|
||||||
[-Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw/${DRONE_TAG}/flipper-z-f7-update-${DRONE_TAG}.tgz&channel=release-cfw&version=${DRONE_TAG})
|
[-Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw/${DRONE_TAG}/flipper-z-f7-update-${DRONE_TAG}.tgz&channel=release-cfw&version=${DRONE_TAG})
|
||||||
|
|
||||||
|
|
||||||
|
[-Version with only main apps - Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-${DRONE_TAG}c.tgz&channel=release-cfw&version=${DRONE_TAG}c)
|
||||||
|
|
||||||
|
|
||||||
[-Version without custom animations - Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_no_anim/flipper-z-f7-update-${DRONE_TAG}n.tgz&channel=release-cfw&version=${DRONE_TAG}n)
|
[-Version without custom animations - Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_no_anim/flipper-z-f7-update-${DRONE_TAG}n.tgz&channel=release-cfw&version=${DRONE_TAG}n)
|
||||||
|
|
||||||
|
|
||||||
@@ -275,7 +338,19 @@ steps:
|
|||||||
commands:
|
commands:
|
||||||
- wget "https://raw.githubusercontent.com/fieu/discord.sh/e1dc1a7595efad2cad8f072f0b3531c470f5b7c8/discord.sh"
|
- wget "https://raw.githubusercontent.com/fieu/discord.sh/e1dc1a7595efad2cad8f072f0b3531c470f5b7c8/discord.sh"
|
||||||
- chmod +x ./discord.sh
|
- chmod +x ./discord.sh
|
||||||
- ./discord.sh --text 'New Unleashed firmware released!\n\nVersion - '${DRONE_TAG}'\n\n[-> Sponsor our project](https://boosty.to/mmxdev)\n\n[[Github - Changelog]](https://github.com/DarkFlippers/unleashed-firmware/releases/tag/'${DRONE_TAG}')\n\n[-How to install firmware-](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/HowToInstall.md)\n\n[-Download latest extra apps pack-](https://github.com/xMasterX/all-the-plugins/archive/refs/heads/main.zip)\n\n[-Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw/'${DRONE_TAG}'/flipper-z-f7-update-'${DRONE_TAG}'.tgz&channel=release-cfw&version='${DRONE_TAG}')\n\n[-Version without custom animations - Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_no_anim/flipper-z-f7-update-'${DRONE_TAG}'n.tgz&channel=release-cfw&version='${DRONE_TAG}'n)\n\n[-Version with RGB patch - only for hardware mod! - Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_TAG}'r.tgz&channel=release-cfw&version='${DRONE_TAG}'r)\n\n[-Version with RGB patch - only for hardware mod! - Direct download-](https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_TAG}'r.tgz)\n\n[-Version with Extra apps - Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_TAG}'e.tgz&channel=release-cfw&version='${DRONE_TAG}'e)'
|
- ./discord.sh --text 'New Unleashed firmware released!\n\nVersion - '${DRONE_TAG}'\n\n[-> Sponsor our project](https://boosty.to/mmxdev)\n\n[[Github - Changelog]](https://github.com/DarkFlippers/unleashed-firmware/releases/tag/'${DRONE_TAG}')\n\n[-How to install firmware-](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/HowToInstall.md)\n\n[-Download latest extra apps pack-](https://github.com/xMasterX/all-the-plugins/releases/latest)\n\n[-Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw/'${DRONE_TAG}'/flipper-z-f7-update-'${DRONE_TAG}'.tgz&channel=release-cfw&version='${DRONE_TAG}')\n\n[-Version with only main apps - Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_TAG}'c.tgz&channel=release-cfw&version='${DRONE_TAG}'c)\n\n[-Version without custom animations - Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_no_anim/flipper-z-f7-update-'${DRONE_TAG}'n.tgz&channel=release-cfw&version='${DRONE_TAG}'n)\n\n[-Version with RGB patch - only for hardware mod! - Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_TAG}'r.tgz&channel=release-cfw&version='${DRONE_TAG}'r)\n\n[-Version with RGB patch - only for hardware mod! - Direct download-](https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_TAG}'r.tgz)\n\n[-Version with Extra apps - Install FW via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_TAG}'e.tgz&channel=release-cfw&version='${DRONE_TAG}'e)'
|
||||||
|
|
||||||
|
- name: "Send clean build to telegram"
|
||||||
|
image: appleboy/drone-telegram
|
||||||
|
settings:
|
||||||
|
token:
|
||||||
|
from_secret: tgtoken
|
||||||
|
to:
|
||||||
|
from_secret: tgid
|
||||||
|
format: markdown
|
||||||
|
message: "Build with only main apps:"
|
||||||
|
document:
|
||||||
|
- flipper-z-f7-update-${DRONE_TAG}c.tgz
|
||||||
|
|
||||||
- name: "Send extra pack build to telegram"
|
- name: "Send extra pack build to telegram"
|
||||||
image: appleboy/drone-telegram
|
image: appleboy/drone-telegram
|
||||||
@@ -314,16 +389,43 @@ steps:
|
|||||||
- git submodule foreach git config --local gc.auto 0
|
- git submodule foreach git config --local gc.auto 0
|
||||||
- git log -1 --format='%H'
|
- git log -1 --format='%H'
|
||||||
|
|
||||||
- name: "Build dev FW"
|
- name: "Build dev clean"
|
||||||
|
image: hfdj/fztools
|
||||||
|
pull: never
|
||||||
|
commands:
|
||||||
|
- export DIST_SUFFIX=${DRONE_BUILD_NUMBER}c
|
||||||
|
- export WORKFLOW_BRANCH_OR_TAG=dev-cfw
|
||||||
|
- export FORCE_NO_DIRTY=yes
|
||||||
|
- export FBT_GIT_SUBMODULE_SHALLOW=1
|
||||||
|
- rm -rf applications/main/clock_app/resources/apps/
|
||||||
|
- rm -rf build/
|
||||||
|
- rm -rf dist/
|
||||||
|
- rm -rf .sconsign.dblite
|
||||||
|
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
||||||
|
- mkdir artifacts-clean
|
||||||
|
- mv dist/f7-C/* artifacts-clean/
|
||||||
|
- ls -laS artifacts-clean
|
||||||
|
- ls -laS artifacts-clean/f7-update-${DRONE_BUILD_NUMBER}c
|
||||||
|
environment:
|
||||||
|
FBT_TOOLS_CUSTOM_LINK:
|
||||||
|
from_secret: fbt_link
|
||||||
|
|
||||||
|
|
||||||
|
- name: "Build dev default"
|
||||||
image: hfdj/fztools
|
image: hfdj/fztools
|
||||||
pull: never
|
pull: never
|
||||||
commands:
|
commands:
|
||||||
- export DIST_SUFFIX=${DRONE_BUILD_NUMBER}
|
- export DIST_SUFFIX=${DRONE_BUILD_NUMBER}
|
||||||
- export WORKFLOW_BRANCH_OR_TAG=dev-cfw
|
- export WORKFLOW_BRANCH_OR_TAG=dev-cfw
|
||||||
- rm -rf assets/resources/apps/
|
- export FORCE_NO_DIRTY=yes
|
||||||
- rm -rf build/
|
- export FBT_GIT_SUBMODULE_SHALLOW=1
|
||||||
- rm -rf dist/
|
- wget https://github.com/xMasterX/all-the-plugins/releases/latest/download/all-the-apps-base.tgz
|
||||||
- rm -rf .sconsign.dblite
|
- tar zxvf all-the-apps-base.tgz
|
||||||
|
- cp -R base_pack_build/artifacts-base/* applications/main/clock_app/resources/apps/
|
||||||
|
- cp -R base_pack_build/apps_data/* applications/main/clock_app/resources/apps_data/
|
||||||
|
- rm -rf base_pack_build
|
||||||
|
- rm -rf all-the-apps-base.tgz
|
||||||
|
- rm -f build/f7-firmware-C/toolbox/version.*
|
||||||
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
||||||
- mkdir artifacts-default
|
- mkdir artifacts-default
|
||||||
- mv dist/f7-C/* artifacts-default/
|
- mv dist/f7-C/* artifacts-default/
|
||||||
@@ -337,12 +439,14 @@ steps:
|
|||||||
image: hfdj/fztools
|
image: hfdj/fztools
|
||||||
pull: never
|
pull: never
|
||||||
commands:
|
commands:
|
||||||
- git clone --branch dev https://github.com/xMasterX/all-the-plugins.git
|
- wget https://github.com/xMasterX/all-the-plugins/releases/latest/download/all-the-apps-extra.tgz
|
||||||
- cp -R all-the-plugins/apps/* assets/resources/apps/
|
- tar zxvf all-the-apps-extra.tgz
|
||||||
- rm -rf all-the-plugins
|
- cp -R extra_pack_build/artifacts-extra/* applications/main/clock_app/resources/apps/
|
||||||
|
- rm -rf extra_pack_build
|
||||||
- export DIST_SUFFIX=${DRONE_BUILD_NUMBER}e
|
- export DIST_SUFFIX=${DRONE_BUILD_NUMBER}e
|
||||||
- export WORKFLOW_BRANCH_OR_TAG=dev-cfw
|
- export WORKFLOW_BRANCH_OR_TAG=dev-cfw
|
||||||
- export FORCE_NO_DIRTY=yes
|
- export FORCE_NO_DIRTY=yes
|
||||||
|
- export FBT_GIT_SUBMODULE_SHALLOW=1
|
||||||
- rm -f build/f7-firmware-C/toolbox/version.*
|
- rm -f build/f7-firmware-C/toolbox/version.*
|
||||||
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
||||||
- mkdir artifacts-extra-apps
|
- mkdir artifacts-extra-apps
|
||||||
@@ -361,6 +465,7 @@ steps:
|
|||||||
- export DIST_SUFFIX=${DRONE_BUILD_NUMBER}r
|
- export DIST_SUFFIX=${DRONE_BUILD_NUMBER}r
|
||||||
- export WORKFLOW_BRANCH_OR_TAG=dev-cfw-rgb
|
- export WORKFLOW_BRANCH_OR_TAG=dev-cfw-rgb
|
||||||
- export FORCE_NO_DIRTY=yes
|
- export FORCE_NO_DIRTY=yes
|
||||||
|
- export FBT_GIT_SUBMODULE_SHALLOW=1
|
||||||
- rm -f build/f7-firmware-C/toolbox/version.*
|
- rm -f build/f7-firmware-C/toolbox/version.*
|
||||||
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
- ./fbt COMPACT=1 DEBUG=0 updater_package
|
||||||
- mkdir artifacts-rgb-patch
|
- mkdir artifacts-rgb-patch
|
||||||
@@ -376,6 +481,7 @@ steps:
|
|||||||
commands:
|
commands:
|
||||||
- cp artifacts-extra-apps/flipper-z-f7-update-${DRONE_BUILD_NUMBER}e.tgz .
|
- cp artifacts-extra-apps/flipper-z-f7-update-${DRONE_BUILD_NUMBER}e.tgz .
|
||||||
- cp artifacts-rgb-patch/flipper-z-f7-update-${DRONE_BUILD_NUMBER}r.tgz .
|
- cp artifacts-rgb-patch/flipper-z-f7-update-${DRONE_BUILD_NUMBER}r.tgz .
|
||||||
|
- cp artifacts-clean/flipper-z-f7-update-${DRONE_BUILD_NUMBER}c.tgz .
|
||||||
- cp artifacts-default/flipper-z-f7-update-${DRONE_BUILD_NUMBER}.tgz .
|
- cp artifacts-default/flipper-z-f7-update-${DRONE_BUILD_NUMBER}.tgz .
|
||||||
- rm -rf artifacts-default/f7-update-${DRONE_BUILD_NUMBER}
|
- rm -rf artifacts-default/f7-update-${DRONE_BUILD_NUMBER}
|
||||||
- ls -laS artifacts-default
|
- ls -laS artifacts-default
|
||||||
@@ -448,6 +554,21 @@ steps:
|
|||||||
from_secret: dep_target_extra
|
from_secret: dep_target_extra
|
||||||
source: flipper-z-f7-update-${DRONE_BUILD_NUMBER}r.tgz
|
source: flipper-z-f7-update-${DRONE_BUILD_NUMBER}r.tgz
|
||||||
|
|
||||||
|
- name: "Upload clean version to updates srv"
|
||||||
|
image: appleboy/drone-scp:linux-amd64
|
||||||
|
settings:
|
||||||
|
host:
|
||||||
|
from_secret: dep_host
|
||||||
|
username:
|
||||||
|
from_secret: dep_user
|
||||||
|
password:
|
||||||
|
from_secret: dep_passwd
|
||||||
|
port:
|
||||||
|
from_secret: dep_port
|
||||||
|
target:
|
||||||
|
from_secret: dep_target_extra
|
||||||
|
source: flipper-z-f7-update-${DRONE_BUILD_NUMBER}c.tgz
|
||||||
|
|
||||||
- name: "Trigger update server reindex"
|
- name: "Trigger update server reindex"
|
||||||
image: hfdj/fztools
|
image: hfdj/fztools
|
||||||
pull: never
|
pull: never
|
||||||
@@ -482,6 +603,9 @@ steps:
|
|||||||
[-Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw/dev/flipper-z-f7-update-${DRONE_BUILD_NUMBER}.tgz&channel=dev-cfw&version=${DRONE_BUILD_NUMBER})
|
[-Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw/dev/flipper-z-f7-update-${DRONE_BUILD_NUMBER}.tgz&channel=dev-cfw&version=${DRONE_BUILD_NUMBER})
|
||||||
|
|
||||||
|
|
||||||
|
[-Version with only main apps - Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-${DRONE_BUILD_NUMBER}c.tgz&channel=dev-cfw&version=${DRONE_BUILD_NUMBER}c)
|
||||||
|
|
||||||
|
|
||||||
[-Version with RGB patch - only for hardware mod! - Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-${DRONE_BUILD_NUMBER}r.tgz&channel=dev-cfw&version=${DRONE_BUILD_NUMBER}r)
|
[-Version with RGB patch - only for hardware mod! - Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-${DRONE_BUILD_NUMBER}r.tgz&channel=dev-cfw&version=${DRONE_BUILD_NUMBER}r)
|
||||||
|
|
||||||
|
|
||||||
@@ -502,6 +626,18 @@ steps:
|
|||||||
document:
|
document:
|
||||||
- dev/flipper-z-f7-update-${DRONE_BUILD_NUMBER}.tgz
|
- dev/flipper-z-f7-update-${DRONE_BUILD_NUMBER}.tgz
|
||||||
|
|
||||||
|
- name: "Send clean build to telegram"
|
||||||
|
image: appleboy/drone-telegram
|
||||||
|
settings:
|
||||||
|
token:
|
||||||
|
from_secret: tgtoken
|
||||||
|
to:
|
||||||
|
from_secret: tgid_dev
|
||||||
|
format: markdown
|
||||||
|
message: "Clean (Main apps only) Build:"
|
||||||
|
document:
|
||||||
|
- flipper-z-f7-update-${DRONE_BUILD_NUMBER}c.tgz
|
||||||
|
|
||||||
- name: "Send extra pack build to telegram"
|
- name: "Send extra pack build to telegram"
|
||||||
image: appleboy/drone-telegram
|
image: appleboy/drone-telegram
|
||||||
settings:
|
settings:
|
||||||
@@ -523,7 +659,7 @@ steps:
|
|||||||
commands:
|
commands:
|
||||||
- wget "https://raw.githubusercontent.com/fieu/discord.sh/e1dc1a7595efad2cad8f072f0b3531c470f5b7c8/discord.sh"
|
- wget "https://raw.githubusercontent.com/fieu/discord.sh/e1dc1a7595efad2cad8f072f0b3531c470f5b7c8/discord.sh"
|
||||||
- chmod +x ./discord.sh
|
- chmod +x ./discord.sh
|
||||||
- ./discord.sh --text 'Unleashed firmware dev build successful!\n\nBuild - '${DRONE_BUILD_NUMBER}'\n\nCommit - https://github.com/DarkFlippers/unleashed-firmware/commit/'${DRONE_COMMIT_SHA}'\n\n[-> Sponsor our project](https://boosty.to/mmxdev)\n\n[-Version with Extra apps - Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_BUILD_NUMBER}'e.tgz&channel=dev-cfw&version='${DRONE_BUILD_NUMBER}'e)\n\n[-Version with RGB patch - only for hardware mod! - Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_BUILD_NUMBER}'r.tgz&channel=dev-cfw&version='${DRONE_BUILD_NUMBER}'r)\n\n[-Version with RGB patch - only for hardware mod! - Direct download-](https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_BUILD_NUMBER}'r.tgz)\n\n[-Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw/dev/flipper-z-f7-update-'${DRONE_BUILD_NUMBER}'.tgz&channel=dev-cfw&version='${DRONE_BUILD_NUMBER}')'
|
- ./discord.sh --text 'Unleashed firmware dev build successful!\n\nBuild - '${DRONE_BUILD_NUMBER}'\n\nCommit - https://github.com/DarkFlippers/unleashed-firmware/commit/'${DRONE_COMMIT_SHA}'\n\n[-> Sponsor our project](https://boosty.to/mmxdev)\n\n[-Version with Extra apps - Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_BUILD_NUMBER}'e.tgz&channel=dev-cfw&version='${DRONE_BUILD_NUMBER}'e)\n\n[-Version with only main apps - Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_BUILD_NUMBER}'c.tgz&channel=dev-cfw&version='${DRONE_BUILD_NUMBER}'c)\n\n[-Version with RGB patch - only for hardware mod! - Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_BUILD_NUMBER}'r.tgz&channel=dev-cfw&version='${DRONE_BUILD_NUMBER}'r)\n\n[-Version with RGB patch - only for hardware mod! - Direct download-](https://unleashedflip.com/fw_extra_apps/flipper-z-f7-update-'${DRONE_BUILD_NUMBER}'r.tgz)\n\n[-Install via Web Updater-](https://lab.flipper.net/?url=https://unleashedflip.com/fw/dev/flipper-z-f7-update-'${DRONE_BUILD_NUMBER}'.tgz&channel=dev-cfw&version='${DRONE_BUILD_NUMBER}')'
|
||||||
|
|
||||||
trigger:
|
trigger:
|
||||||
branch:
|
branch:
|
||||||
|
|||||||
2
.github/CODEOWNERS
vendored
2
.github/CODEOWNERS
vendored
@@ -2,4 +2,4 @@
|
|||||||
* @xMasterX
|
* @xMasterX
|
||||||
|
|
||||||
# Assets
|
# Assets
|
||||||
/assets/resources/infrared/ @xMasterX @amec0e
|
/assets/resources/infrared/assets/ @amec0e @Leptopt1los @xMasterX
|
||||||
1
.github/FUNDING.yml
vendored
1
.github/FUNDING.yml
vendored
@@ -1,3 +1,4 @@
|
|||||||
|
patreon: mmxdev
|
||||||
custom:
|
custom:
|
||||||
[
|
[
|
||||||
"https://boosty.to/mmxdev",
|
"https://boosty.to/mmxdev",
|
||||||
|
|||||||
114
.github/workflows/codeql.yml
vendored
Normal file
114
.github/workflows/codeql.yml
vendored
Normal file
@@ -0,0 +1,114 @@
|
|||||||
|
# For most projects, this workflow file will not need changing; you simply need
|
||||||
|
# to commit it to your repository.
|
||||||
|
#
|
||||||
|
# You may wish to alter this file to override the set of languages analyzed,
|
||||||
|
# or to provide custom queries or build logic.
|
||||||
|
#
|
||||||
|
# ******** NOTE ********
|
||||||
|
# We have attempted to detect the languages in your repository. Please check
|
||||||
|
# the `language` matrix defined below to confirm you have the correct set of
|
||||||
|
# supported CodeQL languages.
|
||||||
|
#
|
||||||
|
name: "CodeQL"
|
||||||
|
run-name: "CodeQL Analyze ${{ github.ref_name }} by @${{ github.ACTOR }}"
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: ["dev"]
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
analyze:
|
||||||
|
name: Analyze
|
||||||
|
# Runner size impacts CodeQL analysis time. To learn more, please see:
|
||||||
|
# - https://gh.io/recommended-hardware-resources-for-running-codeql
|
||||||
|
# - https://gh.io/supported-runners-and-hardware-resources
|
||||||
|
# - https://gh.io/using-larger-runners
|
||||||
|
# Consider using larger runners for possible analysis time improvements.
|
||||||
|
runs-on: [ "ubuntu-latest" ]
|
||||||
|
timeout-minutes: 60
|
||||||
|
permissions:
|
||||||
|
actions: read
|
||||||
|
contents: read
|
||||||
|
security-events: write
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
language: ["cpp"]
|
||||||
|
# CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python', 'ruby', 'swift' ]
|
||||||
|
# Use only 'java' to analyze code written in Java, Kotlin or both
|
||||||
|
# Use only 'javascript' to analyze code written in JavaScript, TypeScript or both
|
||||||
|
# Learn more about CodeQL language support at https://aka.ms/codeql-docs/language-support
|
||||||
|
env:
|
||||||
|
PATH_SARIF_DIR: ".github/results.sarif"
|
||||||
|
PATH_SARIF_FILE: ".github/results.sarif/${{ matrix.language }}.sarif"
|
||||||
|
FBT_NO_SYNC: 0
|
||||||
|
DIST_SUFFIX: "codeql"
|
||||||
|
WORKFLOW_BRANCH_OR_TAG: release-cfw
|
||||||
|
LANG_CATEGORY: "/language:${{matrix.language}}"
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout Firmware Files
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
clean: "true"
|
||||||
|
submodules: "true"
|
||||||
|
fetch-depth: "0"
|
||||||
|
|
||||||
|
# Initializes the CodeQL tools for scanning.
|
||||||
|
- name: Initialize CodeQL
|
||||||
|
uses: github/codeql-action/init@v2
|
||||||
|
with:
|
||||||
|
languages: ${{ matrix.language }}
|
||||||
|
setup-python-dependencies: true
|
||||||
|
|
||||||
|
- name: Resolve CodeQL Build Env
|
||||||
|
uses: github/codeql-action/resolve-environment@v2
|
||||||
|
with:
|
||||||
|
language: ${{ matrix.language }}
|
||||||
|
#debug: true
|
||||||
|
|
||||||
|
- name: Build Firmware
|
||||||
|
shell: bash
|
||||||
|
if: ${{ success() }}
|
||||||
|
run: |
|
||||||
|
./fbt COMPACT=1 DEBUG=0 FBT_NO_SYNC=${{ env.FBT_NO_SYNC }}
|
||||||
|
|
||||||
|
- name: Perform CodeQL Analysis
|
||||||
|
uses: github/codeql-action/analyze@v2
|
||||||
|
if: ${{ success() }}
|
||||||
|
with:
|
||||||
|
threads: 4
|
||||||
|
category: "${{ env.LANG_CATEGORY }}"
|
||||||
|
output: "${{ env.PATH_SARIF_DIR }}"
|
||||||
|
upload-database: false
|
||||||
|
upload: "failure-only" # disable the upload here - we will upload in a different action
|
||||||
|
|
||||||
|
- name: Filter dirs for SARIF
|
||||||
|
uses: advanced-security/filter-sarif@v1
|
||||||
|
if: ${{ success() }}
|
||||||
|
with:
|
||||||
|
# filter out all test files unless they contain a sql-injection vulnerability
|
||||||
|
patterns: |
|
||||||
|
-build/**
|
||||||
|
-dist/**
|
||||||
|
-toolchain/**
|
||||||
|
-lib/**
|
||||||
|
input: "${{ env.PATH_SARIF_FILE }}"
|
||||||
|
output: "${{ env.PATH_SARIF_FILE }}"
|
||||||
|
|
||||||
|
- name: Upload CodeQL SARIF
|
||||||
|
uses: github/codeql-action/upload-sarif@v2
|
||||||
|
if: ${{ success() }}
|
||||||
|
with:
|
||||||
|
category: "${{ env.LANG_CATEGORY }}"
|
||||||
|
sarif_file: "${{ env.PATH_SARIF_FILE }}"
|
||||||
|
|
||||||
|
# optional: for debugging the uploaded sarif
|
||||||
|
# - name: Upload loc as a Build Artifact
|
||||||
|
# uses: actions/upload-artifact@v3
|
||||||
|
# with:
|
||||||
|
# name: sarif-results
|
||||||
|
# path: sarif-results
|
||||||
|
# retention-days: 1
|
||||||
1
.gitignore
vendored
1
.gitignore
vendored
@@ -51,6 +51,7 @@ null.d
|
|||||||
/artifacts-ofw-anims
|
/artifacts-ofw-anims
|
||||||
/artifacts-rgb-patch
|
/artifacts-rgb-patch
|
||||||
/artifacts-extra-apps
|
/artifacts-extra-apps
|
||||||
|
/artifacts-clean
|
||||||
|
|
||||||
# SCons build dir
|
# SCons build dir
|
||||||
/build
|
/build
|
||||||
|
|||||||
14
.gitmodules
vendored
14
.gitmodules
vendored
@@ -10,6 +10,7 @@
|
|||||||
[submodule "assets/protobuf"]
|
[submodule "assets/protobuf"]
|
||||||
path = assets/protobuf
|
path = assets/protobuf
|
||||||
url = https://github.com/flipperdevices/flipperzero-protobuf.git
|
url = https://github.com/flipperdevices/flipperzero-protobuf.git
|
||||||
|
shallow = false
|
||||||
[submodule "lib/libusb_stm32"]
|
[submodule "lib/libusb_stm32"]
|
||||||
path = lib/libusb_stm32
|
path = lib/libusb_stm32
|
||||||
url = https://github.com/flipperdevices/libusb_stm32.git
|
url = https://github.com/flipperdevices/libusb_stm32.git
|
||||||
@@ -25,12 +26,6 @@
|
|||||||
[submodule "lib/cxxheaderparser"]
|
[submodule "lib/cxxheaderparser"]
|
||||||
path = lib/cxxheaderparser
|
path = lib/cxxheaderparser
|
||||||
url = https://github.com/robotpy/cxxheaderparser.git
|
url = https://github.com/robotpy/cxxheaderparser.git
|
||||||
[submodule "applications/external/dap_link/lib/free-dap"]
|
|
||||||
path = applications/external/dap_link/lib/free-dap
|
|
||||||
url = https://github.com/ataradov/free-dap.git
|
|
||||||
[submodule "applications/external/subbrute"]
|
|
||||||
path = applications/external/subbrute
|
|
||||||
url = https://github.com/DarkFlippers/flipperzero-subbrute.git
|
|
||||||
[submodule "lib/heatshrink"]
|
[submodule "lib/heatshrink"]
|
||||||
path = lib/heatshrink
|
path = lib/heatshrink
|
||||||
url = https://github.com/flipperdevices/heatshrink.git
|
url = https://github.com/flipperdevices/heatshrink.git
|
||||||
@@ -43,6 +38,7 @@
|
|||||||
[submodule "lib/stm32wb_copro"]
|
[submodule "lib/stm32wb_copro"]
|
||||||
path = lib/stm32wb_copro
|
path = lib/stm32wb_copro
|
||||||
url = https://github.com/flipperdevices/stm32wb_copro.git
|
url = https://github.com/flipperdevices/stm32wb_copro.git
|
||||||
[submodule "applications/external/multi_fuzzer"]
|
[submodule "subghz_remote"]
|
||||||
path = applications/external/multi_fuzzer
|
path = applications/main/subghz_remote
|
||||||
url = https://github.com/DarkFlippers/Multi_Fuzzer.git
|
url = https://github.com/DarkFlippers/SubGHz_Remote.git
|
||||||
|
branch = ufw_main_app
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
--ignore-ccache -C gccarm --rules-config .pvsconfig -e lib/cmsis_core -e lib/fatfs -e lib/fnv1a-hash -e lib/FreeRTOS-Kernel -e lib/heatshrink -e lib/libusb_stm32 -e lib/littlefs -e lib/mbedtls -e lib/micro-ecc -e lib/microtar -e lib/mlib -e lib/qrcode -e lib/ST25RFAL002 -e lib/stm32wb_cmsis -e lib/stm32wb_copro -e lib/stm32wb_hal -e lib/u8g2 -e lib/nanopb -e */arm-none-eabi/* -e applications/external/dap_link/lib/free-dap
|
--ignore-ccache -C gccarm --rules-config .pvsconfig -e lib/cmsis_core -e lib/fatfs -e lib/fnv1a-hash -e lib/FreeRTOS-Kernel -e lib/heatshrink -e lib/libusb_stm32 -e lib/littlefs -e lib/mbedtls -e lib/micro-ecc -e lib/microtar -e lib/mlib -e lib/qrcode -e lib/stm32wb_cmsis -e lib/stm32wb_copro -e lib/stm32wb_hal -e lib/u8g2 -e lib/nanopb -e */arm-none-eabi/*
|
||||||
|
|||||||
9
.vscode/.gitignore
vendored
9
.vscode/.gitignore
vendored
@@ -1,4 +1,5 @@
|
|||||||
./c_cpp_properties.json
|
/c_cpp_properties.json
|
||||||
./launch.json
|
/extensions.json
|
||||||
./settings.json
|
/launch.json
|
||||||
./tasks.json
|
/settings.json
|
||||||
|
/tasks.json
|
||||||
|
|||||||
19
.vscode/example/clangd/extensions.json
vendored
Normal file
19
.vscode/example/clangd/extensions.json
vendored
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
// See https://go.microsoft.com/fwlink/?LinkId=827846 to learn about workspace recommendations.
|
||||||
|
// Extension identifier format: ${publisher}.${name}. Example: vscode.csharp
|
||||||
|
// List of extensions which should be recommended for users of this workspace.
|
||||||
|
"recommendations": [
|
||||||
|
"ms-python.black-formatter",
|
||||||
|
"llvm-vs-code-extensions.vscode-clangd",
|
||||||
|
"amiralizadeh9480.cpp-helper",
|
||||||
|
"marus25.cortex-debug",
|
||||||
|
"zxh404.vscode-proto3",
|
||||||
|
"augustocdias.tasks-shell-input"
|
||||||
|
],
|
||||||
|
// List of extensions recommended by VS Code that should not be recommended for users of this workspace.
|
||||||
|
"unwantedRecommendations": [
|
||||||
|
"twxs.cmake",
|
||||||
|
"ms-vscode.cpptools",
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
]
|
||||||
|
}
|
||||||
@@ -13,6 +13,7 @@
|
|||||||
],
|
],
|
||||||
// List of extensions recommended by VS Code that should not be recommended for users of this workspace.
|
// List of extensions recommended by VS Code that should not be recommended for users of this workspace.
|
||||||
"unwantedRecommendations": [
|
"unwantedRecommendations": [
|
||||||
|
"llvm-vs-code-extensions.vscode-clangd",
|
||||||
"twxs.cmake",
|
"twxs.cmake",
|
||||||
"ms-vscode.cmake-tools"
|
"ms-vscode.cmake-tools"
|
||||||
]
|
]
|
||||||
7
.vscode/example/settings.json
vendored
7
.vscode/example/settings.json
vendored
@@ -21,5 +21,10 @@
|
|||||||
"SConscript": "python",
|
"SConscript": "python",
|
||||||
"SConstruct": "python",
|
"SConstruct": "python",
|
||||||
"*.fam": "python",
|
"*.fam": "python",
|
||||||
}
|
},
|
||||||
|
"clangd.arguments": [
|
||||||
|
// We might be able to tighten this a bit more to only include the correct toolchain.
|
||||||
|
"--query-driver=**",
|
||||||
|
"--compile-commands-dir=${workspaceFolder}/build/latest"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
16
.vscode/example/tasks.json
vendored
16
.vscode/example/tasks.json
vendored
@@ -28,29 +28,17 @@
|
|||||||
"command": "./fbt -c"
|
"command": "./fbt -c"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"label": "[Release] Flash (ST-Link)",
|
"label": "[Release] Flash (SWD)",
|
||||||
"group": "build",
|
"group": "build",
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
"command": "./fbt COMPACT=1 DEBUG=0 FORCE=1 flash"
|
"command": "./fbt COMPACT=1 DEBUG=0 FORCE=1 flash"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"label": "[Debug] Flash (ST-Link)",
|
"label": "[Debug] Flash (SWD)",
|
||||||
"group": "build",
|
"group": "build",
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
"command": "./fbt FORCE=1 flash"
|
"command": "./fbt FORCE=1 flash"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"label": "[Release] Flash (blackmagic)",
|
|
||||||
"group": "build",
|
|
||||||
"type": "shell",
|
|
||||||
"command": "./fbt COMPACT=1 DEBUG=0 FORCE=1 flash_blackmagic"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "[Debug] Flash (blackmagic)",
|
|
||||||
"group": "build",
|
|
||||||
"type": "shell",
|
|
||||||
"command": "./fbt FORCE=1 flash_blackmagic"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"label": "[Release] Flash (JLink)",
|
"label": "[Release] Flash (JLink)",
|
||||||
"group": "build",
|
"group": "build",
|
||||||
|
|||||||
56
CHANGELOG.md
56
CHANGELOG.md
@@ -1,10 +1,13 @@
|
|||||||
## New changes
|
## New changes
|
||||||
* Plugins: **22+ plugins was fixed (UI update issues) in extra pack and in base firmware pack**
|
* SubGHz: Add 4 more systems to Add Manually (untested!)
|
||||||
* Plugins: Spectrum Analyzer - Modulation switching (hold OK) (by @ALEEF02 | PR #557)
|
* SubGHz: Add Manually fixes
|
||||||
* Plugins: BadBT -> Temp fix for macOS
|
* SubGHz: Added NiceFlor-S to ignore options, removed colons. (by @G2Dolphin | PR #620)
|
||||||
* Plugins: Update TOTP (Authenticator) [(by akopachov)](https://github.com/akopachov/flipper-zero_authenticator) -> + added fix for UI update too
|
* Misc code cleanup
|
||||||
* Infrared: Add Play / Pause in universal projector remote
|
* RGB: Fix white color on reboot, move settings, add custom color option
|
||||||
* Infrared: Update Universal remote assets (by @amec0e)
|
* **BLE Spam app** updated to latest version (Android, Windows support) (by @Willy-JL) -> (app can be found in builds ` `, `e`, `n`, `r`)
|
||||||
|
* OFW: Fix double arrows and add proper indication
|
||||||
|
* OFW: SubGHz: add manually fix 12-bits is 0xFFF (or 0xFF0) CAME/NICE 12-bit
|
||||||
|
* OFW: Fix various crashes if debug libraries used
|
||||||
|
|
||||||
----
|
----
|
||||||
|
|
||||||
@@ -13,17 +16,20 @@
|
|||||||
[-> Download qFlipper (official link)](https://flipperzero.one/update)
|
[-> Download qFlipper (official link)](https://flipperzero.one/update)
|
||||||
|
|
||||||
## Please support development of the project
|
## Please support development of the project
|
||||||
* **Boosty** (patreon alternative): https://boosty.to/mmxdev
|
|Service|Remark|Link/Wallet|
|
||||||
* cloudtips (only RU payments accepted): https://pay.cloudtips.ru/p/7b3e9d65
|
|-|-|-|
|
||||||
* YooMoney (only RU payments accepted): https://yoomoney.ru/fundraise/XA49mgQLPA0.221209
|
|**Patreon**||https://patreon.com/mmxdev|
|
||||||
* USDT(TRC20): `TSXcitMSnWXUFqiUfEXrTVpVewXy2cYhrs`
|
|**Boosty**|patreon alternative|https://boosty.to/mmxdev|
|
||||||
* BCH: `qquxfyzntuqufy2dx0hrfr4sndp0tucvky4sw8qyu3`
|
|cloudtips|only RU payments accepted|https://pay.cloudtips.ru/p/7b3e9d65|
|
||||||
* ETH/BSC/ERC20-Tokens: `darkflippers.eth` (or `0xFebF1bBc8229418FF2408C07AF6Afa49152fEc6a`)
|
|YooMoney|only RU payments accepted|https://yoomoney.ru/fundraise/XA49mgQLPA0.221209|
|
||||||
* BTC: `bc1q0np836jk9jwr4dd7p6qv66d04vamtqkxrecck9`
|
|USDT|(TRC20)|`TSXcitMSnWXUFqiUfEXrTVpVewXy2cYhrs`|
|
||||||
* DOGE: `D6R6gYgBn5LwTNmPyvAQR6bZ9EtGgFCpvv`
|
|BCH||`qquxfyzntuqufy2dx0hrfr4sndp0tucvky4sw8qyu3`|
|
||||||
* LTC: `ltc1q3ex4ejkl0xpx3znwrmth4lyuadr5qgv8tmq8z9`
|
|ETH|(BSC/ERC20-Tokens)|`darkflippers.eth` (or `0xFebF1bBc8229418FF2408C07AF6Afa49152fEc6a`)|
|
||||||
* XMR (Monero): `41xUz92suUu1u5Mu4qkrcs52gtfpu9rnZRdBpCJ244KRHf6xXSvVFevdf2cnjS7RAeYr5hn9MsEfxKoFDRSctFjG5fv1Mhn`
|
|BTC||`bc1q0np836jk9jwr4dd7p6qv66d04vamtqkxrecck9`|
|
||||||
* TON: `EQCOqcnYkvzOZUV_9bPE_8oTbOrOF03MnF-VcJyjisTZmpGf`
|
|DOGE||`D6R6gYgBn5LwTNmPyvAQR6bZ9EtGgFCpvv`|
|
||||||
|
|LTC||`ltc1q3ex4ejkl0xpx3znwrmth4lyuadr5qgv8tmq8z9`|
|
||||||
|
|XMR|(Monero)| `41xUz92suUu1u5Mu4qkrcs52gtfpu9rnZRdBpCJ244KRHf6xXSvVFevdf2cnjS7RAeYr5hn9MsEfxKoFDRSctFjG5fv1Mhn`|
|
||||||
|
|TON||`EQCOqcnYkvzOZUV_9bPE_8oTbOrOF03MnF-VcJyjisTZmpGf`|
|
||||||
|
|
||||||
#### Thanks to our sponsors:
|
#### Thanks to our sponsors:
|
||||||
callmezimbra, Quen0n, MERRON, grvpvl (lvpvrg), art_col, ThurstonWaffles, Moneron, UterGrooll, LUCFER, Northpirate, zloepuzo, T.Rat, Alexey B., ionelife, ...
|
callmezimbra, Quen0n, MERRON, grvpvl (lvpvrg), art_col, ThurstonWaffles, Moneron, UterGrooll, LUCFER, Northpirate, zloepuzo, T.Rat, Alexey B., ionelife, ...
|
||||||
@@ -32,15 +38,21 @@ and all other great people who supported our project and me (xMasterX), thanks t
|
|||||||
|
|
||||||
## **Recommended update option - Web Updater**
|
## **Recommended update option - Web Updater**
|
||||||
|
|
||||||
### What `n`, `r`, `e` means? What I need to download if I don't want to use Web updater?
|
### What `n`, `r`, `e`, ` `, `c` means? What I need to download if I don't want to use Web updater?
|
||||||
What build I should download and what this name means - `flipper-z-f7-update-(version)(n / r / e).tgz` ? <br>
|
What build I should download and what this name means - `flipper-z-f7-update-(version)(n / r / e / c).tgz` ? <br>
|
||||||
`flipper-z` = for Flipper Zero device<br>
|
`flipper-z` = for Flipper Zero device<br>
|
||||||
`f7` = Hardware version - same for all flipper zero devices<br>
|
`f7` = Hardware version - same for all flipper zero devices<br>
|
||||||
`update` = Update package, contains updater, all assets (plugins, IR libs, etc.), and firmware itself<br>
|
`update` = Update package, contains updater, all assets (plugins, IR libs, etc.), and firmware itself<br>
|
||||||
`(version)` = Firmware version<br>
|
`(version)` = Firmware version<br>
|
||||||
`n` = this build comes without our custom animations (we have only 3 of them), only official flipper animations<br>
|
| Designation | 3 Custom Animation | [Base Apps](https://github.com/xMasterX/all-the-plugins#default-pack) | [Extra Apps](https://github.com/xMasterX/all-the-plugins#extra-pack) | ⚠️RGB mode* |
|
||||||
`e` = build has 🎲 [extra apps pack](https://github.com/xMasterX/all-the-plugins) preinstalled<br>
|
|-----|:---:|:---:|:---:|:---:|
|
||||||
`r` = RGB patch (+ extra apps) for flippers with rgb backlight mod (this is hardware mod!) (Works only on modded flippers!) (do not install on non modded device!)
|
| ` ` | ✅ | ✅ | | |
|
||||||
|
| `c` | ✅ | | | |
|
||||||
|
| `n` | | ✅ | | |
|
||||||
|
| `e` | ✅ | ✅ | ✅ | |
|
||||||
|
| `r` | ✅ | ✅ | ✅ | ✅ |
|
||||||
|
|
||||||
|
⚠️This is [hardware mod](https://github.com/quen0n/flipperzero-firmware-rgb#readme), works only on modded flippers! do not install on non modded device!
|
||||||
|
|
||||||
Firmware Self-update package (update from microSD) - `flipper-z-f7-update-(version).tgz` for mobile app / qFlipper / web<br>
|
Firmware Self-update package (update from microSD) - `flipper-z-f7-update-(version).tgz` for mobile app / qFlipper / web<br>
|
||||||
Archive of `scripts` folder (contains scripts for FW/plugins development) - `flipper-z-any-scripts-(version).tgz`<br>
|
Archive of `scripts` folder (contains scripts for FW/plugins development) - `flipper-z-any-scripts-(version).tgz`<br>
|
||||||
|
|||||||
280
ReadMe.md
280
ReadMe.md
@@ -3,6 +3,20 @@
|
|||||||
<img src="https://user-images.githubusercontent.com/10697207/186202043-26947e28-b1cc-459a-8f20-ffcc7fc0c71c.png" align="center" alt="fzCUSTOM" border="0">
|
<img src="https://user-images.githubusercontent.com/10697207/186202043-26947e28-b1cc-459a-8f20-ffcc7fc0c71c.png" align="center" alt="fzCUSTOM" border="0">
|
||||||
</a>
|
</a>
|
||||||
</h3>
|
</h3>
|
||||||
|
<div align="center" id="badges">
|
||||||
|
<a href="https://discord.unleashedflip.com">
|
||||||
|
<img src="https://img.shields.io/discord/937479784148115456?style=flat-square&logo=discord&label=Discord&color=%237289DA&link=https%3A%2F%2Fdiscord.unleashedflip.com%2F" alt="Discord server"/>
|
||||||
|
</a>
|
||||||
|
<a href="https://t.me/flipperzero_unofficial">
|
||||||
|
<img src="https://img.shields.io/endpoint?label=EN%20Channel&style=flat-square&url=https%3A%2F%2Fmogyo.ro%2Fquart-apis%2Ftgmembercount%3Fchat_id%3Dflipperzero_unofficial" alt="EN TG channel"/>
|
||||||
|
</a>
|
||||||
|
<a href="https://t.me/flipperzero_unofficial_ru">
|
||||||
|
<img src="https://img.shields.io/endpoint?label=RU%20Channel&style=flat-square&url=https%3A%2F%2Fmogyo.ro%2Fquart-apis%2Ftgmembercount%3Fchat_id%3Dflipperzero_unofficial_ru" alt="RU TG channel"/>
|
||||||
|
</a>
|
||||||
|
<a href="https://t.me/flipperzero_unofficial_ua">
|
||||||
|
<img src="https://img.shields.io/endpoint?label=UA%20Channel&style=flat-square&url=https%3A%2F%2Fmogyo.ro%2Fquart-apis%2Ftgmembercount%3Fchat_id%3Dflipperzero_unofficial_ua" alt="UA TG channel"/>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
### Welcome to the Flipper Zero Unleashed Firmware repo!
|
### Welcome to the Flipper Zero Unleashed Firmware repo!
|
||||||
|
|
||||||
@@ -16,14 +30,11 @@
|
|||||||
|
|
||||||
##### This software is for experimental purposes only and is not meant for any illegal activity/purposes. <br> We do not condone illegal activity and strongly encourage keeping transmissions to legal/valid uses allowed by law. <br> Also, this software is made without any support from Flipper Devices and is in no way related to the official devs.
|
##### This software is for experimental purposes only and is not meant for any illegal activity/purposes. <br> We do not condone illegal activity and strongly encourage keeping transmissions to legal/valid uses allowed by law. <br> Also, this software is made without any support from Flipper Devices and is in no way related to the official devs.
|
||||||
|
|
||||||
<br>
|
|
||||||
Our Discord Community:
|
|
||||||
<br>
|
|
||||||
<a href="https://discord.unleashedflip.com"><img src="https://discordapp.com/api/guilds/937479784148115456/widget.png?style=banner4" alt="Unofficial Discord Community" target="_blank"></a>
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
<br>
|
|
||||||
<br>
|
## FAQ (frequently asked questions)
|
||||||
|
[Follow this link to find answers to most asked questions](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/FAQ.md)
|
||||||
|
|
||||||
## Dev builds (unstable)
|
## Dev builds (unstable)
|
||||||
- https://dev.unleashedflip.com/
|
- https://dev.unleashedflip.com/
|
||||||
@@ -32,45 +43,59 @@ Our Discord Community:
|
|||||||
- https://t.me/unleashed_fw
|
- https://t.me/unleashed_fw
|
||||||
|
|
||||||
# What's changed
|
# What's changed
|
||||||
* Sub-GHz regional TX restrictions removed
|
- **Sub-GHz** *lib & hal*
|
||||||
* Sub-GHz frequency range can be extended in settings file (Warning: It can damage Flipper's hardware)
|
- Regional TX restrictions removed
|
||||||
* Many rolling code protocols now have the ability to save & send captured signals
|
- Extra Sub-GHz frequencies
|
||||||
* FAAC SLH (Spa) & BFT Mitto (keeloq secure with seed) manual creation
|
- Frequency range can be extended in settings file (Warning: It can damage Flipper's hardware)
|
||||||
* Sub-GHz static code brute-force plugin
|
- Many rolling code [protocols](https://github.com/DarkFlippers/unleashed-firmware#current-modified-and-new-sub-ghz-protocols-list) now have the ability to save & send captured signals
|
||||||
* LFRFID Fuzzer plugin
|
- FAAC SLH (Spa) & BFT Mitto (keeloq secure with seed) manual creation
|
||||||
* Custom community plugins and games added + all known working apps can be downloaded in extra pack in every release
|
- External CC1101 module support [(by quen0n)](https://github.com/DarkFlippers/unleashed-firmware/pull/307)
|
||||||
* Extra Sub-GHz frequencies + extra Mifare Classic keys
|
- **Sub-GHz** *Main App*
|
||||||
* Picopass/iClass plugin included in releases
|
- Save last used frequency [(by derskythe)](https://github.com/DarkFlippers/unleashed-firmware/pull/77)
|
||||||
* Recompiled IR TV Universal Remote for ALL buttons
|
- New frequency analyzer [(by ClusterM)](https://github.com/DarkFlippers/unleashed-firmware/pull/43)
|
||||||
* Universal remote for Projectors, Fans, A/Cs and Audio(soundbars, etc.)
|
- Press OK in frequency analyzer to use detected frequency in Read modes [(by derskythe)](https://github.com/DarkFlippers/unleashed-firmware/pull/77)
|
||||||
* Customizable Flipper name **Update! Now can be changed in Settings->Desktop** (by @xMasterX and @Willy-JL)
|
- Long press OK button in Sub-GHz Frequency analyzer to switch to Read menu [(by derskythe)](https://github.com/DarkFlippers/unleashed-firmware/pull/79)
|
||||||
* Text Input UI element -> Cursor feature (by @Willy-JL)
|
- New option to use timestamps + protocol name when you saving file, instead of random name - Enable in `Radio Settings -> Time in names = ON`
|
||||||
- **BadBT** plugin (BT version of BadKB) [(by Willy-JL, ClaraCrazy, XFW contributors)](https://github.com/ClaraCrazy/Flipper-Xtreme/tree/dev/applications/main/bad_kb) - (See in Applications->Tools) - (aka BadUSB via Bluetooth)
|
- Read mode UI improvements (shows time when signal was received) (by @wosk)
|
||||||
- BadUSB -> Keyboard layouts [(by rien > dummy-decoy)](https://github.com/dummy-decoy/flipperzero-firmware/tree/dummy_decoy/bad_usb_keyboard_layout)
|
- External CC1101 module support (Hardware SPI used)
|
||||||
- Sub-GHz -> External CC1101 module support - [(by quen0n)](https://github.com/DarkFlippers/unleashed-firmware/pull/307)
|
- **Hold right in received signal list to delete selected signal**
|
||||||
- Sub-GHz -> `Add manually` menu extended with new protocols
|
- **Custom buttons for Keeloq / Alutech AT4N / Nice Flor S / Somfy Telis / Security+ 2.0 / CAME Atomo** - now you can use arrow buttons to send signal with different button code
|
||||||
- Sub-GHz -> New frequency analyzer - [(by ClusterM)](https://github.com/DarkFlippers/unleashed-firmware/pull/43)
|
- `Add manually` menu extended with new protocols
|
||||||
- Sub-GHz -> Save last used frequency [(by derskythe)](https://github.com/DarkFlippers/unleashed-firmware/pull/77)
|
- FAAC SLH, BFT Mitto / Somfy Telis / Nice Flor S / CAME Atomo, etc.. manual creation with programming new remote into receiver (use button 0xF for BFT Mitto, 0x8 (Prog) on Somfy Telis)
|
||||||
- Sub-GHz -> Press OK in frequency analyzer to use detected frequency in Read modes [(by derskythe)](https://github.com/DarkFlippers/unleashed-firmware/pull/77)
|
- Debug mode counter increase settings (+1 -> +5, +10, default: +1)
|
||||||
- Sub-GHz -> Long press OK button in Sub-GHz Frequency analyzer to switch to Read menu [(by derskythe)](https://github.com/DarkFlippers/unleashed-firmware/pull/79)
|
- Debug PIN output settings for protocol development
|
||||||
- Lock device with pin(or regular lock if pin not set) by holding UP button on main screen [(by an4tur0r)](https://github.com/DarkFlippers/unleashed-firmware/pull/107)
|
|
||||||
* Sub-GHz -> Short press OK in frequency analyzer to save detected frequency for usage in Read modes
|
|
||||||
* Sub-GHz -> Long press OK button in Sub-GHz Frequency analyzer to switch to Read menu and automatically use selected frequency
|
|
||||||
* SubGHz -> New option to use timestamps + protocol name when you saving file, instead of random name - Enable in `Radio Settings -> Time in names = ON`
|
|
||||||
* SubGHz Bruteforcer plugin -> Time delay (between signals) setting (hold Up in main screen(says Up to Save)) + configure repeats in protocols list by pressing right button on selected protocol
|
|
||||||
* SubGHz -> Read mode UI improvements (scrolling text, + shows time when signal was received) (by @wosk)
|
|
||||||
* Sub-GHz -> External CC1101 module support (Hardware SPI used)
|
|
||||||
* SubGHz -> **Hold right in received signal list to delete selected signal**
|
|
||||||
* SubGHz -> **Custom buttons for Keeloq / Alutech AT4N / Nice Flor S / Somfy Telis / Security+ 2.0 / CAME Atomo** - now you can use arrow buttons to send signal with different button code
|
|
||||||
* SubGHz -> BFT Mitto / Somfy Telis / Nice Flor S / CAME Atomo, etc.. manual creation with programming new remote into receiver (use button 0xF for BFT Mitto, 0x8 (Prog) on Somfy Telis)
|
|
||||||
* SubGHz -> Debug mode counter increase settings (+1 -> +5, +10, default: +1)
|
|
||||||
* SubGHz -> Debug PIN output settings for protocol development
|
|
||||||
* Infrared -> `RCA` Protocol
|
|
||||||
* Infrared -> Debug TX PIN output settings
|
|
||||||
* Other small fixes and changes throughout
|
|
||||||
* See other changes in readme below
|
|
||||||
|
|
||||||
Also check the changelog in releases for latest updates!
|
- **Sub-GHz apps** *by unleashed team*
|
||||||
|
- Sub-GHz Bruteforce - static code brute-force plugin |
|
||||||
|
- Time delay (between signals) setting (hold Up in main screen(says Up to Save)) + configure repeats in protocols list by pressing right button on selected protocol
|
||||||
|
- Load your own file and select bytes you want to bruteforce or use preconfigured options in protocols list
|
||||||
|
- Sub-GHz Remote - remote control for 5 sub-ghz files | bind one file for each button
|
||||||
|
- use the built-in constructor or make config file by following this [instruction](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemotePlugin.md)
|
||||||
|
- **Infrared**
|
||||||
|
- Recompiled IR TV Universal Remote for ALL buttons
|
||||||
|
- Universal remotes for Projectors, Fans, A/Cs and Audio(soundbars, etc.) -> Also always updated and verified by our team
|
||||||
|
- Infrared -> `RCA` Protocol
|
||||||
|
- Infrared -> Debug TX PIN output settings
|
||||||
|
- **NFC/RFID/iButton**
|
||||||
|
* LFRFID/iButton Fuzzer plugins
|
||||||
|
* Extra Mifare Classic keys
|
||||||
|
* `Add manually` -> Mifare Classic with custom UID
|
||||||
|
* Picopass/iClass plugin (now with emulation support!) included in releases
|
||||||
|
- **Quality of life & other features**
|
||||||
|
- Customizable Flipper name **Update! Now can be changed in Settings->Desktop** (by @xMasterX and @Willy-JL)
|
||||||
|
- Text Input UI element -> Cursor feature (by @Willy-JL)
|
||||||
|
- Byte Input Mini editor -> **Press UP** multiple times until the nibble editor appears
|
||||||
|
- Clock on Desktop -> `Settings -> Desktop -> Show Clock`
|
||||||
|
- Battery percentage display with different styles `Settings -> Desktop -> Battery View`
|
||||||
|
- More games in Dummy Mode -> click or hold any of arrow buttons
|
||||||
|
- Lock device with pin(or regular lock if pin not set) by holding UP button on main screen [(by an4tur0r)](https://github.com/DarkFlippers/unleashed-firmware/pull/107)
|
||||||
|
- **BadBT** plugin (BT version of BadKB) [(by Willy-JL, ClaraCrazy, XFW contributors)](https://github.com/ClaraCrazy/Flipper-Xtreme/tree/dev/applications/main/bad_kb) - (See in Applications->Tools) - (aka BadUSB via Bluetooth)
|
||||||
|
- BadUSB -> Keyboard layouts [(by rien > dummy-decoy)](https://github.com/dummy-decoy/flipperzero-firmware/tree/dummy_decoy/bad_usb_keyboard_layout)
|
||||||
|
- Custom community plugins and games added + all known working apps can be downloaded in extra pack in every release
|
||||||
|
- Other small fixes and changes throughout
|
||||||
|
- See other changes in readme below
|
||||||
|
|
||||||
|
Also check the [changelog in releases](https://github.com/DarkFlippers/unleashed-firmware/releases) for latest updates!
|
||||||
|
|
||||||
### Current modified and new Sub-GHz protocols list:
|
### Current modified and new Sub-GHz protocols list:
|
||||||
Thanks to Official team (to their SubGHz Developer, Skorp) for implementing decoders for these protocols in OFW.
|
Thanks to Official team (to their SubGHz Developer, Skorp) for implementing decoders for these protocols in OFW.
|
||||||
@@ -98,8 +123,8 @@ Encoders or sending made by @xMasterX:
|
|||||||
Encoders or sending made by @Eng1n33r(first implementation in Q2 2022) & @xMasterX (current version):
|
Encoders or sending made by @Eng1n33r(first implementation in Q2 2022) & @xMasterX (current version):
|
||||||
- CAME Atomo -> Update! check out new [instructions](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemoteProg.md)
|
- CAME Atomo -> Update! check out new [instructions](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemoteProg.md)
|
||||||
- Nice Flor S -> How to create new remote - [instructions](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemoteProg.md)
|
- Nice Flor S -> How to create new remote - [instructions](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemoteProg.md)
|
||||||
- FAAC SLH (Spa) [External seed calculation required (For info contact me in Discord: @mmx7)]
|
- FAAC SLH (Spa) -> Update!!! Check out new [instructions](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemoteProg.md)
|
||||||
- Keeloq: BFT Mitto -> Update! check out new [instructions](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemoteProg.md)
|
- Keeloq: BFT Mitto -> Update! Check out new [instructions](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemoteProg.md)
|
||||||
- Star Line
|
- Star Line
|
||||||
- Security+ v1 & v2 (encoders was made in OFW)
|
- Security+ v1 & v2 (encoders was made in OFW)
|
||||||
|
|
||||||
@@ -114,146 +139,109 @@ Encoders made by @assasinfil & @xMasterX:
|
|||||||
The majority of this project is developed and maintained by me, @xMasterX.
|
The majority of this project is developed and maintained by me, @xMasterX.
|
||||||
I'm unemployed, and the only income I receive is from your donations.
|
I'm unemployed, and the only income I receive is from your donations.
|
||||||
Our team is small and the guys are working on this project as much as they can solely based on the enthusiasm they have for this project and the community.
|
Our team is small and the guys are working on this project as much as they can solely based on the enthusiasm they have for this project and the community.
|
||||||
- @assasinfil - SubGHz
|
- @gid9798 - SubGHz, Plugins, many other things
|
||||||
|
- @assasinfil - SubGHz protocols
|
||||||
- @Svaarich - UI design and animations
|
- @Svaarich - UI design and animations
|
||||||
- @Amec0e - Infrared assets
|
- @amec0e & @Leptopt1los - Infrared assets
|
||||||
- Community moderators in Telegram, Discord, and Reddit
|
- Community moderators in Telegram, Discord, and Reddit
|
||||||
- And of course our GitHub community. Your PRs are a very important part of this firmware and open-source development.
|
- And of course our GitHub community. Your PRs are a very important part of this firmware and open-source development.
|
||||||
|
|
||||||
The amount of work done on this project is huge and we need your support, no matter how large or small. Even if you just say, "Thank you Unleashed firmware developers!" somewhere. Doing so will help us continue our work and will help drive us to make the firmware better every time.
|
The amount of work done on this project is huge and we need your support, no matter how large or small. Even if you just say, "Thank you Unleashed firmware developers!" somewhere. Doing so will help us continue our work and will help drive us to make the firmware better every time.
|
||||||
Also, regarding our releases, every build has and always will be free and open-source. There will be no paywall releases or closed-source apps within the firmware. As long as I am working on this project it will never happen.
|
Also, regarding our releases, every build has and always will be free and open-source. There will be no paywall releases or closed-source apps within the firmware. As long as I am working on this project it will never happen.
|
||||||
You can support us by using links or addresses below:
|
You can support us by using links or addresses below:
|
||||||
* **Boosty** (patreon alternative): https://boosty.to/mmxdev
|
|Service|Remark|Link/Wallet|
|
||||||
* cloudtips (only RU payments accepted): https://pay.cloudtips.ru/p/7b3e9d65
|
|-|-|-|
|
||||||
* YooMoney (only RU payments accepted): https://yoomoney.ru/fundraise/XA49mgQLPA0.221209
|
|**Patreon**||https://patreon.com/mmxdev|
|
||||||
* USDT(TRC20): `TSXcitMSnWXUFqiUfEXrTVpVewXy2cYhrs`
|
|**Boosty**|patreon alternative|https://boosty.to/mmxdev|
|
||||||
* BCH: `qquxfyzntuqufy2dx0hrfr4sndp0tucvky4sw8qyu3`
|
|cloudtips|only RU payments accepted|https://pay.cloudtips.ru/p/7b3e9d65|
|
||||||
* ETH/BSC/ERC20-Tokens: `darkflippers.eth` (or `0xFebF1bBc8229418FF2408C07AF6Afa49152fEc6a`)
|
|YooMoney|only RU payments accepted|https://yoomoney.ru/fundraise/XA49mgQLPA0.221209|
|
||||||
* BTC: `bc1q0np836jk9jwr4dd7p6qv66d04vamtqkxrecck9`
|
|USDT|(TRC20)|`TSXcitMSnWXUFqiUfEXrTVpVewXy2cYhrs`|
|
||||||
* DOGE: `D6R6gYgBn5LwTNmPyvAQR6bZ9EtGgFCpvv`
|
|BCH||`qquxfyzntuqufy2dx0hrfr4sndp0tucvky4sw8qyu3`|
|
||||||
* LTC: `ltc1q3ex4ejkl0xpx3znwrmth4lyuadr5qgv8tmq8z9`
|
|ETH|(BSC/ERC20-Tokens)|`darkflippers.eth` (or `0xFebF1bBc8229418FF2408C07AF6Afa49152fEc6a`)|
|
||||||
* XMR (Monero): `41xUz92suUu1u5Mu4qkrcs52gtfpu9rnZRdBpCJ244KRHf6xXSvVFevdf2cnjS7RAeYr5hn9MsEfxKoFDRSctFjG5fv1Mhn`
|
|BTC||`bc1q0np836jk9jwr4dd7p6qv66d04vamtqkxrecck9`|
|
||||||
* TON: `EQCOqcnYkvzOZUV_9bPE_8oTbOrOF03MnF-VcJyjisTZmpGf`
|
|DOGE||`D6R6gYgBn5LwTNmPyvAQR6bZ9EtGgFCpvv`|
|
||||||
|
|LTC||`ltc1q3ex4ejkl0xpx3znwrmth4lyuadr5qgv8tmq8z9`|
|
||||||
|
|XMR|(Monero)| `41xUz92suUu1u5Mu4qkrcs52gtfpu9rnZRdBpCJ244KRHf6xXSvVFevdf2cnjS7RAeYr5hn9MsEfxKoFDRSctFjG5fv1Mhn`|
|
||||||
|
|TON||`EQCOqcnYkvzOZUV_9bPE_8oTbOrOF03MnF-VcJyjisTZmpGf`|
|
||||||
|
|
||||||
### Community apps included:
|
## Community apps included
|
||||||
|
|
||||||
- **RFID Fuzzer** [(by @gid9798)](https://github.com/DarkFlippers/Multi_Fuzzer) (original by Ganapati & xMasterX)
|
### [🎲 Download Extra plugins for Unleashed](https://github.com/xMasterX/all-the-plugins/releases/latest)
|
||||||
- **iButton Fuzzer** [(by @gid9798)](https://github.com/DarkFlippers/Multi_Fuzzer) (original by xMasterX)
|
### [List of Extra pack](https://github.com/xMasterX/all-the-plugins/tree/dev#extra-pack) | [List of Base *(Deafult)* pack](https://github.com/xMasterX/all-the-plugins/tree/dev#default-pack)
|
||||||
- **Sub-GHz bruteforcer** [(by @derskythe & xMasterX)](https://github.com/derskythe/flipperzero-subbrute) [(original by Ganapati & xMasterX)](https://github.com/DarkFlippers/unleashed-firmware/pull/57)
|
|
||||||
- **Sub-GHz playlist** [(by darmiel)](https://github.com/DarkFlippers/unleashed-firmware/pull/62)
|
|
||||||
- ESP8266 Deauther plugin [(by SequoiaSan)](https://github.com/SequoiaSan/FlipperZero-Wifi-ESP8266-Deauther-Module)
|
|
||||||
- WiFi Scanner plugin [(by SequoiaSan)](https://github.com/SequoiaSan/FlipperZero-WiFi-Scanner_Module)
|
|
||||||
- MultiConverter plugin [(by theisolinearchip)](https://github.com/theisolinearchip/flipperzero_stuff)
|
|
||||||
- WAV Player [(OFW: DrZlo13)](https://github.com/flipperdevices/flipperzero-firmware/tree/zlo/wav-player) - Fixed and improved by [LTVA1](https://github.com/LTVA1/wav_player) -> Also outputs audio on `PA6` - `3(A6)` pin
|
|
||||||
- Barcode Generator [(by Kingal1337)](https://github.com/Kingal1337/flipper-barcode-generator)
|
|
||||||
- GPIO: Sentry Safe plugin [(by H4ckd4ddy)](https://github.com/H4ckd4ddy/flipperzero-sentry-safe-plugin)
|
|
||||||
- ESP32: WiFi Marauder companion plugin [(by 0xchocolate)](https://github.com/0xchocolate/flipperzero-wifi-marauder) - Saving .pcap on flipper microSD [by tcpassos](https://github.com/tcpassos/flipperzero-firmware-with-wifi-marauder-companion) -> Only with custom marauder build (It is necessary to uncomment "#define WRITE_PACKETS_SERIAL" in configs.h (in marauder fw) and compile the firmware for the wifi board.) Or download precompiled build -> [Download esp32_marauder_ver_flipper_sd_serial.bin](https://github.com/justcallmekoko/ESP32Marauder/releases/latest)
|
|
||||||
- NRF24: Sniffer & MouseJacker (with changes) [(by mothball187)](https://github.com/mothball187/flipperzero-nrf24/tree/main/mousejacker)
|
|
||||||
- Simple Clock (timer by GMMan) [(original by CompaqDisc)](https://gist.github.com/CompaqDisc/4e329c501bd03c1e801849b81f48ea61)
|
|
||||||
- **Sub-GHz Remote** [(by @gid9798)](https://github.com/gid9798)
|
|
||||||
- Spectrum Analyzer (with changes) [(by jolcese)](https://github.com/jolcese/flipperzero-firmware/tree/spectrum/applications/spectrum_analyzer) - [Ultra Narrow mode & scan channels non-consecutively](https://github.com/theY4Kman/flipperzero-firmware/commits?author=theY4Kman)
|
|
||||||
- Metronome [(by panki27)](https://github.com/panki27/Metronome)
|
|
||||||
- DTMF Dolphin [(by litui)](https://github.com/litui/dtmf_dolphin)
|
|
||||||
- **TOTP (Authenticator)** [(by akopachov)](https://github.com/akopachov/flipper-zero_authenticator)
|
|
||||||
- GPS [(by ezod)](https://github.com/ezod/flipperzero-gps) works with module `NMEA 0183` via UART (13TX, 14RX, GND pins on Flipper)
|
|
||||||
- i2c Tools [(by NaejEL)](https://github.com/NaejEL/flipperzero-i2ctools) - C0 -> SCL / C1 -> SDA / GND -> GND | 3v3 logic levels only!
|
|
||||||
- HC-SR04 Distance sensor - Ported and modified by @xMasterX [(original by Sanqui)](https://github.com/Sanqui/flipperzero-firmware/tree/hc_sr04) - How to connect -> (5V -> VCC) / (GND -> GND) / (13|TX -> Trig) / (14|RX -> Echo)
|
|
||||||
- Morse Code [(by wh00hw)](https://github.com/wh00hw/MorseCodeFAP)
|
|
||||||
- **Unitemp - Temperature sensors reader** (DHT11/22, DS18B20, BMP280, HTU21x and more) [(by quen0n)](https://github.com/quen0n/unitemp-flipperzero)
|
|
||||||
- Lightmeter [(by oleksiikutuzov)](https://github.com/oleksiikutuzov/flipperzero-lightmeter)
|
|
||||||
- HEX Viewer [(by QtRoS)](https://github.com/QtRoS/flipper-zero-hex-viewer)
|
|
||||||
- POCSAG Pager [(by xMasterX & Shmuma)](https://github.com/xMasterX/flipper-pager)
|
|
||||||
- Text Viewer [(by kowalski7cc & kyhwana)](https://github.com/kowalski7cc/flipper-zero-text-viewer/tree/refactor-text-app)
|
|
||||||
- **UART Terminal** [(by cool4uma)](https://github.com/cool4uma/UART_Terminal/tree/main)
|
|
||||||
- **ProtoView** [(by antirez)](https://github.com/antirez/protoview)
|
|
||||||
- **SWD Probe** [(by g3gg0)](https://github.com/g3gg0/flipper-swd_probe)
|
|
||||||
- IR Scope [(by kallanreed)](https://github.com/DarkFlippers/unleashed-firmware/pull/407)
|
|
||||||
- **BadBT** plugin (BT version of BadKB) [(by Willy-JL, ClaraCrazy, XFW contributors)](https://github.com/ClaraCrazy/Flipper-Xtreme/tree/dev/applications/main/bad_kb) (See in Applications->Tools) - (aka BadUSB via Bluetooth)
|
|
||||||
- **Mifare Nested** [(by AloneLiberty)](https://github.com/AloneLiberty/FlipperNested) - Works with PC and python app `FlipperNested`
|
|
||||||
- **NFC Maker** plugin (make tags with URLs, Wifi and other things) [(by Willy-JL)](https://github.com/ClaraCrazy/Flipper-Xtreme/tree/dev/applications/external/nfc_maker)
|
|
||||||
- ESP32-CAM -> Camera Suite [(by CodyTolene)](https://github.com/CodyTolene/Flipper-Zero-Camera-Suite)
|
|
||||||
|
|
||||||
Games:
|
See full list and sources here: [xMasterX/all-the-plugins](https://github.com/xMasterX/all-the-plugins/tree/dev)
|
||||||
- DOOM (ported and fixed by @xMasterX & @Svarich & @hedger) [(original by p4nic4ttack)](https://github.com/p4nic4ttack/doom-flipper-zero/)
|
|
||||||
- Zombiez [(Reworked By DevMilanIan)](https://github.com/RogueMaster/flipperzero-firmware-wPlugins/pull/240) [(Original By Dooskington)](https://github.com/Dooskington/flipperzero-zombiez)
|
|
||||||
- Flappy Bird [(by DroomOne)](https://github.com/DroomOne/flipperzero-firmware/tree/dev/applications/flappy_bird)
|
|
||||||
- Arkanoid (refactored by xMasterX) [(by gotnull)](https://github.com/gotnull/flipperzero-firmware-wPlugins)
|
|
||||||
- Tic Tac Toe (refactored by xMasterX) [(by gotnull)](https://github.com/gotnull/flipperzero-firmware-wPlugins)
|
|
||||||
- Tetris (with fixes) [(by jeffplang)](https://github.com/jeffplang/flipperzero-firmware/tree/tetris_game/applications/tetris_game)
|
|
||||||
- Minesweeper [(by panki27)](https://github.com/panki27/minesweeper)
|
|
||||||
- Heap Defence (aka Stack Attack) - Ported to latest firmware by @xMasterX - [(original by wquinoa & Vedmein)](https://github.com/Vedmein/flipperzero-firmware/tree/hd/svisto-perdelki)
|
|
||||||
- Game15 [(by x27)](https://github.com/x27/flipperzero-game15)
|
|
||||||
- Solitaire [(by teeebor)](https://github.com/teeebor/flipper_games)
|
|
||||||
- BlackJack [(by teeebor)](https://github.com/teeebor/flipper_games)
|
|
||||||
- 2048 game [(by eugene-kirzhanov)](https://github.com/eugene-kirzhanov/flipper-zero-2048-game)
|
|
||||||
- Bomberduck [(by leo-need-more-coffee)](https://github.com/leo-need-more-coffee/flipperzero-bomberduck)
|
|
||||||
- JetPack Joyride [(by timstrasser)](https://github.com/timstrasser)
|
|
||||||
|
|
||||||
|
### Official Flipper Zero Apps Catalog [web version](https://lab.flipper.net/apps) or mobile app
|
||||||
|
|
||||||
# Instructions
|
# Instructions
|
||||||
## [- How to install firmware](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/HowToInstall.md)
|
## First lock official docs [docs.flipper.net](https://docs.flipper.net/)
|
||||||
|
## [How to install](/documentation/HowToInstall.md) - [versions info](/CHANGELOG.md#recommended-update-option---web-updater): `n`,` `,`e`...
|
||||||
|
## Firmware & Development
|
||||||
|
|
||||||
## [- How to build firmware](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/HowToBuild.md)
|
### - **[How to build](/documentation/HowToBuild.md#how-to-build-by-yourself) | [Project-structure](#project-structure)**
|
||||||
|
|
||||||
## [- How to connect external CC1101 module](https://github.com/quen0n/flipperzero-ext-cc1101)
|
### - **CLion IDE** - How to setup workspace for flipper firmware development [by Savely Krasovsky](https://krasovs.ky/2022/11/01/flipper-zero-clion.html)
|
||||||
|
|
||||||
## [- BadUSB: how to add new keyboard layouts](https://github.com/dummy-decoy/flipperzero_badusb_kl)
|
### - **"Hello world!"** - plugin tutorial [English<sub> by DroomOne</sub> ](https://github.com/DroomOne/Flipper-Plugin-Tutorial) | [Russian<sub> by Pavel Yakovlev</sub>](https://yakovlev.me/hello-flipper-zero/)
|
||||||
|
|
||||||
## [- How to change Flipper name](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/CustomFlipperName.md)
|
### - [How to write your own app](https://flipper.atmanos.com/docs/overview/intro). Docs by atmanos **⚠️outdated API**
|
||||||
|
|
||||||
## [- How to use Mifare Nested plugin to recover keys](https://github.com/AloneLiberty/FlipperNested#how-to-use-it)
|
## Firmware & main Apps feature
|
||||||
|
|
||||||
## [- How to make captures to add them into Universal IR remotes](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/InfraredCaptures.md)
|
### - System: [How to change Flipper name](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/CustomFlipperName.md)
|
||||||
|
|
||||||
### **Sub-GHz**
|
### - BadUSB: [How to add new keyboard layouts](https://github.com/dummy-decoy/flipperzero_badusb_kl)
|
||||||
|
|
||||||
## [- Transmission is blocked? - How to extend Sub-GHz frequency range](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/DangerousSettings.md)
|
### - Infrared: [How to make captures to add them into Universal IR remotes](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/InfraredCaptures.md)
|
||||||
|
|
||||||
## [- How to add extra Sub-GHz frequencies](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzSettings.md)
|
## **Sub-GHz**
|
||||||
|
|
||||||
## [- How to use Flipper as new remote (Nice FlorS, BFT Mitto, Somfy Telis, Aprimatic, AN-Motors, etc..)](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemoteProg.md)
|
### - External Radio: [How to connect CC1101 module](https://github.com/quen0n/flipperzero-ext-cc1101)
|
||||||
|
|
||||||
## [- Configure Sub-GHz Remote App](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemotePlugin.md)
|
### - Transmission is blocked? [How to extend Sub-GHz frequency range](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/DangerousSettings.md)
|
||||||
|
|
||||||
### **Plugins**
|
### - [How to add extra Sub-GHz frequencies](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzSettings.md)
|
||||||
|
|
||||||
## [- 🎲 Download Extra plugins for Unleashed](https://github.com/xMasterX/all-the-plugins)
|
### - [How to use Flipper as new remote (Nice FlorS, BFT Mitto, Somfy Telis, Aprimatic, AN-Motors, etc..)](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemoteProg.md)
|
||||||
|
|
||||||
## [- TOTP (Authenticator) config description](https://github.com/akopachov/flipper-zero_authenticator/blob/master/docs/conf-file_description.md)
|
### - [~~Configure Sub-GHz Remote App~~](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SubGHzRemotePlugin.md) Not recomeded, please use embedded configurator
|
||||||
|
|
||||||
## [- Barcode Generator](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/BarcodeGenerator.md)
|
## **Plugins**
|
||||||
|
|
||||||
## [- Multi Converter](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/MultiConverter.md)
|
### - TOTP (Authenticator): [config description](https://github.com/akopachov/flipper-zero_authenticator/blob/master/docs/conf-file_description.md)
|
||||||
|
|
||||||
## [- WAV Player sample files & how to convert](https://github.com/UberGuidoZ/Flipper/tree/main/Wav_Player#readme)
|
### - Mifare Nested plugin: [How to recover keys](https://github.com/AloneLiberty/FlipperNested#how-to-use-it)
|
||||||
|
|
||||||
## [- Sub-GHz playlist generator script](https://github.com/darmiel/flipper-scripts/blob/main/playlist/playlist_creator_by_chunk.py)
|
### - Barcode Generator: [How to use](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/BarcodeGenerator.md)
|
||||||
|
|
||||||
### **Plugins that works with external hardware**
|
### - Multi Converter: [How to use](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/MultiConverter.md)
|
||||||
|
|
||||||
## [- How to use: Unitemp - Temperature sensors reader](https://github.com/quen0n/unitemp-flipperzero#readme)
|
### - WAV Player: [sample files & how to convert](https://github.com/UberGuidoZ/Flipper/tree/main/Wav_Player#readme)
|
||||||
|
|
||||||
## [- How to use: [NMEA] GPS](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/applications/external/gps_nmea_uart/README.md)
|
### - Sub-GHz playlist: [generator script](https://github.com/darmiel/flipper-scripts/blob/main/playlist/playlist_creator_by_chunk.py)
|
||||||
|
|
||||||
## [- How to use: i2c Tools](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/applications/external/flipper_i2ctools/README.md)
|
## **Plugins that works with external hardware** [GPIO]
|
||||||
|
|
||||||
## [- How to use: [NRF24] plugins](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/NRF24.md)
|
### - Unitemp - Temperature sensors reader: [How to use & supported sensors](https://github.com/quen0n/unitemp-flipperzero#readme)
|
||||||
|
|
||||||
## [- How to use: [WiFi] Scanner](https://github.com/SequoiaSan/FlipperZero-WiFi-Scanner_Module#readme)
|
### - [NMEA] GPS: [How to use](https://github.com/xMasterX/all-the-plugins/blob/dev/base_pack/gps_nmea_uart/README.md)
|
||||||
|
|
||||||
## [- How to use: [ESP8266] Deauther](https://github.com/SequoiaSan/FlipperZero-Wifi-ESP8266-Deauther-Module#readme)
|
### - i2c Tools [How to use](https://github.com/xMasterX/all-the-plugins/blob/dev/base_pack/flipper_i2ctools/README.md)
|
||||||
|
|
||||||
## [- How to use: [ESP32] WiFi Marauder](https://github.com/UberGuidoZ/Flipper/tree/main/Wifi_DevBoard)
|
### - [NRF24] plugins: [How to use](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/NRF24.md)
|
||||||
|
|
||||||
## [- How to use: [ESP32-CAM] Camera Suite](https://github.com/CodyTolene/Flipper-Zero-Camera-Suite)
|
|
||||||
|
|
||||||
## [- [WiFi] Scanner - Web Flasher for module firmware](https://sequoiasan.github.io/FlipperZero-WiFi-Scanner_Module/)
|
### - [WiFi] Scanner: [How to use](https://github.com/SequoiaSan/FlipperZero-WiFi-Scanner_Module#readme) | [Web Flasher](https://sequoiasan.github.io/FlipperZero-WiFi-Scanner_Module/)
|
||||||
|
|
||||||
## [- [ESP8266] Deauther - Web Flasher for module firmware](https://sequoiasan.github.io/FlipperZero-Wifi-ESP8266-Deauther-Module/)
|
### - [ESP8266] Deauther: [How to use](https://github.com/SequoiaSan/FlipperZero-Wifi-ESP8266-Deauther-Module#readme) | [Web Flasher](https://sequoiasan.github.io/FlipperZero-Wifi-ESP8266-Deauther-Module/)
|
||||||
|
|
||||||
## [- Windows: How to Upload .bin to ESP32/ESP8266](https://github.com/SequoiaSan/Guide-How-To-Upload-bin-to-ESP8266-ESP32)
|
### - [ESP32] WiFi Marauder: [How to use](https://github.com/UberGuidoZ/Flipper/tree/main/Wifi_DevBoard)<sub> docs by UberGuidoZ</sub> | [Marauder repo](https://github.com/justcallmekoko/ESP32Marauder)
|
||||||
|
|
||||||
## [- How to use: [GPIO] SentrySafe plugin](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SentrySafe.md)
|
### - [ESP32-CAM] Camera Suite: [How to use](https://github.com/CodyTolene/Flipper-Zero-Camera-Suite)
|
||||||
|
|
||||||
|
### - How to Upload `.bin` to ESP32/ESP8266: [Windows](https://github.com/SequoiaSan/Guide-How-To-Upload-bin-to-ESP8266-ESP32) | [FAP "ESP flasher"](https://github.com/0xchocolate/flipperzero-esp-flasher)
|
||||||
|
|
||||||
|
### - [GPIO] SentrySafe plugin: [How to use](https://github.com/DarkFlippers/unleashed-firmware/blob/dev/documentation/SentrySafe.md)
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
<br>
|
<br>
|
||||||
@@ -267,13 +255,7 @@ Games:
|
|||||||
|
|
||||||
# Links
|
# Links
|
||||||
|
|
||||||
* Unofficial Discord: [discord.unleashedflip.com](https://discord.unleashedflip.com)
|
* Official Docs: [docs.flipper.net](https://docs.flipper.net/)
|
||||||
* Hello world - plugin tutorial (English): [https://github.com/DroomOne/Flipper-Plugin-Tutorial](https://github.com/DroomOne/Flipper-Plugin-Tutorial)
|
|
||||||
* Hello world - plugin tutorial (in Russian): [https://yakovlev.me/hello-flipper-zero/](https://yakovlev.me/hello-flipper-zero/)
|
|
||||||
* CLion IDE - How to setup workspace for flipper firmware development: [https://krasovs.ky/2022/11/01/flipper-zero-clion.html](https://krasovs.ky/2022/11/01/flipper-zero-clion.html)
|
|
||||||
* Docs by atmanos / How to write your own app (outdated API): [https://flipper.atmanos.com/docs/overview/intro](https://flipper.atmanos.com/docs/overview/intro)
|
|
||||||
|
|
||||||
* Official Docs: [http://docs.flipperzero.one](http://docs.flipperzero.one)
|
|
||||||
* Official Forum: [forum.flipperzero.one](https://forum.flipperzero.one/)
|
* Official Forum: [forum.flipperzero.one](https://forum.flipperzero.one/)
|
||||||
|
|
||||||
# Project structure
|
# Project structure
|
||||||
|
|||||||
70
SConstruct
70
SConstruct
@@ -45,6 +45,7 @@ distenv = coreenv.Clone(
|
|||||||
],
|
],
|
||||||
ENV=os.environ,
|
ENV=os.environ,
|
||||||
UPDATE_BUNDLE_DIR="dist/${DIST_DIR}/f${TARGET_HW}-update-${DIST_SUFFIX}",
|
UPDATE_BUNDLE_DIR="dist/${DIST_DIR}/f${TARGET_HW}-update-${DIST_SUFFIX}",
|
||||||
|
VSCODE_LANG_SERVER=ARGUMENTS.get("LANG_SERVER", "cpptools"),
|
||||||
)
|
)
|
||||||
|
|
||||||
firmware_env = distenv.AddFwProject(
|
firmware_env = distenv.AddFwProject(
|
||||||
@@ -66,20 +67,22 @@ if GetOption("fullenv") or any(
|
|||||||
# Target for self-update package
|
# Target for self-update package
|
||||||
dist_basic_arguments = [
|
dist_basic_arguments = [
|
||||||
"--bundlever",
|
"--bundlever",
|
||||||
'"${UPDATE_VERSION_STRING}"',
|
"${UPDATE_VERSION_STRING}",
|
||||||
]
|
]
|
||||||
dist_radio_arguments = [
|
dist_radio_arguments = [
|
||||||
"--radio",
|
"--radio",
|
||||||
'"${ROOT_DIR.abspath}/${COPRO_STACK_BIN_DIR}/${COPRO_STACK_BIN}"',
|
"${ROOT_DIR.abspath}/${COPRO_STACK_BIN_DIR}/${COPRO_STACK_BIN}",
|
||||||
"--radiotype",
|
"--radiotype",
|
||||||
"${COPRO_STACK_TYPE}",
|
"${COPRO_STACK_TYPE}",
|
||||||
"${COPRO_DISCLAIMER}",
|
"${COPRO_DISCLAIMER}",
|
||||||
"--obdata",
|
"--obdata",
|
||||||
'"${ROOT_DIR.abspath}/${COPRO_OB_DATA}"',
|
"${ROOT_DIR.abspath}/${COPRO_OB_DATA}",
|
||||||
|
"--stackversion",
|
||||||
|
"${COPRO_CUBE_VERSION}",
|
||||||
]
|
]
|
||||||
dist_resource_arguments = [
|
dist_resource_arguments = [
|
||||||
"-r",
|
"-r",
|
||||||
'"${ROOT_DIR.abspath}/assets/resources"',
|
firmware_env.subst("${RESOURCES_ROOT}"),
|
||||||
]
|
]
|
||||||
dist_splash_arguments = (
|
dist_splash_arguments = (
|
||||||
[
|
[
|
||||||
@@ -92,7 +95,7 @@ if GetOption("fullenv") or any(
|
|||||||
|
|
||||||
selfupdate_dist = distenv.DistCommand(
|
selfupdate_dist = distenv.DistCommand(
|
||||||
"updater_package",
|
"updater_package",
|
||||||
(distenv["DIST_DEPENDS"], firmware_env["FW_RESOURCES"]),
|
(distenv["DIST_DEPENDS"], firmware_env["FW_RESOURCES_MANIFEST"]),
|
||||||
DIST_EXTRA=[
|
DIST_EXTRA=[
|
||||||
*dist_basic_arguments,
|
*dist_basic_arguments,
|
||||||
*dist_radio_arguments,
|
*dist_radio_arguments,
|
||||||
@@ -125,7 +128,8 @@ if GetOption("fullenv") or any(
|
|||||||
|
|
||||||
# Installation over USB & CLI
|
# Installation over USB & CLI
|
||||||
usb_update_package = distenv.AddUsbFlashTarget(
|
usb_update_package = distenv.AddUsbFlashTarget(
|
||||||
"#build/usbinstall.flag", (firmware_env["FW_RESOURCES"], selfupdate_dist)
|
"#build/usbinstall.flag",
|
||||||
|
(firmware_env["FW_RESOURCES_MANIFEST"], selfupdate_dist),
|
||||||
)
|
)
|
||||||
distenv.Alias("flash_usb_full", usb_update_package)
|
distenv.Alias("flash_usb_full", usb_update_package)
|
||||||
|
|
||||||
@@ -163,17 +167,25 @@ Depends(
|
|||||||
list(app_artifact.validator for app_artifact in external_app_list),
|
list(app_artifact.validator for app_artifact in external_app_list),
|
||||||
)
|
)
|
||||||
Alias("fap_dist", fap_dist)
|
Alias("fap_dist", fap_dist)
|
||||||
# distenv.Default(fap_dist)
|
|
||||||
|
|
||||||
distenv.Depends(firmware_env["FW_RESOURCES"], external_apps_artifacts.resources_dist)
|
|
||||||
|
|
||||||
# Copy all faps to device
|
# Copy all faps to device
|
||||||
|
|
||||||
fap_deploy = distenv.PhonyTarget(
|
fap_deploy = distenv.PhonyTarget(
|
||||||
"fap_deploy",
|
"fap_deploy",
|
||||||
"${PYTHON3} ${FBT_SCRIPT_DIR}/storage.py -p ${FLIP_PORT} send ${SOURCE} /ext/apps",
|
[
|
||||||
source=Dir("#/assets/resources/apps"),
|
[
|
||||||
|
"${PYTHON3}",
|
||||||
|
"${FBT_SCRIPT_DIR}/storage.py",
|
||||||
|
"-p",
|
||||||
|
"${FLIP_PORT}",
|
||||||
|
"send",
|
||||||
|
"${SOURCE}",
|
||||||
|
"/ext/apps",
|
||||||
|
]
|
||||||
|
],
|
||||||
|
source=firmware_env.Dir(("${RESOURCES_ROOT}/apps")),
|
||||||
)
|
)
|
||||||
|
Depends(fap_deploy, firmware_env["FW_RESOURCES_MANIFEST"])
|
||||||
|
|
||||||
|
|
||||||
# Target for bundling core2 package for qFlipper
|
# Target for bundling core2 package for qFlipper
|
||||||
@@ -184,27 +196,15 @@ copro_dist = distenv.CoproBuilder(
|
|||||||
distenv.AlwaysBuild(copro_dist)
|
distenv.AlwaysBuild(copro_dist)
|
||||||
distenv.Alias("copro_dist", copro_dist)
|
distenv.Alias("copro_dist", copro_dist)
|
||||||
|
|
||||||
firmware_flash = distenv.AddOpenOCDFlashTarget(firmware_env)
|
|
||||||
|
firmware_flash = distenv.AddFwFlashTarget(firmware_env)
|
||||||
distenv.Alias("flash", firmware_flash)
|
distenv.Alias("flash", firmware_flash)
|
||||||
|
|
||||||
|
# To be implemented in fwflash.py
|
||||||
firmware_jflash = distenv.AddJFlashTarget(firmware_env)
|
firmware_jflash = distenv.AddJFlashTarget(firmware_env)
|
||||||
distenv.Alias("jflash", firmware_jflash)
|
distenv.Alias("jflash", firmware_jflash)
|
||||||
|
|
||||||
firmware_bm_flash = distenv.PhonyTarget(
|
distenv.PhonyTarget(
|
||||||
"flash_blackmagic",
|
|
||||||
"$GDB $GDBOPTS $SOURCES $GDBFLASH",
|
|
||||||
source=firmware_env["FW_ELF"],
|
|
||||||
GDBOPTS="${GDBOPTS_BASE} ${GDBOPTS_BLACKMAGIC}",
|
|
||||||
GDBREMOTE="${BLACKMAGIC_ADDR}",
|
|
||||||
GDBFLASH=[
|
|
||||||
"-ex",
|
|
||||||
"load",
|
|
||||||
"-ex",
|
|
||||||
"quit",
|
|
||||||
],
|
|
||||||
)
|
|
||||||
|
|
||||||
gdb_backtrace_all_threads = distenv.PhonyTarget(
|
|
||||||
"gdb_trace_all",
|
"gdb_trace_all",
|
||||||
"$GDB $GDBOPTS $SOURCES $GDBFLASH",
|
"$GDB $GDBOPTS $SOURCES $GDBFLASH",
|
||||||
source=firmware_env["FW_ELF"],
|
source=firmware_env["FW_ELF"],
|
||||||
@@ -323,9 +323,10 @@ distenv.PhonyTarget(
|
|||||||
)
|
)
|
||||||
|
|
||||||
# Start Flipper CLI via PySerial's miniterm
|
# Start Flipper CLI via PySerial's miniterm
|
||||||
distenv.PhonyTarget(
|
distenv.PhonyTarget("cli", "${PYTHON3} ${FBT_SCRIPT_DIR}/serial_cli.py -p ${FLIP_PORT}")
|
||||||
"cli", "${PYTHON3} ${FBT_SCRIPT_DIR}/serial_cli.py -p ${FLIP_PORT}"
|
|
||||||
)
|
# Update WiFi devboard firmware
|
||||||
|
distenv.PhonyTarget("devboard_flash", "${PYTHON3} ${FBT_SCRIPT_DIR}/wifi_board.py")
|
||||||
|
|
||||||
|
|
||||||
# Find blackmagic probe
|
# Find blackmagic probe
|
||||||
@@ -345,7 +346,14 @@ distenv.PhonyTarget(
|
|||||||
)
|
)
|
||||||
|
|
||||||
# Prepare vscode environment
|
# Prepare vscode environment
|
||||||
vscode_dist = distenv.Install("#.vscode", distenv.Glob("#.vscode/example/*"))
|
VSCODE_LANG_SERVER = cmd_environment["LANG_SERVER"]
|
||||||
|
vscode_dist = distenv.Install(
|
||||||
|
"#.vscode",
|
||||||
|
[
|
||||||
|
distenv.Glob("#.vscode/example/*.json"),
|
||||||
|
distenv.Glob(f"#.vscode/example/{VSCODE_LANG_SERVER}/*.json"),
|
||||||
|
],
|
||||||
|
)
|
||||||
distenv.Precious(vscode_dist)
|
distenv.Precious(vscode_dist)
|
||||||
distenv.NoClean(vscode_dist)
|
distenv.NoClean(vscode_dist)
|
||||||
distenv.Alias("vscode_dist", vscode_dist)
|
distenv.Alias("vscode_dist", vscode_dist)
|
||||||
|
|||||||
@@ -35,21 +35,6 @@ Applications for main Flipper menu.
|
|||||||
- `u2f` - U2F Application
|
- `u2f` - U2F Application
|
||||||
|
|
||||||
|
|
||||||
## External
|
|
||||||
|
|
||||||
External applications deployed to SD Card
|
|
||||||
|
|
||||||
- `clock` - Clock application
|
|
||||||
- `dap_link` - DAP Link OnChip debugger
|
|
||||||
- `hid_app` - USB/BT Remote controller
|
|
||||||
- `music_player` - Music player app (demo)
|
|
||||||
- `nfc_magic` - NFC MFC Magic card application
|
|
||||||
- `picopass` - Picopass reader / writer
|
|
||||||
- `signal_generator` - Signal generator app: PWM and clock generator
|
|
||||||
- `snake_game` - Snake game application
|
|
||||||
- `spi_mem_manager` - SPI Memory reader / flasher
|
|
||||||
- `weather_station` - SubGHz weather station
|
|
||||||
|
|
||||||
## services
|
## services
|
||||||
|
|
||||||
Background services providing system APIs to applications.
|
Background services providing system APIs to applications.
|
||||||
|
|||||||
@@ -174,7 +174,7 @@ bool WIEGAND::DoWiegandConversion() {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Handle validation failure case!
|
// TODO FL-3490: Handle validation failure case!
|
||||||
} else if(4 == _bitCount) {
|
} else if(4 == _bitCount) {
|
||||||
// 4-bit Wiegand codes have no data integrity check so we just
|
// 4-bit Wiegand codes have no data integrity check so we just
|
||||||
// read the LOW nibble.
|
// read the LOW nibble.
|
||||||
|
|||||||
16
applications/debug/ccid_test/application.fam
Normal file
16
applications/debug/ccid_test/application.fam
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
App(
|
||||||
|
appid="ccid_test",
|
||||||
|
name="CCID Debug",
|
||||||
|
apptype=FlipperAppType.DEBUG,
|
||||||
|
entry_point="ccid_test_app",
|
||||||
|
cdefines=["CCID_TEST"],
|
||||||
|
requires=[
|
||||||
|
"gui",
|
||||||
|
],
|
||||||
|
provides=[
|
||||||
|
"ccid_test",
|
||||||
|
],
|
||||||
|
stack_size=1 * 1024,
|
||||||
|
order=120,
|
||||||
|
fap_category="Debug",
|
||||||
|
)
|
||||||
169
applications/debug/ccid_test/ccid_test_app.c
Normal file
169
applications/debug/ccid_test/ccid_test_app.c
Normal file
@@ -0,0 +1,169 @@
|
|||||||
|
#include <stdint.h>
|
||||||
|
#include <furi.h>
|
||||||
|
#include <furi_hal.h>
|
||||||
|
|
||||||
|
#include <gui/view.h>
|
||||||
|
#include <gui/view_dispatcher.h>
|
||||||
|
#include <gui/modules/submenu.h>
|
||||||
|
#include <gui/gui.h>
|
||||||
|
|
||||||
|
#include "iso7816_t0_apdu.h"
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
EventTypeInput,
|
||||||
|
} EventType;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
Gui* gui;
|
||||||
|
ViewPort* view_port;
|
||||||
|
FuriMessageQueue* event_queue;
|
||||||
|
FuriHalUsbCcidConfig ccid_cfg;
|
||||||
|
} CcidTestApp;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
union {
|
||||||
|
InputEvent input;
|
||||||
|
};
|
||||||
|
EventType type;
|
||||||
|
} CcidTestAppEvent;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CcidTestSubmenuIndexInsertSmartcard,
|
||||||
|
CcidTestSubmenuIndexRemoveSmartcard,
|
||||||
|
CcidTestSubmenuIndexInsertSmartcardReader
|
||||||
|
} SubmenuIndex;
|
||||||
|
|
||||||
|
void icc_power_on_callback(uint8_t* atrBuffer, uint32_t* atrlen, void* context) {
|
||||||
|
UNUSED(context);
|
||||||
|
|
||||||
|
iso7816_answer_to_reset(atrBuffer, atrlen);
|
||||||
|
}
|
||||||
|
|
||||||
|
//dataBlock points to the buffer
|
||||||
|
//dataBlockLen tells reader how nany bytes should be read
|
||||||
|
void xfr_datablock_callback(
|
||||||
|
const uint8_t* dataBlock,
|
||||||
|
uint32_t dataBlockLen,
|
||||||
|
uint8_t* responseDataBlock,
|
||||||
|
uint32_t* responseDataBlockLen,
|
||||||
|
void* context) {
|
||||||
|
UNUSED(context);
|
||||||
|
|
||||||
|
struct ISO7816_Command_APDU commandAPDU;
|
||||||
|
iso7816_read_command_apdu(&commandAPDU, dataBlock, dataBlockLen);
|
||||||
|
|
||||||
|
struct ISO7816_Response_APDU responseAPDU;
|
||||||
|
//class not supported
|
||||||
|
responseAPDU.SW1 = 0x6E;
|
||||||
|
responseAPDU.SW2 = 0x00;
|
||||||
|
|
||||||
|
iso7816_write_response_apdu(&responseAPDU, responseDataBlock, responseDataBlockLen);
|
||||||
|
}
|
||||||
|
|
||||||
|
static const CcidCallbacks ccid_cb = {
|
||||||
|
icc_power_on_callback,
|
||||||
|
xfr_datablock_callback,
|
||||||
|
};
|
||||||
|
|
||||||
|
static void ccid_test_app_render_callback(Canvas* canvas, void* ctx) {
|
||||||
|
UNUSED(ctx);
|
||||||
|
canvas_clear(canvas);
|
||||||
|
|
||||||
|
canvas_set_font(canvas, FontPrimary);
|
||||||
|
canvas_draw_str(canvas, 0, 10, "CCID Test App");
|
||||||
|
|
||||||
|
canvas_set_font(canvas, FontSecondary);
|
||||||
|
canvas_draw_str(canvas, 0, 63, "Hold [back] to exit");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ccid_test_app_input_callback(InputEvent* input_event, void* ctx) {
|
||||||
|
FuriMessageQueue* event_queue = ctx;
|
||||||
|
|
||||||
|
CcidTestAppEvent event;
|
||||||
|
event.type = EventTypeInput;
|
||||||
|
event.input = *input_event;
|
||||||
|
furi_message_queue_put(event_queue, &event, FuriWaitForever);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t ccid_test_exit(void* context) {
|
||||||
|
UNUSED(context);
|
||||||
|
return VIEW_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
CcidTestApp* ccid_test_app_alloc() {
|
||||||
|
CcidTestApp* app = malloc(sizeof(CcidTestApp));
|
||||||
|
|
||||||
|
// Gui
|
||||||
|
app->gui = furi_record_open(RECORD_GUI);
|
||||||
|
|
||||||
|
//viewport
|
||||||
|
app->view_port = view_port_alloc();
|
||||||
|
gui_add_view_port(app->gui, app->view_port, GuiLayerFullscreen);
|
||||||
|
view_port_draw_callback_set(app->view_port, ccid_test_app_render_callback, NULL);
|
||||||
|
|
||||||
|
//message queue
|
||||||
|
app->event_queue = furi_message_queue_alloc(8, sizeof(CcidTestAppEvent));
|
||||||
|
furi_check(app->event_queue);
|
||||||
|
view_port_input_callback_set(app->view_port, ccid_test_app_input_callback, app->event_queue);
|
||||||
|
|
||||||
|
return app;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ccid_test_app_free(CcidTestApp* app) {
|
||||||
|
furi_assert(app);
|
||||||
|
|
||||||
|
//message queue
|
||||||
|
furi_message_queue_free(app->event_queue);
|
||||||
|
|
||||||
|
//view port
|
||||||
|
gui_remove_view_port(app->gui, app->view_port);
|
||||||
|
view_port_free(app->view_port);
|
||||||
|
|
||||||
|
// Close gui record
|
||||||
|
furi_record_close(RECORD_GUI);
|
||||||
|
app->gui = NULL;
|
||||||
|
|
||||||
|
// Free rest
|
||||||
|
free(app);
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t ccid_test_app(void* p) {
|
||||||
|
UNUSED(p);
|
||||||
|
|
||||||
|
//setup view
|
||||||
|
CcidTestApp* app = ccid_test_app_alloc();
|
||||||
|
|
||||||
|
//setup CCID USB
|
||||||
|
// On linux: set VID PID using: /usr/lib/pcsc/drivers/ifd-ccid.bundle/Contents/Info.plist
|
||||||
|
app->ccid_cfg.vid = 0x1234;
|
||||||
|
app->ccid_cfg.pid = 0x5678;
|
||||||
|
|
||||||
|
FuriHalUsbInterface* usb_mode_prev = furi_hal_usb_get_config();
|
||||||
|
furi_hal_usb_unlock();
|
||||||
|
furi_hal_ccid_set_callbacks((CcidCallbacks*)&ccid_cb);
|
||||||
|
furi_check(furi_hal_usb_set_config(&usb_ccid, &app->ccid_cfg) == true);
|
||||||
|
|
||||||
|
//handle button events
|
||||||
|
CcidTestAppEvent event;
|
||||||
|
while(1) {
|
||||||
|
FuriStatus event_status =
|
||||||
|
furi_message_queue_get(app->event_queue, &event, FuriWaitForever);
|
||||||
|
|
||||||
|
if(event_status == FuriStatusOk) {
|
||||||
|
if(event.type == EventTypeInput) {
|
||||||
|
if(event.input.type == InputTypeLong && event.input.key == InputKeyBack) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
view_port_update(app->view_port);
|
||||||
|
}
|
||||||
|
|
||||||
|
//tear down USB
|
||||||
|
furi_hal_usb_set_config(usb_mode_prev, NULL);
|
||||||
|
furi_hal_ccid_set_callbacks(NULL);
|
||||||
|
|
||||||
|
//teardown view
|
||||||
|
ccid_test_app_free(app);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
37
applications/debug/ccid_test/iso7816_t0_apdu.c
Normal file
37
applications/debug/ccid_test/iso7816_t0_apdu.c
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
/* Implements rudimentary iso7816-3 support for APDU (T=0) */
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <furi.h>
|
||||||
|
#include "iso7816_t0_apdu.h"
|
||||||
|
|
||||||
|
void iso7816_answer_to_reset(uint8_t* dataBuffer, uint32_t* atrlen) {
|
||||||
|
//minimum valid ATR: https://smartcard-atr.apdu.fr/parse?ATR=3B+00
|
||||||
|
uint8_t AtrBuffer[2] = {
|
||||||
|
0x3B, //TS (direct convention)
|
||||||
|
0x00 // T0 (Y(1): b0000, K: 0 (historical bytes))
|
||||||
|
};
|
||||||
|
*atrlen = 2;
|
||||||
|
|
||||||
|
memcpy(dataBuffer, AtrBuffer, sizeof(uint8_t) * (*atrlen));
|
||||||
|
}
|
||||||
|
|
||||||
|
void iso7816_read_command_apdu(
|
||||||
|
struct ISO7816_Command_APDU* command,
|
||||||
|
const uint8_t* dataBuffer,
|
||||||
|
uint32_t dataLen) {
|
||||||
|
UNUSED(dataLen);
|
||||||
|
command->CLA = dataBuffer[0];
|
||||||
|
command->INS = dataBuffer[1];
|
||||||
|
command->P1 = dataBuffer[2];
|
||||||
|
command->P2 = dataBuffer[3];
|
||||||
|
command->Lc = dataBuffer[4];
|
||||||
|
}
|
||||||
|
|
||||||
|
void iso7816_write_response_apdu(
|
||||||
|
const struct ISO7816_Response_APDU* response,
|
||||||
|
uint8_t* dataBuffer,
|
||||||
|
uint32_t* dataLen) {
|
||||||
|
dataBuffer[0] = response->SW1;
|
||||||
|
dataBuffer[1] = response->SW2;
|
||||||
|
*dataLen = 2;
|
||||||
|
}
|
||||||
32
applications/debug/ccid_test/iso7816_t0_apdu.h
Normal file
32
applications/debug/ccid_test/iso7816_t0_apdu.h
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
#ifndef _ISO7816_T0_APDU_H_
|
||||||
|
#define _ISO7816_T0_APDU_H_
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
struct ISO7816_Command_APDU {
|
||||||
|
//header
|
||||||
|
uint8_t CLA;
|
||||||
|
uint8_t INS;
|
||||||
|
uint8_t P1;
|
||||||
|
uint8_t P2;
|
||||||
|
|
||||||
|
//body
|
||||||
|
uint8_t Lc;
|
||||||
|
uint8_t Le;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
struct ISO7816_Response_APDU {
|
||||||
|
uint8_t SW1;
|
||||||
|
uint8_t SW2;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
void iso7816_answer_to_reset(uint8_t* atrBuffer, uint32_t* atrlen);
|
||||||
|
void iso7816_read_command_apdu(
|
||||||
|
struct ISO7816_Command_APDU* command,
|
||||||
|
const uint8_t* dataBuffer,
|
||||||
|
uint32_t dataLen);
|
||||||
|
void iso7816_write_response_apdu(
|
||||||
|
const struct ISO7816_Response_APDU* response,
|
||||||
|
uint8_t* dataBuffer,
|
||||||
|
uint32_t* dataLen);
|
||||||
|
#endif //_ISO7816_T0_APDU_H_
|
||||||
@@ -71,7 +71,7 @@ static void direct_draw_run(DirectDraw* instance) {
|
|||||||
size_t counter = 0;
|
size_t counter = 0;
|
||||||
float fps = 0;
|
float fps = 0;
|
||||||
|
|
||||||
vTaskPrioritySet(furi_thread_get_current_id(), FuriThreadPriorityIdle);
|
furi_thread_set_current_priority(FuriThreadPriorityIdle);
|
||||||
|
|
||||||
do {
|
do {
|
||||||
size_t elapsed = DWT->CYCCNT - start;
|
size_t elapsed = DWT->CYCCNT - start;
|
||||||
|
|||||||
@@ -21,22 +21,51 @@ static void rpc_debug_app_tick_event_callback(void* context) {
|
|||||||
scene_manager_handle_tick_event(app->scene_manager);
|
scene_manager_handle_tick_event(app->scene_manager);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void rpc_debug_app_rpc_command_callback(RpcAppSystemEvent event, void* context) {
|
static void
|
||||||
|
rpc_debug_app_format_hex(const uint8_t* data, size_t data_size, char* buf, size_t buf_size) {
|
||||||
|
if(data == NULL || data_size == 0) {
|
||||||
|
strncpy(buf, "<Data empty>", buf_size);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const size_t byte_width = 3;
|
||||||
|
const size_t line_width = 7;
|
||||||
|
|
||||||
|
data_size = MIN(data_size, buf_size / (byte_width + 1));
|
||||||
|
|
||||||
|
for(size_t i = 0; i < data_size; ++i) {
|
||||||
|
char* p = buf + (i * byte_width);
|
||||||
|
char sep = !((i + 1) % line_width) ? '\n' : ' ';
|
||||||
|
snprintf(p, byte_width + 1, "%02X%c", data[i], sep);
|
||||||
|
}
|
||||||
|
|
||||||
|
buf[buf_size - 1] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
static void rpc_debug_app_rpc_command_callback(const RpcAppSystemEvent* event, void* context) {
|
||||||
furi_assert(context);
|
furi_assert(context);
|
||||||
RpcDebugApp* app = context;
|
RpcDebugApp* app = context;
|
||||||
furi_assert(app->rpc);
|
furi_assert(app->rpc);
|
||||||
|
|
||||||
if(event == RpcAppEventSessionClose) {
|
if(event->type == RpcAppEventTypeSessionClose) {
|
||||||
scene_manager_stop(app->scene_manager);
|
scene_manager_stop(app->scene_manager);
|
||||||
view_dispatcher_stop(app->view_dispatcher);
|
view_dispatcher_stop(app->view_dispatcher);
|
||||||
rpc_system_app_set_callback(app->rpc, NULL, NULL);
|
rpc_system_app_set_callback(app->rpc, NULL, NULL);
|
||||||
app->rpc = NULL;
|
app->rpc = NULL;
|
||||||
} else if(event == RpcAppEventAppExit) {
|
} else if(event->type == RpcAppEventTypeAppExit) {
|
||||||
scene_manager_stop(app->scene_manager);
|
scene_manager_stop(app->scene_manager);
|
||||||
view_dispatcher_stop(app->view_dispatcher);
|
view_dispatcher_stop(app->view_dispatcher);
|
||||||
rpc_system_app_confirm(app->rpc, RpcAppEventAppExit, true);
|
rpc_system_app_confirm(app->rpc, true);
|
||||||
|
} else if(event->type == RpcAppEventTypeDataExchange) {
|
||||||
|
furi_assert(event->data.type == RpcAppSystemEventDataTypeBytes);
|
||||||
|
|
||||||
|
rpc_debug_app_format_hex(
|
||||||
|
event->data.bytes.ptr, event->data.bytes.size, app->text_store, TEXT_STORE_SIZE);
|
||||||
|
|
||||||
|
view_dispatcher_send_custom_event(
|
||||||
|
app->view_dispatcher, RpcDebugAppCustomEventRpcDataExchange);
|
||||||
} else {
|
} else {
|
||||||
rpc_system_app_confirm(app->rpc, event, false);
|
rpc_system_app_confirm(app->rpc, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,40 +1,5 @@
|
|||||||
#include "../rpc_debug_app.h"
|
#include "../rpc_debug_app.h"
|
||||||
|
|
||||||
static void rpc_debug_app_scene_start_format_hex(
|
|
||||||
const uint8_t* data,
|
|
||||||
size_t data_size,
|
|
||||||
char* buf,
|
|
||||||
size_t buf_size) {
|
|
||||||
furi_assert(data);
|
|
||||||
furi_assert(buf);
|
|
||||||
|
|
||||||
const size_t byte_width = 3;
|
|
||||||
const size_t line_width = 7;
|
|
||||||
|
|
||||||
data_size = MIN(data_size, buf_size / (byte_width + 1));
|
|
||||||
|
|
||||||
for(size_t i = 0; i < data_size; ++i) {
|
|
||||||
char* p = buf + (i * byte_width);
|
|
||||||
char sep = !((i + 1) % line_width) ? '\n' : ' ';
|
|
||||||
snprintf(p, byte_width + 1, "%02X%c", data[i], sep);
|
|
||||||
}
|
|
||||||
|
|
||||||
buf[buf_size - 1] = '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
static void rpc_debug_app_scene_receive_data_exchange_callback(
|
|
||||||
const uint8_t* data,
|
|
||||||
size_t data_size,
|
|
||||||
void* context) {
|
|
||||||
RpcDebugApp* app = context;
|
|
||||||
if(data) {
|
|
||||||
rpc_debug_app_scene_start_format_hex(data, data_size, app->text_store, TEXT_STORE_SIZE);
|
|
||||||
} else {
|
|
||||||
strncpy(app->text_store, "<Data empty>", TEXT_STORE_SIZE);
|
|
||||||
}
|
|
||||||
view_dispatcher_send_custom_event(app->view_dispatcher, RpcDebugAppCustomEventRpcDataExchange);
|
|
||||||
}
|
|
||||||
|
|
||||||
void rpc_debug_app_scene_receive_data_exchange_on_enter(void* context) {
|
void rpc_debug_app_scene_receive_data_exchange_on_enter(void* context) {
|
||||||
RpcDebugApp* app = context;
|
RpcDebugApp* app = context;
|
||||||
strncpy(app->text_store, "Received data will appear here...", TEXT_STORE_SIZE);
|
strncpy(app->text_store, "Received data will appear here...", TEXT_STORE_SIZE);
|
||||||
@@ -42,8 +7,6 @@ void rpc_debug_app_scene_receive_data_exchange_on_enter(void* context) {
|
|||||||
text_box_set_text(app->text_box, app->text_store);
|
text_box_set_text(app->text_box, app->text_store);
|
||||||
text_box_set_font(app->text_box, TextBoxFontHex);
|
text_box_set_font(app->text_box, TextBoxFontHex);
|
||||||
|
|
||||||
rpc_system_app_set_data_exchange_callback(
|
|
||||||
app->rpc, rpc_debug_app_scene_receive_data_exchange_callback, app);
|
|
||||||
view_dispatcher_switch_to_view(app->view_dispatcher, RpcDebugAppViewTextBox);
|
view_dispatcher_switch_to_view(app->view_dispatcher, RpcDebugAppViewTextBox);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -53,6 +16,7 @@ bool rpc_debug_app_scene_receive_data_exchange_on_event(void* context, SceneMana
|
|||||||
|
|
||||||
if(event.type == SceneManagerEventTypeCustom) {
|
if(event.type == SceneManagerEventTypeCustom) {
|
||||||
if(event.event == RpcDebugAppCustomEventRpcDataExchange) {
|
if(event.event == RpcDebugAppCustomEventRpcDataExchange) {
|
||||||
|
rpc_system_app_confirm(app->rpc, true);
|
||||||
notification_message(app->notifications, &sequence_blink_cyan_100);
|
notification_message(app->notifications, &sequence_blink_cyan_100);
|
||||||
notification_message(app->notifications, &sequence_display_backlight_on);
|
notification_message(app->notifications, &sequence_display_backlight_on);
|
||||||
text_box_set_text(app->text_box, app->text_store);
|
text_box_set_text(app->text_box, app->text_store);
|
||||||
@@ -66,5 +30,4 @@ bool rpc_debug_app_scene_receive_data_exchange_on_event(void* context, SceneMana
|
|||||||
void rpc_debug_app_scene_receive_data_exchange_on_exit(void* context) {
|
void rpc_debug_app_scene_receive_data_exchange_on_exit(void* context) {
|
||||||
RpcDebugApp* app = context;
|
RpcDebugApp* app = context;
|
||||||
text_box_reset(app->text_box);
|
text_box_reset(app->text_box);
|
||||||
rpc_system_app_set_data_exchange_callback(app->rpc, NULL, NULL);
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -56,7 +56,6 @@ static void subghz_test_packet_rx_callback(bool level, uint32_t duration, void*
|
|||||||
subghz_decoder_princeton_for_testing_parse(instance->decoder, level, duration);
|
subghz_decoder_princeton_for_testing_parse(instance->decoder, level, duration);
|
||||||
}
|
}
|
||||||
|
|
||||||
//todo
|
|
||||||
static void subghz_test_packet_rx_pt_callback(SubGhzDecoderPrinceton* parser, void* context) {
|
static void subghz_test_packet_rx_pt_callback(SubGhzDecoderPrinceton* parser, void* context) {
|
||||||
UNUSED(parser);
|
UNUSED(parser);
|
||||||
furi_assert(context);
|
furi_assert(context);
|
||||||
|
|||||||
@@ -3,7 +3,9 @@ App(
|
|||||||
apptype=FlipperAppType.STARTUP,
|
apptype=FlipperAppType.STARTUP,
|
||||||
entry_point="unit_tests_on_system_start",
|
entry_point="unit_tests_on_system_start",
|
||||||
cdefines=["APP_UNIT_TESTS"],
|
cdefines=["APP_UNIT_TESTS"],
|
||||||
|
requires=["system_settings"],
|
||||||
provides=["delay_test"],
|
provides=["delay_test"],
|
||||||
|
resources="resources",
|
||||||
order=100,
|
order=100,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ void bt_test_alloc() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void bt_test_free() {
|
void bt_test_free() {
|
||||||
furi_assert(bt_test);
|
furi_check(bt_test);
|
||||||
free(bt_test->nvm_ram_buff_ref);
|
free(bt_test->nvm_ram_buff_ref);
|
||||||
free(bt_test->nvm_ram_buff_dut);
|
free(bt_test->nvm_ram_buff_dut);
|
||||||
bt_keys_storage_free(bt_test->bt_keys_storage);
|
bt_keys_storage_free(bt_test->bt_keys_storage);
|
||||||
@@ -89,7 +89,7 @@ static void bt_test_keys_remove_test_file() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
MU_TEST(bt_test_keys_storage_serial_profile) {
|
MU_TEST(bt_test_keys_storage_serial_profile) {
|
||||||
furi_assert(bt_test);
|
furi_check(bt_test);
|
||||||
|
|
||||||
bt_test_keys_remove_test_file();
|
bt_test_keys_remove_test_file();
|
||||||
bt_test_keys_storage_profile();
|
bt_test_keys_storage_profile();
|
||||||
|
|||||||
@@ -26,7 +26,6 @@ void test_furi_memmgr() {
|
|||||||
mu_assert_int_eq(66, ((uint8_t*)ptr)[i]);
|
mu_assert_int_eq(66, ((uint8_t*)ptr)[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: fix realloc to copy only old size, and write testcase that leftover of reallocated memory is zero-initialized
|
|
||||||
free(ptr);
|
free(ptr);
|
||||||
|
|
||||||
// allocate and zero-initialize array (calloc)
|
// allocate and zero-initialize array (calloc)
|
||||||
|
|||||||
@@ -69,7 +69,7 @@ MU_TEST(mu_test_furi_string_mem) {
|
|||||||
mu_check(string != NULL);
|
mu_check(string != NULL);
|
||||||
mu_check(!furi_string_empty(string));
|
mu_check(!furi_string_empty(string));
|
||||||
|
|
||||||
// TODO: how to test furi_string_reserve?
|
// TODO FL-3493: how to test furi_string_reserve?
|
||||||
|
|
||||||
// test furi_string_reset
|
// test furi_string_reset
|
||||||
furi_string_reset(string);
|
furi_string_reset(string);
|
||||||
|
|||||||
602
applications/debug/unit_tests/furi_hal/furi_hal_crypto_tests.c
Normal file
602
applications/debug/unit_tests/furi_hal/furi_hal_crypto_tests.c
Normal file
@@ -0,0 +1,602 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <furi.h>
|
||||||
|
#include <furi_hal.h>
|
||||||
|
#include "../minunit.h"
|
||||||
|
|
||||||
|
static const uint8_t key_ctr_1[32] = {
|
||||||
|
0x77, 0x6B, 0xEF, 0xF2, 0x85, 0x1D, 0xB0, 0x6F, 0x4C, 0x8A, 0x05, 0x42, 0xC8, 0x69, 0x6F, 0x6C,
|
||||||
|
0x6A, 0x81, 0xAF, 0x1E, 0xEC, 0x96, 0xB4, 0xD3, 0x7F, 0xC1, 0xD6, 0x89, 0xE6, 0xC1, 0xC1, 0x04,
|
||||||
|
};
|
||||||
|
static const uint8_t iv_ctr_1[16] = {
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x60,
|
||||||
|
0xDB,
|
||||||
|
0x56,
|
||||||
|
0x72,
|
||||||
|
0xC9,
|
||||||
|
0x7A,
|
||||||
|
0xA8,
|
||||||
|
0xF0,
|
||||||
|
0xB2,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x01,
|
||||||
|
};
|
||||||
|
static const uint8_t pt_ctr_1[16] = {
|
||||||
|
0x53,
|
||||||
|
0x69,
|
||||||
|
0x6E,
|
||||||
|
0x67,
|
||||||
|
0x6C,
|
||||||
|
0x65,
|
||||||
|
0x20,
|
||||||
|
0x62,
|
||||||
|
0x6C,
|
||||||
|
0x6F,
|
||||||
|
0x63,
|
||||||
|
0x6B,
|
||||||
|
0x20,
|
||||||
|
0x6D,
|
||||||
|
0x73,
|
||||||
|
0x67,
|
||||||
|
};
|
||||||
|
static const uint8_t tv_ctr_ct_1[16] = {
|
||||||
|
0x14,
|
||||||
|
0x5A,
|
||||||
|
0xD0,
|
||||||
|
0x1D,
|
||||||
|
0xBF,
|
||||||
|
0x82,
|
||||||
|
0x4E,
|
||||||
|
0xC7,
|
||||||
|
0x56,
|
||||||
|
0x08,
|
||||||
|
0x63,
|
||||||
|
0xDC,
|
||||||
|
0x71,
|
||||||
|
0xE3,
|
||||||
|
0xE0,
|
||||||
|
0xC0,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t key_ctr_2[32] = {
|
||||||
|
0x77, 0x6B, 0xEF, 0xF2, 0x85, 0x1D, 0xB0, 0x6F, 0x4C, 0x8A, 0x05, 0x42, 0xC8, 0x69, 0x6F, 0x6C,
|
||||||
|
0x6A, 0x81, 0xAF, 0x1E, 0xEC, 0x96, 0xB4, 0xD3, 0x7F, 0xC1, 0xD6, 0x89, 0xE6, 0xC1, 0xC1, 0x04,
|
||||||
|
};
|
||||||
|
static const uint8_t iv_ctr_2[16] = {
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x60,
|
||||||
|
0xDB,
|
||||||
|
0x56,
|
||||||
|
0x72,
|
||||||
|
0xC9,
|
||||||
|
0x7A,
|
||||||
|
0xA8,
|
||||||
|
0xF0,
|
||||||
|
0xB2,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x01,
|
||||||
|
};
|
||||||
|
static const uint8_t pt_ctr_2[0] = {};
|
||||||
|
//static const uint8_t tv_ctr_ct_2[0] = {};
|
||||||
|
|
||||||
|
static const uint8_t key_ctr_3[32] = {
|
||||||
|
0xF6, 0xD6, 0x6D, 0x6B, 0xD5, 0x2D, 0x59, 0xBB, 0x07, 0x96, 0x36, 0x58, 0x79, 0xEF, 0xF8, 0x86,
|
||||||
|
0xC6, 0x6D, 0xD5, 0x1A, 0x5B, 0x6A, 0x99, 0x74, 0x4B, 0x50, 0x59, 0x0C, 0x87, 0xA2, 0x38, 0x84,
|
||||||
|
};
|
||||||
|
static const uint8_t iv_ctr_3[16] = {
|
||||||
|
0x00,
|
||||||
|
0xFA,
|
||||||
|
0xAC,
|
||||||
|
0x24,
|
||||||
|
0xC1,
|
||||||
|
0x58,
|
||||||
|
0x5E,
|
||||||
|
0xF1,
|
||||||
|
0x5A,
|
||||||
|
0x43,
|
||||||
|
0xD8,
|
||||||
|
0x75,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x01,
|
||||||
|
};
|
||||||
|
static const uint8_t pt_ctr_3[32] = {
|
||||||
|
0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F,
|
||||||
|
0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F,
|
||||||
|
};
|
||||||
|
static const uint8_t tv_ctr_ct_3[32] = {
|
||||||
|
0xF0, 0x5E, 0x23, 0x1B, 0x38, 0x94, 0x61, 0x2C, 0x49, 0xEE, 0x00, 0x0B, 0x80, 0x4E, 0xB2, 0xA9,
|
||||||
|
0xB8, 0x30, 0x6B, 0x50, 0x8F, 0x83, 0x9D, 0x6A, 0x55, 0x30, 0x83, 0x1D, 0x93, 0x44, 0xAF, 0x1C,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t key_ctr_4[32] = {
|
||||||
|
0xFF, 0x7A, 0x61, 0x7C, 0xE6, 0x91, 0x48, 0xE4, 0xF1, 0x72, 0x6E, 0x2F, 0x43, 0x58, 0x1D, 0xE2,
|
||||||
|
0xAA, 0x62, 0xD9, 0xF8, 0x05, 0x53, 0x2E, 0xDF, 0xF1, 0xEE, 0xD6, 0x87, 0xFB, 0x54, 0x15, 0x3D,
|
||||||
|
};
|
||||||
|
static const uint8_t iv_ctr_4[16] = {
|
||||||
|
0x00,
|
||||||
|
0x1C,
|
||||||
|
0xC5,
|
||||||
|
0xB7,
|
||||||
|
0x51,
|
||||||
|
0xA5,
|
||||||
|
0x1D,
|
||||||
|
0x70,
|
||||||
|
0xA1,
|
||||||
|
0xC1,
|
||||||
|
0x11,
|
||||||
|
0x48,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x01,
|
||||||
|
};
|
||||||
|
static const uint8_t pt_ctr_4[36] = {
|
||||||
|
0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B,
|
||||||
|
0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
|
||||||
|
0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F, 0x20, 0x21, 0x22, 0x23,
|
||||||
|
};
|
||||||
|
static const uint8_t tv_ctr_ct_4[36] = {
|
||||||
|
0xEB, 0x6C, 0x52, 0x82, 0x1D, 0x0B, 0xBB, 0xF7, 0xCE, 0x75, 0x94, 0x46,
|
||||||
|
0x2A, 0xCA, 0x4F, 0xAA, 0xB4, 0x07, 0xDF, 0x86, 0x65, 0x69, 0xFD, 0x07,
|
||||||
|
0xF4, 0x8C, 0xC0, 0xB5, 0x83, 0xD6, 0x07, 0x1F, 0x1E, 0xC0, 0xE6, 0xB8,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t key_ctr_5[32] = {
|
||||||
|
0xFF, 0x7A, 0x61, 0x7C, 0xE6, 0x91, 0x48, 0xE4, 0xF1, 0x72, 0x6E, 0x2F, 0x43, 0x58, 0x1D, 0xE2,
|
||||||
|
0xAA, 0x62, 0xD9, 0xF8, 0x05, 0x53, 0x2E, 0xDF, 0xF1, 0xEE, 0xD6, 0x87, 0xFB, 0x54, 0x15, 0x3D,
|
||||||
|
};
|
||||||
|
static const uint8_t iv_ctr_5[16] = {
|
||||||
|
0x00,
|
||||||
|
0x1C,
|
||||||
|
0xC5,
|
||||||
|
0xB7,
|
||||||
|
0x51,
|
||||||
|
0xA5,
|
||||||
|
0x1D,
|
||||||
|
0x70,
|
||||||
|
0xA1,
|
||||||
|
0xC1,
|
||||||
|
0x11,
|
||||||
|
0x48,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x01,
|
||||||
|
};
|
||||||
|
static const uint8_t pt_ctr_5[0] = {};
|
||||||
|
//static const uint8_t tv_ctr_ct_5[0] = {};
|
||||||
|
|
||||||
|
static const uint8_t key_gcm_1[32] = {
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
};
|
||||||
|
static const uint8_t iv_gcm_1[16] = {
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
};
|
||||||
|
static const uint8_t pt_gcm_1[0] = {};
|
||||||
|
//static const uint8_t tv_gcm_ct_1[0] = {};
|
||||||
|
static const uint8_t aad_gcm_1[0] = {};
|
||||||
|
static const uint8_t tv_gcm_tag_1[16] = {
|
||||||
|
0x53,
|
||||||
|
0x0F,
|
||||||
|
0x8A,
|
||||||
|
0xFB,
|
||||||
|
0xC7,
|
||||||
|
0x45,
|
||||||
|
0x36,
|
||||||
|
0xB9,
|
||||||
|
0xA9,
|
||||||
|
0x63,
|
||||||
|
0xB4,
|
||||||
|
0xF1,
|
||||||
|
0xC4,
|
||||||
|
0xCB,
|
||||||
|
0x73,
|
||||||
|
0x8B,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t key_gcm_2[32] = {
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
};
|
||||||
|
static const uint8_t iv_gcm_2[16] = {
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
};
|
||||||
|
static const uint8_t pt_gcm_2[16] = {
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
};
|
||||||
|
static const uint8_t tv_gcm_ct_2[16] = {
|
||||||
|
0xCE,
|
||||||
|
0xA7,
|
||||||
|
0x40,
|
||||||
|
0x3D,
|
||||||
|
0x4D,
|
||||||
|
0x60,
|
||||||
|
0x6B,
|
||||||
|
0x6E,
|
||||||
|
0x07,
|
||||||
|
0x4E,
|
||||||
|
0xC5,
|
||||||
|
0xD3,
|
||||||
|
0xBA,
|
||||||
|
0xF3,
|
||||||
|
0x9D,
|
||||||
|
0x18,
|
||||||
|
};
|
||||||
|
static const uint8_t aad_gcm_2[0] = {};
|
||||||
|
static const uint8_t tv_gcm_tag_2[16] = {
|
||||||
|
0xD0,
|
||||||
|
0xD1,
|
||||||
|
0xC8,
|
||||||
|
0xA7,
|
||||||
|
0x99,
|
||||||
|
0x99,
|
||||||
|
0x6B,
|
||||||
|
0xF0,
|
||||||
|
0x26,
|
||||||
|
0x5B,
|
||||||
|
0x98,
|
||||||
|
0xB5,
|
||||||
|
0xD4,
|
||||||
|
0x8A,
|
||||||
|
0xB9,
|
||||||
|
0x19,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t key_gcm_3[32] = {
|
||||||
|
0xFE, 0xFF, 0xE9, 0x92, 0x86, 0x65, 0x73, 0x1C, 0x6D, 0x6A, 0x8F, 0x94, 0x67, 0x30, 0x83, 0x08,
|
||||||
|
0xFE, 0xFF, 0xE9, 0x92, 0x86, 0x65, 0x73, 0x1C, 0x6D, 0x6A, 0x8F, 0x94, 0x67, 0x30, 0x83, 0x08,
|
||||||
|
};
|
||||||
|
static const uint8_t iv_gcm_3[16] = {
|
||||||
|
0xCA,
|
||||||
|
0xFE,
|
||||||
|
0xBA,
|
||||||
|
0xBE,
|
||||||
|
0xFA,
|
||||||
|
0xCE,
|
||||||
|
0xDB,
|
||||||
|
0xAD,
|
||||||
|
0xDE,
|
||||||
|
0xCA,
|
||||||
|
0xF8,
|
||||||
|
0x88,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
};
|
||||||
|
static const uint8_t pt_gcm_3[64] = {
|
||||||
|
0xD9, 0x31, 0x32, 0x25, 0xF8, 0x84, 0x06, 0xE5, 0xA5, 0x59, 0x09, 0xC5, 0xAF, 0xF5, 0x26, 0x9A,
|
||||||
|
0x86, 0xA7, 0xA9, 0x53, 0x15, 0x34, 0xF7, 0xDA, 0x2E, 0x4C, 0x30, 0x3D, 0x8A, 0x31, 0x8A, 0x72,
|
||||||
|
0x1C, 0x3C, 0x0C, 0x95, 0x95, 0x68, 0x09, 0x53, 0x2F, 0xCF, 0x0E, 0x24, 0x49, 0xA6, 0xB5, 0x25,
|
||||||
|
0xB1, 0x6A, 0xED, 0xF5, 0xAA, 0x0D, 0xE6, 0x57, 0xBA, 0x63, 0x7B, 0x39, 0x1A, 0xAF, 0xD2, 0x55,
|
||||||
|
};
|
||||||
|
static const uint8_t tv_gcm_ct_3[64] = {
|
||||||
|
0x52, 0x2D, 0xC1, 0xF0, 0x99, 0x56, 0x7D, 0x07, 0xF4, 0x7F, 0x37, 0xA3, 0x2A, 0x84, 0x42, 0x7D,
|
||||||
|
0x64, 0x3A, 0x8C, 0xDC, 0xBF, 0xE5, 0xC0, 0xC9, 0x75, 0x98, 0xA2, 0xBD, 0x25, 0x55, 0xD1, 0xAA,
|
||||||
|
0x8C, 0xB0, 0x8E, 0x48, 0x59, 0x0D, 0xBB, 0x3D, 0xA7, 0xB0, 0x8B, 0x10, 0x56, 0x82, 0x88, 0x38,
|
||||||
|
0xC5, 0xF6, 0x1E, 0x63, 0x93, 0xBA, 0x7A, 0x0A, 0xBC, 0xC9, 0xF6, 0x62, 0x89, 0x80, 0x15, 0xAD,
|
||||||
|
};
|
||||||
|
static const uint8_t aad_gcm_3[0] = {};
|
||||||
|
static const uint8_t tv_gcm_tag_3[16] = {
|
||||||
|
0xB0,
|
||||||
|
0x94,
|
||||||
|
0xDA,
|
||||||
|
0xC5,
|
||||||
|
0xD9,
|
||||||
|
0x34,
|
||||||
|
0x71,
|
||||||
|
0xBD,
|
||||||
|
0xEC,
|
||||||
|
0x1A,
|
||||||
|
0x50,
|
||||||
|
0x22,
|
||||||
|
0x70,
|
||||||
|
0xE3,
|
||||||
|
0xCC,
|
||||||
|
0x6C,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t key_gcm_4[32] = {
|
||||||
|
0xFE, 0xFF, 0xE9, 0x92, 0x86, 0x65, 0x73, 0x1C, 0x6D, 0x6A, 0x8F, 0x94, 0x67, 0x30, 0x83, 0x08,
|
||||||
|
0xFE, 0xFF, 0xE9, 0x92, 0x86, 0x65, 0x73, 0x1C, 0x6D, 0x6A, 0x8F, 0x94, 0x67, 0x30, 0x83, 0x08,
|
||||||
|
};
|
||||||
|
static const uint8_t iv_gcm_4[16] = {
|
||||||
|
0xCA,
|
||||||
|
0xFE,
|
||||||
|
0xBA,
|
||||||
|
0xBE,
|
||||||
|
0xFA,
|
||||||
|
0xCE,
|
||||||
|
0xDB,
|
||||||
|
0xAD,
|
||||||
|
0xDE,
|
||||||
|
0xCA,
|
||||||
|
0xF8,
|
||||||
|
0x88,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
};
|
||||||
|
static const uint8_t pt_gcm_4[60] = {
|
||||||
|
0xD9, 0x31, 0x32, 0x25, 0xF8, 0x84, 0x06, 0xE5, 0xA5, 0x59, 0x09, 0xC5, 0xAF, 0xF5, 0x26,
|
||||||
|
0x9A, 0x86, 0xA7, 0xA9, 0x53, 0x15, 0x34, 0xF7, 0xDA, 0x2E, 0x4C, 0x30, 0x3D, 0x8A, 0x31,
|
||||||
|
0x8A, 0x72, 0x1C, 0x3C, 0x0C, 0x95, 0x95, 0x68, 0x09, 0x53, 0x2F, 0xCF, 0x0E, 0x24, 0x49,
|
||||||
|
0xA6, 0xB5, 0x25, 0xB1, 0x6A, 0xED, 0xF5, 0xAA, 0x0D, 0xE6, 0x57, 0xBA, 0x63, 0x7B, 0x39,
|
||||||
|
};
|
||||||
|
static const uint8_t tv_gcm_ct_4[60] = {
|
||||||
|
0x52, 0x2D, 0xC1, 0xF0, 0x99, 0x56, 0x7D, 0x07, 0xF4, 0x7F, 0x37, 0xA3, 0x2A, 0x84, 0x42,
|
||||||
|
0x7D, 0x64, 0x3A, 0x8C, 0xDC, 0xBF, 0xE5, 0xC0, 0xC9, 0x75, 0x98, 0xA2, 0xBD, 0x25, 0x55,
|
||||||
|
0xD1, 0xAA, 0x8C, 0xB0, 0x8E, 0x48, 0x59, 0x0D, 0xBB, 0x3D, 0xA7, 0xB0, 0x8B, 0x10, 0x56,
|
||||||
|
0x82, 0x88, 0x38, 0xC5, 0xF6, 0x1E, 0x63, 0x93, 0xBA, 0x7A, 0x0A, 0xBC, 0xC9, 0xF6, 0x62,
|
||||||
|
};
|
||||||
|
static const uint8_t aad_gcm_4[20] = {
|
||||||
|
0xFE, 0xED, 0xFA, 0xCE, 0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED,
|
||||||
|
0xFA, 0xCE, 0xDE, 0xAD, 0xBE, 0xEF, 0xAB, 0xAD, 0xDA, 0xD2,
|
||||||
|
};
|
||||||
|
static const uint8_t tv_gcm_tag_4[16] = {
|
||||||
|
0x76,
|
||||||
|
0xFC,
|
||||||
|
0x6E,
|
||||||
|
0xCE,
|
||||||
|
0x0F,
|
||||||
|
0x4E,
|
||||||
|
0x17,
|
||||||
|
0x68,
|
||||||
|
0xCD,
|
||||||
|
0xDF,
|
||||||
|
0x88,
|
||||||
|
0x53,
|
||||||
|
0xBB,
|
||||||
|
0x2D,
|
||||||
|
0x55,
|
||||||
|
0x1B,
|
||||||
|
};
|
||||||
|
|
||||||
|
static void furi_hal_crypto_ctr_setup() {
|
||||||
|
}
|
||||||
|
|
||||||
|
static void furi_hal_crypto_ctr_teardown() {
|
||||||
|
}
|
||||||
|
|
||||||
|
static void furi_hal_crypto_gcm_setup() {
|
||||||
|
}
|
||||||
|
|
||||||
|
static void furi_hal_crypto_gcm_teardown() {
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_crypto_ctr_1) {
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t ct[sizeof(pt_ctr_1)];
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_ctr(key_ctr_1, iv_ctr_1, pt_ctr_1, ct, sizeof(pt_ctr_1));
|
||||||
|
mu_assert(ret, "CTR 1 failed");
|
||||||
|
mu_assert_mem_eq(tv_ctr_ct_1, ct, sizeof(pt_ctr_1));
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_crypto_ctr_2) {
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t ct[sizeof(pt_ctr_2)];
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_ctr(key_ctr_2, iv_ctr_2, pt_ctr_2, ct, sizeof(pt_ctr_2));
|
||||||
|
mu_assert(ret, "CTR 2 failed");
|
||||||
|
//mu_assert_mem_eq(tv_ctr_ct_2, ct, sizeof(pt_ctr_2));
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_crypto_ctr_3) {
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t ct[sizeof(pt_ctr_3)];
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_ctr(key_ctr_3, iv_ctr_3, pt_ctr_3, ct, sizeof(pt_ctr_3));
|
||||||
|
mu_assert(ret, "CTR 3 failed");
|
||||||
|
mu_assert_mem_eq(tv_ctr_ct_3, ct, sizeof(pt_ctr_3));
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_crypto_ctr_4) {
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t ct[sizeof(pt_ctr_4)];
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_ctr(key_ctr_4, iv_ctr_4, pt_ctr_4, ct, sizeof(pt_ctr_4));
|
||||||
|
mu_assert(ret, "CTR 4 failed");
|
||||||
|
mu_assert_mem_eq(tv_ctr_ct_4, ct, sizeof(pt_ctr_4));
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_crypto_ctr_5) {
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t ct[sizeof(pt_ctr_5)];
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_ctr(key_ctr_5, iv_ctr_5, pt_ctr_5, ct, sizeof(pt_ctr_5));
|
||||||
|
mu_assert(ret, "CTR 5 failed");
|
||||||
|
//mu_assert_mem_eq(tv_ctr_ct_5, ct, sizeof(pt_ctr_5));
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_crypto_gcm_1) {
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t pt[sizeof(pt_gcm_1)];
|
||||||
|
uint8_t ct[sizeof(pt_gcm_1)];
|
||||||
|
uint8_t tag_enc[16];
|
||||||
|
uint8_t tag_dec[16];
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_gcm(
|
||||||
|
key_gcm_1,
|
||||||
|
iv_gcm_1,
|
||||||
|
aad_gcm_1,
|
||||||
|
sizeof(aad_gcm_1),
|
||||||
|
pt_gcm_1,
|
||||||
|
ct,
|
||||||
|
sizeof(pt_gcm_1),
|
||||||
|
tag_enc,
|
||||||
|
false);
|
||||||
|
mu_assert(ret, "GCM 1 encryption failed");
|
||||||
|
//mu_assert_mem_eq(tv_gcm_ct_1, ct, sizeof(pt_gcm_1));
|
||||||
|
mu_assert_mem_eq(tv_gcm_tag_1, tag_enc, 16);
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_gcm(
|
||||||
|
key_gcm_1, iv_gcm_1, aad_gcm_1, sizeof(aad_gcm_1), ct, pt, sizeof(pt_gcm_1), tag_dec, true);
|
||||||
|
mu_assert(ret, "GCM 1 decryption failed");
|
||||||
|
//mu_assert_mem_eq(pt_gcm_1, pt, sizeof(pt_gcm_1));
|
||||||
|
mu_assert_mem_eq(tv_gcm_tag_1, tag_dec, 16);
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_crypto_gcm_2) {
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t pt[sizeof(pt_gcm_2)];
|
||||||
|
uint8_t ct[sizeof(pt_gcm_2)];
|
||||||
|
uint8_t tag_enc[16];
|
||||||
|
uint8_t tag_dec[16];
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_gcm(
|
||||||
|
key_gcm_2,
|
||||||
|
iv_gcm_2,
|
||||||
|
aad_gcm_2,
|
||||||
|
sizeof(aad_gcm_2),
|
||||||
|
pt_gcm_2,
|
||||||
|
ct,
|
||||||
|
sizeof(pt_gcm_2),
|
||||||
|
tag_enc,
|
||||||
|
false);
|
||||||
|
mu_assert(ret, "GCM 2 encryption failed");
|
||||||
|
mu_assert_mem_eq(tv_gcm_ct_2, ct, sizeof(pt_gcm_2));
|
||||||
|
mu_assert_mem_eq(tv_gcm_tag_2, tag_enc, 16);
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_gcm(
|
||||||
|
key_gcm_2, iv_gcm_2, aad_gcm_2, sizeof(aad_gcm_2), ct, pt, sizeof(pt_gcm_2), tag_dec, true);
|
||||||
|
mu_assert(ret, "GCM 2 decryption failed");
|
||||||
|
mu_assert_mem_eq(pt_gcm_2, pt, sizeof(pt_gcm_2));
|
||||||
|
mu_assert_mem_eq(tv_gcm_tag_2, tag_dec, 16);
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_crypto_gcm_3) {
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t pt[sizeof(pt_gcm_3)];
|
||||||
|
uint8_t ct[sizeof(pt_gcm_3)];
|
||||||
|
uint8_t tag_enc[16];
|
||||||
|
uint8_t tag_dec[16];
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_gcm(
|
||||||
|
key_gcm_3,
|
||||||
|
iv_gcm_3,
|
||||||
|
aad_gcm_3,
|
||||||
|
sizeof(aad_gcm_3),
|
||||||
|
pt_gcm_3,
|
||||||
|
ct,
|
||||||
|
sizeof(pt_gcm_3),
|
||||||
|
tag_enc,
|
||||||
|
false);
|
||||||
|
mu_assert(ret, "GCM 3 encryption failed");
|
||||||
|
mu_assert_mem_eq(tv_gcm_ct_3, ct, sizeof(pt_gcm_3));
|
||||||
|
mu_assert_mem_eq(tv_gcm_tag_3, tag_enc, 16);
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_gcm(
|
||||||
|
key_gcm_3, iv_gcm_3, aad_gcm_3, sizeof(aad_gcm_3), ct, pt, sizeof(pt_gcm_3), tag_dec, true);
|
||||||
|
mu_assert(ret, "GCM 3 decryption failed");
|
||||||
|
mu_assert_mem_eq(pt_gcm_3, pt, sizeof(pt_gcm_3));
|
||||||
|
mu_assert_mem_eq(tv_gcm_tag_3, tag_dec, 16);
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_crypto_gcm_4) {
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t pt[sizeof(pt_gcm_4)];
|
||||||
|
uint8_t ct[sizeof(pt_gcm_4)];
|
||||||
|
uint8_t tag_enc[16];
|
||||||
|
uint8_t tag_dec[16];
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_gcm(
|
||||||
|
key_gcm_4,
|
||||||
|
iv_gcm_4,
|
||||||
|
aad_gcm_4,
|
||||||
|
sizeof(aad_gcm_4),
|
||||||
|
pt_gcm_4,
|
||||||
|
ct,
|
||||||
|
sizeof(pt_gcm_4),
|
||||||
|
tag_enc,
|
||||||
|
false);
|
||||||
|
mu_assert(ret, "GCM 4 encryption failed");
|
||||||
|
mu_assert_mem_eq(tv_gcm_ct_4, ct, sizeof(pt_gcm_4));
|
||||||
|
mu_assert_mem_eq(tv_gcm_tag_4, tag_enc, 16);
|
||||||
|
|
||||||
|
ret = furi_hal_crypto_gcm(
|
||||||
|
key_gcm_4, iv_gcm_4, aad_gcm_4, sizeof(aad_gcm_4), ct, pt, sizeof(pt_gcm_4), tag_dec, true);
|
||||||
|
mu_assert(ret, "GCM 4 decryption failed");
|
||||||
|
mu_assert_mem_eq(pt_gcm_4, pt, sizeof(pt_gcm_4));
|
||||||
|
mu_assert_mem_eq(tv_gcm_tag_4, tag_dec, 16);
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST_SUITE(furi_hal_crypto_ctr_test) {
|
||||||
|
MU_SUITE_CONFIGURE(&furi_hal_crypto_ctr_setup, &furi_hal_crypto_ctr_teardown);
|
||||||
|
MU_RUN_TEST(furi_hal_crypto_ctr_1);
|
||||||
|
MU_RUN_TEST(furi_hal_crypto_ctr_2);
|
||||||
|
MU_RUN_TEST(furi_hal_crypto_ctr_3);
|
||||||
|
MU_RUN_TEST(furi_hal_crypto_ctr_4);
|
||||||
|
MU_RUN_TEST(furi_hal_crypto_ctr_5);
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST_SUITE(furi_hal_crypto_gcm_test) {
|
||||||
|
MU_SUITE_CONFIGURE(&furi_hal_crypto_gcm_setup, &furi_hal_crypto_gcm_teardown);
|
||||||
|
MU_RUN_TEST(furi_hal_crypto_gcm_1);
|
||||||
|
MU_RUN_TEST(furi_hal_crypto_gcm_2);
|
||||||
|
MU_RUN_TEST(furi_hal_crypto_gcm_3);
|
||||||
|
MU_RUN_TEST(furi_hal_crypto_gcm_4);
|
||||||
|
}
|
||||||
|
|
||||||
|
int run_minunit_test_furi_hal_crypto() {
|
||||||
|
MU_RUN_SUITE(furi_hal_crypto_ctr_test);
|
||||||
|
MU_RUN_SUITE(furi_hal_crypto_gcm_test);
|
||||||
|
return MU_EXIT_CODE;
|
||||||
|
}
|
||||||
@@ -5,6 +5,11 @@
|
|||||||
#include "../minunit.h"
|
#include "../minunit.h"
|
||||||
|
|
||||||
#define DATA_SIZE 4
|
#define DATA_SIZE 4
|
||||||
|
#define EEPROM_ADDRESS 0b10101000
|
||||||
|
#define EEPROM_ADDRESS_HIGH (EEPROM_ADDRESS | 0b10)
|
||||||
|
#define EEPROM_SIZE 512
|
||||||
|
#define EEPROM_PAGE_SIZE 16
|
||||||
|
#define EEPROM_WRITE_DELAY_MS 6
|
||||||
|
|
||||||
static void furi_hal_i2c_int_setup() {
|
static void furi_hal_i2c_int_setup() {
|
||||||
furi_hal_i2c_acquire(&furi_hal_i2c_handle_power);
|
furi_hal_i2c_acquire(&furi_hal_i2c_handle_power);
|
||||||
@@ -14,6 +19,14 @@ static void furi_hal_i2c_int_teardown() {
|
|||||||
furi_hal_i2c_release(&furi_hal_i2c_handle_power);
|
furi_hal_i2c_release(&furi_hal_i2c_handle_power);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void furi_hal_i2c_ext_setup() {
|
||||||
|
furi_hal_i2c_acquire(&furi_hal_i2c_handle_external);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void furi_hal_i2c_ext_teardown() {
|
||||||
|
furi_hal_i2c_release(&furi_hal_i2c_handle_external);
|
||||||
|
}
|
||||||
|
|
||||||
MU_TEST(furi_hal_i2c_int_1b) {
|
MU_TEST(furi_hal_i2c_int_1b) {
|
||||||
bool ret = false;
|
bool ret = false;
|
||||||
uint8_t data_one = 0;
|
uint8_t data_one = 0;
|
||||||
@@ -103,14 +116,116 @@ MU_TEST(furi_hal_i2c_int_1b_fail) {
|
|||||||
mu_assert(data_one != 0, "9 invalid data");
|
mu_assert(data_one != 0, "9 invalid data");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_i2c_int_ext_3b) {
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t data_many[DATA_SIZE] = {0};
|
||||||
|
|
||||||
|
// 3 byte: read
|
||||||
|
data_many[0] = LP5562_CHANNEL_BLUE_CURRENT_REGISTER;
|
||||||
|
ret = furi_hal_i2c_tx_ext(
|
||||||
|
&furi_hal_i2c_handle_power,
|
||||||
|
LP5562_ADDRESS,
|
||||||
|
false,
|
||||||
|
data_many,
|
||||||
|
1,
|
||||||
|
FuriHalI2cBeginStart,
|
||||||
|
FuriHalI2cEndAwaitRestart,
|
||||||
|
LP5562_I2C_TIMEOUT);
|
||||||
|
mu_assert(ret, "3 tx failed");
|
||||||
|
|
||||||
|
// Send a RESTART condition, then read the 3 bytes one after the other
|
||||||
|
ret = furi_hal_i2c_rx_ext(
|
||||||
|
&furi_hal_i2c_handle_power,
|
||||||
|
LP5562_ADDRESS,
|
||||||
|
false,
|
||||||
|
data_many + 1,
|
||||||
|
1,
|
||||||
|
FuriHalI2cBeginRestart,
|
||||||
|
FuriHalI2cEndPause,
|
||||||
|
LP5562_I2C_TIMEOUT);
|
||||||
|
mu_assert(ret, "4 rx failed");
|
||||||
|
mu_assert(data_many[1] != 0, "4 invalid data");
|
||||||
|
ret = furi_hal_i2c_rx_ext(
|
||||||
|
&furi_hal_i2c_handle_power,
|
||||||
|
LP5562_ADDRESS,
|
||||||
|
false,
|
||||||
|
data_many + 2,
|
||||||
|
1,
|
||||||
|
FuriHalI2cBeginResume,
|
||||||
|
FuriHalI2cEndPause,
|
||||||
|
LP5562_I2C_TIMEOUT);
|
||||||
|
mu_assert(ret, "5 rx failed");
|
||||||
|
mu_assert(data_many[2] != 0, "5 invalid data");
|
||||||
|
ret = furi_hal_i2c_rx_ext(
|
||||||
|
&furi_hal_i2c_handle_power,
|
||||||
|
LP5562_ADDRESS,
|
||||||
|
false,
|
||||||
|
data_many + 3,
|
||||||
|
1,
|
||||||
|
FuriHalI2cBeginResume,
|
||||||
|
FuriHalI2cEndStop,
|
||||||
|
LP5562_I2C_TIMEOUT);
|
||||||
|
mu_assert(ret, "6 rx failed");
|
||||||
|
mu_assert(data_many[3] != 0, "6 invalid data");
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(furi_hal_i2c_ext_eeprom) {
|
||||||
|
if(!furi_hal_i2c_is_device_ready(&furi_hal_i2c_handle_external, EEPROM_ADDRESS, 100)) {
|
||||||
|
printf("no device connected, skipping\r\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ret = false;
|
||||||
|
uint8_t buffer[EEPROM_SIZE] = {0};
|
||||||
|
|
||||||
|
for(size_t page = 0; page < (EEPROM_SIZE / EEPROM_PAGE_SIZE); ++page) {
|
||||||
|
// Fill page buffer
|
||||||
|
for(size_t page_byte = 0; page_byte < EEPROM_PAGE_SIZE; ++page_byte) {
|
||||||
|
// Each byte is its position in the EEPROM modulo 256
|
||||||
|
uint8_t byte = ((page * EEPROM_PAGE_SIZE) + page_byte) % 256;
|
||||||
|
|
||||||
|
buffer[page_byte] = byte;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t address = (page < 16) ? EEPROM_ADDRESS : EEPROM_ADDRESS_HIGH;
|
||||||
|
|
||||||
|
ret = furi_hal_i2c_write_mem(
|
||||||
|
&furi_hal_i2c_handle_external,
|
||||||
|
address,
|
||||||
|
page * EEPROM_PAGE_SIZE,
|
||||||
|
buffer,
|
||||||
|
EEPROM_PAGE_SIZE,
|
||||||
|
20);
|
||||||
|
|
||||||
|
mu_assert(ret, "EEPROM write failed");
|
||||||
|
furi_delay_ms(EEPROM_WRITE_DELAY_MS);
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = furi_hal_i2c_read_mem(
|
||||||
|
&furi_hal_i2c_handle_external, EEPROM_ADDRESS, 0, buffer, EEPROM_SIZE, 100);
|
||||||
|
|
||||||
|
mu_assert(ret, "EEPROM read failed");
|
||||||
|
|
||||||
|
for(size_t pos = 0; pos < EEPROM_SIZE; ++pos) {
|
||||||
|
mu_assert_int_eq(pos % 256, buffer[pos]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
MU_TEST_SUITE(furi_hal_i2c_int_suite) {
|
MU_TEST_SUITE(furi_hal_i2c_int_suite) {
|
||||||
MU_SUITE_CONFIGURE(&furi_hal_i2c_int_setup, &furi_hal_i2c_int_teardown);
|
MU_SUITE_CONFIGURE(&furi_hal_i2c_int_setup, &furi_hal_i2c_int_teardown);
|
||||||
MU_RUN_TEST(furi_hal_i2c_int_1b);
|
MU_RUN_TEST(furi_hal_i2c_int_1b);
|
||||||
MU_RUN_TEST(furi_hal_i2c_int_3b);
|
MU_RUN_TEST(furi_hal_i2c_int_3b);
|
||||||
|
MU_RUN_TEST(furi_hal_i2c_int_ext_3b);
|
||||||
MU_RUN_TEST(furi_hal_i2c_int_1b_fail);
|
MU_RUN_TEST(furi_hal_i2c_int_1b_fail);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MU_TEST_SUITE(furi_hal_i2c_ext_suite) {
|
||||||
|
MU_SUITE_CONFIGURE(&furi_hal_i2c_ext_setup, &furi_hal_i2c_ext_teardown);
|
||||||
|
MU_RUN_TEST(furi_hal_i2c_ext_eeprom);
|
||||||
|
}
|
||||||
|
|
||||||
int run_minunit_test_furi_hal() {
|
int run_minunit_test_furi_hal() {
|
||||||
MU_RUN_SUITE(furi_hal_i2c_int_suite);
|
MU_RUN_SUITE(furi_hal_i2c_int_suite);
|
||||||
|
MU_RUN_SUITE(furi_hal_i2c_ext_suite);
|
||||||
return MU_EXIT_CODE;
|
return MU_EXIT_CODE;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -27,7 +27,7 @@ static void infrared_test_alloc() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void infrared_test_free() {
|
static void infrared_test_free() {
|
||||||
furi_assert(test);
|
furi_check(test);
|
||||||
infrared_free_decoder(test->decoder_handler);
|
infrared_free_decoder(test->decoder_handler);
|
||||||
infrared_free_encoder(test->encoder_handler);
|
infrared_free_encoder(test->encoder_handler);
|
||||||
flipper_format_free(test->ff);
|
flipper_format_free(test->ff);
|
||||||
|
|||||||
@@ -311,7 +311,7 @@ MU_TEST(test_bit_lib_test_parity) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
MU_TEST(test_bit_lib_remove_bit_every_nth) {
|
MU_TEST(test_bit_lib_remove_bit_every_nth) {
|
||||||
// TODO: more tests
|
// TODO FL-3494: more tests
|
||||||
uint8_t data_i[1] = {0b00001111};
|
uint8_t data_i[1] = {0b00001111};
|
||||||
uint8_t data_o[1] = {0b00011111};
|
uint8_t data_o[1] = {0b00011111};
|
||||||
size_t length;
|
size_t length;
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ MU_TEST(manifest_iteration_test) {
|
|||||||
ResourceManifestReader* manifest_reader = resource_manifest_reader_alloc(storage);
|
ResourceManifestReader* manifest_reader = resource_manifest_reader_alloc(storage);
|
||||||
do {
|
do {
|
||||||
// Open manifest file
|
// Open manifest file
|
||||||
if(!resource_manifest_reader_open(manifest_reader, EXT_PATH("unit_tests/Manifest"))) {
|
if(!resource_manifest_reader_open(manifest_reader, EXT_PATH("unit_tests/Manifest_test"))) {
|
||||||
result = false;
|
result = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
458
applications/debug/unit_tests/nfc/nfc_transport.c
Normal file
458
applications/debug/unit_tests/nfc/nfc_transport.c
Normal file
@@ -0,0 +1,458 @@
|
|||||||
|
#ifdef FW_CFG_unit_tests
|
||||||
|
|
||||||
|
#include <lib/nfc/nfc.h>
|
||||||
|
#include <lib/nfc/helpers/iso14443_crc.h>
|
||||||
|
#include <lib/nfc/protocols/iso14443_3a/iso14443_3a.h>
|
||||||
|
|
||||||
|
#include <furi/furi.h>
|
||||||
|
|
||||||
|
#define NFC_MAX_BUFFER_SIZE (256)
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
NfcTransportLogLevelWarning,
|
||||||
|
NfcTransportLogLevelInfo,
|
||||||
|
} NfcTransportLogLevel;
|
||||||
|
|
||||||
|
FuriMessageQueue* poller_queue = NULL;
|
||||||
|
FuriMessageQueue* listener_queue = NULL;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
NfcMessageTypeTx,
|
||||||
|
NfcMessageTypeTimeout,
|
||||||
|
NfcMessageTypeAbort,
|
||||||
|
} NfcMessageType;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint16_t data_bits;
|
||||||
|
uint8_t data[NFC_MAX_BUFFER_SIZE];
|
||||||
|
} NfcMessageData;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
NfcMessageType type;
|
||||||
|
NfcMessageData data;
|
||||||
|
} NfcMessage;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
NfcStateIdle,
|
||||||
|
NfcStateReady,
|
||||||
|
NfcStateReset,
|
||||||
|
} NfcState;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
Iso14443_3aColResStatusIdle,
|
||||||
|
Iso14443_3aColResStatusInProgress,
|
||||||
|
Iso14443_3aColResStatusDone,
|
||||||
|
} Iso14443_3aColResStatus;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
Iso14443_3aSensResp sens_resp;
|
||||||
|
Iso14443_3aSddResp sdd_resp[2];
|
||||||
|
Iso14443_3aSelResp sel_resp[2];
|
||||||
|
} Iso14443_3aColResData;
|
||||||
|
|
||||||
|
struct Nfc {
|
||||||
|
NfcState state;
|
||||||
|
|
||||||
|
Iso14443_3aColResStatus col_res_status;
|
||||||
|
Iso14443_3aColResData col_res_data;
|
||||||
|
|
||||||
|
NfcEventCallback callback;
|
||||||
|
void* context;
|
||||||
|
|
||||||
|
NfcMode mode;
|
||||||
|
|
||||||
|
FuriThread* worker_thread;
|
||||||
|
};
|
||||||
|
|
||||||
|
static void nfc_test_print(
|
||||||
|
NfcTransportLogLevel log_level,
|
||||||
|
const char* message,
|
||||||
|
uint8_t* buffer,
|
||||||
|
uint16_t bits) {
|
||||||
|
FuriString* str = furi_string_alloc();
|
||||||
|
size_t bytes = (bits + 7) / 8;
|
||||||
|
|
||||||
|
for(size_t i = 0; i < bytes; i++) {
|
||||||
|
furi_string_cat_printf(str, " %02X", buffer[i]);
|
||||||
|
}
|
||||||
|
if(log_level == NfcTransportLogLevelWarning) {
|
||||||
|
FURI_LOG_W(message, "%s", furi_string_get_cstr(str));
|
||||||
|
} else {
|
||||||
|
FURI_LOG_I(message, "%s", furi_string_get_cstr(str));
|
||||||
|
}
|
||||||
|
|
||||||
|
furi_string_free(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void nfc_prepare_col_res_data(
|
||||||
|
Nfc* instance,
|
||||||
|
uint8_t* uid,
|
||||||
|
uint8_t uid_len,
|
||||||
|
uint8_t* atqa,
|
||||||
|
uint8_t sak) {
|
||||||
|
memcpy(instance->col_res_data.sens_resp.sens_resp, atqa, 2);
|
||||||
|
|
||||||
|
if(uid_len == 7) {
|
||||||
|
instance->col_res_data.sdd_resp[0].nfcid[0] = 0x88;
|
||||||
|
memcpy(&instance->col_res_data.sdd_resp[0].nfcid[1], uid, 3);
|
||||||
|
uint8_t bss = 0;
|
||||||
|
for(size_t i = 0; i < 4; i++) {
|
||||||
|
bss ^= instance->col_res_data.sdd_resp[0].nfcid[i];
|
||||||
|
}
|
||||||
|
instance->col_res_data.sdd_resp[0].bss = bss;
|
||||||
|
instance->col_res_data.sel_resp[0].sak = 0x04;
|
||||||
|
|
||||||
|
memcpy(instance->col_res_data.sdd_resp[1].nfcid, &uid[3], 4);
|
||||||
|
bss = 0;
|
||||||
|
for(size_t i = 0; i < 4; i++) {
|
||||||
|
bss ^= instance->col_res_data.sdd_resp[1].nfcid[i];
|
||||||
|
}
|
||||||
|
instance->col_res_data.sdd_resp[1].bss = bss;
|
||||||
|
instance->col_res_data.sel_resp[1].sak = sak;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
furi_crash("Not supporting not 7 bytes");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Nfc* nfc_alloc() {
|
||||||
|
Nfc* instance = malloc(sizeof(Nfc));
|
||||||
|
|
||||||
|
return instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
void nfc_free(Nfc* instance) {
|
||||||
|
furi_check(instance);
|
||||||
|
|
||||||
|
free(instance);
|
||||||
|
}
|
||||||
|
|
||||||
|
void nfc_config(Nfc* instance, NfcMode mode, NfcTech tech) {
|
||||||
|
UNUSED(instance);
|
||||||
|
UNUSED(tech);
|
||||||
|
|
||||||
|
instance->mode = mode;
|
||||||
|
}
|
||||||
|
|
||||||
|
void nfc_set_fdt_poll_fc(Nfc* instance, uint32_t fdt_poll_fc) {
|
||||||
|
UNUSED(instance);
|
||||||
|
UNUSED(fdt_poll_fc);
|
||||||
|
}
|
||||||
|
|
||||||
|
void nfc_set_fdt_listen_fc(Nfc* instance, uint32_t fdt_listen_fc) {
|
||||||
|
UNUSED(instance);
|
||||||
|
UNUSED(fdt_listen_fc);
|
||||||
|
}
|
||||||
|
|
||||||
|
void nfc_set_mask_receive_time_fc(Nfc* instance, uint32_t mask_rx_time_fc) {
|
||||||
|
UNUSED(instance);
|
||||||
|
UNUSED(mask_rx_time_fc);
|
||||||
|
}
|
||||||
|
|
||||||
|
void nfc_set_fdt_poll_poll_us(Nfc* instance, uint32_t fdt_poll_poll_us) {
|
||||||
|
UNUSED(instance);
|
||||||
|
UNUSED(fdt_poll_poll_us);
|
||||||
|
}
|
||||||
|
|
||||||
|
void nfc_set_guard_time_us(Nfc* instance, uint32_t guard_time_us) {
|
||||||
|
UNUSED(instance);
|
||||||
|
UNUSED(guard_time_us);
|
||||||
|
}
|
||||||
|
|
||||||
|
NfcError nfc_iso14443a_listener_set_col_res_data(
|
||||||
|
Nfc* instance,
|
||||||
|
uint8_t* uid,
|
||||||
|
uint8_t uid_len,
|
||||||
|
uint8_t* atqa,
|
||||||
|
uint8_t sak) {
|
||||||
|
furi_check(instance);
|
||||||
|
furi_check(uid);
|
||||||
|
furi_check(atqa);
|
||||||
|
|
||||||
|
nfc_prepare_col_res_data(instance, uid, uid_len, atqa, sak);
|
||||||
|
|
||||||
|
return NfcErrorNone;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t nfc_worker_poller(void* context) {
|
||||||
|
Nfc* instance = context;
|
||||||
|
furi_check(instance->callback);
|
||||||
|
|
||||||
|
instance->state = NfcStateReady;
|
||||||
|
NfcCommand command = NfcCommandContinue;
|
||||||
|
NfcEvent event = {};
|
||||||
|
|
||||||
|
while(true) {
|
||||||
|
event.type = NfcEventTypePollerReady;
|
||||||
|
command = instance->callback(event, instance->context);
|
||||||
|
if(command == NfcCommandStop) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
instance->state = NfcStateIdle;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void nfc_worker_listener_pass_col_res(Nfc* instance, uint8_t* rx_data, uint16_t rx_bits) {
|
||||||
|
furi_check(instance->col_res_status != Iso14443_3aColResStatusDone);
|
||||||
|
BitBuffer* tx_buffer = bit_buffer_alloc(NFC_MAX_BUFFER_SIZE);
|
||||||
|
|
||||||
|
bool processed = false;
|
||||||
|
|
||||||
|
if((rx_bits == 7) && (rx_data[0] == 0x52)) {
|
||||||
|
instance->col_res_status = Iso14443_3aColResStatusInProgress;
|
||||||
|
bit_buffer_copy_bytes(
|
||||||
|
tx_buffer,
|
||||||
|
instance->col_res_data.sens_resp.sens_resp,
|
||||||
|
sizeof(instance->col_res_data.sens_resp.sens_resp));
|
||||||
|
nfc_listener_tx(instance, tx_buffer);
|
||||||
|
processed = true;
|
||||||
|
} else if(rx_bits == 2 * 8) {
|
||||||
|
if((rx_data[0] == 0x93) && (rx_data[1] == 0x20)) {
|
||||||
|
bit_buffer_copy_bytes(
|
||||||
|
tx_buffer,
|
||||||
|
(const uint8_t*)&instance->col_res_data.sdd_resp[0],
|
||||||
|
sizeof(Iso14443_3aSddResp));
|
||||||
|
nfc_listener_tx(instance, tx_buffer);
|
||||||
|
processed = true;
|
||||||
|
} else if((rx_data[0] == 0x95) && (rx_data[1] == 0x20)) {
|
||||||
|
bit_buffer_copy_bytes(
|
||||||
|
tx_buffer,
|
||||||
|
(const uint8_t*)&instance->col_res_data.sdd_resp[1],
|
||||||
|
sizeof(Iso14443_3aSddResp));
|
||||||
|
nfc_listener_tx(instance, tx_buffer);
|
||||||
|
processed = true;
|
||||||
|
}
|
||||||
|
} else if(rx_bits == 9 * 8) {
|
||||||
|
if((rx_data[0] == 0x93) && (rx_data[1] == 0x70)) {
|
||||||
|
bit_buffer_set_size_bytes(tx_buffer, 1);
|
||||||
|
bit_buffer_set_byte(tx_buffer, 0, instance->col_res_data.sel_resp[0].sak);
|
||||||
|
iso14443_crc_append(Iso14443CrcTypeA, tx_buffer);
|
||||||
|
nfc_listener_tx(instance, tx_buffer);
|
||||||
|
processed = true;
|
||||||
|
} else if((rx_data[0] == 0x95) && (rx_data[1] == 0x70)) {
|
||||||
|
bit_buffer_set_size_bytes(tx_buffer, 1);
|
||||||
|
bit_buffer_set_byte(tx_buffer, 0, instance->col_res_data.sel_resp[1].sak);
|
||||||
|
iso14443_crc_append(Iso14443CrcTypeA, tx_buffer);
|
||||||
|
nfc_listener_tx(instance, tx_buffer);
|
||||||
|
instance->col_res_status = Iso14443_3aColResStatusDone;
|
||||||
|
NfcEvent event = {.type = NfcEventTypeListenerActivated};
|
||||||
|
instance->callback(event, instance->context);
|
||||||
|
|
||||||
|
processed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!processed) {
|
||||||
|
NfcMessage message = {.type = NfcMessageTypeTimeout};
|
||||||
|
furi_message_queue_put(poller_queue, &message, FuriWaitForever);
|
||||||
|
}
|
||||||
|
|
||||||
|
bit_buffer_free(tx_buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t nfc_worker_listener(void* context) {
|
||||||
|
Nfc* instance = context;
|
||||||
|
furi_check(instance->callback);
|
||||||
|
|
||||||
|
NfcMessage message = {};
|
||||||
|
|
||||||
|
NfcEventData event_data = {};
|
||||||
|
event_data.buffer = bit_buffer_alloc(NFC_MAX_BUFFER_SIZE);
|
||||||
|
NfcEvent nfc_event = {.data = event_data};
|
||||||
|
|
||||||
|
while(true) {
|
||||||
|
furi_message_queue_get(listener_queue, &message, FuriWaitForever);
|
||||||
|
bit_buffer_copy_bits(event_data.buffer, message.data.data, message.data.data_bits);
|
||||||
|
if((message.data.data[0] == 0x52) && (message.data.data_bits == 7)) {
|
||||||
|
instance->col_res_status = Iso14443_3aColResStatusIdle;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(message.type == NfcMessageTypeAbort) {
|
||||||
|
break;
|
||||||
|
} else if(message.type == NfcMessageTypeTx) {
|
||||||
|
nfc_test_print(
|
||||||
|
NfcTransportLogLevelInfo, "RDR", message.data.data, message.data.data_bits);
|
||||||
|
if(instance->col_res_status != Iso14443_3aColResStatusDone) {
|
||||||
|
nfc_worker_listener_pass_col_res(
|
||||||
|
instance, message.data.data, message.data.data_bits);
|
||||||
|
} else {
|
||||||
|
instance->state = NfcStateReady;
|
||||||
|
nfc_event.type = NfcEventTypeRxEnd;
|
||||||
|
instance->callback(nfc_event, instance->context);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
instance->state = NfcStateIdle;
|
||||||
|
instance->col_res_status = Iso14443_3aColResStatusIdle;
|
||||||
|
memset(&instance->col_res_data, 0, sizeof(instance->col_res_data));
|
||||||
|
bit_buffer_free(nfc_event.data.buffer);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void nfc_start(Nfc* instance, NfcEventCallback callback, void* context) {
|
||||||
|
furi_check(instance);
|
||||||
|
furi_check(instance->worker_thread == NULL);
|
||||||
|
|
||||||
|
if(instance->mode == NfcModeListener) {
|
||||||
|
furi_check(listener_queue == NULL);
|
||||||
|
// Check that poller didn't start
|
||||||
|
furi_check(poller_queue == NULL);
|
||||||
|
} else {
|
||||||
|
furi_check(poller_queue == NULL);
|
||||||
|
// Check that poller is started after listener
|
||||||
|
furi_check(listener_queue);
|
||||||
|
}
|
||||||
|
|
||||||
|
instance->callback = callback;
|
||||||
|
instance->context = context;
|
||||||
|
|
||||||
|
if(instance->mode == NfcModeListener) {
|
||||||
|
listener_queue = furi_message_queue_alloc(4, sizeof(NfcMessage));
|
||||||
|
} else {
|
||||||
|
poller_queue = furi_message_queue_alloc(4, sizeof(NfcMessage));
|
||||||
|
}
|
||||||
|
|
||||||
|
instance->worker_thread = furi_thread_alloc();
|
||||||
|
furi_thread_set_context(instance->worker_thread, instance);
|
||||||
|
furi_thread_set_priority(instance->worker_thread, FuriThreadPriorityHigh);
|
||||||
|
furi_thread_set_stack_size(instance->worker_thread, 8 * 1024);
|
||||||
|
|
||||||
|
if(instance->mode == NfcModeListener) {
|
||||||
|
furi_thread_set_name(instance->worker_thread, "NfcWorkerListener");
|
||||||
|
furi_thread_set_callback(instance->worker_thread, nfc_worker_listener);
|
||||||
|
} else {
|
||||||
|
furi_thread_set_name(instance->worker_thread, "NfcWorkerPoller");
|
||||||
|
furi_thread_set_callback(instance->worker_thread, nfc_worker_poller);
|
||||||
|
}
|
||||||
|
|
||||||
|
furi_thread_start(instance->worker_thread);
|
||||||
|
}
|
||||||
|
|
||||||
|
void nfc_stop(Nfc* instance) {
|
||||||
|
furi_check(instance);
|
||||||
|
furi_check(instance->worker_thread);
|
||||||
|
|
||||||
|
if(instance->mode == NfcModeListener) {
|
||||||
|
NfcMessage message = {.type = NfcMessageTypeAbort};
|
||||||
|
furi_message_queue_put(listener_queue, &message, FuriWaitForever);
|
||||||
|
furi_thread_join(instance->worker_thread);
|
||||||
|
|
||||||
|
furi_message_queue_free(listener_queue);
|
||||||
|
listener_queue = NULL;
|
||||||
|
|
||||||
|
furi_thread_free(instance->worker_thread);
|
||||||
|
instance->worker_thread = NULL;
|
||||||
|
} else {
|
||||||
|
furi_thread_join(instance->worker_thread);
|
||||||
|
|
||||||
|
furi_message_queue_free(poller_queue);
|
||||||
|
poller_queue = NULL;
|
||||||
|
|
||||||
|
furi_thread_free(instance->worker_thread);
|
||||||
|
instance->worker_thread = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called from worker thread
|
||||||
|
|
||||||
|
NfcError nfc_listener_tx(Nfc* instance, const BitBuffer* tx_buffer) {
|
||||||
|
furi_check(instance);
|
||||||
|
furi_check(poller_queue);
|
||||||
|
furi_check(listener_queue);
|
||||||
|
furi_check(tx_buffer);
|
||||||
|
|
||||||
|
NfcMessage message = {};
|
||||||
|
message.type = NfcMessageTypeTx;
|
||||||
|
message.data.data_bits = bit_buffer_get_size(tx_buffer);
|
||||||
|
bit_buffer_write_bytes(tx_buffer, message.data.data, bit_buffer_get_size_bytes(tx_buffer));
|
||||||
|
|
||||||
|
furi_message_queue_put(poller_queue, &message, FuriWaitForever);
|
||||||
|
|
||||||
|
return NfcErrorNone;
|
||||||
|
}
|
||||||
|
|
||||||
|
NfcError nfc_iso14443a_listener_tx_custom_parity(Nfc* instance, const BitBuffer* tx_buffer) {
|
||||||
|
return nfc_listener_tx(instance, tx_buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
NfcError
|
||||||
|
nfc_poller_trx(Nfc* instance, const BitBuffer* tx_buffer, BitBuffer* rx_buffer, uint32_t fwt) {
|
||||||
|
furi_check(instance);
|
||||||
|
furi_check(tx_buffer);
|
||||||
|
furi_check(rx_buffer);
|
||||||
|
furi_check(poller_queue);
|
||||||
|
furi_check(listener_queue);
|
||||||
|
UNUSED(fwt);
|
||||||
|
|
||||||
|
NfcError error = NfcErrorNone;
|
||||||
|
|
||||||
|
NfcMessage message = {};
|
||||||
|
message.type = NfcMessageTypeTx;
|
||||||
|
message.data.data_bits = bit_buffer_get_size(tx_buffer);
|
||||||
|
bit_buffer_write_bytes(tx_buffer, message.data.data, bit_buffer_get_size_bytes(tx_buffer));
|
||||||
|
// Tx
|
||||||
|
furi_check(furi_message_queue_put(listener_queue, &message, FuriWaitForever) == FuriStatusOk);
|
||||||
|
// Rx
|
||||||
|
FuriStatus status = furi_message_queue_get(poller_queue, &message, 50);
|
||||||
|
|
||||||
|
if(status == FuriStatusErrorTimeout) {
|
||||||
|
error = NfcErrorTimeout;
|
||||||
|
} else if(message.type == NfcMessageTypeTx) {
|
||||||
|
bit_buffer_copy_bits(rx_buffer, message.data.data, message.data.data_bits);
|
||||||
|
nfc_test_print(
|
||||||
|
NfcTransportLogLevelWarning, "TAG", message.data.data, message.data.data_bits);
|
||||||
|
} else if(message.type == NfcMessageTypeTimeout) {
|
||||||
|
error = NfcErrorTimeout;
|
||||||
|
}
|
||||||
|
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
NfcError nfc_iso14443a_poller_trx_custom_parity(
|
||||||
|
Nfc* instance,
|
||||||
|
const BitBuffer* tx_buffer,
|
||||||
|
BitBuffer* rx_buffer,
|
||||||
|
uint32_t fwt) {
|
||||||
|
return nfc_poller_trx(instance, tx_buffer, rx_buffer, fwt);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Technology specific API
|
||||||
|
|
||||||
|
NfcError nfc_iso14443a_poller_trx_short_frame(
|
||||||
|
Nfc* instance,
|
||||||
|
NfcIso14443aShortFrame frame,
|
||||||
|
BitBuffer* rx_buffer,
|
||||||
|
uint32_t fwt) {
|
||||||
|
UNUSED(frame);
|
||||||
|
|
||||||
|
BitBuffer* tx_buffer = bit_buffer_alloc(32);
|
||||||
|
bit_buffer_set_size(tx_buffer, 7);
|
||||||
|
bit_buffer_set_byte(tx_buffer, 0, 0x52);
|
||||||
|
|
||||||
|
NfcError error = nfc_poller_trx(instance, tx_buffer, rx_buffer, fwt);
|
||||||
|
|
||||||
|
bit_buffer_free(tx_buffer);
|
||||||
|
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
NfcError nfc_iso14443a_poller_trx_sdd_frame(
|
||||||
|
Nfc* instance,
|
||||||
|
const BitBuffer* tx_buffer,
|
||||||
|
BitBuffer* rx_buffer,
|
||||||
|
uint32_t fwt) {
|
||||||
|
return nfc_poller_trx(instance, tx_buffer, rx_buffer, fwt);
|
||||||
|
}
|
||||||
|
|
||||||
|
NfcError nfc_iso15693_listener_tx_sof(Nfc* instance) {
|
||||||
|
UNUSED(instance);
|
||||||
|
|
||||||
|
return NfcErrorNone;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
@@ -0,0 +1,66 @@
|
|||||||
|
Filetype: Flipper NFC device
|
||||||
|
Version: 3
|
||||||
|
# Nfc device type can be UID, Mifare Ultralight, Mifare Classic
|
||||||
|
Device type: NTAG213
|
||||||
|
# UID, ATQA and SAK are common for all formats
|
||||||
|
UID: 04 AC 6B 72 BA 6C 80
|
||||||
|
ATQA: 00 44
|
||||||
|
SAK: 00
|
||||||
|
# Mifare Ultralight specific data
|
||||||
|
Data format version: 1
|
||||||
|
Signature: 2D AE BC AF 84 B8 85 87 C2 FB FE 76 13 58 86 72 8E 1D 3C B5 DA 24 23 44 E5 63 4D 4C 82 FB D7 18
|
||||||
|
Mifare version: 00 04 04 02 01 00 0F 03
|
||||||
|
Counter 0: 0
|
||||||
|
Tearing 0: 00
|
||||||
|
Counter 1: 0
|
||||||
|
Tearing 1: 00
|
||||||
|
Counter 2: 0
|
||||||
|
Tearing 2: 00
|
||||||
|
Pages total: 45
|
||||||
|
Pages read: 45
|
||||||
|
Page 0: 04 AC 6B 4B
|
||||||
|
Page 1: 72 BA 6C 80
|
||||||
|
Page 2: 24 48 00 00
|
||||||
|
Page 3: E1 10 12 00
|
||||||
|
Page 4: 00 00 41 50
|
||||||
|
Page 5: 00 00 31 31
|
||||||
|
Page 6: 00 20 09 28
|
||||||
|
Page 7: 00 03 31 59
|
||||||
|
Page 8: 91 DF D3 00
|
||||||
|
Page 9: 00 00 00 00
|
||||||
|
Page 10: 00 00 00 00
|
||||||
|
Page 11: 00 00 00 00
|
||||||
|
Page 12: 00 00 00 00
|
||||||
|
Page 13: 00 00 00 00
|
||||||
|
Page 14: 00 00 00 00
|
||||||
|
Page 15: 00 00 00 00
|
||||||
|
Page 16: 00 00 00 00
|
||||||
|
Page 17: 00 00 00 00
|
||||||
|
Page 18: 00 00 00 00
|
||||||
|
Page 19: 00 00 00 00
|
||||||
|
Page 20: 00 00 00 00
|
||||||
|
Page 21: 00 00 00 00
|
||||||
|
Page 22: 00 00 00 00
|
||||||
|
Page 23: 00 00 00 00
|
||||||
|
Page 24: 00 00 00 00
|
||||||
|
Page 25: 00 00 00 00
|
||||||
|
Page 26: 00 00 00 00
|
||||||
|
Page 27: 00 00 00 00
|
||||||
|
Page 28: 00 00 00 00
|
||||||
|
Page 29: 00 00 00 00
|
||||||
|
Page 30: 00 00 00 00
|
||||||
|
Page 31: 00 00 00 00
|
||||||
|
Page 32: 00 00 00 00
|
||||||
|
Page 33: 00 00 00 00
|
||||||
|
Page 34: 00 00 00 00
|
||||||
|
Page 35: 00 00 00 00
|
||||||
|
Page 36: 00 00 00 00
|
||||||
|
Page 37: 00 00 00 00
|
||||||
|
Page 38: 00 00 00 00
|
||||||
|
Page 39: 00 00 00 00
|
||||||
|
Page 40: 00 00 00 BD
|
||||||
|
Page 41: 04 00 00 04
|
||||||
|
Page 42: C0 05 00 00
|
||||||
|
Page 43: 95 3F 52 FF
|
||||||
|
Page 44: 00 00 00 00
|
||||||
|
Failed authentication attempts: 0
|
||||||
@@ -0,0 +1,156 @@
|
|||||||
|
Filetype: Flipper NFC device
|
||||||
|
Version: 3
|
||||||
|
# Nfc device type can be UID, Mifare Ultralight, Mifare Classic
|
||||||
|
Device type: NTAG215
|
||||||
|
# UID, ATQA and SAK are common for all formats
|
||||||
|
UID: 04 51 5C FA 6F 73 81
|
||||||
|
ATQA: 00 44
|
||||||
|
SAK: 00
|
||||||
|
# Mifare Ultralight specific data
|
||||||
|
Data format version: 1
|
||||||
|
Signature: 42 21 E4 6C 79 6A 81 5E EA 0D 93 6D 85 EE 4B 0C 2A 00 D5 77 F1 C5 67 F3 63 75 F8 EB 86 48 5E 6B
|
||||||
|
Mifare version: 00 04 04 02 01 00 11 03
|
||||||
|
Counter 0: 0
|
||||||
|
Tearing 0: 00
|
||||||
|
Counter 1: 0
|
||||||
|
Tearing 1: 00
|
||||||
|
Counter 2: 00
|
||||||
|
Tearing 2: 00
|
||||||
|
Pages total: 135
|
||||||
|
Pages read: 135
|
||||||
|
Page 0: 04 51 5C 81
|
||||||
|
Page 1: FA 6F 73 81
|
||||||
|
Page 2: 67 48 0F E0
|
||||||
|
Page 3: F1 10 FF EE
|
||||||
|
Page 4: A5 00 00 00
|
||||||
|
Page 5: 90 42 74 71
|
||||||
|
Page 6: FD 8F 50 61
|
||||||
|
Page 7: C5 65 1B 54
|
||||||
|
Page 8: EF 68 D0 8E
|
||||||
|
Page 9: 3D 35 DB 83
|
||||||
|
Page 10: D3 00 29 F6
|
||||||
|
Page 11: 42 2A A5 5C
|
||||||
|
Page 12: F1 69 0A FC
|
||||||
|
Page 13: B6 44 E9 6B
|
||||||
|
Page 14: 77 41 88 81
|
||||||
|
Page 15: 86 31 CB AD
|
||||||
|
Page 16: B1 DE F1 AB
|
||||||
|
Page 17: DF 96 C2 C5
|
||||||
|
Page 18: C1 26 99 96
|
||||||
|
Page 19: 85 AF 9F 0E
|
||||||
|
Page 20: 58 FE ED DC
|
||||||
|
Page 21: 0A 0A 00 01
|
||||||
|
Page 22: 03 C1 05 02
|
||||||
|
Page 23: 38 39 34 33
|
||||||
|
Page 24: 49 2D 4E 5C
|
||||||
|
Page 25: 5B 21 0F 44
|
||||||
|
Page 26: 3F 3F 76 69
|
||||||
|
Page 27: B4 72 D8 38
|
||||||
|
Page 28: A0 35 53 51
|
||||||
|
Page 29: 53 EB A6 7C
|
||||||
|
Page 30: 3E 8B 97 C0
|
||||||
|
Page 31: 00 7A 45 13
|
||||||
|
Page 32: 3A 8B D4 0F
|
||||||
|
Page 33: 31 C2 32 CC
|
||||||
|
Page 34: B4 24 A6 1B
|
||||||
|
Page 35: D3 F5 4A 1F
|
||||||
|
Page 36: CD 8F 1D 64
|
||||||
|
Page 37: 01 F4 DF C2
|
||||||
|
Page 38: 11 16 C2 C5
|
||||||
|
Page 39: 30 6D 49 AF
|
||||||
|
Page 40: 10 D4 7C 3C
|
||||||
|
Page 41: 6E 36 4E 08
|
||||||
|
Page 42: 95 76 BC 84
|
||||||
|
Page 43: 35 50 DD F0
|
||||||
|
Page 44: 21 0F EE D9
|
||||||
|
Page 45: 85 19 54 5F
|
||||||
|
Page 46: 3E A9 04 20
|
||||||
|
Page 47: 1B 97 E4 39
|
||||||
|
Page 48: FF 0A 45 F6
|
||||||
|
Page 49: 13 D4 3E DD
|
||||||
|
Page 50: 97 42 FC 67
|
||||||
|
Page 51: 6A AC 78 96
|
||||||
|
Page 52: D1 DA 25 23
|
||||||
|
Page 53: BF 4D B3 76
|
||||||
|
Page 54: F1 21 ED 15
|
||||||
|
Page 55: BD 55 11 C4
|
||||||
|
Page 56: 4E 8C E9 23
|
||||||
|
Page 57: C0 C4 6D 5A
|
||||||
|
Page 58: 58 25 FF 95
|
||||||
|
Page 59: 3C 2B 7A 57
|
||||||
|
Page 60: 66 BE A0 61
|
||||||
|
Page 61: BC FC 4A 31
|
||||||
|
Page 62: 4D AC EE 81
|
||||||
|
Page 63: BE 1A 86 04
|
||||||
|
Page 64: F6 D7 5E B3
|
||||||
|
Page 65: E7 A8 A2 86
|
||||||
|
Page 66: E9 40 AB 47
|
||||||
|
Page 67: C8 36 E4 3E
|
||||||
|
Page 68: A7 4D D3 EA
|
||||||
|
Page 69: 83 9A 64 F7
|
||||||
|
Page 70: 96 6B 5D BF
|
||||||
|
Page 71: 4E A2 A6 0F
|
||||||
|
Page 72: BD 3D BE 7C
|
||||||
|
Page 73: 22 0C 68 51
|
||||||
|
Page 74: 0F 9A B8 AE
|
||||||
|
Page 75: 38 2C C4 CD
|
||||||
|
Page 76: 53 D8 DD 18
|
||||||
|
Page 77: A6 5D 35 87
|
||||||
|
Page 78: C9 6D 99 59
|
||||||
|
Page 79: 61 9F B6 DC
|
||||||
|
Page 80: E6 22 0F 99
|
||||||
|
Page 81: 39 82 79 60
|
||||||
|
Page 82: 58 2E BE F7
|
||||||
|
Page 83: EF F7 95 62
|
||||||
|
Page 84: D5 06 1B 58
|
||||||
|
Page 85: 65 05 A9 08
|
||||||
|
Page 86: 75 ED 5D 90
|
||||||
|
Page 87: 5A E1 7E C9
|
||||||
|
Page 88: 35 D6 29 BB
|
||||||
|
Page 89: D0 67 6C F9
|
||||||
|
Page 90: A0 FF 0B 93
|
||||||
|
Page 91: 22 EA A3 3F
|
||||||
|
Page 92: E2 BD BD 58
|
||||||
|
Page 93: BE 93 D9 94
|
||||||
|
Page 94: 41 CC 7E 40
|
||||||
|
Page 95: E6 8C 5A 43
|
||||||
|
Page 96: 65 C1 24 94
|
||||||
|
Page 97: B9 97 61 13
|
||||||
|
Page 98: AD 74 FF 21
|
||||||
|
Page 99: 0F EC F6 03
|
||||||
|
Page 100: 89 5D 89 E5
|
||||||
|
Page 101: 8D 11 F8 D7
|
||||||
|
Page 102: 33 43 79 2E
|
||||||
|
Page 103: 23 E5 29 B5
|
||||||
|
Page 104: 53 98 13 FF
|
||||||
|
Page 105: E8 79 8B 33
|
||||||
|
Page 106: 45 6C 34 38
|
||||||
|
Page 107: 3B 69 28 D7
|
||||||
|
Page 108: D2 80 B0 2F
|
||||||
|
Page 109: D0 18 D5 DD
|
||||||
|
Page 110: 6C 2D D9 97
|
||||||
|
Page 111: CA 78 B4 A2
|
||||||
|
Page 112: B7 3E B8 79
|
||||||
|
Page 113: A2 BE 54 E4
|
||||||
|
Page 114: C8 28 0C 4A
|
||||||
|
Page 115: 81 E7 EC 1C
|
||||||
|
Page 116: 39 93 6F 70
|
||||||
|
Page 117: 75 77 5C FC
|
||||||
|
Page 118: 66 58 0C 1C
|
||||||
|
Page 119: 9F 70 2E C8
|
||||||
|
Page 120: 52 4A 52 BD
|
||||||
|
Page 121: 56 D5 6A 15
|
||||||
|
Page 122: 54 1B 33 90
|
||||||
|
Page 123: 44 11 C1 07
|
||||||
|
Page 124: 11 5C BA 80
|
||||||
|
Page 125: 10 14 20 9A
|
||||||
|
Page 126: 4A D8 E6 36
|
||||||
|
Page 127: DA B8 59 E5
|
||||||
|
Page 128: 5E 48 95 DA
|
||||||
|
Page 129: 96 6A 26 85
|
||||||
|
Page 130: 01 00 0F BD
|
||||||
|
Page 131: 00 00 00 04
|
||||||
|
Page 132: 5F 00 00 00
|
||||||
|
Page 133: 00 00 00 00
|
||||||
|
Page 134: 00 00 00 00
|
||||||
|
Failed authentication attempts: 0
|
||||||
@@ -0,0 +1,252 @@
|
|||||||
|
Filetype: Flipper NFC device
|
||||||
|
Version: 2
|
||||||
|
# Nfc device type can be UID, Mifare Ultralight, Mifare Classic, Bank card
|
||||||
|
Device type: NTAG216
|
||||||
|
# UID, ATQA and SAK are common for all formats
|
||||||
|
UID: 04 D9 65 0A 32 5E 80
|
||||||
|
ATQA: 44 00
|
||||||
|
SAK: 00
|
||||||
|
# Mifare Ultralight specific data
|
||||||
|
Data format version: 1
|
||||||
|
Signature: 48 2A F2 01 0F F2 F5 A7 9A D5 79 6E CB 14 54 48 98 D1 57 5D 8A 23 A9 B0 E8 20 02 3E CD C8 16 DB
|
||||||
|
Mifare version: 00 04 04 02 01 00 13 03
|
||||||
|
Counter 0: 0
|
||||||
|
Tearing 0: 00
|
||||||
|
Counter 1: 0
|
||||||
|
Tearing 1: 00
|
||||||
|
Counter 2: 0
|
||||||
|
Tearing 2: 00
|
||||||
|
Pages total: 231
|
||||||
|
Pages read: 231
|
||||||
|
Page 0: 04 D9 65 30
|
||||||
|
Page 1: 0A 32 5E 80
|
||||||
|
Page 2: E6 48 00 00
|
||||||
|
Page 3: E1 10 6D 00
|
||||||
|
Page 4: 03 37 D1 01
|
||||||
|
Page 5: 33 55 04 6D
|
||||||
|
Page 6: 2E 79 6F 75
|
||||||
|
Page 7: 74 75 62 65
|
||||||
|
Page 8: 2E 63 6F 6D
|
||||||
|
Page 9: 2F 77 61 74
|
||||||
|
Page 10: 63 68 3F 76
|
||||||
|
Page 11: 3D 62 78 71
|
||||||
|
Page 12: 4C 73 72 6C
|
||||||
|
Page 13: 61 6B 4B 38
|
||||||
|
Page 14: 26 66 65 61
|
||||||
|
Page 15: 74 75 72 65
|
||||||
|
Page 16: 3D 79 6F 75
|
||||||
|
Page 17: 74 75 2E 62
|
||||||
|
Page 18: 65 FE 00 00
|
||||||
|
Page 19: 00 00 00 00
|
||||||
|
Page 20: 00 00 00 00
|
||||||
|
Page 21: 00 00 00 00
|
||||||
|
Page 22: 00 00 00 00
|
||||||
|
Page 23: 00 00 00 00
|
||||||
|
Page 24: 00 00 00 00
|
||||||
|
Page 25: 00 00 00 00
|
||||||
|
Page 26: 00 00 00 00
|
||||||
|
Page 27: 00 00 00 00
|
||||||
|
Page 28: 00 00 00 00
|
||||||
|
Page 29: 00 00 00 00
|
||||||
|
Page 30: 00 00 00 00
|
||||||
|
Page 31: 00 00 00 00
|
||||||
|
Page 32: 00 00 00 00
|
||||||
|
Page 33: 00 00 00 00
|
||||||
|
Page 34: 00 00 00 00
|
||||||
|
Page 35: 00 00 00 00
|
||||||
|
Page 36: 00 00 00 00
|
||||||
|
Page 37: 00 00 00 00
|
||||||
|
Page 38: 00 00 00 00
|
||||||
|
Page 39: 00 00 00 00
|
||||||
|
Page 40: 00 00 00 00
|
||||||
|
Page 41: 00 00 00 00
|
||||||
|
Page 42: 00 00 00 00
|
||||||
|
Page 43: 00 00 00 00
|
||||||
|
Page 44: 00 00 00 00
|
||||||
|
Page 45: 00 00 00 00
|
||||||
|
Page 46: 00 00 00 00
|
||||||
|
Page 47: 00 00 00 00
|
||||||
|
Page 48: 00 00 00 00
|
||||||
|
Page 49: 00 00 00 00
|
||||||
|
Page 50: 00 00 00 00
|
||||||
|
Page 51: 00 00 00 00
|
||||||
|
Page 52: 00 00 00 00
|
||||||
|
Page 53: 00 00 00 00
|
||||||
|
Page 54: 00 00 00 00
|
||||||
|
Page 55: 00 00 00 00
|
||||||
|
Page 56: 00 00 00 00
|
||||||
|
Page 57: 00 00 00 00
|
||||||
|
Page 58: 00 00 00 00
|
||||||
|
Page 59: 00 00 00 00
|
||||||
|
Page 60: 00 00 00 00
|
||||||
|
Page 61: 00 00 00 00
|
||||||
|
Page 62: 00 00 00 00
|
||||||
|
Page 63: 00 00 00 00
|
||||||
|
Page 64: 00 00 00 00
|
||||||
|
Page 65: 00 00 00 00
|
||||||
|
Page 66: 00 00 00 00
|
||||||
|
Page 67: 00 00 00 00
|
||||||
|
Page 68: 00 00 00 00
|
||||||
|
Page 69: 00 00 00 00
|
||||||
|
Page 70: 00 00 00 00
|
||||||
|
Page 71: 00 00 00 00
|
||||||
|
Page 72: 00 00 00 00
|
||||||
|
Page 73: 00 00 00 00
|
||||||
|
Page 74: 00 00 00 00
|
||||||
|
Page 75: 00 00 00 00
|
||||||
|
Page 76: 00 00 00 00
|
||||||
|
Page 77: 00 00 00 00
|
||||||
|
Page 78: 00 00 00 00
|
||||||
|
Page 79: 00 00 00 00
|
||||||
|
Page 80: 00 00 00 00
|
||||||
|
Page 81: 00 00 00 00
|
||||||
|
Page 82: 00 00 00 00
|
||||||
|
Page 83: 00 00 00 00
|
||||||
|
Page 84: 00 00 00 00
|
||||||
|
Page 85: 00 00 00 00
|
||||||
|
Page 86: 00 00 00 00
|
||||||
|
Page 87: 00 00 00 00
|
||||||
|
Page 88: 00 00 00 00
|
||||||
|
Page 89: 00 00 00 00
|
||||||
|
Page 90: 00 00 00 00
|
||||||
|
Page 91: 00 00 00 00
|
||||||
|
Page 92: 00 00 00 00
|
||||||
|
Page 93: 00 00 00 00
|
||||||
|
Page 94: 00 00 00 00
|
||||||
|
Page 95: 00 00 00 00
|
||||||
|
Page 96: 00 00 00 00
|
||||||
|
Page 97: 00 00 00 00
|
||||||
|
Page 98: 00 00 00 00
|
||||||
|
Page 99: 00 00 00 00
|
||||||
|
Page 100: 00 00 00 00
|
||||||
|
Page 101: 00 00 00 00
|
||||||
|
Page 102: 00 00 00 00
|
||||||
|
Page 103: 00 00 00 00
|
||||||
|
Page 104: 00 00 00 00
|
||||||
|
Page 105: 00 00 00 00
|
||||||
|
Page 106: 00 00 00 00
|
||||||
|
Page 107: 00 00 00 00
|
||||||
|
Page 108: 00 00 00 00
|
||||||
|
Page 109: 00 00 00 00
|
||||||
|
Page 110: 00 00 00 00
|
||||||
|
Page 111: 00 00 00 00
|
||||||
|
Page 112: 00 00 00 00
|
||||||
|
Page 113: 00 00 00 00
|
||||||
|
Page 114: 00 00 00 00
|
||||||
|
Page 115: 00 00 00 00
|
||||||
|
Page 116: 00 00 00 00
|
||||||
|
Page 117: 00 00 00 00
|
||||||
|
Page 118: 00 00 00 00
|
||||||
|
Page 119: 00 00 00 00
|
||||||
|
Page 120: 00 00 00 00
|
||||||
|
Page 121: 00 00 00 00
|
||||||
|
Page 122: 00 00 00 00
|
||||||
|
Page 123: 00 00 00 00
|
||||||
|
Page 124: 00 00 00 00
|
||||||
|
Page 125: 00 00 00 00
|
||||||
|
Page 126: 00 00 00 00
|
||||||
|
Page 127: 00 00 00 00
|
||||||
|
Page 128: 00 00 00 00
|
||||||
|
Page 129: 00 00 00 00
|
||||||
|
Page 130: 00 00 00 00
|
||||||
|
Page 131: 00 00 00 00
|
||||||
|
Page 132: 00 00 00 00
|
||||||
|
Page 133: 00 00 00 00
|
||||||
|
Page 134: 00 00 00 00
|
||||||
|
Page 135: 00 00 00 00
|
||||||
|
Page 136: 00 00 00 00
|
||||||
|
Page 137: 00 00 00 00
|
||||||
|
Page 138: 00 00 00 00
|
||||||
|
Page 139: 00 00 00 00
|
||||||
|
Page 140: 00 00 00 00
|
||||||
|
Page 141: 00 00 00 00
|
||||||
|
Page 142: 00 00 00 00
|
||||||
|
Page 143: 00 00 00 00
|
||||||
|
Page 144: 00 00 00 00
|
||||||
|
Page 145: 00 00 00 00
|
||||||
|
Page 146: 00 00 00 00
|
||||||
|
Page 147: 00 00 00 00
|
||||||
|
Page 148: 00 00 00 00
|
||||||
|
Page 149: 00 00 00 00
|
||||||
|
Page 150: 00 00 00 00
|
||||||
|
Page 151: 00 00 00 00
|
||||||
|
Page 152: 00 00 00 00
|
||||||
|
Page 153: 00 00 00 00
|
||||||
|
Page 154: 00 00 00 00
|
||||||
|
Page 155: 00 00 00 00
|
||||||
|
Page 156: 00 00 00 00
|
||||||
|
Page 157: 00 00 00 00
|
||||||
|
Page 158: 00 00 00 00
|
||||||
|
Page 159: 00 00 00 00
|
||||||
|
Page 160: 00 00 00 00
|
||||||
|
Page 161: 00 00 00 00
|
||||||
|
Page 162: 00 00 00 00
|
||||||
|
Page 163: 00 00 00 00
|
||||||
|
Page 164: 00 00 00 00
|
||||||
|
Page 165: 00 00 00 00
|
||||||
|
Page 166: 00 00 00 00
|
||||||
|
Page 167: 00 00 00 00
|
||||||
|
Page 168: 00 00 00 00
|
||||||
|
Page 169: 00 00 00 00
|
||||||
|
Page 170: 00 00 00 00
|
||||||
|
Page 171: 00 00 00 00
|
||||||
|
Page 172: 00 00 00 00
|
||||||
|
Page 173: 00 00 00 00
|
||||||
|
Page 174: 00 00 00 00
|
||||||
|
Page 175: 00 00 00 00
|
||||||
|
Page 176: 00 00 00 00
|
||||||
|
Page 177: 00 00 00 00
|
||||||
|
Page 178: 00 00 00 00
|
||||||
|
Page 179: 00 00 00 00
|
||||||
|
Page 180: 00 00 00 00
|
||||||
|
Page 181: 00 00 00 00
|
||||||
|
Page 182: 00 00 00 00
|
||||||
|
Page 183: 00 00 00 00
|
||||||
|
Page 184: 00 00 00 00
|
||||||
|
Page 185: 00 00 00 00
|
||||||
|
Page 186: 00 00 00 00
|
||||||
|
Page 187: 00 00 00 00
|
||||||
|
Page 188: 00 00 00 00
|
||||||
|
Page 189: 00 00 00 00
|
||||||
|
Page 190: 00 00 00 00
|
||||||
|
Page 191: 00 00 00 00
|
||||||
|
Page 192: 00 00 00 00
|
||||||
|
Page 193: 00 00 00 00
|
||||||
|
Page 194: 00 00 00 00
|
||||||
|
Page 195: 00 00 00 00
|
||||||
|
Page 196: 00 00 00 00
|
||||||
|
Page 197: 00 00 00 00
|
||||||
|
Page 198: 00 00 00 00
|
||||||
|
Page 199: 00 00 00 00
|
||||||
|
Page 200: 00 00 00 00
|
||||||
|
Page 201: 00 00 00 00
|
||||||
|
Page 202: 00 00 00 00
|
||||||
|
Page 203: 00 00 00 00
|
||||||
|
Page 204: 00 00 00 00
|
||||||
|
Page 205: 00 00 00 00
|
||||||
|
Page 206: 00 00 00 00
|
||||||
|
Page 207: 00 00 00 00
|
||||||
|
Page 208: 00 00 00 00
|
||||||
|
Page 209: 00 00 00 00
|
||||||
|
Page 210: 00 00 00 00
|
||||||
|
Page 211: 00 00 00 00
|
||||||
|
Page 212: 00 00 00 00
|
||||||
|
Page 213: 00 00 00 00
|
||||||
|
Page 214: 00 00 00 00
|
||||||
|
Page 215: 00 00 00 00
|
||||||
|
Page 216: 00 00 00 00
|
||||||
|
Page 217: 00 00 00 00
|
||||||
|
Page 218: 00 00 00 00
|
||||||
|
Page 219: 00 00 00 00
|
||||||
|
Page 220: 00 00 00 00
|
||||||
|
Page 221: 00 00 00 00
|
||||||
|
Page 222: 00 00 00 00
|
||||||
|
Page 223: 00 00 00 00
|
||||||
|
Page 224: 00 00 00 00
|
||||||
|
Page 225: 00 00 00 00
|
||||||
|
Page 226: 00 00 00 BD
|
||||||
|
Page 227: 04 00 00 FF
|
||||||
|
Page 228: 00 05 00 00
|
||||||
|
Page 229: 00 00 00 00
|
||||||
|
Page 230: 00 00 00 00
|
||||||
|
Failed authentication attempts: 0
|
||||||
@@ -0,0 +1,41 @@
|
|||||||
|
Filetype: Flipper NFC device
|
||||||
|
Version: 3
|
||||||
|
# Nfc device type can be UID, Mifare Ultralight, Mifare Classic
|
||||||
|
Device type: Mifare Ultralight 11
|
||||||
|
# UID, ATQA and SAK are common for all formats
|
||||||
|
UID: 04 15 74 F2 B0 5E 81
|
||||||
|
ATQA: 00 44
|
||||||
|
SAK: 00
|
||||||
|
# Mifare Ultralight specific data
|
||||||
|
Data format version: 1
|
||||||
|
Signature: A4 37 7D E5 8C 2F 88 D8 04 60 41 6E 3A C8 CD DB 19 94 26 12 C5 D0 12 B0 EB 88 05 72 89 F2 A5 61
|
||||||
|
Mifare version: 00 04 03 01 01 00 0B 03
|
||||||
|
Counter 0: 0
|
||||||
|
Tearing 0: BD
|
||||||
|
Counter 1: 0
|
||||||
|
Tearing 1: BD
|
||||||
|
Counter 2: 0
|
||||||
|
Tearing 2: BD
|
||||||
|
Pages total: 20
|
||||||
|
Pages read: 20
|
||||||
|
Page 0: 04 15 74 ED
|
||||||
|
Page 1: F2 B0 5E 81
|
||||||
|
Page 2: 9D 48 F8 FF
|
||||||
|
Page 3: C1 31 3E 3F
|
||||||
|
Page 4: B0 00 F0 02
|
||||||
|
Page 5: 2F B3 45 A0
|
||||||
|
Page 6: D4 9C 02 F2
|
||||||
|
Page 7: 4A B1 ED FF
|
||||||
|
Page 8: C8 01 00 02
|
||||||
|
Page 9: 4F B3 46 70
|
||||||
|
Page 10: EE F6 60 B0
|
||||||
|
Page 11: B6 C6 12 1B
|
||||||
|
Page 12: B9 1E 49 C3
|
||||||
|
Page 13: 49 DF 7A 57
|
||||||
|
Page 14: 08 52 2A 11
|
||||||
|
Page 15: 28 0A 28 59
|
||||||
|
Page 16: 00 00 00 FF
|
||||||
|
Page 17: 00 05 00 00
|
||||||
|
Page 18: FF FF FF FF
|
||||||
|
Page 19: 00 00 00 00
|
||||||
|
Failed authentication attempts: 0
|
||||||
@@ -0,0 +1,62 @@
|
|||||||
|
Filetype: Flipper NFC device
|
||||||
|
Version: 3
|
||||||
|
# Nfc device type can be UID, Mifare Ultralight, Mifare Classic
|
||||||
|
Device type: Mifare Ultralight 21
|
||||||
|
# UID, ATQA and SAK are common for all formats
|
||||||
|
UID: 34 BF AB B1 AE 73 D6
|
||||||
|
ATQA: 00 44
|
||||||
|
SAK: 00
|
||||||
|
# Mifare Ultralight specific data
|
||||||
|
Data format version: 1
|
||||||
|
Signature: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
Mifare version: 00 34 21 01 01 00 0E 03
|
||||||
|
Counter 0: 0
|
||||||
|
Tearing 0: 00
|
||||||
|
Counter 1: 0
|
||||||
|
Tearing 1: 00
|
||||||
|
Counter 2: 0
|
||||||
|
Tearing 2: 00
|
||||||
|
Pages total: 41
|
||||||
|
Pages read: 41
|
||||||
|
Page 0: 34 BF AB A8
|
||||||
|
Page 1: B1 AE 73 D6
|
||||||
|
Page 2: BA 00 70 08
|
||||||
|
Page 3: FF FF FF FC
|
||||||
|
Page 4: 45 D9 BB A0
|
||||||
|
Page 5: 5D 9D FA 00
|
||||||
|
Page 6: 80 70 38 40
|
||||||
|
Page 7: 12 30 02 00
|
||||||
|
Page 8: 00 00 00 00
|
||||||
|
Page 9: 00 00 00 00
|
||||||
|
Page 10: AC A1 0D E4
|
||||||
|
Page 11: 80 70 38 40
|
||||||
|
Page 12: 00 57 A0 01
|
||||||
|
Page 13: 00 08 C1 40
|
||||||
|
Page 14: 00 00 00 00
|
||||||
|
Page 15: AC A1 0D E4
|
||||||
|
Page 16: 00 00 00 00
|
||||||
|
Page 17: 00 00 00 00
|
||||||
|
Page 18: 00 00 00 00
|
||||||
|
Page 19: 00 00 00 00
|
||||||
|
Page 20: 00 00 00 00
|
||||||
|
Page 21: 00 00 00 00
|
||||||
|
Page 22: 00 00 00 00
|
||||||
|
Page 23: 00 00 00 00
|
||||||
|
Page 24: 00 00 00 00
|
||||||
|
Page 25: 00 00 00 00
|
||||||
|
Page 26: 00 00 00 00
|
||||||
|
Page 27: 00 00 00 00
|
||||||
|
Page 28: 00 00 00 00
|
||||||
|
Page 29: 00 00 00 00
|
||||||
|
Page 30: 00 00 00 00
|
||||||
|
Page 31: 00 00 00 00
|
||||||
|
Page 32: 00 00 00 00
|
||||||
|
Page 33: 00 00 00 00
|
||||||
|
Page 34: 00 00 00 00
|
||||||
|
Page 35: 00 00 00 00
|
||||||
|
Page 36: 00 00 00 BD
|
||||||
|
Page 37: 00 00 00 FF
|
||||||
|
Page 38: 00 05 00 00
|
||||||
|
Page 39: FF FF FF FF
|
||||||
|
Page 40: 00 00 00 00
|
||||||
|
Failed authentication attempts: 0
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
Yo dawg, I heard you like md5...
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user