Snooping

Wat het is

Snooping is een eigenschap van WHDLoad waarvan de actie het is te bevestigen en het loggen van toegangen naar de Custom en Cia registers. Als Snoop is geactiveerd zullen alle ongeldige toegangen een Toegangs Fout creëren en het geïnstalleerde programma word beëindigd. WHDLoad laat een requester zien die uitlegt wat de reden van deze fout is.

Custom registers

Alle lees en schrijf toegangen naar de custom registers worden gecontroleerd. Ongeldige toegangen zijn: Strobe registers kunnen gelezen of beschreven worden. De set van geldige Custom registers kunnen variëren tussen OCS (Oude ChipSet - A500, A1000, oude A2000), ECS (Enhanced ChipSet - A600, nieuwe A2000, A3000) en AGA (Advanced Graphics - A1200, A4000). Dit is handig speciaal om bugs te ontdekken in oude programma's veroorzaakt door ongedefinieerde toegangen tot nieuwe AGA registers.

Cia registers

Op de Cia registers worden alleen schrijf toegangen geverifiëerd Dat betekend dat lees toegangen naar niet bestaande registers in het geheugen gebied van $bfd000...$bfefff niet worden gedetecteerd. Voor alle schrijf toegangen word de geschreven waarde intern weggeschreven door WHDLoad. Voor sommige Cia registers zijn daar speciale checks voor afhankelijk van de geschreven waarde:

adres register controle
$bfe001 ciaa.ciapra het zetten van de Overlay bit op #0 is verboden
$bfe201 ciaa.ciaddra bits #6-7 kunnen elke waarde hebben (gebruikt met joypad), lagere bits moeten zijn %000011
$bfe801 ciaa.ciatodlow lees-wijzig-schrijf toegangen (bijv. bchg) zijn niet toegestaan als ALARM bit is ingesteld in ciaa.ciacrb (alleen gecheckt op een 68060)
$bfe901 ciaa.ciatodmid
$bfea01 ciaa.ciatodhi
$bfed01 ciaa.ciaicr lees-wijzig-schrijf toegangen (bijv. bchg) zijn niet toegestaan (alleen gecheckt op een 68060)
$bfd100 ciab.ciaprb de bits voor MOTOR #7, SELECT #3-6 en STEP #0 moeten niet leeggehaald worden, andere bits kunnen veranderd worden; met dat kunnen alle toegangen tot floppy drives gedetecteerd worden
$bfd200 ciab.ciaddra de geschreven waarde moet zijn %11000000
$bfd300 ciab.ciaddrb de geschreven waarde moet zijn %11111111
$bfd800 ciab.ciatodlow lees-wijzig-schrijf toegangen (bijv. bchg) zijn niet toegestaan als ALARM bit is ingesteld in ciab.ciacrb (alleen gecheckt op een 68060)
$bfd900 ciab.ciatodmid
$bfda00 ciab.ciatodhi
$bfdd00 ciab.ciaicr lees-wijzig-schrijf toegangen (bijv. bchg) zijn niet toegestaan (alleen gecheckt op een 68060)

Hoe werkt het

Als Snoop geactiveerd is, markeert WHDLoad de adressen van de custom en cia registers als ongeldig/beveiligd tegen schrijven in de MMU vertaal boom. Hierom resulteert elke toegang naar een custom of cia register in een Toegangs Fout uitzondering. De uitzondering handler in WHDLoad behandelt deze uitzondering. Eerst checkt het of de toegang geldig is. Als de toegang ongeldig is wordt het programma beëindigd. Als de toegang geldig is en een lees operatie is dan word het geëmuleerd en word de programma uitvoer hervat. Als het een schrijf operatie is zal WHDLoad extra de waarden schrijven naar een interne opslag.
Om de overhead van de uitzondering en de emulatie volgorde word de programma uitvoer langzamer. Hoeveel langzamer ligt aan de CPU type, Chip Memory type (16/32-bit) en Stackpointer gepositioneerd als de Chip Memory 32-bit is (Lange Woord gepositioneerd of niet). Het verschilt ook voor de toegangs type (Byte/Woord/Lange Woord, Lezen/Schrijven). Op de 68030 is Schrijven sneller dan Lezen (omdat bij lezen de stack frame 92 bytes is en bij schrijven 32 bytes), op de 68060 is Lezen sneller omdat de emulatie voor schrijven meer complex is.

