mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Always pfree strings returned by GetDatabasePath
Several places didn't do it, and in many cases it didn't matter because
it would be a small allocation in a short-lived context; but other
places may accumulate a few (for example, in CreateDatabaseUsingFileCopy,
one per tablespace).  In most databases this is highly unlikely to be
very serious either, but it seems better to make the code consistent in
case there's future copy-and-paste.
The only case of actual concern seems to be the aforementioned routine,
which is new with commit 9c08aea6a3, so there's no need to backpatch.
As pointed out by Coverity.
			
			
This commit is contained in:
		| @@ -217,6 +217,8 @@ CreateDatabaseUsingWalLog(Oid src_dboid, Oid dst_dboid, | |||||||
| 		UnlockRelationId(&dstrelid, AccessShareLock); | 		UnlockRelationId(&dstrelid, AccessShareLock); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	pfree(srcpath); | ||||||
|  | 	pfree(dstpath); | ||||||
| 	list_free_deep(rnodelist); | 	list_free_deep(rnodelist); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -628,6 +630,8 @@ CreateDatabaseUsingFileCopy(Oid src_dboid, Oid dst_dboid, Oid src_tsid, | |||||||
| 			(void) XLogInsert(RM_DBASE_ID, | 			(void) XLogInsert(RM_DBASE_ID, | ||||||
| 							  XLOG_DBASE_CREATE_FILE_COPY | XLR_SPECIAL_REL_UPDATE); | 							  XLOG_DBASE_CREATE_FILE_COPY | XLR_SPECIAL_REL_UPDATE); | ||||||
| 		} | 		} | ||||||
|  | 		pfree(srcpath); | ||||||
|  | 		pfree(dstpath); | ||||||
| 	} | 	} | ||||||
| 	table_endscan(scan); | 	table_endscan(scan); | ||||||
| 	table_close(rel, AccessShareLock); | 	table_close(rel, AccessShareLock); | ||||||
| @@ -2128,6 +2132,9 @@ movedb(const char *dbname, const char *tblspcname) | |||||||
| 	/* Now it's safe to release the database lock */ | 	/* Now it's safe to release the database lock */ | ||||||
| 	UnlockSharedObjectForSession(DatabaseRelationId, db_id, 0, | 	UnlockSharedObjectForSession(DatabaseRelationId, db_id, 0, | ||||||
| 								 AccessExclusiveLock); | 								 AccessExclusiveLock); | ||||||
|  |  | ||||||
|  | 	pfree(src_dbpath); | ||||||
|  | 	pfree(dst_dbpath); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* Error cleanup callback for movedb */ | /* Error cleanup callback for movedb */ | ||||||
| @@ -2141,6 +2148,8 @@ movedb_failure_callback(int code, Datum arg) | |||||||
| 	dstpath = GetDatabasePath(fparms->dest_dboid, fparms->dest_tsoid); | 	dstpath = GetDatabasePath(fparms->dest_dboid, fparms->dest_tsoid); | ||||||
|  |  | ||||||
| 	(void) rmtree(dstpath, true); | 	(void) rmtree(dstpath, true); | ||||||
|  |  | ||||||
|  | 	pfree(dstpath); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -3051,6 +3060,9 @@ dbase_redo(XLogReaderState *record) | |||||||
| 		 * We don't need to copy subdirectories | 		 * We don't need to copy subdirectories | ||||||
| 		 */ | 		 */ | ||||||
| 		copydir(src_path, dst_path, false); | 		copydir(src_path, dst_path, false); | ||||||
|  |  | ||||||
|  | 		pfree(src_path); | ||||||
|  | 		pfree(dst_path); | ||||||
| 	} | 	} | ||||||
| 	else if (info == XLOG_DBASE_CREATE_WAL_LOG) | 	else if (info == XLOG_DBASE_CREATE_WAL_LOG) | ||||||
| 	{ | 	{ | ||||||
| @@ -3063,6 +3075,7 @@ dbase_redo(XLogReaderState *record) | |||||||
| 		/* Create the database directory with the version file. */ | 		/* Create the database directory with the version file. */ | ||||||
| 		CreateDirAndVersionFile(dbpath, xlrec->db_id, xlrec->tablespace_id, | 		CreateDirAndVersionFile(dbpath, xlrec->db_id, xlrec->tablespace_id, | ||||||
| 								true); | 								true); | ||||||
|  | 		pfree(dbpath); | ||||||
| 	} | 	} | ||||||
| 	else if (info == XLOG_DBASE_DROP) | 	else if (info == XLOG_DBASE_DROP) | ||||||
| 	{ | 	{ | ||||||
|   | |||||||
| @@ -1057,6 +1057,7 @@ InitPostgres(const char *in_dbname, Oid dboid, const char *username, | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	SetDatabasePath(fullpath); | 	SetDatabasePath(fullpath); | ||||||
|  | 	pfree(fullpath); | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| 	 * It's now possible to do real access to the system catalogs. | 	 * It's now possible to do real access to the system catalogs. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user