Xi: when creating a new master device, update barries for all clients
The previous code only worked when the barrier was created by the same client as the one calling XIChangeDeviceHierarchy. http://bugzilla.redhat.com/show_bug.cgi?id=1384432 Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net> Reviewed-by: Daniel Stone <daniels@collabora.com>
This commit is contained in:
parent
5611585b87
commit
d6a6e1d6ab
|
@ -194,7 +194,8 @@ add_master(ClientPtr client, xXIAddMasterInfo * c, int flags[MAXDEVICES])
|
||||||
flags[XTestptr->id] |= XISlaveAttached;
|
flags[XTestptr->id] |= XISlaveAttached;
|
||||||
flags[XTestkeybd->id] |= XISlaveAttached;
|
flags[XTestkeybd->id] |= XISlaveAttached;
|
||||||
|
|
||||||
XIBarrierNewMasterDevice(client, ptr->id);
|
for (int i = 0; i < currentMaxClients; i++)
|
||||||
|
XIBarrierNewMasterDevice(clients[i], ptr->id);
|
||||||
|
|
||||||
unwind:
|
unwind:
|
||||||
free(name);
|
free(name);
|
||||||
|
@ -300,7 +301,8 @@ remove_master(ClientPtr client, xXIRemoveMasterInfo * r, int flags[MAXDEVICES])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
XIBarrierRemoveMasterDevice(client, ptr->id);
|
for (int i = 0; i < currentMaxClients; i++)
|
||||||
|
XIBarrierRemoveMasterDevice(clients[i], ptr->id);
|
||||||
|
|
||||||
/* disable the remove the devices, XTest devices must be done first
|
/* disable the remove the devices, XTest devices must be done first
|
||||||
else the sprites they rely on will be destroyed */
|
else the sprites they rely on will be destroyed */
|
||||||
|
|
Loading…
Reference in New Issue