I've listed all the packages in the OP and am slowly working my way though them, listing any issues and fixing game bugs as I go.
Except for the IOMD build, which I need to bug-fix, 2.80y can be considered a release candidate.
ADFFS 2.80 public beta
Re: ADFFS 2.80 public beta
I've spotted an issue with 26bit Module clean-up after CTRL-SHIFT-F12, so would advise rebooting between testing games until resolved.
Examples. Re-running any of these after terminating via CTRL-SHIFT-F12 will lock the machine:
Examples. Re-running any of these after terminating via CTRL-SHIFT-F12 will lock the machine:
- The Arc/A3000 Christmas Box - Brixx
- BlastOn
- BlastOn [UCS]
- Break 147 & Superpool
Re: ADFFS 2.80 public beta
Whilst fixing the Burn 'Out CPU detection, I noticed a bug in the SWI handler that's been around for 10 years, where it wasn't triggering an error if X wasn't set for SWI's that were not passed on to the OS. That is now fixed along with a few other bugs, details in the OP.
2.80y-4 in the OP and on PackMan along with an update Burn 'Out package.
2.80y-4 in the OP and on PackMan along with an update Burn 'Out package.
Re: ADFFS 2.80 public beta
2.80y-5 in the OP and on PackMan, which fixes a bug introduced in 2.80y-4
Re: ADFFS 2.80 public beta
2.80rc1 in the OP and on PackMan, which fixes a bug in OS_ReadMemMapInfo when emulating IOC and a bug that was preventing games writing to the Undefined hardware vector
Re: ADFFS 2.80 public beta
I've briefly tested every packaged game on a Pi3, checking they load and you can get into the gameplay - I've not tested further than that though.
Issues are noted in the OP and in some cases I've already fixed the issue either in the package, the Boot script or by bug fixes in 2.80rc2. I'm not quite ready to upload rc2, so will upload all in one hit in due course.
The majority of issues, as expected, are Null dereferences which I hope to fix before the final release as they might require Boot script updates.
Issues are noted in the OP and in some cases I've already fixed the issue either in the package, the Boot script or by bug fixes in 2.80rc2. I'm not quite ready to upload rc2, so will upload all in one hit in due course.
The majority of issues, as expected, are Null dereferences which I hope to fix before the final release as they might require Boot script updates.
Re: ADFFS 2.80 public beta
rc2 is taking somewhat longer than I would have liked to get ready. You'll note in the OP that I've fixed dozens of games with rc2, but whilst investigating the few non-Null dereference issues, its highlighted some fatal flaws that I would like to fix:
26bit Module forced shutdown:
26bit Module forced shutdown:
- If an unhandled Abort occurs during Finalise it invariably hangs the system or leaves it in an unstable state. This has been resolved by intercepting Aborts that would ordinarily go to the OS and essentially ignoring the Finalise code
- Poorly written Modules that use the non-X form of SWI's would trigger the Error handler and effectively bypass their forced shutdown. This required a complete rewrite of the shutdown code, which no longer uses OS_Module 4 and instead calls the Finalise code directly. I had first attempted to wrap an Error handler around the OS_Module 4 call, but noticed that was resulting in a DEADDDEAD (a magic Workspace pointer value used when Finalise doesn't exit cleanly with V clear) Module that could not be removed and odd Supervisor stack corruption
- When an error occurred during an intercepted SWI in the regular SWI dispatch handler (the one that's always active whilst ADFFS is loaded), it wasn't checking the X bit and triggering the Error handler if unset. This was resulting in SWI errors silently failing. Thankfully very few SWI were affected by this, but to fix required a painstaking manual check of every single SWI handler
- The JIT SWI dispatch was also not checking the X bit on exit and generating errors. This has been a bit more complicated to fix as every SWI call from JIT code goes via this and it also needed to silently pass errors back during 26bit Module forced shutdown
- ADFFS has to sit between the Exit/Error handlers that are active when a code is launched via OS_FSControl Run or StartApplication and the game Exit/Error handlers, primarily to allow seamless transitions between 26/32bit code-space. Currently this only supports the Wimp Exit/Error handler, but needs to support all Exit/Error handlers as they might also be pointing at the Supervisor, Debugger or other 3rd party handlers. I'm still figuring out the best way to handle this in a way that doesn't cause the JIT in shutdown early when the Exit handler is called during a program launched in an Obey file
- Similar to the Exit/Error Environment handlers, the Event handler has to handle transitions between 26/32bit code-space. This currently isn't the always case, which is causing hard locks if a game uses OS_Control or OS_ChangeEnvironment to read the current Event handler and subsequently calls the address returned. I should note this is not an issue if the game replaces the Event handler and uses the previous handler address returned as that does return a pointer to 26/32bit transition code
Re: ADFFS 2.80 public beta
I'm still working on RC2, which is very close to a release. I've made all the code changes required and am currently fixing the last few bugs.
I had hoped to fix the list of game issues noted in the OP for RC2, but given the amount of time its taken to implement the code changes required off the back of RC1, they will have to wait for RC3 or the final release.
I had hoped to fix the list of game issues noted in the OP for RC2, but given the amount of time its taken to implement the code changes required off the back of RC1, they will have to wait for RC3 or the final release.
Re: ADFFS 2.80 public beta
RC2 now available in the OP and via PackMan for testers, along with many package updates as noted in the OP.
EDIT: Changes in 2.80rc2 are now noted in the OP and the following packages have been updated:
EDIT: Changes in 2.80rc2 are now noted in the OP and the following packages have been updated:
- 3D-Construction-Kit_1.0-3
- Alone-in-the-Dark_1.00-4
- Arcturus_0-3
- Bambuzle_1.50-3
- Break-147-and-Superpool_0-3
- Burn-Out_0-3
- Burn-Out-[SA]_0-3
- Chocks-Away-Compendium-[SA]_0-4
- Chopper-Force_0-3
- Chopper-Force-[SA]_0-2
- Drop-Ship_0-3
- Drop-Ship-[SA]_0-3
- Legend-of-the-Lost-Temple_0-4
- Quark_0-3
- Manchester-United-Europe_2.1-3
- Nevyron-[SA]_0-3
- Saloon-Cars-Deluxe_2.0-4
- Saloon-Cars-Deluxe-[SA]_3.3-2
- SimCity2000-[A5000]_0-4
- Software-42-Collection_0-2
- Virtual-Golf_1.0-3
- Wizard-Apprentice_0-3
Re: ADFFS 2.80 public beta
RC3 now available in the OP and via PackMan for testers, along with the following package updates to resolve issues noted in the OP.
Whilst investigating why Stunt Racer 2000's intro appeared corrupt on a Pi, I noticed a problem in the way the screen dimensions where being calculated. It was redefining the physical screen size one frame late and wasn't correctly dropping all unnecessary screen size changes. The knock on effect of fixing the issue is that some games that set VIDC registers may now appear to be a different "size" on screen compared to previous ADFFS builds.
Please let me know if you spot any games that look incorrect, I've tested a few games that I know to adjust VIDC registers, but not all.
The other changes in this build are minor bug fixes from a second sweep of all games.
Whilst investigating why Stunt Racer 2000's intro appeared corrupt on a Pi, I noticed a problem in the way the screen dimensions where being calculated. It was redefining the physical screen size one frame late and wasn't correctly dropping all unnecessary screen size changes. The knock on effect of fixing the issue is that some games that set VIDC registers may now appear to be a different "size" on screen compared to previous ADFFS builds.
Please let me know if you spot any games that look incorrect, I've tested a few games that I know to adjust VIDC registers, but not all.
The other changes in this build are minor bug fixes from a second sweep of all games.
- Boogie Buggy (1991) (The Fourth Dimension)
- Chequered Flag [RO3 version] (1992) (Cambridge International Software)
- Cyborg (1992) (Alpine Software)
- Cycloids (1993) (Software 42)
- E-Type II (1994) (The Fourth Dimension)
- Exotic Adventures of Sylvia Layne, The (1993) (The Fourth Dimension)
- F.R.E.D. (1993) (Software 42)
- Gods [RPC version] (2001) (R-Comp Interactive)
- High Risc Racing (1995) (Modus Software)
- Kaptain Konflict (1990) (Calderglen Computers)
- Logic Mania (1996) (The Fourth Dimension)
- Nevryon [SA version] (2001) (The Fourth Dimension)
- Pushy (1997) (The Fourth Dimension)
- Saloon Cars Deluxe [SA version] (2000) (The Fourth Dimension)
- Spobbleoid Fantasy [SA version] (2002) (The Fourth Dimension)
- StarTrader (1989) (GEM Electronics)
- Trivial Pursuit (1989) (Domark)
- White Magic (1989) (The Fourth Dimension)
- White Magic 2 (1989) (The Fourth Dimension)
- WolfPack (1992) (Software 42)
- Word Up Word Down (1989) (GEM Electronics)
- Zodiac - Aries (1994) (GamesWare)