Commit eb3e3080 by Nicolas Capens

Fix validating sync object pointers.

The spec states that "If <sync> is not a valid sync object for <dpy>, EGL_FALSE is returned and an EGL_BAD_PARAMETER error is generated." Change-Id: I4bbd2ddfefd7baba9c301decb644bfb545e66f01 Reviewed-on: https://swiftshader-review.googlesource.com/5290Tested-by: 's avatarNicolas Capens <capn@google.com> Reviewed-by: 's avatarAlexis Hétu <sugoi@google.com> Reviewed-by: 's avatarNicolas Capens <capn@google.com>
parent 7d6b34d2
...@@ -444,6 +444,15 @@ EGLContext Display::createContext(EGLConfig configHandle, const egl::Context *sh ...@@ -444,6 +444,15 @@ EGLContext Display::createContext(EGLConfig configHandle, const egl::Context *sh
return success(context); return success(context);
} }
EGLSyncKHR Display::createSync(Context *context)
{
FenceSync *fenceSync = new egl::FenceSync(context);
mSyncSet.insert(fenceSync);
return fenceSync;
}
void Display::destroySurface(egl::Surface *surface) void Display::destroySurface(egl::Surface *surface)
{ {
surface->release(); surface->release();
...@@ -473,6 +482,13 @@ void Display::destroyContext(egl::Context *context) ...@@ -473,6 +482,13 @@ void Display::destroyContext(egl::Context *context)
} }
} }
void Display::destroySync(FenceSync *sync)
{
mSyncSet.erase(sync);
delete sync;
}
bool Display::isInitialized() const bool Display::isInitialized() const
{ {
return mConfigSet.size() > 0; return mConfigSet.size() > 0;
...@@ -480,7 +496,7 @@ bool Display::isInitialized() const ...@@ -480,7 +496,7 @@ bool Display::isInitialized() const
bool Display::isValidConfig(EGLConfig config) bool Display::isValidConfig(EGLConfig config)
{ {
return mConfigSet.get(config) != NULL; return mConfigSet.get(config) != nullptr;
} }
bool Display::isValidContext(egl::Context *context) bool Display::isValidContext(egl::Context *context)
...@@ -542,6 +558,11 @@ bool Display::hasExistingWindowSurface(EGLNativeWindowType window) ...@@ -542,6 +558,11 @@ bool Display::hasExistingWindowSurface(EGLNativeWindowType window)
return false; return false;
} }
bool Display::isValidSync(FenceSync *sync)
{
return mSyncSet.find(sync) != mSyncSet.end();
}
EGLint Display::getMinSwapInterval() const EGLint Display::getMinSwapInterval() const
{ {
return mMinSwapInterval; return mMinSwapInterval;
......
...@@ -17,6 +17,7 @@ ...@@ -17,6 +17,7 @@
#define INCLUDE_DISPLAY_H_ #define INCLUDE_DISPLAY_H_
#include "Config.h" #include "Config.h"
#include "Sync.hpp"
#include <set> #include <set>
...@@ -42,9 +43,11 @@ namespace egl ...@@ -42,9 +43,11 @@ namespace egl
EGLSurface createWindowSurface(EGLNativeWindowType window, EGLConfig config, const EGLint *attribList); EGLSurface createWindowSurface(EGLNativeWindowType window, EGLConfig config, const EGLint *attribList);
EGLSurface createPBufferSurface(EGLConfig config, const EGLint *attribList); EGLSurface createPBufferSurface(EGLConfig config, const EGLint *attribList);
EGLContext createContext(EGLConfig configHandle, const Context *shareContext, EGLint clientVersion); EGLContext createContext(EGLConfig configHandle, const Context *shareContext, EGLint clientVersion);
EGLSyncKHR createSync(Context *context);
void destroySurface(Surface *surface); void destroySurface(Surface *surface);
void destroyContext(Context *context); void destroyContext(Context *context);
void destroySync(FenceSync *sync);
bool isInitialized() const; bool isInitialized() const;
bool isValidConfig(EGLConfig config); bool isValidConfig(EGLConfig config);
...@@ -52,6 +55,7 @@ namespace egl ...@@ -52,6 +55,7 @@ namespace egl
bool isValidSurface(Surface *surface); bool isValidSurface(Surface *surface);
bool isValidWindow(EGLNativeWindowType window); bool isValidWindow(EGLNativeWindowType window);
bool hasExistingWindowSurface(EGLNativeWindowType window); bool hasExistingWindowSurface(EGLNativeWindowType window);
bool isValidSync(FenceSync *sync);
EGLint getMinSwapInterval() const; EGLint getMinSwapInterval() const;
EGLint getMaxSwapInterval() const; EGLint getMaxSwapInterval() const;
...@@ -77,6 +81,9 @@ namespace egl ...@@ -77,6 +81,9 @@ namespace egl
typedef std::set<Context*> ContextSet; typedef std::set<Context*> ContextSet;
ContextSet mContextSet; ContextSet mContextSet;
typedef std::set<FenceSync*> SyncSet;
SyncSet mSyncSet;
}; };
} }
......
// SwiftShader Software Renderer
//
// Copyright(c) 2005-2012 TransGaming Inc.
//
// All rights reserved. No part of this software may be copied, distributed, transmitted,
// transcribed, stored in a retrieval system, translated into any human or computer
// language by any means, or disclosed to third parties without the explicit written
// agreement of TransGaming Inc. Without such an agreement, no rights or licenses, express
// or implied, including but not limited to any patent rights, are granted to you.
//
// Sync.hpp: Defines sync objects for the EGL_KHR_fence_sync extension.
#ifndef LIBEGL_SYNC_H_
#define LIBEGL_SYNC_H_
#include "Context.hpp"
#include <EGL/eglext.h>
namespace egl
{
class FenceSync
{
public:
explicit FenceSync(Context *context) : context(context)
{
status = EGL_UNSIGNALED_KHR;
context->addRef();
}
~FenceSync()
{
context->release();
context = nullptr;
}
void wait() { context->finish(); signal(); }
void signal() { status = EGL_SIGNALED_KHR; }
bool isSignaled() const { return status == EGL_SIGNALED_KHR; }
private:
EGLint status;
Context *context;
};
}
#endif // LIBEGL_SYNC_H_
...@@ -1017,30 +1017,6 @@ EGLSurface CreatePlatformPixmapSurfaceEXT(EGLDisplay dpy, EGLConfig config, void ...@@ -1017,30 +1017,6 @@ EGLSurface CreatePlatformPixmapSurfaceEXT(EGLDisplay dpy, EGLConfig config, void
return CreatePixmapSurface(dpy, config, (EGLNativePixmapType)native_pixmap, attrib_list); return CreatePixmapSurface(dpy, config, (EGLNativePixmapType)native_pixmap, attrib_list);
} }
class FenceSync
{
public:
explicit FenceSync(Context *context) : context(context)
{
status = EGL_UNSIGNALED_KHR;
context->addRef();
}
~FenceSync()
{
context->release();
context = nullptr;
}
void wait() { context->finish(); signal(); }
void signal() { status = EGL_SIGNALED_KHR; }
bool isSignaled() const { return status == EGL_SIGNALED_KHR; }
private:
EGLint status;
Context *context;
};
EGLSyncKHR CreateSyncKHR(EGLDisplay dpy, EGLenum type, const EGLint *attrib_list) EGLSyncKHR CreateSyncKHR(EGLDisplay dpy, EGLenum type, const EGLint *attrib_list)
{ {
TRACE("(EGLDisplay dpy = %p, EGLunum type = %x, EGLint *attrib_list=%p)", dpy, type, attrib_list); TRACE("(EGLDisplay dpy = %p, EGLunum type = %x, EGLint *attrib_list=%p)", dpy, type, attrib_list);
...@@ -1069,7 +1045,9 @@ EGLSyncKHR CreateSyncKHR(EGLDisplay dpy, EGLenum type, const EGLint *attrib_list ...@@ -1069,7 +1045,9 @@ EGLSyncKHR CreateSyncKHR(EGLDisplay dpy, EGLenum type, const EGLint *attrib_list
return error(EGL_BAD_MATCH, EGL_NO_SYNC_KHR); return error(EGL_BAD_MATCH, EGL_NO_SYNC_KHR);
} }
return success(new FenceSync(context)); EGLSyncKHR sync = display->createSync(context);
return success(sync);
} }
EGLBoolean DestroySyncKHR(EGLDisplay dpy, EGLSyncKHR sync) EGLBoolean DestroySyncKHR(EGLDisplay dpy, EGLSyncKHR sync)
...@@ -1084,7 +1062,12 @@ EGLBoolean DestroySyncKHR(EGLDisplay dpy, EGLSyncKHR sync) ...@@ -1084,7 +1062,12 @@ EGLBoolean DestroySyncKHR(EGLDisplay dpy, EGLSyncKHR sync)
return error(EGL_BAD_DISPLAY, EGL_FALSE); return error(EGL_BAD_DISPLAY, EGL_FALSE);
} }
delete eglSync; if(!display->isValidSync(eglSync))
{
return error(EGL_BAD_PARAMETER, EGL_FALSE);
}
display->destroySync(eglSync);
return success(EGL_TRUE); return success(EGL_TRUE);
} }
...@@ -1101,6 +1084,11 @@ EGLint ClientWaitSyncKHR(EGLDisplay dpy, EGLSyncKHR sync, EGLint flags, EGLTimeK ...@@ -1101,6 +1084,11 @@ EGLint ClientWaitSyncKHR(EGLDisplay dpy, EGLSyncKHR sync, EGLint flags, EGLTimeK
return error(EGL_BAD_DISPLAY, EGL_FALSE); return error(EGL_BAD_DISPLAY, EGL_FALSE);
} }
if(!display->isValidSync(eglSync))
{
return error(EGL_BAD_PARAMETER, EGL_FALSE);
}
(void)flags; (void)flags;
(void)timeout; (void)timeout;
...@@ -1117,13 +1105,17 @@ EGLBoolean GetSyncAttribKHR(EGLDisplay dpy, EGLSyncKHR sync, EGLint attribute, E ...@@ -1117,13 +1105,17 @@ EGLBoolean GetSyncAttribKHR(EGLDisplay dpy, EGLSyncKHR sync, EGLint attribute, E
TRACE("(EGLDisplay dpy = %p, EGLSyncKHR sync = %p, EGLint attribute = %x, EGLint *value = %p)", dpy, sync, attribute, value); TRACE("(EGLDisplay dpy = %p, EGLSyncKHR sync = %p, EGLint attribute = %x, EGLint *value = %p)", dpy, sync, attribute, value);
egl::Display *display = egl::Display::get(dpy); egl::Display *display = egl::Display::get(dpy);
FenceSync *eglSync = static_cast<FenceSync*>(sync);
if(!validateDisplay(display)) if(!validateDisplay(display))
{ {
return error(EGL_BAD_DISPLAY, EGL_FALSE); return error(EGL_BAD_DISPLAY, EGL_FALSE);
} }
FenceSync *eglSync = static_cast<FenceSync*>(sync); if(!display->isValidSync(eglSync))
{
return error(EGL_BAD_PARAMETER, EGL_FALSE);
}
switch(attribute) switch(attribute)
{ {
......
...@@ -319,6 +319,7 @@ copy "$(OutDir)libEGL.dll" "$(ProjectDir)..\..\..\lib\$(Configuration)_$(Platfor ...@@ -319,6 +319,7 @@ copy "$(OutDir)libEGL.dll" "$(ProjectDir)..\..\..\lib\$(Configuration)_$(Platfor
<ClInclude Include="main.h" /> <ClInclude Include="main.h" />
<ClInclude Include="resource.h" /> <ClInclude Include="resource.h" />
<ClInclude Include="Surface.h" /> <ClInclude Include="Surface.h" />
<ClInclude Include="Sync.hpp" />
<ClInclude Include="Texture.hpp" /> <ClInclude Include="Texture.hpp" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
......
...@@ -76,6 +76,9 @@ ...@@ -76,6 +76,9 @@
<ClInclude Include="..\common\Image.hpp"> <ClInclude Include="..\common\Image.hpp">
<Filter>Header Files</Filter> <Filter>Header Files</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="Sync.hpp">
<Filter>Header Files</Filter>
</ClInclude>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ResourceCompile Include="libEGL.rc" /> <ResourceCompile Include="libEGL.rc" />
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment