Fix XRecordRegisterClients() Integer underflow
CVE-2020-14362 ZDI-CAN-11574 This vulnerability was discovered by: Jan-Niklas Sohn working with Trend Micro Zero Day Initiative Signed-off-by: Matthieu Herrb <matthieu@herrb.eu>
This commit is contained in:
		
							parent
							
								
									144849ea27
								
							
						
					
					
						commit
						2902b78535
					
				|  | @ -2500,7 +2500,7 @@ SProcRecordQueryVersion(ClientPtr client) | ||||||
| }                               /* SProcRecordQueryVersion */ | }                               /* SProcRecordQueryVersion */ | ||||||
| 
 | 
 | ||||||
| static int _X_COLD | static int _X_COLD | ||||||
| SwapCreateRegister(xRecordRegisterClientsReq * stuff) | SwapCreateRegister(ClientPtr client, xRecordRegisterClientsReq * stuff) | ||||||
| { | { | ||||||
|     int i; |     int i; | ||||||
|     XID *pClientID; |     XID *pClientID; | ||||||
|  | @ -2510,13 +2510,13 @@ SwapCreateRegister(xRecordRegisterClientsReq * stuff) | ||||||
|     swapl(&stuff->nRanges); |     swapl(&stuff->nRanges); | ||||||
|     pClientID = (XID *) &stuff[1]; |     pClientID = (XID *) &stuff[1]; | ||||||
|     if (stuff->nClients > |     if (stuff->nClients > | ||||||
|         stuff->length - bytes_to_int32(sz_xRecordRegisterClientsReq)) |         client->req_len - bytes_to_int32(sz_xRecordRegisterClientsReq)) | ||||||
|         return BadLength; |         return BadLength; | ||||||
|     for (i = 0; i < stuff->nClients; i++, pClientID++) { |     for (i = 0; i < stuff->nClients; i++, pClientID++) { | ||||||
|         swapl(pClientID); |         swapl(pClientID); | ||||||
|     } |     } | ||||||
|     if (stuff->nRanges > |     if (stuff->nRanges > | ||||||
|         stuff->length - bytes_to_int32(sz_xRecordRegisterClientsReq) |         client->req_len - bytes_to_int32(sz_xRecordRegisterClientsReq) | ||||||
|         - stuff->nClients) |         - stuff->nClients) | ||||||
|         return BadLength; |         return BadLength; | ||||||
|     RecordSwapRanges((xRecordRange *) pClientID, stuff->nRanges); |     RecordSwapRanges((xRecordRange *) pClientID, stuff->nRanges); | ||||||
|  | @ -2531,7 +2531,7 @@ SProcRecordCreateContext(ClientPtr client) | ||||||
| 
 | 
 | ||||||
|     swaps(&stuff->length); |     swaps(&stuff->length); | ||||||
|     REQUEST_AT_LEAST_SIZE(xRecordCreateContextReq); |     REQUEST_AT_LEAST_SIZE(xRecordCreateContextReq); | ||||||
|     if ((status = SwapCreateRegister((void *) stuff)) != Success) |     if ((status = SwapCreateRegister(client, (void *) stuff)) != Success) | ||||||
|         return status; |         return status; | ||||||
|     return ProcRecordCreateContext(client); |     return ProcRecordCreateContext(client); | ||||||
| }                               /* SProcRecordCreateContext */ | }                               /* SProcRecordCreateContext */ | ||||||
|  | @ -2544,7 +2544,7 @@ SProcRecordRegisterClients(ClientPtr client) | ||||||
| 
 | 
 | ||||||
|     swaps(&stuff->length); |     swaps(&stuff->length); | ||||||
|     REQUEST_AT_LEAST_SIZE(xRecordRegisterClientsReq); |     REQUEST_AT_LEAST_SIZE(xRecordRegisterClientsReq); | ||||||
|     if ((status = SwapCreateRegister((void *) stuff)) != Success) |     if ((status = SwapCreateRegister(client, (void *) stuff)) != Success) | ||||||
|         return status; |         return status; | ||||||
|     return ProcRecordRegisterClients(client); |     return ProcRecordRegisterClients(client); | ||||||
| }                               /* SProcRecordRegisterClients */ | }                               /* SProcRecordRegisterClients */ | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue