2012-06-27 23:27:40 +00:00
|
|
|
#include <r_util.h>
|
|
|
|
|
2013-03-01 08:57:30 +00:00
|
|
|
/* dex/dwarf uleb128 implementation */
|
2012-06-27 23:27:40 +00:00
|
|
|
|
2014-02-04 18:59:39 +00:00
|
|
|
R_API const ut8 *r_uleb128 (const ut8 *data, ut64 *v) {
|
2012-06-27 23:27:40 +00:00
|
|
|
ut8 c;
|
2014-05-17 23:26:13 +00:00
|
|
|
ut64 s, sum = 0;
|
2014-05-19 01:40:45 +00:00
|
|
|
if (data) {
|
|
|
|
if (*data) {
|
|
|
|
for (s = 0; ; s += 7) {
|
|
|
|
c = *(data++) & 0xff;
|
|
|
|
sum |= ((ut32) (c&0x7f) << s);
|
|
|
|
if (!(c&0x80)) break;
|
|
|
|
}
|
|
|
|
} else data++;
|
|
|
|
}
|
2012-06-27 23:27:40 +00:00
|
|
|
if (v) *v = sum;
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
2014-02-04 18:59:39 +00:00
|
|
|
R_API const ut8 *r_leb128 (const ut8 *data, st64 *v) {
|
2014-05-19 01:38:19 +00:00
|
|
|
ut8 c = 0;
|
|
|
|
st64 s = 0, sum = 0;
|
|
|
|
if (data) {
|
|
|
|
for (s = 0; *data;) {
|
|
|
|
c = *(data++) & 0x0ff;
|
|
|
|
sum |= ((st64) (c & 0x7f) << s);
|
|
|
|
s += 7;
|
|
|
|
if (!(c & 0x80)) break;
|
|
|
|
}
|
2014-02-04 18:59:39 +00:00
|
|
|
}
|
|
|
|
if ((s < (8 * sizeof (sum))) && (c & 0x40)) {
|
2014-04-28 09:09:48 +00:00
|
|
|
sum |= -((st64)1 << s);
|
2012-06-27 23:27:40 +00:00
|
|
|
}
|
|
|
|
if (v) *v = sum;
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
main() {
|
|
|
|
ut32 n;
|
|
|
|
ut8 *buf = "\x10\x02\x90\x88";
|
|
|
|
r_uleb128 (buf, &n);
|
|
|
|
printf ("n = %d\n", n);
|
|
|
|
}
|
|
|
|
#endif
|