-
Path: news-archive.icm.edu.pl!news.gazeta.pl!not-for-mail
From: "Greg\(G.Kasprowicz\)" <G...@C...CH>
Newsgroups: pl.misc.elektronika
Subject: czyzby bug w atmega640?
Date: Fri, 6 Feb 2009 18:07:00 +0100
Organization: "Portal Gazeta.pl -> http://www.gazeta.pl"
Lines: 60
Message-ID: <gmhqnm$kvc$1@inews.gazeta.pl>
NNTP-Posting-Host: abpc11059.cern.ch
X-Trace: inews.gazeta.pl 1233940022 21484 137.138.198.168 (6 Feb 2009 17:07:02 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Fri, 6 Feb 2009 17:07:02 +0000 (UTC)
X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2900.5579
X-Priority: 3
X-RFC2646: Format=Flowed; Original
X-Newsreader: Microsoft Outlook Express 6.00.2900.5512
X-User: gkasprow
X-MSMail-Priority: Normal
Xref: news-archive.icm.edu.pl pl.misc.elektronika:556133
[ ukryj nagłówki ]Hej
mam sobie taki problem w mega640
jest sobie ADC, pedzony z 250kHz, trygerowany z timera T0, sygnalem compare
MATCHA
no i wszystko smiga pieknie, dostaje przerwania od ADC co zalozony czas.
Dla celow debugowych sobie wlaczylem generacje sygnalu prostokatnego na OC0A
Problem jest gdy wylacze przerwanie od T0 - ADC staje, pomimo ze sygnal na
OC0A sobie nadal jest..
Na razie rozwiazalem to tak:
void (TIMER0_COMPA_vect) (void) __attribute__ ((signal, __INTR_ATTRS))
__attribute__((naked));
void (TIMER0_COMPA_vect) (void)
//timer 0 interrupt - not used, T0 is used to generate the ADC clock only
//SIGNAL(TIMER0_COMPA_vect) //debug interrupt ftom timer 0
{
asm("reti");
}
czyli pozwalam mu wejsc do przerwania po to by zaraz wyjsc.
Dziala, ale to nieeleganckie.
Ma ktos z Was pomysl o co chodzi?
Wyglada tak, jakby cos blokowalo przerwanie od ADC. Czyzby nieobsluzone
wylaczone przerwanie od T0? troche to bez sensu, aczkolwiek kiedys
przerabialem taki problem w prockach Cypressa.
konfiguracja ADC:
//ADC init, ext REF,left adjust (8 bit mode), MUX= ADC0, MUX5 switches
between ADC15..8 and ADC7..0
ADMUX = (1<<ADLAR);
//enable ADC,start first conversion, auto trigger enabled,enable ADC
interrupt,
ADCSRA = (1<<ADEN)| (1<<ADATE)| (1<<ADIE)| (1<<ADPS2) | (1<<ADPS0);
//mux5 disabled,enable triggering by the timer T0 compare match A - CTC
mode
ADCSRB = (0<<MUX5) | (1<<ADTS1)| (1<<ADTS0);
konfiguracja T0
TCCR0A = (1<<WGM01) | (1<<COM0A0) ; // mode CTC
TCCR0B = (0<<CS01)|(0<<CS00); // prescaller /64 -> 250kHz -> 4us clk
period,//stop T0 at the moment
OCR0A = 100; //enter some value to avoid generation of excessive interrupts
TIMSK0 = (1<<OCIE0A); // enable T0 interrupts.
ADCSRA |= (1<<ADIF); //clear pending ADC interrupts
ADCSRA |= (1<<ADSC); //start 1-st conversion
Najnowsze wątki z tej grupy
- Coś dusi.
- akumulator napięcie 12.0v
- Podłączenie DMA 8257 do 8085
- pozew za naprawę sprzętu na youtube
- gasik
- Zbieranie danych przez www
- reverse engineering i dodawanie elementów do istniejących zamkniętych produktów- legalne?
- Problem z odczytem karty CF
- 74F vs 74HCT
- Newag ciąg dalszy
- Digikey, SN74CBT3253CD, FST3253, ktoś ma?
- Szukam: czujnik ruchu z możliwością zaączenia na stałe
- kabelek - kynar ?
- Podnieść masę o 0.6V
- Moduł BT BLE 5.0
Najnowsze wątki
- 2025-01-12 Jak na naszych oczach odradza się cenzura :-)
- 2025-01-11 Koszty prowadzenia firmy za granicą
- 2025-01-11 19 migrantów
- 2025-01-11 300km/h
- 2025-01-11 Kongres USA uchwalił "Prawo babci Pawlakowej" na MTK [Lex Gradma Pawlak]
- 2025-01-11 Riga => Specjalista ds. public relations <=
- 2025-01-11 Przestępca wyborczy Musk nadciąga nad Tuskistan?
- 2025-01-11 Białystok => Delphi Programmer <=
- 2025-01-09 Jaka nawigacja z asystentem zmiany pasa ruchu?
- 2025-01-10 Coś dusi.
- 2025-01-09 akumulator napięcie 12.0v
- 2025-01-10 Białystok => Architekt rozwiązań (doświadczenie w obszarze Java, A
- 2025-01-10 Warszawa => Software .Net Developer <=
- 2025-01-10 Białystok => Application Security Engineer <=
- 2025-01-10 Warszawa => System Architect (Java background) <=