

# AMSTRAD CPC / CRTC 0

## SHAKER V1.8 OUTPUT

LOGON SYSTEM 2021 / LONGSHOT

More information about CRTC in Amstrad Cpc Crtc Compendium  
("con de chat canadien")

## Sommaire

|                                                              |    |
|--------------------------------------------------------------|----|
| UPDATE VRAM VS CRTC .....                                    | 3  |
| SKEW DISP ON R0 RUPTURE .....                                | 4  |
| INTERRUPT DELAY FROM R2 .....                                | 7  |
| UPDATE CRTC R0 TIMING .....                                  | 9  |
| R13 UPDATE IN 4 USEC SCREENS (R0=3) .....                    | 10 |
| R13 UPDATE IN 2 USEC SCREENS (R0=1) .....                    | 13 |
| R13 UPDATE IN 1 USEC SCREENS (R0=0) .....                    | 16 |
| GATE ARRAY PIXELISATION .....                                | 19 |
| GATE ARRAY INKERISATION .....                                | 20 |
| GATE ARRAY MODERISATION .....                                | 22 |
| HSYNC DELAY ON MODE UPDATE, R2 UPDATE/R3 LENGTH 2 to 0 ..... | 23 |
| R2 UPDATE DURING & AFTER HSYNC .....                         | 25 |
| R3 UPDATE DURING HSYNC .....                                 | 29 |
| R4 & R9 CHECKING .....                                       | 34 |
| VSYNC CONDITIONS .....                                       | 35 |
| R1 STORIES .....                                             | 37 |
| R6 STORIES .....                                             | 41 |
| RVNI (NON INVISIBLE VERTICAL RUPTURE) .....                  | 48 |
| ANALYZER / FORCED STABILISATION ON R0=0 .....                | 50 |
| R5 SCANNER (for CRTC 1) .....                                | 53 |
| R5 STORIES / INTERACTIVE TEST .....                          | 54 |
| OFFSET UPDATE .....                                          | 55 |
| « RVMB » .....                                               | 57 |
| BOUNGA : CRTC 2 R4=R9=0 FORCED .....                         | 69 |
| INTERLACE VM .....                                           | 70 |
| INTERLACE C4/C9 COUNTERS .....                               | 72 |
| INTERLACE CRTC 2 C9 STRANGER THING .....                     | 84 |
| FAKE VSYNC ON CRTC 2 .....                                   | 85 |
| CRTC 2 FIND CO MIN .....                                     | 86 |
| CRTC 2 - 1 LINE RUPTURE .....                                | 87 |
| CRTC 1 – BUG OUTI R0 .....                                   | 88 |
| CRTC 1- BE00 CHECK .....                                     | 89 |

# UPDATE VRAM VS CRTC

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM

