Package: inet.linklayer.bmac
BMacLayer
simple moduleImplementation of B-MAC (called also Berkeley MAC, Low Power Listening or LPL). See C++ documentation for details.
Inheritance diagram
The following diagram shows inheritance relationships for this type. Unresolved types are missing from the diagram.
Extends
Name | Type | Description |
---|---|---|
MACProtocolBase | simple module |
Module base for different MAC protocols. |
Parameters
Name | Type | Default value | Description |
---|---|---|---|
interfaceTableModule | string | ||
address | string | "auto" |
MAC address as hex string (12 hex digits), or "auto". "auto" values will be replaced by a generated MAC address in init stage 0. |
slotDuration | double | 0.1s |
BMAC specific parameters how long is one slot? |
headerLength | int | 10B | |
mtu | int | 0B | |
checkInterval | double | 0.01s |
how long is the check interval (CCA)? |
queueLength | int | 20 | |
animation | bool | true |
should we animate the nodes with colors depending on their state or not? |
bitrate | double | 19200 bps |
bit rate |
useMACAcks | bool | false |
should mac send and expect acknowledgments? |
macMaxFrameRetries | int | 3 |
maximum number of frame retransmission only used when usage of MAC acks is enabled |
radioModule | string | "^.radio" |
The path to the Radio module //FIXME remove default value |
maxTxAttempts | int | 2 |
Maximum transmission attempts per data packet, when ACKs are used |
Properties
Name | Value | Description |
---|---|---|
display | i=block/rxtx | |
class | BMacLayer |
Gates
Name | Direction | Size | Description |
---|---|---|---|
upperLayerIn | input | ||
upperLayerOut | output | ||
lowerLayerIn | input | ||
lowerLayerOut | output |
Signals
Name | Type | Unit |
---|---|---|
NF_LINK_BREAK | inet::BMacFrame |
Source code
// // Implementation of B-MAC (called also Berkeley MAC, Low Power Listening or // LPL). // See C++ documentation for details. // simple BMacLayer extends MACProtocolBase like IMACProtocol { parameters: string address @mutable = default("auto"); // MAC address as hex string (12 hex digits), or // "auto". "auto" values will be replaced by // a generated MAC address in init stage 0. // BMAC specific parameters // how long is one slot? double slotDuration @unit(s) = default(0.1s); int headerLength @unit(B) = default(10B); int mtu @unit("B") = default(0B); // how long is the check interval (CCA)? double checkInterval @unit(s) = default(0.01s); // size of the MAC queue (maximum number of packets in Tx buffer) int queueLength = default(20); // should we animate the nodes with colors depending on their state or // not? bool animation = default(true); // bit rate double bitrate @unit(bps) = default(19200 bps); //should mac send and expect acknowledgments? bool useMACAcks = default(false); // maximum number of frame retransmission // only used when usage of MAC acks is enabled int macMaxFrameRetries = default(3); string radioModule = default("^.radio"); // The path to the Radio module //FIXME remove default value int maxTxAttempts = default(2); // Maximum transmission attempts per data packet, when ACKs are used @class(BMacLayer); @signal[NF_LINK_BREAK](type=inet::BMacFrame); }File: src/inet/linklayer/bmac/BMacLayer.ned