| From: | Bruce Momjian <bruce(at)momjian(dot)us> | 
|---|---|
| To: | Heikki Linnakangas <hlinnakangas(at)vmware(dot)com> | 
| Cc: | PostgreSQL-development <pgsql-hackers(at)postgreSQL(dot)org> | 
| Subject: | Re: Further XLogInsert scaling tweaking | 
| Date: | 2013-09-03 03:32:40 | 
| Message-ID: | 20130903033240.GE21874@momjian.us | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
On Mon, Sep  2, 2013 at 10:14:03AM +0300, Heikki Linnakangas wrote:
> diff --git a/src/backend/access/transam/xlog.c b/src/backend/access/transam/xlog.c
> index 39c58d0..28e62ea 100644
> --- a/src/backend/access/transam/xlog.c
> +++ b/src/backend/access/transam/xlog.c
> @@ -428,8 +428,14 @@ typedef struct XLogCtlInsert
>  	uint64		CurrBytePos;
>  	uint64		PrevBytePos;
>  
> -	/* insertion slots, see above for details */
> -	XLogInsertSlotPadded *insertSlots;
> +	/*
> +	 * Make sure the above heavily-contended spinlock and byte positions are
> +	 * on their own cache line. In particular, the RedoRecPtr and full page
> +	 * write variables below should be on a different cache line. They are
> +	 * read on every WAL insertion, but updated rarely, and we don't want
> +	 * those reads to steal the cache line containing Curr/PrevBytePos.
> +	 */
> +	char		pad[128];
Do we adjust for cache line lengths anywhere else?  PGPROC?  Should it
be a global define?
-- 
  Bruce Momjian  <bruce(at)momjian(dot)us>        http://momjian.us
  EnterpriseDB                             http://enterprisedb.com
+ It's impossible for everything to be true. +
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Karl O. Pinc | 2013-09-03 03:56:54 | Re: backup.sgml-cmd-v003.patch | 
| Previous Message | Noah Misch | 2013-09-03 03:31:50 | Re: dynamic shared memory |