| // SPDX-License-Identifier: GPL-2.0 |
| // Copyright (C) 2005-2017 Andes Technology Corporation |
| |
| |
| beq $r1, $r0, quit_memcpy |
| beqz $r2, quit_memcpy |
| srli $r3, $r2, #5 ! check if len < cache-line size 32 |
| beqz $r3, word_copy_entry |
| andi $r4, $r0, #0x3 ! check byte-align |
| beqz $r4, unalign_word_copy_entry |
| |
| addi $r4, $r4,#-4 |
| abs $r4, $r4 ! check how many un-align byte to copy |
| sub $r2, $r2, $r4 ! update $R2 |
| |
| unalign_byte_copy: |
| lbi1 $r3, $r1, #1 |
| addi $r4, $r4, #-1 |
| sbi1 $r3, $r0, #1 |
| bnez $r4, unalign_byte_copy |
| beqz $r2, quit_memcpy |
| |
| unalign_word_copy_entry: |
| andi $r3, $r0, 0x1f ! check cache-line unaligncount |
| beqz $r3, cache_copy |
| |
| addi $r3, $r3, #-32 |
| abs $r3, $r3 |
| sub $r2, $r2, $r3 ! update $R2 |
| |
| unalign_word_copy: |
| lmw1 $r4, $r1, $r4 |
| addi $r3, $r3, #-4 |
| smw1 $r4, $r0, $r4 |
| bnez $r3, unalign_word_copy |
| beqz $r2, quit_memcpy |
| |
| addi $r3, $r2, #-32 ! to check $r2< cache_line , than go to word_copy |
| bltz $r3, word_copy_entry |
| cache_copy: |
| srli $r3, $r2, #5 |
| beqz $r3, word_copy_entry |
| 3: |
| lmw1 $r17, $r1, $r24 |
| addi $r3, $r3, #-1 |
| smw1 $r17, $r0, $r24 |
| bnez $r3, 3b |
| |
| word_copy_entry: |
| andi $r2, $r2, #31 |
| |
| beqz $r2, quit_memcpy |
| 5: |
| srli $r3, $r2, #2 |
| beqz $r3, byte_copy |
| word_copy: |
| lmw1 $r4, $r1, $r4 |
| addi $r3, $r3, #-1 |
| smw1 $r4, $r0, $r4 |
| bnez $r3, word_copy |
| andi $r2, $r2, #3 |
| beqz $r2, quit_memcpy |
| byte_copy: |
| lbi1 $r3, $r1, #1 |
| addi $r2, $r2, #-1 |
| |
| sbi1 $r3, $r0, #1 |
| bnez $r2, byte_copy |
| quit_memcpy: |