* configure.ac: Add -Wvla if compiler supports it.
This commit is contained in:
		
							parent
							
								
									cd15c394cc
								
							
						
					
					
						commit
						60d5e9cbd9
					
				
					 2 changed files with 39 additions and 2 deletions
				
			
		|  | @ -1,3 +1,7 @@ | ||||||
|  | 2013-12-04  Vladimir Serbinenko  <phcoder@gmail.com> | ||||||
|  | 
 | ||||||
|  | 	* configure.ac: Add -Wvla if compiler supports it. | ||||||
|  | 
 | ||||||
| 2013-12-04  Vladimir Serbinenko  <phcoder@gmail.com> | 2013-12-04  Vladimir Serbinenko  <phcoder@gmail.com> | ||||||
| 
 | 
 | ||||||
| 	* grub-core/osdep/windows/emuconsole.c (grub_console_putchar): | 	* grub-core/osdep/windows/emuconsole.c (grub_console_putchar): | ||||||
|  |  | ||||||
							
								
								
									
										37
									
								
								configure.ac
									
										
									
									
									
								
							
							
						
						
									
										37
									
								
								configure.ac
									
										
									
									
									
								
							|  | @ -422,6 +422,26 @@ esac | ||||||
| # For gnulib. | # For gnulib. | ||||||
| gl_INIT | gl_INIT | ||||||
| 
 | 
 | ||||||
|  | WARN_FLAGS="-Wall -W -Wshadow -Wold-style-definition -Wpointer-arith -Wundef -Wextra -Wattributes -Wchar-subscripts -Wcomment -Wdeprecated-declarations -Wdisabled-optimization -Wdiv-by-zero -Wendif-labels -Wfloat-equal -Wformat-extra-args -Wformat-security -Wformat-y2k -Wimplicit -Wimplicit-function-declaration -Wimplicit-int -Winit-self -Wint-to-pointer-cast -Winvalid-pch -Wmain -Wmissing-braces -Wmissing-field-initializers -Wmissing-format-attribute -Wmultichar -Wnonnull -Woverflow -Wparentheses -Wpointer-arith -Wpointer-to-int-cast -Wreturn-type -Wsequence-point -Wshadow -Wsign-compare -Wstrict-aliasing -Wswitch -Wtrigraphs -Wundef -Wunknown-pragmas -Wunused -Wunused-function -Wunused-label -Wunused-parameter -Wunused-value  -Wunused-variable -Wvariadic-macros -Wvolatile-register-var -Wwrite-strings -Wnested-externs -Wstrict-prototypes -Wpointer-sign" | ||||||
|  | EXTRA_WARN_FLAGS="-Wvla" | ||||||
|  | 
 | ||||||
|  | HOST_CFLAGS="$HOST_CFLAGS $WARN_FLAGS -Wcast-align" | ||||||
|  | 
 | ||||||
|  | AC_CACHE_CHECK([which extra warnings work], [grub_cv_cc_w_extra_flags], [ | ||||||
|  |   SAVED_CFLAGS="$CFLAGS" | ||||||
|  |   grub_cv_cc_w_extra_flags= | ||||||
|  |   for x in $EXTRA_WARN_FLAGS; do | ||||||
|  |       CFLAGS="$HOST_CFLAGS $x -Werror" | ||||||
|  |       AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[]])], [flag=1], [flag=0]) | ||||||
|  |       if test x$flag = x1 ; then | ||||||
|  |          grub_cv_cc_w_extra_flags="$grub_cv_cc_w_extra_flags $x" | ||||||
|  |       fi | ||||||
|  |   done | ||||||
|  |   CFLAGS="$SAVED_CFLAGS" | ||||||
|  | ]) | ||||||
|  | 
 | ||||||
|  | HOST_CFLAGS="$HOST_CFLAGS $grub_cv_cc_w_extra_flags" | ||||||
|  | 
 | ||||||
