This is the mail archive of the gcc-patches@gcc.gnu.org mailing list for the GCC project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]

[PATCH] add FreeBSD/IA-64 to gcc 3.0.3


I would like to commit this to the gcc-3_0-branch.  We need this for
FreeBSD's porting effort to the IA-64.

I configured both stock and with my changes each of "ia64-unknown-linux",
"ia64-unknown-elf", and "ia64-unknown-hpux" and varied no change in the
output of 'gcc -E' ran on the created tm.h.

Permission to commit?

-- 
-- David  (obrien@FreeBSD.org)


Index: ChangeLog
===================================================================
RCS file: /FBSD/egcs-repo/Cvs/gcc/gcc/gcc/ChangeLog,v
retrieving revision 1.9240.2.876
diff -u -r1.9240.2.876 ChangeLog
--- ChangeLog	26 Oct 2001 04:38:12 -0000	1.9240.2.876
+++ ChangeLog	27 Oct 2001 20:36:21 -0000
@@ -1,3 +1,16 @@
+2001-10-27  David O'Brien  <obrien@FreeBSD.org>
+
+	* config.gcc: Add FreeBSD/IA-64 target.  Move inclusion of IA-64
+	target headers to tm_file.
+	* config/i64/ia64.h(TARGET_VERSION,ASM_SPEC,LINK_SPEC): Remove,
+	they are OS specific.  Use CPP_CPU_SPEC rather than CPP_PREDEFINES, so
+	OS specific files and use CPP_PREDEFINES for their needs.
+	* config/i64/elf.h(TARGET_VERSION): Add.  Also, move inclusion of target
+	headers to tm_file.
+	* config/i64/linux.h: Likewise.
+	* config/i64/frebsd.h: New file.
+	* config/frebsd.h: Clean up and change default debugging type to DWARF2.
+
 2001-10-26  David Edelsohn  <edelsohn@gnu.org>
 
 	* config/rs6000/rs6000.md (cr_logical): Swap order of CODE and

Index: config.gcc
===================================================================
RCS file: /FBSD/egcs-repo/Cvs/gcc/gcc/gcc/config.gcc,v
retrieving revision 1.27.2.15
diff -u -r1.27.2.15 config.gcc
--- config.gcc	10 Oct 2001 00:25:25 -0000	1.27.2.15
+++ config.gcc	27 Oct 2001 20:15:24 -0000
@@ -1623,7 +1625,7 @@
 	use_collect2=yes
 	;;
 ia64*-*-elf*)
-	tm_file=ia64/elf.h
+	tm_file="${tm_file} elfos.h ia64/sysv4.h ia64/elf.h"
 	tmake_file="ia64/t-ia64"
 	target_cpu_default="0"
 	if test x$gas = xyes
@@ -1636,8 +1638,15 @@
 	fi
 	float_format=i386
 	;;
+ia64*-*-freebsd*)
+	tm_file="${tm_file} ${fbsd_tm_file} elfos.h ia64/sysv4.h ia64/freebsd.h"
+	target_cpu_default="MASK_GNU_AS|MASK_GNU_LD"
+	xmake_file=none
+	tmake_file="${tmake_file} ia64/t-ia64"
+	float_format=i386
+	;;
 ia64*-*-linux*)
-	tm_file=ia64/linux.h
+	tm_file="${tm_file} linux.h ia64/sysv4.h ia64/linux.h"
 	tmake_file="t-slibgcc-elf-ver t-linux ia64/t-ia64 ia64/t-glibc"
 	target_cpu_default="MASK_GNU_AS|MASK_GNU_LD"
 	if test x$enable_threads = xyes; then
Index: config/elfos.h
===================================================================
RCS file: /FBSD/egcs-repo/Cvs/gcc/gcc/gcc/config/elfos.h,v
retrieving revision 1.25.2.1
diff -u -r1.25.2.1 elfos.h
--- config/elfos.h	16 Apr 2001 18:25:40 -0000	1.25.2.1
+++ config/elfos.h	27 Oct 2001 20:19:50 -0000
@@ -91,6 +95,7 @@
 
 /* Output #ident as a .ident.  */
 
