summaryrefslogtreecommitdiff
path: root/contrib/crossrpms/patches/gcc-g++-4.4.6-rtems4.10-20110829.diff
diff options
context:
space:
mode:
Diffstat (limited to 'contrib/crossrpms/patches/gcc-g++-4.4.6-rtems4.10-20110829.diff')
-rw-r--r--contrib/crossrpms/patches/gcc-g++-4.4.6-rtems4.10-20110829.diff454
1 files changed, 454 insertions, 0 deletions
diff --git a/contrib/crossrpms/patches/gcc-g++-4.4.6-rtems4.10-20110829.diff b/contrib/crossrpms/patches/gcc-g++-4.4.6-rtems4.10-20110829.diff
new file mode 100644
index 0000000000..dcaa439700
--- /dev/null
+++ b/contrib/crossrpms/patches/gcc-g++-4.4.6-rtems4.10-20110829.diff
@@ -0,0 +1,454 @@
+diff -Naur gcc-4.4.6.orig/gcc/cp/cfns.h gcc-4.4.6/gcc/cp/cfns.h
+--- gcc-4.4.6.orig/gcc/cp/cfns.h 2009-02-18 22:01:03.000000000 +0100
++++ gcc-4.4.6/gcc/cp/cfns.h 2011-08-29 07:14:47.562734079 +0200
+@@ -1,4 +1,4 @@
+-/* ANSI-C code produced by gperf version 3.0.1 */
++/* ANSI-C code produced by gperf version 3.0.4 */
+ /* Command-line: gperf -o -C -E -k '1-6,$' -j1 -D -N libc_name_p -L ANSI-C ../../gcc/cp/cfns.gperf */
+
+ #if !((' ' == 32) && ('!' == 33) && ('"' == 34) && ('#' == 35) \
+@@ -57,13 +57,13 @@
+ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
+ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
+ 400, 400, 400, 400, 400, 400, 400, 400, 0, 0,
+- 1, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 1, 400, 400, 400, 400, 400, 400, 400, 400, 400,
+ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
+ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
+ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
+ 400, 400, 400, 400, 400, 400, 400, 28, 90, 0,
+ 95, 0, 51, 93, 114, 26, 109, 124, 5, 1,
+- 6, 13, 37, 128, 3, 0, 0, 49, 38, 0,
++ 6, 13, 37, 128, 3, 0, 0, 49, 38, 0,
+ 104, 45, 0, 400, 400, 400, 400, 400, 400, 400,
+ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
+ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
+@@ -84,29 +84,32 @@
+ switch (hval)
+ {
+ default:
+- hval += asso_values[(unsigned char)str[5]+1];
++ hval += asso_values[(unsigned char)str[5]+1];
+ /*FALLTHROUGH*/
+ case 5:
+- hval += asso_values[(unsigned char)str[4]];
++ hval += asso_values[(unsigned char)str[4]];
+ /*FALLTHROUGH*/
+ case 4:
+- hval += asso_values[(unsigned char)str[3]];
++ hval += asso_values[(unsigned char)str[3]];
+ /*FALLTHROUGH*/
+ case 3:
+- hval += asso_values[(unsigned char)str[2]];
++ hval += asso_values[(unsigned char)str[2]];
+ /*FALLTHROUGH*/
+ case 2:
+- hval += asso_values[(unsigned char)str[1]];
++ hval += asso_values[(unsigned char)str[1]];
+ /*FALLTHROUGH*/
+ case 1:
+- hval += asso_values[(unsigned char)str[0]];
+- break;
++ hval += asso_values[(unsigned char)str[0]];
++ break;
+ }
+ return hval + asso_values[(unsigned char)str[len - 1]];
+ }
+
+ #ifdef __GNUC__
+ __inline
++#if defined __GNUC_STDC_INLINE__ || defined __GNUC_GNU_INLINE__
++__attribute__ ((__gnu_inline__))
++#endif
+ #endif
+ const char *
+ libc_name_p (register const char *str, register unsigned int len)
+@@ -329,17 +332,17 @@
+ register int key = hash (str, len);
+
+ if (key <= MAX_HASH_VALUE && key >= 0)
+- {
+- register int index = lookup[key];
++ {
++ register int index = lookup[key];
+
+- if (index >= 0)
+- {
+- register const char *s = wordlist[index];
+-
+- if (*str == *s && !strcmp (str + 1, s + 1))
+- return s;
+- }
+- }
++ if (index >= 0)
++ {
++ register const char *s = wordlist[index];
++
++ if (*str == *s && !strcmp (str + 1, s + 1))
++ return s;
++ }
++ }
+ }
+ return 0;
+ }
+diff -Naur gcc-4.4.6.orig/gcc/cp/cfns.h.orig gcc-4.4.6/gcc/cp/cfns.h.orig
+--- gcc-4.4.6.orig/gcc/cp/cfns.h.orig 1970-01-01 01:00:00.000000000 +0100
++++ gcc-4.4.6/gcc/cp/cfns.h.orig 2011-08-29 07:08:46.455058067 +0200
+@@ -0,0 +1,348 @@
++/* ANSI-C code produced by gperf version 3.0.4 */
++/* Command-line: gperf -o -C -E -k '1-6,$' -j1 -D -N libc_name_p -L ANSI-C ../../gcc/cp/cfns.gperf */
++
++#if !((' ' == 32) && ('!' == 33) && ('"' == 34) && ('#' == 35) \
++ && ('%' == 37) && ('&' == 38) && ('\'' == 39) && ('(' == 40) \
++ && (')' == 41) && ('*' == 42) && ('+' == 43) && (',' == 44) \
++ && ('-' == 45) && ('.' == 46) && ('/' == 47) && ('0' == 48) \
++ && ('1' == 49) && ('2' == 50) && ('3' == 51) && ('4' == 52) \
++ && ('5' == 53) && ('6' == 54) && ('7' == 55) && ('8' == 56) \
++ && ('9' == 57) && (':' == 58) && (';' == 59) && ('<' == 60) \
++ && ('=' == 61) && ('>' == 62) && ('?' == 63) && ('A' == 65) \
++ && ('B' == 66) && ('C' == 67) && ('D' == 68) && ('E' == 69) \
++ && ('F' == 70) && ('G' == 71) && ('H' == 72) && ('I' == 73) \
++ && ('J' == 74) && ('K' == 75) && ('L' == 76) && ('M' == 77) \
++ && ('N' == 78) && ('O' == 79) && ('P' == 80) && ('Q' == 81) \
++ && ('R' == 82) && ('S' == 83) && ('T' == 84) && ('U' == 85) \
++ && ('V' == 86) && ('W' == 87) && ('X' == 88) && ('Y' == 89) \
++ && ('Z' == 90) && ('[' == 91) && ('\\' == 92) && (']' == 93) \
++ && ('^' == 94) && ('_' == 95) && ('a' == 97) && ('b' == 98) \
++ && ('c' == 99) && ('d' == 100) && ('e' == 101) && ('f' == 102) \
++ && ('g' == 103) && ('h' == 104) && ('i' == 105) && ('j' == 106) \
++ && ('k' == 107) && ('l' == 108) && ('m' == 109) && ('n' == 110) \
++ && ('o' == 111) && ('p' == 112) && ('q' == 113) && ('r' == 114) \
++ && ('s' == 115) && ('t' == 116) && ('u' == 117) && ('v' == 118) \
++ && ('w' == 119) && ('x' == 120) && ('y' == 121) && ('z' == 122) \
++ && ('{' == 123) && ('|' == 124) && ('}' == 125) && ('~' == 126))
++/* The character set is not based on ISO-646. */
++#error "gperf generated tables don't work with this execution character set. Please report a bug to <bug-gnu-gperf@gnu.org>."
++#endif
++
++#line 1 "../../gcc/cp/cfns.gperf"
++
++#ifdef __GNUC__
++__inline
++#endif
++static unsigned int hash (const char *, unsigned int);
++#ifdef __GNUC__
++__inline
++#endif
++const char * libc_name_p (const char *, unsigned int);
++/* maximum key range = 391, duplicates = 0 */
++
++#ifdef __GNUC__
++__inline
++#else
++#ifdef __cplusplus
++inline
++#endif
++#endif
++static unsigned int
++hash (register const char *str, register unsigned int len)
++{
++ static const unsigned short asso_values[] =
++ {
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 0, 0,
++ 1, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 28, 90, 0,
++ 95, 0, 51, 93, 114, 26, 109, 124, 5, 1,
++ 6, 13, 37, 128, 3, 0, 0, 49, 38, 0,
++ 104, 45, 0, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400, 400, 400, 400,
++ 400, 400, 400, 400, 400, 400, 400
++ };
++ register int hval = len;
++
++ switch (hval)
++ {
++ default:
++ hval += asso_values[(unsigned char)str[5]+1];
++ /*FALLTHROUGH*/
++ case 5:
++ hval += asso_values[(unsigned char)str[4]];
++ /*FALLTHROUGH*/
++ case 4:
++ hval += asso_values[(unsigned char)str[3]];
++ /*FALLTHROUGH*/
++ case 3:
++ hval += asso_values[(unsigned char)str[2]];
++ /*FALLTHROUGH*/
++ case 2:
++ hval += asso_values[(unsigned char)str[1]];
++ /*FALLTHROUGH*/
++ case 1:
++ hval += asso_values[(unsigned char)str[0]];
++ break;
++ }
++ return hval + asso_values[(unsigned char)str[len - 1]];
++}
++
++#ifdef __GNUC__
++__inline
++#if defined __GNUC_STDC_INLINE__ || defined __GNUC_GNU_INLINE__
++__attribute__ ((__gnu_inline__))
++#endif
++#endif
++const char *
++libc_name_p (register const char *str, register unsigned int len)
++{
++ enum
++ {
++ TOTAL_KEYWORDS = 156,
++ MIN_WORD_LENGTH = 3,
++ MAX_WORD_LENGTH = 10,
++ MIN_HASH_VALUE = 9,
++ MAX_HASH_VALUE = 399
++ };
++
++ static const char * const wordlist[] =
++ {
++ "wcsstr",
++ "strstr",
++ "cos",
++ "towctrans",
++ "memmove",
++ "wcstol",
++ "wcscoll",
++ "wcstombs",
++ "strtol",
++ "strcoll",
++ "wcslen",
++ "time",
++ "ctime",
++ "strlen",
++ "iswctype",
++ "wmemchr",
++ "wcsrchr",
++ "ceil",
++ "sin",
++ "strrchr",
++ "tan",
++ "iscntrl",
++ "acos",
++ "wmemmove",
++ "wcsrtombs",
++ "wctrans",
++ "wmemcmp",
++ "pow",
++ "atol",
++ "wcsncmp",
++ "memset",
++ "free",
++ "strncmp",
++ "wmemset",
++ "wcsspn",
++ "wcstoul",
++ "strspn",
++ "strtoul",
++ "asctime",
++ "atan2",
++ "asin",
++ "atan",
++ "ferror",
++ "iswalnum",
++ "wcscat",
++ "realloc",
++ "strcat",
++ "wcscpy",
++ "memcpy",
++ "strcpy",
++ "tolower",
++ "floor",
++ "iswcntrl",
++ "atoi",
++ "clearerr",
++ "swscanf",
++ "wcsncat",
++ "islower",
++ "strncat",
++ "btowc",
++ "localtime",
++ "wctomb",
++ "isalnum",
++ "isprint",
++ "mblen",
++ "wcstod",
++ "log10",
++ "strtod",
++ "wcrtomb",
++ "abs",
++ "setlocale",
++ "wcschr",
++ "mbrlen",
++ "memchr",
++ "strchr",
++ "labs",
++ "iswpunct",
++ "exit",
++ "sqrt",
++ "swprintf",
++ "wctype",
++ "mbsrtowcs",
++ "wcscspn",
++ "getenv",
++ "strcspn",
++ "towlower",
++ "atof",
++ "wcstok",
++ "localeconv",
++ "strtok",
++ "calloc",
++ "malloc",
++ "isalpha",
++ "iswlower",
++ "iswspace",
++ "wcsxfrm",
++ "signal",
++ "strxfrm",
++ "wcsftime",
++ "feof",
++ "strftime",
++ "wcscmp",
++ "fabs",
++ "memcmp",
++ "strcmp",
++ "vsprintf",
++ "fwide",
++ "gmtime",
++ "sprintf",
++ "exp",
++ "wmemcpy",
++ "iswprint",
++ "sscanf",
++ "wcsncpy",
++ "strncpy",
++ "isspace",
++ "toupper",
++ "wctob",
++ "div",
++ "mbtowc",
++ "ldiv",
++ "log",
++ "mktime",
++ "isupper",
++ "atexit",
++ "modf",
++ "mbstowcs",
++ "mbrtowc",
++ "ispunct",
++ "iswalpha",
++ "setvbuf",
++ "rand",
++ "srand",
++ "frexp",
++ "towupper",
++ "mbsinit",
++ "cosh",
++ "vswprintf",
++ "iswupper",
++ "wcspbrk",
++ "fmod",
++ "strpbrk",
++ "sinh",
++ "tanh",
++ "iswdigit",
++ "clock",
++ "longjmp",
++ "ldexp",
++ "setbuf",
++ "fseek",
++ "iswgraph",
++ "difftime",
++ "iswxdigit",
++ "isdigit",
++ "isxdigit",
++ "isgraph"
++ };
++
++ static const short lookup[] =
++ {
++ -1, -1, -1, -1, -1, -1, -1, -1, -1, 0,
++ -1, -1, 1, -1, -1, -1, 2, -1, -1, -1,
++ -1, -1, 3, 4, -1, 5, 6, 7, 8, 9,
++ 10, 11, 12, 13, 14, -1, -1, -1, 15, 16,
++ 17, 18, 19, 20, 21, 22, -1, -1, 23, 24,
++ -1, 25, 26, 27, -1, 28, 29, 30, 31, 32,
++ 33, -1, 34, 35, -1, 36, 37, 38, -1, 39,
++ 40, -1, 41, -1, -1, -1, -1, -1, -1, 42,
++ -1, 43, -1, 44, -1, 45, 46, -1, 47, -1,
++ 48, 49, 50, 51, 52, -1, -1, 53, 54, 55,
++ -1, -1, -1, 56, -1, 57, 58, -1, 59, 60,
++ 61, 62, 63, 64, 65, -1, 66, 67, -1, 68,
++ -1, 69, 70, 71, 72, 73, 74, 75, -1, -1,
++ -1, -1, -1, 76, 77, 78, -1, -1, 79, 80,
++ 81, 82, -1, 83, 84, -1, 85, 86, 87, -1,
++ 88, 89, 90, 91, -1, -1, -1, 92, -1, 93,
++ -1, 94, -1, 95, -1, 96, 97, -1, 98, -1,
++ 99, 100, 101, 102, 103, 104, 105, 106, 107, 108,
++ -1, 109, 110, 111, 112, -1, 113, -1, -1, 114,
++ -1, -1, -1, 115, -1, -1, -1, 116, 117, -1,
++ 118, -1, -1, -1, -1, 119, 120, 121, -1, 122,
++ 123, -1, -1, 124, -1, 125, 126, -1, 127, -1,
++ 128, -1, -1, 129, 130, -1, -1, -1, -1, -1,
++ -1, 131, 132, -1, -1, -1, -1, 133, 134, 135,
++ -1, -1, -1, -1, -1, 136, -1, 137, -1, -1,
++ -1, 138, -1, -1, -1, -1, -1, -1, 139, 140,
++ -1, 141, -1, -1, 142, -1, 143, -1, -1, 144,
++ -1, 145, -1, -1, -1, -1, 146, -1, -1, -1,
++ -1, -1, -1, 147, -1, -1, -1, -1, -1, 148,
++ -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
++ -1, -1, -1, -1, 149, -1, -1, -1, -1, -1,
++ -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
++ -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
++ -1, -1, -1, -1, 150, -1, -1, -1, -1, -1,
++ 151, -1, -1, 152, -1, -1, -1, -1, -1, -1,
++ -1, -1, -1, -1, -1, -1, 153, -1, -1, -1,
++ -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
++ -1, -1, -1, 154, -1, -1, -1, -1, -1, -1,
++ -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
++ -1, -1, -1, -1, -1, -1, -1, -1, -1, 155
++ };
++
++ if (len <= MAX_WORD_LENGTH && len >= MIN_WORD_LENGTH)
++ {
++ register int key = hash (str, len);
++
++ if (key <= MAX_HASH_VALUE && key >= 0)
++ {
++ register int index = lookup[key];
++
++ if (index >= 0)
++ {
++ register const char *s = wordlist[index];
++
++ if (*str == *s && !strcmp (str + 1, s + 1))
++ return s;
++ }
++ }
++ }
++ return 0;
++}
+diff -Naur gcc-4.4.6.orig/gcc/cp/ChangeLog.rtems gcc-4.4.6/gcc/cp/ChangeLog.rtems
+--- gcc-4.4.6.orig/gcc/cp/ChangeLog.rtems 1970-01-01 01:00:00.000000000 +0100
++++ gcc-4.4.6/gcc/cp/ChangeLog.rtems 2011-08-29 07:14:47.561734025 +0200
+@@ -0,0 +1,5 @@
++2011-08-29 Ralf Corsépius <ralf.corsepius@rtems.org>
++ and Eric Norum <wenorum@lbl.gov>
++
++ Fix bootstrap breakdowns on OS X 10.7.1 (Lion):
++ * cfns.h: Regenerate.