Upgrade AVR-GCC to GCC-3.4.4.
By the same time, combine all the patches that add support for new AVR devices into a single patch, as they all touch the same three source files. In total, add support for the following AVR devices that were not supported by the stock GCC 3.4.x: ATtiny13/ATtiny2313 ATtiny25/ATtiny45/ATtiny85 ATmega48/ATmega88/ATmega168 AT90PWM2/AT90PWM3 ATmega164/ATmega324/ATmega644 ATmega325/ATmega3250/ATmega645/ATmega6450 ATmega329/ATmega3290/ATmega649/ATmega6490 AT90CAN128 (This is now documented in pkg-descr as well.)
This commit is contained in:
parent
84e3a25369
commit
4f725f7b2f
Notes:
svn2git
2021-03-31 03:12:20 +00:00
svn path=/head/; revision=140495
16 changed files with 638 additions and 906 deletions
|
@ -6,8 +6,7 @@
|
|||
#
|
||||
|
||||
PORTNAME= gcc
|
||||
PORTVERSION= 3.4.3
|
||||
PORTREVISION= 1
|
||||
PORTVERSION= 3.4.4
|
||||
CATEGORIES= devel
|
||||
MASTER_SITES= ${MASTER_SITE_GCC}
|
||||
MASTER_SITES+= http://people.freebsd.org/~joerg/:local
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
MD5 (gcc-core-3.4.3.tar.bz2) = d2cbfe8fc3205c1d7969b26377405778
|
||||
SIZE (gcc-core-3.4.3.tar.bz2) = 13040222
|
||||
MD5 (gcc-g++-3.4.3.tar.bz2) = 26cb84db92feb8e03bb7bf3bc264844f
|
||||
SIZE (gcc-g++-3.4.3.tar.bz2) = 2475405
|
||||
MD5 (gcc-core-3.4.4.tar.bz2) = 9dd911fd9bc136ca42b73c68735d853b
|
||||
SIZE (gcc-core-3.4.4.tar.bz2) = 13153342
|
||||
MD5 (gcc-g++-3.4.4.tar.bz2) = a828b7024f07cebc3bc1e55dbfd4706a
|
||||
SIZE (gcc-g++-3.4.4.tar.bz2) = 2474402
|
||||
|
|
|
@ -1,215 +0,0 @@
|
|||
===================================================================
|
||||
RCS file: /cvsroot/gcc/cvsroot/gcc/gcc/gcc/config/avr/avr.c,v
|
||||
retrieving revision 1.129
|
||||
retrieving revision 1.130
|
||||
diff -u -r1.129 -r1.130
|
||||
--- gcc/config/avr/avr.c 2005/02/09 14:43:28 1.129
|
||||
+++ gcc/config/avr/avr.c 2005/03/06 21:50:34 1.130
|
||||
@@ -1120,6 +1120,16 @@
|
||||
|
||||
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));
|
||||
@@ -1835,6 +1845,9 @@
|
||||
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)
|
||||
@@ -1928,6 +1941,25 @@
|
||||
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));
|
||||
@@ -2508,7 +2540,11 @@
|
||||
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))
|
||||
@@ -2528,33 +2564,33 @@
|
||||
{
|
||||
if (reg_src == REG_X)
|
||||
{
|
||||
- /* "st X+,r26" is undefined */
|
||||
- if (reg_unused_after (insn, src))
|
||||
+ /* "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 (st,X,r26) CR_TAB
|
||||
AS2 (adiw,r26,1) CR_TAB
|
||||
AS2 (st,X,__tmp_reg__) CR_TAB
|
||||
- AS2 (sbiw,r26,1));
|
||||
+ AS2 (sbiw,r26,1) CR_TAB
|
||||
+ AS2 (st,X,r26));
|
||||
}
|
||||
else
|
||||
{
|
||||
- if (reg_unused_after (insn, base))
|
||||
+ 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 (st ,X+,%A1) CR_TAB
|
||||
- AS2 (st ,X,%B1) CR_TAB
|
||||
- AS2 (sbiw,r26,1));
|
||||
+ return *l=3, (AS2 (adiw,r26,1) CR_TAB
|
||||
+ AS2 (st,X,%B1) CR_TAB
|
||||
+ AS2 (st,-X,%A1));
|
||||
}
|
||||
}
|
||||
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)
|
||||
{
|
||||
@@ -2567,14 +2603,14 @@
|
||||
|
||||
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 (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 (st,Y,%A1) 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)));
|
||||
}
|
||||
@@ -2582,31 +2618,53 @@
|
||||
{
|
||||
/* (X + d) = R */
|
||||
if (reg_src == REG_X)
|
||||
- {
|
||||
+ {
|
||||
*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 (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+1));
|
||||
+ AS2 (sbiw,r26,%o0));
|
||||
}
|
||||
*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 (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,%A0,%A1) CR_TAB
|
||||
- AS2 (std,%B0,%B1));
|
||||
+ 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++) */
|
||||
- return *l=2, (AS2 (st,%0,%A1) CR_TAB
|
||||
- AS2 (st,%0,%B1));
|
||||
+ {
|
||||
+ 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 "";
|
||||
}
|
||||
===================================================================
|
||||
RCS file: /cvsroot/gcc/cvsroot/gcc/gcc/gcc/config/avr/avr.md,v
|
||||
retrieving revision 1.49
|
||||
retrieving revision 1.50
|
||||
diff -u -r1.49 -r1.50
|
||||
--- gcc/config/avr/avr.md 2005/01/27 18:22:25 1.49
|
||||
+++ gcc/config/avr/avr.md 2005/03/06 21:50:36 1.50
|
||||
@@ -30,6 +30,8 @@
|
||||
;; j Branch condition.
|
||||
;; k Reverse branch condition.
|
||||
;; o Displacement for (mem (plus (reg) (const_int))) operands.
|
||||
+;; p POST_INC or PRE_DEC address as a pointer (X, Y, Z)
|
||||
+;; r POST_INC or PRE_DEC address as a register (r26, r28, r30)
|
||||
;; ~ Output 'r' if not AVR_MEGA.
|
||||
|
||||
;; UNSPEC usage:
|
|
@ -1,124 +0,0 @@
|
|||
--- gcc/config/avr/avr.c.orig 2004-09-27 19:13:55.000000000 -0600
|
||||
+++ gcc/config/avr/avr.c 2005-02-01 14:58:40.465250000 -0700
|
||||
@@ -175,6 +175,9 @@
|
||||
{ "at90c8534", 2, "__AVR_AT90C8534__" },
|
||||
{ "at90s8535", 2, "__AVR_AT90S8535__" },
|
||||
{ "at86rf401", 2, "__AVR_AT86RF401__" },
|
||||
+ /* Classic + MOVW, <= 8K. */
|
||||
+ { "attiny13", 2, "__AVR_ATtiny13__" },
|
||||
+ { "attiny2313", 2, "__AVR_ATtiny2313__" },
|
||||
/* Classic, > 8K. */
|
||||
{ "avr3", 3, NULL },
|
||||
{ "atmega103", 3, "__AVR_ATmega103__" },
|
||||
@@ -185,6 +188,8 @@
|
||||
/* Enhanced, <= 8K. */
|
||||
{ "avr4", 4, NULL },
|
||||
{ "atmega8", 4, "__AVR_ATmega8__" },
|
||||
+ { "atmega48", 4, "__AVR_ATmega48__" },
|
||||
+ { "atmega88", 4, "__AVR_ATmega88__" },
|
||||
{ "atmega8515", 4, "__AVR_ATmega8515__" },
|
||||
{ "atmega8535", 4, "__AVR_ATmega8535__" },
|
||||
/* Enhanced, > 8K. */
|
||||
@@ -193,11 +198,13 @@
|
||||
{ "atmega161", 5, "__AVR_ATmega161__" },
|
||||
{ "atmega162", 5, "__AVR_ATmega162__" },
|
||||
{ "atmega163", 5, "__AVR_ATmega163__" },
|
||||
+ { "atmega168", 5, "__AVR_ATmega168__" },
|
||||
{ "atmega169", 5, "__AVR_ATmega169__" },
|
||||
{ "atmega32", 5, "__AVR_ATmega32__" },
|
||||
{ "atmega323", 5, "__AVR_ATmega323__" },
|
||||
{ "atmega64", 5, "__AVR_ATmega64__" },
|
||||
{ "atmega128", 5, "__AVR_ATmega128__" },
|
||||
+ { "at90can128", 5, "__AVR_AT90CAN128__" },
|
||||
{ "at94k", 5, "__AVR_AT94K__" },
|
||||
/* Assembler only. */
|
||||
{ "avr1", 1, NULL },
|
||||
|
||||
--- gcc/config/avr/avr.h.orig 2004-03-08 19:59:55.000000000 -0700
|
||||
+++ gcc/config/avr/avr.h 2005-02-01 14:58:40.480875000 -0700
|
||||
@@ -2351,12 +2351,12 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LINK_SPEC " %{!mmcu*:-m avr2}\
|
||||
-%{mmcu=at90s1200|mmcu=attiny1*|mmcu=attiny28:-m avr1} \
|
||||
-%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401:-m avr2}\
|
||||
+%{mmcu=at90s1200|mmcu=attiny11|mmcu=attiny12|mmcu=attiny15|mmcu=attiny28:-m avr1} \
|
||||
+%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401|mmcu=attiny13|mmcu=attiny2313:-m avr2}\
|
||||
%{mmcu=atmega103|mmcu=atmega603|mmcu=at43*|mmcu=at76*:-m avr3}\
|
||||
-%{mmcu=atmega8*:-m avr4}\
|
||||
-%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64|mmcu=atmega128|mmcu=at94k:-m avr5}\
|
||||
-%{mmcu=atmega64|mmcu=atmega128|mmcu=atmega162|mmcu=atmega169: -Tdata 0x800100} "
|
||||
+%{mmcu=atmega8*|mmcu=atmega48:-m avr4}\
|
||||
+%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64|mmcu=atmega128|mmcu=at90can128|mmcu=at94k:-m avr5}\
|
||||
+%{mmcu=atmega48|mmcu=atmega88|mmcu=atmega64|mmcu=atmega128|mmcu=at90can128|mmcu=at90can128|mmcu=atmega162|mmcu=atmega168|mmcu=atmega169: -Tdata 0x800100} "
|
||||
|
||||
/* A C string constant that tells the GCC driver program options to
|
||||
pass to the linker. It can also specify how to translate options
|
||||
@@ -2365,7 +2365,7 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LIB_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lc }}}}}"
|
||||
/* Another C string constant used much like `LINK_SPEC'. The
|
||||
difference between the two is that `LIB_SPEC' is used at the end
|
||||
of the command given to the linker.
|
||||
@@ -2377,7 +2377,7 @@
|
||||
/* No libstdc++ for now. Empty string doesn't work. */
|
||||
|
||||
#define LIBGCC_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lgcc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lgcc }}}}}"
|
||||
/* Another C string constant that tells the GCC driver program how
|
||||
and when to place a reference to `libgcc.a' into the linker
|
||||
command line. This constant is placed both before and after the
|
||||
@@ -2421,23 +2421,29 @@
|
||||
%{mmcu=at90c8534:crtc8534.o%s} \
|
||||
%{mmcu=at90s8535:crts8535.o%s} \
|
||||
%{mmcu=at86rf401:crt86401.o%s} \
|
||||
+%{mmcu=attiny13:crttn13.o%s} \
|
||||
+%{mmcu=attiny2313:crttn2313.o%s} \
|
||||
%{mmcu=atmega103|mmcu=avr3:crtm103.o%s} \
|
||||
%{mmcu=atmega603:crtm603.o%s} \
|
||||
%{mmcu=at43usb320:crt43320.o%s} \
|
||||
%{mmcu=at43usb355:crt43355.o%s} \
|
||||
%{mmcu=at76c711:crt76711.o%s} \
|
||||
%{mmcu=atmega8|mmcu=avr4:crtm8.o%s} \
|
||||
+%{mmcu=atmega48:crtm48.o%s} \
|
||||
+%{mmcu=atmega88:crtm88.o%s} \
|
||||
%{mmcu=atmega8515:crtm8515.o%s} \
|
||||
%{mmcu=atmega8535:crtm8535.o%s} \
|
||||
%{mmcu=atmega16:crtm16.o%s} \
|
||||
%{mmcu=atmega161|mmcu=avr5:crtm161.o%s} \
|
||||
%{mmcu=atmega162:crtm162.o%s} \
|
||||
%{mmcu=atmega163:crtm163.o%s} \
|
||||
+%{mmcu=atmega168:crtm168.o%s} \
|
||||
%{mmcu=atmega169:crtm169.o%s} \
|
||||
%{mmcu=atmega32:crtm32.o%s} \
|
||||
%{mmcu=atmega323:crtm323.o%s} \
|
||||
%{mmcu=atmega64:crtm64.o%s} \
|
||||
%{mmcu=atmega128:crtm128.o%s} \
|
||||
+%{mmcu=at90can128:crtcan128.o%s} \
|
||||
%{mmcu=at94k:crtat94k.o%s}"
|
||||
|
||||
#define EXTRA_SPECS {"crt_binutils", CRT_BINUTILS_SPECS},
|
||||
--- gcc/config/avr/t-avr.orig 2003-02-27 14:45:33.000000000 -0700
|
||||
+++ gcc/config/avr/t-avr 2005-02-01 14:58:40.480875000 -0700
|
||||
@@ -50,13 +50,14 @@
|
||||
mmcu?avr3=mmcu?at43usb320 mmcu?avr3=mmcu?at43usb355 \
|
||||
mmcu?avr3=mmcu?at76c711 \
|
||||
mmcu?avr4=mmcu?atmega8515 mmcu?avr4=mmcu?atmega8535 \
|
||||
- mmcu?avr4=mmcu?atmega8 \
|
||||
+ mmcu?avr4=mmcu?atmega8 mmcu?avr4=mmcu?atmega48 \
|
||||
+ mmcu?avr4=mmcu?atmega88 \
|
||||
mmcu?avr5=mmcu?atmega161 mmcu?avr5=mmcu?atmega162 \
|
||||
mmcu?avr5=mmcu?atmega163 mmcu?avr5=mmcu?atmega169 \
|
||||
- mmcu?avr5=mmcu?atmega16 \
|
||||
+ mmcu?avr5=mmcu?atmega16 mmcu?avr5=mmcu?atmega168 \
|
||||
mmcu?avr5=mmcu?atmega323 mmcu?avr5=mmcu?atmega32 \
|
||||
mmcu?avr5=mmcu?atmega64 mmcu?avr5=mmcu?atmega128 \
|
||||
- mmcu?avr5=mmcu?at94k
|
||||
+ mmcu?avr5=mmcu?at94k mmcu?avr5=mmcu?at90can128
|
||||
|
||||
MULTILIB_EXCEPTIONS =
|
||||
|
|
@ -1,58 +0,0 @@
|
|||
2005-03-04 Eric B. Weddington <ericw@evcohs.com>
|
||||
|
||||
* gcc/config/avr/avr.c (avr_mcu_types): Add entries for atmega325,
|
||||
atmega3250, atmega645, atmega6450.
|
||||
* gcc/config/avr/avr.h (LINK_SPEC): Ditto.
|
||||
(CRT_BINUTILS_SPECS): Ditto.
|
||||
* gcc/config/avr/t-avr (MULTILIB_MATCHES): Ditto.
|
||||
|
||||
--- gcc/config/avr/avr.c.old 2005-02-10 17:36:47.921875000 -0700
|
||||
+++ gcc/config/avr/avr.c 2005-03-04 09:35:26.633875000 -0700
|
||||
@@ -202,7 +202,11 @@
|
||||
{ "atmega169", 5, "__AVR_ATmega169__" },
|
||||
{ "atmega32", 5, "__AVR_ATmega32__" },
|
||||
{ "atmega323", 5, "__AVR_ATmega323__" },
|
||||
+ { "atmega325", 5, "__AVR_ATmega325__" },
|
||||
+ { "atmega3250", 5, "__AVR_ATmega3250__" },
|
||||
{ "atmega64", 5, "__AVR_ATmega64__" },
|
||||
+ { "atmega645", 5, "__AVR_ATmega645__" },
|
||||
+ { "atmega6450", 5, "__AVR_ATmega6450__" },
|
||||
{ "atmega128", 5, "__AVR_ATmega128__" },
|
||||
{ "at90can128", 5, "__AVR_AT90CAN128__" },
|
||||
{ "at94k", 5, "__AVR_AT94K__" },
|
||||
--- gcc/config/avr/avr.h.old 2005-02-10 17:36:48.015625000 -0700
|
||||
+++ gcc/config/avr/avr.h 2005-03-04 09:44:23.118250000 -0700
|
||||
@@ -2355,8 +2355,8 @@
|
||||
%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401|mmcu=attiny13|mmcu=attiny2313:-m avr2}\
|
||||
%{mmcu=atmega103|mmcu=atmega603|mmcu=at43*|mmcu=at76*:-m avr3}\
|
||||
%{mmcu=atmega8*|mmcu=atmega48:-m avr4}\
|
||||
-%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64|mmcu=atmega128|mmcu=at90can128|mmcu=at94k:-m avr5}\
|
||||
-%{mmcu=atmega48|mmcu=atmega88|mmcu=atmega64|mmcu=atmega128|mmcu=at90can128|mmcu=at90can128|mmcu=atmega162|mmcu=atmega168|mmcu=atmega169: -Tdata 0x800100} "
|
||||
+%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64*|mmcu=atmega128|mmcu=at90can128|mmcu=at94k:-m avr5}\
|
||||
+%{mmcu=atmega325|mmcu=atmega3250|mmcu=atmega48|mmcu=atmega88|mmcu=atmega64|mmcu=atmega645|mmcu=atmega6450|mmcu=atmega128|mmcu=at90can128|mmcu=at90can128|mmcu=atmega162|mmcu=atmega168|mmcu=atmega169: -Tdata 0x800100} "
|
||||
|
||||
/* A C string constant that tells the GCC driver program options to
|
||||
pass to the linker. It can also specify how to translate options
|
||||
@@ -2441,7 +2441,11 @@
|
||||
%{mmcu=atmega169:crtm169.o%s} \
|
||||
%{mmcu=atmega32:crtm32.o%s} \
|
||||
%{mmcu=atmega323:crtm323.o%s} \
|
||||
+%{mmcu=atmega325:crtm325.o%s} \
|
||||
+%{mmcu=atmega3250:crtm3250.o%s} \
|
||||
%{mmcu=atmega64:crtm64.o%s} \
|
||||
+%{mmcu=atmega645:crtm645.o%s} \
|
||||
+%{mmcu=atmega6450:crtm6450.o%s} \
|
||||
%{mmcu=atmega128:crtm128.o%s} \
|
||||
%{mmcu=at90can128:crtcan128.o%s} \
|
||||
%{mmcu=at94k:crtat94k.o%s}"
|
||||
--- gcc/config/avr/t-avr.old 2005-02-10 17:36:48.031250000 -0700
|
||||
+++ gcc/config/avr/t-avr 2005-03-04 09:56:43.790125000 -0700
|
||||
@@ -56,6 +56,8 @@
|
||||
mmcu?avr5=mmcu?atmega163 mmcu?avr5=mmcu?atmega169 \
|
||||
mmcu?avr5=mmcu?atmega16 mmcu?avr5=mmcu?atmega168 \
|
||||
mmcu?avr5=mmcu?atmega323 mmcu?avr5=mmcu?atmega32 \
|
||||
+ mmcu?avr5=mmcu?atmega325 mmcu?avr5=mmcu?atmega3250 \
|
||||
+ mmcu?avr5=mmcu?atmega645 mmcu?avr5=mmcu?atmega6450 \
|
||||
mmcu?avr5=mmcu?atmega64 mmcu?avr5=mmcu?atmega128 \
|
||||
mmcu?avr5=mmcu?at94k mmcu?avr5=mmcu?at90can128
|
||||
|
253
devel/avr-gcc-3/files/patch-newdevices
Normal file
253
devel/avr-gcc-3/files/patch-newdevices
Normal file
|
@ -0,0 +1,253 @@
|
|||
diff -ur /tmp/gcc-orig/gcc/config/avr/avr.c ./gcc/config/avr/avr.c
|
||||
--- /tmp/gcc-orig/gcc/config/avr/avr.c Sun Mar 20 22:14:28 2005
|
||||
+++ ./gcc/config/avr/avr.c Sat Jul 30 23:01:43 2005
|
||||
@@ -175,6 +175,12 @@
|
||||
{ "at90c8534", 2, "__AVR_AT90C8534__" },
|
||||
{ "at90s8535", 2, "__AVR_AT90S8535__" },
|
||||
{ "at86rf401", 2, "__AVR_AT86RF401__" },
|
||||
+ /* Classic + MOVW, <= 8K. */
|
||||
+ { "attiny13", 2, "__AVR_ATtiny13__" },
|
||||
+ { "attiny2313", 2, "__AVR_ATtiny2313__" },
|
||||
+ { "attiny25", 2, "__AVR_ATtiny25__" },
|
||||
+ { "attiny45", 2, "__AVR_ATtiny45__" },
|
||||
+ { "attiny85", 2, "__AVR_ATtiny85__" },
|
||||
/* Classic, > 8K. */
|
||||
{ "avr3", 3, NULL },
|
||||
{ "atmega103", 3, "__AVR_ATmega103__" },
|
||||
@@ -185,19 +191,36 @@
|
||||
/* Enhanced, <= 8K. */
|
||||
{ "avr4", 4, NULL },
|
||||
{ "atmega8", 4, "__AVR_ATmega8__" },
|
||||
+ { "atmega48", 4, "__AVR_ATmega48__" },
|
||||
+ { "atmega88", 4, "__AVR_ATmega88__" },
|
||||
{ "atmega8515", 4, "__AVR_ATmega8515__" },
|
||||
{ "atmega8535", 4, "__AVR_ATmega8535__" },
|
||||
+ { "at90pwm2", 4, "__AVR_AT90PWM2__" },
|
||||
+ { "at90pwm3", 4, "__AVR_AT90PWM3__" },
|
||||
/* Enhanced, > 8K. */
|
||||
{ "avr5", 5, NULL },
|
||||
{ "atmega16", 5, "__AVR_ATmega16__" },
|
||||
{ "atmega161", 5, "__AVR_ATmega161__" },
|
||||
{ "atmega162", 5, "__AVR_ATmega162__" },
|
||||
{ "atmega163", 5, "__AVR_ATmega163__" },
|
||||
+ { "atmega164", 5, "__AVR_ATmega164__" },
|
||||
+ { "atmega168", 5, "__AVR_ATmega168__" },
|
||||
{ "atmega169", 5, "__AVR_ATmega169__" },
|
||||
{ "atmega32", 5, "__AVR_ATmega32__" },
|
||||
{ "atmega323", 5, "__AVR_ATmega323__" },
|
||||
+ { "atmega324", 5, "__AVR_ATmega324__" },
|
||||
+ { "atmega325", 5, "__AVR_ATmega325__" },
|
||||
+ { "atmega3250", 5, "__AVR_ATmega3250__" },
|
||||
+ { "atmega329", 5, "__AVR_ATmega329__" },
|
||||
+ { "atmega3290", 5, "__AVR_ATmega3290__" },
|
||||
{ "atmega64", 5, "__AVR_ATmega64__" },
|
||||
+ { "atmega644", 5, "__AVR_ATmega644__" },
|
||||
+ { "atmega645", 5, "__AVR_ATmega645__" },
|
||||
+ { "atmega6450", 5, "__AVR_ATmega6450__" },
|
||||
+ { "atmega649", 5, "__AVR_ATmega649__" },
|
||||
+ { "atmega6490", 5, "__AVR_ATmega6490__" },
|
||||
{ "atmega128", 5, "__AVR_ATmega128__" },
|
||||
+ { "at90can128", 5, "__AVR_AT90CAN128__" },
|
||||
{ "at94k", 5, "__AVR_AT94K__" },
|
||||
/* Assembler only. */
|
||||
{ "avr1", 1, NULL },
|
||||
diff -ur /tmp/gcc-orig/gcc/config/avr/avr.h ./gcc/config/avr/avr.h
|
||||
--- /tmp/gcc-orig/gcc/config/avr/avr.h Sat Jul 30 15:01:51 2005
|
||||
+++ ./gcc/config/avr/avr.h Sat Jul 30 23:03:48 2005
|
||||
@@ -2351,12 +2351,12 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LINK_SPEC " %{!mmcu*:-m avr2}\
|
||||
-%{mmcu=at90s1200|mmcu=attiny1*|mmcu=attiny28:-m avr1} \
|
||||
-%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401:-m avr2}\
|
||||
+%{mmcu=at90s1200|mmcu=attiny11|mmcu=attiny12|mmcu=attiny15|mmcu=attiny28:-m avr1} \
|
||||
+%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401|mmcu=attiny13|mmcu=attiny2313|mmcu=attiny25|mmcu=attiny45|mmcu=attiny85:-m avr2}\
|
||||
%{mmcu=atmega103|mmcu=atmega603|mmcu=at43*|mmcu=at76*:-m avr3}\
|
||||
-%{mmcu=atmega8*:-m avr4}\
|
||||
-%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64|mmcu=atmega128|mmcu=at94k:-m avr5}\
|
||||
-%{mmcu=atmega64|mmcu=atmega128|mmcu=atmega162|mmcu=atmega169: -Tdata 0x800100} "
|
||||
+%{mmcu=atmega8*|mmcu=atmega48|mmcu=at90pwm*:-m avr4}\
|
||||
+%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64*|mmcu=atmega128|mmcu=at90can128|mmcu=at94k:-m avr5}\
|
||||
+%{mmcu=atmega324|mmcu=atmega325|mmcu=atmega3250|mmcu=atmega329|mmcu=atmega3290|mmcu=atmega48|mmcu=atmega88|mmcu=atmega64|mmcu=atmega644|mmcu=atmega645|mmcu=atmega6450|mmcu=atmega649|mmcu=atmega6490|mmcu=atmega128|mmcu=at90can128|mmcu=atmega162|mmcu=atmega164|mmcu=atmega168|mmcu=atmega169: -Tdata 0x800100} "
|
||||
|
||||
/* A C string constant that tells the GCC driver program options to
|
||||
pass to the linker. It can also specify how to translate options
|
||||
@@ -2365,7 +2365,7 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LIB_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lc }}}}}"
|
||||
/* Another C string constant used much like `LINK_SPEC'. The
|
||||
difference between the two is that `LIB_SPEC' is used at the end
|
||||
of the command given to the linker.
|
||||
@@ -2377,7 +2377,7 @@
|
||||
/* No libstdc++ for now. Empty string doesn't work. */
|
||||
|
||||
#define LIBGCC_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lgcc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lgcc }}}}}"
|
||||
/* Another C string constant that tells the GCC driver program how
|
||||
and when to place a reference to `libgcc.a' into the linker
|
||||
command line. This constant is placed both before and after the
|
||||
@@ -2421,23 +2421,45 @@
|
||||
%{mmcu=at90c8534:crtc8534.o%s} \
|
||||
%{mmcu=at90s8535:crts8535.o%s} \
|
||||
%{mmcu=at86rf401:crt86401.o%s} \
|
||||
+%{mmcu=attiny13:crttn13.o%s} \
|
||||
+%{mmcu=attiny2313:crttn2313.o%s} \
|
||||
+%{mmcu=attiny25:crttn25.o%s} \
|
||||
+%{mmcu=attiny45:crttn45.o%s} \
|
||||
+%{mmcu=attiny85:crttn85.o%s} \
|
||||
%{mmcu=atmega103|mmcu=avr3:crtm103.o%s} \
|
||||
%{mmcu=atmega603:crtm603.o%s} \
|
||||
%{mmcu=at43usb320:crt43320.o%s} \
|
||||
%{mmcu=at43usb355:crt43355.o%s} \
|
||||
%{mmcu=at76c711:crt76711.o%s} \
|
||||
%{mmcu=atmega8|mmcu=avr4:crtm8.o%s} \
|
||||
+%{mmcu=atmega48:crtm48.o%s} \
|
||||
+%{mmcu=atmega88:crtm88.o%s} \
|
||||
%{mmcu=atmega8515:crtm8515.o%s} \
|
||||
%{mmcu=atmega8535:crtm8535.o%s} \
|
||||
+%{mmcu=at90pwm2:crt90pwm2.o%s} \
|
||||
+%{mmcu=at90pwm3:crt90pwm3.o%s} \
|
||||
%{mmcu=atmega16:crtm16.o%s} \
|
||||
%{mmcu=atmega161|mmcu=avr5:crtm161.o%s} \
|
||||
%{mmcu=atmega162:crtm162.o%s} \
|
||||
%{mmcu=atmega163:crtm163.o%s} \
|
||||
+%{mmcu=atmega164:crtm164.o%s} \
|
||||
+%{mmcu=atmega168:crtm168.o%s} \
|
||||
%{mmcu=atmega169:crtm169.o%s} \
|
||||
%{mmcu=atmega32:crtm32.o%s} \
|
||||
%{mmcu=atmega323:crtm323.o%s} \
|
||||
+%{mmcu=atmega324:crtm324.o%s} \
|
||||
+%{mmcu=atmega325:crtm325.o%s} \
|
||||
+%{mmcu=atmega3250:crtm3250.o%s} \
|
||||
+%{mmcu=atmega329:crtm329.o%s} \
|
||||
+%{mmcu=atmega3290:crtm3290.o%s} \
|
||||
%{mmcu=atmega64:crtm64.o%s} \
|
||||
+%{mmcu=atmega644:crtm644.o%s} \
|
||||
+%{mmcu=atmega645:crtm645.o%s} \
|
||||
+%{mmcu=atmega6450:crtm6450.o%s} \
|
||||
+%{mmcu=atmega649:crtm649.o%s} \
|
||||
+%{mmcu=atmega6490:crtm6490.o%s} \
|
||||
%{mmcu=atmega128:crtm128.o%s} \
|
||||
+%{mmcu=at90can128:crtcan128.o%s} \
|
||||
%{mmcu=at94k:crtat94k.o%s}"
|
||||
|
||||
#define EXTRA_SPECS {"crt_binutils", CRT_BINUTILS_SPECS},
|
||||
diff -ur /tmp/gcc-orig/gcc/config/avr/avr.h.orig ./gcc/config/avr/avr.h.orig
|
||||
--- /tmp/gcc-orig/gcc/config/avr/avr.h.orig Tue Mar 9 03:59:55 2004
|
||||
+++ ./gcc/config/avr/avr.h.orig Sat Jul 30 22:27:40 2005
|
||||
@@ -2351,12 +2351,12 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LINK_SPEC " %{!mmcu*:-m avr2}\
|
||||
-%{mmcu=at90s1200|mmcu=attiny1*|mmcu=attiny28:-m avr1} \
|
||||
-%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401:-m avr2}\
|
||||
+%{mmcu=at90s1200|mmcu=attiny11|mmcu=attiny12|mmcu=attiny15|mmcu=attiny28:-m avr1} \
|
||||
+%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401|mmcu=attiny13|mmcu=attiny2313|mmcu=attiny25|mmcu=attiny45|mmcu=attiny85:-m avr2}\
|
||||
%{mmcu=atmega103|mmcu=atmega603|mmcu=at43*|mmcu=at76*:-m avr3}\
|
||||
-%{mmcu=atmega8*:-m avr4}\
|
||||
-%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64|mmcu=atmega128|mmcu=at94k:-m avr5}\
|
||||
-%{mmcu=atmega64|mmcu=atmega128|mmcu=atmega162|mmcu=atmega169: -Tdata 0x800100} "
|
||||
+%{mmcu=atmega8*|mmcu=atmega48|mmcu=at90pwm*:-m avr4}\
|
||||
+%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64*|mmcu=atmega128|mmcu=at90can128|mmcu=at94k:-m avr5}\
|
||||
+%{mmcu=atmega325|mmcu=atmega3250|mmcu=atmega48|mmcu=atmega88|mmcu=atmega64|mmcu=atmega645|mmcu=atmega6450|mmcu=atmega128|mmcu=at90can128|mmcu=at90can128|mmcu=atmega162|mmcu=atmega168|mmcu=atmega169: -Tdata 0x800100} "
|
||||
|
||||
/* A C string constant that tells the GCC driver program options to
|
||||
pass to the linker. It can also specify how to translate options
|
||||
@@ -2365,7 +2365,7 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LIB_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lc }}}}}"
|
||||
/* Another C string constant used much like `LINK_SPEC'. The
|
||||
difference between the two is that `LIB_SPEC' is used at the end
|
||||
of the command given to the linker.
|
||||
@@ -2377,7 +2377,7 @@
|
||||
/* No libstdc++ for now. Empty string doesn't work. */
|
||||
|
||||
#define LIBGCC_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lgcc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lgcc }}}}}"
|
||||
/* Another C string constant that tells the GCC driver program how
|
||||
and when to place a reference to `libgcc.a' into the linker
|
||||
command line. This constant is placed both before and after the
|
||||
@@ -2421,23 +2421,38 @@
|
||||
%{mmcu=at90c8534:crtc8534.o%s} \
|
||||
%{mmcu=at90s8535:crts8535.o%s} \
|
||||
%{mmcu=at86rf401:crt86401.o%s} \
|
||||
+%{mmcu=attiny13:crttn13.o%s} \
|
||||
+%{mmcu=attiny2313:crttn2313.o%s} \
|
||||
+%{mmcu=attiny25:crttn25.o%s} \
|
||||
+%{mmcu=attiny45:crttn45.o%s} \
|
||||
+%{mmcu=attiny85:crttn85.o%s} \
|
||||
%{mmcu=atmega103|mmcu=avr3:crtm103.o%s} \
|
||||
%{mmcu=atmega603:crtm603.o%s} \
|
||||
%{mmcu=at43usb320:crt43320.o%s} \
|
||||
%{mmcu=at43usb355:crt43355.o%s} \
|
||||
%{mmcu=at76c711:crt76711.o%s} \
|
||||
%{mmcu=atmega8|mmcu=avr4:crtm8.o%s} \
|
||||
+%{mmcu=atmega48:crtm48.o%s} \
|
||||
+%{mmcu=atmega88:crtm88.o%s} \
|
||||
%{mmcu=atmega8515:crtm8515.o%s} \
|
||||
%{mmcu=atmega8535:crtm8535.o%s} \
|
||||
+%{mmcu=at90pwm2:crt90pwm2.o%s} \
|
||||
+%{mmcu=at90pwm3:crt90pwm3.o%s} \
|
||||
%{mmcu=atmega16:crtm16.o%s} \
|
||||
%{mmcu=atmega161|mmcu=avr5:crtm161.o%s} \
|
||||
%{mmcu=atmega162:crtm162.o%s} \
|
||||
%{mmcu=atmega163:crtm163.o%s} \
|
||||
+%{mmcu=atmega168:crtm168.o%s} \
|
||||
%{mmcu=atmega169:crtm169.o%s} \
|
||||
%{mmcu=atmega32:crtm32.o%s} \
|
||||
%{mmcu=atmega323:crtm323.o%s} \
|
||||
+%{mmcu=atmega325:crtm325.o%s} \
|
||||
+%{mmcu=atmega3250:crtm3250.o%s} \
|
||||
%{mmcu=atmega64:crtm64.o%s} \
|
||||
+%{mmcu=atmega645:crtm645.o%s} \
|
||||
+%{mmcu=atmega6450:crtm6450.o%s} \
|
||||
%{mmcu=atmega128:crtm128.o%s} \
|
||||
+%{mmcu=at90can128:crtcan128.o%s} \
|
||||
%{mmcu=at94k:crtat94k.o%s}"
|
||||
|
||||
#define EXTRA_SPECS {"crt_binutils", CRT_BINUTILS_SPECS},
|
||||
@@ -2479,4 +2494,5 @@
|
||||
/* zero register r1 */
|
||||
#define ZERO_REGNO 1
|
||||
|
||||
+#define DWARF2_DEBUGGING_INFO 1
|
||||
#define PREFERRED_DEBUGGING_TYPE DBX_DEBUG
|
||||
diff -ur /tmp/gcc-orig/gcc/config/avr/t-avr ./gcc/config/avr/t-avr
|
||||
--- /tmp/gcc-orig/gcc/config/avr/t-avr Mon Apr 25 06:17:34 2005
|
||||
+++ ./gcc/config/avr/t-avr Sat Jul 30 23:06:40 2005
|
||||
@@ -46,13 +46,22 @@
|
||||
mmcu?avr3=mmcu?at43usb320 mmcu?avr3=mmcu?at43usb355 \
|
||||
mmcu?avr3=mmcu?at76c711 \
|
||||
mmcu?avr4=mmcu?atmega8515 mmcu?avr4=mmcu?atmega8535 \
|
||||
- mmcu?avr4=mmcu?atmega8 \
|
||||
+ mmcu?avr4=mmcu?atmega8 mmcu?avr4=mmcu?atmega48 \
|
||||
+ mmcu?avr4=mmcu?atmega88 \
|
||||
+ mmcu?avr4=mmcu?at90pwm2 mmcu?avr4=mmcu?at90pwm3 \
|
||||
mmcu?avr5=mmcu?atmega161 mmcu?avr5=mmcu?atmega162 \
|
||||
- mmcu?avr5=mmcu?atmega163 mmcu?avr5=mmcu?atmega169 \
|
||||
+ mmcu?avr5=mmcu?atmega163 mmcu?avr5=mmcu?atmega164 \
|
||||
+ mmcu?avr5=mmcu?atmega168 mmcu?avr5=mmcu?atmega169 \
|
||||
mmcu?avr5=mmcu?atmega16 \
|
||||
- mmcu?avr5=mmcu?atmega323 mmcu?avr5=mmcu?atmega32 \
|
||||
- mmcu?avr5=mmcu?atmega64 mmcu?avr5=mmcu?atmega128 \
|
||||
- mmcu?avr5=mmcu?at94k
|
||||
+ mmcu?avr5=mmcu?atmega323 mmcu?avr5=mmcu?atmega324 \
|
||||
+ mmcu?avr5=mmcu?atmega325 mmcu?avr5=mmcu?atmega3250 \
|
||||
+ mmcu?avr5=mmcu?atmega329 mmcu?avr5=mmcu?atmega3290 \
|
||||
+ mmcu?avr5=mmcu?atmega32 \
|
||||
+ mmcu?avr5=mmcu?atmega644 mmcu?avr5=mmcu?atmega645 \
|
||||
+ mmcu?avr5=mmcu?atmega6450 mmcu?avr5=mmcu?atmega649 \
|
||||
+ mmcu?avr5=mmcu?atmega6490 mmcu?avr5=mmcu?atmega64 \
|
||||
+ mmcu?avr5=mmcu?atmega128 \
|
||||
+ mmcu?avr5=mmcu?at94k mmcu?avr5=mmcu?at90can128
|
||||
|
||||
MULTILIB_EXCEPTIONS =
|
||||
|
|
@ -9,5 +9,16 @@ use without a libstdc++, and it is little tested.
|
|||
Supported debugging formats: -gstabs [default] and -gdwarf-2
|
||||
Locally hack added: recognizes 0bXXX binary constants
|
||||
|
||||
Locally added support for the following AVR devices:
|
||||
|
||||
ATtiny13/ATtiny2313
|
||||
ATtiny25/ATtiny45/ATtiny85
|
||||
ATmega48/ATmega88/ATmega168
|
||||
AT90PWM2/AT90PWM3
|
||||
ATmega164/ATmega324/ATmega644
|
||||
ATmega325/ATmega3250/ATmega645/ATmega6450
|
||||
ATmega329/ATmega3290/ATmega649/ATmega6490
|
||||
AT90CAN128
|
||||
|
||||
WWW: http://gcc.gnu.org/
|
||||
WWW: http://www.nongnu.org/avr-libc/
|
||||
|
|
|
@ -5,58 +5,58 @@ bin/avr-c++
|
|||
bin/avr-cpp
|
||||
bin/avr-g++
|
||||
bin/avr-gcc
|
||||
bin/avr-gcc-3.4.3
|
||||
bin/avr-gcc-3.4.4
|
||||
bin/avr-gccbug
|
||||
lib/gcc/avr/3.4.3/avr3/libgcc.a
|
||||
lib/gcc/avr/3.4.3/avr3/libgcov.a
|
||||
lib/gcc/avr/3.4.3/avr4/libgcc.a
|
||||
lib/gcc/avr/3.4.3/avr4/libgcov.a
|
||||
lib/gcc/avr/3.4.3/avr5/libgcc.a
|
||||
lib/gcc/avr/3.4.3/avr5/libgcov.a
|
||||
lib/gcc/avr/3.4.3/include/README
|
||||
lib/gcc/avr/3.4.3/include/fixed
|
||||
lib/gcc/avr/3.4.3/include/float.h
|
||||
lib/gcc/avr/3.4.3/include/iso646.h
|
||||
lib/gcc/avr/3.4.3/include/limits.h
|
||||
lib/gcc/avr/3.4.3/include/stdarg.h
|
||||
lib/gcc/avr/3.4.3/include/stdbool.h
|
||||
lib/gcc/avr/3.4.3/include/stddef.h
|
||||
lib/gcc/avr/3.4.3/include/syslimits.h
|
||||
lib/gcc/avr/3.4.3/include/unwind.h
|
||||
lib/gcc/avr/3.4.3/include/varargs.h
|
||||
lib/gcc/avr/3.4.3/install-tools/gsyslimits.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/README
|
||||
lib/gcc/avr/3.4.3/install-tools/include/float.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/iso646.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/limits.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/stdarg.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/stdbool.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/stddef.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/unwind.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/varargs.h
|
||||
lib/gcc/avr/3.4.3/install-tools/mkheaders.conf
|
||||
lib/gcc/avr/3.4.3/libgcc.a
|
||||
lib/gcc/avr/3.4.3/libgcov.a
|
||||
lib/gcc/avr/3.4.3/specs
|
||||
libexec/gcc/avr/3.4.3/cc1
|
||||
libexec/gcc/avr/3.4.3/cc1plus
|
||||
libexec/gcc/avr/3.4.3/collect2
|
||||
libexec/gcc/avr/3.4.3/install-tools/fix-header
|
||||
libexec/gcc/avr/3.4.3/install-tools/fixinc.sh
|
||||
libexec/gcc/avr/3.4.3/install-tools/fixincl
|
||||
libexec/gcc/avr/3.4.3/install-tools/fixproto
|
||||
libexec/gcc/avr/3.4.3/install-tools/mkheaders
|
||||
libexec/gcc/avr/3.4.3/install-tools/mkinstalldirs
|
||||
@dirrm lib/gcc/avr/3.4.3/avr3
|
||||
@dirrm lib/gcc/avr/3.4.3/avr4
|
||||
@dirrm lib/gcc/avr/3.4.3/avr5
|
||||
@dirrm lib/gcc/avr/3.4.3/include
|
||||
@dirrm lib/gcc/avr/3.4.3/install-tools/include
|
||||
@dirrm lib/gcc/avr/3.4.3/install-tools
|
||||
@dirrm lib/gcc/avr/3.4.3
|
||||
lib/gcc/avr/3.4.4/avr3/libgcc.a
|
||||
lib/gcc/avr/3.4.4/avr3/libgcov.a
|
||||
lib/gcc/avr/3.4.4/avr4/libgcc.a
|
||||
lib/gcc/avr/3.4.4/avr4/libgcov.a
|
||||
lib/gcc/avr/3.4.4/avr5/libgcc.a
|
||||
lib/gcc/avr/3.4.4/avr5/libgcov.a
|
||||
lib/gcc/avr/3.4.4/include/README
|
||||
lib/gcc/avr/3.4.4/include/fixed
|
||||
lib/gcc/avr/3.4.4/include/float.h
|
||||
lib/gcc/avr/3.4.4/include/iso646.h
|
||||
lib/gcc/avr/3.4.4/include/limits.h
|
||||
lib/gcc/avr/3.4.4/include/stdarg.h
|
||||
lib/gcc/avr/3.4.4/include/stdbool.h
|
||||
lib/gcc/avr/3.4.4/include/stddef.h
|
||||
lib/gcc/avr/3.4.4/include/syslimits.h
|
||||
lib/gcc/avr/3.4.4/include/unwind.h
|
||||
lib/gcc/avr/3.4.4/include/varargs.h
|
||||
lib/gcc/avr/3.4.4/install-tools/gsyslimits.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/README
|
||||
lib/gcc/avr/3.4.4/install-tools/include/float.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/iso646.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/limits.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/stdarg.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/stdbool.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/stddef.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/unwind.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/varargs.h
|
||||
lib/gcc/avr/3.4.4/install-tools/mkheaders.conf
|
||||
lib/gcc/avr/3.4.4/libgcc.a
|
||||
lib/gcc/avr/3.4.4/libgcov.a
|
||||
lib/gcc/avr/3.4.4/specs
|
||||
libexec/gcc/avr/3.4.4/cc1
|
||||
libexec/gcc/avr/3.4.4/cc1plus
|
||||
libexec/gcc/avr/3.4.4/collect2
|
||||
libexec/gcc/avr/3.4.4/install-tools/fix-header
|
||||
libexec/gcc/avr/3.4.4/install-tools/fixinc.sh
|
||||
libexec/gcc/avr/3.4.4/install-tools/fixincl
|
||||
libexec/gcc/avr/3.4.4/install-tools/fixproto
|
||||
libexec/gcc/avr/3.4.4/install-tools/mkheaders
|
||||
libexec/gcc/avr/3.4.4/install-tools/mkinstalldirs
|
||||
@dirrm lib/gcc/avr/3.4.4/avr3
|
||||
@dirrm lib/gcc/avr/3.4.4/avr4
|
||||
@dirrm lib/gcc/avr/3.4.4/avr5
|
||||
@dirrm lib/gcc/avr/3.4.4/include
|
||||
@dirrm lib/gcc/avr/3.4.4/install-tools/include
|
||||
@dirrm lib/gcc/avr/3.4.4/install-tools
|
||||
@dirrm lib/gcc/avr/3.4.4
|
||||
@dirrm lib/gcc/avr
|
||||
@dirrm lib/gcc
|
||||
@dirrm libexec/gcc/avr/3.4.3/install-tools
|
||||
@dirrm libexec/gcc/avr/3.4.3
|
||||
@dirrm libexec/gcc/avr/3.4.4/install-tools
|
||||
@dirrm libexec/gcc/avr/3.4.4
|
||||
@dirrm libexec/gcc/avr
|
||||
@dirrm libexec/gcc
|
||||
|
|
|
@ -6,8 +6,7 @@
|
|||
#
|
||||
|
||||
PORTNAME= gcc
|
||||
PORTVERSION= 3.4.3
|
||||
PORTREVISION= 1
|
||||
PORTVERSION= 3.4.4
|
||||
CATEGORIES= devel
|
||||
MASTER_SITES= ${MASTER_SITE_GCC}
|
||||
MASTER_SITES+= http://people.freebsd.org/~joerg/:local
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
MD5 (gcc-core-3.4.3.tar.bz2) = d2cbfe8fc3205c1d7969b26377405778
|
||||
SIZE (gcc-core-3.4.3.tar.bz2) = 13040222
|
||||
MD5 (gcc-g++-3.4.3.tar.bz2) = 26cb84db92feb8e03bb7bf3bc264844f
|
||||
SIZE (gcc-g++-3.4.3.tar.bz2) = 2475405
|
||||
MD5 (gcc-core-3.4.4.tar.bz2) = 9dd911fd9bc136ca42b73c68735d853b
|
||||
SIZE (gcc-core-3.4.4.tar.bz2) = 13153342
|
||||
MD5 (gcc-g++-3.4.4.tar.bz2) = a828b7024f07cebc3bc1e55dbfd4706a
|
||||
SIZE (gcc-g++-3.4.4.tar.bz2) = 2474402
|
||||
|
|
|
@ -1,215 +0,0 @@
|
|||
===================================================================
|
||||
RCS file: /cvsroot/gcc/cvsroot/gcc/gcc/gcc/config/avr/avr.c,v
|
||||
retrieving revision 1.129
|
||||
retrieving revision 1.130
|
||||
diff -u -r1.129 -r1.130
|
||||
--- gcc/config/avr/avr.c 2005/02/09 14:43:28 1.129
|
||||
+++ gcc/config/avr/avr.c 2005/03/06 21:50:34 1.130
|
||||
@@ -1120,6 +1120,16 @@
|
||||
|
||||
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));
|
||||
@@ -1835,6 +1845,9 @@
|
||||
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)
|
||||
@@ -1928,6 +1941,25 @@
|
||||
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));
|
||||
@@ -2508,7 +2540,11 @@
|
||||
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))
|
||||
@@ -2528,33 +2564,33 @@
|
||||
{
|
||||
if (reg_src == REG_X)
|
||||
{
|
||||
- /* "st X+,r26" is undefined */
|
||||
- if (reg_unused_after (insn, src))
|
||||
+ /* "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 (st,X,r26) CR_TAB
|
||||
AS2 (adiw,r26,1) CR_TAB
|
||||
AS2 (st,X,__tmp_reg__) CR_TAB
|
||||
- AS2 (sbiw,r26,1));
|
||||
+ AS2 (sbiw,r26,1) CR_TAB
|
||||
+ AS2 (st,X,r26));
|
||||
}
|
||||
else
|
||||
{
|
||||
- if (reg_unused_after (insn, base))
|
||||
+ 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 (st ,X+,%A1) CR_TAB
|
||||
- AS2 (st ,X,%B1) CR_TAB
|
||||
- AS2 (sbiw,r26,1));
|
||||
+ return *l=3, (AS2 (adiw,r26,1) CR_TAB
|
||||
+ AS2 (st,X,%B1) CR_TAB
|
||||
+ AS2 (st,-X,%A1));
|
||||
}
|
||||
}
|
||||
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)
|
||||
{
|
||||
@@ -2567,14 +2603,14 @@
|
||||
|
||||
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 (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 (st,Y,%A1) 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)));
|
||||
}
|
||||
@@ -2582,31 +2618,53 @@
|
||||
{
|
||||
/* (X + d) = R */
|
||||
if (reg_src == REG_X)
|
||||
- {
|
||||
+ {
|
||||
*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 (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+1));
|
||||
+ AS2 (sbiw,r26,%o0));
|
||||
}
|
||||
*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 (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,%A0,%A1) CR_TAB
|
||||
- AS2 (std,%B0,%B1));
|
||||
+ 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++) */
|
||||
- return *l=2, (AS2 (st,%0,%A1) CR_TAB
|
||||
- AS2 (st,%0,%B1));
|
||||
+ {
|
||||
+ 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 "";
|
||||
}
|
||||
===================================================================
|
||||
RCS file: /cvsroot/gcc/cvsroot/gcc/gcc/gcc/config/avr/avr.md,v
|
||||
retrieving revision 1.49
|
||||
retrieving revision 1.50
|
||||
diff -u -r1.49 -r1.50
|
||||
--- gcc/config/avr/avr.md 2005/01/27 18:22:25 1.49
|
||||
+++ gcc/config/avr/avr.md 2005/03/06 21:50:36 1.50
|
||||
@@ -30,6 +30,8 @@
|
||||
;; j Branch condition.
|
||||
;; k Reverse branch condition.
|
||||
;; o Displacement for (mem (plus (reg) (const_int))) operands.
|
||||
+;; p POST_INC or PRE_DEC address as a pointer (X, Y, Z)
|
||||
+;; r POST_INC or PRE_DEC address as a register (r26, r28, r30)
|
||||
;; ~ Output 'r' if not AVR_MEGA.
|
||||
|
||||
;; UNSPEC usage:
|
|
@ -1,124 +0,0 @@
|
|||
--- gcc/config/avr/avr.c.orig 2004-09-27 19:13:55.000000000 -0600
|
||||
+++ gcc/config/avr/avr.c 2005-02-01 14:58:40.465250000 -0700
|
||||
@@ -175,6 +175,9 @@
|
||||
{ "at90c8534", 2, "__AVR_AT90C8534__" },
|
||||
{ "at90s8535", 2, "__AVR_AT90S8535__" },
|
||||
{ "at86rf401", 2, "__AVR_AT86RF401__" },
|
||||
+ /* Classic + MOVW, <= 8K. */
|
||||
+ { "attiny13", 2, "__AVR_ATtiny13__" },
|
||||
+ { "attiny2313", 2, "__AVR_ATtiny2313__" },
|
||||
/* Classic, > 8K. */
|
||||
{ "avr3", 3, NULL },
|
||||
{ "atmega103", 3, "__AVR_ATmega103__" },
|
||||
@@ -185,6 +188,8 @@
|
||||
/* Enhanced, <= 8K. */
|
||||
{ "avr4", 4, NULL },
|
||||
{ "atmega8", 4, "__AVR_ATmega8__" },
|
||||
+ { "atmega48", 4, "__AVR_ATmega48__" },
|
||||
+ { "atmega88", 4, "__AVR_ATmega88__" },
|
||||
{ "atmega8515", 4, "__AVR_ATmega8515__" },
|
||||
{ "atmega8535", 4, "__AVR_ATmega8535__" },
|
||||
/* Enhanced, > 8K. */
|
||||
@@ -193,11 +198,13 @@
|
||||
{ "atmega161", 5, "__AVR_ATmega161__" },
|
||||
{ "atmega162", 5, "__AVR_ATmega162__" },
|
||||
{ "atmega163", 5, "__AVR_ATmega163__" },
|
||||
+ { "atmega168", 5, "__AVR_ATmega168__" },
|
||||
{ "atmega169", 5, "__AVR_ATmega169__" },
|
||||
{ "atmega32", 5, "__AVR_ATmega32__" },
|
||||
{ "atmega323", 5, "__AVR_ATmega323__" },
|
||||
{ "atmega64", 5, "__AVR_ATmega64__" },
|
||||
{ "atmega128", 5, "__AVR_ATmega128__" },
|
||||
+ { "at90can128", 5, "__AVR_AT90CAN128__" },
|
||||
{ "at94k", 5, "__AVR_AT94K__" },
|
||||
/* Assembler only. */
|
||||
{ "avr1", 1, NULL },
|
||||
|
||||
--- gcc/config/avr/avr.h.orig 2004-03-08 19:59:55.000000000 -0700
|
||||
+++ gcc/config/avr/avr.h 2005-02-01 14:58:40.480875000 -0700
|
||||
@@ -2351,12 +2351,12 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LINK_SPEC " %{!mmcu*:-m avr2}\
|
||||
-%{mmcu=at90s1200|mmcu=attiny1*|mmcu=attiny28:-m avr1} \
|
||||
-%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401:-m avr2}\
|
||||
+%{mmcu=at90s1200|mmcu=attiny11|mmcu=attiny12|mmcu=attiny15|mmcu=attiny28:-m avr1} \
|
||||
+%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401|mmcu=attiny13|mmcu=attiny2313:-m avr2}\
|
||||
%{mmcu=atmega103|mmcu=atmega603|mmcu=at43*|mmcu=at76*:-m avr3}\
|
||||
-%{mmcu=atmega8*:-m avr4}\
|
||||
-%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64|mmcu=atmega128|mmcu=at94k:-m avr5}\
|
||||
-%{mmcu=atmega64|mmcu=atmega128|mmcu=atmega162|mmcu=atmega169: -Tdata 0x800100} "
|
||||
+%{mmcu=atmega8*|mmcu=atmega48:-m avr4}\
|
||||
+%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64|mmcu=atmega128|mmcu=at90can128|mmcu=at94k:-m avr5}\
|
||||
+%{mmcu=atmega48|mmcu=atmega88|mmcu=atmega64|mmcu=atmega128|mmcu=at90can128|mmcu=at90can128|mmcu=atmega162|mmcu=atmega168|mmcu=atmega169: -Tdata 0x800100} "
|
||||
|
||||
/* A C string constant that tells the GCC driver program options to
|
||||
pass to the linker. It can also specify how to translate options
|
||||
@@ -2365,7 +2365,7 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LIB_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lc }}}}}"
|
||||
/* Another C string constant used much like `LINK_SPEC'. The
|
||||
difference between the two is that `LIB_SPEC' is used at the end
|
||||
of the command given to the linker.
|
||||
@@ -2377,7 +2377,7 @@
|
||||
/* No libstdc++ for now. Empty string doesn't work. */
|
||||
|
||||
#define LIBGCC_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lgcc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lgcc }}}}}"
|
||||
/* Another C string constant that tells the GCC driver program how
|
||||
and when to place a reference to `libgcc.a' into the linker
|
||||
command line. This constant is placed both before and after the
|
||||
@@ -2421,23 +2421,29 @@
|
||||
%{mmcu=at90c8534:crtc8534.o%s} \
|
||||
%{mmcu=at90s8535:crts8535.o%s} \
|
||||
%{mmcu=at86rf401:crt86401.o%s} \
|
||||
+%{mmcu=attiny13:crttn13.o%s} \
|
||||
+%{mmcu=attiny2313:crttn2313.o%s} \
|
||||
%{mmcu=atmega103|mmcu=avr3:crtm103.o%s} \
|
||||
%{mmcu=atmega603:crtm603.o%s} \
|
||||
%{mmcu=at43usb320:crt43320.o%s} \
|
||||
%{mmcu=at43usb355:crt43355.o%s} \
|
||||
%{mmcu=at76c711:crt76711.o%s} \
|
||||
%{mmcu=atmega8|mmcu=avr4:crtm8.o%s} \
|
||||
+%{mmcu=atmega48:crtm48.o%s} \
|
||||
+%{mmcu=atmega88:crtm88.o%s} \
|
||||
%{mmcu=atmega8515:crtm8515.o%s} \
|
||||
%{mmcu=atmega8535:crtm8535.o%s} \
|
||||
%{mmcu=atmega16:crtm16.o%s} \
|
||||
%{mmcu=atmega161|mmcu=avr5:crtm161.o%s} \
|
||||
%{mmcu=atmega162:crtm162.o%s} \
|
||||
%{mmcu=atmega163:crtm163.o%s} \
|
||||
+%{mmcu=atmega168:crtm168.o%s} \
|
||||
%{mmcu=atmega169:crtm169.o%s} \
|
||||
%{mmcu=atmega32:crtm32.o%s} \
|
||||
%{mmcu=atmega323:crtm323.o%s} \
|
||||
%{mmcu=atmega64:crtm64.o%s} \
|
||||
%{mmcu=atmega128:crtm128.o%s} \
|
||||
+%{mmcu=at90can128:crtcan128.o%s} \
|
||||
%{mmcu=at94k:crtat94k.o%s}"
|
||||
|
||||
#define EXTRA_SPECS {"crt_binutils", CRT_BINUTILS_SPECS},
|
||||
--- gcc/config/avr/t-avr.orig 2003-02-27 14:45:33.000000000 -0700
|
||||
+++ gcc/config/avr/t-avr 2005-02-01 14:58:40.480875000 -0700
|
||||
@@ -50,13 +50,14 @@
|
||||
mmcu?avr3=mmcu?at43usb320 mmcu?avr3=mmcu?at43usb355 \
|
||||
mmcu?avr3=mmcu?at76c711 \
|
||||
mmcu?avr4=mmcu?atmega8515 mmcu?avr4=mmcu?atmega8535 \
|
||||
- mmcu?avr4=mmcu?atmega8 \
|
||||
+ mmcu?avr4=mmcu?atmega8 mmcu?avr4=mmcu?atmega48 \
|
||||
+ mmcu?avr4=mmcu?atmega88 \
|
||||
mmcu?avr5=mmcu?atmega161 mmcu?avr5=mmcu?atmega162 \
|
||||
mmcu?avr5=mmcu?atmega163 mmcu?avr5=mmcu?atmega169 \
|
||||
- mmcu?avr5=mmcu?atmega16 \
|
||||
+ mmcu?avr5=mmcu?atmega16 mmcu?avr5=mmcu?atmega168 \
|
||||
mmcu?avr5=mmcu?atmega323 mmcu?avr5=mmcu?atmega32 \
|
||||
mmcu?avr5=mmcu?atmega64 mmcu?avr5=mmcu?atmega128 \
|
||||
- mmcu?avr5=mmcu?at94k
|
||||
+ mmcu?avr5=mmcu?at94k mmcu?avr5=mmcu?at90can128
|
||||
|
||||
MULTILIB_EXCEPTIONS =
|
||||
|
|
@ -1,58 +0,0 @@
|
|||
2005-03-04 Eric B. Weddington <ericw@evcohs.com>
|
||||
|
||||
* gcc/config/avr/avr.c (avr_mcu_types): Add entries for atmega325,
|
||||
atmega3250, atmega645, atmega6450.
|
||||
* gcc/config/avr/avr.h (LINK_SPEC): Ditto.
|
||||
(CRT_BINUTILS_SPECS): Ditto.
|
||||
* gcc/config/avr/t-avr (MULTILIB_MATCHES): Ditto.
|
||||
|
||||
--- gcc/config/avr/avr.c.old 2005-02-10 17:36:47.921875000 -0700
|
||||
+++ gcc/config/avr/avr.c 2005-03-04 09:35:26.633875000 -0700
|
||||
@@ -202,7 +202,11 @@
|
||||
{ "atmega169", 5, "__AVR_ATmega169__" },
|
||||
{ "atmega32", 5, "__AVR_ATmega32__" },
|
||||
{ "atmega323", 5, "__AVR_ATmega323__" },
|
||||
+ { "atmega325", 5, "__AVR_ATmega325__" },
|
||||
+ { "atmega3250", 5, "__AVR_ATmega3250__" },
|
||||
{ "atmega64", 5, "__AVR_ATmega64__" },
|
||||
+ { "atmega645", 5, "__AVR_ATmega645__" },
|
||||
+ { "atmega6450", 5, "__AVR_ATmega6450__" },
|
||||
{ "atmega128", 5, "__AVR_ATmega128__" },
|
||||
{ "at90can128", 5, "__AVR_AT90CAN128__" },
|
||||
{ "at94k", 5, "__AVR_AT94K__" },
|
||||
--- gcc/config/avr/avr.h.old 2005-02-10 17:36:48.015625000 -0700
|
||||
+++ gcc/config/avr/avr.h 2005-03-04 09:44:23.118250000 -0700
|
||||
@@ -2355,8 +2355,8 @@
|
||||
%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401|mmcu=attiny13|mmcu=attiny2313:-m avr2}\
|
||||
%{mmcu=atmega103|mmcu=atmega603|mmcu=at43*|mmcu=at76*:-m avr3}\
|
||||
%{mmcu=atmega8*|mmcu=atmega48:-m avr4}\
|
||||
-%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64|mmcu=atmega128|mmcu=at90can128|mmcu=at94k:-m avr5}\
|
||||
-%{mmcu=atmega48|mmcu=atmega88|mmcu=atmega64|mmcu=atmega128|mmcu=at90can128|mmcu=at90can128|mmcu=atmega162|mmcu=atmega168|mmcu=atmega169: -Tdata 0x800100} "
|
||||
+%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64*|mmcu=atmega128|mmcu=at90can128|mmcu=at94k:-m avr5}\
|
||||
+%{mmcu=atmega325|mmcu=atmega3250|mmcu=atmega48|mmcu=atmega88|mmcu=atmega64|mmcu=atmega645|mmcu=atmega6450|mmcu=atmega128|mmcu=at90can128|mmcu=at90can128|mmcu=atmega162|mmcu=atmega168|mmcu=atmega169: -Tdata 0x800100} "
|
||||
|
||||
/* A C string constant that tells the GCC driver program options to
|
||||
pass to the linker. It can also specify how to translate options
|
||||
@@ -2441,7 +2441,11 @@
|
||||
%{mmcu=atmega169:crtm169.o%s} \
|
||||
%{mmcu=atmega32:crtm32.o%s} \
|
||||
%{mmcu=atmega323:crtm323.o%s} \
|
||||
+%{mmcu=atmega325:crtm325.o%s} \
|
||||
+%{mmcu=atmega3250:crtm3250.o%s} \
|
||||
%{mmcu=atmega64:crtm64.o%s} \
|
||||
+%{mmcu=atmega645:crtm645.o%s} \
|
||||
+%{mmcu=atmega6450:crtm6450.o%s} \
|
||||
%{mmcu=atmega128:crtm128.o%s} \
|
||||
%{mmcu=at90can128:crtcan128.o%s} \
|
||||
%{mmcu=at94k:crtat94k.o%s}"
|
||||
--- gcc/config/avr/t-avr.old 2005-02-10 17:36:48.031250000 -0700
|
||||
+++ gcc/config/avr/t-avr 2005-03-04 09:56:43.790125000 -0700
|
||||
@@ -56,6 +56,8 @@
|
||||
mmcu?avr5=mmcu?atmega163 mmcu?avr5=mmcu?atmega169 \
|
||||
mmcu?avr5=mmcu?atmega16 mmcu?avr5=mmcu?atmega168 \
|
||||
mmcu?avr5=mmcu?atmega323 mmcu?avr5=mmcu?atmega32 \
|
||||
+ mmcu?avr5=mmcu?atmega325 mmcu?avr5=mmcu?atmega3250 \
|
||||
+ mmcu?avr5=mmcu?atmega645 mmcu?avr5=mmcu?atmega6450 \
|
||||
mmcu?avr5=mmcu?atmega64 mmcu?avr5=mmcu?atmega128 \
|
||||
mmcu?avr5=mmcu?at94k mmcu?avr5=mmcu?at90can128
|
||||
|
253
devel/avr-gcc/files/patch-newdevices
Normal file
253
devel/avr-gcc/files/patch-newdevices
Normal file
|
@ -0,0 +1,253 @@
|
|||
diff -ur /tmp/gcc-orig/gcc/config/avr/avr.c ./gcc/config/avr/avr.c
|
||||
--- /tmp/gcc-orig/gcc/config/avr/avr.c Sun Mar 20 22:14:28 2005
|
||||
+++ ./gcc/config/avr/avr.c Sat Jul 30 23:01:43 2005
|
||||
@@ -175,6 +175,12 @@
|
||||
{ "at90c8534", 2, "__AVR_AT90C8534__" },
|
||||
{ "at90s8535", 2, "__AVR_AT90S8535__" },
|
||||
{ "at86rf401", 2, "__AVR_AT86RF401__" },
|
||||
+ /* Classic + MOVW, <= 8K. */
|
||||
+ { "attiny13", 2, "__AVR_ATtiny13__" },
|
||||
+ { "attiny2313", 2, "__AVR_ATtiny2313__" },
|
||||
+ { "attiny25", 2, "__AVR_ATtiny25__" },
|
||||
+ { "attiny45", 2, "__AVR_ATtiny45__" },
|
||||
+ { "attiny85", 2, "__AVR_ATtiny85__" },
|
||||
/* Classic, > 8K. */
|
||||
{ "avr3", 3, NULL },
|
||||
{ "atmega103", 3, "__AVR_ATmega103__" },
|
||||
@@ -185,19 +191,36 @@
|
||||
/* Enhanced, <= 8K. */
|
||||
{ "avr4", 4, NULL },
|
||||
{ "atmega8", 4, "__AVR_ATmega8__" },
|
||||
+ { "atmega48", 4, "__AVR_ATmega48__" },
|
||||
+ { "atmega88", 4, "__AVR_ATmega88__" },
|
||||
{ "atmega8515", 4, "__AVR_ATmega8515__" },
|
||||
{ "atmega8535", 4, "__AVR_ATmega8535__" },
|
||||
+ { "at90pwm2", 4, "__AVR_AT90PWM2__" },
|
||||
+ { "at90pwm3", 4, "__AVR_AT90PWM3__" },
|
||||
/* Enhanced, > 8K. */
|
||||
{ "avr5", 5, NULL },
|
||||
{ "atmega16", 5, "__AVR_ATmega16__" },
|
||||
{ "atmega161", 5, "__AVR_ATmega161__" },
|
||||
{ "atmega162", 5, "__AVR_ATmega162__" },
|
||||
{ "atmega163", 5, "__AVR_ATmega163__" },
|
||||
+ { "atmega164", 5, "__AVR_ATmega164__" },
|
||||
+ { "atmega168", 5, "__AVR_ATmega168__" },
|
||||
{ "atmega169", 5, "__AVR_ATmega169__" },
|
||||
{ "atmega32", 5, "__AVR_ATmega32__" },
|
||||
{ "atmega323", 5, "__AVR_ATmega323__" },
|
||||
+ { "atmega324", 5, "__AVR_ATmega324__" },
|
||||
+ { "atmega325", 5, "__AVR_ATmega325__" },
|
||||
+ { "atmega3250", 5, "__AVR_ATmega3250__" },
|
||||
+ { "atmega329", 5, "__AVR_ATmega329__" },
|
||||
+ { "atmega3290", 5, "__AVR_ATmega3290__" },
|
||||
{ "atmega64", 5, "__AVR_ATmega64__" },
|
||||
+ { "atmega644", 5, "__AVR_ATmega644__" },
|
||||
+ { "atmega645", 5, "__AVR_ATmega645__" },
|
||||
+ { "atmega6450", 5, "__AVR_ATmega6450__" },
|
||||
+ { "atmega649", 5, "__AVR_ATmega649__" },
|
||||
+ { "atmega6490", 5, "__AVR_ATmega6490__" },
|
||||
{ "atmega128", 5, "__AVR_ATmega128__" },
|
||||
+ { "at90can128", 5, "__AVR_AT90CAN128__" },
|
||||
{ "at94k", 5, "__AVR_AT94K__" },
|
||||
/* Assembler only. */
|
||||
{ "avr1", 1, NULL },
|
||||
diff -ur /tmp/gcc-orig/gcc/config/avr/avr.h ./gcc/config/avr/avr.h
|
||||
--- /tmp/gcc-orig/gcc/config/avr/avr.h Sat Jul 30 15:01:51 2005
|
||||
+++ ./gcc/config/avr/avr.h Sat Jul 30 23:03:48 2005
|
||||
@@ -2351,12 +2351,12 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LINK_SPEC " %{!mmcu*:-m avr2}\
|
||||
-%{mmcu=at90s1200|mmcu=attiny1*|mmcu=attiny28:-m avr1} \
|
||||
-%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401:-m avr2}\
|
||||
+%{mmcu=at90s1200|mmcu=attiny11|mmcu=attiny12|mmcu=attiny15|mmcu=attiny28:-m avr1} \
|
||||
+%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401|mmcu=attiny13|mmcu=attiny2313|mmcu=attiny25|mmcu=attiny45|mmcu=attiny85:-m avr2}\
|
||||
%{mmcu=atmega103|mmcu=atmega603|mmcu=at43*|mmcu=at76*:-m avr3}\
|
||||
-%{mmcu=atmega8*:-m avr4}\
|
||||
-%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64|mmcu=atmega128|mmcu=at94k:-m avr5}\
|
||||
-%{mmcu=atmega64|mmcu=atmega128|mmcu=atmega162|mmcu=atmega169: -Tdata 0x800100} "
|
||||
+%{mmcu=atmega8*|mmcu=atmega48|mmcu=at90pwm*:-m avr4}\
|
||||
+%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64*|mmcu=atmega128|mmcu=at90can128|mmcu=at94k:-m avr5}\
|
||||
+%{mmcu=atmega324|mmcu=atmega325|mmcu=atmega3250|mmcu=atmega329|mmcu=atmega3290|mmcu=atmega48|mmcu=atmega88|mmcu=atmega64|mmcu=atmega644|mmcu=atmega645|mmcu=atmega6450|mmcu=atmega649|mmcu=atmega6490|mmcu=atmega128|mmcu=at90can128|mmcu=atmega162|mmcu=atmega164|mmcu=atmega168|mmcu=atmega169: -Tdata 0x800100} "
|
||||
|
||||
/* A C string constant that tells the GCC driver program options to
|
||||
pass to the linker. It can also specify how to translate options
|
||||
@@ -2365,7 +2365,7 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LIB_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lc }}}}}"
|
||||
/* Another C string constant used much like `LINK_SPEC'. The
|
||||
difference between the two is that `LIB_SPEC' is used at the end
|
||||
of the command given to the linker.
|
||||
@@ -2377,7 +2377,7 @@
|
||||
/* No libstdc++ for now. Empty string doesn't work. */
|
||||
|
||||
#define LIBGCC_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lgcc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lgcc }}}}}"
|
||||
/* Another C string constant that tells the GCC driver program how
|
||||
and when to place a reference to `libgcc.a' into the linker
|
||||
command line. This constant is placed both before and after the
|
||||
@@ -2421,23 +2421,45 @@
|
||||
%{mmcu=at90c8534:crtc8534.o%s} \
|
||||
%{mmcu=at90s8535:crts8535.o%s} \
|
||||
%{mmcu=at86rf401:crt86401.o%s} \
|
||||
+%{mmcu=attiny13:crttn13.o%s} \
|
||||
+%{mmcu=attiny2313:crttn2313.o%s} \
|
||||
+%{mmcu=attiny25:crttn25.o%s} \
|
||||
+%{mmcu=attiny45:crttn45.o%s} \
|
||||
+%{mmcu=attiny85:crttn85.o%s} \
|
||||
%{mmcu=atmega103|mmcu=avr3:crtm103.o%s} \
|
||||
%{mmcu=atmega603:crtm603.o%s} \
|
||||
%{mmcu=at43usb320:crt43320.o%s} \
|
||||
%{mmcu=at43usb355:crt43355.o%s} \
|
||||
%{mmcu=at76c711:crt76711.o%s} \
|
||||
%{mmcu=atmega8|mmcu=avr4:crtm8.o%s} \
|
||||
+%{mmcu=atmega48:crtm48.o%s} \
|
||||
+%{mmcu=atmega88:crtm88.o%s} \
|
||||
%{mmcu=atmega8515:crtm8515.o%s} \
|
||||
%{mmcu=atmega8535:crtm8535.o%s} \
|
||||
+%{mmcu=at90pwm2:crt90pwm2.o%s} \
|
||||
+%{mmcu=at90pwm3:crt90pwm3.o%s} \
|
||||
%{mmcu=atmega16:crtm16.o%s} \
|
||||
%{mmcu=atmega161|mmcu=avr5:crtm161.o%s} \
|
||||
%{mmcu=atmega162:crtm162.o%s} \
|
||||
%{mmcu=atmega163:crtm163.o%s} \
|
||||
+%{mmcu=atmega164:crtm164.o%s} \
|
||||
+%{mmcu=atmega168:crtm168.o%s} \
|
||||
%{mmcu=atmega169:crtm169.o%s} \
|
||||
%{mmcu=atmega32:crtm32.o%s} \
|
||||
%{mmcu=atmega323:crtm323.o%s} \
|
||||
+%{mmcu=atmega324:crtm324.o%s} \
|
||||
+%{mmcu=atmega325:crtm325.o%s} \
|
||||
+%{mmcu=atmega3250:crtm3250.o%s} \
|
||||
+%{mmcu=atmega329:crtm329.o%s} \
|
||||
+%{mmcu=atmega3290:crtm3290.o%s} \
|
||||
%{mmcu=atmega64:crtm64.o%s} \
|
||||
+%{mmcu=atmega644:crtm644.o%s} \
|
||||
+%{mmcu=atmega645:crtm645.o%s} \
|
||||
+%{mmcu=atmega6450:crtm6450.o%s} \
|
||||
+%{mmcu=atmega649:crtm649.o%s} \
|
||||
+%{mmcu=atmega6490:crtm6490.o%s} \
|
||||
%{mmcu=atmega128:crtm128.o%s} \
|
||||
+%{mmcu=at90can128:crtcan128.o%s} \
|
||||
%{mmcu=at94k:crtat94k.o%s}"
|
||||
|
||||
#define EXTRA_SPECS {"crt_binutils", CRT_BINUTILS_SPECS},
|
||||
diff -ur /tmp/gcc-orig/gcc/config/avr/avr.h.orig ./gcc/config/avr/avr.h.orig
|
||||
--- /tmp/gcc-orig/gcc/config/avr/avr.h.orig Tue Mar 9 03:59:55 2004
|
||||
+++ ./gcc/config/avr/avr.h.orig Sat Jul 30 22:27:40 2005
|
||||
@@ -2351,12 +2351,12 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LINK_SPEC " %{!mmcu*:-m avr2}\
|
||||
-%{mmcu=at90s1200|mmcu=attiny1*|mmcu=attiny28:-m avr1} \
|
||||
-%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401:-m avr2}\
|
||||
+%{mmcu=at90s1200|mmcu=attiny11|mmcu=attiny12|mmcu=attiny15|mmcu=attiny28:-m avr1} \
|
||||
+%{mmcu=attiny22|mmcu=attiny26|mmcu=at90s2*|mmcu=at90s4*|mmcu=at90s8*|mmcu=at90c8*|mmcu=at86rf401|mmcu=attiny13|mmcu=attiny2313|mmcu=attiny25|mmcu=attiny45|mmcu=attiny85:-m avr2}\
|
||||
%{mmcu=atmega103|mmcu=atmega603|mmcu=at43*|mmcu=at76*:-m avr3}\
|
||||
-%{mmcu=atmega8*:-m avr4}\
|
||||
-%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64|mmcu=atmega128|mmcu=at94k:-m avr5}\
|
||||
-%{mmcu=atmega64|mmcu=atmega128|mmcu=atmega162|mmcu=atmega169: -Tdata 0x800100} "
|
||||
+%{mmcu=atmega8*|mmcu=atmega48|mmcu=at90pwm*:-m avr4}\
|
||||
+%{mmcu=atmega16*|mmcu=atmega32*|mmcu=atmega64*|mmcu=atmega128|mmcu=at90can128|mmcu=at94k:-m avr5}\
|
||||
+%{mmcu=atmega325|mmcu=atmega3250|mmcu=atmega48|mmcu=atmega88|mmcu=atmega64|mmcu=atmega645|mmcu=atmega6450|mmcu=atmega128|mmcu=at90can128|mmcu=at90can128|mmcu=atmega162|mmcu=atmega168|mmcu=atmega169: -Tdata 0x800100} "
|
||||
|
||||
/* A C string constant that tells the GCC driver program options to
|
||||
pass to the linker. It can also specify how to translate options
|
||||
@@ -2365,7 +2365,7 @@
|
||||
Do not define this macro if it does not need to do anything. */
|
||||
|
||||
#define LIB_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lc }}}}}"
|
||||
/* Another C string constant used much like `LINK_SPEC'. The
|
||||
difference between the two is that `LIB_SPEC' is used at the end
|
||||
of the command given to the linker.
|
||||
@@ -2377,7 +2377,7 @@
|
||||
/* No libstdc++ for now. Empty string doesn't work. */
|
||||
|
||||
#define LIBGCC_SPEC \
|
||||
- "%{!mmcu=at90s1*:%{!mmcu=attiny1*:%{!mmcu=attiny28: -lgcc }}}"
|
||||
+ "%{!mmcu=at90s1*:%{!mmcu=attiny11:%{!mmcu=attiny12:%{!mmcu=attiny15:%{!mmcu=attiny28: -lgcc }}}}}"
|
||||
/* Another C string constant that tells the GCC driver program how
|
||||
and when to place a reference to `libgcc.a' into the linker
|
||||
command line. This constant is placed both before and after the
|
||||
@@ -2421,23 +2421,38 @@
|
||||
%{mmcu=at90c8534:crtc8534.o%s} \
|
||||
%{mmcu=at90s8535:crts8535.o%s} \
|
||||
%{mmcu=at86rf401:crt86401.o%s} \
|
||||
+%{mmcu=attiny13:crttn13.o%s} \
|
||||
+%{mmcu=attiny2313:crttn2313.o%s} \
|
||||
+%{mmcu=attiny25:crttn25.o%s} \
|
||||
+%{mmcu=attiny45:crttn45.o%s} \
|
||||
+%{mmcu=attiny85:crttn85.o%s} \
|
||||
%{mmcu=atmega103|mmcu=avr3:crtm103.o%s} \
|
||||
%{mmcu=atmega603:crtm603.o%s} \
|
||||
%{mmcu=at43usb320:crt43320.o%s} \
|
||||
%{mmcu=at43usb355:crt43355.o%s} \
|
||||
%{mmcu=at76c711:crt76711.o%s} \
|
||||
%{mmcu=atmega8|mmcu=avr4:crtm8.o%s} \
|
||||
+%{mmcu=atmega48:crtm48.o%s} \
|
||||
+%{mmcu=atmega88:crtm88.o%s} \
|
||||
%{mmcu=atmega8515:crtm8515.o%s} \
|
||||
%{mmcu=atmega8535:crtm8535.o%s} \
|
||||
+%{mmcu=at90pwm2:crt90pwm2.o%s} \
|
||||
+%{mmcu=at90pwm3:crt90pwm3.o%s} \
|
||||
%{mmcu=atmega16:crtm16.o%s} \
|
||||
%{mmcu=atmega161|mmcu=avr5:crtm161.o%s} \
|
||||
%{mmcu=atmega162:crtm162.o%s} \
|
||||
%{mmcu=atmega163:crtm163.o%s} \
|
||||
+%{mmcu=atmega168:crtm168.o%s} \
|
||||
%{mmcu=atmega169:crtm169.o%s} \
|
||||
%{mmcu=atmega32:crtm32.o%s} \
|
||||
%{mmcu=atmega323:crtm323.o%s} \
|
||||
+%{mmcu=atmega325:crtm325.o%s} \
|
||||
+%{mmcu=atmega3250:crtm3250.o%s} \
|
||||
%{mmcu=atmega64:crtm64.o%s} \
|
||||
+%{mmcu=atmega645:crtm645.o%s} \
|
||||
+%{mmcu=atmega6450:crtm6450.o%s} \
|
||||
%{mmcu=atmega128:crtm128.o%s} \
|
||||
+%{mmcu=at90can128:crtcan128.o%s} \
|
||||
%{mmcu=at94k:crtat94k.o%s}"
|
||||
|
||||
#define EXTRA_SPECS {"crt_binutils", CRT_BINUTILS_SPECS},
|
||||
@@ -2479,4 +2494,5 @@
|
||||
/* zero register r1 */
|
||||
#define ZERO_REGNO 1
|
||||
|
||||
+#define DWARF2_DEBUGGING_INFO 1
|
||||
#define PREFERRED_DEBUGGING_TYPE DBX_DEBUG
|
||||
diff -ur /tmp/gcc-orig/gcc/config/avr/t-avr ./gcc/config/avr/t-avr
|
||||
--- /tmp/gcc-orig/gcc/config/avr/t-avr Mon Apr 25 06:17:34 2005
|
||||
+++ ./gcc/config/avr/t-avr Sat Jul 30 23:06:40 2005
|
||||
@@ -46,13 +46,22 @@
|
||||
mmcu?avr3=mmcu?at43usb320 mmcu?avr3=mmcu?at43usb355 \
|
||||
mmcu?avr3=mmcu?at76c711 \
|
||||
mmcu?avr4=mmcu?atmega8515 mmcu?avr4=mmcu?atmega8535 \
|
||||
- mmcu?avr4=mmcu?atmega8 \
|
||||
+ mmcu?avr4=mmcu?atmega8 mmcu?avr4=mmcu?atmega48 \
|
||||
+ mmcu?avr4=mmcu?atmega88 \
|
||||
+ mmcu?avr4=mmcu?at90pwm2 mmcu?avr4=mmcu?at90pwm3 \
|
||||
mmcu?avr5=mmcu?atmega161 mmcu?avr5=mmcu?atmega162 \
|
||||
- mmcu?avr5=mmcu?atmega163 mmcu?avr5=mmcu?atmega169 \
|
||||
+ mmcu?avr5=mmcu?atmega163 mmcu?avr5=mmcu?atmega164 \
|
||||
+ mmcu?avr5=mmcu?atmega168 mmcu?avr5=mmcu?atmega169 \
|
||||
mmcu?avr5=mmcu?atmega16 \
|
||||
- mmcu?avr5=mmcu?atmega323 mmcu?avr5=mmcu?atmega32 \
|
||||
- mmcu?avr5=mmcu?atmega64 mmcu?avr5=mmcu?atmega128 \
|
||||
- mmcu?avr5=mmcu?at94k
|
||||
+ mmcu?avr5=mmcu?atmega323 mmcu?avr5=mmcu?atmega324 \
|
||||
+ mmcu?avr5=mmcu?atmega325 mmcu?avr5=mmcu?atmega3250 \
|
||||
+ mmcu?avr5=mmcu?atmega329 mmcu?avr5=mmcu?atmega3290 \
|
||||
+ mmcu?avr5=mmcu?atmega32 \
|
||||
+ mmcu?avr5=mmcu?atmega644 mmcu?avr5=mmcu?atmega645 \
|
||||
+ mmcu?avr5=mmcu?atmega6450 mmcu?avr5=mmcu?atmega649 \
|
||||
+ mmcu?avr5=mmcu?atmega6490 mmcu?avr5=mmcu?atmega64 \
|
||||
+ mmcu?avr5=mmcu?atmega128 \
|
||||
+ mmcu?avr5=mmcu?at94k mmcu?avr5=mmcu?at90can128
|
||||
|
||||
MULTILIB_EXCEPTIONS =
|
||||
|
|
@ -9,5 +9,16 @@ use without a libstdc++, and it is little tested.
|
|||
Supported debugging formats: -gstabs [default] and -gdwarf-2
|
||||
Locally hack added: recognizes 0bXXX binary constants
|
||||
|
||||
Locally added support for the following AVR devices:
|
||||
|
||||
ATtiny13/ATtiny2313
|
||||
ATtiny25/ATtiny45/ATtiny85
|
||||
ATmega48/ATmega88/ATmega168
|
||||
AT90PWM2/AT90PWM3
|
||||
ATmega164/ATmega324/ATmega644
|
||||
ATmega325/ATmega3250/ATmega645/ATmega6450
|
||||
ATmega329/ATmega3290/ATmega649/ATmega6490
|
||||
AT90CAN128
|
||||
|
||||
WWW: http://gcc.gnu.org/
|
||||
WWW: http://www.nongnu.org/avr-libc/
|
||||
|
|
|
@ -5,58 +5,58 @@ bin/avr-c++
|
|||
bin/avr-cpp
|
||||
bin/avr-g++
|
||||
bin/avr-gcc
|
||||
bin/avr-gcc-3.4.3
|
||||
bin/avr-gcc-3.4.4
|
||||
bin/avr-gccbug
|
||||
lib/gcc/avr/3.4.3/avr3/libgcc.a
|
||||
lib/gcc/avr/3.4.3/avr3/libgcov.a
|
||||
lib/gcc/avr/3.4.3/avr4/libgcc.a
|
||||
lib/gcc/avr/3.4.3/avr4/libgcov.a
|
||||
lib/gcc/avr/3.4.3/avr5/libgcc.a
|
||||
lib/gcc/avr/3.4.3/avr5/libgcov.a
|
||||
lib/gcc/avr/3.4.3/include/README
|
||||
lib/gcc/avr/3.4.3/include/fixed
|
||||
lib/gcc/avr/3.4.3/include/float.h
|
||||
lib/gcc/avr/3.4.3/include/iso646.h
|
||||
lib/gcc/avr/3.4.3/include/limits.h
|
||||
lib/gcc/avr/3.4.3/include/stdarg.h
|
||||
lib/gcc/avr/3.4.3/include/stdbool.h
|
||||
lib/gcc/avr/3.4.3/include/stddef.h
|
||||
lib/gcc/avr/3.4.3/include/syslimits.h
|
||||
lib/gcc/avr/3.4.3/include/unwind.h
|
||||
lib/gcc/avr/3.4.3/include/varargs.h
|
||||
lib/gcc/avr/3.4.3/install-tools/gsyslimits.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/README
|
||||
lib/gcc/avr/3.4.3/install-tools/include/float.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/iso646.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/limits.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/stdarg.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/stdbool.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/stddef.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/unwind.h
|
||||
lib/gcc/avr/3.4.3/install-tools/include/varargs.h
|
||||
lib/gcc/avr/3.4.3/install-tools/mkheaders.conf
|
||||
lib/gcc/avr/3.4.3/libgcc.a
|
||||
lib/gcc/avr/3.4.3/libgcov.a
|
||||
lib/gcc/avr/3.4.3/specs
|
||||
libexec/gcc/avr/3.4.3/cc1
|
||||
libexec/gcc/avr/3.4.3/cc1plus
|
||||
libexec/gcc/avr/3.4.3/collect2
|
||||
libexec/gcc/avr/3.4.3/install-tools/fix-header
|
||||
libexec/gcc/avr/3.4.3/install-tools/fixinc.sh
|
||||
libexec/gcc/avr/3.4.3/install-tools/fixincl
|
||||
libexec/gcc/avr/3.4.3/install-tools/fixproto
|
||||
libexec/gcc/avr/3.4.3/install-tools/mkheaders
|
||||
libexec/gcc/avr/3.4.3/install-tools/mkinstalldirs
|
||||
@dirrm lib/gcc/avr/3.4.3/avr3
|
||||
@dirrm lib/gcc/avr/3.4.3/avr4
|
||||
@dirrm lib/gcc/avr/3.4.3/avr5
|
||||
@dirrm lib/gcc/avr/3.4.3/include
|
||||
@dirrm lib/gcc/avr/3.4.3/install-tools/include
|
||||
@dirrm lib/gcc/avr/3.4.3/install-tools
|
||||
@dirrm lib/gcc/avr/3.4.3
|
||||
lib/gcc/avr/3.4.4/avr3/libgcc.a
|
||||
lib/gcc/avr/3.4.4/avr3/libgcov.a
|
||||
lib/gcc/avr/3.4.4/avr4/libgcc.a
|
||||
lib/gcc/avr/3.4.4/avr4/libgcov.a
|
||||
lib/gcc/avr/3.4.4/avr5/libgcc.a
|
||||
lib/gcc/avr/3.4.4/avr5/libgcov.a
|
||||
lib/gcc/avr/3.4.4/include/README
|
||||
lib/gcc/avr/3.4.4/include/fixed
|
||||
lib/gcc/avr/3.4.4/include/float.h
|
||||
lib/gcc/avr/3.4.4/include/iso646.h
|
||||
lib/gcc/avr/3.4.4/include/limits.h
|
||||
lib/gcc/avr/3.4.4/include/stdarg.h
|
||||
lib/gcc/avr/3.4.4/include/stdbool.h
|
||||
lib/gcc/avr/3.4.4/include/stddef.h
|
||||
lib/gcc/avr/3.4.4/include/syslimits.h
|
||||
lib/gcc/avr/3.4.4/include/unwind.h
|
||||
lib/gcc/avr/3.4.4/include/varargs.h
|
||||
lib/gcc/avr/3.4.4/install-tools/gsyslimits.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/README
|
||||
lib/gcc/avr/3.4.4/install-tools/include/float.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/iso646.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/limits.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/stdarg.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/stdbool.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/stddef.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/unwind.h
|
||||
lib/gcc/avr/3.4.4/install-tools/include/varargs.h
|
||||
lib/gcc/avr/3.4.4/install-tools/mkheaders.conf
|
||||
lib/gcc/avr/3.4.4/libgcc.a
|
||||
lib/gcc/avr/3.4.4/libgcov.a
|
||||
lib/gcc/avr/3.4.4/specs
|
||||
libexec/gcc/avr/3.4.4/cc1
|
||||
libexec/gcc/avr/3.4.4/cc1plus
|
||||
libexec/gcc/avr/3.4.4/collect2
|
||||
libexec/gcc/avr/3.4.4/install-tools/fix-header
|
||||
libexec/gcc/avr/3.4.4/install-tools/fixinc.sh
|
||||
libexec/gcc/avr/3.4.4/install-tools/fixincl
|
||||
libexec/gcc/avr/3.4.4/install-tools/fixproto
|
||||
libexec/gcc/avr/3.4.4/install-tools/mkheaders
|
||||
libexec/gcc/avr/3.4.4/install-tools/mkinstalldirs
|
||||
@dirrm lib/gcc/avr/3.4.4/avr3
|
||||
@dirrm lib/gcc/avr/3.4.4/avr4
|
||||
@dirrm lib/gcc/avr/3.4.4/avr5
|
||||
@dirrm lib/gcc/avr/3.4.4/include
|
||||
@dirrm lib/gcc/avr/3.4.4/install-tools/include
|
||||
@dirrm lib/gcc/avr/3.4.4/install-tools
|
||||
@dirrm lib/gcc/avr/3.4.4
|
||||
@dirrm lib/gcc/avr
|
||||
@dirrm lib/gcc
|
||||
@dirrm libexec/gcc/avr/3.4.3/install-tools
|
||||
@dirrm libexec/gcc/avr/3.4.3
|
||||
@dirrm libexec/gcc/avr/3.4.4/install-tools
|
||||
@dirrm libexec/gcc/avr/3.4.4
|
||||
@dirrm libexec/gcc/avr
|
||||
@dirrm libexec/gcc
|
||||
|
|
Loading…
Reference in a new issue