forked from amberisvibin/chibi-pc09
		
	Compare commits
	
		
			4 Commits
		
	
	
		
			677b3cb02d
			...
			stack
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| cc8a9fc95f | |||
| a0427ad949 | |||
| 0845370c43 | |||
| 347b6fa236 | 
| @@ -1,31 +1,35 @@ | |||||||
| # Boot Firmware for CHIBI PC-09 | # Boot Firmware for CHIBI PC-09 | ||||||
|  |  | ||||||
| TODO: Description of what the firmware does for the PC-09. | This is the firmware for the CHIBI PC-09. In the future it will provide the | ||||||
|  | CHIBI with initialization code, a UART driver, some self test features. | ||||||
|  |  | ||||||
| ## Building the Firmware | ## Building the Firmware | ||||||
|  |  | ||||||
| You will need GNU `make`, and [`asm6809`](https://www.6809.org.uk/asm6809) to | Building the firmware from source requires [LWTOOLS](http://www.lwtools.ca/) for | ||||||
| build the firmware. Obtaining a working copy of `asm6809` could be difficult if | building S-Records of the ROM, and `mot2bin` from | ||||||
| you aren't on Debian, Ubuntu, or Windows as instructions for building it are not | [F9DASM](https://github.com/Arakula/f9dasm) for building binary images. A GNU | ||||||
| given on the `asm6809` website. Functional instructions for building from Git or | Make makefile is provided for building on Linux. | ||||||
| tarball are given here: |  | ||||||
|  | ### Using the Makefile | ||||||
|  |  | ||||||
|  | To generate an S-Record run: | ||||||
|  |  | ||||||
| ```sh | ```sh | ||||||
| git clone https://www.6809.org.uk/git/asm6809.git | make boot.s19 | ||||||
| cd asm6809 |  | ||||||
| ./configure |  | ||||||
| make |  | ||||||
| sudo make install |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| From there all you should have to do to generate a `boot.bin` is: | To generate a binary run: | ||||||
|  |  | ||||||
| ```sh | ```sh | ||||||
| git clone https://github.com/amberisvibin/chibi-pc09.git |  | ||||||
| cd chibi-pc09/code/boot |  | ||||||
| make | make | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | The makefile also can clean up after itself: | ||||||
|  |  | ||||||
|  | ```sh | ||||||
|  | make clean | ||||||
|  | ``` | ||||||
|  |  | ||||||
| ## Firmware Licensing | ## Firmware Licensing | ||||||
|  |  | ||||||
| This firmware like the rest of the CHIBI PC-09 is licensed under the MIT | This firmware like the rest of the CHIBI PC-09 is licensed under the MIT | ||||||
|   | |||||||
| @@ -9,6 +9,7 @@ | |||||||
| # ------------------------------------------------------------------------------ | # ------------------------------------------------------------------------------ | ||||||
|  |  | ||||||
| TARGET   := boot | TARGET   := boot | ||||||
|  | TARGREC  := $(TARGET).s19 | ||||||
| TARGROM  := $(TARGET).bin | TARGROM  := $(TARGET).bin | ||||||
| SRCDIR   := src/ | SRCDIR   := src/ | ||||||
| BUILDDIR := build/ | BUILDDIR := build/ | ||||||
| @@ -34,11 +35,11 @@ LDFLAGS := -f srec -m map.txt -s linkscript | |||||||
| all: $(TARGROM) | all: $(TARGROM) | ||||||
|  |  | ||||||
| # Fix srec into flashable bin file | # Fix srec into flashable bin file | ||||||
| $(TARGROM): $(TARGET).s19 | $(TARGROM): $(TARGREC) | ||||||
| 	$(FIX) -out $@ $< | 	$(FIX) -out $@ $< | ||||||
|  |  | ||||||
| # Link objects | # Link objects | ||||||
| $(TARGET).s19: $(OBJS) | $(TARGREC): $(OBJS) | ||||||
| 	$(LD) $(LDFLAGS) -o $@ $^ | 	$(LD) $(LDFLAGS) -o $@ $^ | ||||||
|  |  | ||||||
| # Assemble objects | # Assemble objects | ||||||
| @@ -46,7 +47,6 @@ $(OBJS): $(BUILDDIR)%.o : $(SRCDIR)%.s | |||||||
| 	-@mkdir -p $(BUILDDIR) | 	-@mkdir -p $(BUILDDIR) | ||||||
| 	$(AS) $(ASFLAGS) -o $@ $< | 	$(AS) $(ASFLAGS) -o $@ $< | ||||||
|  |  | ||||||
| .IGNORE: clean |  | ||||||
| clean: | clean: | ||||||
| 	@echo 'Cleaning up intermediary files...' | 	@echo 'Cleaning up intermediary files...' | ||||||
| 	@rm -rv $(TARGROM) $(TARGET).s19 $(BUILDDIR) | 	@rm -rv $(TARGROM) $(TARGREC) map.txt $(BUILDDIR) | ||||||
|   | |||||||
| @@ -15,6 +15,16 @@ UART_BASE EQU $7F00 ; UART Base Address | |||||||
| ROM_BASE  EQU $8000 ; ROM Base Address and Entry Point | ROM_BASE  EQU $8000 ; ROM Base Address and Entry Point | ||||||
| VECS_BASE EQU $FFF0 ; Vectors Base Address | VECS_BASE EQU $FFF0 ; Vectors Base Address | ||||||
|  |  | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  | ;; | ||||||
|  | ;; Stack Base Address and Size Information | ||||||
|  | ;; | ||||||
|  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
|  |  | ||||||
|  | STACK_BOTTOM EQU $0100 ; Bottom address of system stack | ||||||
|  | STACK_DEPTH  EQU $FF   ; System stack's depth | ||||||
|  | STACK_TOP    EQU STACK_BOTTOM+STACK_DEPTH ; Top address of system stack | ||||||
|  |  | ||||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||||||
| ;; | ;; | ||||||
| ;; UART Registers and Flags | ;; UART Registers and Flags | ||||||
|   | |||||||
| @@ -16,6 +16,19 @@ | |||||||
|   EXPORT RESET |   EXPORT RESET | ||||||
|  |  | ||||||
| RESET | RESET | ||||||
|  |  | ||||||
|  | CLRSTACK | ||||||
|  |   ; Initialize the system stack | ||||||
|  |   lda #$00           ; Initialize A & X to zero out the stack | ||||||
|  |   ldx #$0000 | ||||||
|  | NEXT@ | ||||||
|  |   sta STACK_BOTTOM,x ; Write a zero and progress to the next byte | ||||||
|  |   leax 1,x | ||||||
|  |   cmpx #STACK_DEPTH  ; See if we're at the top of the stack yet | ||||||
|  |   blo NEXT@          ; Loop if we aren't at the end yet | ||||||
|  |   lds STACK_TOP      ; Set S to top of newly cleared stack | ||||||
|  |  | ||||||
|  | SERINIT | ||||||
|   ; 8n1 Serial Enable DLAB |   ; 8n1 Serial Enable DLAB | ||||||
|   lda #UARTF_LCR_WLS|UARTF_LCR_DLAB |   lda #UARTF_LCR_WLS|UARTF_LCR_DLAB | ||||||
|   sta UART_LCR |   sta UART_LCR | ||||||
| @@ -29,7 +42,8 @@ RESET | |||||||
|   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 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user