From 21d08bc1f606bbd840206b1846fa65fc9e1abab0 Mon Sep 17 00:00:00 2001
From: "Vadim B. Mikheev" <vadim4o@yahoo.com>
Date: Tue, 6 Feb 2001 06:24:00 +0000
Subject: [PATCH] PageAddItem in overwrite mode: must *NOT* check itemid' flag
 if OffsetNumber == MaxOffsetNumber + 1 - there may be garbage there!

---
 src/backend/storage/page/bufpage.c | 15 +++++++++------
 1 file changed, 9 insertions(+), 6 deletions(-)

diff --git a/src/backend/storage/page/bufpage.c b/src/backend/storage/page/bufpage.c
index 02022f9333..02528a30e6 100644
--- a/src/backend/storage/page/bufpage.c
+++ b/src/backend/storage/page/bufpage.c
@@ -8,7 +8,7 @@
  *
  *
  * IDENTIFICATION
- *	  $Header: /cvsroot/pgsql/src/backend/storage/page/bufpage.c,v 1.35 2001/01/24 19:43:08 momjian Exp $
+ *	  $Header: /cvsroot/pgsql/src/backend/storage/page/bufpage.c,v 1.36 2001/02/06 06:24:00 vadim Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -112,12 +112,15 @@ PageAddItem(Page page,
 				elog(NOTICE, "PageAddItem: tried overwrite after maxoff");
 				return InvalidOffsetNumber;
 			}
-			itemId = &((PageHeader) page)->pd_linp[offsetNumber - 1];
-			if (((*itemId).lp_flags & LP_USED) ||
-				((*itemId).lp_len != 0))
+			if (offsetNumber < limit)
 			{
-				elog(NOTICE, "PageAddItem: tried overwrite of used ItemId");
-				return InvalidOffsetNumber;
+				itemId = &((PageHeader) page)->pd_linp[offsetNumber - 1];
+				if (((*itemId).lp_flags & LP_USED) ||
+					((*itemId).lp_len != 0))
+				{
+					elog(NOTICE, "PageAddItem: tried overwrite of used ItemId");
+					return InvalidOffsetNumber;
+				}
 			}
 		}
 		else