Deinitialization fixes, in case if QNXGF driver is not initialized properly.

--HG--
extra : convert_revision : svn%3Ac70aab31-4412-0410-b14c-859654838e24/trunk%404202
This commit is contained in:
Mike Gorchak 2009-11-20 07:06:50 +00:00
parent 413e9a6218
commit 6e0c12e7f7
2 changed files with 20 additions and 3 deletions

View file

@ -1071,6 +1071,7 @@ hiddi_connect_devices()
status = hidd_connect(&hidparams, &connection);
if (status != EOK) {
connection=NULL;
return -1;
}
@ -1097,6 +1098,7 @@ hiddi_connect_devices()
/* Disconnect from HID server */
status = hidd_disconnect(connection);
if (status != EOK) {
connection=NULL;
return -1;
}
@ -1105,6 +1107,7 @@ hiddi_connect_devices()
status = hidd_connect(&hidparams, &connection);
if (status != EOK) {
connection=NULL;
return -1;
}
@ -1119,11 +1122,14 @@ hiddi_disconnect_devices()
hiddi_disable_mouse();
/* Disconnect from HID server */
if (connection!=NULL)
{
status = hidd_disconnect(connection);
if (status != EOK) {
return -1;
}
}
}
void
hiddi_enable_mouse()

View file

@ -251,6 +251,9 @@ qnxgf_create(int devindex)
}
device->driverdata = gfdata;
/* By default GF is not initialized */
gfdata->gfinitialized = SDL_FALSE;
/* Try to attach to graphics device driver */
status =
gf_dev_attach(&gfdata->gfdev, GF_DEVICE_INDEX(devindex),
@ -543,9 +546,17 @@ qnxgf_videoinit(_THIS)
void
qnxgf_videoquit(_THIS)
{
SDL_VideoData *gfdata = (SDL_VideoData *) _this->driverdata;
SDL_DisplayData *didata = NULL;
uint32_t it;
/* Check if GF was initialized before */
if ((gfdata == NULL) || (gfdata->gfinitialized != SDL_TRUE))
{
/* If not, do not deinitialize */
return;
}
/* Stop collecting mouse events */
hiddi_disable_mouse();
/* Delete GF input devices */