+#undef  ASM_OUTPUT_IDENT
 #define ASM_OUTPUT_IDENT(FILE, NAME) \
   fprintf (FILE, "%s\"%s\"\n", IDENT_ASM_OP, NAME);
 
Index: config/ia63/elf.h
===================================================================
RCS file: /FBSD/egcs-repo/Cvs/gcc/gcc/gcc/config/ia64/elf.h,v
retrieving revision 1.1
diff -u -r1.1 elf.h
--- config/ia64/elf.h	9 Mar 2000 00:26:04 -0000	1.1
+++ config/ia64/elf.h	27 Oct 2001 19:10:25 -0000
@@ -1,8 +1,44 @@
 /* Definitions for embedded ia64-elf target.  */
 
-#include "ia64/ia64.h"
-#include "elfos.h"
-#include "sysv4.h"
+/* This macro is a C statement to print on `stderr' a string describing the
+   particular machine description choice.  */
+
+#define TARGET_VERSION fprintf (stderr, " (IA-64)");
+
+/* Define this to be a string constant containing `-D' options to define the
+   predefined macros that identify this machine and system.  These macros will
+   be predefined unless the `-ansi' option is specified.  */
+/* ??? This is undefed in svr4.h.  */
+#define CPP_PREDEFINES "-Dia64 -Amachine=ia64"
+
+/* A C string constant that tells the GNU CC driver program options to pass to
+   the assembler.  It can also specify how to translate options you give to GNU
+   CC into options for GNU CC to pass to the assembler.  */
+
+#if ((TARGET_CPU_DEFAULT | TARGET_DEFAULT) & MASK_GNU_AS) != 0
+/* GNU AS.  */
+#define ASM_SPEC \
+  "%{mno-gnu-as:-N so} %{!mno-gnu-as:-x} %{mconstant-gp} %{mauto-pic}"
+#else
+/* Intel ias.  */
+#define ASM_SPEC \
+  "%{!mgnu-as:-N so} %{mgnu-as:-x} %{mconstant-gp:-M const_gp}\
+   %{mauto-pic:-M no_plabel}"
+#endif
+
+/* A C string constant that tells the GNU CC driver program options to pass to
+   the linker.  It can also specify how to translate options you give to GNU CC
+   into options for GNU CC to pass to the linker.  */
+
+/* The Intel linker does not support dynamic linking, so we need -dn.
+   The Intel linker gives annoying messages unless -N so is used.  */
+#if ((TARGET_CPU_DEFAULT | TARGET_DEFAULT) & MASK_GNU_LD) != 0
+/* GNU LD.  */
+#define LINK_SPEC "%{mno-gnu-ld:-dn -N so}"
+#else
+/* Intel ild.  */
+#define LINK_SPEC "%{!mgnu-ld:-dn -N so}"
+#endif
 
 /* svr4.h links with crti.o/crtn.o, but elfos.h does not.  We override elfos.h
    so that we can use the standard ELF Unix method.  */
