diff --git a/README.rst b/README.rst index 907067d..08a3253 100644 --- a/README.rst +++ b/README.rst @@ -115,52 +115,26 @@ Finally to test out ideas and concepts on the simulator try: See :ref:`Testing on the simulator` for more details on how to use the simulator. -Installing ----------- +Getting Started +--------------- -Use an SWD programmer to install ``bootloader.hex`` to the PineTime. -This file is an Intel HEX file containing both the bootloader and the Nordic -SoftDevice. Once the bootloader is installed the watch will boot, display the -Pine64 logo and wait for a OTA update. +Wasp-os can be installed without using any tools onto the following +devices: -See the `PineTime SWD programming guide <https://wiki.pine64.org/index.php/Reprogramming_the_PineTime>`_ -for instructions on how to reprogram the PineTime using various different SWD -programmers. + * Pine64 PineTime (developer edition) + * Colmi P8 -.. note:: +The +`Installation Guide <https://wasp-os.readthedocs.io/en/latest/install.html>`_ +contains detailed instructions on how to install wasp-os. - If you have a new PineTime then it will have been delivered with flash - protection enabled. You must disable the flash protection before trying to - program it. - - Be careful to disconnect cleanly from the debug software since just pulling - out the SWD cable will mean the nRF52 will still believe it is being - debugged (which harms battery life because the device won't properly enter - deep sleep states). - -To install the main firmware using an Android device: - -* Copy ``micropython.zip`` to your Android device and download nRF Connect - for Android if you do not already have it. -* In nRF Connect, choose settings and reduce the DFU packet count from - 10 to 4. -* Connect to PineDFU using nRFConnect, click the DFU button and send - ``micropython.zip`` to the device. - -Alternatively, to install the main firmware from a GNU/Linux workstation: - -* Look up the MAC address for your watch (try: ``sudo hcitool lescan``\ ). -* Use ota-dfu to upload ``micropython.zip`` to the device. For example: - ``tools/ota-dfu/dfu.py -z micropython.zip -a A0:B1:C2:D3:E3:F5 --legacy`` - -At the end of this process your watch will show the time (03:00) together -with a date and battery meter. When the watch goes into power saving mode -you can use the side button to wake it again. +At the end of the install process your watch will show the time (03:00) +together with a date and battery meter. When the watch goes into power +saving mode you can use the button to wake it again. At this point you will also be able to use the Nordic UART Service to -access the MicroPython REPL, although currently you must send ^C to -interrupt the program that updates the watch display. You can use -``tools/wasptool --console`` to access the MicroPython REPL. +access the MicroPython REPL. You can use ``tools/wasptool --console`` +to access the MicroPython REPL. To set the time and restart the main application: diff --git a/docs/index.rst b/docs/index.rst index c88f8c4..9d4810a 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -11,6 +11,7 @@ Welcome to WASP-OS's documentation! :caption: Contents: README + install appguide wasp TODO diff --git a/docs/install.rst b/docs/install.rst new file mode 100644 index 0000000..2caaccd --- /dev/null +++ b/docs/install.rst @@ -0,0 +1,149 @@ +Installation Guide +================== + +.. contents:: + :local: + +Device Support +-------------- + +wasp-os can run on multiple devices and, in time, will hopefully be ported to +many more. + +In terms of deciding which device to buy we can suggest two criteria to help. + +The first is simply based on aesthetic appeal. A watch is something that you +take everywhere and sits somewhere between clothing and jewellery. That means +it is important to choose a device that feels good on the wrist and +looks right when you glance at it. Aesthetics matter! + +The second criteria is more subtle. In most cases, there is really not really +many important technical differences between the devices. They all use a Nordic +chipset and have the same display controller running a 240x240 panel. So the +second criteria is not technical, it is about community. The Pine64 PineTime is +unique among the devices supported by wasp-os because it is intended that the +watch be used to run a variety of different open source or free software +operating systems. By selling a watch with the intention that it be hacked +every which way from Sunday then we get a bigger stronger community focused on +the PineTime. There is a strong support forum, multiple different OS developers +(who share ideas and knowledge even if hacking on very different code bases) +combined with a reasonable set of hardware documentation. + +There's definitely a lot of fun to be had buying something off-the-shelf and +hacking it to become something the manufacturer never intended. We know +this because we've done it! However the hackable devices are sold for +relatively short periods and may experience undocumented technical changes +between manufacturing runs. This makes it hard for a community to form +around any particular device. + +Thus the second criteria it to think about your own needs and abilities. +If you want to enjoy the social and community aspects of open source +watch development then you should look very closely at the PineTime. + +Pine64 PineTime (developer edition) +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Pine64 PineTime is a square smart watch based on an nRF52832 SoC and +includes a 240x240 colour display with touch screen, a step counter and +a heart rate sensor. + +The developer edition comes pre-programmed with a test firmware that +is used as part of the factory testing. Both the wasp-bootloader and +the main OS image can be installed onto a developer edition PineTime +using DaFlasher for Android. No tools are required to install using +DaFlasher. + +Since the developer edition comes without the case glued shut it is +also possible to install the wasp-bootloader using an SWD programmer. + +Colmi P8 +~~~~~~~~ + +The Colmi P8 is an almost square smart watch based on an nRF52832 SoC +and includes a 240x240 colour display with touch screen, a step counter +and a heart rate sensor. + +Both the wasp-bootloader and the main OS image can be installed onto a +P8 using DaFlasher for Android. No tools are required. + +Installing wasp-bootloader using DaFlasher for Android +------------------------------------------------------ + +For all the DaFit family of smart watches (including the developer +edition of the Pine64 PineTime) the install instructions are the +same although it is important to ensure that both ``bootloader-daflasher.zip`` +and ``micropython.zip`` match the device you are installing on. There are +no runtime checks. + +.. image:: https://img.youtube.com/vi/VJoDtMy-4pk/0.jpg + :target: https://www.youtube.com/watch?v=VJoDtMy-4pk + :alt: Installing MicroPython on a Colmi P8 smart watch using DaFlasher + :width: 320 + :height: 240 + +`Installing MicroPython on a Colmi P8 smart watch using DaFlasher <https://www.youtube.com/watch?v=VJoDtMy-4pk>`_ + +.. warning:: + + The first step cannot be reversed. Once ``DaFitBootloader23Hacked.bin`` + has been installed the factory firmware will be permanently removed + from the device. + +Installing wasp-bootloader using an SWD programmer +-------------------------------------------------- + +There are many different SWD programmers that can be used to install +wasp-bootloader. Use the +`PineTime SWD programming guide <https://wiki.pine64.org/index.php/Reprogramming_the_PineTime>`_ +to lookup the specific instructions for your programmer. + +Use the SWD programmer to install ``bootloader.hex`` to the device. +This file is an Intel HEX file containing both the bootloader and the Nordic +SoftDevice. Once the bootloader is installed the watch will boot, display a +logo and wait for a OTA update. + +.. note:: + + If you have a new device then it may have been delivered with flash + protection enabled. You must disable the flash protection before trying to + program it. + + Be careful to disconnect cleanly from the debug software since just pulling + out the SWD cable will mean the nRF52 will still believe it is being + debugged (which harms battery life because the device won't properly enter + deep sleep states). + +Installing wasp-os using DaFlasher for Android +---------------------------------------------- + +To install the main firmware using DaFlasher for Android: + +* Copy ``micropython.zip`` to your Android device and download DaFlasher + if you do not already have it. +* Open the app and connect to the device (e.g. *PineDFU* if you have a + PineTime). +* Click **Do DFU Update**. +* Click **Select DFU file** and select ``micropython.zip``. +* When the upload is complete the watch will reboot and launch the digital + clock application. + +Installing wasp-os using nRF Connect for Android +------------------------------------------------ + +To install the main firmware using nRF Connect for Android: + +* Copy ``micropython.zip`` to your Android device and download nRF Connect + for Android if you do not already have it. +* Connect to the device (e.g. *PineDFU* if you have a PineTime) using + nRFConnect, click the DFU button and send ``micropython.zip`` to the device. +* When the upload is complete the watch will reboot and launch the digital + clock application. + +Installing wasp-os from a GNU/Linux workstation +----------------------------------------------- + +To install the main firmware from a GNU/Linux workstation: + +* Look up the MAC address for your watch (try: ``sudo hcitool lescan``\ ). +* Use ota-dfu to upload ``micropython.zip`` to the device. For example: + ``tools/ota-dfu/dfu.py -z micropython.zip -a A0:B1:C2:D3:E3:F5 --legacy``