2017-05-16 10:01:08 +02:00
|
|
|
|
|
|
|
|
|
namespace PIC_Simulator.PIC
|
|
|
|
|
{
|
2017-05-16 17:52:02 +02:00
|
|
|
|
public class PICWatchDog
|
2017-05-16 10:01:08 +02:00
|
|
|
|
{
|
|
|
|
|
private PICProgramm programm;
|
|
|
|
|
|
2017-05-16 17:52:02 +02:00
|
|
|
|
public double TimeOut = 0.018; // ms;
|
|
|
|
|
|
|
|
|
|
private const double FREQUENCY = 4000000d; // 4 MHz
|
2017-05-16 10:01:08 +02:00
|
|
|
|
|
|
|
|
|
public uint Prescale = 1;
|
|
|
|
|
|
2017-05-16 17:52:02 +02:00
|
|
|
|
public double time; // in s
|
2017-05-16 10:01:08 +02:00
|
|
|
|
|
|
|
|
|
public bool Aktiviert = false;
|
|
|
|
|
|
2017-05-16 17:52:02 +02:00
|
|
|
|
private Form1 form;
|
|
|
|
|
|
|
|
|
|
public PICWatchDog(PICProgramm p, Form1 frm)
|
2017-05-16 10:01:08 +02:00
|
|
|
|
{
|
|
|
|
|
programm = p;
|
|
|
|
|
time = 0;
|
2017-05-16 17:52:02 +02:00
|
|
|
|
form = frm;
|
2017-05-16 10:01:08 +02:00
|
|
|
|
}
|
|
|
|
|
|
2017-05-16 17:52:02 +02:00
|
|
|
|
public void Aktualisieren(uint cycles)
|
2017-05-16 10:01:08 +02:00
|
|
|
|
{
|
|
|
|
|
if (Aktiviert)
|
|
|
|
|
{
|
2017-05-16 17:52:02 +02:00
|
|
|
|
time += (1.0 / FREQUENCY) * cycles;
|
2017-05-16 10:01:08 +02:00
|
|
|
|
|
2017-05-16 17:52:02 +02:00
|
|
|
|
if (time > TimeOut * GetPreScale())
|
2017-05-16 10:01:08 +02:00
|
|
|
|
{
|
|
|
|
|
WDReset();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
time = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void WDReset()
|
|
|
|
|
{
|
|
|
|
|
if (!programm.IsSleeping)
|
|
|
|
|
{
|
|
|
|
|
// >> WATCHDOG RESET <<
|
|
|
|
|
|
|
|
|
|
time = 0;
|
|
|
|
|
|
|
|
|
|
programm.Reset();
|
|
|
|
|
programm.SetRegisterOhneBank(PICProgramm.ADDR_STATUS, PICProgramm.STATUS_BIT_TO, false);
|
2017-05-16 17:52:02 +02:00
|
|
|
|
form.quartztimer.Stop();
|
2017-05-16 10:01:08 +02:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// >> Wake Up <<
|
|
|
|
|
|
|
|
|
|
time = 0;
|
|
|
|
|
|
|
|
|
|
programm.IsSleeping = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private uint GetPreScale()
|
|
|
|
|
{
|
|
|
|
|
bool prescale_mode = !programm.GetRegisterOhneBank(PICProgramm.ADDR_OPTION, PICProgramm.OPTION_BIT_PSA);
|
|
|
|
|
|
|
|
|
|
uint scale = 0;
|
|
|
|
|
scale += programm.GetRegisterOhneBank(PICProgramm.ADDR_OPTION, PICProgramm.OPTION_BIT_PS2) ? 1U : 0U;
|
|
|
|
|
scale *= 2;
|
|
|
|
|
scale += programm.GetRegisterOhneBank(PICProgramm.ADDR_OPTION, PICProgramm.OPTION_BIT_PS1) ? 1U : 0U;
|
|
|
|
|
scale *= 2;
|
|
|
|
|
scale += programm.GetRegisterOhneBank(PICProgramm.ADDR_OPTION, PICProgramm.OPTION_BIT_PS0) ? 1U : 0U;
|
|
|
|
|
|
|
|
|
|
Prescale = prescale_mode ? 1 : (PICProgramm.SHL(1, scale));
|
|
|
|
|
|
|
|
|
|
return Prescale;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Reset()
|
|
|
|
|
{
|
|
|
|
|
time = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|