Log inRegister an accountBrowse CSDbHelp & documentationFacts & StatisticsThe forumsAvailable RSS-feeds on CSDbSupport CSDb Commodore 64 Scene Database
You are not logged in - nap
CSDb User Forums


Forums > CSDb Entries > Release id #145523 : jsSID-0.9.1
2016-03-07 05:40
mstram
Account closed

Registered: Dec 2013
Posts: 112
Release id #145523 : jsSID-0.9.1

No discussion on this ?

Yes I see the comments, but this is freaking INCREDIBLE !

Congrats Mihály !

Though the absurd speed of today's p.c's obviously helps to make it possible, I'm in awe of Hermit and all of the other programmers who have worked on SID emulation.

The next thing I'd like to see, and I'm trying to possibly figure it out now, is a browser based "mini-editor" or "SID playground".

I.e. a (very) stripped down VICE / basic interpreter that only understands POKE, and maybe FOR, NEXT, and variables / arrays.

I'm looking through the JsSid source now to see how / if I can play / send single notes / or trigger the SID registers.

I see there is some kind of minimal CPU simulation there.

Mike
2016-03-07 16:01
Hermit

Registered: May 2008
Posts: 208
Hi mstram

Thanks for the appreciation of my work. You're right, the CPU is fully emulated (except most of the illegal opcodes which aren't used much in music anyway).
A totally real C64 environment would be much work (VIC,CIA,IRQ,etc. emulation), maybe if jsSID gets melted into jsC64 it can become a reality.
I think you should check Digger's future work or maybe cooperate with him on the jsSID source at GitHub. He have plans for some 'playground' for jsSID. I personally don't have further plans, my work kindof ends here with jsSID as there are many more projects I have to realize too.

The source-code is short enough to learn its internals easily and add to it what you want. This forum thread you just started is a good place to share ideas and solutions...
2016-03-07 16:15
iAN CooG

Registered: May 2002
Posts: 3201
hermit: SBX is quite common in modern players btw, you should consider adding it =)
from a quick scan, players using SBX at least in init:
DefMon
GRG_tiny
GRG_tiny2
Virtuoso
and probably more.
2016-03-08 01:31
mstram
Account closed

Registered: Dec 2013
Posts: 112
Hermit, after a "few" hours of perusing your code I'm starting to understand it (ya I'm a slow learner).

I have a couple of ideas I'm going to explore for the "interpreter / playground"
: (pls post your comments)

1) Bypass the CPU function, and "load" the 'memory' from javascript / screen / html input, then run the play() function

2) Using a "standard" SID / play routine (yours, or Goattrk or other), then have play routine's note / waveform / etc variables exposed to another javascript function / html input fields etc

3) Write a stripped down "basic-interpreter" then have your CPU function run it

4) Use jsc64 to do #3 above

Hermit, thanks for the info on jsc64, didn't know about it.

Unfortunately it seems to be a mess. I cloned the repo, tried running it, get a "bazillion" errors that I'm trying to clean up now.

Mike
2016-03-08 09:00
mstram
Account closed

Registered: Dec 2013
Posts: 112
This is the first sid I've found that won't play Bakakaj

Does that sid have "digi Samples" in it ?
2016-03-08 15:31
Frantic

Registered: Mar 2003
Posts: 1648
Yes, defMON uses "SBX #immediate", and also "LAX zp" and "ASR #immediate".
2016-03-08 15:37
Jammer

Registered: Nov 2002
Posts: 1336
Always a pleasure to serve with tunes that break players ;) I remember both of my Pollytracker tunes had broken rips for some time. It was manifested in the most peculiar way possible - everything was playing perfect apart from different rhythm in drum section :D
2016-03-08 15:42
Frantic

Registered: Mar 2003
Posts: 1648
...and "ANC #immediate" as well. (Sorry for spamming. :) )
2016-03-08 20:47
Digger

