Coverage Report

Created: 2026-04-10 07:28

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/PcapPlusPlus/Packet++/src/Sll2Layer.cpp
Line
Count
Source
1
0
#define LOG_MODULE PacketLogModuleSll2Layer
2
3
#include "Sll2Layer.h"
4
#include "Logger.h"
5
#include "IPv4Layer.h"
6
#include "IPv6Layer.h"
7
#include "PayloadLayer.h"
8
#include "ArpLayer.h"
9
#include "VlanLayer.h"
10
#include "PPPoELayer.h"
11
#include "MplsLayer.h"
12
#include "EndianPortable.h"
13
14
namespace pcpp
15
{
16
  Sll2Layer::Sll2Layer(uint32_t interfaceIndex, uint16_t ARPHRDType, uint8_t packetType)
17
0
  {
18
0
    const size_t headerLen = sizeof(sll2_header);
19
0
    m_DataLen = headerLen;
20
0
    m_Data = new uint8_t[headerLen];
21
0
    memset(m_Data, 0, headerLen);
22
0
    setPacketType(packetType);
23
0
    setArphrdType(ARPHRDType);
24
0
    setInterfaceIndex(interfaceIndex);
25
0
    m_Protocol = SLL2;
26
0
  }
27
28
  bool Sll2Layer::setLinkLayerAddr(const uint8_t* addr, size_t addrLength)
29
0
  {
30
0
    if (addr == nullptr || addrLength == 0 || addrLength > 8)
31
0
    {
32
0
      PCPP_LOG_ERROR("Address length is out of bounds, it must be between 1 and 8");
33
0
      return false;
34
0
    }
35
36
0
    getSll2Header()->link_layer_addr_len = addrLength;
37
0
    memcpy(getSll2Header()->link_layer_addr, addr, addrLength);
38
0
    return true;
39
0
  }
40
41
  MacAddress Sll2Layer::getLinkLayerAsMacAddress()
42
0
  {
43
0
    const uint8_t* data = getLinkLayerAddr();
44
0
    uint8_t dataLen = getLinkLayerAddrLen();
45
0
    if (data == nullptr || dataLen == 0 || dataLen > 8)
46
0
    {
47
0
      return MacAddress::Zero;
48
0
    }
49
0
    return MacAddress(data);
50
0
  }
51
52
  bool Sll2Layer::setMacAddressAsLinkLayer(const MacAddress& macAddr)
53
0
  {
54
0
    uint8_t macAddrAsArr[6];
55
0
    macAddr.copyTo(macAddrAsArr);
56
0
    return setLinkLayerAddr(macAddrAsArr, 6);
57
0
  }
58
59
  void Sll2Layer::parseNextLayer()
60
0
  {
61
0
    if (m_DataLen <= sizeof(sll2_header))
62
0
      return;
63
64
0
    uint8_t* payload = m_Data + sizeof(sll2_header);
65
0
    size_t payloadLen = m_DataLen - sizeof(sll2_header);
66
67
0
    sll2_header* hdr = getSll2Header();
68
0
    switch (be16toh(hdr->protocol_type))
69
0
    {
70
0
    case PCPP_ETHERTYPE_IP:
71
0
    {
72
0
      tryConstructNextLayerWithFallback<IPv4Layer, PayloadLayer>(payload, payloadLen);
73
0
      break;
74
0
    }
75
0
    case PCPP_ETHERTYPE_IPV6:
76
0
    {
77
0
      tryConstructNextLayerWithFallback<IPv6Layer, PayloadLayer>(payload, payloadLen);
78
0
      break;
79
0
    }
80
0
    case PCPP_ETHERTYPE_ARP:
81
0
    {
82
0
      constructNextLayer<ArpLayer>(payload, payloadLen);
83
0
      break;
84
0
    }
85
0
    case PCPP_ETHERTYPE_VLAN:
86
0
    case PCPP_ETHERTYPE_IEEE_802_1AD:
87
0
    {
88
0
      constructNextLayer<VlanLayer>(payload, payloadLen);
89
0
      break;
90
0
    }
91
0
    case PCPP_ETHERTYPE_PPPOES:
92
0
    {
93
0
      tryConstructNextLayerWithFallback<PPPoESessionLayer, PayloadLayer>(payload, payloadLen);
94
0
      break;
95
0
    }
96
0
    case PCPP_ETHERTYPE_PPPOED:
97
0
    {
98
0
      tryConstructNextLayerWithFallback<PPPoEDiscoveryLayer, PayloadLayer>(payload, payloadLen);
99
0
      break;
100
0
    }
101
0
    case PCPP_ETHERTYPE_MPLS:
102
0
    {
103
0
      constructNextLayer<MplsLayer>(payload, payloadLen);
104
0
      break;
105
0
    }
106
0
    default:
107
0
    {
108
0
      constructNextLayer<PayloadLayer>(payload, payloadLen);
109
0
      break;
110
0
    }
111
0
    }
112
0
  }
113
114
  void Sll2Layer::computeCalculateFields()
115
0
  {
116
0
    if (m_NextLayer == nullptr)
117
0
      return;
118
119
0
    sll2_header* hdr = getSll2Header();
120
0
    switch (m_NextLayer->getProtocol())
121
0
    {
122
0
    case IPv4:
123
0
      hdr->protocol_type = htobe16(PCPP_ETHERTYPE_IP);
124
0
      break;
125
0
    case IPv6:
126
0
      hdr->protocol_type = htobe16(PCPP_ETHERTYPE_IPV6);
127
0
      break;
128
0
    case ARP:
129
0
      hdr->protocol_type = htobe16(PCPP_ETHERTYPE_ARP);
130
0
      break;
131
0
    case VLAN:
132
0
      hdr->protocol_type = htobe16(PCPP_ETHERTYPE_VLAN);
133
0
      break;
134
0
    default:
135
0
      return;
136
0
    }
137
0
  }
138
139
  bool Sll2Layer::isDataValid(const uint8_t* data, size_t dataLen)
140
0
  {
141
0
    return data && dataLen >= sizeof(sll2_header);
142
0
  }
143
144
  std::string Sll2Layer::toString() const
145
0
  {
146
0
    return "Linux cooked header v2";
147
0
  }
148
149
  uint16_t Sll2Layer::getProtocolType() const
150
0
  {
151
0
    return be16toh(getSll2Header()->protocol_type);
152
0
  }
153
154
  void Sll2Layer::setProtocolType(uint16_t protocolType)
155
0
  {
156
0
    getSll2Header()->protocol_type = htobe16(protocolType);
157
0
  }
158
159
  uint32_t Sll2Layer::getInterfaceIndex() const
160
0
  {
161
0
    return be32toh(getSll2Header()->interface_index);
162
0
  }
163
164
  void Sll2Layer::setInterfaceIndex(uint32_t interfaceIndex)
165
0
  {
166
0
    getSll2Header()->interface_index = htobe32(interfaceIndex);
167
0
  }
168
169
  uint16_t Sll2Layer::getArphrdType() const
170
0
  {
171
0
    return be16toh(getSll2Header()->ARPHRD_type);
172
0
  }
173
174
  void Sll2Layer::setArphrdType(uint16_t arphrdType)
175
0
  {
176
0
    getSll2Header()->ARPHRD_type = htobe16(arphrdType);
177
0
  }
178
179
  uint8_t Sll2Layer::getPacketType() const
180
0
  {
181
0
    return getSll2Header()->packet_type;
182
0
  }
183
184
  void Sll2Layer::setPacketType(uint8_t packetType)
185
0
  {
186
0
    getSll2Header()->packet_type = packetType;
187
0
  }
188
189
  uint8_t Sll2Layer::getLinkLayerAddrLen() const
190
0
  {
191
0
    return getSll2Header()->link_layer_addr_len;
192
0
  }
193
194
  const uint8_t* Sll2Layer::getLinkLayerAddr() const
195
0
  {
196
0
    return getSll2Header()->link_layer_addr;
197
0
  }
198
199
}  // namespace pcpp