https://gcc.gnu.org/bugzilla/show_bug.cgi?id=79037
--- Comment #14 from ian at gcc dot gnu.org <ian at gcc dot gnu.org> --- Author: ian Date: Wed Feb 1 23:35:59 2017 New Revision: 245110 URL: https://gcc.gnu.org/viewcvs?rev=245110&root=gcc&view=rev Log: PR go/79037 Backport from mainline: compiler, runtime: align gc data for m68k The current GC requires that the gc data be aligned to at least a 4 byte boundary, because it uses the lower two bits of the address for flags (see LOOP and PRECISE in runtime/mgc0.c). As the gc data is stored as a [...]uintptr, that is normally always true. However, on m68k, that only guarantees 2 byte alignment. Fix it by forcing the alignment. The parfor code used by the current GC requires that the parfor data be aligned to at least an 8 byte boundary. The code in parfor.c verifies this. This is normally true, as the data uses uint64_t values, but, again, this must be enforced explicitly on m68k. Fixes GCC PR 79037. Change-Id: Ifdf422db7b37e88f490e54c2f6d249117d359dd6 Modified: branches/gcc-6-branch/gcc/go/gofrontend/types.cc branches/gcc-6-branch/libgo/runtime/go-unsafe-pointer.c branches/gcc-6-branch/libgo/runtime/parfor.c branches/gcc-6-branch/libgo/runtime/runtime.h