-
Data: 2009-02-06 17:07:00
Temat: czyzby bug w atmega640?
Od: "Greg\(G.Kasprowicz\)" <G...@C...CH> szukaj wiadomości tego autora
[ pokaż wszystkie 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
- Kod zniżkowy w TME do 26.09.2025
- SFP, 10G, simplex sc/apc
- [słabe wiatry powodują - przyp. JMJ] Energetyczny paraliż w Niemczech
- NxtPaper
- Programiści nie przestają zadziwiać świat
- Długi kabel zasilający a na końcu procek
- Dlaczego nam nie idzie
- Co czujnik to inna temperatura
- Jak naprawić pilota
- Dlaczego TMP wer. 2.0 nie może być sprzedawany jako patyk USB lub karta PCIe 1x?!?
- produkcja w UE
- Pamięć SRAM nie działa z Z80182
- plyta indukcyjna - naprawa
- założyłem kamerę
- syrenki alarmów
Najnowsze wątki
- 2025-09-18 Kuczyński twierdzi że WIBOR nie jest do ruszenia w sądach
- 2025-09-18 Warszawa => Senior Account Manager <=
- 2025-09-18 Warszawa => OSS System Administrator <=
- 2025-09-18 Kraków => Koordynator Produkcji / Przedstawiciel ds. rozwoju produktu
- 2025-09-18 Ostrów Wielkopolski => Specjalista ds. Marketingu Online (PPC) <=
- 2025-09-18 pierwszy tel kupiłem za 1250zł
- 2025-09-17 jak się kupuje elektryczny?
- 2025-09-17 Kod zniżkowy w TME do 26.09.2025
- 2025-09-17 Ukraińcy uważają polski sys. antydronowy za najlepszy na Świecie, a rząd w III Rzeczy (pospolitej) woli sys. niemiecki
- 2025-09-17 Ukraińcy uważają polski sys. antydronowy za najlepszy na Świecie, a rząd w III Rzeczy (pospolitej) woli sys. niemiecki
- 2025-09-17 Warszawa => Dyrektor pionu IT <=
- 2025-09-17 Rzeszów => International Freight Forwarder <=
- 2025-09-16 China => Production Coordinator / Representant Product Dev <=
- 2025-09-16 Warszawa => Project Manager (AI and innovation) <=
- 2025-09-15 "Jeden telefon z Waszyngtonu i nasze samoloty nie wystartują" - czyli to co każdy koder wie