mirror of
https://github.com/InvisibleUp/uvmac.git
synced 2025-01-05 04:29:47 +00:00
WIP: Try to get system booted again
This commit is contained in:
parent
0a2109f481
commit
b16c65cc79
@ -1607,7 +1607,7 @@ GLOBALFUNC bool FindKeyEvent(int *VirtualKey, bool *KeyDown)
|
|||||||
#ifdef _VIA_Debug
|
#ifdef _VIA_Debug
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#endif
|
#endif
|
||||||
/*
|
|
||||||
GLOBALVAR uimr ICTactive;
|
GLOBALVAR uimr ICTactive;
|
||||||
GLOBALVAR iCountt ICTwhen[kNumICTs];
|
GLOBALVAR iCountt ICTwhen[kNumICTs];
|
||||||
|
|
||||||
@ -1645,4 +1645,4 @@ GLOBALPROC ICT_add(int taskid, uint32_t n)
|
|||||||
NextiCount = when;
|
NextiCount = when;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
|
@ -162,6 +162,37 @@ EXPORTPROC VIAorSCCinterruptChngNtfy(void);
|
|||||||
EXPORTVAR(bool, InterruptButton)
|
EXPORTVAR(bool, InterruptButton)
|
||||||
EXPORTPROC SetInterruptButton(bool v);
|
EXPORTPROC SetInterruptButton(bool v);
|
||||||
|
|
||||||
|
enum {
|
||||||
|
kICT_SubTick,
|
||||||
|
#if EmClassicKbrd
|
||||||
|
kICT_Kybd_ReceiveCommand,
|
||||||
|
kICT_Kybd_ReceiveEndCommand,
|
||||||
|
#endif
|
||||||
|
#if EmADB
|
||||||
|
kICT_ADB_NewState,
|
||||||
|
#endif
|
||||||
|
#if EmPMU
|
||||||
|
kICT_PMU_Task,
|
||||||
|
#endif
|
||||||
|
kICT_VIA1_Timer1Check,
|
||||||
|
kICT_VIA1_Timer2Check,
|
||||||
|
#if EmVIA2
|
||||||
|
kICT_VIA2_Timer1Check,
|
||||||
|
kICT_VIA2_Timer2Check,
|
||||||
|
#endif
|
||||||
|
kNumICTs
|
||||||
|
};
|
||||||
|
|
||||||
|
EXPORTPROC ICT_add(int taskid, uint32_t n);
|
||||||
|
|
||||||
|
#define iCountt uint32_t
|
||||||
|
EXPORTFUNC iCountt GetCuriCount(void);
|
||||||
|
EXPORTPROC ICT_Zap(void);
|
||||||
|
|
||||||
|
EXPORTVAR(uimr, ICTactive)
|
||||||
|
EXPORTVAR(iCountt, ICTwhen[kNumICTs])
|
||||||
|
EXPORTVAR(iCountt, NextiCount)
|
||||||
|
|
||||||
#define kLn2CycleScale 6
|
#define kLn2CycleScale 6
|
||||||
#define kCycleScale (1 << kLn2CycleScale)
|
#define kCycleScale (1 << kLn2CycleScale)
|
||||||
|
|
||||||
|
@ -344,6 +344,7 @@ if ((0 == vMacScreenDepth) || (vMacScreenDepth >= 4)) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// One-second interrupt, I think
|
||||||
GLOBALPROC RTC_Interrupt(void)
|
GLOBALPROC RTC_Interrupt(void)
|
||||||
{
|
{
|
||||||
uint32_t Seconds = 0;
|
uint32_t Seconds = 0;
|
||||||
@ -361,6 +362,7 @@ GLOBALPROC RTC_Interrupt(void)
|
|||||||
|
|
||||||
LastRealDate = NewRealDate;
|
LastRealDate = NewRealDate;
|
||||||
}
|
}
|
||||||
|
RTC_RaiseOneSecIRQ();
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCALFUNC uint8_t RTC_Access_PRAM_Reg(uint8_t Data, bool WriteReg, uint8_t t)
|
LOCALFUNC uint8_t RTC_Access_PRAM_Reg(uint8_t Data, bool WriteReg, uint8_t t)
|
||||||
|
@ -40,13 +40,11 @@
|
|||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
|
|
||||||
#ifndef AllFiles
|
|
||||||
#include "SYSDEPNS.h"
|
#include "SYSDEPNS.h"
|
||||||
|
|
||||||
#include "UI/MYOSGLUE.h"
|
#include "UI/MYOSGLUE.h"
|
||||||
#include "EMCONFIG.h"
|
#include "EMCONFIG.h"
|
||||||
#include "GLOBGLUE.h"
|
#include "GLOBGLUE.h"
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "HW/SCC/SCCEMDEV.h"
|
#include "HW/SCC/SCCEMDEV.h"
|
||||||
#include "HW/VIA/VIAEMDEV.h"
|
#include "HW/VIA/VIAEMDEV.h"
|
||||||
|
@ -58,7 +58,7 @@ char *ScreenColorWhite = NULL;
|
|||||||
|
|
||||||
bool Screen_UseMainPage()
|
bool Screen_UseMainPage()
|
||||||
{
|
{
|
||||||
return VIA_ReadBit(VIA1, rIRA, 6);
|
return (VIA_ReadBit(VIA1, rIRA, 6) == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Screen_Init(void)
|
bool Screen_Init(void)
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include "VIAEMDEV.h"
|
#include "VIAEMDEV.h"
|
||||||
|
#include "GLOBGLUE.h"
|
||||||
|
|
||||||
/* Global state */
|
/* Global state */
|
||||||
VIA_State_t VIA_State[VIA_MAXNUM];
|
VIA_State_t VIA_State[VIA_MAXNUM];
|
||||||
@ -54,19 +55,36 @@ void VIA_RaiseInterrupt(uint8_t id, uint8_t irq)
|
|||||||
// Set interrupt flag
|
// Set interrupt flag
|
||||||
VIA_State[id].vIFR |= (1 << irq) | (1 << 7);
|
VIA_State[id].vIFR |= (1 << irq) | (1 << 7);
|
||||||
|
|
||||||
/*// Call interrupt handler, if required
|
// Call interrupt handler, if required
|
||||||
if (VIA_State[id].vISR[irq] != NULL) {
|
if (VIA_State[id].vISR[irq] != NULL) {
|
||||||
VIA_State[id].vISR[irq]();
|
VIA_State[id].vISR[irq]();
|
||||||
}*/
|
}
|
||||||
|
VIAorSCCinterruptChngNtfy();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Lower an interrupt by irq number
|
||||||
|
void VIA_LowerInterrupt(uint8_t id, uint8_t irq)
|
||||||
|
{
|
||||||
|
assert (id < VIA_MAXNUM);
|
||||||
|
assert (irq < 7);
|
||||||
|
|
||||||
|
// Set interrupt flag
|
||||||
|
VIA_State[id].vIFR &= ~(1 << irq);
|
||||||
|
|
||||||
|
// Call interrupt handler, if required
|
||||||
|
if (VIA_State[id].vISR[irq] != NULL) {
|
||||||
|
VIA_State[id].vISR[irq]();
|
||||||
|
}
|
||||||
|
VIAorSCCinterruptChngNtfy();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Register a VIA interrupt service routine
|
// Register a VIA interrupt service routine
|
||||||
/*void VIA_RegisterISR(uint8_t id, uint8_t irq, VIA_ISR_t isr)
|
void VIA_RegisterISR(uint8_t id, uint8_t irq, VIA_ISR_t isr)
|
||||||
{
|
{
|
||||||
assert(irq < 7);
|
assert(irq < 7);
|
||||||
assert(id < VIA_MAXNUM);
|
assert(id < VIA_MAXNUM);
|
||||||
VIA_State[id].vISR[irq] = isr;
|
VIA_State[id].vISR[irq] = isr;
|
||||||
}*/
|
}
|
||||||
|
|
||||||
// Register data state-change notification interrupts
|
// Register data state-change notification interrupts
|
||||||
void VIA_RegisterDataISR(uint8_t port, uint8_t id, uint8_t irq, VIA_ISR_t isr)
|
void VIA_RegisterDataISR(uint8_t port, uint8_t id, uint8_t irq, VIA_ISR_t isr)
|
||||||
@ -81,6 +99,8 @@ void VIA_RegisterDataISR(uint8_t port, uint8_t id, uint8_t irq, VIA_ISR_t isr)
|
|||||||
VIA_State[id].vISR_B[irq] = isr;
|
VIA_State[id].vISR_B[irq] = isr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
|
const int TEMPSKIP = 1;
|
||||||
|
|
||||||
// Tick VIA timer 1 (and set PB7 as needed)
|
// Tick VIA timer 1 (and set PB7 as needed)
|
||||||
static void VIA_TickTimer1(uint8_t id)
|
static void VIA_TickTimer1(uint8_t id)
|
||||||
@ -93,10 +113,15 @@ static void VIA_TickTimer1(uint8_t id)
|
|||||||
|
|
||||||
if (via->vT1C == 0) {
|
if (via->vT1C == 0) {
|
||||||
if (T1_PULSE) { via->vT1C = via->vT1L; }
|
if (T1_PULSE) { via->vT1C = via->vT1L; }
|
||||||
if (T1_SNDTOGGLE) { via->vBufB ^= (1 << 7); }
|
if (T1_SNDTOGGLE) {
|
||||||
|
bool snd_old = VIA_ReadBit(id, rIRB, 7);
|
||||||
|
VIA_WriteBit(id, rIRB, 7, !snd_old, true);
|
||||||
|
}
|
||||||
VIA_RaiseInterrupt(id, 6); // always IRQ6
|
VIA_RaiseInterrupt(id, 6); // always IRQ6
|
||||||
} else {
|
} else {
|
||||||
via->vT1C -= 1;
|
if (via->vT1C < TEMPSKIP) { via->vT1C = 0; }
|
||||||
|
else { via->vT1C -= TEMPSKIP; }
|
||||||
|
//via->vT1C -= 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -110,8 +135,16 @@ static void VIA_TickTimer2(uint8_t id, bool forceTick)
|
|||||||
if (T2_ISCOUNTER && !forceTick) { return; }
|
if (T2_ISCOUNTER && !forceTick) { return; }
|
||||||
|
|
||||||
// Do a normal tick
|
// Do a normal tick
|
||||||
if (via->vT2C != 0) { via->vT2C -= 1; }
|
if (via->vT2C != 0) {
|
||||||
else { VIA_RaiseInterrupt(id, 5); } // always IRQ5
|
if (via->vT2C < TEMPSKIP) {
|
||||||
|
via->vT2C = 0;
|
||||||
|
} else {
|
||||||
|
via->vT2C -= 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
VIA_RaiseInterrupt(id, 5); // always IRQ5
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Tick all timers by one step (call every 1.2766 us)
|
// Tick all timers by one step (call every 1.2766 us)
|
||||||
@ -121,6 +154,24 @@ void VIA_TickTimers()
|
|||||||
VIA_TickTimer1(id);
|
VIA_TickTimer1(id);
|
||||||
VIA_TickTimer2(id, false);
|
VIA_TickTimer2(id, false);
|
||||||
}
|
}
|
||||||
|
}*/
|
||||||
|
|
||||||
|
// Do fancy shift register stuff
|
||||||
|
void VIA_TickShiftRegister(uint8_t id)
|
||||||
|
{
|
||||||
|
assert(id < VIA_MAXNUM);
|
||||||
|
VIA_State_t *via = &VIA_State[id];
|
||||||
|
|
||||||
|
switch ((via->vACR & 0x1C) >> 2) {
|
||||||
|
case 3 : /* Shifting In */
|
||||||
|
break;
|
||||||
|
case 6 : /* shift out under o2 clock */
|
||||||
|
VIA_LowerInterrupt(id, 3);
|
||||||
|
VIA_RaiseInterrupt(id, 2);
|
||||||
|
break;
|
||||||
|
case 7 : /* Shifting Out */
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -131,8 +182,11 @@ void VIA_Write(uint8_t id, VIA_Register_t reg, uint8_t data)
|
|||||||
assert(reg < rINVALID);
|
assert(reg < rINVALID);
|
||||||
VIA_State_t *via = &VIA_State[id];
|
VIA_State_t *via = &VIA_State[id];
|
||||||
|
|
||||||
|
uint8_t data_old = VIA_Read(id, reg);
|
||||||
|
|
||||||
switch(reg) {
|
switch(reg) {
|
||||||
case rIRB: via->vBufB = data; break;
|
case rIRB: via->vIFR &= 0b11100111; // clear keyboard interrupts
|
||||||
|
via->vBufB = data; break;
|
||||||
case rIRA:
|
case rIRA:
|
||||||
case rORA: via->vBufA = data; break;
|
case rORA: via->vBufA = data; break;
|
||||||
case rDDRB: via->vDirB = data; break;
|
case rDDRB: via->vDirB = data; break;
|
||||||
@ -165,6 +219,10 @@ void VIA_Write(uint8_t id, VIA_Register_t reg, uint8_t data)
|
|||||||
break;
|
break;
|
||||||
default: assert(true);
|
default: assert(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((data_old & via->vIFR) != (data & via->vIFR) && reg == rIFR) {
|
||||||
|
VIAorSCCinterruptChngNtfy();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read to a register
|
// Read to a register
|
||||||
@ -177,20 +235,22 @@ uint8_t VIA_Read(uint8_t id, VIA_Register_t reg)
|
|||||||
switch(reg) {
|
switch(reg) {
|
||||||
// not sure if reading *all* of vBufA or vBufB is correct,
|
// not sure if reading *all* of vBufA or vBufB is correct,
|
||||||
// but it shouldn't matter.
|
// but it shouldn't matter.
|
||||||
case rIRB: return via->vBufB;
|
case rIRB: via->vIFR &= 0b11100111; // clear keyboard interrupts
|
||||||
|
return via->vBufB;
|
||||||
case rIRA:
|
case rIRA:
|
||||||
case rORA: return via->vBufA;
|
case rORA: return via->vBufA;
|
||||||
case rDDRB: return via->vDirB;
|
case rDDRB: return via->vDirB;
|
||||||
case rDDRA: return via->vDirA;
|
case rDDRA: return via->vDirA;
|
||||||
case rT1CL: //via->vIFR &= 0b10111111;
|
case rT1CL: via->vIFR &= 0b10111111; // TODO: is this used correctly?
|
||||||
return (via->vT1C & 0xFF00) >> 8;
|
return (via->vT1C & 0xFF00) >> 8;
|
||||||
case rT1CH: return (via->vT1C & 0x00FF);
|
case rT1CH: return (via->vT1C & 0x00FF);
|
||||||
case rT1LL: return (via->vT1L & 0xFF00) >> 8;
|
case rT1LL: return (via->vT1L & 0xFF00) >> 8;
|
||||||
case rT1LH: return (via->vT1L & 0x00FF);
|
case rT1LH: return (via->vT1L & 0x00FF);
|
||||||
case rT2CL: //via->vIFR &= 0b11011111;
|
case rT2CL: via->vIFR &= 0b11011111; // TODO: is this used correctly?
|
||||||
return (via->vT2C & 0xFF00) >> 8;
|
return (via->vT2C & 0xFF00) >> 8;
|
||||||
case rT2CH: return (via->vT2C & 0x00FF);
|
case rT2CH: return (via->vT2C & 0x00FF);
|
||||||
case rSR: return via->vSR;
|
case rSR:
|
||||||
|
return via->vSR;
|
||||||
case rACR: return via->vACR;
|
case rACR: return via->vACR;
|
||||||
case rPCR: return via->vPCR;
|
case rPCR: return via->vPCR;
|
||||||
case rIFR: return via->vIFR;
|
case rIFR: return via->vIFR;
|
||||||
@ -232,7 +292,13 @@ void VIA_WriteBit(uint8_t id, VIA_Register_t reg, uint8_t bit, bool value, bool
|
|||||||
void VIA_ShiftInData(uint8_t id, uint8_t v)
|
void VIA_ShiftInData(uint8_t id, uint8_t v)
|
||||||
{
|
{
|
||||||
assert(id < VIA_MAXNUM);
|
assert(id < VIA_MAXNUM);
|
||||||
|
VIA_State_t *via = &VIA_State[id];
|
||||||
|
|
||||||
|
uint8_t ShiftMode = (via->vACR & 0x1C) >> 2;
|
||||||
|
assert(ShiftMode == 0 || ShiftMode == 3);
|
||||||
VIA_State[id].vSR = v;
|
VIA_State[id].vSR = v;
|
||||||
|
VIA_RaiseInterrupt(id, 2); // data ready
|
||||||
|
VIA_RaiseInterrupt(id, 4); // data clock
|
||||||
}
|
}
|
||||||
|
|
||||||
// Called by either end, get data out of vSR
|
// Called by either end, get data out of vSR
|
||||||
@ -240,6 +306,178 @@ void VIA_ShiftInData(uint8_t id, uint8_t v)
|
|||||||
uint8_t VIA_ShiftOutData(uint8_t id)
|
uint8_t VIA_ShiftOutData(uint8_t id)
|
||||||
{
|
{
|
||||||
assert(id < VIA_MAXNUM);
|
assert(id < VIA_MAXNUM);
|
||||||
|
VIA_State_t *via = &VIA_State[id];
|
||||||
|
|
||||||
|
uint8_t ShiftMode = (via->vACR & 0x1C) >> 2;
|
||||||
|
assert(ShiftMode == 7);
|
||||||
|
VIA_RaiseInterrupt(id, 2); // data ready
|
||||||
|
VIA_RaiseInterrupt(id, 3); // data rx
|
||||||
|
VIA_WriteBit(id, rIFR, 4, (via->vSR & 1), false); // data clock
|
||||||
return VIA_State[id].vSR;
|
return VIA_State[id].vSR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Old messy VIA timer code (VIA-1 only for now) ///
|
||||||
|
|
||||||
|
#define CyclesPerViaTime (10 * ClockMult)
|
||||||
|
#define CyclesScaledPerViaTime (kCycleScale * CyclesPerViaTime)
|
||||||
|
|
||||||
|
// TODO: Move these into the VIA_State_t struct
|
||||||
|
bool VIA1_T1Running = true;
|
||||||
|
bool VIA1_T1IntReady = false;
|
||||||
|
iCountt VIA1_T1LastTime = 0;
|
||||||
|
uint8_t VIA1_T1_Active = 0;
|
||||||
|
const uint8_t VIA_T1_IRQ = 6;
|
||||||
|
|
||||||
|
bool VIA1_T2Running = true;
|
||||||
|
bool VIA1_T2IntReady = false;
|
||||||
|
bool VIA1_T2C_ShortTime = false;
|
||||||
|
iCountt VIA1_T2LastTime = 0;
|
||||||
|
uint8_t VIA1_T2_Active = 0;
|
||||||
|
const uint8_t VIA_T2_IRQ = 5;
|
||||||
|
|
||||||
|
|
||||||
|
void VIA1_DoTimer1Check()
|
||||||
|
{
|
||||||
|
if (!VIA1_T1Running) { return; }
|
||||||
|
VIA_State_t *via = &VIA_State[VIA1];
|
||||||
|
|
||||||
|
iCountt NewTime = GetCuriCount();
|
||||||
|
iCountt deltaTime = (NewTime - VIA1_T1LastTime);
|
||||||
|
if (deltaTime != 0) {
|
||||||
|
uint32_t Temp = via->vT1C; /* Get Timer 1 Counter */
|
||||||
|
uint32_t deltaTemp = (deltaTime / CyclesPerViaTime) << (16 - kLn2CycleScale);
|
||||||
|
/* may overflow */
|
||||||
|
uint32_t NewTemp = Temp - deltaTemp;
|
||||||
|
if (
|
||||||
|
(deltaTime > (0x00010000UL * CyclesScaledPerViaTime)) ||
|
||||||
|
((Temp <= deltaTemp) && (Temp != 0))
|
||||||
|
) {
|
||||||
|
//VIA_TickTimer1(VIA1);
|
||||||
|
}
|
||||||
|
|
||||||
|
via->vT1C = NewTemp;
|
||||||
|
VIA1_T1LastTime = NewTime;
|
||||||
|
}
|
||||||
|
|
||||||
|
VIA1_T1IntReady = false;
|
||||||
|
if ((via->vIFR & (1 << VIA_T1_IRQ)) == 0) {
|
||||||
|
if (((via->vACR & 0x40) != 0) || (VIA1_T1_Active == 1)) {
|
||||||
|
uint32_t NewTemp = via->vT1C; /* Get Timer 1 Counter */
|
||||||
|
uint32_t NewTimer;
|
||||||
|
#ifdef _VIA_Debug
|
||||||
|
fprintf(stderr, "posting Timer1Check, %d, %d\n",
|
||||||
|
Temp, GetCuriCount());
|
||||||
|
#endif
|
||||||
|
if (NewTemp == 0) {
|
||||||
|
NewTimer = (0x00010000UL * CyclesScaledPerViaTime);
|
||||||
|
} else {
|
||||||
|
NewTimer =
|
||||||
|
(1 + (NewTemp >> (16 - kLn2CycleScale)))
|
||||||
|
* CyclesPerViaTime;
|
||||||
|
}
|
||||||
|
ICT_add(kICT_VIA1_Timer1Check, NewTimer);
|
||||||
|
VIA1_T1IntReady = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
static void VIA1_CheckT1IntReady(void)
|
||||||
|
{
|
||||||
|
VIA_State_t *via = &VIA_State[VIA1];
|
||||||
|
if (VIA1_T1Running) {
|
||||||
|
bool NewT1IntReady = false;
|
||||||
|
|
||||||
|
if ((via->vIFR & (1 << VIA_T1_IRQ)) == 0) {
|
||||||
|
if (((via->vACR & 0x40) != 0) || (VIA1_T1_Active == 1)) {
|
||||||
|
NewT1IntReady = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (VIA1_T1IntReady != NewT1IntReady) {
|
||||||
|
VIA1_T1IntReady = NewT1IntReady;
|
||||||
|
if (NewT1IntReady) {
|
||||||
|
VIA1_DoTimer1Check();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}*/
|
||||||
|
|
||||||
|
uint16_t VIA1_GetT1InvertTime(void)
|
||||||
|
{
|
||||||
|
VIA_State_t *via = &VIA_State[VIA1];
|
||||||
|
|
||||||
|
if ((via->vACR & 0xC0) == 0xC0) {
|
||||||
|
return via->vT1L;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void VIA1_DoTimer2Check(void)
|
||||||
|
{
|
||||||
|
VIA_State_t *via = &VIA_State[VIA1];
|
||||||
|
if (VIA1_T2Running) {
|
||||||
|
iCountt NewTime = GetCuriCount();
|
||||||
|
/* Get Timer 2 Counter */
|
||||||
|
uint32_t Temp = via->vT2C;
|
||||||
|
iCountt deltaTime = (NewTime - VIA1_T2LastTime);
|
||||||
|
/* may overflow */
|
||||||
|
uint32_t deltaTemp = (deltaTime / CyclesPerViaTime) << (16 - kLn2CycleScale);
|
||||||
|
uint32_t NewTemp = Temp - deltaTemp;
|
||||||
|
if (VIA1_T2_Active == 1) {
|
||||||
|
if (
|
||||||
|
(deltaTime > (0x00010000UL * CyclesScaledPerViaTime)) ||
|
||||||
|
((Temp <= deltaTemp) && (Temp != 0))
|
||||||
|
) {
|
||||||
|
VIA1_T2C_ShortTime = false;
|
||||||
|
VIA1_T2_Active = 0;
|
||||||
|
VIA_RaiseInterrupt(VIA1, VIA_T2_IRQ);
|
||||||
|
#if VIA1_dolog && 1
|
||||||
|
dbglog_WriteNote("VIA1 Timer 2 Interrupt");
|
||||||
|
#endif
|
||||||
|
} else {
|
||||||
|
uint32_t NewTimer;
|
||||||
|
#ifdef _VIA_Debug
|
||||||
|
fprintf(stderr, "posting Timer2Check, %d, %d\n",
|
||||||
|
Temp, GetCuriCount());
|
||||||
|
#endif
|
||||||
|
if (NewTemp == 0) {
|
||||||
|
NewTimer = (0x00010000UL * CyclesScaledPerViaTime);
|
||||||
|
} else {
|
||||||
|
NewTimer = (1 + (NewTemp >> (16 - kLn2CycleScale)))
|
||||||
|
* CyclesPerViaTime;
|
||||||
|
}
|
||||||
|
ICT_add(kICT_VIA1_Timer2Check, NewTimer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
via->vT2C = NewTemp;
|
||||||
|
VIA1_T2LastTime = NewTime;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void VIA1_ExtraTimeBegin(void)
|
||||||
|
{
|
||||||
|
if (VIA1_T1Running) {
|
||||||
|
VIA1_DoTimer1Check(); /* run up to this moment */
|
||||||
|
VIA1_T1Running = false;
|
||||||
|
}
|
||||||
|
if (VIA1_T2Running & (! VIA1_T2C_ShortTime)) {
|
||||||
|
VIA1_DoTimer2Check(); /* run up to this moment */
|
||||||
|
VIA1_T2Running = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void VIA1_ExtraTimeEnd(void)
|
||||||
|
{
|
||||||
|
if (! VIA1_T1Running) {
|
||||||
|
VIA1_T1Running = true;
|
||||||
|
VIA1_T1LastTime = GetCuriCount();
|
||||||
|
VIA1_DoTimer1Check();
|
||||||
|
}
|
||||||
|
if (! VIA1_T2Running) {
|
||||||
|
VIA1_T2Running = true;
|
||||||
|
VIA1_T2LastTime = GetCuriCount();
|
||||||
|
VIA1_DoTimer2Check();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -33,7 +33,7 @@ typedef struct {
|
|||||||
uint16_t vT2L; // Timer 2 latch
|
uint16_t vT2L; // Timer 2 latch
|
||||||
uint16_t vT2C; // Timer 2 counter
|
uint16_t vT2C; // Timer 2 counter
|
||||||
|
|
||||||
//VIA_ISR_t vISR[8]; // ISRs to automatically call when interrupt is raised
|
VIA_ISR_t vISR[8]; // ISRs to automatically call when interrupt is raised
|
||||||
VIA_ISR_t vISR_A[8]; // ISRs to call when vBufA changes
|
VIA_ISR_t vISR_A[8]; // ISRs to call when vBufA changes
|
||||||
VIA_ISR_t vISR_B[8]; // ISRs to call when vBufB changes
|
VIA_ISR_t vISR_B[8]; // ISRs to call when vBufB changes
|
||||||
} VIA_State_t;
|
} VIA_State_t;
|
||||||
@ -79,7 +79,7 @@ void VIA_RaiseInterrupt(uint8_t id, uint8_t irq);
|
|||||||
void VIA_RegisterDataISR(uint8_t port, uint8_t id, uint8_t bit, VIA_ISR_t isr);
|
void VIA_RegisterDataISR(uint8_t port, uint8_t id, uint8_t bit, VIA_ISR_t isr);
|
||||||
|
|
||||||
// Tick all timers by one step (call every 1.2766 us)
|
// Tick all timers by one step (call every 1.2766 us)
|
||||||
void VIA_TickTimers();
|
//void VIA_TickTimers();
|
||||||
|
|
||||||
// Write to a register. Does not raise data ISRs.
|
// Write to a register. Does not raise data ISRs.
|
||||||
void VIA_Write(uint8_t id, VIA_Register_t reg, uint8_t data);
|
void VIA_Write(uint8_t id, VIA_Register_t reg, uint8_t data);
|
||||||
@ -93,3 +93,10 @@ void VIA_WriteBit(uint8_t id, VIA_Register_t reg, uint8_t bit, bool value, bool
|
|||||||
// NOTE: for these, raise the interrupt manually w/ VIA_RaiseInterrupt
|
// NOTE: for these, raise the interrupt manually w/ VIA_RaiseInterrupt
|
||||||
void VIA_ShiftInData(uint8_t id, uint8_t v);
|
void VIA_ShiftInData(uint8_t id, uint8_t v);
|
||||||
uint8_t VIA_ShiftOutData(uint8_t id);
|
uint8_t VIA_ShiftOutData(uint8_t id);
|
||||||
|
|
||||||
|
// Compatiblity stuff, probably
|
||||||
|
void VIA1_DoTimer1Check();
|
||||||
|
uint16_t VIA1_GetT1InvertTime();
|
||||||
|
void VIA1_DoTimer2Check();
|
||||||
|
void VIA1_ExtraTimeBegin(void);
|
||||||
|
void VIA1_ExtraTimeEnd(void);
|
||||||
|
@ -64,14 +64,14 @@ const DevMethods_t DEVICES[] = {
|
|||||||
{
|
{
|
||||||
.init = VIA_Zap,
|
.init = VIA_Zap,
|
||||||
.reset = VIA_Reset,
|
.reset = VIA_Reset,
|
||||||
.starttick = VIA_TickTimers,
|
.starttick = NULL,//VIA_TickTimers,
|
||||||
.endtick = NULL,
|
.endtick = NULL,
|
||||||
.subtick = NULL,
|
.subtick = NULL,
|
||||||
.timebegin = NULL,
|
.timebegin = VIA1_ExtraTimeBegin,
|
||||||
.timeend = NULL,
|
.timeend = VIA1_ExtraTimeEnd,
|
||||||
},
|
},
|
||||||
// RTC
|
// RTC
|
||||||
{
|
/* {
|
||||||
.init = EmRTC ? RTC_Init : NULL,
|
.init = EmRTC ? RTC_Init : NULL,
|
||||||
.reset = NULL,
|
.reset = NULL,
|
||||||
.starttick = NULL,
|
.starttick = NULL,
|
||||||
@ -79,7 +79,7 @@ const DevMethods_t DEVICES[] = {
|
|||||||
.subtick = NULL,
|
.subtick = NULL,
|
||||||
.timebegin = NULL,
|
.timebegin = NULL,
|
||||||
.timeend = NULL,
|
.timeend = NULL,
|
||||||
},
|
},*/
|
||||||
// ROM
|
// ROM
|
||||||
{
|
{
|
||||||
.init = ROM_Init,
|
.init = ROM_Init,
|
||||||
@ -121,7 +121,7 @@ const DevMethods_t DEVICES[] = {
|
|||||||
.timeend = NULL,
|
.timeend = NULL,
|
||||||
},*/
|
},*/
|
||||||
// SCSI
|
// SCSI
|
||||||
{
|
/* {
|
||||||
.init = NULL,
|
.init = NULL,
|
||||||
.reset = SCSI_Reset,
|
.reset = SCSI_Reset,
|
||||||
.starttick = NULL,
|
.starttick = NULL,
|
||||||
@ -139,7 +139,7 @@ const DevMethods_t DEVICES[] = {
|
|||||||
.subtick = NULL,
|
.subtick = NULL,
|
||||||
.timebegin = NULL,
|
.timebegin = NULL,
|
||||||
.timeend = NULL,
|
.timeend = NULL,
|
||||||
},
|
},*/
|
||||||
// Extn
|
// Extn
|
||||||
{
|
{
|
||||||
.init = NULL,
|
.init = NULL,
|
||||||
@ -161,7 +161,7 @@ const DevMethods_t DEVICES[] = {
|
|||||||
.timeend = NULL,
|
.timeend = NULL,
|
||||||
},
|
},
|
||||||
// Mouse
|
// Mouse
|
||||||
{
|
/* {
|
||||||
.init = NULL,
|
.init = NULL,
|
||||||
.reset = NULL,
|
.reset = NULL,
|
||||||
.starttick = Mouse_Update,
|
.starttick = Mouse_Update,
|
||||||
@ -169,9 +169,9 @@ const DevMethods_t DEVICES[] = {
|
|||||||
.subtick = NULL,
|
.subtick = NULL,
|
||||||
.timebegin = NULL,
|
.timebegin = NULL,
|
||||||
.timeend = NULL,
|
.timeend = NULL,
|
||||||
},
|
},*/
|
||||||
// Classic Keyboard
|
// Classic Keyboard
|
||||||
{
|
/* {
|
||||||
.init = NULL,
|
.init = NULL,
|
||||||
.reset = NULL,
|
.reset = NULL,
|
||||||
.starttick = EmClassicKbrd ? KeyBoard_Update : NULL,
|
.starttick = EmClassicKbrd ? KeyBoard_Update : NULL,
|
||||||
@ -179,7 +179,7 @@ const DevMethods_t DEVICES[] = {
|
|||||||
.subtick = NULL,
|
.subtick = NULL,
|
||||||
.timebegin = NULL,
|
.timebegin = NULL,
|
||||||
.timeend = NULL,
|
.timeend = NULL,
|
||||||
},
|
},*/
|
||||||
// ADB
|
// ADB
|
||||||
/*{
|
/*{
|
||||||
.init = NULL,
|
.init = NULL,
|
||||||
@ -210,7 +210,7 @@ const DevMethods_t DEVICES[] = {
|
|||||||
.timeend = NULL,
|
.timeend = NULL,
|
||||||
},*/
|
},*/
|
||||||
// ASC
|
// ASC
|
||||||
{
|
/* {
|
||||||
.init = NULL,
|
.init = NULL,
|
||||||
.reset = NULL,
|
.reset = NULL,
|
||||||
.starttick = NULL,
|
.starttick = NULL,
|
||||||
@ -218,7 +218,7 @@ const DevMethods_t DEVICES[] = {
|
|||||||
.subtick = EmASC ? ASC_SubTick : NULL,
|
.subtick = EmASC ? ASC_SubTick : NULL,
|
||||||
.timebegin = NULL,
|
.timebegin = NULL,
|
||||||
.timeend = NULL
|
.timeend = NULL
|
||||||
},
|
},*/
|
||||||
// Sound (non-ASC)
|
// Sound (non-ASC)
|
||||||
{
|
{
|
||||||
.init = NULL,
|
.init = NULL,
|
||||||
@ -293,14 +293,14 @@ LOCALPROC SubTickTaskDo(void)
|
|||||||
might not equal CyclesScaledPerTick.
|
might not equal CyclesScaledPerTick.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
//ICT_add(kICT_SubTick, CyclesScaledPerSubTick);
|
ICT_add(kICT_SubTick, CyclesScaledPerSubTick);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCALPROC SubTickTaskStart(void)
|
LOCALPROC SubTickTaskStart(void)
|
||||||
{
|
{
|
||||||
SubTickCounter = 0;
|
SubTickCounter = 0;
|
||||||
//ICT_add(kICT_SubTick, CyclesScaledPerSubTick);
|
ICT_add(kICT_SubTick, CyclesScaledPerSubTick);
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCALPROC SubTickTaskEnd(void)
|
LOCALPROC SubTickTaskEnd(void)
|
||||||
@ -324,7 +324,6 @@ LOCALPROC SixtiethSecondNotify(void)
|
|||||||
if (EmClassicKbrd) { KeyBoard_Update(); }
|
if (EmClassicKbrd) { KeyBoard_Update(); }
|
||||||
//if (EmADB) { ADB_Update(); }
|
//if (EmADB) { ADB_Update(); }
|
||||||
|
|
||||||
//Sixtieth_PulseNtfy(); /* Vertical Blanking Interrupt */
|
|
||||||
Screen_RaiseVBlank();
|
Screen_RaiseVBlank();
|
||||||
Sony_Update();
|
Sony_Update();
|
||||||
|
|
||||||
@ -391,7 +390,6 @@ LOCALFUNC bool InitEmulation(void)
|
|||||||
}
|
}
|
||||||
// VBlank interrupt
|
// VBlank interrupt
|
||||||
|
|
||||||
#if 0
|
|
||||||
LOCALPROC ICT_DoTask(int taskid)
|
LOCALPROC ICT_DoTask(int taskid)
|
||||||
{
|
{
|
||||||
switch (taskid) {
|
switch (taskid) {
|
||||||
@ -422,14 +420,6 @@ LOCALPROC ICT_DoTask(int taskid)
|
|||||||
case kICT_VIA1_Timer2Check:
|
case kICT_VIA1_Timer2Check:
|
||||||
VIA1_DoTimer2Check();
|
VIA1_DoTimer2Check();
|
||||||
break;
|
break;
|
||||||
#if EmVIA2
|
|
||||||
case kICT_VIA2_Timer1Check:
|
|
||||||
VIA2_DoTimer1Check();
|
|
||||||
break;
|
|
||||||
case kICT_VIA2_Timer2Check:
|
|
||||||
VIA2_DoTimer2Check();
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
default:
|
default:
|
||||||
ReportAbnormalID(0x1001, "unknown taskid in ICT_DoTask");
|
ReportAbnormalID(0x1001, "unknown taskid in ICT_DoTask");
|
||||||
break;
|
break;
|
||||||
@ -471,19 +461,18 @@ LOCALFUNC uint32_t ICT_DoGetNext(uint32_t maxn)
|
|||||||
|
|
||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
LOCALPROC m68k_go_nCycles_1(uint32_t n)
|
LOCALPROC m68k_go_nCycles_1(uint32_t n)
|
||||||
{
|
{
|
||||||
//uint32_t n2;
|
uint32_t n2;
|
||||||
//uint32_t StopiCount = NextiCount + n;
|
uint32_t StopiCount = NextiCount + n;
|
||||||
//do {
|
do {
|
||||||
/*ICT_DoCurrentTasks();
|
ICT_DoCurrentTasks();
|
||||||
n2 = ICT_DoGetNext(n);
|
n2 = ICT_DoGetNext(n);
|
||||||
NextiCount += n2;*/
|
NextiCount += n2;
|
||||||
m68k_go_nCycles(n);
|
m68k_go_nCycles(n2);
|
||||||
//n = StopiCount - NextiCount;
|
n = StopiCount - NextiCount;
|
||||||
//} while (n != 0);
|
} while (n != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCALVAR uint32_t ExtraSubTicksToDo = 0;
|
LOCALVAR uint32_t ExtraSubTicksToDo = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user