(1) UPDATE URAM US CRTC (14 TST) (0) CRTC 2 RUMB  
 (2) SKEW DISP ON R0 RUPTURE (5 TST) (F0) BOUNGA:CRTC 2 ZERO!  
 (3) INTERRUPT DELAY FROM R2 (18 CALC) (F1) INTERLACE UM (27 TST)  
 (4) UPDATE CRTC R0 TIMING (7 TST)  
 (5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
 (6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
 (7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
 (8) GATE ARRAY PIXELISATION  
 (9) GATE ARRAY INKERISATION (3 TST)  
 (E) GATE ARRAY MODERISATION  
 (R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)  
 (T) R2 UPD DURING & AFTER HSYNC (6 TST)  
 (Y) R3 UPD DURING HSYNC (8 TST)  
 (U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
 (I) VSYNC CONDITIONS (16 TST)  
 (O) R1 STORIES (7 TST)  
 (P) R6 STORIES (11 TST)  
 (RETURN) RUNI LTD  
 (CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
 (CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
 (COPY) CRTC 2 OFFSET  
 (DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
 !! REF COvs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!

CREDS 0.1, TASV 0.1.0

## SKEW DISP ON R0 RUPTURE

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM US CRTC (14 TST)  
(2) SKEW DISP ON R0 RUPTURE (5 TST)  
(3) INTERRUPT DELAY FROM R2 (18 CALC)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) USYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC USYNC FROM PPI.PORTB.0=1 !!







## INTERRUPT DELAY FROM R2

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE URAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
(RETURN) RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT < CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```

DISPLAY BETWEEN HSYNC (CODE R2) AND INTERRUPTION (CALL #38)

| R3=0E | INTERRUPT OCCURS | #0F USEC AFTER | 00=R2 | (#FF=NO INT) |
|-------|------------------|----------------|-------|--------------|
| R3=0D | INTERRUPT OCCURS | #0E USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=0C | INTERRUPT OCCURS | #0D USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=0B | INTERRUPT OCCURS | #0C USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=0A | INTERRUPT OCCURS | #0B USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=09 | INTERRUPT OCCURS | #0A USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=08 | INTERRUPT OCCURS | #09 USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=07 | INTERRUPT OCCURS | #08 USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=06 | INTERRUPT OCCURS | #07 USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=05 | INTERRUPT OCCURS | #06 USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=04 | INTERRUPT OCCURS | #05 USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=03 | INTERRUPT OCCURS | #04 USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=02 | INTERRUPT OCCURS | #03 USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=01 | INTERRUPT OCCURS | #02 USEC AFTER | 00=R2 | (#FF=NO INT) |
| R3=00 | INTERRUPT OCCURS | #01 USEC AFTER | 00=R2 | (#FF=NO INT) |

VSYNC DURATION (6=8180 ON CRT 0,3,4) (8=8400 ALL CRT / n=8400 CRT 1,2)

R3 High=6 => SIZE=80180 USEC

R3 High=8 => SIZE=80400 USEC

DELAY OF 'CALL TO #38' ON INTERRUPTION IS 05 USEC (RST#38=4 USEC)

CRTC 0

DISPLAY BY ALLEN HSIEH (DCE2) AND INTERRUPTION LOG (IM2)

WHEN R3=0E, INTERRUPT OCCURS #0F USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=0D, INTERRUPT OCCURS #0E USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=0C, INTERRUPT OCCURS #0D USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=0B, INTERRUPT OCCURS #0C USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=0A, INTERRUPT OCCURS #0B USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=09, INTERRUPT OCCURS #0A USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=08, INTERRUPT OCCURS #09 USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=07, INTERRUPT OCCURS #08 USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=06, INTERRUPT OCCURS #07 USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=05, INTERRUPT OCCURS #06 USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=04, INTERRUPT OCCURS #05 USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=03, INTERRUPT OCCURS #04 USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=02, INTERRUPT OCCURS #03 USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=01, INTERRUPT OCCURS #02 USEC AFTER CB=R2 (#FF=NO INT)

WHEN R3=00, INTERRUPT OCCURS #FF USEC AFTER CB=R2 (#FF=NO INT)

USING DURATION (S=8180 ON CRT 0,3,4) (0=8400 ALL CRT / n=8400 CRT 1,2)

R3 High=0 )) SIZE=80180 uSEC

R3 High=0 )) SIZE=80400 uSEC

DELAY OF INTERRUPTION CALL (IM2) IS 87 uSEC

CRTC 0

## UPDATE CRTC R0 TIMING

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE VRAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD_UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
(RETURN) RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```

```
CODE: / CRTC 10 ON R0 (0010C) (C)
OK: C0=..3F..40..41.. / KG: C0E..3F..00..01..
UPDATE R0=7F, OUT OM HCC=39 :OK
UPDATE R0=7F, OUT OM HCC=3A :OK
UPDATE R0=7F, OUT OM HCC=3B :OK
UPDATE R0=7F, OUT OM HCC=3C :OK
UPDATE R0=7F, OUT OM HCC=3D :OK
UPDATE R0=7F, OUT OM HCC=3E :NO
UPDATE R0=7F, OUT OM HCC=3F :NO
OUTI OM C0vs=#3c:01 (01:ID OM 5TH MOP / 0B:ID OM 4TH MOP)

CRTC 0
```

## R13 UPDATE IN 4 USEC SCREENS (R0=3)

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE VRAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD_UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
(RETURN) RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```







## R13 UPDATE IN 2 USEC SCREENS (R0=1)

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM VS CRTC (14 TST) (0) CRTC 2 RUMB  
(2) SKEW DISP ON R0 RUPTURE (5 TST) (F0) BOUNGA:CRTC 2 ZERO!  
(3) INTERRUPT DELAY FROM R2 (18 CALC) (F1) INTERLACE VM (27 TST)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
**(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)**  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) USYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC USYNC FROM PPI.PORTB.0=1 !!







## R13 UPDATE IN 1 USEC SCREENS (R0=0)

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE VRAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD_UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
(RETURN) RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```







## GATE ARRAY PIXELISATION

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM VS CRTC (14 TST)  
(2) SKEW DISP ON R0 RUPTURE (5 TST)  
(3) INTERRUPT DELAY FROM R2 (18 CALC)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD, UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) USYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC USYNC FROM PPI.PORTB.0=1 !!



## GATE ARRAY INKERISATION

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM VS CRTC (14 TST) (0) CRTC 2 RUMB  
(2) SKEW DISP ON R0 RUPTURE (5 TST) (F0) BOUNGA:CRTC 2 ZERO!  
(3) INTERRUPT DELAY FROM R2 (18 CALC) (F1) INTERLACE VM (27 TST)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) VSYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!





## GATE ARRAY MODERISATION

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM VS CRTC (14 TST)  
(2) SKEW DISP ON R0 RUPTURE (5 TST)  
(3) INTERRUPT DELAY FROM R2 (18 CALC)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
**(E) GATE ARRAY MODERISATION**  
(R) HSYNC DELAY MODE UPD\_UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) VSYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!



## HSYNC DELAY ON MODE UPDATE, R2 UPDATE/R3 LENGTH 2 to 0

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM VS CRTC (14 TST)  
(2) SKEW DISP ON R0 RUPTURE (5 TST)  
(3) INTERRUPT DELAY FROM R2 (18 CALC)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD, UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) VSYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!



00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27



TESTS : R2 UPDATE / R3 LENGTH FOR MODISATION / R3=0 SETTING (ON 3RD ZONE)  
OUT R2,#98 ON CH=7,8,9,A (CRTC CH=SCREEN CH=1)  
YELLOW COLOR ONLY IN MODE 2

CRTC 0

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27



TESTS : R2 UPDATE / R3 LENGTH FOR MODISATION / R3=0 SETTING (ON 3RD ZONE)  
OUT R2,#98 ON CH=7,8,9,A (CRTC CH=SCREEN CH=1)  
YELLOW COLOR ONLY IN MODE 2

CRTC 0

## R2 UPDATE DURING & AFTER HSYNC

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM US CRTC (14 TST) (0) CRTC 2 RUMB  
(2) SKEW DISP ON R0 RUPTURE (5 TST) (F0) BOUNGA:CRTC 2 ZERO!  
(3) INTERRUPT DELAY FROM R2 (18 CALC) (F1) INTERLACE VM (27 TST)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) VSYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!



R2 UPDATE DURING HSYNC  
R2=#0B / R3=10 / ON C0=#0D0E0F10, OUT R2,#12 (+ R2=#2E ON C0=#23)

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

CRTC 0

R2 UPDATE DURING HSYNC  
R2=#0B / R3=10 / ON C0=#0D0E0F10, OUT R2,#13 (+ R2=#2E ON C0=#23)

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

CRTC 0

R2 UPDATE DURING HSYNC  
R2=#0B / R3=10 / ON CB=#0D0E0F10, OUT R2,#14 (+ R2=#2E ON CB=#23)

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

CRTC 0

R2 UPDATE DURING HSYNC  
R2=#0B / R3=10 / ON CB=#0D0E0F10, OUT R2,#15 (+ R2=#2E ON CB=#23)

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

CRTC 0

R2 UPDATE DURING HSYNC  
R2=00B / R3=10 / ON C0=#0D0DDF10, OUT R2,#16 (+ R2=#2E ON C0=#23)

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

CRTC 0

### R3 UPDATE DURING HSYNC

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE VRAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD_UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
(RETURN) RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```



R3 UPDATE DURING HSYNC

R2=#0B / R3=10 / ON CB=#0D0000F10 OUT R3,#01 (+ R2=#2E ON CB=#2A)  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

CRIC 0

R3 UPDATE DURING HSYNC

R2=#0B / R3=10 / ON CB=#0D0000F10 OUT R3,#02 (+ R2=#2E ON CB=#2A)  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

CRIC 0

R3 UPDATE DURING HSYNC

R2=#0B / R3=10 / ON C0=#0D0E0F10 OUT R3,#03 (+ R2=#2E ON C0=#2A)  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26

CRTC 0

R3 UPDATE DURING HSYNC

R2=#0B / R3=10 / ON C0=#0D0E0F10 OUT R3,#04 (+ R2=#2E ON C0=#2A)  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26

CRTC 0



R3 UPDATE DURING HSINC

72=00 / R3=10 / OM CB=00000010 OUT R3, #07 (+ R2=02E OM CB=02A)

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

00 02 04 06 08 0A 0C 0E 10 12 14 16 18 1A 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27

CRTC 8

## R4 & R9 CHECKING

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM VS CRTC (14 TST)  
(2) SKEW DISP ON R0 RUPTURE (5 TST)  
(3) INTERRUPT DELAY FROM R2 (18 CALC)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
**(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))**  
(I) VSYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!

### RESULT OF CRT-R4 & R9 CHECK

```
PREV R9=7 )) UPD R9=1 WHEN (C9=3) > C9=0 (OK FOR CRT 3+4 ONLY):>x0x
PREV R9=7 R4=38 )) UPD R4=1 WHEN (C4=1 & C9=7 )) C4=0 :>x0x
PREV R9=7 R4=38 )) UPD R4=0 WHEN (C4=1 & C9=7 )) C4=2 (0vf) :OK
PREV R9=7 R4=38 )) UPD R9=0 WHEN (C4=1 & C9=0 (UPD FROM C0vsio)(00=Upd V))
    )) 3C=00/3D=00/3E=00/3F=00/00=01/01=01/02=01/03=01/04=01/05=01
