#include <mega8.h>
#include <alcd.h>
#include <stdio.h>
unsigned char ADC;
unsigned char V[16];
int t,AD;
// Timer1 overflow interrupt service routine
interrupt [TIM1_OVF] void timer1_ovf_isr(void)
{
TCNT1H=0xCF2C;
ADCSRA=(1<<7)|(1<<6)|(1<<2)|(1<<1)|(1<<0)|(1<<3)|(1<<4);
t++;
}
interrupt [ADC_INT] void adc_isr(void)
{
ADC=ADCH;
AD=1;
}
// Declare your global variables here
void main(void)
{
// Declare your local variables here
// Input/Output Ports initialization
// Port B initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTB=0x00;
DDRB=0x01;
// Port C initialization
// Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTC=0x00;
DDRC=0x00;
// Port D initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTD=0x00;
DDRD=0x00;
TCCR1B=(1<<1);//делитель 8
TCNT1H=0xCF2C;//считаем с 12500
// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=0x04;
// ADC initialization
// ADC disabled
ADMUX=(1<<0)|(1<<5);//вход ADC
lcd_init(20);
// Global enable interrupts
#asm("sei")
while (1)
{
if(AD!=0)
{
sprintf(V,"%d",ADC);
lcd_gotoxy(0,0);
lcd_puts(V);
AD=0;
}
if(t>=5)
{
PORTB.0=1;
}
if(t>=10)
{
PORTB.0=0;
t=0;
}
}
}
ATMEGA8 АЦП (не хочет работать)
ATMEGA8 АЦП (не хочет работать)
[size=150][color=#FF0000]Во имя пpоцесса-отца, пpоцесса-сына и святаго root'а... АМИHЬ![/color][/size]
- Реклама
-
dimm1985
- Первый раз сказал Мяу!
- Сообщения: 39
- Зарегистрирован: Вс мар 20, 2011 17:09:31
- Откуда: Киев
Re: ATMEGA8 АЦП (не хочет работать)
Я вообще не понял как ты ацп инициализировал? Где регистр ADCSRA, ведь в нем находятся биты отвечающие за включение, запуск, предделитель частоты. Короче я бы делал так:
Добавляем к инклюдам:
#include <delay.h>
#define ADC_VREF_TYPE 0x00
Вместо:
nterrupt [ADC_INT] void adc_isr(void)
{
ADC=ADCH;
AD=1;
}
Пишем:
unsigned int read_adc(unsigned char adc_input)
{
ADMUX=adc_input | (ADC_VREF_TYPE & 0xff);
delay_us(10); // задержка необходимая для стабилизации напряжения на входе АЦП
ADCSRA|=0x40; // Start AD conversion
while ((ADCSRA & 0x10)==0); // Ждем пока AD conversion закончится
ADCSRA|=0x10;
ADC=ADCH;
return ADCH;
return ADCL;
}
В инициализации АЦП:
// ADC initialization
// Для частоты: 500,000 kHz (при XTAL = 4Mhz)
// Опорное на: AREF pin
ADMUX=ADC_VREF_TYPE & 0xff;
ADCSRA=0x83;
Ну а в коде:
Учти, что ADCH - это только 2 старших бита всего (10 битного) числа!!!
Все число = ADCH*256+ADCL;
Тип переменной unsigned char [0..256], поэтому если будешь использовать ADC в качестве всего числа то сделай его хотябы unsigned short
read_adc(0); // число в скобках обозначает номер входа
sprintf(V,"%d",ADC);
Добавляем к инклюдам:
#include <delay.h>
#define ADC_VREF_TYPE 0x00
Вместо:
nterrupt [ADC_INT] void adc_isr(void)
{
ADC=ADCH;
AD=1;
}
Пишем:
unsigned int read_adc(unsigned char adc_input)
{
ADMUX=adc_input | (ADC_VREF_TYPE & 0xff);
delay_us(10); // задержка необходимая для стабилизации напряжения на входе АЦП
ADCSRA|=0x40; // Start AD conversion
while ((ADCSRA & 0x10)==0); // Ждем пока AD conversion закончится
ADCSRA|=0x10;
ADC=ADCH;
return ADCH;
return ADCL;
}
В инициализации АЦП:
// ADC initialization
// Для частоты: 500,000 kHz (при XTAL = 4Mhz)
// Опорное на: AREF pin
ADMUX=ADC_VREF_TYPE & 0xff;
ADCSRA=0x83;
Ну а в коде:
Учти, что ADCH - это только 2 старших бита всего (10 битного) числа!!!
Все число = ADCH*256+ADCL;
Тип переменной unsigned char [0..256], поэтому если будешь использовать ADC в качестве всего числа то сделай его хотябы unsigned short
read_adc(0); // число в скобках обозначает номер входа
sprintf(V,"%d",ADC);
