реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> STM32F429 DMA
MiklPolikov
сообщение Feb 14 2016, 02:57
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



Пытаюсь писать данные из АЦП в кольцевой буфер. Буфер заполняется один раз, и больше не обновляется. Данные в регистре ADC1 DR продолжают обновляться.
DMA настроен в кольцевом режиме. В чём может быть причина ?

Заранее спасибо !

Настройка DMA:
Код
   DMA2_Stream4->CR = 0;
     DMA2_Stream4->M0AR = (unsigned int)p_data_buf;
     DMA2_Stream4->PAR = (unsigned int)&ADC1->DR;
     DMA2_Stream4->NDTR = data_size;
     DMA2_Stream4->FCR = 0;  буферизация отключена

   DMA2_Stream4->CR&=~DMA_SxCR_CHSEL;

   DMA2_Stream4->CR &=~ DMA_SxCR_PSIZE_1;
   DMA2_Stream4->CR |= DMA_SxCR_PSIZE_0;   //разрядность 16 бит
   DMA2_Stream4->CR &=~ DMA_SxCR_MSIZE_1;
   DMA2_Stream4->CR |= DMA_SxCR_MSIZE_0;   //разрядность 16 бит

   DMA2_Stream4->CR |= DMA_SxCR_MINC;

   DMA2_Stream4->CR |= DMA_SxCR_CIRC; //кольцевой режим

   DMA2_Stream4->CR |= DMA_SxCR_EN;


--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
scifi
сообщение Feb 14 2016, 07:35
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Сам на это натыкался. Нужно установить бит DDS в регистре ADC_CR2.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Feb 14 2016, 07:47
Сообщение #3


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(MiklPolikov @ Feb 14 2016, 04:57) *
Код
   DMA2_Stream4->CR = 0;
   DMA2_Stream4->CR &=~DMA_SxCR_CHSEL;
   DMA2_Stream4->CR &=~ DMA_SxCR_PSIZE_1;
   DMA2_Stream4->CR &=~ DMA_SxCR_MSIZE_1;
Не в тему, но объясните смысл последних трех операций после выполнения первой?

Я обычно делаю так:
Код
    DMA2_Stream4->CR = 0;
    DMA2_Stream4->M0AR = (uintptr_t)p_data_buf;     // для указателей есть специальный тип uintptr_t
    DMA2_Stream4->PAR = (uintptr_t)&ADC1->DR;
    DMA2_Stream4->NDTR = data_size;
    DMA2_Stream4->FCR = 0;  буферизация отключена

    DMA2_Stream4->CR = 0
        | 0 * (DMA_SxCR_CHSEL & -DMA_SxCR_CHSEL)    // канал 0
        | 2 * (DMA_SxCR_PSIZE & -DMA_SxCR_PSIZE)    // разрядность 32 бита (для примера)
        | 1 * (DMA_SxCR_MSIZE & -DMA_SxCR_MSIZE)    // разрядность 16 бит
        | 0 * DMA_SxCR_PINC
        | 1 * DMA_SxCR_MINC
        | 1 * DMA_SxCR_CIRC                         // кольцевой режим
        | 1 * DMA_SxCR_EN
       ;
В такой записи легко менять значения битов, значит ее можно копировать из проекта в проект и такая запись компилится ровно в одну запись в регистр.
Запись ( x & -x ) выделяет младший установленный бит из x.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 07:50
Рейтинг@Mail.ru


Страница сгенерированна за 0.01972 секунд с 7
ELECTRONIX ©2004-2016