aboutsummaryrefslogtreecommitdiff
path: root/gcc/d/runtime.cc
diff options
context:
space:
mode:
authorIain Buclaw <ibuclaw@gcc.gnu.org>2018-10-28 19:51:47 +0000
committerIain Buclaw <ibuclaw@gcc.gnu.org>2018-10-28 19:51:47 +0000
commitb4c522fabd0df7be08882d2207df8b2765026110 (patch)
treeb5ffc312b0a441c1ba24323152aec463fdbe5e9f /gcc/d/runtime.cc
parent01ce9e31a02c8039d88e90f983735104417bf034 (diff)
downloadgcc-b4c522fabd0df7be08882d2207df8b2765026110.zip
gcc-b4c522fabd0df7be08882d2207df8b2765026110.tar.gz
gcc-b4c522fabd0df7be08882d2207df8b2765026110.tar.bz2
Add D front-end, libphobos library, and D2 testsuite.
ChangeLog: * Makefile.def (target_modules): Add libphobos. (flags_to_pass): Add GDC, GDCFLAGS, GDC_FOR_TARGET and GDCFLAGS_FOR_TARGET. (dependencies): Make libphobos depend on libatomic, libbacktrace configure, and zlib configure. (language): Add language d. * Makefile.in: Rebuild. * Makefile.tpl (BUILD_EXPORTS): Add GDC and GDCFLAGS. (HOST_EXPORTS): Add GDC. (POSTSTAGE1_HOST_EXPORTS): Add GDC and GDC_FOR_BUILD. (BASE_TARGET_EXPORTS): Add GDC. (GDC_FOR_BUILD, GDC, GDCFLAGS): New variables. (GDC_FOR_TARGET, GDC_FLAGS_FOR_TARGET): New variables. (EXTRA_HOST_FLAGS): Add GDC. (STAGE1_FLAGS_TO_PASS): Add GDC. (EXTRA_TARGET_FLAGS): Add GDC and GDCFLAGS. * config-ml.in: Treat GDC and GDCFLAGS like other compiler/flag environment variables. * configure: Rebuild. * configure.ac: Add target-libphobos to target_libraries. Set and substitute GDC_FOR_BUILD and GDC_FOR_TARGET. config/ChangeLog: * multi.m4: Set GDC. gcc/ChangeLog: * Makefile.in (tm_d_file_list, tm_d_include_list): New variables. (TM_D_H, D_TARGET_DEF, D_TARGET_H, D_TARGET_OBJS): New variables. (tm_d.h, cs-tm_d.h, default-d.o): New rules. (d/d-target-hooks-def.h, s-d-target-hooks-def-h): New rules. (s-tm-texi): Also check timestamp on d-target.def. (generated_files): Add TM_D_H and d-target-hooks-def.h. (build/genhooks.o): Also depend on D_TARGET_DEF. * config.gcc (tm_d_file, d_target_objs, target_has_targetdm): New variables. * config/aarch64/aarch64-d.c: New file. * config/aarch64/aarch64-linux.h (GNU_USER_TARGET_D_CRITSEC_SIZE): Define. * config/aarch64/aarch64-protos.h (aarch64_d_target_versions): New prototype. * config/aarch64/aarch64.h (TARGET_D_CPU_VERSIONS): Define. * config/aarch64/t-aarch64 (aarch64-d.o): New rule. * config/arm/arm-d.c: New file. * config/arm/arm-protos.h (arm_d_target_versions): New prototype. * config/arm/arm.h (TARGET_D_CPU_VERSIONS): Define. * config/arm/linux-eabi.h (EXTRA_TARGET_D_OS_VERSIONS): Define. * config/arm/t-arm (arm-d.o): New rule. * config/default-d.c: New file. * config/glibc-d.c: New file. * config/gnu.h (GNU_USER_TARGET_D_OS_VERSIONS): Define. * config/i386/i386-d.c: New file. * config/i386/i386-protos.h (ix86_d_target_versions): New prototype. * config/i386/i386.h (TARGET_D_CPU_VERSIONS): Define. * config/i386/linux-common.h (EXTRA_TARGET_D_OS_VERSIONS): Define. (GNU_USER_TARGET_D_CRITSEC_SIZE): Define. * config/i386/t-i386 (i386-d.o): New rule. * config/kfreebsd-gnu.h (GNU_USER_TARGET_D_OS_VERSIONS): Define. * config/kopensolaris-gnu.h (GNU_USER_TARGET_D_OS_VERSIONS): Define. * config/linux-android.h (ANDROID_TARGET_D_OS_VERSIONS): Define. * config/linux.h (GNU_USER_TARGET_D_OS_VERSIONS): Define. * config/mips/linux-common.h (EXTRA_TARGET_D_OS_VERSIONS): Define. * config/mips/mips-d.c: New file. * config/mips/mips-protos.h (mips_d_target_versions): New prototype. * config/mips/mips.h (TARGET_D_CPU_VERSIONS): Define. * config/mips/t-mips (mips-d.o): New rule. * config/powerpcspe/linux.h (GNU_USER_TARGET_D_OS_VERSIONS): Define. * config/powerpcspe/linux64.h (GNU_USER_TARGET_D_OS_VERSIONS): Define. * config/powerpcspe/powerpcspe-d.c: New file. * config/powerpcspe/powerpcspe-protos.h (rs6000_d_target_versions): New prototype. * config/powerpcspe/powerpcspe.c (rs6000_output_function_epilogue): Support GNU D by using 0 as the language type. * config/powerpcspe/powerpcspe.h (TARGET_D_CPU_VERSIONS): Define. * config/powerpcspe/t-powerpcspe (powerpcspe-d.o): New rule. * config/riscv/riscv-d.c: New file. * config/riscv/riscv-protos.h (riscv_d_target_versions): New prototype. * config/riscv/riscv.h (TARGET_D_CPU_VERSIONS): Define. * config/riscv/t-riscv (riscv-d.o): New rule. * config/rs6000/linux.h (GNU_USER_TARGET_D_OS_VERSIONS): Define. * config/rs6000/linux64.h (GNU_USER_TARGET_D_OS_VERSIONS): Define. * config/rs6000/rs6000-d.c: New file. * config/rs6000/rs6000-protos.h (rs6000_d_target_versions): New prototype. * config/rs6000/rs6000.c (rs6000_output_function_epilogue): Support GNU D by using 0 as the language type. * config/rs6000/rs6000.h (TARGET_D_CPU_VERSIONS): Define. * config/rs6000/t-rs6000 (rs6000-d.o): New rule. * config/s390/s390-d.c: New file. * config/s390/s390-protos.h (s390_d_target_versions): New prototype. * config/s390/s390.h (TARGET_D_CPU_VERSIONS): Define. * config/s390/t-s390 (s390-d.o): New rule. * config/sparc/sparc-d.c: New file. * config/sparc/sparc-protos.h (sparc_d_target_versions): New prototype. * config/sparc/sparc.h (TARGET_D_CPU_VERSIONS): Define. * config/sparc/t-sparc (sparc-d.o): New rule. * config/t-glibc (glibc-d.o): New rule. * configure: Regenerated. * configure.ac (tm_d_file): New variable. (tm_d_file_list, tm_d_include_list, d_target_objs): Add substitutes. * doc/contrib.texi (Contributors): Add self for the D frontend. * doc/frontends.texi (G++ and GCC): Mention D as a supported language. * doc/install.texi (Configuration): Mention libphobos as an option for --enable-shared. Mention d as an option for --enable-languages. (Testing): Mention check-d as a target. * doc/invoke.texi (Overall Options): Mention .d, .dd, and .di as file name suffixes. Mention d as a -x option. * doc/sourcebuild.texi (Top Level): Mention libphobos. * doc/standards.texi (Standards): Add section on D language. * doc/tm.texi: Regenerated. * doc/tm.texi.in: Add @node for D language and ABI, and @hook for TARGET_CPU_VERSIONS, TARGET_D_OS_VERSIONS, and TARGET_D_CRITSEC_SIZE. * dwarf2out.c (is_dlang): New function. (gen_compile_unit_die): Use DW_LANG_D for D. (declare_in_namespace): Return module die for D, instead of adding extra declarations into the namespace. (gen_namespace_die): Generate DW_TAG_module for D. (gen_decl_die): Handle CONST_DECLSs for D. (dwarf2out_decl): Likewise. (prune_unused_types_walk_local_classes): Handle DW_tag_interface_type. (prune_unused_types_walk): Handle DW_tag_interface_type same as other kinds of aggregates. * gcc.c (default_compilers): Add entries for .d, .dd and .di. * genhooks.c: Include d/d-target.def. gcc/po/ChangeLog: * EXCLUDES: Add sources from d/dmd. gcc/testsuite/ChangeLog: * gcc.misc-tests/help.exp: Add D to option descriptions check. * gdc.dg/asan/asan.exp: New file. * gdc.dg/asan/gdc272.d: New test. * gdc.dg/compilable.d: New test. * gdc.dg/dg.exp: New file. * gdc.dg/gdc254.d: New test. * gdc.dg/gdc260.d: New test. * gdc.dg/gdc270a.d: New test. * gdc.dg/gdc270b.d: New test. * gdc.dg/gdc282.d: New test. * gdc.dg/gdc283.d: New test. * gdc.dg/imports/gdc170.d: New test. * gdc.dg/imports/gdc231.d: New test. * gdc.dg/imports/gdc239.d: New test. * gdc.dg/imports/gdc241a.d: New test. * gdc.dg/imports/gdc241b.d: New test. * gdc.dg/imports/gdc251a.d: New test. * gdc.dg/imports/gdc251b.d: New test. * gdc.dg/imports/gdc253.d: New test. * gdc.dg/imports/gdc254a.d: New test. * gdc.dg/imports/gdc256.d: New test. * gdc.dg/imports/gdc27.d: New test. * gdc.dg/imports/gdcpkg256/package.d: New test. * gdc.dg/imports/runnable.d: New test. * gdc.dg/link.d: New test. * gdc.dg/lto/lto.exp: New file. * gdc.dg/lto/ltotests_0.d: New test. * gdc.dg/lto/ltotests_1.d: New test. * gdc.dg/runnable.d: New test. * gdc.dg/simd.d: New test. * gdc.test/gdc-test.exp: New file. * lib/gdc-dg.exp: New file. * lib/gdc.exp: New file. libphobos/ChangeLog: * Makefile.am: New file. * Makefile.in: New file. * acinclude.m4: New file. * aclocal.m4: New file. * config.h.in: New file. * configure: New file. * configure.ac: New file. * d_rules.am: New file. * libdruntime/Makefile.am: New file. * libdruntime/Makefile.in: New file. * libdruntime/__entrypoint.di: New file. * libdruntime/__main.di: New file. * libdruntime/gcc/attribute.d: New file. * libdruntime/gcc/backtrace.d: New file. * libdruntime/gcc/builtins.d: New file. * libdruntime/gcc/config.d.in: New file. * libdruntime/gcc/deh.d: New file. * libdruntime/gcc/libbacktrace.d.in: New file. * libdruntime/gcc/unwind/arm.d: New file. * libdruntime/gcc/unwind/arm_common.d: New file. * libdruntime/gcc/unwind/c6x.d: New file. * libdruntime/gcc/unwind/generic.d: New file. * libdruntime/gcc/unwind/package.d: New file. * libdruntime/gcc/unwind/pe.d: New file. * m4/autoconf.m4: New file. * m4/druntime.m4: New file. * m4/druntime/cpu.m4: New file. * m4/druntime/libraries.m4: New file. * m4/druntime/os.m4: New file. * m4/gcc_support.m4: New file. * m4/gdc.m4: New file. * m4/libtool.m4: New file. * src/Makefile.am: New file. * src/Makefile.in: New file. * src/libgphobos.spec.in: New file. * testsuite/Makefile.am: New file. * testsuite/Makefile.in: New file. * testsuite/config/default.exp: New file. * testsuite/lib/libphobos-dg.exp: New file. * testsuite/lib/libphobos.exp: New file. * testsuite/testsuite_flags.in: New file. From-SVN: r265573
Diffstat (limited to 'gcc/d/runtime.cc')
-rw-r--r--gcc/d/runtime.cc315
1 files changed, 315 insertions, 0 deletions
diff --git a/gcc/d/runtime.cc b/gcc/d/runtime.cc
new file mode 100644
index 0000000..7f1e910
--- /dev/null
+++ b/gcc/d/runtime.cc
@@ -0,0 +1,315 @@
+/* runtime.cc -- D runtime functions called by generated code.
+ Copyright (C) 2006-2018 Free Software Foundation, Inc.
+
+GCC 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 3, or (at your option)
+any later version.
+
+GCC 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 GCC; see the file COPYING3. If not see
+<http://www.gnu.org/licenses/>. */
+
+#include "config.h"
+#include "system.h"
+#include "coretypes.h"
+
+#include "dmd/aggregate.h"
+#include "dmd/mtype.h"
+
+#include "tree.h"
+#include "fold-const.h"
+#include "stringpool.h"
+
+#include "d-tree.h"
+
+
+/* During the codegen pass, the compiler may do lowering of expressions to call
+ various runtime library functions. Most are implemented in the `rt' package.
+ We represent them in the frontend here, however there's no guarantee that
+ the compiler implementation actually matches the actual implementation. */
+
+enum libcall_type
+{
+ LCT_VOID, /* void */
+ LCT_BYTE, /* byte */
+ LCT_INT, /* int */
+ LCT_UINT, /* uint */
+ LCT_BOOL, /* bool */
+ LCT_DCHAR, /* dchar */
+ LCT_VOIDPTR, /* void* */
+ LCT_STRING, /* string */
+ LCT_WSTRING, /* wstring */
+ LCT_DSTRING, /* dstring */
+ LCT_SIZE_T, /* size_t */
+ LCT_ASSOCARRAY, /* void[void] */
+ LCT_ARRAY_VOID, /* void[] */
+ LCT_ARRAY_SIZE_T, /* size_t[] */
+ LCT_ARRAY_BYTE, /* byte[] */
+ LCT_ARRAY_STRING, /* string[] */
+ LCT_ARRAY_WSTRING, /* wstring[] */
+ LCT_ARRAY_DSTRING, /* dstring[] */
+ LCT_ARRAYARRAY_BYTE, /* byte[][] */
+ LCT_POINTER_ASSOCARRAY, /* void[void]* */
+ LCT_POINTER_VOIDPTR, /* void** */
+ LCT_ARRAYPTR_VOID, /* void[]* */
+ LCT_ARRAYPTR_BYTE, /* byte[]* */
+ LCT_TYPEINFO, /* TypeInfo */
+ LCT_CLASSINFO, /* TypeInfo_Class */
+ LCT_OBJECT, /* Object */
+ LCT_CONST_TYPEINFO, /* const(TypeInfo) */
+ LCT_CONST_CLASSINFO, /* const(ClassInfo) */
+ LCT_END
+};
+
+/* An array of all types that are used by the runtime functions we need. */
+
+static Type *libcall_types[LCT_END];
+
+/* Our internal list of library functions. */
+
+static tree libcall_decls[LIBCALL_LAST];
+
+
+/* Return the frontend Type that is described by TYPE. Most are readily cached
+ by the frontend proper, and likewise the use of pointerTo(), constOf(), and
+ arrayOf() will return cached types if they have been requested before. */
+
+static Type *
+get_libcall_type (libcall_type type)
+{
+ if (libcall_types[type])
+ return libcall_types[type];
+
+ switch (type)
+ {
+ case LCT_VOID:
+ libcall_types[type] = Type::tvoid;
+ break;
+
+ case LCT_BYTE:
+ libcall_types[type] = Type::tint8;
+ break;
+
+ case LCT_INT:
+ libcall_types[type] = Type::tint32;
+ break;
+
+ case LCT_UINT:
+ libcall_types[type] = Type::tuns32;
+ break;
+
+ case LCT_BOOL:
+ libcall_types[type] = Type::tbool;
+ break;
+
+ case LCT_DCHAR:
+ libcall_types[type] = Type::tdchar;
+ break;
+
+ case LCT_VOIDPTR:
+ libcall_types[type] = Type::tvoidptr;
+ break;
+
+ case LCT_STRING:
+ libcall_types[type] = Type::tstring;
+ break;
+
+ case LCT_WSTRING:
+ libcall_types[type] = Type::twstring;
+ break;
+
+ case LCT_DSTRING:
+ libcall_types[type] = Type::tdstring;
+ break;
+
+ case LCT_SIZE_T:
+ libcall_types[type] = Type::tsize_t;
+ break;
+
+ case LCT_ASSOCARRAY:
+ libcall_types[type] = TypeAArray::create (Type::tvoid, Type::tvoid);
+ break;
+
+ case LCT_TYPEINFO:
+ libcall_types[type] = Type::dtypeinfo->type;
+ break;
+
+ case LCT_CLASSINFO:
+ libcall_types[type] = Type::typeinfoclass->type;
+ break;
+
+ case LCT_OBJECT:
+ libcall_types[type] = get_object_type ();
+ break;
+
+ case LCT_CONST_TYPEINFO:
+ libcall_types[type] = Type::dtypeinfo->type->constOf ();
+ break;
+
+ case LCT_CONST_CLASSINFO:
+ libcall_types[type] = Type::typeinfoclass->type->constOf ();
+ break;
+
+ case LCT_ARRAY_VOID:
+ libcall_types[type] = Type::tvoid->arrayOf ();
+ break;
+
+ case LCT_ARRAY_SIZE_T:
+ libcall_types[type] = Type::tsize_t->arrayOf ();
+ break;
+
+ case LCT_ARRAY_BYTE:
+ libcall_types[type] = Type::tint8->arrayOf ();
+ break;
+
+ case LCT_ARRAY_STRING:
+ libcall_types[type] = Type::tstring->arrayOf ();
+ break;
+
+ case LCT_ARRAY_WSTRING:
+ libcall_types[type] = Type::twstring->arrayOf ();
+ break;
+
+ case LCT_ARRAY_DSTRING:
+ libcall_types[type] = Type::tdstring->arrayOf ();
+ break;
+
+ case LCT_ARRAYARRAY_BYTE:
+ libcall_types[type] = Type::tint8->arrayOf ()->arrayOf ();
+ break;
+
+ case LCT_POINTER_ASSOCARRAY:
+ libcall_types[type] = get_libcall_type (LCT_ASSOCARRAY)->pointerTo ();
+ break;
+
+ case LCT_POINTER_VOIDPTR:
+ libcall_types[type] = Type::tvoidptr->arrayOf ();
+ break;
+
+ case LCT_ARRAYPTR_VOID:
+ libcall_types[type] = Type::tvoid->arrayOf ()->pointerTo ();
+ break;
+
+ case LCT_ARRAYPTR_BYTE:
+ libcall_types[type] = Type::tint8->arrayOf ()->pointerTo ();
+ break;
+
+ default:
+ gcc_unreachable ();
+ }
+
+ return libcall_types[type];
+}
+
+/* Builds and returns function declaration named NAME. The RETURN_TYPE is
+ the type returned, FLAGS are the expression call flags, and NPARAMS is
+ the number of arguments, the types of which are provided in `...'. */
+
+static tree
+build_libcall_decl (const char *name, libcall_type return_type,
+ int flags, int nparams, ...)
+{
+ tree *args = XALLOCAVEC (tree, nparams);
+ bool varargs = false;
+ tree fntype;
+
+ /* Add parameter types, using 'void' as the last parameter type
+ to mean this function accepts a variable list of arguments. */
+ va_list ap;
+ va_start (ap, nparams);
+
+ for (int i = 0; i < nparams; i++)
+ {
+ libcall_type ptype = (libcall_type) va_arg (ap, int);
+ Type *type = get_libcall_type (ptype);
+
+ if (type == Type::tvoid)
+ {
+ varargs = true;
+ nparams = i;
+ }
+ else
+ args[i] = build_ctype (type);
+ }
+
+ va_end (ap);
+
+ /* Build the function. */
+ tree tret = build_ctype (get_libcall_type (return_type));
+ if (varargs)
+ fntype = build_varargs_function_type_array (tret, nparams, args);
+ else
+ fntype = build_function_type_array (tret, nparams, args);
+
+ tree decl = build_decl (UNKNOWN_LOCATION, FUNCTION_DECL,
+ get_identifier (name), fntype);
+ DECL_EXTERNAL (decl) = 1;
+ TREE_PUBLIC (decl) = 1;
+ DECL_ARTIFICIAL (decl) = 1;
+ DECL_VISIBILITY (decl) = VISIBILITY_DEFAULT;
+ DECL_VISIBILITY_SPECIFIED (decl) = 1;
+
+ /* Set any attributes on the function, such as malloc or noreturn. */
+ set_call_expr_flags (decl, flags);
+
+ return decl;
+}
+
+/* Return or create the runtime library function declaration for LIBCALL.
+ Library functions are generated as needed. This could probably be changed in
+ the future to be done in the compiler init stage, like GCC builtin trees are,
+ however we depend on run-time initialization of types whose definitions are
+ in the library such as `Object' or `TypeInfo'. */
+
+static tree
+get_libcall (libcall_fn libcall)
+{
+ if (libcall_decls[libcall])
+ return libcall_decls[libcall];
+
+ switch (libcall)
+ {
+#define DEF_D_RUNTIME(CODE, NAME, TYPE, PARAMS, FLAGS) \
+ case LIBCALL_ ## CODE: \
+ libcall_decls[libcall] = build_libcall_decl (NAME, TYPE, FLAGS, PARAMS); \
+ break;
+
+#include "runtime.def"
+
+#undef DEF_D_RUNTIME
+
+ default:
+ gcc_unreachable ();
+ }
+
+ return libcall_decls[libcall];
+}
+
+/* Generate a call to LIBCALL, returning the result as TYPE. NARGS is the
+ number of call arguments, the expressions of which are provided in `...'.
+ This does not perform conversions or promotions on the arguments. */
+
+tree
+build_libcall (libcall_fn libcall, Type *type, int nargs, ...)
+{
+ /* Build the call expression to the runtime function. */
+ tree decl = get_libcall (libcall);
+ tree *args = XALLOCAVEC (tree, nargs);
+ va_list ap;
+
+ va_start (ap, nargs);
+ for (int i = 0; i < nargs; i++)
+ args[i] = va_arg (ap, tree);
+ va_end (ap);
+
+ tree result = build_call_expr_loc_array (input_location, decl, nargs, args);
+
+ /* Assumes caller knows what it is doing. */
+ return convert (build_ctype (type), result);
+}