home *** CD-ROM | disk | FTP | other *** search
/ Amiga ISO Collection / AmigaUtilCD2.iso / Programming / GCC / GCC258_4.README < prev    next >
Encoding:
Text File  |  1994-02-11  |  13.7 KB  |  375 lines

  1. Short: gcc-2.5.8 full dist part 4: extra binaries.
  2. Type: dev/gcc
  3. Uploader: phb@colombo.telesys-innov.fr
  4. Author: phb@colombo.telesys-innov.fr
  5.  
  6. This directory contains the 2.5.8 release of the GNU C compiler.
  7. It includes all of the support for compiling C++ and Objective C,
  8. including a run-time library for Objective C.
  9.  
  10. The GNU C compiler is free software.  See the file COPYING for copying
  11. permission.
  12.  
  13. =======
  14. WARNING
  15. =======
  16.  
  17. This version of gcc has succesfully compiled itself 3 times (up to stage 3) and
  18. was used to compile some utilities such as perl, bison and C++ library.
  19.  
  20. Please test it and reports any bugs to:
  21.  
  22.     Philippe BRAND
  23.     Fidonet: Ramses The Amiga Flying BBS 2:320/104.21
  24.     Email:   phb@colombo.telesys-innov.fr
  25.     Ftp:     192.70.117.81 (sorry, DNS messed up at our regional coord).
  26.              /pub/incoming/uploads.
  27.  
  28. ==========================
  29. What's new in this release
  30. ==========================
  31. 2.5.8:
  32.  
  33. -Read FSF NEWS-2.5.8 file included.
  34. -More internal compiler bugs fixed (see ChangeLogs in gcc sources for details),
  35.  some for C++ support.
  36. -GCC-Install script fixed by Claus Deckhut (to be used with full distrib).
  37. -Upgrade to libg++-2.5.3.
  38. -trace.c updated by J. Hoehle to avoid buffer overflows.
  39.  
  40. 2.5.7:
  41.  
  42. -Read FSF NEWS file included.
  43. -More internal compiler bugs fixed (see ChangeLogs in gcc sources for details),
  44.  a lot for C++ support.
  45. -Fred Fish seems to have finally found an annoying bug which prevented
  46.  to compile a resident version of GCC, or to compile resident programs. But
  47.  don't try it anyway 'cause there's still lack of library support as for now.
  48. -Man command now works, this one was my fault (well in fact like others ;-),
  49.  fix done by Tom Haiko.
  50. -Infoview works also, it was an internal path problem.
  51. -libamy.a HAS TO BE RENAMED to libamiga.a because new ld won't find libamy.a
  52. -upgrade to new C++ library v2.5.1.
  53.  
  54. ===================
  55. EXTREMELY IMPORTANT
  56. ===================
  57.  
  58. I'd like to create a new gcc-2.5.8 development tree, based on users wishes.
  59. So now take your favorite mailer program and send me mail with wishes,
  60. bug fixes (example is for the installer script, already done, or headers),
  61. ideas, etc...
  62.  
  63. I had a major hard-disk crash (backup ? somebody said backup ? Okay now I'll do
  64. backup ;-) So I've lost some fixed headers like time.h (author will know) and
  65. other stuff.
  66.  
  67. So any ideas are welcome. Remember that YOU use gcc so it should at least
  68. please YOU.
  69.  
  70. =========
  71. IMPORTANT
  72. =========
  73.  
  74. NEW: well, old but I've never thought about this before: there's an amiga-gcc
  75. mailing list running in Finland, to which I'm subscribed:
  76.  
  77.     amiga-gcc-port@lists.funet.fi
  78.     
  79. This should be the PREFERED place to send comments/bugs/flames/etc...
  80.  
  81. I'm quite tired of forwarding x times same answer to people so I really think
  82. this mailing list is the right thing.
  83. I'll forward any question to this mailing-list, but please use it directly,
  84. except when you send files, in this case send them to my ftp site.
  85.  
  86. =======
  87. History
  88. =======
  89.  
  90. Gcc v2.2.2 port:   Markus Wild
  91. Gcc v2.3.3 port:   Markus Wild
  92. Gcc v2.4.5 port:   Philippe Brand ,Lars Hecking, Fred Fish
  93. Gcc v2.5.0 and up: Philippe Brand, Fred Fish
  94.  
  95. =======
  96. Sources
  97. =======
  98.  
  99. This archive should contain everything necessary to get you going, it doesn't
  100. include the sources for ixemul.library (should be available RSN as a different
  101. distribution, or ask Markus Wild), and it doesn't include full sources to gcc.
  102.  
  103. As stated by Richard Stallman of the FSF:
  104.  
  105. "The GPL says that any distribution of binaries must contain either the
  106. source code or a written offer to supply source code (see the GPL for
  107. details of what is required)."
  108.  
  109. If you're interested in the sources required to rebuild gcc, get the original
  110. GNU sources (gcc-2.5.8.tar.gz, somewhat 6MB), which should be stored on the
  111. same ftp site you got this binary distribution from (if they're not, tell the
  112. manager of that ftp site, as this is a requirement of the GNU Copyright
  113. LICENSE), or at ftp.gnu.ai.mit.edu:/pub/gnu, or on Ramses BBS (phone numbers
  114. listed below), otherwise ask me by smail then we'll manage to find a solution
  115. for you to get full sources.
  116.  
  117. Then apply the gcc patch-file in src-patches/, and configure for
  118. `amigados'. Same thing goes for libg++-2.5.3. If you want (ie. you don't have
  119. to) get libg++-2.5.3.tar.gz (again, locations are explained below) and apply
  120. the libg++ diff from the src-patches directory, then configure for amigados
  121. and give it a try. Please note that you should have at least 40MB left or your
  122. HD and 8MB of memory minimum in order to rebuild gcc up to stage3. An
  123. accelerated Amiga is welcome, as it took me 4,5 hours to generate a single
  124. pass. So 3 passes makes 4,5 x 3 = 13,5 hours.
  125.  
  126. Sources for other tools only included as binaries are available separately
  127. in self-contained archives (such as for example gnuinfo-920712.lha for
  128. InfoView), same locations, as described below.
  129.  
  130. NOTE: gcc258src.lha has been posted to Aminet sites so you don't have to
  131. look for sources elsewhere and diffs have already been aplied.
  132.  
  133. =====
  134. Where
  135. =====
  136.  
  137. **** All GCC binaries (from 2.2.2 upto 2.5.8) are available on:
  138.  
  139. - Aminet sites (wuarchive.wustl.edu and mirrors such as ftp.luth.se)
  140.     in /pub/aminet/dev/gcc
  141.  
  142. - Ramses The Amiga Flying BBS  +33-1-60037015  HST Dual v32 terbo 4800-21600
  143.                                +33-1-60037713  SupraFax v32bis    4800-14400
  144.                                +33-1-60037716  Tornado v22bis     1200-2400
  145.     in Topic "Development", Area "Gcc"
  146.  
  147. **** GNU source code is available on:
  148.  
  149. - same FTP site you've taken these archives
  150.  
  151. - gnu.prep.ai.mit.edu 18.71.0.38
  152.     in /pub/gnu
  153.  
  154. - Ramses The Amiga Flying BBS
  155.     in Topic "AmigaUnix/Unix/Linux/NetBSD", Area "Gnu Source Code"
  156.  
  157. ======
  158. Layout
  159. ======
  160.  
  161. WARNING: Locations of files have changed from 2.4.5 to conform FSF tree.
  162. WARNING2: g++-include directory has moved to /lib/g++-include
  163.  
  164. Gcc-2.5.8 is splited into 5 archives:
  165.  
  166. gcc258-1.lha        basic gcc distribution, all what you need is there.
  167. gcc258-2.lha        C++, Objective-C binaries, headers and libraries.
  168. gcc258-3.lha        docs in man & TexInfo formats, includes InfoView & man
  169. gcc258-4.lha        extra binaries in /bin (UN*X utilities).
  170. gcc258-5.lha        Full Gcc sources amiga ready.
  171.  
  172. gcc258.lha        update from 2.5.6+ to 2.5.8.
  173.  
  174. Name            What                    Where    
  175. ----            ----                    -----
  176.  
  177. COPYING            GNU LICENSE, read!!            All archives
  178. README.2.5.8        this file                All archives
  179. NEWS_gcc-2.5.8        What's new in gcc-2.5.8            gcc258-1.lha
  180. NEWS_libg++-2.5.3    What's new in libg++-2.5.3        gcc258-2.lha
  181. Installer        Commodore installer utility        gcc258-1.lha
  182. GCC-Install        Installer script to configure gcc    gcc258-1.lha
  183. InfoView        this is a viewer for .info-* files as
  184.             you find them in info/. Please read    gcc258-3.lha
  185. InfoView.info        thru this README before trying to use    gcc258-3.lha
  186.             it, you need to setup some things for
  187.             it to work!
  188. envarc/            global environment variables you should
  189.             have set when using this programming    gcc258-1.lha
  190.             environment
  191. include/        non-amiga specific C/C++ headers    gcc258-1.lha
  192. os-include/        amiga specific C/C++ headers. Add    gcc258-1.lha
  193.             Commodore headers!!        
  194. os-lib/            amiga specific libraries        gcc258-1.lha
  195. lib/g++-include/    C++ headers (for libg++)        gcc258-2.lha
  196. info/            manuals for the compiler, libg++, etc.    gcc258-3.lha
  197. ixpipe/            a pipe handler needed by the library    gcc258-1.lha
  198. libauto/        experimental lib to open shared libs    gcc258-1.lha
  199.             at startup
  200. dev/            empty as for now, but needed.        gcc258-1.lha
  201. libs/            ixemul.library and ixemul.trace        gcc258-1.lha
  202. rexx/            ARexx wrappers for gcc and g++        gcc258-1.lha
  203. src-patches/        source patches                gcc258-1.lha
  204. etc/            this is /etc, and contains a config    gcc258-1.lha
  205.             file for `man'
  206. lib/            normal (not base relatives) libraries    gcc258-1.lha
  207.                                 gcc258-2.lha
  208. lib/gcc-lib/        home of compilers called by gcc        gcc258-1.lha
  209.                                 gcc258-2.lha
  210. bin/            this is /bin, and contains all         gcc258-1.lha
  211.             binaries of this distribution that    gcc258-2.lha
  212.             are meant to be directly invoked by    gcc258-3.lha
  213.             the user (contrary to the executables    gcc258-4.lha
  214.                  in compilers/, that are meant to be
  215.             invoked by a driver program like gcc)
  216. geninline/        Perl scripts to generate inline headers    gcc258-1.lha
  217.             and -lamy glue
  218. man/            this is the root for tons of man pages    gcc258-3.lha
  219.  
  220. ==============
  221. Inline-Headers
  222. ==============
  223.  
  224. Since I'm not able to redistribute amiga header files, you will have to get
  225. them directly from Commodore, unless you're an official registrated Amiga
  226. developper. In order to generate inline-headers, follow these steps (provided
  227. amiga headers and fd files are in os-include). You don't have to generate them
  228. if you use OS3.1 (40.13 headers).
  229.  
  230. CLI> Assign INCLUDE: GCC:os-include
  231. CLI> Assign FD: INCLUDE:fd
  232. CLI> Makedir INCLUDE:inline
  233. CLI> cd USR:bin/geninline
  234. CLI> gen31
  235.  
  236. This will create all inline-headers. If you have 2.0 headers, use gen20
  237. instead, if you have 3.0, use gen30, if you have 6.4, send it to me ;-)
  238.  
  239. NOTE: perl scripts do not handle correctly AmigaDOS include files, which
  240. seems to mean they are somewhat broken. If someone could work on this...
  241.  
  242. ============
  243. Installation
  244. ============
  245.  
  246. 1) If this is your first installation of GCC:
  247.  
  248. CLI> cd Disk_with_lot_space:
  249. CLI> lha x gcc258-x.lha (where x stands for 1 through 4, 5 if you need sources)
  250.  
  251. Now from the Workbench, invoke GCC-Install. This is what people wanted, e.g.
  252. an Installer based configuration script for GCC.
  253.  
  254. Thus you only have to unpack archives and the installer script will do the
  255. rest, creating environment variables, adding assigns to user-startup, copy
  256. library and handler.
  257.  
  258. BTW:
  259.  
  260. Installer and Installer project icon
  261. (c) Copyright 1991-93 Commodore-Amiga, Inc.  All Rights Reserved.
  262. Reproduced and distributed under license from Commodore.
  263.  
  264.  
  265. 2) If you "upgrade" your gcc environment from v2.x.x, well just erase
  266.    gcc directory then go back to step 1. Too many stuff have changed. Just
  267.    make sure you've backuped all what you've added to the GCC tree before.
  268.  
  269. Note that you MUST use ixemul.library revision 45 and NOT revision 47, has
  270. the latter doesn't check for ENV:
  271.      
  272. =====
  273. ARexx
  274. =====
  275.  
  276. The provided ARexx scripts have been contributed by Loren J. Rittle.
  277. If you like ARexx, they're an alternate way of calling gcc. They 
  278. automatically make sure you're using a large enough stack setting, and 
  279. enable you to compile C++ programs with less obscure options. This 
  280. approach is furthermore useful if you're not able to use the g++ /bin/sh
  281. script.
  282.  
  283. ===============
  284. gcc versus gccv
  285. ===============
  286.  
  287. gccv stands for a gcc using vfork() to spawn a new process, and then calling
  288. the new execve() function in ixemul.library to call its subcompilers. Gcc
  289. continues to using the more system friendly RunCommand() function in
  290. dos.library to start subcompilers. Gccv has the advantage of being able to
  291. work with interprocess pipes, thus (provided you have the memory ;-)), you're
  292. able to do
  293.  
  294.     gccv -pipe your_program.c
  295.  
  296. causing the preprocessor (cpp), the C-compiler (cc1) and the assembler (as)
  297. to run at the same time, passing intermediate files thru internal pipes 
  298. instead of using temporary files.
  299.  
  300. As long as you don't want that feature (ok, playing with certain make tools
  301. also requires gccv) you're safe using gcc.
  302.  
  303. ==========
  304. stack size
  305. ==========
  306.  
  307. You need to have a 50.000 stack size in order to compile with GCC. This should
  308. be enough for most projects. Note than while recompiling gcc with itself it
  309. didn't take more than 71KB stack. But stack can grow due to source complexity.
  310. Don't be afraid of it.
  311.  
  312. To use ar and/or ranlib, you should have a much larger stack, between
  313. 200.000 and 300.000, depending on library size.
  314.  
  315. ===========
  316. C++ headers
  317. ===========
  318.  
  319. Because AmigaDOS way of handling filenames, making no difference if
  320. file has capitals or not, you'll certainly run into problems with
  321. some headers, including String.h and normal string.h. My suggestion for
  322. now is to add to C++ "faulty" header filename an "_" in front of it, thus
  323. String.h would become _String.h. Sorry for inconvenience. (thanks to Dirk
  324. Nehring for reminding me this anoying "feature").
  325.  
  326. =======
  327. Patches
  328. =======
  329.  
  330. Includes:
  331.  
  332.     Jörg Höhle
  333. hoehle@inf-wiss.uni-konstanz.de
  334.  
  335. There is a conflict between the Amiga and the UNIX definition of the
  336. timeval structure.  Markus Wild proposed in gcc233 to patch the Amiga
  337. devices/timer.h file so that it loads the UNIX sys/time.h file (and
  338. thus tons of other files) (see os-include/devices/timer.mwild.path). I
  339. suggest that sys/time.h and devices/timer.h be modified to detect each
  340. other and use whichever structure was declared first (see
  341. os-include/devices/timer.jch.patch).  The supplied include/sys/time.h
  342. file works this way.  You can apply the patches with the program patch
  343. or by hand. The original devices/timer.h file is copyrighted by
  344. Commodore-Amiga and not included.
  345.  
  346. The sys/types.h defined BPTR causing conflicts with Amiga includes. I
  347. removed the BPTR definition from sys/types.h and sys/proc.h. In
  348. gcc233, there was no such definition either.
  349.  
  350. I moved the ixemul.h file from include/ to the ixemlib/library/
  351. directory. The ixemlib/ directory could contain the ixemul.library
  352. sources. In the ixemul source tree, ixemul.h is found in the library/
  353. directory.  Furthermore I patched it so that it is now able to compile
  354. a working ixconfig. It was broken (because of the broken ixemul.h) in
  355. gcc252/3/4.  It previously worked in gcc233 but didn't provide the -e
  356. option. The ixemlib/library/version.h is an empty fake. I don't have a
  357. newer ixemul.h file. Never ixemul.library versions are said to always
  358. ignore the global AmigaDOS environment.
  359.  
  360. There's yet another minor patch I'd like to suggest:
  361. *** include/stdlib.h.orig    Mon Aug 10 15:28:54 1992
  362. --- include/stdlib.h    Fri Dec 09 17:12:38 1993
  363. ***************
  364. *** 72,76 ****
  365. --- 72,80 ----
  366.   void    *calloc __P((size_t, size_t));
  367.   div_t     div __P((int, int));
  368. + #if 0
  369.   void volatile exit __P((int));
  370. + #else /* new ANSI-C interpretation */
  371. + typedef void exit_t __P((int)); volatile exit_t exit;
  372. + #endif
  373.   void     free __P((void *));
  374.   char    *getenv __P((const char *));
  375.