Myth: The 6502 Cannot Single Cycle!

แชร์
ฝัง
  • เผยแพร่เมื่อ 17 ม.ค. 2025

ความคิดเห็น • 135

  • @AndersNielsenAA
    @AndersNielsenAA  6 หลายเดือนก่อน +8

    Thanks for watching! You can get the kits here: www.imania.dk/index.php?currency=EUR&cPath=204&sort=5a&language=en
    Come hang out in the Retrocomputing Hackerspace Clubhouse on Discord! discord.com/invite/kmhbxAjQc3

  • @francoisleveille409
    @francoisleveille409 6 หลายเดือนก่อน +28

    I tried to debunk so many myths like that on various Commodore forums and was pelted with insults. I was even expelled from Lemon64. Making videos like yours requires lots of efforts and I didn't have the energy and time.

    • @AureliusR
      @AureliusR 6 หลายเดือนก่อน +3

      If you were banned from Lemon64 it wasn't because you were just trying to debunk myths. As long as you showed evidence and stayed civil then you wouldn't have been banned.

    • @francoisleveille409
      @francoisleveille409 6 หลายเดือนก่อน +5

      ​@@AureliusR I can give you a copy of no less than 500 posts Groepaz left there that were directed at me that were all personal attacks including questioning my mental health. Everyone has their limits.
      What you say is patently false. He was an acquaintance of TNT and that is the only reason it ended the way it did.
      In any case it resulted in me selling more than 200k$ worth of merchandise that according to him should not have worked and caused damage to C64. All false.
      Added edit :
      The document titled 'The C64 PLA Dissected' by Thomas 'Skoe' Giesel proved everything I said was true and all the disparage from Groepaz was lies.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +5

      It requires quite a bit more effort than most believe - and a lot of love for the subject and patience with externalities :)
      Constructive dialogue is great - if people aren’t nice it’s easy to disregard :)

    • @francoisleveille409
      @francoisleveille409 6 หลายเดือนก่อน

      @@AndersNielsenAA Groepaz became very offensive with me around 2008 when I indicated ST's M27C512-90B6 PROM chip (only 1$ US at Mouser back then) had a low slew rate on output and therefore did not generate the glitches other 27(C)512 would cause when used as a PLA replacement for the C64.
      He was involved with Individual Computers' SuperPLA V3 which sold for about 30 Euros so this would have been a significant loss of market.
      I had proof from logic analyzers from the university where I was studying but couldn't take the results out. Eventually the genuine Super Zaxxon cartridge became the litmus test. The ST chips were discontinued in 2011 and would have saved huge sums to C64 users.
      See video from MindFlareRetro :
      #10 'The PLAin Truth About the Commodore 64 PLA' at World of Commodore 2017

    • @francoisleveille409
      @francoisleveille409 6 หลายเดือนก่อน

      @@AndersNielsenAA Groepaz became very offensive with me around 2008 when I indicated ST's M27C512-90B6 PROM chip (only 1$ US at Mouser back then) had a low slew rate on output and therefore did not generate the glitches other 27(C)512 would cause when used as a PLA replacement for the C64.
      He was involved with Individual Computers' SuperPLA V3 which sold for about 30 Euros so this would have been a significant loss of market.
      I had proof from logic analyzers from the university where I was studying but couldn't take the results out. Eventually the genuine Super Zaxxon cartridge became the litmus test. The ST chips were discontinued in 2011 and would have saved huge sums to C64 users.
      See video from MindFlareRetro :
      #10 'The PLAin Truth About the Commodore 64 PLA' at World of Commodore 2017

  • @blarghblargh
    @blarghblargh 6 หลายเดือนก่อน +10

    ohhhh cool! I heard this information about the registers losing data with no clock refresh, and was a bit disappointed. I am interested in running a real 6502 as a hardware unit test and source of truth against an emulator I want to make, so this information should be pretty useful.

    • @williammentink
      @williammentink 6 หลายเดือนก่อน +2

      That's the trick here, that the clock never stops.

  • @BEdmonson85
    @BEdmonson85 5 หลายเดือนก่อน +1

    This was a great watch, here's my comment for the algorithm gods! This channel needs more subscribers!

  • @LordPhobos6502
    @LordPhobos6502 5 หลายเดือนก่อน

    Glad to see this video :)
    Many years ago, I wanted to try a homebrew but wanting to play with single/manual clocking, I ended up getting a 65c816 (the 16 bit version of the 6502)
    Never even tried it with the original.

    • @AndersNielsenAA
      @AndersNielsenAA  5 หลายเดือนก่อน

      It seems it’s still underestimated. The NMOS might actually be able to run slow too.. more testing needed

  • @benjaminshropshire2900
    @benjaminshropshire2900 6 หลายเดือนก่อน +3

    It would be a bit more complex, but I'd think it should be possible to adapt that concept to make a break point debugger as well. E.g. feed all the relevant pins into a RAM chip's address-in pins and use one of the data-out pins as break signal. (Thought at that point, just using another CPU to track things might be easier and cheaper.)

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      Gotta admit - at that point my hands would be tingling to grab the modern 16bit logic analyzer :) …but no break points though

    • @benjaminshropshire2900
      @benjaminshropshire2900 6 หลายเดือนก่อน

      I'm sure there's better options, but I'd be itching to see how much can be done without specialized tools. ("We did it with the wrong tools, as a joke")

  • @johncloar1692
    @johncloar1692 6 หลายเดือนก่อน +2

    Nice project, looks like a lot of fun. Thanks for the video.

  • @weirdboyjim
    @weirdboyjim 6 หลายเดือนก่อน +6

    Interesting, I didn't know that about the early 6502's.

    • @skmgeek
      @skmgeek 6 หลายเดือนก่อน

      james sharman spotted!

    • @weirdboyjim
      @weirdboyjim 6 หลายเดือนก่อน +2

      @@skmgeek Shh, nobody would ever guess I watch retro electronics videos.

    • @jesset2550
      @jesset2550 6 หลายเดือนก่อน

      Lol

  • @jxtq27
    @jxtq27 6 หลายเดือนก่อน +10

    Oh, you mean single step not single cycle. Now I understand.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +5

      Well - both, hence the instruction/cycle switch :) But I know what you mean - titles are hard..

    • @jxtq27
      @jxtq27 5 หลายเดือนก่อน +6

      @@AndersNielsenAA yes there are two hard problems in computer science, cache invalidation, naming, and off-by-one errors.

    • @AndersNielsenAA
      @AndersNielsenAA  5 หลายเดือนก่อน +4

      @@jxtq27 Not the 0th time I’ve heard that one ;-)

  • @phill6859
    @phill6859 6 หลายเดือนก่อน +1

    I never realised that people thought you could not do it. Several 80s computers from the 80s used the rdy line to stall the CPU when the graphics chip needed cycles (even when the ram ran twice the speed of the CPU and the graphics chip, with each getting access alternately). Even the Atari 2600 6507 has a rdy pin, but single stepping it will cause the screen to fall apart.

    • @R.B.
      @R.B. 5 หลายเดือนก่อน +1

      The issue is that the registers need a clock to keep refreshing their state. The way you would typically stop a CPU and make it single step would be to stop the clock signal. This is how it was handled later when it was a static register. The board here doesn't stop the clock signal, it instead latches the signals which allow the CPU to fetch instructions. It's still getting clocked and still refreshing the register states, but it is waiting for the bus to be free to read, hence a single step.

  • @phils_arcade
    @phils_arcade 6 หลายเดือนก่อน +5

    This is very interesting, love how simple the final board looks. Can you single step Z80 range of processors as well?

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +4

      Thanks - I think the Z80 has static registers and doesn't mind stopping the clock. I guess technically you could use this circuit just for debouncing and hook it up to the clock - but less would do :)

    • @phils_arcade
      @phils_arcade 6 หลายเดือนก่อน +1

      @@AndersNielsenAA Thanks for that. I'd be looking to use this for stepping through old Z80 and 6502 arcade PCBs to see what makes them tick. Before the likes of custom chips were a thing.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      @@phils_arcade In that case you would probably need a bit more work for the Z80 in circuit since you would have to manually do all the steps.
      But maybe you get some inspiration on how to make that happen on a breadboard from this :)

    • @blahblahblahblah2933
      @blahblahblahblah2933 6 หลายเดือนก่อน +4

      Z80 has an M1 pin that signals when the CPU is fetching an instruction so plenty of designs are around that single step it.

    • @MrWaalkman
      @MrWaalkman 6 หลายเดือนก่อน +1

      The E&L MT-80Z "The Fox" trainer has a single-step setup built in. Which works just fine.

  • @tigheklory
    @tigheklory 6 หลายเดือนก่อน +1

    This is fun, it would be cool if you used segmented displays for the output!

  • @NorthWay_no
    @NorthWay_no 6 หลายเดือนก่อน +2

    Slightly confused here; didn't both the Ataris and the C= 64 have special pins to let the gfx chip halt the cpu? Was that working different from what you described here?

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +5

      Absolutely - they used the RDY pin to slow down execution just like the description in the 6500 datasheets. My point here is the 65C02 is often credited as the only chip you can use on a breadboard and step one instruction forward at a time - but actually the NMOS 6502 has the RDY pin for exactly that purpose and has no limits as to how long you can pause between instructions if you keep the clock running. ...and then I show how to do it :)

  • @marcuswilliams3455
    @marcuswilliams3455 4 หลายเดือนก่อน

    Thanks, this was a great video. Really, peaked my curiosity. As with the Cycle Board, there are 3 buttons. When this run button is up, is this run at full mode, while pushed is this the debug mode? As per the Cycle/Instr button, when this is pushed down, is this the Single Cycle mode?

    • @AndersNielsenAA
      @AndersNielsenAA  4 หลายเดือนก่อน +1

      When the Run button is pressed RDY is kept high, so the CPU keeps running full speed. The other button toggles whether it stops on every cycle or just when a new opcode is fetched (ignoring operand/data cycles).

  • @Bigmalc0
    @Bigmalc0 3 หลายเดือนก่อน

    An absolutely enjoyable Video on single stepping a old 6502 CPU, I'm repairing a Microtan 65 Full-System built into a 19" Rack, it mostly works but some of the Eprom's don't seam to be getting selected. I'm in England, what would be the postage cost for the ready built stepper. Thanks

    • @AndersNielsenAA
      @AndersNielsenAA  3 หลายเดือนก่อน

      Thank you. I'm sorry to say Brexit has made it impossible for my one man company to send anything to the UK - HMRC requires me to sign up for UK VAT with no exceptions = double accounting in a different country. That means unless I have enough guaranteed volume to justify dealing with HMRC, there's just no way. Some of my products are on eBay UK thanks to their open source nature :)

  • @mitsuruyamada
    @mitsuruyamada 6 หลายเดือนก่อน

    Thanks for the great video! It consists of only two D-FF, so maybe this is the minimum configuration. In my case, I configured it with two JK-FFs and NAND gates. And in my case, when I do a CPU RESET with the CPU stopped, in rare cases the RESET sequence is not performed correctly, so I added a circuit to keep the CPU in RUN state during the RESET period.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      Thank you and thank you for the insight!
      The way the circuit is setup relies heavily on the button’s DPDT nature and makes it harder to control digitally - or just with SPST buttons. A few more logic ICs like you did would certainly make it more versatile and robust.
      The 6502s can differ quite a bit when it comes to the reset - I’ve heard some of the NMOS ones can overheat if held in reset for too long so a short reset pulse is very important too. Luckily I’ve never experienced that with a 6507.
      I appreciate having access to your Perseus schematics very much so I can sanity check a few things while moving forward, thank you 🙏 :)

    • @mitsuruyamada
      @mitsuruyamada 6 หลายเดือนก่อน

      @@AndersNielsenAA Thank you very much. To explain my case in detail, when I powered on the CPU board with the RDY signal at a “L” level and in a stop state, CPU reset, and then proceeded with the step operation, it occurred with a certain probability that the execution address progress was not correct. In this case, I believe that the start vector setting within the CPU is not correct. So, I think this kind of problem does not occur in the case of a configuration where the first state is always RUN state by power-on reset. I had to solve this problem with my PERSEUS-7, because it is assumed that it is often operated in step operation only, not in RUN state at all from power-on. I have made four PERSEUS-7 units and verified the operation with multiple CPUs as well, and confirmed that it is not a defect in only one unit by chance. defect occurred on a Rockwell NMOS R6502A and not on a CMOS R65C02. The R65C02 has a different number of clocks before the first instruction execution and I believe has an improved reset sequence. The additional circuit that solved the defect is R54 in PERSEUS-7 and R4 in PERSEUS-8.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      @@mitsuruyamadaThank you for the details. Since Sync stays low during reset, I wonder if it would be sufficient to ensure “single instruction mode” during reset. I guess that would do the same as keeping it in run state - but of course that means you can’t read the reset vector the CPU reads either way.

    • @mitsuruyamada
      @mitsuruyamada 6 หลายเดือนก่อน

      ​@@AndersNielsenAA Thank you very much. You are right. According to the datasheet, it is sufficient to maintain “single instruction mode” even during RESET. This phenomenon and the countermeasure is based on my personal experiment. I have not been able to reproduce the defect within the conditions and number of times I have re-tested now. Since this circuit allows the same number of dummy steps until the first program instruction for the R6502A and the R65C02, I am going to continue evaluation with this circuit. Thank you again.

  • @tschak909
    @tschak909 5 หลายเดือนก่อน

    The Atari VCS (2600) WSYNC register in the TIA causes the RDY pin to be deserted, until the next scan line. This is CRITICAL for display timing.

    • @AndersNielsenAA
      @AndersNielsenAA  5 หลายเดือนก่อน

      Indeed, and there are no CMOS 6507s out there - that’s still “pretty fast” though, so I guess the myth started because it’s not immediately obvious to everyone that means you can halt it indefinitely and move it forward with a push of a button.
      And it’s also in all the manuals :)

  • @nickolasgaspar9660
    @nickolasgaspar9660 5 หลายเดือนก่อน

    So the 65C02(1981 - found in Atari 8bit XL/XE and some later 800/400 models)essentially has the halting circuit onboard? Since later Atari 800/400 motherboards could accept the 65C02 does that mean that a similar circuit to yours exists on their earlier motherboards?

    • @AndersNielsenAA
      @AndersNielsenAA  5 หลายเดือนก่อน

      No. The 65C02 simply doesn’t mind stopping the clock completely - so you can essentially just use a (debounced) button instead of the input clock.
      Edit: It can still use the circuit though

  • @asadityas67
    @asadityas67 6 หลายเดือนก่อน +1

    Nice design!

  • @bryede
    @bryede 6 หลายเดือนก่อน +1

    4:08 I don't think the C64's 6510 CPU has SYNC capability.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +2

      It doesn't - but you don't need it to single cycle. It works fine with just the RDY pin :)

  • @MCPicoli
    @MCPicoli 6 หลายเดือนก่อน +1

    But what happens if the clock speed gets down to zero hertz (regardless of the circuit shown), specially if using the older versions of the processor? I think part of the myth may still be true - not being able to run if single clock cycles are fed to it. In the video the 6502 still receives the clock at full speed, but execution is "gated" by the RDY pin.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      I did mention it in the video - if the clock gets below about 10 kHz the registers start getting corrupted :)

    • @MCPicoli
      @MCPicoli 6 หลายเดือนก่อน

      @AndersNielsenAA Sorry didn't notice that.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      @@MCPicoli np :) I still don’t have a complete picture of how exactly the registers lose their contents on a silicon level - but I plan to find out :)

    • @gcewing
      @gcewing 6 หลายเดือนก่อน

      @@AndersNielsenAA The register state is held in capacitors, like a dynamic RAM. The charge leaks away and has to be refreshed periodically.

  • @anderskirchenbauer3723
    @anderskirchenbauer3723 6 หลายเดือนก่อน +1

    Guess of what this is a step towards:
    Making a computer that is in a function and form factor similar to an Altair 8080, but using a nice 6502 chip instead of an 8080.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      You are very close :)

    • @TrimeshSZ
      @TrimeshSZ 5 หลายเดือนก่อน

      So, like the Altair 680?

  • @TrimeshSZ
    @TrimeshSZ 6 หลายเดือนก่อน

    Another mildly irritating feature of the original 6502 is that it ignores RDY on write cycles, so if you need to slow writes you have to resort to clock stretching. I guess this made sense at the time, since RAM was faster than the CPU anyway and you normally only had to add waits for ROM reads.

    • @AndersNielsenAA
      @AndersNielsenAA  5 หลายเดือนก่อน

      I think it’s more about the fact that you don’t really need it to pause as you can just latch whatever the 6502 wants to offload to a register pretty easily on the ~W signal if you want to inspect what’s coming out.
      But that’s basically what you said :)

  • @johnrickard8512
    @johnrickard8512 6 หลายเดือนก่อน +8

    So that wasn't exactly an intentional feature, but Woz never really cared what features were intentional when he was looking for them.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +15

      Section 1.4.2.3 of the MCS6500 Hardware Programming Manual shows it was absolutely an intentional feature - and where Woz got it from :)

  • @IainDavies-z2l
    @IainDavies-z2l 6 หลายเดือนก่อน +1

    What shocking news, I had a 6502 on my bike and could never work out why I had to keep peddling. The shop that sold me it said it would certainly cycle, I took it back and he said I must have installed it wrong. It never worked properly and now I know why, so after showing the shop your video I asked for my money back. He said since I bought it over 10 years ago it had probably has failed anyway. So if you can make known to all cycle outlets of your findings, this will help a lot of people.

  • @VandalIO
    @VandalIO 5 หลายเดือนก่อน

    Can this processor run windows?

    • @AndersNielsenAA
      @AndersNielsenAA  5 หลายเดือนก่อน +2

      Sure! Just emulate RISCV in 6502 and emulate x86 in RISCV.. kinda slow tho

    • @AndersNielsenAA
      @AndersNielsenAA  5 หลายเดือนก่อน +1

      Sure! Just emulate RISCV in 6502 and emulate x86 in RISCV.. kinda slow tho

  • @tomwimmenhove4652
    @tomwimmenhove4652 6 หลายเดือนก่อน

    Now try this on a Z80. It uses capacitors as temporary bit-storage elements. If you wait too long, capacitors discharge. That's why it had a minimal clock frequency.
    EDIT: I should've watched the first minute before commenting. Of course the Z80 can also be put in wait state, so there might be a way around it (although, I don't think it has a 'sync' pin)

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน

      I think the Z80 doesn’t mind being clocked at 1Hz but I haven’t dug into it. And I think you’re right it doesn’t have a sync pin 📍

    • @gcewing
      @gcewing 6 หลายเดือนก่อน

      @@AndersNielsenAA It does have an equivalent to SYNC: M1 together with MREQ indicates an opcode fetch cycle.
      There seems to be no minimum clock frequency. From the manual: "When the clock input to the Z80 CPU is stopped at either a High or Low level, the Z80 CPU stops its operation and maintains all registers and control signals."
      So it looks like you can single-cycle a Z80 by either method -- stop the clock, or use WAIT.

  • @keiyakins
    @keiyakins 6 หลายเดือนก่อน

    i mostly just heard to get the cmos version becsuse they're easier to find and interface with modern othrr chips

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน

      Well neither of those actually apply. On the Asian markets it’s super easy to get both - but the CMOS versions are a bit more expensive. Much more if going for a new one.
      Interfacing should be the same except the 90s versions run faster.
      Then there’s also the whole CMOS software incompatibility thing between manufacturers.. and HW incompatibility for the WDC version too

  • @andrewowens5653
    @andrewowens5653 6 หลายเดือนก่อน

    Kim-1 had single step button.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      And somehow people still forgot - it’s also in the original MOS HW Manual :)

    • @andrewowens5653
      @andrewowens5653 6 หลายเดือนก่อน +1

      @@AndersNielsenAA my first computer was a Kim-1. I had to make my own power supply. My second computer was Apple II serial number 000745. I was 15 years old and I worked at The Byte Shop in Englewood Colorado. 8-)

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      @@andrewowens5653 Sounds like some great memories

  • @TheOfAndTo
    @TheOfAndTo 5 หลายเดือนก่อน

    great !!!!

  • @VandalIO
    @VandalIO 6 หลายเดือนก่อน

    Is this true ?

  • @colonthree
    @colonthree 6 หลายเดือนก่อน +5

    "I adore my Commodore Sixtyfour" uwu

  • @paulfalke6227
    @paulfalke6227 วันที่ผ่านมา

    "though the CPU is running at 2MHz, we're successfully halting it after each instruction". The youtube video title is a little clickbait. Your definition of "single cycle" is "run at full speed, but make memory access VERY long". Another definition of "single cycle" is "operate the steps individual". On 8080/Z80 there is a difference between both single cycle definitions. Nice video nevertheless. That you need lots of pullup resistors with CMOS TTL chips is valueable information.

    • @AndersNielsenAA
      @AndersNielsenAA  17 ชั่วโมงที่ผ่านมา

      It's how it's designed to step through instructions. Even the KIM-1 did it this way - and had the switch labelled "single step" :)

  • @KarlFluesse
    @KarlFluesse 4 วันที่ผ่านมา

    However, to achieve it, you need to add a component, so it is not a myth. What can be said is that it is not impossible to accomplish.

    • @AndersNielsenAA
      @AndersNielsenAA  4 วันที่ผ่านมา

      The 6502 doesn’t do anything at all without external help.
      The component isn’t added to make it single cycle - it’s added to control how it does it.
      The feature is there regardless.

    • @KarlFluesse
      @KarlFluesse 4 วันที่ผ่านมา

      ​@@AndersNielsenAA Cool, but isn't it the case that with the newer version, you don't need that extra component to control it? I think that's what is meant. Anyway, thanks for the reply. I'm not claiming that you're wrong; I'm just trying to better understand.

    • @AndersNielsenAA
      @AndersNielsenAA  4 วันที่ผ่านมา

      @ The 80s version can just stop the clock, yes :)

    • @KarlFluesse
      @KarlFluesse 4 วันที่ผ่านมา

      @@AndersNielsenAA Thanks! Old technology, but still as relevant today as it was back then-conceptually speaking.

  • @ArneChristianRosenfeldt
    @ArneChristianRosenfeldt 6 หลายเดือนก่อน +2

    I thought static for a CPU means that it does not rely on race conditions between edges. So you can slowly change the voltage on the clock pin. And as long as your noise amplitude is below the range between high and low, it wouldn’t accidentally go backwards or double step. A lot of flip flops need edges which transit faster than the speed of some logic gates? They store information on the gate capacity?
    10 kHz is really slow and more like dynamic RAM. Again data is stored in a capacitor. Intel had a refresh circuit for this. In 6502 only temporary registers are dynamic. Are we sure that this isn’t really the pre-charge of the bus? It leaks away, and then when a device on the bus fires, no voltage changes.
    So you say that VIC-II in C64 should have used an input buffer to accept early data if the current instruction does not 7 cycles?
    I still don’t get how Atari 8 bit stalled the CPU for individual cycles. Surely, they did not manipulate the core. So they could only keep up the clock high for longer. Is the difference that commodore has a clean rhythm with the clock: 64 always half as slow. Plus4 : faster in the border (separate enable bit for side and bottom border). While Atari comes up with the signal on the fly?

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      I’m not completely sure and you may be right I stretched the comparison between DRAM and SRAM over to registers a bit too far.
      Woz actually ran into the issue with the Apple II - he thought he could keep the clock high while refreshing RAM because it was faster than the spec for a cycle - but he missed that keeping the clock high for a whole cycle at 10kHz is essentially 5kHz.. and he started losing registers.
      He kept swapping to new 6502s because brand new ICs have greater register capacitance than slightly used ones - it worked for a little while..
      I bet he was real happy to switch to CMOS :)

    • @ArneChristianRosenfeldt
      @ArneChristianRosenfeldt 6 หลายเดือนก่อน

      @@AndersNielsenAA so we really talk about the non-temporary registers? So even for NOP the 6502 goes through A X Y SP on instruction load and refreshes a capacitor? I don’t see the metal lines for this. Intel had a register file and a refresh counter just below. And for each cycle (or instruction) this counter would advance. Ah, so on clock low registers live forever?
      To check if real registers are lost we need to keep the clock high for long and sta something with an addressing mode with z or t or SP . Then record the address bus. Then execution the same instruction, but with short high. If Y survived, we now record the correct address . This tests AH and AL .
      Or is it some trick with the instruction pointer? Or ALU input: LDA, CMP, PHA . Slow and fast . Test TAX …
      In a way 6502 is dynamic: it uses a line of inverters to delay the clock to create 4 phases. The clock edge needs to be sharp, not jitter. I don’t think that there is a Schmidt Trigger . I know that Intel and others need two clock pins with non-overlapping phases. I feel like this is mandatory for static operation. So 65C02 has two clock pins? In the end CMOS is mostly great for battery life because at that feature size leakage was zero and energy consumption also while holding a phase. I would like to see a joule thief where the 65c02 uses solar power and reduces it clock at dawn until it stops.
      Just wanted to add: static CMOS must not have an overlap where PNP and NPN both conduct. I guess that 1.1 V core voltage 5 GHz CPUs don’t really care that much. I also wonder how old discrete CMOS avoided this at 12 V max on the rails.
      Scrap that slow clock. Even a CMOS circuit on solar power needs a clean step clock edge and enough energy in an accompanying capacitor to run a full physical cycle ( but not a whole instruction).

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      @@ArneChristianRosenfeldt Neither - in those 1/10.000ths of a second you need to pass both phases.
      I’ve seen NOP running continuously slower than 10kHz without the program counter losing count - but something is out of spec for sure.
      Not completely sure what’s going on at the silicon level - would love a detailed description - but I am guessing it is in some way caps leaking.

    • @ArneChristianRosenfeldt
      @ArneChristianRosenfeldt 6 หลายเดือนก่อน +1

      @@AndersNielsenAA I found that in the NES: The sprite memory in the PPU is DRAM, but its refresh is the same as evaluation.
      Nintendo is explicit about it as Intel. Weird that MOS is not. I should check visual 6502 if the bits use 6 transistors or 1. DRAM needs sense amps and an SRAM buffer. AH AL only serve as buffers. I read that the MOS designers were speed freaks who wanted to squeeze the most MHz out of their ancient fab / large feature size for yield. So with 8 transistors an SRAM bit could be put to the middle between low and high (turn off power) then connect to the bus (phase change), and then power up feedback (delayed phase ). I babbled on in my last comment.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      @@ArneChristianRosenfeldt You’re certainly digging into a deep subject I’ve only scratched the surface of - I guess I should go deep with Visual 6502 some time :)
      I appreciate the thoughts, thanks! 😊

  • @AffidavidDonda
    @AffidavidDonda 6 หลายเดือนก่อน +5

    ldx #0
    lda #0
    ?????
    TXA, man!!!

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +2

      Absolutely! It's been a few years since I wrote that and I wouldn't make the blunder today - but I can't believe I didn't catch it myself while making the video XD

  • @woreno
    @woreno 5 หลายเดือนก่อน

    Why lies? There's two versions

    • @AndersNielsenAA
      @AndersNielsenAA  5 หลายเดือนก่อน

      What lies? BOTH single steps - that’s the whole point :)

  • @gasparinizuzzurro6306
    @gasparinizuzzurro6306 6 หลายเดือนก่อน

    It does not do single cycle. What you achieved is by "help" or external logic. But by itself, the non CMOS version cannot do this. It is the same to achieve BUS arbitration by disconnecting electrically the CPU. the 6502 cannot do this without external logic whereas the 6510 can

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน

      That’s incorrect. All the 6502’s put the data bus into high Z half the cycle - the 6502 and 6510 are the same in that regard. And this actually does let us halt after each CPU cycle.

    • @gasparinizuzzurro6306
      @gasparinizuzzurro6306 6 หลายเดือนก่อน

      @@AndersNielsenAA the 6502 has no tri-state capability. this is proved by the fact that C64 engineer employed a 6510 cpu which is a 6502 with integrated bus tristate capability (AEC signal) plus one memory mapped hw port

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน

      @@gasparinizuzzurro6306 The 6502 databus tristates. The address bus does not. I take advantage of that on my ABN6502 SBC.

    • @gasparinizuzzurro6306
      @gasparinizuzzurro6306 6 หลายเดือนก่อน

      @@AndersNielsenAA so not a full tristate functionality. it always require a custom electronic around it.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน

      @@gasparinizuzzurro6306 Plenty of tristating to single cycle and feed it instructions. You don’t need to tristate the address bus for that.
      The 6502 won’t do anything at all without support circuitry. It’s a CPU. Anything except the most basic address decoding requires more circuitry.
      Doing the same thing on a 65c02 would also require a minimum of an IC to stop the clock in the right state - so you might as well use the same circuit and leave the clock running. And the 6510 is NMOS just like the 6502 so it needs a running clock too.

  • @A3Kr0n
    @A3Kr0n 6 หลายเดือนก่อน +1

    Why bother with a 6502 when the 6809E is SO much better? Quit wasting your time son!

    • @RichardFraser-y9t
      @RichardFraser-y9t 6 หลายเดือนก่อน +4

      Why bother driving a classic car when newer ones exist?

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +5

      Fancy 16 bit registers and everything. No no, I like the budget friendly 6502 ;-)

    • @bryede
      @bryede 6 หลายเดือนก่อน +3

      You could argue that working with any 1970's CPU is just wasting your time, as is whining on videos about them.

    • @AndersNielsenAA
      @AndersNielsenAA  6 หลายเดือนก่อน +1

      @@bryede I think he’s joking 🙃