Registered: Mar 2005
Posts: 438
Feel free to fork the repo (https://github.com/hermitsoft/jsSID), implement what you need and make a pull request :-)
I am currently working on the cleaning up the docs styling in my own fork (https://github.com/og2t/jsSID), had no time last week but expect updates soon.
2016-03-08 21:04
mankeli

Registered: Oct 2010
Posts: 146
Please integrate this to CSDB!
2016-03-08 23:19
Hermit

Registered: May 2008
Posts: 208
As jsSID is not a complete environment (it's not aimed for that) I think it needs quite some addition to be useful for complete CSDB/HVSC integration to play ALL tunes, but that means it can grow twice as big and eat more CPU in the end...
As Digger says, feel free to implement the illegal opcodes, that would increase the CPU code, but it will still be considerably small I think...

Personally I don't like the idea of using illegal opcodes in SID music, because that can fail on many emulators/players which are targeted for slow systems and lack illegals/etc. by definition. For 1raster tracker I had a reason to use LAX, but that's another story... For normal music players I don't think those few cycles are worth the risk of non-working tunes/demos on some lower end systems...
(I saw the SBX #7 in players to advance SID-channels, but TXA;SBC#7;TAX would only be 3*(2+2) = 12 cycles more if we take all the 3 channels...)

@Bakakaj (what a funny-sounding name for a tune) seems to use an own 'RealSID' player (player-address is 0 in SID-header), and who knows what it does inside... Only a real VIC and CIA and IRQ emulation can play all of these SIDs...but as I said several times, I have no plans for these things...maybe someone else picks it up where I left it if there's enough interest to have a full jsSID implementation...
2016-03-09 04:48
mstram
Account closed

Registered: Dec 2013
Posts: 112
Hurray !

I have figured out the primary "playground" step, i.e being able to "poke / peek" to the SID.

1) I added two functions to the jsSID function / class / object:

"peek"
this.getmem = function(addr) { return memory[addr].toString(16) }

"poke"
this.setmem = function(addr,val) {memory[addr] = val; }

2) By using the "poke" (setmem) function, I altered the loaded SID file by changing the initaddr, and playaddr contents :

(pseudo code)
initaddr jmp initaddr ; usually 0x1000
playaddr jmp initaddr ; usually 0x1003

After "patching" the loaded SID, the tune of course halts playing the last note.

At that point I can use further calls to "poke" (setmem) to alter the SID.

I added simple input boxes to accept the addr / data.

I'll "pretty" it up, by adding a select input for the SID regs, and other stuff.

Next I'm going to create a "dummy" SID file, that's already "patched", so that it can just be selected from the play list, and the "manual patching" won't be necessary.
2016-03-09 08:04
Frantic

Registered: Mar 2003
Posts: 1648
Hermit: You need to set carry to a known state as well if using TXA:SBC:TAX. Anyway, I totally respect the design choice for jsSID not to support all kinds of possible stuff — that's very reasonable — but I strongly disagree on making "compromise coding" an ideal for C64 stuff.
2016-03-09 12:22
Hermit

Registered: May 2008
Posts: 208
Oh yes. I usually place code in a way that Carry-flag is set already as a side-effect of a CMP or SBC, but sometimes of course it's unavoidable to set carry with SEC/CLC. Isn't it required for SBX? Then I understand it's attracting for coders...

My common sense tells me: one can never now what the user uses, maybe a special 6502 variant in a custom hardware or an FPGA implementation that aren't compatible with all the 'allowed' illegal opcodes...

Well, demos are all about undocumented behaviour of C64 chips, for that using illegal opcodes is not a big issue, one won't be surprised if something doesn't work as on real C64. The worst that happens is that a demo can't be watched in its full potential.

But when it's for example a music collection, or even more sensitive stuff like a production tool, users who aren't clearly notified about the program containing illegal opcodes, can face unpleasant moments of hidden errors when a program operates erroneously due to misinterpreted illegal opcodes. (Sure, he/she took the risk on the emulator side, but he/she can't check efficiently in monitor if the binary program has opcodes with a potential risk or not. If source code emphasizes that illegals are used, the case gets easier... Fortunately I shared the source-code for 1raster tracker, but I didn't make it apparent in the help text that a LAX is used, so I made this mistake already with 1raster-tracker. This is the only illegal opcode I've ever used though, and I had a strong reason to do so to better fit in 1 rasterline, and I still kinda regret it...)

I wouldn't call it 'compromise coding' to avoid illegal instructions if you mean that above. VIC and SID tricks usually don't affect program flow much, but CPU can cause unpredictable results even for the smallest differences in code interpretation... Illegals can save some cycles and bytes for the program, but can cause hours of headache for users due to lost workfiles in the worst case (e.g. if illegal opcode is in the disk saver routine, or even if a seldom used effect in a music player occasionally causes program freeze due to illegal opcodes that the user don't know about)...

I don't want to tell anyone not to use illegal opcodes, but indicating in the release it's a stock C64 program (and may not run well in some emulators/players) is a must IMO, from user point of view. On the other hand, this information should be preserved throughout the life and incarnations of a program/tune (which is usually not guaranteed). (If SID header 'targeted for Real C64' RealSID information switch refers to the fact illegals may be contained, that's already done for SID file format, but I'm afraid that there are many RealSID tunes that has no illegal opcodes and so they shouldn't be rejected by players that don't support illegals...)
2016-03-09 18:22
Frantic

Registered: Mar 2003
Posts: 1648
Hehe.. well.. I see what point of view you're coming from of course, but let's just agree to disagree. :) From my point of view anything that works on stock C64s is 100% fine however it may be constructed.

No need to set carry to a known state for SBX.
2016-03-09 18:32
chatGPZ

Registered: Dec 2001
Posts: 11390
Quote:
From my point of view anything that works on stock C64s is 100% fine however it may be constructed.

this :) the discussion reminds me of the "emulator id" stuff that was put into C64 emulators in the early 90s - thank god we got rid of this nonsense by now :=P

Quote:
No need to set carry to a known state for SBX.

yup. they key here is that its a combination of CMP and DEX (and not SBC/DEX as one would think by the mnemonic)
2016-03-10 09:17
Hein

Registered: Apr 2004
Posts: 954
Sbx, anc, lax, arr, all fine & legal opcodes to me. My player is meant for c64 with a Sid. I see no reason to stick to a programming dogma that excludes things from Sid/CPU emulation. Great work nevertheless, Hermit.
RefreshSubscribe to this thread:

You need to be logged in to post in the forum.

Search the forum:
Search   for   in  
All times are CET.
Search CSDb
Advanced
Users Online
grass/LETHARGY
iAN CooG/HVSC
Chrom_
JEZ
cba
Erol
Shake/Role
Scrapper
Fred/Channel 4
Guests online: 122
Top Demos
1 Next Level  (9.7)
2 13:37  (9.7)
3 Mojo  (9.6)
4 Coma Light 13  (9.6)
5 The Demo Coder  (9.6)
6 Edge of Disgrace  (9.6)
7 What Is The Matrix 2  (9.6)
8 Sprite Bukkake 2  (9.6)
9 Uncensored  (9.6)
10 Comaland 100%  (9.6)
Top onefile Demos
1 Layers  (9.7)
2 Cubic Dream  (9.6)
3 Party Elk 2  (9.6)
4 Copper Booze  (9.6)
5 Rainbow Connection  (9.5)
6 Morph  (9.5)
7 Dawnfall V1.1  (9.5)
8 Libertongo  (9.5)
9 Katzen-Video.mp4  (9.5)
10 Onscreen 5k  (9.5)
Top Groups
1 Booze Design  (9.3)
2 Oxyron  (9.3)
3 Performers  (9.3)
4 Fairlight  (9.3)
5 Triad  (9.3)
Top Swappers
1 Derbyshire Ram  (10)
2 Jerry  (9.8)
3 Violator  (9.7)
4 Acidchild  (9.7)
5 Cash  (9.7)

Home - Disclaimer
Copyright © No Name 2001-2025
Page generated in: 0.053 sec.