Update the newlib devel branch with stuf from /trunk.
-------- diffstat follows --------
/devel/newlib/configure | 8 4 4 0
/devel/newlib/scripts/build/kernel/linux.sh | 2 1 1 0
/devel/newlib/scripts/build/cc/gcc.sh | 34 22 12 0 +
/devel/newlib/scripts/build/debug/300-gdb.sh | 52 45 7 0 +
/devel/newlib/scripts/build/libc/uClibc.sh | 6 3 3 0
/devel/newlib/scripts/build/mpfr.sh | 2 1 1 0
/devel/newlib/scripts/crosstool-NG.sh.in | 20 18 2 0 +
/devel/newlib/scripts/functions | 44 34 10 0 +
/devel/newlib/patches/glibc/2_9/500-ppc-glibc-2.9-atomic.patch | 414 0 414 0 ----------
/devel/newlib/patches/glibc/2_9/140-regex-BZ9697.patch | 111 0 111 0 ---
/devel/newlib/patches/glibc/2_9/190-queue-header-updates.patch | 89 0 89 0 --
/devel/newlib/patches/glibc/2_9/370-hppa_glibc-2.7-hppa-nptl-carlos.patch | 249 0 249 0 ------
/devel/newlib/patches/glibc/2_9/450-alpha-glibc-2.5-no-page-header.patch | 32 0 32 0 -
/devel/newlib/patches/glibc/2_9/330-2.3.3-china.patch | 35 0 35 0 -
/devel/newlib/patches/glibc/2_9/270-ldbl-nexttowardf.patch | 68 0 68 0 --
/devel/newlib/patches/glibc/2_9/410-2.9-fnmatch.patch | 64 0 64 0 --
/devel/newlib/patches/glibc/2_9/340-new-valencian-locale.patch | 120 0 120 0 ---
/devel/newlib/patches/glibc/2_9/350-2.4-undefine-__i686.patch | 47 0 47 0 -
/devel/newlib/patches/glibc/2_9/160-i386-x86_64-revert-clone-cfi.patch | 53 0 53 0 -
/devel/newlib/patches/glibc/2_9/150-regex-BZ697.patch | 28 0 28 0 -
/devel/newlib/patches/glibc/2_9/420-dont-build-timezone.patch | 19 0 19 0 -
/devel/newlib/patches/glibc/2_9/290-no-inline-gmon.patch | 38 0 38 0 -
/devel/newlib/patches/glibc/2_9/280-section-comments.patch | 29 0 29 0 -
/devel/newlib/patches/glibc/2_9/180-math-tests.patch | 72 0 72 0 --
/devel/newlib/patches/glibc/2_9/250-resolv-dynamic.patch | 44 0 44 0 -
/devel/newlib/patches/glibc/2_9/120-_nss_dns_gethostbyaddr2_r-check-and-adjust-the-buffer-alignment.patch | 35 0 35 0 -
/devel/newlib/patches/glibc/2_9/300-2.9-check_native-headers.patch | 22 0 22 0 -
/devel/newlib/patches/glibc/2_9/130-add_prio-macros.patch | 26 0 26 0 -
/devel/newlib/patches/glibc/2_9/310-2.3.6-fix-pr631.patch | 50 0 50 0 -
/devel/newlib/patches/glibc/2_9/510-sh-no-asm-user-header.patch | 70 0 70 0 --
/devel/newlib/patches/glibc/2_9/260-fadvise64_64.patch | 30 0 30 0 -
/devel/newlib/patches/glibc/2_9/440-alpha-glibc-2.4-xstat.patch | 249 0 249 0 ------
/devel/newlib/patches/glibc/2_9/170-2.10-dns-no-gethostbyname4.patch | 35 0 35 0 -
/devel/newlib/patches/glibc/2_9/230-2.3.3-localedef-fix-trampoline.patch | 74 0 74 0 --
/devel/newlib/patches/glibc/2_9/480-alpha-glibc-2.8-cache-shape.patch | 18 0 18 0 -
/devel/newlib/patches/glibc/2_9/360-2.8-nscd-one-fork.patch | 45 0 45 0 -
/devel/newlib/patches/glibc/2_9/210-2.9-strlen-hack.patch | 109 0 109 0 ---
/devel/newlib/patches/glibc/2_9/320-2.9-assume-pipe2.patch | 59 0 59 0 -
/devel/newlib/patches/glibc/2_9/100-ssp-compat.patch | 193 0 193 0 -----
/devel/newlib/patches/glibc/2_9/110-respect-env-CPPFLAGS.patch | 30 0 30 0 -
/devel/newlib/patches/glibc/2_9/220-manual-no-perl.patch | 29 0 29 0 -
/devel/newlib/patches/glibc/2_9/390-2.3.3_pre20040117-pt_pax.patch | 35 0 35 0 -
/devel/newlib/patches/glibc/2_9/460-alpha-glibc-2.5-no-asm-elf-header.patch | 38 0 38 0 -
/devel/newlib/patches/glibc/2_9/400-tests-sandbox-libdl-paths.patch | 198 0 198 0 -----
/devel/newlib/patches/glibc/2_9/520-sh-no-asm-elf-header.patch | 27 0 27 0 -
/devel/newlib/patches/glibc/2_9/240-i386-LOAD_PIC_REG.patch | 23 0 23 0 -
/devel/newlib/patches/glibc/2_9/200-awk-in-C-locale.patch | 23 0 23 0 -
/devel/newlib/patches/glibc/2_9/430-2.7-cross-compile-nptl.patch | 57 0 57 0 -
/devel/newlib/patches/glibc/2_9/380-2.3.6-dl_execstack-PaX-support.patch | 71 0 71 0 --
/devel/newlib/patches/glibc/2_9/490-ptr-mangling.patch | 114 0 114 0 ---
/devel/newlib/patches/glibc/2_9/470-alpha-glibc-2.8-creat.patch | 19 0 19 0 -
/devel/newlib/patches/glibc/ports-2_9/100-arm_linux_tls.patch | 14 0 14 0 -
/devel/newlib/patches/uClibc/0.9.30.1/140-gnu89-inline.patch | 2 1 1 0
/devel/newlib/docs/known-issues.txt | 16 15 1 0 +
/devel/newlib/docs/overview.txt | 2 1 1 0
/devel/newlib/samples/armeb-unknown-linux-uclibc/uClibc-0.9.30.config | 243 0 243 0 ------
/devel/newlib/samples/armeb-unknown-linux-uclibc/crosstool.config | 78 55 23 0 +-
/devel/newlib/samples/sh4-unknown-linux-gnu/crosstool.config | 35 18 17 0 +
/devel/newlib/samples/x86_64-unknown-linux-gnu/crosstool.config | 104 68 36 0 +--
/devel/newlib/samples/arm-unknown-elf/crosstool.config | 54 47 7 0 +
/devel/newlib/samples/armeb-unknown-eabi/crosstool.config | 54 47 7 0 +
/devel/newlib/samples/arm-unknown-linux-gnueabi/crosstool.config | 113 73 40 0 +--
/devel/newlib/samples/ia64-unknown-linux-gnu/crosstool.config | 91 61 30 0 +-
/devel/newlib/samples/x86_64-unknown-linux-uclibc/uClibc-0.9.30.config | 245 0 245 0 ------
/devel/newlib/samples/x86_64-unknown-linux-uclibc/crosstool.config | 78 55 23 0 +-
/devel/newlib/samples/armeb-unknown-linux-gnueabi/crosstool.config | 105 69 36 0 +--
/devel/newlib/samples/powerpc-e500v2-linux-gnuspe/crosstool.config | 96 63 33 0 +-
/devel/newlib/samples/i686-nptl-linux-gnu/crosstool.config | 78 48 30 0 +-
/devel/newlib/samples/arm-unknown-linux-gnu/crosstool.config | 105 69 36 0 +--
/devel/newlib/samples/powerpc-unknown-linux-gnu/crosstool.config | 103 67 36 0 +-
/devel/newlib/samples/mips-unknown-linux-uclibc/uClibc-0.9.30.config | 254 0 254 0 ------
/devel/newlib/samples/mips-unknown-linux-uclibc/crosstool.config | 77 54 23 0 +-
/devel/newlib/samples/arm-unknown-linux-uclibcgnueabi/uClibc-0.9.30.config | 253 0 253 0 ------
/devel/newlib/samples/arm-unknown-linux-uclibcgnueabi/crosstool.config | 78 55 23 0 +-
/devel/newlib/samples/arm-iphone-linux-gnueabi/crosstool.config | 84 57 27 0 +-
/devel/newlib/samples/armeb-unknown-linux-gnu/crosstool.config | 105 69 36 0 +--
/devel/newlib/samples/powerpc-unknown_nofpu-linux-gnu/crosstool.config | 104 68 36 0 +--
/devel/newlib/samples/i586-geode-linux-uclibc/uClibc-0.9.30.config | 263 0 263 0 ------
/devel/newlib/samples/i586-geode-linux-uclibc/crosstool.config | 78 55 23 0 +-
/devel/newlib/samples/arm-unknown-linux-uclibc/uClibc-0.9.30.config | 253 0 253 0 ------
/devel/newlib/samples/arm-unknown-linux-uclibc/crosstool.config | 78 55 23 0 +-
/devel/newlib/samples/powerpc-unknown-linux-uclibc/uClibc-0.9.30.config | 248 0 248 0 ------
/devel/newlib/samples/powerpc-unknown-linux-uclibc/crosstool.config | 77 54 23 0 +-
/devel/newlib/samples/mips-unknown-elf/crosstool.config | 54 47 7 0 +
/devel/newlib/samples/powerpc-405-linux-gnu/crosstool.config | 104 68 36 0 +--
/devel/newlib/samples/armeb-unknown-linux-uclibcgnueabi/crosstool.config | 26 13 13 0
/devel/newlib/samples/arm-unknown-eabi/crosstool.config | 54 47 7 0 +
/devel/newlib/samples/mipsel-unknown-linux-gnu/crosstool.config | 104 68 36 0 +--
/devel/newlib/samples/powerpc64-unknown-linux-gnu/crosstool.config | 75 49 26 0 +-
/devel/newlib/samples/alphaev56-unknown-linux-gnu/crosstool.config | 94 63 31 0 +-
/devel/newlib/samples/powerpc-860-linux-gnu/crosstool.config | 102 67 35 0 +-
/devel/newlib/config/kernel/linux.in | 87 46 41 0 +-
/devel/newlib/config/cc/gcc.in | 35 30 5 0 +
/devel/newlib/config/debug/gdb.in | 2 1 1 0
94 files changed, 1851 insertions(+), 5813 deletions(-)
2 * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
3 * Released under the terms of the GNU GPL v2.0.
15 #define LKC_DIRECT_LINK
18 static void conf(struct menu *menu);
19 static void check_conf(struct menu *menu);
30 } input_mode = ask_all;
33 static int indent = 1;
34 static int valid_stdin = 1;
35 static int sync_kconfig;
37 static char line[128];
38 static struct menu *rootEntry;
40 static char nohelp_text[] = N_("Sorry, no help available for this option yet.\n");
42 static const char *get_help(struct menu *menu)
44 if (menu_has_help(menu))
45 return _(menu_get_help(menu));
50 static void strip(char *str)
59 memmove(str, p, l + 1);
67 static void check_stdin(void)
70 printf(_("aborted!\n\n"));
71 printf(_("Console input/output is redirected. "));
72 printf(_("Run 'make oldconfig' to update configuration.\n\n"));
77 static int conf_askvalue(struct symbol *sym, const char *def)
79 enum symbol_type type = sym_get_type(sym);
81 if (!sym_has_value(sym))
87 if (!sym_is_changable(sym)) {
97 if (sym_has_value(sym)) {
104 fgets(line, 128, stdin);
123 int conf_string(struct menu *menu)
125 struct symbol *sym = menu->sym;
129 printf("%*s%s ", indent - 1, "", _(menu->prompt->text));
130 printf("(%s) ", sym->name);
131 def = sym_get_string_value(sym);
132 if (sym_get_string_value(sym))
133 printf("[%s] ", def);
134 if (!conf_askvalue(sym, def))
141 if (line[1] == '\n') {
142 printf("\n%s\n", get_help(menu));
147 line[strlen(line)-1] = 0;
150 if (def && sym_set_string_value(sym, def))
155 static int conf_sym(struct menu *menu)
157 struct symbol *sym = menu->sym;
159 tristate oldval, newval;
162 printf("%*s%s ", indent - 1, "", _(menu->prompt->text));
164 printf("(%s) ", sym->name);
165 type = sym_get_type(sym);
167 oldval = sym_get_tristate_value(sym);
179 if (oldval != no && sym_tristate_within_range(sym, no))
181 if (oldval != mod && sym_tristate_within_range(sym, mod))
183 if (oldval != yes && sym_tristate_within_range(sym, yes))
185 if (menu_has_help(menu))
188 if (!conf_askvalue(sym, sym_get_string_value(sym)))
196 if (!line[1] || !strcmp(&line[1], "o"))
208 if (!line[1] || !strcmp(&line[1], "es"))
219 if (sym_set_tristate_value(sym, newval))
222 printf("\n%s\n", get_help(menu));
226 static int conf_choice(struct menu *menu)
228 struct symbol *sym, *def_sym;
234 type = sym_get_type(sym);
235 is_new = !sym_has_value(sym);
236 if (sym_is_changable(sym)) {
239 switch (sym_get_tristate_value(sym)) {
248 switch (sym_get_tristate_value(sym)) {
252 printf("%*s%s\n", indent - 1, "", _(menu_get_prompt(menu)));
262 printf("%*s%s\n", indent - 1, "", _(menu_get_prompt(menu)));
263 def_sym = sym_get_choice_value(sym);
266 for (child = menu->list; child; child = child->next) {
267 if (!menu_is_visible(child))
270 printf("%*c %s\n", indent, '*', _(menu_get_prompt(child)));
274 if (child->sym == def_sym) {
276 printf("%*c", indent, '>');
278 printf("%*c", indent, ' ');
279 printf(" %d. %s", cnt, _(menu_get_prompt(child)));
280 if (child->sym->name)
281 printf(" (%s)", child->sym->name);
282 if (!sym_has_value(child->sym))
286 printf(_("%*schoice"), indent - 1, "");
291 printf("[1-%d", cnt);
292 if (menu_has_help(menu))
295 switch (input_mode) {
306 fgets(line, 128, stdin);
308 if (line[0] == '?') {
309 printf("\n%s\n", get_help(menu));
314 else if (isdigit(line[0]))
324 for (child = menu->list; child; child = child->next) {
325 if (!child->sym || !menu_is_visible(child))
332 if (line[strlen(line) - 1] == '?') {
333 printf("\n%s\n", get_help(child));
336 sym_set_choice_value(sym, child->sym);
337 for (child = child->list; child; child = child->next) {
346 static void conf(struct menu *menu)
349 struct property *prop;
352 if (!menu_is_visible(menu))
360 switch (prop->type) {
362 if (input_mode == ask_silent && rootEntry != menu) {
367 prompt = menu_get_prompt(menu);
369 printf("%*c\n%*c %s\n%*c\n",
371 indent, '*', _(prompt),
381 if (sym_is_choice(sym)) {
383 if (sym->curr.tri != mod)
402 for (child = menu->list; child; child = child->next)
408 static void check_conf(struct menu *menu)
413 if (!menu_is_visible(menu))
417 if (sym && !sym_has_value(sym)) {
418 if (sym_is_changable(sym) ||
419 (sym_is_choice(sym) && sym_get_tristate_value(sym) == yes)) {
421 printf(_("*\n* Restart config...\n*\n"));
422 rootEntry = menu_get_parent_menu(menu);
427 for (child = menu->list; child; child = child->next)
431 int main(int ac, char **av)
437 setlocale(LC_ALL, "");
438 bindtextdomain(PACKAGE, LOCALEDIR);
441 while ((opt = getopt(ac, av, "osdD:nmyrh")) != -1) {
444 input_mode = ask_silent;
447 input_mode = ask_silent;
451 input_mode = set_default;
454 input_mode = set_default;
455 defconfig_file = optarg;
461 input_mode = set_mod;
464 input_mode = set_yes;
467 input_mode = set_random;
471 printf(_("See README for usage info\n"));
475 fprintf(stderr, _("See README for usage info\n"));
480 printf(_("%s: Kconfig file missing\n"), av[0]);
487 if (stat(".config", &tmpstat)) {
488 fprintf(stderr, _("***\n"
489 "*** Please run some configurator (e.g. \"make menuconfig\").\n"
495 switch (input_mode) {
498 defconfig_file = conf_get_default_confname();
499 if (conf_read(defconfig_file)) {
501 "*** Can't find default configuration \"%s\"!\n"
502 "***\n"), defconfig_file);
515 name = getenv("KCONFIG_ALLCONFIG");
516 if (name && !stat(name, &tmpstat)) {
517 conf_read_simple(name, S_DEF_USER);
520 switch (input_mode) {
521 case set_no: name = "allno.config"; break;
522 case set_mod: name = "allmod.config"; break;
523 case set_yes: name = "allyes.config"; break;
524 case set_random: name = "allrandom.config"; break;
527 if (!stat(name, &tmpstat))
528 conf_read_simple(name, S_DEF_USER);
529 else if (!stat("all.config", &tmpstat))
530 conf_read_simple("all.config", S_DEF_USER);
537 if (conf_get_changed()) {
538 name = getenv("KCONFIG_NOSILENTUPDATE");
541 _("\n*** Configuration requires explicit update.\n\n"));
545 valid_stdin = isatty(0) && isatty(1) && isatty(2);
548 switch (input_mode) {
550 conf_set_all_new_symbols(def_no);
553 conf_set_all_new_symbols(def_yes);
556 conf_set_all_new_symbols(def_mod);
559 conf_set_all_new_symbols(def_random);
562 conf_set_all_new_symbols(def_default);
566 rootEntry = &rootmenu;
568 input_mode = ask_silent;
571 /* Update until a loop caused no more changes */
574 check_conf(&rootmenu);
580 /* silentoldconfig is used during the build so we shall update autoconf.
581 * All other commands are only used to generate a config.
583 if (conf_get_changed() && conf_write(NULL)) {
584 fprintf(stderr, _("\n*** Error during writing of the configuration.\n\n"));
588 if (conf_write(NULL)) {
589 fprintf(stderr, _("\n*** Error during writing of the configuration.\n\n"));