• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Update
2
3## Introduction
4
5The Update subsystem helps you implement over the air \(OTA\) update of OpenHarmony devices. The update subsystem consists of the following:
6
7-   Packaging tool
8
9    The packaging tool is developed using Python and deployed on the PC to prepare update packages. It packages each update image, signs the update package, generates the update package execution script, and finally creates an update package. After the execution script is run on a OpenHarmony device, the device parses and executes the script to complete the update process.
10
11    The update package contains two files: **build\_tools.zip** and **update.bin**.
12
13    -   **build\_tools.zip**: update assistance tools, including the executable files and scripts.
14    -   **update.bin**: TLV-encoded file, in which update contents are serialized and stored in the TLV format.
15
16    The packaging tool signs the  **update.bin**  file and the generated update package \(**.zip**  file\) independently.
17
18-   Update service
19
20    The update service is used to search, download, and trigger updates.
21
22-   Updater
23
24    The updater is the core module of the update subsystem. It provides the following functions:
25
26    1.  Obtains update commands from the misc partition and executes different tasks depending on the commands.
27    2.  Decompresses the update package and verifies its validity.
28    3.  Starts the update process and parses the update script.
29    4.  Installs the related component packages based on the update script.
30    5.  Performs post-processing after the update is complete, for example, deleting the update package and recording the update status.
31
32-   Update app
33
34    The upgrade app is used to trigger search and download of update packages.
35
36
37Before you get started, familiarize yourself with the following concepts:
38
39-   OTA
40
41    OTA is an implementation of update over a wireless connection. The update package is downloaded to the device through a wireless connection. The device then performs update through the update subsystem.
42
43-   Full package
44
45    A full package is actually a complete image. The update subsystem writes the full package to a partition to update this partition.
46
47-   Differential package
48
49    A differential package is created based on the difference data of two specific versions \(source version and target version\), which is generated by using bsdiff.
50
51
52## Directory Structure<a name="section212mcpsimp"></a>
53
54```
55base/update             # Update subsystem repository
56├── app         	# Update app code
57├── packaging_tools     # Packaging tool code
58├── updater    		# Updater code
59│   ├── interfaces  	# External APIs
60│   ├── resources 	# UI image resources of the update subsystem, such as animations and progress bar images
61│   ├── services  	# Updater logic code
62│   └── utils  		# Common code of the update subsystem, including the string processing functions and file processing functions
63└── updateservice 	# Update service code
64```
65
66## Repositories Involved<a name="section251mcpsimp"></a>
67
68**Update subsystem**
69
70[update\_app](https://gitee.com/openharmony/update_app)
71
72[update\_updateservice](https://gitee.com/openharmony/update_updateservice)
73
74[update\_updater](https://gitee.com/openharmony/update_updater)
75
76[update\_packaging\_tools](https://gitee.com/openharmony/update_packaging_tools)
77
78