aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorBernd Schmidt <bernd.schmidt@analog.com>2006-04-05 22:03:30 +0000
committerBernd Schmidt <bernds@gcc.gnu.org>2006-04-05 22:03:30 +0000
commitdcef6abaf507eb9a29d837004460f2f15bb78b7c (patch)
treed905381f0c8ac5613a9dd2faa88300d3c2ff6cd8 /gcc
parente6c300efaa5d98974d8a58ee91c458e56714f73f (diff)
downloadgcc-dcef6abaf507eb9a29d837004460f2f15bb78b7c.zip
gcc-dcef6abaf507eb9a29d837004460f2f15bb78b7c.tar.gz
gcc-dcef6abaf507eb9a29d837004460f2f15bb78b7c.tar.bz2
lib1funcs.asm (modsi): P1/P2 can be call-clobbered even if the calling function doesn't modify them.
* config/bfin/lib1funcs.asm (modsi): P1/P2 can be call-clobbered even if the calling function doesn't modify them. From-SVN: r112720
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog3
-rw-r--r--gcc/config/bfin/lib1funcs.asm15
2 files changed, 10 insertions, 8 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 4602174..c630968 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -3,6 +3,9 @@
* config/bfin/bfin.c (bfin_legitimate_address_p): Disallow
got-relative addressing for anything but SImode.
+ * config/bfin/lib1funcs.asm (modsi): P1/P2 can be call-clobbered
+ even if the calling function doesn't modify them.
+
2006-04-05 Richard Guenther <rguenther@suse.de>
PR tree-optimization/26919
diff --git a/gcc/config/bfin/lib1funcs.asm b/gcc/config/bfin/lib1funcs.asm
index 22e8a02..77d4fff 100644
--- a/gcc/config/bfin/lib1funcs.asm
+++ b/gcc/config/bfin/lib1funcs.asm
@@ -64,17 +64,16 @@ ___divsi3:
.type ___modsi3, STT_FUNC;
___modsi3:
- [--SP] = RETS;
- /* P1 and P2 are preserved by divsi3 and udivsi3. */
- P1 = R0;
- P2 = R1;
- CALL ___divsi3;
- R1 = P1;
- R2 = P2;
+ [--SP] = RETS;
+ [--SP] = R0;
+ [--SP] = R1;
+ CALL ___divsi3;
+ R2 = [SP++];
+ R1 = [SP++];
R2 *= R0;
R0 = R1 - R2;
RETS = [SP++];
- RTS;
+ RTS;
#endif
#ifdef L_udivsi3