Differences

This shows you the differences between two versions of the page.

Link to this comparison view

cc65:the_primary_register [2010-05-01 19:26] (current)
uz created
Line 1: Line 1:
 +====== The primary register ======
  
 +The 6502 CPU has no single register that is able to hold any C data besides ''char''. And, for arithmetic operations, only the ''A'' register (the accumulator) can be used. Obviously, the 6502 architecture is not very well suited for C and its larger data types.
 +
 +For this reason, operands are placed in an artificial "primary register". This register consists of the ''A'' and ''X'' CPU registers if the operand is 16 bit wide (low byte in ''A'', high byte in ''X''). For 32 bit operands, a 16 bit zeropage location named ''sreg'' is used in addition to these CPU registers. So the high word goes into ''sreg'' and the low word goes into ''A''/''X''.
 +
 +If a runtime function uses more than one operand (a multiplication for example), the first operand is passed on the [[Parameter and return stacks|parameter stack]], while the second one is passed in the primary register.
cc65/the_primary_register.txt ยท Last modified: 2010-05-01 19:26 by uz
 
Except where otherwise noted, content on this wiki is licensed under the following license: CC Attribution 3.0 Unported
Recent changes RSS feed Donate Powered by PHP Valid XHTML 1.0 Valid CSS Driven by DokuWiki