Settings

Theme

Show HN: 1.5kb Microkernel for Ben Eater's 6502 Computer

github.com

230 points by jroesner 6 years ago · 36 comments

Reader

Diederich 6 years ago

I'm actually more excited to see a new Ben Eater video on youtube than anything else.

His stuff is just fantastic. Even though it's lower level than I've ever worked, it's extremely entertaining and educational.

His 6502 series is just great, but I want to highlight another couple of videos he did:

"Let's build a circuit that displays an image on a VGA monitor! In this video, I talk about how VGA signals work and build a circuit that provides the correct timing of sync signals so that a monitor recognizes the signal."

https://www.youtube.com/watch?v=l7rce6IQDWs

  • ravedave5 6 years ago

    His video series was very enlightening. Seeing absolute lowest level how that stuff is done is a wonderful insight into why stuff is the way it is today.

  • aidos 6 years ago

    Thanks for posting. That‘s wonderful.

kazinator 6 years ago

Skimming through this, this is the first piece of code that my eyes drilled into more deeply:

  LCD__clear_video_ram:
    pha                                         ; preserve A via stack
    tya                                         ; same for Y
    pha
    ldy #$20                                    ; set index to 32
  .loop:
    lda #$20                                    ; set character to 'space'
    sta VIDEO_RAM,Y                             ; clean video ram
    dey                                         ; decrease index
    bne .loop                                   ; are we   done? no, repea
    sta VIDEO_RAM                               ; yes, write zero'th location manually
    pla                                         ; restore Y
    tay
    pla                                         ; restore A
    rts
Surely we don't need to keep loading the space character into A on every iteration?

Since Y starts at a hard-coded value that is (well) below $80, this could use "bpl .loop" and drop the "sta VIDEO_RAM" special case.

In .select_option, I'd looking into doing a jump table. Ideas here: https://wiki.nesdev.com/w/index.php/Jump_table

  • jroesnerOP 6 years ago

    You are more than right. This is just my first assembly project in 20 years, put together from scratch in a couple of days. Therefor I am more than greatful for every constructive hint, that helps me improve. Thanks!

    • Someone 6 years ago

      You probably know, but it also would help readability and portability if you created separate constants SPACE and SCREENSIZE (or similar)

      Also, if you want to go for idiomatic 6502 code, rather than readability:

      - you want to optimize for size and speed by looping down from C to zero (rather than looping up from zero to C) where possible (because you don’t need to do a CMP to compare with zero)

      - LCD__print wastes memory and CPU cycles. It can fall-through to LCD__print_with_offset, and that could fall-through to LCD_render,

    • zellyn 6 years ago

      Get qkumba or John Brooks on the Apple2Infinitum Slack interested, and you're likely to suddenly get a whole lot more optimized :-)

  • that_jojo 6 years ago

    I've been writing to 65816 lately, so it may be that they're extended mode instructions. But does the 6502 not have PHX and PHY?

    • jroesnerOP 6 years ago

      The 65C02 does (as well as AFAIK the 6510) if one compiles VASM with the according flags. Ben decided not to do so, neither did I for the feeling of good old times. Why make it easy ;)

      • jimsmart 6 years ago

        The 6510 is what’s in the C64 - PHX and PHY definitely aren’t supported there (source: I was programmer on multiple published games, back in the day).

        The NES is similar family too, and doesn’t have those opcodes - but the Atari Lynx has them (being 65C02).

magicalhippo 6 years ago

Semi-related, I've been enjoying Robert Baruch's videos[1] on creating a FPGA implementation of the 6800, using nMigen and formal verification. First videos are almost like live coding, then he skips to a more compact format.

As a regular programmer, it's quite interesting to get into how the bits actually end up getting the work done.

[1]: https://www.youtube.com/watch?v=85ZCTuekjGA&list=PLEeZWGE3Pw...

Teknoman117 6 years ago

Watching Ben Eater's videos renewed my interest in making some simple computers out of old hardware, mainly because the older hardware is simple enough that you can work with it on a breadboard.

The interest eventually morphed into doing something with all of the old parts I've hoarded. Going through the bins of parts, I've found things like 8051 microcontrollers (P80C550) and UARTs (AM85C30) and some old RTC units (MC146818). I ended up picking up a few 68010's (among other things) off of eBay with the hope of building a breadboard Linux computer, as slow as that may be. I believe the 68010 may be the only CPU in a DIP package still supported in some capacity by Linux (as long as you provide an MMU).

Hopefully this will actually get me back into writing/making videos about my projects.

that_jojo 6 years ago

I love, love, love Ben's videos, and this is an awesome project.

But to be as painfully pedantic as possible: can we please use the word 'monitor', here? Calling it a 'microkernel' really gives one the wrong initial impression.

Still, very neat. Now write a BASIC!

nategri 6 years ago

Learning about multiple wonderful things at once here. This is pretty much catnip for 6502 fans.

danaur 6 years ago

Are there any good resources for learning electronics for someone with a strong programming background and understand digital logic? Ben Eater videos assume knowledge of electronics and would like to know more

miohtama 6 years ago

This reminds me of C64 tape loaders or "turboa" that need to load the program to RAM.

https://www.atarimagazines.com/compute/issue57/turbotape.htm...

Also let's not forget Bill Gates's 17 bytes loader

https://hackaday.com/2017/03/24/doing-it-with-fewer-bytes-th...

kevstev 6 years ago

Nice! my 6502 kit arrived today! And there is snow in the forecast this weekend- Really looking forward to building this.

jcmeyrignac 6 years ago

I just read your source code a bit, and there are a lot of things wrong. First, you should ALWAYS clear the carry when using ADC or set the carry when using SBC

For example: .increase: adc #1 sta POSITION_MENU

I have no idea if you increment or add two, since the carry is not cleared.

    clc
     lda CURRENT_RAM_ADDRESS_L
    adc #$01
    sta CURRENT_RAM_ADDRESS_L
    lda CURRENT_RAM_ADDRESS_H
    adc #$00
    sta CURRENT_RAM_ADDRESS_H
this is done by the usual INC CURRENT_RAM_ADDRESS_L BNE *+2 INC CURRENT_RAM_ADDRESS_H

    ldy POSITION_CURSOR
    cpy #0  
cpy #0 is useless.

lda POSITION_CURSOR cmp #0 cmp #0 is useless

jsr / rts can be replaced by jmp

clear_ram is super slow

  • transitorykris 6 years ago

    There's a kinder way to share this. Ben's teaching a number of things here (basic electronics, computer architecture, assembly..) in an incredibly inviting and rewarding way. I'm confident he's reaching people at varying skill levels. Let's keep that energy going.

atum47 6 years ago

great job.

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection