ht82j30r Holtek Semiconductor Inc., ht82j30r Datasheet - Page 7

no-image

ht82j30r

Manufacturer Part Number
ht82j30r
Description
Ht82j30r/ht82j30a -- 16 Channel A/d Mcu With Spi Interface
Manufacturer
Holtek Semiconductor Inc.
Datasheet

Available stocks

Company
Part Number
Manufacturer
Quantity
Price
Part Number:
HT82J30R
Manufacturer:
HOLTEK
Quantity:
155
microcontroller manages program control by loading the
required address into the Program Counter. For condi-
tional skip instructions, once the condition has been
met, the next instruction, which has already been
fetched during the present instruction execution, is dis-
carded and a dummy cycle takes its place while the cor-
rect instruction is obtained.
The lower byte of the Program Counter, known as the
Program Counter Low register or PCL, is available for
program control and is a readable and writeable register.
By transferring data directly into this register, a short pro-
gram jump can be executed directly, however, as only
this low byte is available for manipulation, the jumps are
limited to the present page of memory, that is 256 loca-
tions. When such program jumps are executed it should
also be noted that a dummy cycle will be inserted.
The lower byte of the Program Counter is fully accessi-
ble under program control. Manipulating the PCL might
cause program branching, so an extra cycle is needed
to pre-fetch. Further information on the PCL register can
be found in the Special Function Register section.
Stack
This is a special part of the memory which is used to
save the contents of the Program Counter only. The
stack has 6 levels and is neither part of the data nor part
of the program space, and is neither readable nor
writeable. The activated level is indexed by the Stack
Pointer, SP, and is neither readable nor writeable. At a
subroutine call or interrupt acknowledge signal, the con-
tents of the Program Counter are pushed onto the stack.
At the end of a subroutine or an interrupt routine, sig-
naled by a return instruction, RET or RETI, the Program
Note:
Rev. 1.10
Initial Reset
INT0 External Interrupt
INT1 External Interrupt
T i m e r / E v e n t
Overflow
A/D Converter Interrupt
SPI_A Interrupt
SPI_B Interrupt
Skip
Loading PCL
Jump, Call Branch
Return from Subroutine
PC11~PC8: Current Program Counter bits
@7~@0: PCL bits
#11~#0: Instruction code address bits
S11~S0: Stack register bits
Mode
C o u n t e r
PC11 PC10 PC9
S11
b11
#11
0
0
0
0
0
0
0
b10
S10
#10
0
0
0
0
0
0
0
b9
S9
#9
0
0
0
0
0
0
0
Program Counter
PC8
b8
S8
#8
0
0
0
0
0
0
0
7
@7
b7
S7
#7
Program Counter Bits
0
0
0
0
0
0
0
Counter is restored to its previous value from the stack.
After a device reset, the Stack Pointer will point to the
top of the stack.
If the stack is full and an enabled interrupt takes place,
the interrupt request flag will be recorded but the ac-
knowledge signal 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.
However, when the stack is full, a CALL subroutine in-
struction can still be executed which will result in a stack
overflow. Precautions should be taken to avoid such
cases which might cause unpredictable program
branching.
Arithmetic and Logic Unit - ALU
The arithmetic-logic unit or ALU is a critical area of the
microcontroller that carries out arithmetic and logic op-
erations of the instruction set. Connected to the main
microcontroller data bus, the ALU receives related in-
struction codes and performs the required arithmetic or
logical operations after which the result will be placed in
the specified register. As these ALU calculation or oper-
ations may result in carry, borrow or other status
Program Counter + 2
@6
b6
S6
#6
0
0
0
0
0
0
0
@5
b5
S5
#5
0
0
0
0
0
0
0
@4
b4
S4
#4
0
0
1
0
0
1
1
HT82J30R/HT82J30A
@3
b3
#3
S3
0
0
1
1
1
0
0
@2
b2
#2
S2
0
1
0
0
1
0
1
March 13, 2008
@1
b1
#1
S1
0
0
0
0
0
0
0
@0
b0
#0
S0
0
0
0
0
0
0
0

Related parts for ht82j30r