e101a78be9
* cpustate.c: Remove spurious spaces from TRACE strings. Print hex equivalents of floats and doubles. Check element number against array size when accessing vector registers. * memory.c: Trace memory reads when --trace-memory is enabled. Remove float and double load and store functions. * memory.h (aarch64_get_mem_float): Delete prototype. (aarch64_get_mem_double): Likewise. (aarch64_set_mem_float): Likewise. (aarch64_set_mem_double): Likewise. * simulator (IS_SET): Always return either 0 or 1. (IS_CLEAR): Likewise. (fldrs_pcrel): Load and store floats using 32-bit memory accesses and doubles using 64-bit memory accesses. (fldrd_pcrel, fldrs_wb, fldrs_abs, fldrs_scale_ext): Likewise. (fldrd_wb, fldrd_abs, fsturs, fsturd, fldurs, fldurd): Likewise. (fstrs_abs, fstrs_wb, fstrs_scale_ext, fstrd_abs): Likewise. (fstrd_wb, fstrd_scale_ext, store_pair_float): Likewise. (store_pair_double, load_pair_float, load_pair_double): Likewise. (do_vec_MUL_by_element): New function. (do_vec_op2): Call do_vec_MUL_by_element. (do_scalar_NEG): New function. (do_double_add): Call do_scalar_NEG.
59 lines
2.5 KiB
C
59 lines
2.5 KiB
C
/* memory.h -- Prototypes for AArch64 memory accessor functions.
|
|
|
|
Copyright (C) 2015-2016 Free Software Foundation, Inc.
|
|
|
|
Contributed by Red Hat.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef _MEMORY_H
|
|
#define _MEMORY_H
|
|
|
|
#include <sys/types.h>
|
|
#include "bfd.h"
|
|
#include "simulator.h"
|
|
|
|
extern void aarch64_get_mem_long_double (sim_cpu *, uint64_t, FRegister *);
|
|
extern uint64_t aarch64_get_mem_u64 (sim_cpu *, uint64_t);
|
|
extern int64_t aarch64_get_mem_s64 (sim_cpu *, uint64_t);
|
|
extern uint32_t aarch64_get_mem_u32 (sim_cpu *, uint64_t);
|
|
extern int32_t aarch64_get_mem_s32 (sim_cpu *, uint64_t);
|
|
extern uint32_t aarch64_get_mem_u16 (sim_cpu *, uint64_t);
|
|
extern int32_t aarch64_get_mem_s16 (sim_cpu *, uint64_t);
|
|
extern uint32_t aarch64_get_mem_u8 (sim_cpu *, uint64_t);
|
|
extern int32_t aarch64_get_mem_s8 (sim_cpu *, uint64_t);
|
|
extern void aarch64_get_mem_blk (sim_cpu *, uint64_t, char *, unsigned);
|
|
extern const char * aarch64_get_mem_ptr (sim_cpu *, uint64_t);
|
|
|
|
extern void aarch64_set_mem_long_double (sim_cpu *, uint64_t, FRegister);
|
|
extern void aarch64_set_mem_u64 (sim_cpu *, uint64_t, uint64_t);
|
|
extern void aarch64_set_mem_s64 (sim_cpu *, uint64_t, int64_t);
|
|
extern void aarch64_set_mem_u32 (sim_cpu *, uint64_t, uint32_t);
|
|
extern void aarch64_set_mem_s32 (sim_cpu *, uint64_t, int32_t);
|
|
extern void aarch64_set_mem_u16 (sim_cpu *, uint64_t, uint16_t);
|
|
extern void aarch64_set_mem_s16 (sim_cpu *, uint64_t, int16_t);
|
|
extern void aarch64_set_mem_u8 (sim_cpu *, uint64_t, uint8_t);
|
|
extern void aarch64_set_mem_s8 (sim_cpu *, uint64_t, int8_t);
|
|
|
|
#define STACK_TOP 0x07FFFF00
|
|
|
|
extern uint64_t aarch64_get_heap_start (sim_cpu *);
|
|
extern uint64_t aarch64_get_stack_start (sim_cpu *);
|
|
|
|
extern void mem_add_blk (sim_cpu *, uint64_t, char *, uint64_t, bfd_boolean);
|
|
|
|
#endif /* _MEMORY_H */
|