Commit 0a00c9a8 authored by Tom Lane's avatar Tom Lane

Remove useless code that propagated FrontendProtocol to a backend via a

PostgresMain switch.  In point of fact, FrontendProtocol is already set
in a backend process, since ProcessStartupPacket() is executed inside
the backend --- it hasn't been run by the postmaster for many years.
And if it were, we'd still certainly want FrontendProtocol to be set before
we get as far as PostgresMain, so that startup errors get reported in the
right protocol.

-v might have some future use in standalone backends, so I didn't go so
far as to remove the switch outright.

Also, initialize FrontendProtocol to 0 not PG_PROTOCOL_LATEST.  The only
likely result of presetting it like that is to mask failure-to-set-it
mistakes.
parent c66d9ce7
...@@ -37,7 +37,7 @@ ...@@ -37,7 +37,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/postmaster/postmaster.c,v 1.591 2009/08/28 17:42:54 tgl Exp $ * $PostgreSQL: pgsql/src/backend/postmaster/postmaster.c,v 1.592 2009/08/28 18:23:53 tgl Exp $
* *
* NOTES * NOTES
* *
...@@ -3353,7 +3353,6 @@ BackendRun(Port *port) ...@@ -3353,7 +3353,6 @@ BackendRun(Port *port)
int ac; int ac;
long secs; long secs;
int usecs; int usecs;
char protobuf[32];
int i; int i;
/* /*
...@@ -3397,10 +3396,6 @@ BackendRun(Port *port) ...@@ -3397,10 +3396,6 @@ BackendRun(Port *port)
*/ */
split_opts(av, &ac, ExtraOptions); split_opts(av, &ac, ExtraOptions);
/* Tell the backend what protocol the frontend is using. */
snprintf(protobuf, sizeof(protobuf), "-v%u", port->proto);
av[ac++] = protobuf;
/* /*
* Tell the backend it is being called from the postmaster, and which * Tell the backend it is being called from the postmaster, and which
* database to use. -y marks the end of secure switches. * database to use. -y marks the end of secure switches.
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/tcop/postgres.c,v 1.569 2009/07/31 20:26:23 tgl Exp $ * $PostgreSQL: pgsql/src/backend/tcop/postgres.c,v 1.570 2009/08/28 18:23:53 tgl Exp $
* *
* NOTES * NOTES
* this is the "main" module of the postgres backend and * this is the "main" module of the postgres backend and
...@@ -3075,6 +3075,13 @@ PostgresMain(int argc, char *argv[], const char *username) ...@@ -3075,6 +3075,13 @@ PostgresMain(int argc, char *argv[], const char *username)
} }
case 'v': case 'v':
/*
* -v is no longer used in normal operation, since
* FrontendProtocol is already set before we get here.
* We keep the switch only for possible use in standalone
* operation, in case we ever support using normal FE/BE
* protocol with a standalone backend.
*/
if (secure) if (secure)
FrontendProtocol = (ProtocolVersion) atoi(optarg); FrontendProtocol = (ProtocolVersion) atoi(optarg);
break; break;
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/utils/init/globals.c,v 1.108 2009/05/05 19:59:00 tgl Exp $ * $PostgreSQL: pgsql/src/backend/utils/init/globals.c,v 1.109 2009/08/28 18:23:53 tgl Exp $
* *
* NOTES * NOTES
* Globals used all over the place should be declared here and not * Globals used all over the place should be declared here and not
...@@ -23,7 +23,7 @@ ...@@ -23,7 +23,7 @@
#include "storage/backendid.h" #include "storage/backendid.h"
ProtocolVersion FrontendProtocol = PG_PROTOCOL_LATEST; ProtocolVersion FrontendProtocol;
volatile bool InterruptPending = false; volatile bool InterruptPending = false;
volatile bool QueryCancelPending = false; volatile bool QueryCancelPending = false;
......
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