aboutsummaryrefslogtreecommitdiff
path: root/devel
diff options
context:
space:
mode:
authorJoerg Wunsch <joerg@FreeBSD.org>2003-01-20 09:32:48 +0000
committerJoerg Wunsch <joerg@FreeBSD.org>2003-01-20 09:32:48 +0000
commit0baf37d9f988ec06ed8e611f8a7e5a0b0a05a5d9 (patch)
tree9b1b0ba89449690447546758fc68f5628fd09219 /devel
parenteeaeffd4db68853736738cb613af17a2409fcf8b (diff)
downloadports-0baf37d9f988ec06ed8e611f8a7e5a0b0a05a5d9.tar.gz
ports-0baf37d9f988ec06ed8e611f8a7e5a0b0a05a5d9.zip
Replace my old 16 bit IO register assignment hack by an authoritative
patch by the avr-gcc maintainers. Bump portrevision for that.
Notes
Notes: svn path=/head/; revision=73637
Diffstat (limited to 'devel')
-rw-r--r--devel/avr-gcc-3/Makefile1
-rw-r--r--devel/avr-gcc-3/files/patch-16bitassign313
-rw-r--r--devel/avr-gcc/Makefile1
-rw-r--r--devel/avr-gcc/files/patch-16bitassign313
4 files changed, 602 insertions, 26 deletions
diff --git a/devel/avr-gcc-3/Makefile b/devel/avr-gcc-3/Makefile
index 97a2fe2f0747..ea7a0a6c5af3 100644
--- a/devel/avr-gcc-3/Makefile
+++ b/devel/avr-gcc-3/Makefile
@@ -7,6 +7,7 @@
PORTNAME= gcc
PORTVERSION= 3.3.2003.01.08
+PORTREVISION= 1
CATEGORIES= devel
#MASTER_SITES= ${MASTER_SITE_GNU}
#MASTER_SITE_SUBDIR= ${PORTNAME}/${PORTNAME}-${PORTVERSION}
diff --git a/devel/avr-gcc-3/files/patch-16bitassign b/devel/avr-gcc-3/files/patch-16bitassign
index 6a5659c18290..2241dfa1adbe 100644
--- a/devel/avr-gcc-3/files/patch-16bitassign
+++ b/devel/avr-gcc-3/files/patch-16bitassign
@@ -1,13 +1,300 @@
---- gcc/config/avr/avr.c.orig Mon Aug 12 15:13:56 2002
-+++ gcc/config/avr/avr.c Thu Aug 29 12:53:14 2002
-@@ -2711,8 +2711,8 @@
- }
- }
- else
-- return *l=2, (AS2 (st ,%0,%A1) CR_TAB
-- AS2 (std,%0+1,%B1));
-+ return *l=2, (AS2 (std,%0+1,%B1) CR_TAB
-+ AS2 (st ,%0,%A1));
- }
- else if (GET_CODE (base) == PLUS)
- {
+From marekm@amelek.gda.pl Sun Jan 19 02:37:50 2003
+Path: interface-business.de!not-for-mail
+Newsgroups: local.avr.gcc
+Followup-To: poster
+Reply-To: avr-gcc-list@avr1.org
+Subject: [avr-gcc-list] Patch for indirect 16-bit I/O
+To: avr-gcc-list@avr1.org
+X-Mailer: ELM [version 2.4ME+ PL95 (25)]
+MIME-Version: 1.0
+Content-Transfer-Encoding: 7bit
+Content-Type: text/plain; charset=US-ASCII
+Message-ID: <E18a4PG-0004Cs-00@alf.amelek.gda.pl>
+From: Marek Michalkiewicz <marekm@amelek.gda.pl>
+Sender: owner-avr-gcc-list@avr1.org
+Precedence: bulk
+Date: Sun, 19 Jan 2003 02:37:50 +0100 (CET)
+Lines: 280
+Xref: interface-business.de local.avr.gcc:2452
+
+Hi,
+
+This should handle all these 16-bit I/O accesses addressed with
+pointers ("volatile" is required to force writing high byte first
+and reading low byte first in absolutely all cases, even if that
+makes the code less efficient). The patch is for CVS mainline, but
+should apply cleanly to the 3.3 branch too. I'm not committing it
+to GCC CVS just yet - please test, I haven't... well, it compiles :)
+
+BTW, mainline currently requires that SEEK_{SET,CUR,END} are
+defined in <stdio.h> - otherwise some new libgcc2.c stuff (unused
+on the AVR, but it has to compile) will cause the build to fail.
+Just edit /usr/local/avr/include/stdio.h to add them manually...
+
+Marek
+
+
+Index: gcc/config/avr/avr.c
+===================================================================
+RCS file: /cvs/gcc/gcc/gcc/config/avr/avr.c,v
+retrieving revision 1.87
+diff -c -3 -p -r1.87 avr.c
+*** gcc/config/avr/avr.c 16 Dec 2002 18:20:58 -0000 1.87
+--- gcc/config/avr/avr.c 19 Jan 2003 01:07:52 -0000
+*************** print_operand (file, x, code)
+*** 1138,1143 ****
+--- 1138,1153 ----
+
+ print_operand (file, XEXP (addr, 1), 0);
+ }
++ else if (code == 'p' || code == 'r')
++ {
++ if (GET_CODE (addr) != POST_INC && GET_CODE (addr) != PRE_DEC)
++ fatal_insn ("bad address, not post_inc or pre_dec:", addr);
++
++ if (code == 'p')
++ print_operand_address (file, XEXP (addr, 0)); /* X, Y, Z */
++ else
++ print_operand (file, XEXP (addr, 0), 0); /* r26, r28, r30 */
++ }
+ else if (GET_CODE (addr) == PLUS)
+ {
+ print_operand_address (file, XEXP (addr,0));
+*************** out_movhi_r_mr (insn, op, l)
+*** 1944,1949 ****
+--- 1954,1962 ----
+ rtx base = XEXP (src, 0);
+ int reg_dest = true_regnum (dest);
+ int reg_base = true_regnum (base);
++ /* "volatile" forces reading low byte first, even if less efficient,
++ for correct operation with 16-bit I/O registers. */
++ int mem_volatile_p = MEM_VOLATILE_P (src);
+ int tmp;
+
+ if (!l)
+*************** out_movhi_r_mr (insn, op, l)
+*** 2037,2042 ****
+--- 2050,2074 ----
+ if (reg_overlap_mentioned_p (dest, XEXP (base, 0)))
+ fatal_insn ("incorrect insn:", insn);
+
++ if (mem_volatile_p)
++ {
++ if (REGNO (XEXP (base, 0)) == REG_X)
++ {
++ *l = 4;
++ return (AS2 (sbiw,r26,2) CR_TAB
++ AS2 (ld,%A0,X+) CR_TAB
++ AS2 (ld,%B0,X) CR_TAB
++ AS2 (sbiw,r26,1));
++ }
++ else
++ {
++ *l = 3;
++ return (AS2 (sbiw,%r1,2) CR_TAB
++ AS2 (ld,%A0,%p1) CR_TAB
++ AS2 (ldd,%B0,%p1+1));
++ }
++ }
++
+ *l = 2;
+ return (AS2 (ld,%B0,%1) CR_TAB
+ AS2 (ld,%A0,%1));
+*************** out_movhi_mr_r (insn, op, l)
+*** 2668,2674 ****
+--- 2700,2710 ----
+ rtx base = XEXP (dest, 0);
+ int reg_base = true_regnum (base);
+ int reg_src = true_regnum (src);
++ /* "volatile" forces writing high byte first, even if less efficient,
++ for correct operation with 16-bit I/O registers. */
++ int mem_volatile_p = MEM_VOLATILE_P (dest);
+ int tmp;
++
+ if (!l)
+ l = &tmp;
+ if (CONSTANT_ADDRESS_P (base))
+*************** out_movhi_mr_r (insn, op, l)
+*** 2688,2720 ****
+ {
+ if (reg_src == REG_X)
+ {
+! /* "st X+,r26" is undefined */
+! if (reg_unused_after (insn, src))
+ return *l=4, (AS2 (mov,__tmp_reg__,r27) CR_TAB
+ AS2 (st,X,r26) CR_TAB
+ AS2 (adiw,r26,1) CR_TAB
+ AS2 (st,X,__tmp_reg__));
+ else
+ return *l=5, (AS2 (mov,__tmp_reg__,r27) CR_TAB
+- AS2 (st,X,r26) CR_TAB
+ AS2 (adiw,r26,1) CR_TAB
+ AS2 (st,X,__tmp_reg__) CR_TAB
+! AS2 (sbiw,r26,1));
+ }
+ else
+ {
+! if (reg_unused_after (insn, base))
+ return *l=2, (AS2 (st,X+,%A1) CR_TAB
+ AS2 (st,X,%B1));
+ else
+! return *l=3, (AS2 (st ,X+,%A1) CR_TAB
+! AS2 (st ,X,%B1) CR_TAB
+! AS2 (sbiw,r26,1));
+ }
+ }
+ else
+! return *l=2, (AS2 (st ,%0,%A1) CR_TAB
+! AS2 (std,%0+1,%B1));
+ }
+ else if (GET_CODE (base) == PLUS)
+ {
+--- 2724,2756 ----
+ {
+ if (reg_src == REG_X)
+ {
+! /* "st X+,r26" and "st -X,r26" are undefined. */
+! if (!mem_volatile_p && reg_unused_after (insn, src))
+ return *l=4, (AS2 (mov,__tmp_reg__,r27) CR_TAB
+ AS2 (st,X,r26) CR_TAB
+ AS2 (adiw,r26,1) CR_TAB
+ AS2 (st,X,__tmp_reg__));
+ else
+ return *l=5, (AS2 (mov,__tmp_reg__,r27) CR_TAB
+ AS2 (adiw,r26,1) CR_TAB
+ AS2 (st,X,__tmp_reg__) CR_TAB
+! AS2 (sbiw,r26,1) CR_TAB
+! AS2 (st,X,r26));
+ }
+ else
+ {
+! if (!mem_volatile_p && reg_unused_after (insn, base))
+ return *l=2, (AS2 (st,X+,%A1) CR_TAB
+ AS2 (st,X,%B1));
+ else
+! return *l=3, (AS2 (adiw,r26,1) CR_TAB
+! AS2 (st,X,%B1) CR_TAB
+! AS2 (st,-X,%A1));
+ }
+ }
+ else
+! return *l=2, (AS2 (std,%0+1,%B1) CR_TAB
+! AS2 (st,%0,%A1));
+ }
+ else if (GET_CODE (base) == PLUS)
+ {
+*************** out_movhi_mr_r (insn, op, l)
+*** 2727,2740 ****
+
+ if (disp <= 63 + MAX_LD_OFFSET (GET_MODE (dest)))
+ return *l = 4, (AS2 (adiw,r28,%o0-62) CR_TAB
+- AS2 (std,Y+62,%A1) CR_TAB
+ AS2 (std,Y+63,%B1) CR_TAB
+ AS2 (sbiw,r28,%o0-62));
+
+ return *l = 6, (AS2 (subi,r28,lo8(-%o0)) CR_TAB
+ AS2 (sbci,r29,hi8(-%o0)) CR_TAB
+- AS2 (st,Y,%A1) CR_TAB
+ AS2 (std,Y+1,%B1) CR_TAB
+ AS2 (subi,r28,lo8(%o0)) CR_TAB
+ AS2 (sbci,r29,hi8(%o0)));
+ }
+--- 2763,2776 ----
+
+ if (disp <= 63 + MAX_LD_OFFSET (GET_MODE (dest)))
+ return *l = 4, (AS2 (adiw,r28,%o0-62) CR_TAB
+ AS2 (std,Y+63,%B1) CR_TAB
++ AS2 (std,Y+62,%A1) CR_TAB
+ AS2 (sbiw,r28,%o0-62));
+
+ return *l = 6, (AS2 (subi,r28,lo8(-%o0)) CR_TAB
+ AS2 (sbci,r29,hi8(-%o0)) CR_TAB
+ AS2 (std,Y+1,%B1) CR_TAB
++ AS2 (st,Y,%A1) CR_TAB
+ AS2 (subi,r28,lo8(%o0)) CR_TAB
+ AS2 (sbci,r29,hi8(%o0)));
+ }
+*************** out_movhi_mr_r (insn, op, l)
+*** 2746,2772 ****
+ *l = 7;
+ return (AS2 (mov,__tmp_reg__,r26) CR_TAB
+ AS2 (mov,__zero_reg__,r27) CR_TAB
+! AS2 (adiw,r26,%o0) CR_TAB
+! AS2 (st,X+,__tmp_reg__) CR_TAB
+ AS2 (st,X,__zero_reg__) CR_TAB
+ AS1 (clr,__zero_reg__) CR_TAB
+! AS2 (sbiw,r26,%o0+1));
+ }
+ *l = 4;
+! return (AS2 (adiw,r26,%o0) CR_TAB
+! AS2 (st,X+,%A1) CR_TAB
+! AS2 (st,X,%B1) CR_TAB
+! AS2 (sbiw,r26,%o0+1));
+ }
+! return *l=2, (AS2 (std,%A0,%A1) CR_TAB
+! AS2 (std,%B0,%B1));
+ }
+ else if (GET_CODE (base) == PRE_DEC) /* (--R) */
+ return *l=2, (AS2 (st,%0,%B1) CR_TAB
+ AS2 (st,%0,%A1));
+ else if (GET_CODE (base) == POST_INC) /* (R++) */
+! return *l=2, (AS2 (st,%0,%A1) CR_TAB
+! AS2 (st,%0,%B1));
+ fatal_insn ("unknown move insn:",insn);
+ return "";
+ }
+--- 2782,2830 ----
+ *l = 7;
+ return (AS2 (mov,__tmp_reg__,r26) CR_TAB
+ AS2 (mov,__zero_reg__,r27) CR_TAB
+! AS2 (adiw,r26,%o0+1) CR_TAB
+ AS2 (st,X,__zero_reg__) CR_TAB
++ AS2 (st,-X,__tmp_reg__) CR_TAB
+ AS1 (clr,__zero_reg__) CR_TAB
+! AS2 (sbiw,r26,%o0));
+ }
+ *l = 4;
+! return (AS2 (adiw,r26,%o0+1) CR_TAB
+! AS2 (st,X,%B1) CR_TAB
+! AS2 (st,-X,%A1) CR_TAB
+! AS2 (sbiw,r26,%o0));
+ }
+! return *l=2, (AS2 (std,%B0,%B1) CR_TAB
+! AS2 (std,%A0,%A1));
+ }
+ else if (GET_CODE (base) == PRE_DEC) /* (--R) */
+ return *l=2, (AS2 (st,%0,%B1) CR_TAB
+ AS2 (st,%0,%A1));
+ else if (GET_CODE (base) == POST_INC) /* (R++) */
+! {
+! if (mem_volatile_p)
+! {
+! if (REGNO (XEXP (base, 0)) == REG_X)
+! {
+! *l = 4;
+! return (AS2 (adiw,r26,1) CR_TAB
+! AS2 (st,X,%B1) CR_TAB
+! AS2 (st,-X,%A1) CR_TAB
+! AS2 (adiw,r26,2));
+! }
+! else
+! {
+! *l = 3;
+! return (AS2 (std,%p0+1,%B1) CR_TAB
+! AS2 (st,%p0,%A1) CR_TAB
+! AS2 (adiw,%r0,2));
+! }
+! }
+!
+! *l = 2;
+! return (AS2 (st,%0,%A1) CR_TAB
+! AS2 (st,%0,%B1));
+! }
+ fatal_insn ("unknown move insn:",insn);
+ return "";
+ }
+
+
+
+avr-gcc-list at http://avr1.org
+
diff --git a/devel/avr-gcc/Makefile b/devel/avr-gcc/Makefile
index 97a2fe2f0747..ea7a0a6c5af3 100644
--- a/devel/avr-gcc/Makefile
+++ b/devel/avr-gcc/Makefile
@@ -7,6 +7,7 @@
PORTNAME= gcc
PORTVERSION= 3.3.2003.01.08
+PORTREVISION= 1
CATEGORIES= devel
#MASTER_SITES= ${MASTER_SITE_GNU}
#MASTER_SITE_SUBDIR= ${PORTNAME}/${PORTNAME}-${PORTVERSION}
diff --git a/devel/avr-gcc/files/patch-16bitassign b/devel/avr-gcc/files/patch-16bitassign
index 6a5659c18290..2241dfa1adbe 100644
--- a/devel/avr-gcc/files/patch-16bitassign
+++ b/devel/avr-gcc/files/patch-16bitassign
@@ -1,13 +1,300 @@
---- gcc/config/avr/avr.c.orig Mon Aug 12 15:13:56 2002
-+++ gcc/config/avr/avr.c Thu Aug 29 12:53:14 2002
-@@ -2711,8 +2711,8 @@
- }
- }
- else
-- return *l=2, (AS2 (st ,%0,%A1) CR_TAB
-- AS2 (std,%0+1,%B1));
-+ return *l=2, (AS2 (std,%0+1,%B1) CR_TAB
-+ AS2 (st ,%0,%A1));
- }
- else if (GET_CODE (base) == PLUS)
- {
+From marekm@amelek.gda.pl Sun Jan 19 02:37:50 2003
+Path: interface-business.de!not-for-mail
+Newsgroups: local.avr.gcc
+Followup-To: poster
+Reply-To: avr-gcc-list@avr1.org
+Subject: [avr-gcc-list] Patch for indirect 16-bit I/O
+To: avr-gcc-list@avr1.org
+X-Mailer: ELM [version 2.4ME+ PL95 (25)]
+MIME-Version: 1.0
+Content-Transfer-Encoding: 7bit
+Content-Type: text/plain; charset=US-ASCII
+Message-ID: <E18a4PG-0004Cs-00@alf.amelek.gda.pl>
+From: Marek Michalkiewicz <marekm@amelek.gda.pl>
+Sender: owner-avr-gcc-list@avr1.org
+Precedence: bulk
+Date: Sun, 19 Jan 2003 02:37:50 +0100 (CET)
+Lines: 280
+Xref: interface-business.de local.avr.gcc:2452
+
+Hi,
+
+This should handle all these 16-bit I/O accesses addressed with
+pointers ("volatile" is required to force writing high byte first
+and reading low byte first in absolutely all cases, even if that
+makes the code less efficient). The patch is for CVS mainline, but
+should apply cleanly to the 3.3 branch too. I'm not committing it
+to GCC CVS just yet - please test, I haven't... well, it compiles :)
+
+BTW, mainline currently requires that SEEK_{SET,CUR,END} are
+defined in <stdio.h> - otherwise some new libgcc2.c stuff (unused
+on the AVR, but it has to compile) will cause the build to fail.
+Just edit /usr/local/avr/include/stdio.h to add them manually...
+
+Marek
+
+
+Index: gcc/config/avr/avr.c
+===================================================================
+RCS file: /cvs/gcc/gcc/gcc/config/avr/avr.c,v
+retrieving revision 1.87
+diff -c -3 -p -r1.87 avr.c
+*** gcc/config/avr/avr.c 16 Dec 2002 18:20:58 -0000 1.87
+--- gcc/config/avr/avr.c 19 Jan 2003 01:07:52 -0000
+*************** print_operand (file, x, code)
+*** 1138,1143 ****
+--- 1138,1153 ----
+
+ print_operand (file, XEXP (addr, 1), 0);
+ }
++ else if (code == 'p' || code == 'r')
++ {
++ if (GET_CODE (addr) != POST_INC && GET_CODE (addr) != PRE_DEC)
++ fatal_insn ("bad address, not post_inc or pre_dec:", addr);
++
++ if (code == 'p')
++ print_operand_address (file, XEXP (addr, 0)); /* X, Y, Z */
++ else
++ print_operand (file, XEXP (addr, 0), 0); /* r26, r28, r30 */
++ }
+ else if (GET_CODE (addr) == PLUS)
+ {
+ print_operand_address (file, XEXP (addr,0));
+*************** out_movhi_r_mr (insn, op, l)
+*** 1944,1949 ****
+--- 1954,1962 ----
+ rtx base = XEXP (src, 0);
+ int reg_dest = true_regnum (dest);
+ int reg_base = true_regnum (base);
++ /* "volatile" forces reading low byte first, even if less efficient,
++ for correct operation with 16-bit I/O registers. */
++ int mem_volatile_p = MEM_VOLATILE_P (src);
+ int tmp;
+
+ if (!l)
+*************** out_movhi_r_mr (insn, op, l)
+*** 2037,2042 ****
+--- 2050,2074 ----
+ if (reg_overlap_mentioned_p (dest, XEXP (base, 0)))
+ fatal_insn ("incorrect insn:", insn);
+
++ if (mem_volatile_p)
++ {
++ if (REGNO (XEXP (base, 0)) == REG_X)
++ {
++ *l = 4;
++ return (AS2 (sbiw,r26,2) CR_TAB
++ AS2 (ld,%A0,X+) CR_TAB
++ AS2 (ld,%B0,X) CR_TAB
++ AS2 (sbiw,r26,1));
++ }
++ else
++ {
++ *l = 3;
++ return (AS2 (sbiw,%r1,2) CR_TAB
++ AS2 (ld,%A0,%p1) CR_TAB
++ AS2 (ldd,%B0,%p1+1));
++ }
++ }
++
+ *l = 2;
+ return (AS2 (ld,%B0,%1) CR_TAB
+ AS2 (ld,%A0,%1));
+*************** out_movhi_mr_r (insn, op, l)
+*** 2668,2674 ****
+--- 2700,2710 ----
+ rtx base = XEXP (dest, 0);
+ int reg_base = true_regnum (base);
+ int reg_src = true_regnum (src);
++ /* "volatile" forces writing high byte first, even if less efficient,
++ for correct operation with 16-bit I/O registers. */
++ int mem_volatile_p = MEM_VOLATILE_P (dest);
+ int tmp;
++
+ if (!l)
+ l = &tmp;
+ if (CONSTANT_ADDRESS_P (base))
+*************** out_movhi_mr_r (insn, op, l)
+*** 2688,2720 ****
+ {
+ if (reg_src == REG_X)
+ {
+! /* "st X+,r26" is undefined */
+! if (reg_unused_after (insn, src))
+ return *l=4, (AS2 (mov,__tmp_reg__,r27) CR_TAB
+ AS2 (st,X,r26) CR_TAB
+ AS2 (adiw,r26,1) CR_TAB
+ AS2 (st,X,__tmp_reg__));
+ else
+ return *l=5, (AS2 (mov,__tmp_reg__,r27) CR_TAB
+- AS2 (st,X,r26) CR_TAB
+ AS2 (adiw,r26,1) CR_TAB
+ AS2 (st,X,__tmp_reg__) CR_TAB
+! AS2 (sbiw,r26,1));
+ }
+ else
+ {
+! if (reg_unused_after (insn, base))
+ return *l=2, (AS2 (st,X+,%A1) CR_TAB
+ AS2 (st,X,%B1));
+ else
+! return *l=3, (AS2 (st ,X+,%A1) CR_TAB
+! AS2 (st ,X,%B1) CR_TAB
+! AS2 (sbiw,r26,1));
+ }
+ }
+ else
+! return *l=2, (AS2 (st ,%0,%A1) CR_TAB
+! AS2 (std,%0+1,%B1));
+ }
+ else if (GET_CODE (base) == PLUS)
+ {
+--- 2724,2756 ----
+ {
+ if (reg_src == REG_X)
+ {
+! /* "st X+,r26" and "st -X,r26" are undefined. */
+! if (!mem_volatile_p && reg_unused_after (insn, src))
+ return *l=4, (AS2 (mov,__tmp_reg__,r27) CR_TAB
+ AS2 (st,X,r26) CR_TAB
+ AS2 (adiw,r26,1) CR_TAB
+ AS2 (st,X,__tmp_reg__));
+ else
+ return *l=5, (AS2 (mov,__tmp_reg__,r27) CR_TAB
+ AS2 (adiw,r26,1) CR_TAB
+ AS2 (st,X,__tmp_reg__) CR_TAB
+! AS2 (sbiw,r26,1) CR_TAB
+! AS2 (st,X,r26));
+ }
+ else
+ {
+! if (!mem_volatile_p && reg_unused_after (insn, base))
+ return *l=2, (AS2 (st,X+,%A1) CR_TAB
+ AS2 (st,X,%B1));
+ else
+! return *l=3, (AS2 (adiw,r26,1) CR_TAB
+! AS2 (st,X,%B1) CR_TAB
+! AS2 (st,-X,%A1));
+ }
+ }
+ else
+! return *l=2, (AS2 (std,%0+1,%B1) CR_TAB
+! AS2 (st,%0,%A1));
+ }
+ else if (GET_CODE (base) == PLUS)
+ {
+*************** out_movhi_mr_r (insn, op, l)
+*** 2727,2740 ****
+
+ if (disp <= 63 + MAX_LD_OFFSET (GET_MODE (dest)))
+ return *l = 4, (AS2 (adiw,r28,%o0-62) CR_TAB
+- AS2 (std,Y+62,%A1) CR_TAB
+ AS2 (std,Y+63,%B1) CR_TAB
+ AS2 (sbiw,r28,%o0-62));
+
+ return *l = 6, (AS2 (subi,r28,lo8(-%o0)) CR_TAB
+ AS2 (sbci,r29,hi8(-%o0)) CR_TAB
+- AS2 (st,Y,%A1) CR_TAB
+ AS2 (std,Y+1,%B1) CR_TAB
+ AS2 (subi,r28,lo8(%o0)) CR_TAB
+ AS2 (sbci,r29,hi8(%o0)));
+ }
+--- 2763,2776 ----
+
+ if (disp <= 63 + MAX_LD_OFFSET (GET_MODE (dest)))
+ return *l = 4, (AS2 (adiw,r28,%o0-62) CR_TAB
+ AS2 (std,Y+63,%B1) CR_TAB
++ AS2 (std,Y+62,%A1) CR_TAB
+ AS2 (sbiw,r28,%o0-62));
+
+ return *l = 6, (AS2 (subi,r28,lo8(-%o0)) CR_TAB
+ AS2 (sbci,r29,hi8(-%o0)) CR_TAB
+ AS2 (std,Y+1,%B1) CR_TAB
++ AS2 (st,Y,%A1) CR_TAB
+ AS2 (subi,r28,lo8(%o0)) CR_TAB
+ AS2 (sbci,r29,hi8(%o0)));
+ }
+*************** out_movhi_mr_r (insn, op, l)
+*** 2746,2772 ****
+ *l = 7;
+ return (AS2 (mov,__tmp_reg__,r26) CR_TAB
+ AS2 (mov,__zero_reg__,r27) CR_TAB
+! AS2 (adiw,r26,%o0) CR_TAB
+! AS2 (st,X+,__tmp_reg__) CR_TAB
+ AS2 (st,X,__zero_reg__) CR_TAB
+ AS1 (clr,__zero_reg__) CR_TAB
+! AS2 (sbiw,r26,%o0+1));
+ }
+ *l = 4;
+! return (AS2 (adiw,r26,%o0) CR_TAB
+! AS2 (st,X+,%A1) CR_TAB
+! AS2 (st,X,%B1) CR_TAB
+! AS2 (sbiw,r26,%o0+1));
+ }
+! return *l=2, (AS2 (std,%A0,%A1) CR_TAB
+! AS2 (std,%B0,%B1));
+ }
+ else if (GET_CODE (base) == PRE_DEC) /* (--R) */
+ return *l=2, (AS2 (st,%0,%B1) CR_TAB
+ AS2 (st,%0,%A1));
+ else if (GET_CODE (base) == POST_INC) /* (R++) */
+! return *l=2, (AS2 (st,%0,%A1) CR_TAB
+! AS2 (st,%0,%B1));
+ fatal_insn ("unknown move insn:",insn);
+ return "";
+ }
+--- 2782,2830 ----
+ *l = 7;
+ return (AS2 (mov,__tmp_reg__,r26) CR_TAB
+ AS2 (mov,__zero_reg__,r27) CR_TAB
+! AS2 (adiw,r26,%o0+1) CR_TAB
+ AS2 (st,X,__zero_reg__) CR_TAB
++ AS2 (st,-X,__tmp_reg__) CR_TAB
+ AS1 (clr,__zero_reg__) CR_TAB
+! AS2 (sbiw,r26,%o0));
+ }
+ *l = 4;
+! return (AS2 (adiw,r26,%o0+1) CR_TAB
+! AS2 (st,X,%B1) CR_TAB
+! AS2 (st,-X,%A1) CR_TAB
+! AS2 (sbiw,r26,%o0));
+ }
+! return *l=2, (AS2 (std,%B0,%B1) CR_TAB
+! AS2 (std,%A0,%A1));
+ }
+ else if (GET_CODE (base) == PRE_DEC) /* (--R) */
+ return *l=2, (AS2 (st,%0,%B1) CR_TAB
+ AS2 (st,%0,%A1));
+ else if (GET_CODE (base) == POST_INC) /* (R++) */
+! {
+! if (mem_volatile_p)
+! {
+! if (REGNO (XEXP (base, 0)) == REG_X)
+! {
+! *l = 4;
+! return (AS2 (adiw,r26,1) CR_TAB
+! AS2 (st,X,%B1) CR_TAB
+! AS2 (st,-X,%A1) CR_TAB
+! AS2 (adiw,r26,2));
+! }
+! else
+! {
+! *l = 3;
+! return (AS2 (std,%p0+1,%B1) CR_TAB
+! AS2 (st,%p0,%A1) CR_TAB
+! AS2 (adiw,%r0,2));
+! }
+! }
+!
+! *l = 2;
+! return (AS2 (st,%0,%A1) CR_TAB
+! AS2 (st,%0,%B1));
+! }
+ fatal_insn ("unknown move insn:",insn);
+ return "";
+ }
+
+
+
+avr-gcc-list at http://avr1.org
+