Der Agnus (lat. „Lamm“) ist einer der Customchips im Chipsatz des Commodore Amiga. „Agnus“ ist eine Abkürzung von „Adressgenerator“ (AdressGeneratorUnits). Der Baustein ist für die Steuerung des Chip-RAMs zuständig, stellt die Video-Synchronsignale (HSY, CSY, VSY) zur Verfügung und enthält die Coprozessoren Copper und Blitter. Agnus enthält zusätzlich die komplette DMA-Logik für alle 6 möglichen Quellen. Für den zeitlichen Ablauf der einzelnen DMA-Zugriffe dient eine Bildschirmzeile als Zeitbezug. In jeder Zeile werden 225 Speicherzugriffe von Agnus auf die DMA-Kanäle und die CPU verteilt. Für das korrekte Timing sind ein Zeilen- und ein Spaltenzähler verantwortlich (HSY, VSY). Über diese Signale kann das Timing auch extern gesteuert werden (Genlock).
Ein wesentlicher Hauptbestandteil von Agnus ist der große Adressgenerator. Alle Custom-Chips des Amiga können unabhängig von der CPU direkt auf das RAM zugreifen. Dazu benötigen diese Chips jedoch einen freien DMA-Kanal und den Adressgenerator. Über die DMA-Kanäle wird der Zugriff auf das RAM abgewickelt. Der Adressgenerator wandelt die Signale eines Chips in vollständige Speicheradressen um oder ordnet bestimmte Speicheradressen einzelnen Registern in den Chips zu. Er dient quasi als eine Art Übersetzer, welcher die gewünschte Adresse im Speicher ermittelt. Man kann sich das in etwa so vorstellen, dass von einem bestimmten Ort statt der Postanschrift nur die Beschreibung „erste Straße nach dem Ortseingang und dann drittes Haus auf der linken Seite“ bekannt ist. Der Adressgenerator macht aus solchen Angaben sinngemäß „Schillerstraße 12, 47324 Klotzhausen“.
Keiner der anderen Chips des Amiga-Chipsatzes verfügt über DMA-Kanäle oder Adressgeneratoren. Alle Speicherzugriffe laufen deshalb zentral über Agnus und werden von ihm kontrolliert und koordiniert. Insgesamt hat Agnus 25 DMA-Kanäle, über die 25 verschiedene Geräte ohne Beihilfe der CPU Daten in den Speicher schreiben oder aus ihm lesen können. Zu diesen von Agnus aus dem Chip-RAM geholten und von Denise dargestellten Video-Daten gehören neben den Pixel-Daten Paletten- und Sprite-Daten sowie die Copperlisten. Die Daten von BOBs werden zwar auch von Agnus per DMA geholt, aber dann mit dem in Agnus integrierten Blitter direkt an die dazustellende Position innerhalb des Videospeichers im Chip-RAM kopiert.
Agnus holt zum Einen die Video- und Sound-Daten aus dem Chip-RAM und kann zum Anderen auch Daten innerhalb des Chip-RAMs umkopieren und dabei auch verarbeiten (blitten), kann aber auch Daten generieren, nämlich beim Linienzeichnen und Flächenfüllen mit dem Blitter.
Die Urversion des Agnus wurde nur im Amiga 1000 und im Amiga 2000 mit A-Board verwendet. Die Nachfolgemodelle Amiga 500 und Amiga 2000 mit B-Board verfügen bereits über den Fat-Agnus mit erweiterten Funktionen und der Fähigkeit, noch mehr Speicher (1 MB) direkt verwalten zu können. Dieser war bereits Teil des Enhanced Chip Sets. Spätere Modelle heißen Big-Agnus oder Super-Fat-Agnus.
Der Alice-Chip ist die Weiterentwicklung des Big Agnus für den AGA-Chipsatz. Alice wurde von Grund auf neu entwickelt und speziell auf die neueren CPUs (ab MC68020) zugeschnitten. Weil bei diesen Prozessoren der Bus 32 Bit breit ist, konnten einige Signale zusammengefasst bzw. entfernt werden. Damit konnten schon 2 MB Chip-RAM verwendet werden. Alice kann allerdings nicht in alte Amigas eingebaut werden. Er ist nur für die Amigas mit AGA(AA)-Chipset entwickelt worden und wird zum Beispiel im Amiga 1200 und Amiga 4000 verwendet.
Inhaltsverzeichnis |
unter 8370-72/75 laufen verschiedene Varianten:
Zusätzlich sind manche Chips zwischen PAL u. NTSC umschaltbar, ältere nur dediziert für eine Norm.
Bei Austausch/Umbau ist die Pinbelegung interessant. Die Typenangaben sind lediglich zur Referenz gedacht; von einem vorliegenden Agnus-Chip kann nicht direkt auf die Pinbelegung geschlossen werden, da diese unabhängig vom Chip anscheinend erst beim Packaging festgelegt wurde[1].
OCS/ECS | ECS | ECS | AGA (Alice) | |
---|---|---|---|---|
A500/2000 | A3000 | A500+/600 | A4000/1200 | |
8370/1 | 8372 | 8375 | 8374 | |
1 | RD13 | DRD13 | DRD13 | DRD13 |
2 | RD12 | DRD12 | DRD12 | DRD12 |
3 | RD11 | DRD11 | DRD11 | DRD11 |
4 | RD10 | DRD10 | DRD10 | DRD10 |
5 | RD9 | DRD9 | DRD9 | DRD9 |
6 | RD8 | DRD8 | DRD8 | DRD8 |
7 | RD7 | DRD7 | DRD7 | DRD7 |
8 | RD6 | DRD6 | DRD6 | DRD6 |
9 | RD5 | DRD5 | DRD5 | DRD5 |
10 | RD4 | DRD4 | DRD4 | DRD4 |
11 | RD3 | DRD3 | DRD3 | DRD3 |
12 | RD2 | DRD2 | DRD2 | DRD2 |
13 | RD1 | DRD1 | DRD1 | DRD1 |
14 | RD0 | DRD0 | DRD0 | DRD0 |
15 | Vcc | Vcc | Vcc | Vcc1 |
16 | RST* | _RESET | _RESET | /RESET |
17 | INT3 | _INTR | _INTR | /INTR |
18 | DMAL | DMAL | DMAL | DMAL |
19 | BLS* | _BLISS | _BLISS | /BLS |
20 | DBR* | _BLIT | _BLIT | /DBR |
21 | RRW | _WE | _WE | /WE |
22 | PRW | R/W | R/W | R/W |
23 | RGEN* | _REGEN | _REGEN | _REGEN |
24 | AS* | _AS | _AS | NC2 |
25 | RAMEN* | _RAMEN | _RAMEN | /RAMEN |
26 | RGA8 | RGA8 | RGA8 | RGA8 |
27 | RGA7 | RGA7 | RGA7 | RGA7 |
28 | RGA6 | RGA6 | RGA6 | RGA6 |
29 | RGA5 | RGA5 | RGA5 | RGA5 |
30 | RGA4 | RGA4 | RGA4 | RGA4 |
31 | RGA3 | RGA3 | RGA3 | RGA3 |
32 | RGA2 | RGA2 | RGA2 | RGA2 |
33 | RGA1 | RGA1 | RGA1 | RGA1 |
34 | 28MHz | 28MHz | 28MHz | SCLK |
35 | XCLK | A20 | A20 | A20 |
36 | XCLKEN* | _XCLKEN | _CDAC | 14MHz |
37 | CDAC* | _CDAC | 7MHz | /CDAC |
38 | 7MHz | 7MHz | CCKQ | 7MHz |
39 | CCKQ | CCKQ | CCK | CCKQ |
40 | CCK | CCK | 14M | CCK |
41 | TEST | TEST | GND | /NTSC |
42 | Vss | Vss1 | DRA0 | GND2 |
43 | MA0 | DRA0 | DRA1 | DRA0 |
44 | MA1 | DRA1 | DRA2 | DRA1 |
45 | MA2 | DRA2 | DRA3 | DRA2 |
46 | MA3 | DRA3 | DRA4 | DRA3 |
47 | MA4 | DRA4 | DRA5 | DRA4 |
48 | MA5 | DRA5 | DRA6 | DRA5 |
49 | MA6 | DRA6 | DRA7 | DRA6 |
50 | MA7 | DRA7 | DRA8 | DRA7 |
51 | MA8 | DRA8 | _LDS | DRA8 |
52 | LDS* | _LDS | _UDS | Vcc2 |
53 | UDS* | _UDS | _CASL | NC1 |
54 | CASL* | _CASL | _CASU | /CAS |
55 | CASU* | _CASU | DRA9 | Vbb |
56 | RAS1* | DRA9 | _RAS1 | DRA9 |
57 | RAS0* | _RAS | _RAS0 | /RAS |
58 | Vss | Vss2 | GND | GND3 |
59 | A19 | A19 | A19 | A19 |
60 | A1 | A1 | A1 | A1 |
61 | A2 | A2 | A2 | A2 |
62 | A3 | A3 | A3 | A3 |
63 | A4 | A4 | A4 | A4 |
64 | A5 | A5 | A5 | A5 |
65 | A6 | A6 | A6 | A6 |
66 | A7 | A7 | A7 | A7 |
67 | A8 | A8 | A8 | A8 |
68 | A9 | A9 | A9 | A9 |
69 | A10 | A10 | A10 | A10 |
70 | A11 | A11 | A11 | A11 |
71 | A12 | A12 | A12 | A12 |
72 | A13 | A13 | A13 | A13 |
73 | A14 | A14 | A14 | A14 |
74 | A15 | A15 | A15 | A15 |
75 | A16 | A16 | A16 | A16 |
76 | A17 | A17 | A17 | A17 |
77 | A18 | A18 | A18 | A18 |
78 | LP* | _LPEN | _LPEN | /LPEN |
79 | VSY* | _VSYNC | _VSYNC | /VSYNC |
80 | CSY* | _CSYNC | _CSYNC | /CSYNC |
81 | HSY* | _HSYNC | _HSYNC | /HSYNC |
82 | Vss | Vss3 | GND | GND1 |
83 | RD15 | DRD15 | DRD15 | DRD15 |
84 | RD14 | DRD14 | DRD14 | DRD14 |
Quellen: A500 Service Training, A3000 Service Manual, A500+ Service Manual, A1200 Schaltplan |
PET/CBM: KIM-1 | PET 2001 | CBM 3000 | CBM 4000 | CBM 8000 | MMF 9000 CBM II: CBM 500∗ | CBM 600 | CBM 700 | CBM 900∗
Heimcomputer: VC 10 | VC 20 | C64 (SX, GS♦) | 264-Reihe (C16, C116, Plus/4) | C128 | C65∗
Amiga (Übersicht): 1000 | Sidecar | 500 | 2000 | CDTV♦ | 600 | 3000/T/UX | 1200 | 4000 | CD³²♦
IBM-kompatibel: PC-1 | PC-10 bis PC-60 | x86LT | A 1060
Peripherie: Laufwerke: Datasette | VC15xx (VC1540/41, VC1551, VC1570/71, VC1581) | SFD100x (SFD1001, SFD1002) | CBM 2020 bis 8250 | Amiga-Diskette | A570 | A3070
Drucker: MPS-Serie | MPS 801 | CBM-8000-Serie | VC1520
Sonstige Hardware: Zorro-Bus | RAM Expansion Unit | Commodore-Maus | Monochrom- und Farb-Monitore | Lautsprecher A10 | Mehrfachbenutzersysteme (MBS)
Historische Hardware: Schreib- und Tischrechenmaschinen | LED-Uhren | Konsole Commodore 2000k| Schachcomputer
Chips: MOS Technology | VIC | VIC II | TED | VDC | SID | PIA | VIA | TPI | CIA | ACIA | Agnus (Blitter, Copper) | Paula | EHB-Modus | HAM-Modus Chipsätze: OCS | ECS | AGA
Software: Commodore BASIC | Commodore Basic V2 | Kernal | CBM-ASCII (PETSCII) | GEOS | Commodore DOS | AmigaOS | Kickstart | Workbench | AmigaGuide | AMIX