Keyboard interface software

Sdílet
Vložit
  • čas přidán 20. 08. 2024
  • Support these videos on Patreon: / beneater or eater.net/support for other ways to support.
    ------------------
    Social media:
    Website: www.eater.net
    Twitter: / ben_eater
    Patreon: / beneater
    Reddit: / beneater
    Special thanks to these supporters for making this video possible:
    Aaron Todd, Aleksey Smolenchuk, Alexander Wendland, Andrew C. Young, Anson VanDoren, Anthanasius, anula, Armin Brauns, Asherah Connor, Ben Cochran, Ben Dyson, Ben Kamens, Ben Williams, Benny Olsson, Bill Cooksey, Binh Tran, Bouke Groenescheij, Bradley Pirtle, Bradley Stach, Brent Reusing, Brian T Hoover, Bryan Brickman, Bryan Glezerson, Carlos Ambrozak, Christopher Blackmon, Dale Andrew Darling, Daniel Jeppsson, Daniel Tang, dans, Dave Burley, Dave Walter, David Brown, David Clark, David Cox, David House, David Sastre Medina, David Turner, David Worsham, Dean Winger, Dissy, dko, Dmitry Guyvoronsky, Dušan Dželebdžić, Dzevad Trumic, Emilio Mendoza, Eric Dynowski, Erik Broeders, Eugene Bulkin, George Miroshnykov, Harry McDow, Ian Tait, Ingo Eble, Ivan Sorokin, James Capuder, james schaefer, Jared Dziedzic, Jason DeStefano, Jason Specland, JavaXP, Jaxon Ketterman, Jay Binks, Jayne Gabriele, Jeremy A., Jim Kelly, Jim Knowler, Jim Van Meggelen, Joe Beda, Joe OConnor, Joe Pregracke, Joel Miller, John Fenwick, John Meade, Jon Dugan, Joseph Portaro, Joshua King, Jurģis Brigmanis, Kai Wells, Kefen, Kenneth Christensen, Kent Collins, Kitick, Koreo, Lambda GPU Workstations, Larry, László Bácsi, Lucky Resistor, Lukasz Pacholik, Marcos Fujisawa, Marcus Classon, Mark Day, Martin Roth, Mats Fredriksson, Matt Krueger, Matthäus Pawelczyk, Matthew Duphily, melvin2001, Michael Tedder, Michael Timbrook, Michael Weitman, Miguel Ríos, mikebad, Mikel Lindsaar, Miles Macchiaroli, moi n, Nicholas Counts, Nicholas Moresco, Nick, Not Yet Wise, Örn Arnarson, Paul Pluzhnikov, Paul Randal, Pete Dietl, Phil Dennis, Philip Hofstetter, Phillip Glau, PixelSergey, ProgrammerDor, Randal Masutani, Randy True, raoulvp, Renaldas Zioma, Ric King, Rob Bruno, Robert Comyn, Robert Diaz, Roland Bobek, sam raza, Scott Holmes, Sergey Kruk, SonOfSofaman, Stefan Nesinger, Stefanus Du Toit, Stephen, Stephen Riley, Stephen Smithstone, Steve Jones, Steven Zilberberg, Tayler Porter, TheWebMachine, Thomas Bruggink, Tii, Tom, Tommaso Palmieri, Tyler Latham, Vincent Bernat, Vladimir Solomatin, Walter Montalvo, Warren Miller, Wim Coekaerts, Wraithan McCarroll, xisente, Yee Lam Wan

