ATMega_2560_Embedded_THT/ADC/main.c

23 lines
748 B
C
Raw Permalink Normal View History

2022-10-04 18:52:43 +05:30
//ADC
#include <avr/io.h>
#define F_CPU 16000000//16MHz
int main(void)
{
DDRL = 0xff;//port L direction: output //pins- 49:42
DDRC = 0xff;//port C direction: output //pins- 37:30
2022-10-05 20:05:08 +05:30
//DDRA = 0x00;//port A direction: input //pins- 22:29
2022-10-04 18:52:43 +05:30
ADCSRA = 0x87;// ADC enabled and prescaler=128
2022-10-05 20:05:08 +05:30
ADMUX = 0x61;// Ref= Vcc// data is left-justified //ADC0 is source pin
2022-10-04 18:52:43 +05:30
while(1)
{
2022-10-05 20:05:08 +05:30
//ADIF=0 ifu wanna reset, otherwise you keep it as 1 so that conversion doesnt start again
//ADCSRA |= (1<<ADSC); //to start conversion, we set ADSC bit to 1
ADCSRA |= 0x40; //ADSC=1
//while(ADCSRA && (1<<ADIF)==0);// waiting for conversion to finish
while(ADIF==0);
2022-10-04 18:52:43 +05:30
PORTL = ADCL;
PORTC = ADCH;
}
}