This supports both 0.11 and 0.13 versions of the debug spec. Support for `-rtos riscv` will come in a separate commit since it was easy to separate out, and is likely to be more controversial. Flash support for the SiFive boards will also come in a later commit. Change-Id: I1d38fe669c2041b4e21a5c54a091594aac3e2190 Signed-off-by: Tim Newsome <tim@sifive.com> Reviewed-on: http://openocd.zylin.com/4578 Tested-by: jenkins Reviewed-by: Liviu Ionescu <ilg@livius.net> Reviewed-by: Matthias Welwarsky <matthias@welwarsky.de>
39 lines
1015 B
C
39 lines
1015 B
C
#ifndef TARGET__RISCV__ASM_H
|
|
#define TARGET__RISCV__ASM_H
|
|
|
|
#include "riscv.h"
|
|
|
|
/*** Version-independent functions that we don't want in the main address space. ***/
|
|
|
|
static uint32_t load(const struct target *target, unsigned int rd,
|
|
unsigned int base, uint16_t offset) __attribute__ ((unused));
|
|
static uint32_t load(const struct target *target, unsigned int rd,
|
|
unsigned int base, uint16_t offset)
|
|
{
|
|
switch (riscv_xlen(target)) {
|
|
case 32:
|
|
return lw(rd, base, offset);
|
|
case 64:
|
|
return ld(rd, base, offset);
|
|
}
|
|
assert(0);
|
|
return 0; /* Silence -Werror=return-type */
|
|
}
|
|
|
|
static uint32_t store(const struct target *target, unsigned int src,
|
|
unsigned int base, uint16_t offset) __attribute__ ((unused));
|
|
static uint32_t store(const struct target *target, unsigned int src,
|
|
unsigned int base, uint16_t offset)
|
|
{
|
|
switch (riscv_xlen(target)) {
|
|
case 32:
|
|
return sw(src, base, offset);
|
|
case 64:
|
|
return sd(src, base, offset);
|
|
}
|
|
assert(0);
|
|
return 0; /* Silence -Werror=return-type */
|
|
}
|
|
|
|
#endif
|