#
9c9a810c |
| 14-Feb-2020 |
Jérôme Duval <jerome.duval@gmail.com> |
Media Kit: BBufferCache: if not reclaimed, only mark the buffer for deletion
hrev53379 clears the buffer cache for disconnected clients, and also delete buffers. This is too early (see #15263, media
Media Kit: BBufferCache: if not reclaimed, only mark the buffer for deletion
hrev53379 clears the buffer cache for disconnected clients, and also delete buffers. This is too early (see #15263, media_addon_server crash), and should only happen after the buffer is recycled. This can be resolved by abusing the fFlags field of BBuffer to mark the buffer for deletion, and mark the buffer to be reclaimed. Some BBuffers don't reside in the SharedBufferList, so we have to mark them as to be reclaimed. For those in the SharedBufferList, call a new RemoveBuffer(), which can check whether the buffer is still to be reclaimed. For reclaimed BBuffers, delete them right away, others can be marked for deletion. fixes #15606 #15263, possibly #15433
Change-Id: I66e94138e7e10a40d4c48e2ac042f816c79f5aab Reviewed-on: https://review.haiku-os.org/c/haiku/+/2245 Reviewed-by: Adrien Destugues <pulkomandy@gmail.com> Reviewed-by: X512 <danger_mail@list.ru> Reviewed-by: Ryan Leavengood <leavengood@gmail.com>
show more ...
|
#
fe08f0b3 |
| 14-Aug-2019 |
Ryan Leavengood <leavengood@gmail.com> |
Media Kit: Clear the BufferCache of buffers for disconnected clients
Without this, the BufferCache keeps a reference to these buffers inside the media_addon_server until the media_addon_server quits
Media Kit: Clear the BufferCache of buffers for disconnected clients
Without this, the BufferCache keeps a reference to these buffers inside the media_addon_server until the media_addon_server quits, which is pretty much never.
Should fix #4954 and #14755, and possibly #13614 and #14047, though I think they may be something else.
Switched from std::map to our HashMap to get something which works in gcc2 and gcc8.
Change-Id: I26463899724b9d1520d97fec785e435f536eaf3d Reviewed-on: https://review.haiku-os.org/c/haiku/+/1717 Reviewed-by: waddlesplash <waddlesplash@gmail.com>
show more ...
|
#
b84955d4 |
| 23-Oct-2018 |
Barrett17 <b.vitruvio@gmail.com> |
media: Remove debug.h, finalize MediaDebug.h
* Funny rust from 0 AD.
|
#
c302a243 |
| 23-Dec-2015 |
Alexander von Gluck IV <kallisti5@unixzen.com> |
Merge remote-tracking branch 'upstream/master' into intel-extreme
|
#
aa50bf9e |
| 13-Apr-2015 |
Dario Casalinuovo <b.vitruvio@gmail.com> |
BufferCache: Don't find anonymous buffers
|
#
384ae40a |
| 09-Apr-2015 |
Dario Casalinuovo <b.vitruvio@gmail.com> |
Correctly check when the BBuffer failed the registration with the server.
Signed-off-by: Adrien Destugues <pulkomandy@gmail.com>
|
#
9dec2310 |
| 05-Dec-2009 |
Axel Dörfler <axeld@pinc-software.de> |
Sorry for this large commit in advance; it's not really possible to divide this into smaller parts:
media_addon_server: * Removed (broken) use of (broken and inefficient) home-brewn Map, and List
Sorry for this large commit in advance; it's not really possible to divide this into smaller parts:
media_addon_server: * Removed (broken) use of (broken and inefficient) home-brewn Map, and List classes. This also fixes a crash on shutdown when used with the malloc_debug implementation. It's using stl::vector, and stl::map now instead.
_shared_buffer_list: * Renamed _shared_buffer_list to SharedBufferList, and put it into the BPrivate namespace. Also, made a class out of it. * Separated shared buffer list creation from cloning. * Enlarged maximum number of buffers to something that is not that evil, but actually uses the space it has (ie. is a useful multiple of shared_buffer_info that fills a multiple of B_PAGE_SIZE as much as possible). * No longer drops into the debugger if the * The list that is currently used is very inefficient for the features it provides though (no change there).
_buffer_id_cache: * Renamed to BufferCache, and put it into the private namespace * It now deletes its buffers on deletion; since the BBufferConsumer will be gone, too, at this point, there is little chance that there are still buffers in use. * Also, it's now using std::map instead of the (see above) Map class.
BBuffer: * Got rid of the fBufferID member.
Misc.: * Got rid of the global "team" variable; the media kit is now using the private app kit's current_team() now. * Added a lot of missing error checks (mostly memory allocations). * Renamed fields like "flavorid" to flavor_id, renamed "dfi_*" fields to something more detailed. * Moved ServerInterface.h from src/servers/media/ to headers/private/media. * Notifications.h was not self contained. * Added missing licenses. * Lots of cleanups, and coding style fixes.
What this doesn't fix: * Bug #4954 which started all this (this comes next, though) * Deinitialization is broken, as the PortPool is uninitialized too early, and still used afterwards. * The strange add-on monitoring code in the media_addon_server
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@34500 a95241bf-73f2-0310-859d-f6bbb57e9c96
show more ...
|
#
d98b8c7c |
| 19-Nov-2015 |
Dario Casalinuovo <b.vitruvio@gmail.com> |
BufferCache: More strict validity checks
* This add a debugger call if the BBuffer id is mismatched at object creation.
|