Fixing deadlock in miner (#1569)
* Fixing deadlock in miner * Adding more comments [ci skip]
This commit is contained in:
		
							parent
							
								
									57c14eedfa
								
							
						
					
					
						commit
						eef9586c57
					
				| @ -301,6 +301,10 @@ impl Miner { | ||||
| 		let have_work = self.sealing_work.lock().unwrap().peek_last_ref().is_some(); | ||||
| 		trace!(target: "miner", "enable_and_prepare_sealing: have_work={}", have_work); | ||||
| 		if !have_work { | ||||
| 			// --------------------------------------------------------------------------
 | ||||
| 			// | NOTE Code below requires transaction_queue and sealing_work locks.     |
 | ||||
| 			// | Make sure to release the locks before calling that method.             |
 | ||||
| 			// --------------------------------------------------------------------------
 | ||||
| 			self.sealing_enabled.store(true, atomic::Ordering::Relaxed); | ||||
| 			self.prepare_sealing(chain); | ||||
| 		} | ||||
| @ -338,6 +342,10 @@ impl MinerService for Miner { | ||||
| 
 | ||||
| 	fn clear_and_reset(&self, chain: &MiningBlockChainClient) { | ||||
| 		self.transaction_queue.lock().unwrap().clear(); | ||||
| 		// --------------------------------------------------------------------------
 | ||||
| 		// | NOTE Code below requires transaction_queue and sealing_work locks.     |
 | ||||
| 		// | Make sure to release the locks before calling that method.             |
 | ||||
| 		// --------------------------------------------------------------------------
 | ||||
| 		self.update_sealing(chain); | ||||
| 	} | ||||
| 
 | ||||
| @ -493,11 +501,18 @@ impl MinerService for Miner { | ||||
| 	fn import_external_transactions(&self, chain: &MiningBlockChainClient, transactions: Vec<SignedTransaction>) -> | ||||
| 		Vec<Result<TransactionImportResult, Error>> { | ||||
| 
 | ||||
| 		let mut transaction_queue = self.transaction_queue.lock().unwrap(); | ||||
| 		let results = self.add_transactions_to_queue(chain, transactions, TransactionOrigin::External, | ||||
| 													 &mut transaction_queue); | ||||
| 		let results = { | ||||
| 			let mut transaction_queue = self.transaction_queue.lock().unwrap(); | ||||
| 			self.add_transactions_to_queue( | ||||
| 				chain, transactions, TransactionOrigin::External, &mut transaction_queue | ||||
| 			) | ||||
| 		}; | ||||
| 
 | ||||
| 		if !results.is_empty() && self.options.reseal_on_external_tx &&	self.tx_reseal_allowed() { | ||||
| 			// --------------------------------------------------------------------------
 | ||||
| 			// | NOTE Code below requires transaction_queue and sealing_work locks.     |
 | ||||
| 			// | Make sure to release the locks before calling that method.             |
 | ||||
| 			// --------------------------------------------------------------------------
 | ||||
| 			self.update_sealing(chain); | ||||
| 		} | ||||
| 		results | ||||
| @ -531,6 +546,10 @@ impl MinerService for Miner { | ||||
| 			import | ||||
| 		}; | ||||
| 
 | ||||
| 		// --------------------------------------------------------------------------
 | ||||
| 		// | NOTE Code below requires transaction_queue and sealing_work locks.     |
 | ||||
| 		// | Make sure to release the locks before calling that method.             |
 | ||||
| 		// --------------------------------------------------------------------------
 | ||||
| 		if imported.is_ok() && self.options.reseal_on_own_tx && self.tx_reseal_allowed() { | ||||
| 			// Make sure to do it after transaction is imported and lock is droped.
 | ||||
| 			// We need to create pending block and enable sealing
 | ||||
| @ -625,6 +644,10 @@ impl MinerService for Miner { | ||||
| 				self.sealing_work.lock().unwrap().reset(); | ||||
| 			} else { | ||||
| 				*self.next_allowed_reseal.lock().unwrap() = Instant::now() + self.options.reseal_min_period; | ||||
| 				// --------------------------------------------------------------------------
 | ||||
| 				// | NOTE Code below requires transaction_queue and sealing_work locks.     |
 | ||||
| 				// | Make sure to release the locks before calling that method.             |
 | ||||
| 				// --------------------------------------------------------------------------
 | ||||
| 				self.prepare_sealing(chain); | ||||
| 			} | ||||
| 		} | ||||
| @ -715,6 +738,10 @@ impl MinerService for Miner { | ||||
| 			}); | ||||
| 		} | ||||
| 
 | ||||
| 		// --------------------------------------------------------------------------
 | ||||
| 		// | NOTE Code below requires transaction_queue and sealing_work locks.     |
 | ||||
| 		// | Make sure to release the locks before calling that method.             |
 | ||||
| 		// --------------------------------------------------------------------------
 | ||||
| 		self.update_sealing(chain); | ||||
| 	} | ||||
| } | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user