$NOTRANSFORM/de

From MCS Wiki AVR
< $NOTRANSFORM
Revision as of 22:04, 6 February 2013 by Admin (Talk | contribs)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search

Contents

= (**COPIED FROM ENGLISH PAGE**) === Action

This option controls transformation of unsupported ASM mnemonics.

 

 

Syntax

$NOTRANSFORM ON|OFF

 

 

Remarks

By default, assembler mnemonics that are not supported for a chip or register are transformed into different assembler mnemonics.

The IN and OUT instructions for example only work on hardware registers with an address lower then 64. Most PORT registers are located in this lower address space, but there are many chips that have more ports which are located in extended memory. For such chips, using a IN or OUT on an extended address would result in a failure.

Thus the compiler changes IN into an LDS and an OUT into an STS. When a register is required, R23 will be used.

 

When you develop some ASM code, you might want to get an error when you are using an instruction the wrong way. For this purpose you can turn off the transformation.

$NOTRANSFORM OFFwill turn off the transformation. And with $NOTRANFORM ON you can turn it back on.

You should only use this option on your own code. When you use it on your whole program, it will not compile since the bascom libraries which use CBI, SBI, SBIS, IN, OUT, etc. will use the transformation.

 

 

See also

NONE

 

 

Example

NONE



Languages   English Deutsch  
Personal tools
Namespaces
Variants
Actions
Navigation
In other languages
Language