From 5170b974913129bce381d3061d967767a064f2f0 Mon Sep 17 00:00:00 2001 From: Daniel Thompson Date: Sun, 17 Jan 2021 14:55:57 +0000 Subject: [PATCH] docs: appguide: Document how to upload pre-compiled files Signed-off-by: Daniel Thompson --- TODO.rst | 6 ++++-- docs/appguide.rst | 36 ++++++++++++++++++++++++++++++++++-- 2 files changed, 38 insertions(+), 4 deletions(-) diff --git a/TODO.rst b/TODO.rst index 42480ef..8924bf9 100644 --- a/TODO.rst +++ b/TODO.rst @@ -29,6 +29,8 @@ Micropython * [ ] Use SoftDevice sleep logic * [ ] Fix BLE hangs +* [ ] Allow asynchronous control of the SPI chip select signals (this will + allow for double buffered graphics updates) Wasp-os ~~~~~~~ @@ -76,9 +78,9 @@ Wasp-os * [X] Introduce an analog watch face * [X] Add a configuration tool to enable disable applications -* [ ] Documentation +* [X] Documentation - * [ ] Describe how to upload pre-compiled modules + * [X] Describe how to upload pre-compiled modules 0.3 (a.k.a. M3): Smartwatch --------------------------- diff --git a/docs/appguide.rst b/docs/appguide.rst index 5da8c7d..9f3cc01 100644 --- a/docs/appguide.rst +++ b/docs/appguide.rst @@ -298,8 +298,10 @@ takes around five seconds). Once the watch is in OTA mode then press the phyiscal button again to return to normal mode with the application cleared out. -Making it permanent -~~~~~~~~~~~~~~~~~~~ +.. _Uploading in source code form: + +Uploading in source code form +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ To ensure you application survives a reboot then we must copy it to the device and ensure it gets launched during system startup. @@ -351,6 +353,36 @@ to the watch: startup. If that happens, and you don't know how to debug the problem, then you can use wasptool to restore the original version of main.py . +Uploading in binary form +~~~~~~~~~~~~~~~~~~~~~~~~ + +Some applications are too large to be compiled on the target. These applications +need to be pre-compiled and can then either be uploaded in binary form to the +wasp-os filesystem or +:ref:`included in the firmware image` +to further reduce the RAM overhead. + +To pre-compile your application: + +.. code-block:: sh + + sh$ ./micropython/mpy-cross/mpy-cross -mno-unicode -march=armv7m myapp.py + +To copy the binary to the wasp-os filesystem try: + +.. code-block:: sh + + sh$ ./tools/wasptool --binary --upload myapp.mpy + Uploading myapp.mpy: + [##################################################] 100% + +At this point your application is stored on the external FLASH but it will +not automatically be loaded but it can be imported using ``import myapp``. +The application can be registered from ``main.py`` using exactly the same +technique as :ref:`uploads in source code`. + +.. _Freezing your application into the wasp-os binary: + Freezing your application into the wasp-os binary ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~