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