PREV R9=7 R4=38 )) UPD R4=1 WHEN (C4=1 & C9=7 (UPD FROM C0vsio))(01=C4 0vf)
    )) 3C=01/3D=01/3E=01/3F=01/00=01/01=01/02=01/03=01/04=01/05=01
PREV R9=7 R4=1 )) UPD R3=1 WHEN (C4=1 & C9=7 LASTLINE FROM C0=#23 R2=#2E(01:C9=0)
01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01 01
PREV R9=7 R4=1 )) UPD R4=3 WHEN (C4=1 & C9=7 (LAST LINE):01 (00:C4nvf 01:C4=0)
PREV R9=7 R4=1 )) UPD R4=0 WHEN (C4=1 & C9=7 (UPD FROM C0vsio)(01:C4=0 00:C4 nvf)
    )) 3C=01/3D=01/3E=01/3F=01/00=01/01=01/02=01/03=01/04=01/05=01
```

CRTC 0

## VSYNC CONDITIONS

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM VS CRTC (14 TST)  
(2) SKEW DISP ON R0 RUPTURE (5 TST)  
(3) INTERRUPT DELAY FROM R2 (18 CALC)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD, UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) VSYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!

### VSYNC MANAGEMENT DURING R3

R3 APPLIED ON ALL VALUES OF C4  
R2=50, R3=12, RD=63 :V1:#5E, U2:#5F  
R2=50, R3=13, RD=63 :V1:#5E, U2:#5F  
R2=50, R3=14, RD=63 :V1:#5E, U2:#5F  
R2=50, R3=15, RD=63 :V1:#5E, U2:#5F

R3 APPLIED ON ALL VALUES OF C4, EXCEPTED WHEN C4=R7 (C9=0) (THEN R3=12)

R2=50, R3=12, RD=63 :V1:#5E, U2:#5F

R2=50, R3=13, RD=63 :V1:#5E, U2:#5F

R2=50, R3=14, RD=63 :V1:#5E, U2:#5F

R2=50, R3=15, RD=63 :V1:#5E, U2:#5F

R2=50, R3=15, RD=63 :V1:#5E, U2:#5F ON PREVIOUS LINE

VSYNC CONDITIONS IN HSYNC (R2:#2E/R3=14)

>> UPD R2=04 ON C9=0, C0v=#35 PPI.B ON C9=0, C0v=#3A:#5F

>> UPD R2=04 ON C9=0, C0v=#35 PPI.B ON C9=0, C0v=#3E:#5F

>> UPD R2=04 ON C9=0, C0v=#35 PPI.B ON C9=1, C0v=#3A:#5F

>> UPD R2=04 ON C9=0, C0v=#35 PPI.B ON C9=1, C0v=#3E:#5F

PPI.STATUS \$us BEFORE R7=04 :#5E

PPI.STATUS \$us AFTER UPD R7<>04 (R7=04 BEFORE) (VSYNC CANCEL) (C9=0):#5F

PPI.ST C0=46 15 LINES AFTER R7=04 ON C0vsio=#1E:SF, SF, SF, SF, SF, SF

CRTC 0



## R1 STORIES

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE VRAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD_UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
(RETURN) RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```



