# Copyright (c) 2019 HAW Hamburg # # This file is subject to the terms and conditions of the GNU Lesser # General Public License v2.1. See the file LICENSE in the top level # directory for more details. # menuconfig KCONFIG_MODULE_GCOAP bool "Configure Gcoap" depends on MODULE_GCOAP help Configure Gcoap module using Kconfig. If not set default values and CFLAGS will be used. if KCONFIG_MODULE_GCOAP menu "Buffer Sizes" config GCOAP_PDU_BUF_SIZE int "Request or response buffer size" default 128 help Size of the buffer used to build a CoAP request or response. config GCOAP_REQ_OPTIONS_BUF int "Request options buffer size" default 4 help Reduce payload length by this value for a request. Accommodates writing Content-Format option in gcoap_finish(). May be set to zero if the function is not used. config GCOAP_RESP_OPTIONS_BUF int "Response options buffer size" default 4 help Reduce payload length by this value for a response. Accommodates writing Content-Format option in gcoap_finish(). May be set to zero if the function is not used. config GCOAP_OBS_OPTIONS_BUF int "Observe notification options buffer size" default 4 help Reduce payload length by this value for an observe notification. Accommodates writing Content-Format option in gcoap_finish(). May be set to zero if the function is not used. endmenu # Buffer Sizes menu "Observe options" config GCOAP_OBS_CLIENTS_MAX int "Maximum number of Observe clients" default 2 config GCOAP_OBS_REGISTRATIONS_MAX int "Maximum number of registrations for Observable resources" default 2 config GCOAP_OBS_VALUE_WIDTH int "Width of the Observe option value for a notification" default 3 range 1 3 help This width, expressed in bytes, is used to determine the length of the 'tick' used to measure the time between observable changes to a resource. A tick is expressed internally as GCOAP_OBS_TICK_EXPONENT, which is the base 2 log value of the tick length in microseconds. The canonical setting for the value is 3 (exponent 5), which results in a tick length of 32 usec, per sec. 3.4, 4.4 of the RFC. Width 2 (exponent 16) results in a tick length of ~64 msec, and width 1 (exponent 24) results in a tick length of ~17 sec. The tick length must be short enough so that the Observe value strictly increases for each new notification. The purpose of the value is to allow a client to detect message reordering withing the network latency period (128 sec). For resources that change slowly, the reduced message length is useful when packet size is limited. endmenu # Observe options menu "Timeouts and retries" config GCOAP_RECV_TIMEOUT int "Incoming message timeout" default 1000000 help Time, expressed in microseconds, that the event loop waits for an incoming CoAP message. config GCOAP_NON_TIMEOUT int "Non-confirmable response timeout" default 5000000 help Time, expressed in microseconds, to wait for a non-confirmable response. Set to 0 to disable timeout. config GCOAP_NO_RETRANS_BACKOFF bool "Disable retransmission backoff" help In normal operations the timeout between retransmissions doubles. When this option is selected the doubling does not happen, as the retransmission backoff is disabled. config GCOAP_RESEND_BUFS_MAX int "PDU buffers available for resending confirmable messages" default 1 endmenu # Timeouts and retries config GCOAP_MSG_QUEUE_SIZE int "Message queue size" default 4 config GCOAP_PORT int "Server port" default 5683 help Server port, the default is the one specified in RFC 7252. config GCOAP_REQ_WAITING_MAX int "Maximum awaiting requests" default 2 help Maximum amount of requests awaiting for a response. # defined in gcoap.h as GCOAP_TOKENLEN_MAX gcoap-tokenlen-max = 8 config GCOAP_TOKENLEN int "Token length" default 2 range 0 $(gcoap-tokenlen-max) help Lenght for a token, expressed in bytes. config GCOAP_NO_AUTO_INIT bool "Disable auto-initialization" help Disable gcoap startup during system auto init. If disabled, gcoap_init() must be called by some other means. endif # KCONFIG_MODULE_GCOAP