From: Martin Ling Date: Fri, 26 Apr 2013 20:14:00 +0000 (+0100) Subject: bits: fix for big-endian architectures. X-Git-Tag: dsupstream~54 X-Git-Url: https://sigrok.org/gitaction?a=commitdiff_plain;h=542dbd185b2e01e61df8a70a2ab850f5cfe03271;p=libsigrok.git bits: fix for big-endian architectures. --- diff --git a/output/text/bits.c b/output/text/bits.c index af53e49f..3b75e5f3 100644 --- a/output/text/bits.c +++ b/output/text/bits.c @@ -46,7 +46,7 @@ SR_PRIV int data_bits(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, c; ctx = o->internal; @@ -79,9 +79,9 @@ SR_PRIV int data_bits(struct sr_output *o, const uint8_t *data_in, if (length_in >= ctx->unitsize) { 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++) { - c = (sample & ((uint64_t) 1 << p)) ? '1' : '0'; + c = (sample[p / 8] & ((uint8_t) 1 << (p % 8))) ? '1' : '0'; ctx->linebuf[p * ctx->linebuf_len + ctx->line_offset] = c; }