2019-03-13 21:21:44 +00:00
|
|
|
// Copyright 2019 The Chromium OS Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
|
|
// found in the LICENSE file.
|
|
|
|
|
|
|
|
#![no_main]
|
|
|
|
|
2020-08-03 03:09:41 +00:00
|
|
|
use base::SharedMemory;
|
2019-10-24 17:25:16 +00:00
|
|
|
use cros_fuzz::fuzz_target;
|
2020-07-21 03:21:11 +00:00
|
|
|
use vm_memory::{GuestAddress, GuestMemory};
|
2019-03-13 21:21:44 +00:00
|
|
|
|
2019-06-05 16:52:13 +00:00
|
|
|
use std::fs::File;
|
|
|
|
use std::io::Write;
|
2019-03-13 21:21:44 +00:00
|
|
|
|
2019-06-05 17:19:02 +00:00
|
|
|
const MEM_SIZE: u64 = 256 * 1024 * 1024;
|
|
|
|
|
2019-06-05 16:52:13 +00:00
|
|
|
fn make_elf_bin(elf_bytes: &[u8]) -> File {
|
2019-09-10 23:11:18 +00:00
|
|
|
let mut shm = SharedMemory::anon().expect("failed to create shared memory");
|
2019-06-05 16:52:13 +00:00
|
|
|
shm.set_size(elf_bytes.len() as u64)
|
|
|
|
.expect("failed to set shared memory size");
|
|
|
|
shm.write_all(elf_bytes)
|
|
|
|
.expect("failed to write elf to shared memoy");
|
|
|
|
shm.into()
|
|
|
|
}
|
|
|
|
|
2019-10-24 17:25:16 +00:00
|
|
|
fuzz_target!(|bytes| {
|
|
|
|
let mut kimage = make_elf_bin(bytes);
|
|
|
|
let mem = GuestMemory::new(&[(GuestAddress(0), MEM_SIZE)]).unwrap();
|
|
|
|
let _ = kernel_loader::load_kernel(&mem, GuestAddress(0), &mut kimage);
|
|
|
|
});
|