Fix bits to bytes conversion in DMRIdle

pull/14/head
Andy CA6JAU 9 years ago
parent 5c4189f51f
commit f5e065673d

@ -95,16 +95,28 @@ void CDMRIdleRX::bitsToBytes(uint16_t start, uint8_t count, uint8_t* buffer)
{ {
for (uint8_t i = 0U; i < count; i++) { for (uint8_t i = 0U; i < count; i++) {
buffer[i] = 0U; buffer[i] = 0U;
buffer[i] |= ((m_buffer[start + 0U] & 0x01) << 7); buffer[i] |= ((m_buffer[start++] & 0x01) << 7);
buffer[i] |= ((m_buffer[start + 1U] & 0x01) << 6); if (start >= DMR_FRAME_LENGTH_BITS)
buffer[i] |= ((m_buffer[start + 2U] & 0x01) << 5); start -= DMR_FRAME_LENGTH_BITS;
buffer[i] |= ((m_buffer[start + 3U] & 0x01) << 4); buffer[i] |= ((m_buffer[start++] & 0x01) << 6);
buffer[i] |= ((m_buffer[start + 4U] & 0x01) << 3); if (start >= DMR_FRAME_LENGTH_BITS)
buffer[i] |= ((m_buffer[start + 5U] & 0x01) << 2); start -= DMR_FRAME_LENGTH_BITS;
buffer[i] |= ((m_buffer[start + 6U] & 0x01) << 1); buffer[i] |= ((m_buffer[start++] & 0x01) << 5);
buffer[i] |= ((m_buffer[start + 7U] & 0x01) << 0); if (start >= DMR_FRAME_LENGTH_BITS)
start -= DMR_FRAME_LENGTH_BITS;
start += 8U; buffer[i] |= ((m_buffer[start++] & 0x01) << 4);
if (start >= DMR_FRAME_LENGTH_BITS)
start -= DMR_FRAME_LENGTH_BITS;
buffer[i] |= ((m_buffer[start++] & 0x01) << 3);
if (start >= DMR_FRAME_LENGTH_BITS)
start -= DMR_FRAME_LENGTH_BITS;
buffer[i] |= ((m_buffer[start++] & 0x01) << 2);
if (start >= DMR_FRAME_LENGTH_BITS)
start -= DMR_FRAME_LENGTH_BITS;
buffer[i] |= ((m_buffer[start++] & 0x01) << 1);
if (start >= DMR_FRAME_LENGTH_BITS)
start -= DMR_FRAME_LENGTH_BITS;
buffer[i] |= ((m_buffer[start++] & 0x01) << 0);
if (start >= DMR_FRAME_LENGTH_BITS) if (start >= DMR_FRAME_LENGTH_BITS)
start -= DMR_FRAME_LENGTH_BITS; start -= DMR_FRAME_LENGTH_BITS;
} }

Loading…
Cancel
Save

Powered by TurnKey Linux.