From: Martin Ling Date: Fri, 26 Apr 2013 20:17:36 +0000 (+0100) Subject: hex: fix for big-endian architectures. X-Git-Tag: dsupstream~53 X-Git-Url: https://sigrok.org/gitaction?a=commitdiff_plain;h=9275d232089be359ad6ffe3a7b65d6230ff912b3;p=libsigrok.git hex: fix for big-endian architectures. --- diff --git a/output/text/hex.c b/output/text/hex.c index f1529860..c5d12708 100644 --- a/output/text/hex.c +++ b/output/text/hex.c @@ -46,7 +46,7 @@ SR_PRIV int data_hex(struct sr_output *o, const uint8_t *data_in, struct context *ctx; unsigned int outsize, offset, p; int max_linelen; - uint64_t sample; + const uint8_t *sample; uint8_t *outbuf; 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; for (offset = 0; offset <= length_in - 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++) { ctx->linevalues[p] <<= 1; - if (sample & ((uint64_t) 1 << p)) + if (sample[p / 8] & ((uint8_t) 1 << (p % 8))) ctx->linevalues[p] |= 1; sprintf((char *)ctx->linebuf + (p * ctx->linebuf_len) + ctx->line_offset, "%.2x", ctx->linevalues[p]);