| .. | .. |
|---|
| 1 | +// SPDX-License-Identifier: GPL-2.0-only |
|---|
| 1 | 2 | /* |
|---|
| 2 | 3 | * linux/arch/arm/mm/copypage-xsc3.S |
|---|
| 3 | 4 | * |
|---|
| 4 | 5 | * Copyright (C) 2004 Intel Corp. |
|---|
| 5 | | - * |
|---|
| 6 | | - * This program is free software; you can redistribute it and/or modify |
|---|
| 7 | | - * it under the terms of the GNU General Public License version 2 as |
|---|
| 8 | | - * published by the Free Software Foundation. |
|---|
| 9 | 6 | * |
|---|
| 10 | 7 | * Adapted for 3rd gen XScale core, no more mini-dcache |
|---|
| 11 | 8 | * Author: Matt Gilbert (matthew.m.gilbert@intel.com) |
|---|
| .. | .. |
|---|
| 37 | 34 | 1: pld [%1, #64] \n\ |
|---|
| 38 | 35 | pld [%1, #96] \n\ |
|---|
| 39 | 36 | \n\ |
|---|
| 40 | | -2: ldrd r2, [%1], #8 \n\ |
|---|
| 41 | | - ldrd r4, [%1], #8 \n\ |
|---|
| 37 | +2: ldrd r2, r3, [%1], #8 \n\ |
|---|
| 38 | + ldrd r4, r5, [%1], #8 \n\ |
|---|
| 42 | 39 | mcr p15, 0, %0, c7, c6, 1 @ invalidate\n\ |
|---|
| 43 | | - strd r2, [%0], #8 \n\ |
|---|
| 44 | | - ldrd r2, [%1], #8 \n\ |
|---|
| 45 | | - strd r4, [%0], #8 \n\ |
|---|
| 46 | | - ldrd r4, [%1], #8 \n\ |
|---|
| 47 | | - strd r2, [%0], #8 \n\ |
|---|
| 48 | | - strd r4, [%0], #8 \n\ |
|---|
| 49 | | - ldrd r2, [%1], #8 \n\ |
|---|
| 50 | | - ldrd r4, [%1], #8 \n\ |
|---|
| 40 | + strd r2, r3, [%0], #8 \n\ |
|---|
| 41 | + ldrd r2, r3, [%1], #8 \n\ |
|---|
| 42 | + strd r4, r5, [%0], #8 \n\ |
|---|
| 43 | + ldrd r4, r5, [%1], #8 \n\ |
|---|
| 44 | + strd r2, r3, [%0], #8 \n\ |
|---|
| 45 | + strd r4, r5, [%0], #8 \n\ |
|---|
| 46 | + ldrd r2, r3, [%1], #8 \n\ |
|---|
| 47 | + ldrd r4, r5, [%1], #8 \n\ |
|---|
| 51 | 48 | mcr p15, 0, %0, c7, c6, 1 @ invalidate\n\ |
|---|
| 52 | | - strd r2, [%0], #8 \n\ |
|---|
| 53 | | - ldrd r2, [%1], #8 \n\ |
|---|
| 49 | + strd r2, r3, [%0], #8 \n\ |
|---|
| 50 | + ldrd r2, r3, [%1], #8 \n\ |
|---|
| 54 | 51 | subs %2, %2, #1 \n\ |
|---|
| 55 | | - strd r4, [%0], #8 \n\ |
|---|
| 56 | | - ldrd r4, [%1], #8 \n\ |
|---|
| 57 | | - strd r2, [%0], #8 \n\ |
|---|
| 58 | | - strd r4, [%0], #8 \n\ |
|---|
| 52 | + strd r4, r5, [%0], #8 \n\ |
|---|
| 53 | + ldrd r4, r5, [%1], #8 \n\ |
|---|
| 54 | + strd r2, r3, [%0], #8 \n\ |
|---|
| 55 | + strd r4, r5, [%0], #8 \n\ |
|---|
| 59 | 56 | bgt 1b \n\ |
|---|
| 60 | 57 | beq 2b " |
|---|
| 61 | 58 | : "+&r" (kto), "+&r" (kfrom), "=&r" (tmp) |
|---|
| .. | .. |
|---|
| 87 | 84 | mov r2, #0 \n\ |
|---|
| 88 | 85 | mov r3, #0 \n\ |
|---|
| 89 | 86 | 1: mcr p15, 0, %0, c7, c6, 1 @ invalidate line\n\ |
|---|
| 90 | | - strd r2, [%0], #8 \n\ |
|---|
| 91 | | - strd r2, [%0], #8 \n\ |
|---|
| 92 | | - strd r2, [%0], #8 \n\ |
|---|
| 93 | | - strd r2, [%0], #8 \n\ |
|---|
| 87 | + strd r2, r3, [%0], #8 \n\ |
|---|
| 88 | + strd r2, r3, [%0], #8 \n\ |
|---|
| 89 | + strd r2, r3, [%0], #8 \n\ |
|---|
| 90 | + strd r2, r3, [%0], #8 \n\ |
|---|
| 94 | 91 | subs r1, r1, #1 \n\ |
|---|
| 95 | 92 | bne 1b" |
|---|
| 96 | 93 | : "=r" (ptr) |
|---|