- 24 Oct, 2022 40 commits
-
-
Bartosz Kosiorek authored
-
Bartosz Kosiorek authored
-
Bartosz Kosiorek authored
-
Gabriel Ivăncescu authored
Signed-off-by: Gabriel Ivăncescu <gabrielopcode@gmail.com>
-
Gabriel Ivăncescu authored
Signed-off-by: Gabriel Ivăncescu <gabrielopcode@gmail.com>
-
Gabriel Ivăncescu authored
Signed-off-by: Gabriel Ivăncescu <gabrielopcode@gmail.com>
-
Gabriel Ivăncescu authored
Signed-off-by: Gabriel Ivăncescu <gabrielopcode@gmail.com>
-
Gabriel Ivăncescu authored
Signed-off-by: Gabriel Ivăncescu <gabrielopcode@gmail.com>
-
Gabriel Ivăncescu authored
Signed-off-by: Gabriel Ivăncescu <gabrielopcode@gmail.com>
-
Gabriel Ivăncescu authored
Signed-off-by: Gabriel Ivăncescu <gabrielopcode@gmail.com>
-
Gabriel Ivăncescu authored
Signed-off-by: Gabriel Ivăncescu <gabrielopcode@gmail.com>
-
Martin Storsjö authored
This fixes stack overflows since edecac8a. Signed-off-by: Martin Storsjö <martin@martin.st>
-
Ziqing Hui authored
-
Ziqing Hui authored
-
Ziqing Hui authored
-
Alexandre Julliard authored
-
Alexandre Julliard authored
-
Alexandre Julliard authored
-
Alexandre Julliard authored
-
Alexandre Julliard authored
-
Paul Gofman authored
-
Alex Henrie authored
-
Alex Henrie authored
-
Alex Henrie authored
-
Alex Henrie authored
-
Jinoh Kang authored
Today, the image_unlock() helper function has a data race due to non-atomic write to GpImage's 'busy' flag which is accessible by other threads. Also, it lacks a release fence, which means that other threads can observe the unlocked (busy = 0) state too early when the current thread unlocks the image; specifically, the write to the 'busy' field of the GpImage can be reordered before the last read/write to any other fields of the same GpImage. Fix this by replacing the 'busy' field of GpImage with SRWLOCK.
-
Jinoh Kang authored
The 'busy' field in GpImage is used as an atomic variable. The C11 standard (§5.1.2.4, paragraph 25) states that two conflicting actions to a memory location shall be both atomic operations, or otherwise properly synchronized; otherwise, it constitutes a data race. However, select_frame_wic() performs a non-atomic access to the 'busy' field on a GpImage that is potentially accessible by other threads. This happens when select_frame_wic() copies new_image to the old image object. Although it does attempt to preserve the value of the 'busy' field by setting new_image->busy = image->busy first, thereby effectively assigning an identical value to the field, it is unclear that this does not actually constitute a theoretical, if not practical, data race. This also prevents replacing the busy flag with a mutex or other synchronization primitives. Therefore, skip the 'busy' field when copying fields from the new image to the original image object.
-
Jinoh Kang authored
GdipImageRotateFlip() calls GdipBitmapLockBits() while holding the image lock, resulting in a recursive lock. Since GdipImageRotateFlip() uses GdipBitmapLockBits() only to obtain Scan0 and Stride, replace them with equivalent fields from GpBitmap itself.
-
Esme Povirk authored
-
Esme Povirk authored
-
Paul Gofman authored
-
Piotr Caban authored
-
Mihail Ivanchev authored
Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=53821
-
Anton Baskanov authored
Signed-off-by: Anton Baskanov <baskanov@gmail.com>
-
Anton Baskanov authored
Signed-off-by: Anton Baskanov <baskanov@gmail.com>
-
Anton Baskanov authored
Signed-off-by: Anton Baskanov <baskanov@gmail.com>
-
Anton Baskanov authored
Signed-off-by: Anton Baskanov <baskanov@gmail.com>
-
Anton Baskanov authored
Signed-off-by: Anton Baskanov <baskanov@gmail.com>
-
Anton Baskanov authored
Signed-off-by: Anton Baskanov <baskanov@gmail.com>
-
Paul Gofman authored
-