Index: config/ia64/freebsd.h
===================================================================
RCS file: config/ia64/freebsd.h
diff -N config/ia64/freebsd.h
--- /dev/null	1 Jan 1970 00:00:00 -0000
+++ config/ia64/freebsd.h	27 Oct 2001 20:10:35 -0000
@@ -0,0 +1,88 @@
+/* Definitions for Intel IA-64 running FreeBSD using the ELF format
+   Copyright (C) 2001 Free Software Foundation, Inc.
+   Contributed by David E. O'Brien <obrien@FreeBSD.org> and BSDi.
+
+This file is part of GNU CC.
+
+GNU CC is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+GNU CC is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with GNU CC; see the file COPYING.  If not, write to
+the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
+
+
+#undef  LINK_SPEC
+#define LINK_SPEC							\
+ "%{p:%e`-p' not supported; use `-pg' and gprof(1)}			\
+  %{Wl,*:%*}								\
+  %{assert*} %{R*} %{rpath*} %{defsym*}					\
+  %{shared:-Bshareable %{h*} %{soname*}}				\
+  %{symbolic:-Bsymbolic}						\
+  %{!shared:								\
+    %{!static:								\
+      %{rdynamic:-export-dynamic}					\
+      %{!dynamic-linker:-dynamic-linker /usr/libexec/ld-elf.so.1}}	\
+    %{static:-Bstatic}}"
+
+#undef  ASM_SPEC
+#define ASM_SPEC "-x %{mconstant-gp} %{mauto-pic}"
+
+
+/************************[  Target stuff  ]***********************************/
+
+/* Define the actual types of some ANSI-mandated types.  
+   Needs to agree with <machine/ansi.h>.  GCC defaults come from c-decl.c,
+   c-common.c, and config/<arch>/<arch>.h.  */
+
+/* alpha.h gets this wrong for FreeBSD.  We use the GCC defaults instead.  */
+#undef WCHAR_TYPE
+
+#undef  WCHAR_UNSIGNED
+#define WCHAR_UNSIGNED 0
+
+#undef  WCHAR_TYPE_SIZE
+#define WCHAR_TYPE_SIZE 32
+
+#undef  TARGET_VERSION
+#define TARGET_VERSION fprintf (stderr, " (FreeBSD/IA-64 ELF)");
+
+#define TARGET_ELF		1
+
+#define DONT_USE_BUILTIN_SETJMP
+#define JMP_BUF_SIZE  76
+
+/* Output any profiling code before the prologue.  */
+
+#undef  PROFILE_BEFORE_PROLOGUE
+#define PROFILE_BEFORE_PROLOGUE 1
+
+/* A C statement or compound statement to output to FILE some assembler code to
+   call the profiling subroutine `mcount'.  */
+
+#undef FUNCTION_PROFILER
+#define FUNCTION_PROFILER(FILE, LABELNO)		\
+do {							\
+  char buf[20];						\
+  ASM_GENERATE_INTERNAL_LABEL (buf, "LP", LABELNO);	\
+  fputs ("\talloc out0 = ar.pfs, 8, 0, 4, 0\n", FILE);	\
+  if (TARGET_AUTO_PIC)					\
+    fputs ("\tmovl out3 = @gprel(", FILE);		\
+  else							\
+    fputs ("\taddl out3 = @ltoff(", FILE);		\
+  assemble_name (FILE, buf);				\
+  if (TARGET_AUTO_PIC)					\
+    fputs (");;\n", FILE);				\
+  else							\
+    fputs ("), r1;;\n", FILE);				\
+  fputs ("\tmov out1 = r1\n", FILE);			\
+  fputs ("\tmov out2 = b0\n", FILE);			\
+  fputs ("\tbr.call.sptk.many b0 = _mcount;;\n", FILE);	\
+} while (0)
Index: config/ia64/hpux.h
===================================================================
RCS file: /FBSD/egcs-repo/Cvs/gcc/gcc/gcc/config/ia64/hpux.h,v
retrieving revision 1.1.2.1
diff -u -r1.1.2.1 hpux.h
--- config/ia64/hpux.h	16 Mar 2001 04:42:09 -0000	1.1.2.1
+++ config/ia64/hpux.h	27 Oct 2001 20:02:16 -0000
@@ -20,6 +20,11 @@
 the Free Software Foundation, 59 Temple Place - Suite 330,
 Boston, MA 02111-1307, USA.  */
 
+/* This macro is a C statement to print on `stderr' a string describing the
+   particular machine description choice.  */
+
+#define TARGET_VERSION fprintf (stderr, " (IA-64)");
+
 #undef CPP_PREDEFINES
 #define CPP_PREDEFINES "\
   -D__IA64__ -D__ia64 -D__ia64__ -D__hpux -D__hpux__ -Dhpux -Dunix \
Index: config/ia64/ia64.h
===================================================================
RCS file: /FBSD/egcs-repo/Cvs/gcc/gcc/gcc/config/ia64/ia64.h,v
retrieving revision 1.60.4.5
diff -u -r1.60.4.5 ia64.h
--- config/ia64/ia64.h	22 Sep 2001 01:33:20 -0000	1.60.4.5
+++ config/ia64/ia64.h	27 Oct 2001 19:12:00 -0000
@@ -31,11 +31,11 @@
 
 /* Run-time target specifications */
 
