Skip to content

Commit

Permalink
Always add sentinel to capability list before passing it to C
Browse files Browse the repository at this point in the history
  • Loading branch information
Sympatron committed Sep 28, 2024
1 parent bcfb301 commit aae2afa
Showing 1 changed file with 15 additions and 6 deletions.
21 changes: 15 additions & 6 deletions libosdp/src/pdinfo.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@

use alloc::ffi::CString;

use crate::{Channel, OsdpError, OsdpFlag, PdCapability, PdId};
use crate::{Box, Channel, OsdpError, OsdpFlag, PdCapability, PdId};

/// OSDP PD Information. This struct is used to describe a PD to LibOSDP
#[derive(Debug, Default)]
Expand Down Expand Up @@ -253,18 +253,27 @@ impl PdInfo {
let scbk = if let Some(key) = self.scbk {
Box::into_raw(Box::new(key)) as *mut _
} else {
std::ptr::null_mut::<u8>()
core::ptr::null_mut::<u8>()
};
let cap = if !self.cap.is_empty() {
let mut cap = self.cap.clone();
cap.reserve(1);
cap.push(libosdp_sys::osdp_pd_cap {
function_code: -1i8 as u8,
compliance_level: 0,
num_items: 0,
});
Box::into_raw(cap.into_boxed_slice()) as *mut _
} else {
core::ptr::null_mut::<libosdp_sys::osdp_pd_cap>()
};
let mut cap = self.cap.clone();
let cap_ptr = cap.as_mut_ptr();
core::mem::forget(cap);
libosdp_sys::osdp_pd_info_t {
name: self.name.clone().into_raw(),
baud_rate: self.baud_rate,
address: self.address,
flags: self.flags.bits() as i32,
id: self.id.into(),
cap: cap_ptr,
cap: cap as *mut _,
channel: self.channel.take().unwrap().into(),
scbk,
}
Expand Down

0 comments on commit aae2afa

Please sign in to comment.