# **Application Note** # $\mu$ PD6133 SERIES REMOTE CONTROL TRANSMISSION **SAMPLE PROGRAMS** Document No. U11726EJ1V1AN00 (1st edition) Date Published January 1998 N CP(K) [MEMO] The export of this product from Japan is regulated by the Japanese government. To export this product may be prohibited without governmental license, the need for which must be judged by the customer. The export or re-export of this product from a country other than Japan may also be prohibited without a license from that country. Please call an NEC sales representative. The application circuits and their parameters are for reference only and are not intended for use in actual design-ins. #### The information in this document is subject to change without notice. No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Corporation. NEC Corporation assumes no responsibility for any errors which may appear in this document. NEC Corporation does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from use of a device described herein or any other liability arising from use of such device. No license, either express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Corporation or others. While NEC Corporation has been making continuous effort to enhance the reliability of its semiconductor devices, the possibility of defects cannot be eliminated entirely. To minimize risks of damage or injury to persons or property arising from a defect in an NEC semiconductor device, customers must incorporate sufficient safety measures in its design, such as redundancy, fire-containment, and anti-failure features. NEC devices are classified into the following three quality grades: "Standard", "Special", and "Specific". The Specific quality grade applies only to devices developed based on a customer designated "quality assurance program" for a specific application. The recommended applications of a device depend on its quality grade, as indicated below. Customers must check the quality grade of each device before using it in a particular application. - Standard: Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots - Special: Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support) - Specific: Aircrafts, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems or medical equipment for life support, etc. The quality grade of NEC devices is "Standard" unless otherwise specified in NEC's Data Sheets or Data Books. If customers intend to use NEC devices for applications other than those specified for Standard quality grade, they should contact an NEC sales representative in advance. Anti-radioactive design is not implemented in this product. ## **Regional Information** Some information contained in this document may vary from country to country. Before using any NEC product in your application, please contact the NEC office in your country to obtain a list of authorized representatives and distributors. They will verify: - Device availability - · Ordering information - Product release schedule - · Availability of related technical literature - Development environment specifications (for example, specifications for third-party tools and components, host computers, power plugs, AC supply voltages, and so forth) - · Network requirements In addition, trademarks, registered trademarks, export restrictions, and other legal issues may also vary from country to country. #### **NEC Electronics Inc. (U.S.)** Santa Clara, California Tel: 408-588-6000 800-366-9782 Fax: 408-588-6130 800-729-9288 #### **NEC Electronics (Germany) GmbH** Duesseldorf, Germany Tel: 0211-65 03 02 Fax: 0211-65 03 490 #### **NEC Electronics (UK) Ltd.** Milton Keynes, UK Tel: 01908-691-133 Fax: 01908-670-290 #### NEC Electronics Italiana s.r.1. Milano, Italy Tel: 02-66 75 41 Fax: 02-66 75 42 99 #### **NEC Electronics (Germany) GmbH** Benelux Office Eindhoven, The Netherlands Tel: 040-2445845 Fax: 040-2444580 #### **NEC Electronics (France) S.A.** Velizy-Villacoublay, France Tel: 01-30-67 58 00 Fax: 01-30-67 58 99 #### **NEC Electronics (France) S.A.** Spain Office Madrid, Spain Tel: 01-504-2787 Fax: 01-504-2860 #### **NEC Electronics (Germany) GmbH** Scandinavia Office Taeby, Sweden Tel: 08-63 80 820 Fax: 08-63 80 388 #### **NEC Electronics Hong Kong Ltd.** Hong Kong Tel: 2886-9318 Fax: 2886-9022/9044 #### **NEC Electronics Hong Kong Ltd.** Seoul Branch Seoul, Korea Tel: 02-528-0303 Fax: 02-528-4411 #### **NEC Electronics Singapore Pte. Ltd.** United Square, Singapore 1130 Tel: 253-8311 Fax: 250-3583 #### **NEC Electronics Taiwan Ltd.** Taipei, Taiwan Tel: 02-719-2377 Fax: 02-719-5951 #### **NEC do Brasil S.A.** Cumbica-Guarulhos-SP, Brasil Tel: 011-6465-6810 Fax: 011-6465-6829 #### **INTRODUCTION** **Readers** These application notes are intended for engineers who understand the functions of $\mu\text{PD6133}$ Series infrared remote control transmission microcontrollers and who design application programs using these microcontrollers. **Purpose** The purpose of these application notes is to use application program examples to explain the functions of NEC $\mu$ PD6133 Series microcontrollers. **Organization** These application notes can be broadly divided into the following sections. #### GENERAL DESCRIPTION - · Fundamentals of infrared remote control - · Overview of remote control transmission program #### • 48-key program - Hardware configuration - · Transmission waveform - · Timing charts - · Output code - Software configuration - Program description - · Cautions on program revisions - · Program list #### ● 80-key program - Hardware configuration - Transmission waveform - Timing charts - · Output code - Software configuration - Program description - · Cautions on program revisions - · Cautions on use of this program - · Program list Legend Data representation weight: High-order digits are indicated at left and low-order digits at right. Note : Explanation of (Note) in the text Caution : Item deserving extra attention Remark : Supplementary explanation to the text Number representation : Binary number is XXXXB Decimal number is XXXX Hexadecimal number is XXXXH #### **Related Documents** The following documentation should be referred to when using this manual. The related documents indicated in this publication may include preliminary versions. However, preliminary versions are not marked as such. | Document name | Document Number | | | |--------------------------------------|------------------|-----------------|--| | | Japanese version | English version | | | μPD6133, 6134 DATA SHEET | U10454J | U10454E | | | μPD6604 DATA SHEET | U11281J | U11281E | | | μPD63, 64 DATA SHEET | U11371J | U11371E | | | SM6133 VERSION 1.0,<br>USER'S MANUAL | U11128J | U11128E | | | AS6133 ASSEMBLER<br>USER'S MANUAL | U10115J | U10115E | | Caution The programs in this document are intended as examples only and are not intended for production design purposes. #### **CONTENTS** | PART 1 G | ENERAL | 1 | |-----------|-------------------------------------------------|----| | CHAPTER 1 | FUNDAMENTALS OF INFRARED REMOTE CONTROL | 3 | | CHAPTER 2 | OVERVIEW OF REMOTE CONTROL TRANSMISSION PROGRAM | 5 | | 2.1 | General Flow Chart | 5 | | 2.2 | Overview of Processing | 5 | | | 2.2.1 Initialization processing | 5 | | | 2.2.2 STOP mode | | | | 2.2.3 Key input processing | 6 | | | 2.2.4 Transmission processing | 6 | | PART 2 48 | 3-KEY PROGRAM | 7 | | CHAPTER 1 | HARDWARE CONFIGURATION | | | 1.1 | · · · · · · · · · · · · · · · · · · · | | | 1.2 | Key Matrix | 10 | | CHAPTER 2 | TRANSMISSION WAVEFORM | | | 2.1 | NEC-R Format | 11 | | CHAPTER 3 | TIMING CHARTS | | | 3.1 | g,par | | | | 3.1.1 Timing when a key is pressed and held | | | | 3.1.2 Timing during key OFF status | | | 3.2 | Timing Charts of Key Operations | | | | 3.2.1 Output patterns prior to key confirmation | | | | 3.2.2 Operation of combination key | | | | 3.2.3 Key transfer operation | 25 | | CHAPTER 4 | OUTPUT CODES | 27 | | CHAPTER 5 | SOFTWARE CONFIGURATION | 29 | | 5.1 | | | | 5.2 | Program Memory (ROM) Configuration | 30 | | 5.3 | Data Memory (RAM) Configuration | 32 | | 5.4 | Flag Maps | 37 | | CHAPTER 6 | PROGRAM DESCRIPTION | 39 | | 6.1 | Initial Settings | 39 | | | 6.1.1 Description of processing | 39 | | | 6.1.2 Detailed flow chart | | | 6.2 | Key Input Processing | 45 | | | 6.2.1 Description of processing | 45 | |-----------|-------------------------------------------------|-----| | | 6.2.2 Detailed flow chart | 52 | | 6.3 | Transmission Processing | 65 | | | 6.3.1 Description of processing | 66 | | | 6.3.2 Detailed flow chart | 71 | | CHAPTER 7 | CAUTIONS ON PROGRAM REVISIONS | 83 | | CHAPTER 8 | PROGRAM LIST | 85 | | PART 3 80 | O-KEY PROGRAM | 101 | | CHAPTER 1 | HARDWARE CONFIGURATION | 103 | | 1.1 | | | | 1.2 | Key Matrix | | | CHAPTER 2 | TRANSMISSION WAVEFORM | 105 | | 2.1 | | | | CHARTER 2 | TIMING CHARTS | 407 | | 3.1 | | | | 3.1 | 3.1.1 Timing when a key is pressed and held | | | | 3.1.2 Timing during key OFF status | | | 3 2 | Timing Charts of Key Operations | | | 0.2 | 3.2.1 Output patterns prior to key confirmation | | | | 3.2.2 Operation of combination key | | | | 3.2.3 Key transfer operation | | | CHAPTER 4 | OUTPUT CODES | 121 | | CHAPTER 5 | SOFTWARE CONFIGURATION | 123 | | 5.1 | | | | 5.2 | | | | 5.3 | | | | 5.4 | Flag Maps | | | CHAPTER 6 | PROGRAM DESCRIPTION | 133 | | 6.1 | Initial Settings | 133 | | | 6.1.1 Description of processing | 133 | | | 6.1.2 Detailed flow chart | | | 6.2 | Key Input Processing | 139 | | | 6.2.1 Description of processing | 139 | | | 6.2.2 Detailed flow chart | 146 | | 6.3 | Transmission Processing | 158 | | | 6.3.1 Description of processing | 159 | | | 6.3.2 Detailed flow chart | 16/ | | CHAPTER 7 CAUTIONS ON PROGRAM REVISIONS | . 175 | |-------------------------------------------|-------| | CHAPTER 8 CAUTIONS ON USE OF THIS PROGRAM | . 177 | | CHAPTER 9 PROGRAM LIST | 179 | ### LIST OF FIGURES (1/2) | Figure No. | Title | Page | |------------|------------------------------------------------------------|------| | PART 1 | GENERAL | | | 1-1 | Configuration of IR Remote Control Unit | 3 | | 1-2 | Example of NEC-format Transmit Waveform | 4 | | PART 2 | 48-KEY PROGRAM | | | 1-1 | Application Circuit Example | 9 | | 1-2 | Key Matrix | 10 | | 2-1 | NEC-R Format | 11 | | 3-1 | Timing Chart when Key is Pressed and Held | 14 | | 3-2 | Timing Chart for Key OFF Status | | | 3-3 | Output Patterns Prior to Key Confirmation | | | 3-4 | Timing Chart of Key Combination Operation | | | 3-5 | Operation Timing of Key Transfer Operation | 25 | | 5-1 | General Flow Chart | | | 5-2 | ROM Map | | | 5-3 | Data Table Map | 31 | | 6-1 | Chattering of Key Input Signal | 45 | | 6-2 | Key ON Judgment when Chattering Occurs | 46 | | 6-3 | 48-key Key Matrix | 47 | | 6-4 | Key Matrix | 48 | | 6-5 | Key Data (Key Position) | 48 | | 6-6 | Bit Configuration of Key Data when Input is via Kio to Kia | 49 | | 6-7 | Bit Configuration of Key Data when Input is via So and S1 | 50 | | 6-8 | Configuration of Data Pointer | 50 | | 6-9 | Configuration of Timer Counter | 65 | | 6-10 | Time Management of Timer Counter | 65 | | 6-11 | Method for Dividing Frame Space Transmission Times | 69 | | 6-12 | Key OFF Check during Bit Data Transmission | 70 | | PART 3 | 80-KEY PROGRAM | | | 1-1 | Application Circuit Example | 103 | | 1-2 | Key Matrix | 104 | | 0.4 | NEO D Farmer | 405 | #### LIST OF FIGURES (2/2) | Figure No. | Title | Page | |------------|----------------------------------------------------------------|------| | 3-1 | Timing Chart when Key is Pressed and Held | 100 | | | , | | | 3-2 | Timing Chart for Key OFF Status | | | 3-3 | Output Patterns Prior to Key Confirmation | | | 3-4 | Timing Chart of Key Combination Operation | | | 3-5 | Operation Timing of Key Transfer Operation | 120 | | 5-1 | General Flow Chart | 123 | | 5-2 | ROM Map | 124 | | 5-3 | Data Table Map | 125 | | 6-1 | Chattering of Key Input Signal | 139 | | 6-2 | Key ON Judgment when Chattering Occurs | 140 | | 6-3 | 80-key Key Matrix | 141 | | 6-4 | Key Matrix | 142 | | 6-5 | Key Data (Key Position) | 142 | | 6-6 | Bit Configuration of Key Data when Input is via Kio to Ki3 | 143 | | 6-7 | Bit Configuration of Key Data when Input is via S <sub>1</sub> | 144 | | 6-8 | Configuration of Data Pointer | 144 | | 6-9 | Configuration of Timer Counter | 158 | | 6-10 | Time Management of Timer Counter | 158 | | 6-11 | Method for Dividing Frame Space Transmission Times | 162 | | 6-12 | Key OFF Check during Bit Data Transmission | 163 | #### LIST OF TABLES | Table No. | Title | Page | |-----------|-----------------------------------------------------------------------|------| | PART 2 | 48-KEY PROGRAM | | | 1-1 | Pin Functions | 10 | | 4-1 | Output Codes | 27 | | 5-1 | RAM Map | 32 | | 5-2 | Map of RAM Used for Key Input Processing | 33 | | 5-3 | RAM Map Used for Transmission Processing | 34 | | 5-4 | Description of RAM Usage | 35 | | 5-5 | Flag Map | 37 | | 6-1 | Control Register 0 (P3) | 40 | | 6-2 | Time Clock and Carrier Frequency Settings | 40 | | 6-3 | Control Register 1 (P4) | 41 | | 6-4 | Cancellation Conditions for HALT Instruction | 42 | | 6-5 | Description of Data 1 Transmit Counter (R9) | 66 | | 6-6 | Frame Space Times Corresponding to "Data 1" Occurrences | 69 | | PART 3 | 80-KEY PROGRAM | | | 1-1 | Pin Functions | 104 | | 4-1 | Output Codes | 121 | | 5-1 | RAM Map | 126 | | 5-2 | Map of RAM used for Key Input Processing | 127 | | 5-3 | RAM Map Used for Transmission Processing | 128 | | 5-4 | Description of RAM Usage | 129 | | 5-5 | Flag Map | 132 | | 6-1 | Control Register 0 (P3) | 134 | | 6-2 | Time Clock and Carrier Frequency Settings | 134 | | 6-3 | Control Register 1 (P4) | 135 | | 6-4 | Cancellation Conditions for HALT Instruction | 136 | | 6-5 | Description of Data 1 Transmit Counter (R9) | 159 | | 6-6 | Frame Space Times Corresponding to the Number of "Data 1" Occurrences | 162 | | | | | # PART 1 GENERAL [MEMO] #### **CHAPTER 1 FUNDAMENTALS OF INFRARED REMOTE CONTROL** Infrared remote control transmitters (hereafter referred to as "IR remote control units" or "remote control units") interrupt an infrared ray to produce transmission of binary ("0" and "1") data whereby various electronic control devices can be operated under remote control. The IR remote control unit's use of an infrared LED (Ir-LED) as the transmitter diode makes for a smaller remote control transmitter that can be manufactured at less cost. A typical infrared remote control device configuration is shown below. Figure 1-1. Configuration of IR Remote Control Unit To ensure an effective distance of 7 to 10 meters for remote control transmissions, the current supplied to the Ir-LED is generally in the range of 300 to 500 mA. However, since this amount of current would shorten the battery life, modulation is used to produce a pulse current wherein the average current is reduced to one tenth or less of the peak current. The infrared rays that are output from the Ir-LED are re-converted to electrical signals by a photo diode in the receiver. Since the received signal is very weak, it is amplified via a receive amplifier before being detected and demodulated into "0" and "1" signals. An NEC-format transmit waveform is shown below as an example of transmit data from an infrared remote control unit. The Ir-LED is ON (lit) during high-level periods and OFF (not lit) during low-level periods. Figure 1-2. Example of NEC-format Transmit Waveform #### (1) REM output waveform #### (2) Bit data format # 2.25 ms #### (3) Carrier waveform fx = 455 kHz Carrier frequency: 38 kHz Duty factor: 1/3 #### (4) Bit patterns in codes 1.125 ms #### CHAPTER 2 OVERVIEW OF REMOTE CONTROL TRANSMISSION PROGRAM #### 2.1 General Flow Chart #### 2.2 Overview of Processing #### 2.2.1 Initialization processing Since most remote control units use batteries as their power source, it should be assumed that RAM and port contents may undergo sudden changes due to power supply voltage fluctuations during the Ir-LED's infrared ray emissions. Consequently, a program has been implemented to execute RAM and port initialization processing when each remote control signal is transmitted. Initialization processing includes the following settings. - · Port settings, carrier frequency/duty factor, carrier setting - · Carrier frequency and timer/clock division settings - I/O mode settings and pull-down resistor settings for each port #### 2.2.2 STOP mode When in STOP mode, program execution is stopped along with system clock oscillation to enable low current consumption. In the remote control program, setting STOP mode as a condition for canceling key input enables current consumption to be reduced as long as no key is pressed (while in standby mode). #### 2.2.3 Key input processing Key input processing includes the following. - · Key scanning to determine if any key has been pressed - Ensured reliability in key operations (elimination of chattering) - Generation of key data corresponding to each pressed key, which is stored in RAM. #### 2.2.4 Transmission processing Transmission processing includes the following. - Transmit data corresponding to the key data generated by key input processing is transmitted according to the specific manufacturer's remote control transmission format. - · After the first transmission is completed, the unit detects whether or not the key is still being pressed. - If it is determined that the key is still being pressed, key input processing checks whether or not the pressed key has changed. - If it is determined that the key has been released, initialization processing is executed, after which the unit enters STOP mode to reduce power consumption until a key is pressed. # PART 2 48-KEY PROGRAM [MEMO] #### **CHAPTER 1 HARDWARE CONFIGURATION** #### 1.1 Application Circuit Example Figure 1-1 shows an application circuit example. **K**I/06 **K**I/O5 **K**I/07 **K**I/O4 S<sub>0</sub>Note **K**I/03 S<sub>1</sub>/LED<sup>Note</sup> **K**I/O2 REM **K**I/O1 Vdd **K**I/00 K<sub>I3</sub>Note $X_{\text{OUT}}$ $K_{12}^{\text{Note}}$ $X_{IN}$ K<sub>I1</sub>Note **GND** RESET K<sub>10</sub>Note $\mu$ PD6133 Key matrix $(8 \times 6 = 48 \text{ keys})$ Figure 1-1. Application Circuit Example Note The program is set for "on-chip pull-down resistors". The $K_1$ , $K_{1/0}$ , $S_0$ , and $S_1/\overline{\text{LED}}$ pins are used to configure a 48-key key matrix. The transmission code is output via the REM pin with a carrier signal. Table 1-1 lists the various pin functions. Table 1-1. Pin Functions | Pin Name | I/O | Function | | |----------------------|--------|-----------------------------------------------|--| | K1/00 to K1/07 | Output | Key source (active high) | | | Kio to Kis | Input | Key return (active high) | | | S <sub>0</sub> Input | | | | | S <sub>1</sub> /LED | Input | | | | REM | Output | Infrared remote control signal (with carrier) | | #### 1.2 Key Matrix Figure 1-2 illustrates the key matrix. The "Kn" symbol (in which n = 1 to 48) indicates each key's position. Figure 1-2. Key Matrix | <b>K</b> I/07 | K29 | K30 | K31 | K32 | K47 | K48 | |---------------|-----|-----------------|-----------------|-----|----------------|----------------| | K1/06 | K25 | K26 | K27 | K28 | K45 | K46 | | K1/05 | K21 | K22 | K23 | K24 | K43 | K44 | | <b>K</b> I/O4 | K17 | K18 | K19 | K20 | K41 | K42 | | K1/03 | K13 | K14 | K15 | K16 | K39 | K40 | | K1/02 | K9 | K10 | K11 | K12 | K37 | K38 | | <b>K</b> I/O1 | K5 | K6 | K7 | K8 | K35 | K36 | | Kı/00 | K1 | K2 | КЗ | K4 | K33 | K34 | | , | Кіз | K <sub>12</sub> | K <sub>I1</sub> | Kıo | S <sub>1</sub> | S <sub>0</sub> | #### **CHAPTER 2 TRANSMISSION WAVEFORM** The transmission waveform that is output from the REM pin uses the NEC-R (NEC continuous) format. For description of the output data code, see "CHAPTER 4 OUTPUT CODES". #### 2.1 NEC-R Format Figure 2-1 illustrates the NEC-R format. Figure 2-1. NEC-R Format • Transmission waveform · Transmission waveform for first frame - Transmission waveform for second and subsequent frames...same as transmission waveform for first frame - · Bit data format ### #### Carrier waveform Carrier frequency: 38 Duty factor: 1/3 [MEMO] #### **CHAPTER 3 TIMING CHARTS** #### 3.1 Timing Charts for Key Input to REM Output "ON chattering" elimination processing checks for key input every 9.00 ms and if it detects ON status three consecutive times, it determines that the key is ON. "ON chattering" elimination processing also checks for key status changes (between ON and OFF or when the key is pressed and held). The OFF chattering elimination processing is described below. Key OFF status is checked during low-level output of the bit data. During transmission of one frame (108 ms), key input is checked ten times with reference to the timing (34 times) of the low-level output from the REM pin. - (1) If key OFF status is detected all ten times - ... Key OFF status is determined. - (2) If key ON status is detected during at least one of the ten times - ... When key ON status is detected, the check counter is cleared and key input is checked another ten times. - (3) If (1) and (2) above do not determine key OFF status - ... Key press and hold status (key ON status) is determined. Even if key OFF status is determined during transmission of the first frame, initialization processing does not begin until after the second or a subsequent frame is transmitted. #### 3.1.1 Timing when a key is pressed and held Figure 3-1 shows a timing chart for when a key is pressed and held. For details of ON chattering elimination, see "6.2.1 (1) Chattering Elimination Processing". Key input Software key **REM** output 0.94 to 53.06 to 0.94 to 27.50 ms 71.06 ms 18.94 ms 27.00 ms 18.94 ms 27.00 ms 71.06 ms ON OFF Frame | ON Frame Frame OFF chattering chattering space (1) space (2) chattering space (1) chattering Figure 3-1. Timing Chart when Key is Pressed and Held Key input : Actual key operation (manually pressing or releasing a key)Software key : Software-based key operation (key input judgment by program) REM output : Transmission waveform output via REM pin ON chattering : This refers to ON chattering elimination processing. Key input is checked three times at 9.00- ms intervals. OFF chattering : This refers to OFF chattering elimination processing. Key input is checked throughout the (34- bit) bit space that includes the leader code and stop bit. Frame space (1): This frame space is used to maintain a one-frame time of 108.00 ms to modify the transmission time for custom codes. Frame space (2): When it is determined that the current frame is the first frame or that a key OFF status is in effect, frame space (2) is transmitted (during 27.00 ms) without any ON chattering elimination processing. #### 3.1.2 Timing during key OFF status Figure 3-2 shows timing charts for when a key is released during a frame transmission. Figure 3-2. Timing Chart for Key OFF Status (1/3) (1) When key is released during transmission of the first frame (key OFF status has been determined ten times consecutively during transmission of the first frame) ... Key OFF status is confirmed during transmission of second frame - (2) When key is released during transmission of the first frame (key OFF status has not been determined ten times consecutively during transmission of the first frame) - ... Key OFF status is confirmed during transmission of second frame Key input : Actual key operation (manually pressing or releasing a key) Software key : Software-based key operation (key input judgment by program) REM output : Transmission waveform output via REM pin $\hbox{ON chattering} \quad : \quad \hbox{This refers to ON chattering elimination processing. Key input is checked three times at 9.00-leaves of the elimination processing processin$ ms intervals. OFF chattering : This refers to OFF chattering elimination processing. Key input is checked throughout the (34- bit) bit space that includes the leader code and stop bit. $Frame\ space\ (1):\ This\ frame\ space\ is\ used\ to\ maintain\ a\ one-frame\ time\ of\ 108.00\ ms\ to\ modify\ the\ transmission$ time for custom codes. Frame space (2): When it is determined that the current frame is the first frame or that a key OFF status is in effect, frame space (2) is transmitted (during 27.00 ms) without any ON chattering elimination processing. Figure 3-2. Timing Chart for Key OFF Status (2/3) - (3) When key is released during transmission of the second frame (key OFF status has been determined ten times consecutively during transmission of the second frame) - ... Key OFF status is confirmed during transmission of second frame - (4) When key is released during transmission of the second frame (key OFF status has not been determined ten times consecutively during transmission of the second frame) - ... Key OFF status is confirmed by the key's ON chattering Key input : Actual key operation (manually pressing or releasing a key) Software key : Software-based key operation (key input judgment by program) REM output : Transmission waveform output via REM pin ON chattering : This refers to ON chattering elimination processing. Key input is checked three times at 9.00- ms intervals. OFF chattering: This refers to OFF chattering elimination processing. Key input is checked throughout the (34- bit) bit space that includes the leader code and stop bit. Frame space (1): This frame space is used to maintain a one-frame time of 108.00 ms to modify the transmission time for custom codes. Frame space (2): When it is determined that the current frame is the first frame or that a key OFF status is in effect, frame space (2) is transmitted (during 27.00 ms) without any ON chattering elimination processing. Figure 3-2. Timing Chart for Key OFF Status (3/3) (5) When key is released during transmission of the first frame and is pressed again later ... Key OFF cannot be confirmed since a key ON status is detected during the second frame Key input : Actual key operation (manually pressing or releasing a key)Software key : Software-based key operation (key input judgment by program) REM output : Transmission waveform output via REM pin ON chattering : This refers to ON chattering elimination processing. Key input is checked three times at 9.00- ms intervals. OFF chattering: This refers to OFF chattering elimination processing. Key input is checked throughout the (34- bit) bit space that includes the leader code and stop bit. Frame space (1): This frame space is used to maintain a one-frame time of 108.00 ms to modify the transmission time for custom codes. Frame space (2): When it is determined that the current frame is the first frame or that a key OFF status is in effect, frame space (2) is transmitted (during 27.00 ms) without any ON chattering elimination processing. #### 3.2 Timing Charts of Key Operations #### 3.2.1 Output patterns prior to key confirmation Prior to key confirmation, ON chattering elimination processing (9.00 ms $\times$ 3 times = 27.00 ms) is performed and a key is confirmed when it has the same status all 3 times. Key input confirmation is determined after at least 100 $\mu$ s (at least 6 instructions when operating at 455 kHz) has elapsed after the key source output pin goes to high level. Figure 3-3 shows the detailed output patterns prior to key confirmation. Figure 3-3. Output Patterns Prior to Key Confirmation (1/5) #### (1) When K4 is pressed - a: When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.34 ms to 1.95 ms. - b: Key input is checked.Execution time is approximately 0.41 ms. - c: This is the total output time for key scanning. This time varies according to the value of "a". Execution time ranges from approximately 4.23 ms to 4.84 ms. Figure 3-3. Output Patterns Prior to Key Confirmation (2/5) #### (2) When K43 is pressed - a: When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.34 ms to 1.95 ms. - b: Key input is checked. Execution time is approximately 0.41 ms. - c: This is the total output time for key scanning. This time varies according to the value of "a". Execution time ranges from approximately 4.23 ms to 4.84 ms. Figure 3-3. Output Patterns Prior to Key Confirmation (3/5) #### (3) When K29 is pressed along with valid combination key K32 (K29 + K32) - a: When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.34 ms to 1.95 ms. - b: Key input is checked.Execution time is approximately 0.41 ms. - c: This is the total output time for key scanning. This time varies according to the value of "a". Execution time ranges from approximately 4.23 ms to 4.84 ms. Figure 3-3. Output Patterns Prior to Key Confirmation (4/5) #### (4) When K9 and K12 are pressed but are invalid in identical key sources - a: When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.34 ms to 1.95 ms. - b: Key input is checked.Execution time is approximately 0.41 ms. Figure 3-3. Output Patterns Prior to Key Confirmation (5/5) #### (5) When K10 and K16 are pressed but are invalid in identical key sources - a: When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.34 ms to 1.95 ms. - b: Key input is checked. Execution time is approximately 0.41 ms. #### 3.2.2 Operation of combination key K29 is the combination key. There are three valid key combination pairs: K29 + K30, K29 + K31, and K29 + K32. For any pattern, a key combination is valid only when K29 is pressed first. In other words, if another key is pressed before or at the same time as K29, the key combination is not valid. Figure 3-4 shows examples of key operations when a key combination is entered. Figure 3-4. Timing Chart of Key Combination Operation (1/2) (1) If another valid key (K30 to K32) is pressed during transmission of the first frame of the K29 code, after the second frame of the K29 code is transmitted, the key combination becomes valid and the combination's code is transmitted. (2) If another valid key (from K30 to K32) is pressed during transmission of the third frame of the K29 code, after the K29 code and the third frame are transmitted, the key combination becomes valid and the combination's code is transmitted. Figure 3-4. Timing Chart of Key Combination Operation (2/2) (3) If K29 is pressed after another valid key (K30 to K32) has been confirmed, a key check produces a key error and no code is transmitted (the key combination is not valid). (4) If another valid key (K30 to K32) is pressed before K29 has been confirmed, a key check produces a key error and no code is transmitted (the key combination is not valid). #### 3.2.3 Key transfer operation A key transfer operation can be performed when a valid combination key has been pressed. The key transfer operation is an operation that occurs when a second key is pressed before a previously pressed key is released. The operation for the second key is performed when the previous key is released. Figure 3-5 shows the operation timing of a key transfer operation. Figure 3-5. Operation Timing of Key Transfer Operation (1) When a key transfer operation is performed to transfer to key B during transmission of the code for key A, a key check is performed after all of the code has been transmitted. A key error occurs if it is during a key combination period. When key A is released, key B becomes valid and its code is transmitted. (2) If the transfer to key B occurs before key A is confirmed, a key error occurs during the key check. A key error also occurs if it is during a key combination period. After key A is released, a key check is performed. Key B was released before it could be checked, so the check result is "no key". [MEMO] ## **CHAPTER 4 OUTPUT CODES** Table 4-1 lists the output codes. For output using the NEC format, NEC provides each customer with a custom code to avoid the risk of interfering with output from another remote control unit that outputs using the NEC format. This program is set to output 0AH as the custom code and F5H as the custom code'. Contact your NEC sales representative for information on obtaining a custom code. Table 4-1. Output Codes | Key No. | Custom code | Custom code' | Data | Key No. | Custom code | Custom code' | Data | Key No. | Custom code | Custom code' | Data | |---------|-------------|--------------|------|---------|-------------|--------------|------|---------|-------------|--------------|------| | K1 | 0AH | F5H | 00H | K17 | 0AH | F5H | 50H | K33 | 0AH | F5H | A0H | | K2 | 0AH | F5H | 01H | K18 | 0AH | F5H | 51H | K34 | 0AH | F5H | A1H | | K3 | 0AH | F5H | 02H | K19 | 0AH | F5H | 52H | K35 | 0AH | F5H | A2H | | K4 | 0AH | F5H | 03H | K20 | 0AH | F5H | 53H | K36 | 0AH | F5H | АЗН | | K5 | 0AH | F5H | 04H | K21 | 0AH | F5H | 54H | K37 | 0AH | F5H | A4H | | K6 | 0AH | F5H | 05H | K22 | 0AH | F5H | 55H | K38 | 0AH | F5H | A5H | | K7 | 0AH | F5H | 06H | K23 | 0AH | F5H | 56H | K39 | 0AH | F5H | A6H | | K8 | 0AH | F5H | 07H | K24 | 0AH | F5H | 57H | K40 | 0AH | F5H | A7H | | K9 | 0AH | F5H | 08H | K25 | 0AH | F5H | 58H | K41 | 0AH | F5H | A8H | | K10 | 0AH | F5H | 09H | K26 | 0AH | F5H | 59H | K42 | 0AH | F5H | A9H | | K11 | 0AH | F5H | 0AH | K27 | 0AH | F5H | 5AH | K43 | 0AH | F5H | AAH | | K12 | 0AH | F5H | 0BH | K28 | 0AH | F5H | 5BH | K44 | 0AH | F5H | ABH | | K13 | 0AH | F5H | 0CH | K29 | 0AH | F5H | 5CH | K45 | 0AH | F5H | ACH | | K14 | 0AH | F5H | 0DH | K30 | 0AH | F5H | 5DH | K46 | 0AH | F5H | ADH | | K15 | 0AH | F5H | 0EH | K31 | 0AH | F5H | 5EH | K47 | 0AH | F5H | AEH | | K16 | 0AH | F5H | 0FH | K32 | 0AH | F5H | 5FH | K48 | 0AH | F5H | AFH | | Key No. | Custom code | Custom code' | Data | |-----------|-------------|--------------|------| | K29 + K30 | 0AH | F5H | 90H | | K29 + K31 | 0AH | F5H | 91H | | K29 + K32 | 0AH | F5H | 92H | [MEMO] ## **CHAPTER 5 SOFTWARE CONFIGURATION** ### 5.1 General Flow Chart Figure 5-1 shows a general flow chart of this program. START Figure 5-1. General Flow Chart ## 5.2 Program Memory (ROM) Configuration The $\mu$ PD6133's program memory (ROM) consists of 512 steps $\times$ 10 bits. Figure 5-2 shows a ROM map for this program and Figure 5-3 shows a table data map. Figure 5-2. ROM Map Figure 5-3. Data Table Map ## 5.3 Data Memory (RAM) Configuration The data memory (RAM) consists of $32 \times 4$ bits static RAM, which is used to store processing data. Some instructions enable RAM contents to be manipulated in 8 bits units. R0 can function as a data pointer for ROM addresses. ROM contents can be accessed once a ROM address is set to this data pointer. This is called a table lookup for ROM data. When reset, the value of R0 becomes 00H. RF can also be used as an address stack register. When reset, the values of R1 to RF are undefined. Tables 5-1 to 5-3 show RAM maps for the entire program (key input processing and transmission processing), for key input processing alone, and for transmission processing alone. Table 5-4 describes RAM usage. Table 5-1. RAM Map | | H (1) | L (0) | |----|----------------------------------------------------|---------------------------------------------------------| | R0 | Work area 1<br>Data pointer H | Chattering counter Data pointer L | | R1 | Confirmation key data H | Confirmation key data L | | R2 | For immediate setting (0EH) | For immediate setting (1H) | | R3 | K29 ON flag | Continue flag | | R4 | Key data H<br>Custom code H | Key data L<br>Custom code L | | R5 | Custom code' H | Custom code' L | | R6 | Key ON flag<br>Data code H | Key scan counter Data code L | | R7 | For immediate setting (0FH) | Key OFF check counter | | R8 | Key scan data H For immediate setting (0FH) Data 1 | Key scan data L<br>For immediate setting (0H)<br>Data 0 | | R9 | Compare key, data H<br>Data 1 transmit counter H | Compare key, data L Data 1 transmit counter L | | RA | Work area 2 | Key return check counter Transmit bit counter | | RB | For immediate setting (0CH) | For immediate setting (3H) | | RC | Not used | Not used | | RD | Not used | Not used | | RE | Not used | Not used | | RF | Address sta | ack register | Table 5-2. Map of RAM Used for Key Input Processing | | H (1) | L (0) | |----|---------------------------------------------|-----------------------------------------------| | R0 | Work area 1<br>Data pointer H | Chattering counter Data pointer L | | R1 | Confirmation key data H | Confirmation key data L | | R2 | For immediate setting (0EH) | For immediate setting (1H) | | R3 | K29 ON flag | Continue flag | | R4 | Key data H<br>Custom code H | Key data L<br>Custom code L | | R5 | Custom code' H | Custom code' L | | R6 | Key ON flag<br>Data code H | Key scan counter Data code L | | R7 | | | | R8 | Key scan data H For immediate setting (0FH) | Key scan data L<br>For immediate setting (0H) | | R9 | Compare key, data H | Compare key, data L | | RA | | Key return check counter | | RB | For immediate setting (0CH) | For immediate setting (3H) | | RC | Not used | Not used | | RD | Not used | Not used | | RE | Not used | Not used | | RF | Address sta | ack register | : Used for transmission processing Table 5-3. RAM Map Used for Transmission Processing | | H (1) | L (0) | |----|-----------------------------|---------------------------| | R0 | Data pointer H | Data pointer L | | | Work area 1 | | | R1 | | | | R2 | | | | R3 | | Continue flag | | R4 | Custom code H | Custom code L | | R5 | Custom code' H | Custom code' L | | R6 | Data code H | Data code L | | R7 | For immediate setting (0FH) | Key OFF check counter | | R8 | Data 1 | Data 0 | | R9 | Data 1 transmit counter H | Data 1 transmit counter L | | RA | Work area 2 | Transmit bit counter | | RB | | | | RC | Not used | Not used | | RD | Not used | Not used | | RE | Not used | Not used | | RF | Address sta | ack register | : Used for key input processing Table 5-4. Description of RAM Usage (1/2) | Name | RAM | Description | | | | |-----------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Data pointer | R0 | This pointer is used for indicating ROM addresses. It is used when performing a table lookup for ROM data. | | | | | Chattering counter | R00 | This counter is used to count the number of times chattering occurs during key input processing. 0CH is set to this counter as the initial value for a count of three. 0FH indicates completion of three times. | | | | | Work area 1 | R10 | This is a work area that is used to temporarily store data. | | | | | Confirmation key data | R1 | This is used to store confirmation key data after ON chattering elimination processing has been completed. If other confirmation key data has already been stored, it is compared with the key data (R4) when chattering elimination processing is completed. If the two sets of data match, the previous data is retained. If they do not match, the new key data (R4) is stored. | | | | | For immediate setting (1H) | R02 | This is used to clear the high-order three bits or to set 1H. | | | | | For immediate setting (0EH) | R12 | This is used to clear the lowest three bits or to set 0EH. | | | | | Continue flag | R03 | During transmission processing, this flag is used to determine whether it is the first frame or a second or subsequent frame that is currently being transmitted. | | | | | | | Value Description | | | | | | | 0FH Second or subsequent frame is being transmitted | | | | | | | 0H First frame is being transmitted | | | | | | | 0FH: Set, 0H: Clear | | | | | K29 ON flag | R13 | This flag is used to determine whether or not the K29 key (combination key) has been pressed. | | | | | | | Value Description | | | | | | | 0FH K29 key has been pressed | | | | | | | 0H Key other than K29 key has been pressed | | | | | | | 0FH: Set, 0H: Clear | | | | | Key data | R4 | This is used to store the previous key data during ON chattering. This data is compared with the compare key data (R9). If they match, the previous data is retained. If they do not match, the new compare key data (R9) is stored. | | | | | Custom code | R4 | This is used to store the custom code. | | | | | Custom code' | R5 | This is used to store the custom code'. | | | | | Data code | R6 | This is used to store the data code. | | | | | Key scan counter | R06 | This counter is used to count the number of key scans. Since a count of eight is required, 8H (8 times) is set as the counter's initial value. | | | | | Key ON flag | R16 | This flag is used to determine whether or not a key has been pressed. | | | | | | | Value Description | | | | | | | 0FH Key has been pressed | | | | | | | 0H Key has been released | | | | | | | 0FH: Set, 0H: Clear | | | | Table 5-4. Description of RAM Usage (2/2) | Name | RAM | Description | | | | |-----------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Key OFF check counter | R07 | This counter is used to count the number of times key off status occurs during bit data transmission. Although a count of ten is required, 5H is set as the initial value. When the value becomes 0FH (meaning ten continuous times of key OFF status), key OFF status is confirmed. If key OFF status is not determined at this time, the counter value is initialized. | | | | | For immediate setting (0FH) | R17 | This is used to set various flags. | | | | | Key scan data | R8 | This is used to store output data for key scanning. | | | | | Data 0<br>Data1 | R08<br>R18 | This is used to store the row addresses of time data (table data) for transmitting a bit data value of "0" or "1". Data 0: Bit data "0" Data 1: Bit data "1" | | | | | For immediate setting (0H) | R08 | This is used to set various flags. | | | | | For immediate setting (0FH) | R18 | This is used for flag setting and data inversion. The setting is "0FH". | | | | | Compare key data | R9 | This is used to store key data during ON chattering. | | | | | Data 1 transmit counter | R9 | This counter is used to count the number of times bit data "1" is transmitted. | | | | | Key return check counter | ROA | This counter is used to calculate the key data based on the key return data. Since a count of four is required for K <sub>I</sub> input and a count of two is required for input of S <sub>0</sub> or S <sub>1</sub> , a initial value of 0CH (for four times) or 0EH (for two times) is set. | | | | | Transmit bit counter | R0A | During bit transmission processing, this checks whether the required number of transmit bits are in the bit data stored in work area 2 (R1A). The counter counts from one to four times. | | | | | | | Setting Description | | | | | | | 0FH 1-bit transmission (for transmitting leader code and stop bit) | | | | | | | 0EH 2-bit transmission (not used) | | | | | | | 0DH 3-bit transmission (not used) | | | | | | | OCH 4-bit transmission (for transmitting custom code, custom code', data code, and data code) | | | | | Work area 2 | R1A | This is used to store output data for bit transmissions. | | | | | For immediate setting (3H) | R0B | This is used for data judgments and for setting 3H. | | | | | For immediate setting (0CH) | R1B | This is used for data judgments and for setting 0CH. | | | | | | | | | | | ## 5.4 Flag Maps Table 5-5 shows flag operations during various types of processing. Table 5-5. Flag Map ## (1) Continue flag (R03) | | R03 | | |---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------| | Initialization processing | Clear (0H) | | | Key input processing | When the key data used for ON chattering elimination processing differs from the confirmation key data from the previous ON chattering elimination processing. | Clear (0H) | | Transmission processing | During frame space transmission of all frames | Judgment | | | During frame space transmission of only one frame | Set (0FH) | Judgment: A judgment is made during this processing. ## (2) K29 ON flag (R13) | | Processing | R13 | |---------------------------|---------------------------------------------------------------------------------|-----------| | Initialization processing | Clear (0H) | | | Key input processing | When key is ON and flag has been set | Judgment | | | When chattering has been completed 3 times and the confirmation key data is K29 | Set (0FH) | | | Clear (0H) | | | Transmission processing | | _ | Judgment: A judgment is made during this processing. —: Not used ## (3) Key ON flag (R16) | | R16 | | | | |---------------------------|----------------------------------------------------|------------|--|--| | Initialization processing | _ | | | | | Key input processing | | Clear (0H) | | | | | Start of key return check | Judgment | | | | | Judgment | | | | | | During key return check or when there is key input | | | | | | Judgment | | | | | Transmission processing | × | | | | Judgment: A judgment is made during this processing. —: Not used, x: Used by other application [MEMO] ### **CHAPTER 6 PROGRAM DESCRIPTION** ## 6.1 Initial Settings Microcontrollers used in infrared remote control transmitters generally use batteries as their power source. However, the lighting of infrared LEDs requires a large current consumption. The abrupt change in the power supply voltage when infrared LEDs are being lit can cause sudden changes in the contents of RAM, ports, etc., which must be taken into consideration. To prevent operation faults that may occur as a result of sudden changes in the contents of RAM, ports, etc., the program can be designed to reset initial settings after each transmission. ### 6.1.1 Description of processing ## (1) Port settings and control register initialization ### (a) Ki/o port (P0) This is an 8-bit I/O port that is used for key scan output. This port's initial setting is FFH. All of the port's bits (KI/O1 to KI/O7) are set for high level output. ## (b) Control register 0 (P3) Tables 6-1 and 6-2 list the contents of control register 0. The initial setting is 13H. The initial settings are shown in shaded areas in Tables 6-1 and 6-2. Table 6-1. Control Register 0 (P3) | Bit | | b <sub>7</sub> | b <sub>6</sub> | b <sub>5</sub> | b <sub>4</sub> | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | |-----------|----|----------------|----------------|-------------------|----------------|------|----------------|------------------|------------------| | Name | | _ | _ | DP (data pointer) | | TCTL | CARY | MOD <sub>1</sub> | MOD <sub>0</sub> | | | | | | DP <sub>9</sub> | DP8 | | | | | | Setting | 0 | Fixed as "0" | Fixed as "0" | 0 0 | | 1/1 | ON | See Table | <b>6-2</b> . | | | 1 | | | 1 | 1 | 1/2 | OFF | | | | After res | et | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | bo and b1 ...... Specify the REM output's carrier frequency and duty factor. b2 ...... Indicates presence/absence of carrier for frequency specified by b0 and b1. "0" = ON (with carrier), "1" = OFF (no carrier, high level) b<sub>3</sub> ...... Changes the carrier frequency and the timer clock division ratio. "0" = 1/1 (carrier frequency: values set to bo and b1, timer clock: fx/8) "1" = 1/2 (carrier frequency: one half of values set to b<sub>0</sub> and b<sub>1</sub>, timer clock: fx/16) Table 6-2. Time Clock and Carrier Frequency Settings | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | Timer clock | Carrier frequency (duty factor) | |----|----------------|----------------|----------------|-------------|---------------------------------| | 0 | 0 | 0 | 0 | fx/8 | fx (Duty 1/2) | | | | 0 | 1 | | fx/8 (Duty 1/2) | | | | 1 | 0 | | fx/12 (Duty 1/2) | | | | 1 | 1 | | fx/12 (Duty 1/3) | | | 1 | × | × | | No carrier (high level) | | 1 | 0 | 0 | 0 | fx/16 | fx/2 (Duty 1/2) | | | | 0 | 1 | | fx/16 (Duty 1/2) | | | | 1 | 0 | | fx/24 (Duty 1/2) | | | | 1 | 1 | | fx/24 (Duty 1/3) | | | 1 | × | × | | No carrier (high level) | b4 and b5 ...... Specify the high-order two bits (DP8 and DP9) of the ROM data pointer. Remarks 1. $\times$ : don't care 2. : Initial setting (13H)3. fx : System clock frequency ## (c) Control register 1 (P4) Table 6-3 lists the contents of control register 1. The initial setting is 33H, which is shown in the shaded areas of the table. Table 6-3. Control Register 1 (P4) | Bit | | b <sub>7</sub> | b <sub>6</sub> | b <sub>5</sub> | b <sub>4</sub> | b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | |-------------|---|----------------|----------------|-----------------|---------------------------------------------|----------------|-----------------------------|-----------------------|----------------| | Name | | _ | - | Kı<br>pull-down | S <sub>0</sub> /S <sub>1</sub><br>pull-down | - | S <sub>1</sub> /LED<br>mode | K <sub>I/O</sub> mode | S₀<br>mode | | Setting | 0 | Fixed as "0" | Fixed as "0" | OFF | OFF | Fixed as "0" | S <sub>1</sub> | IN | OFF | | | 1 | | | ON | ON | | LED | OUT | IN | | After reset | | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | Remarks 1. All pull-down resistors are automatically switched off during output mode and OFF mode. 2. Initial setting (33H) ### (2) Initialize RAM The following RAM contents are cleared to "0". - · Confirmation key data (R1) - Continue flag (R03) - K29 ON flag (R13) #### (3) Set STOP mode Table 6-4 lists the cancellation conditions for the HALT instruction. The initial setting is 8H. When initialized, the (STOP mode) cancellation conditions are set as shown in the shaded areas of the table. Table 6-4. Cancellation Conditions for HALT Instruction | HALT instruction operand value | | | d value | Mode | Precondition for settings Cancellation condit | | | | |--------------------------------|------------------------------------------------------------|----------------|----------------|------------|-----------------------------------------------|----------------------------------------------------------------------------------------|--|--| | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | Setting | | | | | | 0 | 0 | 0 | 0 | STOP | High-level output from all Kilo pins | High-level input via at least one Kı<br>pin | | | | | 0 | 1 | 1 | STOP | High-level output from all Kilo pins | High-level input via at least one Kı<br>pin | | | | | 1 | 1 | 0 | STOPNote 1 | High-level output from K <sub>1/00</sub> pin | High-level input via at least one Kı<br>pin | | | | 1 | Any combination of | | | STOP | [The following conditions in ad | in addition to the above conditions] | | | | | b <sub>2</sub> , b <sub>1</sub> , and b <sub>0</sub> above | | | | _ | High-level input via at least one pin between S <sub>0</sub> and S <sub>1</sub> Note 2 | | | | 0/1 | 1 | 0 | 1 | HALT | _ | When timer's down counter reaches 0 | | | - **Notes 1.** When HALT #X110B is set, use the K<sub>1</sub>/<sub>00</sub> pin and the K<sub>1</sub> pin to configure a key matrix so that an internal reset is executed whenever a runaway (control loss) condition occurs. - 2. So and/or S1 (at least one of these pins that are used to cancel standby mode) must be set to input mode (an internal reset will not be executed if both are set to output mode). - Cautions 1. An internal reset is executed if the HALT instruction is executed using operand values other than those specified above or when the precondition for HALT instruction execution has not been met. - 2. If STOP mode is set when the timer's down counter has not yet reached "0" (i.e., when the timer is operating), all 10 bits of the enable flags for the timer's down counter and the timer output are cleared to zero and STOP mode is set. - 3. Specify a NOP instruction as the first instruction following cancellation of STOP mode. | Remark | ]: | Initial | setting | (8H) | |--------|----|---------|---------|------| |--------|----|---------|---------|------| (4) After cancellation of STOP mode, execute an NOP instruction, then initialize the timer. The timer's initial setting is 1CH (= 0.5 ms). ### 6.1.2 Detailed flow chart ``` ****** INITIALIZATION PROCESSING ****** TIME05M EQU 01CH ;0.5ms DamyTime EQU 512-1 ;9.00ms ;######### U B L ########## P I C PUBLIC MAIN ;######### Т E ######### ;####### S T A R ######### Control Register Initialize MAIN: (a) Sets all key scan outputs (K<sub>1/0</sub>) to high level OUT P0,#0FFH (b) Initializes ports OUT P4,#033H S_0, S_1: Input mode, K_{I/O}: output mode OUT P3,#013H (c) Initializes control registers 0 and 1 (P3 and P4) With carrier, frequency: fx/12, duty factor: 1/3 TCTL: 1/1, Kı: with pull-down resistor So, S1: with pull-down resistor Data pointer: DP<sub>8</sub>, DP<sub>9</sub> = 01H (MSB of table lookup address) T, #DamyTime \ MOV ..... (d) Clears status flags STTS #0101B RAM Initialize Routine (e) Initializes RAM Confirmation key data (R1): 00H MOV R1,#000H MOV R3,#000H K29 ON flag (R13), continue flag (R03): 00H (f) STOP mode: Canceled by high-level input via K_1,\, S_0,\, \text{and}\,\, S_1 HALT #008H NOP (g) NOP instruction (h) Initializes timer value MOV T, #TIME05M 1CH = 0.5 \text{ ms} ; ``` END ## 6.2 Key Input Processing ## 6.2.1 Description of processing Key input processing includes chattering elimination processing, key scan processing, custom code generation processing, and key data generation processing. ### (1) Chattering elimination processing When switching to key ON or key OFF status, an unstable condition called chattering (ON chattering or OFF chattering) exists until the key signal is stabilized as a high level or low level signal (see Figure 6-1). Since key input during this unstable condition is also unstable, the program must provide a means of eliminating chattering. Figure 6-1. Chattering of Key Input Signal Figure 6-2 illustrates an example of chattering elimination processing (key ON judgment example). At point <1>, key ON status is detected when STOP mode is canceled, and key input is checked during a set time period (from <1> to <4>: $9.00 \text{ ms} \times 3$ ). In part (a) of the figure, key ON status is detected at all check points, so the key signal is judged to be at high level at the software key's <4>. The wait period (a + b + c) after key ON status is detected at point <1> and before the software judges the signal's high level status is called the chattering elimination period. In part (a), the chattering elimination period is "a + b + c" since the key input status is always ON when checked. In part (b), the chattering elimination period is "d + e + f + g + h". Figure 6-2. Key ON Judgment when Chattering Occurs (a) (b) ## (2) Key scan processing Key scan processing is described in sections (a) and (b) below. ### (a) Key matrix Figure 6-3 shows an example of a 48-key key matrix. In this example, Ki/00 to Ki/07 are output ports that output key scan signals. These signals are captured (as key return signals) via input ports comprised of K<sub>10</sub> to K<sub>13</sub>, S<sub>0</sub> and S<sub>1</sub>. Since the program connects these key return signal input ports (K<sub>10</sub> to K<sub>13</sub>, S<sub>0</sub> and S<sub>1</sub>) to an internal pull-down resistor, low-level signals are input when no keys are being pressed. Figure 6-3. 48-key Key Matrix Note The program is set for "internal pull-down resistor". ## (b) Key scan To judge which of the keys in the 48-key key matrix is being pressed, the STTS instruction is used to check for high-level signal input via $K_{10}$ to $K_{13}$ , $S_0$ , and $S_1$ . Next, the key scan signal's output ports ( $K_{1/00}$ to $K_{1/07}$ ) are set to high level one at a time starting from $K_{1/00}$ to determine which output among $K_{1/00}$ to $K_{1/07}$ corresponds to the detected input. During the key scan processing part of the program, the key scan counter (key source position) and key return check counter (key return position) are used to detect the key data (key position). Figure 6-5 shows the correspondence between key data and the values of these two counters. For description of the key data's bit configuration in data memory, see "(4) (a) Bit configuration of key data". When performing a key scan, factors such as stray capacitance in the keyboard and key source delay due to line impedance must be taken into consideration. Therefore, this program waits for about 100 $\mu$ s (six steps when at 455 kHz) following high-level output before capturing the key input. K29 K30 K31 K32 K47 K48 **K**I/07 **K**I/06 K25 K26 K27 K28 K45 K46 **K**I/O5 K44 K21 K22 K23 K24 K43 K17 K18 K19 K20 K41 K42 **K**I/O4 K16 K39 K40 **K**I/O3 K13 K14 K15 **K**I/O2 K9 K10 K11 K12 K37 K38 K5 K6 K7 K8 K36 $K_{I/O1}$ K35 K1 K2 K3 K4 K33 K34 **K**I/O0 Кіз $K_{12}$ K<sub>I1</sub> Κıο $S_1$ $S_0$ Figure 6-4. Key Matrix Figure 6-5. Key Data (Key Position) #### (3) Custom code generation processing This program is set to output 0AH as the custom code and F5H as the custom code'. Specifically, 50H is set to data memory R4 as the custom code and AFH is set to R5 as the custom code'. Caution In the NEC format, the LSB is transmitted first, so values are set in opposite order to the bit string. #### (4) Key data generation processing Key data generation processing is described in (a) and (b) below. Key data H #### (a) Bit configuration of key data Key data consists of eight bits. Each bit indicates a key source and key return status. To accommodate the eight types from $K_{I/O7}$ , the key scan counter uses the LSB of key data H and the high-order two bits of key data L when input is via $K_{I0}$ to $K_{I3}$ , and uses the high-order three bits of key data L when input is via $S_0$ and $S_1$ . The key return check counter accommodates the four types from $K_{I0}$ to $K_{I3}$ by using the low-order two bits of key data L and accommodates the two types $S_1$ and $S_0$ by using the LSB of key data L. When the first key input is detected, 0CH is set to key data H if the input is via $S_0$ and $S_1$ . This key data H is also used to determine the format used to generate the key data, as shown in Figures 6-6 and 6-7. As is described in "(b) Data code" below, this key data is also used as an address for table reference. Therefore, the key data is configured as shown in Figures 6-6 and 6-7. Key data L Key return Key scan counter check counter 1 0 1 KS2 KS1 KS<sub>0</sub> KR1 KR0 bit3 bit2 bit3 bit1 bit0 bit2 bit1 bit0 Figure 6-6. Bit Configuration of Key Data when Input is via K<sub>10</sub> to K<sub>13</sub> Figure 6-7. Bit Configuration of Key Data when Input is via So and So ## (b) Data code The data code can be calculated by using the key data obtained via key input processing (as shown in Figures 6-6 and 6-7) as an address for table lookup. The table lookup method uses the contents of ROM as a transmit code by setting 1H to the high-order four bits of control register 0 (P3) and by setting the key data to the data pointer (see Figure 6-8). Figure 6-8. Configuration of Data Pointer ## Example When key position is K26 (key input K12) - Key scan counter (R06) = EH Key return check counter (R0A) becomes DH (see Figure 6-5). - 2. The low-order three bits of the key scan counter and the low-order two bits of the key return check counter are used to configure the key data, as was shown in Figure 6-6. - 3. Set key data to data pointer. - Configuration of data pointer 0001 1011 $1001 \rightarrow 189$ H #### **CHAPTER 6 PROGRAM DESCRIPTION** The following table reference addresses are generated when a key is generated using one of the bit configurations shown in Figures 6-6 and 6-7. As mentioned above, 1H is set to the high-order four bits of control register 0 (P3). - Key input: K<sub>10</sub> to K<sub>13</sub>, key position: K1 to K32 ... reference addresses = 1A0H to 1BFH - Key input: So and S1, key position: K33 to K48 - ... reference addresses = 1C0H to 1CFH - Key combination (K29 + K30, K29 + K31, K29 + K32) When a key combination has been confirmed, 9H is set to key data H. K29 + K30 ... reference address = 19DH K29 + K31 ... reference address = 19EH K29 + K32 ... reference address = 19FH #### 6.2.2 Detailed flow chart ``` ****** KEY INPUT PROCESSING ****** TIME9M EOU 1FFH ;9.00ms(9.002ms) CUSTM1 EQU 050H ;Custom Code = 0AH CUSTM2 EQU 0AFH ;Custom Code' = F5H ;########## ######### Р ŢŢ В L I C PUBLIC KEY48 ; ;########## Е Т E ######### X R MAIN ;MAIN Routine EXTRN ; ;######### Т R Т ######### KEY48: (a) Sets (0CH to) chattering counter (Roo) MOV R0,#00CH (3 count end at 0FH.) ; ************* ON Chattering ON_CHAT: STTS #0101B (b) Clears status flag (c) Sets all K<sub>VO</sub> outputs to high level OUT P0,#0FFH (d) Sets input mode for S<sub>1</sub> and S<sub>0</sub> OUT P4,#033H HALT #005H (e) HALT mode: timer is canceled when count reaches 00H MOV T, #TIME9M (f) Sets timer counter. (9 ms = 1FFH) MOV R9,#000H (g) Initializes (sets to "00H") compare key data (R9) MOV R6,#008H (h) (i) Sets 8H to key scan counter (Ro6) and sets 0H to clear key ON flag (R<sub>16</sub>) (j) Determines when there is key input (via K_1, S_0, or S_1) STTS #1110B JNF MAIN If no key input, processing branches to MAIN (k) Initializes (sets 01H to) key scan data (R8) MOV R8,#001H Key Scan KEYS_OUT: MOV A.R08 · · · · · · · · · · · · · (I) Outputs key scan data (P<sub>0</sub>) OUT P00,A MOV A,R18 P10,A ;++ 100-\mu s wait before key input ++ MOV Remark R2 is used to set immediate data (R12: 0EH, R02: 1H). R2,#0E1H Remark RB is used to set immediate data (R1B: 0CH, R0B: 3H). RB,#0C3H MOV (m) 100-µs wait before performing key input check NOP NOP NOP NOP ``` | ;*********************** | | | | | | | | | |-----------------------------------------|------------------------|-----------------------------------------|--------------------------------------------------------------------------------------------|--|--|--|--|--| | ; | | Key Return Check | | | | | | | | ; * * * * * * * * * * * * * * * * * * * | | | | | | | | | | | STTS | #1011B | (n) Determines whether or not there is key input. | | | | | | | | JNF | NO_KEYS | If no key input, processing branches to NO_KEYS. | | | | | | | | STTS | #0011B | (o) Determines whether input is via K <sub>1</sub> or S <sub>0</sub> and S <sub>1</sub> | | | | | | | | JNF | S0S1CALC | If via So and So, processing branches to SOS1CALC. | | | | | | | ; * * * * * | ****** | ***** | | | | | | | | ; KI Data Calculate | | | | | | | | | | ; * * * * * | ****** | ***** | | | | | | | | | IN | A,P01 | | | | | | | | | RL | A | (p) When there is input via K <sub>I</sub> , it determines whether there is | | | | | | | | JC | MAIN | also input via S₀ and S₁. | | | | | | | | RL | A | If there is also input via $S_0$ or $S_1$ , a key error is detected | | | | | | | | JC | MAIN | and it goes to MAIN processing. | | | | | | | | VOM | A,R1B | (q) Initializes the key return check counter (R <sub>0A</sub> ). | | | | | | | | VOM | ROA,A | $0CH = 4$ times (In this case, $R_{1B} = 0CH$ ). | | | | | | | | IN | A,P11 | (r) The pin status (P <sub>11</sub> ) of K <sub>I</sub> is transferred to the accumulator. | | | | | | | | JMP | KEY_RETO | | | | | | | | ; * * * * * | ******* | * * * * * * * * * * * * * * * * * * * * | | | | | | | | ; | ; S0,S1 Data Calculate | | | | | | | | | ; * * * * * | ******* | * * * * * * * * * * * * * * * * * * * * | | | | | | | | S0S1CAI | C: | | | | | | | | | | VOM | R9,#0С0Н | (s) A judgment value (0CH) for K33 to K48 (for input via S <sub>0</sub> | | | | | | | | | | and $S_1$ ) is set to the compare key data H ( $R_{19}$ ). | | | | | | | | VOM | A,R12 | | | | | | | | | VOM | ROA,A | (t) Initializes the key return check counter (R <sub>0A</sub> ). | | | | | | | | | | 0EH = 2 times (in this case, R <sub>12</sub> = 0EH). | | | | | | | | IN | A,P01 | (u) The pin status (Po1) of So or S1 is transferred to the | | | | | | | | <b>70</b> - | | accumulator. | | | | | | | KEY_RETO: | | | | | | | | | | | MOV | R10,A | Remark The accumulator's value (Poo or Po1) is stored in the work area. | | | | | | | | STTS | #0101B | (v) Clears status flag. | | | | | | # CHAPTER 6 PROGRAM DESCRIPTION Accumulator values | KL_CALC: | | K₁ input | | | | |----------|-------|----------|---------------------------------------------|----------------------------------------|--------| | ANL | A,R0A | (t) | For K <sub>1</sub> input, the low-order two | 0 0 K | R1 KR0 | | | | | bits of the key return counter | | | | | | | (ROA) is stored in the accumulator. | S <sub>0</sub> or S <sub>1</sub> input | | | | | | For So or S1 input, the LSB is | 0 0 | 0 KR0 | | | | | stored in the accumulator. | | | | ORL | A,R09 | (u) | OR processing of accumulator | Kı input | | | | | | values and compare key data L | KS1 KS0 K | R1 KR0 | | | | | (Ro9). | S <sub>0</sub> or S <sub>1</sub> input | | | | | | | KS2 KS1 K | S0 KR0 | | MOV | R09,A | (v) | Accumulator data is stored in | | | | | | | compare key data L (R <sub>09</sub> ). | | R09 | # **CHAPTER 6 PROGRAM DESCRIPTION** To transmission processing #### **CHAPTER 6 PROGRAM DESCRIPTION** ## 6.3 Transmission Processing Transmission processing transmits custom code, custom code', data code, and data code stored in the data memory, using the NEC-R format that was described in **CHAPTER 2 TRANSMISSION WAVEFORM**. The transmission method uses a data table to store transmission times sets the timer counter via a table reference operation. Afterward, it enters HALT mode (cancellation condition: TIMER) to enable transmission. A method such as that shown in Figure 6-10 is used to ensure correct and simple time management. Immediately after cancellation of HALT mode, a similar method is used to set the transmission time data for the next transmission to the timer counter so that the transmission operation can be performed during a set time between HALT modes. When carrier output is set to ON (hereafter, this status is called "H"), the timer counter's MSB (output control bit) is set. When carrier output is set to OFF (hereafter, this status is called "L"), the timer counter's MSB (output control bit) is cleared. Figure 6-9 shows the timer counter's configuration. Figure 6-9. Configuration of Timer Counter Figure 6-10. Time Management of Timer Counter The timer's operation time can be calculated as [(Setting + 1) $\times$ 8/fx]. When operating at 455 kHz, "MOV T,#1FFH" indicates that $[(1FFH + 1) \times 8/(455 \times 10^3) \div 9.00 \text{ ms}]$ has been set. #### 6.3.1 Description of processing Transmission processing includes the following seven types of processing. - Initialization - · Leader code transmission - Code transmission (custom code, custom code', data code, and data code) - · Stop bit transmission - · Frame space transmission - Transmission of second and subsequent frames - · OFF chattering elimination processing Each of these types of processing is described below. #### (1) Initialization The initialization procedure for transmission processing is described in (a) and (b) below. - (a) The key OFF check counter (R07) is set to 10 times (= 05H). - (b) The data 1 transmit counter is set to 0DFH (for 24 bits). Table 6-5 describes the counter contents. The data 1 transmit counter is used to count the number of times "bit data 1" is transmitted within custom code or custom code' that can affect the frame space transmission time. The number of "data 1" occurrences in the data code and data code is fixed (at eight) and therefore does not affect the frame space transmission time. Table 6-5. Description of Data 1 Transmit Counter (R9) | Counter value | Data 1 transmit counter description | | | | | | | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | D0H<br> <br>E6H | Number of "data 1" occurrences: 0 to 7 This status does not exist since the number of "data 1" occurrences in data code and data code is fixed (at eight). | | | | | | | | E7H | Number of "data 1" occurrences: 8 Number of "data 1" occurrences in custom code and custom code': 0 | | | | | | | | E8H<br> <br>EFH | Number of "data 1" occurrences: 9 to 16 Number of "data 1" occurrences in custom code and custom code': 1 to 8 | | | | | | | | F0H<br> <br>F7H | Number of "data 1" occurrences: 17 to 24 Number of "data 1" occurrences in custom code and custom code': 9 to 16 | | | | | | | #### (2) Leader code transmission The transmission method for the leader code is described in (a) to (f) below. - (a) The table reference address (1D8H) for the leader code is set as follows. - High-order address (0DH) is set to data pointer H (R10) - Low-order address (8H) of "data 0" in bit data is set to data 0 (R08) - (b) Output data 0H for leader code is set to work area 2 (R1A). - (c) A subroutine (BITOUT0F) is called to transmit the leader code as a one-bit transmission. - (d) Work area 2 (R1A) is shifted leftward and a bit judgment is performed. - (e) The table reference address L for the judged bit is set to data pointer L to enable the transmission time to be set to the timer counter. - (f) The leader code (H: 9.00 ms, L: 4.50 ms) is transmitted. ## (3) Code transmission (custom code, custom code', data code, and data code) The code transmission method is described in (a) to (h) below. - (a) The table reference addresses (1DAH and 1DCH) for bit data used for code transmission are set as follows. - High-order address (0DH) is set to data pointer H (R10) - Low-order address (0AH) of "data 0" in bit data is set to data 0 (R08) - Low-order address (0CH) of "data 1" in bit data is set to data 1 (R18) - (b) The following data is set to work area 2 (R1A) when each type of code is transmitted. - Custom code H (R14) - Custom code H' (R15) - Data code H (R16) - Data code H (R16 is fully inverted) - Custom code L (R04) - Custom code L' (R05) - Data code L (R06) - Data code L (R06 is fully inverted) - (c) A subroutine is called to transmit the each type of code as a four-bit transmission. - (d) Work area 2 (R1A) is shifted leftward and a bit judgment is performed. If "data 1" is judged, the number of "data 1" occurrences is counted to enable frame space transmission. - (e) The table reference address L for the judged bit is set to data pointer L to enable the transmission time to be set to the timer counter. - (f) Each type of code is transmitted. - "Data 0" ... H: 0.56 ms, L: 0.56 ms - "Data 1" ... H: 0.56 ms, L: 1.69 ms A key OFF check is performed during low level transmission of each bit. For a description of the key OFF check, see (7) OFF chattering elimination processing below. - (g) Steps (d) to (f) above are repeated until four bits have been transmitted. - (h) Steps (b) to (g) above are repeated until all transmissions from custom code H to data code L are completed. #### (4) Transmission of stop bit The method for transmitting stop bits is described in (a) to (f) below. - (a) The table reference address (1DEH) for the stop bit is set as follows. - High-order address (0DH) is set to data pointer H (R10) - Low-order address (0EH) of "data 0" in bit data is set to data 0 (R08) - (b) Output data 0H for stop bit is set to work area 2 (R1A). - (c) A subroutine is called to transmit the stop bit as a one-bit transmission. - (d) Work area 2 (R1A) is shifted leftward and a bit judgment is performed. - (e) The table reference address L for the judged bit is set to data pointer L to enable the transmission time to be set to the timer counter. - (f) The stop bit (H: 0.56 ms, L: 3.00 ms) is transmitted. #### (5) Frame space transmission The code transmission time differs between transmission of the "data 1" and "data 0" bit data, with variation in the range of 59.06 ms to 77.06 ms. Therefore, when transmitting code, the frame space transmission time varies according to the number of "data 1" occurrences. However, since the number of "data 1" occurrences is fixed (at eight) within the data code and data code, the frame space transmission times are not affected when these types of code are transmitted. The number of "data 1" occurrences in the custom code and custom code' do affect frame space transmission times. The number of "data 1" occurrences are counted during transmission to enable responses to changes in transmission times. The frame space transmission times can be adjusted based on the count values. For details of "data 1" counts, see (3) Code transmission above. Table 6-6 lists frame space times correspond to the number of "data 1" occurrences. Since the maximum value that can be set to the timer counter is 9.00 ms, the frame space is divided into the three patterns shown in Figure 6-11 before being transmitted. Differences between times shown in Table 6-6 and Figure 6-11 are margins of error during code transmission (such as when the "data 0" low level time of 0.565 is set as 0.56) which are absorbed by frame spaces. Table 6-6. Frame Space Times Corresponding to "Data 1" Occurrences | No. of "Data 1" occurrences | Transmission time (ms) | No. of "Data 1" occurrences | Transmission time (ms) | No. of "Data 1" occurrences | Transmission time (ms) | No. of "Data 1" occurrences | Transmission time (ms) | |-----------------------------|------------------------|-----------------------------|------------------------|-----------------------------|------------------------|-----------------------------|------------------------| | 8 | 8 48.940 13 | | 43.315 | 18 | 37.690 | 23 | 32.065 | | 9 | 9 47.815 | | 42.190 | 19 | 36.565 | 24 | 30.940 | | 10 | 46.690 | 15 | 41.065 | 20 | 35.440 | | | | 11 | 45.565 | 16 | 39.940 | 21 | 34.315 | | | | 12 | 44.440 | 17 | 38.815 | 22 | 33.190 | | | **Remark** Since the number of "data 1" occurrences in data code and data code is fixed (at eight), the "Data 1" values are never between 0 and 7. Figure 6-11. Method for Dividing Frame Space Transmission Times (1/2) (a) When there are eight "data 1" occurrences (data 1 transmission counter value: 0E7H) - a: After transmitting the stop bit, the frame space is transmitted for 3.00 ms. - b: A frame space for the time period corresponding to the number of "data 1" occurrences (18.94 ms) is transmitted. - c: If a key has been pressed and held, ON chattering elimination processing (9.00 ms $\times$ 3 times) is performed. In other cases, a frame space is transmitted for 27.00 ms. # (b) When there are from 9 to 16 "data 1" occurrences (data 1 transmission counter value range: 0E8H to 0EFH) - a: After transmitting the stop bit, the frame space is transmitted for 3.00 ms. - b: A frame space for the time period corresponding to the number of "data 1" occurrences (9.94 to 17.80 ms) is transmitted. - c: If a key has been pressed and held, ON chattering elimination processing (9.00 ms $\times$ 3 times) is performed. In other cases, a frame space is transmitted for 27.00 ms. Figure 6-11. Method for Dividing Frame Space Transmission Times (2/2) (c) When there are from 17 to 24 "data 1" occurrences (data 1 transmission counter value range: 0F0H to 0F7H) - a: After transmitting the stop bit, the frame space is transmitted for 3.00 ms. - b: A frame space for the time period corresponding to the number of "data 1" occurrences (0.94 to 8.80 ms) is transmitted. - c: If a key has been pressed and held, ON chattering elimination processing (9.00 ms $\times$ 3 times) is performed. In other cases, a frame space is transmitted for 27.00 ms. #### (6) Transmission of second and subsequent frames Until the current key is released or changed, code transmission of second and subsequent frames is repeated starting with the leader code in the same manner as for the first frame. This transmission method is described in (2) to (5) above. For a description of the key OFF check, see (7) OFF chattering elimination processing below. #### (7) OFF chattering elimination processing A key OFF check is performed during low level output of bit data. Key OFF status is confirmed only when absence of key input (i.e., key OFF) has been judged for ten consecutive times during 34 times of low level output that includes the leader code and stop bit. If even one key input (key ON) is detected during the ten consecutive times being checked, the ten-time counter is cleared and the count is restarted. If key OFF status is not confirmed during the entire 34-time check, the key is judged as being pressed and held. Even if key OFF status is confirmed during transmission of one frame, initialization processing is not performed until at least two frames have been transmitted. Figure 6-12. Key OFF Check during Bit Data Transmission Key OFF check (up to 34 times) #### 6.3.2 Detailed flow chart **Note** As part of the main routine, the output data for the leader code is set to the accumulator (A) and the same data is set to work area 2 (R1A) via the called subroutine (BITOUT0C). | ****** TRANSI | MISSION PROCESSING ****** | | |----------------------------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TIME9M | EQU 1FFH | ;9.00ms(9.002ms) | | ;######## | P U B L I C ##### | **** | | ;#########<br>EXTRN<br>EXTRN<br>; | E X T E R N ######<br>MAIN<br>KEY48 | ##### ;MAIN Routine ;Key Check Routine | | ;########<br>TRNS: | S T A R T ##### | #### | | MOV | R7,#0F5H | (a) Sets the key OFF check counter (R <sub>07</sub> ) for ten times (= 5H). R <sub>17</sub> is used for immediate setting (R <sub>17</sub> = 0FH). | | MOV | R9,#0DFH | (b) Initializes (sets DFH to) the data 1 transmission counter (R9). | | ; ********** | ************************************** | Remark Transmission of leader code (H: 9.00 ms, L: 4.50 ms) | | , | ********* | | | MOV | R0,#0D0H | (c) Sets the 0DH (high-order address of the table data for the bit data transmission time) to data pointer H. | | MOV | R8,#008H | (d) Sets the low-order address of the table data for the bit<br>data transmission time to data 1 (R <sub>18</sub> ) and data 0 (R <sub>08</sub> )<br>(R <sub>18</sub> ← 0H, R <sub>08</sub> ← 8H). | | MOV | A,R18 | <ul> <li>(e) Sets the output data (0H) for leader code to the accumulator.</li> <li>(The accumulator's value is transferred to work area 2 as part of the bit output subroutine.)</li> </ul> | | CALL | BITOUT0F | <ul><li>(f) Calls the bit output subroutine</li><li>(for one-bit transmission: counter value = 0FH).</li></ul> | | | | and the state of t | | ; ********** | ******** | | | ; | ************************************** | Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms) | | ; | Custom Code | Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms) | | ;<br>;****** | Custom Code<br>************************************ | <ul> <li>Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms)</li> <li>(g) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH).</li> <li>(h) Sets output data H (R₁4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as</li> </ul> | | ;;************************************ | Custom Code<br>************************************ | <ul> <li>Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms)</li> <li>(g) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH).</li> <li>(h) Sets output data H (R₁4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.)</li> <li>(i) Calls the bit output subroutine</li> </ul> | | ;;;*********************************** | Custom Code<br>************************************ | Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms) (g) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). (h) Sets output data H (R₁4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (i) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). (j) Sets output data L (R₀4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as | | ;;;*********************************** | Custom Code *********************************** | Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms) (g) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). (h) Sets output data H (R₁4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (i) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). (j) Sets output data L (R₀4) for custom code to accumulator. | | ;;;*********************************** | Custom Code *********************************** | Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms) (g) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). (h) Sets output data H (R₁4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (i) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). (j) Sets output data L (R₀4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (k) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). | | ;;;*********************************** | Custom Code *********************************** | Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms) (g) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). (h) Sets output data H (R₁4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (i) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). (j) Sets output data L (R₀4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (k) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Remark Transmission of custom code' (H: 0.56 ms, L: 0.56 ms or 1.69 ms) | | ;;;*********************************** | Custom Code *********************************** | Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms) (g) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). (h) Sets output data H (R₁4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (i) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). (j) Sets output data L (R₀4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (k) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Remark Transmission of custom code' (H: 0.56 ms, L: 0.56 ms or 1.69 ms) ****** (l) Sets output data H (R₁5) for custom code' to accumulator. (The accumulator's value is transferred to work area 2 as | | ;;;*********************************** | Custom Code *********************************** | Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms) (g) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). (h) Sets output data H (R₁4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (i) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). (j) Sets output data L (R₀4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (k) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Remark Transmission of custom code' (H: 0.56 ms, L: 0.56 ms or 1.69 ms) | | ;;;*********************************** | Custom Code *********************************** | Remark Transmission of custom code (H: 0.56 ms, L: 0.56 ms or 1.69 ms) (g) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). (h) Sets output data H (R₁4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (i) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). (j) Sets output data L (R₀4) for custom code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (k) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Remark Transmission of custom code' (H: 0.56 ms, L: 0.56 ms or 1.69 ms) ****** (l) Sets output data H (R₁5) for custom code' to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) (m) Calls the bit output subroutine (for four-bit transmission: | **Note** As part of the main routine, the output data for the leader code is set to the accumulator (A) and the same data is set to work area 2 (R1A) by the called subroutine (BITOUT0C). | ; * * * * * | ;************* | | | | | | | | |---------------|----------------|------------|--|--|--|--|--|--| | ; | | Data Code | | | | | | | | ;***** | ***** | ********* | | | | | | | | | MOV | A,R16 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CALL | BITOUT0C | | | | | | | | | | | | | | | | | | | MOV | A,R06 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CALL | BITOUT0C | | | | | | | | . * * + + + - | ***** | ******* | | | | | | | | ; | | | | | | | | | | • | ****** | Data Code' | | | | | | | | , | MOV | A,R16 | | | | | | | | | | A,#0FH | | | | | | | | | XRL | A, #OFH | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CAT.T. | BITOUT0C | | | | | | | | | CILL | 21100100 | | | | | | | | | MOV | A,R06 | | | | | | | | | XRL | A,#0FH | | | | | | | | | | , | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CALL | BITOUT0C | | | | | | | | | | | | | | | | | | ;***** | ***** | ******** | | | | | | | | ; | | Stop Bit | | | | | | | | ; * * * * * | ***** | ******** | | | | | | | | | MOV | R8,#00EH | | | | | | | | | | | | | | | | | | | MOV | A,R18 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CALL | BITOUT0F | | | | | | | | | | | | | | | | | Remark Transmission of data code (H: 0.56 ms, L: 0.56 or 1.69 ms) - (a) Sets output data H ( $R_{16}$ ) for the data code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) - (b) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). - (c) Sets output data L ( $R_{06}$ ) for the data code to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) - (d) Calls the bit output subroutine(for four-bit transmission: counter value = 0CH). Remark Transmission of data code (H: 0.56 ms, L: 0.56 or 1.69 ms) - (e) Sets output data H (R<sub>16</sub>) for the data code to accumulator. - (f) The accumulator's value is inverted to create output data for $\overline{\text{data code H}}$ . - (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) - (g) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). - (h) Sets output data L (Ros) for the data code to accumulator. - (i) The accumulator's value is inverted to create output data for $\overline{data\ code\ L}$ . - (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) - (j) Calls the bit output subroutine(for four-bit transmission: counter value = 0CH). Remark Transmits stop bit (H: 0.56 ms, L: 3.00 ms) - (k) Sets the low-order address of table data having a stop bit carrier to data 0 (Ros). - (I) Sets the output data (0H) for the stop bit to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) - (m) Calls the bit output subroutine (for one-bit transmission: counter value = 0FH). **Note** If pressed and held, continue flag = 0FH. #### **CHAPTER 6 PROGRAM DESCRIPTION** # **CHAPTER 6 PROGRAM DESCRIPTION** | ;***** | ***** | ********* | ***** | | | |-------------|-------|----------------------|-------|-----|----------------------------------------------------------------| | ; * * * * * | | | **** | | | | ; **** | | FRAME SPACE = 27MS | **** | Ren | nark Subroutine for outputting remaining 27 ms of frame space. | | ; * * * * * | | Subroutine : FS 27ms | **** | | | | ; * * * * * | | | **** | | | | ; ***** | ***** | ******** | ***** | | | | FS_27MS | : | | | | | | | MOV | A,#0DH | | (a) | Sets counter (accumulator) to count three times (= 0DH). | | FS_27MS | 0: | | | | | | | HALT | #005н | | (b) | HALT mode: canceled when time counter reaches 00H. | | | MOV | T,#TIME9M | | (c) | Sets timer counter to 9 ms (= 1FFH). | | | STTS | #0101B | | (d) | Clears status flag. | | | INC | A | | (e) | Increments counter (accumulator). | | | JNC | FS_27MS0 | | (f) | Determines whether or not three times have been counted. | | | | | | | If they have not been counted, processing branches to | | | | | | | FS_27MS0. | | | RET | | | (g) | End of processing | | | | | | | | [MEMO] #### **CHAPTER 7 CAUTIONS ON PROGRAM REVISIONS** Note the following caution points when modifying the key matrix or the number of keys. #### (1) When changing the number of keys from 48 to 40 or 32 Note Set by the program for "internal pull-down resistor". # (2) In addition to the modification described in (1) above, the S<sub>1</sub>/LED pin can be used as an LED pin: - Delete the keys that are enclosed in broken lines in the following diagram. - Leave the So pin unconnected. - Change the S<sub>1</sub>/LED pin so that b2 (the bit that sets the I/O mode for the S<sub>1</sub>/LED port) in the main program's control register 1 (P4) remains in output mode (bit value = 1). (In μPD6133 Series products, setting the S<sub>1</sub>/LED pin to output mode automatically eliminates internal pull-down resistance.) Note Set by the program for "internal pull-down resistor". # **CHAPTER 8 PROGRAM LIST** AS6133 V1.01 << D6134 ASSEMBLE LIST >> 01:00:00 08/29/96 PAGE 01-002 # SOURCE = MAIN48.ASM | E STNO LOC. OBJ. | M I | I SOURCE STATEMENT | | |------------------|-----|------------------------------------------------------------|------| | 1 | | ;************************************** | **** | | 2 | | ;*** | *** | | 3 | | ;*** Multi - Purpose Remote Control Transmitter System | *** | | 4 | | ;*** | *** | | 5 | | ;*** CPU : uPD6133 Series | *** | | 6 | | ;*** CPU Clock : 455kHz | *** | | 7 | | ;*** Trans. CODE: NEC-R Format (48Key) | *** | | 8 | | ;*** Version : 2.0 | *** | | 9 | | ;*** Programmer : NEC IC Microcomputer Systems Corporation | *** | | 10 | | ;*** | *** | | 11 | | ;*** Copyright(c) NEC Corporation 1995 | *** | | 12 | | ;*** Copyright(c) NIMS Corporation 1995 | *** | | 13 | | ;************************************** | **** | | 14 | | EJECT | | ``` SOURCE = MAIN48.ASM ``` ``` E STNO LOC. OBJ. M I SOURCE STATEMENT 15 001C TIME05M EQU 01CH ;0.5ms (0.510ms) EQU 512-1 16 01FF DamyTime ;9.00ms (= 17.582us * 512) 17 ;######## P U B L I C ######## 19 PUBLIC MAIN 20 ; ;######### E X T E R N ######## 21 22 ; 23 24 ;######## S T A R T ######## 25 26 ; Control Register (P3) Reset:03H 2.7 ;======; ; D9 D8 ! D7 ! D6 ! D5 ! D4 ! D3 ! D2 ! D1 ! D0 ! ; 29 ; ! D.P.! D.P.! D.P.! TCTL! CARY! MOD1! MOD0! ; 30 ; Test Mode! ! AD10! AD9 ! AD8 ! ! ! ! ; 31 ;-----; ; ! 0 ! * ! * ! * ! 1/1 ! ON ! fx,fx/8 ! 0 ; 32 33 ; Set "0" !----; ! 0 ! * ! * ! * ! 1/2 ! OFF !,fx/12(1/3)! 1 ; 34 35 ;=======; 36 37 ; Control Register (P4) Reset:26H 38 ;======; 39 ; D9 D8 ! D7 ! D6 ! D5 ! D4 ! D3 ! D2 ! D1 ! D0 ! ; ; ! ! KI !SO/S1! !S1/LED! KI/O! SO ! ; 40 41 ! ! Pull! Pull! ! MODE ! MODE! MODE! ; 42 43 ! 0 ! 0 ! OFF ! OFF ! 0 ! IN ! IN ! OFF ! 0; ; X !-----!---; 44 ! 0 ! 0 ! ON ! ON ! 0 ! OUT ! OUT ! IN ! 1 ; 45 46 ;======; 47 :************* 48 49 Control Register Initialize ;************** 50 51 MAIN: 52 0000 E6F8 EFEF OUT P0,#0FFH ;KI/O All High 53 0002 E6FC E3E3 OUT P4,#033H P3,#013H 54 0004 E6FB E1E3 OUT ;Set Data Pointer (P3:D8,D9) 55 0006 E6FF F7FF MOV T, #DamyTime 56 0008 E3F1 E0E5 STTS #0101B Clear Status Flag ;************** 58 59 RAM Initialize Routine ;**************** 60 61 000A E6E1 E0E0 MOV R1,#000H ;Final Key Data (R1) = 00H 62 000C E6E3 E0E0 MOV R3,#000H ;K29 ON Flag (R13) , Continuance Flag (R03) = 00H ;STOP mode (KI = High) 64 000E E2F1 E0E8 HALT #008H 65 0010 E0E0 NOP ;No operation command 66 0011 E6FF E0E7 MOV T,#TIME05M ;Set Timer : 0.5ms 67 ; 68 END ``` SOURCE = KEY48.ASM | E STNO LOC. OBJ. M I | | | |----------------------|------------------------------------------------|------------------------------------------------------| | 1 | ;************** | | | 2 | ;**** | | | 3 | ;***** uPD6133 Series Key Check ***** | | | 4 | ;***** Trans. CODE: NEC-R Format (48Key) ***** | | | 5 | ;**** | | | 6 | ;************* | | | 7 01FF | TIME9M EQU 1FFH | ;9.00ms (9.002ms) | | 8 0050 | CUSTM1 EQU 050H | Custom Code = 0AH | | 9 00AF | CUSTM2 EQU 0AFH | ;Custom Code' = F5H | | 10 | | | | 11 | ;######## P U B L I C ######### | | | 12 | PUBLIC KEY48 | | | 13 | i | | | 14 | | | | 15 | ;######### E X T E R N ######### | | | 16 | EXTRN MAIN | ;MAIN Routine | | 17 | i | | | 18 | | | | 19 | ;######### S T A R T ######### | | | 20 | KEY48: | | | 21 0013 E6E0 E0EC | MOV R0,#00CH | Chattering Counter (R00) = 3 Times | | 22 | ;*********** | | | 23 | ; ON Chattering | | | 24 | ;************ | | | 25 | ON_CHAT: | | | 26 0015 E3F1 E0E5 | STTS #0101B | Clear Status Flag | | 27 0017 E6F8 EFEF | OUT P0,#0FFH | ;KI/O All High | | 28 0019 E6FC E3E3 | OUT P4,#033H | | | 29 001B E2F1 E0E5 | HALT #005H | HALT mode (Timer = 00H) | | 30 001D E6FF F7FF | MOV T, #TIME9M | Timer = 9.00ms | | 31 001F E6E9 E0E0 | MOV R9,#000H | Comparative Key Data (R9) = 00H | | 32 0021 E6E6 E0E8 | MOV R6,#008H | ;Key Flag (R16) = 00H , Key Scan Counter (R06) = 08H | | 33 0023 E3F1 E0EE | STTS #1110B | With input Key (KI or SO or S1) ? | | 34 0025 EFF1 E0E0 | JNF MAIN | ; else MAIN: (Without input Key) | | 35 | | ; then (With input Key) | | 36 0027 E6E8 E0E1 | MOV R8,#001H | Key Scan Data (R8) Initialize : 001H | | 37 | | | | 38 | ;************* | | | 39 | ; Key Scan | | | 40 | ;************ | | | 41 | KEYS_OUT: | | | 42 0029 FFE8 | MOV A,R08 | | | 43 002A E5F8 | OUT P00,A | Key Scan Data L (P00) Output | | 44 002B FEE8 | MOV A,R18 | | | 45 002C E4F8 | OUT P10,A | Key Scan Data H (P10) Output | | 46 | ;++++++++++++++++++++++++++++++++++++++ | | | 47 | ;++ 100us Wait ++ | | | 48 | ;++++++++++++++++++++++++++++++++++++++ | office Town Make Bake at 190 | | 49 002D E6E2 EEE1 | MOV R2,#0E1H | ;Set Immediate Data : R2 | | 50 002F E6EB ECE3 | MOV RB,#0C3H | ;Set Immediate Data : RB | | 51 0031 E0E0 | NOP | | | 52 0032 E0E0 | NOP | | | 53 0033 E0E0 | NOP | | | 54 0034 E0E0 | NOP | | | 55 | ;************* | | ``` SOURCE = KEY48.ASM ``` ``` E STNO LOC. OBJ. M I SOURCE STATEMENT 56 : Key Return Check ;************** 57 58 0035 E3F1 E0EB STTS #1011B ;With input Key (KI or S0 or S1) ? 59 0037 EFF1 E9E3 ; else NO_KEYS: (Without input Key) JNF NO_KEYS ; then (With input Key) 61 0039 E3F1 E0E3 STTS #0011B ;With input KI (P11) ? 62 003B EFF1 E4E9 ; else SOS1CALC: (With input KI) JNF S0S1CALC ; then (Without input KI) 64 ;********* 65 KI Data Calculate ;********* 66 67 003D FFF9 TN ;With input KI , Does it have SO or S1 ? A.P01 ;With input SO and S1 , it judges "MULTIPLE KEYS ERROR " , 68 003E FCF3 RI. Α 69 003F ECF1 E0E0 JC MAIN ; and then goes to " MAIN: " ! 70 0041 FCF3 RL A 71 0042 ECF1 E0E0 JC MATN 72 73 0044 FEEB MOV A,R1B ;R1B = 0CH 74 0045 E5EA MOV ROA,A ; Key Return Check Counter (ROA) = 4 Times (=OCH) 75 0046 FEF9 IN A,P11 76 0047 E8F1 E4EE KEY_RETO JMP 77 ; 78 79 :******** 80 S0,S1 Data Calculate ;******** 81 82 SOS1CALC: 83 0049 E6E9 ECE0 MOV R9,#0C0H 84 004B FEE2 MOV A,R12 ;R12 = 0EH 85 004C E5EA MOV ROA.A ;Set Key Return Check Counter (ROA) = 2 Times (=OEH) 86 004D FFF9 A,P01 IN 88 KEY_RET0: 89 004E E4E0 MOV R10,A ;Work (R10) = P11 or P01 STTS #0101B 90 004F E3F1 E0E5 Clear Status Flag 91 KEY RET: 92 0051 FEE0 MOV A,R10 93 0052 FEF3 RLZ A 94 0053 E4E0 MOV R10.A 95 0054 EDF1 E8EE ;With input Key ? JNC KRC_INC 96 ;** With input Key ** ; else KRC_INC: (Without input Key) 97 0056 FEE6 MOV A,R16 ; then (With input Key) 98 0057 FAF3 SCAF ;Key Flag (R16) = OFH ? 99 0058 EDF1 E6E9 JNC KEY_CALC ; else KEY_CALC: (Except for OFH) 100 005A FEE3 A.R13 ; then (= 0FH) MOV 101 005B FAF3 SCAF ;K29 ON Flag (R13) = OFH ? 102 005C EDF1 E0E0 JNC MAIN ; else MAIN: (= Except for OFH) 103 then (= OFH) 104 005E FFF1 F4E0 MOV A,#0100B 105 0060 F4E9 XRI. A,R19 106 0061 FAF3 SCAF Comparative Key Data = K29 (R19=OBH) ? 107 0062 EDF1 E0E0 JNC ; then MAIN: (Key = Except for K29) 108 0064 FFE9 MOV A,R09 else (Key = K29) 109 0065 F5EB A,ROB ;R0B = 03H XRI. 110 0066 FAF3 SCAF Comparative Key Data = K29 (R09=0CH) ? ``` SOURCE = KEY48.ASM ``` E STNO LOC. OBJ. M I SOURCE STATEMENT 111 0067 EDF1 E0E0 ; then DBL_K_CHK: (Key = Except for K29) JNC MAIN 112 ;******** 113 114 Key Data Calculate ;******** 115 KEY_CALC: 116 117 0069 FFEB MOV ;R0B = 03H A,ROB 118 006A F4E9 XRL A,R19 119 006B FAF3 SCAF ;Comparative Key Data H (R19) = OCH ? ALC ; else KI_CALC: (KI Data) ;** S0 or S1 data Calculation **; then (S0 or S1 Data) 120 006C EDF1 E7E5 JNC KI_CALC 121 122 006E FFE6 ;Acc <-- Key Scan Counter (R06) MOV A,R06 123 006F FCF3 RL Α 124 0070 FAE2 ANL A,R12 ;R12 = 1110B 125 0071 E5E9 MOV R09,A 126 0072 FFE2 A,R02 MOV ;R02 = 01H 127 0073 E8F1 E8E1 JMP KL CALC ; 129 ;** KI data Calculation ** 130 KI_CALC: 131 0075 FFE6 ;Acc <-- Key Scan Counter(R06) MOV A.R06 132 0076 FCF3 RL Α 133 0077 FCF3 ;Left shift (2 Times) RL Α 134 0078 E5E9 MOV R09,A ;Comparative Key Data L (R09) <-- Acc 135 0079 FBE2 A,R02 ;Acc AND 0001B (R02=01H) ANL 136 007A FDF1 FAE0 A,#1010B ORT ;Acc OR 1010B 137 007C E4E9 MOV R19,A ;Comparative Key Data H (R19) <-- Acc 138 007D FFE9 MOV ;Acc <-- Comparative Key Data L (R09) A,R09 139 007E FAEB ANL A,R1B ;Acc AND 1100B (R1B=0CH) 140 007F E5E9 MOV RO9.A ;Comparative Key Data L (R09) <-- Acc 141 0080 FFEB ;Acc <-- 0011B (R0B=03H) MOV A,ROB 142 143 KL_CALC: 144 0081 FBEA ANL A,ROA ;Acc AND Key Return Check Counter (ROA) 145 0082 FDE9 ORT A,R09 ;Acc OR Comparative Key Data L (R09) 146 0083 E5E9 MOV R09.A ;Comparative Key Data L (R09) <-- Acc 147 148 ;** Double Key Check ** 149 0084 FEE6 MOV A,R16 ;Key Flag (R16) = OFH ? 150 0085 FAF3 SCAF 151 0086 EDF1 E8EB JNC SINGLE K ; else SINGLE_K (Single Key) 152 0088 FFF1 F9E0 A,#09H MOV then (Double Key) 153 008A E4E9 MOV R19,A SINGLE_K: 154 155 008B FFF1 FFE0 A.#OFH MOV 156 008D E4E6 MOV R16,A 157 158 KRC_INC: 159 008E FFEA MOV A,ROA 160 008F F4F3 TNC ; Key Return Check Counter (ROA) increment Α 161 0090 E5EA MOV ROA,A ; End of Key Return Check ? 162 0091 EDF1 E5E1 KEY_RET ; else KEY_RET: (Continuous) 163 then (End) 164 165 NO_KEYS: ``` SOURCE = KEY48.ASM | E STNO LOC. OBJ. | M I SOURCE STATEM | ENT | | | |--------------------|-----------------------------|-------------------------------|-------------------|-------------------------------------------------| | 166 0093 E3F1 E0E5 | STTS | #0101B | | ;Clear Status Flag | | 167 0095 FFE6 | MOV | A,R06 | | | | 168 0096 F4F3 | INC | A | | ;Key Scan Counter (R06) increment | | 169 0097 E5E6 | MOV | R06,A | | ;End of Key Scan number of 8 Time ? | | 170 0098 ECF1 EAE6 | NOV | | JC KEY_DATA | ; then KEY_DATA: (End) | | 171 009A FEE8 | MOV | A,R18 | OC KBI_DAIA | ; else (Continuous) | | 172 009B FCF3 | RL | A,KIO<br>A | | ;Key Scan Data H (R18) Shift | | 173 009C E4E8 | MOV | R18,A | | They Scall Data it (KIO) SHITE | | 174 009D FFE8 | MOV | A,R08 | | | | 175 009E FCF3 | RL | A,ROO<br>A | | | | 176 009F E5E8 | MOV | R08,A | | ;Key Scan Data L (R08) Shift> CY ? | | 177 00A0 EDF1 E2E9 | JNC | KEYS_OUT | | | | 177 00A0 EDF1 E2E9 | UNC | _ | MOV R8,#010H | | | 179 00A4 E8F1 E2E9 | | | • | ; then (Key Scan Data a high rank) | | 180 | | | JMP KEYS_OUT<br>; | | | | | | 1 | | | 181 | . + + + + + + + + + + + + + | ****** | | | | 182 | , | | | | | 183 | - | y Data = ON Chatter<br>****** | | | | 184 | | ****** | ***** | | | 185 | KEY_DATA: | DO 1100000 | | WW (0 all w) 1 | | 186 00A6 E6F8 EFEF | OUT | PO,#OFFH | | ;KI/O All High | | 187 00A8 E6E8 EFE0 | MOV | R8,#0F0H | | ;Set Immediate Data : R8 | | 188 00AA FEE6 | MOV | A,R16 | | | | 189 00AB FAF3 | SCAF | | | ;Key Flag (R16) = OFH ? | | 190 00AC EDF1 E0E0 | | | JNC MAIN | ; else MAIN: (= Except for OFH) | | 191 00AE FFE0 | MOV | A,R00 | | ; then (= OFH) | | 192 00AF F5EB | XRL | A,ROB | | ;ROB = #0011B | | 193 00B0 FAF3 | SCAF | | | Chattering counter (R00) = 1 Times (=0DH) ? | | 194 00B1 ECF1 EBEE | | 1 | JC KEYCHECK | ; then KEYCHECK: (= 0DH) | | 195 | | | | ; else (= OE-OFH) | | 196 00B3 FEE4 | MOV | A,R14 | | | | 197 00B4 F4E8 | XRL | A,R18 | | ;R18 = 0FH | | 198 00B5 F4E9 | XRL | A,R19 | | ;Acc = OFH | | 199 00B6 FAF3 | SCAF | | | Key Data H (R14) = Comparative Key Data H (R19) | | 200 00B7 EDF1 E0E0 | | | JNC MAIN | ; else MAIN: (Unmatch) | | 201 | | | | ; then (Match) | | 202 00B9 F5E4 | XRL | A,R04 | | ;Acc = OFH | | 203 00BA F5E9 | XRL | A,R09 | | | | 204 00BB FAF3 | SCAF | | | Key Data L (R04) = Comparative Key Data L (R09) | | 205 00BC EDF1 E0E0 | | 1 | JNC MAIN | ; else MAIN: (Unmatch) | | 206 | KEYCHECK: | | | ; then (Match) | | 207 00BE FEE9 | MOV | A,R19 | | | | 208 00BF E4E4 | MOV | R14,A | | Key Data H (R14) < Comparative Key Data H (R19) | | 209 00C0 FFE9 | MOV | A,R09 | | | | 210 00C1 E5E4 | MOV | R04,A | | Key Data L (R04) < Comparative Key Data L (R09) | | 211 00C2 FFE0 | MOV | A,R00 | | | | 212 00C3 F4F3 | INC | A | | Chattering Counter(R00) increment | | 213 00C4 E5E0 | MOV | R00,A | | | | 214 00C5 FAF3 | SCAF | | | ; End of Chattering Routine of 3 Time ? | | 215 00C6 EDF1 E1E5 | | | JNC ON_CHAT | ; else ON_CHAT: (= 0DH) | | 216 | ;** ] | Key High Check ** | | ; then (= OE-OFH) | | 217 00C8 F4E1 | XRL | A,R11 | | ;Acc = OFH | | 218 00C9 F4E4 | XRL | A,R14 | | | | 219 00CA FAF3 | SCAF | | | ;Final Key Data H (R11) = Key Data H (R14) ? | | 220 OOCB EDF1 EDE2 | JNC | KDAT_SET | | ; else KDAT_SET: (Unmacth) | | | | | | | SOURCE = KEY48.ASM | E STNO LOC. OBJ. | M I SOURCE STATEMENT | | | | |--------------------------------|------------------------|-------------------|---------------------------------------|-----------------| | 221 | N I SOURCE STATEMENT | ;** Key Low Check | ** ; then (Match) | | | 222 00CD F5E1 | | XRL A,R01 | ;Acc = 0FH | | | 223 00CE F5E4 | | XRL A,R04 | rice - ori | | | 224 00CF FAF3 | | SCAF | ;Final Key Data L(R01) = Key Data L ( | DU4) 5 | | 225 00D0 ECF1 EDE8 | | JC K29CHECK | ; then K29CHECK: (Match) | 101): | | 226 | KDAT_SET: | UC KZ9CHECK | ; else (Unmatch) | | | 227 00D2 FEE4 | _ | | , else (Unimaccii) | | | 227 00D2 FEE4<br>228 00D3 E4E1 | MOV A,R14<br>MOV R11,A | | Final Van Data II (D11) . Van Data | II (D14) | | | | | ;Final Key Data H (R11) < Key Data | H (K14) | | 229 00D4 FFE4 | MOV A,R04 | | Time! W. Date T (D01) | T (D04) | | 230 00D5 E5E1 | MOV R01,A | | Final Key Data L (R01) < Key Data | L (RU4) | | 231 00D6 FFE8 | MOV A,ROS | | (Cont. in | | | 232 00D7 E5E3 | MOV R03,A | L. | ;Continuance Flag = 00H (R08=00H) | | | 233 | YZOO GYTTGIY | | | | | 234 | K29CHECK: | 005 | | | | 235 00D8 FFF1 F4E0 | MOV A,#01 | | | | | 236 00DA F4E1 | XRL A,R11 | | | | | 237 00DB FAF3 | SCAF | | ;Final Key Data = K29 (R11=OBH) ? | | | 238 00DC EDF1 EEE3 | JNC DBL_K | | ; then DBL_K_CHK: (Key = Exce | | | 239 00DE FFE1 | | MOV A,R01 | ; else (Key = K29) | | | 240 00DF F5EB | | XRL A,ROB | ;R0B = 03H | | | 241 00E0 FAF3 | | SCAF | Final Key Data = K29 (R01=OCH) ? | | | 242 00E1 ECF1 EEEA | | JC K29_FLG | ; then K29_FLG: (Key = Except | for K29) | | 243 | | | ; else (Key = K29) | | | 244 | DBL_K_CHK: | | | | | 245 00E3 FFF1 F6E0 | MOV A,#06 | H | | | | 246 00E5 F4E1 | XRL A,R11 | - | | | | 247 00E6 FAF3 | SCAF | | Final Key Data = K29+ K30 or K31 or | K32 (R11=09H) ? | | 248 00E7 ECF1 EEEB | JC DATA_ | SET | ; then DATA_SET: (Key = Except | for Double Key) | | 249 00E9 FFE8 | | MOV A,R08 | | | | 250 | K29_FLG: | | | | | 251 00EA E4E3 | | MOV R13,A | ;K29 ON Flag = 00H (R08=00H) | | | 252 | ;********** | ******* | | | | 253 | | smit Data Set | | | | 254 | ;*********** | ******* | | | | 255 | DATA_SET: | | | | | 256 | ;** Custom Code | ** | | | | 257 00EB E6E4 E5E0 | MOV R4,#C | CUSTM1 | Custom Code(R4) < Custom Code | | | 258 | | | | | | 259 | ;** Custom Code' | ** | | | | 260 00ED E6E5 EAEF | MOV R5,#C | CUSTM2 | ;Custom Code'(R5) < Custom Code' | | | 261 | | | | | | 262 | ;** Data Code | ** | | | | 263 00EF FEE1 | MOV A,R11 | | | | | 264 00F0 E4E0 | MOV R10,A | 1 | ;Data Pointer H(R10) < Final Key Da | ta H(R11) | | 265 00F1 FFE1 | MOV A,R01 | | | | | 266 00F2 E5E0 | MOV ROO, A | 1 | ;Data Pointer L(ROO) < Final Key Da | ta L(R01) | | 267 00F3 E7E6 | MOV R6,@F | .0 | | | | 268 | | | | | | 269 | END | | | | | | | | | | TOTAL ERRORS = 0 TOTAL WARNINGS = 0 END OF LIST SOURCE = TRANS48.ASM | E STNO LOC. OBJ. | M I SOURCE STATEMENT | | |------------------------|------------------------------------------------------|-----------------------------------------------| | 1 | ;********** | | | 2 | ;**** | | | 3 | ;***** uPD6133 Series Transmit ***** | | | 4 | ;***** Trans. CODE: NEC-R Format (48Key) ***** | | | 5 | ;**** | | | 6 | ;************* | | | 7 01FF | ,<br>TIME9M EQU 1FFH | ;9.00ms (9.002ms) | | 8 | IIMESM EQU IFFN | 79.00ms (9.002ms) | | 9 | ;######## P U B L I C ######## | | | 10 | | | | 11 | ; | | | | | | | 12 | ;######## E X T E R N ######## | | | 13 | EXTRN MAIN | ;MAIN Routine | | 14 | EXTRN KEY48 | Key Check Routine | | 15 | EXTRN FS_27MS | Frame Space Subroutine | | 16 | i | | | 17 | | | | 18 | ;######### S T A R T ######## | | | 19 | TRNS: | | | 20 00F4 E6E7 EFE5 | MOV R7,#0F5H | ;R17 : Set Immediate Data (=0FH) | | 21 | | Key OFF Check Counter (R07) = 10 Times (=05H) | | 22 00F6 E6E9 EDEF | MOV R9,#0DFH | ;Datal Trans Counter (R9) = DFH | | 23 | ;********* | | | 24 | ; Leader Code | | | 25 | ;********* | | | 26 00F8 E6E0 EDE0 | MOV R0,#0D0H | ;Data Pointer H (R10) = ODH | | 27 00FA E6E8 E0E8 | MOV R8,#008H | ;Set Table Address L | | 28 OOFC FEE8 | MOV A,R18 | Output Data (Work) < 00H (R18) | | 29 00FD E6F2 E8F1 E5FF | CALL BITOUTOF | | | 30 | | | | 31 | ;********* | | | 32 | ; Custom Code | | | 33 | ;********* | | | 34 0100 E6E8 ECEA | MOV R8,#0CAH | ;Set Table Address L | | 35 0102 FEE4 | MOV A,R14 | Output Data (Work) < Custom Code H (R14) | | 36 0103 E6F2 E8F1 E6F4 | CALL BITOUTOC | | | 37 | | | | 38 0106 FFE4 | MOV A,R04 | Output Data (Work) < Custom Code L (R04) | | 39 0107 E6F2 E8F1 E6F4 | CALL BITOUTOC | · | | 40 | | | | 41 | ;******** | | | 42 | ; Custom Code' | | | 43 | ;********* | | | 44 010A FEE5 | MOV A,R15 | Output Data (Work) < Custom Code' H (R15) | | 45 010B E6F2 E8F1 E6F4 | CALL BITOUTOC | | | 46 | 51100100 | | | 47 010E FFE5 | MOV A,R05 | Output Data (Work) < Custom Code' L (R05) | | 48 010F E6F2 E8F1 E6F4 | CALL BITOUTOC | | | 49 | Cimp D110010C | | | 50 | ;********* | | | 51 | ' | | | 52 | ; Data Code<br>;************************************ | | | | ' | (Output Data (Mark) c Data Cada H (D1C) | | 53 0112 FEE6 | MOV A,R16 | Output Data (Work) < Data Code H (R16) | | 54 0113 E6F2 E8F1 E6F4 | CALL BITOUTOC | | | 55 | | | SOURCE = TRANS48.ASM | E STNO | LOC. | OBJ. | | ΜI | SOURCE | STATEMEN | Г | | | | | |--------|------|-------|-----------|----|---------|------------|----------|--------|----------|--------------|-----------------------------------------------------------------------------| | | 0116 | | | | | MOV | A,R06 | | | | Output Data (Work) < Data Code L (R06) | | | | | E8F1 E6F4 | | | CALL | BITOUT0C | | | | | | 58 | 011, | 2012 | 2011 2011 | | | 0 | 21100100 | | | | | | 59 | | | | | ;***** | ***** | ****** | ***** | ****** | ***** | | | 60 | | | | | : | | Data Co | | | | | | 61 | | | | | .**** | ****** | | | ****** | ****** | | | | 011A | PPP6 | | | , | | | | | | 'Output Data (Mark) & Data Code II (D16) | | | 011A | | PPP0 | | | MOV<br>XRL | A,R16 | | | | Output Data (Work) < Data Code H (R16) | | | | | | | | | A,#0FH | | | | | | | OTID | E6F2 | E8F1 E6F4 | | | CALL | BITOUT0C | | | | | | 65 | 0100 | | | | | | 06 | | | | | | | 0120 | | | | | MOV | A,R06 | | | | Output Data (Work) < Data Code L (R06) | | | 0121 | | | | | XRL | A,#0FH | | | | | | | 0123 | E6F2 | E8F1 E6F4 | | | CALL | BITOUT0C | | | | | | 69 | | | | | | | | | | | | | 70 | | | | | ;***** | ***** | ****** | ****** | ****** | ****** | | | 71 | | | | | ; | | Stop Bi | | | | | | 72 | | | | | ;***** | ****** | ****** | ****** | ****** | ****** | | | 73 | 0126 | E6E8 | E0EE | | | MOV | R8,#00EH | | | | ;Set Table Address L | | 74 | 0128 | FEE8 | | | | MOV | A,R18 | | | | Output Data (Work) < 00H (R18) | | 75 | 0129 | E6F2 | E8F1 E5FF | | | CALL | BITOUT0F | | | | | | 76 | | | | | | | | | | | | | 77 | | | | | ;***** | ****** | ****** | ***** | ****** | ****** | | | 78 | | | | | ; | | Frame S | pace | | | | | 79 | | | | | ;***** | ***** | ****** | ***** | ****** | ***** | | | 80 | 012C | FEE9 | | | | MOV | A,R19 | | | | | | 81 | 012D | FAF3 | | | | SCAF | | | | | Frame Space > 9.00ms ? | | 82 | 012E | ECF1 | E3FE | | | JC | T9_UNDER | | | | then T9_UNDER: (More than 9.00ms) | | 83 | | | | | | | | | | | ; else (Less than 9.00ms) | | 84 | 0130 | E2F1 | E0E5 | | | | | | HALT | #005H | ;HALT mode (Timer = 00H) | | | 0132 | | | | | | | | MOV | T,#TIME9M | | | | 0134 | | | | | | | | STTS | #0101B | ;Clear Status Flag | | 87 | 0101 | 2011 | 2023 | | | | | | 0110 | 1101012 | roteal bodoub riag | | | 0136 | PPPQ | | | | | | | MOV | A,R09 | | | | 0137 | | | | | | | | RL | A,ROJ<br>A | ·Framo Chago > 10 00mg 2 | | | 0138 | | E2EE | | | JC | TO INDED | | KLI | A | <pre>;Frame Space &gt; 18.00ms ? ; then T9 UNDER: (Less than 18.00ms)</pre> | | | 0130 | ECFI | FOLF | | | UC | T9_UNDER | | | | | | 91 | 0123 | 5051 | D0DF | | | | | | m | 11005** | ; else (More than 18.00ms) | | | 013A | | | | | | | | HALT | #005H | ;HALT mode (Timer = 00H) | | | 013C | E0FF. | F/FF | | | | | | MOV | T,#TIME9M | | | 94 | | | | | | _ | | | | | | | 95 | | | | | T9_UNDE | | | | | | | | | 013E | | E0E5 | | | STTS | #0101B | | | | Clear Status Flag | | 97 | 0140 | FEE9 | | | | MOV | A,R09 | | | | | | 98 | 0141 | FBF1 | F7E0 | | | ANL | A,#0111E | | | | | | 99 | 0143 | E5E0 | | | | MOV | R00,A | | | | | | 100 | 0144 | E2F1 | E0E5 | | | HALT | #005H | | | | ;HALT mode (Timer = 00H) | | 101 | 0146 | E7FF | | | | MOV | T,@R0 | | | | | | 102 | 0147 | E3F1 | E0E5 | | | STTS | #0101B | | | | Clear Status Flag | | 103 | | | | | | | | | | | | | 104 | 0149 | FFE3 | | | | MOV | A,R03 | | | | | | 105 | 014A | FAF3 | | | | SCAF | | | | | Continuously pressed key ? | | 106 | 014B | EDF1 | E5F8 | | | JNC | KEY_ON | | | | ; else KEY_ON: (1st. Frame) | | 107 | 014D | FFE7 | | | | | | | MOV | A,R07 | ; then (Since 2nd. Frame) | | 108 | 014E | FAF3 | | | | | | | SCAF | | ;Without input Key ? | | 109 | 014F | EDF1 | E1E3 | | | | | | JNC | KEY48 | ; then KEY48: (With input Key) | | 110 | | | | | | | | ;** Fr | ame Spac | ce = 27ms ** | ; else (Without input Key) | | | | | | | | | | | - | | - ** | ``` SOURCE = TRANS48.ASM E STNO LOC. OBJ. M I SOURCE STATEMENT 111 0151 EXTRN CALL FS_27MS 112 0154 E2F1 E0E5 HALT #005H ;HALT mode (Timer = 00H) 113 0156 E8F1 E0E0 JMP MAIN 114 115 KEY_ON: 116 0158 FEE7 MOV A,R17 117 0159 E5E3 MOV R03,A ;Continuance Flag (R03) = OFH (R17=OFH) 118 ;** Frame Space = 27ms ** 119 015A EXTRN CALL FS_27MS 120 015D E8F1 EFE4 JMP TRNS 121 ; 122 123 ;*************** 124 ;**** 125 :**** 126 Transmit ;**** Subroutine : Bit Out 127 128 ;*************** 129 130 BITOUTOF: 131 015F E4EA ;Set Output Data (1 Bit Output) MOV R1A.A 132 0160 FFF1 FFE0 ;Send Bit Counter = 1 Times (=0FH) MOV A,#OFH 133 0162 E8F1 E6F7 JMP BITOUT 134 135 BITOUTOC: 136 0164 E4EA R1A.A ;Set Output Data (4 Bit Output) MOV 137 0165 FFF1 FCE0 MOV A,#0CH ;Send Bit Counter = 4 Times (=0CH) 138 139 BITOUT: 140 0167 E5EA MOV ROA.A ;Send Bit Counter (ROA) = OCH or OEH or OFH 141 142 0168 FEEA MOV A,R1A 143 0169 FCF3 RL A 144 016A E4EA MOV R1A,A ;Bit Data = 1 ? 145 016B ECF1 E7F1 JC BIT_DAT1 ; then BIT_DAT1: (Bit Data = 1) 146 ;** Bit Data = 0 ** ; else (Bit Data = 0) 147 016D FFE8 MOV A,R08 ;Set Data Pointer L (R00) <-- Data0 (R08) 148 016E E5E0 MOV ROO,A 149 016F E8F1 E7FB JMP BIT_TRNS 150 ;** Bit Data = 1 **; 151 152 BIT_DAT1: 153 0171 FEE8 MOV A,R18 ;Set Data Pointer L(R00) <-- Data1 (R18) 154 0172 E5E0 MOV R00,A 155 0173 FFE9 A,R09 MOV 156 0174 F4F3 INC ;Data 1 Transmit Counter L (R09) increment Α 157 0175 E5E9 MOV R09,A ;Data 1 Transmit Counter L (R09) = Overflow ? 158 0176 EDF1 E7FB JNC BIT_TRNS ; else BIT_TRNS: (Data 1 Transmit Counter L <= 0FH) 159 0178 FEE9 MOV A,R19 then (Data 1 Transmit Counter L > 0FH) 160 0179 F4F3 TNC ;Data 1 Transmit Counter H(R19) increment Α 161 017A E4E9 MOV R19,A BIT_TRNS: 163 017B E2F1 E0E5 HALT #005H ;HALT mode (Timer = 00H) 164 017D E7FF MOV T,@R0 165 017E E3F1 E0E5 STTS #0101B ;Clear Status Flag ``` SOURCE = TRANS48.ASM | E STNO | LOC. OBJ. | MI | SOURCE | STATEMEN | T | | | | | |--------|----------------|----|---------|----------|----------------|-----|------------------|----------------------------|-------------------------| | 166 | 0180 FFE0 | | | MOV | A,R00 | | | | | | 167 | 0181 F4F3 | | | INC | A | | | ;Data Pointer L (R00) incr | rement | | 168 | 0182 E5E0 | | | MOV | R00,A | | | | | | 169 | 0183 E2F1 E0E5 | | | HALT | #005H | | | ;HALT mode (Timer = 00H) | | | 170 | 0185 E7FF | | | MOV | T,@R0 | | | | | | 171 | | | | | | | | | | | 172 | 0186 FFE7 | | | MOV | A,R07 | | | | | | 173 | 0187 F4F3 | | | INC | A | | | ;Key Off Check Counter (RC | 07) increment | | 174 | 0188 ECF1 E9F3 | | | | | JC | BIT_TRANS2 | ;Key Off Check Counter (RC | 07) = End of 10 Times ? | | 175 | | | | | | | | ; then BIT_TRANS2: | (End of 10 Times) | | 176 | | | | | | | | ; else | (Less than 10 Times) | | 177 | 018A E3F1 E0EE | | | STTS | #1110B | | | ;With input key ? | | | 178 | 018C EFF1 E9F2 | | | JNF | BIT_TRANS1 | | | ; else BIT_TRANS1: | (With input) | | 179 | | | | | | ;** | With input key * | *; then | (Without input) | | 180 | 018E E6E7 EFE5 | | | | | MOV | R7,#0F5H | ;Key off Check Counter (RC | 07) = 05H | | 181 | 0190 E8F1 E9F3 | | | | | JMP | BIT_TRANS2 | | | | 182 | | | | | | ; | | | | | 183 | | | ;** | Withou | t input key ** | | | | | | 184 | | | BIT_TRA | NS1: | | | | | | | 185 | 0192 E5E7 | | | MOV | R07,A | | | | | | 186 | | | | | | | | | | | 187 | | | BIT_TRA | NS2: | | | | | | | 188 | 0193 E3F1 E0E5 | | | STTS | #0101B | | | Clear Status Flag | | | 189 | 0195 FFEA | | | MOV | A,ROA | | | | | | 190 | 0196 F4F3 | | | INC | A | | | ;Send Bit Counter (ROA) ir | ncrement | | 191 | 0197 EDF1 E6F7 | | | JNC | BITOUT | | | | | | 192 | 0199 E8F2 | | | RET | | | | | | | 193 | | | | ; | | | | | | | 194 | | | END | | | | | | | | | | | | | | | | | | TOTAL ERRORS = 0 TOTAL WARNINGS = 0 END OF LIST SOURCE = DTABLE48.TBL ``` E STNO LOC. OBJ. M I SOURCE STATEMENT ;*************** 1 2 ;***** uPD6133 Series Data Table ***** 3 ;***** Trans. CODE: NEC-R Format (48Key) ***** ;**** ;************** 6 7 TIME9M EQU 1FFH 01FF ;9.00ms (9.002ms) 8 9 ;######## P U B L I C ######### DATACODE 10 PUBLIC 11 PUBLIC FS_27MS 12 13 14 ;*********** 15 ;***** Key Data 16 17 Double Key 18 ;*********** 19 019D ORG 19DH 20 ;** K29 + K30 ** DW 009H 21 019D E0E9 ;K29 + K30 : Key Data = 0DH ;** K29 + K31 ** 22 23 019E E8E9 DW 089H ;K29 + K31 : Key Data = 0EH 24 ;** K29 + K32 ** 25 019F E4E9 DW 049H ;K29 + K32 : Key Data = 0FH 26 ; 27 28 ;********* 29 Key Data Single Key 30 31 ORG 1A0H 32 01A0 ;** K 1 - K16 ** 34 01A0 E0E0 DW 000H ;K 1 : Key Data = 20H 080H 35 01A1 E8E0 DW ;K 2 : Key Data = 21H 040H 36 01A2 E4E0 DW ;K 3 : Key Data = 22H 37 01A3 ECE0 0C0H DW ;K 4 : Key Data = 23H 38 01A4 E2E0 DW 020H ;K 5 : Key Data = 24H 39 01A5 EAE0 DW 0A0H ;K 6 : Key Data = 25H 060H 40 01A6 E6E0 ;K 7 : Key Data = 26H DW 41 01A7 EEE0 DW 0E0H ;K 8 : Key Data = 27H 42 01A8 E1E0 DW 010H ;K 9 : Key Data = 28H 43 01A9 E9E0 DW 090H ;K10 : Key Data = 29H 44 01AA E5E0 DW 050H ;K11 : Key Data = 2AH 45 01AB EDE0 DW UDOH ;K12 : Key Data = 2BH 46 01AC E3E0 DW 030H ;K13 : Key Data = 2CH 47 01AD EBE0 DW 0B0H ;K14 : Key Data = 2DH 48 01AE E7E0 DW 070H ;K15 : Key Data = 2EH 49 01AF EFE0 ;K16 : Key Data = 2FH DW 0F0H 50 ; 51 ;** K17 - K32 ** 53 01B0 E0E8 DW 008H ;K17 : Key Data = 30H 54 01B1 E8E8 088H ;K18 : Key Data = 31H DW 55 01B2 E4E8 DW 048H ;K19 : Key Data = 32H ``` AS6133 V1.01 << D6134 ASSEMBLE LIST >> 01:00:01 08/29/96 PAGE 04-003 SOURCE = DTABLE48.TBL | E CENTO | T 0.0 | ODT | M T COLIDOR CHARRIEN | |---------|-------|------|------------------------------------------------| | E STNO | | | M I SOURCE STATEMENT | | | 01B3 | | DW 0C8H ;K20 : Key Data = 33H | | | 01B4 | | DW 028H ;K21 : Key Data = 34H | | | 01B5 | | DW 0A8H ;K22 : Key Data = 35H | | | 01B6 | | DW 068H ;K23 : Key Data = 36H | | | 01B7 | | DW 0E8H ;K24 : Key Data = 37H | | | 01B8 | | DW 018H ;K25 : Key Data = 38H | | | 01B9 | | DW 098H ;K26 : Key Data = 39H | | | 01BA | | DW 058H ;K27 : Key Data = 3AH | | | 01BB | | DW 0D8H ;K28 : Key Data = 3BH | | | 01BC | | DW 038H ;K29 : Key Data = 3CH | | | 01BD | | DW OB8H ;K30 : Key Data = 3DH | | | 01BE | | DW 078H ;K31 : Key Data = 3EH | | | 01BF | EFE8 | DW 0F8H ;K32 : Key Data = 3FH | | 69 | | | i | | 70 | | | ;** K33 - K48 ** | | | 01C0 | | DW 004H ;K33 : Key Data = 40H | | | 01C1 | | DW 084H ;K34 : Key Data = 41H | | | 01C2 | | DW 044H ;K35 : Key Data = 42H | | | 01C3 | | DW 0C4H ;K36 : Key Data = 43H | | | 01C4 | | DW 024H ;K37 : Key Data = 44H | | | 01C5 | | DW 0A4H ;K38 : Key Data = 45H | | | 01C6 | | DW 064H ;K39 : Key Data = 46H | | | 01C7 | | DW 0E4H ;K40: Key Data = 47H | | | 01C8 | | DW 014H ;K41 : Key Data = 48H | | | 01C9 | | DW 094H ;K42: Key Data = 49H | | | 01CA | | DW 054H ;K43: Key Data = 4AH | | | 01CB | | DW 0D4H ;K44 : Key Data = 4BH | | | 01CC | | DW 034H ;K45 : Key Data = 4CH | | | 01CD | | DW OB4H ;K46: Key Data = 4DH | | | 01CE | | DW 074H ;K47: Key Data = 4EH | | | 01CF | EFE4 | DW 0F4H ;K48: Key Data = 4FH | | 87 | | | ; | | 88 | | | | | 89 | | | ;*************************** | | 90 | | | ;**** Frame Space **** | | 91 | | | ;**** Time Data **** | | 92 | 01=0 | | ;ORG 1DOH ************************************ | | | 01D0 | | DT 1F4H ;Counter:000 = 8.815ms (8.809ms) | | | 01D1 | | DT 1B4H ;Counter:001 = 7.690ms (7.683ms) | | | 01D2 | | DT 174H ;Counter:010 = 6.565ms (6.558ms) | | | 01D3 | | DT 134H ;Counter:011 = 5.440ms (5.433ms) | | | 01D4 | | DT 0F4H ;Counter:100 = 4.315ms (4.308ms) | | | 01D5 | | DT 0B4H ;Counter:101 = 3.190ms (3.182ms) | | | 01D6 | | DT 074H ;Counter:110 = 2.065ms (2.057ms) | | | 01D7 | E0ED | DT 034H ;Counter:111 = 0.940ms (0.932ms) | | 101 | | | i | | 102 | | | | | 103 | | | ;************************************** | | 104 | | | ;***** Time Data ***** | | 105 | | | ;ORG 1D8H ************************************ | | 106 | 01-1 | | ;** Leader Code ** | | | 01D8 | | DT 3FFH ;Carrier ON : 9.000ms (9.002ms) | | | 01D9 | F3FF | DT OFFH ;Carrier OFF : 4.500ms (4.501ms) | | 109 | | | ;** Bit data 0 ** | | 110 | 01DA | F8F7 | DT 21FH ;Carrier ON : 0.560ms (0.563ms) | AS6133 V1.01 << D6134 ASSEMBLE LIST >> 01:00:01 08/29/96 PAGE 04-004 SOURCE = DTABLE48.TBL | E STNO | LOC. OBJ. | ΜI | SOURCE S | STATEMENT | Γ | | | | | | | | | | |--------|----------------|----|----------|-----------|--------------|----------|-------|---------|----------|---------|------------|--------|------------|-----| | 111 | 01DB F0F7 | | | DT | 01FH | ;Carrier | OFF : | 0.565ms | (0.563ms | ;) | | | | | | 112 | | | ;** B | it data 1 | 1 ** | | | | | | | | | | | 113 | 01DC F8F7 | | | DT | 21FH | ;Carrier | ON : | 0.560ms | (0.563ms | ) | | | | | | 114 | 01DD F1F7 | | | DT | 05FH | ;Carrier | OFF : | 1.690ms | (1.687ms | ) | | | | | | 115 | | | ;** St | top Bit ' | ** | | | | | | | | | | | 116 | 01DE F8F7 | | | DT | 21FH | ;Carrier | ON : | 0.560ms | (0.563ms | ;) | | | | | | 117 | Oldf E2FA | | | DT | 0A9H | ;Carrier | OFF : | 3.000ms | (2.989ms | ) | | | | | | 118 | | | | ; | | | | | | | | | | | | 119 | | | | | | | | | | | | | | | | 120 | | | | | | | | | | | | | | | | 121 | | | | | | | | | | | | | | | | 122 | | | ;***** | ***** | ****** | ******* | **** | **** | | | | | | | | 123 | | | ;**** | | | | *: | **** | | | | | | | | 124 | | | ;**** | | Frame Space | = 27ms | *: | **** | | | | | | | | 125 | | | ;**** | | Subroutine : | FS 27ms | *: | *** | | | | | | | | 126 | | | ;**** | | | | *: | *** | | | | | | | | 127 | | | ;***** | ***** | ****** | ******* | **** | **** | | | | | | | | 128 | | | | | | | | | | | | | | | | 129 | | | FS_27MS | : | | | | | | | | | | | | 130 | 01E0 FFF1 FDE0 | | | MOV | A,#ODH | | | | ;Counte | er(Acc) | = 3 Times | (=0DH) | | | | 131 | | | FS_27MS( | ): | | | | | | | | | | | | 132 | 01E2 E2F1 E0E5 | | | HALT | #005H | | | | ;HALT m | node (T | imer = 00H | ) | | | | 133 | 01E4 E6FF F7FF | | | MOV | T,#TIME9M | | | | ;Timer | = 9.00 | ms | | | | | 134 | 01E6 E3F1 E0E5 | | | STTS | #0101B | | | | ;Clear | Status | Flag | | | | | 135 | 01E8 F4F3 | | | INC | A | | | | ;More t | han 27t | ms ? | | | | | 136 | 01E9 EDF1 EEF2 | | | JNC | FS_27MS0 | | | | ; | else | FS_27MS0: | (Frame | Space < 27 | ms) | | 137 | 01EB E8F2 | | | RET | | | | | ; | then | RET | (Frame | Space = 27 | ms) | | 138 | | | | ; | | | | | | | | | | | | 139 | | | END | | | | | | | | | | | | | | | | | | | | | | | | | | | | TOTAL ERRORS = 0 TOTAL WARNINGS = 0 END OF LIST #### **CHAPTER 8 PROGRAM LIST** AS6133 V1.01 << D6134 ASSEMBLE LIST >> 21:25:49 06/03/96 PAGE 05-002 SOURCE = OPTION.ASM TOTAL ERRORS = 0 TOTAL WARNINGS = 0 END OF LIST [MEMO] # PART 3 80-KEY PROGRAM [MEMO] ## **CHAPTER 1 HARDWARE CONFIGURATION** ## 1.1 Application Circuit Example Figure 1-1 shows an application circuit example. K<sub>I/O6</sub> **K**I/O5 **K**I/07 **K**I/O4 S<sub>0</sub>Note **K**I/03 S<sub>1</sub>/LEDNote **K**I/O2 REM $K_{I/O1}$ $V_{\text{DD}}$ **K**I/00 K<sub>I3</sub>Note Хоит $K_{12}^{\text{Note}}$ $X_{\text{IN}}$ **GND** K<sub>I1</sub>Note $\text{Kio}^{\text{Note}}$ RESET $\mu$ PD6134 Key matrix $(8 \times 5) \times 2 = 80 \text{ keys}$ Figure 1-1. Application Circuit Example Note The program is set for "on-chip pull-down resistors". The $K_1$ , $K_{1/0}$ , $S_0$ , and $S_1/\overline{\text{LED}}$ pins are used to configure an 80-key key matrix. The transmission code is output via the REM pin with a carrier signal. Table 1-1 lists the various pin functions. Table 1-1. Pin Functions | Pin name | I/O | Function | |---------------------|--------|-----------------------------------------------| | K1/00 to K107 | Output | Key source (active high) | | Kio to Kis | Input | Key return (active high) | | S <sub>0</sub> | Input | Key expansion | | S <sub>1</sub> /LED | Input | Key return (active high) | | REM | Output | Infrared remote control signal (with carrier) | ## 1.2 Key Matrix Figure 1-2 illustrates the key matrix. The "Kn" symbol (in which n = 1 to 80) indicates each key's position. Figure 1-2. Key Matrix | | K <sub>I3</sub> | K <sub>12</sub> | K <sub>I1</sub> | Kıo | S <sub>1</sub> | Кіз | K <sub>12</sub> | K <sub>I1</sub> | Kıo | S <sub>1</sub> | |--------------------|-----------------|-----------------|-----------------|-----|----------------|-----|-----------------|-----------------|-----|----------------| | <b>K</b> I/O0 | K1 | K2 | K3 | K4 | K33 | K41 | K42 | K43 | K44 | K73 | | <b>K</b> I/O1 | K5 | K6 | K7 | K8 | K34 | K45 | K46 | K47 | K48 | K74 | | <b>K</b> I/O2 | K9 | K10 | K11 | K12 | K35 | K49 | K50 | K51 | K52 | K75 | | <b>K</b> I/O3 | K13 | K14 | K15 | K16 | K36 | K53 | K54 | K55 | K56 | K76 | | <b>K</b> I/O4 | K17 | K18 | K19 | K20 | K37 | K57 | K58 | K59 | K60 | K77 | | <b>K</b> I/O5 | K21 | K22 | K23 | K24 | K38 | K61 | K62 | K63 | K64 | K78 | | K <sub>1</sub> /06 | K25 | K26 | K27 | K28 | K39 | K65 | K66 | K67 | K68 | K79 | | <b>K</b> I/07 | K29 | K30 | K31 | K32 | K40 | K69 | K70 | K71 | K72 | K80 | #### **CHAPTER 2 TRANSMISSION WAVEFORM** The transmission waveform that is output from the REM pin uses the NEC-R (NEC continuous) format. For description of the output data code, see CHAPTER 4 OUTPUT CODES. ## 2.1 NEC-R Format Figure 2-1 illustrates the NEC-R format. Figure 2-1. NEC-R Format · Transmission waveform · Transmission waveform for first frame - · Transmission waveform for second and subsequent frames...same as transmission waveform for first frame - · Bit data format Carrier waveform [MEMO] #### **CHAPTER 3 TIMING CHARTS** #### 3.1 Timing Charts for Key Input to REM Output ON chattering elimination processing checks for key input every 9.00 ms and if it detects ON status three consecutive times, it determines that the key is ON. "ON chattering" elimination processing also checks for key status changes (between ON and OFF or when the key is pressed and held). The OFF chattering elimination processing is described below. Key OFF status is checked during low-level output of the bit data. During transmission of one frame (108 ms), key input is checked ten times with reference to the timing (34 times) of the low-level output from the REM pin. - (1) If key OFF status is detected all ten times - ... Key OFF status is determined. - (2) If key ON status is detected during at least one of the ten times - ... When key ON status is detected, the check counter is cleared and key input is checked another ten times. - (3) If (1) and (2) above do not determine key OFF status - ... Key press and hold status (key ON status) is determined. Even if key OFF status is determined during transmission of one frame, initialization processing does not begin until after the second or a subsequent frame is transmitted. ## 3.1.1 Timing when a key is pressed and held Figure 3-1 shows a timing chart for when a key is pressed and held. For details of ON chattering elimination, see 6.2.1 (1) Chattering elimination processing. Figure 3-1. Timing Chart when Key is Pressed and Held Key input : Actual key operation (manually pressing or releasing a key) Software key : Software-based key operation (key input judgment by program) REM output : Transmission waveform output via REM pin ON chattering : This refers to ON chattering elimination processing. Key input is checked three times at 9.00- ms intervals. OFF chattering : This refers to OFF chattering elimination processing. Key input is checked throughout the (34-bit) bit space that includes the leader code and stop bit. Frame space (1) : This frame space is used to maintain a one-frame time of 108.00 ms to modify the transmission time for custom codes. Frame space (2) : When it is determined that the current frame is the first frame or that a key OFF status is in effect, frame space (2) is transmitted (during 27.00 ms) without any ON chattering elimination processing. ## 3.1.2 Timing during key OFF status Figure 3-2 shows timing charts for when a key is released during a frame transmission. Figure 3-2. Timing Chart for Key OFF Status (1/3) - (1) When key is released during transmission of the first frame (key OFF status has been determined ten times consecutively during transmission of the first frame) - ... Key OFF status is confirmed during transmission of second frame - (2) When key is released during transmission of the first frame (key OFF status has not been determined ten times consecutively during transmission of the first frame) - ... Key OFF status is confirmed during transmission of second frame Key input : Actual key operation (manually pressing or releasing a key) Software key : Software-based key operation (key input judgment by program) REM output : Transmission waveform output via REM pin ON chattering : This refers to ON chattering elimination processing. Key input is checked three times at 9.00- ms intervals. OFF chattering : This refers to OFF chattering elimination processing. Key input is checked throughout the (34- bit) bit space that includes the leader code and stop bit. $Frame\ space\ (1): This\ frame\ space\ is\ used\ to\ maintain\ a\ one-frame\ time\ of\ 108.00\ ms\ to\ modify\ the\ transmission$ time for custom codes. Frame space (2): When it is determined that the current frame is the first frame or that a key OFF status is in effect, frame space (2) is transmitted (during 27.00 ms) without any ON chattering elimination processing. Figure 3-2. Timing Chart for Key OFF Status (2/3) - (3) When key is released during transmission of the second frame (key OFF status has been determined ten times consecutively during transmission of the second frame) - ... Key OFF status is confirmed during transmission of second frame - (4) When key is released during transmission of the second frame (key OFF status has not been determined ten times consecutively during transmission of the second frame) - ... Key OFF status is confirmed by the key's ON chattering Key input : Actual key operation (manually pressing or releasing a key) Software key : Software-based key operation (key input judgment by program) REM output : Transmission waveform output via REM pin ON chattering : This refers to ON chattering elimination processing. Key input is checked three times at 9.00- ms intervals. OFF chattering : This refers to OFF chattering elimination processing. Key input is checked throughout the (34- bit) bit space that includes the leader code and stop bit. $Frame\ space\ (1): This\ frame\ space\ is\ used\ to\ maintain\ a\ one-frame\ time\ of\ 108.00\ ms\ to\ modify\ the\ transmission$ time for custom codes. Frame space (2): When it is determined that the current frame is the first frame or that a key OFF status is in effect, frame space (2) is transmitted (during 27.00 ms) without any ON chattering elimination processing. Figure 3-2. Timing Chart for Key OFF Status (3/3) ## (5) When key is released during transmission of the first frame and is pressed again later ... Key OFF cannot be confirmed since a key ON status is detected during the second frame Key input : Actual key operation (manually pressing or releasing a key) Software key : Software-based key operation (key input judgment by program) REM output : Transmission waveform output via REM pin ON chattering : This refers to ON chattering elimination processing. Key input is checked three times at 9.00- ms intervals. OFF chattering : This refers to OFF chattering elimination processing. Key input is checked throughout the (34- bit) bit space that includes the leader code and stop bit. Frame space (1): This frame space is used to maintain a one-frame time of 108.00 ms to modify the transmission time for custom codes. Frame space (2): When it is determined that the current frame is the first frame or that a key OFF status is in effect, frame space (2) is transmitted (during 27.00 ms) without any ON chattering elimination processing. ## 3.2 Timing Charts of Key Operations ## 3.2.1 Output patterns prior to key confirmation Prior to key confirmation, ON chattering elimination processing (9.00 ms $\times$ 3 times = 27.00 ms) is performed and a key is confirmed when it has the same status all three times. Key input confirmation is determined after at least 100 $\mu$ s (at least six instructions when operating at 455 kHz) has elapsed after the key source output pin goes to high level. Figure 3-3 shows the detailed output patterns prior to key confirmation. Figure 3-3. Output Patterns Prior to Key Confirmation (1/6) ## (1) When K4 is pressed - a: When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.32 to 2.02 ms. - b : Key input is checked.Execution time is approximately 0.41 ms. - c: This is the total output time for key scanning. This time varies according to the value of "a". Execution time ranges from approximately 4.18 to 4.88 ms. Figure 3-3. Output Patterns prior to Key Confirmation (2/6) ## (2) When K38 is pressed - a: When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.32 to 2.02 ms. - b : Key input is checked. Execution time is approximately 0.41 ms. c: This is the total output time for key scanning. This time varies according to the value of "a". Execution time ranges from approximately 4.18 to 4.88 ms. Figure 3-3. Output Patterns prior to Key Confirmation (3/6) ## (3) When K60 is pressed a : When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.32 to 2.02 ms. b : Key input is checked. Execution time is approximately 0.41 ms. c: This is the total output time for key scanning. This time varies according to the value of "a". Execution time ranges from approximately 4.18 to 4.88 ms. Figure 3-3. Output Patterns prior to Key Confirmation (4/6) ## (4) When K29 is pressed along with valid combination key K32 (K29 + K32) - a : When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.32 to 2.02 ms. - b : Key input is checked.Execution time is approximately 0.41 ms. - c: This is the total output time for key scanning. This time varies according to the value of "a". Execution time ranges from approximately 4.18 to 4.88 ms. Figure 3-3. Output Patterns prior to Key Confirmation (5/6) ## (5) When K9 and K12 are pressed but are invalid due to an identical key source - a: When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.32 to 2.02 ms. - b : Key input is checked.Execution time is approximately 0.41 ms. Figure 3-3. Output Patterns prior to Key Confirmation (6/6) ## (6) When K10 and K16 are pressed but are invalid due to an identical key source - a: When a key ON status has been determined, the key return is checked and the key data is calculated. Execution time ranges from approximately 1.32 to 2.02 ms. - b : Key input is checked.Execution time is approximately 0.41 ms. #### 3.2.2 Operation of combination key K29 is the combination key. There are three valid key combination pairs: K29 + K30, K29 + K31, and K29 + K32. For any pattern, a key combination is valid only when K29 is pressed first. In other words, if another key is pressed before or at the same time as K29, the key combination is not valid. Figure 3-4 shows examples of key operations when a key combination is entered. Figure 3-4. Timing Chart of Key Combination Operation (1/2) (1) If another valid key (from K30 to K32) is pressed during transmission of the first frame of the K29 code, after the second frame of the K29 code is transmitted, the key combination becomes valid and the combination's code is transmitted. (2) If another valid key (from K30 to K32) is pressed during transmission of the third frame of the K29 code, after the K29 code and the third frame are transmitted, the key combination becomes valid and the combination's code is transmitted. Figure 3-4. Timing Chart of Key Combination Operation (2/2) (3) If K29 is pressed after another valid key (from K30 to K32) has been confirmed, a key check produces a key error and no code is transmitted (the key combination is not valid). (4) If another valid key (from K30 to K32) is pressed before K29 has been confirmed, a key check produces a key error and no code is transmitted (the key combination is not valid). #### 3.2.3 Key transfer operation A key transfer operation can be performed when a valid combination key has been pressed. The key transfer operation is an operation that occurs when a second key is pressed before a previously pressed key is released. The operation for the second key is performed when the previous key is released. Figure 3-5 shows the operation timing of a key transfer operation. Figure 3-5. Operation Timing of Key Transfer Operation (1) When a key transfer operation is performed to transfer to key B during transmission of the code for key A, a key check is performed after all of the code has been transmitted. A key error occurs if it is during a key combination period. When key A is released, key B becomes valid and its code is transmitted. (2) If the transfer to key B occurs before key A is confirmed, a key error occurs during the key check. A key error also occurs if it is during a key combination period. After key A is released, a key check is performed for key B. However, key B was released before it could be checked, so the check result is "no key". ## **CHAPTER 4 OUTPUT CODES** Table 4-1 lists the output codes. For output using the NEC format, NEC provides each customer with a custom code to avoid the risk of interfering with output from another remote control unit that outputs using the NEC format. This program is set to output 0AH as the custom code and F5H as the custom code'. Contact your NEC sales representative for information on obtaining a custom code. Table 4-1. Output Codes (1/2) | Key No. | Custom code | Custom code' | Data | Key No. | Custom code | Custom code' | Data | Key No. | Custom code | Custom code' | Data | |---------|-------------|--------------|------|---------|-------------|--------------|------|---------|-------------|--------------|------| | K1 | 0AH | F5H | 00H | K28 | 0AH | F5H | 1BH | K55 | 0AH | F5H | 36H | | K2 | 0AH | F5H | 01H | K29 | 0AH | F5H | 1CH | K56 | 0AH | F5H | 37H | | K3 | 0AH | F5H | 02H | K30 | 0AH | F5H | 1DH | K57 | 0AH | F5H | 38H | | K4 | 0AH | F5H | 03H | K31 | 0AH | F5H | 1EH | K58 | 0AH | F5H | 39H | | K5 | 0AH | F5H | 04H | K32 | 0AH | F5H | 1FH | K59 | 0AH | F5H | ЗАН | | K6 | 0AH | F5H | 05H | K33 | 0AH | F5H | 20H | K60 | 0AH | F5H | звн | | K7 | 0AH | F5H | 06H | K34 | 0AH | F5H | 21H | K61 | 0AH | F5H | 3СН | | K8 | 0AH | F5H | 07H | K35 | 0AH | F5H | 22H | K62 | 0AH | F5H | 3DH | | K9 | 0AH | F5H | 08H | K36 | 0AH | F5H | 23H | K63 | 0AH | F5H | 3EH | | K10 | 0AH | F5H | 09H | K37 | 0AH | F5H | 24H | K64 | 0AH | F5H | 3FH | | K11 | 0AH | F5H | 0AH | K38 | 0AH | F5H | 25H | K65 | 0AH | F5H | 40H | | K12 | 0AH | F5H | 0BH | K39 | 0AH | F5H | 26H | K66 | 0AH | F5H | 41H | | K13 | 0AH | F5H | 0CH | K40 | 0AH | F5H | 27H | K67 | 0AH | F5H | 42H | | K14 | 0AH | F5H | 0DH | K41 | 0AH | F5H | 28H | K68 | 0AH | F5H | 43H | | K15 | 0AH | F5H | 0EH | K42 | 0AH | F5H | 29H | K69 | 0AH | F5H | 44H | | K16 | 0AH | F5H | 0FH | K43 | 0AH | F5H | 2AH | K70 | 0AH | F5H | 45H | | K17 | 0AH | F5H | 10H | K44 | 0AH | F5H | 2BH | K71 | 0AH | F5H | 46H | | K18 | 0AH | F5H | 11H | K45 | 0AH | F5H | 2CH | K72 | 0AH | F5H | 47H | | K19 | 0AH | F5H | 12H | K46 | 0AH | F5H | 2DH | K73 | 0AH | F5H | 48H | | K20 | 0AH | F5H | 13H | K47 | 0AH | F5H | 2EH | K74 | 0AH | F5H | 49H | | K21 | 0AH | F5H | 14H | K48 | 0AH | F5H | 2FH | K75 | 0AH | F5H | 4AH | | K22 | 0AH | F5H | 15H | K49 | 0AH | F5H | 30H | K76 | 0AH | F5H | 48H | | K23 | 0AH | F5H | 16H | K50 | 0AH | F5H | 31H | K77 | 0AH | F5H | 4CH | | K24 | 0AH | F5H | 17H | K51 | 0AH | F5H | 32H | K78 | 0AH | F5H | 4DH | | K25 | 0AH | F5H | 18H | K52 | 0AH | F5H | 33H | K79 | 0AH | F5H | 4EH | | K26 | 0AH | F5H | 19H | K53 | 0AH | F5H | 34H | K80 | 0AH | F5H | 4FH | | K27 | 0AH | F5H | 1AH | K54 | 0AH | F5H | 35H | | | | | Table 4-1. Output Codes (2/2) | Key No. | Custom code | Custom code' | Data | |---------|-------------|--------------|------| | K29+K30 | 0AH | F5H | 90H | | K29+K31 | 0AH | F5H | 91H | | K29+K32 | 0AH | F5H | 92H | ## **CHAPTER 5 SOFTWARE CONFIGURATION** ## 5.1 General Flow Chart Figure 5-1 shows a general flow chart of this program. Figure 5-1. General Flow Chart ## 5.2 Program Memory (ROM) Configuration The $\mu$ PD6134's program memory (ROM) consists of 1002 steps x 10 bits (the 22 steps from 3EAH to 3FFH comprise the test program area). Figure 5-2 shows a ROM map for this program and Figure 5-3 shows a data table map. Figure 5-2. ROM Map Figure 5-3. Data Table Map ## 5.3 Data Memory (RAM) Configuration The data memory (RAM) consists of $32 \times 4$ -bit static RAM, which is used to store processing data. Some instructions enable RAM contents to be manipulated in 8-bit units. R0 can function as a data pointer for ROM addresses. ROM contents can be accessed once a ROM address is set to this data pointer. This is called a table reference for ROM data. After reset, the value of R0 becomes 00H. RF can also be used as an address stack register. After reset, the values of R1 to RF are undefined. Tables 5-1 to 5-3 show RAM maps for the entire program (key input processing and transmission processing), for key input processing alone, and for transmission processing alone. Table 5-4 describes RAM usage. Table 5-1. RAM Map | | H (1) | L (0) | | | | |----|-----------------------------|----------------------------|--|--|--| | R0 | Work area 1 | Chattering counter | | | | | | Data pointer H | Data pointer L | | | | | R1 | Confirmation key data H | Confirmation key data L | | | | | R2 | For immediate setting (0FH) | For immediate setting (1H) | | | | | R3 | K29 ON flag | Continue flag | | | | | R4 | Key data H | Key data L | | | | | | Custom code H | Custom code L | | | | | R5 | Custom code' H | Custom code' L | | | | | R6 | Key ON flag | Key scan counter | | | | | | Data code H | Data code L | | | | | R7 | For immediate setting (0FH) | Key OFF check counter | | | | | R8 | Key scan data H | Key scan data L | | | | | | For immediate setting (0FH) | For immediate setting (0H) | | | | | | Data 1 | Data 0 | | | | | R9 | Compare key data H | Compare key data L | | | | | | Data 1 transmit counter H | Data 1 transmit counter L | | | | | RA | Work area 2 | Key return check counter | | | | | | | Transmit bit counter | | | | | RB | For immediate setting (0CH) | For immediate setting (3H) | | | | | RC | For immediate setting (08H) | For immediate setting (3H) | | | | | RD | Not used | Not used | | | | | RE | Not used | Not used | | | | | RF | Address stack register | | | | | Table 5-2. Map of RAM used for Key Input Processing | | H (1) | L (0) | |----|-----------------------------|----------------------------| | R0 | Work area 1 | Chattering counter | | | Data pointer H | Data pointer L | | R1 | Confirmation key data H | Confirmation key data L | | R2 | For immediate setting (0FH) | For immediate setting (1H) | | R3 | K29 ON flag | Continue flag | | R4 | Key data H | Key data L | | | Custom code H | Custom code L | | R5 | Custom code' H | Custom code' L | | R6 | Key ON flag | Key scan counter | | | Data code H | Data code L | | R7 | | | | R8 | Key scan data H | Key scan data L | | | For immediate setting (0FH) | For immediate setting (0H) | | R9 | Compare key data H | Compare key data L | | RA | | Key return check counter | | RB | For immediate setting (0CH) | For immediate setting (3H) | | RC | For immediate setting (08H) | For immediate setting (2H) | | RD | Not used | Not used | | RE | Not used | Not used | | RF | Address sta | ack register | : Used for transmission processing Table 5-3. RAM Map Used for Transmission Processing | | H (1) | L (0) | |----|-----------------------------|---------------------------| | R0 | Data pointer H | Data pointer L | | | Work area 1 | | | R1 | | | | R2 | | | | R3 | | Continue flag | | R4 | Custom code H | Custom code L | | R5 | Custom code' H | Custom code' L | | R6 | Data code H | Data code L | | R7 | For immediate setting (0FH) | Key OFF check counter | | R8 | Data 1 | Data 0 | | R9 | Data 1 transmit counter H | Data 1 transmit counter L | | RA | Work area 2 | Transmit bit counter | | RC | | | | RC | Not used | Not used | | RD | Not used | Not used | | RE | Not used | Not used | | RF | Address sta | ack register | : Used for key input processing Table 5-4. Description of RAM Usage (1/3) | Name | RAM | Description | | | | | |-----------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Data pointer | R0 | This pointer is used for indicating ROM addresses. It is used when performing a table reference for ROM data. | | | | | | Chattering counter | R00 | This counter is used to count the number of times chattering occurs during key input processing. 0CH is set to this counter as the initial value to count three times. 0FH indicates completion of three times. | | | | | | Work area 1 | R10 | This is a work area that is used to temporarily store data. | | | | | | Confirmation key data | R1 | This is used to store confirmation key data after ON chattering elimination processing has been completed. | | | | | | | | If other confirmation key data has already been stored, it is compared with the key data when chattering elimination processing is completed (R4). If the two sets of data match, the previous data is retained. If they do not match, the new key data (R4) is stored. | | | | | | For immediate setting (1H) | R02 | This is used to clear the high-order three bits. | | | | | | For immediate setting (0FH) | R12 | This is used to set 0FH. | | | | | | Continue flag | R03 | During transmission processing, this flag is used to determine whether it is the first frame or a second or subsequent frame that is currently being transmitted. | | | | | | | | Value Description | | | | | | | | 0FH Second or subsequent frame is being transmitted | | | | | | | | 0H First frame is being transmitted | | | | | | | | 0FH: Set, 0H: Clear | | | | | | K29 ON flag | R13 | This flag is used to determine whether or not the K29 key (combination key) has been pressed. | | | | | | | | Value Description | | | | | | | | 0FH K29 key has been pressed | | | | | | | | 0H Key other than K29 key has been pressed | | | | | | | | 0FH: Set, 0H: Clear | | | | | | Key data | R4 | This is used to store the previous key data during ON chattering. This data is compared with the compare key data (R9). If they match, the previous data is retained. If they do not match, the new compare key data (R9) is stored. | | | | | | Custom code | R4 | This is used to store the custom code. | | | | | | Custom code' | R5 | This is used to store the custom code'. | | | | | | Data code | R6 | This is used to store the data code. | | | | | | Key scan counter | R06 | This counter is used to count the number of key scans. Since a count of eight is required, 8H (8 times) is set as the counter's initial value. | | | | | Table 5-4. Description of RAM Usage (2/3) | Description s been pressed s been released to count the number of times key OFF status occurs during bit data is required, 5H is set as the initial value. When the value becomes ontinuous times of key OFF status), key OFF status is confirmed. not determined at this time, the counter value is initialized. tarious flags. to output data for key scanning. the row addresses of time data (table data) for transmitting a or "1". ta "0" ta "1" | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | s been pressed s been released ar to count the number of times key OFF status occurs during bit data is required, 5H is set as the initial value. When the value becomes ontinuous times of key OFF status), key OFF status is confirmed. not determined at this time, the counter value is initialized. various flags. e output data for key scanning. e the row addresses of time data (table data) for transmitting a or "1". ta "0" | | | | | s been released ar to count the number of times key OFF status occurs during bit data is required, 5H is set as the initial value. When the value becomes continuous times of key OFF status), key OFF status is confirmed. not determined at this time, the counter value is initialized. rarious flags. e output data for key scanning. e the row addresses of time data (table data) for transmitting a or "1". ta "0" | | | | | to count the number of times key OFF status occurs during bit data is required, 5H is set as the initial value. When the value becomes ontinuous times of key OFF status), key OFF status is confirmed. not determined at this time, the counter value is initialized. various flags. e output data for key scanning. e the row addresses of time data (table data) for transmitting a or "1". ta "0" | | | | | to count the number of times key OFF status occurs during bit data is required, 5H is set as the initial value. When the value becomes ontinuous times of key OFF status), key OFF status is confirmed. not determined at this time, the counter value is initialized. rarious flags. e output data for key scanning. e the row addresses of time data (table data) for transmitting a or "1". ta "0" | | | | | is required, 5H is set as the initial value. When the value becomes ontinuous times of key OFF status), key OFF status is confirmed. not determined at this time, the counter value is initialized. various flags. e output data for key scanning. e the row addresses of time data (table data) for transmitting a or "1". ta "0" | | | | | ontinuous times of key OFF status), key OFF status is confirmed. not determined at this time, the counter value is initialized. various flags. e output data for key scanning. e the row addresses of time data (table data) for transmitting a or "1". ta "0" | | | | | e output data for key scanning. e the row addresses of time data (table data) for transmitting a or "1". ta "0" | | | | | e the row addresses of time data (table data) for transmitting a or "1". ta "0" | | | | | or "1".<br>ta "0" | | | | | ta "0" | | | | | | | | | | ta "1" | | | | | | | | | | This is used for flag setting. | | | | | This is used for data inversion. | | | | | | | | | | key data during ON chattering. | | | | | to count the number of times bit data "1" is transmitted. | | | | | to calculate the key data based on the key return data. | | | | | r is required for $K_I$ input and a count of one is required for input of 0CH (for four times) or 0EH (for one time) is set. | | | | | I to set the required number of bits stored in work 2 (R1A) for bit counter counts from one to four times. | | | | | Description | | | | | ansmission (for transmitting leader code and stop bit) | | | | | | | | | | ansmission (not used) | | | | | ansmission (not used) ansmission (not used) | | | | | ra | | | | Table 5-4. Description of RAM Usage (3/3) | Name | RAM | Description | |-----------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------| | Work area 2 | R1A | This is used to store output data for bit transmissions. | | For immediate setting (3H) | R0B | This is used for data judgments and for setting 3H. | | For immediate setting (0CH) | R1B | This is used for data judgments, for setting 0CH, for setting the high-order two bits, and for clearing the low-order two bits. | | For immediate setting (2H) | R0C | This is used for bit 1 judgments. | | For immediate setting (08H) | R1C | This is used for clearing the low-order three bits. | ## 5.4 Flag Maps Table 5-5 describes flag operations during various types of processing. Table 5-5. Flag Map ## (1) Continue flag (R03) | Processing | | R03 | |---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------| | Initialization processing | | Clear (0H) | | Key input processing | When the key data used for ON chattering elimination processing differs from the confirmation key data from the previous ON chattering elimination processing. | Clear (0H) | | Transmission | During frame space transmission of all frames | Judgment | | processing | During frame space transmission of only one frame | Set (0FH) | Judgment: A judgment is made during this processing. ## (2) K29 ON flag (R13) | Processing | | R13 | |---------------------------|-------------------------------------------------------------------------------------------------------------------------------|------------| | Initialization processing | | Clear (0H) | | Key input | When key ON flag has been set | Judgment | | processing | When chattering has been completed three times and the confirmation key data is K29 | Set (0FH) | | | When chattering has been completed three times and the confirmation key data is not K29, nor is there a valid key combination | Clear (0H) | | Transmission processing | | _ | Judgment: A judgment is made during this processing. —: Not used ## (3) Key ON flag (R16) | Processing | | R16 | |---------------------------|----------------------------------------------------|------------| | Initialization processing | | _ | | Key input | During RAM initialization | Clear (0H) | | processing | Start of key return check | Judgment | | | After key data calculation | Judgment | | | During key return check or when there is key input | Set (0FH) | | | After completion of key scanning (8 times) | Judgment | | Transmission processing | | × | Judgment: A judgment is made during this processing. —: Not used ×: Used by other application # **CHAPTER 6 PROGRAM DESCRIPTION** # 6.1 Initial Settings Microcontrollers used in infrared remote control transmitters generally use batteries as their power source. However, the lighting of infrared LEDs requires a large current consumption. The abrupt change in the power supply voltage when infrared LEDs are being lit can cause sudden changes in the contents of RAM, ports, etc., which must be taken into consideration. To prevent operation faults that may occur as a result of sudden changes in the contents of RAM, ports, etc., the program should be designed to reset data in RAM, ports, etc., to the initial value after each transmission. # 6.1.1 Description of processing # (1) Port settings and control register initialization # (a) Ki/o port (P0) This is an 8-bit I/O port that is used for key scan output. This port's initial setting is FFH. All of the port's bits (KI/O1 to KI/O7) are set to high-level output. # (b) Control register 0 (P3) Tables 6-1 and 6-2 list the contents of control register 0. The initial setting is 13H. The initial settings are shown in shaded areas in Tables 6-1 and 6-2. Table 6-1. Control Register 0 (P3) | Bit | | b <sub>7</sub> | b <sub>6</sub> | b₅ | b <sub>4</sub> | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | |-------------|---|----------------|----------------|-------------------|----------------|------|----------------|------------------|----------------| | Name | | _ | - | DP (data pointer) | | TCTL | CARY | MOD <sub>1</sub> | MOD₀ | | | | | | DP <sub>9</sub> | DP8 | | | | | | Setting | 0 | Fixed to "0" | Fixed to "0" | 0 | 0 | 1/1 | ON | See Table | 6-2. | | | 1 | | | 1 | 1 | 1/2 | OFF | | | | After reset | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | bo and b1...... Specify the REM output's carrier frequency and duty factor. b2...... Indicates presence/absence of carrier for frequency specified by b0 and b1. "0" = ON (with carrier), "1" = OFF (no carrier, high level) b<sub>3</sub>...... Changes the carrier frequency and the timer clock division ratio. "0" = 1/1 (carrier frequency: values set to $b_0$ and $b_1$ , timer clock: fx/8) "1" = 1/2 (carrier frequency: one half of values set to b<sub>0</sub> and b<sub>1</sub>, timer clock: fx/16) Table 6-2. Time Clock and Carrier Frequency Settings | b3 | b2 | b1 | b0 | Timer clock | Carrier frequency (duty factor) | |----|----|----|----|-------------|---------------------------------| | 0 | 0 | 0 | 0 | fx/8 | fx (Duty 1/2) | | | | 0 | 1 | | fx/8 (Duty 1/2) | | | | 1 | 0 | | fx/12 (Duty 1/2) | | | | 1 | 1 | | fx/12 (Duty 1/3) | | | 1 | × | × | | No carrier (high level) | | 1 | 0 | 0 | 0 | fx/16 | fx/2 (Duty 1/2) | | | | 0 | 1 | | fx/16 (Duty 1/2) | | | | 1 | 0 | | fx/24 (Duty 1/2) | | | | 1 | 1 | | fx/24 (Duty 1/3) | | | 1 | × | × | | No carrier (high level) | b4 and b5...... Specify the high-order two bits (DP8 and DP9) of the ROM data pointer. Remarks 1. × : Don't care 2. : Initial setting (13H)3. fx : System clock frequency # (c) Control register 1 (P4) Table 6-3 lists the contents of control register 1. The initial setting is 32H, which is shown in the shaded areas of the table. Table 6-3. Control Register 1 (P4) | Bit | | b <sub>7</sub> | b <sub>6</sub> | b₅ | b <sub>4</sub> | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | |------------|---|----------------|----------------|-----------|--------------------------------|--------------|---------------------|-------------------|----------------| | Name | | - | _ | Kı | S <sub>0</sub> /S <sub>1</sub> | _ | S <sub>1</sub> /LED | K <sub>I</sub> /O | S <sub>0</sub> | | | | | | pull-down | pull-down | | mode | mode | mode | | Setting | 0 | Fixed to "0" | Fixed to "0" | OFF | OFF | Fixed to "0" | S <sub>1</sub> | IN | OFF | | | 1 | | | ON | ON | | LED | OUT | IN | | When reset | | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | bo....... Specifies the So port's input mode. "0" = OFF mode (high impedance), "1" = IN (input mode). b1 ....... Specifies the Ki/o port's I/O mode. "0" = IN (input mode), "1" = OUT (output mode). b<sub>2</sub>...... Specifies the S<sub>1</sub>/ $\overline{\text{LED}}$ port's I/O mode. "0" = S<sub>1</sub> (input mode), "1" = $\overline{\text{LED}}$ (output mode) $b_4$ ...... Specifies presence/absence of pull-down resistor when $S_0/S_1$ port is in input mode. "0" = OFF (no pull-down), "1" = ON (pull-down). b5...... Specifies presence/absence of pull-down resistor when K<sub>I</sub> port is in input mode. "0" = OFF (no pull-down), "1" = ON (pull-down). Remarks 1. All pull-down resistors are automatically switched off during output mode and OFF mode. 2. : Initial setting (32H) # (2) Initialize RAM The following RAM contents are cleared to "0". - Confirmation key data (R1) - Continue flag (R03) - K29 ON flag (R13) #### (3) Set STOP mode Table 6-4 lists the cancellation conditions for the HALT instruction. The initial setting is 8H. When initialized, the (STOP mode) cancellation conditions are set as shown in the shaded areas of the table. Table 6-4. Cancellation Conditions for HALT Instruction | HALT | IALT instruction operand value | | Mode setting | Precondition for settings | Cancellation condition | | | |------|--------------------------------|--------------|--------------------------------------|---------------------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------|--| | b3 | b2 | b1 | b0 | | | | | | 0 | 0 | 0 | 0 | STOP | High-level output from all K <sub>VO</sub> pins | High-level input via at least one K <sub>1</sub> pin | | | | 0 | 1 | 1 | STOP | High-level output from all K <sub>VO</sub> pins | High-level input via at least one K <sub>i</sub> pin | | | | 1 | 1 | 0 | STOPNote 1 | High-level output from K <sub>1/00</sub> pin | High-level input via at least one K <sub>1</sub> pin | | | 1 | Any com | nbination of | of b <sub>2</sub> , b <sub>1</sub> , | STOP | [The following conditions in addition to the above condi | | | | | and b <sub>0</sub> a | bove | | | | High-level input via at least one pin between S <sub>0</sub> and S <sub>1</sub> Note <sup>2</sup> | | | 0/1 | 1 | 0 | 1 | HALT | - | When timer's down counter reaches 0 | | - Notes 1. When HALT#×110B is set, use the Ki/oo pin and the Ki pin to configure a key matrix so that an internal reset is executed whenever a runaway (control loss) condition occurs. - 2. So and/or S1 (at least one of these pins that are used to cancel standby mode) must be set to input mode (an internal reset will not be executed if both are set to output mode). - Cautions 1. An internal reset is executed if the HALT instruction is executed using operand values other than those specified above or when the precondition for HALT instruction execution has not been met. - 2. If STOP mode is set when the timer's down counter has not yet reached "0" (i.e., when the timer is operating), all 10 bits of the timer's down counter and the timer output enable flags are cleared to zero and STOP mode is set. - 3. Specify a NOP instruction as the first instruction following cancellation of STOP mode. | Remark | - | Initial setting | (8H) | |--------|---|-----------------|------| | | | | | (4) After cancellation of STOP mode, execute a NOP instruction, then initialize the timer. The timer's initial setting is 1CH (= 0.5 ms). # 6.1.2 Detailed flow chart ``` ****** INITIALIZATION PROCESSING TIME05M EQU 01CH ; 0.5ms(0.510ms) ; 9.00ms DamyTime EQU 512-1 ;######## P U B L I C ######## PUBLIC MAIN ;######## S T A R T ######## Control Register Initialize ; ************** MAIN: (a) Sets all key scan outputs (KI/O) to high level OUT P0,#0FFH P4,#032H (b) Initializes ports OUT So: High impedance, S1: Input mode, Ki/o: Output mode (c) Initializes control registers 0 and 1 (P<sub>3</sub> and P<sub>4</sub>) OUT P3,#013H With carrier, frequency: fx/12, duty factor: 1/3 TCTL: 1/1, Ki: with pull-down resistor So and S1: with pull-down resistor Data pointer: DP8 and DP9 = 01H (Most significant position of table reference address) MOV T,#DamyTime (d) Clears status flags #0101B STTS RAM Initialize Routine (e) Initializes RAM MOV R1,#000H Confirmation key data (R1): 00H K29 ON flag (R<sub>13</sub>) and continue flag (R<sub>03</sub>): 0H R3,#000H MOV (f) STOP mode: Canceled by high-level input via HALT #008H Kı, So, and S1 (g) NOP instruction NOP (h) Initializes timer value MOV T, #TIME05M ICH = 0.5 \text{ ms} ``` END # 6.2 Key Input Processing # 6.2.1 Description of processing Key input processing includes chattering elimination processing, key scan processing, custom code generation processing, and key data generation processing. # (1) Chattering elimination processing When switching to key ON or key OFF status, an unstable condition called chattering (ON chattering or OFF chattering) exists until the key signal is stabilized as the high-level or low-level signal (see Figure 6-1). Since key input during chattering is also unstable, the program must provide a means of eliminating chattering. Figure 6-1. Chattering of Key Input Signal Figure 6-2 illustrates an example of chattering elimination processing (key ON judgment example). At point <1>, key ON status is detected when STOP mode is canceled, and key input is checked during a set time period (from points <1> to <4>: $9.00 \text{ ms} \times 3$ ). In part (a) of the figure, key ON status is detected at all check points, so the key signal is judged to be at high level at the software key's point <4>. The wait period (a + b + c) after key ON status is detected at point <1> and before the software judges the signal's high level status is called the chattering elimination period. In part (a), the chattering elimination period is "a + b + c" since the key input status is always ON when checked. In part (b), the chattering elimination period is "d + e + f + g + h". Figure 6-2. Key ON Judgment when Chattering Occurs (a) (b) #### (2) Key scan processing Key scan processing is described in sections (a) and (b) below. #### (a) Key matrix Figure 6-3 shows an example of an 80-key key matrix. In this example, K<sub>1/00</sub> to K<sub>1/07</sub> are output ports that output key scan signals. These signals are captured (as key return signals) via input ports comprised of K<sub>10</sub> to K<sub>13</sub>, S<sub>0</sub>, and S<sub>1</sub>. Since each of these key return signal input ports (K<sub>10</sub> to K<sub>13</sub>, S<sub>0</sub> and S<sub>1</sub>) is connected to an internal pull-down resistor, low-level signals are input when no keys are being pressed. Figure 6-3. 80-key Key Matrix **Note** The program is set for "on-chip pull-down resistor". # (b) Key scan To judge which of the keys in the 80-key key matrix is being pressed, the STTS instruction is used to check for high-level signal input via $K_{10}$ to $K_{13}$ , $S_0$ , and $S_1$ . Next, the key scan signal's output ports (K<sub>1/00</sub> to K<sub>1/07</sub>) are set to high level one at a time starting from K<sub>1/00</sub> to determine which output among K<sub>1/00</sub> to K<sub>1/07</sub> corresponds to the detected input. During the key scan processing part of the program, the key scan counter (key source position) and key return check counter (key return position) are used to detect the key data (key position). Figure 6-5 shows the correspondence between key data and the values of these two counters. For description of the key data's bit configuration in data memory, see (4) (a) Bit configuration of key data. When performing a key scan, factors such as stray capacitance in the keyboard and key source delay due to line impedance must be taken into consideration. Therefore, this program waits for about 100 $\mu$ s (six steps when at 455 kHz) following high-level output before capturing the key input. **K**I/07 K29 K30 K31 K32 K40 K69 K70 K71 K72 K80 K25 K<sub>I</sub>/O6 K26 K27 K28 K39 K65 K66 K67 K68 K79 K38 K62 **K**I/O5 K21 K22 K23 K24 K61 K63 K64 K78 K20 K57 $K_{I/O4}$ K17 K18 K19 K37 K58 K59 K60 K77 **K**I/O3 K13 K14 K15 K16 K36 K53 K54 K55 K56 K76 $K_{1/O2}$ K9 K10 K11 K12 K35 K49 K50 K51 K52 K75 K7 K47 **K**I/O1 K5 K6 K8 K34 K45 K46 K48 K74 $K_{I/O0}$ K1 K2 K3 K4 K33 K41 K42 K43 K44 K73 Кіз $K_{12}$ K<sub>I1</sub> Κıο $S_1$ Кіз $K_{12}$ $K_{l1}$ $S_1$ Kıo $S_0 = 0$ $S_0 = 1$ (expansion) Figure 6-4. Key Matrix Figure 6-5. Key Data (Key Position) | Key scan counter | (R06) | | | | | | | | | | |------------------------------------|-------|-----|-----|-----|-----|-----|-----|-----|-----|-----| | ↓<br>F | K29 | K30 | K31 | K32 | K40 | K69 | K70 | K71 | K72 | K80 | | E | K25 | K26 | K27 | K28 | K39 | K65 | K66 | K67 | K68 | K79 | | D | K21 | K22 | K23 | K24 | K38 | K61 | K62 | K63 | K64 | K78 | | С | K17 | K18 | K19 | K20 | K37 | K57 | K58 | K59 | K60 | K77 | | В | K13 | K14 | K15 | K16 | K36 | K53 | K54 | K55 | K56 | K76 | | Α | K9 | K10 | K11 | K12 | K35 | K49 | K50 | K51 | K52 | K75 | | 9 | K5 | K6 | K7 | K8 | K34 | K45 | K46 | K47 | K48 | K74 | | 8 | K1 | K2 | K3 | K4 | K33 | K41 | K42 | K43 | K44 | K73 | | Key return –<br>check counter (R0/ | | D | Е | F | F | С | D | Е | F | F | #### (3) Custom code generation processing This program is set to output 0AH as the custom code and F5H as the custom code'. Specifically, 50H is set to data memory R4 as the custom code and AFH is set to R5 as the custom code'. Caution In the NEC format, the LSB is transmitted first, so values are set in opposite order to the bit string. #### (4) Key data generation processing Key data processing is described in (a) and (b) below. ### (a) Bit configuration of key data Key data consists of eight bits. Each bit indicates a key source or key return status. To accommodate the eight types from $K_{I/O7}$ , the key scan counter uses the LSB of key data H and the high-order two bits of key data L when input is via $K_{I0}$ to $K_{I3}$ , and uses the low-order three bits of key data L when input is via $S_1$ . The key return check counter accommodates the four types from $K_{10}$ to $K_{13}$ by using the low-order two bits of the key data. For input via $S_1$ , there is only one type, so the key return check counter is not used. The data from key expansion pin S<sub>0</sub> uses bit 1 of the key data H if input is via K<sub>10</sub> to K<sub>13</sub> and uses the MSB of key data L if input is via S<sub>1</sub>. When the first key input is detected, 0BH is set to key data H if the input is from other than K<sub>I</sub> (such as input via S<sub>1</sub>). This key data H is also used to determine the format used to generate the key data, as shown in Figures 6-6 and 6-7. As is described in "(b) Data code" below, this key data is also used as an address for table reference. Therefore, the key data is configured as shown in Figures 6-6 and 6-7. Key return Key scan counter check counter KS2 KS1 KS<sub>0</sub> KR1 KR0 bit3 bit2 bit1 bit0 bit3 bit2 bit1 bit0 Key data L Key data H Figure 6-6. Bit Configuration of Key Data when Input is via Ki0 to Ki3 Figure 6-7. Bit Configuration of Key Data when Input is via S1 # (b) Data code The data code can be calculated by using the key data obtained via key input processing (as shown in Figures 6-6 and 6-7) as an address for table reference. The table reference method uses the contents of ROM as a transmit code by setting 1H to the high-order four bits of control register 0 (P3) and by setting the key data to the data pointer (see Figure 6-8). Figure 6-8. Configuration of Data Pointer **Example** When key position is K26 (key input K<sub>12</sub>) - Key scan counter (R06) becomes EH key return check counter (R0A) becomes 0H (see Figure 6-5). - 2. The low-order three bits of the key scan counter and the low-order two bits of the key return check counter are used to configure the key data, as was shown in Figure 6-6. - 3. Set key data to data pointer. - Configuration of data pointer 0001 1101 $1001 \rightarrow 109$ H The following table reference addresses are generated when a key is generated using one of the bit configurations shown in Figures 6-6 and 6-7. As mentioned above, 1H is set to the high-order four bits of control register 0 (P3). - Key input: K<sub>10</sub> to K<sub>13</sub>, key position: K1 to K32 (when S<sub>0</sub> = 0) ... reference addresses = 1C0H to 1DFH - Key input: K<sub>10</sub> to K<sub>13</sub>, key position: K41 to K72 (when S<sub>0</sub> = 1) ... reference addresses = 1E0H to 1FFH - Key input: $S_1$ , key position: K33 to K40 (when $S_0 = 0$ ) ... reference addresses = 1B0H to 1B7H - Key input: $S_1$ , key position: K73 to K80 (when $S_0 = 1$ ) ... reference addresses = 1B8H to 1BFH - Key combination (K29 + K30, K29 + K31, K29 + K32) When a key combination has been confirmed, 9H is set to key data H. ``` K29 + K30 ... reference address = 19DH K29 + K31 ... reference address = 19EH K29 + K32 ... reference address = 19FH ``` #### 6.2.2 Detailed flow chart ``` ****** KEY INPUT PROCESSING ****** TIME9M EOU 1FFH ; 9.00ms(9.002ms) ; Custom Code = 0AH CUSTM1 EQU 050H ; Custom Code' = F5H CUSTM2 EOU 0AFH ;######## P U B L I C ######## PUBLIC KEY80 ; ;######### E X T E R N ######### EXTRN ; MAIN Routine MAIN ; ;######## S T A R T ######## KEY80: (a) Sets (0CH to) chattering counter (Roo) R0,#00CH MOV (Three times count ends at 0FH.) (b) Use RC to set immediate data (R<sub>1</sub>c = 8H, R<sub>0</sub>c VOM RC, #082H = 2H) ON Chattering ON_CHAT: STTS #0101B (c) Clears status flag (d) Sets all Ki/o outputs to high level OUT PO,#OFFH P4,#033H (e) Sets input mode for S<sub>1</sub> and S<sub>0</sub> OUT (f) HALT mode: timer is canceled when count HALT #005H reaches 00H (g) Sets timer counter. (9 ms = 1FFH) VOM T, #TIME9M (h) Initializes (sets to "00H") compare key data (R9) MOV R9,#000H MOV R6,#008H (i) (j) Sets 8H to key scan counter (Ro6) and sets 0H to clear key ON flag (R<sub>16</sub>) STTS #1110B (k) Determines when there is key input (via K<sub>1</sub>, S<sub>0</sub>, or S<sub>1</sub>) JNF MAIN If no key input, processing branches to MAIN. (I) Initializes (sets 01H to) key scan data (R<sub>8</sub>) MOV R8,#001H Key Scan KEYS_OUT: MOV A,R08 OUT P00,A (m) Outputs key scan data (Po) MOV A,R18 OUT P10,A ;++ 100-\mu s wait before key input ++ Remark R2 is used to set immediate data R2,#0F1H ' VOM (R<sub>12</sub>: 0FH, R<sub>02</sub>: 1H). Remark R8 is used to set immediate data RB, #0C3H MOV (R<sub>1B</sub>: 0CH, R<sub>0B</sub>: 3H). (n) 100-μs wait before performing key input check NOP NOP NOP NOP ``` | ; * * * * * | ***** | ******** | | | |-------------|---------|------------------|-----|-------------------------------------------------------------------------| | ; | | Key Return Check | | | | ; * * * * * | ***** | ******** | | | | | STTS | #1011B | (o) | Determines whether or not there is key input. | | | JNF | NO_KEYS | | If no key input, processing branches to | | | | | | NO_KEYS. | | | STTS | #0011B | (p) | Determines whether input is via $K_1$ or $S_0$ and $S_1$ . | | | JNF | S0S1CALC | | If via $S_0$ and $S_1$ , processing branches to | | | | | | S0S1CALC. | | ; * * * * * | ***** | ****** | | | | ; | KI Data | Calculate | | | | ; ***** | ***** | ****** | | | | | IN | A,P01 | | | | | RL | Α | (q) | When there is input via Kı, it determines whether | | | | | | there is also input via S <sub>1</sub> . | | | JC | MAIN J | | If there is also input via S <sub>1</sub> , a multiple | | | | | | combination key error is detected | | | | | | and it goes to MAIN processing. | | | MOV | A,R1B | (r) | Initializes the key return check counter (ROA). | | | MOV | ROA,A | | $0CH = 4$ times (In this case, $R_{1B} = 0CH$ ). | | | IN | A,P11 | (s) | The pin status (P11) of KI is transferred to the | | | JMP | KEY_RET0 | | accumulator. | | ; ***** | ***** | ***** | | | | ; | S0,S1 D | ata Calculate | | | | ; * * * * * | ***** | ***** | | | | S0S1CAL | ıC: | | | | | | VOM | R9,#0B0H | (t) | A judgment value (0BH) for K33 to K40 and K73 | | | | | | to K80 (for input via S <sub>0</sub> and S <sub>1</sub> ) is set to the | | | | | | compare key data H (R <sub>19</sub> ). | | | VOM | A,R12 | | | | | VOM | ROA,A | (u) | Initializes the key return check counter (ROA). | | | | | | $0FH = 1$ time (in this case, $R_{12} = 0FH$ ). | | | IN | A,P01 | (v) | The pin status (Po1) of So or S1 is transferred to | | | | | | the accumulator. | | KEY_RET | 0: | | | | | | VOM | R10,A | Re | mark The accumulator's value (Poo or Po1) is | | | | | | stored in the work area. | | | STTS | #0101B | (w) | Clears status flag. | | | | | | | #### Accumulator values S0 0 (a) Clears bits 3, 2, and 0 of accumulator 0 A,ROC ANL (In this case, Roc = 2H) KS2 Performs OR processing of S<sub>0</sub> ORL A,R19 accumulator values and compare key data H (R<sub>19</sub>). (c) Stores accumulator values in MOV R19,A $Acc \rightarrow R_{19}$ compare key data H (R<sub>19</sub>). MOV A,R09 (d) Transfers compare key data L (Ro9) KS1 KS0 KS3 KS2 to accumulator. KS1 (e) Clears the low-order two bits of the KS0 0 ANL A,R1B 0 accumulator. (In this case, R<sub>1B</sub> =1100B) MOV R09,A Stores accumulator values in Acc → Ro9 compare key data L (Ro9). (g) Transfers key return check counter KR3 KR2 KR1 KR0 MOV A,ROA (R<sub>0A</sub>) to accumulator. (h) Clears the accumulator's high-order 0 0 KS1 KS0 ANL A,R08 two bits. (In this case, Rob =0011B). KL\_CALC: Kı input Performs OR processing of KS1 KS0 KR1 KR0 CRL A,R09 S<sub>1</sub> input accumulator values and compare key data L (Ro9). S0 KS2 KS1 KS0 Stores accumulator values to MOV R09,A $Acc \rightarrow Rog$ compare key data L (Ro9). ; \*\* Key combination check \*\* MOV A,R16 SCAF Determines whether or not the key ON flag (R<sub>16</sub>) has been set. If it has been cleared, processing branches to SINGLE\_K. JNC SINGLE\_K A,#09H MOV Sets 9H to compare key data H (R<sub>19</sub>). MOV R19,A SINGLE\_K: MOV A,R12 ---- (m) Sets the key ON flag ( $R_{16}$ ) (In this case, $R_{12} = 0FH$ ). MOV R16,A KRC\_INC: A,ROA MOV INC Α .\_\_\_ (n) Increments the key return check counter (RoA). MOV ROA,A (o) Determines whether or not the key return check has been completed JNC KEY\_RET four times (for K<sub>1</sub> input) or one time (for S<sub>1</sub> input). If it has not been completed the required number of times, processing branches to KEY\_RET. NO\_KEY: Clears status flags. STTS #0101B MOV A,R06 Increments key scan counter (Ro6). ---- (q) INC R06,A MOV JC KEY\_DATA Determines whether or not the key scan has been completed eight MOV A,R18 If it has been completed, processing branches to KEY\_DATA. RT. Α MOV R18,A MOV A,R08 RL Shifts the key scan data (R8) one bit leftward. R08,A MOV JNC KEYS\_OUT MOV R8,#010H KEYS\_OUT JMP MOV R13,A **Remark** In this case, Roc = 2H. (k) Determines whether or not K29 has been pressed. (In this case, Rob = 3H). If a key other than K29 has been pressed, processing branches to K29\_FLG. - (I) Determines whether or not the confirmation key data is combination key data. - If it is combination key data, processing branches to DATA\_SET. - (m) Sets 0H to the accumulator. (In this case, $R_{08} = 0H$ ). - (n) Clears the K29 ON flag (in this case, the accumulator value = 0H). - (o) Sets the K29 ON flag (in this case, the accumulator value = 0FH). # 6.3 Transmission Processing Transmission processing transmits custom code, custom code', data code, and data code stored in the data memory, using the NEC-R format that was described in **CHAPTER 2 TRANSMISSION WAVEFORM**. The transmission method uses a data table to store transmission times and sets the timer counter via a table reference operation. Afterward, it enters HALT mode (cancellation condition: TIMER) to enable transmission. A method such as that shown in Figure 6-10 is used to ensure correct and simple time management. Immediately after cancellation of HALT mode, a similar method is used to set the transmission time data for the next transmission to the timer counter so that the transmission operation can be performed during a set time between HALT modes. When carrier output is set to ON (hereafter, this status is called "H"), the timer counter's MSB (output control bit) is set. When carrier output is set to OFF (hereafter, this status is called "L"), the timer counter's MSB (output control bit) is cleared. Figure 6-9 shows the timer counter's configuration. Figure 6-9. Configuration of Timer Counter Figure 6-10. Time Management of Timer Counter The timer's operation time can be calculated as [(Setting + 1) X 8/fx]. When operating at 455 kHz, "MOV T,#1FFH" indicates that $[(1FFH + 1) \times 8/(455 \times 10^3) = 9.00 \text{ ms}]$ has been set. #### 6.3.1 Description of processing Transmission processing includes the following seven types of processing. - Initialization - · Leader code transmission - Code transmission (custom code, custom code', data code, and data code) - Stop bit transmission - Frame space transmission - Transmission of second and subsequent frames - · OFF chattering elimination processing Each of these types of processing is described below. # (1) Initialization The initialization procedure for transmission processing is described in (a) and (b) below. - (a) The key OFF check counter (R07) is set to 10 times (= 05H). - (b) The data 1 transmit counter is set to 0DFH (for 24 bits). Table 6-5 describes the counter contents. The data 1 transmit counter is used to count the number of times bit data "1" is transmitted within custom code or custom code' that can affect the frame space transmission time. The number of "data 1" occurrences in the data code and data code is fixed (at eight) and therefore does not affect the frame space transmission time. Table 6-5. Description of Data 1 Transmit Counter (R9) | Counter value | Data 1 transmit counter description | |---------------|----------------------------------------------------------------------------------| | D0H | Number of "data 1" occurrences: 0 to 7 | | to | This status does not exist since the number of "data 1" occurrences in data code | | E6H | and data code is fixed (at eight). | | E7H | Number of "data 1" occurrences: 8 | | | Number of "data 1" occurrences in custom code and custom code': 0 | | E8H | Number of "data 1" occurrences: 9 to 16 | | to | Number of "data 1" occurrences in custom code and custom code': 1 to 8 | | EFH | | | F0H | Number of "data 1" occurrences: 17 to 24 | | to | Number of "data 1" occurrences in custom code and custom code': 9 to 16 | | F7H | | #### (2) Leader code transmission The transmission method for the leader code is described in (a) to (f) below. - (a) The table reference address (1A8H) for the leader code is set as follows. - High-order address (0AH) is set to data pointer H (R10) - Low-order address (8H) of "data 0" in bit data is set to data 0 (R08) - (b) Output data 0H for leader code is set to work area 2 (R1A). - (c) A subroutine (BITOUT0F) is called to transmit the leader code as a one-bit transmission. - (d) Work area 2 (R1A) is shifted leftward and a bit judgment is performed. - (e) The table reference address L for the judged bit is set to data pointer L to enable the transmission time to be set to the timer counter. - (f) The leader code (H: 9.00 ms, L: 4.50 ms) is transmitted. ### (3) Code transmission (custom code, custom code', data code, and data code) The code transmission method is described in (a) to (h) below. - (a) The table reference addresses (1AAH and 1ACH) for bit data used for code transmission are set as follows. - High-order address (0AH) is set to data pointer H (R10) - Low-order address (0AH) of "data 0" in bit data is set to data 0 (R08) - Low-order address (0CH) of "data 1" in bit data is set to data 1 (R18) - (b) The following data is set to work area 2 (R1A) when each type of code is transmitted. - Custom code H (R14) - Custom code L (R04) - Custom code H' (R15) - Custom code L' (R05) - Data code H (R16) - Data code L (R06) - Data code H (R16 is fully inverted) - Data code L (R06 is fully inverted) - (c) A subroutine is called to transmit the each type of code as a four-bit transmission. - (d) Work area 2 (R1A) is shifted leftward and a bit judgment is performed. If "data 1" is judged, the number of "data 1" occurrences is counted to enable frame space transmission. - (e) The table reference address L for the judged bit is set to data pointer L to enable the transmission time to be set to the timer counter. - (f) Each type of code is transmitted. - "Data 0" ... H: 0.56 ms, L: 0.56 ms - "Data 1" ... H: 0.56 ms, L: 1.69 ms A key OFF check is performed during low level transmission of each bit. For a description of the key OFF check, see (7) OFF chattering elimination processing below. - (g) Steps (d) to (f) above are repeated until four bits have been transmitted. - (h) Steps (b) to (g) above are repeated until all transmissions from custom code H to data code L are completed. #### (4) Transmission of stop bit The method for transmitting stop bits is described in (a) to (f) below. - (a) The table reference address (1AEH) for the stop bit is set as follows. - High-order address (0AH) is set to data pointer H (R10) - Low-order address (0EH) of "data 0" in bit data is set to data 0 (R08) - (b) Output data 0H for stop bit is set to work area 2 (R1A). - (c) A subroutine is called to transmit the stop bit as a one-bit transmission. - (d) Work area 2 (R1A) is shifted leftward and a bit judgment is performed. - (e) The table reference address L for the judged bit is set to data pointer L to enable the transmission time to be set to the timer counter. - (f) The stop bit (H: 0.56 ms, L: 3.00 ms) is transmitted. #### (5) Frame space transmission The code transmission time differs between transmission of the "data 1" and "data 0" bit data, with variation in the range of 59.06 ms to 77.06 ms. Therefore, when transmitting code, the frame space transmission time varies according to the number of "data 1" occurrences. However, since the number of "data 1" occurrences is fixed (at eight) within the data code and data code, the frame space transmission times are not affected when these types of code are transmitted. The number of "data 1" occurrences in the custom code and custom code' do affect frame space transmission times. The number of "data 1" occurrences are counted during transmission to enable responses to changes in transmission times. The frame space transmission times can be adjusted based on the count values. For details of "data 1" counts, see (3) Code transmission above. Table 6-6 lists frame space times correspond to the number of "data 1" occurrences. Since the maximum value that can be set to the timer counter is 9.00 ms, the frame space is divided into the three patterns shown in Figure 6-11 before being transmitted. Differences between times shown in Table 6-6 and Figure 6-11 are margins of error during code transmission (such as when the "data 0" low level time of 0.565 ms is set as 0.56 ms) which are absorbed by frame spaces. Table 6-6. Frame Space Times Corresponding to the Number of "Data 1" Occurrences | No. of "Data 1" | Transmission | No. of "Data 1" | Transmission | No. of "Data 1" | Transmission | No. of "Data 1" | Transmission | |-----------------|--------------|-----------------|--------------|-----------------|--------------|-----------------|--------------| | occurrences | time (ms) | occurrences | time (ms) | occurrences | time (ms) | occurrences | time (ms) | | 8 | 48.940 | 13 | 43.315 | 18 | 37.690 | 23 | 32.065 | | 9 | 47.815 | 14 | 42.190 | 19 | 36.565 | 24 | 30.940 | | 10 | 46.690 | 15 | 41.065 | 20 | 35.440 | | | | 11 | 45.565 | 16 | 39.940 | 21 | 34.315 | | | | 12 | 44.440 | 17 | 38.815 | 22 | 33.190 | | | **Remark** Since the number of "data 1" occurrences in data code and data code is fixed (at eight), the "data 1" values are never between 0 and 7. Figure 6-11. Method for Dividing Frame Space Transmission Times (1/2) (a) When there are eight "data 1" occurrences (data 1 transmission counter value: 0E7H) - a: After transmitting the stop bit, the frame space is transmitted for 3.00 ms. - b: A frame space is transmitted for the period corresponding to the number of "data 1" occurrences (18.94 ms). - c: If a key has been pressed and held, ON chattering elimination processing (9.00 ms × 3 times) is performed. In other cases, a frame space is transmitted for 27.00 ms. # (b) When there are from 9 to 16 "data 1" occurrences (data 1 transmission counter value range: 0E8H to 0EFH) - a: After transmitting the stop bit, the frame space is transmitted for 3.00 ms. - b: A frame space is transmitted for the period corresponding to the number of "data 1" occurrences (9.94 ms to 17.80 ms). - c: If a key has been pressed and held, ON chattering elimination processing (9.00 ms × 3 times) is performed. In other cases, a frame space is transmitted for 27.00 ms. Figure 6-11. Method for Dividing Frame Space Transmission Times (2/2) (c) When there are from 17 to 24 "data 1" occurrences (data 1 transmission counter value range: 0F0H to 0F7H) - a: After transmitting the stop bit, the frame space is transmitted for 3.00 ms. - b: A frame space is transmitted for the period corresponding to the number of "data 1" occurrences (0.94 ms to 8.80 ms). - c: If a key has been pressed and held, ON chattering elimination processing (9.00 ms × 3 times) is performed. In other cases, a frame space is transmitted for 27.00 ms. ### (6) Transmission of second and subsequent frames Until the current key is released or changed, code transmission of second and subsequent frames is repeated starting with the leader code in the same manner as for the first frame. This transmission method is described in (2) to (5) above. For a description of the key OFF check, see (7) OFF chattering elimination processing below. # (7) OFF chattering elimination processing A key OFF check is performed during low level output of bit data. Key OFF status is confirmed only when absence of key input (i.e., key OFF) has been judged for ten consecutive times during 34 times of low level output that includes the leader code and stop bit. If even one key input (key ON) is detected during the ten consecutive times being checked, the ten-time counter is cleared and the count is restarted. If key OFF status is not confirmed during the entire 34-time check, the key is judged as being pressed and held. Even if key OFF status is confirmed during transmission of one frame, initialization processing is not performed until at least two frames have been transmitted. Figure 6-12. Key OFF Check during Bit Data Transmission #### 6.3.2 Detailed flow chart **Note** As part of the main routine, the output data for the leader code is set to the accumulator (A) and the same data is set to work area 2 (R1A) via the called subroutine (BITOUT0C). | ****** | TRANS | MISS | ION | PR | OCES | SSI | 1G | *** | **** | | | | |--------------------------|-----------------------------------------|-------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------|---------|------|------|-------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | TIME9M | EQ | U | | 1FFI | I | | | | | ; | 9.00ms(9.002ms) | | ;####### | ### P | U | В | L | I | С | ##: | #### | #### | | | | | | i | | | | | | | | | | | | | ;###### | ### E<br>EXTRN | X | Т | | R<br>MAI1 | | ##: | #### | #### | | | MAIN Routine | | | EXTRN | | | ] | KEY8 | 30 | 7 | | | | ; | Key Check Routine | | | EXTRN | | | | FS_2 | 2 / IMS | | | | | , | Frame Space Subroutine | | ;######<br>TRNS: | #### | S T | A | R | Т | | ##: | #### | #### | | | | | | MOV | R7 | ,#OE | 75H | | | | | | | (a) | Sets the key OFF check counter ( $R_{07}$ ) for ten times (= 5H). | | | MOV | R 9 | ,#OI | нас | | | | | | | (b) | R <sub>17</sub> is used for immediate setting (R <sub>17</sub> = 0FH).<br>Initializes (sets 0FH to) the data 1 transmission | | :***** | | | | | | | L + + · | ++++ | ++++ | +++++ | (~) | counter (Ros). | | ; | | Le | adeı | c C | ode | | | | | | Re | mark Transmission of leader code (H: 9.00 ms, | | ; * * * * * * | *****<br>MOV | | ****<br>,#0 <i>I</i> | | | *** | *** | *** | **** | ***** | (c) | L: 4.50 ms) Sets the 0AH (high-order address of the table | | | | 200 | , II 01 | | | | | | | | (0) | data for the bit data transmission time) to data | | | MOV | R8 | ,#00 | )8Н | | | | | | | (d) | pointer H (R <sub>10</sub> ).<br>Sets the low-order address of the table data for | | | | | | | | | | | | | | the bit data transmission time to data 1 (R <sub>18</sub> ) and data 0 (R <sub>08</sub> ) (R <sub>18</sub> $\leftarrow$ 0H, R <sub>08</sub> $\leftarrow$ 8H). | | | MOV | Α, | R18 | | | | | | | | (e) | Sets the output data (0H) for leader code to the accumulator. (The accumulator's value is | | | | | | | | | | | | | | transferred to work area 2 as part of the bit | | | CALL | BI | TOUT | rof | | | | | | | (f) | output subroutine.) Calls the bit output subroutine (for one-bit | | | | | | | | | | | | | | transmission: counter value = 0FH). | | ;***** | ***** | *** | *** | *** | *** | *** | *** | *** | **** | ***** | | transmission. Counter value = orm. | | ; | | Cu | stor | n C | ode | | | | | | Re | mark Transmission of custom code | | ; ******<br>;<br>; ***** | | Cu<br>*** | stor | n C | ode | | | | | | | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for | | ; | ***** | Cu<br>*** | stor | n C | ode | | | | | | (g) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). | | ; | ***** | Cu<br>****<br>R8 | stor | n C | ode | | | | | | (g) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the | | ; | *****<br>MOV | Cu<br>****<br>R8 | stor<br>***<br>,#00 | n C | ode | | | | | | (g) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit | | ; | *****<br>MOV | Cu<br>****<br>R8<br>A, | stor<br>***<br>,#00 | m C<br>***<br>CAH | ode | | | | | | (g)<br>(h) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit | | ; | ******<br>MOV<br>MOV | Cu<br>****<br>R8<br>A, | stor<br>***;<br>,#00 | m C<br>***<br>CAH | ode | | | | | | (g)<br>(h) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). | | ; | MOV CALL | Cu<br>****<br>R8<br>A, | stor<br>****<br>,#00<br>R14 | m C<br>***<br>CAH | ode | | | | | | (g)<br>(h) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is | | ; | MOV CALL MOV | Cu<br>****<br>R8<br>A,<br>BI | ****,<br>#00<br>R14<br>TOUT | m Co | ode | | | | | | (g) (h) (i) (j) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) | | ; | MOV CALL | Cu<br>****<br>R8<br>A,<br>BI | stor<br>****<br>,#00<br>R14 | m Co | ode | | | | | | (g) (h) (i) (j) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit | | ; | MOV CALL MOV CALL | Cu**** R8 A, BI A, | stor<br>****<br>,#00<br>R14<br>TOUT | n C<br>***<br>CAH | ode<br>**** | *** | k** | *** | **** | **** | (g) (h) (i) (j) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit | | ;;******; | MOV CALL MOV CALL | Cu **** R8 A, BI A, BI **** | **** **** **** **** **** **** | n Control Cont | ode<br>****<br>**** | ***** | **** | **** | **** | **** | (g) (h) (i) (j) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). | | ,<br>;***** | MOV CALL MOV CALL | Cu **** R8 A, BI A, BI **** | **** **** **** **** **** **** | n Control Cont | ode<br>****<br>**** | ***** | **** | **** | **** | **** | (g) (h) (i) (j) (k) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). mark Transmission of custom code' (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets output data H (R₁5) for custom code' to | | ;;******; | MOV CALL MOV CALL ****** | Cu **** R8 A, BI A, BI **** | **** **** **** **** **** | n Control Cont | ode<br>****<br>**** | ***** | **** | **** | **** | **** | (g) (h) (i) (j) (k) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). mark Transmission of custom code' (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets output data H (R₁5) for custom code' to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit | | ;;******; | MOV CALL MOV CALL ****** | Cu **** R8 A, BI A, BI **** A, | **** **** **** **** **** | n Co | ode<br>****<br>**** | ***** | **** | **** | **** | **** | (g) (h) (i) (j) (k) Re (l) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). mark Transmission of custom code' (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets output data H (R₁5) for custom code' to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) | | ;;******; | MOV CALL MOV CALL ****** MOV CALL | Cu**** R8 A, BI A, BI **** Cu **A, | **** TOUT **** R14 TOUT **** R15 | n Co | ode<br>****<br>**** | ***** | **** | **** | **** | **** | (g) (h) (i) (j) (k) Rea (l) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). mark Transmission of custom code' (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets output data H (R₁₅) for custom code' to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). | | ;;******; | MOV CALL MOV CALL ****** MOV | Cu**** R8 A, BI A, BI **** Cu **A, | ****;<br>#000<br>R14<br>TOUT<br>****;<br>stor<br>***;<br>R15 | n Co | ode<br>****<br>**** | ***** | **** | **** | **** | **** | (g) (h) (i) (j) (k) Rea (l) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). mark Transmission of custom code' (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets output data H (R₁5) for custom code' to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀5) for custom code' to accumulator. (The accumulator's value is | | ;;******; | MOV CALL MOV CALL ****** MOV CALL | Cu**** R8 A, BI A, BI **** Cu **A, | **** TOUT **** R14 TOUT **** R15 | n Co | ode<br>****<br>**** | ***** | **** | **** | **** | **** | (g) (h) (i) (j) (k) Re (l) (m) (n) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). mark Transmission of custom code' (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets output data H (R₁5) for custom code' to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀5) for custom code' to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) | | ;;******; | MOV CALL MOV CALL ****** MOV CALL | Cu**** R8 A, BI A, BI **** Cu *** A, BI A, | **** TOUT **** R14 TOUT **** R15 | n Co | ode<br>****<br>**** | ***** | **** | **** | **** | **** | (g) (h) (i) (j) (k) Re (l) (m) (n) | mark Transmission of custom code (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets the low-order address of the table data for the custom code to data 1 (R₁8) and data 0 (R₀8) (R₁8 ← CH, R₀8 ← AH). Sets output data H (R₁4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀4) for custom code to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). mark Transmission of custom code' (H: 0.56 ms, L: 0.56 or 1.69 ms) Sets output data H (R₁5) for custom code' to the accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). Sets output data L (R₀5) for custom code' to accumulator. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) | **Note** As part of the main routine, the output data for the leader code is set to the accumulator (A) and the same data is set to work area 2 (R1A) by the called subroutine (BITOUT0C). | ;***** | ***** | ******** | | |-------------|--------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ; | | Data Code | Remark Transmission of data code | | ; * * * * * | ****** | ********* | (H: 0.56 ms, L: 0.56 or 1.69 ms) | | | MOV | A,R16 | <ul><li>(a) Sets output data H (R<sub>16</sub>) for the data code to<br/>the accumulator.</li><li>(The accumulator's value is transferred to work<br/>area 2 as part of the bit output subroutine.)</li></ul> | | | CALL | BITOUT0C | (b) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). | | | MOV | A,R06 | <ul><li>(c) Sets output data L (R<sub>06</sub>) for the data code to the accumulator.</li><li>(The accumulator's value is transferred to work area 2 as part of the bit output subroutine.)</li></ul> | | | CALL | BITOUT0C | (d) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). | | ; * * * * * | ***** | ******** | | | ; | | Data Code' | Remark Transmission of data code | | ; * * * * * | ***** | * * * * * * * * * * * * * * * * * * * * | (H: 0.56 ms, L: 0.56 or 1.69 ms) | | | MOV | A,R16 | (e) Sets output data H (R <sub>16</sub> ) for the data code to the accumulator. | | | XRL | A,#0FH | <ul> <li>(f) The accumulator's value is inverted to create output data for data code H.</li> <li>(The accumulator's value is transferred to work area 2 as part of the bit output subroutine.)</li> </ul> | | | CALL | BITOUT0C | (g) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). | | | MOV | A,R06 | <ul><li>(h) Sets output data L (R<sub>06</sub>) for the data code to<br/>the accumulator.</li></ul> | | | XRL | A,#0FH | (i) The accumulator's value is inverted to create output data for data code L. (The accumulator's value is transferred to work area 2 as part of the bit output subroutine.) | | | CALL | BITOUT0C | (j) Calls the bit output subroutine (for four-bit transmission: counter value = 0CH). | | ; * * * * * | ***** | ********* | | | ; | | Stop Bit | Remark Transmits stop bit | | ; * * * * * | ****** | ********* | (H: 0.56 ms, L: 3 ms) | | | MOV | R8,#00EH | (k) Sets the low-order address of table data having a stop bit carrier to data 0 (R <sub>08</sub> ). | | | MOV | A,R18 | <ul><li>(I) Sets the output data (0H) for the stop bit to the accumulator.</li><li>(The accumulator's value is transferred to work area 2 as part of the bit output subroutine.)</li></ul> | | | CALL | BITOUTOF | (m) Calls the bit output subroutine (for one-bit transmission: counter value = 0FH). | Note If pressed continuously, continue flag = 0FH. | ; * * * * * | ***** | ***** | ****** | **** | | |-------------|------------|------------|----------|-------------|-------------------------------------------------------------------------| | ; * * * * * | | | | **** | | | ; * * * * * | | Transmi | | **** | | | ; * * * * * | | Subroutine | | **** | | | , | | ****** | ******* | ***** | | | BITOUT | | | | ( ) | 0 ( ) | | | MOV | R1A,A | | | Sets output data to work area 2 (R1A). | | | MOV | A,#0FH | | (a) | Sets 0FH to accumulator to set the transmit bit | | | TMD | DITTOIT | | | counter to count one time. | | | JMP | BITOUT | | | Processing branches to BITOUT. | | BITOUT | nc: | | | | | | 2110010 | MOV | R1A,A | | (c) | Sets output data to work area 2 (R <sub>1A</sub> ). | | | MOV | A,#0CH | | | Sets 0CH to accumulator to set the transmit bit | | | | • | | , | counter to count four times. | | BITOUT | : | | | | | | | MOV | ROA,A | | Re | emark 0FH, 0EH, or 0CH can be set to the transmit | | | | | | | bit counter (ROA). | | | | | | | | | | MOV | A,R1A | ) | ( ) | | | | RL | A | <b>}</b> | (e) | Shifts the output data one bit leftward. | | | MOV | R1A,A | ) | <b>(£</b> ) | ludges whether hit data value is "O" or "1" | | | JC | BIT_DAT1 | | (1) | Judges whether bit data value is "0" or "1". | | ;** B | it Data = | 0 ** | | | If it is "1", processing branches to BIT_DAT1. | | / D. | MOV | A,R08 | _ | | | | | MOV | R00,A | | (a) | Sets data 0 (Ros) to data pointer L (Roo). | | | JMP | BIT_TRN | <u></u> | (9) | Processing branches to BIT_TRNS. | | | ; | D11_114V | | | Troopsoming prantones to Bit_Trute. | | ;** Bi | it Data = | 1 **; | | | | | BIT_DAT | г1: | | | | | | | MOV | A,R18 | } | (h) | Sets data 1 (R <sub>18</sub> ) to data pointer L (R <sub>00</sub> ). | | | MOV | R00,A | J | | | | | MOV | A,R09 | ) | | | | | INC | A | } | · (i) | Increments data 1 transmit counter L (R <sub>09</sub> ). | | | MOV | R09,A | J | (*) | | | | JNC | BIT_TRANS | | (j) | If there is no overflow in data 1 transmit counter | | | MOT7 | 7 D10 | | | L (R <sub>09</sub> ), processing branches to BIT_TRNS. | | | MOV<br>INC | A,R19<br>A | \ | (k) | Increments data 1 transmit counter H (R <sub>19</sub> ). | | | MOV | R19,A | <u></u> | (14) | morements data i transmit obunter ii (1719). | | BIT_TRN | | 1(1) /11 | | | | | | HALT | #005Н | | (1) | HALT mode: canceled when time counter | | | | | | ( ) | reaches 00H. | | | MOV | T,@R0 | | (m | ) Performs table reference to set transmit time data | | | | | | | to timer counter. | | | STTS | #0101B | | (n) | Clears status flag. | | | MOV | A,R00 | ) | | | | | INC | A | } | · (o) | Increments data pointer L (R <sub>00</sub> ). | | | MOV | R00,A | J | | | | | MOV | R00,A | | (n) | HAI Tmode: canceled when time counterresches | | | HALT | #005H | | (p) | HALT mode: canceled when time counter reaches 00H. | | | MOV | T,@R0 | | (a) | Performs table reference to set transmit time data | | | 1·10 V | 1,000 | | (4) | to timer counter. | | | MOV | A,R07 | _ | | to time ocurren | | | INC | A | | (r) | Judges whether key OFF status is maintained | | | JC | BIT_TRANS2 | J | ( ) | during ten consecutive times. | | | | _ | | | If key OFF status is confirmed, processing | | | | | | | branches to BIT_TRANS2. | | | STTS | #1110B | } | (s) | Determines whether or not key input exists. | | | JNF | BIT_TRANS1 | J | | If a key has been pressed and held, processing | | | | | | | branches to BIT_TRANS1. | | ;** Ke | ey input | | | 101 | | | | MOV | R7,#0F5H | | (t) | | | | | | | | (Ro7) if key input exists even once during the (10-time) key OFF check. | | | JMP | BIT_TRANS2 | | | Processing branches to BIT_TRANS2. | | | | DII_INWN97 | | | 1 100000111g branchios to DIT_ITTANOZ. | | | ; | | | | | - (u) Increments key OFF check counter. - (v) Clears status flag. - (w) Increments transmit bit counter (RoA). - (x) Determines whether or not the transmit bit count has been completed. If not completed, processing branches to BITOUT. - (y) End of processing **Remark** Subroutine for outputting remaining 27 ms of frame space. FS\_27MS: MOV A,#0DH FS\_27MS0: HALT #005H MOV T,#TIME9M STTS #0101B INC A JNC FS\_27MS0 RET J. END (a) Sets counter (accumulator) to count three times (= 0DH). - (b) HALT mode: canceled when time counter reaches 00H. - (c) Sets timer counter to 9 ms (= 1FFH). - (d) Clears status flag. - (e) Increments counter (accumulator). - (f) Determines whether or not three times have been counted.If they have not been counted, processing branches to FS\_27MS0. - (g) End of processing ### **CHAPTER 7 CAUTIONS ON PROGRAM REVISIONS** Note the following caution points when modifying the key matrix or the number of keys. ## (1) When changing the number of keys from 80 to 64 • Delete the keys that are enclosed in broken lines in the following diagram (when doing so, if the S<sub>1</sub>/LED pin is left unconnected, the number of keys can be changed without modifying the main program itself. **Note** Set by the program for "internal pull-down resistor". # (2) In addition to the modification described in (1) above, the $S_1/\overline{\text{LED}}$ pin can be used as an LED pin: - Delete the keys that are enclosed in broken lines in the following diagram. - Change the S<sub>1</sub>/LED pin so that b<sub>2</sub> (the bit that sets the I/O mode for the S<sub>1</sub>/LED port) in the main program's control register 1 (P4) remains in output mode (bit value = 1). (In μPD6133 Series products, setting the S<sub>1</sub>/LED pin to output mode automatically eliminates internal pull-down resistance.) Note Set by the program for "internal pull-down resistor". # **CHAPTER 8 CAUTIONS ON USE OF THIS PROGRAM** The key combination specifications in this program provide only three valid key combination patterns: K29 + K30, K29 + K31, and K29 + K32. For this key matrix, if an ordinary key (K1 to K40) is pressed in combination with an expansion key (K41 to K80) on the same key source line, the expansion key will always be the valid key. For example, if K19 is pressed in combination with K59, then K59 is the valid key. [MEMO] # **CHAPTER 9 PROGRAM LIST** AS6133 V1.01 << D6134 ASSEMBLE LIST >> 01:00:00 08/29/96 PAGE 01-002 ## SOURCE = MAIN80.ASM | E STNO LOC. OBJ. | M I | SOURCE STATEMENT | | |------------------|-----|------------------------------------------------------------|------| | 1 | | ;************************************** | **** | | 2 | | ;*** | *** | | 3 | | ;*** Multi-Purpose Remote Control Transmitter System | *** | | 4 | | ;*** | *** | | 5 | | ;*** CPU : uPD6133 Series | *** | | 6 | | ;*** CPU Clock : 455kHz | *** | | 7 | | ;*** Trans. CODE: NEC-R Format (80Key) | *** | | 8 | | ;*** Version : 2.0 | *** | | 9 | | ;*** Programmer : NEC IC Microcomputer Systems Corporation | *** | | 10 | | ;*** | *** | | 11 | | ;*** Copyright(c) NEC Corporation 1995 | *** | | 12 | | ;*** Copyright(c) NIMS Corporation 1995 | *** | | 13 | | ;************************************** | **** | | 14 | | EJECT | | ``` SOURCE = MAIN80.ASM ``` ``` M I SOURCE STATEMENT E STNO LOC. OBJ. ;0.5ms (0.510ms) 15 001C EQU 01CH EQU 512-1 16 01FF DamyTime ;9.00MS (= 17.582us * 512) 17 ;######## P U B L I C ######## 18 19 MAIN 20 21 ;######### E X T E R N ######## 2.2 ; 23 24 ;######## S T A R T ######## 25 26 ; Control Register (P3) Reset:03H 27 ;----: 28 ; D9 D8 ! D7 ! D6 ! D5 ! D4 ! D3 ! D2 ! D1 ! D0 ! ; 29 ; ! D.P.! D.P.! D.P.! TCTL! CARY! MOD1! MOD0! ; 30 ; Test Mode! ! AD10! AD9 ! AD8 ! AD8 ! ! ! ; ;-----; 31 ; ! 0 ! * ! * ! 1/1 ! ON ! fx,fx/8 ! 0 ; 32 33 ; Set "0" !----; ,fx/12(1/2) !---; ; ! 0 ! * ! * ! 1/2 ! OFF ! ,fx/12(1/3) ! 1 ; 34 35 ;=====; 36 37 ; Control Register (P4) Reset:26H 38 ;======; 39 ; D9 D8 ! D7 ! D6 ! D5 ! D4 ! D3 ! D2 ! D1 ! D0 ! ; 40 ; ! ! KI!SO/S1! !S1/LED! KI/O! SO ! ; 41 ! ! Pull! Pull! ! MODE ! MODE! MODE! ; 42 43 ! 0 ! 0 ! OFF ! OFF ! 0 ! IN ! IN ! OFF ! 0 ; 44 X !-----!---; 45 ! 0 ! 0 ! ON! ON! 0 ! OUT ! OUT! IN! 1; 46 ;=======; 47 ;************** 48 49 Control Register Initialize 50 51 MAIN: 52 0000 E6F8 EFEF P0,#0FFH ;KI/O All High OUT 53 0002 E6FC E3E2 OUT P4,#032H 54 0004 E6FB E1E3 OUT P3,#013H ;Set Data Pointer (P3:D8,D9) MOV T, #DamyTime 55 0006 E6FF F7FF 56 0008 E3F1 E0E5 STTS #0101B Clear Status Flag 58 ;*************** 59 RAM Initialize Routine ;************** 60 61 000A E6E1 E0E0 MOV ;Final Key Data (R1) = 00h R1.#000H 62 000C E6E3 E0E0 MOV R3,#000H ;K29 ON Flag (R13),Continuance Falg (R03) = 00H 63 64 000E E2F1 E0E8 HALT #008H ;STOP mode (KI = High) 65 0010 E0E0 NOP ;No operation command 66 0011 E6FF E0E7 MOV T,#TIME05M ;Set Timer : 0.5ms 67 68 END ``` #### SOURCE = KEY80.ASM | E STNO LOC. OBJ. M I | SOURCE STATEMENT | | |------------------------------|------------------------------------------------|-----------------------------------------------------| | 1 | ;************ | | | 2 | ;**** | | | 3 | ;***** uPD6133 Series Key Check ***** | | | 4 | ;***** Trans. CODE: NEC-R Format (80Key) ***** | | | | :**** | | | 5 | ;*********** | | | 6 | | .0.00(0.000) | | 7 01FF | TIME9M EQU 1FFH | ;9.00ms (9.002ms) | | 8 0050 | CUSTM1 EQU 050H | ;Custom Code = OAH | | 9 00AF | CUSTM1 EQU OAFH | ;Custom Code' = F5H | | 10 | | | | 11 | ;######## P U B L I C ######## | | | 12 | PUBLIC KEY80 | | | 13 | i | | | 14 | | | | 15 | ;######### E X T E R N ######## | | | 16 | EXTRN MAIN | ;MAIN Routine | | 17 | i | | | 18 | | | | 19 | ;######## S T A R T ######## | | | 20 | KEY80: | | | 21 0013 E6E0 E0EC | MOV R0,#00CH | Chattering Counter (R00) = 3 Times | | 22 0015 E6EC E8E2 | MOV RC,#082H | ;Set Immediate Data : RC | | 23 | ;************* | | | 24 | ; ON Chattering | | | 25 | ;************** | | | 26 | ON_CHAT: | | | 27 0017 E3F1 E0E5 | STTS #0101B | Clear Status Flag | | 28 0019 E6F8 EFEF | OUT PO,#0FFH | ;KI/O All High | | 29 001B E6FC E3E3 | OUT P4,#033H | | | 30 001D E2F1 E0E5 | HALT #005H | HALT mode (Timer = 00H) | | 31 001F E6FF F7FF | MOV T, #TIME9M | Timer = 9.00ms | | 32 0021 E6E9 E0E0 | MOV R9,#000H | Comparative Key Data (R9) = 00H | | 33 0023 E6E6 E0E8 | MOV R6,#008H | ;Key Flag (R16) = 00H, Key Scan Counter (R06) = 08H | | 34 0025 E3F1 E0EE | STTS #1110B | ;With input Key (KI or SO or S1) ? | | 35 0027 EFF1 E0E0 | JNF MAIN | ; else MAIN: (Without input Key) | | 36 | | ; then (With input Key) | | 37 0029 E6E8 E0E1 | MOV R8,#001H | ;Key Scan Data (R8) Initialize : 001H | | 38 | | | | 39 | ;************** | | | 40 | ; Key Scan | | | 41 | ;************** | | | 42 | KEYS_OUT: | | | 43 002B FFE8 | MOV A,R08 | | | 44 002C E5F8 | OUT POO,A | ;Key Scan Data L (POO) Output | | 45 OO2D FEE8 | MOV A,R18 | | | 46 002E E4F8 | OUT P10,A | ;Key Scan Data H (P10) Output | | 47 | ;++++++ | | | 48 | ;++ 100us Wait ++ | | | 49 | ;++++++ | | | 50 002F E6E2 EFE1 | MOV R2,#0F1H | ;Set Immediate Data : R2 | | 51 0031 E6EB ECE3 | MIV RB, #0C3H | ;Set Immediate Data : RB | | 52 0033 E0E0 | NOP | | | 53 0034 E0E0 | 1102 | | | | NOP | | | | NOP<br>NOP | | | 54 0035 E0E0<br>55 0036 E0E0 | NOP<br>NOP<br>NOP | | SOURCE = KEY80.ASM ``` E STNO LOC. OBJ. M I SOURCE STATEMENT ;*************** 56 57 Key Return Check ;************** 5.0 59 0037 E3F1 E0EB STTS #1011B ;With input Key (KI or SO or S1) ? JNF NO_KEYS ; else NO_KEYS: (Without input Key) 60 0039 EFF1 E9E8 ; then (With input Key) 62 003B E3F1 E0E3 STTS #0011B ;With input KI (P11)? 63 003D EFF1 E4E8 JNF S0S1CALC ; else SOS1CALC: (With input KI) 64 then (Without input KI) ;*******; 65 t.hen (KI(P11)Without input) 66 KI Data Calculate 67 ;********* 68 003F FFF9 IN A,P01 69 0040 FCF3 A RT. ;With input S1(P01)? 70 0041 ECF1 E0E0 MAIN ; else MAIN: JC (With input S1) then (Without input S1) 72 0043 FEEB MOV A,R1B ;R1B = OCH 73 0044 E5EA MOV ROA,A ; Key Return Check Counter (ROA) = 4 Times (=OCH) 74 0045 FEF9 A,P11 TN 75 0046 E8F1 E4ED JMP KEY_RET0 77 ;********* 78 79 ; S0,S1 Data Calculate ;******** 81 SOS1CALC: 82 0048 E6E9 EBE0 MOV R9,#0B0H 83 004A FEE2 MOV A,R12 ;R12 = 0FH 84 004B E5EA MOV ROA,A ;Set Key Return Check Counter (ROA) = 1 Times (=OFH) 85 004C FFF9 IN A,P01 86 87 KEY_RET0: MOV R10,A ;Work (R10) = P11 or P01 88 004D E4E0 89 004E E3F1 E0E5 STTS #0101B Clear Status Flag KEY_RET: 91 0050 FEE0 MOV A,R10 92 0051 FEF3 RIZ A 93 0052 E4E0 MOV R10.A 94 0053 EDF1 E9E3 ;With input Key? JNC KRC INC else KRC_INC: (Without input Key) 95 ;** With input Key ** 96 0055 FEE6 MOV A,R16 ; then (With input Key) 97 0056 FAF3 ;Key Flag (R16) = OFH? SCAF 98 0057 EDF1 E6E7 JNC KEY CALC ; else KEY CALC: (Except for OFH) 99 0059 FEE3 MOV A,R13 then (= OFH) 100 005A FAF3 ;K29 ON Flag (R13) = 0FH? SCAF 101 005B EDF1 E0E0 JNC MAIN ; else MAIN: (= Except for OFH) 102 (= OFH) ; then 103 005D FFEC MOV A.ROC ;ROC = 02H 104 005E F4E9 XRL A,R19 105 005F FAF3 SCAF ;Comparative Key Data = K29 (R19=ODH) ? ; then MAIN: (Key = Except for K29) 106 0060 EDF1 E0E0 JNC MAIN ; 107 0062 FFE9 MOV A,R09 else (Key = K29) 108 0063 F5EB ;ROB = 03H XRL A.ROB 109 0064 FAF3 SCAF Comparative Key Data = K29 (R09=OCH) ? 110 0065 EDF1 E0E0 JNC MAIN ; then DBL_K_CHK: (Key = Except for K29) ``` ``` SOURCE = KEY80.ASM ``` ``` E STNO LOC. OBJ. M I SOURCE STATEMENT ;******************** 112 113 Key Data Calculate ;******** 114 115 KEY_CALC: 116 0067 FFF1 F4E0 MOV A,#04H 117 0069 F4E9 XRL A,R19 118 006A FAF3 SCAF ;Comparative Key Data H (R19) = OBH ? 119 006B EDF1 E7E5 JNC KI CALC ; else KI_CALC: (KI Data) ;** S1 data Calculation ** then (S1 Data) 121 006D FFE6 MOV A,R06 ;Acc <-- Key Scan Counter (R06) 122 006E FBF1 F7E0 ANL A,#0111B 123 0070 E5E9 R09.A MOV 124 0071 FEE0 ;Acc <-- Work 1 (R10) MOV A,R10 125 0072 FAEC A,R1C ;R1C = 08H 126 0073 E8F1 E8E8 JMP KL_CALC 127 ;** KI data Calculation ** 128 129 KI_CALC: 130 0075 FFE6 MOV A,R06 ;Acc <-- Key Scan Counter (R06) 131 0076 FCF3 RL Α 132 0077 FCF3 RT. ;Left shift (2 Times) Α 133 0078 E5E9 MOV R09.A ;Comparative Key Data L (R09) <-- Acc 134 0079 FBE2 ;Acc AND 0001B (R02=01H) ANL A,R02 135 007A FCEB ORL A,R1B ;Acc OR 1100B (R1B=0CH) 136 007B E4E9 MOV R19,A ;Comparative Key Data H (R19) <-- Acc 137 007C FFF9 TN A.P01 ;Acc <-- S1 and S0 Data 138 007D FCF3 RL ;Left shift (3 Times) Α 139 007E FCF3 RL A 140 007F FCF3 RL 141 0080 FREC ANT. A . ROC ;Acc AND 0010B (R0C=02H) 142 0081 FCE9 ORT A.R19 Acc OR Comparative Key Data H (R19) 143 0082 E4E9 MOV R19,A ;Comparative Key Data H (R19) <-- Acc 144 0083 FFE9 MOV A,R09 ;Acc <-- Comparative Key Data L (R09) 145 0084 FAEB ANL A,R1B ;Acc AND 1100B (R1B=0CH) 146 0085 E5E9 MOV R09.A Comparative Key Data L (R09) <-- Acc 147 0086 FFEA ;Acc <-- Key Return Check Counter (ROA) MOV A.ROA ;Acc AND 0011B (R08=03H) 148 0087 FBEB ANL A,R08 149 KL_CALC: 150 0088 FDE9 ORL A.R09 ;Acc OR Comparative Key Data L (R09) 151 0089 E5E9 MOV R09,A ;Comparative Key Data L (R09) <-- Acc 152 ;** Double Key Check ** 153 154 008A FEE6 MOV A,R16 155 008B FAF3 SCAF ;Key Flag (R16) = 0FH? 156 008C EDF1 E9E1 ; else SINGLE_K (Single Key) TNC SINGLE K 157 008E FFF1 F9E0 MOV A.#09H then (Double Key) 158 0090 E4E9 MOV R19,A 159 SINGLE_K: ;R12 = 0FH 160 0091 FEE2 MOV A,R12 161 0092 E4E6 MOV R16.A 162 KRC_INC: 164 0093 FFEA MOV A,ROA 165 0094 F4F3 TNC A ; Key Return Check Counter (ROA) increment ``` SOURCE = KEY80.ASM | F. STNO | LOC. OBJ. | | M I | SOURCE | STATEMEN | rr | | | | | | |---------|-----------|------|------|-----------|----------|------------------|----------|----------|---------|-------------------|-----------------------------| | | 0095 E5EA | | rı ı | DOURCE | MOV | ROA,A | | | :End o | f Key Return Chec | k 2 | | | 0096 EDF1 | | | | PIOV | NOA,A | JNC | KEY_RET | ; | else KEY_RET: | (Continuous) | | 168 | 0000 EDF1 | 5550 | | | | | OIVC | KEI_KEI | ; | then | (End) | | 169 | | | | | | | | | , | chen | (EIIU) | | 170 | | | | NO_KEYS | | | | | | | | | | 0000 8381 | DODE | | NO_VEIS | | #0101B | | | .01 | Obstant Plan | | | | 0098 E3F1 | | | | STTS | #0101B | | | /Clear | Status Flag | | | | 009A FFE6 | | | | MOV | A,R06 | | | | a (505) | | | | 009B F4F3 | | | | INC | A | | | _ | can Counter(R06) | | | | 009C E5E6 | | | | MOV | R06.A | | | | f Key Scan number | | | | 009D ECF1 | EAEB | | | | | JC | KEY_DATA | i | then KEY_DATA: | | | | 009F FEE8 | | | | MOV | A,R18 | | | ; | else | (Continuous) | | | 00A0 FCF3 | | | | RL | A | | | ;Key S | can Data H (R18) | Snift | | | 00A1 E4E8 | | | | MOV | R18,A | | | | | | | | 00A2 FFE8 | | | | MOV | A,R08 | | | | | | | | 00A3 FCF3 | | | | RL | A | | | | | | | | 00A4 E5E8 | | | | MOV | R08,A | | | | can Data L (R08) | | | | 00A5 EDF1 | | | | JNC | KEYS_OUT | | | ; | _ | (key Scan Data a low rank) | | | 00A7 E6E8 | | | | | | VOM | R8,#010H | ; | then | (key Scan Data a high rank) | | 184 | 00A9 E8F1 | E2EB | | | | | JMP | KEYS_OUT | | | | | 185 | | | | | | | ; | | | | | | 186 | | | | | | | | | | | | | 187 | | | | ;***** | ****** | ****** | ****** | ****** | | | | | 188 | | | | ; Trans | mit Key | Data = ON Chatte | ring Key | Data? | | | | | 189 | | | | ;***** | ****** | ****** | ****** | ****** | | | | | 190 | | | | KEY_DAT | A: | | | | | | | | 191 | 00AB E6F8 | EFEF | | | OUT | P0,#0FFH | | | ;KI/0 | All High | | | 192 | 00AD E6E8 | EFE0 | | | MOV | R8,#0F0H | | | ;Set I | mmediate Data : R | 8 | | 193 | 00AF FEE6 | | | | MOV | A,R16 | | | | | | | 194 | 00B0 FAF3 | | | | SCAF | | | | ;Key F | lag (R16) = 0FH ? | | | 195 | 00B1 EDF1 | E0E0 | | | | | JNC | MAIN | ; | else MAIN: | (=Except for OFH) | | 196 | 00B3 FFE0 | | | | MOV | A,R00 | | | ; | then | (= OFH) | | 197 | 00B4 F5EB | | | | XRL | A,ROB | | | ;R0B = | #0011B | | | 198 | 00B5 FAF3 | | | | SCAF | | | | ;Chatt | ering Counter (RO | 0) = 1 Times (=0DH)? | | 199 | 00B6 ECF1 | ECE3 | | | | | JC | KEYCHECK | ; | then KEYCHECK: | (=0DH) | | 200 | | | | | | | | | ; | else | (=0E-0FH) | | 201 | 00B8 FEE4 | | | | MOV | A,R14 | | | | | | | 202 | 00B9 F4E8 | | | | XRL | A,R18 | | | ;R18 = | 0FH | | | 203 | 00BA F4E9 | | | | XRL | A,R19 | | | :Acc = | 0FH | | | 204 | 00BB FAF3 | | | | SCAF | | | | ;Key D | ata H (R14) = Com | parative Key Data H (R19) | | 205 | 00BC EDF1 | E0E0 | | | | | JNC | MAIN | ; | else MAIN: | (Unmatch) | | 206 | | | | | | | | | ; | then | (Match) | | 207 | 00BE F5E4 | | | | XRL | A,R04 | | | ;Acc = | 0FH | | | 208 | 00BF F5E9 | | | | XRL | A,R09 | | | | | | | | 00C0 FAF3 | | | | SCAF | , | | | ;Kev D | ata I (RO4) = Com | parative Key Data L (R09) | | | 00C1 EDF1 | | | | | | JNC | MAIN | ; | else MAIN: | (Unmatch) | | 211 | | | | KEYCHEC | к: | | | | ; | then | (Match) | | | 00C3 FEE9 | | | 112101120 | MOV | A,R19 | | | | 011011 | (1.001) | | | 00C3 FEE5 | | | | MOV | R14,A | | | ;Kev D | ata H (R14) ← Co | mparative Key Data H (R19) | | | 00C5 FFE9 | | | | MOV | A,R09 | | | D | () ( 00 | | | | 00C5 FFE9 | | | | MOV | R04,A | | | :Kar D | ata I. (RN4) ∠ ~~ | mparative Key Data L (R09) | | | 00C0 ESE4 | | | | MOV | A,R00 | | | , ney D | ~~~ I (IVI) \ CO | merative net para n (100) | | | 00C7 FFE0 | | | | INC | A, 1000<br>A | | | :Cha++ | ering Counter (RO | (1) ingrement | | | 00C0 F4F3 | | | | MOV | R00,A | | | ruiact | cring counter (RU | o, increment | | | 00C9 ESE0 | | | | SCAF | NUU,A | | | :End o | f Chattering Rout | ine of 3 Time? | | | 00CB EDF1 | | | | DUMF | | TNIC | ON CUAT | ; End o | else ON CHAT: | | | 220 | OUCD EDF1 | DID/ | | | | | JNC | ON_CHAT | , | GIBE ON_CHAI. | (= VUII) | SOURCE = KEY80.ASM ``` E STNO LOC. OBJ. M I SOURCE STATEMENT ; then 221 ;** Key High Check ** (= 0E-0FH) 222 00CD F4E1 XRL A.R11 ;Acc = OFH XRL A,R14 223 OOCE E4E4 224 00CF FAF3 SCAF ;Final Key Data H (R11) = Key Data H (R14) ? 225 00D0 EDF1 EDE7 JNC KDAT_SET ; else KDAT_SET: (Unmacth) 226 ;** Key Low Check ** ; then (Match) XRL A,R01 ;Acc = OFH 227 00D2 F5E1 228 00D3 F5E4 XRL A,R04 229 00D4 FAF3 SCAF = ;Final Key Data L (R01) = Key Data L (R04) ? ; then K29CHECK: (Match) 230 00D5 ECF1 EDED JC K29CHECK KDAT_SET: else (Unmacth) 232 00D7 FEE4 MOV A,R14 233 00D8 E4E1 MOV R11.A ;Final Key Data H (R11) <-- Key Data H (R14) 234 00D9 FFE4 MOV A,R04 235 00DA E5E1 MOV R01,A ;Final Key Data L (R01) <-- Key Data L (R04) 236 00DB FFE8 MOV A,R08 237 00DC E5E3 MOV RO3,A ;Continuance Flag = 00H (R08=00H) 238 239 K29CHECK: 240 00DD FFEC MOV A,ROC ;ROC = 02H (K29=1DCH) 241 00DE F4E1 XRL A,R11 242 00DF FAF3 ;Final Key Data = K29 (R11=0BH)? SCAF 243 00E0 EDF1 EEE7 JNC DBL_K_CHK ; then DBL_K_CHK: (Key = Except for K29) 244 00E2 FFE1 MOV A,R01 ; else (Key = K29) 245 00E3 F5EB XRL A,ROB ;ROB = 03H 246 00E4 FAF3 SCAF ;Final Key Data = K29 (R01=0CH)? ; then K29_FLG: (Key = Except for K29) 247 00E5 ECF1 EEEE JC K29 FLG 248 else (Key = K29) DBL_K_CHK: 250 00E7 FFF1 F6E0 MOV A,#06H 251 OOE9 F4E1 XRI. A.R11 ;Final Key Data K29+ K30 or K31 or K32 (R11=09H) ? 252 OOEA FAF3 SCAF 253 OOEB ECF1 EEEF JC DATA_SET ; then DATA_SET: (Key = Except for Double Key) 254 00ED FFE8 MOV A,R08 255 K29_FLG: 256 OOEE E4E3 MOV R13,A ;K29 ON Flag = 00H (R08=00H) ;*************** 257 258 Transmit Data Set ;************** 259 260 DATA_SET: ;** Custom Code ** 261 262 00EF E6E4 E5E0 MOV R4, #CUSTM1 ;Custom Code(R4) <-- Custom Code ;** Custom Code' ** MOV R5, #CUSTM2 265 00F1 E6E5 EAEF ;Custom Code'(R5) <-- Custom Code' 266 267 ;** Data Code ** 268 00F3 FEE1 MOV A,R11 269 00F4 E4E0 MOV R10.A ;Data Pointer H(R10) <-- Final Key Data H(R11) MOV A,R01 270 00F5 FFE1 271 00F6 E5E0 MOV ROO,A ;Data Pointer L(R00) <-- Final Key Data L(R01) 272 00F7 E7E6 MOV R6,@R0 273 274 END ``` SOURCE = TRANS80.ASM | E STNO LOC. OBJ. | M I SOURCE STAT | MENT | | |------------------------|-----------------|--------------------------------------|------------------------------------------------------| | 1 | | ********** | | | 2 | ;**** | **** | | | 3 | ;**** | uPD6133 Series Transmit ***** | | | 4 | ;**** Tr | ns. CODE: NEC-R Format (80Key) ***** | | | 5 | ;**** | **** | | | 6 | ;****** | ******** | | | 7 01FF | TIM | 9M EQU 1FFH | ;9.00ms (9.002ms) | | 8 | | | | | 9 | ;######### | P U B L I C ######## | | | 10 | ; | | | | 11 | | | | | 12 | ;######### | E X T E R N ######## | | | 13 | EXT | N MAIN | ;MAIN Routine | | 14 | EXT | N KEY80 | Key Check Routine | | 15 | EXT | n fs_27ms | Frame Space Subroutine | | 16 | ; | | | | 17 | | | | | 18 | ;######### | S T A R T ######## | | | 19 | TRNS: | | | | 20 00F8 E6E7 EFE5 | MOV | R7,#0F5H | ;R17 : Set Immediate Data (=0FH) | | 21 | | | Key OFF Check counter (R07) = 10 Times (=05H) | | 22 00FA E6E9 EDEF | MOV | R9,#00FH | ;Data1 Trans counter (R9) = DFH | | 23 | ;****** | ******** | | | 24 | ; | Leader Code | | | 25 | ;****** | ******** | | | 26 00FC E6E0 EAE0 | MOV | RO,#0A0H | ;Data Pointer H (R10) = OAH | | 27 00FE E6E8 E0E8 | MOV | R8,#008H | ;Set Table Address L | | 28 0100 FEE8 | MOV | A,R18 | Output Data (Work) < 00H (R18) | | 29 0101 E6F2 E8F1 E6F1 | CAL | BITOUTOF | | | 30 | | | | | 31 | ;****** | ********** | | | 32 | i | Custom Code | | | 33 | ;****** | ********* | | | 34 0104 E6E8 ECEA | MOV | R8,#0CAH | ;Set Table Address L | | 35 0106 FEE4 | MOV | A,R14 | Output Data (Work) < Custom Code H (R14) | | 36 0107 E6F2 E8F1 E6F6 | CAL | BITOUTOC | | | 37 | | | | | 38 010A FFE4 | MOV | A,R04 | Output Data (Work) < Custom Code H (R04) | | 39 0108 E6F2 E8F1 E6F6 | CAL | BITOUTOC | | | 40 | | | | | 41 | ;****** | ********** | | | 42 | ; | Custom Code' | | | 43 | ;****** | ********** | | | 44 010E FEE5 | MOV | A,R15 | Output Data (Work) < Custom Code' H (R15) | | 45 010F E6F2 E8F1 E6F6 | CAL | BITOUTOC | | | 46 | | | | | 47 0112 FFE5 | MOV | A,R05 | Output Data (Work) < Custom Code' L (R05) | | 48 0113 E6F2 E8F1 E6F6 | CAL | BITOUTOC | | | 49 | | | | | 50 | ;****** | ********** | | | 51 | ; | Custom Code | | | 52 | , | ********** | | | 53 0116 FEE6 | MOV | A,R16 | <pre>;utput Data (Work) &lt; Data Code H (R16)</pre> | | 54 0117 E6F2 E8F1 E6F6 | CAL | BITOUTOC | | | 55 | | | | SOURCE = TRANS80.ASM | E STNO | LOC. | OBJ. | | | MI | SOURCE | STATEME | NT | | | | | | | |--------|--------------|---------|------|------|----|---------|---------|-----------------|---------|-----------|-----------|---------------|--------------------|---------------------| | | 011A | | | | | | MOV | A,R06 | | | | ;Output | t Data (Work) < | Data Code L (R06) | | 57 | 011B | E6F2 | E8F1 | E6F6 | | | CALL | BITOUT | OC . | | | | | | | 58 | | | | | | | | | | | | | | | | 59 | | | | | | ;***** | ***** | ****** | ****** | ****** | ***** | | | | | 60 | | | | | | ; | | Data Co | | | | | | | | 61 | | | | | | ;***** | ***** | ****** | ****** | ****** | ***** | | | | | 62 | 011E | FEE6 | | | | | MOV | A,R16 | | | | ;Output | t Data (Work) < | Data Code H (R16) | | | 011F | | | | | | XRL | A,R17 | | | | ;R17 = | 0FH | | | 64 | 0120 | E6F2 | E8F1 | E6F6 | | | CALL | BITOUT | OC . | | | | | | | 65 | | | | | | | | | | | | | | | | | 0123 | | | | | | MOV | A,R06 | | | | | | Data Code L (R06) | | | 0124 | | | | | | XRL | A,R17 | | | | ;R17 = | 0FH | | | 68 | 0125 | E6F2 | E8F1 | E6F6 | | | CALL | BITOUT | OC . | | | | | | | 69 | | | | | | | | | | | | | | | | 70 | | | | | | ;***** | ****** | | | ****** | ******* | | | | | 71 | | | | | | ; | | Stop B | | | | | | | | 72 | | | | | | ;***** | | | | ****** | ******* | | | | | | 0128 | | E0EE | | | | MOV | R8,#00I | EH | | | | able Address L | | | | 012A | | | | | | MOV | A,R18 | | | | ;Output | t Data (Work) < | 00H (R18) | | | 012B | E6F2 | E8F1 | E6F1 | | | CALL | BITOUT | OF | | | | | | | 76 | | | | | | | | | | | | | | | | 77 | | | | | | , | ***** | | | ****** | ******* | | | | | 78 | | | | | | ; | | Frame S | - | | | | | | | 79 | | ^ | | | | ;***** | | | ***** | ***** | ******* | | | | | | 012E | | | | | | MOV | A,R19 | | | | | | | | | 012F | | D450 | | | | SCAF | mo mm | TD. | | | | Space > 9.00ms ? | | | | 0130 | ECFI | E4FU | | | | JC | T9_UND | ER | | | ; | _ | (More than 9.00ms) | | 83 | | | | | | | | | | | | ; | else | (Less than 9.00ms) | | | 0132 | | | | | | | | | | #005H | HALT 1 | mode (Timer = 00H | ) | | | 0134 | | | | | | | | | MOV | T,#TIME9M | | a | | | | 0136 | E3F1 | EUE5 | | | | | | | STTS | #0101B | Clear | Status Flag | | | 87 | | | | | | | | | | 14017 | 3 700 | | | | | | 0138 | | | | | | | | | MOV | A,R09 | . There are a | C 10 00 | 2 | | | 0139 | | D450 | | | | 70 | mo mm | TD. | RL | A | | Space > 18.00ms | | | | 013A | ECFI | E4FU | | | | JC | T9_UND | ER | | | ; | _ | (Less than 18.00ms) | | 91 | | D0D1 | HORE | | | | | | | 113.T M | #00Ett | ; | else | (More than 18.00ms) | | | 013C<br>013E | | | | | | | | | | #005H | /HALI | mode (Timer = 00H | 1 | | 93 | | LOTI | r/rr | | | | | | | MOV | T,#TIME9M | | | | | 95 | | | | | | TO INTO | n · | | | | | | | | | | 0140 | F3F1 | POPE | | | T9_UNDE | | #0101B | | | | ·alaam | Ctatua Flac | | | | 0140 | | CAUA | | | | STTS | #0101B<br>A,R09 | | | | /CIEdi | Status Flag | | | | 0142 | | P7P0 | | | | ANL | A,#0111 | 1 D | | | | | | | | 0145 | | F/EU | | | | MOV | R00,A | LD | | | | | | | | 0146 | | FOFS | | | | HALT | #005H | | | | : 177.77 | mode (Timer = 00H | 1 | | | 0148 | | EUEJ | | | | MOV | T,@R0 | | | | /1101111 | node (IImel = 0011 | 1 | | | 0149 | | EUEE | | | | STTS | #0101B | | | | ·cloar | Status Flag | | | 102 | | EJFI | EUEJ | | | | 2112 | #01015 | | | | /CICal | Status riay | | | | 014B | EEE3 | | | | | MOV | A,R03 | | | | | | | | | 014C | | | | | | SCAF | 11,1100 | | | | :Conti | nuously pressed k | AV ? | | | 014C | | ESEN | | | | JNC | KEY_ON | | | | ; | else KEY_ON: | (1st. Frame) | | | 014E | | TOLK | | | | 3110 | 1017_OIA | | MOV | A,R07 | ; | then | (Since 2nd. Frame) | | | 0150 | | | | | | | | | SCAF | 11,1001 | | ut input Key ? | (DINCE ZING, FIAME) | | | 0151 | | E1E3 | | | | | | | JNC | KEY80 | ; WICHO | then KEY80: | (With input Key) | | 110 | | ד זיייי | رتيب | | | | | | :** Er- | | = 27ms ** | ; | | (Without input Key) | | 110 | | | | | | | | | , 110 | mic phace | - Z/IIIS | , | CIDC | (wremone rubus vel) | ``` SOURCE = TRANS80.ASM E STNO LOC. OBJ. M I SOURCE STATEMENT 111 0153 EXTRN CALL FS_27MS 112 0156 E2F1 E0E5 HALT #005H ;HALT mode (Timer = 00H) 113 0158 E8F1 E0E0 JMP MATN 114 115 KEY_ON: 116 015A FEE7 MOV A,R17 117 015B E5E3 MOV R03,A ;Continuance Flag (R03) = OFH (R17=OFH) ;** Frame Space = 27ms ** 118 119 015C EXTRN CALL FS 27MS 120 015F E8F1 EFE8 JMP TRNS 121 122 ;**************** 123 ;**** 124 125 ;**** Transmit ;**** **** 126 Subroutine : Bit Out :**** 127 ;*************** 128 129 BITOUTOF: 130 0161 E4EA MOV R1A,A ;Set Output Data (1 Bit Output) 131 0162 FFF1 FFE0 MOV A,#0FH ;Send Bit Counter = 1 Times (=0FH) 132 0164 E8F1 E6F9 JMP BITOUT 133 BITOUTOC: 135 0166 E4EA MOV R1A,A ;Set Output Data (4 Bit Output) 136 0167 FFF1 FCE0 MOV A,#0CH ;Send Bit Counter = 4 Times (=0CH) 137 138 BITOUT: 139 0169 E5EA MOV ROA,A ;Send Bit Counter (ROA) = OCH or OEH or OFH 140 141 016A FEEA MOV A,R1A 142 016B FCF3 RL 143 016C E4EA MOV R1A,A ;Bit Data = 1 ? 144 016D ECF1 E7F3 BIT_DAT1 ; then BIT_DAT1: (Bit Data = 1) 145 ;** Bit Data = 0 ** ; else (Bit Data = 0) 146 016F FFE8 MOV A,R08 ;Set Data Pointer L (R00) <-- Data0 (R08) 147 0170 E5E0 MOV R00.A 148 0171 E8F1 E7FD JMP BIT_TRNS 149 150 ;** Bit Data = 1 **; 151 BIT_DAT1: 152 0173 FEE8 MOV A.R18 ;Set Data Pointer L(ROO) <-- Data1 (R18) 153 0174 E5E0 R00,A MOV 154 0175 FFE9 MOV A,R09 155 0176 F4F3 TNC ;Data 1 Transmit Counter L (R09) increment 156 0177 E5E9 MOV R09.A ;Data 1 Transmit Counter L (R09) = Overflow ? ; else BIT_TRNS: (Data 1 Transmit Counter L <= OFH) 157 0178 EDF1 E7FD JNC BIT_TRNS 158 017A FEE9 MOV A,R19 then (Data 1 Transmit Counter L > 0FH) 159 017B F4F3 INC ;Data 1 Transmit counter H(R19) increment MOV R19,A 160 017C E4E9 161 BIT_TRNS: 162 017D E2F1 E0E5 HALT #005H ;HALT mode (Timer = 00H) 163 017F E7FF MOV T,@R0 164 0180 E3F1 E0E5 STTS #0101B ;Clear Status Flag 165 0182 FFE0 A.R00 MOV ``` SOURCE = TRANS80.ASM | E STNO | LOC. OBJ. | | ΜI | SOURCE : | STATEMENT | Г | | | | | | |--------|-------------|------|----|----------|-----------|--------------|--------|-----------------|---------|---------------------|-------------------------| | 166 | 5 0183 F4F3 | | | | INC | A | | | ;Data P | ointer L (R00) incr | rement | | 16 | 7 0184 E5E0 | | | | MOV | R00,A | | | | | | | 168 | 3 0185 E2F1 | E0E5 | | | HALT | #005H | | | ;HALT m | ode (Timer = 00H) | | | 169 | 0187 E7FF | | | | MOV | T,@R0 | | | | | | | 170 | ) | | | | | | | | | | | | 173 | l 0188 FFE7 | | | | MOV | A,R07 | | | | | | | 172 | 2 0189 F4F3 | | | | INC | A | | | ;Key Of | f Check Counter (RC | 07) increment | | 173 | 3 018A ECF1 | E9F5 | | | | | JC | BIT_TRANS2 | ;Key Of | f Check Counter (RC | 07) = End of 10 Times ? | | 174 | 1 | | | | | | | | ; | then BIT_TRANS2: | (End of 10 Times) | | 175 | 5 | | | | | | | | ; | else | (Less than 10 Times) | | 176 | 5 018C E3F1 | E0EE | | | STTS | #1110B | | | ;With i | nput key ? | | | 177 | 7 018E EFF1 | E9F4 | | | JNF | BIT_TRANS1 | | | ; | else BIT_TRANS1: | (With input) | | 178 | 3 | | | | | | ;** Wi | th input key ** | ; | then | (Without input) | | 179 | 9 0190 E6E7 | EFE5 | | | | | MOV | R7, #0F5H | ;Key of | f Check Counter (RC | 07) = 05H | | 180 | 0192 E8F1 | E9F5 | | | | | JMP | BIT_TRANS2 | | | | | 183 | l | | | | | | ; | | | | | | 182 | 2 | | | ;** | Without | input Key ** | | | | | | | 183 | 3 | | | BIT_TRAI | NS1: | | | | | | | | 184 | 4 0194 E5E7 | | | | MOV | R07,A | | | | | | | 185 | 5 | | | | | | | | | | | | 186 | 5 | | | BIT_TRAI | NS2: | | | | | | | | 18' | 7 0195 E3F1 | E0E5 | | | STTS | #0101B | | | ;Clear | Status Falg | | | 188 | 3 0197 FFEA | | | | MOV | A,ROA | | | | | | | 189 | 0198 F4F3 | | | | INC | A | | | ;Send B | it Counter (ROA) ir | ncrement | | 190 | 0199 EDF1 | E6F9 | | | JNC | BITOUT | | | | | | | 193 | l 019B E8F2 | | | | RET | | | | | | | | 192 | 2 | | | | ; | | | | | | | | 193 | 3 | | | END | | | | | | | | | | | | | | | | | | | | | TOTAL ERRORS = 0 TOTAL WARNINGS = 0 END OF LIST SOURCE = DTABLE80 TBL ``` M I SOURCE STATEMENT E STNO LOC. OBJ. ;************** 1 :**** 2 uPD6133 Series Data Table ***** 3 ;***** Trans. CODE: NEC-R Format (80Key) ***** 4 ;**** ;*************** 7 01FF TIME9M EQU 1FFH ;9.00ms (9.002ms) 8 9 ;######### P U B L I C ######### DATACODE 10 PUBLIC 11 PUBLIC FS_27MS 12 13 14 DATACODE: ;********* 15 16 ;**** Data Code 17 Double Key ;********* 18 19 019D ORG 19DH 20 ;** K29 + K30 ** 21 019D E0E9 DW 009H ;K29 + K30 : Key Data = 70H ;** K29 + K31 ** 22 DW 089H 23 019E E8E9 ;K29 + K31 : Key Data = 71H ;** K29 + K32 ** 24 25 019F E4E9 DW 049H ;K29 + K32 : Key Data = 72H 26 2.7 ;************ 28 ;**** Frame Space ;**** Time Data 29 30 Time Data 31 1F4H 32 01A0 E7ED ;Counter:000 = 8.815ms (8.809ms) DT 33 01A1 E6ED DT 1B4H ;Counter:001 = 7.690ms (7.683ms) 34 01A2 E5ED DT 174H ;Counter:010 = 6.565ms (6.558ms) 35 01A3 E4ED DT 134H ;Counter:011 = 5.440ms (5.433ms) ;Counter:100 = 4.315ms (4.308ms) 36 01A4 E3ED DT 0F4H ;Counter:101 = 3.190ms (3.182ms) DT 0B4H 37 01A5 E2ED ;Counter:110 = 2.065ms (2.057ms) DT 38 01A6 E1ED 074H 39 01A7 E0ED DT 034H ;Counter:111 = 0.940ms (0.932ms) 40 41 ;*********** 42 43 ;**** Time Data 44 45 ;** Leader Code ** Carrier ON : 9.000ms (9.002ms) 46 01A8 FFFF DT 3FFH 47 01A9 F3FF DT 0FFH (Carrier OFF : 4.500ms (4.501ms) ;** Bit data 0 ** 49 01AA F8F7 DT 21FH ;Carrier ON : 0.560ms (0.563ms) DT 01FH 50 01AB F0F7 Carrier OFF : 0.565ms (0.563ms) ;** Bit data 1 ** 51 52 01AC F8F7 DT 21FH ;Carrier ON : 0.560ms (0.563ms) 53 01AD F1F7 DT 05FH Carrier OFF : 1.690ms (1.687ms) ;** Stop Bit ** 54 55 01AE F8F7 DT 21FH ;Carrier ON : 0.560ms (0.563ms) ``` SOURCE = DTABLE80.TBL | F | STNO | TOC | ∩р.т | М | т | SULLINGE | STATEME | NTT | | |----|------|------|------|-----|---|----------|----------|-----------|---------------------------------| | 10 | | 01AF | | 111 | _ | DOORCE | DT | 0A9H | ;Carrier OFF : 3.00ms (2.989ms) | | | 57 | ULAF | LZFA | | | | ; | UAJII | /Calllet Off · 3.00ms (2.969ms) | | | 58 | | | | | | , | | | | | 59 | | | | | ;**** | ***** | ****** | ****** | | | 60 | | | | | ;**** | | Data Code | **** | | | 61 | | | | | ;**** | | Single Ke | | | | 62 | | | | | ;**** | ****** | - | ********* | | | | 01B0 | | | | ORG | 1B0H | | | | | 64 | | | | | ;** I | K33 - K4 | 0 ** | | | | 65 | 01B0 | E0E4 | | | | DW | 004H | ;K33 : Data Code = 20H | | | 66 | 01B1 | E8E4 | | | | DW | 084H | ;K34 : Data Code = 21H | | | 67 | 01B2 | E4E4 | | | | DW | 044H | ;K35 : Data Code = 22H | | | 68 | 01B3 | ECE4 | | | | DW | 0C4H | ;K36 : Data Code = 23H | | | 69 | 01B4 | E2E4 | | | | DW | 024H | ;K37 : Data Code = 24H | | | 70 | 01B5 | EAE4 | | | | DW | 0A4H | ;K38 : Data Code = 25H | | | 71 | 01B6 | E6E4 | | | | DW | 064H | ;K39 : Data Code = 26H | | | 72 | 01B7 | EEE4 | | | | DW | 0E4H | ;K40 : Data Code = 27H | | | 73 | | | | | | ; | | | | | 74 | | | | | ;** ] | K73 + K8 | 0 ** | | | | 75 | 01B8 | E1E2 | | | | DW | 012H | ;K73 : Data Code = 48H | | | 76 | 01B9 | E9E2 | | | | DW | 092H | ;K74 : Data Code = 49H | | | 77 | 01BA | E5E2 | | | | DW | 052H | ;K75 : Data Code = 4AH | | | 78 | 01BB | EDE2 | | | | DW | 0D2H | ;K76 : Data Code = 4BH | | | 79 | 01BC | E3E2 | | | | DW | 032H | ;K77 : Data Code = 4CH | | | 80 | 01BD | EBE2 | | | | DW | 0B2H | ;K78 : Data Code = 4DH | | | 81 | 01BE | E7E2 | | | | DW | 072H | ;K79 : Data Code = 4EH | | | 82 | 01BF | EFE2 | | | | DW | 0F2H | ;K80 : Data Code = 4FH | | | 83 | | | | | | ; | | | | | 84 | | | | | | | | | | | 85 | 01C0 | | | | ORG | 1COH | | | | | 86 | | | | | ;** I | K1 - K16 | ** | | | | 87 | 01C0 | E0E0 | | | | DW | 000H | ;K 1 : Data Code = 00H | | | 88 | 01C1 | E8E0 | | | | DW | 080H | ;K 2 : Data Code = 01H | | | 89 | 01C2 | E4E0 | | | | DW | 040H | ;K 3 : Data Code = 02H | | | 90 | 01C3 | ECE0 | | | | DW | 0C0H | ;K 4 : Data Code = 03H | | | 91 | 01C4 | E2E0 | | | | DW | 020H | ;K 5 : Data Code = 04H | | | 92 | 01C5 | EAE0 | | | | DW | 0A0H | ;K 6 : Data Code = 05H | | | 93 | 01C6 | E6E0 | | | | DW | 060H | ;K 7 : Data Code = 06H | | | 94 | 01C7 | EEE0 | | | | DW | 0E0H | ;K 8 : Data Code = 07H | | | 95 | 01C8 | E1E0 | | | | DW | 010H | ;K 9 : Data Code = 08H | | | 96 | 01C9 | E9E0 | | | | DW | 090H | ;K10 : Data Code = 09H | | | 97 | 01CA | E5E0 | | | | DW | 050H | ;K11 : Data Code = OAH | | | 98 | 01CB | EDE0 | | | | DW | 0D0H | ;K12 : Data Code = OBH | | | 99 | 01CC | E3E0 | | | | DW | 030H | ;K13 : Data Code = OCH | | | 100 | 01CD | EBE0 | | | | DW | 0B0H | ;K14 : Data Code = ODH | | | 101 | 01CE | E7E0 | | | | DW | 070H | ;K15 : Data Code = OEH | | | 102 | 01CF | EFE0 | | | | DW | 0F0H | ;K16 : Data Code = OFH | | | 103 | | | | | | ; | | | | | 104 | | | | | ;** I | K17 - K3 | 2 ** | | | | 105 | 01D0 | E0E8 | | | | DW | 008H | ;K17 : Data Code = 10H | | | 106 | 01D1 | E8E8 | | | | DW | 088H | ;K18 : Data Code = 11H | | | 107 | 01D2 | E4E8 | | | | DW | 048H | ;K19 : Data Code = 12H | | | 108 | 01D3 | ECE8 | | | | DW | 0C8H | ;K20 : Data Code = 13H | | | 109 | 01D4 | E2E8 | | | | DW | 028H | ;K21 : Data Code = 14H | | | 110 | 01D5 | EAE8 | | | | DW | 0A8H | ;K22 : Data Code = 15H | | | | | | | | | | | | SOURCE = DTABLE80.TBL | E STNO | T 00 | OD T | М | т | COIDOR CTATEME | NITI | | | |--------|------|------|-----|---|----------------|--------------|----------|------------------------------------| | | 01D6 | | IVI | 1 | SOURCE STATEME | 068H | ·v12 · | Data Code = 16H | | | 01D0 | | | | DW<br>DW | 0E8H | | Data Code = 10H<br>Data Code = 17H | | | 01D7 | | | | DW | 018H | | Data Code = 17H | | | 01D0 | | | | DW | 018H | | Data Code = 19H | | | 01DA | | | | DW | 058H | | Data Code = 13H | | | 01DB | | | | DW | OD8H | | Data Code = 1BH | | | 01DC | | | | DW | 038H | | Data Code = 1CH | | | 01DD | | | | DW | 0B8H | | Data Code = 1DH | | | 01DE | | | | DW | 078H | | Data Code = 1EH | | | 01DF | | | | DW | OF8H | | Data Code = 1FH | | 121 | | | | | ; | | | | | 122 | | | | | ;** K41 - K5 | 6 ** | | | | 123 | 01E0 | E1E4 | | | DW | 014H | ;K41 : | Data Code = 28H | | 124 | 01E1 | E9E4 | | | DW | 094H | ;K42 : | Data Code = 29H | | 125 | 01E2 | E5E4 | | | DW | 054H | ;K43 : | Data Code = 2AH | | 126 | 01E3 | EDE4 | | | DW | 0D4H | ;K44 : | Data Code = 2BH | | 127 | 01E4 | E3E4 | | | DW | 034H | ;K45 : | Data Code = 2CH | | 128 | 01E5 | EBE4 | | | DW | 0B4H | ;K46 : | Data Code = 2DH | | 129 | 01E6 | E7E4 | | | DW | 074H | ;K47 : | Data Code = 2EH | | 130 | 01E7 | EFE4 | | | DW | 0F4H | ;K48 : | Data Code = 2FH | | 131 | 01E8 | EOEC | | | DW | 00CH | ;K49 : | Data Code = 30H | | 132 | 01E9 | E8EC | | | DW | 08CH | ;K50 : | Data Code = 31H | | 133 | 01EA | E4EC | | | DW | 04CH | ;K51 : | Data Code = 32H | | 134 | 01EB | ECEC | | | DW | 0CCH | ;K52 : | Data Code = 33H | | 135 | 01EC | E2EC | | | DW | 02CH | ;K53 : | Data Code = 34H | | 136 | 01ED | EAEC | | | DW | 0ACH | ;K54 : | Data Code = 35H | | 137 | 01EE | E6EC | | | DW | 06CH | ;K55 : | Data Code = 36H | | 138 | 01EF | EEEC | | | DW | 0ECH | ;K56 : | Data Code = 37H | | 139 | | | | | ; | | | | | 140 | | | | | ;** K57 - K7 | 2 ** | | | | 141 | 01F0 | E1EC | | | DW | 01CH | ;K57 : | Data Code = 38H | | 142 | 01F1 | E9EC | | | DW | 09CH | ;K58 : | Data Code = 39H | | 143 | 01F2 | E5EC | | | DW | 05CH | ;K59 : | Data Code = 3AH | | 144 | 01F3 | EDEC | | | DW | 0DCH | ;K60 : | Data Code = 3BH | | 145 | 01F4 | E3EC | | | DW | 03CH | ;K61 : | Data Code = 3CH | | 146 | 01F5 | EBEC | | | DW | 0BCH | ;K62 : | Data Code = 3DH | | 147 | 01F6 | E7EC | | | DW | 07CH | ;K63 : | Data Code = 3EH | | 148 | 01F7 | EFEC | | | DW | 0FCH | ;K64 : | Data Code = 3FH | | 149 | 01F8 | E0E2 | | | DW | 002H | ;K65 : | Data Code = 40H | | | 01F9 | | | | DW | 082H | | Data Code = 41H | | 151 | 01FA | E4E2 | | | DW | 042H | | Data Code = 42H | | | 01FB | | | | DW | 0C2H | | Data Code = 43H | | | 01FC | | | | DW | 022H | | Data Code = 44H | | | 01FD | | | | DW | 0A2H | | Data Code = 45H | | | 01FE | | | | DW | 062H | | Data Code = 46H | | | 01FF | EEE2 | | | DW | 0E2H | ;K72 : | Data Code = 47H | | 157 | | | | | i | | | | | 158 | | | | | | | | | | 159 | | | | | | | | | | 160 | | | | | | | | | | 161 | | | | | ;********* | ********** | ******** | | | 162 | | | | | ;***** | | | **** | | 163 | | | | | ;**** | Frame Space | | **** | | 164 | | | | | ;**** | Subroutine : | FS 27ms | **** | | 165 | | | | | ;**** | | | **** | SOURCE = DTABLE80.TBL E STNO LOC. OBJ. M I SOURCE STATEMENT ;\*\*\*\*\*\*\*\*\*\*\*\*\* 167 FS\_27MS: 168 0200 FFF1 FDE0 MOV A,#00H ;Counter(Acc) = 3 Times (=0DH) 169 FS\_27MS0: 170 0202 E2F1 E0E5 HALT #005H ;HALT mode (Timer = 00H) 171 0204 E6FF F7FF MOV T,#TIME9M Timer = 9.00ms 172 0206 E3F1 E0E5 STTS #0101B ;Status Flag Clear 173 0208 F4F3 INC A ;More than 27ms ? 174 0209 EDF1 F0E2 ; else FS\_27MSO: (Frame Space < 27ms) JNC FS\_27MS0 175 020B E8F2 RET ; then RET (Frame Space = 27ms) 176 END 177 TOTAL ERRORS = 0 TOTAL WARNINGS = 0 END OF LIST # **CHAPTER 9 PROGRAM LIST** AS6133 V1.01 << D6134 ASSEMBLE LIST >> 01:00:01 08/29/96 PAGE 05-002 SOURCE = OPTION.ASM TOTAL ERRORS = 0 TOTAL WARNINGS = 0 END OF LIST # Facsimile Message | From: | Message | Although NEC has taken all possible steps to ensure that the documentation supplied to our customers is complete, bug free and up-to-date, we readily accept tha errors may occur. Despite all the care and precautions we've taken, you may | | | | | | |------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--|--|--|--| | Name | | encounter problems in<br>Please complete the | n the documentation.<br>his form whenever | | | | | | Company | | you'd like to report improvements to us. | | | | | | | Tel. | FAX | | | | | | | | Address | | | | | | | | | | | Thank you for yo | ur kind support. | | | | | | North America NEC Electronics Inc. Corporate Communications Dept. Fax: 1-800-729-9288 1-408-588-6130 | Hong Kong, Philippines, Oceania<br>NEC Electronics Hong Kong Ltd.<br>Fax: +852-2886-9022/9044 | Asian Nations except P<br>NEC Electronics Singapo<br>Fax: +65-250-3583 | | | | | | | Europe NEC Electronics (Europe) GmbH Technical Documentation Dept. Fax: +49-211-6503-274 | Korea<br>NEC Electronics Hong Kong Ltd.<br>Seoul Branch<br>Fax: 02-528-4411 | Japan NEC Corporation Semiconductor Solution Engineering Division Technical Information Support Dept. Fax: 044-548-7900 | | | | | | | South America<br>NEC do Brasil S.A.<br>Fax: +55-11-6465-6829 | <b>Taiwan</b> NEC Electronics Taiwan Ltd. Fax: 02-719-5951 | 1 dx. 011 0 10 7000 | | | | | | | would like to report the follo | wing error/make the following s | suggestion: | | | | | | | Document title: | | | | | | | | | | | Dago numbor: | | | | | | | Document number: | | Page number: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | f possible, please fax the ref | erenced page or drawing. | | | | | | | | Document Rating | Excellent Good | Acceptable | Poor | | | | | | Clarity | | | | | | | | | Technical Accuracy | | | | | | | | Organization