Чт авг 16, 2018 13:54:59
изучите, наконец, даташит - с WDT просто так работать нельзя, надо выдерживать определенную последовательность действий при смене его режима работы. не надо гадать - в даташите есть примеры, которые будут работать.SIM31 писал(а):Все равно каждые 2 секунды перезагружает после отработки прерывания.
Вс авг 19, 2018 02:51:15
Чт авг 23, 2018 11:13:27
#include <mega328p.h>
//используем стандартную процедуру задержки
#include <delay.h>
// Declare your global variables here
// Standard Input/Output functions
#include <stdio.h>
// TWI functions
#include <twi.h>
#define KEY1 (1<<PORTD2)
#define KEY2 (1<<PORTD3)
#define ANYKEY (KEY1 | KEY2)
#define NOKEY 0
unsigned char getkey(void)
{
unsigned char key = ~(PIND & ANYKEY);
delay_ms(20);
if(~(PIND & ANYKEY) == key)
return key;
else
return NOKEY;
}
void main(void)
{
// Declare your local variables here
// Crystal Oscillator division factor: 1
#pragma optsize-
CLKPR=(1<<CLKPCE);
CLKPR=(0<<CLKPCE) | (0<<CLKPS3) | (0<<CLKPS2) | (0<<CLKPS1) | (0<<CLKPS0);
#ifdef _OPTIMIZE_SIZE_
#pragma optsize+
#endif
// Input/Output Ports initialization
// Port B initialization
// Function: Bit7=In Bit6=In Bit5=In Bit4=In Bit3=Out Bit2=Out Bit1=Out Bit0=Out
DDRB=(0<<DDB7) | (0<<DDB6) | (0<<DDB5) | (0<<DDB4) | (1<<DDB3) | (1<<DDB2) | (1<<DDB1) | (1<<DDB0);
// State: Bit7=T Bit6=T Bit5=T Bit4=T Bit3=0 Bit2=0 Bit1=0 Bit0=0
PORTB=(0<<PORTB7) | (0<<PORTB6) | (0<<PORTB5) | (0<<PORTB4) | (0<<PORTB3) | (0<<PORTB2) | (0<<PORTB1) | (0<<PORTB0);
// Port C initialization
// Function: Bit6=In Bit5=In Bit4=In Bit3=In Bit2=In Bit1=In Bit0=In
DDRC=(0<<DDC6) | (0<<DDC5) | (0<<DDC4) | (0<<DDC3) | (0<<DDC2) | (0<<DDC1) | (0<<DDC0);
// State: Bit6=T Bit5=T Bit4=T Bit3=T Bit2=T Bit1=T Bit0=T
PORTC=(0<<PORTC6) | (0<<PORTC5) | (0<<PORTC4) | (0<<PORTC3) | (0<<PORTC2) | (0<<PORTC1) | (0<<PORTC0);
// Port D initialization
// Function: Bit7=In Bit6=In Bit5=In Bit4=In Bit3=In Bit2=In Bit1=In Bit0=In
DDRD=(0<<DDD7) | (0<<DDD6) | (0<<DDD5) | (0<<DDD4) | (0<<DDD3) | (0<<DDD2) | (0<<DDD1) | (0<<DDD0);
// State: Bit7=P Bit6=P Bit5=P Bit4=P Bit3=P Bit2=P Bit1=T Bit0=T
PORTD=(1<<PORTD7) | (1<<PORTD6) | (1<<PORTD5) | (1<<PORTD4) | (1<<PORTD3) | (1<<PORTD2) | (0<<PORTD1) | (0<<PORTD0);
// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: Timer 0 Stopped
// Mode: Normal top=0xFF
// OC0A output: Disconnected
// OC0B output: Disconnected
TCCR0A=(0<<COM0A1) | (0<<COM0A0) | (0<<COM0B1) | (0<<COM0B0) | (0<<WGM01) | (0<<WGM00);
TCCR0B=(0<<WGM02) | (0<<CS02) | (0<<CS01) | (0<<CS00);
TCNT0=0x00;
OCR0A=0x00;
OCR0B=0x00;
// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: Timer1 Stopped
// Mode: Normal top=0xFFFF
// OC1A output: Disconnected
// OC1B output: Disconnected
// Noise Canceler: Off
// Input Capture on Falling Edge
// Timer1 Overflow Interrupt: Off
// Input Capture Interrupt: Off
// Compare A Match Interrupt: Off
// Compare B Match Interrupt: Off
TCCR1A=(0<<COM1A1) | (0<<COM1A0) | (0<<COM1B1) | (0<<COM1B0) | (0<<WGM11) | (0<<WGM10);
TCCR1B=(0<<ICNC1) | (0<<ICES1) | (0<<WGM13) | (0<<WGM12) | (0<<CS12) | (0<<CS11) | (0<<CS10);
TCNT1H=0x00;
TCNT1L=0x00;
ICR1H=0x00;
ICR1L=0x00;
OCR1AH=0x00;
OCR1AL=0x00;
OCR1BH=0x00;
OCR1BL=0x00;
// Timer/Counter 2 initialization
// Clock source: System Clock
// Clock value: Timer2 Stopped
// Mode: Normal top=0xFF
// OC2A output: Disconnected
// OC2B output: Disconnected
ASSR=(0<<EXCLK) | (0<<AS2);
TCCR2A=(0<<COM2A1) | (0<<COM2A0) | (0<<COM2B1) | (0<<COM2B0) | (0<<WGM21) | (0<<WGM20);
TCCR2B=(0<<WGM22) | (0<<CS22) | (0<<CS21) | (0<<CS20);
TCNT2=0x00;
OCR2A=0x00;
OCR2B=0x00;
// Timer/Counter 0 Interrupt(s) initialization
TIMSK0=(0<<OCIE0B) | (0<<OCIE0A) | (0<<TOIE0);
// Timer/Counter 1 Interrupt(s) initialization
TIMSK1=(0<<ICIE1) | (0<<OCIE1B) | (0<<OCIE1A) | (0<<TOIE1);
// Timer/Counter 2 Interrupt(s) initialization
TIMSK2=(0<<OCIE2B) | (0<<OCIE2A) | (0<<TOIE2);
// External Interrupt(s) initialization
// INT0: Off
// INT1: Off
// Interrupt on any change on pins PCINT0-7: Off
// Interrupt on any change on pins PCINT8-14: Off
// Interrupt on any change on pins PCINT16-23: Off
EICRA=(0<<ISC11) | (0<<ISC10) | (0<<ISC01) | (0<<ISC00);
EIMSK=(0<<INT1) | (0<<INT0);
PCICR=(0<<PCIE2) | (0<<PCIE1) | (0<<PCIE0);
// USART initialization
// Communication Parameters: 8 Data, 1 Stop, No Parity
// USART Receiver: On
// USART Transmitter: On
// USART0 Mode: Asynchronous
// USART Baud Rate: 9600
UCSR0A=(0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
UCSR0B=(0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (1<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80);
UCSR0C=(0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0);
UBRR0H=0x00;
UBRR0L=0x67;
// Analog Comparator initialization
// Analog Comparator: Off
// The Analog Comparator's positive input is
// connected to the AIN0 pin
// The Analog Comparator's negative input is
// connected to the AIN1 pin
ACSR=(1<<ACD) | (0<<ACBG) | (0<<ACO) | (0<<ACI) | (0<<ACIE) | (0<<ACIC) | (0<<ACIS1) | (0<<ACIS0);
ADCSRB=(0<<ACME);
// Digital input buffer on AIN0: On
// Digital input buffer on AIN1: On
DIDR1=(0<<AIN0D) | (0<<AIN1D);
// ADC initialization
// ADC disabled
ADCSRA=(0<<ADEN) | (0<<ADSC) | (0<<ADATE) | (0<<ADIF) | (0<<ADIE) | (0<<ADPS2) | (0<<ADPS1) | (0<<ADPS0);
// SPI initialization
// SPI disabled
SPCR=(0<<SPIE) | (0<<SPE) | (0<<DORD) | (0<<MSTR) | (0<<CPOL) | (0<<CPHA) | (0<<SPR1) | (0<<SPR0);
// TWI initialization
// Mode: TWI Master
// Bit Rate: 100 kHz
twi_master_init(100);
// Global enable interrupts
#asm("sei")
while (1)
{
// Place your code here
switch(getkey())
{
case KEY1:
// обработка кнопки 1
PORTB.2=1;
break;
}
}
}
unsigned char getkey(void){
unsigned char key;
key = ~PIND & ANYKEY;
delay_ms(15);
if(key == (~PIND & ANYKEY))
return key;
else
return NOKEY;
}
unsigned char getkey(void)
{
unsigned char key = ~(PIND & ANYKEY);
delay_ms(20);
if(~(PIND & ANYKEY) == key)
return key;
else
return NOKEY;
}
Пн авг 27, 2018 06:33:13
Пн авг 27, 2018 07:01:07
Пн авг 27, 2018 07:04:47
Пн авг 27, 2018 09:18:01
Пн авг 27, 2018 09:48:25
Пн авг 27, 2018 10:13:26
Пн авг 27, 2018 10:50:26
Вт авг 28, 2018 20:48:15
Вт авг 28, 2018 22:16:46
Ср авг 29, 2018 05:33:15
Ср авг 29, 2018 05:37:45
Ср авг 29, 2018 06:32:26
Ср авг 29, 2018 06:57:29
Чт ноя 01, 2018 17:45:14
#include <mega8.h>
#include <delay.h>
unsigned char i,OFcount,var[4],zamer_T,c3,c2,c1,c0;
unsigned long T,f;
unsigned int rising1,rising2;
static flash unsigned char SEGMENTE[]= // масив для индикатора
{
(0b10111110), // 0
(0b10001000), // 1
(0b11110010), // 2
(0b11011010), // 3
(0b11001100), // 4
(0b01011110), // 5
(0b01111110), // 6
(0b10001010), // 7
(0b11111110), // 8
(0b11011110), // 9
};
void bcd(unsigned long s)
{
c3=0;c2=0;c1=0;
while (s>=1000){s-=1000;c3++;}
while (s>=100){s-=100;c2++;}
while (s>=10){s-=10;c1++;}
c0=s;
}
interrupt [TIM1_OVF] void timer1_ovf_isr(void)
{
OFcount++;//считаем количество переполнений
}
interrupt [TIM1_CAPT] void timer1_capt_isr(void)
{
switch(zamer_T)
{
case 0:
rising1 = ICR1; // Запоминаем значение счётчика
OFcount = 0; // Обнуляем количество переполнений счётчика
zamer_T = 1; // Переходим к следующему вычислению
break;
case 1:
rising2 = ICR1; // Запоминаем значение счётчика
T = (unsigned long)rising2 - (unsigned long)rising1 + ((unsigned long)OFcount * 65536); // Приводим все переменные к одному типу и вычисляем период импульса
f = 30000000/T; // Вычисляем обороты в минуту
zamer_T = 0;
break;
}
}
// Индикация
interrupt [TIM0_OVF] void timer0_ovf_isr(void)
{
TCNT0=0x06;
PORTC &=~ (1<<i);
i++;
if(i>=4)i=0;
PORTB=SEGMENTE[var[i]]; //значение для индикации
PORTC |= (1<<i);
}
void main(void)
{
DDRB=(1<<DDB7) | (1<<DDB6) | (1<<DDB5) | (1<<DDB4) | (1<<DDB3) | (1<<DDB2) | (1<<DDB1) | (0<<DDB0);
PORTB=(0<<PORTB7) | (0<<PORTB6) | (0<<PORTB5) | (0<<PORTB4) | (0<<PORTB3) | (0<<PORTB2) | (0<<PORTB1) | (1<<PORTB0);
DDRC=(0<<DDC6) | (0<<DDC5) | (0<<DDC4) | (1<<DDC3) | (1<<DDC2) | (1<<DDC1) | (1<<DDC0);
PORTC=(0<<PORTC6) | (0<<PORTC5) | (0<<PORTC4) | (0<<PORTC3) | (0<<PORTC2) | (0<<PORTC1) | (0<<PORTC0);
DDRD=(0<<DDD7) | (0<<DDD6) | (0<<DDD5) | (0<<DDD4) | (0<<DDD3) | (0<<DDD2) | (0<<DDD1) | (0<<DDD0);
PORTD=(0<<PORTD7) | (0<<PORTD6) | (0<<PORTD5) | (0<<PORTD4) | (0<<PORTD3) | (0<<PORTD2) | (0<<PORTD1) | (0<<PORTD0);
// Clock value: 125,000 kHz
TCCR0=(0<<CS02) | (1<<CS01) | (1<<CS00);
TCNT0=0x06;
// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: 125,000 kHz
// Mode: Normal top=0xFFFF
// Input Capture on Rising Edge
// Input Capture Interrupt: On
TCCR1A=0x00;
TCCR1B=0xC2;
TCNT1=0x00;
ICR1=0x00;
TIMSK=(0<<OCIE2) | (0<<TOIE2) | (1<<TICIE1) | (0<<OCIE1A) | (0<<OCIE1B) | (1<<TOIE1) | (1<<TOIE0);
#asm("sei")
while (1)
{
var[0]=c3;
var[1]=c2;
var[2]=c0;
var[3]=c1;
bcd(f);
}
}
Чт ноя 01, 2018 21:06:25
interrupt [TIM0_OVF] void timer0_ovf_isr(void)
{
TCNT0=0x06;
...
PORTB=SEGMENTE[var[i]]; //значение для индикации
PORTC |= (1<<i);
if (OFcount>1000) f=0; // в счетчике интервала значение за разумными пределами
}
interrupt [TIM1_OVF] void timer1_ovf_isr(void)
{
OFcount++;//считаем количество переполнений
if (OFcount>1000) f=0; // в счетчике интервала значение за разумными пределами
}
Чт ноя 01, 2018 21:25:28
Спасибо. Но не один не второй вариант не дал ни какого результата.SIM31 писал(а):сделать проверку в конце
Чт ноя 01, 2018 21:53:02