Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Разбор кода ADC
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > AVR
konstatinopol
Прошу помощи в разборе кода, не прошу обьяснить что делает код а что значит каждый пункт в нём.
Зарание благодарен.

Проц на борте : Atmega8

Код
#include <stdint.h>                                        // Dateitypen
#include <avr/io.h>                                        // In/Outputs
#include <avr/interrupt.h>                                // Interrupts - fuer sei()
#include <avr/signal.h>                                    // Interrupts - fuer signal()

unsigned char al, ah;
unsigned short aw;

int main (void)
{
    DDRD = 252;
    DDRB = 15;
    DDRC = 0;
    PORTC = 0;                

    sei();                                    // Global Interrupt Flag setzen

        ADMUX = 0;
        ADCSRA = 128 + 64 + 8 + 4 + 1;

    while(1)                                // Run forever
    {
//                PORTD = 128;
    }
    

}


SIGNAL(SIG_ADC)                   // Wenn ADC fertig ist
{
        al = ADCL;
        ah = ADCH;
        aw = (ah <<8) | al;
        PORTD = (aw >> 2)&252;
    PORTB = aw & 15;
        ADCSRA |= 64;
}
SysRq
Какие куски именно не понятно?
konstatinopol
непонятен кусок
Код
DDRD = 252;
    DDRB = 15;

Раньше все DDR были либо 0 либо 7(вход/выход), но почему в ADC они начали принимать другие значения?

Код
ADMUX
        ADCSRA

Для чего они нужны?

Что такое ADC Hight и Low?
Ну и что происходит в строках
Код
aw = (ah <<8) | al;
        PORTD = (aw >> 2)&252;
    PORTB = aw & 15;
        ADCSRA |= 64;
SysRq
DDRn - регистр управления портом n микроконтроллера; устанавливает режим работы ног контроллера порта n как вход или выход. Значение в регистр записывается исходя из схемы железки исключительно.

Что означают значения регистров АЦП читаем в официальном datasheet для ATMega8, раздел "Analog-to-Digital Converter". Если что будет не понятно - только тогда спрашиваем.

Что происходит в строках:
http://ru.wikipedia.org/wiki/Битовые_операции (операторы |, &).
http://ru.wikipedia.org/wiki/Битовый_сдвиг (операторы <<, >>).

PS: Брутфорс программировение, акт 2. (посмотрел предыдущие темы автора.)
KRS
Этот код вообще выкинуть надо, а не разбирать!
Константы не информативные! Их хотя бы в 16ричном виде записать!
Например 252 = 0xFC и сразу понятен смысл выражений (aw >> 2)&0xFC и aw & 0x0F
младшие 4 бита и старшие 6 бит маскируются.
konstatinopol
Материал хороший, уже посмотрел.
А есть подобное, но на русском или на немецком???
konstatinopol
Всем спасибо за помощь, вроди разобрался
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.