/*****************************************************
This program was produced by the
CodeWizardAVR V2.05.0 Professional
Automatic Program Generator
© Copyright 1998-2010 Pavel Haiduc, HP InfoTech s.r.l.
http://www.hpinfotech.com
Project :
Version :
Date : 21.04.2015
Author :
Company :
Comments:
Chip type : ATmega32L
Program type : Application
AVR Core Clock frequency: 16,000000 MHz
Memory model : Small
External RAM size : 0
Data Stack size : 512
*****************************************************/
#include <mega32.h>
#include <delay.h>
volatile unsigned char i;
// External Interrupt 0 service routine
interrupt [EXT_INT0] void ext_int0_isr(void)
{
// Place your code here
i=1;
/*PORTA=0b00001001;
delay_ms(1);
PORTA=0b00001000;
delay_ms(1);
PORTA=0b00001100;
delay_ms(1);
PORTA=0b00000100;
delay_ms(1);
PORTA=0b00000110;
delay_ms(1);
PORTA=0b00000010;
delay_ms(1);
PORTA=0b00000011;
delay_ms(1);
PORTA=0b00000001;
delay_ms(1); */
}
// External Interrupt 1 service routine
interrupt [EXT_INT1] void ext_int1_isr(void)
{
i=2;
/*PORTA=0b00000001;
delay_ms(1);
PORTA=0b00000011;
delay_ms(1);
PORTA=0b00000010;
delay_ms(1);
PORTA=0b00000110;
delay_ms(1);
PORTA=0b00000100;
delay_ms(1);
PORTA=0b00001100;
delay_ms(1);
PORTA=0b00001000;
delay_ms(1);
PORTA=0b00001001;
delay_ms(1); */
}
// Declare your global variables here
void main(void)
{
// Declare your local variables here
// Input/Output Ports initialization
// Port A initialization
// Func7=In Func6=In Func5=In Func4=In Func3=Out Func2=Out Func1=Out Func0=Out
// State7=T State6=T State5=T State4=T State3=0 State2=0 State1=0 State0=0
PORTA=0x00;
DDRA=0x0F;
PORTD=0x0C;
DDRD=0x00;
// External Interrupt(s) initialization
// INT0: On
// INT0 Mode: Low level
// INT1: On
// INT1 Mode: Low level
// INT2: Off
GICR|=0xC0;
MCUCR=0x00;
MCUCSR=0x00;
GIFR=0xC0;
// Global enable interrupts
#asm("sei")
while (1)
{
switch (i) {
case 1:
PORTA=0b00001001;
delay_ms(1);
PORTA=0b00001000;
delay_ms(1);
PORTA=0b00001100;
delay_ms(1);
PORTA=0b00000100;
delay_ms(1);
PORTA=0b00000110;
delay_ms(1);
PORTA=0b00000010;
delay_ms(1);
PORTA=0b00000011;
delay_ms(1);
PORTA=0b00000001;
delay_ms(1);
i=0;
break;
case 2:
PORTA=0b00000001;
delay_ms(1);
PORTA=0b00000011;
delay_ms(1);
PORTA=0b00000010;
delay_ms(1);
PORTA=0b00000110;
delay_ms(1);
PORTA=0b00000100;
delay_ms(1);
PORTA=0b00001100;
delay_ms(1);
PORTA=0b00001000;
delay_ms(1);
PORTA=0b00001001;
delay_ms(1);
i=0;
break;
}
}
}