mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
3cc6c68ec4
pkg/nimble: configure BLE_LL_INIT_SLOT_SIZE to 1
136 lines
4.9 KiB
Makefile
136 lines
4.9 KiB
Makefile
NIMIBASE = -I$(PKGDIRBASE)/nimble
|
|
|
|
# include RIOT glue code headers
|
|
INCLUDES += -I$(RIOTPKG)/nimble/contrib/include
|
|
|
|
# include generic nimble headers
|
|
INCLUDES += $(NIMIBASE)/nimble/include
|
|
|
|
# include the RIOT NPL headers
|
|
ifneq (,$(filter nimble_npl_riot,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/porting/npl/riot/include
|
|
else
|
|
INCLUDES += $(NIMIBASE)/porting/npl/riot/include/npl_syscfg
|
|
INCLUDES += -I$(RIOTPKG)/nimble/npl/include
|
|
endif
|
|
INCLUDES += $(NIMIBASE)/porting/nimble/include
|
|
|
|
# include nimble controller headers
|
|
ifneq (,$(filter nimble_controller,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/controller/include
|
|
# set environment
|
|
CFLAGS += -DNIMBLE_CFG_CONTROLLER=1
|
|
ifneq (,$(filter nimble_npl_riot,$(USEMODULE)))
|
|
CFLAGS += -DMYNEWT_VAL_OS_CPUTIME_FREQ=32768
|
|
endif
|
|
ifneq (,$(filter nimble_drivers_nrf5x,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/drivers/$(CPU_FAM)/include
|
|
endif
|
|
endif
|
|
|
|
# include nimble host headers
|
|
ifneq (,$(filter nimble_host,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/include
|
|
endif
|
|
ifneq (,$(filter nimble_host_store_ram,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/store/ram/include
|
|
endif
|
|
ifneq (,$(filter nimble_host_util,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/util/include
|
|
endif
|
|
|
|
# include tinycrypt headers
|
|
ifneq (,$(filter nimble_controller,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/ext/tinycrypt/include
|
|
endif
|
|
|
|
# include transport headers
|
|
ifneq (,$(filter nimble_transport_ram,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/transport/ram/include
|
|
endif
|
|
|
|
# include services
|
|
ifneq (,$(filter nimble_svc_ans,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/services/ans/include
|
|
endif
|
|
ifneq (,$(filter nimble_svc_bas,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/services/bas/include
|
|
endif
|
|
ifneq (,$(filter nimble_svc_bleuart,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/services/bleuart/include
|
|
endif
|
|
ifneq (,$(filter nimble_svc_gap,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/services/gap/include
|
|
endif
|
|
ifneq (,$(filter nimble_svc_gatt,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/services/gatt/include
|
|
endif
|
|
ifneq (,$(filter nimble_svc_ias,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/services/ias/include
|
|
endif
|
|
ifneq (,$(filter nimble_svc_ipss,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/services/ipss/include
|
|
endif
|
|
ifneq (,$(filter nimble_svc_lls,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/services/lls/include
|
|
endif
|
|
ifneq (,$(filter nimble_svc_tps,$(USEMODULE)))
|
|
INCLUDES += $(NIMIBASE)/nimble/host/services/tps/include
|
|
endif
|
|
|
|
# include additional headers for RIOT specific NimBLE submodules
|
|
ifneq (,$(filter nimble_addr,$(USEMODULE)))
|
|
INCLUDES += -I$(RIOTPKG)/nimble/addr/include
|
|
endif
|
|
ifneq (,$(filter nimble_autoadv,$(USEMODULE)))
|
|
INCLUDES += -I$(RIOTPKG)/nimble/autoadv/include
|
|
endif
|
|
ifneq (,$(filter nimble_autoconn,$(USEMODULE)))
|
|
INCLUDES += -I$(RIOTPKG)/nimble/autoconn/include
|
|
endif
|
|
ifneq (,$(filter nimble_netif,$(USEMODULE)))
|
|
INCLUDES += -I$(RIOTPKG)/nimble/netif/include
|
|
|
|
# when using IP, the host should have a higher prio than the netif thread, but
|
|
# MUST always have a lower priority then the controller thread. Setting it to
|
|
# controller prio plus will guarantee the latter while also matching the first
|
|
# condition as long as the default netif prio is not changed.
|
|
CFLAGS += -DNIMBLE_HOST_PRIO="(NIMBLE_CONTROLLER_PRIO + 1)"
|
|
|
|
# configure NimBLE's internals
|
|
NIMBLE_MAX_CONN ?= 3
|
|
CFLAGS += -DMYNEWT_VAL_BLE_L2CAP_COC_MAX_NUM=$(NIMBLE_MAX_CONN)
|
|
CFLAGS += -DMYNEWT_VAL_BLE_MAX_CONNECTIONS=$(NIMBLE_MAX_CONN)
|
|
|
|
# the maximum fragment size that we can receive. For maximum efficiency this
|
|
# should be equal to the maximum configured link layer packet size.
|
|
# WARNING: this value MUST never be larger than MYNEWT_VAL_BLE_LL_MAX_PKT_SIZE
|
|
CFLAGS += -DMYNEWT_VAL_BLE_L2CAP_COC_MPS=251
|
|
|
|
# in order to fit a 251 byte COC data segment into a single mbuf buffer, the
|
|
# used block size must be at least 297 byte (251 data + 48 overhead)
|
|
CFLAGS += -DMYNEWT_VAL_MSYS_1_BLOCK_SIZE="(MYNEWT_VAL_BLE_L2CAP_COC_MPS + 48)"
|
|
|
|
# in the worst case, NimBLEs internal buffer needs to hold two full IPv6 MTUs
|
|
# per connection (1 TX and 1 RX). But in practice this would be highly over-
|
|
# provisioned. Allocating 10 memory blocks per connection plus another 5
|
|
# for internal buffering has proven to be a generous default value.
|
|
CFLAGS += -DMYNEWT_VAL_MSYS_1_BLOCK_COUNT=35
|
|
|
|
# optimize the NimBLE controller for IP traffic
|
|
ifneq (,$(filter nimble_controller,$(USEMODULE)))
|
|
CFLAGS += -DMYNEWT_VAL_BLE_LL_MAX_PKT_SIZE=251
|
|
CFLAGS += -DMYNEWT_VAL_BLE_LL_CONN_INIT_SLOTS=1
|
|
CFLAGS += -DMYNEWT_VAL_BLE_LL_CFG_FEAT_DATA_LEN_EXT=1
|
|
endif
|
|
endif
|
|
ifneq (,$(filter nimble_scanlist,$(USEMODULE)))
|
|
INCLUDES += -I$(RIOTPKG)/nimble/scanlist/include
|
|
endif
|
|
ifneq (,$(filter nimble_scanner,$(USEMODULE)))
|
|
INCLUDES += -I$(RIOTPKG)/nimble/scanner/include
|
|
endif
|
|
ifneq (,$(filter nimble_statconn,$(USEMODULE)))
|
|
INCLUDES += -I$(RIOTPKG)/nimble/statconn/include
|
|
endif
|