Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
flipdot:start [2013/02/23 14:48] – [Nomenklatur] datenkleptomaneflipdot:start [2024/03/07 22:07] (current) linuxhackerman
Line 1: Line 1:
 += Flipdot
 +
 ---- dataentry Projekt ---- ---- dataentry Projekt ----
-Projekt_url          +Projekt_url       :  
-Name                : Flipdot +Name              : Flipdot 
-Beschreibung_wiki   Die Flipdotmatrix die uns zukam in Betrieb nehmen +Beschreibung_wiki : Flipdotmatrixen in Betrieb nehmen 
 +Links_urls        :  
 +Bilder_imgs       :  
 +Source_url        : https://github.com/muccc/flipdots 
 +Lizenz            : -- 
 +Beteiligt         : sepi, jan, lilafisch, martin, krobin, fpletz 
 +Termine_page      : 
 +Status_           : done 
 +Kategorie_tags    : Hardware, Software 
 +Verwandtes_tags   : Display, Schaufenster 
 +----
  
-Links_urls          :  +Uns ist irgendwann mal ein Rudel Flipdot-Panels zugelaufendie wir sowohl im Münchner Club als auch in andere Hackerspaces verteilt habenDie Panels wurden in verschiedenen Konfigurationen zu mehreren Displays aggregiert und zeigen z.B. den Clubraum Status, das Channel Topic oder aktuelle (politischeNachrichten im Schaufenster an.
-Bilder_imgs         : ====== Geometrie ====== +
-  Ein Paneldas kleinste Element besteht aus einem Rechteck von 20x16 (BxH) Pixeln. +
-  - Eine Spalte besteht aus 11 Zeilen, also 11 Panels übereinander und 18? Spalten: 18x11 (BxH).+
  
 +Es gibt verschiedenste Treiberplatinen und Ansteuerungshardware, die auch mal besser dokumentiert werden müsste. :-) 
  
-Source_url          : https://github.com/muccc/flipdots +Der Quellcode sammelt sich im [[https://github.com/muccc/flipdots|flipdot git]].
-Lizenz              : --+
  
-Beteiligt           : sepi, jan, lilafisch, martin, krobin 
-Termine_page        : flipdot:termine 
  
-Status_             : hardware planenmehr testen +Ein Panel hat die Abmessungen 30x24x6cm und wiegt mit vier Haltern ca. 1,2 kg. Zwei Panels mit Rücken aneinander haben zusammen ca. 9 anstatt 6 cm Tiefe.
-Kategorie_tags      : Hardware +
-Verwandtes_tags     : Display, Schaufenster +
-----+
  
-Wir haben eine Flipdotmatrix.+== Nomenklatur
  
-  * 198 schwarze und 4 blaue Module +Um dem Chaos ausnahmsweise entgegen- und nicht zu-zuwirken legen wir hier feste Worte für die einfachere Kommunikation fest!
-    * 2 der schwarzen Module sind noch den Ingolstädtern designated!+
  
-====== Nomenklatur ====== +  * **Panel** == 1 Object voll mit Dots; besteht aus: Dot-Matrix mit 16 Zeilen und 20 Spalten. Hat hinten noch die Treiberplatine dran. 
-Um dem Chaos ausnahmsweiße entgegen- und nicht zu-zuwirken legen wir hier feste Worte für die einfachere Kommunikation fest!+    * FIXME: Sollte man nicht lieber 16 Spalten × 20 Zeilen verwenden? Dann entspräche eine Modulzeile einem 16 Bit Wort, was auch die interne Aufteilung von üblichen Framebuffern entspricht. 
 +    * Treiberplatine == nimmt seriell Daten entgegen und gibt dieses Parallel auf die Dot-Matrix eines Moduls. 
 +    * Panelzeile == horizontal aggregierte Ansammlung von Dots, typischerweise 20 Dots 
 +    * Panelspalte == vertikal aggregierte Ansammlung von Dots, typischerweise 16 Dots 
 +    * Der Ursprung ist oben links (wenn man von vorne draufschaut) und mit X0Y0 beschriftet 
 +  * **Assembly** == Ein bis mehrere Panel sind zu einem größeren Aggregat zusammengebaut worden und haben eine gemeinsame Steuerungseinheit. Im Club stehen drei Assemblys im Schaufenster rum. 
 +  * **Display** == Ein Display besteht aus einer bis mehreren Assemblies und ist für den Betrachter eine zusammenhängende Installation. Z.B. die drei Assemblies im Clubschaufenster, eine Assembly die aus einer "Zeile" panels besteht und im Clubhauptraum den ganzen Raum umrundet. Eine Einpanelassembly die nur den Clubstatus anzeigt. 
 +  * **Window** == Ein rechteckiger Bereich in einem Display. Diese Bereiche können als Resource an verschiedene Teilnehmer vergeben werden die darauf schreiben dürfen.
  
