Message-Id: <199705122252.SAA19887@delorie.com> Date: Mon, 12 May 1997 11:43:23 +0200 (METDST) From: Robert Hoehne <robert DOT hoehne AT Mathematik DOT TU-Chemnitz DOT DE> To: DJGPP-ANNOUNCE <djgpp-announce AT delorie DOT com> Subject: ANNOUNCE: obj2bfd, a converter for MS .obj files to COFF Mime-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Precedence: bulk Precedence: bulk This is to announce that OBJ2BFD version 0.1 has been uploaded to SimTel.NET mirrors: ftp:/ftp.simtel.net/pub/simtelnet/gnu/djgpp/v2apps/o2bfd01b.zip ftp:/ftp.simtel.net/pub/simtelnet/gnu/djgpp/v2apps/o2bfd01s.zip For a description of OBJ2BFD please read below the readme from the above achives. --------------------------- Here I will give you some hints about rebuilding and using OBJ2BFD, the converter of .obj files to an object format, supported by the in OBJ2BFD linked BFD library. Why an other converter for .obj files? ====================================== The need for this converter cames from the fact, that the GNU linker, which comes with binutils 2.7, cannot handle libraries, which have different types of object files. That means, emxaout created aout object files from .obj files and if you put them together with COFF object files in a library you was not able to use that library. Most of the source code in OBJ2BFD is taken from emxaout, written by Eberhard Mattes. I have changed and added "only" the code to support the BFD output format(s). The biggest problem was the relocation and since I don't have a tool to create 32-bit .obj files, I couldn't test it in all cases. So, if you have any problems with the created object files by OBJ2BFD, please send any .obj file which produces the error together with the other files to build a small executable and a describtion what should be and what happened. I will try then to give my best to fix the possible bug. Limitations =========== Since DJGPP supports ONLY 32-bit object files, OBJ2BFD can be used also on .obj files which are compiled in the flat memory model Requirements for compiling OBJ2BFD are: ======================================= 1) You have installed the BFD library sources at least from version 2.7. These can be the BFD library from binutils 2.7 or from gdb 4.16 on DJGPP, which has also the BFD library 2.7 (I say here that you need at least version 2.7, because I haven't tried it with an other version). 2) Together with the BFD library you need also the libiberty library, which comes with that package. Before you can link OBJ2BFD you have to build at first the two libraries 'libbfd.a' and 'libibert.a'. Since I made this only for DJGPP I have the names truncated to fit the 8+3 filename limit. If you want to build OBJ2BFD on an other (unix) environment, you have to change the names in the makefile 'obj2bfd.mak'. After successfull building of the two above mentioned libraries you can run make and OBJ2BFD will be build. I have not added any rule in the makefiles to build that libraries. You have to do this manually. Here are the steps, if I assume, that you have installed them in c:/djgpp/gnu/binutl-2.7 c: cd \djgpp\gnu\binutl-2.7\libibert make cd ..\bfd make If you have not installed the BFD library in the default directory, ( %DJDIR%/gnu/binutl-2.7 ), then you have to modify also the path in 'makefile' to the correct directory. The makefile 'obj2bfd.mak' is generated automaticaly by RHIDE, and so it may look a little bit confusing to you if you don't have so much knowlage about makefiles. How to use OBJ2BFD? =================== The usage of OBJ2BFD is very simple. Usage: obj2bfd [-u] [-O <output-target>] -o <output_file> <input_file> obj2bfd [-u] [-O <output-target>] <input_file(s)> Options: -u Don't add leading underscores -o <output_file> Write output to <output_file> -O <outout-target> Create object format <output-target> As you can see, you have to specify on commandline in most cases only the input and the output filename and that's all. Since the BFD library can support multiple object formats, you can select the output-target also with the -O switch if you need or want an other than the default. The default is currently 'coff-go32', the COFF object file format used by DJGPP. Example: To convert all the .obj files in a directory to COFF objectfiles, you can type obj2bfd *.obj The switch '-u' comes originaly from emxaout. This program was originaly written for the SciTech MGL Graphics library to convert the .obj files, but it can be used also for any other purposes. If you any problems or questions to OBJ2BFD, mail me. Happy programming, Robert Hoehne <robert DOT hoehne AT mathematik DOT tu-chemnitz> ***************************************************************** * Robert Hoehne, Fakultaet fuer Mathematik, TU-Chemnitz-Zwickau * * Post: Am Berg 3, D-09573 Dittmannsdorf * * e-Mail: Robert DOT Hoehne AT Mathematik DOT TU-Chemnitz DOT DE * * WWW: http://www.tu-chemnitz.de/~rho * *****************************************************************