From a09dad7fc6da3fe0c8b6e64b6187bb8b15191ccf Mon Sep 17 00:00:00 2001 From: Joerg Hofrichter Date: Thu, 5 Dec 2019 16:34:57 +0100 Subject: transport: liberio: correctly release resources on destruction Stop the streaming and free the allocated buffers on destruction of the liberio xport object. Note: There is a lingering resource leak in the kernel module, this patch merely orders the resource release correctly. Signed-off-by: Joerg Hofrichter --- host/lib/transport/liberio_link.cpp | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) (limited to 'host/lib/transport') diff --git a/host/lib/transport/liberio_link.cpp b/host/lib/transport/liberio_link.cpp index acc63ee37..ec8abbca8 100644 --- a/host/lib/transport/liberio_link.cpp +++ b/host/lib/transport/liberio_link.cpp @@ -75,9 +75,7 @@ liberio_link::liberio_link( _tx_chan = ctx_holder.alloc_tx_chan(tx_path); UHD_ASSERT_THROW(_tx_chan); - /* Reset channel */ - liberio_chan_stop_streaming(_tx_chan); - liberio_chan_request_buffers(_tx_chan, 0); + /* set the size, allocate */ UHD_ASSERT_THROW(!liberio_chan_set_fixed_size(_tx_chan, 0, params.send_frame_size)); UHD_ASSERT_THROW(!liberio_chan_request_buffers(_tx_chan, params.num_send_frames)); @@ -93,9 +91,7 @@ liberio_link::liberio_link( _rx_chan = ctx_holder.alloc_rx_chan(rx_path); UHD_ASSERT_THROW(_rx_chan); - /* stop the channel, free the buffers, set the size, allocate */ - liberio_chan_stop_streaming(_rx_chan); - liberio_chan_request_buffers(_rx_chan, 0); + /* set the size, allocate */ UHD_ASSERT_THROW(!liberio_chan_set_fixed_size(_rx_chan, 0, params.recv_frame_size)); UHD_ASSERT_THROW(!liberio_chan_request_buffers(_rx_chan, params.num_recv_frames)); /* TODO: Check params in factory and adjust them there instead of throwing exception @@ -134,7 +130,13 @@ liberio_link::liberio_link( liberio_link::~liberio_link() { + /* stop the channel, free the buffers */ + liberio_chan_stop_streaming(_tx_chan); + liberio_chan_request_buffers(_tx_chan, 0); liberio_chan_put(_tx_chan); + + liberio_chan_stop_streaming(_rx_chan); + liberio_chan_request_buffers(_rx_chan, 0); liberio_chan_put(_rx_chan); } -- cgit v1.2.3