forked from mirrors/gstreamer-rs
gstreamer/buffer: Only unmap memory in buffer cursor seek impl if we have to move to a different memory
Prevents some unnecessary unmaps.
This commit is contained in:
parent
35f7c910a9
commit
2fbb10ec92
1 changed files with 8 additions and 7 deletions
|
@ -48,13 +48,6 @@ pub struct BufferRefCursor<T> {
|
||||||
macro_rules! define_seek_impl(
|
macro_rules! define_seek_impl(
|
||||||
($get_buffer_ref:expr) => {
|
($get_buffer_ref:expr) => {
|
||||||
fn seek(&mut self, pos: io::SeekFrom) -> Result<u64, io::Error> {
|
fn seek(&mut self, pos: io::SeekFrom) -> Result<u64, io::Error> {
|
||||||
if !self.map_info.memory.is_null() {
|
|
||||||
unsafe {
|
|
||||||
gst_sys::gst_memory_unmap(self.map_info.memory, &mut self.map_info);
|
|
||||||
self.map_info.memory = ptr::null_mut();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
match pos {
|
match pos {
|
||||||
io::SeekFrom::Start(off) => {
|
io::SeekFrom::Start(off) => {
|
||||||
self.cur_offset = std::cmp::min(self.size, off);
|
self.cur_offset = std::cmp::min(self.size, off);
|
||||||
|
@ -96,6 +89,14 @@ macro_rules! define_seek_impl(
|
||||||
let (idx, _, skip) = get_buffer_ref(self)
|
let (idx, _, skip) = get_buffer_ref(self)
|
||||||
.find_memory(self.cur_offset as usize, None)
|
.find_memory(self.cur_offset as usize, None)
|
||||||
.expect("Failed to find memory");
|
.expect("Failed to find memory");
|
||||||
|
|
||||||
|
if idx != self.cur_mem_idx && !self.map_info.memory.is_null() {
|
||||||
|
unsafe {
|
||||||
|
gst_sys::gst_memory_unmap(self.map_info.memory, &mut self.map_info);
|
||||||
|
self.map_info.memory = ptr::null_mut();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
self.cur_mem_idx = idx;
|
self.cur_mem_idx = idx;
|
||||||
self.cur_mem_offset = skip;
|
self.cur_mem_offset = skip;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue