diff options
Diffstat (limited to 'go/patch/go5.patch')
-rw-r--r-- | go/patch/go5.patch | 198 |
1 files changed, 198 insertions, 0 deletions
diff --git a/go/patch/go5.patch b/go/patch/go5.patch new file mode 100644 index 00000000..fa656586 --- /dev/null +++ b/go/patch/go5.patch @@ -0,0 +1,198 @@ +misc/cgo/testcshared: add support for -target. + +--- misc/cgo/testcshared/test.bash ++++ misc/cgo/testcshared/test.bash +@@ -14,9 +14,23 @@ if [ ! -f src/libgo/libgo.go ]; then + exit 1 + fi + +-goos=$(go env GOOS) +-goarch=$(go env GOARCH) +-goroot=$(go env GOROOT) ++function target() ++ { ++ [[ -n "${target}" ]] ++ } ++ ++function go_target() ++ { ++ if target; then ++ go_${target} "$@" ++ else ++ go "$@" ++ fi ++ } ++ ++goos=$(go_target env GOOS) ++goarch=$(go_target env GOARCH) ++goroot=$(go_target env GOROOT) + if [ ! -d "$goroot" ]; then + echo 'misc/cgo/testcshared/test.bash cannnot find GOROOT' 1>&2 + echo '$GOROOT:' "$GOROOT" 1>&2 +@@ -31,8 +45,10 @@ if [ "${goos}" == "darwin" ]; then + installdir=pkg/${goos}_${goarch}_testcshared + fi + +-# Temporary directory on the android device. +-androidpath=/data/local/tmp/testcshared-$$ ++# Temporary directory on the android/chromeos device. ++if target; then ++ remotepath=$(target_tmpdir)/testcshared-$$ ++fi + + function cleanup() { + rm -f libgo.$libext libgo2.$libext libgo4.$libext libgo5.$libext +@@ -40,37 +56,33 @@ function cleanup() { + rm -f testp testp2 testp3 testp4 testp5 + rm -rf pkg "${goroot}/${installdir}" + +- if [ "$goos" == "android" ]; then +- adb shell rm -rf "$androidpath" ++ if target; then ++ target_sh "${target}" "rm -rf $remotepath" + fi + } + trap cleanup EXIT + +-if [ "$goos" == "android" ]; then +- adb shell mkdir -p "$androidpath" ++if target; then ++ target_sh "${target}" "mkdir -p $remotepath" + fi + + function run() { +- case "$goos" in +- "android") ++ if target; then + local args=$@ +- output=$(adb shell "cd ${androidpath}; $@") +- output=$(echo $output|tr -d '\r') ++ output=$(target_sh "${target}" "cd ${remotepath}; $@") + case $output in + *PASS) echo "PASS";; + *) echo "$output";; + esac +- ;; +- *) ++ else + echo $(env $@) +- ;; +- esac ++ fi + } + + function binpush() { + bin=${1} +- if [ "$goos" == "android" ]; then +- adb push "$bin" "${androidpath}/${bin}" 2>/dev/null ++ if target; then ++ target_cp "$bin" "${target}:${remotepath}/${bin}" + fi + } + +@@ -84,9 +96,9 @@ if [ "$goos" == "darwin" ]; then + fi + + # Create the header files. +-GOPATH=$(pwd) go install -buildmode=c-shared $suffix libgo ++GOPATH=$(pwd) go_target install -buildmode=c-shared $suffix libgo + +-GOPATH=$(pwd) go build -buildmode=c-shared $suffix -o libgo.$libext src/libgo/libgo.go ++GOPATH=$(pwd) go_target build -buildmode=c-shared $suffix -o libgo.$libext src/libgo/libgo.go + binpush libgo.$libext + + if [ "$goos" == "linux" ] || [ "$goos" == "android" ] ; then +@@ -96,8 +108,8 @@ if [ "$goos" == "linux" ] || [ "$goos" == "android" ] ; then + fi + fi + +-GOGCCFLAGS=$(go env GOGCCFLAGS) +-if [ "$goos" == "android" ]; then ++GOGCCFLAGS=$(go_target env GOGCCFLAGS) ++if target; then + GOGCCFLAGS="${GOGCCFLAGS} -pie" + fi + +@@ -105,7 +117,7 @@ status=0 + + # test0: exported symbols in shared lib are accessible. + # TODO(iant): using _shared here shouldn't really be necessary. +-$(go env CC) ${GOGCCFLAGS} -I ${installdir} -o testp main0.c libgo.$libext ++$(go_target env CC) ${GOGCCFLAGS} -I ${installdir} -o testp main0.c libgo.$libext + binpush testp + + output=$(run LD_LIBRARY_PATH=. ./testp) +@@ -115,7 +127,7 @@ if [ "$output" != "PASS" ]; then + fi + + # test1: shared library can be dynamically loaded and exported symbols are accessible. +-$(go env CC) ${GOGCCFLAGS} -o testp main1.c -ldl ++$(go_target env CC) ${GOGCCFLAGS} -o testp main1.c -ldl + binpush testp + output=$(run ./testp ./libgo.$libext) + if [ "$output" != "PASS" ]; then +@@ -124,13 +136,13 @@ if [ "$output" != "PASS" ]; then + fi + + # test2: tests libgo2 which does not export any functions. +-GOPATH=$(pwd) go build -buildmode=c-shared $suffix -o libgo2.$libext libgo2 ++GOPATH=$(pwd) go_target build -buildmode=c-shared $suffix -o libgo2.$libext libgo2 + binpush libgo2.$libext + linkflags="-Wl,--no-as-needed" + if [ "$goos" == "darwin" ]; then + linkflags="" + fi +-$(go env CC) ${GOGCCFLAGS} -o testp2 main2.c $linkflags libgo2.$libext ++$(go_target env CC) ${GOGCCFLAGS} -o testp2 main2.c $linkflags libgo2.$libext + binpush testp2 + output=$(run LD_LIBRARY_PATH=. ./testp2) + if [ "$output" != "PASS" ]; then +@@ -138,9 +150,9 @@ if [ "$output" != "PASS" ]; then + status=1 + fi + +-# test3: tests main.main is exported on android. +-if [ "$goos" == "android" ]; then +- $(go env CC) ${GOGCCFLAGS} -o testp3 main3.c -ldl ++# test3: tests main.main is exported on android/chromeos. ++if target; then ++ $(go_target env CC) ${GOGCCFLAGS} -o testp3 main3.c -ldl + binpush testp3 + output=$(run ./testp ./libgo.so) + if [ "$output" != "PASS" ]; then +@@ -150,14 +162,14 @@ if [ "$goos" == "android" ]; then + fi + + # test4: tests signal handlers +-GOPATH=$(pwd) go build -buildmode=c-shared $suffix -o libgo4.$libext libgo4 ++GOPATH=$(pwd) go_target build -buildmode=c-shared $suffix -o libgo4.$libext libgo4 + binpush libgo4.$libext +-$(go env CC) ${GOGCCFLAGS} -pthread -o testp4 main4.c -ldl ++$(go_target env CC) ${GOGCCFLAGS} -pthread -o testp4 main4.c -ldl + binpush testp4 + output=$(run ./testp4 ./libgo4.$libext 2>&1) + if test "$output" != "PASS"; then + echo "FAIL test4 got ${output}" +- if test "$goos" != "android"; then ++ if ! target; then + echo "re-running test4 in verbose mode" + ./testp4 ./libgo4.$libext verbose + fi +@@ -165,14 +177,14 @@ if test "$output" != "PASS"; then + fi + + # test5: tests signal handlers with os/signal.Notify +-GOPATH=$(pwd) go build -buildmode=c-shared $suffix -o libgo5.$libext libgo5 ++GOPATH=$(pwd) go_target build -buildmode=c-shared $suffix -o libgo5.$libext libgo5 + binpush libgo5.$libext +-$(go env CC) ${GOGCCFLAGS} -pthread -o testp5 main5.c -ldl ++$(go_target env CC) ${GOGCCFLAGS} -pthread -o testp5 main5.c -ldl + binpush testp5 + output=$(run ./testp5 ./libgo5.$libext 2>&1) + if test "$output" != "PASS"; then + echo "FAIL test5 got ${output}" +- if test "$goos" != "android"; then ++ if ! target; then + echo "re-running test5 in verbose mode" + ./testp5 ./libgo5.$libext verbose + fi |