CRIC 8 R1 STORIES  
STORY 2 : R1 > R0 WHEN C9=R9 & C90=R9  
PROCESS : UPDATE R1 ON 16 LINES (64 x 7, 48 (C9=7))+(48 x 7, 84(C9=7))  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 19 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27  
(11)AT #0000+(5x80)  
(12)AT #0000+(6x80)  
(12)AT #0000+(16x80)  
(13)AT #0000+(7x80)

CRIC 8 R1 STORIES  
STORY 3 : R1=0 EFFECT (EACH LINE : 4 x OUT R1,0/OUT R1,48)  
PROCESS : UPDATE R1=0 FOR 4x8 Lines FROM C0=3C, C0=3D, C0=3E, C0=3F  
00 02 04 06 08 0A 0C 0E 10 12 14 16 18 19 1C 1E 20 22 24 26  
01 03 05 07 09 0B 0D 0F 11 13 15 17 19 1B 1D 1F 21 23 25 27





## R6 STORIES

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE VRAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD_UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
(RETURN) RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```





CRIC 8 R6 STORIES (3 RUPTURES ON SCREEN)  
TB3-50 L. PATCHWORK R6=0/B FROM 2ND LINE OF MIDDLE SCREEN RUPTURE (C4=0,C9=1)



CRIC 8 R6 STORIES (3 RUPTURES ON SCREEN)  
TB4-1ST LINE IN DISPLAY AREA : SEQUENCE R6=0/R6=0/ WHEN R1)R0



CRTC B R6 STORIES (3 RUPTURES ON SCREEN)  
DBS-SB L. FROM 2ND LINE IN DISP AREA : PATCHWORK R6=0/R6=3 WHEN R1>R0

CRTC B R6 STORIES (3 RUPTURES ON SCREEN)  
DBS-SB L. FROM 2ND LINE IN DISP AREA : PATCHWORK R6=0/R6=3 WHEN R1>R0  
R6=0/C9=0 PATCHWORK R6=9/25 IN DISP AREA FOR 64 LINES

CRTC B R6 STORIES - AGAIN -  
DBS-SB L. FROM 2ND LINE IN DISP AREA : PATCHWORK R6=9/25 IN DISP AREA FOR 64 LINES

CRIC 0 RB STORIES - AGAIN -  
T05A-0M C4=3/C9E0 PATCHWORK R6=9/25 IN DISP AREA FOR 64 LINES



CRIC 0 RB STORIES - AGAIN -  
T05B-0M C4=3/C9E1 PATCHWORK R6=9/25 IN DISP AREA FOR 64 LINES



R6 STORIES -ROBIN-  
R6C-ON C4=3/C9=1 PATCHWORK R6=R/25 IN DISP AREA FOR 64 LINES

CRTC 0 R6 STORIES -LAST LINE-  
R6=R/FF FROM C8=2 ON C4=R4, C9=0..7, PREVIOUS R6=R4+1

? PREVIOUS R6=R4+1

CRTC 0 R6 STORIES -LAST LINE-  
R6=R/FF FROM C8=2 ON C4=R4, C9=0

CRTC 0 R6 STORIES -LAST LINE-  
R6=R4/TF FROM CB=2 IN V.ADJ ZONE (RS=16) (C4=fnc(CRTC)) PREVIOUS R6=R4+3

CRTC 0 R6 STORIES -LAST LINE-  
R6=R4/TF FROM CB=2 IN V.ADJ ZONE  
(RS=16) (C4=fnc(CRTC)) PREVIOUS R6=R4+3

CRTC 0 R6 STORIES -LAST LINE-  
R6=R4+1/TF FROM CB=2 IN V.ADJ ZONE (RS=16) (C4=fnc(CRTC)) PREVIOUS R6=R4+3

CRTC 0 R6 STORIES -LAST LINE-  
R6=R4+1/TF FROM CB=2 IN V.ADJ ZONE (RS=16) (C4=fnc(CRTC)) PREVIOUS R6=R4+3

## RVNI (NON INVISIBLE VERTICAL RUPTURE)

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE VRAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
RETURN RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```





## **ANALYZER / FORCED STABILISATION ON R0=0**

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
 (1) UPDATE VRAM VS CRTC (14 TST)  
 (2) SKEW DISP ON R0 RUPTURE (5 TST)  
 (3) INTERRUPT DELAY FROM R2 (18 CALC)  
 (4) UPDATE CRTC R0 TIMING (7 TST)  
 (5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
 (6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
 (7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
 (8) GATE ARRAY PIXELISATION  
 (9) GATE ARRAY INKERISATION (3 TST)  
 (E) GATE ARRAY MODERISATION  
 (R) HSYNC DELAY MODE UPD\_UPD R2,LGTH R3 (2.1.0)(3 TST)  
 (T) R2 UPD DURING & AFTER HSYNC (6 TST)  
 (Y) R3 UPD DURING HSYNC (8 TST)  
 (U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
 (I) USYNC CONDITIONS (16 TST)  
 (O) R1 STORIES (7 TST)  
 (P) R6 STORIES (11 TST)  
 (RETURN) RUNI LTD  
 (CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
 (CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
 (COPY) CRTC 2 OFFSET  
 (DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
 !! REF C0vs=0 DEFINED FROM CRTC USYNC FROM PPI.PORTB.0=1 !!







## R5 SCANNER (for CRTC 1)

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE VRAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
(RETURN) RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```

TEST FOR CRTC 1

## R5 STORIES / INTERACTIVE TEST

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE VRAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
(RETURN) RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```

TEST FOR CRTC 1

## OFFSET UPDATE

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM VS CRTC (14 TST) (0) CRTC 2 RUMB  
(2) SKEW DISP ON R0 RUPTURE (5 TST) (F0) BOUNGA:CRTC 2 ZERO!  
(3) INTERRUPT DELAY FROM R2 (18 CALC) (F1) INTERLACE VM (27 TST)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) VSYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
**(COPY) CRTC 2 OFFSET**  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!

CRTC 0 UPD R12/R13=#1000 CRT 2 ON C4=R4=1, C9=7, R1=#28  
UPD R12 ON COvcc=#3F



CRTC 0 UPD R12/R13=#1000 CRT 2 ON C4=R4=1, C9=7, R1=#28  
UPD R12 ON COvcc=#00  
CRTC 0 UPD R12/R13=#1000 CRT 2 ON C4=R4=1, C9=7, R1=#29  
UPD R12 ON COvcc=#00

« RVMB »

CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM VS CRTC (14 TST)  
(2) SKEW DISP ON R0 RUPTURE (5 TST)  
(3) INTERRUPT DELAY FROM R2 (18 CALC)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) VSYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!



RD=3 / TEST FOR CRT 2 (NOT EXCLUSIVE :-)) / YELLOW = BORDER ONLY / C9=R9 NOT IN HSYNC  
CHAN COLOR )) C9=0 - 16 RUP! / LINE  
TEST WITH R1=3, R9=7, R4=120  
CRTC 0



RD=3 / TEST FOR CRT 2 (NOT EXCLUSIVE :-)) / YELLOW = BORDER ONLY / C9=R9 NOT IN HSYNC  
CHAN COLOR )) C9=0 - 16 RUP! / LINE  
TEST WITH R1=3, R9=7, R4=120  
CRTC 0





















