diff options
| author | Tristan Gingold <tgingold@free.fr> | 2015-09-12 21:44:59 +0200 | 
|---|---|---|
| committer | Tristan Gingold <tgingold@free.fr> | 2015-09-12 21:44:59 +0200 | 
| commit | bdc8e297b8cc2c36cf9e9ce41007cade06d2ee3f (patch) | |
| tree | 8a13176b25fb96aaed4187baa482392feb0ceccf | |
| parent | d08ed8de338da3b7ea4fcd0139f4ca248c129078 (diff) | |
| download | ghdl-bdc8e297b8cc2c36cf9e9ce41007cade06d2ee3f.tar.gz ghdl-bdc8e297b8cc2c36cf9e9ce41007cade06d2ee3f.tar.bz2 ghdl-bdc8e297b8cc2c36cf9e9ce41007cade06d2ee3f.zip | |
Check llvm version. Fix ghdldrv --post for llvm.
| -rw-r--r-- | README | 5 | ||||
| -rwxr-xr-x | configure | 32 | ||||
| -rw-r--r-- | src/ghdldrv/ghdl_gcc.adb | 2 | ||||
| -rw-r--r-- | src/ghdldrv/ghdl_llvm.adb | 2 | ||||
| -rw-r--r-- | src/ghdldrv/ghdldrv.adb | 229 | ||||
| -rw-r--r-- | src/ghdldrv/ghdldrv.ads | 5 | 
6 files changed, 164 insertions, 111 deletions
| @@ -73,7 +73,7 @@ Building with the gcc backend  *****************************  You need to download and untar the sources of -gcc version 4.9.2 [do not modify this line as this is read by scripts]. +gcc version 4.9 [do not modify this line as this is read by scripts].  First configure ghdl and specify gcc source dir:  $ ./configure --with-gcc=/path/to/gcc/source/dir @@ -88,7 +88,8 @@ enable the vhdl language (you can use --enable-languages=c,vhdl  Building with the llvm backend  ****************************** -You need llvm 3.5 +You need to build and install +llvm version 3.5 [do not modify this line as this is read by scripts].  First configure ghdl and specify where llvm is installed  $ ./configure --with-llvm=PREFIX @@ -36,10 +36,22 @@ else    echoc=  fi -# Read gcc version from README file +# Read required gcc version from README file  gcc_version=`grep '^gcc version' $srcdir/README |   sed -e 's/gcc version \([0-9.]*\) \[.*\]\.$/\1/'` +# Read required llvm version from README file +llvm_version=`grep '^llvm version' $srcdir/README | + sed -e 's/llvm version \([0-9.]*\) \[.*\]\.$/\1/'` + +# Check $1 is a prefix of $2 +function check_version() +{ +  exp_ver=`echo $1 | sed 's/\./v/g'` +  tool_ver=`echo $2 | sed 's/\./v/g'` +  echo $tool_ver | grep -q "^$exp_ver" +} +  # Decode options  for opt do    optarg=`expr x"$opt" : 'x[^=]*=\(.*\)'` @@ -68,14 +80,14 @@ Options [defaults in brackets]:    --prefix=PREFIX   install in PREFIX [$prefix]    --srcdir=SRCDIR   source code path [$srcdir]    --with-gcc=DIR    use gcc backend from DIR (needs gcc $gcc_version) -  --with-llvm=DIR   use llvm installed in DIR +  --with-llvm=DIR   use llvm installed in DIR (needs llvm $llvm_version)  EOF  exit 0  fi  # Sanity checks  # Check that gnatmake exists -if ! $GNATMAKE --version 2> /dev/null; then +if ! $GNATMAKE --version >/dev/null 2>&1; then      echo "Sorry, you need GNAT to build GHDL.  See the README"      echo "(gnatmake executable is: $GNATMAKE)"      exit 1 @@ -108,7 +120,7 @@ if test $backend = gcc; then  	exit 1      fi      base_ver=`cat $gcc_src_dir/gcc/BASE-VER` -    if test x$base_ver != x$gcc_version; then +    if ! check_version $gcc_version $base_ver; then  	echo "Mismatch gcc version from $gcc_src_dir"  	echo "Need gcc version $gcc_version"  	exit 1 @@ -118,11 +130,17 @@ fi  # For llvm backend, check llvm-config  if test $backend = llvm; then      llvm_cmd="$llvm_prefix/bin/llvm-config --version" -    if ! $llvm_cmd > /dev/null 2>&1; then +    llvm_ver=`$llvm_cmd 2>/dev/null` +    if [ $? != 0 ]; then  	echo "cannot run $llvm_cmd"  	exit 1      fi -    # For llvm, the c++ compiler is for linking so that the standard c++ +    if ! check_version $llvm_version $llvm_ver; then +	echo "Mismatch llvm version $llvm_ver from $llvm_prefix" +	echo "Need llvm version $llvm_version" +	exit 1 +    fi +    # For llvm, the c++ compiler isused  for linking so that the standard c++      # library is included.  However, the linker needs the no_compact_unwind      # flag because code generated by gcc is not compatible with compact unwind.      case "$build" in @@ -190,7 +208,7 @@ sed -e "s%@COMPILER_GCC@%ghdl1-gcc%" \      -e "s%@COMPILER_DEBUG@%ghdl1-debug%" \      -e "s%@COMPILER_MCODE@%ghdl1-mcode%" \      -e "s%@COMPILER_LLVM@%bin/ghdl1-llvm%" \ -    -e "s%@POST_PROCESSOR@%oread-gcc%" \ +    -e "s%@POST_PROCESSOR@%oread-$backend%" \      -e "s%@INSTALL_PREFIX@%$prefix%" \      -e "s%@LIB_PREFIX@%$libdirsuffix%" \      < $srcdir/src/ghdldrv/default_pathes.ads.in > default_pathes.ads diff --git a/src/ghdldrv/ghdl_gcc.adb b/src/ghdldrv/ghdl_gcc.adb index 615a8c5d6..d97a7ed16 100644 --- a/src/ghdldrv/ghdl_gcc.adb +++ b/src/ghdldrv/ghdl_gcc.adb @@ -25,7 +25,7 @@ begin     --  Manual elaboration so that the order is known (because it is the order     --  used to display help).     Ghdlmain.Version_String := new String'("GCC back-end code generator"); -   Ghdldrv.Compile_Kind := Ghdldrv.Compile_Gcc; +   Ghdldrv.Backend := Ghdldrv.Backend_Gcc;     Ghdldrv.Register_Commands;     Ghdllocal.Register_Commands;     Ghdlprint.Register_Commands; diff --git a/src/ghdldrv/ghdl_llvm.adb b/src/ghdldrv/ghdl_llvm.adb index 3a3c72b3b..7f2efddc5 100644 --- a/src/ghdldrv/ghdl_llvm.adb +++ b/src/ghdldrv/ghdl_llvm.adb @@ -25,7 +25,7 @@ begin     --  Manual elaboration so that the order is known (because it is the order     --  used to display help).     Ghdlmain.Version_String := new String'("llvm code generator"); -   Ghdldrv.Compile_Kind := Ghdldrv.Compile_Llvm; +   Ghdldrv.Backend := Ghdldrv.Backend_Llvm;     Ghdldrv.Register_Commands;     Ghdllocal.Register_Commands;     Ghdlprint.Register_Commands; diff --git a/src/ghdldrv/ghdldrv.adb b/src/ghdldrv/ghdldrv.adb index 4bacd8902..afea5d42c 100644 --- a/src/ghdldrv/ghdldrv.adb +++ b/src/ghdldrv/ghdldrv.adb @@ -64,6 +64,9 @@ package body Ghdldrv is     --  "-quiet" option.     Dash_Quiet : constant String_Access := new String'("-quiet"); +   --  True if --post is present. +   Flag_Postprocess : Boolean := False; +     --  If set, do not assmble     Flag_Asm : Boolean; @@ -140,20 +143,16 @@ package body Ghdldrv is        Success : Boolean;     begin        --  Create post file. -      case Compile_Kind is -         when Compile_Debug => -            Post_File := Append_Suffix (File, Post_Suffix, In_Work); -         when others => -            null; -      end case; +      if Flag_Postprocess then +         Post_File := Append_Suffix (File, Post_Suffix, In_Work); +      end if;        --  Create asm file. -      case Compile_Kind is -         when Compile_Gcc -           | Compile_Debug => +      case Backend is +         when Backend_Gcc =>              Asm_File := Append_Suffix (File, Asm_Suffix, In_Work); -         when Compile_Llvm -           | Compile_Mcode => +         when Backend_Llvm +           | Backend_Mcode =>              null;        end case; @@ -177,31 +176,35 @@ package body Ghdldrv is              Args (P) := Options (I);           end loop; -         --  Add -quiet. -         case Compile_Kind is -            when Compile_Gcc => -               if not Flag_Not_Quiet then +         --  Add -quiet for gcc, add -c for llvm +         if not Flag_Postprocess then +            case Backend is +               when Backend_Gcc => +                  if not Flag_Not_Quiet then +                     P := P + 1; +                     Args (P) := Dash_Quiet; +                  end if; +               when Backend_Llvm =>                    P := P + 1; -                  Args (P) := Dash_Quiet; -               end if; -            when Compile_Llvm => -               P := P + 1; -               Args (P) := Dash_c; -            when Compile_Debug -              | Compile_Mcode => -               null; -         end case; +                  Args (P) := Dash_c; +               when Backend_Mcode => +                  null; +            end case; +         end if; +         --  Object file (or assembly file).           Args (P + 1) := Dash_o; -         case Compile_Kind is -            when Compile_Debug => -               Args (P + 2) := Post_File; -            when Compile_Gcc => -               Args (P + 2) := Asm_File; -            when Compile_Mcode -              | Compile_Llvm => -               Args (P + 2) := Obj_File; -         end case; +         if Flag_Postprocess then +            Args (P + 2) := Post_File; +         else +            case Backend is +               when Backend_Gcc => +                  Args (P + 2) := Asm_File; +               when Backend_Mcode +                 | Backend_Llvm => +                  Args (P + 2) := Obj_File; +            end case; +         end if;           Args (P + 3) := new String'(File);           My_Spawn (Compiler_Path.all, Args (1 .. P + 3)); @@ -215,10 +218,10 @@ package body Ghdldrv is        end;        --  Post-process. -      if Compile_Kind = Compile_Debug then +      if Flag_Postprocess then           declare              P : Natural; -            Nbr_Args : constant Natural := Last (Postproc_Args) + 4; +            Nbr_Args : constant Natural := Last (Postproc_Args) + 5;              Args : Argument_List (1 .. Nbr_Args);           begin              P := 0; @@ -227,13 +230,26 @@ package body Ghdldrv is                 Args (P) := Postproc_Args.Table (I);              end loop; -            if not Flag_Not_Quiet then -               P := P + 1; -               Args (P) := Dash_Quiet; -            end if; +            case Backend is +               when Backend_Gcc => +                  if not Flag_Not_Quiet then +                     P := P + 1; +                     Args (P) := Dash_Quiet; +                  end if; +               when Backend_Llvm => +                  null; +               when Backend_Mcode => +                  null; +            end case;              Args (P + 1) := Dash_o; -            Args (P + 2) := Asm_File; +            case Backend is +               when Backend_Gcc => +                  Args (P + 2) := Asm_File; +               when Backend_Llvm +                 | Backend_Mcode => +                  Args (P + 2) := Obj_File; +            end case;              Args (P + 3) := Post_File;              My_Spawn (Post_Processor_Path.all, Args (1 .. P + 3));           end; @@ -242,30 +258,34 @@ package body Ghdldrv is        end if;        --  Assemble. -      if Compile_Kind >= Compile_Gcc then -         if Flag_Expect_Failure then -            Delete_File (Asm_File.all, Success); -         elsif not Flag_Asm then -            declare -               P : Natural; -               Nbr_Args : constant Natural := Last (Assembler_Args) + 4; -               Args : Argument_List (1 .. Nbr_Args); -               Success : Boolean; -            begin -               P := 0; -               for I in First .. Last (Assembler_Args) loop -                  P := P + 1; -                  Args (P) := Assembler_Args.Table (I); -               end loop; - -               Args (P + 1) := Dash_o; -               Args (P + 2) := Obj_File; -               Args (P + 3) := Asm_File; -               My_Spawn (Assembler_Path.all, Args (1 .. P + 3)); +      case Backend is +         when Backend_Gcc => +            if Flag_Expect_Failure then                 Delete_File (Asm_File.all, Success); -            end; -         end if; -      end if; +            elsif not Flag_Asm then +               declare +                  P : Natural; +                  Nbr_Args : constant Natural := Last (Assembler_Args) + 4; +                  Args : Argument_List (1 .. Nbr_Args); +                  Success : Boolean; +               begin +                  P := 0; +                  for I in First .. Last (Assembler_Args) loop +                     P := P + 1; +                     Args (P) := Assembler_Args.Table (I); +                  end loop; + +                  Args (P + 1) := Dash_o; +                  Args (P + 2) := Obj_File; +                  Args (P + 3) := Asm_File; +                  My_Spawn (Assembler_Path.all, Args (1 .. P + 3)); +                  Delete_File (Asm_File.all, Success); +               end; +            end if; +         when Backend_Mcode +           | Backend_Llvm => +            null; +      end case;        Free (Asm_File);        Free (Obj_File); @@ -395,16 +415,18 @@ package body Ghdldrv is     begin        --  Set tools name.        if Compiler_Cmd = null then -         case Compile_Kind is -            when Compile_Debug => -               Compiler_Cmd := new String'(Default_Pathes.Compiler_Debug); -            when Compile_Gcc => -               Compiler_Cmd := new String'(Default_Pathes.Compiler_Gcc); -            when Compile_Mcode => -               Compiler_Cmd := new String'(Default_Pathes.Compiler_Mcode); -            when Compile_Llvm => -               Compiler_Cmd := new String'(Default_Pathes.Compiler_Llvm); -         end case; +         if Flag_Postprocess then +            Compiler_Cmd := new String'(Default_Pathes.Compiler_Debug); +         else +            case Backend is +               when Backend_Gcc => +                  Compiler_Cmd := new String'(Default_Pathes.Compiler_Gcc); +               when Backend_Mcode => +                  Compiler_Cmd := new String'(Default_Pathes.Compiler_Mcode); +               when Backend_Llvm => +                  Compiler_Cmd := new String'(Default_Pathes.Compiler_Llvm); +            end case; +         end if;        end if;        if Post_Processor_Cmd = null then           Post_Processor_Cmd := new String'(Default_Pathes.Post_Processor); @@ -451,22 +473,33 @@ package body Ghdldrv is     procedure Locate_Tools is     begin +      --  Compiler.        Compiler_Path := Locate_Exec_Tool (Compiler_Cmd.all);        if Compiler_Path = null then           Tool_Not_Found (Compiler_Cmd.all);        end if; -      if Compile_Kind >= Compile_Debug then + +      --  Postprocessor. +      if Flag_Postprocess then           Post_Processor_Path := Locate_Exec_Tool (Post_Processor_Cmd.all);           if Post_Processor_Path = null then              Tool_Not_Found (Post_Processor_Cmd.all);           end if;        end if; -      if Compile_Kind >= Compile_Gcc then -         Assembler_Path := Locate_Exec_On_Path (Assembler_Cmd); -         if Assembler_Path = null and not Flag_Asm then -            Tool_Not_Found (Assembler_Cmd); -         end if; -      end if; + +      --  Assembler. +      case Backend is +         when Backend_Gcc => +            Assembler_Path := Locate_Exec_On_Path (Assembler_Cmd); +            if Assembler_Path = null and not Flag_Asm then +               Tool_Not_Found (Assembler_Cmd); +            end if; +         when Backend_Llvm +           | Backend_Mcode => +            null; +      end case; + +      --  Linker.        Linker_Path := Locate_Exec_On_Path (Linker_Cmd);        if Linker_Path = null then           Tool_Not_Found (Linker_Cmd); @@ -542,13 +575,7 @@ package body Ghdldrv is           Flag_Asm := True;           Res := Option_Ok;        elsif Opt = "--post" then -         Compile_Kind := Compile_Debug; -         Res := Option_Ok; -      elsif Opt = "--mcode" then -         Compile_Kind := Compile_Mcode; -         Res := Option_Ok; -      elsif Opt = "--llvm" then -         Compile_Kind := Compile_Llvm; +         Flag_Postprocess := True;           Res := Option_Ok;        elsif Opt = "-o" then           if Arg'Length = 0 then @@ -666,14 +693,18 @@ package body Ghdldrv is        Put_Line ("Pathes at configuration:");        Put ("compiler command: ");        Put_Line (Compiler_Cmd.all); -      if Compile_Kind >= Compile_Debug then +      if Flag_Postprocess then           Put ("post-processor command: ");           Put_Line (Post_Processor_Cmd.all);        end if; -      if Compile_Kind >= Compile_Gcc then -         Put ("assembler command: "); -         Put_Line (Assembler_Cmd); -      end if; +      case Backend is +         when Backend_Gcc => +            Put ("assembler command: "); +            Put_Line (Assembler_Cmd); +         when Backend_Llvm +           | Backend_Mcode => +            null; +      end case;        Put ("linker command: ");        Put_Line (Linker_Cmd);        Put_Line ("default lib prefix: " & Default_Pathes.Lib_Prefix); @@ -685,14 +716,18 @@ package body Ghdldrv is        Locate_Tools;        Put ("compiler path: ");        Put_Line (Compiler_Path.all); -      if Compile_Kind >= Compile_Debug then +      if Flag_Postprocess then           Put ("post-processor path: ");           Put_Line (Post_Processor_Path.all);        end if; -      if Compile_Kind >= Compile_Gcc then -         Put ("assembler path: "); -         Put_Line (Assembler_Path.all); -      end if; +      case Backend is +         when Backend_Gcc => +            Put ("assembler path: "); +            Put_Line (Assembler_Path.all); +         when Backend_Llvm +           | Backend_Mcode => +            null; +      end case;        Put ("linker path: ");        Put_Line (Linker_Path.all); diff --git a/src/ghdldrv/ghdldrv.ads b/src/ghdldrv/ghdldrv.ads index 3e37b38f1..ed9c6b07c 100644 --- a/src/ghdldrv/ghdldrv.ads +++ b/src/ghdldrv/ghdldrv.ads @@ -17,9 +17,8 @@  --  02111-1307, USA.  package Ghdldrv is     --  Compiler to use. -   type Compile_Kind_Type is -     (Compile_Mcode, Compile_Llvm, Compile_Gcc, Compile_Debug); -   Compile_Kind : Compile_Kind_Type := Compile_Gcc; +   type Backend_Type is (Backend_Mcode, Backend_Llvm, Backend_Gcc); +   Backend : Backend_Type;     procedure Register_Commands;  end Ghdldrv; | 
