use crate::kiss::{KissBuffer, KissFrame};
+use crate::modem::ModulatorFrame;
use crate::protocol::{Frame, LichCollection, LsfFrame, Mode, PacketFrameCounter};
/// Handles the KISS protocol and frame management for `SoftModulator` and `SoftDemodulator`.
}
/// Process an individual `Frame` that has been decoded by the modem.
- pub fn handle_frame(&mut self, frame: Frame) -> Result<(), SoftTncError> {
+ pub fn handle_frame(&mut self, frame: Frame) {
match frame {
Frame::Lsf(lsf) => {
// A new LSF implies a clean slate.
let end = start + payload_len;
rx.packet[start..(start + payload_len)]
.copy_from_slice(&packet.payload);
+ // TODO: compatible packets should be sent on port 0 too
let kiss =
KissFrame::new_full_packet(&rx.lsf.0, &rx.packet[0..end])
.unwrap();
}
}
}
- Ok(())
}
- /// Update the number of samples that have been received by the incoming stream, as a form of timekeeping
- pub fn advance_samples(&mut self, _samples: u64) {}
-
pub fn set_data_carrier_detect(&mut self, _dcd: bool) {}
+
+ pub fn set_now(&mut self, samples: u64) {}
+
+ pub fn set_tx_end_time(&mut self, in_samples: usize) {
+ // This is a relative time from now, expressed in samples
+ // Use the time from set_now() to decide when to drop PTT
+ }
- pub fn read_tx_frame(&mut self) -> Result<Option<Frame>, SoftTncError> {
- // yes we want to deal with Frames here
+ pub fn read_tx_frame(&mut self) -> Option<ModulatorFrame> {
+ // yes we want to deal with frames here
// it's important to establish successful decode that SoftDemodulator is aware of the frame innards
- Ok(None)
+ None
}
/// Read KISS message to be sent to host.
///
/// After each frame input, this should be consumed in a loop until length 0 is returned.
/// This component will never block. Upstream interface can provide blocking `read()` if desired.
- pub fn read_kiss(&mut self, target_buf: &mut [u8]) -> Result<usize, SoftTncError> {
+ pub fn read_kiss(&mut self, target_buf: &mut [u8]) -> usize {
match self.outgoing_kiss.as_mut() {
Some(outgoing) => {
let n = (outgoing.kiss_frame.len - outgoing.sent).min(target_buf.len());
if outgoing.sent == outgoing.kiss_frame.len {
self.outgoing_kiss = None;
}
- Ok(n)
+ n
}
- None => Ok(0),
+ None => 0,
}
}
- pub fn write_kiss(&mut self, buf: &[u8]) -> Result<usize, SoftTncError> {
+ pub fn write_kiss(&mut self, buf: &[u8]) -> usize {
let target_buf = self.kiss_buffer.buf_remaining();
let n = buf.len().min(target_buf.len());
target_buf[0..n].copy_from_slice(&buf[0..n]);
while let Some(_kiss_frame) = self.kiss_buffer.next_frame() {
// TODO: handle host-to-TNC message
}
- Ok(n)
+ n
}
fn kiss_to_host(&mut self, kiss_frame: KissFrame) {
};
let mut tnc = SoftTnc::new();
let mut kiss = KissFrame::new_empty();
- assert_eq!(tnc.read_kiss(&mut kiss.data), Ok(0));
+ assert_eq!(tnc.read_kiss(&mut kiss.data), 0);
- tnc.handle_frame(Frame::Lsf(lsf)).unwrap();
- kiss.len = tnc.read_kiss(&mut kiss.data).unwrap();
+ tnc.handle_frame(Frame::Lsf(lsf));
+ kiss.len = tnc.read_kiss(&mut kiss.data);
assert_eq!(kiss.command().unwrap(), KissCommand::DataFrame);
assert_eq!(kiss.port().unwrap(), PORT_STREAM);
let n = kiss.decode_payload(&mut payload_buf).unwrap();
assert_eq!(n, 30);
- tnc.handle_frame(Frame::Stream(stream1)).unwrap();
- kiss.len = tnc.read_kiss(&mut kiss.data).unwrap();
+ tnc.handle_frame(Frame::Stream(stream1));
+ kiss.len = tnc.read_kiss(&mut kiss.data);
assert_eq!(kiss.command().unwrap(), KissCommand::DataFrame);
assert_eq!(kiss.port().unwrap(), PORT_STREAM);
let n = kiss.decode_payload(&mut payload_buf).unwrap();
assert_eq!(n, 26);
- tnc.handle_frame(Frame::Stream(stream2)).unwrap();
- kiss.len = tnc.read_kiss(&mut kiss.data).unwrap();
+ tnc.handle_frame(Frame::Stream(stream2));
+ kiss.len = tnc.read_kiss(&mut kiss.data);
assert_eq!(kiss.command().unwrap(), KissCommand::DataFrame);
assert_eq!(kiss.port().unwrap(), PORT_STREAM);
let mut tnc = SoftTnc::new();
let mut kiss = KissFrame::new_empty();
for f in frames {
- tnc.handle_frame(Frame::Stream(f)).unwrap();
+ tnc.handle_frame(Frame::Stream(f));
}
- kiss.len = tnc.read_kiss(&mut kiss.data).unwrap();
+ kiss.len = tnc.read_kiss(&mut kiss.data);
let mut payload_buf = [0u8; 2048];
let n = kiss.decode_payload(&mut payload_buf).unwrap();
assert_eq!(n, 30);
};
let mut tnc = SoftTnc::new();
let mut kiss = KissFrame::new_empty();
- assert_eq!(tnc.read_kiss(&mut kiss.data), Ok(0));
+ assert_eq!(tnc.read_kiss(&mut kiss.data), 0);
- tnc.handle_frame(Frame::Lsf(lsf)).unwrap();
- kiss.len = tnc.read_kiss(&mut kiss.data).unwrap();
+ tnc.handle_frame(Frame::Lsf(lsf));
+ kiss.len = tnc.read_kiss(&mut kiss.data);
assert_eq!(kiss.command().unwrap(), KissCommand::DataFrame);
assert_eq!(kiss.port().unwrap(), PORT_STREAM);
let n = kiss.decode_payload(&mut payload_buf).unwrap();
assert_eq!(n, 30);
- tnc.handle_frame(Frame::Stream(stream1)).unwrap();
- kiss.len = tnc.read_kiss(&mut kiss.data).unwrap();
+ tnc.handle_frame(Frame::Stream(stream1));
+ kiss.len = tnc.read_kiss(&mut kiss.data);
assert_eq!(kiss.command().unwrap(), KissCommand::DataFrame);
assert_eq!(kiss.port().unwrap(), PORT_STREAM);
let n = kiss.decode_payload(&mut payload_buf).unwrap();
assert_eq!(n, 26);
- tnc.handle_frame(Frame::Stream(stream3)).unwrap();
- kiss.len = tnc.read_kiss(&mut kiss.data).unwrap();
+ tnc.handle_frame(Frame::Stream(stream3));
+ kiss.len = tnc.read_kiss(&mut kiss.data);
assert_eq!(kiss.command().unwrap(), KissCommand::DataFrame);
assert_eq!(kiss.port().unwrap(), PORT_STREAM);