Re: ERROR: invalid spinlock number: 0 - Mailing list pgsql-hackers

From Fujii Masao
Subject Re: ERROR: invalid spinlock number: 0
Date
Msg-id 0c58fb4f-3492-c69e-c9fb-56dc252d22fd@oss.nttdata.com
Whole thread Raw
In response to Re: ERROR: invalid spinlock number: 0  (Michael Paquier <michael@paquier.xyz>)
List pgsql-hackers

On 2021/02/15 19:45, Michael Paquier wrote:
> On Mon, Feb 15, 2021 at 10:47:05PM +1300, Thomas Munro wrote:
>> Why not initialise it in WalRcvShmemInit()?
> 
> I was thinking about doing that as well, but we have no real need to
> initialize this stuff in most cases, say standalone deployments.  In
> particular for the fallback implementation of atomics, we would
> prepare a spinlock for nothing.

But on second thought, if we make WalRceiverMain() call pg_atomic_init_u64(),
the variable is initialized (i,e., SpinLockInit() is called in --disable-atomics)
every time walreceiver is started. That may be problematic? If so, the variable
needs to be initialized in WalRcvShmemInit(), instead.

BTW, the recent commit 46d6e5f567 has the similar issue. The variable
that commit added is initialized in InitProcess(), but maybe should be done
in InitProcGlobal() or elsewhere.

Regards,

-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION



pgsql-hackers by date:

Previous
From: Amit Kapila
Date:
Subject: Re: logical replication seems broken
Next
From: vignesh C
Date:
Subject: Re: logical replication seems broken