s390xcpuid.pl: fix comment
[openssl.git] / crypto / s390xcpuid.pl
1 #! /usr/bin/env perl
2 # Copyright 2009-2018 The OpenSSL Project Authors. All Rights Reserved.
3 #
4 # Licensed under the Apache License 2.0 (the "License").  You may not use
5 # this file except in compliance with the License.  You can obtain a copy
6 # in the file LICENSE in the source distribution or at
7 # https://www.openssl.org/source/license.html
8
9 $flavour = shift;
10
11 if ($flavour =~ /3[12]/) {
12         $SIZE_T=4;
13         $g="";
14 } else {
15         $SIZE_T=8;
16         $g="g";
17 }
18
19 while (($output=shift) && ($output!~/\w[\w\-]*\.\w+$/)) {}
20 open STDOUT,">$output";
21
22 $ra="%r14";
23 $sp="%r15";
24 $stdframe=16*$SIZE_T+4*8;
25
26 $code=<<___;
27 #include "s390x_arch.h"
28
29 .text
30
31 .globl  OPENSSL_s390x_facilities
32 .type   OPENSSL_s390x_facilities,\@function
33 .align  16
34 OPENSSL_s390x_facilities:
35         lghi    %r0,0
36         larl    %r4,OPENSSL_s390xcap_P
37
38         stg     %r0,S390X_STFLE+8(%r4)  # wipe capability vectors
39         stg     %r0,S390X_STFLE+16(%r4)
40         stg     %r0,S390X_STFLE+24(%r4)
41
42         .long   0xb2b04000              # stfle 0(%r4)
43         brc     8,.Ldone
44         lghi    %r0,1
45         .long   0xb2b04000              # stfle 0(%r4)
46         brc     8,.Ldone
47         lghi    %r0,2
48         .long   0xb2b04000              # stfle 0(%r4)
49 .Ldone:
50         br      $ra
51 .size   OPENSSL_s390x_facilities,.-OPENSSL_s390x_facilities
52
53 .globl  OPENSSL_s390x_functions
54 .type   OPENSSL_s390x_functions,\@function
55 .align  16
56 OPENSSL_s390x_functions:
57         lghi    %r0,0
58         larl    %r4,OPENSSL_s390xcap_P
59
60         stg     %r0,S390X_KIMD(%r4)     # wipe capability vectors
61         stg     %r0,S390X_KIMD+8(%r4)
62         stg     %r0,S390X_KLMD(%r4)
63         stg     %r0,S390X_KLMD+8(%r4)
64         stg     %r0,S390X_KM(%r4)
65         stg     %r0,S390X_KM+8(%r4)
66         stg     %r0,S390X_KMC(%r4)
67         stg     %r0,S390X_KMC+8(%r4)
68         stg     %r0,S390X_KMAC(%r4)
69         stg     %r0,S390X_KMAC+8(%r4)
70         stg     %r0,S390X_KMCTR(%r4)
71         stg     %r0,S390X_KMCTR+8(%r4)
72         stg     %r0,S390X_KMO(%r4)
73         stg     %r0,S390X_KMO+8(%r4)
74         stg     %r0,S390X_KMF(%r4)
75         stg     %r0,S390X_KMF+8(%r4)
76         stg     %r0,S390X_PRNO(%r4)
77         stg     %r0,S390X_PRNO+8(%r4)
78         stg     %r0,S390X_KMA(%r4)
79         stg     %r0,S390X_KMA+8(%r4)
80         stg     %r0,S390X_PCC(%r4)
81         stg     %r0,S390X_PCC+8(%r4)
82         stg     %r0,S390X_KDSA(%r4)
83         stg     %r0,S390X_KDSA+8(%r4)
84
85         lmg     %r2,%r3,S390X_STFLE(%r4)
86
87         tmhl    %r2,0x4000              # check for message-security-assist
88         jz      .Lret
89
90         lghi    %r0,S390X_QUERY         # query kimd capabilities
91         la      %r1,S390X_KIMD(%r4)
92         .long   0xb93e0002              # kimd %r0,%r2
93
94         lghi    %r0,S390X_QUERY         # query klmd capabilities
95         la      %r1,S390X_KLMD(%r4)
96         .long   0xb93f0002              # klmd %r0,%r2
97
98         lghi    %r0,S390X_QUERY         # query km capability vector
99         la      %r1,S390X_KM(%r4)
100         .long   0xb92e0042              # km %r4,%r2
101
102         lghi    %r0,S390X_QUERY         # query kmc capability vector
103         la      %r1,S390X_KMC(%r4)
104         .long   0xb92f0042              # kmc %r4,%r2
105
106         lghi    %r0,S390X_QUERY         # query kmac capability vector
107         la      %r1,S390X_KMAC(%r4)
108         .long   0xb91e0042              # kmac %r4,%r2
109
110         tmhh    %r3,0x0003              # check for message-security-assist-3
111         jz      .Lret
112
113         lghi    %r0,S390X_QUERY         # query pcc capability vector
114         la      %r1,S390X_PCC(%r4)
115         .long   0xb92c0000              # pcc
116
117         tmhh    %r3,0x0004              # check for message-security-assist-4
118         jz      .Lret
119
120         lghi    %r0,S390X_QUERY         # query kmctr capability vector
121         la      %r1,S390X_KMCTR(%r4)
122         .long   0xb92d2042              # kmctr %r4,%r2,%r2
123
124         lghi    %r0,S390X_QUERY         # query kmo capability vector
125         la      %r1,S390X_KMO(%r4)
126         .long   0xb92b0042              # kmo %r4,%r2
127
128         lghi    %r0,S390X_QUERY         # query kmf capability vector
129         la      %r1,S390X_KMF(%r4)
130         .long   0xb92a0042              # kmf %r4,%r2
131
132         tml     %r2,0x40                # check for message-security-assist-5
133         jz      .Lret
134
135         lghi    %r0,S390X_QUERY         # query prno capability vector
136         la      %r1,S390X_PRNO(%r4)
137         .long   0xb93c0042              # prno %r4,%r2
138
139         lg      %r2,S390X_STFLE+16(%r4)
140
141         tmhl    %r2,0x2000              # check for message-security-assist-8
142         jz      .Lret
143
144         lghi    %r0,S390X_QUERY         # query kma capability vector
145         la      %r1,S390X_KMA(%r4)
146         .long   0xb9294022              # kma %r2,%r4,%r2
147
148         tmhl    %r2,0x0010              # check for message-security-assist-9
149         jz      .Lret
150
151         lghi    %r0,S390X_QUERY         # query kdsa capability vector
152         la      %r1,S390X_KDSA(%r4)
153         .long   0xb93a0002              # kdsa %r0,%r2
154
155 .Lret:
156         br      $ra
157 .size   OPENSSL_s390x_functions,.-OPENSSL_s390x_functions
158
159 .globl  OPENSSL_rdtsc
160 .type   OPENSSL_rdtsc,\@function
161 .align  16
162 OPENSSL_rdtsc:
163         larl    %r4,OPENSSL_s390xcap_P
164         tm      S390X_STFLE+3(%r4),0x40 # check for store-clock-fast facility
165         jz      .Lstck
166
167         .long   0xb27cf010      # stckf 16($sp)
168         lg      %r2,16($sp)
169         br      $ra
170 .Lstck:
171         stck    16($sp)
172         lg      %r2,16($sp)
173         br      $ra
174 .size   OPENSSL_rdtsc,.-OPENSSL_rdtsc
175
176 .globl  OPENSSL_atomic_add
177 .type   OPENSSL_atomic_add,\@function
178 .align  16
179 OPENSSL_atomic_add:
180         l       %r1,0(%r2)
181 .Lspin: lr      %r0,%r1
182         ar      %r0,%r3
183         cs      %r1,%r0,0(%r2)
184         brc     4,.Lspin
185         lgfr    %r2,%r0         # OpenSSL expects the new value
186         br      $ra
187 .size   OPENSSL_atomic_add,.-OPENSSL_atomic_add
188
189 .globl  OPENSSL_wipe_cpu
190 .type   OPENSSL_wipe_cpu,\@function
191 .align  16
192 OPENSSL_wipe_cpu:
193         xgr     %r0,%r0
194         xgr     %r1,%r1
195         lgr     %r2,$sp
196         xgr     %r3,%r3
197         xgr     %r4,%r4
198         lzdr    %f0
199         lzdr    %f1
200         lzdr    %f2
201         lzdr    %f3
202         lzdr    %f4
203         lzdr    %f5
204         lzdr    %f6
205         lzdr    %f7
206         br      $ra
207 .size   OPENSSL_wipe_cpu,.-OPENSSL_wipe_cpu
208
209 .globl  OPENSSL_cleanse
210 .type   OPENSSL_cleanse,\@function
211 .align  16
212 OPENSSL_cleanse:
213 #if !defined(__s390x__) && !defined(__s390x)
214         llgfr   %r3,%r3
215 #endif
216         lghi    %r4,15
217         lghi    %r0,0
218         clgr    %r3,%r4
219         jh      .Lot
220         clgr    %r3,%r0
221         bcr     8,%r14
222 .Little:
223         stc     %r0,0(%r2)
224         la      %r2,1(%r2)
225         brctg   %r3,.Little
226         br      %r14
227 .align  4
228 .Lot:   tmll    %r2,7
229         jz      .Laligned
230         stc     %r0,0(%r2)
231         la      %r2,1(%r2)
232         brctg   %r3,.Lot
233 .Laligned:
234         srlg    %r4,%r3,3
235 .Loop:  stg     %r0,0(%r2)
236         la      %r2,8(%r2)
237         brctg   %r4,.Loop
238         lghi    %r4,7
239         ngr     %r3,%r4
240         jnz     .Little
241         br      $ra
242 .size   OPENSSL_cleanse,.-OPENSSL_cleanse
243
244 .globl  CRYPTO_memcmp
245 .type   CRYPTO_memcmp,\@function
246 .align  16
247 CRYPTO_memcmp:
248 #if !defined(__s390x__) && !defined(__s390x)
249         llgfr   %r4,%r4
250 #endif
251         lghi    %r5,0
252         clgr    %r4,%r5
253         je      .Lno_data
254
255 .Loop_cmp:
256         llgc    %r0,0(%r2)
257         la      %r2,1(%r2)
258         llgc    %r1,0(%r3)
259         la      %r3,1(%r3)
260         xr      %r1,%r0
261         or      %r5,%r1
262         brctg   %r4,.Loop_cmp
263
264         lnr     %r5,%r5
265         srl     %r5,31
266 .Lno_data:
267         lgr     %r2,%r5
268         br      $ra
269 .size   CRYPTO_memcmp,.-CRYPTO_memcmp
270
271 .globl  OPENSSL_instrument_bus
272 .type   OPENSSL_instrument_bus,\@function
273 .align  16
274 OPENSSL_instrument_bus:
275         lghi    %r2,0
276         br      %r14
277 .size   OPENSSL_instrument_bus,.-OPENSSL_instrument_bus
278
279 .globl  OPENSSL_instrument_bus2
280 .type   OPENSSL_instrument_bus2,\@function
281 .align  16
282 OPENSSL_instrument_bus2:
283         lghi    %r2,0
284         br      $ra
285 .size   OPENSSL_instrument_bus2,.-OPENSSL_instrument_bus2
286
287 .globl  OPENSSL_vx_probe
288 .type   OPENSSL_vx_probe,\@function
289 .align  16
290 OPENSSL_vx_probe:
291         .word   0xe700,0x0000,0x0044    # vzero %v0
292         br      $ra
293 .size   OPENSSL_vx_probe,.-OPENSSL_vx_probe
294 ___
295
296 {
297 ################
298 # void s390x_kimd(const unsigned char *in, size_t len, unsigned int fc,
299 #                 void *param)
300 my ($in,$len,$fc,$param) = map("%r$_",(2..5));
301 $code.=<<___;
302 .globl  s390x_kimd
303 .type   s390x_kimd,\@function
304 .align  16
305 s390x_kimd:
306         llgfr   %r0,$fc
307         lgr     %r1,$param
308
309         .long   0xb93e0002      # kimd %r0,%r2
310         brc     1,.-4           # pay attention to "partial completion"
311
312         br      $ra
313 .size   s390x_kimd,.-s390x_kimd
314 ___
315 }
316
317 {
318 ################
319 # void s390x_klmd(const unsigned char *in, size_t inlen, unsigned char *out,
320 #                 size_t outlen, unsigned int fc, void *param)
321 my ($in,$inlen,$out,$outlen,$fc) = map("%r$_",(2..6));
322 $code.=<<___;
323 .globl  s390x_klmd
324 .type   s390x_klmd,\@function
325 .align  32
326 s390x_klmd:
327         llgfr   %r0,$fc
328         l${g}   %r1,$stdframe($sp)
329
330         .long   0xb93f0042      # klmd %r4,%r2
331         brc     1,.-4           # pay attention to "partial completion"
332
333         br      $ra
334 .size   s390x_klmd,.-s390x_klmd
335 ___
336 }
337
338 ################
339 # void s390x_km(const unsigned char *in, size_t len, unsigned char *out,
340 #               unsigned int fc, void *param)
341 {
342 my ($in,$len,$out,$fc,$param) = map("%r$_",(2..6));
343 $code.=<<___;
344 .globl  s390x_km
345 .type   s390x_km,\@function
346 .align  16
347 s390x_km:
348         lr      %r0,$fc
349         l${g}r  %r1,$param
350
351         .long   0xb92e0042      # km $out,$in
352         brc     1,.-4           # pay attention to "partial completion"
353
354         br      $ra
355 .size   s390x_km,.-s390x_km
356 ___
357 }
358
359 ################
360 # void s390x_kmac(const unsigned char *in, size_t len, unsigned int fc,
361 #                 void *param)
362 {
363 my ($in,$len,$fc,$param) = map("%r$_",(2..5));
364 $code.=<<___;
365 .globl  s390x_kmac
366 .type   s390x_kmac,\@function
367 .align  16
368 s390x_kmac:
369         lr      %r0,$fc
370         l${g}r  %r1,$param
371
372         .long   0xb91e0002      # kmac %r0,$in
373         brc     1,.-4           # pay attention to "partial completion"
374
375         br      $ra
376 .size   s390x_kmac,.-s390x_kmac
377 ___
378 }
379
380 ################
381 # void s390x_kmo(const unsigned char *in, size_t len, unsigned char *out,
382 #                unsigned int fc, void *param)
383 {
384 my ($in,$len,$out,$fc,$param) = map("%r$_",(2..6));
385 $code.=<<___;
386 .globl  s390x_kmo
387 .type   s390x_kmo,\@function
388 .align  16
389 s390x_kmo:
390         lr      %r0,$fc
391         l${g}r  %r1,$param
392
393         .long   0xb92b0042      # kmo $out,$in
394         brc     1,.-4           # pay attention to "partial completion"
395
396         br      $ra
397 .size   s390x_kmo,.-s390x_kmo
398 ___
399 }
400
401 ################
402 # void s390x_kmf(const unsigned char *in, size_t len, unsigned char *out,
403 #                unsigned int fc, void *param)
404 {
405 my ($in,$len,$out,$fc,$param) = map("%r$_",(2..6));
406 $code.=<<___;
407 .globl  s390x_kmf
408 .type   s390x_kmf,\@function
409 .align  16
410 s390x_kmf:
411         lr      %r0,$fc
412         l${g}r  %r1,$param
413
414         .long   0xb92a0042      # kmf $out,$in
415         brc     1,.-4           # pay attention to "partial completion"
416
417         br      $ra
418 .size   s390x_kmf,.-s390x_kmf
419 ___
420 }
421
422 ################
423 # void s390x_kma(const unsigned char *aad, size_t alen,
424 #                const unsigned char *in, size_t len,
425 #                unsigned char *out, unsigned int fc, void *param)
426 {
427 my ($aad,$alen,$in,$len,$out) = map("%r$_",(2..6));
428 $code.=<<___;
429 .globl  s390x_kma
430 .type   s390x_kma,\@function
431 .align  16
432 s390x_kma:
433         st${g}  $out,6*$SIZE_T($sp)
434         lm${g}  %r0,%r1,$stdframe($sp)
435
436         .long   0xb9292064      # kma $out,$aad,$in
437         brc     1,.-4           # pay attention to "partial completion"
438
439         l${g}   $out,6*$SIZE_T($sp)
440         br      $ra
441 .size   s390x_kma,.-s390x_kma
442 ___
443 }
444
445 ################
446 # int s390x_pcc(unsigned int fc, void *param)
447 {
448 my ($fc,$param) = map("%r$_",(2..3));
449 $code.=<<___;
450 .globl  s390x_pcc
451 .type   s390x_pcc,\@function
452 .align  16
453 s390x_pcc:
454         lr      %r0,$fc
455         l${g}r  %r1,$param
456         lhi     %r2,0
457
458         .long   0xb92c0000      # pcc
459         brc     1,.-4           # pay attention to "partial completion"
460         brc     7,.Lpcc_err     # if CC==0 return 0, else return 1
461 .Lpcc_out:
462         br      $ra
463 .Lpcc_err:
464         lhi     %r2,1
465         j       .Lpcc_out
466 .size   s390x_pcc,.-s390x_pcc
467 ___
468 }
469
470 ################
471 # int s390x_kdsa(unsigned int fc, void *param,
472 #                const unsigned char *in, size_t len)
473 {
474 my ($fc,$param,$in,$len) = map("%r$_",(2..5));
475 $code.=<<___;
476 .globl  s390x_kdsa
477 .type   s390x_kdsa,\@function
478 .align  16
479 s390x_kdsa:
480         lr      %r0,$fc
481         l${g}r  %r1,$param
482         lhi     %r2,0
483
484         .long   0xb93a0004      # kdsa %r0,$in
485         brc     1,.-4           # pay attention to "partial completion"
486         brc     7,.Lkdsa_err    # if CC==0 return 0, else return 1
487 .Lkdsa_out:
488         br      $ra
489 .Lkdsa_err:
490         lhi     %r2,1
491         j       .Lkdsa_out
492 .size   s390x_kdsa,.-s390x_kdsa
493 ___
494 }
495
496 $code.=<<___;
497 .section        .init
498         brasl   $ra,OPENSSL_cpuid_setup
499 ___
500
501 $code =~ s/\`([^\`]*)\`/eval $1/gem;
502 print $code;
503 close STDOUT;   # force flush