Ensure judging the SF trigger by relative branch (#1399)
Rather than just the canon chain.
This commit is contained in:
		
							parent
							
								
									9a1e1b7c89
								
							
						
					
					
						commit
						230c6c889a
					
				| @ -230,7 +230,7 @@ impl<V> Client<V> where V: Verifier { | |||||||
| 		let last_hashes = self.build_last_hashes(header.parent_hash.clone()); | 		let last_hashes = self.build_last_hashes(header.parent_hash.clone()); | ||||||
| 		let db = self.state_db.lock().unwrap().boxed_clone(); | 		let db = self.state_db.lock().unwrap().boxed_clone(); | ||||||
| 
 | 
 | ||||||
| 		let enact_result = enact_verified(&block, engine, self.tracedb.tracing_enabled(), db, &parent, last_hashes, self.dao_rescue_block_gas_limit(), &self.vm_factory); | 		let enact_result = enact_verified(&block, engine, self.tracedb.tracing_enabled(), db, &parent, last_hashes, self.dao_rescue_block_gas_limit(header.parent_hash.clone()), &self.vm_factory); | ||||||
| 		if let Err(e) = enact_result { | 		if let Err(e) = enact_result { | ||||||
| 			warn!(target: "client", "Block import failed for #{} ({})\nError: {:?}", header.number(), header.hash(), e); | 			warn!(target: "client", "Block import failed for #{} ({})\nError: {:?}", header.number(), header.hash(), e); | ||||||
| 			return Err(()); | 			return Err(()); | ||||||
| @ -486,7 +486,7 @@ impl<V> BlockChainClient for Client<V> where V: Verifier { | |||||||
| 			last_hashes: last_hashes, | 			last_hashes: last_hashes, | ||||||
| 			gas_used: U256::zero(), | 			gas_used: U256::zero(), | ||||||
| 			gas_limit: U256::max_value(), | 			gas_limit: U256::max_value(), | ||||||
| 			dao_rescue_block_gas_limit: self.dao_rescue_block_gas_limit(), | 			dao_rescue_block_gas_limit: self.dao_rescue_block_gas_limit(view.parent_hash()), | ||||||
| 		}; | 		}; | ||||||
| 		// that's just a copy of the state.
 | 		// that's just a copy of the state.
 | ||||||
| 		let mut state = self.state(); | 		let mut state = self.state(); | ||||||
| @ -808,7 +808,7 @@ impl<V> MiningBlockChainClient for Client<V> where V: Verifier { | |||||||
| 			self.state_db.lock().unwrap().boxed_clone(), | 			self.state_db.lock().unwrap().boxed_clone(), | ||||||
| 			&self.chain.block_header(&h).expect("h is best block hash: so it's header must exist: qed"), | 			&self.chain.block_header(&h).expect("h is best block hash: so it's header must exist: qed"), | ||||||
| 			self.build_last_hashes(h.clone()), | 			self.build_last_hashes(h.clone()), | ||||||
| 			self.dao_rescue_block_gas_limit(), | 			self.dao_rescue_block_gas_limit(h.clone()), | ||||||
| 			author, | 			author, | ||||||
| 			gas_floor_target, | 			gas_floor_target, | ||||||
| 			extra_data, | 			extra_data, | ||||||
|  | |||||||
| @ -227,9 +227,19 @@ pub trait BlockChainClient : Sync + Send { | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 	/// Get `Some` gas limit of block 1_760_000, or `None` if chain is not yet that long.
 | 	/// Get `Some` gas limit of block 1_760_000, or `None` if chain is not yet that long.
 | ||||||
| 	fn dao_rescue_block_gas_limit(&self) -> Option<U256> { | 	fn dao_rescue_block_gas_limit(&self, chain_hash: H256) -> Option<U256> { | ||||||
| 		self.block_header(BlockID::Number(1_760_000)) | 		if let Some(mut header) = self.block_header(BlockID::Hash(chain_hash)) { | ||||||
| 			.map(|header| HeaderView::new(&header).gas_limit()) | 			if HeaderView::new(&header).number() < 1_760_000 { | ||||||
|  | 				None | ||||||
|  | 			} else { | ||||||
|  | 				while HeaderView::new(&header).number() != 1_760_000 { | ||||||
|  | 					header = self.block_header(BlockID::Hash(HeaderView::new(&header).parent_hash())).expect("chain is complete; parent of chain entry must be in chain; qed"); | ||||||
|  | 				} | ||||||
|  | 				Some(HeaderView::new(&header).gas_limit()) | ||||||
|  | 			} | ||||||
|  | 		} else { | ||||||
|  | 			None | ||||||
|  | 		} | ||||||
| 	}	
 | 	}	
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -274,7 +274,7 @@ impl MinerService for Miner { | |||||||
| 					last_hashes: last_hashes, | 					last_hashes: last_hashes, | ||||||
| 					gas_used: U256::zero(), | 					gas_used: U256::zero(), | ||||||
| 					gas_limit: U256::max_value(), | 					gas_limit: U256::max_value(), | ||||||
| 					dao_rescue_block_gas_limit: chain.dao_rescue_block_gas_limit(), | 					dao_rescue_block_gas_limit: chain.dao_rescue_block_gas_limit(header.parent_hash().clone()), | ||||||
| 				}; | 				}; | ||||||
| 				// that's just a copy of the state.
 | 				// that's just a copy of the state.
 | ||||||
| 				let mut state = block.state().clone(); | 				let mut state = block.state().clone(); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user