Rewrote the transform function
[libgcrypt.git] / mpi / m68k / mpih-add1.S
1 /* mc68020 __mpn_add_n -- Add two limb vectors of the same length > 0 and store
2    sum in a third limb vector.
3
4 Copyright (C) 1992, 1994, 1996 Free Software Foundation, Inc.
5
6 This file is part of the GNU MP Library.
7
8 The GNU MP Library is free software; you can redistribute it and/or modify
9 it under the terms of the GNU Library General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or (at your
11 option) any later version.
12
13 The GNU MP Library is distributed in the hope that it will be useful, but
14 WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
15 or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Library General Public
16 License for more details.
17
18 You should have received a copy of the GNU Library General Public License
19 along with the GNU MP Library; see the file COPYING.LIB.  If not, write to
20 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
21 MA 02111-1307, USA. */
22
23
24 #include "sysdep.h"
25 #include "asm-syntax.h"
26
27
28 /*******************
29  *  mpi_limb_t
30  *  mpihelp_add_n( mpi_ptr_t res_ptr,   (sp + 4)
31  *                 mpi_ptr_t s1_ptr,    (sp + 8)
32  *                 mpi_ptr_t s2_ptr,    (sp + 16)
33  *                 mpi_size_t size)     (sp + 12)
34  */
35
36
37         TEXT
38         ALIGN
39         GLOBL   C_SYMBOL_NAME(mpihelp_add_n)
40
41 C_SYMBOL_NAME(mpihelp_add_n:)
42 PROLOG(mpihelp_add_n)
43         /* Save used registers on the stack.  */
44         movel   R(d2),MEM_PREDEC(sp)
45         movel   R(a2),MEM_PREDEC(sp)
46
47         /* Copy the arguments to registers.  Better use movem?  */
48         movel   MEM_DISP(sp,12),R(a2)
49         movel   MEM_DISP(sp,16),R(a0)
50         movel   MEM_DISP(sp,20),R(a1)
51         movel   MEM_DISP(sp,24),R(d2)
52
53         eorw    #1,R(d2)
54         lsrl    #1,R(d2)
55         bcc     L(L1)
56         subql   #1,R(d2)        /* clears cy as side effect */
57
58 L(Loop:)
59         movel   MEM_POSTINC(a0),R(d0)
60         movel   MEM_POSTINC(a1),R(d1)
61         addxl   R(d1),R(d0)
62         movel   R(d0),MEM_POSTINC(a2)
63 L(L1:)  movel   MEM_POSTINC(a0),R(d0)
64         movel   MEM_POSTINC(a1),R(d1)
65         addxl   R(d1),R(d0)
66         movel   R(d0),MEM_POSTINC(a2)
67
68         dbf     R(d2),L(Loop)           /* loop until 16 lsb of %4 == -1 */
69         subxl   R(d0),R(d0)     /* d0 <= -cy; save cy as 0 or -1 in d0 */
70         subl    #0x10000,R(d2)
71         bcs     L(L2)
72         addl    R(d0),R(d0)     /* restore cy */
73         bra     L(Loop)
74
75 L(L2:)
76         negl    R(d0)
77
78         /* Restore used registers from stack frame.  */
79         movel   MEM_POSTINC(sp),R(a2)
80         movel   MEM_POSTINC(sp),R(d2)
81
82         rts
83 EPILOG(mpihelp_add_n)
84
85