[BACK]Return to add_n.s CVS log [TXT][DIR] Up to [local] / OpenXM_contrib / gmp / mpn / thumb

Annotation of OpenXM_contrib/gmp/mpn/thumb/add_n.s, Revision 1.1.1.2

1.1.1.2 ! ohara       1: @ ARM/Thumb mpn_add_n -- Add two limb vectors of the same length > 0 and store
1.1       maekawa     2: @ sum in a third limb vector.
                      3:
1.1.1.2 ! ohara       4: @ Copyright 1997, 2000 Free Software Foundation, Inc.
1.1       maekawa     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 Lesser General Public License as published by
                     10: @ the Free Software Foundation; either version 2.1 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 Lesser General Public
                     16: @ License for more details.
                     17:
                     18: @ You should have received a copy of the GNU Lesser 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: @ INPUT PARAMETERS
                     25: @ RES_ptr      r0
                     26: @ S1_ptr       r1
                     27: @ S2_ptr       r2
                     28: @ SIZE         r3
                     29:
                     30: @ NOT TESTED CODE
                     31:
                     32:        .text
                     33:        .thumb
                     34:        .align  0
                     35:        .global ___gmpn_add_n
                     36: ___gmpn_add_n:
                     37:        push    {r4, r5, r6, lr}
                     38:        mov     r6, #1                  @ init carry save register
                     39:
                     40: Loop:  sub     r6, #1                  @ restore carry (set iff r6 was 0)
                     41:        ldmia   r1!, {r4}               @ load next limb from S1
                     42:        ldmia   r2!, {r5}               @ load next limb from S2
                     43:        adc     r4, r5
                     44:        stmia   r0!, {r4}               @ store result limb to RES
                     45:        sbc     r6, r6                  @ save negated carry
                     46:        sub     r3, #1
                     47:        bge     Loop                    @ loop back while remaining count >= 4
                     48:
                     49:        mov     r0, r6
                     50:        pop     {r4, r5, r6, pc}

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>