Snelle Snoop Mode

De optie Snoop/S activeert de snelle snooping. Lees toegangen worden niet gecontroleerd. Geen speciale checks worden uitgevoerd. Deze mode kan handig zijn om alleen de inhoud van custom registers te verkrijgen, bijv. om een plaatje weg te schrijven met SP.

Copper Lijst Scanner

Vanaf versie 13 van WHDLoad worden ook copperlijsten zelf gecheckt. De scanner word geactiveerd tijdens het schrijven naar de coplc registers als de copper dma geactiveerd is, of wanneer het geïnstalleerde programma de copper dma activeert door het schrijven van de dmacon register. De scanner volgt de copperlijst en valideert alle Verplaats instructies door restricties toe te passen veroorzaakt door de Snoop optie (OCS/ECS/AGA). Sla over en Wacht (behalve CEND) instructies worden genegeerd. Wanneer het ongeldige notities vind, word het geïnstalleerde programma beëindigd. De scanner volgt takken (copjmp), detecteert loops en checkt tot wel 16 sublijsten. De Verplaatsingen in de copperlijst worden weggeschreven in de interne custom register bestand wat word gedumpt bij het verlaten van WHDLoad. De scanner is niet actief in Snelle Snoop Mode.

Blitter Prioriteiten Check

Wanneer de optie ChkBltHog/S is geactiveerd zal WHDLoad checken of het geïnstalleerde programma niet BltHog activeert door het schrijven naar de dmacon register. De Blitter prioriteit kan problemen veroorzaken op sommige hardware configuraties in samenwerking met grote blitter operaties (alle kanalen gebruikt.)

Blitter Grootte Check

Wanneer de optie ChkBltSize/S is geactiveerd zal WHDLoad checken dat blitter werkzaamheden niet toegang krijgen tot geheugen buiten het BaseMem gebied. Tijdens schrijf toegangen naar bltsize of bltsizh checkt het of de regel mode is ingeschakeld in bltcon1. Als de regel mode actief is verbreekt het de grootte check. Anders zal WHDLoad de toegang van het eerste en laatste woord berekenen voor elke geactiveerde DMA kanaal. Als 1 adres buiten het BaseMem gebied bevind zal het programma worden gestopt met een requester. De berekening is ontworpen om te werken met alle modes (stijgend/dalend, positieve/negatieve modulos, oneven modulos/verwijzing).
Weet dat de regel teken mode niet geverifieerd word en dat alle blitter registers ook geschreven worden door de copper als copcon is ingeschakeld.

Blitter Wacht Check

Als de optie ChkBltWait/S is geactiveerd zal WHDLoad een instructie spoor gebruiken om te verifiëren dat het geïnstalleerde programma correct wacht op de blitter om te stoppen voordat het start met een nieuwe blitter operatie. Het gebruikt een interne variabele welke de werkende staat van de blitter vertegenwoordigd. De variabele is ingeschakeld wanneer een schrijf toegang naar de bltsize of bltsizh plaatsvind en leeggemaakt word wanneer lees toegang naar het dmaconr register is uitgevoerd. Op elke schrijven naar een blitter register word de interne variabele gecheckt, als het een draaiende blitter operatie constateert word het geïnstalleerde programma gestopt en zal WHDLoad de PC van de laatst gestarte blitter operatie samen met de eigenlijke toegang rapporteren.
Er zijn 2 grote knelpunten met deze eigenschap. Ten eerste blitter gebruik via de copper is niet gecheckt en ten tweede het gebruik van blitter onderbreking zorgt ervoor dat de check routine fouten rapporteert die niet nodig zijn.

Toekomst

Het is de bedoeling om eigenschappen toe te voegen zoals Freezing en Iconifing. Van deze, is Snoop een essentiële aanname. Daarom is het aanbevolen voor Install auteurs om hun Installs te checken met Snoop om toekomstige compatibiliteit te waarborgen.

Benodigdheden

Een MMU is nodig voor de Snoop eigenschap. Ook moet WHDLoad de MMU gebruiken, daarom moet MMU/S geactiveerd zijn op 68030 machines.

Beperkingen