Commit 6de6d96d authored by Robert Haas's avatar Robert Haas

Invalidate caches after cranking up a parallel worker transaction.

Starting a parallel worker transaction changes our notion of which XIDs
are in-progress or committed, and our notion of the current command
counter ID.  Therefore, our view of these caches prior to starting
this transaction may no longer valid.  Defend against that by clearing
them.

This fixes a bug in commit 924bcf4f.
parent d07fea54
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
#include "tcop/tcopprot.h" #include "tcop/tcopprot.h"
#include "utils/combocid.h" #include "utils/combocid.h"
#include "utils/guc.h" #include "utils/guc.h"
#include "utils/inval.h"
#include "utils/memutils.h" #include "utils/memutils.h"
#include "utils/resowner.h" #include "utils/resowner.h"
#include "utils/snapmgr.h" #include "utils/snapmgr.h"
...@@ -928,6 +929,12 @@ ParallelWorkerMain(Datum main_arg) ...@@ -928,6 +929,12 @@ ParallelWorkerMain(Datum main_arg)
Assert(asnapspace != NULL); Assert(asnapspace != NULL);
PushActiveSnapshot(RestoreSnapshot(asnapspace)); PushActiveSnapshot(RestoreSnapshot(asnapspace));
/*
* We've changed which tuples we can see, and must therefore invalidate
* system caches.
*/
InvalidateSystemCaches();
/* Restore user ID and security context. */ /* Restore user ID and security context. */
SetUserIdAndSecContext(fps->current_user_id, fps->sec_context); SetUserIdAndSecContext(fps->current_user_id, fps->sec_context);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment