The following binutils patches introduce a new moxie-based target called moxiebox. Moxiebox is a VM developed by the bitcoin community to act as a secure, sandboxed execution environment for bitcoin automation.
See http://github.com/jgarzik/moxiebox for more information. I'm checking these changes in. There's a config.sub change as well that I'll submit through the regular process. Thanks, AG For gcc... 2014-07-27 Anthony Green <gr...@moxielogic.com> * config.gcc: Add moxie-*-moxiebox* configuration. * config/moxie/moxiebox.h: New file. For libgcc... 2014-07-27 Anthony Green <gr...@moxielogic.com> * config.host: Add moxiebox configuration suppport. Index: gcc/config/moxie/moxiebox.h =================================================================== --- gcc/config/moxie/moxiebox.h (revision 0) +++ gcc/config/moxie/moxiebox.h (working copy) @@ -0,0 +1,47 @@ +/* Definitions for the moxiebox. + Copyright (C) 2014 Free Software Foundation, Inc. + Contributed by Anthony Green (gr...@moxielogic.com) + +This file is part of GCC. + +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/>. */ + +/* Target OS preprocessor built-ins. */ +#define TARGET_OS_CPP_BUILTINS() \ + do \ + { \ + builtin_define_std ("moxie"); \ + builtin_define ("__moxiebox__"); \ + builtin_assert ("system=moxiebox"); \ + } \ + while (0) + +#undef LIB_SPEC +#define LIB_SPEC \ +"%{!T*:-Tmoxiebox.ld} \ + %{!nostdlib: --start-group -lsandboxrt -lc -lgcc --end-group }" + +#undef LINK_SPEC +#define LINK_SPEC "%{h*} %{v:-V} -EL -Bstatic" + +#undef ASM_SPEC +#define ASM_SPEC "-EL" + +#undef MULTILIB_DEFAULTS + +#undef SIZE_TYPE +#undef PTRDIFF_TYPE +#undef WCHAR_TYPE +#undef WCHAR_TYPE_SIZE Index: gcc/config.gcc =================================================================== --- gcc/config.gcc (revision 212980) +++ gcc/config.gcc (working copy) @@ -1168,6 +1168,12 @@ tmake_file="${tmake_file} moxie/t-moxie" tm_file="moxie/moxie.h dbxelf.h elfos.h moxie/rtems.h rtems.h newlib-stdint.h" ;; +moxie-*-moxiebox*) + gas=yes + gnu_ld=yes + tm_file="${tm_file} dbxelf.h elfos.h moxie/moxiebox.h newlib-stdint.h" + tmake_file="${tmake_file} moxie/t-moxiebox" + ;; h8300-*-rtems*) tmake_file="${tmake_file} h8300/t-h8300 h8300/t-rtems" tm_file="h8300/h8300.h dbxelf.h elfos.h h8300/elf.h h8300/rtems.h rtems.h newlib-stdint.h" Index: libgcc/config.host =================================================================== --- libgcc/config.host (revision 212980) +++ libgcc/config.host (working copy) @@ -881,9 +881,9 @@ mn10300-*-*) tmake_file=t-fdpbit ;; -moxie-*-elf | moxie-*-uclinux*) +moxie-*-elf | moxie-*-moxiebox* | moxie-*-uclinux*) tmake_file="moxie/t-moxie t-softfp-sfdf t-softfp-excl t-softfp" - extra_parts="$extra_parts crti.o crtn.o" + extra_parts="$extra_parts crti.o crtn.o crtbegin.o crtend.o" ;; moxie-*-rtems*) tmake_file="$tmake_file moxie/t-moxie t-softfp-sfdf t-softfp-excl t-softfp"