aes-s390x.pl: fix crash in AES_set_decrypt_key in linux32-s390x build [from HEAD].

This commit is contained in:
Andy Polyakov 2012-04-09 15:12:30 +00:00
parent 3a89e9f106
commit bc0f56d6d7

View File

@ -837,7 +837,8 @@ $code.=<<___ if (!$softonly);
je 1f je 1f
lg %r1,24($inp) lg %r1,24($inp)
stg %r1,24($key) stg %r1,24($key)
1: st $bits,236($key) # save bits 1: st $bits,236($key) # save bits [for debugging purposes]
lgr $t0,%r5
st %r5,240($key) # save km code st %r5,240($key) # save km code
lghi %r2,0 lghi %r2,0
br %r14 br %r14
@ -845,7 +846,7 @@ ___
$code.=<<___; $code.=<<___;
.align 16 .align 16
.Lekey_internal: .Lekey_internal:
stm${g} %r6,%r13,6*$SIZE_T($sp) # all non-volatile regs stm${g} %r4,%r13,4*$SIZE_T($sp) # all non-volatile regs and $key
larl $tbl,AES_Te+2048 larl $tbl,AES_Te+2048
@ -905,8 +906,9 @@ $code.=<<___;
la $key,16($key) # key+=4 la $key,16($key) # key+=4
la $t3,4($t3) # i++ la $t3,4($t3) # i++
brct $rounds,.L128_loop brct $rounds,.L128_loop
lghi $t0,10
lghi %r2,0 lghi %r2,0
lm${g} %r6,%r13,6*$SIZE_T($sp) lm${g} %r4,%r13,4*$SIZE_T($sp)
br $ra br $ra
.align 16 .align 16
@ -953,8 +955,9 @@ $code.=<<___;
st $s2,32($key) st $s2,32($key)
st $s3,36($key) st $s3,36($key)
brct $rounds,.L192_continue brct $rounds,.L192_continue
lghi $t0,12
lghi %r2,0 lghi %r2,0
lm${g} %r6,%r13,6*$SIZE_T($sp) lm${g} %r4,%r13,4*$SIZE_T($sp)
br $ra br $ra
.align 16 .align 16
@ -1015,8 +1018,9 @@ $code.=<<___;
st $s2,40($key) st $s2,40($key)
st $s3,44($key) st $s3,44($key)
brct $rounds,.L256_continue brct $rounds,.L256_continue
lghi $t0,14
lghi %r2,0 lghi %r2,0
lm${g} %r6,%r13,6*$SIZE_T($sp) lm${g} %r4,%r13,4*$SIZE_T($sp)
br $ra br $ra
.align 16 .align 16
@ -1067,34 +1071,26 @@ $code.=<<___;
.type private_AES_set_decrypt_key,\@function .type private_AES_set_decrypt_key,\@function
.align 16 .align 16
private_AES_set_decrypt_key: private_AES_set_decrypt_key:
st${g} $key,4*$SIZE_T($sp) # I rely on AES_set_encrypt_key to #st${g} $key,4*$SIZE_T($sp) # I rely on AES_set_encrypt_key to
st${g} $ra,14*$SIZE_T($sp) # save non-volatile registers! st${g} $ra,14*$SIZE_T($sp) # save non-volatile registers and $key!
bras $ra,_s390x_AES_set_encrypt_key bras $ra,_s390x_AES_set_encrypt_key
l${g} $key,4*$SIZE_T($sp) #l${g} $key,4*$SIZE_T($sp)
l${g} $ra,14*$SIZE_T($sp) l${g} $ra,14*$SIZE_T($sp)
ltgr %r2,%r2 ltgr %r2,%r2
bnzr $ra bnzr $ra
___ ___
$code.=<<___ if (!$softonly); $code.=<<___ if (!$softonly);
l $t0,240($key) #l $t0,240($key)
lhi $t1,16 lhi $t1,16
cr $t0,$t1 cr $t0,$t1
jl .Lgo jl .Lgo
oill $t0,0x80 # set "decrypt" bit oill $t0,0x80 # set "decrypt" bit
st $t0,240($key) st $t0,240($key)
br $ra br $ra
.align 16
.Ldkey_internal:
st${g} $key,4*$SIZE_T($sp)
st${g} $ra,14*$SIZE_T($sp)
bras $ra,.Lekey_internal
l${g} $key,4*$SIZE_T($sp)
l${g} $ra,14*$SIZE_T($sp)
___ ___
$code.=<<___; $code.=<<___;
.align 16
.Lgo: llgf $rounds,240($key) .Lgo: lgr $rounds,$t0 #llgf $rounds,240($key)
la $i1,0($key) la $i1,0($key)
sllg $i2,$rounds,4 sllg $i2,$rounds,4
la $i2,0($i2,$key) la $i2,0($i2,$key)