-
Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.onet.pl!not-for-mail
From: Michoo <m...@v...pl>
Newsgroups: pl.misc.elektronika
Subject: Re: ADC w ATMEGA16 i ilość stanów
Date: Fri, 30 Jul 2010 22:16:08 +0200
Organization: http://onet.pl
Lines: 49
Message-ID: <i2vbt7$1ti$1@news.onet.pl>
References: <f...@f...googlegroups.com>
<i2uu17$sq6$1@news.onet.pl>
<8...@d...googlegroups.com>
NNTP-Posting-Host: c6-100.icpnet.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: news.onet.pl 1280520936 1970 62.21.6.100 (30 Jul 2010 20:15:36 GMT)
X-Complaints-To: n...@o...pl
NNTP-Posting-Date: Fri, 30 Jul 2010 20:15:36 +0000 (UTC)
User-Agent: Mozilla-Thunderbird 2.0.0.22 (X11/20090706)
In-Reply-To: <8...@d...googlegroups.com>
Xref: news-archive.icm.edu.pl pl.misc.elektronika:593015
[ ukryj nagłówki ]Jan Górski pisze:
> Powinno być ?
Nie wiem co masz w układzie - to Twój projekt
Taka uwaga - nie wiem skąd u programistów uC bierze się maniera do
pisania w hex. Może od razu podawać adresy rejestrów zamiast ich
definicji? np. ((*(volatile uint8_t *)((0x06) + 0x20))) |= 0x20;
Jak piszesz ADMUX=0X40; to bez zajrzenia do dokumentacji kompletnie nie
wiem o co chodzi. A zaglądanie do dokumentacji marnuje mój czas. Jak byś
napisał ADMUX=_BV(REFS0); (jak twój kompilator nie ma to #define _BV(a)
(1<<a)) to od razu byłoby wiadomo co ustawiasz.
> KOD --------------
> void adc_init(void) // Function to initialise the ADC feature
> {
> ADCSRA=0X00;
> ADMUX=0X40;
> ADCSRA=0X47; // prescaler (128) + ADSC
> ADCSRA|=0X80; // ENABLE
Dla zasady wypadałoby tu poczekać na zakończenie tej pierwszej konwersji.
> }
> ------------------------
void setup_adc()
{
ADMUX = _BV(REFS0);
ADCSRA = 0b111;// /128
ADCSRA |= _BV(ADEN) | _BV(ADSC);
while( ADCSRA & _BV(ADSC) )
;
}
nie jest czytelniejsze?
> unsigned int adc_start(unsigned char channel) // Function to perform
> an ADC conversion, Takes 0-8 as input
> // to select which input to convert
> {
> unsigned char i;
> ADCH=0x00; // Clear the previous result
> ADCL=0x00; // Clear the previous result
Zbędne, niezdefiniowane zachowanie, ale chyba nie powinno powodować błędów.
> ADMUX=i|0x60; // Enter which line to perform in the ADC control
> register
Dlaczego ustawiasz ADLAR?
--
Pozdrawiam
Michoo
Następne wpisy z tego wątku
- 30.07.10 20:57 Konop
- 31.07.10 07:01 Jan Górski
Najnowsze wątki z tej grupy
- Klip testowy, jak sie to używa
- Jak sie smazy elektronike z odleglosci kilkuset metrów?
- William Shockley, co-inventor of the transistor
- Gazowy kocioł CO regulacja cyklingu i regulacja pogodowa
- Zamek elektroniczny
- szablon do pasty DIY
- Głośnik potrzebny
- Silikonowy przewód ekranowany
- Wtyk bananowy ekranowany
- Co może być gorsze od pożaru elektryka?
- daltonizm
- Mały Linux
- Superkondensator. Czy to się uda?
- Stare filmy o technice
- Zasilanie własnych konstrukcji przez PoE
Najnowsze wątki
- 2025-11-08 Klip testowy, jak sie to używa
- 2025-11-08 Warszawa => Senior Cloud Engineer - AWS <=
- 2025-11-08 Pewnie za malo zarabial, to sie musial odstresowac
- 2025-11-08 Uszkodzenie na parkingu a odpowiedzialność sprawcy z OC
- 2025-11-08 Środa Wielkopolska => SAP FI/CO Konsultant wewnętrzny <=
- 2025-11-08 Gdańsk => Senior Software Developer C++ <=
- 2025-11-08 Uszkodzenie na parkingu a odpowiedzialność sprawcy z OC
- 2025-11-08 Warszawa => Programista Microsoft Dynamics 365 Finance & Operations (D
- 2025-11-07 Warszawa => International Freight Forwarder <=
- 2025-11-07 Warszawa => C Programmer <=
- 2025-11-07 Warszawa => Starszy Programista C <=
- 2025-11-07 Warszawa => Senior Programmer C <=
- 2025-11-07 Warszawa => Developer Microsoft Dynamics 365 Finance & Operations (D36
- 2025-11-07 Warszawa => Programista C <=
- 2025-11-07 Warszawa => Asystent ds. Sprzedaży i Rozwoju Klienta <=




Elektromobilność dojrzewa. Auta elektryczne kupujemy z rozsądku, nie dla idei