Home My Page Projects Code Snippets Project Openings SML/NJ
Summary Activity Forums Tracker Lists Tasks Docs Surveys News SCM Files

SCM Repository

[smlnj] Diff of /sml/trunk/HISTORY
ViewVC logotype

Diff of /sml/trunk/HISTORY

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1124, Thu Mar 7 19:49:22 2002 UTC revision 1617, Tue Aug 31 22:15:48 2004 UTC
# Line 13  Line 13 
13  Description:  Description:
14    
15  ----------------------------------------------------------------------  ----------------------------------------------------------------------
16    Name: Matthias Blume (blume (at) tti - c (dot) org)
17    Date: 2004/08/31 17:15:00 CDT
18    Tag: blume-20040831-core
19    Description:
20    
21    Added some exports to src/compiler/core.cm upon request by J. Joemann.
22    
23    ----------------------------------------------------------------------
24    Name: Matthias Blume (blume (at) tti - c (dot) org)
25    Date: 2004/08/30 17:55:00 CDT
26    Tag: blume-20040830-installer
27    Description:
28    
29    Upon request by Johannes Joemann:
30    
31    - improved ML code of installer to fall back to coping when renaming
32      fails (i.e., when source and target are on different file systems);
33      the code compiles but has yet to be tested in anger
34    - removed mlrisc from list of default targets (config/targets)
35    
36    ----------------------------------------------------------------------
37    Name: Matthias Blume (blume (at) tti - c (dot) org)
38    Date: 2004/08/27 17:20:00 CDT
39    Tag: blume-20040827-ptreql
40    Description:
41    
42    Added ptreql primop to structure InlineT (upon request from Larry
43    Paulson).
44    
45    ----------------------------------------------------------------------
46    Name: Allen Leung (leunga (at) reservoir (dot) com)
47    Date: 2004/08/15 21:21:00 EST
48    Tag: leunga-110_48-udgraph
49    Description:
50    
51    Another bug fix from Carl Hauser:
52    
53    diff /net/niflab/smlnj48/src/MLRISC/graphs/udgraph.sml udgraph.sml
54    > 48c48
55    > <              | rmv((e as (k,_))::es,L) = rmv(es,if k = i then es else
56    > e::L)
57    > ---
58    > >              | rmv((e as (k,_))::es,L) = rmv(es,if k = i then L else e::L)
59    > Without this, any deletion of an edge in an undirected graph does severe
60    > violence to the graph.
61    
62    ----------------------------------------------------------------------
63    Name: Allen Leung (leunga (at) reservoir (dot) com)
64    Date: 2004/08/10 23:35:00 EST
65    Tag: leunga-110_48-ppc
66    Description:
67    
68       The IBM/MacOS syntax switch on PPC was incorrectly swapped.
69    
70    ----------------------------------------------------------------------
71    Name: Matthias Blume (blume (at) tti - c (dot) org)
72    Date: 2004/08/10 12:00:00 CDT
73    Tag: Release_110_48
74    Description:
75    
76    New working version (110.48).  NEW BOOTFILES!
77    
78    ----------------------------------------------------------------------
79    Name: Allen Leung (leunga (at) reservoir (dot) com)
80    Date: 2004/08/09 12:21:00 EST
81    Tag: leunga-110_47-dijsktra
82    Description:
83    
84    Bug fix from Carl Hauser:
85    
86    single_source_shortest_paths in dijkstra.sml was observed to get wrong
87    answers (by comparing to single_source_shortest_paths in bellman-ford.sml).
88    
89    The problem is that following the expression A.update(dist,s,Num.zero)
90    it is necessary to update the priority queue using Q.decreaseWeight(Q,s).
91    
92    ----------------------------------------------------------------------
93    Name: Matthias Blume (blume (at) tti - c (dot) org)
94    Date: 2004/08/06 18:10:00 CDT
95    Tag: blume-20040806-cmdline
96    Description:
97    
98    Fiddled with handling of command-line options:
99    
100      * sml now quits after processing the command line
101        if -H, -S, -h<n>, or -s<n> appears as the last
102        command-line argument
103      * a new option -q terminates the session when encountered on
104        the command line; subsequent arguments will be ignored
105      * bug fixes: short (erroneous) arguments are no longer ignored
106        completely
107    
108    ----------------------------------------------------------------------
109    Name: Allen Leung (leunga (at) reservoir (dot) com)
110    Date: 2004/08/04 18:17:00 EST
111    Tag: leunga-110_47-ppc-ibm-asm
112    Description:
113    
114      - Added minimal IBM assembly syntax support for PowerPC.
115    
116      - Cygwin: manually changed the file cygwin.def.  Some exported symbols have
117        been altered in the runtime.  We need an automatic way to keep the file
118        in sync.
119    
120    ----------------------------------------------------------------------
121    Name: Matthias Blume (blume (at) tti - c (dot) org)
122    Date: 2004/08/04 14:00:00 CDT
123    Tag: Release_110_47
124    Description:
125    
126    New working version (110.47).  NEW BOOTFILES!
127    
128    ----------------------------------------------------------------------
129    Name: Matthias Blume (blume (at) tti - c (dot) org)
130    Date: 2004/08/03 14:25:00 CDT
131    Tag: blume-20040803-callingconv
132    Description:
133    
134    Added low-level support for choosing C calling conventions by
135    twiddling the type of rawccall.  (See
136    src/compiler/Semant/types/cproto.sml for details.)
137    
138    ----------------------------------------------------------------------
139    Name: Matthias Blume (blume (at) tti - c (dot) org)
140    Date: 2004/08/02 15:55:00 CDT
141    Tag: blume-20040802-backout
142    Description:
143    
144    Backed out of change to win32-filesys.c.  The earlier patch to
145    get_file_time caused CM to produce files with the wrong time stamp.
146    
147    ----------------------------------------------------------------------
148    Name: Matthias Blume (blume (at) tti - c (dot) org)
149    Date: 2004/08/02 14:45:00 CDT
150    Tag: blume-20040802-nlffi-win32
151    Description:
152    
153    Added NLFFI support for Win32, adapted from a patch provided by David
154    Hansel.  This is currently completely untested.  Also, the issue
155    concerning stdcall vs. ccall is still unresolved.
156    
157    ----------------------------------------------------------------------
158    Name: Matthias Blume (blume (at) tti - c (dot) org)
159    Date: 2004/07/30 17:55:00 CDT
160    Tag: blume-20040730-various
161    Description:
162    
163    Gearing up towards 110.47...
164    
165    - various minor bugfixes to ml-nlffigen
166    - a beginning of a manual for nlffi
167    
168    - eliminated 'export name=value' in config/install.sh as this does
169      not work with certain versions of /bin/sh
170      (Thanks to David King at Motorola for catching this.)
171    
172    - several bugfixes provided or suggested by David Hansel at Reactive Systems:
173      - added a test for tm==NULL to gmtime.c and localtime.c
174      - applied patch for incorrect GetFileTime under win32
175      - toSeconds -> toMilliseconds in Win32/win32-process.sml
176    
177    ----------------------------------------------------------------------
178    Name: Matthias Blume (blume (at) tti - c (dot) org)
179    Date: 2004/07/21 18:20:00 CDT
180    Tag: blume-20040721-nlffigen
181    Description:
182    
183    - Fixed minor issue in ml-nlffigen: Now generate structure T_foo
184      for a typedef to an incomplete type, but leave out the "typ" member.
185      (This is just for consistency.)
186    - Started to produce what is supposed to become better (i.e., comprehensive)
187      documentation of what ml-nlffigen does and produces.
188    
189    ----------------------------------------------------------------------
190    Name: Matthias Blume (blume (at) tti - c (dot) org)
191    Date: 2004/07/14 16:25:00 CDT
192    Tag: blume-20040714-union
193    Description:
194    
195    Added C_UNION to c-calls/c-types.sml and updated the machinery
196    (ml-nlffigen, cproto.sml) that conveys C function interface
197    information to the code generator.
198    
199    However, the actual architecture-specific implementation of function
200    arguments and results that are C unions is still not implemented.
201    
202    ----------------------------------------------------------------------
203    Name: Allen Leung (leunga (at) reservoir (dot) com)
204    Date: 2004/07/14 14:38:00 EST
205    Tag: leunga-110_46_1-ppc-lwzu
206    Description:
207    
208        Added these instructions to the PowerPC architecture:
209        LBZU(X), LHZU(X), LWZU(X),
210        STWU(X), STFDU, STFSU
211    
212        etc...
213    
214        Note: I haven't added their instruction encoding into the description.
215    
216    ----------------------------------------------------------------------
217    Name: Allen Leung (leunga (at) reservoir (dot) com)
218    Date: 2004/07/13 15:04:00 EST
219    Tag: leunga-110_46_1-ppc-lwarx
220    Description:
221    
222       Added the two instructions LWARX and STWCX to the PowerPC
223    instruction set.
224    
225       A (untested) rewrite of loop-structure.sml.  The old version
226    is completely broken.
227    
228    ----------------------------------------------------------------------
229    Name: Matthias Blume (blume (at) tti - c (dot) org)
230    Date: 2004/07/13 13:50:00 CDT
231    Tag: blume-20040713-nlffi
232    Description:
233    
234    - use paramAlloc to report c-calls with too many arguments
235      (for PPC version where parameter area is pre-allocated)
236    - added ccall_maxargspace to machspec (to implement the above)
237    - made "make" commend in CM's "make" tool configurable
238    - added option (default: on) for passing the name of the SML/NJ's "bin"
239      directory to "make"; the call looks like this:
240    
241         make <options> SMLNJ_BINDIR=<dir> <target>
242    
243      This can be used by the Makefile to, e.g., pick the "right" version
244      of ml-nlffigen.
245    - minor code tweaks
246    
247    ----------------------------------------------------------------------
248    Name: Matthias Blume (blume (at) tti - c (dot) org)
249    Date: 2004/07/12 22:50:00 CDT
250    Tag: blume-110_46_1-macosx-nlffi
251    Description:
252    
253    NLFFI under Mac OS X now working (sort of).  This is largely untested,
254    though.
255    
256    Note:  1. You have to make a new, clean build of the runtime system.
257           2. There are new BOOTFILES, you have to use them!
258              (Doing the bootstrap process yourself would be *very* painful!
259               If you absolutely have to do it, build the system under
260               a different architecture and then cross-compile.)
261    
262    Version bumped to 110.46.1 to account for runtime data format changes.
263    
264    ----------------------------------------------------------------------
265    Name: Matthias Blume (blume (at) tti - c (dot) org)
266    Date: 2004/06/18 14:30:00 CDT
267    Tag: blume-20040618-unix
268    Description:
269    
270    Changed the implementation of structure Unix so that the same stream
271    is returned every time one of the {text,bin}{In,Out}streamOf functions
272    is invoked on the same proc.  This is not what the spec currently
273    says -- although IMO it arguably should.  (See discussion below.)
274    
275    ----------------------------------------------------------------------
276    Name: Matthias Blume (blume (at) tti - c (dot) org)
277    Date: 2004/06/17 18:15:00 CDT
278    Tag: Release_110_46
279    Description:
280    
281    New working version (110.46).  NEW BOOTFILES!
282    
283    ----------------------------------------------------------------------
284    Name: Matthias Blume (blume (at) tti - c (dot) org)
285    Date: 2004/06/17 17:20:00 CDT
286    Tag: blume-20040617-timer-unix
287    Description:
288    
289    Changed the interface of structures Timer and Unix to match the most
290    recent Basis spec.
291    
292    In the case of Unix there still seems to be an open/weird issue:
293    
294       The {text,bin}{In,Out}streamOf functions are supposed to create
295       fresh streams whenever they are called -- as opposed to have them
296       return the same stream every time.  This design is supposed to
297       prevent space leaks caused by proc values hanging on to streams.
298    
299       The reap function, on the other hand, is supposed to close the
300       streams.  This cannot be done without having a handle on the
301       stream in proc after all...
302    
303    I took the liberty to implement the following stopgap solution:
304    
305      The proc value hangs on to the most recently created stream(s).
306      Reap closes those.  If either or both of the two streams hadn't
307      been created at all yet, then reap will close the corresponding
308      file descriptors directly.
309    
310    PS: I don't understand the original space leak argument anymore.  If
311    a proc hangs on to the imperative stream, then I/O operations on those
312    will advance the state of the cached stream and avoid the space leak.
313    
314    ----------------------------------------------------------------------
315    Name: Matthias Blume (blume (at) tti - c (dot) org)
316    Date: 2004/05/28 16:45:00 CDT
317    Tag: blume-20040528-basis
318    Description:
319    
320    Added signature PACK_REAL and exported functor PrimIO.
321    
322    ----------------------------------------------------------------------
323    Name: Matthias Blume (blume (at) tti - c (dot) org)
324    Date: 2004/05/25 16:00:00 CDT
325    Tag: blume-20040525-group-owner
326    Description:
327    
328    CM now ignores (but still accepts) the "owner" information in group
329    descriptions.  The owner of a group is its next enclosing
330    library. Each group must have a unique owner.  (There is a virtual
331    "toplevel" library that owns groups which are not nested within a real
332    library.)  Previously, each group had to explicitly declare its owner,
333    and CM would check that such a declaration is correct.  The new scheme
334    is to have CM check that for each group there is precisely one owning
335    library.
336    
337    The advantage of the new scheme is that the programmer no longer needs
338    to maintain the somewhat annoying owner information.  The downside is
339    that CM cannot enforce the ownership rule across multiple runs of
340    CM.make.  Fortunately, enclosing the same group in two different
341    libraries A and B which are not part of the same program does not
342    cause real problems.
343    
344    ----------------------------------------------------------------------
345    Name: Matthias Blume (blume (at) tti - c (dot) org)
346    Date: 2004/05/20 16:00:00 CDT
347    Tag: blume-20040520-win32
348    Description:
349    
350    Made the win32 version work again.  (Strangely, a misplaced comma had
351    slipped into win32-process.c which prevented the runtime from being
352    compiled correctly.)
353    
354    Also, included a minor addition to ml-build.bat analogous to what was
355    done in blume-20040519-ml-build.
356    
357    ----------------------------------------------------------------------
358    Name: Matthias Blume (blume (at) tti - c (dot) org)
359    Date: 2004/05/19 22:10:00 CDT
360    Tag: blume-20040519-ml-build
361    Description:
362    
363    Arranged for ml-build to clean up after itself a little bit better.
364    The script generates a temporary SML source file and compiles it using
365    CM, so CM generates metadata (GUID, SKEL, objectfile) for it.  It now
366    gets rid of those at the end, so they don't accumulate under .cm.
367    
368    This required a minor change to install.sh because the name of the
369    metadata directory (default: .cm) is actually configurable at
370    installation time.
371    
372    ----------------------------------------------------------------------
373    Name: Matthias Blume (blume (at) tti - c (dot) org)
374    Date: 2004/05/18 15:50:00 CDT
375    Tag: blume-20040518-mkreader
376    Description:
377    
378    Added Posix.IO.mk{Bin,Text}{Reader,Writer} by lifting their respective
379    implementations from internal modules PosixBinPrimIO and PosixTextPrimIO.
380    
381    ----------------------------------------------------------------------
382    Name: Matthias Blume (blume (at) tti - c (dot) org)
383    Date: 2004/05/11 14:35:00 CDT
384    Tag: blume-20040511-win32sock
385    Description:
386    
387    Added previously missing support for many socket-related functions
388    under win32.  Thanks to David Hansel <hansel@reactive-systems.com>
389    for the voluminous patch!
390    
391    (I have not tested this patch under win32 yet.)
392    
393    Here is David's e-mail:
394    
395    Hi,
396    
397    Attached to this email you find a diff against sml/nj 110.45
398    that will enable socket support under Windows.
399    
400    To apply the patch (using unix or cygwin)
401    1) gunzip runtime.diff.gz
402    2) "cd" into "src/runtime" in the source tree of a fresh
403       110.45 installation.
404    3) patch -p 1 < [your/path/to]runtime.diff
405    
406    The code compiles fine but has NOT yet been extensively tested.
407    I only ran a few tests for basic socket client functionality
408    (which worked fine).  Especially the functions that use ioctl
409    are not tested at all and might not work (see below).
410    
411    I implemented this since we want to move to a newer version of sml/nj
412    but need socket support in order to use it.  This is the first time I
413    even had a look at the sml/nj source,  so please review my changes
414    before making this part of the distribution!  Here are a few issues
415    that I think might be better for someone to solve who is more
416    familiar with the sml/nj source (and socket programming):
417    
418    - getnetbyaddr.c and getnetbyname.c will raise a "not implemented"
419      exception since I could not figure out what the windows equivalent
420      of these functions is
421    
422    - In sockets-osdep.h there are a some #include statements that are
423      only used in a few files that include sockets-osdep.h
424    
425    - In smlnj-sock-lib.c, function init_fn() calls WSAStartup() but
426      does not process its return value since I don't know how to
427      report an error upwards.
428    
429    - It would probably be good to have a call to WSACleanup() when
430      the library is unloaded (if there is such a possibility).
431      Otherwise I think Windows will take care of this automatically
432      when the process finishes.
433    
434    - I used ioctlsocket() as a replacement for ioctl() but I have
435      no idea if that is actually the proper replacement on Windows.
436    
437    - All these issues are marked in the code by "FIXME" comments.
438    
439    We use sml/nj extensively in our products and are quite happy
440    with it.  I hope this contribution will help you.
441    
442    Keep up the good work!
443    
444    David
445    
446    ----------------------------------------------------------------------
447    Name: Matthias Blume (blume (at) tti - c (dot) org)
448    Date: 2004/05/11 14:20:00 CDT
449    Tag: blume-20040511-installml
450    Description:
451    
452    Fixed two bugs in installml script.  (Thanks to Vesa A. Norrman for
453    the patch.)
454    
455    ----------------------------------------------------------------------
456    Name: Matthias Blume (blume (at) tti - c (dot) org)
457    Date: 2004/05/11 14:05:00 CDT
458    Tag: blume-20040511-nlffi-netbsd
459    Description:
460    
461    Added support for nlffi under netbsd.  (Thanks to Vesa A. Norrman for
462    the patch.)
463    
464    ----------------------------------------------------------------------
465    Name: Matthias Blume (blume (at) tti - c (dot) org)
466    Date: 2004/05/11 12:05:00 CDT
467    Tag: blume-20040511-exports
468    Description:
469    
470    As per request by Adam Chlipala <adam@hcoop.net>, extended various
471    export lists in compiler-related .cm-files.
472    
473    ----------------------------------------------------------------------
474    Name: Matthias Blume (blume (at) tti - c (dot) org)
475    Date: 2004/05/11 11:35:00 CDT
476    Tag: blume-20040511-allsource
477    Description:
478    
479    The installer now honors the "src-smlnj" target again, although its meaning
480    has changed from "all sources required for the compiler" to "all sources
481    the installer knows about".  In other words, if you enable "src-smlnj"
482    in the "targets" file, then the installer will pull in sources for
483    everything.  (Notice that this refers to source code only.  Compiled
484    code is still only installed for modules that were requested explicitly
485    or which are required for other modules that were requested explicitly.)
486    
487    ----------------------------------------------------------------------
488    Name: Matthias Blume (blume (at) tti - c (dot) org)
489    Date: 2004/04/23 17:40:00 CDT
490    Tag: blume-20040423-ieee-scan
491    Description:
492    
493    Fixed IEEEReal.scan (and .fromString) so that if there is an overflow
494    in the exponent calculation we get INF or ZERO (depending on the mantissa
495    and the sign of the exponent).
496    
497    ----------------------------------------------------------------------
498    Name: Matthias Blume (blume (at) tti - c (dot) org)
499    Date: 2004/04/23 10:40:00 CDT
500    Tag: blume-20040423-ml-build
501    Description:
502    
503    The ml-build script now terminates with a non-0 status when something
504    goes wrong.
505    
506    ----------------------------------------------------------------------
507    Name: Matthias Blume (blume (at) tti - c (dot) org)
508    Date: 2004/04/22 16:35:00 CDT
509    Tag: blume-20040422-Option
510    Description:
511    
512    Made exception Option to be the same as exception Option.Option
513    (as it should be).
514    
515    ----------------------------------------------------------------------
516    Name: Allen Leung (leunga (at) reservoir (dot) com)
517    Date: 2004/03/19 14:40:00 EST
518    Tag: leunga-20040319-cygwin-nlffi
519    Description:
520    
521    Fixed the runtime so that ml-nlffi-lib runs on the cygwin version
522    of SML/NJ.  The problem is that
523    
524       lib = dlopen(NULL, ...)
525       f   = dlsym(lib, "malloc");
526    
527    does not work on Windows unless we explicitly export symbols
528    such as 'malloc' during linking.  We fixed this by explicitly
529    exporting the required symbols with the magic gcc incantation:
530    
531        -Wl,--export-all cygwin.def
532    
533    where cygwin.def is a file containing all the symbols that
534    we wish to export.
535    
536    I suspect this is a Windows problem and we'll have to
537    do the same (somehow with windows compilers) when
538    we build the native win32 version with the system
539    calls LoadLibrary/GetProcAddress.
540    
541    ----------------------------------------------------------------------
542    Name: Matthias Blume (blume (at) tti - c (dot) org)
543    Date: 2004/03/04 16:35:00 CST
544    Tag: blume-20040304-intinf-fmt
545    Description:
546    
547    Fixed problem with IntInf.fmt (sign would show up on the right instead
548    of on the left for BIN, OCT, and HEX).
549    
550    ----------------------------------------------------------------------
551    Name: Matthias Blume (blume (at) tti - c (dot) org)
552    Date: 2004/03/04 11:25:00 CST
553    Tag: blume-20040304-symlinks
554    Description:
555    
556    Fixed problem with installer script (unix only) where bin/ml-yacc and
557    friends pointed (via symlinks) to absolute locations instead of just
558    .run-sml.  This was reported by Vesa A Norrman.
559    
560    ----------------------------------------------------------------------
561    Name: Matthias Blume (blume (at) tti - c (dot) org)
562    Date: 2004/02/13 14:50:00 CST
563    Tag: Release_110_45
564    Description:
565    
566    New working version (110.45). New bootfiles.
567    
568    ----------------------------------------------------------------------
569    Name: Matthias Blume (blume (at) tti - c (dot) org)
570    Date: 2004/01/26 15:15:15 CST
571    Tag: blume-20040126-toplevel
572    Description:
573    
574    Improved handling of exceptions at the interactive toplevel.
575    
576    ----------------------------------------------------------------------
577    Name: Matthias Blume (blume (at) tti - c (dot) org)
578    Date: 2004/01/26 11:25:00
579    Tag: blume-20040126-app
580    Description:
581    
582    Type of top-level "app" corrected.
583    Added code for setting vp_limitPtrMask to Win32-specific runtime.
584    
585    ----------------------------------------------------------------------
586    Name: Matthias Blume (blume (at) tti - c (dot) org)
587    Date: 2003/11/18 17:10 CST
588    Tag: blume-20031118-basis-fiddle
589    Description:
590    
591    - changed Timer interface to what might become the spec
592    - POSIX_FLAGS -> BIT_FLAGS according to spec
593    - some other minor discrepancies wrt. spec eliminated
594    
595    ----------------------------------------------------------------------
596    Name: Matthias Blume (blume (at) tti - c (dot) org)
597    Date: 2003/11/06 12:00:00 CST
598    Tag: Release_110_44
599    Description:
600    
601    New working version (110.44). New bootfiles.
602    
603    ----------------------------------------------------------------------
604    Name: Matthias Blume (blume (at) tti - c (dot) org)
605    Date: 2003/11/04 11:50:00 CST
606    Tag: blume-20031104-move-libraries
607    Description:
608    
609    Eliminated the "dont_move_libraries" directive in config/targets.
610    (The mechanism was broken and could not be fixed easily.  Moreover,
611    there does not seem to be any reason not to move all libraries into
612    lib during installation.  I originally implemented this directive as a
613    backward-compatibility feature when I first introduced the new CM.
614    Now that things have been stable for a long time and going back to the
615    old CM is not an option, there is no reason to keep it around.)
616    
617    ----------------------------------------------------------------------
618    Name: Matthias Blume (blume (at) tti - c (dot) org)
619    Date: 2003/11/03 16:00:00 CST
620    Tag: blume-20031103-installdir
621    Description:
622    
623    Made installer honor INSTALLDIR variable again.  (Thanks to Chris
624    Richards for pointing out the problem and providing the solution.)
625    
626    ----------------------------------------------------------------------
627    Name: Matthias Blume (blume (at) tti - c (dot) org)
628    Date: 2003/10/01 17:05:00 CDT
629    Tag: blume-20031001-lal-mlrisc
630    Description:
631    
632    MLRISC bug fix from Lal.
633    
634    ----------------------------------------------------------------------
635    Name: Matthias Blume (blume (at) tti - c (dot) org)
636    Date: 2003/09/30 16:10:00 CDT
637    Tag: blume-20030930-primio-bat
638    Description:
639    
640    1. Added openVector, nullRd, and nullWr to PRIM_IO.
641    2. Improved .bat files (for Win32 port) to make things work under Win95.
642       (thanks to Aaron S. Hawley for this one)
643    
644    ----------------------------------------------------------------------
645    Name: Matthias Blume (blume (at) tti - c (dot) org)
646    Date: 2003/09/26 16:05:00 CDT
647    Tag: blume-20030926-wrappriv
648    Description:
649    
650    Added missing wrapper for privilege "primitive" in $smlnj/viscomp/core.cm.
651    
652    ----------------------------------------------------------------------
653    Name: Matthias Blume (blume (at) tti - c (dot) org)
654    Date: 2003/09/26 15:00:00 CDT
655    Tag: blume-20030926-110_43_3
656    Description:
657    
658    - additional cleanup
659    - version number bump, NEW BOOTFILES
660    
661    ----------------------------------------------------------------------
662    Name: Matthias Blume (blume (at) tti - c (dot) org)
663    Date: 2003/09/26 12:00:00 CDT
664    Tag: blume-20030926-ppautoload
665    Description:
666    
667    I modified the read-eval-print loop so that the autoloader gets
668    invoked whenever the prettyprinter tries to look up a symbol that
669    is not currently defined in the toplevel environment but which
670    appears in CM's autoload registry.  As a result, we see far fewer of
671    those ?.Foo.Bar.xxx names in the prettyprinter's output.
672    
673    In addition to this I tried to clean up some pieces of the Basis
674    implementation (e.g., Socket, Word8Array) in order to prevent other
675    instances of these ?.Foo.Bar.xxx names from being printed.
676    
677    The mechanism that picks names for types still needs some work, though.
678    (Right now it seems that if there is a type A.t which is defined to
679    be B.u, but B is unavailable at toplevel, then A.t gets printed as
680    "?.B.u" although the perhaps more sensible solution would be to use
681    "A.t" in this case.  In other words, the prettyprinter should follow
682    a chain of DEFtycs not farther than there are corresponding toplevel
683    names in the current environment.)
684    
685    ----------------------------------------------------------------------
686    Name: Matthias Blume (blume (at) tti - c (dot) org)
687    Date: 2003/09/24 16:31:00 CDT
688    Tag: blume-20030924-installer
689    Description:
690    
691    Another installer tweak:  All the ML code for the installer is now
692    compiled during CMB.make and put into a little library called
693    $smlnj/installer.cm.  The installation then simply invokes
694    
695       sml -m $smlnj/installer.cm
696    
697    and everything happens automagically.
698    
699    Win32:  ML code senses value of environment variable SMLNJ_HOME.
700    Unix:   ML code senses values of environment variables ROOT, CONFIGDIR,
701            and BINDIR.
702    
703    The new scheme guarantees that the ML code responsible for the installation
704    is in sync with the APIs of the main system.  Also, the installer is
705    somewhat faster because the installer script is precompiled.
706    
707    ----------------------------------------------------------------------
708    Name: Matthias Blume (blume (at) tti - c (dot) org)
709    Date: 2003/09/24 15:35:00 CDT
710    Tag: blume-20030924-synsock
711    Description:
712    
713    Added a signature SYNCHRONOUS_SOCKET to basis.cm.  This is like SOCKET
714    but excludes all non-blocking operations.  Defined SOCKET (in Basis)
715    and CML_SOCKET in terms of SYNCHRONOUS_SOCKET.  Removed superfluous
716    implementations of non-blocking operations from CML's Socket
717    structure.
718    
719    ----------------------------------------------------------------------
720    Name: Matthias Blume (blume (at) tti - c (dot) org)
721    Date: 2003/09/24 15:10:05 CDT
722    Tag: blume-20030924-sockets
723    Description:
724    
725    1. Fixed SOCKET API and implementation to match Basis spec.
726       This required changing the internal representation of sockets to one
727       that remembers (for each socket file descriptor) whether it is currently
728       blocking or non-blocking.  This state is maintained lazily (i.e., a system
729       call is made only if the state actually needs to change).
730    
731    2. OS-specific details of sockets were moved into separate files, thus
732       making it possible to unify the bulk of the socket implementations
733       between Unix and Win32.
734    
735    3. CML's socket API changed accordingly.
736       (Note that we need to remove non-blocking functions from this API
737       since they are redundant in the case of CML!)
738    
739    4. CML's socket implementation now makes use of non-blocking functions
740       provided by Basis, thus removing all OS-dependent code from this part
741       of CML.
742    
743    5. Changed Real64.precision from 52 to 53.  Minor cleanup in Real64 code.
744    
745    ----------------------------------------------------------------------
746    Name: Matthias Blume (blume (at) tti - c (dot) org)
747    Date: 2003/09/22 12:10:00 CDT
748    Tag: blume-20030922-110_43_2
749    Description:
750    
751    Made a new interim version and bootfiles for developer's bootstrapping
752    convenience.
753    
754       110.43.2 -- NEW BOOTFILES
755    
756    ----------------------------------------------------------------------
757    Name: Matthias Blume (blume (at) tti - c (dot) org)
758    Date: 2003/09/19 15:55:00 CDT
759    Tag: blume-20030919-cmdir
760    Description:
761    
762    1. new-install.sh -> install.sh
763    2. changed default CM "metadata" directory name to ".cm" (instead of "CM")
764    3. tweaked installer so that another name instead of .cm can be chosen
765       at install time (by setting the CM_DIR_ARC environment variable
766       during installation); once installation is complete, the name is
767       fixed
768    
769    ----------------------------------------------------------------------
770    Name: Matthias Blume (blume (at) tti - c (dot) org)
771    Date: 2003/09/18 16:00:00 CDT
772    Tag: blume-20030918-110_43_1
773    Description:
774    
775    Made a new interim version and bootfiles for developer's bootstrapping
776    convenience.
777    
778       110.43.1 -- NEW BOOTFILES
779    
780    ----------------------------------------------------------------------
781    Name: Matthias Blume (blume (at) tti - c (dot) org)
782    Date: 2003/09/18 15:20:00 CDT
783    Tag: blume-20030918-misc
784    Description:
785    
786    1. Exported fractionsPerSecond etc. from TimeImp (but not from Time as
787       this seems to be controversial at the moment) and used those in
788       Posix.ProcEnv.times.
789    
790    2. Added Time.{from,to}Nanoseconds to Time.
791    
792    3. Improved Real.{from,to}LargeInt by avoiding needless calculations.
793       For example, fromLargeInt never needs to look at more than 3 "big
794       digits" to get its 53 bits of precision.
795    
796    ----------------------------------------------------------------------
797    Name: Matthias Blume (blume (at) tti - c (dot) org)
798    Date: 2003/09/17 16:30:00 CDT
799    Tag: blume-20030917-real32-slices
800    Description:
801    
802    Added an entry to the primitive environment
803    (compiler/Semant/statenv/prim.sml) for int32->real64 conversion and
804    added code to compiler/CodeGen/main/mlriscGen.sml to implement it.
805    
806    Removed some of the "magic" constants in real64.sml and replaced them
807    with code that generates these values from their corresponding
808    integer counterparts.
809    
810    Made all(?) the slice-related changes to the Basis and made everything
811    compile again...
812    
813    ----------------------------------------------------------------------
814    Name: Matthias Blume (blume (at) tti - c (dot) org)
815    Date: 2003/09/15 17:45:00 CDT
816    Tag: blume-20030915-rbase
817    Description:
818    
819    Fixed bug in Real.fromLargeInt.
820    
821    ----------------------------------------------------------------------
822    Name: Matthias Blume (blume (at) tti - c (dot) org)
823    Date: 2003/09/13 18:11:00 CDT
824    Tag: blume-20030913-libinstall
825    Description:
826    
827    Minor bugfix in config/libinstall (set anchor with path to
828    standalone tool after installing it, otherwise libraries that
829    need ml-lex or ml-yacc won't compile the first time the installer
830    runs).
831    
832    ----------------------------------------------------------------------
833    Name: Matthias Blume (blume (at) tti - c (dot) org)
834    Date: 2003/09/12 11:45:00 CDT
835    Tag: blume-20030912-various
836    Description:
837    
838     - fixed bug in Real.toLargeInt
839     - fixed bug in Posix.ProcEnv.times
840     - changed inputLine functions to return an option
841     - minor installer improvements / bugfixes
842     - changed default @SMLalloc parameter for x86/celeron to 64k
843    
844    ----------------------------------------------------------------------
845    Name: Matthias Blume (blume (at) tti - c (dot) org)
846    Date: 2003/09/09 22:00:00 CDT
847    Tag: Release_110_43
848    Description:
849    
850        New working release 110.43.  New bootfiles.
851    
852    ----------------------------------------------------------------------
853    Name: Matthias Blume (blume (at) tti - c (dot) org)
854    Date: 2003/09/09 19:20:00 CDT
855    Tag: blume-20030909-installer
856    Description:
857    
858    Rewrote large parts of config/install.sh in SML (config/libinstall.sml).
859    Modified config/install.bat to take advantage of it.  Also modified
860    config/install.sh (and called it config/new-install.sh) to take advantage
861    of it on Unix systems.  (The SML code is (supposed to be) platform-
862    independent.)
863    
864    The installer can now install everything under Win32
865    as well as under *nix as long as it compiles.
866    
867    Other changes:
868    
869      - made CML compile again under Win32
870      - made eXene compile under Win32 (by providing a fake structure UnixSock
871        and by using OS.Process.getEnv instead of Posix.ProcEnv.getenv)
872      - fixed a bug in nowhere: it assumed that type OS.Process.status is the
873        same as type int;  under Win32 it isn't
874      - fixed some slice-related problems in the win32-specific parts of CML
875      - added a functor argument "sameVol" to os-path-fn.sml in the Basis
876        (under Win32, the volume name is case-insensitive, and the
877        OS.Path code compares volume names for equality)
878    
879    ----------------------------------------------------------------------
880    Name: Matthias Blume (blume (at) tti - c (dot) org)
881    Date: 2003/09/08 11:55:00 CDT
882    Tag: blume-20030908-fullpath
883    Description:
884    
885    Made Win32 version of OS.FileSys.fullPath return current directory
886    when given an empty string.  This is what the spec says, and incidentally,
887    CM depends on it.  (CM otherwise goes into an infinite loop in certain
888    cases when presented with the name of a non-existing .cm file.)
889    
890    ----------------------------------------------------------------------
891    Name: Matthias Blume (blume (at) tti - c (dot) org)
892    Date: 2003/09/04 16:30:00 CDT
893    Tag: blume-20030905-slices-etc
894    Description:
895    
896      1. Changed interface to vectors and arrays in Basis to match
897         (draft) Basis spec.
898      2. Added signatures and implementations of slices according to
899         Basis spec.
900      3. Edited source code throughout the system to make it compile again
901         under 1. and 2.  (In some cases code had to be added to have it
902         match the new signatures.)
903      4. MLRISC should be backward-compatible: the copies of the originals
904         of files that needed to change under 3. were retained, the .cm files
905         check the compiler version number and use old versions when
906         appropriate.
907      5. Changed type of OS.FileSys.readDir and Posix.FileSys.readdir to
908         dirstream -> string option (in accordance with Basis spec).
909      6. When generating code that counts lines, ml-lex used function
910         CharVector.foldli, taking advantage of its old interface.
911         This has been replaced with the corresponding code from
912         CharVectorSlice.  (html-lex must be re-lexed!)
913      7. BitArray in smlnj-lib/Util has been extended/modified to match the
914         new MONO_ARRAY signature.  (Do we need BitArraySlice?)
915      8. Removed temporary additions (fromInternal, toInternal) from the
916         (now obsolete) IntInf in smlnj-lib/Util.
917      9. Cleaned up structure Byte.
918     10. Added localOffset, scan, and fromString to Date (according to spec).
919         Cleaned/corrected implementation of Date.
920         (Still need to check for correctness; implement better canonicalizeDate.)
921     11. Added "scan" to signature IEEE_REAL.
922     12. Some improvements to IntInf [in particular: efficiency-hack for
923         mod and rem when second operand is 2 (for parity checks).]
924     13. Changed representation of type Time.time, using a single IntInf.int
925         value counting microseconds.  This considerably simplified the
926         implementation of structure Time.  We now support negative time
927         values; scan and fromString handle signs.
928     14. Functor PrimIO now takes two additional arguments (VectorSlice and
929         ArraySlice).
930    
931    ----------------------------------------------------------------------
932    Name: Matthias Blume (blume (at) tti - c (dot) org)
933    Date: 2003/08/28 17:00:00 CDT
934    Tag: blume-20030828-intinf
935    Description:
936    
937    This is a major update which comes with a version number bump
938    (110.42.99 -- yes, we are really close to 110.43 :-), NEW BOOTFILES,
939    and an implementation of IntInf in the Basis.
940    
941    There are a fairly large number of related changes and updates throughout
942    the system:
943    
944    Basis:
945            - Implemented IntInf.
946            - Made LargeInt a projection of IntInf (by filtering through INTEGER).
947            - Added some missing Real64 operations, most notably Real.toLargeInt.
948            - Added FixedInt as a synonym for Int32.
949    
950    compiler:
951            * Added support for a built-in intinf type.
952              - literals
953              - pattern matching
954              - conversion shortcuts (Int32.fromLarge o Int.toLarge etc.)
955              - overloading on literals and operations
956    
957            This required adding a primitive type intinf, some additional
958            primops, and implementations for several non-trivial intinf
959            operations in Core.  (The intinf type is completely abstract
960            to the compiler; all operations get delegated back to the Core.)
961    
962            * Intinf equality is handled by polyequal.  However, the compiler
963            does not print its usual warning in this case (since polyequal
964            is the right thing to do there).
965    
966            * Improved the organization of structure InlineT.
967    
968            * A word about conversion primops:
969            If conversions involving intinf do not cancel out during
970            CPS contract, then the compiler must insert calls to Core functions.
971            Since all core access must be resolved already during the FLINT
972            translate phase, it would be too late a the time of CPS contract
973            to add new Core calls.  For this reason, conversion primops
974            for intinf carry two arguments:  1. the numeric argument that
975            they are supposed to convert, and 2. the Core function that
976            can help with this conversion if necessary.  If CPS contract
977            eliminates a primop, then the associated Core function becomes
978            dead and goes away.  Intinf conversion primops that do not get
979            eliminated by CPS contract get rewritten into calls of their
980            core functions by a separate, new phase.
981    
982    interactive system:
983            - Control.Print.intinfDepth controls max length of intinf constants
984            being printed. (Analogous to Control.Print.stringDepth.)
985            - Cleanup in printutil and pputil: got rid of unused stuff and
986            duplicates; replaced some of the code with code that makes better
987            use of library functionality.
988    
989    CM:
990            Bugfix: parse-errors in init group (system/smlnj/init/init.cmi)
991            are no longer silent.
992    
993    CKIT:
994            Fixed mismatched uses of Int32 and LargeInt.  I always decided
995            in favor of LargeInt -- which is now the same as IntInf.
996            CKIT-knowledgable people should check whether this is what's
997            intended and otherwise change things back to using Int32 or
998            FixedInt.
999    
1000    Throughout the code:
1001            Started using IntInf.int literals and built-in operations
1002            (e.g., comparison with 0) where this seems appropriate.
1003    
1004    
1005    ----------------------------------------------------------------------
1006    Name: Dave MacQueen (dbm@cs.uchicago.edu)
1007    Date: 2003/08/13 11:36:00 CDT
1008    Tag: dbm-20030813-mcz-merge1
1009    Description:
1010    
1011    Merging changes from the mcz-branch development branch into trunk.
1012    These changes involve replacement of the emulated old prettyprinter
1013    interface with direct use of the SML/NJ Lib PP library, and fixing
1014    of a couple of bugs (895, 1186) relating to error messages.  A new
1015    prettyprinter for ast datatypes (Elaborator/print/ppast.{sig,sml})
1016    has been added.
1017    
1018    ----------------------------------------------------------------------
1019    Name: Matthias Blume (blume (at) tti - c (dot) org)
1020    Date: 2003/08/11 15:45:00 CDT
1021    Tag: blume-20030811-windows
1022    Description:
1023    
1024    Version number bumped to 110.42.9.  NEW BOOTFILES!!!
1025    
1026        http://smlnj.cs.uchicago.edu/dist/working/110.42.9/
1027    
1028    This patch restores SML/NJ's ability to run under win32.  There are a
1029    number of changes, including fixes for several bugs that had gone
1030    unnoticed until now:
1031    
1032      - uname "CYGWIN_NT*" is recognized as win32 (This is relevant only when
1033        trying to run the win32 version from within cygwin.)
1034    
1035      - There are a number of simple .bat scripts that substitute for their
1036        corresponding Unix shell-scripts.  (See below.)
1037    
1038      - The internals of ml-build have been modified slightly.  The main
1039        difference is that instead of calling ".link-sml" (or link-sml.bat)
1040        using OS.Process.system, the ML process delegates this task back
1041        to the script.  Otherwise problems arise in mixed environments such
1042        as Cygwin where scripts look and work like Unix scripts, but
1043        where OS.Process.system cannot run them.
1044    
1045      - In CM, the srcpath pickler used native pathname syntax -- which
1046        is incorrect in the case of cross-compilation.  The new pickle format
1047        is independent of platform-specific naming conventions.
1048    
1049      - Path configuration files (such as lib/pathconfig) can now choose
1050        between native and standard syntax.  Placing a line of the form
1051    
1052            standard!
1053    
1054        into the file causes all subsequent paths to be interpreted using
1055        CM standard pathname syntax (= Unix conventions); a line
1056    
1057            native!
1058    
1059        switches back to native style.  This was needed so that
1060        path config files can be written portably, see src/system/pathconfig.
1061    
1062      - Runtime system:
1063    
1064          - win32-filesys.c:  get_file_time and set_file_time now
1065            access modification time, not creation time.
1066    
1067          - I/O code made aware of new array representation.
1068    
1069          - Bug fixes in X86.prim.masm.
1070    
1071       - src/system/makeml made aware of win32. (For use under cygwin
1072            and other Unix-environments for windows.)
1073    
1074       - In Basis, fixed off-by-one error in win32-io.sml (function vecF)
1075         which caused BinIO.inputAll to fail consistently.
1076    
1077    .bat scripts:
1078    
1079       Windows .bat scripts assume that SMLNJ_HOME is defined.
1080    
1081       - sml.bat, ml-yacc.bat, ml-lex.bat:  Driver scripts for standalone
1082         applications (sml, ml-yacc, ml-lex).
1083       - ml-build.bat: analogous to ml-build.
1084       - config\install.bat:  Analogous to config/install.sh.  This requires
1085         that SMLNJ_HOME is set and that Microsoft Visual C is ready to use.
1086         (nmake etc. must be on the path, and vcvars32 must have been run.)
1087         Moreover, sources for ml-lex and ml-yacc need to exist under src,
1088         and the bootfile hierarchy must have been unpacked under
1089         sml.boot.x86-win32.
1090         The script is very primitive and does a poor job at error checking.
1091         It only installs the base system, ml-lex, and ml-yacc.  No other
1092         libraries are being installed (i.e., you get only those that
1093         are part of the compiler.)
1094       - link-sml.bat:  analogous to .link-sml, but not currently used
1095    
1096    Unrelated bug fixes:
1097    
1098      - ml-nlffigen now exports structures ST_* corresponding to incomplete
1099        types.
1100      - Added getDevice to PP/src/pp-debug-fn.sml.  (Would not compile
1101        otherwise.)
1102    
1103    ----------------------------------------------------------------------
1104    Name: Dave MacQueen (macqueen@cs.uchicago.edu)
1105    Date: 2003/06/17
1106    Tag: macqueen-20030617-bug895
1107    Description:
1108    
1109    Modified compiler/Elaborator/print/pptype.sml to fix bug 895.
1110    Tag will be used for new development branch (mcz-branch) for
1111    use by MacQueen, (Lucasz) Zairek, and (George) Cao at uchicago.
1112    
1113    ----------------------------------------------------------------------
1114    Name: Matthias Blume (blume (at) tti - c (dot) org)
1115    Date: 2003/05/27 16:55:00 CDT
1116    Tag: blume-20030527-polyeq
1117    Description:
1118    
1119    Tried to eliminated most cases of polymorphic equality.
1120    
1121    ----------------------------------------------------------------------
1122    Name: Matthias Blume (blume (at) tti - c (dot) org)
1123    Date: 2003/05/21 17:45:00 CDT
1124    Tag: blume-20030517-complete
1125    Description:
1126    
1127    Two changes:
1128    
1129      1. Added a flag for controlling whether non-exhaustive bindings will
1130         be treated as errors (default is false).
1131      2. Cleaned up the *entire* source tree so that CMB.make goes through
1132         without a single non-exhaustive match- or bind warning.
1133    
1134    ----------------------------------------------------------------------
1135    Name: Matthias Blume (blume (at) tti - c (dot) org)
1136    Date: 2003/05/17 10:20:00 CDT
1137    Tag: blume-20030517-absyn
1138    Description:
1139    
1140    1. Added cases for IF, WHILE, ANDALSO, and ORELSE to Absyn.
1141    
1142       This mainly affects the quality of error messages.  However, some
1143       of the code is now more straightforward than before. (Treatment of
1144       the above four constructs in translate.sml is much simpler than
1145       the "macro-expansion" that was going on before.  Plus, the mach-
1146       compiler no longer gets invoked just to be able to compile an
1147       if-expression.)
1148    
1149    2. The ErrorMsg.Error exception is now caught and absorbed by the
1150       interactive loop.
1151    
1152    ----------------------------------------------------------------------
1153    Name: Allen Leung
1154    Date: 2003/05/16 13:05:00 CDT
1155    Tag: leunga-20030516-cygwin-runtime
1156    Description:
1157    
1158        Ported the runtime system to cygwin, which uses the unix
1159    x86-unix bin files.  Missing/buggy features:
1160    
1161       o getnetbyname, getnetbyaddr: these functions seem to be missing in
1162         the Cygwin library.
1163       o Ctrl-C handling may be flaky.
1164       o Windows system calls and Windows I/O are not supported.
1165    
1166       A new set of binfiles is located at:
1167    
1168         http://www.dorsai.org/~leunga/boot.x86-unix.tgz
1169    
1170       This is only needed for bootstrapping the cygwin version of smlnj.
1171       Other x86 versions can use the existing binfiles.
1172    
1173    ----------------------------------------------------------------------
1174    Name: Matthias Blume
1175    Date: 2003/04/08 15:42:00 CDT
1176    Tag: blume-20030408-listpair
1177    Description:
1178    
1179    1. Added a target 'mlrisc' to installer.
1180    
1181    2. Added missing elements to structure ListPair.
1182    
1183    ----------------------------------------------------------------------
1184    Name: Allen Leung
1185    Date: 2003/01/07 10:40:00 EST
1186    Tag: leunga-20030107-int-rem
1187    Description:
1188    
1189    Fixed a bug in Int.rem(x,y) where y is a power of 2 on x86.
1190    The arguments to the SUBL instruction were swapped.
1191    
1192    ----------------------------------------------------------------------
1193    Name: Matthias Blume
1194    Date: 2002/12/12 16:25:00 EST
1195    Tag: blume-20021212-risc-ra
1196    Description:
1197    
1198    Fixed a serious bug in the rewrite code for FP spilling/reloading that
1199    sent the RA into an infinite loop when floating point registers get
1200    spilled.  (Because of this bug, e.g., nucleic stopped compiling between
1201    110.37 and 110.38.)
1202    There was another set of potential problems related to the handling of
1203    MLRISC annotations (but those did not yet cause real problems, apparently).
1204    
1205    ----------------------------------------------------------------------
1206    Name: Matthias Blume
1207    Date: 2002/12/06 22:40:00 EST
1208    Tag: blume-20021206-cm-fileid
1209    Description:
1210    
1211    Added a call of SrcPath.sync at the beginning of Parse.parse (in CM).
1212    This fixes the problem of CM getting confused by files that suddenly
1213    change their identity (e.g., by getting unlinked and recreated by some
1214    text editor such as vi).  There might be a better/cheaper/cleaner way
1215    of doing this, but for now this will have to do.
1216    
1217    ----------------------------------------------------------------------
1218    Name: Matthias Blume
1219    Date: 2002/10/28 09:50:00 EST
1220    Tag: blume-20021028-typecheck
1221    Description:
1222    
1223    Exported structure Typecheck from $smlnj/viscomp/core.cm.
1224    
1225    ----------------------------------------------------------------------
1226    Name: Matthias Blume
1227    Date: 2002/10/17 09:10:00 EDT
1228    Tag: Release_110_42
1229    Description:
1230    
1231    In good old tradition, there has been a slight hiccup so that we have
1232    to patch 110.42 after the fact.   The old release tag has been replaced
1233    (see below).
1234    
1235    The change solves a problem with two competing approaches the
1236    configuration problem regarding MacOS 10.1 vs. MacOS 10.2 which got in
1237    each other's way.
1238    
1239    This change only affects the runtime system code and the installer script.
1240    (No new bootfiles.)
1241    
1242    ----------------------------------------------------------------------
1243    Name: Matthias Blume
1244    Date: 2002/10/16 12:00:00 EDT
1245    Tag: Release_110_42_removed
1246    Description:
1247    
1248    New working release.  New bootfiles.
1249    
1250    ----------------------------------------------------------------------
1251    Name: Matthias Blume
1252    Date: 2002/10/10 13:10:00 EDT
1253    Tag: blume-20021010-ppc-divs
1254    Description:
1255    
1256    The mltree operator DIVS must be implemented with an overflow check on
1257    the PPC because the hardware indicates divide-by-zero using "overflow" as
1258    well.
1259    
1260    ----------------------------------------------------------------------
1261    Name: Matthias Blume
1262    Date: 2002/07/23 11:45:00
1263    Tag: blume-20020723-smlnj-home
1264    Description:
1265    
1266    Sml now senses the SMLNJ_HOME environment variable.  If this is set,
1267    then the bin dir is assumed to be in $SMLNJ_HOME/bin and (unless
1268    CM_PATHCONFIG is also set), the path configuration file is assumed
1269    to be in $SMLNJ_HOME/lib/pathconfig.  This way one can easily move
1270    the entire tree to some other place and everything will "just work".
1271    
1272    (Companion commands such as ml-build and ml-makedepend also sense this
1273    variable.)
1274    
1275    ----------------------------------------------------------------------
1276    Name: Matthias Blume
1277    Date: 2002/07/12 21:19:00 EDT
1278    Tag: blume-20020712-liveness
1279    Description:
1280    
1281    Exported two useful "step" functions from liveness module (MLRISC).
1282    
1283    ----------------------------------------------------------------------
1284    Name: Matthias Blume
1285    Date: 2002/07/05 16:00 EDT
1286    Tag: Release_110_41
1287    Description:
1288    
1289    New working release.  New bootfiles.
1290    
1291    ----------------------------------------------------------------------
1292    Name: Matthias Blume
1293    Date: 2002/07/05 10:25:00 EDT
1294    Tag: blume-20020705-btimp
1295    Description:
1296    
1297    Exported structure BTImp from $smlnj/viscomp/debugprof.cm so that
1298    other clients can set up backtracing support.
1299    
1300    ----------------------------------------------------------------------
1301    Name: Matthias Blume
1302    Date: 2002/06/25 17:23:00 EDT
1303    Tag: blume-20020625-fpmax
1304    Description:
1305    
1306    Fixed a bug in translation of INLMAX (and INLMIN) for the floating-point
1307    case.  (The sense of the isNaN test was reversed -- which made min and
1308    max always return their first argument.)
1309    
1310    ----------------------------------------------------------------------
1311    Name: Matthias Blume
1312    Date: 2002/06/11
1313    Tag: blume-20020611-unixpath
1314    Description:
1315    
1316    Back-ported OS.Path.{from,to}UnixPath from idlbasis-devel branch.
1317    
1318    ----------------------------------------------------------------------
1319    Name: Matthias Blume
1320    Date: 2002/06/10 16:35:00 EDT
1321    Tag: blume-20020610-ieeereal
1322    Description:
1323    
1324    I back-ported my implementation of IEEEReal.fromString from the
1325    idlbasis-devel branch so that we can test it.
1326    
1327    Another small change is that ppDec tries to give more information
1328    than just "<sig>" in the case of functors.  However, this code is
1329    broken in some mysterious way if the functor's body's signature
1330    has not been declared by ascription but gets inferred from the
1331    implementation.  This needs fixing...
1332    
1333    ----------------------------------------------------------------------
1334    Name: Matthias Blume
1335    Date: 2002/05/31
1336    Tag: blume-20020531-btrace-mode
1337    Description:
1338    
1339    Resurrected SMLofNJ.Internals.BTrace.mode.  (It accidentally fell by
1340    the wayside when I switched over to using Controls everywhere.)
1341    
1342    ----------------------------------------------------------------------
1343    Name: Lal George
1344    Date: 2002/05/23 12:21:40 EDT
1345    Tag: george-20020523-visual-labels
1346    Description:
1347    
1348    Labels are now displayed in the graphical output to make
1349    the fall-through and target blocks obvious.
1350    
1351    ----------------------------------------------------------------------
1352    Name: Matthias Blume
1353    Date: 2002/05/22 11:03:00 EDT
1354    Tag: blume-20020522-shrink
1355    Description:
1356    
1357    John tweaked yesterday's fix for 1131 to handle an out-of-memory
1358    situation that comes up when allocating huge arrays.
1359    
1360    ----------------------------------------------------------------------
1361    Name: Matthias Blume
1362    Date: 2002/05/21 16:00:00 EDT
1363    Tag: Release_110_40
1364    Description:
1365    
1366    New working release (110.40).  New bootfiles.
1367    
1368    [Also: John Reppy fixed GC bug 1131.]
1369    
1370    ----------------------------------------------------------------------
1371    Name: Matthias Blume
1372    Date: 2002/05/21 12:35:00 EDT
1373    Tag: blume-20020521-cmdoc
1374    Description:
1375    
1376    CM documentation update.
1377    
1378    ----------------------------------------------------------------------
1379    Name: Matthias Blume
1380    Date: 2002/05/21 10:55:00 EDT
1381    Tag: blume-20020521-misc
1382    Description:
1383    
1384    - John tweaked runtime to be silent on heap export (except when
1385      GC messages are on).
1386    - I added a few more things (cross-compiling versions of CMB) to
1387      config/preloads (as suggestions).
1388    
1389    ----------------------------------------------------------------------
1390    Name: Matthias Blume
1391    Date: 2002/05/20 22:25:00 EDT
1392    Tag: blume-20020520-controls
1393    Description:
1394    
1395    - Added ControlUtil structure to control-lib.cm.
1396    - Use it throughout.
1397    - Used Controls facility to define MLRISC controls (as opposed to
1398      registering MLRISC control ref cells with Controls after the fact)
1399    - Fixed messed-up controls priorities.
1400    
1401    * Removed again all the stuff from config/preloads that one wouldn't
1402      be able to preload at the time the initial heap image is built.
1403      (Many libraries, e.g., CML, do not exist yet at this time.  The
1404       only libraries that can be preloaded via config/preloads are those
1405       that come bundled with the bootfiles.)
1406    
1407    ----------------------------------------------------------------------
1408    Name: Matthias Blume
1409    Date: 2002/05/20 10:59:00 EDT
1410    Tag: blume-20020520-preloads
1411    Description:
1412    
1413    Added a lot of commented-out suggestions for things to be included
1414    in config/preloads.
1415    
1416    ----------------------------------------------------------------------
1417    Name: Allen Leung
1418    Date: 2002/05/18 14:20:00 EDT
1419    Tag: leunga-20020518-mdl
1420    Description:
1421    
1422    o Made the mdl tool stuff compile and run again.
1423    o I've disabled all the stuff that depends on RTL specifications; they
1424      are all badly broken anyway.
1425    
1426    ----------------------------------------------------------------------
1427    Name: Matthias Blume
1428    Date: 2002/05/17 16:49:00 EDT
1429    Tag: blume-20020517-controls
1430    Description:
1431    
1432    0. John Reppy made several modifications to the SML/NJ library.
1433       In particular, there is a shiny new controls-lib.cm.
1434    
1435    1. Pushed new controls interface through compiler so that everything
1436       compiles again.
1437    
1438    2. Added FormatComb and FORMAT_COMB to the CML version of the
1439       SML/NJ library (so that CML compiles again).
1440    
1441    3. Modified init scripts because XXX_DEFAULT environment variables
1442       are no longer with us.  (Boot-time initialization is now done
1443       using the same environment variables that are also used for
1444       startup-time initialization of controls.)
1445    
1446    ----------------------------------------------------------------------
1447    Name: Lal George
1448    Date: 2002/05/15 09:20:10 EDT
1449    Tag: george-20020515-pseudo-op-decls
1450    Description:
1451    
1452            All pseudo-ops emitted before the first segment declaration
1453    such as TEXT, DATA, and BSS directives are assumed to be global
1454    declarations and are emitted first in the assembly file. This is
1455    useful in a number of situations where one has pseudo-ops that are not
1456    specific to any segment, and also works around the constraint that one
1457    cannot have client pseudo-ops in the TEXT segment.
1458    
1459            Because no segment is associated with these declarations it is
1460    an error to allocate any space or objects before the first segment
1461    directive and an exception will be raised. However, we cannot make
1462    this check for client pseudo-ops.
1463    
1464            These top level declarations are a field in the CFG graph_info.
1465    In theory you can continue to add to this field after the CFG has been
1466    built -- provided you know what you are doing;-)
1467    
1468    ----------------------------------------------------------------------
1469    Name: Matthias Blume
1470    Date: 2002/05/13 16:40:00 EDT
1471    Tag: blume-20020513-pp-etc
1472    Description:
1473    
1474    A few minor bugfixes:
1475    
1476      - Stopgap measure for bug recently reported by Elsa Gunter (ppDec).
1477        (Bogus printouts for redefined bindings still occur.  Compiler
1478        bug should no longer occur now.  We need to redo the prettyprinter
1479        from scratch.)
1480    
1481      - CM pathname printer now also adds escape sequences for ( and )
1482    
1483      - commend and docu fixes for ml-nlffi
1484    
1485    ----------------------------------------------------------------------
1486    Name: Matthias Blume
1487    Date: 2002/05/10 16:40:00 EDT
1488    Tag: blume-20020510-erg-textio
1489    Description:
1490    
1491    Applied the following bugfix provided by Emden Gansner:
1492    
1493        Output is corrupted when outputSubstr is used rather than output.
1494    
1495        The problem occurs when a substring
1496    
1497            ss = (s, dataStart, dataLen)
1498    
1499        where dataStart > 0, fills a stream buffer with avail bytes left.
1500        avail bytes of s, starting at index dataStart, are copied into the
1501        buffer, the buffer is flushed, and then the remaining dataLen-avail
1502        bytes of ss are copied into the beginning of the buffer. Instead of
1503        starting this copy at index dataStart+avail in s, the current code
1504        starts the copy at index avail.
1505    
1506        Fix:
1507        In text-io-fn.sml, change line 695 from
1508             val needsFlush = copyVec(v, avail, dataLen-avail, buf, 0)
1509        to
1510             val needsFlush = copyVec(v, dataStart+avail, dataLen-avail, buf, 0)
1511    
1512    ----------------------------------------------------------------------
1513    Name: Matthias Blume
1514    Date: 2002/04/12 13:55:00 EDT
1515    Tag: blume-20020412-assyntax
1516    Description:
1517    
1518    1. Grabbed newer assyntax.h from the XFree86 project.
1519    2. Fiddled with how to compile X86.prim.asm without warnings.
1520    3. (Very) Minor cleanup in CM.
1521    
1522    ----------------------------------------------------------------------
1523    Name: Matthias Blume
1524    Date: 2002/04/01 (no joke!) 17:07:00 EST
1525    Tag: blume-20020401-x86div
1526    Description:
1527    
1528    Added full support for div/mod/rem/quot on the x86, using the machine
1529    instruction's two results (without clumsily recomputing the remainder)
1530    directly where appropriate.
1531    
1532    Some more extensive power-of-two support was added to the x86 instruction
1533    selector (avoiding expensive divs, mods, and muls where they can be
1534    replaced with cheaper shifts and masks).  However, this sort of thing
1535    ought to be done earlier, e.g., within the CPS optimizer so that
1536    all architectures benefit from it.
1537    
1538    The compiler compiles to a fixed point, but changes might be somewhat
1539    fragile nevertheless.  Please, report any strange things that you might
1540    see wrt. div/mod/quot/rem...
1541    
1542    ----------------------------------------------------------------------
1543    Name: Matthias Blume
1544    Date: 2002/03/29 17:22:00
1545    Tag: blume-20020329-div
1546    Description:
1547    
1548    Fixed my broken div/mod logic.  Unfortunately, this means that the
1549    inline code for div/mod now has one more comparison than before.
1550    Fast paths (quotient > 0 or remainder = 0) are not affected, though.
1551    The problem was with quotient = 0, because that alone does not tell
1552    us which way the rounding went.  One then has to look at whether
1553    remainder and divisor have the same sign...  :(
1554    
1555    Anyway, I replaced the bootfiles with fresh ones...
1556    
1557    ----------------------------------------------------------------------
1558    Name: Matthias Blume
1559    Date: 2002/03/29 14:10:00 EST
1560    Tag: blume-20020329-inlprims
1561    Description:
1562    
1563    NEW BOOTFILES!!!    Version number bumped to 110.39.3.
1564    
1565    Primops have changed. This means that the bin/boot-file formats have
1566    changed as well.
1567    
1568    To make sure that there is no confusion, I made a new version.
1569    
1570    
1571    CHANGES:
1572    
1573    * removed REMT from mltree (remainder should never overflow).
1574    
1575    * added primops to deal with divisions of all flavors to the frontend
1576    
1577    * handled these primops all the way through so they map to their respective
1578      MLRISC support
1579    
1580    * used these primops in the implementation of Int, Int32, Word, Word32
1581    
1582    * removed INLDIV, INLMOD, and INLREM as they are no longer necessary
1583    
1584    * parameterized INLMIN, INLMAX, and INLABS by a numkind
1585    
1586    * translate.sml now deals with all flavors of INL{MIN,MAX,ABS}, including
1587      floating point
1588    
1589    * used INL{MIN,MAX,ABS} in the implementation of Int, Int32, Word, Word32,
1590      and Real (but Real.abs maps to a separate floating-point-only primop)
1591    
1592    
1593    TODO items:
1594    
1595    * Hacked Alpha32 instruction selection, disabling the selection of REMx
1596      instructions because the machine instruction encoder cannot handle
1597      them.  (Hppa, PPC, and Sparc instruction selection did not handle
1598      REM in the first place, and REM is supported by the x86 machine coder.)
1599    
1600    * Handle DIV and MOD with DIV_TO_NEGINF directly in the x86 instruction
1601      selection phase.  (The two can be streamlined because the hardware
1602      delivers both quotient and remainder at the same time anyway.)
1603    
1604    * Think about what to do with "valOf(Int32.minInt) div ~1" and friends.
1605      (Currently the behavior is inconsistent both across architectures and
1606      wrt. the draft Basis spec.)
1607    
1608    * Word8 should eventually be handled natively, too.
1609    
1610    * There seems to be one serious bug in mltree-gen.sml.  It appears, though,
1611      as if there currently is no execution path that could trigger it in
1612      SML/NJ.  (The assumptions underlying functions arith and promotable do not
1613      hold for things like multiplication and division.)
1614    
1615    ----------------------------------------------------------------------
1616    Name: Matthias Blume
1617    Date: 2002/03/27 16:27:00 EST
1618    Tag: blume-20020327-mlrisc-divisions
1619    Description:
1620    
1621    Added support for all four division operations (ML's div, mod, quot,
1622    and rem) to MLRISC.  In the course of doing so, I also rationalized
1623    the naming (no more annoying switch-around of DIV and QUOT), by
1624    parameterizing the operation by div_rounding_mode (which can be either
1625    DIV_TO_ZERO or DIV_TO_NEGINF).
1626    
1627    The generic MLTreeGen functor takes care of compiling all four
1628    operations down to only round-to-zero div.
1629    
1630    Missing pieces:
1631    
1632      * Doing something smarter than relying on MLTreeGen on architectures
1633        like, e.g., the x86 where hardware division delivers both quotient and
1634        remainder at the same time.  With this, the implementation of the
1635        round-to-neginf operations could be further streamlined.
1636    
1637      * Remove inlining support for div/mod/rem from the frontend and replace it
1638        with primops that get carried through to the backend.  Do this for all
1639        int and word types.
1640    
1641    ----------------------------------------------------------------------
1642    Name: Matthias Blume
1643    Date: 2002/03/25 17:25:00 EST
1644    Tag: blume-20020325-divmod
1645    Description:
1646    
1647    I improved (hopefully without breaking them) the implementation of Int.div,
1648    Int.mod, and Int.rem.   For this, the code in translate.sml now takes
1649    advantage of the following observations:
1650    
1651      Let  q = x quot y      r = x rem y
1652           d = x div  y      m = x mod y
1653    
1654    where "quot" is the round-to-zero version of integer division that
1655    hardware usually provides.  Then we have:
1656    
1657         r = x - q * y        where neither the * nor the - will overflow
1658         d = if q >= 0 orelse x = q * y then q else q - 1
1659                              where neither the * nor the - will overflow
1660         m = if q >= 0 orelse r = 0 then r else r + y
1661                              where the + will not overflow
1662    
1663    This results in substantial simplification of the generated code.
1664    The following table shows the number of CFG nodes and edges generated
1665    for
1666            fun f (x, y) = x OPER y
1667            (* with OPER \in div, mod, quot, rem *)
1668    
1669    
1670        OPER | nodes(old) | edges(old) | nodes(new) | edges(new)
1671        --------------------------------------------------------
1672         div |         24 |         39 |         12 |         16
1673         mod |         41 |         71 |         12 |         16
1674        quot |          8 |         10 |          8 |         10
1675         rem |         10 |         14 |          8 |         10
1676    
1677    
1678    ----------------------------------------------------------------------
1679    Name: Matthias Blume
1680    Date: 2002/03/25 22:06:00 EST
1681    Tag: blume-20020325-cprotobug
1682    Description:
1683    
1684    Fixed a bug in cproto (c prototype decoder).
1685    
1686    ----------------------------------------------------------------------
1687    Name: Matthias Blume
1688    Date: 2002/03/25 16:00:00 EST
1689    Tag: blume-20020325-raw-primops
1690    Description:
1691    
1692    I did some cleanup to Allen's new primop code and
1693    replaced yesterday's bootfiles with new ones.
1694    (But they are stored in the same place.)
1695    
1696    ----------------------------------------------------------------------
1697    Name: Matthias Blume
1698    Date: 2002/03/24 22:40:00 EST
1699    Tag: blume-20020324-bootfiles
1700    Description:
1701    
1702    Made the bootfiles that Allen asked for.
1703    
1704    ----------------------------------------------------------------------
1705    Name: Allen Leung
1706    Date: 2002/03/23 15:50:00 EST
1707    Tag: leunga-20020323-flint-cps-rcc-primops
1708    Description:
1709    
1710      1. Changes to FLINT primops:
1711    
1712        (* make a call to a C-function;
1713         * The primop carries C function prototype information and specifies
1714         * which of its (ML-) arguments are floating point. C prototype
1715         * information is for use by the backend, ML information is for
1716         * use by the CPS converter. *)
1717      | RAW_CCALL of { c_proto: CTypes.c_proto,
1718                       ml_args: ccall_type list,
1719                       ml_res_opt: ccall_type option,
1720                       reentrant : bool
1721                     } option
1722       (* Allocate uninitialized storage on the heap.
1723        * The record is meant to hold short-lived C objects, i.e., they
1724        * are not ML pointers.  With the tag, the representation is
1725        * the same as RECORD with tag tag_raw32 (sz=4), or tag_fblock (sz=8)
1726        *)
1727      | RAW_RECORD of {tag:bool,sz:int}
1728      and ccall_type = CCALL_INT32 | CCALL_REAL64 | CCALL_ML_PTR
1729    
1730      2.  These CPS primops are now overloaded:
1731    
1732           rawload of {kind:numkind}
1733           rawstore of {kind:numkind}
1734    
1735          The one argument form is:
1736    
1737             rawload {kind} address
1738    
1739          The two argument form is:
1740    
1741             rawload {kind} [ml object, byte-offset]
1742    
1743      3. RAW_CCALL/RCC now takes two extra arguments:
1744    
1745         a. The first is whether the C call is reentrant, i.e., whether
1746            ML state should be saved and restored.
1747         b. The second argument is a string argument specifying the name of
1748            library and the C function.
1749    
1750         These things are currently not handled in the code generator, yet.
1751    
1752      4. In CProto,
1753    
1754         An encoding type of "bool" means "ml object" and is mapped into
1755         C prototype of PTR.  Note that "bool" is different than "string",
1756         even though "string" is also mapped into PTR, because "bool"
1757         is assigned an CPS type of BOGt, while "string" is assigned INT32t.
1758    
1759      5. Pickler/unpicker
1760    
1761         Changed to handle RAW_RECORD and newest RAW_CCALL
1762    
1763      6. MLRiscGen,
1764    
1765         1. Changed to handle the new rawload/rawstore/rawrecord operators.
1766         2. Code for handling C Calls has been moved to a new module CPSCCalls,
1767            in the file CodeGen/cpscompile/cps-c-calls.sml
1768    
1769      7. Added the conditional move operator
1770    
1771             condmove of branch
1772    
1773         to cps.  Generation of this is still buggy so it is currently
1774         disabled.
1775    
1776    ----------------------------------------------------------------------
1777    Name: Lal George
1778    Date: 2002/03/22 14:18:25 EST
1779    Tag: george-20020322-cps-branch-prob
1780    Description:
1781    
1782    Implemented the Ball-Larus branch prediction-heuristics, and
1783    incorporated graphical viewers for control flow graphs.
1784    
1785    Ball-Larus Heuristics:
1786    ---------------------
1787    See the file compiler/CodeGen/cpscompile/cpsBranchProb.sml.
1788    
1789    By design it uses the Dempster-Shafer theory for combining
1790    probabilities.  For example, in the function:
1791    
1792        fun f(n,acc) = if n = 0 then acc else f(n-1, n*acc)
1793    
1794    the ball-larus heuristics predicts that the n=0 is unlikely
1795    (OH-heuristic), and the 'then' branch is unlikely because of the
1796    RH-heuristic -- giving the 'then' branch an even lower combined
1797    probability using the Dempster-Shafer theory.
1798    
1799    Finally, John Reppy's loop analysis in MLRISC, further lowers the
1800    probability of the 'then' branch because of the loop in the else
1801    branch.
1802    
1803    
1804    Graphical Viewing:
1805    ------------------
1806    I merely plugged in Allen's graphical viewers into the compiler. The
1807    additional code is not much. At the top level, saying:
1808    
1809            Control.MLRISC.getFlag "cfg-graphical-view" := true;
1810    
1811    will display the graphical view of the control flow graph just before
1812    back-patching.  daVinci must be in your path for this to work. If
1813    daVinci is not available, then the default viewer can be changed
1814    using:
1815    
1816            Control.MLRISC.getString "viewer"
1817    
1818    which can be set to "dot" or "vcg" for the corresponding viewers. Of
1819    course, these viewers must be in your path.
1820    
1821    The above will display the compilation unit at the level of clusters,
1822    many of which are small, boring, and un-interesting. Also setting:
1823    
1824            Control.MLRISC.getInt "cfg-graphical-view_size"
1825    
1826    will display clusters that are larger than the value set by the above.
1827    
1828    
1829    ----------------------------------------------------------------------
1830    Name: Matthias Blume
1831    Date: 2002/03/21 22:20:00 EST
1832    Tag: blume-20020321-kmp-bugfix
1833    Description:
1834    
1835    Changed the interface to the KMP routine in PreString and fixed
1836    a minor bug in one place where it was used.
1837    
1838    ----------------------------------------------------------------------
1839    Name: Allen Leung
1840    Date: 2002/03/21 20:30:00 EST
1841    Tag: leunga-20020321-cfg
1842    Description:
1843    
1844      Fixed a potential problem in cfg edge splitting.
1845    
1846    ----------------------------------------------------------------------
1847    Name: Allen Leung
1848    Date: 2002/03/21 17:15:00 EST
1849    Tag: leunga-20020321-x86-fp-cfg
1850    Description:
1851    
1852      1. Recoded the buggy parts of x86-fp.
1853    
1854         a. All the block reordering code has been removed.
1855            We now depend on the block placement phases to do this work.
1856    
1857         b. Critical edge splitting code has been simplified and moved into the
1858            CFG modules, as where they belong.
1859    
1860         Both of these were quite buggy and complex.  The code is now much, much
1861         simpler.
1862    
1863      2. X86 backend.
1864    
1865         a. Added instructions for 64-bit support.  Instruction selection for
1866            64-bit has not been committed, however, since that
1867            requires changes to MLTREE which haven't been approved by
1868            Lal and John.
1869    
1870         b. Added support for FUCOMI and FUCOMIP when generating code for
1871            PentiumPro and above.  We only generate these instructions in
1872            the fast-fp mode.
1873    
1874         c. Added cases for JP and JNP in X86FreqProps.
1875    
1876      3. CFG
1877    
1878         CFG now has a bunch of methods for edge splitting and merging.
1879    
1880      4. Machine description.
1881    
1882         John's simplification of MLTREE_BASIS.fcond broke a few machine
1883         description things:
1884    
1885         rtl-build.{sig,sml} and hppa.mdl fixed.
1886    
1887         NOTE: the machine description stuff in the repository is still broken.
1888               Again, I can't put my fixes in because that involves
1889               changes to MLTREE.
1890    
1891    ----------------------------------------------------------------------
1892    Name: Matthias Blume
1893    Date: 2002/03/20 15:55:00 EST
1894    Tag: blume-20020320-kmp
1895    Description:
1896    
1897    Implemented Knuth-Morris-Pratt string matching in PreString and used
1898    it for String.isSubstring, Substring.isSubstring, and
1899    Substring.position.
1900    
1901    (Might need some stress-testing.  Simple examples worked fine.)
1902    
1903    ----------------------------------------------------------------------
1904    Name: Matthias Blume
1905    Date: 2002/03/19 16:37:00 EST
1906    Tag: blume-20020319-witnesses
1907    Description:
1908    
1909    Added a structure C.W and functions convert/Ptr.convert to ml-nlffi-lib.
1910    
1911    This implements a generic mechanism for changing constness qualifiers
1912    anywhere within big C types without resorting to outright "casts".
1913    (So far, functions such as C.rw/C.ro or C.Ptr.rw/C.Ptr.ro only let you
1914    modify the constness at the outermost level.)
1915    The implementation of "convert" is based on the idea of "witness"
1916    values -- values that are not used by the operation but whose types
1917    "testify" to their applicability.  On the implementation side, "convert"
1918    is simply a projection (returning its second curried argument).  With
1919    cross-module inlining, it should not result in any machine code being
1920    generated.
1921    
1922    ----------------------------------------------------------------------
1923    Name: Matthias Blume
1924    Date: 2002/03/15 16:40:00 EST
1925    Tag: blume-20020315-basis
1926    Description:
1927    
1928    Provided (preliminary?) implementations for
1929    
1930      {String,Substring}.{concatWith,isSuffix,isSubstring}
1931    
1932    and
1933    
1934      Substring.full
1935    
1936    Those are in the Basis spec but they were missing in SML/NJ.
1937    
1938    ----------------------------------------------------------------------
1939    Name: Matthias Blume
1940    Date: 2002/03/14 21:30:00 EST
1941    Tag: blume-20020314-controls
1942    Description:
1943    
1944    Controls:
1945    ---------
1946    
1947    1. Factored out the recently-added Controls : CONTROLS stuff and put
1948       it into its own library $/controls-lib.cm.  The source tree for
1949       this is under src/smlnj-lib/Controls.
1950    
1951    2. Changed the names of types and functions in this interface, so they
1952       make a bit more "sense":
1953    
1954          module -> registry
1955          'a registry -> 'a group
1956    
1957    3. The interface now deals in ref cells only.  The getter/setter interface
1958       is (mostly) gone.
1959    
1960    4. Added a function that lets one register an already-existing ref cell.
1961    
1962    5. Made the corresponding modifications to the rest of the code so that
1963       everything compiles again.
1964    
1965    6. Changed the implementation of Controls.MLRISC back to something closer
1966       to the original.  In particular, this module (and therefore MLRISC)
1967       does not depend on Controls.  There now is some link-time code in
1968       int-sys.sml that registers the MLRISC controls with the Controls
1969       module.
1970    
1971    CM:
1972    ---
1973    
1974      * One can now specify the lambda-split aggressiveness in init.cmi.
1975    
1976    ----------------------------------------------------------------------
1977    Name: Allen Leung
1978    Date: 2002/03/13 17:30:00 EST
1979    Tag: leunga-20020313-x86-fp-unary
1980    Description:
1981    
1982    Bug fix for:
1983    
1984    > leunga@weaselbane:~/Yale/tmp/sml-dist{21} bin/sml
1985    > Standard ML of New Jersey v110.39.1 [FLINT v1.5], March 08, 2002
1986    > - fun f(x,(y,z)) = Real.~ y;
1987    > [autoloading]
1988    > [autoloading done]
1989    >       fchsl   (%eax), 184(%esp)
1990    > Error: MLRisc bug: X86MCEmitter.emitInstr
1991    >
1992    > uncaught exception Error
1993    >   raised at: ../MLRISC/control/mlriscErrormsg.sml:16.14-16.19
1994    
1995    The problem was that the code generator did not generate any fp registers
1996    in this case, and the ra didn't know that it needed to run the X86FP phase to
1997    translate the pseudo fp instruction.   This only happened with unary fp
1998    operators in certain situations.
1999    
2000    ----------------------------------------------------------------------
2001    Name: Matthias Blume
2002    Date: 2002/03/13 14:00:00 EST
2003    Tag: blume-20020313-overload-etc
2004    Description:
2005    
2006    1. Added _overload as a synonym for overload for backward compatibility.
2007       (Control.overloadKW must be true for either version to be accepted.)
2008    
2009    2. Fixed bug in install script that caused more things to be installed
2010       than what was requested in config/targets.
2011    
2012    3. Made CM aware of the (_)overload construct so that autoloading
2013       works.
2014    
2015    ----------------------------------------------------------------------
2016    Name: Matthias Blume
2017    Date: 2002/03/12 22:03:00 EST
2018    Tag: blume-20020312-url
2019    Description:
2020    
2021    Forgot to update BOOT and srcarchiveurl.
2022    
2023    ----------------------------------------------------------------------
2024    Name: Matthias Blume
2025    Date: 2002/03/12 17:30:00 EST
2026    Tag: blume-20020312-version110392
2027    Description:
2028    
2029    Yet another version number bump (because of small changes to the
2030    binfile format).  Version number is now 110.39.2.  NEW BOOTFILES!
2031    
2032    Changes:
2033    
2034      The new pid generation scheme described a few weeks ago was overly
2035      complicated.  I implemented a new mechanism that is simpler and
2036      provides a bit more "stability":  Once CM has seen a compilation
2037      unit, it keeps its identity constant (as long as you do not delete
2038      those crucial CM/GUID/* files).  This means that when you change
2039      an interface, compile, then go back to the old interface, and
2040      compile again, you arrive at the original pid.
2041    
2042      There now also is a mechanism that instructs CM to use the plain
2043      environment hash as a module's pid (effectively making its GUID
2044      the empty string).  For this, "noguid" must be specified as an
2045      option to the .sml file in question within its .cm file.
2046      This is most useful for code that is being generated by tools such
2047      as ml-nlffigen (because during development programmers tend to
2048      erase the tool's entire output directory tree including CM's cached
2049      GUIDs).  "noguid" is somewhat dangerous (since it can be used to locally
2050      revert to the old, broken behavior of SML/NJ, but in specific cases
2051      where there is no danger of interface confusion, its use is ok
2052      (I think).
2053    
2054      ml-nlffigen by default generates "noguid" annotations.  They can be
2055      turned off by specifying -guid in its command line.
2056    
2057    ----------------------------------------------------------------------
2058    Name: Lal George
2059    Date: 2002/03/12 12 14:42:36 EST
2060    Tag: george-20020312-frequency-computation
2061    Description:
2062    
2063    Integrated jump chaining and static block frequency into the
2064    compiler. More details and numbers later.
2065    
2066    ----------------------------------------------------------------------
2067    Name: Lal George
2068    Date: 2002/03/11 11 22:38:53 EST
2069    Tag: george-20020311-jump-chain-elim
2070    Description:
2071    
2072    Tested the jump chain elimination on all architectures (except the
2073    hppa).  This is on by default right now and is profitable for the
2074    alpha and x86, however, it may not be profitable for the sparc and ppc
2075    when compiling the compiler.
2076    
2077    The gc test will typically jump to a label at the end of the cluster,
2078    where there is another jump to an external cluster containing the actual
2079    code to invoke gc. This is to allow factoring of common gc invocation
2080    sequences. That is to say, we generate:
2081    
2082            f:
2083               testgc
2084               ja   L1      % jump if above to L1
2085    
2086            L1:
2087               jmp L2
2088    
2089    
2090    After jump chain elimination the 'ja L1' instructions is converted to
2091    'ja L2'. On the sparc and ppc, many of the 'ja L2' instructions may end
2092    up being implemented in their long form (if L2 is far away) using:
2093    
2094            jbe     L3      % jump if below or equal to L3
2095            jmp     L2
2096         L3:
2097            ...
2098    
2099    
2100    For large compilation units L2  may be far away.
2101    
2102    
2103    ----------------------------------------------------------------------
2104    Name: Matthias Blume
2105    Date: 2002/03/11 13:30:00 EST
2106    Tag: blume-20020311-mltreeeval
2107    Description:
2108    
2109    A functor parameter was missing.
2110    
2111    ----------------------------------------------------------------------
2112    Name: Allen Leung
2113    Date: 2002/03/11 10:30:00 EST
2114    Tag: leunga-20020311-runtime-string0
2115    Description:
2116    
2117       The representation of the empty string now points to a
2118    legal null terminated C string instead of unit.  It is now possible
2119    to convert an ML string into C string with InlineT.CharVector.getData.
2120    This compiles into one single machine instruction.
2121    
2122    ----------------------------------------------------------------------
2123    Name: Allen Leung
2124    Date: 2002/03/10 23:55:00 EST
2125    Tag: leunga-20020310-x86-call
2126    Description:
2127    
2128       Added machine generation for CALL instruction (relative displacement mode)
2129    
2130    ----------------------------------------------------------------------
2131    Name: Matthias Blume
2132    Date: 2002/03/08 16:05:00
2133    Tag: blume-20020308-entrypoints
2134    Description:
2135    
2136    Version number bumped to 110.39.1.  NEW BOOTFILES!
2137    
2138    Entrypoints: non-zero offset into a code object where execution should begin.
2139    
2140    - Added the notion of an entrypoint to CodeObj.
2141    - Added reading/writing of entrypoint info to Binfile.
2142    - Made runtime system bootloader aware of entrypoints.
2143    - Use the address of the label of the first function given to mlriscGen
2144      as the entrypoint.  This address is currently always 0, but it will
2145      not be 0 once we turn on block placement.
2146    - Removed the linkage cluster code (which was The Other Way(tm) of dealing
2147      with entry points) from mlriscGen.
2148    
2149    ----------------------------------------------------------------------
2150    Name: Allen Leung
2151    Date: 2002/03/07 20:45:00 EST
2152    Tag: leunga-20020307-x86-cmov
2153    Description:
2154    
2155       Bug fixes for CMOVcc on x86.
2156    
2157       1. Added machine code generation for CMOVcc
2158       2. CMOVcc is now generated in preference over SETcc on PentiumPro or above.
2159       3. CMOVcc cannot have an immediate operand as argument.
2160    
2161    ----------------------------------------------------------------------
2162    Name: Matthias Blume
2163    Date: 2002/03/07 16:15:00 EST
2164    Tag: blume-20020307-controls
2165    Description:
2166    
2167    This is a very large but mostly boring patch which makes (almost)
2168    every tuneable compiler knob (i.e., pretty much everything under
2169    Control.* plus a few other things) configurable via both the command
2170    line and environment variables in the style CM did its configuration
2171    until now.
2172    
2173    Try starting sml with '-h' (or, if you are brave, '-H')
2174    
2175    To this end, I added a structure Controls : CONTROLS to smlnj-lib.cm which
2176    implements the underlying generic mechanism.
2177    
2178    The interface to some of the existing such facilities has changed somewhat.
2179    For example, the MLRiscControl module now provides mkFoo instead of getFoo.
2180    (The getFoo interface is still there for backward-compatibility, but its
2181    use is deprecated.)
2182    
2183    The ml-build script passes -Cxxx=yyy command-line arguments through so
2184    that one can now twiddle the compiler settings when using this "batch"
2185    compiler.
2186    
2187    TODO items:
2188    
2189    We should go through and throw out all controls that are no longer
2190    connected to anything.  Moreover, we should go through and provide
2191    meaningful (and correct!) documentation strings for those controls
2192    that still are connected.
2193    
2194    Currently, multiple calls to Controls.new are accepted (only the first
2195    has any effect).  Eventually we should make sure that every control
2196    is being made (via Controls.new) exactly once.  Future access can then
2197    be done using Controls.acc.
2198    
2199    Finally, it would probably be a good idea to use the getter-setter
2200    interface to controls rather than ref cells.  For the time being, both
2201    styles are provided by the Controls module, but getter-setter pairs are
2202    better if thread-safety is of any concern because they can be wrapped.
2203    
2204    *****************************************
2205    
2206    One bug fix: The function blockPlacement in three of the MLRISC
2207    backpatch files used to be hard-wired to one of two possibilities at
2208    link time (according to the value of the placementFlag).  But (I
2209    think) it should rather sense the flag every time.
2210    
2211    *****************************************
2212    
2213    Other assorted changes (by other people who did not supply a HISTORY entry):
2214    
2215    1. the cross-module inliner now works much better (Monnier)
2216    2. representation of weights, frequencies, and probabilities in MLRISC
2217       changed in preparation of using those for weighted block placement
2218       (Reppy, George)
2219    
2220    ----------------------------------------------------------------------
2221  Name: Lal George  Name: Lal George
2222  Date: 2002/03/07 14:44:24 EST 2002  Date: 2002/03/07 14:44:24 EST 2002
2223  Tag: george-20020307-weighted-block-placement  Tag: george-20020307-weighted-block-placement

Legend:
Removed from v.1124  
changed lines
  Added in v.1617

root@smlnj-gforge.cs.uchicago.edu
ViewVC Help
Powered by ViewVC 1.0.0