]> granicus.if.org Git - postgresql/blobdiff - src/include/miscadmin.h
Remove leftovers of BeOS port
[postgresql] / src / include / miscadmin.h
index d06b34be437401705a9b3a69008ecae6a50bc140..b186eed8f478ae66ca1fde3ee8f08e613d97c54d 100644 (file)
  *       Over time, this has also become the preferred place for widely known
  *       resource-limitation stuff, such as work_mem and check_stack_depth().
  *
- * Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
+ * Portions Copyright (c) 1996-2012, PostgreSQL Global Development Group
  * Portions Copyright (c) 1994, Regents of the University of California
  *
- * $PostgreSQL: pgsql/src/include/miscadmin.h,v 1.201 2008/02/20 22:46:24 tgl Exp $
+ * src/include/miscadmin.h
  *
  * NOTES
  *       some of the information in this file should be moved to other files.
  * course, only if the interrupt holdoff counter is zero).     See the
  * related code for details.
  *
+ * A lost connection is handled similarly, although the loss of connection
+ * does not raise a signal, but is detected when we fail to write to the
+ * socket. If there was a signal for a broken connection, we could make use of
+ * it by setting ClientConnectionLost in the signal handler.
+ *
  * A related, but conceptually distinct, mechanism is the "critical section"
  * mechanism.  A critical section not only holds off cancel/die interrupts,
  * but causes any ereport(ERROR) or ereport(FATAL) to become ereport(PANIC)
@@ -70,6 +75,8 @@ extern PGDLLIMPORT volatile bool InterruptPending;
 extern volatile bool QueryCancelPending;
 extern volatile bool ProcDiePending;
 
+extern volatile bool ClientConnectionLost;
+
 /* these are marked volatile because they are examined by signal handlers: */
 extern volatile bool ImmediateInterruptOK;
 extern PGDLLIMPORT volatile uint32 InterruptHoldoffCount;
