⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 vmac_8cpp-source.html

📁 著名的密码库Crypto++的文档 C++语言的杰作。程序员必备。
💻 HTML
📖 第 1 页 / 共 5 页
字号:
<a name="l00109"></a>00109                         memcpy(<a class="code" href="class_v_m_a_c___base.html#e35d611e167eb767e073bc84484798e7">m_nonce</a>(), IV, s);<a name="l00110"></a>00110                         <a class="code" href="class_v_m_a_c___base.html#e35d611e167eb767e073bc84484798e7">m_nonce</a>()[s-1] &amp;= 0xfe;<a name="l00111"></a>00111                         AccessCipher().<a class="code" href="class_block_transformation.html#2fefb3f4c6c6297c0c91fcbba9e4f4f3" title="encrypt or decrypt one block">ProcessBlock</a>(<a class="code" href="class_v_m_a_c___base.html#e35d611e167eb767e073bc84484798e7">m_nonce</a>(), <a class="code" href="class_v_m_a_c___base.html#06d8287263e19935d1d8089876e6dc85">m_pad</a>());<a name="l00112"></a>00112                         <a class="code" href="class_v_m_a_c___base.html#02596234f2eb210428573f3062244a0d">m_padCached</a> = <span class="keyword">true</span>;<a name="l00113"></a>00113                 }<a name="l00114"></a>00114                 <a class="code" href="class_v_m_a_c___base.html#e35d611e167eb767e073bc84484798e7">m_nonce</a>()[s-1] = IV[s-1];<a name="l00115"></a>00115         }<a name="l00116"></a>00116         <a class="code" href="class_v_m_a_c___base.html#cee066bf89503f32699aba376c874fce">m_isFirstBlock</a> = <span class="keyword">true</span>;<a name="l00117"></a>00117         <a class="code" href="class_iterated_hash_base.html#d53da712634ea213ad047b2a68b0fe70" title="discard the current state, and restart with a new message">Restart</a>();<a name="l00118"></a>00118 }<a name="l00119"></a>00119 <a name="l00120"></a><a class="code" href="class_v_m_a_c___base.html#fc475d6a455618658c07049b39df582a">00120</a> <span class="keywordtype">void</span> <a class="code" href="class_v_m_a_c___base.html#fc475d6a455618658c07049b39df582a">VMAC_Base::HashEndianCorrectedBlock</a>(<span class="keyword">const</span> word64 *data)<a name="l00121"></a>00121 {<a name="l00122"></a>00122         assert(<span class="keyword">false</span>);<a name="l00123"></a>00123 }<a name="l00124"></a>00124 <a name="l00125"></a>00125 <span class="preprocessor">#if CRYPTOPP_BOOL_SSE2_ASM_AVAILABLE &amp;&amp; CRYPTOPP_BOOL_X86</span><a name="l00126"></a>00126 <span class="preprocessor"></span><span class="preprocessor">#pragma warning(disable: 4731)  // frame pointer register 'ebp' modified by inline assembly code</span><a name="l00127"></a>00127 <span class="preprocessor"></span><span class="keywordtype">void</span><a name="l00128"></a>00128 <span class="preprocessor">#ifdef __GNUC__</span><a name="l00129"></a>00129 <span class="preprocessor"></span>__attribute__ ((noinline))              <span class="comment">// Intel Compiler 9.1 workaround</span><a name="l00130"></a>00130 <span class="preprocessor">#endif</span><a name="l00131"></a>00131 <span class="preprocessor"></span>VMAC_Base::VHASH_Update_SSE2(<span class="keyword">const</span> word64 *data, <span class="keywordtype">size_t</span> blocksRemainingInWord64, <span class="keywordtype">int</span> tagPart)<a name="l00132"></a>00132 {<a name="l00133"></a>00133         <span class="keyword">const</span> word64 *nhK = <a class="code" href="class_v_m_a_c___base.html#fd452fbdfcf6b297b27249e6788ecbec">m_nhKey</a>();<a name="l00134"></a>00134         word64 *polyS = <a class="code" href="class_v_m_a_c___base.html#674767bdfe5ba30deaf057b0750f11a5">m_polyState</a>();<a name="l00135"></a>00135 <a name="l00136"></a>00136 <span class="preprocessor">#ifdef __GNUC__</span><a name="l00137"></a>00137 <span class="preprocessor"></span>        word32 temp;<a name="l00138"></a>00138         __asm__ __volatile__<a name="l00139"></a>00139         (<a name="l00140"></a>00140         AS2(    mov             %%ebx, %0)<a name="l00141"></a>00141         AS2(    mov             %1, %%ebx)<a name="l00142"></a>00142         <span class="stringliteral">".intel_syntax noprefix;"</span><a name="l00143"></a>00143 #<span class="keywordflow">else</span><a name="l00144"></a>00144         #<span class="keywordflow">if</span> _MSC_VER &lt; 1300<a name="l00145"></a>00145         word32 L1KeyLength = <a class="code" href="class_v_m_a_c___base.html#59b7e6dadc750dd324db269c8a5f59b9">m_L1KeyLength</a>;<a name="l00146"></a>00146         <span class="keywordtype">char</span> isFirstBlock = <a class="code" href="class_v_m_a_c___base.html#cee066bf89503f32699aba376c874fce">m_isFirstBlock</a>;<a name="l00147"></a>00147         AS2(    mov             ebx, [L1KeyLength])<a name="l00148"></a>00148         AS2(    mov             dl, [isFirstBlock])<a name="l00149"></a>00149         <span class="preprocessor">#else</span><a name="l00150"></a>00150 <span class="preprocessor"></span>        AS2(    mov             ecx, <span class="keyword">this</span>)<a name="l00151"></a>00151         AS2(    mov             ebx, [ecx+<a class="code" href="class_v_m_a_c___base.html#59b7e6dadc750dd324db269c8a5f59b9">m_L1KeyLength</a>])<a name="l00152"></a>00152         AS2(    mov             dl, [ecx+<a class="code" href="class_v_m_a_c___base.html#cee066bf89503f32699aba376c874fce">m_isFirstBlock</a>])<a name="l00153"></a>00153         <span class="preprocessor">#endif</span><a name="l00154"></a>00154 <span class="preprocessor"></span>        AS2(    mov             eax, tagPart)<a name="l00155"></a>00155         AS2(    shl             eax, 4)<a name="l00156"></a>00156         AS2(    mov             edi, nhK)<a name="l00157"></a>00157         AS2(    add             edi, eax)<a name="l00158"></a>00158         AS2(    add             eax, eax)<a name="l00159"></a>00159         AS2(    add             eax, polyS)<a name="l00160"></a>00160 <a name="l00161"></a>00161         AS2(    mov             esi, data)<a name="l00162"></a>00162         AS2(    mov             ecx, blocksRemainingInWord64)<a name="l00163"></a>00163 <span class="preprocessor">#endif</span><a name="l00164"></a>00164 <span class="preprocessor"></span><a name="l00165"></a>00165         AS2(    shr             ebx, 3)<a name="l00166"></a>00166         AS1(    push    ebp)<a name="l00167"></a>00167         AS2(    sub             esp, 12)<a name="l00168"></a>00168         ASL(4)<a name="l00169"></a>00169         AS2(    mov             ebp, ebx)<a name="l00170"></a>00170         AS2(    cmp             ecx, ebx)<a name="l00171"></a>00171         AS2(    cmovl   ebp, ecx)<a name="l00172"></a>00172         AS2(    sub             ecx, ebp)<a name="l00173"></a>00173         AS2(    lea             ebp, [edi+8*ebp])       <span class="comment">// end of nhK</span><a name="l00174"></a>00174         AS2(    movq    mm6, [esi])<a name="l00175"></a>00175         AS2(    paddq   mm6, [edi])<a name="l00176"></a>00176         AS2(    movq    mm5, [esi+8])<a name="l00177"></a>00177         AS2(    paddq   mm5, [edi+8])<a name="l00178"></a>00178         AS2(    add             esi, 16)<a name="l00179"></a>00179         AS2(    add             edi, 16)<a name="l00180"></a>00180         AS2(    movq    mm4, mm6)<a name="l00181"></a>00181         ASS(    pshufw  mm2, mm6, 1, 0, 3, 2)<a name="l00182"></a>00182         AS2(    pmuludq mm6, mm5)<a name="l00183"></a>00183         ASS(    pshufw  mm3, mm5, 1, 0, 3, 2)<a name="l00184"></a>00184         AS2(    pmuludq mm5, mm2)<a name="l00185"></a>00185         AS2(    pmuludq mm2, mm3)<a name="l00186"></a>00186         AS2(    pmuludq mm3, mm4)<a name="l00187"></a>00187         AS2(    pxor    mm7, mm7)<a name="l00188"></a>00188         AS2(    movd    [esp], mm6)<a name="l00189"></a>00189         AS2(    psrlq   mm6, 32)<a name="l00190"></a>00190         AS2(    movd    [esp+4], mm5)<a name="l00191"></a>00191         AS2(    psrlq   mm5, 32)<a name="l00192"></a>00192         AS2(    cmp             edi, ebp)<a name="l00193"></a>00193         ASJ(    je,             1, f)<a name="l00194"></a>00194         ASL(0)<a name="l00195"></a>00195         AS2(    movq    mm0, [esi])<a name="l00196"></a>00196         AS2(    paddq   mm0, [edi])<a name="l00197"></a>00197         AS2(    movq    mm1, [esi+8])<a name="l00198"></a>00198         AS2(    paddq   mm1, [edi+8])<a name="l00199"></a>00199         AS2(    add             esi, 16)<a name="l00200"></a>00200         AS2(    add             edi, 16)<a name="l00201"></a>00201         AS2(    movq    mm4, mm0)<a name="l00202"></a>00202         AS2(    paddq   mm5, mm2)<a name="l00203"></a>00203         ASS(    pshufw  mm2, mm0, 1, 0, 3, 2)<a name="l00204"></a>00204         AS2(    pmuludq mm0, mm1)<a name="l00205"></a>00205         AS2(    movd    [esp+8], mm3)<a name="l00206"></a>00206         AS2(    psrlq   mm3, 32)<a name="l00207"></a>00207         AS2(    paddq   mm5, mm3)<a name="l00208"></a>00208         ASS(    pshufw  mm3, mm1, 1, 0, 3, 2)<a name="l00209"></a>00209         AS2(    pmuludq mm1, mm2)<a name="l00210"></a>00210         AS2(    pmuludq mm2, mm3)<a name="l00211"></a>00211         AS2(    pmuludq mm3, mm4)<a name="l00212"></a>00212         AS2(    movd    mm4, [esp])<a name="l00213"></a>00213         AS2(    paddq   mm7, mm4)<a name="l00214"></a>00214         AS2(    movd    mm4, [esp+4])<a name="l00215"></a>00215         AS2(    paddq   mm6, mm4)<a name="l00216"></a>00216         AS2(    movd    mm4, [esp+8])<a name="l00217"></a>00217         AS2(    paddq   mm6, mm4)<a name="l00218"></a>00218         AS2(    movd    [esp], mm0)<a name="l00219"></a>00219         AS2(    psrlq   mm0, 32)<a name="l00220"></a>00220         AS2(    paddq   mm6, mm0)<a name="l00221"></a>00221         AS2(    movd    [esp+4], mm1)<a name="l00222"></a>00222         AS2(    psrlq   mm1, 32)<a name="l00223"></a>00223         AS2(    paddq   mm5, mm1)<a name="l00224"></a>00224         AS2(    cmp             edi, ebp)<a name="l00225"></a>00225         ASJ(    jne,    0, b)<a name="l00226"></a>00226         ASL(1)<a name="l00227"></a>00227         AS2(    paddq   mm5, mm2)<a name="l00228"></a>00228         AS2(    movd    [esp+8], mm3)<a name="l00229"></a>00229         AS2(    psrlq   mm3, 32)<a name="l00230"></a>00230         AS2(    paddq   mm5, mm3)<a name="l00231"></a>00231         AS2(    movd    mm4, [esp])<a name="l00232"></a>00232         AS2(    paddq   mm7, mm4)<a name="l00233"></a>00233         AS2(    movd    mm4, [esp+4])<a name="l00234"></a>00234         AS2(    paddq   mm6, mm4)<a name="l00235"></a>00235         AS2(    movd    mm4, [esp+8])<a name="l00236"></a>00236         AS2(    paddq   mm6, mm4)<a name="l00237"></a>00237         AS2(    lea             ebp, [8*ebx])

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -