mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 01:29:19 +03:00 
			
		
		
		
	Simplify do_pg_start_backup's API by opening pg_tblspc internally.
do_pg_start_backup() expects its callers to pass in an open DIR pointer for the pg_tblspc directory, but there's no apparent advantage in that. It complicates the callers without adding any flexibility, and there's no robustness advantage, since we surely have to be prepared for errors during the scan of pg_tblspc anyway. In fact, by holding an extra kernel resource during operations like the preliminary checkpoint, we might be making things a fraction more failure-prone not less. Hence, remove that argument and open the directory just for the duration of the actual scan. Discussion: https://postgr.es/m/28752.1512413887@sss.pgh.pa.us
This commit is contained in:
		| @@ -310,7 +310,7 @@ typedef enum SessionBackupState | ||||
| } SessionBackupState; | ||||
|  | ||||
| extern XLogRecPtr do_pg_start_backup(const char *backupidstr, bool fast, | ||||
| 				   TimeLineID *starttli_p, StringInfo labelfile, DIR *tblspcdir, | ||||
| 				   TimeLineID *starttli_p, StringInfo labelfile, | ||||
| 				   List **tablespaces, StringInfo tblspcmapfile, bool infotbssize, | ||||
| 				   bool needtblspcmapfile); | ||||
| extern XLogRecPtr do_pg_stop_backup(char *labelfile, bool waitforarchive, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user