-  Modul (Panel) == 1 Object voll mit Dots; besteht ausDot-Matrix mit 16 Spalten und 20 ZeilenHat hinten noch die Treiberplatine dran+**ACHTUNG**: Eventuell ist im Rest der Wikiseite alles vertauscht. Das sollte später gefixt werden! 
-  * Treiberplatine == nimmt seriell Daten entgegen und gibt dieses Parallel auf die Dot-Matrix eines Moduls+ 
-  Zeile == horizontal aggregierte Ansammlung von Dotstypischer Weiße 16 Dots + 
-  Spalte == vertikal aggregierte Ansammlung von Dotstypischer Weiße 20 Dots +== Displays 
-====== Steuerplatine ======+ 
 +Wir haben aktuell folgende Flipdot-Displays: 
 + 
 +^                               ^ Anzahl  ^                                                                               ^ 
 +| Mini                          |  2      | Zeigt den Clubstatus an, kann (offiziell?nicht direkt angesprochen werden. 
 +| Zeile                          11     | Zeigt Topic aus #ccc an                                                       | 
 +| [[wand|Schaufenster / Wand]]  |  63     | drei Assemblies die in der Regel als ein großes Display betrieben werden      | 
 +| [[mobil|Mobil / Demo]]        |  ??     | mobiles, wasserfestes Case                                                    | 
 + 
 +=== Zeile 
 + 
 +176x20 Pixel. 
 + 
 +Es gibt mehrere Möglichkeiten die Zeile anzusprechen: 
 +  UDP: Wie alle Displays beherrscht auch die Zeile ein triviales UDP-Protokoll:  `2001:7f0:3003:beef:ba27:ebff:fe89:4cd2` Port `2323` 
 +  - In #ccc auf darkfasel: Alle Posts, die "Alarm" enthalten sowie Topic-Änderungen werden angezeigt. 
 +  - <del>https://muc.pads.ccc.de/flipdot wird angezeigt (BETA)</del> Landet aktuell auf der Wand, nicht auf der Zeile 
 + 
 +=== Bildformat 
 +Es muss ein animiertes 144x120 gif sein mit einem delay auf dem frame. am besten sowas wie 600 sekunden oder so 
 + 
 +Schwarz-weiss: Image -> Mode -> Indexed...:  use black and white (1-bit) palette 
 + 
 +Bug: Aktuell scheinen die linkesten 16 pixel am rechten Rand angezeigt zu werden. 
 + 
 +Workaround: ''gm convert tdoh.gif -affine 1,0,0,1,-16,0 -transform -draw 'image Over -112,0 144,120 tdoh.gif' tdoh2.gif'' 
 + 
 +einfach per ssh das gif in ~/gifs/active legen 
 + 
 +=== Schaufenster / Wand 
 + 
 +Das Fenster ist ca. 210x215cm – damit braucht es dann 7x9, also 63 Panele. 
 + 
 +Web-UI: http://[2001:7f0:3003:beef:ba27:ebff:fee3:ff77]:8000/ 
 +== Change Log 
 + 
 +  * **2013-10-20**:  
 +{{gallery>?flipdot-ph*.jpg&lightbox&4}} 
 +IPs: 
 +  links 2001:67c:20a1:1033:33c3:beef:1234:0001 
 +  mitte 2001:67c:20a1:1033:33c3:beef:1234:0002 
 +  rechts 2001:67c:20a1:1033:33c3:beef:1234:0003 
 + 
 +  * **2013-10-19**: fehlende Kanthölzer und zusätzlich Holzbretter (Holzbretter als Netzteil-Unterlage zum mit'rollen) wurden besorgt und Flipdotpanel für das linke Schaufenster wurde mit vielen Helfern fertiggestellt. 
 +  * **2013-10-14**: Holzspäne vom Vorkonstrukteur gekehrt!; alle Gewindestangen geflext, entgratet und gestapelt; Rollflipdotpanel in das linke Schaufenster gerollt; ein Kantholz gesägt und mit einem weiteren Flipdotpanel gebohrt und geschraubt; das dritte Flipdotpanel schräg dazu gestellt; 3x Kanthölzer werden vermisst bzw. nicht gefunden zum weiter machen; rest-Flipdotmaterial in eine Kiste gepackt; das Werkzeug vom Vorkonstrukteur!! und das eigene weggeräumt; den eigenen dreck wie Holzspäne gekehrt. Siehe: 
 + 
 +{{gallery>?flipdot_image_*.jpg&lightbox&4}} 
 + 
 +  * **2013-09-30**: Das 48x120 gross Display ist jetzt unter 2001:7f0:3003:cafe:ba27:ebff:fe71:dd32 zu erreichen. In eventuellen Skripten einfach die IP und groesse anpassen. Das Netzteil ist normalerweise aus und muss mit dem Netzkabel erst mit Strom versorgt werden. Der Treiber startet automatisch
 +  * **2013-09-2x**: Ein Netzteil, Treiberplatine und rpi wurden zusammengeschaltet. Ein schnell gehackter Treiber steuert alles an. 
 +  * **2013-09-07**: fpletz, argv und martin haben versucht den [[http://datasheets.maximintegrated.com/en/ds/MAX7301.pdf|MAX7301]] unter Linux zum Laufen zu bekommen 
 +    * Kernel-Anpassungen nötig, daher erstmal Aufsetzen eines Cross-Build-Environments für RPi Kernel: [[http://www.elinux.org/Rpi_kernel_compilation|elinux kernel compile guide]] 
 +    Wir nehmen als Basis [[https://github.com/raspberrypi/linux/tree/rpi-3.11.y|raspberrypi/linux/rpi-3.11.y]] 
 +    * Fnord! Fork: [[https://github.com/muccc/linux/tree/rpi-3.11.y-max7301|muccc/linux/rpi-3.11.y-max7301]] 
 +      * Um den gpio-max7301 GPIO Device Treiber zu benutzenmuss man entweder Platform Code ändern/schreiben oder Device Table benutzen 
 +        * Wir machen Platform Code, weil DT neuen Bootloader und damit mehr Fnord erfordert hätte [[https://github.com/muccc/linux/commit/655678d08e177502f539ed376365edea0b4e84d8|Commit]] 
 +      * Der RPi GPIO Treiber bcm2708_gpio ist kaputt, man kann nicht mehrere GPIO Devices haben... 
 +        * Fix: [[https://github.com/muccc/linux/commit/af493530b7f1ff4af4b344649841cf42604b01f6|Commit]] 
 +      * **TODO**: Der RPi SPI Treiber spi-bcm2708 ist, diplomatisch ausgedrückt, unvollständig 
 +        * Der MAX7301 kann eigentlich nur 16 Bit pro Word, testweise auf 8 Bit runter (wegen Schieberegister), aber [[https://github.com/muccc/linux/commit/6ef80df17e079b010ee83ddf20d6cfcf260a57d9|Fail-Commit]] 
 +        Der BCM2708 kann erstmal nur 8 Bit pro Wordoder mehr wenn man DMA benutzt, der Treiber kann weder DMA noch mit anderen Wordsizes umgehen 
 +          * **TODO**: Evaluation [[https://github.com/raspberrypi/linux/pull/147|dieses Pull Requests]], auf den ersten Blick Fnord 
 +    * Wir brauchen einen Logic Analyzer (es sollen diverse im Club sein, aber keinen gefunden), da total unklar ist was auf dem SPI Bus wirklich passiert 
 + 
 +  * **2013-09-0x**: jan hat Extension Boards für RaspberryPi mit MAX7301 per SPI gebastelt 
 + 
 +  * **2013-06-14**: sepi/fpletz hacken an [[https://github.com/muccc/netfbd]] 
 +    * Ziel: Streaming eines (virtuellen) Framebuffers 
 + 
 + 
 + 
 +== Steuerplatine
   * 10 8-Stufe Schieberegister (80 bit) [[http://www.nxp.com/documents/data_sheet/74HC_HCT4094.pdf|74HC_HCT4094]]   * 10 8-Stufe Schieberegister (80 bit) [[http://www.nxp.com/documents/data_sheet/74HC_HCT4094.pdf|74HC_HCT4094]]
     * Aufgeteilt in row + column register     * Aufgeteilt in row + column register
Line 40: Line 121:
     * FIXME: Wo kommt die Zahl her, gilt das für ein Modul, also eine Steuerplatine?     * FIXME: Wo kommt die Zahl her, gilt das für ein Modul, also eine Steuerplatine?
  
-===== Pinbelegung =====+== Pinbelegung
 Thx an x5444 von den Ingolstädern für das PIN-Layout! Thx an x5444 von den Ingolstädern für das PIN-Layout!
  
-row == 20px (effektiv werden beim chainen noch 4px fnord mitgeschickt) +Das row register ist 24px lang. (effektiv werden beim chainen noch 4px fnord mitgeschickt) 
-col == 16px+Das col register is 16px lang. 
 + 
 +^ 1  | ?1        ^  2 | GND      | 
 +^ 3  | ROW_DATA  ^  4 | GND     | 
 +^ 5  | STROBE    ^  6 | GND     | 
 +^ 7  | WHITE_OE  ^  8 | GND     | 
 +^ 9  | BLACK_OE  ^ 10 | GND     | 
 +^ 11 | COL_CLOCK ^ 12 | GND     | 
 +^ 13 | ROW_CLOCK ^ 14 | GND     | 
 +^ 15 | COL_DATA  ^ 16 | GND     | 
 +^ 17 | DO        ^ 18 | GND     | 
 +^ 19 | ?1        ^ 20 | ?2     | 
 + 
 +* ?1 == durchverbunden, kann man wohl am abschluss für nen rückkanal nutzen, so dass man die anzahl der segmente zählen kann 
 +* DO == Ausgang des zweiten nichtinvertierten Schieberegisters für die Spalten auf der input Seite bei Kaskadierung von Modulen 
 +* ?2 == ind ein wenig komisch, die sind jeweils ein bestimmter pegel (hab ich grad nicht im kopf) sobald an einer der steuerplatinen in der kette die matrix die tatsächliche display-einheit verbunden ist 
 + 
 + 
 +== Historie 
 + 
 +Ursprünglicher Standort über der A9 bei Fröttmaning: 
 + 
 +{{:flipdot:flipdot_a9.png?direct&200|}} 
 + 
 +Wir haben 198 schwarze und 4 blaue Panels mit je 20x16 Pixeln 
 + 
 +Bisher wurden nur die schwarzen verbaut. 
  
-^ 1  | ?1        ^ 11 | ?2      | +Davon stecken insgesamt 
-^ 2  | ROW_DATA  ^ 12 | GND     | +  * 54 x in den drei großen Displays fürs Schaufenster 
-^ 3  | STROBE    ^ 13 | GND     | +  * 2 x im Minidisplay Hauptraum 
-^ 4  | OE1       ^ 14 | GND     | +  * 24 x im mobilen Flipdot
-^ 5  | OE2       ^ 15 | GND     | +
-^ 6  | COL_CLOCK ^ 16 | GND     | +
-^ 7  | ROW_CLOCK ^ 17 | GND     | +
-^ 8  | COL_DATA  ^ 18 | GND     | +
-^ 9  | DO        ^ 19 | GND     | +
-^ 10 | ?2        ^ 20 | GND     |+
  
-?1 == durchverbunden, kann man wohl am abschluss für nen rückkanal nutzen, so dass man die anzahl der segmente zählen kann +=== Verteilung
-DO == Ausgang des zweiten nichtinvertierten Schieberegisters für die Spalten auf der input Seite bei Kaskadierung von Modulen +
-?2 == ind ein wenig komisch, die sind jeweils ein bestimmter pegel (hab ich grad nicht im kopf) sobald an einer der steuerplatinen in der kette die matrix die tatsächliche display-einheit verbunden ist+
  
 +70 Vergeben:
 +    * 4 x bei den Ingolstädtern; http://bytewerk.org/index.php/Schaufenster_Tetris und http://bytewerk.org/index.php/Flipdot-Matrix
 +    * 1 x bei Karsten (Student-Robotics-Student von lila)
 +    * 6 x Hannover, Mcfly (gewannen eine Wild Demo Compo: http://xayax.net/flippin_the_dots/ )
 +    * 2 x Hamburg, Mcfly, Attraktor
 +    * 1 × datenwolf
 +    * 6 x Metalab Wien, overflo https://metalab.at/wiki/Flipdots
 +    * 8 x Dortmund, Eimann
 +    * 3 x Karlsruhe
 +    * 3 x Darmstadt, bios
 +    * 6 x ccc Köln
 +    * 4 x AFRA - Abteilung-für-Redundanz-Abteilung (Martin weis mehr)
 +    * 2 x Tausch gegen neuen Münzer Matemat (Bekommt noch 2, Martin weis mehr)
 +    * 4 x + 1 Steuerplatine normal für OpenLab Hackspace/Chaostreff Augsburg, via gamambel im IRC -- als Wall im Space und für Veranstaltungen.
 +      * im Tausch gegen Datenhandschuh und Geekend
 +      * 2014-01-14: Haben über krobin ein Ersatzteilmodul bekommen. Pixel waren kaum noch drauf, aber Spulen und Transistoren.
 +    * 6 x Southampton(UK) +  fuer SoMakeIt/StudentRobotics (lilafisch)
 +    * 3 x Chaostreff Salzburg via ahuemer. Geplante Projekte: Julia Mengen Betrachter, Mate Counter für das baldig kommende Geekend bei uns.
 +    * 2? x foobar Essen via gammlaa
 +    * 3 x [[http://flipdot.org/blog/|flipdot]] Kassel, http://vimeo.com/99262516
 +    * 2 x Hackerspace Budapest
  
-====== Alles neu, unsere viel bessere modulare Ansteuerung ======+am 31c3 rausgegeben von Gigo an ccczh 
 +    * 2 x [[https://www.ccczh.ch|CCC Zürich]]   
 +    * 2 x [[http://bastli.ch|Bastli]] ETH Zürich - daraus wurde unsere [[http://bastli.ch/uploads/coffeedot.jpg|Coffeedot-Anzeige]] zur [[http://bastli.ch/uploads/coffedot-machine.jpg|Studenten-Kaffeemaschine]]! 
 +    * 2 x [[http://zurich.fablab.ch|Fablab Zürich]] 
 +    * 2 x [[http://coredump.ch|coredump]]
  
-===== Vorschlag von luja ====== +=== Requests
-Man nimmt ein kleines FPGA, und etwas RAM(z.B. im FPGA enthalten) und hat einen Prozess,  +
-der die Daten zu den Schieberegistern schreibt. Der Pin9 sollte zum Prueflesen benutzt werden. +
-Nun teilen wir den RAM in 2 Bildschirmspeicher ein: +
-Einer der Speicher wird angezeigt, und der andere kann geladen werden.  +
-Ein Toggle-Bit im config-Register des FPGA schaltet zwischen Bildschirmspeicher und Vorbereitungs- +
-Speicher um. Bei Flankenwechsel des Speicherschalt-Bits wird der Update-Prozess ausgeloest.+
  
 +Wir haben noch ca. 11 Panels zu vergeben, Hackerspaces werden bevorzugt. Die Plan-Spalte wird nur von Mitgliedern des Fliptdot-Vergabe-Kommitees geändert. 
  
-Insgesamt kann man das Verhalten wie bei den grafikfaehigen Industrie-Displays LCD gestaltensodass +^ Angefragt  ^ Plan                                ^ Hackerspace/Person                                     ^ Transport                                   ^ Kommentar                                                                                                  ^ 
-man vorhandene Linux-Treiber fuer den Druckerport nutzen und anpassen kann.+| 1 defektes |                                   | com ]aet[ flipdot.org                                  | auf 32c3 übergeben                          | Haben 2aber defekte Pixel, deswegen Ersatz aus defektem Panel                                            | 
 +| 2          | 1                                   | Attraktor Hamburg via mc.fly                                                                       | Haben schon 2 (siehe oben)                                                                                 | 
 +| 4          | 2                                   | [[https://​stratum0.org|Stratum 0]] Braunschweig                                                   | als Twitter/IRC/...-Wall fürs Easterheg                                                                    | 
 +| 1 oder 2   | 0                                   | Philip Dusl                                            | Abholen @ muCCC                                                                                                                                        | 
 +| 4          | 2                                   | [[http://lug-hgw.de/|LUG Greifswald]]                  | auf 31c3 übergeben                          | Außenwerbung / Statusanzeige / Termine                                                                     | 
 +|            | 2                                   | www.hackerspace-bielefeld.de                                                                                                                                                                                  | 
 +| 2          |                                     | [[http://hackerspace-bamberg.de|Hackerspace Bamberg]]  |                                             | Würden gerne unsere Fenster mit schönen interaktiven Krams dekorieren                                      | 
 +| 2-4        |                                     | daniel domscheit-berg / havel:lab                      | Abholung, Uebergabe auf Veranstaltung, etc  | Wuerden einen hacker/makerspace im Aufbau gern mit idealerweise 2x2 Displays versorgen, fuer Auge und Ohr  | 
 +| 4        |                                     | FabLab Nürnberg: charlie ]ät[ fabfolk ]dod[ com                      | Abholung, Uebergabe auf Veranstaltung, etc  | Statusanzeige, Twitterwall und Veranstaltungsshowcase 
 +^            ^ ~~=sum(range(1,0,col(),row()-1))~~  ^                                                                                                                                                                                                           Summe |||
  
-Von der Ansteuerungsseite aus wird man z.B. 2 Addressen sehen, mit 8bit breiten Daten. 
-Addresse0 ist das Daten-Transferregister. 
-Adresse 1 ist config register: 
  
-Beschreibung:+Sonstige 
 +    * 1 x Marian Kleineberg -> Jan kümmert sich
  
-Wenn error-flag gesetzt, bringt ein read vom 
-dataport den errorcode 
-wenn error-flag nicht gesetzt, bringt read vom  
-data port, den zuletzt mit addresse selektierten 
-ram_inhalt. 
  
  
-Man kann im Config-Register 2 Register unterbringen,  +== Archiv
-wenn Register nur lesbar oder nur schreibbar sind, wird +
-je nach richtung das Register selektiert.+
  
 +* [[https://wiki.muc.ccc.de/flipdot:start?rev=1385812570#deprecated_krobin_und_sepi_s_vorschlag|krobin_und_sepi_s_vorschlag]]
  
-Also haben wir eine Address-Select-Leitung  
-und eine 8-bit-Datenleitung fuer den hackerport 
  
-Bedeutung der Kommandos: 
-Config-Register: 
-Bit0 invert: invertiert den bildschirmspeicher. Zusammen mit Redraw zum Blinken und Oelverteilen :-)  /W 1=Invert 
-BIT1 redraw: Schiebt den Bildschirmspeicher raus bei jedem uebergang 0->1 
-BIT2 speed: 0=slow, 1=fast, Speed fuer schieberegister /W 
-BIT3 error_flag (irgend ein error ist da) /R  error_clear /W 
-BIT4 ADDRESS_STROBE fuer Addresse_Highbyte wird aus Inhalt, der im Register an Addresse 0 liegt, gesetzt 
-BIT5 ADDRESS_STROBE fuer Communikations-Register an Addresse0 -> Addresse_Lowbyte wird aus Inhalt, der im Register an Addresse 0 liegt, gesetzt 
-BIT6 DATA_STROBE fuer Communikations-Register an Addresse0 -> Daten werden in zuvor selektierte Addresse  
-BIT7 TOGGLE_FRAMEBUFFER ->1=Higher Buffer wird angezeigt, lower kann gefuellt, gelesen werden. /W 
-  
-Redraw: entweder 3xToggeln Bit 7 oder Bit1 toggeln, 
-je nach Erfahrungen mit dem Schieberegisterkram. 
-Wir koennen auch den Redraw unabhaengig vom Buffer-Select BIT7 
-machen, sodass man mit Bufferselect ein Redraw befehlen muss, wenn man rausschreiben will. 
-So koennte man evtl. auch den Aktuellen Puffer manipulieren, um einen Blink-Cursor zu machen. 
-Intelligente Ansteuerung nach "Was hat sich geaendert" werden die Schieberigister nicht koennen oder? 
-Wenn ja koennte man die Elemente einzeln an das FPGA machen und so z.B. auch nur das sich geaenderte 
-Element updaten. I/Os haben FPGAs genug :-) 
  
 +== Live interaction at rc3
  
-Rambedarf ist Pixelzahl zweimal +See the flipdot in our rc3.world assembly in the couch area or at [[https://webex.muc.ccc.de/rc3lounge|RC3 lounge]] via Jitsi.
-Mein Vorschlag waere ein kleines automotive-fpga von actel. +
-Als Bildspeicher: +
-Wenn ichs richtig hab: +
-20*16*11*18 +
-63360BIT*2 +
-rund 128Kbit, also 16KBYTE RAM, ein paar Addressleitungen und 8 bit datenleitung zum  +
-FPGA und fertigWird auf nen 1-Lager passen. +
-Als RAM ein altes CAcHE-SRAM vom 586er oder 486er Mainboard, denn SRAM ist zahm in der Ansteuerung, +
-kein Refresh und so zeugsAddress/Datenbus, r/W, da wars schon.+
  
-Asynchrones Reset und Clock versteht sich fuer das ganze Design von selbst.+You can send own pixel data to the flipdot using IPv6 (only! Still using legacy IP? Time to upgrade) UDP packets to the Host flip.y.nu port 2424.
  
-   +There are a few examples in our [[https://github.com/muccc/flipdots/tree/master/scripts|flipdot git]] but they need some tweaking for the resolution and the destination host.
-Takt mit beliebigem Quarz z.B. 14.xxx MHZ aus Bastelkiste/ISACLK aus altem Mainboard.+
  
-Wegen altem Mainboard, frueher TM war IDE nur ein per Puffer und Addressdekoder rausgefuehrter ISA-BUS! +For a quick start try out [[https://pla.y.nu/flipdot-gameoflife.tar|this archive]] containing an adapted version of the game of life script. Bewareit needs python2Example use: python2 gameoflife.py random
-Und das Zeugs ist aufwaertskompatibelMan koennte das FPGA-Ding als "Festplatte" an den IDE/ISA-Bus haengen, +
-denn IDE wird aehnlich addressiert:-) +
-  +
-ich waere dafuer, dass man die beiden 8-bit Register (Config und Data) zusaetzlich ueber SPI zugreifbar macht, +
-einen SPI-Core von opencores.org nimmt, und so das Teil an irgendeinen OpenWRT-Router drandengeln kann, +
-und so ein web-interface hat, wo man SW-BMPs hochladen kann+
  
-Ob man jetzt per Parallel-Port oder SPI drauf geht ist egalSPI waere aber schon cool wegen Router-Recycling. +Unfortunately so far the animations won't stop when you send data (unlike our [[https://wiki.muc.ccc.de/acab|ACAB]])so depending on the shown animations your frames interleave with the current display or are almost invisible... We are working on that.
-Hab mal fuer ein MIL-Projekt SPI per LVDS angesteuert, ist sicher fuer einige Meter ok. +
-  +
-Vorteil der FPGA-Loesung istdass das SW-Timing voellig egal ist, denn das FPGA kuemmert sich um das Geschiebe und das Timing +
-Theoretisch koennte man durch das Prueflesen des Schieberegisters bis zur Geschwindigkeitsgrenze der HW gehen. +
-Ich wuerde aber sagen, dass 2MHZ schiebe-Clock genug sindWir nehmen z.Bbesagten 14MHZ-Quarz oder sonst was ab 10MHZ, +
-und teilen uns den Clock wie wir ihn brauchen. Evtl, im Configregister noch ein Flag fuer FAST/slow shift haben  +
-(z.B. 2MHZ vs 500kHz)+
  
  • flipdot/start.1361630888.txt.gz
  • Last modified: 2021/04/18 12:32
  • (external edit)