Add explicit disable/enable function and skip enable in configure

This commit is contained in:
Ulf Lilleengen 2024-09-06 09:58:54 +02:00
parent 5e74434cb8
commit e2e3143c2e

View File

@ -95,6 +95,8 @@ impl<'a> Control<'a> {
/// ///
/// NOTE: This will disconnect the modem from any current APN and should not /// NOTE: This will disconnect the modem from any current APN and should not
/// be called if the configuration has not been changed. /// be called if the configuration has not been changed.
///
/// After configuring, invoke [`enable()`] to activate the configuration.
pub async fn configure(&self, config: &Config<'_>) -> Result<(), Error> { pub async fn configure(&self, config: &Config<'_>) -> Result<(), Error> {
let mut cmd: [u8; 256] = [0; 256]; let mut cmd: [u8; 256] = [0; 256];
let mut buf: [u8; 256] = [0; 256]; let mut buf: [u8; 256] = [0; 256];
@ -131,22 +133,6 @@ impl<'a> Control<'a> {
// info!("RES2: {}", unsafe { core::str::from_utf8_unchecked(&buf[..n]) }); // info!("RES2: {}", unsafe { core::str::from_utf8_unchecked(&buf[..n]) });
CommandParser::parse(&buf[..n]).expect_identifier(b"OK").finish()?; CommandParser::parse(&buf[..n]).expect_identifier(b"OK").finish()?;
let op = CommandBuilder::create_set(&mut cmd, true)
.named("+CFUN")
.with_int_parameter(1)
.finish()
.map_err(|_| Error::BufferTooSmall)?;
let n = self.control.at_command(op, &mut buf).await;
CommandParser::parse(&buf[..n]).expect_identifier(b"OK").finish()?;
let op = CommandBuilder::create_set(&mut cmd, true)
.named("%XPDNCFG")
.with_int_parameter(1)
.finish()
.map_err(|_| Error::BufferTooSmall)?;
let n = self.control.at_command(op, &mut buf).await;
CommandParser::parse(&buf[..n]).expect_identifier(b"OK").finish()?;
Ok(()) Ok(())
} }
@ -301,20 +287,49 @@ impl<'a> Control<'a> {
Ok(status) Ok(status)
} }
/// Run a control loop for this context, ensuring that reaattach is handled. /// Disable modem
pub async fn run<F: Fn(&Status)>(&self, reattach: F) -> Result<(), Error> { pub async fn disable(&self) -> Result<(), Error> {
let mut cmd: [u8; 256] = [0; 256];
let mut buf: [u8; 256] = [0; 256];
let op = CommandBuilder::create_set(&mut cmd, true)
.named("+CFUN")
.with_int_parameter(0)
.finish()
.map_err(|_| Error::BufferTooSmall)?;
let n = self.control.at_command(op, &mut buf).await;
CommandParser::parse(&buf[..n]).expect_identifier(b"OK").finish()?;
Ok(())
}
/// Enable modem
pub async fn enable(&self) -> Result<(), Error> {
let mut cmd: [u8; 256] = [0; 256]; let mut cmd: [u8; 256] = [0; 256];
let mut buf: [u8; 256] = [0; 256]; let mut buf: [u8; 256] = [0; 256];
// Make sure modem is enabled
let op = CommandBuilder::create_set(&mut cmd, true) let op = CommandBuilder::create_set(&mut cmd, true)
.named("+CFUN") .named("+CFUN")
.with_int_parameter(1) .with_int_parameter(1)
.finish() .finish()
.map_err(|_| Error::BufferTooSmall)?; .map_err(|_| Error::BufferTooSmall)?;
let n = self.control.at_command(op, &mut buf).await; let n = self.control.at_command(op, &mut buf).await;
CommandParser::parse(&buf[..n]).expect_identifier(b"OK").finish()?; CommandParser::parse(&buf[..n]).expect_identifier(b"OK").finish()?;
// Make modem survive PDN detaches
let op = CommandBuilder::create_set(&mut cmd, true)
.named("%XPDNCFG")
.with_int_parameter(1)
.finish()
.map_err(|_| Error::BufferTooSmall)?;
let n = self.control.at_command(op, &mut buf).await;
CommandParser::parse(&buf[..n]).expect_identifier(b"OK").finish()?;
Ok(())
}
/// Run a control loop for this context, ensuring that reaattach is handled.
pub async fn run<F: Fn(&Status)>(&self, reattach: F) -> Result<(), Error> {
self.enable().await?;
let status = self.wait_attached().await?; let status = self.wait_attached().await?;
let mut fd = self.control.open_raw_socket().await; let mut fd = self.control.open_raw_socket().await;
reattach(&status); reattach(&status);