1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
|
Overview of changes in libqmi 1.20.0
----------------------------------------
* New services:
** loc: new "LOC" (location) service, which e.g. allows controlling GPS
devices in newer modules that don't implement the PDS service. Just some
very basic implementation for now.
* New request/responses:
** nas: new "Attach/Detach" request/response messages.
** wds: new "Get Channel Rates" request/response messages.
** dms: new 'Swi Get/Set USB Composition' request/response messages.
* New TLVs supported in existing messages:
** nas: new 'Extended LTE Band Preference' TLV in "Set/Get SSP".
** dms: new 'Extended LTE Band Capability' TLV in "Get Band Capabilities".
* libqmi:
** New 'QMI_DEVICE_SIGNAL_REMOVED' signal in the QmiDevice object, propagated
through the qmi-proxy.
** New 'QMI_CLIENT_VALID' property in the QmiClient that allows detecting
whether the underlying QmiDevice is usable or not.
** Defined additional LTE bands.
* qmicli:
** New '--wds-set-ip-family' command.
** New '--wds-get-channel-rates' command.
** New '--uim-read-record' command.
** New '--dms-swi-get-usb-composition' and '--dms-swi-set-usb-composition'
commands.
* Several other minor improvements and fixes.
The following features which were backported to 1.18.x releases are also present
in libqmi 1.20.0:
* libqmi-glib:
** Prefer realpath() to canonicalize_file_name().
** Avoid signals sent to the qmi-proxy process.
* qmi-firmware-update:
** Support USB3->USB2 mode changes during upgrade.
Overview of changes in libqmi 1.18.0
----------------------------------------
The full list of new features include:
* libqmi:
** Implemented support for vendor-specific commands through a new
qmi_device_command_full() operation and a new QmiMessageContext type. The
original qmi_device_command() is flagged as deprecated.
** New 'QMI_DEVICE_OPEN_FLAGS_AUTO' flag in qmi_device_open() which allows
automatic detection of the underlying protocol in a cdc-wdm device (either
QMI or MBIM) and transparently uses it based on that.
** New qmi_device_close_async() operation, which allows closing a QmiDevice
asynchronously (especially important when closing devices running QMI over
MBIM, as this operation requires MBIM protocol cleanups). The original
qmi_device_close() is flagged as deprecated.
** Fixed QmiWmsCdmaCauseCode enum names, and provided a compatibility layer
keeping the old names (flagged as deprecated) to avoid breaking API.
* New services:
** pdc: new "PDC" (persistent device configuration) service, which among
other things, allows configuring the HP lt4120.
* New request/responses:
** dms: new sierra-specific "SWI Get Current Firmware" request/response.
** dms: new hp-specific "HP Change Device Mode" request/response.
** dms: new "Set Firmware ID" request/response.
** dms: new "Get Boot Image Download Mode" request/response.
** dms: new "Set Boot Image Download Mode" request/response.
** wds: new "Create Profile" request/response.
** wds: new "Modify Profile" request/response.
** wds: new "Delete Profile" request/response.
** wds: new "Set Event Report" request/response.
** wds: new "Go Dormant" request/response.
** wds: new "Go Active" request/response.
** wds: new "Get Dormancy Status" request/response.
** pdc: new "Reset" request/response.
** pdc: new "Register" request/response.
** pdc: new "Config Change" request/response.
** pdc: new "Get Selected Config" request/response.
** pdc: new "Set Selected Config" request/response.
** pdc: new "List Configs" request/response.
** pdc: new "Delete Config" request/response.
** pdc: new "Load Config" request/response.
** pdc: new "Activate Config" request/response.
** pdc: new "Get Config Info" request/response.
** pdc: new "Get Config Limits" request/response.
** pdc: new "Get Default Config Info" request/response.
** pdc: new "Deactivate Config" request/response.
** uim: new "Power Off SIM" request/response.
** uim: new "Power On SIM" request/response.
** nas: new "Get Operator Name" request/response.
** wds: new "Bind Mux Data Port" request/response.
* New indications:
** wds: new "Event report" indication.
** pdc: new "Get Selected Config" indication.
** pdc: new "Set Selected Config" indication.
** pdc: new "List Configs" indication.
** pdc: new "Load Config" indication.
** pdc: new "Activate Config" indication.
** pdc: new "Get Config Info" indication.
** pdc: new "Deactivate Config" indication.
** nas: new "Operator Name" indication.
* New TLVs supported in existing messages:
** wda: updated "Set Data Format" request to allow specifying endpoint type
and interface number.
* qmi-firmware-update:
** This is a completely new tool that allows upgrading firmware in (at least)
Sierra Wireless devices with MDM9200, MDM9x15 or MDM9x30 chipsets. Run the
tool with --help and --help-examples to get more information on how to use
it.
* qmicli:
** The CLI no longer requires the '--device-open-mbim' explicit option when
opening QMI capable MBIM devices, the automatic detection of QMI over MBIM
is enabled by default.
** New '--device-open-qmi' option to disable the automatic detection of
protocol and force using QMI.
** New '--dms-set-firmware-id' operation.
** New '--dms-get-software-version' operation.
** New '--dms-set-boot-image-download-mode' and
'--dms-get-boot-image-download-mode' operations to configure the default
download mode.
** New '--dms-set-firmware-preference' and '--dms-get-firmware-preference'
operations to manage the current firmware preference.
** New '--wds-go-dormant', '--wds-go-active' and '--wds-get-dormancy-status'
operations to manage dormancy related operations.
** New '--nas-get-rf-band-info' operation.
** New '--uim-sim-power-on' and '--uim-sim-power-off' operations.
** New '--nas-get-operator-name' operation.
** New '--wds-bind-mux-data-port' operation.
** Updated '--wda-set-data-format' to allow specifying endpoint type and
interface number.
** If running in MBIM mode, enable MBIM logs and traces.
** By default the QmiDevice will be closed before exiting, e.g. so that the
MBIM session is also closed.
* docs:
** Updated the documentation so that each QMI message and each TLV specifies
in which libqmi version it was introduced, using "since:" tags in the QMI
message databases.
** Added indices for new symbols introduced in the major libqmi releases, as
well as for symbols flagged as deprecated.
* build:
** Bump GLib requirement to 2.36.
** Added GUdev requirement for qmi-firmware-update, that may be explicitly
disabled using the new '--without-udev' configure switch.
** The new '--disable-firmware-update' configure switch allows completely
disabling the qmi-firmware-update tool build.
** The new '--disable-mm-runtime-check' configure switch allows disabling
the runtime check for ModemManager done by the qmi-firmware-update tool.
The following features which were backported to 1.16.x releases are also present
in libqmi 1.18.0:
* dms: flagged several methods as available since DMS 1.1.
* nas: Fix RX/TX mixup in 'Get LTE Cphy CA Info'.
* libqmi-glib:
** Fix segfault in QmiDevice when cancellable already cancelled.
** Fix releasing transaction on MBIM error.
* qmicli:
** Added support for IP type in --wds-start-network.
** Fix options receiving a list of flags.
** Fix second ctrl+c handling.
** Avoid converting to dB invalid SINR values.
* qmi-proxy:
** Fix segfault when trying to use already disposed clients.
** Fix segfault when trying to use already disposed transactions.
** Plug several memleaks in error conditions.
* build:
** Guard invocations of g_type_init().
** Fix checking for libmbim.
Overview of changes in libqmi 1.16.0
----------------------------------------
* New `--enable-mbim-qmux' option during configure, which enables the support
for using an MBIM control device as transport for the QMI messages, only if
the MBIM device implements the "QMI service". This setting is automatically
enabled if libmbim >= 1.14.0 is found in the system, and can be explicitly
disabled with `--disable-mbim-qmux'.
* New request/responses:
** nas: new "Get LTE Cphy CA Info" request/response.
** nas: new "Force Network Search" request/response.
* qmi-network:
** Fixed several bashisms.
The following features which were backported to 1.14.x releases are also present
in libqmi 1.16.0:
* Added compatibility symbols for some API breaks introduced in 1.14.0:
** qmi_message_dms_set_service_programming_code_input_get_current
was renamed to qmi_message_dms_set_service_programming_code_input_get_current_code.
** qmi_message_dms_set_service_programming_code_input_get_new
was renamed to qmi_message_dms_set_service_programming_code_input_get_new_code.
** qmi_message_dms_set_service_programming_code_input_set_current
was renamed to qmi_message_dms_set_service_programming_code_input_set_current_code.
** qmi_message_dms_set_service_programming_code_input_set_new
was renamed to qmi_message_dms_set_service_programming_code_input_set_new_code.
** QMI_NAS_SIM_REJECT_STATE_SIM_VAILABLE was renamed to
QMI_NAS_SIM_REJECT_STATE_SIM_AVAILABLE.
* libqmi-glib:
** Fixed QMI_DMS_BAND_CAPABILITY_BC_15 enum value so that it isn't treated as
a negative value.
* qmicli:
** Fixed --dms-get-band-capabilities output on 32-bit platforms.
** Fixed license text of the voice service implementation.
Overview of changes in libqmi 1.14.0
----------------------------------------
* This version comes with a couple of small API breaks:
** ECIO value type in "NAS Event Report Indication" is given as unsigned.
** ECIO value in ECIO List array type in "NAS Get Signal Strenght" is given as
unsigned.
** QMI_NAS_SIM_REJECT_STATE_SIM_AVAILABLE enum name was fixed.
* The library and tools now support working with modems which only implement raw
IP (i.e. no ethernet headers) in the WWAN interface. This relies on the kernel
to expose '/sys/class/net/<WWAN>/qmi/raw_ip' sysfs files for each WWAN network
interface (available since Linux 4.5-rc1).
* New initial support for the 'Voice' service.
* New request/responses:
** wms: new "Get Supported Messages" request/response.
** wds: new "Get Supported Messages" request/response.
** voice: new "Get Supported Messages" request/response.
** uim: new "Get Supported Messages" request/response.
** nas: new "Get Supported Messages" request/response.
** wda: new "Get Supported Messages" request/response.
** dms: new "Get Supported Messages" request/response.
** wds: new "Set Autoconnect Setting" request/response.
** wds: new "Get Autoconnect Setting" request/response.
** wds: new "Get PDN Throttle Info" request/response.
** uim: new "Change PIN" request/response.
** uim: new "Unblock PIN" request/response.
** uim: new "Verify PIN" request/response.
** uim: new "Set PIN protection" request/response.
** voice: new "Dial Call" request/response.
** voice: new "End Call" request/response.
** voice: new "Answer Call" request/response.
** voice: new "Get Config" request/response.
** voice: new "Get Supported Messages" request/response.
* New indications:
** wms: new "SMSC Address" indication.
** pds: new "GPS Ready" indication.
** wds: new "Packet Service Status" indication.
* New TLVs supported in existing messages:
** wds: support "UMTS Granted QoS" TLV in 'Get Current Settings'.
** nas: support "Home Network 3GPP MNC" in "Get Home Network" to know whether
MNC is 2 or 3 digits.
* The qmicli tool has been updated with several new functionalities:
** New '--get-wwan-iface' command line option to allow querying which is the
WWAN interface associated with a given /dev/cdc-wdm device.
** New '--wds-get-current-settings' command line option to query the current
settings in the WDS service.
** New '--get-expected-data-format' and '--set-expected-data-format' actions
to get or set the data format expected by the kernel.
** LTE band descriptions are now printed along with the EARFCN.
** Updated '--wds-start-network' arguments to allow specifying "key=value"
pairs. The old legacy "[(APN),(PAP|CHAP|BOTH),(Username),(Password)]"
format is kept as valid for backwards compatibility, although it should be
assumed deprecated.
** Updated '--wds-start/stop-network' to allow autoconnect settings, and 3GPP
or 3GPP2 profile parameters.
* The qmi-network helper script has been updated with several new features:
** Allow running with the qmi-proxy.
** Allow running qmi-network with multiple devices at the same time.
** Automatic link layer protocol update before connecting.
** Allow specifying APN user/password.
* Added command completion support in qmicli.
* Other bugfixes and minor improvements.
The following features which were backported to 1.12.x releases are also present
in libqmi 1.14.0:
* New request/responses:
** dms: new "Set FCC Authentication" request/response.
Overview of changes in libqmi 1.12.0
----------------------------------------
* New `--enable-qmi-username' option during configure, which allows specifying
which will be the user owning the /dev/cdc-wdm character devices of all QMI
modems (udev rules are installed to change file ownership). If this option is
used, the qmi-proxy will only allow connections from processes running by the
specified user or by the root user.
* New TLV builder and reader API, which is much more strict and secure. The
autogenerated code will no longer first check if there is enough space
available in the output message buffer and then write the parsed contents.
Instead, the new reader API will be used, which is able to check for the
expected size directly before writing in the buffer.
* New unit tests to check messages built by the libqmi-glib library, using a
fake proxy. In order to support these, the QmiDevice has two new properties:
** "device-no-file-check": instructs the QmiDevice to avoid checking if the
specified file exists.
** "device-proxy-path": specifies a custom abstract socket path for the
QmiProxy, to avoid using the default one.
* New A-GPS support in the PDS service:
** pds: added "Get Default Tracking Session" request/response
** pds: added "Set Default Tracking Session" request/response
** pds: added "Get AGPS Config" request/response
** pds: added "Set AGPS Config" request/response
* Updated minumum available version of several messages:
** dms: "UIM Get IMSI" seems to be available in DMS 1.1 already
** dms: "UIM Get ICCID" seems to be available in DMS 1.1 already
* Other bugfixes and minor improvements:
** Attach timeout and idle events to the thread-default context.
** Fix bashisms in the qmi-network script.
** Fix qmi_message_set_transaction_id() in non-CTL messages.
** Fix segfault due to race condition in the QmiProxy.
** Fixed printing contents of structs with fixed sized strings in qmi-codegen.
Overview of changes in libqmi 1.10.0
----------------------------------------
* Fixed default internal proxy timeout for requests.
* Added initial support for the WDA service.
* Added support for cell location info retrieval.
* Added support for UIM card status retrieval.
* Added support to specify net open flags in the command line.
Overview of changes in libqmi 1.8.0
----------------------------------------
This version comes with one small API break:
* Enum value QMI_SERVICE_RMTFS is not 0x14, but 14. I doubt anyone has been hit
by this issue, anyway.
Additional changes include:
* Support for sharing the QMI port through multiple processes with the new
'qmi-proxy' infrastructure.
* api: added new known service ID enumeration values
* wds: added "Get Profile List" request/response
* wds: added "Get Profile Settings" request/response
* wds: added "Get Default Settings" request/response
* cli: add --wds-get-profile-list
* cli: add --wds-get-default-settings
* man: added qmi-network manpage, autogenerated from --help-all
Overview of changes in libqmi 1.6.0
----------------------------------------
This version comes with one small API break:
* dms: 'SID' TLV in "Activate Manual" is a guint8, not a string
Additional changes include:
* Extended API with macros to check for the libqmi-glib version in use
* Setup libtool versioning in libqmi-glib
* Added initial support for the PBM (phonebook) service
* Added initial support for the UIM service
* Added initial support for the OMA (Open Mobile Alliance) service
* nas: added "Get Tx Rx Info" request/response
* wds: added "Get Packet Statistics" request/response
* dms: added support for the 'PRL' TLV in "Activate Manual"
* cli: add --nas-get-tx-rx-info
* cli: add --wds-get-packet-statistics
* cli: add --get-service-version-info
* cli: add --uim-read-transparent
* cli: add --uim-get-file-attributes
* cli: fix following network status until disconnected
* tests: use gtester to run unit tests
* man: added qmicli manpage, autogenerated from --help-all
* Also fixed several minor bugs and memory leaks
Overview of changes in libqmi 1.4.0
----------------------------------------
* dms: fix minimum version requirement for DMS Get/Set Operating Mode
* nas: added 'Network Time' indication
* utils: fix reading sized uints in BE systems
* cli: add --dms-activate-manual
* cli: implemented setting System Selection Preference
* cli: fix technology preference persistence reporting
* cli: fix reading new PIN in '--dms-uim-change-pin'
* docs: always generate documentation at dist time
* tests: fixed BE/LE tests in BE systems
Overview of changes in libqmi 1.2.0
----------------------------------------
* Builds with Python3
* Fixed DMS activation code string handling
* Enhanced "start network" functionality in qmicli
Overview of changes in libqmi 1.0
----------------------------------------
Initial release.
|