@@ -123,7 +130,8 @@ do { \
  */
 extern pid_t PostmasterPid;
 extern bool IsPostmasterEnvironment;
-extern bool IsUnderPostmaster;
+extern PGDLLIMPORT bool IsUnderPostmaster;
+extern bool IsBinaryUpgrade;
 
 extern bool ExitOnAnyError;
 
@@ -137,6 +145,7 @@ extern PGDLLIMPORT int MyProcPid;
 extern PGDLLIMPORT pg_time_t MyStartTime;
 extern PGDLLIMPORT struct Port *MyProcPort;
 extern long MyCancelKey;
+extern int     MyPMChildSlot;
 
 extern char OutputFileName[];
 extern PGDLLIMPORT char my_exec_path[];
@@ -192,6 +201,20 @@ extern PGDLLIMPORT Oid MyDatabaseTableSpace;
 extern int     DateStyle;
 extern int     DateOrder;
 
+/*
+ * IntervalStyles
+ *      INTSTYLE_POSTGRES                         Like Postgres < 8.4 when DateStyle = 'iso'
+ *      INTSTYLE_POSTGRES_VERBOSE         Like Postgres < 8.4 when DateStyle != 'iso'
+ *      INTSTYLE_SQL_STANDARD             SQL standard interval literals
+ *      INTSTYLE_ISO_8601                         ISO-8601-basic formatted intervals
+ */
+#define INTSTYLE_POSTGRES                      0
+#define INTSTYLE_POSTGRES_VERBOSE      1
+#define INTSTYLE_SQL_STANDARD          2
+#define INTSTYLE_ISO_8601                      3
+
+extern int     IntervalStyle;
+
 /*
  * HasCTZSet is true if user has set timezone as a numeric offset from UTC.
  * If so, CTimeZone is the timezone offset in seconds (using the Unix-ish
@@ -214,19 +237,47 @@ extern int        VacuumCostPageDirty;
 extern int     VacuumCostLimit;
 extern int     VacuumCostDelay;
 
+extern int     VacuumPageHit;
+extern int     VacuumPageMiss;
+extern int     VacuumPageDirty;
+
 extern int     VacuumCostBalance;
 extern bool VacuumCostActive;
 
 
 /* in tcop/postgres.c */
+
+#if defined(__ia64__) || defined(__ia64)
+typedef struct
+{
+       char       *stack_base_ptr;
+       char       *register_stack_base_ptr;
+} pg_stack_base_t;
+#else
+typedef char *pg_stack_base_t;
+#endif
+
+extern pg_stack_base_t set_stack_base(void);
+extern void restore_stack_base(pg_stack_base_t base);
 extern void check_stack_depth(void);
 
+/* in tcop/utility.c */
+extern void PreventCommandIfReadOnly(const char *cmdname);
+extern void PreventCommandDuringRecovery(const char *cmdname);
+
+/* in utils/misc/guc.c */
+extern int     trace_recovery_messages;
+extern int     trace_recovery(int trace_level);
 
 /*****************************************************************************
  *       pdir.h --                                                                                                                              *
  *                     POSTGRES directory path definitions.                                                     *
  *****************************************************************************/
 
+/* flags to be OR'd to form sec_context */
+#define SECURITY_LOCAL_USERID_CHANGE   0x0001
+#define SECURITY_RESTRICTED_OPERATION  0x0002
+
 extern char *DatabasePath;
 
 /* now in utils/init/miscinit.c */
@@ -236,9 +287,12 @@ extern char *GetUserNameFromId(Oid roleid);
 extern Oid     GetUserId(void);
 extern Oid     GetOuterUserId(void);
 extern Oid     GetSessionUserId(void);
+extern void GetUserIdAndSecContext(Oid *userid, int *sec_context);
+extern void SetUserIdAndSecContext(Oid userid, int sec_context);
+extern bool InLocalUserIdChange(void);
+extern bool InSecurityRestrictedOperation(void);
 extern void GetUserIdAndContext(Oid *userid, bool *sec_def_context);
 extern void SetUserIdAndContext(Oid userid, bool sec_def_context);
-extern bool InSecurityDefinerContext(void);
 extern void InitializeSessionUserId(const char *rolename);
 extern void InitializeSessionUserIdStandalone(void);
 extern void SetSessionAuthorization(Oid userid, bool is_superuser);
@@ -308,26 +362,54 @@ extern ProcessingMode Mode;
  *****************************************************************************/
 
 /* in utils/init/postinit.c */
-extern bool InitPostgres(const char *in_dbname, Oid dboid, const char *username,
-                        char **out_dbname);
+extern void pg_split_opts(char **argv, int *argcp, char *optstr);
+extern void InitPostgres(const char *in_dbname, Oid dboid, const char *username,
+                        char *out_dbname);
 extern void BaseInit(void);
 
 /* in utils/init/miscinit.c */
 extern bool IgnoreSystemIndexes;
+extern PGDLLIMPORT bool process_shared_preload_libraries_in_progress;
 extern char *shared_preload_libraries_string;
 extern char *local_preload_libraries_string;
 
-extern void SetReindexProcessing(Oid heapOid, Oid indexOid);
-extern void ResetReindexProcessing(void);
-extern bool ReindexIsProcessingHeap(Oid heapOid);
-extern bool ReindexIsProcessingIndex(Oid indexOid);
+/*
+ * As of 9.1, the contents of the data-directory lock file are:
+ *
+ * line #
+ *             1       postmaster PID (or negative of a standalone backend's PID)
+ *             2       data directory path
+ *             3       postmaster start timestamp (time_t representation)
+ *             4       port number
+ *             5       socket directory path (empty on Windows)
+ *             6       first listen_address (IP address or "*"; empty if no TCP port)
+ *             7       shared memory key (not present on Windows)
+ *
+ * Lines 6 and up are added via AddToDataDirLockFile() after initial file
+ * creation; they have to be ordered according to time of addition.
+ *
+ * The socket lock file, if used, has the same contents as lines 1-5.
+ */
+#define LOCK_FILE_LINE_PID                     1
+#define LOCK_FILE_LINE_DATA_DIR                2
+#define LOCK_FILE_LINE_START_TIME      3
+#define LOCK_FILE_LINE_PORT                    4
+#define LOCK_FILE_LINE_SOCKET_DIR      5
+#define LOCK_FILE_LINE_LISTEN_ADDR     6
+#define LOCK_FILE_LINE_SHMEM_KEY       7
+
 extern void CreateDataDirLockFile(bool amPostmaster);
 extern void CreateSocketLockFile(const char *socketfile, bool amPostmaster);
 extern void TouchSocketLockFile(void);
-extern void RecordSharedMemoryInLockFile(unsigned long id1,
-                                                        unsigned long id2);
+extern void AddToDataDirLockFile(int target_line, const char *str);
 extern void ValidatePgVersion(const char *path);
 extern void process_shared_preload_libraries(void);
 extern void process_local_preload_libraries(void);
+extern void pg_bindtextdomain(const char *domain);
+extern bool is_authenticated_user_replication_role(void);
+
+/* in access/transam/xlog.c */
+extern bool BackupInProgress(void);
+extern void CancelBackup(void);
 
 #endif   /* MISCADMIN_H */