forked from mirrors/gstreamer-rs
video: Don't store a copy of the VideoInfo
in VideoFrame
Instead just reference the one inside the FFI struct directly by making sure that the memory representation of the FFI and Rust type are the same. This reduces the size of `VideoFrame` by about half. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer-rs/-/merge_requests/1244>
This commit is contained in:
parent
ca9d822042
commit
e584fdb17b
2 changed files with 21 additions and 39 deletions
|
@ -10,7 +10,6 @@ pub enum Writable {}
|
||||||
pub struct VideoFrame<T> {
|
pub struct VideoFrame<T> {
|
||||||
frame: ffi::GstVideoFrame,
|
frame: ffi::GstVideoFrame,
|
||||||
buffer: gst::Buffer,
|
buffer: gst::Buffer,
|
||||||
info: crate::VideoInfo,
|
|
||||||
phantom: PhantomData<T>,
|
phantom: PhantomData<T>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,10 +19,10 @@ unsafe impl<T> Sync for VideoFrame<T> {}
|
||||||
impl<T> fmt::Debug for VideoFrame<T> {
|
impl<T> fmt::Debug for VideoFrame<T> {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
f.debug_struct("VideoFrame")
|
f.debug_struct("VideoFrame")
|
||||||
.field("frame", &self.frame)
|
.field("flags", &self.flags())
|
||||||
.field("buffer", &self.buffer)
|
.field("id", &self.id())
|
||||||
.field("info", &self.info)
|
.field("buffer", &self.buffer())
|
||||||
.field("phantom", &self.phantom)
|
.field("info", &self.info())
|
||||||
.finish()
|
.finish()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -31,7 +30,7 @@ impl<T> fmt::Debug for VideoFrame<T> {
|
||||||
impl<T> VideoFrame<T> {
|
impl<T> VideoFrame<T> {
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn info(&self) -> &crate::VideoInfo {
|
pub fn info(&self) -> &crate::VideoInfo {
|
||||||
&self.info
|
unsafe { &*(&self.frame.info as *const ffi::GstVideoInfo as *const crate::VideoInfo) }
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -254,12 +253,10 @@ impl<T> VideoFrame<T> {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub unsafe fn from_glib_full(frame: ffi::GstVideoFrame) -> Self {
|
pub unsafe fn from_glib_full(frame: ffi::GstVideoFrame) -> Self {
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
let buffer = gst::Buffer::from_glib_none(frame.buffer);
|
let buffer = gst::Buffer::from_glib_none(frame.buffer);
|
||||||
Self {
|
Self {
|
||||||
frame,
|
frame,
|
||||||
buffer,
|
buffer,
|
||||||
info,
|
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -267,10 +264,8 @@ impl<T> VideoFrame<T> {
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn as_video_frame_ref(&self) -> VideoFrameRef<&gst::BufferRef> {
|
pub fn as_video_frame_ref(&self) -> VideoFrameRef<&gst::BufferRef> {
|
||||||
let frame = unsafe { ptr::read(&self.frame) };
|
let frame = unsafe { ptr::read(&self.frame) };
|
||||||
let info = self.info.clone();
|
|
||||||
VideoFrameRef {
|
VideoFrameRef {
|
||||||
frame,
|
frame,
|
||||||
info,
|
|
||||||
unmap: false,
|
unmap: false,
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
}
|
}
|
||||||
|
@ -323,11 +318,9 @@ impl VideoFrame<Readable> {
|
||||||
Err(buffer)
|
Err(buffer)
|
||||||
} else {
|
} else {
|
||||||
let frame = frame.assume_init();
|
let frame = frame.assume_init();
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
frame,
|
frame,
|
||||||
buffer,
|
buffer,
|
||||||
info,
|
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -358,11 +351,9 @@ impl VideoFrame<Readable> {
|
||||||
Err(buffer)
|
Err(buffer)
|
||||||
} else {
|
} else {
|
||||||
let frame = frame.assume_init();
|
let frame = frame.assume_init();
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
frame,
|
frame,
|
||||||
buffer,
|
buffer,
|
||||||
info,
|
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -400,11 +391,9 @@ impl VideoFrame<Writable> {
|
||||||
Err(buffer)
|
Err(buffer)
|
||||||
} else {
|
} else {
|
||||||
let frame = frame.assume_init();
|
let frame = frame.assume_init();
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
frame,
|
frame,
|
||||||
buffer,
|
buffer,
|
||||||
info,
|
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -437,11 +426,9 @@ impl VideoFrame<Writable> {
|
||||||
Err(buffer)
|
Err(buffer)
|
||||||
} else {
|
} else {
|
||||||
let frame = frame.assume_init();
|
let frame = frame.assume_init();
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
frame,
|
frame,
|
||||||
buffer,
|
buffer,
|
||||||
info,
|
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -497,10 +484,8 @@ impl VideoFrame<Writable> {
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn as_mut_video_frame_ref(&mut self) -> VideoFrameRef<&mut gst::BufferRef> {
|
pub fn as_mut_video_frame_ref(&mut self) -> VideoFrameRef<&mut gst::BufferRef> {
|
||||||
let frame = unsafe { ptr::read(&self.frame) };
|
let frame = unsafe { ptr::read(&self.frame) };
|
||||||
let info = self.info.clone();
|
|
||||||
VideoFrameRef {
|
VideoFrameRef {
|
||||||
frame,
|
frame,
|
||||||
info,
|
|
||||||
unmap: false,
|
unmap: false,
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
}
|
}
|
||||||
|
@ -512,18 +497,29 @@ impl VideoFrame<Writable> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug)]
|
|
||||||
pub struct VideoFrameRef<T> {
|
pub struct VideoFrameRef<T> {
|
||||||
frame: ffi::GstVideoFrame,
|
frame: ffi::GstVideoFrame,
|
||||||
info: crate::VideoInfo,
|
|
||||||
unmap: bool,
|
unmap: bool,
|
||||||
phantom: PhantomData<T>,
|
phantom: PhantomData<T>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<T> fmt::Debug for VideoFrameRef<T> {
|
||||||
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
f.debug_struct("VideoFrameRef")
|
||||||
|
.field("flags", &self.flags())
|
||||||
|
.field("id", &self.id())
|
||||||
|
.field("buffer", &unsafe {
|
||||||
|
gst::BufferRef::from_ptr(self.frame.buffer)
|
||||||
|
})
|
||||||
|
.field("info", &self.info())
|
||||||
|
.finish()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl<T> VideoFrameRef<T> {
|
impl<T> VideoFrameRef<T> {
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn info(&self) -> &crate::VideoInfo {
|
pub fn info(&self) -> &crate::VideoInfo {
|
||||||
&self.info
|
unsafe { &*(&self.frame.info as *const ffi::GstVideoInfo as *const crate::VideoInfo) }
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -743,10 +739,8 @@ impl<'a> VideoFrameRef<&'a gst::BufferRef> {
|
||||||
debug_assert!(!frame.is_null());
|
debug_assert!(!frame.is_null());
|
||||||
|
|
||||||
let frame = ptr::read(frame);
|
let frame = ptr::read(frame);
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Borrowed::new(Self {
|
Borrowed::new(Self {
|
||||||
frame,
|
frame,
|
||||||
info,
|
|
||||||
unmap: false,
|
unmap: false,
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
})
|
})
|
||||||
|
@ -754,10 +748,8 @@ impl<'a> VideoFrameRef<&'a gst::BufferRef> {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub unsafe fn from_glib_full(frame: ffi::GstVideoFrame) -> Self {
|
pub unsafe fn from_glib_full(frame: ffi::GstVideoFrame) -> Self {
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Self {
|
Self {
|
||||||
frame,
|
frame,
|
||||||
info,
|
|
||||||
unmap: true,
|
unmap: true,
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
}
|
}
|
||||||
|
@ -785,10 +777,8 @@ impl<'a> VideoFrameRef<&'a gst::BufferRef> {
|
||||||
Err(glib::bool_error!("Failed to map VideoFrame"))
|
Err(glib::bool_error!("Failed to map VideoFrame"))
|
||||||
} else {
|
} else {
|
||||||
let frame = frame.assume_init();
|
let frame = frame.assume_init();
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
frame,
|
frame,
|
||||||
info,
|
|
||||||
unmap: true,
|
unmap: true,
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
})
|
})
|
||||||
|
@ -820,10 +810,8 @@ impl<'a> VideoFrameRef<&'a gst::BufferRef> {
|
||||||
Err(glib::bool_error!("Failed to map VideoFrame"))
|
Err(glib::bool_error!("Failed to map VideoFrame"))
|
||||||
} else {
|
} else {
|
||||||
let frame = frame.assume_init();
|
let frame = frame.assume_init();
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
frame,
|
frame,
|
||||||
info,
|
|
||||||
unmap: true,
|
unmap: true,
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
})
|
})
|
||||||
|
@ -843,10 +831,8 @@ impl<'a> VideoFrameRef<&'a mut gst::BufferRef> {
|
||||||
debug_assert!(!frame.is_null());
|
debug_assert!(!frame.is_null());
|
||||||
|
|
||||||
let frame = ptr::read(frame);
|
let frame = ptr::read(frame);
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Self {
|
Self {
|
||||||
frame,
|
frame,
|
||||||
info,
|
|
||||||
unmap: false,
|
unmap: false,
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
}
|
}
|
||||||
|
@ -854,10 +840,8 @@ impl<'a> VideoFrameRef<&'a mut gst::BufferRef> {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub unsafe fn from_glib_full_mut(frame: ffi::GstVideoFrame) -> Self {
|
pub unsafe fn from_glib_full_mut(frame: ffi::GstVideoFrame) -> Self {
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Self {
|
Self {
|
||||||
frame,
|
frame,
|
||||||
info,
|
|
||||||
unmap: true,
|
unmap: true,
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
}
|
}
|
||||||
|
@ -887,10 +871,8 @@ impl<'a> VideoFrameRef<&'a mut gst::BufferRef> {
|
||||||
Err(glib::bool_error!("Failed to map VideoFrame"))
|
Err(glib::bool_error!("Failed to map VideoFrame"))
|
||||||
} else {
|
} else {
|
||||||
let frame = frame.assume_init();
|
let frame = frame.assume_init();
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
frame,
|
frame,
|
||||||
info,
|
|
||||||
unmap: true,
|
unmap: true,
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
})
|
})
|
||||||
|
@ -924,10 +906,8 @@ impl<'a> VideoFrameRef<&'a mut gst::BufferRef> {
|
||||||
Err(glib::bool_error!("Failed to map VideoFrame"))
|
Err(glib::bool_error!("Failed to map VideoFrame"))
|
||||||
} else {
|
} else {
|
||||||
let frame = frame.assume_init();
|
let frame = frame.assume_init();
|
||||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
frame,
|
frame,
|
||||||
info,
|
|
||||||
unmap: true,
|
unmap: true,
|
||||||
phantom: PhantomData,
|
phantom: PhantomData,
|
||||||
})
|
})
|
||||||
|
|
|
@ -92,6 +92,7 @@ impl From<VideoColorRange> for glib::Value {
|
||||||
|
|
||||||
#[doc(alias = "GstVideoColorimetry")]
|
#[doc(alias = "GstVideoColorimetry")]
|
||||||
#[derive(Copy, Clone)]
|
#[derive(Copy, Clone)]
|
||||||
|
#[repr(transparent)]
|
||||||
pub struct VideoColorimetry(ffi::GstVideoColorimetry);
|
pub struct VideoColorimetry(ffi::GstVideoColorimetry);
|
||||||
|
|
||||||
impl VideoColorimetry {
|
impl VideoColorimetry {
|
||||||
|
@ -267,6 +268,7 @@ impl TryFrom<crate::VideoMultiviewMode> for crate::VideoMultiviewFramePacking {
|
||||||
|
|
||||||
#[doc(alias = "GstVideoInfo")]
|
#[doc(alias = "GstVideoInfo")]
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
|
#[repr(transparent)]
|
||||||
pub struct VideoInfo(pub(crate) ffi::GstVideoInfo);
|
pub struct VideoInfo(pub(crate) ffi::GstVideoInfo);
|
||||||
|
|
||||||
impl fmt::Debug for VideoInfo {
|
impl fmt::Debug for VideoInfo {
|
||||||
|
|
Loading…
Reference in a new issue