Current File : //opt/RZruby/share/doc/ruby/html/d6/de3/crypt_8c_source.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.5"/>
<title>Ruby: missing/crypt.c Source File</title>
<link href="../../tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="../../jquery.js"></script>
<script type="text/javascript" src="../../dynsections.js"></script>
<link href="../../doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td style="padding-left: 0.5em;">
   <div id="projectname">Ruby
   &#160;<span id="projectnumber">1.9.3p551(2014-11-13revision48407)</span>
   </div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.5 -->
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="../../index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="../../modules.html"><span>Modules</span></a></li>
      <li><a href="../../annotated.html"><span>Data&#160;Structures</span></a></li>
      <li class="current"><a href="../../files.html"><span>Files</span></a></li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="../../files.html"><span>File&#160;List</span></a></li>
      <li><a href="../../globals.html"><span>Globals</span></a></li>
    </ul>
  </div>
<div id="nav-path" class="navpath">
  <ul>
<li class="navelem"><a class="el" href="../../dir_f3bfeebb553c3f6ecfb19202628b4493.html">missing</a></li>  </ul>
</div>
</div><!-- top -->
<div class="header">
  <div class="headertitle">
<div class="title">crypt.c</div>  </div>
</div><!--header-->
<div class="contents">
<a href="../../d6/de3/crypt_8c.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;<span class="comment"> * Copyright (c) 1989, 1993</span></div>
<div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;<span class="comment"> *      The Regents of the University of California.  All rights reserved.</span></div>
<div class="line"><a name="l00004"></a><span class="lineno">    4</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00005"></a><span class="lineno">    5</span>&#160;<span class="comment"> * This code is derived from software contributed to Berkeley by</span></div>
<div class="line"><a name="l00006"></a><span class="lineno">    6</span>&#160;<span class="comment"> * Tom Truscott.</span></div>
<div class="line"><a name="l00007"></a><span class="lineno">    7</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00008"></a><span class="lineno">    8</span>&#160;<span class="comment"> * Redistribution and use in source and binary forms, with or without</span></div>
<div class="line"><a name="l00009"></a><span class="lineno">    9</span>&#160;<span class="comment"> * modification, are permitted provided that the following conditions</span></div>
<div class="line"><a name="l00010"></a><span class="lineno">   10</span>&#160;<span class="comment"> * are met:</span></div>
<div class="line"><a name="l00011"></a><span class="lineno">   11</span>&#160;<span class="comment"> * 1. Redistributions of source code must retain the above copyright</span></div>
<div class="line"><a name="l00012"></a><span class="lineno">   12</span>&#160;<span class="comment"> *    notice, this list of conditions and the following disclaimer.</span></div>
<div class="line"><a name="l00013"></a><span class="lineno">   13</span>&#160;<span class="comment"> * 2. Redistributions in binary form must reproduce the above copyright</span></div>
<div class="line"><a name="l00014"></a><span class="lineno">   14</span>&#160;<span class="comment"> *    notice, this list of conditions and the following disclaimer in the</span></div>
<div class="line"><a name="l00015"></a><span class="lineno">   15</span>&#160;<span class="comment"> *    documentation and/or other materials provided with the distribution.</span></div>
<div class="line"><a name="l00016"></a><span class="lineno">   16</span>&#160;<span class="comment"> * 3. Neither the name of the University nor the names of its contributors</span></div>
<div class="line"><a name="l00017"></a><span class="lineno">   17</span>&#160;<span class="comment"> *    may be used to endorse or promote products derived from this software</span></div>
<div class="line"><a name="l00018"></a><span class="lineno">   18</span>&#160;<span class="comment"> *    without specific prior written permission.</span></div>
<div class="line"><a name="l00019"></a><span class="lineno">   19</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00020"></a><span class="lineno">   20</span>&#160;<span class="comment"> * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS&#39;&#39; AND</span></div>
<div class="line"><a name="l00021"></a><span class="lineno">   21</span>&#160;<span class="comment"> * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE</span></div>
<div class="line"><a name="l00022"></a><span class="lineno">   22</span>&#160;<span class="comment"> * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE</span></div>
<div class="line"><a name="l00023"></a><span class="lineno">   23</span>&#160;<span class="comment"> * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE</span></div>
<div class="line"><a name="l00024"></a><span class="lineno">   24</span>&#160;<span class="comment"> * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL</span></div>
<div class="line"><a name="l00025"></a><span class="lineno">   25</span>&#160;<span class="comment"> * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS</span></div>
<div class="line"><a name="l00026"></a><span class="lineno">   26</span>&#160;<span class="comment"> * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)</span></div>
<div class="line"><a name="l00027"></a><span class="lineno">   27</span>&#160;<span class="comment"> * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT</span></div>
<div class="line"><a name="l00028"></a><span class="lineno">   28</span>&#160;<span class="comment"> * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY</span></div>
<div class="line"><a name="l00029"></a><span class="lineno">   29</span>&#160;<span class="comment"> * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF</span></div>
<div class="line"><a name="l00030"></a><span class="lineno">   30</span>&#160;<span class="comment"> * SUCH DAMAGE.</span></div>
<div class="line"><a name="l00031"></a><span class="lineno">   31</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00032"></a><span class="lineno">   32</span>&#160;</div>
<div class="line"><a name="l00033"></a><span class="lineno">   33</span>&#160;<span class="preprocessor">#if defined(LIBC_SCCS) &amp;&amp; !defined(lint)</span></div>
<div class="line"><a name="l00034"></a><span class="lineno">   34</span>&#160;<span class="preprocessor"></span><span class="keyword">static</span> <span class="keywordtype">char</span> sccsid[] = <span class="stringliteral">&quot;@(#)crypt.c     8.1 (Berkeley) 6/4/93&quot;</span>;</div>
<div class="line"><a name="l00035"></a><span class="lineno">   35</span>&#160;<span class="preprocessor">#endif </span><span class="comment">/* LIBC_SCCS and not lint */</span><span class="preprocessor"></span></div>
<div class="line"><a name="l00036"></a><span class="lineno">   36</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00037"></a><span class="lineno">   37</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="../../d3/d90/missing_8h.html">ruby/missing.h</a>&quot;</span></div>
<div class="line"><a name="l00038"></a><span class="lineno">   38</span>&#160;<span class="preprocessor">#ifdef HAVE_UNISTD_H</span></div>
<div class="line"><a name="l00039"></a><span class="lineno">   39</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#include &lt;unistd.h&gt;</span></div>
<div class="line"><a name="l00040"></a><span class="lineno">   40</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00041"></a><span class="lineno">   41</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#include &lt;limits.h&gt;</span></div>
<div class="line"><a name="l00042"></a><span class="lineno">   42</span>&#160;<span class="preprocessor">#ifdef HAVE_PWD_H</span></div>
<div class="line"><a name="l00043"></a><span class="lineno">   43</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#include &lt;pwd.h&gt;</span></div>
<div class="line"><a name="l00044"></a><span class="lineno">   44</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00045"></a><span class="lineno">   45</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#include &lt;stdio.h&gt;</span></div>
<div class="line"><a name="l00046"></a><span class="lineno">   46</span>&#160;<span class="preprocessor">#ifndef _PASSWORD_EFMT1</span></div>
<div class="line"><a name="l00047"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a916ed973888ae694d78cbe3097e10f0f">   47</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define _PASSWORD_EFMT1 &#39;_&#39;</span></div>
<div class="line"><a name="l00048"></a><span class="lineno">   48</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00049"></a><span class="lineno">   49</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00050"></a><span class="lineno">   50</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00051"></a><span class="lineno">   51</span>&#160;<span class="comment"> * UNIX password, and DES, encryption.</span></div>
<div class="line"><a name="l00052"></a><span class="lineno">   52</span>&#160;<span class="comment"> * By Tom Truscott, trt@rti.rti.org,</span></div>
<div class="line"><a name="l00053"></a><span class="lineno">   53</span>&#160;<span class="comment"> * from algorithms by Robert W. Baldwin and James Gillogly.</span></div>
<div class="line"><a name="l00054"></a><span class="lineno">   54</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00055"></a><span class="lineno">   55</span>&#160;<span class="comment"> * References:</span></div>
<div class="line"><a name="l00056"></a><span class="lineno">   56</span>&#160;<span class="comment"> * &quot;Mathematical Cryptology for Computer Scientists and Mathematicians,&quot;</span></div>
<div class="line"><a name="l00057"></a><span class="lineno">   57</span>&#160;<span class="comment"> * by Wayne Patterson, 1987, ISBN 0-8476-7438-X.</span></div>
<div class="line"><a name="l00058"></a><span class="lineno">   58</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00059"></a><span class="lineno">   59</span>&#160;<span class="comment"> * &quot;Password Security: A Case History,&quot; R. Morris and Ken Thompson,</span></div>
<div class="line"><a name="l00060"></a><span class="lineno">   60</span>&#160;<span class="comment"> * Communications of the ACM, vol. 22, pp. 594-597, Nov. 1979.</span></div>
<div class="line"><a name="l00061"></a><span class="lineno">   61</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00062"></a><span class="lineno">   62</span>&#160;<span class="comment"> * &quot;DES will be Totally Insecure within Ten Years,&quot; M.E. Hellman,</span></div>
<div class="line"><a name="l00063"></a><span class="lineno">   63</span>&#160;<span class="comment"> * IEEE Spectrum, vol. 16, pp. 32-39, July 1979.</span></div>
<div class="line"><a name="l00064"></a><span class="lineno">   64</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00065"></a><span class="lineno">   65</span>&#160;</div>
<div class="line"><a name="l00066"></a><span class="lineno">   66</span>&#160;<span class="comment">/* =====  Configuration ==================== */</span></div>
<div class="line"><a name="l00067"></a><span class="lineno">   67</span>&#160;</div>
<div class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00069"></a><span class="lineno">   69</span>&#160;<span class="comment"> * define &quot;MUST_ALIGN&quot; if your compiler cannot load/store</span></div>
<div class="line"><a name="l00070"></a><span class="lineno">   70</span>&#160;<span class="comment"> * long integers at arbitrary (e.g. odd) memory locations.</span></div>
<div class="line"><a name="l00071"></a><span class="lineno">   71</span>&#160;<span class="comment"> * (Either that or never pass unaligned addresses to des_cipher!)</span></div>
<div class="line"><a name="l00072"></a><span class="lineno">   72</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00073"></a><span class="lineno">   73</span>&#160;<span class="preprocessor">#if !defined(vax)</span></div>
<div class="line"><a name="l00074"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#adf668ad8163e197b71ab07ca0bb17817">   74</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define MUST_ALIGN</span></div>
<div class="line"><a name="l00075"></a><span class="lineno">   75</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00076"></a><span class="lineno">   76</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00077"></a><span class="lineno">   77</span>&#160;<span class="preprocessor">#ifdef CHAR_BITS</span></div>
<div class="line"><a name="l00078"></a><span class="lineno">   78</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if CHAR_BITS != 8</span></div>
<div class="line"><a name="l00079"></a><span class="lineno">   79</span>&#160;<span class="preprocessor"></span><span class="preprocessor">        #error C_block structure assumes 8 bit characters</span></div>
<div class="line"><a name="l00080"></a><span class="lineno">   80</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00081"></a><span class="lineno">   81</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00082"></a><span class="lineno">   82</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00083"></a><span class="lineno">   83</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00084"></a><span class="lineno">   84</span>&#160;<span class="comment"> * define &quot;LONG_IS_32_BITS&quot; only if sizeof(long)==4.</span></div>
<div class="line"><a name="l00085"></a><span class="lineno">   85</span>&#160;<span class="comment"> * This avoids use of bit fields (your compiler may be sloppy with them).</span></div>
<div class="line"><a name="l00086"></a><span class="lineno">   86</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00087"></a><span class="lineno">   87</span>&#160;<span class="preprocessor">#if !defined(cray)</span></div>
<div class="line"><a name="l00088"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#af3368f8dc9bc790c4b276af77ad93441">   88</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define LONG_IS_32_BITS</span></div>
<div class="line"><a name="l00089"></a><span class="lineno">   89</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00090"></a><span class="lineno">   90</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00091"></a><span class="lineno">   91</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00092"></a><span class="lineno">   92</span>&#160;<span class="comment"> * define &quot;B64&quot; to be the declaration for a 64 bit integer.</span></div>
<div class="line"><a name="l00093"></a><span class="lineno">   93</span>&#160;<span class="comment"> * XXX this feature is currently unused, see &quot;endian&quot; comment below.</span></div>
<div class="line"><a name="l00094"></a><span class="lineno">   94</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00095"></a><span class="lineno">   95</span>&#160;<span class="preprocessor">#if defined(cray)</span></div>
<div class="line"><a name="l00096"></a><span class="lineno">   96</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define B64     long</span></div>
<div class="line"><a name="l00097"></a><span class="lineno">   97</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00098"></a><span class="lineno">   98</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if defined(convex)</span></div>
<div class="line"><a name="l00099"></a><span class="lineno">   99</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define B64     long long</span></div>
<div class="line"><a name="l00100"></a><span class="lineno">  100</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00101"></a><span class="lineno">  101</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00102"></a><span class="lineno">  102</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00103"></a><span class="lineno">  103</span>&#160;<span class="comment"> * define &quot;LARGEDATA&quot; to get faster permutations, by using about 72 kilobytes</span></div>
<div class="line"><a name="l00104"></a><span class="lineno">  104</span>&#160;<span class="comment"> * of lookup tables.  This speeds up des_setkey() and des_cipher(), but has</span></div>
<div class="line"><a name="l00105"></a><span class="lineno">  105</span>&#160;<span class="comment"> * little effect on crypt().</span></div>
<div class="line"><a name="l00106"></a><span class="lineno">  106</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00107"></a><span class="lineno">  107</span>&#160;<span class="preprocessor">#if defined(notdef)</span></div>
<div class="line"><a name="l00108"></a><span class="lineno">  108</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define LARGEDATA</span></div>
<div class="line"><a name="l00109"></a><span class="lineno">  109</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00110"></a><span class="lineno">  110</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00111"></a><span class="lineno">  111</span>&#160;<span class="keywordtype">int</span> <a class="code" href="../../d6/de3/crypt_8c.html#a654d8b345f7098c1108e712985321c3c">des_setkey</a>(), <a class="code" href="../../d6/de3/crypt_8c.html#a5c9b491358c3434f273b874b413afb09">des_cipher</a>();</div>
<div class="line"><a name="l00112"></a><span class="lineno">  112</span>&#160;</div>
<div class="line"><a name="l00113"></a><span class="lineno">  113</span>&#160;<span class="comment">/* compile with &quot;-DSTATIC=int&quot; when profiling */</span></div>
<div class="line"><a name="l00114"></a><span class="lineno">  114</span>&#160;<span class="preprocessor">#ifndef STATIC</span></div>
<div class="line"><a name="l00115"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a10b2d890d871e1489bb02b7e70d9bdfb">  115</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define STATIC  static</span></div>
<div class="line"><a name="l00116"></a><span class="lineno">  116</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00117"></a><span class="lineno">  117</span>&#160;<span class="preprocessor"></span><a class="code" href="../../d6/de3/crypt_8c.html#a10b2d890d871e1489bb02b7e70d9bdfb">STATIC</a> <span class="keywordtype">void</span> <a class="code" href="../../d6/de3/crypt_8c.html#aa2378a0e5d6788c77c9e719ecb0291a0">init_des</a>(), <a class="code" href="../../d6/de3/crypt_8c.html#a70ea989e3d76e6f0ca30dfed27527da8">init_perm</a>(), <a class="code" href="../../d6/de3/crypt_8c.html#af957276b65abd295692175245d603c04">permute</a>();</div>
<div class="line"><a name="l00118"></a><span class="lineno">  118</span>&#160;<span class="preprocessor">#ifdef DEBUG</span></div>
<div class="line"><a name="l00119"></a><span class="lineno">  119</span>&#160;<span class="preprocessor"></span><a class="code" href="../../d6/de3/crypt_8c.html#a10b2d890d871e1489bb02b7e70d9bdfb">STATIC</a> <span class="keywordtype">void</span> prtab();</div>
<div class="line"><a name="l00120"></a><span class="lineno">  120</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00121"></a><span class="lineno">  121</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00122"></a><span class="lineno">  122</span>&#160;<span class="comment">/* ==================================== */</span></div>
<div class="line"><a name="l00123"></a><span class="lineno">  123</span>&#160;</div>
<div class="line"><a name="l00124"></a><span class="lineno">  124</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00125"></a><span class="lineno">  125</span>&#160;<span class="comment"> * Cipher-block representation (Bob Baldwin):</span></div>
<div class="line"><a name="l00126"></a><span class="lineno">  126</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00127"></a><span class="lineno">  127</span>&#160;<span class="comment"> * DES operates on groups of 64 bits, numbered 1..64 (sigh).  One</span></div>
<div class="line"><a name="l00128"></a><span class="lineno">  128</span>&#160;<span class="comment"> * representation is to store one bit per byte in an array of bytes.  Bit N of</span></div>
<div class="line"><a name="l00129"></a><span class="lineno">  129</span>&#160;<span class="comment"> * the NBS spec is stored as the LSB of the Nth byte (index N-1) in the array.</span></div>
<div class="line"><a name="l00130"></a><span class="lineno">  130</span>&#160;<span class="comment"> * Another representation stores the 64 bits in 8 bytes, with bits 1..8 in the</span></div>
<div class="line"><a name="l00131"></a><span class="lineno">  131</span>&#160;<span class="comment"> * first byte, 9..16 in the second, and so on.  The DES spec apparently has</span></div>
<div class="line"><a name="l00132"></a><span class="lineno">  132</span>&#160;<span class="comment"> * bit 1 in the MSB of the first byte, but that is particularly noxious so we</span></div>
<div class="line"><a name="l00133"></a><span class="lineno">  133</span>&#160;<span class="comment"> * bit-reverse each byte so that bit 1 is the LSB of the first byte, bit 8 is</span></div>
<div class="line"><a name="l00134"></a><span class="lineno">  134</span>&#160;<span class="comment"> * the MSB of the first byte.  Specifically, the 64-bit input data and key are</span></div>
<div class="line"><a name="l00135"></a><span class="lineno">  135</span>&#160;<span class="comment"> * converted to LSB format, and the output 64-bit block is converted back into</span></div>
<div class="line"><a name="l00136"></a><span class="lineno">  136</span>&#160;<span class="comment"> * MSB format.</span></div>
<div class="line"><a name="l00137"></a><span class="lineno">  137</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00138"></a><span class="lineno">  138</span>&#160;<span class="comment"> * DES operates internally on groups of 32 bits which are expanded to 48 bits</span></div>
<div class="line"><a name="l00139"></a><span class="lineno">  139</span>&#160;<span class="comment"> * by permutation E and shrunk back to 32 bits by the S boxes.  To speed up</span></div>
<div class="line"><a name="l00140"></a><span class="lineno">  140</span>&#160;<span class="comment"> * the computation, the expansion is applied only once, the expanded</span></div>
<div class="line"><a name="l00141"></a><span class="lineno">  141</span>&#160;<span class="comment"> * representation is maintained during the encryption, and a compression</span></div>
<div class="line"><a name="l00142"></a><span class="lineno">  142</span>&#160;<span class="comment"> * permutation is applied only at the end.  To speed up the S-box lookups,</span></div>
<div class="line"><a name="l00143"></a><span class="lineno">  143</span>&#160;<span class="comment"> * the 48 bits are maintained as eight 6 bit groups, one per byte, which</span></div>
<div class="line"><a name="l00144"></a><span class="lineno">  144</span>&#160;<span class="comment"> * directly feed the eight S-boxes.  Within each byte, the 6 bits are the</span></div>
<div class="line"><a name="l00145"></a><span class="lineno">  145</span>&#160;<span class="comment"> * most significant ones.  The low two bits of each byte are zero.  (Thus,</span></div>
<div class="line"><a name="l00146"></a><span class="lineno">  146</span>&#160;<span class="comment"> * bit 1 of the 48 bit E expansion is stored as the &quot;4&quot;-valued bit of the</span></div>
<div class="line"><a name="l00147"></a><span class="lineno">  147</span>&#160;<span class="comment"> * first byte in the eight byte representation, bit 2 of the 48 bit value is</span></div>
<div class="line"><a name="l00148"></a><span class="lineno">  148</span>&#160;<span class="comment"> * the &quot;8&quot;-valued bit, and so on.)  In fact, a combined &quot;SPE&quot;-box lookup is</span></div>
<div class="line"><a name="l00149"></a><span class="lineno">  149</span>&#160;<span class="comment"> * used, in which the output is the 64 bit result of an S-box lookup which</span></div>
<div class="line"><a name="l00150"></a><span class="lineno">  150</span>&#160;<span class="comment"> * has been permuted by P and expanded by E, and is ready for use in the next</span></div>
<div class="line"><a name="l00151"></a><span class="lineno">  151</span>&#160;<span class="comment"> * iteration.  Two 32-bit wide tables, SPE[0] and SPE[1], are used for this</span></div>
<div class="line"><a name="l00152"></a><span class="lineno">  152</span>&#160;<span class="comment"> * lookup.  Since each byte in the 48 bit path is a multiple of four, indexed</span></div>
<div class="line"><a name="l00153"></a><span class="lineno">  153</span>&#160;<span class="comment"> * lookup of SPE[0] and SPE[1] is simple and fast.  The key schedule and</span></div>
<div class="line"><a name="l00154"></a><span class="lineno">  154</span>&#160;<span class="comment"> * &quot;salt&quot; are also converted to this 8*(6+2) format.  The SPE table size is</span></div>
<div class="line"><a name="l00155"></a><span class="lineno">  155</span>&#160;<span class="comment"> * 8*64*8 = 4K bytes.</span></div>
<div class="line"><a name="l00156"></a><span class="lineno">  156</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00157"></a><span class="lineno">  157</span>&#160;<span class="comment"> * To speed up bit-parallel operations (such as XOR), the 8 byte</span></div>
<div class="line"><a name="l00158"></a><span class="lineno">  158</span>&#160;<span class="comment"> * representation is &quot;union&quot;ed with 32 bit values &quot;i0&quot; and &quot;i1&quot;, and, on</span></div>
<div class="line"><a name="l00159"></a><span class="lineno">  159</span>&#160;<span class="comment"> * machines which support it, a 64 bit value &quot;b64&quot;.  This data structure,</span></div>
<div class="line"><a name="l00160"></a><span class="lineno">  160</span>&#160;<span class="comment"> * &quot;C_block&quot;, has two problems.  First, alignment restrictions must be</span></div>
<div class="line"><a name="l00161"></a><span class="lineno">  161</span>&#160;<span class="comment"> * honored.  Second, the byte-order (e.g. little-endian or big-endian) of</span></div>
<div class="line"><a name="l00162"></a><span class="lineno">  162</span>&#160;<span class="comment"> * the architecture becomes visible.</span></div>
<div class="line"><a name="l00163"></a><span class="lineno">  163</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00164"></a><span class="lineno">  164</span>&#160;<span class="comment"> * The byte-order problem is unfortunate, since on the one hand it is good</span></div>
<div class="line"><a name="l00165"></a><span class="lineno">  165</span>&#160;<span class="comment"> * to have a machine-independent C_block representation (bits 1..8 in the</span></div>
<div class="line"><a name="l00166"></a><span class="lineno">  166</span>&#160;<span class="comment"> * first byte, etc.), and on the other hand it is good for the LSB of the</span></div>
<div class="line"><a name="l00167"></a><span class="lineno">  167</span>&#160;<span class="comment"> * first byte to be the LSB of i0.  We cannot have both these things, so we</span></div>
<div class="line"><a name="l00168"></a><span class="lineno">  168</span>&#160;<span class="comment"> * currently use the &quot;little-endian&quot; representation and avoid any multi-byte</span></div>
<div class="line"><a name="l00169"></a><span class="lineno">  169</span>&#160;<span class="comment"> * operations that depend on byte order.  This largely precludes use of the</span></div>
<div class="line"><a name="l00170"></a><span class="lineno">  170</span>&#160;<span class="comment"> * 64-bit datatype since the relative order of i0 and i1 are unknown.  It</span></div>
<div class="line"><a name="l00171"></a><span class="lineno">  171</span>&#160;<span class="comment"> * also inhibits grouping the SPE table to look up 12 bits at a time.  (The</span></div>
<div class="line"><a name="l00172"></a><span class="lineno">  172</span>&#160;<span class="comment"> * 12 bits can be stored in a 16-bit field with 3 low-order zeroes and 1</span></div>
<div class="line"><a name="l00173"></a><span class="lineno">  173</span>&#160;<span class="comment"> * high-order zero, providing fast indexing into a 64-bit wide SPE.)  On the</span></div>
<div class="line"><a name="l00174"></a><span class="lineno">  174</span>&#160;<span class="comment"> * other hand, 64-bit datatypes are currently rare, and a 12-bit SPE lookup</span></div>
<div class="line"><a name="l00175"></a><span class="lineno">  175</span>&#160;<span class="comment"> * requires a 128 kilobyte table, so perhaps this is not a big loss.</span></div>
<div class="line"><a name="l00176"></a><span class="lineno">  176</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00177"></a><span class="lineno">  177</span>&#160;<span class="comment"> * Permutation representation (Jim Gillogly):</span></div>
<div class="line"><a name="l00178"></a><span class="lineno">  178</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00179"></a><span class="lineno">  179</span>&#160;<span class="comment"> * A transformation is defined by its effect on each of the 8 bytes of the</span></div>
<div class="line"><a name="l00180"></a><span class="lineno">  180</span>&#160;<span class="comment"> * 64-bit input.  For each byte we give a 64-bit output that has the bits in</span></div>
<div class="line"><a name="l00181"></a><span class="lineno">  181</span>&#160;<span class="comment"> * the input distributed appropriately.  The transformation is then the OR</span></div>
<div class="line"><a name="l00182"></a><span class="lineno">  182</span>&#160;<span class="comment"> * of the 8 sets of 64-bits.  This uses 8*256*8 = 16K bytes of storage for</span></div>
<div class="line"><a name="l00183"></a><span class="lineno">  183</span>&#160;<span class="comment"> * each transformation.  Unless LARGEDATA is defined, however, a more compact</span></div>
<div class="line"><a name="l00184"></a><span class="lineno">  184</span>&#160;<span class="comment"> * table is used which looks up 16 4-bit &quot;chunks&quot; rather than 8 8-bit chunks.</span></div>
<div class="line"><a name="l00185"></a><span class="lineno">  185</span>&#160;<span class="comment"> * The smaller table uses 16*16*8 = 2K bytes for each transformation.  This</span></div>
<div class="line"><a name="l00186"></a><span class="lineno">  186</span>&#160;<span class="comment"> * is slower but tolerable, particularly for password encryption in which</span></div>
<div class="line"><a name="l00187"></a><span class="lineno">  187</span>&#160;<span class="comment"> * the SPE transformation is iterated many times.  The small tables total 9K</span></div>
<div class="line"><a name="l00188"></a><span class="lineno">  188</span>&#160;<span class="comment"> * bytes, the large tables total 72K bytes.</span></div>
<div class="line"><a name="l00189"></a><span class="lineno">  189</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00190"></a><span class="lineno">  190</span>&#160;<span class="comment"> * The transformations used are:</span></div>
<div class="line"><a name="l00191"></a><span class="lineno">  191</span>&#160;<span class="comment"> * IE3264: MSB-&gt;LSB conversion, initial permutation, and expansion.</span></div>
<div class="line"><a name="l00192"></a><span class="lineno">  192</span>&#160;<span class="comment"> *      This is done by collecting the 32 even-numbered bits and applying</span></div>
<div class="line"><a name="l00193"></a><span class="lineno">  193</span>&#160;<span class="comment"> *      a 32-&gt;64 bit transformation, and then collecting the 32 odd-numbered</span></div>
<div class="line"><a name="l00194"></a><span class="lineno">  194</span>&#160;<span class="comment"> *      bits and applying the same transformation.  Since there are only</span></div>
<div class="line"><a name="l00195"></a><span class="lineno">  195</span>&#160;<span class="comment"> *      32 input bits, the IE3264 transformation table is half the size of</span></div>
<div class="line"><a name="l00196"></a><span class="lineno">  196</span>&#160;<span class="comment"> *      the usual table.</span></div>
<div class="line"><a name="l00197"></a><span class="lineno">  197</span>&#160;<span class="comment"> * CF6464: Compression, final permutation, and LSB-&gt;MSB conversion.</span></div>
<div class="line"><a name="l00198"></a><span class="lineno">  198</span>&#160;<span class="comment"> *      This is done by two trivial 48-&gt;32 bit compressions to obtain</span></div>
<div class="line"><a name="l00199"></a><span class="lineno">  199</span>&#160;<span class="comment"> *      a 64-bit block (the bit numbering is given in the &quot;CIFP&quot; table)</span></div>
<div class="line"><a name="l00200"></a><span class="lineno">  200</span>&#160;<span class="comment"> *      followed by a 64-&gt;64 bit &quot;cleanup&quot; transformation.  (It would</span></div>
<div class="line"><a name="l00201"></a><span class="lineno">  201</span>&#160;<span class="comment"> *      be possible to group the bits in the 64-bit block so that 2</span></div>
<div class="line"><a name="l00202"></a><span class="lineno">  202</span>&#160;<span class="comment"> *      identical 32-&gt;32 bit transformations could be used instead,</span></div>
<div class="line"><a name="l00203"></a><span class="lineno">  203</span>&#160;<span class="comment"> *      saving a factor of 4 in space and possibly 2 in time, but</span></div>
<div class="line"><a name="l00204"></a><span class="lineno">  204</span>&#160;<span class="comment"> *      byte-ordering and other complications rear their ugly head.</span></div>
<div class="line"><a name="l00205"></a><span class="lineno">  205</span>&#160;<span class="comment"> *      Similar opportunities/problems arise in the key schedule</span></div>
<div class="line"><a name="l00206"></a><span class="lineno">  206</span>&#160;<span class="comment"> *      transforms.)</span></div>
<div class="line"><a name="l00207"></a><span class="lineno">  207</span>&#160;<span class="comment"> * PC1ROT: MSB-&gt;LSB, PC1 permutation, rotate, and PC2 permutation.</span></div>
<div class="line"><a name="l00208"></a><span class="lineno">  208</span>&#160;<span class="comment"> *      This admittedly baroque 64-&gt;64 bit transformation is used to</span></div>
<div class="line"><a name="l00209"></a><span class="lineno">  209</span>&#160;<span class="comment"> *      produce the first code (in 8*(6+2) format) of the key schedule.</span></div>
<div class="line"><a name="l00210"></a><span class="lineno">  210</span>&#160;<span class="comment"> * PC2ROT[0]: Inverse PC2 permutation, rotate, and PC2 permutation.</span></div>
<div class="line"><a name="l00211"></a><span class="lineno">  211</span>&#160;<span class="comment"> *      It would be possible to define 15 more transformations, each</span></div>
<div class="line"><a name="l00212"></a><span class="lineno">  212</span>&#160;<span class="comment"> *      with a different rotation, to generate the entire key schedule.</span></div>
<div class="line"><a name="l00213"></a><span class="lineno">  213</span>&#160;<span class="comment"> *      To save space, however, we instead permute each code into the</span></div>
<div class="line"><a name="l00214"></a><span class="lineno">  214</span>&#160;<span class="comment"> *      next by using a transformation that &quot;undoes&quot; the PC2 permutation,</span></div>
<div class="line"><a name="l00215"></a><span class="lineno">  215</span>&#160;<span class="comment"> *      rotates the code, and then applies PC2.  Unfortunately, PC2</span></div>
<div class="line"><a name="l00216"></a><span class="lineno">  216</span>&#160;<span class="comment"> *      transforms 56 bits into 48 bits, dropping 8 bits, so PC2 is not</span></div>
<div class="line"><a name="l00217"></a><span class="lineno">  217</span>&#160;<span class="comment"> *      invertible.  We get around that problem by using a modified PC2</span></div>
<div class="line"><a name="l00218"></a><span class="lineno">  218</span>&#160;<span class="comment"> *      which retains the 8 otherwise-lost bits in the unused low-order</span></div>
<div class="line"><a name="l00219"></a><span class="lineno">  219</span>&#160;<span class="comment"> *      bits of each byte.  The low-order bits are cleared when the</span></div>
<div class="line"><a name="l00220"></a><span class="lineno">  220</span>&#160;<span class="comment"> *      codes are stored into the key schedule.</span></div>
<div class="line"><a name="l00221"></a><span class="lineno">  221</span>&#160;<span class="comment"> * PC2ROT[1]: Same as PC2ROT[0], but with two rotations.</span></div>
<div class="line"><a name="l00222"></a><span class="lineno">  222</span>&#160;<span class="comment"> *      This is faster than applying PC2ROT[0] twice,</span></div>
<div class="line"><a name="l00223"></a><span class="lineno">  223</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00224"></a><span class="lineno">  224</span>&#160;<span class="comment"> * The Bell Labs &quot;salt&quot; (Bob Baldwin):</span></div>
<div class="line"><a name="l00225"></a><span class="lineno">  225</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00226"></a><span class="lineno">  226</span>&#160;<span class="comment"> * The salting is a simple permutation applied to the 48-bit result of E.</span></div>
<div class="line"><a name="l00227"></a><span class="lineno">  227</span>&#160;<span class="comment"> * Specifically, if bit i (1 &lt;= i &lt;= 24) of the salt is set then bits i and</span></div>
<div class="line"><a name="l00228"></a><span class="lineno">  228</span>&#160;<span class="comment"> * i+24 of the result are swapped.  The salt is thus a 24 bit number, with</span></div>
<div class="line"><a name="l00229"></a><span class="lineno">  229</span>&#160;<span class="comment"> * 16777216 possible values.  (The original salt was 12 bits and could not</span></div>
<div class="line"><a name="l00230"></a><span class="lineno">  230</span>&#160;<span class="comment"> * swap bits 13..24 with 36..48.)</span></div>
<div class="line"><a name="l00231"></a><span class="lineno">  231</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00232"></a><span class="lineno">  232</span>&#160;<span class="comment"> * It is possible, but ugly, to warp the SPE table to account for the salt</span></div>
<div class="line"><a name="l00233"></a><span class="lineno">  233</span>&#160;<span class="comment"> * permutation.  Fortunately, the conditional bit swapping requires only</span></div>
<div class="line"><a name="l00234"></a><span class="lineno">  234</span>&#160;<span class="comment"> * about four machine instructions and can be done on-the-fly with about an</span></div>
<div class="line"><a name="l00235"></a><span class="lineno">  235</span>&#160;<span class="comment"> * 8% performance penalty.</span></div>
<div class="line"><a name="l00236"></a><span class="lineno">  236</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00237"></a><span class="lineno">  237</span>&#160;</div>
<div class="line"><a name="l00238"></a><span class="lineno"><a class="line" href="../../df/da2/union_c__block.html">  238</a></span>&#160;<span class="keyword">typedef</span> <span class="keyword">union </span>{</div>
<div class="line"><a name="l00239"></a><span class="lineno"><a class="line" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">  239</a></span>&#160;        <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#af5857437ff0274b5a927afe95f104a39">b</a>[8];</div>
<div class="line"><a name="l00240"></a><span class="lineno">  240</span>&#160;        <span class="keyword">struct </span>{</div>
<div class="line"><a name="l00241"></a><span class="lineno">  241</span>&#160;<span class="preprocessor">#if defined(LONG_IS_32_BITS)</span></div>
<div class="line"><a name="l00242"></a><span class="lineno">  242</span>&#160;<span class="preprocessor"></span>                <span class="comment">/* long is often faster than a 32-bit bit field */</span></div>
<div class="line"><a name="l00243"></a><span class="lineno"><a class="line" href="../../df/da2/union_c__block.html#a48d864bc645bde7086c33a216c41176a">  243</a></span>&#160;                <span class="keywordtype">long</span>    <a class="code" href="../../df/da2/union_c__block.html#a48d864bc645bde7086c33a216c41176a">i0</a>;</div>
<div class="line"><a name="l00244"></a><span class="lineno"><a class="line" href="../../df/da2/union_c__block.html#ace63ec71fc3cef8deb34ce3a0a8da5fa">  244</a></span>&#160;                <span class="keywordtype">long</span>    <a class="code" href="../../df/da2/union_c__block.html#ace63ec71fc3cef8deb34ce3a0a8da5fa">i1</a>;</div>
<div class="line"><a name="l00245"></a><span class="lineno">  245</span>&#160;<span class="preprocessor">#else</span></div>
<div class="line"><a name="l00246"></a><span class="lineno">  246</span>&#160;<span class="preprocessor"></span>                <span class="keywordtype">long</span>    i0: 32;</div>
<div class="line"><a name="l00247"></a><span class="lineno">  247</span>&#160;                <span class="keywordtype">long</span>    i1: 32;</div>
<div class="line"><a name="l00248"></a><span class="lineno">  248</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00249"></a><span class="lineno">  249</span>&#160;<span class="preprocessor"></span>        } b32;</div>
<div class="line"><a name="l00250"></a><span class="lineno">  250</span>&#160;<span class="preprocessor">#if defined(B64)</span></div>
<div class="line"><a name="l00251"></a><span class="lineno">  251</span>&#160;<span class="preprocessor"></span>        B64     b64;</div>
<div class="line"><a name="l00252"></a><span class="lineno">  252</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00253"></a><span class="lineno">  253</span>&#160;<span class="preprocessor"></span>} <a class="code" href="../../df/da2/union_c__block.html">C_block</a>;</div>
<div class="line"><a name="l00254"></a><span class="lineno">  254</span>&#160;</div>
<div class="line"><a name="l00255"></a><span class="lineno">  255</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00256"></a><span class="lineno">  256</span>&#160;<span class="comment"> * Convert twenty-four-bit long in host-order</span></div>
<div class="line"><a name="l00257"></a><span class="lineno">  257</span>&#160;<span class="comment"> * to six bits (and 2 low-order zeroes) per char little-endian format.</span></div>
<div class="line"><a name="l00258"></a><span class="lineno">  258</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00259"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a1a1902080cb6a4fb4caa7affb5cebb51">  259</a></span>&#160;<span class="preprocessor">#define TO_SIX_BIT(rslt, src) {                         \</span></div>
<div class="line"><a name="l00260"></a><span class="lineno">  260</span>&#160;<span class="preprocessor">                C_block cvt;                            \</span></div>
<div class="line"><a name="l00261"></a><span class="lineno">  261</span>&#160;<span class="preprocessor">                cvt.b[0] = (unsigned char)(src); (src) &gt;&gt;= 6; \</span></div>
<div class="line"><a name="l00262"></a><span class="lineno">  262</span>&#160;<span class="preprocessor">                cvt.b[1] = (unsigned char)(src); (src) &gt;&gt;= 6; \</span></div>
<div class="line"><a name="l00263"></a><span class="lineno">  263</span>&#160;<span class="preprocessor">                cvt.b[2] = (unsigned char)(src); (src) &gt;&gt;= 6; \</span></div>
<div class="line"><a name="l00264"></a><span class="lineno">  264</span>&#160;<span class="preprocessor">                cvt.b[3] = (unsigned char)(src);                \</span></div>
<div class="line"><a name="l00265"></a><span class="lineno">  265</span>&#160;<span class="preprocessor">                (rslt) = (cvt.b32.i0 &amp; 0x3f3f3f3fL) &lt;&lt; 2;       \</span></div>
<div class="line"><a name="l00266"></a><span class="lineno">  266</span>&#160;<span class="preprocessor">        }</span></div>
<div class="line"><a name="l00267"></a><span class="lineno">  267</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00268"></a><span class="lineno">  268</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00269"></a><span class="lineno">  269</span>&#160;<span class="comment"> * These macros may someday permit efficient use of 64-bit integers.</span></div>
<div class="line"><a name="l00270"></a><span class="lineno">  270</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00271"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#aae9ccc58a01ccfd146045885993165bd">  271</a></span>&#160;<span class="preprocessor">#define ZERO(d,d0,d1)                   ((d0) = 0, (d1) = 0)</span></div>
<div class="line"><a name="l00272"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a1b207183df3765ba2eabb5562da72158">  272</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define LOAD(d,d0,d1,bl)                ((d0) = (bl).b32.i0, (d1) = (bl).b32.i1)</span></div>
<div class="line"><a name="l00273"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ab644f676d8d67d6265407b73d33a647d">  273</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define LOADREG(d,d0,d1,s,s0,s1)        ((d0) = (s0), (d1) = (s1))</span></div>
<div class="line"><a name="l00274"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a690b7fe0554b40cc1d5c4204be4fd24b">  274</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define OR(d,d0,d1,bl)                  ((d0) |= (bl).b32.i0, (d1) |= (bl).b32.i1)</span></div>
<div class="line"><a name="l00275"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ad50d91202186ced15ec3fc3a922506b3">  275</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define STORE(s,s0,s1,bl)               ((bl).b32.i0 = (s0), (bl).b32.i1 = (s1))</span></div>
<div class="line"><a name="l00276"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a2c844749684bfce83e662dee88390dc9">  276</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define DCL_BLOCK(d,d0,d1)              long d0, d1</span></div>
<div class="line"><a name="l00277"></a><span class="lineno">  277</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00278"></a><span class="lineno">  278</span>&#160;<span class="preprocessor">#if defined(LARGEDATA)</span></div>
<div class="line"><a name="l00279"></a><span class="lineno">  279</span>&#160;<span class="preprocessor"></span>        <span class="comment">/* Waste memory like crazy.  Also, do permutations in line */</span></div>
<div class="line"><a name="l00280"></a><span class="lineno">  280</span>&#160;<span class="preprocessor">#define LGCHUNKBITS     3</span></div>
<div class="line"><a name="l00281"></a><span class="lineno">  281</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define CHUNKBITS       (1&lt;&lt;LGCHUNKBITS)</span></div>
<div class="line"><a name="l00282"></a><span class="lineno">  282</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define PERM6464(d,d0,d1,cpp,p)                         \</span></div>
<div class="line"><a name="l00283"></a><span class="lineno">  283</span>&#160;<span class="preprocessor">        LOAD((d),(d0),(d1),(p)[(0&lt;&lt;CHUNKBITS)+(cpp)[0]]);               \</span></div>
<div class="line"><a name="l00284"></a><span class="lineno">  284</span>&#160;<span class="preprocessor">        OR ((d),(d0),(d1),(p)[(1&lt;&lt;CHUNKBITS)+(cpp)[1]]);                \</span></div>
<div class="line"><a name="l00285"></a><span class="lineno">  285</span>&#160;<span class="preprocessor">        OR ((d),(d0),(d1),(p)[(2&lt;&lt;CHUNKBITS)+(cpp)[2]]);                \</span></div>
<div class="line"><a name="l00286"></a><span class="lineno">  286</span>&#160;<span class="preprocessor">        OR ((d),(d0),(d1),(p)[(3&lt;&lt;CHUNKBITS)+(cpp)[3]]);                \</span></div>
<div class="line"><a name="l00287"></a><span class="lineno">  287</span>&#160;<span class="preprocessor">        OR (d),(d0),(d1),(p)[(4&lt;&lt;CHUNKBITS)+(cpp)[4]]);         \</span></div>
<div class="line"><a name="l00288"></a><span class="lineno">  288</span>&#160;<span class="preprocessor">        OR (d),(d0),(d1),(p)[(5&lt;&lt;CHUNKBITS)+(cpp)[5]]);         \</span></div>
<div class="line"><a name="l00289"></a><span class="lineno">  289</span>&#160;<span class="preprocessor">        OR (d),(d0),(d1),(p)[(6&lt;&lt;CHUNKBITS)+(cpp)[6]]);         \</span></div>
<div class="line"><a name="l00290"></a><span class="lineno">  290</span>&#160;<span class="preprocessor">        OR (d),(d0),(d1),(p)[(7&lt;&lt;CHUNKBITS)+(cpp)[7]]);</span></div>
<div class="line"><a name="l00291"></a><span class="lineno">  291</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define PERM3264(d,d0,d1,cpp,p)                         \</span></div>
<div class="line"><a name="l00292"></a><span class="lineno">  292</span>&#160;<span class="preprocessor">        LOAD((d),(d0),(d1),(p)[(0&lt;&lt;CHUNKBITS)+(cpp)[0]]);               \</span></div>
<div class="line"><a name="l00293"></a><span class="lineno">  293</span>&#160;<span class="preprocessor">        OR ((d),(d0),(d1),(p)[(1&lt;&lt;CHUNKBITS)+(cpp)[1]]);                \</span></div>
<div class="line"><a name="l00294"></a><span class="lineno">  294</span>&#160;<span class="preprocessor">        OR ((d),(d0),(d1),(p)[(2&lt;&lt;CHUNKBITS)+(cpp)[2]]);                \</span></div>
<div class="line"><a name="l00295"></a><span class="lineno">  295</span>&#160;<span class="preprocessor">        OR ((d),(d0),(d1),(p)[(3&lt;&lt;CHUNKBITS)+(cpp)[3]]);</span></div>
<div class="line"><a name="l00296"></a><span class="lineno">  296</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l00297"></a><span class="lineno">  297</span>&#160;<span class="preprocessor"></span>        <span class="comment">/* &quot;small data&quot; */</span></div>
<div class="line"><a name="l00298"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#aefe059a4e3b401e9378733c2c59878db">  298</a></span>&#160;<span class="preprocessor">#define LGCHUNKBITS     2</span></div>
<div class="line"><a name="l00299"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">  299</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define CHUNKBITS       (1&lt;&lt;LGCHUNKBITS)</span></div>
<div class="line"><a name="l00300"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a2d3c04b14357f1839a3e32c88312e15f">  300</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define PERM6464(d,d0,d1,cpp,p)                         \</span></div>
<div class="line"><a name="l00301"></a><span class="lineno">  301</span>&#160;<span class="preprocessor">        { C_block tblk; permute((cpp),&amp;tblk,(p),8); LOAD ((d),(d0),(d1),tblk); }</span></div>
<div class="line"><a name="l00302"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a46df822e601f80265b7348b8fa89ed36">  302</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define PERM3264(d,d0,d1,cpp,p)                         \</span></div>
<div class="line"><a name="l00303"></a><span class="lineno">  303</span>&#160;<span class="preprocessor">        { C_block tblk; permute((cpp),&amp;tblk,(p),4); LOAD ((d),(d0),(d1),tblk); }</span></div>
<div class="line"><a name="l00304"></a><span class="lineno">  304</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00305"></a><span class="lineno">  305</span>&#160;<a class="code" href="../../d6/de3/crypt_8c.html#a10b2d890d871e1489bb02b7e70d9bdfb">STATIC</a> <span class="keywordtype">void</span></div>
<div class="line"><a name="l00306"></a><span class="lineno">  306</span>&#160;<a class="code" href="../../d6/de3/crypt_8c.html#af957276b65abd295692175245d603c04">permute</a>(<a class="code" href="../../d6/de3/crypt_8c.html#a7b8aa9e9351c17779590208d93d33fb4">cp</a>, <a class="code" href="../../d6/de3/crypt_8c.html#a60d0673ec77a0a3574652b45bdfcc623">out</a>, <a class="code" href="../../dd/dfb/yaml2byte_8c.html#a37ed7f02c58c0c771e7e76b4c1e594e6">p</a>, <a class="code" href="../../d6/de3/crypt_8c.html#acf339f7dd636dc2a8da0ff818f4908ad">chars_in</a>)</div>
<div class="line"><a name="l00307"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a7b8aa9e9351c17779590208d93d33fb4">  307</a></span>&#160;        unsigned <span class="keywordtype">char</span> *<a class="code" href="../../d6/de3/crypt_8c.html#a7b8aa9e9351c17779590208d93d33fb4">cp</a>;</div>
<div class="line"><a name="l00308"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a60d0673ec77a0a3574652b45bdfcc623">  308</a></span>&#160;        <a class="code" href="../../df/da2/union_c__block.html">C_block</a> *<a class="code" href="../../d6/de3/crypt_8c.html#a60d0673ec77a0a3574652b45bdfcc623">out</a>;</div>
<div class="line"><a name="l00309"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#afc1dd3c6791f3e7cc697d4e8e6ba20e8">  309</a></span>&#160;        register <a class="code" href="../../df/da2/union_c__block.html">C_block</a> *<a class="code" href="../../dd/dfb/yaml2byte_8c.html#a37ed7f02c58c0c771e7e76b4c1e594e6">p</a>;</div>
<div class="line"><a name="l00310"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#acf339f7dd636dc2a8da0ff818f4908ad">  310</a></span>&#160;        <span class="keywordtype">int</span> <a class="code" href="../../d6/de3/crypt_8c.html#acf339f7dd636dc2a8da0ff818f4908ad">chars_in</a>;</div>
<div class="line"><a name="l00311"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a8a1eb1db6dc99f82114ae4594b3593ea">  311</a></span>&#160;{</div>
<div class="line"><a name="l00312"></a><span class="lineno">  312</span>&#160;        <span class="keyword">register</span> <a class="code" href="../../d6/de3/crypt_8c.html#a2c844749684bfce83e662dee88390dc9">DCL_BLOCK</a>(<a class="code" href="../../de/df1/util_8c.html#af316c33cc298530f245e8b55330e86b5">D</a>,D0,D1);</div>
<div class="line"><a name="l00313"></a><span class="lineno">  313</span>&#160;        <span class="keyword">register</span> <a class="code" href="../../df/da2/union_c__block.html">C_block</a> *<a class="code" href="../../d6/de3/crypt_8c.html#a8a1eb1db6dc99f82114ae4594b3593ea">tp</a>;</div>
<div class="line"><a name="l00314"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#af188ef44251a5eafb576c4327441f820">  314</a></span>&#160;        <span class="keyword">register</span> <span class="keywordtype">int</span> <a class="code" href="../../d5/d11/ripper_8c.html#a93ca48b6ca5634eebe9872b8dc2650ee">t</a>;</div>
<div class="line"><a name="l00315"></a><span class="lineno">  315</span>&#160;</div>
<div class="line"><a name="l00316"></a><span class="lineno">  316</span>&#160;        <a class="code" href="../../d1/d81/complex_8c.html#ac328e551bde3d39b6d7b8cc9e048d941">ZERO</a>(<a class="code" href="../../de/df1/util_8c.html#af316c33cc298530f245e8b55330e86b5">D</a>,D0,D1);</div>
<div class="line"><a name="l00317"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a721c6ff80a6d3e4ad4ffa52a04c60085">  317</a></span>&#160;        <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l00318"></a><span class="lineno">  318</span>&#160;                t = *cp++;</div>
<div class="line"><a name="l00319"></a><span class="lineno">  319</span>&#160;                tp = &amp;p[t&amp;0xf]; <a class="code" href="../../d6/de3/crypt_8c.html#a690b7fe0554b40cc1d5c4204be4fd24b">OR</a>(<a class="code" href="../../de/df1/util_8c.html#af316c33cc298530f245e8b55330e86b5">D</a>,D0,D1,*tp); p += (1&lt;&lt;<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>);</div>
<div class="line"><a name="l00320"></a><span class="lineno">  320</span>&#160;                tp = &amp;p[t&gt;&gt;4];  <a class="code" href="../../d6/de3/crypt_8c.html#a690b7fe0554b40cc1d5c4204be4fd24b">OR</a>(<a class="code" href="../../de/df1/util_8c.html#af316c33cc298530f245e8b55330e86b5">D</a>,D0,D1,*tp); p += (1&lt;&lt;<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>);</div>
<div class="line"><a name="l00321"></a><span class="lineno">  321</span>&#160;        } <span class="keywordflow">while</span> (--chars_in &gt; 0);</div>
<div class="line"><a name="l00322"></a><span class="lineno">  322</span>&#160;        <a class="code" href="../../d6/de3/crypt_8c.html#ad50d91202186ced15ec3fc3a922506b3">STORE</a>(<a class="code" href="../../de/df1/util_8c.html#af316c33cc298530f245e8b55330e86b5">D</a>,D0,D1,*out);</div>
<div class="line"><a name="l00323"></a><span class="lineno">  323</span>&#160;}</div>
<div class="line"><a name="l00324"></a><span class="lineno">  324</span>&#160;<span class="preprocessor">#endif </span><span class="comment">/* LARGEDATA */</span><span class="preprocessor"></span></div>
<div class="line"><a name="l00325"></a><span class="lineno">  325</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00326"></a><span class="lineno">  326</span>&#160;</div>
<div class="line"><a name="l00327"></a><span class="lineno">  327</span>&#160;<span class="comment">/* =====  (mostly) Standard DES Tables ==================== */</span></div>
<div class="line"><a name="l00328"></a><span class="lineno">  328</span>&#160;</div>
<div class="line"><a name="l00329"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#af5b1e159fb6e48c6bd447777b381a7a8">  329</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#af5b1e159fb6e48c6bd447777b381a7a8">IP</a>[] = {           <span class="comment">/* initial permutation */</span></div>
<div class="line"><a name="l00330"></a><span class="lineno">  330</span>&#160;        58, 50, 42, 34, 26, 18, 10,  2,</div>
<div class="line"><a name="l00331"></a><span class="lineno">  331</span>&#160;        60, 52, 44, 36, 28, 20, 12,  4,</div>
<div class="line"><a name="l00332"></a><span class="lineno">  332</span>&#160;        62, 54, 46, 38, 30, 22, 14,  6,</div>
<div class="line"><a name="l00333"></a><span class="lineno">  333</span>&#160;        64, 56, 48, 40, 32, 24, 16,  8,</div>
<div class="line"><a name="l00334"></a><span class="lineno">  334</span>&#160;        57, 49, 41, 33, 25, 17,  9,  1,</div>
<div class="line"><a name="l00335"></a><span class="lineno">  335</span>&#160;        59, 51, 43, 35, 27, 19, 11,  3,</div>
<div class="line"><a name="l00336"></a><span class="lineno">  336</span>&#160;        61, 53, 45, 37, 29, 21, 13,  5,</div>
<div class="line"><a name="l00337"></a><span class="lineno">  337</span>&#160;        63, 55, 47, 39, 31, 23, 15,  7,</div>
<div class="line"><a name="l00338"></a><span class="lineno">  338</span>&#160;};</div>
<div class="line"><a name="l00339"></a><span class="lineno">  339</span>&#160;</div>
<div class="line"><a name="l00340"></a><span class="lineno">  340</span>&#160;<span class="comment">/* The final permutation is the inverse of IP - no table is necessary */</span></div>
<div class="line"><a name="l00341"></a><span class="lineno">  341</span>&#160;</div>
<div class="line"><a name="l00342"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a3d92a6f0c00c0ed46fdeec86b6da0c4c">  342</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#a3d92a6f0c00c0ed46fdeec86b6da0c4c">ExpandTr</a>[] = {     <span class="comment">/* expansion operation */</span></div>
<div class="line"><a name="l00343"></a><span class="lineno">  343</span>&#160;        32,  1,  2,  3,  4,  5,</div>
<div class="line"><a name="l00344"></a><span class="lineno">  344</span>&#160;         4,  5,  6,  7,  8,  9,</div>
<div class="line"><a name="l00345"></a><span class="lineno">  345</span>&#160;         8,  9, 10, 11, 12, 13,</div>
<div class="line"><a name="l00346"></a><span class="lineno">  346</span>&#160;        12, 13, 14, 15, 16, 17,</div>
<div class="line"><a name="l00347"></a><span class="lineno">  347</span>&#160;        16, 17, 18, 19, 20, 21,</div>
<div class="line"><a name="l00348"></a><span class="lineno">  348</span>&#160;        20, 21, 22, 23, 24, 25,</div>
<div class="line"><a name="l00349"></a><span class="lineno">  349</span>&#160;        24, 25, 26, 27, 28, 29,</div>
<div class="line"><a name="l00350"></a><span class="lineno">  350</span>&#160;        28, 29, 30, 31, 32,  1,</div>
<div class="line"><a name="l00351"></a><span class="lineno">  351</span>&#160;};</div>
<div class="line"><a name="l00352"></a><span class="lineno">  352</span>&#160;</div>
<div class="line"><a name="l00353"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a1e467111f12800763f28f038bd8cebaa">  353</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#a1e467111f12800763f28f038bd8cebaa">PC1</a>[] = {          <span class="comment">/* permuted choice table 1 */</span></div>
<div class="line"><a name="l00354"></a><span class="lineno">  354</span>&#160;        57, 49, 41, 33, 25, 17,  9,</div>
<div class="line"><a name="l00355"></a><span class="lineno">  355</span>&#160;         1, 58, 50, 42, 34, 26, 18,</div>
<div class="line"><a name="l00356"></a><span class="lineno">  356</span>&#160;        10,  2, 59, 51, 43, 35, 27,</div>
<div class="line"><a name="l00357"></a><span class="lineno">  357</span>&#160;        19, 11,  3, 60, 52, 44, 36,</div>
<div class="line"><a name="l00358"></a><span class="lineno">  358</span>&#160;</div>
<div class="line"><a name="l00359"></a><span class="lineno">  359</span>&#160;        63, 55, 47, 39, 31, 23, 15,</div>
<div class="line"><a name="l00360"></a><span class="lineno">  360</span>&#160;         7, 62, 54, 46, 38, 30, 22,</div>
<div class="line"><a name="l00361"></a><span class="lineno">  361</span>&#160;        14,  6, 61, 53, 45, 37, 29,</div>
<div class="line"><a name="l00362"></a><span class="lineno">  362</span>&#160;        21, 13,  5, 28, 20, 12,  4,</div>
<div class="line"><a name="l00363"></a><span class="lineno">  363</span>&#160;};</div>
<div class="line"><a name="l00364"></a><span class="lineno">  364</span>&#160;</div>
<div class="line"><a name="l00365"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a9af53e8c6f003c783332ad9b499a7f7c">  365</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#a9af53e8c6f003c783332ad9b499a7f7c">Rotates</a>[] = {      <span class="comment">/* PC1 rotation schedule */</span></div>
<div class="line"><a name="l00366"></a><span class="lineno">  366</span>&#160;        1, 1, 2, 2, 2, 2, 2, 2, 1, 2, 2, 2, 2, 2, 2, 1,</div>
<div class="line"><a name="l00367"></a><span class="lineno">  367</span>&#160;};</div>
<div class="line"><a name="l00368"></a><span class="lineno">  368</span>&#160;</div>
<div class="line"><a name="l00369"></a><span class="lineno">  369</span>&#160;<span class="comment">/* note: each &quot;row&quot; of PC2 is left-padded with bits that make it invertible */</span></div>
<div class="line"><a name="l00370"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ac3e66cac1d02038eda4509f0d4f7a80c">  370</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#ac3e66cac1d02038eda4509f0d4f7a80c">PC2</a>[] = {          <span class="comment">/* permuted choice table 2 */</span></div>
<div class="line"><a name="l00371"></a><span class="lineno">  371</span>&#160;         9, 18,    14, 17, 11, 24,  1,  5,</div>
<div class="line"><a name="l00372"></a><span class="lineno">  372</span>&#160;        22, 25,     3, 28, 15,  6, 21, 10,</div>
<div class="line"><a name="l00373"></a><span class="lineno">  373</span>&#160;        35, 38,    23, 19, 12,  4, 26,  8,</div>
<div class="line"><a name="l00374"></a><span class="lineno">  374</span>&#160;        43, 54,    16,  7, 27, 20, 13,  2,</div>
<div class="line"><a name="l00375"></a><span class="lineno">  375</span>&#160;</div>
<div class="line"><a name="l00376"></a><span class="lineno">  376</span>&#160;         0,  0,    41, 52, 31, 37, 47, 55,</div>
<div class="line"><a name="l00377"></a><span class="lineno">  377</span>&#160;         0,  0,    30, 40, 51, 45, 33, 48,</div>
<div class="line"><a name="l00378"></a><span class="lineno">  378</span>&#160;         0,  0,    44, 49, 39, 56, 34, 53,</div>
<div class="line"><a name="l00379"></a><span class="lineno">  379</span>&#160;         0,  0,    46, 42, 50, 36, 29, 32,</div>
<div class="line"><a name="l00380"></a><span class="lineno">  380</span>&#160;};</div>
<div class="line"><a name="l00381"></a><span class="lineno">  381</span>&#160;</div>
<div class="line"><a name="l00382"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#abe081f68ee621d157bd09424831be314">  382</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#abe081f68ee621d157bd09424831be314">S</a>[8][64] = {       <span class="comment">/* 48-&gt;32 bit substitution tables */</span></div>
<div class="line"><a name="l00383"></a><span class="lineno">  383</span>&#160;    {</div>
<div class="line"><a name="l00384"></a><span class="lineno">  384</span>&#160;                                        <span class="comment">/* S[1]                 */</span></div>
<div class="line"><a name="l00385"></a><span class="lineno">  385</span>&#160;        14,  4, 13,  1,  2, 15, 11,  8,  3, 10,  6, 12,  5,  9,  0,  7,</div>
<div class="line"><a name="l00386"></a><span class="lineno">  386</span>&#160;         0, 15,  7,  4, 14,  2, 13,  1, 10,  6, 12, 11,  9,  5,  3,  8,</div>
<div class="line"><a name="l00387"></a><span class="lineno">  387</span>&#160;         4,  1, 14,  8, 13,  6,  2, 11, 15, 12,  9,  7,  3, 10,  5,  0,</div>
<div class="line"><a name="l00388"></a><span class="lineno">  388</span>&#160;        15, 12,  8,  2,  4,  9,  1,  7,  5, 11,  3, 14, 10,  0,  6, 13,</div>
<div class="line"><a name="l00389"></a><span class="lineno">  389</span>&#160;    },</div>
<div class="line"><a name="l00390"></a><span class="lineno">  390</span>&#160;    {</div>
<div class="line"><a name="l00391"></a><span class="lineno">  391</span>&#160;                                        <span class="comment">/* S[2]                 */</span></div>
<div class="line"><a name="l00392"></a><span class="lineno">  392</span>&#160;        15,  1,  8, 14,  6, 11,  3,  4,  9,  7,  2, 13, 12,  0,  5, 10,</div>
<div class="line"><a name="l00393"></a><span class="lineno">  393</span>&#160;         3, 13,  4,  7, 15,  2,  8, 14, 12,  0,  1, 10,  6,  9, 11,  5,</div>
<div class="line"><a name="l00394"></a><span class="lineno">  394</span>&#160;         0, 14,  7, 11, 10,  4, 13,  1,  5,  8, 12,  6,  9,  3,  2, 15,</div>
<div class="line"><a name="l00395"></a><span class="lineno">  395</span>&#160;        13,  8, 10,  1,  3, 15,  4,  2, 11,  6,  7, 12,  0,  5, 14,  9,</div>
<div class="line"><a name="l00396"></a><span class="lineno">  396</span>&#160;    },</div>
<div class="line"><a name="l00397"></a><span class="lineno">  397</span>&#160;    {</div>
<div class="line"><a name="l00398"></a><span class="lineno">  398</span>&#160;                                        <span class="comment">/* S[3]                 */</span></div>
<div class="line"><a name="l00399"></a><span class="lineno">  399</span>&#160;        10,  0,  9, 14,  6,  3, 15,  5,  1, 13, 12,  7, 11,  4,  2,  8,</div>
<div class="line"><a name="l00400"></a><span class="lineno">  400</span>&#160;        13,  7,  0,  9,  3,  4,  6, 10,  2,  8,  5, 14, 12, 11, 15,  1,</div>
<div class="line"><a name="l00401"></a><span class="lineno">  401</span>&#160;        13,  6,  4,  9,  8, 15,  3,  0, 11,  1,  2, 12,  5, 10, 14,  7,</div>
<div class="line"><a name="l00402"></a><span class="lineno">  402</span>&#160;         1, 10, 13,  0,  6,  9,  8,  7,  4, 15, 14,  3, 11,  5,  2, 12,</div>
<div class="line"><a name="l00403"></a><span class="lineno">  403</span>&#160;    },</div>
<div class="line"><a name="l00404"></a><span class="lineno">  404</span>&#160;    {</div>
<div class="line"><a name="l00405"></a><span class="lineno">  405</span>&#160;                                        <span class="comment">/* S[4]                 */</span></div>
<div class="line"><a name="l00406"></a><span class="lineno">  406</span>&#160;         7, 13, 14,  3,  0,  6,  9, 10,  1,  2,  8,  5, 11, 12,  4, 15,</div>
<div class="line"><a name="l00407"></a><span class="lineno">  407</span>&#160;        13,  8, 11,  5,  6, 15,  0,  3,  4,  7,  2, 12,  1, 10, 14,  9,</div>
<div class="line"><a name="l00408"></a><span class="lineno">  408</span>&#160;        10,  6,  9,  0, 12, 11,  7, 13, 15,  1,  3, 14,  5,  2,  8,  4,</div>
<div class="line"><a name="l00409"></a><span class="lineno">  409</span>&#160;         3, 15,  0,  6, 10,  1, 13,  8,  9,  4,  5, 11, 12,  7,  2, 14,</div>
<div class="line"><a name="l00410"></a><span class="lineno">  410</span>&#160;    },</div>
<div class="line"><a name="l00411"></a><span class="lineno">  411</span>&#160;    {</div>
<div class="line"><a name="l00412"></a><span class="lineno">  412</span>&#160;                                        <span class="comment">/* S[5]                 */</span></div>
<div class="line"><a name="l00413"></a><span class="lineno">  413</span>&#160;         2, 12,  4,  1,  7, 10, 11,  6,  8,  5,  3, 15, 13,  0, 14,  9,</div>
<div class="line"><a name="l00414"></a><span class="lineno">  414</span>&#160;        14, 11,  2, 12,  4,  7, 13,  1,  5,  0, 15, 10,  3,  9,  8,  6,</div>
<div class="line"><a name="l00415"></a><span class="lineno">  415</span>&#160;         4,  2,  1, 11, 10, 13,  7,  8, 15,  9, 12,  5,  6,  3,  0, 14,</div>
<div class="line"><a name="l00416"></a><span class="lineno">  416</span>&#160;        11,  8, 12,  7,  1, 14,  2, 13,  6, 15,  0,  9, 10,  4,  5,  3,</div>
<div class="line"><a name="l00417"></a><span class="lineno">  417</span>&#160;    },</div>
<div class="line"><a name="l00418"></a><span class="lineno">  418</span>&#160;    {</div>
<div class="line"><a name="l00419"></a><span class="lineno">  419</span>&#160;                                        <span class="comment">/* S[6]                 */</span></div>
<div class="line"><a name="l00420"></a><span class="lineno">  420</span>&#160;        12,  1, 10, 15,  9,  2,  6,  8,  0, 13,  3,  4, 14,  7,  5, 11,</div>
<div class="line"><a name="l00421"></a><span class="lineno">  421</span>&#160;        10, 15,  4,  2,  7, 12,  9,  5,  6,  1, 13, 14,  0, 11,  3,  8,</div>
<div class="line"><a name="l00422"></a><span class="lineno">  422</span>&#160;         9, 14, 15,  5,  2,  8, 12,  3,  7,  0,  4, 10,  1, 13, 11,  6,</div>
<div class="line"><a name="l00423"></a><span class="lineno">  423</span>&#160;         4,  3,  2, 12,  9,  5, 15, 10, 11, 14,  1,  7,  6,  0,  8, 13,</div>
<div class="line"><a name="l00424"></a><span class="lineno">  424</span>&#160;    },</div>
<div class="line"><a name="l00425"></a><span class="lineno">  425</span>&#160;    {</div>
<div class="line"><a name="l00426"></a><span class="lineno">  426</span>&#160;                                        <span class="comment">/* S[7]                 */</span></div>
<div class="line"><a name="l00427"></a><span class="lineno">  427</span>&#160;         4, 11,  2, 14, 15,  0,  8, 13,  3, 12,  9,  7,  5, 10,  6,  1,</div>
<div class="line"><a name="l00428"></a><span class="lineno">  428</span>&#160;        13,  0, 11,  7,  4,  9,  1, 10, 14,  3,  5, 12,  2, 15,  8,  6,</div>
<div class="line"><a name="l00429"></a><span class="lineno">  429</span>&#160;         1,  4, 11, 13, 12,  3,  7, 14, 10, 15,  6,  8,  0,  5,  9,  2,</div>
<div class="line"><a name="l00430"></a><span class="lineno">  430</span>&#160;         6, 11, 13,  8,  1,  4, 10,  7,  9,  5,  0, 15, 14,  2,  3, 12,</div>
<div class="line"><a name="l00431"></a><span class="lineno">  431</span>&#160;    },</div>
<div class="line"><a name="l00432"></a><span class="lineno">  432</span>&#160;    {</div>
<div class="line"><a name="l00433"></a><span class="lineno">  433</span>&#160;                                        <span class="comment">/* S[8]                 */</span></div>
<div class="line"><a name="l00434"></a><span class="lineno">  434</span>&#160;        13,  2,  8,  4,  6, 15, 11,  1, 10,  9,  3, 14,  5,  0, 12,  7,</div>
<div class="line"><a name="l00435"></a><span class="lineno">  435</span>&#160;         1, 15, 13,  8, 10,  3,  7,  4, 12,  5,  6, 11,  0, 14,  9,  2,</div>
<div class="line"><a name="l00436"></a><span class="lineno">  436</span>&#160;         7, 11,  4,  1,  9, 12, 14,  2,  0,  6, 10, 13, 15,  3,  5,  8,</div>
<div class="line"><a name="l00437"></a><span class="lineno">  437</span>&#160;         2,  1, 14,  7,  4, 10,  8, 13, 15, 12,  9,  0,  3,  5,  6, 11,</div>
<div class="line"><a name="l00438"></a><span class="lineno">  438</span>&#160;    },</div>
<div class="line"><a name="l00439"></a><span class="lineno">  439</span>&#160;};</div>
<div class="line"><a name="l00440"></a><span class="lineno">  440</span>&#160;</div>
<div class="line"><a name="l00441"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#af24d6b29124568045885a69859ad56a8">  441</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#af24d6b29124568045885a69859ad56a8">P32Tr</a>[] = {        <span class="comment">/* 32-bit permutation function */</span></div>
<div class="line"><a name="l00442"></a><span class="lineno">  442</span>&#160;        16,  7, 20, 21,</div>
<div class="line"><a name="l00443"></a><span class="lineno">  443</span>&#160;        29, 12, 28, 17,</div>
<div class="line"><a name="l00444"></a><span class="lineno">  444</span>&#160;         1, 15, 23, 26,</div>
<div class="line"><a name="l00445"></a><span class="lineno">  445</span>&#160;         5, 18, 31, 10,</div>
<div class="line"><a name="l00446"></a><span class="lineno">  446</span>&#160;         2,  8, 24, 14,</div>
<div class="line"><a name="l00447"></a><span class="lineno">  447</span>&#160;        32, 27,  3,  9,</div>
<div class="line"><a name="l00448"></a><span class="lineno">  448</span>&#160;        19, 13, 30,  6,</div>
<div class="line"><a name="l00449"></a><span class="lineno">  449</span>&#160;        22, 11,  4, 25,</div>
<div class="line"><a name="l00450"></a><span class="lineno">  450</span>&#160;};</div>
<div class="line"><a name="l00451"></a><span class="lineno">  451</span>&#160;</div>
<div class="line"><a name="l00452"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ac5ce08a9d852fd1e1016698361b1ae8a">  452</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#ac5ce08a9d852fd1e1016698361b1ae8a">CIFP</a>[] = {         <span class="comment">/* compressed/interleaved permutation */</span></div>
<div class="line"><a name="l00453"></a><span class="lineno">  453</span>&#160;         1,  2,  3,  4,   17, 18, 19, 20,</div>
<div class="line"><a name="l00454"></a><span class="lineno">  454</span>&#160;         5,  6,  7,  8,   21, 22, 23, 24,</div>
<div class="line"><a name="l00455"></a><span class="lineno">  455</span>&#160;         9, 10, 11, 12,   25, 26, 27, 28,</div>
<div class="line"><a name="l00456"></a><span class="lineno">  456</span>&#160;        13, 14, 15, 16,   29, 30, 31, 32,</div>
<div class="line"><a name="l00457"></a><span class="lineno">  457</span>&#160;</div>
<div class="line"><a name="l00458"></a><span class="lineno">  458</span>&#160;        33, 34, 35, 36,   49, 50, 51, 52,</div>
<div class="line"><a name="l00459"></a><span class="lineno">  459</span>&#160;        37, 38, 39, 40,   53, 54, 55, 56,</div>
<div class="line"><a name="l00460"></a><span class="lineno">  460</span>&#160;        41, 42, 43, 44,   57, 58, 59, 60,</div>
<div class="line"><a name="l00461"></a><span class="lineno">  461</span>&#160;        45, 46, 47, 48,   61, 62, 63, 64,</div>
<div class="line"><a name="l00462"></a><span class="lineno">  462</span>&#160;};</div>
<div class="line"><a name="l00463"></a><span class="lineno">  463</span>&#160;</div>
<div class="line"><a name="l00464"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ae3e94e9dc24634a41777b3f79cbaf152">  464</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#ae3e94e9dc24634a41777b3f79cbaf152">itoa64</a>[] =         <span class="comment">/* 0..63 =&gt; ascii-64 */</span></div>
<div class="line"><a name="l00465"></a><span class="lineno">  465</span>&#160;        <span class="stringliteral">&quot;./0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz&quot;</span>;</div>
<div class="line"><a name="l00466"></a><span class="lineno">  466</span>&#160;</div>
<div class="line"><a name="l00467"></a><span class="lineno">  467</span>&#160;</div>
<div class="line"><a name="l00468"></a><span class="lineno">  468</span>&#160;<span class="comment">/* =====  Tables that are initialized at run time  ==================== */</span></div>
<div class="line"><a name="l00469"></a><span class="lineno">  469</span>&#160;</div>
<div class="line"><a name="l00470"></a><span class="lineno">  470</span>&#160;</div>
<div class="line"><a name="l00471"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a165a57131af55136a06ae73ff5de0d74">  471</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#a165a57131af55136a06ae73ff5de0d74">a64toi</a>[128];       <span class="comment">/* ascii-64 =&gt; 0..63 */</span></div>
<div class="line"><a name="l00472"></a><span class="lineno">  472</span>&#160;</div>
<div class="line"><a name="l00473"></a><span class="lineno">  473</span>&#160;<span class="comment">/* Initial key schedule permutation */</span></div>
<div class="line"><a name="l00474"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ac74af7e25757c0f4e0aac279b4fa9a6d">  474</a></span>&#160;<span class="keyword">static</span> <a class="code" href="../../df/da2/union_c__block.html">C_block</a>  <a class="code" href="../../d6/de3/crypt_8c.html#ac74af7e25757c0f4e0aac279b4fa9a6d">PC1ROT</a>[64/<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>][1&lt;&lt;<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>];</div>
<div class="line"><a name="l00475"></a><span class="lineno">  475</span>&#160;</div>
<div class="line"><a name="l00476"></a><span class="lineno">  476</span>&#160;<span class="comment">/* Subsequent key schedule rotation permutations */</span></div>
<div class="line"><a name="l00477"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a6c5e316784747b91ac3a602c26cedea0">  477</a></span>&#160;<span class="keyword">static</span> <a class="code" href="../../df/da2/union_c__block.html">C_block</a>  <a class="code" href="../../d6/de3/crypt_8c.html#a6c5e316784747b91ac3a602c26cedea0">PC2ROT</a>[2][64/<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>][1&lt;&lt;<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>];</div>
<div class="line"><a name="l00478"></a><span class="lineno">  478</span>&#160;</div>
<div class="line"><a name="l00479"></a><span class="lineno">  479</span>&#160;<span class="comment">/* Initial permutation/expansion table */</span></div>
<div class="line"><a name="l00480"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a29a66b01dcde739252b17b74247261c7">  480</a></span>&#160;<span class="keyword">static</span> <a class="code" href="../../df/da2/union_c__block.html">C_block</a>  <a class="code" href="../../d6/de3/crypt_8c.html#a29a66b01dcde739252b17b74247261c7">IE3264</a>[32/<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>][1&lt;&lt;<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>];</div>
<div class="line"><a name="l00481"></a><span class="lineno">  481</span>&#160;</div>
<div class="line"><a name="l00482"></a><span class="lineno">  482</span>&#160;<span class="comment">/* Table that combines the S, P, and E operations.  */</span></div>
<div class="line"><a name="l00483"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ad3fb9cc97dae7f6a4addf926032aa4a0">  483</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">long</span> <a class="code" href="../../d6/de3/crypt_8c.html#ad3fb9cc97dae7f6a4addf926032aa4a0">SPE</a>[2][8][64];</div>
<div class="line"><a name="l00484"></a><span class="lineno">  484</span>&#160;</div>
<div class="line"><a name="l00485"></a><span class="lineno">  485</span>&#160;<span class="comment">/* compressed/interleaved =&gt; final permutation table */</span></div>
<div class="line"><a name="l00486"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a1cae11ec4891641a52e3a8326d126924">  486</a></span>&#160;<span class="keyword">static</span> <a class="code" href="../../df/da2/union_c__block.html">C_block</a>  <a class="code" href="../../d6/de3/crypt_8c.html#a1cae11ec4891641a52e3a8326d126924">CF6464</a>[64/<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>][1&lt;&lt;<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>];</div>
<div class="line"><a name="l00487"></a><span class="lineno">  487</span>&#160;</div>
<div class="line"><a name="l00488"></a><span class="lineno">  488</span>&#160;</div>
<div class="line"><a name="l00489"></a><span class="lineno">  489</span>&#160;<span class="comment">/* ==================================== */</span></div>
<div class="line"><a name="l00490"></a><span class="lineno">  490</span>&#160;</div>
<div class="line"><a name="l00491"></a><span class="lineno">  491</span>&#160;</div>
<div class="line"><a name="l00492"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#af8856dca2c10738529739b7a65df2e87">  492</a></span>&#160;<span class="keyword">static</span> <a class="code" href="../../df/da2/union_c__block.html">C_block</a>  <a class="code" href="../../d6/de3/crypt_8c.html#af8856dca2c10738529739b7a65df2e87">constdatablock</a>;                 <span class="comment">/* encryption constant */</span></div>
<div class="line"><a name="l00493"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ade137bb0251cdfb9c60e29e405efe2e2">  493</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">char</span>     <a class="code" href="../../d6/de3/crypt_8c.html#ade137bb0251cdfb9c60e29e405efe2e2">cryptresult</a>[1+4+4+11+1];        <span class="comment">/* encrypted result */</span></div>
<div class="line"><a name="l00494"></a><span class="lineno">  494</span>&#160;</div>
<div class="line"><a name="l00495"></a><span class="lineno">  495</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00496"></a><span class="lineno">  496</span>&#160;<span class="comment"> * Return a pointer to static data consisting of the &quot;setting&quot;</span></div>
<div class="line"><a name="l00497"></a><span class="lineno">  497</span>&#160;<span class="comment"> * followed by an encryption produced by the &quot;key&quot; and &quot;setting&quot;.</span></div>
<div class="line"><a name="l00498"></a><span class="lineno">  498</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00499"></a><span class="lineno">  499</span>&#160;<span class="keywordtype">char</span> *</div>
<div class="line"><a name="l00500"></a><span class="lineno">  500</span>&#160;<a class="code" href="../../d3/d90/missing_8h.html#a47fa3eb2086507cf2eb232be5379841c">crypt</a>(<a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>, <a class="code" href="../../d6/de3/crypt_8c.html#a34b754e74efdb8dcb9b6043233bfb2df">setting</a>)</div>
<div class="line"><a name="l00501"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a990c8aa5eb0c5fc709da3ab410d28104">  501</a></span>&#160;        register <a class="code" href="../../d8/d4e/strftime_8c.html#a2c212835823e3c54a8ab6d95c652660e">const</a> <span class="keywordtype">char</span> *<a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>;</div>
<div class="line"><a name="l00502"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a34b754e74efdb8dcb9b6043233bfb2df">  502</a></span>&#160;        register <a class="code" href="../../d8/d4e/strftime_8c.html#a2c212835823e3c54a8ab6d95c652660e">const</a> <span class="keywordtype">char</span> *<a class="code" href="../../d6/de3/crypt_8c.html#a34b754e74efdb8dcb9b6043233bfb2df">setting</a>;</div>
<div class="line"><a name="l00503"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a8049b7300164a52c90d26573e1e0c4f1">  503</a></span>&#160;{</div>
<div class="line"><a name="l00504"></a><span class="lineno">  504</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">char</span> *<a class="code" href="../../d6/de3/crypt_8c.html#a68746f7aa4b680a43bfd8e327d4340bb">encp</a>;</div>
<div class="line"><a name="l00505"></a><span class="lineno">  505</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">long</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00506"></a><span class="lineno">  506</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">int</span> <a class="code" href="../../d5/d11/ripper_8c.html#a93ca48b6ca5634eebe9872b8dc2650ee">t</a>;</div>
<div class="line"><a name="l00507"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#af437ed9a79a4001148d8edae7baeadee">  507</a></span>&#160;        <span class="keywordtype">long</span> <a class="code" href="../../d6/de3/crypt_8c.html#af437ed9a79a4001148d8edae7baeadee">salt</a>;</div>
<div class="line"><a name="l00508"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a8fbee099f20911d69a39d82e6fcac459">  508</a></span>&#160;        <span class="keywordtype">int</span> <a class="code" href="../../d6/de3/crypt_8c.html#aec2269ddcef2faf5f35a7257ba3b8f0b">num_iter</a>, <a class="code" href="../../d6/de3/crypt_8c.html#a8fbee099f20911d69a39d82e6fcac459">salt_size</a>;</div>
<div class="line"><a name="l00509"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a0500d1419552f2e99e1e896e6d6adfba">  509</a></span>&#160;        <a class="code" href="../../df/da2/union_c__block.html">C_block</a> <a class="code" href="../../d6/de3/crypt_8c.html#a6702f12a379cd011a0e99d5c863c484a">keyblock</a>, <a class="code" href="../../d6/de3/crypt_8c.html#a0500d1419552f2e99e1e896e6d6adfba">rsltblock</a>;</div>
<div class="line"><a name="l00510"></a><span class="lineno">  510</span>&#160;</div>
<div class="line"><a name="l00511"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#af92ff103638d1c64d71a208621495bd7">  511</a></span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; 8; i++) {</div>
<div class="line"><a name="l00512"></a><span class="lineno">  512</span>&#160;                <span class="keywordflow">if</span> ((t = 2*(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>)(*key)) != 0)</div>
<div class="line"><a name="l00513"></a><span class="lineno">  513</span>&#160;                        key++;</div>
<div class="line"><a name="l00514"></a><span class="lineno">  514</span>&#160;                keyblock.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>] = <a class="code" href="../../d5/d11/ripper_8c.html#a93ca48b6ca5634eebe9872b8dc2650ee">t</a>;</div>
<div class="line"><a name="l00515"></a><span class="lineno">  515</span>&#160;        }</div>
<div class="line"><a name="l00516"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a9016ca722e4970ecd6a384152c2ea1fd">  516</a></span>&#160;        <span class="keywordflow">if</span> (<a class="code" href="../../d6/de3/crypt_8c.html#a654d8b345f7098c1108e712985321c3c">des_setkey</a>((<span class="keywordtype">char</span> *)keyblock.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>))     <span class="comment">/* also initializes &quot;a64toi&quot; */</span></div>
<div class="line"><a name="l00517"></a><span class="lineno">  517</span>&#160;                <span class="keywordflow">return</span> (<a class="code" href="../../dd/dfb/yaml2byte_8c.html#ad0b08ddfcb8010b1d73d9d635d5e0201">NULL</a>);</div>
<div class="line"><a name="l00518"></a><span class="lineno">  518</span>&#160;</div>
<div class="line"><a name="l00519"></a><span class="lineno">  519</span>&#160;        encp = &amp;cryptresult[0];</div>
<div class="line"><a name="l00520"></a><span class="lineno">  520</span>&#160;        <span class="keywordflow">switch</span> (*setting) {</div>
<div class="line"><a name="l00521"></a><span class="lineno">  521</span>&#160;        <span class="keywordflow">case</span> <a class="code" href="../../d6/de3/crypt_8c.html#a916ed973888ae694d78cbe3097e10f0f">_PASSWORD_EFMT1</a>:</div>
<div class="line"><a name="l00522"></a><span class="lineno">  522</span>&#160;                <span class="comment">/*</span></div>
<div class="line"><a name="l00523"></a><span class="lineno">  523</span>&#160;<span class="comment">                 * Involve the rest of the password 8 characters at a time.</span></div>
<div class="line"><a name="l00524"></a><span class="lineno">  524</span>&#160;<span class="comment">                 */</span></div>
<div class="line"><a name="l00525"></a><span class="lineno">  525</span>&#160;                <span class="keywordflow">while</span> (*key) {</div>
<div class="line"><a name="l00526"></a><span class="lineno">  526</span>&#160;                        <span class="keywordflow">if</span> (<a class="code" href="../../d6/de3/crypt_8c.html#a5c9b491358c3434f273b874b413afb09">des_cipher</a>((<span class="keywordtype">char</span> *)&amp;keyblock,</div>
<div class="line"><a name="l00527"></a><span class="lineno">  527</span>&#160;                            (<span class="keywordtype">char</span> *)&amp;keyblock, 0L, 1))</div>
<div class="line"><a name="l00528"></a><span class="lineno">  528</span>&#160;                                <span class="keywordflow">return</span> (<a class="code" href="../../dd/dfb/yaml2byte_8c.html#ad0b08ddfcb8010b1d73d9d635d5e0201">NULL</a>);</div>
<div class="line"><a name="l00529"></a><span class="lineno">  529</span>&#160;                        <span class="keywordflow">for</span> (i = 0; i &lt; 8; i++) {</div>
<div class="line"><a name="l00530"></a><span class="lineno">  530</span>&#160;                                <span class="keywordflow">if</span> ((t = 2*(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>)(*key)) != 0)</div>
<div class="line"><a name="l00531"></a><span class="lineno">  531</span>&#160;                                        key++;</div>
<div class="line"><a name="l00532"></a><span class="lineno">  532</span>&#160;                                keyblock.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>] ^= <a class="code" href="../../d5/d11/ripper_8c.html#a93ca48b6ca5634eebe9872b8dc2650ee">t</a>;</div>
<div class="line"><a name="l00533"></a><span class="lineno">  533</span>&#160;                        }</div>
<div class="line"><a name="l00534"></a><span class="lineno">  534</span>&#160;                        <span class="keywordflow">if</span> (<a class="code" href="../../d6/de3/crypt_8c.html#a654d8b345f7098c1108e712985321c3c">des_setkey</a>((<span class="keywordtype">char</span> *)keyblock.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>))</div>
<div class="line"><a name="l00535"></a><span class="lineno">  535</span>&#160;                                <span class="keywordflow">return</span> (<a class="code" href="../../dd/dfb/yaml2byte_8c.html#ad0b08ddfcb8010b1d73d9d635d5e0201">NULL</a>);</div>
<div class="line"><a name="l00536"></a><span class="lineno">  536</span>&#160;                }</div>
<div class="line"><a name="l00537"></a><span class="lineno">  537</span>&#160;</div>
<div class="line"><a name="l00538"></a><span class="lineno">  538</span>&#160;                *encp++ = *setting++;</div>
<div class="line"><a name="l00539"></a><span class="lineno">  539</span>&#160;</div>
<div class="line"><a name="l00540"></a><span class="lineno">  540</span>&#160;                <span class="comment">/* get iteration count */</span></div>
<div class="line"><a name="l00541"></a><span class="lineno">  541</span>&#160;                num_iter = 0;</div>
<div class="line"><a name="l00542"></a><span class="lineno">  542</span>&#160;                <span class="keywordflow">for</span> (i = 4; --i &gt;= 0; ) {</div>
<div class="line"><a name="l00543"></a><span class="lineno">  543</span>&#160;                        <span class="keywordflow">if</span> ((t = (<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>)setting[i]) == <span class="charliteral">&#39;\0&#39;</span>)</div>
<div class="line"><a name="l00544"></a><span class="lineno">  544</span>&#160;                                t = <span class="charliteral">&#39;.&#39;</span>;</div>
<div class="line"><a name="l00545"></a><span class="lineno">  545</span>&#160;                        encp[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>] = <a class="code" href="../../d5/d11/ripper_8c.html#a93ca48b6ca5634eebe9872b8dc2650ee">t</a>;</div>
<div class="line"><a name="l00546"></a><span class="lineno">  546</span>&#160;                        num_iter = (num_iter&lt;&lt;6) | a64toi[t];</div>
<div class="line"><a name="l00547"></a><span class="lineno">  547</span>&#160;                }</div>
<div class="line"><a name="l00548"></a><span class="lineno">  548</span>&#160;                setting += 4;</div>
<div class="line"><a name="l00549"></a><span class="lineno">  549</span>&#160;                encp += 4;</div>
<div class="line"><a name="l00550"></a><span class="lineno">  550</span>&#160;                salt_size = 4;</div>
<div class="line"><a name="l00551"></a><span class="lineno">  551</span>&#160;                <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00552"></a><span class="lineno">  552</span>&#160;        <span class="keywordflow">default</span>:</div>
<div class="line"><a name="l00553"></a><span class="lineno">  553</span>&#160;                num_iter = 25;</div>
<div class="line"><a name="l00554"></a><span class="lineno">  554</span>&#160;                salt_size = 2;</div>
<div class="line"><a name="l00555"></a><span class="lineno">  555</span>&#160;        }</div>
<div class="line"><a name="l00556"></a><span class="lineno">  556</span>&#160;</div>
<div class="line"><a name="l00557"></a><span class="lineno">  557</span>&#160;        salt = 0;</div>
<div class="line"><a name="l00558"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a7ff3868d9df29286fab7055400e2b057">  558</a></span>&#160;        <span class="keywordflow">for</span> (i = salt_size; --i &gt;= 0; ) {</div>
<div class="line"><a name="l00559"></a><span class="lineno">  559</span>&#160;                <span class="keywordflow">if</span> ((t = (<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>)setting[i]) == <span class="charliteral">&#39;\0&#39;</span>)</div>
<div class="line"><a name="l00560"></a><span class="lineno">  560</span>&#160;                        t = <span class="charliteral">&#39;.&#39;</span>;</div>
<div class="line"><a name="l00561"></a><span class="lineno">  561</span>&#160;                encp[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>] = <a class="code" href="../../d5/d11/ripper_8c.html#a93ca48b6ca5634eebe9872b8dc2650ee">t</a>;</div>
<div class="line"><a name="l00562"></a><span class="lineno">  562</span>&#160;                salt = (salt&lt;&lt;6) | a64toi[t];</div>
<div class="line"><a name="l00563"></a><span class="lineno">  563</span>&#160;        }</div>
<div class="line"><a name="l00564"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a68746f7aa4b680a43bfd8e327d4340bb">  564</a></span>&#160;        encp += <a class="code" href="../../d6/de3/crypt_8c.html#a8fbee099f20911d69a39d82e6fcac459">salt_size</a>;</div>
<div class="line"><a name="l00565"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#aecc97a2a164c21913529e3d4324fe1a4">  565</a></span>&#160;        <span class="keywordflow">if</span> (<a class="code" href="../../d6/de3/crypt_8c.html#a5c9b491358c3434f273b874b413afb09">des_cipher</a>((<span class="keywordtype">char</span> *)&amp;<a class="code" href="../../d6/de3/crypt_8c.html#af8856dca2c10738529739b7a65df2e87">constdatablock</a>, (<span class="keywordtype">char</span> *)&amp;rsltblock,</div>
<div class="line"><a name="l00566"></a><span class="lineno">  566</span>&#160;            salt, num_iter))</div>
<div class="line"><a name="l00567"></a><span class="lineno">  567</span>&#160;                <span class="keywordflow">return</span> (<a class="code" href="../../dd/dfb/yaml2byte_8c.html#ad0b08ddfcb8010b1d73d9d635d5e0201">NULL</a>);</div>
<div class="line"><a name="l00568"></a><span class="lineno">  568</span>&#160;</div>
<div class="line"><a name="l00569"></a><span class="lineno">  569</span>&#160;        <span class="comment">/*</span></div>
<div class="line"><a name="l00570"></a><span class="lineno">  570</span>&#160;<span class="comment">         * Encode the 64 cipher bits as 11 ascii characters.</span></div>
<div class="line"><a name="l00571"></a><span class="lineno">  571</span>&#160;<span class="comment">         */</span></div>
<div class="line"><a name="l00572"></a><span class="lineno">  572</span>&#160;        i = ((<a class="code" href="../../d3/d15/name2ctype_8h.html#a86f2415763322050063a5502f87c9422">long</a>)((rsltblock.b[0]&lt;&lt;8) | rsltblock.b[1])&lt;&lt;8) | rsltblock.b[2];</div>
<div class="line"><a name="l00573"></a><span class="lineno">  573</span>&#160;        encp[3] = itoa64[i&amp;0x3f];       i &gt;&gt;= 6;</div>
<div class="line"><a name="l00574"></a><span class="lineno">  574</span>&#160;        encp[2] = itoa64[i&amp;0x3f];       i &gt;&gt;= 6;</div>
<div class="line"><a name="l00575"></a><span class="lineno">  575</span>&#160;        encp[1] = itoa64[i&amp;0x3f];       i &gt;&gt;= 6;</div>
<div class="line"><a name="l00576"></a><span class="lineno">  576</span>&#160;        encp[0] = itoa64[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>];            encp += 4;</div>
<div class="line"><a name="l00577"></a><span class="lineno">  577</span>&#160;        i = ((<a class="code" href="../../d3/d15/name2ctype_8h.html#a86f2415763322050063a5502f87c9422">long</a>)((rsltblock.b[3]&lt;&lt;8) | rsltblock.b[4])&lt;&lt;8) | rsltblock.b[5];</div>
<div class="line"><a name="l00578"></a><span class="lineno">  578</span>&#160;        encp[3] = itoa64[i&amp;0x3f];       i &gt;&gt;= 6;</div>
<div class="line"><a name="l00579"></a><span class="lineno">  579</span>&#160;        encp[2] = itoa64[i&amp;0x3f];       i &gt;&gt;= 6;</div>
<div class="line"><a name="l00580"></a><span class="lineno">  580</span>&#160;        encp[1] = itoa64[i&amp;0x3f];       i &gt;&gt;= 6;</div>
<div class="line"><a name="l00581"></a><span class="lineno">  581</span>&#160;        encp[0] = itoa64[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>];            encp += 4;</div>
<div class="line"><a name="l00582"></a><span class="lineno">  582</span>&#160;        i = ((<a class="code" href="../../d3/d15/name2ctype_8h.html#a86f2415763322050063a5502f87c9422">long</a>)((rsltblock.b[6])&lt;&lt;8) | rsltblock.b[7])&lt;&lt;2;</div>
<div class="line"><a name="l00583"></a><span class="lineno">  583</span>&#160;        encp[2] = itoa64[i&amp;0x3f];       i &gt;&gt;= 6;</div>
<div class="line"><a name="l00584"></a><span class="lineno">  584</span>&#160;        encp[1] = itoa64[i&amp;0x3f];       i &gt;&gt;= 6;</div>
<div class="line"><a name="l00585"></a><span class="lineno">  585</span>&#160;        encp[0] = itoa64[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>];</div>
<div class="line"><a name="l00586"></a><span class="lineno">  586</span>&#160;</div>
<div class="line"><a name="l00587"></a><span class="lineno">  587</span>&#160;        encp[3] = 0;</div>
<div class="line"><a name="l00588"></a><span class="lineno">  588</span>&#160;</div>
<div class="line"><a name="l00589"></a><span class="lineno">  589</span>&#160;        <span class="keywordflow">return</span> (cryptresult);</div>
<div class="line"><a name="l00590"></a><span class="lineno">  590</span>&#160;}</div>
<div class="line"><a name="l00591"></a><span class="lineno">  591</span>&#160;</div>
<div class="line"><a name="l00592"></a><span class="lineno">  592</span>&#160;</div>
<div class="line"><a name="l00593"></a><span class="lineno">  593</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00594"></a><span class="lineno">  594</span>&#160;<span class="comment"> * The Key Schedule, filled in by des_setkey() or setkey().</span></div>
<div class="line"><a name="l00595"></a><span class="lineno">  595</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00596"></a><span class="lineno">  596</span>&#160;<span class="preprocessor">#define KS_SIZE 16</span></div>
<div class="line"><a name="l00597"></a><span class="lineno">  597</span>&#160;<span class="preprocessor"></span><span class="keyword">static</span> <a class="code" href="../../df/da2/union_c__block.html">C_block</a>  KS[<a class="code" href="../../d6/de3/crypt_8c.html#a136f3095237ae23358c30581753e4178">KS_SIZE</a>];</div>
<div class="line"><a name="l00598"></a><span class="lineno">  598</span>&#160;</div>
<div class="line"><a name="l00599"></a><span class="lineno">  599</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00600"></a><span class="lineno">  600</span>&#160;<span class="comment"> * Set up the key schedule from the key.</span></div>
<div class="line"><a name="l00601"></a><span class="lineno">  601</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00602"></a><span class="lineno">  602</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00603"></a><span class="lineno">  603</span>&#160;<a class="code" href="../../d6/de3/crypt_8c.html#a654d8b345f7098c1108e712985321c3c">des_setkey</a>(key)</div>
<div class="line"><a name="l00604"></a><span class="lineno">  604</span>&#160;        register <a class="code" href="../../d8/d4e/strftime_8c.html#a2c212835823e3c54a8ab6d95c652660e">const</a> <span class="keywordtype">char</span> *key;</div>
<div class="line"><a name="l00605"></a><span class="lineno">  605</span>&#160;{</div>
<div class="line"><a name="l00606"></a><span class="lineno">  606</span>&#160;        <span class="keyword">register</span> <a class="code" href="../../d6/de3/crypt_8c.html#a2c844749684bfce83e662dee88390dc9">DCL_BLOCK</a>(K, K0, K1);</div>
<div class="line"><a name="l00607"></a><span class="lineno">  607</span>&#160;        <span class="keyword">register</span> <a class="code" href="../../df/da2/union_c__block.html">C_block</a> *ptabp;</div>
<div class="line"><a name="l00608"></a><span class="lineno">  608</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">int</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00609"></a><span class="lineno">  609</span>&#160;        <span class="keyword">static</span> <span class="keywordtype">int</span> des_ready = 0;</div>
<div class="line"><a name="l00610"></a><span class="lineno">  610</span>&#160;</div>
<div class="line"><a name="l00611"></a><span class="lineno">  611</span>&#160;        <span class="keywordflow">if</span> (!des_ready) {</div>
<div class="line"><a name="l00612"></a><span class="lineno">  612</span>&#160;                <a class="code" href="../../d6/de3/crypt_8c.html#aa2378a0e5d6788c77c9e719ecb0291a0">init_des</a>();</div>
<div class="line"><a name="l00613"></a><span class="lineno">  613</span>&#160;                des_ready = 1;</div>
<div class="line"><a name="l00614"></a><span class="lineno">  614</span>&#160;        }</div>
<div class="line"><a name="l00615"></a><span class="lineno">  615</span>&#160;</div>
<div class="line"><a name="l00616"></a><span class="lineno">  616</span>&#160;        <a class="code" href="../../d6/de3/crypt_8c.html#a2d3c04b14357f1839a3e32c88312e15f">PERM6464</a>(K,K0,K1,(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *)key,(<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)PC1ROT);</div>
<div class="line"><a name="l00617"></a><span class="lineno">  617</span>&#160;        key = (<span class="keywordtype">char</span> *)&amp;KS[0];</div>
<div class="line"><a name="l00618"></a><span class="lineno">  618</span>&#160;        <a class="code" href="../../d6/de3/crypt_8c.html#ad50d91202186ced15ec3fc3a922506b3">STORE</a>(K&amp;~0x03030303L, K0&amp;~0x03030303L, K1, *(<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)key);</div>
<div class="line"><a name="l00619"></a><span class="lineno">  619</span>&#160;        <span class="keywordflow">for</span> (i = 1; i &lt; 16; i++) {</div>
<div class="line"><a name="l00620"></a><span class="lineno">  620</span>&#160;                key += <span class="keyword">sizeof</span>(<a class="code" href="../../df/da2/union_c__block.html">C_block</a>);</div>
<div class="line"><a name="l00621"></a><span class="lineno">  621</span>&#160;                <a class="code" href="../../d6/de3/crypt_8c.html#ad50d91202186ced15ec3fc3a922506b3">STORE</a>(K,K0,K1,*(<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)key);</div>
<div class="line"><a name="l00622"></a><span class="lineno">  622</span>&#160;                ptabp = (<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)PC2ROT[Rotates[i]-1];</div>
<div class="line"><a name="l00623"></a><span class="lineno">  623</span>&#160;                <a class="code" href="../../d6/de3/crypt_8c.html#a2d3c04b14357f1839a3e32c88312e15f">PERM6464</a>(K,K0,K1,(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *)key,ptabp);</div>
<div class="line"><a name="l00624"></a><span class="lineno">  624</span>&#160;                <a class="code" href="../../d6/de3/crypt_8c.html#ad50d91202186ced15ec3fc3a922506b3">STORE</a>(K&amp;~0x03030303L, K0&amp;~0x03030303L, K1, *(<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)key);</div>
<div class="line"><a name="l00625"></a><span class="lineno">  625</span>&#160;        }</div>
<div class="line"><a name="l00626"></a><span class="lineno">  626</span>&#160;        <span class="keywordflow">return</span> (0);</div>
<div class="line"><a name="l00627"></a><span class="lineno">  627</span>&#160;}</div>
<div class="line"><a name="l00628"></a><span class="lineno">  628</span>&#160;</div>
<div class="line"><a name="l00629"></a><span class="lineno">  629</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00630"></a><span class="lineno">  630</span>&#160;<span class="comment"> * Encrypt (or decrypt if num_iter &lt; 0) the 8 chars at &quot;in&quot; with abs(num_iter)</span></div>
<div class="line"><a name="l00631"></a><span class="lineno">  631</span>&#160;<span class="comment"> * iterations of DES, using the the given 24-bit salt and the pre-computed key</span></div>
<div class="line"><a name="l00632"></a><span class="lineno">  632</span>&#160;<span class="comment"> * schedule, and store the resulting 8 chars at &quot;out&quot; (in == out is permitted).</span></div>
<div class="line"><a name="l00633"></a><span class="lineno">  633</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00634"></a><span class="lineno">  634</span>&#160;<span class="comment"> * NOTE: the performance of this routine is critically dependent on your</span></div>
<div class="line"><a name="l00635"></a><span class="lineno">  635</span>&#160;<span class="comment"> * compiler and machine architecture.</span></div>
<div class="line"><a name="l00636"></a><span class="lineno">  636</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00637"></a><span class="lineno">  637</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00638"></a><span class="lineno">  638</span>&#160;<a class="code" href="../../d6/de3/crypt_8c.html#a5c9b491358c3434f273b874b413afb09">des_cipher</a>(<a class="code" href="../../d6/de3/crypt_8c.html#af37fdeb6d61d15736ead54f1b8a6df3a">in</a>, out, salt, num_iter)</div>
<div class="line"><a name="l00639"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#af37fdeb6d61d15736ead54f1b8a6df3a">  639</a></span>&#160;        <a class="code" href="../../d8/d4e/strftime_8c.html#a2c212835823e3c54a8ab6d95c652660e">const</a> <span class="keywordtype">char</span> *<a class="code" href="../../d6/de3/crypt_8c.html#af37fdeb6d61d15736ead54f1b8a6df3a">in</a>;</div>
<div class="line"><a name="l00640"></a><span class="lineno">  640</span>&#160;        <span class="keywordtype">char</span> *out;</div>
<div class="line"><a name="l00641"></a><span class="lineno">  641</span>&#160;        <span class="keywordtype">long</span> salt;</div>
<div class="line"><a name="l00642"></a><span class="lineno">  642</span>&#160;        <span class="keywordtype">int</span> num_iter;</div>
<div class="line"><a name="l00643"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a72044a36b6c9a9a7c8381c2df90d1ae7">  643</a></span>&#160;{</div>
<div class="line"><a name="l00644"></a><span class="lineno">  644</span>&#160;        <span class="comment">/* variables that we want in registers, most important first */</span></div>
<div class="line"><a name="l00645"></a><span class="lineno">  645</span>&#160;<span class="preprocessor">#if defined(pdp11)</span></div>
<div class="line"><a name="l00646"></a><span class="lineno">  646</span>&#160;<span class="preprocessor"></span>        <span class="keyword">register</span> <span class="keywordtype">int</span> j;</div>
<div class="line"><a name="l00647"></a><span class="lineno">  647</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00648"></a><span class="lineno">  648</span>&#160;<span class="preprocessor"></span>        <span class="keyword">register</span> <span class="keywordtype">long</span> <a class="code" href="../../d6/de3/crypt_8c.html#a65462adaaad855ead567351e0c8475c4">L0</a>, <a class="code" href="../../d6/de3/crypt_8c.html#a9407b59ea8a359bef2f97830a5aebc08">L1</a>, <a class="code" href="../../d2/d24/sha1_8c.html#a8ac24a09e1273548828d3cc9436f9bc7">R0</a>, <a class="code" href="../../d6/de3/crypt_8c.html#a81031dcd5c94ba95ab1de0ffe6a97bbf">R1</a>, k;</div>
<div class="line"><a name="l00649"></a><span class="lineno">  649</span>&#160;        <span class="keyword">register</span> <a class="code" href="../../df/da2/union_c__block.html">C_block</a> *<a class="code" href="../../d6/de3/crypt_8c.html#a72044a36b6c9a9a7c8381c2df90d1ae7">kp</a>;</div>
<div class="line"><a name="l00650"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a8500a318327bde6daa31a9a14396c075">  650</a></span>&#160;        <span class="keyword">register</span> <span class="keywordtype">int</span> <a class="code" href="../../d6/de3/crypt_8c.html#aa63fb92fcb3fdd61c86dc0e0ee707a0e">ks_inc</a>, <a class="code" href="../../d6/de3/crypt_8c.html#a8500a318327bde6daa31a9a14396c075">loop_count</a>;</div>
<div class="line"><a name="l00651"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a74f47ef83df9b0d710c651e9f6ea594f">  651</a></span>&#160;        <a class="code" href="../../df/da2/union_c__block.html">C_block</a> <a class="code" href="../../d6/de3/crypt_8c.html#a74f47ef83df9b0d710c651e9f6ea594f">B</a>;</div>
<div class="line"><a name="l00652"></a><span class="lineno">  652</span>&#160;</div>
<div class="line"><a name="l00653"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a65462adaaad855ead567351e0c8475c4">  653</a></span>&#160;        L0 = <a class="code" href="../../d6/de3/crypt_8c.html#af437ed9a79a4001148d8edae7baeadee">salt</a>;</div>
<div class="line"><a name="l00654"></a><span class="lineno">  654</span>&#160;        <a class="code" href="../../d6/de3/crypt_8c.html#a1a1902080cb6a4fb4caa7affb5cebb51">TO_SIX_BIT</a>(salt, L0);   <span class="comment">/* convert to 4*(6+2) format */</span></div>
<div class="line"><a name="l00655"></a><span class="lineno">  655</span>&#160;</div>
<div class="line"><a name="l00656"></a><span class="lineno">  656</span>&#160;<span class="preprocessor">#if defined(vax) || defined(pdp11)</span></div>
<div class="line"><a name="l00657"></a><span class="lineno">  657</span>&#160;<span class="preprocessor"></span>        salt = ~salt;   <span class="comment">/* &quot;x &amp;~ y&quot; is faster than &quot;x &amp; y&quot;. */</span></div>
<div class="line"><a name="l00658"></a><span class="lineno">  658</span>&#160;<span class="preprocessor">#define SALT (~salt)</span></div>
<div class="line"><a name="l00659"></a><span class="lineno">  659</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l00660"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ae908f2f4596121d74b000a293905a920">  660</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define SALT salt</span></div>
<div class="line"><a name="l00661"></a><span class="lineno">  661</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00662"></a><span class="lineno">  662</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00663"></a><span class="lineno">  663</span>&#160;<span class="preprocessor">#if defined(MUST_ALIGN)</span></div>
<div class="line"><a name="l00664"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a9e97b9a5a14bd16d8f52b8afbde48c21">  664</a></span>&#160;<span class="preprocessor"></span>        B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[0] = in[0]; B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[1] = in[1]; B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[2] = in[2]; B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[3] = in[3];</div>
<div class="line"><a name="l00665"></a><span class="lineno">  665</span>&#160;        B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[4] = in[4]; B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[5] = in[5]; B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[6] = in[6]; B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[7] = in[7];</div>
<div class="line"><a name="l00666"></a><span class="lineno">  666</span>&#160;        <a class="code" href="../../d6/de3/crypt_8c.html#a1b207183df3765ba2eabb5562da72158">LOAD</a>(L,L0,L1,B);</div>
<div class="line"><a name="l00667"></a><span class="lineno">  667</span>&#160;<span class="preprocessor">#else</span></div>
<div class="line"><a name="l00668"></a><span class="lineno">  668</span>&#160;<span class="preprocessor"></span>        <a class="code" href="../../d6/de3/crypt_8c.html#a1b207183df3765ba2eabb5562da72158">LOAD</a>(L,L0,L1,*(<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)in);</div>
<div class="line"><a name="l00669"></a><span class="lineno">  669</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00670"></a><span class="lineno">  670</span>&#160;<span class="preprocessor"></span>        <a class="code" href="../../d6/de3/crypt_8c.html#ab644f676d8d67d6265407b73d33a647d">LOADREG</a>(<a class="code" href="../../d3/d80/sha2_8c.html#af299e0982ce71aad5027c4a7315e536f">R</a>,R0,R1,L,L0,L1);</div>
<div class="line"><a name="l00671"></a><span class="lineno">  671</span>&#160;        L0 &amp;= 0x55555555L;</div>
<div class="line"><a name="l00672"></a><span class="lineno">  672</span>&#160;        L1 &amp;= 0x55555555L;</div>
<div class="line"><a name="l00673"></a><span class="lineno">  673</span>&#160;        L0 = (L0 &lt;&lt; 1) | L1;    <span class="comment">/* L0 is the even-numbered input bits */</span></div>
<div class="line"><a name="l00674"></a><span class="lineno">  674</span>&#160;        R0 &amp;= 0xaaaaaaaaL;</div>
<div class="line"><a name="l00675"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a81031dcd5c94ba95ab1de0ffe6a97bbf">  675</a></span>&#160;        R1 = (R1 &gt;&gt; 1) &amp; 0x55555555L;</div>
<div class="line"><a name="l00676"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a9407b59ea8a359bef2f97830a5aebc08">  676</a></span>&#160;        L1 = R0 | <a class="code" href="../../d6/de3/crypt_8c.html#a81031dcd5c94ba95ab1de0ffe6a97bbf">R1</a>;           <span class="comment">/* L1 is the odd-numbered input bits */</span></div>
<div class="line"><a name="l00677"></a><span class="lineno">  677</span>&#160;        <a class="code" href="../../d6/de3/crypt_8c.html#ad50d91202186ced15ec3fc3a922506b3">STORE</a>(L,L0,L1,B);</div>
<div class="line"><a name="l00678"></a><span class="lineno">  678</span>&#160;        <a class="code" href="../../d6/de3/crypt_8c.html#a46df822e601f80265b7348b8fa89ed36">PERM3264</a>(L,L0,L1,B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>,  (<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)IE3264);      <span class="comment">/* even bits */</span></div>
<div class="line"><a name="l00679"></a><span class="lineno">  679</span>&#160;        <a class="code" href="../../d6/de3/crypt_8c.html#a46df822e601f80265b7348b8fa89ed36">PERM3264</a>(<a class="code" href="../../d3/d80/sha2_8c.html#af299e0982ce71aad5027c4a7315e536f">R</a>,R0,R1,B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>+4,(<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)IE3264);      <span class="comment">/* odd bits */</span></div>
<div class="line"><a name="l00680"></a><span class="lineno">  680</span>&#160;</div>
<div class="line"><a name="l00681"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#acffd192bc38dc3e58fe4ccd6ea3edb23">  681</a></span>&#160;        <span class="keywordflow">if</span> (num_iter &gt;= 0)</div>
<div class="line"><a name="l00682"></a><span class="lineno">  682</span>&#160;        {               <span class="comment">/* encryption */</span></div>
<div class="line"><a name="l00683"></a><span class="lineno">  683</span>&#160;                kp = &amp;KS[0];</div>
<div class="line"><a name="l00684"></a><span class="lineno">  684</span>&#160;                ks_inc  = (<a class="code" href="../../de/d07/bigdecimal_8c.html#accd5e629f58868c52137db996aaf8b83">int</a>)<span class="keyword">sizeof</span>(*kp);</div>
<div class="line"><a name="l00685"></a><span class="lineno">  685</span>&#160;        }</div>
<div class="line"><a name="l00686"></a><span class="lineno">  686</span>&#160;        <span class="keywordflow">else</span></div>
<div class="line"><a name="l00687"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a0544c3fe466e421738dae463968b70ba">  687</a></span>&#160;        {               <span class="comment">/* decryption */</span></div>
<div class="line"><a name="l00688"></a><span class="lineno">  688</span>&#160;                num_iter = -<a class="code" href="../../d6/de3/crypt_8c.html#aec2269ddcef2faf5f35a7257ba3b8f0b">num_iter</a>;</div>
<div class="line"><a name="l00689"></a><span class="lineno">  689</span>&#160;                kp = &amp;KS[<a class="code" href="../../d6/de3/crypt_8c.html#a136f3095237ae23358c30581753e4178">KS_SIZE</a>-1];</div>
<div class="line"><a name="l00690"></a><span class="lineno">  690</span>&#160;                ks_inc  = -(<a class="code" href="../../de/d07/bigdecimal_8c.html#accd5e629f58868c52137db996aaf8b83">int</a>)<span class="keyword">sizeof</span>(*kp);</div>
<div class="line"><a name="l00691"></a><span class="lineno">  691</span>&#160;        }</div>
<div class="line"><a name="l00692"></a><span class="lineno">  692</span>&#160;</div>
<div class="line"><a name="l00693"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#a9b6623881078077369e8cc5d762f9b9d">  693</a></span>&#160;        <span class="keywordflow">while</span> (--num_iter &gt;= 0) {</div>
<div class="line"><a name="l00694"></a><span class="lineno">  694</span>&#160;                loop_count = 8;</div>
<div class="line"><a name="l00695"></a><span class="lineno">  695</span>&#160;                <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l00696"></a><span class="lineno">  696</span>&#160;</div>
<div class="line"><a name="l00697"></a><span class="lineno">  697</span>&#160;<span class="preprocessor">#define SPTAB(t, i)     (*(long *)((unsigned char *)(t) + (i)*(sizeof(long)/4)))</span></div>
<div class="line"><a name="l00698"></a><span class="lineno">  698</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if defined(gould)</span></div>
<div class="line"><a name="l00699"></a><span class="lineno">  699</span>&#160;<span class="preprocessor"></span>                        <span class="comment">/* use this if B.b[i] is evaluated just once ... */</span></div>
<div class="line"><a name="l00700"></a><span class="lineno">  700</span>&#160;<span class="preprocessor">#define DOXOR(x,y,i)    (x)^=SPTAB(SPE[0][(i)],B.b[(i)]); (y)^=SPTAB(SPE[1][(i)],B.b[(i)]);</span></div>
<div class="line"><a name="l00701"></a><span class="lineno">  701</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l00702"></a><span class="lineno">  702</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if defined(pdp11)</span></div>
<div class="line"><a name="l00703"></a><span class="lineno">  703</span>&#160;<span class="preprocessor"></span>                        <span class="comment">/* use this if your &quot;long&quot; int indexing is slow */</span></div>
<div class="line"><a name="l00704"></a><span class="lineno">  704</span>&#160;<span class="preprocessor">#define DOXOR(x,y,i)    j=B.b[(i)]; (x)^=SPTAB(SPE[0][(i)],j); (y)^=SPTAB(SPE[1][(i)],j);</span></div>
<div class="line"><a name="l00705"></a><span class="lineno">  705</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l00706"></a><span class="lineno">  706</span>&#160;<span class="preprocessor"></span>                        <span class="comment">/* use this if &quot;k&quot; is allocated to a register ... */</span></div>
<div class="line"><a name="l00707"></a><span class="lineno">  707</span>&#160;<span class="preprocessor">#define DOXOR(x,y,i)    k=B.b[(i)]; (x)^=SPTAB(SPE[0][(i)],k); (y)^=SPTAB(SPE[1][(i)],k);</span></div>
<div class="line"><a name="l00708"></a><span class="lineno">  708</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00709"></a><span class="lineno">  709</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00710"></a><span class="lineno">  710</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00711"></a><span class="lineno">  711</span>&#160;<span class="preprocessor">#define CRUNCH(p0, p1, q0, q1)  \</span></div>
<div class="line"><a name="l00712"></a><span class="lineno">  712</span>&#160;<span class="preprocessor">                        k = ((q0) ^ (q1)) &amp; SALT;       \</span></div>
<div class="line"><a name="l00713"></a><span class="lineno">  713</span>&#160;<span class="preprocessor">                        B.b32.i0 = k ^ (q0) ^ kp-&gt;b32.i0;               \</span></div>
<div class="line"><a name="l00714"></a><span class="lineno">  714</span>&#160;<span class="preprocessor">                        B.b32.i1 = k ^ (q1) ^ kp-&gt;b32.i1;               \</span></div>
<div class="line"><a name="l00715"></a><span class="lineno">  715</span>&#160;<span class="preprocessor">                        kp = (C_block *)((char *)kp+ks_inc);    \</span></div>
<div class="line"><a name="l00716"></a><span class="lineno">  716</span>&#160;<span class="preprocessor">                                                        \</span></div>
<div class="line"><a name="l00717"></a><span class="lineno">  717</span>&#160;<span class="preprocessor">                        DOXOR((p0), (p1), 0);           \</span></div>
<div class="line"><a name="l00718"></a><span class="lineno">  718</span>&#160;<span class="preprocessor">                        DOXOR((p0), (p1), 1);           \</span></div>
<div class="line"><a name="l00719"></a><span class="lineno">  719</span>&#160;<span class="preprocessor">                        DOXOR((p0), (p1), 2);           \</span></div>
<div class="line"><a name="l00720"></a><span class="lineno">  720</span>&#160;<span class="preprocessor">                        DOXOR((p0), (p1), 3);           \</span></div>
<div class="line"><a name="l00721"></a><span class="lineno">  721</span>&#160;<span class="preprocessor">                        DOXOR((p0), (p1), 4);           \</span></div>
<div class="line"><a name="l00722"></a><span class="lineno">  722</span>&#160;<span class="preprocessor">                        DOXOR((p0), (p1), 5);           \</span></div>
<div class="line"><a name="l00723"></a><span class="lineno">  723</span>&#160;<span class="preprocessor">                        DOXOR((p0), (p1), 6);           \</span></div>
<div class="line"><a name="l00724"></a><span class="lineno">  724</span>&#160;<span class="preprocessor">                        DOXOR((p0), (p1), 7);</span></div>
<div class="line"><a name="l00725"></a><span class="lineno">  725</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00726"></a><span class="lineno">  726</span>&#160;                        <a class="code" href="../../d6/de3/crypt_8c.html#a87dd96357d7e75ad011a9c3896ee9d2f">CRUNCH</a>(L0, L1, R0, R1);</div>
<div class="line"><a name="l00727"></a><span class="lineno">  727</span>&#160;                        <a class="code" href="../../d6/de3/crypt_8c.html#a87dd96357d7e75ad011a9c3896ee9d2f">CRUNCH</a>(R0, R1, L0, L1);</div>
<div class="line"><a name="l00728"></a><span class="lineno">  728</span>&#160;                } <span class="keywordflow">while</span> (--loop_count != 0);</div>
<div class="line"><a name="l00729"></a><span class="lineno">  729</span>&#160;                kp = (<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)((<span class="keywordtype">char</span> *)kp-(ks_inc*<a class="code" href="../../d6/de3/crypt_8c.html#a136f3095237ae23358c30581753e4178">KS_SIZE</a>));</div>
<div class="line"><a name="l00730"></a><span class="lineno">  730</span>&#160;</div>
<div class="line"><a name="l00731"></a><span class="lineno">  731</span>&#160;</div>
<div class="line"><a name="l00732"></a><span class="lineno">  732</span>&#160;                <span class="comment">/* swap L and R */</span></div>
<div class="line"><a name="l00733"></a><span class="lineno">  733</span>&#160;                L0 ^= <a class="code" href="../../d2/d24/sha1_8c.html#a8ac24a09e1273548828d3cc9436f9bc7">R0</a>;  L1 ^= <a class="code" href="../../d6/de3/crypt_8c.html#a81031dcd5c94ba95ab1de0ffe6a97bbf">R1</a>;</div>
<div class="line"><a name="l00734"></a><span class="lineno">  734</span>&#160;                R0 ^= <a class="code" href="../../d6/de3/crypt_8c.html#a65462adaaad855ead567351e0c8475c4">L0</a>;  R1 ^= <a class="code" href="../../d6/de3/crypt_8c.html#a9407b59ea8a359bef2f97830a5aebc08">L1</a>;</div>
<div class="line"><a name="l00735"></a><span class="lineno">  735</span>&#160;                L0 ^= <a class="code" href="../../d2/d24/sha1_8c.html#a8ac24a09e1273548828d3cc9436f9bc7">R0</a>;  L1 ^= <a class="code" href="../../d6/de3/crypt_8c.html#a81031dcd5c94ba95ab1de0ffe6a97bbf">R1</a>;</div>
<div class="line"><a name="l00736"></a><span class="lineno">  736</span>&#160;        }</div>
<div class="line"><a name="l00737"></a><span class="lineno">  737</span>&#160;</div>
<div class="line"><a name="l00738"></a><span class="lineno">  738</span>&#160;        <span class="comment">/* store the encrypted (or decrypted) result */</span></div>
<div class="line"><a name="l00739"></a><span class="lineno">  739</span>&#160;        L0 = ((L0 &gt;&gt; 3) &amp; 0x0f0f0f0fL) | ((L1 &lt;&lt; 1) &amp; 0xf0f0f0f0L);</div>
<div class="line"><a name="l00740"></a><span class="lineno">  740</span>&#160;        L1 = ((R0 &gt;&gt; 3) &amp; 0x0f0f0f0fL) | ((R1 &lt;&lt; 1) &amp; 0xf0f0f0f0L);</div>
<div class="line"><a name="l00741"></a><span class="lineno">  741</span>&#160;        <a class="code" href="../../d6/de3/crypt_8c.html#ad50d91202186ced15ec3fc3a922506b3">STORE</a>(L,L0,L1,B);</div>
<div class="line"><a name="l00742"></a><span class="lineno">  742</span>&#160;        <a class="code" href="../../d6/de3/crypt_8c.html#a2d3c04b14357f1839a3e32c88312e15f">PERM6464</a>(L,L0,L1,B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>, (<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)CF6464);</div>
<div class="line"><a name="l00743"></a><span class="lineno">  743</span>&#160;<span class="preprocessor">#if defined(MUST_ALIGN)</span></div>
<div class="line"><a name="l00744"></a><span class="lineno">  744</span>&#160;<span class="preprocessor"></span>        <a class="code" href="../../d6/de3/crypt_8c.html#ad50d91202186ced15ec3fc3a922506b3">STORE</a>(L,L0,L1,B);</div>
<div class="line"><a name="l00745"></a><span class="lineno">  745</span>&#160;        out[0] = B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[0]; out[1] = B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[1]; out[2] = B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[2]; out[3] = B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[3];</div>
<div class="line"><a name="l00746"></a><span class="lineno">  746</span>&#160;        out[4] = B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[4]; out[5] = B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[5]; out[6] = B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[6]; out[7] = B.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[7];</div>
<div class="line"><a name="l00747"></a><span class="lineno">  747</span>&#160;<span class="preprocessor">#else</span></div>
<div class="line"><a name="l00748"></a><span class="lineno">  748</span>&#160;<span class="preprocessor"></span>        <a class="code" href="../../d6/de3/crypt_8c.html#ad50d91202186ced15ec3fc3a922506b3">STORE</a>(L,L0,L1,*(<a class="code" href="../../df/da2/union_c__block.html">C_block</a> *)out);</div>
<div class="line"><a name="l00749"></a><span class="lineno">  749</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00750"></a><span class="lineno">  750</span>&#160;<span class="preprocessor"></span>        <span class="keywordflow">return</span> (0);</div>
<div class="line"><a name="l00751"></a><span class="lineno">  751</span>&#160;}</div>
<div class="line"><a name="l00752"></a><span class="lineno">  752</span>&#160;</div>
<div class="line"><a name="l00753"></a><span class="lineno">  753</span>&#160;</div>
<div class="line"><a name="l00754"></a><span class="lineno">  754</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00755"></a><span class="lineno">  755</span>&#160;<span class="comment"> * Initialize various tables.  This need only be done once.  It could even be</span></div>
<div class="line"><a name="l00756"></a><span class="lineno">  756</span>&#160;<span class="comment"> * done at compile time, if the compiler were capable of that sort of thing.</span></div>
<div class="line"><a name="l00757"></a><span class="lineno">  757</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00758"></a><span class="lineno">  758</span>&#160;<a class="code" href="../../d6/de3/crypt_8c.html#a10b2d890d871e1489bb02b7e70d9bdfb">STATIC</a> <span class="keywordtype">void</span></div>
<div class="line"><a name="l00759"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#aa2378a0e5d6788c77c9e719ecb0291a0">  759</a></span>&#160;<a class="code" href="../../d6/de3/crypt_8c.html#aa2378a0e5d6788c77c9e719ecb0291a0">init_des</a>()</div>
<div class="line"><a name="l00760"></a><span class="lineno">  760</span>&#160;{</div>
<div class="line"><a name="l00761"></a><span class="lineno">  761</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">int</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>, j;</div>
<div class="line"><a name="l00762"></a><span class="lineno">  762</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">long</span> k;</div>
<div class="line"><a name="l00763"></a><span class="lineno">  763</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">int</span> tableno;</div>
<div class="line"><a name="l00764"></a><span class="lineno">  764</span>&#160;        <span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> <a class="code" href="../../d6/de3/crypt_8c.html#ab8f66b8c0e8b9c69d47c8b38393f0b07">perm</a>[64], tmp32[32];       <span class="comment">/* &quot;static&quot; for speed */</span></div>
<div class="line"><a name="l00765"></a><span class="lineno">  765</span>&#160;</div>
<div class="line"><a name="l00766"></a><span class="lineno">  766</span>&#160;        <span class="comment">/*</span></div>
<div class="line"><a name="l00767"></a><span class="lineno">  767</span>&#160;<span class="comment">         * table that converts chars &quot;./0-9A-Za-z&quot;to integers 0-63.</span></div>
<div class="line"><a name="l00768"></a><span class="lineno">  768</span>&#160;<span class="comment">         */</span></div>
<div class="line"><a name="l00769"></a><span class="lineno">  769</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; 64; i++)</div>
<div class="line"><a name="l00770"></a><span class="lineno">  770</span>&#160;                a64toi[itoa64[i]] = i;</div>
<div class="line"><a name="l00771"></a><span class="lineno">  771</span>&#160;</div>
<div class="line"><a name="l00772"></a><span class="lineno">  772</span>&#160;        <span class="comment">/*</span></div>
<div class="line"><a name="l00773"></a><span class="lineno">  773</span>&#160;<span class="comment">         * PC1ROT - bit reverse, then PC1, then Rotate, then PC2.</span></div>
<div class="line"><a name="l00774"></a><span class="lineno">  774</span>&#160;<span class="comment">         */</span></div>
<div class="line"><a name="l00775"></a><span class="lineno">  775</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; 64; i++)</div>
<div class="line"><a name="l00776"></a><span class="lineno">  776</span>&#160;                perm[i] = 0;</div>
<div class="line"><a name="l00777"></a><span class="lineno">  777</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; 64; i++) {</div>
<div class="line"><a name="l00778"></a><span class="lineno">  778</span>&#160;                <span class="keywordflow">if</span> ((k = PC2[i]) == 0)</div>
<div class="line"><a name="l00779"></a><span class="lineno">  779</span>&#160;                        <span class="keywordflow">continue</span>;</div>
<div class="line"><a name="l00780"></a><span class="lineno">  780</span>&#160;                k += Rotates[0]-1;</div>
<div class="line"><a name="l00781"></a><span class="lineno">  781</span>&#160;                <span class="keywordflow">if</span> ((k%28) &lt; Rotates[0]) k -= 28;</div>
<div class="line"><a name="l00782"></a><span class="lineno">  782</span>&#160;                k = PC1[k];</div>
<div class="line"><a name="l00783"></a><span class="lineno">  783</span>&#160;                <span class="keywordflow">if</span> (k &gt; 0) {</div>
<div class="line"><a name="l00784"></a><span class="lineno">  784</span>&#160;                        k--;</div>
<div class="line"><a name="l00785"></a><span class="lineno">  785</span>&#160;                        k = (k|07) - (k&amp;07);</div>
<div class="line"><a name="l00786"></a><span class="lineno">  786</span>&#160;                        k++;</div>
<div class="line"><a name="l00787"></a><span class="lineno">  787</span>&#160;                }</div>
<div class="line"><a name="l00788"></a><span class="lineno">  788</span>&#160;                perm[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>] = (<span class="keywordtype">unsigned</span> char)k;</div>
<div class="line"><a name="l00789"></a><span class="lineno">  789</span>&#160;        }</div>
<div class="line"><a name="l00790"></a><span class="lineno">  790</span>&#160;<span class="preprocessor">#ifdef DEBUG</span></div>
<div class="line"><a name="l00791"></a><span class="lineno">  791</span>&#160;<span class="preprocessor"></span>        prtab(<span class="stringliteral">&quot;pc1tab&quot;</span>, perm, 8);</div>
<div class="line"><a name="l00792"></a><span class="lineno">  792</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00793"></a><span class="lineno">  793</span>&#160;<span class="preprocessor"></span>        <a class="code" href="../../d6/de3/crypt_8c.html#a70ea989e3d76e6f0ca30dfed27527da8">init_perm</a>(PC1ROT, perm, 8, 8);</div>
<div class="line"><a name="l00794"></a><span class="lineno">  794</span>&#160;</div>
<div class="line"><a name="l00795"></a><span class="lineno">  795</span>&#160;        <span class="comment">/*</span></div>
<div class="line"><a name="l00796"></a><span class="lineno">  796</span>&#160;<span class="comment">         * PC2ROT - PC2 inverse, then Rotate (once or twice), then PC2.</span></div>
<div class="line"><a name="l00797"></a><span class="lineno">  797</span>&#160;<span class="comment">         */</span></div>
<div class="line"><a name="l00798"></a><span class="lineno">  798</span>&#160;        <span class="keywordflow">for</span> (j = 0; j &lt; 2; j++) {</div>
<div class="line"><a name="l00799"></a><span class="lineno">  799</span>&#160;                <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> pc2inv[64];</div>
<div class="line"><a name="l00800"></a><span class="lineno">  800</span>&#160;                <span class="keywordflow">for</span> (i = 0; i &lt; 64; i++)</div>
<div class="line"><a name="l00801"></a><span class="lineno">  801</span>&#160;                        perm[i] = pc2inv[i] = 0;</div>
<div class="line"><a name="l00802"></a><span class="lineno">  802</span>&#160;                <span class="keywordflow">for</span> (i = 0; i &lt; 64; i++) {</div>
<div class="line"><a name="l00803"></a><span class="lineno">  803</span>&#160;                        <span class="keywordflow">if</span> ((k = PC2[i]) == 0)</div>
<div class="line"><a name="l00804"></a><span class="lineno">  804</span>&#160;                                <span class="keywordflow">continue</span>;</div>
<div class="line"><a name="l00805"></a><span class="lineno">  805</span>&#160;                        pc2inv[k-1] = i+1;</div>
<div class="line"><a name="l00806"></a><span class="lineno">  806</span>&#160;                }</div>
<div class="line"><a name="l00807"></a><span class="lineno">  807</span>&#160;                <span class="keywordflow">for</span> (i = 0; i &lt; 64; i++) {</div>
<div class="line"><a name="l00808"></a><span class="lineno">  808</span>&#160;                        <span class="keywordflow">if</span> ((k = PC2[i]) == 0)</div>
<div class="line"><a name="l00809"></a><span class="lineno">  809</span>&#160;                                <span class="keywordflow">continue</span>;</div>
<div class="line"><a name="l00810"></a><span class="lineno">  810</span>&#160;                        k += j;</div>
<div class="line"><a name="l00811"></a><span class="lineno">  811</span>&#160;                        <span class="keywordflow">if</span> ((k%28) &lt;= j) k -= 28;</div>
<div class="line"><a name="l00812"></a><span class="lineno">  812</span>&#160;                        perm[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>] = pc2inv[k];</div>
<div class="line"><a name="l00813"></a><span class="lineno">  813</span>&#160;                }</div>
<div class="line"><a name="l00814"></a><span class="lineno">  814</span>&#160;<span class="preprocessor">#ifdef DEBUG</span></div>
<div class="line"><a name="l00815"></a><span class="lineno">  815</span>&#160;<span class="preprocessor"></span>                prtab(<span class="stringliteral">&quot;pc2tab&quot;</span>, perm, 8);</div>
<div class="line"><a name="l00816"></a><span class="lineno">  816</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00817"></a><span class="lineno">  817</span>&#160;<span class="preprocessor"></span>                <a class="code" href="../../d6/de3/crypt_8c.html#a70ea989e3d76e6f0ca30dfed27527da8">init_perm</a>(PC2ROT[j], perm, 8, 8);</div>
<div class="line"><a name="l00818"></a><span class="lineno">  818</span>&#160;        }</div>
<div class="line"><a name="l00819"></a><span class="lineno">  819</span>&#160;</div>
<div class="line"><a name="l00820"></a><span class="lineno">  820</span>&#160;        <span class="comment">/*</span></div>
<div class="line"><a name="l00821"></a><span class="lineno">  821</span>&#160;<span class="comment">         * Bit reverse, then initial permutation, then expansion.</span></div>
<div class="line"><a name="l00822"></a><span class="lineno">  822</span>&#160;<span class="comment">         */</span></div>
<div class="line"><a name="l00823"></a><span class="lineno">  823</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; 8; i++) {</div>
<div class="line"><a name="l00824"></a><span class="lineno">  824</span>&#160;                <span class="keywordflow">for</span> (j = 0; j &lt; 8; j++) {</div>
<div class="line"><a name="l00825"></a><span class="lineno">  825</span>&#160;                        k = (j &lt; 2)? 0: IP[ExpandTr[i*6+j-2]-1];</div>
<div class="line"><a name="l00826"></a><span class="lineno">  826</span>&#160;                        <span class="keywordflow">if</span> (k &gt; 32)</div>
<div class="line"><a name="l00827"></a><span class="lineno">  827</span>&#160;                                k -= 32;</div>
<div class="line"><a name="l00828"></a><span class="lineno">  828</span>&#160;                        <span class="keywordflow">else</span> <span class="keywordflow">if</span> (k &gt; 0)</div>
<div class="line"><a name="l00829"></a><span class="lineno">  829</span>&#160;                                k--;</div>
<div class="line"><a name="l00830"></a><span class="lineno">  830</span>&#160;                        <span class="keywordflow">if</span> (k &gt; 0) {</div>
<div class="line"><a name="l00831"></a><span class="lineno">  831</span>&#160;                                k--;</div>
<div class="line"><a name="l00832"></a><span class="lineno">  832</span>&#160;                                k = (k|07) - (k&amp;07);</div>
<div class="line"><a name="l00833"></a><span class="lineno">  833</span>&#160;                                k++;</div>
<div class="line"><a name="l00834"></a><span class="lineno">  834</span>&#160;                        }</div>
<div class="line"><a name="l00835"></a><span class="lineno">  835</span>&#160;                        perm[i*8+j] = (<span class="keywordtype">unsigned</span> char)k;</div>
<div class="line"><a name="l00836"></a><span class="lineno">  836</span>&#160;                }</div>
<div class="line"><a name="l00837"></a><span class="lineno">  837</span>&#160;        }</div>
<div class="line"><a name="l00838"></a><span class="lineno">  838</span>&#160;<span class="preprocessor">#ifdef DEBUG</span></div>
<div class="line"><a name="l00839"></a><span class="lineno">  839</span>&#160;<span class="preprocessor"></span>        prtab(<span class="stringliteral">&quot;ietab&quot;</span>, perm, 8);</div>
<div class="line"><a name="l00840"></a><span class="lineno">  840</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00841"></a><span class="lineno">  841</span>&#160;<span class="preprocessor"></span>        <a class="code" href="../../d6/de3/crypt_8c.html#a70ea989e3d76e6f0ca30dfed27527da8">init_perm</a>(IE3264, perm, 4, 8);</div>
<div class="line"><a name="l00842"></a><span class="lineno">  842</span>&#160;</div>
<div class="line"><a name="l00843"></a><span class="lineno">  843</span>&#160;        <span class="comment">/*</span></div>
<div class="line"><a name="l00844"></a><span class="lineno">  844</span>&#160;<span class="comment">         * Compression, then final permutation, then bit reverse.</span></div>
<div class="line"><a name="l00845"></a><span class="lineno">  845</span>&#160;<span class="comment">         */</span></div>
<div class="line"><a name="l00846"></a><span class="lineno">  846</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; 64; i++) {</div>
<div class="line"><a name="l00847"></a><span class="lineno">  847</span>&#160;                k = IP[CIFP[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>]-1];</div>
<div class="line"><a name="l00848"></a><span class="lineno">  848</span>&#160;                <span class="keywordflow">if</span> (k &gt; 0) {</div>
<div class="line"><a name="l00849"></a><span class="lineno">  849</span>&#160;                        k--;</div>
<div class="line"><a name="l00850"></a><span class="lineno">  850</span>&#160;                        k = (k|07) - (k&amp;07);</div>
<div class="line"><a name="l00851"></a><span class="lineno">  851</span>&#160;                        k++;</div>
<div class="line"><a name="l00852"></a><span class="lineno">  852</span>&#160;                }</div>
<div class="line"><a name="l00853"></a><span class="lineno">  853</span>&#160;                perm[k-1] = i+1;</div>
<div class="line"><a name="l00854"></a><span class="lineno">  854</span>&#160;        }</div>
<div class="line"><a name="l00855"></a><span class="lineno">  855</span>&#160;<span class="preprocessor">#ifdef DEBUG</span></div>
<div class="line"><a name="l00856"></a><span class="lineno">  856</span>&#160;<span class="preprocessor"></span>        prtab(<span class="stringliteral">&quot;cftab&quot;</span>, perm, 8);</div>
<div class="line"><a name="l00857"></a><span class="lineno">  857</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00858"></a><span class="lineno">  858</span>&#160;<span class="preprocessor"></span>        <a class="code" href="../../d6/de3/crypt_8c.html#a70ea989e3d76e6f0ca30dfed27527da8">init_perm</a>(CF6464, perm, 8, 8);</div>
<div class="line"><a name="l00859"></a><span class="lineno">  859</span>&#160;</div>
<div class="line"><a name="l00860"></a><span class="lineno">  860</span>&#160;        <span class="comment">/*</span></div>
<div class="line"><a name="l00861"></a><span class="lineno">  861</span>&#160;<span class="comment">         * SPE table</span></div>
<div class="line"><a name="l00862"></a><span class="lineno">  862</span>&#160;<span class="comment">         */</span></div>
<div class="line"><a name="l00863"></a><span class="lineno">  863</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; 48; i++)</div>
<div class="line"><a name="l00864"></a><span class="lineno">  864</span>&#160;                perm[i] = P32Tr[ExpandTr[i]-1];</div>
<div class="line"><a name="l00865"></a><span class="lineno">  865</span>&#160;        <span class="keywordflow">for</span> (tableno = 0; tableno &lt; 8; tableno++) {</div>
<div class="line"><a name="l00866"></a><span class="lineno">  866</span>&#160;                <span class="keywordflow">for</span> (j = 0; j &lt; 64; j++)  {</div>
<div class="line"><a name="l00867"></a><span class="lineno">  867</span>&#160;                        k = (((j &gt;&gt; 0) &amp;01) &lt;&lt; 5)|</div>
<div class="line"><a name="l00868"></a><span class="lineno">  868</span>&#160;                            (((j &gt;&gt; 1) &amp;01) &lt;&lt; 3)|</div>
<div class="line"><a name="l00869"></a><span class="lineno">  869</span>&#160;                            (((j &gt;&gt; 2) &amp;01) &lt;&lt; 2)|</div>
<div class="line"><a name="l00870"></a><span class="lineno">  870</span>&#160;                            (((j &gt;&gt; 3) &amp;01) &lt;&lt; 1)|</div>
<div class="line"><a name="l00871"></a><span class="lineno">  871</span>&#160;                            (((j &gt;&gt; 4) &amp;01) &lt;&lt; 0)|</div>
<div class="line"><a name="l00872"></a><span class="lineno">  872</span>&#160;                            (((j &gt;&gt; 5) &amp;01) &lt;&lt; 4);</div>
<div class="line"><a name="l00873"></a><span class="lineno">  873</span>&#160;                        k = S[tableno][k];</div>
<div class="line"><a name="l00874"></a><span class="lineno">  874</span>&#160;                        k = (((k &gt;&gt; 3)&amp;01) &lt;&lt; 0)|</div>
<div class="line"><a name="l00875"></a><span class="lineno">  875</span>&#160;                            (((k &gt;&gt; 2)&amp;01) &lt;&lt; 1)|</div>
<div class="line"><a name="l00876"></a><span class="lineno">  876</span>&#160;                            (((k &gt;&gt; 1)&amp;01) &lt;&lt; 2)|</div>
<div class="line"><a name="l00877"></a><span class="lineno">  877</span>&#160;                            (((k &gt;&gt; 0)&amp;01) &lt;&lt; 3);</div>
<div class="line"><a name="l00878"></a><span class="lineno">  878</span>&#160;                        <span class="keywordflow">for</span> (i = 0; i &lt; 32; i++)</div>
<div class="line"><a name="l00879"></a><span class="lineno">  879</span>&#160;                                tmp32[i] = 0;</div>
<div class="line"><a name="l00880"></a><span class="lineno">  880</span>&#160;                        <span class="keywordflow">for</span> (i = 0; i &lt; 4; i++)</div>
<div class="line"><a name="l00881"></a><span class="lineno">  881</span>&#160;                                tmp32[4 * tableno + i] = (<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>)(k &gt;&gt; <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>) &amp; 01;</div>
<div class="line"><a name="l00882"></a><span class="lineno">  882</span>&#160;                        k = 0;</div>
<div class="line"><a name="l00883"></a><span class="lineno">  883</span>&#160;                        <span class="keywordflow">for</span> (i = 24; --i &gt;= 0; )</div>
<div class="line"><a name="l00884"></a><span class="lineno">  884</span>&#160;                                k = (k&lt;&lt;1) | tmp32[perm[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>]-1];</div>
<div class="line"><a name="l00885"></a><span class="lineno">  885</span>&#160;                        <a class="code" href="../../d6/de3/crypt_8c.html#a1a1902080cb6a4fb4caa7affb5cebb51">TO_SIX_BIT</a>(SPE[0][tableno][j], k);</div>
<div class="line"><a name="l00886"></a><span class="lineno">  886</span>&#160;                        k = 0;</div>
<div class="line"><a name="l00887"></a><span class="lineno">  887</span>&#160;                        <span class="keywordflow">for</span> (i = 24; --i &gt;= 0; )</div>
<div class="line"><a name="l00888"></a><span class="lineno">  888</span>&#160;                                k = (k&lt;&lt;1) | tmp32[perm[i+24]-1];</div>
<div class="line"><a name="l00889"></a><span class="lineno">  889</span>&#160;                        <a class="code" href="../../d6/de3/crypt_8c.html#a1a1902080cb6a4fb4caa7affb5cebb51">TO_SIX_BIT</a>(SPE[1][tableno][j], k);</div>
<div class="line"><a name="l00890"></a><span class="lineno">  890</span>&#160;                }</div>
<div class="line"><a name="l00891"></a><span class="lineno">  891</span>&#160;        }</div>
<div class="line"><a name="l00892"></a><span class="lineno">  892</span>&#160;}</div>
<div class="line"><a name="l00893"></a><span class="lineno">  893</span>&#160;</div>
<div class="line"><a name="l00894"></a><span class="lineno">  894</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00895"></a><span class="lineno">  895</span>&#160;<span class="comment"> * Initialize &quot;perm&quot; to represent transformation &quot;p&quot;, which rearranges</span></div>
<div class="line"><a name="l00896"></a><span class="lineno">  896</span>&#160;<span class="comment"> * (perhaps with expansion and/or contraction) one packed array of bits</span></div>
<div class="line"><a name="l00897"></a><span class="lineno">  897</span>&#160;<span class="comment"> * (of size &quot;chars_in&quot; characters) into another array (of size &quot;chars_out&quot;</span></div>
<div class="line"><a name="l00898"></a><span class="lineno">  898</span>&#160;<span class="comment"> * characters).</span></div>
<div class="line"><a name="l00899"></a><span class="lineno">  899</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00900"></a><span class="lineno">  900</span>&#160;<span class="comment"> * &quot;perm&quot; must be all-zeroes on entry to this routine.</span></div>
<div class="line"><a name="l00901"></a><span class="lineno">  901</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00902"></a><span class="lineno">  902</span>&#160;<a class="code" href="../../d6/de3/crypt_8c.html#a10b2d890d871e1489bb02b7e70d9bdfb">STATIC</a> <span class="keywordtype">void</span></div>
<div class="line"><a name="l00903"></a><span class="lineno">  903</span>&#160;<a class="code" href="../../d6/de3/crypt_8c.html#a70ea989e3d76e6f0ca30dfed27527da8">init_perm</a>(<a class="code" href="../../d6/de3/crypt_8c.html#ab8f66b8c0e8b9c69d47c8b38393f0b07">perm</a>, p, chars_in, <a class="code" href="../../d6/de3/crypt_8c.html#ae39213effe2b09e6b612e9cd6ccefc27">chars_out</a>)</div>
<div class="line"><a name="l00904"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ab8f66b8c0e8b9c69d47c8b38393f0b07">  904</a></span>&#160;        <a class="code" href="../../df/da2/union_c__block.html">C_block</a> <a class="code" href="../../d6/de3/crypt_8c.html#ab8f66b8c0e8b9c69d47c8b38393f0b07">perm</a>[64/<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>][1&lt;&lt;<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>];</div>
<div class="line"><a name="l00905"></a><span class="lineno">  905</span>&#160;        <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> p[64];</div>
<div class="line"><a name="l00906"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ae39213effe2b09e6b612e9cd6ccefc27">  906</a></span>&#160;        <span class="keywordtype">int</span> chars_in, <a class="code" href="../../d6/de3/crypt_8c.html#ae39213effe2b09e6b612e9cd6ccefc27">chars_out</a>;</div>
<div class="line"><a name="l00907"></a><span class="lineno">  907</span>&#160;{</div>
<div class="line"><a name="l00908"></a><span class="lineno">  908</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">int</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>, j, k, l;</div>
<div class="line"><a name="l00909"></a><span class="lineno">  909</span>&#160;</div>
<div class="line"><a name="l00910"></a><span class="lineno">  910</span>&#160;        <span class="keywordflow">for</span> (k = 0; k &lt; chars_out*8; k++) {     <span class="comment">/* each output bit position */</span></div>
<div class="line"><a name="l00911"></a><span class="lineno">  911</span>&#160;                l = p[k] - 1;           <span class="comment">/* where this bit comes from */</span></div>
<div class="line"><a name="l00912"></a><span class="lineno">  912</span>&#160;                <span class="keywordflow">if</span> (l &lt; 0)</div>
<div class="line"><a name="l00913"></a><span class="lineno">  913</span>&#160;                        <span class="keywordflow">continue</span>;       <span class="comment">/* output bit is always 0 */</span></div>
<div class="line"><a name="l00914"></a><span class="lineno">  914</span>&#160;                i = l&gt;&gt;<a class="code" href="../../d6/de3/crypt_8c.html#aefe059a4e3b401e9378733c2c59878db">LGCHUNKBITS</a>;     <span class="comment">/* which chunk this bit comes from */</span></div>
<div class="line"><a name="l00915"></a><span class="lineno">  915</span>&#160;                l = 1&lt;&lt;(l&amp;(CHUNKBITS-1));       <span class="comment">/* mask for this bit */</span></div>
<div class="line"><a name="l00916"></a><span class="lineno">  916</span>&#160;                <span class="keywordflow">for</span> (j = 0; j &lt; (1&lt;&lt;<a class="code" href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a>); j++) {  <span class="comment">/* each chunk value */</span></div>
<div class="line"><a name="l00917"></a><span class="lineno">  917</span>&#160;                        <span class="keywordflow">if</span> ((j &amp; l) != 0)</div>
<div class="line"><a name="l00918"></a><span class="lineno">  918</span>&#160;                                <a class="code" href="../../d6/de3/crypt_8c.html#ab8f66b8c0e8b9c69d47c8b38393f0b07">perm</a>[i][j].<a class="code" href="../../de/d07/bigdecimal_8c.html#af5857437ff0274b5a927afe95f104a39">b</a>[k&gt;&gt;3] |= 1&lt;&lt;(k&amp;07);</div>
<div class="line"><a name="l00919"></a><span class="lineno">  919</span>&#160;                }</div>
<div class="line"><a name="l00920"></a><span class="lineno">  920</span>&#160;        }</div>
<div class="line"><a name="l00921"></a><span class="lineno">  921</span>&#160;}</div>
<div class="line"><a name="l00922"></a><span class="lineno">  922</span>&#160;</div>
<div class="line"><a name="l00923"></a><span class="lineno">  923</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00924"></a><span class="lineno">  924</span>&#160;<span class="comment"> * &quot;setkey&quot; routine (for backwards compatibility)</span></div>
<div class="line"><a name="l00925"></a><span class="lineno">  925</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00926"></a><span class="lineno">  926</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00927"></a><span class="lineno">  927</span>&#160;setkey(key)</div>
<div class="line"><a name="l00928"></a><span class="lineno">  928</span>&#160;        register <a class="code" href="../../d8/d4e/strftime_8c.html#a2c212835823e3c54a8ab6d95c652660e">const</a> <span class="keywordtype">char</span> *key;</div>
<div class="line"><a name="l00929"></a><span class="lineno">  929</span>&#160;{</div>
<div class="line"><a name="l00930"></a><span class="lineno">  930</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">int</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>, j, k;</div>
<div class="line"><a name="l00931"></a><span class="lineno">  931</span>&#160;        <a class="code" href="../../df/da2/union_c__block.html">C_block</a> <a class="code" href="../../d6/de3/crypt_8c.html#a6702f12a379cd011a0e99d5c863c484a">keyblock</a>;</div>
<div class="line"><a name="l00932"></a><span class="lineno">  932</span>&#160;</div>
<div class="line"><a name="l00933"></a><span class="lineno">  933</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; 8; i++) {</div>
<div class="line"><a name="l00934"></a><span class="lineno">  934</span>&#160;                k = 0;</div>
<div class="line"><a name="l00935"></a><span class="lineno">  935</span>&#160;                <span class="keywordflow">for</span> (j = 0; j &lt; 8; j++) {</div>
<div class="line"><a name="l00936"></a><span class="lineno">  936</span>&#160;                        k &lt;&lt;= 1;</div>
<div class="line"><a name="l00937"></a><span class="lineno">  937</span>&#160;                        k |= (<span class="keywordtype">unsigned</span> char)*key++;</div>
<div class="line"><a name="l00938"></a><span class="lineno">  938</span>&#160;                }</div>
<div class="line"><a name="l00939"></a><span class="lineno">  939</span>&#160;                keyblock.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>] = k;</div>
<div class="line"><a name="l00940"></a><span class="lineno">  940</span>&#160;        }</div>
<div class="line"><a name="l00941"></a><span class="lineno">  941</span>&#160;        <span class="keywordflow">return</span> (<a class="code" href="../../d6/de3/crypt_8c.html#a654d8b345f7098c1108e712985321c3c">des_setkey</a>((<span class="keywordtype">char</span> *)keyblock.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>));</div>
<div class="line"><a name="l00942"></a><span class="lineno">  942</span>&#160;}</div>
<div class="line"><a name="l00943"></a><span class="lineno">  943</span>&#160;</div>
<div class="line"><a name="l00944"></a><span class="lineno">  944</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00945"></a><span class="lineno">  945</span>&#160;<span class="comment"> * &quot;encrypt&quot; routine (for backwards compatibility)</span></div>
<div class="line"><a name="l00946"></a><span class="lineno">  946</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00947"></a><span class="lineno">  947</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00948"></a><span class="lineno">  948</span>&#160;encrypt(<a class="code" href="../../d6/de3/crypt_8c.html#ad030b207cd89c8ec896ef79b4617831c">block</a>, <a class="code" href="../../d5/d9d/tcltklib_8c.html#aa47c45738d686ad11e7b9c7c1615fcd2">flag</a>)</div>
<div class="line"><a name="l00949"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ad030b207cd89c8ec896ef79b4617831c">  949</a></span>&#160;        register <span class="keywordtype">char</span> *<a class="code" href="../../d6/de3/crypt_8c.html#ad030b207cd89c8ec896ef79b4617831c">block</a>;</div>
<div class="line"><a name="l00950"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#adf916204820072417ed73a32de1cefcf">  950</a></span>&#160;        <span class="keywordtype">int</span> <a class="code" href="../../d5/d9d/tcltklib_8c.html#aa47c45738d686ad11e7b9c7c1615fcd2">flag</a>;</div>
<div class="line"><a name="l00951"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#adad8a6b1fcd44511dda6e1760e48d0a2">  951</a></span>&#160;{</div>
<div class="line"><a name="l00952"></a><span class="lineno">  952</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">int</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>, j, k;</div>
<div class="line"><a name="l00953"></a><span class="lineno">  953</span>&#160;        <a class="code" href="../../df/da2/union_c__block.html">C_block</a> <a class="code" href="../../d6/de3/crypt_8c.html#adad8a6b1fcd44511dda6e1760e48d0a2">cblock</a>;</div>
<div class="line"><a name="l00954"></a><span class="lineno">  954</span>&#160;</div>
<div class="line"><a name="l00955"></a><span class="lineno">  955</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; 8; i++) {</div>
<div class="line"><a name="l00956"></a><span class="lineno">  956</span>&#160;                k = 0;</div>
<div class="line"><a name="l00957"></a><span class="lineno">  957</span>&#160;                <span class="keywordflow">for</span> (j = 0; j &lt; 8; j++) {</div>
<div class="line"><a name="l00958"></a><span class="lineno">  958</span>&#160;                        k &lt;&lt;= 1;</div>
<div class="line"><a name="l00959"></a><span class="lineno">  959</span>&#160;                        k |= (<span class="keywordtype">unsigned</span> char)*block++;</div>
<div class="line"><a name="l00960"></a><span class="lineno">  960</span>&#160;                }</div>
<div class="line"><a name="l00961"></a><span class="lineno">  961</span>&#160;                cblock.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>] = k;</div>
<div class="line"><a name="l00962"></a><span class="lineno">  962</span>&#160;        }</div>
<div class="line"><a name="l00963"></a><span class="lineno"><a class="line" href="../../d6/de3/crypt_8c.html#ad764ebaadb4cc041d304afa3c989d62e">  963</a></span>&#160;        <span class="keywordflow">if</span> (<a class="code" href="../../d6/de3/crypt_8c.html#a5c9b491358c3434f273b874b413afb09">des_cipher</a>((<span class="keywordtype">char</span> *)&amp;cblock, (<span class="keywordtype">char</span> *)&amp;cblock, 0L, (flag ? -1: 1)))</div>
<div class="line"><a name="l00964"></a><span class="lineno">  964</span>&#160;                <span class="keywordflow">return</span> (1);</div>
<div class="line"><a name="l00965"></a><span class="lineno">  965</span>&#160;        <span class="keywordflow">for</span> (i = 7; i &gt;= 0; i--) {</div>
<div class="line"><a name="l00966"></a><span class="lineno">  966</span>&#160;                k = cblock.<a class="code" href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">b</a>[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>];</div>
<div class="line"><a name="l00967"></a><span class="lineno">  967</span>&#160;                <span class="keywordflow">for</span> (j = 7; j &gt;= 0; j--) {</div>
<div class="line"><a name="l00968"></a><span class="lineno">  968</span>&#160;                        *--block = k&amp;01;</div>
<div class="line"><a name="l00969"></a><span class="lineno">  969</span>&#160;                        k &gt;&gt;= 1;</div>
<div class="line"><a name="l00970"></a><span class="lineno">  970</span>&#160;                }</div>
<div class="line"><a name="l00971"></a><span class="lineno">  971</span>&#160;        }</div>
<div class="line"><a name="l00972"></a><span class="lineno">  972</span>&#160;        <span class="keywordflow">return</span> (0);</div>
<div class="line"><a name="l00973"></a><span class="lineno">  973</span>&#160;}</div>
<div class="line"><a name="l00974"></a><span class="lineno">  974</span>&#160;</div>
<div class="line"><a name="l00975"></a><span class="lineno">  975</span>&#160;<span class="preprocessor">#ifdef DEBUG</span></div>
<div class="line"><a name="l00976"></a><span class="lineno">  976</span>&#160;<span class="preprocessor"></span><a class="code" href="../../d6/de3/crypt_8c.html#a10b2d890d871e1489bb02b7e70d9bdfb">STATIC</a> <span class="keywordtype">void</span></div>
<div class="line"><a name="l00977"></a><span class="lineno">  977</span>&#160;prtab(<a class="code" href="../../de/d46/os2_8c.html#a58defbf6fe556592007171f7a347f9d6">s</a>, t, num_rows)</div>
<div class="line"><a name="l00978"></a><span class="lineno">  978</span>&#160;        char *<a class="code" href="../../de/d46/os2_8c.html#a58defbf6fe556592007171f7a347f9d6">s</a>;</div>
<div class="line"><a name="l00979"></a><span class="lineno">  979</span>&#160;        <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *t;</div>
<div class="line"><a name="l00980"></a><span class="lineno">  980</span>&#160;        <span class="keywordtype">int</span> num_rows;</div>
<div class="line"><a name="l00981"></a><span class="lineno">  981</span>&#160;{</div>
<div class="line"><a name="l00982"></a><span class="lineno">  982</span>&#160;        <span class="keyword">register</span> <span class="keywordtype">int</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>, j;</div>
<div class="line"><a name="l00983"></a><span class="lineno">  983</span>&#160;</div>
<div class="line"><a name="l00984"></a><span class="lineno">  984</span>&#160;        (<a class="code" href="../../de/d07/bigdecimal_8c.html#ac537498b5ed6e25bced70b90e5949201">void</a>)printf(<span class="stringliteral">&quot;%s:\n&quot;</span>, s);</div>
<div class="line"><a name="l00985"></a><span class="lineno">  985</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; num_rows; i++) {</div>
<div class="line"><a name="l00986"></a><span class="lineno">  986</span>&#160;                <span class="keywordflow">for</span> (j = 0; j &lt; 8; j++) {</div>
<div class="line"><a name="l00987"></a><span class="lineno">  987</span>&#160;                         (<a class="code" href="../../de/d07/bigdecimal_8c.html#ac537498b5ed6e25bced70b90e5949201">void</a>)printf(<span class="stringliteral">&quot;%3d&quot;</span>, t[i*8+j]);</div>
<div class="line"><a name="l00988"></a><span class="lineno">  988</span>&#160;                }</div>
<div class="line"><a name="l00989"></a><span class="lineno">  989</span>&#160;                (<a class="code" href="../../de/d07/bigdecimal_8c.html#ac537498b5ed6e25bced70b90e5949201">void</a>)printf(<span class="stringliteral">&quot;\n&quot;</span>);</div>
<div class="line"><a name="l00990"></a><span class="lineno">  990</span>&#160;        }</div>
<div class="line"><a name="l00991"></a><span class="lineno">  991</span>&#160;        (<a class="code" href="../../de/d07/bigdecimal_8c.html#ac537498b5ed6e25bced70b90e5949201">void</a>)printf(<span class="stringliteral">&quot;\n&quot;</span>);</div>
<div class="line"><a name="l00992"></a><span class="lineno">  992</span>&#160;}</div>
<div class="line"><a name="l00993"></a><span class="lineno">  993</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="ttc" id="complex_8c_html_ac328e551bde3d39b6d7b8cc9e048d941"><div class="ttname"><a href="../../d1/d81/complex_8c.html#ac328e551bde3d39b6d7b8cc9e048d941">ZERO</a></div><div class="ttdeci">#define ZERO</div><div class="ttdef"><b>Definition:</b> <a href="../../d1/d81/complex_8c_source.html#l00015">complex.c:15</a></div></div>
<div class="ttc" id="crypt_8c_html_a70ea989e3d76e6f0ca30dfed27527da8"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a70ea989e3d76e6f0ca30dfed27527da8">init_perm</a></div><div class="ttdeci">STATIC void init_perm()</div></div>
<div class="ttc" id="crypt_8c_html_a0500d1419552f2e99e1e896e6d6adfba"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a0500d1419552f2e99e1e896e6d6adfba">rsltblock</a></div><div class="ttdeci">C_block rsltblock</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00509">crypt.c:509</a></div></div>
<div class="ttc" id="crypt_8c_html_a1a1902080cb6a4fb4caa7affb5cebb51"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a1a1902080cb6a4fb4caa7affb5cebb51">TO_SIX_BIT</a></div><div class="ttdeci">#define TO_SIX_BIT(rslt, src)</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00259">crypt.c:259</a></div></div>
<div class="ttc" id="crypt_8c_html_a29a66b01dcde739252b17b74247261c7"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a29a66b01dcde739252b17b74247261c7">IE3264</a></div><div class="ttdeci">static C_block IE3264[32/CHUNKBITS][1&lt;&lt; CHUNKBITS]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00480">crypt.c:480</a></div></div>
<div class="ttc" id="crypt_8c_html_a87dd96357d7e75ad011a9c3896ee9d2f"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a87dd96357d7e75ad011a9c3896ee9d2f">CRUNCH</a></div><div class="ttdeci">#define CRUNCH(p0, p1, q0, q1)</div></div>
<div class="ttc" id="crypt_8c_html_ad030b207cd89c8ec896ef79b4617831c"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ad030b207cd89c8ec896ef79b4617831c">block</a></div><div class="ttdeci">int register char * block</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00949">crypt.c:949</a></div></div>
<div class="ttc" id="sha2_8c_html_af299e0982ce71aad5027c4a7315e536f"><div class="ttname"><a href="../../d3/d80/sha2_8c.html#af299e0982ce71aad5027c4a7315e536f">R</a></div><div class="ttdeci">#define R(b, x)</div><div class="ttdef"><b>Definition:</b> <a href="../../d3/d80/sha2_8c_source.html#l00203">sha2.c:203</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_accd5e629f58868c52137db996aaf8b83"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#accd5e629f58868c52137db996aaf8b83">int</a></div><div class="ttdeci">VP_EXPORT int</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l04911">bigdecimal.c:4911</a></div></div>
<div class="ttc" id="crypt_8c_html_a1b207183df3765ba2eabb5562da72158"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a1b207183df3765ba2eabb5562da72158">LOAD</a></div><div class="ttdeci">#define LOAD(d, d0, d1, bl)</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00272">crypt.c:272</a></div></div>
<div class="ttc" id="crypt_8c_html_abe081f68ee621d157bd09424831be314"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#abe081f68ee621d157bd09424831be314">S</a></div><div class="ttdeci">static unsigned char S[8][64]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00382">crypt.c:382</a></div></div>
<div class="ttc" id="crypt_8c_html_a8500a318327bde6daa31a9a14396c075"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a8500a318327bde6daa31a9a14396c075">loop_count</a></div><div class="ttdeci">register int loop_count</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00650">crypt.c:650</a></div></div>
<div class="ttc" id="crypt_8c_html_a60d0673ec77a0a3574652b45bdfcc623"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a60d0673ec77a0a3574652b45bdfcc623">out</a></div><div class="ttdeci">C_block * out</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00308">crypt.c:308</a></div></div>
<div class="ttc" id="crypt_8c_html_adad8a6b1fcd44511dda6e1760e48d0a2"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#adad8a6b1fcd44511dda6e1760e48d0a2">cblock</a></div><div class="ttdeci">C_block cblock</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00951">crypt.c:951</a></div></div>
<div class="ttc" id="crypt_8c_html_a46df822e601f80265b7348b8fa89ed36"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a46df822e601f80265b7348b8fa89ed36">PERM3264</a></div><div class="ttdeci">#define PERM3264(d, d0, d1, cpp, p)</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00302">crypt.c:302</a></div></div>
<div class="ttc" id="crypt_8c_html_acf339f7dd636dc2a8da0ff818f4908ad"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#acf339f7dd636dc2a8da0ff818f4908ad">chars_in</a></div><div class="ttdeci">int chars_in</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00310">crypt.c:310</a></div></div>
<div class="ttc" id="yaml2byte_8c_html_a37ed7f02c58c0c771e7e76b4c1e594e6"><div class="ttname"><a href="../../dd/dfb/yaml2byte_8c.html#a37ed7f02c58c0c771e7e76b4c1e594e6">p</a></div><div class="ttdeci">SYMID SyckParser * p</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/dfb/yaml2byte_8c_source.html#l00119">yaml2byte.c:119</a></div></div>
<div class="ttc" id="crypt_8c_html_af24d6b29124568045885a69859ad56a8"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#af24d6b29124568045885a69859ad56a8">P32Tr</a></div><div class="ttdeci">static unsigned char P32Tr[]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00441">crypt.c:441</a></div></div>
<div class="ttc" id="missing_8h_html_a47fa3eb2086507cf2eb232be5379841c"><div class="ttname"><a href="../../d3/d90/missing_8h.html#a47fa3eb2086507cf2eb232be5379841c">crypt</a></div><div class="ttdeci">RUBY_EXTERN char * crypt(const char *, const char *)</div></div>
<div class="ttc" id="crypt_8c_html_af37fdeb6d61d15736ead54f1b8a6df3a"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#af37fdeb6d61d15736ead54f1b8a6df3a">in</a></div><div class="ttdeci">int const char * in</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00639">crypt.c:639</a></div></div>
<div class="ttc" id="crypt_8c_html_a8a1eb1db6dc99f82114ae4594b3593ea"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a8a1eb1db6dc99f82114ae4594b3593ea">tp</a></div><div class="ttdeci">register C_block * tp</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00311">crypt.c:311</a></div></div>
<div class="ttc" id="crypt_8c_html_ad3fb9cc97dae7f6a4addf926032aa4a0"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ad3fb9cc97dae7f6a4addf926032aa4a0">SPE</a></div><div class="ttdeci">static long SPE[2][8][64]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00483">crypt.c:483</a></div></div>
<div class="ttc" id="missing_8h_html"><div class="ttname"><a href="../../d3/d90/missing_8h.html">missing.h</a></div></div>
<div class="ttc" id="crypt_8c_html_a6702f12a379cd011a0e99d5c863c484a"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a6702f12a379cd011a0e99d5c863c484a">keyblock</a></div><div class="ttdeci">C_block keyblock</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00509">crypt.c:509</a></div></div>
<div class="ttc" id="crypt_8c_html_af8856dca2c10738529739b7a65df2e87"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#af8856dca2c10738529739b7a65df2e87">constdatablock</a></div><div class="ttdeci">static C_block constdatablock</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00492">crypt.c:492</a></div></div>
<div class="ttc" id="crypt_8c_html_ac74af7e25757c0f4e0aac279b4fa9a6d"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ac74af7e25757c0f4e0aac279b4fa9a6d">PC1ROT</a></div><div class="ttdeci">static C_block PC1ROT[64/CHUNKBITS][1&lt;&lt; CHUNKBITS]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00474">crypt.c:474</a></div></div>
<div class="ttc" id="crypt_8c_html_a65462adaaad855ead567351e0c8475c4"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a65462adaaad855ead567351e0c8475c4">L0</a></div><div class="ttdeci">L0</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00653">crypt.c:653</a></div></div>
<div class="ttc" id="tcltklib_8c_html_aa47c45738d686ad11e7b9c7c1615fcd2"><div class="ttname"><a href="../../d5/d9d/tcltklib_8c.html#aa47c45738d686ad11e7b9c7c1615fcd2">flag</a></div><div class="ttdeci">flag</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/d9d/tcltklib_8c_source.html#l02039">tcltklib.c:2039</a></div></div>
<div class="ttc" id="crypt_8c_html_ac3e66cac1d02038eda4509f0d4f7a80c"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ac3e66cac1d02038eda4509f0d4f7a80c">PC2</a></div><div class="ttdeci">static unsigned char PC2[]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00370">crypt.c:370</a></div></div>
<div class="ttc" id="crypt_8c_html_af957276b65abd295692175245d603c04"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#af957276b65abd295692175245d603c04">permute</a></div><div class="ttdeci">STATIC void permute()</div></div>
<div class="ttc" id="bigdecimal_8c_html_af5857437ff0274b5a927afe95f104a39"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#af5857437ff0274b5a927afe95f104a39">b</a></div><div class="ttdeci">Real * b</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l01140">bigdecimal.c:1140</a></div></div>
<div class="ttc" id="crypt_8c_html_ac5ce08a9d852fd1e1016698361b1ae8a"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ac5ce08a9d852fd1e1016698361b1ae8a">CIFP</a></div><div class="ttdeci">static unsigned char CIFP[]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00452">crypt.c:452</a></div></div>
<div class="ttc" id="crypt_8c_html_a81031dcd5c94ba95ab1de0ffe6a97bbf"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a81031dcd5c94ba95ab1de0ffe6a97bbf">R1</a></div><div class="ttdeci">R0 &amp; R1</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00675">crypt.c:675</a></div></div>
<div class="ttc" id="crypt_8c_html_aa2378a0e5d6788c77c9e719ecb0291a0"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#aa2378a0e5d6788c77c9e719ecb0291a0">init_des</a></div><div class="ttdeci">STATIC void init_des()</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00759">crypt.c:759</a></div></div>
<div class="ttc" id="crypt_8c_html_a10b2d890d871e1489bb02b7e70d9bdfb"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a10b2d890d871e1489bb02b7e70d9bdfb">STATIC</a></div><div class="ttdeci">#define STATIC</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00115">crypt.c:115</a></div></div>
<div class="ttc" id="union_c__block_html_a48d864bc645bde7086c33a216c41176a"><div class="ttname"><a href="../../df/da2/union_c__block.html#a48d864bc645bde7086c33a216c41176a">C_block::i0</a></div><div class="ttdeci">long i0</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00243">crypt.c:243</a></div></div>
<div class="ttc" id="yaml2byte_8c_html_ad0b08ddfcb8010b1d73d9d635d5e0201"><div class="ttname"><a href="../../dd/dfb/yaml2byte_8c.html#ad0b08ddfcb8010b1d73d9d635d5e0201">NULL</a></div><div class="ttdeci">n NULL</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/dfb/yaml2byte_8c_source.html#l00134">yaml2byte.c:134</a></div></div>
<div class="ttc" id="crypt_8c_html_a9af53e8c6f003c783332ad9b499a7f7c"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a9af53e8c6f003c783332ad9b499a7f7c">Rotates</a></div><div class="ttdeci">static unsigned char Rotates[]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00365">crypt.c:365</a></div></div>
<div class="ttc" id="crypt_8c_html_a2d3c04b14357f1839a3e32c88312e15f"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a2d3c04b14357f1839a3e32c88312e15f">PERM6464</a></div><div class="ttdeci">#define PERM6464(d, d0, d1, cpp, p)</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00300">crypt.c:300</a></div></div>
<div class="ttc" id="crypt_8c_html_a34b754e74efdb8dcb9b6043233bfb2df"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a34b754e74efdb8dcb9b6043233bfb2df">setting</a></div><div class="ttdeci">register const char * setting</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00502">crypt.c:502</a></div></div>
<div class="ttc" id="crypt_8c_html_a5c9b491358c3434f273b874b413afb09"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a5c9b491358c3434f273b874b413afb09">des_cipher</a></div><div class="ttdeci">int des_cipher()</div></div>
<div class="ttc" id="crypt_8c_html_ae39213effe2b09e6b612e9cd6ccefc27"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ae39213effe2b09e6b612e9cd6ccefc27">chars_out</a></div><div class="ttdeci">int chars_out</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00906">crypt.c:906</a></div></div>
<div class="ttc" id="crypt_8c_html_ab644f676d8d67d6265407b73d33a647d"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ab644f676d8d67d6265407b73d33a647d">LOADREG</a></div><div class="ttdeci">#define LOADREG(d, d0, d1, s, s0, s1)</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00273">crypt.c:273</a></div></div>
<div class="ttc" id="union_c__block_html_a387c2a8e0752b0a49330248e77f87023"><div class="ttname"><a href="../../df/da2/union_c__block.html#a387c2a8e0752b0a49330248e77f87023">C_block::b</a></div><div class="ttdeci">unsigned char b[8]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00239">crypt.c:239</a></div></div>
<div class="ttc" id="crypt_8c_html_a9407b59ea8a359bef2f97830a5aebc08"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a9407b59ea8a359bef2f97830a5aebc08">L1</a></div><div class="ttdeci">L1</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00676">crypt.c:676</a></div></div>
<div class="ttc" id="crypt_8c_html_a8fbee099f20911d69a39d82e6fcac459"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a8fbee099f20911d69a39d82e6fcac459">salt_size</a></div><div class="ttdeci">int salt_size</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00508">crypt.c:508</a></div></div>
<div class="ttc" id="crypt_8c_html_a654d8b345f7098c1108e712985321c3c"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a654d8b345f7098c1108e712985321c3c">des_setkey</a></div><div class="ttdeci">int des_setkey()</div></div>
<div class="ttc" id="crypt_8c_html_a3d92a6f0c00c0ed46fdeec86b6da0c4c"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a3d92a6f0c00c0ed46fdeec86b6da0c4c">ExpandTr</a></div><div class="ttdeci">static unsigned char ExpandTr[]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00342">crypt.c:342</a></div></div>
<div class="ttc" id="crypt_8c_html_ab8f66b8c0e8b9c69d47c8b38393f0b07"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ab8f66b8c0e8b9c69d47c8b38393f0b07">perm</a></div><div class="ttdeci">STATIC void C_block perm[64/CHUNKBITS][1&lt;&lt; CHUNKBITS]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00904">crypt.c:904</a></div></div>
<div class="ttc" id="tkutil_8c_html_a300a5cc1ad956ba66d9082e9e1945142"><div class="ttname"><a href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a></div><div class="ttdeci">static int VALUE key</div><div class="ttdef"><b>Definition:</b> <a href="../../d9/dee/tkutil_8c_source.html#l00265">tkutil.c:265</a></div></div>
<div class="ttc" id="crypt_8c_html_ad50d91202186ced15ec3fc3a922506b3"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ad50d91202186ced15ec3fc3a922506b3">STORE</a></div><div class="ttdeci">#define STORE(s, s0, s1, bl)</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00275">crypt.c:275</a></div></div>
<div class="ttc" id="crypt_8c_html_a165a57131af55136a06ae73ff5de0d74"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a165a57131af55136a06ae73ff5de0d74">a64toi</a></div><div class="ttdeci">static unsigned char a64toi[128]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00471">crypt.c:471</a></div></div>
<div class="ttc" id="crypt_8c_html_a916ed973888ae694d78cbe3097e10f0f"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a916ed973888ae694d78cbe3097e10f0f">_PASSWORD_EFMT1</a></div><div class="ttdeci">#define _PASSWORD_EFMT1</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00047">crypt.c:47</a></div></div>
<div class="ttc" id="crypt_8c_html_a1e467111f12800763f28f038bd8cebaa"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a1e467111f12800763f28f038bd8cebaa">PC1</a></div><div class="ttdeci">static unsigned char PC1[]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00353">crypt.c:353</a></div></div>
<div class="ttc" id="strftime_8c_html_a2c212835823e3c54a8ab6d95c652660e"><div class="ttname"><a href="../../d8/d4e/strftime_8c.html#a2c212835823e3c54a8ab6d95c652660e">const</a></div><div class="ttdeci">#define const</div><div class="ttdef"><b>Definition:</b> <a href="../../d8/d4e/strftime_8c_source.html#l00101">strftime.c:101</a></div></div>
<div class="ttc" id="os2_8c_html_a58defbf6fe556592007171f7a347f9d6"><div class="ttname"><a href="../../de/d46/os2_8c.html#a58defbf6fe556592007171f7a347f9d6">s</a></div><div class="ttdeci">register char * s</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d46/os2_8c_source.html#l00056">os2.c:56</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_ac537498b5ed6e25bced70b90e5949201"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#ac537498b5ed6e25bced70b90e5949201">void</a></div><div class="ttdeci">VP_EXPORT void</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l04944">bigdecimal.c:4944</a></div></div>
<div class="ttc" id="crypt_8c_html_aefe059a4e3b401e9378733c2c59878db"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#aefe059a4e3b401e9378733c2c59878db">LGCHUNKBITS</a></div><div class="ttdeci">#define LGCHUNKBITS</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00298">crypt.c:298</a></div></div>
<div class="ttc" id="crypt_8c_html_a136f3095237ae23358c30581753e4178"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a136f3095237ae23358c30581753e4178">KS_SIZE</a></div><div class="ttdeci">#define KS_SIZE</div></div>
<div class="ttc" id="crypt_8c_html_a1cae11ec4891641a52e3a8326d126924"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a1cae11ec4891641a52e3a8326d126924">CF6464</a></div><div class="ttdeci">static C_block CF6464[64/CHUNKBITS][1&lt;&lt; CHUNKBITS]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00486">crypt.c:486</a></div></div>
<div class="ttc" id="crypt_8c_html_a74f47ef83df9b0d710c651e9f6ea594f"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a74f47ef83df9b0d710c651e9f6ea594f">B</a></div><div class="ttdeci">C_block B</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00651">crypt.c:651</a></div></div>
<div class="ttc" id="crypt_8c_html_a2c844749684bfce83e662dee88390dc9"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a2c844749684bfce83e662dee88390dc9">DCL_BLOCK</a></div><div class="ttdeci">#define DCL_BLOCK(d, d0, d1)</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00276">crypt.c:276</a></div></div>
<div class="ttc" id="union_c__block_html_ace63ec71fc3cef8deb34ce3a0a8da5fa"><div class="ttname"><a href="../../df/da2/union_c__block.html#ace63ec71fc3cef8deb34ce3a0a8da5fa">C_block::i1</a></div><div class="ttdeci">long i1</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00244">crypt.c:244</a></div></div>
<div class="ttc" id="crypt_8c_html_a72044a36b6c9a9a7c8381c2df90d1ae7"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a72044a36b6c9a9a7c8381c2df90d1ae7">kp</a></div><div class="ttdeci">register C_block * kp</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00643">crypt.c:643</a></div></div>
<div class="ttc" id="crypt_8c_html_ade137bb0251cdfb9c60e29e405efe2e2"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ade137bb0251cdfb9c60e29e405efe2e2">cryptresult</a></div><div class="ttdeci">static char cryptresult[1+4+4+11+1]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00493">crypt.c:493</a></div></div>
<div class="ttc" id="ripper_8c_html_a93ca48b6ca5634eebe9872b8dc2650ee"><div class="ttname"><a href="../../d5/d11/ripper_8c.html#a93ca48b6ca5634eebe9872b8dc2650ee">t</a></div><div class="ttdeci">int t</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/d11/ripper_8c_source.html#l14285">ripper.c:14285</a></div></div>
<div class="ttc" id="crypt_8c_html_af5b1e159fb6e48c6bd447777b381a7a8"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#af5b1e159fb6e48c6bd447777b381a7a8">IP</a></div><div class="ttdeci">static unsigned char IP[]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00329">crypt.c:329</a></div></div>
<div class="ttc" id="crypt_8c_html_a6c5e316784747b91ac3a602c26cedea0"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a6c5e316784747b91ac3a602c26cedea0">PC2ROT</a></div><div class="ttdeci">static C_block PC2ROT[2][64/CHUNKBITS][1&lt;&lt; CHUNKBITS]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00477">crypt.c:477</a></div></div>
<div class="ttc" id="union_c__block_html"><div class="ttname"><a href="../../df/da2/union_c__block.html">C_block</a></div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00238">crypt.c:238</a></div></div>
<div class="ttc" id="crypt_8c_html_aa63fb92fcb3fdd61c86dc0e0ee707a0e"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#aa63fb92fcb3fdd61c86dc0e0ee707a0e">ks_inc</a></div><div class="ttdeci">register int ks_inc</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00650">crypt.c:650</a></div></div>
<div class="ttc" id="crypt_8c_html_a690b7fe0554b40cc1d5c4204be4fd24b"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a690b7fe0554b40cc1d5c4204be4fd24b">OR</a></div><div class="ttdeci">#define OR(d, d0, d1, bl)</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00274">crypt.c:274</a></div></div>
<div class="ttc" id="crypt_8c_html_a68746f7aa4b680a43bfd8e327d4340bb"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a68746f7aa4b680a43bfd8e327d4340bb">encp</a></div><div class="ttdeci">encp</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00564">crypt.c:564</a></div></div>
<div class="ttc" id="crypt_8c_html_af437ed9a79a4001148d8edae7baeadee"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#af437ed9a79a4001148d8edae7baeadee">salt</a></div><div class="ttdeci">long salt</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00507">crypt.c:507</a></div></div>
<div class="ttc" id="name2ctype_8h_html_a86f2415763322050063a5502f87c9422"><div class="ttname"><a href="../../d3/d15/name2ctype_8h.html#a86f2415763322050063a5502f87c9422">long</a></div><div class="ttdeci">#define long</div><div class="ttdef"><b>Definition:</b> <a href="../../d3/d15/name2ctype_8h_source.html#l00037">name2ctype.h:37</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_acb559820d9ca11295b4500f179ef6392"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a></div><div class="ttdeci">ssize_t i</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l05519">bigdecimal.c:5519</a></div></div>
<div class="ttc" id="crypt_8c_html_ac4ff72292f8daebbe0308b1c756e65a7"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ac4ff72292f8daebbe0308b1c756e65a7">CHUNKBITS</a></div><div class="ttdeci">#define CHUNKBITS</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00299">crypt.c:299</a></div></div>
<div class="ttc" id="crypt_8c_html_ae3e94e9dc24634a41777b3f79cbaf152"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#ae3e94e9dc24634a41777b3f79cbaf152">itoa64</a></div><div class="ttdeci">static unsigned char itoa64[]</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00464">crypt.c:464</a></div></div>
<div class="ttc" id="util_8c_html_af316c33cc298530f245e8b55330e86b5"><div class="ttname"><a href="../../de/df1/util_8c.html#af316c33cc298530f245e8b55330e86b5">D</a></div><div class="ttdeci">#define D</div><div class="ttdef"><b>Definition:</b> <a href="../../de/df1/util_8c_source.html#l00193">util.c:193</a></div></div>
<div class="ttc" id="sha1_8c_html_a8ac24a09e1273548828d3cc9436f9bc7"><div class="ttname"><a href="../../d2/d24/sha1_8c.html#a8ac24a09e1273548828d3cc9436f9bc7">R0</a></div><div class="ttdeci">#define R0(v, w, x, y, z, i)</div><div class="ttdef"><b>Definition:</b> <a href="../../d2/d24/sha1_8c_source.html#l00064">sha1.c:64</a></div></div>
<div class="ttc" id="crypt_8c_html_aec2269ddcef2faf5f35a7257ba3b8f0b"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#aec2269ddcef2faf5f35a7257ba3b8f0b">num_iter</a></div><div class="ttdeci">int num_iter</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00508">crypt.c:508</a></div></div>
<div class="ttc" id="crypt_8c_html_a7b8aa9e9351c17779590208d93d33fb4"><div class="ttname"><a href="../../d6/de3/crypt_8c.html#a7b8aa9e9351c17779590208d93d33fb4">cp</a></div><div class="ttdeci">STATIC void unsigned char * cp</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/de3/crypt_8c_source.html#l00307">crypt.c:307</a></div></div>
</div><!-- fragment --></div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="../../doxygen.png" alt="doxygen"/>
</a> 1.8.5
</small></address>
</body>
</html>