-/* Define this to be a string constant containing `-D' options to define the
-   predefined macros that identify this machine and system.  These macros will
-   be predefined unless the `-ansi' option is specified.  */
-/* ??? This is undefed in svr4.h.  */
-#define CPP_PREDEFINES "-Dia64 -Amachine=ia64"
+#define CPP_CPU_SPEC "\
+  -Acpu=ia64 -Amachine=ia64 \
+  %{!ansi:%{!std=c*:%{!std=i*:-Dia64}}} -D__ia64 -D__ia64__"
+
+#define CC1_SPEC "%(cc1_cpu) "
 
 /* This declaration should be present.  */
 extern int target_flags;
@@ -169,11 +169,6 @@
       N_("Specify range of registers to make fixed.")},			\
 }
 
-/* This macro is a C statement to print on `stderr' a string describing the
-   particular machine description choice.  */
-
-#define TARGET_VERSION fprintf (stderr, " (IA-64)");
-
 /* Sometimes certain combinations of command options do not make sense on a
    particular target machine.  You can define a macro `OVERRIDE_OPTIONS' to
    take account of this.  This macro, if defined, is executed once just after
@@ -201,6 +196,7 @@
    defines in other tm.h files.  */
 #define CPP_SPEC \
   "%{mcpu=itanium:-D__itanium__} %{mbig-endian:-D__BIG_ENDIAN__}	\
+   %{fPIC:-D__PIC__ -D__pic__} %{fpic:-D__PIC__ -D__pic__}		\
    -D__LONG_MAX__=9223372036854775807L"
 
 /* If this macro is defined, the preprocessor will not define the builtin macro
@@ -235,36 +231,6 @@
    into options for GNU CC to pass to the `cc1plus'.  */
 
 /* #define CC1PLUS_SPEC "" */
-
-/* A C string constant that tells the GNU CC driver program options to pass to
-   the assembler.  It can also specify how to translate options you give to GNU
-   CC into options for GNU CC to pass to the assembler.  */
-
-#if ((TARGET_CPU_DEFAULT | TARGET_DEFAULT) & MASK_GNU_AS) != 0
-/* GNU AS.  */
-#define ASM_SPEC \
-  "%{mno-gnu-as:-N so} %{!mno-gnu-as:-x} %{mconstant-gp} %{mauto-pic}"
-#else
-/* Intel ias.  */
-#define ASM_SPEC \
-  "%{!mgnu-as:-N so} %{mgnu-as:-x} %{mconstant-gp:-M const_gp}\
-   %{mauto-pic:-M no_plabel}"
-#endif
-
-/* A C string constant that tells the GNU CC driver program options to pass to
-   the linker.  It can also specify how to translate options you give to GNU CC
-   into options for GNU CC to pass to the linker.  */
-
-/* The Intel linker does not support dynamic linking, so we need -dn.
-   The Intel linker gives annoying messages unless -N so is used.  */
-#if ((TARGET_CPU_DEFAULT | TARGET_DEFAULT) & MASK_GNU_LD) != 0
-/* GNU LD.  */
-#define LINK_SPEC "%{mno-gnu-ld:-dn -N so}"
-#else
-/* Intel ild.  */
-#define LINK_SPEC "%{!mgnu-ld:-dn -N so}"
-#endif
-
 
 /* Storage Layout */
 
Index: config/ia64/linux.h
===================================================================
RCS file: /FBSD/egcs-repo/Cvs/gcc/gcc/gcc/config/ia64/linux.h,v
retrieving revision 1.8.4.1
diff -u -r1.8.4.1 linux.h
--- config/ia64/linux.h	8 Jun 2001 17:10:35 -0000	1.8.4.1
+++ config/ia64/linux.h	27 Oct 2001 19:29:39 -0000
@@ -1,7 +1,9 @@
 /* Definitions for ia64-linux target.  */
-#include "ia64/ia64.h"
-#include <linux.h>
-#include "sysv4.h"
+
+/* This macro is a C statement to print on `stderr' a string describing the
+   particular machine description choice.  */
+
+#define TARGET_VERSION fprintf (stderr, " (IA-64)");
 
 /* This is for -profile to use -lc_p instead of -lc. */
 #undef CC1_SPEC

