mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-03 07:29:37 +01:00
Fixed NULL pointer dereference, thanks Ozkan Sezer
This commit is contained in:
parent
5b14a943a8
commit
39ba2ab835
@ -125,11 +125,7 @@ calc_swizzle32(const SDL_PixelFormat * srcfmt, const SDL_PixelFormat * dstfmt)
|
|||||||
0x0C);
|
0x0C);
|
||||||
vector unsigned char vswiz;
|
vector unsigned char vswiz;
|
||||||
vector unsigned int srcvec;
|
vector unsigned int srcvec;
|
||||||
#define RESHIFT(X) (3 - ((X) >> 3))
|
Uint32 rmask, gmask, bmask, amask;
|
||||||
Uint32 rmask = RESHIFT(srcfmt->Rshift) << (dstfmt->Rshift);
|
|
||||||
Uint32 gmask = RESHIFT(srcfmt->Gshift) << (dstfmt->Gshift);
|
|
||||||
Uint32 bmask = RESHIFT(srcfmt->Bshift) << (dstfmt->Bshift);
|
|
||||||
Uint32 amask;
|
|
||||||
|
|
||||||
if (!srcfmt) {
|
if (!srcfmt) {
|
||||||
srcfmt = &default_pixel_format;
|
srcfmt = &default_pixel_format;
|
||||||
@ -138,6 +134,11 @@ calc_swizzle32(const SDL_PixelFormat * srcfmt, const SDL_PixelFormat * dstfmt)
|
|||||||
dstfmt = &default_pixel_format;
|
dstfmt = &default_pixel_format;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define RESHIFT(X) (3 - ((X) >> 3))
|
||||||
|
rmask = RESHIFT(srcfmt->Rshift) << (dstfmt->Rshift);
|
||||||
|
gmask = RESHIFT(srcfmt->Gshift) << (dstfmt->Gshift);
|
||||||
|
bmask = RESHIFT(srcfmt->Bshift) << (dstfmt->Bshift);
|
||||||
|
|
||||||
/* Use zero for alpha if either surface doesn't have alpha */
|
/* Use zero for alpha if either surface doesn't have alpha */
|
||||||
if (dstfmt->Amask) {
|
if (dstfmt->Amask) {
|
||||||
amask =
|
amask =
|
||||||
@ -149,6 +150,7 @@ calc_swizzle32(const SDL_PixelFormat * srcfmt, const SDL_PixelFormat * dstfmt)
|
|||||||
0xFFFFFFFF);
|
0xFFFFFFFF);
|
||||||
}
|
}
|
||||||
#undef RESHIFT
|
#undef RESHIFT
|
||||||
|
|
||||||
((unsigned int *) (char *) &srcvec)[0] = (rmask | gmask | bmask | amask);
|
((unsigned int *) (char *) &srcvec)[0] = (rmask | gmask | bmask | amask);
|
||||||
vswiz = vec_add(plus, (vector unsigned char) vec_splat(srcvec, 0));
|
vswiz = vec_add(plus, (vector unsigned char) vec_splat(srcvec, 0));
|
||||||
return (vswiz);
|
return (vswiz);
|
||||||
|
Loading…
Reference in New Issue
Block a user