
* libafl_qemu: fix systemmode with slirp dependency libslirp will be dropped from future QEMU releases (see https://wiki.qemu.org/ChangeLog/7.0). This change adds the "slirp" feature, which links with the host-systems libslirp. * libafl_qemu: enable systemmode snapshots, vm_start Re-enable snapshot functions. Start the VM before qemu_main_loop. * libafl_qemu: allow synchronous snapshotting Add a flag to take snapshots synchronosly. This should be used to take or load snapshots while the emulator is not running. * libafl_qemu: fallback cpu for read-/write_mem In systemmode, current_cpu may not be set. In such cases use the first cpus memory access methods. * fuzzers: add example for libafl_qemu in systemmode * libafl_qemu: update libafl-qemu-bridge revision * libafl_qemu: add memory access by physcial address * fix liabfl_qemu example Use GuestAddr and physical memory access * ci: install libslirp-dev for libafl_qemu * fuzzers/qemu_systemmode: clean up example * libafl_qemu: remove obsolete functions emu::libafl_cpu_thread_fn emu::libafl_start_vcpu emu::start * fuzzers/qemu_systemmode: simplify example * improve build_linux.rs * Update qemu_systemmode fuzzer * upd * clippy Co-authored-by: Alwin Berger <alwin.berger@tu-dortmund.de> Co-authored-by: Andrea Fioraldi <andreafioraldi@gmail.com>
144 lines
3.8 KiB
Plaintext
144 lines
3.8 KiB
Plaintext
/*
|
|
* FreeRTOS V202112.00
|
|
* Copyright (C) 2020 Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
* this software and associated documentation files (the "Software"), to deal in
|
|
* the Software without restriction, including without limitation the rights to
|
|
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
|
* the Software, and to permit persons to whom the Software is furnished to do so,
|
|
* subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in all
|
|
* copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
|
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
|
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
|
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*
|
|
* https://www.FreeRTOS.org
|
|
* https://github.com/FreeRTOS
|
|
*
|
|
*/
|
|
|
|
MEMORY
|
|
{
|
|
RAM (xrw) : ORIGIN = 0x00000000, LENGTH = 4M
|
|
/* Originally */
|
|
/* FLASH (xr) : ORIGIN = 0x00000000, LENGTH = 4M */
|
|
/* RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 4M */
|
|
}
|
|
ENTRY(Reset_Handler)
|
|
|
|
_Min_Heap_Size = 0x300000 ; /* Required amount of heap. */
|
|
_Min_Stack_Size = 0x4000 ; /* Required amount of stack. */
|
|
M_VECTOR_RAM_SIZE = (16 + 48) * 4;
|
|
_estack = ORIGIN(RAM) + LENGTH(RAM);
|
|
|
|
SECTIONS
|
|
{
|
|
|
|
.isr_vector :
|
|
{
|
|
__vector_table = .;
|
|
KEEP(*(.isr_vector))
|
|
. = ALIGN(4);
|
|
} > RAM /* FLASH */
|
|
|
|
.text :
|
|
{
|
|
. = ALIGN(4);
|
|
*(.text*)
|
|
KEEP (*(.init))
|
|
KEEP (*(.fini))
|
|
KEEP(*(.eh_frame))
|
|
*(.rodata*)
|
|
. = ALIGN(4);
|
|
_etext = .;
|
|
} > RAM /* FLASH */
|
|
|
|
.ARM.extab :
|
|
{
|
|
. = ALIGN(4);
|
|
*(.ARM.extab* .gnu.linkonce.armextab.*)
|
|
. = ALIGN(4);
|
|
} >RAM /* FLASH */
|
|
|
|
.ARM :
|
|
{
|
|
. = ALIGN(4);
|
|
__exidx_start = .;
|
|
*(.ARM.exidx* .gnu.linkonce.armexidx.*)
|
|
__exidx_end = .;
|
|
. = ALIGN(4);
|
|
} >RAM /* FLASH */
|
|
|
|
.interrupts_ram :
|
|
{
|
|
. = ALIGN(4);
|
|
__VECTOR_RAM__ = .;
|
|
__interrupts_ram_start__ = .;
|
|
. += M_VECTOR_RAM_SIZE;
|
|
. = ALIGN(4);
|
|
__interrupts_ram_end = .;
|
|
} > RAM
|
|
|
|
_sidata = LOADADDR(.data);
|
|
|
|
.data : /* AT ( _sidata ) */
|
|
{
|
|
. = ALIGN(4);
|
|
_sdata = .;
|
|
*(.data*)
|
|
. = ALIGN(4);
|
|
_edata = .;
|
|
} > RAM /* RAM AT > FLASH */
|
|
|
|
.uninitialized (NOLOAD):
|
|
{
|
|
. = ALIGN(32);
|
|
__uninitialized_start = .;
|
|
*(.uninitialized)
|
|
KEEP(*(.keep.uninitialized))
|
|
. = ALIGN(32);
|
|
__uninitialized_end = .;
|
|
} > RAM
|
|
|
|
.bss :
|
|
{
|
|
. = ALIGN(4);
|
|
_sbss = .;
|
|
__bss_start__ = _sbss;
|
|
*(.bss*)
|
|
*(COMMON)
|
|
. = ALIGN(4);
|
|
_ebss = .;
|
|
__bss_end__ = _ebss;
|
|
} >RAM
|
|
|
|
.heap :
|
|
{
|
|
. = ALIGN(8);
|
|
PROVIDE ( end = . );
|
|
PROVIDE ( _end = . );
|
|
_heap_bottom = .;
|
|
. = . + _Min_Heap_Size;
|
|
_heap_top = .;
|
|
. = . + _Min_Stack_Size;
|
|
. = ALIGN(8);
|
|
} >RAM
|
|
|
|
/* Set stack top to end of RAM, and stack limit move down by
|
|
* size of stack_dummy section */
|
|
__StackTop = ORIGIN(RAM) + LENGTH(RAM);
|
|
__StackLimit = __StackTop - _Min_Stack_Size;
|
|
PROVIDE(__stack = __StackTop);
|
|
|
|
/* Check if data + heap + stack exceeds RAM limit */
|
|
ASSERT(__StackLimit >= _heap_top, "region RAM overflowed with stack")
|
|
}
|
|
|