회원가입 ID/PW 찾기
AA

안녕하세요.
제가 AVR 정말 초보라 모르는게 너무많아 질문 올립니다.
ATmega128사용, 컴파일러는 CodevisionAVR을 사용하고 있습니다.

제가 CCD센서를 이용하여 광세기 변화에 따른 전압값을 ADC를 해야하는데,
우선, ADC의 실습을 위해 가변저항을 변화시키며 나온 전압값의 변화를
 LCD창 또는 "serial com"이라는 통신 프로그램 화면으로 출력하려고 하는데 어떤 원인으로 안되는지 전혀 모르겠습니다.ㅜㅜ
하기 소스는 제가 책보고 나름 레지스터 값을 설정해놓은 것입니다.
ADC를 꼭 해야하는데, 제가 너무 초보라서 이렇게 질문올립니다.
LCD 창 및  "serial com" 화면으로 출력되기 위해 어떻게 해야되나요?

답변 꼭 부탁드리며, 감사합니다..

------------------소스----------------------------------------------------------------------------

#include <mega128.h>                     //ATmega128라이브러리 선언                                       
#include <delay.h>                             //delay라이브러리 선언
#include <stdio.h>

unsigned int data;                       //AVR에서 컴퓨터로 전송시키기 위해 선언

#define ADC_VREF_TYPE 0x40               //외부의 AVcc단자로 입력된 전압 사용

 

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

// Read the AD conversion result
unsigned int read_adc(unsigned char adc_input)           //ADC_input=아날로그 입력 채널
{
ADMUX=adc_input | (ADC_VREF_TYPE & 0xff);               //아날로그 입력 채널과 외부의 AVcc단자 사용을 OR시켜 ADMUX레지스터에 대입

// Delay needed for the stabilization of the ADC input voltage
delay_us(10);

// Start the AD conversion
ADCSRA|=0x40;                                           //AD 컨버터 변환 시작 시점

// Wait for the AD conversion to complete
while ((ADCSRA & 0x10)==0);                             //AD 컨버터 변환이 종료될 때까지 polling방식으로 계속 대기
ADCSRA|=0x10;                                           //ADCSRA를 0x10으로 초기화
return ADCW;                                             //ADCL ADCH값을 16비트로 합친 ADCW 레지스터 선언

}

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

void Init_Serial(void)
{
UCSR0B = 0x18;              //포트 송신부와 수신부가 동작하도록 설정
UCSR0C = 0x16;              //8비트 데이터 전송
UBRR0H = 0x06;
UBRR0L = 0x67;              //9600 bps
}

void main(void)
{

PORTA=0x00;
DDRA=0x00;

// 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=0x00;

// Port C 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
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;

// Port E 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
PORTE=0x00;
DDRE=0x00;

// Port F 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
PORTF=0x00;
DDRF=0x00;

// Port G initialization
// Func4=In Func3=In Func2=In Func1=In Func0=In
// State4=T State3=T State2=T State1=T State0=T
PORTG=0x00;
DDRG=0x00;

// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: Timer 0 Stopped
// Mode: Normal top=FFh
// OC0 output: Disconnected
ASSR=0x00;
TCCR0=0x00;
TCNT0=0x00;
OCR0=0x00;

// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: Timer 1 Stopped
// Mode: Normal top=FFFFh
// OC1A output: Discon.
// OC1B output: Discon.
// OC1C output: Discon.
// Noise Canceler: Off
// Input Capture on Falling Edge
// Timer 1 Overflow Interrupt: Off
// Input Capture Interrupt: Off
// Compare A Match Interrupt: Off
// Compare B Match Interrupt: Off
// Compare C Match Interrupt: Off
TCCR1A=0x00;
TCCR1B=0x00;
TCNT1H=0x00;
TCNT1L=0x00;
ICR1H=0x00;
ICR1L=0x00;
OCR1AH=0x00;
OCR1AL=0x00;
OCR1BH=0x00;
OCR1BL=0x00;
OCR1CH=0x00;
OCR1CL=0x00;

// Timer/Counter 2 initialization
// Clock source: System Clock
// Clock value: Timer 2 Stopped
// Mode: Normal top=FFh
// OC2 output: Disconnected
TCCR2=0x00;
TCNT2=0x00;
OCR2=0x00;

// Timer/Counter 3 initialization
// Clock source: System Clock
// Clock value: Timer 3 Stopped
// Mode: Normal top=FFFFh
// Noise Canceler: Off
// Input Capture on Falling Edge
// OC3A output: Discon.
// OC3B output: Discon.
// OC3C output: Discon.
// Timer 3 Overflow Interrupt: Off
// Input Capture Interrupt: Off
// Compare A Match Interrupt: Off
// Compare B Match Interrupt: Off
// Compare C Match Interrupt: Off
TCCR3A=0x00;
TCCR3B=0x00;
TCNT3H=0x00;
TCNT3L=0x00;
ICR3H=0x00;
ICR3L=0x00;
OCR3AH=0x00;
OCR3AL=0x00;
OCR3BH=0x00;
OCR3BL=0x00;
OCR3CH=0x00;
OCR3CL=0x00;

// External Interrupt(s) initialization
EICRA=0x00;
EICRB=0x00;
EIMSK=0x00;

// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=0x00;
ETIMSK=0x00;

// Analog Comparator initialization
// Analog Comparator: Off
// Analog Comparator Input Capture by Timer/Counter 1: Off
ACSR=0x80;
SFIOR=0x00;

// ADC initialization
// ADC Clock frequency: 1000.000 kHz
// ADC Voltage Reference: AVCC pin
ADMUX=ADC_VREF_TYPE & 0xff;                           //define0x40 설정 되어있으므로 ADMUX=0x40과 같음
ADCSRA=0x84;                                          //AD컨버터 동작 허용, 16분주비 사용

Init_Serial();

while (1)
      {
      ADCSRA &=0x7F;
      ADMUX=0x40;
      data=read_adc(0);                              //입력 채널 ADC0를 사용하여 출력 값을 data에 넣음
      delay_ms(10);
     
      printf("%d\r\n",data);                         //data값을 출력
      delay_ms(1000);

      };
}

댓글 1
  • No Profile

    Init_Serial() 함수의 UCSR0C = 0x16;  은  0x16이 아니라 0x06일 것 같고요.  비동기방식이라.
    UBRR0H = 0x06;은  0x06이 아니라  0x00일 것 같습니다. 보레이트가 안 맞는 것 같아요.
    UBRR이 103인데 9600bps라면 크리스털은 16MHz 사용하시겠네요.

     

    main() 함수의 while(1) 문 안에 ADCSRA &=0x7F; 은 반대로  ADCSRA |=0x80; 로 해야  ADC가
    Enable 되겠죠.


하드웨어 설계 및 개발에 대하여 개발자들이 자유롭게 토론하는 공간입니다.
- Q&A, 자유주재 토론, 관련 정보 공유
- 분야 : 마이크로프로세서 응용, 전기/전자(아날로그/디지털) 회로 설계, C/C++ 프로그래밍, 펌웨어,
         PCB Artwork, 트러블슈팅 등 하드웨어 설계에 관한 전반인 내용
※ 게시글에 맞는 분류를 선택하여 글을 작성해 주시면 쾌적한 사이트 운영에 많은 도움이 됩니다.
※ 하드웨어 인사이트는 회원들간의 거래정보를 게재할 뿐이지, 그 어떤 책임과 의무도 가지지 않습니다.

search
번호 분류 제목 글쓴이 조회 수 날짜
452 마이크로프로세서 HOTKEIL Compiler에 대한 매뉴얼 파인 윤 1450 2010.02.25
451 마이크로프로세서 HOT초보인데요.. 개똥껄레 841 2010.02.20
450 펌웨어 & 코딩언어 HOT8051과 일반 C와 많이 차이나나요?5 개똥껄레 1093 2010.02.20
449 펌웨어 & 코딩언어 HOTblackfin 칩 부트코드 작성해보신분?1 퀴아쿠 859 2010.02.19
마이크로프로세서 HOTATmega128 ADC 관련하여 도움요청드립니다.1 쥬니치로 2972 2010.02.18
447 펌웨어 & 코딩언어 HOT어셈블리를 공부해야할까요?>8 GrayShark 1216 2010.02.17
446 마이크로프로세서 HOT책좀 추천해주세요 ^^;11 GrayShark 1249 2010.02.17
445 마이크로프로세서 HOTlcd backlight에 대한 질문입니다.1 strongman 1210 2010.02.10
444 마이크로프로세서 HOTatmega128 포트 a에 대한 질문입니다.2 strongman 1186 2010.02.09
443 마이크로프로세서 HOTkey matrix에 대한 질문2 strongman 3562 2010.02.09
442 마이크로프로세서 HOTwinide sim51 또는 프로테우스 에뮬레이터좀 사용하고 싶습니다.4 Eodrmfdl 3447 2010.02.09
441 마이크로프로세서 HOTAVR128 uart관련 질문올립니다.3 히야신스83 1331 2010.02.08
440 펌웨어 & 코딩언어 HOTC언어책 추천 해주세요 ㅋㅋ9 따라하다 1621 2010.02.06
439 Software & IDEs HOTatmega128에 대해 알기 쉬운 책 좀 알려주세요..5 마이무따이가 1471 2010.02.03
438 마이크로프로세서 HOT7-세그먼트관련 질문입니다...5 좋지 1169 2010.02.02
437 마이크로프로세서 HOT임베디드 제어법 개괄적으로 설명좀 해주세요1 수달달이짱 796 2010.01.30
436 마이크로프로세서 HOT제가 PIC18F8723칩을 찾고 있는데요. 엑스트라 1488 2010.01.29
435 마이크로프로세서 HOT8051을 처음 접하게 되었는데..2 타키온 1181 2010.01.27
434 마이크로프로세서 HOT8051참힘드네요.8 동키 1121 2010.01.26
433 마이크로프로세서 HOT팬틸트 제작( 2개 서보모터 따로 제어) 질문입니다.9 haze 3591 2010.01.25
Prev 1 ... 31 32 33 34 35 36 37 38 39 40 ... 58 Next
  • 시간을 잘 맞춘 침묵은 말보다 더 좋은 웅변이다.
    - 터퍼
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
  • 내 글이 추천받음 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.