home *** CD-ROM | disk | FTP | other *** search
/ Chip 2001 August - Disc 3 / chip_20018103_hu.iso / amiga / chiputil / gg / ixemul-cross.lha / NEWS < prev   
Text File  |  2001-04-12  |  35KB  |  893 lines

  1. ============
  2. VERSION 48.2
  3. ============
  4.  
  5. Removed all pOS code and references.
  6.  
  7. Fixed error reporting in __extend_file().
  8.  
  9. Fixed potential problem of reading from freed memory, and enforcer hits
  10. caused from running non-ixemul programs under ixemul control (ie. make).
  11. Patches supplied by Emmanuel Lesueur.
  12.  
  13. ============
  14. VERSION 48.1
  15. ============
  16.  
  17. Interim release.
  18.  
  19. ============
  20. VERSION 48.0
  21. ============
  22.  
  23. Fixed a bug in ftruncate reported by Niels Froehling (incorrect
  24. interpretation of the SetFileSize return value).
  25.  
  26. Fixed a malloc bug (it no longer accepts sizes < 0).
  27.  
  28. Added a few things for Holger Jakob's ppc ixemul support.
  29.  
  30. p.OS is no longer supported. While 99% of the code is still there
  31. it is no longer compiled, nor supported. Binaries compiled for
  32. ixemul 48.0 will no longer work under a p.OS system, nor do you
  33. need the p.OS headers anymore to compile ixemul.library.
  34.  
  35. ============
  36. VERSION 47.3
  37. ============
  38.  
  39. Fixed a bug in getUserPasswd where certain strings weren't properly
  40. 0-terminated.
  41.  
  42. Fixed a bug in setpriority and getpriority: these functions always failed
  43. due to an wrong test.
  44.  
  45. Fixed a bug in ctype.h: all macros (e.g. isspace and friends) failed to
  46. work properly with character code >= 128. Now cast everything to unsigned
  47. char first.
  48.  
  49. Applied patch from David Zaroski to uname.c. Improved OS version number
  50. reporting.
  51.  
  52. ============
  53. VERSION 47.2
  54. ============
  55.  
  56. Fixed a bug in handling of "/". Thanks to Norbert Pueschel for providing me
  57. with a fix.
  58.  
  59. Updated ixprefs from Kriton Kyrimis.
  60.  
  61. Fixed problems with vfork() and sockets when the program was started from
  62. inetd.
  63.  
  64. ============
  65. VERSION 47.1
  66. ============
  67.  
  68. Fixed ixtrace bug that made it impossible to set the stacksize.
  69.  
  70. Fixed bug in crt0.c which caused a crash under p.OS.
  71.  
  72. ============
  73. VERSION 47.0
  74. ============
  75.  
  76. It was possible to kill a process with a SIGKILL signal when that process
  77. was already in the exit() function: this can cause major crashes.
  78.  
  79. Fixed more bugs in wait4(): the list of child processes could contain
  80. processes whose 'getuser()' pointer was NULL, causing enforcer hits and
  81. general mayhem.
  82.  
  83. Signalling processes that were asleep waiting for some event would not wake
  84. these processes.
  85.  
  86. Fixed a bug in wait4: if there are no longer any childs available that
  87. meet the criteria of wait4, then wait4 should exit. In previous versions
  88. this test was only done for the zombie processes, and not for all other
  89. childs.
  90.  
  91. Updated timezone sources and databases.
  92.  
  93. Kriton Kyrimis supplied patches to port ixprefs to p.OS.
  94.  
  95. David Zaroski supplied patches to upgrade ixtrace to this ixemul version.
  96.  
  97. vfork() will now copy any open sockets to the child, previously the
  98. sockets inherited by the child from the parent were always invalid.
  99.  
  100. Added Unix Sys V semaphore and message support (sem* and msg* functions).
  101.  
  102. Added low-level mutex (semaphore) functions: ix_mutex_lock(),
  103. ix_mutex_attempt_lock() and ix_mutex_unlock(). These functions are
  104. wrappers for the AmigaOS or p.OS kernel semaphore functions. See ix.h for
  105. more info.
  106.  
  107. Fixed several nasty bugs in the shm support code.
  108.  
  109. Added a new checkbox to ixprefs: Enable MuFS support. By default the
  110. support for the Multi-user File System is turned off. One reason for adding
  111. this checkbox is that apparently the MuFS support isn't bug-free.
  112.  
  113. ade -> gg
  114.  
  115. Added workaround for AFS bug with symlink("", "").
  116.  
  117. The resolv.conf keyword scan is now case-insensitive: the AmiTCP
  118. resolv.conf file is uppercase, while NetBSD assumes lowercase.
  119.  
  120. Applied patches from Norbert Pueschel fixing argv[0] when starting a
  121. script: it was the name of the scripts, now it is the name of the
  122. interpreter. This conforms to NetBSD and fixes problems with dld.
  123.  
  124. ttyname() in libc.a now always returns "/dev/tty" if the device is a tty
  125. and NULL otherwise.
  126.  
  127. "#!shell arg" handling has been changed to be consistent with NetBSD: all
  128. arguments after the shell name are now passed as the first argument to the
  129. shell.
  130.  
  131. munmap() now calls msync().
  132.  
  133. Ixemul now fully supports pOS.
  134.  
  135. chown() will succeed if the device doesn't support this action instead of
  136. reporting an error.
  137.  
  138. The -enforcer flag of gdb now also supports the 68060.
  139.  
  140. Improved getppid and added hstrerror thanks to Norbert Pueschel.
  141.  
  142. Added ix_obtain_socket and ix_release_socket thanks to Jeff Shepherd.
  143. Added __flush_cache for gcc trampoline handling.
  144. Added ix_flush_insn_cache, ix_flush_caches and ix_flush_data_cache for OS
  145. independent cache flushing.
  146. Added ix_get_first_segment and ix_get_next_segment.
  147. Added ix_select.
  148. Added isascii, isiso, toascii and toiso.
  149. Added ix_get_long, ix_set_long.
  150.  
  151. Removed aselect.
  152. Removed CreatePort, CreateExtIO, CreateStdIO, CreateTask.
  153. Removed DeletePort, DeleteExtIO, DeleteStdIO, DeleteTask.
  154. Removed ix_get_vars.
  155. Removed _wb_parse, _cli_parse and _main.
  156.  
  157. Renamed achmod to ix_chmod.
  158. Renamed ix_get_vars2 to ix_get_vars.
  159. Renamed vfork2 to ix_vfork.
  160. Renamed vfork_resume to ix_vfork_resume.
  161. Renamed __amiga_filehandle to ix_filehandle.
  162. Renamed tracecntl to ix_tracecntl.
  163. Renamed ix_amiga.h to ix.h.
  164.  
  165. ============
  166. VERSION 46.1
  167. ============
  168.  
  169. Renamed __os to ix_os as a preparation for ixemul-47.0. Also renamed
  170. expand_cmd_line to ix_expand_cmd_line and default_wb_window to
  171. ix_default_wb_window.
  172.  
  173. ============
  174. VERSION 46.0
  175. ============
  176.  
  177. Copied basic pOS support from ixemul-47.0 especially for GeekGadgets 2. The
  178. ixemul.library does *not* support pOS, you have to use ixemul-47.0 for
  179. that, but all programs compiled with the new libc.a and *crt0.o will also
  180. run on pOS using ixemul-47.0. Unless Amiga kernel functions are used, of
  181. course. See README.pOS for more information.
  182.  
  183. Added ipcs and ipcrm to manage the shm functionality.
  184.  
  185. Upgraded db to version 1.85.
  186.  
  187. Added an ixprefs option to show the stack usage of all the programs that
  188. use ixemul.library.
  189.  
  190. chmod() now also checks if someone else has the same file open, and makes
  191. sure that when that file is closed the same mode flags are written instead
  192. of the flags specified when the file was opened.
  193.  
  194. Added shared memory support (shmget, shmat, shmdt and shmctl) and the ftok
  195. function.
  196.  
  197. Fixed a bug in memccpy (the wrong pointer was returned).
  198.  
  199. Added a patch from Marc Espie to correctly setup the program name and
  200. directory in the CLI structure so that GetProgramName and GetProgramDir do
  201. the right thing.
  202.  
  203. ============
  204. VERSION 45.1
  205. ============
  206.  
  207. Fixed a bug in the Unix Domain socket code that would occasionally cause a
  208. client to wait indefinately for a connection to be granted, while in fact
  209. the server had already accepted the connection.
  210.  
  211. getdtablesize() now returns FD_SETSIZE instead of NOFILE (256 instead of
  212. 512). The result of this function was used by several X clients to discover
  213. the number of filehandles select() can test. And if that value is too large,
  214. you'll get unexpected and hard to find crashes. The same change was made to
  215. sysconf(_SC_OPEN_MAX).
  216.  
  217. shutdown() could close down the whole Unix domain socket, causing a
  218. crash when the socket was closed a second time by the 'real' close.
  219.  
  220. rename() now tests for a rename across devices and returns the correct
  221. error code.
  222.  
  223. Applied patch from Norbert Pueschel to improve delayed unlink.
  224.  
  225. Closing of Unix domain sockets is now atomic (between Forbid/Permit),
  226. otherwise the Amiga could crash if the X server was running at a higher
  227. priority than the client.
  228.  
  229. Fixed a bug in ixemul.trace that caused Enforcer hits in gcc.
  230.  
  231. Fixed a bug with 'du -ks /volume'. The convert_dir() function stored the
  232. directory name in Amiga format instead of Unix format.
  233.  
  234. Norbert Pueschel greatly improved uid/gid handling in ixemul.library. See
  235. the README for detailed information.
  236.  
  237. Fixed a bug in handling volumes/devices named "dev:". Ixemul handles the
  238. volume /dev specially (e.g., /dev/console is translated to console:) and
  239. that interfered with the handling of the DEV:  device or any volume named
  240. DEV:.  To circumvent the /dev handling you can now use "dev:" instead of
  241. "/dev" or write "DEV" instead of "dev" (in other words, the open() function
  242. tests for the string "/dev/" in a case-sensitive way).
  243.  
  244. Due to a clumsy design of the ENV: notification a signal was occasionally
  245. left unfreed. WShell gives warnings for that, so I changed the design and
  246. that should take care of the warning. The unfreed signal warning was
  247. harmless, but annoying.
  248.  
  249. Now fill the file type in the dirent struct. Thanks to Lars Hecking for
  250. reporting this.
  251.  
  252. Some AmigaOS programs started from an ixemul program set Signals that were
  253. allocated by ixemul. This can happen because ixemul resets the allocated
  254. signal mask in the Task structure.  Because of that a handshake between the
  255. child and the parent when the child process is dying failed, and Enforcer
  256. hits (usually followed by a crash) were the result.  Fixed by resetting all
  257. Signals.
  258.  
  259. Fixed a bug in the trap.s supervisor() code: you cannot safely pass data on
  260. the stack to the function to be executed in supervisor mode. In fact, this
  261. failed with a beta version of the 68060.library from Phase 5. Now pass the
  262. data through registers.
  263.  
  264. Fixed bug in frexp(0.0, &i) where i was set to 1 instead of 0.
  265.  
  266. Fixed 32 Kb memory leak.
  267.  
  268. Added tty CRMOD support.
  269.  
  270. Fixed serious bug in unix domain sockets where a kind of deadlock situation
  271. could occur.
  272.  
  273. system() now searches the whole path for 'sh' and doesn't use /bin/sh only.
  274. Also the paths in paths.h have been adjusted for Geek Gadgets.  Thanks to
  275. Robert Davis for pointing out the system() problem.
  276.  
  277. select() on a small file that was stored in memory if the user selected a
  278. non-zero Membuf size in ixprefs didn't produce the expected results. Thanks
  279. to Stefan Grosse Pawig for reporting this.
  280.  
  281. ============
  282. VERSION 45.0
  283. ============
  284.  
  285. Moved popen() and pclose() into ixemul.library from libc.a. These functions
  286. are used regularly by libraries, and having them in ixemul.library makes
  287. the conversion of those static libraries into shared libraries easier.
  288. Besides, these functions are used frequently enough to warrant their
  289. integration into ixemul.library.
  290.  
  291. Added a patch from Kamil Iskra that fixes problems with -mstackextend and
  292. vfork2(). However, such programs *must* call vfork_setup_child().
  293.  
  294. Thanks to Lars Hecking, a new fnmatch(3) with extended functionality is
  295. available. The fnmatch code is copied from the NetBSD sources.
  296.  
  297. Added new manual pages.
  298.  
  299. Upgraded ixemul to the new structure passing scheme of gcc (A1 contains a
  300. pointer to the return structure). This involved ldiv(), div() and
  301. inet_makeaddr(). Thanks to Kamil Iskra for providing me with patches to
  302. implement this.
  303.  
  304. Upgraded the timezone stuff to the latest version.
  305.  
  306. Implemented Unix Domain sockets. Missing features: datagrams aren't
  307. (yet?) supported, and connect() doesn't have a timeout.
  308.  
  309. Removed stack watcher code. It was seldom used, and it was never very
  310. reliable.
  311.  
  312. Implemented sessions. This improves Ctrl-C handling, and is required to
  313. make full use of xterm.
  314.  
  315. Fixed an unlink bug (it has to check all open files for the given filename)
  316. and a bug in ix_lock_base/ix_unlock_base: if these calls were nested, the
  317. signal masked was restored to ~0 instead of the original value.
  318.  
  319. Added a new utility, ixstack, and a new global variable, __stack, to allow
  320. the user and programmer to specify a minimum stacksize. If the current
  321. stack is too small, a new stack is automatically allocated. Thanks to Kamil
  322. Iskra for implementing this.
  323.  
  324. ioctl(fd, TIOCGPGRP, ...) now returns something useful. NcFtp didn't show
  325. the progress bar anymore because of this.
  326.  
  327. Added large-baserel libraries and startup-code.
  328.  
  329. ============
  330. VERSION 44.0
  331. ============
  332.  
  333. Kriton Kyrimis updated ixprefs.
  334.  
  335. David Zaroski updated ixtrace.
  336.  
  337. Fixed link count for directories. Thanks to Norbert Pueschel.
  338.  
  339. umask implemented for for open() and mkdir(). Thanks to Norbert Pueschel.
  340.  
  341. Added muFIBB_SET_GID, which will be implemented in the next version
  342. of MultiUser. The old way of handling setgid was confusing and even
  343. potentially dangerous.  Thanks to Norbert Pueschel.
  344.  
  345. Added the translation unix sticky bit -> AmigaOS h bit. This one is
  346. more for aestaethical reasons, as the h bit is no longer supported in 3.x.
  347. Thanks to Norbert Pueschel.
  348.  
  349. Added a field 'void *u_user;' near the beginning of the user struct which
  350. everybody is free to (ab)use. It can be handy to store task private data
  351. in the user struct, at least, I had to use it recently.
  352.  
  353. Added an ix_amiga.h header, which will contain all amiga specific functions
  354. and macros in ixemul.library and libc.a, together with a description.
  355.  
  356. Profiling has been enhanced. Ixprefs adds a new profiling preference:
  357. either take samples only while your program is running and the PC is within
  358. your program, or take samples while your program is running and if the PC
  359. is outside your program code (e.g. in ixemul or in intuition.library), use
  360. the last function your program entered before calling ixemul or whatever,
  361. or always take samples, even if other programs are running.  Again, the
  362. last recorded function gets the hit in those cases.
  363.  
  364. An array of 100 longs to store the A4 register of shared libraries has been
  365. added to the user struct. This array can be easily increased in future
  366. releases, should the need arise. The first 20 slots are for your own free
  367. use, the other slots should be registered. See the file REGISTRY in the
  368. ixemul source distribution for more details.
  369.  
  370. Fixed yet another path bug. Running a shell script that's placed somewhere
  371. in your PATH from 'make' failed, unless the filename of the script was
  372. absolute.
  373.  
  374. Added vfork_setup_child to libc.a. This is a wrapper intended to make life
  375. just a little bit easier for those who need to use the vfork2()/vfork_resume()
  376. trick. It replaces the old 'ix_resident()/ix_get_vars2()' pair.
  377.  
  378. Fixed more problems with the routines that start a shell script. This time
  379. problems with symbolic links have been fixed.
  380.  
  381. Fixed problems when parsing a pathname of a shell script, preventing the
  382. execution of that script.
  383.  
  384. Replaced the stdio-sources by the NetBSD 44.0 versions, which incidentally
  385. fixed the broken fgetpos function. This change also adds printf() and scanf()
  386. support for the 'long long' datatype.
  387.  
  388. Added support for the O_CASE open() flag: this will open an existing file
  389. only if the filenames match using a case-sensitive comparison.
  390.  
  391. fstat() didn't compensate the file time for the current timezone offset.
  392.  
  393. Ixemul now supports the 68010 CPU. Thanks to Pascal Eeftinck for pointing
  394. out that the 68010 uses a 68020-like stackframe.
  395.  
  396. Build the version.[ch] files in the build directory instead of in the
  397. source directory.
  398.  
  399. Fixed fchdir().
  400.  
  401. Changed the machine name as returned by uname() to "m68k". Thanks to Lars
  402. Hecking for this.
  403.  
  404. O_ASYNC I/O is now partially supported: select() will test for this
  405. situation.
  406.  
  407. /dev/tty is now translated to console:.
  408.  
  409. Implemented pseudo-terminals support using the FIFO device.
  410.  
  411. Many, mostly small, changes to become more NetBSD compatible. Where
  412. possible, I've replaced the old sources with the NetBSD 1.1 sources.
  413.  
  414. The select() function has been improved: it is now much faster and works
  415. much better.
  416.  
  417. Using F_SETFL with fcntl() failed if the file wasn't a regular file. It now
  418. also works for pipes and sockets.
  419.  
  420. Requesters that are from ixemul.library or ixnet.library now have the name
  421. of the library as their title, so that you can see that they are from the
  422. library, and not from the application. Thanks to Udo Schnurpfeil for
  423. suggesting this.
  424.  
  425. The tty database functions unfortunately slipped through and weren't
  426. included with 43.1. They are back in 44.0.
  427.  
  428. Implemented mmap() and friends. Of course, any mmap feature that actually
  429. requires a MMU will return an error. But if mmap() is used to load a file
  430. into memory, then it works fine.
  431.  
  432. ============
  433. VERSION 43.2
  434. ============
  435.  
  436. Applied patch from Kamil Iskra to improve ixemul stack extension
  437. handling.
  438.  
  439. ============
  440. VERSION 43.1
  441. ============
  442.  
  443. Ixemul no longer uses async writes. All I/O is now synchronous. This
  444. allowed me to remove several Disable()/Enable() pairs, and actually made
  445. ixemul faster. Apparently the overhead in handling async I/O was
  446. substantial.
  447.  
  448. Applied patches from Jeff Shepherd fixing various problems in the
  449. ixnet.library. Among them improved AS225 passwd handling.
  450.  
  451. Moved the resolver functions out of ixnet.library into libc.a. All programs
  452. that used these functions will have to be recompiled. Very few programs use
  453. these functions, and since they are really higher level functions and do
  454. not belong in a low level library like ixnet, I've moved them.
  455.  
  456. Also moved tty database functions (getttyent() and friends, ttyname() and
  457. ttyslot()) to libc.a, for much the same reason.
  458.  
  459. Added the NetBSD DB sources to libc.a and removed the hacked versions from
  460. ixnet.
  461.  
  462. Replaced various headers with the NetBSD versions. Important for certain
  463. socket-related ioctl defines that were incorrect in the old headers.
  464.  
  465. Added ptrace(GETA4, pid, 0, 0) to obtain the value of the a4 register if
  466. this executable was compiled with -fbaserel or -resident. Needed by gdb to
  467. find out where the data section is.
  468.  
  469. Added ptrace(GETEXENAME, pid, 0, 0) to obtain the name of the current
  470. executable. Useful in scripts that start with '#!/bin/sh' or something
  471. similar. 'argv[0]' as seen by sh is the name of the script, but if you want
  472. to get the pathname of 'sh' itself, you can use this ptrace call.
  473.  
  474. Added setlocale() and ctermid() to libc.a.
  475.  
  476. It is now possible to unlink() a file that is owned by another process
  477. (just like Unix). Gcc uses this to remove temporary files that are actually
  478. owned by cpp (or as). Of course, on the Amiga this is implemented as a
  479. delayed delete, i.e. a flag is set in the 'struct file' to tell ixemul to
  480. delete the file when it is closed by the owner process.
  481.  
  482. Added support for a root ('/') directory. This will only work for programs
  483. that use ixemul.library. So if you start pdksh, 'cd' to the root (cd /) and
  484. use the AmigaOS command 'list' to view this directory, then you won't get
  485. what you expect. If you use the Unix ls command however, then you will see
  486. all the volumes that you have as top level directories.
  487.  
  488. Removed an old hack in __wait_packet.c that interfered with Ctrl-F
  489. handling.
  490.  
  491. Fixed a bug in fnctl(), F_SETFL.
  492.  
  493. Added AFS, AFSFloppy and PFS support.  Many thanks to the AFS author,
  494. Michiel Pelt, who provided me with the necessary technical information, and
  495. to Kriton Kyrimis for giving some very useful suggestions.
  496.  
  497. Added MultiUserFileSystem support, contributed by Mike Krings. Thanks Mike!
  498.  
  499. Added new function ix_warning: similar to ix_panic, but allows the user to
  500. choose between "Continue" and "Abort". This to work around a case like:
  501.  
  502.     for (;;) crypt();
  503.  
  504. where one couldn't break out of the program because the requester kept
  505. popping up.
  506.  
  507. Fixed -mstackcheck support and fixed buggy baserel-stackextend support.
  508.  
  509. The call socket(AF_UNIX, SOCK_STREAM, 0) no longer crashes if ixnet.library
  510. is not installed.
  511.  
  512. Reorganized Makefiles. I've removed the option to compile each source
  513. separately, instead they are always catenated together. Also, 'make' no
  514. longer starts itself two more times in order to make the library. I've
  515. used GNU make wizardry to let 'make' figure out all the targets by itself.
  516.  
  517. Sigsetjmp and siglongjmp were broken. Fixed.
  518.  
  519. Replaced the old man pages with the new NetBSD manual pages in the original
  520. troff form.
  521.  
  522. Replaced the nice() stub in ix_stub with nice.c from NetBSD.
  523.  
  524. Removed a Delay(100) that was called just before a vfork()ed program finally
  525. terminated.
  526.  
  527. Made h_errno a global variable like errno.
  528.  
  529. At several places in the library the errno variable was reset to 0.
  530. However, the library should (almost) never set errno to 0. This caused
  531. problems with the 'ping' program, where recvfrom set errno to 4, but the
  532. library changed it back to 0 before 'ping' got to see it.
  533.  
  534. Now sets st_uid and st_gid from a 'stat' structure to the effective UID and
  535. GID. Some programs tested these fields and they failed when using
  536. networking support. These fields used to be 0.
  537.  
  538. Reread the global environment variables only when 1) a new program is
  539. started, and 2) the ENV: directory has been changed (i.e., a new setting
  540. was added to ENV:). ENV: used to be read every time a program was started,
  541. whether it was needed or not.
  542.  
  543. Given the shell script s.sh in /ram/t:
  544.  
  545.     #!/bin/sh
  546.     /bin/echo $0
  547.  
  548. 'sh /ram/t/s.sh' produced '/ram/t/s.sh', while typing '/ram/t/s.sh' from
  549. within the pdksh shell produced 'Ram:t/s.sh'. Fixed.
  550.  
  551. Removed a dubious CurrentDir() to a *file* instead of a directory.  While
  552. this is apparently supported for the standard AmigaOS filesystems, not all
  553. third-party filesystems supported this.
  554.  
  555. When you try to use a >68020 ixemul.library on a 68000 Amiga, you now get a
  556. decent message instead of a crash.
  557.  
  558. ============
  559. VERSION 43.0
  560. ============
  561.  
  562. Integrated Jeff Shepherd's networking code. If ixnet.library is installed,
  563. then ixemul.library will use the networking functions from the
  564. ixnet.library, instead of the default dummy implementation. Ixnet.library
  565. works with AS225 and with AmiTCP. It supports both clients and daemons.
  566. A program that uses networking functions is completely shielded from the
  567. AS225 and AmiTCP differences by ixnet.library. That library will take care
  568. of all the details for you. That means that there is no longer any need to
  569. provide two different binaries, one for AS225 and one for AmiTCP.
  570. Furthermore, it is relatively easy to add support for other network
  571. packages. Thanks, Jeff!
  572.  
  573. Added stackchecking and extension code, thanks to Matthias Fleischer.
  574.  
  575. Finalized GDB support.
  576.  
  577. ============
  578. VERSION 42.1
  579. ============
  580.  
  581. Fixed bugs when running non-ixemul programs from tools like pdksh or make.
  582. You could get Enforcer hits and the Ctrl-C support also crashed the Amiga.
  583.  
  584. Use the NetBSD code for the system() function instead of using the Amiga
  585. kernel function SystemTagList. This was the cause of several
  586. incompatibilities when porting Unix programs.
  587.  
  588. Improved termios support (added OPORT and ONLCR flags and the INLCR flag).
  589.  
  590. Fixed ptrace handling. Almost none of Leonard's code has survived, I used a
  591. completely different method.
  592.  
  593. Fixed a problem where the name of the current directory, as is visible
  594. by the shell, wasn't changed when a program terminated and ixemul reset the
  595. current directory to its original place.
  596.  
  597. Improved performance somewhat by no longer going through address 4 to get
  598. to the ExecBase structure. Instead, it's copied once to the SysBase
  599. variable, and thereafter only that variable is used. The Enforcer manual
  600. warned against accessing address 4 too often, and ixemul.library did that
  601. a lot.
  602.  
  603. Also improved performance by fixing a busy wait. At one point in the
  604. ixemul, the program cannot continue until a context switch has taken place.
  605. So ixemul waits until the dispatch count of ExecBase has changed,
  606. indicating that a context switch has taken place. By installing a small,
  607. high priority (9) task with body "for (;;) Wait(1 << 31);" and signalling
  608. that task whenever a context switch is needed, I was able to circumvent the
  609. busy wait loop. Because of the high priority of the Task, a context switch
  610. would take place immediately. The task itself goes back to sleep at once,
  611. so there is no time lost there.
  612.  
  613. ============
  614. VERSION 42.0
  615. ============
  616.  
  617. Installed patch in arith.c to work around bug in IEEEDPCmp.  If the first
  618. 32 bits of both doubles are equal, and both doubles are negative, then
  619. the result can no longer be trusted.  Discovered by Bart Van Assche.
  620.  
  621. Ixtrace has been updated to recognize all 42.0 syscalls, thanks to David
  622. Zaroski.
  623.  
  624. Ctrl-C handling worked with KingCON, but not with the standard AmigaOS
  625. CON-handler (since I use KingCON I never noticed this until it was pointed
  626. out to me by Fred Fish :-). This has now been fixed. See the comments in
  627. library/__read.c for more information.
  628.  
  629. Added the uname() function, written by Lars Hecking.
  630.  
  631. The termios code now properly recognizes the ICRNL input flag for '\r' to
  632. '\n' translation.
  633.  
  634. Fixed a bug in the fcntl() function (actually, in the fcntl.h and
  635. sys/fcntl.h headers).
  636.  
  637. Moved several static variables to user.h, so they are now process-specific.
  638.  
  639. Added profiling support. It was always there, but it was never actually
  640. used.
  641.  
  642. The write() function writes its buffer line-by-line instead of in one big
  643. chunk if the filehandle is the handle of an interactive stream (for
  644. example, a console window). This allows the user to interrupt the output by
  645. pressing a key and it also allows the use of Ctrl-C to break the program.
  646. In previous versions you were unable to stop the output if you forgot to
  647. redirect it to a file. E.g., 'cat /libs/ixemul.library' would essentially
  648. take over the computer.
  649.  
  650. Changed default stack size handling when a new process is launched. It is
  651. either the value of the environment variable IXSTACK, or it inherits the
  652. size from its parent, but if that size is less than 16384, it uses a stack
  653. of 16384 bytes instead.
  654.  
  655. Replaced ixconfig by ixprefs (written by Kriton Kyrimis).
  656.  
  657. Integrated the partial ptrace support from Leonard Norrgard.
  658.  
  659. Removed the gnulib, gnulib-68881 and gnulib-soft-float directories.
  660.  
  661. Compiled with -Wall and fixed (nearly) all warnings. Some warnings are
  662. inevitable and cannot be avoided. -Wall already caught one illegal memory
  663. access bug in __Close()!
  664.  
  665. Added functions to set and get ixemulbase-private information. This will
  666. break older ixconfig's but is much cleaner. Nearly all of the ixemulbase
  667. structure is now off-limits and liable to change without notice! You are
  668. warned! In fact, the structure has been changed already. The library will
  669. complain if a program called 'ixconfig' tries to use it to prevent the user
  670. from using an old ixconfig with the new library.
  671.  
  672. Removed several arithmetic functions dealing with 'long long' types. They
  673. didn't belong in the library, link with libgcc.a instead. Also removed some
  674. arithmetic functions that are never called because they are compiled
  675. directly in 68000 assembly. Don't know why they were ever added.
  676.  
  677. Fixed gen_glue.c so that it no longer generates glue for obsolete functions.
  678.  
  679. Removed ssystem(). ssystem() was the precursor of vfork/execve, and is no
  680. longer needed. NOTE: it is still used in gcc. But this fails spectacularly
  681. once you use Ctrl-C! Delete gcc and replace it by gccv, this one uses
  682. vfork/execve as it should and works perfectly.
  683.  
  684. ixemul.library now uses the new-style inlines.
  685.  
  686. qsort() is now re-entrant and no longer uses the horrible Semaphore hack.
  687.  
  688. Moved general/fts.c to the static library. These directory-tree traversal
  689. functions are rarely, if ever used, so they belong in libc.a and not in a
  690. shared library.
  691.  
  692. Reorganized the Makefiles. The makefiles now use several GNU make-only
  693. features to make them smaller and easier to maintain.  'make clean' and
  694. 'make clobber' now work correctly.  It is also no longer nessecary to add
  695. the -srcdir option to 'sh configure' in order to create valid Makefiles.
  696.  
  697. The top level Makefile contains the line 'export CATENATE = 1'. If this
  698. line is present, the compilation speed is greatly improved by catenating
  699. several small C-sources together into one bigger C-source, and then the
  700. bigger one is compiled. By commenting this line each separate source is 
  701. compiled. Note that besides improving compilation speed, the library also
  702. gets smaller as the compiler can now determine whether a call can be made
  703. relative or should remain absolute.
  704.  
  705. Fixed a symlink-bug (ln -s /ram/t created a symlink to /am/t, removing the
  706. first character of the volumename).
  707.  
  708. Moved ixtrace to the new utils directory, together with the small ixrun
  709. utility.  ixrun can be used to run Amiga batch files from /bin/sh (just put
  710. ';!ixrun' at the second line (!) of the batch file).  Also added manual
  711. page for ixrun.
  712.  
  713. Cleaned up the static directory:  removed xmalloc.c and alloca.c as they do
  714. not belong in the standard C library.  Also replaced the ctime.c source by
  715. the version from elsie.nci.nih.gov, which is the official version used by
  716. NetBSD and Linux, among others.  Finally, errlst.c and siglist.c now just
  717. include their counterparts in the general directory.
  718.  
  719. The version information is placed in the version.in file in the
  720. top-level directory. The version.c and version.h sources are created from
  721. this file.
  722.  
  723. The print_base_size.c and print_user.c sources have been replaced by
  724. create_header.c, which creates a header containing a few defines that are
  725. used by start.s and trap.s. These used to be hard-coded, but now they are
  726. generated, preventing future mistakes.
  727.  
  728. Added the raise function. For some reason, raise.c was never compiled into
  729. the library. It is now.
  730.  
  731. Removed ALL sources that were not needed for compilation.
  732.  
  733. Added timezone handling. The timezone databases from elsie.nci.nih.gov are
  734. used and installed in etc:zoneinfo. The new ixtimezone utility should be
  735. added to the startup-sequence. This utility determines the correct offset
  736. for Greenwich Mean Time. Read the manual page (Yes! Documentation at last!)
  737. for more information.
  738.  
  739. Merged the ixpipe-handler into the ixemul-distribution. It has been placed
  740. in the utils-directory.
  741.  
  742. Added hack to allow ixemul to run AmigaOS scripts without breaking them
  743. when run from the AmigaOS shell. The problem is that the ".KEY" string
  744. must be at the first line of the script, while ixemul also looks for "#!"
  745. and ";!" in the first line. If a file starts with ".KEY", ixemul will now
  746. skip the first line, before checking for "#!" and ";!".
  747.  
  748. ============
  749. VERSION 41.4
  750. ============
  751.  
  752. Integrated patches from Hans Verkuil that fix CTRL-C handling, fix another
  753. signal bug, fix problem with "rm -f", prepare for proper timezone handling,
  754. and remove '@' hack in argument parsing.
  755.  
  756. Applied patch from Kamil Iskra to avoid incompatibility between ixemul
  757. and the popular KingCON 1.3.  This is KingCON's fault because it makes
  758. invalid assumptions about the nature of reply port contained in "dp_Port"
  759. of packets sent to it.  Also applied patch (duplicated in Hans' patches)
  760. to crt0.c that fixes bug where the revision requester was not working
  761. properly if the current revision is 0.
  762.  
  763. Applied patch from Rask Lambertsen (duplicated in Hans' patches) that makes
  764. ixemul.library open "CONSOLE:" instead of "*".
  765.  
  766. Added implementation from Kriton Kyrimis for srand48, seed48, lcong48,
  767. lrand48, nrand48, mrand48, jrand48, drand48, and erand48.
  768.  
  769. Added "#include <sys/types.h>" to <dirent.h> to be more compatible
  770. with most current systems that do this inclusion for you.  This change
  771. should be backwards compatible with code that does the inclusion
  772. explicitly.  Suggested by Lars Hecking.
  773.  
  774. Changed prototype in <unistd.h> for getpgrp() to take a pid_t argument,
  775. which matches the implementation in library/getcrap.c.  Suggested by
  776. Lars Hecking.
  777.  
  778. Made change to <math-68881.h> in pow() so that if x<0 the code does
  779. log(-x) rather than log(x).  Suggested by Thomas Radtke and implemented
  780. by Lars Hecking.
  781.  
  782. Disable definitions of F_GETLK, F_SETLK, F_SETLKW, F_RDLCK, F_UNLCK, and
  783. F_WRLCK in <fcntl.h> since they are unimplemented and thus might have misled
  784. autoconfiguration schemes into thinking they were available.  Also fix
  785. ixtrace.c so it will still compile without these defined.  Suggested by
  786. Robert Ramiega.
  787.  
  788. Integrated patch from Joop van de Wege (duplicated in Hans' patches) for
  789. setting up fpu on 68060.
  790.  
  791. ============
  792. VERSION 41.3
  793. ============
  794.  
  795. Updated DBL_MIN and DBL_MAX in float.h to include one additional digit
  796. of precision.  Enclose negative constants in parens to avoid unexpected
  797. conversion to subtraction via cpp macros.
  798.  
  799. Applied patch from Hans Verkuil to fix serious bug in signal handling,
  800. to reset all signal handlers after an execve, except for those which are
  801. being ignored (SIG_IGN).
  802.  
  803. Applied patch from Joop van de Wege to trap.s to set 68881 rounding mode
  804. back to truncation instead of "round to nearest", as required by the
  805. ANSI C standard which specifies truncation.
  806.  
  807. Integrated ixtrace into source tree and arranged for it to be built and
  808. installed.
  809.  
  810. ============
  811. VERSION 41.2
  812. ============
  813.  
  814. Added "#include <sys/types.h>" to <sys/stat.h> to be more compatible
  815. with most current systems that do this inclusion for you.  This change
  816. should be backwards compatible with code that does the inclusion
  817. explicitly.
  818.  
  819. Changed version string to be style guide compliant.  Also arranged that
  820. version.o gets linked in, since it has the $VER: string and is otherwise
  821. unreferenced by any ixemul.library code.
  822.  
  823. Merged patches from Hans Verkuil to fix execve environment passing,
  824. always open the console for stderr if no other file handle is provided,
  825. move AmigaOS style filename matching into glob(), and fix a small problem
  826. with "open(NULL,...) that caused enforcer hits.
  827.  
  828. ============
  829. VERSION 41.1
  830. ============
  831.  
  832. A 68040 version of the library with soft floating point is now built,
  833. since there are apparently systems that use the versions of the 68040
  834. without FPUs.
  835.  
  836. Fixed crt0 files to use "jra _ENTRY" as first instruction rather than
  837. "jmp pc@(_ENTRY)" which was getting assembled by gas 2.5.2 as a 68020+
  838. instruction.  Note "jmp pc@(_ENTRY:W)" seems to generate the 68000
  839. instruction but a bad jump offset.  Added corresponding change to
  840. execve.c to recognize ixemul using executables with this change.
  841.  
  842. Fixed cpu.h, machdep.c, trap.s to avoid pc relative assembly instruction
  843. that was getting compiled as 68020+ instruction and causing crashes on
  844. 68000 machines.
  845.  
  846. Fixed numerous files that did "#include" of "DEFS.H" rather than "defs.h".
  847. This is an innocuous bug on the Amiga, which is case independent, but
  848. it kills cross compilations.
  849.  
  850. ============
  851. VERSION 41.0
  852. ============
  853.  
  854. No significant changes since the 40.6 beta release other than the
  855. mechanism (and macros) for building debug versions has been cleaned
  856. up and the version number has been bumped to 41.0.
  857.  
  858. Did include the cat'able man pages back in the source tree, but no
  859. work has been done yet to track down the sources for the man pages
  860. and arrange for them to be properly integrated into the tree and
  861. have the cat'able versions generated from those sources.
  862.  
  863. ============
  864. VERSION 40.6
  865. ============
  866.  
  867. Many bugs have been fixed since the 40.4 release, including a serious
  868. one that was causing memory corruption and many enforcer or mungwall
  869. hits.
  870.  
  871. Network support has been reintegrated into the library, however it is
  872. still mostly untested.  In particular, many functions are only
  873. available for static linking from the libnet.a library.  By the next
  874. release, it is expected that libnet.a will be incorporated in libc.a.
  875.  
  876. Work is underway to merge the best features from at least two
  877. different strains of the ixemul library.  Many more changes are
  878. expected by the 41.0 release.
  879.  
  880. An environment variable called "IXSTACK" is now used to control the
  881. stack size of programs started by system().  If the current stack is
  882. smaller than the value in IXSTACK, the stack is raised to the value
  883. specified in IXSTACK.  So IXSTACK is a minimum value.
  884.  
  885. Automatic stack checking, with a requestor if the stack overflows, is
  886. available for executables compiled with a version of gcc that supports
  887. the -mstackcheck option.  This also requires linking with new crt0 and
  888. libc.a.
  889.  
  890. Automatic stack extension as necessary is available for executables
  891. compiled with a version of gcc that supports the -mstackextend option.
  892. This also requires linking with new crt0 and libc.a.
  893.