From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on polar.synack.me X-Spam-Level: X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,FREEMAIL_FROM autolearn=ham autolearn_force=no version=3.4.4 X-Google-Thread: 103376,1580f5833894f157,start X-Google-Attributes: gid103376,public X-Google-Language: ENGLISH,ASCII-7-bit Path: g2news2.google.com!postnews.google.com!h48g2000cwc.googlegroups.com!not-for-mail From: "ldb" Newsgroups: comp.lang.ada Subject: program error (exception access violation) in windows Date: 26 Sep 2006 16:18:33 -0700 Organization: http://groups.google.com Message-ID: <1159312713.137314.324080@h48g2000cwc.googlegroups.com> NNTP-Posting-Host: 206.210.81.52 Mime-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" X-Trace: posting.google.com 1159312718 30062 127.0.0.1 (26 Sep 2006 23:18:38 GMT) X-Complaints-To: groups-abuse@google.com NNTP-Posting-Date: Tue, 26 Sep 2006 23:18:38 +0000 (UTC) User-Agent: G2/1.0 X-HTTP-UserAgent: Mozilla/5.0 (Macintosh; U; PPC Mac OS X Mach-O; en-US; rv:1.8.0.7) Gecko/20060909 Firefox/1.5.0.7,gzip(gfe),gzip(gfe) Complaints-To: groups-abuse@google.com Injection-Info: h48g2000cwc.googlegroups.com; posting-host=206.210.81.52; posting-account=V3awPg0AAAB11Uk1Sshvlrxz0peUf-At Xref: g2news2.google.com comp.lang.ada:6762 Date: 2006-09-26T16:18:33-07:00 List-Id: > raised PROGRAM_ERROR : EXCEPTION_ACCESS_VIOLATION We have tried, in numerous ways, to come up with an ada library that can be used by c programs. The ada program needs to return a pretty large and ugly dynamic structure. For the sake of discussion, think of it as an array of structs (with pointers to dynamic sub-arrays). I've gotten it to work flawlessly under linux using shared libraries. I use a combination of importing malloc() and the Ada.Address_To_Access_Conversions package. In this way, I can malloc the correctly sized eventual c data-structure, and use the created access from that package to populate the data structure. When I return the address of that to C, everything appears to work fine. I can free it like any other C data structure. It seems to fail (sometimes) when I move it to windows (using a c program and my ada-based dll), resulting in the above exception. When I remove the free calls, in c, everything works fine (and memory leaks). I have a 'minimal' program that uses a simple array of integers, and it seems to work fine, but for our main program, it still crashes. Tommorow, I'm going to rip apart our program to see if I can find a minimal example of the crashing behavior. We've tried numerous different ways of allocating the memory in ada, and free'ing it in C. We even got a smiliar error when we tried allocating it in Ada, and free'ing it in Ada through another C call to the ada library. We are about to change our interface from Ada to single elements, only, and have C wrapper functions that do all the allocating and query for each single value to populate the data structure. Has anyone heard of issues like this? Or have a possible guess as to what is going on?