comparison gcc/config/mips/vr4120-div.S @ 0:a06113de4d67

first commit
author kent <kent@cr.ie.u-ryukyu.ac.jp>
date Fri, 17 Jul 2009 14:47:48 +0900
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:a06113de4d67
1 /* Support file for -mfix-vr4120.
2 Copyright (C) 2002, 2004, 2007 Free Software Foundation, Inc.
3
4 This file is part of GCC.
5
6 GCC is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3, or (at your option)
9 any later version.
10
11 GCC is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
19
20 /* This file contains functions which implement divsi3 and modsi3 for
21 -mfix-vr4120. div and ddiv do not give the correct result when one
22 of the operands is negative. */
23
24 .set nomips16
25
26 #define DIV \
27 xor $3,$4,$5 /* t = x ^ y */ ; \
28 li $2,0x80000000; \
29 .set noreorder; \
30 bgez $4,1f /* x >= 0 */; \
31 and $3,$3,$2 /* t = (x ^ y) & 0x80000000 in delay slot */ ;\
32 .set reorder; \
33 subu $4,$0,$4 /* x = -x */ ; \
34 1:; \
35 .set noreorder; \
36 bgez $5,2f /* y >= 0 */ ; \
37 nop; \
38 subu $5,$0,$5 /* y = -y */ ; \
39 .set reorder; \
40 2:; \
41 divu $0,$4,$5; /* we use divu because of INT_MIN */ \
42 .set noreorder; \
43 bne $5,$0,3f; \
44 nop; \
45 break 7 /* division on zero y */ ; \
46 3:; \
47 .set reorder; \
48 mflo $2 /* r = x / y */ ; \
49 .set noreorder; \
50 beq $3,$0,4f /* t == 0 */ ; \
51 nop; \
52 subu $2,$0,$2 /* r = -r */ ; \
53 .set reorder; \
54 4:
55
56 .globl __vr4120_divsi3
57 .ent __vr4120_divsi3
58 __vr4120_divsi3:
59 DIV
60 j $31
61 .end __vr4120_divsi3
62
63 .globl __vr4120_modsi3
64 .ent __vr4120_modsi3
65 __vr4120_modsi3:
66 move $6,$4 # x1 = x
67 move $7,$5 # y1 = y
68 DIV
69 mult $2,$7 # r = r * y1
70 mflo $2
71 .set noreorder
72 j $31
73 subu $2,$6,$2 # r = x1 - r in delay slot
74 .end __vr4120_modsi3