On Sat, Mar 28, 2015 at 12:19:10PM +1100, Michael Ellerman wrote:
> This adds a test of the switch_endian() syscall we added in the previous
> commit.
> 
> We test it by calling the endian switch syscall, and then executing some
> code in the other endian to check everything went as expected. That code
> checks registers we expect to be maintained are. If the endian switch
> failed to happen that code sequence will be illegal and cause the test
> to abort.
> 
> We then switch back to the original endian, do the same checks and
> finally write a success message and exit(0).
> 
> Signed-off-by: Michael Ellerman <m...@ellerman.id.au>
> 
> ---
> v3: Have the test switch back to the original endian.
> v4: Add .gitignore.
>     Drop the message write in the checking code - it clobbers some regs
>     and breaks the second check.
> 
>  tools/testing/selftests/powerpc/Makefile           |  2 +-
>  .../selftests/powerpc/switch_endian/.gitignore     |  2 +
>  .../selftests/powerpc/switch_endian/Makefile       | 23 +++++
>  .../selftests/powerpc/switch_endian/check.S        | 98 
> ++++++++++++++++++++++
>  .../selftests/powerpc/switch_endian/common.h       |  6 ++
>  .../powerpc/switch_endian/switch_endian_test.S     | 82 ++++++++++++++++++
>  6 files changed, 212 insertions(+), 1 deletion(-)
>  create mode 100644 tools/testing/selftests/powerpc/switch_endian/.gitignore
>  create mode 100644 tools/testing/selftests/powerpc/switch_endian/Makefile
>  create mode 100644 tools/testing/selftests/powerpc/switch_endian/check.S
>  create mode 100644 tools/testing/selftests/powerpc/switch_endian/common.h
>  create mode 100644 
> tools/testing/selftests/powerpc/switch_endian/switch_endian_test.S

[snipped]
> diff --git 
> a/tools/testing/selftests/powerpc/switch_endian/switch_endian_test.S 
> b/tools/testing/selftests/powerpc/switch_endian/switch_endian_test.S
> new file mode 100644
> index 000000000000..eee0e393600b
> --- /dev/null
> +++ b/tools/testing/selftests/powerpc/switch_endian/switch_endian_test.S
> @@ -0,0 +1,82 @@
> +#include "common.h"
> +
> +     .data
> +     .balign 8
> +message:
> +     .ascii "success: switch_endian_test\n\0"
> +
> +     .section ".toc"
> +     .balign 8
> +pattern:
> +     .llong 0x5555AAAA5555AAAA
> +
> +     .text
> +FUNC_START(_start)
> +     /* Load the pattern */
> +     ld      r15, pattern@TOC(%r2)
> +
> +     /* Setup CR, only CR2-CR4 are maintained */
> +     lis     r3, 0x00FF
> +     ori     r3, r3, 0xF000
> +     mtcr    r3
> +
> +     /* Load the pattern slightly modified into the registers */
> +     mr      r3, r15
> +     addi    r4, r15, 4
> +
> +     addi    r5, r15, 32
> +     mtlr    r5
> +
> +     addi    r5, r15, 5
> +     addi    r6, r15, 6
> +     addi    r7, r15, 7
> +     addi    r8, r15, 8
> +
> +     /* r9 - r12 are clobbered */
> +
> +     addi    r13, r15, 13
> +     addi    r14, r15, 14
> +
> +     /* Skip r15 we're using it */
> +
> +     addi    r16, r15, 16
> +     addi    r16, r15, 16

Duplicate?


> +     addi    r17, r15, 17
> +     addi    r18, r15, 18
> +     addi    r19, r15, 19
> +     addi    r20, r15, 20
> +     addi    r21, r15, 21
> +     addi    r22, r15, 22
> +     addi    r23, r15, 23
> +     addi    r24, r15, 24
> +     addi    r25, r15, 25
> +     addi    r26, r15, 26
> +     addi    r27, r15, 27
> +     addi    r28, r15, 28
> +     addi    r29, r15, 29
> +     addi    r30, r15, 30
> +     addi    r31, r15, 31
> +
> +     /*
> +      * Call the syscall to switch endian.
> +      * It clobbers r9-r12, XER, CTR and CR0-1,5-7.
> +      */
> +     li r0, __NR_switch_endian
> +     sc
> +
> +#include "check-reversed.S"
> +
> +     /* Flip back, r0 already has the switch syscall number */
> +     .long   0x02000044      /* sc */
> +
> +#include "check.S"
> +
> +     li      r0, __NR_write
> +     li      r3, 1   /* stdout */
> +     ld      r4, message@got(%r2)
> +     li      r5, 28  /* strlen(message3) */
> +     sc
> +     li      r0, __NR_exit
> +     li      r3, 0
> +     sc
> +     b       .
> -- 
> 2.1.0

    Gabriel
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to