Import a platform framework
This commit is contained in:
parent
24bf472d3d
commit
ecb407c721
|
@ -20,6 +20,7 @@
|
||||||
|
|
||||||
|
|
||||||
# include "GServer/gserver.h"
|
# include "GServer/gserver.h"
|
||||||
|
# include "GServer/platform.h"
|
||||||
# include "GServer/video.h"
|
# include "GServer/video.h"
|
||||||
|
|
||||||
#endif /* !GRAPHICS_GSERVER_H */
|
#endif /* !GRAPHICS_GSERVER_H */
|
||||||
|
|
36
include/GServer/platform.h
Normal file
36
include/GServer/platform.h
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
/* $Id$ */
|
||||||
|
/* Copyright (c) 2015 Pierre Pronchery <khorben@defora.org> */
|
||||||
|
/* This file is part of DeforaOS Graphics GServer */
|
||||||
|
/* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, version 3 of the License.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef GRAPHICS_GSERVER_PLATFORM_H
|
||||||
|
# define GRAPHICS_GSERVER_PLATFORM_H
|
||||||
|
|
||||||
|
|
||||||
|
/* GServerPlatform */
|
||||||
|
/* protected */
|
||||||
|
/* types */
|
||||||
|
typedef struct _GServerPlatform GServerPlatform;
|
||||||
|
|
||||||
|
|
||||||
|
/* public */
|
||||||
|
/* accessors */
|
||||||
|
int gserverplatform_get_video_refresh_rate(GServerPlatform * platform);
|
||||||
|
|
||||||
|
int gserverplatform_get_video_depth(GServerPlatform * platform);
|
||||||
|
int gserverplatform_get_video_height(GServerPlatform * platform);
|
||||||
|
int gserverplatform_get_video_width(GServerPlatform * platform);
|
||||||
|
|
||||||
|
#endif /* !GRAPHICS_GSERVER_PLATFORM_H */
|
|
@ -21,6 +21,7 @@
|
||||||
# include <stdint.h>
|
# include <stdint.h>
|
||||||
# include <System.h>
|
# include <System.h>
|
||||||
# include "gserver.h"
|
# include "gserver.h"
|
||||||
|
# include "platform.h"
|
||||||
|
|
||||||
|
|
||||||
/* Video */
|
/* Video */
|
||||||
|
@ -94,6 +95,7 @@ typedef struct _GServerVideoPluginHelper
|
||||||
char const * (*config_get)(GServer * gserver, char const * section,
|
char const * (*config_get)(GServer * gserver, char const * section,
|
||||||
char const * variable);
|
char const * variable);
|
||||||
Event * (*get_event)(GServer * gserver);
|
Event * (*get_event)(GServer * gserver);
|
||||||
|
GServerPlatform * (*get_platform)(GServer * gserver);
|
||||||
void (*refresh)(GServer * gserver);
|
void (*refresh)(GServer * gserver);
|
||||||
} GServerVideoPluginHelper;
|
} GServerVideoPluginHelper;
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include <System.h>
|
#include <System.h>
|
||||||
#include "GServer/video.h"
|
#include "GServer/video.h"
|
||||||
#include "../data/GServer.h"
|
#include "../data/GServer.h"
|
||||||
|
#include "platform.h"
|
||||||
#include "gserver.h"
|
#include "gserver.h"
|
||||||
#include "../config.h"
|
#include "../config.h"
|
||||||
|
|
||||||
|
@ -58,6 +59,8 @@ typedef struct _GServerClient GServerClient;
|
||||||
|
|
||||||
struct _App
|
struct _App
|
||||||
{
|
{
|
||||||
|
GServerPlatform * platform;
|
||||||
|
|
||||||
Event * event;
|
Event * event;
|
||||||
int event_own;
|
int event_own;
|
||||||
AppServer * appserver;
|
AppServer * appserver;
|
||||||
|
@ -167,6 +170,8 @@ GServer * gserver_new(AppServerOptions options, Event * event)
|
||||||
|
|
||||||
static int _new_init(AppServerOptions options, GServer * gserver, Event * event)
|
static int _new_init(AppServerOptions options, GServer * gserver, Event * event)
|
||||||
{
|
{
|
||||||
|
if((gserver->platform = gserverplatform_new()) == NULL)
|
||||||
|
return -1;
|
||||||
gserver->video_handle = NULL;
|
gserver->video_handle = NULL;
|
||||||
gserver->video_plugin = NULL;
|
gserver->video_plugin = NULL;
|
||||||
gserver->clients = NULL;
|
gserver->clients = NULL;
|
||||||
|
@ -174,11 +179,15 @@ static int _new_init(AppServerOptions options, GServer * gserver, Event * event)
|
||||||
if((gserver->event = event) != NULL)
|
if((gserver->event = event) != NULL)
|
||||||
gserver->event_own = 0;
|
gserver->event_own = 0;
|
||||||
else if((gserver->event = event_new()) == NULL)
|
else if((gserver->event = event_new()) == NULL)
|
||||||
|
{
|
||||||
|
gserverplatform_delete(gserver->platform);
|
||||||
return -1;
|
return -1;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
gserver->event_own = 1;
|
gserver->event_own = 1;
|
||||||
gserver->video_helper.gserver = gserver;
|
gserver->video_helper.gserver = gserver;
|
||||||
gserver->video_helper.get_event = gserver_get_event;
|
gserver->video_helper.get_event = gserver_get_event;
|
||||||
|
gserver->video_helper.get_platform = gserver_get_platform;
|
||||||
gserver->video_helper.refresh = gserver_refresh;
|
gserver->video_helper.refresh = gserver_refresh;
|
||||||
if((gserver->appserver = appserver_new_event(gserver, options,
|
if((gserver->appserver = appserver_new_event(gserver, options,
|
||||||
"GServer", NULL, gserver->event))
|
"GServer", NULL, gserver->event))
|
||||||
|
@ -192,14 +201,18 @@ static int _new_init(AppServerOptions options, GServer * gserver, Event * event)
|
||||||
appserver_delete(gserver->appserver);
|
appserver_delete(gserver->appserver);
|
||||||
if(gserver->event_own != 0)
|
if(gserver->event_own != 0)
|
||||||
event_delete(gserver->event);
|
event_delete(gserver->event);
|
||||||
|
gserverplatform_delete(gserver->platform);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int _init_video(GServer * gserver)
|
static int _init_video(GServer * gserver)
|
||||||
/* FIXME ask Hardware what to load instead of hard-coding glut */
|
|
||||||
{
|
{
|
||||||
if((gserver->video_handle = plugin_new(LIBDIR, PACKAGE, "video",
|
String const subsystem[] = "video";
|
||||||
"glut")) == NULL)
|
GServerPlatform * platform = gserver->platform;
|
||||||
|
|
||||||
|
if((gserver->video_handle = plugin_new(LIBDIR, PACKAGE, subsystem,
|
||||||
|
gserverplatform_get_driver(platform,
|
||||||
|
subsystem))) == NULL)
|
||||||
return 1;
|
return 1;
|
||||||
if((gserver->video_plugin = plugin_lookup(gserver->video_handle,
|
if((gserver->video_plugin = plugin_lookup(gserver->video_handle,
|
||||||
"video_plugin")) == NULL)
|
"video_plugin")) == NULL)
|
||||||
|
@ -226,6 +239,8 @@ void gserver_delete(GServer * gserver)
|
||||||
appserver_delete(gserver->appserver);
|
appserver_delete(gserver->appserver);
|
||||||
if(gserver->event != NULL)
|
if(gserver->event != NULL)
|
||||||
event_delete(gserver->event);
|
event_delete(gserver->event);
|
||||||
|
if(gserver->platform != NULL)
|
||||||
|
gserverplatform_delete(gserver->platform);
|
||||||
object_delete(gserver);
|
object_delete(gserver);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -246,6 +261,13 @@ Event * gserver_get_event(GServer * gserver)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gserver_get_platform */
|
||||||
|
GServerPlatform * gserver_get_platform(GServer * gserver)
|
||||||
|
{
|
||||||
|
return gserver->platform;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* useful */
|
/* useful */
|
||||||
/* gserver_loop */
|
/* gserver_loop */
|
||||||
int gserver_loop(GServer * gserver)
|
int gserver_loop(GServer * gserver)
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
|
|
||||||
# include <System.h>
|
# include <System.h>
|
||||||
# include <System/App.h>
|
# include <System/App.h>
|
||||||
|
# include "GServer/platform.h"
|
||||||
# include "GServer/gserver.h"
|
# include "GServer/gserver.h"
|
||||||
|
|
||||||
|
|
||||||
|
@ -32,6 +33,7 @@ void gserver_delete(GServer * gserver);
|
||||||
|
|
||||||
/* accessors */
|
/* accessors */
|
||||||
Event * gserver_get_event(GServer * gserver);
|
Event * gserver_get_event(GServer * gserver);
|
||||||
|
GServerPlatform * gserver_get_platform(GServer * gserver);
|
||||||
|
|
||||||
|
|
||||||
/* useful */
|
/* useful */
|
||||||
|
|
155
src/platform.c
Normal file
155
src/platform.c
Normal file
|
@ -0,0 +1,155 @@
|
||||||
|
/* $Id$ */
|
||||||
|
/* Copyright (c) 2015 Pierre Pronchery <khorben@defora.org> */
|
||||||
|
/* This file is part of DeforaOS Graphics GServer */
|
||||||
|
/* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, version 3 of the License.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <limits.h>
|
||||||
|
#include <System.h>
|
||||||
|
#include "GServer/platform.h"
|
||||||
|
#include "../config.h"
|
||||||
|
|
||||||
|
#ifndef VENDOR
|
||||||
|
# define VENDOR "DeforaOS"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* GServerPlatform */
|
||||||
|
/* private */
|
||||||
|
/* types */
|
||||||
|
struct _GServerPlatform
|
||||||
|
{
|
||||||
|
Config * config;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* prototypes */
|
||||||
|
/* accessors */
|
||||||
|
static int _gserverplatform_get_integer(GServerPlatform * platform,
|
||||||
|
String const * section, String const * name, int fallback);
|
||||||
|
static String const * _gserverplatform_get_string(GServerPlatform * platform,
|
||||||
|
String const * section, String const * name,
|
||||||
|
String const * fallback);
|
||||||
|
|
||||||
|
|
||||||
|
/* public */
|
||||||
|
/* functions */
|
||||||
|
/* gserverplatform_new */
|
||||||
|
GServerPlatform * gserverplatform_new(void)
|
||||||
|
{
|
||||||
|
GServerPlatform * platform;
|
||||||
|
|
||||||
|
if((platform = object_new(sizeof(*platform))) == NULL)
|
||||||
|
return NULL;
|
||||||
|
if((platform->config = config_new()) == NULL)
|
||||||
|
{
|
||||||
|
object_delete(platform->config);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
/* XXX report errors */
|
||||||
|
config_load_preferences_system(platform->config, VENDOR, PACKAGE,
|
||||||
|
"platform.conf");
|
||||||
|
return platform;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gserverplatform_delete */
|
||||||
|
void gserverplatform_delete(GServerPlatform * platform)
|
||||||
|
{
|
||||||
|
config_delete(platform->config);
|
||||||
|
object_delete(platform);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* accessors */
|
||||||
|
/* gserverplatform_get_driver */
|
||||||
|
String const * gserverplatform_get_driver(GServerPlatform * platform,
|
||||||
|
String const * subsystem)
|
||||||
|
{
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
String const * subsystem;
|
||||||
|
String const * fallback;
|
||||||
|
} fallback[] =
|
||||||
|
{
|
||||||
|
{ "video", "glx" }
|
||||||
|
};
|
||||||
|
size_t i;
|
||||||
|
|
||||||
|
for(i = 0; i < sizeof(fallback) / sizeof(*fallback); i++)
|
||||||
|
if(string_compare(fallback[i].subsystem, subsystem) == 0)
|
||||||
|
return _gserverplatform_get_string(platform, "drivers",
|
||||||
|
subsystem, fallback[i].fallback);
|
||||||
|
return _gserverplatform_get_string(platform, "drivers", subsystem,
|
||||||
|
NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gserverplatform_get_video_depth */
|
||||||
|
int gserverplatform_get_video_depth(GServerPlatform * platform)
|
||||||
|
{
|
||||||
|
return _gserverplatform_get_integer(platform, "video", "depth", 24);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gserverplatform_get_video_height */
|
||||||
|
int gserverplatform_get_video_height(GServerPlatform * platform)
|
||||||
|
{
|
||||||
|
return _gserverplatform_get_integer(platform, "video", "height", 480);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gserverplatform_get_video_refresh_rate */
|
||||||
|
int gserverplatform_get_video_refresh_rate(GServerPlatform * platform)
|
||||||
|
{
|
||||||
|
return _gserverplatform_get_integer(platform, "video", "refresh_rate",
|
||||||
|
60);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gserverplatform_get_video_width */
|
||||||
|
int gserverplatform_get_video_width(GServerPlatform * platform)
|
||||||
|
{
|
||||||
|
return _gserverplatform_get_integer(platform, "video", "width", 640);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* private */
|
||||||
|
/* functions */
|
||||||
|
/* gserverplatform_get_integer */
|
||||||
|
static int _gserverplatform_get_integer(GServerPlatform * platform,
|
||||||
|
String const * section, String const * name, int fallback)
|
||||||
|
{
|
||||||
|
String const * p;
|
||||||
|
int d;
|
||||||
|
|
||||||
|
if((p = config_get(platform->config, section, name)) == NULL
|
||||||
|
|| (d = strtol(p, NULL, 0)) == 0)
|
||||||
|
return fallback;
|
||||||
|
return d;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gserverplatform_get_string */
|
||||||
|
static String const * _gserverplatform_get_string(GServerPlatform * platform,
|
||||||
|
String const * section, String const * name,
|
||||||
|
String const * fallback)
|
||||||
|
{
|
||||||
|
String const * s;
|
||||||
|
|
||||||
|
if((s = config_get(platform->config, section, name)) == NULL)
|
||||||
|
return fallback;
|
||||||
|
return s;
|
||||||
|
}
|
34
src/platform.h
Normal file
34
src/platform.h
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
/* $Id$ */
|
||||||
|
/* Copyright (c) 2015 Pierre Pronchery <khorben@defora.org> */
|
||||||
|
/* This file is part of DeforaOS Graphics GServer */
|
||||||
|
/* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, version 3 of the License.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef GSERVER_PLATFORM_H
|
||||||
|
# define GSERVER_PLATFORM_H
|
||||||
|
|
||||||
|
# include <System/string.h>
|
||||||
|
|
||||||
|
|
||||||
|
/* GServerPlatform */
|
||||||
|
/* public */
|
||||||
|
/* accessors */
|
||||||
|
GServerPlatform * gserverplatform_new(void);
|
||||||
|
void gserverplatform_delete(GServerPlatform * platform);
|
||||||
|
|
||||||
|
/* accessors */
|
||||||
|
String const * gserverplatform_get_driver(GServerPlatform * platform,
|
||||||
|
String const * subsystem);
|
||||||
|
|
||||||
|
#endif /* !GSERVER_PLATFORM_H */
|
|
@ -15,11 +15,14 @@ depends=../data/GServer.interface
|
||||||
|
|
||||||
[GServer]
|
[GServer]
|
||||||
type=binary
|
type=binary
|
||||||
sources=gserver.c,main.c
|
sources=gserver.c,platform.c,main.c
|
||||||
cflags=`pkg-config --cflags gl`
|
cflags=`pkg-config --cflags gl`
|
||||||
|
|
||||||
[gserver.c]
|
[gserver.c]
|
||||||
depends=gserver.h,../data/GServer.h,../config.h
|
depends=gserver.h,../data/GServer.h,../config.h
|
||||||
|
|
||||||
|
[platform.c]
|
||||||
|
depends=../config.h
|
||||||
|
|
||||||
[main.c]
|
[main.c]
|
||||||
depends=gserver.h,../config.h
|
depends=gserver.h,../config.h
|
||||||
|
|
|
@ -122,6 +122,7 @@ GServerVideoPlugin video_plugin =
|
||||||
static int _glut_init(GServerVideoPlugin * plugin)
|
static int _glut_init(GServerVideoPlugin * plugin)
|
||||||
{
|
{
|
||||||
GLUTVideo * glut;
|
GLUTVideo * glut;
|
||||||
|
GServerPlatform * platform;
|
||||||
int argc = 1;
|
int argc = 1;
|
||||||
char * argv[] = { "GServer", NULL };
|
char * argv[] = { "GServer", NULL };
|
||||||
|
|
||||||
|
@ -131,8 +132,9 @@ static int _glut_init(GServerVideoPlugin * plugin)
|
||||||
if((glut = object_new(sizeof(*glut))) == NULL)
|
if((glut = object_new(sizeof(*glut))) == NULL)
|
||||||
return 1;
|
return 1;
|
||||||
plugin->priv = glut;
|
plugin->priv = glut;
|
||||||
glut->width = 640;
|
platform = plugin->helper->get_platform(plugin->helper->gserver);
|
||||||
glut->height = 480;
|
glut->width = gserverplatform_get_video_width(platform);
|
||||||
|
glut->height = gserverplatform_get_video_height(platform);
|
||||||
glutInit(&argc, argv);
|
glutInit(&argc, argv);
|
||||||
glutInitWindowSize(glut->width, glut->height);
|
glutInitWindowSize(glut->width, glut->height);
|
||||||
glutCreateWindow(PACKAGE " GLUT");
|
glutCreateWindow(PACKAGE " GLUT");
|
||||||
|
@ -186,15 +188,18 @@ static int _idle_timeout(void * data);
|
||||||
static void _glut_idle(void)
|
static void _glut_idle(void)
|
||||||
{
|
{
|
||||||
struct timeval tv;
|
struct timeval tv;
|
||||||
|
GServerPlatform * platform;
|
||||||
Event * event;
|
Event * event;
|
||||||
|
|
||||||
|
platform = video_plugin.helper->get_platform(
|
||||||
|
video_plugin.helper->gserver);
|
||||||
event = video_plugin.helper->get_event(video_plugin.helper->gserver);
|
event = video_plugin.helper->get_event(video_plugin.helper->gserver);
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
tv.tv_sec = 1;
|
tv.tv_sec = 1;
|
||||||
tv.tv_usec = 0;
|
tv.tv_usec = 0;
|
||||||
#else
|
#else
|
||||||
tv.tv_sec = 0;
|
tv.tv_sec = 0;
|
||||||
tv.tv_usec = 1000000 / 60;
|
tv.tv_usec = 1000000 / gserverplatform_get_video_refresh_rate(platform);
|
||||||
#endif
|
#endif
|
||||||
event_register_timeout(event, &tv, _idle_timeout, event);
|
event_register_timeout(event, &tv, _idle_timeout, event);
|
||||||
event_loop(event);
|
event_loop(event);
|
||||||
|
|
|
@ -125,6 +125,7 @@ GServerVideoPlugin video_plugin =
|
||||||
/* glx_init */
|
/* glx_init */
|
||||||
static int _glx_init(GServerVideoPlugin * plugin)
|
static int _glx_init(GServerVideoPlugin * plugin)
|
||||||
{
|
{
|
||||||
|
GServerPlatform * platform;
|
||||||
GLXVideo * glx;
|
GLXVideo * glx;
|
||||||
Event * event;
|
Event * event;
|
||||||
Window root;
|
Window root;
|
||||||
|
@ -146,6 +147,7 @@ static int _glx_init(GServerVideoPlugin * plugin)
|
||||||
if((glx = object_new(sizeof(*glx))) == NULL)
|
if((glx = object_new(sizeof(*glx))) == NULL)
|
||||||
return 1;
|
return 1;
|
||||||
plugin->priv = glx;
|
plugin->priv = glx;
|
||||||
|
platform = plugin->helper->get_platform(plugin->helper->gserver);
|
||||||
event = plugin->helper->get_event(plugin->helper->gserver);
|
event = plugin->helper->get_event(plugin->helper->gserver);
|
||||||
glx->display = XOpenDisplay(NULL);
|
glx->display = XOpenDisplay(NULL);
|
||||||
glx->screen = DefaultScreen(glx->display);
|
glx->screen = DefaultScreen(glx->display);
|
||||||
|
@ -159,8 +161,8 @@ static int _glx_init(GServerVideoPlugin * plugin)
|
||||||
vi = glXChooseVisual(glx->display, glx->screen, attributes);
|
vi = glXChooseVisual(glx->display, glx->screen, attributes);
|
||||||
}
|
}
|
||||||
glx->context = glXCreateContext(glx->display, vi, 0, GL_TRUE);
|
glx->context = glXCreateContext(glx->display, vi, 0, GL_TRUE);
|
||||||
glx->width = 640;
|
glx->width = gserverplatform_get_video_width(platform);
|
||||||
glx->height = 480;
|
glx->height = gserverplatform_get_video_height(platform);
|
||||||
memset(&attr, 0, sizeof(attr));
|
memset(&attr, 0, sizeof(attr));
|
||||||
root = RootWindow(glx->display, vi->screen);
|
root = RootWindow(glx->display, vi->screen);
|
||||||
attr.colormap = XCreateColormap(glx->display, root, vi->visual,
|
attr.colormap = XCreateColormap(glx->display, root, vi->visual,
|
||||||
|
@ -211,7 +213,7 @@ static int _glx_init(GServerVideoPlugin * plugin)
|
||||||
tv.tv_usec = 0;
|
tv.tv_usec = 0;
|
||||||
#else
|
#else
|
||||||
tv.tv_sec = 0;
|
tv.tv_sec = 0;
|
||||||
tv.tv_usec = 1000000 / 60;
|
tv.tv_usec = 1000000 / gserverplatform_get_video_refresh_rate(platform);
|
||||||
#endif
|
#endif
|
||||||
if(_glx_timeout(plugin) == 0)
|
if(_glx_timeout(plugin) == 0)
|
||||||
event_register_timeout(event, &tv, _glx_timeout, plugin);
|
event_register_timeout(event, &tv, _glx_timeout, plugin);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user