Skip to contentSkip to navigationSkip to topbar
On this page

Microvisor Polite Deployment


(warning)

Microvisor Public Beta

Microvisor is in a pre-release phase and the information contained in this document is subject to change. Some features referenced below may not be fully available until Microvisor's General Availability (GA) release.

Polite deployment is the facility by which a running application is informed by Microvisor that there are application and/or Microvisor updates ready to be applied so that the application can choose to defer the installation of these updates if it is currently performing critical tasks which should not be interrupted.

By default, Microvisor applies updates as soon as they have been downloaded and verified. This involves restarting the application, and this may be undesirable in certain circumstances. Polite deployment puts the timing of update installations into the hands of the application.

Polite deployment is an opt-in feature. Developers enable it by setting specific values in their application bundles before they are uploaded for installation on Microvisor-enabled devices. Developers must also implement within the application a suitable mechanism to monitor notifications from Microvisor (so that the application is alerted when updates are pending) and code that triggers the update procedure immediately or at a time convenient to the application.


Polite Deployment Sequencing

polite-deployment-sequencing page anchor

It is important to understand that whether a specific application bundle is politely deployed or not depends not on its own settings but on those of the currently running application bundle.

For example, if application 42 does not have polite deployment set, but its successor, application 43, does, then application 43 will not be installed politely. However, application 44 will be. So will application 45 — provided application 44 was uploaded with the polite deployment flag set in its manifest, as outlined in Step 2 below.

If there is no running application on the device, the first application bundle to be deployed to it will be installed immediately, even if its manifest has its polite deployment flag set. Any subsequent update will be deployed politely.


How to implement Polite Deployment

how-to-implement-polite-deployment page anchor

1. Update Your Application Code

1-update-your-application-code page anchor
(information)

Info

Polite deployment makes use of Microvisor's notifications mechanism. If you are unfamiliar with this system, please take a moment to review our notifications documentation.

When Microvisor has an application or Microvisor update it would like to install, and polite deployment has been enabled in that application's bundle (see below), it will issue a notification of type MV_EVENTTYPE_UPDATEDOWNLOADED. You should check for this event in your notification interrupt service routine.

This notification is only posted when application and/or Microvisor updates have been marked for polite deployment via the bundle. To receive this notification, your application needs to tell Microvisor to which notification center it should post polite deployment notifications. You do so by calling mvOpenSystemNotification(const struct MvOpenSystemNotificationParams* params, MvSystemEventHandle* handle) and passing in a pointer to a configuration structure and the address of a variable into which Microvisor will write a system event sender handle value, as demonstrated in the example code below.

On receipt of the above notification you will set a flag in the notification interrupt service routine (ISR), or enqueue an RTOS message, and exit. Your main code loop will read the flag and, if set, use its own business logic to determine when to permit the pending update to be installed and the application restarted.

(warning)

Warning

If you fail to monitor polite deployment notifications from the system, and polite deployment is enabled, updates will not be applied — even if the next update disables polite deployment. You can force update installation by power-cycling the device or restarting it remotely using the Microvisor API.

To trigger the restart, call mvRestart(enum RestartMode mode). Its argument is currently a single value: MV_RESTARTMODE_AUTOAPPLYUPDATE.

It returns a value of type MvStatus. In the unlikely event that Microvisor is unable to restart the application, it will return a value indicating that this is the case and indicate why the system call failed. Otherwise, Microvisor will halt the running application (so the system call cannot return) and proceed to apply the update.

(warning)

Warning

It is up to the application to call mvRestart(). In normal circumstances, Microvisor updates will not be applied until this function is called. However, we do not recommend delaying the update indefinitely as this could compromise device security. In addition, KORE reserves the right to force essential Microvisor upgrades — for example, those containing critical security updates — if the device takes too long to restart and update manually.