## BOUNGA : CRTC 2 R4=R9=0 FORCED

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM  
(1) UPDATE VRAM VS CRTC (14 TST)  
(2) SKEW DISP ON R0 RUPTURE (5 TST)  
(3) INTERRUPT DELAY FROM R2 (18 CALC)  
(4) UPDATE CRTC R0 TIMING (7 TST)  
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)  
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)  
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)  
(8) GATE ARRAY PIXELISATION  
(9) GATE ARRAY INKERISATION (3 TST)  
(E) GATE ARRAY MODERISATION  
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)  
(T) R2 UPD DURING & AFTER HSYNC (6 TST)  
(Y) R3 UPD DURING HSYNC (8 TST)  
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))  
(I) VSYNC CONDITIONS (16 TST)  
(O) R1 STORIES (7 TST)  
(P) R6 STORIES (11 TST)  
(RETURN) RUNI LTD  
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)  
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)  
(COPY) CRTC 2 OFFSET  
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```



## INTERLACE VM

```
CPC SHAKER 1.8 / LONGSHOT, LOGON SYSTEM
(1) UPDATE VRAM VS CRTC (14 TST)
(2) SKEW DISP ON R0 RUPTURE (5 TST)
(3) INTERRUPT DELAY FROM R2 (18 CALC)
(4) UPDATE CRTC R0 TIMING (7 TST)
(5) R13 UPDATE IN 4 USEC SCREENS (R0=3) (5 TST)
(6) R13 UPDATE IN 2 USEC SCREENS (R0=1) (5 TST)
(7) R13 UPDATE IN 1 USEC SCREENS (R0=0) (5 TST)
(8) GATE ARRAY PIXELISATION
(9) GATE ARRAY INKERISATION (3 TST)
(E) GATE ARRAY MODERISATION
(R) HSYNC DELAY MODE UPD,UPD R2,LGTH R3 (2.1.0)(3 TST)
(T) R2 UPD DURING & AFTER HSYNC (6 TST)
(Y) R3 UPD DURING HSYNC (8 TST)
(U) R4 & R9 CHECKING (6 TST (IN PROGRESS))
(I) VSYNC CONDITIONS (16 TST)
(O) R1 STORIES (7 TST)
(P) R6 STORIES (11 TST)
(RETURN) RUNI LTD
(CAPS) ANALYZER / FORCED STAB CRTC 0 R0=0 (4 CONF)
(CTRL) R5 SCANNER / (TAB) R5 STORIES (INTERACTIVE)
(COPY) CRTC 2 OFFSET
(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY
!! REF C0vs=0 DEFINED FROM CRTC VSYNC FROM PPI.PORTB.0=1 !!
```

```
CRTC 0 INTERLACED VIDEO MODE
CALC WITH R6=#19:
R8E3 ON LINE 0 : FRAME SIZE=#2720 usec (R9=6)(R7=0)
R8E3 ON LINE 1 : FRAME SIZE=#2740 usec (R9=6)(R7=0)
R8E3 ON LINE 2 : FRAME SIZE=#2720 usec (R9=6)(R7=0)
R8E3 ON LINE 3 : FRAME SIZE=#2840 usec (R9=6)(R7=0)
R8E3 ON LINE 4 : FRAME SIZE=#2820 usec (R9=6)(R7=0)
R8E3 ON RASTER LINE 2 / R8=0 ON LINE 43 / FRAME SIZE=#3C00 usec (R9=6)(R7=0)

CALC WITH R6=#7F:
R8E3 ON LINE 0 : FRAME SIZE=#2740 usec (R9=6)(R7=0)
R8E3 ON LINE 1 : FRAME SIZE=#2730 usec (R9=6)(R7=0)
R8E3 ON LINE 2 : FRAME SIZE=#2740 usec (R9=6)(R7=0)
R8E3 ON LINE 3 : FRAME SIZE=#2820 usec (R9=6)(R7=0)
R8E3 ON LINE 4 : FRAME SIZE=#2840 usec (R9=6)(R7=0)
R8E3 ON RASTER LINE 2 / R8=0 ON LINE 43 / FRAME SIZE=#3C00 usec (R9=6)(R7=0)

#18 BEFORE R6
CALC WITH R6=#19:
R8E3 ON LINE 0 : FRAME SIZE=#1800 usec (R9=6)(R7=0)
R8E3 ON LINE 1 : FRAME SIZE=#1800 usec (R9=6)(R7=0)
R8E3 ON LINE 2 : FRAME SIZE=#1800 usec (R9=6)(R7=0)
R8E3 ON LINE 3 : FRAME SIZE=#1000 usec (R9=6)(R7=0)
R8E3 ON LINE 4 : FRAME SIZE=#1000 usec (R9=6)(R7=0)
R8E3 ON RASTER LINE 2 / R8=0 ON LINE 43 / FRAME SIZE=#2200 usec (R9=6)(R7=0)
```

```

CTRL 0: INTERLACE VIDEO MODE
BB UPDATE DELAY + 0 FRAME DELAY
BB=3 ON C9H0, CB=#0D : FRAME SIZE = #2720 usec (R9=6)
BB=3 ON C9H0, CB=#0E : FRAME SIZE = #2740 usec (R9=6)
BB=3 ON C9H0, CB=#0F : FRAME SIZE = #2720 usec (R9=6)
BB=3 ON C9H1, CB=#0D : FRAME SIZE = #2720 usec (R9=6)
BB=3 ON C9H1, CB=#0E : FRAME SIZE = #2740 usec (R9=6)
BB UPDATE DELAY + 0 FRAME DELAY
BB=3 ON C9H0, CB=#0D : FRAME SIZE = #2740 usec (R9=6)
BB=3 ON C9H0, CB=#0E : FRAME SIZE = #2720 usec (R9=6)
BB=3 ON C9H0, CB=#0F : FRAME SIZE = #2740 usec (R9=6)
BB=3 ON C9H1, CB=#0D : FRAME SIZE = #2740 usec (R9=6)
BB=3 ON C9H1, CB=#0E : FRAME SIZE = #2720 usec (R9=6)
BB UPDATE DELAY + 1 FRAME DELAY
BB=3 ON C9H0, CB=#0D : FRAME SIZE = #2720 usec (R9=6)
BB=3 ON C9H0, CB=#0E : FRAME SIZE = #2740 usec (R9=6)
BB=3 ON C9H0, CB=#0F : FRAME SIZE = #2720 usec (R9=6)
BB=3 ON C9H1, CB=#0D : FRAME SIZE = #2720 usec (R9=6)
BB=3 ON C9H1, CB=#0E : FRAME SIZE = #2740 usec (R9=6)

DELAY FOR EVEN+ODD FRAME (E/O R6=50/50, 7E/50, 50/7E, 7E/7E)
BB=3 ON LINE 0 : FRAME SIZE = #9060 usec (R9=6)(R7=0)
BB=3 ON LINE 0 : FRAME SIZE = #9040 usec (R9=6)(R7=0)
BB=3 ON LINE 0 : FRAME SIZE = #9020 usec (R9=6)(R7=0)
BB=3 ON LINE 0 : FRAME SIZE = #9020 usec (R9=6)(R7=0)

```

## INTERLACE C4/C9 COUNTERS

CPC SHAKER 1.8 - ADDITIONAL MODULE / LONGSHOT. LOGON SYSTEM  
(1) INTERLACE C4/C9 COUNTERS  
(2) INTERLACE CRTC 2 C9 STRANGER THING  
(3) FAKE VSYNC ON CRTC 2  
(4) CRTC 2 FIND C0 MIN  
(5) CRTC 2 RLAL  
(6) CRTC 1 BUG OUTI R0

(S) BE00 CHECK (CRTC 1)

(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0=0 DEFINED FROM THE MICROSEC WHEN CRTC VSYNC SET PPI.PORTB.0=1 !!

CRTC 0 INTERFACE UV TESTS - C4/C9 COUNTING IN IUM PERIOD (GRADE 2000)

NEXT SCREEN : C4=6, C9=0 )) UPD RS=6, RB=3 (+3105)

EXIT IUM MODE ON C9=0 )) UPD RS=7, RB=0

AUTOSYNC ON PREVIOUS SCREEN TEST: R4=box RS=box



CRTC 0 INTERFACE UM TESTS - C4/C9 COUNTING IN IOM PERIOD (MOVE ZONE)

NEXT SCREEN : C4=6, C9=0 >> UPD R9=6, R8=3 (+3105)

EXIT IUM MODE ON C9=0 >> UPD R9=7, R8=0

AUTOSYNC ON PREVIOUS SCREEN TEST: R4=hex R5=hex



CRTC 0 INTERFACE VM TESTS - C4/C9 COUNTING IN ION PERIOD (GRADE 2000)

NEXT SCREEN : C4=6, C9=1 => UPD RS=6, RB=3 (+3105)

EXIT ION MODE ON C9=0 => UPD RS=7, RB=0

AUTOSYNC ON PREVIOUS SCREEN TEST: P4=#2A RS=100







CNHC 0 INTERFACE VM TESTS - C4/C9 COUNTING IN ION PERIOD (CHARGE MODE)

NEXT SCREEN : C4=6, C9=5 >> UPD R9=6, R8=3 (+3105)  
EXIT ION MODE ON C9=0 >> UPD R9=7, R8=0

AUTOSYNC ON PREVIOUS SCREEN TEST: R4=126 RS=100













## INTERLACE CRTC 2 C9 STRANGER THING

CPC SHAKER 1.8 - ADDITIONAL MODULE / LONGSHOT. LOGON SYSTEM  
(1) INTERLACE C4/C9 COUNTERS  
**(2) INTERLACE CRTC 2 C9 STRANGER THING**  
(3) FAKE VSYNC ON CRTC 2  
(4) CRTC 2 FIND C0 MIN  
(5) CRTC 2 RLAL  
(6) CRTC 1 BUG OUTI R0

(S) BE00 CHECK (CRTC 1)

(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0=0 DEFINED FROM THE MICROSEC WHEN CRTC VSYNC SET PPI.PORTB.0=1 !!

TEST FOR CRTC 2

## FAKE VSYNC ON CRTC 2

CPC SHAKER 1.8 - ADDITIONAL MODULE / LONGSHOT. LOGON SYSTEM  
(1) INTERLACE C4/C9 COUNTERS  
(2) INTERLACE CRTC 2 C9 STRANGER THING  
**(3) FAKE VSYNC ON CRTC 2**  
(4) CRTC 2 FIND C0 MIN  
(5) CRTC 2 RLAL  
(6) CRTC 1 BUG OUTI R0

(S) BE00 CHECK (CRTC 1)

(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0=0 DEFINED FROM THE MICROSEC WHEN CRTC VSYNC SET PPI.PORTB.0=1 !!



## CRTC 2 FIND C0 MIN

CPC SHAKER 1.8 - ADDITIONAL MODULE / LONGSHOT. LOGON SYSTEM  
(1) INTERLACE C4/C9 COUNTERS  
(2) INTERLACE CRTC 2 C9 STRANGER THING  
(3) FAKE VSYNC ON CRTC 2  
**(4) CRTC 2 FIND C0 MIN**  
(5) CRTC 2 RVAL  
(6) CRTC 1 BUG OUTI R0

(S) BE00 CHECK (CRTC 1)

(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0=0 DEFINED FROM THE MICROSEC WHEN CRTC VSYNC SET PPI.PORTB.0=1 !!

**TEST FOR CRTC 2**

## CRTC 2 - 1 LINE RUPTURE

CPC SHAKER 1.8 - ADDITIONAL MODULE / LONGSHOT. LOGON SYSTEM  
(1) INTERLACE C4/C9 COUNTERS  
(2) INTERLACE CRTC 2 C9 STRANGER THING  
(3) FAKE VSYNC ON CRTC 2  
(4) CRTC 2 FIND C0 MIN  
(5) CRTC 2 RAL  
(6) CRTC 1 BUG OUTI R0

(S) BE00 CHECK (CRTC 1)

(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0=0 DEFINED FROM THE MICROSEC WHEN CRTC VSYNC SET PPI.PORTB.0=1 !!

TEST FOR CRTC 2

## CRTC 1 - BUG OUTI R0

CPC SHAKER 1.8 - ADDITIONAL MODULE / LONGSHOT. LOGON SYSTEM  
(1) INTERLACE C4/C9 COUNTERS  
(2) INTERLACE CRTC 2 C9 STRANGER THING  
(3) FAKE VSYNC ON CRTC 2  
(4) CRTC 2 FIND C0 MIN  
(5) CRTC 2 RLAL  
(6) CRTC 1 BUG OUTI R0

(S) BE00 CHECK (CRTC 1)

(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0=0 DEFINED FROM THE MICROSEC WHEN CRTC VSYNC SET PPI.PORTB.0=1 !!

TEST FOR CRTC 1

## CRTC 1- BE00 CHECK

CPC SHAKER 1.8 - ADDITIONAL MODULE / LONGSHOT. LOGON SYSTEM  
(1) INTERLACE C4/C9 COUNTERS  
(2) INTERLACE CRTC 2 C9 STRANGER THING  
(3) FAKE VSYNC ON CRTC 2  
(4) CRTC 2 FIND C0 MIN  
(5) CRTC 2 RLAL  
(6) CRTC 1 BUG OUTI R0

(S) BE00 CHECK (CRTC 1)

(DEL) RUN ALL TEST (4 SEC EACH) / Z80A SYNC ON CRTC CNT <> CRTC CAR DISPLAY  
!! REF C0=0 DEFINED FROM THE MICROSEC WHEN CRTC VSYNC SET PPI.PORTB.0=1 !!

TEST FOR CRTC 1