From bf347c60bdd7e05800f0c06d03e2ad87aeaa5e09 Mon Sep 17 00:00:00 2001 From: Robert Haas Date: Fri, 17 Jun 2011 13:34:39 -0400 Subject: [PATCH] Fix crash in CREATE UNLOGGED TABLE. The code that created the init fork neglected to make sure that the relation was open at the smgr level before attempting to invoke smgr. This didn't happen every time; only when the relcache entry was rebuilt along the way. Per report from Garick Hamlin. --- src/backend/catalog/heap.c | 1 + 1 file changed, 1 insertion(+) diff --git a/src/backend/catalog/heap.c b/src/backend/catalog/heap.c index 67a7749a30..e606ac2b9e 100644 --- a/src/backend/catalog/heap.c +++ b/src/backend/catalog/heap.c @@ -1295,6 +1295,7 @@ heap_create_with_catalog(const char *relname, { Assert(relkind == RELKIND_RELATION || relkind == RELKIND_TOASTVALUE); + RelationOpenSmgr(new_rel_desc); smgrcreate(new_rel_desc->rd_smgr, INIT_FORKNUM, false); if (XLogIsNeeded()) log_smgrcreate(&new_rel_desc->rd_smgr->smgr_rnode.node,