diff --git a/src/video/SDL_surface.c b/src/video/SDL_surface.c index 1f836bf217..7ef72f5e6e 100644 --- a/src/video/SDL_surface.c +++ b/src/video/SDL_surface.c @@ -20,6 +20,7 @@ */ #include "../SDL_internal.h" +#include "SDL_hints.h" #include "SDL_video.h" #include "SDL_sysvideo.h" #include "SDL_blit.h" @@ -153,13 +154,17 @@ SDL_Surface *SDL_CreateRGBSurfaceWithFormat(Uint32 flags, int width, int height, return NULL; } - surface->pixels = SDL_SIMDAlloc(size); + if (SDL_GetHintBoolean("SDL_SURFACE_MALLOC", SDL_FALSE)) { + surface->pixels = SDL_malloc(size); + } else { + surface->flags |= SDL_SIMD_ALIGNED; + surface->pixels = SDL_SIMDAlloc(size); + } if (!surface->pixels) { SDL_FreeSurface(surface); SDL_OutOfMemory(); return NULL; } - surface->flags |= SDL_SIMD_ALIGNED; /* This is important for bitmaps */ SDL_memset(surface->pixels, 0, size); }