1 /*
2 * Copyright (C) 2024 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16 #include "addressutils_fuzzer.h"
17
18 #include <cstddef>
19 #include <cstdint>
20 #include <unistd.h>
21 #include "securec.h"
22 #include "address_utils.h"
23 #include "dhcp_s_define.h"
24
25 namespace OHOS {
26 namespace DHCP {
27 constexpr size_t DHCP_SLEEP_1 = 2;
28 constexpr size_t U32_AT_SIZE_ZERO = 4;
29 constexpr int CFG_DATA_MAX_BYTES = 20;
30
NetworkAddressTest(const uint8_t * data,size_t size)31 void NetworkAddressTest(const uint8_t* data, size_t size)
32 {
33 uint32_t index = 0;
34 uint32_t ip = static_cast<uint32_t>(data[index++]);
35 uint32_t netmask = static_cast<uint32_t>(data[0]);
36 NetworkAddress(ip, netmask);
37 }
38
FirstIpAddressTest(const uint8_t * data,size_t size)39 void FirstIpAddressTest(const uint8_t* data, size_t size)
40 {
41 uint32_t index = 0;
42 uint32_t ip = static_cast<uint32_t>(data[index++]);
43 uint32_t netmask = static_cast<uint32_t>(data[0]);
44 FirstIpAddress(ip, netmask);
45 }
46
NextIpAddressTest(const uint8_t * data,size_t size)47 void NextIpAddressTest(const uint8_t* data, size_t size)
48 {
49 uint32_t index = 0;
50 uint32_t currIp = static_cast<uint32_t>(data[index++]);
51 uint32_t netmask = static_cast<uint32_t>(data[0]);
52 uint32_t offset = static_cast<uint32_t>(data[index++]);
53 NextIpAddress(currIp, netmask, offset);
54 }
55
FirstNetIpAddressTest(const uint8_t * data,size_t size)56 void FirstNetIpAddressTest(const uint8_t* data, size_t size)
57 {
58 uint32_t index = 0;
59 uint32_t networkAddr = static_cast<uint32_t>(data[index++]);
60 FirstNetIpAddress(networkAddr);
61 }
62
LastIpAddressTest(const uint8_t * data,size_t size)63 void LastIpAddressTest(const uint8_t* data, size_t size)
64 {
65 uint32_t index = 0;
66 uint32_t ip = static_cast<uint32_t>(data[index++]);
67 uint32_t netmask = static_cast<uint32_t>(data[0]);
68 LastIpAddress(ip, netmask);
69 }
70
IpInNetworkTest(const uint8_t * data,size_t size)71 void IpInNetworkTest(const uint8_t* data, size_t size)
72 {
73 uint32_t index = 0;
74 uint32_t ip = static_cast<uint32_t>(data[index++]);
75 uint32_t network = static_cast<uint32_t>(data[index++]);
76 uint32_t netmask = static_cast<uint32_t>(data[0]);
77 IpInNetwork(ip, network, netmask);
78 }
79
IpInRangeTest(const uint8_t * data,size_t size)80 void IpInRangeTest(const uint8_t* data, size_t size)
81 {
82 uint32_t index = 0;
83 uint32_t ip = static_cast<uint32_t>(data[index++]);
84 uint32_t beginIp = static_cast<uint32_t>(data[index++]);
85 uint32_t endIp = static_cast<uint32_t>(data[index++]);
86 uint32_t netmask = static_cast<uint32_t>(data[0]);
87 IpInRange(ip, beginIp, endIp, netmask);
88 }
89
BroadCastAddressTest(const uint8_t * data,size_t size)90 void BroadCastAddressTest(const uint8_t* data, size_t size)
91 {
92 uint32_t index = 0;
93 uint32_t ip = static_cast<uint32_t>(data[index++]);
94 uint32_t netmask = static_cast<uint32_t>(data[0]);
95 BroadCastAddress(ip, netmask);
96 }
97
ParseIpAddrTest(const uint8_t * data,size_t size)98 void ParseIpAddrTest(const uint8_t* data, size_t size)
99 {
100 const char *strIp = "TEXT";
101 (void)ParseIpAddr(strIp);
102 }
103
HostTotalTest(const uint8_t * data,size_t size)104 void HostTotalTest(const uint8_t* data, size_t size)
105 {
106 uint32_t netmask = static_cast<uint32_t>(data[0]);
107 HostTotal(netmask);
108 }
109
ParseIpTest(const uint8_t * data,size_t size)110 void ParseIpTest(const uint8_t* data, size_t size)
111 {
112 uint8_t *ipAddr = nullptr;
113 if (memcpy_s(ipAddr, CFG_DATA_MAX_BYTES, data, CFG_DATA_MAX_BYTES - 1) != EOK) {
114 return;
115 }
116 ParseIp(ipAddr);
117 }
118
IsEmptyHWAddrTest(const uint8_t * data,size_t size)119 void IsEmptyHWAddrTest(const uint8_t* data, size_t size)
120 {
121 uint8_t ipAddr[DHCP_HWADDR_LENGTH];
122 IsEmptyHWAddr(&ipAddr[0]);
123 }
124
ParseStrMacTest(const uint8_t * data,size_t size)125 void ParseStrMacTest(const uint8_t* data, size_t size)
126 {
127 uint8_t* macAddr = nullptr;
128 size_t addrSize = MAC_ADDR_LENGTH;
129 ParseStrMac(macAddr, addrSize);
130 }
131
ParseMacAddressTest(const uint8_t * data,size_t size)132 void ParseMacAddressTest(const uint8_t* data, size_t size)
133 {
134 const char *strMac = "TEXT";
135 uint8_t macAddr[DHCP_HWADDR_LENGTH];
136 (void)ParseMacAddress(strMac, &macAddr[0]);
137 }
138
ParseHostNameTest(const uint8_t * data,size_t size)139 void ParseHostNameTest(const uint8_t* data, size_t size)
140 {
141 const char *strHostName = "TEXT";
142 char hostName[DHCP_BOOT_FILE_LENGTH];
143 (void)ParseHostName(strHostName, &hostName[0]);
144 }
145
HostToNetworkTest(const uint8_t * data,size_t size)146 void HostToNetworkTest(const uint8_t* data, size_t size)
147 {
148 uint32_t index = 0;
149 uint32_t host = static_cast<uint32_t>(data[index++]);
150 HostToNetwork(host);
151 }
152
NetworkToHostTest(const uint8_t * data,size_t size)153 void NetworkToHostTest(const uint8_t* data, size_t size)
154 {
155 uint32_t index = 0;
156 uint32_t network = static_cast<uint32_t>(data[index++]);
157 NetworkToHost(network);
158 }
159
ParseLogMacTest(const uint8_t * data,size_t size)160 void ParseLogMacTest(const uint8_t* data, size_t size)
161 {
162 uint8_t macAddr[DHCP_HWADDR_LENGTH];
163 ParseLogMac(&macAddr[0]);
164 }
165
AddrEquelsTest(const uint8_t * data,size_t size)166 void AddrEquelsTest(const uint8_t* data, size_t size)
167 {
168 int index = 0;
169 int addrLength = static_cast<int>(data[index++]);
170 uint8_t firstAddr[DHCP_HWADDR_LENGTH];
171 uint8_t secondAddr[DHCP_HWADDR_LENGTH];
172 AddrEquels(&firstAddr[0], &secondAddr[0], addrLength);
173 }
174
175 /* Fuzzer entry point */
LLVMFuzzerTestOneInput(const uint8_t * data,size_t size)176 extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
177 {
178 if ((data == nullptr) || (size <= OHOS::DHCP::U32_AT_SIZE_ZERO)) {
179 return 0;
180 }
181 sleep(DHCP_SLEEP_1);
182 OHOS::DHCP::NetworkAddressTest(data, size);
183 OHOS::DHCP::FirstIpAddressTest(data, size);
184 OHOS::DHCP::NextIpAddressTest(data, size);
185 OHOS::DHCP::FirstNetIpAddressTest(data, size);
186 OHOS::DHCP::LastIpAddressTest(data, size);
187 OHOS::DHCP::IpInNetworkTest(data, size);
188 OHOS::DHCP::IpInRangeTest(data, size);
189 OHOS::DHCP::BroadCastAddressTest(data, size);
190 OHOS::DHCP::ParseIpAddrTest(data, size);
191 OHOS::DHCP::HostTotalTest(data, size);
192 OHOS::DHCP::ParseIpTest(data, size);
193 OHOS::DHCP::IsEmptyHWAddrTest(data, size);
194 OHOS::DHCP::ParseStrMacTest(data, size);
195 OHOS::DHCP::ParseMacAddressTest(data, size);
196 OHOS::DHCP::ParseHostNameTest(data, size);
197 OHOS::DHCP::HostToNetworkTest(data, size);
198 OHOS::DHCP::NetworkToHostTest(data, size);
199 OHOS::DHCP::ParseLogMacTest(data, size);
200 OHOS::DHCP::AddrEquelsTest(data, size);
201 return 0;
202 }
203 } // namespace DHCP
204 } // namespace OHOS
205