16df3ef80SGreg Tucker;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 26df3ef80SGreg Tucker; Copyright(c) 2011-2016 Intel Corporation All rights reserved. 36df3ef80SGreg Tucker; 46df3ef80SGreg Tucker; Redistribution and use in source and binary forms, with or without 56df3ef80SGreg Tucker; modification, are permitted provided that the following conditions 66df3ef80SGreg Tucker; are met: 76df3ef80SGreg Tucker; * Redistributions of source code must retain the above copyright 86df3ef80SGreg Tucker; notice, this list of conditions and the following disclaimer. 96df3ef80SGreg Tucker; * Redistributions in binary form must reproduce the above copyright 106df3ef80SGreg Tucker; notice, this list of conditions and the following disclaimer in 116df3ef80SGreg Tucker; the documentation and/or other materials provided with the 126df3ef80SGreg Tucker; distribution. 136df3ef80SGreg Tucker; * Neither the name of Intel Corporation nor the names of its 146df3ef80SGreg Tucker; contributors may be used to endorse or promote products derived 156df3ef80SGreg Tucker; from this software without specific prior written permission. 166df3ef80SGreg Tucker; 176df3ef80SGreg Tucker; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 186df3ef80SGreg Tucker; "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 196df3ef80SGreg Tucker; LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 206df3ef80SGreg Tucker; A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 216df3ef80SGreg Tucker; OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 226df3ef80SGreg Tucker; SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 236df3ef80SGreg Tucker; LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 246df3ef80SGreg Tucker; DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 256df3ef80SGreg Tucker; THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 266df3ef80SGreg Tucker; (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 276df3ef80SGreg Tucker; OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 286df3ef80SGreg Tucker;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 296df3ef80SGreg Tucker 306df3ef80SGreg Tucker%include "reg_sizes.asm" 316df3ef80SGreg Tucker%include "multibinary.asm" 326df3ef80SGreg Tuckerdefault rel 336df3ef80SGreg Tucker[bits 64] 346df3ef80SGreg Tucker 356df3ef80SGreg Tucker; declare the L3 ctx level symbols (these will then call the appropriate 366df3ef80SGreg Tucker; L2 symbols) 372fb85107SPablo de Laraextern _sha256_ctx_mgr_init_sse 382fb85107SPablo de Laraextern _sha256_ctx_mgr_submit_sse 392fb85107SPablo de Laraextern _sha256_ctx_mgr_flush_sse 406df3ef80SGreg Tucker 412fb85107SPablo de Laraextern _sha256_ctx_mgr_init_avx 422fb85107SPablo de Laraextern _sha256_ctx_mgr_submit_avx 432fb85107SPablo de Laraextern _sha256_ctx_mgr_flush_avx 446df3ef80SGreg Tucker 452fb85107SPablo de Laraextern _sha256_ctx_mgr_init_avx2 462fb85107SPablo de Laraextern _sha256_ctx_mgr_submit_avx2 472fb85107SPablo de Laraextern _sha256_ctx_mgr_flush_avx2 486df3ef80SGreg Tucker 492fb85107SPablo de Laraextern _sha256_ctx_mgr_init_base 502fb85107SPablo de Laraextern _sha256_ctx_mgr_submit_base 512fb85107SPablo de Laraextern _sha256_ctx_mgr_flush_base 52a907b4f0SChunyang Hui 532fb85107SPablo de Laraextern _sha256_ctx_mgr_init_avx512 542fb85107SPablo de Laraextern _sha256_ctx_mgr_submit_avx512 552fb85107SPablo de Laraextern _sha256_ctx_mgr_flush_avx512 566df3ef80SGreg Tucker 572fb85107SPablo de Laraextern _sha256_ctx_mgr_init_sse_ni 582fb85107SPablo de Laraextern _sha256_ctx_mgr_submit_sse_ni 592fb85107SPablo de Laraextern _sha256_ctx_mgr_flush_sse_ni 6010f7e16bSXiaodong Liu 612fb85107SPablo de Laraextern _sha256_ctx_mgr_init_avx512_ni 622fb85107SPablo de Laraextern _sha256_ctx_mgr_submit_avx512_ni 632fb85107SPablo de Laraextern _sha256_ctx_mgr_flush_avx512_ni 6410f7e16bSXiaodong Liu 656df3ef80SGreg Tucker;;; *_mbinit are initial values for *_dispatched; is updated on first call. 666df3ef80SGreg Tucker;;; Therefore, *_dispatch_init is only executed on first call. 676df3ef80SGreg Tucker 686df3ef80SGreg Tucker; Initialise symbols 69*bc903ec1SPablo de Larambin_interface _sha256_ctx_mgr_init 70*bc903ec1SPablo de Larambin_interface _sha256_ctx_mgr_submit 71*bc903ec1SPablo de Larambin_interface _sha256_ctx_mgr_flush 726df3ef80SGreg Tucker 73*bc903ec1SPablo de Larambin_dispatch_base_to_avx512_shani _sha256_ctx_mgr_init, _sha256_ctx_mgr_init_base, \ 742fb85107SPablo de Lara _sha256_ctx_mgr_init_sse, _sha256_ctx_mgr_init_avx, _sha256_ctx_mgr_init_avx2, \ 752fb85107SPablo de Lara _sha256_ctx_mgr_init_avx512, _sha256_ctx_mgr_init_sse_ni, _sha256_ctx_mgr_init_avx512_ni 76*bc903ec1SPablo de Larambin_dispatch_base_to_avx512_shani _sha256_ctx_mgr_submit, _sha256_ctx_mgr_submit_base, \ 772fb85107SPablo de Lara _sha256_ctx_mgr_submit_sse, _sha256_ctx_mgr_submit_avx, _sha256_ctx_mgr_submit_avx2, \ 782fb85107SPablo de Lara _sha256_ctx_mgr_submit_avx512, _sha256_ctx_mgr_submit_sse_ni, _sha256_ctx_mgr_submit_avx512_ni 79*bc903ec1SPablo de Larambin_dispatch_base_to_avx512_shani _sha256_ctx_mgr_flush, _sha256_ctx_mgr_flush_base, \ 802fb85107SPablo de Lara _sha256_ctx_mgr_flush_sse, _sha256_ctx_mgr_flush_avx, _sha256_ctx_mgr_flush_avx2, \ 812fb85107SPablo de Lara _sha256_ctx_mgr_flush_avx512, _sha256_ctx_mgr_flush_sse_ni, _sha256_ctx_mgr_flush_avx512_ni 826df3ef80SGreg Tucker 836df3ef80SGreg Tucker;;; func core, ver, snum 84a907b4f0SChunyang Huislversion sha256_ctx_mgr_init, 00, 04, 0160 85a907b4f0SChunyang Huislversion sha256_ctx_mgr_submit, 00, 04, 0161 86a907b4f0SChunyang Huislversion sha256_ctx_mgr_flush, 00, 04, 0162 87