1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/net/application_layer/gcoap/Kconfig
2020-01-28 11:59:52 +01:00

145 lines
4.4 KiB
Plaintext

# 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