HT46R23/HT46C23
Rev. 1.60
8
May 3, 2004
If the stack is full and a non-masked interrupt takes
place, the interrupt request flag will be recorded but the
acknowledgment will be inhibited. When the stack
pointer is decremented (by RET or RETI), the interrupt
will be serviced. This feature prevents stack overflow al-
lowing the programmer to use the structure more easily.
In a similar case, if the stack is full and a CALL is sub-
sequently executed, stack overflow occurs and the first
entry will be lost (only the most recent 8 return ad-
dresses are stored).
Data Memory
RAM
The data memory is designed with 224 8 bits. The
data memory is divided into two functional groups: spe-
cial function registers and general purpose data mem-
ory (192 8). Most are read/write, but some are read
only.
The special function registers include the indirect ad-
dressing registers (00H;02H), timer/event counter
higher-order byte register (TMRH;0CH), timer/event
counter low-order byte register (TMRL;0DH),
timer/event counter control register (TMRC;0EH), pro-
gram counter lower-order byte register (PCL;06H),
memory pointer registers (MP0;01H, MP1;03H), accu-
mulator (ACC;05H), table pointer (TBLP;07H), table
higher-order byte register (TBLH;08H), status register
(STATUS;0AH), interrupt control register 0 (INTC0;
0BH), PWM data register (PWM0;1AH, PWM1;1BH),
the I
2
C Bus slave address register (HADR;20H), the I
2
C
Bus control register (HCR;21H), the I
2
C Bus status reg-
ister (HSR;22H), the I
2
C Bus data register (HDR;23H),
the A/D result lower-order byte register (ADRL;24H), the
A/D result higher-order byte register (ADRH;25H), the
A/D control register (ADCR;26H), the A/D clock setting
register (ACSR;27H), I/O registers (PA;12H, PB;14H,
PC;16H, PD;18H) and I/O control registers (PAC;13H,
PBC;15H, PCC;17H, PDC;19H). The remaining space
before the 40H is reserved for future expanded usage
and reading these locations will get 00H . The general
purpose data memory, addressed from 40H to FFH, is
used for data and control information under instruction
commands.
All of the data memory areas can handle arithmetic,
logic, increment, decrement and rotate operations di-
rectly. Except for some dedicated bits, each bit in the
data memory can be set and reset by SET [m].i and
CLR [m].i . They are also indirectly accessible through
memory pointer registers (MP0;01H/MP1;03H).
Indirect Addressing Register
Location 00H and 02H are indirect addressing registers
that are not physically implemented. Any read/write op-
eration of [00H] or [02H] will access data memory
pointed to by MP0[01H] or MP1[03H] respectively.
Reading location 00H or 02H itself indirectly will return
the result 00H. Writing indirectly result in no operation.
The memory pointer registers (MP0 and MP1 are 8-bit
registers).
Accumulator
The accumulator is closely related to ALU operations. It
is also mapped to location 05H of the data memory and
can carry out immediate data operations. The data
movement between two data memory locations must
pass through the accumulator.
# " % $ .
#
( "
7
>
>
>
0 >
>
>
2 >
/ >
3 >
8 >
>
>
>
>
>
1 >
>
>
>
0 >
>
>
2 >
/ >
3 >
8 >
>
>
>
>
>
1 >
B
! ( " )
"
)
( C
C
- " ! "
.
#
( "
7
9 8
' " ( :
1 1 >
>
>
>
>
0 >
>
>
2 >
/ >
3 >
0 1 >
! ) $ " %
) ) " ( ( $ !
"
$ ( "
! ) $ " %
) ) " ( ( $ !
"
$ ( "
*
*
* >
>
*
>
>
>
>
*
>
RAM Mapping