Index: config/freebsd.h
===================================================================
RCS file: /FBSD/egcs-repo/Cvs/gcc/gcc/gcc/config/freebsd.h,v
retrieving revision 1.5.4.2
diff -u -r1.5.4.2 freebsd.h
--- config/freebsd.h	30 May 2001 23:05:30 -0000	1.5.4.2
+++ config/freebsd.h	27 Oct 2001 20:33:44 -0000
@@ -38,16 +38,18 @@
     || (CHAR) == 'z' /* ignored by ld */				\
     || (CHAR) == 'R')
 
-#undef SWITCH_TAKES_ARG
+#undef  SWITCH_TAKES_ARG
 #define SWITCH_TAKES_ARG(CHAR) (FBSD_SWITCH_TAKES_ARG(CHAR))
 
+/* This defines which multi-letter switches take arguments.  */
+
 #define FBSD_WORD_SWITCH_TAKES_ARG(STR)					\
   (DEFAULT_WORD_SWITCH_TAKES_ARG (STR)					\
    || !strcmp ((STR), "rpath") || !strcmp ((STR), "rpath-link")		\
    || !strcmp ((STR), "soname") || !strcmp ((STR), "defsym") 		\
    || !strcmp ((STR), "assert") || !strcmp ((STR), "dynamic-linker"))
 
-#undef WORD_SWITCH_TAKES_ARG
+#undef  WORD_SWITCH_TAKES_ARG
 #define WORD_SWITCH_TAKES_ARG(STR) (FBSD_WORD_SWITCH_TAKES_ARG(STR))
 
 #if FBSD_MAJOR == 6
@@ -81,8 +83,8 @@
 /* Provide a CPP_SPEC appropriate for FreeBSD.  We just deal with the GCC 
    option `-posix', and PIC issues.  */
 
-#undef CPP_SPEC
-#define CPP_SPEC "%(cpp_cpu)						\
+#define FBSD_CPP_SPEC "							\
+  %(cpp_cpu)								\
   %{fPIC:-D__PIC__ -D__pic__} %{fpic:-D__PIC__ -D__pic__}		\
   %{posix:-D_POSIX_SOURCE}"
 
@@ -100,6 +102,10 @@
    misconfigured the gcc bootstrap but are later consulting FreeBSD
    manual pages that refer to the mythical -pthread option).  */
 
+/* Provide a LIB_SPEC appropriate for FreeBSD.  Just select the appropriate
+   libc, depending on whether we're doing profiling or need threads support.
+   (simular to the default, except no -lg, and no -p).  */
+
 #undef  LIB_SPEC
 #ifdef FBSD_NO_THREADS
 #define LIB_SPEC "							\
@@ -129,53 +135,73 @@
 #endif
 #endif
 
-/* Code generation parameters.  */
 
-/* Make gcc agree with <machine/ansi.h>.  */
+/************************[  Target stuff  ]***********************************/
 
-#undef WCHAR_TYPE
-#define WCHAR_TYPE "int"
+/* Don't assume anything about the header files.  */
+#undef  NO_IMPLICIT_EXTERN_C
+#define NO_IMPLICIT_EXTERN_C
 
-#undef WCHAR_UNSIGNED
-#define WCHAR_UNSIGNED 0
+/* Allow #sccs in preprocessor.  */
+#undef  SCCS_DIRECTIVE
+#define SCCS_DIRECTIVE
+
+/* Code generation parameters.  */
 
 /* Don't default to pcc-struct-return, because gcc is the only compiler, and
    we want to retain compatibility with older gcc versions
    (even though the SVR4 ABI for the i386 says that records and unions are
    returned in memory).  */
-#undef DEFAULT_PCC_STRUCT_RETURN
+#undef  DEFAULT_PCC_STRUCT_RETURN
 #define DEFAULT_PCC_STRUCT_RETURN 0
 
-/* Ensure we the configuration knows our system correctly so we can link with
-   libraries compiled with the native cc.  */
+/* Writing `int' for a bitfield forces int alignment for the structure.  */
+#undef  PCC_BITFIELD_TYPE_MATTERS
+#define PCC_BITFIELD_TYPE_MATTERS 1
+
+/* Use periods rather than dollar signs in special g++ assembler names.
+   This ensures the configuration knows our system correctly so we can link
+   with libraries compiled with the native cc.  */
 #undef NO_DOLLAR_IN_LABEL
 
