HT48R05A-1/HT48C05/HT48R06A-1/HT48C06
Rev. 1.10
7
June 9, 2004
struction. It will not be enabled until the TBLH has
been backed up. All table related instructions require
two cycles to complete the operation. These areas
may function as normal program memory depending
upon the requirements.
Stack Register
STACK
This is a special part of the memory which is used to
save the contents of the program counter (PC) only. The
stack is organized into 2 levels and is neither part of the
data nor part of the program space, and is neither read-
able nor writable. The activated level is indexed by the
stack pointer (SP) and is neither readable nor writeable.
At a subroutine call or interrupt acknowledgment, the
contents of the program counter are pushed onto the
stack. At the end of a subroutine or an interrupt routine,
signaled by a return instruction (RET or RETI), the pro-
gram counter is restored to its previous value from the
stack.Afterachipreset,theSPwillpointtothetopofthe
stack.
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 2 return ad-
dresses are stored).
Data Memory
RAM
The data memory is designed with 49 8 bits
(HT48R05A-1/HT48C05) or 81 8 bits (HT48R06A-1/
HT48C06). The data memory is divided into two func-
tional groups: special function registers and general
purpose data memory 32 8 (HT48R05A-1/HT48C05)
or 64 8 (HT48R06A-1/HT48C06). Most are read/write,
but some are read only.
The special function registers include the indirect ad-
dressing register (00H), timer/event counter
(TMR;0DH), timer/event counter control register
(TMRC;0EH), program counter lower-order byte regis-
ter (PCL;06H), memory pointer register (MP;01H), ac-
cumulator (ACC;05H), table pointer (TBLP;07H), table
higher-order byte register (TBLH;08H), status register
(STATUS;0AH), interrupt control register (INTC;0BH),
Watchdog Timer option setting register (WDTS;09H),
I/O registers (PA;12H, PB;14H, PC;16H) and I/O control
registers (PAC;13H, PBC;15H, PCC;17H). The remain-
ing space before the 60H (HT48R05A-1/ HT48C05) or
40H (HT48R06A-1/ HT48C06) is reserved for future ex-
panded usage and reading these locations will get
00H . The general purpose data memory, addressed
from 60H to 7FH (HT48R05A-1/ HT48C05) or 40H to
7FH (HT48R06A-1/ HT48C06), 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 register (MP;01H).
Indirect Addressing Register
Location 00H is an indirect addressing register that is
not physically implemented. Any read/write operation of
[00H] accesses data memory pointed to by MP (01H).
Reading location 00H itself indirectly will return the re-
sult 00H. Writing indirectly results in no operation.
/ % # % 0
" &
+ %
6 3
* $ % + 8
& % ( ' 0
" &
+ %
>
>
>
3 >
>
1 >
2 >
>
4 >
5 >
>
>
>
>
>
9 >
>
>
>
3 >
>
1 >
2 >
>
4 >
5 >
>
>
>
>
>
9 >
9 >
# , ' % ( $
, , % + + ' #
%
' + $ %
-
-
- >
A
# " + % ,
% , + B
B
1 9 >
2
>
>
RAM Mapping for HT48R05A-1/HT48C05