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 #197710 : Transwarp v0.64
2020-11-22 17:12
Krill

Registered: Apr 2002
Posts: 2982
Release id #197710 : Transwarp v0.64

General Q&A thread, also report problems and error logs here.
 
... 162 posts hidden. Click here to view all posts....
 
2020-12-10 20:14
Krill

Registered: Apr 2002
Posts: 2982
Quoting BiGFooT
Even building a custom AR/RR ROM with different fastloader options would be lovely but no one really care about it. At least I don't.
Plan is to add Transwarp including fallback fastloader for standard format (and saver for Transwarp encoding) to tlr's Superfluid V0.7 at some point. Would you care about that? =)
2020-12-10 22:07
Burglar

Registered: Dec 2004
Posts: 1105
Quoting Krill
would there be any interest in support for a parallel connection?
yes! its fairly easy to solder and is supported by vice. main issue would be no 1541u support for that afaik.
im already using a parallel setup by default (with dolphindos), as u know
2020-12-13 23:10
Krill

Registered: Apr 2002
Posts: 2982
Another size-coding trick, but it's quite obvious in hindsight and also not new. =)

Transwarp buffers block data of up to 21 * $1f = $028b bytes per track in drive RAM, which are then transferred while stepping to the next track.

These 21 buffers are scattered in drive RAM (in rather harmless regions so the custom code can return control to ROM after loading without a soft reset).

The buffer addresses are stored in a table of 21 bytes, that is, 16-bit addresses are packed into 8-bit entries.

The table looks like this:
>8:0082  c0 11 51 71  91 02 b2 d2  03 23 43 63  83 a3 c3 e3
>8:0092  04 24 44 64  84
The encoded addresses are $00c0, $0110, $0150, etc.
So, an address from that table can be depacked like this:
.8:0578  B7 82       LAX $82,Y; read address table entry
.8:057a  A2 0F       LDX #$0F ; hi-byte mask
[...]
.8:0586  8F 92 05    SAX $0592; buffer address hi-byte
.8:0589  29 F0       AND #$F0 ; lo-byte mask
.8:058b  8D 91 05    STA $0591; buffer address lo-byte
Note that the 4:4 granularity is arbitrary. With the 2K RAM of a 1541, it could also have been 5:3 to encode addresses from $0000 to $07f8 in steps of 8. (But for sync time-outs with removed disks etc., the code requires a dummy buffer in unmapped address space somewhere between $0800 and $1000.)
2020-12-13 23:43
Copyfault

Registered: Dec 2001
Posts: 478
Really nice!

Looking at this code fragment, I'm wondering wether SHX could be used to shave off another cycle (and two bytes)...
   ldx $82,y           ; read address table entry
   lda #$f0            ; lo-byte mask
   sax $0691           ; store lo-byte to buffer@$06xx
   shx $0692-offset,y  ; mask hi-byte with #$07 and store to buffer
Ok, depends on quite some things (first of all, buffer location at $0600 must be allowed and hi-byte may never go over $07, offset=y so it must be known,...), but what I find most interesting: does an SHX used on the drive's cpu reliably have this "&h+1"-masking going on? It has no RDY-line, so should be the case...
2020-12-13 23:45
chatGPZ

Registered: Dec 2001
Posts: 11391
that calls for some new test programs :)
2020-12-13 23:49
Krill

Registered: Apr 2002
Posts: 2982
Quoting Copyfault
does an SHX used on the drive's cpu reliably have this "&h+1"-masking going on? It has no RDY-line, so should be the case...
Afaik, it's reliable on all 6502 (and variants with illegals) systems without DMA interference. But yes, what Groepaz said. :)

And of course i optimised only as much as needed. =) (And Y is the buffer number and thus not a constant.)
2020-12-14 00:12
Copyfault

Registered: Dec 2001
Posts: 478
Yes, y is the buffer no. (and thus not const), you wrote that in your post... but the SHX was too tempting so I dared to share the thought;)
2020-12-14 21:26
Oswald

Registered: Apr 2002
Posts: 5095
transfering while stepping track, awesome idea :) remembers me when I tried to "stream" load vector anim, and it always stopped for track stepping haha.
2020-12-14 22:36
Krill

Registered: Apr 2002
Posts: 2982
Quoting Oswald
transfering while stepping track, awesome idea :) remembers me when I tried to "stream" load vector anim, and it always stopped for track stepping haha.
I think stepping itself is not to blame for the hiccup. =)

The normal* stepping duration in Transwarp is $90 (144) bycles, that's a fifth (18%) of a revolution, or 4 sectors. So for a regular interleave 4 loader, that means just one missed block. Plus they would use shorter stepping times, usually around $30-$40 bycles. (The $90 setting was determined experimentally, it was the safest setting across all test drives.)

However, the loader you used probably did not load blocks out of order, and then the mean waiting time for a block after trackstep is half a revolution, a tenth of a second, and the worst case double that time.

* With secondary addresses >= 2, the track step times for either or both half-track steps can be increased for drives with particularly long settle times or slow steppers, in order to counter stepping-related loading problems.
Bits 3..1 increase the overall stepping time: +2 = $a0, +4 = $b0, +6 = $c0, ..., +14 = $0100 bycles.
Bits 7..4 increase the time between first and second half-track step: +16, +32 etc. would shift the relation further towards the overall stepping time.
So loading a Transwarp file with ,8,255 would be pretty slow. =)

Having the secondary address take on more meanings than just loading to BASIC start or saved address, i was slightly dismayed to see BiGFoot use ,8,8 out of an old learned habit. =D
2020-12-14 22:45
Count Zero

Registered: Jan 2003
Posts: 1940
https://codebase64.org/feed.php

Tap tap tap ... oh, thats the sound of my drive sometimes recently - not the frequency of your codebase submissions! :)
Previous - 1 | ... | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | ... | 18 - Next
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
MWR/Visdom
Guests online: 114
Top Demos
1 Next Level  (9.7)
2 13:37  (9.7)
3 Coma Light 13  (9.6)
4 Edge of Disgrace  (9.6)
5 Mojo  (9.6)
6 Uncensored  (9.6)
7 The Demo Coder  (9.6)
8 Comaland 100%  (9.6)
9 What Is The Matrix 2  (9.6)
10 Unboxed  (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 Dawnfall V1.1  (9.5)
6 Rainbow Connection  (9.5)
7 Morph  (9.5)
8 Libertongo  (9.5)
9 Onscreen 5k  (9.5)
10 It's More Fun to Com..  (9.5)
Top Groups
1 Booze Design  (9.3)
2 Oxyron  (9.3)
3 Performers  (9.3)
4 Triad  (9.3)
5 Censor Design  (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.049 sec.