# **FM8P59** # EPROM/ROM-Based 8-Bit Microcontroller #### **Devices Included in this Data Sheet:** FM8P59AE: 28-pin EPROM device FM8P59BE: 32-pin EPROM device FM8P59A: 28-pin Mask ROM device FM8P59B: 32-pin Mask ROM device #### **FEATURES** - · Only 47 single word instructions - · All instructions are single cycle except for program branches which are two-cycle - 13-bit wide instructions - · All ROM/EPROM area GOTO/FGOTO instruction - · All ROM/EPROM area subroutine CALL/FCALL instruction - 8-bit wide data path - 5-level deep hardware stack - 4K x 13 bits on chip EPROM/ROM - 144 x 8 bits on chip general purpose registers (SRAM) - Operating speed: DC-20 MHz clock input DC-100 ns instruction cycle - · Direct, indirect addressing modes for data accessing - 8-bit real time clock/counter (Timer0) with 8-bit programmable prescaler - Internal Power-on Reset (POR) - Built-in Low Voltage Detector (LVD) for Brown-out Reset (BOR) - Power-up Reset Timer (PWRT) and Oscillator Start-up Timer(OST) - On chip Watchdog Timer (WDT) with internal oscillator for reliable operation and soft-ware watch-dog enable/disable control - · Three I/O ports IOA, IOB and IOC with independent direction control - 16 soft-ware control pull-high pins: Port B/Port C - 8 soft-ware control pull-down pins:IOA0~A3/IOB0~B3 - 2 soft-ware control open-drain pins: IOC6/IOC7 - One internal interrupt source: Timer0 overflow; Two external interrupt source: INT0 pin, INT1 pin - · Wake-up from SLEEP by Port B/IOC4/IOC5 input falling - Power saving SLEEP mode - · Programmable Code Protection - · Selectable oscillator options: - ERC: External Resistor/Capacitor Oscillator - XT: Crystal/Resonator Oscillator - HF: High Frequency Crystal/Resonator Oscillator - LF: Low Frequency Crystal Oscillator - · Wide-operating voltage range: - EPROM : 2.3V to 5.5V - ROM: 2.3V to 5.5V This datasheet contains new product information. Feeling Technology reserves the rights to modify the product specification without notice. No liability is assumed as a result of the use of this product. No rights under any patent accompany the sales of the product. ### **GENERAL DESCRIPTION** The FM8P59 series is a family of low-cost, high speed, high noise immunity, EPROM/ROM-based 8-bit CMOS microcontrollers. It employs a RISC architecture with only 47 instructions. All instructions are single cycle except for program branches which take two cycles. The easy to use and easy to remember instruction set reduces development time significantly. The FM8P59 series consists of Power-on Reset (POR), Brown-out Reset (BOR), Power-up Reset Timer (PWRT), Oscillator Start-up Timer(OST), Watchdog Timer, EPROM/ROM, SRAM, tri-state I/O port, I/O pull-high/open-drain/pull-down control, Power saving SLEEP mode, real time programmable clock/counter, Interrupt, Wake-up from SLEEP mode, and Code Protection for EPROM products. There are four oscillator configurations to choose from, including the power-saving LP (Low Power) oscillator and cost saving RC oscillator. The FM8P59 series address 4K×13 of program memory. The FM8P59 series can directly or indirectly address its register files and data memory. All special function registers including the program counter are mapped in the data memory. #### **BLOCK DIAGRAM** # **PIN CONNECTION** | PDIP, SOP | | | | | |------------|----|----------|----|-------| | | | | | | | T0CKI□ | 1 | | 28 | □RSTB | | Vdd□ | 2 | | 27 | □osci | | NC□ | 3 | | 26 | □osco | | Vss⊑ | 4 | | 25 | □IOC7 | | INT1□ | 5 | | 24 | □IOC6 | | IOA0□ | 6 | | 23 | □IOC5 | | IOA1□ | 7 | FM8P59A | 22 | □IOC4 | | IOA2□ | 8 | FM8P59AE | 21 | □IOC3 | | IOA3□ | 9 | | 20 | □IOC2 | | IOB0/INT0□ | 10 | | 19 | □IOC1 | | IOB1□ | 11 | | 18 | □10C0 | | IOB2□ | 12 | | 17 | □IOB7 | | IOB3□ | 13 | | 16 | □IOB6 | | IOB4□ | 14 | | 15 | □IOB5 | | | | | | | | SSOP | | | |--------------|----------|------------------| | | | | | Vss □1 | | 28□RSTB | | T0CKI □2 | | 27 OSCI | | Vdd □3 | | 26⊐osco | | INT1 ☐4 | | 25 10C7 | | IOA0 □5 | | 24 IOC6 | | IOA1 ☐6 | | 23 10C5 | | IOA2 ☐7 | FM8P59A | 22 10C4 | | IOA3 ☐8 | FM8P59AE | 21 10C3 | | IOB0/INT0 □9 | | 20 10C2 | | IOB1 ☐10 | | 19 10C1 | | IOB2 ☐ 11 | | 18 DIOC0 | | IOB3 ☐ 12 | | 17 10B7 | | IOB4 ☐ 13 | | 16 <b>□</b> 10B6 | | Vss □14 | | 15 10B5 | | | | | # **PIN DESCRIPTIONS** #### FM8P59A/FM8P59AE | Name | I/O | Description | |-------------|-----|---------------------------------------------------------------------------------------| | IOA0 ~ IOA3 | I/O | IOA0 ~ IOA3 as bi-direction I/O port | | IOB0/INT0 | I/O | Bi-direction I/O pin with system wake-up function / External interrupt input 0 | | IOB1 ~ IOB7 | I/O | Bi-direction I/O port with system wake-up function | | IOC0 ~ IOC7 | I/O | Bi-direction I/O port | | INT1 | I | External interrupt input 1 triggered by falling edge | | T0CKI | | Clock input to Timer0. Must be tied to Vss or Vdd, if not in use, to reduce current | | TUCKI | I | consumption | | RSTB | I | System clear (RESET) input. This pin is an active low RESET to the device. | | OSCI | | X'tal type: Oscillator crystal input | | 0301 | l | RC type: Clock input of RC oscillator | | osco | 0 | X'tal type: Oscillator crystal output. | | 0300 | U | RC mode: Outputs with 1/4 the frequency of OSCI to denotes the instruction cycle rate | | Vdd | - | Positive supply | | Vss | - | Ground | Legend: I=input, O=output, I/O=input/output ## FM8P59B/FM8P59BE | Name | I/O | Description | |-------------|-----|---------------------------------------------------------------------------------------| | IOA0 ~ IOA7 | I/O | Bi-direction I/O port | | IOB0/INT0 | I/O | Bi-direction I/O pin with system wake-up function / External interrupt input 0 | | IOB1 ~ IOB7 | I/O | Bi-direction I/O port with system wake-up function | | IOC0 ~ IOC7 | I/O | Bi-direction I/O port | | INT1 | I | External interrupt input 1 triggered by falling edge | | T0CKI | | Clock input to Timer0. Must be tied to Vss or Vdd, if not in use, to reduce current | | TUCKI | I | consumption | | RSTB | I | System clear (RESET) input. This pin is an active low RESET to the device. | | OSCI | | X'tal type: Oscillator crystal input | | 0301 | I | RC type: Clock input of RC oscillator | | osco | 0 | X'tal type: Oscillator crystal output. | | 0300 | U | RC mode: Outputs with 1/4 the frequency of OSCI to denotes the instruction cycle rate | | Vdd | - | Positive supply | | Vss | - | Ground | Legend: I=input, O=output, I/O=input/output #### 1.0 MEMORY ORGANIZATION FM8P59 series memory is organized into program memory and data memory. #### 1.1 Program Memory Organization The FM8P59 series have an 12-bit Program Counter capable of addressing a 4K×13 program memory space. The RESET vector for the FM8P59 series is at FFFh. The H/W interrupt vector is at 008h. And the S/W interrupt vector is at 002h. FM8P59 series has program memory size greater than 1K words, but the CALL and GOTO instructions only have a 10-bit address range. This 10-bit address range allows a branch within a 1K program memory page size. To allow CALL and GOTO instructions to address the entire 4K program memory address range for FM8P59 series, there is another two bits to specify the program memory page. This paging bit comes from the PCHBUF<3:2> bits. When doing a CALL or GOTO instruction, the user must ensure that page bit PCHBUF<3:2> are programmed so that the desired program memory page is addressed. When one of the return instructions is executed, the entire 12-bit PC is POPed from the stack. Therefore, manipulation of the PCHBUF<3:2> is not required for the return instructions. User can use "PAGE" instruction to change memory page and maintains the program memory page. Otherwise, user can use "FCALL(far call)/FGOTO(far goto)" instructions to program user's code. FIGURE 1.1: Program Memory Map and STACK FM8P59 Series ## 1.2 Data Memory Organization Data memory is composed of Special Function Registers and General Purpose Registers. The General Purpose Registers are accessed either directly or indirectly through the FSR register. The Special Function Registers are registers used by the CPU and peripheral functions to control the operation of the device. In FM8P59 series, the data memory is partitioned into four banks. Switching between these banks requires the RP1 and RP0 bits in the FSR register to be configured for the desired bank. User can use "BANK" instruction to change the data memory bank. TABLE 1.1: Registers File Map for FM8P59 Series | FSR<7:6> | isters File Map 1 | Description | | | | | | | | | |----------|-------------------|--------------------|--------------------|--------------------|--|--|--|--|--|--| | Address | 0 0<br>Bank 0 | 0 1<br>Bank 1 | 1 0<br>Bank 2 | 1 1<br>Bank 3 | | | | | | | | 00h | INDF | | | | | | | | | | | 01h | TMR0 | | | | | | | | | | | 02h | PCL | | | | | | | | | | | 03h | STATUS | | | | | | | | | | | 04h | FSR | | | | | | | | | | | 05h | PORTA | | | | | | | | | | | 06h | PORTB | | | | | | | | | | | 07h | PORTC | | | | | | | | | | | 08h | PCON | | | | | | | | | | | 09h | WUCON | | | | | | | | | | | 0Ah | PCHBUF | Memory | back to address i | n Bank 0 | | | | | | | | 0Bh | PDCON | | | | | | | | | | | 0Ch | BPHCON | | | | | | | | | | | 0Dh | CPHCON | | | | | | | | | | | 0Eh | INTEN | | | | | | | | | | | 0Fh | INTFLAG | | | | | | | | | | | | | | | | | | | | | | | 10h | General | | | | | | | | | | | | Purpose | | | | | | | | | | | 1Fh | Registers | | | | | | | | | | | | | | <u> </u> | T | | | | | | | | 20h | General | Conoral | Conoral | Conoral | | | | | | | | 2011 | Purpose | General<br>Purpose | General<br>Purpose | General<br>Purpose | | | | | | | | ا<br>3Fh | Registers | Registers | Registers | Registers | | | | | | | | 31 11 | rvegisters | rvegisters | registers | registers | | | | | | | | IN/A | OPTION | |------|--------| | | | | | | | | | | 05h | IOSTA | | 06h | IOSTB | **IOSTC** 07h # TABLE 1.2: The Registers Controlled by OPTION or IOST Instructions | Address | Name | В7 | B6 | B5 | B4 | В3 | B2 | B1 | В0 | | | |---------|--------|----|-----------------------------|------|-------------|-------------|-----|-----|-----|--|--| | N/A (w) | OPTION | - | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | | | | 05h (w) | IOSTA | | Port A I/O Control Register | | | | | | | | | | 06h (w) | IOSTB | | Port B I/O Control Register | | | | | | | | | | 07h (w) | IOSTC | | | Po | rt C I/O Co | ntrol Regis | ter | | | | | ## **TABLE 1.3: Operational Registers Map** | Address Name B7 B6 B5 B4 B3 B2 B1 B0 00h (r/w) INDF Uses contents of FSR to address data memory (not a physical register) 01h (r/w) TMR0 8-bit real-time clock/counter 02h (r/w) PCL Low order 8 bits of PC 03h (r/w) STATUS GP2 GP1 GP0 TO PD Z DC C 04h (r/w) FSR RP1 RP0 Indirect data memory address pointer 05h (r/w) PORTA IOA7 IOA6 IOA5 IOA4 IOA3 IOA2 IOA1 IOA0 06h (r/w) PORTB IOB7 IOB6 IOB5 IOB4 IOB3 IOB2 IOB1 IOB0 07h (r/w) PORTC IOC7 IOC6 IOC5 IOC4 IOC3 IOC2 IOC1 IOC0 08h (r/w) PCN WUB7 /WUB6 /WUB5 /WUB4 /WUB3 /WUB2 /WUB1 /WUB0 0 | | ABEL 110. Operational Registers map | | | | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------------------------------|-------|-----------------------------------------------------------------------|-------|--------------|--------------|-------------|-------------|--------|--|--| | 01h (r/w) TMR0 8-bit real-time clock/counter 02h (r/w) PCL Low order 8 bits of PC 03h (r/w) STATUS GP2 GP1 GP0 TO PD Z DC C 04h (r/w) FSR RP1 RP0 Indirect data memory address pointer 05h (r/w) PORTA IOA7 IOA6 IOA5 IOA4 IOA3 IOA2 IOA1 IOA0 06h (r/w) PORTB IOB7 IOB6 IOB5 IOB4 IOB3 IOB2 IOB1 IOB0 07h (r/w) PORTC IOC7 IOC6 IOC5 IOC4 IOC3 IOC2 IOC1 IOC0 08h (r/w) PCON WDTE EIS LVDTE ROC - - ODC67 /WUB5 09h (r/w) WUCON /WUB7 /WUB6 /WUB5 /WUB4 /WUB3 /WUB2 /WUB1 /WUB0 0Ah (r/w) PCHBUF - - - Upper 4 bits Buffer of PC <t< td=""><td>Address</td><td>Name</td><td>B7</td><td>В6</td><td>B5</td><td>B4</td><td>В3</td><td>B2</td><td>B1</td><td>В0</td></t<> | Address | Name | B7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | | | | 02h (r/w) PCL Low order 8 bits of PC 03h (r/w) STATUS GP2 GP1 GP0 TO PD Z DC C 04h (r/w) FSR RP1 RP0 Indirect data memory address pointer 05h (r/w) PORTA IOA7 IOA6 IOA5 IOA4 IOA3 IOA2 IOA1 IOA0 06h (r/w) PORTB IOB7 IOB6 IOB5 IOB4 IOB3 IOB2 IOB1 IOB0 07h (r/w) PORTC IOC7 IOC6 IOC5 IOC4 IOC3 IOC2 IOC1 IOC0 08h (r/w) PCON WDTE EIS LVDTE ROC - - ODC67 /WUC45 09h (r/w) WUCON /WUB7 /WUB6 /WUB5 /WUB4 /WUB3 /WUB2 /WUB1 /WUB0 0Ah (r/w) PCHBUF - - - Upper 4 bits Buffer of PC 0Bh (r/w) PDCON /PDB3 /PDB2 /PDB1 /PDB0 | 00h (r/w) | INDF | Us | Uses contents of FSR to address data memory (not a physical register) | | | | | | | | | | 03h (r/w) STATUS GP2 GP1 GP0 TO PD Z DC C 04h (r/w) FSR RP1 RP0 Indirect data memory address pointer 05h (r/w) PORTA IOA7 IOA6 IOA5 IOA4 IOA3 IOA2 IOA1 IOA0 06h (r/w) PORTB IOB7 IOB6 IOB5 IOB4 IOB3 IOB2 IOB1 IOB0 07h (r/w) PORTC IOC7 IOC6 IOC5 IOC4 IOC3 IOC2 IOC1 IOC0 08h (r/w) PCON WDTE EIS LVDTE ROC - - ODC67 /WUC45 09h (r/w) WUCON /WUB7 /WUB6 /WUB5 /WUB4 /WUB3 /WUB2 /WUB1 /WUB0 0Ah (r/w) PCHBUF - - - - Upper 4 bits Buffer of PC 0Bh (r/w) PDCON /PDB3 /PDB2 /PDB1 /PDB0 /PDA3 /PDA2 /PDA1 / | 01h (r/w) | TMR0 | | | 8-b | it real-time | clock/cour | nter | | | | | | 04h (r/w) FSR RP1 RP0 Indirect data memory address pointer 05h (r/w) PORTA IOA7 IOA6 IOA5 IOA4 IOA3 IOA2 IOA1 IOA0 06h (r/w) PORTB IOB7 IOB6 IOB5 IOB4 IOB3 IOB2 IOB1 IOB0 07h (r/w) PORTC IOC7 IOC6 IOC5 IOC4 IOC3 IOC2 IOC1 IOC0 08h (r/w) PCON WDTE EIS LVDTE ROC - - ODC67 /WUC45 09h (r/w) WUCON /WUB7 /WUB6 /WUB5 /WUB4 /WUB3 /WUB2 /WUB1 /WUB0 0Ah (r/w) PCHBUF - - - - Upper 4 bits Buffer of PC 0Bh (r/w) PDCON /PDB3 /PDB2 /PDB1 /PDB0 /PDA3 /PDA2 /PDA1 /PDA0 0Ch (r/w) BPHCON /PHB7 /PHB6 /PHB5 /PHC4 /PHC3 /PHC2 / | 02h (r/w) | PCL | | | | Low order | 8 bits of PC | ) | | | | | | 05h (r/w) PORTA IOA7 IOA6 IOA5 IOA4 IOA3 IOA2 IOA1 IOA0 06h (r/w) PORTB IOB7 IOB6 IOB5 IOB4 IOB3 IOB2 IOB1 IOB0 07h (r/w) PORTC IOC7 IOC6 IOC5 IOC4 IOC3 IOC2 IOC1 IOC0 08h (r/w) PCON WDTE EIS LVDTE ROC - - ODC67 /WUC45 09h (r/w) WUCON /WUB7 /WUB6 /WUB5 /WUB4 /WUB3 /WUB2 /WUB1 /WUB0 0Ah (r/w) PCHBUF - - - - Upper 4 bits Buffer of PC 0Bh (r/w) PDCON /PDB3 /PDB2 /PDB1 /PDB0 /PDA3 /PDA2 /PDA1 /PDA0 0Ch (r/w) BPHCON /PHB7 /PHB6 /PHB5 /PHC4 /PHC3 /PHC2 /PHC1 /PHC0 0Eh (r/w) INTEN GIE - | 03h (r/w) | STATUS | GP2 | GP1 | GP0 | TO | PD | Z | DC | С | | | | 06h (r/w) PORTB IOB7 IOB6 IOB5 IOB4 IOB3 IOB2 IOB1 IOB0 07h (r/w) PORTC IOC7 IOC6 IOC5 IOC4 IOC3 IOC2 IOC1 IOC0 08h (r/w) PCON WDTE EIS LVDTE ROC - - ODC67 /WUC45 09h (r/w) WUCON /WUB7 /WUB6 /WUB5 /WUB4 /WUB3 /WUB2 /WUB1 /WUB0 0Ah (r/w) PCHBUF - - - - Upper 4 bits Buffer of PC 0Bh (r/w) PDCON /PDB3 /PDB2 /PDB1 /PDB0 /PDA3 /PDA2 /PDA1 /PDA0 0Ch (r/w) BPHCON /PHB7 /PHB6 /PHB5 /PHB4 /PHB3 /PHB2 /PHC1 /PHC0 0Dh (r/w) CPHCON /PHC7 /PHC6 /PHC5 /PHC4 /PHC3 /PHC2 /PHC1 /PHC0 0Eh (r/w) INTEN GIE - | 04h (r/w) | FSR | RP1 | RP0 | | Indirect | data memo | ory address | pointer | | | | | 07h (r/w) PORTC IOC7 IOC6 IOC5 IOC4 IOC3 IOC2 IOC1 IOC0 08h (r/w) PCON WDTE EIS LVDTE ROC - - ODC67 /WUC45 09h (r/w) WUCON /WUB7 /WUB6 /WUB5 /WUB4 /WUB3 /WUB2 /WUB1 /WUB0 0Ah (r/w) PCHBUF - - - - Upper 4 bits Buffer of PC 0Bh (r/w) PDCON /PDB3 /PDB2 /PDB1 /PDB0 /PDA3 /PDA2 /PDA1 /PDA0 0Ch (r/w) BPHCON /PHB7 /PHB6 /PHB5 /PHB4 /PHB3 /PHB2 /PHB1 /PHB0 0Dh (r/w) CPHCON /PHC7 /PHC6 /PHC5 /PHC4 /PHC3 /PHC2 /PHC1 /PHC0 0Eh (r/w) INTEN GIE - - - INT1IE INT0IE - TOIE | 05h (r/w) | PORTA | IOA7 | IOA6 | IOA5 | IOA4 | IOA3 | IOA2 | IOA1 | IOA0 | | | | 08h (r/w) PCON WDTE EIS LVDTE ROC - - ODC67 /WUC45 09h (r/w) WUCON /WUB7 /WUB6 /WUB5 /WUB4 /WUB3 /WUB2 /WUB1 /WUB0 0Ah (r/w) PCHBUF - - - - Upper 4 bits Buffer of PC 0Bh (r/w) PDCON /PDB3 /PDB2 /PDB1 /PDB0 /PDA3 /PDA2 /PDA1 /PDA0 0Ch (r/w) BPHCON /PHB7 /PHB6 /PHB5 /PHB4 /PHB3 /PHB2 /PHB1 /PHC0 0Dh (r/w) CPHCON /PHC7 /PHC6 /PHC5 /PHC4 /PHC3 /PHC2 /PHC1 /PHC0 0Eh (r/w) INTEN GIE - - - INT1IE INT0IE - T0IE | 06h (r/w) | PORTB | IOB7 | IOB6 | IOB5 | IOB4 | IOB3 | IOB2 | IOB1 | IOB0 | | | | 09h (r/w) WUCON /WUB7 /WUB6 /WUB5 /WUB4 /WUB3 /WUB2 /WUB1 /WUB0 0Ah (r/w) PCHBUF - - - - Upper 4 bits Buffer of PC 0Bh (r/w) PDCON /PDB3 /PDB2 /PDB1 /PDB0 /PDA3 /PDA2 /PDA1 /PDA0 0Ch (r/w) BPHCON /PHB7 /PHB6 /PHB5 /PHB4 /PHB3 /PHB2 /PHB1 /PHB0 0Dh (r/w) CPHCON /PHC7 /PHC6 /PHC5 /PHC4 /PHC3 /PHC2 /PHC1 /PHC0 0Eh (r/w) INTEN GIE - - INT1IE INT0IE - T0IE | 07h (r/w) | PORTC | IOC7 | IOC6 | IOC5 | IOC4 | IOC3 | IOC2 | IOC1 | IOC0 | | | | OAh (r/w) PCHBUF - - - - Upper 4 bits Buffer of PC 0Bh (r/w) PDCON /PDB3 /PDB2 /PDB1 /PDB0 /PDA3 /PDA2 /PDA1 /PDA0 0Ch (r/w) BPHCON /PHB7 /PHB6 /PHB5 /PHB4 /PHB3 /PHB2 /PHB1 /PHB0 0Dh (r/w) CPHCON /PHC7 /PHC6 /PHC5 /PHC4 /PHC3 /PHC2 /PHC1 /PHC0 0Eh (r/w) INTEN GIE - - - INT1IE INT0IE - T0IE | 08h (r/w) | PCON | WDTE | EIS | LVDTE | ROC | - | - | ODC67 | /WUC45 | | | | OBh (r/w) PDCON /PDB3 /PDB2 /PDB1 /PDB0 /PDA3 /PDA2 /PDA1 /PDA0 OCh (r/w) BPHCON /PHB7 /PHB6 /PHB5 /PHB4 /PHB3 /PHB2 /PHB1 /PHB0 ODh (r/w) CPHCON /PHC7 /PHC6 /PHC5 /PHC4 /PHC3 /PHC2 /PHC1 /PHC0 OEh (r/w) INTEN GIE - - - INT1IE INT0IE - T0IE | 09h (r/w) | WUCON | /WUB7 | /WUB6 | /WUB5 | /WUB4 | /WUB3 | /WUB2 | /WUB1 | /WUB0 | | | | OCh (r/w) BPHCON /PHB7 /PHB6 /PHB5 /PHB4 /PHB3 /PHB2 /PHB1 /PHB0 0Dh (r/w) CPHCON /PHC7 /PHC6 /PHC5 /PHC4 /PHC3 /PHC2 /PHC1 /PHC0 0Eh (r/w) INTEN GIE - - - INT1IE INT0IE - T0IE | 0Ah (r/w) | PCHBUF | - | - | - | - | U | pper 4 bits | Buffer of F | C | | | | ODh (r/w) CPHCON /PHC7 /PHC6 /PHC5 /PHC4 /PHC3 /PHC2 /PHC1 /PHC0 0Eh (r/w) INTEN GIE - - - INT1IE INT0IE - T0IE | 0Bh (r/w) | PDCON | /PDB3 | /PDB2 | /PDB1 | /PDB0 | /PDA3 | /PDA2 | /PDA1 | /PDA0 | | | | 0Eh (r/w) INTEN GIE INT1IE INT0IE - T0IE | 0Ch (r/w) | BPHCON | /PHB7 | /PHB6 | /PHB5 | /PHB4 | /PHB3 | /PHB2 | /PHB1 | /PHB0 | | | | | 0Dh (r/w) | CPHCON | /PHC7 | /PHC6 | /PHC5 | /PHC4 | /PHC3 | /PHC2 | /PHC1 | /PHC0 | | | | 0Fh (r/w) INTFLAG - - - INT1IF INT0IF - T0IF | 0Eh (r/w) | INTEN | GIE | - | - | - | INT1IE | INT0IE | - | T0IE | | | | | 0Fh (r/w) | INTFLAG | - | - | - | - | INT1IF | INT0IF | - | TOIF | | | Legend: - = unimplemented, read as '0', ## 2.0 FUNCTIONAL DESCRIPTIONS #### 2.1 Operational Registers #### 2.1.1 INDF (Indirect Addressing Register) | Address | Name | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | |-----------|------|----|-------------|-----------|------------|------------|--------------|-------------|------| | 00h (r/w) | INDF | Us | es contents | of FSR to | address da | ata memory | y (not a phy | sical regis | ter) | The INDF Register is not a physical register. Any instruction accessing the INDF register can actually access the register pointed by FSR Register. Reading the INDF register itself indirectly (FSR="0") will read 00h. Writing to the INDF register indirectly results in a no-operation (although status bits may be affected). The bits 5-0 of FSR register are used to select up to 64 registers (address: 00h ~ 3Fh). In FM8P59 series, the data memory is partitioned into four banks. Switching between these banks requires the RP1 and RP0 bits in the FSR register to be configured for the desired bank. The lower locations of each bank are reserved for the Special Function Registers. Above the Special Function Registers are General Purpose Registers. All Special Function Registers and some of General Purpose Registers from other banks are mirrored in bank 0 for code reduction and quicker access. | Accessed<br>Bank | RP1:RP0 | | | | |------------------|---------|--|--|--| | 0 | 0 0 | | | | | 1 | 0 1 | | | | | 2 | 1 0 | | | | | 3 | 1 1 | | | | #### **EXAMPLE 2.1: INDIRECT ADDRESSING** - Register file 38 contains the value 10h - Register file 39 contains the value 0Ah - Load the value 38 into the FSR Register - A read of the INDF Register will return the value of 10h - Increment the value of the FSR Register by one (@FSR=39h) - · A read of the INDR register now will return the value of 0Ah. FIGURE 2.2: Direct/Indirect Addressing for FM8P59 Series ## 2.1.2 TMR0 (Time Clock/Counter register) | Address | Name | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | |-----------|------|----|----|-----|--------------|------------|------|----|----| | 01h (r/w) | TMR0 | | | 8-b | it real-time | clock/cour | nter | | | The Timer0 is a 8-bit timer/counter. The clock source of Timer0 can come from the instruction cycle clock or by an external clock source (T0CKI pin) defined by T0CS bit (OPTION<5>). If T0CKI pin is selected, the Timer0 is increased by T0CKI signal rising/falling edge (selected by T0SE bit (OPTION<4>)). The prescaler is assigned to Timer0 by clearing the PSA bit (OPTION<3>). In this case, the prescaler will be cleared when TMR0 register is written with a value. # 2.1.3 PCL (Low Bytes of Program Counter) & Stack | Address | Name | B7 | B6 | B5 | B4 | B3 | B2 | B1 | В0 | |-----------|------|----|----|----|-------------|--------------|----|----|----| | 02h (r/w) | PCL | | | | Low order 8 | B bits of PC | ; | | | FM8P59 devices have a 12-bit wide Program Counter (PC) and five-level deep 12-bit hardware push/pop stack. The low byte of PC is called the PCL register. This register is readable and writable. The high byte of PC is called the PCH register. This register contains the PC<11:8> bits and is not directly readable or writable. All updates to the PCH register go through the PCHBUF register. As a program instruction is executed, the Program Counter will contain the address of the next program instruction to be executed. The PC value is increased by one, every instruction cycle, unless an instruction changes the PC. For a GOTO instruction, the PC<9:0> is provided by the GOTO instruction word. The PC<11:10> is updated from the PCHBUF<3:2>. The PCL register is mapped to PC<7:0>, and the PCHBUF register is not updated. For a CALL instruction, the PC<9:0> is provided by the CALL instruction word. The PC<11:10> is updated from the PCHBUF<3:2>. The next PC will be loaded (PUSHed) onto the top of STACK. The PCL register is mapped to PC<7:0>, and the PCHBUF register is not updated. For a FGOTO instruction, the PC<11:0> is provided by the FGOTO instruction word. The PCL register is mapped to PC<7:0>, the PCHBUF<3:2> bits is also updated from the FGOTO instruction word, and the PCHBUF<1:0> bits are not updated. For a FCALL instruction, the PC<11:0> is provided by the FCALL instruction word. The next PC will be loaded (PUSHed) onto the top of STACK. The PCL register is mapped to PC<7:0>, the PCHBUF<3:2> bits is also updated from the FCALL instruction word, and the PCHBUF<1:0> bits are not updated. For a RETIA, RETFIE, or RETURN instruction, the PC are updated (POPed) from the top of STACK. The PCL register is mapped to PC<7:0>, and the PCHBUF register is not updated. For any instruction where the PCL is the destination (excluding TBL instruction), the PC<7:0> is provided by the instruction word or ALU result. However, the PC<11:8> will come from the PCHBUF<3:0> bits (PCHBUF $\rightarrow$ PCH). For TBL instruction, the PC<7:0> is provided by the ALU result, and the PC<9:8> are not changed. The PC<11:10> will come from the PCH<3:2> bits. PCHBUF register is never updated with the contents of PCH. ## FIGURE 2.2: Loading of PC in Different Situations #### Situation 1: GOTO Instruction #### Situation 2: CALL Instruction #### Situation 3: FGOTO Instruction ## Situation 4: FCALL Instruction Situation 6: Instruction with PCL as destination (except TBL instruction) Situation 7: TBL Instruction Note: PCHBUF is used for instruction with PCL as destination, GOTO and CALL instructions. ## 2.1.4 STATUS (Status Register) | P | Address | Name | B7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | |---|-----------|--------|-----|-----|-----|----|----|----|----|----| | 0 | )3h (r/w) | STATUS | GP2 | GP1 | GP0 | TO | PD | Z | DC | С | This register contains the arithmetic status of the ALU, the RESET status. If the STATUS Register is the destination for an instruction that affects the Z, DC or C bits, then the <u>write</u> to <u>these</u> three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the $\overline{\text{TO}}$ and $\overline{\text{PD}}$ bits are not writable. Therefore, the result of an instruction with the STATUS Register as destination may be different than intended. For example, CLRR STATUS will clear the upper three bits and set the Z bit. This leaves the STATUS Register as 000u u1uu (where u = unchanged). #### C: Carry/borrow bit. ADDAR, ADDIA - = 1, a carry occurred. - = 0, a carry did not occur. SUBAR, SUBIA - = 1, a borrow did not occur. - = 0, a borrow occurred. Note: A subtraction is executed by adding the two's complement of the second operand. For rotate (RRR, RLR) instructions, this bit is loaded with either the high or low order bit of the source register. DC: Half carry/half borrow bit. ADDAR, ADDIA - = 1, a carry from the 4th low order bit of the result occurred. - = 0, a carry from the 4th low order bit of the result did not occur. SUBAR, SUBIA - = 1, a borrow from the 4th low order bit of the result did not occur. - = 0, a borrow from the 4th low order bit of the result occurred. #### Z: Zero bit. - = 1, the result of a logic operation is zero. - = 0, the result of a logic operation is not zero. **PD**: Power down flag bit. - = 1, after power-up or by the CLRWDT instruction. - = 0, by the SLEEP instruction. **TO**: Time overflow flag bit. - = 1, after power-up or by the CLRWDT or SLEEP instruction. - = 0, a watch-dog time overflow occurred. **GP2:GP0**: General purpose read/write bits. #### 2.1.5 FSR (Indirect Data Memory Address Pointer) | Address | Name | B7 | B6 | B5 | B4 | В3 | B2 | B1 | B0 | |-----------|------|-----|-----|----|----------|-----------|-------------|---------|----| | 04h (r/w) | FSR | RP1 | RP0 | | Indirect | data memo | ory address | pointer | | Bit5:Bit0 : Select registers address in the indirect addressing mode. See 2.1.1 for detail description. **RP1:RP0**: These bits are used to switching the bank of four data memory banks. User can use "BANK" instruction to change bank. See 2.1.1 for detail description. ## 2.1.6 PORTA, PORTB & PORTC (Port Data Registers) | Address | Name | B7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | |-----------|-------|------|------|------|------|------|------|------|------| | 05h (r/w) | PORTA | IOA7 | IOA6 | IOA5 | IOA4 | IOA3 | IOA2 | IOA1 | IOA0 | | 06h (r/w) | PORTB | IOB7 | IOB6 | IOB5 | IOB4 | IOB3 | IOB2 | IOB1 | IOB0 | | 07h (r/w) | PORTC | IOC7 | IOC6 | IOC5 | IOC4 | IOC3 | IOC2 | IOC1 | IOC0 | Reading the port (PORTA, PORTB, PORTC register) reads the status of the pins independent of the pin's input/output modes. Writing to these ports will write to the port data latch. For FM8P59A devices, PORTA is a 4-bit port data Register. In this type, only the low order 4 bits are used (PORTA<3:0>) and bits 7-4 are unimplemented and read as '0's. For FM8P59B devides, PORTA is a 8-bit port data Register. PORTB and PORTC are 8-bit port data registers. #### 2.1.7 PCON (Power Control Register) | Address | Name | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | |-----------|------|------|-----|-------|-----|----|----|-------|--------| | 08h (r/w) | PCON | WDTE | EIS | LVDTE | ROC | - | - | ODC67 | /WUC45 | /WUC45 : = 0, Enable the input falling wake-up function of IOC4 and IOC5 pins. = 1, Disable the input falling wake-up function of IOC4 and IOC5 pins. **ODC67**: = 0, Disable the internal open-drain of IOC6 and IOC7 pins. = 1, Enable the internal open-drain of IOC6 and IOC7 pins. Bit3:Bit2: Not used. Read as "0"s. **ROC**: R-option function of IOC0 and IOC1 pins enable bit. - = 0, Disable the R-option function. - = 1, Enable the R-option function. In this case, if a 430K $\Omega$ external resister is connected/disconnected to Vss, the status of IOC0 (IOC1) is read as "0"/"1". LVDTE: LVDT (low voltage detector) enable bit. - = 0, Disable LVDT. - = 1, Enable LVDT. **EIS**: Define the function of IOB0/INT0 pin. - = 0, IOB0 (bi-directional I/O pin) is selected. The path of INT0 is masked. - = 1, INT0 (external interrupt pin) is selected. In this case, the I/O control bit of IOB0 must be set to "1". The path of Port B input change of IOB0 pin is masked by hardware, the status of INT0 pin can also be read by way of reading PORTB. WDTE: WDT (watch-dog timer) enable bit. - = 0, Disable WDT. - = 1, Enable WDT. #### 2.1.8 WUCON (Port B Input Falling Wake-up Control Register) | Address | Name | В7 | В6 | B5 | B4 | В3 | B2 | B1 | B0 | |-----------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | 09h (r/w) | WUCON | /WUB7 | /WUB6 | /WUB5 | /WUB4 | /WUB3 | /WUB2 | /WUB1 | /WUB0 | /WUB0 : = 0, Enable the input falling wake-up function of IOB0 pin. = 1, Disable the input falling wake-up function of IOB0 pin. /WUB1 : = 0, Enable the input falling wake-up function of IOB1 pin. = 1, Disable the input falling wake-up function of IOB1 pin. /WUB2 : = 0, Enable the input falling wake-up function of IOB2 pin. = 1, Disable the input falling wake-up function of IOB2 pin. /WUB3: = 0, Enable the input falling wake-up function of IOB3 pin. = 1, Disable the input falling wake-up function of IOB3 pin. /WUB4 : = 0, Enable the input falling wake-up function of IOB4 pin. = 1, Disable the input falling Wake-up function of IOB4 pin. /WUB5 : = 0, Enable the input falling wake-up function of IOB5 pin. = 1, Disable the input falling wake-up function of IOB5 pin. /WUB6 : = 0, Enable the input falling wake-up function of IOB6 pin. = 1, Disable the input falling wake-up function of IOB6 pin. **/WUB7**: = 0, Enable the input falling wake-up function of IOB7 pin. = 1, Disable the input falling wake-up function of IOB7 pin. #### 2.1.9 PCHBUF (High Byte Buffer of Program Counter) | Address | Name | B7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | |-----------|--------|----|----|----|----|----|-------------|-------------|----| | 0Ah (r/w) | PCHBUF | - | - | - | - | U | pper 4 bits | Buffer of P | Ö | **PCHBUF<3:2>**: Program memory page selection bits. $= 0, 0 \rightarrow Page 0.$ = 0, 1 → Page 1. = 1, $0 \rightarrow$ Page 2. = 1, 1 → Page 3. User can use "PAGE" instruction to change memory page and maintains the program memory page. Otherwise, user can use "FGOTO" (far goto), or "FCALL" (far call) instructions to program user's code. See 2.1.3 for detail description. ### 2.1.10 PDCON (Pull-down Control Register) | Address | Name | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | |-----------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | 0Bh (r/w) | PDCON | /PDB3 | /PDB2 | /PDB1 | /PDB0 | /PDA3 | /PDA2 | /PDA1 | /PDA0 | /PDA0 : = 0, Enable the internal pull-down of IOA0 pin. = 1, Disable the internal pull-down of IOA0 pin. **/PDA1**: = 0, Enable the internal pull-down of IOA1 pin. = 1, Disable the internal pull-down of IOA1 pin. **/PDA2**: = 0, Enable the internal pull-down of IOA2 pin. = 1, Disable the internal pull-down of IOA2 pin. **/PDA3**: = 0, Enable the internal pull-down of IOA3 pin. = 1, Disable the internal pull-down of IOA3 pin. **/PDB0** : = 0, Enable the internal pull-down of IOB0 pin. = 1, Disable the internal pull-down of IOB0 pin. /PDB1 : = 0, Enable the internal pull-down of IOB1 pin. = 1, Disable the internal pull-down of IOB1 pin. /PDB2 : = 0, Enable the internal pull-down of IOB2 pin. = 1, Disable the internal pull-down of IOB2 pin. /PDB3 : = 0, Enable the internal pull-down of IOB3 pin. = 1, Disable the internal pull-down of IOB3 pin. ## 2.1.11 BPHCON (PortB Pull-high Control Register) | ı | Address | Name | B7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | |---|-----------|--------|-------|-------|-------|-------|-------|-------|-------|-------| | ı | 0Ch (r/w) | BPHCON | /PHB7 | /PHB6 | /PHB5 | /PHB4 | /PHB3 | /PHB2 | /PHB1 | /PHB0 | /PHB0 : = 0, Enable the internal pull-high of IOB0 pin. = 1, Disable the internal pull-high of IOB0 pin. **/PHB1** : = 0, Enable the internal pull-high of IOB1 pin. = 1, Disable the internal pull-high of IOB1 pin. /PHB2: = 0, Enable the internal pull-high of IOB2 pin. = 1, Disable the internal pull-high of IOB2 pin. **/PHB3** : = 0, Enable the internal pull-high of IOB3 pin. = 1, Disable the internal pull-high of IOB3 pin. /PHB4 : = 0, Enable the internal pull-high of IOB4 pin. = 1, Disable the internal pull-high of IOB4 pin. /PHB5 : = 0, Enable the internal pull-high of IOB5 pin. = 1, Disable the internal pull-high of IOB5 pin. /PHB6 : = 0, Enable the internal pull-high of IOB6 pin. = 1, Disable the internal pull-high of IOB6 pin. /PHB7 : = 0, Enable the internal pull-high of IOB7 pin. = 1, Disable the internal pull-high of IOB7 pin. ### 2.1.12 CPHCON (PortC Pull-high Control Register) | Address | Name | B7 | B6 | B5 | B4 | В3 | B2 | B1 | В0 | |-----------|--------|-------|-------|-------|-------|-------|-------|-------|-------| | 0Dh (r/w) | CPHCON | /PHC7 | /PHC6 | /PHC5 | /PHC4 | /PHC3 | /PHC2 | /PHC1 | /PHC0 | /PHC0 : = 0, Enable the internal pull-high of IOC0 pin. = 1, Disable the internal pull-high of IOC0 pin. **/PHC1**: = 0, Enable the internal pull-high of IOC1 pin. = 1, Disable the internal pull-high of IOC1 pin. /PHC2 : = 0, Enable the internal pull-high of IOC2 pin. = 1, Disable the internal pull-high of IOC2 pin. **/PHC3** : = 0, Enable the internal pull-high of IOC3 pin. = 1, Disable the internal pull-high of IOC3 pin. **/PHC4**: = 0, Enable the internal pull-high of IOC4 pin. = 1, Disable the internal pull-high of IOC4 pin. /PHC5 : = 0, Enable the internal pull-high of IOC5 pin. = 1, Disable the internal pull-high of IOC5 pin. **/PHC6**: = 0, Enable the internal pull-high of IOC6 pin. = 1, Disable the internal pull-high of IOC6 pin. /PHC7 : = 0, Enable the internal pull-high of IOC7 pin. = 1, Disable the internal pull-high of IOC7 pin. #### 2.1.13 INTEN (Interrupt Mask Register) | Address | Name | B7 | B6 | B5 | B4 | В3 | B2 | B1 | В0 | |-----------|-------|-----|----|----|----|--------|--------|----|------| | 0Eh (r/w) | INTEN | GIE | - | - | - | INT1IE | INT0IE | - | T0IE | **T0IE**: Timer0 overflow interrupt enable bit. = 0, Disable the Timer0 overflow interrupt. = 1, Enable the Timer0 overflow interrupt. Bit1: Not used. Read as "0". INTOIE: External INTO pin interrupt enable bit. = 0, Disable the External INT0 pin interrupt. = 1, Enable the External INT0 pin interrupt. INT1IE: External INT1 pin interrupt enable bit. = 0, Disable the External INT1 pin interrupt. = 1, Enable the External INT1 pin interrupt. Bit6:BIT4: Not used. Read as "0"s. **GIE**: Global interrupt enable bit. = 0, Disable all interrupts. = 1, Enable all un-masked interrupts. Note: When an interrupt event occur with the GIE bit and its corresponding interrupt enable bit are all set, the GIE bit will be cleared by hardware to disable any further interrupts. The RETFIE instruction will exit the interrupt routine and set the GIE bit to re-enable interrupt. # 2.1.14 INTFLAG (Interrupt Status Register) | Address | Name | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | |-----------|---------|----|----|----|----|--------|--------|----|------| | 0Fh (r/w) | INTFLAG | - | - | - | - | INT1IF | INT0IF | - | T0IF | **T0IF**: Timer0 overflow interrupt flag. Set when Timer0 overflows, reset by software. Bit1: Not used. Read as "0". **INT0IF**: External INT0 pin interrupt flag. Set by rising/falling (selected by INTEDG bit (OPTION<6>)) edge on INT0 pin, reset by software. INT1IF: External INT1 pin interrupt flag. Set by falling edge on INT1 pin, reset by software. Bit7:BIT4: Not used. Read as "0"s. #### 2.1.15 ACC (Accumulator) | Address | Name | В7 | B6 | B5 | B4 | В3 | B2 | B1 | В0 | |-----------|------|----|----|----|-------|---------|----|----|----| | N/A (r/w) | ACC | | | | Accum | nulator | | | | Accumulator is an internal data transfer, or instruction operand holding. It can not be addressed. # 2.1.16 OPTION Register | Address | Name | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | |---------|--------|----|--------|------|------|-----|-----|-----|-----| | N/A (w) | OPTION | - | INTEDG | T0CS | T0SE | PSA | PS2 | PS1 | PS0 | Accessed by OPTION instruction. By executing the OPTION instruction, the contents of the ACC Register will be transferred to the OPTION Register. The OPTION Register is a 7-bit wide, write-only register which contains various control bits to configure the Timer0/WDT prescaler, Timer0, and the external INT interrupt. The OPTION Register are "write-only" and are set all "1"s except INTEDG bit. PS2:PS0 : Prescaler rate select bits. | PS2:PS0 | Timer0 Rate | WDT Rate | |---------|-------------|----------| | 0 0 0 | 1:2 | 1:1 | | 0 0 1 | 1:4 | 1:2 | | 0 1 0 | 1:8 | 1:4 | | 0 1 1 | 1:16 | 1:8 | | 1 0 0 | 1:32 | 1:16 | | 1 0 1 | 1:64 | 1:32 | | 1 1 0 | 1:128 | 1:64 | | 1 1 1 | 1:256 | 1:128 | **PSA**: Prescaler assign bit. = 1, WDT (watch-dog timer). = 0, TMR0 (Timer0). **T0SE**: TMR0 source edge select bit. = 1, Falling edge on T0CKI pin. = 0, Rising edge on T0CKI pin. T0CS: TMR0 clock source select bit. = 1, External T0CKI pin. = 0, internal instruction clock cycle. INTEDG: INTO pin interrupt edge select bit. = 1, interrupt on rising edge of INT0 pin. = 0, interrupt on falling edge of INT0 pin. Bit7: Not used. ## 2.1.17 IOSTA, IOSTB & IOSTC (Port I/O Control Registers) | Address | Name | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 | | |---------|-------|----|-----------------------------|----|----|----|----|----|----|--| | N/A (w) | IOSTA | | Port A I/O Control Register | | | | | | | | | N/A (w) | IOSTB | | Port B I/O Control Register | | | | | | | | | N/A (w) | IOSTC | | Port C I/O Control Register | | | | | | | | Accessed by IOST instruction. The Port I/O Control Registers are loaded with the contents of the ACC Register by executing the IOST R (05h~07h) instruction. A '1' from a IOST Register bit puts the corresponding output driver in hi-impedance state (input mode). A '0' enables the output buffer and puts the contents of the output data latch on the selected pins (output mode). The IOST Registers are "write-only" and are set (output drivers disabled) upon RESET. #### 2.2 I/O Ports Port A, port B and port C are bi-directional tri-state I/O ports. Port A is a 4-pin I/O port for FM8P59A, and port A is a 8-pin I/O port for FM8P59B. Port B and port C are 8-pin I/O ports. All I/O pins (IOA<7:0>, IOB<7:0> and IOC<7:0>) have data direction control registers (IOSTA, IOSTB, IOSTC) which can configure these pins as output or input. IOB<7:0> and IOC<7:0> have its corresponding pull-high control bits (BPHCON and CPHCON registers) to enable the weak internal pull-high. The weak pull-high is automatically turned off when the pin is configured as an output pin. IOA<3:0> and IOB<3:0> have its corresponding pull-down control bits (PDCON register) to enable the weak internal pull-down. The weak pull-down is automatically turned off when the pin is configured as an output pin. IOC<7:6> have its corresponding open-drain control bit (ODC67 bit (PCON<1>)) to enable the open-drain output when these pins are configured to be an output pin. IOA0 and IOA1 are the R-option pins enabled by setting the ROC bit (PCON<4>). When the R-option function is used, it is recommended that IOA0 and IOA1 are used as output pins, and read the status of IOA0 and IOA1 before these pins are configured to be an output pin. IOB<7:0> and IOC<5:4> also provide the input falling wake-up function. Each pin has its corresponding input falling wake-up enable bits (WUCON register and /WUC45 bit (PCON<0>)) to select the input falling wake-up source. The IOB0 is also an external interrupt input signal by setting the EIS bit (PCON<6>). In this case, IOB0 input falling wake-up function will be disabled by hardware even if it is enabled by software. ## FIGURE 2.3: Block Diagram of I/O PINs IOA7 ~ IOA0, IOC7 ~ IOC6, IOC3 ~ IOC0 : Pull-down is not shown in the figure IOC5 ~ IOC4 : Pull-high and open-drain are not shown in the figure IOB0: Pull-high/pull-down and open-drain are not shown in the figure ## IOB7 ~ IOB1 : Pull-high/pull-down and open-drain are not shown in the figure #### 2.3 Timer0/WDT & Prescler #### 2.3.1 Timer0 The Timer0 is a 8-bit timer/counter. The clock source of Timer0 can come from the internal clock or by an external clock source (T0CKI pin). #### 2.3.1.1 Using Timer0 with an Internal Clock: Timer mode Timer mode is selected by clearing the T0CS bit (OPTION<5>). In timer mode, the timer0 register (TMR0) will increment every instruction cycle (without prescaler). If TMR0 register is written, the increment is inhibited for the following two cycles. #### 2.3.1.2 Using Timer0 with an External Clock: Counter mode Counter mode is selected by setting the T0CS bit (OPTON<5>). In this mode, Timer0 will increment either on every rising or falling edge of pin T0CKI. The incrementing edge is determined by the source edge select bit T0SE (OPTION<4>). The external clock requirement is due to internal phase clock (Tosc) synchronization. Also, there is a delay in the actual incrementing of Timer0 after synchronization. When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of T0CKI with the internal phase clocks is accomplished by sampling the prescaler output on the T2 and T4 cycles of the internal phase clocks. Therefore, it is necessary for T0CKI to be high for at least $2 \, T_{OSC}$ and low for at least $2 \, T_{OSC}$ . When a prescaler is used, the external clock input is divided by the asynchronous prescaler. For the external clock to meet the sampling requirement, the ripple counter must be taken into account. Therefore, it is necessary for TOCKI to have a period of at least 4Tosc divided by the prescaler value. #### 2.3.2 Watchdog Timer (WDT) The Watchdog Timer (WDT) is a free running on-chip RC oscillator which does not require any external components. So the WDT will still run even if the clock on the OSCI and OSCO pins is turned off, such as in SLEEP mode. During normal operation or in SLEEP mode, a WDT time-out will cause the device reset and the TO bit (STATUS<4>) will be cleared. The WDT can be disabled by clearing the control bit WDTE (PCON<7>) to "0". The WDT has a nominal time-out period of 18 ms (without prescaler). If a longer time-out period is desired, a prescaler with a division ratio of up to 1:128 can be assigned to the WDT controlled by the OPTION register. Thus, the longest time-out period is approxmately 2.3 seconds. The CLRWDT instruction clears the WDT and the prescaler, if assigned to the WDT, and prevents it from timing out and generating a device reset. The SLEEP instruction resets the WDT and the prescaler, if assigned to the WDT. This gives the maximum SLEEP time before a WDT Wake-up Reset. #### 2.3.3 Prescaler An 8-bit counter (down counter) is available as a prescaler for the Timer0, or as a postscaler for the Watchdog Timer (WDT). Note that the prescaler may be used by either the Timer0 module or the WDT, but not both. Thus, a prescaler assignment for the Timer0 means that there is no prescaler for the WDT, and vice-versa. The PSA bit (OPTION<3>) determines prescaler assignment. The PS<2:0> bits (OPTION<2:0>) determine prescaler ratio. When the prescaler is assigned to the Timer0 module, all instructions writing to the TMR0 register will clear the prescaler. When it is assigned to WDT, a CLRWDT instruction will clear the prescaler along with the WDT. The prescaler is neither readable nor writable. On a RESET, the prescaler contains all '1's. To avoid an unintended device reset, CLRWDT or CLRR TMR0 instructions must be executed when changing the prescaler assignment from Timer0 to the WDT, and vice-versa. FIGURE 2.4: Block Diagram of The Timer0/WDT Prescaler ### 2.4 Interrupts The FM8P59 series has up to three sources of interrupt: - 1. External interrupt INT0 pin. - 2. External interrupt INT1 pin. - 3. TMR0 overflow interrupt. INTFLAG is the interrupt flag register that recodes the interrupt requests in the relative flags. A global interrupt enable bit, GIE (INTEN<7>), enables (if set) all un-masked interrupts or disables (if cleared) all interrupts. Individual interrupts can be enabled/disabled through their corresponding enable bits in INTEN register regardless of the status of the GIE bit. When an interrupt event occur with the GIE bit and its corresponding interrupt enable bit are all set, the GIE bit will be cleared by hardware to disable any further interrupts, and the next instruction will be fetched from address 008h. The interrupt flag bits must be cleared by software before re-enabling GIE bit to avoid recursive interrupts. The RETFIE instruction exits the interrupt routine and set the GIE bit to re-enable interrupt. The flag bit in INTFLAG register is set by interrupt event regardless of the status of its mask bit. Reading the INTFLAG register will be the logic AND of INTFLAG and INTEN. When an interrupt is generated by the INT instruction, the next instruction will be fetched from address 002h. ## 2.4.1 External INTO Interrupt External interrupt on INT0 pin is rising or falling edge triggered selected by INTEDG (OPTION<6>). When a valid edge appears on the INT0 pin the flag bit INT0IF (INTFLAG<2>) is set. This interrupt can be disabled by clearing INT0IE bit (INTEN<2>). ## 2.4.2 External INT1 Interrupt External interrupt on INT1 pin is falling edge triggered. When a falling edge appears on the INT1 pin the flag bit INT1IF (INTFLAG<3>) is set. This interrupt can be disabled by clearing INT1IE bit (INTEN<3>). #### 2.4.3 Timer0 Interrupt An overflow (FFh $\rightarrow$ 00h) in the TMR0 register will set the flag bit T0IF (INTFLAG<0>). This interrupt can be disabled by clearing T0IE bit (INTEN<0>). ## 2.5 Power-down Mode (SLEEP) Power-down mode is entered by executing a SLEEP instruction. When SLEEP instruction is executed, the $\overrightarrow{PD}$ bit (STATUS<3>) is cleared, the $\overrightarrow{TO}$ bit is set, the watchdog timer will be cleared and keeps running, and the oscillator driver is turned off. All I/O pins maintain the status they had before the SLEEP instruction was executed. #### 2.5.1 Wake-up from SLEEP Mode The device can wake-up from SLEEP mode through one of the following events: - 1. RSTB reset. - 2. WDT time-out reset (if enabled). - 3. PORTB/IOC4/IOC5 input falling. External RSTB reset and WDT time-out reset will cause a device reset. The $\overrightarrow{PD}$ and $\overrightarrow{TO}$ bits can be used to determine the cause of device reset. The $\overrightarrow{PD}$ bit is set on power-up and is cleared when SLEEP instruction is executed. The $\overrightarrow{TO}$ bit is cleared if a WDT time-out occurred. For the device to wake-up through an PORTB/IOC4/IOC5 input falling event, and the program will execute next PC after wake-up. Any pin which corresponding /WUBn bit (WUCON<7:0>) or /WUC45 bit (PCON<0>) is set to "1" or configured as output will be excluded from this function. The system wake-up delay time is 18ms plus 128 oscillator cycle time. #### 2.6 Reset FM8P59 devices may be RESET in one of the following ways: - 1. Power-on Reset (POR) - 2. Brown-out Reset (BOR) - 3. RSTB Pin Reset - 4. WDT time-out Reset Some registers are not affected in any RESET condition. Their status is unknown on Power-on Reset and unchanged in any other RESET. Most other registers are reset to a "reset state" on Power-on Reset, RSTB or WDT Reset. A Power-on RESET pulse is generated on-chip when Vdd rise is detected. To use this feature, the user merely ties the RSTB pin to Vdd. On-chip Low Voltage Detector (LVD) places the device into reset when Vdd is below a fixed voltage. This ensures that the device does not continue program execution outside the valid operation Vdd range. Brown-out RESET is typically used in AC line or heavy loads switched applications. A RSTB or WDT Wake-up from SLEEP also results in a device RESET, and not a continuation of operation before SLEEP. The TO and PD bits (STATUS<4:3>) are set or cleared depending on the different reset conditions. #### 2.6.1 Power-up Reset Timer(PWRT) The Power-up Reset Timer provides a nominal 18ms delay after Power-on Reset (POR), Brown-out Reset (BOR), RSTB Reset or WDT time-out Reset. The device is kept in reset state as long as the PWRT is active. The PWDT delay will vary from device to device due to Vdd, temperature, and process variation. #### 2.6.2 Oscillator Start-up Timer(OST) The OST timer provides a 128 oscillator cycle delay (from OSCI input) after the PWRT delay (18ms) is over. This delay ensures that the X'tal oscillator or resonator has started and stabilized. The device is kept in reset state as long as the OST is active. This counter only starts incrementing after the amplitude of the OSCI signal reaches the oscillator input thresholds. #### 2.6.3 Reset Sequence When Power-on Reset (POR), Brown-out Reset (BOR), RSTB Reset or WDT time-out Reset is detected, the reset sequence is as follows: - 1. The reset latch is set and the PWRT & OST are cleared. - 2. When the internal POR, BOR, RSTB Reset or WDT time-out Reset pulse is finished, then the PWRT begins counting. - 3. After the PWRT time-out, the OST is activated. - 4. And after the OST delay is over, the reset latch will be cleared and thus end the on-chip reset signal. The totally system reset delay time is 18ms plus 128 oscillator cycle time. FIGURE 2.5: Simplified Block Diagram of on-chip Reset Circuit FIGURE 2.6: Time-out Sequence on Power-up (RSTB Pin Tied to Vdd) Note: $T_{PWRT}$ = 18 ms; $T_{OST}$ = 128 oscillator cycle time FIGURE 2.7: Time-out Sequence on Power-up (RSTB Pin Not Tied to Vdd) Note: $T_{PWRT}$ = 18 ms; $T_{OST}$ = 128 oscillator cycle time **TABLE 2.1: Reset Conditions for All Registers** | Register | Address | Power-on Reset<br>Brown-out Reset | RSTB Reset<br>WDT Reset | |---------------------------|----------|-----------------------------------|-------------------------| | ACC | N/A | xxxx xxxx | uuuu uuuu | | OPTION | N/A | -011 1111 | -011 1111 | | IOSTA | 05h | A: 0000 1111 | A: 0000 1111 | | | | B: 1111 1111 | B: 1111 1111 | | IOSTB | 06h | 1111 1111 | 1111 1111 | | IOSTC | 07h | 1111 1111 | 1111 1111 | | INDF | 00h | xxxx xxxx | uuuu uuuu | | TMR0 | 01h | xxxx xxxx | uuuu uuuu | | PCL | 02h | 1111 1111 | 1111 1111 | | STATUS | 03h | 0001 1xxx | 000# #uuu | | FSR | 04h | xxxx xxxx | uuuu uuuu | | PORTA | 05h | xxxx | uuuu | | PORTB | 06h | xxxx xxxx | uuuu uuuu | | PORTC | 07h | xxxx xxxx | uuuu uuuu | | PCON | 08h | 101000 | 101000 | | WUCON | 09h | 0000 0000 | 0000 0000 | | PCHBUF | 0Ah | 000 | 000 | | PDCON | 0Bh | 1111 1111 | 1111 1111 | | BPHCON | 0Ch | 1111 1111 | 1111 1111 | | CPHCON | 0Dh | 1111 1111 | 1111 1111 | | INTEN | 0Eh | 0 00-0 | 0 00-0 | | INTFLAG | 0Fh | 00-0 | 00-0 | | General Purpose Registers | 10 ~ 3Fh | xxxx xxxx | uuuu uuuu | Legend: u = unchanged, x = unknown, - = unimplemented, # = refer to the following table for possible values. ## TABLE 2.2: TO/PD Status after Reset | TO | PD | RESET was caused by | |----|----|------------------------------------| | 1 | 1 | Power-on Reset | | 1 | 1 | Brown-out reset | | u | u | RSTB Reset during normal operation | | 1 | 0 | RSTB Reset during SLEEP | | 0 | 1 | WDT Reset during normal operation | | 0 | 0 | WDT Wake-up during SLEEP | Legend: u = unchanged TABLE 2.3: Events Affecting TO/PD Status Bits | Event | TO | PD | |--------------------|----|----| | Power-on | 1 | 1 | | WDT Time-Out | 0 | u | | SLEEP instruction | 1 | 0 | | CLRWDT instruction | 1 | 1 | Legend: u = unchanged #### 2.7 Hexadecimal Convert to Decimal (HCD) Decimal format is another number format for FM8P59 series. When the content of the data memory has been assigned as decimal format, it is necessary to convert the results to decimal format after the execution of ALU instructions. When the decimal converting operation is processing, all of the operand data (including the contents of the data memory (RAM), accumulator (ACC), immediate data, and look-up table) should be in the decimal format, or the results of conversion will be incorrect. Instruction DAA can convert the ACC data from hexadecimal to decimal format after any addition operation and restored to ACC. The conversion operation is illustrated in example 2.2. #### **EXAMPLE 2.2: DAA CONVERSION** | MOVIA | 90h | ;Set immediate data = decimal format number "90" (ACC ← 90h) | |-------|--------|--------------------------------------------------------------------------------| | MOVAR | 30h | ;Load immediate data "90" to data memory address 30H | | MOVIA | 10h | ;Set immediate data = decimal format number "10" (ACC ← 10h) | | ADDAR | 30h, 0 | ;Contents of the data memory address 30H and ACC are binary-added | | | | ;the result loads to the ACC (ACC ← A0h, C ← 0) | | DAA | | ;Convert the content of ACC to decimal format, and restored to ACC | | | | ;The result in the ACC is "00" and the carry bit C is "1". This represents the | | | | ;decimal number "100" | Instruction DAS can convert the ACC data from hexadecimal to decimal format after any subtraction operation and restored to ACC. The conversion operation is illustrated in example 2.3. #### **EXAMPLE 2.3: DAS CONVERSION** | <br> | | | |-------|--------|--------------------------------------------------------------------------------| | MOVIA | 10h | ;Set immediate data = decimal format number "10" (ACC ← 10h) | | MOVAR | 30h | ;Load immediate data "10" to data memory address 30H | | MOVIA | 20h | ;Set immediate data = decimal format number "20" (ACC ← 20h) | | SUBAR | 30h, 0 | ;Contents of the data memory address 30H and ACC are binary-subtracted | | | | ;the result loads to the ACC (ACC $\leftarrow$ F0h, C $\leftarrow$ 0) | | DAS | | ;Convert the content of ACC to decimal format, and restored to ACC | | | | ;The result in the ACC is "90" and the carry bit C is "0". This represents the | | | | ;decimal number " -10" | | | | | ## 2.8 Oscillator Configurations FM8P59 series can be operated in four different oscillator modes. Users can program two configuration bits (Fosc<1:0>) to select the appropriate modes: - · LF: Low Frequency Crystal Oscillator - · XT: Crystal/Resonator Oscillator - · HF: High Frequency Crystal/Resonator Oscillator - ERC: External Resistor/Capacitor Oscillator In LF, XT, or HF modes, a crystal or ceramic resonator in connected to the OSCI and OSCO pins to establish oscillation. When in LF, XT, or HF modes, the devices can have an external clock source drive the OSCI pin. The ERC device option offers additional cost savings for timing insensitive applications. The RC oscillator frequency is a function of the supply voltage, the resistor (Rext) and capacitor (Cext), the operating temperature, and the process parameter. FIGURE 2.8: HF, XT or LF Oscillator Modes (Crystal Operation or Ceramic Resonator) FIGURE 2.9: HF, XT or LF Oscillator Modes (External Clock Input Operation) FIGURE 2.10: ERC Oscillator Mode # 2.9 Configurations Word **TABLE 2.4: Configurations Word** | Name | Description | |---------|-----------------------------------------------------------| | | Oscillator Selection Bits | | _ | = 1, 1 → ERC mode (default) | | Fosc | = 1, 0 → HF mode | | | = 0, 1 → XT mode | | | = 0, 0 → LF mode | | | Watchdog Timer Enable Bit | | WDTEN | = 1, WDT enabled (default) | | | = 0, WDT disabled | | | Code Protection Bit | | PROTECT | = 1, EPROM code protection off (default) | | | = 0, EPROM code protection on | | | Low Voltage Detector Selection Bit | | | = 1, 1 → disable (default) | | LVDT | = 1, 0 → enable, LVDT voltage = 2.0V, controlled by SLEEP | | | = 0, 1 → enable, LVDT voltage = 2.0V | | | = 0, 0 → enable, LVDT voltage = 3.6V | | | Instruction Period Selection Bits | | | = 1, 1 → four oscillator periods (default) | | OSCD | = 1, 0 → two oscillator periods | | | = 0, 1 → one oscillator period | | | = 0, 0 → eight oscillator periods | | | Power Mode Selection Bit | | PMOD | = 1, Non-power saving (default) | | | = 0, Power saving | | | Type Selection Bit | | TYPE | = 1, A type (28-pin) is selected (default) | | | = 0, B type (32-pin) is selected | # 3.0 INSTRUCTION SET | Mnemo<br>Opera | - | Description | Operation | Cycles | Status<br>Affected | |----------------|--------|--------------------------------------------------------------------------|-------------------------------------------------------------------|---------|--------------------| | BCR | R, bit | Clear bit in R | 0 → R <b></b> | 1 | - | | BSR | R, bit | Set bit in R | 1 → R <b></b> | 1 | - | | BTRSC | R, bit | Test bit in R, Skip if Clear | Skip if R <b> = 0</b> | 1/2 (1) | - | | BTRSS | R, bit | Test bit in R, Skip if Set | Skip if R <b> = 1</b> | 1/2 (1) | - | | NOP | | No Operation | No operation | 1 | - | | CLRWDT | | Clear Watchdog Timer | 00h → WDT,<br>00h → WDT prescaler | 1 | TO, PD | | OPTION | | Load OPTION register | ACC → OPTION | 1 | - | | SLEEP | | Go into power-down mode | 00h → WDT,<br>00h → WDT prescaler | 1 | TO, PD | | TBL | | Table look-up | PC<7:0> + ACC → PC<7:0> PC<9:8> unchanged PCHBUF<3:2> → PC<11:10> | 1 | C, DC, Z | | DAA | | Adjust ACC's data format from HEX to DEC after any addition operation | ACC(hex) → ACC(dec) | 1 | С | | DAS | | Adjust ACC's data format from HEX to DEC after any subtraction operation | ACC(hex) → ACC(dec) | 1 | - | | INT | | S/W interrupt | PC + 1 → Top of Stack,<br>002h → PC | 2 | - | | RETURN | | Return from subroutine | Top of Stack → PC | 2 | - | | RETFIE | | Return from interrupt, set GIE bit | Top of Stack → PC,<br>1 → GIE | 2 | - | | CLRA | | Clear ACC | 00h → ACC | 1 | Z | | IOST | R | Load IOST register | ACC → IOST register | 1 | - | | CLRR | R | Clear R | 00h → R | 1 | Z | | MOVAR | R | Move ACC to R | ACC → R | 1 | - | | MOVR | R, d | Move R | R → dest | 1 | Z | | DECR | R, d | Decrement R | R - 1 → dest | 1 | Z | | DECRSZ | R, d | Decrement R, Skip if 0 | R - 1 → dest,<br>Skip if result = 0 | 1/2 (1) | - | | INCR | R, d | Increment R | R + 1 → dest | 1 | Z | | INCRSZ | R, d | Increment R, Skip if 0 | R + 1 → dest,<br>Skip if result = 0 | 1/2 (1) | - | | ADDAR | R, d | Add ACC and R | R + ACC → dest | 1 | C, DC, Z | | SUBAR | R, d | Subtract ACC from R | R - ACC → dest | 1 | C, DC, Z | | ADCAR | R, d | Add ACC and R with Carry | R + ACC + C → dest | 1 | C, DC, Z | | SBCAR | R, d | Subtract ACC from R with Carry | R + ACC + C → dest | 1 | C, DC, Z | | ANDAR | R, d | AND ACC with R | ACC and R → dest | 1 | Z | | IORAR | R, d | Inclusive OR ACC with R | ACC or R → dest | 1 | Z | | XORAR | R, d | Exclusive OR ACC with R | R xor ACC → dest | 1 | Z | | COMR | R, d | Complement R | R → dest | 1 | Z | | RLR | R, d | Rotate left f through Carry | R<7> → C,<br>R<6:0> → dest<7:1>,<br>C → dest<0> | 1 | С | | RRR | R, d | Rotate right f through Carry | C → dest<7>,<br>R<7:1> → dest<6:0>,<br>R<0> → C | 1 | С | |-------|------|-------------------------------------|------------------------------------------------------------------|---|----------| | SWAPR | R, d | Swap R | R<3:0> → dest<7:4>,<br>R<7:4> → dest<3:0> | 1 | - | | MOVIA | I | Move Immediate to ACC | I → ACC | 1 | - | | ADDIA | I | Add ACC and Immediate | I + ACC → ACC | 1 | C, DC, Z | | SUBIA | I | Subtract ACC from Immediate | I - ACC → ACC | 1 | C, DC, Z | | ANDIA | I | AND Immediate with ACC | ACC and I → ACC | 1 | Z | | IORIA | I | OR Immediate with ACC | ACC or I → ACC | 1 | Z | | XORIA | I | Exclusive OR Immediate to ACC | ACC xor I → ACC | 1 | Z | | RETIA | I | Return, place Immediate in ACC | I → ACC, Top of Stack → PC | 2 | - | | BANK | I | Move Immediate to memory bank bits | I → RP<1:0> | 1 | - | | PAGE | I | Move Immediate to program page bits | I → PCHBUF<3:2> | 1 | - | | CALL | ı | Call subroutine | PC + 1 → Top of Stack,<br>I → PC<9:0><br>PCHBUF<3:2> → PC<11:10> | 2 | - | | GOTO | I | Unconditional branch | I → PC<9:0><br>PCHBUF<3:2> → PC<11:10> | 2 | - | | FCALL | ı | Call subroutine | PC + 1 → Top of Stack,<br>I → PC<11:0><br>I<11:10> → PCHBUF<3:2> | 3 | - | | FGOTO | ı | Unconditional branch | I → PC<11:0><br>I<11:10> → PCHBUF<3:2> | 3 | - | Note: 1. 2 cycles for skip, else 1 cycle. (3 cycles if skip and followed by a 2-word instruction FCALL/FGOTO) 2. bit : Bit address within an 8-bit register $\ensuremath{\text{R}}$ R: Register address (00h to 3Fh) I : Immediate data ACC : Accumulator d : Destination select; =0 (store result in ACC) =1 (store result in file register R) dest : Destination PC : Program Counter PCHBUF: High Byte Buffer of Program Counter WDT : Watchdog Timer Counter GIE : Global interrupt enable bit TO : Time-out bit PD : Power-down bit C : Carry bit DC: Digital carry bit Z : Zero bit ADCAR Add ACC and R with Carry Syntax: ADCAR R, d Operands: $0 \le R \le 63$ $d \in [0,1]$ Operation: $R + ACC + C \rightarrow dest$ Status Affected: C, DC, Z Description: Add the contents of the ACC register and register 'R' with Carry. If 'd' is 0 the result is stored in the ACC register. If 'd' is '1' the result is stored back in register 'R'. Cycles: 1 ADDAR Add ACC and R Syntax: ADDAR R, d Operands: $0 \le R \le 63$ $d\!\in\![0,\!1]$ Operation: $ACC + R \rightarrow dest$ Status Affected: C, DC, Z Description: Add the contents of the ACC register and register 'R'. If 'd' is 0 the result is stored in the ACC register. If 'd' is '1' the result is stored back in register 'R'. Cycles: 1 ADDIA Add ACC and Immediate Syntax: ADDIA I Operands: $0 \le I \le 255$ Operation: ACC + I $\rightarrow$ ACC Status Affected: C, DC, Z Description: Add the contents of the ACC register with the 8-bit immediate 'I'. The result is placed in the ACC register. Cycles: 1 ANDAR AND ACC and R Syntax: ANDAR R, d Operands: $0 \le R \le 63$ $d \in [0,1]$ Operation: ACC and $R \rightarrow dest$ Status Affected: Z Description: The contents of the ACC register are AND'ed with register 'R'. If 'd' is 0 the result is stored in the ACC register. If 'd' is '1' the result is stored back in register 'R'. Cycles: 1 ANDIA AND Immediate with ACC Syntax: ANDIA I Operands: $0 \le I \le 255$ Operation: ACC AND I → ACC Status Affected: Z Description: The contents of the ACC register are AND'ed with the 8-bit immediate 'I'. The result is placed in the ACC register. **BANK** Move Immediate to memory bank bits Syntax: BANK I Operands: $0 \le I \le 3$ Operation: $I \to RP<1:0>$ Status Affected: None Description: The memory bank bits are loaded with the 2-bit immediate 'I'. Cycles: 1 BCR Clear Bit in R Syntax: BCF R, b Operands: $0 \le R \le 63$ $0 \le b \le 7$ Operation: $0 \rightarrow R < b >$ Status Affected: None Description: Clear bit 'b' in register 'R'. Cycles: 1 BSR Set Bit in R Syntax: BSR R, b Operands: $0 \le R \le 63$ $0 \le b \le 7$ Operation: $1 \rightarrow R < b >$ Status Affected: None Description: Set bit 'b' in register 'R'. Cycles: 1 BTRSC Test Bit in R, Skip if Clear Syntax: BTRSC R, b Operands: $0 \le R \le 63$ $0 \le b \le 7$ Operation: Skip if R<br/>b> = 0 Status Affected: None Description: If bit 'b' in register 'R' is 0 then the next instruction is skipped. If bit 'b' is 0 then next instruction fetched during the current instruction execution is discarded, and a NOP is executed instead making this a 2-cycle instruction.. Cycles: 1/2 (3 cycles if skip and followed by a 2-word instruction FCALL/FGOTO) BTRSS Test Bit in R, Skip if Set Syntax: BTRSS R, b Operands: $0 \le R \le 63$ $0 \le b \le 7$ Operation: Skip if R < b > = 1 Status Affected: None Description: If bit 'b' in register 'R' is '1' then the next instruction is skipped. If bit 'b' is '1', then the next instruction fetched during the current instruction execution, is discarded and a NOP is executed instead, making this a 2-cycle instruction. Cycles: 1/2 (3 cycles if skip and followed by a 2-word instruction FCALL/FGOTO) **CALL Subroutine Call** Syntax: CALL I Operands: $0 \le I \le 1023$ Operation: PC +1 → Top of Stack; I → PC<9:0> PCHBUF<3:2> → PC<11:10> Status Affected: None Description: Subroutine call. First, return address (PC+1) is pushed onto the stack. The 10-bit immediate address is loaded into PC bits <9:0>. CALL is a two-cycle instruction. Cycles: **CLRA Clear ACC** Syntax: CLRA Operands: None $00h \rightarrow ACC$ ; Operation: $1 \rightarrow Z$ Status Affected: Ζ Description: The ACC register is cleared. Zero bit (Z) is set. Cycles: **CLRR** Clear R Syntax: CLRR R 0≤R≤63 Operands: Operation: $00h \rightarrow R$ ; $1 \rightarrow Z$ Status Affected: Ζ Description: The contents of register 'R' are cleared and the Z bit is set. Cycles: **CLRWDT Clear Watchdog Timer** Syntax: **CLRWDT** Operands: None Operation: $00h \rightarrow WDT$ : 00h → WDT prescaler (if assigned); $1 \rightarrow \overline{TO}$ ; $1 \rightarrow \overline{PD}$ TO PD Status Affected: Description: The CLRWDT instruction resets the WDT. It also resets the prescaler, if the prescaler is assigned to the WDT and not Timer0. Status bits $\overline{TO}$ and $\overline{PD}$ are set. Cycles: 1 COMR Complement R Syntax: COMR R, d Operands: 0≤R≤63 $d \in [0,1]$ Operation: R → dest Status Affected: Description: The contents of register 'R' are complemented. If 'd' is 0 the result is stored in the ACC register. If 'd' is 1 the result is stored back in register 'R'. DAA Adjust ACC's data format from HEX to DEC Syntax: DAA Operands: None Operation: $ACC(hex) \rightarrow ACC(dec)$ Status Affected: C Description: Convert the ACC data from hexadecimal to decimal format after any addition operation and restored to ACC. Cycles: 1 DAS Adjust ACC's data format from HEX to DEC Syntax: DAS Operands: None Operation: $ACC(hex) \rightarrow ACC(dec)$ Status Affected: None Description: Convert the ACC data from hexadecimal to decimal format after any subtraction operation and restored to ACC. Cycles: 1 DECR Decrement R Syntax: DECR R, d Operands: $0 \le R \le 63$ $d \in [0,1]$ Operation: R - 1 → dest Status Affected: Z Description: Decrement register 'R'. If 'd' is 0 the result is stored in the ACC register. If 'd' is 1 the result is stored back in register 'R'. Cycles: 1 DECRSZ Decrement R, Skip if 0 Syntax: DECRSZ R, d Operands: $0 \le R \le 63$ $d \in [0,1]$ Operation: $R - 1 \rightarrow dest$ ; skip if result =0 Status Affected: None Description: The contents of register 'R' are decremented. If 'd' is 0 the result is placed in the ACC register. If 'd' is 1 the result is placed back in register 'R'. If the result is 0, the next instruction, which is already fetched, is discarded and a NOP is executed instead making it a two-cycle instruction. Cycles: 1/2 (3 cycles if skip and followed by a 2-word instruction FCALL/FGOTO) FCALL Subroutine Call Syntax: FCALL I Operands: $0 \le I \le 4095$ Operation: PC +1 $\rightarrow$ Top of Stack; I → PC<11:0> I<11:10> → PCHBUF<3:2> Status Affected: None Description: Subroutine call. First, return address (PC+1) is pushed onto the stack. The 12-bit immediate address is loaded into PC bits <11:0>. FCALL is a two-word (three-cycle) instruction. FGOTO Unconditional Branch Syntax: FGOTO I Operands: $0 \le I \le 4095$ Operation: $I \rightarrow PC < 11:0 >$ I<11:10> → PCHBUF<3:2> Status Affected: None Description: FGOTO is an unconditional branch. The 12-bit immediate value is loaded into PC bits <11:0>. FGOTO is a two-word (three-cycle) instruction. Cycles: 3 GOTO Unconditional Branch Syntax: GOTO I Operands: $0 \le I \le 1023$ Operation: $I \to PC < 9:0 >$ PCHBUF<3:2> → PC<11:10> Status Affected: None Description: GOTO is an unconditional branch. The 10-bit immediate value is loaded into PC bits <9:0>. GOTO is a two-cycle instruction. Cycles: 2 INCR Increment R Syntax: INCR R, d Operands: $0 \le R \le 63$ $d \in [0,1]$ Operation: $R + 1 \rightarrow dest$ Status Affected: Z Description: The contents of register 'R' are incremented. If 'd' is 0 the result is placed in the ACC register. If 'd' is 1 the result is placed back in register 'R'. Cycles: 1 INCRSZ Increment R, Skip if 0 Syntax: INCRSZ R, d Operands: $0 \le R \le 63$ $d\!\in\![0,\!1]$ Operation: $R + 1 \rightarrow dest$ , skip if result = 0 Status Affected: None Description: The contents of register 'R' are incremented. If 'd' is 0 the result is placed in the ACC register. If 'd' is the result is placed back in register 'R'. If the result is 0, then the next instruction, which is already fetched, is discarded and a NOP is executed instead making it a two-cycle instruction. Cycles: 1/2 (3 cycles if skip and followed by a 2-word instruction FCALL/FGOTO) INT S/W Interrupt Syntax: INT Operands: None Operation: $PC + 1 \rightarrow Top of Stack$ , 002h → PC Status Affected: None Description: Interrupt subroutine call. First, return address (PC+1) is pushed onto the stack. The address 002h is loaded into PC bits <10:0>. IORAR OR ACC with R Syntax: IORAR R, d Operands: $0 \le R \le 63$ $d \in [0,1]$ Operation: ACC or $R \rightarrow dest$ Status Affected: Z Description: Inclusive OR the ACC register with register 'R'. If 'd' is 0 the result is placed in the ACC register. If 'd' is 1 the result is placed back in register 'R'. Cycles: 1 IORIA OR Immediate with ACC Syntax: IORIA I Operands: $0 \le l \le 255$ Operation: ACC or $l \to ACC$ Status Affected: Z Description: The contents of the ACC register are OR'ed with the 8-bit immediate 'I'. The result is placed in the ACC register. Cycles: 1 IOST Load IOST Register Syntax: IOST R Operands: R = 5,6 or 7 Operation: ACC → IOST register R Status Affected: None Description: IOST register 'R' (R= 5,6 or 7) is loaded with the contents of the ACC register. Cycles: 1 MOVAR Move ACC to R Syntax: MOVAR R Operands: $0 \le R \le 63$ Operation: ACC $\rightarrow$ R Status Affected: None Description: Move data from the ACC register to register 'R'. Cycles: 1 MOVIA Move Immediate to ACC Syntax: MOVIA I Operands: $0 \le I \le 255$ Operation: $I \to ACC$ Status Affected: None Description: The 8-bit immediate 'I' is loaded into the ACC register. The don't cares will assemble as 0s. Cycles: 1 MOVR Move R Syntax: MOVR R, d Operands: $0 \le R \le 63$ $d \in [0,1]$ Status Affected: Z Operation: Description: The contents of register 'R' is moved to destination 'd'. If 'd' is 0, destination is the ACC register. If 'd' is 1, the destination is file register 'R'. 'd' is 1 is useful to test a file register since status flag Z is affected. R → dest NOP No Operation Syntax: NOP Operands: None Operation: No operation Status Affected: None Description: No operation. Cycles: 1 OPTION Load OPTION Register Syntax: OPTION Operands: None Operation: ACC → OPTION Status Affected: None Description: The content of the ACC register is loaded into the OPTION register. Cycles: 1 PAGE Move Immediate to program page bits Syntax: PAGE I Operands: $0 \le I \le 3$ Operation: I → PCHBUF<3:2> Status Affected: None Description: The program page bits are loaded with the 2-bit immediate 'l'. Cycles: 1 RETFIE Return from Interrupt, Set 'GIE' Bit Syntax: RETFIE Operands: None Operation: Top of Stack → PC Status Affected: None Description: The program counter is loaded from the top of the stack (the return address). The 'GIE' bit is set to 1. This is a two-cycle instruction. Cycles: 2 RETIA Return with Immediate in ACC Syntax: RETIA I Operands: $0 \le I \le 255$ Operation: $I \rightarrow ACC$ ; Top of Stack $\rightarrow$ PC Status Affected: None Description: The ACC register is loaded with the 8-bit immediate 'I'. The program counter is loaded from the top of the stack (the return address). This is a two-cycle instruction. Cycles: 2 RETURN Return from Subroutine Syntax: RETURN Operands: None Operation: Top of Stack → PC Status Affected: None Description: The program counter is loaded from the top of the stack (the return address). This is a two-cycle instruction. RLR Rotate Left f through Carry $\begin{array}{ll} \text{Syntax:} & \text{RLR R, d} \\ \text{Operands:} & 0 \leq R \leq 63 \end{array}$ $d \in [0,1]$ Operation: $R<7> \rightarrow C$ ; $R<6:0> \rightarrow dest<7:1>;$ $C \rightarrow dest<0>$ Status Affected: C Description: The contents of register 'R' are rotated one bit to the left through the Carry Flag. If 'd' is 0 the result is placed in the ACC register. If 'd' is 1 the result is stored back in register 'R'. Cycles: 1 RRR Rotate Right f through Carry Syntax: RRR R, d Operands: $0 \le R \le 63$ $d \in [0,1]$ Operation: $C \rightarrow dest<7>$ ; $R<7:1> \rightarrow dest<6:0>;$ $R<0> \rightarrow C$ Status Affected: C Description: The contents of register 'R' are rotated one bit to the right through the Carry Flag. If 'd' is 0 the result is placed in the ACC register. If 'd' is 1 the result is placed back in register 'R'. Cycles: 1 SLEEP Enter SLEEP Mode Syntax: SLEEP Operands: None Operation: $00h \rightarrow WDT$ ; 00h → WDT prescaler; $1 \to \overline{TO}; \\ 0 \to \overline{PD}$ Status Affected: TO PD Description: Time-out status bit $(\overline{TO})$ is set. The power-down status bit $(\overline{PD})$ is cleared. The WDT and its prescaler are cleared. The processor is put into SLEEP mode. Cycles: 1 SBCAR Subtract ACC from R with Carry Syntax: SBCAR R, d Operands: $0 \le R \le 63$ $d \in [0,1]$ Operation: $R + \overline{ACC} + C \rightarrow dest$ Status Affected: C, DC, Z Description: Add the 2's complement data of the ACC register from register 'R' with Carry. If 'd' is 0 the result is stored in the ACC register. If 'd' is 1 the result is stored back in register 'R'. **SUBAR** Subtract ACC from R Syntax: SUBAR R. d Operands: $0 \le R \le 63$ $d \in [0,1]$ R - ACC → dest Operation: Status Affected: C, DC, Z Subtract (2's complement method) the ACC register from register 'R'. If 'd' is 0 the result is Description: stored in the ACC register. If 'd' is 1 the result is stored back in register 'R'. Cycles: **SUBIA Subtract ACC from Immediate** Syntax: SUBIA I Operands: $0 \le 1 \le 255$ Operation: I - ACC → ACC Status Affected: C, DC, Z Description: Subtract (2's complement method) the ACC register from the 8-bit immediate 'I'. The result is placed in the ACC register. Cycles: 1 **SWAPR** Swap nibbles in R SWAPR R, d Syntax: Operands: 0≤R≤63 $d \in [0,1]$ Operation: $R<3:0> \rightarrow dest<7:4>$ ; R<7:4> → dest<3:0> Status Affected: None Description: The upper and lower nibbles of register 'R' are exchanged. If 'd' is 0 the result is placed in ACC register. If 'd' is 1 the result in placed in register 'R'. Cycles: 1 **TBL** Table Look-up Syntax: TBL Operands: None Operation: PC<7:0> + ACC → PC<7:0> PC<9:8> unchanged PCHBUF<3:2> → PC<11:10> Status Affected: C, DC, Z Description: Operate with RETIA to look-up table Cycles: **XORAR Exclusive OR ACC with R** Syntax: XORAR R, d Operands: 0≤R≤63 $d \in [0,1]$ ACC xor R → dest Operation: Status Affected: Description: Exclusive OR the contents of the ACC register with register 'R'. If 'd' is 0 the result is stored in the ACC register. If 'd' is 1 the result is stored back in register 'R'. # FM8P59 XORIA Exclusive OR Immediate with ACC Syntax: XORIA I Operands: $0 \le 1 \le 255$ Operation: ACC xor I $\rightarrow$ ACC Status Affected: Z Description: The contents of the ACC register are XOR'ed with the 8-bit immediate 'I'. The result is placed in the ACC register. ## FM8P59 #### 4.0 ABSOLUTE MAXIMUM RATINGS #### **5.0 OPERATING CONDITIONS** DC Supply Voltage +2.3V to +5.5V Operating Temperature 0°C to +70°C ## **6.0 ELECTRICAL CHARACTERISTICS** #### 6.1 ELECTRICAL CHARACTERISTICS of FM8P59AE/47BE Under Operating Conditions, at four clock instruction cycles and WDT & LVDT are disabled | Sym | Description | Conditions | Min. | Тур. | Max. | Unit | |------------------|---------------------|---------------------------------|------|------|------|------| | F <sub>HF</sub> | | HF mode, Vdd=5V | 2 | | 20 | MHz | | THE | | HF mode, Vdd=3V | | | | | | _ | | XT mode, Vdd=5V | 1 | | 5 | MHz | | F <sub>XT</sub> | | XT mode, Vdd=3V | | | | | | _ | | LF mode, Vdd=5V | 32 | | 1000 | KHZ | | F <sub>LF</sub> | | LF mode, Vdd=3V | | | | | | Е | | ERC mode, Vdd=5V | DC | | 4 | MHz | | F <sub>ERC</sub> | | ERC mode, Vdd=3V | | | | | | $V_{IH}$ | Input high voltage | I/O ports, Vdd=5V | 2.2 | | | V | | VIH | input night voltage | RSTB pin, Vdd=5V | 4.2 | | | V | | \/ | Input low voltage | I/O ports, Vdd=5V | | | 1.1 | V | | $V_{IL}$ | Input low voltage | RSTB pin, Vdd=5V | | | 1.0 | V | | $V_{OH}$ | Output high voltage | I <sub>OH</sub> =-5.4mA, Vdd=5V | 3.8 | | | V | | $V_{OL}$ | Output low voltage | I <sub>OL</sub> =8.7mA, Vdd=5V | | | 0.6 | V | | $I_{PH}$ | Pull-high current | Input pin at Vss | | -70 | | uA | | $I_{PD}$ | Pull-down current | Input pin at Vdd | | 50 | | uA | | l | WDT current | Vdd=5V | | | | | | I <sub>WDT</sub> | WDT current | Vdd=3V | | 3 | | uA | | | LVDT current | Vdd=5V | | | | | | $I_{LVDT}$ | LVDT current | Vdd=3V | | | | | | 1 | Power down current | Sleep mode, Vdd=5V | | | | uA | | I <sub>SB</sub> | Fower down current | Sleep mode, Vdd=3V | | < 1 | | uA | | | | HF mode: 20MHz, Vdd = 5V | | | | mA | | | | Vdd = 3V | | | | mA | | | Operating current | XT mode: 4MHz, Vdd = 5V | | | | mA | | 1 | | Vdd = 3V | | | | mA | | I <sub>DD</sub> | | LF mode: 32KHz, Vdd = 5V | | | | uA | | | | Vdd = 3V | | 15 | | uA | | | | ERC mode: 4MHz, Vdd = 5V | | | | mA | | | | Vdd = 3V | | | | mA | #### 6.2 ELECTRICAL CHARACTERISTICS of FM8P59A/47B To be defined ## 7.0 PACKAGE DIMENSION #### 7.1 <u>28-PIN PDIP 600mil</u> | Cumbala | Dime | ension In Millim | eters | Dir | Dimension In Inches | | | |---------|-------|------------------|-------|-------|---------------------|-------|--| | Symbols | Min | Nom | Max | Min | Nom | Max | | | Α | = | = | 5.59 | = | - | 0.220 | | | A1 | 0.38 | - | - | 0.015 | - | - | | | A2 | 3.81 | 3.94 | 4.06 | 0.150 | 0.155 | 0.160 | | | В | - | 1.52 | - | - | 0.06 | - | | | B1 | - | 0.46 | - | - | 0.018 | - | | | D | 36.96 | 37.08 | 37.34 | 1.455 | 1.460 | 1.470 | | | Е | - | 15.24 | - | - | 0.600 | - | | | E1 | 13.72 | 13.84 | 13.97 | 0.540 | 0.545 | 0.550 | | | е | - | 2.54 | - | - | 0.100 | - | | | L | 3.18 | - | - | 0.125 | - | - | | | eВ | 16.00 | 16.51 | 17.02 | 0.630 | 0.650 | 0.670 | | #### 7.2 28-PIN Skinny PDIP 300mil | | Dime | ension In Millim | eters | Dimension In Inches | | | |---------|-------|------------------|-------|---------------------|-------|-------| | Symbols | Min | Nom | Max | Min | Nom | Max | | Α | - | - | 4.57 | - | - | 0.180 | | A1 | 0.38 | 1 | - | 0.015 | - | ı | | A2 | - | 3.30 | 3.56 | - | 0.130 | 0.140 | | В | 1.02 | = | 1.65 | 0.0040 | - | 0.065 | | B1 | 0.41 | - | 0.58 | 0.016 | - | 0.023 | | B2 | 0.71 | = | 1.12 | 0.028 | - | 0.044 | | С | 0.20 | 0.25 | 0.33 | 0.008 | 0.010 | 0.013 | | D | 35.13 | 35.18 | 35.43 | 1.383 | 1.385 | 1.395 | | Е | 7.87 | 8.31 | 8.38 | 0.310 | 0.327 | 0.330 | | E1 | 7.26 | 7.32 | 7.52 | 0.284 | 0.288 | 0.296 | | е | - | 2.54 | - | - | 0.100 | = | | L | 3.18 | - | - | 0.125 | - | - | | eВ | 8.64 | - | 9.65 | 0.340 | - | 0.380 | ## 7.3 <u>28-PIN SOP 300mil</u> | Cumbala | Dime | ension In Millim | eters | Dimension In Inches | | | |---------|-------|------------------|-------|---------------------|-------|-------| | Symbols | Min | Nom | Max | Min | Nom | Max | | Α | - | 2.488 | 2.743 | - | 0.098 | 0.108 | | A1 | 0.152 | - | - | 0.006 | - | - | | A2 | 2.21 | 2.336 | 2.464 | 0.087 | 0.091 | 0.097 | | В | 0.305 | 0.406 | 0.508 | 0.012 | 0.016 | 0.020 | | С | 0.204 | 0.254 | 0.304 | 0.008 | 0.010 | 0.012 | | D | 17.78 | 17.91 | 18.42 | 0.700 | 0.705 | 0.725 | | Е | 7.366 | 7.493 | 7.62 | 0.290 | 0.295 | 0.300 | | е | 1.219 | 1.270 | 1.321 | 0.048 | 0.050 | 0.052 | | eВ | 10.26 | 10.42 | 10.57 | 0.404 | 0.410 | 0.416 | | L | 0.635 | - | - | 0.025 | - | • | | θ | 0° | 4° | 8° | 0° | 4° | 8° | | D1 | 0.356 | 0.508 | - | 0.014 | 0.020 | - | #### 7.4 <u>28-PIN SSOP 209mil</u> | O wash alla | Dimension In Millimeters | | | |-------------|--------------------------|-------|-------| | Symbols | Min | Nom | Max | | Α | = | = | 2.00 | | A1 | 0.05 | - | - | | A2 | 1.62 | 1.75 | 1.85 | | b | 0.22 | - | 0.38 | | С | 0.09 | - | 0.25 | | D | 9.90 | 10.20 | 10.50 | | Е | 7.40 | 7.80 | 8.20 | | E1 | 5.00 | 5.30 | 5.60 | | е | 0.65 BSC | 10.42 | 10.57 | | L | 0.55 | 0.75 | 0.95 | | R | 0.09 | - | - | | θ° | 0° | 4° | 8° | ## 7.5 32-PIN PDIP 600mil | Cymala ala | Dimension In Inchs | | | | |-----------------------|--------------------|----------|-------|--| | Symbols | Min | Nom | Max | | | Α | - | - | 0.220 | | | A1 | 0.015 | - | - | | | A2 | 0.150 | 0.155 | 0.160 | | | D | 1.645 | 1.650 | 1.660 | | | Е | | 0.600BSC | | | | E1 | 0.540 | 0.545 | 0.550 | | | L | 0.115 | 0.130 | 0.150 | | | <b>e</b> <sub>B</sub> | 0.630 | 0.650 | 0.670 | | | θ° | 0 | 7 | 15 | | ## 7.6 <u>32-PIN SOP 450mil</u> | Cumbala | Dimension In Inch | | | |-----------------------|-------------------|-------|--| | Symbols | Min | Max | | | Α | ı | 0.120 | | | A1 | 0.004 | 0.014 | | | D | 0.799 | 0.815 | | | Е | 0.437 | 0.450 | | | Н | 0.530 | 0.580 | | | L | 0.016 | 0.050 | | | $\Theta_{\mathrm{o}}$ | 0° | 10° | | ## **8.0 ORDERING INFORMATION** | OTP Type MCU | Package Type | Pin Count | Package Size | |--------------|--------------|-----------|--------------| | FM8P59AEP | PDIP | 28 | 600 mil | | FM8P59AEM | Skinny PDIP | 28 | 300 mil | | FM8P59AED | SOP | 28 | 300 mil | | FM8P59AER | SSOP | 28 | 209 mil | | FM8P59BEP | PDIP | 32 | 600 mil | | FM8P59BED | SOP | 32 | 450 mil | | Mask Type MCU | Package Type | Pin Count | Package Size | |---------------|--------------|-----------|--------------| | FM8P59AP | PDIP | 28 | 600 mil | | FM8P59AM | Skinny PDIP | 28 | 300 mil | | FM8P59AD | SOP | 28 | 300 mil | | FM8P59AR | SSOP | 28 | 209 mil | | FM8P59BP | PDIP | 32 | 600 mil | | FM8P59BD | SOP | 32 | 450 mil |