forked from amberisvibin/chibi-pc09
		
	Compare commits
	
		
			6 Commits
		
	
	
		
			hardware.i
			...
			d2c5118ba2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d2c5118ba2 | |||
| a642e05c2c | |||
| 9edc255412 | |||
| 971dc1d719 | |||
| 1237cc89eb | |||
|   | 808f868344 | 
| @@ -10,37 +10,101 @@ | |||||||
| ;; | ;; | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  |   SECTION "Reset" | ||||||
|   ORG ROM_BASE |   ORG ROM_BASE | ||||||
|  |  | ||||||
| RESET | RESET | ||||||
|   lda #%11000001 ; 8n1 serial, enable DLAB |   ; 8n1 Serial Enable DLAB | ||||||
|  |   lda #(UARTF_LCR_WLS | UARTF_LCR_DLAB) | ||||||
|   sta UART_LCR |   sta UART_LCR | ||||||
|  |  | ||||||
|   lda #$00       ; Set divisor to 12 (9600 baud) |   ; REVIEW: Potential endianness hiccough here | ||||||
|   sta UART_DLL |   ldd #$0C00           ; Set divisor to 12 (9600 baud) | ||||||
|   lda #$0C |  | ||||||
|   sta UART_DLM |   sta UART_DLM | ||||||
|  |   stb UART_DLL | ||||||
|  |  | ||||||
|   lda #%11000000 ; 8n1 serial, disable DLAB |   lda #(UARTF_LCR_WLS) ; 8n1 serial, disable DLAB | ||||||
|   sta UART_LCR |   sta UART_LCR | ||||||
|  |  | ||||||
|   lda #%01000000 ; Enable RTS |   lda #(UARTF_MCR_RTS) ; Enable Request-to-Send | ||||||
|   sta UART_MCR |   sta UART_MCR | ||||||
|  |  | ||||||
|   lda 'H         ; send 'H' |   lda 'H               ; send 'H' | ||||||
|   sta UART_BUFR |   sta UART_BUFR | ||||||
|  |  | ||||||
| WAIT | WAIT | ||||||
|   sync           ; Wait for interrupts |   sync                 ; Wait for interrupts | ||||||
|   nop |   nop | ||||||
|   bra WAIT |   bra WAIT | ||||||
|  |  | ||||||
|  |   SECTION "Serial" | ||||||
|  |  | ||||||
|  | ; Writes a char to the UART in non FIFO mode, preserves A. | ||||||
|  | ; @param b: char to write | ||||||
|  | OUTCHAR | ||||||
|  |   pshs a               ; Preserve A | ||||||
|  | 1 | ||||||
|  |   lda UART_LSR         ; if LSR.THRE == 1 then write | ||||||
|  |   anda UARTF_LSR_THRE | ||||||
|  |   bne 1B               ; Loop if UART not ready yet | ||||||
|  |   stb UART_BUFR        ; Write char | ||||||
|  |   puls a               ; Restore A | ||||||
|  |   rts | ||||||
|  |  | ||||||
|  | ; Writes a null terminated string to the UART in non FIFO mode, clobbers A and | ||||||
|  | ; B. | ||||||
|  | ; @param x: null terminated string start address. | ||||||
|  | OUTSTR | ||||||
|  |   ldb x                ; Get the next value from X | ||||||
|  |   cmpb #$00            ; Make sure that mother is non-null | ||||||
|  |   beq 2F | ||||||
|  |   leax 1,x             ; Increment X for our next char | ||||||
|  | 1                      ; Loop point for UART waiting | ||||||
|  |   lda UART_LSR         ; Wait for UART to be ready | ||||||
|  |   anda UARTF_LSR_THRE | ||||||
|  |   bne 1B | ||||||
|  |   stb UART_BUFR        ; Actually do our write | ||||||
|  |   bra OUTSTR           ; Reset for the next char | ||||||
|  | 2                      ; Jump point for end of routine | ||||||
|  |   rts | ||||||
|  |  | ||||||
|  |   SECTION "Memtest" | ||||||
|  |  | ||||||
|  | ; RAM testing routine. Ported to 6809 from 6800, based on source for ROBIT-2 for | ||||||
|  | ; MIKBUG. | ||||||
|  | RAMTEST | ||||||
|  |   ldx #SRAM_BASE | ||||||
|  | 1                      ; Store 1 in memory | ||||||
|  |   lda #1               ; Set [X] to 1 | ||||||
|  |   sta 0,x | ||||||
|  |   cmpa 0,x             ; If failed print out an error indicator | ||||||
|  |   bne 3F | ||||||
|  | 2                      ; Loop point for next address | ||||||
|  |   asla                 ; Shift A and [X] left | ||||||
|  |   asl 0,x | ||||||
|  |   cmpa 0,x             ; Compare A and [X] | ||||||
|  |   bne 3F | ||||||
|  |   cmpa #$80            ; Only test up to $80 | ||||||
|  |   bne 2B               ; Loop if not $80 | ||||||
|  |   cmpx #$60FF          ; Compare X to end of RAM | ||||||
|  |   beq 4F               ; Finish if we're at the end | ||||||
|  |   leax 1,x             ; Increment X | ||||||
|  |   bra 1B | ||||||
|  | 3                      ; Write out error indicator | ||||||
|  |   ldb #'X | ||||||
|  |   jsr OUTCHAR | ||||||
|  | 4                      ; Pass test | ||||||
|  |   ldb #'P | ||||||
|  |   jsr OUTCHAR | ||||||
|  |   rts | ||||||
|  |  | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
| ;; | ;; | ||||||
| ;; Interrupt and Reset Vectors | ;; Interrupt and Reset Vectors | ||||||
| ;; | ;; | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  |   SECTION "Vectors" | ||||||
|   ORG VECS_BASE |   ORG VECS_BASE | ||||||
|  |  | ||||||
| VECTORS | VECTORS | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user