| # | # | ||||||
| # Check for target programs. | # Check for target programs. | ||||||
| # | # | ||||||
|  | @ -472,8 +492,6 @@ LDFLAGS="$TARGET_LDFLAGS" | ||||||
| LIBS="" | LIBS="" | ||||||
| 
 | 
 | ||||||
| # debug flags. | # debug flags. | ||||||
| WARN_FLAGS="-Wall -W -Wshadow -Wold-style-definition -Wpointer-arith -Wundef -Wextra -Wattributes -Wchar-subscripts -Wcomment -Wdeprecated-declarations -Wdisabled-optimization -Wdiv-by-zero -Wendif-labels -Wfloat-equal -Wformat-extra-args -Wformat-security -Wformat-y2k -Wimplicit -Wimplicit-function-declaration -Wimplicit-int -Winit-self -Wint-to-pointer-cast -Winvalid-pch -Wmain -Wmissing-braces -Wmissing-field-initializers -Wmissing-format-attribute -Wmultichar -Wnonnull -Woverflow -Wparentheses -Wpointer-arith -Wpointer-to-int-cast -Wreturn-type -Wsequence-point -Wshadow -Wsign-compare -Wstrict-aliasing -Wswitch -Wtrigraphs -Wundef -Wunknown-pragmas -Wunused -Wunused-function -Wunused-label -Wunused-parameter -Wunused-value  -Wunused-variable -Wvariadic-macros -Wvolatile-register-var -Wwrite-strings -Wnested-externs -Wstrict-prototypes -Wpointer-sign" |  | ||||||
| HOST_CFLAGS="$HOST_CFLAGS $WARN_FLAGS -Wcast-align" |  | ||||||
| TARGET_CFLAGS="$TARGET_CFLAGS $WARN_FLAGS -g -Wredundant-decls -Wmissing-prototypes -Wmissing-declarations" | TARGET_CFLAGS="$TARGET_CFLAGS $WARN_FLAGS -g -Wredundant-decls -Wmissing-prototypes -Wmissing-declarations" | ||||||
| TARGET_CCASFLAGS="$TARGET_CCASFLAGS -g" | TARGET_CCASFLAGS="$TARGET_CCASFLAGS -g" | ||||||
| 
 | 
 | ||||||
|  | @ -481,6 +499,21 @@ if test "x$target_cpu" != xi386 && test "x$target_cpu" != xx86_64; then | ||||||
| TARGET_CFLAGS="$TARGET_CFLAGS -Wcast-align" | TARGET_CFLAGS="$TARGET_CFLAGS -Wcast-align" | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
|  | AC_CACHE_CHECK([which extra warnings work], [grub_cv_target_cc_w_extra_flags], [ | ||||||
|  |   LDFLAGS="$TARGET_LDFLAGS -nostdlib -static" | ||||||
|  | 
 | ||||||
|  |   grub_cv_target_cc_w_extra_flags= | ||||||
|  |   for x in $EXTRA_WARN_FLAGS; do | ||||||
|  |       CFLAGS="$TARGET_CFLAGS $x -Werror" | ||||||
|  |       AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[]])], [flag=1], [flag=0]) | ||||||
|  |       if test x$flag = x1 ; then | ||||||
|  |          grub_cv_target_cc_w_extra_flags="$grub_cv_target_cc_w_extra_flags $x" | ||||||
|  |       fi | ||||||
|  |   done | ||||||
|  | ]) | ||||||
|  | 
 | ||||||
|  | TARGET_CFLAGS="$TARGET_CFLAGS $grub_cv_target_cc_w_extra_flags" | ||||||
|  | 
 | ||||||
| AC_CACHE_CHECK([if compiling with clang], [grub_cv_cc_target_clang] | AC_CACHE_CHECK([if compiling with clang], [grub_cv_cc_target_clang] | ||||||
| [AC_COMPILE_IFELSE( | [AC_COMPILE_IFELSE( | ||||||
| [AC_LANG_PROGRAM([], [[ | [AC_LANG_PROGRAM([], [[ | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue