hex: fix for big-endian architectures.
This commit is contained in:
parent
542dbd185b
commit
9275d23208
|
@ -46,7 +46,7 @@ SR_PRIV int data_hex(struct sr_output *o, const uint8_t *data_in,
|
||||||
struct context *ctx;
|
struct context *ctx;
|
||||||
unsigned int outsize, offset, p;
|
unsigned int outsize, offset, p;
|
||||||
int max_linelen;
|
int max_linelen;
|
||||||
uint64_t sample;
|
const uint8_t *sample;
|
||||||
uint8_t *outbuf;
|
uint8_t *outbuf;
|
||||||
|
|
||||||
ctx = o->internal;
|
ctx = o->internal;
|
||||||
|
@ -71,10 +71,10 @@ SR_PRIV int data_hex(struct sr_output *o, const uint8_t *data_in,
|
||||||
ctx->line_offset = 0;
|
ctx->line_offset = 0;
|
||||||
for (offset = 0; offset <= length_in - ctx->unitsize;
|
for (offset = 0; offset <= length_in - ctx->unitsize;
|
||||||
offset += ctx->unitsize) {
|
offset += ctx->unitsize) {
|
||||||
memcpy(&sample, data_in + offset, ctx->unitsize);
|
sample = data_in + offset;
|
||||||
for (p = 0; p < ctx->num_enabled_probes; p++) {
|
for (p = 0; p < ctx->num_enabled_probes; p++) {
|
||||||
ctx->linevalues[p] <<= 1;
|
ctx->linevalues[p] <<= 1;
|
||||||
if (sample & ((uint64_t) 1 << p))
|
if (sample[p / 8] & ((uint8_t) 1 << (p % 8)))
|
||||||
ctx->linevalues[p] |= 1;
|
ctx->linevalues[p] |= 1;
|
||||||
sprintf((char *)ctx->linebuf + (p * ctx->linebuf_len) +
|
sprintf((char *)ctx->linebuf + (p * ctx->linebuf_len) +
|
||||||
ctx->line_offset, "%.2x", ctx->linevalues[p]);
|
ctx->line_offset, "%.2x", ctx->linevalues[p]);
|
||||||
|
|
Loading…
Reference in New Issue