xref: /isa-l_crypto/sha256_mb/sha256_multibinary.asm (revision d28f1034f736e3eb791c3cf6bff3e2fa81fb5331)
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