gcc/libgo
Lynn Boger 2fbed0dc6c libgo: ensure memmove, memset 8 byte atomicity on ppc64x
Go requires that pointer moves are done 8 bytes at a time,
but gccgo uses libc's memmove and memset which does not require
that, and there are some cases where an 8 byte move might be
done as 4+4.

To enforce 8 byte moves for memmove and memset, this adds a
C implementation in libgo/runtime for memmove and memset to be
used on ppc64le and ppc64. Asm implementations were considered
but discarded to avoid different implementations for different
target ISAs.

Fixes golang/go#41428

Reviewed-on: https://go-review.googlesource.com/c/gofrontend/+/294931
2021-02-25 17:01:23 -08:00
..
config Update GNU/Hurd configure support 2021-01-05 16:04:14 -07:00
go libgo: ensure memmove, memset 8 byte atomicity on ppc64x 2021-02-25 17:01:23 -08:00
misc/cgo libgo: update to Go1.16 release 2021-02-19 12:33:25 -08:00
runtime libgo: ensure memmove, memset 8 byte atomicity on ppc64x 2021-02-25 17:01:23 -08:00
testsuite libgo: update to Go1.16beta1 release 2020-12-30 15:13:24 -08:00
aclocal.m4
check-packages.txt libgo: update to Go1.16rc1 2021-01-29 11:04:55 -08:00
config.h.in libgo: update to Go1.16beta1 release 2020-12-30 15:13:24 -08:00
configure Update GNU/Hurd configure support 2021-01-05 16:04:14 -07:00
configure.ac libgo: update to Go1.16beta1 release 2020-12-30 15:13:24 -08:00
goarch.sh
godeps.sh
gotool-packages.txt libgo: update to Go1.16beta1 release 2020-12-30 15:13:24 -08:00
libgo-packages.txt libgo: update to Go1.16rc1 2021-01-29 11:04:55 -08:00
libgo.imp
LICENSE
Makefile.am libgo: ensure memmove, memset 8 byte atomicity on ppc64x 2021-02-25 17:01:23 -08:00
Makefile.in libgo: ensure memmove, memset 8 byte atomicity on ppc64x 2021-02-25 17:01:23 -08:00
match.sh libgo: update to Go1.16beta1 release 2020-12-30 15:13:24 -08:00
MERGE libgo: update to Go1.16 release 2021-02-19 12:33:25 -08:00
merge.sh libgo: update to Go1.16rc1 2021-01-29 11:04:55 -08:00
mklinknames.awk
mkrsysinfo.sh libgo: adjust sysinfo scripts for changed -fdump-go-spec 2020-12-20 20:16:50 -08:00
mkruntimeinc.sh libgo: update to Go1.16beta1 release 2020-12-30 15:13:24 -08:00
mksigtab.sh
mksysinfo.sh libgo: adjust sysinfo scripts for changed -fdump-go-spec 2020-12-20 20:16:50 -08:00
mvifdiff.sh
PATENTS
README
README.gcc
sysinfo.c libgo: adjust sysinfo scripts for changed -fdump-go-spec 2020-12-20 20:16:50 -08:00
VERSION libgo: update to Go1.16 release 2021-02-19 12:33:25 -08:00

See ../README.

This is the runtime support library for the Go programming language.
This library is intended for use with the Go frontend.

This library should not be stripped when it is installed.  Go code
relies on being able to look up file/line information, which comes
from the debugging info using the libbacktrace library.

The library has only been tested on GNU/Linux using glibc, and on
Solaris.  It should not be difficult to port to other operating
systems.

Directories:

go
  A copy of the Go library from http://golang.org/, with several
  changes for gccgo.

runtime
  Runtime functions, written in C, which are called directly by the
  compiler or by the library.

Contributing
============

To contribute patches to the files in this directory, please see
http://golang.org/doc/gccgo_contribute.html .

The master copy of these files is hosted at
http://code.google.com/p/gofrontend .  Changes to these files require
signing a Google contributor license agreement.  If you are the
copyright holder, you will need to agree to the individual contributor
license agreement at
http://code.google.com/legal/individual-cla-v1.0.html.  This agreement
can be completed online.

If your organization is the copyright holder, the organization will
need to agree to the corporate contributor license agreement at
http://code.google.com/legal/corporate-cla-v1.0.html.

If the copyright holder for your code has already completed the
agreement in connection with another Google open source project, it
does not need to be completed again.

Debugging
=========

This describes how to test libgo when built as part of gccgo.

To test a specific package, cd to the libgo build directory
(TARGET/libgo) and run `make PKG/check`.  For example, `make
bytes/check`.

To see the exact commands that it runs, including how the compiler is
invoked, run `make GOTESTFLAGS=--trace bytes/check`.  This will
display the commands if the test fails.  If the test passes, the
commands and other output will be visible in a file named
check-testlog in a subdirectory with the name of the package being
checked.  In the case of bytes/check, this will create
bytes/check-testlog.

To leave the test program behind, run `make GOTESTFLAGS=--keep
bytes/check`.  That will leave a gotestNNNN/test directory in the
libgo build directory.  In that directory you can run
`LD_LIBRARY_PATH=../../.libs ./a.out -test.short` to run the tests.
You can run specific failing tests using a -test.run option.  You can
see the tests being run with the -test.v option.  You can run the
program under a debugger such as gdb.