I am new to gccgo and I need help with compiling/running the below code (that works all right with the "standard" go compiler (sorry, I do not know the proper nomenclature)):
my gcc:
nailor@macbuntu:*rgo/src/tictoc-demo$ gccgo -v
Using built-in specs.
COLLECT_GCC=gccgo
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/4.7/lto-wrapper
Target: x86_64-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.7.2-0ubuntu3' --with-bugurl=file:///usr/share/doc/gccgo-4.7/README.Bugs --enable-languages=c,c++,go --prefix=/usr --program-suffix=-4.7 --enable-shared --enable-linker-build-id --with-system-zlib --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.7 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-time=yes --enable-gnu-unique-object --disable-libmudflap --enable-plugin --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64 --with-tune=generic --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu
Thread model: posix
gcc version 4.7.2 (Ubuntu/Linaro 4.7.2-0ubuntu3)
my first file:
nailor@macbuntu:*rgo/src/tictoc-demo$ cat tictoc.go
package tictoc
import "fmt"
import "time"
var ticTime = time.Now()
const default_section_name = "measurement"
var section_name = default_section_name
func Tic() {
TicM(default_section_name)
}
func TicM(name string) {
section_name = name
fmt.Printf("[%s] tic\n", section_name)
ticTime = time.Now()
}
func Toc() {
TocM("")
}
func TocM(message string) {
dur := time.Now().Sub(ticTime).Seconds()
fmt.Printf("[%s] [%s] toc %5f\n", section_name, message, dur)
}
func TocTic() {
Toc();
Tic();
}
func TocTicM(message string) {
Toc();
TicM(message);
}
my second file:
nailor@macbuntu:*rgo/src/tictoc-demo$ cat tictoc-demo.go
package main
import . "tictoc"
func main(){
Tic()
Toc()
Toc()
TicM("2nd tic")
Toc()
Toc()
TocM("Error")
Toc()
TocM("More Fancy")
Toc()
Toc()
TocTic()
Toc()
}
my compilation with the error:
nailor@macbuntu:*rgo/src/tictoc-demo$ gccgo -c tictoc.go
nailor@macbuntu:*rgo/src/tictoc-demo$ gccgo -c tictoc-demo.go
nailor@macbuntu:*rgo/src/tictoc-demo$ gccgo -o tictoc-demo tictoc-demo.o tictoc.o -static
nailor@macbuntu:*rgo/src/tictoc-demo$ ./tictoc-demo
panic: runtime error: invalid memory address or nil pointer dereference
[signal 0xb code=0x1 addr=0x0]
goroutine 2 [syscall]:
goroutine 1 [runnable]:
nailor@macbuntu:*rgo/src/tictoc-demo2$
What am I doing wrong here?
You are not doing anything wrong. This looks like a bug in the compiler when doing full-static linkage. Try linking with
-static-libgo
instead, and it should work.This is the backtrace in gdb:
I'll see if there's a bug filed upstream for this already, or file one otherwise.
(issue filed: http://golang.org/issue/6375 )