Sophie

Sophie

distrib > Fedora > 15 > i386 > by-pkgid > d07d7ab417d79053e7e0155c99e1a1c8 > files > 2255

mlton-20100608-3.fc15.i686.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta name="robots" content="index,nofollow">



<title>GnuMP - MLton Standard ML Compiler (SML Compiler)</title>
<link rel="stylesheet" type="text/css" charset="iso-8859-1" media="all" href="common.css">
<link rel="stylesheet" type="text/css" charset="iso-8859-1" media="screen" href="screen.css">
<link rel="stylesheet" type="text/css" charset="iso-8859-1" media="print" href="print.css">


<link rel="Start" href="Home">


</head>

<body lang="en" dir="ltr">

<script src="http://www.google-analytics.com/urchin.js" type="text/javascript">
</script>
<script type="text/javascript">
_uacct = "UA-833377-1";
urchinTracker();
</script>
<table bgcolor = lightblue cellspacing = 0 style = "border: 0px;" width = 100%>
  <tr>
    <td style = "
		border: 0px;
		color: darkblue; 
		font-size: 150%;
		text-align: left;">
      <a class = mltona href="Home">MLton MLTONWIKIVERSION</a>
    <td style = "
		border: 0px;
		font-size: 150%;
		text-align: center;
		width: 50%;">
      GnuMP
    <td style = "
		border: 0px;
		text-align: right;">
      <table cellspacing = 0 style = "border: 0px">
        <tr style = "vertical-align: middle;">
      </table>
  <tr style = "background-color: white;">
    <td colspan = 3
	style = "
		border: 0px;
		font-size:70%;
		text-align: right;">
      <a href = "Home">Home</a>
      &nbsp;<a href = "TitleIndex">Index</a>
      &nbsp;
</table>
<div id="content" lang="en" dir="ltr">
The <a class="external" href="http://www.gnu.org/software/gmp/gmp.html"><img src="moin-www.png" alt="[WWW]" height="11" width="11">GnuMP</a> library (GNU multiprecision library) is a library for arbitrary precision integer arithmetic.  MLton uses the GnuMP library to implement the <a href="BasisLibrary"> Basis Library</a> <tt>IntInf</tt> module. <h2 id="head-b05203cf89b60eb36609a1a8b7f3cafe0927486a">Known issues</h2>

    <ul>

    <li>
<p>
 There is a known problem with the GnuMP library (prior to version 4.2.x), where it requires a lot of  stack space for some computations, e.g. <tt>IntInf.toString</tt> of a  million digit number.  If you run with stack size limited, you may see  a segfault in such programs.  This problem is mentioned in the  <a class="external" href="http://gmplib.org/#FAQ"><img src="moin-www.png" alt="[WWW]" height="11" width="11">GnuMP FAQ</a>, where they describe two  solutions. 
</p>
</li>

        <ul>

        <li>
<p>
 Increase (or unlimit) your stack space.  From your program, use   <tt>setrlimit</tt>, or from the shell, use <tt>ulimit</tt>. 
</p>
</li>
        <li class="gap">
<p>
 Configure and rebuild <tt>libgmp</tt> with <tt>--disable-alloca</tt>,   which will cause it to allocate temporaries using <tt>malloc</tt>   instead of on the stack. 
</p>
</li>

        </ul>


    <li class="gap">
<p>
 On some platforms, the GnuMP library may be configured to use one  of multiple ABIs (Application Binary Interfaces).  For example, on  some 32-bit architectures, GnuMP may be configured to represent a  limb as either a 32-bit <tt>long</tt> or as a 64-bit <tt>long&nbsp;long</tt>.  Similarly, GnuMP may be configured to use specific CPU features. 
</p>
<p>
 In order to efficiently use the GnuMP library, MLton represents an  <tt>IntInf.int</tt> value in a manner compatible with the GnuMP  library's representation of a limb.  Hence, it is important that  MLton and the GnuMP library agree upon the representation of a limb. 
</p>
</li>

        <ul>

        <li>
<p>
 When using a source package of MLton, building will detect the   GnuMP library's representation of a limb. 
</p>
</li>
        <li class="gap">
<p>
 When using a binary package of MLton that is dynamically linked   against the GnuMP library, the build machine and the install machine   must have the GnuMP library configured with the same representation   of a limb.  (On the other hand, the build machine need not have the   GnuMP library configured with CPU features compatible with the install   machine.) 
</p>
</li>
        <li class="gap">
<p>
 When using a binary package of MLton that is statically linked   against the GnuMP library, the build machine and the install machine   need not have the GnuMP library configured with the same   representation of a limb.  (On the other hand, the build machine   must have the GnuMP library configured with CPU features compatible   with the install machine.) 
</p>
<p>
  However, MLton will be configured with the representation of a limb   from the GnuMP library of the build machine.  Executables produced   by MLton will be incompatible with the GnuMP library of the install   machine.  To <em>reconfigure</em> MLton with the representation of a limb   from the GnuMP library of the install machine, one must edit: 
<pre>/usr/lib/mlton/self/sizes</pre>   changing the 
<pre>mplimb = ??</pre>   entry so that <tt>??</tt> corresponds to the bytes in a limb; and, one must edit: 
<pre>/usr/lib/mlton/sml/basis/config/c/arch-os/c-types.sml</pre>  changing the 
<pre>(* from "gmp.h" *)
structure C_MPLimb = struct open Word?? type t = word end
functor C_MPLimb_ChooseWordN (A: CHOOSE_WORDN_ARG) = ChooseWordN_Word?? (A)
</pre>  entries so that <tt>??</tt> corresponds to the bits in a limb. 
</p>
</li>
</ul>

</ul>

</div>



<p>
<hr>
Last edited on 2007-12-17 16:36:16 by <span title="fenrir.uchicago.edu"><a href="MatthewFluet">MatthewFluet</a></span>.
</body></html>