1
#define SYS_NT_BUFFER_SIZE_R 8 // Value in # of records, not bytes
2
/*
3
* Set up the system notification system -- typically in main()
4
*/
5
// Store the notification center handle
6
MvNotificationHandle sys_notification_center_handle;
7
MvSystemEventHandle sys_event_handle;
8
volatile uint32_t current_notification_index = 0;
9
volatile bool update_pending = false;
10
11
// Central store for system notifications
12
volatile struct MvNotification sys_notification_center[SYS_NT_BUFFER_SIZE_R] __attribute__((aligned(8)));
13
14
// Clear the notification store
15
memset((void *)sys_notification_center, 0xFF, sizeof(sys_notification_center));
16
17
// Configure a notification center for system-centric notifications
18
static struct MvNotificationSetup sys_notification_config = {
19
.irq = TIM1_BRK_IRQn,
20
.buffer = (struct MvNotification *)sys_notification_center,
21
.buffer_size = sizeof(sys_notification_center)
22
};
23
24
// Ask Microvisor to establish the notification center
25
// and confirm that it has accepted the request
26
enum MvStatus status = mvSetupNotifications(&sys_notification_config, &sys_notification_center_handle);
27
assert(status == MV_STATUS_OKAY);
28
assert(sys_notification_center_handle != 0);
29
30
// Tell Microvisor to use the new notification center for system notifications
31
const struct MvOpenSystemNotificationParams sys_notification_params = {
32
.notification_handle = sys_notification_center_handle,
33
.notification_tag = 0,
34
.notification_source = MV_SYSTEMNOTIFICATIONSOURCE_UPDATE
35
};
36
37
status = mvOpenSystemNotification(&sys_notification_params, &sys_event_handle);
38
assert(status == MV_STATUS_OKAY);
39
assert(sys_event_handle != 0);
40
41
// Start the notification IRQ
42
NVIC_ClearPendingIRQ(TIM1_BRK_IRQn);
43
NVIC_EnableIRQ(TIM1_BRK_IRQn);
44
45
...
46
47
while(1) {
48
if (update_pending) {
49
// Update pending -- can we go ahead?
50
// NOTE `critical_task_running()` is a dummy function not provided here
51
if (!critical_task_running()) {
52
enum MvStatus status = mvRestart(MV_RESTART_AUTOAPPLYUPDATE);
53
// If the above call succeeds, the app with restart.
54
// If not, report the failure code
55
char err_msg_buffer[40] = {0};
56
sprintf(buffer, "Application restart failed (code %lu)", status);
57
mvServerLog((const uint8_t*)buffer, (uint16_t)strlen(buffer));
58
}
59
}
60
}
61
62
...
63
64
/*
65
* Set up the notification ISR
66
*/
67
void TIM1_BRK_IRQHandler(void) {
68
69
// Check for a suitable event
70
bool got_notification = false;
71
volatile struct MvNotification notification = sys_notification_center[current_notification_index];
72
if (notification.event_type == MV_EVENTTYPE_UPDATEDOWNLOADED) {
73
// Flag there is an update pending
74
update_pending = true;
75
got_notification = true;
76
}
77
78
if (got_notification) {
79
// Point to the next record to be written
80
current_notification_index = (current_notification_index + 1) % SYS_NT_BUFFER_SIZE_R;
81
82
// Clear the current notifications event
83
// See https://www.twilio.com/docs/iot/microvisor/microvisor-notifications#buffer-overruns
84
notification.event_type = 0;
85
}
86
}

2. Set Your Application Bundle

2-set-your-application-bundle page anchor
(warning)

Warning

The following tasks require updated Microvisor tooling that is currently in alpha release and only being made available to customers using polite deployment.

Compiled applications are uploaded as application bundles; bundles are generated from application binaries by the Microvisor tooling. To enable polite deployment, your bundles' manifests must be set accordingly: add the flag --polite-deployment to the bundle generation command:

microvisor app bundle /path/to/app-binary.bin /path/to/bundle.zip --polite-deployment

This will generate a bundle .zip file which you can upload to the Microvisor Cloud and then deploy to devices in the usual way. For example:

microvisor app upload /path/to/bundle.zip

The tooling will output the newly uploaded bundle's SID. Use it to deploy the bundle to your device:

microvisor device assign {device SID} --app-sid {app bundle SID}
(information)

Info

For more information on application bundles, please see Applications and Bundles.

Need some help?

Terms of service

Copyright © 2025 Twilio Inc.