+/* The prefix to add to user-visible assembler symbols.
+   For System V Release 4 & ELF the convention is *not* to prepend a leading
+   underscore onto user-level symbol names.  */
+
+#undef  USER_LABEL_PREFIX
+#define USER_LABEL_PREFIX ""
+
+/* Handle #pragma weak and #pragma pack.  */
+#undef  HANDLE_SYSV_PRAGMA
+#define HANDLE_SYSV_PRAGMA
+
 /* Use more efficient ``thunks'' to implement C++ vtables.  */
 #undef DEFAULT_VTABLE_THUNKS
 #define DEFAULT_VTABLE_THUNKS 1
 
-/* The GNU tools operate better with dwarf2 than stabs.  Since we
-   don't have any native tools to be compatible with, default to
-   dwarf2.  */
-#undef PREFERRED_DEBUGGING_TYPE
-#define PREFERRED_DEBUGGING_TYPE DWARF2_DEBUG
+/************************[  Assembler stuff  ]********************************/
 
-#undef IDENT_ASM_OP
+#undef  IDENT_ASM_OP
 #define IDENT_ASM_OP "\t.ident\t"
 
 /* Output #ident as a .ident.  */
-#undef ASM_OUTPUT_IDENT
+
+#undef  ASM_OUTPUT_IDENT
 #define ASM_OUTPUT_IDENT(FILE, NAME)					\
   fprintf ((FILE), "%s\"%s\"\n", IDENT_ASM_OP, (NAME));
 
-/* Miscellaneous parameters.  */
-
-/* Don't assume anything about the header files.  */
-#undef NO_IMPLICIT_EXTERN_C
-#define NO_IMPLICIT_EXTERN_C
-
-/* Allow #sccs in preprocessor.  */
-#define SCCS_DIRECTIVE
+/************************[  Debugger stuff  ]*********************************/
 
-/* Handle #pragma weak and #pragma pack.  */
-#define HANDLE_SYSV_PRAGMA
+/* All ELF targets can support DWARF-2.  */
+#undef  DWARF2_DEBUGGING_INFO
+#define DWARF2_DEBUGGING_INFO
+
+/* This is BSD, so we want the DBX format.  */
+#undef  DBX_DEBUGGING_INFO
+#define DBX_DEBUGGING_INFO
+
+/* Even though this is BSD, ELF and the GNU tools operates better with dwarf2
+   than stabs.  Since we don't have any native tools to be compatible with,
+   defaulting to dwarf2 is OK.  */
+#undef  PREFERRED_DEBUGGING_TYPE
+#define PREFERRED_DEBUGGING_TYPE DWARF2_DEBUG

Index: po/ChangeLog
===================================================================
RCS file: /FBSD/egcs-repo/Cvs/gcc/gcc/gcc/po/ChangeLog,v
retrieving revision 1.41.2.8
diff -u -r1.41.2.8 ChangeLog
--- po/ChangeLog	23 Oct 2001 17:20:00 -0000	1.41.2.8
+++ po/ChangeLog	27 Oct 2001 20:21:53 -0000
@@ -1,3 +1,7 @@
+2001-10-27  David O'Brien  <obrien@FreeBSD.org>
+
+	* POTFILES.in: Add config/ia64/freebsd.h.
+
 2001-10-23  Release Manager
 
 	* GCC 3.0.2 Released.
Index: po/POTFILES.in
===================================================================
RCS file: /FBSD/egcs-repo/Cvs/gcc/gcc/gcc/po/POTFILES.in,v
retrieving revision 1.39.4.3
diff -u -r1.39.4.3 POTFILES.in
--- po/POTFILES.in	13 Jun 2001 00:45:34 -0000	1.39.4.3
+++ po/POTFILES.in	27 Oct 2001 20:22:13 -0000
@@ -358,6 +358,7 @@
 config/i960/vx960.h
 config/i960/xm-i960.h
 config/ia64/elf.h
+config/ia64/freebsd.h
 config/ia64/fde-glibc.c
 config/ia64/hpux.h
 config/ia64/ia64-protos.h


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]