Тема: IWDG

## Завдання:

Створити модуль який визначав чи не відбулося в ядрі помилок, які б зупинили його роботу. При наявності зависання, подавати сигнал перезапуску.

## Хід роботи:

Аналогічна периферія реалізована в МК STM32, тому було вирішено робити все по аналогії. В даташиті на МК блок схеми не було, тому було вирішено для зручності її створити, рисунок прикладено.



Основна ідея полягає в тому, що якщо мікроконтролер функціонує правильно, він подасть сигнал скидання на лічильник, і рахунок почнеться заново. Якщо ж цього не відбудеться, то лічильник дійшовши до нуля. Згенерує сигнал скидання, який піде на ядро.

В периферії присутній регістр, IWDG\_KR, якщо в нього записати значення 0xCCCC, то лічильник почне свою роботу. Мультиплексор, керує ввімкненням/вимкненням роботи Watchdog. При виконанні двох умов роботи, завдяки елементу "AND" на лічильник буде подаватись тактова частота, і він почне свою роботу. Відповідно при досягнені 0, буде згенеровано сигнал скидання.

Готовий модуль, має таку RTL схему:



## Висновок

Створено периферію, яка контролює «зависання» ядра. Проект було написано на мові Verilog. На ній же створено допоміжні модулі лічильника та мультиплексора. В ідеалі реальний модуль має тактуватись від окремого RC генератора або кварцу, та для тестового проекту, це не критично.