mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-21 02:52:47 +03:00 
			
		
		
		
	amcheck: Fixes for right page check during unique constraint check
* Don't forget to pfree() the right page when it's to be ignored.
 * Report error on unexpected non-leaf right page even if this page is not
   to be ignored.  This restores the logic which was unintendedly changed
   in 97e5b0026f.
Reported-by: Pavel Borisov
			
			
This commit is contained in:
		| @@ -1901,6 +1901,10 @@ bt_target_page_check(BtreeCheckState *state) | ||||
|  | ||||
| 					if (P_IGNORE(topaque)) | ||||
| 					{ | ||||
| 						pfree(rightpage); | ||||
| 						break; | ||||
| 					} | ||||
|  | ||||
| 					if (unlikely(!P_ISLEAF(topaque))) | ||||
| 						ereport(ERROR, | ||||
| 								(errcode(ERRCODE_INDEX_CORRUPTED), | ||||
| @@ -1909,9 +1913,7 @@ bt_target_page_check(BtreeCheckState *state) | ||||
| 								 errdetail_internal("Block=%u page lsn=%X/%X.", | ||||
| 													state->targetblock, | ||||
| 													LSN_FORMAT_ARGS(state->targetlsn)))); | ||||
| 						else | ||||
| 							break; | ||||
| 					} | ||||
|  | ||||
| 					itemid = PageGetItemIdCareful(state, rightblock_number, | ||||
| 												  rightpage, | ||||
| 												  rightfirstoffset); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user