Storage

How do we move 40-bit data in the accumulator into 16-bit data memory space?
Two methods:

  • MOV from memory mapped accumulator register
    • Contents of specified portion of the accumulator are stored
    • Does not allow for:
      • Rounding
      • Data Write Saturation
    • Not recommended for most applications
      • OK for integer multiplies
  • SAC (Store Accumulator)
    • Specialized command for storing accumulators
    • Maintains sign bit
    • Automatically rounds if desired
    • Can saturate destination register if desired (data write saturation)
    • Can shift during store process
      • Recommended way of retrieving data from accumulators
Storage.png
Click image to enlarge.

Since the six accumulator registers are memory mapped, one can also store the contents of an accumulator register using the MOV instruction. However, it is best to use the SAC instructions to take advantage of the built in rounding and saturation that this command provides.

Store Accumulator

The SAC and SAC.R instructions provide the most convenient and most straightforward methods of saving the accumulator. These instructions store the contents of an accumulator to a location in memory, using either direct or indirect addressing. Accumulator High is the accumulator target source register, and one may optionally shift the data as it is being stored.

SAC
* Store Accumulator
* Store truncated ACCxH into 16-bit memory, with optional pre-shift.

SAC.R
* Store Rounded Accumulator
* Store rounded ACCxH into 16-bit memory, with optional pre-shift
* Rounding type determined by RND bit, CORCON<1>

© 2024 Microchip Technology, Inc.
Notice: ARM and Cortex are the registered trademarks of ARM Limited in the EU and other countries.
Information contained on this site regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.