From df49f62d3d838e35f412a516f4eaf3949f4455d7 Mon Sep 17 00:00:00 2001 From: "Daniele Verducci (ZenPenguin)" Date: Fri, 1 Jan 2021 17:50:52 +0100 Subject: [PATCH 1/5] Uncommitted changes --- arduino/sdcard-test/sdcard-test.ino | 48 +++++++++++++++++++++++------ assembly/bios/drivers/sn76489.asm | 2 +- assembly/bios/libs/time.asm | 6 ++-- 3 files changed, 44 insertions(+), 12 deletions(-) diff --git a/arduino/sdcard-test/sdcard-test.ino b/arduino/sdcard-test/sdcard-test.ino index 382fc17..d9877ec 100644 --- a/arduino/sdcard-test/sdcard-test.ino +++ b/arduino/sdcard-test/sdcard-test.ino @@ -1,6 +1,6 @@ /** * SPI SD-Card test sketch - * Reads the first 128 bytes from cf and prints it out as ascii characters in serial monitor at 9200 baud + * Reads the first 128 bytes from sdcard and prints it out as ascii characters in serial monitor at 9200 baud * * Implementation of the specification at http://elm-chan.org/docs/mmc/mmc_e.html */ @@ -35,10 +35,41 @@ void setup() { // CMD0 with CS low (Software reset). Means "Leave native mode and enter SPI mode" digitalWrite(CS, LOW); - sendCommand(B01000000); // First two bits are always 01. Command is 0 (000000). + byte arg[] = {0x00,0x00,0x00,0x00}; + sendCommand(B01000000, arg); // First two bits are always 01. Command is 0 (000000). byte resp = receiveResponse(); - Serial.println("Card response:"); + Serial.print(" CMD0 response: "); Serial.println(resp, HEX); + // Now card is in idle mode + + // Send CMD8 (check voltage) to find if sd version is 2 or previous + byte arg2[] = {0x00,0x00,0x00,0x00}; + sendCommand(B01001000, arg2); // CMD8 + resp = receiveResponse(); + Serial.print(" CMD8 response: "); + Serial.println(resp, HEX); + + if (resp == 5) { + // CMD8 Illegal command: sd version 1.X + + while(true) { + // Now send ACMD41. ACMD is a CMD55 followed by a CMDxx + byte arg3[] = {0x00,0x00,0x00,0x00}; + sendCommand(B01110111, arg3); // CMD55 + //resp = receiveResponse(); + Serial.print(" CMD55 response: "); + Serial.println(resp, HEX); + byte arg4[] = {0x40,0x00,0x00,0x00}; + sendCommand(B01101001, arg4); // CMD41 + resp = receiveResponse(); + Serial.print(" CMD41 response: "); + Serial.println(resp, HEX); + } + } else { + Serial.print("Sd version 2 not supported."); + } + + digitalWrite(CS, HIGH); } @@ -61,12 +92,12 @@ void clk() { * This is ok, since the CRC field will not be checked in SPI mode. * @param index: the command index byte. First two bytes are the sync bytes "01". */ -void sendCommand(byte index) { +void sendCommand(byte index, byte arg[]) { // Send command index (2+6=8 bits) sendByte(index); // Send argument (32 bit) for(byte i=0; i<4; i++) { - sendByte(0); + sendByte(arg[i]); } // Send CRC with final stop bit (7+1=8 bits) sendByte(B10010101); // We send always the CMD0 CRC, because is not checked in SPI mode @@ -80,6 +111,7 @@ void sendByte(byte b) { for (byte i=0; i<8; i++) { // If last bit is 1 set MOSI HIGH, else LOW digitalWrite(MOSI, (b & B10000000) == B10000000 ? HIGH : LOW); + //Serial.print((b & B10000000) == B10000000 ? "1" : "0"); clk(); // Shift byte to have, in the next cycle, the next bit in last position b = b << 1; @@ -103,11 +135,9 @@ byte receiveResponse() { byte resp = 0; // Read 8 bits for (byte i=0; i<8; i++) { - if (digitalRead(MISO)) { - resp = resp | B00000001; - } resp = resp << 1; + resp = resp | digitalRead(MISO); clk(); } - + return resp; } diff --git a/assembly/bios/drivers/sn76489.asm b/assembly/bios/drivers/sn76489.asm index 57bf387..7151942 100644 --- a/assembly/bios/drivers/sn76489.asm +++ b/assembly/bios/drivers/sn76489.asm @@ -40,7 +40,7 @@ Snd_beep: ld a,%00001000 out (SND_DATA_REG),a ; wait - ld bc, (TIME_DUR_MILLIS * 100) + ld bc, (TIME_DUR_MILLIS * 10) call Time_delay55 ; silence ch1 ld a,%10011111 diff --git a/assembly/bios/libs/time.asm b/assembly/bios/libs/time.asm index f272ea6..2767151 100644 --- a/assembly/bios/libs/time.asm +++ b/assembly/bios/libs/time.asm @@ -1,14 +1,16 @@ ; Time library ; @author Daniele Verducci + ; Duration in cpu cycles / 55 (change these values based on CPU frequency) -TIME_DUR_SECOND: EQU 2545 -TIME_DUR_MILLIS: EQU 3 +TIME_DUR_SECOND: EQU 1818 +TIME_DUR_MILLIS: EQU 2 ; Wait bc * 55 states ; Use 1 iteration as delay between I/O bus writes ; @param bc The number of iterations. Each iteration is 55 states long. Time_delay55: +ret bit 0,a ; 8 bit 0,a ; 8 bit 0,a ; 8 From 68752e85a7e3405df1ff10c9394b4c6bed98dc75 Mon Sep 17 00:00:00 2001 From: Daniele Verducci su MatissePenguin Date: Sat, 2 Jan 2021 16:33:51 +0100 Subject: [PATCH 2/5] Reorganized folders, added pal-adapter io device folder --- .../hardware/logisim}/decoding_logic.circ | 0 .../z80-assembly}/applications/README.md | 0 .../applications/brief/hello_world.asm | 0 .../tests/hd44780_lcd_test_procedure.asm | 0 .../z80-assembly}/dev-headers/README.md | 0 .../z80-assembly}/dev-headers/monitor.asm | 0 .../software/z80-assembly}/os/Makefile | 0 .../software/z80-assembly}/os/README.md | 0 .../z80-assembly}/os/abi-generated.asm | 0 .../os/drivers/arduino_terminal.asm | 0 .../z80-assembly}/os/drivers/hd44780.asm | 0 .../z80-assembly}/os/drivers/keyboard.asm | 0 .../z80-assembly}/os/drivers/sn76489.asm | 0 .../z80-assembly}/os/drivers/vgax.asm | 0 .../z80-assembly}/os/libs/strings.asm | 0 .../software/z80-assembly}/os/libs/time.asm | 1 + .../software/z80-assembly}/os/main-dev.asm | 0 .../software/z80-assembly}/os/main.asm | 6 + .../software/z80-assembly}/os/monitor.asm | 0 .../z80-assembly}/os/tests/sndtest.asm | 0 .../software/avr-assembly/Makefile | 5 + .../avr-assembly/atmega1284definition.asm | 276 ++++++++++++++++++ .../software/avr-assembly/main.asm | 31 ++ .../software/avr-assembly/main.cof | 0 .../software/avr-assembly/main.eep.hex | 1 + .../software/avr-assembly/main.hex | 4 + .../software/avr-assembly/main.obj | Bin 0 -> 205 bytes .../arduino_terminal/arduino_terminal.ino | 0 .../python}/terminal_emulator.py | 4 +- .../SN76489-test/SN76489-test.ino | 0 .../eeprom_programmer/eeprom_programmer.ino | 0 .../hd44780_debugger/hd44780_debugger.ino | 0 .../pal_adapter/pal_adapter.ino | 0 .../sdcard-test/sdcard-test.ino | 0 .../z80_debugger/z80_debugger.ino | 0 35 files changed, 327 insertions(+), 1 deletion(-) rename {logisim => pat80-computer/hardware/logisim}/decoding_logic.circ (100%) rename {assembly => pat80-computer/software/z80-assembly}/applications/README.md (100%) rename {assembly => pat80-computer/software/z80-assembly}/applications/brief/hello_world.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/applications/tests/hd44780_lcd_test_procedure.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/dev-headers/README.md (100%) rename {assembly => pat80-computer/software/z80-assembly}/dev-headers/monitor.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/Makefile (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/README.md (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/abi-generated.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/drivers/arduino_terminal.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/drivers/hd44780.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/drivers/keyboard.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/drivers/sn76489.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/drivers/vgax.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/libs/strings.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/libs/time.asm (98%) rename {assembly => pat80-computer/software/z80-assembly}/os/main-dev.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/main.asm (95%) rename {assembly => pat80-computer/software/z80-assembly}/os/monitor.asm (100%) rename {assembly => pat80-computer/software/z80-assembly}/os/tests/sndtest.asm (100%) create mode 100644 pat80-io-devices/composite-pal-adapter/software/avr-assembly/Makefile create mode 100644 pat80-io-devices/composite-pal-adapter/software/avr-assembly/atmega1284definition.asm create mode 100644 pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm create mode 100644 pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.cof create mode 100644 pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.eep.hex create mode 100644 pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.hex create mode 100644 pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.obj rename {arduino => pat80-io-devices/parallel-terminal/arduino}/arduino_terminal/arduino_terminal.ino (100%) rename {python => pat80-io-devices/parallel-terminal/python}/terminal_emulator.py (96%) rename {arduino => prototiping-with-arduino}/SN76489-test/SN76489-test.ino (100%) rename {arduino => prototiping-with-arduino}/eeprom_programmer/eeprom_programmer/eeprom_programmer.ino (100%) rename {arduino => prototiping-with-arduino}/hd44780_debugger/hd44780_debugger.ino (100%) rename {arduino => prototiping-with-arduino}/pal_adapter/pal_adapter.ino (100%) rename {arduino => prototiping-with-arduino}/sdcard-test/sdcard-test.ino (100%) rename {arduino => prototiping-with-arduino}/z80_debugger/z80_debugger.ino (100%) diff --git a/logisim/decoding_logic.circ b/pat80-computer/hardware/logisim/decoding_logic.circ similarity index 100% rename from logisim/decoding_logic.circ rename to pat80-computer/hardware/logisim/decoding_logic.circ diff --git a/assembly/applications/README.md b/pat80-computer/software/z80-assembly/applications/README.md similarity index 100% rename from assembly/applications/README.md rename to pat80-computer/software/z80-assembly/applications/README.md diff --git a/assembly/applications/brief/hello_world.asm b/pat80-computer/software/z80-assembly/applications/brief/hello_world.asm similarity index 100% rename from assembly/applications/brief/hello_world.asm rename to pat80-computer/software/z80-assembly/applications/brief/hello_world.asm diff --git a/assembly/applications/tests/hd44780_lcd_test_procedure.asm b/pat80-computer/software/z80-assembly/applications/tests/hd44780_lcd_test_procedure.asm similarity index 100% rename from assembly/applications/tests/hd44780_lcd_test_procedure.asm rename to pat80-computer/software/z80-assembly/applications/tests/hd44780_lcd_test_procedure.asm diff --git a/assembly/dev-headers/README.md b/pat80-computer/software/z80-assembly/dev-headers/README.md similarity index 100% rename from assembly/dev-headers/README.md rename to pat80-computer/software/z80-assembly/dev-headers/README.md diff --git a/assembly/dev-headers/monitor.asm b/pat80-computer/software/z80-assembly/dev-headers/monitor.asm similarity index 100% rename from assembly/dev-headers/monitor.asm rename to pat80-computer/software/z80-assembly/dev-headers/monitor.asm diff --git a/assembly/os/Makefile b/pat80-computer/software/z80-assembly/os/Makefile similarity index 100% rename from assembly/os/Makefile rename to pat80-computer/software/z80-assembly/os/Makefile diff --git a/assembly/os/README.md b/pat80-computer/software/z80-assembly/os/README.md similarity index 100% rename from assembly/os/README.md rename to pat80-computer/software/z80-assembly/os/README.md diff --git a/assembly/os/abi-generated.asm b/pat80-computer/software/z80-assembly/os/abi-generated.asm similarity index 100% rename from assembly/os/abi-generated.asm rename to pat80-computer/software/z80-assembly/os/abi-generated.asm diff --git a/assembly/os/drivers/arduino_terminal.asm b/pat80-computer/software/z80-assembly/os/drivers/arduino_terminal.asm similarity index 100% rename from assembly/os/drivers/arduino_terminal.asm rename to pat80-computer/software/z80-assembly/os/drivers/arduino_terminal.asm diff --git a/assembly/os/drivers/hd44780.asm b/pat80-computer/software/z80-assembly/os/drivers/hd44780.asm similarity index 100% rename from assembly/os/drivers/hd44780.asm rename to pat80-computer/software/z80-assembly/os/drivers/hd44780.asm diff --git a/assembly/os/drivers/keyboard.asm b/pat80-computer/software/z80-assembly/os/drivers/keyboard.asm similarity index 100% rename from assembly/os/drivers/keyboard.asm rename to pat80-computer/software/z80-assembly/os/drivers/keyboard.asm diff --git a/assembly/os/drivers/sn76489.asm b/pat80-computer/software/z80-assembly/os/drivers/sn76489.asm similarity index 100% rename from assembly/os/drivers/sn76489.asm rename to pat80-computer/software/z80-assembly/os/drivers/sn76489.asm diff --git a/assembly/os/drivers/vgax.asm b/pat80-computer/software/z80-assembly/os/drivers/vgax.asm similarity index 100% rename from assembly/os/drivers/vgax.asm rename to pat80-computer/software/z80-assembly/os/drivers/vgax.asm diff --git a/assembly/os/libs/strings.asm b/pat80-computer/software/z80-assembly/os/libs/strings.asm similarity index 100% rename from assembly/os/libs/strings.asm rename to pat80-computer/software/z80-assembly/os/libs/strings.asm diff --git a/assembly/os/libs/time.asm b/pat80-computer/software/z80-assembly/os/libs/time.asm similarity index 98% rename from assembly/os/libs/time.asm rename to pat80-computer/software/z80-assembly/os/libs/time.asm index f272ea6..f183cf2 100644 --- a/assembly/os/libs/time.asm +++ b/pat80-computer/software/z80-assembly/os/libs/time.asm @@ -9,6 +9,7 @@ TIME_DUR_MILLIS: EQU 3 ; Use 1 iteration as delay between I/O bus writes ; @param bc The number of iterations. Each iteration is 55 states long. Time_delay55: +ret bit 0,a ; 8 bit 0,a ; 8 bit 0,a ; 8 diff --git a/assembly/os/main-dev.asm b/pat80-computer/software/z80-assembly/os/main-dev.asm similarity index 100% rename from assembly/os/main-dev.asm rename to pat80-computer/software/z80-assembly/os/main-dev.asm diff --git a/assembly/os/main.asm b/pat80-computer/software/z80-assembly/os/main.asm similarity index 95% rename from assembly/os/main.asm rename to pat80-computer/software/z80-assembly/os/main.asm index d43f86e..c688328 100644 --- a/assembly/os/main.asm +++ b/pat80-computer/software/z80-assembly/os/main.asm @@ -104,4 +104,10 @@ Sysinit: ; Run memory monitor call Monitor_main + ; DEBUG: Echo chars + ; loop: + ; call Term_readc + ; call Term_printc + ; jp loop + halt diff --git a/assembly/os/monitor.asm b/pat80-computer/software/z80-assembly/os/monitor.asm similarity index 100% rename from assembly/os/monitor.asm rename to pat80-computer/software/z80-assembly/os/monitor.asm diff --git a/assembly/os/tests/sndtest.asm b/pat80-computer/software/z80-assembly/os/tests/sndtest.asm similarity index 100% rename from assembly/os/tests/sndtest.asm rename to pat80-computer/software/z80-assembly/os/tests/sndtest.asm diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/Makefile b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/Makefile new file mode 100644 index 0000000..1ea2994 --- /dev/null +++ b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/Makefile @@ -0,0 +1,5 @@ +pal-adapter: + @echo "Building pal adapter rom..." + @avra main.asm + @echo "Writing to ATMEGA1284..." + @minipro -w main.hex -p ATMEGA1284 \ No newline at end of file diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/atmega1284definition.asm b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/atmega1284definition.asm new file mode 100644 index 0000000..cfbc22d --- /dev/null +++ b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/atmega1284definition.asm @@ -0,0 +1,276 @@ +; ***** I/O REGISTER DEFINITIONS ***************************************** +; NOTE: +; Definitions marked "MEMORY MAPPED"are extended I/O ports +; and cannot be used with IN/OUT instructions +.equ UDR1 = 0xce ; MEMORY MAPPED +.equ UBRR1L = 0xcc ; MEMORY MAPPED +.equ UBRR1H = 0xcd ; MEMORY MAPPED +.equ UCSR1C = 0xca ; MEMORY MAPPED +.equ UCSR1B = 0xc9 ; MEMORY MAPPED +.equ UCSR1A = 0xc8 ; MEMORY MAPPED +.equ UDR0 = 0xc6 ; MEMORY MAPPED +.equ UBRR0L = 0xc4 ; MEMORY MAPPED +.equ UBRR0H = 0xc5 ; MEMORY MAPPED +.equ UCSR0C = 0xc2 ; MEMORY MAPPED +.equ UCSR0B = 0xc1 ; MEMORY MAPPED +.equ UCSR0A = 0xc0 ; MEMORY MAPPED +.equ TWAMR = 0xbd ; MEMORY MAPPED +.equ TWCR = 0xbc ; MEMORY MAPPED +.equ TWDR = 0xbb ; MEMORY MAPPED +.equ TWAR = 0xba ; MEMORY MAPPED +.equ TWSR = 0xb9 ; MEMORY MAPPED +.equ TWBR = 0xb8 ; MEMORY MAPPED +.equ ASSR = 0xb6 ; MEMORY MAPPED +.equ OCR2B = 0xb4 ; MEMORY MAPPED +.equ OCR2A = 0xb3 ; MEMORY MAPPED +.equ TCNT2 = 0xb2 ; MEMORY MAPPED +.equ TCCR2B = 0xb1 ; MEMORY MAPPED +.equ TCCR2A = 0xb0 ; MEMORY MAPPED +.equ OCR3BL = 0x9a ; MEMORY MAPPED +.equ OCR3BH = 0x9b ; MEMORY MAPPED +.equ OCR3AL = 0x98 ; MEMORY MAPPED +.equ OCR3AH = 0x99 ; MEMORY MAPPED +.equ ICR3L = 0x96 ; MEMORY MAPPED +.equ ICR3H = 0x97 ; MEMORY MAPPED +.equ TCNT3L = 0x94 ; MEMORY MAPPED +.equ TCNT3H = 0x95 ; MEMORY MAPPED +.equ TCCR3C = 0x92 ; MEMORY MAPPED +.equ TCCR3B = 0x91 ; MEMORY MAPPED +.equ TCCR3A = 0x90 ; MEMORY MAPPED +.equ OCR1BL = 0x8a ; MEMORY MAPPED +.equ OCR1BH = 0x8b ; MEMORY MAPPED +.equ OCR1AL = 0x88 ; MEMORY MAPPED +.equ OCR1AH = 0x89 ; MEMORY MAPPED +.equ ICR1L = 0x86 ; MEMORY MAPPED +.equ ICR1H = 0x87 ; MEMORY MAPPED +.equ TCNT1L = 0x84 ; MEMORY MAPPED +.equ TCNT1H = 0x85 ; MEMORY MAPPED +.equ TCCR1C = 0x82 ; MEMORY MAPPED +.equ TCCR1B = 0x81 ; MEMORY MAPPED +.equ TCCR1A = 0x80 ; MEMORY MAPPED +.equ DIDR1 = 0x7f ; MEMORY MAPPED +.equ DIDR0 = 0x7e ; MEMORY MAPPED +.equ ADMUX = 0x7c ; MEMORY MAPPED +.equ ADCSRB = 0x7b ; MEMORY MAPPED +.equ ADCSRA = 0x7a ; MEMORY MAPPED +.equ ADCH = 0x79 ; MEMORY MAPPED +.equ ADCL = 0x78 ; MEMORY MAPPED +.equ PCMSK3 = 0x73 ; MEMORY MAPPED +.equ TIMSK3 = 0x71 ; MEMORY MAPPED +.equ TIMSK2 = 0x70 ; MEMORY MAPPED +.equ TIMSK1 = 0x6f ; MEMORY MAPPED +.equ TIMSK0 = 0x6e ; MEMORY MAPPED +.equ PCMSK2 = 0x6d ; MEMORY MAPPED +.equ PCMSK1 = 0x6c ; MEMORY MAPPED +.equ PCMSK0 = 0x6b ; MEMORY MAPPED +.equ EICRA = 0x69 ; MEMORY MAPPED +.equ PCICR = 0x68 ; MEMORY MAPPED +.equ OSCCAL = 0x66 ; MEMORY MAPPED +.equ PRR1 = 0x65 ; MEMORY MAPPED +.equ PRR0 = 0x64 ; MEMORY MAPPED +.equ CLKPR = 0x61 ; MEMORY MAPPED +.equ WDTCSR = 0x60 ; MEMORY MAPPED +.equ SREG = 0x3f +.equ SPL = 0x3d +.equ SPH = 0x3e +.equ RAMPZ = 0x3b +.equ SPMCSR = 0x37 +.equ MCUCR = 0x35 +.equ MCUSR = 0x34 +.equ SMCR = 0x33 +.equ OCDR = 0x31 +.equ ACSR = 0x30 +.equ SPDR = 0x2e +.equ SPSR = 0x2d +.equ SPCR = 0x2c +.equ GPIOR2 = 0x2b +.equ GPIOR1 = 0x2a +.equ OCR0B = 0x28 +.equ OCR0A = 0x27 +.equ TCNT0 = 0x26 +.equ TCCR0B = 0x25 +.equ TCCR0A = 0x24 +.equ GTCCR = 0x23 +.equ EEARH = 0x22 +.equ EEARL = 0x21 +.equ EEDR = 0x20 +.equ EECR = 0x1f +.equ GPIOR0 = 0x1e +.equ EIMSK = 0x1d +.equ EIFR = 0x1c +.equ PCIFR = 0x1b +.equ TIFR3 = 0x18 +.equ TIFR2 = 0x17 +.equ TIFR1 = 0x16 +.equ TIFR0 = 0x15 +.equ PORTD = 0x0b +.equ DDRD = 0x0a +.equ PIND = 0x09 +.equ PORTC = 0x08 +.equ DDRC = 0x07 +.equ PINC = 0x06 +.equ PORTB = 0x05 +.equ DDRB = 0x04 +.equ PINB = 0x03 +.equ PORTA = 0x02 +.equ DDRA = 0x01 +.equ PINA = 0x00 + +; ***** PORTA ************************ +; PORTA - Port A Data Register +.equ PORTA0 = 0 ; Port A Data Register bit 0 +.equ PA0 = 0 ; For compatibility +.equ PORTA1 = 1 ; Port A Data Register bit 1 +.equ PA1 = 1 ; For compatibility +.equ PORTA2 = 2 ; Port A Data Register bit 2 +.equ PA2 = 2 ; For compatibility +.equ PORTA3 = 3 ; Port A Data Register bit 3 +.equ PA3 = 3 ; For compatibility +.equ PORTA4 = 4 ; Port A Data Register bit 4 +.equ PA4 = 4 ; For compatibility +.equ PORTA5 = 5 ; Port A Data Register bit 5 +.equ PA5 = 5 ; For compatibility +.equ PORTA6 = 6 ; Port A Data Register bit 6 +.equ PA6 = 6 ; For compatibility +.equ PORTA7 = 7 ; Port A Data Register bit 7 +.equ PA7 = 7 ; For compatibility + +; DDRA - Port A Data Direction Register +.equ DDA0 = 0 ; Data Direction Register, Port A, bit 0 +.equ DDA1 = 1 ; Data Direction Register, Port A, bit 1 +.equ DDA2 = 2 ; Data Direction Register, Port A, bit 2 +.equ DDA3 = 3 ; Data Direction Register, Port A, bit 3 +.equ DDA4 = 4 ; Data Direction Register, Port A, bit 4 +.equ DDA5 = 5 ; Data Direction Register, Port A, bit 5 +.equ DDA6 = 6 ; Data Direction Register, Port A, bit 6 +.equ DDA7 = 7 ; Data Direction Register, Port A, bit 7 + +; PINA - Port A Input Pins +.equ PINA0 = 0 ; Input Pins, Port A bit 0 +.equ PINA1 = 1 ; Input Pins, Port A bit 1 +.equ PINA2 = 2 ; Input Pins, Port A bit 2 +.equ PINA3 = 3 ; Input Pins, Port A bit 3 +.equ PINA4 = 4 ; Input Pins, Port A bit 4 +.equ PINA5 = 5 ; Input Pins, Port A bit 5 +.equ PINA6 = 6 ; Input Pins, Port A bit 6 +.equ PINA7 = 7 ; Input Pins, Port A bit 7 + + +; ***** PORTB ************************ +; PORTB - Port B Data Register +.equ PORTB0 = 0 ; Port B Data Register bit 0 +.equ PB0 = 0 ; For compatibility +.equ PORTB1 = 1 ; Port B Data Register bit 1 +.equ PB1 = 1 ; For compatibility +.equ PORTB2 = 2 ; Port B Data Register bit 2 +.equ PB2 = 2 ; For compatibility +.equ PORTB3 = 3 ; Port B Data Register bit 3 +.equ PB3 = 3 ; For compatibility +.equ PORTB4 = 4 ; Port B Data Register bit 4 +.equ PB4 = 4 ; For compatibility +.equ PORTB5 = 5 ; Port B Data Register bit 5 +.equ PB5 = 5 ; For compatibility +.equ PORTB6 = 6 ; Port B Data Register bit 6 +.equ PB6 = 6 ; For compatibility +.equ PORTB7 = 7 ; Port B Data Register bit 7 +.equ PB7 = 7 ; For compatibility + +; DDRB - Port B Data Direction Register +.equ DDB0 = 0 ; Port B Data Direction Register bit 0 +.equ DDB1 = 1 ; Port B Data Direction Register bit 1 +.equ DDB2 = 2 ; Port B Data Direction Register bit 2 +.equ DDB3 = 3 ; Port B Data Direction Register bit 3 +.equ DDB4 = 4 ; Port B Data Direction Register bit 4 +.equ DDB5 = 5 ; Port B Data Direction Register bit 5 +.equ DDB6 = 6 ; Port B Data Direction Register bit 6 +.equ DDB7 = 7 ; Port B Data Direction Register bit 7 + +; PINB - Port B Input Pins +.equ PINB0 = 0 ; Port B Input Pins bit 0 +.equ PINB1 = 1 ; Port B Input Pins bit 1 +.equ PINB2 = 2 ; Port B Input Pins bit 2 +.equ PINB3 = 3 ; Port B Input Pins bit 3 +.equ PINB4 = 4 ; Port B Input Pins bit 4 +.equ PINB5 = 5 ; Port B Input Pins bit 5 +.equ PINB6 = 6 ; Port B Input Pins bit 6 +.equ PINB7 = 7 ; Port B Input Pins bit 7 + + +; ***** PORTC ************************ +; PORTC - Port C Data Register +.equ PORTC0 = 0 ; Port C Data Register bit 0 +.equ PC0 = 0 ; For compatibility +.equ PORTC1 = 1 ; Port C Data Register bit 1 +.equ PC1 = 1 ; For compatibility +.equ PORTC2 = 2 ; Port C Data Register bit 2 +.equ PC2 = 2 ; For compatibility +.equ PORTC3 = 3 ; Port C Data Register bit 3 +.equ PC3 = 3 ; For compatibility +.equ PORTC4 = 4 ; Port C Data Register bit 4 +.equ PC4 = 4 ; For compatibility +.equ PORTC5 = 5 ; Port C Data Register bit 5 +.equ PC5 = 5 ; For compatibility +.equ PORTC6 = 6 ; Port C Data Register bit 6 +.equ PC6 = 6 ; For compatibility +.equ PORTC7 = 7 ; Port C Data Register bit 7 +.equ PC7 = 7 ; For compatibility + +; DDRC - Port C Data Direction Register +.equ DDC0 = 0 ; Port C Data Direction Register bit 0 +.equ DDC1 = 1 ; Port C Data Direction Register bit 1 +.equ DDC2 = 2 ; Port C Data Direction Register bit 2 +.equ DDC3 = 3 ; Port C Data Direction Register bit 3 +.equ DDC4 = 4 ; Port C Data Direction Register bit 4 +.equ DDC5 = 5 ; Port C Data Direction Register bit 5 +.equ DDC6 = 6 ; Port C Data Direction Register bit 6 +.equ DDC7 = 7 ; Port C Data Direction Register bit 7 + +; PINC - Port C Input Pins +.equ PINC0 = 0 ; Port C Input Pins bit 0 +.equ PINC1 = 1 ; Port C Input Pins bit 1 +.equ PINC2 = 2 ; Port C Input Pins bit 2 +.equ PINC3 = 3 ; Port C Input Pins bit 3 +.equ PINC4 = 4 ; Port C Input Pins bit 4 +.equ PINC5 = 5 ; Port C Input Pins bit 5 +.equ PINC6 = 6 ; Port C Input Pins bit 6 +.equ PINC7 = 7 ; Port C Input Pins bit 7 + + +; ***** PORTD ************************ +; PORTD - Port D Data Register +.equ PORTD0 = 0 ; Port D Data Register bit 0 +.equ PD0 = 0 ; For compatibility +.equ PORTD1 = 1 ; Port D Data Register bit 1 +.equ PD1 = 1 ; For compatibility +.equ PORTD2 = 2 ; Port D Data Register bit 2 +.equ PD2 = 2 ; For compatibility +.equ PORTD3 = 3 ; Port D Data Register bit 3 +.equ PD3 = 3 ; For compatibility +.equ PORTD4 = 4 ; Port D Data Register bit 4 +.equ PD4 = 4 ; For compatibility +.equ PORTD5 = 5 ; Port D Data Register bit 5 +.equ PD5 = 5 ; For compatibility +.equ PORTD6 = 6 ; Port D Data Register bit 6 +.equ PD6 = 6 ; For compatibility +.equ PORTD7 = 7 ; Port D Data Register bit 7 +.equ PD7 = 7 ; For compatibility + +; DDRD - Port D Data Direction Register +.equ DDD0 = 0 ; Port D Data Direction Register bit 0 +.equ DDD1 = 1 ; Port D Data Direction Register bit 1 +.equ DDD2 = 2 ; Port D Data Direction Register bit 2 +.equ DDD3 = 3 ; Port D Data Direction Register bit 3 +.equ DDD4 = 4 ; Port D Data Direction Register bit 4 +.equ DDD5 = 5 ; Port D Data Direction Register bit 5 +.equ DDD6 = 6 ; Port D Data Direction Register bit 6 +.equ DDD7 = 7 ; Port D Data Direction Register bit 7 + +; PIND - Port D Input Pins +.equ PIND0 = 0 ; Port D Input Pins bit 0 +.equ PIND1 = 1 ; Port D Input Pins bit 1 +.equ PIND2 = 2 ; Port D Input Pins bit 2 +.equ PIND3 = 3 ; Port D Input Pins bit 3 +.equ PIND4 = 4 ; Port D Input Pins bit 4 +.equ PIND5 = 5 ; Port D Input Pins bit 5 +.equ PIND6 = 6 ; Port D Input Pins bit 6 +.equ PIND7 = 7 ; Port D Input Pins bit 7 \ No newline at end of file diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm new file mode 100644 index 0000000..e04c42f --- /dev/null +++ b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm @@ -0,0 +1,31 @@ +.include "atmega1284definition.asm" + +; define constant +.equ LED_PIN = PD7 ; use PD7 as LED pin + +; start vector +.org 0x0000 + rjmp main ; jump to main label + +; main program +main: + sbi DDRD, LED_PIN ; set LED pin as output +loop: + sbic PIND, LED_PIN ; if bit of LED pin is clear, skip next line + cbi PORTD, LED_PIN ; if 1, turn the LED off + sbis PIND, LED_PIN ; if bit of LED pin is set, skip next line + sbi PORTD, LED_PIN ; if 0, light the LED up +delay_500ms: + ldi r20, 32 ; set register, r20 = 32 +delay2: + ldi r19, 64 ; set register, r19 = 64 +delay1: + ldi r18, 128 ; set register, r18 = 128 +delay0: + dec r18 ; decrement register, r18 = r18 - 1 + brne delay0 ; if r18 != 0, jump to label delay0 + dec r19 ; decrement register, r19 = r19 -1 + brne delay1 ; if r19 != 0, jump to label delay1 + dec r20 ; decrement register, r20 = r20 -1 + brne delay2 ; if r20 != 0, jump to label delay2 + rjmp loop ; if r20 == 0, jump to label loop \ No newline at end of file diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.cof b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.cof new file mode 100644 index 0000000..e69de29 diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.eep.hex b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.eep.hex new file mode 100644 index 0000000..1996e8f --- /dev/null +++ b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.eep.hex @@ -0,0 +1 @@ +:00000001FF diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.hex b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.hex new file mode 100644 index 0000000..ea269f6 --- /dev/null +++ b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.hex @@ -0,0 +1,4 @@ +:020000020000FC +:1000000000C0579A4F995F984F9B5F9A40E230E447 +:1000100020E82A95F1F73A95D9F74A95C1F7F2CF3A +:00000001FF diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.obj b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.obj new file mode 100644 index 0000000000000000000000000000000000000000..d2d9bd44c3a94e6d6507e225692d5c3f655304d3 GIT binary patch literal 205 zcmZQzU|7Y#z#zrR Date: Sat, 2 Jan 2021 17:02:30 +0100 Subject: [PATCH 3/5] pal-adapter: fuses config and readme --- .../software/avr-assembly/README.md | 13 +++++++++++++ .../software/avr-assembly/fuses.conf | 4 ++++ 2 files changed, 17 insertions(+) create mode 100644 pat80-io-devices/composite-pal-adapter/software/avr-assembly/README.md create mode 100644 pat80-io-devices/composite-pal-adapter/software/avr-assembly/fuses.conf diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/README.md b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/README.md new file mode 100644 index 0000000..e4299ed --- /dev/null +++ b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/README.md @@ -0,0 +1,13 @@ +# Atmega Microcontroller +## Build ASM code +`avra filename.asm` (generates *filename.hex*) + +## Flash +### Rom +`minipro -w filename.hex -p ATMEGA1284` + +### Fuses +Read fuses: `minipro -r -c config -p ATMEGA1284` (`-r -c config` means read configuration (fuses)) +Fuses must be written all together, so read the current values, edit the generated file and write it. +The meaning of every bis is in the conf file. +Write fuses: `minipro -w fuses.conf -c config -p ATMEGA1284` \ No newline at end of file diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/fuses.conf b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/fuses.conf new file mode 100644 index 0000000..76a3a9a --- /dev/null +++ b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/fuses.conf @@ -0,0 +1,4 @@ +fuses_lo = 0x6F +fuses_hi = 0x99 +fuses_ext = 0xff +lock_byte = 0xff From 60243dc95f503e57750e62a0f69362d9dc62cbe6 Mon Sep 17 00:00:00 2001 From: Daniele Verducci su MatissePenguin Date: Sat, 2 Jan 2021 19:54:17 +0100 Subject: [PATCH 4/5] Horyzontal timings (working, checked with oscilloscope) --- .../software/avr-assembly/fuses.conf | 2 +- .../software/avr-assembly/main.asm | 92 ++++++++++++++----- 2 files changed, 72 insertions(+), 22 deletions(-) diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/fuses.conf b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/fuses.conf index 76a3a9a..fc9d0a0 100644 --- a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/fuses.conf +++ b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/fuses.conf @@ -1,4 +1,4 @@ -fuses_lo = 0x6F +fuses_lo = 0xAF fuses_hi = 0x99 fuses_ext = 0xff lock_byte = 0xff diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm index e04c42f..a991e01 100644 --- a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm +++ b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm @@ -1,7 +1,11 @@ +; VIDEO COMPOSITE PAL IO DEVICE +; Implemented following timings in http://blog.retroleum.co.uk/electronics-articles/pal-tv-timing-and-voltages/ + .include "atmega1284definition.asm" ; define constant -.equ LED_PIN = PD7 ; use PD7 as LED pin +.equ SYNC_PIN = PD7 ; Sync pin is on Port D 7 (pin 21) +.equ VIDEO_PIN = PD6 ; Video pin is on Port D 6 (pin 20) ; start vector .org 0x0000 @@ -9,23 +13,69 @@ ; main program main: - sbi DDRD, LED_PIN ; set LED pin as output -loop: - sbic PIND, LED_PIN ; if bit of LED pin is clear, skip next line - cbi PORTD, LED_PIN ; if 1, turn the LED off - sbis PIND, LED_PIN ; if bit of LED pin is set, skip next line - sbi PORTD, LED_PIN ; if 0, light the LED up -delay_500ms: - ldi r20, 32 ; set register, r20 = 32 -delay2: - ldi r19, 64 ; set register, r19 = 64 -delay1: - ldi r18, 128 ; set register, r18 = 128 -delay0: - dec r18 ; decrement register, r18 = r18 - 1 - brne delay0 ; if r18 != 0, jump to label delay0 - dec r19 ; decrement register, r19 = r19 -1 - brne delay1 ; if r19 != 0, jump to label delay1 - dec r20 ; decrement register, r20 = r20 -1 - brne delay2 ; if r20 != 0, jump to label delay2 - rjmp loop ; if r20 == 0, jump to label loop \ No newline at end of file + sbi DDRD, SYNC_PIN ; set pin as output + sbi DDRD, VIDEO_PIN ; set pin as output + +v_refresh_loop: + ; start 5 long sync pulses + + ; end 5 long sync pulses + + ; start 5 short sync pulses + + ; end 5 short sync pulses + + ; start 304 picture lines + ldi r16, 2 + h_picture_outer_loop: + ldi r17, 152 ; line counter + h_picture_loop: + ; start line sync: 4uS, 96 cycles @ 24Mhz + cbi PORTD, SYNC_PIN ; sync goes low (0v) ; 2 cycle + ldi r18, 32 ; 1 cycle + l_sync_pulse_loop: ; requires 3 cpu cycles + dec r18 ; 1 cycle + brne l_sync_pulse_loop ; 2 cycle if true, 1 if false + sbi PORTD, SYNC_PIN ; sync goes high (0.3v) + ; end line sync + + ; start back porch: 8uS, 192 cycles @ 24Mhz + ldi r18, 64 ; 1 cycle + l_sync_back_porch_loop: + dec r18 ; 1 cycle + brne l_sync_back_porch_loop ; 2 cycle if true, 1 if false + ; end back porch + + ; start image: 52uS, 1247 cycles @ 24Mhz + ; 3 bande da 416 cicli + + sbi PORTD, VIDEO_PIN ; video goes high ; 2 cycle + + ldi r18, 138 ; 1 cycle + l_sync_video_loop1: + dec r18 ; 1 cycle + brne l_sync_video_loop1 ; 2 cycle if true, 1 if false + + cbi PORTD, VIDEO_PIN ; video goes low + + ldi r18, 137 ; 1 cycle + l_sync_video_loop2: + dec r18 ; 1 cycle + brne l_sync_video_loop2 ; 2 cycle if true, 1 if false + + sbi PORTD, VIDEO_PIN ; video goes high + + ldi r18, 138 ; 1 cycle + l_sync_video_loop3: + dec r18 ; 1 cycle + brne l_sync_video_loop3 ; 2 cycle if true, 1 if false + cbi PORTD, VIDEO_PIN ; video goes low + + ; end image + + dec r17 ; decrement line counter + brne h_picture_loop ; if not 0, repeat h_picture_loop + + dec r16 ; decrement outside counter + brne h_picture_outer_loop ; if not 0, repeat h_picture_loop + ; end picture lines From 7e1facf59f270de4c6ed14c42afb0956d004f07c Mon Sep 17 00:00:00 2001 From: Daniele Verducci su MatissePenguin Date: Sat, 2 Jan 2021 20:43:42 +0100 Subject: [PATCH 5/5] First working image with a lot of jitter --- .../software/avr-assembly/main.asm | 65 ++++++++++++++++++- 1 file changed, 63 insertions(+), 2 deletions(-) diff --git a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm index a991e01..a031f7f 100644 --- a/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm +++ b/pat80-io-devices/composite-pal-adapter/software/avr-assembly/main.asm @@ -18,11 +18,19 @@ main: v_refresh_loop: ; start 5 long sync pulses - + call long_sync + call long_sync + call long_sync + call long_sync + call long_sync ; end 5 long sync pulses ; start 5 short sync pulses - + call short_sync + call short_sync + call short_sync + call short_sync + call short_sync ; end 5 short sync pulses ; start 304 picture lines @@ -79,3 +87,56 @@ v_refresh_loop: dec r16 ; decrement outside counter brne h_picture_outer_loop ; if not 0, repeat h_picture_loop ; end picture lines + + ; start 6 short sync pulses + call short_sync + call short_sync + call short_sync + call short_sync + call short_sync + ; end 6 short sync pulses + + jmp v_refresh_loop +; end vertical refresh + +long_sync: + ; long sync: 30uS low (719 cycles @ 24Mhz), 2uS high (48 cycles @ 24Mhz) + cbi PORTD, SYNC_PIN ; sync goes low (0v) ; 2 cycle + + ldi r18, 120 ; 1 cycle + long_sync_low_loop: ; requires 6 cpu cycles + nop ; 1 cycle + nop ; 1 cycle + nop ; 1 cycle + dec r18 ; 1 cycle + brne long_sync_low_loop ; 2 cycle if true, 1 if false + + sbi PORTD, SYNC_PIN ; sync goes high (0.3v) + + ldi r18, 16 ; 1 cycle + long_sync_high_loop: ; requires 3 cpu cycles + dec r18 ; 1 cycle + brne long_sync_high_loop ; 2 cycle if true, 1 if false + + ret + +short_sync: + ; short sync: 2uS low (48 cycles @ 24Mhz), 30uS high + cbi PORTD, SYNC_PIN ; sync goes low (0v) ; 2 cycle + + ldi r18, 16 ; 1 cycle + short_sync_low_loop: ; requires 3 cpu cycles + dec r18 ; 1 cycle + brne long_sync_low_loop ; 2 cycle if true, 1 if false + + sbi PORTD, SYNC_PIN ; sync goes high (0.3v) + + ldi r18, 120 ; 1 cycle + short_sync_high_loop: ; requires 6 cpu cycles + nop ; 1 cycle + nop ; 1 cycle + nop ; 1 cycle + dec r18 ; 1 cycle + brne short_sync_high_loop ; 2 cycle if true, 1 if false + + ret \ No newline at end of file