radare2/libr/reg/double.c
Damien Zammit af0a865d9f WIP - Totally remove host endianness dependence
- Adds endian aware functions
- Removes references to host endian
- Uses binary detected endianness else tries LE and restricts by RAsmPlugin
- Fixes gdb debugger endianness when debugging BE qemu gdbserver

Signed-off-by: Damien Zammit <damien@zamaudio.com>
2016-05-04 23:42:17 +10:00

121 lines
2.8 KiB
C

/* radare - LGPL - Copyright 2015 - pancake */
#include <r_reg.h>
#include <r_util.h>
// TODO: add support for 80bit floating point value
// long double = 128 bit
R_API double r_reg_get_double(RReg *reg, RRegItem *item) {
RRegSet *regset;
double vld = 0.0f;
int off;
double ret = 0.0f;
if (!reg || !item)
return 0LL;
off = BITS2BYTES (item->offset);
regset = &reg->regset[item->type];
switch (item->size) {
case 64:
if (regset->arena->size - off - 1 >= 0) {
memcpy (&vld, regset->arena->bytes + off, sizeof (double));
ret = vld;
}
break;
default:
eprintf ("r_reg_set_double: Bit size %d not supported\n", item->size);
return 0.0f;
}
return ret;
}
R_API bool r_reg_set_double(RReg *reg, RRegItem *item, double value) {
ut8 *src;
if (!item) {
eprintf ("r_reg_set_value: item is NULL\n");
return false;
}
switch (item->size) {
case 64:
// FIXME: endian
src = (ut8 *)&value;
break;
default:
eprintf ("r_reg_set_double: Bit size %d not supported\n", item->size);
return false;
}
if (reg->regset[item->type].arena->size - BITS2BYTES (item->offset) - BITS2BYTES (item->size) >= 0) {
r_mem_copybits (reg->regset[item->type].arena->bytes +
BITS2BYTES (item->offset),
src, item->size);
return true;
}
eprintf ("r_reg_set_value: Cannot set %s to %lf\n", item->name, value);
return false;
}
// long double = 80 bit
R_API long double r_reg_get_longdouble(RReg *reg, RRegItem *item) {
RRegSet *regset;
long double vld = 0.0f;
int off;
long double ret = 0.0f;
if (!reg || !item)
return 0LL;
off = BITS2BYTES (item->offset);
regset = &reg->regset[item->type];
switch (item->size) {
case 80:
case 96:
case 128:
if (regset->arena->size - off - 1 >= 0) {
memcpy (&vld, regset->arena->bytes + off, sizeof (long double));
ret = vld;
}
break;
default:
eprintf ("r_reg_get_longdouble: Bit size %d not supported\n", item->size);
return 0.0f;
}
return ret;
}
R_API bool r_reg_set_longdouble(RReg *reg, RRegItem *item, long double value) {
ut8 *src;
if (!item) {
eprintf ("r_reg_set_value: item is NULL\n");
return false;
}
switch (item->size) {
case 80:
case 96:
case 128:
// FIXME: endian
src = (ut8 *)&value;
break;
default:
eprintf ("r_reg_set_longdouble: Bit size %d not supported\n", item->size);
return false;
}
if (reg->regset[item->type].arena->size - BITS2BYTES (item->offset) - BITS2BYTES (item->size) >= 0) {
r_mem_copybits (reg->regset[item->type].arena->bytes +
BITS2BYTES (item->offset),
src, item->size);
return true;
}
eprintf ("r_reg_set_value: Cannot set %s to %Lf\n", item->name, value);
return false;
}
/* floating point . deprecate maybe? */
R_API float r_reg_get_float(RReg *reg, RRegItem *item) {
// TODO
return 0.0f;
}
R_API bool r_reg_set_float(RReg *reg, RRegItem *item, float value) {
return false;
}