-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
8 changed files
with
60 additions
and
21 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,24 +1,18 @@ | ||
# MicroPython Flipper Zero | ||
|
||
This branch contains the research of adding [Python](https://www.python.org) support to the famous [Flipper Zero](https://flipperzero.one/) gadget. | ||
~~The content of this repository is just work in progress at the moment. | ||
But the first working examples already look promising.~~ | ||
The research phase was successful and the development has moved to a [fork of the original firmware](https://github.com/ofabel/flipperzero-firmware). | ||
This branch contains the [FAP](https://developer.flipper.net/flipperzero/doxygen/apps_on_sd_card.html) version of the [MicroPython](https://micropython.org/) support for the famous [Flipper Zero](https://flipperzero.one/) gadget. | ||
The results of the preceding research phase is still available in the [poc](https://github.com/ofabel/mp-flipper/tree/poc) branch. | ||
The [lib](https://github.com/ofabel/mp-flipper/tree/lib) branch of this repository contains just the MicroPython library. | ||
The progress of further research on what can be achieved when moving functionality to the firmware can be found in the [fork of the original firmware](https://github.com/ofabel/flipperzero-firmware). | ||
|
||
Check the progress in this [issue](https://github.com/flipperdevices/flipperzero-firmware/issues/3559) and feel free to share your thoughts and ideas. | ||
|
||
## Requirements | ||
|
||
* [Git](https://git-scm.com/) | ||
* [Make](https://www.gnu.org/software/make/) | ||
* [uFBT](https://pypi.org/project/ufbt/) available in your `PATH` (or you have to adjust the [Makefile](./Makefile) | ||
* [Flipper Zero](https://flipperzero.one/) (tested with firmware version 0.99.1 and 0.100.3) | ||
|
||
For compiling MicroPython, you will also need: | ||
|
||
* [gcc](https://gcc.gnu.org/) | ||
* [Arm GNU Toolchain](https://developer.arm.com/Tools%20and%20Software/GNU%20Toolchain) (e.g. `gcc-arm-none-eabi` on Ubuntu) | ||
* [uFBT](https://pypi.org/project/ufbt/) available in your `PATH` (or you have to adjust the [Makefile](./Makefile)) | ||
* [Flipper Zero](https://flipperzero.one/) (tested with firmware versions 0.99.1 and 0.100.3) | ||
|
||
## Setup | ||
|
||
|
@@ -28,7 +22,7 @@ git clone --recurse-submodules [email protected]:ofabel/mp-flipper.git | |
|
||
## Build | ||
|
||
Since this application requires a 3th party library, more than just a simple `ufbt build` is needed to build the application: | ||
Just open a terminal and run the Makefile targets: | ||
|
||
```bash | ||
make build | ||
|
@@ -40,13 +34,36 @@ You can also build an launch the application on the attached Flipper Zero device | |
make launch | ||
``` | ||
|
||
## Install | ||
|
||
To install a [release](https://github.com/ofabel/mp-flipper/releases) by hand, just copy the `mp_flipper_app.fap` file on the SD card of your flipper (e.g. using the [qFlipper](https://flipperzero.one/downloads) app): | ||
|
||
 | ||
|
||
You should now be able to start the application on your Flipper: Apps > Tools > uPython | ||
|
||
_You might need to unconnect qFlipper first to free some space in SRAM._ | ||
|
||
## Usage | ||
|
||
The application just starts with an open file browser. | ||
Here you can select any Python file to compile and execute from the SD card. | ||
Just place your Python files somewhere on the SD card. | ||
|
||
The application just starts with an open file browser: | ||
|
||
 | ||
|
||
Here you can select any Python file to compile and execute from the SD card: | ||
|
||
 | ||
|
||
## Disclaimer | ||
|
||
**This is work in progress and just a proof of concept.** | ||
The produced application has very limited functionality at the moment and since the whole application runs in the SRAM there is not much space left. | ||
However, the Python application itself can use about 16 kB of heap space (minus up to 2 kB for the stack). | ||
This FAP version requires about 120 kB from SRAM to start (needed for the Python runtime and compiler). | ||
Due to memory fragmentation it's possible, that the application crashes when you start it (tested with the original 0.100.3 firmware). | ||
If this happens, just try again (the crash doesn't harm your device). | ||
|
||
**This is still work in progress, but already more than just a proof of concept.** | ||
|
||
There is no documentation of the `flipperzero` module. | ||
Just checkout the [examples](./examples/) for the syntax. | ||
Sadly, REPL support is only available in fhe [firmware fork](https://github.com/ofabel/flipperzero-firmware) version. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Submodule micropython
updated
3 files
+1 −1 | genhdr/mpversion.h | |
+4 −0 | genhdr/qstrdefs.generated.h | |
+2 −1 | mp_flipper_config.h |