| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 | <html lang="en"><head><title>Bugs - avram - a virtual machine code interpreter</title><meta http-equiv="Content-Type" content="text/html"><meta name="description" content="avram - a virtual machine code interpreter"><meta name="generator" content="makeinfo 4.13"><link title="Top" rel="start" href="index.html#Top"><link rel="up" href="User-Manual.html#User-Manual" title="User Manual"><link rel="prev" href="Environment.html#Environment" title="Environment"><link href="http://www.gnu.org/software/texinfo/" rel="generator-home" title="Texinfo Homepage"><meta http-equiv="Content-Style-Type" content="text/css"><style type="text/css"><!--  pre.display { font-family:inherit }  pre.format  { font-family:inherit }  pre.smalldisplay { font-family:inherit; font-size:smaller }  pre.smallformat  { font-family:inherit; font-size:smaller }  pre.smallexample { font-size:smaller }  pre.smalllisp    { font-size:smaller }  span.sc    { font-variant:small-caps }  span.roman { font-family:serif; font-weight:normal; }   span.sansserif { font-family:sans-serif; font-weight:normal; } --></style></head><body><div class="node"><a name="Bugs"></a><p>Previous: <a rel="previous" accesskey="p" href="Environment.html#Environment">Environment</a>,Up: <a rel="up" accesskey="u" href="User-Manual.html#User-Manual">User Manual</a><hr></div><h3 class="section">1.11 Bugs</h3><p><a name="index-internal-errors-138"></a><a name="index-bugs-139"></a><a name="index-exceptions-140"></a>There are no known bugs outstanding, except for any that may beinherent in the external library functions. However, <code>avram</code> hasbeen used most extensively on GNU/Linux systems, and the prospectof portability issues with new or lesser used features on othersystems can't be excluded.   <p>Though not observed in practice, it's theoretically possible to blowthe stack by passing enough functions as arguments to libraryfunctions that pass more functions to library functions (e.g., byusing nested calls to the gsl integration functions meant for a singlevariable to evaluate a very high dimensional multiple integral). Inall other cases only dynamic heap storage or a constant amount ofstack space is used.  In particular, this issue is <em>not</em> relevantto virtual code applications that don't use external libraries, orthat don't pass functions to them as arguments.   <p><code>avram</code> is designed to recover gracefully from memory overflowsby always checking for <code>NULL</code> results from <code>malloc()</code> orotherwise trapping functions that allocate memory. In the event of anoverflow, it conveys an appropriate error message to the virtual codeapplication to be handled by the usual exception handlingmechanisms. However, there is currently no way for a virtual codeapplication to detect in advance whether sufficient memory isavailable, nor for it to resume normal operation once an exceptionoccurs. Furthermore, it has been observed on some systems includingIrix and 2.4 series Linux kernels that the <code>avram</code> process iskilled automatically for attempting to allocate too much memory ratherthan given the chance to recover.   <p>Please send bug reports to <a href="mailto:[email protected]">[email protected]</a>.   </body></html>
 |