Rescue clock of the AVRISP-MKII moved to the AVR's OCR1A pin, so that the clock can be generated at all times when 125KHz ISP programming mode is selected.
This commit is contained in:
		
							parent
							
								
									40db485c79
								
							
						
					
					
						commit
						3bf760ad7d
					
				
					 7 changed files with 56 additions and 25 deletions
				
			
		| 
						 | 
				
			
			@ -67,7 +67,7 @@ void SoftUART_Init(void)
 | 
			
		|||
	SoftUART_SetBaud(9600);
 | 
			
		||||
 | 
			
		||||
	/* Setup reception timer compare ISR */
 | 
			
		||||
	TIMSK1 = (1 << ICIE1);
 | 
			
		||||
	TIMSK2 = (1 << ICIE2);
 | 
			
		||||
 | 
			
		||||
	/* Setup transmission timer compare ISR and start the timer */
 | 
			
		||||
	TIMSK3 = (1 << ICIE3);
 | 
			
		||||
| 
						 | 
				
			
			@ -81,7 +81,7 @@ ISR(INT0_vect, ISR_BLOCK)
 | 
			
		|||
	RX_BitsRemaining = 8;
 | 
			
		||||
 | 
			
		||||
	/* Reset the bit reception timer */
 | 
			
		||||
	TCNT1 = 0;
 | 
			
		||||
	TCNT2 = 0;
 | 
			
		||||
 | 
			
		||||
	/* Check to see that the pin is still low (prevents glitches from starting a frame reception) */
 | 
			
		||||
	if (!(SRXPIN & (1 << SRX)))
 | 
			
		||||
| 
						 | 
				
			
			@ -90,12 +90,12 @@ ISR(INT0_vect, ISR_BLOCK)
 | 
			
		|||
		EIMSK = 0;
 | 
			
		||||
 | 
			
		||||
		/* Start the reception timer */
 | 
			
		||||
		TCCR1B = ((1 << CS10) | (1 << WGM13) | (1 << WGM12));
 | 
			
		||||
		TCCR2B = ((1 << CS20) | (1 << WGM23) | (1 << WGM22));
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/** ISR to manage the reception of bits to the software UART. */
 | 
			
		||||
ISR(TIMER1_CAPT_vect, ISR_BLOCK)
 | 
			
		||||
ISR(TIMER2_CAPT_vect, ISR_BLOCK)
 | 
			
		||||
{
 | 
			
		||||
	/* Cache the current RX pin value for later checking */
 | 
			
		||||
	uint8_t SRX_Cached = (SRXPIN & (1 << SRX));
 | 
			
		||||
| 
						 | 
				
			
			@ -114,7 +114,7 @@ ISR(TIMER1_CAPT_vect, ISR_BLOCK)
 | 
			
		|||
	else
 | 
			
		||||
	{
 | 
			
		||||
		/* Disable the reception timer as all data has now been received, re-enable start bit detection ISR */
 | 
			
		||||
		TCCR1B = 0;
 | 
			
		||||
		TCCR2B = 0;
 | 
			
		||||
		EIFR   = (1 << INTF0);
 | 
			
		||||
		EIMSK  = (1 << INT0);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue