mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-30 10:45:40 +03:00 
			
		
		
		
	A larger number of format specifiers coudld cause a stack overflow, potentially allowing to bypass _FORTIFY_SOURCE format string protection.
		
			
				
	
	
		
			71 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include <stdio.h>
 | |
| #include <string.h>
 | |
| #include <stdlib.h>
 | |
| 
 | |
| static const char expected[] = "\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55\
 | |
| \n\
 | |
| a\n\
 | |
| abbcd55%%%%%%%%%%%%%%%%%%%%%%%%%%\n";
 | |
| 
 | |
| static int
 | |
| do_test (void)
 | |
| {
 | |
|   char *buf = malloc (strlen (expected) + 1);
 | |
|   snprintf (buf, strlen (expected) + 1,
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d"
 | |
| 	    "%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\n",
 | |
| 	    "a", "b", "c", "d", 5);
 | |
|   return strcmp (buf, expected) != 0;
 | |
| }
 | |
| 
 | |
| #define TEST_FUNCTION do_test ()
 | |
| #include "../test-skeleton.c"
 |