1# Copyright (c) 2017 Linaro Limited
2# SPDX-License-Identifier: Apache-2.0
3
4menuconfig LWM2M
5	bool "OMA LwM2M protocol stack"
6	select COAP
7	select HTTP_PARSER_URL
8	select NET_SOCKETS
9	help
10	  This option adds logic for managing OMA LwM2M data
11
12if LWM2M
13
14module = LWM2M
15module-dep = LOG
16module-str = Log level for LwM2M library
17source "subsys/net/Kconfig.template.log_config.net"
18
19menu "Protocol versions"
20
21choice LWM2M_VERSION
22	prompt "LwM2M protocol version"
23	default LWM2M_VERSION_1_0
24	help
25	  Select which version of the LwM2M protocol is used
26
27config LWM2M_VERSION_1_0
28	bool "LwM2M version 1.0"
29	imply LWM2M_RW_OMA_TLV_SUPPORT
30
31config LWM2M_VERSION_1_1
32	bool "LwM2M version 1.1"
33	imply LWM2M_RW_CBOR_SUPPORT
34	imply ZCBOR
35
36endchoice # "LwM2M protocol version"
37
38choice
39	prompt "LwM2M Security object version"
40	default LWM2M_SECURITY_OBJECT_VERSION_1_0 if LWM2M_VERSION_1_0
41	default LWM2M_SECURITY_OBJECT_VERSION_1_1 if LWM2M_VERSION_1_1
42	help
43	  Select which version of the security object should be used.
44
45config LWM2M_SECURITY_OBJECT_VERSION_1_0
46	bool "Security object version 1.0"
47
48config LWM2M_SECURITY_OBJECT_VERSION_1_1
49	bool "Security object version 1.1"
50
51endchoice # "LwM2M Security object version"
52
53choice
54	prompt "LwM2M Server object version"
55	default LWM2M_SERVER_OBJECT_VERSION_1_0 if LWM2M_VERSION_1_0
56	default LWM2M_SERVER_OBJECT_VERSION_1_1 if LWM2M_VERSION_1_1
57	help
58	  Select which version of the Server object should be used.
59
60config LWM2M_SERVER_OBJECT_VERSION_1_0
61	bool "Server object version 1.0"
62
63config LWM2M_SERVER_OBJECT_VERSION_1_1
64	bool "Server object version 1.1"
65
66endchoice # "LwM2M Server object version"
67
68endmenu # "Protocol versions"
69
70menu "Engine features"
71
72config LWM2M_DTLS_SUPPORT
73	bool "DTLS support in the LwM2M client"
74
75
76config LWM2M_DNS_SUPPORT
77	bool "DNS support in the LwM2M client"
78	default y if DNS_RESOLVER
79
80config LWM2M_COAP_BLOCK_TRANSFER
81	bool "CoAP block transfer support for big outgoing LwM2M messages [EXPERIMENTAL]"
82	select EXPERIMENTAL
83	help
84	  LwM2M messages with a big body that exceed the block size will be split
85	  into blocks for sending.
86	  To append CoAP ETag option into outgoing block transfers, CONFIG_SYS_HASH_FUNC32 should
87	  be enabled.
88
89config LWM2M_CANCEL_OBSERVE_BY_PATH
90	bool "Use path matching as fallback for cancel-observe"
91	help
92	  Some ambiguous language in the LwM2M spec causes some LwM2M server
93	  implementations to implement cancel-observe by specifying the resource
94	  path rather than the token of the original observe request. Without
95	  this option, cancel-observe may not work properly when connecting to
96	  those servers.
97
98config LWM2M_QUEUE_MODE_ENABLED
99	bool "Queue Mode UDP binding"
100	help
101	  Set the transport binding to UDP with Queue Mode (UQ).
102
103config LWM2M_QUEUE_MODE_UPTIME
104	int "Specify time the LwM2M client should stay online in queue mode." if LWM2M_QUEUE_MODE_ENABLED
105	default 93
106	help
107	  This config specifies time (in seconds) the device should stay online
108	  after sending a message to the server. Note, that LwM2M specification
109	  recommends this to be CoAP MAX_TRANSMIT_WAIT parameter (which
110	  defaults to 93 seconds, see RFC 7252), it does not forbid other
111	  values though.
112
113config LWM2M_QUEUE_MODE_NO_MSG_BUFFERING
114	bool "Disable buffering notifications and messages on queue mode"
115	select EXPERIMENTAL
116	help
117	  Messages are sent right away instead of waiting for next registration update.
118	  This might not be supported on all servers.
119
120config LWM2M_TLS_SESSION_CACHING
121	bool "TLS session caching"
122	help
123	  Enabling this only when feature is supported in TLS library.
124
125config LWM2M_DTLS_CID
126	bool "DTLS Connection Identifier support"
127	default y if MBEDTLS_SSL_DTLS_CONNECTION_ID
128	help
129	  Request TLS stack to enable DTLS Connection identifier. This requires stack that support it
130	  and actual effect depends on the target server as well.
131
132config LWM2M_RD_CLIENT_SUPPORT_BOOTSTRAP
133	bool "Bootstrap support"
134	help
135	  Enabling this setting allows the RD client to support bootstrap mode.
136
137config LWM2M_ENGINE_ALWAYS_REPORT_OBJ_VERSION
138	bool "LwM2M engine always report object version"
139	help
140	  According to LwM2M specification v1.0 and v1.1, non-core object versions other than 1.0
141	  'must' be provided, while all other versions 'may' be provided. With specification v1.2,
142	  a client 'can always attach Object Version Information'. Enable this configuration to
143	  always report all object versions.
144
145choice
146prompt "Socket handling at idle state"
147
148config LWM2M_RD_CLIENT_CLOSE_SOCKET_AT_IDLE
149	bool "Close socket when entering RX idle"
150
151config LWM2M_RD_CLIENT_SUSPEND_SOCKET_AT_IDLE
152	bool "Stop polling on RX idle and close only when resuming"
153
154config  LWM2M_RD_CLIENT_STOP_POLLING_AT_IDLE
155	bool "Stop polling the socket on RX idle"
156
157config  LWM2M_RD_CLIENT_LISTEN_AT_IDLE
158	bool "Keep open and listening"
159
160endchoice
161
162choice
163	prompt "LwM2M Engine operation mode"
164	default LWM2M_TICKLESS if NET_SOCKETPAIR
165	default LWM2M_INTERVAL if !NET_SOCKETPAIR
166
167config LWM2M_TICKLESS
168	bool "Tickless operation mode"
169	depends on NET_SOCKETPAIR
170
171config LWM2M_INTERVAL
172	bool "Interval based polling mode"
173
174endchoice
175
176config LWM2M_SERVER_DEFAULT_SSID
177	int "Default server ssid when using the lwm2m-client. (used for access control)"
178	default 101
179	help
180	  When bootstrap is not enabled, access control needs a default owner.
181
182config LWM2M_PEER_PORT
183	int "LWM2M server port"
184	default 5683
185	help
186	  This is the default server port to connect to for LwM2M communication.
187
188config LWM2M_FIRMWARE_PORT_NONSECURE
189	int "LWM2M firmware server port non-secure"
190	default 5683
191	help
192	  This is the default server port to connect to for LwM2M firmware downloads over coap.
193
194config LWM2M_FIRMWARE_PORT_SECURE
195	int "LWM2M firmware server port secure"
196	default 5684
197	help
198	  This is the default server port to connect to for LwM2M firmware downloads over coaps.
199
200config LWM2M_SERVER_DEFAULT_PMIN
201	int "Default server record PMIN"
202	default 0
203	help
204	  Default minimum amount of time in seconds the client must wait
205	  between notifications.  If a resource has to be notified during this
206	  minimum time period, the notification must be sent after the time
207	  period expires.
208
209config LWM2M_SERVER_DEFAULT_PMAX
210	int "Default server record PMAX"
211	default 0
212	help
213	  Default maximum amount of time in seconds the client may wait
214	  between notifications.  When this time period expires a notification
215	  must be sent.
216
217config LWM2M_RD_CLIENT_MAX_RETRIES
218	int "Specify maximum number of registration retries"
219	default 5
220	help
221	  Specify maximum number of registration retries, before the application
222	  is notified about the network failure. Once application is notified,
223	  it's up to the application to handle this situation in a way
224	  appropriate for the specific use-case (for instance by waiting for
225	  LTE link to be re-established).
226
227config LWM2M_RESOURCE_DATA_CACHE_SUPPORT
228	bool "Resource Time series data cache support"
229	depends on (LWM2M_RW_SENML_JSON_SUPPORT || LWM2M_RW_SENML_CBOR_SUPPORT)
230	depends on (POSIX_TIMERS && RING_BUFFER)
231	help
232	  Enable time series data storage.
233	  Requires time() to provide current Unix timestamp.
234
235if LWM2M_RESOURCE_DATA_CACHE_SUPPORT
236config LWM2M_MAX_CACHED_RESOURCES
237	int "Maximum # of cached resources"
238	default 4
239	help
240	  This settings define how many different resources may have cache enabled.
241	  This affects static memory usage of engine.
242choice
243	prompt "Cache full policy"
244	default LWM2M_CACHE_DROP_OLDEST
245
246config LWM2M_CACHE_DROP_LATEST
247	bool "Drop new data when cache is full"
248
249config LWM2M_CACHE_DROP_OLDEST
250	bool "Drop oldest data when cache is full"
251
252endchoice
253
254endif # LWM2M_RESOURCE_DATA_CACHE_SUPPORT
255
256endmenu # "Engine features"
257
258menu "Memory and buffer size configuration"
259
260config LWM2M_ENGINE_STACK_SIZE
261	int "LWM2M engine stack size"
262	default 2560 if NET_LOG
263	default 2048
264	help
265	  Set the stack size for the LwM2M library engine (used for handling
266	  OBSERVE and NOTIFY events)
267
268config LWM2M_ENGINE_MAX_MESSAGES
269	int "LWM2M engine max. message object"
270	default 10
271	help
272	  Set the maximum message objects for the LwM2M library client
273
274config LWM2M_COAP_BLOCK_SIZE
275	int "LWM2M CoAP block-wise transfer size"
276	default 256
277	range 64 1024
278	help
279	  CoAP block size used by LwM2M when performing block-wise
280	  transfers. Possible values: 64, 128, 256, 512 and 1024.
281
282config LWM2M_ENGINE_MESSAGE_HEADER_SIZE
283	int "Room for CoAP header data"
284	default 48
285	range 24 128
286	help
287	  Extra room allocated to handle CoAP header data
288
289config LWM2M_COAP_MAX_MSG_SIZE
290	int "LWM2M CoAP maximum message size"
291	default LWM2M_COAP_BLOCK_SIZE
292	help
293	  CoAP message size used by LWM2M. Minimum is the block size used
294	  in blockwise transfers.
295
296config LWM2M_ENGINE_VALIDATION_BUFFER_SIZE
297	int "Size of the validation buffer for the incoming data"
298	default 64
299	help
300	  LwM2M will use the validation buffer during the write operation, to
301	  decode the resource value before validating it (applies for resources
302	  for which validation callback has been registered). Set this value to
303	  the maximum expected size of the resources that need to be validated
304	  (and thus have validation callback registered).
305	  Setting the validation buffer size to 0 disables validation support.
306
307config LWM2M_ENGINE_MAX_PENDING
308	int "LWM2M engine max. pending objects"
309	default 5
310	help
311	  Set the maximum pending objects for the LwM2M library client
312
313config LWM2M_ENGINE_MAX_REPLIES
314	int "LWM2M engine max. reply objects"
315	default 5
316	help
317	  Set the maximum reply objects for the LwM2M library client
318
319config LWM2M_ENGINE_MAX_OBSERVER
320	int "Maximum # of observable LwM2M resources"
321	default 10
322	range 5 200
323	help
324	  This value sets the maximum number of resources which can be
325	  added to the observe notification list.
326
327config LWM2M_RD_CLIENT_ENDPOINT_NAME_MAX_LENGTH
328	int "Maximum length of client endpoint name"
329	default 33
330	help
331	  Default: room for 32 hexadecimal digits (UUID) + NULL
332
333config LWM2M_SECURITY_KEY_SIZE
334	int "Buffer size of the security key resources"
335	default 16
336	help
337	  This setting establishes the size of the key (pre-shared / public)
338	  resources in the security object instances.
339
340config LWM2M_SECURITY_DTLS_TLS_CIPHERSUITE_MAX
341	int "Maximum # of DTLS/TLS ciphersuite resource instances"
342	default 5
343	range 0 20
344	depends on LWM2M_SECURITY_OBJECT_VERSION_1_1
345	help
346	  This setting sets the maximum number of the resource instances of
347	  a security object defined in LwM2M version 1.1. Affects the resource
348	  0/X/16, where X is the object instance number.
349
350config LWM2M_SECURITY_INSTANCE_COUNT
351	int "Maximum # of LwM2M Security object instances"
352	default 2 if LWM2M_RD_CLIENT_SUPPORT_BOOTSTRAP
353	default 1
354	range 1 10
355	help
356	  This setting establishes the total count of LwM2M Security instances
357	  available to the client.
358
359config LWM2M_SERVER_INSTANCE_COUNT
360	int "Maximum # of LwM2M Server object instances"
361	default 2 if LWM2M_RD_CLIENT_SUPPORT_BOOTSTRAP
362	default 1
363	range 1 10
364	help
365	  This setting establishes the total count of LwM2M Server instances
366	  available to the client (including: bootstrap and regular servers).
367
368if LWM2M_COAP_BLOCK_TRANSFER
369config LWM2M_COAP_ENCODE_BUFFER_SIZE
370	int "LwM2M CoAP buffer size for encoding the full message for block-wise transfer"
371	default 1024
372	help
373	  Size of buffers for serializing big LwM2M CoAP messages that need to be
374	  split into blocks for sending.
375
376config LWM2M_NUM_OUTPUT_BLOCK_CONTEXT
377	int "Maximum # of LwM2M block contexts used for outgoing messages"
378	default 3
379	help
380	  Maximum number of CoAP block contexts needed to split messages into blocks for
381	  sending. This limits the number of messages that need block transfer that can be
382	  handled at the same time.
383
384config LWM2M_LOG_ENCODE_BUFFER_ALLOCATIONS
385	bool "Log allocations of encode buffers for block wise transfer"
386	select MEM_SLAB_TRACE_MAX_UTILIZATION
387	help
388	  The allocation of encode buffers can be tracked to analyse the usage and
389	  to optimize the configuration of number of block contexts and indirectly
390	  the number of available encode buffers.
391endif # LWM2M_COAP_BLOCK_TRANSFER
392
393config LWM2M_NUM_BLOCK1_CONTEXT
394	int "Maximum # of LwM2M block1 contexts"
395	default 3
396	help
397	  This value sets up the maximum number of block1 contexts for
398	  CoAP block-wise transfer we can handle at the same time.
399
400config LWM2M_SWMGMT_PACKAGE_URI_LEN
401	int "Maximum size of the software management object's download URI string"
402	default 128
403
404config LWM2M_COMPOSITE_PATH_LIST_SIZE
405	int "Maximum # of composite read and send operation URL path"
406	default 6
407	help
408	  Define path list size for Composite Read and send operation.
409
410config LWM2M_DEVICE_ERROR_CODE_SETTINGS
411	bool "Use settings to store error codes across device resets"
412	depends on SETTINGS
413	help
414	  Store the device error code list in settings. Ensures error list can
415	  be transferred to LwM2M server even if the device is reset.
416
417config LWM2M_DEVICE_PWRSRC_MAX
418	int "Maximum # of device power source records"
419	default 5
420	range 1 20
421	help
422	  This value sets the maximum number of power source data that a device
423	  can store.  These are displayed via the "Device" object /3/0/6,
424	  /3/0/7 and /3/0/8 resources.
425
426config LWM2M_DEVICE_ERROR_CODE_MAX
427	int "Maximum # of device obj error codes to store"
428	default 10
429	range 1 20
430	help
431	  This value sets the maximum number of error codes that the device
432	  object will store before ignoring new values.
433
434config LWM2M_DEVICE_EXT_DEV_INFO_MAX
435	int "Maximum # of device obj external device info to store"
436	default 5
437	range 1 20
438	help
439	  This value sets the maximum number of external device info that the
440	  device object will store before ignoring new values.
441
442config LWM2M_NUM_ATTR
443	int "Maximum # of LwM2M attributes"
444	default 20
445	help
446	  This value sets up the maximum number of LwM2M attributes that
447	  we can handle at the same time.
448
449endmenu # "Memory and buffer size configuration"
450
451menu "Content format supports"
452config LWM2M_RW_OMA_TLV_SUPPORT
453	bool "TLV data format"
454	help
455	  Include support for write / parse TLV data
456
457config LWM2M_RW_JSON_SUPPORT
458	bool "support for JSON writer"
459	depends on JSON_LIBRARY
460	help
461	  Include support for writing JSON data
462
463
464config LWM2M_RW_SENML_JSON_SUPPORT
465	bool "SENML JSON data format"
466	depends on BASE64
467	depends on JSON_LIBRARY
468	help
469	  Include support for write / parse SENML JSON data
470
471config LWM2M_RW_CBOR_SUPPORT
472	bool "support for CBOR writer"
473	depends on ZCBOR
474	help
475	  Include support for writing CBOR data
476
477config LWM2M_RW_SENML_CBOR_SUPPORT
478	bool "support for SenML CBOR writer"
479	depends on ZCBOR
480	depends on ZCBOR_CANONICAL
481	help
482	  Include support for writing SenML CBOR data
483
484config LWM2M_RW_SENML_CBOR_RECORDS
485	int "Maximum # of SenML records packed into a CBOR binary"
486	depends on LWM2M_RW_SENML_CBOR_SUPPORT
487	default 30
488	help
489	  The CBOR library requires you to set an upper limit for the records when encoder
490	  and decoder do get generated.
491
492endmenu # "Content format supports"
493
494config LWM2M_ENGINE_DEFAULT_LIFETIME
495	int "LWM2M engine default server connection lifetime"
496	default 30
497	range 15 $(UINT32_MAX)
498	help
499	  Set the default lifetime (in seconds) for the LwM2M library engine.
500	  This is also a minimum lifetime that client accepts. If server sets lifetime
501	  less than this value, client automatically raises it.
502
503config LWM2M_UPDATE_PERIOD
504	int "LwM2M engine update period"
505	default 0
506	range 0 $(UINT32_MAX)
507	help
508	  Time period after the previous update or registration when to send the next update message.
509	  This allows modifying lifetime without affecting the update period.
510	  Set to zero, to allow LWM2M_SECONDS_TO_UPDATE_EARLY and lifetime to control when to
511	  send the update. When both values are set, smallest period will be used.
512
513config LWM2M_SECONDS_TO_UPDATE_EARLY
514	int "LWM2M Registration Update transmission time before timeout"
515	default 10
516	range 1 $(UINT32_MAX)
517	help
518	  Time in seconds before the registration timeout, when the LWM2M
519	  Registration Update is sent by the engine. In networks with large
520	  round trip times (like NB-IoT), it might be needed to set this value
521	  higher, in order to allow the response to arrive before timeout.
522
523config LWM2M_SHELL
524	bool "LwM2M shell utilities"
525	select SHELL
526	select CRC
527	help
528	  Activate shell module that provides LwM2M commands like
529	  send to the console.
530
531config LWM2M_ACCESS_CONTROL_ENABLE
532	bool "Access control support (ID 2)"
533	help
534	  Enabling this setting registers the access control object.
535
536config LWM2M_ACCESS_CONTROL_INSTANCE_COUNT
537	int "Maximum # of LwM2M Access Control object instances" if LWM2M_ACCESS_CONTROL_ENABLE
538	default 50
539	help
540	  This setting establishes the total count of LwM2M Access Control instances
541	  available to the client.
542
543config LWM2M_CONN_MON_OBJ_SUPPORT
544	bool "Connectivity Monitoring object support (ID 4)"
545	help
546	  Include support for LwM2M Connectivity Monitoring Object
547
548if LWM2M_CONN_MON_OBJ_SUPPORT
549choice
550	prompt "LwM2M Connectivity Monitor object version"
551	default LWM2M_CONNMON_OBJECT_VERSION_1_0 if LWM2M_VERSION_1_0
552	default LWM2M_CONNMON_OBJECT_VERSION_1_2 if LWM2M_VERSION_1_1
553	help
554	  Select Which version of the Connectivity Monitor object should be used.
555
556config LWM2M_CONNMON_OBJECT_VERSION_1_0
557	bool "Connectivity monitor object version 1.0"
558
559config LWM2M_CONNMON_OBJECT_VERSION_1_2
560	bool "Connectivity monitor object version 1.2"
561
562config LWM2M_CONNMON_OBJECT_VERSION_1_3
563	bool "Connectivity monitor object version 1.3"
564
565endchoice
566
567config LWM2M_CONN_MON_BEARER_MAX
568	int "Maximum # of available network bearer resource instances"
569	default 1
570	help
571	  This value sets the maximum number of available network bearer
572	  resource instances.  These are displayed via the
573	  "Connection Monitoring" object /4/0/1.
574
575config LWM2M_CONN_MON_APN_MAX
576	int "Maximum # of APN resource instances"
577	default 1
578	help
579	  This value sets the maximum number of APN resource instances.
580	  These are displayed via the "Connection Monitoring" object /4/0/7.
581endif # LWM2M_CONN_MON_OBJ_SUPPORT
582
583config LWM2M_FIRMWARE_UPDATE_OBJ_SUPPORT
584	bool "Firmware Update object support (ID 5)"
585	default y
586	help
587	  Include support for LwM2M Firmware Update Object
588
589if LWM2M_FIRMWARE_UPDATE_OBJ_SUPPORT
590config LWM2M_FIRMWARE_UPDATE_OBJ_SUPPORT_MULTIPLE
591	bool "Support multiple firmware update objects [EXPERIMENTAL]"
592	select EXPERIMENTAL
593	help
594	  Support multiple instances of LwM2M Firmware Update Object
595
596config LWM2M_FIRMWARE_UPDATE_OBJ_INSTANCE_COUNT
597	int "Maximum # of LwM2M Firmware update object instances"
598	default 1
599	help
600	  This setting establishes the total count of LwM2M Firmware update
601	  object instances available to the client.
602
603config LWM2M_FIRMWARE_UPDATE_PULL_SUPPORT
604	bool "Firmware Update object pull support"
605	default y
606	depends on (HTTP_PARSER || HTTP_PARSER_URL)
607	help
608	  Include support for pulling a file from a remote server via
609	  block transfer and "FIRMWARE PACKAGE URI" resource.  This option
610	  adds another UDP context and packet handling.
611
612config LWM2M_FIRMWARE_UPDATE_PULL_COAP_PROXY_SUPPORT
613	bool "Firmware Update object pull via CoAP-CoAP/HTTP proxy support"
614	depends on LWM2M_FIRMWARE_UPDATE_PULL_SUPPORT
615	help
616	  Include support for pulling firmware file via a CoAP-CoAP/HTTP proxy.
617
618config LWM2M_FIRMWARE_UPDATE_PULL_COAP_PROXY_ADDR
619	string "CoAP proxy network address"
620	depends on LWM2M_FIRMWARE_UPDATE_PULL_COAP_PROXY_SUPPORT
621	help
622	  Network address of the CoAP proxy server.
623
624endif # LWM2M_FIRMWARE_UPDATE_OBJ_SUPPORT
625
626config LWM2M_LOCATION_OBJ_SUPPORT
627	bool "Location object support (ID 6)"
628	help
629	  Include support for LwM2M Location Object
630
631config LWM2M_SWMGMT_OBJ_SUPPORT
632	bool "Software management object support (ID 9)"
633	help
634	  Include support for LwM2M Software Management Object.
635
636if LWM2M_SWMGMT_OBJ_SUPPORT
637config LWM2M_SWMGMT_MAX_INSTANCE_COUNT
638	int "Maximum # of object instances"
639	depends on LWM2M_SWMGMT_OBJ_SUPPORT
640	default 1
641
642config LWM2M_SWMGMT_PACKAGE_NAME_LEN
643	int "Maximum size of the software management object's name string"
644	depends on LWM2M_SWMGMT_OBJ_SUPPORT
645	default 64
646
647config LWM2M_SWMGMT_PACKAGE_VERSION_LEN
648	int "Maximum size of the software management object's version string"
649	depends on LWM2M_SWMGMT_OBJ_SUPPORT
650	default 64
651endif # LWM2M_SWMGMT_OBJ_SUPPORT
652
653config LWM2M_PORTFOLIO_OBJ_SUPPORT
654	bool "LwM2M Portfolio object ID support (ID 16)"
655	help
656	  Include support for LwM2M Portfolio Object.
657
658config LWM2M_BINARYAPPDATA_OBJ_SUPPORT
659	bool "LwM2M BinaryAppDataContainer Object (ID 19)"
660	help
661	  Include support for LwM2M BinaryAppDataContainer Object
662
663if LWM2M_BINARYAPPDATA_OBJ_SUPPORT
664config LWM2M_BINARYAPPDATA_INSTANCE_COUNT
665	int "Maximum # of BinaryAppDataContainer object instances"
666	default 2
667	range 1 10
668	help
669	  This setting establishes the total count of BinaryAppDataContainer
670	  instances available to the client.
671
672config LWM2M_BINARYAPPDATA_DATA_INSTANCE_COUNT
673	int "Maximum # of BinaryAppDataContainer data resource instances"
674	default 2
675	range 1 10
676	help
677	  This setting establishes the total count of BinaryAppDataContainer
678	  data resource instances available to the client.
679endif # LWM2M_BINARYAPPDATA_OBJ_SUPPORT
680
681config LWM2M_EVENT_LOG_OBJ_SUPPORT
682	bool "LwM2M Event Log Object (ID 20)"
683	help
684	  Include support for LwM2M Event Log Object
685
686config LWM2M_GATEWAY_OBJ_SUPPORT
687	bool "LwM2M Gateway Object (ID 25) [EXPERIMENTAL]"
688	select EXPERIMENTAL
689
690if LWM2M_GATEWAY_OBJ_SUPPORT
691
692config LWM2M_GATEWAY_MAX_INSTANCES
693	int "Maximum number of bridged devices"
694	default 1
695	help
696	  This setting establishes the total count of LwM2M Gateway
697	  instances available to the LwM2M client.
698
699config LWM2M_GATEWAY_DEFAULT_DEVICE_ID
700	string "Identifies the IoT Device bridged to the LwM2M Gateway"
701	default "Node"
702
703config LWM2M_GATEWAY_DEVICE_ID_MAX_STR_SIZE
704	int "Maximum string size for device ID"
705	default 32
706
707config LWM2M_GATEWAY_DEFAULT_DEVICE_PREFIX
708	string "Used for access to LwM2M Objects of this IoT Device"
709	default "n"
710	help
711	  Defaults are n0, n1, n2, ..., n<max instances - 1>
712
713config LWM2M_GATEWAY_PREFIX_MAX_STR_SIZE
714	int "Max string size for prefix"
715	default 32
716
717config LWM2M_GATEWAY_DEFAULT_IOT_DEVICE_OBJECTS
718	string "Contains the Objects and Object Instances exposed by Gateway"
719	default ""
720	help
721	  It uses the same CoreLnk format as Registration Interface.
722	  This must be populated by Gateway.
723	  Example:
724	    </3>;ver=1.0,</3/0>,</4>;ver=1.0,</4/0>,
725	    </5>;ver=1.0,</5/0>,</9>;ver=1.0,</9/0>,</3303/0>
726
727config LWM2M_GATEWAY_IOT_DEVICE_OBJECTS_MAX_STR_SIZE
728	int "Maximum string size for IoT device objects"
729	default 128
730
731endif # LWM2M_GATEWAY_OBJ_SUPPORT
732
733source "subsys/net/lib/lwm2m/Kconfig.ipso"
734
735source "subsys/net/lib/lwm2m/Kconfig.ucifi"
736
737endif # LWM2M
738