After a short hiatus mostly down to an illness of one of our dogs, who sadly didn't get better, the last couple of games I've finally got round to finishing off.
They are very similar games and share a lot of code. Basically it is you vs everyone else and you either have to reach the touchdown line, or get a clear shot at the basket at straight on or 45 degrees.
Players take it in turn to attack, there is no defence control.
What it says. From the huge pile of technical documentation on the Cosmos (a few pictures of circuit boards and a couple of interviews) I'm recreating the whole thing, from scratch.
Friday, 27 October 2017
Monday, 23 October 2017
Last lap
Having not done a great deal over the last couple of days, I've had half an hour to devote to it this evening.
This has involved writing the 'throwing' code for Basketball, so the ball has to be thrown at 90 or 45 degrees to the basket and isn't blocked.
Apart from a couple of tweaks I'm considering, that just leaves the defender moving code to be written. First is fairly simple, the system allows three lives for each game and for Basketball/Football I'll put this up to more like 6 or 7. The second is whether to fail the player or not if they go off the top or bottom of the gaming area.
So far the code for the two sports games occupies just over 3 pages, which is fewer than I expected.
This has involved writing the 'throwing' code for Basketball, so the ball has to be thrown at 90 or 45 degrees to the basket and isn't blocked.
Apart from a couple of tweaks I'm considering, that just leaves the defender moving code to be written. First is fairly simple, the system allows three lives for each game and for Basketball/Football I'll put this up to more like 6 or 7. The second is whether to fail the player or not if they go off the top or bottom of the gaming area.
So far the code for the two sports games occupies just over 3 pages, which is fewer than I expected.
Saturday, 21 October 2017
Game#7 and Game#8 in progress
As you can see, some progress has been made on the Basketball and Football games. Here we see the Quarterback approaching the Defensive Line - it's modelled on the Mattel Game pretty much. Much of the basics is there, it flips from side to side depending on whose turn it is. I might change it so that there are more than 3 goes each this game perhaps.
You can't play this one yet.
There are three things left to do to complete ; firstly the collision between the player and the defence, at present you can just run through them. Secondly, the scoring attempt in basketball (you can already score a touchdown) and thirdly the player movement.
The topmost PCTR is at $67F which means six pages left. If I have the time, memory and inclination I'll change one thing from the game, viz. that the game speeds up as time goes on. This isn't difficult, I just haven't done it.
You can't play this one yet.
There are three things left to do to complete ; firstly the collision between the player and the defence, at present you can just run through them. Secondly, the scoring attempt in basketball (you can already score a touchdown) and thirdly the player movement.
The topmost PCTR is at $67F which means six pages left. If I have the time, memory and inclination I'll change one thing from the game, viz. that the game speeds up as time goes on. This isn't difficult, I just haven't done it.
Friday, 20 October 2017
Game#6 : Superman completed
Superman, the last non sport game, is now completed.
It's not as obvious as most of the other games. The object is to catch the dragons that fly backwards and forwards (you will hear a beep when you catch them) and transfer them to the dungeons (a white noise). You have to fill the dungeons to win in the fastest time (the clock counts down). However, the dragons periodically escape the dungeons and so you have to keep them in and chase them.
It's more infuriating than you think ;-)
The ROM is about 2/3 full, which leaves 9 64 byte pages to do the remaining 2 games (the others are mostly 2 or 3 pages), which will probably be a modified single game, having spent time looking at Mattel Football and Basketball there is a lot of commonality - the difference is that in Football you have to get to the goal area and in Basketball you have to get a clear shot at the basket.
It's not as obvious as most of the other games. The object is to catch the dragons that fly backwards and forwards (you will hear a beep when you catch them) and transfer them to the dungeons (a white noise). You have to fill the dungeons to win in the fastest time (the clock counts down). However, the dragons periodically escape the dungeons and so you have to keep them in and chase them.
It's more infuriating than you think ;-)
The ROM is about 2/3 full, which leaves 9 64 byte pages to do the remaining 2 games (the others are mostly 2 or 3 pages), which will probably be a modified single game, having spent time looking at Mattel Football and Basketball there is a lot of commonality - the difference is that in Football you have to get to the goal area and in Basketball you have to get a clear shot at the basket.
Thursday, 19 October 2017
Javascript Cosmos now has Sound Effects
Only beeps and white noise, but they are there :)
I used a tool JFXR which was a java port of BFXR (requires Flash ....) I might redo it, the beeps are sine ones so sound far too nice and not 8 bitty enough - or 4 bitty enough for that matter.
I used a tool JFXR which was a java port of BFXR (requires Flash ....) I might redo it, the beeps are sine ones so sound far too nice and not 8 bitty enough - or 4 bitty enough for that matter.
Quick Fix
Noticed Asteroids and Space Invaders had both stopped working. I'd moved the common new turn code into page 3, but forgot it had a JSRP in it ; this made it into a JMP which meant code after that wasn't being run, hence the turn wasn't being initialised.
Also done the holograms for Superman, Game#6, and spent some time viewing youtube videos of Mattel Football and BasketBall which seem quite similarish in many ways ; you either dodge the bad guys to make a touchdown or to get a shot at a basket. I think the games are sort of going to be alternate attacks, rather than the whole counting the yardage thing that they do in the US.
Also done the holograms for Superman, Game#6, and spent some time viewing youtube videos of Mattel Football and BasketBall which seem quite similarish in many ways ; you either dodge the bad guys to make a touchdown or to get a shot at a basket. I think the games are sort of going to be alternate attacks, rather than the whole counting the yardage thing that they do in the US.
Game#5 : Destroyer completed
So, you can now play Destroyer on the Cosmos a-like. The idea of this game is that the two ships fire at each other. You can take 4 hits before sinking, and there are as many ships as you want to sink on the other side.
Quiz of the week: The pictures show the two holograms (this is another "Game Over" hologram). Guess which one I drew and which one I found as a bit of artwork and borrowed :)
Quiz of the week: The pictures show the two holograms (this is another "Game Over" hologram). Guess which one I drew and which one I found as a bit of artwork and borrowed :)
Third go at it.
Cannon movement patterns in Destroyer |
Doing it efficiently and reliably has taken me some time, and I actually chucked away two previous working versions. But I'm happy with number 3 and it seems to work reliably. It's fiddlier than it looks in COP444 assembler when you are trying to fit it into about four bytes of ROM. Not only do you have the varying pattern at the top, but you can't fire on row 1. All this takes precious memory.
Having said that all that's left of Destroyer is to add the collision detection and the scoring and to make the opponent firing slightly more sensible. (It just has bodge test code at the moment) and the fill percent is still only 54% of the ROM. I had the same thing with Microvision Space Invaders, worrying about memory space and ending with half of it unused.
In other, er, news, I've tweaked Outlaw. It's now the same game, except the player controlled is on the left hand side, which I think is more normal. Destroyer has the player on the left by default.
I'm presuming all the '2 player games' are turn taking rather than firing at each other, there's only one set of controls ....
Tuesday, 17 October 2017
Game#4 RoadRunner completed
Even more games - this one a real quickie. It's a very simple game, you have to dodge the vehicles (which flash) and collect the cash (that doesn't flash)
As its a RoadRunner game it's probably birdseed and rocks or something. There's very little about this game - there's a 2600 game with the same idea - scroll rightwards dodging/collecting, and a Tiger LCD handheld.
This game is unique in one way - I fitted it all in one page (that's 64 bytes). It wasn't cut down at all ; it does everything I wanted it to.
So that gives me 15 pages for four games, which is looking much more like it :)
As its a RoadRunner game it's probably birdseed and rocks or something. There's very little about this game - there's a 2600 game with the same idea - scroll rightwards dodging/collecting, and a Tiger LCD handheld.
This game is unique in one way - I fitted it all in one page (that's 64 bytes). It wasn't cut down at all ; it does everything I wanted it to.
So that gives me 15 pages for four games, which is looking much more like it :)
Game#3 Outlaw complete
I can't aspire to such high resolution on the Cosmos |
In other, err... news, with a bit of fudging and fiddling I've saved a page of ROM memory ; it is now half full.
This gives me 16 pages to do Roadrunner, Destroyer, Superman, Basketball and Football.
Still no sound.
There's a permanent link to the current Javascript build in the top right.
Outlaw in development.
Outlaw, game 3 is under development. One player only here, and as with Invaders a few posts back, currently very one way - the other gunfighter doesn't actually fight back.
The ROM is now slightly less than half full. I reckon the opponent code for this game will take a page maybe. That will leave me with 6 games (DodgeEm, RoadRunner, Superman, Seawars, Football and Basketball) and 15 pages left, or about three each.
I'm beginning to wonder about what games were there and what were completed. Roger Hector (interview with Atari Compendium) is very explicit:
A: Yes, that was pretty much the end for me. We had conceived of and
patented a whole new technology (mass-producible holographic displays), and created a finished tooled product that was supported by 8 finished games (Asteroids, Basketball, Destroyer, Football, Outlaw, Road Runner, Space Invaders, and Superman).
Q: A press kit labeled Electronic Entertainment has a flyer that lists 9 games, and a letter that mentions there were 8 (but only lists 7). Two different titles mentioned were Dodge 'Em and Sea Battle. Were either of those being worked on, or were they simply vaporware?
A: There were a number of brainstorming sessions that considered other games, but the original 8 were the only ones worked on.
This is supported with an internal document (see above). I think I'm going to go with Hector here. So Dodge'Em and Sea Wars are off and replaced by Destroyer. I'm guessing this was a simpler game, it sounds simpler certainly (it's loosely described by Roger Hector).
With this it starts to look reasonably plausible. Reasonably, I must add. Of the five (now) incomplete Destroyer, Road Runner and Superman don't worry me too much. I'm wondering how much code Football and Basketball share.
The ROM is now slightly less than half full. I reckon the opponent code for this game will take a page maybe. That will leave me with 6 games (DodgeEm, RoadRunner, Superman, Seawars, Football and Basketball) and 15 pages left, or about three each.
I'm beginning to wonder about what games were there and what were completed. Roger Hector (interview with Atari Compendium) is very explicit:
Internal Atari Document |
patented a whole new technology (mass-producible holographic displays), and created a finished tooled product that was supported by 8 finished games (Asteroids, Basketball, Destroyer, Football, Outlaw, Road Runner, Space Invaders, and Superman).
Q: A press kit labeled Electronic Entertainment has a flyer that lists 9 games, and a letter that mentions there were 8 (but only lists 7). Two different titles mentioned were Dodge 'Em and Sea Battle. Were either of those being worked on, or were they simply vaporware?
A: There were a number of brainstorming sessions that considered other games, but the original 8 were the only ones worked on.
This is supported with an internal document (see above). I think I'm going to go with Hector here. So Dodge'Em and Sea Wars are off and replaced by Destroyer. I'm guessing this was a simpler game, it sounds simpler certainly (it's loosely described by Roger Hector).
With this it starts to look reasonably plausible. Reasonably, I must add. Of the five (now) incomplete Destroyer, Road Runner and Superman don't worry me too much. I'm wondering how much code Football and Basketball share.
Game#2 Space Invaders working
.... as per title.
It is working as far as I'm going with it ; the invaders march backwards and forwards and down, fire at you, you shoot back.
They only fire one missile between them. I could increase this but it might become very difficult.
Note, the Javascript version doesn't have the sound effects , yet. The C version does but it is classic 8 bit stuff ; short beeps, long beeps and white noise, and that's pretty much it.
I think much of my guesswork about the hardware is probably not far off, but the sound system ; other than it's a second processor I know nothing.
It is working as far as I'm going with it ; the invaders march backwards and forwards and down, fire at you, you shoot back.
They only fire one missile between them. I could increase this but it might become very difficult.
Note, the Javascript version doesn't have the sound effects , yet. The C version does but it is classic 8 bit stuff ; short beeps, long beeps and white noise, and that's pretty much it.
I think much of my guesswork about the hardware is probably not far off, but the sound system ; other than it's a second processor I know nothing.
In which I cannot count
There's only one thing wrong with the post what I wrote a couple of days ago.
There's actually nine games not seven.
Some consequences, most things are designed for sevens, which has meant some rearrangements of the jump tables. I have two of these because of the way JQID works ; basically it changes the LSB of the PCTR according to ROM memory, there is then a dispatching table which goes to do each games code. So a bit of rearrangement.
I also made Space Invaders into the worlds hardest. They now have that zig zaggy movement so well known by arcade fans, but it's a little bit fast so I'll have to slow it down a bit, well a lot .... I haven't uploaded it yet as it is unplayably fast, it gets to the bottom in 3-4 seconds.
I'm not actually short of CPU power in this project, I think it spends 80% of its time in IT (wait for timeout), what I am short of is memory. Nine games is a lot for 2k.
There's actually nine games not seven.
Some consequences, most things are designed for sevens, which has meant some rearrangements of the jump tables. I have two of these because of the way JQID works ; basically it changes the LSB of the PCTR according to ROM memory, there is then a dispatching table which goes to do each games code. So a bit of rearrangement.
I also made Space Invaders into the worlds hardest. They now have that zig zaggy movement so well known by arcade fans, but it's a little bit fast so I'll have to slow it down a bit, well a lot .... I haven't uploaded it yet as it is unplayably fast, it gets to the bottom in 3-4 seconds.
I'm not actually short of CPU power in this project, I think it spends 80% of its time in IT (wait for timeout), what I am short of is memory. Nine games is a lot for 2k.
Monday, 16 October 2017
Over the weekend - second half
Today : eating Pizza rather than writing code. |
ed the source code a bit, and also added a mechanism by which games can be selected by clicking on a simple menu in HTML.
This gets round the cartridge swapping thing because there aren't any cartridges.
By my reckoning I have six games and 15 days, which is a couple of days per game.
The next games will be (probably) Space Invaders, Dodge Em and Road Runner. These are all doable reasonably quickly. This leaves the three that concern me a little timewise, Basketball, Football and Sea Wars.
We shall see :)
Thursday, 12 October 2017
Game#1 Asteroids
Game in Progress .... |
All the system stuff works - you can set the speed, 1 or 2 players and it will alternate them. When your turn is over it shows you the other hologram (a pic of the Shuttle, holo#1 you can see here, some rocks and a surface).
Games apparently either did this, or they had left/right sides for the sports game and the sea war game.
I've also fixed a couple of bugs (holograms weren't switching in this JS port ... they aren't holograms ... because I'd forgotten to write that bit of code) and rewritten the code for generating back lit holograms, which just didn't work in practice.
I'm beginning to see the limitations of this unit. I'm not convinced that however good a programmer you are - and Atari at that time had some very very good ones - it's possible to squeeze 7 decent LED games into 2k. Things like Mattel Football were 2k in their own right. Even Simon, a much simpler game, is 1k.
Wednesday, 11 October 2017
A sort of game ....
it really is just a test for my pixel collision routine which I've just written.
It is the basis of a game, it's just not very hard, you can't fight back. You can just shoot the baddies (with the completely inappropriate hologram) and get a point each time you do it.
Still next up is the first proper game, which will be Asteroids, or really a simpler version of the Intellivision Astrosmash.
I did get Asteroids in 64x32 on a Studio2, but 7 x 6 resolution .... nope.
Studio II Asteroids
The code hasn't changed much, basically MovePlayerMissile skips if the missile is in flight - if you need to check collisions. It calls the new CheckCollision function, which skips itself if there is a collision, with the pixel ID in A + B. This object is killed, the PlayerMissile is killed, the score is bumped and round we go again.
I realised why the NOPs are there ; it's a feature of MoveUp/Down/Left/Right which the MoveXPlayer routines use. I think I'll leave it.
jsrp Update
jsrp MoveHPlayer
nop
jsrp MoveVPlayer
nop
jsrp CheckFire
jsrp MovePlayerMissile
jp game_code
lbi 0,PlayerMissile
jsrp CheckCollision
jp game_code
jsrp Kill
jsrp KillPlayerMissile
jsrp BumpCounter
jp game_code
It is the basis of a game, it's just not very hard, you can't fight back. You can just shoot the baddies (with the completely inappropriate hologram) and get a point each time you do it.
Still next up is the first proper game, which will be Asteroids, or really a simpler version of the Intellivision Astrosmash.
I did get Asteroids in 64x32 on a Studio2, but 7 x 6 resolution .... nope.
Studio II Asteroids
The code hasn't changed much, basically MovePlayerMissile skips if the missile is in flight - if you need to check collisions. It calls the new CheckCollision function, which skips itself if there is a collision, with the pixel ID in A + B. This object is killed, the PlayerMissile is killed, the score is bumped and round we go again.
I realised why the NOPs are there ; it's a feature of MoveUp/Down/Left/Right which the MoveXPlayer routines use. I think I'll leave it.
jsrp Update
jsrp MoveHPlayer
nop
jsrp MoveVPlayer
nop
jsrp CheckFire
jsrp MovePlayerMissile
jp game_code
lbi 0,PlayerMissile
jsrp CheckCollision
jp game_code
jsrp Kill
jsrp KillPlayerMissile
jsrp BumpCounter
jp game_code
More general routines
The plan is to write most of the general routines which can be reused up front, then do the actual games.
Some of it now works. If you run the latest version, of the Javascript version (link on right) or the C version you can now move your "player" LED with the arrow keys and shoot a "missile" LED with fire (Control key).
A Cop444 has a JSRP instruction which does a subroutine jump into page 2; what I'm doing is creating a whole pile of extra one byte instructions that do far more complex things.
So, in this bit of code there's the following which does this.
Update updates the screen display, timers and scans the keypad.
MoveHPlayer/MoveVPlayer move the player in that axis. They both skip if you move off the screen hence the NOPs. (I might change this as none of the games need this). CheckFire fires a new missile if possible and the fire key is down. MovePlayerMissile moves the P/M if it is in flight and return-skips if it is still in flight (e.g. you might check it collides with something). In this demo it increments the counter when the missile is in flight. (BumpCounter .... increments the counter)
All of these instructions are one byte JSRP commands.
game_code:
jsrp Update
jsrp MoveHPlayer
nop
jsrp MoveVPlayer
nop
jsrp CheckFire
jsrp MovePlayerMissile
jp game_code
jsrp BumpCounter
jp game_code
Some of it now works. If you run the latest version, of the Javascript version (link on right) or the C version you can now move your "player" LED with the arrow keys and shoot a "missile" LED with fire (Control key).
A Cop444 has a JSRP instruction which does a subroutine jump into page 2; what I'm doing is creating a whole pile of extra one byte instructions that do far more complex things.
So, in this bit of code there's the following which does this.
Update updates the screen display, timers and scans the keypad.
MoveHPlayer/MoveVPlayer move the player in that axis. They both skip if you move off the screen hence the NOPs. (I might change this as none of the games need this). CheckFire fires a new missile if possible and the fire key is down. MovePlayerMissile moves the P/M if it is in flight and return-skips if it is still in flight (e.g. you might check it collides with something). In this demo it increments the counter when the missile is in flight. (BumpCounter .... increments the counter)
All of these instructions are one byte JSRP commands.
game_code:
jsrp Update
jsrp MoveHPlayer
nop
jsrp MoveVPlayer
nop
jsrp CheckFire
jsrp MovePlayerMissile
jp game_code
jsrp BumpCounter
jp game_code
Tuesday, 10 October 2017
It lives :)
The Javascript Cosmos is now alive and it lives at http://www.studio2.org.uk/cosmos/
Keys are : arrow keys for directions, P for player, S for skill level, ENTER to start and CTRL to fire.
At the moment all you can do is to select the player number and skill level with P and S and start it. When this happens, the LEDs on the top row light sequentially and the left 7 Segment LED counts.
The app needs to have the focus so it may need clicking on before it will work.
But this is exactly what the C one does :)
I will try to keep this up to date so when some games appear they can be played on the JS version or the C version.
Obviously it is much easier to play games on the JS version but it's easier to develop on the C version ; the JS version has no debugger.
Keys are : arrow keys for directions, P for player, S for skill level, ENTER to start and CTRL to fire.
At the moment all you can do is to select the player number and skill level with P and S and start it. When this happens, the LEDs on the top row light sequentially and the left 7 Segment LED counts.
The app needs to have the focus so it may need clicking on before it will work.
But this is exactly what the C one does :)
I will try to keep this up to date so when some games appear they can be played on the JS version or the C version.
Obviously it is much easier to play games on the JS version but it's easier to develop on the C version ; the JS version has no debugger.
Monday, 9 October 2017
Javascript Port
Thinking about actually running it, I've decided to port the emulator to Javascript, well actually Typescript which I rather like despite its Microsoft origins.
Having been developing stuff with MS since Windows 3.0 one gets paranoid about embrace, extend, exterminate. Or just being dumped. Some of us remember when the web was all going to be ActiveX web apps written in Visual Basic. Or Silverlight. But this does appear to be genuinely open source.
Phaser will do the graphics and sound and so on.
I modified the COP444 code generator slightly to suit JS code generation as well as C, and got it generating a typescript file which is a superclass of an abstract processor class which is itself then subclassed to add useful and necessary stuff. Each opcode becomes a function called opcode_207() or whatever and an array of these functions is returned by an accessor method. I'm unconvinced by javascripts case statement, perhaps unfairly. The one thing about GCC is you know it's going to optimise the case to a jump table.
Mostly these changes involved getting it to output things like this.a rather than A in code ; JS and C are near enough syntactically and the output code simple enough that it's pretty much all just replace().
It seems to be working even though there's no real hardware ; it is just a dummy class which implements IHardware and outputs what the CPUs doing to it, but running the "ROM image" it is certainly doing the first bits - figuring out the Game ID, displaying S1 on the LEDs and then scanning the keyboard.
The next time I write a framework emulator I'll probably think through a JS port in advance.
Having been developing stuff with MS since Windows 3.0 one gets paranoid about embrace, extend, exterminate. Or just being dumped. Some of us remember when the web was all going to be ActiveX web apps written in Visual Basic. Or Silverlight. But this does appear to be genuinely open source.
Phaser will do the graphics and sound and so on.
I modified the COP444 code generator slightly to suit JS code generation as well as C, and got it generating a typescript file which is a superclass of an abstract processor class which is itself then subclassed to add useful and necessary stuff. Each opcode becomes a function called opcode_207() or whatever and an array of these functions is returned by an accessor method. I'm unconvinced by javascripts case statement, perhaps unfairly. The one thing about GCC is you know it's going to optimise the case to a jump table.
Mostly these changes involved getting it to output things like this.a rather than A in code ; JS and C are near enough syntactically and the output code simple enough that it's pretty much all just replace().
It seems to be working even though there's no real hardware ; it is just a dummy class which implements IHardware and outputs what the CPUs doing to it, but running the "ROM image" it is certainly doing the first bits - figuring out the Game ID, displaying S1 on the LEDs and then scanning the keyboard.
The next time I write a framework emulator I'll probably think through a JS port in advance.
Sunday, 8 October 2017
Core Mostly Done
Apart from utility routines, of which there will be several - move, collide etc. I've done a fair amount, pretty much all of the core.
First thing was a replacement of the timing system with a lot more flexible one that allows a lot more choice in speeds, but keeps the basic idea - that the timers go quickly in slow mode.
Then the select phase has been added ; when you start up it displays S 1 on the 7 segment displays and the #players and skill switches change this to S 2 F 1 or F2. Start then starts the game.
As I wrote yesterday there's a sort of very very slow task switcher in there ; whenever the player changes it swaps pages 0-2 and 5-7 round (page 3 is stuff like keys and timers), and when both tasks are killed the game is over. I initialise it by creating both anyway and killing a player for the one player game.
This then goes into a jump table using the JQID instruction, which goes to the entry point. If the carry is set it initialises the game and returns, if it is clear it plays another round of the game.
At the moment all I have is a 'game' which counts on one of the 7 segment LEDs and moves a lit led across the top row, but it works well enough to get the core tested.
Next up, some games. At the moment I'm using 4 1/2 pages of the 32, which leaves 27 1/2 or a bit less than 4 each. Should be enough for most, though I'm a bit worried about the football / basketball games especially. I suspect these are simpler than the Mattel games.
First thing was a replacement of the timing system with a lot more flexible one that allows a lot more choice in speeds, but keeps the basic idea - that the timers go quickly in slow mode.
Then the select phase has been added ; when you start up it displays S 1 on the 7 segment displays and the #players and skill switches change this to S 2 F 1 or F2. Start then starts the game.
As I wrote yesterday there's a sort of very very slow task switcher in there ; whenever the player changes it swaps pages 0-2 and 5-7 round (page 3 is stuff like keys and timers), and when both tasks are killed the game is over. I initialise it by creating both anyway and killing a player for the one player game.
This then goes into a jump table using the JQID instruction, which goes to the entry point. If the carry is set it initialises the game and returns, if it is clear it plays another round of the game.
At the moment all I have is a 'game' which counts on one of the 7 segment LEDs and moves a lit led across the top row, but it works well enough to get the core tested.
Next up, some games. At the moment I'm using 4 1/2 pages of the 32, which leaves 27 1/2 or a bit less than 4 each. Should be enough for most, though I'm a bit worried about the football / basketball games especially. I suspect these are simpler than the Mattel games.
Saturday, 7 October 2017
Minor improvements
I've been running Arch Linux for a while and yesterday they transitioned to Gnome 3.26. For some reason I couldn't figure out, SDL2 no longer worked, it crashed the Desktop Environment, may be something to do with Wayland changes maybe.
Anyway, I've been thinking of changing for a while, so my spare time yesterday was spent shifting to Fedora 26, which works fine and is surprisingly quick.
So everything is working again. But I haven't written much code since yesterday because of that, the code to keep the overall synchronisation going and a routine to exchange the contents of pages 3 and 4 of RAM.
I have a 'sort of' game. Actually all it does is increment one of the timers and shift a pixel, but it still has an 'init' and 'update' part which is all I want for testing. I will use this "game" to write the code that handles the selection of speed and #players - I'm presuming here that this is selected by the two buttons and pressing START starts the game and subsequently handles the toggling between the two games. All games will be turn taking. Exactly how I multitask this I'm still considering .... rather than just switching 3 and 4, the original idea, it might be advantageous to switch banks 0 and 1 as well, make bank 2 the 'local data' page and switch that, and bank 3 becomes the common page (game ID, speed, player#, keyboard status, counter status and so on), then switch banks 0,1 and 2.
At this point making those changes creates no problems, but it needs some thought.
Anyway, I've been thinking of changing for a while, so my spare time yesterday was spent shifting to Fedora 26, which works fine and is surprisingly quick.
So everything is working again. But I haven't written much code since yesterday because of that, the code to keep the overall synchronisation going and a routine to exchange the contents of pages 3 and 4 of RAM.
I have a 'sort of' game. Actually all it does is increment one of the timers and shift a pixel, but it still has an 'init' and 'update' part which is all I want for testing. I will use this "game" to write the code that handles the selection of speed and #players - I'm presuming here that this is selected by the two buttons and pressing START starts the game and subsequently handles the toggling between the two games. All games will be turn taking. Exactly how I multitask this I'm still considering .... rather than just switching 3 and 4, the original idea, it might be advantageous to switch banks 0 and 1 as well, make bank 2 the 'local data' page and switch that, and bank 3 becomes the common page (game ID, speed, player#, keyboard status, counter status and so on), then switch banks 0,1 and 2.
At this point making those changes creates no problems, but it needs some thought.
Friday, 6 October 2017
Hardware Interface
I've been working on more general interface code. You can see it running here.
The first two pages 0x and 1x are the 'on LEDs' - only one at 08/18 at 4,B which is 4 across, 4 down. 0D/1D and 0E/1E are set up to access LEDs (E and F values) and re displaying digits 60 (2D/2E)
New stuff includes the game ID, which is at 2C at the moment ; this is the 'cartridge selector' connections which are currently %0101 or 5.
The keyboard scanner also works - this is at 20-24. Bit 3 of $20 being set means the left key is being pressed, Bit 2 of $21 means that the 'Number of Players' key (P) is being pressed. If fire was being pressed bit 0 of $22 would be set.
There is also code to clear the screen and the whole of memory.
I'm going to have 2 players by having the 'current player information' in $30-$3F, and switching this with another bank, $40-$4F maybe, each time the player changes sides. Additionally the difficulty level will be primarily speed based. With a bit of luck all this will be automatic.
The first two pages 0x and 1x are the 'on LEDs' - only one at 08/18 at 4,B which is 4 across, 4 down. 0D/1D and 0E/1E are set up to access LEDs (E and F values) and re displaying digits 60 (2D/2E)
New stuff includes the game ID, which is at 2C at the moment ; this is the 'cartridge selector' connections which are currently %0101 or 5.
The keyboard scanner also works - this is at 20-24. Bit 3 of $20 being set means the left key is being pressed, Bit 2 of $21 means that the 'Number of Players' key (P) is being pressed. If fire was being pressed bit 0 of $22 would be set.
There is also code to clear the screen and the whole of memory.
I'm going to have 2 players by having the 'current player information' in $30-$3F, and switching this with another bank, $40-$4F maybe, each time the player changes sides. Additionally the difficulty level will be primarily speed based. With a bit of luck all this will be automatic.
Thursday, 5 October 2017
Some actual working COP444 code.
In the end after some tinkering I decided on the following for video generation.
Page 0 of RAM, from 0-14 is used for the x coordinate which can be zero (off) or 1-7. Page 1 of RAM from 0-14 is used for the y coordinate which is from 8-15 representing row 0-5 on the LEDs, the left 7 segment and the right 7 segment.
If a Y coordinate in page 1 is 14 or 15 (the 7 segment displays) then the digit is taken from the equivalent row in page 2.
The code is shown below (minus the data tables). The handy thing about the datatables is if my assumptions are wrong about how the wiring works, all I have to do is change the datatables.
I originally thought that the layout had to be sensible (e.g. the 7 LEDs being G2 G1 G0 D3 D2 D1 D0 in order) but with this system it doesn't matter. Though it probably is still that way.
This routine doesn't quite fit in a page with the three tables (column bit, row bit, 7 segment lookup) unfortunately and I can't make it fit, it's about 8 bytes too long.
One perhaps rather optimistic question ; does anyone know if the COP444's IT instruction resets the timeout flag. IT is 'stop processor till timeout' - a COP444 has a 10 bit internal timer but it isn't clear whether this resets the timeout overflow flag or not. SKT definitely does, but of course skips ... because the timer has overflowed. If IT does reset the flag I can reduce the IT/SKT/NOP sequence to just IT.
This synchronises the timing ; one LED is displayed every timeout, this routine takes the same amount of time (16 timer cycles, a frame rate of about 16Hz) when it is called, irrespective of how many LEDs are displayed (this allows a maximum of 15 or 13 + 2 score digits)
I do wonder if this will be a bit like Microvision Space Invaders. That was on a TMS1100 , a very similar processor with 2k of ROM space. I was a bit panicky about space when I started it and wrote tight but unclear code (the code below has two seperately overlapping loops), but I ended up with half the ROM space unused.
We shall see. I should be able to write tighter code than the original developers if for no other reason than I have much better development tools - I can reassemble in a second, I have a proper single stepping debugger. I don't doubt the original developers were awesome programmers.
I suspect the original devs had a much slower turnaround, which means you program more defensively. A defensive simpler version of this is about half as long again.
It's amazing what you do in retrospect. When I was a kid I had a Sharp MZ80K, which had BASIC loaded from tape. If you crashed it, you reloaded the tape which took 3 or 4 minutes. I hacked the BASIC to add a pile of commands including a complete Z80 assembler that worked like the one in the BBC Micro. Still not quite sure how :)
Page 0 of RAM, from 0-14 is used for the x coordinate which can be zero (off) or 1-7. Page 1 of RAM from 0-14 is used for the y coordinate which is from 8-15 representing row 0-5 on the LEDs, the left 7 segment and the right 7 segment.
If a Y coordinate in page 1 is 14 or 15 (the 7 segment displays) then the digit is taken from the equivalent row in page 2.
The code is shown below (minus the data tables). The handy thing about the datatables is if my assumptions are wrong about how the wiring works, all I have to do is change the datatables.
I originally thought that the layout had to be sensible (e.g. the 7 LEDs being G2 G1 G0 D3 D2 D1 D0 in order) but with this system it doesn't matter. Though it probably is still that way.
This routine doesn't quite fit in a page with the three tables (column bit, row bit, 7 segment lookup) unfortunately and I can't make it fit, it's about 8 bytes too long.
One perhaps rather optimistic question ; does anyone know if the COP444's IT instruction resets the timeout flag. IT is 'stop processor till timeout' - a COP444 has a 10 bit internal timer but it isn't clear whether this resets the timeout overflow flag or not. SKT definitely does, but of course skips ... because the timer has overflowed. If IT does reset the flag I can reduce the IT/SKT/NOP sequence to just IT.
This synchronises the timing ; one LED is displayed every timeout, this routine takes the same amount of time (16 timer cycles, a frame rate of about 16Hz) when it is called, irrespective of how many LEDs are displayed (this allows a maximum of 15 or 13 + 2 score digits)
I do wonder if this will be a bit like Microvision Space Invaders. That was on a TMS1100 , a very similar processor with 2k of ROM space. I was a bit panicky about space when I started it and wrote tight but unclear code (the code below has two seperately overlapping loops), but I ended up with half the ROM space unused.
We shall see. I should be able to write tighter code than the original developers if for no other reason than I have much better development tools - I can reassemble in a second, I have a proper single stepping debugger. I don't doubt the original developers were awesome programmers.
I suspect the original devs had a much slower turnaround, which means you program more defensively. A defensive simpler version of this is about half as long again.
It's amazing what you do in retrospect. When I was a kid I had a Sharp MZ80K, which had BASIC loaded from tape. If you crashed it, you reloaded the tape which took 3 or 4 minutes. I hacked the BASIC to add a pile of commands including a complete Z80 assembler that worked like the one in the BBC Micro. Still not quite sure how :)
__Repaint: lbi 1,15 ; point to first one plus 1, also set B upper to one. RPDoneY: ld 1 ; switch back to zero. it ; delay for brightness skt nop cba ; get the pointer. aisc 15 ; effectively subtract 1 and skip on not borrow ret ; borrowed, so return. RPContinue: cab ; save new address in B. xad RowTemp ; save it in RowTemp clra ; A:M now points to the table in the first 16 bytes. lqid ; read the 8 bit pattern into Q. skmbz 3 ; if M(B) is in range 0-7 it is 'X', so skip. jp RPDoneY ; otherwise we have done Y, so complete. ld 1 ; point to Y smb 3 ; set the mandatory bit 3. ld 3 ; read Y this value is 8-15. Execute if 14,15. Set Bu to 2 aisc 2 ; will skip if 14,15 jp RPNotSevenSegment clra ; read from seven segment table. aisc 15 lqid RPNotSevenSegment: ldd HoloDisplay ; read the holo display location aisc 15 ; set carry if non zero nop lbi RPWork1 ; point to useable location for CQMA and set to page 1. cqma ; copy X 8 bit data to MA smb 3 ; set bit 3 if carry set. skc rmb 3 ; otherwise, clear it. omg ; output high 3 bits and G3 bit set here. cab ; output low 4 bits obd ldd RowTemp ; load rowtemp, Bu is still 1 cab jp RPContinue ; and do the Y part
Wednesday, 4 October 2017
Thinking about games & core routines
I've spent some time thinking about how the games actually work, and as a consequence of this how the core routines should operate.
I am working on the premise that the games are like other games of the same name, where practical, looking at Atari hardware, 2600 games and similar LED games.
There is some description of games in the Atari Cosmos Patent (4,421,317), (though annoyingly its mostly about the hologram technology( and a bit more in the interview with Roger Hector.
I'm thinking along the following lines.
Basketball, Football and Space Invaders - Atari don't seem to have done LED versions of these, so these will use the Mattel games and Entex game respectively for ideas.
Asteroids - there are very few LED Asteroid games - unsurprisingly as its a vector graphic game, so I think this is more like the Intellivision game Astrosmash (the one LED game I could find was like this) e.g. Asteroids drop vertically and you shoot them.
Dodge'Em - a classic game where you have concentric squares in a maze and you go round dodging the bad guys. Presumably a similar game to the 2600 games.
Outlaw - a game where you shoot at each other - a gunfighter simulation, this too has a 2600 equivalent.
Road Runner - I can only find a 2600 game and a Tiger LCD game, this appears to be a sideways scrolling dodge and collect game.
Sea Battle - probably the best described game of the lot, as it is described in the Patent and by Roger Hector. However, not much actual mechanics information.
Superman - an original game based around collecting dragons.
Originally, I was going to do this as a "memory mapped screen", where there is an area of memory where bits are 1 and 0 for LEDs being on and off. This works fine, but having tried it and though about it it lacks a lot of flexibility.
So plan B is to have a list of LEDs that are turned on. These can be moved about by changing the coordinates which are stored in adjacent lists - so say making a bullet go up involves subtracting one from its vertical position and it 'automatically redraws' rather than bit twiddling memory which 4 bit processors aren't great at.
The "odd one out" is DodgeEm which has a "Pacman" sort of system - a maze where you collect the Dots. I might work round this by doing what Magnavox did with their Odyssey II Pacmans - having enough dots so you have to go round the whole maze, but not so many that it can handle the numbers. Or maybe I'll just do an overlay. To be decided :)
I am working on the premise that the games are like other games of the same name, where practical, looking at Atari hardware, 2600 games and similar LED games.
There is some description of games in the Atari Cosmos Patent (4,421,317), (though annoyingly its mostly about the hologram technology( and a bit more in the interview with Roger Hector.
I'm thinking along the following lines.
Basketball, Football and Space Invaders - Atari don't seem to have done LED versions of these, so these will use the Mattel games and Entex game respectively for ideas.
Asteroids - there are very few LED Asteroid games - unsurprisingly as its a vector graphic game, so I think this is more like the Intellivision game Astrosmash (the one LED game I could find was like this) e.g. Asteroids drop vertically and you shoot them.
Dodge'Em - a classic game where you have concentric squares in a maze and you go round dodging the bad guys. Presumably a similar game to the 2600 games.
Outlaw - a game where you shoot at each other - a gunfighter simulation, this too has a 2600 equivalent.
Road Runner - I can only find a 2600 game and a Tiger LCD game, this appears to be a sideways scrolling dodge and collect game.
Sea Battle - probably the best described game of the lot, as it is described in the Patent and by Roger Hector. However, not much actual mechanics information.
Superman - an original game based around collecting dragons.
Originally, I was going to do this as a "memory mapped screen", where there is an area of memory where bits are 1 and 0 for LEDs being on and off. This works fine, but having tried it and though about it it lacks a lot of flexibility.
So plan B is to have a list of LEDs that are turned on. These can be moved about by changing the coordinates which are stored in adjacent lists - so say making a bullet go up involves subtracting one from its vertical position and it 'automatically redraws' rather than bit twiddling memory which 4 bit processors aren't great at.
The "odd one out" is DodgeEm which has a "Pacman" sort of system - a maze where you collect the Dots. I might work round this by doing what Magnavox did with their Odyssey II Pacmans - having enough dots so you have to go round the whole maze, but not so many that it can handle the numbers. Or maybe I'll just do an overlay. To be decided :)
Tuesday, 3 October 2017
and some .... sort of ...holograms
This is the cross between the last two posts. It's using the hologram image and the LED cycling program to produce a sort of hologram with LEDs display.
Obviously needs a bit of fine tuning ; it looks a bit too blocky, might reduce the difference between the dark and the light graphics, as the hologram is independently lit anyway.
It's a bit primitive, but it works. I can also switch between the two holograms and have the keyboard hardware emulated.
Obviously needs a bit of fine tuning ; it looks a bit too blocky, might reduce the difference between the dark and the light graphics, as the hologram is independently lit anyway.
It's a bit primitive, but it works. I can also switch between the two holograms and have the keyboard hardware emulated.
Monday, 2 October 2017
Working emulator
So, I now have a semi working (only a couple of bugs found so far) emulator of the processor and the display.
Most of the code has been borrowed from earlier emulators I wrote - I have a framework where you just provide the debugger display and the runtime and it does everything else pretty much.
There isn't that much difference between a COP444, an SM510 and a TMS1100. Though I maintain the SM510 is broken as a processor because it can't do an indirect write ; this stuffed up a previous Retrochallenge.
The code it is running is writing patterns to the display, it's rubbish code but just slung together to make it work. This is on the left at the top. Registers and I/O ports are in the middle, and the display is on the right - a pair of 7 Segment LEDs and a 7x6 LED array. The bottom chunk is the COP444's 128 nibbles of RAM.
I want to replace this display with bits cut from the "hologram" images shown in the last post ; this will require some hacking of the Framework so that it can read in and render PNG files, which it can't do at present.
Most of the code has been borrowed from earlier emulators I wrote - I have a framework where you just provide the debugger display and the runtime and it does everything else pretty much.
There isn't that much difference between a COP444, an SM510 and a TMS1100. Though I maintain the SM510 is broken as a processor because it can't do an indirect write ; this stuffed up a previous Retrochallenge.
The code it is running is writing patterns to the display, it's rubbish code but just slung together to make it work. This is on the left at the top. Registers and I/O ports are in the middle, and the display is on the right - a pair of 7 Segment LEDs and a 7x6 LED array. The bottom chunk is the COP444's 128 nibbles of RAM.
I want to replace this display with bits cut from the "hologram" images shown in the last post ; this will require some hacking of the Framework so that it can read in and render PNG files, which it can't do at present.
Sunday, 1 October 2017
Rendering Holograms.
The 'video' display of a Cosmos is an array of 7 x 6 LEDs with a switchable 3D hologram in front of it which can display one of two images.
The hologram is like those things you used to get with breakfast cereal (if you're my sort of age) where it displayed two seperate images depending on how you tilted it. I don't remember if any of these were 3D OTOMH.
A Cosmos doesn't tilt it, it just shines light on it from different directions, and from the LEDs behind.
Going to have some issues with 3D, so I've flattened it to 2D.
I've written a Python script which takes the picture (the flowers and the UFO, first things off openclipart.org ....) and produces two versions of it ; one is darker than normal because there's no background LED, and one lit by an array of 7x6 LEDs (the green bar is solid colour so doesn't show the Red directly). The colours of the objects are reddened slightly as well so it looks like RED LEDs are lighting it up - so the flowers look pinker on the top.
The emulator will just grab a square chunk of the graphic depending on what LEDs are on and which Hologram is selected - there will be two of these image - pairs as each hologram can display two different images.
At the moment the prototype emulator just displays a grid of square LEDs. If I build a real one - I have the parts for this, a 16x8 LED array (half for the digit display), a Mega2560 and a joypad shield in my bits box somewhere.
The hologram is like those things you used to get with breakfast cereal (if you're my sort of age) where it displayed two seperate images depending on how you tilted it. I don't remember if any of these were 3D OTOMH.
A Cosmos doesn't tilt it, it just shines light on it from different directions, and from the LEDs behind.
Going to have some issues with 3D, so I've flattened it to 2D.
I've written a Python script which takes the picture (the flowers and the UFO, first things off openclipart.org ....) and produces two versions of it ; one is darker than normal because there's no background LED, and one lit by an array of 7x6 LEDs (the green bar is solid colour so doesn't show the Red directly). The colours of the objects are reddened slightly as well so it looks like RED LEDs are lighting it up - so the flowers look pinker on the top.
The emulator will just grab a square chunk of the graphic depending on what LEDs are on and which Hologram is selected - there will be two of these image - pairs as each hologram can display two different images.
At the moment the prototype emulator just displays a grid of square LEDs. If I build a real one - I have the parts for this, a 16x8 LED array (half for the digit display), a Mega2560 and a joypad shield in my bits box somewhere.
Subscribe to:
Posts (Atom)