#include "catalog/pg_opclass.h"
 #include "catalog/pg_proc.h"
 #include "catalog/pg_rewrite.h"
+#include "catalog/pg_shseclabel.h"
 #include "catalog/pg_tablespace.h"
 #include "catalog/pg_trigger.h"
 #include "catalog/pg_type.h"
 static const FormData_pg_attribute Desc_pg_authid[Natts_pg_authid] = {Schema_pg_authid};
 static const FormData_pg_attribute Desc_pg_auth_members[Natts_pg_auth_members] = {Schema_pg_auth_members};
 static const FormData_pg_attribute Desc_pg_index[Natts_pg_index] = {Schema_pg_index};
+static const FormData_pg_attribute Desc_pg_shseclabel[Natts_pg_shseclabel] = {Schema_pg_shseclabel};
 
 /*
  *     Hash tables that index the relation cache
  *     catalogs.
  *
  * formrdesc is currently used for: pg_database, pg_authid, pg_auth_members,
- * pg_class, pg_attribute, pg_proc, and pg_type
+ * pg_shseclabel, pg_class, pg_attribute, pg_proc, and pg_type
  * (see RelationCacheInitializePhase2/3).
  *
  * Note that these catalogs can't have constraints (except attnotnull),
  *
  *     This is called to prepare for access to shared catalogs during startup.
  *     We must at least set up nailed reldescs for pg_database, pg_authid,
- *     and pg_auth_members.  Ideally we'd like to have reldescs for their
- *     indexes, too.  We attempt to load this information from the shared
- *     relcache init file.  If that's missing or broken, just make phony
- *     entries for the catalogs themselves.  RelationCacheInitializePhase3
- *     will clean up as needed.
+ *     pg_auth_members, and pg_shseclabel. Ideally we'd like to have reldescs
+ *     for their indexes, too.  We attempt to load this information from the
+ *     shared relcache init file.  If that's missing or broken, just make
+ *     phony entries for the catalogs themselves.
+ *     RelationCacheInitializePhase3 will clean up as needed.
  */
 void
 RelationCacheInitializePhase2(void)
                  true, Natts_pg_authid, Desc_pg_authid);
        formrdesc("pg_auth_members", AuthMemRelation_Rowtype_Id, true,
                  false, Natts_pg_auth_members, Desc_pg_auth_members);
+       formrdesc("pg_shseclabel", SharedSecLabelRelation_Rowtype_Id, true,
+                 false, Natts_pg_shseclabel, Desc_pg_shseclabel);
 
-#define NUM_CRITICAL_SHARED_RELS   3   /* fix if you change list above */
+#define NUM_CRITICAL_SHARED_RELS   4   /* fix if you change list above */
    }
 
    MemoryContextSwitchTo(oldcxt);
     * non-shared catalogs at all.  Autovacuum calls InitPostgres with a
     * database OID, so it instead depends on DatabaseOidIndexId.  We also
     * need to nail up some indexes on pg_authid and pg_auth_members for use
-    * during client authentication.
+    * during client authentication.  SharedSecLabelObjectIndexId isn't
+    * critical for the core system, but authentication hooks might be
+    * interested in it.
     */
    if (!criticalSharedRelcachesBuilt)
    {
                            AuthIdRelationId);
        load_critical_index(AuthMemMemRoleIndexId,
                            AuthMemRelationId);
+       load_critical_index(SharedSecLabelObjectIndexId,
+                           SharedSecLabelRelationId);
 
-#define NUM_CRITICAL_SHARED_INDEXES 5  /* fix if you change list above */
+#define NUM_CRITICAL_SHARED_INDEXES 6  /* fix if you change list above */
 
        criticalSharedRelcachesBuilt = true;
    }