mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Widen xl_len field of XLogRecord header to 32 bits, so that we'll have
a more tolerable limit on the number of subtransactions or deleted files in COMMIT and ABORT records. Buy back the extra space by eliminating the xl_xact_prev field, which isn't being used for anything and is rather unlikely ever to be used for anything. This does not force initdb, but you do need to do pg_resetxlog if you want to upgrade an existing 8.0 installation without initdb.
This commit is contained in:
		| @@ -7,7 +7,7 @@ | |||||||
|  * Portions Copyright (c) 1996-2004, PostgreSQL Global Development Group |  * Portions Copyright (c) 1996-2004, PostgreSQL Global Development Group | ||||||
|  * Portions Copyright (c) 1994, Regents of the University of California |  * Portions Copyright (c) 1994, Regents of the University of California | ||||||
|  * |  * | ||||||
|  * $PostgreSQL: pgsql/src/backend/access/transam/xlog.c,v 1.166 2004/08/29 05:06:40 momjian Exp $ |  * $PostgreSQL: pgsql/src/backend/access/transam/xlog.c,v 1.167 2004/08/29 16:34:47 tgl Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -409,6 +409,10 @@ static uint32 readOff = 0; | |||||||
| /* Buffer for currently read page (BLCKSZ bytes) */ | /* Buffer for currently read page (BLCKSZ bytes) */ | ||||||
| static char *readBuf = NULL; | static char *readBuf = NULL; | ||||||
|  |  | ||||||
|  | /* Buffer for current ReadRecord result (expandable) */ | ||||||
|  | static char *readRecordBuf = NULL; | ||||||
|  | static uint32 readRecordBufSize = 0; | ||||||
|  |  | ||||||
| /* State information for XLOG reading */ | /* State information for XLOG reading */ | ||||||
| static XLogRecPtr ReadRecPtr; | static XLogRecPtr ReadRecPtr; | ||||||
| static XLogRecPtr EndRecPtr; | static XLogRecPtr EndRecPtr; | ||||||
| @@ -440,11 +444,9 @@ static bool RestoreArchivedFile(char *path, const char *xlogfname, | |||||||
| 					const char *recovername, off_t expectedSize); | 					const char *recovername, off_t expectedSize); | ||||||
| static void PreallocXlogFiles(XLogRecPtr endptr); | static void PreallocXlogFiles(XLogRecPtr endptr); | ||||||
| static void MoveOfflineLogs(uint32 log, uint32 seg, XLogRecPtr endptr); | static void MoveOfflineLogs(uint32 log, uint32 seg, XLogRecPtr endptr); | ||||||
| static XLogRecord *ReadRecord(XLogRecPtr *RecPtr, int emode, char *buffer); | static XLogRecord *ReadRecord(XLogRecPtr *RecPtr, int emode); | ||||||
| static bool ValidXLOGHeader(XLogPageHeader hdr, int emode); | static bool ValidXLOGHeader(XLogPageHeader hdr, int emode); | ||||||
| static XLogRecord *ReadCheckpointRecord(XLogRecPtr RecPtr, | static XLogRecord *ReadCheckpointRecord(XLogRecPtr RecPtr, int whichChkpt); | ||||||
| 					 int whichChkpt, |  | ||||||
| 					 char *buffer); |  | ||||||
| static List *readTimeLineHistory(TimeLineID targetTLI); | static List *readTimeLineHistory(TimeLineID targetTLI); | ||||||
| static bool existsTimeLineHistory(TimeLineID probeTLI); | static bool existsTimeLineHistory(TimeLineID probeTLI); | ||||||
| static TimeLineID findNewestTimeLine(TimeLineID startTLI); | static TimeLineID findNewestTimeLine(TimeLineID startTLI); | ||||||
| @@ -627,7 +629,7 @@ begin:; | |||||||
| 	 * may not be true forever.  If you need to remove the len == 0 check, | 	 * may not be true forever.  If you need to remove the len == 0 check, | ||||||
| 	 * also remove the check for xl_len == 0 in ReadRecord, below. | 	 * also remove the check for xl_len == 0 in ReadRecord, below. | ||||||
| 	 */ | 	 */ | ||||||
| 	if (len == 0 || len > MAXLOGRECSZ) | 	if (len == 0) | ||||||
| 		elog(PANIC, "invalid xlog record length %u", len); | 		elog(PANIC, "invalid xlog record length %u", len); | ||||||
|  |  | ||||||
| 	START_CRIT_SECTION(); | 	START_CRIT_SECTION(); | ||||||
| @@ -745,14 +747,6 @@ begin:; | |||||||
| 	/* Insert record header */ | 	/* Insert record header */ | ||||||
|  |  | ||||||
| 	record->xl_prev = Insert->PrevRecord; | 	record->xl_prev = Insert->PrevRecord; | ||||||
| 	if (no_tran) |  | ||||||
| 	{ |  | ||||||
| 		record->xl_xact_prev.xlogid = 0; |  | ||||||
| 		record->xl_xact_prev.xrecoff = 0; |  | ||||||
| 	} |  | ||||||
| 	else |  | ||||||
| 		record->xl_xact_prev = MyLastRecPtr; |  | ||||||
|  |  | ||||||
| 	record->xl_xid = GetCurrentTransactionId(); | 	record->xl_xid = GetCurrentTransactionId(); | ||||||
| 	record->xl_len = len;		/* doesn't include backup blocks */ | 	record->xl_len = len;		/* doesn't include backup blocks */ | ||||||
| 	record->xl_info = info; | 	record->xl_info = info; | ||||||
| @@ -2316,14 +2310,14 @@ RecordIsValid(XLogRecord *record, XLogRecPtr recptr, int emode) | |||||||
|  * If no valid record is available, returns NULL, or fails if emode is PANIC. |  * If no valid record is available, returns NULL, or fails if emode is PANIC. | ||||||
|  * (emode must be either PANIC or LOG.) |  * (emode must be either PANIC or LOG.) | ||||||
|  * |  * | ||||||
|  * buffer is a workspace at least _INTL_MAXLOGRECSZ bytes long.  It is needed |  * The record is copied into readRecordBuf, so that on successful return, | ||||||
|  * to reassemble a record that crosses block boundaries.  Note that on |  * the returned record pointer always points there. | ||||||
|  * successful return, the returned record pointer always points at buffer. |  | ||||||
|  */ |  */ | ||||||
| static XLogRecord * | static XLogRecord * | ||||||
| ReadRecord(XLogRecPtr *RecPtr, int emode, char *buffer) | ReadRecord(XLogRecPtr *RecPtr, int emode) | ||||||
| { | { | ||||||
| 	XLogRecord *record; | 	XLogRecord *record; | ||||||
|  | 	char	   *buffer; | ||||||
| 	XLogRecPtr	tmpRecPtr = EndRecPtr; | 	XLogRecPtr	tmpRecPtr = EndRecPtr; | ||||||
| 	bool		randAccess = false; | 	bool		randAccess = false; | ||||||
| 	uint32		len, | 	uint32		len, | ||||||
| @@ -2467,6 +2461,13 @@ got_record:; | |||||||
| 						RecPtr->xlogid, RecPtr->xrecoff))); | 						RecPtr->xlogid, RecPtr->xrecoff))); | ||||||
| 		goto next_record_is_invalid; | 		goto next_record_is_invalid; | ||||||
| 	} | 	} | ||||||
|  | 	if (record->xl_rmid > RM_MAX_ID) | ||||||
|  | 	{ | ||||||
|  | 		ereport(emode, | ||||||
|  | 				(errmsg("invalid resource manager ID %u at %X/%X", | ||||||
|  | 					 record->xl_rmid, RecPtr->xlogid, RecPtr->xrecoff))); | ||||||
|  | 		goto next_record_is_invalid; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| 	 * Compute total length of record including any appended backup | 	 * Compute total length of record including any appended backup | ||||||
| @@ -2481,24 +2482,34 @@ got_record:; | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| 	 * Make sure it will fit in buffer (currently, it is mechanically | 	 * Allocate or enlarge readRecordBuf as needed.  To avoid useless | ||||||
| 	 * impossible for this test to fail, but it seems like a good idea | 	 * small increases, round its size to a multiple of BLCKSZ, and make | ||||||
| 	 * anyway). | 	 * sure it's at least 4*BLCKSZ to start with.  (That is enough for | ||||||
|  | 	 * all "normal" records, but very large commit or abort records might | ||||||
|  | 	 * need more space.) | ||||||
| 	 */ | 	 */ | ||||||
| 	if (total_len > _INTL_MAXLOGRECSZ) | 	if (total_len > readRecordBufSize) | ||||||
| 	{ | 	{ | ||||||
|  | 		uint32		newSize = total_len; | ||||||
|  |  | ||||||
|  | 		newSize += BLCKSZ - (newSize % BLCKSZ); | ||||||
|  | 		newSize = Max(newSize, 4 * BLCKSZ); | ||||||
|  | 		if (readRecordBuf) | ||||||
|  | 			free(readRecordBuf); | ||||||
|  | 		readRecordBuf = (char *) malloc(newSize); | ||||||
|  | 		if (!readRecordBuf) | ||||||
|  | 		{ | ||||||
|  | 			readRecordBufSize = 0; | ||||||
|  | 			/* We treat this as a "bogus data" condition */ | ||||||
| 			ereport(emode, | 			ereport(emode, | ||||||
| 					(errmsg("record length %u at %X/%X too long", | 					(errmsg("record length %u at %X/%X too long", | ||||||
| 							total_len, RecPtr->xlogid, RecPtr->xrecoff))); | 							total_len, RecPtr->xlogid, RecPtr->xrecoff))); | ||||||
| 			goto next_record_is_invalid; | 			goto next_record_is_invalid; | ||||||
| 		} | 		} | ||||||
| 	if (record->xl_rmid > RM_MAX_ID) | 		readRecordBufSize = newSize; | ||||||
| 	{ |  | ||||||
| 		ereport(emode, |  | ||||||
| 				(errmsg("invalid resource manager ID %u at %X/%X", |  | ||||||
| 					 record->xl_rmid, RecPtr->xlogid, RecPtr->xrecoff))); |  | ||||||
| 		goto next_record_is_invalid; |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	buffer = readRecordBuf; | ||||||
| 	nextRecord = NULL; | 	nextRecord = NULL; | ||||||
| 	len = BLCKSZ - RecPtr->xrecoff % BLCKSZ; | 	len = BLCKSZ - RecPtr->xrecoff % BLCKSZ; | ||||||
| 	if (total_len > len) | 	if (total_len > len) | ||||||
| @@ -3481,8 +3492,6 @@ BootStrapXLOG(void) | |||||||
| 	record = (XLogRecord *) ((char *) page + SizeOfXLogLongPHD); | 	record = (XLogRecord *) ((char *) page + SizeOfXLogLongPHD); | ||||||
| 	record->xl_prev.xlogid = 0; | 	record->xl_prev.xlogid = 0; | ||||||
| 	record->xl_prev.xrecoff = 0; | 	record->xl_prev.xrecoff = 0; | ||||||
| 	record->xl_xact_prev.xlogid = 0; |  | ||||||
| 	record->xl_xact_prev.xrecoff = 0; |  | ||||||
| 	record->xl_xid = InvalidTransactionId; | 	record->xl_xid = InvalidTransactionId; | ||||||
| 	record->xl_len = sizeof(checkPoint); | 	record->xl_len = sizeof(checkPoint); | ||||||
| 	record->xl_info = XLOG_CHECKPOINT_SHUTDOWN; | 	record->xl_info = XLOG_CHECKPOINT_SHUTDOWN; | ||||||
| @@ -3981,12 +3990,8 @@ StartupXLOG(void) | |||||||
| 	uint32		endLogId; | 	uint32		endLogId; | ||||||
| 	uint32		endLogSeg; | 	uint32		endLogSeg; | ||||||
| 	XLogRecord *record; | 	XLogRecord *record; | ||||||
| 	char	   *buffer; |  | ||||||
| 	uint32		freespace; | 	uint32		freespace; | ||||||
|  |  | ||||||
| 	/* Use malloc() to ensure record buffer is MAXALIGNED */ |  | ||||||
| 	buffer = (char *) malloc(_INTL_MAXLOGRECSZ); |  | ||||||
|  |  | ||||||
| 	CritSectionCount++; | 	CritSectionCount++; | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| @@ -4063,7 +4068,7 @@ StartupXLOG(void) | |||||||
| 		 * from the checkpoint it identifies, rather than using | 		 * from the checkpoint it identifies, rather than using | ||||||
| 		 * pg_control. | 		 * pg_control. | ||||||
| 		 */ | 		 */ | ||||||
| 		record = ReadCheckpointRecord(checkPointLoc, 0, buffer); | 		record = ReadCheckpointRecord(checkPointLoc, 0); | ||||||
| 		if (record != NULL) | 		if (record != NULL) | ||||||
| 		{ | 		{ | ||||||
| 			ereport(LOG, | 			ereport(LOG, | ||||||
| @@ -4085,7 +4090,7 @@ StartupXLOG(void) | |||||||
| 		 * according to pg_control is broken, try the next-to-last one. | 		 * according to pg_control is broken, try the next-to-last one. | ||||||
| 		 */ | 		 */ | ||||||
| 		checkPointLoc = ControlFile->checkPoint; | 		checkPointLoc = ControlFile->checkPoint; | ||||||
| 		record = ReadCheckpointRecord(checkPointLoc, 1, buffer); | 		record = ReadCheckpointRecord(checkPointLoc, 1); | ||||||
| 		if (record != NULL) | 		if (record != NULL) | ||||||
| 		{ | 		{ | ||||||
| 			ereport(LOG, | 			ereport(LOG, | ||||||
| @@ -4095,7 +4100,7 @@ StartupXLOG(void) | |||||||
| 		else | 		else | ||||||
| 		{ | 		{ | ||||||
| 			checkPointLoc = ControlFile->prevCheckPoint; | 			checkPointLoc = ControlFile->prevCheckPoint; | ||||||
| 			record = ReadCheckpointRecord(checkPointLoc, 2, buffer); | 			record = ReadCheckpointRecord(checkPointLoc, 2); | ||||||
| 			if (record != NULL) | 			if (record != NULL) | ||||||
| 			{ | 			{ | ||||||
| 				ereport(LOG, | 				ereport(LOG, | ||||||
| @@ -4198,12 +4203,12 @@ StartupXLOG(void) | |||||||
| 		if (XLByteLT(checkPoint.redo, RecPtr)) | 		if (XLByteLT(checkPoint.redo, RecPtr)) | ||||||
| 		{ | 		{ | ||||||
| 			/* back up to find the record */ | 			/* back up to find the record */ | ||||||
| 			record = ReadRecord(&(checkPoint.redo), PANIC, buffer); | 			record = ReadRecord(&(checkPoint.redo), PANIC); | ||||||
| 		} | 		} | ||||||
| 		else | 		else | ||||||
| 		{ | 		{ | ||||||
| 			/* just have to read next record after CheckPoint */ | 			/* just have to read next record after CheckPoint */ | ||||||
| 			record = ReadRecord(NULL, LOG, buffer); | 			record = ReadRecord(NULL, LOG); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if (record != NULL) | 		if (record != NULL) | ||||||
| @@ -4263,7 +4268,7 @@ StartupXLOG(void) | |||||||
|  |  | ||||||
| 				LastRec = ReadRecPtr; | 				LastRec = ReadRecPtr; | ||||||
|  |  | ||||||
| 				record = ReadRecord(NULL, LOG, buffer); | 				record = ReadRecord(NULL, LOG); | ||||||
| 			} while (record != NULL && recoveryContinue); | 			} while (record != NULL && recoveryContinue); | ||||||
|  |  | ||||||
| 			/* | 			/* | ||||||
| @@ -4287,7 +4292,7 @@ StartupXLOG(void) | |||||||
| 	 * Re-fetch the last valid or last applied record, so we can identify | 	 * Re-fetch the last valid or last applied record, so we can identify | ||||||
| 	 * the exact endpoint of what we consider the valid portion of WAL. | 	 * the exact endpoint of what we consider the valid portion of WAL. | ||||||
| 	 */ | 	 */ | ||||||
| 	record = ReadRecord(&LastRec, PANIC, buffer); | 	record = ReadRecord(&LastRec, PANIC); | ||||||
| 	EndOfLog = EndRecPtr; | 	EndOfLog = EndRecPtr; | ||||||
| 	XLByteToPrevSeg(EndOfLog, endLogId, endLogSeg); | 	XLByteToPrevSeg(EndOfLog, endLogId, endLogSeg); | ||||||
|  |  | ||||||
| @@ -4404,7 +4409,7 @@ StartupXLOG(void) | |||||||
| 							RecPtr.xlogid, RecPtr.xrecoff))); | 							RecPtr.xlogid, RecPtr.xrecoff))); | ||||||
| 			do | 			do | ||||||
| 			{ | 			{ | ||||||
| 				record = ReadRecord(&RecPtr, PANIC, buffer); | 				record = ReadRecord(&RecPtr, PANIC); | ||||||
| 				if (TransactionIdIsValid(record->xl_xid) && | 				if (TransactionIdIsValid(record->xl_xid) && | ||||||
| 					!TransactionIdDidCommit(record->xl_xid)) | 					!TransactionIdDidCommit(record->xl_xid)) | ||||||
| 					RmgrTable[record->xl_rmid].rm_undo(EndRecPtr, record); | 					RmgrTable[record->xl_rmid].rm_undo(EndRecPtr, record); | ||||||
| @@ -4498,8 +4503,12 @@ StartupXLOG(void) | |||||||
| 		free(readBuf); | 		free(readBuf); | ||||||
| 		readBuf = NULL; | 		readBuf = NULL; | ||||||
| 	} | 	} | ||||||
|  | 	if (readRecordBuf) | ||||||
| 	free(buffer); | 	{ | ||||||
|  | 		free(readRecordBuf); | ||||||
|  | 		readRecordBuf = NULL; | ||||||
|  | 		readRecordBufSize = 0; | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -4509,9 +4518,7 @@ StartupXLOG(void) | |||||||
|  * 1 for "primary", 2 for "secondary", 0 for "other" (backup_label) |  * 1 for "primary", 2 for "secondary", 0 for "other" (backup_label) | ||||||
|  */ |  */ | ||||||
| static XLogRecord * | static XLogRecord * | ||||||
| ReadCheckpointRecord(XLogRecPtr RecPtr, | ReadCheckpointRecord(XLogRecPtr RecPtr, int whichChkpt) | ||||||
| 					 int whichChkpt, |  | ||||||
| 					 char *buffer) |  | ||||||
| { | { | ||||||
| 	XLogRecord *record; | 	XLogRecord *record; | ||||||
|  |  | ||||||
| @@ -4535,7 +4542,7 @@ ReadCheckpointRecord(XLogRecPtr RecPtr, | |||||||
| 		return NULL; | 		return NULL; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	record = ReadRecord(&RecPtr, LOG, buffer); | 	record = ReadRecord(&RecPtr, LOG); | ||||||
|  |  | ||||||
| 	if (record == NULL) | 	if (record == NULL) | ||||||
| 	{ | 	{ | ||||||
| @@ -5080,9 +5087,8 @@ xlog_outrec(char *buf, XLogRecord *record) | |||||||
| 	int			bkpb; | 	int			bkpb; | ||||||
| 	int			i; | 	int			i; | ||||||
|  |  | ||||||
| 	sprintf(buf + strlen(buf), "prev %X/%X; xprev %X/%X; xid %u", | 	sprintf(buf + strlen(buf), "prev %X/%X; xid %u", | ||||||
| 			record->xl_prev.xlogid, record->xl_prev.xrecoff, | 			record->xl_prev.xlogid, record->xl_prev.xrecoff, | ||||||
| 			record->xl_xact_prev.xlogid, record->xl_xact_prev.xrecoff, |  | ||||||
| 			record->xl_xid); | 			record->xl_xid); | ||||||
|  |  | ||||||
| 	for (i = 0, bkpb = 0; i < XLR_MAX_BKP_BLOCKS; i++) | 	for (i = 0, bkpb = 0; i < XLR_MAX_BKP_BLOCKS; i++) | ||||||
|   | |||||||
| @@ -23,7 +23,7 @@ | |||||||
|  * Portions Copyright (c) 1996-2004, PostgreSQL Global Development Group |  * Portions Copyright (c) 1996-2004, PostgreSQL Global Development Group | ||||||
|  * Portions Copyright (c) 1994, Regents of the University of California |  * Portions Copyright (c) 1994, Regents of the University of California | ||||||
|  * |  * | ||||||
|  * $PostgreSQL: pgsql/src/bin/pg_resetxlog/pg_resetxlog.c,v 1.23 2004/08/29 05:06:54 momjian Exp $ |  * $PostgreSQL: pgsql/src/bin/pg_resetxlog/pg_resetxlog.c,v 1.24 2004/08/29 16:34:48 tgl Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -645,8 +645,6 @@ WriteEmptyXLOG(void) | |||||||
| 	record = (XLogRecord *) ((char *) page + SizeOfXLogLongPHD); | 	record = (XLogRecord *) ((char *) page + SizeOfXLogLongPHD); | ||||||
| 	record->xl_prev.xlogid = 0; | 	record->xl_prev.xlogid = 0; | ||||||
| 	record->xl_prev.xrecoff = 0; | 	record->xl_prev.xrecoff = 0; | ||||||
| 	record->xl_xact_prev.xlogid = 0; |  | ||||||
| 	record->xl_xact_prev.xrecoff = 0; |  | ||||||
| 	record->xl_xid = InvalidTransactionId; | 	record->xl_xid = InvalidTransactionId; | ||||||
| 	record->xl_len = sizeof(CheckPoint); | 	record->xl_len = sizeof(CheckPoint); | ||||||
| 	record->xl_info = XLOG_CHECKPOINT_SHUTDOWN; | 	record->xl_info = XLOG_CHECKPOINT_SHUTDOWN; | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
|  * Portions Copyright (c) 1996-2004, PostgreSQL Global Development Group |  * Portions Copyright (c) 1996-2004, PostgreSQL Global Development Group | ||||||
|  * Portions Copyright (c) 1994, Regents of the University of California |  * Portions Copyright (c) 1994, Regents of the University of California | ||||||
|  * |  * | ||||||
|  * $PostgreSQL: pgsql/src/include/access/xlog.h,v 1.57 2004/08/29 05:06:55 momjian Exp $ |  * $PostgreSQL: pgsql/src/include/access/xlog.h,v 1.58 2004/08/29 16:34:48 tgl Exp $ | ||||||
|  */ |  */ | ||||||
| #ifndef XLOG_H | #ifndef XLOG_H | ||||||
| #define XLOG_H | #define XLOG_H | ||||||
| @@ -35,18 +35,18 @@ typedef struct XLogRecord | |||||||
| { | { | ||||||
| 	crc64		xl_crc;			/* CRC for this record */ | 	crc64		xl_crc;			/* CRC for this record */ | ||||||
| 	XLogRecPtr	xl_prev;		/* ptr to previous record in log */ | 	XLogRecPtr	xl_prev;		/* ptr to previous record in log */ | ||||||
| 	XLogRecPtr	xl_xact_prev;	/* ptr to previous record of this xact */ |  | ||||||
| 	TransactionId xl_xid;		/* xact id */ | 	TransactionId xl_xid;		/* xact id */ | ||||||
| 	uint16		xl_len;			/* total len of rmgr data */ | 	uint32		xl_len;			/* total len of rmgr data */ | ||||||
| 	uint8		xl_info;		/* flag bits, see below */ | 	uint8		xl_info;		/* flag bits, see below */ | ||||||
| 	RmgrId		xl_rmid;		/* resource manager for this record */ | 	RmgrId		xl_rmid;		/* resource manager for this record */ | ||||||
|  |  | ||||||
|  | 	/* Depending on MAXALIGN, there are either 2 or 6 wasted bytes here */ | ||||||
|  |  | ||||||
| 	/* ACTUAL LOG DATA FOLLOWS AT END OF STRUCT */ | 	/* ACTUAL LOG DATA FOLLOWS AT END OF STRUCT */ | ||||||
|  |  | ||||||
| } XLogRecord; | } XLogRecord; | ||||||
|  |  | ||||||
| #define SizeOfXLogRecord	MAXALIGN(sizeof(XLogRecord)) | #define SizeOfXLogRecord	MAXALIGN(sizeof(XLogRecord)) | ||||||
| #define MAXLOGRECSZ			65535		/* the most that'll fit in xl_len */ |  | ||||||
|  |  | ||||||
| #define XLogRecGetData(record)	((char*) (record) + SizeOfXLogRecord) | #define XLogRecGetData(record)	((char*) (record) + SizeOfXLogRecord) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ | |||||||
|  * Portions Copyright (c) 1996-2004, PostgreSQL Global Development Group |  * Portions Copyright (c) 1996-2004, PostgreSQL Global Development Group | ||||||
|  * Portions Copyright (c) 1994, Regents of the University of California |  * Portions Copyright (c) 1994, Regents of the University of California | ||||||
|  * |  * | ||||||
|  * $PostgreSQL: pgsql/src/include/access/xlog_internal.h,v 1.4 2004/08/29 05:06:55 momjian Exp $ |  * $PostgreSQL: pgsql/src/include/access/xlog_internal.h,v 1.5 2004/08/29 16:34:48 tgl Exp $ | ||||||
|  */ |  */ | ||||||
| #ifndef XLOG_INTERNAL_H | #ifndef XLOG_INTERNAL_H | ||||||
| #define XLOG_INTERNAL_H | #define XLOG_INTERNAL_H | ||||||
| @@ -58,7 +58,7 @@ typedef struct XLogContRecord | |||||||
| /* | /* | ||||||
|  * Each page of XLOG file has a header like this: |  * Each page of XLOG file has a header like this: | ||||||
|  */ |  */ | ||||||
| #define XLOG_PAGE_MAGIC 0xD05B	/* can be used as WAL version indicator */ | #define XLOG_PAGE_MAGIC 0xD05C	/* can be used as WAL version indicator */ | ||||||
|  |  | ||||||
| typedef struct XLogPageHeaderData | typedef struct XLogPageHeaderData | ||||||
| { | { | ||||||
| @@ -203,13 +203,6 @@ typedef XLogLongPageHeaderData *XLogLongPageHeader; | |||||||
|  |  | ||||||
| extern char XLogDir[MAXPGPATH]; | extern char XLogDir[MAXPGPATH]; | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * _INTL_MAXLOGRECSZ: max space needed for a record including header and |  | ||||||
|  * any backup-block data. |  | ||||||
|  */ |  | ||||||
| #define _INTL_MAXLOGRECSZ	(SizeOfXLogRecord + MAXLOGRECSZ + \ |  | ||||||
| 							 XLR_MAX_BKP_BLOCKS * (sizeof(BkpBlock) + BLCKSZ)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Method table for resource managers. |  * Method table for resource managers. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user