X-Git-Url: https://code.octet-stream.net/m17rt/blobdiff_plain/5fe056d1599b4feff228ae0a398e427b2487dc9a..9058451e46e4d36264282abe381aa9b6fd2c773f:/m17core/src/encode.rs?ds=sidebyside diff --git a/m17core/src/encode.rs b/m17core/src/encode.rs index 54f5bc2..4fc7429 100644 --- a/m17core/src/encode.rs +++ b/m17core/src/encode.rs @@ -35,13 +35,36 @@ pub(crate) fn encode_packet(frame: &PacketFrame) -> [f32; 192] { } PacketFrameCounter::FinalFrame { payload_len } => { type1[0..payload_len].copy_from_slice(&frame.payload[0..payload_len]); - type1[25] = (payload_len as u8) << 3 | 0x04; + type1[25] = ((payload_len as u8) << 3) | 0x04; } } let type3 = fec::encode(&type1, 206, p_3); interleave_to_dibits(type3, PACKET_SYNC) } +/// Generate a preamble suitable for placement before an LSF frame. +/// +/// Polarity needs to be flipped for BERT, however we don't support this yet. +/// STREAM and PACKET don't need to be considered as they are an invalid way to +/// begin a transmission. +pub(crate) fn generate_preamble() -> [f32; 192] { + // TODO: should all these encode/generate functions return owning iterators? + // Then I could avoid making this array which I'm just going to have to copy anyway + let mut out = [1.0f32; 192]; + for n in out.iter_mut().skip(1).step_by(2) { + *n = -1.0; + } + out +} + +pub(crate) fn generate_end_of_transmission() -> [f32; 192] { + let mut out = [1.0f32; 192]; + for n in out.iter_mut().skip(6).step_by(8) { + *n = -1.0; + } + out +} + pub(crate) fn encode_lich(counter: u8, part: &[u8; 5]) -> [u8; 12] { let mut out = [0u8; 12]; let to_encode = [