mirror of
https://github.com/kanjitalk755/macemu.git
synced 2025-01-12 01:30:03 +00:00
Merge pull request #12 from spolsley/mutex_test
SDL mutex deadlock and video fix, try 2
This commit is contained in:
commit
a8bb4790df
@ -875,23 +875,24 @@ static int present_sdl_video()
|
|||||||
SDL_SetRenderDrawColor(sdl_renderer, 0, 0, 0, 0); // Use black
|
SDL_SetRenderDrawColor(sdl_renderer, 0, 0, 0, 0); // Use black
|
||||||
SDL_RenderClear(sdl_renderer); // Clear the display
|
SDL_RenderClear(sdl_renderer); // Clear the display
|
||||||
|
|
||||||
|
// We're about to work with sdl_update_video_rect, so stop other threads from
|
||||||
|
// modifying it!
|
||||||
|
LOCK_PALETTE;
|
||||||
|
SDL_LockMutex(sdl_update_video_mutex);
|
||||||
// Convert from the guest OS' pixel format, to the host OS' texture, if necessary.
|
// Convert from the guest OS' pixel format, to the host OS' texture, if necessary.
|
||||||
if (host_surface != guest_surface &&
|
if (host_surface != guest_surface &&
|
||||||
host_surface != NULL &&
|
host_surface != NULL &&
|
||||||
guest_surface != NULL)
|
guest_surface != NULL)
|
||||||
{
|
{
|
||||||
SDL_Rect destRect = sdl_update_video_rect;
|
SDL_Rect destRect = sdl_update_video_rect;
|
||||||
LOCK_PALETTE;
|
|
||||||
SDL_LockMutex(sdl_update_video_mutex);
|
|
||||||
int result = SDL_BlitSurface(guest_surface, &sdl_update_video_rect, host_surface, &destRect);
|
int result = SDL_BlitSurface(guest_surface, &sdl_update_video_rect, host_surface, &destRect);
|
||||||
SDL_UnlockMutex(sdl_update_video_mutex);
|
if (result != 0) {
|
||||||
UNLOCK_PALETTE;
|
SDL_UnlockMutex(sdl_update_video_mutex);
|
||||||
if (result != 0) return -1;
|
UNLOCK_PALETTE;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
UNLOCK_PALETTE; // passed potential deadlock, can unlock palette
|
||||||
// We're about to work with sdl_update_video_rect, so stop other threads from
|
|
||||||
// modifying it!
|
|
||||||
SDL_LockMutex(sdl_update_video_mutex);
|
|
||||||
|
|
||||||
// Update the host OS' texture
|
// Update the host OS' texture
|
||||||
void * srcPixels = (void *)((uint8_t *)host_surface->pixels +
|
void * srcPixels = (void *)((uint8_t *)host_surface->pixels +
|
||||||
|
Loading…
x
Reference in New Issue
Block a user