mirror of
				https://github.com/yuzu-emu/mbedtls.git
				synced 2025-10-26 12:37:40 +00:00 
			
		
		
		
	Fix integer overflow in benchmark program
When building with MBEDTLS_MEMORY_DEBUG enabled, and running the ecdh part, the benchmark program would start writing a very large number of space characters on stdout, and would have to be killed because it never seemed to terminate. This was due to an integer overflow in computing how many space to leave after the title in order to get memory measurements aligned, which resulted in up to SIZE_MAX spaces being printed. This commit just fixes the overflow, the next commit is going to fix the magic number (12). Signed-off-by: Manuel Pégourié-Gonnard <manuel.pegourie-gonnard@arm.com>
This commit is contained in:
		
							parent
							
								
									e61988a766
								
							
						
					
					
						commit
						5408f72027
					
				|  | @ -141,7 +141,8 @@ do {                                                                    \ | |||
| 
 | ||||
| #define MEMORY_MEASURE_PRINT( title_len )                               \ | ||||
|     mbedtls_memory_buffer_alloc_max_get( &max_used, &max_blocks );      \ | ||||
|     for( ii = 12 - title_len; ii != 0; ii-- ) mbedtls_printf( " " );    \ | ||||
|     for( ii = 12 > (title_len) ? 12 - (title_len) : 1; ii !=0; ii--)    \ | ||||
|         mbedtls_printf( " " );                                          \ | ||||
|     max_used -= prv_used;                                               \ | ||||
|     max_blocks -= prv_blocks;                                           \ | ||||
|     max_bytes = max_used + MEM_BLOCK_OVERHEAD * max_blocks;             \ | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue