Since this is an initialization guard - can’t it simply be double checked with 
an atomic flag?

> On Jun 20, 2023, at 9:04 AM, Ian Lance Taylor <i...@golang.org> wrote:
> 
> On Tue, Jun 20, 2023 at 5:32 AM Bảo Phan Quốc <phq...@gmail.com> wrote:
>> 
>> I'm using cgo to call a C function from Go. Inside the C function there is a 
>> callback to a Go function. In other way, I'm calling Go -> C -> Go.
>> 
>> After running pprof, I noticed that the __GI___pthread_mutex_unlock took 
>> half of the execution time. AFAIK, cgo has an overhead, especially calling 
>> back from C to Go. But it's weird that cgo takes half of the execution time 
>> to do some locking. Is there something wrong in my code?
> 
> Every call from C to Go does acquire a mutex to check that the Go
> runtime has been fully initialized.  This is normally not a big deal
> as the mutex is held only briefly.  But your code does a lot of
> parallel calls from C to Go.  It is possible that the heavy contention
> on the mutex is causing the results that you are seeing.
> 
> The code in question is the C function _cgo_wait_runtime_init_done in
> runtime/gco/gcc_libinit.c.  It might be possible to speed it up in
> some way to avoid the mutex in the normal case.
> 
> Ian
> 
> -- 
> You received this message because you are subscribed to the Google Groups 
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an 
> email to golang-nuts+unsubscr...@googlegroups.com.
> To view this discussion on the web visit 
> https://groups.google.com/d/msgid/golang-nuts/CAOyqgcU7Csb_hf5gvy8dVHKEHd8GFkN-fUML18uW0HiQGOAXyg%40mail.gmail.com.

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/EF9D02CC-01CB-49D6-922E-59766A396927%40ix.netcom.com.

Reply via email to