6502.org Forum  Projects  Code  Documents  Tools  Forum
It is currently Sun Nov 24, 2024 4:56 am

All times are UTC




Post new topic Reply to topic  [ 3 posts ] 
Author Message
PostPosted: Thu Jun 16, 2022 5:33 pm 
Offline

Joined: Sun Oct 03, 2021 2:17 am
Posts: 114
Here's another 65816 gotcha. The mx flags are set to the opposite of what I'd expect when using XCE to switch into native mode.

My best guess is that the designers wanted to save a little silicon, so they have the XCE instruction blindly swap E and C without much awareness of what the values actually are, and not try to be convenient by clearing mx. (Surely it's not that it's actually more common to be processing 8-bit data than 16-bit data on a 16-bit processor.)

And since m and x have to be set in emulation mode, they just happen to stay that way when switching to native mode.


Top
 Profile  
Reply with quote  
PostPosted: Thu Jun 16, 2022 6:49 pm 
Offline
User avatar

Joined: Fri Aug 30, 2002 1:09 am
Posts: 8546
Location: Southern California
It's like the interrupt sequences automatically clearing the decimal mode bit d and setting the interrupt-disable bit i. The only actual mode bits though are d and e. m and x are register-size bits that come into play in native mode. I suspect one part of the logic for starting native mode with the registers at 8-bit is that in many cases, you'll go into native mode immediately after boot-up (and never touch that bit again), and immediately you'll need to be setting up I/O, and you'll normally need 8-bit for that.

_________________
http://WilsonMinesCo.com/ lots of 6502 resources
The "second front page" is http://wilsonminesco.com/links.html .
What's an additional VIA among friends, anyhow?


Top
 Profile  
Reply with quote  
PostPosted: Thu Jun 16, 2022 8:01 pm 
Offline
User avatar

Joined: Fri Dec 11, 2009 3:50 pm
Posts: 3367
Location: Ontario, Canada
jeffythedragonslayer wrote:
And since m and x have to be set in emulation mode, they just happen to stay that way when switching to native mode.

IMO, having x and m initially set =1 when switching to Native Mode makes things a little more friendly for 6502 folks who want to experiment with the '816.

When they first enter Native Mode, they'll find it's actually very much like Emulation Mode (ie, much like 6502). Then later, after they've gotten used to Native Mode with m and x =1 they can experiment with m=0 and/or x=0.

-- Jeff

_________________
In 1988 my 65C02 got six new registers and 44 new full-speed instructions!
https://laughtonelectronics.com/Arcana/ ... mmary.html


Top
 Profile  
Reply with quote  
Display posts from previous:  Sort by  
Post new topic Reply to topic  [ 3 posts ] 

All times are UTC


Who is online

Users browsing this forum: Google [Bot] and 50 guests


You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot post attachments in this forum

Search for:
Jump to: