You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
* Music (control the playback of music on your phone)
45
-
* Heart rate (measure your heart rate)
46
-
* Navigation (displays navigation instructions coming from the companion app)
47
-
* Notification (displays the last notification received)
48
-
* Paddle (single player pong-like game)
49
-
* Twos (2048 clone game)
50
-
* Stopwatch
51
-
* Steps (displays the number of steps taken)
52
-
* Timer (set a countdown timer that will notify you when it expires)
53
-
* Metronome (vibrates to a given bpm with a customizable beats per bar)
54
-
- User settings:
55
-
* Display timeout
56
-
* Wake-up condition
57
-
* Time format (12/24h)
58
-
* Default watch face
59
-
* Daily step goal
60
-
* Battery status
61
-
* Firmware validation
62
-
* System information
63
-
- Supported by 3 companion apps (development is in progress):
64
-
*[Gadgetbridge](https://codeberg.org/Freeyourgadget/Gadgetbridge/) (on Android via F-Droid)
65
-
*[Amazfish](https://openrepos.net/content/piggz/amazfish) (on SailfishOS and Linux)
66
-
*[Siglo](https://github.com/alexr4535/siglo) (on Linux)
67
-
***[Experimental]**[WebBLEWatch](https://hubmartin.github.io/WebBLEWatch/) Synchronize time directly from your web browser. [video](https://youtu.be/IakiuhVDdrY)
68
-
***[Experimental]**[InfiniLink](https://github.com/xan-m/InfiniLink) (on iOS)
69
-
- OTA (Over-the-air) update via BLE
70
-
-[Bootloader](https://github.com/JF002/pinetime-mcuboot-bootloader) based on [MCUBoot](https://www.mcuboot.com)
11
+
-[Getting started with InfiniTime](doc/gettingStarted/gettingStarted-1.0.md)
12
+
-[About the software and updating](doc/gettingStarted/updating-software.md)
- Add more BLE functionalities : call notifications, agenda, configuration, data logging,...
122
-
- Measure power consumption and improve battery life
123
-
- Improve documentation, take better pictures and video than mine
124
-
- Improve the UI
125
-
- Create companion app for multiple OSes (Linux, Android, iOS) and platforms (desktop, ARM, mobile). Do not forget the other devices from Pine64 like [the Pinephone](https://www.pine64.org/pinephone/) and the [Pinebook Pro](https://www.pine64.org/pinebook-pro/).
126
-
- Design a simple CI (preferably self-hosted and easy to reproduce).
50
+
Do not hesitate to fork the code, hack it and create pull-requests!
127
51
128
-
Do not hesitate to clone/fork the code, hack it and create pull-requests. I'll do my best to review and merge them :)
52
+
Read this page for more information on how you can help: [How to contribute?](doc/contribute.md)
Download the files **bootloader.bin**, **image-x.y.z.bin** and **pinetime-graphics-x.y.z.bin** from the release page:
3
+
4
+

5
+
6
+
The bootloader reads a boot logo from the external SPI flash memory. The first step consists of flashing a tool in the MCU that will flash the boot logo into this SPI flash memory. This first step is optional but recommended (the bootloader will display garbage on screen for a few second if you don't do it).
7
+
Using your SWD tool, flash **pinetime-graphics-x.y.z.bin** at offset **0x0000**. Reset the MCU and wait for a few second, until the logo is completely drawn on the display.
8
+
9
+
Then, using your SWD tool, flash those file at specific offset:
10
+
11
+
- bootloader.bin : **0x0000**
12
+
- image-x.y.z.bin : **0x8000**
13
+
14
+
Reset and voilà, you're running InfiniTime on your PineTime!
[Gadgetbridge](https://gadgetbridge.org/) is an Android application that supports many smartwatches and fitness trackers.
3
3
4
-
The integration of InfiniTime (previously Pinetime-JF) is now merged into the master branch (https://codeberg.org/Freeyourgadget/Gadgetbridge/) and initial support is available [starting with version 0.47](https://codeberg.org/Freeyourgadget/Gadgetbridge/src/branch/master/CHANGELOG.md). Note that the official version is only available on F-Droid (as of May 2021), and the unofficial fork available on the Play Store is outdated and does not support Infinitime.
4
+
Gadgetbridge supports InfiniTime [starting with version 0.47](https://codeberg.org/Freeyourgadget/Gadgetbridge/src/branch/master/CHANGELOG.md). Note that the official version is only available on F-Droid (as of May 2021), and the unofficial fork available on the Play Store is outdated and does not support InfiniTime.
5
5
6
-
## Features
7
-
The following features are implemented:
8
-
- Scanning & detection of Pinetime-JF / InfiniTime
9
-
- Connection / disconnection
10
-
- Notifications
11
-
12
6
## Demo
13
-
[This video](https://seafile.codingfield.com/f/0a2920b9d765462385e4/) shows how to scan, connect, send notification (using the debug screen) and disconnect from the Pinetime.
7
+
[This video](https://seafile.codingfield.com/f/0a2920b9d765462385e4/) shows how to scan, connect, send notification (using the debug screen) and disconnect from the PineTime.
Copy file name to clipboardExpand all lines: doc/gettingStarted/gettingStarted-1.0.md
+13-88Lines changed: 13 additions & 88 deletions
Display the source diff
Display the rich diff
Original file line number
Diff line number
Diff line change
@@ -1,91 +1,23 @@
1
-
# Getting started with InfiniTime 1.0
1
+
# Getting started with InfiniTime 1.0.0
2
2
3
-
On April 22 2021, InfiniTime and Pine64 [announced the release of InfiniTime 1.0](https://www.pine64.org/2021/04/22/its-time-infinitime-1-0/) and the availability of PineTime smartwatches as *enthusiast grade end-user product*. This page aims to guide you with your first step with your new PineTime.
3
+
On April 22 2021, InfiniTime and Pine64 [announced the release of InfiniTime 1.0.0](https://www.pine64.org/2021/04/22/its-time-infinitime-1-0/) and the availability of PineTime smartwatches as *enthusiast grade end-user product*. This page aims to guide you with your first step with your new PineTime.
4
4
5
-
## Firmware, InfiniTime, Bootloader, Recovery firmware, OTA, DFU... What is it?
5
+
It is highly recommended to update the firmware to the latest version when you receive your watch and when a new InfiniTime version is released. More information on updating the firmware [here](/doc/gettingStarted/updating-software.md).
6
6
7
-
You might have already seen these words by reading the announcement, release notes, or [the wiki guide](https://wiki.pine64.org/wiki/Upgrade_PineTime_to_InfiniTime_1.0.0) and, you may find them misleading if you're not familiar with the project.
7
+
## InfiniTime 1.0.0 quick user guide
8
8
9
-
Basically, a **firmware** is just a software running on the embedded hardware of a device, the PineTime in this case.
10
-
**InfiniTime** is based on 3 distinct **firmwares**:
11
-
-**[InfiniTime](https://github.com/InfiniTimeOrg/InfiniTime)** itself, this is the *application firmware* running on the PineTime. This is the main firmware which provides most of the functionalities you'll use on a daily basis : bluetooth low-energy (BLE) connectivity, applications, watchfaces,...
12
-
-**[The bootloader](https://github.com/JF002/pinetime-mcuboot-bootloader)** is responsible for safely applying **updates** of the *application firmware*, reverting them in case of issues and load the recovery firmware when requested.
13
-
-**The recovery firmware** is a specific *application firmware* than can be loaded by the bootloader on user request. This firmware can be useful in case of serious issue, when the main application firmware cannot perform an OTA update correctly. Currently, this recovery firmware is based on [InfiniTime 0.14.1](https://github.com/InfiniTimeOrg/InfiniTime/releases/tag/0.14.1).
14
-
15
-
**OTA** and **DFU** refer to the update of the firmware over BLE (**B**luetooth **L**ow **E**nergy). **OTA** means **O**ver **T**he **A**ir, this is a functionality that allows the user to update the firmware how their device using a wireless communication like BLE. When we talk about **DFU** (**D**evice **F**irmware **U**pdate), we refer to the file format and protocol used to send the update of the firmware to the watch over-the-air. InfiniTime implement the (legacy) DFU protocol from Nordic Semiconductor (NRF).
16
-
17
-
## How to check the version of InfiniTime and the bootloader?
18
-
19
-
Since September 2020, all PineTimes (devkits or sealed) are flashed using the **[first iteration of the bootloader](https://github.com/lupyuen/pinetime-rust-mynewt/releases/tag/v4.1.7)** and **[InfiniTime 0.7.1](https://github.com/InfiniTimeOrg/InfiniTime/releases/tag/0.7.1)**. There was no recovery firmware at that time.
20
-
21
-
The bootloader only runs when the watch starts (from an empty battery, for example) or after a reset (after a successful OTA or a manual reset - long push on the button).
22
-
23
-
You can recognize this first iteration of the bootloader with it greenish **PINETIME** logo.
24
-
25
-

26
-
27
-
You can check the version of InfiniTime by opening the app *SystemInfo*. For version < 1.0:
PineTime shipped from June 2021 (to be confirmed) will be flashed with the [new version of the bootloader](https://github.com/JF002/pinetime-mcuboot-bootloader/releases/tag/1.0.0), the [recovery firmware](https://github.com/InfiniTimeOrg/InfiniTime/releases/tag/0.14.1) and [InfiniTime 1.0](https://github.com/InfiniTimeOrg/InfiniTime/releases/tag/1.0.0).
37
-
38
-
The bootloader is easily recognizable with it white pine cone that is progressively drawn in green. It also displays its own version on the bottom (1.0.0 as of now).
39
-
40
-

41
-
42
-
## How to update your PineTime?
43
-
44
-
To update your PineTime, you can use one of the compatible companion applications. Here are the main ones:
45
-
46
-
-**[Amazfish](https://github.com/piggz/harbour-amazfish)** (Desktop Linux, mobile Linux, SailfishOS, runs on the PinebookPro and the Pinephone)
See [this page](ota-gadgetbridge-nrfconnect.md) for more info about the OTA procedure using Gadgetbridge and NRFConnect.
52
-
53
-
### From InfiniTime 0.7.1 / old bootloader
54
-
55
-
If your PineTime is currently running InfiniTime 0.7.1 and the old bootloader, we strongly recommend you update them to more recent version (Bootloader 1.0.0 and InfiniTime 1.0.0 as of now). We also recommend you install the recovery firmware once the bootloader is up-do-date.
56
-
57
-
Using the companion app of your choice, you'll need to apply the OTA procedure for these 3 firmwares in this sequence (failing to follow this specific order might temporarily or permanently brick your device):
58
-
59
-
1. Flash the latest version of InfiniTime. The file to upload is named **pinetime-mcuboot-app-dfu-x.y.z.zip**. Here is the link to [InfiniTime 1.0](https://github.com/InfiniTimeOrg/InfiniTime/releases/download/1.0.0/pinetime-mcuboot-app-dfu-1.0.0.zip).
60
-
2. Update the bootloader by applying the OTA procedure with the file named [**reloader-mcuboot.zip** from the repo of the bootloader](https://github.com/JF002/pinetime-mcuboot-bootloader/releases/download/1.0.0/reloader-mcuboot.zip).
61
-
3. Install the recovery firmware by applying the OTA procedure with the file named [**pinetime-mcuboot-recovery-loader-dfu-0.14.1.zip** from the version 0.14.1 of InfiniTime](https://github.com/InfiniTimeOrg/InfiniTime/releases/download/0.14.1/pinetime-mcuboot-recovery-loader-dfu-0.14.1.zip).
62
-
63
-
You'll find more info about this process in [this wiki page](https://wiki.pine64.org/wiki/Upgrade_PineTime_to_InfiniTime_1.0.0). You can also see the procedure in video [here](https://video.codingfield.com/videos/watch/831077c5-16f3-47b4-9b2b-c4bbfecc6529) and [here (from Amazfish)](https://video.codingfield.com/videos/watch/f7bffb3d-a6a1-43c4-8f01-f4aeff4adf9e)
64
-
65
-
### From version > 1.0
66
-
67
-
If you are already running the new "1.0.0" bootloader, all you have to do is update your version of InfiniTime when it'll be available. We'll write specific instructions when (if) we release a new version of the bootloader.
68
-
69
-
### Firmware validation
70
-
71
-
The bootloader requires a (manual) validation of the firmware. If the watch reset with an updated firmware that was not validated, the bootloader will consider it as non-functioning and will revert to the previous version of the firmware. This is a safety feature to prevent bricking your device with a faulty firmware.
72
-
73
-
You can validate your updated firmware on InfiniTime >= 1.0 by following this simple procedure:
74
-
75
-
- From the watchface, swipe **right** to display the *Quick Actions menu*
76
-
- Open the **Settings** app by tapping the *gear* icon on the bottom right
77
-
- Swipe down and tap on the entry named **Firmware**
78
-
- This app shows the version that is currently running. If it's not validated yet, it displays 2 buttons:
79
-
-**Validate** to validate your firmware
80
-
-**Reset** to reset the watch and revert to the previously running version of the firmware
9
+
### Setting the time
81
10
82
-
## InfiniTime 1.0 quick user guide
11
+
By default, InfiniTime starts on the digital watchface. It'll probably display the epoch time (1 Jan 1970, 00:00).
83
12
84
-
### Setting the time
13
+
You can sync the time using companion apps.
85
14
86
-
By default, InfiniTime starts on the digital watchface. It'll probably display the epoch time (1 Jan 1970, 00:00). The time will be automatically synchronized once you connect on of the companion app to your PineTime using BLE connectivity. InfiniTime does not provide any way to manually set the time for now.
15
+
- Gadgetbridge automatically synchronizes the time when you connect it to your watch. More information on Gadgetbridge [here](/doc/gettingStarted/ota-gadgetbridge.md)
16
+
- You can use NRFConnect to [sync the time](/doc/gettingStarted/time-nrfconnect.md)
17
+
- Sync the time with your browser https://hubmartin.github.io/WebBLEWatch/
18
+
- Since InfiniTime 1.7.0, you can set the time in the settings without needing to use a companion app
87
19
88
-
###Navigation in the menu
20
+
## Navigation in the menu
89
21
90
22

91
23

@@ -98,14 +30,7 @@ By default, InfiniTime starts on the digital watchface. It'll probably display t
98
30
- Start the **flashlight** app
99
31
- Enable/disable vibrations on notifications (Do Not Disturb mode)
0 commit comments