diff --git a/gcc/config/m68k/next.h b/gcc/config/m68k/next.h
new file mode 100644
index 0000000000000000000000000000000000000000..579e2d0b1e775344f859c45d0bde2e7afcf18674
--- /dev/null
+++ b/gcc/config/m68k/next.h
@@ -0,0 +1,430 @@
+/* next.h:  definitions for NeXT.
+
+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.  */
+
+#include "m68k.h"
+
+#define EXTRA_FORMAT_FUNCTIONS \
+      "NXPrintf",	FALSE,	2,	FALSE,	\
+      "NXScanf",	TRUE,	2,	FALSE,	\
+      "NXVPrintf",	FALSE,	2,	TRUE,	\
+      "NXVScanf",	TRUE,	2,	TRUE,	\
+      "DPSPrintf",	FALSE,	2,	FALSE,	\
+      "bsd_sprintf",	FALSE,	2,	FALSE,	\
+      "bsd_vsprintf",	FALSE,	2,	TRUE,
+
+/* Use NeXT's special calling convention for sending an Objc message.  */
+#define NEXT_OBJC_RUNTIME
+
+/* We have atexit.  */
+#define HAVE_ATEXIT
+
+/* Enable recent gcc to compile under the old gcc in Next release 1.0.  */
+#define __inline inline
+
+/* See m68k.h.  0407 means 68040 (or 68030 or 68020, with 68881/2).  */
+
+#define TARGET_DEFAULT 0407
+
+/* wchar_t is unsigned short */
+
+#undef WCHAR_TYPE
+#undef WCHAR_TYPE_SIZE
+#define WCHAR_TYPE "short unsigned int"
+#define WCHAR_TYPE_SIZE (BITS_PER_WORD / 2)
+
+/* Give methods pretty symbol names on NeXT. */
+
+#define OBJC_GEN_METHOD_LABEL(BUF,IS_INST,CLASS_NAME,CAT_NAME,SEL_NAME)	\
+  do { if (CAT_NAME)							\
+	 sprintf (BUF, "%c[%s(%s) %s]", (IS_INST) ? '-' : '+',		\
+		  (CLASS_NAME), (CAT_NAME), (SEL_NAME));		\
+       else								\
+	 sprintf (BUF, "%c[%s %s]", (IS_INST) ? '-' : '+',		\
+		  (CLASS_NAME), (SEL_NAME));				\
+     } while (0)
+
+/* Wrap new method names in quotes so the assembler doesn't gag.
+   Make Objective-C internal symbols local. */
+
+#undef ASM_OUTPUT_LABELREF
+#define ASM_OUTPUT_LABELREF(FILE,NAME)	\
+  do { if (NAME[0] == '+' || NAME[0] == '-') fprintf (FILE, "\"%s\"", NAME); \
+       else if (!strncmp (NAME, "_OBJC_", 6)) fprintf (FILE, "L%s", NAME);   \
+       else fprintf (FILE, "_%s", NAME); } while (0)
+
+#undef STACK_BOUNDARY
+/* Boundary (in *bits*) on which stack pointer should be aligned.  */
+#define STACK_BOUNDARY 32
+
+/* These compiler options take n arguments.  */
+
+#define WORD_SWITCH_TAKES_ARG(STR)	 	\
+  (!strcmp (STR, "Ttext") ? 1 :			\
+   !strcmp (STR, "Tdata") ? 1 :			\
+   !strcmp (STR, "include") ? 1 :		\
+   !strcmp (STR, "imacros") ? 1 :		\
+   !strcmp (STR, "segalign") ? 1 :		\
+   !strcmp (STR, "seg1addr") ? 1 :		\
+   !strcmp (STR, "segaddr") ? 2 :		\
+   !strcmp (STR, "sectobjectsymbols") ? 2 :	\
+   !strcmp (STR, "segprot") ? 3 :		\
+   !strcmp (STR, "sectcreate") ? 3 :		\
+   !strcmp (STR, "sectalign") ? 3 :		\
+   !strcmp (STR, "segcreate") ? 3 :		\
+   !strcmp (STR, "sectorder") ? 3 :		\
+   0)
+
+/* Names to predefine in the preprocessor for this target machine.  */
+
+#define CPP_PREDEFINES "-Dmc68000 -Dm68k -DNeXT -Dunix -D__MACH__"
+
+/* Machine dependent ccp options.  */
+
+#define CPP_SPEC "%{bsd:-D__STRICT_BSD__}"
+
+/* Machine dependent ld options.  */
+
+#define LINK_SPEC "%{Z} %{M} \
+%{execute*} %{object*} %{preload*} %{fvmlib*} \
+%{segalign*} %{seg1addr*} %{segaddr*} %{segprot*} \
+%{seglinkedit*} %{noseglinkedit*} \
+%{sectcreate*} %{sectalign*} %{sectobjectsymbols}\
+%{segcreate*} %{Mach*} %{whyload} %{w} \
+%{sectorder*} %{whatsloaded}"
+
+/* Machine dependent libraries.  */
+
+#define LIB_SPEC "%{!p:%{!pg:-lsys_s}} %{pg:-lsys_p}"
+ 
+/* We specify crt0.o as -lcrt0.o so that ld will search the library path. */
+#define STARTFILE_SPEC  \
+  "%{pg:-lgcrt0.o}%{!pg: \
+     %{p:%e-p profiling is no longer supported.  Use -pg instead.} \
+     %{!p:-lcrt0.o}}"
+
+/* Every structure or union's size must be a multiple of 2 bytes.
+   (Why isn't this in m68k.h?)  */
+
+#define STRUCTURE_SIZE_BOUNDARY 16
+
+/* Why not? */
+
+#define DOLLARS_IN_IDENTIFIERS 2
+
+/* Allow #sscs (but don't do anything). */
+
+#define SCCS_DIRECTIVE
+
+/* We use Dbx symbol format.  */
+
+#define DBX_DEBUGGING_INFO
+
+/* This saves a fair amount of space. */
+
+#define DBX_CONTIN_LENGTH 0
+
+/* These screw up NeXT's gdb at the moment, so don't use them. */
+
+#define DBX_OUTPUT_MAIN_SOURCE_DIRECTORY(FILE, FILENAME)
+
+/* gdb needs a null N_SO at the end of each file for scattered loading. */
+
+#define DBX_OUTPUT_MAIN_SOURCE_FILE_END(FILE, FILENAME)			\
+  fprintf (FILE,							\
+	   "\t.text\n\t.stabs \"%s\",%d,0,0,Letext\nLetext:\n",		\
+	   "" , N_SO)
+
+/* Don't use .gcc_compiled symbols to communicate with GDB;
+   They interfere with numerically sorted symbol lists. */
+
+#define ASM_IDENTIFY_GCC(asm_out_file)
+
+/* This is how to output an assembler line defining a `double' constant.  */
+
+#undef ASM_OUTPUT_DOUBLE
+#define ASM_OUTPUT_DOUBLE(FILE,VALUE)					\
+  (REAL_VALUE_ISINF ((VALUE))						\
+   ? fprintf (FILE, "\t.double 0r%s99e999\n", ((VALUE) > 0 ? "" : "-")) \
+   : fprintf (FILE, "\t.double 0r%.20e\n", (VALUE)))
+
+/* This is how to output an assembler line defining a `float' constant.  */
+
+#undef ASM_OUTPUT_FLOAT
+#define ASM_OUTPUT_FLOAT(FILE,VALUE)					\
+  (REAL_VALUE_ISINF ((VALUE))						\
+   ? fprintf (FILE, "\t.single 0r%s99e999\n", ((VALUE) > 0 ? "" : "-")) \
+   : fprintf (FILE, "\t.single 0r%.20e\n", (VALUE)))
+
+#undef ASM_OUTPUT_FLOAT_OPERAND
+#define ASM_OUTPUT_FLOAT_OPERAND(FILE,VALUE)				\
+  (REAL_VALUE_ISINF ((VALUE))						\
+   ? fprintf (FILE, "#0r%s99e999", ((VALUE) > 0 ? "" : "-")) \
+   : fprintf (FILE, "#0r%.9g", (VALUE)))
+
+#undef ASM_OUTPUT_DOUBLE_OPERAND
+#define ASM_OUTPUT_DOUBLE_OPERAND(FILE,VALUE)				\
+  (REAL_VALUE_ISINF ((VALUE))						\
+   ? fprintf (FILE, "#0r%s99e999", ((VALUE) > 0 ? "" : "-")) \
+   : fprintf (FILE, "#0r%.20g", (VALUE)))
+
+#define ASM_OUTPUT_CONSTRUCTOR(FILE,NAME)	\
+  do { constructor_section ();			\
+       ASM_OUTPUT_ALIGN (FILE, 1);		\
+       fprintf (FILE, "\t.long ");		\
+       assemble_name (FILE, NAME);		\
+       fprintf (FILE, "\n"); } while (0)
+
+#define ASM_OUTPUT_DESTRUCTOR(FILE,NAME)	\
+  do { destructor_section ();			\
+       ASM_OUTPUT_ALIGN (FILE, 1);		\
+       fprintf (FILE, "\t.long ");		\
+       assemble_name (FILE, NAME);		\
+       fprintf (FILE, "\n"); } while (0)
+
+/* How to parse #pragma's */
+
+#define HANDLE_PRAGMA(finput) handle_pragma (finput)
+
+/* Create new Mach-O sections. */
+
+#define SECTION_FUNCTION(FUNCTION, SECTION, DIRECTIVE, WAS_TEXT)	\
+void									\
+FUNCTION ()								\
+{									\
+  extern void text_section ();					 	\
+  extern int flag_no_mach_text_sections;		 	      	\
+  									\
+  if (WAS_TEXT && flag_no_mach_text_sections)       			\
+    text_section ();							\
+  else if (in_section != SECTION)					\
+    {									\
+      fprintf (asm_out_file, "%s\n", DIRECTIVE);			\
+      in_section = SECTION;						\
+    }									\
+}									\
+
+#define EXTRA_SECTIONS					\
+  in_const, in_cstring, in_literal4, in_literal8,	\
+  in_constructor, in_destructor,			\
+  in_objc_class, in_objc_meta_class, in_objc_category,	\
+  in_objc_class_vars, in_objc_instance_vars,		\
+  in_objc_cls_meth, in_objc_inst_meth,			\
+  in_objc_cat_cls_meth, in_objc_cat_inst_meth,		\
+  in_objc_selector_strs, in_objc_selector_refs,		\
+  in_objc_symbols, in_objc_module_info
+
+#define EXTRA_SECTION_FUNCTIONS			\
+SECTION_FUNCTION (const_section,		\
+		  in_const,			\
+		  ".const", 1)			\
+SECTION_FUNCTION (cstring_section,		\
+		  in_cstring,			\
+		  ".cstring", 1)		\
+SECTION_FUNCTION (literal4_section,		\
+		  in_literal4,			\
+		  ".literal4", 1)		\
+SECTION_FUNCTION (literal8_section,		\
+		  in_literal8,			\
+		  ".literal8", 1)		\
+SECTION_FUNCTION (constructor_section,		\
+		  in_constructor,		\
+		  ".constructor", 0)		\
+SECTION_FUNCTION (destructor_section,		\
+		  in_destructor,		\
+		  ".destructor", 0)		\
+SECTION_FUNCTION (objc_class_section,		\
+		  in_objc_class,		\
+		  ".objc_class", 0)		\
+SECTION_FUNCTION (objc_meta_class_section,	\
+		  in_objc_meta_class,		\
+		  ".objc_meta_class", 0)	\
+SECTION_FUNCTION (objc_category_section,	\
+		  in_objc_category,		\
+		".objc_category", 0)		\
+SECTION_FUNCTION (objc_class_vars_section,	\
+		  in_objc_class_vars,		\
+		  ".objc_class_vars", 0)	\
+SECTION_FUNCTION (objc_instance_vars_section,	\
+		  in_objc_instance_vars,	\
+		  ".objc_instance_vars", 0)	\
+SECTION_FUNCTION (objc_cls_meth_section,	\
+		  in_objc_cls_meth,		\
+		  ".objc_cls_meth", 0)		\
+SECTION_FUNCTION (objc_inst_meth_section,	\
+		  in_objc_inst_meth,		\
+		  ".objc_inst_meth", 0)		\
+SECTION_FUNCTION (objc_cat_cls_meth_section,	\
+		  in_objc_cat_cls_meth,		\
+		  ".objc_cat_cls_meth", 0)	\
+SECTION_FUNCTION (objc_cat_inst_meth_section,	\
+		  in_objc_cat_inst_meth,	\
+		  ".objc_cat_inst_meth", 0)	\
+SECTION_FUNCTION (objc_selector_strs_section,	\
+		  in_objc_selector_strs,	\
+		  ".objc_selector_strs", 0)	\
+SECTION_FUNCTION (objc_selector_refs_section,	\
+		  in_objc_selector_refs,	\
+		  ".objc_selector_refs", 0)	\
+SECTION_FUNCTION (objc_symbols_section,		\
+		  in_objc_symbols,		\
+		  ".objc_symbols", 0)		\
+SECTION_FUNCTION (objc_module_info_section,	\
+		  in_objc_module_info,		\
+		  ".objc_module_info", 0)
+
+#define READONLY_DATA_SECTION const_section
+
+#define SELECT_SECTION(exp,reloc)				\
+  do								\
+    {								\
+      if (TREE_CODE (exp) == STRING_CST)			\
+	{							\
+	  if (flag_writable_strings)				\
+	    data_section ();					\
+	  else if (TREE_STRING_LENGTH (exp) !=			\
+		   strlen (TREE_STRING_POINTER (exp)) + 1)	\
+	    readonly_data_section ();				\
+	  else							\
+	    cstring_section ();					\
+	}							\
+      else if (TREE_CODE (exp) == INTEGER_CST			\
+	       || TREE_CODE (exp) == REAL_CST)			\
+        {							\
+	  tree size = TYPE_SIZE (TREE_TYPE (exp));		\
+	  							\
+	  if (TREE_CODE (size) == INTEGER_CST &&		\
+	      TREE_INT_CST_LOW (size) == 4 &&			\
+	      TREE_INT_CST_HIGH (size) == 0)			\
+	    literal4_section ();				\
+	  else if (TREE_CODE (size) == INTEGER_CST &&		\
+	      TREE_INT_CST_LOW (size) == 8 &&			\
+	      TREE_INT_CST_HIGH (size) == 0)			\
+	    literal8_section ();				\
+	  else							\
+	    readonly_data_section ();				\
+	}							\
+      else if ((TREE_READONLY (exp) || TREE_CONSTANT (exp))	\
+	       && !TREE_SIDE_EFFECTS (exp))				\
+	readonly_data_section ();					\
+      else if (TREE_CODE (exp) == VAR_DECL &&				\
+	       DECL_NAME (exp) &&					\
+	       TREE_CODE (DECL_NAME (exp)) == IDENTIFIER_NODE &&	\
+	       IDENTIFIER_POINTER (DECL_NAME (exp)) &&			\
+	       !strncmp (IDENTIFIER_POINTER (DECL_NAME (exp)), "_OBJC_", 6)) \
+	{								\
+	  const char *name = IDENTIFIER_POINTER (DECL_NAME (exp));	\
+	  								\
+	  if (!strncmp (name, "_OBJC_CLASS_METHODS_", 20))		\
+	    objc_cls_meth_section ();					\
+	  else if (!strncmp (name, "_OBJC_INSTANCE_METHODS_", 23))	\
+	    objc_inst_meth_section ();					\
+	  else if (!strncmp (name, "_OBJC_CATEGORY_CLASS_METHODS_", 20)) \
+	    objc_cat_cls_meth_section ();				\
+	  else if (!strncmp (name, "_OBJC_CATEGORY_INSTANCE_METHODS_", 23)) \
+	    objc_cat_inst_meth_section ();				\
+	  else if (!strncmp (name, "_OBJC_CLASS_VARIABLES_", 22))	\
+	    objc_class_vars_section ();					\
+	  else if (!strncmp (name, "_OBJC_INSTANCE_VARIABLES_", 25))	\
+	    objc_instance_vars_section ();				\
+	  else if (!strncmp (name, "_OBJC_CLASS_", 12))			\
+	    objc_class_section ();					\
+	  else if (!strncmp (name, "_OBJC_METACLASS_", 16))		\
+	    objc_meta_class_section ();					\
+	  else if (!strncmp (name, "_OBJC_CATEGORY_", 15))		\
+	    objc_category_section ();					\
+	  else if (!strncmp (name, "_OBJC_STRINGS", 13))		\
+	    objc_selector_strs_section ();				\
+	  else if (!strncmp (name, "_OBJC_SELECTOR_REFERENCES", 25))	\
+	    objc_selector_refs_section ();				\
+	  else if (!strncmp (name, "_OBJC_SYMBOLS", 13))		\
+	    objc_symbols_section ();					\
+	  else if (!strncmp (name, "_OBJC_MODULES", 13))		\
+	    objc_module_info_section ();				\
+	  else								\
+	    data_section ();						\
+	}								\
+      else								\
+        data_section ();						\
+    }									\
+  while (0)
+
+/* Force the assembler to create all the Objective-C sections,
+    so that their order is guaranteed. */
+  
+#define OBJC_PROLOGUE					\
+  do {							\
+	extern void objc_class_section ();		\
+	extern void objc_meta_class_section ();		\
+	extern void objc_cat_cls_meth_section ();	\
+	extern void objc_cat_inst_meth_section ();	\
+	extern void objc_cls_meth_section ();		\
+	extern void objc_inst_meth_section ();		\
+	extern void objc_selector_refs_section ();	\
+	extern void objc_symbols_section ();		\
+	extern void objc_category_section ();		\
+	extern void objc_class_vars_section ();		\
+	extern void objc_instance_vars_section ();	\
+	extern void objc_module_info_section ();	\
+	extern void objc_selector_strs_section ();	\
+							\
+	objc_class_section ();		\
+	objc_meta_class_section ();	\
+	objc_cat_cls_meth_section ();	\
+	objc_cat_inst_meth_section ();	\
+	objc_cls_meth_section ();	\
+	objc_inst_meth_section ();	\
+	objc_selector_refs_section ();	\
+	objc_symbols_section ();	\
+	objc_category_section ();	\
+	objc_class_vars_section ();	\
+	objc_instance_vars_section ();	\
+	objc_module_info_section ();	\
+	objc_selector_strs_section ();	\
+     } while (0)
+
+/* We do not define JUMP_TABLES_IN_TEXT_SECTION, since we wish to keep
+   the text section pure.  There is no point in addressing the jump
+   tables using pc relative addressing, since they are not in the text
+   section, so we undefine CASE_VECTOR_PC_RELATIVE.  This also
+   causes the compiler to use absolute addresses in the jump table,
+   so we redefine CASE_VECTOR_MODE to be SImode. */
+
+#undef CASE_VECTOR_MODE
+#define CASE_VECTOR_MODE SImode
+
+#undef CASE_VECTOR_PC_RELATIVE
+
+/* Don't treat addresses involving labels differently from symbol names.
+   Previsouly, references to labels generated pc-relative addressing modes
+   while references to symbol names generated absolute addressing modes.  */
+
+#undef GO_IF_INDEXABLE_BASE(X, ADDR)
+#define GO_IF_INDEXABLE_BASE(X, ADDR)	\
+{ if (GET_CODE (X) == REG && REG_OK_FOR_BASE_P (X)) goto ADDR; }
+
+#define ALIGN_ASM_OP		"\t.align"
+
+#undef ASM_OUTPUT_ALIGN
+#define ASM_OUTPUT_ALIGN(FILE,LOG)	\
+  if ((LOG) != 0)			\
+    fprintf (FILE, "%s %d\n", ALIGN_ASM_OP, (LOG))
+
+/* The maximum alignment which the object file format can support.
+   For NeXT's Mach-O format, this is 2^15.  */
+
+#define MAX_OFILE_ALIGNMENT 0x8000