Commit d714abee authored by Heiko Carstens's avatar Heiko Carstens Committed by Vasily Gorbik

s390/vdso: Use one large alternative instead of an alternative branch

Replace the alternative branch with a larger alternative that contains
both paths. That way the two paths are closer together and it is easier
to change both paths if the need should arise.
Signed-off-by: default avatarHeiko Carstens <hca@linux.ibm.com>
Reviewed-by: default avatarJens Remus <jremus@linux.ibm.com>
Signed-off-by: default avatarVasily Gorbik <gor@linux.ibm.com>
parent c902b578
...@@ -130,16 +130,22 @@ SYM_FUNC_START(__arch_chacha20_blocks_nostack) ...@@ -130,16 +130,22 @@ SYM_FUNC_START(__arch_chacha20_blocks_nostack)
/* OUTPUT3 = STATE3 + COPY3 */ /* OUTPUT3 = STATE3 + COPY3 */
VAF STATE3,STATE3,COPY3 VAF STATE3,STATE3,COPY3
/* ALTERNATIVE \
* 32 bit wise little endian store to OUTPUT. If the vector __stringify( \
* enhancement facility 2 is not installed use the slow path. /* Convert STATE to little endian and store to OUTPUT */\
*/ VPERM TMP0,STATE0,STATE0,BEPERM; \
ALTERNATIVE "brc 0xf,.Lstoreslow", "nop", ALT_FACILITY(148) VPERM TMP1,STATE1,STATE1,BEPERM; \
VSTBRF STATE0,0,,%r2 VPERM TMP2,STATE2,STATE2,BEPERM; \
VSTBRF STATE1,16,,%r2 VPERM TMP3,STATE3,STATE3,BEPERM; \
VSTBRF STATE2,32,,%r2 VSTM TMP0,TMP3,0,%r2), \
VSTBRF STATE3,48,,%r2 __stringify( \
.Lstoredone: /* 32 bit wise little endian store to OUTPUT */ \
VSTBRF STATE0,0,,%r2; \
VSTBRF STATE1,16,,%r2; \
VSTBRF STATE2,32,,%r2; \
VSTBRF STATE3,48,,%r2; \
brcl 0,0), \
ALT_FACILITY(148)
/* ++COPY3.COUNTER */ /* ++COPY3.COUNTER */
/* alsih %r3,1 */ /* alsih %r3,1 */
...@@ -171,14 +177,5 @@ SYM_FUNC_START(__arch_chacha20_blocks_nostack) ...@@ -171,14 +177,5 @@ SYM_FUNC_START(__arch_chacha20_blocks_nostack)
VZERO TMP3 VZERO TMP3
br %r14 br %r14
.Lstoreslow:
/* Convert STATE to little endian format and store to OUTPUT */
VPERM TMP0,STATE0,STATE0,BEPERM
VPERM TMP1,STATE1,STATE1,BEPERM
VPERM TMP2,STATE2,STATE2,BEPERM
VPERM TMP3,STATE3,STATE3,BEPERM
VSTM TMP0,TMP3,0,%r2
j .Lstoredone
CFI_ENDPROC CFI_ENDPROC
SYM_FUNC_END(__arch_chacha20_blocks_nostack) SYM_FUNC_END(__arch_chacha20_blocks_nostack)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment