blob: 3a790221ee91db2ea46a403684b124c687e0d7e8 [file] [log] [blame]
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +00001/*
2 *
Robert Swieckie7294ca2017-11-11 02:46:32 +01003 * honggfuzz - run->dynamicFilefer mangling routines
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +00004 * -----------------------------------------
5 *
6 * Author:
7 * Robert Swiecki <swiecki@google.com>
8 *
Robert Swiecki46288f72018-02-27 17:28:47 +01009 * Copyright 2010-2018 by Google Inc. All Rights Reserved.
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +000010 *
11 * Licensed under the Apache License, Version 2.0 (the "License"); you may
12 * not use this file except in compliance with the License. You may obtain
13 * a copy of the License at
14 *
15 * http://www.apache.org/licenses/LICENSE-2.0
16 *
17 * Unless required by applicable law or agreed to in writing, software
18 * distributed under the License is distributed on an "AS IS" BASIS,
19 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
20 * implied. See the License for the specific language governing
21 * permissions and limitations under the License.
22 *
23 */
24
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +000025#include "mangle.h"
26
27#include <inttypes.h>
robert.swiecki@gmail.com173f5192015-02-23 00:06:47 +000028#include <math.h>
Robert Swiecki03de4082017-12-06 17:56:50 +010029#include <stdio.h>
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +000030#include <stdlib.h>
31#include <string.h>
robert.swiecki@gmail.come7680522015-02-22 22:22:37 +000032#include <sys/mman.h>
Robert Swiecki3ab16642018-01-12 18:08:37 +010033#include <sys/stat.h>
34#include <sys/types.h>
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +000035#include <unistd.h>
36
Robert Swiecki3ab16642018-01-12 18:08:37 +010037#include "input.h"
Robert Swiecki246af3e2018-01-05 14:56:32 +010038#include "libhfcommon/common.h"
39#include "libhfcommon/log.h"
40#include "libhfcommon/util.h"
Robert Swiecki78346012018-01-12 13:30:38 +010041
Robert Swieckid50ed422017-11-13 23:32:26 +010042static inline void mangle_Overwrite(run_t* run, const uint8_t* src, size_t off, size_t sz) {
Robert Swieckie7294ca2017-11-11 02:46:32 +010043 size_t maxToCopy = run->dynamicFileSz - off;
robert.swiecki@gmail.com1c555c72015-02-22 16:25:54 +000044 if (sz > maxToCopy) {
45 sz = maxToCopy;
46 }
47
Robert Swieckife3429c2017-11-14 00:45:00 +010048 memmove(&run->dynamicFile[off], src, sz);
robert.swiecki@gmail.com1c555c72015-02-22 16:25:54 +000049}
50
Robert Swieckid50ed422017-11-13 23:32:26 +010051static inline void mangle_Move(run_t* run, size_t off_from, size_t off_to, size_t len) {
Robert Swieckie7294ca2017-11-11 02:46:32 +010052 if (off_from >= run->dynamicFileSz) {
Robert Swiecki8e9ed422017-01-26 16:46:55 +010053 return;
54 }
Robert Swieckie7294ca2017-11-11 02:46:32 +010055 if (off_to >= run->dynamicFileSz) {
Robert Swiecki8e9ed422017-01-26 16:46:55 +010056 return;
57 }
58
Robert Swieckie7294ca2017-11-11 02:46:32 +010059 ssize_t len_from = (ssize_t)run->dynamicFileSz - off_from - 1;
60 ssize_t len_to = (ssize_t)run->dynamicFileSz - off_to - 1;
Robert Swiecki8e9ed422017-01-26 16:46:55 +010061
Robert Swiecki4e595fb2017-10-11 17:26:51 +020062 if ((ssize_t)len > len_from) {
Robert Swiecki8e9ed422017-01-26 16:46:55 +010063 len = len_from;
64 }
Robert Swiecki4e595fb2017-10-11 17:26:51 +020065 if ((ssize_t)len > len_to) {
Robert Swiecki8e9ed422017-01-26 16:46:55 +010066 len = len_to;
67 }
68
Robert Swieckie7294ca2017-11-11 02:46:32 +010069 memmove(&run->dynamicFile[off_to], &run->dynamicFile[off_from], len);
Robert Swiecki8e9ed422017-01-26 16:46:55 +010070}
71
Robert Swieckid50ed422017-11-13 23:32:26 +010072static void mangle_Inflate(run_t* run, size_t off, size_t len) {
Robert Swieckie9231d62018-03-02 03:35:11 +010073 if (run->dynamicFileSz >= run->global->mutate.maxFileSz) {
Robert Swiecki40d13412017-01-29 02:45:37 +010074 return;
75 }
Robert Swieckie9231d62018-03-02 03:35:11 +010076 if (len > (run->global->mutate.maxFileSz - run->dynamicFileSz)) {
77 len = run->global->mutate.maxFileSz - run->dynamicFileSz;
Robert Swiecki40d13412017-01-29 02:45:37 +010078 }
79
Robert Swiecki0f2c30a2018-01-13 14:03:39 +010080 input_setSize(run, run->dynamicFileSz + len);
Robert Swieckie7294ca2017-11-11 02:46:32 +010081 mangle_Move(run, off, off + len, run->dynamicFileSz);
Robert Swiecki40d13412017-01-29 02:45:37 +010082}
83
Robert Swieckid50ed422017-11-13 23:32:26 +010084static void mangle_MemMove(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +010085 size_t off_from = util_rndGet(0, run->dynamicFileSz - 1);
86 size_t off_to = util_rndGet(0, run->dynamicFileSz - 1);
87 size_t len = util_rndGet(0, run->dynamicFileSz);
Robert Swiecki8e9ed422017-01-26 16:46:55 +010088
Robert Swieckie7294ca2017-11-11 02:46:32 +010089 mangle_Move(run, off_from, off_to, len);
Robert Swiecki8e9ed422017-01-26 16:46:55 +010090}
91
Robert Swieckid50ed422017-11-13 23:32:26 +010092static void mangle_Byte(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +010093 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
94 run->dynamicFile[off] = (uint8_t)util_rnd64();
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +000095}
96
plusundc64d052018-07-31 13:55:50 +000097static void mangle_PrintableByte(run_t* run) {
98 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
99 run->dynamicFile[off] = util_rndPrintable();
100}
101
Robert Swieckid50ed422017-11-13 23:32:26 +0100102static void mangle_Bytes(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100103 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
Robert Swiecki4e595fb2017-10-11 17:26:51 +0200104 uint32_t val = (uint32_t)util_rnd64();
robert.swiecki@gmail.com457ca142015-02-22 14:59:34 +0000105
robert.swiecki@gmail.com12e75062015-02-22 15:01:21 +0000106 /* Overwrite with random 2,3,4-byte values */
107 size_t toCopy = util_rndGet(2, 4);
Robert Swieckie7294ca2017-11-11 02:46:32 +0100108 mangle_Overwrite(run, (uint8_t*)&val, off, toCopy);
robert.swiecki@gmail.com457ca142015-02-22 14:59:34 +0000109}
110
plusundc64d052018-07-31 13:55:50 +0000111static void mangle_PrintableBytes(run_t* run) {
112 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
plusun0262b322018-08-06 07:37:49 +0000113 uint32_t val;
114 util_rndBufPrintable((uint8_t *)&val, sizeof(val));
plusundc64d052018-07-31 13:55:50 +0000115
116 /* Overwrite with random 2,3,4-byte values */
117 size_t toCopy = util_rndGet(2, 4);
118 mangle_Overwrite(run, (uint8_t*)&val, off, toCopy);
119}
120
Robert Swieckid50ed422017-11-13 23:32:26 +0100121static void mangle_Bit(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100122 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
123 run->dynamicFile[off] ^= (uint8_t)(1U << util_rndGet(0, 7));
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000124}
125
plusundc64d052018-07-31 13:55:50 +0000126static void mangle_BitPrintable(run_t* run) {
127 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
128 run->dynamicFile[off] ^= (uint8_t)(1U << util_rndGet(0, 7));
129 util_turnToPrintable(&(run->dynamicFile[off]), 1);
130}
131
Robert Swieckid50ed422017-11-13 23:32:26 +0100132static void mangle_DictionaryInsert(run_t* run) {
Robert Swiecki04dcac32018-03-02 03:05:26 +0100133 if (run->global->mutate.dictionaryCnt == 0) {
Robert Swiecki78633d12017-11-13 23:24:55 +0100134 mangle_Bit(run);
Robert Swiecki40d13412017-01-29 02:45:37 +0100135 return;
136 }
137
Robert Swiecki04dcac32018-03-02 03:05:26 +0100138 uint64_t choice = util_rndGet(0, run->global->mutate.dictionaryCnt - 1);
139 struct strings_t* str = TAILQ_FIRST(&run->global->mutate.dictq);
Robert Swiecki40d13412017-01-29 02:45:37 +0100140 for (uint64_t i = 0; i < choice; i++) {
Robert Swieckiafb16102017-03-13 22:14:31 +0100141 str = TAILQ_NEXT(str, pointers);
Robert Swiecki40d13412017-01-29 02:45:37 +0100142 }
143
Robert Swieckie7294ca2017-11-11 02:46:32 +0100144 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
Robert Swiecki78633d12017-11-13 23:24:55 +0100145 mangle_Inflate(run, off, str->len);
Robert Swieckie7294ca2017-11-11 02:46:32 +0100146 mangle_Move(run, off, off + str->len, str->len);
147 mangle_Overwrite(run, (uint8_t*)str->s, off, str->len);
Robert Swiecki40d13412017-01-29 02:45:37 +0100148}
149
plusundc64d052018-07-31 13:55:50 +0000150static void mangle_DictionaryInsertPrintable(run_t* run) {
151 if (run->global->mutate.dictionaryCnt == 0) {
152 mangle_BitPrintable(run);
153 return;
154 }
155
156 uint64_t choice = util_rndGet(0, run->global->mutate.dictionaryCnt - 1);
157 struct strings_t* str = TAILQ_FIRST(&run->global->mutate.dictq);
158 for (uint64_t i = 0; i < choice; i++) {
159 str = TAILQ_NEXT(str, pointers);
160 }
161
162 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
163 mangle_Inflate(run, off, str->len);
164 mangle_Move(run, off, off + str->len, str->len);
165 mangle_Overwrite(run, (uint8_t*)str->s, off, str->len);
166}
167
Robert Swieckid50ed422017-11-13 23:32:26 +0100168static void mangle_Dictionary(run_t* run) {
Robert Swiecki04dcac32018-03-02 03:05:26 +0100169 if (run->global->mutate.dictionaryCnt == 0) {
Robert Swiecki78633d12017-11-13 23:24:55 +0100170 mangle_Bit(run);
tlogic@gmail.com7b6d7ee2015-04-23 21:30:12 +0000171 return;
robert.swiecki@gmail.com4f1124f2015-04-21 17:12:22 +0000172 }
173
Robert Swieckie7294ca2017-11-11 02:46:32 +0100174 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
Robert Swiecki531438a2016-09-13 19:05:11 +0200175
Robert Swiecki04dcac32018-03-02 03:05:26 +0100176 uint64_t choice = util_rndGet(0, run->global->mutate.dictionaryCnt - 1);
177 struct strings_t* str = TAILQ_FIRST(&run->global->mutate.dictq);
Robert Swiecki8e9ed422017-01-26 16:46:55 +0100178 for (uint64_t i = 0; i < choice; i++) {
Robert Swieckiafb16102017-03-13 22:14:31 +0100179 str = TAILQ_NEXT(str, pointers);
Robert Swiecki8e9ed422017-01-26 16:46:55 +0100180 }
181
Robert Swieckie7294ca2017-11-11 02:46:32 +0100182 mangle_Overwrite(run, (uint8_t*)str->s, off, str->len);
plusundc64d052018-07-31 13:55:50 +0000183 /* FIXME */
184}
185
186static void mangle_DictionaryPrintable(run_t* run) {
187 if (run->global->mutate.dictionaryCnt == 0) {
188 mangle_BitPrintable(run);
189 return;
190 }
191
192 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
193
194 uint64_t choice = util_rndGet(0, run->global->mutate.dictionaryCnt - 1);
195 struct strings_t* str = TAILQ_FIRST(&run->global->mutate.dictq);
196 for (uint64_t i = 0; i < choice; i++) {
197 str = TAILQ_NEXT(str, pointers);
198 }
199
200 mangle_Overwrite(run, (uint8_t*)str->s, off, str->len);
201 /* FIXME */
Robert Swiecki8e9ed422017-01-26 16:46:55 +0100202}
203
Robert Swieckid50ed422017-11-13 23:32:26 +0100204static void mangle_Magic(run_t* run) {
robert.swiecki@gmail.com3d928f12015-04-15 14:43:21 +0000205 static const struct {
Anestis Bechtsoudis4799a9d2015-12-20 15:44:26 +0200206 const uint8_t val[8];
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000207 const size_t size;
Anestis Bechtsoudis4799a9d2015-12-20 15:44:26 +0200208 } mangleMagicVals[] = {
Anestis Bechtsoudis51c9bb12015-08-26 14:46:21 +0300209 /* 1B - No endianness */
Robert Swieckid50ed422017-11-13 23:32:26 +0100210 {"\x00\x00\x00\x00\x00\x00\x00\x00", 1},
211 {"\x01\x00\x00\x00\x00\x00\x00\x00", 1},
212 {"\x02\x00\x00\x00\x00\x00\x00\x00", 1},
213 {"\x03\x00\x00\x00\x00\x00\x00\x00", 1},
214 {"\x04\x00\x00\x00\x00\x00\x00\x00", 1},
215 {"\x05\x00\x00\x00\x00\x00\x00\x00", 1},
216 {"\x06\x00\x00\x00\x00\x00\x00\x00", 1},
217 {"\x07\x00\x00\x00\x00\x00\x00\x00", 1},
218 {"\x08\x00\x00\x00\x00\x00\x00\x00", 1},
219 {"\x09\x00\x00\x00\x00\x00\x00\x00", 1},
220 {"\x0A\x00\x00\x00\x00\x00\x00\x00", 1},
221 {"\x0B\x00\x00\x00\x00\x00\x00\x00", 1},
222 {"\x0C\x00\x00\x00\x00\x00\x00\x00", 1},
223 {"\x0D\x00\x00\x00\x00\x00\x00\x00", 1},
224 {"\x0E\x00\x00\x00\x00\x00\x00\x00", 1},
225 {"\x0F\x00\x00\x00\x00\x00\x00\x00", 1},
226 {"\x10\x00\x00\x00\x00\x00\x00\x00", 1},
227 {"\x20\x00\x00\x00\x00\x00\x00\x00", 1},
228 {"\x40\x00\x00\x00\x00\x00\x00\x00", 1},
229 {"\x7E\x00\x00\x00\x00\x00\x00\x00", 1},
230 {"\x7F\x00\x00\x00\x00\x00\x00\x00", 1},
231 {"\x80\x00\x00\x00\x00\x00\x00\x00", 1},
232 {"\x81\x00\x00\x00\x00\x00\x00\x00", 1},
233 {"\xC0\x00\x00\x00\x00\x00\x00\x00", 1},
234 {"\xFE\x00\x00\x00\x00\x00\x00\x00", 1},
235 {"\xFF\x00\x00\x00\x00\x00\x00\x00", 1},
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000236 /* 2B - NE */
Robert Swieckid50ed422017-11-13 23:32:26 +0100237 {"\x00\x00\x00\x00\x00\x00\x00\x00", 2},
238 {"\x01\x01\x00\x00\x00\x00\x00\x00", 2},
239 {"\x80\x80\x00\x00\x00\x00\x00\x00", 2},
240 {"\xFF\xFF\x00\x00\x00\x00\x00\x00", 2},
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000241 /* 2B - BE */
Robert Swieckid50ed422017-11-13 23:32:26 +0100242 {"\x00\x01\x00\x00\x00\x00\x00\x00", 2},
243 {"\x00\x02\x00\x00\x00\x00\x00\x00", 2},
244 {"\x00\x03\x00\x00\x00\x00\x00\x00", 2},
245 {"\x00\x04\x00\x00\x00\x00\x00\x00", 2},
246 {"\x00\x05\x00\x00\x00\x00\x00\x00", 2},
247 {"\x00\x06\x00\x00\x00\x00\x00\x00", 2},
248 {"\x00\x07\x00\x00\x00\x00\x00\x00", 2},
249 {"\x00\x08\x00\x00\x00\x00\x00\x00", 2},
250 {"\x00\x09\x00\x00\x00\x00\x00\x00", 2},
251 {"\x00\x0A\x00\x00\x00\x00\x00\x00", 2},
252 {"\x00\x0B\x00\x00\x00\x00\x00\x00", 2},
253 {"\x00\x0C\x00\x00\x00\x00\x00\x00", 2},
254 {"\x00\x0D\x00\x00\x00\x00\x00\x00", 2},
255 {"\x00\x0E\x00\x00\x00\x00\x00\x00", 2},
256 {"\x00\x0F\x00\x00\x00\x00\x00\x00", 2},
257 {"\x00\x10\x00\x00\x00\x00\x00\x00", 2},
258 {"\x00\x20\x00\x00\x00\x00\x00\x00", 2},
259 {"\x00\x40\x00\x00\x00\x00\x00\x00", 2},
260 {"\x00\x7E\x00\x00\x00\x00\x00\x00", 2},
261 {"\x00\x7F\x00\x00\x00\x00\x00\x00", 2},
262 {"\x00\x80\x00\x00\x00\x00\x00\x00", 2},
263 {"\x00\x81\x00\x00\x00\x00\x00\x00", 2},
264 {"\x00\xC0\x00\x00\x00\x00\x00\x00", 2},
265 {"\x00\xFE\x00\x00\x00\x00\x00\x00", 2},
266 {"\x00\xFF\x00\x00\x00\x00\x00\x00", 2},
267 {"\x7E\xFF\x00\x00\x00\x00\x00\x00", 2},
268 {"\x7F\xFF\x00\x00\x00\x00\x00\x00", 2},
269 {"\x80\x00\x00\x00\x00\x00\x00\x00", 2},
270 {"\x80\x01\x00\x00\x00\x00\x00\x00", 2},
271 {"\xFF\xFE\x00\x00\x00\x00\x00\x00", 2},
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000272 /* 2B - LE */
Robert Swieckid50ed422017-11-13 23:32:26 +0100273 {"\x00\x00\x00\x00\x00\x00\x00\x00", 2},
274 {"\x01\x00\x00\x00\x00\x00\x00\x00", 2},
275 {"\x02\x00\x00\x00\x00\x00\x00\x00", 2},
276 {"\x03\x00\x00\x00\x00\x00\x00\x00", 2},
277 {"\x04\x00\x00\x00\x00\x00\x00\x00", 2},
278 {"\x05\x00\x00\x00\x00\x00\x00\x00", 2},
279 {"\x06\x00\x00\x00\x00\x00\x00\x00", 2},
280 {"\x07\x00\x00\x00\x00\x00\x00\x00", 2},
281 {"\x08\x00\x00\x00\x00\x00\x00\x00", 2},
282 {"\x09\x00\x00\x00\x00\x00\x00\x00", 2},
283 {"\x0A\x00\x00\x00\x00\x00\x00\x00", 2},
284 {"\x0B\x00\x00\x00\x00\x00\x00\x00", 2},
285 {"\x0C\x00\x00\x00\x00\x00\x00\x00", 2},
286 {"\x0D\x00\x00\x00\x00\x00\x00\x00", 2},
287 {"\x0E\x00\x00\x00\x00\x00\x00\x00", 2},
288 {"\x0F\x00\x00\x00\x00\x00\x00\x00", 2},
289 {"\x10\x00\x00\x00\x00\x00\x00\x00", 2},
290 {"\x20\x00\x00\x00\x00\x00\x00\x00", 2},
291 {"\x40\x00\x00\x00\x00\x00\x00\x00", 2},
292 {"\x7E\x00\x00\x00\x00\x00\x00\x00", 2},
293 {"\x7F\x00\x00\x00\x00\x00\x00\x00", 2},
294 {"\x80\x00\x00\x00\x00\x00\x00\x00", 2},
295 {"\x81\x00\x00\x00\x00\x00\x00\x00", 2},
296 {"\xC0\x00\x00\x00\x00\x00\x00\x00", 2},
297 {"\xFE\x00\x00\x00\x00\x00\x00\x00", 2},
298 {"\xFF\x00\x00\x00\x00\x00\x00\x00", 2},
299 {"\xFF\x7E\x00\x00\x00\x00\x00\x00", 2},
300 {"\xFF\x7F\x00\x00\x00\x00\x00\x00", 2},
301 {"\x00\x80\x00\x00\x00\x00\x00\x00", 2},
302 {"\x01\x80\x00\x00\x00\x00\x00\x00", 2},
303 {"\xFE\xFF\x00\x00\x00\x00\x00\x00", 2},
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000304 /* 4B - NE */
Robert Swieckid50ed422017-11-13 23:32:26 +0100305 {"\x00\x00\x00\x00\x00\x00\x00\x00", 4},
306 {"\x01\x01\x01\x01\x00\x00\x00\x00", 4},
307 {"\x80\x80\x80\x80\x00\x00\x00\x00", 4},
308 {"\xFF\xFF\xFF\xFF\x00\x00\x00\x00", 4},
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000309 /* 4B - BE */
Robert Swieckid50ed422017-11-13 23:32:26 +0100310 {"\x00\x00\x00\x01\x00\x00\x00\x00", 4},
311 {"\x00\x00\x00\x02\x00\x00\x00\x00", 4},
312 {"\x00\x00\x00\x03\x00\x00\x00\x00", 4},
313 {"\x00\x00\x00\x04\x00\x00\x00\x00", 4},
314 {"\x00\x00\x00\x05\x00\x00\x00\x00", 4},
315 {"\x00\x00\x00\x06\x00\x00\x00\x00", 4},
316 {"\x00\x00\x00\x07\x00\x00\x00\x00", 4},
317 {"\x00\x00\x00\x08\x00\x00\x00\x00", 4},
318 {"\x00\x00\x00\x09\x00\x00\x00\x00", 4},
319 {"\x00\x00\x00\x0A\x00\x00\x00\x00", 4},
320 {"\x00\x00\x00\x0B\x00\x00\x00\x00", 4},
321 {"\x00\x00\x00\x0C\x00\x00\x00\x00", 4},
322 {"\x00\x00\x00\x0D\x00\x00\x00\x00", 4},
323 {"\x00\x00\x00\x0E\x00\x00\x00\x00", 4},
324 {"\x00\x00\x00\x0F\x00\x00\x00\x00", 4},
325 {"\x00\x00\x00\x10\x00\x00\x00\x00", 4},
326 {"\x00\x00\x00\x20\x00\x00\x00\x00", 4},
327 {"\x00\x00\x00\x40\x00\x00\x00\x00", 4},
328 {"\x00\x00\x00\x7E\x00\x00\x00\x00", 4},
329 {"\x00\x00\x00\x7F\x00\x00\x00\x00", 4},
330 {"\x00\x00\x00\x80\x00\x00\x00\x00", 4},
331 {"\x00\x00\x00\x81\x00\x00\x00\x00", 4},
332 {"\x00\x00\x00\xC0\x00\x00\x00\x00", 4},
333 {"\x00\x00\x00\xFE\x00\x00\x00\x00", 4},
334 {"\x00\x00\x00\xFF\x00\x00\x00\x00", 4},
335 {"\x7E\xFF\xFF\xFF\x00\x00\x00\x00", 4},
336 {"\x7F\xFF\xFF\xFF\x00\x00\x00\x00", 4},
337 {"\x80\x00\x00\x00\x00\x00\x00\x00", 4},
338 {"\x80\x00\x00\x01\x00\x00\x00\x00", 4},
339 {"\xFF\xFF\xFF\xFE\x00\x00\x00\x00", 4},
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000340 /* 4B - LE */
Robert Swieckid50ed422017-11-13 23:32:26 +0100341 {"\x00\x00\x00\x00\x00\x00\x00\x00", 4},
342 {"\x01\x00\x00\x00\x00\x00\x00\x00", 4},
343 {"\x02\x00\x00\x00\x00\x00\x00\x00", 4},
344 {"\x03\x00\x00\x00\x00\x00\x00\x00", 4},
345 {"\x04\x00\x00\x00\x00\x00\x00\x00", 4},
346 {"\x05\x00\x00\x00\x00\x00\x00\x00", 4},
347 {"\x06\x00\x00\x00\x00\x00\x00\x00", 4},
348 {"\x07\x00\x00\x00\x00\x00\x00\x00", 4},
349 {"\x08\x00\x00\x00\x00\x00\x00\x00", 4},
350 {"\x09\x00\x00\x00\x00\x00\x00\x00", 4},
351 {"\x0A\x00\x00\x00\x00\x00\x00\x00", 4},
352 {"\x0B\x00\x00\x00\x00\x00\x00\x00", 4},
353 {"\x0C\x00\x00\x00\x00\x00\x00\x00", 4},
354 {"\x0D\x00\x00\x00\x00\x00\x00\x00", 4},
355 {"\x0E\x00\x00\x00\x00\x00\x00\x00", 4},
356 {"\x0F\x00\x00\x00\x00\x00\x00\x00", 4},
357 {"\x10\x00\x00\x00\x00\x00\x00\x00", 4},
358 {"\x20\x00\x00\x00\x00\x00\x00\x00", 4},
359 {"\x40\x00\x00\x00\x00\x00\x00\x00", 4},
360 {"\x7E\x00\x00\x00\x00\x00\x00\x00", 4},
361 {"\x7F\x00\x00\x00\x00\x00\x00\x00", 4},
362 {"\x80\x00\x00\x00\x00\x00\x00\x00", 4},
363 {"\x81\x00\x00\x00\x00\x00\x00\x00", 4},
364 {"\xC0\x00\x00\x00\x00\x00\x00\x00", 4},
365 {"\xFE\x00\x00\x00\x00\x00\x00\x00", 4},
366 {"\xFF\x00\x00\x00\x00\x00\x00\x00", 4},
367 {"\xFF\xFF\xFF\x7E\x00\x00\x00\x00", 4},
368 {"\xFF\xFF\xFF\x7F\x00\x00\x00\x00", 4},
369 {"\x00\x00\x00\x80\x00\x00\x00\x00", 4},
370 {"\x01\x00\x00\x80\x00\x00\x00\x00", 4},
371 {"\xFE\xFF\xFF\xFF\x00\x00\x00\x00", 4},
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000372 /* 8B - NE */
Robert Swieckid50ed422017-11-13 23:32:26 +0100373 {"\x00\x00\x00\x00\x00\x00\x00\x00", 8},
374 {"\x01\x01\x01\x01\x01\x01\x01\x01", 8},
375 {"\x80\x80\x80\x80\x80\x80\x80\x80", 8},
376 {"\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 8},
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000377 /* 8B - BE */
Robert Swieckid50ed422017-11-13 23:32:26 +0100378 {"\x00\x00\x00\x00\x00\x00\x00\x01", 8},
379 {"\x00\x00\x00\x00\x00\x00\x00\x02", 8},
380 {"\x00\x00\x00\x00\x00\x00\x00\x03", 8},
381 {"\x00\x00\x00\x00\x00\x00\x00\x04", 8},
382 {"\x00\x00\x00\x00\x00\x00\x00\x05", 8},
383 {"\x00\x00\x00\x00\x00\x00\x00\x06", 8},
384 {"\x00\x00\x00\x00\x00\x00\x00\x07", 8},
385 {"\x00\x00\x00\x00\x00\x00\x00\x08", 8},
386 {"\x00\x00\x00\x00\x00\x00\x00\x09", 8},
387 {"\x00\x00\x00\x00\x00\x00\x00\x0A", 8},
388 {"\x00\x00\x00\x00\x00\x00\x00\x0B", 8},
389 {"\x00\x00\x00\x00\x00\x00\x00\x0C", 8},
390 {"\x00\x00\x00\x00\x00\x00\x00\x0D", 8},
391 {"\x00\x00\x00\x00\x00\x00\x00\x0E", 8},
392 {"\x00\x00\x00\x00\x00\x00\x00\x0F", 8},
393 {"\x00\x00\x00\x00\x00\x00\x00\x10", 8},
394 {"\x00\x00\x00\x00\x00\x00\x00\x20", 8},
395 {"\x00\x00\x00\x00\x00\x00\x00\x40", 8},
396 {"\x00\x00\x00\x00\x00\x00\x00\x7E", 8},
397 {"\x00\x00\x00\x00\x00\x00\x00\x7F", 8},
398 {"\x00\x00\x00\x00\x00\x00\x00\x80", 8},
399 {"\x00\x00\x00\x00\x00\x00\x00\x81", 8},
400 {"\x00\x00\x00\x00\x00\x00\x00\xC0", 8},
401 {"\x00\x00\x00\x00\x00\x00\x00\xFE", 8},
402 {"\x00\x00\x00\x00\x00\x00\x00\xFF", 8},
403 {"\x7E\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 8},
404 {"\x7F\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 8},
405 {"\x80\x00\x00\x00\x00\x00\x00\x00", 8},
406 {"\x80\x00\x00\x00\x00\x00\x00\x01", 8},
407 {"\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFE", 8},
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000408 /* 8B - LE */
Robert Swieckid50ed422017-11-13 23:32:26 +0100409 {"\x00\x00\x00\x00\x00\x00\x00\x00", 8},
410 {"\x01\x00\x00\x00\x00\x00\x00\x00", 8},
411 {"\x02\x00\x00\x00\x00\x00\x00\x00", 8},
412 {"\x03\x00\x00\x00\x00\x00\x00\x00", 8},
413 {"\x04\x00\x00\x00\x00\x00\x00\x00", 8},
414 {"\x05\x00\x00\x00\x00\x00\x00\x00", 8},
415 {"\x06\x00\x00\x00\x00\x00\x00\x00", 8},
416 {"\x07\x00\x00\x00\x00\x00\x00\x00", 8},
417 {"\x08\x00\x00\x00\x00\x00\x00\x00", 8},
418 {"\x09\x00\x00\x00\x00\x00\x00\x00", 8},
419 {"\x0A\x00\x00\x00\x00\x00\x00\x00", 8},
420 {"\x0B\x00\x00\x00\x00\x00\x00\x00", 8},
421 {"\x0C\x00\x00\x00\x00\x00\x00\x00", 8},
422 {"\x0D\x00\x00\x00\x00\x00\x00\x00", 8},
423 {"\x0E\x00\x00\x00\x00\x00\x00\x00", 8},
424 {"\x0F\x00\x00\x00\x00\x00\x00\x00", 8},
425 {"\x10\x00\x00\x00\x00\x00\x00\x00", 8},
426 {"\x20\x00\x00\x00\x00\x00\x00\x00", 8},
427 {"\x40\x00\x00\x00\x00\x00\x00\x00", 8},
428 {"\x7E\x00\x00\x00\x00\x00\x00\x00", 8},
429 {"\x7F\x00\x00\x00\x00\x00\x00\x00", 8},
430 {"\x80\x00\x00\x00\x00\x00\x00\x00", 8},
431 {"\x81\x00\x00\x00\x00\x00\x00\x00", 8},
432 {"\xC0\x00\x00\x00\x00\x00\x00\x00", 8},
433 {"\xFE\x00\x00\x00\x00\x00\x00\x00", 8},
434 {"\xFF\x00\x00\x00\x00\x00\x00\x00", 8},
435 {"\xFF\xFF\xFF\xFF\xFF\xFF\xFF\x7E", 8},
436 {"\xFF\xFF\xFF\xFF\xFF\xFF\xFF\x7F", 8},
437 {"\x00\x00\x00\x00\x00\x00\x00\x80", 8},
438 {"\x01\x00\x00\x00\x00\x00\x00\x80", 8},
439 {"\xFE\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 8},
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000440 };
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000441
Robert Swieckie7294ca2017-11-11 02:46:32 +0100442 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000443 uint64_t choice = util_rndGet(0, ARRAYSIZE(mangleMagicVals) - 1);
Robert Swieckie7294ca2017-11-11 02:46:32 +0100444 mangle_Overwrite(run, mangleMagicVals[choice].val, off, mangleMagicVals[choice].size);
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +0000445}
446
plusundc64d052018-07-31 13:55:50 +0000447static void mangle_MagicPrintable(run_t* run) {
448 static const struct {
449 const uint8_t val[8];
450 const size_t size;
451 } mangleMagicVals[] = {
452 /* 1B - No endianness */
453 {"\x00\x00\x00\x00\x00\x00\x00\x00", 1},
454 {"\x01\x00\x00\x00\x00\x00\x00\x00", 1},
455 {"\x02\x00\x00\x00\x00\x00\x00\x00", 1},
456 {"\x03\x00\x00\x00\x00\x00\x00\x00", 1},
457 {"\x04\x00\x00\x00\x00\x00\x00\x00", 1},
458 {"\x05\x00\x00\x00\x00\x00\x00\x00", 1},
459 {"\x06\x00\x00\x00\x00\x00\x00\x00", 1},
460 {"\x07\x00\x00\x00\x00\x00\x00\x00", 1},
461 {"\x08\x00\x00\x00\x00\x00\x00\x00", 1},
462 {"\x09\x00\x00\x00\x00\x00\x00\x00", 1},
463 {"\x0A\x00\x00\x00\x00\x00\x00\x00", 1},
464 {"\x0B\x00\x00\x00\x00\x00\x00\x00", 1},
465 {"\x0C\x00\x00\x00\x00\x00\x00\x00", 1},
466 {"\x0D\x00\x00\x00\x00\x00\x00\x00", 1},
467 {"\x0E\x00\x00\x00\x00\x00\x00\x00", 1},
468 {"\x0F\x00\x00\x00\x00\x00\x00\x00", 1},
469 {"\x10\x00\x00\x00\x00\x00\x00\x00", 1},
470 {"\x20\x00\x00\x00\x00\x00\x00\x00", 1},
471 {"\x40\x00\x00\x00\x00\x00\x00\x00", 1},
472 {"\x7E\x00\x00\x00\x00\x00\x00\x00", 1},
473 {"\x7F\x00\x00\x00\x00\x00\x00\x00", 1},
474 {"\x80\x00\x00\x00\x00\x00\x00\x00", 1},
475 {"\x81\x00\x00\x00\x00\x00\x00\x00", 1},
476 {"\xC0\x00\x00\x00\x00\x00\x00\x00", 1},
477 {"\xFE\x00\x00\x00\x00\x00\x00\x00", 1},
478 {"\xFF\x00\x00\x00\x00\x00\x00\x00", 1},
479 /* 2B - NE */
480 {"\x00\x00\x00\x00\x00\x00\x00\x00", 2},
481 {"\x01\x01\x00\x00\x00\x00\x00\x00", 2},
482 {"\x80\x80\x00\x00\x00\x00\x00\x00", 2},
483 {"\xFF\xFF\x00\x00\x00\x00\x00\x00", 2},
484 /* 2B - BE */
485 {"\x00\x01\x00\x00\x00\x00\x00\x00", 2},
486 {"\x00\x02\x00\x00\x00\x00\x00\x00", 2},
487 {"\x00\x03\x00\x00\x00\x00\x00\x00", 2},
488 {"\x00\x04\x00\x00\x00\x00\x00\x00", 2},
489 {"\x00\x05\x00\x00\x00\x00\x00\x00", 2},
490 {"\x00\x06\x00\x00\x00\x00\x00\x00", 2},
491 {"\x00\x07\x00\x00\x00\x00\x00\x00", 2},
492 {"\x00\x08\x00\x00\x00\x00\x00\x00", 2},
493 {"\x00\x09\x00\x00\x00\x00\x00\x00", 2},
494 {"\x00\x0A\x00\x00\x00\x00\x00\x00", 2},
495 {"\x00\x0B\x00\x00\x00\x00\x00\x00", 2},
496 {"\x00\x0C\x00\x00\x00\x00\x00\x00", 2},
497 {"\x00\x0D\x00\x00\x00\x00\x00\x00", 2},
498 {"\x00\x0E\x00\x00\x00\x00\x00\x00", 2},
499 {"\x00\x0F\x00\x00\x00\x00\x00\x00", 2},
500 {"\x00\x10\x00\x00\x00\x00\x00\x00", 2},
501 {"\x00\x20\x00\x00\x00\x00\x00\x00", 2},
502 {"\x00\x40\x00\x00\x00\x00\x00\x00", 2},
503 {"\x00\x7E\x00\x00\x00\x00\x00\x00", 2},
504 {"\x00\x7F\x00\x00\x00\x00\x00\x00", 2},
505 {"\x00\x80\x00\x00\x00\x00\x00\x00", 2},
506 {"\x00\x81\x00\x00\x00\x00\x00\x00", 2},
507 {"\x00\xC0\x00\x00\x00\x00\x00\x00", 2},
508 {"\x00\xFE\x00\x00\x00\x00\x00\x00", 2},
509 {"\x00\xFF\x00\x00\x00\x00\x00\x00", 2},
510 {"\x7E\xFF\x00\x00\x00\x00\x00\x00", 2},
511 {"\x7F\xFF\x00\x00\x00\x00\x00\x00", 2},
512 {"\x80\x00\x00\x00\x00\x00\x00\x00", 2},
513 {"\x80\x01\x00\x00\x00\x00\x00\x00", 2},
514 {"\xFF\xFE\x00\x00\x00\x00\x00\x00", 2},
515 /* 2B - LE */
516 {"\x00\x00\x00\x00\x00\x00\x00\x00", 2},
517 {"\x01\x00\x00\x00\x00\x00\x00\x00", 2},
518 {"\x02\x00\x00\x00\x00\x00\x00\x00", 2},
519 {"\x03\x00\x00\x00\x00\x00\x00\x00", 2},
520 {"\x04\x00\x00\x00\x00\x00\x00\x00", 2},
521 {"\x05\x00\x00\x00\x00\x00\x00\x00", 2},
522 {"\x06\x00\x00\x00\x00\x00\x00\x00", 2},
523 {"\x07\x00\x00\x00\x00\x00\x00\x00", 2},
524 {"\x08\x00\x00\x00\x00\x00\x00\x00", 2},
525 {"\x09\x00\x00\x00\x00\x00\x00\x00", 2},
526 {"\x0A\x00\x00\x00\x00\x00\x00\x00", 2},
527 {"\x0B\x00\x00\x00\x00\x00\x00\x00", 2},
528 {"\x0C\x00\x00\x00\x00\x00\x00\x00", 2},
529 {"\x0D\x00\x00\x00\x00\x00\x00\x00", 2},
530 {"\x0E\x00\x00\x00\x00\x00\x00\x00", 2},
531 {"\x0F\x00\x00\x00\x00\x00\x00\x00", 2},
532 {"\x10\x00\x00\x00\x00\x00\x00\x00", 2},
533 {"\x20\x00\x00\x00\x00\x00\x00\x00", 2},
534 {"\x40\x00\x00\x00\x00\x00\x00\x00", 2},
535 {"\x7E\x00\x00\x00\x00\x00\x00\x00", 2},
536 {"\x7F\x00\x00\x00\x00\x00\x00\x00", 2},
537 {"\x80\x00\x00\x00\x00\x00\x00\x00", 2},
538 {"\x81\x00\x00\x00\x00\x00\x00\x00", 2},
539 {"\xC0\x00\x00\x00\x00\x00\x00\x00", 2},
540 {"\xFE\x00\x00\x00\x00\x00\x00\x00", 2},
541 {"\xFF\x00\x00\x00\x00\x00\x00\x00", 2},
542 {"\xFF\x7E\x00\x00\x00\x00\x00\x00", 2},
543 {"\xFF\x7F\x00\x00\x00\x00\x00\x00", 2},
544 {"\x00\x80\x00\x00\x00\x00\x00\x00", 2},
545 {"\x01\x80\x00\x00\x00\x00\x00\x00", 2},
546 {"\xFE\xFF\x00\x00\x00\x00\x00\x00", 2},
547 /* 4B - NE */
548 {"\x00\x00\x00\x00\x00\x00\x00\x00", 4},
549 {"\x01\x01\x01\x01\x00\x00\x00\x00", 4},
550 {"\x80\x80\x80\x80\x00\x00\x00\x00", 4},
551 {"\xFF\xFF\xFF\xFF\x00\x00\x00\x00", 4},
552 /* 4B - BE */
553 {"\x00\x00\x00\x01\x00\x00\x00\x00", 4},
554 {"\x00\x00\x00\x02\x00\x00\x00\x00", 4},
555 {"\x00\x00\x00\x03\x00\x00\x00\x00", 4},
556 {"\x00\x00\x00\x04\x00\x00\x00\x00", 4},
557 {"\x00\x00\x00\x05\x00\x00\x00\x00", 4},
558 {"\x00\x00\x00\x06\x00\x00\x00\x00", 4},
559 {"\x00\x00\x00\x07\x00\x00\x00\x00", 4},
560 {"\x00\x00\x00\x08\x00\x00\x00\x00", 4},
561 {"\x00\x00\x00\x09\x00\x00\x00\x00", 4},
562 {"\x00\x00\x00\x0A\x00\x00\x00\x00", 4},
563 {"\x00\x00\x00\x0B\x00\x00\x00\x00", 4},
564 {"\x00\x00\x00\x0C\x00\x00\x00\x00", 4},
565 {"\x00\x00\x00\x0D\x00\x00\x00\x00", 4},
566 {"\x00\x00\x00\x0E\x00\x00\x00\x00", 4},
567 {"\x00\x00\x00\x0F\x00\x00\x00\x00", 4},
568 {"\x00\x00\x00\x10\x00\x00\x00\x00", 4},
569 {"\x00\x00\x00\x20\x00\x00\x00\x00", 4},
570 {"\x00\x00\x00\x40\x00\x00\x00\x00", 4},
571 {"\x00\x00\x00\x7E\x00\x00\x00\x00", 4},
572 {"\x00\x00\x00\x7F\x00\x00\x00\x00", 4},
573 {"\x00\x00\x00\x80\x00\x00\x00\x00", 4},
574 {"\x00\x00\x00\x81\x00\x00\x00\x00", 4},
575 {"\x00\x00\x00\xC0\x00\x00\x00\x00", 4},
576 {"\x00\x00\x00\xFE\x00\x00\x00\x00", 4},
577 {"\x00\x00\x00\xFF\x00\x00\x00\x00", 4},
578 {"\x7E\xFF\xFF\xFF\x00\x00\x00\x00", 4},
579 {"\x7F\xFF\xFF\xFF\x00\x00\x00\x00", 4},
580 {"\x80\x00\x00\x00\x00\x00\x00\x00", 4},
581 {"\x80\x00\x00\x01\x00\x00\x00\x00", 4},
582 {"\xFF\xFF\xFF\xFE\x00\x00\x00\x00", 4},
583 /* 4B - LE */
584 {"\x00\x00\x00\x00\x00\x00\x00\x00", 4},
585 {"\x01\x00\x00\x00\x00\x00\x00\x00", 4},
586 {"\x02\x00\x00\x00\x00\x00\x00\x00", 4},
587 {"\x03\x00\x00\x00\x00\x00\x00\x00", 4},
588 {"\x04\x00\x00\x00\x00\x00\x00\x00", 4},
589 {"\x05\x00\x00\x00\x00\x00\x00\x00", 4},
590 {"\x06\x00\x00\x00\x00\x00\x00\x00", 4},
591 {"\x07\x00\x00\x00\x00\x00\x00\x00", 4},
592 {"\x08\x00\x00\x00\x00\x00\x00\x00", 4},
593 {"\x09\x00\x00\x00\x00\x00\x00\x00", 4},
594 {"\x0A\x00\x00\x00\x00\x00\x00\x00", 4},
595 {"\x0B\x00\x00\x00\x00\x00\x00\x00", 4},
596 {"\x0C\x00\x00\x00\x00\x00\x00\x00", 4},
597 {"\x0D\x00\x00\x00\x00\x00\x00\x00", 4},
598 {"\x0E\x00\x00\x00\x00\x00\x00\x00", 4},
599 {"\x0F\x00\x00\x00\x00\x00\x00\x00", 4},
600 {"\x10\x00\x00\x00\x00\x00\x00\x00", 4},
601 {"\x20\x00\x00\x00\x00\x00\x00\x00", 4},
602 {"\x40\x00\x00\x00\x00\x00\x00\x00", 4},
603 {"\x7E\x00\x00\x00\x00\x00\x00\x00", 4},
604 {"\x7F\x00\x00\x00\x00\x00\x00\x00", 4},
605 {"\x80\x00\x00\x00\x00\x00\x00\x00", 4},
606 {"\x81\x00\x00\x00\x00\x00\x00\x00", 4},
607 {"\xC0\x00\x00\x00\x00\x00\x00\x00", 4},
608 {"\xFE\x00\x00\x00\x00\x00\x00\x00", 4},
609 {"\xFF\x00\x00\x00\x00\x00\x00\x00", 4},
610 {"\xFF\xFF\xFF\x7E\x00\x00\x00\x00", 4},
611 {"\xFF\xFF\xFF\x7F\x00\x00\x00\x00", 4},
612 {"\x00\x00\x00\x80\x00\x00\x00\x00", 4},
613 {"\x01\x00\x00\x80\x00\x00\x00\x00", 4},
614 {"\xFE\xFF\xFF\xFF\x00\x00\x00\x00", 4},
615 /* 8B - NE */
616 {"\x00\x00\x00\x00\x00\x00\x00\x00", 8},
617 {"\x01\x01\x01\x01\x01\x01\x01\x01", 8},
618 {"\x80\x80\x80\x80\x80\x80\x80\x80", 8},
619 {"\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 8},
620 /* 8B - BE */
621 {"\x00\x00\x00\x00\x00\x00\x00\x01", 8},
622 {"\x00\x00\x00\x00\x00\x00\x00\x02", 8},
623 {"\x00\x00\x00\x00\x00\x00\x00\x03", 8},
624 {"\x00\x00\x00\x00\x00\x00\x00\x04", 8},
625 {"\x00\x00\x00\x00\x00\x00\x00\x05", 8},
626 {"\x00\x00\x00\x00\x00\x00\x00\x06", 8},
627 {"\x00\x00\x00\x00\x00\x00\x00\x07", 8},
628 {"\x00\x00\x00\x00\x00\x00\x00\x08", 8},
629 {"\x00\x00\x00\x00\x00\x00\x00\x09", 8},
630 {"\x00\x00\x00\x00\x00\x00\x00\x0A", 8},
631 {"\x00\x00\x00\x00\x00\x00\x00\x0B", 8},
632 {"\x00\x00\x00\x00\x00\x00\x00\x0C", 8},
633 {"\x00\x00\x00\x00\x00\x00\x00\x0D", 8},
634 {"\x00\x00\x00\x00\x00\x00\x00\x0E", 8},
635 {"\x00\x00\x00\x00\x00\x00\x00\x0F", 8},
636 {"\x00\x00\x00\x00\x00\x00\x00\x10", 8},
637 {"\x00\x00\x00\x00\x00\x00\x00\x20", 8},
638 {"\x00\x00\x00\x00\x00\x00\x00\x40", 8},
639 {"\x00\x00\x00\x00\x00\x00\x00\x7E", 8},
640 {"\x00\x00\x00\x00\x00\x00\x00\x7F", 8},
641 {"\x00\x00\x00\x00\x00\x00\x00\x80", 8},
642 {"\x00\x00\x00\x00\x00\x00\x00\x81", 8},
643 {"\x00\x00\x00\x00\x00\x00\x00\xC0", 8},
644 {"\x00\x00\x00\x00\x00\x00\x00\xFE", 8},
645 {"\x00\x00\x00\x00\x00\x00\x00\xFF", 8},
646 {"\x7E\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 8},
647 {"\x7F\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 8},
648 {"\x80\x00\x00\x00\x00\x00\x00\x00", 8},
649 {"\x80\x00\x00\x00\x00\x00\x00\x01", 8},
650 {"\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFE", 8},
651 /* 8B - LE */
652 {"\x00\x00\x00\x00\x00\x00\x00\x00", 8},
653 {"\x01\x00\x00\x00\x00\x00\x00\x00", 8},
654 {"\x02\x00\x00\x00\x00\x00\x00\x00", 8},
655 {"\x03\x00\x00\x00\x00\x00\x00\x00", 8},
656 {"\x04\x00\x00\x00\x00\x00\x00\x00", 8},
657 {"\x05\x00\x00\x00\x00\x00\x00\x00", 8},
658 {"\x06\x00\x00\x00\x00\x00\x00\x00", 8},
659 {"\x07\x00\x00\x00\x00\x00\x00\x00", 8},
660 {"\x08\x00\x00\x00\x00\x00\x00\x00", 8},
661 {"\x09\x00\x00\x00\x00\x00\x00\x00", 8},
662 {"\x0A\x00\x00\x00\x00\x00\x00\x00", 8},
663 {"\x0B\x00\x00\x00\x00\x00\x00\x00", 8},
664 {"\x0C\x00\x00\x00\x00\x00\x00\x00", 8},
665 {"\x0D\x00\x00\x00\x00\x00\x00\x00", 8},
666 {"\x0E\x00\x00\x00\x00\x00\x00\x00", 8},
667 {"\x0F\x00\x00\x00\x00\x00\x00\x00", 8},
668 {"\x10\x00\x00\x00\x00\x00\x00\x00", 8},
669 {"\x20\x00\x00\x00\x00\x00\x00\x00", 8},
670 {"\x40\x00\x00\x00\x00\x00\x00\x00", 8},
671 {"\x7E\x00\x00\x00\x00\x00\x00\x00", 8},
672 {"\x7F\x00\x00\x00\x00\x00\x00\x00", 8},
673 {"\x80\x00\x00\x00\x00\x00\x00\x00", 8},
674 {"\x81\x00\x00\x00\x00\x00\x00\x00", 8},
675 {"\xC0\x00\x00\x00\x00\x00\x00\x00", 8},
676 {"\xFE\x00\x00\x00\x00\x00\x00\x00", 8},
677 {"\xFF\x00\x00\x00\x00\x00\x00\x00", 8},
678 {"\xFF\xFF\xFF\xFF\xFF\xFF\xFF\x7E", 8},
679 {"\xFF\xFF\xFF\xFF\xFF\xFF\xFF\x7F", 8},
680 {"\x00\x00\x00\x00\x00\x00\x00\x80", 8},
681 {"\x01\x00\x00\x00\x00\x00\x00\x80", 8},
682 {"\xFE\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 8},
683 };
684
685 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
686 uint64_t choice = util_rndGet(0, ARRAYSIZE(mangleMagicVals) - 1);
687 mangle_Overwrite(run, mangleMagicVals[choice].val, off, mangleMagicVals[choice].size);
plusun4129bd92018-07-31 14:59:01 +0000688 util_turnToPrintable(&run->dynamicFile[off], mangleMagicVals[choice].size);
plusundc64d052018-07-31 13:55:50 +0000689}
690
Robert Swieckid50ed422017-11-13 23:32:26 +0100691static void mangle_MemSet(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100692 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
693 size_t sz = util_rndGet(1, run->dynamicFileSz - off);
robert.swiecki@gmail.com89cc38c2015-02-23 02:52:08 +0000694 int val = (int)util_rndGet(0, UINT8_MAX);
695
Robert Swieckie7294ca2017-11-11 02:46:32 +0100696 memset(&run->dynamicFile[off], val, sz);
robert.swiecki@gmail.com89cc38c2015-02-23 02:52:08 +0000697}
698
plusundc64d052018-07-31 13:55:50 +0000699static void mangle_MemSetPrintable(run_t* run) {
700 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
701 size_t sz = util_rndGet(1, run->dynamicFileSz - off);
702 int val = (int)util_rndPrintable();
703
704 memset(&run->dynamicFile[off], val, sz);
705}
706
Robert Swieckid50ed422017-11-13 23:32:26 +0100707static void mangle_Random(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100708 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
709 size_t len = util_rndGet(1, run->dynamicFileSz - off);
710 util_rndBuf(&run->dynamicFile[off], len);
robert.swiecki@gmail.com89cc38c2015-02-23 02:52:08 +0000711}
712
plusundc64d052018-07-31 13:55:50 +0000713static void mangle_RandomPrintable(run_t* run) {
714 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
715 size_t len = util_rndGet(1, run->dynamicFileSz - off);
plusun0262b322018-08-06 07:37:49 +0000716 util_rndBufPrintable(&run->dynamicFile[off], len);
plusundc64d052018-07-31 13:55:50 +0000717}
718
Robert Swieckid50ed422017-11-13 23:32:26 +0100719static void mangle_AddSub(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100720 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
Robert Swiecki017f5212017-01-26 16:03:29 +0100721
Robert Swieckid6aaca72017-11-14 00:54:39 +0100722 /* 1,2,4,8 */
723 uint64_t varLen = 1U << util_rndGet(0, 3);
Robert Swieckie7294ca2017-11-11 02:46:32 +0100724 if ((run->dynamicFileSz - off) < varLen) {
robert.swiecki@gmail.com57197642015-03-01 15:39:30 +0000725 varLen = 1;
robert.swiecki@gmail.com549ff182015-02-28 22:38:00 +0000726 }
727
Robert Swiecki40d13412017-01-29 02:45:37 +0100728 int delta = (int)util_rndGet(0, 8192);
729 delta -= 4096;
robert.swiecki@gmail.com549ff182015-02-28 22:38:00 +0000730
731 switch (varLen) {
Robert Swieckid50ed422017-11-13 23:32:26 +0100732 case 1: {
733 run->dynamicFile[off] += delta;
734 return;
735 break;
robert.swiecki@gmail.com62e34ae2015-03-05 03:39:32 +0000736 }
Robert Swieckid50ed422017-11-13 23:32:26 +0100737 case 2: {
Robert Swieckid6aaca72017-11-14 00:54:39 +0100738 int16_t val;
739 memcpy(&val, &run->dynamicFile[off], sizeof(val));
740 if (util_rnd64() & 0x1) {
Robert Swieckid50ed422017-11-13 23:32:26 +0100741 val += delta;
742 } else {
743 /* Foreign endianess */
744 val = __builtin_bswap16(val);
745 val += delta;
746 val = __builtin_bswap16(val);
747 }
748 mangle_Overwrite(run, (uint8_t*)&val, off, varLen);
749 return;
750 break;
robert.swiecki@gmail.com549ff182015-02-28 22:38:00 +0000751 }
Robert Swieckid50ed422017-11-13 23:32:26 +0100752 case 4: {
Robert Swieckid6aaca72017-11-14 00:54:39 +0100753 int32_t val;
754 memcpy(&val, &run->dynamicFile[off], sizeof(val));
755 if (util_rnd64() & 0x1) {
Robert Swieckid50ed422017-11-13 23:32:26 +0100756 val += delta;
757 } else {
758 /* Foreign endianess */
759 val = __builtin_bswap32(val);
760 val += delta;
761 val = __builtin_bswap32(val);
762 }
763 mangle_Overwrite(run, (uint8_t*)&val, off, varLen);
764 return;
765 break;
766 }
Robert Swieckid6aaca72017-11-14 00:54:39 +0100767 case 8: {
768 int64_t val;
769 memcpy(&val, &run->dynamicFile[off], sizeof(val));
770 if (util_rnd64() & 0x1) {
771 val += delta;
772 } else {
773 /* Foreign endianess */
774 val = __builtin_bswap64(val);
775 val += delta;
776 val = __builtin_bswap64(val);
777 }
778 mangle_Overwrite(run, (uint8_t*)&val, off, varLen);
779 return;
780 break;
781 }
Robert Swieckid50ed422017-11-13 23:32:26 +0100782 default: {
783 LOG_F("Unknown variable length size: %" PRIu64, varLen);
784 break;
785 }
robert.swiecki@gmail.com549ff182015-02-28 22:38:00 +0000786 }
787}
788
plusundc64d052018-07-31 13:55:50 +0000789static void mangle_AddSubPrintable(run_t* run) {
790 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
791
792 /* 1,2,4,8 */
793 uint64_t varLen = 1U << util_rndGet(0, 3);
794 if ((run->dynamicFileSz - off) < varLen) {
795 varLen = 1;
796 }
797
798 int delta = (int)util_rndGet(0, 8192);
799 delta -= 4096;
800
801 switch (varLen) {
802 case 1: {
803 run->dynamicFile[off] += delta;
804 break;
805 }
806 case 2: {
807 int16_t val;
808 memcpy(&val, &run->dynamicFile[off], sizeof(val));
809 if (util_rnd64() & 0x1) {
810 val += delta;
811 } else {
812 /* Foreign endianess */
813 val = __builtin_bswap16(val);
814 val += delta;
815 val = __builtin_bswap16(val);
816 }
817 mangle_Overwrite(run, (uint8_t*)&val, off, varLen);
818 break;
819 }
820 case 4: {
821 int32_t val;
822 memcpy(&val, &run->dynamicFile[off], sizeof(val));
823 if (util_rnd64() & 0x1) {
824 val += delta;
825 } else {
826 /* Foreign endianess */
827 val = __builtin_bswap32(val);
828 val += delta;
829 val = __builtin_bswap32(val);
830 }
831 mangle_Overwrite(run, (uint8_t*)&val, off, varLen);
832 break;
833 }
834 case 8: {
835 int64_t val;
836 memcpy(&val, &run->dynamicFile[off], sizeof(val));
837 if (util_rnd64() & 0x1) {
838 val += delta;
839 } else {
840 /* Foreign endianess */
841 val = __builtin_bswap64(val);
842 val += delta;
843 val = __builtin_bswap64(val);
844 }
845 mangle_Overwrite(run, (uint8_t*)&val, off, varLen);
846 break;
847 }
848 default: {
849 LOG_F("Unknown variable length size: %" PRIu64, varLen);
850 break;
851 }
852 }
853 util_turnToPrintable((uint8_t *)&run->dynamicFile[off], varLen);
854}
855
Robert Swieckid50ed422017-11-13 23:32:26 +0100856static void mangle_IncByte(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100857 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
858 run->dynamicFile[off] += (uint8_t)1UL;
robert.swiecki@gmail.com78973ed2015-03-01 03:57:18 +0000859}
860
plusundc64d052018-07-31 13:55:50 +0000861static void mangle_IncBytePrintable(run_t* run) {
862 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
plusun441f9cf2018-08-06 07:27:54 +0000863 run->dynamicFile[off] = (run->dynamicFile[off] - 32 + 1) % 95 + 32;
plusundc64d052018-07-31 13:55:50 +0000864}
865
Robert Swieckid50ed422017-11-13 23:32:26 +0100866static void mangle_DecByte(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100867 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
868 run->dynamicFile[off] -= (uint8_t)1UL;
robert.swiecki@gmail.com78973ed2015-03-01 03:57:18 +0000869}
870
plusundc64d052018-07-31 13:55:50 +0000871static void mangle_DecBytePrintable(run_t* run) {
872 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
plusun441f9cf2018-08-06 07:27:54 +0000873 run->dynamicFile[off] = (run->dynamicFile[off] - 32 + 94) % 95 + 32;
plusundc64d052018-07-31 13:55:50 +0000874}
875
Robert Swieckid50ed422017-11-13 23:32:26 +0100876static void mangle_NegByte(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100877 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
878 run->dynamicFile[off] = ~(run->dynamicFile[off]);
Robert Swieckie3bcadf2017-03-02 04:38:12 +0100879}
880
plusundc64d052018-07-31 13:55:50 +0000881static void mangle_NegBytePrintable(run_t* run) {
882 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
plusun441f9cf2018-08-06 07:27:54 +0000883 run->dynamicFile[off] = 94 - (run->dynamicFile[off] - 32) + 32;
plusundc64d052018-07-31 13:55:50 +0000884}
885
Robert Swieckid50ed422017-11-13 23:32:26 +0100886static void mangle_CloneByte(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100887 size_t off1 = util_rndGet(0, run->dynamicFileSz - 1);
888 size_t off2 = util_rndGet(0, run->dynamicFileSz - 1);
Robert Swiecki017f5212017-01-26 16:03:29 +0100889
Robert Swieckie7294ca2017-11-11 02:46:32 +0100890 uint8_t tmp = run->dynamicFile[off1];
891 run->dynamicFile[off1] = run->dynamicFile[off2];
892 run->dynamicFile[off2] = tmp;
Robert Swiecki017f5212017-01-26 16:03:29 +0100893}
894
Robert Swieckid50ed422017-11-13 23:32:26 +0100895static void mangle_Resize(run_t* run) {
Robert Swieckie9231d62018-03-02 03:35:11 +0100896 size_t sz = util_rndGet(1, run->global->mutate.maxFileSz);
Robert Swiecki0f2c30a2018-01-13 14:03:39 +0100897 input_setSize(run, sz);
Robert Swiecki017f5212017-01-26 16:03:29 +0100898}
899
Robert Swieckid50ed422017-11-13 23:32:26 +0100900static void mangle_Expand(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100901 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
902 size_t len = util_rndGet(1, run->dynamicFileSz - off);
Robert Swiecki01fa6062017-01-26 17:04:36 +0100903
Robert Swiecki78633d12017-11-13 23:24:55 +0100904 mangle_Inflate(run, off, len);
Robert Swieckie7294ca2017-11-11 02:46:32 +0100905 mangle_Move(run, off, off + len, run->dynamicFileSz);
Robert Swiecki8e9ed422017-01-26 16:46:55 +0100906}
907
Robert Swieckid50ed422017-11-13 23:32:26 +0100908static void mangle_Shrink(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100909 if (run->dynamicFileSz <= 1U) {
Robert Swiecki8e9ed422017-01-26 16:46:55 +0100910 return;
911 }
912
Robert Swieckie7294ca2017-11-11 02:46:32 +0100913 size_t len = util_rndGet(1, run->dynamicFileSz - 1);
Robert Swieckice15c8c2017-01-28 14:56:34 +0100914 size_t off = util_rndGet(0, len);
Robert Swiecki8e9ed422017-01-26 16:46:55 +0100915
Robert Swiecki0f2c30a2018-01-13 14:03:39 +0100916 input_setSize(run, run->dynamicFileSz - len);
Robert Swieckie7294ca2017-11-11 02:46:32 +0100917 mangle_Move(run, off + len, off, run->dynamicFileSz);
Jagger28a59772016-09-26 01:50:09 +0200918}
919
Robert Swieckid50ed422017-11-13 23:32:26 +0100920static void mangle_InsertRnd(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +0100921 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
922 size_t len = util_rndGet(1, run->dynamicFileSz - off);
Robert Swiecki40d13412017-01-29 02:45:37 +0100923
Robert Swiecki78633d12017-11-13 23:24:55 +0100924 mangle_Inflate(run, off, len);
Robert Swieckie7294ca2017-11-11 02:46:32 +0100925 mangle_Move(run, off, off + len, run->dynamicFileSz);
926 util_rndBuf(&run->dynamicFile[off], len);
Robert Swiecki40d13412017-01-29 02:45:37 +0100927}
928
plusundc64d052018-07-31 13:55:50 +0000929static void mangle_InsertRndPrintable(run_t* run) {
930 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
931 size_t len = util_rndGet(1, run->dynamicFileSz - off);
932
plusun98022492018-08-06 07:16:24 +0000933 mangle_Inflate(run, off, len);
plusundc64d052018-07-31 13:55:50 +0000934 mangle_Move(run, off, off + len, run->dynamicFileSz);
935 util_rndBuf(&run->dynamicFile[off], len);
936 util_turnToPrintable(&run->dynamicFile[off], len);
937}
938
Robert Swiecki03de4082017-12-06 17:56:50 +0100939static void mangle_ASCIIVal(run_t* run) {
940 char buf[32];
941 snprintf(buf, sizeof(buf), "%" PRId64, (int64_t)util_rnd64());
942 size_t off = util_rndGet(0, run->dynamicFileSz - 1);
943
944 mangle_Overwrite(run, (uint8_t*)buf, off, strlen(buf));
945}
946
plusundc64d052018-07-31 13:55:50 +0000947static void (*mangleFuncs[])(run_t * run) = {
948 mangle_Resize,
949 mangle_Byte,
950 mangle_Bit,
951 mangle_Bytes,
952 mangle_Magic,
953 mangle_IncByte,
954 mangle_DecByte,
955 mangle_NegByte,
956 mangle_AddSub,
957 mangle_Dictionary,
958 mangle_DictionaryInsert,
959 mangle_MemMove,
960 mangle_MemSet,
961 mangle_Random,
962 mangle_CloneByte,
963 mangle_Expand,
964 mangle_Shrink,
965 mangle_InsertRnd,
966 mangle_ASCIIVal,
967};
968
969void mangle_init(bool only_printable) {
970 if (only_printable) {
971 static void (*const manglePrintableFuncs[])(run_t * run) = {
plusun98022492018-08-06 07:16:24 +0000972 mangle_Resize,
plusundc64d052018-07-31 13:55:50 +0000973 mangle_PrintableByte,
974 mangle_BitPrintable,
975 mangle_PrintableBytes,
976 mangle_MagicPrintable,
977 mangle_IncBytePrintable,
978 mangle_DecBytePrintable,
979 mangle_NegBytePrintable,
980 mangle_AddSubPrintable,
981 mangle_DictionaryPrintable,
982 mangle_DictionaryInsertPrintable,
983 mangle_MemMove,
984 mangle_MemSetPrintable,
985 mangle_RandomPrintable,
986 mangle_CloneByte,
plusun98022492018-08-06 07:16:24 +0000987 mangle_Expand,
plusundc64d052018-07-31 13:55:50 +0000988 mangle_Shrink,
989 mangle_InsertRndPrintable,
990 mangle_ASCIIVal,
991 };
plusun4129bd92018-07-31 14:59:01 +0000992
plusundc64d052018-07-31 13:55:50 +0000993 if (ARRAYSIZE(mangleFuncs) != ARRAYSIZE(manglePrintableFuncs)) {
994 LOG_F("mangle function list sizes are different")
995 }
996 memcpy(mangleFuncs, manglePrintableFuncs, sizeof(mangleFuncs));
997 }
998}
999
Robert Swiecki0f2c30a2018-01-13 14:03:39 +01001000void mangle_mangleContent(run_t* run) {
Robert Swieckie7294ca2017-11-11 02:46:32 +01001001 if (run->mutationsPerRun == 0U) {
Robert Swieckia438a522017-03-02 14:37:54 +01001002 return;
Robert Swiecki9f25daf2017-01-30 01:29:52 +01001003 }
Robert Swieckia438a522017-03-02 14:37:54 +01001004
Robert Swiecki04f4b4b2018-01-14 20:59:01 +01001005 /* No point in modifying it, if its size is 0 */
Robert Swiecki3f8e9fd2017-12-21 04:07:11 +01001006 if (run->dynamicFileSz == 0UL) {
Robert Swiecki04f4b4b2018-01-14 20:59:01 +01001007 input_setSize(run, 1UL);
Robert Swiecki3f8e9fd2017-12-21 04:07:11 +01001008 }
1009
Robert Swieckibcd7f302017-05-09 17:02:30 +02001010 /* Max number of stacked changes is 6 */
Robert Swiecki04dcac32018-03-02 03:05:26 +01001011 uint64_t changesCnt = util_rndGet(1, run->global->mutate.mutationsPerRun);
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +00001012
1013 for (uint64_t x = 0; x < changesCnt; x++) {
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +00001014 uint64_t choice = util_rndGet(0, ARRAYSIZE(mangleFuncs) - 1);
Robert Swiecki78633d12017-11-13 23:24:55 +01001015 mangleFuncs[choice](run);
robert.swiecki@gmail.coma3e014e2015-02-22 14:33:46 +00001016 }
1017}