llvm-mirror/win32
Jeff Cohen 98c99a3a02 Unbreak VC++ build.
llvm-svn: 34917
2007-03-05 00:00:42 +00:00
..
Analysis Unbreak VC++ build. 2007-03-05 00:00:42 +00:00
AsmParser Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
bugpoint Unbreak VC++ build. 2006-11-05 19:31:28 +00:00
Bytecode Unbreak VC++ build. 2007-03-05 00:00:42 +00:00
CBackend Unbreak VC++ build. 2007-01-15 20:27:18 +00:00
CodeGen Unbreak VC++ build. 2007-03-05 00:00:42 +00:00
Configure Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
ExecutionEngine Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
Fibonacci Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
Linker Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
llc Unbreak VC++ build. 2007-01-15 20:27:18 +00:00
lli Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
llvm-ar Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
llvm-as Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
llvm-bcanalyzer Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
llvm-dis Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
llvm-ld Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
llvm-link Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
llvm-nm Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
llvm-prof Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
llvm-ranlib Add _CRT_SECURE_NO_DEPRECATE preprocessor symbol to make VS2005 happy. 2006-01-30 04:07:08 +00:00
opt Unbreak VC++ build. 2006-11-05 19:31:28 +00:00
Support Unbreak VC++ build. 2007-03-05 00:00:42 +00:00
System Unbreak VC++ build. 2007-03-05 00:00:42 +00:00
TableGen Unbreak VC++ build. 2007-03-05 00:00:42 +00:00
Target Unbreak VC++ build. 2007-03-05 00:00:42 +00:00
Transforms Unbreak VC++ build. 2007-03-05 00:00:42 +00:00
VMCore Unbreak VC++ build. 2007-03-05 00:00:42 +00:00
x86 Unbreak VC++ build. 2007-03-05 00:00:42 +00:00
.cvsignore Add some .cvsignores to the win32 hierarchy to account for generated files 2005-01-16 03:18:23 +00:00
config.h Unbreak VC++ build. 2006-11-05 19:31:28 +00:00
dobison.cmd Visual Studio enters the future of bisoning. 2006-02-16 04:07:03 +00:00
doflex.cmd Match changes to unix build system. 2006-02-14 06:12:08 +00:00
llvm.sln Unbreak VC++ build. 2006-11-05 19:31:28 +00:00
README.txt Top level files for building natively on win32 2004-11-03 16:14:40 +00:00
unistd.h Top level files for building natively on win32 2004-11-03 16:14:40 +00:00

Directory structure
===================
Although I have made every effort not to use absolute paths, I have only tested building
with my own directory structure and it looks like this:

c:\project\llvm                  ; Main project directory
c:\project\llvm\win32            ; win32 project
c:\project\llvm\win32\tools      ; flex, bison and sed live here
c:\project\llvm\win32\share      ; flex, bison and sed support files

Requirements
============

You need flex, sed and bison - I'm using the GnuWin32 versions of these tools which can be obtained from

http://gnuwin32.sourceforge.net/

Limitations
============

At the moment only the core LLVM libraries and the tablegen executable are built. If anyone has time to
port the rest of the LLVM tools it would be great...

Other notes
===========

When linking with your own application it is of the utmost importance that you use the same runtime
libraries in compiling LLVM as in your own project. Otherwise you will get a lot of errors. To change this,
just mark all the projects except the Config project (since it doesn't use the C compiler) in the
solution explorer, select properties - then go to the C/C++ options and the Code Generation sub option page.
In the Runtime Library (6th from the top) select the appropriate version. Then change the active
configuration to Release (in the top left corner of the properties window) and select the appropriate
runtime library for the release version.

When linking with your applications, you need to force a symbol reference to bring in the x86 backend.
Open the properties for your main project and select the Linker options - under the Input options there
is a Force Symbol References field where you need to enter _X86TargetMachineModule. If anyone has a better
suggestion for how to trick the linker into always pulling in these objects, I'd be grateful...

Contact Information
===================

please contact me at this address if you have any questions:

morten@hue.no


-- Morten Ofstad 2.11.2004