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

Планировщик Задач На Базе 1Мгц Таймера - Не Могу Найти Баг :(


rusefi

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

Зашёл в тупик - не могу найти ошибку в программе своей, может быть кто-то сможет помочь? К сожалению частей движущихся слишком много, нужно будет подумать как упростить воспроизведение проблемы

stm32f4 + chibios, пытаюсь программно генерировать несколько ШИМ разной частоты используя один 32-битный таймер 1МГц. шим здесь просто частный случай планирования сигналов, велосипед вообще изобретаю вместо аппаратных таймеров на каждую задачу потому что так таймеров не хватит

Базовые файлы:

1) 32-битный будульник 1МГц, просто планирует вызов через заданное время: http://sourceforge.net/p/rusefi/code/HEAD/tree/trunk/firmware/hw_layer/microsecond_timer.c

2) 64-битные часы поверх счётчика циклов процессора - http://sourceforge.net/p/rusefi/code/HEAD/tree/trunk/firmware/util/efilib2.cpp

3) структура данных очереди событий: https://sourceforge.net/p/rusefi/code/HEAD/tree/trunk/firmware/controllers/algo/event_queue.cpp

каждый генератор ШИМ - высчитывает время следующего переключения пина, ставит будильник на это время, ставит в очередь следующий вызов, и всё по циклу - https://sourceforge.net/p/rusefi/code/HEAD/tree/trunk/firmware/controllers/system/pwm_generator_logic.cpp

Полные исходники: https://sourceforge.net/p/rusefi/code/HEAD/tree/trunk/firmware/

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

mANkEEh.png

а картинке мы видим, что четыре ШИМа какое-то время генерируются - третий самый быстрый, там событий 100 отрабатывает - а потом что-то идёт не так. к сожалению в этом дизайне достаточно одного несработавшего будильника, чтоб вся цепочка сломалась.

Для включения тестовой генерации нужно разкомментировать строчку52 в https://sourceforge.net/p/rusefi/code/HEAD/tree/trunk/firmware/controllers/PwmTester.cpp

будет 4 сигнала:

1Hz on PB9

10Hz on PB8

1000Hz on PE3

33Hz on PE5

может быть, кто-то увидит проблему? Что-то я немного в тупике.

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

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

rusefi,

При всём ..... такие вещи так не пишутся. Такой подход это задрачивание проца!!! Скоростные ШИМ (частотой больше 100 Гц) пишцться только на железе.

ничко скоростные сделай периодическое прерывание 0.1 мС это даст тебе возможность независимо программно реализовывать очень много ШИМов причём абсолютно независимо. Если необходимы частоты более низкие замени char на int.


#define PWM1_PIN .............. Номер пина
#define PWM1_PORT ....... указывай регистр порта для максимальной скорости.

volatile unsigned char pwm1_duty, pwm1_counter, pwm1_period;

void IRQ100us(void)
{
if (++pwm1_counter == pwm1_period)
{
pwm1_counter=0;
PWM1_PORT&=~(1<<PWM1_PIN);
}
else
{
if (pwm1_counter==pwm1_duty) PWM1_PORT|=(1<<PMW1_PIN);
}

}

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

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

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

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

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

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

Как я пытался озвучить - ШИМ здесь частный случай, основная задача - абстрактный планировщик нескольких потоков событий на одном аппаратном таймере.

На stm32f4 скоростях процессора я совсем не понимаю, как 1КГц будет напрягать процессор - тезис, что 100Гц является пределом нагрузки процессора мне кажется странным. Но всё-таки мы не о том - всё-таки основной вопрос, где же баг в том коде.

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

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

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

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

На stm32f4 скоростях процессора я совсем не понимаю, как 1КГц будет напрягать процессор - тезис, что 100Гц является пределом нагрузки

100 Гц с разрешением duty 1% = 100Hz * 100 = 10000hZ = 100uS.

тк обработка события происходит в прерывании, то соответственно увеличивается латентность прерываний с меньшим приоритетом. В народе называется задрачивание процессора.

В остальном не думаю , что мы поймём друг друга.

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

100 Гц с разрешением duty 1% = 100Hz * 100

Это важный момент. Программистам хватает двух прерываний на полный цикл ШИМ 100Hz * 2 = 200Hz, а народу - если нужно обязательно умножить на 100 - действительно непросто. Так что это видимо топик для программистов.

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

А что это такое? (выделено жирным)

CH_IRQ_HANDLER(STM32_TIM5_HANDLER) {

CH_IRQ_PROLOGUE();

if (((TIM->SR & 0x0001) != 0) && ((TIM->DIER & 0x0001) != 0))

callback();

TIM->SR = (int) ~STM32_TIM_SR_UIF; // Interrupt has been handled

CH_IRQ_EPILOGUE();

}

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

if (((TIM->SR & 0x0001) != 0) && ((TIM->DIER & 0x0001) != 0))

первый 0x0001 TIM_SR_UIF - это Update interrupt Flag?

второй 0x0001 TIM_DIER_UIE - Update interrupt enable?

TIM->SR = (int) ~STM32_TIM_SR_UIF;

сброс флага прерывания?

плюс хороший вопрос, не нужны ли там фигурные скобочки - чтоб сбрасывать только в случае выполнения условия и вызова callback

Для меня эти регистры страх и стыд, признаться просто брал из примеров. Как здесь должно быть?

попробовал несколько вариантов - поведение везде такое же, работает секунду-полторы, потом умирает :(

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

Новая информация:

void setHardwareUsTimer(int timeUs) {

TIM->ARR = timeUs - 1;

TIM->EGR |= TIM_EGR_UG; // generate an update event to reload timer's counter value

TIM->CR1 |= TIM_CR1_CEN; // restart timer

lastSetTimerTime = getTimeNowUs();

isTimerPending = TRUE;

timerRestartCounter++;

}

Похоже что если будильник ставить на малое время - например передавать параметром 5 или 11, то срабатывания не происходит. Если параметр 300 и больше - то всё работает. Осталось понять, почему и что с этим делать.

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

Просто не хватает времени на обработку прерывания. Запретите прерывания на время обработки. Но в этом случае получите не контролируемые временные интервалы.

По идее все должно работать при тактовой проца 168мгц и, если, внутри нет какой нибудь операционки или неизвестного кода.

Запустите задачу в профайлере и выловите проблему.

Вы пользуетесь отладкой по SWD?

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

Запрет на прерывания там есть, но сейчас он происходит не сразу - попробую поднять выше.

Сейчас там

register uint32_t tmp asm ("r3") = CORTEX_BASEPRI_KERNEL; \

asm volatile ("msr BASEPRI, %0" : : "r" (tmp) : "memory"); \

В профайлере или в дебагере? Если в профайлере, то какой профайлере под ARM вы посоветуете?

Отладка пока STLink, аппаратный идёт по почте пока.

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

В профайлере или в дебагере? Если в профайлере, то какой профайлере под ARM вы посоветуете?

Отладка пока STLink, аппаратный идёт по почте пока.

STLink это и есть аппаратный.

Я пользуюсь профайлером из среды IAR 6.30.

Очень удобно когда используешь чужой код и не понятно куда девается время.

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

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

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

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

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

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

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

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

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

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

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

    • Всё, всё, понял, 233 ома расчётных.
    • это не питание... это падение напряжения на переходе коллектор-эмиттер
    • и что не так? при входном токе 10 ма,и питании 3,3в выходной ток будет в районе 12ма.
    • Так случилось, что ничего кроме новых КТ840Б нет, а покупать на такую ерунду не охота. Нужно соединить параллельно 5 транзисторов *2, чтобы создать пуш-пул ферритовый преобразователь для питания магнетрона от микроволновой печи. Я уже намотал пластиковым проводом (они держат большее напряжение, чем эмальпровод) 267 витков вторичная обмотка (Одесакабель со снятой вторичной (белой) изоляцией 0.75) и 3*2 витка первичная (150 жил провода 0.1 мм), и уже испытал, что этот трансформатор держит 3 см дугу (около 30 киловольт) без пробоя (а сама изоляция держит около 50 кВ постоянного, тестировал умножителем УН9-27 со строчником ТВС110), дополнительно будет погружен в масло для охлаждения и изоляции, намотан на ферритовых полукольцах отклоняющей системы кинескопа М2000НМ, а габаритную мощность калькулятор показал 4кВт на частоте 35кГц (которая на Вашем форуме описана как оптимальная для "меандра" именно на М2000НМ). Возможно эти данные помогут определить, нужно уменьшать или увеличивать количество транзисторов КТ840 и повлияют на схему соединения. Программа расчета показала что нужно 1100 жил 0.1 мм но я намотал только 150 - больше не помещается и работать он будет в импульсном режиме (включатся на десяток секунд). Мощность 700 Вт, питание 12В, ток первичной обмотки 70А. Возможно придется добавлять еще транзистор КТ840 к каждой сборке, чтобы открывать такое большое количество транзисторов. Всего КТ840 есть 50 штук. По расчету преобразователь должен давать напряжение 1000-1400В, а остальное надо сделать умножителем, и я не нашел высоковольтных быстрых диодов на 35кГц ни в одном из местных киевских магазинов (возможно придется заказывать в интернете).  Множить хочу до максимального возможного (хоть 100кВ), которое выдержит магнетрон, потому что чем больше напряжение, тем больше мощность. Хочу купить фольгу и пленку, пропитать и погрузить в масло, скрутить в рулон, сделать высоковольтный конденсатор, типо этот преобразователь (допустим он даст 30кВ после умножения) заряжает этот конденсатор, а потом он разряжается на магнетрон.
    • Похоже так. При этом оптопара - далеко не микроскоп, а вполне себе ширпотреб, копеечный.  У ходовой оптопары PC817 типовое время закрытия - 3 мкс, максимальное - 18 мкс. Надо пробовать, возможно вам хватит. Быстрее будет 6N136, но у неё включение сложнее.
×
×
  • Создать...