Перейти к содержанию

Ацп В Stm32F303


Рекомендуемые сообщения

Доброго времени суток!

Пытаюсь разобраться с АЦП в STM32f3Discovery. Цель - просто запустить самое простое преобразование и с помощью АЦП регулировать частоту поочередного мигания двух светодиодов. Уже несколько дней пытаюсь, ничего не выходит. Вроде всё по даташиту делаю. Смотрел различные примеры в интернете и пытался сделать подобно, но тоже не работает.

Ниже привожу код программы. Может я что-то еще забыл сделать?

#include "stm32f30x.h"
uint32_t adc_res;

int main(void)
{
RCC->AHBENR|=RCC_AHBENR_GPIOAEN|RCC_AHBENR_GPIOEEN;//включение тактирования портов А и Е
RCC->AHBENR|=RCC_AHBENR_ADC12EN;//включение тактирования АЦП 1 и 2
GPIOE->MODER=0x55555555;//порт Е на выход, там светодиоды
GPIOA->MODER|=GPIO_MODER_MODER0_0;GPIO_MODER_MODER0_1;//РА0 в аналоговый режим, это первый канал АЦП1
ADC1->JSQR|=ADC_JSQR_JSQ1_1;//задаем первый канал в первом преобразовании. По умолчанию в этом регистре задано одно преобразование в последовательности.
ADC1->CR|=ADC_CR_ADEN;//включаем АЦП
ADC1->CR|=ADC_CR_JADSTART;//Запускаем инжектированную последовательность

while(1)
{
 while (!(ADC1->ISR & ADC_ISR_JEOC));//ждем флаг конца преобразования
 ADC1->ISR|=ADC_ISR_JEOC;//сбрасываем флаг конца преобразования
 ADC1->ISR|=ADC_ISR_JEOS;//сбрасываем флаг конца выборки
 adc_res=ADC1->JDR1;//считываем данные
 GPIOE->BSRR|=GPIO_BSRR_BS_15;
 GPIOE->BSRR|=GPIO_BSRR_BR_10;
 for (int i=0;i<=(adc_res*1000);i++);//делаем задержку в зависимости от полученных данных
 while (!(ADC1->ISR & ADC_ISR_JEOC));//далее аналогично меняем сведодиоды
 ADC1->ISR|=ADC_ISR_JEOC;
 ADC1->ISR|=ADC_ISR_JEOS;
 adc_res=ADC1->JDR1;
 for (int i=0;i<=(adc_res*1000);i++);
 GPIOE->BSRR|=GPIO_BSRR_BS_10;
 GPIOE->BSRR|=GPIO_BSRR_BR_15;
}
}

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

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

А что именно происходит? С 32 я тоже только начал разбираться, а вот в 8 надо каждый раз пинать ацп для преобразования. Плюс в случае простоя он засыпает, его еще будить надо.

Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

Ничего не происходит. :D У меня такое чувство, что флаг окончания преобразования не выставляется, т е оно не заканчивается. Я по разному пытался сделать уже, но почему то ничего не происходит всё равно.

Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

У меня получилось:

#include <iostm32f100xB.h>

void blink( void )
{
for ( long int i = 0; i < ADC1_JDR1*10; i++ );
GPIOC_ODR_bit.ODR8 ^= 1;
}

int adc_res;

void main(void)
{
//включение тактирования портa C
RCC_APB2ENR_bit.IOPCEN = 1;
GPIOC_CRH_bit.MODE8 = 3;//LED
GPIOC_CRH_bit.CNF8 = 0;
GPIOC_CRL_bit.MODE0 = 0; //ADC in 10
GPIOC_CRL_bit.CNF0 = 0;
RCC_APB2ENR_bit.ADC1EN = 1;//включение тактирования АЦП 1
ADC1_SMPR1_bit.SMP10 = 7;//sample time
ADC1_CR2_bit.JEXTSEL = 7;//инжектированная группа запуск битом старта
ADC1_CR2_bit.JEXTTRIG = 1;
ADC1_CR2_bit.CONT = 1; //постоянно измерять
ADC1_CR1_bit.JAUTO = 1;
ADC1_JSQR_bit.JSQ4 = 10;//10 канал
ADC1_JSQR_bit.JL = 0;
ADC1_CR2_bit.ADON = 1;//включим ацп
ADC1_CR2_bit.CAL = 1;//calibrate
while ( ADC1_CR2_bit.CAL );
ADC1_CR2_bit.JSWSTART = 1;//старт
while ( 1 )
{
while ( !ADC1_SR_bit.JEOC );
ADC1_SR_bit.JEOC = 0;
adc_res = ADC1_JDR1;
blink();
}
}

Полностью как вы хотели, только камень другой.

Изменено пользователем Стальной
Ссылка на комментарий
Поделиться на другие сайты

Для настройки 10 вывода как аналогового входа что-то такое должно быть.

GPIOC_CRH_bit.MODE10 = 0; //ADC in 10

Изменено пользователем Вуйко
Ссылка на комментарий
Поделиться на другие сайты

У меня получилось:

#include <iostm32f100xB.h>

void blink( void )
{
for ( long int i = 0; i < ADC1_JDR1*10; i++ );
GPIOC_ODR_bit.ODR8 ^= 1;
}

int adc_res;

void main(void)
{
//включение тактирования портa C
RCC_APB2ENR_bit.IOPCEN = 1;
GPIOC_CRH_bit.MODE8 = 3;//LED
GPIOC_CRH_bit.CNF8 = 0;
GPIOC_CRL_bit.MODE0 = 0; //ADC in 10
GPIOC_CRL_bit.CNF0 = 0;
RCC_APB2ENR_bit.ADC1EN = 1;//включение тактирования АЦП 1
ADC1_SMPR1_bit.SMP10 = 7;//sample time
ADC1_CR2_bit.JEXTSEL = 7;//инжектированная группа запуск битом старта
ADC1_CR2_bit.JEXTTRIG = 1;
ADC1_CR2_bit.CONT = 1; //постоянно измерять
ADC1_CR1_bit.JAUTO = 1;
ADC1_JSQR_bit.JSQ4 = 10;//10 канал
ADC1_JSQR_bit.JL = 0;
ADC1_CR2_bit.ADON = 1;//включим ацп
ADC1_CR2_bit.CAL = 1;//calibrate
while ( ADC1_CR2_bit.CAL );
ADC1_CR2_bit.JSWSTART = 1;//старт
while ( 1 )
{
while ( !ADC1_SR_bit.JEOC );
ADC1_SR_bit.JEOC = 0;
adc_res = ADC1_JDR1;
blink();
}
}

Полностью как вы хотели, только камень другой.

Дело в том, что на f100 у меня тоже все работает, но в 100 и 300 сериях АЦП немного отличаются как я понял. А по отладчику я смотрел - регистр данных нулю равен всегда.

Ссылка на комментарий
Поделиться на другие сайты

Всё, я разобрался! Надо было еще тактовую частоту АЦП задать.

RCC->CFGR2|=RCC_CFGR2_ADCPRE12_DIV2;

Ну и так по мелочи еще ошибки были, но это главная причина.

Ссылка на комментарий
Поделиться на другие сайты

Автор, я рекомендую посмотреть в сторону HAL вместо SPL, а гуевиной cubemx от st можно генерировать готовый проект с инициализацией переферии, либо из этого проекта брать готовые куски инициализации, я тут недавно всю кухню эту раскопал, прямо в восторге)

Ссылка на комментарий
Поделиться на другие сайты

Автор, я рекомендую посмотреть в сторону HAL вместо SPL, а гуевиной cubemx от st можно генерировать готовый проект с инициализацией переферии, либо из этого проекта брать готовые куски инициализации, я тут недавно всю кухню эту раскопал, прямо в восторге)

Спасибо за совет! Но это скорее в академических целях - писать код и параллельно во всем разбираться.))) В будущем возможно посмотрю в сторону оптимизации процесса программирования. :yes:

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
×
×
  • Создать...