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

adnega

Свой
  • Постов

    3 580
  • Зарегистрирован

  • Посещение

  • Победитель дней

    3

adnega стал победителем дня 1 декабря 2023

adnega имел наиболее популярный контент!

Репутация

11 Хороший

2 Подписчика

Информация о adnega

  • Звание
    Гуру
    Гуру
  • День рождения 01.05.1982

Контакты

  • Сайт
    Array
  • ICQ
    Array

Информация

  • Город
    Array

Посетители профиля

12 298 просмотров профиля
  1. Конкретно мне он интересен: USB-HS со встроенной физикой на 480МГц. Ethernet 10/100/1000 со встроенной физикой на 10МГц. Восемь последовательных портов, SDIO, CAN (два), еще один USB, но -FS, контроллер внешней памяти FSMC, порт для камеры DVP, ADC-12бит 2 по 16 (с возможностью тача), DAC-12бит, операционники/компараторы OPA/CMP (четыре штуки), часы реального времени, три SPI, два I2C. А главное ценник от 250 руб/шт (почти в розницу) и наличие в РФ. Кста, частота 144 МГц (но есть особенности). Оперативки можно накрутить до 128КБ за счет флеши (которая WS0). По плотности кода и эффективности исполнения соглашусь - до Cortex-M4 не дотягивает, но я на последние и не гуляю. FPU одинарной точности имеется.
  2. Дело хозяйское, но рекомендую про RISC-V не забывать) Есть отладка, в два раза дешевле, по некоторым пунктам уделывает "нормальный" МК) https://aliexpress.ru/item/1005006650480128.html?sku_id=12000037925938796&spm=a2g2w.productlist.search_results.7.62aa778fnseC10 Если принципиально Cortex-M, то смотреть AT32F, GD32F что-то из 4хх-линейки.
  3. Это очень хороший результат. Я бы разделил понятия: "точность-погрешность-и т.п." Тут все ок, без предфильтров будет 1 такт таймера. И "пропуски-дребезг-загнулись". Нужно до ядра доводить только ту информацию, которая нужна для принятия решений. Т.е. если можно аппаратно выкинуть часть импульсов - это нужно делать. У вас настроен DMA на два переноса - в будущем можете просто увеличить размер буфера или вообще перейти на кольцо. Если передавать ядру всю информацию об импульсах, то оно загнется раньше TIM/DMA/ISR. > Применить смогу, например, при измерении частоты Частоту можно двумя способами измерять: 1) измерив период между соседними импульсами. 2) измерив количество импульсов за единицу времени. В зависимости от требований выбирается тот или иной способ. > Анти-шим это обратное извелечение информации из ШИМ, декодирование что-ли? Да. Очень во многих областях/протоколах информация передается длительностью импульса/паузы. > Правильные МК посмотрел. Купить в розницу незадорого, и собрать минимальный набор для отладки не получится. Не знаю что в них правильного? В наличии нет, ценник конский, решение получится не универсальное, т.к. будет привязано к конкретному МК. Сразу поставить ПЛИС, если программист не способен решить задачу без красивостей/правильностей в железе. > Для того, чтобы сделать вывод о возможном пропуске Вариантов много. Я часто один из свободных каналов захвата/сравнения использую для аппаратных таймаутов. > Для меня интересным было время, которое тратится на дма, на вход в прерывание, на синхронизацию, время сохранности результата в регистре. Это правильные интересы. У вас ядро популярное. Советую книги Джозефа Ю - зачитаться.
  4. В этом вы ошибаетесь сильно: у меня все разрабатываемые контроллеры нафаршированы максимально) Под задачу я выбираю МК из типовых (что уже серийно используем, чтоб не раздувать номенклатуру), затем свободные ресурсы задействую для добавления функционала в перспективе. Я максимально использую аппаратные возможности МК. "Хоть поллингом флагов" это не призыв к действию, а иллюстрация простоты задачи. Для захвата ШИМ я использую два варианта: 1) с обработкой в реальном времени каждого импульса в прерывании; 2) с постобработкой порции или всего пакета импульсов в связке TIM+DMA. ТС не поставил никакой практической задачи, поэтому конкретно ответить сложно, но это точно не "использовать нормальный МК". Когда мы подменяем принцип выбора подходящего под задачу камня, нытьем танцора, которому в "обычных" МК все жмет. Не хочу переходить на личности, но мимо заявления о существовании неких "нормальных" МК пройти не смог. Итого, ТСу нужно зафиксировать задачу. Если это анти-ШИМ чего-то нешустрого, то советую освоить TIM+ISR. Для более шустрого, но не требовательного с реалтайму - TIM+DMA. Это закроет 99% типовых потребностей. Будут вопросы - поможем. Если задачу экстремалить, т.е. повышать частоту до предела, то, разумеется, в этот предел упрешься, а там уже принципиально иные способы решения могут возникнуть. Вместо этого рекомендую освоить TIM_master+TIM_slave - добавит в копилку решений еще 0.99%
  5. >Может не будем валить с больной головы на здоровую? Речь шла о фиксации длительности одиночных импульсов. С одиночными импульсами вообще проблем никаких нет - хоть поллингом флагов CCR таймера. Речь шла о захвате в пределе - в терминах ТС "с минимальной задержкой". Я понял, что речь идет о задержке между соседними импульсами. >отсутствие информации, что такая потеря произошла. И что делать с информацией, что потеря произошла? Какой практический смысл? > была короткая иголка (в несколько тактов) В таймере перед блоком захвата есть аппаратный фильтр - для борьбы с такими иголками) > Поэтому при наличии всякого рода дребезгов, анализ посредством DMA на STM32 очень сложен. Я борьбу с дребезгом поручаю аппаратному фильтру. Иначе "дребезги" разобьют в дребезги любую систему, борющуюся с ними программно. Разве нет?)) Системы, типа, "я зафиксировала дребезг на входе поэтому работать дальше не буду" я рассматривать не готов) > Тогда расскажите - как будете действовать в случае... Вообще проблем не вижу. Недавно сдал систему захвата 12 каналов датчиков детонации с привязкой к углу возникновения с точностью 0.025 градуса. Помехи от частотника прут и по каналам захвата и от энкодера)) Есть и аппаратная борьба на входе МК (причем лайтовая, чтоб импульс не сдвинуть и не наврать с углом), и программная низкоуровневая, и программная высокоуровневая. Забавно, вообще все построил на EXTI-прерываниях. А точность получилась - мама не горюй - видно как вал скручивается в зависимости от нагрузки и оборотов)) Кста, есть программная компенсация задержки распространения сигнала во входных аналоговых цепях. ШИМ-декодировать приходилось в драйвере приемника от ИК-пультов. Или в вызывной панели VIZIT. Или в работе с 1-wire устройствами. Вообще без проблем. Итого: если не придумывать себе проблему, чтоб потом ее героически решить, то и проблемы не будет. > ЗЫ: Или всё-таки в таймерах STM32 есть какой-то способ зарегистрировать факт потери события? Кто знает? Я же сказал: задача фиксировать факт потери события в большинстве случаев не стоит. Кто знает систему, где обработка потерь импульсов играет рояля?
  6. Могут предложить такую задачку (если ТС не против): 1) Есть адресные светодиодные ленты (типа WS2811) - 4 шт. 2) Есть источник данных для этой светодиодной ленты. 3) Нужно сделать контроллер с одним входом (WS2811) и 4 выходами (WS2811). 4) На каждом выходе нужно индивидуально задать сколько светодиодов будет пропущено из потока. Проще: нужно входные импульсы пропустить на выход, но первые 24*Ni (i от 1 до 4, Ni > 0) заменить на лог "0". Будем считать, что импульсы со скважностью 2 и частотой 800кГц. Я сделал такое на STM32F042 (аналог F030, на F030 тоже заработает). Контроллер позволяет данные для одной длинной светодиодной ленты поделить на сегменты с индивидуальным смещением - резко удобнее становится подключение. Кста, одноканальный вариант вообще на Тини13 делал)
  7. Идут импульсы/паузы в тактах: 1/1-1/2-1/1-1/1 и т.д. непрерывно. Сколько тактов стоит CPU вытащить эти данные из FIFO (со всеми флагами переполнения и т.п.)? Очевидно же, CPU не сможет обработать такой непрерывный поток. Очевидно же, DMA тоже может обеспечить поток, который CPU не сможет обработать. Чушь - ок. Отсутствие потери событий гарантируется архитектурой системы. Кто-то проектирует систему, где допускается потеря событий - я так не поступаю и другим не советую. Предметнее проще: приведите пример задачи, где без "нормального" МК не обойтись. Я довольно сильно использую таймеры - пока все задачки решаются STM-совместимой таймерной периферий большинства популярных МК.
  8. Обрисуйте конкретную задачу - будет проще предложить решение. Регистры CCR - это и есть FIFO на один элемент, далее - DMA (с характерным темпом не чаще 12 тактов CPU). Не знаю зачем "нормальным" МК какие-то FIFO: ну наловишь импульсы "хоть в 1 такт" - дальше что? кто их будет способен обработать?
  9. А разве TMR2 должен ремапиться на PB8/9 ? "Non-timer peripherals has priority over timer peripherals". Нужно проверить, что на этих пинах нет никакой нетаймерной периферии. Кста, в чем отличия _MUX и _GMUX регистров?
  10. li t0, 0x1f csrw 0xbc0, t0 /* Enable nested and hardware stack */ li t0, 0x0b csrw 0x804, t0 /* Enable floating point and interrupt =0x6088 / =0x7888 */ li t0, 0x7888 csrs mstatus, t0 la t0, _vector_base ori t0, t0, 3 csrw mtvec, t0 /* la t0, main csrw mepc, t0 mret */ j main Можно поправить исходный примерно так.
  11. В своем загрузчике startup от производителя не заработает, т.к. там делается переход в U-режим. И уже попытка записи csr в startup приложения вызовет сбой.
  12. Чему равен Page_Address ? #define FLASH_BANK1_END_ADDRESS ((uint32_t)0x807FFFF) - не много для 16кБ флешки?
  13. 2000014a: jalr t0,160(zero) # 0x0 <_start> А это что? Что лежит по адресу 0xA0 ?
×
×
  • Создать...