Komentáře • 736

  • @XDjUanZInHO
    @XDjUanZInHO Před 3 lety +476

    Can we just appreciate that this dude truly made a hello world from true scratch in assembly on an ancient processor and documented it in an easy to follow way for all of us to see and learn with?

    • @chitlitlah
      @chitlitlah Před rokem +12

      That's why we're here; we appreciate it. I did do some machine language programming on some of these old processors including the 6502 in one of my college classes. They plugged into these boards that we used to enter opcodes and values into memory and then we could step it forward and examine the values to see what the processor was doing. (I wish I could remember what those boards were called.) Ben definitely takes it another step though.

    • @ProctorSilex
      @ProctorSilex Před rokem +6

      @@chitlitlah I wish my college had that much. Although we did get some hands on, it was very little and the equipment was not up to the task. Ben's projects are what I had expected computer engineering school to be before facing uncaring reality.

    • @pareshmhatre4019
      @pareshmhatre4019 Před rokem +2

      No!

    • @russianvideovlogguy
      @russianvideovlogguy Před rokem +2

      this is going to be a stupid question, but could you code this in c and then use a compiler that's been specifically designed to output 6502 machine code?

    • @kaitlyn__L
      @kaitlyn__L Před rokem +5

      @@russianvideovlogguy that’s what most people do. And modern compilers are more efficient than human coders 99.9% of the time (not always true even in the 90s). That’s why hand-coding assembly in this day and age is such a madlad endeavour!
      Fun fact: when assemblers were first invented, the computer scientists who learned to keep track of all their memory and instruction addresses by hand viewed _assembly_ as the easy-mode cheat for modern hacks, much as present-day C aficionados view Python!

  • @maxxroach8033
    @maxxroach8033 Před 3 lety +301

    "And that didn't do anything!" I relate to that hahaha

    • @burnstick1380
      @burnstick1380 Před 3 lety +11

      For me it's more like ohh that broke even more

    • @ug333
      @ug333 Před 3 lety +3

      I love that you leave that stuff in. It's so critical to see and understand it's just part of the process

    • @thorin1045
      @thorin1045 Před 3 lety +2

      It is the fun of programming, you wrote your code, checked it, and still something is wrong. And you need to find out what, a missed part of syntax, a wrong label or variable name or just your code wrong.

  • @chrismcghee4867
    @chrismcghee4867 Před 3 lety +172

    Using an 8bit pointer to create an “automatic” circular buffer was brilliant. I kept waiting for a modulus, but no, you one-upped my expectations. Fantastic as always.

    • @musicalfringe
      @musicalfringe Před 3 lety +11

      Same here! I suppose AND would be the way to go with any power-of-two buffer size if you didn't have the luxury of small pointers on your CPU.

    • @johnm2012
      @johnm2012 Před rokem +4

      @@musicalfringe A 128-byte buffer would be almost as easy - the negative flag is set when the pointer reaches 128 so it's easy to detect.

    • @elfreey
      @elfreey Před 5 měsíci

      Except that writep = readp when the buffer is empty and when it's full, the way the program is written. Easy fix, just keep track of the buffer length and only write when length is less than 256 and read when it's greater than 0. That is if you want to read then inc and write then inc.

    • @elfreey
      @elfreey Před 5 měsíci

      Either way Ben's the man

  • @omarhurani
    @omarhurani Před 3 lety +18

    Note, there should be a separate flag for the right and left shifts, because with one flag I could press LSHFT, RSHFT then release RSHFT and it would count as released even though LSHFT is still pressed (and same vise versa)

    • @Jason9637
      @Jason9637 Před 4 měsíci +3

      Pressing and releasing both shifts at the same time would give you a special shift-lock mode

  • @TheStrelok7
    @TheStrelok7 Před 3 lety +259

    I'm studying master in computer engineering and these videos from Ben are the best in the field

    • @wicket4969
      @wicket4969 Před 3 lety +3

      Nice, what’s your thesis on?

    • @arisweedler4703
      @arisweedler4703 Před 3 lety +2

      @@wicket4969 I don't know if you need to write a thesis for a masters in CS. I don't think you do

    • @dr.palsonp.h.d815
      @dr.palsonp.h.d815 Před 3 lety +2

      @@arisweedler4703 yes you do

    • @blablabla7796
      @blablabla7796 Před 3 lety +2

      @@dr.palsonp.h.d815 it depends on which country you’re from. There is no universal regulatory body for Computer Science that I’m aware of.

    • @dr.palsonp.h.d815
      @dr.palsonp.h.d815 Před 3 lety +1

      @@blablabla7796 usually all western masters programs require a thesis, the ones that dont are the exception

  • @ridespirals
    @ridespirals Před 3 lety +153

    that sped-up typing sound at 6:05 sounds so cool

    • @proxy1035
      @proxy1035 Před 3 lety +7

      it sounds like a dying floppy drive

    • @masheroz
      @masheroz Před 3 lety +11

      The keyboard sounds triggers the "[Applause]" in the auto captions.

    • @yousorooo
      @yousorooo Před 3 lety +3

      Keyboard ASMR

    • @ridespirals
      @ridespirals Před 3 lety +1

      @@yousorooo exactly

    • @SnafuDMZ
      @SnafuDMZ Před 3 lety

      Aphex Twin samples

  • @wmhilton-old
    @wmhilton-old Před 3 lety +163

    He threw in the 0x0F bug to appear human, but he's clearly a god 😏. Another amazing video sir!

    • @eduardog3000
      @eduardog3000 Před 3 lety +17

      But for real: it's nice that he keeps in the issues he experiences so we can learn from them and be ready for a bug like that.

    • @IceMetalPunk
      @IceMetalPunk Před 3 lety +10

      The final code still has another bug: pressing both Shift keys at the same time breaks it 😂 When the first is released, letters will go back to lower-case even though you're still pressing the second; and when the second is released, because he's using xor ("eor") to clear the flag, it'll turn shift on permanently until you press and release Shift once again. So... definitely a fallible human 😁

    • @nilswegner2881
      @nilswegner2881 Před 3 lety +2

      @@IceMetalPunk yeah but who presses both shift keys at the same time? That doesn't make much sense

    • @mrlitbottoms6968
      @mrlitbottoms6968 Před 3 lety +13

      @@nilswegner2881 its still a bug that someone could accidentally activate. when your programming u have to not only think of the correct use case but also the incorrect edge case, it is on the edge case that most bugs exist

    • @IceMetalPunk
      @IceMetalPunk Před 3 lety +3

      @@nilswegner2881 I occasionally do just as I tap keys randomly as I fidget. But when designing software, you should *never* assume your users "would never" do something -- always code to cover all your bases.

  • @opendstudio7141
    @opendstudio7141 Před 3 lety +42

    Mercy! I needed to know this back in the late '60s and early '70s. So here we are fifty plus years later as I slip into my second childhood. 😆

  • @DrRChandra
    @DrRChandra Před 3 lety +8

    Typically, an interrupt service routine (ISR) does the minimum possible to deal with the peripheral, and then it returns, and it's up to some other routines to interpret the retrieved data. One thing to remember is that when an interrupt is processed, interrupts are disabled until either they're explicitly enabled or the return from interrupt instruction is executed. Therefore any other interrupts (from other devices) will be blocked, and possibly missed. So the routine to read the keyboard port would just fill the buffer, and any program/subroutine which reads the buffer would do the handling of modifier keys like shift.
    In this case, it really doesn't matter, because there isn't another device competing for CPU cycles via interrupts. But for more complex systems this sort of thing should be kept in mind.

  • @zachdecou
    @zachdecou Před 3 lety +41

    I found your 8 bit build videos probably a year ago and was glued to the screen in a way I didn’t expect. The final videos on conditional jumps and control word logic felt like the climax in an action flick. I soon discovered an alternative purpose for the videos: highly effective sleep aid. I’m not insinuating your videos are boring. Far from it. Rather the tone and cadence of your voice and and the quiet sound of assembling tiny components on a breadboard knock me right out. It’s like magic. I love these videos when I want to be awake, and I love them when I want to be asleep. Someday I’ll order a kit and see if my kid’s attention spans are as as solid as mine. Perhaps I could even lull them into a nap.

    • @kjanovich
      @kjanovich Před 3 lety +1

      No I feel it dude, total same here. Its a great series to both learn from, and relax to.

    • @MDarkus3
      @MDarkus3 Před 3 lety +1

      Thanks to you Ben will start a ASMR series of video ;)

  • @skilz8098
    @skilz8098 Před 3 lety +206

    After following Ben Eater's Videos for several years now, I still don't understand how anyone can "dislike" his videos... for the content that he provides, it is the best that is currently available on the net anywhere... even better than most college or university content that is publicly and freely available... if I could like more than once, I wouldn't hesitate to do so!

    • @vaclavtrpisovsky
      @vaclavtrpisovsky Před 3 lety +16

      Missing the "like" button on a small touchscreen. This just happened to me but I thankfully noticed immediately

    • @Sparkette
      @Sparkette Před 3 lety +9

      I wouldn't be surprised if they were all accidental. Like Václav said, or perhaps some little kid randomly clicking around on CZcams. Any intentional dislikes are probably just trolls.

    • @franchufranchu119
      @franchufranchu119 Před 3 lety +26

      Must be because he's using vim and not emacs

    • @ecosta
      @ecosta Před 3 lety +6

      @@franchufranchu119 Or how he uses VIM. Some VIM users are quite finnicky about using VIM "properly"

    • @Nick-lx4fo
      @Nick-lx4fo Před 3 lety +1

      @@ecosta Or maybe they just don't understand

  • @Wraithan
    @Wraithan Před 3 lety +25

    I recently hooked a 6551 up to my bread boarded 6502, been having a blast with the kit and plan to eventually build my own sound card. Thanks for the videos, been using a circular buffer like this for processing serial input and other interrupt-y situations. A nice generally useful technique for working with input, thanks for showcasing it.

    • @Wraithan
      @Wraithan Před 3 lety

      @Stephen Anthony I happen to have a SY6551, but the WDC65C51 has well known work arounds, so it isn't a deal breaker just a little less performance at the same clock rate.

  • @crispoman
    @crispoman Před 3 lety +300

    May I be the first to congratulate you on accidentally reviving the concept of "Shift-Lock".
    As you're toggling the flag when shift is released but setting it when pressed, pressing both shift keys together and then releasing them will toggle the shift bit back to on. :)
    [Edit: Typo correction]

    • @anschelsc
      @anschelsc Před 3 lety +30

      Yeah, I think to be fully correct you'd have to implement the two shift keys as separate flags.

    • @lightdark00
      @lightdark00 Před 3 lety +5

      Explain your thought process. humans aren't accurate enough for "same time" conditions, one will always be first or polling would cause one to be first.
      My thought is you would lose caps holding both, then still have no caps releasing them both. With even boolean operations, it always returns to the default state.

    • @anschelsc
      @anschelsc Před 3 lety +16

      Depending how you implement it, either holding both shift keys gives you lowercase, or holding both and then letting go of one gives you lowercase, or as in the existing implementation holding both and letting go of both gives you uppercase. I consider all three of these to be incorrect behavior.

    • @jgharston
      @jgharston Před 3 lety +8

      @@anschelsc Or implement ShiftUp as AND #NOT(SHIFT) instead of EOR #SHIFT.

    • @anschelsc
      @anschelsc Před 3 lety +12

      @@jgharston Then when you hold down both shifts, and let one up, you'll be in lowercase even though you're still holding down one of the shift keys.

  • @kuroikenjin7652
    @kuroikenjin7652 Před 3 lety +74

    Good stuff , but that interrupt routine is doing quite a bit. Usually you want to keep interrupts doing a minimal amount of work so the execution gets back to the main loop. Probably for better performance just capture scan codes in the buffer, and then dispatch a key translation when the main loop reads the next key value. For more advanced projects, you can then have context based key mappings.

    • @BertGrink
      @BertGrink Před 3 lety +2

      Good point.

    • @arisweedler4703
      @arisweedler4703 Před 3 lety +15

      You're not complaining, you are pointing out an interesting fact. Thank you for sharing! :)
      One thing that I was thinking of: When he was implementing the shifted keymap, instead of a branch insn, he could have just set the shift flag to be 0x100 and added it to the keymap's address. In both cases this will do a load from 0xfd00 if the shift flag is 0 and load from 0xff00 if the shift flag is 1, so... yeah... this doesn't make it *better*, per se, but the code would be cuter.
      I would like to say, though: indirection at the cost of complexity for efficiency ((when you don't need the added efficiency to function)) is bad. I think Ben rightfully and consistently chooses simplicity over performance, and I praise him for it.

    • @ZeroPlayerGame
      @ZeroPlayerGame Před 3 lety +4

      @@arisweedler4703 it's arguably better-ish because there's less jumping around... but tracking separate shift states for left and right shift would become impossible with that.

    • @willofirony
      @willofirony Před 3 lety +1

      Back in the day, when I was just starting assembly language, I would get anxious, as the number of lines of code kept increasing, that the code I was writing would take an age to execute. After assembling, it usually executed in the blink of an eye. One reason is that much of the code is skipped. When I write "usually", I mean when there are no loops. Loops in an interrupt routine can be a real problem.

    • @BertGrink
      @BertGrink Před 3 lety +2

      @@willofirony Loops in general can be problematic; I remember that when I started looking into some PHP coding, I had a section that would take a very long time to show results, and upon closer inspection I was able to track it down to a couple of nested loops. The solution was to reverse the order of nesting, i.e. the inner loop became the outer one and vice versa. This blew my mind, so to speak.

  • @jordy15322
    @jordy15322 Před 3 lety +59

    I literally swear i've learn't more information about lower level computing from this channel than I did across my whole compsci degree. Great video as always ben!

    • @jgharston
      @jgharston Před 3 lety +8

      CompSci != CompEng.

    • @jordy15322
      @jordy15322 Před 3 lety +8

      @@jgharston Yeah I get that and know the difference... But in my opinion understanding of lower level functionality of a computer helps re-enforce knowledge and understanding within higher level computing. did a little comp enginnering stuff on my degree but it was taught so half assed it was useless.
      Fun fact: I've regretted since the begining of my second year not choosing a computer engineering degree but was too late by that point.

    • @jgharston
      @jgharston Před 3 lety +1

      @@jordy15322 Yeah, me too exactly. I was three years into my CompSci degree and still thinking "when are we going to get to some, y'know *actual* computing?" It was years after that I realised I should have looked for something with "engineering" in the course title. It was only in my very final semester that I put together hardware interfaces for controlling a set of LEDs and a printer, and wrote a PDP11 assembler - both of which I just did a brain-dump of stuff I'd done more than six years previously.

    • @chiblast100x
      @chiblast100x Před 3 lety +1

      @@jordy15322 I can't speak to now, but depending where one went to school a couple decades back it was practically assured one would get a CE minor pursuing a CS major (and vice versa) at the BS level, and putting in two extra years one could graduate with a BS in each CS, CE and Math

    • @dr.palsonp.h.d815
      @dr.palsonp.h.d815 Před 3 lety

      @@jordy15322 Computer Science is arguable much harder than Computer Eng, stick to it, its worth much more than being able to write assembly

  • @misi67
    @misi67 Před 3 lety +21

    It's more than 30 years ago, I've learned writing code for the 6502. But it's still amazing and I love your series about this small computer.

    • @topilinkala1594
      @topilinkala1594 Před rokem

      Let's see, C64 came out in 80's, so to me it's about 40 years.

  • @ModernTimesYT
    @ModernTimesYT Před 3 lety +9

    Some day in the future, I will look back at these videos and understand every single line of code.

    • @RedwoodRhiadra
      @RedwoodRhiadra Před 3 lety +1

      If you follow along all the videos from the beginning, it shouldn't be too hard. Almost everything he did here was introduced and explained in a previous video.

  • @stenzenneznets
    @stenzenneznets Před 3 lety +27

    Thank you Ben, now you should use this and the "worst" graphic card, to print some text on the monitor! :)

    • @tekvax01
      @tekvax01 Před 3 lety +9

      give him time... I'm sure that's next! He's building a word processor from scratch! :P

    • @JoshHeidenreich
      @JoshHeidenreich Před 3 lety +3

      It'll be self hosting soon

    • @nikkiofthevalley
      @nikkiofthevalley Před 3 lety

      Problem is, he would need some kind of font handler and a graphics driver aswell, which sounds like it would be a pain and a half to program in Assembly.

  • @GreeNBluE1988
    @GreeNBluE1988 Před 3 lety +9

    ahh man you open my mind to hole new level. programming for 10 years and I just realize how small I know things. good work

  • @qpn6ph9q
    @qpn6ph9q Před 3 lety +7

    I love these videos. Working at this level of simplicity in 8bits is extremely satisfying because everything just makes sense on the surface, without need for too many abstractions.

  • @mattsains
    @mattsains Před 3 lety +24

    I’m amazed by how much footage there is on this channel of you removing the eeprom from the programmer and putting it back on the breadboard

    • @JoshHeidenreich
      @JoshHeidenreich Před 3 lety

      Does he reuse the same clip each time...?

    • @mattsains
      @mattsains Před 3 lety +1

      @@JoshHeidenreich I was wondering that but I think it’s different each time. Either that or very well edited

    • @paulevans9307
      @paulevans9307 Před 3 lety +3

      EEPROM installation supercut, anyone?

  • @alexisraels1437
    @alexisraels1437 Před 3 lety +5

    I don't understand how anyone, let alone 16 people could dislike a Ben Eater video. This is better than anything I learned in university when getting my CpE degree. Thank you Ben for all that you do.

  • @AdolphusOfBlood
    @AdolphusOfBlood Před 3 lety +5

    i like how this started as building a System and now it's turning into a system programming set of videos for the most part.

  • @blizzy78
    @blizzy78 Před 3 lety +159

    Ben posts, I like.

    • @loneranger4282
      @loneranger4282 Před 3 lety

      1st comment, nice
      Also, r u a patreon bec u got access to the video before it was public lmao

    • @thatMatthew
      @thatMatthew Před 3 lety +2

      I was rewatching his older videos and I was like "hey how have I not seen that one yet"
      20 mins ago
      oh, that's how
      OH WAIT

    • @blizzy78
      @blizzy78 Před 3 lety

      @@loneranger4282 Yes I am.

    • @ilyadaemon
      @ilyadaemon Před 3 lety

      like then watch :)

  • @bamboopyanda
    @bamboopyanda Před 3 lety +26

    Just been following along with your 6502 Computer videos. I can tell that lots of effort goes into these videos, thanks for the great content, and keep up the good work!

    • @MikeSims70
      @MikeSims70 Před 3 lety +2

      I wholeheartedly concur with this concise and accurate statement, ☺

  • @squ1dd13
    @squ1dd13 Před 3 lety +2

    I love the way the captions hear the keyboard sound as applause. It makes it look like he’s giving an inspiring speech about handling keypresses.

  • @sjair6526
    @sjair6526 Před 6 měsíci

    I love how he kinda skipped right over needing to replace the quotations with apostrophe's on line 50 of the shifted key matrix. Took me a minute to figure out what was going on. I should have realized something was different right away when my line turned 3 different colors. Absolutely great video! I actually like that it doesn't just work right away every time. I feel like I learn more when I have to troubleshoot crazy problems.

  • @DrewNorthup
    @DrewNorthup Před 3 lety +5

    Having actually (re-)written a keyboard driver / scancode translator I appreciate this.
    In case anybody is wondering why a different map for upper case, well just look at an actual ASCII table and compare that to the scancode table. He'd need at least another ten minutes to explain the mapping shift, so fodder for later.

  • @mina86
    @mina86 Před 3 lety +3

    The sei and cli aren’t actually necessary. kb_ptr is only modified outside of the interrupt handler so it doesn’t need to be in critical section and kb_wptr is read atomically (since it’s a single byte) so the read doesn’t need a critical section either.

  • @davethedaemon9024
    @davethedaemon9024 Před 3 lety +2

    I did stuff like this (circular buffers) with a 6800 back in 1979. Thanks for inspiring me to get back into hardware again. I bought your 6502 kits, but it wasn't enough. I upgraded to a 65C816 running at 8Mhz. It now has 1Mb ram and 96K of eeprom and an NHD-0440WH 40 x 4 display. I finally figured out how to get a PCF8584 working so I have I2C to a DS3231 for date/time and more I2C peripherals in the pipeline. I can't seem to get my AM9511A-4 (FPU) working and I'm about to give up and look into alternatives. Thanks again.

  • @azwsd
    @azwsd Před 3 lety +530

    2090 Building an A.I. that can simulate the human mind from scratch.

    • @Hiphopasaurus
      @Hiphopasaurus Před 3 lety +70

      On a 6502 of course

    • @realdragon
      @realdragon Před 3 lety +12

      3450: Programming GTA X on 6502

    • @brammie155
      @brammie155 Před 3 lety +5

      @@realdragon ez for this god of a man

    • @yuvalbechar5429
      @yuvalbechar5429 Před 3 lety +6

      seems like a content worth to wait for

    • @mased-v2j
      @mased-v2j Před 3 lety +2

      That he will offload his consciousness to.

  • @cmyk8964
    @cmyk8964 Před 3 lety

    Your mention of a keyboard buffer explained to me why frozen Windows programs sometimes spring back into action processing all the keystrokes you entered while it was frozen.

  • @baurdt
    @baurdt Před 3 lety +1

    OMG, this popped up as possible interest to me and I watched this to the end as it brought back memories to my life in the mid 70s to 80s. I was watching the assembler instructions and surprising to me, I was recognizing all the 6502 instruction set you typed in. Thanks for the memories ...

  • @pseydtonne
    @pseydtonne Před 3 lety +2

    This is an amazing training session for 6502 assembly! I didn't think I could follow this, but I got it all the way. Thank you!
    I'm tempted to type up the code so I can learn from the mimicry. This would be like typing the Basic programs from a 1980s magazine.

    • @markanderson2904
      @markanderson2904 Před 8 měsíci

      Or it would be like Mozart copying Bach in order to study/learn.

  • @AzureLazuline
    @AzureLazuline Před 3 lety +1

    There's something magical about seeing the letters appear on the tiny screen as you type them!

  • @Sidewinder_mj
    @Sidewinder_mj Před 3 lety +31

    "Writing code with a keyboard to make a keyboard work, now
    Thats thight!"
    :)

    • @sly1024
      @sly1024 Před 3 lety +5

      You know that many code compilers are written in their own language? A C++ compiler is written in C++ (just the previous version), obviously the first one had to be written in another language (assembly) though..

    • @ScienceDiscoverer
      @ScienceDiscoverer Před 3 lety +6

      @@sly1024 And think about how first assembly was written? In binary!

    • @josugambee3701
      @josugambee3701 Před 3 lety +1

      @@ScienceDiscoverer Actually, the first assembler was present in the very first core memory module installed in an electronic computer. Nobody knows how it got there.

  • @garydunken7934
    @garydunken7934 Před 3 lety +3

    Awesome as always. You editing skills are at another level too. I can understand amount of effort put into make this video. Much appreciated Ben.

  • @brickmasterg7366
    @brickmasterg7366 Před rokem

    This video tied it all nicely. As I'm tying this comment out, I'm imagining the little transistors in all of the circuits flipping on and off like crazy. Your videos really make it easier to understand than when I was in school. My teachers were great, but maybe my Interest then wasn't as great as it is now. So, thank you!

  • @aritzh
    @aritzh Před 3 lety +5

    Hi Ben, love your videos!
    In the handling of the release of the shift keys, you used "eor", which would flip the bit. This means that if the following key sequence happened, the shift flag would stay enabled with no shift key being pressed:
    - Press left shift (sets the shift flag)
    - Press right shift (does nothing, since the flag is already set)
    - Release one shift (clears the shift flag)
    - Release the other shift (sets the shift flag, because of the XOR)
    Maybe the only way to solve this case is to handle each shift key in its own flag?

    • @JoeldaSilvaVicenteFilho
      @JoeldaSilvaVicenteFilho Před 3 lety +1

      or instead of flipping the flag, set it to the actual value

    • @aritzh
      @aritzh Před 3 lety +1

      @@JoeldaSilvaVicenteFilho however this would mean that after releasing the first shift key, but keeping the other pressed, the letters would be written in lowercase

    • @mrseanbob
      @mrseanbob Před 3 lety

      I came looking for this same comment. I think you’d need a separate flag for each shift key.

    • @JoeldaSilvaVicenteFilho
      @JoeldaSilvaVicenteFilho Před 3 lety

      @@aritzh true

    • @mrmimeisfunny
      @mrmimeisfunny Před 3 lety

      Or yknow, do it properly
      lda kb_flags
      and #~SHIFT ;vasm allows that. I checked.
      sta kb_flags
      I cringed when he did "eor" because that is asking for bugs. Though I didn't spot that specific one.

  • @mrlithium69
    @mrlithium69 Před 3 lety +1

    the most amazing part about this is how you typed the keymap scan code table from scratch so quickly.
    I thought it was fast enough as random jibberish. until it actually worked! - and then my mind was blown.

    • @RedwoodRhiadra
      @RedwoodRhiadra Před 3 lety

      He's not really doing it from scratch - he's got a copy of what he needs to type offscreen and is reading that while he types. Plus the video is sped up there, which hides any delays as he looks back and forth between the screen and his offscreen copy.

    • @normanstevens4924
      @normanstevens4924 Před rokem

      @@RedwoodRhiadra Isn't it just traversing the keyboard with a particular zig zag pattern, i.e. start with a key on the bottom row, then the key slightly to the left on the next row, followed by the key on the third row just to the right of that one and the key on the fourth row to the left of that. Repeat for each column of keys.

    • @RedwoodRhiadra
      @RedwoodRhiadra Před rokem

      @@normanstevens4924 It's been a while since I looked at the video, but I don't think it's that simple.

  • @nemomenth
    @nemomenth Před 3 lety

    This series really reinforces to me how creative and inventive early computer people had to be to make all this work. You take things like the keyboard just plug and play and off you go but never really think about how much is happening behind the scenes just to type some characters.
    PS. Thank you for making these videos!!

  • @richardbenes9
    @richardbenes9 Před 3 lety +2

    Very nice video.
    Regarding the shift key handling, I do think that handling two keys with only one flag might cause a little glitch: if you press both shift keys, and then release only one of them, software will behave as if you did not hold the latter; it will print non-capitalised letters.
    It's allways fun trying to find any "errors" in the work presented; however one can only be grateful for this opportunity, thanks to your great work!

  • @BertGrink
    @BertGrink Před 3 lety +4

    Holy Moly! This is really cool! Even though I speak Z80 Assembler natively, I'm slowly beginning to understand 6502 coding. Big thanks to Ben. 😁

    • @MrTridac
      @MrTridac Před 3 lety +3

      I'm switching back and forth between Z80 and 6502, and it always feels like switching between C++ and BASIC. Luckily I love both. (except BASIC, I don't love that)

  • @marred2277
    @marred2277 Před 3 lety +4

    the 65c02 has phx, phy, plx, and ply opcodes btw :) (4:32)

  • @robandsharonseddon-smith5216

    6502 assembler is SO much more relaxing when someone else is writing it... Excellent series. Thank you.

  • @stuntbum
    @stuntbum Před 3 lety +1

    Very grateful for all your work Mr. Eater. QMK Finally just made sense in just 20 minutes. Thanks! I'm looking forward to starting kits 1-4!! Shout out from TX

  • @graemezimmer604
    @graemezimmer604 Před 3 lety

    Wonderful!
    This takes me back to 1983 when I bought an Apple II and a copy of the ORCA/M assembler.
    Thanks Ben.

  • @deepakmistry5907
    @deepakmistry5907 Před 3 lety +1

    If there were massive destruction of this earth, this is the only guy who can make computers from scratch! Following you since last 6 years. Huge #respect

  • @wallyhall
    @wallyhall Před 3 lety +6

    Plot twist: he’s already got vim running on his breadboard.

  • @theDomCorporation
    @theDomCorporation Před 3 lety +4

    This is so cool!! Ben has reached the "Hello, world!" stage now :D

  • @UlfFormynder
    @UlfFormynder Před 3 lety

    These videos have been instrumental in helping me understand and appreciate how the very basics of computers work. I can't wait to see more.

  • @TheDanEfranChannel
    @TheDanEfranChannel Před 3 lety +1

    This is a great example of just how efficient assembly language can be. Each feature is implemented in just a handful of instructions. Each instruction is just a few bytes. I didn’t count, but the key map probably takes up more memory than all the rest of the code.

    • @squirlmy
      @squirlmy Před 3 lety

      maybe it's because of growing up with 6502 computers and peeks and pokes, but I'm not so impressed with assembly efficiency. That's literally what it's made to be for, a step above hexadecimal(which is almost always only used for reverse-engineering, not coding!) I guess if your first programming language was something like Python, or even Perl, you'd be impressed with assembler.

    • @TheDanEfranChannel
      @TheDanEfranChannel Před 3 lety

      @@squirlmy Oh, I grew up with 6502 programming too, mostly BASIC and assembly. Certainly comparing to an interpreted language accentuates this sense that assembly is efficient; a modern compiled language is more on par with assembly in practice. I just like how what we call "lines of code" and perhaps envision as sophisticated control structures with a lot of machinery behind them...can often be expressed in machine language as just a handful of bytes that perform very simple state changes in the processor. It's neat.

  • @hierandel8
    @hierandel8 Před 3 lety

    I was just recommended this channel, and how happy I am! Watching you gradually add function to your interface was extremely satisfying and calming. Thanks for the great content!

  • @louwrentius
    @louwrentius Před 3 lety +31

    Awesome Ben! I am curious how you will expand this project from here.

    • @mceajc
      @mceajc Před 3 lety +6

      I hope the graphics interface will make another appearance, and replace the LCD screen - then there will be the opportunity for a mouse-controlled cursor. I'm surprised that a dot-matrix printer has not (yet) made an appearance as an essential output peripheral!

    • @lightdark00
      @lightdark00 Před 3 lety

      A mouse to move the curser on the screen!

    • @josephc8482
      @josephc8482 Před 3 lety +2

      I'm wondering if he will attempt to make a simple game like hangman on the lcd. Just to show everything coming together and interacting.
      That said, in his patreon, he did hint that he wants to do another video comparing the PS/2 interface with USB, but the 6502 is too slow for USB, so it will be a stand-alone demo rather than a 6502 breadboard project.

    • @genjii931
      @genjii931 Před 3 lety

      Serial communications, storage, and graphics ability would be the most likely candidates, I would think. Mouse, not so much. Mice didn't come into common usage until the 16-bit GUI days, and this computer is pretty far from that at this point.

  • @JiffyJames85
    @JiffyJames85 Před 3 lety

    Quite possibly the most involved "Hello, World" application I have ever seen in my 27 years of programming.

  • @diezam
    @diezam Před 3 lety +1

    May 2031: today in the breadboard computer, ray tracing video adapter with dual 8K displays

  • @jorgeferreira6727
    @jorgeferreira6727 Před 2 lety +1

    Hi!
    First of all, "Great Videos", its always nice to remember the basics and the importance of some "minor" details.
    As for this specific video, I think your ISR is being overloaded. I would suggest a minimal ISR just to stuff the bytes in the FIFO buffer, and move all the processing/decoding to the main program body. The usual rule of thumb is to keep an ISR as short and fast as possible.

  • @jgurtz
    @jgurtz Před 3 lety

    This series is just fantastic. I know just some basic x86 asm but it's close enough I can go along here. Thank you!

  • @hecker688
    @hecker688 Před 3 lety +12

    People who are disliking Ben Eater's awesome videos are school professors

    • @MarkBurrell1964
      @MarkBurrell1964 Před 3 lety

      I sincerely hope you are wrong there, but who knows. For what it's worth I taught degree / masters level computer architecture for years and even wrote a book on computer architecture.... And Ben Eater is teaching me stuff! Thanks Ben, I'm having a brilliant time playing with hardware again and coding 6502 for the first time in 30 years.

  • @VanillaEngineer
    @VanillaEngineer Před 3 lety +7

    Let me like before watching. I have the guarantee that I will never be disappointed by Ben.

  • @anirvinkandarpa5544
    @anirvinkandarpa5544 Před 10 měsíci

    Sir, thanks for all these videos. you are a real hero for me. thanks a lot

  • @arjunyg4655
    @arjunyg4655 Před 3 lety +2

    I appreciate that he’s using the Model M to type the code to run the Model M 😆
    I can’t wait to go back to the office where I have desk space to use mine again.

  • @ameturephysicist
    @ameturephysicist Před 3 lety +4

    Instead of using a different keymap for shift you could just set the fifth bit to 0. That will make any letter uppercase. You would have to handle numbers and special character differently, but it would take less memory.

    • @sdspivey
      @sdspivey Před 3 lety

      That only handles 26 keys, out of ~90. That doesn't sound like it would save memory or time.

    • @ameturephysicist
      @ameturephysicist Před 3 lety

      26 bytes can be a lot, especially when you're programming an embedded system. The 6502 can handle a relatively huge amount of ram at 64k, but it's still a good idea to save all the memory you can, since it will add up.

    • @topilinkala1594
      @topilinkala1594 Před rokem

      Caps lock and shift are totally two different things.

  • @louisferreira9055
    @louisferreira9055 Před 3 lety

    Hi Ben, you added all this new hardware to detect and create a clean IRQ pulse when you didn't have too.... you already had the hardware in place with the 6522. All you needed to do was use the Timer 2 in "Pulse Counting mode", and voila! Just set it up to count down 11 pulses applied to PB6 and it automatically fires the IRQ output when it reached zero. Then read in the data from your shift register into PortB, and you're good. You'll just need to add more code to check the IFR to see what generated the interupt. Would be a good way to show how to handle multiple interupts anyway. Keep up the good work man!

  • @AlexanderPetrossian
    @AlexanderPetrossian Před 2 lety

    Thanks, Ben, for this fantastic material.
    Vim has a Ctrl+N shortcut to autocomplete a word. Extremely useful.

  • @vikiai4241
    @vikiai4241 Před 3 lety

    Lovely. Thanks! It brings back memories of learning some very simple assembly on my C64 when I was in my teens (a time almost beyond living memory now!). While I'd never want to go back to passing carries around for multi-byte arithmetic, I do miss most other aspects of the simplicity of 6502 assembly!

  • @clonkex
    @clonkex Před 3 lety +1

    4:06 The sped-up typing is insanely satisfying

  • @CirclesandSounds
    @CirclesandSounds Před 10 měsíci

    You remind me so much of John Carmack! Your voice, inflections, and brilliance. ❤

  • @Yotanido
    @Yotanido Před 3 lety +3

    In visual mode: gU to uppercase everything selected ;)
    Granted, that doesn't help with the numbers and symbols, but hey - that's 26 characters you didn't need to replace :P

    • @diab303
      @diab303 Před 3 lety

      or simply press ~ and wait for repeats :)

  • @darkstatehk
    @darkstatehk Před 3 lety

    Watching this series has taught me how to write and understand basic assembly language, which is so cool! Thank you Ben!

  • @typedef_
    @typedef_ Před 3 lety +1

    This is more assembly programming than computer architecture, but still fun to watch.

  • @catalinbadalan4463
    @catalinbadalan4463 Před 3 lety

    15 Java programmers have had their keyboard buffers overflown.

  • @CompuSAR
    @CompuSAR Před 3 lety +1

    I love your channel, and I love what you do with the hardware. I think your software is a little basic, however. Someone already mentioned not differentiating between the shifts, thus losing state. A few others:
    - You disable interrupts. The algorithm you use, however, is a wait-free algorithm. It works even if interrupted.
    - If the interrupt handler takes too long, the next key-code might arrive. If that happens, the code might drop it. It would have been better to store the raw key-codes in the buffer, and do the decoding outside the interrupt handler.
    - This would also obviate the need for a "key down" state. If the code is "key down", just immediately fall through to fetching the next key (when it's available) and ignoring it.
    - Instead of parsing the keyboard's state every time, parse it when it changes, and store it in the Y register. You can then use the indirect+Y addressing mode to fetch the actual translated code, and simplify the code fetch.
    To reiterate: I _love_ what you're doing here. This are fairly minor nitpicks on how you can make things even greater.

  • @ProctorSilex
    @ProctorSilex Před rokem

    I had the displeasure of working on a legacy system that abused a circular buffer.
    Every time I hear the term, I have to repeat to myself: "Circular buffers are not inherently evil."

  • @NicolasGasnier
    @NicolasGasnier Před 3 lety

    You have that ability to make things appears so simple. It's great !

  • @AlanCanon2222
    @AlanCanon2222 Před 3 lety

    On old PCs, I remember that, on POST, you could fill up the keyboard buffer, and the PC would then reject any keystroke, and often beep. The size of the buffer was not large. The number 12 comes to mind (I tested it a few times over the years out of boredom / curiosity).

  • @mohamedkoblawi4175
    @mohamedkoblawi4175 Před rokem

    I can't explain why this is so captivating

  • @aliceitc8380
    @aliceitc8380 Před 3 lety +3

    wonderful as always!

  • @stupossibleify
    @stupossibleify Před 3 lety +2

    I had been waiting with bated breath for this video :)

  • @pv2b
    @pv2b Před 3 lety

    2:40 What a lovely sound of those buckling springs in that IBM Model M(?) as you're typing. :-)

  • @KaletheQuick
    @KaletheQuick Před 3 lety +1

    20 minutes?
    Too short. I didnt even finish my drink and a snack!

  • @Romanujan
    @Romanujan Před 3 lety +1

    1. You do not need SEI / CLI in the 'loop:' - this wastes 2 bytes. Wrtiting to kb_wptr in the interrupt is an atomic operation, we do not have to stop the interrupt for that.
    2. Shouldn't the interrupt handler preserve the processor status register (PHP/PLP)?
    3. The 'kb_flags' should store flags in bits 6 and 7. This way you could use BIT instruction together with BMI and BVS to check the flags, there would be no need for AND.
    4. The 'JMP push_key' probably wastes 1 byte; if none of the codes translates to 0, than it would be shorter to write 'BNE push_key' instead.
    5. What exactly CPU do you have? If this is a 65C02 (not a pure 6502) you have instructions like BRA, STZ, PHX, PLX, and possibly SMB, RMB, BBR, BBS - they would make you code significantly shorter.

    • @dr.palsonp.h.d815
      @dr.palsonp.h.d815 Před 3 lety +1

      wow, very informed comment

    • @thek3743
      @thek3743 Před 3 lety

      Nice optimizations, but not the point here. This is targeted at beginners. The easier the better. Less commands are good.

  • @senceryazici
    @senceryazici Před 3 lety +1

    Awesome!! I think you’ll need one of those 4 line LCD displays, cuz a “Vim on 6502” is on the way I can sense that :D

  • @hyperion2858
    @hyperion2858 Před 3 lety +3

    One of the few channels where I leave a like before watching because I know I‘ll enjoy the video, and this way I won‘t forget to like xD

  • @LambertZero
    @LambertZero Před 2 lety +1

    19:35 "You can come up with your own designs..."
    ... and end up with a commodore 64

  • @omgwtfkthxbai
    @omgwtfkthxbai Před 3 lety

    Always enjoy watching your videos! Brings back fond memories of my college days! :)

  • @musicalfringe
    @musicalfringe Před 3 lety

    This is pretty much exactly the design I came up with for a keyboard driver for a DOS Lightcycles game I wrote in C in the '90s.

  • @rjk0128
    @rjk0128 Před 3 lety

    Super helpful animations within the vid, loved it!

  • @KJohansson
    @KJohansson Před 3 lety

    This is so useful! I am about to build a PS2 interface to my Atari ST, with a ATmega CPU, but still.. All the workings and concepts are here. Thanks!

    • @squirlmy
      @squirlmy Před 3 lety

      Are you aware of Soarer's Converter? or all the TMK-based projects? github.com/tmk/tmk_keyboard/wiki/TMK-Based-Projects ? I wasn't sure at first if your the Atari ST has the ATmega, because your converter could also use an ATmega. It would be funny if your keyboard is more powerful than the CPU!

  • @Quesbe
    @Quesbe Před 3 lety

    Ben is the person that convinced me to learn 6502 assembly -- I love it!
    (unlike amd64 assembly. it's awful and ridiculously too complex for my brain. congrats to those who wrote the first compilers for this architecture)

  • @spacetoast4874
    @spacetoast4874 Před 3 lety +1

    Ben you got me back into retro tech and now my house is so full of it I can’t walk! It’s a hazard now! The city is gonna condemn my house Ben!

  • @SteeleDynamics
    @SteeleDynamics Před 3 lety

    Always great, Ben! Can't wait to pick up a kit of my own!

  • @ayushgaurav3984
    @ayushgaurav3984 Před 2 lety

    I am gonna binge watch all his videos today.

  • @kidsforcode3052
    @kidsforcode3052 Před 3 lety

    I wish I knew the key map by heart and could type it that fast! So educational, as usual!

  • @frostie8802
    @frostie8802 Před 3 lety

    i love your content, it is so fun to watch

  • @sportsracer48
    @sportsracer48 Před 3 lety

    >Press left shift
    >Press right shift
    >Release left shift
    >Type lowercase letters with right shift held down

  • @nicksenske662
    @nicksenske662 Před 3 lety

    A 6502 computer, a vga graphics card, and now a keyboard interface. He’s on a crash course to play doom from scratch

    • @squirlmy
      @squirlmy Před 3 lety

      Doom was the first popular game that could be played over LANs, so networking hardware could be on such a project!

  • @GoldenretriverYT
    @GoldenretriverYT Před 3 lety

    i am just waiting for 2025, when you puts everything together and writes an operating system for the computer in pure assembly

  • @TerabyteForever
    @TerabyteForever Před 3 lety

    You are gonna make me buy parts and start making hobby electronics. Appreciated.

  • @dmitrymarukh6857
    @dmitrymarukh6857 Před 3 lety +2

    Why on Earth would you do all that scan code processing in the interrupt and not in the main loop? Or, better yet, in separate read key block. You certainly have enough buffer space to delay the processing until it is appropriate