2016-02-27 07:27:58 +08:00
|
|
|
#
|
|
|
|
# For a description of the syntax of this configuration file,
|
|
|
|
# see the file kconfig-language.txt in the NuttX tools repository.
|
|
|
|
#
|
|
|
|
|
2017-05-15 05:55:07 +08:00
|
|
|
menuconfig WIRELESS_IEEE802154
|
|
|
|
bool "IEEE 802.15.4 Support"
|
2016-02-27 07:27:58 +08:00
|
|
|
default n
|
2017-05-09 21:34:59 +08:00
|
|
|
select MM_IOB
|
2017-05-15 05:55:07 +08:00
|
|
|
depends on WIRELESS
|
2016-06-01 18:12:21 +08:00
|
|
|
---help---
|
|
|
|
Enables a Media Access Controller for any IEEE802.15.4 radio
|
|
|
|
device. This in turn can be used by higher layer entities
|
2017-05-15 05:55:07 +08:00
|
|
|
such as 6lowpan.
|
2016-06-01 18:12:21 +08:00
|
|
|
|
2017-05-15 05:55:07 +08:00
|
|
|
if WIRELESS_IEEE802154
|
2017-04-26 23:30:54 +08:00
|
|
|
|
2017-11-02 04:15:21 +08:00
|
|
|
config IEEE802154_PRIMITIVE_PREALLOC
|
|
|
|
int "Number of pre-allocated primitive structures"
|
|
|
|
default 20
|
|
|
|
---help---
|
|
|
|
This specifies the total number of preallocated primitive structures.
|
|
|
|
A primitive is an abstracted data type that provides service information
|
|
|
|
between the MAC layer and the next highest layer. These may be allocated
|
|
|
|
from either from tasking logic or from interrupt level logic.
|
|
|
|
|
|
|
|
config IEEE802154_PRIMITIVE_IRQRESERVE
|
|
|
|
int "Reserved pre-allocated primitive structures"
|
|
|
|
default 0
|
|
|
|
depends on EXPERIMENTAL
|
|
|
|
---help---
|
2018-04-02 02:25:30 +08:00
|
|
|
If primitives can be allocated from interrupt handlers, then this
|
|
|
|
specifies the number of pre-allocated meta-data structures that are
|
2017-11-02 04:15:21 +08:00
|
|
|
reserved for for use only by interrupt handlers. This may be zero to
|
|
|
|
reserve no meta-data structures for interrupt handlers. In that case,
|
|
|
|
the allocation will fail if tasking logic has allocated them all.
|
|
|
|
|
|
|
|
Interrupt logic will first attempt to allocate from the general,
|
|
|
|
pre-allocated structure pool that will contain up to (size
|
|
|
|
CONFIG_IEEE802154_PRIMITIVE_PREALLOC - CONFIG_IEEE802154_PRIMITIVE_IRQRESERVE)
|
|
|
|
entries. If that fails, then it will try to take a structure from
|
|
|
|
the reserve (size CONFIG_IEEE802154_PRIMITIVE_IRQRESERVE).
|
|
|
|
|
|
|
|
Non-interrupt logic will also first attempt to allocate from the
|
|
|
|
general, pre-allocated structure pool. If that fails, it will
|
|
|
|
dynamically allocate the primitive with an additional cost in performance.
|
|
|
|
|
|
|
|
NOTE: Currently marked as experimental and with a default of zero
|
|
|
|
because there are no interrupt level allocations performed by the
|
|
|
|
current IEEE 802.15.4 MAC code.
|
|
|
|
|
|
|
|
config IEEE802154_MAC
|
|
|
|
bool "Software MAC layer"
|
|
|
|
default n
|
2017-04-26 23:30:54 +08:00
|
|
|
---help---
|
2017-11-02 04:15:21 +08:00
|
|
|
There are two types of IEEE 802.15.4 radios supported. Those that provide
|
|
|
|
all MAC functionality equivalent to the MAC802154 software implementation,
|
|
|
|
and radios that provide a lower half to the MAC802154 software layer.
|
|
|
|
This option enables the software MAC layer that can interface with
|
|
|
|
the lower-half radio drivers.
|
2017-06-22 00:40:36 +08:00
|
|
|
|
2017-11-02 04:15:21 +08:00
|
|
|
if IEEE802154_MAC
|
2017-04-26 23:30:54 +08:00
|
|
|
|
2017-06-22 00:08:25 +08:00
|
|
|
config MAC802154_NTXDESC
|
2017-04-26 23:30:54 +08:00
|
|
|
int "Number or TX descriptors"
|
2017-11-02 04:15:21 +08:00
|
|
|
default 5
|
2017-04-26 23:30:54 +08:00
|
|
|
---help---
|
|
|
|
Configured number of Tx descriptors. Default: 3
|
2017-06-21 03:30:17 +08:00
|
|
|
|
|
|
|
When used with 6LoWPAN, the descriptor allocator runs on a work
|
|
|
|
and must avoid blocking if possible. Each frame will be provided in
|
|
|
|
an IOB and each TX frame will need a TX descriptor. So the safe
|
2017-06-22 00:08:25 +08:00
|
|
|
thing to do is set CONFIG_MAC802154_NTXDESC to CONFIG_IOB_NBUFFERS.
|
2017-06-21 03:30:17 +08:00
|
|
|
Then there should be the maximum pre-allocated buffers for each
|
|
|
|
possible TX frame.
|
|
|
|
|
2017-06-26 06:07:50 +08:00
|
|
|
config MAC802154_NPANDESC
|
|
|
|
int "Number of PAN descriptors"
|
|
|
|
default 5
|
|
|
|
---help---
|
|
|
|
Configured number of PAN descriptors Default: 5
|
|
|
|
|
|
|
|
When performing a scan to find a suitable PAN, the MAC must store
|
|
|
|
information for all unique beacons received. This is the number of unique
|
|
|
|
descriptors that can be held before the scan cancels with LIMIT_REACHED.
|
|
|
|
|
2017-07-10 11:57:11 +08:00
|
|
|
config MAC802154_SFEVENT_VERBOSE
|
|
|
|
bool "Verbose logging related to superframe events"
|
|
|
|
default n
|
|
|
|
depends on DEBUG_WIRELESS_INFO
|
|
|
|
---help---
|
|
|
|
Enable verbose logging of superframe events Default: false
|
|
|
|
|
2017-06-18 22:53:31 +08:00
|
|
|
config IEEE802154_MACDEV
|
|
|
|
bool "Character driver for IEEE 802.15.4 MAC layer"
|
|
|
|
default n
|
|
|
|
depends on WIRELESS_IEEE802154
|
|
|
|
---help---
|
|
|
|
Enable the device driver to expose the IEEE 802.15.4 MAC layer
|
|
|
|
access to user space as IOCTLs
|
|
|
|
|
|
|
|
if IEEE802154_MACDEV
|
|
|
|
|
2017-06-19 01:00:47 +08:00
|
|
|
config IEEE802154_MACDEV_RECVRPRIO
|
2020-02-23 16:50:23 +08:00
|
|
|
int "Priority of frame receiver registered with the MAC layer"
|
2017-06-18 22:53:31 +08:00
|
|
|
default 0
|
|
|
|
---help---
|
|
|
|
When the MAC layer receives an incoming data frame, it passes the frame
|
|
|
|
to registered receivers, in order of receiver priority, until one of the
|
2017-06-19 01:00:47 +08:00
|
|
|
receivers claim the frame.
|
|
|
|
|
2017-06-18 22:53:31 +08:00
|
|
|
An example case would be when 6LoWPAN and the MAC character driver are
|
|
|
|
enabled. Both have receivers registered with the MAC. The 6LoWPAN layer
|
|
|
|
should get assigned a higher priority than the character driver. In this
|
|
|
|
case, the 6LoWPAN receiver will receive the frame first. If the frame is
|
|
|
|
a 6LoWPAN frame, it will claim the frame and the MAC will not pass the
|
|
|
|
frame to any additional receivers. If it does not claim the frame, the
|
|
|
|
MAC layer will call the next highest priority receiver, in this case,
|
|
|
|
the MAC character driver (which should always be lowest priority since
|
|
|
|
it is a "catch-all" type receiver).
|
|
|
|
|
|
|
|
endif # IEEE802154_MACDEV
|
2017-05-06 02:50:34 +08:00
|
|
|
|
2017-04-09 03:27:03 +08:00
|
|
|
config IEEE802154_NETDEV
|
2017-06-19 06:00:08 +08:00
|
|
|
bool "IEEE802154 6LoWPAN Network Device"
|
2017-04-09 03:27:03 +08:00
|
|
|
default n
|
2017-08-21 01:14:43 +08:00
|
|
|
depends on NET_6LOWPAN || NET_IEEE802154
|
2017-04-09 03:27:03 +08:00
|
|
|
select ARCH_HAVE_NETDEV_STATISTICS
|
|
|
|
---help---
|
2017-06-19 06:00:08 +08:00
|
|
|
Add support for the IEEE802.15.4 6LoWPAN network device built on
|
2017-04-09 03:27:03 +08:00
|
|
|
the common IEEE802.15.4 MAC.
|
|
|
|
|
|
|
|
if IEEE802154_NETDEV
|
|
|
|
|
2017-06-19 01:00:47 +08:00
|
|
|
config IEEE802154_NETDEV_RECVRPRIO
|
2020-02-23 16:50:23 +08:00
|
|
|
int "Priority of frame receiver registered with the MAC layer"
|
2017-06-19 01:00:47 +08:00
|
|
|
default 1
|
|
|
|
---help---
|
|
|
|
When the MAC layer receives an incoming data frame, it passes the frame
|
|
|
|
to registered receivers, in order of receiver priority, until one of the
|
|
|
|
receivers claim the frame.
|
|
|
|
|
|
|
|
An example case would be when 6LoWPAN and the MAC character driver are
|
|
|
|
enabled. Both have receivers registered with the MAC. The 6LoWPAN layer
|
|
|
|
should get assigned a higher priority than the character driver. In this
|
|
|
|
case, the 6LoWPAN receiver will receive the frame first. If the frame is
|
|
|
|
a 6LoWPAN frame, it will claim the frame and the MAC will not pass the
|
|
|
|
frame to any additional receivers. If it does not claim the frame, the
|
|
|
|
MAC layer will call the next highest priority receiver, in this case,
|
|
|
|
the MAC character driver (which should always be lowest priority since
|
|
|
|
it is a "catch-all" type receiver).
|
|
|
|
|
2019-08-11 01:02:26 +08:00
|
|
|
config IEEE802154_NETDEV_DEFAULT_PREFIX_0
|
|
|
|
hex "IPv6 Prefix 0"
|
|
|
|
default 0xfe80
|
|
|
|
---help---
|
|
|
|
First section of IPv6 Prefix
|
|
|
|
|
|
|
|
config IEEE802154_NETDEV_DEFAULT_PREFIX_1
|
|
|
|
hex "IPv6 Prefix 1"
|
|
|
|
default 0x0000
|
|
|
|
---help---
|
|
|
|
Second section of IPv6 Prefix
|
|
|
|
|
|
|
|
config IEEE802154_NETDEV_DEFAULT_PREFIX_2
|
|
|
|
hex "IPv6 Prefix 2"
|
|
|
|
default 0x0000
|
|
|
|
---help---
|
|
|
|
Third section of IPv6 Prefix
|
|
|
|
|
|
|
|
config IEEE802154_NETDEV_DEFAULT_PREFIX_3
|
|
|
|
hex "IPv6 Prefix 3"
|
|
|
|
default 0x0000
|
|
|
|
---help---
|
|
|
|
Fourth section of IPv6 Prefix
|
|
|
|
|
2017-04-09 03:27:03 +08:00
|
|
|
endif # IEEE802154_NETDEV
|
2017-11-02 04:15:21 +08:00
|
|
|
endif # IEEE802154_MACDEV
|
|
|
|
|
2017-04-03 06:29:02 +08:00
|
|
|
config IEEE802154_LOOPBACK
|
2017-06-19 06:00:08 +08:00
|
|
|
bool "IEEE802154 6LoWPAN Loopback"
|
2017-04-03 06:29:02 +08:00
|
|
|
default n
|
2017-08-21 01:14:43 +08:00
|
|
|
depends on NET_6LOWPAN || NET_IEEE802154
|
2017-04-03 06:29:02 +08:00
|
|
|
select ARCH_HAVE_NETDEV_STATISTICS
|
|
|
|
---help---
|
2017-06-19 06:00:08 +08:00
|
|
|
Add support for the IEEE802.15.4 6LoWPAN Loopback test device.
|
2017-04-03 06:29:02 +08:00
|
|
|
|
2017-04-03 06:29:02 +08:00
|
|
|
if IEEE802154_LOOPBACK
|
|
|
|
endif # IEEE802154_LOOPBACK
|
|
|
|
|
2017-04-03 22:46:16 +08:00
|
|
|
endif # WIRELESS_IEEE802154
|