Commodore 64 and 128 TIME: Exploration of TI and TI$

  Рет қаралды 23,254

8-Bit Show And Tell

8-Bit Show And Tell

Күн бұрын

Пікірлер: 140
@jim_64s8-bitprojects5
@jim_64s8-bitprojects5 2 жыл бұрын
Your “extremely unimportant fix” is fascinating! 😉
@DavidYoud
@DavidYoud 2 жыл бұрын
I love these extra-nerdy deep dives! I bet this episode took a long time to make. Thanks!
@timsmith2525
@timsmith2525 2 жыл бұрын
Most excellent! Off By One: The error so common that it earned its own name. I love the one byte fix.
@8bittimes
@8bittimes Жыл бұрын
The 6/5 fix is even more convoluted. If you start with the value 5 from the last call, until the BPL at $f62f actually triggers, you have 6 values: 5,4,3,2,1,0. The BPL at $f62f only falls through on the transition from zero to minus 1. So, I first thought this would be a 7/6 fix - but, as the Jiffy increment is repeated, so is the DEC of the fix counter at f631. I.e. even the fix counter, that has 6 values, is decremented twice in one interrupt. Therefore it indeed is a 6/5 fix for the Jiffies.
@raymondarias5925
@raymondarias5925 2 жыл бұрын
A little historical time trivia: the division of units into 60s came originally from the Sumerians at about 2500 to 2000 BC. Instead of individual digits, they marked units and tens, and then after 5 tens and 9 units (and all these were in the same "place"), there was a great unit, representing 60. There only problem is that there was no 0 as a place holder then, so 1 and 60 looked like exactly the same number! Also, they could subdivide units into 60 pieces, and have a kind of "sexigesimal point," except for one other major problem: you guessed it! no symbol for it. So, a unit on a tablet could represent one, or sixty, or one-sixtieth, or 3600, or 1/3600, etc. lol Anyway, this system was passed on to the Akkadians, the Babylonians, and the Egyptians. It seemed, it was the Egyptians who perfected using sexigesimal units for parts of the 12 hours of the day, which back then were just the duration of daylight each day divided evenly by twelve. Later, the Greeks decided to also account for the hours without daylight and to make all the hours of the full day (more or less) even by dividing the whole thing into 24 hours. AM and PM are designations given to us by the Romans meaning "Before Noon" (Ante Meridian) and "After Noon" (Post Meridian). From there, the 24+ time zones came in the late 19th Century, and now we have atomic clocks that send out time signals on the Internet and beam them to satelites, and GPS that, in part, uses these signals to set their internal clocks by in order to precisely locate every vehicle and device using it.
@markjreed
@markjreed 2 жыл бұрын
Base 12 is convenient because it's evenly divided by 2,3,4, and 6 as well as 12. 60 is the smallest base that adds 5 to the mix. So those were logical choices. And today we have 60 seconds in the minute and 60 minutes in the hour or angular degree. 360 degrees in a circle is a nice round number in base 60 and close to the number of days in the year. A largely unappreciated side effect of the 24-hour day is the order of the days in our week. Originally, the seven Greek "planets" (everything visible to the naked eye that moved against the stars: Saturn, Jupiter, Mars, the Sun, Venus, Mercury, and the Moon) were assigned to hours instead of days. The assignment ran in the above order, from slowest to fastest motion through the night sky. When ancient timekeepers switched from hours to days, they named each day after the planet governing its first hour, and since 24 mod 7 is 3, successive days had names separated by 3 in the above list: the Sun, the Moon, Mars, Mercury, Jupiter, Venus, and Saturn. The associations between the planets and day names are more obvious in the Romance languages; in English, only Sun=Sunday, Moon=Monday, and Saturn=Saturday make sense directly. But that's because Old English timekeepers mapped the Roman gods to their own pantheon instead of adopting the rest of the names directly. So Mars, the Roman god of war, was taken to be Tiw (Norse Tyr), whence Tiw's Day->Tuesday, and likewise down the line: Mercury->Woden(Odin)->Wednesday, Jupiter->Thor->Thursday, and Venus->Frigg(Freya)->Friday.
@CityXen
@CityXen 2 жыл бұрын
Excellent! Had to refresh our memory of TI and TI$ when we did the Smokerdore 64 program so it was a good case of how to use them.
@00Skyfox
@00Skyfox 2 жыл бұрын
Good work! I love how in depth these videos are.
@Commodoreretro-programming
@Commodoreretro-programming 2 жыл бұрын
Jiffies remain jiffies in Europe and North America unlike feet and ounces :) I guess the confusion comes from the difference of CPU frequencies. The CIA will wait freq/60s CPU cycles to perform an IRQ. That's 16,421 (=985,248/60) CPU cycles on a PAL but 17,045 (=1,022,730/60) CPU cycles on an NTSC.
@TheBookaroo
@TheBookaroo 2 жыл бұрын
Hi, love the videos takes me back ;-) Also NTSC is not 60 image per second (actually it's 1 image for the impair lines and one with the pair lines so it's 29.97 complete image per second composed of two half of the image interlaced), it is 59.94 because the color burst was interfering with the audio on old TV when they added colour to the black and white signal they just reduced the images per second to be out of the harmonics of the audio sub carrier. Also timecode to be accurate for each image had to be compensated for by dropping 1 frame every minute except on minute 10, 20, 30, 40 and 50 it's called dropframe timecode and even audio recordings had to have those "drop frames" in their timecode so that they can stay in sync with the video. And even today you still have 59.94 images per second in HD even if it's not a problem anymore for over the air broadcast since it's now in digital form and there are no need for it.
@8_Bit
@8_Bit 2 жыл бұрын
Thanks, yes, the true NTSC spec is as you say. However, most/all 8-bit computers and games consoles were not exactly to spec. They neither ran at exactly 59.94 (or 29.97 depending on how you're counting) Hz, and most did not generate proper odd/even interlacing video either. So I find it's both easier *and* more accurate to just talk about 60 fps video output.
@TheBookaroo
@TheBookaroo 2 жыл бұрын
@@8_Bit Yes exactly, coming from a TV background, those missing frames in the timecode was something to really check for or else for example the commercial brakes were not at the correct time and you saw bumpers coming in out off commercial brakes in the middle of the show and you got commercial brakes in the middle of a sentence... Or the a show of 1 hour was short by 108 frames and you got black on air during that time. And it was easy as flipping a switch on a VTR to be in non-drop frame mode...
@stevethepocket
@stevethepocket 2 жыл бұрын
@@TheBookaroo Ah, the days when commercials interrupting mid-sentence was a bug, not a feature.
@csbruce
@csbruce 2 жыл бұрын
I heard the field rate is exactly 60*1000/1001. Would they really have needed drop frames every so often when they could just play video back a tiny bit slower? kzbin.info/www/bejne/aXithoBspaijm9k
@TheBookaroo
@TheBookaroo 2 жыл бұрын
@@csbruce They actually dropped the frequency from 60 to 59.94 but timecode is a number attached (either in an audio extra track (LTC) or embedded in the vertical interval of an image (VITC)) so to be accurate so that an hour long show it's timecode will also be an hour long, you have to skip the numbering of frames going from 10:01:59:29 for example to 10:02:00:01 skipping 10:02:00:00 to compensate so that the timecode stays in sync with the actual duration.
@freemesy
@freemesy 2 жыл бұрын
It was really interesting to understand all these TI connected things. Thanks for another great video.
@Lion_McLionhead
@Lion_McLionhead 2 жыл бұрын
Remember how hard it was to use a time value in strange fractional second units. Most high level languages have time in milliseconds.
@michaelcarey
@michaelcarey 2 жыл бұрын
Excellent video Robin. Very interesting indeed. Until recently I always thought that TI and TI$ came from the TOD clocks in the CIA chips. Do you know of any software that uses the CIA TOD clocks for timekeeping rather than the KERNAL derived time functions? Do you know how the KERNAL sets the CIA's 50/60Hz flag, how it determines if it's operating in a 50Hz or 60Hz AC area? What about the SX-64 where it has a built in 60Hz oscillator for the CIA chips? Interesting to know your thoughts.
@Rocknrollthor_norway
@Rocknrollthor_norway Ай бұрын
7:46 I think you are right, what else could it be.. Anyways.. nice videos, thanks. I must admit my c128 has been running in 128 mode for only a few minutes all in all since the late 1980's, maybe its time to learn to use the recourses that is there when running in 128 mode. :)
@JohnGames-gz7ue
@JohnGames-gz7ue 2 жыл бұрын
I love how you fixed something that was useless to fix. That’s why I love these videos.
@merman1974
@merman1974 2 жыл бұрын
TI and TI$ are almost a cross between a variable and a function. Vartion? Functable? I remember using TI and TI$ in some of my early BASIC programmes but haven't used them in years. I guess they left that jiffy number the same in the C128 Kernal/BASIC to avoid breaking backwards compatibility. It's amazing how dense and interconnected the BASIC ROM is, with routines calling other routines. I wonder how many jiffies this video lasted?
@SimonQuigley
@SimonQuigley 2 жыл бұрын
How about fartion :-)
@andrewgillham1907
@andrewgillham1907 2 жыл бұрын
Great analysis Robin. I never really thought about how those might have been implemented since they are special. You should make a consolidated list of all your bug fixes. It is super easy to use a patched kernel with an EasyFlash 3. BASIC is slightly harder but still doable without opening up the C64 with the right cartridge. (Or just use emulators of course) At least the Commander X16 ROM could have these bug fixes easily! I would be happy to file issues / pull requests. I’m amateur at best but happy to help.
@8_Bit
@8_Bit 2 жыл бұрын
It'd be a neat idea to make an unofficial "KERNAL V4" ROM that incorporates the best fixes/patches people have come up with. I'd be happy if some of my ideas made it in there, but I don't have full confidence that these patches don't have some side effect I haven't noticed. I'm happiest exploring and raising awareness about these strange quirks and if you and/or others want to pull it together with other contributions into a project that produces an alternate ROM that'd be really cool.
@aresaurelian
@aresaurelian 2 жыл бұрын
☺Love the "remember when" songs. Brilliant production. Thank you.
@tedthrasher9433
@tedthrasher9433 2 жыл бұрын
Really love these deep dive videos!
@Anth369
@Anth369 2 жыл бұрын
Loved the end!
@PeranMe
@PeranMe 2 жыл бұрын
Fantastic work, Robin, super interesting! Excellent video!
@csbruce
@csbruce 2 жыл бұрын
4:10 It's not a dummy parameter on the C128. 5:39 Reading a multi-byte value without protection can give an inconsistent result. Here, you could read a high byte right before it increments and then read the low byte right after it rolls over. It's odd that the jiffy clock is big-endian. 10:00 There's another potential bug here: the IRQ handler doesn't execute a CLD, so if Decimal mode is active in a user program when an interrupt happens, the time comparison with SBC will be done in BCD and will be wrong. Also, SEC : LDA $A2 : SBC #$01 code could be shortened to LDA $A2 : CMP #$01. 11:42 You could avoid the race condition by printing the TI figure first every time. 14:43 Making the number of jiffies per second different between regions would produce a lot of broken BASIC programs. 15:44 C128 BASIC is so sluggish that you pretty much can only use it in FAST mode. 16:13 One minor issue is that the NTSC field rate isn't exactly 60 Hz, while PAL is supposed to be exactly 50 Hz.
@markjreed
@markjreed 2 жыл бұрын
Good point about the FRE() parameter. In C128 mode it refers to the RAM bank, and it's an ILLEGAL QUANTITY to pass anything other than 0 or 1. FRE(0) is space available for the BASIC program, while FRE(1) is space available for variables.
@8_Bit
@8_Bit 2 жыл бұрын
And if I remember correctly, on the B128 (80-column CBM-II machine) the 128K is split up into four 32K banks. FRE(0) returns free code space, while a parameter of 1, 2, or 3 returns free variable space for each different type: string, scalar, or array, or something similar to that.
@csbruce
@csbruce 2 жыл бұрын
@@8_Bit: According to the Anthology (p.43), this corresponds to how the B-series RAM banks were used, though they seem to skip bank 0. Sounds like they fill each of the four RAM banks only half-way for the B128.
@H2Obsession
@H2Obsession Жыл бұрын
POS(x) has a dummy parameter. Even on the C128 where it could conceivably use different values for the 40 and 80 column displays... Even though TI and ST are weird functions, it saves typing and bytes to omit the parentheses...
@csbruce
@csbruce Жыл бұрын
@@H2Obsession: At 4:10, Robin is talking about the FRE(x) function. On the C128, the FRE() parameter is the RAM bank.
@ropersonline
@ropersonline 2 жыл бұрын
2:30: Does defining TI(0)=1 have any bearing on the output of TI or TI$?
@retroCombs
@retroCombs 2 жыл бұрын
Love this, Robin. Interestingly, the MEGA65, which I know is a modern device, includes a battery backed RTC. Wonder how this hardware addition might modify your TI and TI$ (they are reserved for BASIC 65) tips and tricks, if at all.
@markjreed
@markjreed 2 жыл бұрын
On the Mega65's BASIC 10, TI$ and TI are independent variables. TI$ has the current clock time (complete with colons now), while TI is the number of seconds (with fraction) since boot. Neither of them is resettable, either, which makes timing things a little more work.
@sandcat-maurice
@sandcat-maurice 2 жыл бұрын
Thanks for this interesting video! The CBM machines are new to me (grew up with MSX), and with my new MEGA65 I'm now working my way through the C64 User Guide and the C64 Programmers Reference Guide. Can you please explain to me how/where to find the keys corresponding to the graphical characters? Like in your program TIME WRAP, line 1, you have the inverted heart. I know it is CLR HOME after trial and error, but could I have find it somewhere in the manuals?
@8_Bit
@8_Bit 2 жыл бұрын
Hi, congratulations on getting a MEGA65! Yes, all these special symbols are shown in the C64 Programmer's Reference Guide on pages 72-74, when describing the various special Quote Mode, Insert Mode, etc. They're a bit quirky, but also quite powerful and efficient.
@sandcat-maurice
@sandcat-maurice 2 жыл бұрын
@@8_Bit Ahhhhh....yes, I see them now! Thanks a lot!! I was searching for them in the appendix etc. ps, the C64 core for the MEGA65 is amazing, but also the C64 mode ("GO64") in MEGA65/C65 is already quite compatible.
@ropersonline
@ropersonline 2 жыл бұрын
7:19: 5183974 does not equal exactly one second before midnight (5183940). I suspect the discrepancy/delay might be accounted for by the time it takes to interpreted code to run.
@TheUtuber999
@TheUtuber999 Жыл бұрын
14:25 The following will perform an exact one-second time delay on an NTSC or PAL C64 and confirms that there are 60 Jiffies per second on either system: 10 ti$="000000" 20 ifti$"000001"then20 30 printti
@TrollingAround
@TrollingAround 2 жыл бұрын
Question: does copying the basic (and Kernal?) ROMs to RAM increase the speed of BASIC programmes (since RAM is typically faster than ROM) - IBM clones used to mirror (AKA shadow) ROMs to RAM for a speed increase.
@8_Bit
@8_Bit 2 жыл бұрын
On a stock C64, RAM and ROM are the same speed. On my SuperCPU accelerator for the C64 (which is unfortunately quite rare) then the RAM is a lot faster and it does copy/shadow the ROMs into RAM like the IBM clones did.
@mikegarland4500
@mikegarland4500 Жыл бұрын
Brilliant explaining as always. I'm sad this series is over.. now what's next...
@Lofote
@Lofote 2 жыл бұрын
Very nice. And I also love that you finally also show some C128 internals, not just C64 :) I would love to see that much more often... By the way I never understood why they didn't implement a query on the CIAs timers instead, which will work even with interrupts disabled ("SEI" command in Assembler) and is more exact. Very very strange design decision if you ask me. GEOS clock does it right IIRC.
@H2Obsession
@H2Obsession Жыл бұрын
The CIA's TOD clock is specifically designed for accurate time keeping, and should be more accurate than CIA timer. But I don't think there is a PAL CIA, so I don't think the TOD is accurate on PAL. I don't have PAL machine to check...
@Lofote
@Lofote Жыл бұрын
@@H2Obsession the pal version does have the cash going on at 60hz, it is used by goes for example 🙃
@raymondarias5925
@raymondarias5925 2 жыл бұрын
Hey, but did you fix the type of TI$ error where it's assigned a numerical string, but not one that represents a valid time, such as: TI$ = "999999"?
@8_Bit
@8_Bit 2 жыл бұрын
No, that would be a much more elaborate patch and the original authors didn't appear to even attempt that level of error checking. They did seem to want a numeric digit check and as it was easy to implement, I tried it :)
@808v1
@808v1 2 жыл бұрын
dude, your songs are great - little added bonus imho
@awilliams1701
@awilliams1701 2 жыл бұрын
I assumed TI was just a variable with a fixed pointer to a location that is constantly updated and not treated any differently. Also you're the only reason I'm even aware of TI in the first place. When I was a kid I never heard of it. But my programs were always super super super simple.
@markjreed
@markjreed 2 жыл бұрын
If Commodore BASIC supported 24-bit integer values it would make sense to just have TI be a permanent entry in the variable table pointing to the jiffy clock. But it has to be converted to floating-point, which is a pretty expensive operation to be doing 60 times a second, every second. Much more efficient to only do that when the program accesses the variable.
@awilliams1701
@awilliams1701 2 жыл бұрын
@@markjreed makes sense. I always thought of BASIC as this magic box that just works (especially as a kid). I never thought that much about what was in it. Especially now that I use much more modern languages these days.
@c128stuff
@c128stuff 2 жыл бұрын
Oh.. you also have a 'flat' c128!.. I knew about your 128DCR.. nice video again.
@jensschroder8214
@jensschroder8214 2 жыл бұрын
how to quickly calculate in machine language: x2 = shift 1 bit left (1clock cycle only) x3 = shift 1 bit left + add itself ( 2 clock cycle) x4 = shift 2 bit left ( 2 clock cycle) x5 = shift 2 bit left + add itself ( 3 clock cycle) x6 = do x2 and x3 ( 3 clock cycle) x7 = do x2 and x3 + add itself ( 4 clock cycle) x10 = do x5 and x2 ( 4 clock cycle)
@bodan1196
@bodan1196 2 жыл бұрын
I probably missed something, but does the "hack" of looking for _TI_ not preclude using variable names beginning with TI? Meaning that TIMOTHY for example can't be used as a name for a variable?
@8_Bit
@8_Bit 2 жыл бұрын
These Commodore BASICs all have a 2 character limit on variable names anyway, so TIMOTHY gets treated the same as TI; extra letters are just ignored.
@bodan1196
@bodan1196 2 жыл бұрын
@@8_Bit Oh... well, I suppose not having touched a C64 in a... never-mind-how-long time, can excuse me for forgetting that little detail. No? Thx for replying.
@granitepenguin
@granitepenguin 2 жыл бұрын
Loved "Remember When"
@davidt9902
@davidt9902 Жыл бұрын
I will have to dig out my old C64. In the USA you have 60Hz AC, in Australia and UK we have 50Hz AC. When coding split screen on the C64 it was from memory 50Hz to be in sync with the TV otherwise it would not work. Clock speed was also adjusted to be in sync with video refresh. Eg: “6510 CPU is clocked at 1.023 MHz (NTSC) and 0.985 MHz (PAL)”
@headlessmike
@headlessmike 2 жыл бұрын
Fun fact: 1/60th of a second used to be known as thirds, and 1/60th of a third as fourths, etc.
@paulwratt
@paulwratt 3 ай бұрын
I would suggest that the main reason for not fixing that check to be an engineering "option" (a "what if" option). By that I mean it is then easily ptached (as you did) to count RPM (or any other jiffy-ized-able number) instead of 24 Hours, where that MAX value you found then has some significance. As opposed to being a "mistake".
@WillKalman
@WillKalman 2 жыл бұрын
How does the C64 get it's 60Hz clock? I read on the internet that it's from a free-running CIA hardware timer, which reminds me of an AVR328-based clock project of mine that needed a 60Hz clock. I discovered that at the usual 16Mhz, there was no way to get a proper value in the 16-bit hardware timer to get exactly 60Hz so I ran the AVR at 12Mhz where there was a proper division (and I had to re-work the WS2812 assembly to get it to bit-bang at that speed). It makes me wonder if this leap-jiffy "bug" might be covering up for a pretty-darn-close-but-not-quite 60Hz clock - or maybe it just makes it worse ;^) Can any CIA gurus verify the precision of the CIA timer interrupt to give exactly 60Hz?
@ImYourProblem
@ImYourProblem 2 жыл бұрын
It comes directly from the 60hz AC power supply signal.
@WillKalman
@WillKalman 2 жыл бұрын
@@ImYourProblem I've done some reading since my comment and it seems that the jiffy clock comes from a CIA hardware timer and the CIA TOD real-time clock comes from the mains.
@der.Schtefan
@der.Schtefan Жыл бұрын
I think they accepted the 1/60th of a second off time, because if you have a look, it makes the code easier. You can do SBC 01 to force the carry flag to ripple through the other two subtractions, otherwise you'd need to check if the first byte is 00 and branch out manually. Either speed or memory size constraint. Plus, if you think about it: the clock is not from the more stable TV signal oscillator, but the "roughly 60 Hz" timer. That one is most def. far less accurate than 1/60th of a second in a day.
@H2Obsession
@H2Obsession Жыл бұрын
No. The wrap-around code will work just fine if the first constant is zero. Using 1 instead is definitely a bug. However, if you reverse the order of subtraction then the correct first constant would be 1 (because of the way CPU carry flag works. You can test this yourself by copy ROM to RAM and modify like Robin did. I guess maybe they had the order of subtraction reversed at sometime, then reversed the order, but the constant was not updated. Who knows? What is surprising is it wasn't fixed on C128.
@QrzysztofPL
@QrzysztofPL 2 жыл бұрын
I had to turn on my PAL C128 running on 50Hz AC to check if this was true. I was pretty surprised they went with 60Hz timer on all machines. I thought they simply used AC input as source for a clock counter.
@8_Bit
@8_Bit 2 жыл бұрын
Yes, I think there's a lot of uncertainty surrounding this topic; I wasn't sure about several things until I really dug into it for this video. Though now that you mention it, I didn't even talk about the AC input! Or how the system IRQ timer is set in the first place.
@csbruce
@csbruce 2 жыл бұрын
@@8_Bit: Also, the bulk of the C64 ROM content was just copied in a hurry from the VIC-20. The VIC used a timer configured for a 60 Hz IRQ, so that just got copied into the C64.
@markjreed
@markjreed 2 жыл бұрын
@@csbruce Sure, but the VIC-20 also had a PAL version. Weren't those the same other than the VIC chip itself?
@PaulDriverPlus
@PaulDriverPlus 2 жыл бұрын
@@markjreed CPU in the C64 was different too, controlled the bank switching.
@retrozmachine1189
@retrozmachine1189 2 жыл бұрын
The TOD in the CIAs is indeed clocked by the mains frequency in most C64 variants but the CPU interrupt is timer driver. TOD tick is derived from the 9VAC supply. If you want a less drifty time of day read the CIA registers instead of relying on TI etc. There's gotchas such as ensuring the CIA is configured for the mains frequency in your area. This isn't necessarily correct. Apparently different ROM versions didn't work it out properly, and of course you could be using a C64 intended for an NTSC country in a PAL country and vice-versa.
@madmartigan1498
@madmartigan1498 2 жыл бұрын
Is TI$ stored in the RAM? If so, where can I find the address of the bytes?
@ge97aa
@ge97aa 2 жыл бұрын
TI$ is not stored in RAM, but TI is. It is at addresses $00A0..$00A2. It is big-endian, in units of 1/60 seconds. Evaluation of the TI$ variable reads the TI value and converts it to the more human-readable HHMMSS form.
@madmartigan1498
@madmartigan1498 2 жыл бұрын
@@ge97aa Thank you for your answer! But: Which routine(s) does (do) converts $00A0..$A00A2 into TI / TI$ and where can it be found in the RAM?
@ge97aa
@ge97aa 2 жыл бұрын
@@madmartigan1498 As for TI, I'm not sure what you mean by converting $00A0..$00A2 to TI, since for all intents and purposes $00A0..$00A2 **is** TI. You can get this value in an interrupt-safe manner by calling the kernal's RDTIM function at $FFDE. It returns the three bytes in the Y, X, and A registers in order from high to low. As for TI$, this is done by the routine that evaluates a BASIC variable within a BASIC expression. This routine is located at $AF28 in ROM. This routine calls another routine at $BE68 which does the actual work of the numeric conversion (incidentally, this function is also used by the routine that converts a floating point value to a decimal string). The resulting 6-character string is stored in BASIC String RAM at a location chosen by the BASIC interpreter. A 3-byte descriptor for this string is pushed to BASIC's temporary string stack (located at $19..$21) and a pointer to that descriptor is returned in memory locations $64/$65. Additionally, an interim working copy of the string will be found at $00FF..$0104, but this will be overwritten by any subsequent conversion of a numeric value to a string. I'm not sure if you are asking purely for curiosity's sake, but if you're thinking about writing code to use this built-in feature, there are a number of things you must consider. First, the routine at $AF28 starts by reading a variable name from the BASIC command buffer. This means that there MUST be a valid active BASIC command buffer pointer that currently points to the first character of the TI$ variable name. If you simply want to get the TI$ value "on the fly", I suppose you could bypass the command buffer read by instead calling into the routine at $AF48. Remember, though, that this routine is part of the BASIC interpreter, and it expects and requires a fully operational BASIC environment. Additionally, you would need to make sure that you properly deregister the temporary result string from BASIC's string stack by loading the the pointer at $64/$65 into the Y and A registers (low byte in A, high byte in Y) and calling the routine at $B6AA. This will return a pointer to the string data in memory locations $22/$23. This string should be used for your intended purpose before invoking any additional functions in the BASIC interpreter, as there is a good chance that pointer will be overwritten by the interpreter. If you DON'T want to have a full BASIC environment active (e.g. String RAM, Variable RAM, program memory, temporary string stack, garbage collector, etc.), you could just use the conversion routine at $BE68. Here's how you would do it: 1. Call the routine at $AF84 to convert TI to a 32-bit big-endian integer at $0062..$0065. 2. Store the value 0 in memory location $5E. 3. Store the value #$FF in memory location $71. 4. Store the value 6 in memory location $5D. 5. Load the Y register with the value #$24. 6. Call the conversion routine at $BE68. 7. The resulting 6-character string can then be read from memory at $00FF..$0104. Note that this method requires the use of the following memory locations, so you would have to be sure they aren't in use by other parts of your code: $0047, $005D, $005E, $0062..$0065, $0071, $00FF..$0105.
@NuntiusLegis
@NuntiusLegis 2 жыл бұрын
Is there a way for a program to find out whether it runs on a 50 Hz AC or 60 Hz AC machine? Or does it have to ask the user? I am thinking of a program that uses a TOD clock and wants to set that accordingly.
@8_Bit
@8_Bit 2 жыл бұрын
I was looking into this a week or two ago. Some programs just check if they're running on PAL/NTSC and assume 50/60 AC based on that. A large % of the time that is an okay assumption. However it's wrong for some edge cases, such as the SX-64 which has a 60 Hz TOD no matter whether PAL or NTSC as it has an internal 60 Hz crystal generating the signal instead of using AC. A better solution is to start a CIA timer (cycle counter) and set the TOD to 60 Hz and count the cycles it takes for the TOD to reach a certain amount of time (like a 10th of a second or whatever). Then that cycle count can be used to see if the TOD is really running at 60 Hz, or if it's too far out, 50 Hz must be right.
@NuntiusLegis
@NuntiusLegis 2 жыл бұрын
@@8_Bit Great, thank you!
@ge97aa
@ge97aa 2 жыл бұрын
2:23 Here's an obscure little bug. If you move the BASIC memory area to anywhere in the 4kB block between $C000 and $CFFF, then accessing either TI$ or TI with array indices will actually return the system time as if you accessed the TI$ or TI "variables" themselves. For example, PRINT TI$(5) will be treated as the same as PRINT TI$. 13:12 Minor quibble - the way the KERNAL sets the CIA system timer is not quite "independent" of the video display. Rather, the KERNAL must first determine whether the C64 is PAL or NTSC in order to determine the processor speed so that it can set the CIA timer to 60 Hz (and theoretically, in certain very unlikely circumstances, this determination by the KERNAL can be wrong).
@silkwesir1444
@silkwesir1444 2 жыл бұрын
I read somewhere, don't remember where though, that on the C128 a jiffy is a 100th of a second instead of a 60th. Interesting to see that proven wrong, as I assumed that to be so.
@markjreed
@markjreed 2 жыл бұрын
That's not the C128, but the term "jiffy" has been used for other subsecond intervals. The 0.01-second version shows up mostly in Linux. Microsoft file and directory timestamps count from 1601-01-01T00:00:00Z the number of 100-nanosecond periods (= one ten-millionth of a second), which are also sometimes called "jiffies".
@QrzysztofPL
@QrzysztofPL 2 жыл бұрын
I wonder if 1/60s jiffy is a remnant of old unix time system when they probably used 60Hz counter instead of counting every second since 1 january 1970 in utc. At least wikipedia says so.
@uriituw
@uriituw Жыл бұрын
I actually learned a fair bit there.
@johnsaller2481
@johnsaller2481 2 жыл бұрын
I wonder if there is any difference with TI or TI$ in the C128 1986 rom revision? Nothing is mentioned in the Rom Announcement! palnts $02A6 ;pal =1 or ntsc =0 set during init using video These values are used to set timers depending on palnts so 60 hertz will be correct sixty = 17045 ;ntsc sixtyp = 16421 ;pal
@madmartigan1498
@madmartigan1498 2 жыл бұрын
Is there a kind of database including all the bugs that could be fixed? Or even a bugfix file? - Thx for the extra nerdy content! :-)
@ge97aa
@ge97aa 2 жыл бұрын
I'm in the process of compiling a pretty comprehensive list of bugs in the kernal and basic roms. More comprehensive than any I have ever seen, really. I may publish it some day when it's complete.
@madmartigan1498
@madmartigan1498 2 жыл бұрын
@@ge97aa Great, looking forward to reading it!
@VulpisFoxfire
@VulpisFoxfire 2 жыл бұрын
Hmmm. Code that patches the kernal like that should probably check to see if the RAM version is already in use due to another patch, so that multiple patches can be compatible, instead of wiping each other out.
@whomigazone
@whomigazone 4 ай бұрын
Should at the very least also use bitwise operations incase other ram operations are being used as well.
@magnusjahn5342
@magnusjahn5342 2 жыл бұрын
Hi, its Magnus. Me and my nephew are playing last update VERMEER in C64 and saving isnt working proper. neither in cas mode than in disk mode. My promis was to be able to save it but I cant. May you help me?
@8_Bit
@8_Bit 2 жыл бұрын
Hi Magnus. Sorry I don't know anything about that game, especially since it's in German, but here's a good website with info and links to another website with a manual. You can see if it even supports a save feature: www.c64-wiki.de/wiki/Vermeer Are you playing on a C64 with a real disk? You might need to insert a blank, formatted disk to get the save to work. I'm just guessing though; let me know more of the symptoms and maybe I'll have other ideas.
@awilliams1701
@awilliams1701 2 жыл бұрын
The 1/60th of a second bug assumes that a Jiffy really is 1/60th of a second. I had computers in the 90's where the clocks were not that accurate. I had to reset the clock monthly to get the time in the right ballpark. They would lose or gain 5 minutes a month or so. So the real question is how accurate is the 1/60 second timer. I used to have an internet based alarm clock that was even less accurate than that. So every week I would just unplug it and when restarting it would update the time automatically. Eventually they issued an update that it would check the clock at least once per day. But it was nice because I got pandora radio as my wakeup call instead of a CD starting on the same track every day or the stupid radio with some jerk that I don't care about making horrible jokes that just makes me mad at 7 am. lol (and no they aren't anymore funny at 5 pm either)
@TheBookaroo
@TheBookaroo 2 жыл бұрын
To add to that, on the schematic of both C64 and C128 there is pin 19 (TOD Time Of Day) on the CIAs that is connected to the AC 9 Volts input and that is where it gets it's time reference, and in most countries the 60 Hz is really precise and is compensated by the utility company so that it is accurate overtime. Bwak on KZbin has interesting videos of reverse engineering the CIAs from pictures of the die and we see those counters of the Time Of Day pin 19 kzbin.infovideos
@8_Bit
@8_Bit 2 жыл бұрын
The CIA does get 50 or 60 Hz from AC for the TOD but to be clear (I'm not sure if you're implying otherwise or not) that's not used by the C64 for the TI or TI$ functions at all; they're driven by the system IRQ which is driven by a CIA timer interrupt set to roughly 1,000,000 / 60 microseconds. The TOD functions are an interesting and under-utilized feature of the C64 I think.
@TheBookaroo
@TheBookaroo 2 жыл бұрын
@@8_Bit I see, I did not remember that, makes sense since disabling interrupts makes TI skip counts.
@k4tfjprojects296
@k4tfjprojects296 2 жыл бұрын
@14:30 you are running a PAL version on a power supply that is fed with 60Hz AC. PAL was designed for 50Hz. This could affect the results of your experiment.
@8_Bit
@8_Bit 2 жыл бұрын
All CPU and video timings on the C64 and C128 are derived from a crystal oscillator of 14.31818 MHz for NTSC and 17.734475 MHz for PAL, and have nothing to do with the AC frequency. The only thing the 50 or 60 Hz AC does is drives the Time Of Day (TOD) clock on the CIA chip, but that is not the source of the system IRQ. The system IRQ is driven by a CIA system cycle counter / timer in C64 mode at approximately 60 Hz, or by the video refresh on a C128 (at 50 Hz in PAL or 60 Hz in NTSC), but none of those 50 or 60 Hz for video or system interrupts have anything to do with the AC power frequency.
@alexmcd378
@alexmcd378 2 жыл бұрын
Hey look, it's the split screen flicker that drove me nuts. 😂
@markjreed
@markjreed 2 жыл бұрын
Were you on a PAL machine? I used an NTSC C128 as my main computer for years and only very rarely noticed any flickering in the split-screen graphics modes.
@alexmcd378
@alexmcd378 2 жыл бұрын
@@markjreed it's fine on my ntsc machine. I was having the issue on my emulator setup. Got Robin's help with a workaround.
@markjreed
@markjreed 2 жыл бұрын
@@alexmcd378 Ah, emulators. I know VICE x128 in NTSC mode simply does not handle split-screen graphics; the entire text portion of the screen flashes, rendering it completely unusable. In PAL mode there's a much more minor flicker of just a scan-line or so. Which was also on the PAL machine in this video, so maybe that's accurate to the real hardware!
@alexmcd378
@alexmcd378 2 жыл бұрын
@@markjreed that's it exactly. If you use draw routines to cover the bottom couple rows of pixels of the graphics area, it reduces the flicker to a single row of pixels. Not ideal, but much less distracting
@markjreed
@markjreed 2 жыл бұрын
@@alexmcd378 Hm, adding lines to he bottom of the graphics area doesn't seem to help. I must be misunderstanding.
@madmartigan1498
@madmartigan1498 2 жыл бұрын
Just in TIME$ for my machine code subroutine, yay
@G7VFY
@G7VFY 2 жыл бұрын
Ah! Commodore and their JIFFIES!
@cmuller1441
@cmuller1441 2 жыл бұрын
The error is actually worse because the actual field rate of NTSC is 60/1.001 ~ 59.94 So the actual count should be from 0 to 5 178 820 Actually because of the quartz used in the C64 or slow C128 it's actually 1 022 700×7÷2÷227,5÷525 =29,96923 images per second. So a good count should be from 0 to 5 178 682
@8_Bit
@8_Bit 2 жыл бұрын
I'm sorry but I don't follow. The TI variable is counting jiffies which are approximately 1/60th of a second but have nothing to do with the NTSC or PAL video standards. Jiffies are counted each system IRQ which is driven by the CIA timer interrupt which counts cpu/system cycles.
@Waccoon
@Waccoon 2 жыл бұрын
I think you're under the impression that the Time of Day source is the video crystal, but it actually comes directly from the A/C line from the power supply. Only the interrupt routine on the C128 runs from vsync, not the TOD timer itself. There should be some error involved since the interrupt and timer updates don't sync, but the error is still pretty small. The system timers make a lot of sense on the C64 and C128. The Amiga is what has me all confused, since most of those systems *DO* get the TOD source from vsync. I haven't figured out yet how AmigaOS determines whether the hardware uses a 59.94 Hz or 60 Hz timer.
@zorandavidovac985
@zorandavidovac985 2 жыл бұрын
I always wondered why they did not use TOD from any CIAs for printing TIme now I know, that by using US supply on PAL Commodore would give us wrong TIme, As when you use US power supply you will get 60Hz signal on TOD (pin 19 on both CIAs) while EU power supply gives 50Hz signal, so your test would not be valid in case when TOD is used. So IRQ runs 60 times per second and that is independent of PAL or NTSC C64 /128, source of IRQ is CIA1 and your test is valid only because crystal for PAL/NTSC is different. I found this funny and interesting at the same time :)
@mysticmarble94
@mysticmarble94 2 жыл бұрын
Robin be like : 👉👆👈👎☝👍🤞🤏🤌🖐🖖 😅
@8BitNaptime
@8BitNaptime 2 жыл бұрын
Interestingly, TI% and ST% are valid true variable names.
@mattruddick8919
@mattruddick8919 2 жыл бұрын
Your info the sx64 pal has a 60hz clock for CIA and 50hz vic chip
@8_Bit
@8_Bit 2 жыл бұрын
Yes, apparently the Time Of Day on the SX-64 is driven by a crystal at 60 Hz on both PAL & NTSC models instead of AC mains power at 50 or 60 Hz.
@paulkoopmans4620
@paulkoopmans4620 2 жыл бұрын
At 47.30 I am not so sure this is a valid test. Maybe both pal and ntsc 128 computers solve it differently on pcb level. How these 'rumours' started is that for C64, for the 250407 assy for example, the schematics clearly show that the TOD pins from the CIA's are connected to a little circuit that basically generates clock pulses based on the 9V ac input. So taking the 'pal' or 'ntsc' version would not matter as it is the line voltage alternation that is the driving factor.
@paulkoopmans4620
@paulkoopmans4620 2 жыл бұрын
Even in the C128 schematics the TOD pins from CIA1 and 2 are hooked up to the 9V AC. Through a Smitt Trigger and Zener and some timing circuitry. I don't have any own tools or something to do any measurements but it could well be this indeed is always 60 because you are just not changing your line phase.
@silkwesir1444
@silkwesir1444 2 жыл бұрын
Well, even though this doesn't have to do directly with the video standard, most PAL regions use 50 Hz AC power, while most NTSC regions use 60 Hz. I guess this is where the thought comes from. But you are correct, even on a PAL C64, a Jiffy is a 60th of a second. (Or close to at least, it seems to be kinda inaccurate)
@8_Bit
@8_Bit 2 жыл бұрын
​@@paulkoopmans4620 There seems to be an assumption that the TOD in the CIA has something - anything to do with TI and TI$, but it doesn't. TI is incremented as part of the main system IRQ which is driven by a looping CIA timer (cycle counter) set to approximately 1 000 000 / 60 cycles. TOD is driven by AC, but it's not used by the TI functions at all.
@rotordave81
@rotordave81 2 жыл бұрын
TWO Commodore Security badges. This must be serious.
@8_Bit
@8_Bit 2 жыл бұрын
Something was definitely goin' down there.
@silkwesir1444
@silkwesir1444 2 жыл бұрын
Well that 1/60th of a second within a day is hardly relevant considering the JiffyClock is not very accurate at all. I think even after one hour you will see considerable drift from the actual time.
@tenminutetokyo2643
@tenminutetokyo2643 2 жыл бұрын
DOOD!
@robertlinder6414
@robertlinder6414 2 жыл бұрын
Random number seed
@MrMaxeemum
@MrMaxeemum 2 жыл бұрын
It's amazing how many errors / bugs etc. there are in a 40 year old 8k kernal rom, it's easy to see how windows would have so many unforeseen errors / backdoors / bugs etc. as software is based on older software which is based on older software etc.etc.etc. The C64 maybe flawed but it plays Bruce Lee so I'm happy.
@NuntiusLegis
@NuntiusLegis 2 жыл бұрын
These can be hardly called errors / bugs because under all practical circumstances, it all works. No one sets the time to 99:99:99 (and even then nothing explodes), or cares if TI$ is off a second when running for months.
@MrMaxeemum
@MrMaxeemum 2 жыл бұрын
@@NuntiusLegis Appart from hackers.
@ge97aa
@ge97aa 2 жыл бұрын
Honestly though, a lot of the bugs are CAUSED by the need to cram everything into such a small space. Add to that the fact that it was all programmed in handmade assembly... lots of very ugly hacks are used to get the job done. In a modern O/S, many of these kind of bugs would be avoided by adherence to proper coding standards and the use of MUCH better development tools.
@ge97aa
@ge97aa 2 жыл бұрын
Also, the kernal ROM is only about 6.5 kB. The BASIC interpreter is around 9.5 kB.
@whomigazone
@whomigazone 4 ай бұрын
Yet another bad programming practice, assuming that location contains a set value, not bitwise set.
@Richardddoobies
@Richardddoobies 2 жыл бұрын
Today I learned: If I type "SYS 44808" I get: ? SYNTAX ERROR But is it really? It is not.
The Great Donkey Kong Junior Hoax - Nintendo on Commodore 64
32:59
8-Bit Show And Tell
Рет қаралды 73 М.
99.8% Compatible? The C64 Mode of the Commodore 128
1:02:11
8-Bit Show And Tell
Рет қаралды 33 М.
黑天使被操控了#short #angel #clown
00:40
Super Beauty team
Рет қаралды 61 МЛН
Sigma Kid Mistake #funny #sigma
00:17
CRAZY GREAPA
Рет қаралды 30 МЛН
Леон киллер и Оля Полякова 😹
00:42
Канал Смеха
Рет қаралды 4,7 МЛН
Adding Hex Support To C64 BASIC
28:29
8-Bit Show And Tell
Рет қаралды 22 М.
RAM Scan 64 - Early 1980s Glitch Art Code?
28:52
8-Bit Show And Tell
Рет қаралды 20 М.
GUI64 Demo
5:03
WebFritzi
Рет қаралды 3 М.
Exploring 1982's Commodore MAX Machine: Commodore 64's Little Brother
47:51
8-Bit Show And Tell
Рет қаралды 54 М.
Ten Great Commodore 128 BASIC Improvements Over The C64
45:43
8-Bit Show And Tell
Рет қаралды 42 М.
AMAZING New OS for the 40-year-old Commodore 64! C64 OS Review
39:47
Retro Recipes 🕹️ vintage tech + tv
Рет қаралды 297 М.
Exploring Sid Meier's Pirates! - BASIC Code, Quirks, Bugs on Commodore 64
46:01
The Computer Chronicles - Commodore 64 (1988)
28:32
The Computer Chronicles
Рет қаралды 48 М.
Cracking a C64 Game From Cassette: Livingstone, I Presume?
35:36
8-Bit Show And Tell
Рет қаралды 45 М.
黑天使被操控了#short #angel #clown
00:40
Super Beauty team
Рет қаралды 61 МЛН