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

STM32F407ZGT Демоны где то в reset


SuperЛёха

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

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

Пару лет вяло осваиваю STM, никогда такого не было, и вот снова....

Суть проблемы в следующем:

Опрашиваю 12 аналоговых входов с 3-х АЦП в циклическом режиме через DMA. На каждый АЦП по 4 канала.

Заливаю в STM, всё работает как надо, и вот оно: отключаешь питание, затем включаешь - в ДМА хрень какая то сыпится не имея ничего общего с потенциалом на входах (может не в нём дело, а в АЦП), причём остальная периферия работает исправно.

Далее делаю аппаратный reset - всё работает. Ещё раз reset - работает и всегда всё работает после аппаратного reset. Но как только питание передёрнешь - хрень.

В первую очередь погрешил на конденсатор в цепи сброса - исправен 0,1мкФ, зажал ресет, включил питание, отпустил ресет - хрень.

Повторил кучу экспериментов - одно и тоже, после передёргивания питания - хрень. После повторного сброса после старта - нормально работает всё до отключения питания.

Питание стабильное, у каждой питающей ноге - емкость, да и в принципе плата многослойная проблемы с питанием исключаю.

Как будто после включения питания не всё сбрасывается, но такое наверное вряд ли может быть.

Может кто подскажет, в каком направлении копать.

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

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

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

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

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

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

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

А супервизор питания вместо просто конденсатора применить не пробовали?

Просят - не откажи. Не просят - не навязывайся!

Простота хуже воровства.

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

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

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

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

Честно - ещё не дорос. Слишком много задач кроме STM. 

В общем причина глюка который я видел найдена:

Я получал значения с АЦП, затем их обрабатывал (считал TRMS), и вот результат после передёргивания питания - был бредом, однако после аппаратного сброса - всё работало как надою.

Почти весь код лежит в CCMRAM, однако в RAM вынесены буферы DMA и буферы для подсчёта TRMS для каждого канала.

Так вот, после передёргивания питания в RAM почему то валяется какой то мусор, который попадал в предварительно неинициализированный буфер (массив).

Странно, что этот мусор находится в RAM после передёргивания питания, ведь по сути после подачи питания происходит тот же самый аппаратный сброс. 

Проинициализировал буфер и всё стало работать как надо.

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

1 час назад, Falconist сказал:

супервизор питания

У STM стоит внутри.

 

46 минут назад, SuperЛёха сказал:

Проинициализировал буфер

Ну так в программах в принципе желательно все переменные и буферы инициализировать. И это не только к МК относится.

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

47 минут назад, SuperЛёха сказал:

по сути

аппаратный сброс  RAM не инициализирует. Странно, что помогал сброс на горячую.

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

48 минут назад, SuperЛёха сказал:

Странно, что этот мусор находится в RAM после передёргивания питания, ведь по сути после подачи питания происходит тот же самый аппаратный сброс. 

Как-раз ничего странного.
Возьмите за правило объявлять буфер как-то так: uint16_t buf[100] = {0}; и он автоматом заполнится нулями.

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

3 часа назад, BARS_ сказал:

Ну так в программах в принципе желательно все переменные и буферы инициализировать. И это не только к МК относится.

Полностью согласен! 

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

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

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

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

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

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

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

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

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

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

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

    • @Gomerchik а вы контролировали как меняется уровень сигнала на А1 ардуины?
    • Спасибо за совет. Автором данного проекта я не являюсь, мне нужно было воссоздать уличный датчик для метеостанции взамен пропавшего(( Из разного найденного в интернете этот проект работает с моей станцией Орегон (спасибо автору). В понедельник попробую последовать Вашему совету. Но все равно куча непоняток  как блин это работает)) Если дело в неправильной отправки команды, то как на это влияет подключение датчика температуры? Если совсем не подключать таймер, то передача идет один раз (как и прописано в программе), станция принимает и отображает, но минут через сколько-то естественно станция уже ни чего не показывает, но с таймером питание полностью не пропадает с ардуинки, но передача сигнала каким-то образом работает по таймеру.  В моем понимании данная команда подается один раз потому, что таймер должен отключать питание МК после передачи сигнала и каждые 43 сек снова подавать питание (так того требует станция).  Ардуино передает показания температуры отключается полностью и 43 секунды мк не работает.  Сейчас у меня питание пока сделано на подпитке от солнечной батареи, но пару пасмурных дней и аккумулятор съедается до отключения(
    • thickman Так и сделаю. Вытащу из бу БП.  Буду знать, как отличить. Благодарю. Заменил транзисторы на IRFB20N50K. Картина стала, совсем другой.  Похоже трудность не в драйвере, на момент подвозбуда, переходные процессы, в нем, завершены. Увеличил затворные резисторы до 50ом, стало немного лучше.  Не понятно, почему верхний ключ греется несколько сильнее. Возможно, стоит посмотреть ток в коллекторе.  Снабберные емкости временно удалил, изменений не произошло.  Замена ТГР на другой, на кольце MSTN-16A-TH, так же, результата не принесла.   irfb20n50k.pdf
    • А что нить из ассортимента активных щупов производства СССР..))
    • Типа такого: https://aliexpress.ru/item/2044864227.html?sku_id=58855020183
×
×
  • Создать...