dix: fix endianess issue in AddInputDevice. #18111
dev->enabled is a Bool. Bool is two bytes. BOOL on the other hand is a protocol type and always 1 byte. So copy the value into the one-byte type before passing it into XIChangeDeviceProperty. Found by Michel Dänzer. X.Org Bug 18111 <http://bugs.freedesktop.org/show_bug.cgi?id=18111>
This commit is contained in:
		
							parent
							
								
									f6cbe0326c
								
							
						
					
					
						commit
						98f01c2abe
					
				| 
						 | 
				
			
			@ -139,6 +139,7 @@ AddInputDevice(ClientPtr client, DeviceProc deviceProc, Bool autoStart)
 | 
			
		|||
    DeviceIntPtr devtmp;
 | 
			
		||||
    int devid;
 | 
			
		||||
    char devind[MAX_DEVICES];
 | 
			
		||||
    BOOL enabled;
 | 
			
		||||
 | 
			
		||||
    /* Find next available id */
 | 
			
		||||
    memset(devind, 0, sizeof(char)*MAX_DEVICES);
 | 
			
		||||
| 
						 | 
				
			
			@ -183,8 +184,9 @@ AddInputDevice(ClientPtr client, DeviceProc deviceProc, Bool autoStart)
 | 
			
		|||
    *prev = dev;
 | 
			
		||||
    dev->next = NULL;
 | 
			
		||||
 | 
			
		||||
    enabled = TRUE;
 | 
			
		||||
    XIChangeDeviceProperty(dev, XIGetKnownProperty(XI_PROP_ENABLED),
 | 
			
		||||
                           XA_INTEGER, 8, PropModeReplace, 1, &dev->enabled,
 | 
			
		||||
                           XA_INTEGER, 8, PropModeReplace, 1, &enabled,
 | 
			
		||||
                           FALSE);
 | 
			
		||||
    XISetDevicePropertyDeletable(dev, XIGetKnownProperty(XI_PROP_ENABLED), FALSE);
 | 
			
		||||
    XIRegisterPropertyHandler(dev, DeviceSetProperty, NULL, NULL);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue