[comp.os.vms] VMS C version 2.3 optimize bug?

hildum@iris.ucdavis.edu (Eric Hildum) (05/28/88)

Hello.

I am current using VAX/VMS C version 2.3-024.  Several of my programs
dynamically allocate space which is later referenced using array
reference syntax (eg, in a partial sketch: the variable is declared
"double ****temp[3]" and later referenced with
"temp[index][f][b][y][x]", after having been set to point at arrays of
properly declared pointers).  I have no trouble when I compile the
programs /NOOPTIMIZE, but get access violations when I compile
/OPTIMIZE.  The only time I have noticed the problem is when I
reference the (declared) array in a loop where the loop variable is
used as the index (ie, "index" in the above example).  Apparently the
optimizer attempts to optimize the loop index - and screws up.

Is there a later version of C that I can get, and is this a known
problem - or should I submit an SPR?

				Thank you,
				Eric Hildum
				dehildum@ucdavis.ucdavis.edu	(Internet)
				dehildum@ucdavis.bitnet	(BITNET)
				ucbvax!ucdavis!dehildum	(uucp)

jnh@ece-csc.UUCP (Joseph Nathan Hall) (05/29/88)

In article <2101@ucdavis.ucdavis.edu> hildum@iris.ucdavis.edu (Eric Hildum) writes:
>I am current using VAX/VMS C version 2.3-024.  Several of my programs
>dynamically allocate space ...
>...  I have no trouble when I compile the
>programs /NOOPTIMIZE, but get access violations when I compile
>/OPTIMIZE...

It is my experience, and the experience of a couple other programmers
working here, that malloc() and the optimizer are not compatible in general
in VAX C.

I had some truly strange problems with what should have been perfectly-
functional code.  A module would crash and dump ("access violation") for
no apparent reason.  I'd track down the suspect line of code, insert a
printf or two for debugging purposes, recompile (optimizer on), and the
module would either work flawlessly or would crash at a later line.  It
seems that somehow a stack pointer got corrupted, and it was never clear
to me how malloc() was associated with this, except that I've never
observed this problem in any code that didn't use malloc().

Things were so screwed up that the debugger choked (non-symbolic stack dump)
whenever I tried to use it to examine one of these glitches.  I never got
around to looking at the machine code, though I probably will one day when
I've got time to play with this at length.

Everything, of course, works peachy with the optimizer off.  /NOOPT has,
unfortunately, become SOP in most of my (heavily malloc()-oriented) work.


-- 
v   v sssss|| joseph hall                      || 201-1D Hampton Lee Court
 v v s   s || jnh@ece-csc.ncsu.edu (Internet)  || Cary, NC  27511
  v   sss  || the opinions expressed herein are not necessarily those of my
-----------|| employer, north carolina state university . . . . . . . . . . . 

bob@aconcagua (Bob Firestine) (06/03/88)

In article <2101@ucdavis.ucdavis.edu> hildum@iris.ucdavis.edu (Eric Hildum) writes:
<I am current using VAX/VMS C version 2.3-024.  Several of my programs
<dynamically allocate space which is later referenced using array
<reference syntax (eg, in a partial sketch: the variable is declared
<"double ****temp[3]" and later referenced with
<"temp[index][f][b][y][x]", after having been set to point at arrays of
<properly declared pointers).  I have no trouble when I compile the
<programs /NOOPTIMIZE, but get access violations when I compile
</OPTIMIZE.  The only time I have noticed the problem is when I
<reference the (declared) array in a loop where the loop variable is
<used as the index (ie, "index" in the above example).  Apparently the
<optimizer attempts to optimize the loop index - and screws up.

<Is there a later version of C that I can get, and is this a known
<problem - or should I submit an SPR?
>
We received version 2.4 about two days ago.

-------------------------------------------------------------------------------

Bob Firestine			firestine@M_sjs.sdr.slb.com
Schlumberger Technologies	bob%sjsca4@spar.slb.com
1601 Technology Drive 
San Jose CA 95115	
408-437-5216