/src/curl_fuzzer/curl_fuzzer_tlv.cc
Line | Count | Source (jump to first uncovered line) |
1 | | /*************************************************************************** |
2 | | * _ _ ____ _ |
3 | | * Project ___| | | | _ \| | |
4 | | * / __| | | | |_) | | |
5 | | * | (__| |_| | _ <| |___ |
6 | | * \___|\___/|_| \_\_____| |
7 | | * |
8 | | * Copyright (C) 2017, Max Dymond, <cmeister2@gmail.com>, et al. |
9 | | * |
10 | | * This software is licensed as described in the file COPYING, which |
11 | | * you should have received as part of this distribution. The terms |
12 | | * are also available at https://curl.se/docs/copyright.html. |
13 | | * |
14 | | * You may opt to use, copy, modify, merge, publish, distribute and/or sell |
15 | | * copies of the Software, and permit persons to whom the Software is |
16 | | * furnished to do so, under the terms of the COPYING file. |
17 | | * |
18 | | * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
19 | | * KIND, either express or implied. |
20 | | * |
21 | | ***************************************************************************/ |
22 | | #include <stdlib.h> |
23 | | #include <string.h> |
24 | | #include <curl/curl.h> |
25 | | #include "curl_fuzzer.h" |
26 | | |
27 | | /** |
28 | | * TLV access function - gets the first TLV from a data stream. |
29 | | */ |
30 | | int fuzz_get_first_tlv(FUZZ_DATA *fuzz, |
31 | | TLV *tlv) |
32 | 1.76M | { |
33 | | /* Reset the cursor. */ |
34 | 1.76M | fuzz->state.data_pos = 0; |
35 | 1.76M | return fuzz_get_tlv_comn(fuzz, tlv); |
36 | 1.76M | } |
37 | | |
38 | | /** |
39 | | * TLV access function - gets the next TLV from a data stream. |
40 | | */ |
41 | | int fuzz_get_next_tlv(FUZZ_DATA *fuzz, |
42 | | TLV *tlv) |
43 | 8.35M | { |
44 | | /* Advance the cursor by the full length of the previous TLV. */ |
45 | 8.35M | fuzz->state.data_pos += sizeof(TLV_RAW) + tlv->length; |
46 | | |
47 | | /* Work out if there's a TLV's worth of data to read */ |
48 | 8.35M | if(fuzz->state.data_pos + sizeof(TLV_RAW) > fuzz->state.data_len) { |
49 | | /* No more TLVs to parse */ |
50 | 1.43M | return TLV_RC_NO_MORE_TLVS; |
51 | 1.43M | } |
52 | | |
53 | 6.91M | return fuzz_get_tlv_comn(fuzz, tlv); |
54 | 8.35M | } |
55 | | |
56 | | /** |
57 | | * Common TLV function for accessing TLVs in a data stream. |
58 | | */ |
59 | | int fuzz_get_tlv_comn(FUZZ_DATA *fuzz, |
60 | | TLV *tlv) |
61 | 8.68M | { |
62 | 8.68M | int rc = 0; |
63 | 8.68M | size_t data_offset; |
64 | 8.68M | TLV_RAW *raw; |
65 | | |
66 | | /* Start by casting the data stream to a TLV. */ |
67 | 8.68M | raw = (TLV_RAW *)&fuzz->state.data[fuzz->state.data_pos]; |
68 | 8.68M | data_offset = fuzz->state.data_pos + sizeof(TLV_RAW); |
69 | | |
70 | | /* Set the TLV values. */ |
71 | 8.68M | tlv->type = to_u16(raw->raw_type); |
72 | 8.68M | tlv->length = to_u32(raw->raw_length); |
73 | 8.68M | tlv->value = &fuzz->state.data[data_offset]; |
74 | | |
75 | 8.68M | FV_PRINTF(fuzz, "TLV: type %x length %u\n", tlv->type, tlv->length); |
76 | | |
77 | | /* Use uint64s to verify lengths of TLVs so that overflow problems don't |
78 | | matter. */ |
79 | 8.68M | uint64_t check_length = data_offset; |
80 | 8.68M | check_length += tlv->length; |
81 | | |
82 | 8.68M | uint64_t remaining_len = fuzz->state.data_len; |
83 | 8.68M | FV_PRINTF(fuzz, "Check length of data: %" PRIu64 " \n", check_length); |
84 | 8.68M | FV_PRINTF(fuzz, "Remaining length of data: %" PRIu64 " \n", remaining_len); |
85 | | |
86 | | /* Sanity check that the TLV length is ok. */ |
87 | 8.68M | if(check_length > remaining_len) { |
88 | 195k | FV_PRINTF(fuzz, "Returning TLV_RC_SIZE_ERROR\n"); |
89 | 195k | rc = TLV_RC_SIZE_ERROR; |
90 | 195k | } |
91 | | |
92 | 8.68M | return rc; |
93 | 8.68M | } |
94 | | |
95 | | /** |
96 | | * Do different actions on the CURL handle for different received TLVs. |
97 | | */ |
98 | | int fuzz_parse_tlv(FUZZ_DATA *fuzz, TLV *tlv) |
99 | 7.08M | { |
100 | 7.08M | int rc; |
101 | 7.08M | char *tmp = NULL; |
102 | 7.08M | uint32_t tmp_u32; |
103 | 7.08M | curl_slist *new_list; |
104 | | |
105 | 7.08M | switch(tlv->type) { |
106 | | /* The pointers in response TLVs will always be valid as long as the fuzz |
107 | | data is in scope, which is the entirety of this file. */ |
108 | 32.4k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE0, 0); |
109 | 42.2k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE1, 1); |
110 | 20.8k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE2, 2); |
111 | 37.3k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE3, 3); |
112 | 12.0k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE4, 4); |
113 | 28.3k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE5, 5); |
114 | 11.5k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE6, 6); |
115 | 6.19k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE7, 7); |
116 | 3.46k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE8, 8); |
117 | 30.6k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE9, 9); |
118 | 3.15k | FRESPONSETLV(&fuzz->sockman[0], TLV_TYPE_RESPONSE10, 10); |
119 | | |
120 | 4.07k | FRESPONSETLV(&fuzz->sockman[1], TLV_TYPE_SECOND_RESPONSE0, 0); |
121 | 4.13k | FRESPONSETLV(&fuzz->sockman[1], TLV_TYPE_SECOND_RESPONSE1, 1); |
122 | | |
123 | 2.16k | case TLV_TYPE_UPLOAD1: |
124 | | /* The pointers in the TLV will always be valid as long as the fuzz data |
125 | | is in scope, which is the entirety of this file. */ |
126 | | |
127 | 2.16k | FCHECK_OPTION_UNSET(fuzz, CURLOPT_UPLOAD); |
128 | | |
129 | 2.14k | fuzz->upload1_data = tlv->value; |
130 | 2.14k | fuzz->upload1_data_len = tlv->length; |
131 | | |
132 | 2.14k | FSET_OPTION(fuzz, CURLOPT_UPLOAD, 1L); |
133 | 2.14k | FSET_OPTION(fuzz, |
134 | 2.14k | CURLOPT_INFILESIZE_LARGE, |
135 | 2.14k | (curl_off_t)fuzz->upload1_data_len); |
136 | 2.14k | break; |
137 | | |
138 | 279k | case TLV_TYPE_HEADER: |
139 | | /* Limit the number of headers that can be added to a message to prevent |
140 | | timeouts. */ |
141 | 279k | if(fuzz->header_list_count >= TLV_MAX_NUM_CURLOPT_HEADER) { |
142 | 14 | rc = 255; |
143 | 14 | goto EXIT_LABEL; |
144 | 14 | } |
145 | | |
146 | 279k | tmp = fuzz_tlv_to_string(tlv); |
147 | 279k | if (tmp == NULL) { |
148 | | // keep on despite allocation failure |
149 | 0 | break; |
150 | 0 | } |
151 | 279k | new_list = curl_slist_append(fuzz->header_list, tmp); |
152 | 279k | if (new_list == NULL) { |
153 | 0 | break; |
154 | 0 | } |
155 | 279k | fuzz->header_list = new_list; |
156 | 279k | fuzz->header_list_count++; |
157 | 279k | break; |
158 | | |
159 | 40.3k | case TLV_TYPE_MAIL_RECIPIENT: |
160 | | /* Limit the number of headers that can be added to a message to prevent |
161 | | timeouts. */ |
162 | 40.3k | if(fuzz->header_list_count >= TLV_MAX_NUM_CURLOPT_HEADER) { |
163 | 13 | rc = 255; |
164 | 13 | goto EXIT_LABEL; |
165 | 13 | } |
166 | 40.3k | tmp = fuzz_tlv_to_string(tlv); |
167 | 40.3k | if (tmp == NULL) { |
168 | | // keep on despite allocation failure |
169 | 0 | break; |
170 | 0 | } |
171 | 40.3k | new_list = curl_slist_append(fuzz->mail_recipients_list, tmp); |
172 | 40.3k | if (new_list != NULL) { |
173 | 40.3k | fuzz->mail_recipients_list = new_list; |
174 | 40.3k | fuzz->header_list_count++; |
175 | 40.3k | } |
176 | 40.3k | break; |
177 | | |
178 | 6.14M | case TLV_TYPE_MIME_PART: |
179 | 6.14M | if(fuzz->mime == NULL) { |
180 | 6.28k | fuzz->mime = curl_mime_init(fuzz->easy); |
181 | 6.28k | } |
182 | | |
183 | 6.14M | fuzz->part = curl_mime_addpart(fuzz->mime); |
184 | | |
185 | | /* This TLV may have sub TLVs. */ |
186 | 6.14M | fuzz_add_mime_part(tlv, fuzz->part); |
187 | | |
188 | 6.14M | break; |
189 | | |
190 | 1.40k | case TLV_TYPE_POSTFIELDS: |
191 | 1.40k | FCHECK_OPTION_UNSET(fuzz, CURLOPT_POSTFIELDS); |
192 | 1.38k | fuzz->postfields = fuzz_tlv_to_string(tlv); |
193 | 1.38k | FSET_OPTION(fuzz, CURLOPT_POSTFIELDS, fuzz->postfields); |
194 | 1.38k | break; |
195 | | |
196 | 1.15k | case TLV_TYPE_HTTPPOSTBODY: |
197 | 1.15k | FCHECK_OPTION_UNSET(fuzz, CURLOPT_HTTPPOST); |
198 | 1.14k | fuzz_setup_http_post(fuzz, tlv); |
199 | 1.14k | FSET_OPTION(fuzz, CURLOPT_HTTPPOST, fuzz->httppost); |
200 | 1.14k | break; |
201 | | |
202 | | /* Define a set of u32 options. */ |
203 | 21.6k | FU32TLV(fuzz, TLV_TYPE_HTTPAUTH, CURLOPT_HTTPAUTH); |
204 | 1.15k | FU32TLV(fuzz, TLV_TYPE_OPTHEADER, CURLOPT_HEADER); |
205 | 2.26k | FU32TLV(fuzz, TLV_TYPE_NOBODY, CURLOPT_NOBODY); |
206 | 7.68k | FU32TLV(fuzz, TLV_TYPE_FOLLOWLOCATION, CURLOPT_FOLLOWLOCATION); |
207 | 2.26k | FU32TLV(fuzz, TLV_TYPE_WILDCARDMATCH, CURLOPT_WILDCARDMATCH); |
208 | 9.07k | FU32TLV(fuzz, TLV_TYPE_RTSP_REQUEST, CURLOPT_RTSP_REQUEST); |
209 | 588 | FU32TLV(fuzz, TLV_TYPE_RTSP_CLIENT_CSEQ, CURLOPT_RTSP_CLIENT_CSEQ); |
210 | 54.4k | FU32TLV(fuzz, TLV_TYPE_HTTP_VERSION, CURLOPT_HTTP_VERSION); |
211 | 2.81k | FU32TLV(fuzz, TLV_TYPE_NETRC, CURLOPT_NETRC); |
212 | 414 | FU32TLV(fuzz, TLV_TYPE_WS_OPTIONS, CURLOPT_WS_OPTIONS); |
213 | 2.21k | FU32TLV(fuzz, TLV_TYPE_CONNECT_ONLY, CURLOPT_CONNECT_ONLY); |
214 | 1.57k | FU32TLV(fuzz, TLV_TYPE_POST, CURLOPT_POST); |
215 | 43.5k | FU32TLV(fuzz, TLV_TYPE_PROXYTYPE, CURLOPT_PROXYTYPE); |
216 | 3.07k | FU32TLV(fuzz, TLV_TYPE_PORT, CURLOPT_PORT); |
217 | 3.66k | FU32TLV(fuzz, TLV_TYPE_LOW_SPEED_LIMIT, CURLOPT_LOW_SPEED_LIMIT); |
218 | 2.59k | FU32TLV(fuzz, TLV_TYPE_LOW_SPEED_TIME, CURLOPT_LOW_SPEED_TIME); |
219 | 3.96k | FU32TLV(fuzz, TLV_TYPE_RESUME_FROM, CURLOPT_RESUME_FROM); |
220 | 474 | FU32TLV(fuzz, TLV_TYPE_TIMEVALUE, CURLOPT_TIMEVALUE); |
221 | 14.1k | FU32TLV(fuzz, TLV_TYPE_NOPROGRESS, CURLOPT_NOPROGRESS); |
222 | 1.00k | FU32TLV(fuzz, TLV_TYPE_FAILONERROR, CURLOPT_FAILONERROR); |
223 | 263 | FU32TLV(fuzz, TLV_TYPE_DIRLISTONLY, CURLOPT_DIRLISTONLY); |
224 | 271 | FU32TLV(fuzz, TLV_TYPE_APPEND, CURLOPT_APPEND); |
225 | 4.12k | FU32TLV(fuzz, TLV_TYPE_TRANSFERTEXT, CURLOPT_TRANSFERTEXT); |
226 | 707 | FU32TLV(fuzz, TLV_TYPE_AUTOREFERER, CURLOPT_AUTOREFERER); |
227 | 1.71k | FU32TLV(fuzz, TLV_TYPE_PROXYPORT, CURLOPT_PROXYPORT); |
228 | | // too easy for API misuse FU32TLV(fuzz, TLV_TYPE_POSTFIELDSIZE, CURLOPT_POSTFIELDSIZE); |
229 | 256 | FU32TLV(fuzz, TLV_TYPE_HTTPPROXYTUNNEL, CURLOPT_HTTPPROXYTUNNEL); |
230 | 438 | FU32TLV(fuzz, TLV_TYPE_SSL_VERIFYPEER, CURLOPT_SSL_VERIFYPEER); |
231 | 1.94k | FU32TLV(fuzz, TLV_TYPE_MAXREDIRS, CURLOPT_MAXREDIRS); |
232 | 676 | FU32TLV(fuzz, TLV_TYPE_FILETIME, CURLOPT_FILETIME); |
233 | 2.07k | FU32TLV(fuzz, TLV_TYPE_MAXCONNECTS, CURLOPT_MAXCONNECTS); |
234 | 394 | FU32TLV(fuzz, TLV_TYPE_FRESH_CONNECT, CURLOPT_FRESH_CONNECT); |
235 | 283 | FU32TLV(fuzz, TLV_TYPE_FORBID_REUSE, CURLOPT_FORBID_REUSE); |
236 | 5.86k | FU32TLV(fuzz, TLV_TYPE_CONNECTTIMEOUT, CURLOPT_CONNECTTIMEOUT); |
237 | 318 | FU32TLV(fuzz, TLV_TYPE_HTTPGET, CURLOPT_HTTPGET); |
238 | 356 | FU32TLV(fuzz, TLV_TYPE_SSL_VERIFYHOST, CURLOPT_SSL_VERIFYHOST); |
239 | 258 | FU32TLV(fuzz, TLV_TYPE_FTP_USE_EPSV, CURLOPT_FTP_USE_EPSV); |
240 | 282 | FU32TLV(fuzz, TLV_TYPE_SSLENGINE_DEFAULT, CURLOPT_SSLENGINE_DEFAULT); |
241 | 2.31k | FU32TLV(fuzz, TLV_TYPE_DNS_CACHE_TIMEOUT, CURLOPT_DNS_CACHE_TIMEOUT); |
242 | 226 | FU32TLV(fuzz, TLV_TYPE_COOKIESESSION, CURLOPT_COOKIESESSION); |
243 | 6.03k | FU32TLV(fuzz, TLV_TYPE_BUFFERSIZE, CURLOPT_BUFFERSIZE); |
244 | 721 | FU32TLV(fuzz, TLV_TYPE_NOSIGNAL, CURLOPT_NOSIGNAL); |
245 | 493 | FU32TLV(fuzz, TLV_TYPE_UNRESTRICTED_AUTH, CURLOPT_UNRESTRICTED_AUTH); |
246 | 157 | FU32TLV(fuzz, TLV_TYPE_FTP_USE_EPRT, CURLOPT_FTP_USE_EPRT); |
247 | 1.81k | FU32TLV(fuzz, TLV_TYPE_FTP_CREATE_MISSING_DIRS, CURLOPT_FTP_CREATE_MISSING_DIRS); |
248 | 2.33k | FU32TLV(fuzz, TLV_TYPE_MAXFILESIZE, CURLOPT_MAXFILESIZE); |
249 | 401 | FU32TLV(fuzz, TLV_TYPE_TCP_NODELAY, CURLOPT_TCP_NODELAY); |
250 | 356 | FU32TLV(fuzz, TLV_TYPE_IGNORE_CONTENT_LENGTH, CURLOPT_IGNORE_CONTENT_LENGTH); |
251 | 288 | FU32TLV(fuzz, TLV_TYPE_FTP_SKIP_PASV_IP, CURLOPT_FTP_SKIP_PASV_IP); |
252 | 3.72k | FU32TLV(fuzz, TLV_TYPE_LOCALPORT, CURLOPT_LOCALPORT); |
253 | 2.48k | FU32TLV(fuzz, TLV_TYPE_LOCALPORTRANGE, CURLOPT_LOCALPORTRANGE); |
254 | 250 | FU32TLV(fuzz, TLV_TYPE_SSL_SESSIONID_CACHE, CURLOPT_SSL_SESSIONID_CACHE); |
255 | 1.78k | FU32TLV(fuzz, TLV_TYPE_FTP_SSL_CCC, CURLOPT_FTP_SSL_CCC); |
256 | 7.64k | FU32TLV(fuzz, TLV_TYPE_CONNECTTIMEOUT_MS, CURLOPT_CONNECTTIMEOUT_MS); |
257 | 748 | FU32TLV(fuzz, TLV_TYPE_HTTP_TRANSFER_DECODING, CURLOPT_HTTP_TRANSFER_DECODING); |
258 | 390 | FU32TLV(fuzz, TLV_TYPE_HTTP_CONTENT_DECODING, CURLOPT_HTTP_CONTENT_DECODING); |
259 | 2.13k | FU32TLV(fuzz, TLV_TYPE_NEW_FILE_PERMS, CURLOPT_NEW_FILE_PERMS); |
260 | 160 | FU32TLV(fuzz, TLV_TYPE_NEW_DIRECTORY_PERMS, CURLOPT_NEW_DIRECTORY_PERMS); |
261 | 1.45k | FU32TLV(fuzz, TLV_TYPE_PROXY_TRANSFER_MODE, CURLOPT_PROXY_TRANSFER_MODE); |
262 | 4.91k | FU32TLV(fuzz, TLV_TYPE_ADDRESS_SCOPE, CURLOPT_ADDRESS_SCOPE); |
263 | 262 | FU32TLV(fuzz, TLV_TYPE_CERTINFO, CURLOPT_CERTINFO); |
264 | 2.34k | FU32TLV(fuzz, TLV_TYPE_TFTP_BLKSIZE, CURLOPT_TFTP_BLKSIZE); |
265 | 76 | FU32TLV(fuzz, TLV_TYPE_SOCKS5_GSSAPI_NEC, CURLOPT_SOCKS5_GSSAPI_NEC); |
266 | 227 | FU32TLV(fuzz, TLV_TYPE_FTP_USE_PRET, CURLOPT_FTP_USE_PRET); |
267 | 271 | FU32TLV(fuzz, TLV_TYPE_RTSP_SERVER_CSEQ, CURLOPT_RTSP_SERVER_CSEQ); |
268 | 957 | FU32TLV(fuzz, TLV_TYPE_TRANSFER_ENCODING, CURLOPT_TRANSFER_ENCODING); |
269 | 1.55k | FU32TLV(fuzz, TLV_TYPE_ACCEPTTIMEOUT_MS, CURLOPT_ACCEPTTIMEOUT_MS); |
270 | 1.50k | FU32TLV(fuzz, TLV_TYPE_TCP_KEEPALIVE, CURLOPT_TCP_KEEPALIVE); |
271 | 3.07k | FU32TLV(fuzz, TLV_TYPE_TCP_KEEPIDLE, CURLOPT_TCP_KEEPIDLE); |
272 | 3.23k | FU32TLV(fuzz, TLV_TYPE_TCP_KEEPINTVL, CURLOPT_TCP_KEEPINTVL); |
273 | 694 | FU32TLV(fuzz, TLV_TYPE_SASL_IR, CURLOPT_SASL_IR); |
274 | 419 | FU32TLV(fuzz, TLV_TYPE_SSL_ENABLE_ALPN, CURLOPT_SSL_ENABLE_ALPN); |
275 | 1.50k | FU32TLV(fuzz, TLV_TYPE_EXPECT_100_TIMEOUT_MS, CURLOPT_EXPECT_100_TIMEOUT_MS); |
276 | 442 | FU32TLV(fuzz, TLV_TYPE_SSL_VERIFYSTATUS, CURLOPT_SSL_VERIFYSTATUS); |
277 | 83 | FU32TLV(fuzz, TLV_TYPE_SSL_FALSESTART, CURLOPT_SSL_FALSESTART); |
278 | 449 | FU32TLV(fuzz, TLV_TYPE_PATH_AS_IS, CURLOPT_PATH_AS_IS); |
279 | 267 | FU32TLV(fuzz, TLV_TYPE_PIPEWAIT, CURLOPT_PIPEWAIT); |
280 | 2.46k | FU32TLV(fuzz, TLV_TYPE_STREAM_WEIGHT, CURLOPT_STREAM_WEIGHT); |
281 | 496 | FU32TLV(fuzz, TLV_TYPE_TFTP_NO_OPTIONS, CURLOPT_TFTP_NO_OPTIONS); |
282 | 209 | FU32TLV(fuzz, TLV_TYPE_TCP_FASTOPEN, CURLOPT_TCP_FASTOPEN); |
283 | 223 | FU32TLV(fuzz, TLV_TYPE_KEEP_SENDING_ON_ERROR, CURLOPT_KEEP_SENDING_ON_ERROR); |
284 | 1.41k | FU32TLV(fuzz, TLV_TYPE_PROXY_SSL_VERIFYPEER, CURLOPT_PROXY_SSL_VERIFYPEER); |
285 | 408 | FU32TLV(fuzz, TLV_TYPE_PROXY_SSL_VERIFYHOST, CURLOPT_PROXY_SSL_VERIFYHOST); |
286 | 246 | FU32TLV(fuzz, TLV_TYPE_PROXY_SSL_OPTIONS, CURLOPT_PROXY_SSL_OPTIONS); |
287 | 842 | FU32TLV(fuzz, TLV_TYPE_SUPPRESS_CONNECT_HEADERS, CURLOPT_SUPPRESS_CONNECT_HEADERS); |
288 | 1.16k | FU32TLV(fuzz, TLV_TYPE_SOCKS5_AUTH, CURLOPT_SOCKS5_AUTH); |
289 | 190 | FU32TLV(fuzz, TLV_TYPE_SSH_COMPRESSION, CURLOPT_SSH_COMPRESSION); |
290 | 1.80k | FU32TLV(fuzz, TLV_TYPE_HAPPY_EYEBALLS_TIMEOUT_MS, CURLOPT_HAPPY_EYEBALLS_TIMEOUT_MS); |
291 | 602 | FU32TLV(fuzz, TLV_TYPE_HAPROXYPROTOCOL, CURLOPT_HAPROXYPROTOCOL); |
292 | 670 | FU32TLV(fuzz, TLV_TYPE_DNS_SHUFFLE_ADDRESSES, CURLOPT_DNS_SHUFFLE_ADDRESSES); |
293 | 331 | FU32TLV(fuzz, TLV_TYPE_DISALLOW_USERNAME_IN_URL, CURLOPT_DISALLOW_USERNAME_IN_URL); |
294 | 7.12k | FU32TLV(fuzz, TLV_TYPE_UPLOAD_BUFFERSIZE, CURLOPT_UPLOAD_BUFFERSIZE); |
295 | 1.46k | FU32TLV(fuzz, TLV_TYPE_UPKEEP_INTERVAL_MS, CURLOPT_UPKEEP_INTERVAL_MS); |
296 | 326 | FU32TLV(fuzz, TLV_TYPE_HTTP09_ALLOWED, CURLOPT_HTTP09_ALLOWED); |
297 | 339 | FU32TLV(fuzz, TLV_TYPE_ALTSVC_CTRL, CURLOPT_ALTSVC_CTRL); |
298 | 2.16k | FU32TLV(fuzz, TLV_TYPE_MAXAGE_CONN, CURLOPT_MAXAGE_CONN); |
299 | 174 | FU32TLV(fuzz, TLV_TYPE_MAIL_RCPT_ALLOWFAILS, CURLOPT_MAIL_RCPT_ALLOWFAILS); |
300 | 399 | FU32TLV(fuzz, TLV_TYPE_HSTS_CTRL, CURLOPT_HSTS_CTRL); |
301 | 172 | FU32TLV(fuzz, TLV_TYPE_DOH_SSL_VERIFYPEER, CURLOPT_DOH_SSL_VERIFYPEER); |
302 | 179 | FU32TLV(fuzz, TLV_TYPE_DOH_SSL_VERIFYHOST, CURLOPT_DOH_SSL_VERIFYHOST); |
303 | 289 | FU32TLV(fuzz, TLV_TYPE_DOH_SSL_VERIFYSTATUS, CURLOPT_DOH_SSL_VERIFYSTATUS); |
304 | 2.47k | FU32TLV(fuzz, TLV_TYPE_MAXLIFETIME_CONN, CURLOPT_MAXLIFETIME_CONN); |
305 | 305 | FU32TLV(fuzz, TLV_TYPE_MIME_OPTIONS, CURLOPT_MIME_OPTIONS); |
306 | 3.22k | FU32TLV(fuzz, TLV_TYPE_CA_CACHE_TIMEOUT, CURLOPT_CA_CACHE_TIMEOUT); |
307 | 178 | FU32TLV(fuzz, TLV_TYPE_QUICK_EXIT, CURLOPT_QUICK_EXIT); |
308 | 1.56k | FU32TLV(fuzz, TLV_TYPE_SERVER_RESPONSE_TIMEOUT_MS, CURLOPT_SERVER_RESPONSE_TIMEOUT_MS); |
309 | 2.54k | FU32TLV(fuzz, TLV_TYPE_TCP_KEEPCNT, CURLOPT_TCP_KEEPCNT); |
310 | 2.65k | FU32TLV(fuzz, TLV_TYPE_SSLVERSION, CURLOPT_SSLVERSION); |
311 | 4.24k | FU32TLV(fuzz, TLV_TYPE_TIMECONDITION, CURLOPT_TIMECONDITION); |
312 | 4.20k | FU32TLV(fuzz, TLV_TYPE_PROXYAUTH, CURLOPT_PROXYAUTH); |
313 | 2.09k | FU32TLV(fuzz, TLV_TYPE_IPRESOLVE, CURLOPT_IPRESOLVE); |
314 | 1.86k | FU32TLV(fuzz, TLV_TYPE_USE_SSL, CURLOPT_USE_SSL); |
315 | 1.81k | FU32TLV(fuzz, TLV_TYPE_FTPSSLAUTH, CURLOPT_FTPSSLAUTH); |
316 | 1.80k | FU32TLV(fuzz, TLV_TYPE_FTP_FILEMETHOD, CURLOPT_FTP_FILEMETHOD); |
317 | 151 | FU32TLV(fuzz, TLV_TYPE_SSH_AUTH_TYPES, CURLOPT_SSH_AUTH_TYPES); |
318 | 1.60k | FU32TLV(fuzz, TLV_TYPE_POSTREDIR, CURLOPT_POSTREDIR); |
319 | 85 | FU32TLV(fuzz, TLV_TYPE_GSSAPI_DELEGATION, CURLOPT_GSSAPI_DELEGATION); |
320 | 369 | FU32TLV(fuzz, TLV_TYPE_SSL_OPTIONS, CURLOPT_SSL_OPTIONS); |
321 | 5.75k | FU32TLV(fuzz, TLV_TYPE_HEADEROPT, CURLOPT_HEADEROPT); |
322 | 1.61k | FU32TLV(fuzz, TLV_TYPE_PROXY_SSLVERSION, CURLOPT_PROXY_SSLVERSION); |
323 | 4.73k | FU32TLV(fuzz, TLV_TYPE_RESUME_FROM_LARGE, CURLOPT_RESUME_FROM_LARGE); |
324 | 2.92k | FU32TLV(fuzz, TLV_TYPE_MAXFILESIZE_LARGE, CURLOPT_MAXFILESIZE_LARGE); |
325 | | // too easy for API misuse FU32TLV(fuzz, TLV_TYPE_POSTFIELDSIZE_LARGE, CURLOPT_POSTFIELDSIZE_LARGE); |
326 | 5.68k | FU32TLV(fuzz, TLV_TYPE_MAX_SEND_SPEED_LARGE, CURLOPT_MAX_SEND_SPEED_LARGE); |
327 | 10.6k | FU32TLV(fuzz, TLV_TYPE_MAX_RECV_SPEED_LARGE, CURLOPT_MAX_RECV_SPEED_LARGE); |
328 | 896 | FU32TLV(fuzz, TLV_TYPE_TIMEVALUE_LARGE, CURLOPT_TIMEVALUE_LARGE); |
329 | | |
330 | | /* Define a set of singleton TLVs - they can only have their value set once |
331 | | and all follow the same pattern. */ |
332 | 250k | FSINGLETONTLV(fuzz, TLV_TYPE_URL, CURLOPT_URL); |
333 | 9.56k | FSINGLETONTLV(fuzz, TLV_TYPE_DOH_URL, CURLOPT_DOH_URL); |
334 | 3.35k | FSINGLETONTLV(fuzz, TLV_TYPE_USERNAME, CURLOPT_USERNAME); |
335 | 3.17k | FSINGLETONTLV(fuzz, TLV_TYPE_PASSWORD, CURLOPT_PASSWORD); |
336 | 1.63k | FSINGLETONTLV(fuzz, TLV_TYPE_COOKIE, CURLOPT_COOKIE); |
337 | 4.47k | FSINGLETONTLV(fuzz, TLV_TYPE_RANGE, CURLOPT_RANGE); |
338 | 2.19k | FSINGLETONTLV(fuzz, TLV_TYPE_CUSTOMREQUEST, CURLOPT_CUSTOMREQUEST); |
339 | 863 | FSINGLETONTLV(fuzz, TLV_TYPE_MAIL_FROM, CURLOPT_MAIL_FROM); |
340 | 5.20k | FSINGLETONTLV(fuzz, TLV_TYPE_ACCEPTENCODING, CURLOPT_ACCEPT_ENCODING); |
341 | 739 | FSINGLETONTLV(fuzz, TLV_TYPE_RTSP_SESSION_ID, CURLOPT_RTSP_SESSION_ID); |
342 | 323 | FSINGLETONTLV(fuzz, TLV_TYPE_RTSP_STREAM_URI, CURLOPT_RTSP_STREAM_URI); |
343 | 385 | FSINGLETONTLV(fuzz, TLV_TYPE_RTSP_TRANSPORT, CURLOPT_RTSP_TRANSPORT); |
344 | 227 | FSINGLETONTLV(fuzz, TLV_TYPE_MAIL_AUTH, CURLOPT_MAIL_AUTH); |
345 | 1.01k | FSINGLETONTLV(fuzz, TLV_TYPE_LOGIN_OPTIONS, CURLOPT_LOGIN_OPTIONS); |
346 | 2.66k | FSINGLETONTLV(fuzz, TLV_TYPE_XOAUTH2_BEARER, CURLOPT_XOAUTH2_BEARER); |
347 | 3.38k | FSINGLETONTLV(fuzz, TLV_TYPE_USERPWD, CURLOPT_USERPWD); |
348 | 2.61k | FSINGLETONTLV(fuzz, TLV_TYPE_USERAGENT, CURLOPT_USERAGENT); |
349 | 120 | FSINGLETONTLV(fuzz, TLV_TYPE_SSH_HOST_PUBLIC_KEY_SHA256, CURLOPT_SSH_HOST_PUBLIC_KEY_SHA256); |
350 | 37.0k | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY, CURLOPT_PROXY); |
351 | 5.22k | FSINGLETONTLV(fuzz, TLV_TYPE_PROXYUSERPWD, CURLOPT_PROXYUSERPWD); |
352 | 479 | FSINGLETONTLV(fuzz, TLV_TYPE_REFERER, CURLOPT_REFERER); |
353 | 731 | FSINGLETONTLV(fuzz, TLV_TYPE_FTPPORT, CURLOPT_FTPPORT); |
354 | 481 | FSINGLETONTLV(fuzz, TLV_TYPE_SSLCERT, CURLOPT_SSLCERT); |
355 | 171 | FSINGLETONTLV(fuzz, TLV_TYPE_KEYPASSWD, CURLOPT_KEYPASSWD); |
356 | 6.84k | FSINGLETONTLV(fuzz, TLV_TYPE_INTERFACE, CURLOPT_INTERFACE); |
357 | 42 | FSINGLETONTLV(fuzz, TLV_TYPE_KRBLEVEL, CURLOPT_KRBLEVEL); |
358 | 2.05k | FSINGLETONTLV(fuzz, TLV_TYPE_CAINFO, CURLOPT_CAINFO); |
359 | 17.2k | FSINGLETONTLV(fuzz, TLV_TYPE_SSL_CIPHER_LIST, CURLOPT_SSL_CIPHER_LIST); |
360 | 291 | FSINGLETONTLV(fuzz, TLV_TYPE_SSLCERTTYPE, CURLOPT_SSLCERTTYPE); |
361 | 91 | FSINGLETONTLV(fuzz, TLV_TYPE_SSLKEY, CURLOPT_SSLKEY); |
362 | 105 | FSINGLETONTLV(fuzz, TLV_TYPE_SSLKEYTYPE, CURLOPT_SSLKEYTYPE); |
363 | 19.9k | FSINGLETONTLV(fuzz, TLV_TYPE_SSLENGINE, CURLOPT_SSLENGINE); |
364 | 1.27k | FSINGLETONTLV(fuzz, TLV_TYPE_CAPATH, CURLOPT_CAPATH); |
365 | 119 | FSINGLETONTLV(fuzz, TLV_TYPE_FTP_ACCOUNT, CURLOPT_FTP_ACCOUNT); |
366 | 27.1k | FSINGLETONTLV(fuzz, TLV_TYPE_COOKIELIST, CURLOPT_COOKIELIST); |
367 | 131 | FSINGLETONTLV(fuzz, TLV_TYPE_FTP_ALTERNATIVE_TO_USER, CURLOPT_FTP_ALTERNATIVE_TO_USER); |
368 | 36 | FSINGLETONTLV(fuzz, TLV_TYPE_SSH_PUBLIC_KEYFILE, CURLOPT_SSH_PUBLIC_KEYFILE); |
369 | 32 | FSINGLETONTLV(fuzz, TLV_TYPE_SSH_PRIVATE_KEYFILE, CURLOPT_SSH_PRIVATE_KEYFILE); |
370 | 30 | FSINGLETONTLV(fuzz, TLV_TYPE_SSH_HOST_PUBLIC_KEY_MD5, CURLOPT_SSH_HOST_PUBLIC_KEY_MD5); |
371 | 223 | FSINGLETONTLV(fuzz, TLV_TYPE_ISSUERCERT, CURLOPT_ISSUERCERT); |
372 | 311 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXYUSERNAME, CURLOPT_PROXYUSERNAME); |
373 | 191 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXYPASSWORD, CURLOPT_PROXYPASSWORD); |
374 | 5.44k | FSINGLETONTLV(fuzz, TLV_TYPE_NOPROXY, CURLOPT_NOPROXY); |
375 | 32 | FSINGLETONTLV(fuzz, TLV_TYPE_SSH_KNOWNHOSTS, CURLOPT_SSH_KNOWNHOSTS); |
376 | 459 | FSINGLETONTLV(fuzz, TLV_TYPE_TLSAUTH_USERNAME, CURLOPT_TLSAUTH_USERNAME); |
377 | 589 | FSINGLETONTLV(fuzz, TLV_TYPE_TLSAUTH_PASSWORD, CURLOPT_TLSAUTH_PASSWORD); |
378 | 106 | FSINGLETONTLV(fuzz, TLV_TYPE_TLSAUTH_TYPE, CURLOPT_TLSAUTH_TYPE); |
379 | 50 | FSINGLETONTLV(fuzz, TLV_TYPE_DNS_SERVERS, CURLOPT_DNS_SERVERS); |
380 | 34 | FSINGLETONTLV(fuzz, TLV_TYPE_DNS_INTERFACE, CURLOPT_DNS_INTERFACE); |
381 | 40 | FSINGLETONTLV(fuzz, TLV_TYPE_DNS_LOCAL_IP4, CURLOPT_DNS_LOCAL_IP4); |
382 | 36 | FSINGLETONTLV(fuzz, TLV_TYPE_DNS_LOCAL_IP6, CURLOPT_DNS_LOCAL_IP6); |
383 | 455 | FSINGLETONTLV(fuzz, TLV_TYPE_PINNEDPUBLICKEY, CURLOPT_PINNEDPUBLICKEY); |
384 | 1.73k | FSINGLETONTLV(fuzz, TLV_TYPE_UNIX_SOCKET_PATH, CURLOPT_UNIX_SOCKET_PATH); |
385 | 329 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_SERVICE_NAME, CURLOPT_PROXY_SERVICE_NAME); |
386 | 283 | FSINGLETONTLV(fuzz, TLV_TYPE_SERVICE_NAME, CURLOPT_SERVICE_NAME); |
387 | 2.39k | FSINGLETONTLV(fuzz, TLV_TYPE_DEFAULT_PROTOCOL, CURLOPT_DEFAULT_PROTOCOL); |
388 | 435 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_CAINFO, CURLOPT_PROXY_CAINFO); |
389 | 765 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_CAPATH, CURLOPT_PROXY_CAPATH); |
390 | 289 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_TLSAUTH_USERNAME, CURLOPT_PROXY_TLSAUTH_USERNAME); |
391 | 223 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_TLSAUTH_PASSWORD, CURLOPT_PROXY_TLSAUTH_PASSWORD); |
392 | 104 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_TLSAUTH_TYPE, CURLOPT_PROXY_TLSAUTH_TYPE); |
393 | 279 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_SSLCERT, CURLOPT_PROXY_SSLCERT); |
394 | 113 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_SSLCERTTYPE, CURLOPT_PROXY_SSLCERTTYPE); |
395 | 141 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_SSLKEY, CURLOPT_PROXY_SSLKEY); |
396 | 107 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_SSLKEYTYPE, CURLOPT_PROXY_SSLKEYTYPE); |
397 | 339 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_KEYPASSWD, CURLOPT_PROXY_KEYPASSWD); |
398 | 8.11k | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_SSL_CIPHER_LIST, CURLOPT_PROXY_SSL_CIPHER_LIST); |
399 | 381 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_CRLFILE, CURLOPT_PROXY_CRLFILE); |
400 | 45.4k | FSINGLETONTLV(fuzz, TLV_TYPE_PRE_PROXY, CURLOPT_PRE_PROXY); |
401 | 319 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_PINNEDPUBLICKEY, CURLOPT_PROXY_PINNEDPUBLICKEY); |
402 | 1.04k | FSINGLETONTLV(fuzz, TLV_TYPE_ABSTRACT_UNIX_SOCKET, CURLOPT_ABSTRACT_UNIX_SOCKET); |
403 | 571 | FSINGLETONTLV(fuzz, TLV_TYPE_REQUEST_TARGET, CURLOPT_REQUEST_TARGET); |
404 | 3.65k | FSINGLETONTLV(fuzz, TLV_TYPE_TLS13_CIPHERS, CURLOPT_TLS13_CIPHERS); |
405 | 1.69k | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_TLS13_CIPHERS, CURLOPT_PROXY_TLS13_CIPHERS); |
406 | 237 | FSINGLETONTLV(fuzz, TLV_TYPE_SASL_AUTHZID, CURLOPT_SASL_AUTHZID); |
407 | 231 | FSINGLETONTLV(fuzz, TLV_TYPE_PROXY_ISSUERCERT, CURLOPT_PROXY_ISSUERCERT); |
408 | 6.46k | FSINGLETONTLV(fuzz, TLV_TYPE_SSL_EC_CURVES, CURLOPT_SSL_EC_CURVES); |
409 | 13.2k | FSINGLETONTLV(fuzz, TLV_TYPE_AWS_SIGV4, CURLOPT_AWS_SIGV4); |
410 | 2.86k | FSINGLETONTLV(fuzz, TLV_TYPE_REDIR_PROTOCOLS_STR, CURLOPT_REDIR_PROTOCOLS_STR); |
411 | 977 | FSINGLETONTLV(fuzz, TLV_TYPE_HAPROXY_CLIENT_IP, CURLOPT_HAPROXY_CLIENT_IP); |
412 | 36 | FSINGLETONTLV(fuzz, TLV_TYPE_ECH, CURLOPT_ECH); |
413 | 506 | default: |
414 | | /* The fuzzer generates lots of unknown TLVs - we don't want these in the |
415 | | corpus so we reject any unknown TLVs. */ |
416 | 506 | rc = 127; |
417 | 506 | goto EXIT_LABEL; |
418 | 0 | break; |
419 | 7.08M | } |
420 | | |
421 | 7.06M | rc = 0; |
422 | | |
423 | 7.08M | EXIT_LABEL: |
424 | | |
425 | 7.08M | fuzz_free((void **)&tmp); |
426 | | |
427 | 7.08M | return rc; |
428 | 7.06M | } |
429 | | |
430 | | /** |
431 | | * Converts a TLV data and length into an allocated string. |
432 | | */ |
433 | | char *fuzz_tlv_to_string(TLV *tlv) |
434 | 1.85M | { |
435 | 1.85M | char *tlvstr; |
436 | | |
437 | | /* Allocate enough space, plus a null terminator */ |
438 | 1.85M | tlvstr = (char *)malloc(tlv->length + 1); |
439 | | |
440 | 1.85M | if(tlvstr != NULL) { |
441 | 1.85M | memcpy(tlvstr, tlv->value, tlv->length); |
442 | 1.85M | tlvstr[tlv->length] = 0; |
443 | 1.85M | } |
444 | | |
445 | 1.85M | return tlvstr; |
446 | 1.85M | } |
447 | | |
448 | | /* set up for CURLOPT_HTTPPOST, an alternative API to CURLOPT_MIMEPOST */ |
449 | | void fuzz_setup_http_post(FUZZ_DATA *fuzz, TLV *tlv) |
450 | 1.14k | { |
451 | 1.14k | if (fuzz->httppost == NULL) { |
452 | 1.14k | struct curl_httppost *post = NULL; |
453 | 1.14k | struct curl_httppost *last = NULL; |
454 | | |
455 | 1.14k | fuzz->post_body = fuzz_tlv_to_string(tlv); |
456 | 1.14k | if (fuzz->post_body == NULL) { |
457 | 0 | return; |
458 | 0 | } |
459 | | |
460 | | /* This is just one of several possible entrypoints to |
461 | | * the HTTPPOST API. see https://curl.se/libcurl/c/curl_formadd.html |
462 | | * for lots of others which could be added here. |
463 | | */ |
464 | 1.14k | curl_formadd(&post, &last, |
465 | 1.14k | CURLFORM_COPYNAME, FUZZ_HTTPPOST_NAME, |
466 | 1.14k | CURLFORM_PTRCONTENTS, fuzz->post_body, |
467 | 1.14k | CURLFORM_CONTENTLEN, (curl_off_t) strlen(fuzz->post_body), |
468 | 1.14k | CURLFORM_END); |
469 | | |
470 | 1.14k | fuzz->last_post_part = last; |
471 | 1.14k | fuzz->httppost = post; |
472 | 1.14k | } |
473 | | |
474 | 1.14k | return; |
475 | 1.14k | } |
476 | | |
477 | | /** |
478 | | * Extract the values from the TLV. |
479 | | */ |
480 | | int fuzz_add_mime_part(TLV *src_tlv, curl_mimepart *part) |
481 | 6.14M | { |
482 | 6.14M | FUZZ_DATA part_fuzz; |
483 | 6.14M | TLV tlv; |
484 | 6.14M | int rc = 0; |
485 | 6.14M | int tlv_rc; |
486 | | |
487 | 6.14M | memset(&part_fuzz, 0, sizeof(FUZZ_DATA)); |
488 | | |
489 | 6.14M | if(src_tlv->length < sizeof(TLV_RAW)) { |
490 | | /* Not enough data for a single TLV - don't continue */ |
491 | 4.57M | goto EXIT_LABEL; |
492 | 4.57M | } |
493 | | |
494 | | /* Set up the state parser */ |
495 | 1.57M | part_fuzz.state.data = src_tlv->value; |
496 | 1.57M | part_fuzz.state.data_len = src_tlv->length; |
497 | | |
498 | 1.57M | for(tlv_rc = fuzz_get_first_tlv(&part_fuzz, &tlv); |
499 | 2.86M | tlv_rc == 0; |
500 | 1.57M | tlv_rc = fuzz_get_next_tlv(&part_fuzz, &tlv)) { |
501 | | |
502 | | /* Have the TLV in hand. Parse the TLV. */ |
503 | 1.39M | rc = fuzz_parse_mime_tlv(part, &tlv); |
504 | | |
505 | 1.39M | if(rc != 0) { |
506 | | /* Failed to parse the TLV. Can't continue. */ |
507 | 106k | goto EXIT_LABEL; |
508 | 106k | } |
509 | 1.39M | } |
510 | | |
511 | 1.46M | if(tlv_rc != TLV_RC_NO_MORE_TLVS) { |
512 | | /* A TLV call failed. Can't continue. */ |
513 | 194k | goto EXIT_LABEL; |
514 | 194k | } |
515 | | |
516 | 6.14M | EXIT_LABEL: |
517 | | |
518 | 6.14M | return(rc); |
519 | 1.46M | } |
520 | | |
521 | | /** |
522 | | * Do different actions on the mime part for different received TLVs. |
523 | | */ |
524 | | int fuzz_parse_mime_tlv(curl_mimepart *part, TLV *tlv) |
525 | 1.39M | { |
526 | 1.39M | int rc; |
527 | 1.39M | char *tmp; |
528 | | |
529 | 1.39M | switch(tlv->type) { |
530 | 1.27M | case TLV_TYPE_MIME_PART_NAME: |
531 | 1.27M | tmp = fuzz_tlv_to_string(tlv); |
532 | 1.27M | curl_mime_name(part, tmp); |
533 | 1.27M | fuzz_free((void **)&tmp); |
534 | 1.27M | break; |
535 | | |
536 | 17.3k | case TLV_TYPE_MIME_PART_DATA: |
537 | 17.3k | curl_mime_data(part, (const char *)tlv->value, tlv->length); |
538 | 17.3k | break; |
539 | | |
540 | 106k | default: |
541 | | /* The fuzzer generates lots of unknown TLVs - we don't want these in the |
542 | | corpus so we reject any unknown TLVs. */ |
543 | 106k | rc = 255; |
544 | 106k | goto EXIT_LABEL; |
545 | 0 | break; |
546 | 1.39M | } |
547 | | |
548 | 1.29M | rc = 0; |
549 | | |
550 | 1.39M | EXIT_LABEL: |
551 | | |
552 | 1.39M | return rc; |
553 | 1.29M | } |