String placement – Zilog Z8F0130 User Manual
Page 228
![background image](https://www.manualsdir.com/files/771166/content/doc228.png)
Using the ANSI C-Compiler
UM013037-1212
204
Zilog Developer Studio II – Z8 Encore!
User Manual
#pragma _monitor
void my_kernel_fn (void)
{ … }
This feature does not work properly for functions that are also declared as interrupt service
routines. Avoid combining the use of the
_monitor
and interrupt qualifiers for the same
function.
The
#pragma _monitor
declaration has function scope and will affect the next function
definition (as opposed to a function declaration, that is, a function prototype) that the com-
piler encounters. For this reason, quite unexpected results can ensue if this pragma is used
in a function prototype, especially when function declarations and definitions are grouped
separately as is common practice. In the case of
_monitor
, these results might cause seri-
ous problems in your application by disabling interrupts in a function in which this was not
your intention. Therefore, it is recommended that you avoid using this
#pragma
in func-
tion prototypes.
String Placement
When string constants (literals) such as
"mystring"
are used in a C program, they are
stored by the C-Compiler in the RData address space for the small memory model and in
the EData address space for the large memory model. However, sometimes this default
placement of string constants does not allow you adequate control over your memory use.
Therefore, language extensions are provided to give you more control over string place-
ment:
•
N"mystring"
This defines a
near
string constant. The string is stored in RData. The address of the
string is a
near
pointer.
•
F"mystring"
This defines a far string constant. The string is stored in EData. The address of the
string is a far pointer.
•
R"mystring"
This defines a
rom
string constant. The string is stored in ROM. The address of the
string is a
rom
pointer.
The following is an example of string placement:
#include
void funcn (near char *str)
{
while (*str)
putch (*str++);
Note:
- Z8F0131 Z8F0230 Z8F0231 Z8F0430 Z8F0431 Z8F043A Z8F0830 Z8F0831 Z8F083A Z8F1232 Z8F1233 Z8F0113 Z8F011A Z8F0123 Z8F012A Z8F0213 Z8F021A Z8F0223 Z8F022A Z8F0411 Z8F0412 Z8F0413 Z8F041A Z8F0421 Z8F0422 Z8F0423 Z8F042A Z8F0811 Z8F0812 Z8F0813 Z8F081A Z8F0821 Z8F0822 Z8F0823 Z8F082A Z8F0880 Z8F1621 Z8F1622 Z8F1680 Z8F1681 Z8F1682 Z8F2421 Z8F2422 Z8F2480 Z8F3221 Z8F3222 Z8F3281 Z8F3282 Z8F4821 Z8F4822 Z8F4823 Z8F6081 Z8F6082 Z8F6421 Z8F6422 Z8F6423 Z8F6481 Z8F6482 Z8FS021A ZMOT1AHH Z8FS040B ZMOT0BHH ZMOT0BSB Z8FMC04 Z8FMC08 Z8FMC16