Renesas HD64F2552 Renesas 16-bit single-chip microcomputer h8s family/h8s/2500 sery Datasheet

To our customers,
Old Company Name in Catalogs and Other Documents
On April 1st, 2010, NEC Electronics Corporation merged with Renesas Technology
Corporation, and Renesas Electronics Corporation took over all the business of both
companies. Therefore, although the old company name remains in this document, it is a valid
Renesas Electronics document. We appreciate your understanding.
Renesas Electronics website: http://www.renesas.com
April 1st, 2010
Renesas Electronics Corporation
Issued by: Renesas Electronics Corporation (http://www.renesas.com)
Send any inquiries to http://www.renesas.com/inquiry.
Notice
1.
2.
3.
4.
5.
6.
7.
All information included in this document is current as of the date this document is issued. Such information, however, is
subject to change without any prior notice. Before purchasing or using any Renesas Electronics products listed herein, please
confirm the latest product information with a Renesas Electronics sales office. Also, please pay regular and careful attention to
additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website.
Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights
of third parties by or arising from the use of Renesas Electronics products or technical information described in this document.
No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights
of Renesas Electronics or others.
You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part.
Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of
semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software,
and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by
you or third parties arising from the use of these circuits, software, or information.
When exporting the products or technology described in this document, you should comply with the applicable export control
laws and regulations and follow the procedures required by such laws and regulations. You should not use Renesas
Electronics products or the technology described in this document for any purpose relating to military applications or use by
the military, including but not limited to the development of weapons of mass destruction. Renesas Electronics products and
technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited
under any applicable domestic or foreign laws or regulations.
Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics
does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages
incurred by you resulting from errors in or omissions from the information included herein.
Renesas Electronics products are classified according to the following three quality grades: “Standard”, “High Quality”, and
“Specific”. The recommended applications for each Renesas Electronics product depends on the product’s quality grade, as
indicated below. You must check the quality grade of each Renesas Electronics product before using it in a particular
application. You may not use any Renesas Electronics product for any application categorized as “Specific” without the prior
written consent of Renesas Electronics. Further, you may not use any Renesas Electronics product for any application for
which it is not intended without the prior written consent of Renesas Electronics. Renesas Electronics shall not be in any way
liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an
application categorized as “Specific” or for which the product is not intended where you have failed to obtain the prior written
consent of Renesas Electronics. The quality grade of each Renesas Electronics product is “Standard” unless otherwise
expressly specified in a Renesas Electronics data sheets or data books, etc.
“Standard”:
8.
9.
10.
11.
12.
Computers; office equipment; communications equipment; test and measurement equipment; audio and visual
equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots.
“High Quality”: Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anticrime systems; safety equipment; and medical equipment not specifically designed for life support.
“Specific”:
Aircraft; aerospace equipment; submersible repeaters; nuclear reactor control systems; medical equipment or
systems for life support (e.g. artificial life support devices or systems), surgical implantations, or healthcare
intervention (e.g. excision, etc.), and any other applications or purposes that pose a direct threat to human life.
You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics,
especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation
characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or
damages arising out of the use of Renesas Electronics products beyond such specified ranges.
Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have
specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further,
Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to
guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a
Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire
control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because
the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system
manufactured by you.
Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental
compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable
laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS
Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with
applicable laws and regulations.
This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written consent of Renesas
Electronics.
Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this
document or Renesas Electronics products, or if you have any other inquiries.
(Note 1) “Renesas Electronics” as used in this document means Renesas Electronics Corporation and also includes its majorityowned subsidiaries.
(Note 2) “Renesas Electronics product(s)” means any product developed or manufactured by or for Renesas Electronics.
User’s Manual
16
The revision list can be viewed directly by clicking the title page.
The revision list summarizes the locations of revisions and
additions. Details should always be checked by referring to the
relevant text.
H8S/2556 Group,
H8S/2552 Group,
H8S/2506 Group
Hardware Manual
Renesas 16-Bit Single-Chip
Microcomputer
H8S Family/H8S/2500 Series
H8S/2556
H8S/2552
H8S/2551
H8S/2506
H8S/2505
HD64F2556
HD64F2552
HD64F2551
HD64F2506
HD64F2505
Rev.6.00 2009.09
Notes regarding these materials
1. This document is provided for reference purposes only so that Renesas customers may select the appropriate
Renesas products for their use. Renesas neither makes warranties or representations with respect to the
accuracy or completeness of the information contained in this document nor grants any license to any
intellectual property rights or any other rights of Renesas or any third party with respect to the information in
this document.
2. Renesas shall have no liability for damages or infringement of any intellectual property or other rights arising
out of the use of any information in this document, including, but not limited to, product data, diagrams, charts,
programs, algorithms, and application circuit examples.
3. You should not use the products or the technology described in this document for the purpose of military
applications such as the development of weapons of mass destruction or for the purpose of any other military
use. When exporting the products or technology described herein, you should follow the applicable export
control laws and regulations, and procedures required by such laws and regulations.
4. All information included in this document such as product data, diagrams, charts, programs, algorithms, and
application circuit examples, is current as of the date this document is issued. Such information, however, is
subject to change without any prior notice. Before purchasing or using any Renesas products listed in this
document, please confirm the latest product information with a Renesas sales office. Also, please pay regular
and careful attention to additional and different information to be disclosed by Renesas such as that disclosed
through our website. (http://www.renesas.com )
5. Renesas has used reasonable care in compiling the information included in this document, but Renesas
assumes no liability whatsoever for any damages incurred as a result of errors or omissions in the information
included in this document.
6. When using or otherwise relying on the information in this document, you should evaluate the information in
light of the total system before deciding about the applicability of such information to the intended application.
Renesas makes no representations, warranties or guaranties regarding the suitability of its products for any
particular application and specifically disclaims any liability arising out of the application and use of the
information in this document or Renesas products.
7. With the exception of products specified by Renesas as suitable for automobile applications, Renesas
products are not designed, manufactured or tested for applications or otherwise in systems the failure or
malfunction of which may cause a direct threat to human life or create a risk of human injury or which require
especially high quality and reliability such as safety systems, or equipment or systems for transportation and
traffic, healthcare, combustion control, aerospace and aeronautics, nuclear power, or undersea communication
transmission. If you are considering the use of our products for such purposes, please contact a Renesas
sales office beforehand. Renesas shall have no liability for damages arising out of the uses set forth above.
8. Notwithstanding the preceding paragraph, you should not use Renesas products for the purposes listed below:
(1) artificial life support devices or systems
(2) surgical implantations
(3) healthcare intervention (e.g., excision, administration of medication, etc.)
(4) any other purposes that pose a direct threat to human life
Renesas shall have no liability for damages arising out of the uses set forth in the above and purchasers who
elect to use Renesas products in any of the foregoing applications shall indemnify and hold harmless Renesas
Technology Corp., its affiliated companies and their officers, directors, and employees against any and all
damages arising out of such applications.
9. You should use the products described herein within the range specified by Renesas, especially with respect
to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation
characteristics, installation and other product characteristics. Renesas shall have no liability for malfunctions or
damages arising out of the use of Renesas products beyond such specified ranges.
10. Although Renesas endeavors to improve the quality and reliability of its products, IC products have specific
characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use
conditions. Please be sure to implement safety measures to guard against the possibility of physical injury, and
injury or damage caused by fire in the event of the failure of a Renesas product, such as safety design for
hardware and software including but not limited to redundancy, fire control and malfunction prevention,
appropriate treatment for aging degradation or any other applicable measures. Among others, since the
evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or
system manufactured by you.
11. In case Renesas products listed in this document are detached from the products to which the Renesas
products are attached or affixed, the risk of accident such as swallowing by infants and small children is very
high. You should implement safety measures so that Renesas products may not be easily detached from your
products. Renesas shall have no liability for damages arising out of such detachment.
12. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written
approval from Renesas.
13. Please contact a Renesas sales office if you have any questions regarding the information contained in this
document, Renesas semiconductor products, or if you have any other inquiries.
Rev. 6.00 Sep. 24, 2009 Page ii of xlvi
REJ09B0099-0600
General Precautions in the Handling of MPU/MCU Products
The following usage notes are applicable to all MPU/MCU products from Renesas. For detailed usage notes
on the products covered by this manual, refer to the relevant sections of the manual. If the descriptions under
General Precautions in the Handling of MPU/MCU Products and in the body of the manual differ from each
other, the description in the body of the manual takes precedence.
1. Handling of Unused Pins
Handle unused pins in accord with the directions given under Handling of Unused Pins in
the manual.
⎯ The input pins of CMOS products are generally in the high-impedance state. In
operation with an unused pin in the open-circuit state, extra electromagnetic noise is
induced in the vicinity of LSI, an associated shoot-through current flows internally, and
malfunctions may occur due to the false recognition of the pin state as an input signal.
Unused pins should be handled as described under Handling of Unused Pins in the
manual.
2. Processing at Power-on
The state of the product is undefined at the moment when power is supplied.
⎯ The states of internal circuits in the LSI are indeterminate and the states of register
settings and pins are undefined at the moment when power is supplied.
In a finished product where the reset signal is applied to the external reset pin, the
states of pins are not guaranteed from the moment when power is supplied until the
reset process is completed.
In a similar way, the states of pins in a product that is reset by an on-chip power-on
reset function are not guaranteed from the moment when power is supplied until the
power reaches the level at which resetting has been specified.
3. Prohibition of Access to Reserved Addresses
Access to reserved addresses is prohibited.
⎯ The reserved addresses are provided for the possible future expansion of functions. Do
not access these addresses; the correct operation of LSI is not guaranteed if they are
accessed.
4. Clock Signals
After applying a reset, only release the reset line after the operating clock signal has
become stable. When switching the clock signal during program execution, wait until the
target clock signal has stabilized.
⎯ When the clock signal is generated with an external resonator (or from an external
oscillator) during a reset, ensure that the reset line is only released after full stabilization
of the clock signal. Moreover, when switching to a clock signal produced with an
external resonator (or by an external oscillator) while program execution is in progress,
wait until the target clock signal is stable.
5. Differences between Products
Before changing from one product to another, i.e. to one with a different type number,
confirm that the change will not lead to problems.
⎯ The characteristics of MPU/MCU in the same group but having different type numbers
may differ because of the differences in internal memory capacity and layout pattern.
When changing to products of different type numbers, implement a system-evaluation
test for each of the products.
Rev. 6.00 Sep. 24, 2009 Page iii of xlvi
REJ09B0099-0600
Configuration of This Manual
This manual comprises the following items:
1.
2.
3.
4.
5.
6.
General Precautions in the Handling of MPU/MCU Products
Configuration of This Manual
Preface
Contents
Overview
Description of Functional Modules
• CPU and System-Control Modules
• On-Chip Peripheral Modules
The configuration of the functional description of each module differs according to the
module. However, the generic style includes the following items:
i) Feature
ii) Input/Output Pin
iii) Register Description
iv) Operation
v) Usage Note
When designing an application system that includes this LSI, take notes into account. Each section
includes notes in relation to the descriptions given, and usage notes are given, as required, as the
final part of each section.
7. List of Registers
8. Electrical Characteristics
9. Appendix
10. Main Revisions for This Edition (only for revised versions)
The list of revisions is a summary of points that have been revised or added to earlier versions.
This does not include all of the revised contents. For details, see the actual locations in this
manual.
11. Index
Rev. 6.00 Sep. 24, 2009 Page iv of xlvi
REJ09B0099-0600
Preface
This LSI is a high-performance microcomputer made up of the H8S/2000 CPU with an internal
32-bit configuration as its core, and the peripheral functions required to configure a system.
A single-power flash memory (F-ZTATTM)*1 version is available for this LSI’s ROM. The F-ZTAT
version provides flexibility as it can be reprogrammed in no time to cope with all situations from
the early stages of mass production to full-scale mass production. This is particularly applicable to
application devices with specifications that will most probably change. The on-chip peripheral
functions for each of the group are shown below.
List of on-chip peripheral functions:
Group Name
H8S/2556 Group
H8S/2552 Group
H8S/2506 Group
H8S/2552
H8S/2506
Product Name
H8S/2556
H8S/2551
H8S/2505
Bus controller
O (16 bits)
O (16 bits)
O (16 bits)
Data transfer controller (DTC)
O
O
O
PC break controller (PBC)
O
O
O
16-bit timer pulse unit (TPU)
×6
×6
×6
8-bit timer (TMR)
×4
×4
×4
Watch dog timer (WDT)
×2
×2
×2
Serial communication interface (SCI)
×5
×5
×5
×2
×2
×2
IEBus * controller (IEB)
⎯
×1
⎯
Controller area network (HCAN)
×1
⎯
⎯
D/A converter
×2
×2
×2
A/D converter
× 16
× 16
× 16
2
I C bus interface 2 (IIC2)
TM 2
Notes: 1. F-ZTAT is a trademark of Renesas Technology Corp.
2. IEBus is a trademark of NEC Electronics Corporation.
Rev. 6.00 Sep. 24, 2009 Page v of xlvi
REJ09B0099-0600
Target Users: This manual was written for users who will be using the H8S/2556 Group,
H8S/2552 Group, and H8S/2506 Group in the design of application systems.
Target users are expected to understand the fundamentals of electrical circuits,
logical circuits, and microcomputers.
Objective:
This manual was written to explain the hardware functions and electrical
characteristics of the H8S/2556 Group, H8S/2552 Group, and H8S/2506 Group.
Refer to the H8S/2600 Series, H8S/2000 Series Software Manual for a detailed
description of the instruction set.
Notes on reading this manual:
• In order to understand the overall functions of the chip
Read the manual according to the contents. This manual can be roughly categorized into parts
on the CPU, system control functions, peripheral functions and electrical characteristics.
• In order to understand the details of the CPU's functions
Read the H8S/2600 Series, H8S/2000 Series Software Manual.
• In order to understand the details of a register when its name is known
Read the index that is the final part of the manual to find the page number of the entry on the
register. The addresses, bits, and initial values of the registers are summarized in section 23,
List of Registers.
Examples: Register name:
The following notation is used for cases when the same or a
similar function, e.g. 16-bit timer pulse unit or serial
communication, is implemented on more than one channel:
XXX_N (XXX is the register name and N is the channel
number)
Bit order:
The MSB is on the left and the LSB is on the right.
Number notation: Binary is B'xxxx, hexadecimal is H'xxxx, decimal is xxxx.
Signal notation:
An overbar is added to a low-active signal: xxxx
Related Manuals: The latest versions of all related manuals are available from our web site. Please
ensure you have the latest versions of all documents you require.
http://www.renesas.com/
Rev. 6.00 Sep. 24, 2009 Page vi of xlvi
REJ09B0099-0600
H8S/2556, H8S/2552, H8S/2506 manuals:
Document Title
Document No.
H8S/2556, H8S/2552, H8S/2506 Group Hardware Manual
This manual
H8S/2600 Series, H8S/2000 Series Software Manual
REJ09B0139
User's manuals for development tools:
Document Title
Document No.
H8S, H8/300 Series C/C++ Compiler, Assembler, Optimized Linkage Editor
Compiler Package Ver.6.01 User's Manual
REJ10B0161
H8S, H8/300 Series Simulator/Debugger User's Manual
REJ10B0211
H8S, H8/300 Series High-performance Embedded Workshop User's Manual REJ10J2000
Rev. 6.00 Sep. 24, 2009 Page vii of xlvi
REJ09B0099-0600
All trademarks and registered trademarks are the property of their respective owners.
Rev. 6.00 Sep. 24, 2009 Page viii of xlvi
REJ09B0099-0600
Contents
Section 1 Overview..................................................................................................1
1.1
1.2
1.3
Features.................................................................................................................................. 1
Internal Block Diagram.......................................................................................................... 2
Pin Arrangements................................................................................................................... 6
1.3.1 Pin Arrangements ..................................................................................................... 6
1.3.2 Pin Arrangements in Each mode............................................................................. 11
1.3.3 Pin Functions .......................................................................................................... 17
Section 2 CPU........................................................................................................25
2.1
2.2
2.3
2.4
2.5
2.6
2.7
Features................................................................................................................................ 25
2.1.1 Differences between H8S/2600 CPU and H8S/2000 CPU ..................................... 26
2.1.2 Differences from H8/300 CPU ............................................................................... 27
2.1.3 Differences from H8/300H CPU............................................................................. 27
CPU Operating Modes......................................................................................................... 28
2.2.1 Normal Mode.......................................................................................................... 28
2.2.2 Advanced Mode...................................................................................................... 29
Address Space...................................................................................................................... 32
Register Configuration......................................................................................................... 33
2.4.1 General Registers.................................................................................................... 34
2.4.2 Program Counter (PC) ............................................................................................ 35
2.4.3 Extended Control Register (EXR) .......................................................................... 35
2.4.4 Condition-Code Register (CCR)............................................................................. 36
2.4.5 Initial Values of CPU Registers .............................................................................. 37
Data Formats........................................................................................................................ 38
2.5.1 General Register Data Formats ............................................................................... 38
2.5.2 Memory Data Formats ............................................................................................ 40
Instruction Set ...................................................................................................................... 40
2.6.1 Table of Instructions Classified by Function .......................................................... 42
2.6.2 Basic Instruction Formats ....................................................................................... 51
Addressing Modes and Effective Address Calculation........................................................ 52
2.7.1 Register Direct⎯Rn ............................................................................................... 53
2.7.2 Register Indirect⎯@ERn ....................................................................................... 53
2.7.3 Register Indirect with Displacement⎯@(d:16, ERn) or @(d:32, ERn)................. 53
2.7.4 Register Indirect with Post-Increment or Pre-Decrement⎯@ERn+ or @-ERn..... 53
2.7.5 Absolute Address⎯@aa:8, @aa:16, @aa:24, or @aa:32....................................... 54
2.7.6 Immediate⎯#xx:8, #xx:16, or #xx:32.................................................................... 54
Rev. 6.00 Sep. 24, 2009 Page ix of xlvi
REJ09B0099-0600
2.8
2.9
2.7.7 Program-Counter Relative⎯@(d:8, PC) or @(d:16, PC) ...................................... 55
2.7.8 Memory Indirect⎯@@aa:8 ................................................................................... 55
2.7.9 Effective Address Calculation ................................................................................ 56
Processing States.................................................................................................................. 59
Usage Notes ......................................................................................................................... 61
2.9.1 TAS Instruction ...................................................................................................... 61
2.9.2 STM/LDM Instruction............................................................................................ 61
2.9.3 Bit Manipulation Instructions ................................................................................. 61
2.9.4 Access Method for Registers with Write-Only Bits ............................................... 63
Section 3 MCU Operating Modes ......................................................................... 67
3.1
3.2
3.3
3.4
Operating Mode Selection ................................................................................................... 67
Register Descriptions........................................................................................................... 68
3.2.1 Mode Control Register (MDCR) ............................................................................ 68
3.2.2 System Control Register (SYSCR)......................................................................... 68
Operating Mode ................................................................................................................... 70
3.3.1 Mode 6.................................................................................................................... 70
3.3.2 Mode 7.................................................................................................................... 70
3.3.3 Pin Functions .......................................................................................................... 70
Address Map in Each Operating Mode................................................................................ 72
Section 4 Exception Handling ............................................................................... 75
4.1
4.2
4.3
4.4
4.5
4.6
4.7
4.8
Exception Handling Types and Priority............................................................................... 75
Exception Sources and Exception Vector Table .................................................................. 75
Reset .................................................................................................................................... 77
4.3.1 Types of Reset ........................................................................................................ 77
4.3.2 Reset Exception Handling ...................................................................................... 78
4.3.3 Interrupts after Reset............................................................................................... 79
4.3.4 State of On-Chip Peripheral Modules after Reset Release ..................................... 79
Trace Exception Handling ................................................................................................... 79
Interrupt Exception Handling .............................................................................................. 80
Trap Instruction Exception Handling................................................................................... 80
Stack State after Exception Handling .................................................................................. 82
Usage Note........................................................................................................................... 82
Section 5 Interrupt Controller................................................................................ 85
5.1
5.2
5.3
Features................................................................................................................................ 85
Input/Output Pins................................................................................................................. 87
Register Descriptions........................................................................................................... 88
5.3.1 Interrupt Priority Registers A to M, and O (IPRA to IPRM, IPRO)....................... 89
Rev. 6.00 Sep. 24, 2009 Page x of xlvi
REJ09B0099-0600
5.4
5.5
5.6
5.3.2 IRQ Enable Register (IER) ..................................................................................... 90
5.3.3 IRQ Sense Control Registers H and L (ISCRH and ISCRL) .................................. 91
5.3.4 IRQ Status Register (ISR)....................................................................................... 93
Interrupt Sources.................................................................................................................. 94
5.4.1 External Interrupts .................................................................................................. 94
5.4.2 Internal Interrupts ................................................................................................... 95
5.4.3 Interrupt Exception Handling Vector Table............................................................ 95
Operation ........................................................................................................................... 100
5.5.1 Interrupt Control Modes and Interrupt Operation ................................................. 100
5.5.2 Interrupt Control Mode 0 ...................................................................................... 103
5.5.3 Interrupt Control Mode 2 ...................................................................................... 105
5.5.4 Interrupt Exception Handling Sequence ............................................................... 107
5.5.5 Interrupt Response Times ..................................................................................... 109
5.5.6 DTC Activation by Interrupt................................................................................. 110
Usage Notes ....................................................................................................................... 112
5.6.1 Contention between Interrupt Generation and Disabling...................................... 112
5.6.2 Instructions That Disable Interrupts...................................................................... 113
5.6.3 When Interrupts Are Disabled .............................................................................. 113
5.6.4 Interrupts during Execution of EEPMOV Instruction........................................... 114
5.6.5 IRQ Interrupt ........................................................................................................ 114
5.6.6 NMI Interrupt Usage Notes .................................................................................. 114
Section 6 PC Break Controller (PBC) .................................................................115
6.1
6.2
6.3
6.4
Features.............................................................................................................................. 115
Register Descriptions ......................................................................................................... 116
6.2.1 Break Address Register A (BARA) ...................................................................... 116
6.2.2 Break Address Register B (BARB) ...................................................................... 117
6.2.3 Break Control Register A (BCRA) ....................................................................... 117
6.2.4 Break Control Register B (BCRB)........................................................................ 118
Operation ........................................................................................................................... 118
6.3.1 PC Break Interrupt Due to Instruction Fetch ........................................................ 118
6.3.2 PC Break Interrupt Due to Data Access................................................................ 119
6.3.3 Notes on PC Break Interrupt Handling ................................................................. 119
6.3.4 Operation in Transitions to Power-Down Modes ................................................. 119
6.3.5 When Instruction Execution Is Delayed by One State.......................................... 120
Usage Notes ....................................................................................................................... 121
6.4.1 Module Stop Mode Setting ................................................................................... 121
6.4.2 PC Break Interrupts .............................................................................................. 121
6.4.3 CMFA and CMFB ................................................................................................ 121
6.4.4 PC Break Interrupt when DTC Is Bus Master ...................................................... 121
Rev. 6.00 Sep. 24, 2009 Page xi of xlvi
REJ09B0099-0600
6.4.5
6.4.6
6.4.7
6.4.8
PC Break Set for Instruction Fetch at Address Following BSR, JSR, JMP, TRAPA,
RTE, or RTS Instruction....................................................................................... 121
I Bit Set by LDC, ANDC, ORC, or XORC Instruction ........................................ 121
PC Break Set for Instruction Fetch at Address Following Bcc Instruction........... 122
PC Break Set for Instruction Fetch at Branch Destination Address of Bcc
Instruction............................................................................................................. 122
Section 7 Bus Controller ..................................................................................... 123
7.1
7.2
7.3
Features.............................................................................................................................. 123
Input/Output Pins............................................................................................................... 125
Register Descriptions......................................................................................................... 125
7.3.1 Bus Width Control Register (ABWCR) ............................................................... 126
7.3.2 Access State Control Register (ASTCR) .............................................................. 126
7.3.3 Wait Control Registers H and L (WCRH, WCRL)............................................... 127
7.3.4 Bus Control Register H (BCRH) .......................................................................... 130
7.3.5 Bus Control Register L (BCRL) ........................................................................... 131
7.3.6 Pin Function Control Register (PFCR) ................................................................. 132
7.4 Bus Control........................................................................................................................ 134
7.4.1 Area Divisions ...................................................................................................... 134
7.4.2 Bus Specifications ................................................................................................ 135
7.4.3 Bus Interface for Each Area.................................................................................. 136
7.4.4 Chip Select Signals ............................................................................................... 137
7.5 Basic Timing...................................................................................................................... 139
7.5.1 On-Chip Memory (ROM, RAM) Access Timing ................................................. 139
7.5.2 On-Chip Peripheral Module Access Timing......................................................... 140
7.5.3 External Address Space Access Timing ............................................................... 144
7.6 Basic Bus Interface ............................................................................................................ 145
7.6.1 Data Size and Data Alignment.............................................................................. 145
7.6.2 Valid Strobes ........................................................................................................ 146
7.6.3 Basic Timing......................................................................................................... 147
7.6.4 Wait Control ......................................................................................................... 155
7.7 Burst ROM Interface ......................................................................................................... 157
7.7.1 Basic Timing......................................................................................................... 157
7.7.2 Wait Control ......................................................................................................... 159
7.8 Idle Cycle........................................................................................................................... 160
7.9 Bus Release........................................................................................................................ 163
7.9.1 Usage Note for Bus Mastership Release............................................................... 164
7.10 Bus Arbitration .................................................................................................................. 165
7.10.1 Operation .............................................................................................................. 165
7.10.2 Bus Mastership Transfer Timing .......................................................................... 165
Rev. 6.00 Sep. 24, 2009 Page xii of xlvi
REJ09B0099-0600
7.10.3 Usage Note for External Bus Mastership Release ................................................ 166
7.11 Resets and the Bus Controller............................................................................................ 166
Section 8 Data Transfer Controller (DTC) ..........................................................167
8.1
8.2
8.3
8.4
8.5
8.6
8.7
8.8
Features.............................................................................................................................. 167
Register Descriptions ......................................................................................................... 169
8.2.1 DTC Mode Register A (MRA) ............................................................................. 170
8.2.2 DTC Mode Register B (MRB).............................................................................. 171
8.2.3 DTC Source Address Register (SAR)................................................................... 172
8.2.4 DTC Destination Address Register (DAR)........................................................... 172
8.2.5 DTC Transfer Count Register A (CRA) ............................................................... 172
8.2.6 DTC Transfer Count Register B (CRB)................................................................ 172
8.2.7 DTC Enable Registers A to G, and I (DTCERA to DTCERG, and DTCERI) ..... 172
8.2.8 DTC Vector Register (DTVECR)......................................................................... 173
Activation Sources ............................................................................................................. 174
Location of Register Information and DTC Vector Table ................................................. 176
Operation ........................................................................................................................... 180
8.5.1 Normal Mode........................................................................................................ 181
8.5.2 Repeat Mode ......................................................................................................... 182
8.5.3 Block Transfer Mode ............................................................................................ 183
8.5.4 Chain Transfer ...................................................................................................... 185
8.5.5 Interrupts............................................................................................................... 186
8.5.6 Operation Timing.................................................................................................. 186
8.5.7 Number of DTC Execution States ........................................................................ 187
Procedures for Using DTC................................................................................................. 189
8.6.1 Activation by Interrupt.......................................................................................... 189
8.6.2 Activation by Software ......................................................................................... 189
Examples of Use of the DTC ............................................................................................. 190
8.7.1 Normal Mode........................................................................................................ 190
8.7.2 Software Activation .............................................................................................. 190
Usage Notes ....................................................................................................................... 191
8.8.1 Module Stop Mode Setting ................................................................................... 191
8.8.2 On-Chip RAM ...................................................................................................... 191
8.8.3 DTCE Bit Setting.................................................................................................. 191
Section 9 I/O Ports ...............................................................................................193
9.1
Port 1.................................................................................................................................. 199
9.1.1 Port 1 Data Direction Register (P1DDR).............................................................. 199
9.1.2 Port 1 Data Register (P1DR)................................................................................. 200
9.1.3 Port 1 Register (PORT1)....................................................................................... 200
Rev. 6.00 Sep. 24, 2009 Page xiii of xlvi
REJ09B0099-0600
9.2
9.3
9.4
9.5
9.6
9.7
9.8
9.9
9.1.4 Pin Functions ........................................................................................................ 200
Port 2.................................................................................................................................. 205
9.2.1 Port 2 Data Direction Register (P2DDR).............................................................. 205
9.2.2 Port 2 Data Register (P2DR) ................................................................................ 206
9.2.3 Port 2 Register (PORT2)....................................................................................... 206
9.2.4 Pin Functions ........................................................................................................ 207
Port 3.................................................................................................................................. 210
9.3.1 Port 3 Data Direction Register (P3DDR).............................................................. 210
9.3.2 Port 3 Data Register (P3DR) ................................................................................ 211
9.3.3 Port 3 Register (PORT3)....................................................................................... 211
9.3.4 Port 3 Open Drain Control Register (P3ODR) ..................................................... 212
9.3.5 Pin Functions ........................................................................................................ 212
Port 4.................................................................................................................................. 216
9.4.1 Port 4 Register (PORT4)....................................................................................... 216
9.4.2 Pin Functions ........................................................................................................ 216
Port 5.................................................................................................................................. 217
9.5.1 Port 5 Data Direction Register (P5DDR).............................................................. 217
9.5.2 Port 5 Data Register (P5DR) ................................................................................ 217
9.5.3 Port 5 Register (PORT5)....................................................................................... 218
9.5.4 Pin Functions ........................................................................................................ 218
Port 7.................................................................................................................................. 219
9.6.1 Port 7 Data Direction Register (P7DDR).............................................................. 219
9.6.2 Port 7 Data Register (P7DR) ................................................................................ 220
9.6.3 Port 7 Register (PORT7)....................................................................................... 220
9.6.4 Pin Functions ........................................................................................................ 221
Port 9.................................................................................................................................. 224
9.7.1 Port 9 Register (PORT9)....................................................................................... 224
9.7.2 Pin Functions ........................................................................................................ 224
Port A................................................................................................................................. 226
9.8.1 Port A Data Direction Register (PADDR)............................................................ 226
9.8.2 Port A Data Register (PADR)............................................................................... 227
9.8.3 Port A Register (PORTA)..................................................................................... 227
9.8.4 Port A Pull-Up MOS Control Register (PAPCR) ................................................. 228
9.8.5 Port A Open Drain Control Register (PAODR).................................................... 228
9.8.6 Pin Functions ........................................................................................................ 229
9.8.7 Input Pull-Up MOS Function (Port A) ................................................................. 232
Port B ................................................................................................................................. 232
9.9.1 Port B Data Direction Register (PBDDR) ............................................................ 233
9.9.2 Port B Data Register (PBDR) ............................................................................... 233
9.9.3 Port B Register (PORTB) ..................................................................................... 234
Rev. 6.00 Sep. 24, 2009 Page xiv of xlvi
REJ09B0099-0600
9.10
9.11
9.12
9.13
9.14
9.15
9.16
9.9.4 Port B Pull-Up MOS Control Register (PBPCR) ................................................. 234
9.9.5 Pin Functions ........................................................................................................ 235
9.9.6 Input Pull-Up MOS Function (Port B).................................................................. 238
Port C ................................................................................................................................. 239
9.10.1 Port C Data Direction Register (PCDDR) ............................................................ 239
9.10.2 Port C Data Register (PCDR) ............................................................................... 240
9.10.3 Port C Register (PORTC) ..................................................................................... 240
9.10.4 Port C Pull-Up MOS Control Register (PCPCR) ................................................. 241
9.10.5 Pin Functions ........................................................................................................ 241
9.10.6 Input Pull-Up MOS Function (Port C).................................................................. 242
Port D................................................................................................................................. 243
9.11.1 Port D Data Direction Register (PDDDR) ............................................................ 243
9.11.2 Port D Data Register (PDDR)............................................................................... 244
9.11.3 Port D Register (PORTD)..................................................................................... 244
9.11.4 Port D Pull-Up MOS Control Register (PDPCR) ................................................. 245
9.11.5 Pin Functions ........................................................................................................ 245
9.11.6 Input Pull-Up MOS Function (Port D) ................................................................. 246
Port E ................................................................................................................................. 247
9.12.1 Port E Data Direction Register (PEDDR)............................................................. 247
9.12.2 Port E Data Register (PEDR)................................................................................ 248
9.12.3 Port E Register (PORTE)...................................................................................... 248
9.12.4 Port E Pull-Up MOS Control Register (PEPCR) .................................................. 249
9.12.5 Pin Functions ........................................................................................................ 249
9.12.6 Input Pull-Up MOS Function (Port E).................................................................. 250
Port F ................................................................................................................................. 251
9.13.1 Port F Data Direction Register (PFDDR) ............................................................. 251
9.13.2 Port F Data Register (PFDR) ................................................................................ 252
9.13.3 Port F Register (PORTF) ...................................................................................... 252
9.13.4 Pin Functions ........................................................................................................ 253
Port G................................................................................................................................. 255
9.14.1 Port G Data Direction Register (PGDDR) ............................................................ 255
9.14.2 Port G Data Register (PGDR)............................................................................... 256
9.14.3 Port G Register (PORTG)..................................................................................... 256
9.14.4 Pin Functions ........................................................................................................ 257
Port H................................................................................................................................. 258
9.15.1 Port H Data Direction Register (PHDDR) ............................................................ 259
9.15.2 Port H Data Register (PHDR)............................................................................... 259
9.15.3 Port H Register (PORTH)..................................................................................... 260
9.15.4 Pin Functions ........................................................................................................ 260
Port J .................................................................................................................................. 261
Rev. 6.00 Sep. 24, 2009 Page xv of xlvi
REJ09B0099-0600
9.16.1 Port J Data Direction Register (PJDDR)............................................................... 261
9.16.2 Port J Data Register (PJDR) ................................................................................. 262
9.16.3 Port J Register (PORTJ) ....................................................................................... 262
9.16.4 Pin Functions ........................................................................................................ 263
9.17 Power Supply Pin Control ................................................................................................. 264
9.17.1 IC Power Control Register (ICPCR)..................................................................... 264
9.18 Handling of Unused Pins ................................................................................................... 265
Section 10 16-Bit Timer Pulse Unit (TPU) ......................................................... 267
10.1 Features.............................................................................................................................. 267
10.2 Input/Output Pins............................................................................................................... 271
10.3 Register Descriptions......................................................................................................... 273
10.3.1 Timer Control Register (TCR).............................................................................. 276
10.3.2 Timer Mode Register (TMDR)............................................................................. 281
10.3.3 Timer I/O Control Register (TIOR)...................................................................... 282
10.3.4 Timer Interrupt Enable Register (TIER)............................................................... 300
10.3.5 Timer Status Register (TSR)................................................................................. 302
10.3.6 Timer Counter (TCNT)......................................................................................... 305
10.3.7 Timer General Register (TGR) ............................................................................. 305
10.3.8 Timer Start Register (TSTR) ................................................................................ 305
10.3.9 Timer Synchro Register (TSYR) .......................................................................... 306
10.4 Operation ........................................................................................................................... 307
10.4.1 Basic Functions..................................................................................................... 307
10.4.2 Synchronous Operation......................................................................................... 313
10.4.3 Buffer Operation................................................................................................... 315
10.4.4 Cascaded Operation .............................................................................................. 318
10.4.5 PWM Modes......................................................................................................... 320
10.4.6 Phase Counting Mode........................................................................................... 325
10.5 Interrupts............................................................................................................................ 332
10.6 DTC Activation.................................................................................................................. 334
10.7 A/D Converter Activation.................................................................................................. 334
10.8 Operation Timing............................................................................................................... 335
10.8.1 Input/Output Timing............................................................................................. 335
10.8.2 Interrupt Signal Timing ........................................................................................ 339
10.9 Usage Notes ....................................................................................................................... 343
10.9.1 Module Stop Mode Setting ................................................................................... 343
10.9.2 Input Clock Restrictions ....................................................................................... 343
10.9.3 Caution on Period Setting ..................................................................................... 344
10.9.4 Contention between TCNT Write and Clear Operations...................................... 344
10.9.5 Contention between TCNT Write and Increment Operations............................... 345
Rev. 6.00 Sep. 24, 2009 Page xvi of xlvi
REJ09B0099-0600
10.9.6 Contention between TGR Write and Compare Match .......................................... 346
10.9.7 Contention between Buffer Register Write and Compare Match ......................... 347
10.9.8 Contention between TGR Read and Input Capture............................................... 348
10.9.9 Contention between TGR Write and Input Capture.............................................. 349
10.9.10 Contention between Buffer Register Write and Input Capture ............................. 350
10.9.11 Contention between Overflow/Underflow and Counter Clearing......................... 351
10.9.12 Contention between TCNT Write and Overflow/Underflow................................ 352
10.9.13 Multiplexing of I/O Pins ....................................................................................... 352
10.9.14 Interrupts in Module Stop Mode........................................................................... 352
Section 11 8-Bit Timers (TMR)...........................................................................353
11.1 Features.............................................................................................................................. 353
11.2 Input/Output Pins ............................................................................................................... 355
11.3 Register Descriptions ......................................................................................................... 355
11.3.1 Timer Counter (TCNT)......................................................................................... 356
11.3.2 Time Constant Register A (TCORA).................................................................... 356
11.3.3 Time Constant Register B (TCORB) .................................................................... 357
11.3.4 Timer Control Register (TCR).............................................................................. 357
11.3.5 Timer Control/Status Register (TCSR)................................................................. 359
11.4 Operation ........................................................................................................................... 364
11.4.1 Pulse Output.......................................................................................................... 364
11.5 Operation Timing............................................................................................................... 365
11.5.1 TCNT Incrementation Timing .............................................................................. 365
11.5.2 Timing of CMFA and CMFB Setting When a Compare-Match Occurs............... 366
11.5.3 Timing of Timer Output When a Compare-Match Occurs ................................... 366
11.5.4 Timing of Compare-Match Clear When a Compare-Match Occurs ..................... 367
11.5.5 TCNT External Reset Timing............................................................................... 367
11.5.6 Timing of Overflow Flag (OVF) Setting .............................................................. 368
11.6 Operation with Cascaded Connection................................................................................ 369
11.6.1 16-Bit Count Mode ............................................................................................... 369
11.6.2 Compare-Match Count Mode ............................................................................... 369
11.7 Interrupt Sources................................................................................................................ 370
11.7.1 Interrupt Sources and DTC Activation ................................................................. 370
11.7.2 A/D Converter Activation..................................................................................... 370
11.8 Usage Notes ....................................................................................................................... 371
11.8.1 Setting Module Stop Mode ................................................................................... 371
11.8.2 Contention between TCNT Write and Clear......................................................... 371
11.8.3 Contention between TCNT Write and Increment ................................................. 372
11.8.4 Contention between TCOR Write and Compare-Match ....................................... 373
11.8.5 Contention between Compare-Matches A and B.................................................. 373
Rev. 6.00 Sep. 24, 2009 Page xvii of xlvi
REJ09B0099-0600
11.8.6 Switching of Internal Clocks and TCNT Operation ............................................. 374
11.8.7 Contention between Interrupts and Module Stop Mode ....................................... 376
11.8.8 Mode Setting in Cascading ................................................................................... 376
Section 12 Watchdog Timer (WDT) ................................................................... 377
12.1 Features.............................................................................................................................. 377
12.2 Input/Output Pin ................................................................................................................ 379
12.3 Register Descriptions......................................................................................................... 380
12.3.1 Timer Counter (TCNT)......................................................................................... 380
12.3.2 Timer Control/Status Register .............................................................................. 380
12.3.3 Reset Control/Status Register (RSTCSR) (WDT_0 only) .................................... 385
12.4 Operation ........................................................................................................................... 386
12.4.1 Watchdog Timer Mode......................................................................................... 386
12.4.2 Interval Timer Mode............................................................................................. 387
12.4.3 Timing of Setting Overflow Flag (OVF) .............................................................. 388
12.4.4 Timing of Setting Watchdog Timer Overflow Flag (WOVF) .............................. 389
12.5 Interrupt Sources................................................................................................................ 389
12.6 Usage Notes ....................................................................................................................... 390
12.6.1 Notes on Register Access ..................................................................................... 390
12.6.2 Contention between Timer Counter (TCNT) Write and Increment ...................... 392
12.6.3 Changing Value of PSS or CKS2 to CKS0........................................................... 392
12.6.4 Switching between Watchdog Timer Mode and Interval Timer Mode................. 392
12.6.5 Internal Reset in Watchdog Timer Mode.............................................................. 393
12.6.6 OVF Flag Clearing in Interval Timer Mode ......................................................... 393
12.6.7 Initialization of TCNT by the TME Bit ................................................................ 393
Section 13 Serial Communication Interface (SCI).............................................. 395
13.1 Features.............................................................................................................................. 395
13.2 Input/Output Pins............................................................................................................... 397
13.3 Register Descriptions......................................................................................................... 398
13.3.1 Receive Shift Register (RSR) ............................................................................... 399
13.3.2 Receive Data Register (RDR)............................................................................... 399
13.3.3 Transmit Data Register (TDR).............................................................................. 400
13.3.4 Transmit Shift Register (TSR) .............................................................................. 400
13.3.5 Serial Mode Register (SMR) ................................................................................ 400
13.3.6 Serial Control Register (SCR) .............................................................................. 405
13.3.7 Serial Status Register (SSR) ................................................................................. 410
13.3.8 Smart Card Mode Register (SCMR)..................................................................... 417
13.3.9 Bit Rate Register (BRR) ....................................................................................... 418
13.4 Operation in Asynchronous Mode ..................................................................................... 425
Rev. 6.00 Sep. 24, 2009 Page xviii of xlvi
REJ09B0099-0600
13.5
13.6
13.7
13.8
13.9
13.4.1 Data Transfer Format............................................................................................ 425
13.4.2 Receive Data Sampling Timing and Reception Margin in Asynchronous
Mode ..................................................................................................................... 427
13.4.3 Clock..................................................................................................................... 428
13.4.4 SCI Initialization (Asynchronous Mode) .............................................................. 428
13.4.5 Serial Data Transmission (Asynchronous Mode) ................................................. 430
13.4.6 Serial Data Reception (Asynchronous Mode)....................................................... 432
Multiprocessor Communication Function.......................................................................... 436
13.5.1 Multiprocessor Serial Data Transmission ............................................................. 438
13.5.2 Multiprocessor Serial Data Reception .................................................................. 440
Operation in Clocked Synchronous Mode ......................................................................... 444
13.6.1 Clock..................................................................................................................... 444
13.6.2 SCI Initialization (Clocked Synchronous Mode) .................................................. 445
13.6.3 Serial Data Transmission (Clocked Synchronous Mode) ..................................... 446
13.6.4 Serial Data Reception (Clocked Synchronous Mode)........................................... 449
13.6.5 Simultaneous Serial Data Transmission and Reception (Clocked Synchronous
Mode).................................................................................................................... 451
Operation in Smart Card Interface ..................................................................................... 453
13.7.1 Pin Connection Example....................................................................................... 453
13.7.2 Data Format (Except for Block Transfer Mode)................................................... 454
13.7.3 Block Transfer Mode ............................................................................................ 455
13.7.4 Receive Data Sampling Timing and Reception Margin........................................ 456
13.7.5 Initialization .......................................................................................................... 457
13.7.6 Serial Data Transmission (Except for Block Transfer Mode)............................... 458
13.7.7 Serial Data Reception (Except for Block Transfer Mode) .................................... 461
13.7.8 Clock Output Control............................................................................................ 462
Interrupt Sources................................................................................................................ 464
13.8.1 Interrupts in Normal Serial Communication Interface Mode ............................... 464
13.8.2 Interrupts in Smart Card Interface Mode .............................................................. 466
Usage Notes ....................................................................................................................... 467
13.9.1 Module Stop Mode Setting ................................................................................... 467
13.9.2 Break Detection and Processing (Asynchronous Mode Only).............................. 467
13.9.3 Mark State and Break Detection (Asynchronous Mode Only) ............................. 467
13.9.4 Receive Error Flags and Transmit Operations
(Clocked Synchronous Mode Only) ..................................................................... 467
13.9.5 Restrictions on Use of DTC.................................................................................. 467
13.9.6 Operation in Case of Mode Transition.................................................................. 468
13.9.7 Notes when Switching from SCK Pin to Port Pin................................................. 471
Rev. 6.00 Sep. 24, 2009 Page xix of xlvi
REJ09B0099-0600
Section 14 I2C Bus Interface 2 (IIC2).................................................................. 475
14.1 Features.............................................................................................................................. 475
14.2 Input/Output Pins............................................................................................................... 478
14.3 Register Descriptions......................................................................................................... 479
14.3.1 I2C Bus Control Register 1 (ICCR1)..................................................................... 479
14.3.2 I2C Bus Control Register 2 (ICCR2)..................................................................... 482
14.3.3 I2C Bus Mode Register (ICMR)............................................................................ 483
14.3.4 I2C Bus Interrupt Enable Register (ICIER)........................................................... 486
14.3.5 I2C Bus Status Register (ICSR)............................................................................. 488
14.3.6 Slave Address Register (SAR).............................................................................. 490
14.3.7 I2C Bus Transmit Data Register (ICDRT) ............................................................ 491
14.3.8 I2C Bus Receive Data Register (ICDRR).............................................................. 491
14.3.9 I2C Bus Shift Register (ICDRS)............................................................................ 491
14.4 Operation ........................................................................................................................... 492
14.4.1 I2C Bus Format...................................................................................................... 492
14.4.2 Master Transmit Operation................................................................................... 493
14.4.3 Master Receive Operation .................................................................................... 495
14.4.4 Slave Transmit Operation ..................................................................................... 497
14.4.5 Slave Receive Operation....................................................................................... 499
14.4.6 Clocked Synchronous Serial Format .................................................................... 501
14.4.7 Noise Canceler...................................................................................................... 503
14.4.8 Example of Use..................................................................................................... 504
14.5 Interrupt Request................................................................................................................ 509
14.6 Bit Synchronous Circuit..................................................................................................... 510
14.7 Note on Usage.................................................................................................................... 511
14.7.1 Setting Module Stop Mode ................................................................................... 511
14.7.2 Issuance of Stop and Repeated Start Conditions................................................... 511
14.7.3 WAIT Bit in I2C Bus Mode Register (ICMR) ...................................................... 511
14.7.4 Usage Note on Master Receive Mode................................................................... 512
14.7.5 Restriction on Setting of Transfer Rate in Use of Multi-Master........................... 512
14.7.6 Restriction on Use of Bit Manipulation Instructions to Set MST and TRS when
Multi-Master Is Used ............................................................................................ 512
Section 15 A/D Converter ................................................................................... 513
15.1 Features.............................................................................................................................. 513
15.2 Input/Output Pins............................................................................................................... 515
15.3 Register Descriptions......................................................................................................... 516
15.3.1 A/D Data Registers A to D (ADDRA to ADDRD) .............................................. 516
15.3.2 A/D Control/Status Register (ADCSR) ................................................................ 517
Rev. 6.00 Sep. 24, 2009 Page xx of xlvi
REJ09B0099-0600
15.4
15.5
15.6
15.7
15.8
15.3.3 A/D Control Register (ADCR) ............................................................................. 520
Interface to Bus Master ...................................................................................................... 521
Operation ........................................................................................................................... 522
15.5.1 Single Mode.......................................................................................................... 522
15.5.2 Scan Mode ............................................................................................................ 523
15.5.3 Input Sampling and A/D Conversion Time .......................................................... 524
15.5.4 External Trigger Input Timing.............................................................................. 526
Interrupt Source ................................................................................................................. 527
A/D Conversion Accuracy Definitions .............................................................................. 527
Usage Notes ....................................................................................................................... 529
15.8.1 Module Stop Mode Setting ................................................................................... 529
15.8.2 Permissible Signal Source Impedance .................................................................. 529
15.8.3 Influences on Absolute Accuracy ......................................................................... 529
15.8.4 Range of Analog Power Supply and Other Pin Settings....................................... 530
15.8.5 Notes on Board Design ......................................................................................... 530
15.8.6 Notes on Noise Countermeasures ......................................................................... 530
Section 16 D/A Converter....................................................................................533
16.1 Features.............................................................................................................................. 533
16.2 Input/Output Pins ............................................................................................................... 534
16.3 Register Descriptions ......................................................................................................... 534
16.3.1 D/A Data Registers 0, 1 (DADR0, DADR1) ........................................................ 534
16.3.2 D/A Control Register (DACR) ............................................................................. 535
16.4 Operation ........................................................................................................................... 536
16.5 Usage Notes ....................................................................................................................... 537
16.5.1 Analog Power Supply Current in Power-Down Mode.......................................... 537
16.5.2 Setting for Module Stop Mode ............................................................................. 537
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group] ...................................539
17.1 Features.............................................................................................................................. 539
17.1.1 IEBus Communications Protocol.......................................................................... 541
17.1.2 Communications Protocol..................................................................................... 543
17.1.3 Transfer Data (Data Field Contents)..................................................................... 551
17.1.4 Bit Format............................................................................................................. 555
17.2 Input/Output Pins ............................................................................................................... 556
17.3 Register Descriptions ......................................................................................................... 556
17.3.1 IEBus Control Register (IECTR).......................................................................... 557
17.3.2 IEBus Command Register (IECMR) .................................................................... 560
17.3.3 IEBus Master Control Register (IEMCR)............................................................. 561
17.3.4 IEBus Master Unit Address Register 1 (IEAR1) .................................................. 563
Rev. 6.00 Sep. 24, 2009 Page xxi of xlvi
REJ09B0099-0600
17.3.5 IEBus Master Unit Address Register 2 (IEAR2) .................................................. 564
17.3.6 IEBus Slave Address Setting Register 1 (IESA1)................................................. 564
17.3.7 IEBus Slave Address Setting Register 2 (IESA2)................................................. 565
17.3.8 IEBus Transmit Message Length Register (IETBFL) .......................................... 565
17.3.9 IEBus Transmit Buffer Register (IETBR) ............................................................ 566
17.3.10 IEBus Reception Master Address Register 1 (IEMA1) ........................................ 567
17.3.11 IEBus Reception Master Address Register 2 (IEMA2) ........................................ 568
17.3.12 IEBus Receive Control Field Register (IERCTL) ................................................ 568
17.3.13 IEBus Receive Message Length Register (IERBFL)............................................ 569
17.3.14 IEBus Receive Buffer Register (IERBR).............................................................. 570
17.3.15 IEBus Lock Address Register 1 (IELA1) ............................................................. 571
17.3.16 IEBus Lock Address Register 2 (IELA2) ............................................................. 571
17.3.17 IEBus General Flag Register (IEFLG) ................................................................. 572
17.3.18 IEBus Transmit/Runaway Status Register (IETSR) ............................................. 576
17.3.19 IEBus Transmit/Runaway Interrupt Enable Register (IEIET) .............................. 579
17.3.20 IEBus Transmit Error Flag Register (IETEF)....................................................... 580
17.3.21 IEBus Receive Status Register (IERSR)............................................................... 583
17.3.22 IEBus Receive Interrupt Enable Register (IEIER)................................................ 585
17.3.23 IEBus Receive Error Flag Register (IEREF) ........................................................ 586
17.4 Operation Descriptions ...................................................................................................... 589
17.4.1 Master Transmit Operation................................................................................... 589
17.4.2 Slave Receive Operation....................................................................................... 591
17.4.3 Master Reception .................................................................................................. 596
17.4.4 Slave Transmission............................................................................................... 599
17.5 Interrupt Sources................................................................................................................ 602
17.6 Usage Notes ....................................................................................................................... 603
17.6.1 Setting Module Stop Mode ................................................................................... 603
17.6.2 TxRDY Flag and Underrun Error ......................................................................... 603
17.6.3 RxRDY Flag and Overrun Error........................................................................... 604
17.6.4 Error Flag s in the IETEF ..................................................................................... 604
17.6.5 Error Flags in IEREF ............................................................................................ 605
17.6.6 Notes on Slave Transmission................................................................................ 606
17.6.7 Notes on DTC Specification ................................................................................. 607
17.6.8 Error Handling in Transmission............................................................................ 607
17.6.9 Power-Down Mode Operation.............................................................................. 608
17.6.10 Notes on Middle-Speed Mode .............................................................................. 608
17.6.11 Notes on Register Access ..................................................................................... 608
Section 18 Controller Area Network (HCAN) [H8S/2556 Group].................... 609
18.1 Features.............................................................................................................................. 609
Rev. 6.00 Sep. 24, 2009 Page xxii of xlvi
REJ09B0099-0600
18.2 Input/Output Pins ............................................................................................................... 611
18.3 Register Descriptions ......................................................................................................... 611
18.3.1 Master Control Register (MCR) ........................................................................... 612
18.3.2 General Status Register (GSR) ............................................................................. 613
18.3.3 Bit Configuration Register (BCR) ........................................................................ 615
18.3.4 Mailbox Configuration Register (MBCR) ............................................................ 617
18.3.5 Transmit Wait Register (TXPR) ........................................................................... 618
18.3.6 Transmit Wait Cancel Register (TXCR)............................................................... 619
18.3.7 Transmit Acknowledge Register (TXACK) ......................................................... 620
18.3.8 Abort Acknowledge Register (ABACK) .............................................................. 621
18.3.9 Receive Complete Register (RXPR)..................................................................... 622
18.3.10 Remote Request Register (RFPR)......................................................................... 623
18.3.11 Interrupt Register (IRR)........................................................................................ 624
18.3.12 Mailbox Interrupt Mask Register (MBIMR)......................................................... 628
18.3.13 Interrupt Mask Register (IMR) ............................................................................. 628
18.3.14 Receive Error Counter (REC)............................................................................... 630
18.3.15 Transmit Error Counter (TEC).............................................................................. 630
18.3.16 Unread Message Status Register (UMSR)............................................................ 630
18.3.17 Local Acceptance Filter Masks (LAFML, LAFMH)............................................ 631
18.3.18 Message Control (MC0 to MC15) ........................................................................ 634
18.3.19 Message Data (MD0 to MD15) ............................................................................ 636
18.4 Operation ........................................................................................................................... 637
18.4.1 Hardware and Software Resets ............................................................................. 637
18.4.2 Initialization after Hardware Reset ....................................................................... 637
18.4.3 Message Transmission .......................................................................................... 643
18.4.4 Message Reception ............................................................................................... 647
18.4.5 HCAN Sleep Mode............................................................................................... 651
18.4.6 HCAN Halt Mode................................................................................................. 653
18.5 Interrupts............................................................................................................................ 654
18.6 DTC Interface .................................................................................................................... 655
18.7 CAN Bus Interface............................................................................................................. 656
18.8 Usage Notes ....................................................................................................................... 656
18.8.1 Module Stop Mode Setting ................................................................................... 656
18.8.2 Reset ..................................................................................................................... 656
18.8.3 HCAN Sleep Mode............................................................................................... 657
18.8.4 Interrupts............................................................................................................... 657
18.8.5 Error Counters....................................................................................................... 657
18.8.6 Register Access..................................................................................................... 657
18.8.7 HCAN Medium-Speed Mode ............................................................................... 657
18.8.8 Register Hold in Standby Modes and Watch Mode.............................................. 657
Rev. 6.00 Sep. 24, 2009 Page xxiii of xlvi
REJ09B0099-0600
18.8.9 Usage of Bit Change Instructions ......................................................................... 658
18.8.10 HCAN TXCR Operation ...................................................................................... 658
18.8.11 HCAN Transmit Procedure .................................................................................. 659
18.8.12 Canceling HCAN Software Reset or HCAN Sleep Mode .................................... 661
18.8.13 Accessing Mailboxes in HCAN Sleep Mode........................................................ 661
Section 19 RAM .................................................................................................. 663
Section 20 Flash Memory.................................................................................... 665
20.1 Features.............................................................................................................................. 665
20.1.1 Block Diagram...................................................................................................... 667
20.1.2 Operating Mode .................................................................................................... 668
20.1.3 Mode Comparison ................................................................................................ 670
20.1.4 Flash MAT Configuration .................................................................................... 671
20.1.5 Block Division ...................................................................................................... 672
20.1.6 Programming/Erasing Interface ............................................................................ 673
20.2 Pin Configuration............................................................................................................... 675
20.3 Register Descriptions......................................................................................................... 676
20.3.1 Programming/Erasing Interface Register.............................................................. 677
20.3.2 Programming/Erasing Interface Parameter........................................................... 684
20.3.3 RAM Emulation Register (RAMER).................................................................... 696
20.3.4 Flash Vector Address Control Register (FVACR)................................................ 697
20.3.5 Flash Vector Address Data Register (FVADR) .................................................... 698
20.4 On-Board Programming Mode .......................................................................................... 699
20.4.1 Boot Mode ............................................................................................................ 699
20.4.2 User Program Mode.............................................................................................. 703
20.4.3 User Boot Mode.................................................................................................... 714
20.4.4 Procedure Program and Storable Area for Programming Data............................. 718
20.5 Protection........................................................................................................................... 726
20.5.1 Hardware Protection ............................................................................................. 726
20.5.2 Software Protection .............................................................................................. 727
20.5.3 Error Protection .................................................................................................... 727
20.6 Flash Memory Emulation in RAM .................................................................................... 729
20.7 Switching between User MAT and User Boot MAT......................................................... 732
20.8 Usage Notes ....................................................................................................................... 733
20.9 Programmer Mode ............................................................................................................. 734
20.9.1 Pin Arrangement of Socket Adapter ..................................................................... 734
20.9.2 Programmer Mode Operation ............................................................................... 736
20.9.3 Memory-Read Mode............................................................................................. 737
20.9.4 Auto-Program Mode ............................................................................................. 738
Rev. 6.00 Sep. 24, 2009 Page xxiv of xlvi
REJ09B0099-0600
20.9.5 Auto-Erase Mode.................................................................................................. 738
20.9.6 Status-Read Mode................................................................................................. 739
20.9.7 Status Polling ........................................................................................................ 739
20.9.8 Transition Time to Programmer Mode ................................................................. 740
20.9.9 Notes on Programmer Mode................................................................................. 740
20.10 Serial Communication Interface Specification for Boot Mode.......................................... 741
20.11 AC Characteristics and Timing in Programmer Mode....................................................... 767
Section 21 Clock Pulse Generator .......................................................................775
21.1 Register Descriptions ......................................................................................................... 776
21.1.1 System Clock Control Register (SCKCR) ............................................................ 776
21.1.2 Low-Power Control Register (LPWRCR) ............................................................ 777
21.2 System Clock Oscillator..................................................................................................... 780
21.2.1 Connecting Crystal Resonator .............................................................................. 780
21.2.2 External Clock Input............................................................................................. 781
21.2.3 Notes on Switching External Clock ...................................................................... 783
21.3 PLL Circuit ........................................................................................................................ 784
21.4 Medium-Speed Clock Divider ........................................................................................... 785
21.5 Bus Master Clock Selection Circuit................................................................................... 785
21.6 System Clock with IEBus .................................................................................................. 785
21.7 Subclock Oscillator............................................................................................................ 786
21.7.1 Connecting 32.768-kHz Crystal Resonator........................................................... 786
21.7.2 Handling Pins when Subclock Is Not Used .......................................................... 787
21.8 Subclock Waveform Generation Circuit............................................................................ 787
21.9 Usage Notes ....................................................................................................................... 788
21.9.1 Note on Crystal Resonator .................................................................................... 788
21.9.2 Note on Board Design........................................................................................... 788
Section 22 Power-Down Modes ..........................................................................791
22.1 Register Descriptions ......................................................................................................... 795
22.1.1 Standby Control Register (SBYCR) ..................................................................... 796
22.1.2 Module Stop Control Registers A to C (MSTPCRA to MSTPCRC).................... 797
22.2 Medium-Speed Mode......................................................................................................... 799
22.3 Sleep Mode ........................................................................................................................ 800
22.3.1 Transition to Sleep Mode...................................................................................... 800
22.3.2 Clearing Sleep Mode ............................................................................................ 800
22.4 Software Standby Mode..................................................................................................... 801
22.4.1 Transition to Software Standby Mode .................................................................. 801
22.4.2 Clearing Software Standby Mode ......................................................................... 801
22.4.3 Oscillation Settling Time after Clearing Software Standby Mode........................ 802
Rev. 6.00 Sep. 24, 2009 Page xxv of xlvi
REJ09B0099-0600
22.5
22.6
22.7
22.8
22.9
22.4.4 Software Standby Mode Application Example..................................................... 802
Hardware Standby Mode ................................................................................................... 804
22.5.1 Transition to Hardware Standby Mode................................................................. 804
22.5.2 Clearing Hardware Standby Mode........................................................................ 804
22.5.3 Hardware Standby Mode Timing.......................................................................... 804
Module Stop Mode ............................................................................................................ 805
Watch Mode....................................................................................................................... 806
22.7.1 Transition to Watch Mode .................................................................................... 806
22.7.2 Clearing Watch Mode........................................................................................... 806
φ Clock Output Disabled Function .................................................................................... 807
Usage Notes ....................................................................................................................... 808
22.9.1 I/O Port Status....................................................................................................... 808
22.9.2 Current Consumption during Oscillation Settling Wait Period ............................ 808
22.9.3 DTC Module Stop................................................................................................. 808
22.9.4 On-Chip Peripheral Module Interrupt................................................................... 808
22.9.5 Writing to MSTPCR ............................................................................................. 808
22.9.6 Entering Watch Mode and DTC Module Stop...................................................... 809
Section 23 List of Registers................................................................................. 811
23.1 Register Addresses (in address order)................................................................................ 812
23.2 Register Bits....................................................................................................................... 832
23.3 Register States in Each Operating Mode ........................................................................... 853
Section 24 Electrical Characteristics ................................................................... 871
24.1
24.2
24.3
24.4
Power Supply Voltage and Operating Frequency Range................................................... 871
Absolute Maximum Ratings .............................................................................................. 873
DC Characteristics ............................................................................................................. 874
AC Characteristics ............................................................................................................. 882
24.4.1 Power-On/Off Timing........................................................................................... 882
24.4.2 Clock Timing ........................................................................................................ 884
24.4.3 Control Signal Timing .......................................................................................... 886
24.4.4 Bus Timing ........................................................................................................... 889
24.4.5 Timing of On-Chip Peripheral Modules ............................................................... 895
24.5 A/D Conversion Characteristics ........................................................................................ 903
24.6 D/A Conversion Characteristics ........................................................................................ 904
24.7 Flash Memory Characteristics ........................................................................................... 905
Appendix
A.
B.
......................................................................................................... 907
I/O Port States in Each Pin State........................................................................................ 907
Product Codes .................................................................................................................... 911
Rev. 6.00 Sep. 24, 2009 Page xxvi of xlvi
REJ09B0099-0600
C.
Package Dimensions .......................................................................................................... 912
Main Revisions for This Edition..........................................................................915
Index
.........................................................................................................923
Rev. 6.00 Sep. 24, 2009 Page xxvii of xlvi
REJ09B0099-0600
Rev. 6.00 Sep. 24, 2009 Page xxviii of xlvi
REJ09B0099-0600
Figures
Sction 1 Overview
Figure 1.1 Internal Block Diagram of H8S/2556 Group .............................................................. 3
Figure 1.2 Internal Block Diagram of H8S/2552 Group .............................................................. 4
Figure 1.3 Internal Block Diagram of H8S/2506 Group .............................................................. 5
Figure 1.4 Pin Arrangement of H8S/2556 Group (FP-144J and FP-144JV) ................................ 6
Figure 1.5 Pin Arrangement of H8S/2552 Group (FP-144J and FP-144JV) ................................ 7
Figure 1.6 Pin Arrangement of H8S/2506 Group (FP-144J and FP-144JV) ................................ 8
Figure 1.7 Pin Arrangement of H8S/2552 Group (BP-176V) ...................................................... 9
Figure 1.8 Pin Arrangement of H8S/2506 Group (BP-176V) .................................................... 10
Section 2 CPU
Figure 2.1 Exception Vector Table (Normal Mode)................................................................... 29
Figure 2.2 Stack Structure in Normal Mode............................................................................... 29
Figure 2.3 Exception Vector Table (Advanced Mode)............................................................... 30
Figure 2.4 Stack Structure in Advanced Mode........................................................................... 31
Figure 2.5 Memory Map............................................................................................................. 32
Figure 2.6 CPU Registers ........................................................................................................... 33
Figure 2.7 Usage of General Registers ....................................................................................... 34
Figure 2.8 Stack Status ............................................................................................................... 35
Figure 2.9 General Register Data Formats (1)............................................................................ 38
Figure 2.9 General Register Data Formats (2)............................................................................ 39
Figure 2.10 Memory Data Formats .............................................................................................. 40
Figure 2.11 Instruction Formats (Examples) ................................................................................ 52
Figure 2.12 Branch Address Specification in Memory Indirect Mode......................................... 56
Figure 2.13 State Transitions........................................................................................................ 60
Figure 2.14 Flowchart of Access Method for Registers with Write-Only Bits............................. 64
Section 3 MCU Operating Modes
Figure 3.1 Address Map of H8S/2556, H8S/2552, and H8S/2506 ............................................. 72
Figure 3.2 Address Map of H8S/2551 ........................................................................................ 73
Figure 3.3 Address Map of H8S/2505 ........................................................................................ 74
Section 4 Exception Handling
Figure 4.1 Reset Sequence (Advanced Mode with On-Chip ROM Enabled)............................. 78
Figure 4.2 Stack State after Exception Handling (Advanced Mode).......................................... 82
Figure 4.3 Operation when SP Value Is Odd.............................................................................. 83
Rev. 6.00 Sep. 24, 2009 Page xxix of xlvi
REJ09B0099-0600
Section 5 Interrupt Controller
Figure 5.1 Block Diagram of Interrupt Controller...................................................................... 86
Figure 5.2 Block Diagram of IRQ7 to IRQ0 Interrupts.............................................................. 94
Figure 5.3 Set Timing for IRQ7F to IRQ0F ............................................................................... 95
Figure 5.4 Block Diagram of Interrupt Control Operation ....................................................... 101
Figure 5.5 Flowchart of Procedure up to Interrupt Acceptance in Interrupt Control Mode 0 . 104
Figure 5.6 Flowchart of Procedure up to Interrupt Acceptance in Interrupt Control Mode 2 . 106
Figure 5.7 Interrupt Exception Handling.................................................................................. 108
Figure 5.8 DTC and Interrupt Controller.................................................................................. 111
Figure 5.9 Contention between Interrupt Generation and Disabling ........................................ 113
Section 6 PC Break Controller (PBC)
Figure 6.1 Block Diagram of PC Break Controller .................................................................. 116
Figure 6.2 Operation in Power-Down Mode Transitions ......................................................... 120
Section 7 Bus Controller
Figure 7.1 Block Diagram of Bus Controller ........................................................................... 124
Figure 7.2 Overview of Area Divisions.................................................................................... 135
Figure 7.3 CSn Signal Output Timing (n = 0 to 7) ................................................................... 138
Figure 7.4 On-Chip Memory Access Cycle ............................................................................. 139
Figure 7.5 Pin States during On-Chip Memory Access............................................................ 140
Figure 7.6 On-Chip Peripheral Module Access Cycle ............................................................. 140
Figure 7.7 Pin States during On-Chip Peripheral Module Access............................................ 141
Figure 7.8 On-Chip Port H, Port J, and IIC2 Module Access Cycle ........................................ 141
Figure 7.9 Pin States during On-Chip Port H, Port J, and IIC2 Module Access ...................... 142
Figure 7.10 On-Chip IEB Module Access Cycle ....................................................................... 142
Figure 7.11 Pin States during On-Chip IEB Module Access...................................................... 143
Figure 7.12 On-Chip HCAN Module Access Cycle................................................................... 143
Figure 7.13 Pin States during On-Chip HCAN Module Access................................................. 144
Figure 7.14 Access Sizes and Data Alignment Control (8-Bit Access Space) ........................... 145
Figure 7.15 Access Sizes and Data Alignment Control (16-Bit Access Space) ......................... 146
Figure 7.16 Bus Timing for 8-Bit 2-State Access Space ............................................................ 147
Figure 7.17 Bus Timing for 8-Bit 3-State Access Space ............................................................ 148
Figure 7.18 Bus Timing for 16-Bit 2-State Access Space (1) (Even Address Byte Access)...... 149
Figure 7.19 Bus Timing for 16-Bit 2-State Access Space (2) (Odd Address Byte Access) ....... 150
Figure 7.20 Bus Timing for 16-Bit 2-State Access Space (3) (Word Access) ........................... 151
Figure 7.21 Bus Timing for 16-Bit 3-State Access Space (1) (Even Address Byte Access)...... 152
Figure 7.22 Bus Timing for 16-Bit 3-State Access Space (2) (Odd Address Byte Access) ....... 153
Figure 7.23 Bus Timing for 16-Bit 3-State Access Space (3) (Word Access) ........................... 154
Figure 7.24 Example of Wait State Insertion Timing................................................................. 156
Rev. 6.00 Sep. 24, 2009 Page xxx of xlvi
REJ09B0099-0600
Figure 7.25
Figure 7.26
Figure 7.27
Figure 7.28
Figure 7.29
Figure 7.30
Example of Burst ROM Access Timing (When AST0 = BRSTS1 = 1).................. 158
Example of Burst ROM Access Timing (When AST0 = BRSTS1 = 0).................. 158
Example of Idle Cycle Operation (1) ...................................................................... 160
Example of Idle Cycle Operation (2) ...................................................................... 161
Relationship between Chip Select (CS) and Read (RD) ......................................... 162
Bus Mastership Released State Transition Timing.................................................. 164
Section 8 Data Transfer Controller (DTC)
Figure 8.1 Block Diagram of DTC ........................................................................................... 168
Figure 8.2 Block Diagram of DTC Activation Source Control ................................................ 175
Figure 8.3 Location of DTC Register Information in Address Space....................................... 176
Figure 8.4 Correspondence between DTC Vector Address and Register Information ............. 177
Figure 8.5 Flowchart of DTC Operation .................................................................................. 181
Figure 8.6 Memory Mapping in Normal Mode ........................................................................ 182
Figure 8.7 Memory Mapping in Repeat Mode ......................................................................... 183
Figure 8.8 Memory Mapping in Block Transfer Mode ............................................................ 184
Figure 8.9 Chain Transfer Operation........................................................................................ 185
Figure 8.10 DTC Operation Timing (Example in Normal Mode or Repeat Mode) ................... 186
Figure 8.11 DTC Operation Timing (Example in Block Transfer Mode, with Block Size of 2)187
Figure 8.12 DTC Operation Timing (Example of Chain Transfer) ............................................ 187
Section 9 I/O Ports
Figure 9.1 Types of Open Drain Outputs ................................................................................. 212
Section 10 16-Bit Timer Pulse Unit (TPU)
Figure 10.1 Block Diagram of TPU ........................................................................................... 270
Figure 10.2 Example of Counter Operation Setting Procedure .................................................. 307
Figure 10.3 Free-Running Counter Operation............................................................................ 308
Figure 10.4 Periodic Counter Operation..................................................................................... 309
Figure 10.5 Example of Setting Procedure for Waveform Output by Compare Match.............. 310
Figure 10.6 Example of 0 Output/1 Output Operation ............................................................... 311
Figure 10.7 Example of Toggle Output Operation ..................................................................... 311
Figure 10.8 Example of Input Capture Operation Setting Procedure ......................................... 312
Figure 10.9 Example of Input Capture Operation ...................................................................... 313
Figure 10.10 Example of Synchronous Operation Setting Procedure .......................................... 314
Figure 10.11 Example of Synchronous Operation........................................................................ 315
Figure 10.12 Compare Match Buffer Operation........................................................................... 316
Figure 10.13 Input Capture Buffer Operation .............................................................................. 316
Figure 10.14 Example of Buffer Operation Setting Procedure..................................................... 316
Figure 10.15 Example of Buffer Operation (1) ............................................................................ 317
Rev. 6.00 Sep. 24, 2009 Page xxxi of xlvi
REJ09B0099-0600
Figure 10.16 Example of Buffer Operation (2) ............................................................................ 318
Figure 10.17 Cascaded Operation Setting Procedure ................................................................... 319
Figure 10.18 Example of Cascaded Operation (1) ....................................................................... 319
Figure 10.19 Example of Cascaded Operation (2) ....................................................................... 320
Figure 10.20 Example of PWM Mode Setting Procedure ............................................................ 322
Figure 10.21 Example of PWM Mode Operation (1)................................................................... 323
Figure 10.22 Example of PWM Mode Operation (2)................................................................... 323
Figure 10.23 Example of PWM Mode Operation (3)................................................................... 324
Figure 10.24 Example of Phase Counting Mode Setting Procedure ............................................ 326
Figure 10.25 Example of Phase Counting Mode 1 Operation ...................................................... 327
Figure 10.26 Example of Phase Counting Mode 2 Operation ...................................................... 328
Figure 10.27 Example of Phase Counting Mode 3 Operation ...................................................... 329
Figure 10.28 Example of Phase Counting Mode 4 Operation ...................................................... 330
Figure 10.29 Phase Counting Mode Application Example .......................................................... 332
Figure 10.30 Count Timing in Internal Clock Operation ............................................................. 335
Figure 10.31 Count Timing in External Clock Operation ............................................................ 335
Figure 10.32 Output Compare Output Timing ............................................................................. 336
Figure 10.33 Input Capture Input Signal Timing ......................................................................... 336
Figure 10.34 Counter Clear Timing (Compare Match) ................................................................ 337
Figure 10.35 Counter Clear Timing (Input Capture).................................................................... 337
Figure 10.36 Buffer Operation Timing (Compare Match) ........................................................... 338
Figure 10.37 Buffer Operation Timing (Input Capture) ............................................................... 338
Figure 10.38 TGI Interrupt Timing (Compare Match) ................................................................. 339
Figure 10.39 TGI Interrupt Timing (Input Capture)..................................................................... 340
Figure 10.40 TCIV Interrupt Setting Timing ............................................................................... 340
Figure 10.41 TCIU Interrupt Setting Timing ............................................................................... 341
Figure 10.42 Timing for Status Flag Clearing by CPU ................................................................ 342
Figure 10.43 Timing for Status Flag Clearing by DTC Activation .............................................. 342
Figure 10.44 Phase Difference, Overlap, and Pulse Width in Phase Counting Mode .................. 343
Figure 10.45 Contention between TCNT Write and Clear Operations......................................... 344
Figure 10.46 Contention between TCNT Write and Increment Operations ................................. 345
Figure 10.47 Contention between TGR Write and Compare Match ............................................ 346
Figure 10.48 Contention between Buffer Register Write and Compare Match............................ 347
Figure 10.49 Contention between TGR Read and Input Capture ................................................. 348
Figure 10.50 Contention between TGR Write and Input Capture ................................................ 349
Figure 10.51 Contention between Buffer Register Write and Input Capture ............................... 350
Figure 10.52 Contention between Overflow and Counter Clearing ............................................. 351
Figure 10.53 Contention between TCNT Write and Overflow .................................................... 352
Rev. 6.00 Sep. 24, 2009 Page xxxii of xlvi
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
Figure 11.1 Block Diagram of 8-Bit Timer Module................................................................... 354
Figure 11.2 Example of Pulse Output......................................................................................... 364
Figure 11.3 Count Timing for Internal Clock Input ................................................................... 365
Figure 11.4 Count Timing for External Clock Input .................................................................. 365
Figure 11.5 Timing of CMF Flag Setting ................................................................................... 366
Figure 11.6 Timing of Timer Output.......................................................................................... 366
Figure 11.7 Timing of Compare-Match Clear ............................................................................ 367
Figure 11.8 Timing of Clearing by External Reset Input ........................................................... 367
Figure 11.9 Timing of OVF Setting ........................................................................................... 368
Figure 11.10 Contention between TCNT Write and Clear ........................................................... 371
Figure 11.11 Contention between TCNT Write and Increment.................................................... 372
Figure 11.12 Contention between TCOR Write and Compare-Match ......................................... 373
Section 12
Figure 12.1
Figure 12.1
Figure 12.2
Figure 12.3
Figure 12.4
Figure 12.5
Figure 12.6
Figure 12.7
Figure 12.8
Watchdog Timer (WDT)
Block Diagram of WDT_0 (1) ................................................................................ 378
Block Diagram of WDT_1 (2) ................................................................................ 379
Watchdog Timer Mode Operation .......................................................................... 387
Interval Timer Mode Operation .............................................................................. 388
Timing of OVF Setting ........................................................................................... 388
Timing of WOVF Setting........................................................................................ 389
Writing to TCNT and TCSR (WDT_0)................................................................... 390
Writing to RSTCSR ................................................................................................ 391
Contention between TCNT Write and Increment.................................................... 392
Section 13 Serial Communication Interface (SCI)
Figure 13.1 Block Diagram of SCI............................................................................................. 396
Figure 13.2 Data Format in Asynchronous Communication (Example with 8-Bit Data, Parity,
Two Stop Bits) ........................................................................................................ 425
Figure 13.3 Receive Data Sampling Timing in Asynchronous Mode ........................................ 427
Figure 13.4 Relationship between Output Clock and Transfer Data Phase
(Asynchronous Mode)............................................................................................. 428
Figure 13.5 Sample SCI Initialization Flowchart ....................................................................... 429
Figure 13.6 Example of Operation in Transmission in Asynchronous Mode
(Example with 8-Bit Data, Parity, One Stop Bit) .................................................... 430
Figure 13.7 Sample Serial Transmission Flowchart ................................................................... 431
Figure 13.8 Example of SCI Operation in Reception
(Example with 8-Bit Data, Parity, One Stop Bit) .................................................... 432
Figure 13.9 Sample Serial Reception Data Flowchart (1) .......................................................... 434
Rev. 6.00 Sep. 24, 2009 Page xxxiii of xlvi
REJ09B0099-0600
Figure 13.9 Sample Serial Reception Data Flowchart (2) .......................................................... 435
Figure 13.10 Example of Communication Using Multiprocessor Format
(Transmission of Data H'AA to Receiving Station A) ............................................ 437
Figure 13.11 Sample Multiprocessor Serial Transmission Flowchart.......................................... 439
Figure 13.12 Example of SCI Operation in Reception
(Example with 8-Bit Data, Multiprocessor Bit, One Stop Bit) ............................... 441
Figure 13.13 Sample Multiprocessor Serial Reception Flowchart (1).......................................... 442
Figure 13.13 Sample Multiprocessor Serial Reception Flowchart (2).......................................... 443
Figure 13.14 Data Format in Clocked Synchronous Communication (For LSB-First) ................ 444
Figure 13.15 Sample SCI Initialization Flowchart ....................................................................... 445
Figure 13.16 Sample SCI Transmission Operation in Clocked Synchronous Mode.................... 447
Figure 13.17 Sample Serial Transmission Flowchart................................................................... 448
Figure 13.18 Example of SCI Operation in Reception................................................................. 449
Figure 13.19 Sample Serial Reception Flowchart ........................................................................ 450
Figure 13.20 Sample Flowchart of Simultaneous Serial Transmit and Receive Operations ........ 452
Figure 13.21 (1) Schematic Diagram of Smart Card Interface Pin Connections
(Channels 0, 1, 3, and 4) .................................................................................... 453
Figure 13.21 (2) Schematic Diagram of Smart Card Interface Pin Connections
(Channel 2) ........................................................................................................ 454
Figure 13.22 Normal Smart Card Interface Data Format ............................................................. 454
Figure 13.23 Direct Convention (SDIR = SINV = O/E = 0) ........................................................ 455
Figure 13.24 Inverse Convention (SDIR = SINV = O/E = 1) ...................................................... 455
Figure 13.25 Receive Data Sampling Timing in Smart Card Interface Mode
(Using Clock of 372 Times the Transfer Rate) ....................................................... 457
Figure 13.26 Retransfer Operation in SCI Transmit Mode .......................................................... 459
Figure 13.27 TEND Flag Generation Timing in Transmission Operation ................................... 459
Figure 13.28 Example of Transmission Processing Flow ............................................................ 460
Figure 13.29 Retransfer Operation in SCI Receive Mode............................................................ 462
Figure 13.30 Example of Reception Processing Flow.................................................................. 462
Figure 13.31 Timing for Fixing Clock Output Level ................................................................... 463
Figure 13.32 Clock Halt and Restart Procedure ........................................................................... 464
Figure 13.33 Example of Clocked Synchronous Transmission by DTC...................................... 468
Figure 13.34 Sample Flowchart for Mode Transition during Transmission................................. 469
Figure 13.35 Asynchronous Transmission Using Internal Clock................................................. 469
Figure 13.36 Clocked Synchronous Transmission Using Internal Clock..................................... 470
Figure 13.37 Sample Flowchart for Mode Transition during Reception...................................... 471
Figure 13.38 Operation when Switching from SCK Pin to Port Pin ............................................ 472
Figure 13.39 Operation when Switching from SCK Pin to Port Pin
(Example of Preventing Low-Level Output)........................................................... 473
Rev. 6.00 Sep. 24, 2009 Page xxxiv of xlvi
REJ09B0099-0600
Section 14 I2C Bus Interface 2 (IIC2)
Figure 14.1 Block Diagram of I2C Bus Interface 2..................................................................... 477
Figure 14.2 External Circuit Connections of I/O Pins................................................................ 478
Figure 14.3 I2C Bus Formats ...................................................................................................... 492
Figure 14.4 I2C Bus Timing........................................................................................................ 492
Figure 14.5 Master Transmit Mode Operation Timing (1)......................................................... 494
Figure 14.6 Master Transmit Mode Operation Timing (2)......................................................... 494
Figure 14.7 Master Receive Mode Operation Timing (1) .......................................................... 496
Figure 14.8 Master Receive Mode Operation Timing (2) .......................................................... 497
Figure 14.9 Slave Transmit Mode Operation Timing (1) ........................................................... 498
Figure 14.10 Slave Transmit Mode Operation Timing (2) ........................................................... 499
Figure 14.11 Slave Receive Mode Operation Timing (1)............................................................. 500
Figure 14.12 Slave Receive Mode Operation Timing (2)............................................................. 501
Figure 14.13 Clocked Synchronous Serial Transfer Format......................................................... 501
Figure 14.14 Transmit Mode Operation Timing .......................................................................... 502
Figure 14.15 Receive Mode Operation Timing ............................................................................ 503
Figure 14.16 Block Diagram of Noise Canceler........................................................................... 504
Figure 14.17 Sample Flowchart for Master Transmit Mode ........................................................ 505
Figure 14.18 Sample Flowchart for Master Receive Mode .......................................................... 506
Figure 14.19 Sample Flowchart for Slave Transmit Mode........................................................... 507
Figure 14.20 Sample Flowchart for Slave Receive Mode ............................................................ 508
Figure 14.21 The Timing of the Bit Synchronous Circuit ............................................................ 510
Section 15 A/D Converter
Figure 15.1 Block Diagram of A/D Converter ........................................................................... 514
Figure 15.2 Access to ADDR (When Reading H'AA40) ........................................................... 521
Figure 15.3 A/D Conversion Timing (Single-Chip Mode, Channel 1 Selected) ........................ 523
Figure 15.4 A/D Conversion Timing (Scan Mode, Channels AN0 to AN2 Selected)................ 524
Figure 15.5 A/D Conversion Timing.......................................................................................... 525
Figure 15.6 External Trigger Input Timing ................................................................................ 526
Figure 15.7 A/D Conversion Accuracy Definitions ................................................................... 528
Figure 15.8 A/D Conversion Accuracy Definitions ................................................................... 528
Figure 15.9 Example of Analog Input Circuit ............................................................................ 530
Figure 15.10 Example of Analog Input Protection Circuit........................................................... 531
Figure 15.11 Analog Input Pin Equivalent Circuit ....................................................................... 532
Section 16 D/A Converter
Figure 16.1 Block Diagram of D/A Converter ........................................................................... 533
Figure 16.2 D/A Converter Operation Example ......................................................................... 537
Rev. 6.00 Sep. 24, 2009 Page xxxv of xlvi
REJ09B0099-0600
Section 17
Figure 17.1
Figure 17.2
Figure 17.3
Figure 17.4
Figure 17.5
Figure 17.6
Figure 17.7
IEBus™ Controller (IEB) [H8S/2552 Group]
Block Diagram of IEB ............................................................................................ 540
Transfer Signal Format ........................................................................................... 544
Bit Configuration of Slave Status (SSR)................................................................. 553
Locked Address Configuration ............................................................................... 554
IEBus Bit Format (Conceptual Diagram)................................................................ 555
Transmission Signal Format and Registers in Data Transfer .................................. 567
Relationship between Transmission Signal Format and Registers in IEBus Data
Reception ................................................................................................................ 570
Figure 17.8 Master Transmit Operation Timing......................................................................... 591
Figure 17.9 Slave Reception Operation Timing ......................................................................... 594
Figure 17.10 Error Occurrence in the Broadcast Reception (DEE = 1) ....................................... 595
Figure 17.11 Master Receive Operation Timing .......................................................................... 598
Figure 17.12 Slave Transmit Operation Timing........................................................................... 601
Figure 17.13 Relationships among Transfer Interrupt Sources .................................................... 602
Figure 17.14 Relationships among Receive Interrupt Sources..................................................... 602
Figure 17.15 Error Processing in Transfer ................................................................................... 607
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Figure 18.1 HCAN Block Diagram............................................................................................ 610
Figure 18.2 Message Control Register Configuration ................................................................ 634
Figure 18.3 Standard Format ...................................................................................................... 634
Figure 18.4 Extended Format ..................................................................................................... 634
Figure 18.5 Message Data Configuration................................................................................... 636
Figure 18.6 Hardware Reset Flowchart ...................................................................................... 638
Figure 18.7 Software Reset Flowchart ....................................................................................... 639
Figure 18.8 Detailed Description of One Bit.............................................................................. 640
Figure 18.9 Transmission Flowchart .......................................................................................... 644
Figure 18.10 Transmit Message Cancellation Flowchart ............................................................. 646
Figure 18.11 Reception Flowchart ............................................................................................... 648
Figure 18.12 Unread Message Overwrite Flowchart.................................................................... 651
Figure 18.13 HCAN Sleep Mode Flowchart ................................................................................ 652
Figure 18.14 HCAN Halt Mode Flowchart .................................................................................. 653
Figure 18.15 DTC Transfer Flowchart ......................................................................................... 655
Figure 18.16 High-Speed Interface Using PCA82C250............................................................... 656
Figure 18.17 HCAN Transmit Procedure..................................................................................... 660
Section 20 Flash Memory
Figure 20.1 Block Diagram of Flash Memory............................................................................ 667
Figure 20.2 Mode Transition of Flash Memory ......................................................................... 668
Rev. 6.00 Sep. 24, 2009 Page xxxvi of xlvi
REJ09B0099-0600
Figure 20.3 Flash Memory Configuration .................................................................................. 671
Figure 20.4 Block Division of User MAT.................................................................................. 672
Figure 20.5 Overview of User Procedure Program .................................................................... 673
Figure 20.6 System Configuration in Boot Mode....................................................................... 699
Figure 20.7 Automatic-Bit-Rate Adjustment Operation of SCI ................................................. 700
Figure 20.8 Overview of Boot Mode State Transition Diagram................................................. 702
Figure 20.9 Programming/Erasing Overview Flow.................................................................... 703
Figure 20.10 RAM Map when Programming/Erasing Is Executed .............................................. 704
Figure 20.11 Programming Procedure.......................................................................................... 705
Figure 20.12 Erasing Procedure ................................................................................................... 711
Figure 20.13 Sample Procedure of Repeating RAM Emulation, Erasing, and Programming
(Overview) .............................................................................................................. 713
Figure 20.14 Procedure for Programming User MAT in User Boot Mode .................................. 715
Figure 20.15 Procedure for Erasing User MAT in User Boot Mode ............................................ 717
Figure 20.16 Transitions to Error-Protection State....................................................................... 728
Figure 20.17 Emulation of Flash Memory in RAM ..................................................................... 729
Figure 20.18 Example of a RAM-Overlap Operation .................................................................. 730
Figure 20.19 Programming of the Data after Tuning ................................................................... 731
Figure 20.20 Switching between the User MAT and User Boot MAT ........................................ 732
Figure 20.21 On-Chip Flash Memory Map .................................................................................. 734
Figure 20.22 Pin arrangement of Socket Adapter......................................................................... 735
Figure 20.23 Boot Program States................................................................................................ 742
Figure 20.24 Bit-Rate-Adjustment Sequence ............................................................................... 743
Figure 20.25 Communication Protocol Format ............................................................................ 744
Figure 20.26 New Bit-Rate Selection Sequence........................................................................... 754
Figure 20.27 Programming Sequence........................................................................................... 758
Figure 20.28 Erasure Sequence .................................................................................................... 761
Figure 20.29 Memory Read Timing after Command Programming ............................................ 767
Figure 20.30 Waveform of Transition from Memory-Read Mode to Other Mode....................... 768
Figure 20.31 Waveform of CE, OE Enable State Read................................................................ 769
Figure 20.32 Waveform of CE, OE Clock System Read.............................................................. 769
Figure 20.33 Waveform of Automatic Programming Mode......................................................... 770
Figure 20.34 Waveform in Auto-Erase Mode .............................................................................. 771
Figure 20.35 Waveform in Status-Read Mode ............................................................................. 772
Figure 20.36 Oscillation Stabilized Time, Programmer Mode Setup Time and Power Falling
Sequence ................................................................................................................. 773
Section 21 Clock Pulse Generator
Figure 21.1 Block Diagram of Clock Pulse Generator ............................................................... 775
Figure 21.2 Connection of Crystal Resonator (Example)........................................................... 780
Rev. 6.00 Sep. 24, 2009 Page xxxvii of xlvi
REJ09B0099-0600
Figure 21.3 Crystal Resonator Equivalent Circuit...................................................................... 780
Figure 21.4 External Clock Input (Examples) ............................................................................ 781
Figure 21.5 External Clock Input Timing................................................................................... 782
Figure 21.6 External Clock Switching Circuit (Examples) ........................................................ 783
Figure 21.7 External Clock Switching Timing (Examples)........................................................ 784
Figure 21.8 Connection Example of 32.768-kHz Crystal Resonator ......................................... 786
Figure 21.9 Equivalent Circuit for 32.768-kHz Crystal Resonator ............................................ 786
Figure 21.10 Pin Handling when Subclock Is Not Used .............................................................. 787
Figure 21.11 Note on Board Design of Oscillator Circuit............................................................ 788
Figure 21.12 Recommended Connection Circuit between Power Supply Pins and Vss Pin ........ 789
Section 22
Figure 22.1
Figure 22.2
Figure 22.3
Figure 22.4
Power-Down Modes
Mode Transition Diagram ....................................................................................... 794
Medium-Speed Mode Transition and Clearance Timing ........................................ 800
Software Standby Mode Application Example ....................................................... 803
Hardware Standby Mode Timing............................................................................ 805
Section 24 Electrical Characteristics
Figure 24.1 (1) Power Supply Voltage and Operating Ranges
(H8S/2552 Group, H8S/2506 Group) ................................................................. 871
Figure 24.1 (2) Power Supply Voltage and Operating Ranges (H8S/2556 Group) ..................... 872
Figure 24.2 Output Load Circuit ................................................................................................ 882
Figure 24.3 Power-On/Off Timing............................................................................................. 883
Figure 24.4 Power-On Timing.................................................................................................... 883
Figure 24.5 System Clock Timing.............................................................................................. 885
Figure 24.6 Oscillator Settling Timing....................................................................................... 886
Figure 24.7 Reset Input Timing.................................................................................................. 887
Figure 24.8 Interrupt Input Timing............................................................................................. 888
Figure 24.9 Basic Bus Timing: Two-State Access ..................................................................... 891
Figure 24.10 Basic Bus Timing: Three-State Access ................................................................... 892
Figure 24.11 Basic Bus Timing: Three-State Access, One Wait.................................................. 893
Figure 24.12 Burst ROM Access Timing: Two-State Access ...................................................... 894
Figure 24.13 External Bus-Released Timing................................................................................ 894
Figure 24.14 I/O Port Input/Output Timing ................................................................................. 897
Figure 24.15 TPU Input/Output Timing....................................................................................... 898
Figure 24.16 TPU Clock Input Timing ........................................................................................ 898
Figure 24.17 8-Bit Timer Output Timing ..................................................................................... 898
Figure 24.18 8-Bit Timer Clock Input Timing ............................................................................. 898
Figure 24.19 8-Bit Timer Reset Input Timing.............................................................................. 899
Figure 24.20 WDT_1 Output Timing........................................................................................... 899
Rev. 6.00 Sep. 24, 2009 Page xxxviii of xlvi
REJ09B0099-0600
Figure 24.21 SCK Clock Input Timing ........................................................................................ 899
Figure 24.22 SCI Input/Output Timing/Synchronous Mode ........................................................ 899
Figure 24.23 External Trigger Input Timing for A/D Converter.................................................. 900
Figure 24.24 HCAN Input/Output Timing ................................................................................... 900
Figure 24.25 I2C Bus Interface 2 Input/Output Timing ................................................................ 902
Appendix
Figure C.1
Figure C.2
FP-144J and FP-144JV Package Dimensions ......................................................... 912
BP-176V Package Dimensions ............................................................................... 913
Rev. 6.00 Sep. 24, 2009 Page xxxix of xlvi
REJ09B0099-0600
Rev. 6.00 Sep. 24, 2009 Page xl of xlvi
REJ09B0099-0600
Tables
Section 1 Overview
Table 1.1
Pin Arrangements in Operating Mode....................................................................... 11
Table 1.2
Pin Functions............................................................................................................. 17
Section 2 CPU
Table 2.1
Instruction Classification........................................................................................... 41
Table 2.2
Operation Notation.................................................................................................... 42
Table 2.3
Data Transfer Instructions ......................................................................................... 43
Table 2.4
Arithmetic Operations Instructions (1)...................................................................... 44
Table 2.4
Arithmetic Operations Instructions (2)...................................................................... 45
Table 2.5
Logic Operations Instructions ................................................................................... 46
Table 2.6
Shift Instructions ....................................................................................................... 46
Table 2.7
Bit Manipulation Instructions (1) .............................................................................. 47
Table 2.7
Bit Manipulation Instructions (2) .............................................................................. 48
Table 2.8
Branch Instructions ................................................................................................... 49
Table 2.9
System Control Instructions ...................................................................................... 50
Table 2.10 Block Data Transfer Instructions .............................................................................. 51
Table 2.11 Addressing Modes..................................................................................................... 53
Table 2.12 Absolute Address Access Ranges ............................................................................. 54
Table 2.13 Effective Address Calculation (1) ............................................................................. 57
Table 2.13 Effective Address Calculation (2) ............................................................................. 58
Section 3 MCU Operating Modes
Table 3.1
MCU Operating Mode Selection............................................................................... 67
Table 3.2
Pin Function in Each Operating Mode ...................................................................... 71
Section 4 Exception Handling
Table 4.1
Exception Types and Priority .................................................................................... 75
Table 4.2
Exception Handling Vector Table ............................................................................. 76
Table 4.3
Types of Reset........................................................................................................... 77
Table 4.4
State of CCR and EXR after Trace Exception Handling........................................... 80
Table 4.5
State of CCR and EXR after Trap Instruction Exception Handling .......................... 81
Section 5 Interrupt Controller
Table 5.1
Pin Configuration ...................................................................................................... 87
Table 5.2
Interrupt Sources, Vector Addresses, and Interrupt Priorities ................................... 96
Rev. 6.00 Sep. 24, 2009 Page xli of xlvi
REJ09B0099-0600
Table 5.3
Table 5.4
Table 5.5
Table 5.6
Table 5.7
Table 5.8
Table 5.9
Interrupt Control Modes.......................................................................................... 100
Interrupts Selected in Each Interrupt Control Mode (1).......................................... 102
Interrupts Selected in Each Interrupt Control Mode (2).......................................... 102
Operations and Control Signal Functions in Each Interrupt Control Mode ............ 103
Interrupt Response Times (States) .......................................................................... 109
Number of States in Interrupt Handling Routine Execution Status......................... 110
Interrupt Source Selection and Clear Control ......................................................... 112
Section 7 Bus Controller
Table 7.1
Pin Configuration .................................................................................................... 125
Table 7.2
Bus Specifications for Each Area (Basic Bus Interface)......................................... 136
Table 7.3
Data Buses Used and Valid Strobes ........................................................................ 146
Table 7.4
Pin States in Idle Cycle ........................................................................................... 162
Table 7.5
Pin States in Bus Mastership Released State........................................................... 163
Section 8 Data Transfer Controller (DTC)
Table 8.1
Activation Source and DTCER Clearing ................................................................ 175
Table 8.2
Interrupt Sources, DTC Vector Addresses, and Corresponding DTCEs................. 178
Table 8.3
Register Function in Normal Mode......................................................................... 182
Table 8.4
Register Function in Repeat Mode.......................................................................... 183
Table 8.5
Register Function in Block Transfer Mode............................................................. 184
Table 8.6
DTC Execution Status............................................................................................. 188
Table 8.7
Number of States Required for Each Execution Status........................................... 188
Section 9 I/O Ports
Table 9.1
Port Functions ......................................................................................................... 194
Table 9.2
Input Pull-Up MOS States (Port A) ........................................................................ 232
Table 9.3
Input Pull-Up MOS States (Port B)......................................................................... 238
Table 9.4
Input Pull-Up MOS States (Port C)......................................................................... 242
Table 9.5
Input Pull-Up MOS States (Port D) ........................................................................ 246
Table 9.6
Input Pull-Up MOS States (Port E)......................................................................... 250
Table 9.7
Examples of Ways to Handle Unused Input Pins.................................................... 265
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.1 TPU Functions ........................................................................................................ 268
Table 10.2 TPU Pins ................................................................................................................. 271
Table 10.3 CCLR0 to CCLR2 (channels 0 and 3)..................................................................... 277
Table 10.4 CCLR0 to CCLR2 (channels 1, 2, 4, and 5)............................................................ 277
Table 10.5 TPSC0 to TPSC2 (channel 0).................................................................................. 278
Table 10.6 TPSC0 to TPSC2 (channel 1).................................................................................. 278
Rev. 6.00 Sep. 24, 2009 Page xlii of xlvi
REJ09B0099-0600
Table 10.7
Table 10.8
Table 10.9
Table 10.10
Table 10.11
Table 10.12
Table 10.13
Table 10.14
Table 10.15
Table 10.16
Table 10.17
Table 10.18
Table 10.19
Table 10.20
Table 10.21
Table 10.22
Table 10.23
Table 10.24
Table 10.25
Table 10.26
Table 10.27
Table 10.28
Table 10.29
Table 10.30
Table 10.31
Table 10.32
Table 10.33
Table 10.34
Table 10.35
Table 10.36
TPSC0 to TPSC2 (channels 2) ................................................................................ 279
TPSC0 to TPSC2 (channel 3).................................................................................. 279
TPSC0 to TPSC2 (channel 4).................................................................................. 280
TPSC0 to TPSC2 (channel 5).................................................................................. 280
MD0 to MD3........................................................................................................... 282
TIORH_0 ................................................................................................................ 284
TIORL_0 ................................................................................................................. 285
TIOR_1 ................................................................................................................... 286
TIOR_2 ................................................................................................................... 287
TIORH_3 ................................................................................................................ 288
TIORL_3 ................................................................................................................. 289
TIOR_4 ................................................................................................................... 290
TIOR_5 ................................................................................................................... 291
TIORH_0 ................................................................................................................ 292
TIORL_0 ................................................................................................................. 293
TIOR_1 ................................................................................................................... 294
TIOR_2 ................................................................................................................... 295
TIORH_3 ................................................................................................................ 296
TIORL_3 ................................................................................................................. 297
TIOR_4 ................................................................................................................... 298
TIOR_5 ................................................................................................................... 299
Register Combinations in Buffer Operation............................................................ 315
Cascaded Combinations .......................................................................................... 318
PWM Output Registers and Output Pins................................................................. 321
Phase Counting Mode Clock Input Pins.................................................................. 325
Up/Down-Count Conditions in Phase Counting Mode 1 ........................................ 327
Up/Down-Count Conditions in Phase Counting Mode 2 ........................................ 328
Up/Down-Count Conditions in Phase Counting Mode 3 ........................................ 329
Up/Down-Count Conditions in Phase Counting Mode 4 ........................................ 330
TPU Interrupts......................................................................................................... 333
Section 11 8-Bit Timers (TMR)
Table 11.1 Pin Configuration .................................................................................................... 355
Table 11.2 8-Bit Timer Interrupt Sources ................................................................................. 370
Table 11.3 Timer Output Priorities ........................................................................................... 373
Table 11.4 Switching of Internal Clock and TCNT Operation ................................................. 374
Section 12 Watchdog Timer (WDT)
Table 12.1 Pin Configuration .................................................................................................... 379
Table 12.2 WDT Interrupt Source............................................................................................. 389
Rev. 6.00 Sep. 24, 2009 Page xliii of xlvi
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Table 13.1 Pin Configuration .................................................................................................... 397
Table 13.2 Relationships between N Setting in BRR and Bit Rate B ....................................... 418
Table 13.3 BRR Settings for Various Bit Rates (Asynchronous Mode) ................................... 419
Table 13.4 Maximum Bit Rate for Each Frequency (Asynchronous Mode)............................. 420
Table 13.5 Maximum Bit Rate with External Clock Input (Asynchronous Mode)................... 421
Table 13.6 BRR Settings for Various Bit Rates (Clocked Synchronous Mode) ....................... 422
Table 13.7 Maximum Bit Rate with External Clock Input (Clocked Synchronous Mode)....... 423
Table 13.8 Examples of Bit Rate for Various BRR Settings (Smart Card Interface Mode)
(When n = 0 and S = 372) ....................................................................................... 423
Table 13.9 Maximum Bit Rate at Various Frequencies (Smart Card Interface Mode)
(when S = 372)........................................................................................................ 424
Table 13.10 Serial Transfer Formats (Asynchronous Mode) ...................................................... 426
Table 13.11 SSR Status Flags and Receive Data Handling ........................................................ 433
Table 13.12 Interrupt Sources of Serial Communication Interface Mode................................... 465
Table 13.13 Interrupt Sources in Smart Card Interface Mode .................................................... 466
Section 14 I2C Bus Interface 2 (IIC2)
Table 14.1 I2C Bus Interface Pins ............................................................................................. 478
Table 14.2 Transfer Rate........................................................................................................... 481
Table 14.3 Interrupt Requests ................................................................................................... 509
Table 14.4 Time for Monitoring SCL ....................................................................................... 510
Section 15 A/D Converter
Table 15.1 Pin Configuration .................................................................................................... 515
Table 15.2 Analog Input Channels and Corresponding ADDR Registers ................................ 516
Table 15.3 A/D Conversion Time (Single Mode) ..................................................................... 525
Table 15.4 A/D Conversion Time (Scan Mode) ....................................................................... 526
Table 15.5 A/D Converter Interrupt Source .............................................................................. 527
Table 15.6 Analog Pin Specifications ....................................................................................... 531
Section 16 D/A Converter
Table 16.1 Pin Configuration .................................................................................................... 534
Table 16.2 D/A Conversion Control ......................................................................................... 536
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Table 17.1 Mode Types............................................................................................................. 541
Table 17.2 Transfer speed and Maximum Number of Transfer Bytes in Each Communications
Mode ....................................................................................................................... 542
Table 17.3 Contents of Message Length bits ............................................................................ 547
Rev. 6.00 Sep. 24, 2009 Page xliv of xlvi
REJ09B0099-0600
Table 17.4
Table 17.5
Table 17.6
Table 17.7
Control Bit Contents................................................................................................ 551
Control Field for Locked Slave Unit ....................................................................... 552
Pin Configuration .................................................................................................... 556
List of System Clock Division Ratio....................................................................... 559
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Table 18.1 Pin Configuration .................................................................................................... 611
Table 18.2 Limits for Settable Value ........................................................................................ 640
Table 18.3 Setting Range for TSEG1 and TSEG2 in BCR ....................................................... 642
Table 18.4 HCAN Interrupt Sources......................................................................................... 654
Table 18.5 Interval Limitation between TXPR and TXPR or between TXPR and TXCR ....... 660
Section 20 Flash Memory
Table 20.1 MD Pin Setting and Operating Mode...................................................................... 669
Table 20.2 Comparison of Programming Modes ...................................................................... 670
Table 20.3 Pin Configuration .................................................................................................... 675
Table 20.4 Register/Parameter and Target Mode...................................................................... 677
Table 20.5 Parameters and Target Modes ................................................................................. 685
Table 20.6 Division of User MAT Area.................................................................................... 697
Table 20.7 System Clock Frequency for Automatic-Bit-Rate Adjustment by This LSI ........... 700
Table 20.8 Executable MAT ..................................................................................................... 719
Table 20.9 (1) Useable Area for Programming in User Program Mode................................... 719
Table 20.9 (2) Useable Area for Erasure in User Program Mode............................................. 721
Table 20.9 (3) Useable Area for Programming in User Boot Mode......................................... 722
Table 20.9 (4) Useable Area for Erasure in User Boot Mode .................................................. 724
Table 20.10 Hardware Protection................................................................................................ 726
Table 20.11 Software Protection ................................................................................................. 727
Table 20.12 Setting Procedure of each Operation Mode of Programmer Mode ......................... 736
Table 20.13 Each Command in Programmer Mode .................................................................... 737
Table 20.14 Return Codes in Status-Read Mode ........................................................................ 739
Table 20.15 True Value Table of Status Polling Output ............................................................. 739
Table 20.16 Inquiry and Selection Commands ........................................................................... 745
Table 20.17 Programming/Erasing Command ............................................................................ 756
Table 20.18 Status Code.............................................................................................................. 766
Table 20.19 Error Code............................................................................................................... 766
Table 20.20 AC Characteristics in Memory Read Mode ............................................................ 767
Table 20.21 AC Characteristics in Transition from Memory-Read Mode to Other Mode.......... 768
Table 20.22 AC Characteristics in Memory-Read Mode ............................................................ 769
Table 20.23 AC Characteristics in Auto-Program Mode ............................................................ 770
Table 20.24 AC Characteristic in Auto-Erase Mode................................................................... 771
Rev. 6.00 Sep. 24, 2009 Page xlv of xlvi
REJ09B0099-0600
Table 20.25 AC Characteristics in Status-Read Mode................................................................ 772
Table 20.26 Transition Time Rules before Command Wait State .............................................. 773
Section 21 Clock Pulse Generator
Table 21.1 Damping Resistance Value ..................................................................................... 780
Table 21.2 Crystal Resonator Characteristics ........................................................................... 781
Table 21.3 External Clock Input Conditions............................................................................. 782
Section 22 Power-Down Modes
Table 22.1 LSI Internal States in Each Mode ........................................................................... 791
Table 22.2 Power-Down Mode Transition Conditions ............................................................. 795
Table 22.3 Oscillation Settling Time Settings........................................................................... 802
Table 22.4 φ Pin State in Each Processing State ....................................................................... 807
Section 24
Table 24.1
Table 24.2
Table 24.2
Table 24.2
Table 24.3
Table 24.4
Table 24.5
Table 24.6
Table 24.6
Table 24.7
Table 24.8
Table 24.9
Table 24.10
Table 24.11
Table 24.12
Table 24.13
Electrical Characteristics
Absolute Maximum Ratings.................................................................................... 873
DC Characteristics (1)............................................................................................. 874
DC Characteristics (2)............................................................................................. 876
DC Characteristics (3)............................................................................................. 878
Permissible Output Currents ................................................................................... 880
Bus Drive Characteristics........................................................................................ 881
Power-On/Off Timing............................................................................................. 882
Clock Timing (1)..................................................................................................... 884
Clock Timing (2)..................................................................................................... 885
Control Signal Timing............................................................................................. 886
Bus Timing.............................................................................................................. 889
Timing of On-Chip Peripheral Modules ................................................................. 895
I2C Bus Interface 2 Timing...................................................................................... 901
A/D Conversion Characteristics.............................................................................. 903
D/A Conversion Characteristics.............................................................................. 904
Flash Memory Characteristics................................................................................. 905
Rev. 6.00 Sep. 24, 2009 Page xlvi of xlvi
REJ09B0099-0600
Section 1 Overview
Section 1 Overview
1.1
Features
• High-speed H8S/2000 central processing unit with an internal 16-bit architecture
⎯ Upward-compatible with H8/300 and H8/300H CPUs on an object level
⎯ Sixteen 16-bit general registers
⎯ 65 basic instructions
• Various peripheral functions
⎯ PC break controller
⎯ Data transfer controller (DTC)
⎯ 16-bit timer-pulse unit (TPU)
⎯ 8-bit timer (TMR)
⎯ Watchdog timer (WDT)
⎯ Serial communication interface (SCI)
⎯ I2C bus interface 2 (IIC2)
⎯ 10-bit A/D converter
⎯ 8-bit D/A converter
⎯ IEBusTM controller (IEB) (H8S/2552, H8S/2551)
⎯ Controller area network (HCAN) (H8S/2556)
• On-chip memory
ROM
Part No.
ROM
RAM
Flash memory
version
HD64F2556
512 kbytes
32 kbytes
HD64F2552
512 kbytes
32 kbytes
HD64F2551
384 kbytes
24 kbytes
HD64F2506
512 kbytes
32 kbytes
HD64F2505
384 kbytes
32 kbytes
Remarks
Rev. 6.00 Sep. 24, 2009 Page 1 of 928
REJ09B0099-0600
Section 1 Overview
• General I/O ports
Support two types of the port with different power supply sources
⎯ H8S/2556 Group
I/O pins: 102
HCAN pins: 2 (one input and one output)
Input pins: 16
⎯ H8S/2552 Group and H8S/2506 Group
I/O pins: 104
Input port: 16
• Supports various power-down modes
• Compact package
2
Body Size
Pin Pitch
Package
Code*
QFP-144
FP-144J/FP-144JV
20.0 × 20.0 mm
0.5 mm
LFBGA-176*1
BP-176V
13.0 × 13.0 mm
0.8 mm
Notes: 1. Available only in the H8S/2552 Group and H8S/2506 Group.
2. Package code ending in the letter V designate Pb-free Product.
1.2
Internal Block Diagram
Figures 1.1 to 1.3 show the internal block diagrams.
Rev. 6.00 Sep. 24, 2009 Page 2 of 928
REJ09B0099-0600
Port A
PA7/A23
PA6/A22
PA5/A21
PA4/A20
PA3/A19
PA2/A18
PA1/A17
PA0/A16
Port B
PB7/A15
PB6/A14
PB5/A13
PB4/A12
PB3 / A11
PB2/A10
PB1/A9
PB0/A8
Port C
PC7/A7
PC6/A6
PC5/A5
PC4/A4
PC3/A3
PC2/A2
PC1/A1
PC0/A0
Port 3
Port E
P37/TxD4
P36/RxD4
P35/SCK1/SCK4/SCL0/IRQ5
P34/RxD1/SDA0
P33/TxD1/SCL1
P32/SCK0/SDA1/IRQ4
P31/RxD0
P30/TxD0
Port 9
Port D
P97/AN15/DA1
P96/AN14/DA0
P95/AN13
P94/AN12
P93/AN11
P92/AN10
P91/AN9
P90/AN8
PLL for
system clock
H8S/2000 CPU
Sub clock
pulse
generator
Bus controller
Internal data bus
Internal address bus
System
clock
pulse
generator
Port F
PF7/φ
PF6/AS
PF5/RD
PF4/HWR
PF3/LWR/ADTRG/IRQ3
PF2/WAIT
PF1/BACK/BUZZ
PF0/BREQ/IRQ2
PE7/D7
PE6/D6
PE5/D5
PE4/D4
PE3/D3
PE2/D2
PE1/D1
PE0/D0
MD2
MD1
MD0
EXTAL
XTAL
OSC1
OSC2
STBY
RES
NMI
PD7/D15
PD6/D14
PD5/D13
PD4/D12
PD3/D11
PD2/D10
PD1/D9
PD0/D8
TEST
P1VCC
P1VCC
P2VCC
VSS
VSS
VSS
VCL
VCC
VSS
VSS
Section 1 Overview
Interrupt controller
PC break controller
(2 channels)
WDT0
8-bit timer (4 channels)
ROM
Port 1
P10 / TIOCA0
P11 / TIOCB0
P12 / TIOCC0 / TCLKA
P13 / TIOCD0 / TCLKB
P14 / TIOCA1/IRQ0
P15 / TIOCB1 / TCLKC
P16 / TIOCA2/IRQ1
P17 / TIOCB2/ TCLKD
WDT1 (sub
clock operation)
Peripheral data bus
Peripheral address bus
DTC
Port G
PG4/CS0
PG1/CS3/IRQ7
PG0/IRQ6
SCI (5 channels)
RAM
2
I C bus interface 2
Port 2
P52/SCK2
P51/RxD2
P50/TxD2
Port 5
D/A converter (2 channels)
P27/TIOCB5
P26/TIOCA5
P25/TIOCB4
P24/TIOCA4
P23/TIOCD3
P22/TIOCC3
P21/TIOCB3
P20/TIOCA3
TPU (6 channels)
A/D converter (16 channels)
Port 7
Port 4
P47/AN7
P46/AN6
P45/AN5
P44/AN4
P43/AN3
P42/AN2
P41/AN1
P40/AN0
Port J
PJ7
PJ6
PJ5
PJ4
PJ3
PJ2
PJ1
PJ0
HRxD
HTxD
Vref
AVCC
AVSS
PH7
PH6
PH5
PH4
PH3
PH2
PH1
PH0
Port H
P70/TMRI01/TMCI01/CS4
P71/TMRI23/TMCI23/CS5
P72/TMO0/CS6
P73/TMO1/CS7
P74/TMO2/MRES
P75/T MO 3/SCK3
P76/RxD3
P77/TxD3
HCAN (1 channel)
Figure 1.1 Internal Block Diagram of H8S/2556 Group
Rev. 6.00 Sep. 24, 2009 Page 3 of 928
REJ09B0099-0600
Port A
Port B
PB7/A15
PB6/A14
PB5/A13
PB4/A12
PB3 / A11
PB2/A10
PB1/A9
PB0/A8
Port C
PC7/A7
PC6/A6
PC5/A5
PC4/A4
PC3/A3
PC2/A2
PC1/A1
PC0/A0
Port 3
H8S/2000 CPU
Sub clock
pulse
generator
Bus controller
Internal data bus
Internal address bus
Port F
System
clock
pulse
generator
Interrupt controller
P37/TxD4
P36/RxD4
P35/SCK1/SCK4/SCL0/IRQ5
P34/RxD1/SDA0
P33/TxD1/SCL1
P32/SCK0/SDA1/IRQ4
P31/RxD0
P30/TxD0
P97/AN15/DA1
P96/AN14/DA0
P95/AN13
P94/AN12
P93/AN11
P92/AN10
P91/AN9
P90/AN8
DTC
PC break controller
(2 channels)
WDT0
ROM
WDT1 (sub
clock operation)
8-bit timer (4 channels)
Port 1
P10/TIOCA0
P11/TIOCB0
P12/TIOCC0/TCLKA
P13/TIOCD0/TCLKB
P14/TIOCA1/IRQ0
P15/TIOCB1/TCLKC
P16/TIOCA2/IRQ1
P17/TIOCB2/TCLKD
PA7/A23
PA6/A22
PA5/A21
PA4/A20
PA3/A19
PA2/A18
PA1/A17
PA0/A16
Port 9
Port E
Peripheral data bus
Peripheral address bus
PG4/CS0
PG3/Rx/CS1
PG2/Tx/CS2
PG1/CS3/IRQ7
PG0/IRQ6
Port D
PLL for
system clock
Port G
PF7/φ
PF6/AS
PF5/RD
PF4/HWR
PF3/LWR/ADTRG/IRQ3
PF2/WAIT
PF1/BACK/BUZZ
PF0/BREQ/IRQ2
PE7 / D7
PE6 / D6
PE5 / D5
PE4 / D4
PE3 / D3
PE2 / D2
PE1 / D1
PE0 / D0
MD2
MD1
MD0
EXTAL
XTAL
OSC1
OSC2
STBY
RES
NMI
PD7 / D15
PD6 / D14
PD5 / D13
PD4 / D12
PD3 / D11
PD2 / D10
PD1 / D9
PD0 / D8
TEST
P1VCC
P1VCC
P2VCC
VSS
VSS
VSS
VCL
VCC
VSS
VSS
Section 1 Overview
SCI (5 channels)
RAM
2
I C bus interface 2
Port 2
P52/SCK2
P51/RxD2
P50/TxD2
Port 5
D/A converter (2 channels)
P27/TIOCB5
P26/TIOCA5
P25/TIOCB4
P24/TIOCA4
P23/TIOCD3
P22/TIOCC3
P21/TIOCB3
P20/TIOCA3
TPU (6 channels)
A/D converter (16 channels)
Port 4
P47 / AN7
P46 / AN6
P45 / AN5
P44 / AN4
P43 / AN3
P42 / AN2
P41 / AN1
P40 / AN0
PJ7
PJ6
PJ5
PJ4
PJ3
PJ2
PJ1
PJ0
Port 7
P70 / T M R I 0 1 / T M C I 0 1 /CS4
P71 / T M R I 2 3 / T M C I 2 3 /CS5
P72 / TMO0/CS6
P73 / TMO1/CS7
P74 / T M O 2 / MRES
P75 / T M O 3 / SCK3
P76 /RxD3
P77 / TxD3
Port J
Vref
AVCC
AVSS
Port H
PH7
PH6
PH5
PH4
PH3
PH2
PH1
PH0
IEB (1 channel)
Figure 1.2 Internal Block Diagram of H8S/2552 Group
Rev. 6.00 Sep. 24, 2009 Page 4 of 928
REJ09B0099-0600
Port A
Port B
PB7/A15
PB6/A14
PB5/A13
PB4/A12
PB3 / A11
PB2/A10
PB1/A9
PB0/A8
Port C
PC7/A7
PC6/A6
PC5/A5
PC4/A4
PC3/A3
PC2/A2
PC1/A1
PC0/A0
Port 3
H8S/2000 CPU
Sub clock
pulse
generator
Bus controller
Internal data bus
Internal address bus
Port F
System
clock
pulse
generator
Interrupt controller
P37/TxD4
P36/RxD4
P35/SCK1/SCK4/SCL0/IRQ5
P34/RxD1/SDA0
P33/TxD1/SCL1
P32/SCK0/SDA1/IRQ4
P31/RxD0
P30/TxD0
P97/AN15/DA1
P96/AN14/DA0
P95/AN13
P94/AN12
P93/AN11
P92/AN10
P91/AN9
P90/AN8
DTC
PC break controller
(2 channels)
WDT
ROM
WDT1 (sub
clock operation)
8-bit timer (4 channels)
Port 1
P10/TIOCA0
P11/TIOCB0
P12/TIOCC0/TCLKA
P13/TIOCD0/TCLKB
P14/TIOCA1/IRQ0
P15/TIOCB1/TCLKC
P16/TIOCA2/IRQ1
P17/TIOCB2/TCLKD
PA7/A23
PA6/A22
PA5/A21
PA4/A20
PA3/A19
PA2/A18
PA1/A17
PA0/A16
Port 9
Port E
Peripheral data bus
Peripheral address bus
PG4/CS0
PG3/CS1
PG2/CS2
PG1/CS3/IRQ7
PG0/IRQ6
Port D
PLL for
system clock
Port G
PF7/φ
PF6/AS
PF5/RD
PF4/HWR
PF3/LWR/ADTRG/IRQ3
PF2/WAIT
PF1/BACK/BUZZ
PF0/BREQ/IRQ2
PE7 / D7
PE6 / D6
PE5 / D5
PE4 / D4
PE3 / D3
PE2 / D2
PE1 / D1
PE0 / D0
MD2
MD1
MD0
EXTAL
XTAL
OSC1
OSC2
STBY
RES
NMI
PD7 / D15
PD6 / D14
PD5 / D13
PD4 / D12
PD3 / D11
PD2 / D10
PD1 / D9
PD0 / D8
TEST
P1VCC
P1VCC
P2VCC
VSS
VSS
VSS
VCL
VCC
VSS
VSS
Section 1 Overview
SCI (5 channels)
RAM
2
I C bus interface 2
Port 2
P52/SCK2
P51/RxD2
P50/TxD2
Port 5
D/A converter (2 channels)
P27/TIOCB5
P26/TIOCA5
P25/TIOCB4
P24/TIOCA4
P23/TIOCD3
P22/TIOCC3
P21/TIOCB3
P20/TIOCA3
TPU (6 channels)
Port 4
P47 / AN7
P46 / AN6
P45 / AN5
P44 / AN4
P43 / AN3
P42 / AN2
P41 / AN1
P40 / AN0
PJ7
PJ6
PJ5
PJ4
PJ3
PJ2
PJ1
PJ0
Port 7
P70 / T M R I 0 1 / T M C I 0 1 /CS4
P71 / T M R I 2 3 / T M C I 2 3 /CS5
P72 / TMO0/CS6
P73 / TMO1/CS7
P74 / T M O 2 / MRES
P75 / T M O 3 / SCK3
P76 /RxD3
P77 / TxD3
Port J
Vref
AVCC
AVSS
Port H
PH7
PH6
PH5
PH4
PH3
PH2
PH1
PH0
A/D converter (16 channels)
Figure 1.3 Internal Block Diagram of H8S/2506 Group
Rev. 6.00 Sep. 24, 2009 Page 5 of 928
REJ09B0099-0600
Section 1 Overview
1.3
Pin Arrangements
1.3.1
Pin Arrangements
72
71
70
69
68
67
66
65
64
63
62
61
60
59
58
57
56
55
54
53
52
51
50
49
48
47
46
45
44
43
42
41
40
39
38
37
FP-144J/FP-144JV
(top view)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
Vref
P40/AN0
P41/AN1
P42/AN2
P43/AN3
AVss
P44/AN4
P45/AN5
P46/AN6
P47/AN7
P90/AN8
P91/AN9
P92/AN10
P93/AN11
P94/AN12
P95/AN13
P96/AN14/DA0
P97/AN15/DA1
Vss
PJ0
PJ1
PJ2
PJ3
PJ4
PJ5
PJ6
PJ7
PH0
PH1
PH2
PH3
PH4
PH5
PH6
PH7
PA7/A23
PE5/D5
PE6/D6
PE7/D7
PD0/D8
PD1/D9
PD2/D10
PD3/D11
PD4/D12
PD5/D13
PD6/D14
PD7/D15
Vss
PC0/A0
P1Vcc
PC1/A1
PC2/A2
PC3/A3
PC4/A4
PC5/A5
PC6/A6
PC7/A7
PB0/A8
PB1/A9
PB2/A10
PB3/A11
PB4/A12
PB5/A13
PB6/A14
PB7/A15
PA0/A16
PA1/A17
PA2/A18
PA3/A19
PA4/A20
PA5/A21
PA6/A22
P17/TIOCB2/TCLKD
P16/TIOCA2/IRQ1
P15/TIOCB1/TCLKC
P14/TIOCA1/IRQ0
P13/TIOCD0/TCLKB
P12/TIOCC0/TCLKA
P11/TIOCB0
P10/TIOCA0
Vss
P2Vcc
P37/TxD4
P36/RxD4
P35/SCK1/SCK4/SCL0/IRQ5
P34/RxD1/SDA0
P33/TxD1/SCL1
P32/SCK0/SDA1/IRQ4
P31/RxD0
P30/TxD0
P77/TxD3
P76/RxD3
P75/TMO3/SCK3
P74/TMO2/MRES
P73/TMO1/CS7
P72/TMO0/CS6
P71/TMRI23/TMCI23/CS5
P70/TMRI01/TMCI01/CS4
PG4/CS0
HRxD
HTxD
PG1/CS3/IRQ7
PG0/IRQ6
PE0/D0
PE1/D1
PE2/D2
PE3/D3
PE4/D4
108
107
106
105
104
103
102
101
100
99
98
97
96
95
94
93
92
91
90
89
88
87
86
85
84
83
82
81
80
79
78
77
76
75
74
73
P27/TIOCB5
P26/TIOCA5
P25/TIOCB4
P24/TIOCA4
P23/TIOCD3
P22/TIOCC3
P21/TIOCB3
P20/TIOCA3
RES
STBY
MD1
MD0
Vcc
EXTAL
Vss
XTAL
MD2
NMI
OSC1
OSC2
VCL*
TEST
Vss
PF7/φ
P1Vcc
PF6/AS
PF5/RD
PF4/HWR
PF3/LWR/ADTRG/IRQ3
PF2/WAIT
PF1/BACK/BUZZ
PF0/BREQ/IRQ2
P52/SCK2
P51/RxD2
P50/TxD2
AVcc
Figures 1.4 to 1.8 show the pin arrangement.
Notes: * An external capacitor must be connected to the VCL pin. (Do not connect
to the system power.)
1. Powers within specified voltages must be supplied to all power supply pins.
If not, this LSI may not operate correctly.
2. Capacitors for stabilization should be inserted near the pin between the
power supply pins (P1Vcc (14, 84), P2Vcc (118), Vcc (96)) and Vss pin.
For an example of connection, see section 21.9.2, Note on Board Design.
88
0.47 μF
Figure 1.4 Pin Arrangement of H8S/2556 Group (FP-144J and FP-144JV)
Rev. 6.00 Sep. 24, 2009 Page 6 of 928
REJ09B0099-0600
72
71
70
69
68
67
66
65
64
63
62
61
60
59
58
57
56
55
54
53
52
51
50
49
48
47
46
45
44
43
42
41
40
39
38
37
FP-144J/FP-144JV
(top view)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
Vref
P40/AN0
P41/AN1
P42/AN2
P43/AN3
AVss
P44/AN4
P45/AN5
P46/AN6
P47/AN7
P90/AN8
P91/AN9
P92/AN10
P93/AN11
P94/AN12
P95/AN13
P96/AN14/DA0
P97/AN15/DA1
Vss
PJ0
PJ1
PJ2
PJ3
PJ4
PJ5
PJ6
PJ7
PH0
PH1
PH2
PH3
PH4
PH5
PH6
PH7
PA7/A23
PE5/D5
PE6/D6
PE7/D7
PD0/D8
PD1/D9
PD2/D10
PD3/D11
PD4/D12
PD5/D13
PD6/D14
PD7/D15
Vss
PC0/A0
P1Vcc
PC1/A1
PC2/A2
PC3/A3
PC4/A4
PC5/A5
PC6/A6
PC7/A7
PB0/A8
PB1/A9
PB2/A10
PB3/A11
PB4/A12
PB5/A13
PB6/A14
PB7/A15
PA0/A16
PA1/A17
PA2/A18
PA3/A19
PA4/A20
PA5/A21
PA6/A22
P17/TIOCB2/TCLKD
P16/TIOCA2/IRQ1
P15/TIOCB1/TCLKC
P14/TIOCA1/IRQ0
P13/TIOCD0/TCLKB
P12/TIOCC0/TCLKA
P11/TIOCB0
P10/TIOCA0
Vss
P2Vcc
P37/TxD4
P36/RxD4
P35/SCK1/SCK4/SCL0/IRQ5
P34/RxD1/SDA0
P33/TxD1/SCL1
P32/SCK0/SDA1/IRQ4
P31/RxD0
P30/TxD0
P77/TxD3
P76/RxD3
P75/TMO3/SCK3
P74/TMO2/MRES
P73/TMO1/CS7
P72/TMO0/CS6
P71/TMRI23/TMCI23/CS5
P70/TMRI01/TMCI01/CS4
PG4/CS0
PG3/Rx/CS1
PG2/Tx/CS2
PG1/CS3/IRQ7
PG0/IRQ6
PE0/D0
PE1/D1
PE2/D2
PE3/D3
PE4/D4
108
107
106
105
104
103
102
101
100
99
98
97
96
95
94
93
92
91
90
89
88
87
86
85
84
83
82
81
80
79
78
77
76
75
74
73
P27/TIOCB5
P26/TIOCA5
P25/TIOCB4
P24/TIOCA4
P23/TIOCD3
P22/TIOCC3
P21/TIOCB3
P20/TIOCA3
RES
STBY
MD1
MD0
Vcc
EXTAL
Vss
XTAL
MD2
NMI
OSC1
OSC2
VCL*
TEST
Vss
PF7/φ
P1Vcc
PF6/AS
PF5/RD
PF4/HWR
PF3/LWR/ADTRG/IRQ3
PF2/WAIT
PF1/BACK/BUZZ
PF0/BREQ/IRQ2
P52/SCK2
P51/RxD2
P50/TxD2
AVcc
Section 1 Overview
Notes: * An external capacitor must be connected to the VCL pin. (Do not connect
to the system power.)
1. Powers within specified voltages must be supplied to all power supply pins.
If not, this LSI may not operate correctly.
2. Capacitors for stabilization should be inserted near the pin between the
power supply pins (P1Vcc (14, 84), P2Vcc (118), Vcc (96)) and Vss pin.
For an example of connection, see section 21.9.2, Note on Board Design.
88
0.47 μF
Figure 1.5 Pin Arrangement of H8S/2552 Group (FP-144J and FP-144JV)
Rev. 6.00 Sep. 24, 2009 Page 7 of 928
REJ09B0099-0600
72
71
70
69
68
67
66
65
64
63
62
61
60
59
58
57
56
55
54
53
52
51
50
49
48
47
46
45
44
43
42
41
40
39
38
37
FP-144J/FP-144JV
(top view)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
Vref
P40/AN0
P41/AN1
P42/AN2
P43/AN3
AVss
P44/AN4
P45/AN5
P46/AN6
P47/AN7
P90/AN8
P91/AN9
P92/AN10
P93/AN11
P94/AN12
P95/AN13
P96/AN14/DA0
P97/AN15/DA1
Vss
PJ0
PJ1
PJ2
PJ3
PJ4
PJ5
PJ6
PJ7
PH0
PH1
PH2
PH3
PH4
PH5
PH6
PH7
PA7/A23
PE5/D5
PE6/D6
PE7/D7
PD0/D8
PD1/D9
PD2/D10
PD3/D11
PD4/D12
PD5/D13
PD6/D14
PD7/D15
Vss
PC0/A0
P1Vcc
PC1/A1
PC2/A2
PC3/A3
PC4/A4
PC5/A5
PC6/A6
PC7/A7
PB0/A8
PB1/A9
PB2/A10
PB3/A11
PB4/A12
PB5/A13
PB6/A14
PB7/A15
PA0/A16
PA1/A17
PA2/A18
PA3/A19
PA4/A20
PA5/A21
PA6/A22
P17/TIOCB2/TCLKD
P16/TIOCA2/IRQ1
P15/TIOCB1/TCLKC
P14/TIOCA1/IRQ0
P13/TIOCD0/TCLKB
P12/TIOCC0/TCLKA
P11/TIOCB0
P10/TIOCA0
Vss
P2Vcc
P37/TxD4
P36/RxD4
P35/SCK1/SCK4/SCL0/IRQ5
P34/RxD1/SDA0
P33/TxD1/SCL1
P32/SCK0/SDA1/IRQ4
P31/RxD0
P30/TxD0
P77/TxD3
P76/RxD3
P75/TMO3/SCK3
P74/TMO2/MRES
P73/TMO1/CS7
P72/TMO0/CS6
P71/TMRI23/TMCI23/CS5
P70/TMRI01/TMCI01/CS4
PG4/CS0
PG3/CS1
PG2/CS2
PG1/CS3/IRQ7
PG0/IRQ6
PE0/D0
PE1/D1
PE2/D2
PE3/D3
PE4/D4
108
107
106
105
104
103
102
101
100
99
98
97
96
95
94
93
92
91
90
89
88
87
86
85
84
83
82
81
80
79
78
77
76
75
74
73
P27/TIOCB5
P26/TIOCA5
P25/TIOCB4
P24/TIOCA4
P23/TIOCD3
P22/TIOCC3
P21/TIOCB3
P20/TIOCA3
RES
STBY
MD1
MD0
Vcc
EXTAL
Vss
XTAL
MD2
NMI
OSC1
OSC2
VCL*
TEST
Vss
PF7/φ
P1Vcc
PF6/AS
PF5/RD
PF4/HWR
PF3/LWR/ADTRG/IRQ3
PF2/WAIT
PF1/BACK/BUZZ
PF0/BREQ/IRQ2
P52/SCK2
P51/RxD2
P50/TxD2
AVcc
Section 1 Overview
Notes: * An external capacitor must be connected to the VCL pin. (Do not connect
to the system power.)
1. Powers within specified voltages must be supplied to all power supply pins.
If not, this LSI may not operate correctly.
2. Capacitors for stabilization should be inserted near the pin between the
power supply pins (P1Vcc (14, 84), P2Vcc (118), Vcc (96)) and Vss pin.
For an example of connection, see section 21.9.2, Note on Board Design.
88
0.47 μF
Figure 1.6 Pin Arrangement of H8S/2506 Group (FP-144J and FP-144JV)
Rev. 6.00 Sep. 24, 2009 Page 8 of 928
REJ09B0099-0600
Section 1 Overview
A
B
C
D
E
F
G
H
J
L
M
N
P
R
Vss
PF6/
AS
PF3/
LWR/
ADTRG/
IRQ3
PF0/
BREQ/
IRQ2
P50/
TxD2
Vref
15
OSC1
Vss
PF5/
RD
PF1/
BACK/
BUZZ
P51/
RxD2
AVcc
Vref
14
MD2
VCL
PF7/
φ
PF4/
HWR
P52/
SCK2
AVcc
AVcc
Vref
13
NMI
TEST
P1Vcc
PF2/
WAIT
AVcc
P40/
AN0
P41/
AN1
AVss
12
P12/
P11/
TIOCC0/
TIOCB0 TCLKA
P42/
AN2
P44/
AN4
P43/
AN3
AVss
11
Vss
P2Vcc
P2Vcc
P90/
AN8
P47/
AN7
P45/
AN5
P46/
AN6
10
P36/
RxD4
P2Vcc
P2Vcc
P94/
AN12
P93/
AN11
P91/
AN9
P92/
AN10
9
P97/
AN15/
DA1
P96/
AN14/
DA0
Vss
P95/
AN13
8
15
P17/
TIOCB2/
TCLKD
P26/
TIOCA5
P23/
TIOCD3
P20/
TIOCA3
MD1
EXTAL
XTAL
Vss
OSC2
14
Vss
P27/
TIOCB5
P25/
TIOCB4
P21/
TIOCB3
STBY
Vcc
Vss
Vss
13
Vss
P15/
P16/
TIOCB1/ TIOCA2/
TCLKC
IRQ1
P22/
TIOCC3
RES
Vss
Vss
12
Vss
P13/
P14/
TIOCD0/ TIOCA1/
TCLKB
IRQ0
P24/
TIOCA4
MD0
Vss
Vss
11
Vss
P10/
TIOCA0
10
Vss
9
P37/
TxD4
K
8
P33/
TxD1/
SCL1
P32/
SCK0/
SDA1/
IRQ4
P34/
RxD1/
SDA0
P35/
SCK1/
SCK4/
SCL0/
IRQ5
7
P77/
TxD3
P76/
RxD3
P30/
TxD0
P31/
RxD0
PJ1
PJ0
Vss
Vss
7
6
P73/
TMO1/
CS7
P72/
TMO0/
CS6
P74/
TMO2/
MRES
P75/
TMO3/
SCK3
PJ4
PJ3
PJ2
Vss
6
5
P70/
TMRI01/
TMCI01/
CS4
PG4/
CS0
P71/
TMRI23/
TMCI23/
CS5
PG3/
Rx/
CS1
PH1
PJ7
PJ6
PJ5
5
4
PG2/
Tx/
CS2
PG1/
CS3/
IRQ7
PG0/
IRQ6
PE1/
D1
PD4/
D12
PC0/
A0
P1Vcc
P1Vcc
PC3/
A3
PC7/
A7
PB6/
A14
PA3/
A19
PH4
PH2
PH0
4
3
PE0/
D0
PE2/
D2
PE6/
D6
PD1/
D9
PD6/
D14
P1Vcc
P1Vcc
P1Vcc
PC4/
A4
PB0/
A8
PB3/
A11
PA1/
A17
PH7
PH5
PH3
3
2
PE3/
D3
PE4/
D4
PD0/
D8
PD3/
D11
PD7/
D15
Vss
Vss
PC2/
A2
PC6/
A6
PB2/
A10
PB5/
A13
PA0/
A16
PA4/
A20
PA6/
A22
PH6
2
1
PE5/
D5
PE7/
D7
PD2/
D10
PD5/
D13
Vss
Vss
Vss
PC1/
A1
PC5/
A5
PB1/
A9
PB4/
A12
PB7/
A15
PA2/
A18
PA5/
A21
PA7/
A23
1
A
B
C
D
E
F
G
H
J
K
L
M
N
P
R
INDEX
BP-176V
(Top View)
Notes: 1. Supply given voltages to all the power pins. If not, this LSI may not operate correctly.
2. An external capacitor must be connected to the VCL pin. (Do not apply system power.)
3. External capacitors must be connected between a Vss pin and the following pins:
each supply power pin, P1Vcc (G3, K12), P2Vcc (D9), Vcc (F14). For an example of
connection, see section 21.9.2, Note on Board Design.
J13
0.47μF
Figure 1.7 Pin Arrangement of H8S/2552 Group (BP-176V)
Rev. 6.00 Sep. 24, 2009 Page 9 of 928
REJ09B0099-0600
Section 1 Overview
A
B
C
D
E
F
G
H
J
L
M
N
P
R
Vss
PF6/
AS
PF3/
LWR/
ADTRG/
IRQ3
PF0/
BREQ/
IRQ2
P50/
TxD2
Vref
15
OSC1
Vss
PF5/
RD
PF1/
BACK/
BUZZ
P51/
RxD2
AVcc
Vref
14
MD2
VCL
PF7/
φ
PF4/
HWR
P52/
SCK2
AVcc
AVcc
Vref
13
NMI
TEST
P1Vcc
PF2/
WAIT
AVcc
P40/
AN0
P41/
AN1
AVss
12
P12/
P11/
TIOCC0/
TIOCB0 TCLKA
P42/
AN2
P44/
AN4
P43/
AN3
AVss
11
Vss
P2Vcc
P2Vcc
P90/
AN8
P47/
AN7
P45/
AN5
P46/
AN6
10
P37/
TxD4
P36/
RxD4
P2Vcc
P2Vcc
P94/
AN12
P93/
AN11
P91/
AN9
P92/
AN10
9
8
P33/
TxD1/
SCL1
P32/
SCK0/
SDA1/
IRQ4
P34/
RxD1/
SDA0
P35/
SCK1/
SCK4/
SCL0/
IRQ5
P97/
AN15/
DA1
P96/
AN14/
DA0
Vss
P95/
AN13
8
7
P77/
TxD3
P76/
RxD3
P30/
TxD0
P31/
RxD0
PJ1
PJ0
Vss
Vss
7
6
P73/
TMO1/
CS7
P72/
TMO0/
CS6
P74/
TMO2/
MRES
P75/
TMO3/
SCK3
PJ4
PJ3
PJ2
Vss
6
5
P70/
TMRI01/
TMCI01/
CS4
PG4/
CS0
P71/
TMRI23/
TMCI23/
CS5
PG3/
CS1
PH1
PJ7
PJ6
PJ5
5
4
PG2/
CS2
PG1/
CS3/
IRQ7
PG0/
IRQ6
PE1/
D1
PD4/
D12
PC0/
A0
P1Vcc
P1Vcc
PC3/
A3
PC7/
A7
PB6/
A14
PA3/
A19
PH4
PH2
PH0
4
3
PE0/
D0
PE2/
D2
PE6/
D6
PD1/
D9
PD6/
D14
P1Vcc
P1Vcc
P1Vcc
PC4/
A4
PB0/
A8
PB3/
A11
PA1/
A17
PH7
PH5
PH3
3
2
PE3/
D3
PE4/
D4
PD0/
D8
PD3/
D11
PD7/
D15
Vss
Vss
PC2/
A2
PC6/
A6
PB2/
A10
PB5/
A13
PA0/
A16
PA4/
A20
PA6/
A22
PH6
2
1
PE5/
D5
PE7/
D7
PD2/
D10
PD5/
D13
Vss
Vss
Vss
PC1/
A1
PC5/
A5
PB1/
A9
PB4/
A12
PB7/
A15
PA2/
A18
PA5/
A21
PA7/
A23
1
A
B
C
D
E
F
G
H
J
K
L
M
N
P
R
15
P17/
TIOCB2/
TCLKD
P26/
TIOCA5
P23/
TIOCD3
P20/
TIOCA3
MD1
EXTAL
XTAL
Vss
OSC2
14
Vss
P27/
TIOCB5
P25/
TIOCB4
P21/
TIOCB3
STBY
Vcc
Vss
Vss
13
Vss
P15/
P16/
P22/
TIOCB1/ TIOCA2/
TIOCC3
TCLKC
IRQ1
RES
Vss
Vss
12
Vss
P13/
P14/
P24/
TIOCD0/ TIOCA1/
TIOCA4
TCLKB
IRQ0
MD0
Vss
Vss
11
Vss
P10/
TIOCA0
10
Vss
9
INDEX
K
BP-176V
(Top view)
Notes: 1. Supply given voltages to all the power pins. If not, this LSI may not operate correctly.
2. An external capacitor must be connected to the VCL pin. (Do not apply system power.)
3. External capacitors must be connected between a Vss pin and the following pins:
each supply power pin, P1Vcc (G3, K12), P2Vcc (D9), Vcc (F14). For an example of
connection, see section 21.9.2, Note on Board Design.
Figure 1.8 Pin Arrangement of H8S/2506 Group (BP-176V)
Rev. 6.00 Sep. 24, 2009 Page 10 of 928
REJ09B0099-0600
J13
0.47μF
Section 1 Overview
1.3.2
Pin Arrangements in Each mode
Pin arrangements in each mode are shown below.
Table 1.1
Pin Arrangements in Operating Mode
Pin No.
Pin Name
FP-144J,
FP-144JV BP-176V*4 Mode 6
Mode 7
Power
Supply
Flash Memory
Programmer Mode*5 Source
1
A1
PE5/D5
PE5
OE
P1Vcc
2
C3
PE6/D6
PE6
WE
P1Vcc
3
B1
PE7/D7
PE7
CE
P1Vcc
4
C2
D8
PD0
D0
P1Vcc
5
D3
D9
PD1
D1
P1Vcc
6
C1
D10
PD2
D2
P1Vcc
7
D2
D11
PD3
D3
P1Vcc
8
E4
D12
PD4
D4
P1Vcc
9
D1
D13
PD5
D5
P1Vcc
10
E3
D14
PD6
D6
P1Vcc
11
E2
D15
PD7
D7
P1Vcc
12
G2, G1,
Vss
F2, F1, E1
Vss
Vss
Vss
13
F4
PC0
A0
P1Vcc
14
H4, H3,
P1Vcc
G4, G3, F3
P1Vcc
Vcc
P1Vcc
15
H1
PC1/A1
PC1
A1
P1Vcc
16
H2
PC2/A2
PC2
A2
P1Vcc
17
J4
PC3/A3
PC3
A3
P1Vcc
18
J3
PC4/A4
PC4
A4
P1Vcc
19
J1
PC5/A5
PC5
A5
P1Vcc
PC0/A0
Rev. 6.00 Sep. 24, 2009 Page 11 of 928
REJ09B0099-0600
Section 1 Overview
Pin No.
Pin Name
Mode 7
Flash Memory
Programmer Mode*5
Power
Supply
Source
PC6/A6
PC6
A6
P1Vcc
K4
PC7/A7
PC7
A7
P1Vcc
22
K3
PB0/A8
PB0
A8
P1Vcc
23
K1
PB1/A9
PB1
A9
P1Vcc
24
K2
PB2/A10
PB2
A10
P1Vcc
25
L3
PB3/A11
PB3
A11
P1Vcc
26
L1
PB4/A12
PB4
A12
P1Vcc
27
L2
PB5/A13
PB5
A13
P1Vcc
28
L4
PB6/A14
PB6
A14
P1Vcc
29
M1
PB7/A15
PB7
A15
P1Vcc
30
M2
PA0/A16
PA0
A16
P1Vcc
31
M3
PA1/A17
PA1
A17
P1Vcc
FP-144J,
FP-144JV BP-176V*4 Mode 6
20
J2
21
32
N1
PA2/A18
PA2
A18
P1Vcc
33
M4
PA3/A19
PA3
NC
P1Vcc
34
N2
PA4/A20
PA4
NC
P1Vcc
35
P1
PA5/A21
PA5
NC
P1Vcc
36
P2
PA6/A22
PA6
NC
P1Vcc
37
R1
PA7/A23
PA7
NC
P1Vcc
38
N3
PH7
PH7
NC
P1Vcc
39
R2
PH6
PH6
NC
P1Vcc
40
P3
PH5
PH5
NC
P1Vcc
41
N4
PH4
PH4
NC
P1Vcc
42
R3
PH3
PH3
NC
P1Vcc
43
P4
PH2
PH2
NC
P1Vcc
44
M5
PH1
PH1
NC
P1Vcc
45
R4
PH0
PH0
NC
P1Vcc
46
N5
PJ7
PJ7
NC
P1Vcc
47
P5
PJ6
PJ6
NC
P1Vcc
Rev. 6.00 Sep. 24, 2009 Page 12 of 928
REJ09B0099-0600
Section 1 Overview
Pin No.
Pin Name
Mode 7
Flash Memory
Programmer Mode*5
Power
Supply
Source
PJ5
PJ5
NC
P1Vcc
M6
PJ4
PJ4
NC
P1Vcc
50
N6
PJ3
PJ3
NC
P1Vcc
51
P6
PJ2
PJ2
NC
P1Vcc
52
M7
PJ1
PJ1
NC
P1Vcc
53
N7
PJ0
PJ0
NC
P1Vcc
54
R7, R6,
P8, P7
Vss
Vss
Vss
Vss
55
M8
P97/AN15/DA1
P97/AN15/DA1
NC
AVcc
56
N8
P96/AN14/DA0
P96/AN14/DA0
NC
AVcc
57
R8
P95/AN13
P95/AN13
NC
AVcc
58
M9
P94/AN12
P94/AN12
NC
AVcc
59
N9
P93/AN11
P93/AN11
NC
AVcc
60
R9
P92/AN10
P92/AN10
NC
AVcc
61
P9
P91/AN9
P91/AN9
NC
AVcc
62
M10
P90/AN8
P90/AN8
NC
AVcc
63
N10
P47/AN7
P47/AN7
NC
AVcc
64
R10
P46/AN6
P46/AN6
NC
AVcc
65
P10
P45/AN5
P45/AN5
NC
AVcc
66
N11
P44/AN4
P44/AN4
NC
AVcc
67
R12, R11
AVss
AVss
Vss
AVss
68
P11
P43/AN3
P43/AN3
NC
AVcc
69
M11
P42/AN2
P42/AN2
NC
AVcc
70
P12
P41/AN1
P41/AN1
NC
AVcc
71
N12
P40/AN0
P40/AN0
NC
AVcc
72
R15, R14,
R13
Vref
Vref
Vcc
Vref
73
P14, P13,
N13, M12
AVcc
AVcc
Vcc
AVcc
74
P15
P50/TxD2
P50/TxD2
NC
P1Vcc
FP-144J,
FP-144JV BP-176V*4 Mode 6
48
R5
49
Rev. 6.00 Sep. 24, 2009 Page 13 of 928
REJ09B0099-0600
Section 1 Overview
Pin No.
Pin Name
Mode 7
Flash Memory
Programmer Mode*5
Power
Supply
Source
P51/RxD2
P51/RxD2
NC
P1Vcc
M13
P52/SCK2
P52/SCK2
NC
P1Vcc
77
N15
PF0/BREQ/IRQ2
PF0/IRQ2
Vcc
P1Vcc
78
M14
PF1/BACK/BUZZ
PF1/BUZZ
NC
P1Vcc
79
L12
PF2/WAIT
PF2
NC
P1Vcc
80
M15
PF3/LWR/ADTRG/ PF3/ADTRG/IRQ3
IRQ3
Vcc
P1Vcc
81
L13
HWR
PF4
NC
P1Vcc
82
L14
RD
PF5
NC
P1Vcc
83
L15
AS
PF6
NC
P1Vcc
84
K12
P1Vcc
P1Vcc
Vcc
P1Vcc
85
K13
PF7/φ
PF7/φ
NC
P1Vcc
86
K15, K14
Vss
Vss
Vss
Vss
87
J12
TEST
TEST
Vss
Vcc
88
J13
VCL
VCL
VCL
VCL
89
J15
OSC2
OSC2
NC
⎯
90
J14
OSC1
OSC1
Vss
⎯
91
H12
NMI
NMI
Vcc
Vcc
92
H13
MD2
MD2
Vss
Vcc
93
G15
XTAL
XTAL
XTAL
⎯
94
H15, H14, Vss
G14, G13,
G12, F13,
F12
Vss
Vss
Vss
95
F15
EXTAL
EXTAL
EXTAL
Vcc
96
F14
Vcc
Vcc
Vcc
Vcc
97
E12
MD0
MD0
Vss
Vcc
98
E15
MD1
MD1
Vss
Vcc
99
E14
STBY
STBY
Vcc
Vcc
100
E13
RES
RES
RES
Vcc
FP-144J,
FP-144JV BP-176V*4 Mode 6
75
N14
76
Rev. 6.00 Sep. 24, 2009 Page 14 of 928
REJ09B0099-0600
Section 1 Overview
Pin No.
Pin Name
Mode 7
Flash Memory
Programmer Mode*5
Power
Supply
Source
P20/TIOCA3
P20/TIOCA3
NC
P2Vcc
D14
P21/TIOCB3
P21/TIOCB3
NC
P2Vcc
103
D13
P22/TIOCC3
P22/TIOCC3
NC
P2Vcc
104
C15
P23/TIOCD3
P23/TIOCD3
NC
P2Vcc
105
D12
P24/TIOCA4
P24/TIOCA4
NC
P2Vcc
106
C14
P25/TIOCB4
P25/TIOCB4
NC
P2Vcc
107
B15
P26/TIOCA5
P26/TIOCA5
NC
P2Vcc
108
B14
P27/TIOCB5
P27/TIOCB5
NC
P2Vcc
109
A15
P17/TIOCB2/
TCLKD
P17/TIOCB2/
TCLKD
NC
P2Vcc
110
C13
P16/TIOCA2/IRQ1 P16/TIOCA2/IRQ1
Vss
P2Vcc
111
B13
P15/TIOCB1/
TCLKC
NC
P2Vcc
112
C12
P14/TIOCA1/IRQ0 P14/TIOCA1/IRQ0
Vss
P2Vcc
113
B12
P13/TIOCD0/
TCLKB
P13/TIOCD0/
TCLKB
NC
P2Vcc
114
D11
P12/TIOCC0/
TCLKA
P12/TIOCC0/
TCLKA
NC
P2Vcc
115
C11
P11/TIOCB0
P11/TIOCB0
NC
P2Vcc
116
B11
P10/TIOCA0
P10/TIOCA0
NC
P2Vcc
117
B10, A14,
A13, A12,
A11, A10
Vss
Vss
Vss
Vss
118
D10, D9,
C10, C9
P2Vcc
P2Vcc
Vcc
P2Vcc
119
A9
P37/TxD4
P37/TxD4
NC
P2Vcc
120
B9
P36/RxD4
P36/RxD4
NC
P2Vcc
121
D8
P35/SCK1/SCK4/
SCL0/IRQ5
P35/SCK1/SCK4/
SCL0/IRQ5
NC
P2Vcc
122
C8
P34/RxD1/SDA0
P34/RxD1/SDA0
NC
P2Vcc
123
A8
P33/TxD1/SCL1
P33/TxD1/SCL1
NC
P2Vcc
124
B8
P32/SCK0/SDA1/
IRQ4
P32/SCK0/SDA1/
IRQ4
NC
P2Vcc
FP-144J,
FP-144JV BP-176V*4 Mode 6
101
D15
102
P15/TIOCB1/
TCLKC
Rev. 6.00 Sep. 24, 2009 Page 15 of 928
REJ09B0099-0600
Section 1 Overview
Pin No.
Pin Name
Mode 7
Flash Memory
Programmer Mode*5
Power
Supply
Source
P31/RxD0
P31/RxD0
NC
P2Vcc
C7
P30/TxD0
P30/TxD0
NC
P2Vcc
127
A7
P77/TxD3
P77/TxD3
NC
P2Vcc
128
B7
P76/RxD3
P76/RxD3
NC
P2Vcc
FP-144J,
FP-144JV BP-176V*4 Mode 6
125
D7
126
129
D6
P75/TMO3/SCK3
P75/TMO3/SCK3
NC
P2Vcc
130
C6
P74/TMO2/MRES P74/TMO2/MRES
NC
P2Vcc
131
A6
P73/TMO1/CS7
P73/TMO1
NC
P2Vcc
132
B6
P72/TMO0/CS6
P72/TMO0
NC
P2Vcc
133
C5
P71/TMRI23/
TMCI23/CS5
P71/TMRI23/
TMCI23
NC
P2Vcc
134
A5
P70/TMRI01/
TMCI01/CS4
P70/TMRI01/
TMCI01
NC
P2Vcc
135
B5
PG4/CS0
PG4
NC
P1Vcc
NC
P1Vcc
NC
P1Vcc
136
D5
1
HRxD*
HRxD*
2
PG3/Rx/CS1*
PG3/CS1*
137
A4
3
PG3/Rx*
2
PG3*3
HTxD*1
HTxD*1
PG2/Tx/CS2*
PG2/CS2*
1
2
3
PG2/Tx*
2
PG2*3
138
B4
PG1/CS3/IRQ7
PG1/IRQ7
NC
P1Vcc
139
C4
PG0/IRQ6
PG0/IRQ6
NC
P1Vcc
140
A3
PE0/D0
PE0
NC
P1Vcc
141
D4
PE1/D1
PE1
NC
P1Vcc
142
B3
PE2/D2
PE2
NC
P1Vcc
143
A2
PE3/D3
PE3
Vcc
P1Vcc
144
B2
PE4/D4
PE4
Vss
P1Vcc
Notes: 1.
2.
3.
4.
5.
Symbol name for the H8S/2556 Group
Symbol name for the H8S/2552 Group
Symbol name for the H8S/2506 Group
Available only in the H8S/2552 Group and H8S/2506 Group.
NC pins should be left open.
Rev. 6.00 Sep. 24, 2009 Page 16 of 928
REJ09B0099-0600
Section 1 Overview
1.3.3
Pin Functions
Table 1.2 lists the pins functions in each mode.
Table 1.2
Pin Functions
Pin No.
Type
Symbol
FP-144J,
2
FP-144JV BP-176V* I/O
Power
supply
Vcc
96
F14
I
Power supply pin. Connect this pin to the system power
supply.
P1Vcc
14, 84
F3, G3,
G4, H3,
H4, K12
I
Power supply pin for ports indicated that its power is
supplied by P1Vcc (see table 1.1).
P2Vcc
118
C9, C10,
D9, D10
I
Pins for connecting a capacitor to stabilize the internal
step-down voltage.
Function
Power supply pin for ports indicated that its power is
supplied by P2Vcc (see table 1.1).
Clock
VCL
88
J13
O
Pin for connecting the on-chip step-down power supply to
a capacitor for voltage stabilization. Must not be directly
connected to a power supply. A capacitor of 0.47 μF must
be connected between this pin and Vss. (Place close to
the pin.)
VSS
12, 54,
86, 94,
117
I
G2, G1,
F2, F1,
E1, R7,
R6, P8,
P7, K15,
K14, H15,
H14, G14,
G13, G12,
F13, F12,
B10, A14,
A13, A12,
A11, A10
Ground pins. Connect this pin to the system power supply
(0V).
XTAL
93
G15
I
For connection to a crystal resonator. For examples of
connecting crystal resonator and external clock input, see
section 21, Clock Pulse Generator.
EXTAL
95
F15
I
For connection to a crystal resonator or a ceramic
resonator. This pin can be also used for external clock
input. For examples of connecting crystal resonator and
external clock input, see section 21, Clock Pulse
Generator.
Rev. 6.00 Sep. 24, 2009 Page 17 of 928
REJ09B0099-0600
Section 1 Overview
Pin No.
Type
Symbol
FP-144J,
2
FP-144JV BP-176V* I/O
Clock
OSC1
90
J14
I
Connects to a 32.768 kHz crystal resonator. For examples
of connecting crystal resonator, see section 21, Clock
Pulse Generator.
OSC2
89
J15
I
Connects to a 32.768 kHz crystal resonator. For examples
of connecting crystal resonator, see section 21, Clock
Pulse Generator.
φ
85
K13
O
Supplies clock pulses to external devices.
92
H13
I
98
E15
97
E12
Sets the operating mode. Inputs at these pins should not
be changed during operation. Be sure to fix the levels of
the mode pins (MD2 to MD0) by pull-down or pull-up,
except for mode changing.
100
E13
I
Reset input pin. When this pin is low, this LSI enters the
power-on reset state.
MRES*
130
C6
I
Reset input pin. When this pin is low, this LSI enters the
manual reset state.
STBY*
99
E14
I
When this pin is low, a transition is made to hardware
standby mode.
BREQ
77
N15
I
Indicates that an external bus master is requesting bus
mastership.
BACK
78
M14
O
Indicates that the bus is released to an external bus
master.
87
J12
I
Test pin. Connect to a Vss.
91
H12
I
Nonmaskable interrupt pin. If this pin is not used, it should
be fixed-high.
IRQ7
138
B4
I
These pins request maskable interrupts.
IRQ6
139
C4
IRQ5
121
D8
IRQ4
124
B8
IRQ3
80
M15
IRQ2
77
N15
IRQ1
110
C13
IRQ0
112
C12
Operating MD2
mode
MD1
control
MD0
System
control
RES*
1
1
1
TEST*
1
1
Interrupts NMI*
Rev. 6.00 Sep. 24, 2009 Page 18 of 928
REJ09B0099-0600
Function
Section 1 Overview
Pin No.
FP-144J,
2
FP-144JV BP-176V* I/O
Function
Type
Symbol
Address
bus
A23 to A0 37 to 15,
13
R1, P2,
P1, N2,
M4, N1,
M3, M2,
M1, L4,
L2, L1,
L3, K2,
K1, K3,
K4, J2,
J1, J3,
J4, H2,
H1, F4
O
Outputs addresses.
Data bus
D15 to D0 11 to 1,
144 to
140
E2, E3,
D1, E4,
D2, C1,
D3, C2,
B1, C3,
A1, B2,
A2, B3,
D4, A3
I/O
Bi-directional bus.
Bus
control
CS7
131
A6
O
Chip select signals for areas 7 to 0.
CS6
132
B6
CS5
133
C5
CS4
134
A5
CS3
138
B4
CS2
137
A4
CS1
136
D5
Pins CS2 and CS1 are not supported by the H8S/2556
Group.
CS0
135
B5
AS
83
L15
O
Indicates that data output on the address bus is valid
when this pin is a low level.
RD
82
L14
O
Indicates that an access to the external address space is
in progress when this pin is a low level.
HWR
81
L13
O
Strobe signal. Indicates that data on the upper bits (D15
to D8) of the data bus is valid during a write access.
LWR
80
M15
O
Strobe signal. Indicates that data on the upper bits (D7 to
D0) of the data bus is valid during a write access.
Rev. 6.00 Sep. 24, 2009 Page 19 of 928
REJ09B0099-0600
Section 1 Overview
Pin No.
Type
Symbol
FP-144J,
2
FP-144JV BP-176V* I/O
Bus
control
WAIT
79
L12
I
Requests insertion of wait cycles in a bus cycle when the
access is made to the external address space.
16-bit
TCLKD
timerTCLKC
pulse unit
TCLKB
(TPU)
109
A15
I
These pins input an external clock.
111
B13
113
B12
TCLKA
114
D11
TIOCA0
116
B11
I/O
TIOCB0
115
C11
Pins for the TGRA_0 to TGRD_0 input capture input,
output compare output, or PWM output.
TIOCC0
114
D11
TIOCD0
113
B12
TIOCA1
112
C12
I/O
TIOCB1
111
B13
Pins for the TGRA_1 and TGRB_1 input capture input,
output compare output, or PWM output.
TIOCA2
110
C13
I/O
TIOCB2
109
A15
Pins for the TGRA_2 and TGRB_2 input capture input,
output compare output, or PWM output.
TIOCA3
101
D15
I/O
TIOCB3
102
D14
Pins for the TGRA_3 and TGRD_3 input capture input,
output compare output, or PWM output.
TIOCC3
103
D13
TIOCD3
104
C15
TIOCA4
105
D12
I/O
TIOCB4
106
C14
Pins for the TGRA_4 and TGRB_4 input capture input,
output compare output, or PWM output.
TIOCA5
107
B15
I/O
TIOCB5
108
B14
Pins for the TGRA_5 and TGRB_5 input capture input,
output compare output, or PWM output.
8-bit timer TMO3
129
Compare-match output pins
130
D6, C6,
A6, B6
O
TMO2
TMO1
131
TMO0
132
TMCI23
133
C5
I
Pins for external clock input to the counter
TMCI01
134
A5
TMRI23
133
C5
I
Counter reset input pins.
TMRI01
134
A5
Rev. 6.00 Sep. 24, 2009 Page 20 of 928
REJ09B0099-0600
Function
Section 1 Overview
Pin No.
FP-144J,
2
FP-144JV BP-176V* I/O
Function
BUZZ
Watch
dog timer
(WDT)
78
M14
O
Outputs pulse signal divided by the watchdog timer.
Serial
communication
interface
(SCI)/
smart
card
interface
TxD4
119
A9
O
Data output pins
TxD3
127
A7
TxD2
74
P15
TxD1
123
A8
TxD0
126
C7
RxD4
120
B9
I
Data input pins
RxD3
128
B7
RxD2
75
N14
RxD1
122
C8
RxD0
125
D7
SCK4
121
D8
I/O
Clock input/output pins
SCK3
129
D6
SCK2
76
M13
SCK1
121
D8
SCK0
124
B8
SCL1
123
A8
SCL0
121
D8
SDA1
124
B8
SDA0
122
C8
55 to 66,
68 to 71
I
M8, N8,
R8, M9,
N9, R9,
P9, M10,
N10, R10,
P10, N11,
P11, M11,
P12, N12
Analog input pins for A/D converter.
80
M15
I
Pin for input of an external trigger to start A/D conversion
55
M8
O
Analog output pins for the D/A converter.
56
N8
Type
2
I C bus
interface
2 (IIC2)
Symbol
A/D
AN15 to
converter AN0
ADTRG
D/A
DA1
converter
DA0
SCK4 and SCK1 are NMOS push-pull outputs.
2
I/O
I C clock input/output pins. These pins are capable of
driving bus. Pin SCL0 is an NMOS open-drain output.
I/O
I C data input/output pins. These pins are capable of
driving bus. Pin SDA0 is an NMOS open-drain output.
2
Rev. 6.00 Sep. 24, 2009 Page 21 of 928
REJ09B0099-0600
Section 1 Overview
Pin No.
Type
Symbol
A/D
AVcc
converter,
D/A
converter
AVss
Vref
IEBus
Tx
controller
(IEB)
Rx
TM
FP-144J,
2
FP-144JV BP-176V* I/O
Function
73
M12, N13, I
P13, P14
Power supply pin for the A/D and D/A converters. If both
converters are not used, connect this pin to the system
power supply (Vcc level).
67
R11, R12
I
Ground pin for the A/D and D/A converters. Connect this
pin to the system power supply (0 V).
72
R13, R14,
R15
I
Reference voltage input pin for the A/D and D/A
converters. If both converters are not used, connect this
pin to the system power supply (Vcc level).
137
A4
O
Transmit data output pin for the IEB.
(Supported only by the H8S/2552 Group.)
136
D5
I
Receive data input pin for the IEB.
(Supported only by the H8S/2552 Group.)
Controller HTxD
area
network
(HCAN) HRxD
137
A4
O
Pin for CAN bus transmission.
(Supported only by the H8S/2556 Group.)
136
D5
I
Pin for CAN bus reception.
(Supported only by the H8S/2556 Group.)
I/O ports
P17 to
P10
109 to
116
A15, C13,
B13, C12,
B12, D11,
C11, B11
I/O
8-bit I/O pins
P27 to
P20
108 to
101
B14, B15,
C14, D12,
C15, D13,
D14, D15
I/O
8-bit I/O pins
P37 to
P30
119 to
126
A9, B9,
D8, C8,
A8, B8,
D7, C7
I/O
8-bit I/O pins.
P47 to
P40
63 to 66,
68 to 71
N10, R10, I
P10, N11,
P11, M11,
P12, N12
8-bit input pins
P52 to
P50
76 to 74
M13, N14, I/O
P15
3-bit I/O pins
Rev. 6.00 Sep. 24, 2009 Page 22 of 928
REJ09B0099-0600
Pins P34 and P35 are NMOS push-pull outputs.
Section 1 Overview
Pin No.
Type
Symbol
FP-144J,
2
FP-144JV BP-176V* I/O
I/O ports
P77 to
P70
127 to
134
A7, B7,
D6, C6,
A6, B6,
C5, A5
I/O
8-bit I/O pins
P97 to
P90
55 to 62
M8, N8,
R8, M9,
N9, R9,
P9, M10
I
8-bit input pins
PA7 to
PA0
37 to 30
R1, P2,
P1, N2,
M4, N1,
M3, M2
I/O
8-bit I/O pins
PB7 to
PB0
29 to 22
M1, L4,
L2, L1,
L3, K2,
K1, K3
I/O
8-bit I/O pins
PC7 to
PC0
21 to 15,
13
K4, J2,
J1, J3,
J4, H2,
H1, F4
I/O
8-bit I/O pins
PD7 to
PD0
11 to 4
E2, E3,
D1, E4,
D2, C1,
D3, C2
I/O
8-bit I/O pins
PE7 to
PE0
3 to 1,
144 to
140
B1, C3,
A1, B2,
A2, B3,
D4, A3
I/O
8-bit I/O pins
PF7 to
PF0
85, 83 to
77
K13, L15,
L14, L13,
M15, L12,
M14, N15
I/O
8-bit I/O pins
PG4 to
PG0
135 to
139
B5, D5,
A4, B4,
C4
I/O
5-bit I/O pins
Function
Pins PG3 and PG2 are not supported by the H8S/2556
Group.
Rev. 6.00 Sep. 24, 2009 Page 23 of 928
REJ09B0099-0600
Section 1 Overview
Pin No.
FP-144J,
2
FP-144JV BP-176V* I/O
Function
PH7 to
PH0
38 to 45
N3, R2,
P3, N4,
R3, P4,
M5, R4
I/O
8-bit I/O pins
PJ7 to
PJ0
46 to 53
N5, P5,
R5, M6,
N6, P6,
M7, N7
I/O
8-bit I/O pins
Type
Symbol
I/O ports
Notes: 1. Countermeasure against noise should be executed or may result in malfunction.
2. Available only in the H8S/2552 Group and H8S/2506 Group.
Rev. 6.00 Sep. 24, 2009 Page 24 of 928
REJ09B0099-0600
Section 2 CPU
Section 2 CPU
The H8S/2000 CPU is a high-speed central processing unit with an internal 32-bit architecture that
is upward-compatible with the H8/300 and H8/300H CPUs. The H8S/2000 CPU has sixteen 16-bit
general registers, can address a 16-Mbyte linear address space, and is ideal for realtime control.
This section describes the H8S/2000 CPU. The usable modes and address spaces differ depending
on the product. For details on each product, see section 3, MCU Operating Modes.
2.1
Features
• Upward-compatible with H8/300 and H8/300H CPU
⎯ Can execute H8/300 and H8/300H CPU object programs
• General-register architecture
⎯ Sixteen 16-bit general registers also usable as sixteen 8-bit registers or eight 32-bit registers
• 65 basic instructions
⎯ 8/16/32-bit arithmetic and logic instructions
⎯ Multiply and divide instructions
⎯ Powerful bit-manipulation instructions
• Eight addressing modes
⎯ Register direct [Rn]
⎯ Register indirect [@ERn]
⎯ Register indirect with displacement [@(d:16,ERn) or @(d:32,ERn)]
⎯ Register indirect with post-increment or pre-decrement [@ERn+ or @–ERn]
⎯ Absolute address [@aa:8, @aa:16, @aa:24, or @aa:32]
⎯ Immediate [#xx:8, #xx:16, or #xx:32]
⎯ Program-counter relative [@(d:8,PC) or @(d:16,PC)]
⎯ Memory indirect [@@aa:8]
• 16-Mbyte address space
⎯ Program: 16 Mbytes
⎯ Data:
16 Mbytes
• High-speed operation
⎯ All frequently-used instructions execute in one or two states
⎯ 8/16/32-bit register-register add/subtract
: 1 state
⎯ 8 × 8-bit register-register multiply : 12 states
⎯ 16 ÷ 8-bit register-register divide
: 12 states
Rev. 6.00 Sep. 24, 2009 Page 25 of 928
REJ09B0099-0600
Section 2 CPU
⎯ 16 × 16-bit register-register multiply : 20 states
⎯ 32 ÷ 16-bit register-register divide : 20 states
• Two CPU operating modes
⎯ Normal mode*
⎯ Advanced mode
• Power-down state
⎯ Transition to power-down state by a SLEEP instruction
⎯ CPU clock speed selection
Note: * Normal mode is not available in this LSI.
2.1.1
Differences between H8S/2600 CPU and H8S/2000 CPU
The differences between the H8S/2600 CPU and the H8S/2000 CPU are shown below.
• Register configuration
⎯ The MAC register is supported by the H8S/2600 CPU only.
• Basic instructions
⎯ The four instructions MAC, CLRMAC, LDMAC, and STMAC are supported by the
H8S/2600 CPU only.
• The number of execution states of the MULXU and MULXS instructions;
Execution States
Instruction
MULXU
MULXS
Mnemonic
H8S/2600
H8S/2000
MULXU.B Rs, Rd
3
12
MULXU.W Rs, ERd
4
20
MULXS.B Rs, Rd
4
13
MULXS.W Rs, ERd
5
21
In addition, there are differences in address space, CCR and EXR register functions, and powerdown modes, etc., depending on the model.
Rev. 6.00 Sep. 24, 2009 Page 26 of 928
REJ09B0099-0600
Section 2 CPU
2.1.2
Differences from H8/300 CPU
In comparison to the H8/300 CPU, the H8S/2000 CPU has the following enhancements:
• More general registers and control registers
⎯ Eight 16-bit expanded registers, and one 8-bit and two 32-bit control registers, have been
added.
• Expanded address space
⎯ Normal mode supports the same 64-kbyte address space as the H8/300 CPU.
⎯ Advanced mode supports a maximum 16-Mbyte address space.
• Enhanced addressing
⎯ The addressing modes have been enhanced to make effective use of the 16-Mbyte address
space.
• Enhanced instructions
⎯ Addressing modes of bit-manipulation instructions have been enhanced.
⎯ Signed multiply and divide instructions have been added.
⎯ Two-bit shift instructions have been added.
⎯ Instructions for saving and restoring multiple registers have been added.
⎯ A test and set instruction has been added.
• Higher speed
⎯ Basic instructions execute twice as fast.
2.1.3
Differences from H8/300H CPU
In comparison to the H8/300H CPU, the H8S/2000 CPU has the following enhancements:
• Additional control register
⎯ One 8-bit control registers have been added.
• Enhanced instructions
⎯ Addressing modes of bit-manipulation instructions have been enhanced.
⎯ Two-bit shift instructions have been added.
⎯ Instructions for saving and restoring multiple registers have been added.
⎯ A test and set instruction has been added.
• Higher speed
⎯ Basic instructions execute twice as fast.
Rev. 6.00 Sep. 24, 2009 Page 27 of 928
REJ09B0099-0600
Section 2 CPU
2.2
CPU Operating Modes
The H8S/2000 CPU has two operating modes: normal and advanced. Normal mode supports a
maximum 64-kbyte address space. Advanced mode supports a maximum 16-Mbyte total address
space. The mode is selected by the mode pins.
2.2.1
Normal Mode
The exception vector table and stack have the same structure as in the H8/300 CPU.
• Address Space
Linear access is provided to a maximum address space of 64 kbytes.
• Extended Registers (En)
The extended registers (E0 to E7) can be used as 16-bit registers, or as the upper 16-bit
segments of 32-bit registers. When En is used as a 16-bit register it can contain any value, even
when the corresponding general register (Rn) is used as an address register. If the general
register is referenced in the register indirect addressing mode with pre-decrement (@–Rn) or
post-increment (@Rn+) and a carry or borrow occurs, however, the value in the corresponding
extended register (En) will be affected.
• Instruction Set
All instructions and addressing modes can be used. Only the lower 16 bits of effective
addresses (EA) are valid.
• Exception Vector Table and Memory Indirect Branch Addresses
In normal mode the top area starting at H'0000 is allocated to the exception vector table. One
branch address is stored per 16 bits. Figure 2.1 shows the structure of the exception vector
table in normal mode. For details of the exception vector table, see section 4, Exception
Handling.
The memory indirect addressing mode (@@aa:8) employed in the JMP and JSR instructions
uses an 8-bit absolute address included in the instruction code to specify a memory operand
that contains a branch address. In normal mode the operand is a 16-bit word operand,
providing a 16-bit branch address. Branch addresses can be stored in the top area from H'0000
to H'00FF. Note that this area is also used for the exception vector table.
• Stack Structure
When the program counter (PC) is pushed onto the stack in a subroutine call, and the PC,
condition-code register (CCR) and extended control register (EXR) are pushed onto the stack
in exception handling, they are stored as shown in figure 2.2. EXR is not pushed onto the stack
in interrupt control mode 0. For details, see section 4, Exception Handling.
Rev. 6.00 Sep. 24, 2009 Page 28 of 928
REJ09B0099-0600
Section 2 CPU
Note: * Normal mode is not available in this LSI.
H'0000
H'0001
H'0002
H'0003
H'0004
H'0005
H'0006
H'0007
H'0008
H'0009
H'000A
H'000B
Reset exception vector
(Reserved for system use)
Exception
vector table
Exception vector 1
Exception vector 2
Figure 2.1 Exception Vector Table (Normal Mode)
SP
PC
(16 bits)
EXR*1
SP
2
(SP *
Reserved*1*3
)
CCR
CCR*3
PC
(16 bits)
(a) Subroutine Branch
(b) Exception Handling
Notes: 1. When EXR is not used it is not stored on the stack.
2. SP when EXR is not used.
3. lgnored when returning.
Figure 2.2 Stack Structure in Normal Mode
2.2.2
Advanced Mode
• Address Space
Linear access is provided to a maximum 16-Mbyte address space.
• Extended Registers (En)
Rev. 6.00 Sep. 24, 2009 Page 29 of 928
REJ09B0099-0600
Section 2 CPU
The extended registers (E0 to E7) can be used as 16-bit registers, or as the upper 16-bit
segments of 32-bit registers or address registers.
• Instruction Set
All instructions and addressing modes can be used.
• Exception Vector Table and Memory Indirect Branch Addresses
In advanced mode, the top area starting at H'00000000 is allocated to the exception vector
table in units of 32 bits. In each 32 bits, the upper 8 bits are ignored and a branch address is
stored in the lower 24 bits (figure 2.3). For details of the exception vector table, see section 4,
Exception Handling.
H'00000000
Reserved
Reset exception vector
H'00000003
H'00000004
H'00000007
H'00000008
Exception vector table
Exception vector 3
H'0000000B
H'0000000C
H'00000010
Reserved
Exception vector 1
Figure 2.3 Exception Vector Table (Advanced Mode)
The memory indirect addressing mode (@@aa:8) employed in the JMP and JSR instructions
uses an 8-bit absolute address included in the instruction code to specify a memory operand
that contains a branch address. In advanced mode, the operand is a 32-bit longword operand,
providing a 32-bit branch address. The upper 8 bits of these 32 bits is a reserved area that is
regarded as H'00. Branch addresses can be stored in the area from H'00000000 to H'000000FF.
Note that the first part of this range is also the exception vector table.
Rev. 6.00 Sep. 24, 2009 Page 30 of 928
REJ09B0099-0600
Section 2 CPU
• Stack Structure
In advanced mode, when the program counter (PC) is pushed onto the stack in a subroutine
call, and the PC, condition-code register (CCR), and extended control register (EXR) are
pushed onto the stack in exception handling, they are stored as shown in figure 2.4. When
EXR is invalid, it is not pushed onto the stack. For details, see section 4, Exception Handling.
EXR*1
SP
SP
Reserved
PC
(24 bits)
(SP
*2
Reserved*1*3
)
(a) Subroutine Branch
CCR
PC
(24 bits)
(b) Exception Handling
Notes: 1. When EXR is not used it is not stored on the stack.
2. SP when EXR is not used.
3. Ignored when returning.
Figure 2.4 Stack Structure in Advanced Mode
Rev. 6.00 Sep. 24, 2009 Page 31 of 928
REJ09B0099-0600
Section 2 CPU
2.3
Address Space
Figure 2.5 shows a memory map of the H8S/2000 CPU. The H8S/2000 CPU provides linear
access to a maximum 64-kbyte address space in normal mode, and a maximum 16-Mbyte
(architecturally 4-Gbyte) address space in advanced mode. The usable modes and address spaces
differ depending on the product. For details on each product, see section 3, MCU Operating
Modes.
H'0000
H'00000000
64 kbytes
16 Mbytes
H'FFFF
Program area
H'00FFFFFF
Data area
Cannot be used
by this LSI
H'FFFFFFFF
(a) Normal Mode
(b) Advanced Mode
Note: Normal mode is not available in this LSI
Figure 2.5 Memory Map
Rev. 6.00 Sep. 24, 2009 Page 32 of 928
REJ09B0099-0600
Section 2 CPU
2.4
Register Configuration
The H8S/2000 CPU has the internal registers shown in figure 2.6. There are two types of registers:
general registers and control registers. Control registers are a 24-bit program counter (PC), an 8bit extended control register (EXR), and an 8-bit condition code register (CCR).
General Registers (Rn) and Extended Registers (En)
15
0 7
0 7
0
ER0
E0
R0H
R0L
ER1
E1
R1H
R1L
ER2
E2
R2H
R2L
ER3
E3
R3H
R3L
ER4
E4
R4H
R4L
ER5
E5
R5H
R5L
ER6
E6
R6H
R6L
ER7 (SP)
E7
R7H
R7L
Control Registers (CR)
23
0
PC
7 6 5 4 3 2 1 0
- - - - I2 I1 I0
EXR T
7 6 5 4 3 2 1 0
CCR I UI H U N Z V C
Legend:
SP
PC
EXR
T
I2 to I0
CCR
I
UI
:Stack pointer
:Program counter
:Extended control register
:Trace bit
:Interrupt mask bits
:Condition-code register
:Interrupt mask bit
:User bit or interrupt mask bit*
H
U
N
Z
V
C
:Half-carry flag
:User bit
:Negative flag
:Zero flag
:Overflow flag
:Carry flag
Note: * The interrupt mask bit is not available in this LSI.
Figure 2.6 CPU Registers
Rev. 6.00 Sep. 24, 2009 Page 33 of 928
REJ09B0099-0600
Section 2 CPU
2.4.1
General Registers
The H8S/2000 CPU has eight 32-bit general registers. These general registers are all functionally
alike and can be used as both address registers and data registers. When a general register is used
as a data register, it can be accessed as a 32-bit, 16-bit, or 8-bit register. Figure 2.7 illustrates the
usage of the general registers.
When the general registers are used as 32-bit registers or address registers, they are designated by
the letters ER (ER0 to ER7).
The ER registers divide into 16-bit general registers designated by the letters E (E0 to E7) and R
(R0 to R7). These registers are functionally equivalent, providing a maximum sixteen 16-bit
registers. The E registers (E0 to E7) are also referred to as extended registers.
The R registers divide into 8-bit general registers designated by the letters RH (R0H to R7H) and
RL (R0L to R7L). These registers are functionally equivalent, providing a maximum sixteen 8-bit
2egisters.
The usage of each register can be selected independently.
General register ER7 has the function of stack pointer (SP) in addition to its general-register
function, and is used implicitly in exception handling and subroutine calls. Figure 2.8 shows the
stack.
• Address registers
• 32-bit registers
• 16-bit registers
• 8-bit registers
E registers (extended registers)
(E0 to E7)
ER registers
(ER0 to ER7)
RH registers
(R0H to R7H)
R registers
(R0 to R7)
RL registers
(R0L to R7L)
Figure 2.7 Usage of General Registers
Rev. 6.00 Sep. 24, 2009 Page 34 of 928
REJ09B0099-0600
Section 2 CPU
Free area
SP (ER7)
Stack area
Figure 2.8 Stack Status
2.4.2
Program Counter (PC)
This 24-bit counter indicates the address of the next instruction the CPU will execute. The length
of all CPU instructions is 2 bytes (one word), so the least significant PC bit is ignored. (When an
instruction is fetched, the least significant PC bit is regarded as 0.)
2.4.3
Extended Control Register (EXR)
EXR is an 8-bit register that manipulates the LDC, STC, ANDC, ORC, and XORC instructions.
When these instructions except for the STC instruction is executed, all interrupts including NMI
will be masked for three states after execution is completed.
Bit
Bit Name
Initial Value
R/W
Description
7
T
0
R/W
Trace Bit
When this bit is set to 1, a trace exception is
generated each time an instruction is executed.
When this bit is cleared to 0, instructions are
executed in sequence.
6 to 3
⎯
All 1
⎯
Reserved
These bits are always read as 1.
2
I2
1
R/W
1
I1
1
R/W
0
I0
1
R/W
These bits designate the interrupt mask level (0 to
7). For details, see section 5, Interrupt Controller.
Rev. 6.00 Sep. 24, 2009 Page 35 of 928
REJ09B0099-0600
Section 2 CPU
2.4.4
Condition-Code Register (CCR)
This 8-bit register contains internal CPU status information, including an interrupt mask bit (I) and
half-carry (H), negative (N), zero (Z), overflow (V), and carry (C) flags.
Operations can be performed on the CCR bits by the LDC, STC, ANDC, ORC, and XORC
instructions. The N, Z, V, and C flags are used as branching conditions for conditional branch
(Bcc) instructions.
Bit
Bit Name
Initial Value
R/W
Description
7
I
1
R/W
Interrupt Mask Bit
Masks interrupts other than NMI when set to 1.
NMI is accepted regardless of the I bit setting. The
I bit is set to 1 by hardware at the start of an
exception-handling sequence. For details, see
section 5, Interrupt Controller.
6
UI
Undefined
R/W
User Bit or Interrupt Mask Bit
Can be written and read by software using the
LDC, STC, ANDC, ORC, and XORC instructions.
This bit cannot be used as an interrupt mask bit in
this LSI.
5
H
Undefined
R/W
Half-Carry Flag
When the ADD.B, ADDX.B, SUB.B, SUBX.B,
CMP.B, or NEG.B instruction is executed, this flag
is set to 1 if there is a carry or borrow at bit 3, and
cleared to 0 otherwise. When the ADD.W,
SUB.W, CMP.W, or NEG.W instruction is
executed, the H flag is set to 1 if there is a carry or
borrow at bit 11, and cleared to 0 otherwise.
When the ADD.L, SUB.L, CMP.L, or NEG.L
instruction is executed, the H flag is set to 1 if
there is a carry or borrow at bit 27, and cleared to
0 otherwise.
4
U
Undefined
R/W
User Bit
Can be written and read by software using the
LDC, STC, ANDC, ORC, and XORC instructions.
3
N
Undefined
R/W
Negative Flag
Stores the value of the most significant bit of data
as a sign bit.
Rev. 6.00 Sep. 24, 2009 Page 36 of 928
REJ09B0099-0600
Section 2 CPU
Bit
Bit Name
Initial Value
R/W
Description
2
Z
Undefined
R/W
Zero Flag
Set to 1 to indicate zero data, and cleared to 0 to
indicate non-zero data.
1
V
Undefined
R/W
Overflow Flag
Set to 1 when an arithmetic overflow occurs, and
cleared to 0 at other times.
0
C
Undefined
R/W
Carry Flag
Set to 1 when a carry occurs, and cleared to 0
otherwise. Used by:
•
Add instructions, to indicate a carry
•
Subtract instructions, to indicate a borrow
•
Shift and rotate instructions, to indicate a carry
The carry flag is also used as a bit accumulator by
bit manipulation instructions.
2.4.5
Initial Values of CPU Registers
Reset exception handling loads the CPU's program counter (PC) from the vector table, clears the
trace bit in EXR to 0, and sets the interrupt mask bits in CCR and EXR to 1. The other CCR bits
and the general registers are not initialized. In particular, the stack pointer (ER7) is not initialized.
The stack pointer should therefore be initialized by an MOV.L instruction executed immediately
after a reset.
Rev. 6.00 Sep. 24, 2009 Page 37 of 928
REJ09B0099-0600
Section 2 CPU
2.5
Data Formats
The H8S/2000 CPU can process 1-bit, 4-bit (BCD), 8-bit (byte), 16-bit (word), and 32-bit
(longword) data. Bit-manipulation instructions operate on 1-bit data by accessing bit n (n = 0, 1, 2,
…, 7) of byte operand data. The DAA and DAS decimal-adjust instructions treat byte data as two
digits of 4-bit BCD data.
2.5.1
General Register Data Formats
Figure 2.9 shows the data formats in general registers.
Data Type
Register Number
Data Format
7
1-bit data
RnH
1-bit data
RnL
4-bit BCD data
RnH
4-bit BCD data
RnL
Byte data
RnH
0
Don't care
7 6 5 4 3 2 1 0
0
7
Don't care
7
7 6 5 4 3 2 1 0
4 3
Upper
0
Lower
Don't care
7
Don't care
7
4 3
Upper
0
Don't care
MSB
LSB
7
Byte data
RnL
Figure 2.9 General Register Data Formats (1)
REJ09B0099-0600
0
Don't care
MSB
Rev. 6.00 Sep. 24, 2009 Page 38 of 928
0
Lower
LSB
Section 2 CPU
Data Type
Register Number
Word data
Rn
Data Format
15
0
MSB
Word data
15
0
MSB
LSB
Longword data
ERn
31
MSB
LSB
En
16 15
En
0
Rn
LSB
Legend:
ERn
: General register ER
En
: General register E
Rn
: General register R
RnH
: General register RH
RnL
: General register RL
MSB : Most significant bit
LSB
: Least significant bit
Figure 2.9 General Register Data Formats (2)
Rev. 6.00 Sep. 24, 2009 Page 39 of 928
REJ09B0099-0600
Section 2 CPU
2.5.2
Memory Data Formats
Figure 2.10 shows the data formats in memory. The H8S/2000 CPU can access word data and
longword data in memory, but word or longword data must begin at an even address. If an attempt
is made to access word or longword data at an odd address, no address error occurs but the least
significant bit of the address is regarded as 0, so the access starts at the preceding address. This
also applies to instruction fetches.
When ER7 is used as an address register to access the stack, the operand size should be word or
longword.
Data Type
Address
Data Format
7
1-bit data
Address L
7
Byte data
Address L
MSB
Word data
Address 2M
MSB
0
6
5
4
3
2
Address 2N
0
LSB
LSB
Address 2M+1
Longword data
1
MSB
Address 2N+1
Address 2N+2
Address 2N+3
LSB
Figure 2.10 Memory Data Formats
2.6
Instruction Set
The H8S/2000 CPU has 65 types of instructions. The instructions are classified by function in
table 2.1.
Rev. 6.00 Sep. 24, 2009 Page 40 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.1
Instruction Classification
Function
Data transfer
Instructions
Size
Types
MOV
B/W/L
5
POP*1, PUSH*1
W/L
LDM*5, STM*5
3
MOVFPE* , MOVTPE*
Arithmetic
operations
L
3
B
ADD, SUB, CMP, NEG
B/W/L
ADDX, SUBX, DAA, DAS
B
INC, DEC
B/W/L
ADDS, SUBS
L
19
MULXU, DIVXU, MULXS, DIVXS
B/W
EXTU, EXTS
W/L
TAS*4
B
Logic operations
AND, OR, XOR, NOT
B/W/L
4
Shift
SHAL, SHAR, SHLL, SHLR, ROTL, ROTR, ROTXL,
ROTXR
B/W/L
8
Bit manipulation
BSET, BCLR, BNOT, BTST, BLD, BILD, BST, BIST, BAND, B
BIAND, BOR, BIOR, BXOR, BIXOR
Branch
Bcc*2, JMP, BSR, JSR, RTS
⎯
5
System control
TRAPA, RTE, SLEEP, LDC, STC, ANDC, ORC, XORC,
NOP
⎯
9
⎯
1
Block data transfer EEPMOV
14
Total: 65
Legend:
B:
Byte
W:
Word
L:
Longword
Notes: 1. POP.W Rn and PUSH.W Rn are identical to MOV.W @SP+, Rn and MOV.W Rn,
@-SP. POP.L ERn and PUSH.L ERn are identical to MOV.L @SP+, ERn and MOV.L
ERn, @-SP.
2. Bcc is the general name for conditional branch instructions.
3. Cannot be used in this LSI.
4. Only register ER0, ER1, ER4, or ER5 should be used when using the TAS instruction.
5. Only register ER0 to ER6 should be used when using the STM/LDM instruction.
Rev. 6.00 Sep. 24, 2009 Page 41 of 928
REJ09B0099-0600
Section 2 CPU
2.6.1
Table of Instructions Classified by Function
Tables 2.3 to 2.10 summarize the instructions in each functional category. The notation used in
tables 2.3 to 2.10 is defined below.
Table 2.2
Operation Notation
Symbol
Description
Rd
General register (destination)*
Rs
General register (source)*
Rn
General register*
ERn
General register (32-bit register)
(EAd)
Destination operand
(EAs)
Source operand
EXR
Extended control register
CCR
Condition-code register
N
N (negative) flag in CCR
Z
Z (zero) flag in CCR
V
V (overflow) flag in CCR
C
C (carry) flag in CCR
PC
Program counter
SP
Stack pointer
#IMM
Immediate data
disp
Displacement
+
Addition
–
Subtraction
×
Multiplication
÷
Division
∧
Logical AND
∨
Logical OR
⊕
Logical XOR
Rev. 6.00 Sep. 24, 2009 Page 42 of 928
REJ09B0099-0600
Section 2 CPU
Symbol
Description
→
Move
∼
NOT (logical complement)
:8/:16/:24/:32
8-, 16-, 24-, or 32-bit length
Note:
*
General registers include 8-bit registers (R0H to R7H, R0L to R7L), 16-bit registers (R0
to R7, E0 to E7), and 32-bit registers (ER0 to ER7).
Table 2.3
Data Transfer Instructions
Instruction
Size*1
Function
MOV
B/W/L
(EAs) → Rd, Rs → (EAd)
Moves data between two general registers or between a general
register and memory, or moves immediate data to a general register.
MOVFPE
B
Cannot be used in this LSI.
MOVTPE
B
Cannot be used in this LSI.
POP
W/L
@SP+ → Rn
Pops a general register from the stack. POP.W Rn is identical to
MOV.W @SP+, Rn. POP.L ERn is identical to MOV.L @SP+, ERn.
PUSH
W/L
Rn → @–SP
Pushes a general register onto the stack. PUSH.W Rn is identical to
MOV.W Rn, @–SP. PUSH.L ERn is identical to MOV.L ERn, @–SP.
LDM*2
L
@SP+ → Rn (register list)
Pops two or more general registers from the stack.
STM*2
L
Rn (register list) → @–SP
Pushes two or more general registers onto the stack.
Notes: 1.
B:
W:
L:
2.
Refers to the operand size.
Byte
Word
Longword
Only register ER0 to ER6 should be used when using the STM/LDM instruction.
Rev. 6.00 Sep. 24, 2009 Page 43 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.4
Arithmetic Operations Instructions (1)
Instruction
Size*
Function
ADD
B/W/L
Rd ± Rs → Rd, Rd ± #IMM → Rd
Performs addition or subtraction on data in two general registers, or on
immediate data and data in a general register (immediate byte data
cannot be subtracted from byte data in a general register. Use the
SUBX or ADD instruction.)
B
Rd ± Rs ± C → Rd, Rd ± #IMM ± C → Rd
Performs addition or subtraction with carry on byte data in two general
registers, or on immediate data and data in a general register.
B/W/L
Rd ± 1 → Rd, Rd ± 2 → Rd
Increments or decrements a general register by 1 or 2. (Byte operands
can be incremented or decremented by 1 only.)
L
Rd ± 1 → Rd, Rd ± 2 → Rd, Rd ± 4 → Rd
Adds or subtracts the value 1, 2, or 4 to or from data in a 32-bit register.
B
Rd decimal adjust → Rd
Decimal-adjusts an addition or subtraction result in a general register by
referring to the CCR to produce 4-bit BCD data.
MULXU
B/W
Rd × Rs → Rd
Performs unsigned multiplication on data in two general registers: either
8 bits × 8 bits → 16 bits or 16 bits × 16 bits → 32 bits.
MULXS
B/W
Rd × Rs → Rd
Performs signed multiplication on data in two general registers: either 8
bits × 8 bits → 16 bits or 16 bits × 16 bits → 32 bits.
DIVXU
B/W
Rd ÷ Rs → Rd
Performs unsigned division on data in two general registers: either 16
bits ÷ 8 bits → 8-bit quotient and 8-bit remainder or 32 bits ÷ 16 bits →
16-bit quotient and 16-bit remainder.
SUB
ADDX
SUBX
INC
DEC
ADDS
SUBS
DAA
DAS
Note:
*
B:
W:
L:
Refers to the operand size.
Byte
Word
Longword
Rev. 6.00 Sep. 24, 2009 Page 44 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.4
Arithmetic Operations Instructions (2)
Instruction
Size*1
Function
DIVXS
B/W
Rd ÷ Rs → Rd
Performs signed division on data in two general registers: either 16 bits
÷ 8 bits → 8-bit quotient and 8-bit remainder or 32 bits ÷ 16 bits → 16bit quotient and 16-bit remainder.
CMP
B/W/L
Rd – Rs, Rd – #IMM
Compares data in a general register with data in another general
register or with immediate data, and sets CCR bits according to the
result.
NEG
B/W/L
0 – Rd → Rd
Takes the two's complement (arithmetic complement) of data in a
general register.
EXTU
W/L
Rd (zero extension) → Rd
Extends the lower 8 bits of a 16-bit register to word size, or the lower 16
bits of a 32-bit register to longword size, by padding with zeros on the
left.
EXTS
W/L
Rd (sign extension) → Rd
Extends the lower 8 bits of a 16-bit register to word size, or the lower 16
bits of a 32-bit register to longword size, by extending the sign bit.
TAS*2
B
@ERd – 0, 1 → (<bit 7> of @ERd)
Tests memory contents, and sets the most significant bit (bit 7) to 1.
Notes: 1.
B:
W:
L:
2.
Refers to the operand size.
Byte
Word
Longword
Only register ER0, ER1, ER4, or ER5 should be used when using the TAS instruction.
Rev. 6.00 Sep. 24, 2009 Page 45 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.5
Logic Operations Instructions
Instruction
Size*
Function
AND
B/W/L
Rd ∧ Rs → Rd, Rd ∧ #IMM → Rd
Performs a logical AND operation on a general register and another
general register or immediate data.
OR
B/W/L
Rd ∨ Rs → Rd, Rd ∨ #IMM → Rd
Performs a logical OR operation on a general register and another
general register or immediate data.
XOR
B/W/L
Rd ⊕ Rs → Rd, Rd ⊕ #IMM → Rd
Performs a logical exclusive OR operation on a general register and
another general register or immediate data.
NOT
B/W/L
∼ Rd → Rd
Takes the one's complement of general register contents.
Note:
*
B:
W:
L:
Refers to the operand size.
Byte
Word
Longword
Table 2.6
Shift Instructions
Instruction
Size*
Function
SHAL
B/W/L
Rd (shift) → Rd
Performs an arithmetic shift on general register contents.
1-bit or 2-bit shifts are possible.
B/W/L
Rd (shift) → Rd
Performs a logical shift on general register contents.
1-bit or 2-bit shifts are possible.
B/W/L
Rd (rotate) → Rd
Rotates general register contents.
1-bit or 2-bit rotations are possible.
B/W/L
Rd (rotate) → Rd
Rotates general register contents through the carry flag.
1-bit or 2-bit rotations are possible.
SHAR
SHLL
SHLR
ROTL
ROTR
ROTXL
ROTXR
Note:
*
B:
W:
L:
Refers to the operand size.
Byte
Word
Longword
Rev. 6.00 Sep. 24, 2009 Page 46 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.7
Bit Manipulation Instructions (1)
Instruction
Size*
Function
BSET
B
1 → (<bit-No.> of <EAd>)
Sets a specified bit in a general register or memory operand to 1. The
bit number is specified by 3-bit immediate data or the lower three bits of
a general register.
BCLR
B
0 → (<bit-No.> of <EAd>)
Clears a specified bit in a general register or memory operand to 0. The
bit number is specified by 3-bit immediate data or the lower three bits of
a general register.
BNOT
B
∼ (<bit-No.> of <EAd>) → (<bit-No.> of <EAd>)
Inverts a specified bit in a general register or memory operand. The bit
number is specified by 3-bit immediate data or the lower three bits of a
general register.
BTST
B
∼ (<bit-No.> of <EAd>) → Z
Tests a specified bit in a general register or memory operand and sets
or clears the Z flag accordingly. The bit number is specified by 3-bit
immediate data or the lower three bits of a general register.
BAND
B
C ∧ (<bit-No.> of <EAd>) → C
ANDs the carry flag with a specified bit in a general register or memory
operand and stores the result in the carry flag.
BIAND
B
C ∧ ← (<bit-No.> of <EAd>) → C
ANDs the carry flag with the inverse of a specified bit in a general
register or memory operand and stores the result in the carry flag.
The bit number is specified by 3-bit immediate data.
BOR
B
C ∨ (<bit-No.> of <EAd>) → C
ORs the carry flag with a specified bit in a general register or memory
operand and stores the result in the carry flag.
BIOR
B
C ∨ ← (<bit-No.> of <EAd>) → C
ORs the carry flag with the inverse of a specified bit in a general register
or memory operand and stores the result in the carry flag.
The bit number is specified by 3-bit immediate data.
Note:
* Refers to the operand size.
B: Byte
Rev. 6.00 Sep. 24, 2009 Page 47 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.7
Bit Manipulation Instructions (2)
Instruction
Size*
Function
BXOR
B
C ⊕ (<bit-No.> of <EAd>) → C
XORs the carry flag with a specified bit in a general register or memory
operand and stores the result in the carry flag.
BIXOR
B
C ⊕ ← (<bit-No.> of <EAd>) → C
XORs the carry flag with the inverse of a specified bit in a general
register or memory operand and stores the result in the carry flag.
The bit number is specified by 3-bit immediate data.
BLD
B
(<bit-No.> of <EAd>) → C
Transfers a specified bit in a general register or memory operand to the
carry flag.
BILD
B
∼ (<bit-No.> of <EAd>) → C
Transfers the inverse of a specified bit in a general register or memory
operand to the carry flag.
The bit number is specified by 3-bit immediate data.
BST
B
C → (<bit-No.> of <EAd>)
Transfers the carry flag value to a specified bit in a general register or
memory operand.
BIST
B
∼ C → (<bit-No.> of <EAd>)
Transfers the inverse of the carry flag value to a specified bit in a
general register or memory operand.
The bit number is specified by 3-bit immediate data.
Note:
* Refers to the operand size.
B: Byte
Rev. 6.00 Sep. 24, 2009 Page 48 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.8
Branch Instructions
Instruction
Size
Function
Bcc
⎯
Branches to a specified address if a specified condition is true. The
branching conditions are listed below.
Mnemonic
Description
Condition
BRA(BT)
Always (true)
Always
BRN(BF)
Never (false)
Never
BHI
High
C∨Z=0
BLS
Low or same
C∨Z=1
BCC(BHS)
Carry clear
(high or same)
C=0
BCS(BLO)
Carry set (low)
C=1
BNE
Not equal
Z=0
BEQ
Equal
Z=1
BVC
Overflow clear
V=0
BVS
Overflow set
V=1
BPL
Plus
N=0
BMI
Minus
N=1
BGE
Greater or equal
N⊕V=0
BLT
Less than
N⊕V=1
BGT
Greater than
Z∨(N ⊕ V) = 0
BLE
Less or equal
Z∨(N ⊕ V) = 1
JMP
⎯
Branches unconditionally to a specified address.
BSR
⎯
Branches to a subroutine at a specified address.
JSR
⎯
Branches to a subroutine at a specified address.
RTS
⎯
Returns from a subroutine
Rev. 6.00 Sep. 24, 2009 Page 49 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.9
System Control Instructions
Instruction
Size*
Function
TRAPA
⎯
Starts trap-instruction exception handling.
RTE
⎯
Returns from an exception-handling routine.
SLEEP
⎯
Causes a transition to a power-down state.
LDC
B/W
(EAs) → CCR, (EAs) → EXR
Moves the source operand contents or immediate data to CCR or EXR.
Although CCR and EXR are 8-bit registers, word-size transfers are
performed between them and memory. The upper 8 bits are valid.
STC
B/W
CCR → (EAd), EXR → (EAd)
Transfers CCR or EXR contents to a general register or memory.
Although CCR and EXR are 8-bit registers, word-size transfers are
performed between them and memory. The upper 8 bits are valid.
ANDC
B
CCR ∧ #IMM → CCR, EXR ∧ #IMM → EXR
Logically ANDs the CCR or EXR contents with immediate data.
ORC
B
CCR ∨ #IMM → CCR, EXR ∨ #IMM → EXR
Logically ORs the CCR or EXR contents with immediate data.
XORC
B
CCR ⊕ #IMM → CCR, EXR ⊕ #IMM → EXR
Logically XORs the CCR or EXR contents with immediate data.
NOP
⎯
PC + 2 → PC
Only increments the program counter.
Note:
* Refers to the operand size.
B: Byte
W: Word
Rev. 6.00 Sep. 24, 2009 Page 50 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.10 Block Data Transfer Instructions
Instruction
Size
Function
EEPMOV.B
⎯
if R4L ≠ 0 then
Repeat @ER5+ → @ER6+
R4L–1 → R4L
Until R4L = 0
else next;
EEPMOV.W
⎯
if R4 ≠ 0 then
Repeat @ER5+ → @ER6+
R4–1 → R4
Until R4 = 0
else next;
Transfers a data block. Starting from the address set in ER5, transfers
data for the number of bytes set in R4L or R4 to the address location set
in ER6.
Execution of the next instruction begins as soon as the transfer is
completed.
2.6.2
Basic Instruction Formats
This LSI instructions consist of 2-byte (1-word) units. An instruction consists of an operation field
(op field), a register field (r field), an effective address extension (EA field), and a condition field
(cc).
Figure 2.11 shows examples of instruction formats.
• Operation Field
Indicates the function of the instruction, the addressing mode, and the operation to be carried
out on the operand. The operation field always includes the first four bits of the instruction.
Some instructions have two operation fields.
• Register Field
Specifies a general register. Address registers are specified by 3 bits, and data registers by 3
bits or 4 bits. Some instructions have two register fields. Some have no register field.
• Effective Address Extension
8, 16, or 32 bits specifying immediate data, an absolute address, or a displacement.
• Condition Field
Specifies the branching condition of Bcc instructions.
Rev. 6.00 Sep. 24, 2009 Page 51 of 928
REJ09B0099-0600
Section 2 CPU
(1) Operation field only
op
NOP, RTS, etc.
(2) Operation field and register fields
op
rm
rn
ADD.B Rn, Rm, etc.
(3) Operation field, register fields, and effective address extension
op
rn
rm
MOV.B @(d:16, Rn), Rm, etc.
EA(disp)
(4) Operation field, effective address extension, and condition field
op
cc
EA(disp)
BRA d:16, etc.
Figure 2.11 Instruction Formats (Examples)
2.7
Addressing Modes and Effective Address Calculation
The H8S/2000 CPU supports the eight addressing modes listed in table 2.11. Each instruction uses
a subset of these addressing modes. Arithmetic and logic instructions can use the register direct
and immediate modes. Data transfer instructions can use all addressing modes except programcounter relative and memory indirect. Bit manipulation instructions use register direct, register
indirect, or the absolute addressing mode to specify an operand, and register direct (BSET, BCLR,
BNOT, and BTST instructions) or immediate (3-bit) addressing mode to specify a bit number in
the operand.
Rev. 6.00 Sep. 24, 2009 Page 52 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.11 Addressing Modes
No.
Addressing Mode
Symbol
1
Register direct
Rn
2
Register indirect
@ERn
3
Register indirect with displacement
@(d:16,ERn)/@(d:32,ERn)
4
Register indirect with post-increment
Register indirect with pre-decrement
@ERn+
@–ERn
5
Absolute address
@aa:8/@aa:16/@aa:24/@aa:32
6
Immediate
#xx:8/#xx:16/#xx:32
7
Program-counter relative
@(d:8,PC)/@(d:16,PC)
8
Memory indirect
@@aa:8
2.7.1
Register Direct⎯Rn
The register field of the instruction specifies an 8-, 16-, or 32-bit general register containing the
operand. R0H to R7H and R0L to R7L can be specified as 8-bit registers. R0 to R7 and E0 to E7
can be specified as 16-bit registers. ER0 to ER7 can be specified as 32-bit registers.
2.7.2
Register Indirect⎯@ERn
The register field of the instruction code specifies an address register (ERn) which contains the
address of the operand on memory. If the address is a program instruction address, the lower 24
bits are valid and the upper 8 bits are all assumed to be 0 (H'00).
2.7.3
Register Indirect with Displacement⎯@(d:16, ERn) or @(d:32, ERn)
A 16-bit or 32-bit displacement contained in the instruction is added to an address register (ERn)
specified by the register field of the instruction, and the sum gives the address of a memory
operand. A 16-bit displacement is sign-extended when added.
2.7.4
Register Indirect with Post-Increment or Pre-Decrement⎯@ERn+ or @-ERn
Register indirect with post-increment⎯@ERn+: The register field of the instruction code
specifies an address register (ERn) which contains the address of a memory operand. After the
operand is accessed, 1, 2, or 4 is added to the address register contents and the sum is stored in the
address register. The value added is 1 for byte access, 2 for word transfer instruction, or 4 for
Rev. 6.00 Sep. 24, 2009 Page 53 of 928
REJ09B0099-0600
Section 2 CPU
longword transfer instruction. For the word or longword transfer instructions, the register value
should be even.
Register indirect with pre-decrement⎯@-ERn: The value 1, 2, or 4 is subtracted from an
address register (ERn) specified by the register field in the instruction code, and the result is the
address of a memory operand. The result is also stored in the address register. The value
subtracted is 1 for byte access, 2 for word transfer instruction, or 4 for longword transfer
instruction. For the word or longword transfer instructions, the register value should be even.
2.7.5
Absolute Address⎯@aa:8, @aa:16, @aa:24, or @aa:32
The instruction code contains the absolute address of a memory operand. The absolute address
may be 8 bits long (@aa:8), 16 bits long (@aa:16), 24 bits long (@aa:24), or 32 bits long
(@aa:32). Table 2.12 indicates the accessible absolute address ranges.
To access data, the absolute address should be 8 bits (@aa:8), 16 bits (@aa:16), or 32 bits
(@aa:32) long. For an 8-bit absolute address, the upper 24 bits are all assumed to be 1 (H'FFFF).
For a 16-bit absolute address the upper 16 bits are a sign extension. A 32-bit absolute address can
access the entire address space.
A 24-bit absolute address (@aa:24) indicates the address of a program instruction. The upper 8
bits are all assumed to be 0 (H'00).
Table 2.12 Absolute Address Access Ranges
Absolute Address
Data address
Normal Mode*
Advanced Mode
8 bits (@aa:8)
H'FF00 to H'FFFF
H'FFFF00 to H'FFFFFF
16 bits (@aa:16)
H'0000 to H'FFFF
H'000000 to H'007FFF,
H'FF8000 to H'FFFFFF
32 bits (@aa:32)
Program instruction
address
Note:
2.7.6
*
H'000000 to H'FFFFFF
24 bits (@aa:24)
Normal mode is not available in this LSI.
Immediate⎯#xx:8, #xx:16, or #xx:32
The instruction contains 8-bit (#xx:8), 16-bit (#xx:16), or 32-bit (#xx:32) immediate data as an
operand.
Rev. 6.00 Sep. 24, 2009 Page 54 of 928
REJ09B0099-0600
Section 2 CPU
The ADDS, SUBS, INC and DEC instructions contain immediate data implicitly. Some bit
manipulation instructions contain 3-bit immediate data in the instruction code, specifying a bit
number. The TRAPA instruction contains 2-bit immediate data in its instruction code, specifying a
vector address.
2.7.7
Program-Counter Relative⎯@(d:8, PC) or @(d:16, PC)
This mode is used in the Bcc and BSR instructions. An 8-bit or 16-bit displacement contained in
the instruction is sign-extended and added to the 24-bit PC contents to generate a branch address.
Only the lower 24 bits of this branch address are valid; the upper 8 bits are all assumed to be 0
(H'00). The PC value to which the displacement is added is the address of the first byte of the next
instruction, so the possible branching range is –126 to +128 bytes (–63 to +64 words) or –32766 to
+32768 bytes (–16383 to +16384 words) from the branch instruction. The resulting value should
be an even number.
2.7.8
Memory Indirect⎯@@aa:8
This mode can be used by the JMP and JSR instructions. The instruction code contains an 8-bit
absolute address specifying a memory operand. This memory operand contains a branch address.
The upper bits of the absolute address are all assumed to be 0, so the address range is 0 to 255
(H'0000 to H'00FF in normal mode*, H'000000 to H'0000FF in advanced mode). In normal mode,
the memory operand is a word operand and the branch address is 16 bits long. In advanced mode,
the memory operand is a longword operand, the first byte of which is assumed to be 0 (H'00).
Note that the first part of the address range is also the exception vector area. For further details,
see section 4, Exception Handling.
If an odd address is specified in word or longword memory access, or as a branch address, the
least significant bit is regarded as 0, causing data to be accessed or instruction code to be fetched
at the address preceding the specified address. (For further information, see section 2.5.2, Memory
Data Formats.)
Note: * Normal mode is not available in this LSI.
Rev. 6.00 Sep. 24, 2009 Page 55 of 928
REJ09B0099-0600
Section 2 CPU
Specified
by @aa:8
Branch address
Specified
by @aa:8
Reserved
Branch address
(a) Normal Mode*
(a) Advanced Mode
Note: * Normal mode is not available in this LSI.
Figure 2.12 Branch Address Specification in Memory Indirect Mode
2.7.9
Effective Address Calculation
Table 2.13 indicates how effective addresses are calculated in each addressing mode. In normal
mode the upper 8 bits of the effective address are ignored in order to generate a 16-bit address.
Rev. 6.00 Sep. 24, 2009 Page 56 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.13 Effective Address Calculation (1)
No
1
Addressing Mode and Instruction Format
op
2
Effective Address Calculation
Effective Address (EA)
Register direct(Rn)
rm
Operand is general register contents.
rn
Register indirect(@ERn)
0
31
op
3
31
24 23
0
Don't care
General register contents
r
Register indirect with displacement
@(d:16,ERn) or @(d:32,ERn)
0
31
General register contents
op
r
31
disp
Sign extension
Register indirect with post-increment or
pre-decrement
•Register indirect with post-increment @ERn+
op
disp
31
0
31
24 23
0
Don't care
General register contents
r
•Register indirect with pre-decrement @-ERn
0
0
31
4
24 23
Don't care
1, 2, or 4
31
0
General register contents
31
24 23
0
Don't care
op
r
1, 2, or 4
Operand Size
Byte
Word
Longword
Offset
1
2
4
Rev. 6.00 Sep. 24, 2009 Page 57 of 928
REJ09B0099-0600
Section 2 CPU
Table 2.13 Effective Address Calculation (2)
No
5
Addressing Mode and Instruction Format
Effective Address Calculation
Effective Address (EA)
Absolute address
@aa:8
31
op
@aa:16
31
op
0
H'FFFF
24 23
16 15
0
Don't care Sign extension
abs
@aa:24
31
op
8 7
24 23
Don't care
abs
24 23
0
Don't care
abs
@aa:32
op
31
6
Immediate
#xx:8/#xx:16/#xx:32
op
7
0
24 23
Don't care
abs
Operand is immediate data.
IMM
0
23
Program-counter relative
PC contents
@(d:8,PC)/@(d:16,PC)
op
disp
23
0
Sign
extension
disp
31
24 23
0
Don't care
8
Memory indirect @@aa:8
• Normal mode*
8 7
31
op
abs
0
abs
H'000000
15
0
31
24 23
Don't care
Memory contents
16 15
0
H'00
• Advanced mode
31
op
abs
8 7
H'000000
31
0
Memory contents
Note: * Normal mode is not available in this LSI.
Rev. 6.00 Sep. 24, 2009 Page 58 of 928
REJ09B0099-0600
0
abs
31
24 23
Don't care
0
Section 2 CPU
2.8
Processing States
The H8S/2000 CPU has five main processing states: the reset state, exception handling state,
program execution state, bus-released state, and power-down state. Figure 2.13 indicates the state
transitions.
• Reset State
In this state, the CPU and all on-chip peripheral modules are initialized and not operating.
When the RES input goes low, all current processing stops and the CPU enters the reset state.
All interrupts are masked in the reset state. Reset exception handling starts when the RES
signal changes from low to high. For details, see section 4, Exception Handling.
The reset state can also be entered by a watchdog timer overflow.
• Exception-Handling State
The exception-handling state is a transient state that occurs when the CPU alters the normal
processing flow due to an exception source, such as a reset, trace, interrupt, or trap instruction.
The CPU fetches a start address (vector) from the exception vector table and branches to that
address. For further details, see section 4, Exception Handling.
• Program Execution State
In this state, the CPU executes program instructions in sequence.
• Bus-Released State
In a product which has a bus master other than the CPU, such as a data transfer controller
(DTC), the bus-released state occurs when the bus has been released in response to a bus
request from a bus master other than the CPU.
While the bus is released, the CPU halts operations.
• Power-down State
This is a power-down state in which the CPU stops operating. The program stop state occurs
when a SLEEP instruction is executed or the CPU enters hardware standby mode. For further
details, see section 22, Power-Down Modes.
Rev. 6.00 Sep. 24, 2009 Page 59 of 928
REJ09B0099-0600
Section 2 CPU
End of bus request
Bus request
tio
n
ha
nd
lin
g
Program execution state
s
bu
f
t
t
o
SLEEP instruction,
es
d ues
qu
En req
SSBY = 0
re
s
Bu
Sleep mode
eq
pt r
rru
Inte
t
ues
SLEEP instruction,
SSBY = 1
En
d
o
ha f ex
nd ce
lin pti
g on
Re
qu
es
tf
or
ex
ce
p
Bus-released state
Exception handling state
External interrupt request
Software standby mode
RES = high
MRES = high
Manual reset state *1
Power-on reset state *1
STBY = high,
RES = low
Reset state
Hardware standby mode*2
Power-down state*3
Notes: 1. From any state except hardware standby mode, a transition to the reset state occurs
whenever RES goes low. A transition can also be made to the reset state when the
watchdog timer overflows.
2. From any state, a transition to hardware standby mode occurs when STBY goes low.
3. Apart from these states, there is also watch mode. For details, see section 22,
Power-Down Modes.
Figure 2.13 State Transitions
Rev. 6.00 Sep. 24, 2009 Page 60 of 928
REJ09B0099-0600
Section 2 CPU
2.9
Usage Notes
2.9.1
TAS Instruction
Only register ER0, ER1, ER4, or ER5 should be used when using the TAS instruction. The TAS
instruction is not generated by the H8S and H8/300 Series C/C++ compilers. If the TAS
instruction is used as a user-defined intrinsic function, ensure that only register ER0, ER1, ER4, or
ER5 is used.
2.9.2
STM/LDM Instruction
With the STM or LDM instruction, the ER7 register is used as the stack pointer, and thus cannot
be used as a register that allows save (STM) or restore (LDM) operation.
With a single STM or LDM instruction, two to four registers can be saved or restored. The
available registers are as follows:
For two registers: ER0 and ER1, ER2 and ER3, or ER4 and ER5
For three registers: ER0 to ER2, or ER4 to ER6
For four registers: ER0 to ER3
For the H8S or H8/300 Series C/C++ Compiler, the STM/LDM instruction including ER7 is not
created.
2.9.3
Bit Manipulation Instructions
When bit-manipulation is used with registers that include write-only bits, bits to be manipulated
may not be manipulated properly or bits unrelated to the bit-manipulation may be changed.
Some values read from write-only bits are fixed and some are undefined. When such bits are the
operands of bit-manipulation instructions that use read values in arithmetic operations (BNOT,
BTST, BAND, BIAND, BOR, BIOR, BXOR, BIXOR, BLD, BILD), the desired bit-manipulation
will not be executed.
Also, bit-manipulation instructions that write back data according to the results of arithmetic
operations (BSET, BCLR, BNOT, BST, BIST) may change bits that are not related to the bitmanipulation. Therefore, special care is necessary when using these instructions with registers that
include write-only bits.
Rev. 6.00 Sep. 24, 2009 Page 61 of 928
REJ09B0099-0600
Section 2 CPU
The BSET, BCLR, BNOT, BST and BIST instructions are executed as follows:
1. Data is read in bytes.
2. The operation corresponding to the instruction is applied to the specified bit of the data.
3. The byte produced by the bit-manipulation is written back.
• Consider this example, where the BCLR instruction is executed to clear only bit 4 in P1DDR
of Port 1.
P1DDR is an 8-bit register that consists of write-only bits and specifies input or output for
each pin of port 1. Reading of these bits is not valid, since values read are specified as
undefined.
In the following example, the BCLR instruction specifies P14 as an input. Before the
operation, P17 to P14 are set as output pins and P13 to P10 are set as input pins. The value of
P1DDR is H'F0.
I/O
P17
P16
P15
P14
P13
P12
P11
P10
Output
Output
Output
Output
Input
Input
Input
Input
1
1
1
1
0
0
0
0
P1DDR
To switch P14 from an output to an input, the value of bit 4 in P1DDR has to be changed from
1 to 0 (from H'F0 to H'E0). The BCLR instruction used to clear bit 4 in P1DDR is as follows.
BCLR
#4, @P1DDR
However, the above bit-manipulation of the write-only P1DDR register may cause the
following problem.
The data in P1DDR is read in bytes. Data read from P1DDR is undefined. Thus, regardless of
whether the value in the register is 0 or 1, it is impossible to tell which value will be read. All
bits in P1DDR are write-only, thus read as undefined. The actual value in P1DDR is H'F0. Let
us assume that the value read is H'F8, where the value of bit 3 is read as 1 rather than its actual
value of 0.
P17
P16
P15
P14
P13
P12
P11
P10
Output
Output
Output
Output
Input
Input
Input
Input
P1DDR
1
1
1
1
0
0
0
0
Read value
1
1
1
1
1
0
0
0
I/O
Rev. 6.00 Sep. 24, 2009 Page 62 of 928
REJ09B0099-0600
Section 2 CPU
The target bit of the data read out is then manipulated. In this example, clearing bit 4 of H'F8
leaves us with H'E8.
P17
P16
P15
P14
P13
P12
P11
P10
Output
Output
Output
Output
Input
Input
Input
Input
P1DDR
1
1
1
1
0
0
0
0
After bitmanipulation
1
1
1
0
1
0
0
0
I/O
After the bit-manipulation, The data is then written back to P1DDR, and execution of the
BCLR instruction is complete.
P17
P16
P15
P14
P13
P12
P11
P10
Output
Output
Output
Input
Output
Input
Input
Input
P1DDR
1
1
1
0
1
0
0
0
Write value
1
1
1
0
1
0
0
0
I/O
This instruction was meant to change the value of P1DDR to H'E0, but H'E8 was written back
instead. P13, which should be an input pin, has been turned into an output pin. Note that while
the error in this case occurred because bit 3 in P1DDR was read as 1, the values read from bits
7 to 0 in P1DDR are undefined. Bit-manipulation instructions that write back values might
change any bit from 0 to 1 or 1 to 0. Section 2.9.4, Access Method for Registers with WriteOnly Bits, describes a way to avoid this possibility when changing the values of registers that
include write-only bits.
The BCLR instruction can be used to clear flags in the internal I/O registers to 0. In this case,
if it is obvious that a given flag has been set to 1 because an interrupt handler has been entered,
there is no need to read the flag .
2.9.4
Access Method for Registers with Write-Only Bits
A read value from a write-only bit using a data-transfer or a bit-manipulation instruction is
undefined. To avoid using the read value for subsequent operations, follow the procedure shown
below to access registers that include write-only bits.
When writing to registers that include write-only bits, set up a work area in memory such as onchip RAM, write the data to the work area, read the data back from the memory, and then write
the data to the registers that include write-only bits.
Rev. 6.00 Sep. 24, 2009 Page 63 of 928
REJ09B0099-0600
Section 2 CPU
Write initial data to work area
Writing initial value
Copy data from work area to
register including write-only bit
Access data in work area
(data-transfer and bit-manipulation
instructions can be used)
Changing value of register
including write-only bit
Copy data from work area to
register including write-only bit
Figure 2.14 Flowchart of Access Method for Registers with Write-Only Bits
• Consider the following example, where only bit 4 in P1DDR of port 1 is cleared.
P1DDR is an 8-bit register that consists of write-only bits and specifies input or output for
each pin of port 1. Reading of these bits is not valid, since values read are specified as
undefined.
In the following example, the BCLR instruction specifies P14 as an input. Start by writing the
initial value H'F0, which will be written to P1DDR, to the work area (RAM0) in memory.
MOV.B
#H'F0, R0L
MOV.B
R0L, @RAM0
MOV.B
R0L, @P1DDR
P17
P16
P15
P14
P13
P12
P11
P10
Output
Output
Output
Output
Input
Input
Input
Input
P1DDR
1
1
1
1
0
0
0
0
RAM0
1
1
1
1
0
0
0
0
I/O
P14 is now an output. To switch P14 from an output to an input, the value of bit 4 in P1DDR
has to be changed from 1 to 0 (from H'F0 to H'E0). Clear bit 4 of RAM0 using the BCLR
instruction.
BCLR
#4,
@RAM0
Rev. 6.00 Sep. 24, 2009 Page 64 of 928
REJ09B0099-0600
Section 2 CPU
P17
P16
P15
P14
P13
P12
P11
P10
Output
Output
Output
Output
Input
Input
Input
Input
P1DDR
1
1
1
1
0
0
0
0
RAM0
1
1
1
0
0
0
0
0
I/O
RAM locations are readable and writable, so there is no possibility of a problem if a bitmanipulation instruction is used to clear only bit 4 of RAM0. Read the value from RAM0 and
then write it back to P1DDR.
MOV.B
@RAM0,
R0L
MOV.B
R0L,
@P1DDR
P17
P16
P15
P14
P13
P12
P11
P10
Output
Output
Output
Input
Input
Input
Input
Input
P1DDR
1
1
1
0
0
0
0
0
RAM0
1
1
1
0
0
0
0
0
I/O
Following this procedure in access to registers that include write-only bits makes the behavior
of the program independent of the type of instruction.
Rev. 6.00 Sep. 24, 2009 Page 65 of 928
REJ09B0099-0600
Section 2 CPU
Rev. 6.00 Sep. 24, 2009 Page 66 of 928
REJ09B0099-0600
Section 3 MCU Operating Modes
Section 3 MCU Operating Modes
3.1
Operating Mode Selection
This LSI supports two types of operating mode (modes 6 and 7). Pin functions are changed
according to each operating mode. The operation mode is determined by the setting of mode pins
(MD2 to MD0). Mode 6 is the external expansion mode, which allows external memory and
peripheral device to be accessed. In external expansion mode, the bus controller sets address space
of 8 bits or 16 bits for each area after the program is started to execute. Making one of the areas a
16-bit address space leads to 16-bit bus mode and making all the area 8-bit access space leads to
8-bit bus mode.
In mode 7, the external address space cannot be used. Mode pins should not be changed during
operations.
Table 3.1
MCU Operating Mode Selection
MCU
CPU
Operating
Operating
Mode
MD2 MD1 MD0 Mode
Description
External Data Bus
On-Chip
ROM
Initial
Width
Max.
Width
6
1
1
0
Advanced
mode
On-chip ROM valid Enabled
expansion mode
8 bits
16 bits
7
1
1
1
Advanced
mode
Single-chip mode
⎯
⎯
Enabled
Rev. 6.00 Sep. 24, 2009 Page 67 of 928
REJ09B0099-0600
Section 3 MCU Operating Modes
3.2
Register Descriptions
The following registers are related to the operating mode.
• Mode control register (MDCR)
• System control register (SYSCR)
3.2.1
Mode Control Register (MDCR)
MDCR monitors the current operating mode.
Bit
Bit Name
Initial
Value
R/W
Descriptions
7
⎯
1
⎯
Reserved
This bit is always read as 1 and cannot be modified.
⎯
6 to 3
All 0
⎯
Reserved
These bits are always read as 0 and cannot be modified.
2
MDS2
⎯*
R
Mode Select 2 to 0
1
MDS1
⎯*
R
0
MDS0
⎯*
R
These bits indicate the input levels at mode pins MD2 to
MD0 (the current operating mode). Bits MDS2 to MDS0
correspond to pins MD2 to MD0, respectively. MDS2 to
MDS0 are read-only bits and cannot be modified. The
input levels at mode pins MD2 to MD0 are latched into
these bits when MDCR is read. These latches are
canceled by a power-on reset, but retained by a manual
reset.
Note:
3.2.2
*
Determined by the setting of pins MD2 to MD0.
System Control Register (SYSCR)
SYSCR performs the selection of interrupt control mode, the selection of NMI detection edge, the
selection of enable/disable of MRES pin input, and the selection of valid/invalid of on-chip RAM.
Rev. 6.00 Sep. 24, 2009 Page 68 of 928
REJ09B0099-0600
Section 3 MCU Operating Modes
Bit
Bit Name
Initial
Value
R/W
Descriptions
7
⎯
0
R/W
Reserved
The write value should always be 0.
6
⎯
0
⎯
Reserved
This bit is always read as 0 and cannot be modified.
5
INTM1
0
R/W
4
INTM0
0
R/W
Select interrupt control mode of the interrupt controller.
For interrupt control mode, see section 5.5.1, Interrupt
Control Modes and Interrupt Operation.
00: Interrupt control mode 0
01: Setting prohibited
10: Interrupt control mode 2
11: Setting prohibited
3
NMIEG
0
R/W
NMI Edge Select
Performs input edge selection of the NMI pin.
0: Interrupt request is generated at the falling edge of NMI
input.
1: Interrupt request is generated at the rising edge of NMI
input.
2
MRESE
0
R/W
Manual Reset Selection Bit
Selects enable/disable of the MRES pin input.
0: Disables manual reset.
1: Enables manual reset. The MRES pin input is enabled.
1
⎯
0
⎯
Reserved
This bit is always read as 0 and cannot be modified.
0
RAME
1
R/W
RAM Enable
Selects valid/invalid of the on-chip RAM. The RAME bit is
initialized when a reset is canceled.
0: The on-chip RAM is disabled.
1: The on-chip RAM is enabled.
Rev. 6.00 Sep. 24, 2009 Page 69 of 928
REJ09B0099-0600
Section 3 MCU Operating Modes
3.3
Operating Mode
3.3.1
Mode 6
The CPU can access a 16-Mbyte address space in advanced mode. The on-chip ROM is valid.
Immediately after a reset, ports A, B, and C become input ports. The AE3 to AEO bits in PFCR
allow enable/disable setting of the address (A23 to A8) output, regardless of the corresponding
DDR value. The pin which is disabled of the address output at ports A and B becomes an output
port when the corresponding DDR is set to 1.
The address (A7 to A0) is output when the corresponding DDR is set to 1 at port C.
Ports D and E are data buses, and a part of the port F is the bus control signal.
Immediately after a reset, 8-bits bus mode is set and all the areas become 8-bit access space.
However, when any of the areas is set to 16-bit access space by the bus controller, 16-bit bus
mode is set and port E becomes the data bus.
3.3.2
Mode 7
The CPU can access a 16-Mbyte address space in advanced mode. The on-chip ROM is valid and
the external address space cannot be accessed.
All the I/O port can be used as an input/output port.
3.3.3
Pin Functions
Table 3.2 shows the pin functions in modes 6 and 7.
Rev. 6.00 Sep. 24, 2009 Page 70 of 928
REJ09B0099-0600
Section 3 MCU Operating Modes
Table 3.2
Pin Function in Each Operating Mode
Port
Mode 6
Mode 7
Port A
P*/A
P
Port B
P*/A
P
Port C
P*/A
P
Port D
D
P
Port E
P*/D
P
PF7
P/C*
P*/C
PF6 to PF4
C
P
PF3
P*/C
PF2 to PF0
P*/C
Port F
Legend:
P: Input/output port
A: Address bus output
D: Data bus Input/output
C: Control signal, clock Input/output
∗: Immediately after a reset
Rev. 6.00 Sep. 24, 2009 Page 71 of 928
REJ09B0099-0600
Section 3 MCU Operating Modes
3.4
Address Map in Each Operating Mode
Figures 3.1 to 3.3 show the address map of each product.
Mode 6
(Advanced and expanded
mode with on-chip ROM
enabled)
H'000000
Mode 7
(Advanced and Singlechip mode)
H'000000
On-chip ROM
On-chip ROM
H'07FFFF
H'080000
External address
space
H'FF7000
On-chip RAM
H'FF7000
H'FFEFBF
On-chip RAM
H'FFEFC0 External address space
H'FFF800
H'FFFF40
Internal
I/O registers
H'FFF800 Internal I/O registers
H'FFFF3F
Reserved area
H'FFFF60 Internal I/O registers
H'FFFF60 Internal I/O registers
H'FFFFC0
H'FFFFFF
H'FFFFC0
H'FFFFFF
On-chip RAM
On-chip RAM
Figure 3.1 Address Map of H8S/2556, H8S/2552, and H8S/2506
Rev. 6.00 Sep. 24, 2009 Page 72 of 928
REJ09B0099-0600
Section 3 MCU Operating Modes
Mode 6
(Advanced and expanded
mode with on-chip ROM
enabled)
H'000000
Mode 7
(Advanced and Singlechip mode)
H'000000
On-chip ROM
On-chip ROM
H'05FFFF
H'060000
Reserved area
H'080000
External address
space
H'FF7000
Reserved area
H'FF9000
On-chip RAM
H'FF9000
H'FFEFBF
On-chip RAM
H'FFEFC0 External address space
H'FFF800
H'FFFF40
Internal I/O registers
H'FFF800
Internal I/O registers
H'FFFF3F
Reserved area
H'FFFF60 Internal I/O registers
H'FFFF60 Internal I/O registers
H'FFFFC0
H'FFFFFF
H'FFFFC0
H'FFFFFF
On-chip RAM
On-chip RAM
Figure 3.2 Address Map of H8S/2551
Rev. 6.00 Sep. 24, 2009 Page 73 of 928
REJ09B0099-0600
Section 3 MCU Operating Modes
Mode 6
(Advanced and expanded
mode with on-chip ROM
enabled)
H'000000
Mode 7
(Advanced and Singlechip mode)
H'000000
On-chip ROM
On-chip ROM
H'05FFFF
H'060000
Reserved area
H'080000
External address
space
H'FF7000
H'FF7000
On-chip RAM
On-chip RAM
H'FFEFBF
H'FFEFC0 External address space
H'FFF800 Internal I/O registers
H'FFFF40
H'FFF800 Internal I/O registers
H'FFFF3F
Reserved area
H'FFFF60 Internal I/O registers
H'FFFF60 Internal I/O registers
H'FFFFC0
H'FFFFFF
H'FFFFC0
H'FFFFFF
On-chip RAM
On-chip RAM
Figure 3.3 Address Map of H8S/2505
Rev. 6.00 Sep. 24, 2009 Page 74 of 928
REJ09B0099-0600
Section 4 Exception Handling
Section 4 Exception Handling
4.1
Exception Handling Types and Priority
As table 4.1 indicates, exception handling may be caused by a reset, trace, trap instruction, or
interrupt. Exception handling is prioritized as shown in table 4.1. If two or more exceptions occur
simultaneously, they are accepted and processed in order of priority. Trap instruction exception
handling requests are accepted at all times in program execution state.
The exception source, the stack structure, and the operation of the CPU vary depending on the
interrupt control mode set by the INTM0 and INTM1 bits in SYSCR.
Table 4.1
Exception Types and Priority
Priority
Exception Type
Start of Exception Handling
High
Reset
Starts immediately after a low-to-high transition at the RES
and MRES pins, or when the watchdog timer overflows. The
CPU enters the power-on reset state when the RES pin is low.
The CPU enters the manual reset state when the MRES pin is
low.
Trace
Starts when execution of the current instruction or exception
handling ends, if the trace (T) bit is set to 1. Trace is enabled
only in interrupt control mode 2. Trace exception handling is
not executed after execution of an RTE instruction.
Interrupt
Starts when execution of the current instruction or exception
handling ends, if an interrupt request has been issued.
Interrupt detection is not performed on completion of ANDC,
ORC, XORC, or LDC instruction execution, or on completion
of reset exception handling.
Trap instruction
(TRAPA)
Started by execution of a trap instruction (TRAPA). Trap
instruction exception handling requests are accepted at all
times in program execution state.
Low
4.2
Exception Sources and Exception Vector Table
Different vector address is assigned to each exception source. Table 4.2 lists the exception sources
and their vector addresses.
Rev. 6.00 Sep. 24, 2009 Page 75 of 928
REJ09B0099-0600
Section 4 Exception Handling
Table 4.2
Exception Handling Vector Table
Vector Address*1
Exception Source
Vector Number
Advanced Mode
Power-on reset
0
H'0000 to H'0003
Manual reset
1
H'0004 to H'0007
Reserved for system use
2
H'0008 to H'000B
3
H'000C to H'000F
4
H'0010 to H'0013
5
H'0014 to H'0017
Direct transitions*
6
H'0018 to H'001B
External interrupt (NMI)
7
H'001C to H'001F
Trap instruction (four sources)
8
H'0020 to H'0023
9
H'0024 to H'0027
10
H'0028 to H'002B
11
H'002C to H'002F
12
H'0030 to H'0033
13
H'0034 to H'0037
14
H'0038 to H'003B
15
H'003C to H'003F
IRQ0
16
H'0040 to H'0043
IRQ1
17
H'0044 to H'0047
IRQ2
18
H'0048 to H'004B
IRQ3
19
H'004C to H'004F
IRQ4
20
H'0050 to H'0053
IRQ5
21
H'0054 to H'0057
IRQ6
22
H'0058 to H'005B
IRQ7
23
H'005C to H'005F
24
⎜
127
H'0060 to H'0063
⎜
H'01FC to H'01FF
Trace
3
Reserved for system use
External interrupt
2
Internal interrupt*
Notes: 1. Indicates lower 16 bits of the address.
2. For details on the internal interrupt vector table, see section 5.4.3, Interrupt Exception
Handling Vector Table.
3. Direct transitions are not supported in this LSI.
Rev. 6.00 Sep. 24, 2009 Page 76 of 928
REJ09B0099-0600
Section 4 Exception Handling
4.3
Reset
A reset has the highest exception priority.
When the RES or MRES pin goes low, all processing halts and this LSI enters the reset state. A
reset initializes the internal state of the CPU and the registers of the on-chip peripheral modules.
This LSI enters interrupt control mode 0 immediately after a reset.
When the RES or MRES pin goes high from the low state, this LSI starts reset exception handling.
The chip can also be reset by overflow of the watchdog timer. For details, see section 12,
Watchdog Timer (WDT).
4.3.1
Types of Reset
The LSI supports two types of resets: power-on reset and manual reset.
Table 4.3 shows the types of reset. Set to power-on reset when the power is tuned on.
The CPU internal status is initialized both by the power-on reset and the manual reset. By a
power-on reset, all registers of the on-chip peripheral modules are initialized; by a manual reset,
registers of the on-chip peripheral modules, except for the bus controller and I/O ports, are
initialized. The status of the bus controller and I/O ports is maintained.
By a manual reset, on-chip peripheral modules are initialized and thus ports used as input/output
pins of the on-chip peripheral modules are switched to input/output ports controlled by DDR and
DR.
Table 4.3
Types of Reset
Reset Shift Conditions
Internal State
MRES
RES
CPU
On-Chip Peripheral Modules
Power-on reset
*
Low
Initialized
Initialized
Manual reset
Low
High
Initialized
Initialized except for bus controller
and I/O ports
Types
Legend:
*:
Don’t care
The power-on reset and the manual reset are also available for the reset by the watchdog timer.
To enable the MRES pin, set the MRESE bit in SYSCR to 1.
Rev. 6.00 Sep. 24, 2009 Page 77 of 928
REJ09B0099-0600
Section 4 Exception Handling
4.3.2
Reset Exception Handling
When the RES or MRES pin goes low, this LSI enters the reset state. To ensure that this LSI is
reset, hold the RES pin low for at least 20 ms at power-up. To reset the chip during operation, hold
the RES or MRES pin low for at least 20 states.
When the RES or MRES pin goes high after being held low for the necessary time, this LSI starts
reset exception handling as follows:
1. The internal state of the CPU and the registers of the on-chip peripheral modules are
initialized, the T bit in EXR is cleared to 0, and the I bits in EXR and CCR are set to 1.
2. The reset exception handling vector address is read and transferred to the PC, and program
execution starts from the address indicated by the PC.
Figures 4.1 shows an example of the reset sequence.
Vector fetch
Fetch first instruction
Internal
processing of a program
(1)
(3)
φ
RES
Internal
address bus
(5)
Internal read
signal
Internal write
signal
Internal data
bus
(1)(3)
(2)(4)
(5)
(6)
High
(2)
(4)
(6)
Reset exception handling vector address (At a reset, (1) = H'000000; (3) = H'000002)
Start address (contents of reset exception handling vector address)
Start address ((5) = (2) (4))
First instruction of a program
Figure 4.1 Reset Sequence (Advanced Mode with On-Chip ROM Enabled)
Rev. 6.00 Sep. 24, 2009 Page 78 of 928
REJ09B0099-0600
Section 4 Exception Handling
4.3.3
Interrupts after Reset
If an interrupt is accepted after a reset and before the stack pointer (SP) is initialized, the PC and
CCR will not be saved correctly, leading to a program crash. To prevent this, all interrupt requests,
including NMI, are disabled immediately after a reset. Since the first instruction of a program is
always executed immediately after the reset state ends, make sure that this instruction initializes
the stack pointer (example: MOV.L #xx: 32, SP).
4.3.4
State of On-Chip Peripheral Modules after Reset Release
After reset release, MSTPCRA is initialized to H'3F, MSTPCRB and MSTPCRC are initialized to
H'FF, and all modules except the DTC enter module stop mode. Consequently, on-chip peripheral
module registers cannot be read or written to. Register reading and writing is enabled when the
module stop mode is exited.
4.4
Trace Exception Handling
Trace is enabled in interrupt control mode 2. Trace mode is not entered in interrupt control mode
0, irrespective of the state of the T bit. For details on the interrupt control mode, see section 5,
Interrupt Controller.
If the T bit in EXR is set to 1, trace mode is entered. In trace mode, a trace exception handling
occurs on completion of each instruction. After execution of trace exception handling, the T bit in
EXR is cleared to 0 and trace mode is canceled. Trace mode is not affected by interrupt masking.
Table 4.4 shows the state of CCR and EXR after execution of trace exception handling. Interrupts
are accepted even within the trace exception handling routine.
The T bit saved on the stack retains its value of 1, and when control is returned from the trace
exception handling routine by the RTE instruction, trace mode resumes. Trace exception handling
is not carried out after execution of the RTE instruction.
Rev. 6.00 Sep. 24, 2009 Page 79 of 928
REJ09B0099-0600
Section 4 Exception Handling
Table 4.4
State of CCR and EXR after Trace Exception Handling
CCR
Interrupt Control Mode
I
UI
EXR
I2 to I0
0
Trace exception handling cannot be used.
2
1
⎯
⎯
T
0
Legend:
1:
Set to 1
0:
Cleared to 0
⎯:
Retains value prior to execution
4.5
Interrupt Exception Handling
Interrupts are controlled by the interrupt controller. The interrupt controller has two interrupt
control modes and can assign interrupts other than NMI to eight priority/mask levels to enable
multiplexed interrupt control. For details, see section 5, Interrupt Controller.
Interrupt exception handling is conducted as follows:
1.
2.
3.
4.6
The values in the program counter (PC), condition code register (CCR), and extended register
(EXR) are saved to the stack.
The interrupt mask bit is updated and the T bit is cleared to 0.
A vector address corresponding to the interrupt source is generated, the start address is loaded
from the vector table to the PC, and program execution begins from that address.
Trap Instruction Exception Handling
Trap instruction exception handling starts when a TRAPA instruction is executed. Trap instruction
exception handling can be executed at all times in the program execution state.
Trap instruction exception handling is conducted as follows:
1.
2.
3.
The values in the program counter (PC), condition code register (CCR), and extended register
(EXR) are saved to the stack.
The interrupt mask bit is updated and the T bit is cleared to 0.
A vector address corresponding to the interrupt source is generated, the start address is loaded
from the vector table to the PC, and program execution starts from that address.
Rev. 6.00 Sep. 24, 2009 Page 80 of 928
REJ09B0099-0600
Section 4 Exception Handling
The TRAPA instruction fetches a start address from a vector table entry corresponding to a vector
number from 0 to 3, as specified in the instruction code.
Table 4.5 shows the state of CCR and EXR after execution of trap instruction exception handling.
Table 4.5
State of CCR and EXR after Trap Instruction Exception Handling
CCR
EXR
Interrupt Control Mode
I
UI
I2 to I0
T
0
1
⎯
⎯
⎯
2
1
⎯
⎯
0
Legend:
1:
Set to 1
0:
Cleared to 0
⎯: Retains value prior to execution
Rev. 6.00 Sep. 24, 2009 Page 81 of 928
REJ09B0099-0600
Section 4 Exception Handling
4.7
Stack State after Exception Handling
Figures 4.2 shows the stack state after completion of trap instruction exception handling and
interrupt exception handling.
SP
EXR
Reserved*
SP
CCR
CCR
PC
(24 bits)
PC
(24 bits)
(a) Interrupt control mode 0
(b) Interrupt control mode 2
Note:* Ignored on return.
Figure 4.2 Stack State after Exception Handling (Advanced Mode)
4.8
Usage Note
When accessing word data or longword data, this LSI assumes that the lowest address bit is 0. The
stack should always be accessed by word transfer instruction or longword transfer instruction, and
the value of the stack pointer (SP: ER7) should always be kept even. Use the following
instructions to save registers:
PUSH.W
Rn
(or MOV.W Rn, @-SP)
PUSH.L
ERn
(or MOV.L ERn, @-SP)
Use the following instructions to restore registers:
POP.W
Rn
(or MOV.W @SP+, Rn)
POP.L
ERn
(or MOV.L @SP+, ERn)
Setting the SP to an odd value may lead to a malfunction. Figure 4.3 shows an example of what
happens when the SP value is odd.
Rev. 6.00 Sep. 24, 2009 Page 82 of 928
REJ09B0099-0600
Section 4 Exception Handling
CCR
SP
R1L
SP
H'FFFEFA
H'FFFEFB
PC
PC
H'FFFEFC
H'FFFEFD
SP
H'FFFEFF
TRAPA instruction executed
SP set to H'FFFEFF
MOV.B R1L, @-ER7 executed
Data saved above SP
Contents of CCR lost
Legend:
CCR: Condition code register
PC: Program counter
R1L: General register R1L
SP: Stack pointer
Note: This diagram illustrates an example in interrupt control mode 0 and advanced mode.
Figure 4.3 Operation when SP Value Is Odd
Rev. 6.00 Sep. 24, 2009 Page 83 of 928
REJ09B0099-0600
Section 4 Exception Handling
Rev. 6.00 Sep. 24, 2009 Page 84 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Section 5 Interrupt Controller
5.1
Features
This LSI controls interrupts with the interrupt controller. The interrupt controller has the following
features:
• Two interrupt control modes
⎯ Any of two interrupt control modes can be set by means of the INTM1 and INTM0 bits in
the system control register (SYSCR).
• Priorities settable with IPR
⎯ An interrupt priority register (IPR) is provided for setting interrupt priorities. Eight priority
levels can be set for each module for all interrupts except NMI. NMI is assigned the
highest priority level of 8, and can be accepted at all times.
• Independent vector addresses
⎯ All interrupt sources are assigned independent vector addresses, making it unnecessary for
the source to be identified in the interrupt handling routine.
• Nine external interrupt pins
⎯ NMI is the highest-priority interrupt, and is accepted at all times. Rising edge or falling
edge can be selected for NMI.
⎯ Falling edge, rising edge, both edges, or level sensing can be independently selected for
IRQ7 to IRQ0.
• DTC control
⎯ The DTC can be activated by an interrupt request.
Rev. 6.00 Sep. 24, 2009 Page 85 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
A block diagram of the interrupt controller is shown in figure 5.1.
CPU
INTM1, INTM0
SYSCR
NMIEG
NMI input
NMI input unit
IRQ input
IRQ input unit
ISR
ISCR
IER
Interrupt
request
Vector number
Priority
determination
I
CCR
Internal interrupt
source
SWDTEND to TEI4
I2 to I0
IPR
Interrupt controller
Legend:
ISCR: IRQ sense control register
IRQ enable register
IER:
IRQ status register
ISR:
Interrupt priority register
IPR:
SYSCR: System control register
Figure 5.1 Block Diagram of Interrupt Controller
Rev. 6.00 Sep. 24, 2009 Page 86 of 928
REJ09B0099-0600
EXR
Section 5 Interrupt Controller
5.2
Input/Output Pins
Table 5.1 summarizes the pins of the interrupt controller.
Table 5.1
Pin Configuration
Name
I/O
Function
NMI
Input
Nonmaskable external interrupt
Rising edge or falling edge can be selected.
IRQ7
Input
Maskable external interrupt
IRQ6
Input
Rising edge, falling edge, both edges, or level sensing can be selected.
IRQ5
Input
IRQ4
Input
IRQ3
Input
IRQ2
Input
IRQ1
Input
IRQ0
Input
Rev. 6.00 Sep. 24, 2009 Page 87 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
5.3
Register Descriptions
The interrupt controller has the following registers. For details on the system control register, see
section 3.2.2, System Control Register (SYSCR).
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
System control register (SYSCR)
IRQ sense control register H (ISCRH)
IRQ sense control register L (ISCRL)
IRQ enable register (IER)
IRQ status register (ISR)
Interrupt priority register A (IPRA)
Interrupt priority register B (IPRB)
Interrupt priority register C (IPRC)
Interrupt priority register D (IPRD)
Interrupt priority register E (IPRE)
Interrupt priority register F (IPRF)
Interrupt priority register G (IPRG)
Interrupt priority register H (IPRH)
Interrupt priority register I (IPRI)
Interrupt priority register J (IPRJ)
Interrupt priority register K (IPRK)
Interrupt priority register L (IPRL)
Interrupt priority register M (IPRM)
Interrupt priority register O (IPRO)
Rev. 6.00 Sep. 24, 2009 Page 88 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
5.3.1
Interrupt Priority Registers A to M, and O (IPRA to IPRM, IPRO)
The IPR registers are fourteen 8-bit readable/writable registers that set priorities (levels 7 to 0) for
interrupts other than NMI. The correspondence between interrupt sources and IPR settings is
shown in section 5.4.3, Interrupt Exception Handling Vector Table. Setting a value in the range
from H'0 to H'7 in the 3-bit groups of bits 6 to 4 and 2 to 0 sets the priority of the corresponding
interrupt.
Bit
Bit Name
Initial
Value
R/W
7
⎯
0
⎯
Description
Reserved
This bit is always read as 0 and cannot be modified.
6
IPR6
1
R/W
5
IPR5
1
R/W
These bits set the priority of the corresponding interrupt
source.
4
IPR4
1
R/W
000: Priority level 0 (lowest)
001: Priority level 1
010: Priority level 2
011: Priority level 3
100: Priority level 4
101: Priority level 5
110: Priority level 6
111: Priority level 7 (highest)
3
⎯
0
⎯
2
IPR2
1
R/W
1
IPR1
1
R/W
These bits set the priority of the corresponding interrupt
source.
0
IPR0
1
R/W
000: Priority level 0 (lowest)
Reserved
This bit is always read as 0 and cannot be modified.
001: Priority level 1
010: Priority level 2
011: Priority level 3
100: Priority level 4
101: Priority level 5
110: Priority level 6
111: Priority level 7 (highest)
Rev. 6.00 Sep. 24, 2009 Page 89 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
5.3.2
IRQ Enable Register (IER)
IER controls the enabling and disabling of interrupt requests IRQ7 to IRQ0.
Bit
Bit Name
Initial
Value
R/W
Description
7
IRQ7E
0
R/W
IRQ7 Enable
The IRQ7 interrupt request is enabled when this bit is 1.
6
IRQ6E
0
R/W
IRQ6 Enable
The IRQ6 interrupt request is enabled when this bit is 1.
5
IRQ5E
0
R/W
IRQ5 Enable
4
IRQ4E
0
R/W
IRQ4 Enable
The IRQ5 interrupt request is enabled when this bit is 1.
The IRQ4 interrupt request is enabled when this bit is 1.
3
IRQ3E
0
R/W
IRQ3 Enable
The IRQ3 interrupt request is enabled when this bit is 1.
2
IRQ2E
0
R/W
IRQ2 Enable
The IRQ2 interrupt request is enabled when this bit is 1.
1
IRQ1E
0
R/W
IRQ1 Enable
The IRQ1 interrupt request is enabled when this bit is 1.
0
IRQ0E
0
R/W
IRQ0 Enable
The IRQ0 interrupt request is enabled when this bit is 1.
Rev. 6.00 Sep. 24, 2009 Page 90 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
5.3.3
IRQ Sense Control Registers H and L (ISCRH and ISCRL)
The ISCR registers select the source that generates an interrupt request at IRQ7 to IRQ0 pins.
Specifiable sources are the falling edge, rising edge, both edges, and level sensing.
Bit Bit Name
Initial
Value
R/W Description
15
IRQ7SCB 0
R/W IRQ7 Sense Control B
14
IRQ7SCA 0
R/W IRQ7 Sense Control A
00: Interrupt request is generated at IRQ7 input level low
01: Interrupt request is generated at falling edge of IRQ7 input
10: Interrupt request is generated at rising edge of IRQ7 input
11: Interrupt request is generated at both falling and rising
edges of IRQ7 input
13
IRQ6SCB 0
R/W IRQ6 Sense Control B
12
IRQ6SCA 0
R/W IRQ6 Sense Control A
00: Interrupt request is generated at IRQ6 input level low
01: Interrupt request is generated at falling edge of IRQ6 input
10: Interrupt request is generated at rising edge of IRQ6 input
11: Interrupt request is generated at both falling and rising
edges of IRQ6 input
11
IRQ5SCB 0
R/W IRQ5 Sense Control B
10
IRQ5SCA 0
R/W IRQ5 Sense Control A
00: Interrupt request is generated at IRQ5 input level low
01: Interrupt request is generated at falling edge of IRQ5 input
10: Interrupt request is generated at rising edge of IRQ5 input
11: Interrupt request is generated at both falling and rising
edges of IRQ5 input
9
IRQ4SCB 0
R/W IRQ4 Sense Control B
8
IRQ4SCA 0
R/W IRQ4 Sense Control A
00: Interrupt request is generated at IRQ4 input level low
01: Interrupt request is generated at falling edge of IRQ4 input
10: Interrupt request is generated at rising edge of IRQ4 input
11: Interrupt request is generated at both falling and rising
edges of IRQ4 input
Rev. 6.00 Sep. 24, 2009 Page 91 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Bit
Bit Name
Initial
Value
R/W
Description
7
IRQ3SCB
0
R/W
IRQ3 Sense Control B
6
IRQ3SCA
0
R/W
IRQ3 Sense Control A
00: Interrupt request is generated at IRQ3 input level low
01: Interrupt request is generated at falling edge of IRQ3
input
10: Interrupt request is generated at rising edge of IRQ3
input
11: Interrupt request is generated at both falling and rising
edges of IRQ3 input
5
IRQ2SCB
0
R/W
IRQ2 Sense Control B
4
IRQ2SCA
0
R/W
IRQ2 Sense Control A
00: Interrupt request is generated at IRQ2 input level low
01: Interrupt request is generated at falling edge of IRQ2
input
10: Interrupt request is generated at rising edge of IRQ2
input
11: Interrupt request is generated at both falling and rising
edges of IRQ2 input
3
IRQ1SCB
0
R/W
IRQ1 Sense Control B
2
IRQ1SCA
0
R/W
IRQ1 Sense Control A
00: Interrupt request is generated at IRQ1 input level low
01: Interrupt request is generated at falling edge of IRQ1
input
10: Interrupt request is generated at rising edge of IRQ1
input
11: Interrupt request is generated at both falling and rising
edges of IRQ1 input
Rev. 6.00 Sep. 24, 2009 Page 92 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Bit
Bit Name
Initial
Value
R/W
Description
1
IRQ0SCB
0
R/W
IRQ0 Sense Control B
0
IRQ0SCA
0
R/W
IRQ0 Sense Control A
00: Interrupt request is generated at IRQ0 input level low
01: Interrupt request is generated at falling edge of IRQ0
input
10: Interrupt request is generated at rising edge of IRQ0
input
11: Interrupt request is generated at both falling and rising
edges of IRQ0 input
5.3.4
IRQ Status Register (ISR)
ISR indicates the status of IRQ7 to IRQ 0 interrupt requests.
Bit
Bit Name
Initial
Value
R/W*
Description
7
IRQ7F
0
R/W
IRQ7 to IRQ0 flags
6
IRQ6F
0
R/W
5
IRQ5F
0
R/W
These bits indicate the status of IRQ7 to IRQ0 interrupt
requests.
4
IRQ4F
0
R/W
[Setting condition]
3
IRQ3F
0
R/W
•
2
IRQ2F
0
R/W
1
IRQ1F
0
R/W
0
IRQ0F
0
R/W
Note:
*
When the interrupt source selected by the ISCR
registers occurs
[Clearing conditions]
•
Cleared by reading IRQnF flag when IRQnF = 1, then
writing 0 to IRQnF flag
•
When interrupt exception handling is executed while
low-level detection is set and IRQn (n = 0 to 7) input
is high
•
When IRQn interrupt exception handling is executed
while detection of falling edge, rising edge, or both
edges is set
•
When the DTC is activated by an IRQn interrupt, and
the DISEL bit in MRB of the DTC with the transfer
counter other than 0 is cleared to 0
Only 0 can be written to this bit to clear the flag.
Rev. 6.00 Sep. 24, 2009 Page 93 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
5.4
Interrupt Sources
5.4.1
External Interrupts
There are 9 external interrupts: NMI and IRQ7 to IRQ0. These interrupts can be used to restore
this LSI from software standby mode.
NMI Interrupt: NMI is the highest-priority interrupt, and is always accepted by the CPU
regardless of the interrupt control mode or the status of the CPU interrupt mask bits. The NMIEG
bit in SYSCR can be used to select whether an interrupt is requested at a rising edge or a falling
edge on the NMI pin.
IRQ7 to IRQ0 Interrupts: IRQ7 to IRQ0 interrupts are requested by an input signal at the IRQ7
to IRQ0 pins. IRQ7 to IRQ0 interrupts have the following features:
• Using ISCR, it is possible to select whether an interrupt is generated by a low level, falling
edge, rising edge, or both edges, at the IRQ7 to IRQ0 pins.
• Enabling or disabling of IRQ7 to IRQ0 interrupt requests can be selected with IER.
• The interrupt priority level can be set with IPR.
• The status of IRQ7 to IRQ0 interrupt requests is indicated in ISR. ISR flags can be cleared to 0
by software.
A block diagram of IRQ7 to IRQ0 interrupts is shown in figure 5.2.
IRQnE
IRQnSCA, IRQnSCB
IRQnF
Edge/level
detection circuit
S
Q
IRQn interrupt
request
R
IRQn input
Clear signal
Note: n = 7 to 0
Figure 5.2 Block Diagram of IRQ7 to IRQ0 Interrupts
The set timing for IRQ7F to IRQ0F is shown in figure 5.3.
Rev. 6.00 Sep. 24, 2009 Page 94 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
φ
IRQn
input pin
IRQnF
Note: n = 7 to 0
Figure 5.3 Set Timing for IRQ7F to IRQ0F
The detection of IRQ7 to IRQ0 interrupts does not depend on whether the relevant pin has been
set for input or output. However, when a pin is used as an external interrupt input pin, do not clear
the corresponding DDR to 0 to use the pin as an I/O pin for another function. The IRQ7F to
IRQ0F interrupt request flags can be set to 1 when the setting condition is satisfied, regardless of
IER settings. Accordingly, refer to only necessary flags.
5.4.2
Internal Interrupts
For each on-chip peripheral module, there are flags that indicate the interrupt request status, and
enable bits that select enabling or disabling of these interrupts. If both of these are set to 1 for a
particular interrupt source, an interrupt request is sent to the interrupt controller.
5.4.3
Interrupt Exception Handling Vector Table
Table 5.2 shows interrupt exception handling sources, vector addresses, and interrupt priorities.
For default priorities, the lower the vector number, the higher the priority.
Priorities among modules can be set by means of the IPR. Modules set at the same priority will
conform to their default priorities. Priorities within a module are fixed.
Rev. 6.00 Sep. 24, 2009 Page 95 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Table 5.2
Interrupt Sources, Vector Addresses, and Interrupt Priorities
Vector Address*
Origin of
Interrupt
Source
Interrupt Source
Vector
Number
Advanced Mode IPR
Priority
External pin
NMI
7
H'001C
High
IRQ0
16
H'0040
IPRA6 to IPRA4
IRQ1
17
H'0044
IPRA2 to IPRA0
IRQ2
18
H'0048
IPRB6 to IPRB4
IRQ3
19
H'004C
IRQ4
20
H'0050
IRQ5
21
H'0054
IRQ6
22
H'0058
IRQ7
23
H'005C
DTC
SWDTEND
(completion of software
initiation data transfer)
24
H'0060
IPRC2 to IPRC0
Watchdog
timer 0
WOVI0
(interval timer 0)
25
H'0064
IPRD6 to IPRD4
PC break
PC break
27
H'006C
IPRE6 to IPRE4
A/D
ADI (completion of A/D
conversion)
28
H'0070
IPRE2 to IPRE0
Watchdog
timer 1
WOVI1
(interval timer 1)
29
H'0074
⎯
Reserved
30
31
H'0078
H'007C
TPU channel
0
TGI0A (TGR0A input
capture/compare-match)
32
H'0080
TGI0B (TGR0B input
capture/compare-match)
33
H'0084
TGI0C (TGR0C input
capture/compare-match)
34
H'0088
Rev. 6.00 Sep. 24, 2009 Page 96 of 928
REJ09B0099-0600
IPRB2 to IPRB0
IPRC6 to IPRC4
IPRF6 to IPRF4
Low
Section 5 Interrupt Controller
Vector Address*
Origin of
Interrupt
Source
Interrupt Source
TPU channel
0
Vector
Number
Advanced Mode IPR
Priority
TGI0D (TGR0D input
capture/compare- match)
35
H'008C
High
TCI0V (overflow 0)
36
H'0090
⎯
Reserved
37
38
39
H'0094
H'0098
H'009C
TPU channel
1
TGI1A (TGR1A input
capture/compare-match)
40
H'00A0
TGI1B (TGR1B input
capture/compare-match)
41
H'00A4
TCI1V (overflow 1)
42
H'00A8
TCI1U (underflow 1)
43
H'00AC
TGI2A (TGR2A input
capture/compare-match)
44
H'00B0
TGI2B (TGR2B input
capture/compare-match)
45
H'00B4
TCI2V (overflow 2)
46
H'00B8
TCI2U (underflow 2)
47
H'00BC
TGI3A (TGR3A input
capture/compare-match)
48
H'00C0
TGI3B (TGR3B input
capture/compare-match)
49
H'00C4
TGI3C (TGR3C input
capture/compare-match)
50
H'00C8
TGI3D (TGR3D input
capture/compare-match)
51
H'00CC
TCI3V (overflow 3)
52
H'00D0
Reserved
53
54
55
H'00D4
H'00D8
H'00DC
TPU channel
2
TPU channel
3
⎯
IPRF6 to IPRF4
IPRF2 to IPRF0
IPRG6 to IPRG4
IPRG2 to IPRG0
Low
Rev. 6.00 Sep. 24, 2009 Page 97 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Vector Address*
Origin of
Interrupt
Source
Interrupt Source
TPU channel
4
Vector
Number
Advanced Mode IPR
TGI4A (TGR4A input
capture/compare-match)
56
H'00E0
TGI4B (TGR4B input
capture/compare-match)
57
H'00E4
TCI4V (overflow 4)
58
H'00E8
TCI4U (underflow 4)
59
H'00EC
TGI5A (TGR5A input
capture/compare-match)
60
H'00F0
TGI5B (TGR5B input
capture/compare-match)
61
H'00F4
TCI5V (overflow 5)
62
H'00F8
TCI5U (underflow 5)
63
H'00FC
CMIA0 (compare-match A0) 64
H'0100
CMIB0 (compare-match B0) 65
H'0104
OVI0 (overflow 0)
66
H'0108
⎯
Reserved
67
H'010C
8-bit timer
channel 1
CMIA1 (compare-match A1) 68
H'0110
CMIB1 (compare-match B1) 69
H'0114
OVI1 (overflow 1)
70
H'0118
Reserved
71
H'011C
80
H'0140
RXI0 (receive completion 0) 81
H'0144
TXI0 (transmit data empty 0) 82
H'0148
TEI0 (transmit end 0)
83
H'014C
SCI channel 1 ERI1 (receive error 1)
84
H'0150
RXI1 (receive completion 1) 85
H'0154
TXI1 (transmit data empty 1) 86
H'0158
TEI1 (transmit end 1)
87
H'015C
SCI channel 2 ERI2 (receive error 2)
88
H'0160
RXI2 (receive completion 2) 89
H'0164
TPU channel
5
8-bit timer
channel 0
⎯
SCI channel 0 ERI0 (receive error 0)
Rev. 6.00 Sep. 24, 2009 Page 98 of 928
REJ09B0099-0600
IPRH6 to IPRH4
Priority
High
IPRH2 to IPRH0
IPRI6 to IPRI4
IPRI2 to IPRI0
IPRJ2 to IPRJ0
IPRK6 to IPRK4
IPRK2 to IPRK0
Low
Section 5 Interrupt Controller
Origin of
Interrupt
Source
Vector Address*
Interrupt Source
Vector
Number
SCI channel 2 TXI2 (transmit data empty 2) 90
TEI2 (transmit end 2)
8-bit timer
channel 2
Advanced Mode IPR
Priority
H'0168
High
91
H'016C
CMIA2 (compare-match A2) 92
H'0170
CMIB2 (compare-match B2) 93
H'0174
OVI2 (overflow 2)
94
H'0178
⎯
Reserved
95
H'017C
8-bit timer
channel 3
CMIA3 (compare-match A3) 96
H'0180
CMIB3 (compare-match B3) 97
H'0184
OVI3 (overflow 3)
98
H'0188
⎯
Reserved
99
H'018C
IEB
(H8S/2552
Group only)
IERSI (reception status)
104
H'01A0
IERxI (RxRDY)
105
H'01A4
IETxI (TxRDY)
106
H'01A8
IETSI (transmission status)
107
H'01AC
ERS0, OVR0, RM1, SLE0
108
H'01B0
RM0
109
H'01B4
IIC2 channel 0 IICI0 (1-byte transmission/
reception completion)
110
H'01B8
IIC2 channel 1 IICI1 (1-byte transmission/
reception completion)
111
H'01BC
SCI channel 3 ERI3 (receive error 3)
120
H'01E0
RXI3 (receive completion 3) 121
H'01E4
TXI3 (transmit data empty 3) 122
H'01E8
HCAN
(H8S/2556
Group only)
TEI3 (transmit end 3)
123
H'01EC
SCI channel 4 ERI4 (receive error 4)
124
H'01F0
RXI4 (receive completion 4) 125
H'01F4
TXI4 (transmit data empty 4) 126
H'01F8
TEI4 (transmit end 4)
H'01FC
Note:
*
127
IPRK2 to IPRK0
IPRL6 to IPRL4
IPRM6 to IPRM4
IPRM2 to IPRM0
IPRO6 to IPRO4
IPRO2 to IPRO0
Low
Indicates lower 16 bits of the start address.
Rev. 6.00 Sep. 24, 2009 Page 99 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
5.5
Operation
5.5.1
Interrupt Control Modes and Interrupt Operation
Interrupt operations in this LSI differ depending on the interrupt control mode.
NMI interrupts are accepted at all times except in the reset state and the hardware standby state. In
the case of IRQ interrupts and on-chip peripheral module interrupts, an enable bit is provided for
each interrupt. Clearing an enable bit to 0 disables the corresponding interrupt request. Interrupt
sources for which the enable bits are set to 1 are controlled by the interrupt controller.
Table 5.3 shows the interrupt control modes.
The interrupt controller performs interrupt control according to the interrupt control mode set by
the INTM1 and INTM0 bits in SYSCR, the priorities set in IPR, and the masking state indicated
by the I bit in the CPU’s CCR, and bits I2 to I0 in EXR.
Table 5.3
Interrupt Control Modes
SYSCR
Interrupt
Priority Setting Interrupt
Control Mode INTM1 INTM0 Register
Mask Bits
0
0
⎯
2
⎯
1
Description
0
⎯
I
Interrupt mask control is
performed by the I bit.
1
⎯
⎯
Setting prohibited
0
IPR
I2 to I0
8-level interrupt mask control is
performed by bits I2 to I0.
8 priority levels can be set with
IPR.
1
⎯
⎯
Setting prohibited
Figures 5.4 shows a block diagram of the priority decision circuit.
Rev. 6.00 Sep. 24, 2009 Page 100 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Interrupt
control
mode 0
I
Interrupt
acceptance
control
Default priority
determination
Interrupt source
Vector number
8-level
mask control
IPR
I2 to I0
Interrupt control mode 2
Figure 5.4 Block Diagram of Interrupt Control Operation
Rev. 6.00 Sep. 24, 2009 Page 101 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Interrupt Acceptance Control: In interrupt control mode 0, interrupt acceptance is controlled by
the I bit in CCR.
Table 5.4 shows the interrupts selected in each interrupt control mode.
Table 5.4
Interrupts Selected in Each Interrupt Control Mode (1)
Interrupt Mask Bits
Interrupt Control Mode
I
Selected Interrupts
0
0
All interrupts
1
NMI interrupt
X
All interrupts
2
Legend:
X:
Don't care
8-Level Control: In interrupt control mode 2, 8-level mask level determination is performed for
the selected interrupts in interrupt acceptance control according to the interrupt priority level
(IPR).
The interrupt source selected is the interrupt with the highest priority level, and whose priority
level set in IPR is higher than the mask level.
Table 5.5
Interrupts Selected in Each Interrupt Control Mode (2)
Interrupt Control Mode
Selected Interrupts
0
All interrupts
2
Highest priority-level (IPR) interrupt whose priority level is greater
than the mask level (IPR > I2 to I0)
Default Priority Determination: When an interrupt is selected by 8-level control, its priority is
determined and a vector number is generated.
If the same value is set for IPR, acceptance of multiple interrupts is enabled, and so only the
interrupt source with the highest priority according to the preset default priorities is selected and
has a vector number generated. Interrupt sources with a lower priority than the accepted interrupt
source are held pending.
Table 5.6 shows operations and control signal functions in each interrupt control mode.
Rev. 6.00 Sep. 24, 2009 Page 102 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Table 5.6
Operations and Control Signal Functions in Each Interrupt Control Mode
Setting
Interrupt
Control INTM INTM
Mode
1
0
0
2
0
1
0
0
Interrupt
Acceptance
Control
8-Level Control
I2 to
I0
IPR
Default Priority
Determination T (Trace)
X
⎯
⎯*2
O
⎯
O
IM
PR
O
T
I
O
IM
X
⎯*
1
Legend:
Interrupt operation control performed
O:
X:
No operation. (All interrupts enabled)
IM:
Used as interrupt mask bit
PR:
Sets priority
⎯:
Not used
Notes: 1. Set to 1 when an interrupt is accepted.
2. Keep the initial setting.
5.5.2
Interrupt Control Mode 0
Enabling and disabling of IRQ interrupts and on-chip peripheral module interrupts can be set by
means of the I bit in the CPU’s CCR. Interrupts are enabled when the I bit is cleared to 0, and
disabled when set to 1.
Figure 5.5 shows a flowchart of the interrupt acceptance operation in this case.
1. If an interrupt source occurs when the corresponding interrupt enable bit is set to 1, an
interrupt request is sent to the interrupt controller.
2. The I bit is referred to. If the I bit is cleared to 0, an interrupt request is accepted. If the I bit is
set to 1, only an NMI interrupt is accepted, and other interrupt requests are held pending.
3. Interrupt requests are sent to the interrupt controller, the highest-ranked interrupt according to
the priority system is accepted, and other interrupt requests are held pending.
4. When the CPU accepts an interrupt request, it starts interrupt exception handling after
execution of the current instruction has been completed.
5. The PC and CCR are saved to the stack area by interrupt exception handling. The PC saved on
the stack shows the address of the first instruction to be executed after returning from the
interrupt handling routine.
6. Next, the I bit in CCR is set to 1. This masks all interrupts except NMI.
Rev. 6.00 Sep. 24, 2009 Page 103 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
7. The CPU generates a vector address for the accepted interrupt and starts execution of the
interrupt handling routine at the address indicated by the contents of the vector address.
Program execution status
Interrupt generated
No
Yes
Yes
NMI
No
No
Hold
pending
I=0
Yes
No
IRQ0
No
Yes
IRQ1
Yes
TEI4
Yes
Save PC and CCR
→
I
1
Read vector address
Branch to interrupt handling routine
Figure 5.5 Flowchart of Procedure up to Interrupt Acceptance
in Interrupt Control Mode 0
Rev. 6.00 Sep. 24, 2009 Page 104 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
5.5.3
Interrupt Control Mode 2
Eight-level masking is implemented for IRQ interrupts and on-chip peripheral module interrupts
by comparing the interrupt mask level set by bits I2 to I0 of EXR in the CPU with IPR.
Figure 5.6 shows a flowchart of the interrupt acceptance operation in this case.
1. If an interrupt source occurs when the corresponding interrupt enable bit is set to 1, an interrupt
request is sent to the interrupt controller.
2. When interrupt requests are sent to the interrupt controller, the interrupt with the highest
priority according to the interrupt priority levels set in IPR is selected, and lower-priority
interrupt requests are held pending. If a number of interrupt requests with the same priority are
generated at the same time, the interrupt request with the highest priority according to the
priority system shown in table 5.2 is selected.
3. Next, the priority of the selected interrupt request is compared with the interrupt mask level set
in EXR. An interrupt request with a priority no higher than the mask level set at that time is
held pending, and only an interrupt request with a priority higher than the interrupt mask level
is accepted.
4. When the CPU accepts an interrupt request, it starts interrupt exception handling after
execution of the current instruction has been completed.
5. The PC, CCR, and EXR are saved to the stack area by interrupt exception handling. The PC
saved on the stack shows the address of the first instruction to be executed after returning from
the interrupt handling routine.
6. The T bit in EXR is cleared to 0. The interrupt mask level is rewritten with the priority level of
the accepted interrupt.
If the accepted interrupt is NMI, the interrupt mask level is set to H'7.
7. The CPU generates a vector address for the accepted interrupt and starts execution of the
interrupt handling routine at the address indicated by the contents of the vector address.
Rev. 6.00 Sep. 24, 2009 Page 105 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Program execution status
Interrupt generated?
No
Yes
Yes
NMI
No
Level 7 interrupt?
No
Yes
Mask level 6
or below?
Level 6 interrupt?
No
No
Yes
Level 1 interrupt?
Yes
Mask level 5
or below?
No
No
Yes
Yes
Mask level 0?
No
Yes
Save PC, CCR, and EXR
Hold
pending
Clear T bit to 0
Update mask level
Read vector address
Branch to interrupt handling routine
Figure 5.6 Flowchart of Procedure up to Interrupt Acceptance
in Interrupt Control Mode 2
Rev. 6.00 Sep. 24, 2009 Page 106 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
5.5.4
Interrupt Exception Handling Sequence
Figure 5.7 shows the interrupt exception handling sequence. The example shown is for the case
where interrupt control mode 0 is set in advanced mode, and the program area and stack area are
in on-chip memory.
Rev. 6.00 Sep. 24, 2009 Page 107 of 928
REJ09B0099-0600
REJ09B0099-0600
Rev. 6.00 Sep. 24, 2009 Page 108 of 928
Figure 5.7 Interrupt Exception Handling
(1)
(2)
(4)
(3)
Internal
operation
Instruction prefetch address (Not executed.
This is the contents of the saved PC, the return address.)
(2) (4) Instruction code (Not executed.)
(3)
Instruction prefetch address (Not executed.)
(5)
SP-2
(7)
SP-4
(1)
Internal
data bus
Internal
write signal
Internal
read signal
Internal
address bus
Interrupt
request signal
φ
Interrupt
acceptance
Wait for end of interrupt
Instruction
level determination
prefetch
instruction
(7)
(8)
(10)
(9)
Vector fetch
(12)
(11)
(14)
(13)
Interrupt handling
routine instruction
prefetch
Saved PC and saved CCR
Vector address
Interrupt handling routine start address (Vector address contents)
Interrupt handling routine start address ((13) = (10)(12))
First instruction of interrupt handling routine
(6)
(6) (8)
(9) (11)
(10) (12)
(13)
(14)
(5)
Stack
Internal
operation
Section 5 Interrupt Controller
Section 5 Interrupt Controller
5.5.5
Interrupt Response Times
This LSI is capable of fast word transfer to on-chip memory, has the program area in on-chip
ROM and the stack area in on-chip RAM, enabling high-speed processing.
Table 5.7 shows interrupt response times — the interval between generation of an interrupt request
and execution of the first instruction in the interrupt handling routine. The execution status
symbols used in table 5.7 are explained in table 5.8.
Table 5.7
Interrupt Response Times (States)
Normal Mode*5
No.
Execution Status
1
Interrupt priority determination*
2
Number of wait states until
executing instruction ends*2
1
Advanced Mode
INTM1 = 0
INTM1 = 1
INTM1 = 0
INTM1 = 1
3
3
3
3
1 to 19 +
2·SI
1 to 19 +
2·SI
1 to 19 +
2·SI
1 to 19 +
2·SI
3
PC, CCR, EXR stack save
2·SK
3·SK
2·SK
3·SK
4
Vector fetch
SI
SI
2·SI
2·SI
2·SI
2·SI
2·SI
2·SI
2
2
2
2
11 to 31
12 to 32
12 to 32
13 to 33
5
6
Instruction fetch*
3
4
Internal processing*
Total (using on-chip memory)
Notes: 1.
2.
3.
4.
5.
Two states in case of internal interrupt.
Refers to MULXS and DIVXS instructions.
Prefetch after interrupt acceptance and interrupt handling routine prefetch.
Internal processing after interrupt acceptance and internal processing after vector fetch.
Not available in this LSI.
Rev. 6.00 Sep. 24, 2009 Page 109 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Table 5.8
Number of States in Interrupt Handling Routine Execution Status
Object of Access
External Device*
8-Bit Bus
Symbol
Instruction fetch
SI
Branch address read
SJ
Stack manipulation
SK
16-Bit Bus
On-Chip
Memory
2-State
Access
3-State
Access
2-State
Access
3-State
Access
1
4
6 + 2m
2
3+m
Legend:
m:
Number of wait states in an external device access.
Note: * Not available in this LSI.
5.5.6
DTC Activation by Interrupt
The DTC can be activated by an interrupt. In this case, the following selections can be made.
1.
2.
3.
Interrupt request to CPU
Activation request to DTC
Multiple selection of 1 and 2 above.
For details on interrupt request, which enables DTC activation, see section 8, Data Transfer
Controller (DTC). Figure 5.8 shows a block diagram of DTC and interrupt controller.
Rev. 6.00 Sep. 24, 2009 Page 110 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Interrupt request
IRQ
interrupt
DTC activation
request vector
number
Selection
circuit
Selection
signal
Clear signal
On-chip
peripheral
module
Interrupt source
clear signal
Control
logic
DTC
DTCER
Clear signal
DTVECR
SWDTE
clear signal
Priority
determination
CPU interrupt
request vector
number
Interrupt controller
CPU
I, I2 to I0
Figure 5.8 DTC and Interrupt Controller
Interrupt controller of DTC control has the following three main functions.
Interrupt Source Selection: For interruption source, select DTC activation request or CPU
interruption request by the DTCE bits in DTCERA to DTCERG, and DTCERI of the DTC. After
DTC data transfer, the DTCE bit is cleared to 0, and an interrupt request to the CPU can be made
by the setting of the DISEL bit in MRB of the DTC. When DTC performs data transfer for
prescribed number of times and transfer counter becomes 0, the DTCE bit should be cleared to 0
and an interrupt request to the CPU is made after DTC data transfer.
Priority Determination: DTC activation source is selected according to priority of default
setting. Mask level and priority level do not affect the selection. For details, see section 8.4,
Location of Register Information and DTC Vector Table.
Rev. 6.00 Sep. 24, 2009 Page 111 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
Operation Order: When the same interrupts are selected as DTC activation source and CPU
interruption source, DTC data is transferred, and then CPU interrupt exception processing is made.
Table 5.9 shows interrupt source selection and interrupt source clear control by the setting of the
DTCE bit in DTCERA to DTCERG, and DTCERI of the DTC and the setting of the DISEL bit in
MRB of the DTC.
Table 5.9
Interrupt Source Selection and Clear Control
Settings
Interrupt Source Selection and Clear
Control
DTC
DTCE
DESEL
DTC
CPU
0
∗
X
#
1
0
#
X
1
O
#
Legend:
#:
Corresponding interrupt is used. Interrupt source is cleared.
(The CPU should clear the source flag in the interrupt processing routine.)
Corresponding interrupt is used. Interrupt source is not cleared.
O:
X:
Corresponding interrupt cannot be used.
*:
Don’t care
Usage Note: Interrupt sources of the SCI and A/D converter are cleared when the DTC reads or
writes prescribed register, and they do not depend on the DTCE or DISEL bit.
5.6
Usage Notes
5.6.1
Contention between Interrupt Generation and Disabling
When an interrupt enable bit is cleared to 0 to disable interrupt requests, the disabling becomes
effective after execution of the instruction.
When an interrupt enable bit is cleared to 0 by an instruction such as BCLR or MOV, and if an
interrupt is generated during execution of the instruction, the interrupt concerned will still be
enabled on completion of the instruction, and so interrupt exception handling for that interrupt will
be executed on completion of the instruction. However, if there is an interrupt request of higher
priority than that interrupt, interrupt exception handling will be executed for the higher-priority
interrupt, and the lower-priority interrupt will be ignored.
Rev. 6.00 Sep. 24, 2009 Page 112 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
The same also applies when an interrupt source flag is cleared to 0.
The above contention will not occur, if an enable bit or interrupt source flag is cleared to 0 while
the interrupt is masked.
Figure 5.9 shows an example in which the CMIEA bit in the TCR register of the 8-bit timer is
cleared to 0.
TCR write cycle by CPU
CMIA exception handling
φ
Internal
address bus
TCR address
Internal
write signal
CMIEA
CMFA
CMIA
interrupt signal
Figure 5.9 Contention between Interrupt Generation and Disabling
5.6.2
Instructions That Disable Interrupts
The instructions that disable interrupt requests directly after execution are LDC, ANDC, ORC,
and XORC. After any of these instructions are executed, all interrupts including NMI are disabled
and the next instruction is always executed.
When the I bit is set by one of these instructions, the new value becomes valid two states after
execution of the instruction ends.
5.6.3
When Interrupts Are Disabled
There are times when interrupt acceptance is disabled by the interrupt controller.
Rev. 6.00 Sep. 24, 2009 Page 113 of 928
REJ09B0099-0600
Section 5 Interrupt Controller
The interrupt controller disables interrupt acceptance for a 3-state period after the CPU has
updated the mask level with an LDC, ANDC, ORC, or XORC instruction.
5.6.4
Interrupts during Execution of EEPMOV Instruction
Interrupt operation differs between the EEPMOV.B instruction and the EEPMOV.W instruction.
With the EEPMOV.B instruction, an interrupt request (including NMI) issued during the transfer
is not accepted until the transfer is completed.
With the EEPMOV.W instruction, if an interrupt request is issued during the transfer, interrupt
exception handling starts at a break in the transfer cycle. The PC value saved on the stack in this
case is the address of the next instruction.
Therefore, if an interrupt is generated during execution of an EEPMOV.W instruction, the
following coding should be used.
L1: EEPMOV.W
5.6.5
MOV.W
R4,R4
BNE
L1
IRQ Interrupt
When operating by clock input, acceptance of input to an IRQ is synchronized with the clock. In
software standby mode and watch mode, the input is accepted asynchronously. For details on the
input conditions, see section 24.4.3, Control Signal Timing.
5.6.6
NMI Interrupt Usage Notes
The NMI interrupt is part of the exception processing performed cooperatively by the LSI’s
internal interrupt controller and the CPU when the system is operating normally under the
specified electrical conditions. No operations, including NMI interrupts, are guaranteed when
operation is not normal (runaway status) due to software problems or abnormal input to the LSI’s
pins. In such cases, the LSI may be restored to the normal program execution state by applying an
external reset.
Rev. 6.00 Sep. 24, 2009 Page 114 of 928
REJ09B0099-0600
Section 6 PC Break Controller (PBC)
Section 6 PC Break Controller (PBC)
The PC break controller (PBC) provides functions that simplify program debugging. Using these
functions, it is easy to create a self-monitoring debugger, enabling programs to be debugged with
the chip alone, without using an in-circuit emulator. A block diagram of the PC break controller is
shown in figure 6.1.
6.1
Features
• Two break channels (A and B)
• 24-bit break address
⎯ Bit masking possible
• Four types of break compare conditions
⎯ Instruction fetch
⎯ Data read
⎯ Data write
⎯ Data read/write
• Bus master
⎯ Either CPU or CPU/DTC can be selected
• The timing of PC break exception handling after the occurrence of a break condition is as
follows:
⎯ Immediately before execution of the instruction fetched at the set address (instruction
fetch)
⎯ Immediately after execution of the instruction that accesses data at the set address (data
access)
• Module stop mode can be set
Rev. 6.00 Sep. 24, 2009 Page 115 of 928
REJ09B0099-0600
Section 6 PC Break Controller (PBC)
BCRA
Mask control
Output control
BARA
Control
logic
Comparator
Match signal
Internal address
PC break
interrupt
Access
status
Comparator
Match signal
Mask control
BARB
Output control
Control
logic
BCRB
Figure 6.1 Block Diagram of PC Break Controller
6.2
Register Descriptions
The PC break controller has the following registers.
•
•
•
•
Break address register A (BARA)
Break address register B (BARB)
Break control register A (BCRA)
Break control register B (BCRB)
6.2.1
Break Address Register A (BARA)
BARA is a 32-bit readable/writable register that specifies the channel A break address.
Bit
Bit Name
Initial
Value
31 to 24
⎯
Undefined ⎯
R/W
Description
Reserved
These bits are read as an undefined value and
cannot be modified.
23 to 0
BAA23 to BAA0 H'000000
Rev. 6.00 Sep. 24, 2009 Page 116 of 928
REJ09B0099-0600
R/W
These bits set the PC break address of channel
A.
Section 6 PC Break Controller (PBC)
6.2.2
Break Address Register B (BARB)
BARB is the channel B break address register. The bit configuration is the same as for BARA.
6.2.3
Break Control Register A (BCRA)
BCRA controls channel A PC breaks.
Bit
7
Bit Name
CMFA
Initial
Value
0
R/W
Description
1
R/(W)* Condition Match Flag A
[Setting condition]
When a condition set for channel A is satisfied
[Clearing condition]
When 0 is written to CMFA after reading*2 CMFA = 1
6
CDA
0
R/W
CPU Cycle/DTC Cycle Select A
Selects the channel A break condition bus master.
0: CPU
1: CPU or DTC
5
BAMRA2
0
R/W
Break Address Mask Register A2 to A0
4
BAMRA1
0
R/W
3
BAMRA0
0
R/W
These bits specify which bits of the break address set in
BARA are to be unmasked.
000: BAA23 to BAA0 (All bits are unmasked)
001: BAA23 to BAA1 (Lowest bit is masked)
010: BAA23 to BAA2 (Lower 2 bits are masked)
011: BAA23 to BAA3 (Lower 3 bits are masked)
100: BAA23 to BAA4 (Lower 4 bits are masked)
101: BAA23 to BAA8 (Lower 8 bits are masked)
110: BAA23 to BAA12 (Lower 12 bits are masked)
111: BAA23 to BAA16 (Lower 16 bits are masked)
2
CSELA1
0
R/W
Break Condition Select
1
CSELA0
0
R/W
These bits select the break condition of channel A.
00: Instruction fetch is used as the break condition.
01: Data read cycle is used as the break condition.
10: Data write cycle is used as the break condition.
11: Data read/write cycle is used as the break condition.
Rev. 6.00 Sep. 24, 2009 Page 117 of 928
REJ09B0099-0600
Section 6 PC Break Controller (PBC)
Bit
Bit Name
Initial
Value
R/W
Description
0
BIEA
0
R/W
Break Interrupt Enable
When this bit is set to 1, the PC break interrupt request of
channel A is enabled.
Notes: 1. Only 0 can be written to this bit to clear the flag.
2. Read the state wherein CMFA = 1 twice or more, when the CMFA is polled after
inhibiting the PC break interruption.
6.2.4
Break Control Register B (BCRB)
BCRB is the channel B break control register. The bit configuration is the same as for BCRA.
6.3
Operation
The operation flow from break condition setting to PC break interrupt exception handling is
shown in section 6.3.1, PC Break Interrupt Due to Instruction Fetch, and section 6.3.2, PC Break
Interrupt Due to Data Access, taking the example of channel A.
6.3.1
PC Break Interrupt Due to Instruction Fetch
1. Set the break address in BARA.
For a PC break caused by an instruction fetch, set the address of the first instruction byte as the
break address.
2. Set the break conditions in BCR.
Set bit 6 (CDA) to 0 to select the CPU because the bus master must be the CPU for a PC break
caused by an instruction fetch. Set the address bits to be masked to bits 5 to 3 (BAMRA2 to
BAMRA0). Set bits 2 and 1 (CSELA1 and CSELA0) to 00 to specify an instruction fetch as
the break condition. Set bit 0 (BIEA) to 1 to enable break interrupts.
3. When the instruction at the set address is fetched, a PC break request is generated immediately
before execution of the fetched instruction, and the condition match flag (CMFA) is set.
4. After priority determination by the interrupt controller, PC break interrupt exception handling
is started.
Rev. 6.00 Sep. 24, 2009 Page 118 of 928
REJ09B0099-0600
Section 6 PC Break Controller (PBC)
6.3.2
PC Break Interrupt Due to Data Access
1. Set the break address in BARA.
For a PC break caused by a data access, set the target ROM, RAM, I/O, or external address
space address as the break address. Stack operations and branch address reads are included in
data accesses.
2. Set the break conditions in BCRA.
Select the bus master with bit 6 (CDA). Set the address bits to be masked to bits 5 to 3
(BAMRA2 to BAMRA0). Set bits 2 and 1 (CSELA1 and CSELA0) to 01, 10, or 11 to specify
data access as the break condition. Set bit 0 (BIEA) to 1 to enable break interrupts.
3. After execution of the instruction that performs a data access on the set address, a PC break
request is generated and the condition match flag (CMFA) is set.
4. After priority determination by the interrupt controller, PC break interrupt exception handling
is started.
6.3.3
Notes on PC Break Interrupt Handling
• When a PC break interrupt is generated at the transfer address of an EEPMOV.B instruction
PC break exception handling is executed after all data transfers have been completed and the
EEPMOV.B instruction has ended.
• When a PC break interrupt is generated at a DTC transfer address
PC break exception handling is executed after the DTC has completed the specified number of
data transfers, or after data for which the DISEL bit is set to 1 has been transferred.
6.3.4
Operation in Transitions to Power-Down Modes
The operation when a PC break interrupt is set for an instruction fetch at the address after a
SLEEP instruction is shown below.
• When the SLEEP instruction causes a transition from high-speed (medium-speed) mode to
sleep mode
After execution of the SLEEP instruction, a transition is not made to sleep mode, and PC break
exception handling is executed. After execution of PC break exception handling, the
instruction at the address after the SLEEP instruction is executed (figure 6.2 (A)).
Rev. 6.00 Sep. 24, 2009 Page 119 of 928
REJ09B0099-0600
Section 6 PC Break Controller (PBC)
• When the SLEEP instruction causes a transition to software standby mode or watch mode
After execution of the SLEEP instruction, a transition is made to the respective mode, and PC
break exception handling is not executed. However, the CMFA or CMFB flag is set (figure 6.2
(B)).
SLEEP instruction
execution
SLEEP instruction
execution
PC break exception
handling execution
Transition to
respective mode
(B)
Execution of instruction
after SLEEP instruction
(A)
Figure 6.2 Operation in Power-Down Mode Transitions
6.3.5
When Instruction Execution Is Delayed by One State
While the break interrupt enable bit is set to 1, instruction execution in the following cases is one
state later than usual.
• For 1-word branch instructions (Bcc d:8, BSR, JSR, JMP, TRAPA, RTE, and RTS) in on-chip
ROM or RAM
• When break interruption by instruction fetch is set, the set address indicates on-chip ROM or
RAM space, and that address is used for data access
• When break interruption by instruction fetch is set, if the instruction to be executed
immediately before the set instruction has one of the addressing modes shown below, and that
address indicates on-chip ROM or RAM
Addressing modes: @ERn, @(d:16,ERn), @(d:32,ERn), @-ERn/ERn+, @aa:8, @aa:24,
@aa:32, @(d:8,PC), @(d:16,PC), @@aa:8
• When break interruption by instruction fetch is set, if the instruction to be executed
immediately before the set instruction is NOP or SLEEP, or has #xx, Rn as its addressing
mode, and that instruction is located in on-chip ROM or RAM
Rev. 6.00 Sep. 24, 2009 Page 120 of 928
REJ09B0099-0600
Section 6 PC Break Controller (PBC)
6.4
Usage Notes
6.4.1
Module Stop Mode Setting
PBC operation can be disabled or enabled using the module stop control register. The initial
setting is for PBC operation to be halted. Register access is enabled by clearing module stop
mode. For details, see section 22, Power-Down Modes.
6.4.2
PC Break Interrupts
The PC break interrupt is shared by channels A and B. The channel from which the request was
issued must be determined by the interrupt handler.
6.4.3
CMFA and CMFB
The CMFA and CMFB flags are not automatically cleared to 0, so 0 must be written to CMFA or
CMFB after first reading the flag while it is set to 1. If the flag is left set to 1, another interrupt
will be requested after interrupt handling ends.
6.4.4
PC Break Interrupt when DTC Is Bus Master
A PC break interrupt generated when the DTC is the bus master is accepted after the bus
mastership has been transferred to the CPU by the bus controller.
6.4.5
PC Break Set for Instruction Fetch at Address Following BSR, JSR, JMP, TRAPA,
RTE, or RTS Instruction
Even if the instruction at the address following a BSR, JSR, JMP, TRAPA, RTE, or RTS
instruction is fetched, it is not executed, and so a PC break interrupt is not generated by the
instruction fetch at the next address.
6.4.6
I Bit Set by LDC, ANDC, ORC, or XORC Instruction
When the I bit is set by an LDC, ANDC, ORC, or XORC instruction, a PC break interrupt
becomes valid two states after the end of the executing instruction. If a PC break interrupt is set
for the instruction following one of these instructions, since interrupts, including NMI, are
disabled for a 3-state period in the case of LDC, ANDC, ORC, and XOR, the next instruction is
always executed. For details, see section 5, Interrupt Controller.
Rev. 6.00 Sep. 24, 2009 Page 121 of 928
REJ09B0099-0600
Section 6 PC Break Controller (PBC)
6.4.7
PC Break Set for Instruction Fetch at Address Following Bcc Instruction
A PC break interrupt is generated if the instruction at the next address is executed in accordance
with the branch condition, and is not generated if the instruction at the next address is not
executed.
6.4.8
PC Break Set for Instruction Fetch at Branch Destination Address of Bcc
Instruction
A PC break interrupt is generated if the instruction at the branch destination is executed in
accordance with the branch condition, and is not generated if the instruction at the branch
destination is not executed.
Rev. 6.00 Sep. 24, 2009 Page 122 of 928
REJ09B0099-0600
Section 7 Bus Controller
Section 7 Bus Controller
This LSI has a built-in bus controller (BSC) that manages the external address space divided into
eight areas. As the bus controller has a bus mastership arbitration function, it controls the
operation of the CPU (the internal bus master) and the data transfer controller (DTC).
7.1
Features
• Manages external address space in area units
⎯ Manages the external address space as 8 areas in 2-Mbyte units
⎯ Bus specifications can be set independently for each area
⎯ Burst ROM interface can be set
• Basic bus interface
⎯ H8S/2552 Group, H8S/2506 Group: Chip select signals (CS0 to CS7) can be output for
areas 0 to 7.
⎯ H8S/2556 Group: Chip select signals (CS0, CS3 to CS7) can be output for areas 0 and 3 to
7.
⎯ 8-bit access or 16-bit access can be selected for each area
⎯ 2-state access or 3-state access can be selected for each area
⎯ Program wait states can be inserted for each area
• Burst ROM interface
⎯ Burst ROM interface can be selected for area 0
⎯ One or two states can be selected for the burst cycle
• Idle cycle insertion
⎯ Idle cycle can be inserted between consecutive read accesses to different external areas
⎯ Idle cycle can be inserted before a write access to an external area immediately after a read
access to an external area
• Bus mastership arbitration
⎯ The on-chip bus arbiter arbitrates the bus mastership among CPU and DTC.
• Other features
⎯ External bus mastership release function
Rev. 6.00 Sep. 24, 2009 Page 123 of 928
REJ09B0099-0600
Section 7 Bus Controller
Figure 7.1 shows a block diagram of the bus controller.
Chip select signal
Internal
address bus
Area decoder
ABWCR
External bus control signal
ASTCR
BCRH
BCRL
Bus
controller
Wait
controller
WAIT
Internal data bus
BREQ
BACK
Internal control
signal
Bus mode signal
WCRH
WCRL
CPU bus mastership request signal
Bus arbiter
DTC bus mastership request signal
CPU bus acknowledge signal
DTC bus acknowledge signal
Legend:
ABWCR: Bus width control register
ASTCR: Access state control register
WCRH, WCRL: Wait control registers H, L
BCRH, BCRL: Bus control registers H, L
Figure 7.1 Block Diagram of Bus Controller
Rev. 6.00 Sep. 24, 2009 Page 124 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.2
Input/Output Pins
Table 7.1 summarizes the pins of the bus controller.
Table 7.1
Pin Configuration
Name
Symbol
I/O
Address strove
AS
Output Strobe signal indicating that address output on
address bus is enabled.
Read
RD
Output Strobe signal indicating that external address space is
being read.
High write
HWR
Output Strobe signal indicating that external address space is
to be written, and upper half (D15 to D8) of data bus is
enabled.
Low write
LWR
Output Strobe signal indicating that external address space is
to be written, and lower half (D7 to D0) of data bus is
enabled.
Chip select 0 to 7 CS0 to CS7*
Function
Output Strobe signal indicating that areas 0 to 7 are selected.
Wait
WAIT
Input
Wait request signal when accessing external 3-state
access space.
Bus mastership
request
BREQ
Input
Request signal that releases bus to external device.
Bus mastership
request
acknowledge
BACK
Output Acknowledge signal indicating that bus has been
released.
Note:
7.3
*
CS1 and CS2 are not provided in the H8S/2556 Group.
Register Descriptions
The bus controller has the following registers.
•
•
•
•
•
•
•
Bus width control register (ABWCR)
Access state control register (ASTCR)
Wait control register H (WCRH)
Wait control register L (WCRL)
Bus control register H (BCRH)
Bus control register L (BCRL)
Pin function control register (PFCR)
Rev. 6.00 Sep. 24, 2009 Page 125 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.3.1
Bus Width Control Register (ABWCR)
ABWCR designates each area as either an 8-bit access space or a 16-bit access space.
ABWCR sets the data bus width for the external memory space. The bus width for on-chip
memory and internal I/O registers is fixed regardless of the settings in ABWCR.
Bit
Bit Name
Initial
Value
R/W
Description
7
ABW7
1
R/W
Area 7 to 0 Bus Width Control
6
ABW6
1
R/W
5
ABW5
1
R/W
These bits select whether the corresponding area is to be
designated for 8-bit access or 16-bit access.
4
ABW4
1
R/W
0: Area n is designated for 16-bit access
3
ABW3
1
R/W
1: Area n is designated for 8-bit access
2
ABW2
1
R/W
Note: n = 7 to 0
1
ABW1
1
R/W
0
ABW0
1
R/W
7.3.2
Access State Control Register (ASTCR)
ASTCR designates each area as either a 2-state access space or a 3-state access space.
ASTCR sets the number of access states for the external memory space. The number of access
states for on-chip memory and internal I/O registers is fixed regardless of the settings in ASTCR.
Bit
Bit Name
Initial
Value
R/W
Description
7
AST7
1
R/W
Area 7 to 0 Access State Control
6
AST6
1
R/W
5
AST5
1
R/W
4
AST4
1
R/W
These bits select whether the corresponding area is to be
designated as a 2-state access space or a 3-state access
space. Wait state insertion is enabled or disabled at the
same time.
3
AST3
1
R/W
0: Area n is designated for 2-state access
2
AST2
1
R/W
1
AST1
1
R/W
0
AST0
1
R/W
Wait state insertion in area n external space is disabled
1: Area n is designated for 3-state access
Wait state insertion in area n external space is enabled
Note: n = 7 to 0
Rev. 6.00 Sep. 24, 2009 Page 126 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.3.3
Wait Control Registers H and L (WCRH, WCRL)
WCRH and WCRL select the number of program wait states for each area.
Program wait states are not inserted in the case of on-chip memory or internal I/O registers.
• WCRH
Bit
Bit Name
Initial
Value
R/W
Description
7
W71
1
R/W
Area 7 Wait Control 1 and 0
6
W70
1
R/W
These bits select the number of program wait states when
area 7 in external address space is accessed while the
AST7 bit in ASTCR is set to 1.
00: Program wait states are not inserted
01: 1 program wait state is inserted
10: 2 program wait states are inserted
11: 3 program wait states are inserted
5
W61
1
R/W
Area 6 Wait Control 1 and 0
4
W60
1
R/W
These bits select the number of program wait states when
area 6 in external address space is accessed while the
AST6 bit in ASTCR is set to 1.
00: Program wait states are not inserted
01: 1 program wait state is inserted
10: 2 program wait states are inserted
11: 3 program wait states are inserted
3
W51
1
R/W
Area 5 Wait Control 1 and 0
2
W50
1
R/W
These bits select the number of program wait states when
area 5 in external address space is accessed while the
AST5 bit in ASTCR is set to 1.
00: Program wait states are not inserted
01: 1 program wait state is inserted
10: 2 program wait states are inserted
11: 3 program wait states are inserted
Rev. 6.00 Sep. 24, 2009 Page 127 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bit
Bit Name
Initial
Value
R/W
Description
1
W41
1
R/W
Area 4 Wait Control 1 and 0
0
W40
1
R/W
These bits select the number of program wait states when
area 4 in external address space is accessed while the
AST4 bit in ASTCR is set to 1.
00: Program wait states are not inserted
01: 1 program wait state is inserted
10: 2 program wait states are inserted
11: 3 program wait states are inserted
• WCRL
Bit
Bit Name
Initial
Value
R/W
Description
7
W31
1
R/W
Area 3 Wait Control 1 and 0
6
W30
1
R/W
These bits select the number of program wait states when
area 3 in external address space is accessed while the
AST3 bit in ASTCR is set to 1.
00: Program wait states are not inserted
01: 1 program wait state is inserted
10: 2 program wait states are inserted
11: 3 program wait states are inserted
5
W21
1
R/W
Area 2 Wait Control 1 and 0
4
W20
1
R/W
These bits select the number of program wait states when
area 2 in external address space is accessed while the
AST2 bit in ASTCR is set to 1.
00: Program wait states are not inserted
01: 1 program wait state is inserted
10: 2 program wait states are inserted
11: 3 program wait states are inserted
Rev. 6.00 Sep. 24, 2009 Page 128 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bit
Bit Name
Initial
Value
R/W
Description
3
W11
1
R/W
Area 1 Wait Control 1 and 0
2
W10
1
R/W
These bits select the number of program wait states when
area 1 in external address space is accessed while the
AST1 bit in ASTCR is set to 1.
00: Program wait states are not inserted
01: 1 program wait state is inserted
10: 2 program wait states are inserted
11: 3 program wait states are inserted
1
W01
1
R/W
Area 0 Wait Control 1 and 0
0
W00
1
R/W
These bits select the number of program wait states when
area 0 in external address space is accessed while the
AST0 bit in ASTCR is set to 1.
00: Program wait states are not inserted
01: 1 program wait state is inserted
10: 2 program wait states are inserted
11: 3 program wait states are inserted
Rev. 6.00 Sep. 24, 2009 Page 129 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.3.4
Bus Control Register H (BCRH)
BCRH selects enabling or disabling of idle cycle insertion, and the memory interface for area 0.
Bit
Bit Name
Initial
Value
R/W
Description
7
ICIS1
1
R/W
Idle Cycle Insertion 1
Selects whether or not one idle cycle state is to be
inserted between bus cycles when consecutive external
read cycles are performed in different areas.
0: Idle cycle is not inserted in case of consecutive
external read cycles in different areas
1: Idle cycle is inserted in case of consecutive external
read cycles in different areas
6
ICIS0
1
R/W
Idle Cycle Insertion 0
Selects whether or not one idle cycle state is to be
inserted between bus cycles when consecutive external
read and write cycles are performed.
0: Idle cycle is not inserted in case of consecutive
external read and write cycles
1: Idle cycle is inserted in case of consecutive external
read and write cycles
5
BRSTRM
0
R/W
Burst ROM Enable
Selects whether area 0 is used as a burst ROM interface.
0: Area 0 is basic bus interface
1: Area 0 is burst ROM interface
4
BRSTS1
1
R/W
Burst Cycle Select 1
Selects the number of burst cycles for the burst ROM
interface.
0: Burst cycle comprises 1 state
1: Burst cycle comprises 2 states
3
BRSTS0
0
R/W
Burst Cycle Select 0
Selects the number of words that can be accessed in a
burst ROM interface burst access.
0: Max. 4 words in burst access
1: Max. 8 words in burst access
Rev. 6.00 Sep. 24, 2009 Page 130 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bit
Bit Name
2 to 0 ⎯
Initial
Value
R/W
Description
All 0
R/W
Reserved
The write value should always be 0.
7.3.5
Bus Control Register L (BCRL)
BCRL performs selection of the external bus-released state protocol, and enabling or disabling of
the WAIT pin input.
Bit
Bit Name
Initial
Value
R/W
Description
7
BRLE
0
R/W
Bus Release Enable
Enables or disables external bus release.
0: External bus release is disabled. BREQ and BACK can
be used as I/O ports.
1: External bus release is enabled.
6
⎯
0
R/W
Reserved
The write value should always be 0.
5
⎯
0
–
Reserved
This bit is always read as 0 and cannot be modified.
4
⎯
0
R/W
Reserved
The write value should always be 0.
3
⎯
1
R/W
Reserved
2, 1
⎯
All 0
R/W
Reserved
The write value should always be 1.
The write value should always be 0.
0
WAITE
0
R/W
WAIT Pin Enable
Selects enabling or disabling of wait input by the WAIT pin.
0: Wait input by the WAIT pin is disabled. The WAIT pin
can be used as I/O port.
1: Wait input by the WAIT pin is enabled.
Rev. 6.00 Sep. 24, 2009 Page 131 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.3.6
Pin Function Control Register (PFCR)
PFCR performs address output control in external extended mode.
Bit
Bit Name
Initial
Value
R/W
Description
7, 6
⎯
All 0
R/W
Reserved
The write value should always be 0.
5
BUZZE
0
R/W
BUZZ Output Enable
Enables/disables BUZZ output of the PF1 pin. Input clock of
WDT_1 selected by the PSS, CKS2 to CKS0 bits is output as
BUZZ signal.
0: Functions as PF1 input/output pins
1: Functions as BUZZ output pins
4
⎯
0
R/W
Reserved
The write value should always be 0.
Rev. 6.00 Sep. 24, 2009 Page 132 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bit
Bit Name
Initial
Value
R/W
Description
3
AE3
0
R/W
Address Output Enable 3 to 0
2
AE2
0
R/W
1
AE1
0
R/W
These bits select enabling or disabling of address outputs A8
to A23 in ROM extended mode.
0
AE0
0
R/W
When a pin is enabled for address output, the address is
output regardless of the corresponding DDR setting. When a
pin is disabled for address output, it becomes an output port
when the corresponding DDR bit is set to 1.
0000: A8 to A23 output disabled.
0001: A8 output enabled. A9 to A23 output disabled.
0010: A8 and A9 output enabled. A10 to A23 output
disabled.
0011: A8 to A10 output enabled. A11 to A23 output disabled.
0100: A8 to A11 output enabled. A12 to A23 output disabled.
0101: A8 to A12 output enabled. A13 to A23 output disabled.
0110: A8 to A13 output enabled. A14 to A23 output disabled.
0111: A8 to A14 output enabled. A15 to A23 output disabled.
1000: A8 to A15 output enabled. A16 to A23 output disabled.
1001: A8 to A16 output enabled. A17 to A23 output disabled.
1010: A8 to A17 output enabled. A18 to A23 output disabled.
1011: A8 to A18 output enabled. A19 to A23 output disabled.
1100: A8 to A19 output enabled. A20 to A23 output disabled.
1101: A8 to A20 output enabled. A21 to A23 output disabled.
1110: A8 to A21 output enabled. A22 and A23 output
disabled.
1111: A8 to A23 output enabled.
Rev. 6.00 Sep. 24, 2009 Page 133 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.4
Bus Control
7.4.1
Area Divisions
In advanced mode, the bus controller partitions the 16-Mbyte address space into eight areas, area 0
to area 7, in 2-Mbyte units, and performs bus control for external address space in area units. In
normal mode*, it controls a 64-kbyte address space comprising part of area 0.
Figure 7.2 shows an outline of the memory map.
The chip select signals (CS0 to CS7) can be output for each area.
Note: * Not available in this LSI.
Rev. 6.00 Sep. 24, 2009 Page 134 of 928
REJ09B0099-0600
Section 7 Bus Controller
H'000000
H'0000
Area 0
(2 Mbytes)
H'1FFFFF
H'200000
Area 1
(2 Mbytes)
H'3FFFFF
H'400000
Area 2
(2 Mbytes)
H'FFFF
H'5FFFFF
H'600000
Area 3
(2 Mbytes)
H'7FFFFF
H'800000
Area 4
(2 Mbytes)
H'9FFFFF
H'A00000
Area 5
(2 Mbytes)
H'BFFFFF
H'C00000
Area 6
(2 Mbytes)
H'DFFFFF
H'E00000
Area 7
(2 Mbytes)
H'FFFFFF
(1) Advanced mode
(2) Normal mode*
Note: * Not available in this LSI.
Figure 7.2 Overview of Area Divisions
7.4.2
Bus Specifications
The external address space bus specifications consist of three elements: bus width, number of
access states, and number of program wait states.
The bus width and number of access states for on-chip memory and internal I/O registers are
fixed, and are not affected by the bus controller.
Bus width: A bus width of 8 or 16 bits can be selected with ABWCR. An area for which an 8-bit
bus is selected functions as an 8-bit access space, and an area for which a 16-bit bus is selected
functions as a 16-bit access space.
Rev. 6.00 Sep. 24, 2009 Page 135 of 928
REJ09B0099-0600
Section 7 Bus Controller
If all areas are designated for 8-bit access, 8-bit bus mode is set; if any area is designated for 16bit access, 16-bit bus mode is set. When the burst ROM interface is designated, 16-bit bus mode is
always set.
Number of access states: Two or three access states can be selected with ASTCR. An area for
which 2-state access is selected functions as a 2-state access space, and an area for which 3-state
access is selected functions as a 3-state access space.
With the burst ROM interface, the number of access states may be determined without regarding
to ASTCR.
When 2-state access space is designated, wait insertion is disabled.
Number of program wait states: When 3-state access space is designated by ASTCR, the
number of program wait states to be inserted automatically is selected with WCRH and WCRL.
From 0 to 3 program wait states can be selected.
Table 7.2
Bus Specifications for Each Area (Basic Bus Interface)
ABWCR
ASTCR
WCRH, WCRL
ABWn
ASTn
Wn1
Wn0
Number of Access Number of Program
Bus Width States
Wait States
0
0
⎯
⎯
16
1
0
0
1
1
7.4.3
2
0
3
0
1
1
0
2
1
3
0
⎯
⎯
1
0
0
1
Bus Specifications (Basic Bus Interface)
8
2
0
3
0
1
1
0
2
1
3
Bus Interface for Each Area
The initial state of each area is basic bus interface, 3-state access space. The initial bus width is
selected according to the operating mode. The bus specifications described here cover basic items
only, and sections 7.6, Basic Bus Interface, and 7.7, Burst ROM Interface, on each memory
interface should be referred to for further details.
Rev. 6.00 Sep. 24, 2009 Page 136 of 928
REJ09B0099-0600
Section 7 Bus Controller
Area 0: Area 0 includes on-chip ROM, and in ROM-enabled extended mode, space excluding onchip ROM is external address space.
When external address space of area 0 is accessed, the CS0 signal can be output.
Either basic bus interface or burst ROM interface can be selected for area 0.
Areas 1 to 6: In external extended mode, all of areas 1 to 6 are external address spaces. When
external address spaces of areas 1 to 6 are accessed, the CS1 to CS6 pin signals can be output
respectively. Only the basic bus interface can be used for areas 1 to 6.
Area 7: Area 7 includes on-chip RAM and internal l/O registers. In external extended mode, the
space excluding on-chip RAM and internal l/O registers, is external address space. The on-chip
RAM is enabled when the RAME bit in the system control register (SYSCR) is set to 1; when the
RAME bit is cleared to 0, the on-chip RAM is disabled and the corresponding space becomes
external address space.
When external address space of area 7 is accessed, the CS7 signal can be output.
Only the basic bus interface can be used for area 7.
7.4.4
Chip Select Signals
This LSI can output chip select signals (CS0 to CS7) to areas 0 to 7, and these signals are driven
low respectively when the corresponding external address space area is accessed. Figure 7.3 shows
an example of CSn (n = 0 to 7) signal output timing. Enabling or disabling of the CSn signal is
performed by setting the data direction register (DDR) for the port corresponding to the particular
CSn pin.
In ROM-enabled extended mode, pins CS0 to CS7 are all placed in the input state after a poweron reset, and so the corresponding DDR should be set to 1 when outputting signals CS0 to CS7.
For details, see section 9, I/O Ports.
Rev. 6.00 Sep. 24, 2009 Page 137 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bus cycle
T1
T2
T3
φ
Address bus
External address of area n
CSn
Figure 7.3 CSn Signal Output Timing (n = 0 to 7)
Rev. 6.00 Sep. 24, 2009 Page 138 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.5
Basic Timing
The CPU is driven by a system clock, denoted by the symbol φ. The period from one rising edge
of φ to the next is referred to as a "state." The memory cycle or bus cycle consists of one, two, or
three states. Different methods are used to access on-chip memory, on-chip peripheral modules,
and the external address space.
7.5.1
On-Chip Memory (ROM, RAM) Access Timing
On-chip memory is accessed in one state. The data bus width is 16 bits, enabling both byte and
word transfer. Figure 7.4 shows the on-chip memory access cycle. Figure 7.5 shows the pin states.
Bus cycle
T1
φ
Internal address bus
Address
Internal read signal
Read
Internal data bus
Read data
Internal write signal
Write
Internal data bus
Write data
Figure 7.4 On-Chip Memory Access Cycle
Rev. 6.00 Sep. 24, 2009 Page 139 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bus cycle
T1
φ
Address bus
Retained
AS
High
RD
High
HWR, LWR
High
Data bus
High impedance
Figure 7.5 Pin States during On-Chip Memory Access
7.5.2
On-Chip Peripheral Module Access Timing
On-Chip Peripheral Module Access Timing Excluding Port H, Port J, IIC2, IEB, and
HCAN: The on-chip peripheral modules are accessed in two states except for port H, port J, IIC2,
IEB, and HCAN. The data bus width is either 8 bits or 16 bits, depending on the particular internal
I/O register being accessed. Figure 7.6 shows the access timing for the on-chip peripheral
modules. Figure 7.7 shows the pin states.
Bus cycle
T1
T2
φ
Internal address bus
Address
Internal read signal
Read
Internal data bus
Read data
Internal write signal
Write
Internal data bus
Write data
Figure 7.6 On-Chip Peripheral Module Access Cycle
Rev. 6.00 Sep. 24, 2009 Page 140 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bus cycle
T1
T2
φ
Address bus
Retained
AS
High
RD
High
HWR, LWR
High
Data bus
High impedance
Figure 7.7 Pin States during On-Chip Peripheral Module Access
On-Chip Port H, Port J, and IIC2 Module Access Timing: On-chip port H, port J, and IIC2
modules are accessed in four states. At this time, the data bus width is 8 bits. Figure 7.8 shows onchip port H, port J, and IIC2 module access timing, and figure 7.9 shows the pin states.
Bus cycle
T1
T2
T3
T4
φ
Internal address bus
Read
Address
Port H, port J, and
IIC2 read signal
Internal data bus
Write
Read data
Port H, port J, and
IIC2 write signal
Internal data bus
Write data
Figure 7.8 On-Chip Port H, Port J, and IIC2 Module Access Cycle
Rev. 6.00 Sep. 24, 2009 Page 141 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bus cycle
T2
T1
T3
T4
φ
Address bus
Retained
AS
High
RD
High
HWR, LWR
High
Data bus
High impedance
Figure 7.9 Pin States during On-Chip Port H, Port J, and IIC2 Module Access
On-Chip IEB Module Access Timing (H8S/2552 Group Only): On-chip IEB module is
accessed in four states. At this time, the data bus width is 8 bits. Figure 7.10 shows on-chip IEB
module access timing, and figure 7.11 shows the pin states.
Bus cycle
T1
T2
T3
T4
φ
Internal address bus
Address
IEB read signal
Read
Internal data bus
Read data
IEB write signal
Write
Internal data bus
Write data
Figure 7.10 On-Chip IEB Module Access Cycle
Rev. 6.00 Sep. 24, 2009 Page 142 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bus cycle
T1
T2
T3
T4
φ
Address bus
Retained
AS
High
RD
High
HWR, LWR
High
Data bus
High impedance
Figure 7.11 Pin States during On-Chip IEB Module Access
On-Chip HCAN Module Access Timing (H8S/2556 Group Only):On-chip HCAN module is
accessed in five states. At this time, the data bus width is 16 bits. Figure 7.12 shows on-chip
HCAN module access timing, and figure 7.13 shows the pin states.
Bus cycle
T1
T2
T3
T4
T5
φ
Internal address bus
Address
HCAN read signal
Read
Internal data bus
Read data
HCAN write signal
Write
Internal data bus
Write data
Figure 7.12 On-Chip HCAN Module Access Cycle
Rev. 6.00 Sep. 24, 2009 Page 143 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bus cycle
T1
T2
T3
T4
T5
φ
Address bus
AS
RD
HWR, LWR
Data bus
Retained
High
High
High
High impedance
Figure 7.13 Pin States during On-Chip HCAN Module Access
7.5.3
External Address Space Access Timing
The external address space is accessed with an 8-bit or 16-bit data bus width in a two-state or
three-state bus cycle. In three-state access, wait states can be inserted. For further details, see
section 7.6.3, Basic Timing.
Rev. 6.00 Sep. 24, 2009 Page 144 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.6
Basic Bus Interface
The basic bus interface enables direct connection of ROM, SRAM, and so on.
7.6.1
Data Size and Data Alignment
Data sizes for the CPU and other internal bus masters are byte, word, and longword. The bus
controller has a data alignment function. When accessing external address space, it controls
whether the upper data bus (D15 to D8) or lower data bus (D7 to D0) is used, according to the bus
specifications for the area being accessed (8-bit access space or 16-bit access space) and the data
size.
8-Bit Access Space: Figure 7.14 illustrates data alignment control for the 8-bit access space. With
the 8-bit access space, the upper data bus (D15 to D8) is always used for accesses. The amount of
data that can be accessed at one time is one byte: a word transfer instruction is performed as twobyte accesses, and a longword transfer instruction, as four-byte accesses.
Upper data bus
Lower data bus
D15
D8 D7
D0
Byte size
Word size
1st bus cycle
2nd bus cycle
1st bus cycle
Longword
size
2nd bus cycle
3rd bus cycle
4th bus cycle
Figure 7.14 Access Sizes and Data Alignment Control (8-Bit Access Space)
16-Bit Access Space: Figure 7.15 illustrates data alignment control for the 16-bit access space.
With the 16-bit access space, the upper data bus (D15 to D8) and lower data bus (D7 to D0) are
used for accesses. The amount of data that can be accessed at one time is one byte or one word,
and a longword transfer instruction is performed as two-word accesses.
In byte access, whether the upper or lower data bus is used is determined by whether the address is
even or odd. The upper data bus is used for an even address, and the lower data bus for an odd
address.
Rev. 6.00 Sep. 24, 2009 Page 145 of 928
REJ09B0099-0600
Section 7 Bus Controller
Upper data bus
Lower data bus
D15
D8 D7
D0
Byte size
· Even address
Byte size
· Odd address
Word size
1st bus cycle
Longword
size
2nd bus cycle
Figure 7.15 Access Sizes and Data Alignment Control (16-Bit Access Space)
7.6.2
Valid Strobes
Table 7.3 shows the data buses used and valid strobes for the access spaces.
In read access, the RD signal is valid without discrimination between the upper and lower halves
of the data bus.
In write access, the HWR signal is valid for the upper half of the data bus, and the LWR signal for
the lower half.
Table 7.3
Area
Data Buses Used and Valid Strobes
Access
Size
8-bit access Byte
space
16-bit
access
space
Byte
Read/
Write
Address
Valid Strobe
Upper Data Bus Lower Data Bus
(D15 to D8)
(D7 to D0)
Read
⎯
RD
Valid
Write
⎯
HWR
Valid
Hi-Z
Read
Even
RD
Valid
Invalid
Odd
RD
Invalid
Valid
Even
HWR
Valid
Hi-Z
Odd
LWR
Hi-Z
Valid
Read
⎯
RD
Valid
Valid
Write
⎯
HWR, LWR
Valid
Valid
Write
Word
Legend:
Hi-Z: High impedance
Invalid: Input state; input value is ignored.
Rev. 6.00 Sep. 24, 2009 Page 146 of 928
REJ09B0099-0600
Invalid
Section 7 Bus Controller
7.6.3
Basic Timing
8-Bit 2-State Access Space: Figure 7.16 shows the bus timing for an 8-bit 2-state access space.
When an 8-bit access space is accessed, the upper half (D15 to D8) of the data bus is used.
Wait states cannot be inserted.
Bus cycle
T2
T1
φ
Address bus
CSn
AS
RD
Read
D15 to D8
Valid
D7 to D0
Invalid
HWR
LWR
(16-bit bus
mode)
Write
LWR
(8-bit bus
mode)
D15 to D8
D7 to D0
High
High impedance
Valid
High impedance
Note: n = 0 to 7
Figure 7.16 Bus Timing for 8-Bit 2-State Access Space
Rev. 6.00 Sep. 24, 2009 Page 147 of 928
REJ09B0099-0600
Section 7 Bus Controller
8-Bit 3-State Access Space: Figure 7.17 shows the bus timing for an 8-bit 3-state access space.
When an 8-bit access space is accessed, the upper half (D15 to D8) of the data bus is used.
Wait states can be inserted.
Bus cycle
T1
T2
T3
φ
Address bus
CSn
AS
RD
Read
D15 to D8
Valid
D7 to D0
Invalid
HWR
LWR
(16-bit bus
mode)
Write
LWR
(8-bit bus
mode)
D15 to D8
D7 to D0
High
High impedance
Valid
High impedance
Note: n = 0 to 7
Figure 7.17 Bus Timing for 8-Bit 3-State Access Space
Rev. 6.00 Sep. 24, 2009 Page 148 of 928
REJ09B0099-0600
Section 7 Bus Controller
16-Bit 2-State Access Space: Figures 7.18 to 7.20 show bus timings for a 16-bit 2-state access
space. When a 16-bit access space is accessed, the upper half (D15 to D8) of the data bus is used
for an even address, and the lower half (D7 to D0) for an odd address.
Wait states cannot be inserted.
Bus cycle
T1
T2
φ
Address bus
CSn
AS
RD
Read
D15 to D8
Valid
D7 to D0
Invalid
HWR
LWR
High
Write
D15 to D8
D7 to D0
Valid
High impedance
Note: n = 0 to 7
Figure 7.18 Bus Timing for 16-Bit 2-State Access Space (1) (Even Address Byte Access)
Rev. 6.00 Sep. 24, 2009 Page 149 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bus cycle
T1
T2
φ
Address bus
CSn
AS
RD
Read
D15 to D8
Invalid
D7 to D0
Valid
HWR
High
LWR
Write
High impedance
D15 to D8
D7 to D0
Valid
Note: n = 0 to 7
Figure 7.19 Bus Timing for 16-Bit 2-State Access Space (2) (Odd Address Byte Access)
Rev. 6.00 Sep. 24, 2009 Page 150 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bus cycle
T1
T2
φ
Address bus
CSn
AS
RD
Read
D15 to D8
Valid
D7 to D0
Valid
HWR
LWR
Write
D15 to D8
Valid
D7 to D0
Valid
Note: n = 0 to 7
Figure 7.20 Bus Timing for 16-Bit 2-State Access Space (3) (Word Access)
Rev. 6.00 Sep. 24, 2009 Page 151 of 928
REJ09B0099-0600
Section 7 Bus Controller
16-Bit 3-State Access Space: Figures 7.21 to 7.23 show bus timings for a 16-bit 3-state access
space. When a 16-bit access space is accessed, the upper half (D15 to D8) of the data bus is used
for an even address, and the lower half (D7 to D0) for an odd address.
Wait states can be inserted.
Bus cycle
T1
T2
T3
φ
Address bus
CSn
AS
RD
Read
D15 to D8
Valid
D7 to D0
Invalid
HWR
LWR
High
Write
D15 to D8
D7 to D0
Valid
High impedance
Note: n = 0 to 7
Figure 7.21 Bus Timing for 16-Bit 3-State Access Space (1) (Even Address Byte Access)
Rev. 6.00 Sep. 24, 2009 Page 152 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bus cycle
T1
T2
T3
φ
Address bus
CSn
AS
RD
Read
D15 to D8
Invalid
D7 to D0
Valid
HWR
High
LWR
Write
D15 to D8
D7 to D0
High impedance
Valid
Note: n = 0 to 7
Figure 7.22 Bus Timing for 16-Bit 3-State Access Space (2) (Odd Address Byte Access)
Rev. 6.00 Sep. 24, 2009 Page 153 of 928
REJ09B0099-0600
Section 7 Bus Controller
Bus cycle
T1
T2
T3
φ
Address bus
CSn
AS
RD
Read
D15 to D8
Valid
D7 to D0
Valid
HWR
LWR
Write
D15 to D8
Valid
D7 to D0
Valid
Note: n = 0 to 7
Figure 7.23 Bus Timing for 16-Bit 3-State Access Space (3) (Word Access)
Rev. 6.00 Sep. 24, 2009 Page 154 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.6.4
Wait Control
When accessing external address space, this LSI can extend the bus cycle by inserting one or more
wait states (Tw).
Program Wait Insertion: From 0 to 3 wait states can be inserted automatically between the T2
state and T3 state on an individual area basis in 3-state access space, according to the settings of
WCRH and WCRL.
Pin Wait Insertion: Setting the WAITE bit in BCRH to 1 enables wait insertion by means of the
WAIT pin. When external address space is accessed in this state, program wait insertion is first
carried out according to the settings of WCRH and WCRL. Then, if the WAIT pin is low at the
falling edge of φ in the last T2 or TW state, a TW state is inserted. If the WAIT pin is held low, TW
states are inserted until it goes high.
Figure 7.24 shows an example of wait state insertion timing.
Rev. 6.00 Sep. 24, 2009 Page 155 of 928
REJ09B0099-0600
Section 7 Bus Controller
By program
wait
T1
T2
Tw
By the WAIT pin
Tw
Tw
T3
φ
WAIT
Address bus
AS
RD
Read
Read data
Data bus
HWR, LWR
Write
Data bus
Write data
Note: ↓ indicates the timing of WAIT pin sampling.
Figure 7.24 Example of Wait State Insertion Timing
Rev. 6.00 Sep. 24, 2009 Page 156 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.7
Burst ROM Interface
With this LSI, external address space of area 0 can be designated as burst ROM space, and burst
ROM interfacing can be performed. The burst ROM space interface enables 16-bit configuration
ROM with burst access capability to be accessed at high speed.
Area 0 can be designated as burst ROM space by means of the BRSTRM bit in BCRH.
Consecutive burst accesses of a maximum of 4 words or 8 words can be performed for CPU
instruction fetches only. One or two states can be selected for burst access.
7.7.1
Basic Timing
The number of access states in the initial cycle (full access) of the burst ROM interface is in
accordance with the setting of the AST0 bit in ASTCR. Also, when the AST0 bit is set to 1, wait
states can be inserted. One or two states can be selected for the burst cycle, according to the
setting of the BRSTS1 bit in BCRH. Wait states cannot be inserted. When area 0 is designated as
burst ROM space, it becomes 16-bit access space regardless of the setting of the ABW0 bit in
ABWCR.
When the BRSTS0 bit in BCRH is cleared to 0, burst access of up to 4 words is performed; when
the BRSTS0 bit is set to 1, burst access of up to 8 words is performed.
The basic access timing for burst ROM space is shown in figures 7.25 and 7.26. The timing shown
in figure 7.25 is for the case where the AST0 and BRSTS1 bits are both set to 1, and that in figure
7.26 is for the case where both these bits are cleared to 0.
Rev. 6.00 Sep. 24, 2009 Page 157 of 928
REJ09B0099-0600
Section 7 Bus Controller
Full access
T1
T2
Burst access
T3
T1
T2
T1
T2
φ
Address bus
Only lower address changed
CS0
AS
RD
Data bus
Read data
Read data
Read data
Figure 7.25 Example of Burst ROM Access Timing (When AST0 = BRSTS1 = 1)
Full access
T1
T2
Burst access
T1
T1
φ
Address bus
Only lower address changed
CS0
AS
RD
Data bus
Read data
Read data Read data
Figure 7.26 Example of Burst ROM Access Timing (When AST0 = BRSTS1 = 0)
Rev. 6.00 Sep. 24, 2009 Page 158 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.7.2
Wait Control
As with the basic bus interface, either program wait insertion or pin wait insertion using the WAIT
pin can be used in the initial cycle (full access) of the burst ROM interface. See section 7.6.4, Wait
Control.
Wait states cannot be inserted in a burst cycle.
Rev. 6.00 Sep. 24, 2009 Page 159 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.8
Idle Cycle
When this LSI accesses external address space, it can insert one-state idle cycle (TI) between bus
cycles in the following two cases: (1) when read accesses between different areas occur
consecutively, and (2) when a write cycle occurs immediately after a read cycle. By inserting an
idle cycle it is possible, for example, to avoid data collisions between ROM, with a long output
floating time, and high-speed memory, I/O interfaces, and so on.
Consecutive Reads between Different Areas: If consecutive reads between different areas occur
while the ICIS1 bit in BCRH is set to 1, an idle cycle is inserted at the start of the second read
cycle.
Figure 7.27 shows an example of the operation in this case. In this example, bus cycle A is a read
cycle from ROM with a long output floating time, and bus cycle B is a read cycle from SRAM,
each being located in a different area. In (a), an idle cycle is not inserted, and a collision occurs in
cycle B between the read data from ROM and that from SRAM. In (b), an idle cycle is inserted,
and a data collision is prevented.
Bus cycle A
T1
T2
T3
Bus cycle B
T1
Bus cycle A
T1
T2
φ
φ
Address bus
Address bus
CS (area A)
CS (area A)
CS (area B)
CS (area B)
RD
RD
Data bus
Data bus
Long output floating time
(a) Idle cycle not inserted
(ICIS1 = 0)
T2
T3
REJ09B0099-0600
TI
T1
Data collision
(b) Idle cycle inserted
(Initial value: ICIS1 = 1)
Figure 7.27 Example of Idle Cycle Operation (1)
Rev. 6.00 Sep. 24, 2009 Page 160 of 928
Bus cycle B
T2
Section 7 Bus Controller
Write after Read: If an external write occurs after an external read while the ICIS0 bit in BCRH
is set to 1, an idle cycle is inserted at the start of the write cycle.
Figure 7.28 shows an example of the operation in this case. In this example, bus cycle A is a read
cycle from ROM with a long output floating time, and bus cycle B is a CPU write cycle. In (a), an
idle cycle is not inserted, and a collision occurs in cycle B between the read data from ROM and
the CPU write data. In (b), an idle cycle is inserted, and a data collision is prevented.
Bus cycle A
T1
T2
T3
Bus cycle B
T1
Bus cycle A
T2
T1
φ
φ
Address bus
Address bus
CS (area A)
CS (area A)
CS (area B)
CS (area B)
RD
RD
HWR
HWR
Data bus
Data bus
Long output floating time
(a) Idle cycle not inserted
(ICIS0 = 0)
T2
T3
Bus cycle B
TI
T1
T2
Data collision
(b) Idle cycle inserted
(Initial value: ICIS0 = 1)
Figure 7.28 Example of Idle Cycle Operation (2)
Rev. 6.00 Sep. 24, 2009 Page 161 of 928
REJ09B0099-0600
Section 7 Bus Controller
Relationship between Chip Select (CS) Signal and Read (RD) Signal: Depending on the
system’s load conditions, the RD signal may lag behind the CS signal. An example is shown in
figure 7.29.
In this case, with the setting for no idle cycle insertion (a), there may be a period of overlap
between the bus cycle A RD signal and the bus cycle B CS signal.
Setting idle cycle insertion, as in (b), however, will prevent any overlap between the RD and CS
signals.
In the initial state after reset release, idle cycle insertion (b) is set.
Bus cycle A
T1
T2
T3
Bus cycle A
Bus cycle B
T1
T2
T1
φ
φ
Address bus
Address bus
CS (area A)
CS (area A)
CS (area B)
CS (area B)
RD
RD
T2
T3
Bus cycle B
TI
T1
Possibility of overlap between
CS (area B) and RD
(b) Idle cycle inserted
(Initial value: ICIS1 = 1)
(a) Idle cycle not inserted
(ICIS1 = 0)
Figure 7.29 Relationship between Chip Select (CS) and Read (RD)
Table 7.4 shows the pin states in an idle cycle.
Table 7.4
Pin States in Idle Cycle
Pins
Pin State
A23 to A0
Contents of next bus cycle
D15 to D0
High impedance
CSn
High
AS
High
RD
High
HWR
High
LWR
High
Rev. 6.00 Sep. 24, 2009 Page 162 of 928
REJ09B0099-0600
T2
Section 7 Bus Controller
7.9
Bus Release
This LSI can release the external bus in response to a bus mastership request from an external
device. In the external bus mastership released state, the internal bus master continues to operate
as long as there is no external access.
In external extended mode, the bus mastership can be released to an external device by setting the
BRLE bit in BCRL to 1. Driving the BREQ pin low issues an external bus mastership request to
this LSI. When the BREQ pin is sampled, the BACK pin is driven low at the prescribed timing,
and the address bus, data bus, and bus control signals are placed in the high-impedance state,
establishing the external bus mastership released state.
In the external bus mastership released state, an internal bus master can perform accesses using the
internal bus. When an internal bus master wants to make an external access, it temporarily defers
activation of the bus cycle, and waits for the bus mastership request from the external bus master
to be dropped.
When the BREQ pin is driven high, the BACK pin is driven high at the prescribed timing and the
external bus mastership released state is terminated.
In the event of simultaneous external bus mastership release request and external access request
generation, the order of priority is as follows:
(High) External bus mastership release > Internal bus master external access (Low)
Table 7.5 shows the pin states in the external bus mastership released state.
Table 7.5
Pin States in Bus Mastership Released State
Pins
Pin State
A23 to A0
High impedance
D15 to D0
High impedance
CSn
High impedance
AS
High impedance
RD
High impedance
HWR
High impedance
LWR
High impedance
Rev. 6.00 Sep. 24, 2009 Page 163 of 928
REJ09B0099-0600
Section 7 Bus Controller
Figure 7.30 shows the timing for transition to the bus mastership released state.
External bus mastership
released state
CPU cycle
T0
T1
CPU
cycle
T2
φ
High impedance
Address bus
Address
High impedance
Data bus
High impedance
CSn
High impedance
AS
High impedance
RD
High impedance
HWR, LWR
BREQ
BACK
Minimum
1 state
[1]
[1]
[2]
[3]
[4]
[5]
[2]
[3]
[4]
[5]
The low level of the BREQ pin is sampled at the rise of T2 state.
The BACK pin is driven low at one state after the end of CPU read cycle,
releasing bus mastership to external bus master.
The BREQ pin state is still sampled in external bus mastership released state.
The high level of the BREQ pin is sampled.
The BACK pin is driven high, ending the bus mastership release cycles.
Note : n = 0 to 7
Figure 7.30 Bus Mastership Released State Transition Timing
7.9.1
Usage Note for Bus Mastership Release
When a transition to software standby mode or watch mode is made, external bus mastership
release function is aborted. In the state where MSTPCR is set to H'FFFFFF, and a transition to
sleep mode is made, external bus mastership release function is aborted. When external bus
mastership release function is used in sleep mode, MSTPCR should not be set to H'FFFFFF.
Rev. 6.00 Sep. 24, 2009 Page 164 of 928
REJ09B0099-0600
Section 7 Bus Controller
7.10
Bus Arbitration
This LSI has a bus arbiter that arbitrates bus master operations.
There are two bus masters, the CPU and DTC, which perform read/write operations when they
have possession of the bus. Each bus master requests the bus mastership by means of a bus request
signal. The bus arbiter determines priorities at the prescribed timing, and permits use of the bus by
means of a bus mastership request acknowledge signal. The selected bus master then takes
possession of the bus mastership and begins its operation.
7.10.1
Operation
The bus arbiter detects the bus masters’ bus mastership request signals, and if the bus mastership
is requested, sends a bus mastership request acknowledge signal to the bus master. If there are bus
mastership requests from more than one bus master, the bus mastership request acknowledge
signal is sent to the one with the highest priority. When a bus master receives the bus mastership
request acknowledge signal, it takes possession of the bus until that signal is canceled.
The order of priority of the bus masters is as follows:
(High) DTC > CPU (Low)
An internal bus access by an internal bus master, and external bus mastership release, can be
executed in parallel.
In the event of simultaneous external bus mastership release request, and internal bus master
external access request generation, the order of priority is as follows:
(High) External bus mastership release > Internal bus master external access (Low)
7.10.2
Bus Mastership Transfer Timing
Even if a bus mastership request is received from a bus master with a higher priority than that of
the bus master that has acquired the bus and is currently operating, the bus mastership is not
necessarily transferred immediately. There are specific times at which each bus master can
relinquish the bus mastership.
CPU: The CPU is the lowest-priority bus master, and if a bus mastership request is received from
the DTC, the bus arbiter transfers the bus mastership to the bus master that issued the request. The
timing for transfer of the bus mastership is as follows:
Rev. 6.00 Sep. 24, 2009 Page 165 of 928
REJ09B0099-0600
Section 7 Bus Controller
• The bus mastership is transferred at a break between bus cycles. However, if a bus cycle is
executed in discrete operations, as in the case of a longword-size access, the bus mastership is
not transferred between the operations.
• If the CPU is in sleep mode, it transfers the bus mastership immediately.
DTC: The DTC sends the bus arbiter a request for the bus mastership when an activation request
is generated.
The DTC can release the bus mastership after a vector read, a register information read (3 states),
a single data transfer, or a register information write (3 states). It does not release the bus
mastership during a register information read (3 states), a single data transfer, or a register
information write (3 states).
7.10.3
Usage Note for External Bus Mastership Release
External bus mastership release can be performed on completion of an external bus cycle. The CS
signal remains low until the end of the external bus cycle. Therefore, when external bus
mastership release is performed, the CS signal may change from the low level to the highimpedance state.
7.11
Resets and the Bus Controller
In a power-on reset, this LSI, including the bus controller, enters the reset state at that point, and
an executing bus cycle is discontinued.
In a manual reset, the bus controller’s registers and internal state are maintained, and an executing
external bus cycle is completed. In this case, WAIT input is ignored and write data is not
guaranteed.
Rev. 6.00 Sep. 24, 2009 Page 166 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Section 8 Data Transfer Controller (DTC)
This LSI includes a data transfer controller (DTC). The DTC can be activated by an interrupt or
software, to transfer data.
Figure 8.1 shows a block diagram of the DTC.
The DTC’s register information is stored in on-chip RAM. When the DTC is used, the RAME bit
in SYSCR must be set to 1. As 32-bit bus connects the DTC to on-chip RAM (1 kbyte), 32-bit/1state reading and writing of the DTC register information is enabled.
8.1
Features
• Transfer is possible over any number of channels
⎯ One activation source can trigger a number of data transfers (chain transfer)
• Three transfer modes
⎯ Normal, repeat, and block transfer modes are available
• The direct specification of 16-Mbyte address space is possible
• Transfer can be set in byte or word units
• A CPU interrupt can be requested for the interrupt that activated the DTC
• Activation by software is possible
• Module stop mode can be set
Rev. 6.00 Sep. 24, 2009 Page 167 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Internal address bus
CPU interrupt
request
Legend:
MRA, MRB:
CRA, CRB:
SAR:
DAR:
DTCERA to DTCERG,
and DTCERI:
DTVECR:
On-chip
RAM
Internal data bus
DTC mode registers A and B
DTC transfer count registers A and B
DTC source address register
DTC destination address register
DTC enable registers A to G, and I
DTC vector register
Figure 8.1 Block Diagram of DTC
Rev. 6.00 Sep. 24, 2009 Page 168 of 928
REJ09B0099-0600
Register information
MRA MRB
CRA
CRB
DAR
SAR
Control logic
DTC
DTC activation
request
DTCERA
to
DTCERG,
and DTCERI
Interrupt
request
DTVECR
Interrupt controller
Section 8 Data Transfer Controller (DTC)
8.2
Register Descriptions
The DTC has the following registers.
•
•
•
•
•
•
DTC mode register A (MRA)
DTC mode register B (MRB)
DTC source address register (SAR)
DTC destination address register (DAR)
DTC transfer count register A (CRA)
DTC transfer count register B (CRB)
These six registers cannot be directly accessed from the CPU. When activated, the DTC reads a
set of register information that is stored in on-chip RAM and transfers data to the corresponding
DTC registers. After the data transfer, it writes a set of updated register inform ation back to the
RAM.
• DTC enable registers A to G, and I (DTCERA to DTCERG, and DTCERI)
• DTC vector register (DTVECR)
Rev. 6.00 Sep. 24, 2009 Page 169 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
8.2.1
DTC Mode Register A (MRA)
MRA selects the DTC operating mode.
Bit
Bit Name
Initial
Value
7
SM1
Undefined ⎯
Source Address Mode 1 and 0
6
SM0
Undefined ⎯
These bits specify an SAR operation after a data
transfer.
R/W
Description
0X: SAR is fixed
10: SAR is incremented after a transfer
(by +1 when Sz = 0; by +2 when Sz = 1)
11: SAR is decremented after a transfer
(by –1 when Sz = 0; by –2 when Sz = 1)
5
DM1
Undefined ⎯
Destination Address Mode 1 and 0
4
DM0
Undefined ⎯
These bits specify a DAR operation after a data transfer.
0X: DAR is fixed
10: DAR is incremented after a transfer
(by +1 when Sz = 0; by +2 when Sz = 1)
11: DAR is decremented after a transfer
(by –1 when Sz = 0; by –2 when Sz = 1)
3
MD1
Undefined ⎯
DTC Mode 1 and 0
2
MD0
Undefined ⎯
These bits specify the DTC transfer mode.
00: Normal mode
01: Repeat mode
10: Block transfer mode
11: ⎯
1
DTS
Undefined ⎯
DTC Transfer Mode Select
Specifies whether the source side or the destination side
is set to be a repeat area or block area, in repeat mode
or block transfer mode.
0: Destination side is repeat area or block area
1: Source side is repeat area or block area
Rev. 6.00 Sep. 24, 2009 Page 170 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Bit
Bit Name
Initial
Value
0
Sz
Undefined ⎯
R/W
Description
DTC Data Transfer Size
Specifies the size of data to be transferred.
0: Byte-size transfer
1: Word-size transfer
Legend:
X:
Don’t care
8.2.2
DTC Mode Register B (MRB)
MRB is an 8-bit register that selects the DTC operating mode.
Bit
Bit Name
Initial
Value
7
CHNE
Undefined ⎯
R/W
Description
DTC Chain Transfer Enable
This bit specifies a chain transfer. For details, see
section 8.5.4, Chain Transfer.
In data transfer with CHNE set to 1, determination of the
end of the specified number of transfers, clearing of the
interrupt source flag, and clearing of DTCER, are not
performed.
0: DTC data transfer completed (waiting for start)
1: DTC data transfer (reads new register information
and transfers data)
6
DISEL
Undefined ⎯
DTC Interrupt Select
This bit specifies whether CPU interrupt is disabled or
enabled after a data transfer.
0: Interrupt request is issued to the CPU when the
specified data transfer is completed. (The DTC clears
the interrupt request flag that causes the activation.)
1: The DTC issues interrupt request to the CPU in every
data transfer. (The DTC does not clear the interrupt
request flag that causes the activation.)
5 to 0
⎯
Undefined ⎯
Reserved
These bits have no effect on the DTC operation. The
write value should always be 0.
Rev. 6.00 Sep. 24, 2009 Page 171 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
8.2.3
DTC Source Address Register (SAR)
SAR is a 24-bit register that designates the source address of data to be transferred by the DTC.
For word-size transfer, specify an even source address.
8.2.4
DTC Destination Address Register (DAR)
DAR is a 24-bit register that designates the destination address of data to be transferred by the
DTC. For word-size transfer, specify an even destination address.
8.2.5
DTC Transfer Count Register A (CRA)
CRA is a 16-bit register that designates the number of times that data is transferred by the DTC.
In normal mode, the entire CRA functions as a 16-bit transfer counter (1 to 65536). It is
decremented by 1 every time data is transferred, and transfer ends when the count reaches H'0000.
In repeat mode or block transfer mode, the CRA is divided into two parts; the upper 8 bits
(CRAH) and the lower 8 bits (CRAL). In repeat mode, CRAH holds the number of transfers while
CRAL functions as an 8-bit transfer counter (1 to 256). In block transfer mode, CRAH holds the
block size while CRAL functions as an 8-bit block size counter (1 to 256). CRAL is decremented
by 1 every time data is transferred, and the contents of CRAH are sent when the count reaches
H'00. These operations are repeated.
8.2.6
DTC Transfer Count Register B (CRB)
CRB is a 16-bit register that designates the number of times that data is transferred by the DTC in
block transfer mode. It functions as a 16-bit transfer counter (1 to 65536) that is decremented by 1
every time data is transferred, and transfer ends when the count reaches H'0000.
8.2.7
DTC Enable Registers A to G, and I (DTCERA to DTCERG, and DTCERI)
DTCER is a set of registers to specify the DTC activation interrupt source, and comprised of eight
registers; DTCERA to DTCERG, and DTCERI. The correspondence between interrupt sources
and DTCE bits, and vector numbers generated by the interrupt controller are shown in table 8.2.
For DTCE bit setting, use bit manipulation instructions such as BSET and BCLR for reading and
writing. When multiple activation sources are to be set at one time, only at the initial setting,
writing data is enabled after executing a dummy read on the relevant register with all the interrupts
being masked.
Rev. 6.00 Sep. 24, 2009 Page 172 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Bit
Bit Name
Initial
Value
R/W
Description
7
DTCEn7
0
R/W
DTC Activation Enable
6
DTCEn6
0
R/W
1: Disables an interrupt for DTC activation.
5
DTCEn5
0
R/W
4
DTCEn4
0
R/W
0: Specifies a relevant interrupt source as a DTC
activation source.
3
DTCEn3
0
R/W
[Clearing conditions]
2
DTCEn2
0
R/W
1
DTCEn1
0
R/W
• When the DISEL bit in MRB is 1 and the data transfer
has ended
0
DTCEn0
0
R/W
• When the specified number of transfers have ended
[Retaining condition]
• When the DISEL bit is 0 and the specified number of
transfers have not been completed
(n = A to G, and I)
8.2.8
DTC Vector Register (DTVECR)
DTVECR is an 8-bit readable/writable register that enables or disables DTC activation by
software, and sets a vector number for the software activation interrupt.
Bit
Bit Name
Initial
Value
R/W
Description
7
SWDTE
0
R/W
DTC Software Activation Enable
Enables or disables the DTC software activation.
0: Disables the DTC software activation.
1: Enables the DTC software activation.
[Clearing conditions]
• When the DISEL bit is 0 and the specified number of
transfers have not ended
• When 0 is written after a software-activated data
transfer end interrupt (SWDTEND) request has been
sent to the CPU
[Retaining conditions]
• When the DISEL bit is 1 and data transfer has ended
• When the specified number of transfers have ended
• When the software-activated data transfer is in process
Rev. 6.00 Sep. 24, 2009 Page 173 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Bit
Bit Name
Initial
Value
R/W
Description
6
DTVEC6
0
R/W
DTC Software Activation Vector 6 to 0
5
DTVEC5
0
R/W
4
DTVEC4
0
R/W
These bits specify a vector number for the DTC software
activation.
3
DTVEC3
0
R/W
2
DTVEC2
0
R/W
The vector address is expressed as H'0400 + (vector
number × 2). For example, when DTVEC6 to DTVEC0 =
H'10, the vector address is H'0420.
1
DTVEC1
0
R/W
These bits are writable when SWDTE = 0.
0
DTVEC0
0
R/W
8.3
Activation Sources
The DTC operates when activated by an interrupt request or by a write to DTVECR by software.
An activation interrupt request is specified by DTCER. When the corresponding bit is set to 1, it
becomes DTC activation source and when it is cleared to 0, it becomes CPU interrupt source. At
the end of a data transfer (or the last consecutive transfer in the case of chain transfer), the
interrupt flag of activation source or corresponding DTCER bit is cleared. Table 8.1 shows the
relationship between the activation source and DTCER clearing. The activation source flag, in the
case of RXI0, for example, is the RDRF flag in SCI_0.
Since there are a number of DTC activation sources, transferring the last byte (or word) does not
clear the flag of its activation source. Take appropriate steps at each interrupt processing.
When an interrupt has been designated as a DTC activation source, the existing CPU mask level
and interrupt controller priorities have no effect. If there are more than one activation sources at
the same time, the DTC operates in accordance with the default priority of the interrupt sources.
Figure 8.2 shows a block diagram of the DTC activation source control. For details, see section 5,
Interrupt Controller.
Rev. 6.00 Sep. 24, 2009 Page 174 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Table 8.1
Activation Source and DTCER Clearing
Activation Source
The DISEL Bit is 0, and Transfer
Counts Specified have not Ended
The DISEL Bit is 1, or Transfer
Counts Specified have Ended
Software activation
• The SWDTE bit is cleared to 0
• The SWDTE bit retains 1
• The interrupt request is sent to the
CPU
Interrupt activation
• The corresponding DTCER bit
retains 1
• The corresponding DTCER bit is
cleared to 0
• The activation source flag is
cleared to 0
• The activation source flag retains 1
• The interrupt request which
becomes an activation source is
sent to the CPU
Source flag cleared
Clear
controller
Clear
DTCER
On-chip
peripheral
module
IRQ interrupt
DTVECR
Interrupt
request
Selection circuit
Select
Clear request
DTC
CPU
Interrupt controller
Interrupt mask
Figure 8.2 Block Diagram of DTC Activation Source Control
Rev. 6.00 Sep. 24, 2009 Page 175 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
8.4
Location of Register Information and DTC Vector Table
Locate the register information in on-chip RAM (addresses: H'FFEBC0 to H'FFEFBF). Register
information should be located at an address that is a multiple of four within the range. Locating
the register information in address space is shown in figure 8.3. Locate the MRA, SAR, MRB,
DAR, CRA, and CRB registers, in that order, from the start address of the register information.
In the case of chain transfer, register information should be located in consecutive areas as shown
in figure 8.3, and the register information start address should be located at the vector address
corresponding to the interrupt source. Figure 8.4 shows the correspondence between the DTC
vector address and register information. The DTC reads the start address of the register
information from the vector address set for each activation source, and then reads the register
information from that start address.
When the DTC is activated by software, the vector address is obtained from: H'0400 +
(DTVECR[6:0] × 2). For example, if DTVECR is H'10, the vector address is H'0420.
The configuration of the vector address is the same in both normal* and advanced modes, a 2-byte
unit being used in both cases. These two bytes specify the lower bits of the register information
start address.
Note:
Normal mode is not supported in this LSI.
Lower address
0
Register
information
start address
Chain
transfer
1
2
MRA
SAR
MRB
DAR
3
Register information
CRB
CRA
MRA
SAR
MRB
DAR
Register information
for 2nd transfer in
chain transfer
CRB
CRA
4 bytes
Figure 8.3 Location of DTC Register Information in Address Space
Rev. 6.00 Sep. 24, 2009 Page 176 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
DTC vector
address
Register information
start address
Register information
Chain transfer
Figure 8.4 Correspondence between DTC Vector Address and Register Information
Rev. 6.00 Sep. 24, 2009 Page 177 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Table 8.2
Interrupt Sources, DTC Vector Addresses, and Corresponding DTCEs
Interrupt
Source
Origin of Interrupt
Source
Vector
Number
DTC Vector
Address
Software
Write to DTVECR
DTVECR
External pin
IRQ0
DTCE*
Priority
H'0400 +
(vector number × 2)
⎯
High
16
H'0420
DTCEA7
IRQ1
17
H'0422
DTCEA6
IRQ2
18
H'0424
DTCEA5
IRQ3
19
H'0426
DTCEA4
IRQ4
20
H'0428
DTCEA3
IRQ5
21
H'042A
DTCEA2
IRQ6
22
H'042C
DTCEA1
IRQ7
23
H'042E
DTCEA0
A/D converter ADI (A/D conversion end)
28
H'0438
DTCEB6
TPU
channel 0
TGI0A
32
H'0440
DTCEB5
TGI0B
33
H'0442
DTCEB4
TGI0C
34
H'0444
DTCEB3
TGI0D
35
H'0446
DTCEB2
TPU
channel 1
TGI1A
40
H'0450
DTCEB1
TGI1B
41
H'0452
DTCEB0
TPU
channel 2
TGI2A
44
H'0458
DTCEC7
TGI2B
45
H'045A
DTCEC6
TPU
channel 3
TGI3A
48
H'0460
DTCEC5
TGI3B
49
H'0462
DTCEC4
TGI3C
50
H'0464
DTCEC3
TGI3D
51
H'0466
DTCEC2
TPU
channel 4
TGI4A
56
H'0470
DTCEC1
TGI4B
57
H'0472
DTCEC0
TPU
channel 5
TGI5A
60
H'0478
DTCED5
TGI5B
61
H'047A
DTCED4
8-bit timer
channel 0
CMIA0
64
H'0480
DTCED3
CMIB0
65
H'0482
DTCED2
Rev. 6.00 Sep. 24, 2009 Page 178 of 928
REJ09B0099-0600
Low
Section 8 Data Transfer Controller (DTC)
Interrupt
Source
Origin of Interrupt
Source
Vector
Number
DTC Vector
Address
DTCE*
Priority
8-bit timer
channel 1
CMIA1
68
H'0488
DTCED1
High
CMIB1
69
H'048A
DTCED0
SCI
channel 0
RXI0
81
H'04A2
DTCEE3
TXI0
82
H'04A4
DTCEE2
SCI
channel 1
RXI1
85
H'04AA
DTCEE1
TXI1
86
H'04AC
DTCEE0
SCI
channel 2
RXI2
89
H'04B2
DTCEF7
TXI2
90
H'04B4
DTCEF6
8-bit timer
channel 2
CMIA2
92
H'04B8
DTCEF5
CMIB2
93
H'04BA
DTCEF4
8-bit timer
channel 3
CMIA3
96
H'04C0
DTCEF3
CMIB3
97
H'04C2
DTCEF2
IEB
(H8S/2552
Group only)
IERxl
105
H'04D2
DTCEG6
IETxl
106
H'04D4
DTCEG5
HCAN
(H8S/2556
Group only)
RM0
109
H'04DA
DTCEG2
SCI
channel 3
RXI3
121
H'04F2
DTCEI7
TXI3
122
H'04F4
DTCEI6
SCI
channel 4
RXI4
125
H'04FA
DTCEI5
TXI4
126
H'04FC
DTCEI4
Note:
*
Low
The DTCE bits with no corresponding interrupt are reserved, and should be written with
0.
Rev. 6.00 Sep. 24, 2009 Page 179 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
8.5
Operation
Register information is stored in on-chip RAM. When activated, the DTC reads register
information in on-chip RAM and transfers data. After the data transfer, the DTC writes updated
register information back to on-chip RAM.
The pre-storage of register information in on-chip RAM makes it possible to transfer data over any
required number of channels. The transfer mode can be specified as normal, repeat, or block
transfer mode. Setting the CHNE bit in MRB to 1 makes it possible to perform a number of
transfers with a single activation source (chain transfer).
The 24-bit SAR designates the DTC transfer source address, and the 24-bit DAR designates the
transfer destination address. After each transfer, SAR and DAR are independently incremented,
decremented, or left fixed depending on its register information.
Figure 8.5 shows the flowchart of DTC operation.
Rev. 6.00 Sep. 24, 2009 Page 180 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Start
Read DTC vector
Next transfer
Read register information
Data transfer
Write register information
CHNE = 1
Yes
No
Transfer counter = 0
or DISEL = 1
Yes
No
Clear an activation
source flag
Clear DTCER
End
Interrupt exception
handling
*
Note: * For details, see the section related to each peripheral module.
Figure 8.5 Flowchart of DTC Operation
8.5.1
Normal Mode
In normal mode, one operation transfers one byte or one word of data.
From 1 to 65,536 transfers can be specified. Once the specified number of transfers have been
completed, a CPU interrupt can be requested.
Table 8.3 lists the register function in normal mode. Figure 8.6 shows the memory mapping in
normal mode.
Rev. 6.00 Sep. 24, 2009 Page 181 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Table 8.3
Register Function in Normal Mode
Name
Abbreviation
Function
DTC source address register
SAR
Designates transfer source address
DTC destination address register
DAR
Designates transfer destination
address
DTC transfer count register A
CRA
Designates transfer count
DTC transfer count register B
CRB
Not used
SAR
DAR
Transfer
Figure 8.6 Memory Mapping in Normal Mode
8.5.2
Repeat Mode
In repeat mode, one operation transfers one byte or one word of data.
From 1 to 256 transfers can be specified. Once the specified number of transfers have ended, the
initial state of the transfer counter and the address register specified as the repeat area is restored,
and transfer is repeated. In repeat mode, the transfer counter value does not reach H'00, and
therefore CPU interrupts cannot be requested when DISEL = 0.
Table 8.4 lists the register function in repeat mode. Figure 8.7 shows the memory mapping in
repeat mode.
Rev. 6.00 Sep. 24, 2009 Page 182 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Table 8.4
Register Function in Repeat Mode
Name
Abbreviation
Function
DTC source address register
SAR
Designates transfer source address
DTC destination address register
DAR
Designates transfer destination
address
DTC transfer count register AH
CRAH
Holds number of transfers
DTC transfer count register AL
CRAL
Designates transfer count
DTC transfer count register B
CRB
Not used
SAR
or
DAR
DAR
or
SAR
Repeat area
Transfer
Figure 8.7 Memory Mapping in Repeat Mode
8.5.3
Block Transfer Mode
In block transfer mode, one operation transfers one block of data. Either the transfer source or the
transfer destination is designated as a block area.
The block size can be between 1 to 256. When the transfer of one block ends, the initial state of
the block size counter and the address register specified as the block area is restored. The other
address register is then incremented, decremented, or left fixed depending on its register
information.
From 1 to 65,536 transfers can be specified. Once the specified numbers of transfers have been
completed, a CPU interrupt is requested.
Rev. 6.00 Sep. 24, 2009 Page 183 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Table 8.5 lists the register function in block transfer mode. Figure 8.8 shows the memory mapping
in block transfer mode.
Table 8.5
Register Function in Block Transfer Mode
Name
Abbreviation
Function
DTC source address register
SAR
Designates transfer source address
DTC destination address register
DAR
Designates transfer destination
address
DTC transfer count register AH
CRAH
Holds block size
DTC transfer count register AL
CRAL
Designates block size count
DTC transfer count register B
CRB
Designates transfer count
First block
SAR
or
DAR
.
.
.
Block area
Transfer
Nth block
Figure 8.8 Memory Mapping in Block Transfer Mode
Rev. 6.00 Sep. 24, 2009 Page 184 of 928
REJ09B0099-0600
DAR
or
SAR
Section 8 Data Transfer Controller (DTC)
8.5.4
Chain Transfer
Setting the CHNE bit in MRB to 1 enables a number of data transfers to be performed
consecutively in response to a single transfer request. SAR, DAR, CRA, CRB, MRA, and MRB,
which define data transfers, can be set independently.
Figure 8.9 shows the memory map for chain transfer. When activated, the DTC reads the register
information start address stored at the vector address, which corresponds to the activation request,
and then reads the first register information at that start address. After the data transfer, the CHNE
bit will be tested. When it has been set to 1, the DTC reads the next register information located in
a consecutive area and performs the data transfer. These sequences are repeated until the CHNE
bit is cleared to 0.
In the case of transfer with CHNE set to 1, an interrupt request to the CPU is not generated at the
end of the specified number of transfers or by setting of the DISEL bit to 1, and the interrupt
request flag for the activation source is not affected.
Source
Destination
Register information
CHNE = 1
DTC vector
address
Register information
start address
Register information
CHNE = 0
Source
Destination
Figure 8.9 Chain Transfer Operation
Rev. 6.00 Sep. 24, 2009 Page 185 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
8.5.5
Interrupts
An interrupt request is issued to the CPU when the DTC has completed the specified number of
data transfers, or a data transfer for which the DISEL bit was set to 1. In the case of interrupt
activation, the interrupt set as the activation source is generated. These interrupts to the CPU are
subject to CPU mask level and interrupt controller priority level control.
In the case of software activation, a software-activated data transfer end interrupt (SWDTEND) is
generated.
When the DISEL bit is 1 and one data transfer has been completed, or the specified number of
transfers have been completed, the SWDTE bit is held at 1 and an SWDTEND interrupt is
generated after the end of data transfer. The interrupt handling routine will then clear the SWDTE
bit to 0.
When the DTC is activated by software, an SWDTEND interrupt is not generated during a data
transfer wait or during data transfer even if the SWDTE bit is set to 1.
8.5.6
Operation Timing
Figures 8.10 to 8.12 show the DTC operation timing.
φ
DTC activation
request
DTC
request
Vector read
Data transfer
Address
Read Write
Transfer
information read
Transfer
information write
Figure 8.10 DTC Operation Timing (Example in Normal Mode or Repeat Mode)
Rev. 6.00 Sep. 24, 2009 Page 186 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
φ
DTC activation
request
DTC
request
Data transfer
Vector read
Read Write Read Write
Address
Transfer
information read
Transfer
information write
Figure 8.11 DTC Operation Timing (Example in Block Transfer Mode,
with Block Size of 2)
φ
DTC activation
request
DTC
request
Data transfer
Data transfer
Read Write
Read Write
Vector read
Address
Transfer
information read
Transfer
information
write
Transfer
information
read
Transfer
information write
Figure 8.12 DTC Operation Timing (Example of Chain Transfer)
8.5.7
Number of DTC Execution States
Table 8.6 lists execution status for a single DTC data transfer, and table 8.7 lists the number of
states required for each execution status.
Rev. 6.00 Sep. 24, 2009 Page 187 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Table 8.6
DTC Execution Status
Mode
Vector Read
I
Register Information
Read/Write
Data Read
J
K
Data Write
L
Internal
Operations
M
Normal
1
6
1
1
3
Repeat
1
6
1
1
3
Block transfer
1
6
N
N
3
Legend:
N:
Block size (initial setting of CRAH and CRAL)
Table 8.7
Number of States Required for Each Execution Status
Internal I/O Registers
Object to be Accessed
OnChip
RAM
OnChip
ROM
IEB*
Other
than IEB
2
HCAN* and HCAN External Devices
Bus width
32
16
8
16
8
16
8
8
16
16
Access states
1
1
4
5
2
2
2
3
2
3
1
⎯
⎯
⎯
⎯
4
6 + 2m 2
3+m
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Execution Vector read SI
⎯
Status
Register information 1
read/write SJ
1
Byte data read SK
1
1
4
5
2
2
2
3+m
2
3+m
Word data read SK
1
1
⎯
5
4
2
4
6 + 2m 2
3+m
Byte data write SL
1
1
4
5
2
2
2
3+m
2
3+m
Word data write SL
1
1
⎯
5
4
2
4
6 + 2m 2
3+m
Internal operation SM 1
1
1
1
1
1
1
1
1
1
Legend:
m:
The number of wait states for accessing external devices.
Notes: 1. H8S/2552 Group only.
2. H8S/2556 Group only.
The number of execution states is calculated from using the formula below. Note that Σ is the sum
of all transfers activated by one activation source (the number in which the CHNE bit is set to 1,
plus 1).
Number of execution states = I · SI + Σ (J · SJ + K · SK + L · SL) + M · SM
Rev. 6.00 Sep. 24, 2009 Page 188 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
For example, when the DTC vector address is located in on-chip ROM, normal mode is set, and
data is transferred from on-chip ROM to an internal I/O register, the time required for the DTC
operation is 13 states. The time from activation to the end of the data write is 10 states.
8.6
Procedures for Using DTC
8.6.1
Activation by Interrupt
The procedure for using the DTC with interrupt activation is as follows:
1.
2.
3.
4.
5.
Set the MRA, MRB, SAR, DAR, CRA, and CRB register information in on-chip RAM.
Set the start address of the register information in the DTC vector address.
Set the corresponding bit in DTCER to 1.
Set the enable bits for the interrupt sources to be used as the activation sources to 1. The DTC
is activated when an interrupt used as an activation source is generated.
After one data transfer has been completed, or after the specified number of data transfers has
been completed, the DTCE bit is cleared to 0 and a CPU interrupt is requested. If the DTC is
to continue transferring data, set the DTCE bit to 1.
8.6.2
Activation by Software
The procedure for using the DTC with software activation is as follows:
1.
2.
3.
4.
5.
6.
Set the MRA, MRB, SAR, DAR, CRA, and CRB register information in on-chip RAM.
Set the start address of the register information in the DTC vector address.
Check that the SWDTE bit is 0.
Write 1 to SWDTE bit and the vector number to DTVECR.
Check the vector number written to DTVECR.
After one data transfer has been completed, if the DISEL bit is 0 and a CPU interrupt is not
requested, the SWDTE bit is cleared to 0. If the DTC is to continue transferring data, set the
SWDTE bit to 1. When the DISEL bit is 1, or after the specified number of data transfers has
been completed, the SWDTE bit is held at 1 and a CPU interrupt is requested.
Rev. 6.00 Sep. 24, 2009 Page 189 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
8.7
Examples of Use of the DTC
8.7.1
Normal Mode
An example is shown in which the DTC is used to receive 128 bytes of data via the SCI.
1.
2.
3.
4.
5.
6.
MRA sets the source address fixed (SM1 = SM0 = 0), destination address increment (DM1 =
1, DM0 = 0), normal mode (MD1 = MD0 = 0), and byte size (Sz = 0). The DTS bit can be set
to any value. MRB performs one data transfer by one interrupt (CHNE = 0, DISEL = 0). SAR
sets the RDR address in SCI, DAR sets the start address of the RAM area where the data will
be received in, and CRA sets 128 (H'0080). CRB can be set to any value.
Set the start address of the register information in the DTC vector address.
Set the corresponding bit in DTCER to 1.
Set the SCI to the appropriate receive mode. Set the RIE bit in SCR to 1 to enable the
reception complete (RXI) interrupt. Since the generation of a receive error during the SCI
reception operation will disable subsequent reception, the CPU should be enabled to accept
receive error interrupts.
Each time the reception of one byte of data has been completed on the SCI, the RDRF flag in
SSR is set to 1, an RXI interrupt is generated, and the DTC is activated. The receive data is
transferred from RDR to RAM by the DTC. DAR is incremented and CRA is decremented.
The RDRF flag is automatically cleared to 0.
When CRA becomes 0 after the 128 data transfers have been completed, the RDRF flag is
held at 1, the DTCE bit is cleared to 0, and an RXI interrupt request is sent to the CPU. The
interrupt handling routine will perform wrap-up processing.
8.7.2
Software Activation
An example is shown in which the DTC is used to transfer a block of 128 bytes of data by means
of software activation. The transfer source address is H'1000 and the transfer destination address is
H'2000. The vector number is H'60, so the vector address is H'04C0.
1.
2.
MRA sets the source address increment (SM1 = 1, SM0 = 0), destination address increment
(DM1 = 1, DM0 = 0), block transfer mode (MD1 = 1, MD0 = 0), and byte size (Sz = 0). The
DTS bit can be set to any value. MRB performs one block transfer by one interrupt (CHNE =
0). SAR sets the transfer source address (H'1000), DAR sets the transfer destination address
(H'2000), and CRA sets 128 (H'8080). CRB sets 1 (H'0001).
Set the start address of the register information at the DTC vector address (H'04C0).
Rev. 6.00 Sep. 24, 2009 Page 190 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
3.
4.
5.
6.
7.
Check that the SWDTE bit in DTVECR is 0. Check that there is currently no transfer
activated by software.
Write 1 to the SWDTE bit and the vector number (H'60) to DTVECR. The write data is H'E0.
Read DTVECR again and check that it is set to the vector number (H'60). If it is not, this
indicates that the write has failed. This is presumably because an interrupt occurred between
steps 3 and 4 and led to a different software activation. To activate this transfer, go back to
step 3.
If the write was successful, the DTC is activated and a block of 128 bytes of data is
transferred.
After the transfer, an SWDTEND interrupt occurs. The interrupt handling routine should clear
the SWDTE bit to 0 and perform other wrap-up processing.
8.8
Usage Notes
8.8.1
Module Stop Mode Setting
The DTC operation can be disabled or enabled using the module stop control register. The initial
setting is for the DTC operation to be enabled. Register access is disabled by setting module stop
mode. Module stop mode cannot be set during the DTC operation. For details, see section 22,
Power-Down Modes.
8.8.2
On-Chip RAM
The MRA, MRB, SAR, DAR, CRA, and CRB registers are all located in on-chip RAM. When the
DTC is used, the RAME bit in SYSCR should not be cleared to 0.
8.8.3
DTCE Bit Setting
For DTCE bit setting, use bit manipulation instructions such as BSET and BCLR for reading and
writing. When multiple activation sources are to be set at one time, only at the initial setting,
writing data is enabled after executing a dummy read on the relevant register with all the interrupts
being masked.
Rev. 6.00 Sep. 24, 2009 Page 191 of 928
REJ09B0099-0600
Section 8 Data Transfer Controller (DTC)
Rev. 6.00 Sep. 24, 2009 Page 192 of 928
REJ09B0099-0600
Section 9 I/O Ports
Section 9 I/O Ports
Table 9.1 summarizes the port functions. The pins of each port also have other functions such as
input/output or interrupt input pins of on-chip peripheral modules. Each I/O port includes a data
direction register (DDR) that controls input/output, a data register (DR) that stores output data,
and a port register (PORT) used to read the pin states. The input-only ports do not have DDR and
DR registers.
Ports A to E have a built-in input pull-up MOS function and an input pull-up MOS control register
(PCR) to control the on/off state of the input pull-up MOS.
Ports 3 and A include an open-drain control register (ODR) that controls the on/off state of the
output buffer PMOS.
All the I/O ports can drive a single TTL load and a 30 pF capacitive load.
The P34 and P35 pins on port 3 are NMOS push pull outputs.
The IRQ pin is a schmitt trigger input.
Rev. 6.00 Sep. 24, 2009 Page 193 of 928
REJ09B0099-0600
Section 9 I/O Ports
Table 9.1
Port
Port Functions
Description
Port 1 General I/O port
also functioning
as TPU I/O pins
and interrupt
input pins
Mode 6
P17/TIOCB2/TCLKD
P16/TIOCA2/IRQ1
P15/TIOCB1/TCLKC
Mode 7
Input/Output and
Output Type
Schmitt trigger
input
(IRQ1, IRQ0)
P14/TIOCA1/IRQ0
P13/TIOCD0/TCLKB
P12/TIOCC0/TCLKA
P11/TIOCB0
P10/TIOCA0
Port 2 General I/O port P27/TIOCB5
also functioning P26/TIOCA5
as TPU I/O pins
P25/TIOCB4
P24/TIOCA4
P23/TIOCD3
P22/TIOCC3
P21/TIOCB3
P20/TIOCA3
Port 3 General I/O port
also functioning
2
as I C bus
interface 2 I/O
pins, SCI I/O
pins, and
interrupt input
pins
P37/TxD4
P36/RxD4
P35/SCK1/SCK4/SCL0/IRQ5
P34/RxD1/SDA0
P33/TxD1/SCL1
P32/SCK0/SDA1/IRQ4
P31/RxD0
P30/TxD0
Rev. 6.00 Sep. 24, 2009 Page 194 of 928
REJ09B0099-0600
Open drain output
enabled
Schmitt trigger
input
(IRQ5, IRQ4)
NMOS push-pull
output (P35, P34,
SCK1, SCK4)
Section 9 I/O Ports
Port
Description
Mode 6
Port 4
General input
port also
functioning as
A/D converter
analog input
pins
P47/AN7
Mode 7
Input/Output and
Output Type
P46/AN6
P45/AN5
P44/AN4
P43/AN3
P42/AN2
P41/AN1
P40/AN0
Port 5
General I/O port P52/SCK2
also functioning P51/RxD2
as SCI I/O pins
P50/TxD2
Port 7
General I/O port
also functioning
as SCI I/O pins,
TMR I/O pins,
bus control
output pins, and
manual reset
input pins
Port 9
General input
port also
functioning as
A/D converter
analog input
and D/A
converter
analog output
pins
P77/TxD3
P76/RxD3
P75/TMO3/SCK3
P74/TMO2/MRES
P73/TMO1/CS7
P73/TMO1
P72/TMO0/CS6
P72/TMO0
P71/TMRI23/TMCI23/CS5
P71/TMRI23/TMCI23
P70/TMRI01/TMCI01/CS4
P70/TMRI0/TMCI01
P97/AN15/DA1
P96/AN14/DA0
P95/AN13
P94/AN12
P93/AN11
P92/AN10
P91/AN9
P90/AN8
Rev. 6.00 Sep. 24, 2009 Page 195 of 928
REJ09B0099-0600
Section 9 I/O Ports
Port
Description
Mode 6
Mode 7
Port A General I/O port PA7/A23
also functioning PA6/A22
as address
PA5/A21
output pins
PA4/A20
PA7
PA3/A19
PA3
PA2/A18
PA2
PA1/A17
PA1
PA0/A16
PA0
Port B General I/O port PB7/A15
also functioning PB6/A14
as address
PB5/A13
output pins
PB4/A12
PB7
PB3/A11
PB3
PB2/A10
PB2
PB1/A9
PB1
PB0/A8
PB0
Port C General I/O port PC7/A7
also functioning PC6/A6
as address
PC5/A5
output pins
PC4/A4
PC7
PC3/A3
PC3
PC2/A2
PC2
PC1/A1
PC1
PC0/A0
PC0
PA6
PA5
PA4
PB6
Open drain output
enabled
Built-in input pullup MOS
PB4
PC6
Built-in input pullup MOS
PC5
PC4
PD7
D12
PD4
D11
PD3
D10
PD2
D9
PD1
D8
PD0
REJ09B0099-0600
Built-in input pullup MOS
PB5
Port D General I/O port D15
also functioning D14
as data I/O pins
D13
Rev. 6.00 Sep. 24, 2009 Page 196 of 928
Input/Output and
Output Type
PD6
PD5
Built-in input pullup MOS
Section 9 I/O Ports
Port
Description
Mode 6
Input/Output and
Output Type
Mode 7
Port E General I/O port PE7/D7
also functioning PE6/D6
as data I/O pins
PE5/D5
PE7
PE4/D4
PE4
PE3/D3
PE3
PE2/D2
PE2
PE1/D1
PE1
PE0/D0
PE0
PF7/φ
PF7/φ
AS
PF6
RD
PF5
HWR
PF4
PF3/LWR/ADTRG/IRQ3
PF3/ADTRG/IRQ3
PF2/WAIT
PF2
PF1/BACK/BUZZ
PF1/BUZZ
PF0/BREQ/IRQ2
PF0/IRQ2
PG4/CS0
PG4
Port F
General I/O port
also functioning
as system clock
output pins,
interrupt input
pins, bus control
I/O pins, A/D
converter input
pins, and BUZZ
output pins
Port G General I/O port
also functioning
as bus control
output pins,
interrupt input
pins, and IEB
1
I/O pins*
Built-in input pullup MOS
PE6
PE5
Schmitt trigger
input
(IRQ3, IRQ2)
1
2
PG3/Rx* *
1
PG2/Tx* /CS2*
2
PG2/Tx* *
PG1/CS3/IRQ7
PG1/IRQ7
PG0/IRQ6
PG0/IRQ6
PG3/Rx* /CS1*
1
2
1
2
Schmitt trigger
input
(IRQ7, IRQ6)
Port H General I/O port PH7
PH6
PH5
PH4
PH3
PH2
PH1
PH0
Rev. 6.00 Sep. 24, 2009 Page 197 of 928
REJ09B0099-0600
Section 9 I/O Ports
Port
Description
Mode 6
Port J
General I/O port PJ7
Mode 7
Input/Output and
Output Type
PJ6
PJ5
PJ4
PJ3
PJ2
PJ1
PJ0
Notes: 1. The Rx and Tx of IEB are valid only in the H8S/2552 Group.
2. The PG3/Rx/CS1 and PG2/Tx/CS2 pins are not available in the H8S/2556 Group.
Rev. 6.00 Sep. 24, 2009 Page 198 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.1
Port 1
Port 1 is an 8-bit I/O port and has the following registers.
• Port 1 data direction register (P1DDR)
• Port 1 data register (P1DR)
• Port 1 register (PORT1)
9.1.1
Port 1 Data Direction Register (P1DDR)
P1DDR specifies input or output of the port 1 pins using the individual bits. P1DDR cannot be
read; if it is, the read value is undefined. Since this register is a write-only register, bitmanipulation instructions should not be used when writing. See section 2.9.4, Access Method for
Registers with Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
P17DDR
0
W
6
P16DDR
0
W
5
P15DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port 1 pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
4
P14DDR
0
W
3
P13DDR
0
W
2
P12DDR
0
W
1
P11DDR
0
W
0
P10DDR
0
W
Rev. 6.00 Sep. 24, 2009 Page 199 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.1.2
Port 1 Data Register (P1DR)
P1DR stores output data for port 1 pins.
Bit
Bit Name
Initial Value
R/W
Description
7
P17DR
0
R/W
6
P16DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
P15DR
0
R/W
4
P14DR
0
R/W
3
P13DR
0
R/W
2
P12DR
0
R/W
1
P11DR
0
R/W
0
P10DR
0
R/W
9.1.3
Port 1 Register (PORT1)
PORT1 shows port 1 pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
P17
⎯*
R
6
P16
⎯*
R
5
P15
⎯*
R
If a port 1 read is performed while P1DDR bits are
set to 1, the P1DR values are read. If a port 1 read
is performed while P1DDR bits are cleared to 0, the
pin states are read.
4
P14
⎯*
R
3
P13
⎯*
R
2
P12
⎯*
R
1
P11
⎯*
R
0
P10
⎯*
R
Note:
*
9.1.4
Determined by the states of pins P17 to P10.
Pin Functions
Port 1 pins also function as TPU I/O pins and interrupt input pins. Port 1 pin functions are shown
below.
Rev. 6.00 Sep. 24, 2009 Page 200 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P17/TIOCB2/TCLKD
The pin function is switched as shown below according to the combination of the TPU channel
2 setting, the TPSC2 to TPSC0 bits in TCR_0 or TCR_5, and the P17DDR bit.
TPU Channel 2 Setting*1
P17DDR
Pin function
Output
Input or Initial Value
⎯
0
1
TIOCB2 output
P17 input
P17 output
TIOCB2 input*2
TCLKD input*3
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCB2 input when TPU channel 2 timer operating mode is set to
normal operation or phase counting mode and IOB3 in TIOR_2 is set to 1.
3. This pin functions as TCLKD input when TPSC2 to TPSC0 in TCR_0 or TCR_5 are set
to 111. This pin also functions as TCLKD input when channel 2 or 4 is set to phase
counting mode.
• P16/TIOCA2/IRQ1
The pin function is switched as shown below according to the combination of the TPU channel
2 setting and the P16DDR bit.
TPU Channel 2 Setting*1
P16DDR
Pin function
Output
Input or Initial Value
⎯
0
1
TIOCA2 output
P16 input
P16 output
TIOCA2 input*2
IRQ1 input*3
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCA2 input when TPU channel 2 timer operating mode is set to
normal operation or phase counting mode and IOA3 in TIOR_2 is set to 1.
3. When this pin is used as an external interrupt pin, do not specify other functions.
Rev. 6.00 Sep. 24, 2009 Page 201 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P15/TIOCB1/TCLKC
The pin function is switched as shown below according to the combination of the TPU channel
1 setting, the TPSC2 to TPSC0 bits in TCR_0, TCR_2, TCR_4, or TCR_5, and the P15DDR
bit.
1
Output
TPU Channel 1 Setting*
⎯
0
1
TIOCB1 output
P15 input
P15 output
P15DDR
Pin function
Input or Initial Value
TIOCB1 input*
1
2
TCLKC input*
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCB1 input when TPU channel 1 timer operating mode is set to
normal operation or phase counting mode and IOB3 to IOB0 in TIOR_1 are set to 10xx.
3. This pin functions as TCLKC input when TPSC2 to TPSC0 in TCR_0 or TCR_2 are set
to 110, or when TPSC2 to TPSC0 in TCR_4 or TCR_5 are set to 101. This pin also
functions as TCLKC input when channel 2 or 4 is set to phase counting mode.
• P14/TIOCA1/IRQ0
The pin function is switched as shown below according to the combination of the TPU channel
1 setting and the P14DDR bit.
1
Output
TPU Channel 1 Setting*
⎯
0
1
TIOCA1 output
P14 input
P14 output
P14DDR
Pin function
Input or Initial Value
TIOCA1 input*
IRQ0 input*
2
3
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCA1 input when TPU channel 1 timer operating mode is set to
normal operation or phase counting mode and IOA3 to IOA0 in TIOR_1 are set to 10xx.
3. When this pin is used as an external interrupt pin, do not specify other functions.
Rev. 6.00 Sep. 24, 2009 Page 202 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P13/TIOCD0/TCLKB
The pin function is switched as shown below according to the combination of the TPU channel
0 setting, the TPSC2 to TPSC0 bits in TCR_0, TCR_1, or TCR_2, and the P13DDR bit.
TPU Channel 0 Setting*1
P13DDR
Pin function
Output
Input or Initial Value
⎯
0
1
TIOCD0 output
P13 input
P13 output
TIOCD0 input*2
TCLKB input*3
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCD0 input when TPU channel 0 timer operating mode is set to
normal operation and IOD3 to IOD0 in TIORL_0 are set to 10xx.
3. This pin functions as TCLKB input when TPSC2 to TPSC0 are set to 101 in any of
TCR_0, TCR_1, and TCR_2. This pin also functions as TCLKB input when channel 1 or
5 is set to phase counting mode.
• P12/TIOCC0/TCLKA
The pin function is switched as shown below according to the combination of the TPU channel
0 setting, the TPSC2 to TPSC0 bits in TCR_0, TCR_1, TCR_2, TCR_3, TCR_4, or TCR_5,
and the P12DDR bit.
1
TPU Channel 0 Setting*
P12DDR
Pin function
Output
Input or Initial Value
⎯
0
1
TIOCC0 output
P12 input
P12 output
TIOCC0 input*
2
3
TCLKA input*
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCC0 input when TPU channel 0 timer operating mode is set to
normal operation and IOC3 to IOC0 in TIORL_0 are set to 10xx.
3. This pin functions as TCLKA input when TPSC2 to TPSC0 are set to 100 in any of
TCR_0, TCR_1, TCR_2, TCR_3, TCR_4, and TCR_5. This pin also functions as
TCLKA input when channel 1 or 5 is set to phase counting mode.
Rev. 6.00 Sep. 24, 2009 Page 203 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P11/TIOCB0
The pin function is switched as shown below according to the combination of the TPU channel
0 setting and the P11DDR bit.
TPU Channel 0 Setting*1
Output
⎯
0
1
TIOCB0 output
P11 input
P11 output
P11DDR
Pin function
Input or Initial Value
TIOCB0 input*2
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCB0 input when TPU channel 0 timer operating mode is set to
normal operation and IOB3 to IOB0 in TIORH_0 are set to 10xx.
• P10/TIOCA0
The pin function is switched as shown below according to the combination of the TPU channel
0 setting and the P10DDR bit.
TPU Channel 0 Setting*1
Output
Pin function
Input or Initial Value
⎯
0
1
TIOCA0 output
P10 input
P10 output
P10DDR
TIOCA0 input*2
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCA0 input when TPU channel 0 timer operating mode is set to
normal operation and IOA3 to IOA0 in TIORH_0 are set to 10xx.
Rev. 6.00 Sep. 24, 2009 Page 204 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.2
Port 2
Port 2 is an 8-bit I/O port and has the following registers.
• Port 2 data direction register (P2DDR)
• Port 2 data register (P2DR)
• Port 2 register (PORT2)
9.2.1
Port 2 Data Direction Register (P2DDR)
P2DDR specifies input or output of the port 2 pins using the individual bits. P2DDR cannot be
read; if it is, the read value is undefined. Since this register is a write-only register, bitmanipulation instructions should not be used when writing. See section 2.9.4, Access Method for
Registers with Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
P27DDR
0
W
6
P26DDR
0
W
5
P25DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port 2 pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
4
P24DDR
0
W
3
P23DDR
0
W
2
P22DDR
0
W
1
P21DDR
0
W
0
P20DDR
0
W
Rev. 6.00 Sep. 24, 2009 Page 205 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.2.2
Port 2 Data Register (P2DR)
P2DR stores output data for port 2 pins.
Bit
Bit Name
Initial Value
R/W
Description
7
P27DR
0
R/W
6
P26DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
P25DR
0
R/W
4
P24DR
0
R/W
3
P23DR
0
R/W
2
P22DR
0
R/W
1
P21DR
0
R/W
0
P20DR
0
R/W
9.2.3
Port 2 Register (PORT2)
PORT2 shows port 2 pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
P27
⎯*
R
6
P26
⎯*
R
5
P25
⎯*
R
If a port 2 read is performed while P2DDR bits are
set to 1, the P2DR values are read. If a port 2 read is
performed while P2DDR bits are cleared to 0, the pin
states are read.
4
P24
⎯*
R
3
P23
⎯*
R
2
P22
⎯*
R
1
P21
⎯*
R
0
P20
⎯*
R
Note:
*
Determined by the states of pins P27 to P20.
Rev. 6.00 Sep. 24, 2009 Page 206 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.2.4
Pin Functions
Port 2 pins also function as TPU I/O pins. Port 2 pin functions are shown below.
• P27/TIOCB5
The pin function is switched as shown below according to the combination of the TPU channel
5 setting and the P27DDR bit.
TPU Channel 5 Setting*1
P27DDR
Pin function
Output
Input or Initial Value
⎯
0
1
TIOCB5 output
P27 input
P27 output
TIOCB5 input*2
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCB5 input when TPU channel 5 timer operating mode is set to
normal operation or phase counting mode and IOB3 in TIOR_5 is set to 1.
• P26/TIOCA5
The pin function is switched as shown below according to the combination of the TPU channel
5 setting and the P26DDR bit.
TPU Channel 5 Setting*1
P26DDR
Pin function
Output
Input or Initial Value
⎯
0
1
TIOCA5 output
P26 input
P26 output
TIOCA5 input*2
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCA5 input when TPU channel 5 timer operating mode is set to
normal operation or phase counting mode and IOA3 in TIOR_5 is set to 1.
Rev. 6.00 Sep. 24, 2009 Page 207 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P25/TIOCB4
The pin function is switched as shown below according to the combination of the TPU channel
4 setting and the P25DDR bit.
TPU Channel 4 Setting*1
Output
⎯
0
1
TIOCB4 output
P25 input
P25 output
P25DDR
Pin function
Input or Initial Value
TIOCB4 input*1
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCB4 input when TPU channel 4 timer operating mode is set to
normal operation or phase counting mode and IOB3 to IOB0 in TIOR_4 are set to 10xx.
• P24/TIOCA4
The pin function is switched as shown below according to the combination of the TPU channel
4 setting and the P24DDR bit.
TPU Channel 4 Setting*1
Output
Pin function
Input or Initial Value
⎯
0
1
TIOCA4 output
P24 input
P24 output
P24DDR
TIOCA4 input*2
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCA4 input when TPU channel 4 timer operating mode is set to
normal operation or phase counting mode and IOA3 to IOA0 in TIOR_4 are set to 10xx.
• P23/TIOCD3
The pin function is switched as shown below according to the combination of the TPU channel
3 setting and the P23DDR bit.
1
Output
TPU Channel 3 Setting*
⎯
0
1
TIOCD3 output
P23 input
P23 output
P23DDR
Pin function
Input or Initial Value
TIOCD3 input*
2
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCD3 input when TPU channel 3 timer operating mode is set to
normal operation and IOD3 to IOD0 in TIORL_3 are set to 10xx.
Rev. 6.00 Sep. 24, 2009 Page 208 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P22/TIOCC3
The pin function is switched as shown below according to the combination of the TPU channel
3 setting and the P22DDR bit.
TPU Channel 3 Setting*1
P22DDR
Pin function
Output
Input or Initial Value
⎯
0
1
TIOCC3 output
P22 input
P22 output
TIOCC3 input*2
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCC3 input when TPU channel 3 timer operating mode is set to
normal operation and IOC3 to IOC0 in TIORL_3 are set to 10xx.
• P21/TIOCB3
The pin function is switched as shown below according to the combination of the TPU channel
3 setting and the P21DDR bit.
TPU Channel 3 Setting*1
P21DDR
Pin function
Output
Input or Initial Value
⎯
0
1
TIOCB3 output
P21 input
P21 output
TIOCB3 input*2
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCB3 input when TPU channel 3 timer operating mode is set to
normal operation and IOB3 to IOB0 in TIORH_3 are set to 10xx.
• P20/TIOCA3
The pin function is switched as shown below according to the combination of the TPU channel
3 setting and the P20DDR bit.
1
TPU Channel 3 Setting*
P20DDR
Pin function
Output
Input or Initial Value
⎯
0
1
TIOCA3 output
P20 input
P20 output
TIOCA3 input*
2
Notes: 1. For the setting of the TPU channel, see section 10, 16-Bit Timer Pulse Unit (TPU).
2. This pin functions as TIOCA3 input when TPU channel 3 timer operating mode is set to
normal operation and IOA3 to IOA0 in TIORH_3 are set to 10xx.
Rev. 6.00 Sep. 24, 2009 Page 209 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.3
Port 3
Port 3 is an 8-bit I/O port and has the following registers.
The P34, P35, SCK1, and SCK4 pins of port 3 are NMOS push-pull outputs.
•
•
•
•
Port 3 data direction register (P3DDR)
Port 3 data register (P3DR)
Port 3 register (PORT3)
Port 3 open drain control register (P3ODR)
9.3.1
Port 3 Data Direction Register (P3DDR)
P3DDR specifies input or output of the port 3 pins using the individual bits. P3DDR cannot be
read; if it is, the read value is undefined. Since this register is a write-only register, bitmanipulation instructions should not be used when writing. See section 2.9.4, Access Method for
Registers with Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
P37DDR
0
W
6
P36DDR
0
W
5
P35DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port 3 pin an output port. Clearing this bit to 0 makes
the pin an input port.
4
P34DDR
0
W
3
P33DDR
0
W
2
P32DDR
0
W
1
P31DDR
0
W
0
P30DDR
0
W
Rev. 6.00 Sep. 24, 2009 Page 210 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.3.2
Port 3 Data Register (P3DR)
P3DR stores output data for port 3 pins.
Bit
Bit Name
Initial Value
R/W
Description
7
P37DR
0
R/W
6
P36DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
P35DR
0
R/W
4
P34DR
0
R/W
3
P33DR
0
R/W
2
P32DR
0
R/W
1
P31DR
0
R/W
0
P30DR
0
R/W
9.3.3
Port 3 Register (PORT3)
PORT3 shows port 3 pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
P37
⎯*
R
6
P36
⎯*
R
5
P35
⎯*
R
If a port 3 read is performed while P3DDR bits are
set to 1, the P3DR values are read. If a port 3 read is
performed while P3DDR bits are cleared to 0, the pin
states are read.
4
P34
⎯*
R
3
P33
⎯*
R
2
P32
⎯*
R
1
P31
⎯*
R
0
P30
⎯*
R
Note:
*
Determined by the states of pins P37 to P30.
Rev. 6.00 Sep. 24, 2009 Page 211 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.3.4
Port 3 Open Drain Control Register (P3ODR)
P3ODR controls on/off state of the PMOS for port 3 pins.
Bit
Bit Name
Initial Value
R/W
Description
7
P37ODR
0
R/W
6
P36ODR
0
R/W
5
P35ODR
0
R/W
4
P34ODR
0
R/W
3
P33ODR
0
R/W
2
P32ODR
0
R/W
1
P31ODR
0
R/W
0
P30ODR
0
R/W
When each of P37ODR, P36ODR, and P33ODR to
P30ODR bits is set to 1, the corresponding pins P37,
P36, and P33 to P30 function as NMOS open drain
outputs. When cleared to 0, the corresponding pins
function as CMOS outputs.
When each of P35ODR and P34ODR bits is set to 1,
the corresponding pins P35 and P34 function as
NMOS open drain outputs. When cleared to 0, the
corresponding pins function as NMOS push pull
outputs.
9.3.5
Pin Functions
The port 3 pins also function as SCI I/O pins, I2C bus interface 2 I/O pins, and interrupt input
pins.
As shown in figure 9.1, when the pin P34, P35, SCK1, SCK4, SCL0, or SDA0 type open drain
output is used, a bus line is not affected even if the power supply for this LSI fails. Use (a) type
open drain output when using a bus line having a state in which the power is not supplied to this
LSI.
NMOS off
PMOS Off
1
0
Output
Input
Output
Input
(a) Open drain output type for
P34, P35, SCK1, SCK4,
SCL0, and SDA0 pins
(b) Open drain output type for
P37, P36, P33 to P30,
SCL1, SDA1, and port A pins
Figure 9.1 Types of Open Drain Outputs
Rev. 6.00 Sep. 24, 2009 Page 212 of 928
REJ09B0099-0600
Section 9 I/O Ports
The NMOS push-pull outputs of the P34, P35, SCK1 and SCK4 pins do not reach the voltage of
P2Vcc, even when the pins are specified so that they are driven high and regardless of the load.
To output the voltage of P2Vcc, a pull-up resistor must be externally connected.
Notes: 1. When a pull-up resistor is externally connected, signals take longer to rise and fall.
When the input signals take a long time to rise and fall, connect an input circuit that
has a noise reduction function, such as a Schmitt trigger circuit.
2. For high-speed operation, use an external circuit such as a level shifter.
3. For output characteristics, see the entries for high output voltage for pins P34 and P35
in table 24.2, DC Characteristics (1). The value of the pull-up resistor should satisfy
the specification in table 24.3, Permissible Output Currents.
• P37/TxD4
The pin function is switched as shown below according to the combination of the TE bit in
SCR_4 of SCI_4 and the P37DDR bit.
TE
0
P37DDR
Pin function
Note:
*
1
0
1
⎯
P37 input
P37 output*
TxD4 output*
When P37ODR is set to 1, this pin functions as NMOS open drain output.
• P36/RxD4
The pin function is switched as shown below according to the combination of the RE bit in
SCR_4 of SCI_4 and the P36DDR bit.
RE
0
P36DDR
Pin function
Note:
*
1
0
1
⎯
P36 input
P36 output*
RxD4 input
When P36ODR is set to 1, this pin functions as NMOS open drain output.
Rev. 6.00 Sep. 24, 2009 Page 213 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P35/SCK1/SCK4/SCL0/IRQ5
The pin function is switched as shown below according to the combination of the ICE bit in
ICCR1_0 of IIC2_0, the C/A bit in SMR_1 of SCI_1 or in SMR_4 of SCI_4, the CKE0 and
CKE1 bits in SCR_1 or SCR_4, and the P35DDR bit. The SCK1 and SCK4 are not set to
outputs simultaneously.
ICE
0
CKE1
1
1
⎯
1
⎯
⎯
1
⎯
⎯
⎯
⎯
⎯
⎯
⎯
SCK1/
SCK4
output*1
SCK1/
SCK4
output*1
SCK1/SCK4
input
SCL0 input/
output
0
C/A
0
CKE0
0
P35DDR
0
Pin function
1
P35 input
1
P35 output*
IRQ5 input*
2
Notes: 1. When P35ODR is set to 1, this pin functions as NMOS open drain output. When cleared
to 0, this pin functions as NMOS push pull output.
2. When this pin is used as an external interrupt pin, do not specify other functions.
• P34/RxD1/SDA0
The pin function is switched as shown below according to the combination of the ICE bit in
ICCR1_0 of IIC2_0, the RE bit in SCR_1 of SCI_1, and the P34DDR bit.
ICE
0
1
⎯
0
1
⎯
⎯
P34 input
P34 output*
RxD1 input
SDA0 input/output
RE
0
P34DDR
Pin function
Note:
*
1
When P34ODR is set to 1, this pin functions as NMOS open drain output. When cleared
to 0, this pin functions as NMOS push pull output.
Rev. 6.00 Sep. 24, 2009 Page 214 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P33/TxD1/SCL1
The pin function is switched as shown below according to the combination of the ICE bit in
ICCR1_1 of IIC2_1, the TE bit in SCR_1 of SCI_1, and the P33DDR bit.
ICE
0
TE
0
Pin function
*
1
⎯
0
1
⎯
⎯
P33 input
P33 output*
TxD1 output*
SCL1 input/output
P33DDR
Note:
1
When P33ODR is set to 1, this pin functions as NMOS open drain output.
• P32/SCK0/SDA1/IRQ4
The pin function is switched as shown below according to the combination of the ICE bit in
ICCR1_1 of IIC2_1, the C/A bit in SMR_0 of SCI_0, the CKE0 and CKE1 bits in SCR_0, and
the P32DDR bit.
ICE
0
CKE1
1
0
C/A
0
P32DDR
Pin function
⎯
1
⎯
⎯
1
⎯
⎯
⎯
0
CKE0
1
0
1
⎯
⎯
⎯
⎯
P32 input
P32
output*1
SCK0
output*1
SCK0
output*1
SCK0 input
SDA1 input/
output
IRQ4 Input*2
Notes: 1. When P32ODR is set to 1, this pin functions as NMOS open drain output.
2. When this pin is used as an external interrupt pin, do not specify other functions.
• P31/RxD0
The pin function is switched as shown below according to the combination of the RE bit in
SCR_0 of SCI_0 and the P31DDR bit.
RE
0
P31DDR
Pin function
Note:
*
1
0
1
⎯
P31 input
P31 output*
RxD0 input
When P31ODR is set to 1, this pin functions as NMOS open drain output.
Rev. 6.00 Sep. 24, 2009 Page 215 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P30/TxD0
The pin function is switched as shown below according to the combination of the TE bit in
SCR_0 of SCI_0 and the P30DDR bit.
TE
0
0
1
⎯
P30 input
P30 output*
TxD0 output*
P30DDR
Pin function
Note:
*
9.4
1
When P30ODR is set to 1, this pin functions as NMOS open drain output.
Port 4
Port 4 is an 8-bit input-only port and has the following register.
• Port 4 register (PORT4)
9.4.1
Port 4 Register (PORT4)
PORT4 shows port 4 pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
P47
⎯*
R
6
P46
⎯*
R
The pin states are always read when a port 4 read is
performed.
5
P45
⎯*
R
4
P44
⎯*
R
3
P43
⎯*
R
2
P42
⎯*
R
1
P41
⎯*
R
0
P40
⎯*
R
Note:
*
9.4.2
Determined by the states of pins P47 to P40.
Pin Functions
Port 4 pins also function as A/D converter analog input pins (AN0 to AN7).
Rev. 6.00 Sep. 24, 2009 Page 216 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.5
Port 5
Port 5 is a 3-bit I/O port and has the following registers.
• Port 5 data direction register (P5DDR)
• Port 5 data register (P5DR)
• Port 5 register (PORT5)
9.5.1
Port 5 Data Direction Register (P5DDR)
P5DDR specifies input or output of the port 5 pins using the individual bits. P5DDR cannot be
read; if it is, the read value is undefined. Since this register is a write-only register, bitmanipulation instructions should not be used when writing. See section 2.9.4, Access Method for
Registers with Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7 to 3
⎯
Undefined
⎯
Reserved
These bits are always read as undefined value and
cannot be modified.
2
P52DDR
0
W
1
P51DDR
0
W
0
P50DDR
0
W
9.5.2
Port 5 Data Register (P5DR)
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port 5 pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
P5DR stores output data for port 5 pins.
Bit
Bit Name
Initial Value
R/W
Description
7 to 3
⎯
Undefined
⎯
Reserved
These bits are always read as undefined value and
cannot be modified.
2
P52DR
0
R/W
1
P51DR
0
R/W
0
P50DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
Rev. 6.00 Sep. 24, 2009 Page 217 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.5.3
Port 5 Register (PORT5)
PORT5 shows port 5 pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7 to 3
⎯
Undefined
⎯
Reserved
These bits are always read as undefined value and
cannot be modified.
2
P52
⎯*
R
1
P51
⎯*
R
0
P50
⎯*
R
Note:
*
9.5.4
If a port 5 read is performed while P5DDR bits are
set to 1, the P5DR values are read. If a port 5 read
is performed while P5DDR bits are cleared to 0, the
pin states are read.
Determined by the states of pins P52 to P50.
Pin Functions
Port 5 pins also function as SCI I/O pins. Port 5 pin functions are shown below.
• P52/SCK2
The pin function is switched as shown below according to the combination of the C/A bit in
SMR_2 of SCI_2, the CKE0 and CKE1 bits in SCR_2, and the P52DDR bit.
CKE1
0
C/A
Pin function
1
⎯
1
⎯
⎯
0
CKE0
P52DDR
1
0
0
1
⎯
⎯
⎯
P52 input
P52 output
SCK2 output
SCK2 output
SCK2 input
• P51/RxD2
The pin function is switched as shown below according to the combination of the RE bit in
SCR_2 of SCI_2 and the P51DDR bit.
RE
P51DDR
Pin function
0
0
1
⎯
P51 input
P51 output
RxD2 input
Rev. 6.00 Sep. 24, 2009 Page 218 of 928
REJ09B0099-0600
1
Section 9 I/O Ports
• P50/ TxD2
The pin function is switched as shown below according to the combination of the TE bit in
SCR_2 of SCI_2 and the P50DDR bit.
TE
0
P50DDR
Pin function
9.6
1
0
1
⎯
P50 input
P50 output
TxD2 output
Port 7
Port 7 is an 8-bit I/O port and has the following registers.
• Port 7 data direction register (P7DDR)
• Port 7 data register (P7DR)
• Port 7 register (PORT7)
9.6.1
Port 7 Data Direction Register (P7DDR)
P7DDR specifies input or output of the port 7 pins using the individual bits. P7DDR cannot be
read; if it is, the read value is undefined. Since this register is a write-only register, bitmanipulation instructions should not be used when writing. See section 2.9.4, Access Method for
Registers with Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
P77DDR
0
W
6
P76DDR
0
W
5
P75DDR
0
W
When a pin is specified as a general purpose I/O port,
setting this bit to 1 makes the corresponding port 7 pin
an output pin. Clearing this bit to 0 makes the pin an
input pin.
4
P74DDR
0
W
3
P73DDR
0
W
2
P72DDR
0
W
1
P71DDR
0
W
0
P70DDR
0
W
Rev. 6.00 Sep. 24, 2009 Page 219 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.6.2
Port 7 Data Register (P7DR)
P7DR stores output data for port 7 pins.
Bit
Bit Name
Initial Value
R/W
Description
7
P77DR
0
R/W
6
P76DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
P75DR
0
R/W
4
P74DR
0
R/W
3
P73DR
0
R/W
2
P72DR
0
R/W
1
P71DR
0
R/W
0
P70DR
0
R/W
9.6.3
Port 7 Register (PORT7)
PORT7 shows port 7 pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
P77
⎯*
R
6
P76
⎯*
R
5
P75
⎯*
R
If a port 7 read is performed while P7DDR bits are
set to 1, the P7DR values are read. If a port 7 read is
performed while P7DDR bits are cleared to 0, the pin
states are read.
4
P74
⎯*
R
3
P73
⎯*
R
2
P72
⎯*
R
1
P71
⎯*
R
0
P70
⎯*
R
Note:
*
Determined by the states of pins P77 to P70.
Rev. 6.00 Sep. 24, 2009 Page 220 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.6.4
Pin Functions
Port 7 pins also function as TMR I/O pins, bus control output pins, SCI I/O pins, and manual reset
input pins. Port 7 pin functions are shown below.
• P77/TxD3
The pin function is switched as shown below according to the combination of the TE bit in
SCR_3 of SCI_3 and the P77DDR bit.
TE
0
0
1
⎯
P77 input
P77 output
TxD3 output
P77DDR
Pin function
1
• P76/RxD3
The pin function is switched as shown below according to the combination of the RE bit in
SCR_3 of SCI_3 and the P76DDR bit.
RE
0
0
1
⎯
P76 input
P76 output
RxD3 input
P76DDR
Pin function
1
• P75/TMO3/SCK3
The pin function is switched as shown below according to the combination of the OS3 to OS0
bits in TCSR_3 of TMR_3, the CKE1 and CKE0 bits in SCR_3 of SCI_3, the C/A bit in
SMR_3, and the P75DDR bit.
OS3 to OS0
All bits are 0
CKE1
⎯
⎯
⎯
1
⎯
⎯
⎯
⎯
⎯
⎯
⎯
0
CKE0
Pin function
1
1
0
C/A
P75DDR
Any bit is 1
0
0
P75 input
1
P75 output SCK3 output SCK3 output SCK3 input TMO3 output
Rev. 6.00 Sep. 24, 2009 Page 221 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P74/TMO2/MRES
The pin function is switched as shown below according to the combination of the OS3 to OS0
bits in TCSR_2 of TMR_2, the MRESE bit in SYSCR, and the P74DDR bit.
MRESE
0
OS3 to OS0
All bits are 0
Any bit is 1
⎯
0
1
⎯
0
P74 input
P74 output
TMO2 output
MRES input
P74DDR
Pin function
1
• P73/TMO1/CS7
The pin function is switched as shown below according to the combination of the operating
mode, the OS3 to OS0 bits in TCSR_1 of TMR_1, and the P73DDR bit.
Operating mode
Mode 6
OS3 to OS0
P73DDR
Pin function
All bits are 0
Mode 7
Any bit is 1
0
1
⎯
P73 input
CS7 output
TMO1
output
All bits are 0
0
1
Any bit is 1
⎯
P73 input P73 output TMO1 output
• P72/TMO0/CS6
The pin function is switched as shown below according to the combination of the operating
mode, the OS3 to OS0 bits in TCSR_0 of TMR_0, and the P72DDR bit.
Operating mode
Mode 6
OS3 to OS0
P72DDR
Pin function
All bits are 0
Any bit is 1
0
1
⎯
P72 input
CS6 output
TMO0
output
Rev. 6.00 Sep. 24, 2009 Page 222 of 928
REJ09B0099-0600
Mode 7
All bits are 0
0
1
Any bit is 1
⎯
P72 input P72 output TMO0 output
Section 9 I/O Ports
• P71/TMRI23/TMCI23/CS5
The pin function is switched as shown below according to the combination of the operating
mode and the P71DDR bit.
Operating mode
P71DDR
Pin function
Mode 6
Mode 7
0
1
0
1
P71 input
CS5 output
P71 input
P71 output
TMRI23/TMCI23 input
• P70/TMRI01/TMCI01/CS4
The pin function is switched as shown below according to the combination of the operating
mode and the P70DDR bit.
Operating mode
P70DDR
Pin function
Mode 6
Mode 7
0
1
0
1
P70 input
CS4 output
P70 input
P70 output
TMRI01/TMCI01 input
Rev. 6.00 Sep. 24, 2009 Page 223 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.7
Port 9
Port 9 is an 8-bit input-only port and has the following register.
• Port 9 register (PORT9)
9.7.1
Port 9 Register (PORT9)
PORT9 shows port 9 pin states. This register cannot be modified.
Bit
Bit Name
Initial Value R/W
Description
7
P97
⎯*
R
6
P96
⎯*
R
The pin states are always read when a port 9 read is
performed.
5
P95
⎯*
R
4
P94
⎯*
R
3
P93
⎯*
R
2
P92
⎯*
R
1
P91
⎯*
R
0
P90
⎯*
R
Note:
*
9.7.2
Determined by the states of pins P97 and P90.
Pin Functions
Port 9 pins also function as A/D converter analog input pins (AN15 and AN8) and D/A converter
analog output pins (DA0 and DA1).
• P97/AN15/DA1
The pin function is switched as shown below according to the combination of the DAE bit and
the DAOE1 bit in DACR of D/A converter.
DAOE1
DAE
Pin function
0
1
0
1
⎯
P97 input
DA1 output
DA1 output
AN15 input
Rev. 6.00 Sep. 24, 2009 Page 224 of 928
REJ09B0099-0600
Section 9 I/O Ports
• P96/AN14/DA0
The pin function is switched as shown below according to the combination of the DAE bit and
the DAOE0 bit in DACR of D/A converter.
DAOE0
DAE
Pin function
0
1
0
1
⎯
P96 input
DA0 output
DA0 output
AN14 input
• P95/AN13, P94/AN12, P93/AN11, P92/AN10, P91/AN9, P90/AN8
Pin function
P95, P94, P93, P92, P91, P90 input pin
AN13, AN12, AN11, AN10, AN9, AN8 input
Rev. 6.00 Sep. 24, 2009 Page 225 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.8
Port A
Port A is an 8-bit I/O port and has the following registers.
•
•
•
•
•
Port A data direction register (PADDR)
Port A data register (PADR)
Port A register (PORTA)
Port A pull-up MOS control register (PAPCR)
Port A open drain control register (PAODR)
9.8.1
Port A Data Direction Register (PADDR)
PADDR specifies input or output the port A pins using the individual bits. PADDR cannot be
read; if it is, the read value is undefined. Since this register is a write-only register, bitmanipulation instructions should not be used when writing. See section 2.9.4, Access Method for
Registers with Write-only Bits.
Bit
Bit Name
Initial Value R/W
Description
7
PA7DDR
0
W
6
PA6DDR
0
W
5
PA5DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port A pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
4
PA4DDR
0
W
3
PA3DDR
0
W
2
PA2DDR
0
W
1
PA1DDR
0
W
0
PA0DDR
0
W
Rev. 6.00 Sep. 24, 2009 Page 226 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.8.2
Port A Data Register (PADR)
PADR stores output data for port A pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PA7DR
0
R/W
6
PA6DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
PA5DR
0
R/W
4
PA4DR
0
R/W
3
PA3DR
0
R/W
2
PA2DR
0
R/W
1
PA1DR
0
R/W
0
PA0DR
0
R/W
9.8.3
Port A Register (PORTA)
PORTA shows port A pin states. This register cannot be modified.
Bit
Bit Name
Initial Value R/W
Description
7
PA7
⎯*
R
6
PA6
⎯*
R
5
PA5
⎯*
R
If a port A read is performed while PADDR bits are
set to 1, the PADR values are read. If a port A read
is performed while PADDR bits are cleared to 0, the
pin states are read.
4
PA4
⎯*
R
3
PA3
⎯*
R
2
PA2
⎯*
R
1
PA1
⎯*
R
0
PA0
⎯*
R
Note:
*
Determined by the states of pins PA7 to PA0.
Rev. 6.00 Sep. 24, 2009 Page 227 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.8.4
Port A Pull-Up MOS Control Register (PAPCR)
PAPCR controls on/off state of the input pull-up MOS for port A pins.
Bit
Bit Name
Initial Value R/W
Description
7
PA7PCR
0
R/W
6
PA6PCR
0
R/W
5
PA5PCR
0
R/W
When a pin is specified as an input port, setting the
corresponding bit to 1 turns on the input pull-up MOS
for that pin.
4
PA4PCR
0
R/W
3
PA3PCR
0
R/W
2
PA2PCR
0
R/W
1
PA1PCR
0
R/W
0
PA0PCR
0
R/W
9.8.5
Port A Open Drain Control Register (PAODR)
PAODR selects the output type for port A pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PA7ODR
0
R/W
6
PA6ODR
0
R/W
5
PA5ODR
0
R/W
When these bits are set to 1, the corresponding pins
function as NMOS open drain outputs. When cleared
to 0, the corresponding pins function as CMOS
outputs.
4
PA4ODR
0
R/W
3
PA3ODR
0
R/W
2
PA2ODR
0
R/W
1
PA1ODR
0
R/W
0
PA0ODR
0
R/W
Rev. 6.00 Sep. 24, 2009 Page 228 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.8.6
Pin Functions
Port A pins also function as address output pins. Port A pin functions are shown below.
• PA7/A23
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PA7DDR bit.
Operating mode
AE3 to AE0
PA7DDR
Pin function
Note:
*
Mode 6
B'1111
Mode 7
⎯
Other than B'1111
⎯
0
1
0
1
A23 output
PA7 input
PA7 output*
PA7 input
PA7 output*
When PA7ODR in PAODR is set to 1, this pin functions as NMOS open drain output.
• PA6/A22
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PA6DDR bit.
Operating mode
AE3 to AE0
PA6DDR
Pin function
Note:
*
Mode 6
B'1111
Mode 7
⎯
Other than B'1111
⎯
0
1
0
1
A22 output
PA6 input
PA6 output*
PA6 input
PA6 output*
When PA6ODR in PAODR is set to 1, this pin functions as NMOS open drain output.
• PA5/A21
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PA5DDR bit.
Operating mode
AE3 to AE0
PA5DDR
Pin function
Mode 6
B'111x
Mode 7
⎯
Other than B'111x
⎯
0
1
0
1
A21 output
PA5 input
PA5 output*
PA5 input
PA5 output*
Legend:
x:
Don’t care
Note: * When PA5ODR in PAODR is set to 1, this pin functions as NMOS open drain output.
Rev. 6.00 Sep. 24, 2009 Page 229 of 928
REJ09B0099-0600
Section 9 I/O Ports
• PA4/A20
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PA4DDR bit.
Operating mode
AE3 to AE0
PA4DDR
Pin function
Note:
*
Mode 6
B'1101 to
B'1111
Mode 7
⎯
Other than B'1101 to B'1111
⎯
0
1
0
1
A20 output
PA4 input
PA4 output*
PA4 input
PA4 output*
When PA4ODR in PAODR is set to 1, this pin functions as NMOS open drain output.
• PA3/A19
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PA3DDR bit.
Operating mode
AE3 to AE0
PA3DDR
Pin function
Mode 6
B'11xx
Mode 7
⎯
Other than B'11xx
⎯
0
1
0
1
A19 output
PA3 input
PA3 output*
PA3 input
PA3 output*
Legend:
x:
Don’t care
Note: * When PA3ODR in PAODR is set to 1, this pin functions as NMOS open drain output.
• PA2/A18
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PA2DDR bit.
Operating mode
AE3 to AE0
PA2DDR
Pin function
Mode 6
B'1011 or
B'11xx
Mode 7
⎯
Other than B'1011 or B'11xx
⎯
0
1
0
1
A18 output
PA2 input
PA2 output*
PA2 input
PA2 output*
Legend:
x:
Don’t care
Note: * When PA2ODR in PAODR is set to 1, this pin functions as NMOS open drain output.
Rev. 6.00 Sep. 24, 2009 Page 230 of 928
REJ09B0099-0600
Section 9 I/O Ports
• PA1/A17
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PA1DDR bit.
Operating mode
AE3 to AE0
PA1DDR
Pin function
Mode 6
B'101x or
B'11xx
Mode 7
⎯
Other than B'101x or B'11xx
⎯
0
1
0
1
A17 output
PA1 input
PA1 output*
PA1 input
PA1 output*
Legend:
x:
Don’t care
Note: * When PA1ODR in PAODR is set to 1, this pin functions as NMOS open drain output.
• PA0/A16
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PA0DDR bit.
Operating mode
AE3 to AE0
PA0DDR
Pin function
Mode 6
Other than B'0xxx or
B'1000
Mode 7
⎯
B'0xxx or B'1000
⎯
0
1
0
1
A16 output
PA0 input
PA0 output*
PA0 input
PA0 output*
Legend:
x:
Don’t care
Note: * When PA0ODR in PAODR is set to 1, this pin functions as NMOS open drain output.
Rev. 6.00 Sep. 24, 2009 Page 231 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.8.7
Input Pull-Up MOS Function (Port A)
Port A has a built-in input pull-up MOS function that can be controlled by software. Input pull-up
MOS can be specified as on or off on an individual bit basis. Table 9.2 summarizes the input pullup MOS states in port A.
Table 9.2
Input Pull-Up MOS States (Port A)
Pin States
Power-on
Reset
Address output and port
output
Hardware
Manual
Standby Mode Reset
OFF
Port input
Port B
Port B is an 8-bit I/O port and has the following registers.
•
•
•
•
OFF
ON/OFF
Legend:
OFF:
Input pull-up MOS is always off.
ON/OFF: On when PADDR = 0 and PAPCR = 1; otherwise off.
9.9
Software
Standby Mode
Port B data direction register (PBDDR)
Port B data register (PBDR)
Port B register (PORTB)
Port B pull-up MOS control register (PBPCR)
Rev. 6.00 Sep. 24, 2009 Page 232 of 928
REJ09B0099-0600
In Other
Operations
Section 9 I/O Ports
9.9.1
Port B Data Direction Register (PBDDR)
PBDDR specifies input or output the port B pins using the individual bits. PBDDR cannot be read;
if it is, the read value is undefined. Since this register is a write-only register, bit-manipulation
instructions should not be used when writing. See section 2.9.4, Access Method for Registers with
Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
PB7DDR
0
W
6
PB6DDR
0
W
5
PB5DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port B pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
4
PB4DDR
0
W
3
PB3DDR
0
W
2
PB2DDR
0
W
1
PB1DDR
0
W
0
PB0DDR
0
W
9.9.2
Port B Data Register (PBDR)
PBDR stores output data for port B pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PB7DR
0
R/W
6
PB6DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
PB5DR
0
R/W
4
PB4DR
0
R/W
3
PB3DR
0
R/W
2
PB2DR
0
R/W
1
PB1DR
0
R/W
0
PB0DR
0
R/W
Rev. 6.00 Sep. 24, 2009 Page 233 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.9.3
Port B Register (PORTB)
PORTB shows port B pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
PB7
⎯*
R
6
PB6
⎯*
R
5
PB5
⎯*
R
If a port B read is performed while PBDDR bits are
set to 1, the PBDR values are read. If a port B read
is performed while PBDDR bits are cleared to 0, the
pin states are read.
4
PB4
⎯*
R
3
PB3
⎯*
R
2
PB2
⎯*
R
1
PB1
⎯*
R
0
PB0
⎯*
R
Note:
*
9.9.4
Determined by the states of pins PB7 to PB0.
Port B Pull-Up MOS Control Register (PBPCR)
PBPCR controls on/off state of the input pull-up MOS for port B pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PB7PCR
0
R/W
6
PB6PCR
0
R/W
5
PB5PCR
0
R/W
When a pin is specified as an input port, setting the
corresponding bit to 1 turns on the input pull-up MOS
for that pin.
4
PB4PCR
0
R/W
3
PB3PCR
0
R/W
2
PB2PCR
0
R/W
1
PB1PCR
0
R/W
0
PB0PCR
0
R/W
Rev. 6.00 Sep. 24, 2009 Page 234 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.9.5
Pin Functions
Port B pins also function as address output pins. Port B pin functions are shown below.
• PB7/A15
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PB7DDR bit.
Operating mode
AE3 to AE0
PB7DDR
Pin function
Mode 6
B'1xxx
Mode 7
⎯
Other than B'1xxx
⎯
0
1
0
1
A15 output
PB7 input
PB7 output
PB7 input
PB7 output
Legend:
x:
Don’t care
• PB6/A14
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PB6DDR bit.
Operating mode
AE3 to AE0
PB6DDR
Pin function
Mode 6
B'0111 or
B'1xxx
Mode 7
⎯
Other than B'0111 or B'1xxx
⎯
0
1
0
1
A14 output
PB6 input
PB6 output
PB6 input
PB6 output
Legend:
x:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 235 of 928
REJ09B0099-0600
Section 9 I/O Ports
• PB5/A13
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PB5DDR bit.
Operating mode
AE3 to AE0
PB5DDR
Pin function
Mode 6
B'011x or
B'1xxx
Mode 7
⎯
Other than B'111x or B'1xxx
⎯
0
1
0
1
A13 output
PB5 input
PB5 output
PB5 input
PB5 output
Legend:
x:
Don’t care
• PB4/A12
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PB4DDR bit.
Operating mode
AE3 to AE0
PB4DDR
Pin function
Mode 6
Other than B'0100
or B'00xx
Mode 7
⎯
B'0100 or B'00xx
⎯
0
1
0
1
A12 output
PB4 input
PB4 output
PB4 input
PB4 output
Legend:
x:
Don’t care
• PB3/A11
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PB3DDR bit.
Operating mode
AE3 to AE0
PB3DDR
Pin function
Mode 6
Other than
B'00xx
⎯
B'00xx
⎯
0
1
0
1
A11 output
PB3 input
PB3 output
PB3 input
PB3 output
Legend:
x:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 236 of 928
REJ09B0099-0600
Mode 7
Section 9 I/O Ports
• PB2/A10
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PB2DDR bit.
Operating mode
AE3 to AE0
PB2DDR
Pin function
Mode 6
Other than B'0010
or B'000x
Mode 7
⎯
B'0010 or B'000x
⎯
0
1
0
1
A10 output
PB2 input
PB2 output
PB2 input
PB2 output
Legend:
x:
Don’t care
• PB1/A9
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PB1DDR bit.
Operating mode
AE3 to AE0
PB1DDR
Pin function
Mode 6
Mode 7
Other than B'000x
⎯
B'000x
⎯
0
1
0
1
A9 output
PB1 input
PB1 output
PB1 input
PB1 output
Legend:
x:
Don’t care
• PB0/A8
The pin function is switched as shown below according to the combination of the operating
mode, the AE3 to AE0 bits in PFCR, and the PB0DDR bit.
Operating mode
AE3 to AE0
PB0DDR
Pin function
Mode 6
Other than B'0000
Mode 7
⎯
B'0000
⎯
0
1
0
1
A8 output
PB0 input
PB0 output
PB0 input
PB0 output
Legend:
x:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 237 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.9.6
Input Pull-Up MOS Function (Port B)
Port B has a built-in input pull-up MOS function that can be controlled by software. Input pull-up
MOS can be specified as on or off on an individual bit basis. Table 9.3 summarizes the input pullup MOS states in port B.
Table 9.3
Input Pull-Up MOS States (Port B)
Pin States
Power-on
Reset
Address output and port
output
Hardware
Manual
Standby Mode Reset
OFF
Port input
Legend:
OFF:
Input pull-up MOS is always off.
ON/OFF: On when PBDDR = 0 and PBPCR = 1; otherwise off.
Rev. 6.00 Sep. 24, 2009 Page 238 of 928
REJ09B0099-0600
Software
Standby Mode
OFF
ON/OFF
In Other
Operations
Section 9 I/O Ports
9.10
Port C
Port C is an 8-bit I/O port and has the following registers.
•
•
•
•
Port C data direction register (PCDDR)
Port C data register (PCDR)
Port C register (PORTC)
Port C pull-up MOS control register (PCPCR)
9.10.1
Port C Data Direction Register (PCDDR)
PCDDR specifies input or output the port C pins using the individual bits. PCDDR cannot be read;
if it is, the read value is undefined. Since this register is a write-only register, bit-manipulation
instructions should not be used when writing. See section 2.9.4, Access Method for Registers with
Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
PC7DDR
0
W
6
PC6DDR
0
W
5
PC5DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port C pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
4
PC4DDR
0
W
3
PC3DDR
0
W
2
PC2DDR
0
W
1
PC1DDR
0
W
0
PC0DDR
0
W
Rev. 6.00 Sep. 24, 2009 Page 239 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.10.2
Port C Data Register (PCDR)
PCDR stores output data for port C pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PC7DR
0
R/W
6
PC6DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
PC5DR
0
R/W
4
PC4DR
0
R/W
3
PC3DR
0
R/W
2
PC2DR
0
R/W
1
PC1DR
0
R/W
0
PC0DR
0
R/W
9.10.3
Port C Register (PORTC)
PORTC shows port C pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
PC7
⎯*
R
6
PC6
⎯*
R
5
PC5
⎯*
R
If a port C read is performed while PCDDR bits are
set to 1, the PCDR values are read. If a port C read
is performed while PCDDR bits are cleared to 0, the
pin states are read.
4
PC4
⎯*
R
3
PC3
⎯*
R
2
PC2
⎯*
R
1
PC1
⎯*
R
0
PC0
⎯*
R
Note:
*
Determined by the states of pins PC7 to PC0.
Rev. 6.00 Sep. 24, 2009 Page 240 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.10.4
Port C Pull-Up MOS Control Register (PCPCR)
PCPCR controls on/off state of the input pull-up MOS for port C pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PC7PCR
0
R/W
6
PC6PCR
0
R/W
5
PC5PCR
0
R/W
When a pin is specified as an input port, setting the
corresponding bit to 1 turns on the input pull-up MOS
for that pin.
4
PC4PCR
0
R/W
3
PC3PCR
0
R/W
2
PC2PCR
0
R/W
1
PC1PCR
0
R/W
0
PC0PCR
0
R/W
9.10.5
Pin Functions
Port C pins also function as address output pins. Port C pin functions are shown below.
• PC7/A7, PC6/A6, PC5/A5, PC4/A4, PC3/A3, PC2/A2, PC1/A1, PC0/A0
The pin function is switched as shown below according to the combination of the operating
mode and the PCnDDR bit.
Operating mode
PCnDDR
Pin function
Mode 6
Mode 7
0
1
0
1
PCn input
Address output
PCn input
PCn output
Note: n = 7 to 0
Rev. 6.00 Sep. 24, 2009 Page 241 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.10.6
Input Pull-Up MOS Function (Port C)
Port C has a built-in input pull-up MOS function that can be controlled by software. Input pull-up
MOS can be used in mode 6 or mode 7, and can be specified as on or off on an individual bit
basis. Table 9.4 summarizes the input pull-up MOS states in port C.
Table 9.4
Input Pull-Up MOS States (Port C)
Pin States
Power-on
Reset
Address output (mode 6)
and port output (mode 7)
Hardware
Manual
Standby Mode Reset
OFF
Port input
Legend:
OFF:
Input pull-up MOS is always off.
ON/OFF: On when PCDDR = 0 and PCPCR = 1; otherwise off.
Rev. 6.00 Sep. 24, 2009 Page 242 of 928
REJ09B0099-0600
Software
Standby Mode
OFF
ON/OFF
In Other
Operations
Section 9 I/O Ports
9.11
Port D
Port D is an 8-bit I/O port and has the following registers.
•
•
•
•
Port D data direction register (PDDDR)
Port D data register (PDDR)
Port D register (PORTD)
Port D pull-up MOS control register (PDPCR)
9.11.1
Port D Data Direction Register (PDDDR)
PDDDR specifies input or output the port D pins using the individual bits. PDDDR cannot be
read; if it is, the read value is undefined. Since this register is a write-only register, bitmanipulation instructions should not be used when writing. See section 2.9.4, Access Method for
Registers with Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
PD7DDR
0
W
6
PD6DDR
0
W
5
PD5DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port D pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
4
PD4DDR
0
W
3
PD3DDR
0
W
2
PD2DDR
0
W
1
PD1DDR
0
W
0
PD0DDR
0
W
Rev. 6.00 Sep. 24, 2009 Page 243 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.11.2
Port D Data Register (PDDR)
PDDR stores output data for port D pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PD7DR
0
R/W
6
PD6DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
PD5DR
0
R/W
4
PD4DR
0
R/W
3
PD3DR
0
R/W
2
PD2DR
0
R/W
1
PD1DR
0
R/W
0
PD0DR
0
R/W
9.11.3
Port D Register (PORTD)
PORTD shows port D pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
PD7
⎯*
R
6
PD6
⎯*
R
5
PD5
⎯*
R
If a port D read is performed while PDDDR bits are
set to 1, the PDDR values are read. If a port D read
is performed while PDDDR bits are cleared to 0, the
pin states are read.
4
PD4
⎯*
R
3
PD3
⎯*
R
2
PD2
⎯*
R
1
PD1
⎯*
R
0
PD0
⎯*
R
Note:
*
Determined by the states of pins PD7 to PD0.
Rev. 6.00 Sep. 24, 2009 Page 244 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.11.4
Port D Pull-Up MOS Control Register (PDPCR)
PDPCR controls on/off state of the input pull-up MOS for port D pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PD7PCR
0
R/W
6
PD6PCR
0
R/W
5
PD5PCR
0
R/W
When a pin is specified as an input port, setting the
corresponding bit to 1 turns on the input pull-up MOS
for that pin.
4
PD4PCR
0
R/W
3
PD3PCR
0
R/W
2
PD2PCR
0
R/W
1
PD1PCR
0
R/W
0
PD0PCR
0
R/W
9.11.5
Pin Functions
Port D pins also function as data I/O pins. Port D pin functions are shown below.
• PD7/D15, PD6/D14, PD5/D13, PD4/D12, PD3/D11, PD2/D10, PD1/D9, PD0/D8
The pin function is switched as shown below according to the combination of the operating
mode and the PDnDDR bit.
Operating mode
PDnDDR
Pin function
Mode 6
Mode 7
⎯
0
1
Data input/output
PDn input
PDn output
Note: n = 7 to 0
Rev. 6.00 Sep. 24, 2009 Page 245 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.11.6
Input Pull-Up MOS Function (Port D)
Port D has a built-in input pull-up MOS function that can be controlled by software. Input pull-up
MOS can be used in mode 7, and can be specified as on or off on an individual bit basis. Table 9.5
summarizes the input pull-up MOS states in port D.
Table 9.5
Input Pull-Up MOS States (Port D)
Pin States
Data input/output
(mode 6) and
port output (mode 7)
Power-on
Reset
Hardware
Manual
Standby Mode Reset
OFF
Port input (mode 7)
Legend:
OFF:
Input pull-up MOS is always off.
ON/OFF: On when PDDDR = 0 and PDPCR = 1; otherwise off.
Rev. 6.00 Sep. 24, 2009 Page 246 of 928
REJ09B0099-0600
Software
Standby Mode
OFF
ON/OFF
In Other
Operations
Section 9 I/O Ports
9.12
Port E
Port E is an 8-bit I/O port and has the following registers.
•
•
•
•
Port E data direction register (PEDDR)
Port E data register (PEDR)
Port E register (PORTE)
Port E pull-up MOS control register (PEPCR)
9.12.1
Port E Data Direction Register (PEDDR)
PEDDR specifies input or output the port E pins using the individual bits. PEDDR cannot be read;
if it is, the read value is undefined. Since this register is a write-only register, bit-manipulation
instructions should not be used when writing. See section 2.9.4, Access Method for Registers with
Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
PE7DDR
0
W
6
PE6DDR
0
W
5
PE5DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port E pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
4
PE4DDR
0
W
3
PE3DDR
0
W
2
PE2DDR
0
W
1
PE1DDR
0
W
0
PE0DDR
0
W
Rev. 6.00 Sep. 24, 2009 Page 247 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.12.2
Port E Data Register (PEDR)
PEDR stores output data for port E pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PE7DR
0
R/W
6
PE6DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
PE5DR
0
R/W
4
PE4DR
0
R/W
3
PE3DR
0
R/W
2
PE2DR
0
R/W
1
PE1DR
0
R/W
0
PE0DR
0
R/W
9.12.3
Port E Register (PORTE)
PORTE shows port E pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
PE7
⎯*
R
6
PE6
⎯*
R
5
PE5
⎯*
R
If a port E read is performed while PEDDR bits are
set to 1, the PEDR values are read. If a port E read
is performed while PEDDR bits are cleared to 0, the
pin states are read.
4
PE4
⎯*
R
3
PE3
⎯*
R
2
PE2
⎯*
R
1
PE1
⎯*
R
0
PE0
⎯*
R
Note:
*
Determined by the states of pins PE7 to PE0.
Rev. 6.00 Sep. 24, 2009 Page 248 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.12.4
Port E Pull-Up MOS Control Register (PEPCR)
PEPCR controls on/off state of the input pull-up MOS for port E pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PE7PCR
0
R/W
6
PE6PCR
0
R/W
5
PE5PCR
0
R/W
When a pin is specified as an input port, setting the
corresponding bit to 1 turns on the input pull-up MOS
for that pin.
4
PE4PCR
0
R/W
3
PE3PCR
0
R/W
2
PE2PCR
0
R/W
1
PE1PCR
0
R/W
0
PE0PCR
0
R/W
9.12.5
Pin Functions
Port E pins also function as data I/O pins. Port E pin functions are shown below.
• PE7/D7, PE6/D6, PE5/D5, PE4/D4, PE3/D3, PE2/D2, PE1/D1, PE0/D0
The pin function is switched as shown below according to the combination of the operating
mode and the PEnDDR bit.
Operating mode
Bus mode
PEnDDR
Pin function
Mode 6
8-bit bus mode
Mode 7
⎯
16-bit bus mode
0
1
⎯
0
1
PEn input
PEn output
Data input/output
PEn input
PEn output
Note: n = 7 to 0
Rev. 6.00 Sep. 24, 2009 Page 249 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.12.6
Input Pull-Up MOS Function (Port E)
Port E has a built-in input pull-up MOS function that can be controlled by software. Input pull-up
MOS can be used in mode 7 or 8-bit bus mode in mode 6, and can be specified as on or off on an
individual bit basis. Table 9.6 summarizes the input pull-up MOS states in port E.
Table 9.6
Input Pull-Up MOS States (Port E)
Pin States
Power-on Hardware
Manual Software
In Other
Reset
Standby Mode Reset Standby Mode Operations
Data input/output (16-bit bus in
mode 6) and port output (8-bit
bus in mode 6, mode 7)
OFF
Port input
(8-bit bus in mode 6, mode 7)
Legend:
OFF:
Input pull-up MOS is always off.
ON/OFF: On when PEDDR = 0 and PEPCR = 1; otherwise off.
Rev. 6.00 Sep. 24, 2009 Page 250 of 928
REJ09B0099-0600
OFF
ON/OFF
Section 9 I/O Ports
9.13
Port F
Port F is an 8-bit I/O port and has the following registers.
• Port F data direction register (PFDDR)
• Port F data register (PFDR)
• Port F register (PORTF)
9.13.1
Port F Data Direction Register (PFDDR)
PFDDR specifies input or output the port F pins using the individual bits. PFDDR cannot be read;
if it is, the read value is undefined. Since this register is a write-only register, bit-manipulation
instructions should not be used when writing. See section 2.9.4, Access Method for Registers with
Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
PF7DDR
0/1*
W
6
PF6DDR
0
W
5
PF5DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port F pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
4
PF4DDR
0
W
3
PF3DDR
0
W
2
PF2DDR
0
W
1
PF1DDR
0
W
0
PF0DDR
0
W
Note:
*
PF7DDR is initialized to 1 in mode 6 and 0 in mode 7.
Rev. 6.00 Sep. 24, 2009 Page 251 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.13.2
Port F Data Register (PFDR)
PFDR stores output data for port F pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PF7DR*
0
R/W
6
PF6DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
PF5DR
0
R/W
4
PF4DR
0
R/W
3
PF3DR
0
R/W
2
PF2DR
0
R/W
1
PF1DR
0
R/W
0
PF0DR
0
R/W
Note:
*
9.13.3
The value of PF7DR is not output on pin PF7 when the PF7DDR bit is set to 1 since the
φ signal is output.
Port F Register (PORTF)
PORTF shows port F pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
PF7
⎯*
R
6
PF6
⎯*
R
5
PF5
⎯*
R
If a port F read is performed while PFDDR bits are
set to 1, the PFDR values are read. If a port F read is
performed while PFDDR bits are cleared to 0, the pin
states are read.
4
PF4
⎯*
R
3
PF3
⎯*
R
2
PF2
⎯*
R
1
PF1
⎯*
R
0
PF0
⎯*
R
Note:
*
Determined by the states of pins PF7 to PF0.
Rev. 6.00 Sep. 24, 2009 Page 252 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.13.4
Pin Functions
Port F pins also function as bus control I/O pins, interrupt input pins, system clock output pins,
A/D trigger input pins, and BUZZ output pins. Port F pin functions are shown below.
• PF7/φ
The pin function is switched as shown below according to the PF7DDR bit.
PF7DDR
Pin function
0
1
PF7 input
φ output
• PF6/AS
The pin function is switched as shown below according to the combination of the operating
mode and the PF6DDR bit.
Operating mode
PF6DDR
Pin function
Mode 6
Mode 7
⎯
0
1
AS output
PF6 input
PF6 output
• PF5/RD
The pin function is switched as shown below according to the combination of the operating
mode and the PF5DDR bit.
Operating mode
PF5DDR
Pin function
Mode 6
Mode 7
⎯
0
1
RD output
PF5 input
PF5 output
• PF4/HWR
The pin function is switched as shown below according to the combination of the operating
mode and the PF4DDR bit.
Operating mode
PF4DDR
Pin function
Mode 6
Mode 7
⎯
0
1
HWR output
PF4 input
PF4 output
Rev. 6.00 Sep. 24, 2009 Page 253 of 928
REJ09B0099-0600
Section 9 I/O Ports
• PF3/LWR/ADTRG/IRQ3
The pin function is switched as shown below according to the combination of the operation
mode, the bus mode, the TRGS1 and TRGS0 bits in ADCR of the A/D converter, and the
PF3DDR bit.
Operating mode
Mode 6
Mode 7
⎯
Bus mode
16-bit bus mode
PF3DDR
⎯
0
1
0
1
LWR output
PF3 input
PF3 output
PF3 input
PF3 output
Pin function
8-bit bus mode
ADTRG input*
1
IRQ3 input*2
Notes: 1. When TRGS0 = TRGS1 = 1, port F is used as the ADTRG input pin.
2. When this port is used as an external interrupt pin, do not specify other functions.
• PF2/WAIT
The pin function is switched as shown below according to the combination of the operating
mode, the WAITE bit, and the PF2DDR bit.
Operating mode
Mode 6
WAITE
0
⎯
1
0
1
⎯
0
1
PF2 input
PF2 output
WAIT input
PF2 input
PF2 output
PF2DDR
Pin function
Mode 7
• PF1/BACK/BUZZ
The pin function is switched as shown below according to the combination of the operating
mode, the BRLE bit, the BUZZ bit in PFCR, and the PF1DDR bit.
Operating mode
Mode 6
BRLE
0
BUZZE
PF1DDR
Pin function
0
⎯
1
1
⎯
0
1
0
1
⎯
⎯
0
1
⎯
PF1
input
PF1
output
BUZZ
output
BACK
output
PF1 input
PF1
output
BUZZ
output
Rev. 6.00 Sep. 24, 2009 Page 254 of 928
REJ09B0099-0600
Mode 7
Section 9 I/O Ports
• PF0/BREQ/IRQ2
The pin function is switched as shown below according to the combination of the operating
mode, the BRLE bit, and the PF0DDR bit.
Operating mode
Mode 6
BRLE
Mode 7
0
0
1
⎯
0
1
PF0 input
PF0 output
BREQ input
PF0 input
PF0 output
PF0DDR
Pin function
⎯
1
IRQ2 input*
Note:
*
9.14
When this port is used as an external interrupt pin, do not specify other functions.
Port G
Port G is a 5-bit I/O port and has the following registers.
• Port G data direction register (PGDDR)
• Port G data register (PGDR)
• Port G register (PORTG)
9.14.1
Port G Data Direction Register (PGDDR)
PGDDR specifies input or output the port G pins using the individual bits. PGDDR cannot be
read; if it is, the read value is undefined. Since this register is a write-only register, bitmanipulation instructions should not be used when writing. See section 2.9.4, Access Method for
Registers with Write-only Bits.
Bit
Bit Name
Initial Value R/W
7 to 5
⎯
Undefined
⎯
Description
Reserved
These bits are always read as undefined value and
cannot be modified.
4
PG4DDR
0
W
3
PG3DDR*
0
W
2
PG2DDR*
0
W
1
PG1DDR
0
W
0
PG0DDR
0
W
Note:
*
When a pin is specified as a general purpose I/O
port, setting these bits to 1 makes the corresponding
port G pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
Reserved in the H8S/2556 Group. This bit is set to 0.
Rev. 6.00 Sep. 24, 2009 Page 255 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.14.2
Port G Data Register (PGDR)
PGDR stores output data for port G pins.
Bit
Bit Name
Initial Value R/W
7 to 5
⎯
Undefined
⎯
Description
Reserved
These bits are always read as undefined value and
cannot be modified.
4
PG4DR
0
R/W
3
PG3DR*
0
R/W
2
PG2DR*
0
R/W
1
PG1DR
0
R/W
0
PG0DR
0
R/W
Note:
9.14.3
*
Output data for a pin is stored when the pin is
specified as a general purpose output port.
Reserved in the H8S/2556 Group. This bit is set to 0.
Port G Register (PORTG)
PORTG shows port G pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7 to 5
⎯
Undefined
⎯
Reserved
This bit is always read as undefined value and
cannot be modified.
4
3
⎯*
R
2
⎯*
R
2
1
PG4
PG3*
1
2
PG2*
⎯*
R
1
PG1
⎯*1
R
PG0
⎯*
R
0
1
1
If these bits are read while the corresponding
PGDDR bits are set to 1, the PGDR value is read. If
these bits are read while PGDDR bits are cleared to
0, the pin states are read.
Notes: 1. Determined by the states of pins PG4 to PG0.
2. Reserved in the H8S/2556 Group. An undefined value will be read.
Rev. 6.00 Sep. 24, 2009 Page 256 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.14.4
Pin Functions
Port G pins also function as bus control I/O pins, interrupt input pins, and IEB I/O pins. Port G pin
functions are shown below.
• PG4/CS0
The pin function is switched as shown below according to the combination of the operating
mode and the PG4DDR bit.
Operating mode
Mode 6
PG4DDR
Pin function
Mode 7
0
1
0
1
PG4 input
CS0 output
PG4 input
PG4 output
• PG3/Rx/CS1
In the H8S/2552 and H8S/2506 Groups, the pin function is switched as shown below
according to the combination of the IEE bit in IECTR of IEB*, the operating mode, and the
PG3DDR bit. This pin is not available in the H8S/2556 Group.
IEE
0
Operating mode
PG3DDR
Pin function
Note:
*
1
Mode 6
⎯
Mode 7
0
1
0
1
⎯
PG3 input
CS1 output
PG3 input
PG3 output
Rx input
IEB is supported only by the H8S/2552 Group.
• PG2/Tx/CS2
In the H8S/2552 and H8S/2506 Groups, the pin function is switched as shown below
according to the combination of the IEE bit in IECTR of IEB*, the operating mode, and the
PG2DDR bit. This pin is not available in the H8S/2556 Group.
IEE
0
Operating mode
PG2DDR
Pin function
Note:
*
1
Mode 6
⎯
Mode 7
0
1
0
1
⎯
PG2 input
CS2 output
PG2 input
PG2 output
Tx output
IEB is supported only by the H8S/2552 Group.
Rev. 6.00 Sep. 24, 2009 Page 257 of 928
REJ09B0099-0600
Section 9 I/O Ports
• PG1/CS3/IRQ7
The pin function is switched as shown below according to the combination of the operating
mode and the PG1DDR bit.
Operating mode
PG1DDR
Pin function
Mode 6
Mode 7
0
1
0
1
PG1 input
CS3 output
PG1 input
PG1 output
IRQ7 input*
Note:
*
When this port is used as an external interrupt pin, do not specify other functions.
• PG0/IRQ6
The pin function is switched as shown below according to the PG0DDR bit.
PG0DDR
Pin function
0
1
PG0 input
PG0 output
IRQ6 input*
Note:
9.15
*
When this port is used as an external interrupt pin, do not specify other functions.
Port H
Port H is an 8-bit I/O port and has the following registers.
• Port H data direction register (PHDDR)
• Port H data register (PHDR)
• Port H register (PORTH)
Rev. 6.00 Sep. 24, 2009 Page 258 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.15.1
Port H Data Direction Register (PHDDR)
PHDDR specifies input or output the port H pins using the individual bits. PHDDR cannot be
read; if it is, the read value is undefined. Since this register is a write-only register, bitmanipulation instructions should not be used when writing. See section 2.9.4, Access Method for
Registers with Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
PH7DDR
0
W
6
PH6DDR
0
W
5
PH5DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port H pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
4
PH4DDR
0
W
3
PH3DDR
0
W
2
PH2DDR
0
W
1
PH1DDR
0
W
0
PH0DDR
0
W
9.15.2
Port H Data Register (PHDR)
PHDR stores output data for port H pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PH7DR
0
R/W
6
PH6DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
PH5DR
0
R/W
4
PH4DR
0
R/W
3
PH3DR
0
R/W
2
PH2DR
0
R/W
1
PH1DR
0
R/W
0
PH0DR
0
R/W
Rev. 6.00 Sep. 24, 2009 Page 259 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.15.3
Port H Register (PORTH)
PORTH shows port H pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
PH7
⎯*
R
6
PH6
⎯*
R
5
PH5
⎯*
R
If a port H read is performed while PHDDR bits are
set to 1, the PHDR values are read. If a port H read
is performed while PHDDR bits are cleared to 0, the
pin states are read.
4
PH4
⎯*
R
3
PH3
⎯*
R
2
PH2
⎯*
R
1
PH1
⎯*
R
0
PH0
⎯*
R
Note:
*
9.15.4
Determined by the states of pins PH7 to PH0.
Pin Functions
Port H pins also function as general purpose I/O pins. Port H pin functions are shown below.
• PH7, PH6, PH5, PH4, PH3, PH2, PH1, PH0
The pin function is switched as shown below according to the PHnDDR bit.
PHnDDR
Pin function
0
1
PHn input
PHn output
Note: n = 7 to 0
Rev. 6.00 Sep. 24, 2009 Page 260 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.16
Port J
Port J is an 8-bit I/O port and has the following registers.
• Port J data direction register (PJDDR)
• Port J data register (PJDR)
• Port J register (PORTJ)
9.16.1
Port J Data Direction Register (PJDDR)
PJDDR specifies input or output the port J pins using the individual bits. PJDDR cannot be read; if
it is, the read value is undefined. Since this register is a write-only register, bit-manipulation
instructions should not be used when writing. See section 2.9.4, Access Method for Registers with
Write-only Bits.
Bit
Bit Name
Initial Value
R/W
Description
7
PJ7DDR
0
W
6
PJ6DDR
0
W
5
PJ5DDR
0
W
When a pin is specified as a general purpose I/O
port, setting this bit to 1 makes the corresponding
port J pin an output pin. Clearing this bit to 0 makes
the pin an input pin.
4
PJ4DDR
0
W
3
PJ3DDR
0
W
2
PJ2DDR
0
W
1
PJ1DDR
0
W
0
PJ0DDR
0
W
Rev. 6.00 Sep. 24, 2009 Page 261 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.16.2
Port J Data Register (PJDR)
PJDR stores output data for port J pins.
Bit
Bit Name
Initial Value
R/W
Description
7
PJ7DR
0
R/W
6
PJ6DR
0
R/W
Output data for a pin is stored when the pin is
specified as a general purpose output port.
5
PJ5DR
0
R/W
4
PJ4DR
0
R/W
3
PJ3DR
0
R/W
2
PJ2DR
0
R/W
1
PJ1DR
0
R/W
0
PJ0DR
0
R/W
9.16.3
Port J Register (PORTJ)
PORTJ shows port J pin states. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
PJ7
⎯*
R
6
PJ6
⎯*
R
5
PJ5
⎯*
R
If a port J read is performed while PJDDR bits are
set to 1, the PJDR values are read. If a port J read is
performed while PJDDR bits are cleared to 0, the pin
states are read.
4
PJ4
⎯*
R
3
PJ3
⎯*
R
2
PJ2
⎯*
R
1
PJ1
⎯*
R
0
PJ0
⎯*
R
Note:
*
Determined by the states of pins PJ7 to PJ0.
Rev. 6.00 Sep. 24, 2009 Page 262 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.16.4
Pin Functions
Port J pins also function as general purpose I/O pins. Port J pin functions are shown below.
• PJ7, PJ6, PJ5, PJ4, PJ3, PJ2, PJ1, PJ0
The pin function is switched as shown below according to the PJnDDR bit.
PJnDDR
Pin function
0
1
PJn input
PJn output
Note: n = 7 to 0
Rev. 6.00 Sep. 24, 2009 Page 263 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.17
Power Supply Pin Control
Drivability of output ports of which power is supplied by P1VCC or P2VCC is controlled.
9.17.1
IC Power Control Register (ICPCR)
ICPCR controls buffer drivability.
Bit
Bit Name
Initial
Value
R/W
Description
7 to 4
⎯
All 0
⎯
Reserved
This bit is readable/writable, but the write value
should always be 0.
3
BUFGC2
0
R/W
Buffer Gain Control 2
Controls drivability of output ports of which power is
supplied by P2VCC. This bit should be set according to
the voltage of P2VCC when a port is used as an output
port. If the bit setting is not appropriate, it may cause
malfunction or characteristics described in section 24,
Electrical Characteristics cannot be satisfied. For the
power supply pin, see table 1.1.
0: 4.5 V ≤ P2VCC ≤ 5.5 V
1: 3.0 V ≤ P2VCC ≤ 3.6 V
2
BUFGC1
0
R/W
Buffer Gain Control 1
Controls drivability of output ports of which power is
supplied by P1VCC. This bit should be set according to
the voltage of P1VCC when a port is used as an output
port. If the bit setting is not appropriate, it may cause
malfunction or characteristics described in section 24,
Electrical Characteristics cannot be satisfied. For the
power supply pin, see table 1.1.
0: 4.5 V ≤ P1VCC ≤ 5.5 V
1: 3.0 V ≤ P1VCC ≤ 3.6 V
1, 0
⎯
All 0
R/W
Reserved
These bits are readable/writable, but the write value
should always be 0.
Rev. 6.00 Sep. 24, 2009 Page 264 of 928
REJ09B0099-0600
Section 9 I/O Ports
9.18
Handling of Unused Pins
Unused input pins should be fixed high or low. Generally, the input pins of CMOS products are
high-impedance. Leaving unused pins open can cause the generation of intermediate levels due to
peripheral noise induction. This can result in shoot-through current inside the device and cause it
to malfunction. Table 9.7 lists examples of ways to handle unused pins.
Table 9.7
Examples of Ways to Handle Unused Input Pins
Port Name
Pin Handling Example
Port 1
Connect each pin to P2Vcc (pull-up) or to Vss (pull-down) via a resistor.
Port 2
Port 3
Port 4
Connect each pin to AVcc (pull-up) or to AVss (pull-down) via a resistor.
Port 5
Connect each pin to P1Vcc (pull-up) or to Vss (pull-down) via a resistor.
Port 7
Connect each pin to P2Vcc (pull-up) or to Vss (pull-down) via a resistor.
Port 9
Connect each pin to AVcc (pull-up) or to AVss (pull-down) via a resistor.
Port A
Connect each pin to P1Vcc (pull-up) or to Vss (pull-down) via a resistor.
Port B
Port C
Port D
Port E
Port F
Port G
Port H
Port J
Rev. 6.00 Sep. 24, 2009 Page 265 of 928
REJ09B0099-0600
Section 9 I/O Ports
Rev. 6.00 Sep. 24, 2009 Page 266 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Section 10 16-Bit Timer Pulse Unit (TPU)
This LSI has an on-chip 16-bit timer pulse unit (TPU) comprised of six 16-bit timer channels.
The function list of the 16-bit timer unit and its block diagram are shown in table 10.1 and figure
10.1, respectively.
10.1
Features
• Maximum 16-pulse input/output
• Selection of 8 counter input clocks for each channel
• The following operations can be set for each channel:
⎯ Waveform output at compare match
⎯ Input capture function
⎯ Counter clear operation
⎯ Synchronous operation:
Multiple timer counters (TCNT) can be written to simultaneously
Simultaneous clearing by compare match and input capture is possible
Register simultaneous input/output is possible by synchronous counter operation
⎯ A maximum 15-phase PWM output is possible in combination with synchronous operation
• Buffer operation settable for channels 0 and 3
• Phase counting mode settable independently for each of channels 1, 2, 4, and 5
• Cascaded operation
• Fast access via internal 16-bit bus
• 26 interrupt sources
• Automatic transfer of register data
• A/D converter conversion start trigger can be generated
• Module stop mode can be set
Rev. 6.00 Sep. 24, 2009 Page 267 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.1 TPU Functions
Item
Channel 0 Channel 1 Channel 2 Channel 3 Channel 4 Channel 5
Count clock
φ/1
φ/4
φ/16
φ/64
TCLKA
TCLKB
TCLKC
TCLKD
φ/1
φ/4
φ/16
φ/64
φ/256
TCLKA
TCLKB
φ/1
φ/4
φ/16
φ/64
φ/1024
TCLKA
TCLKB
TCLKC
φ/1
φ/4
φ/16
φ/64
φ/256
φ/1024
φ/4096
TCLKA
φ/1
φ/4
φ/16
φ/64
φ/1024
TCLKA
TCLKC
φ/1
φ/4
φ/16
φ/64
φ/256
TCLKA
TCLKC
TCLKD
General registers
(TGR)
TGRA_0
TGRB_0
TGRA_1
TGRB_1
TGRA_2
TGRB_2
TGRA_3
TGRB_3
TGRA_4
TGRB_4
TGRA_5
TGRB_5
General registers/
buffer registers
TGRC_0
TGRD_0
—
—
TGRC_3
TGRD_3
—
—
I/O pins
TIOCA0
TIOCB0
TIOCC0
TIOCD0
TIOCA1
TIOCB1
TIOCA2
TIOCB2
TIOCA3
TIOCB3
TIOCC3
TIOCD3
TIOCA4
TIOCB4
TIOCA5
TIOCB5
Counter clear
function
TGR
compare
match or
input
capture
TGR
compare
match or
input
capture
TGR
compare
match or
input
capture
TGR
compare
match or
input
capture
TGR
compare
match or
input
capture
TGR
compare
match or
input
capture
—
—
Compare 0 output
match
1 output
output
Toggle
output
Input capture
function
Synchronous
operation
PWM mode
Phase counting
mode
Buffer operation
—
—
—
Rev. 6.00 Sep. 24, 2009 Page 268 of 928
REJ09B0099-0600
—
Section 10 16-Bit Timer Pulse Unit (TPU)
Item
Channel 0
Channel 1
Channel 2
Channel 3
Channel 4
Channel 5
DTC
TGR
activation compare
match or
input
capture
TGR
compare
match or
input
capture
TGR
compare
match or
input
capture
TGR
compare
match or
input
capture
TGR
compare
match or
input
capture
TGR
compare
match or
input
capture
A/D
TGRA_0
converter compare
trigger
match or
input
capture
TGRA_1
compare
match or
input
capture
TGRA_2
compare
match or
input
capture
TGRA_3
compare
match or
input
capture
TGRA_4
compare
match or
input
capture
TGRA_5
compare
match or
input
capture
Interrupt
sources
4 sources
4 sources
5 sources
4 sources
4 sources
5 sources
•
Compare •
match or
input
capture
0A
Compare •
match or
input
capture
1A
Compare •
match or
input
capture
2A
Compare •
match or
input
capture
3A
Compare •
match or
input
capture
4A
Compare
match or
input
capture
5A
•
Compare •
match or
input
capture
0B
Compare •
match or
input
capture
1B
Compare •
match or
input
capture
2B
Compare •
match or
input
capture
3B
Compare •
match or
input
capture
4B
Compare
match or
input
capture
5B
•
Compare •
match or •
input
capture
0C
Overflow
•
Compare •
match or •
input
capture
3C
Overflow
•
Overflow
•
Underflow •
Overflow
Underflow
•
Compare
match or
input
capture
0D
•
Compare
match or
input
capture
3D
•
Overflow
•
Overflow
Underflow •
Underflow
Legend:
:
Possible
—:
Not possible
Rev. 6.00 Sep. 24, 2009 Page 269 of 928
REJ09B0099-0600
TGRD
TGRC
TGRB
TGRB
TGRB
TCNT
TGRA
TCNT
TGRA
TCNT
TGRA
Module data bus
Bus
interface
TGRB
TGRD
TGRB
TGRB
TGRC
TCNT
TCNT
TGRA
TCNT
TGRA
TSTR
TSR
TSR
TIER
TIER
TSR
TIOR
TIORH TIORL
A/D converter conversion start signal
Legend:
TSTR:
TSYR:
TCR:
TMDR:
Timer start register
Timer synchro register
Timer control register
Timer mode register
Timer I/O control registers (H, L)
TIOR (H, L)
Timer interrupt enable register
TIER:
Timer status register
TSR:
TGR (A, B, C, D): Timer general registers (A, B, C, D)
Timer counter
TCNT:
Figure 10.1 Block Diagram of TPU
Rev. 6.00 Sep. 24, 2009 Page 270 of 928
REJ09B0099-0600
Interrupt request signals
Channel 3: TGI3A
TGI3B
TGI3C
TGI3D
TCI3V
Channel 4: TGI4A
TGI4B
TCI4V
TCI4U
Channel 5: TGI5A
TGI5B
TCI5V
TCI5U
Internal data bus
TGRA
TSR
TIER
TSR
TSYR
TIER
TSR
TIER
TIOR
TIOR
Control logic
TIOR
TIER
TMDR
TIORH TIORL
TCR
TMDR
Channel 4
TCR
TMDR
TCR
Channel 5
Common
Channel 0
Channel 2:
Control logic for channels 0 to 2
Channel 1:
TIOCA0
TIOCB0
TIOCC0
TIOCD0
TIOCA1
TIOCB1
TIOCA2
TIOCB2
Channel 1
Input/output pins
Channel 0:
TMDR
Channel 2
External clock:
φ/1
φ/4
φ/16
φ/64
φ/256
φ/1024
φ/4096
TCLKA
TCLKB
TCLKC
TCLKD
TCR
Clock input
Internal clock:
TMDR
Channel 5:
TCR
Channel 4:
TIOCA3
TIOCB3
TIOCC3
TIOCD3
TIOCA4
TIOCB4
TIOCA5
TIOCB5
Control logic for channels 3 to 5
Channel 3:
TMDR
Input/output pins
TCR
Channel 3
Section 10 16-Bit Timer Pulse Unit (TPU)
Interrupt request signals
Channel 0: TGI0A
TGI0B
TGI0C
TGI0D
TCI0V
Channel 1: TGI1A
TGI1B
TCI1V
TCI1U
Channel 2: TGI2A
TGI2B
TCI2V
TCI2U
Section 10 16-Bit Timer Pulse Unit (TPU)
10.2
Input/Output Pins
Table 10.2 TPU Pins
Channel
I/O
Function
Common TCLKA
Input
External clock A input pin
(Channel 1 and 5 phase counting mode A phase input)
TCLKB
Input
External clock B input pin
(Channel 1 and 5 phase counting mode B phase input)
TCLKC
Input
External clock C input pin
(Channel 2 and 4 phase counting mode A phase input)
TCLKD
Input
External clock D input pin
(Channel 2 and 4 phase counting mode B phase input)
TIOCA0
I/O
TGRA_0 input capture input/output compare output/PWM
output pin
TIOCB0
I/O
TGRB_0 input capture input/output compare output/PWM
output pin
TIOCC0
I/O
TGRC_0 input capture input/output compare output/PWM
output pin
TIOCD0
I/O
TGRD_0 input capture input/output compare output/PWM
output pin
TIOCA1
I/O
TGRA_1 input capture input/output compare output/PWM
output pin
TIOCB1
I/O
TGRB_1 input capture input/output compare output/PWM
output pin
TIOCA2
I/O
TGRA_2 input capture input/output compare output/PWM
output pin
TIOCB2
I/O
TGRB_2 input capture input/output compare output/PWM
output pin
TIOCA3
I/O
TGRA_3 input capture input/output compare output/PWM
output pin
TIOCB3
I/O
TGRB_3 input capture input/output compare output/PWM
output pin
TIOCC3
I/O
TGRC_3 input capture input/output compare output/PWM
output pin
TIOCD3
I/O
TGRD_3 input capture input/output compare output/PWM
output pin
0
1
2
3
Symbol
Rev. 6.00 Sep. 24, 2009 Page 271 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Channel
Symbol
I/O
Function
4
TIOCA4
I/O
TGRA_4 input capture input/output compare output/PWM
output pin
TIOCB4
I/O
TGRB_4 input capture input/output compare output/PWM
output pin
TIOCA5
I/O
TGRA_5 input capture input/output compare output/PWM
output pin
TIOCB5
I/O
TGRB_5 input capture input/output compare output/PWM
output pin
5
Rev. 6.00 Sep. 24, 2009 Page 272 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.3
Register Descriptions
The TPU has the following registers. When the FLSHE bit in the system control register 2
(SYSCR2) is set to 1, some TPU control registers (H'FFFE80 to H'FFFEB1) cannot be accessed.
The FLSHE bit should be cleared to 0 before the TPU control register is accessed. For the system
control register 2, see System Control Register 2 (SYSCR2) in section 20.3.1,
Programming/Erasing Interface Register.
Channel 0
• Timer control register_0 (TCR_0)
• Timer mode register_0 (TMDR_0)
• Timer I/O control register H_0 (TIORH_0)
• Timer I/O control register L_0 (TIORL_0)
• Timer interrupt enable register_0 (TIER_0)
• Timer status register_0 (TSR_0)
• Timer counter_0 (TCNT_0)
• Timer general register A_0 (TGRA_0)
• Timer general register B_0 (TGRB_0)
• Timer general register C_0 (TGRC_0)
• Timer general register D_0 (TGRD_0)
Channel 1
• Timer control register_1 (TCR_1)
• Timer mode register_1 (TMDR_1)
• Timer I/O control register _1 (TIOR_1)
• Timer interrupt enable register_1 (TIER_1)
• Timer status register_1 (TSR_1)
• Timer counter_1 (TCNT_1)
• Timer general register A_1 (TGRA_1)
• Timer general register B_1 (TGRB_1)
Rev. 6.00 Sep. 24, 2009 Page 273 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Channel 2
• Timer control register_2 (TCR_2)
• Timer mode register_2 (TMDR_2)
• Timer I/O control register_2 (TIOR_2)
• Timer interrupt enable register_2 (TIER_2)
• Timer status register_2 (TSR_2)
• Timer counter_2 (TCNT_2)
• Timer general register A_2 (TGRA_2)
• Timer general register B_2 (TGRB_2)
Channel 3
• Timer control register_3 (TCR_3)
• Timer mode register_3 (TMDR_3)
• Timer I/O control register H_3 (TIORH_3)
• Timer I/O control register L_3 (TIORL_3)
• Timer interrupt enable register_3 (TIER_3)
• Timer status register_3 (TSR_3)
• Timer counter_3 (TCNT_3)
• Timer general register A_3 (TGRA_3)
• Timer general register B_3 (TGRB_3)
• Timer general register C_3 (TGRC_3)
• Timer general register D_3 (TGRD_3)
Channel 4
• Timer control register_4 (TCR_4)
• Timer mode register_4 (TMDR_4)
• Timer I/O control register _4 (TIOR_4)
• Timer interrupt enable register_4 (TIER_4)
• Timer status register_4 (TSR_4)
• Timer counter_4 (TCNT_4)
• Timer general register A_4 (TGRA_4)
• Timer general register B_4 (TGRB_4)
Rev. 6.00 Sep. 24, 2009 Page 274 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Channel 5
• Timer control register_5 (TCR_5)
• Timer mode register_5 (TMDR_5)
• Timer I/O control register_5 (TIOR_5)
• Timer interrupt enable register_5 (TIER_5)
• Timer status register_5 (TSR_5)
• Timer counter_5 (TCNT_5)
• Timer general register A_5 (TGRA_5)
• Timer general register B_5 (TGRB_5)
Common Registers
• Timer start register (TSTR)
• Timer synchro register (TSYR)
Rev. 6.00 Sep. 24, 2009 Page 275 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.3.1
Timer Control Register (TCR)
The TCR registers control the TCNT operation for each channel. The TPU has a total of six TCR
registers, one for each channel (channels 0 to 5). TCR register settings should be conducted only
when TCNT operation is stopped.
Bit
Bit Name
Initial
value
R/W
Description
7
CCLR2
0
R/W
Counter Clear 2 to 0
6
CCLR1
0
R/W
5
CCLR0
0
R/W
These bits select the TCNT counter clearing source. See
tables 10.3 and 10.4 for details.
4
CKEG1
0
R/W
Clock Edge 1 and 0
3
CKEG0
0
R/W
These bits select the input clock edge. When the input
clock is counted using both edges, the input clock period is
halved (e.g. φ/4 both edges = φ/2 rising edge). If phase
counting mode is used on channels 1, 2, 4, and 5, this
setting is ignored and the phase counting mode setting
has priority. Internal clock edge selection is valid when the
input clock is φ/4 or slower. This setting is ignored if the
input clock is φ/1, or when overflow/underflow of another
channel is selected. (The clock is counted at the falling
edge when φ/1 is selected.)
00: Count at rising edge
01: Count at falling edge
1X: Count at both edges
Legend:
X: Don’t care
2
TPSC2
0
R/W
Time Prescaler 2 to 0
1
TPSC1
0
R/W
0
TPSC0
0
R/W
These bits select the TCNT counter clock. The clock
source can be selected independently for each channel.
See tables 10.5 to 10.10 for details.
Rev. 6.00 Sep. 24, 2009 Page 276 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.3 CCLR0 to CCLR2 (channels 0 and 3)
Channel
Bit 7
CCLR2
Bit 6
CCLR1
Bit 5
CCLR0
Description
0, 3
0
0
0
TCNT clearing disabled
1
TCNT cleared by TGRA compare match/input
capture
0
TCNT cleared by TGRB compare match/input
capture
1
TCNT cleared by counter clearing for another
channel performing synchronous clearing/
1
synchronous operation*
0
TCNT clearing disabled
1
TCNT cleared by TGRC compare match/input
2
capture*
0
TCNT cleared by TGRD compare match/input
capture*2
1
TCNT cleared by counter clearing for another
channel performing synchronous clearing/
synchronous operation*1
1
1
0
1
Notes: 1. Synchronous operation is set by setting the SYNC bit in TSYR to 1.
2. When TGRC or TGRD is used as a buffer register, TCNT is not cleared because the
buffer register setting has priority, and compare match/input capture does not occur.
Table 10.4 CCLR0 to CCLR2 (channels 1, 2, 4, and 5)
Channel
Bit 7
Bit 6
Reserved*2 CCLR1
Bit 5
CCLR0
Description
1, 2, 4, 5
0
0
TCNT clearing disabled
1
TCNT cleared by TGRA compare match/input
capture
0
TCNT cleared by TGRB compare match/input
capture
1
TCNT cleared by counter clearing for another
channel performing synchronous clearing/
1
synchronous operation*
0
1
Notes: 1. Synchronous operation is selected by setting the SYNC bit in TSYR to 1.
2. Bit 7 is reserved in channels 1, 2, 4, and 5. It is always read as 0 and cannot be
modified.
Rev. 6.00 Sep. 24, 2009 Page 277 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.5 TPSC0 to TPSC2 (channel 0)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
0
0
0
0
Internal clock: counts on φ/1
1
Internal clock: counts on φ/4
0
Internal clock: counts on φ/16
1
Internal clock: counts on φ/64
0
External clock: counts on TCLKA pin input
1
External clock: counts on TCLKB pin input
1
1
0
1
0
External clock: counts on TCLKC pin input
1
External clock: counts on TCLKD pin input
Table 10.6 TPSC0 to TPSC2 (channel 1)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
1
0
0
0
Internal clock: counts on φ/1
1
Internal clock: counts on φ/4
0
Internal clock: counts on φ/16
1
Internal clock: counts on φ/64
0
External clock: counts on TCLKA pin input
1
External clock: counts on TCLKB pin input
0
Internal clock: counts on φ/256
1
Counts on TCNT2 overflow/underflow
1
1
0
1
Note: This setting is ignored when channel 1 is in phase counting mode.
Rev. 6.00 Sep. 24, 2009 Page 278 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.7 TPSC0 to TPSC2 (channels 2)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
2
0
0
0
Internal clock: counts on φ/1
1
Internal clock: counts on φ/4
0
Internal clock: counts on φ/16
1
Internal clock: counts on φ/64
0
External clock: counts on TCLKA pin input
1
External clock: counts on TCLKB pin input
1
1
0
1
0
External clock: counts on TCLKC pin input
1
Internal clock: counts on φ/1024
Note: This setting is ignored when channel 2 is in phase counting mode.
Table 10.8 TPSC0 to TPSC2 (channel 3)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
3
0
0
0
Internal clock: counts on φ/1
1
Internal clock: counts on φ/4
0
Internal clock: counts on φ/16
1
Internal clock: counts on φ/64
0
External clock: counts on TCLKA pin input
1
Internal clock: counts on φ/1024
0
Internal clock: counts on φ/256
1
Internal clock: counts on φ/4096
1
1
0
1
Rev. 6.00 Sep. 24, 2009 Page 279 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.9 TPSC0 to TPSC2 (channel 4)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
4
0
0
0
Internal clock: counts on φ/1
1
Internal clock: counts on φ/4
0
Internal clock: counts on φ/16
1
Internal clock: counts on φ/64
0
External clock: counts on TCLKA pin input
1
External clock: counts on TCLKC pin input
1
1
0
1
0
Internal clock: counts on φ/1024
1
Counts on TCNT5 overflow/underflow
Note: This setting is ignored when channel 4 is in phase counting mode.
Table 10.10 TPSC0 to TPSC2 (channel 5)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
5
0
0
0
Internal clock: counts on φ/1
1
Internal clock: counts on φ/4
0
Internal clock: counts on φ/16
1
Internal clock: counts on φ/64
0
External clock: counts on TCLKA pin input
1
External clock: counts on TCLKC pin input
0
Internal clock: counts on φ/256
1
External clock: counts on TCLKD pin input
1
1
0
1
Note: This setting is ignored when channel 5 is in phase counting mode.
Rev. 6.00 Sep. 24, 2009 Page 280 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.3.2
Timer Mode Register (TMDR)
The TMDR registers are used to set the operating mode of each channel. The TPU has six TMDR
registers, one for each channel. TMDR register settings should be changed only when TCNT
operation is stopped.
Bit
Bit Name
Initial
value
R/W
Description
7, 6
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
5
BFB
0
R/W
Buffer Operation B
Specifies whether TGRB is to operate in the normal way,
or TGRB and TGRD are to be used together for buffer
operation. When TGRD is used as a buffer register, TGRD
input capture/output compare is not generated.
In channels 1, 2, 4, and 5, which have no TGRD, bit 5 is
reserved. It is always read as 0 and cannot be modified.
0: TGRB operates normally
1: TGRB and TGRD are used together for buffer operation
4
BFA
0
R/W
Buffer Operation A
Specifies whether TGRA is to operate in the normal way,
or TGRA and TGRC are to be used together for buffer
operation. When TGRC is used as a buffer register, TGRC
input capture/output compare is not generated.
In channels 1, 2, 4, and 5, which have no TGRC, bit 4 is
reserved. It is always read as 0 and cannot be modified.
0: TGRA operates normally
1:TGRA and TGRC are used together for buffer operation
3
MD3
0
R/W
Modes 3 to 0
2
MD2
0
R/W
These bits are used to set the timer operating mode.
1
MD1
0
R/W
0
MD0
0
R/W
MD3 is a reserved bit. In a write, it should always be
written with 0. See table 10.11 for details.
Rev. 6.00 Sep. 24, 2009 Page 281 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.11 MD0 to MD3
Bit 3
MD3*1
Bit 2
MD2*2
Bit 1
MD1
Bit 0
MD0
Description
0
0
0
0
Normal operation
1
Reserved
0
PWM mode 1
1
PWM mode 2
0
Phase counting mode 1
1
Phase counting mode 2
1
1
0
1
1
X
X
0
Phase counting mode 3
1
Phase counting mode 4
X
—
Legend:
X:
Don’t care
Notes: 1. MD3 is a reserved bit. In a write, it should always be written with 0.
2. Phase counting mode cannot be set for channels 0 and 3. In this case, 0 should always
be written to MD2.
10.3.3
Timer I/O Control Register (TIOR)
The TIOR registers control the TGR registers. The TPU has eight TIOR registers, two each for
channels 0 and 3, and one each for channels 1, 2, 4, and 5. Care is required as TIOR is affected by
the TMDR setting.
The initial output specified by TIOR is valid when the counter is stopped (the CST bit in TSTR is
cleared to 0). Note also that, in PWM mode 2, the output at the point at which the counter is
cleared to 0 is specified.
When TGRC or TGRD is designated for buffer operation, this setting is invalid and the register
operates as a buffer register.
Rev. 6.00 Sep. 24, 2009 Page 282 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
• TIORH_0, TIOR_1, TIOR_2, TIORH_3, TIOR_4, TIOR_5
Bit
Bit Name
Initial
value
R/W
Description
7
IOB3
0
R/W
I/O Control B3 to B0
6
IOB2
0
R/W
5
IOB1
0
R/W
Specify the function of TGRB. See tables 10.12, 10.14,
10.15, 10.16, 10.18, and 10.19 for details.
4
IOB0
0
R/W
3
IOA3
0
R/W
I/O Control A3 to A0
2
IOA2
0
R/W
1
IOA1
0
R/W
Specify the function of TGRA. See tables 10.20, 10,22,
10.23, 10.24, 10.26, and 10.27 for details.
0
IOA0
0
R/W
• TIORL_0, TIORL_3
Bit
Bit Name
Initial
value
R/W
Description
7
IOD3
0
R/W
I/O Control D3 to D0
6
IOD2
0
R/W
5
IOD1
0
R/W
Specify the function of TGRD. See tables 10.13, and 10.17
for details.
4
IOD0
0
R/W
3
IOC3
0
R/W
I/O Control C3 to C0
2
IOC2
0
R/W
1
IOC1
0
R/W
Specify the function of TGRC. See tables 10.21, and 10.25
for details.
0
IOC0
0
R/W
Rev. 6.00 Sep. 24, 2009 Page 283 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.12 TIORH_0
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_0
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
0
1
TIOCB0 Pin Function
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCB0 pin
register
Input capture at rising edge
1
Capture input source is TIOCB0 pin
Input capture at falling edge
1
X
Capture input source is TIOCB0 pin
Input capture at both edges
X
X
Capture input source is channel 1/count clock
Input capture at TCNT_1 count-up/count-down*
0
Legend:
X:
Don’t care
Note: * When the TPSC0 to TPSC2 bits in TCR_1 are set to B'000 and φ/1 is used as the
TCNT_1 count clock, this setting is invalid and input capture is not generated.
Rev. 6.00 Sep. 24, 2009 Page 284 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.13 TIORL_0
Description
Bit 7
IOD3
Bit 6
IOD2
Bit 5
IOD1
Bit 4
IOD0
TGRD_0
Function
0
0
0
0
Output
compare
register*2
1
1
1
0
1
1
0
1
0
TIOCD0 Pin Function
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCD0 pin
register*2
Input capture at rising edge
1
Capture input source is TIOCD0 pin
Input capture at falling edge
1
X
Capture input source is TIOCD0 pin
Input capture at both edges
X
X
Capture input source is channel 1/count clock
Input capture at TCNT_1 count-up/count-down*1
Legend:
X:
Don’t care
Notes: 1. When the TPSC0 to TPSC2 bits in TCR_1 are set to B'000 and φ/1 is used as the
TCNT_1 count clock, this setting is invalid and input capture is not generated.
2. When the BFB bit in TMDR_0 is set to 1 and TGRD_0 is used as a buffer register, this
setting is invalid and input capture/output compare is not generated.
Rev. 6.00 Sep. 24, 2009 Page 285 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.14 TIOR_1
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_1
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
0
1
0
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCB1 pin
register
Input capture at rising edge
1
Capture input source is TIOCB1 pin
Input capture at falling edge
1
X
Capture input source is TIOCB1 pin
Input capture at both edges
X
X
TGRC_0 compare match/ input capture
Input capture at generation of TGRC_0 compare
match/input capture
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 286 of 928
REJ09B0099-0600
TIOCB1 Pin Function
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.15 TIOR_2
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_2
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
X
0
1
TIOCB2 Pin Function
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCB2 pin
register
Input capture at rising edge
1
Capture input source is TIOCB2 pin
Input capture at falling edge
X
Capture input source is TIOCB2 pin
Input capture at both edges
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 287 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.16 TIORH_3
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_3
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
0
1
0
TIOCB3 Pin Function
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCB3 pin
register
Input capture at rising edge
1
Capture input source is TIOCB3 pin
Input capture at falling edge
1
X
Capture input source is TIOCB3 pin
Input capture at both edges
X
X
Capture input source is channel 4/count clock
Input capture at TCNT_4 count-up/count-down*
Legend:
X:
Don’t care
Note: * When the TPSC0 to TPSC2 bits in TCR_4 are set to B'000 and φ/1 is used as the
TCNT_4 count clock, this setting is invalid and input capture is not generated.
Rev. 6.00 Sep. 24, 2009 Page 288 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.17 TIORL_3
Description
Bit 7
IOD3
Bit 6
IOD2
Bit 5
IOD1
Bit 4
IOD0
TGRD_3
Function
0
0
0
0
Output
compare
register*2
1
1
1
0
1
1
0
1
0
TIOCD3 Pin Function
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCD3 pin
register*2
Input capture at rising edge
1
Capture input source is TIOCD3 pin
Input capture at falling edge
1
X
Capture input source is TIOCD3 pin
Input capture at both edges
X
X
Capture input source is channel 4/count clock
Input capture at TCNT_4 count-up/count-down*1
Legend:
X:
Don’t care
Notes: 1. When the TPSC0 to TPSC2 bits in TCR_4 are set to B'000 and φ/1 is used as the
TCNT_4 count clock, this setting is invalid and input capture is not generated.
2. When the BFB bit in TMDR_3 is set to 1 and TGRD_3 is used as a buffer register, this
setting is invalid and input capture/output compare is not generated.
Rev. 6.00 Sep. 24, 2009 Page 289 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.18 TIOR_4
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_4
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
0
1
0
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCB4 pin
register
Input capture at rising edge
1
Capture input source is TIOCB4 pin
Input capture at falling edge
1
X
Capture input source is TIOCB4 pin
Input capture at both edges
X
X
Capture input source is TGRC_3 compare
match/input capture
Input capture at generation of TGRC_3 compare
match/input capture
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 290 of 928
REJ09B0099-0600
TIOCB4 Pin Function
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.19 TIOR_5
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_5
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
X
0
1
TIOCB5 Pin Function
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCB5 pin
register
Input capture at rising edge
1
Capture input source is TIOCB5 pin
Input capture at falling edge
X
Capture input source is TIOCB5 pin
Input capture at both edges
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 291 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.20 TIORH_0
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_0
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
0
1
0
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCA0 pin
register
Input capture at rising edge
1
Capture input source is TIOCA0 pin
Input capture at falling edge
1
X
Capture input source is TIOCA0 pin
Input capture at both edges
X
X
Capture input source is channel 1/count clock
Input capture at TCNT_1 count-up/count-down
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 292 of 928
REJ09B0099-0600
TIOCA0 Pin Function
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.21 TIORL_0
Description
Bit 3
IOC3
Bit 2
IOC2
Bit 1
IOC1
Bit 0
IOC0
TGRC_0
Function
0
0
0
0
Output
compare
register*
1
1
1
0
1
1
0
1
0
TIOCC0 Pin Function
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCC0 pin
register*
Input capture at rising edge
1
Capture input source is TIOCC0 pin
Input capture at falling edge
1
X
Capture input source is TIOCC0 pin
Input capture at both edges
X
X
Capture input source is channel 1/count clock
Input capture at TCNT_1 count-up/count-down
Legend:
X:
Don’t care
Note: * When the BFA bit in TMDR_0 is set to 1 and TGRC_0 is used as a buffer register, this
setting is invalid and input capture/output compare is not generated.
Rev. 6.00 Sep. 24, 2009 Page 293 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.22 TIOR_1
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_1
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
0
1
0
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCA1 pin
register
Input capture at rising edge
1
Capture input source is TIOCA1 pin
Input capture at falling edge
1
X
Capture input source is TIOCA1 pin
Input capture at both edges
X
X
Capture input source is TGRA_0 compare
match/input capture
Input capture at generation of channel 0/TGRA_0
compare match/input capture
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 294 of 928
REJ09B0099-0600
TIOCA1 Pin Function
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.23 TIOR_2
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_2
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
X
0
1
TIOCA2 Pin Function
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCA2 pin
register
Input capture at rising edge
1
Capture input source is TIOCA2 pin
Input capture at falling edge
X
Capture input source is TIOCA2 pin
Input capture at both edges
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 295 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.24 TIORH_3
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_3
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
0
1
0
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCA3 pin
register
Input capture at rising edge
1
Capture input source is TIOCA3 pin
Input capture at falling edge
1
X
Capture input source is TIOCA3 pin
Input capture at both edges
X
X
Capture input source is channel 4/count clock
Input capture at TCNT_4 count-up/count-down
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 296 of 928
REJ09B0099-0600
TIOCA3 Pin Function
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.25 TIORL_3
Description
Bit 3
IOC3
Bit 2
IOC2
Bit 1
IOC1
Bit 0
IOC0
TGRC_3
Function
0
0
0
0
Output
compare
register*
1
1
1
0
1
1
0
1
0
TIOCC3 Pin Function
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCC3 pin
register*
Input capture at rising edge
1
Capture input source is TIOCC3 pin
Input capture at falling edge
1
X
Capture input source is TIOCC3 pin
Input capture at both edges
X
X
Capture input source is channel 4/count clock
Input capture at TCNT_4 count-up/count-down
Legend:
X:
Don’t care
Note: * When the BFA bit in TMDR_3 is set to 1 and TGRC_3 is used as a buffer register, this
setting is invalid and input capture/output compare is not generated.
Rev. 6.00 Sep. 24, 2009 Page 297 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.26 TIOR_4
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_4
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
0
1
0
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCA4 pin
register
Input capture at rising edge
1
Capture input source is TIOCA4 pin
Input capture at falling edge
1
X
Capture input source is TIOCA4 pin
Input capture at both edges
X
X
Capture input source is TGRA_3 compare
match/input capture
Input capture at generation of TGRA_3 compare
match/input capture
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 298 of 928
REJ09B0099-0600
TIOCA4 Pin Function
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.27 TIOR_5
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_5
Function
0
0
0
0
Output
compare
register
1
1
1
0
1
1
X
0
1
TIOCA5 Pin Function
Output disabled
Initial output is 0
0 output at compare match
0
Initial output is 0
1 output at compare match
1
Initial output is 0
Toggle output at compare match
0
Output disabled
1
Initial output is 1
0 output at compare match
0
Initial output is 1
1 output at compare match
1
Initial output is 1
Toggle output at compare match
0
Input capture Capture input source is TIOCA5 pin
register
Input capture at rising edge
1
Capture input source is TIOCA5 pin
Input capture at falling edge
X
Capture input source is TIOCA5 pin
Input capture at both edges
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 299 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.3.4
Timer Interrupt Enable Register (TIER)
The TIER registers control enabling or disabling of interrupt requests for each channel. The TPU
has six TIER registers, one for each channel.
Bit
Bit Name
Initial
value
R/W
Description
7
TTGE
0
R/W
A/D Conversion Start Request Enable
Enables or disables generation of A/D conversion start
requests by TGRA input capture/compare match.
0: A/D conversion start request generation disabled
1: A/D conversion start request generation enabled
6
⎯
1
⎯
Reserved
This bit is always read as 1 and cannot be modified.
5
TCIEU
0
R/W
Underflow Interrupt Enable
Enables or disables interrupt requests (TCIU) by the TCFU
flag when the TCFU flag in TSR is set to 1 in channels 1, 2,
4, and 5.
In channels 0 and 3, bit 5 is reserved. It is always read as 0
and cannot be modified.
0: Interrupt requests (TCIU) by TCFU disabled
1: Interrupt requests (TCIU) by TCFU enabled
4
TCIEV
0
R/W
Overflow Interrupt Enable
Enables or disables interrupt requests (TCIV) by the TCFV
flag when the TCFV flag in TSR is set to 1.
0: Interrupt requests (TCIV) by TCFV disabled
1: Interrupt requests (TCIV) by TCFV enabled
3
TGIED
0
R/W
TGR Interrupt Enable D
Enables or disables interrupt requests (TGID) by the TGFD
bit when the TGFD bit in TSR is set to 1 in channels 0 and
3.
In channels 1, 2, 4, and 5, bit 3 is reserved. It is always
read as 0 and cannot be modified.
0: Interrupt requests (TGID) by TGFD bit disabled
1: Interrupt requests (TGID) by TGFD bit enabled
Rev. 6.00 Sep. 24, 2009 Page 300 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Bit
Bit Name
Initial
value
R/W
Description
2
TGIEC
0
R/W
TGR Interrupt Enable C
Enables or disables interrupt requests (TGIC) by the TGFC
bit when the TGFC bit in TSR is set to 1 in channels 0 and
3.
In channels 1, 2, 4, and 5, bit 2 is reserved. It is always
read as 0 and cannot be modified.
0: Interrupt requests (TGIC) by TGFC bit disabled
1: Interrupt requests (TGIC) by TGFC bit enabled
1
TGIEB
0
R/W
TGR Interrupt Enable B
Enables or disables interrupt requests (TGIB) by the TGFB
bit when the TGFB bit in TSR is set to 1.
0: Interrupt requests (TGIB) by TGFB bit disabled
1: Interrupt requests (TGIB) by TGFB bit enabled
0
TGIEA
0
R/W
TGR Interrupt Enable A
Enables or disables interrupt requests (TGIA) by the TGFA
bit when the TGFA bit in TSR is set to 1.
0: Interrupt requests (TGIA) by TGFA bit disabled
1: Interrupt requests (TGIA) by TGFA bit enabled
Rev. 6.00 Sep. 24, 2009 Page 301 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.3.5
Timer Status Register (TSR)
The TSR registers indicate the status of each channel. The TPU has six TSR registers, one for each
channel.
Bit
Bit Name
Initial
value
R/W
Description
7
TCFD
1
R
Count Direction Flag
Status flag that shows the direction in which TCNT counts
in channels 1, 2, 4, and 5.
In channels 0 and 3, bit 7 is reserved. It is always read as 1
and cannot be modified.
0: TCNT counts down
1: TCNT counts up
6
⎯
1
⎯
Reserved
This bit is always read as 1 and cannot be modified.
5
TCFU
0
R/(W)* Underflow Flag
Status flag that indicates that TCNT underflow has
occurred when channels 1, 2, 4, and 5 are set to phase
counting mode. Only 0 can be written, for flag clearing.
In channels 0 and 3, bit 5 is reserved. It is always read as 0
and cannot be modified.
[Setting condition]
When the TCNT value underflows (changes from H'0000 to
H'FFFF)
[Clearing condition]
When 0 is written to TCFU after reading TCFU = 1
4
TCFV
0
R/(W)* Overflow Flag
Status flag that indicates that TCNT overflow has occurred.
Only 0 can be written, for flag clearing.
[Setting condition]
When the TCNT value overflows (changes from H'FFFF to
H'0000 )
[Clearing condition]
When 0 is written to TCFV after reading TCFV = 1
Rev. 6.00 Sep. 24, 2009 Page 302 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Bit
Bit Name
Initial
value
R/W
3
TGFD
0
R/(W)* Input Capture/Output Compare Flag D
Description
Status flag that indicates the occurrence of TGRD input
capture or compare match in channels 0 and 3. Only 0 can
be written, for flag clearing. In channels 1, 2, 4, and 5, bit 3
is reserved. It is always read as 0 and cannot be modified.
[Setting conditions]
•
When TCNT = TGRD and TGRD is functioning as
output compare register
•
When TCNT value is transferred to TGRD by input
capture signal and TGRD is functioning as input
capture register
[Clearing conditions]
2
TGFC
0
•
When DTC is activated by TGID interrupt, the DISEL bit
of MRB in DTC is 0 with the transfer counter other than
0
•
When 0 is written to TGFD after reading TGFD = 1
R/(W)* Input Capture/Output Compare Flag C
Status flag that indicates the occurrence of TGRC input
capture or compare match in channels 0 and 3. Only 0 can
be written, for flag clearing. In channels 1, 2, 4, and 5, bit 2
is reserved. It is always read as 0 and cannot be modified.
[Setting conditions]
•
When TCNT = TGRC and TGRC is functioning as
output compare register
•
When TCNT value is transferred to TGRC by input
capture signal and TGRC is functioning as input
capture register
[Clearing conditions]
•
When DTC is activated by TGIC interrupt, the DISEL bit
of MRB in DTC is 0 with the transfer counter other than
0
•
When 0 is written to TGFC after reading TGFC = 1
Rev. 6.00 Sep. 24, 2009 Page 303 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Bit
Bit Name
Initial
value
R/W
1
TGFB
0
R/(W)* Input Capture/Output Compare Flag B
Description
Status flag that indicates the occurrence of TGRB input
capture or compare match. Only 0 can be written, for flag
clearing.
[Setting conditions]
•
When TCNT = TGRB and TGRB is functioning as
output compare register
•
When TCNT value is transferred to TGRB by input
capture signal and TGRB is functioning as input
capture register
[Clearing conditions]
0
TGFA
0
•
When DTC is activated by TGIB interrupt, the DISEL bit
of MRB in DTC is 0 with the transfer counter other than
0
•
When 0 is written to TGFB after reading TGFB = 1
R/(W)* Input Capture/Output Compare Flag A
Status flag that indicates the occurrence of TGRA input
capture or compare match. Only 0 can be written, for flag
clearing.
[Setting conditions]
•
When TCNT = TGRA and TGRA is functioning as
output compare register
•
When TCNT value is transferred to TGRA by input
capture signal and TGRA is functioning as input
capture register
[Clearing conditions]
Note:
*
•
When DTC is activated by TGIA interrupt, the DISEL bit
of MRB in DTC is 0 with the transfer counter other than
0
•
When 0 is written to TGFA after reading TGFA = 1
Only 0 can be written to this bit to clear the flag.
Rev. 6.00 Sep. 24, 2009 Page 304 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.3.6
Timer Counter (TCNT)
The TCNT registers are 16-bit readable/writable counters. The TPU has six TCNT counters, one
for each channel.
The TCNT counters are initialized to H'0000 by a reset, and in hardware standby mode.
The TCNT counters cannot be accessed in 8-bit units; they must always be accessed as a 16-bit
unit.
10.3.7
Timer General Register (TGR)
The TGR registers are dual function 16-bit readable/writable registers, functioning as either output
compare or input capture registers. The TPU has 16 TGR registers, four each for channels 0 and 3
and two each for channels 1, 2, 4, and 5. TGRC and TGRD for channels 0 and 3 can also be
designated for operation as buffer registers. The TGR registers cannot be accessed in 8-bit units;
they must always be accessed as a 16-bit unit. TGR buffer register combinations are TGRA—
TGRC and TGRB—TGRD.
10.3.8
Timer Start Register (TSTR)
TSTR specifies whether to operate or stop TCNT for channels 0 to 5. When setting the operating
mode in TMDR or setting the count clock in TCR, first stop the TCNT counter.
Bit
Bit Name
Initial
value
R/W
Description
7, 6
⎯
All 0
⎯
Reserved
Only 0 should be written to these bits.
5
CST5
0
R/W
Counter Start 5 to 0
4
CST4
0
R/W
These bits specify whether to operate or stop TCNT.
3
CST3
0
R/W
2
CST2
0
R/W
1
CST1
0
R/W
0
CST0
0
R/W
If 0 is written to the CST bit during operation with the TIOC
pin designated for output, the counter stops but the TIOC
pin output compare output level is retained. If TIOR is
written to when the CST bit is cleared to 0, the pin output
level will be changed to the set initial output value.
0: TCNT_0 to TCNT_5 count operation is stopped
1: TCNT_0 to TCNT_5 performs count operation
Rev. 6.00 Sep. 24, 2009 Page 305 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.3.9
Timer Synchro Register (TSYR)
TSYR selects the independent operation or synchronous operation of TCNT for channels 0 to 5. A
channel performs synchronous operation when the corresponding bit in TSYR is set to 1.
Bit
Bit Name
Initial
value
R/W
Description
7, 6
⎯
All 0
⎯
Reserved
5
SYNC5
0
R/W
Timer Synchro 5 to 0
4
SYNC4
0
R/W
3
SYNC3
0
R/W
These bits are used to select the independent or
synchronized operation with other channels.
2
SYNC2
0
R/W
1
SYNC1
0
R/W
0
SYNC0
0
R/W
Only 0 should be written to these bits.
When synchronous operation is selected, the TCNT
synchronous presetting of multiple channels, and
synchronous clearing by counter clearing on another
channel, are possible.
To set synchronous operation, the SYNC bits for at least
two channels must be set to 1. To set synchronous
clearing, in addition to the SYNC bit , the TCNT clearing
source must also be set by means of the CCLR0 to CCLR2
bits in TCR.
0: TCNT_0 to TCNT_5 operates independently (TCNT
presetting /clearing is unrelated to other channels)
1: TCNT_0 to TCNT_5 performs synchronous operation.
TCNT synchronous presetting/synchronous clearing is
possible.
Rev. 6.00 Sep. 24, 2009 Page 306 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.4
Operation
10.4.1
Basic Functions
Each channel has a TCNT and TGR register. TCNT performs up-counting, and is also capable of
free-running operation, synchronous counting, and external event counting.
Each TGR can be used as an input capture register or output compare register.
Counter Operation: When one of the CST0 to CST5 bits is set to 1 in TSTR, the TCNT counter
for the corresponding channel begins counting. TCNT can operate as a free-running counter,
periodic counter, for example.
1. Example of count operation setting procedure
Figure 10.2 shows an example of the count operation setting procedure.
Operation selection
Select counter clock
[1]
Periodic counter
Select counter clearing source
Free-running counter
[2]
[3]
Select output compare register
Set period
[4]
Start count operation
[5]
<Periodic counter>
Start count operation
<Free-running counter>
[5]
[1] Select the counter
clock with the TPSC2 to
TPSC0 bits in
TCR. At the same
time, select the
input clock edge
with the CKEG1 and CKEG0
bits in TCR.
[2] For periodic counter
operation, select the
TGR to be used as
the TCNT clearing
source with the CCLR2 to
CCLR0 bits in TCR.
[3] Designate the TGR
selected in [2] as an
output compare
register by means of
TIOR.
[4] Set the periodic
counter cycle in the
TGR selected in [2].
[5] Set the CST bit in
TSTR to 1 to start
the counter operation.
Figure 10.2 Example of Counter Operation Setting Procedure
Rev. 6.00 Sep. 24, 2009 Page 307 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
2. Free-running count operation and periodic count operation
Immediately after a reset, the TPU’s TCNT counters are all designated as free-running
counters. When the relevant bit in TSTR is set to 1 the corresponding TCNT counter starts upcount operation as a free-running counter. When TCNT overflows (from H'FFFF to H'0000),
the TCFV bit in TSR is set to 1. If the value of the corresponding TCIEV bit in TIER is 1 at
this point, the TPU requests an interrupt. After overflow, TCNT starts counting up again from
H'0000.
Figure 10.3 illustrates free-running counter operation.
TCNT value
H'FFFF
H'0000
Time
CST bit
TCFV
Figure 10.3 Free-Running Counter Operation
When compare match is selected as the TCNT clearing source, the TCNT counter for the
relevant channel performs periodic count operation. The TGR register for setting the period is
designated as an output compare register, and counter clearing by compare match is selected
by means of the CCLR0 to CCLR2 bits in TCR. After the settings have been made, TCNT
starts up-count operation as a periodic counter when the corresponding bit in TSTR is set to 1.
When the count value matches the value in TGR, the TGF bit in TSR is set to 1 and TCNT is
cleared to H'0000.
If the value of the corresponding TGIE bit in TIER is 1 at this point, the TPU requests an
interrupt. After a compare match, TCNT starts counting up again from H'0000.
Figure 10.4 illustrates periodic counter operation.
Rev. 6.00 Sep. 24, 2009 Page 308 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
TCNT value
TGR
Counter cleared by TGR
compare match
H'0000
Time
CST bit
Flag cleared by software or
DTC activation
TGF
Figure 10.4 Periodic Counter Operation
Rev. 6.00 Sep. 24, 2009 Page 309 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Waveform Output by Compare Match: The TPU can perform 0, 1, or toggle output from the
corresponding output pin using compare match.
1. Example of setting procedure for waveform output by compare match
Figure 10.5 shows an example of the setting procedure for waveform output by compare
match.
Output selection
Select waveform output mode
[1]
Set output timing
[2]
Start count operation
[3]
[1] Select initial value 0 output or 1 output, and
compare match output value 0 output, 1 output,
or toggle output, by means of TIOR. The set
initial value is output at the TIOC pin unit the
first compare match occurs.
[2] Set the timing for compare match generation in
TGR.
[3] Set the CST bit in TSTR to 1 to start the count
operation.
<Waveform output>
Figure 10.5 Example of Setting Procedure for Waveform Output by Compare Match
2. Examples of waveform output operation
Figure 10.6 shows an example of 0 output/1 output.
In this example TCNT has been designated as a free-running counter, and settings have been
made such that 1 is output by compare match A, and 0 is output by compare match B. When
the set level and the pin level coincide, the pin level does not change.
Rev. 6.00 Sep. 24, 2009 Page 310 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
TCNT value
H'FFFF
TGRA
TGRB
Time
H'0000
No change
No change
1 output
TIOCA
TIOCB
No change
No change
0 output
Figure 10.6 Example of 0 Output/1 Output Operation
Figure 10.7 shows an example of toggle output.
In this example, TCNT has been designated as a periodic counter (with counter clearing on
compare match B), and settings have been made such that the output is toggled by both
compare match A and compare match B.
TCNT value
Counter cleared by TGRB compare match
H'FFFF
TGRB
TGRA
Time
H'0000
Toggle output
TIOCB
Toggle output
TIOCA
Figure 10.7 Example of Toggle Output Operation
Input Capture Function: The TCNT value can be transferred to TGR on detection of the TIOC
pin input edge.
Rising edge, falling edge, or both edges can be selected as the detected edge. For channels 0, 1, 3,
and 4, it is also possible to specify another channel's counter input clock or compare match signal
as the input capture source.
Note: When another channel's counter input clock is used as the input capture input for channels
0 and 3, φ/1 should not be selected as the counter input clock used for input capture input.
Input capture will not be generated if φ/1 is selected.
Rev. 6.00 Sep. 24, 2009 Page 311 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
1. Example of input capture operation setting procedure
Figure 10.8 shows an example of the input capture operation setting procedure.
Input selection
Select input capture input
Start count
[1] Designate TGR as an input capture register by
means of TIOR, and select rising edge, falling
edge, or both edges as the input capture source
and input signal edge.
[2] Set the CST bit in TSTR to 1 to start the count
operation.
[1]
[2]
<Input capture operation>
Figure 10.8 Example of Input Capture Operation Setting Procedure
2. Example of input capture operation
Figure 10.9 shows an example of input capture operation.
In this example both rising and falling edges have been selected as the TIOCA pin input
capture input edge, the falling edge has been selected as the TIOCB pin input capture input
edge, and counter clearing by TGRB input capture has been designated for TCNT.
Rev. 6.00 Sep. 24, 2009 Page 312 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Counter cleared by TIOCB
input (falling edge)
TCNT value
H'0180
H'0160
H'0010
H'0005
Time
H'0000
TIOCA
TGRA
H'0005
H'0160
H'0010
TIOCB
TGRB
H'0180
Figure 10.9 Example of Input Capture Operation
10.4.2
Synchronous Operation
In synchronous operation, the values in a number of TCNT counters can be rewritten
simultaneously (synchronous presetting). Also, a number of TCNT counters can be cleared
simultaneously by making the appropriate setting in TCR (synchronous clearing).
Synchronous operation enables TGR to be incremented with respect to a single time base.
Channels 0 to 5 can all be designated for synchronous operation.
Example of Synchronous Operation Setting Procedure: Figure 10.10 shows an example of the
synchronous operation setting procedure.
Rev. 6.00 Sep. 24, 2009 Page 313 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Synchronous operation
selection
Set synchronous
operation
[1]
Synchronous presetting
Set TCNT
Synchronous clearing
[2]
Clearing
source generation
channel?
No
Yes
<Synchronous presetting>
Select counter
clearing source
[3]
Set synchronous
counter clearing
[4]
Start count
[5]
Start count
[5]
<Counter clearing>
<Synchronous clearing>
[1] Set to 1 the SYNC bits in TSYR corresponding to the channels to be designated for synchronous
operation.
[2] When the TCNT counter of any of the channels designated for synchronous operation is
written to, the same value is simultaneously written to the other TCNT counters.
[3] Use the CCLR2 to CCLR0 bits in TCR to specify TCNT clearing by input capture/output compare,
etc.
[4] Use the CCLR2 to CCLR0 bits in TCR to designate synchronous clearing for the counter clearing
source.
[5] Set to 1 the CST bits in TSTR for the relevant channels, to start the count operation.
Figure 10.10 Example of Synchronous Operation Setting Procedure
Example of Synchronous Operation: Figure 10.11 shows an example of synchronous operation.
In this example, synchronous operation and PWM mode 1 have been designated for channels 0 to
2, TGRB_0 compare match has been set as the channel 0 counter clearing source, and
synchronous clearing has been set for the channel 1 and 2 counter clearing source.
Three-phase PWM waveforms are output from pins TIOCA0, TIOCA1, and TIOCA2. At this
time, synchronous presetting, and synchronous clearing by TGRB_0 compare match, are
performed for channel 0 to 2 TCNT counters, and the data set in TGRB_0 is used as the PWM
cycle.
For details of PWM modes, see section 10.4.5, PWM Modes.
Rev. 6.00 Sep. 24, 2009 Page 314 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Synchronous clearing by TGRB_0 compare match
TCNT0 to TCNT2 values
TGRB_0
TGRB_1
TGRA_0
TGRB_2
TGRA_1
TGRA_2
Time
H'0000
TIOCA0
TIOCA1
TIOCA2
Figure 10.11 Example of Synchronous Operation
10.4.3
Buffer Operation
Buffer operation, provided for channels 0 and 3, enables TGRC and TGRD to be used as buffer
registers.
Buffer operation differs depending on whether TGR has been designated as an input capture
register or as a compare match register.
Table 10.28 shows the register combinations used in buffer operation.
Table 10.28 Register Combinations in Buffer Operation
Channel
Timer General Register
Buffer Register
0
TGRA_0
TGRC_0
TGRB_0
TGRD_0
TGRA_3
TGRC_3
TGRB_3
TGRD_3
3
• When TGR is an output compare register
When a compare match occurs, the value in the buffer register for the corresponding channel is
transferred to the timer general register.
Rev. 6.00 Sep. 24, 2009 Page 315 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
This operation is illustrated in figure 10.12.
Compare match signal
Timer general
register
Buffer register
Comparator
TCNT
Figure 10.12 Compare Match Buffer Operation
• When TGR is an input capture register
When input capture occurs, the value in TCNT is transferred to TGR and the value previously
held in the timer general register is transferred to the buffer register.
This operation is illustrated in figure 10.13.
Input capture
signal
Timer general
register
Buffer register
TCNT
Figure 10.13 Input Capture Buffer Operation
Example of Buffer Operation Setting Procedure: Figure 10.14 shows an example of the buffer
operation setting procedure.
Buffer operation
Select TGR function
[1]
Set buffer operation
[2]
Start count
[3]
[1] Designate TGR as an input capture register or
output compare register by means of TIOR.
[2] Designate TGR for buffer operation with the
BFA and BFB bits in TMDR.
[3] Set the CST bit in TSTR to 1 start the count
operation.
<Buffer operation>
Figure 10.14 Example of Buffer Operation Setting Procedure
Rev. 6.00 Sep. 24, 2009 Page 316 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Examples of Buffer Operation
1. When TGR is an output compare register
Figure 10.15 shows an operation example in which PWM mode 1 has been designated for
channel 0, and buffer operation has been designated for TGRA and TGRC. The settings used
in this example are TCNT clearing by compare match B, 1 output at compare match A, and 0
output at compare match B.
As buffer operation has been set, when compare match A occurs the output changes and the
value in buffer register TGRC is simultaneously transferred to timer general register TGRA.
This operation is repeated each time that compare match A occurs.
For details of PWM modes, see section 10.4.5, PWM Modes.
TCNT value
TGRB_0
H'0520
H'0450
H'0200
TGRA_0
Time
H'0000
TGRC_0 H'0200
H'0450
H'0520
Transfer
TGRA_0
H'0200
H'0450
TIOCA
Figure 10.15 Example of Buffer Operation (1)
2. When TGR is an input capture register
Figure 10.16 shows an operation example in which TGRA has been designated as an input
capture register, and buffer operation has been designated for TGRA and TGRC.
Counter clearing by TGRA input capture has been set for TCNT, and both rising and falling
edges have been selected as the TIOCA pin input capture input edge.
As buffer operation has been set, when the TCNT value is stored in TGRA upon the
occurrence of input capture A, the value previously stored in TGRA is simultaneously
transferred to TGRC.
Rev. 6.00 Sep. 24, 2009 Page 317 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
TCNT value
H'0F07
H'09FB
H'0532
H'0000
Time
TIOCA
H'0532
TGRA
TGRC
H'0F07
H'09FB
H'0532
H'0F07
Figure 10.16 Example of Buffer Operation (2)
10.4.4
Cascaded Operation
In cascaded operation, two 16-bit counters for different channels are used together as a 32-bit
counter.
This function works by counting the channel 1 (channel 4) counter clock upon overflow/underflow
of TCNT_2 (TCNT_5) as set in the TPSC0 to TPSC2 bits in TCR.
Underflow occurs only when the lower 16-bit TCNT is in phase-counting mode.
Table 10.29 shows the register combinations used in cascaded operation.
Note: When phase counting mode is set for channel 1 or 4, the counter clock setting is invalid
and the counters operates independently in phase counting mode.
Table 10.29 Cascaded Combinations
Combination
Upper 16 Bits
Lower 16 Bits
Channels 1 and 2
TCNT_1
TCNT_2
Channels 4 and 5
TCNT_4
TCNT_5
Rev. 6.00 Sep. 24, 2009 Page 318 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Example of Cascaded Operation Setting Procedure: Figure 10.17 shows an example of the
setting procedure for cascaded operation.
Cascaded operation
Set cascading
[1]
Start count
[2]
[1] Set the TPSC2 to TPSC0 bits in the channel 1
(channel 4) TCR to B'1111 to select TCNT_2
(TCNT_5) overflow/underflow counting.
[2] Set the CST bit in TSTR for the upper and lower
channel to 1 to start the count operation.
<Cascaded operation>
Figure 10.17 Cascaded Operation Setting Procedure
Examples of Cascaded Operation: Figure 10.18 illustrates the operation when TCNT_2
overflow/underflow counting has been set for TCNT_1, when TGRA_1 and TGRA_2 have been
designated as input capture registers, and when TIOC pin rising edge has been selected.
When a rising edge is input to the TIOCA1 and TIOCA2 pins simultaneously, the upper 16 bits of
the 32-bit data are transferred to TGRA_1, and the lower 16 bits to TGRA_2.
TCNT_1
clock
TCNT_1
H'03A1
H'03A2
TCNT_2
clock
TCNT_2
H'FFFF
H'0001
H'0000
TIOCA1,
TIOCA2
TGRA_1
H'03A2
TGRA_2
H'0000
Figure 10.18 Example of Cascaded Operation (1)
Figure 10.19 illustrates the operation when TCNT_2 overflow/underflow counting has been set for
TCNT_1 and phase counting mode has been designated for channel 2.
Rev. 6.00 Sep. 24, 2009 Page 319 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
TCNT_1 is incremented by TCNT_2 overflow and decremented by TCNT_2 underflow.
TCLKA
TCLKB
TCNT_2
FFFD
TCNT_1
FFFE
FFFF
0000
0000
0001
0002
0001
0000
0001
FFFF
0000
Figure 10.19 Example of Cascaded Operation (2)
10.4.5
PWM Modes
In PWM mode, PWM waveforms are output from the output pins. The output level can be selected
as 0, 1, or toggle output in response to a compare match of each TGR.
TGR registers settings can be used to output a PWM waveform in the range of 0% to 100% duty.
Designating TGR compare match as the counter clearing source enables the period to be set in that
register. All channels can be designated for PWM mode independently. Synchronous operation is
also possible.
There are two PWM modes, as described below.
• PWM mode 1
PWM output is generated from the TIOCA and TIOCC pins by pairing TGRA with TGRB and
TGRC with TGRD. The output specified by the IOA0 to IOA3 bits and IOC0 to IOC3 bits in
TIOR is output from the TIOCA and TIOCC pins at compare matches A and C, and the output
specified by the IOB0 to IOB3 bits and IOD0 to IOD3 bits in TIOR is output at compare
matches B and D. The initial output value is the value set in TGRA or TGRC. If the set values
of paired TGRs are identical, the output value does not change when a compare match occurs.
In PWM mode 1, a maximum 8-phase PWM output is possible.
• PWM mode 2
PWM output is generated using one TGR as the cycle register and the others as duty registers.
The output specified in TIOR is performed by means of compare matches. Upon counter
clearing by a synchronization register compare match, the output value of each pin is the initial
value set in TIOR. If the set values of the cycle and duty registers are identical, the output
value does not change when a compare match occurs.
Rev. 6.00 Sep. 24, 2009 Page 320 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
In PWM mode 2, a maximum 15-phase PWM output is possible in combination use with
synchronous operation.
The correspondence between PWM output pins and registers is shown in table 10.30.
Table 10.30 PWM Output Registers and Output Pins
Output Pins
Channel
Registers
PWM Mode 1
PWM Mode 2
0
TGRA_0
TIOCA0
TIOCA0
TGRB_0
TGRC_0
TIOCB0
TIOCC0
TGRD_0
1
TGRA_1
TIOCD0
TIOCA1
TGRB_1
2
TGRA_2
TGRA_3
TIOCA2
TIOCA3
TGRA_4
TIOCC3
TGRA_5
TGRB_5
TIOCC3
TIOCD3
TIOCA4
TGRB_4
5
TIOCA3
TIOCB3
TGRD_3
4
TIOCA2
TIOCB2
TGRB_3
TGRC_3
TIOCA1
TIOCB1
TGRB_2
3
TIOCC0
TIOCA4
TIOCB4
TIOCA5
TIOCA5
TIOCB5
Note: In PWM mode 2, PWM output is not possible for the TGR register in which the period is set.
Rev. 6.00 Sep. 24, 2009 Page 321 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Example of PWM Mode Setting Procedure: Figure 10.20 shows an example of the PWM mode
setting procedure.
PWM mode
Select counter clock
[1]
Select counter clearing source
[2]
Select waveform output level
[3]
Set TGR
[4]
Set PWM mode
[5]
Start count
[6]
[1] Select the counter clock with the TPSC2 to
TPSC0 bits in TCR. At the same time, select the
input clock edge with the CKEG1 and CKEG0 bits
in TCR.
[2] Use the CCLR2 to CCLR0 bits in TCR to select the
TGR to be used as the TCNT clearing source.
[3] Use TIOR to designate the TGR as an output
compare register, and select the initial value and
output value.
[4] Set the cycle in the TGR selected in [2], and set
the duty in the other the TGR.
[5] Select the PWM mode with the MD3 to MD0 bits
in TMDR.
[6] Set the CST bit in TSTR to 1 start the count
operation.
<PWM mode>
Figure 10.20 Example of PWM Mode Setting Procedure
Examples of PWM Mode Operation: Figure 10.21 shows an example of PWM mode 1
operation.
In this example, TGRA compare match is set as the TCNT clearing source, 0 is set for the TGRA
initial output value and output value, and 1 is set as the TGRB output value.
In this case, the value set in TGRA is used as the period, and the values set in the TGRB registers
are used as the duty levels.
Rev. 6.00 Sep. 24, 2009 Page 322 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
TCNT value
Counter cleared by
TGRA compare match
TGRA
TGRB
H'0000
Time
TIOCA
Figure 10.21 Example of PWM Mode Operation (1)
Figure 10.22 shows an example of PWM mode 2 operation.
In this example, synchronous operation is designated for channels 0 and 1, TGRB_1 compare
match is set as the TCNT clearing source, and 0 is set for the initial output value and 1 for the
output value of the other TGR registers (TGRA_0 to TGRD_0, TGRA_1), outputting a 5-phase
PWM waveform.
In this case, the value set in TGRB_1 is used as the cycle, and the values set in the other TGRs are
used as the duty levels.
TCNT value
Counter cleared by
TGRB_1 compare match
TGRB_1
TGRA_1
TGRD_0
TGRC_0
TGRB_0
TGRA_0
H'0000
Time
TIOCA0
TIOCB0
TIOCC0
TIOCD0
TIOCA1
Figure 10.22 Example of PWM Mode Operation (2)
Rev. 6.00 Sep. 24, 2009 Page 323 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Figure 10.23 shows examples of PWM waveform output with 0% duty and 100% duty in PWM
mode.
TCNT value
TGRB rewritten
TGRA
TGRB
TGRB rewritten
TGRB
rewritten
H'0000
Time
0% duty
TIOCA
Output does not change when cycle register and duty register
compare matches occur simultaneously
TCNT value
TGRB rewritten
TGRA
TGRB rewritten
TGRB rewritten
TGRB
H'0000
Time
100% duty
TIOCA
Output does not change when cycle register and duty
register compare matches occur simultaneously
TCNT value
TGRB rewritten
TGRA
TGRB rewritten
TGRB
TGRB rewritten
Time
H'0000
100% duty
TIOCA
0% duty
Figure 10.23 Example of PWM Mode Operation (3)
Rev. 6.00 Sep. 24, 2009 Page 324 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.4.6
Phase Counting Mode
In phase counting mode, the phase difference between two external clock inputs is detected and
TCNT is incremented/decremented accordingly. This mode can be set for channels 1, 2, 4, and 5.
When phase counting mode is set, an external clock is selected as the counter input clock and
TCNT operates as an up/down-counter regardless of the setting of the TPSC0 to TPSC2 bits and
CKEG0 and CKEG1 bits in TCR. However, the functions of the CCLR0 and CCLR1 bits in TCR,
and of TIOR, TIER, and TGR, are valid, and input capture/compare match and interrupt functions
can be used.
This can be used for two-phase encoder pulse input.
If overflow occurs when TCNT is counting up, the TCFV flag in TSR is set; if underflow occurs
when TCNT is counting down, the TCFU flag is set.
The TCFD bit in TSR is the count direction flag. Reading the TCFD flag reveals whether TCNT is
counting up or down.
Table 10.31 shows the correspondence between external clock pins and channels.
Table 10.31 Phase Counting Mode Clock Input Pins
External Clock Pins
Channels
A-Phase
B-Phase
When channel 1 or 5 is set to phase counting mode
TCLKA
TCLKB
When channel 2 or 4 is set to phase counting mode
TCLKC
TCLKD
Example of Phase Counting Mode Setting Procedure: Figure 10.24 shows an example of the
phase counting mode setting procedure.
Rev. 6.00 Sep. 24, 2009 Page 325 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
[1] Select phase counting mode with the MD3 to
MD0 bits in TMDR.
[2] Set the CST bit in TSTR to 1 to start the count
operation.
Phase counting mode
Select phase counting mode
[1]
Start count
[2]
<Phase counting mode>
Figure 10.24 Example of Phase Counting Mode Setting Procedure
Rev. 6.00 Sep. 24, 2009 Page 326 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Examples of Phase Counting Mode Operation: In phase counting mode, TCNT counts up or
down according to the phase difference between two external clocks. There are four modes,
according to the count conditions.
1. Phase counting mode 1
Figure 10.25 shows an example of phase counting mode 1 operation, and table 10.32
summarizes the TCNT up/down-count conditions.
TCLKA (channels 1 and 5)
TCLKC (channels 2 and 4)
TCLKB (channels 1 and 5)
TCLKD (channels 2 and 4)
TCNT value
Down-count
Up-count
Time
Figure 10.25 Example of Phase Counting Mode 1 Operation
Table 10.32 Up/Down-Count Conditions in Phase Counting Mode 1
TCLKA (Channels 1 and 5)
TCLKC (Channels 2 and 4)
TCLKB (Channels 1 and 5)
TCLKD (Channels 2 and 4)
High level
Operation
Up-count
Low level
Up-count
Low level
Up-count
High level
Up-count
High level
Down-count
Low level
Down-count
High level
Down-count
Low level
Down-count
Legend:
:
Rising edge
:
Falling edge
Rev. 6.00 Sep. 24, 2009 Page 327 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
2. Phase counting mode 2
Figure 10.26 shows an example of phase counting mode 2 operation, and table 10.33
summarizes the TCNT up/down-count conditions.
TCLKA (channels 1 and 5)
TCLKC (channels 2 and 4)
TCLKB (channels 1 and 5)
TCLKD (channels 2 and 4)
TCNT value
Up-count
Down-count
Time
Figure 10.26 Example of Phase Counting Mode 2 Operation
Table 10.33 Up/Down-Count Conditions in Phase Counting Mode 2
TCLKA (Channels 1 and 5)
TCLKC (Channels 2 and 4)
TCLKB (Channels 1 and 5)
TCLKD (Channels 2 and 4)
High level
Operation
Don’t care
Low level
Don’t care
Low level
Don’t care
High level
Up-count
High level
Don’t care
Low level
Don’t care
Legend:
:
Rising edge
:
Falling edge
Rev. 6.00 Sep. 24, 2009 Page 328 of 928
REJ09B0099-0600
High level
Don’t care
Low level
Down-count
Section 10 16-Bit Timer Pulse Unit (TPU)
3. Phase counting mode 3
Figure 10.27 shows an example of phase counting mode 3 operation, and table 10.34
summarizes the TCNT up/down-count conditions.
TCLKA (channels 1 and 5)
TCLKC (channels 2 and 4)
TCLKB (channels 1 and 5)
TCLKD (channels 2 and 4)
TCNT value
Down-count
Up-count
Time
Figure 10.27 Example of Phase Counting Mode 3 Operation
Table 10.34 Up/Down-Count Conditions in Phase Counting Mode 3
TCLKA (Channels 1 and 5)
TCLKC (Channels 2 and 4)
TCLKB (Channels 1 and 5)
TCLKD (Channels 2 and 4)
Operation
High level
Don’t care
Low level
Don’t care
Low level
Don’t care
High level
Up-count
High level
Down-count
Low level
Don’t care
High level
Don’t care
Low level
Don’t care
Legend:
:
Rising edge
:
Falling edge
Rev. 6.00 Sep. 24, 2009 Page 329 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
4. Phase counting mode 4
Figure 10.28 shows an example of phase counting mode 4 operation, and table 10.35
summarizes the TCNT up/down-count conditions.
TCLKA (channels 1 and 5)
TCLKC (channels 2 and 4)
TCLKB (channels 1 and 5)
TCLKD (channels 2 and 4)
TCNT value
Down-count
Up-count
Time
Figure 10.28 Example of Phase Counting Mode 4 Operation
Table 10.35 Up/Down-Count Conditions in Phase Counting Mode 4
TCLKA (Channels 1 and 5)
TCLKC (Channels 2 and 4)
TCLKB (Channels 1 and 5)
TCLKD (Channels 2 and 4)
Operation
High level
Up-count
Low level
Up-count
Low level
Don’t care
High level
Don’t care
High level
Down-count
Low level
Down-count
Legend:
:
Rising edge
:
Falling edge
Rev. 6.00 Sep. 24, 2009 Page 330 of 928
REJ09B0099-0600
High level
Don’t care
Low level
Don’t care
Section 10 16-Bit Timer Pulse Unit (TPU)
Phase Counting Mode Application Example: Figure 10.29 shows an example in which channel
1 is in phase counting mode, and channel 1 is coupled with channel 0 to input servo motor 2-phase
encoder pulses in order to detect position or speed.
Channel 1 is set to phase counting mode 1, and the encoder pulse A-phase and B-phase are input
to TCLKA and TCLKB.
Channel 0 operates with TCNT counter clearing by TGRC_0 compare match; TGRA_0 and
TGRC_0 are used for the compare match function and are set with the speed control period and
position control period. TGRB_0 is used for input capture, with TGRB_0 and TGRD_0 operating
in buffer mode. The channel 1 counter input clock is designated as the TGRB_0 input capture
source, and the pulse widths of 2-phase encoder 4-multiplication pulses are detected.
TGRA_1 and TGRB_1 for channel 1 are designated for input capture, and channel 0 TGRA_0 and
TGRC_0 compare matches are selected as the input capture source and store the up/down-counter
values for the control periods.
This procedure enables the accurate detection of position and speed.
Rev. 6.00 Sep. 24, 2009 Page 331 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Channel 1
TCLKA
TCLKB
Edge
detection
circuit
TCNT_1
TGRA_1
(speed period capture)
TGRB_1
(position period capture)
TCNT_0
TGRA_0
(speed control period)
+
-
TGRC_0
(position control period)
+
-
TGRB_0 (pulse width capture)
TGRD_0 (buffer operation)
Channel 0
Figure 10.29 Phase Counting Mode Application Example
10.5
Interrupts
There are three kinds of TPU interrupt source; TGR input capture/compare match, TCNT
overflow, and TCNT underflow. Each interrupt source has its own status flag and enable/disabled
bit, allowing the generation of interrupt request signals to be enabled or disabled individually.
When an interrupt request is generated, the corresponding status flag in TSR is set to 1. If the
corresponding enable/disable bit in TIER is set to 1 at this time, an interrupt is requested. The
interrupt request is cleared by clearing the status flag to 0.
Relative channel priorities can be changed by the interrupt controller, however the priority order
within a channel is fixed. For details, see section 5, Interrupt Controller.
Rev. 6.00 Sep. 24, 2009 Page 332 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Table 10.36 lists the TPU interrupt sources.
Table 10.36 TPU Interrupts
Channel
Name
Interrupt Source
DTC
Interrupt Flag Activation
0
TGI0A
TGRA_0 input capture/compare match
TGFA_0
Possible
TGI0B
TGRB_0 input capture/compare match
TGFB_0
Possible
TGI0C
TGRC_0 input capture/compare match
TGFC_0
Possible
TGI0D
TGRD_0 input capture/compare match
TGFD_0
Possible
1
2
3
4
5
TCI0V
TCNT_0 overflow
TCFV_0
Not possible
TGI1A
TGRA_1 input capture/compare match
TGFA_1
Possible
TGI1B
TGRB_1 input capture/compare match
TGFB_1
Possible
TCI1V
TCNT_1 overflow
TCFV_1
Not possible
TCI1U
TCNT_1 underflow
TCFU_1
Not possible
TGI2A
TGRA_2 input capture/compare match
TGFA_2
Possible
TGI2B
TGRB_2 input capture/compare match
TGFB_2
Possible
TCI2V
TCNT_2 overflow
TCFV_2
Not possible
TCI2U
TCNT_2 underflow
TCFU_2
Not possible
TGI3A
TGRA_3 input capture/compare match
TGFA_3
Possible
TGI3B
TGRB_3 input capture/compare match
TGFB_3
Possible
TGI3C
TGRC_3 input capture/compare match
TGFC_3
Possible
TGI3D
TGRD_3 input capture/compare match
TGFD_3
Possible
TCI3V
TCNT_3 overflow
TCFV_3
Not possible
TGI4A
TGRA_4 input capture/compare match
TGFA_4
Possible
TGI4B
TGRB_4 input capture/compare match
TGFB_4
Possible
TCI4V
TCNT_4 overflow
TCFV_4
Not possible
TCI4U
TCNT_4 underflow
TCFU_4
Not possible
TGI5A
TGRA_5 input capture/compare match
TGFA_5
Possible
TGI5B
TGRB_5 input capture/compare match
TGFB_5
Possible
TCI5V
TCNT_5 overflow
TCFV_5
Not possible
TCI5U
TCNT_5 underflow
TCFU_5
Not possible
Note: This table shows the initial state immediately after a reset. The relative channel priorities
can be changed by the interrupt controller.
Rev. 6.00 Sep. 24, 2009 Page 333 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Input Capture/Compare Match Interrupt: An interrupt is requested if the TGIE bit in TIER is
set to 1 when the TGF flag in TSR is set to 1 by the occurrence of a TGR input capture/compare
match on a particular channel. The interrupt request is cleared by clearing the TGF flag to 0. The
TPU has 16 input capture/compare match interrupts, four each for channels 0 and 3, and two each
for channels 1, 2, 4, and 5.
Overflow Interrupt: An interrupt is requested if the TCIEV bit in TIER is set to 1 when the
TCFV flag in TSR is set to 1 by the occurrence of TCNT overflow on a channel. The interrupt
request is cleared by clearing the TCFV flag to 0. The TPU has six overflow interrupts, one for
each channel.
Underflow Interrupt: An interrupt is requested if the TCIEU bit in TIER is set to 1 when the
TCFU flag in TSR is set to 1 by the occurrence of TCNT underflow on a channel. The interrupt
request is cleared by clearing the TCFU flag to 0. The TPU has four underflow interrupts, one
each for channels 1, 2, 4, and 5.
10.6
DTC Activation
The DTC can be activated by the TGR input capture/compare match interrupt for a channel. For
details, see section 8, Data Transfer Controller (DTC).
A total of 16 TPU input capture/compare match interrupts can be used as DTC activation sources,
four each for channels 0 and 3, and two each for channels 1, 2, 4, and 5.
10.7
A/D Converter Activation
The A/D converter can be activated by the TGRA input capture/compare match for a channel.
If the TTGE bit in TIER is set to 1 when the TGFA flag in TSR is set to 1 by the occurrence of a
TGRA input capture/compare match on a particular channel, a request to begin A/D conversion is
sent to the A/D converter. If the TPU conversion start trigger has been selected on the A/D
converter side at this time, A/D conversion is begun.
In the TPU, a total of six TGRA input capture/compare match interrupts can be used as A/D
converter conversion start sources, one for each channel.
Rev. 6.00 Sep. 24, 2009 Page 334 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.8
Operation Timing
10.8.1
Input/Output Timing
TCNT Count Timing: Figure 10.30 shows TCNT count timing in internal clock operation, and
figure 10.31 shows TCNT count timing in external clock operation.
φ
Internal clock
Falling edge
Rising edge
TCNT
input clock
TCNT
N-1
N
N+1
N+2
Figure 10.30 Count Timing in Internal Clock Operation
φ
External clock
Falling edge
Rising edge
Falling edge
TCNT
input clock
TCNT
N-1
N
N+1
N+2
Figure 10.31 Count Timing in External Clock Operation
Rev. 6.00 Sep. 24, 2009 Page 335 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Output Compare Output Timing: A compare match signal is generated in the final state in
which TCNT and TGR match (the point at which the count value matched by TCNT is updated).
When a compare match signal is generated, the output value set in TIOR is output at the output
compare output pin. After a match between TCNT and TGR, the compare match signal is not
generated until the TCNT input clock is generated.
Figure 10.32 shows output compare output timing.
φ
TCNT
input clock
N+1
N
TCNT
N
TGR
Compare
match signal
TIOC pin
Figure 10.32 Output Compare Output Timing
Input Capture Signal Timing: Figure 10.33 shows input capture signal timing.
φ
Input capture
input
Input capture
signal
TCNT
N
N+1
N+2
N
TGR
Figure 10.33 Input Capture Input Signal Timing
Rev. 6.00 Sep. 24, 2009 Page 336 of 928
REJ09B0099-0600
N+2
Section 10 16-Bit Timer Pulse Unit (TPU)
Timing for Counter Clearing by Compare Match/Input Capture: Figure 10.34 shows the
timing when counter clearing on compare match is specified, and figure 10.35 shows the timing
when counter clearing on input capture is specified.
φ
Compare
match signal
Counter
clear signal
TCNT
N
TGR
N
H'0000
Figure 10.34 Counter Clear Timing (Compare Match)
φ
Input capture
signal
Counter clear
signal
TCNT
TGR
N
H'0000
N
Figure 10.35 Counter Clear Timing (Input Capture)
Rev. 6.00 Sep. 24, 2009 Page 337 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Buffer Operation Timing: Figures 10.36 and 10.37 show the timing in buffer operation.
φ
TCNT
n
n+1
Compare
match signal
TGRA,
TGRB
n
TGRC,
TGRD
N
N
Figure 10.36 Buffer Operation Timing (Compare Match)
φ
Input capture
signal
TCNT
N
TGRA,
TGRB
n
TGRC,
TGRD
N+1
N
N+1
n
N
Figure 10.37 Buffer Operation Timing (Input Capture)
Rev. 6.00 Sep. 24, 2009 Page 338 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.8.2
Interrupt Signal Timing
TGF Flag Setting Timing in Case of Compare Match: Figure 10.38 shows the timing for
setting of the TGF flag in TSR on compare match, and TGI interrupt request signal timing.
φ
TCNT input
clock
TCNT
N
TGR
N
N+1
Compare
match signal
TGF flag
TGI interrupt
Figure 10.38 TGI Interrupt Timing (Compare Match)
TGF Flag Setting Timing in Case of Input Capture: Figure 10.39 shows the timing for setting
of the TGF flag in TSR on input capture, and TGI interrupt request signal timing.
Rev. 6.00 Sep. 24, 2009 Page 339 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
φ
Input capture
signal
TCNT
N
TGR
N
TGF flag
TGI interrupt
Figure 10.39 TGI Interrupt Timing (Input Capture)
TCFV Flag/TCFU Flag Setting Timing: Figure 10.40 shows the timing for setting of the TCFV
flag in TSR on overflow, and TCIV interrupt request signal timing.
Figure 10.41 shows the timing for setting of the TCFU flag in TSR on underflow, and TCIU
interrupt request signal timing.
φ
TCNT input
clock
TCNT
(overflow)
H'FFFF
H'0000
Overflow
signal
TCFV flag
TCIV interrupt
Figure 10.40 TCIV Interrupt Setting Timing
Rev. 6.00 Sep. 24, 2009 Page 340 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
φ
TCNT
input clock
TCNT
(underflow)
H'0000
H'FFFF
Underflow
signal
TCFU flag
TCIU interrupt
Figure 10.41 TCIU Interrupt Setting Timing
Rev. 6.00 Sep. 24, 2009 Page 341 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
Status Flag Clearing Timing: After a status flag is read as 1 by the CPU, it is cleared by writing
0 to it. When the DTC is activated, the flag is cleared automatically. Figure 10.42 shows the
timing for status flag clearing by the CPU, and figure 10.43 shows the timing for status flag
clearing by the DTC.
TSR write cycle
T1
T2
φ
TSR address
Address
Write signal
Status flag
Interrupt
request
signal
Figure 10.42 Timing for Status Flag Clearing by CPU
DTC
read cycle
T1
T2
DTC
write cycle
T1
T2
φ
Address
Source address
Destination
address
Status flag
Interrupt
request
signal
Figure 10.43 Timing for Status Flag Clearing by DTC Activation
Rev. 6.00 Sep. 24, 2009 Page 342 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.9
Usage Notes
10.9.1
Module Stop Mode Setting
TPU operation can be disabled or enabled using the module stop control register. The initial
setting is for TPU operation to be halted. Register access is enabled by clearing module stop
mode. For details, see section 22, Power-Down Modes.
10.9.2
Input Clock Restrictions
The input clock pulse width must be at least 1.5 states in the case of single-edge detection, and at
least 2.5 states in the case of both-edge detection. The TPU will not operate properly at narrower
pulse widths.
In phase counting mode, the phase difference and overlap between the two input clocks must be at
least 1.5 states, and the pulse width must be at least 2.5 states. Figure 10.44 shows the input clock
conditions in phase counting mode.
Overlap
Phase
Phase
differdifference Overlap ence
Pulse width
Pulse width
TCLKA
(TCLKC)
TCLKB
(TCLKD)
Pulse width
Pulse width
Notes: Phase difference and overlap : 1.5 states or more
Pulse width
: 2.5 states or more
Figure 10.44 Phase Difference, Overlap, and Pulse Width in Phase Counting Mode
Rev. 6.00 Sep. 24, 2009 Page 343 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.9.3
Caution on Period Setting
When counter clearing on compare match is set, TCNT is cleared in the final state in which it
matches the TGR value (the point at which the count value matched by TCNT is updated).
Consequently, the actual counter frequency is given by the following formula:
φ
f=
(N + 1)
Where
10.9.4
f : Counter frequency
φ : Operating frequency
N : TGR set value
Contention between TCNT Write and Clear Operations
If the counter clear signal is generated in the T2 state of a TCNT write cycle, TCNT clearing takes
precedence and the TCNT write is not performed.
Figure 10.45 shows the timing in this case.
TCNT write cycle
T2
T1
φ
TCNT address
Address
Write signal
Counter clear
signal
TCNT
N
H'0000
Figure 10.45 Contention between TCNT Write and Clear Operations
Rev. 6.00 Sep. 24, 2009 Page 344 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.9.5
Contention between TCNT Write and Increment Operations
If incrementing occurs in the T2 state of a TCNT write cycle, the TCNT write takes precedence
and TCNT is not incremented.
Figure 10.46 shows the timing in this case.
TCNT write cycle
T1
T2
φ
TCNT address
Address
Write signal
TCNT input
clock
TCNT
N
M
TCNT write data
Figure 10.46 Contention between TCNT Write and Increment Operations
Rev. 6.00 Sep. 24, 2009 Page 345 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.9.6
Contention between TGR Write and Compare Match
If a compare match occurs in the T2 state of a TGR write cycle, the TGR write takes precedence
and the compare match signal is inhibited. A compare match does not occur even if the previous
value is written.
Figure 10.47 shows the timing in this case.
TGR write cycle
T1
T2
φ
TGR address
Address
Write signal
Compare
match signal
Disabled
TCNT
N
N+1
TGR
N
M
TGR write data
Figure 10.47 Contention between TGR Write and Compare Match
Rev. 6.00 Sep. 24, 2009 Page 346 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.9.7
Contention between Buffer Register Write and Compare Match
If a compare match occurs in the T2 state of a TGR write cycle, the data that is transferred to TGR
by the buffer operation will be that in the buffer prior to the write.
Figure 10.48 shows the timing in this case.
TGR write cycle
T2
T1
φ
Buffer register
address
Address
Write signal
Compare
match signal
Buffer register write data
Buffer
register
TGR
N
M
N
Figure 10.48 Contention between Buffer Register Write and Compare Match
Rev. 6.00 Sep. 24, 2009 Page 347 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.9.8
Contention between TGR Read and Input Capture
If an input capture signal is generated in the T1 state of a TGR read cycle, the data that is read will
be that in the buffer after input capture transfer.
Figure 10.49 shows the timing in this case.
TGR read cycle
T2
T1
φ
TGR address
Address
Read signal
Input capture
signal
TGR
X
Internal
data bus
M
M
Figure 10.49 Contention between TGR Read and Input Capture
Rev. 6.00 Sep. 24, 2009 Page 348 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.9.9
Contention between TGR Write and Input Capture
If an input capture signal is generated in the T2 state of a TGR write cycle, the input capture
operation takes precedence and the write to TGR is not performed.
Figure 10.50 shows the timing in this case.
TGR write cycle
T2
T1
φ
Address
TGR address
Write signal
Input capture
signal
TCNT
TGR
M
M
Figure 10.50 Contention between TGR Write and Input Capture
Rev. 6.00 Sep. 24, 2009 Page 349 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.9.10 Contention between Buffer Register Write and Input Capture
If an input capture signal is generated in the T2 state of a buffer register write cycle, the buffer
operation takes precedence and the write to the buffer register is not performed.
Figure 10.51 shows the timing in this case.
Buffer register write cycle
T2
T1
φ
Buffer register
address
Address
Write signal
Input capture
signal
TCNT
TGR
Buffer
register
N
M
N
M
Figure 10.51 Contention between Buffer Register Write and Input Capture
Rev. 6.00 Sep. 24, 2009 Page 350 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.9.11 Contention between Overflow/Underflow and Counter Clearing
If overflow/underflow and counter clearing occur simultaneously, the TCFV/TCFU flag in TSR is
not set and TCNT clearing takes precedence.
Figure 10.52 shows the operation timing when a TGR compare match is specified as the clearing
source, and when H'FFFF is set in TGR.
φ
TCNT input
clock
TCNT
H'FFFF
H'0000
Counter
clear signal
TGF flag
Disabled
TCFV flag
Figure 10.52 Contention between Overflow and Counter Clearing
Rev. 6.00 Sep. 24, 2009 Page 351 of 928
REJ09B0099-0600
Section 10 16-Bit Timer Pulse Unit (TPU)
10.9.12 Contention between TCNT Write and Overflow/Underflow
If there is an up-count or down-count in the T2 state of a TCNT write cycle, and
overflow/underflow occurs, the TCNT write takes precedence and the TCFV/TCFU flag in TSR is
not set.
Figure 10.53 shows the operation timing when there is contention between TCNT write and
overflow.
TNC Write cycle
T1
T2
φ
TCNT address
Address
Write signal
TCNT
TCFV flag
TCNT write data
H'FFFF
M
Disabled
Figure 10.53 Contention between TCNT Write and Overflow
10.9.13 Multiplexing of I/O Pins
In this LSI, the TCLKA input pin is multiplexed with the TIOCC0 I/O pin, the TCLKB input pin
with the TIOCD0 I/O pin, the TCLKC input pin with the TIOCB1 I/O pin, and the TCLKD input
pin with the TIOCB2 I/O pin. When an external clock is input, compare match output should not
be performed from a multiplexed pin.
10.9.14 Interrupts in Module Stop Mode
If module stop mode is entered when an interrupt has been requested, it will not be possible to
clear the CPU interrupt source or the DTC activation source. Interrupts should therefore be
disabled before entering module stop mode.
Rev. 6.00 Sep. 24, 2009 Page 352 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
Section 11 8-Bit Timers (TMR)
This LSI has an on-chip 8-bit timer module with four channels. The 8-bit timer module can be
used to count external events and be used as a multifunction timer in a variety of applications,
such as generation of counter reset, interrupt requests, and pulse output with an arbitrary duty
cycle using a compare-match signal with two registers.
11.1
Features
• Selection of four clock sources
Selected from three internal clocks (φ/8, φ/64, and φ/8192) and an external clock
• Selection of three ways to clear the counters
The counters can be cleared on compare-match A or B, or by an external reset signal
• Timer output controlled by two compare-match signals
The timer output signal in each channel is controlled by two independent compare-match
signals, enabling the timer to be used for various applications, such as the generation of pulse
output or PWM output with an arbitrary duty cycle
• Cascading of the two channels
(Cascading of TMR_0, TMR_1)
The module can operate as a 16-bit timer using TMR_0 as the upper half and TMR_1 as the
lower half (16-bit count mode)
TMR_1 can be used to count TMR_0 compare-match occurrences (compare-match count
mode)
(Cascading of TMR_2, TMR_3)
The module can operate as a 16-bit timer using TMR_2 as the upper half and TMR_3 as the
lower half (16-bit count mode)
TMR_3 can be used to count TMR_2 compare-match occurrences (compare-match count
mode)
• Multiple interrupt sources for each channel
Two compare-match interrupts and one overflow interrupt can be requested independently
• Generation of A/D converter conversion start trigger
Channel 0 compare-match signal can be used as the A/D converter conversion start trigger
• Module stop mode can be set
As the initial setting, the 8-bit timer operation is halted. Register access is enabled by
canceling the module stop mode.
Rev. 6.00 Sep. 24, 2009 Page 353 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
Figure 11.1 shows a block diagram of the 8-bit timer module (TMR_0 and TMR_1).
External clock
Internal clock
TMCI01
TMCI23
φ/8
φ/64
φ/8192
Clock 1
Clock 0
Clock select
Compare-match A1
Compare-match A0 Comparator A_0
Overflow 1
Overflow 0
TMO0
TMRI01
TMRI23
TCNT_0
TCORA_1
Comparator A_1
TCNT_1
Clear 0
Clear 1
Compare-match B1
Compare-match B0 Comparator B_0
TMO1
TMO2
TMO3
Comparator B_1
Control logic
A/D conversion
start request
signal
TCORB_0
TCORB_1
TCSR_0
TCSR_1
TCR_0
TCR_1
CMIA0
CMIB0
OVI0
CMIA1
CMIB1
OVI1
Interrupt signals
Legend:
TCORA_0:
TCORB_0:
TCNT_0:
TCSR_0:
TCR_0:
Time constant register A_0
Time constant register B_0
Timer counter_0
Timer control/status register_0
Timer control register_0
TCORA_1:
TCORB_1:
TCNT_1:
TCSR_1:
TCR_1:
Time constant register A_1
Time constant register B_1
Timer counter_1
Timer control/status register_1
Timer control register_1
Figure 11.1 Block Diagram of 8-Bit Timer Module
Rev. 6.00 Sep. 24, 2009 Page 354 of 928
REJ09B0099-0600
Internal bus
TCORA_0
Section 11 8-Bit Timers (TMR)
11.2
Input/Output Pins
Table 11.1 summarizes the input and output pins of the 8-bit timer module.
Table 11.1 Pin Configuration
Channel
Name
Symbol
I/O
Function
0
Timer output
TMO0
Output
Output controlled by compare-match
1
Timer output
TMO1
Output
Output controlled by compare-match
Common
to 0 and 1
Timer clock input
TMCI01
Input
External clock input for the counter
Timer reset input
TMRI01
Input
External reset input for the counter
2
Timer output
TMO2
Output
Output controlled by compare-match
3
Timer output
TMO3
Output
Output controlled by compare-match
Common
to 2 and 3
Timer clock input
TMCI23
Input
External clock input for the counter
Timer reset input
TMRI23
Input
External reset input for the counter
11.3
Register Descriptions
The 8-bit timer has the following registers. For details on the module stop register, see section
22.1.2, Module Stop Control Registers A to C (MSTPCRA to MSTPCRC).
Channel 0
• Timer counter_0 (TCNT_0)
• Time constant register A_0 (TCORA_0)
• Time constant register B_0 (TCORB_0)
• Timer control register_0 (TCR_0)
• Timer control/status register_0 (TCSR_0)
Channel 1
• Timer counter_1 (TCNT_1)
• Time constant register A_1 (TCORA_1)
• Time constant register B_1 (TCORB_1)
• Timer control register_1 (TCR_1)
• Timer control/status register_1 (TCSR_1)
Rev. 6.00 Sep. 24, 2009 Page 355 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
Channel 2
• Timer counter_2 (TCNT_2)
• Time constant register A_2 (TCORA_2)
• Time constant register B_2 (TCORB_2)
• Timer control register_2 (TCR_2)
• Timer control/status register_2 (TCSR_2)
Channel 3
• Timer counter_3 (TCNT_3)
• Time constant register A_3 (TCORA_3)
• Time constant register B_3 (TCORB_3)
• Timer control register_3 (TCR_3)
• Timer control/status register_3 (TCSR_3)
11.3.1
Timer Counter (TCNT)
Each TCNT is an 8-bit up-counter. TCNT_0 and TCNT_1 (or TCNT_2 and TCNT_3) comprise a
single 16-bit register, so they can be accessed together by word access.
This clock source is selected by the clock select bits, CKS2 to CKS0, in TCR. TCNT can be
cleared by an external reset input signal or compare-match signals A and B. The CCLR1 and
CCLR0 bits in TCR select the method of TCNT clearing.
When TCNT overflows from H'FF to H'00, the overflow flag (OVF) in TCSR is set to 1. The
initial value of TCNT is H'00.
11.3.2
Time Constant Register A (TCORA)
TCORA is an 8-bit readable/writable register. TCORA_0 and TCORA_1 (or TCORA_2 and
TCORA_3) comprise a single 16-bit register, so they can be accessed together by word access.
TCORA is continually compared with the value in TCNT. When a match is detected, the
corresponding compare-match flag A (CMFA) in TCSR is set. Note, however, that comparison is
disabled during the T2 state of a TCORA write cycle.
The timer output from the TMO pin can be freely controlled by the compare-match signal A and
the settings of the output select bits, OS1 and OS0, in TCSR.
The initial value of TCORA is H'FF.
Rev. 6.00 Sep. 24, 2009 Page 356 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.3.3
Time Constant Register B (TCORB)
TCORB is an 8-bit readable/writable register. TCORB_0 and TCORB_1 (or TCORB_2 and
TCORB_3) comprise a single 16-bit register, so they can be accessed together by word access.
TCORB is continually compared with the value in TCNT. When a match is detected, the
corresponding compare-match flag B (CMFB) in TCSR is set. Note, however, that comparison is
disabled during the T2 state of a TCORB write cycle.
The timer output from the TMO pin can be freely controlled by the compare-match signal B and
the settings of the output select bits, OS1 and OS0, in TCSR.
The initial value of TCORB is H'FF.
11.3.4
Timer Control Register (TCR)
TCR selects the TCNT clock source and the time at which TCNT is cleared, and controls interrupt
requests.
Bit
Bit Name
Initial
Value
R/W
Description
7
CMIEB
0
R/W
Compare-Match Interrupt Enable B
Selects whether the CMFB interrupt request (CMIB) is
enabled or disabled when the CMFB flag in TCSR is set to
1.
0: CMFB interrupt request (CMIB) is disabled
1: CMFB interrupt request (CMIB) is enabled
6
CMIEA
0
R/W
Compare-Match Interrupt Enable A
Selects whether the CMFA interrupt request (CMIA) is
enabled or disabled when the CMFA flag in TCSR is set to
1.
0: CMFA interrupt request (CMIA) is disabled
1: CMFA interrupt request (CMIA) is enabled
5
OVIE
0
R/W
Timer Overflow Interrupt Enable
Selects whether the OVF interrupt request (OVI) is enabled
or disabled when the OVF flag in TCSR is set to 1.
0: OVF interrupt request (OVI) is disabled
1: OVF interrupt request (OVI) is enabled
Rev. 6.00 Sep. 24, 2009 Page 357 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
Bit
Bit Name
Initial
Value
R/W
Description
4
CCLR1
0
R/W
Counter Clear 1 and 0
3
CCLR0
0
R/W
These bits select the method by which TCNT is cleared
00: Clearing is disabled
01: Cleared on compare-match A
10: Cleared on compare-match B
11: Cleared on rising edge of external reset input
2
CKS2
0
R/W
Clock Select 2 to 0
1
CKS1
0
R/W
0
CKS0
0
R/W
The input clock can be selected from three clocks divided
from the system clock (φ). When use of an external clock is
selected, three types of count can be selected: at the rising
edge, the falling edge, and both rising and falling edges.
000: Clock input disabled
001: φ/8 internal clock source, counted on the falling edge
010: φ/64 internal clock source, counted on the falling edge
011: φ/8192 internal clock source, counted on the falling
edge
100: For channel 0: Counted on TCNT1 overflow signal*
For channel 1: Counted on TCNT0 compare-match A
signal*
For channel 2: Counted on TCNT3 overflow signal*
For channel 3: Counted on TCNT2 compare-match A
signal*
101: External clock source, counted at rising edge
110: External clock source, counted at falling edge
111: External clock source, counted at both rising and
falling edges
Note:
*
If the count input of channel 0 (channel 2) is the TCNT1 (TCNT3) overflow signal and
that of channel 1 (channel 3) is the TCNT0 (TCNT2) compare-match signal, no
incrementing clock will be generated. Do not use this setting.
Rev. 6.00 Sep. 24, 2009 Page 358 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.3.5
Timer Control/Status Register (TCSR)
TCSR indicates status flags and controls compare-match output.
• TCSR_0
Bit
Bit Name
Initial
Value
R/W
7
CMFB
0
R/(W)* Compare-Match Flag B
Description
[Setting condition]
When TCNT = TCORB
[Clearing conditions]
6
CMFA
0
•
Read CMFB when CMFB = 1, then write 0 in CMFB.
•
When DTC is activated by CMIB interrupt, the DISEL
bit in MRB of DTC is 0 with the transfer counter other
than 0.
R/(W)* Compare-Match Flag A
[Setting condition]
When TCNT = TCORA
[Clearing conditions]
5
OVF
0
•
Read CMFA when CMFA = 1, then write 0 in CMFA.
•
When DTC is activated by CMIA interrupt, the DISEL
bit in MRB of DTC is 0 with the transfer counter other
than 0.
R/(W)* Timer Overflow Flag
[Setting condition]
When TCNT overflows from H'FF to H'00
[Clearing condition]
Read OVF when OVF = 1, then write 0 in OVF
4
ADTE
0
R/W
A/D Trigger Enable
Enables or disables A/D converter start requests by
compare-match A.
0: A/D converter start requests by compare-match A are
disabled
1: A/D converter start requests by compare-match A are
enabled
Rev. 6.00 Sep. 24, 2009 Page 359 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
Bit
Bit Name
Initial
Value
R/W
Description
3
OS3
0
R/W
Output Select 3 and 2
2
OS2
0
R/W
These bits specify how the timer output level is to be
changed by a compare-match B of TCORB and
TCNT.
00: No change when compare-match B occurs
01: 0 is output when compare-match B occurs
10: 1 is output when compare-match B occurs
11: Output is inverted when compare-match B occurs
(toggle output)
1
OS1
0
R/W
Output Select 1 and 0
0
OS0
0
R/W
These bits specify how the timer output level is to be
changed by a compare-match A of TCORA and
TCNT.
00: No change when compare-match A occurs
01: 0 is output when compare-match A occurs
10: 1 is output when compare-match A occurs
11: Output is inverted when compare-match A occurs
(toggle output)
Note:
*
Only 0 can be written to this bit, to clear the flag.
Rev. 6.00 Sep. 24, 2009 Page 360 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
• TCSR_1 and TCSR_3
Bit
Bit Name
Initial
Value
R/W
7
CMFB
0
R/(W)* Compare-Match Flag B
Description
[Setting condition]
When TCNT = TCORB
[Clearing conditions]
6
CMFA
0
•
Read CMFB when CMFB = 1, then write 0 in CMFB.
•
When DTC is activated by CMIB interrupt, the DISEL
bit in MRB of DTC is 0 with the transfer counter other
than 0.
R/(W)* Compare-Match Flag A
[Setting condition]
When TCNT = TCORA
[Clearing conditions]
5
OVF
0
•
Read CMFA when CMFA = 1, then write 0 in CMFA.
•
When DTC is activated by CMIA interrupt, the DISEL
bit in MRB of DTC is 0 with the transfer counter other
than 0.
R/(W)* Timer Overflow Flag
[Setting condition]
When TCNT overflows from H'FF to H'00
[Clearing condition]
Read OVF when OVF = 1, then write 0 in OVF
4
⎯
1
⎯
Reserved
This bit is always read as 1 and cannot be modified.
3
OS3
0
R/W
Output Select 3 and 2
2
OS2
0
R/W
These bits specify how the timer output level is to be
changed by a compare-match B of TCORB and TCNT.
00: No change when compare-match B occurs
01: 0 is output when compare-match B occurs
10: 1 is output when compare-match B occurs
11: Output is inverted when compare-match B occurs
(toggle output)
Rev. 6.00 Sep. 24, 2009 Page 361 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
Bit
Bit Name
Initial
Value
R/W
Description
1
OS1
0
R/W
Output Select 1 and 0
0
OS0
0
R/W
These bits specify how the timer output level is to be
changed by a compare-match A of TCORA and TCNT.
00: No change when compare-match A occurs
01: 0 is output when compare-match A occurs
10: 1 is output when compare-match A occurs
11: Output is inverted when compare-match A occurs
(toggle output)
Note:
*
Only 0 can be written to this bit, to clear the flag.
• TCSR_2
Bit
Bit Name
Initial
Value
R/W
7
CMFB
0
R/(W)* Compare-Match Flag B
Description
[Setting condition]
When TCNT = TCORB
[Clearing conditions]
6
CMFA
0
•
Read CMFB when CMFB = 1, then write 0 in CMFB.
•
When DTC is activated by CMIB interrupt, the DISEL
bit in MRB of DTC is 0 with the transfer counter other
than 0.
R/(W)* Compare-Match Flag A
[Setting condition]
When TCNT = TCORA
[Clearing conditions]
Rev. 6.00 Sep. 24, 2009 Page 362 of 928
REJ09B0099-0600
•
Read CMFA when CMFA = 1, then write 0 in CMFA.
•
When DTC is activated by CMIA interrupt, the DISEL
bit in MRB of DTC is 0 with the transfer counter other
than 0.
Section 11 8-Bit Timers (TMR)
Bit
Bit Name
Initial
Value
R/W
5
OVF
0
R/(W)* Timer Overflow Flag
Description
[Setting condition]
When TCNT overflows from H'FF to H'00
[Clearing condition]
Read OVF when OVF = 1, then write 0 in OVF
4
⎯
0
R/W
Reserved
This bit is a readable/writable bit, but the write value should
always be 0.
3
OS3
0
R/W
Output Select 3 and 2
2
OS2
0
R/W
These bits specify how the timer output level is to be
changed by a compare-match B of TCORB and TCNT.
00: No change when compare-match B occurs
01: 0 is output when compare-match B occurs
10: 1 is output when compare-match B occurs
11: Output is inverted when compare-match B occurs
(toggle output)
1
OS1
0
R/W
Output Select 1 and 0
0
OS0
0
R/W
These bits specify how the timer output level is to be
changed by a compare-match A of TCORA and TCNT.
00: No change when compare-match A occurs
01: 0 is output when compare-match A occurs
10: 1 is output when compare-match A occurs
11: Output is inverted when compare-match A occurs
(toggle output)
Note:
*
Only 0 can be written to this bit, to clear the flag.
Rev. 6.00 Sep. 24, 2009 Page 363 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.4
Operation
11.4.1
Pulse Output
Figure 11.2 shows an example of arbitrary duty pulse output.
1. Set the CCR1 bit in TCR to 0 and the CCLR0 bit to 1 to clear TCNT by a TCORA comparematch.
2. Set the OS3 to OS0 bits in TCSR to B'0110 to output 1 by a TCORA compare-match and 0 by
a TCORB compare-match.
By the above settings, waveforms with the cycle of TCORA and the pulse width of TCORB can
be output without software intervention.
TCNT
H'FF
Counter clear
TCORA
TCORB
H'00
TMO
Figure 11.2 Example of Pulse Output
Rev. 6.00 Sep. 24, 2009 Page 364 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.5
Operation Timing
11.5.1
TCNT Incrementation Timing
Figure 11.3 shows the TCNT count timing with internal clock source. Figure 11.4 shows the
TCNT incrementation timing with external clock source. The pulse width of the external clock for
incrementation at single edge must be at least 1.5 status, and at least 2.5 states for incrementation
at both edges. The counter will not increment correctly if the pulse width is less than these values.
φ
Internal clock
TCNT input
clock
TCNT
N–1
N
N+1
Figure 11.3 Count Timing for Internal Clock Input
φ
External clock
input pin
TCNT input
clock
TCNT
N–1
N
N+1
Figure 11.4 Count Timing for External Clock Input
Rev. 6.00 Sep. 24, 2009 Page 365 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.5.2
Timing of CMFA and CMFB Setting When a Compare-Match Occurs
The CMFA and CMFB flags in TCSR are set to 1 by a compare-match signal generated when the
TCOR and TCNT values match. The compare-match signal is generated at the last state in which
the match is true, just before the timer counter is updated. Therefore, when TCOR and TCNT
match, the compare-match signal is not generated until the next incrementation clock input. Figure
11.5 shows the timing of CMF flag setting.
φ
TCNT
N
TCOR
N
N+1
Compare-match
signal
CMF
Figure 11.5 Timing of CMF Flag Setting
11.5.3
Timing of Timer Output When a Compare-Match Occurs
When a compare-match occurs, the timer output changes as specified by the output select bits,
OS3 to OS0, in TCSR. Figure 11.6 shows the timing when the output is set to toggle at comparematch A.
φ
Compare-match A
signal
Timer output
pin
Figure 11.6 Timing of Timer Output
Rev. 6.00 Sep. 24, 2009 Page 366 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.5.4
Timing of Compare-Match Clear When a Compare-Match Occurs
TCNT is cleared when compare-match A or B occurs, depending on the setting of the CCLR1 and
CCLR0 bits in TCR. Figure 11.7 shows the timing of this operation.
φ
Compare-match
signal
N
TCNT
H'00
Figure 11.7 Timing of Compare-Match Clear
11.5.5
TCNT External Reset Timing
TCNT is cleared at the rising edge of an external reset input, depending on the settings of the
CCLR1 and CCLR0 bits in TCR. The width of the clearing pulse must be at least 1.5 states. Figure
11.8 shows the timing of this operation.
φ
External reset
input pin
Clear signal
TCNT
N–1
N
H'00
Figure 11.8 Timing of Clearing by External Reset Input
Rev. 6.00 Sep. 24, 2009 Page 367 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.5.6
Timing of Overflow Flag (OVF) Setting
OVF in TCSR is set to 1 when the timer count overflows (changes from H'FF to H'00). Figure
11.9 shows the timing of this operation.
φ
TCNT
H'FF
H'00
Overflow signal
OVF
Figure 11.9 Timing of OVF Setting
Rev. 6.00 Sep. 24, 2009 Page 368 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.6
Operation with Cascaded Connection
If the CKS2 to CKS0 bits in one of TCR_0 and TCR_1 (or TCR_2 and TCR_3) are set to B'100,
the 8-bit timers (TMR) of the two channels are cascaded. With this configuration, a single 16-bit
timer can be used (16-bit timer mode) or compare-matches of 8-bit channel 0 (channel 2) can be
counted by the timer of channel 1 (channel 3) (compare-match count mode). In the case that
channel 0 is connected to channel 1 in cascade, the timer operates as described below.
11.6.1
16-Bit Count Mode
When the CKS2 to CKS0 bits in TCR_0 are set to B'100, the timer functions as a single 16-bit
timer with channel 0 occupying the upper 8 bits and channel 1 occupying the lower 8 bits.
• Setting of compare-match flags
⎯ The CMF flag in TCSR_0 is set to 1 when a 16-bit compare-match occurs.
⎯ The CMF flag in TCSR_1 is set to 1 when a lower 8-bit compare-match occurs.
• Counter clear specification
⎯ If the CCLR1 and CCLR0 bits in TCR_0 have been set for counter clear at compare-match,
the 16-bit counter (TCNT_0 and TCNT_1 together) is cleared when a 16-bit comparematch occurs. The 16-bit counter (TCNT_0 and TCNT_1 together) is cleared even if
counter clear by the TMRI01 pin has also been set.
⎯ The settings of the CCLR1 and CCLR0 bits in TCR_1 are ignored. The lower 8 bits cannot
be cleared independently.
• Pin output
⎯ Control of output from the TMO0 pin by the OS3 to OS0 bits in TCSR_0 is in accordance
with the 16-bit compare-match conditions.
⎯ Control of output from the TMO1 pin by the OS3 to OS0 bits in TCSR_1 is in accordance
with the lower 8-bit compare-match conditions.
11.6.2
Compare-Match Count Mode
When the CKS2 to CKS0 bits in TCR_1 are B'100, TCNT_1 counts compare-match A for channel
0. Channels 0 and 1 are controlled independently. Conditions such as setting of the CMF flag,
generation of interrupts, output from the TMO pin, and counter clearing are in accordance with the
settings for each channel.
Rev. 6.00 Sep. 24, 2009 Page 369 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.7
Interrupt Sources
11.7.1
Interrupt Sources and DTC Activation
The 8-bit timer can generate three types of interrupt: CMIA, CMIB, and OVI. Table 11.2 shows
the interrupt sources and priority. Each interrupt source can be enabled or disabled independently
by the interrupt enable bits in TCR. Independent signals are sent to the interrupt controller for each
interrupt. It is also possible to activate the DTC by means of CMIA or CMIB interrupt.
Table 11.2 8-Bit Timer Interrupt Sources
Interrupt
source
Description
Flag
DTC
Activation*
Interrupt
Priority
CMIA0
TCORA_0 compare-match
CMFA
Possible
High
CMIB0
TCORB_0 compare-match
CMFB
Possible
OVI0
TCNT_0 overflow
OVF
Not possible
CMIA1
TCORA_1 compare-match
CMFA
Possible
CMIB1
TCORB_1 compare-match
CMFB
Possible
OVI1
TCNT_1 overflow
OVF
Not possible
CMIA2
TCORA_2 compare-match
CMFA
Possible
CMIB2
TCORB_2 compare-match
CMFB
Possible
OVI2
TCNT_2 overflow
OVF
Not possible
CMIA3
TCORA_3 compare-match
CMFA
Possible
CMIB3
TCORB_3 compare-match
CMFB
Possible
OVI3
TCNT_3 overflow
OVF
Not possible
Low
Note: This list shows the initial state directly after the reset. Relative channel priorities can be
changed by the interrupt controller.
11.7.2
A/D Converter Activation
The A/D converter can be activated only by channel 0 compare match A.
If the ADTE bit in TCSR0 is set to 1 when the CMFA flag is set to 1 by the occurrence of channel
0 compare match A, a request to start A/D conversion is sent to the A/D converter. If the 8-bit
timer conversion start trigger has been selected on the A/D converter side at this time, A/D
conversion is started.
Rev. 6.00 Sep. 24, 2009 Page 370 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.8
Usage Notes
11.8.1
Setting Module Stop Mode
The TMR is enabled or disabled by setting the module stop control register. In the initial state, the
TMR is disabled. After the module stop mode is canceled, registers can be accessed. For details,
see section 22, Power-Down Modes.
11.8.2
Contention between TCNT Write and Clear
If a timer counter clock pulse is generated during the T2 state of a TCNT write cycle, the clear
takes priority, so that the counter is cleared and the write is not performed. Figure 11.10 shows
this operation.
TCNT write cycle by CPU
T2
T1
φ
Address
TCNT address
Internal write signal
Counter clear signal
TCNT
N
H'00
Figure 11.10 Contention between TCNT Write and Clear
Rev. 6.00 Sep. 24, 2009 Page 371 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.8.3
Contention between TCNT Write and Increment
If a timer counter clock pulse is generated during the T2 state of a TCNT write cycle, the write
takes priority and the counter is not incremented. Figure 11.11 shows this operation.
TCNT write cycle by CPU
T1
T2
φ
Address
TCNT address
Internal write signal
TCNT input clock
TCNT
N
M
Counter write data
Figure 11.11 Contention between TCNT Write and Increment
Rev. 6.00 Sep. 24, 2009 Page 372 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.8.4
Contention between TCOR Write and Compare-Match
During the T2 state of a TCOR write cycle, the TCOR write has priority even if a compare-match
occurs and the compare-match signal is disabled. Figure 11.12 shows this operation.
TCOR write cycle by CPU
T1
T2
φ
Address
TCOR address
Internal write signal
TCNT
N
N+1
TCOR
N
M
TCOR write data
Compare-match signal
Disabled
Figure 11.12 Contention between TCOR Write and Compare-Match
11.8.5
Contention between Compare-Matches A and B
If compare-matches A and B occur at the same time, the 8-bit timer operates in accordance with
the priorities for the output states set for compare-match A and compare-match B, as shown in
table 11.3.
Table 11.3 Timer Output Priorities
Output Setting
Priority
Toggle output
High
1 output
0 output
No change
Low
Rev. 6.00 Sep. 24, 2009 Page 373 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.8.6
Switching of Internal Clocks and TCNT Operation
TCNT may increment erroneously when the internal clock is switched over. Table 11.4 shows the
relationship between the timing at which the internal clock is switched (by writing to the CKS1
and CKS0 bits) and the TCNT operation.
When the TCNT clock is generated from an internal clock, the falling edge of the internal clock
pulse is detected. If clock switching causes a change from high to low level, as shown in no. 3 in
table 11.4, a TCNT clock pulse is generated on the assumption that the switchover is a falling
edge. This increments TCNT.
Erroneous incrementation can also happen when switching between internal and external clocks.
Table 11.4 Switching of Internal Clock and TCNT Operation
No.
1
Timing of Switchover
by Means of CKS1 and
CKS0 Bits
TCNT Clock Operation
Switching from low to
1
low*
Clock before
switchover
Clock after
switchover
TCNT clock
TCNT
N
N+1
CKS bit rewrite
2
Switching from low to
high*2
Clock before
switchover
Clock after
switchover
TCNT clock
TCNT
N
N+1
N+2
CKS bit rewrite
Rev. 6.00 Sep. 24, 2009 Page 374 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
No.
3
Timing of Switchover
by Means of CKS1 and
CKS0 Bits
TCNT Clock Operation
Switching from high to
3
low*
Clock before
switchover
Clock after
switchover
*4
TCNT clock
TCNT
N
N+1
N+2
CKS bit rewrite
4
Switching from high to
high
Clock before
switchover
Clock after
switchover
TCNT clock
TCNT
N
N+1
N+2
CKS bit rewrite
Notes: 1.
2.
3.
4.
Includes switching from low to stop, and from stop to low.
Includes switching from stop to high.
Includes switching from high to stop.
Generated on the assumption that the switchover is a falling edge; TCNT is
incremented.
Rev. 6.00 Sep. 24, 2009 Page 375 of 928
REJ09B0099-0600
Section 11 8-Bit Timers (TMR)
11.8.7
Contention between Interrupts and Module Stop Mode
If module stop mode is entered when an interrupt has been requested, it will not be possible to
clear the CPU interrupt source or the DTC activation source. Interrupts should therefore be
disabled before entering module stop mode.
11.8.8
Mode Setting in Cascading
When 16-bit counter mode and compare much counter mode are set simultaneously, input clock of
TCNT_0 and TCNT_1 (or TCNT_2 and TCNT_3) are not generated, causing the counter to stop
operating. This mode should not be set.
Rev. 6.00 Sep. 24, 2009 Page 376 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
Section 12 Watchdog Timer (WDT)
The watchdog timer (WDT) is an 8-bit timer in two channels that can reset this LSI internally or
generate the internal NMI interrupt, if a system crash prevents the CPU from writing to the timer.
When this watchdog function is not needed, the WDT can be used as an interval timer. In interval
timer operation, an interval timer interrupt is generated each time the counter overflows.
The block diagram of the WDT is shown in figure 12.1.
12.1
Features
• Selectable from eight counter input clocks for WDT_0
Selectable from 16 counter input clocks for WDT_1
• Switchable between watchdog timer mode and interval timer mode
Watchdog timer mode
• If the counter in WDT_0 overflows, it is possible to select whether this LSI is internally reset
or not
• Power-on reset and manual reset are selectable for internal reset
• If the counter in WDT_1 overflows, it is possible to select whether this LSI is internally reset
at a power-on timing or the internal NMI interrupt is generated
Interval timer mode
• If the counter overflows, the WDT generates an interval timer interrupt (WOVI)
• Selected clock can be output from BUZZ output pin (WDT_1)
Rev. 6.00 Sep. 24, 2009 Page 377 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
Interrupt
control
Clock
Internal reset signal*
Clock
select
Reset
control
RSTCSR
TCNT_0
φ/2
φ/64
φ/128
φ/512
φ/2048
φ/8192
φ/32768
φ/131072
Internal clock
TCSR_0
Module bus
WDT
Legend:
TCSR_0: Timer control/status register 0
TCNT_0: Timer counter 0
RSTCSR: Reset control/status register
Note: * The internal reset signal is generated by the register setting.
Power-on reset and manual reset are selectable for internal reset.
Figure 12.1 Block Diagram of WDT_0 (1)
Rev. 6.00 Sep. 24, 2009 Page 378 of 928
REJ09B0099-0600
Bus
interface
Internal bus
Overflow
WOVI0
(interrupt request signal)
Section 12 Watchdog Timer (WDT)
Internal NMI
(interrupt request signal)
Interrupt
control
Overflow
Clock
Reset
control
Clock
select
Internal reset signal*
φ/2
φ/64
φ/128
φ/512
φ/2048
φ/8192
φ/32768
φ/131072
Internal clock
BUZZ
TCNT_1
TCSR_1
Bus
interface
Module bus
φSUB/2
φSUB/4
φSUB/8
φSUB/16
φSUB/32
φSUB/64
φSUB/128
φSUB/256
Internal bus
WOVI1
(interrupt request signal)
WDT
Legend:
TCSR_1:
TCNT_1:
Timer control/status register 1
Timer counter 1
Note: * The internal reset signal is generated by the register setting.
Power-on reset is set for internal reset.
Figure 12.1 Block Diagram of WDT_1 (2)
12.2
Input/Output Pin
Table 12.1 shows the WDT pin.
Table 12.1 Pin Configuration
Name
Symbol
Input/Output
Function
Buzz output
BUZZ
Output
Clock output selected at WDT_1
Rev. 6.00 Sep. 24, 2009 Page 379 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
12.3
Register Descriptions
The WDT has the following three registers. To prevent accidental overwriting, TCSR and TCNT
have to be written to by a different method from normal registers. For details, see section 12.6.1,
Notes on Register Access. For detailed description on the system control register, see section
3.2.2, System Control Register (SYSCR). For details on the pin function control register, see
section 7.3.6, Pin Function Control Register (PFCR).
• Timer counter (TCNT)
• Timer control/status register (TCSR)
• Reset control/status register (RSTCSR)
12.3.1
Timer Counter (TCNT)
TCNT is an 8-bit readable/writable up-counter. TCNT is initialized to H'00 when the TME bit in
TCSR is cleared to 0.
To initialize TCNT to H’00 during timer operation, write a value of H'00 directly to TCNT. For
details, see 12.6.7, Initialization of TCNT by the TME Bit.
12.3.2
Timer Control/Status Register
TCSR functions include selecting the clock source to be input to TCNT and the timer mode.
• TCSR_0
Bit
7
Bit Name
OVF
Initial
Value
0
R/W
Description
1
R/(W)* Overflow Flag
Indicates that TCNT has overflowed. Only a 0 can be
written to this bit, to clear the flag.
[Setting condition]
When TCNT overflows (changes from H'FF to H'00).
However, when internal reset request generation is
selected in watchdog timer mode, OVF is cleared
automatically by the internal reset.
[Clearing condition]
2
Cleared by reading TCSR* when OVF = 1, then writing 0
to OVF
Rev. 6.00 Sep. 24, 2009 Page 380 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
Bit
Bit Name
Initial
Value
R/W
Description
6
WT/IT
0
R/W
Timer Mode Select
Selects whether the WDT is used as a watchdog timer or
interval timer.
0: Interval timer mode (the interval timer interrupt (WOVI)
request to the CPU)
1: Watchdog timer mode (internal reset selectable)
5
TME
0
R/W
Timer Enable
When this bit is set to 1, TCNT starts counting. When this
bit is cleared, TCNT stops counting and is initialized to
H'00.
4, 3
⎯
All 1
⎯
2
CKS2
0
R/W
Clock Select 0 to 2
1
CKS1
0
R/W
0
CKS0
0
R/W
These bits select the clock source to be input to TCNT.
3
The overflow frequency* for φ = 20 MHz is enclosed in
parentheses.
Reserved
These bits are always read as 1 and cannot be modified.
000: Clock φ/2 (frequency: 25.6 μs)
001: Clock φ/64 (frequency: 819.2 μs)
010: Clock φ/128 (frequency: 1.6 ms)
011: Clock φ/512 (frequency: 6.6 ms)
100: Clock φ/2048 (frequency: 26.2 ms)
101: Clock φ/8192 (frequency: 104.9 ms)
110: Clock φ/32768 (frequency: 419.4 ms)
111: Clock φ/131072 (frequency: 1.68 s)
Notes: 1. Only 0 can be written for flag clearing.
2. When the OVF flag is polled with the interval timer interrupt disabled, read the OVF bit
while it is 1 at least twice.
3. The overflow period is the time from when TCNT starts counting up from H′00 until an
overflow occurs.
Rev. 6.00 Sep. 24, 2009 Page 381 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
• TCSR_1
Bit
7
Bit Name
OVF
Initial
Value
0
R/W
Description
1
R/(W)* Overflow Flag
Indicates that TCNT has overflowed. Only a 0 can be
written to this bit, to clear the flag.
[Setting condition]
When TCNT overflows (changes from H'FF to H'00).
However, when internal reset request generation is
selected in watchdog timer mode, OVF is cleared
automatically by the internal reset.
[Clearing condition]
2
Cleared by reading TCSR* when OVF = 1, then writing 0
to OVF
6
WT/IT
0
R/W
Timer Mode Select
Selects whether the WDT is used as a watchdog timer or
interval timer.
0: Interval timer mode (the interval timer interrupt (WOVI)
request to the CPU)
1: Watchdog timer mode (a power-on reset or the NMI
interrupt request to the CPU)
5
TME
0
R/W
Timer Enable
When this bit is set to 1, TCNT starts counting. When this
bit is cleared, TCNT stops counting and is initialized to
H'00.
Rev. 6.00 Sep. 24, 2009 Page 382 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
Bit
Bit Name
Initial
Value
R/W
Description
4
PSS
0
R/W
Prescaler Select
Selects the clock source input to TCNT of WDT_1.
Controls the operation in power-down mode transition.
0: TCNT counts divided clock of φ-base prescaler (PSM).
When SLEEP instruction is executed in high-speed
mode or medium-speed mode, transition to sleep
mode or software standby mode is made.
1: TCNT counts divided clock of φSUB -base prescaler
(PSS).
When SLEEP instruction is executed in high-speed
mode or medium-speed mode, transition to sleep
mode, software standby mode, or watch mode* is
made.
Note: * When transition is made to watch mode, make
sure that high-speed mode is set.
3
RST/NMI
0
R/W
Reset or NMI (REST/NMI)
Selects either a power-on reset or the NMI interrupt
request when TCNT overflows in watchdog timer mode.
0: NMI interrupt is requested.
1: Power-on reset is requested.
Rev. 6.00 Sep. 24, 2009 Page 383 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
Bit
Bit Name
Initial
Value
R/W
Description
2
CKS2
0
R/W
Clock Select 2 to 0
1
CKS1
0
R/W
0
CKS0
0
R/W
These bits select the clock source to be input to TCNT.
3
The overflow frequency* for φ = 20 MHz and φSUB =
32.768 MHz is enclosed in parentheses.
When PSS = 0:
000: Clock φ/2 (frequency: 25.6 μs)
001: Clock φ/64 (frequency: 819.2 μs)
010: Clock φ/128 (frequency: 1.6 ms)
011: Clock φ/512 (frequency: 6.6 ms)
100: Clock φ/2048 (frequency: 26.2 ms)
101: Clock φ/8192 (frequency: 104.9 ms)
110: Clock φ/32768 (frequency: 419.4 ms)
111: Clock φ/131072 (frequency: 1.68 s)
When PSS = 1:
000: Clock φSUB/2 (frequency: 15.6 ms)
001: Clock φSUB/4 (frequency: 31.3 ms)
010: Clock φSUB/8 (frequency: 62.5 ms)
011: Clock φSUB/16 (frequency: 125 ms)
100: Clock φSUB/32 (frequency: 250 ms)
101: Clock φSUB/64 (frequency: 500 ms)
110: Clock φSUB/128 (frequency: 1 s)
111: Clock φSUB/256 (frequency: 2 s)
Notes: 1. Only 0 can be written, for flag clearing.
2. When the OVF flag is polled with the interval timer interrupt disabled, read the OVF bit
while it is 1 at least twice.
3. The overflow period is the time from when TCNT starts counting up from H'00 until
overflow occurs.
Rev. 6.00 Sep. 24, 2009 Page 384 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
12.3.3
Reset Control/Status Register (RSTCSR) (WDT_0 only)
RSTCSR controls to generate the internal reset signal when TCNT overflows, and selects the type
of internal reset signal. RSTCSR is initialized by a reset signal from the RES pin, and not by the
WDT internal reset signal caused by overflows.
Bit
Bit Name
Initial
Value
R/W
7
WOVF
0
R/(W)* Watchdog Overflow Flag
Description
This bit is set when TCNT overflows in watchdog timer
mode. This bit cannot be set in interval timer mode, and
only 0 can be written, to clear the flag.
[Setting condition]
Set when TCNT overflows (changed from H'FF to H'00)
in watchdog timer mode
[Clearing condition]
Cleared by reading RSTCSR when WOVF = 1, and
then writing 0 to WOVF
6
RSTE
0
R/W
Reset Enable
Specifies whether or not a reset signal is generated in
the chip if TCNT overflows during watchdog timer
operation.
0: Reset signal is not generated even if TCNT
overflows. (Though this LSI is not reset, TCNT and
TCSR in WDT are reset.)
1: Reset signal is generated if TCNT overflows.
5
RSTS
0
R/W
Reset Select
Selects the type of internal reset, which is generated if
TCNT overflows during watchdog timer operation.
0: Power-on reset
1: Manual reset
⎯
4 to 0
All 1
⎯
Reserved
These bits are always read as 1 and cannot be
modified.
Note:
*
Only 0 can be written, to clear the flag.
Rev. 6.00 Sep. 24, 2009 Page 385 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
12.4
Operation
12.4.1
Watchdog Timer Mode
To use the WDT as a watchdog timer, set the WT/IT bit in TCSR and the TME bit to 1.
Software must prevent TCNT overflows by rewriting the TCNT value (normally be writing H'00)
before overflows occurs. Thus, TCNT does not overflow while the system is operating normally.
When the WDT is used as a watchdog timer and the RSTE bit in RSTCSR of WDT_0 is set to 1,
and if TCNT overflows without being rewritten because of a system malfunction or other error, an
internal reset signal for this LSI is output for 518 system clocks.
When the RST/NMI bit in TCSR of WDT_1 is set to 1, and if TCNT overflows, the internal reset
signal is output for 516 system clocks. When the RST/ NMI bit is cleared to 0, if TCNT
overflows, an NMI interrupt request is generated (for 515 or 516 system clocks when the clock
source is set to φSUB (PSS = 1)).
An internal reset request from the watchdog timer and a reset input from the RES pin are both
treated as having the same vector. If a WDT internal reset request and the RES pin reset occur at
the same time, the RES pin reset has priority and the WOVF bit in RSTCSR is cleared to 0.
An NMI interrupt request from the watchdog timer and an interrupt request from the NMI pin are
both treated as having the same vector. So, avoid handling an NMI interrupt request from the
watchdog timer and an interrupt request from the NMI pin at the same time.
Rev. 6.00 Sep. 24, 2009 Page 386 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
TCNT value
Overflow
H'FF
Time
H'00
WT/IT = 1
TME = 1
Write H'00'
to TCNT
WOVF = 1
WT/IT = 1 Write H'00'
TME = 1 to TCNT
Internal reset signal*
Legend:
WT/IT: Timer mode select bit
Timer enable bit
TME:
WOVF: Overflow flag
518 system clocks (WDT0)
515/516 system clocks (WDT1)
Note: * In the case of WDT_0, the internal reset signal is generated only when the RSTE bit is set to 1.
In the case of WDT_1, either the internal reset or the NMI interrupt is generated.
Figure 12.2 Watchdog Timer Mode Operation
12.4.2
Interval Timer Mode
To use the WDT as an internal timer, set the WT/IT bit in TCSR to 0 and the TME bit to 1.
When the WDT is used as an interval timer, an interval timer interrupt (WOVI) is generated each
time the TCNT overflows. (The NMI interrupt request is not generated.) Therefore, an interrupt
can be generated at specified times.
Rev. 6.00 Sep. 24, 2009 Page 387 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
TCNT value
Overflow
H'FF
Overflow
Overflow
Overflow
Time
H'00
WT/IT = 0
TME = 1
WOVI
WOVI
WOVI
WOVI
Legend:
WOVI: Interval timer interrupt request generation
Figure 12.3 Interval Timer Mode Operation
12.4.3
Timing of Setting Overflow Flag (OVF)
The OVF bit in TCSR is set to 1 if TCNT overflows during interval timer operation. At the same
time, an interval timer interrupt (WOVI) is requested. This timing is shown in figure 12.4.
In the case of WDT_1, when an NMI request is selected in watchdog timer mode, if TCNT
overflows, the OVF bit in TCSR is set to 1 and an NMI interrupt is requested simultaneously.
φ
TCNT
H'FF
Overflow signal
(internal signal)
OVF
Figure 12.4 Timing of OVF Setting
Rev. 6.00 Sep. 24, 2009 Page 388 of 928
REJ09B0099-0600
H'00
Section 12 Watchdog Timer (WDT)
12.4.4
Timing of Setting Watchdog Timer Overflow Flag (WOVF)
In the case of WDT_0, if TCNT overflows in watchdog timer mode, the WOVF bit in RSTCSR is
set to 1. If TCNT overflows while the RSTE bit in RSTCSR is set to 1, an internal reset signal is
generated for the entire chip. (The WOVI interrupt is not generated.) This timing is shown in
figure 12.5.
φ
TCNT
H'FF
H'00
Overflow signal
(internal signal)
WOVF
Internal reset
signal
518 states (WDT_0)
515/516 states (WDT_1)
Figure 12.5 Timing of WOVF Setting
12.5
Interrupt Sources
During interval timer mode operation, an overflow generates an interval timer interrupt (WOVI).
The interval timer interrupt is requested whenever the OVF flag in TCSR is set to 1. OVF must be
cleared to 0 in the interrupt handling routine.
If an NMI request has been chosen in watchdog timer mode, an NMI request is generated when a
TCNT overflow occurs.
Table 12.2 WDT Interrupt Source
Name
Interrupt Source
Interrupt Flag
WOVI
TCNT overflow (interval timer mode)
OVF
NMI
TCNT overflow (watchdog timer mode)
OVF
Rev. 6.00 Sep. 24, 2009 Page 389 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
12.6
Usage Notes
12.6.1
Notes on Register Access
The watchdog timer’s TCNT and TCSR registers differ from other registers in being more
difficult to write to. The procedures for writing to and reading these registers are given below.
Writing to TCNT and TCSR: These registers must be written to by a word transfer instruction.
They cannot be written to by a byte transfer instruction. Refer to figure 12.6.
Both TCNT and TCSR are allocated to the same address when they are written to. When writing
to TCNT, the upper byte must be H'5A and the lower byte must be data to be written to. When
writing to TCSR, the upper byte must be H'A5 and the lower byte must be data to be written to.
Accordingly, the lower byte data is written to TCNT or TCSR.
Writing to TCNT
15
Address: H'FF74
8
7
H'5A
0
Write data
Writing to TCSR
15
Address: H'FF74
8
H'A5
7
0
Write data
Figure 12.6 Writing to TCNT and TCSR (WDT_0)
Rev. 6.00 Sep. 24, 2009 Page 390 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
Writing to RSTCSR: This register must be written to by a word transfer instruction. It cannot be
written to by a byte transfer instruction. Refer to figure 12.7.
The method of writing 0 to the WOVF bit differs from that of writing to the RSTE and RSTS bits.
To write 0 to the WOVF bit, the upper byte must be H'A5 and the lower byte must be H'00. This
clears the WOVF bit to 0 and does not affect the RSTE and RSTS bits.
To write to the RSTE and RSTS bits, the upper byte must be H'5A and the lower byte must be data
to be written to. Bits 6 and 5 in the lower byte are written to the RSTE and RSTS bits,
respectively. This does not affect the WOVF bit.
Writing 0 to WOVF bit
15
Address: H'FF76
8
7
H'A5
0
H'00
Writing to RSTE or RSTS bit
15
Address: H'FF76
8
H'5A
7
0
Write data
Figure 12.7 Writing to RSTCSR
Reading from TCNT, TCSR and RSTCSR (in the case of WDT_0): These registers are read in
the same way as other registers. The read addresses are allocated in H'FF74 for TCSR, H'FF75 for
TCNT, and H'FF77 for RSTCSR.
Rev. 6.00 Sep. 24, 2009 Page 391 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
12.6.2
Contention between Timer Counter (TCNT) Write and Increment
If a timer counter clock pulse is generated during the T2 state of a TCNT write cycle, the write
takes priority and the timer counter is not incremented. Figure 12.8 shows this operation.
TCNT write cycle
T1
T2
φ
Address
Internal write signal
TCNT input clock
TCNT
N
M
Counter write data
Figure 12.8 Contention between TCNT Write and Increment
12.6.3
Changing Value of PSS or CKS2 to CKS0
If the PSS or CKS0 to CKS2 bits in TCSR are modified while the WDT is operating, errors could
occur in the incrementation. Software must be used to stop the watchdog timer (by clearing the
TME bit to 0) before changing the value of the PSS or CKS0 to CKS2 bits.
12.6.4
Switching between Watchdog Timer Mode and Interval Timer Mode
If the mode is switched between watchdog timer mode and interval timer mode while the WDT is
operating, errors could occur. Software must be used to stop the watchdog timer (by clearing the
TME bit to 0) before switching the timer mode.
Rev. 6.00 Sep. 24, 2009 Page 392 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
12.6.5
Internal Reset in Watchdog Timer Mode
This LSI is not reset internally when TCNT overflows, if the RSTE bit is cleared to 0 in watchdog
timer mode, however TCNT_0 and TCSR_0 of the WDT_0 are reset.
TCNT, TCSR, or RSTCR cannot be written to for 132 states following an overflow. During this
period, any attempt to read the WOVF flag is not acknowledged. Accordingly, wait 132 states
after an overflow to write 0 to the WOVF flag.
12.6.6
OVF Flag Clearing in Interval Timer Mode
When the OVF flag setting conflicts with the OVF flag reading in interval timer mode, writing 0
to the OVF flag may not clear the flag even though the OVF flag has been read while it is 1. If
there is a possibility that the OVF flag setting and reading will conflict, such as when the OVF
flag is polled with the interval timer interrupt disabled, read the OVF flag while it is 1 at least
twice before writing 0 to the OVF flag to clear the flag.
12.6.7
Initialization of TCNT by the TME Bit
In high-speed or medium-speed mode, after the counter (TCNT) is initialized by clearing TME in
TCSR to 0 while operation is in progress with φSUB (subclock) selected as the dividing clock
(PSS in TCSR set to 1) for the TCNT input clock, TCNT may not initialize properly when TME is
once again set to 1 to activate TCNT operation. To avoid this problem, TCNT by writing a value
of H'00 to it directly.
Rev. 6.00 Sep. 24, 2009 Page 393 of 928
REJ09B0099-0600
Section 12 Watchdog Timer (WDT)
Rev. 6.00 Sep. 24, 2009 Page 394 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Section 13 Serial Communication Interface (SCI)
This LSI has five independent serial communication interface (SCI) channels. The SCI can handle
both asynchronous and clocked synchronous serial communication. In asynchronous mode, serial
data communication can be carried out using standard asynchronous communication chips such as
a Universal Asynchronous Receiver/Transmitter (UART) or an Asynchronous Communication
Interface Adapter (ACIA). In asynchronous mode, a function is also provided for serial
communication between multiple processors (multiprocessor communication function). The SCI
also supports an IC card (Smart Card) interface conforming to ISO/IEC 7816-3 (Identification
Card) as an extension function in clocked synchronous serial communication mode.
13.1
Features
• Choice of asynchronous or clocked synchronous serial communication mode
(Because the same pin is used as the clock input/output pin for channel 1 and channel 4, these
clocks cannot be output at the same time.)
• Full-duplex communication capability
The transmitter and receiver are mutually independent, enabling transmission and reception to
be executed simultaneously.
The double-buffering configuration is adopted in both the transmitter and the receiver,
enabling continuous transmission and continuous reception of serial data.
• On-chip baud rate generator allows any bit rate to be selected
External clock can be selected as a transfer clock source (except in Smart Card interface mode)
• Choice of LSB-first or MSB-first transfer (except in the case of asynchronous mode 7-bit data)
• Four interrupt sources
Transmit-end, transmit-data-empty, receive-data-full, and receive error — that can issue
requests.
The transmit-data-empty and receive-data-full interrupts can be used to activate the data
transfer controller (DTC).
• Module stop mode can be set
Asynchronous mode
• Data length: 7 or 8 bits
• Stop bit length: 1 or 2 bits
• Parity: Even, odd, or none
• Receive error detection: Parity, overrun, and framing errors
Rev. 6.00 Sep. 24, 2009 Page 395 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
• Break detection: Break can be detected by reading the RxD pin level directly in the case of a
framing error
• Communications between multiple processors are possible.
Clocked synchronous mode
• Data length: 8 bits
• Receive error detection: Overrun errors detected
Smart Card interface
• Automatic transmission of an error signal when a parity error is detected in receive mode
• Automatic data retransmission when an error signal is received in transmit mode
• Direct convention and inverse convention both supported
Bus interface
Figure 13.1 shows a block diagram of the SCI.
Module data bus
RDR
TDR
BRR
SCMR
SSR
RxD
TxD
SCR
RSR
TSR
SMR
Baud rate
generator
Transmission/
reception control
Parity generation
φ
φ/4
φ/16
φ/64
Clock
Parity check
External clock
SCK
Legend:
RSR:
RDR:
TSR:
TDR:
SMR:
SCR:
SSR:
SCMR:
Receive shift register
Receive data register
Transmit shift register
Transmit data register
Serial mode register
Serial control register
Serial status register
Smart Card mode register
Figure 13.1 Block Diagram of SCI
Rev. 6.00 Sep. 24, 2009 Page 396 of 928
REJ09B0099-0600
TEI
TXI
RXI
ERI
Internal
data bus
Section 13 Serial Communication Interface (SCI)
13.2
Input/Output Pins
Table 13.1 shows the pin configuration for each SCI channel.
Table 13.1 Pin Configuration
Channel
Pin Name*1
I/O
Function
0
SCK0
I/O
Clock input/output in channel 0
RxD0
Input
Receive data input in channel 0
Output
Transmit data output in channel 0
I/O
Clock input/output in channel 1
TxD0
1
2
3
2
SCK1*
RxD1
Input
Receive data input in channel 1
TxD1
Output
Transmit data output in channel 1
SCK2
I/O
Clock input/output in channel 2
RxD2
Input
Receive data input in channel 2
TxD2
Output
Transmit data output in channel 2
SCK3
I/O
Clock input/output in channel 3
RxD3
Input
Receive data input in channel 3
Output
Transmit data output in channel 3
TxD3
4
2
SCK4*
I/O
Clock input/output in channel 4
RxD4
Input
Receive data input in channel 4
TxD4
Output
Transmit data output in channel 4
Notes: 1. Pin names SCK, RxD, and TxD are used in this manual for all channels, omitting the
channel designation.
2. Because SCK1 and SCK4 are allocated to the same pin, these clocks cannot be output
at the same time.
Rev. 6.00 Sep. 24, 2009 Page 397 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.3
Register Descriptions
The SCI has the following registers for each channel. The serial mode register (SMR), serial status
register (SSR), and serial control register (SCR) are described separately for normal serial
communication interface mode and Smart Card interface mode, because some of their bit
functions differ depending on the mode.
Channel 0
• Receive shift register_0 (RSR_0)
• Receive data register_0 (RDR_0)
• Transmit data register_0 (TDR_0)
• Transmit shift register_0 (TSR_0)
• Serial mode register_0 (SMR_0)
• Serial control register_0 (SCR_0)
• Serial status register_0 (SSR_0)
• Smart Card mode register_0 (SCMR_0)
• Bit rate register_0 (BRR_0)
Channel 1
• Receive shift register_1 (RSR_1)
• Receive data register_1 (RDR_1)
• Transmit data register_1 (TDR_1)
• Transmit shift register_1 (TSR_1)
• Serial mode register_1 (SMR_1)
• Serial control register_1 (SCR_1)
• Serial status register_1 (SSR_1)
• Smart Card mode register_1 (SCMR_1)
• Bit rate register_1 (BRR_1)
Channel 2
• Receive shift register_2 (RSR_2)
• Receive data register_2 (RDR_2)
• Transmit data register_2 (TDR_2)
• Transmit shift register_2 (TSR_2)
• Serial mode register_2 (SMR_2)
• Serial control register_2 (SCR_2)
Rev. 6.00 Sep. 24, 2009 Page 398 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
• Serial status register_2 (SSR_2)
• Smart Card mode register_2 (SCMR_2)
• Bit rate register_2 (BRR_2)
Channel 3
• Receive shift register_3 (RSR_3)
• Receive data register_3 (RDR_3)
• Transmit data register_3 (TDR_3)
• Transmit shift register_3 (TSR_3)
• Serial mode register_3 (SMR_3)
• Serial control register_3 (SCR_3)
• Serial status register_3 (SSR_3)
• Smart Card mode register_3 (SCMR_3)
• Bit rate register_3 (BRR_3)
Channel 4
• Receive shift register_4 (RSR_4)
• Receive data register_4 (RDR_4)
• Transmit data register_4 (TDR_4)
• Transmit shift register_4 (TSR_4)
• Serial mode register_4 (SMR_4)
• Serial control register_4 (SCR_4)
• Serial status register_4 (SSR_4)
• Smart Card mode register_4 (SCMR_4)
• Bit rate register_4 (BRR_4)
13.3.1
Receive Shift Register (RSR)
RSR is a shift register that is used to receive serial data input to the RxD pin and convert it into
parallel data. When one byte of data has been received, it is transferred to RDR automatically.
RSR cannot be directly accessed by the CPU.
13.3.2
Receive Data Register (RDR)
RDR is an 8-bit register that stores receive data. When the SCI has received one byte of serial
data, it transfers the received serial data from RSR to RDR, where it is stored. After this, RSR is
Rev. 6.00 Sep. 24, 2009 Page 399 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
receive-enabled. As RSR and RDR function as a double buffer in this way, continuous receive
operations are possible. After confirming that the RDRF bit in SSR is set to 1, read RDR only
once.
RDR cannot be written to by the CPU.
RDR is initialized to H'00 by a reset, or in standby mode, watch mode, or module stop mode.
13.3.3
Transmit Data Register (TDR)
TDR is an 8-bit register that stores data for transmission. When the SCI detects that TSR is empty,
it transfers the transmit data written in TDR to TSR and starts transmission. As TDR and TSR
function as a double buffer in this way, continuous transmit operations are possible. When the SCI
transmits one byte of serial data, if the next transmit data has already been written to TDR, the SCI
transfers the written data to TSR to continue transmission. Although TDR can be read or written to
by the CPU at all times, to achieve reliable serial transmission, write transmit data to TDR only
once after confirming that the TDRE bit in SSR is set to 1.
TDR is initialized to H'FF by a reset, or in standby mode, watch mode, or module stop mode.
13.3.4
Transmit Shift Register (TSR)
TSR is a shift register that transmits serial data. To perform serial data transmission, the SCI first
transfers transmit data from TDR to TSR, and then sends the data to the TxD pin. TSR cannot be
directly accessed by the CPU.
13.3.5
Serial Mode Register (SMR)
SMR is used to set the SCI’s serial transfer format and select the baud rate generator clock source.
Some bit functions of SMR differ between normal serial communication interface mode and Smart
Card interface mode.
• Normal Serial Communication Interface Mode (When SMIF in SCMR Is 0)
Bit
Bit Name
Initial
Value
R/W
Description
7
C/A
0
R/W
Communication Mode
0: Asynchronous mode
1: Clocked synchronous mode
Rev. 6.00 Sep. 24, 2009 Page 400 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
Bit Name
Initial
Value
R/W
Description
6
CHR
0
R/W
Character Length (enabled only in asynchronous mode)
0: Selects 8 bits as the data length.
1: Selects 7 bits as the data length. LSB-first is fixed and
the MSB (bit 7) of TDR is not transmitted in
transmission.
In clocked synchronous mode, a fixed data length of 8
bits is used.
5
PE
0
R/W
Parity Enable (enabled only in asynchronous mode)
When this bit is set to 1, the parity bit is added to transmit
data before transmission, and the parity bit is checked in
reception. For a multiprocessor format, parity bit addition
and checking are not performed regardless of the PE bit
setting.
4
O/E
0
R/W
Parity Mode (enabled only when the PE bit is 1 in
asynchronous mode)
0: Selects even parity.
When even parity is set, parity bit addition is
performed in transmission so that the total number of 1
bits in the transmit character plus the parity bit is even.
In reception, a check is performed to see if the total
number of 1 bits in the receive character plus parity bit
is even.
1: Selects odd parity.
When odd parity is set, parity bit addition is performed
in transmission so that the total number of 1 bits in the
transmit character plus the parity bit is odd. In
reception, a check is performed to see if the total
number of 1 bits in the receive character plus the
parity bit is odd.
3
STOP
0
R/W
Stop Bit Length (enabled only in asynchronous mode)
Selects the stop bit length in transmission.
0: 1 stop bit
1: 2 stop bits
In reception, only the first stop bit is checked. If the
second stop bit is 0, it is treated as the start bit of the
next transmit character.
Rev. 6.00 Sep. 24, 2009 Page 401 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
Bit Name
Initial
Value
R/W
Description
2
MP
0
R/W
Multiprocessor Mode (enabled only in asynchronous
mode)
When this bit is set to 1, the multiprocessor
communication function is enabled. The PE bit and O/E
bit settings are invalid in multiprocessor mode.
For details, see section 13.5, Multiprocessor
Communication Function.
1
CKS1
0
R/W
Clock Select 1 and 0
0
CKS0
0
R/W
These bits select the clock source for the baud rate
generator.
00: φ clock (n = 0)
01: φ/4 clock (n = 1)
10: φ/16 clock (n = 2)
11: φ/64 clock (n = 3)
For the relationship between the bit rate register setting
and the baud rate, see section 13.3.9, Bit Rate Register
(BRR). n is the decimal representation of the value of n in
bit rate register.
Rev. 6.00 Sep. 24, 2009 Page 402 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
• Smart Card Interface Mode (When SMIF in SCMR Is 1)
Bit
Bit Name
Initial
Value
R/W
Description
7
GM
0
R/W
GS Mode
Setting this bit to 1 allows GSM mode operation. In GSM
mode, the TEND set timing is put forward to 11.0 etu
from the start and the clock output control function is
appended. For details, see section 13.7.8, Clock Output
Control.
0: Normal smart card interface mode operation (initial
value)
•
The TEND flag is generated 12.5 etu (11.5 etu in the
block transfer mode) after the beginning of the start
bit.
•
Clock output on/off control only
1: GSM mode operation in smart card interface mode
6
BLK
0
R/W
•
The TEND flag is generated 11.0 etu after the
beginning of the start bit.
•
In addition to clock output on/off control, high/low
fixed control is supported (set using SCR).
Setting this bit to 1 allows block transfer mode operation.
For details, see section 13.7.3, Block Transfer Mode.
0: Normal smart card interface mode operation (initial
value)
•
Error signal transmission, detection, and automatic
data retransmission are performed.
•
The TXI interrupt is generated by the TEND flag.
•
The TEND flag is set 12.5 etu (11.0 etu in the GSM
mode) after transmission starts.
1: Operation in block transfer mode
•
Error signal transmission, detection, and automatic
data retransmission are not performed.
•
The TXI interrupt is generated by the TDRE flag.
•
The TEND flag is set 11.5 etu (11.0 etu in the GSM
mode) after transmission starts.
Rev. 6.00 Sep. 24, 2009 Page 403 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
Bit Name
Initial
Value
R/W
Description
5
PE
0
R/W
Parity Enable (enabled only in asynchronous mode)
When this bit is set to 1, the parity bit is added to transmit
data in transmission, and the parity bit is checked in
reception. In Smart Card interface mode, this bit must be
set to 1.
4
O/E
0
R/W
Parity Mode (enabled only when the PE bit is 1 in
asynchronous mode)
0: Selects even parity.
1: Selects odd parity.
For details on setting this bit in Smart Card interface
mode, see section 13.7.2, Data Format (Except for Block
Transfer Mode).
3
BCP1
0
R/W
Basic Clock Pulse 1 and 0
2
BCP0
0
R/W
These bits specify the number of basic clock periods in a
1-bit transfer interval on the Smart Card interface.
00: 32 clock (S = 32)
01: 64 clock (S = 64)
10: 372 clock (S = 372)
11: 256 clock (S = 256)
For details, see section 13.7.4, Receive Data Sampling
Timing and Reception Margin. S stands for the value of S
in bit rate register.
1
CKS1
0
R/W
Clock Select 1 and 0
0
CKS0
0
R/W
These bits select the clock source for the baud rate
generator.
00: φ clock (n = 0)
01: φ/4 clock (n = 1)
10: φ/16 clock (n = 2)
11: φ/64 clock (n = 3)
For the relationship between the bit rate register setting
and the baud rate, see section 13.3.9, Bit Rate Register
(BRR). n is the decimal representation of the value of n in
BRR.
Note: etu: Elementary time unit (time for transfer of 1 bit)
Rev. 6.00 Sep. 24, 2009 Page 404 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.3.6
Serial Control Register (SCR)
SCR is a register that enables or disables SCI transfer operations and interrupt requests, and is also
used to selection of the transfer clock source. For details on interrupt requests, see section 13.8,
Interrupt Sources. Some bit functions of SCR differ between normal serial communication
interface mode and Smart Card interface mode.
• Normal Serial Communication Interface Mode (When SMIF in SCMR Is 0)
Bit
Bit Name
Initial
Value
R/W
Description
7
TIE
0
R/W
Transmit Interrupt Enable
When this bit is set to 1, the TXI interrupt request is
enabled.
TXI interrupt request cancellation can be performed by
reading 1 from the TDRE flag in SSR, then clearing it to
0, or clearing the TIE bit to 0.
6
RIE
0
R/W
Receive Interrupt Enable
When this bit is set to 1, RXI and ERI interrupt requests
are enabled.
RXI and ERI interrupt request cancellation can be
performed by reading 1 from the RDRF, FER, PER, or
ORER flag in SSR, then clearing the flag to 0, or clearing
the RIE bit to 0.
5
TE
0
R/W
Transmit Enable
When this bit is set to 1, transmission is enabled.
In this state, serial transmission is started when transmit
data is written to TDR and the TDRE flag in SSR is
cleared to 0.
SMR setting must be performed to decide the transfer
format before setting the TE bit to 1. When this bit is
cleared to 0, the transmission operation is disabled, and
the TDRE flag is fixed at 1.
Rev. 6.00 Sep. 24, 2009 Page 405 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
Bit Name
Initial
Value
R/W
Description
4
RE
0
R/W
Receive Enable
When this bit is set to 1, reception is enabled.
Serial reception is started in this state when a start bit is
detected in asynchronous mode or serial clock input is
detected in clocked synchronous mode.
SMR setting must be performed to decide the reception
format before setting the RE bit to 1.
Clearing the RE bit to 0 does not affect the RDRF, FER,
PER, and ORER flags, which retain their states.
3
MPIE
0
R/W
Multiprocessor Interrupt Enable (enabled only when the
MP bit in SMR is 1 in asynchronous mode)
When this bit is set to 1, receive data in which the
multiprocessor bit is 0 is skipped, and setting of the
RDRF, FER, and ORER status flags in SSR is prohibited.
On receiving data in which the multiprocessor bit is 1, this
bit is automatically cleared and normal reception is
resumed. For details, see section 13.5, Multiprocessor
Communication Function.
When receive data including MPB = 0 is received,
receive data transfer from RSR to RDR, receive error
detection, and setting of the RERF, FER, and ORER
flags in SSR, are not performed.
When receive data including MPB = 1 is received, the
MPB bit in SSR is set to 1, the MPIE bit is cleared to 0
automatically, and generation of RXI and ERI interrupts
(when the TIE and RIE bits in SCR are set to 1) and FER
and ORER flag setting are enabled.
2
TEIE
0
R/W
Transmit End Interrupt Enable
When this bit is set to 1, TEI interrupt request is enabled.
TEI cancellation can be performed by reading 1 from the
TDRE flag in SSR, then clearing it to 0 and clearing the
TEND flag to 0, or clearing the TEIE bit to 0.
Rev. 6.00 Sep. 24, 2009 Page 406 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
Bit Name
Initial
Value
R/W
Description
1
CKE1
0
R/W
Clock Enable 1 and 0
0
CKE0
0
R/W
Selects the clock source and SCK pin function.
Asynchronous mode
00: On-chip baud rate generator
SCK pin functions as I/O port
01: On-chip baud rate generator
Outputs a clock of the same frequency as the bit rate
from the SCK pin.
1X: External clock
Inputs a clock with a frequency 16 times the bit rate
from the SCK pin.
Clocked synchronous mode
0X: Internal clock (SCK pin functions as clock output)
1X: External clock (SCK pin functions as clock input)
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 407 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
• Smart Card Interface Mode (When SMIF in SCMR Is 1)
Bit
Bit Name
Initial
Value
R/W
Description
7
TIE
0
R/W
Transmit Interrupt Enable
When this bit is set to 1, TXI interrupt request is enabled.
TXI interrupt request cancellation can be performed by
reading 1 from the TDRE flag in SSR, then clearing it to
0, or clearing the TIE bit to 0.
6
RIE
0
R/W
Receive Interrupt Enable
When this bit is set to 1, RXI and ERI interrupt requests
are enabled.
RXI and ERI interrupt request cancellation can be
performed by reading 1 from the RDRF, FER, PER, or
ORER flag in SSR, then clearing the flag to 0, or clearing
the RIE bit to 0.
5
TE
0
R/W
Transmit Enable
When this bit is set to 1, transmission is enabled.
In this state, serial transmission is started when transmit
data is written to TDR and the TDRE flag in SSR is
cleared to 0.
SMR setting must be performed to decide the transfer
format before setting the TE bit to 1. When this bit is
cleared to 0, the transmission operation is disabled, and
the TDRE flag is fixed at 1.
4
RE
0
R/W
Receive Enable
When this bit is set to 1, reception is enabled.
Serial reception is started in this state when a start bit is
detected in asynchronous mode or serial clock input is
detected in clocked synchronous mode.
SMR setting must be performed to decide the reception
format before setting the RE bit to 1.
Clearing the RE bit to 0 does not affect the RDRF, FER,
PER, and ORER flags, which retain their states.
Rev. 6.00 Sep. 24, 2009 Page 408 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
Bit Name
Initial
Value
R/W
Description
3
MPIE
0
R/W
Multiprocessor Interrupt Enable (enabled only when the
MP bit in SMR is 1 in asynchronous mode)
Write 0 to this bit in Smart Card interface mode.
When receive data including MPB = 0 is received,
receive data transfer from RSR to RDR, receive error
detection, and setting of the RERF, FER, and ORER
flags in SSR, are not performed.
When receive data including MPB = 1 is received, the
MPB bit in SSR is set to 1, the MPIE bit is cleared to 0
automatically, and generation of RXI and ERI interrupts
(when the TIE and RIE bits in SCR are set to 1) and FER
and ORER flag setting are enabled.
2
TEIE
0
R/W
Transmit End Interrupt Enable
Write 0 to this bit in Smart Card interface mode.
TEI cancellation can be performed by reading 1 from the
TDRE flag in SSR, then clearing it to 0 and clearing the
TEND flag to 0, or clearing the TEIE bit to 0.
1
CKE1
0
R/W
Clock Enable 1 and 0
0
CKE0
0
R/W
Enable or disable clock output from the SCK pin. The
clock output can be dynamically switched in GSM mode.
For details, see section 13.7.8, Clock Output Control.
When the GM bit in SMR is 0:
00: Output disabled (SCK pin can be used as an I/O port
pin)
01: Clock output
1X: Reserved
When the GM bit in SMR is 1:
00: Output fixed low
01: Clock output
10: Output fixed high
11: Clock output
Legend:
X:
Don’t care
Rev. 6.00 Sep. 24, 2009 Page 409 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.3.7
Serial Status Register (SSR)
SSR is a register containing status flags of the SCI and multiprocessor bits for transfer. 1 cannot
be written to flags TDRE, RDRF, ORER, PER, and FER; they can only be cleared. Some bit
functions of SSR differ between normal serial communication interface mode and Smart Card
interface mode.
• Normal Serial Communication Interface Mode (When SMIF in SCMR Is 0)
Bit
7
Bit Name
TDRE
Initial
Value
1
R/W
Description
1
R/(W)* Transmit Data Register Empty
Displays whether TDR contains transmit data.
[Setting conditions]
•
When the TE bit in SCR is 0
•
When data is transferred from TDR to TSR and data
can be written to TDR
[Clearing conditions]
6
RDRF
0
•
When 0 is written to TDRE after reading TDRE = 1*3
•
When the DTC*2 is activated by a TXI interrupt
request and writes data to TDR
R/(W)*1 Receive Data Register Full
Indicates that the received data is stored in RDR.
[Setting condition]
•
When serial reception ends normally and receive data
is transferred from RSR to RDR
[Clearing conditions]
•
•
3
When 0 is written to RDRF after reading RDRF = 1*
2
When the DTC* is activated by an RXI interrupt and
transfers data from RDR
The RDRF flag is not affected and retains their previous
values when the RE bit in SCR is cleared to 0.
If reception of the next data is completed while the RDRF
flag is still set to 1, an overrun error will occur and the
receive data will be lost.
Rev. 6.00 Sep. 24, 2009 Page 410 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
5
Bit Name
ORER
Initial
Value
0
R/W
Description
1
R/(W)* Overrun Error
Indicates that an overrun error occurred during reception,
causing abnormal termination.
[Setting condition]
•
When the next serial reception is completed while
RDRF = 1
The receive data prior to the overrun error is retained in
RDR, and the data received subsequently is lost. Also,
subsequent serial reception cannot be continued while
the ORER flag is set to 1. In clocked synchronous mode,
serial transmission cannot be continued either.
[Clearing condition]
•
3
When 0 is written to ORER after reading ORER = 1*
The ORER flag is not affected and retains its previous
state when the RE bit in SCR is cleared to 0.
4
FER
0
R/(W)*1 Framing Error
Indicates that a framing error occurred during reception in
asynchronous mode, causing abnormal termination.
[Setting condition]
•
When the stop bit is 0
In 2 stop bit mode, only the first stop bit is checked for a
value to 1; the second stop bit is not checked. If a
framing error occurs, the receive data is transferred to
RDR but the RDRF flag is not set. Also, subsequent
serial reception cannot be continued while the FER flag is
set to 1. In clocked synchronous mode, serial
transmission cannot be continued, either.
[Clearing condition]
•
When 0 is written to FER after reading FER = 1*3
In 2-stop-bit mode, only the first stop bit is checked.
The FER flag is not affected and retains its previous state
when the RE bit in SCR is cleared to 0.
Rev. 6.00 Sep. 24, 2009 Page 411 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
3
Bit Name
PER
Initial
Value
0
R/W
Description
1
R/(W)* Parity Error
Indicates that a parity error occurred during reception
using parity addition in asynchronous mode, causing
abnormal termination.
[Setting condition]
•
When a parity error is detected during reception
If a parity error occurs, the receive data is transferred to
RDR but the RDRF flag is not set. Also, subsequent
serial reception cannot be continued while the PER flag
is set to 1. In clocked synchronous mode, serial
transmission cannot be continued, either.
[Clearing condition]
•
3
When 0 is written to PER after reading PER = 1*
The PER flag is not affected and retains its previous state
when the RE bit in SCR is cleared to 0.
2
TEND
1
R
Transmit End
Indicates that transmission has been ended.
[Setting conditions]
•
When the TE bit in SCR is 0
•
When TDRE = 1 at transmission of the last bit of a 1byte serial transmit character
[Clearing conditions]
1
MPB
0
R
•
When 0 is written to TDRE after reading TDRE = 1
•
When the DTC*2 is activated by a TXI interrupt
request and transfers transmit data to TDR
Multiprocessor Bit
MPB stores the multiprocessor bit in the receive data.
When the RE bit in SCR is cleared to 0 its previous state
is retained.
0
MPBT
0
R/W
Multiprocessor Bit Transfer
MPBT stores the multiprocessor bit to be added to the
transmit data.
Notes: 1. Only a 0 can be written to this bit to clear the flag.
2. This bit is cleared by DTC only when DISEL is 0 with the transfer counter other than 0.
3. To clear the flag by using the CPU, write 0 to the flag and then read it once again.
Rev. 6.00 Sep. 24, 2009 Page 412 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
• Smart Card Interface Mode (When SMIF in SCMR Is 1)
Bit
7
Bit Name
TDRE
Initial
Value
1
R/W
Description
1
R/(W)* Transmit Data Register Empty
Indicates whether TDR contains transmit data.
[Setting conditions]
•
When the TE bit in SCR is 0
•
When data is transferred from TDR to TSR and data
can be written to TDR
[Clearing conditions]
6
RDRF
0
•
When 0 is written to TDRE after reading TDRE = 1*3
•
When the DTC*2 is activated by a TXI interrupt
request and writes data to TDR
R/(W)*1 Receive Data Register Full
Indicates that the received data is stored in RDR.
[Setting condition]
•
When serial reception ends normally and receive data
is transferred from RSR to RDR
[Clearing conditions]
•
When 0 is written to RDRF after reading RDRF = 1*
•
When the DTC*2 is activated by an RXI interrupt and
transfers data from RDR
3
The RDRF flag is not affected and retains their previous
values when the RE bit in SCR is cleared to 0.
If reception of the next data is completed while the RDRF
flag is still set to 1, an overrun error will occur and the
receive data will be lost.
Rev. 6.00 Sep. 24, 2009 Page 413 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
5
Bit Name
ORER
Initial
Value
0
R/W
Description
1
R/(W)* Overrun Error
Indicates that an overrun error occurred during reception,
causing abnormal termination.
[Setting condition]
•
When the next serial reception is completed while
RDRF = 1
The receive data prior to the overrun error is retained in
RDR, and the data received subsequently is lost. Also,
subsequent serial cannot be continued while the ORER
flag is set to 1. In clocked synchronous mode, serial
transmission cannot be continued, either.
[Clearing condition]
•
3
When 0 is written to ORER after reading ORER = 1*
The ORER flag is not affected and retains its previous
state when the RE bit in SCR is cleared to 0.
4
ERS
0
1
R/(W)* Error Signal Status
Indicates that the status of an error, signal 1 returned
from the reception side at reception
[Setting condition]
•
When the low level of the error signal is sampled
[Clearing condition]
•
When 0 is written to ERS after reading ERS = 1*3
The ERS flag is not affected and retains its previous state
when the TE bit in SCR is cleared to 0.
Rev. 6.00 Sep. 24, 2009 Page 414 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
3
Bit Name
PER
Initial
Value
0
R/W
Description
1
R/(W)* Parity Error
Indicates that a parity error occurred during reception
using parity addition in asynchronous mode, causing
abnormal termination.
[Setting condition]
•
When a parity error is detected during reception
If a parity error occurs, the receive data is transferred to
RDR but the RDRF flag is not set. Also, subsequent
serial reception cannot be continued while the PER flag is
set to 1. In clocked synchronous mode, serial
transmission cannot be continued, either.
[Clearing condition]
•
3
When 0 is written to PER after reading PER = 1*
The PER flag is not affected and retains its previous state
when the RE bit in SCR is cleared to 0.
Rev. 6.00 Sep. 24, 2009 Page 415 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Bit
Bit Name
Initial
Value
R/W
Description
2
TEND
1
R
Transmit End
This bit is set to 1 when no error signal has been sent
back from the receiving end and the next transmit data is
ready to be transferred to TDR.
[Setting conditions]
•
When the TE bit in SCR is 0 and the ERS bit is also 0
•
When the ERS bit is 0 and the TDRE bit is 1 after the
specified interval following transmission of 1-byte
data.
The timing of bit setting differs according to the register
setting as follows:
When GM = 0 and BLK = 0, 12.5 etu after transmission
starts
When GM = 0 and BLK = 1, 11.5 etu after transmission
starts
When GM = 1 and BLK = 0, 11.0 etu after transmission
starts
When GM = 1 and BLK = 1, 11.0 etu after transmission
starts
[Clearing conditions]
•
•
1
MPB
0
R
When 0 is written to TDRE after reading TDRE = 1
2
When the DTC* is activated by a TXI interrupt and
transfers transmit data to TDR
Multiprocessor Bit
This bit is not used in Smart Card interface mode.
0
MPBT
0
R/W
Multiprocessor Bit Transfer
Write 0 to this bit in Smart Card interface mode.
Notes: etu: Elementary time unit (time for transfer of 1 bit)
1. Only 0 can be written to this bit, to clear the flag.
2. This bit is cleared by DTC only when DISEL is 0 with the transfer counter other than 0.
3. To clear the flag by using the CPU, write 0 to the flag and then read it once again.
Rev. 6.00 Sep. 24, 2009 Page 416 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.3.8
Smart Card Mode Register (SCMR)
SCMR is a register that selects Smart Card interface mode and its communications format.
Bit
Bit Name
Initial
Value
R/W
7 to 4
—
All 1
—
Description
Reserved
These bits are always read as 1, and cannot be modified.
3
SDIR
0
R/W
Smart Card Data Transfer Direction
Selects the serial/parallel conversion format.
0: LSB-first in transfer
1: MSB-first in transfer
The bit setting is valid only when the transfer data format
is 8 bits. For 7-bit data, LSB-first is fixed.
2
SINV
0
R/W
Smart Card Data Invert
Specifies inversion of the data logic level. The SINV bit
does not affect the logic level of the parity bit. To invert
the parity bit, invert the O/E bit in SMR.
0: TDR contents are transmitted as they are. Receive
data is stored as it is in RDR
1: TDR contents are inverted before being transmitted.
Receive data is stored in inverted form in RDR
1
—
1
—
Reserved
This bit is always read as 1, and cannot be modified.
0
SMIF
0
R/W
Smart Card Interface Mode Select
This bit is set to 1 to make the SCI operate in Smart Card
interface mode.
0: Normal asynchronous mode or clocked synchronous
mode
1: Smart Card interface mode
Rev. 6.00 Sep. 24, 2009 Page 417 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.3.9
Bit Rate Register (BRR)
BRR is an 8-bit register that adjusts the bit rate. As the SCI performs baud rate generator control
independently for each channel, different bit rates can be set for each channel. Table 13.2 shows
the relationships between the N setting in BRR and bit rate B for normal asynchronous mode,
clocked synchronous mode, and Smart Card interface mode. The initial value of BRR is H'FF, and
it can be read or written to by the CPU at all times.
Table 13.2 Relationships between N Setting in BRR and Bit Rate B
Communication Mode
Asynchronous Mode
Bit Rate
B=
Clocked Synchronous
Mode
B=
Smart Card Interface
Mode
B=
Legend:
B:
N:
φ:
n and S:
Error
φ × 106
64 × 2 2n-1 × (N + 1)
Error (%) = {
φ × 106
B × 64 × 2 2n-1 × (N + 1)
φ × 106
⎯
8 × 2 2n-1 × (N + 1)
φ × 106
S × 2 2n+1 × (N + 1)
-1 } × 100
Error (%) = {
φ × 106
B × S × 2 2n+1 × (N + 1)
-1 } × 100
Bit rate (bit/s)
BRR setting for baud rate generator (0 ≤ N ≤ 255)
Operating frequency (MHz)
Determined by the SMR settings shown in the following tables.
SMR Setting
SMR Setting
CKS1
CKS0
Clock
Source
0
0
φ
0
0
0
32
0
1
φ/4
1
0
1
64
1
0
φ/16
2
1
0
372
1
1
φ/64
3
1
1
256
n
BCP1
BCP0
S
Table 13.3 shows sample N settings in BRR in normal asynchronous mode. Table 13.4 shows the
maximum bit rate for each frequency in normal asynchronous mode. Table 13.6 shows sample N
settings in BRR in clocked synchronous mode. Table 13.8 shows sample N settings in BRR in
Smart Card interface mode. In Smart Card interface mode, S (the number of basic clock periods in
a 1-bit transfer interval) can be selected. For details, see section 13.7.4, Receive Data Sampling
Timing and Reception Margin. Tables 13.5 and 13.7 show the maximum bit rates with external
clock input.
Rev. 6.00 Sep. 24, 2009 Page 418 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Table 13.3 BRR Settings for Various Bit Rates (Asynchronous Mode)
Operating Frequency φ (MHz)
8
9.8304
10
12
12.288
Bit Rate
(bps)
n
N
110
2
141 0.03
2
174 –0.26
2
177 –0.25
2
212 0.03
2
217 0.08
150
2
103 0.16
2
127 0.00
2
129 0.16
2
155 0.16
2
159 0.00
300
1
207 0.16
1
255 0.00
2
64
0.16
2
77
0.16
2
79
600
1
103 0.16
1
127 0.00
1
129 0.16
1
155 0.16
1
159 0.00
1200
0
207 0.16
0
255 0.00
1
64
0.16
1
77
0.16
1
79
2400
0
103 0.16
0
127 0.00
0
129 0.16
0
155 0.16
0
159 0.00
4800
0
51
0.16
0
63
0.00
0
64
0.16
0
77
0.16
0
79
0.00
9600
0
25
0.16
0
31
0.00
0
32
–1.36
0
38
0.16
0
39
0.00
19200
0
12
0.16
0
15
0.00
0
15
1.73
0
19
–2.34 0
19
0.00
31250
0
7
0.00
0
9
–1.70
0
9
0.00
0
11
0.00
11
2.40
38400
— —
—
0
7
0.00
0
7
1.73
0
9
–2.34 0
9
0.00
Error
(%)
n N
Error
(%)
n N
Error
(%)
n N
Error
(%)
n N
0
Error
(%)
0.00
0.00
Operating Frequency φ (MHz)
14
14.7456
Bit Rate
(bps)
n
N
Error
(%)
110
2
248
–0.17
3
64
0.70
150
2
181
0.16
2
191
0.00
300
2
90
0.16
2
95
0.00
600
1
181
0.16
1
191
1200
1
90
0.16
1
2400
0
181
0.16
4800
0
90
9600
0
19200
31250
38400
17.2032
N
Error
(%)
n
N
Error
(%)
3
70
0.03
3
75
0.48
2
207
0.16
2
223
0.00
2
103
0.16
2
111
0.00
0.00
1
207
0.16
1
223
0.00
95
0.00
1
103
0.16
1
111
0.00
0
191
0.00
0
207
0.16
0
223
0.00
0.16
0
95
0.00
0
103
0.16
0
111
0.00
45
–0.93
0
47
0.00
0
51
0.16
0
55
0.00
0
22
–0.93
0
23
0.00
0
25
0.16
0
27
0.00
0
13
0.00
0
14
–1.70
0
15
0.00
0
16
1.20
—
—
—
0
11
0.00
0
12
0.16
0
13
0.00
n
N
Error
(%)
16
n
Rev. 6.00 Sep. 24, 2009 Page 419 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Operating Frequency φ (MHz)
18
19.6608
20
25
Bit Rate
(bps)
n
N
Error
(%)
n
N
Error
(%)
n
N
Error
(%)
n
N
Error
(%)
110
3
79
–0.12
3
86
0.31
3
88
–0.25
3
110
–0.02
150
2
233
0.16
2
255
0.00
3
64
0.16
3
80
0.47
300
2
116
0.16
2
127
0.00
2
129
0.16
2
162
–0.15
600
1
233
0.16
1
255
0.00
2
64
0.16
2
80
0.47
1200
1
116
0.16
1
127
0.00
1
129
0.16
1
162
–0.15
2400
0
233
0.16
0
255
0.00
1
64
0.16
1
80
0.47
4800
0
116
0.16
0
127
0.00
0
129
0.16
0
162
–0.15
9600
0
58
–0.69
0
63
0.00
0
64
0.16
0
80
0.47
19200
0
28
1.02
0
31
0.00
0
32
–1.36
0
40
–0.76
31250
0
17
0.00
0
19
–1.70
0
19
0.00
0
24
0.00
38400
0
14
–2.34
0
15
0.00
0
15
1.73
0
19
1.73
Table 13.4 Maximum Bit Rate for Each Frequency (Asynchronous Mode)
φ (MHz)
Maximum Bit
Rate (bit/s)
n
N
8
250000
0
0
9.8304
307200
0
0
10
312500
0
0
12
375000
0
0
12.288
384000
0
0
14
437500
0
0
14.7456
460800
0
0
16
500000
0
0
17.2032
537600
0
0
18
562500
0
0
19.6608
614400
0
0
20
625000
0
0
25
781250
0
0
Rev. 6.00 Sep. 24, 2009 Page 420 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Table 13.5 Maximum Bit Rate with External Clock Input (Asynchronous Mode)
φ (MHz)
External Input
Clock (MHz)
Maximum Bit
Rate (bit/s)
8
2.0000
125000
9.8304
2.4576
153600
10
2.5000
156250
12
3.0000
187500
12.288
3.0720
192000
14
3.5000
218750
14.7456
3.6864
230400
16
4.0000
250000
17.2032
4.3008
268800
18
4.5000
281250
19.6608
4.9152
307200
20
5.0000
312500
25
6.2500
390625
Rev. 6.00 Sep. 24, 2009 Page 421 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Table 13.6 BRR Settings for Various Bit Rates (Clocked Synchronous Mode)
Operating Frequency φ (MHz)
8
10
16
Bit Rate
(bps)
n
N
n
N
n
N
250
3
124
—
—
3
249
500
2
249
—
—
3
1k
2
124
—
—
2.5k
1
199
1
5k
1
99
10k
0
25k
20
25
n
N
124
—
—
2
249
—
249
2
99
1
124
1
199
0
249
0
79
0
50k
0
39
0
100k
0
19
0
24
0
39
0
49
0
62
250k
0
7
0
9
0
15
0
19
0
24
500k
0
3
0
4
0
7
0
9
—
—
1M
0
1
0
3
0
4
—
—
0
1
—
—
0
0*
—
—
2.5M
0
n
N
—
3
97
2
124
2
155
199
1
249
2
77
1
99
1
124
1
155
99
0
159
0
199
0
249
49
0
79
0
99
0
124
0*
5M
Legend:
Blank: Cannot be set.
—:
Can be set, but there will be a degree of error.
*:
Continuous transfer is not possible.
Rev. 6.00 Sep. 24, 2009 Page 422 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Table 13.7 Maximum Bit Rate with External Clock Input (Clocked Synchronous Mode)
φ (MHz)
External Input Clock (MHz)
Maximum Bit Rate (bps)
8
1.3333
1333333.3
10
1.6667
1666666.7
12
2.0000
2000000.0
14
2.3333
2333333.3
16
2.6667
2666666.7
18
3.0000
3000000.0
20
3.3333
3333333.3
25
4.1667
4166666.7
Table 13.8 Examples of Bit Rate for Various BRR Settings (Smart Card Interface Mode)
(When n = 0 and S = 372)
Operating Frequency φ (MHz)
Bit Rate
(bps)
N
9600
1
10.00
10.7136
13.00
14.2848
Error (%)
N
Error (%)
N
Error (%)
N
Error (%)
30.00
1
25.00
1
8.99
1
0.00
Operating Frequency φ (MHz)
16.00
18.00
20.00
25.00
Bit Rate
(bps)
N
Error (%)
N
Error (%)
N
Error (%)
N
Error (%)
9600
1
12.01
2
15.99
2
6.66
3
12.49
Rev. 6.00 Sep. 24, 2009 Page 423 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Table 13.9 Maximum Bit Rate at Various Frequencies (Smart Card Interface Mode)
(when S = 372)
φ (MHz)
Maximum Bit Rate (bps)
n
N
10.00
13441
0
0
10.7136
14400
0
0
13.00
17473
0
0
14.2848
19200
0
0
16.00
21505
0
0
18.00
24194
0
0
20.00
26882
0
0
25.00
33602
0
0
Rev. 6.00 Sep. 24, 2009 Page 424 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.4
Operation in Asynchronous Mode
Figure 13.2 shows the general format for asynchronous serial communication. One frame consists
of a start bit (low level), followed by data, a parity bit, and finally stop bits (high level). In
asynchronous serial communication, the transmission line is usually held in the mark state (high
level). The SCI monitors the transmission line, and when it goes to the space state (low level),
recognizes a start bit and starts serial communication. Inside the SCI, the transmitter and receiver
are independent units, enabling full-duplex communication. Both the transmitter and the receiver
also have a double-buffered structure, so that data can be read or written during transmission or
reception, enabling continuous data transfer. In asynchronous mode, the SCI performs
synchronization at the falling edge of the start bit in reception. The SCI samples the data on the
8th pulse of a clock with a frequency of 16 times the length of one bit, so that the transfer data is
latched at the center of each bit.
1
Serial
data
LSB
D0
0
Idle state
(mark state)
1
MSB
D1
D2
D3
D4
D5
Start
bit
Transmit/receive data
1 bit
7 or 8 bits
D6
D7
0/1
Parity
bit
1 bit,
or none
1
1
Stop bit
1 or
2 bits
One unit of transfer data (character or frame)
Figure 13.2 Data Format in Asynchronous Communication
(Example with 8-Bit Data, Parity, Two Stop Bits)
13.4.1
Data Transfer Format
Table 13.10 shows the data transfer formats that can be used in asynchronous mode. Any of 12
transfer formats can be selected according to the SMR setting. For details on the multiprocessor
bit, see section 13.5, Multiprocessor Communication Function.
Rev. 6.00 Sep. 24, 2009 Page 425 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Table 13.10 Serial Transfer Formats (Asynchronous Mode)
SMR Settings
Serial Transfer Format and Frame Length
CHR
PE
MP
STOP
1
0
0
0
0
S
8-bit data
STOP
0
0
0
1
S
8-bit data
STOPSTOP
0
1
0
0
S
8-bit data
P STOP
0
1
0
1
S
8-bit data
P STOPSTOP
1
0
0
0
S
7-bit data
STOP
1
0
0
1
S
7-bit data
STOP STOP
1
1
0
0
S
7-bit data
P STOP
1
1
0
1
S
7-bit data
P STOPSTOP
0
—
1
0
S
8-bit data
MPB STOP
0
—
1
1
S
8-bit data
MPB STOPSTOP
1
—
1
0
S
7-bit data
MPB STOP
1
—
1
1
S
7-bit data
MPB STOPSTOP
Legend:
S:
Start bit
STOP: Stop bit
P:
Parity bit
MPB: Multiprocessor bit
Rev. 6.00 Sep. 24, 2009 Page 426 of 928
REJ09B0099-0600
2
3
4
5
6
7
8
9
10
11
12
Section 13 Serial Communication Interface (SCI)
13.4.2
Receive Data Sampling Timing and Reception Margin in Asynchronous Mode
In asynchronous mode, the SCI operates on a basic clock with a frequency of 16 times the transfer
rate. In reception, the SCI samples the falling edge of the start bit using the basic clock, and
performs internal synchronization. Receive data is latched internally at the rising edge of the 8th
pulse of the basic clock as shown in figure 13.6. Thus, the reception margin in asynchronous mode
is given by formula (1) below.
M = | (0.5 –
| D – 0.5 |
1
) – (L – 0.5) F –
(1 + F) | × 100 [%]
N
2N
... Formula (1)
Where M:
N:
D:
L:
F:
Reception margin (%)
Ratio of bit rate to clock (N = 16)
Clock duty (D = 0 to 1.0)
Frame length (L = 9 to 12)
Absolute value of clock rate deviation
Assuming values of F (absolute value of clock rate deviation) = 0, D (clock duty) = 0.5, and N
(ratio of bit rate to clock) = 16 in formula (1), the reception margin can be given by the formula.
M = {0.5 – 1/(2 × 16)} × 100 [%] = 46.875%
However, this is only the computed value, and a margin of 20% to 30% should be allowed for in
system design.
16 clocks
8 clocks
0
7
15 0
7
15 0
Internal basic
clock
Receive data
(RxD)
Start bit
D0
D1
Synchronization
sampling timing
Data sampling
timing
Figure 13.3 Receive Data Sampling Timing in Asynchronous Mode
Rev. 6.00 Sep. 24, 2009 Page 427 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.4.3
Clock
Either an internal clock generated by the on-chip baud rate generator or an external clock input at
the SCK pin can be selected as the SCI’s serial clock, according to the setting of the C/A bit in
SMR and the CKE0 and CKE1 bits in SCR. When an external clock is input at the SCK pin, the
clock frequency should be 16 times the bit rate used.
When the SCI is operated on an internal clock, the clock can be output from the SCK pin when
setting CKE1 = 0 and CKE0 = 1. The frequency of the clock output in this case is equal to the bit
rate, and the phase is such that the rising edge of the clock is in the middle of the transmit data, as
shown in figure 13.4.
SCK
TxD
0
D0
D1
D2
D3
D4
D5
D6
D7
0/1
1
1
1 frame
Figure 13.4 Relationship between Output Clock and Transfer Data Phase
(Asynchronous Mode)
13.4.4
SCI Initialization (Asynchronous Mode)
Before transmitting and receiving data, you should first clear the TE and RE bits in SCR to 0, then
initialize the SCI as described in figure 13.5. When the operating mode, or transfer format, is
changed for example, the TE and RE bits must be cleared to 0 before making the change using the
following procedure. When the TE bit is cleared to 0, the TDRE flag is set to 1. Note that clearing
the RE bit to 0 does not initialize the contents of the RDRF, PER, FER, and ORER flags, or the
contents of RDR. When the external clock is used in asynchronous mode, the clock must be
supplied even during initialization.
Rev. 6.00 Sep. 24, 2009 Page 428 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Start initialization
[1] Set the clock selection in SCR.
Be sure to clear bits RIE, TIE,
TEIE, and MPIE, and bits TE and
RE, to 0.
Clear TE and RE bits in SCR to 0
Set CKE1 and CKE0 bits in SCR
(TE, RE bits = 0)
[1]
When the clock is selected in
asynchronous mode, it is output
immediately after SCR settings are
made.
[2] Set the data transfer format in SMR
and SCMR.
Set data transfer format in
SMR and SCMR
[2]
Set value in BRR
[3]
Wait
No
1-bit interval elapsed?
[3] Write a value corresponding to the
bit rate to BRR. Not necessary if
an external clock is used.
[4] Wait at least one bit interval, then
set the TE bit or RE bit in SCR to 1.
Also set the RIE, TIE, TEIE, and
MPIE bits.
Setting the TE and RE bits enables
the TxD and RxD pins to be used.
Yes
Set TE and RE* bits in
SCR to 1, and set RIE, TIE, TEIE,
and MPIE bits
[4]
Note: * Set the RE bit while the RxD pin is
driven 1. When the RE bit is set to 1
while the RxD pin is driven 0, it may
be received as the start bit.
<Initialization completion>
Figure 13.5 Sample SCI Initialization Flowchart
Rev. 6.00 Sep. 24, 2009 Page 429 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.4.5
Serial Data Transmission (Asynchronous Mode)
Figure 13.6 shows an example of operation for transmission in asynchronous mode. In
transmission, the SCI operates as described below.
1. The SCI monitors the TDRE flag in SSR. If the flag is cleared to 0, the SCI recognizes that
data has been written to TDR, and transfers the data from TDR to TSR.
2. After transferring data from TDR to TSR, the SCI sets the TDRE flag to 1 and starts
transmission. If the TIE bit is set to 1 at this time, a transmit data empty interrupt request (TXI)
is generated. Continuous transmission is possible because the TXI interrupt routine writes next
transmit data to TDR before transmission of the current transmit data has been completed.
3. Data is sent from the TxD pin in the following order: start bit, transmit data, parity bit or
multiprocessor bit (may be omitted depending on the format), and stop bit.
4. The SCI checks the TDRE flag at the timing for sending the stop bit.
5. If the TDRE flag is 0, the data is transferred from TDR to TSR, the stop bit is sent, and then
serial transmission of the next frame is started.
6. If the TDRE flag is 1, the TEND flag in SSR is set to 1, the stop bit is sent, and then the “mark
state” is entered, in which 1 is output. If the TEIE bit in SCR is set to 1 at this time, a TEI
interrupt request is generated.
1
Start
bit
0
Data
D0
D1
Parity Stop Start
bit
bit
bit
D7
0/1
1
0
Data
D0
D1
Parity Stop
bit
bit
D7
0/1
1
1
Idle state
(mark state)
TDRE
TEND
TXI interrupt
Data written to TDR and
TXI interrupt
request generated TDRE flag cleared to 0 in
request generated
TXI interrupt service routine
TEI interrupt
request generated
1 frame
Figure 13.6 Example of Operation in Transmission in Asynchronous Mode
(Example with 8-Bit Data, Parity, One Stop Bit)
Rev. 6.00 Sep. 24, 2009 Page 430 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Figure 13.7 shows a sample flowchart for data transmission.
Initialization
[1]
Start transmission
Read TDRE flag in SSR
[2]
[2] SCI status check and transmit data
write:
Read SSR and check that the
TDRE flag is set to 1, then write
transmit data to TDR and clear the
TDRE flag to 0.
No
TDRE = 1
Yes
Write transmit data to TDR
and clear TDRE flag in SSR to 0
No
All data transmitted?
Yes
[3]
Read TEND flag in SSR
TEND = 1
Yes
No
Yes
Clear DR to 0 and
set DDR to 1
[3] Serial transmission continuation
procedure:
To continue serial transmission,
read 1 from the TDRE flag to
confirm that writing is possible,
then write data to TDR, and then
clear the TDRE flag to 0. Checking
and clearing of the TDRE flag is
automatic when the DTC* is
activated by a transmit data empty
interrupt (TXI) request, and data is
written to TDR.
[4] Break output at the end of serial
transmission:
To output a break in serial
transmission, clear DR for the port
corresponding to the TxD pin to 0,
set DDR to 1, then clear the TE bit
in SCR to 0.
No
Break output?
[1] SCI initialization:
The TxD pin is automatically
designated as the transmit data
output pin.
After the TE bit is set to 1, a frame
of 1s is output, and transmission is
enabled.
[4]
Note: * The case, where the TDRE flag check and clearing are
automatically executed by DTC,
occurs only when the DISEL bit in DTC is 0
with the transfer counter other than 0.
Therefore, when the DISEL bit is 1, or
both the DISEL bit and the transfer counter are 0,
give the CPU an instruction to clear the TDRE flag.
Clear TE bit in SCR to 0
<End>
Figure 13.7 Sample Serial Transmission Flowchart
Rev. 6.00 Sep. 24, 2009 Page 431 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.4.6
Serial Data Reception (Asynchronous Mode)
Figure 13.8 shows an example of operation for reception in asynchronous mode. In serial
reception, the SCI operates as described below.
1. The SCI monitors the communication line. If a start bit is detected, the SCI performs internal
synchronization, receives receive data in RSR, and checks the parity bit and stop bit.
2. If an overrun error occurs (when reception of the next data is completed while the RDRF flag
is still set to 1), the ORER bit in SSR is set to 1. If the RIE bit in SCR is set to 1 at this time, an
ERI interrupt request is generated. Receive data is not transferred to RDR. The RDRF flag
remains to be set to 1.
3. If a parity error is detected, the PER bit in SSR is set to 1 and receive data is transferred to
RDR. If the RIE bit in SCR is set to 1 at this time, an ERI interrupt request is generated.
4. If a framing error is detected (when the stop bit is 0), the FER bit in SSR is set to 1 and receive
data is transferred to RDR. If the RIE bit in SCR is set to 1 at this time, an ERI interrupt
request is generated.
5. If reception is completed successfully, the RDRF bit in SSR is set to 1, and receive data is
transferred to RDR. If the RIE bit in SCR is set to 1 at this time, an RXI interrupt request is
generated. Continuous reception is possible because the RXI interrupt routine reads the receive
data transferred to RDR before reception of the next receive data has been completed.
1
Start
bit
0
Data
D0
D1
Parity Stop Start
bit
bit
bit
D7
0/1
1
0
Data
D0
D1
Parity Stop
bit
bit
D7
0/1
0
1
Idle state
(mark state)
RDRF
FER
RXI interrupt
request
generated
RDR data read and RDRF
flag cleared to 0 in RXI
interrupt service routine
1 frame
Figure 13.8 Example of SCI Operation in Reception
(Example with 8-Bit Data, Parity, One Stop Bit)
Rev. 6.00 Sep. 24, 2009 Page 432 of 928
REJ09B0099-0600
ERI interrupt request
generated by framing
error
Section 13 Serial Communication Interface (SCI)
Table 13.11 shows the states of the SSR status flags and receive data handling when a receive
error is detected. If a receive error is detected, the RDRF flag retains its state before receiving
data. Reception cannot be resumed while a receive error flag is set to 1. Accordingly, clear the
ORER, FER, PER, and RDRF bits to 0 before resuming reception. Figure 13.9 shows a sample
flowchart for serial data reception.
Table 13.11 SSR Status Flags and Receive Data Handling
SSR Status Flag
RDRF*
ORER
FER
PER
Receive Data
Receive Error Type
1
1
0
0
Lost
Overrun error
0
0
1
0
Transferred to RDR
Framing error
0
0
0
1
Transferred to RDR
Parity error
1
1
1
0
Lost
Overrun error + framing error
1
1
0
1
Lost
Overrun error + parity error
0
0
1
1
Transferred to RDR
Framing error + parity error
1
1
1
1
Lost
Overrun error + framing error +
parity error
Note:
*
The RDRF flag retains the state it had before data reception.
Rev. 6.00 Sep. 24, 2009 Page 433 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Initialization
[1]
Start reception
[1] SCI initialization:
The RxD pin is automatically
designated as the receive data input
pin.
[2] [3] Receive error processing and break
detection:
[2]
If a receive error occurs, read the
ORER, PER, and FER flags in SSR to
identify the error. After performing the
appropriate error processing, ensure
Yes
that the ORER, PER, and FER flags are
PER∨FER∨ORER = 1
all cleared to 0. Reception cannot be
[3]
resumed if any of these flags are set to
No
Error processing
1. In the case of a framing error, a
break can be detected by reading the
(Continued on next page)
value of the input port corresponding to
the RxD pin.
[4]
Read RDRF flag in SSR
[4] SCI status check and receive data read:
Read SSR and check that RDRF = 1,
then read the receive data in RDR and
RDRF = 1
clear the RDRF flag to 0. Transition of
the RDRF flag from 0 to 1 can also be
identified by an RXI interrupt.
Yes
Read ORER, PER, and
FER flags in SSR
No
Read receive data in RDR, and
clear RDRF flag in SSR to 0
No
All data received?
[5]
[5] Serial reception continuation procedure:
To continue serial reception, before the
stop bit for the current frame is
received, read the RDRF flag, read
RDR, and clear the RDRF flag to 0.
The RDRF flag is cleared automatically
when DTC* is activated by an RXI
interrupt and the RDR value is read.
Yes
Clear RE bit in SCR to 0
<End>
Note: * The case, where the RDRF flag is
automatically cleared by DTC,
occurs only when the DISEL bit in DTC is 0
with the transfer counter other than 0.
Therefore, when the DISEL bit is 1, or
both the DISEL bit and the transfer counter are 0,
give the CPU an instruction to clear the RDRF flag.
Figure 13.9 Sample Serial Reception Data Flowchart (1)
Rev. 6.00 Sep. 24, 2009 Page 434 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
[3]
Error processing
No
ORER = 1
Yes
Overrun error processing
No
FER = 1
Yes
Yes
Break?
No
Framing error processing
Clear RE bit in SCR to 0
No
PER = 1
Yes
Parity error processing
Clear ORER, PER, and
FER flags in SSR to 0
<End>
Figure 13.9 Sample Serial Reception Data Flowchart (2)
Rev. 6.00 Sep. 24, 2009 Page 435 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.5
Multiprocessor Communication Function
Use of the multiprocessor communication function enables data transfer between a number of
processors sharing communication lines by asynchronous serial communication using the
multiprocessor format, in which a multiprocessor bit is added to the transfer data. When
multiprocessor communication is performed, each receiving station is addressed by a unique ID
code. The serial communication cycle consists of two component cycles; an ID transmission cycle
that specifies the receiving station, and a data transmission cycle. The multiprocessor bit is used to
differentiate between the ID transmission cycle and the data transmission cycle. If the
multiprocessor bit is 1, the cycle is an ID transmission cycle; if the multiprocessor bit is 0, the
cycle is a data transmission cycle. Figure 13.10 shows an example of inter-processor
communication using the multiprocessor format. The transmitting station first sends the ID code
of the receiving station with which it wants to perform serial communication as data with a 1
multiprocessor bit added. It then sends transmit data as data with a 0 multiprocessor bit added.
When data with a 1 multiprocessor bit is received, the receiving station compares that data with its
own ID. The station whose ID matches then receives the data sent next. Stations whose IDs do not
match continue to skip data until data with a 1 multiprocessor bit is again received.
The SCI uses the MPIE bit in SCR to implement this function. When the MPIE bit is set to 1,
transfer of receive data from RSR to RDR, error flag detection, and setting the SSR status flags,
RDRF, FER, and ORER to 1, are inhibited until data with a 1 multiprocessor bit is received. On
reception of a receive character with a 1 multiprocessor bit, the MPB bit in SSR is set to 1 and the
MPIE bit is automatically cleared, thus normal reception is resumed. If the RIE bit in SCR is set to
1 at this time, an RXI interrupt is generated.
When the multiprocessor format is selected, the parity bit setting is rendered invalid. All other bit
settings are the same as those in normal asynchronous mode. The clock used for multiprocessor
communication is the same as that in normal asynchronous mode.
Rev. 6.00 Sep. 24, 2009 Page 436 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Transmitting
station
Serial transmission line
Receiving
station A
Receiving
station B
Receiving
station C
Receiving
station D
(ID = 01)
(ID = 02)
(ID = 03)
(ID = 04)
Serial
data
H'AA
H'01
(MPB = 1)
(MPB = 0)
ID transmission cycle = Data transmission cycle =
receiving station
Data transmission to
specification
receiving station specified by ID
Legend:
MPB: Multiprocessor bit
Figure 13.10 Example of Communication Using Multiprocessor Format
(Transmission of Data H'AA to Receiving Station A)
Rev. 6.00 Sep. 24, 2009 Page 437 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.5.1
Multiprocessor Serial Data Transmission
Figure 13.11 shows a sample flowchart for multiprocessor serial data transmission. For an ID
transmission cycle, set the MPBT bit in SSR to 1 before transmission. For a data transmission
cycle, clear the MPBT bit in SSR to 0 before transmission. All other SCI operations are the same
as those in asynchronous mode.
Rev. 6.00 Sep. 24, 2009 Page 438 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
[1]
Initialization
Start transmission
Read TDRE flag in SSR
[2]
[2] SCI status check and transmit
data write:
Read SSR and check that the
TDRE flag is set to 1, then write
transmit data to TDR. Set the
MPBT bit in SSR to 0 or 1.
Finally, clear the TDRE flag to 0.
No
TDRE = 1
Yes
Write transmit data to TDR and
set MPBT bit in SSR
Clear TDRE flag to 0
No
All data transmitted?
[1] SCI initialization:
The TxD pin is automatically
designated as the transmit data
output pin.
After the TE bit is set to 1, a
frame of 1s is output, and
transmission is enabled.
[3]
Yes
Read TEND flag in SSR
[3] Serial transmission continuation
procedure:
To continue serial transmission,
be sure to read 1 from the TDRE
flag to confirm that writing is
possible, then write data to TDR,
and then clear the TDRE flag to
0. Checking and clearing of the
TDRE flag is automatic when the
DTC* is activated by a transmit
data empty interrupt (TXI)
request, and data is written to
TDR.
[4] Break output at the end of serial
transmission:
To output a break in serial
transmission, set the port DR to
0, set DDR to 1, then clear the
TE bit in SCR to 0.
No
TEND = 1
Yes
No
Break output?
Yes
Clear DR to 0 and set DDR to 1
[4]
Note: * The case, where the TDRE flag is
automatically cleared by DTC,
occurs only when the DISEL bit in DTC is 0
with the transfer counter other than 0.
Therefore, when the DISEL bit is 1, or
both the DISEL bit and the transfer counter are 0,
give the CPU an instruction to clear the TDRE flag.
Clear TE bit in SCR to 0
<End>
Figure 13.11 Sample Multiprocessor Serial Transmission Flowchart
Rev. 6.00 Sep. 24, 2009 Page 439 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.5.2
Multiprocessor Serial Data Reception
Figure 13.13 shows a sample flowchart for multiprocessor serial data reception. If the MPIE bit in
SCR is set to 1, data is skipped until data with a 1 multiprocessor bit is sent. On receiving data
with a 1 multiprocessor bit, the receive data is transferred to RDR. An RXI interrupt request is
generated at this time. All other SCI operations are the same as in asynchronous mode. Figure
13.12 shows an example of SCI operation for multiprocessor format reception.
Rev. 6.00 Sep. 24, 2009 Page 440 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
1
MultiData (ID1) processor Stop
bit
bit
Start
bit
0
D0
D1
D7
1
1
MultiData (Data1) processor Stop
bit
bit
Start
bit
0
D0
D1
D7
0
1
1 Mark state
(idle state)
MPIE
RDRF
RDR
value
ID1
MPIE = 0
RXI interrupt
request
(multiprocessor
interrupt)
generated
RDR data read
and RDRF flag
cleared to 0 in
RXI interrupt
service routine
If not this station’s ID,
MPIE bit is set to 1
again
RXI interrupt request is
not generated, and RDR
retains its state
(a) Data does not match station’s ID
1
MultiData (ID2) processor Stop
bit
bit
Start
bit
0
D0
D1
D7
1
1
MultiData (Data2) processor Stop
bit
bit
Start
bit
0
D0
D1
D7
0
1
1 Mark state
(idle state)
MPIE
RDRF
RDR
value
ID1
MPIE = 0
Data2
ID2
RXI interrupt
request
(multiprocessor
interrupt)
generated
RDR data read and
RDRF flag cleared
to 0 in RXI interrupt
service routine
Matches this station’s ID,
so reception continues, and
data is received in RXI
interrupt service routine
MPIE bit set to 1
again
(b) Data matches station’s ID
Figure 13.12 Example of SCI Operation in Reception
(Example with 8-Bit Data, Multiprocessor Bit, One Stop Bit)
Rev. 6.00 Sep. 24, 2009 Page 441 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Initialization
[1]
[1] SCI initialization:
The RxD pin is automatically designated
as the receive data input pin.
Start reception
Set MPIE bit in SCR to 1
[2] ID reception cycle:
Set the MPIE bit in SCR to 1.
[2]
[3] SCI status check, ID reception and
comparison:
Read SSR and check that the RDRF
flag is set to 1, then read the receive
data in RDR and compare it with this
station’s ID.
If the data is not this station’s ID, set the
MPIE bit to 1 again, and clear the RDRF
flag to 0.
If the data is this station’s ID, clear the
RDRF flag to 0.
Read ORER and FER flags in SSR
Yes
FER∨ORER = 1
No
Read RDRF flag in SSR
[3]
No
RDRF = 1
[4] SCI status check and data reception:
Read SSR and check that the RDRF
flag is set to 1, then read the data in
RDR.
Yes
Read receive data in RDR
[5] Receive error processing and break
detection:
If a receive error occurs, read the ORER
and FER flags in SSR to identify the
error. After performing the appropriate
error processing, ensure that the ORER
and FER flags are all cleared to 0.
Reception cannot be resumed if either
of these flags is set to 1.
In the case of a framing error, a break
can be detected by reading the RxD pin
value.
No
This station’s ID?
Yes
Read ORER and FER flags in SSR
Yes
FER∨ORER = 1
No
Read RDRF flag in SSR
[4]
No
RDRF = 1
Yes
Read receive data in RDR
No
All data received?
[5]
Error processing
Yes
Clear RE bit in SCR to 0
(Continued on
next page)
<End>
Figure 13.13 Sample Multiprocessor Serial Reception Flowchart (1)
Rev. 6.00 Sep. 24, 2009 Page 442 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
[5]
Error processing
No
ORER = 1
Yes
Overrun error processing
No
FER = 1
Yes
Yes
Break?
No
Framing error processing
Clear RE bit in SCR to 0
Clear ORER, PER, and
FER flags in SSR to 0
<End>
Figure 13.13 Sample Multiprocessor Serial Reception Flowchart (2)
Rev. 6.00 Sep. 24, 2009 Page 443 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.6
Operation in Clocked Synchronous Mode
Figure 13.14 shows the general format for clocked synchronous communication. In clocked
synchronous mode, data is transmitted or received synchronous with clock pulses. In clocked
synchronous serial communication, data on the transmission line is output from one falling edge of
the serial clock to the next. In clocked synchronous mode, the SCI receives data in synchronous
with the rising edge of the serial clock. After 8-bit data is output, the transmission line holds the
MSB state. In clocked synchronous mode, no parity or multiprocessor bit is added. Inside the SCI,
the transmitter and receiver are independent units, enabling full-duplex communication through
the use of a common clock. Both the transmitter and the receiver also have a double-buffered
structure, so data can be read or written during transmission or reception, enabling continuous data
transfer.
One unit of transfer data (character or frame)
*
*
Synchronization
clock
LSB
Bit 0
Serial data
MSB
Bit 1
Don’t care
Bit 2
Bit 3
Bit 4
Bit 5
Bit 6
Bit 7
Don’t care
Note: * High except in continuous transfer
Figure 13.14 Data Format in Clocked Synchronous Communication (For LSB-First)
13.6.1
Clock
Either an internal clock generated by the on-chip baud rate generator or an external
synchronization clock input at the SCK pin can be selected, according to the setting of CKE0 and
CKE1 bits in SCR. When the SCI is operated on an internal clock, the serial clock is output from
the SCK pin. Eight serial clock pulses are output in the transfer of one character, and when no
transfer is performed the clock is fixed high.
Rev. 6.00 Sep. 24, 2009 Page 444 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.6.2
SCI Initialization (Clocked Synchronous Mode)
Before transmitting and receiving data, the TE and RE bits in SCR should be cleared to 0, then the
SCI should be initialized as described in a sample flowchart in figure 13.15. When the operating
mode, or transfer format, is changed for example, the TE and RE bits must be cleared to 0 before
making the change using the following procedure. When the TE bit is cleared to 0, the TDRE flag
is set to 1. Note that clearing the RE bit to 0 does not change the contents of the RDRF, PER,
FER, and ORER flags, or the contents of RDR.
Start initialization
[1] Set the clock selection in SCR. Be sure
to clear bits RIE, TIE, TEIE, and MPIE,
TE and RE, to 0.
Clear TE and RE bits in SCR to 0
[2] Set the data transfer format in SMR and
SCMR.
Set CKE1 and CKE0 bits in SCR
(TE, RE bits 0)
[1]
Set data transfer format in
SMR and SCMR
[2]
Set value in BRR
[3]
[3] Write a value corresponding to the bit
rate to BRR. Not necessary if an
external clock is used.
[4] Wait at least one bit interval, then set
the TE bit or RE bit in SCR to 1.
Also set the RIE, TIE TEIE, and MPIE
bits.
Setting the TE and RE bits enables the
TxD and RxD pins to be used.
Wait
No
1-bit interval elapsed?
Yes
Set TE and RE bits in SCR to 1, and
set RIE, TIE, TEIE, and MPIE bits
[4]
<Transfer start>
Note: In simultaneous transmit and receive operations, the TE and RE bits should both be cleared
to 0 or set to 1 simultaneously.
Figure 13.15 Sample SCI Initialization Flowchart
Rev. 6.00 Sep. 24, 2009 Page 445 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.6.3
Serial Data Transmission (Clocked Synchronous Mode)
Figure 13.16 shows an example of SCI operation for transmission in clocked synchronous mode.
In serial transmission, the SCI operates as described below.
1. The SCI monitors the TDRE flag in SSR, and if the flag is 0, the SCI recognizes that data has
been written to TDR, and transfers the data from TDR to TSR.
2. After transferring data from TDR to TSR, the SCI sets the TDRE flag to 1 and starts
transmission. If the TIE bit in SCR is set to 1 at this time, a transmit data empty interrupt (TXI)
is generated. Continuous transmission is possible because the TXI interrupt routine writes the
next transmit data to TDR before transmission of the current transmit data has been completed.
3. 8-bit data is sent from the TxD pin synchronized with the output clock when output clock
mode has been specified, and synchronized with the input clock when use of an external clock
has been specified.
4. The SCI checks the TDRE flag at the timing for sending the MSB (bit 7).
5. If the TDRE flag is cleared to 0, data is transferred from TDR to TSR, and serial transmission
of the next frame is started.
6. If the TDRE flag is set to 1, the TEND flag in SSR is set to 1, and the TDRE flag maintains the
output state of the last bit. If the TEIE bit in SCR is set to 1 at this time, a TEI interrupt request
is generated. The SCK pin is fixed high.
Rev. 6.00 Sep. 24, 2009 Page 446 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Figure 13.17 shows a sample flowchart for serial data transmission. Even if the TDRE flag is
cleared to 0, transmission will not start while a receive error flag (ORER, FER, or PER) is set to 1.
Make sure that the receive error flags are cleared to 0 before starting transmission. Note that
clearing the RE bit to 0 does not clear the receive error flags.
Transfer direction
Synchronization
clock
Serial data
Bit 0
Bit 1
Bit 7
Bit 0
Bit 1
Bit 6
Bit 7
TDRE
TEND
TXI interrupt
request generated
Data written to TDR
and TDRE flag cleared
to 0 in TXI interrupt
service routine
TXI interrupt
request generated
TEI interrupt request
generated
1 frame
Figure 13.16 Sample SCI Transmission Operation in Clocked Synchronous Mode
Rev. 6.00 Sep. 24, 2009 Page 447 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Initialization
[1]
Start transmission
Read TDRE flag in SSR
[2]
No
TDRE = 1
Yes
Write transmit data to TDR and
clear TDRE flag in SSR to 0
No
All data transmitted?
[3]
Yes
[1] SCI initialization:
The TxD pin is automatically
designated as the transmit data output
pin.
[2] SCI status check and transmit data
write:
Read SSR and check that the TDRE
flag is set to 1, then write transmit data
to TDR and clear the TDRE flag to 0.
[3] Serial transmission continuation
procedure:
To continue serial transmission, be
sure to read 1 from the TDRE flag to
confirm that writing is possible, then
write data to TDR, and then clear the
TDRE flag to 0.
Checking and clearing of the TDRE
flag is automatic when the DTC* is
activated by a transmit data empty
interrupt (TXI) request and data is
written to TDR.
Read TEND flag in SSR
No
TEND = 1
Yes
Note: * The case, where the TDRE flag is
automatically cleared by DTC,
occurs only when the DISEL bit in DTC is 0
with the transfer counter other than 0.
Therefore, when the DISEL bit is 1, or
both the DISEL bit and the transfer counter are 0,
give the CPU an instruction to clear the TDRE flag.
Clear TE bit in SCR to 0
<End>
Figure 13.17 Sample Serial Transmission Flowchart
Rev. 6.00 Sep. 24, 2009 Page 448 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.6.4
Serial Data Reception (Clocked Synchronous Mode)
Figure 13.18 shows an example of SCI operation for reception in clocked synchronous mode. In
serial reception, the SCI operates as described below.
1. The SCI performs internal initialization synchronous with a synchronous clock input or output,
starts receiving data, and stores the received data in RSR.
2. If an overrun error occurs (when reception of the next data is completed while the RDRF flag
in SSR is still set to 1), the ORER bit in SSR is set to 1. If the RIE bit in SCR is set to 1 at this
time, an ERI interrupt request is generated, receive data is not transferred to RDR, and the
RDRF flag remains to be set to 1.
3. If reception is completed successfully, the RDRF bit in SSR is set to 1, and receive data is
transferred to RDR. If the RIE bit in SCR is set to 1 at this time, an RXI interrupt request is
generated. Continuous reception is possible because the RXI interrupt routine reads the receive
data transferred to RDR before reception of the next receive data has finished.
Synchronization
clock
Serial data
Bit 7
Bit 0
Bit 7
Bit 0
Bit 1
Bit 6
Bit 7
RDRF
ORER
RXI interrupt
request
generated
RDR data read and
RDRF flag cleared
to 0 in RXI interrupt
RXI interrupt
request generated
ERI interrupt request
generated by overrun
error
1 frame
Figure 13.18 Example of SCI Operation in Reception
Reception cannot be resumed while a receive error flag is set to 1. Accordingly, clear the ORER,
FER, PER, and RDRF bits to 0 before resuming reception. Figure 13.19 shows a sample flow
chart for serial data reception.
An overrun error occurs or synchronous clocks are output until the RE bit is cleared to 0 when an
internal clock is selected and only receive operation is possible. When a transmission and
reception will be carried out in a unit of one frame, be sure to carry out a dummy transmission
with only one frame by the simultaneous transmit and receive operations at the same time.
Rev. 6.00 Sep. 24, 2009 Page 449 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Initialization
[1]
Start reception
[2]
Read ORER flag in SSR
Yes
[3]
ORER = 1
No
Error processing
(Continued below)
Read RDRF flag in SSR
[4]
No
RDRF = 1
Yes
Read receive data in RDR, and
clear RDRF flag in SSR to 0
No
All data received?
[5]
[1] SCI initialization:
The RxD pin is automatically
designated as the receive data input
pin.
[2] [3] Receive error processing:
If a receive error occurs, read the
ORER flag in SSR, and after
performing the appropriate error
processing, clear the ORER flag to 0.
Transfer cannot be resumed if the
ORER flag is set to 1.
[4] SCI status check and receive data
read:
Read SSR and check that the RDRF
flag is set to 1, then read the receive
data in RDR and clear the RDRF flag
to 0.
Transition of the RDRF flag from 0 to 1
can also be identified by an RXI
interrupt.
[5] Serial reception continuation
procedure:
To continue serial reception, before
the final bit of the current frame is
received, reading the RDRF flag,
reading RDR, and clearing the RDRF
flag to 0 should be finished. The
RDRF flag is cleared automatically
when the DTC* is activated by a
receive data full interrupt (RXI) request
and the RDR value is read.
Yes
Clear RE bit in SCR to 0
<End>
[3]
Note: * The case, where the RDRF flag check and
clearing are automatically executed by DTC,
occurs only when the DISEL bit in DTC is 0
with the transfer counter other than 0.
Therefore, when the DISEL bit is 1, or
both the DISEL bit and the transfer counter are 0,
give the CPU an instruction to clear the RDRF flag.
Error processing
Overrun error processing
Clear ORER flag in SSR to 0
<End>
Figure 13.19 Sample Serial Reception Flowchart
Rev. 6.00 Sep. 24, 2009 Page 450 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.6.5
Simultaneous Serial Data Transmission and Reception (Clocked Synchronous
Mode)
Figure 13.20 shows a sample flowchart for simultaneous serial transmit and receive operations.
The following procedure should be used for simultaneous serial data transmit and receive
operations. To switch from transmit mode to simultaneous transmit and receive mode, after
checking that the SCI has finished transmission and the TDRE and TEND flags are set to 1, clear
TE to 0. Then simultaneously set TE and RE to 1 with a single instruction. To switch from receive
mode to simultaneous transmit and receive mode, after checking that the SCI has finished
reception, clear RE to 0. Then after checking that the RDRF and receive error flags (ORER, FER,
and PER) are cleared to 0, simultaneously set TE and RE to 1 with a single instruction.
Rev. 6.00 Sep. 24, 2009 Page 451 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Initialization
[1]
SCI initialization:
The TxD pin is designated as the
transmit data output pin, and the RxD
pin is designated as the receive data
input pin, enabling simultaneous
transmit and receive operations.
[2]
SCI status check and transmit data
write:
Read SSR and check that the TDRE
flag is set to 1, then write transmit
data to TDR and clear the TDRE flag
to 0.
Transition of the TDRE flag from 0 to
1 can also be identified by a TXI
interrupt.
Receive error processing:
If a receive error occurs, read the
ORER flag in SSR, and after
performing the appropriate error
processing, clear the ORER flag to 0.
Transmission/reception cannot be
resumed if the ORER flag is set to 1.
[1]
Start transmission/reception
Read TDRE flag in SSR
No
[2]
TDRE = 1
Yes
Write transmit data to TDR and
clear TDRE flag in SSR to 0
[3]
Read ORER flag in SSR
Yes
ORER = 1
No
Read RDRF flag in SSR
No
Read receive data in RDR, and
clear RDRF flag in SSR to 0
[5]
Yes
Clear TE and RE bits in SCR to 0
<End>
Notes:
[5]
Serial transmission/reception
continuation procedure:
To continue serial transmission/
reception, before the final bit of the
current frame is received, finish
reading the RDRF flag, reading RDR,
and clearing the RDRF flag to 0.
Also, before the final bit of the current
frame is transmitted, read 1 from the
TDRE flag to confirm that writing is
possible. Then write data to TDR and
clear the TDRE flag to 0.
Checking and clearing of the TDRE
flag is automatic when the DTC* is
activated by a transmit data empty
interrupt (TXI) request and data is
written to TDR. Also, the RDRF flag
is cleared automatically when the
DTC* is activated by a receive data
full interrupt (RXI) request and the
RDR value is read.
[4]
Yes
All data received?
SCI status check and receive data
read:
Read SSR and check that the RDRF
flag is set to 1, then read the receive
data in RDR and clear the RDRF flag
to 0. Transition of the RDRF flag from
0 to 1 can also be identified by an RXI
interrupt.
Error processing
RDRF = 1
No
[4]
[3]
When switching from transmit or receive operation to simultaneous
transmit and receive operations, first clear the TE bit and RE bit
to 0, then set both these bits to 1 by one instruction simultaneously.
* The case, where the TDRE flag or RDRF flag is automatically cleared by DTC,
occurs only when the DISEL bit in the corresponding DTC is 0 with the transfer counter other than 0.
Therefore, when the DISEL bit in the corresponding DTC is 1, or both the DISEL bit and the transfer counter are 0,
give the CPU an instruction to clear the corresponding flags.
Figure 13.20 Sample Flowchart of Simultaneous Serial Transmit and Receive Operations
Rev. 6.00 Sep. 24, 2009 Page 452 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.7
Operation in Smart Card Interface
The SCI supports an IC card (Smart Card) interface that conforms to ISO/IEC 7816-3
(Identification Card) as a serial communication interface extension function. Switching between
the normal serial communication interface and the Smart Card interface mode is carried out by
means of a register setting.
13.7.1
Pin Connection Example
Figure 13.21 shows an example of connection with the Smart Card. In communication with an IC
card, as both transmission and reception are carried out on a single data transmission line, the TxD
pin and RxD pin should be connected to the LSI pin. The data transmission line should be pulled
up to the power supply (other than channel 2: P2Vcc, channel 2: P1Vcc) with a resistor. If an IC
card is not connected, and the TE and RE bits are both set to 1, closed transmission/reception is
possible, enabling self-diagnosis to be carried out. When the clock generated on the SCI is
supplied to an IC card, the SCK pin output is input to the CLK pin of the IC card. When an
internal clock is used in an IC card, this connection is not necessary. This LSI port output is used
as the reset signal. Adding to these connections, connection of pins with power supply and ground
is necessary.
P2 VCC
TxD
RxD
SCK
Px (port)
This LSI
Data line
Clock line
Reset line
I/O
CLK
RST
IC card
Connected equipment
Figure 13.21 (1) Schematic Diagram of Smart Card Interface Pin Connections
(Channels 0, 1, 3, and 4)
Rev. 6.00 Sep. 24, 2009 Page 453 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
P1 VCC
TxD
Data line
RxD
SCK
Clock line
Px (port)
Reset line
This LSI
I/O
CLK
RST
IC card
Connected equipment
Figure 13.21 (2) Schematic Diagram of Smart Card Interface Pin Connections
(Channel 2)
13.7.2
Data Format (Except for Block Transfer Mode)
Figure 13.22 shows the transfer data format in Smart Card interface mode.
• One frame consists of 8-bit data plus a parity bit in asynchronous mode.
• In transmission, a guard time of at least 2 etu (Elementary time unit: the time for transfer of
one bit) is left between the end of the parity bit and the start of the next frame.
• If a parity error is detected during reception, a low error signal level is output for one etu
period, 10.5 etu after the start bit.
• If an error signal is sampled during transmission, the same data is retransmitted automatically
after a delay of 2 etu or longer.
When there is no parity error
Ds
D0
D1
D2
D3
D4
D5
D6
D7
Dp
D6
D7
Dp
Transmitting station output
When a parity error occurs
Ds
D0
D1
D2
D3
D4
D5
DE
Transmitting station output
Legend:
: Start bit
DS
D0 to D7 : Data bits
: Parity bit
Dp
: Error signal
DE
Receiving station
output
Figure 13.22 Normal Smart Card Interface Data Format
Rev. 6.00 Sep. 24, 2009 Page 454 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Data transfer with other types of IC cards (direct convention and inverse convention) are
performed as described in the following.
(Z)
A
Z
Z
A
Z
Z
Z
A
A
Z
Ds
D0
D1
D2
D3
D4
D5
D6
D7
Dp
(Z)
State
Figure 13.23 Direct Convention (SDIR = SINV = O/E = 0)
With the direction convention type IC and the above sample start character, the logic 1 level
corresponds to state Z and the logic 0 level to state A, and transfer is performed in LSB-first order.
The start character data above is H'3B. For the direct convention type, clear the SDIR and SINV
bits in SCMR to 0. According to Smart Card regulations, clear the O/E bit in SMR to 0 to select
even parity mode.
(Z)
A
Z
Z
A
A
A
A
A
A
Z
Ds
D7
D6
D5
D4
D3
D2
D1
D0
Dp
(Z)
State
Figure 13.24 Inverse Convention (SDIR = SINV = O/E = 1)
With the inverse convention type, the logic 1 level corresponds to state A and the logic 0 level to
state Z, and transfer is performed in MSB-first order. The start character data for the above is
H'3F. For the inverse convention type, set the SDIR and SINV bits in SCMR to 1. According to
Smart Card regulations, even parity mode is the logic 0 level of the parity bit, and corresponds to
state Z. In this LSI, the SINV bit inverts only data bits D0 to D7. Therefore, set the O/E bit in
SMR to 1 to invert the parity bit for both transmission and reception.
13.7.3
Block Transfer Mode
Operation in block transfer mode is the same as that in the normal Smart Card interface mode,
except for the following points.
• In reception, though the parity check is performed, no error signal is output even if an error is
detected. However, the PER bit in SSR is set to 1 and must be cleared before receiving the
parity bit of the next frame.
• In transmission, a guard time of at least 1 etu is left between the end of the parity bit and the
start of the next frame.
• In transmission, because retransmission is not performed, the TEND flag is set to 1, 11.5 etu
after transmission start.
Rev. 6.00 Sep. 24, 2009 Page 455 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
• As with the normal Smart Card interface, the ERS flag indicates the error signal status, but
since error signal transfer is not performed, this flag is always cleared to 0.
Note: etu: Elementary time unit (time for transfer of 1 bit)
13.7.4
Receive Data Sampling Timing and Reception Margin
In Smart Card interface mode an internal clock generated by the on-chip baud rate generator can
only be used as a transmission/reception clock. In this mode, the SCI operates on a basic clock
with a frequency of 32, 64, 372, or 256 times the transfer rate (fixed to 16 times in normal
asynchronous mode) as determined by bits BCP1 and BCP0. In reception, the SCI samples the
falling edge of the start bit using the basic clock, and performs internal synchronization. As shown
in figure 13.25, by sampling receive data at the rising-edge of the 16th, 32nd, 186th, or 128th
pulse of the basic clock, data can be latched at the middle of the bit. The reception margin is given
by the following formula.
M = | (0.5 –
1
| D – 0.5 |
) – (L – 0.5) F –
(1 + F) | × 100%
2N
N
Where M: Reception margin (%)
N: Ratio of bit rate to clock (N = 32, 64, 372, and 256)
D: Clock duty (D = 0 to 1.0)
L: Frame length (L = 10)
F: Absolute value of clock frequency deviation
Assuming values of F = 0, D = 0.5 and N = 372 in the above formula, the reception margin
formula is as follows.
M
= (0.5 – 1/2 × 372) × 100%
= 49.866%
Rev. 6.00 Sep. 24, 2009 Page 456 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
372 clocks
186 clocks
0
185
185
371 0
371 0
Internal
basic clock
Receive data
(RxD)
Start bit
D0
D1
Synchronization
sampling timing
Data sampling
timing
Figure 13.25 Receive Data Sampling Timing in Smart Card Interface Mode
(Using Clock of 372 Times the Transfer Rate)
13.7.5
Initialization
Before transmitting and receiving data, initialize the SCI as described below. Initialization is also
necessary when switching from transmit mode to receive mode, or vice versa.
1.
2.
3.
4.
Clear the TE and RE bits in SCR to 0.
Clear the error flags ERS, PER, and ORER in SSR to 0.
Set the GM, BLK, O/E, BCP0, BCP1, CKS0, and CKS1 bits in SMR. Set the PE bit to 1.
Set the SMIF, SDIR, and SINV bits in SCMR.
When the SMIF bit is set to 1, the TxD and RxD pins are both switched from ports to SCI pins,
and are placed in the high-impedance state.
5. Set the value corresponding to the bit rate in BRR.
6. Set the CKE0 and CKE1 bits in SCR. Clear the TIE, RIE, TE, RE, MPIE, and TEIE bits to 0.
If the CKE0 bit is set to 1, the clock is output from the SCK pin.
7. Wait at least one bit interval, then set the TIE, RIE, TE, and RE bits in SCR. Do not set the TE
bit and RE bit at the same time, except for self-diagnosis.
To switch from receive mode to transmit mode, after checking that the SCI has finished reception,
initialize the SCI, and set RE to 0 and TE to 1. Whether SCI has finished reception or not can be
checked with the RDRF, PER, or ORER flags. To switch from transmit mode to receive mode,
after checking that the SCI has finished transmission, initialize the SCI, and set TE to 0 and RE to
1. Whether SCI has finished transmission or not can be checked with the TEND flag.
Rev. 6.00 Sep. 24, 2009 Page 457 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.7.6
Serial Data Transmission (Except for Block Transfer Mode)
As data transmission in Smart Card interface mode involves error signal sampling and
retransmission processing, the operations are different from those in normal serial communication
interface mode (except for block transfer mode). Figure 13.26 illustrates the retransfer operation
when the SCI is in transmit mode.
1. If an error signal is sent back from the receiving end after transmission of one frame is
complete, the ERS bit in SSR is set to 1. If the RIE bit in SCR is enabled at this time, an ERI
interrupt request is generated. The ERS bit in SSR should be cleared to 0 by the time the next
parity bit is sampled.
2. The TEND bit in SSR is not set for a frame in which an error signal indicating an abnormality
is received. Data is retransferred from TDR to TSR, and retransmitted automatically.
3. If an error signal is not sent back from the receiving end, the ERS bit in SSR is not set.
Transmission of one frame, including a retransfer, is judged to have been completed, and the
TEND bit in SSR is set to 1. If the TIE bit in SCR is enabled at this time, a TXI interrupt
request is generated. Writing transmit data to TDR transfers the next transmit data.
Figure 13.28 shows a flowchart for transmission. A sequence of transmit operations can be
performed automatically by specifying the DTC to be activated with a TXI interrupt source. In a
transmit operation, the TDRE flag is set to 1 at the same time as the TEND flag in SSR is set, and
a TXI interrupt will be generated if the TIE bit in SCR has been set to 1. If the TXI request is
designated beforehand as a DTC activation source, the DTC will be activated by the TXI request,
and transfer of the transmit data will be carried out. At this moment, when the DISEL bit in DTC
is 0 and the transfer counter is other than 0, the TDRE and TEND flags are automatically cleared
to 0 when data is transferred by the DTC. When the DISEL bit in the corresponding DTC is 1, or
both the DISEL bit and the transfer counter are 0, flags are not cleared although the transfer data is
written to TDR by DTC. Consequently, give the CPU an instruction of flag clear processing. In
addition, in the event of an error, the SCI retransmits the same data automatically. During this
period, the TEND flag remains cleared to 0 and the DTC is not activated. Therefore, the SCI and
DTC will automatically transmit the specified number of bytes in the event of an error, including
retransmission. However, the ERS flag is not cleared automatically when an error occurs, and so
the RIE bit should be set to 1 beforehand so that an ERI request will be generated in the event of
an error, and the ERS flag will be cleared.
When performing transfer using the DTC, it is essential to set and enable the DTC before carrying
out SCI setting. For details on the DTC setting procedures, see section 8, Data Transfer Controller
(DTC).
Rev. 6.00 Sep. 24, 2009 Page 458 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Transfer
frame n+1
Retransferred frame
nth transfer frame
Ds D0 D1 D2 D3 D4 D5 D6 D7 Dp DE
Ds D0 D1 D2 D3 D4 D5 D6 D7 Dp
(DE)
Ds D0 D1 D2 D3 D4
TDRE
Transfer to TSR from TDR
Transfer to TSR
from TDR
Transfer to TSR from TDR
TEND
FER/ERS
Figure 13.26 Retransfer Operation in SCI Transmit Mode
The timing for setting the TEND flag depends on the value of the GM bit in SMR. The TEND flag
set timing is shown in figure 13.27.
I/O data
Ds
TXI
(TEND interrupt)
D0
D1
D2
D3
D4
D5
D6
D7
Dp
DE
Guard
time
12.5etu
When GM = 0
11.0etu
When GM = 1
Legend:
Ds
D0 to D7
Dp
DE
: Start bit
: Data bits
: Parity bit
: Error signal
Note:
etu: Elementary time unit (time for transfer of 1 bit)
Figure 13.27 TEND Flag Generation Timing in Transmission Operation
Rev. 6.00 Sep. 24, 2009 Page 459 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Start
Initialization
Start transmission
ERS = 0?
No
Yes
Error processing
No
TEND = 1?
Yes
Write data to TDR,
and clear TDRE flag
in SSR to 0
No
All data transmitted ?
Yes
No
ERS = 0?
Yes
Error processing
No
TEND = 1?
Yes
Clear TE bit to 0
End
Figure 13.28 Example of Transmission Processing Flow
Rev. 6.00 Sep. 24, 2009 Page 460 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.7.7
Serial Data Reception (Except for Block Transfer Mode)
Data reception in Smart Card interface mode uses the same operation procedure as for normal
serial communication interface mode. Figure 13.29 illustrates the retransfer operation when the
SCI is in receive mode.
1. If an error is found when the received parity bit is checked, the PER bit in SSR is
automatically set to 1. If the RIE bit in SCR is set at this time, an ERI interrupt request is
generated. The PER bit in SSR should be kept cleared to 0 until the next parity bit is sampled.
2. The RDRF bit in SSR is not set for a frame in which an error has occurred.
3. If no error is found when the received parity bit is checked, the PER bit in SSR is not set to 1,
the receive operation is judged to have been completed normally, and the RDRF flag in SSR is
automatically set to 1. If the RIE bit in SCR is enabled at this time, an RXI interrupt request is
generated.
Figure 13.30 shows a flowchart for reception. A sequence of receive operations can be performed
automatically by specifying the DTC to be activated with an RXI interrupt source. In a receive
operation, an RXI interrupt request is generated when the RDRF flag in SSR is set to 1. If the RXI
request is designated beforehand as a DTC activation source, the DTC will be activated by the
RXI request, and the receive data will be transferred. The RDRF flag is cleared to 0 automatically
when the DISEL bit in DTC is 0 and the transfer counter is other than 0. When the DISEL bit in
DTC is 1, or both the DISEL bit and the transfer counter are 0, flags are not cleared although the
receive data is transferred by DTC. Consequently, give the CPU an instruction of flag clear
processing. If an error occurs in receive mode and the ORER or PER flag is set to 1, a transfer
error interrupt (ERI) request will be generated. Hence, so the error flag must be cleared to 0. In the
event of an error, the DTC is not activated and receive data is skipped. Therefore, receive data is
transferred for only the specified number of bytes in the event of an error. Even when a parity
error occurs in receive mode and the PER flag is set to 1, the data that has been received is
transferred to RDR and can be read from there.
Note: For details on receive operations in block transfer mode, see section 13.4, Operation in
Asynchronous Mode.
Rev. 6.00 Sep. 24, 2009 Page 461 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
nth transfer frame
Transfer
frame n+1
Retransferred frame
Ds D0 D1 D2 D3 D4 D5 D6 D7 Dp DE
Ds D0 D1 D2 D3 D4 D5 D6 D7 Dp
(DE)
Ds D0 D1 D2 D3 D4
RDRF
PER
Figure 13.29 Retransfer Operation in SCI Receive Mode
Start
Initialization
Start reception
ORER = 0 and
PER = 0
No
Yes
Error processing
No
RDRF = 1?
Yes
Read RDR and clear
RDRF flag in SSR to 0
No
All data received?
Yes
Clear RE bit to 0
Figure 13.30 Example of Reception Processing Flow
13.7.8
Clock Output Control
When the GM bit in SMR is set to 1, the clock output level can be fixed with bits CKE0 and
CKE1 in SCR. At this time, the minimum clock pulse width can be made the specified width.
Figure 13.31 shows the timing for fixing the clock output level. In this example, GM is set to 1,
CKE1 is cleared to 0, and the CKE0 bit is controlled.
Rev. 6.00 Sep. 24, 2009 Page 462 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
CKE0
SCK
Specified pulse width
Specified pulse width
Figure 13.31 Timing for Fixing Clock Output Level
When turning on the power or switching between Smart Card interface mode and software
standby mode, the following procedures should be followed in order to maintain the clock duty.
Powering On: To secure clock duty from power-on, the following switching procedure should be
followed.
1. The initial state is port input and high impedance. Use a pull-up resistor or pull-down
resistor to fix the potential.
2. Fix the SCK pin to the specified output level with the CKE1 bit in SCR.
3. Set SMR and SCMR, and switch to smart card mode operation.
4. Set the CKE0 bit in SCR to 1 to start clock output.
When Changing from Smart Card Interface Mode to Software Standby Mode:
1. Set the data register (DR) and data direction register (DDR) corresponding to the SCK pin
to the value for the fixed output state in software standby mode.
2. Write 0 to the TE bit and RE bit in the serial control register (SCR) to halt transmit/receive
operation. At the same time, set the CKE1 bit to the value for the fixed output state in
software standby mode.
3. Write 0 to the CKE0 bit in SCR to halt the clock.
4. Wait for one serial clock period.
During this interval, clock output is fixed at the specified level, with the duty preserved.
5. Make the transition to the software standby state.
When Returning to Smart Card Interface Mode from Software Standby Mode:
1. Exit the software standby state.
2. Write 1 to the CKE0 bit in SCR and output the clock. Signal generation is started with the
normal duty.
Rev. 6.00 Sep. 24, 2009 Page 463 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Normal operation
Software
standby
Normal operation
Figure 13.32 Clock Halt and Restart Procedure
13.8
Interrupt Sources
13.8.1
Interrupts in Normal Serial Communication Interface Mode
Table 13.12 shows the interrupt sources in normal serial communication interface mode. A
different interrupt vector is assigned to each interrupt source, and individual interrupt sources can
be enabled or disabled using the enable bits in SCR.
When the TDRE flag in SSR is set to 1, a TXI interrupt request is generated. When the TEND flag
in SSR is set to 1, a TEI interrupt request is generated. A TXI interrupt can activate the DTC to
perform data transfer. The TDRE flag is cleared to 0 automatically when data is transferred by the
DTC*.
When the RDRF flag in SSR is set to 1, an RXI interrupt request is generated. When the ORER,
PER, or FER flag in SSR is set to 1, an ERI interrupt request is generated. An RXI interrupt
request can activate the DTC to transfer data. The RDRF flag is cleared to 0 automatically when
data is transferred by the DTC*.
A TEI interrupt is requested when the TEND flag is set to 1 and the TEIE bit is set to 1. If a TEI
interrupt and a TXI interrupt are requested simultaneously, the TXI interrupt has priority for
acceptance. However, if the TDRE and TEND flags are cleared simultaneously by the TXI
interrupt routine, the SCI cannot branch to the TEI interrupt routine later.
Note: * Flags are cleared only when the DISEL bit in DTC is 0 with the transfer couter other
than 0.
Rev. 6.00 Sep. 24, 2009 Page 464 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Table 13.12 Interrupt Sources of Serial Communication Interface Mode
Channel
0
1
2
3
4
Note:
*
Name
Interrupt Source
Interrupt Flag
DTC Activation
Priority*
High
ERI0
Receive Error
ORER, FER, PER
Not possible
RXI0
Receive Data Full
RDRF
Possible
TXI0
Transmit Data Empty
TDRE
Possible
TEI0
Transmission End
TEND
Not possible
ERI1
Receive Error
ORER, FER, PER
Not possible
RXI1
Receive Data Full
RDRF
Possible
TXI1
Transmit Data Empty
TDRE
Possible
TEI1
Transmission End
TEND
Not possible
ERI2
Receive Error
ORER, FER, PER
Not possible
RXI2
Receive Data Full
RDRF
Possible
TXI2
Transmit Data Empty
TDRE
Possible
TEI2
Transmission End
TEND
Not possible
ERI3
Receive Error
ORER, FER, PER
Not possible
RXI3
Receive Data Full
RDRF
Possible
TXI3
Transmit Data Empty
TDRE
Possible
TEI3
Transmission End
TEND
Not possible
ERI4
Receive Error
ORER, FER, PER
Not possible
RXI4
Receive Data Full
RDRF
Possible
TXI4
Transmit Data Empty
TDRE
Possible
TEI4
Transmission End
TEND
Not possible
Low
Indicates the initial state immediately after a reset. Priorities in channels can be
changed by the interrupt controller.
Rev. 6.00 Sep. 24, 2009 Page 465 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.8.2
Interrupts in Smart Card Interface Mode
Table 13.13 shows the interrupt sources in Smart Card interface mode. The transmit end interrupt
(TEI) request cannot be used in this mode.
Note: In case of block transfer mode, see section 13.8.1, Interrupts in Normal Serial
Communication Interface Mode.
Table 13.13 Interrupt Sources in Smart Card Interface Mode
DTC Activation
Channel
Name
Interrupt Source
Interrupt Flag
0
ERI0
Receive Error, detection
ORER, PER, ERS
Not possible
RXI0
Receive Data Full
RDRF
Possible
TXI0
Transmit Data Empty
TEND
Possible
ERI1
Receive Error, detection
ORER, PER, ERS
Not possible
1
2
3
4
Note:
*
Priority*
RXI1
Receive Data Full
RDRF
Possible
TXI1
Transmit Data Empty
TEND
Possible
ERI2
Receive Error, detection
ORER, PER, ERS
Not possible
RXI2
Receive Data Full
RDRF
Possible
TXI2
Transmit Data Empty
TEND
Possible
ERI3
Receive Error, detection
ORER, PER, ERS
Not possible
RXI3
Receive Data Full
RDRF
Possible
TXI3
Transmit Data Empty
TEND
Possible
ERI4
Receive Error, detection
ORER, PER, ERS
Not possible
RXI4
Receive Data Full
RDRF
Possible
TXI4
Transmit Data Empty
TEND
Possible
High
Low
Indicates the initial state immediately after a reset. Priorities in channels can be
changed by the interrupt controller.
Rev. 6.00 Sep. 24, 2009 Page 466 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
13.9
Usage Notes
13.9.1
Module Stop Mode Setting
SCI operation can be disabled or enabled using the module stop control register. The initial setting
is for SCI operation to be halted. Register access is enabled by clearing module stop mode. For
details, see section 22, Power-Down Modes.
13.9.2
Break Detection and Processing (Asynchronous Mode Only)
When framing error (FER) detection is performed, a break can be detected by reading the RxD pin
value directly. In a break, the input from the RxD pin becomes all 0s, setting the FER flag, and
possibly the PER flag. Note that as the SCI continues the receive operation after receiving a break,
even if the FER flag is cleared to 0, it will be set to 1 again.
13.9.3
Mark State and Break Detection (Asynchronous Mode Only)
When TE is 0, the TxD pin is used as an I/O port whose direction (input or output) and level are
determined by DDR. This can be used to set the TxD pin to mark state (high level) or send a break
during serial data transmission. To maintain the communication line at mark state until TE is set to
1, set both DDR and DR to 1. As TE is cleared to 0 at this point, the TxD pin becomes an I/O port,
and 1 is output from the TxD pin. To send a break during serial transmission, first set PDR to 1
and DR to 0, and then clear TE to 0. When TE is cleared to 0, the transmitter is initialized
regardless of the current transmission state, the TxD pin becomes an I/O port, and 0 is output from
the TxD pin.
13.9.4
Receive Error Flags and Transmit Operations (Clocked Synchronous Mode Only)
Transmission cannot be started when a receive error flag (ORER, PER, or FER) is set to 1, even if
the TDRE flag is cleared to 0. Be sure to clear the receive error flags to 0 before starting
transmission. Note also that receive error flags cannot be cleared to 0 even if the RE bit is cleared
to 0.
13.9.5
Restrictions on Use of DTC
• When an external clock source is used as the serial clock, the transmit clock should not be
input until at least 5 φ clock cycles after TDR is updated by the DTC. Incorrect operation may
occur if the transmit clock is input within 4 φ clocks after TDR is updated. (Figure 13.33)
Rev. 6.00 Sep. 24, 2009 Page 467 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
• When RDR is read by the DTC, be sure to set the activation source to the relevant SCI
reception data full interrupt (RXI).
•
The flags are automatically cleared to 0 by the DTC during the data transfer only when the
DISEL bit in DTC is 0 with the transfer counter other than 0. When the DISEL bit in the
corresponding DTC is 1, or both the DISEL bit and the transfer counter are 0, give the CPU
an instruction to clear flags. Note that, particularly during transmission, the TDRE flag that is
not cleared by the CPU causes incorrect transmission.
SCK
t
TDRE
LSB
Serial data
D0
D1
D2
D3
D4
D5
D6
D7
Note: When operating on an external clock, set t >4 clocks.
Figure 13.33 Example of Clocked Synchronous Transmission by DTC
13.9.6
Operation in Case of Mode Transition
• Transmission
Operation should be stopped (by clearing TE, TIE, and TEIE bits to 0) before making a
module stop mode, software standby mode, or watch mode transition. TSR, TDR, and SSR are
reset. The output pin states in module stop mode, software standby mode, or watch mode
depend on the port settings, and become high-level output after the relevant mode is cleared. If
a transition is made during transmission, the data being transmitted will be undefined. When
transmitting without changing the transmit mode after the relevant mode is cleared,
transmission can be started by setting TE to 1 again, and performing the following sequence:
SSR read -> TDR write -> TDRE clearance. To transmit with a different transmit mode after
clearing the relevant mode, the procedure must be started again from initialization. Figure
13.34 shows a sample flowchart for mode transition during transmission. Port pin states are
shown in figures 13.35 and 13.36.
Operation should also be stopped (by clearing TE, TIE, and TEIE bits to 0) before making a
transition from transmission by DTC transfer to module stop mode, software standby mode, or
watch mode. To perform transmission with the DTC after the relevant mode is cleared, setting
the TE and TIE bits to 1 will set the TXI flag and start DTC transmission.
Rev. 6.00 Sep. 24, 2009 Page 468 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
<Transmission>
No
All data
transmitted?
[1]
[1]
Data being transmitted is interrupted.
After exiting software standby mode,
etc., normal CPU transmission is
possible by setting TE to 1, reading
SSR, writing TDR, and clearing
TDRE to 0, but note that if the DTC
has been activated, the remaining
data in DTCRAM will be transmitted
when TE and TIE are set to 1.
[2]
If TIE and TEIE are set to 1, clear
them to 0 in the same way.
[3]
Includes module stop mode and
watch mode.
Yes
Read TEND flag in SSR
No
TEND = 1
Yes
[2]
TE = 0
Transition to software
standby mode, etc.
[3]
Exit from software
standby mode, etc.
Change
operating mode?
No
Yes
Initialization
TE = 1
<Start of transmission>
Figure 13.34 Sample Flowchart for Mode Transition during Transmission
Start of transmission
End of
transmission
Transition
to software
standby
Exit from
software
standby
TE bit
Port input/output
SCK output pin
TxD output pin
Port input/output
Port
High output
Start
SCI TxD output
Stop
Port input/output
Port
High output
SCI TxD
output
Figure 13.35 Asynchronous Transmission Using Internal Clock
Rev. 6.00 Sep. 24, 2009 Page 469 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Start of transmission
End of
transmission
Transition
to software
standby
Exit from
software
standby
TE bit
Port input/output
SCK output pin
TxD output pin Port input/output
Last TxD bit held
Marking output
Port
SCI TxD output
Port input/output
Port
High output*
SCI TxD
output
Note: * Initialized by software standby.
Figure 13.36 Clocked Synchronous Transmission Using Internal Clock
• Reception
Receive operation should be stopped (by clearing RE to 0) before making a module stop mode,
software standby mode, or watch mode transition. RSR, RDR, and SSR are reset. If a
transition is made without stopping operation, the data being received will be invalid.
To continue receiving without changing the reception mode after the relevant mode is cleared,
set RE to 1 before starting reception. To receive with a different receive mode, the procedure
must be started again from initialization.
Figure 13.37 shows a sample flowchart for mode transition during reception.
Rev. 6.00 Sep. 24, 2009 Page 470 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
<Reception>
Read RDRF flag in SSR
RDRF = 1
No
[1]
Yes
[1] Receive data being received
becomes invalid.
[2] Includes module stop mode
and watch mode.
Read receive data in RDR
RE = 0
Transition to software
standby mode, etc.
[2]
Exit from software
standby mode, etc.
Change
operating mode?
No
Yes
Initialization
RE = 1
<Start of reception>
Figure 13.37 Sample Flowchart for Mode Transition during Reception
13.9.7
Notes when Switching from SCK Pin to Port Pin
• Problem in Operation: When DDR and DR are set to 1, SCI clock output is used in clocked
synchronous mode, and the SCK pin is changed to the port pin while transmission is ended,
port output is enabled after low-level output occurs for one half-cycle.
When switching the SCK pin to the port pin by making the following settings while DDR = 1,
DR = 1, C/A = 1, CKE1 = 0, CKE0 = 0, and TE = 1, low-level output occurs for one halfcycle.
1. End of serial data transmission
2. TE bit = 0
3. C/A bit = 0 ... switchover to port output
4. Occurrence of low-level output (see figure 13.38)
Rev. 6.00 Sep. 24, 2009 Page 471 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Half-cycle low-level output
SCK/port
1. End of transmission
Bit 6
Data
4. Low-level output
Bit 7
2. TE = 0
TE
3. C/A = 0
C/A
CKE1
CKE0
Figure 13.38 Operation when Switching from SCK Pin to Port Pin
• Usage Note: To prevent low-level output occurred when switching the SCK pin to port pin,
follow the procedure described below.
As this sample procedure temporarily places the SCK pin in the input state, the SCK/port pin
should be pulled up beforehand with an external circuit.
With DDR = 1, DR = 1, C/A = 1, CKE1 = 0, CKE0 = 0, and TE = 1, make the following
settings in the order shown.
1. End of serial data transmission
2. TE bit = 0
3. CKE1 bit = 1
4. C/A bit = 0 ... switchover to port output
5. CKE1 bit = 0
Rev. 6.00 Sep. 24, 2009 Page 472 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
High-level output
SCK/port
1. End of transmission
Data
TE
Bit 6
Bit 7
2. TE = 0
4. C/A = 0
C/A
3. CKE1 = 1
CKE1
5. CKE1 = 0
CKE0
Figure 13.39 Operation when Switching from SCK Pin to Port Pin
(Example of Preventing Low-Level Output)
Rev. 6.00 Sep. 24, 2009 Page 473 of 928
REJ09B0099-0600
Section 13 Serial Communication Interface (SCI)
Rev. 6.00 Sep. 24, 2009 Page 474 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Section 14 I2C Bus Interface 2 (IIC2)
This LSI includes 2-channel I2C bus interface.
The I2C bus interface 2 conforms to and provides a subset of the Philips I2C bus (inter-IC bus)
interface functions. For the bus drive characteristics and the I2C bus timing, see section 24,
Electrical Characteristics. The register configuration that controls the I2C bus differs partly from
the Philips configuration, however.
Figure 14.1 shows a block diagram of the I2C bus interface 2.
Figure 14.2 shows an example of I/O pin connections to external circuits.
14.1
Features
• Selection of I2C format or clocked synchronous serial format
• Continuous transmission/reception
Since the shift register, transmit data register, and receive data register are independent from
each other, the continuous transmission/reception can be performed.
• Module stop mode can be set.
I2C bus format
• Start and stop conditions generated automatically in master mode
• Selection of acknowledge output levels when receiving
• Automatic loading of acknowledge bit when transmitting
• Bit synchronization/wait function
In master mode, the state of SCL is monitored per bit, and the timing is synchronized
automatically.
If transmission/reception is not yet possible, set the SCL to low until preparations are
completed.
• Six interrupt sources
Transmit data empty (including slave-address match), transmit end, receive data full (including
slave-address match), arbitration lost, NACK detection, and stop condition detection
Rev. 6.00 Sep. 24, 2009 Page 475 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
• Direct bus drive
Two pins, pins P35/SCL0 and P34/SDA0, function as NMOS open-drain outputs when the bus
drive function is selected.
Two pins, pins P33/SCL1 and P32/SDA1, are driven only by NMOS transistors when the bus
drive function is selected.
Clocked synchronous format
• Four interrupt sources
Transmit-data-empty, transmit-end, receive-data-full, and overrun error
The I/O pins for channel 0 function as NMOS open-drain outputs, and it is possible to apply
voltages in excess of the power supply (P2Vcc) voltage for this LSI. The maximum voltage must
not exceed 0.3 V + this LSI's power supply voltage (P2Vcc). Since the I/O pins for channel 1 are
driven only by NMOS transistors, so in terms of appearance they carry out the same operations as
an NMOS open drain. However, the voltage which can be applied to the I/O pins depends on the
voltage of the power supply (P2Vcc) of this LSI.
Rev. 6.00 Sep. 24, 2009 Page 476 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Transfer clock
generation
circuit
SCL
Transmission/
reception
control circuit
Output
control
ICCR1
ICCR2
ICMR
Internal data bus
Noise canceler
ICDRT
SDA
Output
control
ICDRS
SAR
Address
comparator
Noise canceler
ICDRR
Bus state
decision circuit
Arbitration
decision circuit
ICSR
ICIER
Interrupt
generator
Legend:
Interrupt request
2
ICCR1 : I C bus control register 1
ICCR2 : I2C bus control register 2
ICMR : I2C bus mode register
ICSR : I2C bus status register
ICIER : I2C bus interrupt enable register
ICDRT : I2C bus transmit data register
ICDRR : I2C bus receive data register
ICDRS : I2C bus shift register
SAR : Slave address register
Figure 14.1 Block Diagram of I2C Bus Interface 2
Rev. 6.00 Sep. 24, 2009 Page 477 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
VDD
P2Vcc
SCL in
SCL
SCL
SDA
SDA
SCL out
SDA in
SCL in
SCL out
SCL
SDA
(Master)
SCL
SDA
SDA out
SCL in
SCL out
SDA in
SDA in
SDA out
SDA out
(Slave 1)
(Slave 2)
Figure 14.2 External Circuit Connections of I/O Pins
14.2
Input/Output Pins
Table 14.1 summarizes the input/output pins used by the I2C bus interface 2.
Table 14.1 I2C Bus Interface Pins
Channel
Abbreviation
I/O
Description
0
SCL0
I/O
Serial clock input/output for channel 0
SDA0
I/O
Serial data input/output for channel 0
SCL1
I/O
Serial clock input/output for channel 1
SDA1
I/O
Serial data input/output for channel 1
1
Note:
*
In the text, the channel subscript is omitted, and only SCL and SDA are used.
Rev. 6.00 Sep. 24, 2009 Page 478 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
14.3
Register Descriptions
The I2C bus interface 2 has the following registers.
Channel 0
•
•
•
•
•
•
•
•
•
I2C bus control register 1_0 (ICCR1_0)
I2C bus control register 2_0 (ICCR2_0)
I2C bus mode register_0 (ICMR_0)
I2C bus interrupt enable register_0 (ICIER_0)
I2C bus status register_0 (ICSR_0)
I2C bus slave address register_0 (SAR_0)
I2C bus transmit data register_0 (ICDRT_0)
I2C bus receive data register_0 (ICDRR_0)
I2C bus shift register_0 (ICDRS_0)
Channel 1
•
•
•
•
•
•
•
•
•
I2C bus control register 1_1 (ICCR1_1)
I2C bus control register 2_1 (ICCR2_1)
I2C bus mode register_1 (ICMR_1)
I2C bus interrupt enable register_1 (ICIER_1)
I2C bus status register_1 (ICSR_1)
I2C bus slave address register_1 (SAR_1)
I2C bus transmit data register_1 (ICDRT_1)
I2C bus receive data register_1 (ICDRR_1)
I2C bus shift register_1 (ICDRS_1)
14.3.1
I2C Bus Control Register 1 (ICCR1)
ICCR1 enables or disables the I2C bus interface 2, controls transmission or reception, and selects
master or slave mode, transmission or reception, and transfer clock frequency in master mode.
Rev. 6.00 Sep. 24, 2009 Page 479 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Bit
Bit Name
Initial
Value
R/W
Description
7
ICE
0
R/W
I2C Bus Interface Enable
0: This module is halted. (SCL and SDA pins are set to port
function.)
1: This bit is enabled for transfer operations. (SCL and
SDA pins are bus drive state.)
6
RCVD
0
R/W
Reception Disable
This bit enables or disables the next receive operation
while TRS is 0 and until ICDRR is read.
0: Enables next reception
1: Disables next reception
5
MST
0
R/W
Master/Slave Select
4
TRS
0
R/W
Transmit/Receive Select
2
In master mode with the I C bus format, when arbitration is
lost, MST and TRS are both reset by hardware, causing a
transition to slave receive mode. Modification of the TRS
bit should be made between transfer frames.
After data receive has been started in slave receive mode,
when the first seven bits of the receive data agree with the
slave address that is set to SAR and the eighth bit is 1,
TRS is automatically set to 1. If an overrun error occurs in
master mode with the clock synchronous serial format,
MST is cleared to 0 and slave receive mode is entered.
Operating modes are described below according to MST
and TRS combination. When clocked synchronous serial
format is selected and MST is 1, clock is output.
00: Slave receive mode
01: Slave transmit mode
10: Master receive mode
11: Master transmit mode
3
CKS3
0
R/W
Transfer Clock Select 3 to 0
2
CKS2
0
R/W
1
CKS1
0
R/W
0
CKS0
0
R/W
Set these bits according to the necessary transfer rate in
master mode (see table 14.2). During slave mode, these
bits are specified to ensure enough time for data setup in
transmit mode. When CKS3 is 0, the time is 10 tcyc, and
CKS3 is 1, 20 tcyc.
Rev. 6.00 Sep. 24, 2009 Page 480 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Table 14.2 Transfer Rate
Bit 3
Bit 2
Bit 1
Bit 0
CKS3
CKS2
CKS1
CKS0
Clock
φ = 8 MHz
φ = 10 MHz φ = 16 MHz φ = 20 MHz φ = 25 MHz
0
0
0
0
φ/28
286 kHz
357 kHz
571 kHz
714 kHz
893 kHz
1
φ/40
200 kHz
250 kHz
400 kHz
500 kHz
625 kHz
0
φ/48
167 kHz
208 kHz
333 kHz
417 kHz
521 kHz
1
φ/64
125 kHz
156 kHz
250 kHz
313 kHz
391 kHz
0
φ/168
47.6 kHz
59.5 kHz
95.2 kHz
119 kHz
149 kHz
1
φ/100
80.0 kHz
100 kHz
160 kHz
200 kHz
250 kHz
0
φ/112
71.4 kHz
89.3 kHz
143 kHz
179 kHz
223 kHz
1
φ/128
62.5 kHz
78.1 kHz
125 kHz
156 kHz
195 kHz
0
φ/56
143 kHz
179 kHz
286 kHz
357 kHz
446 kHz
1
φ/80
100 kHz
125 kHz
200 kHz
250 kHz
313 kHz
0
φ/96
83.3 kHz
104 kHz
167 kHz
208 kHz
260 kHz
1
φ/128
62.5 kHz
78.1 kHz
125 kHz
156 kHz
195 kHz
0
φ/336
23.8 kHz
29.8 kHz
47.6 kHz
59.5 kHz
74.4 kHz
1
φ/200
40.0 kHz
50.0 kHz
80.0 kHz
100 kHz
125 kHz
0
φ/224
35.7 kHz
44.6 kHz
71.4 kHz
89.3 kHz
112 kHz
1
φ/256
31.3 kHz
39.1 kHz
62.5 kHz
78.1 kHz
97.7 kHz
1
1
0
1
1
0
0
1
1
0
1
Transfer Rate
Rev. 6.00 Sep. 24, 2009 Page 481 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
14.3.2
I2C Bus Control Register 2 (ICCR2)
ICCR1 issues start/stop conditions, manipulates the SDA pin, monitors the SCL pin, and controls
reset in the control part of the I2C bus interface 2.
Bit
Bit Name
Initial
Value
R/W
Description
7
BBSY
0
R/W
Bus Busy
2
This bit enables to confirm whether the I C bus is occupied
or released and to issue start/stop conditions in master
mode. With the clocked synchronous serial format, this bit
2
has no meaning. With the I C bus format, this bit is set to 1
when the SDA level changes from high to low under the
condition of SCL = high, assuming that the start condition
has been issued. This bit is cleared to 0 when the SDA
level changes from low to high under the condition of SCL
= high, assuming that the stop condition has been issued.
Write 1 to BBSY and 0 to SCP to issue a start condition.
Follow this procedure when also re-transmitting a start
condition. Write 0 in BBSY and 0 in SCP to issue a stop
condition. To issue start/stop conditions, use the MOV
instruction.
6
SCP
1
R/W
Start/Stop Issue Condition Disable
The SCP bit controls the issue of start/stop conditions in
master mode.
To issue a start condition, write 1 in BBSY and 0 in SCP. A
retransmit start condition is issued in the same way. To
issue a stop condition, write 0 in BBSY and 0 in SCP. This
bit is always read as 1. If 1 is written, the data is not stored.
5
SDAO
1
R/W
SDA Output Value Control
This bit is used with SDAOP when modifying output level of
SDA. This bit should not be manipulated during transfer.
0: When reading, SDA pin outputs low.
When writing, SDA pin is changed to output low.
1: When reading, SDA pin outputs high.
When writing, SDA pin is changed to output Hi-Z
(outputs high by external pull-up resistance).
Rev. 6.00 Sep. 24, 2009 Page 482 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Bit
Bit Name
Initial
Value
R/W
Description
4
SDAOP
1
R/W
SDAO Write Protect
This bit controls change of output level of the SDA pin by
modifying the SDAO bit. To change the output level, clear
SDAO and SDAOP to 0 or set SDAO to 1 and clear
SDAOP to 0 by the MOV instruction. This bit is always read
as 1.
3
SCLO
1
R
This bit monitors SCL output level. When SCLO is 1, SCL
pin outputs high. When SCLO is 0, SCL pin outputs low.
2
⎯
1
⎯
Reserved
This bit is always read as 1, and cannot be modified.
1
IICRST
0
R/W
IIC Control Part Reset
2
This bit resets the control part except for I C2 registers. If
this bit is set to 1 when hang-up occurs because of
2
2
communication failure during I C2 operation, I C2 control
part can be reset without setting ports and initializing
registers.
0
⎯
1
⎯
Reserved
This bit is always read as 1, and cannot be modified.
14.3.3
I2C Bus Mode Register (ICMR)
ICMR selects whether the MSB or LSB is transferred first, performs master mode wait control,
and selects the transfer bit count.
Bit
Bit Name
Initial
Value
R/W
7
MLS
0
R/W
Description
MSB-First/LSB-First Select
0: MSB-first
1: LSB-first
2
Set this bit to 0 when the I C bus format is used.
Rev. 6.00 Sep. 24, 2009 Page 483 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Bit
Bit Name
Initial
Value
R/W
Description
6
WAIT
0
R/W
Wait Insertion Bit
In master mode with the I2C bus format, this bit selects
whether to insert a wait after data transfer except the
acknowledge bit. When WAIT is set to 1, after the fall of
the clock for the final data bit, low period is extended for
two transfer clocks. If WAIT is cleared to 0, data and
acknowledge bits are transferred consecutively with no
wait inserted.
2
The setting of this bit is invalid in slave mode with the I C
bus format or with the clocked synchronous serial format.
5, 4
⎯
All 1
⎯
Reserved
These bits are always read as 1, and cannot be modified.
3
BCWP
1
R/W
BC Write Protect
This bit controls the BC2 to BC0 modifications. When
modifying BC2 to BC0, this bit should be cleared to 0 and
use the MOV instruction. In clock synchronous serial
mode, BC should not be modified.
0: When writing, values of BC2 to BC0 are set.
1: When reading, 1 is always read.
When writing, settings of BC2 to BC0 are invalid.
Rev. 6.00 Sep. 24, 2009 Page 484 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Bit
Bit Name
Initial
Value
R/W
Description
2
BC2
0
R/W
Bit Counter 2 to 0
1
BC1
0
R/W
0
BC0
0
R/W
These bits specify the number of bits to be transferred
next. When read, the remaining number of transfer bits is
indicated. With the I2C bus format, the data is transferred
with one addition acknowledge bit. Bit BC2 to BC0 settings
should be made during an interval between transfer
frames. If bits BC2 to BC0 are set to a value other than
000, the setting should be made while the SCL pin is low.
The value returns to 000 at the end of a data transfer,
including the acknowledge bit. With the clock synchronous
serial format, these bits should not be modified.
2
I C Bus Format
Clock Synchronous Serial Format
000: 9 bits
000:
8 bits
001: 2 bits
001:
1 bits
010: 3 bits
010:
2 bits
011: 4 bits
011:
3 bits
100: 5 bits
100:
4 bits
101: 6 bits
101:
5 bits
110: 7 bits
110:
6 bits
111: 8 bits
111:
7 bits
Rev. 6.00 Sep. 24, 2009 Page 485 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
14.3.4
I2C Bus Interrupt Enable Register (ICIER)
ICIER enables or disables interrupt sources and acknowledge bits, sets acknowledge bits to be
transferred, and confirms acknowledge bits to be received.
Bit
Bit Name
Initial
Value
R/W
Description
7
TIE
0
R/W
Transmit Interrupt Enable
When the TDRE bit in ICSR is set to 1, this bit enables or
disables the transmit data empty interrupt (TXI).
0: Transmit data empty interrupt request (TXI) is disabled.
1: Transmit data empty interrupt request (TXI) is enabled.
6
TEIE
0
R/W
Transmit End Interrupt Enable
This bit enables or disables the transmit end interrupt (TEI)
at the rising of the ninth clock while the TDRE bit in ICSR
is 1. TEI can be canceled by clearing the TEND bit or the
TEIE bit to 0.
0: Transmit end interrupt request (TEI) is disabled.
1: Transmit end interrupt request (TEI) is enabled.
5
RIE
0
R/W
Receive Interrupt Enable
This bit enables or disables the receive data full interrupt
request (RXI) and the overrun error interrupt request (ERI)
with the clocked synchronous format, when a receive data
is transferred from ICDRS to ICDRR and the RDRF bit in
ICSR is set to 1. RXI can be canceled by clearing the
RDRF or RIE bit to 0.
0: Receive data full interrupt request (RXI) and overrun
error interrupt request (ERI) with the clocked
synchronous format are disabled.
1: Receive data full interrupt request (RXI) and overrun
error interrupt request (ERI) with the clocked
synchronous format are enabled.
Rev. 6.00 Sep. 24, 2009 Page 486 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Bit
Bit Name
Initial
Value
R/W
Description
4
NAKIE
0
R/W
NACK Receive Interrupt Enable
This bit enables or disables the NACK receive interrupt
request (NAKI) and the overrun error (setting of the OVE
bit in ICSR) interrupt request (ERI) with the clocked
synchronous format, when the NACKF and AL bits in ICSR
are set to 1. NAKI can be canceled by clearing the NACKF,
OVE, or NAKIE bit to 0.
0: NACK receive interrupt request (NAKI) is disabled.
1: NACK receive interrupt request (NAKI) is enabled.
3
STIE
0
R/W
Stop Condition Detection Interrupt Enable
0: Stop condition detection interrupt request (STPI) is
disabled.
1: Stop condition detection interrupt request (STPI) is
enabled.
2
ACKE
0
R/W
Acknowledge Bit Judgement Select
0: The value of the receive acknowledge bit is ignored, and
continuous transfer is performed.
1: If the receive acknowledge bit is 1, continuous transfer is
halted.
1
ACKBR
0
R
Receive Acknowledge
In transmit mode, this bit stores the acknowledge data that
are returned by the receive device. This bit cannot be
modified.
0: Receive acknowledge = 0
1: Receive acknowledge = 1
0
ACKBT
0
R/W
Transmit Acknowledge
In receive mode, this bit specifies the bit to be sent at the
acknowledge timing.
0: 0 is sent at the acknowledge timing.
1: 1 is sent at the acknowledge timing.
Rev. 6.00 Sep. 24, 2009 Page 487 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
14.3.5
I2C Bus Status Register (ICSR)
ICSR performs confirmation of interrupt request flags and status.
Bit
Bit Name
Initial
Value
R/W
7
TDRE
0
R/W
Description
Transmit Data Register Empty
[Setting conditions]
•
When data is transferred from ICDRT to ICDRS and
ICDRT becomes empty
•
When TRS is set
•
When a start condition (including re-transfer) has been
issued
•
When transmit mode is entered from receive mode in
slave mode
[Clearing conditions]
6
TEND
0
R/W
•
When 0 is written in TDRE after reading TDRE = 1
•
When data is written to ICDRT with an instruction
Transmit End
[Setting conditions]
•
When the ninth clock of SCL rises with the I C bus
format while the TDRE flag is 1
•
When the final bit of transmit frame is sent with the
clock synchronous serial format
2
[Clearing conditions]
5
RDRF
0
R/W
•
When 0 is written in TEND after reading TEND = 1
•
When data is written to ICDRT with an instruction
Receive Data Register Full
[Setting condition]
•
When a receive data is transferred from ICDRS to
ICDRR
[Clearing conditions]
Rev. 6.00 Sep. 24, 2009 Page 488 of 928
REJ09B0099-0600
•
When 0 is written in RDRF after reading RDRF = 1
•
When ICDRR is read with an instruction
2
Section 14 I C Bus Interface 2 (IIC2)
Bit
Bit Name
Initial
Value
R/W
Description
4
NACKF
0
R/W
No Acknowledge Detection Flag
[Setting condition]
•
When no acknowledge is detected from the receive
device in transmission while the ACKE bit in ICIER is 1
[Clearing condition]
•
3
STOP
0
R/W
When 0 is written in NACKF after reading NACKF = 1
Stop Condition Detection Flag
[Setting conditions]
•
In master mode, when a stop condition is detected after
frame transfer
•
In slave mode, when a stop condition is detected after
the general call address or the first byte slave address,
next to detection of start condition, accords with the
address set in SAR
[Clearing condition]
•
2
AL/OVE
0
R/W
When 0 is written in STOP after reading STOP = 1
Arbitration Lost Flag/Overrun Error Flag
This flag indicates that arbitration was lost in master mode
2
with the I C bus format and that the final bit has been
received while RDRF = 1 with the clocked synchronous
format.
When two or more master devices attempt to seize the bus
at nearly the same time, if the I2C bus interface detects
data differing from the data it sent, it sets AL to 1 to
indicate that the bus has been taken by another master.
[Setting conditions]
•
If the internal SDA and SDA pin disagree at the rise of
SCL in master transmit mode
•
When the SDA pin outputs high in master mode while a
start condition is detected
•
When the final bit is received with the clocked
synchronous format while RDRF = 1
[Clearing condition]
•
When 0 is written in AL/OVE after reading AL/OVE=1
Rev. 6.00 Sep. 24, 2009 Page 489 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Bit
Bit Name
Initial
Value
R/W
Description
1
AAS
0
R/W
Slave Address Recognition Flag
In slave receive mode, this flag is set to 1 if the first frame
following a start condition matches bits SVA6 to SVA0 in
SAR.
[Setting conditions]
•
When the slave address is detected in slave receive
mode
•
When the general call address is detected in slave
receive mode.
[Clearing condition]
•
0
ADZ
0
R/W
When 0 is written in AAS after reading AAS=1
General Call Address Recognition Flag
2
This bit is valid in I C bus format slave receive mode.
[Setting condition]
•
When the general call address is detected in slave
receive mode
[Clearing condition]
•
14.3.6
When 0 is written in ADZ after reading ADZ=1
Slave Address Register (SAR)
SAR selects the communication format and sets the slave address. When the chip is in slave mode
with the I2C bus format, if the upper 7 bits of SAR match the upper 7 bits of the first frame
received after a start condition, the chip operates as the slave device.
Rev. 6.00 Sep. 24, 2009 Page 490 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Bit Bit Name
Initial Value R/W
Description
7
SVA6
0
R/W
Slave Address 6 to 0
6
SVA5
0
R/W
5
SVA4
0
R/W
4
SVA3
0
R/W
These bits set a unique address in bits SVA6 to SVA0,
differing form the addresses of other slave devices
2
connected to the I C bus.
3
SVA2
0
R/W
2
SVA1
0
R/W
1
SVA0
0
R/W
0
FS
0
R/W
Format Select
0: I2C bus format is selected.
1: Clocked synchronous serial format is selected.
14.3.7
I2C Bus Transmit Data Register (ICDRT)
ICDRT is an 8-bit readable/writable register that stores the transmit data. When ICDRT detects the
space in the shift register (ICDRS), it transfers the transmit data which is written in ICDRT to
ICDRS and starts transferring data. If the next transfer data is written to ICDRT during
transferring data of ICDRS, continuous transfer is possible. If the MLS bit of ICMR is set to 1 and
when the data is written to ICDRT, the MSB/LSB inverted data is read. The initial value of
ICDRT is H′FF.
14.3.8
I2C Bus Receive Data Register (ICDRR)
ICDRR is an 8-bit register that stores the receive data. When data of one byte is received, ICDRR
transfers the receive data from ICDRS to ICDRR and the next data can be received. ICDRR is a
receive-only register, therefore the CPU cannot write to this register. The initial value of ICDRR is
H′FF.
14.3.9
I2C Bus Shift Register (ICDRS)
ICDRS is a register that is used to transfer/receive data. In transmission, data is transferred from
ICDRT to ICDRS and the data is sent from the SDA pin. In reception, data is transferred from
ICDRS to ICDRR after data of one byte is received. This register cannot be read directly from the
CPU.
Rev. 6.00 Sep. 24, 2009 Page 491 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
14.4
Operation
The I2C bus interface can communicate either in I2C bus mode or clocked synchronous serial mode
by setting FS in SAR.
14.4.1
I2C Bus Format
Figure 14.3 shows the I2C bus formats. Figure 14.4 shows the I2C bus timing. The first frame
following a start condition always consists of 8 bits.
(a) I2C bus format (FS = 0)
S
SLA
R/W
A
DATA
A
A/A
P
1
7
1
1
n
1
1
1
1
n: Transfer bit count
(n = 1 to 8)
m: Transfer frame count
(m ≥ 1)
m
(b) I2C bus format (Start condition retransmission, FS = 0)
S
SLA
R/W
A
DATA
A/A
S
SLA
R/W
A
DATA
A/A
P
1
7
1
1
n1
1
1
7
1
1
n2
1
1
1
m1
1
m2
n1 and n2: Transfer bit count (n1 and n2 = 1 to 8)
m1 and m2: Transfer frame count (m1 and m2 ≥ 1)
Figure 14.3 I2C Bus Formats
SDA
SCL
S
1-7
8
9
SLA
R/W
A
1-7
DATA
8
9
A
Figure 14.4 I2C Bus Timing
Rev. 6.00 Sep. 24, 2009 Page 492 of 928
REJ09B0099-0600
1-7
DATA
8
9
A
P
2
Section 14 I C Bus Interface 2 (IIC2)
Legend:
S:
Start condition. The master device drives SDA from high to low while SCL is high.
SLA: Slave address
R/W: Indicates the direction of data transfer: from the slave device to the master device when
R/W is 1, or from the master device to the slave device when R/W is 0.
A:
Acknowledge. The receive device drives SDA to low.
DATA: Transfer data
P:
Stop condition. The master device drives SDA from low to high while SCL is high.
14.4.2
Master Transmit Operation
In master transmit mode, the master device outputs the transmit clock and transmit data, and the
slave device returns an acknowledge signal. For master transmit mode operation timing, see
figures 14.5 and 14.6. The transmission procedure and operations in master transmit mode are
described below.
1. Set the ICE bit in ICCR1 to 1. Set the MLS and WAIT bits in ICMR and the CKS3 to CKS0
bits in ICCR1 to 1. (Initial setting)
2. Read the BBSY flag in ICCR2 to confirm that the bus is free. Set the MST and TRS bits in
ICCR1 to select master transmit mode. Then, write 1 to BBSY and 0 to SCP using MOV
instruction. (Start condition issued) This generates the start condition.
3. After confirming that TDRE in ICSR has been set, write the transmit data (the first byte data
show the slave address and R/W) to ICDRT. At this time, TDRE is automatically cleared to 0,
and data is transferred from ICDRT to ICDRS. TDRE is set again.
4. When transmission of one byte data is completed while TDRE is 1, TEND in ICSR is set to 1
at the rise of the 9th transmit clock pulse. Read the ACKBR bit in ICIER, and confirm that the
slave device has been selected. Then, write second byte data to ICDRT. When ACKBR is 1,
the slave device has not been acknowledged, so issue the stop condition. To issue the stop
condition, write 0 to BBSY and SCP using MOV instruction. SCL is fixed low until the
transmit data is prepared or the stop condition is issued.
5. The transmit data after the second byte is written to ICDRT every time TDRE is set.
6. Write the number of bytes to be transmitted to ICDRT. Wait until TEND is set (the end of last
byte data transmission) while TDRE is 1, or wait for NACK (NACKF in ICSR = 1) from the
receive device while ACKE in ICIER is 1. Then, issue the stop condition to clear TEND or
NACKF.
7. When the STOP bit in ICSR is set to 1, the operation returns to the slave receive mode.
Rev. 6.00 Sep. 24, 2009 Page 493 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
SCL
(Master output)
1
2
3
4
5
6
SDA
(Master output)
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
7
8
Bit 1
Slave address
9
1
Bit 0
Bit 7
2
Bit 6
R/W
SDA
(Slave output)
A
TDRE
TEND
Address + R/W
ICDRT
ICDRS
User
processing
Data 1
Address + R/W
[2] Instruction of start
condition issuance
Data 2
Data 1
[4] Write data to ICDRT (second byte)
[5] Write data to ICDRT (third byte)
[3] Write data to ICDRT (first byte)
Figure 14.5 Master Transmit Mode Operation Timing (1)
SCL
(Master output)
9
SDA
(Master output)
SDA
(Slave output)
1
2
3
4
5
6
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
A
7
Bit 1
8
9
Bit 0
A/A
TDRE
TEND
Data n
ICDRT
ICDRS
Data n
User
[5] Write data to ICDRT
processing
[6] Issue stop condition. Clear TEND.
[7] Set slave receive mode
Figure 14.6 Master Transmit Mode Operation Timing (2)
Rev. 6.00 Sep. 24, 2009 Page 494 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
14.4.3
Master Receive Operation
In master receive mode, the master device outputs the receive clock, receives data from the slave
device, and returns an acknowledge signal. For master receive mode operation timing, see figures
14.7 and 14.8. The reception procedure and operations in master receive mode are shown below.
1. Clear the TEND bit in ICSR to 0, then clear the TRS bit in ICCR1 to 0 to switch from master
transmit mode to master receive mode. Then, clear the TDRE bit to 0.
2. When ICDRR is read (dummy data read), reception is started, and the receive clock is output,
and data received, in synchronization with the internal clock. The master device outputs the
level specified by ACKBT in ICIER to SDA, at the 9th receive clock pulse.
3. After the reception of first frame data is completed, the RDRF bit in ICST is set to 1 at the rise
of 9th receive clock pulse. At this time, the receive data is read by reading ICDRR, and RDRF
is cleared to 0.
4. The continuous reception is performed by reading ICDRR every time RDRF is set. If, while
RDRF is set to 1, the reading of ICDRR is delayed by other processing and does not occur by
the falling edge of the 8th clock pulse, set RCVD to 1 and perform one-byte data transfer.
5. If next frame is the last receive data, set the RCVD bit in ICCR1 to 1 before reading ICDRR.
This enables the issuance of the stop condition after the next reception.
6. When the RDRF bit is set to 1 at rise of the 9th receive clock pulse, issue the stage condition.
7. When the STOP bit in ICSR is set to 1, read ICDRR. Then clear the RCVD bit to 0.
8. The operation returns to the slave receive mode.
Rev. 6.00 Sep. 24, 2009 Page 495 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Master transmit mode
SCL
(Master output)
Master receive mode
9
1
2
3
4
5
6
7
8
SDA
(Master output)
9
1
A
SDA
(Slave output)
A
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Bit 7
TDRE
TEND
TRS
RDRF
ICDRS
Data 1
ICDRR
User
processing
Data 1
[3] Read ICDRR
[1] Clear TDRE after clearing
TEND and TRS
[2] Read ICDRR (dummy read)
Figure 14.7 Master Receive Mode Operation Timing (1)
Rev. 6.00 Sep. 24, 2009 Page 496 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
SCL
(Master output)
9
SDA
(Master output)
A
SDA
(Slave output)
1
2
3
4
5
6
7
8
9
A/A
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
RDRF
RCVD
ICDRS
Data n
Data n-1
ICDRR
Data n
Data n-1
User
processing
[5] Read ICDRR after setting RCVD
[7] Read ICDRR,
and clear RCVD
[6] Issue stop
condition [8] Set slave
receive mode
Figure 14.8 Master Receive Mode Operation Timing (2)
14.4.4
Slave Transmit Operation
In slave transmit mode, the slave device outputs the transmit data, while the master device outputs
the receive clock and returns an acknowledge signal. For slave transmit mode operation timing,
see figures 14.9 and 14.10.
The transmission procedure and operations in slave transmit mode are described below.
1. Set the ICE bit in ICCR1 to 1. Set the MLS and WAIT bits in ICMR and the CKS3 to CKS0
bits in ICCR1 to 1. (Initial setting) Set the MST and TRS bits in ICCR1 to select slave receive
mode, and wait until the slave address matches.
2. When the slave address matches in the first frame following detection of the start condition,
the slave device outputs the level specified by ACKBT in ICIER to SDA, at the rise of the 9th
clock pulse. At this time, if the 8th bit data (R/W) is 1, the TRS and ICSR bits in ICCR1 are
set to 1, and the mode changes to slave transmit mode automatically. The continuous
transmission is performed by writing transmit data to ICDRT every time TDRE is set.
3. If TDRE is set after writing last transmit data to ICDRT, wait until TEND in ICSR is set to 1,
with TDRE = 1. When TEND is set, clear TEND.
4. Clear TRS for the end processing, and read ICDRR (dummy read). SCL is free.
5. Clear TDRE.
Rev. 6.00 Sep. 24, 2009 Page 497 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Slave receive mode
Slave transmit mode
SCL
(Master output)
9
1
2
3
4
5
6
7
8
9
SDA
(Master output)
1
A
SCL
(Slave output)
SDA
(Slave output)
A
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Bit 7
TDRE
TEND
TRS
Data 1
ICDRT
ICDRS
Data 2
Data 1
Data 3
Data 2
ICDRR
User
processing
[2] Write data to ICDRT (data 1)
[2] Write data to ICDRT (data 2)
[2] Write data to ICDRT (data 3)
Figure 14.9 Slave Transmit Mode Operation Timing (1)
Rev. 6.00 Sep. 24, 2009 Page 498 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Slave receive
mode
Slave transmit mode
SCL
(Master output)
9
SDA
(Master output)
A
1
2
3
4
5
6
7
8
9
A
SCL
(Slave output)
SDA
(Slave output)
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
TDRE
TEND
TRS
ICDRT
ICDRS
Data n
ICDRR
User
processing
[3] Clear TEND
[4] Read ICDRR (dummy read)
after clearing TRS
[5] Clear TDRE
Figure 14.10 Slave Transmit Mode Operation Timing (2)
14.4.5
Slave Receive Operation
In slave receive mode, the master device outputs the transmit clock and transmit data, and the
slave device returns an acknowledge signal. For slave receive mode operation timing, see figures
14.11 and 14.12. Since a flag may be set according to the port state, initialization should be
performed after all bits in ICSR have been cleared. The reception procedure and operations in
slave receive mode are described below.
1. Set the ICE bit in ICCR1 to 1. Set the MLS and WAIT bits in ICMR and the CKS3 to CKS0
bits in ICCR1 to 1. (Initial setting) Set the MST and TRS bits in ICCR1 to select slave receive
mode, and wait until the slave address matches.
2. When the slave address matches in the first frame following detection of the start condition,
the slave device outputs the level specified by ACKBT in ICIER to SDA, at the rise of the 9th
Rev. 6.00 Sep. 24, 2009 Page 499 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
clock pulse. At the same time, RDRF in ICSR is set to read ICDRR (dummy read). (Since the
read data show the slave address and R/W, it is not used.)
3. Read ICDRR every time RDRF is set. If 8th receive clock pulse falls while RDRF is 1, SCL is
fixed low until ICDRR is read. The change of the acknowledge before reading ICDRR, to be
returned to the master device, is reflected to the next transmit frame.
4. The last byte data is read by reading ICDRR.
SCL
(Master output)
9
SDA
(Master output)
1
2
3
4
5
6
7
8
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
9
1
Bit 7
SCL
(Slave output)
SDA
(Slave output)
A
A
RDRF
ICDRS
Data 1
ICDRR
User
processing
Data 1
[2] Read ICDRR (dummy read)
Figure 14.11 Slave Receive Mode Operation Timing (1)
Rev. 6.00 Sep. 24, 2009 Page 500 of 928
REJ09B0099-0600
Data 2
[2] Read ICDRR
2
Section 14 I C Bus Interface 2 (IIC2)
SCL
(Master output)
9
SDA
(Master output)
1
2
3
4
5
6
7
8
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
9
SCL
(Slave output)
SDA
(Slave output)
A
A
RDRF
ICDRS
Data 2
Data 1
ICDRR
Data 1
User
processing
[3] Set ACKBT
[3] Read ICDRR [4] Read ICDRR
Figure 14.12 Slave Receive Mode Operation Timing (2)
14.4.6
Clocked Synchronous Serial Format
This module can be operated with the clocked synchronous serial format, by setting the FS bit in
SAR to 1. When the MST bit in ICCR1 is 1, the transfer clock output from SCL is selected. When
MST is 0, the external clock input is selected.
Data Transfer Format: Figure 14.13 shows the clocked synchronous serial transfer format.
The transfer data is output from the rise to the fall of the SCL clock, and the data at the rising edge
of the SCL clock is guaranteed. The MLS bit in ICMR sets the order of data transfer, in either the
MSB first or LSB first. The output level of SDA can be changed during the transfer wait, by the
SDAO bit in ICCR2.
SCL
SDA
Bit 0
Bit 1
Bit 2 Bit 3 Bit 4
Bit 5 Bit 6
Bit 7
Figure 14.13 Clocked Synchronous Serial Transfer Format
Transmit Operation: In transmit mode, transmit data is output from SDA, in synchronization
with the fall of the transfer clock. The transfer clock is output when MST in ICCR1 is 1, and is
Rev. 6.00 Sep. 24, 2009 Page 501 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
input when MST is 0. For transmit mode operation timing, see figure 14.14. The transmission
procedure and operations in transmit mode are described below.
1. Set the ICE bit in ICCR1 to 1. Set the MST and CKS3 to CKS0 bits in ICCR1 to 1. (Initial
setting)
2. Set the TRS bit in ICCR1 to select the transmit mode. Then, TDRE in ICSR is set.
3. Confirm that TDRE has been set. Then, write the transmit data to ICDRT. The data is
transferred from ICDRT to ICDRS, and TDRE is set automatically. The continuous
transmission is performed by writing data to ICDRT every time TDRE is set. When changing
from transmit mode to receive mode, clear TRS while TDRE is 1.
SCL
1
2
7
8
1
7
8
1
SDA
(Output)
Bit 0
Bit 1
Bit 6
Bit 7
Bit 0
Bit 6
Bit 7
Bit 0
TRS
TDRE
Data 1
ICDRT
Data 1
ICDRS
User
processing
Data 2
[3] Write data [3] Write data
to ICDRT
to ICDRT
[2] Set TRS
Data 3
Data 2
Data 3
[3] Write data
to ICDRT
[3] Write data
to ICDRT
Figure 14.14 Transmit Mode Operation Timing
Receive Operation: In receive mode, data is latched at the rise of the transfer clock. The transfer
clock is output when MST in ICCR1 is 1, and is input when MST is 0. For receive mode operation
timing, see figure 14.15. The reception procedure and operations in receive mode are described
below.
1. Set the ICE bit in ICCR1 to 1. Set the MST and CKS3 to CKS0 bits in ICCR1 to 1. (Initial
setting)
2. When the transfer clock is output, set MST to 1 to start outputting the receive clock.
3. When the receive operation is completed, data is transferred from ICDRS to ICDRR and
RDRF in ICSR is set. When MST = 1, the next byte can be received, so the clock is
continually output. The continuous reception is performed by reading ICDRR every time
Rev. 6.00 Sep. 24, 2009 Page 502 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
RDRF is set. When the 8th clock is risen while RDRF is 1, the overrun is detected and
AL/OVE in ICSR is set. At this time, the previous reception data is retained in ICDRR.
4. To stop receiving when MST = 1, set RCVD in ICCR1 to 1, then read ICDRR. Then, SCL is
fixed high after receiving the next byte data.
SCL
1
2
7
8
1
7
8
1
2
SDA
(Input)
Bit 0
Bit 1
Bit 6
Bit 7
Bit 0
Bit 6
Bit 7
Bit 0
Bit 1
MST
TRS
RDRF
Data 1
ICDRS
Data 1
ICDRR
User
processing
Data 2
[2] Set MST
(when outputting the clock)
[3] Read ICDRR
Data 3
Data 2
[3] Read ICDRR
Figure 14.15 Receive Mode Operation Timing
14.4.7
Noise Canceler
The logic levels at the SCL and SDA pins are routed through noise cancelers before being latched
internally. Figure 14.16 shows a block diagram of the noise canceler circuit.
The noise canceler consists of two cascaded latches and a match detector. The SCL (or SDA)
input signal is sampled on the system clock, but is not passed forward to the next circuit unless the
outputs of both latches agree. If they do not agree, the previous value is held.
Rev. 6.00 Sep. 24, 2009 Page 503 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Sampling clock
C
C
SCL or SDA
input signal
D
Q
Latch
D
Q
Latch
March detector
Internal
SCL or SDA
signal
System clock
period
Sampling
clock
Figure 14.16 Block Diagram of Noise Canceler
14.4.8
Example of Use
Flowcharts in respective modes that use the I2C bus interface are shown in figures 14.17 to 14.20.
Rev. 6.00 Sep. 24, 2009 Page 504 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Start
Initialize
[1]
Test the status of the SCL and SDA lines.
[2]
Set master transmit mode.
[3]
Issue the start condition.
[2]
[4]
Set the first byte (slave address + R/W) of transmit data.
Write 1 to BBSY
and 0 to SCP.
[3]
[5]
Wait for 1 byte to be transmitted.
Write transmit data
in ICDRT
[4]
[6]
Test the acknowledge transferred from the specified slave device.
[7]
Set the second and subsequent bytes (except for the final byte) of transmit data.
[8]
Wait for ICDRT empty.
[9]
Set the last byte of transmit data.
Read BBSY in ICCR2
[1]
No
BBSY=0 ?
Yes
Set MST and TRS
in ICCR1 to 1.
Read TEND in ICSR
[5]
No
TEND=1 ?
Yes
Read ACKBR in ICIER
[6]
ACKBR=0 ?
[10] Wait for last byte to be transmitted.
No
[11] Clear the TEND flag.
Yes
Transmit
mode?
Yes
No
Write transmit data in ICDRT
Mater receive mode
[7]
[13] Issue the stop condition.
Read TDRE in ICSR
No
[8]
TDRE=1 ?
Yes
No
[12] Clear the STOP flag.
[14] Wait for the creation of stop condition.
[15] Set slave receive mode. Clear TDRE.
Last byte?
[9]
Yes
Write transmit data in ICDRT
Read TEND in ICSR
No
[10]
TEND=1 ?
Yes
Clear TEND in ICSR
[11]
Clear STOP in ICSR
[12]
Write 0 to BBSY
and SCP
[13]
Read STOP in ICSR
No
[14]
STOP=1 ?
Yes
Set MST to 1 and TRS
to 0 in ICCR1
[15]
Clear TDRE in ICSR
End
Figure 14.17 Sample Flowchart for Master Transmit Mode
Rev. 6.00 Sep. 24, 2009 Page 505 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Mater receive mode
[1]
Clear TEND, select master receive mode, and then clear TDRE.*
[2]
Set acknowledge to the transmit device.*
[3]
Dummy-read ICDDR.*
[4]
Wait for 1 byte to be received
[5]
Check whether it is the (last receive - 1).
[6]
Read the receive data last.
[7]
Set acknowledge of the final byte. Disable continuous reception (RCVD = 1).
[8]
Read the (final byte - 1) of receive data.
[9]
Wait for the last byte to be receive.
Clear TEND in ICSR
Clear TRS in ICCR1 to 0
[1]
Clear TDRE in ICSR
Clear ACKBT in ICIER to 0
[2]
Dummy-read ICDRR
[3]
Read RDRF in ICSR
No
[4]
RDRF=1 ?
Yes
Last receive
- 1?
No
Read ICDRR
Yes
[5]
[10] Clear the STOP flag.
[6]
[11] Issue the stop condition.
[12] Wait for the creation of stop condition.
Set ACKBT in ICIER to 1
[7]
Set RCVD in ICCR1 to 1
Read ICDRR
[13] Read the last byte of receive data.
[14] Clear RCVD.
[8]
[15] Set slave receive mode.
Read RDRF in ICSR
No
RDRF=1 ?
[9]
Yes
Clear STOP in ICSR.
Write 0 to BBSY
and SCP
[10]
[11]
Read STOP in ICSR
No
[12]
STOP=1 ?
Yes
Read ICDRR
[13]
Clear RCVD in ICCR1 to 0
[14]
Clear MST in ICCR1 to 0
[15]
Notes: When receiving one byte, execute step [7] after step [1] without executing
steps [2] to [6]. The step [8] is ICDRR dummy read.
* Do not activate an interrupt during the execution of steps [1] to [3].
End
Figure 14.18 Sample Flowchart for Master Receive Mode
Rev. 6.00 Sep. 24, 2009 Page 506 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
[1] Clear the AAS flag.
Slave transmit mode
Clear AAS in ICSR
[1]
Write transmit data
in ICDRT
[2]
[3] Wait for ICDRT empty.
[4] Set the last byte of transmit data.
Read TDRE in ICSR
No
[5] Wait for the last byte to be transmitted.
[3]
TDRE=1 ?
Yes
No
[6] Clear the TEND flag .
[7] Set slave receive mode.
Last
byte?
Yes
[2] Set transmit data for ICDRT (except for the last data).
[8] Dummy-read ICDRR to release the SCL line.
[4]
[9] Clear the TDRE flag.
Write transmit data
in ICDRT
Read TEND in ICSR
No
[5]
TEND=1 ?
Yes
Clear TEND in ICSR
[6]
Clear TRS in ICCR1 to 0
[7]
Dummy read ICDRR
[8]
Clear TDRE in ICSR
[9]
End
Figure 14.19 Sample Flowchart for Slave Transmit Mode
Rev. 6.00 Sep. 24, 2009 Page 507 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
Slave receive mode
[1] Clear the AAS flag.
Clear AAS in ICSR
[1]
Clear ACKBT in ICIER to 0
[2]
Dummy-read ICDRR
[3]
[2] Set acknowledge to the transmit device.
[3] Dummy-read ICDRR.
[5] Check whether it is the (last receive - 1).
Read RDRF in ICSR
No
[4]
RDRF=1 ?
[6] Read the receive data.
[7] Set acknowledge of the last byte.
Yes
Last receive
- 1?
[4] Wait for 1 byte to be received.
Yes
No
Read ICDRR
[5]
[8] Read the (last byte - 1) of receive data.
[9] Wait the last byte to be received.
[6]
[10] Read for the last byte of receive data.
Set ACKBT in ICIER to 1
[7]
Read ICDRR
[8]
Read RDRF in ICSR
No
[9]
RDRF=1 ?
Yes
Read ICDRR
[10]
Note: When receiving one byte, execute step [7] after step [1] without executing
executing steps [2] to [6]. The step [8] is ICDRR dummy read.
End
Figure 14.20 Sample Flowchart for Slave Receive Mode
Rev. 6.00 Sep. 24, 2009 Page 508 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
14.5
Interrupt Request
There are six interrupt requests in this module; transmit data empty, transmit end, receive data full,
NACK receive, STOP recognition, and arbitration lost/overrun error. Table 14.3 shows the
contents of each interrupt request.
Table 14.3 Interrupt Requests
Interrupt Request
Abbreviation
Interrupt Condition
Clocked
Synchronous
2
I C Mode Mode
Transmit data empty
TXI
(TDRE=1) • (TIE=1)
O
{
Transmit end
TEI
(TEND=1) • (TEIE=1)
{
{
Receive data full
RXI
(RDRF=1) • (RIE=1)
{
{
STOP recognition
STPI
(STOP=1) (STIE=1)
{
X
NACK receive
NAKI
{(NACKF=1)+(AL=1)}
(NAKIE=1)
Arbitration
lost/overrun Error
•
•
{
X
{
{
When interrupt conditions described in table 14.3 are 1 and the I bit in CCR is 0, the CPU
executes an interrupt exception processing. Interrupt sources should be cleared in the exception
processing. TDRE and TEND are automatically cleared to 0 by writing the transmit data to
ICDRT. RDRF are automatically cleared to 0 by reading ICDRR. TDRE is set to 1 again at the
same time when transmit data is written to ICDRT. When TDRE is cleared to 0, then an excessive
data of one byte may be transmitted.
Rev. 6.00 Sep. 24, 2009 Page 509 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
14.6
Bit Synchronous Circuit
In master mode, this module has a possibility that high level period may be short in the two states
described below.
• When SCL is driven to low by the slave device
• When the rising speed of SCL is lowered by the load of the SCL line (load capacitance or pullup resistance)
Therefore, it monitors SCL and communicates by bit with synchronization.
Figure 14.21 shows the timing of the bit synchronous circuit and table 14.4 shows the time when
SCL output changes from low to Hi-Z then SCL is monitored.
SCL monitor
timing reference
clock
VIH
SCL
Internal SCL
Figure 14.21 The Timing of the Bit Synchronous Circuit
Table 14.4 Time for Monitoring SCL
CKS3
CKS2
Time for Monitoring SCL
0
0
7.5 tcyc
1
19.5 tcyc
0
14.5 tcyc
1
41.5 tcyc
1
Rev. 6.00 Sep. 24, 2009 Page 510 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
14.7
14.7.1
Note on Usage
Setting Module Stop Mode
The IIC2 is enabled or disabled by setting the module stop control register. In the initial state, the
IIC2 is disabled. After the module stop mode is canceled, registers can be accessed. For details,
see section 22, Power-Down Modes.
14.7.2
Issuance of Stop and Repeated Start Conditions
Confirm the ninth falling edge of the clock before issuing a stop or a repeated start condition.
The ninth falling edge can be confirmed by monitoring the SCLO bit in the I2C bus control register
2 (ICCR2).
If a stop or a repeated start condition is issued at a certain timing in either of the following cases,
the stop or repeated start condition may be issued incorrectly.
• The rising time of the SCL signal exceeds the time given in section 14.6, Bit Synchronous
Circuit, because of the load on the SCL bus.
• The bit synchronous circuit is activated because a slave device holds the SCL bus low during
the eighth clock.
14.7.3
WAIT Bit in I2C Bus Mode Register (ICMR)
The WAIT bit in the I2C bus mode register (ICMR) must be held 0.
If the WAIT bit is set to 1, when a slave device holds the SCL signal low more than one transfer
clock cycle during the eights clock, the high level period of the ninth clock may be shorter than a
given period.
Rev. 6.00 Sep. 24, 2009 Page 511 of 928
REJ09B0099-0600
2
Section 14 I C Bus Interface 2 (IIC2)
14.7.4
Usage Note on Master Receive Mode
In master receive mode, when SCL is fixed low on the falling edge of the 8th clock while the
RDRF bit is set to 1 and ICDRR is read around the falling edge of the 8th clock, the clock is only
fixed low in the 8th clock of the next round of data reception. The SCL is then released from its
fixed state without reading ICDRR and the 9th clock is output. As a result, some receive data is
lost.
Ways to avoid this phenomenon are listed below.
• Read ICDRR in master receive mode before the rising edge of the 8th clock.
• Set RCVD to 1 in master receive mode and perform communication in units of one byte.
14.7.5
Restriction on Setting of Transfer Rate in Use of Multi-Master
In multi-master usage when the IIC transfer rate setting of this LSI is lower than those of the other
masters, unexpected length of SCL may occasionally be output. To avoid this, the specified value
must be greater than or equal to the value produced by multiplying the fastest transfer rate among
the other masters by 1/1.8. For example, when the transfer rate of the fastest bus master among the
other bus masters is 400 kbps, the transfer rate of the IIC of this LSI must be set to at least 223
kbps (= 400/1.8).
14.7.6
Restriction on Use of Bit Manipulation Instructions to Set MST and TRS when
Multi-Master Is Used
When master transmission is selected by consecutively manipulating the MST and TRS bits in
multi-master usage, an arbitration loss during execution of the bit-manipulation instruction for
TRS leads to the contradictory situation where AL in ICSR is 1 in master transmit mode (MST =
1, TRS = 1).
Ways to avoid this effect are listed below.
• Use the MOV instruction to set MST and TRS in multi-master usage.
• When arbitration is lost, confirm that MST = 0 and TRS = 0. If the setting of MST = 0 and
TRS = 0 is not confirmed, set MST = 0 and TRS = 0 again.
Rev. 6.00 Sep. 24, 2009 Page 512 of 928
REJ09B0099-0600
Section 15 A/D Converter
Section 15 A/D Converter
This LSI includes a successive approximation type 10-bit A/D converter that allows up to 16
analog input channels to be selected. A block diagram of the A/D converter is shown in figure
15.1.
15.1
Features
• 10-bit resolution
• 16 input channels
• Conversion time: 13.3 µs per channel (at 20-MHz operation), 10.1 µs per channel (at 26-MHz
operation)
• Two operating modes
Single mode: Single-channel A/D conversion
Scan mode: Continuous A/D conversion on 1 to 4 channels
• Four data registers
Conversion results are held in a 16-bit data register for each channel
• Sample and hold function
• Three methods conversion start
Software
16-bit timer pulse unit (TPU or TMR) conversion start trigger
External trigger signal
• Interrupt request
An A/D conversion end interrupt request (ADI) can be generated
• Module stop mode can be set
• Selectable range of voltages of analog inputs
The range of voltages of analog inputs to be converted can be specified using the Vref signal
as the analog reference voltage.
Rev. 6.00 Sep. 24, 2009 Page 513 of 928
REJ09B0099-0600
Section 15 A/D Converter
AVcc
Module data bus
Bus interface
Internal data bus
ADCR
ADCSR
ADDRD
ADDRC
φ/2
+
φ/4
Comparator
Multiplexer
AN0
AN1
AN2
AN3
AN4
AN5
AN6
AN7
AN8
AN9
AN10
AN11
AN12
AN13
AN14
AN15
ADDRB
Vref
ADDRA
Successive approximations
register
10-bit D/A
converter
Control circuit
Sample-andhold circuit
φ/8
φ/16
ADI
interrupt signal
Conversion start
trigger from TPU or
8-bit timer
ADTRG
Off while waiting for A/D conversion.
On during A/D conversion.
AVss
Legend:
ADCR: A/D control register
ADCSR: A/D control/status register
ADDRA: A/D data register A
ADDRB: A/D data register B
ADDRC: A/D data register C
ADDRD: A/D data register D
Figure 15.1 Block Diagram of A/D Converter
Rev. 6.00 Sep. 24, 2009 Page 514 of 928
REJ09B0099-0600
Section 15 A/D Converter
15.2
Input/Output Pins
Table 15.1 summarizes the input pins used by the A/D converter. The 16 analog input pins (AN0
to AN15) are divided into four groups each of which consists of two channels; analog input pins 0
to 7 (AN0 to AN7) comprising channel set 0, analog input pins 8 to 15 (AN8 to AN15) comprising
channel set 1, analog input pins 0 to 3, 8 to 11 (AN0 to AN3, AN8 to AN11) comprising group 0,
and analog input pins 4 to 7, 12 to 15 (AN4 to AN7, AN12 to AN15) comprising group 1. The
AVcc and AVss pins are the power supply pins for the analog block in the A/D converter. The
Vref pin is the A/D conversion reference voltage pin.
Table 15.1 Pin Configuration
Pin Name
Symbol
I/O
Function
Analog power supply pin
AVCC
Input
Analog block power supply pin
Analog ground pin
AVSS
Input
Analog block ground and reference voltage
Reference voltage pin
Vref
Input
Reference voltage for A/D conversion
Analog input pin 0
AN0
Input
Analog input pin 1
AN1
Input
Channel set 0 (CH3 = 0), group 0 analog
input pins
Analog input pin 2
AN2
Input
Analog input pin 3
AN3
Input
Analog input pin 4
AN4
Input
Analog input pin 5
AN5
Input
Analog input pin 6
AN6
Input
Analog input pin 7
AN7
Input
Analog input pin 8
AN8
Input
Analog input pin 9
AN9
Input
Analog input pin 10
AN10
Input
Analog input pin 11
AN11
Input
Analog input pin 12
AN12
Input
Analog input pin 13
AN13
Input
Analog input pin 14
AN14
Input
Analog input pin 15
AN15
Input
A/D external trigger input
ADTRG
Input
Channel set 0 (CH3 = 0), group 1 analog
input pins
Channel set 1 (CH3 = 1), group 0 analog
input pins
Channel set 1 (CH3 = 1), group 1 analog
input pins
External trigger input pin for starting A/D
conversion
Rev. 6.00 Sep. 24, 2009 Page 515 of 928
REJ09B0099-0600
Section 15 A/D Converter
15.3
Register Descriptions
The A/D converter has the following registers. For details on the module stop control register, see
section 22.1.2, Module Stop Control Registers A to C (MSTPCRA to MSTPCRC).
•
•
•
•
•
•
A/D data register A (ADDRA)
A/D data register B (ADDRB)
A/D data register C (ADDRC)
A/D data register D (ADDRD)
A/D control/status register (ADCSR)
A/D control register (ADCR)
15.3.1
A/D Data Registers A to D (ADDRA to ADDRD)
There are four 16-bit read-only ADDR registers; ADDRA to ADDRD, used to store the results of
A/D conversion. The ADDR registers, which store a conversion result for each analog input
channel, are shown in table 15.2.
The converted 10-bit data is stored in bits 6 to 15. The lower 6 bits are always read as 0.
The data bus between the CPU and the A/D converter is 8 bits wide. The upper byte can be read
directly from the CPU, however the lower byte should be read via a temporary register. Therefore,
when reading ADDR, read only the upper byte, or read in word unit.
Table 15.2 Analog Input Channels and Corresponding ADDR Registers
Analog Input Channel
Channel Set 0 (CH3 = 0)
Channel Set 1 (CH3 = 1)
Group 0
(CH2 = 0)
Group 1
(CH2 = 1)
Group 0
(CH2 = 0)
Group 1
(CH2 = 1)
A/D Data Register to be
Stored Results of A/D
Conversion
AN0
AN4
AN8
AN12
ADDRA
AN1
AN5
AN9
AN13
ADDRB
AN2
AN6
AN10
AN14
ADDRC
AN3
AN7
AN11
AN15
ADDRD
Rev. 6.00 Sep. 24, 2009 Page 516 of 928
REJ09B0099-0600
Section 15 A/D Converter
15.3.2
A/D Control/Status Register (ADCSR)
ADCSR controls A/D conversion operations.
Bit
Bit Name
Initial
Value
R/W
7
ADF
0
R/(W)* A/D End Flag
Description
A status flag that indicates the end of A/D conversion.
[Setting conditions]
•
When A/D conversion ends in single mode
•
When A/D conversion ends on all specified channels in
scan mode
[Clearing conditions]
6
ADIE
0
R/W
•
When 0 is written after reading ADF = 1
•
When the DTC is activated by an ADI interrupt, and the
DISEL bit in DTC is 0 with the transfer counter other
than 0
A/D Interrupt Enable
A/D conversion end interrupt (ADI) request enabled when 1
is set
5
ADST
0
R/W
A/D Start
Clearing this bit to 0 stops A/D conversion, and the A/D
converter enters the wait state.
Setting this bit to 1 starts A/D conversion. In single mode,
this bit is cleared to 0 automatically when conversion on
the specified channel is complete. In scan mode,
conversion continues sequentially on the specified
channels until this bit is cleared to 0 by software, a reset, or
a transition to software standby mode, hardware standby
mode, or module stop mode.
The ADST bit can be set to 1 by software, a timer
conversion start trigger, or the A/D external trigger input pin
(ADTRG).
Rev. 6.00 Sep. 24, 2009 Page 517 of 928
REJ09B0099-0600
Section 15 A/D Converter
Bit
Bit Name
Initial
Value
R/W
Description
4
SCAN
0
R/W
Scan Mode
Selects single mode or scan mode as the A/D conversion
operating mode.
Only set the SCAN bit while conversion is stopped (ADST
= 0).
0: Single mode
1: Scan mode
3
CH3
0
R/W
Channel Select 3
Switches the analog channel allocated to group 0 and
group 1.
Group 0
Rev. 6.00 Sep. 24, 2009 Page 518 of 928
REJ09B0099-0600
Group 1
0: Channel set 0 AN0 to AN3
AN4 to AN7
1: Channel set 1 AN 8 to AN11
AN12 to AN15
Section 15 A/D Converter
Bit
Bit Name
Initial
Value
R/W
Description
2
CH2
0
R/W
Channel Select 0 to 2
1
CH1
0
R/W
Select analog input channels.
0
CH0
0
R/W
When SCAN = 0
When SCAN = 1
Channel set 0 (CH3 = 0)
000: AN0
000: AN0
001: AN1
001: AN0, AN1
010: AN2
010: AN0 to AN2
011: AN3
011: AN0 to AN3
100: AN4
100: AN4
101: AN5
101: AN4, AN5
110: AN6
110: AN4 to AN6
111: AN7
111: AN4 to AN7
Channel set 1 (CH3 = 1)
000: AN8
Note:
*
000: AN8
001: AN9
001: AN8, AN9
010: AN10
010: AN8 to AN10
011: AN11
011: AN8 to AN11
100: AN12
100: AN12
101: AN13
101: AN12, AN13
110: AN14
110: AN12 to AN14
111: AN15
111: AN12 to AN15
Only 0 can be written to clear this flag.
Rev. 6.00 Sep. 24, 2009 Page 519 of 928
REJ09B0099-0600
Section 15 A/D Converter
15.3.3
A/D Control Register (ADCR)
ADCR enables A/D conversion started by an external trigger signal.
Bit
Bit Name
Initial
Value
R/W
Description
7
TRGS1
0
R/W
Timer Trigger Select 0 and 1
6
TRGS0
0
R/W
Enables the start of A/D conversion by a trigger signal.
Only set bits TRGS0 and TRGS1 while conversion is
stopped (ADST = 0).
00: A/D conversion start by software is enabled
01: A/D conversion start by TPU conversion start trigger is
enabled
10: A/D conversion start by 8-bit timer conversion start
trigger is enabled
11: A/D conversion start by external trigger pin (ADTRG) is
enabled
5, 4
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
3
CKS1
0
R/W
Clock Select 0 and 1
2
CKS0
0
R/W
These bits specify the A/D conversion time. The
conversion time should be changed only when the A/D
conversion stops (ADST = 0).
The conversion time setting should exceed the conversion
time shown in section 24.5, A/D Converter Characteristics.
00: Conversion time = 530 states (max.)
01: Conversion time = 266 states (max.)
10: Conversion time = 134 states (max.)
11: Conversion time = 68 states (max.)
1, 0
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
Rev. 6.00 Sep. 24, 2009 Page 520 of 928
REJ09B0099-0600
Section 15 A/D Converter
15.4
Interface to Bus Master
ADDRA to ADDRD are 16-bit registers. As the data bus to the bus master is 8 bits wide, the bus
master accesses to the upper byte of the registers directly while to the lower byte of the registers
via the temporary register (TEMP).
Data in ADDR is read in the following way: When the upper-byte data is read, the upper-byte data
will be transferred to the CPU and the lower-byte data will be transferred to TEMP. Then, when
the lower-byte data is read, the lower-byte data will be transferred to the CPU.
When data in ADDR is read, the data should be read from the upper byte and lower byte in the
order. When only the upper-byte data is read, the data is guaranteed. However, when only the
lower-byte data is read, the data is not guaranteed.
Figure 15.2 shows data flow when accessing to ADDR.
Read the upper byte
Bus master
(H'AA)
Module data bus
Bus interface
TEMP
(H'40)
ADDRnH
(H'AA)
ADDRnL
(H'40)
(n = A to D)
Read the lower byte
Bus master
(H'40)
Module data bus
Bus interface
TEMP
(H'40)
ADDRnH
(H'AA)
ADDRnL
(H'40)
(n = A to D)
Figure 15.2 Access to ADDR (When Reading H'AA40)
Rev. 6.00 Sep. 24, 2009 Page 521 of 928
REJ09B0099-0600
Section 15 A/D Converter
15.5
Operation
The A/D converter operates by successive approximation with 10-bit resolution. It has two
operating modes; single mode and scan mode. When changing the operating mode or analog input
channel, in order to prevent incorrect operation, first clear the bit ADST to 0 in ADCSR. The
ADST bit can be set at the same time as the operating mode or analog input channel is changed.
15.5.1
Single Mode
In single mode, A/D conversion is to be performed only once on the specified single channel. The
operations are as follows.
1. A/D conversion is started when the ADST bit is set to 1, according to software, timer
conversion start trigger, or external trigger input.
2. When A/D conversion is completed, the result is transferred to the corresponding A/D data
register to the channel.
3. On completion of conversion, the ADF bit in ADCSR is set to 1. If the ADIE bit is set to 1 at
this time, an ADI interrupt request is generated.
4. The ADST bit remains set to 1 during A/D conversion. When A/D conversion ends, the ADST
bit is automatically cleared to 0 and the A/D converter enters the wait state.
Rev. 6.00 Sep. 24, 2009 Page 522 of 928
REJ09B0099-0600
Section 15 A/D Converter
Set*
ADIE
ADST
A/D
conversion
starts
Set*
Set*
Clear*
ADF
State of channel 0 (AN0)
Clear*
Idle
State of channel 1 (AN1)
Idle
State of channel 2 (AN2)
Idle
State of channel 3 (AN3)
Idle
A/D conversion 1
Idle
A/D conversion 2
Idle
ADDRA
Read conversion result*
ADDRB
A/D conversion result 1
Read conversion result*
A/D conversion result 2
ADDRC
ADDRD
Note: * Vertical arrows ( ) indicate instructions executed by software.
Figure 15.3 A/D Conversion Timing (Single-Chip Mode, Channel 1 Selected)
15.5.2
Scan Mode
In scan mode, A/D conversion is to be performed sequentially on the specified channels (four
channels maximum). The operations are as follows.
1. When the ADST bit is set to 1 by software, timer conversion start trigger, or external trigger
input, A/D conversion starts on the first channel in the group (AN0 when CH3 = 0 and CH2 =
0, AN4 when CH3 = 0 and CH2 = 1, AN8 when CH3 = 1 and CH2 = 0, or AN12 when CH3 =
1 and CH2 = 1).
2. When A/D conversion for each channel is completed, the result is sequentially transferred to
the A/D data register corresponding to each channel.
3. When conversion of all the selected channels is completed, the ADF flag is set to 1. If the
ADIE bit is set to 1 at this time, an ADI interrupt is requested after A/D conversion ends.
Conversion of the first channel in the group starts again.
4. Steps 2 to 3 are repeated as long as the ADST bit remains set to 1. When the ADST bit is
cleared to 0, A/D conversion stops and the A/D converter enters the wait state. After that,
when the ADST bit is set to 1, conversion of the first channel in the group starts again.
Rev. 6.00 Sep. 24, 2009 Page 523 of 928
REJ09B0099-0600
Section 15 A/D Converter
Continuous A/D conversion execution
Clear*1
Set*1
ADST
Clear*1
ADF
A/D conversion time
State of
channel 0 (AN0)
State of
channel 1 (AN1)
State of
channel 2 (AN2)
Idle
Idle
A/D conversion 1
Idle
A/D conversion 2
Idle
Idle
State of
channel 3 (AN3)
ADDRA
Idle
A/D conversion 4
A/D conversion 5*2
Idle
Idle
A/D conversion 3
Idle
Transfer
A/D conversion result 1
ADDRB
ADDRC
A/D conversion result 4
A/D conversion result 2
A/D conversion result 3
ADDRD
Notes: 1. Vertical arrows ( ) indicate instructions executed by software.
2. Data currently being converted is ignored.
Figure 15.4 A/D Conversion Timing (Scan Mode, Channels AN0 to AN2 Selected)
15.5.3
Input Sampling and A/D Conversion Time
The A/D converter has a built-in sample-and-hold circuit. The A/D converter samples the analog
input when the A/D conversion start delay time (tD) has passed after the ADST bit is set to 1, then
starts conversion. Figure 15.5 shows the A/D conversion timing. Table 15.3 shows the A/D
conversion time.
As indicated in figure 15.5, the A/D conversion time (tCONV) includes tD and the input sampling time
(tSPL). The length of tD varies depending on the timing of the write access to ADCSR. The total
conversion time therefore varies within the ranges indicated in table 15.3. Specify the conversion
time by setting bits CKS0 and CKS1 in ADCR with ADST cleared to 0. Note that the specified
conversion time should be longer than the value described in section 24.5 A/D Conversion
Characteristics.
In scan mode, the values given in table 15.3 apply to the first conversion time. The values given in
table 15.4 apply to the second and subsequent conversions.
Rev. 6.00 Sep. 24, 2009 Page 524 of 928
REJ09B0099-0600
Section 15 A/D Converter
(1)
φ
Address
(2)
Write signal
Input sampling
timing
ADF
tD
tSPL
tCONV
Legend:
(1)
: ADCSR write cycle
(2)
: ADCSR address
: A/D conversion start delay
tD
tSPL : Input sampling time
tCONV : A/D conversion time
Figure 15.5 A/D Conversion Timing
Table 15.3 A/D Conversion Time (Single Mode)
CKS1 = 0
CKS0 = 0
CKS1 = 1
CKS0 = 1
CKS0 = 0
CKS0 = 1
Min. Typ. Max.
Min. Typ. Max.
Min. Typ. Max.
Item
Symbol Min. Typ. Max.
A/D conversion
start delay time
tD
18
⎯
33
10
⎯
17
6
⎯
9
4
⎯
5
Input sampling
time
tSPL
⎯
127
⎯
⎯
63
⎯
⎯
31
⎯
⎯
15
⎯
A/D conversion
time
tCONV
515
⎯
530
259 ⎯
266
131
⎯
134
67
⎯
68
Note:
All values represent the number of states.
Rev. 6.00 Sep. 24, 2009 Page 525 of 928
REJ09B0099-0600
Section 15 A/D Converter
Table 15.4 A/D Conversion Time (Scan Mode)
CKS1
CKS0
Conversion Time (State)
0
0
512 (Fixed)
1
256 (Fixed)
0
128 (Fixed)
1
64 (Fixed)
1
15.5.4
External Trigger Input Timing
A/D conversion can be externally triggered. When the TRGS0 and TRGS1 bits are set to 1 in
ADCR, external trigger input is enabled at the ADTRG pin. A falling edge at the ADTRG pin sets
the ADST bit to 1 in ADCSR, starting A/D conversion. Other operations, in both single and scan
modes, are the same as when the bit ADST has been set to 1 by software. Figure 15.6 shows the
timing.
φ
ADTRG
Internal trigger signal
ADST
A/D conversion
Figure 15.6 External Trigger Input Timing
Rev. 6.00 Sep. 24, 2009 Page 526 of 928
REJ09B0099-0600
Section 15 A/D Converter
15.6
Interrupt Source
The A/D converter generates an A/D conversion end interrupt (ADI) at the end of A/D conversion.
Setting the ADIE bit to 1 enables ADI interrupt requests while the ADF bit in ADCSR is set to 1
after A/D conversion is completed. The data transfer controller (DTC) can be activated by an ADI
interrupt. Having the converted data read by the DTC in response to an ADI interrupt enables
continuous conversion without imposing a load on software.
Table 15.5 A/D Converter Interrupt Source
Name
Interrupt Source
Interrupt Flag
DTC Activation
ADI
A/D conversion end
ADF
Possible
15.7
A/D Conversion Accuracy Definitions
This LSI's A/D conversion accuracy definitions are given below.
• Resolution
The number of A/D converter digital output codes
• Quantization error
The deviation inherent in the A/D converter, given by 1/2 LSB (see figure 15.7).
• Offset error
The deviation of the analog input voltage value from the ideal A/D conversion characteristic
when the digital output changes from the minimum voltage value B'0000000000 (H'000) to
B'0000000001 (H'001) (see figure 15.8).
• Full-scale error
The deviation of the analog input voltage value from the ideal A/D conversion characteristic
when the digital output changes from B'1111111110 (H'3FE) to B'1111111111 (H'3FF) (see
figure 15.8).
• Nonlinearity error
The error with respect to the ideal A/D conversion characteristic between zero voltage and fullscale voltage. Does not include offset error, full-scale error, or quantization error (see figure
15.8).
• Absolute accuracy
The deviation between the digital value and the analog input value. Includes offset error, fullscale error, quantization error, and nonlinearity error.
Rev. 6.00 Sep. 24, 2009 Page 527 of 928
REJ09B0099-0600
Section 15 A/D Converter
Digital output
Ideal A/D conversion
characteristic
111
110
101
100
011
010
Quantization error
001
000
1
2
1024 1024
1022 1023 FS
1024 1024
Analog
input voltage
Figure 15.7 A/D Conversion Accuracy Definitions
Full-scale error
Digital output
Ideal A/D conversion
characteristic
Nonlinearity
error
Actual A/D conversion
characteristic
Offset error
FS
Analog
input voltage
Figure 15.8 A/D Conversion Accuracy Definitions
Rev. 6.00 Sep. 24, 2009 Page 528 of 928
REJ09B0099-0600
Section 15 A/D Converter
15.8
Usage Notes
15.8.1
Module Stop Mode Setting
Operation of the A/D converter can be disabled or enabled using the module stop control register.
The initial setting is for operation of the A/D converter to be halted. Register access is enabled by
clearing module stop mode. For details, see section 22, Power-Down Modes.
15.8.2
Permissible Signal Source Impedance
This LSI's analog input is designed such that conversion accuracy is guaranteed for an input signal
for which the signal source impedance is 5 kΩ or less. This specification is provided to enable the
A/D converter's sample-and-hold circuit input capacitance to be charged within the sampling time;
if the sensor output impedance exceeds 5 kΩ, charging may be insufficient and it may not be
possible to guarantee A/D conversion accuracy. However, for A/D conversion in single mode with
a large capacitance provided externally, the input load will essentially comprise only the internal
input resistance of 10 kΩ, and the signal source impedance is ignored. However, as a low-pass
filter effect is obtained in this case, it may not be possible to follow an analog signal with a large
differential coefficient (e.g., 5 mV/μs or greater) (see figure 15.9). When converting a high-speed
analog signal, a low-impedance buffer should be inserted.
15.8.3
Influences on Absolute Accuracy
Adding capacitance results in coupling with GND, and therefore noise in GND may adversely
affect absolute accuracy. Be sure to make the connection to an electrically stable GND such as
AVss.
Care is also required to insure that filter circuits do not communicate with digital signals on the
mounting board (i.e., acting as antennas).
Rev. 6.00 Sep. 24, 2009 Page 529 of 928
REJ09B0099-0600
Section 15 A/D Converter
This LSI
Sensor input
impedance
to 5 k Ω
A/D converter
equivalent circuit
10 kΩ
Sensor input
Low-pass
filter
C to 0.1 μF
Cin =
15 pF
20 pF
Figure 15.9 Example of Analog Input Circuit
15.8.4
Range of Analog Power Supply and Other Pin Settings
If the conditions below are not met, the reliability of the device may be adversely affected.
• Analog input voltage range
The voltage applied to analog input pin ANn during A/D conversion should be in the range
AVss ≤ ANn ≤ AVcc.
• Relationship between AVcc, AVss and Vcc, Vss
Set AVss = Vss as the relationship between AVcc, AVss and Vcc, Vss. If the A/D converter is
not used, the AVcc and AVss pins must not be left open.
• Vref range
The reference voltage input from the Vref pin should be set to AVcc or less.
15.8.5
Notes on Board Design
In board design, digital circuitry and analog circuitry should be as mutually isolated as possible,
and layout in which digital circuit signal lines and analog circuit signal lines cross or are in close
proximity should be avoided as far as possible. Failure to do so may result in incorrect operation
of the analog circuitry due to inductance, adversely affecting A/D conversion values. Also, digital
circuitry must be isolated from the analog input signals (AN0 to AN15), and analog power supply
(AVcc) by the analog ground (AVss). Also, the analog ground (AVss) should be connected at one
point to a stable digital ground (Vss) on the board.
15.8.6
Notes on Noise Countermeasures
A protection circuit should be connected in order to prevent damage due to abnormal voltage, such
as an excessive surge at the analog input pins (AN0 to AN15), between AVcc and AVss, as shown
Rev. 6.00 Sep. 24, 2009 Page 530 of 928
REJ09B0099-0600
Section 15 A/D Converter
in figure 15.10. Also, the bypass capacitors connected to AVcc and the filter capacitor connected
to AN0 to AN15 must be connected to AVss.
If a filter capacitor is connected, the input currents at the analog input pins (AN0 to AN15) are
averaged, and so an error may arise. Also, when A/D conversion is performed frequently, as in
scan mode, if the current charged and discharged by the capacitance of the sample-and-hold circuit
in the A/D converter exceeds the current input via the input impedance (Rin), an error will arise in
the analog input pin voltage. Careful consideration is therefore required when deciding circuit
constants.
AVCC
Vref
Rin *2
*1
100 Ω
AN0 to AN15
*1
0.1 µF
AVSS
Notes: Values are reference values.
1.
10 µF
0.01 µF
2 Rin: Input Impedance
Figure 15.10 Example of Analog Input Protection Circuit
Table 15.6 Analog Pin Specifications
Item
Min.
Max.
Unit
Analog input capacitance
⎯
20
pF
Permissible signal source impedance
⎯
5
kΩ
Rev. 6.00 Sep. 24, 2009 Page 531 of 928
REJ09B0099-0600
Section 15 A/D Converter
10 kΩ
AN0 to AN15
To A/D converter
20 pF
Note: Values are reference values.
Figure 15.11 Analog Input Pin Equivalent Circuit
Rev. 6.00 Sep. 24, 2009 Page 532 of 928
REJ09B0099-0600
Section 16 D/A Converter
Section 16 D/A Converter
16.1
8-bit resolution
Two output channels
Conversion time: 10 µs, maximum (when load capacitance is 20 pF)
Output voltage: 0 V to Vref
Module stop mode can be set
Module data bus
Bus interface
Internal data bus
Vref
8-bit D/A
DACR
DA1
DADR1
AVCC
DADR0
•
•
•
•
•
Features
DA0
AVSS
Control circuit
Legend:
DACR : D/A control register
DADR0: D/A data register 0
DADR1: D/A data register 1
Figure 16.1 Block Diagram of D/A Converter
Rev. 6.00 Sep. 24, 2009 Page 533 of 928
REJ09B0099-0600
Section 16 D/A Converter
16.2
Input/Output Pins
Table 16.1 shows the pin configuration for the D/A converter.
Table 16.1 Pin Configuration
Pin Name
Symbol
I/O
Function
Analog power supply pin
AVCC
Input
Analog block power supply
Analog ground pin
AVSS
Input
Analog block ground and reference voltage
Analog output pin 0
DA0
Output
Channel 0 analog output pin
Analog output pin 1
DA1
Output
Channel 1 analog output pin
Reference voltage pin
Vref
Input
Analog block reference voltage
16.3
Register Descriptions
The D/A converter has the following registers. For details on the module stop control register, see
section 22.1.2, Module Stop Control Registers A to C (MSTPCRA to MSTPCRC).
• D/A data register 0 (DADR0)
• D/A data register 1 (DADR1)
• D/A control register (DACR)
16.3.1
D/A Data Registers 0, 1 (DADR0, DADR1)
DADR0 and DADR1 are 8-bit readable/writable registers that store data for D/A conversion.
When analog output is permitted, D/A data register contents are converted and output to analog
output pins.
Rev. 6.00 Sep. 24, 2009 Page 534 of 928
REJ09B0099-0600
Section 16 D/A Converter
16.3.2
D/A Control Register (DACR)
DACR controls D/A converter operation.
Bit
Bit Name
Initial
Value
R/W
Description
7
DAOE1
0
R/W
D/A Output Enable 1
Controls D/A conversion and analog output
0: Analog output DA1 is disabled
1: D/A conversion for channel 1 and analog output DA1
are enabled
6
DAOE0
0
R/W
D/A Output Enable 0
Controls D/A conversion and analog output
0: Analog output DA0 is disabled
1: D/A conversion for channel 0 and analog output DA0
are enabled
5
DAE
0
R/W
D/A Enable
Controls D/A conversion in conjunction with the DAOE0
and DAOE1 bits. When the DAE bit is cleared to 0, D/A
conversion for channels 0 and 1 are controlled
individually. When DAE is set to 1, D/A conversion for
channels 0 and 1 are controlled as one. Conversion
result output is controlled by the DAOE0 and DAOE1
bits. For details, see table 16.2.
4 to 0
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
Rev. 6.00 Sep. 24, 2009 Page 535 of 928
REJ09B0099-0600
Section 16 D/A Converter
Table 16.2 D/A Conversion Control
Bit 5
Bit 7
Bit 6
DAE
DAOE1
DAOE0
0
0
1
1
0
1
Description
0
Disables D/A Conversion
1
Enables D/A Conversion for channel 0
0
Enables D/A Conversion for channel 1
1
Enables D/A Conversion for channels 0 and 1
0
Disables D/A Conversion
1
Enables D/A Conversion for channels 0 and 1
0
1
16.4
Operation
Two channels of the D/A converter can perform conversion individually.
When the DAOE bit in DACR is set to 1, D/A conversion is enabled and the conversion results are
output.
An example of D/A conversion of channel 0 is shown below. The operation timing is shown in
figure 16.2.
1. Write conversion data to DADR0.
2. When the DAOE0 bit in DACR is set to 1, D/A conversion starts. After the interval of tDCONV,
the conversion results are output from the analog output pin DA0. The conversion results are
output continuously until DADR0 is modified or DAOE0 bit is cleared to 0. The output value
is calculated by the following formula:
(DADR contents)/256 × Vref
3. Conversion starts immediately after DADR0 is modified. After the interval of tDCONV,
conversion results are output.
4. When the DAOE bit is cleared to 0, analog output is disabled.
Rev. 6.00 Sep. 24, 2009 Page 536 of 928
REJ09B0099-0600
Section 16 D/A Converter
DADR0
write cycle
DACR
write cycle
DADR0
write cycle
DACR
write cycle
φ
ADRES
Conversion data (1)
DADR0
Conversion data (2)
DAOE0
Conversion result (2)
Conversion result (1)
DA0
High impedance state
tDCONV
tDCONV
Legend:
tDCONV: D/A conversion time
Figure 16.2 D/A Converter Operation Example
16.5
Usage Notes
16.5.1
Analog Power Supply Current in Power-Down Mode
If this LSI enters a power-down mode such as software standby, watch, and module stop modes
while D/A conversion is enabled, the D/A cannot retain analog outputs within the given D/A
absolute accuracy although it retains digital values. The analog power supply current is
approximately the same as that during D/A conversion. To reduce analog power supply current in
power-down mode, clear the DAOE0, DAOE1 and DAE bits to 0 to disable D/A outputs before
entering the mode.
16.5.2
Setting for Module Stop Mode
It is possible to enable/disable the D/A converter operation using the module stop control register,
the D/A converter does not operate by the initial value of the register. The register can be accessed
by releasing the module stop mode. For more details, see section 22, Power-Down Modes.
Rev. 6.00 Sep. 24, 2009 Page 537 of 928
REJ09B0099-0600
Section 16 D/A Converter
Rev. 6.00 Sep. 24, 2009 Page 538 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
This LSI has an on-chip one-channel IEBus controller (IEB). The Inter Equipment Bus™
(IEBus™)*1 is a small-scaled digital data transfer system for inter equipment data transfer.
This LSI does not have an on-chip IEBus driver/receiver, so it is necessary to mount a dedicated
driver/receiver*2 externally.
Notes: 1. IEBus is a trademark of NEC Electronics Corporation.
2. Bus interface driver/receiver IC: HA12187FP is recommended.
17.1
Features
• IEBus protocol control (layer 2) supported
⎯ Half duplex asynchronous communications
⎯ Multi-master system
⎯ Broadcast communications function
⎯ Selectable mode (three types) with different transfer speeds
• Data transfer by the data transfer controller (DTC)
⎯ Transfer buffer: 1 byte
⎯ Reception buffer: 1 byte
⎯ Up to 128 bytes of consecutive transfer/reception (maximum number of transfer bytes in
mode 2)
• Operating frequency
⎯ 12 MHz, 12.58 MHz (IEB uses 1/2 divided external clock.)
⎯ 18 MHz, 18.87 MHz (IEB uses 1/3 divided external clock.)
⎯ 24 MHz, 25.16 MHz (IEB uses 1/4 divided external clock.)
Note: When selected communications mode 0 or mode 1 (± 1.5 %)
When selected communications mode 2 (± 0.5 %)
• Noise resistance is improved by mounting the IEBus driver/receiver (layer 1) externally.
• Module stop mode can be set.
Rev. 6.00 Sep. 24, 2009 Page 539 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Figure 17.1 shows an IEB block diagram.
Tx
Signal
polarity
select
circuit
Bit timing set/
detect circuit
Rx
Transmission block
IEBus
driver/receiver
Conflict
detect
circuit
Parity
generation
circuit
Parity
check
circuit
Transmit shift register
IEAR1
IEAR2
IESA1
IESA2
IEMCR
IETBFL
Reception block
IETBR
Receive shift register
IEMA1
IEMA2
IERBFL
IERBR
IELA1
Data link layer control block
IELA2
IECMR
IECTR
Status/interrupt control block
IETXI
(TxRDY interrupt)
IETSI
(Tx status interrupt)
IETSR
IERXI
(RxRDY interrupt)
IERSI
(Rx status interrupt)
IERSR
IEIET
IETEF
IEIER
IEREF
Figure 17.1 Block Diagram of IEB
Rev. 6.00 Sep. 24, 2009 Page 540 of 928
REJ09B0099-0600
Internal data bus
IERCTL
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.1.1
IEBus Communications Protocol
The overview of the IEBus is described below.
• Communications method: Half duplex asynchronous communications
• Multi-master system
All units connected to the IEBus can transfer data to other units.
• Broadcast communications function (one-to-many communications)
⎯ Group broadcast communications: Broadcast communications to group unit
⎯ General broadcast communications: Broadcast communications to all units
• Mode is selectable (three modes with different transfer speeds).
Table 17.1 Mode Types
Mode
φ = 12, 18, 24 MHz
φ = 12.58, 18.87, 25.16 MHz
Maximum Number Of
Transfer Bytes (byte/frame)
0
About 3.9 kbps
About 4.1 kbps
16
1
About 17 kbps
About 18 kbps
32
2
About 26 kbps
About 27 kbps
128
• Access control: CSMA/CD (Carrier Sense Multiple Access with Collision Detection)
Priority of bus mastership is as follows.
⎯ Broadcast communications (one-to-many communications) have priority rather than
normal communications (one-to-one communications).
⎯ Smaller master address has priority.
• Communications scale
⎯ Number of units: Up to 50
⎯ Cable length: Up to 150 m (when using a twisted pair cable)
Note: The communications scale of the actual system depends on the externally mounted IEBus
driver/receiver characteristics and the characteristics of the cable to be used.
(1)
Determination of Bus Mastership (Arbitration)
A unit connected to the IEBus performs an operation for getting the bus to control other units.
This operation is called arbitration. In arbitration, when the multiple units start transfer
simultaneously, the bus mastership is given to one unit among them.
Rev. 6.00 Sep. 24, 2009 Page 541 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Only one unit can get bus mastership through arbitration, so the following priority for bus
mastership is defined.
(a) Priority according to communications type
Broadcast communications (one-to-many communications) has priority over normal
communications (one-to-one communications).
(b) Priority according to master address
A unit with the smallest master address has priority among units with the same
communications type.
Example: The master address is configured with 12 bits. A unit with H'000 has the highest
priority, and a unit with H'FFF has the lowest priority.
Note: When a unit loses arbitration, the unit can automatically enter retransfer mode (0 to 7
retransfer times can be selected by bits RN2 to RN0 in IEMCR).
(2) Communications Mode
The IEBus has three communications modes with different transfer speeds. Table 17.2 shows the
transfer speed in each communications mode and the maximum number of transfer bytes in one
communications frame.
Table 17.2 Transfer speed and Maximum Number of Transfer Bytes in Each
Communications Mode
Effective Transfer Speed*1 (kbps)
Maximum Number
Communications of Transfer Bytes
Mode
(byte/frame)
φ = 12, 18, 24 MHz*
0
16
About 3.9
About 4.1
1
32
About 17
About 18
128
About 26
About 27
2
Notes:
2
φ = 12.58, 18.87, 25.16 MHz*2
Each unit connected to the IEBus should select a communications mode prior to
performing communications. Note that correct communications is not guaranteed if the
master and slave units do not adopt the same communications mode.
In the case of communications between a unit with φ = 12 MHz and a unit with φ =
12.58 MHz, correct communications is not possible even if the same communications
mode is adopted. This is similar to the case of communications between a unit with φ =
24 MHz and a unit with φ = 25.16 MHz, or between a unit with φ = 18 MHz and a unit
with φ = 18.87 MHz. Communications must be performed at the same oscillation
frequency.
1. An effective transfer speed when the maximum number of transfer bytes is transmitted.
2. Oscillation frequency when this LSI is used
Rev. 6.00 Sep. 24, 2009 Page 542 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
(3)
Communications Address
In the IEBus, a 12-bit specific communications addresses are allocated to individual units. A
communications address is configured as follows.
• Upper four bits: group number (number identifying a group to which the unit belongs)
• Lower eight bits: unit number (number identifying individual units in a group)
(4)
Broadcast Communications
In normal transfer, a single master unit communicates with a single slave unit. So, one-to-one
transfer or reception is performed. In broadcast communications, a single master unit
communicates with multiple slave units. Since there are multiple slave units, acknowledgement is
not returned from the slave units during communications.
A broadcast bit decides whether broadcast or normal communications is performed. (For details of
the broadcast bit, see section 17.1.2 (1) (b), Broadcast Bit.
There are two types of broadcast communications.
(a) Group broadcast communications
Broadcast communications is performed to units with the same group number, meaning that
those units have the same upper four bits of the communications address.
(b) General broadcast communications
Broadcast communications is performed to all units regardless of the group number.
Group broadcast and general broadcast communications are identified by a slave address. (For
details on the slave address, see section 17.1.2 (3), Slave Address Field.)
17.1.2
Communications Protocol
Figure 17.2 shows an IEBus transfer signal format.
Communications data is transferred as a series of signals referred to as a communications frame.
The number of data which can be transmitted in a single communications frame and the transfer
speed differ according to communications mode.
Rev. 6.00 Sep. 24, 2009 Page 543 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
(When φ = 12, 18, or 24MHz)
Field name
Number
of bits
Header
1
1
Master
Slave address
address field
field
12
1
12
1 1
Start Broad- Master
bit cast address
bit
P
Slave
address
P A
Control field
4
Control
bits
1
1
P A
Message
length field
8
1 1
Message
length
bits
P A
Data field
8
1
Data
bits
1
P A
8
Data
bits
1
1
P A
Transfer
time
Mode 0
Approximately 7330 μs
Approximately 1590 × N μs
Mode 1
Approximately 2090 μs
Approximately 410 × N μs
Mode 2
Approximately 1590 μs
Approximately 300 × N μs
P: Parity bit (1 bit)
A: Acknowledge bit (1 bit)
When A = 0: ACK
When A = 1: NAK
N: Number of bytes
Note: The value of acknowledge bit is ignored in broadcast communications.
Figure 17.2 Transfer Signal Format
(1)
Header
Header is comprised of a start bit and a broadcast bit.
(a) Start Bit
The start bit is a signal for informing a start of data transfer to other units. A unit, which
attempts to start data transfer, outputs a low-level signal (start bit) for a specified period and
then outputs the broadcast bit.
If another unit is already outputting a start bit when a unit attempts to output a start bit, the unit
waits for completion of output of the start bit from the other unit without outputting the start
bit, and then outputs the broadcast bit synchronized with the completion timing.
Other units enter the receive state after detecting the start bit.
(b) Broadcast Bit
The broadcast bit is a bit to identify the type of communications: broadcast or normal.
When this bit is cleared to 0, it indicates the broadcast communications. When it is set to 1, it
indicates the normal communications. Broadcast communications includes group broadcast
and general broadcast, which are identified by a value of the slave address. (For details of the
slave address, see section 17.1.2 (3), Slave Address Field.)
Since there are multiple slave units, which are communications destination units, in the case of
broadcast communications, the acknowledge bit is not returned from each field described in (b)
and below.
Rev. 6.00 Sep. 24, 2009 Page 544 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
When more than one unit starts transfer of communications frame at the same timing,
broadcast communications has priority over normal communications, and arbitration occurs.
(2)
Master Address Field
The master address field is a field for transmitting the unit address (master address) to other units.
The master address field is comprised of master address bits and a parity bit.
The master address has 12 bits and are output MSB first.
When more than one unit starts transfer of the broadcast bit having the same value at the same
timing, arbitration is decided by the master address field.
In the master address field, self-output data and data on the bus are compared for every one-bit
transfer. If the self-output master address and data on the bus are different, the unit that loses
arbitration, stops transfer, and enters the receive state.
Since the IEBus is configured with wired AND, a unit having the smallest master address of the
units in arbitration (arbitration master) wins in arbitration.
Finally, only a single unit remains in the transfer state as a master unit after outputting 12-bit
master address.
Next, this master unit outputs a parity bit*, defines the master address to other units, and then
enters the slave address field output state.
Note: Since even parity is used, when the number of one bits in the master address is odd, the
parity bit is 1.
(3)
Slave Address Field
The slave address field is a field to transmit an address (slave address) of a unit (slave unit) to
which a master transmit data. The slave address field is comprised of slave address bits, a parity
bit, and an acknowledge bit.
The slave address has 12 bits and is output MSB first. The parity bit is output after the 12-bit slave
address is transmitted in order to avoid receiving the slave address accidentally. The master unit
then detects the acknowledgement from the slave unit in order to confirm that the slave unit exists
on the bus. When the acknowledgement is detected, the master unit enters the control field output
state. However, the master unit enters the control field output state without detecting the
acknowledgement in broadcast communications.
Rev. 6.00 Sep. 24, 2009 Page 545 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
The slave unit returns the acknowledgement when the slave addresses match and the parities of the
master and slave addresses are correct. When either of the parities of the master and slave
addresses is wrong, the slave unit decides that the master or slave address is not correctly received
and does not return the acknowledgement. In this case, the master unit enters the waiting (monitor)
state, and communications end.
In the case of broadcast communications, the slave address is used to identify the type of broadcast
communications (group or general) as follows:
• When the slave address is H'FFF: General broadcast communications
• When the slave address is other than H'FFF: Group broadcast communications
Note: The group number is the upper 4-bit value of the slave address in group broadcast
communications.
(4)
Control Field
The control field is a field for transmitting the type and direction of the following data field. The
control field is comprised of control bits, a parity bit, and an acknowledge bit.
The control bits include four bits and are output MSB first.
The parity bit is output following the control bits. When the parity is correct, and the slave unit
can implement the function required from the master unit, the slave unit returns the
acknowledgement and enters the message length field output state. However, if the slave unit
cannot implement the requirements from the master unit even though the parity is correct, or if the
parity is not correct, the slave unit does not return the acknowledgement, and returns to the
waiting (monitor) state.
The master unit enters the subsequent message length field output state after confirming the
acknowledgement.
When the acknowledgement is not confirmed, the master unit enters the waiting (monitor) state,
and communications end. However, in the case of broadcast communications, the master unit
enters the following message length field output state without confirming the acknowledgement.
For details of the contents of the control bit, see table 17.4.
(5)
Message Length Field
The message length field is a field for specifying the number of transfer bytes. The message length
field is comprised of message length bits, a parity bit, and an acknowledge bit.
Rev. 6.00 Sep. 24, 2009 Page 546 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
The message length has eight bits and is output MSB first. Table 17.3 shows the number of
transfer bytes.
Table 17.3 Contents of Message Length bits
Message Length bits (Hexadecimal)
Number of Transfer Bytes
H'01
1 byte
H'02
2 bytes
.
.
.
.
H'FF
255 bytes
H'00
256 bytes
Note:
*
If a number greater than the maximum number of transfer bytes in one frame is
specified, communications are performed in multiple frames depending on the
communications mode. In this case, the message length bits indicate the number of
remaining communications data after the first transfer. In this LSI, after the first transfer,
the message length bits must be specified to the number of remaining communications
data by a program, since these bits are not automatically specified by the hardware.
This field operation differs depending on the value of bit 3 in the control field: master
transmission (bit 3 in the control bits is 1) or master reception (bit 3 in the control bits is 0).
(a) Master Transmission
The master unit outputs the message length bits and parity bit. When the parity is correct, the
slave unit returns the acknowledgement and enters the following data field. Note that the slave
unit does not return the acknowledgement in broadcast communications.
In addition, when the parity is not correct, the slave unit decides that the message length field
is not correctly received, does not return the acknowledgement, and returns to the waiting
(monitor) state. In this case, the master unit also returns to the waiting state, and
communications end.
(b) Master Reception
The slave unit outputs the message length bits and parity bit. When the parity is correct, the
master unit returns the acknowledgement.
When the parity is not correct, the master unit decides that the message length bits are not
correctly received, does not return the acknowledgement, and returns to the waiting state. In
this case, the slave unit also returns to the waiting state, and communications end.
Rev. 6.00 Sep. 24, 2009 Page 547 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
(6)
Data Field
The data field is a field for data transmission/reception to the slave unit. The master unit
transmits/receives data to/from the slave unit using the data field. The data field is comprised of
data bits, a parity bit, and an acknowledge bit.
The data bits include eight bits and are output MSB first.
The parity bit and acknowledge bit following the data bits are output from the master unit and
slave unit, respectively.
Broadcast communications are performed only for the transmission of the master unit. In this case,
the acknowledge bit is ignored. Operations in master transmission and master reception are
described below.
(a) Master Transmission
The master unit transmits the data bits and parity bit to the slave unit to write data from the
master unit to the slave unit. The slave unit receives the data bits and parity bit, and returns the
acknowledgement if the parity bit is correct and the receive buffer is empty. If the parity bit is
not correct or the receive buffer is not empty, the slave unit rejects acceptance of
corresponding data and does not return the acknowledgement.
When the slave unit does not return the acknowledgement, the master unit retransmits the same
data. This operation is repeated until either the acknowledgement from the slave unit is
detected or the maximum number of data transfer bytes is exceeded.
When the parity is correct and the acknowledgement is output from the slave unit, the master
unit transmits the subsequent data if data remains and the maximum number of transfer bytes
is not exceeded.
In the case of broadcast communications, the slave unit does not return the acknowledgement,
and the master unit transfers data byte by byte.
(b) Master Reception
The master unit outputs synchronous signals corresponding to all data bits to be read from the
slave unit.
The slave unit outputs the data bits and parity bit on the bus in accordance with the
synchronous signals from the master unit.
Rev. 6.00 Sep. 24, 2009 Page 548 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
The master unit reads the parity bit output from the slave unit, and checks the parity. If the
parity is not correct, or the receive buffer is not empty, the master unit rejects acceptance of the
data, and does not return the acknowledgement. The master unit reads the same data repeatedly
if the number of data does not exceed the maximum number of transfer bytes in one frame. If
the parity is correct and the receive buffer is empty, the master unit accepts data and returns the
acknowledgement. The master unit reads in the subsequent data if the number of data does not
exceed the maximum number of transfer bytes in one frame.
(7)
Parity bit
The parity bit is used to confirm that transfer data has no error.
The parity bit is added to respective data of the master address, slave address, control, message
length, and data bits.
The even parity is used. When the number of one bits in data is odd, the parity bit is 1. When the
number of one bits in data is even, the parity bit is 0.
(8)
Acknowledge bit
In normal communications (a single unit to a single unit communications), the acknowledge bit is
added to the following position in order to confirm that data is correctly accepted.
•
•
•
•
At the end of the slave address field
At the end of the control field
At the end of the message length field
At the end of the data field
The acknowledge bit is defined below.
• 0: indicates that the transfer data is acknowledged. (ACK)
• 1: indicates that the transfer data is not acknowledged. (NAK)
Note that the acknowledge bit is ignored in the case of broadcast communications.
(a) Acknowledge bit at the End of the Slave Address Field
The acknowledge bit at the end of the slave address field becomes NAK in the following cases
and transfer is stopped.
⎯ When the parity of the master address or slave address bits is incorrect
⎯ When a timing error (an error in bit format) occurs
⎯ When there is no slave unit
Rev. 6.00 Sep. 24, 2009 Page 549 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
(b) Acknowledge bit at the End of the Control Field
The acknowledge bit at the end of the control field becomes NAK in the following cases and
transfer is stopped.
⎯ When the parity of the control bits is incorrect
⎯ When bit 3 in the control bits is 1 (data write) although the slave receive buffer* is not
empty
⎯ When the control bits are set to the data read (H'3, H'7) although the slave transmit buffer*
is empty
⎯ When another unit which locked the slave unit requests H'3, H'6, H'7, H'A, H'B, H'E, or
H'F in the control bits although the slave unit has been locked
⎯ When the control bits are the locked address read (H'4, H'5) although the unit is not locked
⎯ When a timing error occurs
⎯ When the control bits are undefined
Note: See section 17.1.3 (1), Slave Status Read (Control Bits: H'0, H'6).
(c) Acknowledge Bit at the End of the Message Length Field
The acknowledge bit at the end of the message length field becomes NAK in the following
cases and transfer is stopped.
⎯ When the parity of the message length bits is incorrect
⎯ When a timing error occurs
(d) Acknowledge Bit at the End of the Data Field
The acknowledge bit at the end of the data field becomes NAK in the following cases and
transfer is stopped.
⎯ When the parity of the data bits is incorrect*
⎯ When a timing error occurs after the previous transfer of the acknowledge bit
⎯ When the receive buffer becomes full and cannot accept further data
Note: In this case, data field is transferred repeatedly until the number of data reaches the
maximum number of transfer bytes if the number of data does not exceed the maximum
number of transfer bytes in one frame.
Rev. 6.00 Sep. 24, 2009 Page 550 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.1.3
Transfer Data (Data Field Contents)
The data filed contents are specified by the control bits.
Table 17.4 Control Bit Contents
Setting
Value
Bit 3*1
Bit 2
Bit 1
Bit 0
Function*2
H'0
0
0
0
0
Reads slave status (SSR)
H'1
0
0
0
1
Undefined. Setting prohibited.
H'2
0
0
1
0
Undefined. Setting prohibited.
H'3
0
0
1
1
Reads data and locks
H'4
0
1
0
0
Reads locked address (lower 8 bits)
H'5
0
1
0
1
Reads locked address (upper 4 bits)
H'6
0
1
1
0
Reads slave status (SSR) and unlocks
H'7
0
1
1
1
Reads data
H'8
1
0
0
0
Undefined. Setting prohibited.
H'9
1
0
0
1
Undefined. Setting prohibited.
H'A
1
0
1
0
Writes command and locks
H'B
1
0
1
1
Writes data and locks
H'C
1
1
0
0
Undefined. Setting prohibited.
H'D
1
1
0
1
Undefined. Setting prohibited.
H'E
1
1
1
0
Writes command
H'F
1
1
1
1
Writes data
Notes: 1. According to the value of bit 3 (MSB), the transfer directions of the message length bits
in the following message length field and data in the data field vary.
When bit 3 is 1: Data is transferred from the master unit to the slave unit.
When bit 3 is 0: Data is transferred from the slave unit to the master unit.
2. H'3, H'6, H'A, and H'B are control bits to specify lock setting and cancellation.
When the undefined values of H'1, H'2, H'8, H'9, H'C, and H'D are transmitted, the
acknowledge bit is not returned.
When the control bits received from another unit which locked are not included in table 17.5, the
slave unit which has been locked by the master unit rejects acceptance of the control bits and does
not return the acknowledge bit.
Rev. 6.00 Sep. 24, 2009 Page 551 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Table 17.5 Control Field for Locked Slave Unit
Setting
Value
Bit 3
Bit 2
Bit 1
Bit 0
Function
H'0
0
0
0
0
Reads slave status
H'4
0
1
0
0
Reads locked address (upper 8 bits)
H'5
0
1
0
1
Reads locked address (lower 4 bits)
(1)
Slave Status Read (Control Bits: H'0, H'6)
The master unit can decide the reason the slave unit does not return the acknowledgement (ACK)
by reading the slave status (H'0, H'6). The slave status indicates the result of the last
communications that the slave unit performs. All slave units can provide slave status information.
Figure 17.3 shows bit configuration of the slave status.
Rev. 6.00 Sep. 24, 2009 Page 552 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
MSB
LSB
Bit 7
Bit 6
Bit 5
Bit 4
Bit
Value Description
Bit 7,
00
Mode 0
bit 6
01
Mode 1
10
Mode 2
Bit 3
Bit 2
Bit 1
Indicates the highest mode
supported by a unit. *1
11
For future use
Bit 5
0
Fixed 0
Bit 4*2
0
Slave transmission halted
1
Slave transmission enabled
Bit 3
0
Fixed 0
Bit 2
0
Unit is unlocked
1
Unit is locked
0
Slave receive buffer is empty
1
Slave receive buffer is not empty
0
Slave transmit buffer is empty
1
Slave transmit buffer is not empty
Bit 1*3
Bit
0*4
Bit 0
Notes: 1. Since this LSI can support up to mode 2, bits 6 and 7 are fixed to 10.
2. The value of bit 4 can be selected by the STE bit in the IEBus master unit address register 1 (IEAR1).
3. The slave receive buffer is a buffer which is accessed during data write
(control bits: H'8, H'A, H'B, H'E, H'F).
In this LSI, the slave receive buffer corresponds to the IEBus receive buffer register (IERBR);
and bit 2 is the value of the RxRDY flag in the IEBus receive status register (IERSR).
4. The slave transmit buffer is a buffer which is accessed during data read
(control bits: H'3, H'7).
In this LSI, the slave transmit buffer corresponds to the IEBus transmit buffer register (IETBR)
when SRQ = 1 in the IEBus general flag register (IEFLG); and bit 1 is a value which reverses the
TxRDY flag in the IEBus transmit/runaway status register (IETSR).
Figure 17.3 Bit Configuration of Slave Status (SSR)
(2)
Data Command Transfer (Control Bits: Read (H'3, H'7), Write (H'A, H'B, H'E, H'F))
In the case of data read (H'3, H'7), data in the data buffer of the slave unit is read in the master
unit. In the case of data write (H'B or H'F) or command write (H'A or H'E), data received in the
slave unit is processed in accordance with the operation specification of the slave unit.
Notes: 1. The user can select data and commands freely in accordance with the system.
2. H'3, H'A, or H'B may lock depending on the communications condition and status.
(3)
Locked Address Read (Control Bits: H′4, H′5)
In the case of the locked address read (H'4 or H'5), the address (12 bits) of the master unit which
issues lock instruction is configured in bytes shown in figure 17.4.
Rev. 6.00 Sep. 24, 2009 Page 553 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
MSB
Control bits: H'4
Control bits: H'5
LSB
Lower 8 bits
Undefined
Upper 4 bits
Figure 17.4 Locked Address Configuration
(4)
Locking/Unlocking (Control Bits: Setting (H'3, H'A, HB), Cancellation: (H'6))
The lock function is used for message transfer over multiple communications frames. Locked unit
receives data only from the unit which has locked.
Locking and unlocking are described below.
• Locking
When the acknowledge bit of 0 in the message length field is transmitted/received with the
control bits indicating the lock operation, and then the communications frame is completed
before completion of data transmission/reception for the number of bytes specified by the
message length bits, the slave unit is locked by the master unit. In this case, the bit (bit 2)
relevant to lock in the byte data indicating the slave status is set to 1.
Lock is set only when the number of data exceeds the maximum number of transfer bytes in
one frame. Lock is not set by other error termination.
• Unlocking
When the control bits indicate the lock (H'3, H'A, or H'B) or unlock (H'6) operation and the
byte data for the number of bytes specified by the message length bits are transmitted/received
in a single communications frame, the slave unit is unlocked by the master unit. In this case, a
bit (bit 2) relevant to lock in the byte indicating the slave status is cleared to 0.
Note that locking and unlocking are not performed in broadcast communications.
Note: * There are three methods to unlock by a locked unit itself.
•
Perform hardware reset
•
Enter module stop mode
•
Issue unlock command by the IEBus command register (IECMR)
Rev. 6.00 Sep. 24, 2009 Page 554 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Note that the LCK flag in IEFLG can be used to check whether the unit is
locked/unlocked.
17.1.4
Bit Format
Figure 17.5 shows the bit format (conceptual diagram) configuring the IEBus communications
frame.
Logic 1
Logic 0
Preparation Synchronous
period
period
Data
period
Halt
period
Active low: Logic 1 = low level and logic 0 = high level
Active high: Logic 1 = high level and logic 0 = low level
Figure 17.5 IEBus Bit Format (Conceptual Diagram)
Each period of bit format for use of active high signals is described below.
•
•
•
•
Preparation period: first logic 1 period (high level)
Synchronous period: subsequent logic 0 period (low level)
Data period: period indicating bit value (logic 1: high level, logic 0: low level)
Halt period: last logic 1 cycle (high level)
For use of active low signals, levels are reversed from the active high signals.
The synchronous and data periods have approximately the same length.
The IEBus is synchronized bit by bit. The specifications for the time of all bits and the periods
allocated to the bits differ depending on the type of transfer bits and the unit (master or slave unit).
Rev. 6.00 Sep. 24, 2009 Page 555 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.2
Input/Output Pins
Table 17.6 shows the IEB pin configuration.
Table 17.6 Pin Configuration
Name
Abbreviation I/O
Function
IEBus transmit data pin
Tx
O
Transmit data output pin
IEBus receive data pin
Rx
I
Receive data input pin
17.3
Register Descriptions
The IEB has the following registers. For the module stop control register, see section 22.1.2,
Module Stop Control Registers A to C (MSTPCRA to MSTPCRC).
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
IEBus control register (IECTR)
IEBUS command register (IECMR)
IEBus master control register (IEMCR)
IEBus master unit address register 1 (IEAR1)
IEBus master unit address register 2 (IEAR2)
IEBus slave address setting register 1 (IESA1)
IEBus slave address setting register 2 (IESA2)
IEBus transmit message length register (IETBFL)
IEBus transmit buffer register (IETBR)
IEBus reception master address register 1 (IEMA1)
IEBus reception master address register 2 (IEMA2)
IEBus receive control field register (IERCTL)
IEBus receive message length register (IERBFL)
IEBus receive buffer register (IERBR)
IEBus lock address register 1 (IELA1)
IEBus lock address register 2 (IELA2)
IEBus general flag register (IEFLG)
IEBus transmit/runaway status register (IETSR)
IEBus transmit/runaway interrupt enable register (IEIET)
IEBus transmit error flag register (IETEF)
IEBus receive status register (IERSR)
Rev. 6.00 Sep. 24, 2009 Page 556 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
• IEBus receive interrupt enable register (IEIER)
• IEBus receive error flag register (IEREF)
17.3.1
IEBus Control Register (IECTR)
IECTR controls IEB operation (switches IEBus pin/port functions, selects input/output level, and
enables receive operation).
Bit
Bit Name
Initial
Value
R/W
Description
7
IEE
0
R/W
IEB Pin Switch
Switches IEB pin and port functions.
0: The PG3/Rx/CS1 and PG2/Tx/CS2 pins function as the
PG3/CS1 and PG2/CS2 pins.
1: The PG3/Rx/CS1 and PG2/Tx/CS2 pins function as the
Tx and Rx pins.
6
IOL
0
R/W
Input/Output Level
Selects input/output pin level (polarity) for the Rx and Tx
pins.
0: Pin input/output is set to active low. (Logic 1 is low level
and logic 0 is high level.)
1: Pin input/output is set to active high. (Logic 1 is high
level and logic 0 is low level.)
Rev. 6.00 Sep. 24, 2009 Page 557 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
5
DEE
0
R/W
Broadcast Receive Error Interrupt Enable
Since the acknowledgement is not returned between the
master and slave units in broadcast reception, the master
unit cannot decide whether the slave unit is in the receive
enabled state. If this bit is set to 1, a reception error
interrupt occurs (note that there is not the corresponding bit
in the IEBus receive error flag register to this error) when
the receive buffer is not in the receive enabled state during
receiving the control field in broadcast reception (when the
RE bit is not set to 1 or the RxRDY flag is set.). At this
time, the master address is stored in IEMA1 and IEMA2.
The receive data is not stored in IERCTL.
While this bit is 0, a reception error interrupt does not occur
when the receive buffer is not in the receive enabled state,
and the reception stops and enters the wait state. The
master address is not saved.
0: A broadcast receive error is not generated up to the
control field.
1: A broadcast receive error is generated up to the control
field.
4
CKS1
0
R/W
Input Clock Select
Selects clock used by the IEB. See table 17.7.
3
RE
0
R/W
Receive Enable
Enables/disables IEB reception. This bit must be set at the
initial setting before frame reception. Changing this bit
before receiving the control field is valid, however,
changing this bit after receiving the control field is invalid
and the value before the change is validated.
0: Reception is disabled.
1: Reception is enabled.
Rev. 6.00 Sep. 24, 2009 Page 558 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
2
LUEE
0
R/W
Last Byte Underrun Enable
Sets whether to generate an underrun error when the last
data field byte is transferred in data transmission.
If the IEB reads from IETBR when the TxRDY flag is set
(the transmit buffer register (IETBR) is empty), an underrun
error occurs. In transmission using the DTC, an underrun
error occurs at the last byte transmission if the CPU did not
clear the TxRDY flag, because the DTC does not clear the
TxRDY flag. When the DTC is used, set this bit to 0 to
mask an underrun error generated at the last byte
transmission. When the DTC is not used, set this bit to 1 to
generate an underrun error at the last byte transmission.
0: An underrun error does not occur at the last byte
transmission (when using the DTC)
1: An underrun error does not occur at the last byte
transmission (when not using the DTC)
1
CKS0
0
R/W
Input Clock Select
Selects clock used by the IEB. See table 17.7.
0
⎯
0
⎯
Reserved
This bit is always read as 0 and cannot be modified.
Table 17.7 List of System Clock Division Ratio
Bit 4
Bit 1
CKS1
CKS0
Function
0
0
1/4 system clock is used (φ = 24MHz, 25.16 MHz)
0
1
1/3 system clock is used (φ = 18MHz, 18.87 MHz)
1
0
1/2 system clock is used (φ = 12MHz, 12.58 MHz)
1
1
Setting prohibited
Rev. 6.00 Sep. 24, 2009 Page 559 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.2
IEBus Command Register (IECMR)
IECMR issues commands to control IEB communications. Since this register is a write-only
register, bit-manipulation instructions should not be used when writing. See section 2.9.4, Access
Method for Registers with Write-only Bits.
Bit
Bit Name
7 to 3 ⎯
Initial
Value
R/W
Description
All 0
⎯
Reserved
The read value is undefined. In order to avoid
malfunction, do not use bit manipulation instructions.
These bits cannot be modified.
2
CMD2
0
W
Command Bits
1
CMD1
0
W
0
CMD0
0
W
These bits issue a command to control IEB
communications. When the CMX flag in IEFLG is set after
the command issuance, the command is indicated to be in
execution. When the CMX flag becomes 0, the operation
state is entered. The read value is undefined. Do not use
a bit manipulation instruction that causes malfunction.
000: No operation. Operation is not affected.
1
001: Unlock (required from other units)*
010: Requires communications as the master
2
011: Stops master communications*
100: Undefined bits. Operation is not affected by this
command.
101: Requires data transfer from the slave.
3
110: Stops data transfer from the slave* .
111: Undefined bits. Operation is not affected by this
command.
Notes: 1. Do not execute this command in slave communications. Execute this command after
slave communications ends or in master communications. If this command is issued in
slave communications, this command is ignored.
2. This command is valid during master communications (MRQ = 1). In other states, this
command issuance is ignored. If this command is issued in master communications, the
communications controller immediately enters the wait state. At this time, the issued
master transmission request ends (MRQ = 0).
Rev. 6.00 Sep. 24, 2009 Page 560 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
3. This command is valid during slave communications (SRQ = 1). In other states, this
command issuance is ignored. Once this command was issued in slave transmission,
the SRQ flag is 0 before slave transmission. Therefore, a transmit request from the
master is not responded. If a transmit request is issued during slave transmission, the
transmission stops and the wait state is entered (SRQ = 0).
17.3.3
IEBus Master Control Register (IEMCR)
IEMCR sets communications conditions for master communications (selection of broadcast or
normal communications, retransmission counts at arbitration loss, and control bits value). It is not
necessary to set this register for slave communications.
Bit
Bit Name
Initial
Value
R/W
Description
7
SS
1
R/W
Broadcast/Normal Communications Select
Selects broadcast or normal communications for master
communications.
0: Broadcast communications
1: Normal communications
6
RN2
0
R/W
Retransmission Counts
5
RN1
0
R/W
4
RN0
0
R/W
Set the number of times retransmission is performed when
arbitration is lost in master communications. If arbitration is
lost for a specified number of times, the AL flag in IETEF
and the TxE bit in IETSR is set and transmission ends with
a transmit error. If arbitration is won during retransmission,
the retransmission count is automatically restored to the
initial setting after master address transfer.
000: 0
001: 1
010: 2
011: 3
100: 4
101: 5
110: 6
111: 7
Rev. 6.00 Sep. 24, 2009 Page 561 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
1
Initial
Value
R/W
Description
3
CTL3*
0
R/W
Control bits
2
CTL2
0
R/W
1
CTL1
0
R/W
Set the control bits in the control field for master
transmission.
0
CTL0
0
R/W
0000: Reads slave status
0001: Undefined. Setting prohibited.
0010: Undefined. Setting prohibited.
0011: Reads data and locks*
2
0100: Reads locked address (lower 8 bits)
0101: Reads locked address (upper 4 bits)
2
0110: Reads slave status and unlocks*
0111: Reads data
1000: Undefined. Setting prohibited.
1001: Undefined. Setting prohibited.
1010: Writes command and locks*
1011: Writes data and locks*
2
2
1100: Undefined. Setting prohibited.
1101: Undefined. Setting prohibited.
1110: Writes command
1111: Writes data
Notes: 1. CTL3 decides the data transfer direction of the message length bits in the message
length field and data bits in the data field:
CTL3 = 1: Transfer is performed from master unit to slave unit
CTL3 = 0: Transfer is performed from slave unit to master unit
2. Control bits to lock and unlock
Rev. 6.00 Sep. 24, 2009 Page 562 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.4
IEBus Master Unit Address Register 1 (IEAR1)
IEAR1 sets the lower 4 bits of the master unit address and communications mode. In master
communications, the master unit address becomes the master address field value. In slave
communications, the master unit address is compared with the received slave address field.
Bit
Bit Name
Initial
Value
R/W
Description
7
IAR3
0
R/W
Lower 4 Bits of IEBus Master Unit Address
6
IAR2
0
R/W
Set the lower 4 bits of the master unit address.
5
IAR1
0
R/W
4
IAR0
0
R/W
3
IMD1
0
R/W
IEBus Communications Mode
2
IMD0
0
R/W
Set IEBus communications mode.
00: Communications mode 0
01: Communications mode 1
10: Communications mode 2
11: Setting prohibited
1
⎯
0
⎯
Reserved
0
STE
0
R/W
Slave Transmission Setting
This bit is always read as 0 and cannot be modified.
Sets bit 4 in the slave status register. Transmitting the
slave status register informs the master unit that the slave
transmission enabled state is entered by setting this bit to
1. Note that this bit only sets the slave status register value
and does not affect slave transmission directly.
0: Bit 4 in the slave status register is 0 (slave transmission
stop state)
1: Bit 4 in the slave status register is 1 (slave transmission
enabled state)
Rev. 6.00 Sep. 24, 2009 Page 563 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.5
IEBus Master Unit Address Register 2 (IEAR2)
IEAR2 sets the upper 8 bits of the master unit address. In master communications, this register
becomes the master address field value. In slave communications, this register is compared with
the received slave address field.
Bit
Bit Name
Initial Value
R/W
Description
7
IAR11
0
R/W
Upper 8 Bits of IEBus Master Unit Address
6
IAR10
0
R/W
Set the upper 8 bits of the master unit address.
5
IAR9
0
R/W
4
IAR8
0
R/W
3
IAR7
0
R/W
2
IAR6
0
R/W
1
IAR5
0
R/W
0
IAR4
0
R/W
17.3.6
IEBus Slave Address Setting Register 1 (IESA1)
IESA1 sets the lower 4 bits of the communications destination slave unit address. For slave
communications, it is not necessary to set this register.
Bit
Bit Name
Initial Value
R/W
Description
7
ISA3
0
R/W
Lower 4 Bits of IEBus Slave Address
6
ISA2
0
R/W
5
ISA1
0
R/W
These bits set the lower 4 bits of the
communications destination slave unit address
4
ISA0
0
R/W
All 0
⎯
3 to 0 ⎯
Reserved
These bits are always read as 0 and cannot be
modified.
Rev. 6.00 Sep. 24, 2009 Page 564 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.7
IEBus Slave Address Setting Register 2 (IESA2)
IESA2 sets the upper 8 bits of the communications destination slave unit address. For slave
communications, it is not necessary to set this register.
Bit
Bit Name
Initial Value
R/W
Description
7
ISA11
0
R/W
Upper 8 Bits of IEBus Slave Address
6
ISA10
0
R/W
5
ISA9
0
R/W
Set upper 8 bits of the communications destination
slave unit address
4
ISA8
0
R/W
3
ISA7
0
R/W
2
ISA6
0
R/W
1
ISA5
0
R/W
0
ISA4
0
R/W
17.3.8
IEBus Transmit Message Length Register (IETBFL)
IETBFL sets the message length for master or slave transmission.
Bit
Bit Name
Initial Value
R/W
Description
7
TBFL7
0
R/W
Transmit Message Length
6
TBFL6
0
R/W
5
TBFL5
0
R/W
Set the message length for master or slave
transmission.
4
TBFL4
0
R/W
3
TBFL3
0
R/W
2
TBFL2
0
R/W
1
TBFL1
0
R/W
0
TBFL0
0
R/W
If a value exceeding the maximum transmit bytes
for one frame is set in IETBFL, communications
are performed with two or more frames in some
communications modes. In this case, in or after the
second frame, the message length value should
be the number of bytes of the remaining
communications data, however, the initial IETBFL
setting remains unchanged. Therefore, for the
second frame or after, re-set the number of bytes
of the remaining communications data.
Rev. 6.00 Sep. 24, 2009 Page 565 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.9
IEBus Transmit Buffer Register (IETBR)
IETBR is a 1-byte buffer to which data to be transmitted in master or slave transmission is written.
IETBR is empty when the TxRDY flag in IETSR is 1. Check the TxRDY flag before setting
transmit data in IETBR.
Data written in IETBR is transmitted in the data field in master or slave transmission. Figure 17.6
shows the correspondence between the communications signal format and registers for IEBus data
transfer.
Bit
Bit Name
Initial Value
R/W
Description
7
TBR7
0
R/W
6
TBR6
0
R/W
Data to be transmitted is written to this 1-byte
buffer.
5
TBR5
0
R/W
4
TBR4
0
R/W
3
TBR3
0
R/W
2
TBR2
0
R/W
1
TBR1
0
R/W
0
TBR0
0
R/W
Rev. 6.00 Sep. 24, 2009 Page 566 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
[In master transmission]
Communications frame Master address Slave address
Control bits
Message length
bits
Data bits
Register
IESA1, IESA2
CTL3 to CTL0
in IEMCR
IETBFL
IETBR
Communications frame Master address Slave address
Control bits
Message length
bits
Data bits
(*3)
IETBFL
IETBR
IEAR1, IEAR2
[In slave transmission]
(*2)
Register
(*1)
IEAR1, IEAR2
Notes: 1. In slave transmission, the received master address is not saved. If the unit is locked,
address comparison performed.
2. The received slave address is compared with IEAR1 and IEAR2, and if these addresses
match, operation continues.
3. In slave transmission, the received control bits are not saved. The received control bits
are decoded to decide the subsequent operation.
Figure 17.6 Transmission Signal Format and Registers in Data Transfer
17.3.10 IEBus Reception Master Address Register 1 (IEMA1)
IEMA1 indicates the lower four bits of the communications destination master unit address in
slave/broadcast reception. This register is enabled when slave/broadcast reception starts, and the
contents are changed at the timing of setting the RxS flag in IERSR.
If a broadcast receive error interrupt is selected by the DEE bit in IECTR and the receive buffer is
not in the receive enabled state on control field reception, a receive error interrupt is generated and
the lower 4 bits of the master address are stored in IEMA1. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
IMA3
0
R
Lower 4 Bits of IEBus Reception Master Address
6
IMA2
0
R
5
IMA1
0
R
4
IMA0
0
R
Indicates the lower 4 bits of the communications
destination master unit address in slave/broadcast
reception.
All 0
R
3 to 0 ⎯
Reserved
These bits are always read as 0.
Rev. 6.00 Sep. 24, 2009 Page 567 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.11 IEBus Reception Master Address Register 2 (IEMA2)
IEMA2 indicates the upper 8 bits of the communications destination master unit address in
slave/broadcast reception. This register is enabled when slave/broadcast reception starts, and the
contents are changed at the timing of setting the RxS flag in IERSR.
If a broadcast receive error interrupt is selected with the DEE bit in IECTR and the receive buffer
is not in the receive enabled state at control field reception, a receive error interrupt is generated
and the upper 8 bits of the master address are stored in IEMA2. This register cannot be modified
by a write.
Bit
Bit Name
Initial Value
R/W
Description
7
IMA11
0
R
Upper 8 Bits of IEBus Reception Master Address
6
IMA10
0
R
5
IMA9
0
R
4
IMA8
0
R
Indicates the upper 8 bits of the communications
destination master unit address in slave/broadcast
reception.
3
IMA7
0
R
2
IMA6
0
R
1
IMA5
0
R
0
IMA4
0
R
17.3.12 IEBus Receive Control Field Register (IERCTL)
IERCTL indicates the control field value in slave/broadcast reception. This register is enabled
when slave/broadcast receive starts, and the contents are changed at the timing of setting the RxS
flag in IERSR.
This register cannot be modified.
Bit
Bit Name
7 to 4 ⎯
Initial Value
R/W
Description
All 0
R
Reserved
These bits are always read as 0.
3
RCTL3
0
R
IEBus Receive Control Field
2
RCTL2
0
R
1
RCTL1
0
R
Indicates the control field value in slave/broadcast
reception.
0
RCTL0
0
R
Rev. 6.00 Sep. 24, 2009 Page 568 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.13 IEBus Receive Message Length Register (IERBFL)
IERBFL indicates the message length field in slave/broadcast reception. This register is enabled
when slave/broadcast receive starts, and the contents are changed at the timing of setting the RxS
flag in IERSR.
This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
RBFL7
0
R
IEBus Receive Message Length
6
RBFL6
0
R
5
RBFL5
0
R
Indicates the contents of message length field in
slave/broadcast reception.
4
RBFL4
0
R
3
RBFL3
0
R
2
RBFL2
0
R
1
RBFL1
0
R
0
RBFL0
0
R
Rev. 6.00 Sep. 24, 2009 Page 569 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.14 IEBus Receive Buffer Register (IERBR)
IERBR is a 1-byte read-only buffer that stores data received in master or slave reception. This
register can be read when the RxRDY flag in IERSR is set to 1. This register indicates the data
field value both in master and slave receptions. This register cannot be modified.
Figure 17.7 shows the relationship between transmission signal format and registers in IEBus data
reception.
Bit
Bit Name
Initial Value
R/W
Description
7
RBR7
0
R
6
RBR6
0
R
One-byte read-only buffer that stores data
received in master or slave reception
5
RBR5
0
R
4
RBR4
0
R
3
RBR3
0
R
2
RBR2
0
R
1
RBR1
0
R
0
RBR0
0
R
[In slave reception]
Communications frame Master address Slave address
Control bits
Message length
bits
Data bits
(*)
Register
IEMA1, IEMA2 IEAR1, IEAR2
IERCTL
IERBFL
IERBR
Note: * Received slave address is compared with IEAR1 and IEAR2. If they match,
the following operations are performed.
[In master reception]
Communications frame Master address Slave address
Register settings
IEAR1, IEAR2
IESA1, IESA2
Control bits
CTL3 to CTL0
in IEMCR
Message length
bits
IERBFL
Data bits
IERBR
Figure 17.7 Relationship between Transmission Signal Format and Registers
in IEBus Data Reception
Rev. 6.00 Sep. 24, 2009 Page 570 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.15 IEBus Lock Address Register 1 (IELA1)
IELA1 specifies the lower 8 bits of a locked address when a unit is locked. Data in this register is
valid when the LCK flag in IEFLG is set to 1. This register cannot be modified.
Bit
Bit Name
Initial Value
R/W
Description
7
ILA7
0
R
Lower 8 Bits of IEBus Lock Address
6
ILA6
0
R
5
ILA5
0
R
Stores the lower 8 bits of the master unit address
when a unit is locked.
4
ILA4
0
R
3
ILA3
0
R
2
ILA2
0
R
1
ILA1
0
R
0
ILA0
0
R
17.3.16 IEBus Lock Address Register 2 (IELA2)
IELA2 is an 8-bit read-only register that specifies the upper 4 bits of a locked address when a unit
is locked. Data in this register is valid when the LCK flag in IEFLG is set to 1. This register
cannot be modified.
Bit
Bit Name
7 to 4 ⎯
Initial Value
R/W
All 0
R
Description
Reserved
These bits are always read as 0.
3
ILA11
0
R
Upper 4 Bits of IEBus Locked Address
2
ILA10
0
R
1
ILA9
0
R
Stores the upper 4 bits of the master unit address
when a unit is locked.
0
ILA8
0
R
Rev. 6.00 Sep. 24, 2009 Page 571 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.17 IEBus General Flag Register (IEFLG)
IEFLG indicates the IEB command execution status, lock status and slave address match, and
broadcast reception detection. This register cannot be modified.
Bit
Bit Name
Initial
Value
R/W
Description
7
CMX
0
R
Command Execution Status
Indicates the command execution status.
1: A command is being executed
[Setting condition]
•
When a master communications request or slave
transmit request command is issued while the MRQ,
SRQ, or SRE flag is set to 1
0: A command execution is completed
[Clearing condition]
•
6
MRQ
0
R
When a command execution has been completed
Master Communications Request
Indicates whether or not the unit is in communications
request state as a master unit.
1: The unit is in communications request state as a master
unit
[Setting condition]
•
When the CMX flag is cleared to 0 after the master
communications request command is issued
0: The unit is not in communications request status as a
master unit
[Clearing condition]
•
Rev. 6.00 Sep. 24, 2009 Page 572 of 928
REJ09B0099-0600
When the master communications have been
completed
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
5
SRQ
0
R
Slave Transmission Request
Indicates whether or not the unit is in transmit request
status as a slave unit.
1: The unit is in transmit request status as a slave unit
[Setting condition]
•
When the CMX flag is cleared to 0 after the slave
transmit request command is issued.
0: The unit is not in transmit request status as a slave unit
[Clearing condition]
•
4
SRE
0
R
When a slave transmission has been completed.
Slave Receive Status
Indicates the execution status in slave/broadcast reception.
1: Slave/broadcast reception is being executed
[Setting condition]
•
When the slave/broadcast reception is started while the
RE bit in IECTR is set to 1.
0: Slave/broadcast reception is not being executed
[Clearing condition]
•
When the slave/broadcast reception has been
completed.
Rev. 6.00 Sep. 24, 2009 Page 573 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
3
LCK
0
R
Lock Status Indication
Set to 1 when a unit is locked by a lock request from the
master unit. IELA1 and IELA2 values are valid only when
this flag is set to 1.
1: A unit is locked
[Setting condition]
•
When data for the number of bytes specified by the
message length is not received after the control bits
that make the unit locked are received from the master
unit. (The LCK flag is set to 1 only when the message
length exceeds the maximum number of transfer bytes
in one frame. This flag is not set by completion of other
errors.)
0: A unit is unlocked
[Clearing condition]
•
2
⎯
0
R
When an unlock condition is satisfied or when an
unlock command is issued.
Reserved
This bit is always read as 0.
1
RSS
0
R
Receive Broadcast Bit Status
Indicates the received broadcast bit value. This flag is valid
when the slave/broadcast reception is started. (This flag is
changed at the timing of setting the RxS flag in IERSR.)
The previous value remains unchanged until the next
slave/broadcast reception is started.
Rev. 6.00 Sep. 24, 2009 Page 574 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
0
GG
0
R
General Broadcast Reception Acknowledgement
Set to 1 when the slave address is acknowledged as
H'FFF in broadcast reception. As well as the receive
broadcast bit, this flag is valid when the slave/broadcast
reception is started. (This flag is changed at the timing of
setting the RxS flag in IERSR.)
The previous value remains unchanged until the next
slave/broadcast reception is started. This flag is cleared to
0 in slave normal reception.
[Setting condition]
•
When H'FFF is acknowledged in the slave field in
broadcast reception
[Clearing conditions]
•
A unit is in slave reception
•
When H'FFF is not acknowledged in slave field in
broadcast reception
Rev. 6.00 Sep. 24, 2009 Page 575 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.18 IEBus Transmit/Runaway Status Register (IETSR)
IETSR detects transmit data ready, transmit start, transmit normal completion, transmit
completion with an error, or runaway states. Each status flags in IETSR corresponds to a bit in the
IEBus transmit/runaway interrupt enable register (IEIET) that enables or disables each interrupt.
Bit
Bit Name
Initial
Value
R/W
Description
7
TxRDY
1
R/W
Transmit Data Ready
Indicates that the next data can be written to IETBR since
IETBR is empty. This flag is automatically cleared by
DTC* data transfer. When data is transmitted by the CPU,
this flag must be cleared by software. This flag is cleared
by writing 0 after reading a 1 from this flag.
[Setting conditions]
•
Immediately after reset
•
When data can be written to IETBR (when IEB has
loaded data from IETBR to the transmit shift register.)
[Clearing conditions]
•
When writing 0 after reading TxRDY = 1
•
When data is written to TBR by the DTC by a TxRDY
request.
Note: This flag is not cleared on the end byte of DTC
transfer.
6 to 4 ⎯
All 0
⎯
Reserved
These bits are always read as 0 and cannot be modified.
3
IRA
0
R/W
IEBus Runaway State
Indicates that the on-chip microprogram for IEBus control
is in the runaway states. This flag is set to 1 when a
runaway occurs during either IEBus transmission or
reception. (This flag is not a transfer specific flag and is
also set for a reception runaway.)
[Setting condition]
•
When the on-chip microprogram is in the runaway
states
[Clearing condition]
•
Rev. 6.00 Sep. 24, 2009 Page 576 of 928
REJ09B0099-0600
When writing 0 after reading IRA = 1
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
2
TxS
0
R/W
Transmit Start Detection
Indicates that the IEB starts transmission.
[Setting conditions]
•
Master transmission: When the arbitration is won and
when the master address field transmission is
completed
•
Slave transmission: When the control bits of H'3 (0011)
or H'7 (0111) is received from the master unit meaning
that data transfer is requested
[Clearing condition]
•
1
TxF
0
R/W
When writing 0 after reading TxS = 1
Transmit Normal Completion
Indicates that data for the number of bytes specified by the
message length bits has been transmitted with no error.
[Setting condition]
•
When data for the number of bytes specified by the
message length bits has been transmitted normally
[Clearing condition]
•
When writing 0 after reading TxF = 1
Rev. 6.00 Sep. 24, 2009 Page 577 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
0
TxE
0
R/W
Transmit Error Completion
Indicates that data for the number of bytes specified by the
message length bits is not completed and that the data
transmission is terminated. The source of this error can be
checked by the contents of IETEF. This flag is set at the
timing that an error indicated by IETEF occurs. The TxE
flag can be cleared even when the error source flag in
IETEF is set to 1 because the TxE flag is not logically
ORed with the flags in IETEF.
In master reception, an error (arbitration loss, timing error,
or NAK reception) generated after a master
communications command is issued before master
reception starts will be detected as a transmit error.
[Setting condition]
•
When the data for the number of bytes specified by the
message length bits is not completed and when the
transmission is terminated
[Clearing condition]
•
Rev. 6.00 Sep. 24, 2009 Page 578 of 928
REJ09B0099-0600
When writing 0 after reading TxE = 1
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.19 IEBus Transmit/Runaway Interrupt Enable Register (IEIET)
IEIET enables/disables IETSR transmit ready, transmit start, transmit normal completion, transmit
completion with an error, and runaway interrupts.
Bit
Bit Name
Initial
Value
R/W
Description
7
TxRDYE
0
R/W
Transmit Data Ready Interrupt Enable
Enables/disables a transmit data ready interrupt.
0: Disables a transmit data ready (TxRDY) interrupt
1: Enables a transmit data ready (TxRDY) interrupt
6 to 4 ⎯
All 0
⎯
Reserved
These bits are always read as 0 and cannot be modified.
3
IRAE
0
R/W
IEBus Runaway State Interrupt Enable
Enables/disables an IEBus runaway state interrupt.
0: Disables an IEBus runaway state interrupt (IRA)
1: Enables an IEBus runaway state interrupt (IRA)
2
TxSE
0
R/W
Transmit Start Interrupt Enable
Enables/disables a transmit start (TxS) interrupt.
0: Disables a transmit start (TxS) interrupt
1: Enables a transmit start (TxS) interrupt
1
TxFE
0
R/W
Transmit Normal Completion Interrupt Enable
Enables/disables a transmit normal completion (TxF)
interrupt.
0: Disables a transmit normal completion (TxF) interrupt
1: Enables a transmit normal completion (TxF) interrupt
0
TxEE
0
R/W
Transmit Error Termination Interrupt Enable
Enables/disables a transmit error termination (TxE)
interrupt.
0: Disables a transmit error termination (TxE) interrupt
1: Enables a transmit error termination (TxE) interrupt
Rev. 6.00 Sep. 24, 2009 Page 579 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.20 IEBus Transmit Error Flag Register (IETEF)
IETEF checks the source of a TxE interrupt indicated in IETSR. This register detects an overflow
of a maximum number of bytes in one frame, arbitration loss, underrun error, timing error, and
NAK reception.
Bit
Bit Name
7 to 5 ⎯
Initial
Value
R/W
Description
All 0
⎯
Reserved
These bits are always read as 0 and cannot be modified.
4
AL
0
R/W
Arbitration Loss
The IEB retransmits from the start bit for the number of
times specified by bits RN2 to Rn0 in IEMCR if the
arbitration has been lost in master communications. If the
arbitration has been lost for the specified number of times,
the AL and TxE flags are set to enter the wait state. If the
arbitration has been won within retransmit for the
specified number of times, this flag is not set to 1. This
flag is set only when the arbitration has been lost and the
wait state is entered.
[Setting condition]
•
When the arbitration has been lost during data
transmission and the transmission has been
terminated
[Clearing condition]
•
Rev. 6.00 Sep. 24, 2009 Page 580 of 928
REJ09B0099-0600
When writing 0 after reading AL = 1
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
3
UE
0
R/W
Underrun Error
Indicates that an underrun error has occurred during data
transmission. The IEB detects an underrun error
occurrence when the IEB fetches data from IETBR while
the TxRDY flag is set to 1, and the IEB sets the TxE flag
and enters the wait state. Accordingly, when the TxRDY
flag is not cleared even if data is written to IETBR, an
underrun error occurs and data transmission is
terminated. Note that the TxRDY flag must be cleared in
data transmission by the CPU.
[Setting condition]
•
When the IEB loads data from IETBR to the transmit
shift register while the TxRDY flag is set to 1
[Clearing condition]
•
2
TTME
0
R/W
When writing 0 after reading UE = 1
Timing Error
Set to 1 if data is not transmitted at the timing specified by
the IEBus protocol during data transmission. The IEB sets
the TxE flag and enters the wait state.
[Setting condition]
•
When a timing error occurs during data transmission
[Clearing condition]
•
When writing 0 after reading TTME = 1
Rev. 6.00 Sep. 24, 2009 Page 581 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
1
RO
0
R/W
Overflow of Maximum Number of Transmit Bytes in One
Frame
Indicates that the maximum number of bytes defined by
communications mode have been transmitted because a
NAK has been received from the receive unit and retransmit
has been performed, or that transmission has not been
completed because the message length value exceeds the
maximum number of transmit bytes in one frame. The IEB
sets the TxE flag and enters the wait state.
[Setting condition]
•
When the transmit has not been completed although the
maximum number of bytes defined by communications
mode have been transmitted
[Clearing condition]
•
0
ACK
0
R/W
When writing 0 after reading RO = 1
Acknowledge bit Status
Indicates the data received in the acknowledge bit of the
data field.
•
Acknowledge bit other than in the data field
The IEB terminates the transmission and enters the wait
state if a NAK is received. In this case, this bit and the
TxE flag are set to 1.
•
Acknowledge bit in the data field
The IEB retransmits data up to the maximum number of
bytes defined by communications mode until an ACK is
received from the receive unit if a NAK is received from
the receive unit during data field transmission. In this
case, when an ACK is received from the receive unit
during retransmission, this flag is not set and
transmission will be continued. When transmission is
terminated without receiving an ACK, this flag is set to 1.
Note: This flag is invalid in broadcast communications.
[Setting condition]
•
When the acknowledge bit of 1 (NAK) is detected
[Clearing condition]
•
Rev. 6.00 Sep. 24, 2009 Page 582 of 928
REJ09B0099-0600
When writing 0 after reading ACK = 1
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.21 IEBus Receive Status Register (IERSR)
IERSR detects receive data ready, receive start, transmit/receive normal completion, or receive
completion with an error. Each status flag in IERSR corresponds to a bit in the IEIER that
enables/disables each interrupt.
Bit
Bit Name
Initial
Value
R/W
Description
7
RxRDY
1
R/W
Receive Data Ready
Indicates that the receive data is stored in IERBR and that
the receive data can be read. This flag is automatically
cleared by DTC* data transfer. When data is transmitted
by the CPU, this flag must be cleared by software.
[Setting condition]
•
When data reception has been completed normally
and receive data has been loaded to IERBR.
[Clearing conditions]
•
When writing 0 after reading RxRDY = 1
•
When IERBR data is read by the DTC by a RxRDY
request.
Note: This flag cannot be cleared on the end byte of the
DTC transfer.
6 to 3 ⎯
All 0
⎯
Reserved
These bits are always read as 0 and cannot be modified.
2
RxS
0
R/W
Receive Start Detection
Indicates that the IEB starts reception.
[Setting conditions]
•
Master reception: When the message length field has
been received from the slave unit correctly after the
arbitration is won and the control field transmission is
completed
•
Slave reception: When the message length field has
been received from the master unit correctly
[Clearing condition]
•
When writing 0 after reading RxS = 1
Rev. 6.00 Sep. 24, 2009 Page 583 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
1
RxF
0
R/W
Receive Normal Completion
Indicates that data for the number of bytes specified by the
message length bits has been received and with no error.
[Setting condition]
•
When data for the number of bytes specified by the
message length bits has been received normally.
[Clearing condition]
•
0
RxE
0
R/W
When writing 0 after reading RxF = 1
Receive Error Completion
Indicates that data for the number of bytes specified by the
message length bits is not completed and that the data
reception is terminated. The source of this error can be
checked by the contents of IEREF. This flag is set at the
timing that an error indicated by IEREF occurs. The RxE
flag can be cleared even when the error source flag in
IEREF is set to 1 because the RxE flag is not logically
ORed with the flags in IEREF.
[Setting condition]
•
When the data for the number of bytes specified by the
message length bits is not completed and when the
reception is terminated.
[Clearing condition]
•
Rev. 6.00 Sep. 24, 2009 Page 584 of 928
REJ09B0099-0600
When writing 0 after reading RxE = 1
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.22 IEBus Receive Interrupt Enable Register (IEIER)
IEIER enables/disables IERSR reception ready, receive start, transmit/receive normal completion,
and receive completion with an error interrupts.
Bit
Bit Name
Initial
Value
R/W
Description
7
RxRDYE
0
R/W
Receive Data Ready Interrupt Enable
Enables/disables a receive data ready interrupt.
0: Disables a receive data ready (RxRDY) interrupt
1: Enables a receive data ready (RxRDY) interrupt
6 to 3 ⎯
All 0
⎯
Reserved
These bits are always read as 0 and cannot be modified.
2
RxSE
0
R/W
Receive Start Interrupt Enable
Enables/disables a receive start (RxS) interrupt.
0: Disables a receive start (RxS) interrupt
1: Enables a receive start (RxS) interrupt
1
RxFE
0
R/W
Receive Normal Completion Enable
Enables or disables a receive normal completion (RxF)
interrupt.
0: Disables a receive normal completion (RxF) interrupt
1: Enables a receive normal completion (RxF) interrupt
0
RxEE
0
R/W
Receive Error Termination Interrupt Enable
Enables or disables a receive error termination (RxE)
interrupt.
0: Disables a receive error termination (RxE) interrupt
1: Enables a receive error termination (RxE) interrupt
Rev. 6.00 Sep. 24, 2009 Page 585 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.3.23 IEBus Receive Error Flag Register (IEREF)
IEREF checks the source of an RxE interrupt indicated in IERSR. This register detects an overrun
error, timing error, overflow of a maximum number of bytes in one frame, and parity error.
These flags become valid when the receive start flag (RxS) is set to 1. If an error occurs before the
RxS flag is set to 1, the IEB terminates the communications and enters the wait state. In this case,
these flags will not be set and the RxE flag is not set.
Bit
Bit Name
7 to 4 ⎯
Initial
Value
R/W
Description
All 0
⎯
Reserved
These bits are always read as 0 and cannot be modified.
3
OVE
0
R/W
Overrun Control Flag
Used to control the overrun during data reception. The IEB
sets the OVE and RxE flags when the IEB receives the
next byte data while the receive data has not been read
(the RxRDY flag is not cleared) and when the parity bit
reception has been started. If this flag remains set until
acknowledge bit transfer, the IEB assumes that an
overrun error has occurred and returns a NAK to the
communications destination unit.
The communications destination unit retransmits data up
to the maximum number of transmit bytes. The IEB,
however, returns a NAK when this flag remains set
because the IEB assumes that the overrun error has not
been cleared.
If this flag is cleared to 0, the IEB decides that the overrun
error has been cleared, returns an ACK, and receives the
next data.
In broadcast reception, if this flag is set during
acknowledge bit transmission, the IEB immediately enters
the wait state.
[Setting condition]
•
When the next byte data is received while the RxRDY
flag is not cleared and when the parity bit of the data is
received.
[Clearing condition]
•
Rev. 6.00 Sep. 24, 2009 Page 586 of 928
REJ09B0099-0600
When writing 0 after reading OVE = 1
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
2
RTME
0
R/W
Timing Error
Set to 1 if data is not received at the timing specified by
the IEBus protocol during data reception. The IEB sets the
RxE flag and enters the wait state.
[Setting condition]
•
When a timing error occurs during data reception
[Clearing condition]
•
1
DLE
0
R/W
When writing 0 after reading RTME = 1
Overflow of Maximum Number of Receive Bytes in One
Frame
Indicates that the maximum number of bytes defined by
communications mode have been received because a
parity error or overrun error occurred, or that the reception
has not be completed because the message length value
exceeds the maximum number of receive bytes in one
frame. The IEB sets the RxE flag and enters the wait
state.
[Setting condition]
•
When the reception has not been completed although
the maximum number of bytes defined by
communications mode have been received.
[Clearing condition]
•
When writing 0 after reading DLE = 1
Rev. 6.00 Sep. 24, 2009 Page 587 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Bit
Bit Name
Initial
Value
R/W
Description
0
PE
0
R/W
Parity Error
Indicates that a parity error has occurred during data field
reception. If a parity error occurs before data field
reception, the IEB immediately enters the wait state and
the PE flag is not set.
If a parity error occurs when the maximum number of
receive bytes in one frame has not been received, the PE
flag is not set. When a parity error occurs, the IEB returns
a NAK to the communications destination unit via the
acknowledge bit. In this case, the communications
destination unit continues retransfer up to the maximum
number of receive bytes in one frame and if the reception
has been completed normally by clearing the parity error,
the PE flag is not set. If the parity error is not cleared when
the reception is terminated before receiving data for the
number of bytes specified by the message length, the PE
flag is set.
In broadcast reception, if a parity error occurs during data
field reception, the IEB enters the wait state immediately
after setting the PE flag.
[Setting condition]
•
When the parity bit of last data of the data field is not
correct after the maximum number of receive bytes has
been received
[Clearing condition]
•
Rev. 6.00 Sep. 24, 2009 Page 588 of 928
REJ09B0099-0600
When writing 0 after reading PE = 1
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.4
Operation Descriptions
17.4.1
Master Transmit Operation
This section describes an example of master transmission using the DTC after slave reception.
(1)
IEB Initialization
(a) Setting the IEBus Control Register (IECTR)
Enable the IEBus pins, select the signal polarity, and select a clock supplied to the IEB. Clear
the LUEE bit to 0 since the transfer is performed by the DTC.
(b) Setting the IEBus Master Unit Address Registers 1 and 2 (IEAR1 and IEAR2)
Specify the master unit address and specify the communications mode in IEAR1.
(c) Setting the IEBus Slave Address Setting Registers 1 and 2 (IESA1 and IESA2)
Specify the communications destination slave unit address.
(d) Setting the IEBus Master Control register (IEMCR)
Select broadcast/normal communications, specify the number of retransfer counts at arbitration
loss, and specify the control bits.
(e) Setting the IEBus Transmit Message Length Register (IETBFL)
Specify the message length bits.
(f) Setting the IEBus Transmit/Runaway Interrupt Enable Register (IEIET)
Enable TxRDY (IETxI), TxS, TxF, and TxE (IETSI) interrupts.
The above registers can be specified in any order. (The register specification order does not affect
the IEB operation.)
(2)
DTC Initialization
1. Set the start address of the RAM which stores the register information necessary for the DTC
transfer in the vector address (H'000004D4) to be accessed when a DTC transfer request is
generated.
2. Set the following data from the start address of the RAM.
⎯ Transfer source address (SAR): Start address of the RAM which stores data to be
transmitted in the data field.
⎯ Transfer destination address (DAR): Address (H'FFF808) of the IEBus transmit buffer
register (IETBR)
⎯ Transfer count (CRA): The same value as the IETBFL contents
Rev. 6.00 Sep. 24, 2009 Page 589 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
3. Set DTCEG5 in the DTC enable register G (DTCERG) to enable the TxRDY interrupt
(IETxI).
Because the TxRDY flag is retained after a reset, the DTC transfer starts when the IETxI is
enabled and the first data for the data field is written to IETBR. The DTC negates the TxRDY
flag and the first byte of DTC transfer is completed.
(3)
Master Transmission Flow
Figure 17.8 shows the master transmission flow. Numbers in the following description correspond
to the number in figure 17.8.
1. After the IEB and DTC have been initialized, a master communications request command is
issued from IECMR. During slave reception, the command execution status flag (CMX) in
IEFLG is set and the master communications request will not be issued.
2. When the slave reception has been completed, the CMX flag is cleared, the master
communications command is executed, and the MRQ flag is set.
3. The transmit start detection flag (TxS) in IETSR is set when arbitration is won and the master
address has been transmitted. In this case, one of the transmit status interrupts (IETSI) is
requested to the CPU, and the TxS flag is cleared in the interrupt handling routine.
4. The IEB loads data to be transmitted in the data field from IETBR when the control and
message length fields have been transmitted and an ACK is received in each field. After that,
the TxRDY flag is set. A DTC transfer request is generated by IETxI and the second byte is
written to the transmit buffer.
5. Similarly, the data field load and transmission are repeated.
6. The DTC completes the data transfer for the number of specified bytes when data to be
transmitted in the last byte is written to. At this time, the DTC does not clear the TxRDY flag.
It, however, clears bit DTCEG5 in the DTC enable register G (DTCERG) so as not to generate
more DTC transfer request.
7. A TxRDY interrupt (IETxI) is issued to the CPU when the DTC transfer is completed. In this
interrupt handling routine, the TxRDY flag can be cleared. However, since a TxRDY interrupt
will be generated again after the last byte transfer, the TxRDY flag remains set. (Note that the
LUEE bit must be cleared to 0 because an underrun error occurs to terminate the transfer if the
LUEE bit in IECTR is set to 1.) Note, however, that the TxRDY interrupt must be disabled
because the TxRDY interrupt is always generated.
8. A transmit normal completion (TxF) interrupt (IETSI) occurs after the last data transfer is
completed. In this case, the CPU clears the TxF flag and completes the normal completion
interrupt and clears the MRQ flag to 0.
Note: As a transmit status interrupt (IETSI), the transmit error termination (TxE) interrupt as
well as the transfer start detection (TxS) and transmit normal completion (TxF) interrupts
Rev. 6.00 Sep. 24, 2009 Page 590 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
must be enabled. If an error termination interrupt is disabled, no interrupt is generated
even if the transmission is terminated by an error.
H: Header, MA: Master address field, SA: Slave address field,
CF: Control field, LF: Message length field, D1, D2,..., Dn-1, Dn: Data field
Slave reception
LF
Dn-1
Master transmission
Dn
H
MA
SA
CF
LF
D1
D2
Dn-1
Dn
IECMR
Master transmission request
IEFLG
(1)
(2)
CMX
(2)
MRQ
SRQ
SRE
DTC transfer
of 2nd byte
IETSR
(4)
TxRDY Cleared to 0 byt DTC transfer of 1st byte
(5)
DTC transfer
of 3rd byte
(6)
DTC transfer
of nth byte
(3)
TxS
(8)
TxF
Interrupt
(4)
IETxI (TxRDY)
(TO DTC)
(5)
(6)
(7)
IETxI (TxRDY)
(TO CPU)
(8)
(3)
IETSI
(TO CPU)
Figure 17.8 Master Transmit Operation Timing
17.4.2
Slave Receive Operation
This section describes an example of performing a slave reception using the DTC.
(1)
IEB Initialization
(a) Setting the IEBus Control Register (IECTR)
Enable the IEBus pins, select the signal polarity, and select a clock supplied to the IEB. Set the
RE bit to 1 to perform reception. The LUEE bit does not need to be specified.
(b) Setting the IEBus Master Unit Address Registers 1 and 2 (IEAR1 and IEAR2)
Rev. 6.00 Sep. 24, 2009 Page 591 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Specify the master unit address and specify the communications mode in IEAR1. Compare
with the slave address in the communications frame and receive the frame if matched.
(c) Setting the IEBus Receive Interrupt Enable Register (IEIER)
Enable RxRDY (IERxI), RxS, and RxE (IERSI) interrupts.
The above registers can be specified in any order. (The register specification order does not affect
the IEB operation.)
(2)
DTC Initialization
1. Set the start address of the RAM which stores the register information necessary for the DTC
transfer in the vector address (H'000004D2) to be accessed when a DTC transfer request is
generated.
2. Specify the following from the start address of the RAM.
⎯ Transfer source address (SAR): Address (H'FFF80D) of the IEBus receive buffer register
(IERBR).
⎯ Transfer destination address (DAR): Start address of the RAM which stores data received
from the data field.
⎯ Transfer count (CRA): Maximum number of transfer bytes in one frame in the transfer
mode.
3. Set DTCEG6 in the DTC enabler register G (DTCERG) to enable the RxRDY interrupt
(IETxI).
Because the above settings are performed before the frame reception, the length of data to be
received cannot be decided. Accordingly, the maximum number of transfer bytes in one frame is
specified as the DTC transfer count.
If the DTC is specified after reception starts, the above settings are performed in the receive start
(RxS) interrupt handling routine. In this case, the transfer count must be the same value as the
contents of the IEBus receive message length register (IERBFL).
(3)
Slave Reception Flow
Figure 17.9 shows the slave reception flow. Numbers in the following description correspond to
the number in Figure 17.9. In this example, the DTC is specified when the frame reception starts.
1. After the broadcast reception has been completed, the slave reception is performed. The
receive broadcast bit status flag (RSS) in IEFLG retains the previous frame information (set to
1) until the receive start detection flag (RxS) is set to 1. If the RSS flag changes at the timing
of header reception, the interrupt handling of the broadcast reception completion must be
Rev. 6.00 Sep. 24, 2009 Page 592 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
2.
3.
4.
5.
6.
7.
completed before the header reception. Accordingly, the RSS flag is stipulated that it changes
at the timing of starting reception.
If data is received up to the message length field, a receive start detection (RxS) interrupt
(receive status interrupt (IERSI)) will occur and the SRE flag is set to 1. In this case, the DTC
initialization described in (2) is performed. After initialization, the RxS flag is cleared to 0.
When the first data is received, the RxRDY flag is set to 1. A DTC transfer request by IERxI
occurs, and the DTC loads data from the IEBus receive buffer register (IERBR) and clears the
RxRDY flag.
Similarly, the data field reception and load are repeated.
When the last data is received, the DTC completes the data transfer for the specified number of
bytes after loading the receive data to the RAM. In this case, the DTC does not clear the
RxRDY flag. It, however, clears the DTC enable register G (DTCEG). Accordingly, hereafter,
no transfer request will be issued to the DTC.
When the DTC transfer has been completed, an RxRDY interrupt (IERxI) is issued to the
CPU. In this interrupt handling routine, the RxRDY flag is cleared.
When the last data is received, a receive normal completion (RxF) interrupt (IERSI) occurs. In
this case, the CPU clears the RxF flag in order to complete the normal completion interrupt.
The SRE flag is cleared to 0.
Notes: 1. As a receive status interrupt (IERSI), the receive error termination (RxE) interrupt as
well as the receive start detection (RxS) and receive normal completion (RxF)
interrupts must be enabled. If an error termination interrupt is disabled, no interrupt is
generated even if the reception is terminated by an error.
2. The interrupt occurs after the DTC transfer has been completed. Accordingly, the
interrupt described in item 6 actually occurs after item 7 above.
Rev. 6.00 Sep. 24, 2009 Page 593 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
H: Header, MA: Master address field, SA: Slave address field,
CF: Control field, LF: Message length field, D1, D2,..., Dn-1, Dn: Data field
Broadcast reception
Dn
Slave reception
H
MA
SA
CF
LF
D1
D2
Dn-1
Dn
IECTR
RE
IEFLG
(1)
RSS
IEFLG
CMX
MRQ
SRQ
(7)
SRE
(5)
DTC transfer DTC transfer DTC transfer DTC transfer
of 1st byte of (n-2)th byte of (n-1)th byte of nth byte
IERSR
(3)
RxRDY
(4)
(2)
RxS
(7)
RxF
Interrupt
(3)
IERxI (RxRDY)
(TO DTC)
(4)
(6)
IERxI (RxRDY)
(TO CPU)
(2)
IERSI
(TO CPU)
Figure 17.9 Slave Reception Operation Timing
Rev. 6.00 Sep. 24, 2009 Page 594 of 928
REJ09B0099-0600
(5)
(7)
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
(4)
When an Error Occurs in Broadcast Reception (DEE = 1)
Figure 17.10 shows an example in which a receive error occurs because the receive preparation
cannot be completed (the RxRDY flag is not cleared) until the control field is received in
broadcast reception after the slave reception while the DEE bit is set to 1.
Note: The same as the case in which the RE bit is not set before the control field reception.
H: Header, MA: Master address field, SA: Slave address field,
CF: Control field, LF: Message length field, D1, D2,..., Dn-1, Dn: Data field
Slave reception
Dn
Broadcast reception
H
MA
SA
CF
LF
D1
D2
Dn-1
Dn
IECTR
RE, DEE
Broadcast reception is performed while the DEE bit is set to 1.
IEFLG
RSS
IEFLG
CMX
MRQ
SRQ
SRE
IERSR
The RxRDY flag has not been cleared when the control field is received.
RxRDY
RxS
RxF
RxE
Set the RxE flag and the master unit address in IEAR1 and IEAR2.
IEMA1
Lower 4 bits of the master address
IEMA2
Upper 8 bits of the master address
Figure 17.10 Error Occurrence in the Broadcast Reception (DEE = 1)
Rev. 6.00 Sep. 24, 2009 Page 595 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.4.3
Master Reception
This section shows an example of performing a master reception using the DTC after slave
reception.
(1)
IEB Initialization
(a) Setting the IEBus Control Register (IECTR)
Enable the IEBus pins, select the signal polarity, and select a clock supplied to the IEB. Set the
RE bit to 1 to perform reception. The LUEE bit does not need to be specified.
(b) Setting the IEBus Master Unit Address Registers 1 and 2 (IEAR1 and IEAR2)
Specify the master unit address and specify the communications mode in IEAR1. Compare
with the slave address in the communications frame and receive the frame if matched.
(c) Setting the IEBus Slave Address Setting Registers 1 and 2 (IESA1 and IESA2)
Specify the communications destination slave unit address.
(d) Setting the IEBus Master Control Register (IEMCR)
Select broadcast/normal communications, specify the number of retransfer counts at arbitration
loss, and specify the control bits.
(e) Setting the IEBus Receive Interrupt Enable Register (IEIER)
Enable the RxRDY (IERxI), RxS, RxF, and RxE (IERSI) interrupts.
The above registers can be specified in any order. (The register specification order does not affect
the IEB operation.)
(2)
DTC Initialization
1. Set the start address of the RAM which stores the register information necessary for the DTC
transfer in the vector address (H'000004D2) to be accessed when a DTC transfer request is
generated.
2. Set the following data from the start address of the RAM.
⎯ Transfer source address (SAR): Address (H'FFF80D) of the IEBus receive buffer register
(IERBR).
⎯ Transfer destination address (DAR): Start address of the RAM which stores data to be
received from the data field.
⎯ Transfer count (CRA): Maximum number of transfer bytes in one frame in the transfer
mode.
3. Set bit DTCEG6 in the DTC enabler register G (DTCERG), and enable the RxRDY interrupt
(IERxI).
Rev. 6.00 Sep. 24, 2009 Page 596 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
Because the above settings are performed before frame reception, the length of data to be received
cannot be determined. Accordingly, the maximum number of transfer bytes in one frame is
specified as the DTC transfer count.
If the DTC is specified after reception starts, the above settings are performed in the receive start
detection (RxS) interrupt handling routine. In this case, the transfer count must be the same value
as the contents of the IEBus receive message length register (IERBFL).
(3)
Master Reception Flow
Figure 17.11 shows the master reception flow. Numbers in the following description correspond to
the number in figure 17.11. In this example, the DTC is specified when the frame reception starts.
1. After the IEB has been initialized, a master communications request command is issued from
IECMR. During slave reception, the command execution status flag (CMX) in IEFLG is set
and the master communications request will not be issued.
2. The CMX flag is cleared when the slave reception is completed, the master communications
command is executed, and the MRQ flag is set.
3. If the arbitration is won, the master address, slave address, and control field will be
transmitted. An error generated before the control field transmission will be handled as a
transmission error. In this case, the TxE flag is set and the error contents will be reflected in
IETEF.
4. The message length field is received from the slave unit. If no parity error is detected and
reception is performed correctly, the receive start detection flag (RxS) is set to 1. If a parity
error occurs, it is handled as a receive error. A receive start detection (RxS) interrupt (receive
status interrupt (IERSI)) occurs and the DTC initialization described in (2) is performed. After
DTC initialization, the RxS flag is cleared to 0.
5. When the first data is received, the RxRDY flag is set to 1. A DTC transfer request by IERxI
occurs and the DTC loads data from the IEBus receive buffer register (IERBR) and clears the
RxRDY flag.
6. Similarly, the above data field receive and load operations are repeated.
7. When the last data is received, the DTC completes the data transfer for the specified number of
bytes after loading the receive data to the RAM. In this case, the DTC does not clear the
RxRDY flag. It, however, clears the DTC enable register G (DTCEG). Accordingly, hereafter,
no transfer request will be issued to the DTC.
8. When the DTC transfer has been completed, an RxRDY interrupt (IERxI) is issued to the
CPU. In this interrupt handling routine, the RxRDY flag is cleared.
Rev. 6.00 Sep. 24, 2009 Page 597 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
9. When the last data is received, a receive normal completion (RxF) interrupt (IERSI) occurs. In
this case, the CPU clears the RxF flag to complete the receive normal completion interrupt.
The MRQ flag is cleared to 0.
Notes: 1. As a receive status interrupt (IERSI), an receive error completion (RxE) interrupt as
well as the receive start detection (RxS) and receive normal completion (RxF)
interrupts must be enabled. If a receive error completion interrupt is disabled, no
interrupt is generated even if the reception is terminated by an error.
2. The interrupt occurs after the DTC transfer has been completed. Accordingly, the
interrupt described in item 8 actually occurs after item 9 above.
H: Header, MA: Master address field, SA: Slave address field,
CF: Control field, LF: Message length field, D1, D2,..., Dn-1, Dn: Data field
Slave reception
Master reception
Dn
H
MA
SA
CF
LF
D1
D2
Dn-1
Dn
(3)
IECTR
RE
IECMR
Master reception request
IEFLG
(1)
(2)
CMX
MRQ
(2)
(9)
SRQ
SRE
DTC transfer DTC transfer DTC transfer DTC transfer
of 1st byte of (n-2)th byte of (n-1)th byte of nth byte
IERSR
(5)
RxRDY
(6)
(7)
(4)
RxS
(9)
RxF
Interrupt
(5)
IERxI (RxRDY)
(TO DTC)
(6)
(8)
IERxI (RxRDY)
(TO CPU)
(4)
IERSI
(TO CPU)
Figure 17.11 Master Receive Operation Timing
Rev. 6.00 Sep. 24, 2009 Page 598 of 928
REJ09B0099-0600
(7)
(9)
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.4.4
Slave Transmission
This section shows an example of performing a slave transmission using the DTC after slave
reception.
(1)
IEB Initialization
(a) Setting the IEBus Control Register (IECTR)
Enable the IEBus pins, select the signal polarity, and select a clock supplied to the IEB. Clear
the LUEE bit to 0 because transfer by the DTC is performed.
(b) Setting the IEBus Master Unit Address Registers 1 and 2 (IEAR1 and IEAR2)
Specify the master unit address and specify the communications mode in IEAR1. Compare
with the slave address in the communications frame and receive the frame if matched.
(c) Setting the IEBus Transmit Message Length Register (IETBFL)
Specify the message length bits.
(d) Setting the IEBus Transmit/Runaway Interrupt Enable Register (IEIET)
Enable the TxRDY (IETxI), TxS, and TxE (IETSI) interrupts.
The above registers can be specified in any order. (The register specification order does not affect
the IEB operation.)
(2)
DTC Initialization
1. Set the start address of the RAM which stores the register information necessary for the DTC
transfer in the vector address (H'000004D4) to be accessed a DTC transfer request is
generated.
2. Set the following data from the start address of the RAM.
⎯ Transfer source address (SAR): Start address of the RAM which stores data to be
transmitted from the data field.
⎯ Transfer destination address (DAR): Address (H'FFF808) of the IEBus transmit buffer
register (IETBR)
⎯ Transfer count (CRA): The same value as IETBFL
3. Set bit DTCEG5 in the DTC enabler register G (DTCERG), and enable the TxRDY interrupt
(IETxI).
Because the TxRDY flag is retained after reset, the DTC transfer is executed when the IETxI is
enabled and the first data field data is written to IETBR. The DTC negates the TxRDY flag
and the DTC transfer of the first byte is completed.
Rev. 6.00 Sep. 24, 2009 Page 599 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
(3)
Slave Transmission Flow
Figure 17.12 shows the slave transmission flow. Numbers in the following description correspond
to the numbers in Figure 17.12.
1. After the IEB and DTC have been initialized, a slave communications request command is
issued from IECMR. During slave reception, the command execution status flag (CMX) in
IEFLG is set and the slave communications request will not be issued.
2. The CMX flag is cleared when the slave reception is completed, the slave communications
command is executed, and the SRQ flag is set.
3. If data up to the control field has been received correctly and if the contents of the control bits
is H'3 or H'7, the transmit start detection flag (TxS) in IETSR register is set to 1. In this case,
the TxS flag is cleared in the TxS interrupt handling routine.
4. The slave then transmits the message length field, and the IEB loads the transmit data in the
data field from IETBR when the ACK is received. Then the TxRDY flag is set to 1. A DTC
transfer request by IETxI is generated and the second byte data is written to the transmit
buffer.
5. Similarly, the above data field load and transmission operations are repeated.
6. The DTC completes the data transfer for the number of specified bytes when data to be
transmitted in the last byte is written to. At this time, the DTC does not clear the TxRDY flag.
It, however, clears bit DTCEG5 in the DTC enable register G (DTCERG) not to generate more
DTC transfer request.
7. A TxRDY interrupt (IETxI) is issued to the CPU when the DTC transfer is completed. In this
interrupt handling routine, the TxRDY flag can be cleared. However, since the TxRDY
interrupt will be generated again after the last byte transfer, the TxRDY flag remains set. (Note
that the LUEE bit should be cleared to 0 because an underrun error occurs to terminate the
transfer if the LUEE bit in IECTR is set to 1.) Note, however, that the TxRDY interrupt should
be disabled because the TxRDY interrupt is always generated.
8. After the last data transfer has been completed, a transmit normal completion (TxF) interrupt
occurs. In this case, the CPU clears the TxF flag and completes the normal completion
interrupt and clears the SRQ flag to 0.
Notes: 1. As a transmit status interrupt (IETSI), a transmit error termination (TxE) interrupt as
well as the transmit start detection (TxS) and transmit normal completion (TxF)
interrupts must be enabled. If a transmit error completion interrupt is disabled, no
interrupt is generated even if the transfer is terminated by an error.
2. If the control bits sent from the master unit is H'0, H'4, H'5, or H'6 in slave
transmission, the IEB automatically performs processing and the TxS and TxF flags are
not set.
Rev. 6.00 Sep. 24, 2009 Page 600 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
H: Header, MA: Master address field, SA: Slave address field,
CF: Control field, LF: Message length field, D1, D2,..., Dn-1, Dn: Data field
Slave reception
LF
Dn-1
Slave transmission
Dn
H
MA
SA
CF
LF
D1
D2
Dn-1
Dn
IECMR
Slave transmission request
IEFLG
(1)
(2)
CMX
MRQ
SRQ
(8)
(2)
SRE
DTC transfer
of 2nd byte
IETSR
(4)
TxRDY Cleared to 0 byt DTC transfer of 1st byte
TxS
(5)
DTC transfer
of 3rd byte
DTC transfer
of nth byte
(6)
(3)
(8)
TxF
Interrupt
(4)
IETxI (TxRDY)
(TO DTC)
(5)
(6)
(7)
IETxI (TxRDY)
(TO CPU)
IETSI
(TO CPU)
(3)
(8)
Figure 17.12 Slave Transmit Operation Timing
Rev. 6.00 Sep. 24, 2009 Page 601 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.5
Interrupt Sources
Figures 17.13 and 17.14 show the transmit and receive interrupt sources, respectively.
IETSR
IETxI (TxRDY interrupt)
IEIET
TxRDY
DTC
TxRDYE
IRA
IRAE
TxS
CPU
IETSI
(Transmit status
interrupt)
TxSE
IETEF
TxF
AL
TxFE
UE
(*)
TTME
TxE
TxEE
RO
ACK
Note: * The TxE flag is set at the timing when an error source of IETEF occurs. The TxE flag can be cleared even
when the error source flag in IETEF is set to 1 because the TxE flag is not logically ORed with flags in IETEF.
Figure 17.13 Relationships among Transfer Interrupt Sources
IEIER
IERSR
IERxI (RxRDY interrupt)
RxRDY
DTC
RxRDYE
RxS
RxSE
IEREF
CPU
IERSI
(Transmit status
interrupt)
RxF
OVE
RxFE
RTME
RxEE
DLE
(*)
RxE
PE
Note: * The RxE flag is set at the timing when an error source of IEREF occurs. The RxE flag can be cleared even
when the error source flag in IEREF is set to 1 because the RxE flag is not logically ORed with flags in IEREF.
Figure 17.14 Relationships among Receive Interrupt Sources
Rev. 6.00 Sep. 24, 2009 Page 602 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.6
Usage Notes
17.6.1
Setting Module Stop Mode
The IEB is enabled or disabled by setting the module stop control register. In the initial state, the
IEB is disabled. After the module stop mode is canceled, registers can be accessed. For details, see
section 22, Power-Down Modes.
17.6.2
TxRDY Flag and Underrun Error
1. The TxRDY flag indicates that IETBR is empty. Writing to IETBR by the DTC clears the
TxRDY flag. Meanwhile, the TxRDY flag must be cleared by software since writing to IETBR
by the CPU does not clear the TxRDY flag.
2. If the CPU fails to write to IETBR by the timing of the frame transmission or if the number of
transfer words is less than the length specified by the message length bits, an underrun error
occurs.
3. The IEB decides that an underrun error occurred when the data is loaded from IETBR to the
transmit shift register while the TxRDY flag is set to 1. In this case, the IEB sets the TxE flag
in IETSR and enters the wait state. The UE flag in IETEF is also set to 1.
4. On the receive side, the unit decides that a timing error has occurred because the
communications are terminated.
5. In data transfer using the DTC, the TxRDY flag in IETSR is not cleared after the last byte data
is transferred to IETBR and a CPU interrupt caused by the DTC interrupt will occur.
If the TxRDY flag is not cleared in this CPU interrupt handling routine, an underrun error will
occur when the last byte data is loaded from IETBR to the transmit shift register. In this case,
if the LUEE bit is cleared to 0 (initial value), no underrun error occurs and the last byte of the
data field is transmitted correctly. (if the LUEE bit is set to 1, an underrun error occurs.)
6. Although the DTC is used as described in item 5, if the number of DTC transfer words is less
than the length specified by the message length bits, the LUEE bit setting is invalid. (The
LUEE bit is valid only when data is transmitted for the number of bytes specified by the
message length bits has been transmitted.) In this case, an underrun error occurs, data is
transmitted for one byte less than the DTC transfer words, and the transfer is terminated by a
transmit error.
Rev. 6.00 Sep. 24, 2009 Page 603 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.6.3
RxRDY Flag and Overrun Error
1. The RxRDY flag indicates that IERBR stores data. Reading from IERBR by the DTC clears
the RxRDY flag. Meanwhile, the RxRDY flag must be cleared by software since reading from
IERBR by the CPU does not clear the RxRDY flag.
2. If the CPU fails to read from IERBR by the timing of the frame reception or if the number of
transfer words is less than the length specified by the message length bits, an overrun error
occurs.
3. The IEB receives data while the RxRDY flag is set and sets the OVE flag when the parity bit
reception starts. If the OVE flag is set when the acknowledge bit is transmitted, the IEB
assumes that an overrun error has occurred, returns a NAK, and discards the data in the receive
shift register.
4. On the transmit side, the unit continues retransfer until an ACK is received because it receives
a NAK.
5. If the OVE flag is cleared without loading the receive data from IERBR in the RxE interrupt
handling routine caused when the OVE flag is set to 1, the IEB decides that the overrun error
has been cleared and sends an ACK to other units. In this case, the transmit unit completes the
communications correctly. However, no receive data is loaded from the IERBR and the receive
unit continues reception. Accordingly, in an interrupt handling routine caused by the OVE
flag, receive data must be loaded from IERBR, the RxRDY flag must be cleared. The DTC,
thus, should be ready to receive the next byte, and then the OVE flag must be cleared.
6. Item 5 above will not occur when the DTC transfer words is specified as the IERBFL value.
17.6.4
(1)
Error Flag s in the IETEF
AL Flag
The AL Flag is set to 1 when arbitration is lost even if retransfer is performed for the number of
times specified by IEMCR after arbitration has been lost. The AL flag is not set when arbitration
is won during retransfer. If the AL flag is set to 1, the TxE flag is set and the wait state is entered.
(2)
UE Flag
If the UE flag is set to 1, the TxE flag is set and the wait state is entered. For details, see section
17.6.2, TxRDY Flag and Underrun Error.
(3)
TTME Flag
If a timing error occurs during data transfer, the TTME and TxE flags are set, and the wait state is
entered.
Rev. 6.00 Sep. 24, 2009 Page 604 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
(4)
RO Flag
When retransfer is performed up to the maximum number of transfer bytes defined by the protocol
because of reception of a NAK from the receive side during data field transmission, the number of
transferred bytes may be less than that of bytes specified by the message length. At this time the
RO flag is set. Moreover, when the value of the message length bits is greater than the maximum
number of transfer bytes, the RO flag is also set. The RO flag is not set if the maximum number of
transfer bytes defined by the protocol is specified (for example, 32-byte message length is
specified in mode 1) and the transfer is performed correctly.
If the RO flag is set to 1, the TxE flag is set to 1 and the wait state is entered.
(5)
ACK Flag
• If a NAK is received in an acknowledge bit before the message length field transmission, the
ACK flag is set, the TxE flag is set, and then the wait state is entered.
• If a NAK is received in an acknowledge bit of the data field, data is automatically
retransmitted up to the maximum number of transfer bytes defined by the protocol. If an ACK
is received in an acknowledge bit during retransfer and the following data is transmitted
correctly, the ACK flag is not set. If a NAK is received in the last data transfer during the
retransfer for the maximum number of transfer bytes, the ACK flag is set to 1 and the wait
state is entered.
Note: Even if a NAK is received from the receive side during the data field transmission,
retransfer is performed up to the maximum number of transfer bytes defined by the
protocol, and the number of transferred bytes is less than that of bytes specified by the
message length bits, an ACK may be received in the acknowledge bit in the last data
transfer. In this case, the ACK flag is not set although the RO flag is set.
17.6.5
(1)
Error Flags in IEREF
OVE Flag
When the OVE flag is set, the RxE flag is also set. If an overrun error is cleared and the OVE flag
is also cleared, the IEBus receive operation is continued. For details, see section 17.6.3, RxRDY
Flag and Overrun Error.
(2)
RTME Flag
If a timing error occurs during data reception after reception starts (the RxS flag is set to 1), the
RTME flag is set to 1, RxE flag is set to 1, and the wait state is entered. When a timing error
occurs before reception starts, this flag is not set and the reception frame is discarded.
Rev. 6.00 Sep. 24, 2009 Page 605 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
(3)
DLE Flag
When retransfer is performed up to the maximum number of transfer bytes defined by the protocol
because of reception of a NAK caused by a parity or an overrun error during data field reception,
the number of transferred bytes may be greater than that of bytes specified by the message length.
At this time the DLE flag is set. Moreover, when the value of the message length bits is greater
than the maximum number of transfer bytes, the DLE flag is also set. The DLE flag is not set if
the maximum number of transfer bytes defined by the protocol is specified and the transfer is
performed correctly.
If the DLE flag is set to 1, the RxE flag is set to 1 and the wait state is entered.
(4)
PE Flag
If a parity error occurs after reception starts (the RxS flag is set to 1), a NAK is sent to perform rereception.
If a parity error is not cleared when the maximum number of transfer bytes specified by the
protocol is received, the PE flag is set to 1, the RxE flag is set to 1 and the wait state is entered. If
a parity error is cleared during the rereception and if the following data is received correctly, the
PE flag is not set.
Notes: 1. If the reception is performed up to the maximum number of transfer bytes defined by
the protocol because of a parity or an overrun error during data field reception, the
number of receive bytes is less than that of bytes specified by the message length bits,
no parity error or overrun error may occur at the last byte reception. In this case, the
DLE flag is set. However, the OVE and PE flags are not set.
2. The flags in IEREF are set after reception starts. Accordingly, the RxE flag is valid and
set after the RxS flag has been set. If an error occurs before reception starts, the frame
is discarded and no interrupt occurs.
17.6.6
Notes on Slave Transmission
When the slave unit transmits the slave status and upper and lower locked addresses, a parity or an
overrun error occurs in the master reception side and the data cannot be received. Accordingly,
even if a NAK is returned, the slave unit is not capable of retransfer.
In this case, the master unit must discard the frame in which an error occurred and request the
above operation in the master reception to receive the correct frame.
Rev. 6.00 Sep. 24, 2009 Page 606 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.6.7
Notes on DTC Specification
When transmit or receive data is transferred by the DTC, bit 5 (for transmission) or bit 6 (for
reception) in DTCERG must be set by the bit manipulation instruction (such as BSET or BCLR).
In this case, other bits (bits 7 and 4 to 0) in DTCERG must not be set to 1.
17.6.8
Error Handling in Transmission
Figure 17.15 shows the operation when a timing error occurs.
When a timing error occurs in data transmission (1), there is a possibility that the next data is
already transferred to the transmit buffer by the DTC and the TxRDY flag that is the DTC
initiation source is already cleared to 0 (2).
In this case, if retransfer is performed, data remained in the transmit buffer (previous frame data )
is transmitted as the first byte data of the data field (3).
To avoid this error, in master transmission, the first byte data in the data field should be written to
the transmit buffer by software instead of using the DTC. After that, data can be transferred by the
DTC. In this case, the SAR (transfer source address) and CRA (transfer counter) should be
specified as follows.
• An address of the on-chip memory that stores the second byte data → SAR
• The number of bytes specified by message length –1 → CRA
Retransfer frame
Transmit error frame
(3)
S
IETSR
TxRDY
IETEF
TTME
MA
SA
CF
1st byte data
transferred
by DTC
LF
D1
2nd byte data
transferred
by DTC
S
MA
SA
CF
Timing error
LF
D2 D1
1st byte data
transferred
by DTC
(2)
(1)
Legend:
S: Start bit, broadcast bit
MA: Master address field
SA: Slave address field
CF: Control field
LF: Message length field
D1, D2, ...Dn-1, Dn: Data field
Figure 17.15 Error Processing in Transfer
Rev. 6.00 Sep. 24, 2009 Page 607 of 928
REJ09B0099-0600
Section 17 IEBus™ Controller (IEB) [H8S/2552 Group]
17.6.9
Power-Down Mode Operation
The IEB stops operation and is initialized in power-down modes such as module stop, watch,
software standby and hardware standby modes.
To initialize the IEB, the module stop mode must be specified. To reduce power consumption
during IEB operation, the sleep mode must be used.
17.6.10 Notes on Middle-Speed Mode
In middle-speed mode, the IEB registers must not be read from or written to.
17.6.11 Notes on Register Access
The IEB registers can be accessed in bytes. The IEB registers must not be accessed in words or
longwords.
Rev. 6.00 Sep. 24, 2009 Page 608 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Section 18 Controller Area Network (HCAN)
[H8S/2556 Group]
The HCAN controls a controller area network (CAN) for realtime communication in vehicular and
industrial equipment systems, etc. For details on CAN specification, refer to Bosch CAN
Specification Version 2.0 1991, Robert Bosch GmbH.
The block diagram of the HCAN is shown in figure 18.1.
18.1
Features
• CAN version: Conforming to Bosch 2.0B active
Communication systems: NRZ (Non-Return to Zero) system (with bit-stuffing function)
Broadcast communication system
Transmission path: Bidirectional 2-wire serial communication
Communication speed: Max. 1 Mbps
Data length: 0 to 8 bytes
• Number of channels: 1
• Data buffers: 16 (one receive-only buffer and 15 buffers settable for transmission/reception)
• Data transmission: Two methods
Mailbox (buffer) number order (low-to-high)
Message priority (identifier) reverse-order (high-to-low)
• Data reception: Two methods
Message identifier match (transmit/receive-setting buffers)
Reception with message identifier masked (receive-only)
• CPU interrupts: 12
Error interrupt
Reset processing interrupt
Message reception interrupt
Message transmission interrupt
• HCAN operating modes
• Support for various modes
Hardware reset
Software reset
Normal status (error-active, error-passive)
Rev. 6.00 Sep. 24, 2009 Page 609 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
HCAN
MBI
Message buffer
Peripheral data bus
Peripheral address bus
Bus off status
HCAN configuration mode
HCAN sleep mode
HCAN halt mode
• Module stop mode can be set
• DTC can be activated by the reception of a message (only in HCAN mailbox 0)
Mailboxes
Message control
Message data
MC0 to MC15,
MD0 to MD15
LAFM
(CDLC)
CAN
Data Link Controller
Bosch CAN 2.0B active
MPI
Microprocessor interface
Tx buffer
Rx buffer
HTxD
HRxD
CPU interface
Control register
Status register
Figure 18.1 HCAN Block Diagram
• Message Buffer Interface (MBI)
The MBI, consisting of mailboxes and a local acceptance filter mask (LAFM), stores CAN
transmit/receive messages (identifiers, data, etc.) Transmit messages are written by the CPU.
For receive messages, the data received by the CDLC is stored automatically.
• Microprocessor Interface (MPI)
The MPI, consisting of a bus interface, control register, status register, etc., controls HCAN
internal data, status, and so forth.
• CAN Data Link Controller (CDLC)
The CDLC transmits and receives of messages conforming to the Bosch CAN Ver. 2.0B active
standard (data frames, remote frames, error frames, overload frames, inter-frame spacing), as
well as CRC checking, bus arbitration, and other functions.
Rev. 6.00 Sep. 24, 2009 Page 610 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.2
Input/Output Pins
Table 18.1 shows the HCAN's pins.
When using HCAN pins, settings must be made in the HCAN configuration mode (during
initialization: MCR0 = 1 and GSR3 = 1).
Table 18.1 Pin Configuration
Name
Abbreviation
Input/Output
Function
HCAN transmit data pin
HTxD
Output
CAN bus transmission pin
HCAN receive data pin
HRxD
Input
CAN bus reception pin
A bus driver is necessary for the interface between the pins and the CAN bus. A Philips
PCA82C250 compatible model is recommended.
18.3
Register Descriptions
The HCAN has the following registers.
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
Master control register (MCR)
General status register (GSR)
Bit configuration register (BCR)
Mailbox configuration register (MBCR)
Transmit wait register (TXPR)
Transmit wait cancel register (TXCR)
Transmit acknowledge register (TXACK)
Abort acknowledge register (ABACK)
Receive complete register (RXPR)
Remote request register (RFPR)
Interrupt register (IRR)
Mailbox interrupt mask register (MBIMR)
Interrupt mask register (IMR)
Receive error counter (REC)
Transmit error counter (TEC)
Unread message status register (UMSR)
Local acceptance filter mask H (LAFMH)
Rev. 6.00 Sep. 24, 2009 Page 611 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
• Local acceptance filter mask L (LAFML)
• Message control (8-bit × 8 registers × 16 sets) (MC0 to MC15)
• Message data (8-bit × 8 registers × 16 sets) (MD0 to MD15)
18.3.1
Master Control Register (MCR)
MCR controls the HCAN.
Bit
Bit Name
Initial
Value
R/W
Description
7
MCR7
0
R/W
HCAN Sleep Mode Release
When this bit is set to 1, the HCAN automatically exits
HCAN sleep mode on detection of CAN bus operation.
6
⎯
0
R
Reserved
This bit is always read as 0. The write value should always
be 0.
5
MCR5
0
R/W
HCAN Sleep Mode
When this bit is set to 1, the HCAN transits to HCAN sleep
mode. When this bit is cleared to 0, HCAN sleep mode is
released.
4, 3
⎯
All 0
R
Reserved
These bits are always read as 0. The write value should
always be 0.
2
MCR2
0
R/W
Message Transmission Method
0: Transmission order determined by message identifier
priority
1: Transmission order determined by mailbox number
priority (TXPR1 > TXPR15)
1
MCR1
0
R/W
Halt Request
When this bit is set to 1, the HCAN transits to HCAN HALT
mode. When this bit is cleared to 0, HCAN HALT mode is
released.
Rev. 6.00 Sep. 24, 2009 Page 612 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Bit
Bit Name
Initial
Value
R/W
Description
0
MCR0
1
R/W
Reset Request
When this bit is set to 1, the HCAN transits to reset mode.
For details, see section 18.4.1, Hardware and Software
Resets.
[Setting conditions]
•
•
•
•
•
•
Power-on reset
Hardware standby
Software standby
Watch mode
Module stop mode
1-write (software reset)
[Clearing condition]
•
18.3.2
When 0 is written to this bit while the GSR3 bit in GSR
is 1
General Status Register (GSR)
GSR indicates the status of the HCAN.
Bit
Bit Name
7 to 4 ⎯
Initial
Value
R/W
All 0
R
Description
Reserved
These bits are always read as 0. The write value should
always be 0.
3
GSR3
1
R
Reset Status Bit
Indicates whether the HCAN module is in the normal
operating state or the reset state. This bit cannot be
modified.
[Setting conditions]
•
When entering configuration mode after the HCAN
internal reset has finished
•
Sleep mode
[Clearing condition]
•
When entering normal operation mode after the MCR0
bit in MCR is cleared to 0 (Note that there is a delay
between clearing of the MCR0 bit and the GSR3 bit.)
Rev. 6.00 Sep. 24, 2009 Page 613 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Bit
Bit Name
Initial
Value
R/W
Description
2
GSR2
1
R
Message Transmission Status Flag
Flag that indicates whether the module is currently in the
message transmission period. This bit cannot be modified.
[Setting condition]
•
Third bit of Intermission after EOF (End of Frame)
[Clearing condition]
•
1
GSR1
0
R
Start of message transmission (SOF)
Transmit/Receive Warning Flag
This bit cannot be modified.
[Setting condition]
When TEC ≥ 96 or REC ≥ 96
[Clearing conditions]
0
GSR0
0
R
•
When TEC < 96 and REC < 96
•
When TEC ≥ 256 (bus off state)
Bus Off Flag
This bit cannot be modified.
[Setting condition]
•
When TEC ≥ 256 (bus off state)
[Clearing condition]
•
Rev. 6.00 Sep. 24, 2009 Page 614 of 928
REJ09B0099-0600
Recovery from bus off state
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.3
Bit Configuration Register (BCR)
BCR is used to set HCAN bit timing parameters and the baud rate prescaler. For details on
parameters, see section 18.4.2, Initialization after Hardware Reset.
Bit
Bit Name
Initial
Value
R/W
Description
15
BCR7
0
R/W
Re-Synchronization Jump Width (SJW)
14
BCR6
0
R/W
Set the maximum bit synchronization width.
00: 1 time quantum
01: 2 time quanta
10: 3 time quanta
11: 4 time quanta
13
BCR5
0
R/W
Baud Rate Prescaler (BRP)
12
BCR4
0
R/W
Set the length of time quantum.
11
BCR3
0
R/W
000000: 2 × system clock
10
BCR2
0
R/W
000001: 4 × system clock
9
BCR1
0
R/W
000010: 6 × system clock
8
BCR0
0
R/W
:
111111: 128 × system clock
7
BCR15
0
R/W
Bit Sample Point (BSP)
Sets the point at which data is sampled.
0: Bit sampling at one point (end of time segment 1
(TSEG1))
1: Bit sampling at three points (end of TSEG1 and
preceding and following one time quantum)
Rev. 6.00 Sep. 24, 2009 Page 615 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Bit
Bit Name
Initial
Value
R/W
Description
6
BCR14
0
R/W
Time Segment 2 (TSEG2)
5
BCR13
0
R/W
Set the TSEG2 width within a range of 2 to 8 time quanta.
4
BCR12
0
R/W
000: Setting prohibited
001: 2 time quanta
010: 3 time quanta
011: 4 time quanta
100: 5 time quanta
101: 6 time quanta
110: 7 time quanta
111: 8 time quanta
3
BCR11
0
R/W
Time Segment 1 (TSEG1)
2
BCR10
0
R/W
1
BCR9
0
R/W
Set the TSEG1 (PRSEG + PHSEG1) width to between 4
and 16 time quanta.
0
BCR8
0
R/W
0000: Setting prohibited
0001: Setting prohibited
0010: Setting prohibited
0011: 4 time quanta
0100: 5 time quanta
0101: 6 time quanta
0110: 7 time quanta
0111: 8 time quanta
1000: 9 time quanta
1001: 10 time quanta
1010: 11 time quanta
1011: 12 time quanta
1100: 13 time quanta
1101: 14 time quanta
1110: 15 time quanta
1111: 16 time quanta
Rev. 6.00 Sep. 24, 2009 Page 616 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.4
Mailbox Configuration Register (MBCR)
MBCR is used to set the transfer direction for each mailbox.
Bit
Bit Name
Initial Value
R/W
Description
15
MBCR7
0
R/W
14
MBCR6
0
R/W
13
MBCR5
0
R/W
These bits set the transfer direction for the
corresponding mailboxes from 1 to 15. MBCRn
determines the transfer direction for mailbox n (n =1
to 15).
12
MBCR4
0
R/W
0: Corresponding mailbox is set for transmission
11
MBCR3
0
R/W
1: Corresponding mailbox is set for reception
10
MBCR2
0
R/W
9
MBCR1
0
R/W
Bit 8 is reserved. This bit is always read as 1 and
the write value should always be 1.
8
⎯
1
R
7
MBCR15
0
R/W
6
MBCR14
0
R/W
5
MBCR13
0
R/W
4
MBCR12
0
R/W
3
MBCR11
0
R/W
2
MBCR10
0
R/W
1
MBCR9
0
R/W
0
MBCR8
0
R/W
Rev. 6.00 Sep. 24, 2009 Page 617 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.5
Transmit Wait Register (TXPR)
TXPR is used to set a transmit wait after a transmit message is stored in a mailbox (buffer) (CAN
bus arbitration wait).
Bit
Bit Name
Initial Value
R/W
Description
15
TXPR7
0
R/W
14
TXPR6
0
R/W
13
TXPR5
0
R/W
These bits set a transmit wait (CAN bus arbitration
wait) for the corresponding mailboxes 1 to 15. When
TXPRn (n = 1 to 15) is set to 1, the message in
mailbox n becomes the transmit wait state.
12
TXPR4
0
R/W
[Clearing conditions]
11
TXPR3
0
R/W
•
Completion of message transmission
10
TXPR2
0
R/W
•
Completion of transmission cancellation
9
TXPR1
0
R/W
8
⎯
0
R
Bit 8 is reserved. This bit is always read as 0 and
the write value should always be 0.
7
TXPR15
0
R/W
6
TXPR14
0
R/W
5
TXPR13
0
R/W
4
TXPR12
0
R/W
3
TXPR11
0
R/W
2
TXPR10
0
R/W
1
TXPR9
0
R/W
0
TXPR8
0
R/W
Rev. 6.00 Sep. 24, 2009 Page 618 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.6
Transmit Wait Cancel Register (TXCR)
TXCR controls the cancellation of transmit wait messages in mailboxes (buffers).
Bit
Bit Name
Initial Value
R/W
Description
15
TXCR7
0
R/W
14
TXCR6
0
R/W
13
TXCR5
0
R/W
These bits cancel the transmit wait message in the
corresponding mailboxes 1 to 15. When TXCRn (n
= 1 to 15) is set to 1, the transmit wait message in
mailbox n is canceled.
12
TXCR4
0
R/W
[Clearing condition]
11
TXCR3
0
R/W
•
10
TXCR2
0
R/W
9
TXCR1
0
R/W
8
⎯
0
R
7
TXCR15
0
R/W
6
TXCR14
0
R/W
5
TXCR13
0
R/W
4
TXCR12
0
R/W
3
TXCR11
0
R/W
2
TXCR10
0
R/W
1
TXCR9
0
R/W
0
TXCR8
0
R/W
Completion of TXPR clearing when transmit
message is canceled normally
Bit 8 is reserved. This bit is always read as 0 and
the write value should always be 0.
Rev. 6.00 Sep. 24, 2009 Page 619 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.7
Transmit Acknowledge Register (TXACK)
TXACK is a status register that indicates the normal transmission of mailbox (buffer) transmit
messages.
Bit
Bit Name
Initial Value
R/W
Description
15
TXACK7
0
R/(W)*
14
TXACK6
0
R/(W)*
13
TXACK5
0
R/(W)*
12
TXACK4
0
R/(W)*
These bits are status flags that indicate error-free
transmission of the transmit message in the
corresponding mailboxes 1 to 15. When the
message in mailbox n (n = 1 to 15) has been
transmitted error-free, TXACKn is set to 1.
11
TXACK3
0
R/(W)*
[Setting condition]
10
TXACK2
0
R/(W)*
•
9
TXACK1
0
R/(W)*
8
⎯
0
R
[Clearing condition]
7
TXACK15
0
R/(W)*
•
Bit 8 is reserved. This bit is always read as 0 and
the write value should always be 0.
6
TXACK14
0
R/(W)*
5
TXACK13
0
R/(W)*
4
TXACK12
0
R/(W)*
3
TXACK11
0
R/(W)*
2
TXACK10
0
R/(W)*
1
TXACK9
0
R/(W)*
0
TXACK8
0
R/(W)*
Note:
*
Completion of message transmission for
corresponding mailbox
Writing 1
Only 1 can be written to this bit for clearing the flag.
Rev. 6.00 Sep. 24, 2009 Page 620 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.8
Abort Acknowledge Register (ABACK)
ABACK is a status register that indicates the normal cancellation (aborting) of mailbox (buffer)
transmit messages.
Bit
Bit Name
Initial Value
R/W
Description
15
ABACK7
0
R/(W)*
14
ABACK6
0
R/(W)*
13
ABACK5
0
R/(W)*
12
ABACK4
0
R/(W)*
These bits are status flags that indicate error-free
cancellation (abortion) of the transmit message in
the corresponding mailboxes 1 to 15. When the
message in mailbox n (n = 1 to 15) has been
canceled error-free, ABACKn is set to 1.
11
ABACK3
0
R/(W)*
[Setting condition]
10
ABACK2
0
R/(W)*
•
9
ABACK1
0
R/(W)*
8
⎯
0
R
[Clearing condition]
7
ABACK15
0
R/(W)*
•
Bit 8 is reserved. This bit is always read as 0. The
write value should always be 0.
6
ABACK14
0
R/(W)*
5
ABACK13
0
R/(W)*
4
ABACK12
0
R/(W)*
3
ABACK11
0
R/(W)*
2
ABACK10
0
R/(W)*
1
ABACK9
0
R/(W)*
0
ABACK8
0
R/(W)*
Note:
*
Completion of transmit message cancellation for
corresponding mailbox
Writing 1
Only 1 can be written to this bit for clearing the flag.
Rev. 6.00 Sep. 24, 2009 Page 621 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.9
Receive Complete Register (RXPR)
RXPR is a status register that indicates the normal reception of messages (data frame or remote
frame) in mailboxes. For reception of a remote frame, when a bit in this register is set to 1, the
corresponding remote request register (RFPR) bit is also set to 1 simultaneously.
Bit
Bit Name
Initial Value
R/W
Description
15
RXPR7
0
R/(W)*
14
RXPR6
0
R/(W)*
When the message in mailbox n (n = 0 to 15) has
been received error-free, RXPRn is set to 1.
13
RXPR5
0
R/(W)*
[Setting condition]
12
RXPR4
0
R/(W)*
•
11
RXPR3
0
R/(W)*
10
RXPR2
0
R/(W)*
9
RXPR1
0
R/(W)*
8
RXPR0
0
R/(W)*
7
RXPR15
0
R/(W)*
6
RXPR14
0
R/(W)*
5
RXPR13
0
R/(W)*
4
RXPR12
0
R/(W)*
3
RXPR11
0
R/(W)*
2
RXPR10
0
R/(W)*
1
RXPR9
0
R/(W)*
0
RXPR8
0
R/(W)*
Note:
*
Completion of message (data frame or remote
frame) reception in corresponding mailbox
[Clearing condition]
•
Writing 1
Only 1 can be written to this bit for clearing the flag.
Rev. 6.00 Sep. 24, 2009 Page 622 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.10 Remote Request Register (RFPR)
RFPR is a status register that indicates normal reception of remote frames in mailboxes (buffers).
When a bit in this register is set to 1, the corresponding receive complete register (RXPR) bit is
also set to 1 simultaneously.
Bit
Bit Name
Initial Value
R/W
Description
15
RFPR7
0
R/(W)*
14
RFPR6
0
R/(W)*
13
RFPR5
0
R/(W)*
When mailbox n (n = 0 to 15) has received the
remote frame error-free, RFPRn (n = 0 to 15) is set
to 1.
12
RFPR4
0
R/(W)*
11
RFPR3
0
R/(W)*
10
RFPR2
0
R/(W)*
9
RFPR1
0
R/(W)*
8
RFPR0
0
R/(W)*
7
RFPR15
0
R/(W)*
6
RFPR14
0
R/(W)*
5
RFPR13
0
R/(W)*
4
RFPR12
0
R/(W)*
3
RFPR11
0
R/(W)*
2
RFPR10
0
R/(W)*
1
RFPR9
0
R/(W)*
0
RFPR8
0
R/(W)*
Note:
*
[Setting condition]
•
Completion of remote frame reception in
corresponding mailbox
[Clearing condition]
•
Writing 1
Only 1 can be written to this bit for clearing the flag.
Rev. 6.00 Sep. 24, 2009 Page 623 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.11 Interrupt Register (IRR)
IRR is an interrupt status flag register.
Bit
Bit Name
Initial
Value
R/W
15
IRR7
0
R/(W)* Overload Frame Recovery Interrupt Flag
Description
[Setting condition]
•
When an overload frame is transmitted in error
active/passive state
[Clearing condition]
•
14
IRR6
0
Writing 1
R/(W)* Bus Off Interrupt Flag
Status flag indicating the bus off state caused by the
transmit error counter.
[Setting condition]
•
When TEC ≥ 256
[Clearing condition]
•
13
IRR5
0
Writing 1
R/(W)* Error Passive Interrupt Flag
Status flag indicating the error passive state caused by the
transmit/receive error counter.
[Setting condition]
•
When TEC ≥ 128 or REC ≥ 128
[Clearing condition]
•
12
IRR4
0
Writing 1
R/(W)* Receive Overload Warning Interrupt Flag
Status flag indicating the error warning state caused by the
receive error counter.
[Setting condition]
•
When REC ≥ 96
[Clearing condition]
•
Rev. 6.00 Sep. 24, 2009 Page 624 of 928
REJ09B0099-0600
Writing 1
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Bit
Bit Name
Initial
Value
R/W
11
IRR3
0
R/(W)* Transmit Overload Warning Interrupt Flag
Description
Status flag indicating the error warning state caused by the
transmit error counter.
[Setting condition]
•
When TEC ≥ 96
[Clearing condition]
•
10
IRR2
0
R
Writing 1
Remote Frame Request Interrupt Flag
Status flag indicating that a remote frame has been
received in a mailbox when MBIMR = 0.
[Setting condition]
•
When remote frame reception is completed, when
corresponding MBIMR = 0
[Clearing condition]
•
9
IRR1
0
R
Clearing of all bits in RFPR (remote request register)
Receive Message Interrupt Flag
Status flag indicating that a mailbox receive message has
been received normally when MBIMR = 0.
[Setting condition]
•
When data frame or remote frame reception is
completed, when corresponding MBIMR = 0
[Clearing condition]
•
Clearing of all bits in RXPR (receive complete register)
Rev. 6.00 Sep. 24, 2009 Page 625 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Bit
Bit Name
Initial
Value
R/W
8
IRR0
1
R/(W)* Reset Interrupt Flag
Description
Status flag indicating that the HCAN module has been
reset. This bit cannot be masked by the interrupt mask
register (IMR). If this bit is not cleared to 0 after entering
power-on reset or returning from software standby mode,
watch mode, or module stop mode, interrupt processing
will start immediately when the interrupt controller enables
interrupts.
[Setting condition]
•
When the reset operation has finished after entering
power-on reset or software standby mode, watch mode,
or module stop mode.
[Clearing condition]
•
7 to 5 ⎯
All 0
⎯
Writing 1
Reserved
These bits are always read as 0. The write value should
always be 0.
4
IRR12
0
R/(W)* Bus Operation Interrupt Flag
Status flag indicating detection of a dominant bit due to bus
operation when the HCAN module is in HCAN sleep mode.
[Setting condition]
•
Bus operation (dominant bit) detection in HCAN sleep
mode
[Clearing condition]
•
3, 2
⎯
All 0
⎯
Writing 1
Reserved
These bits are always read as 0. The write value should
always be 0.
Rev. 6.00 Sep. 24, 2009 Page 626 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Bit
Bit Name
Initial
Value
R/W
Description
1
IRR9
0
R
Unread Interrupt Flag
Status flag indicating that a receive message has been
overwritten before being read.
[Setting condition]
•
When UMSR (unread message status register) is set
[Clearing condition]
•
0
IRR8
0
Clearing of all bits in UMSR (unread message status
register)
R/(W)* Mailbox Empty Interrupt Flag
Status flag indicating that the next transmit message can
be stored in the mailbox.
[Setting condition]
•
When TXPR (transmit wait register) is cleared by
completion of transmission or completion of
transmission abort
[Clearing condition]
•
Note:
*
Writing 1
Only 1 can be written to this bit for clearing the flag.
Rev. 6.00 Sep. 24, 2009 Page 627 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.12 Mailbox Interrupt Mask Register (MBIMR)
MBIMR controls the enabling or disabling of individual mailbox interrupt requests.
Bit
Bit Name
Initial Value
R/W
Description
15
MBIMR7
1
R/W
Mailbox Interrupt Mask (MBIMRx)
14
MBIMR6
1
R/W
13
MBIMR5
1
R/W
12
MBIMR4
1
R/W
When MBIMRn (n = 0 to 15) is cleared to 0, the
interrupt request in mailbox n is enabled. When set
to 1, the interrupt request is masked.
11
MBIMR3
1
R/W
10
MBIMR2
1
R/W
9
MBIMR1
1
R/W
8
MBIMR0
1
R/W
7
MBIMR15
1
R/W
6
MBIMR14
1
R/W
5
MBIMR13
1
R/W
4
MBIMR12
1
R/W
3
MBIMR11
1
R/W
2
MBIMR10
1
R/W
1
MBIMR9
1
R/W
0
MBIMR8
1
R/W
The interrupt source in a transmit mailbox is TXPR
clearing caused by transmission end or
transmission cancellation. The interrupt source in a
receive mailbox is RXPR setting on reception end.
18.3.13 Interrupt Mask Register (IMR)
IMR enables or disables requests by individual interrupt sources of IRR. The interrupt flag cannot
be masked.
Bit
Bit Name
Initial
Value
R/W
Description
15
IMR7
1
R/W
Overload Frame Recovery Interrupt Mask
When this bit is cleared to 0, OVR0 (interrupt request by
IRR7) is enabled. When set to 1, OVR0 is masked.
14
IMR6
1
R/W
Bus Off Interrupt Mask
When this bit is cleared to 0, ERS0 (interrupt request by
IRR6) is enabled. When set to 1, ERS0 is masked.
Rev. 6.00 Sep. 24, 2009 Page 628 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Bit
Bit Name
Initial
Value
R/W
Description
13
IMR5
1
R/W
Error Passive Interrupt Mask
When this bit is cleared to 0, ERS0 (interrupt request by
IRR5) is enabled. When set to 1, ERS0 is masked.
12
IMR4
1
R/W
Receive Overload Warning Interrupt Mask
When this bit is cleared to 0, OVR0 (interrupt request by
IRR4) is enabled. When set to 1, OVR0 is masked.
11
IMR3
1
R/W
Transmit Overload Warning Interrupt Mask
When this bit is cleared to 0, OVR0 (interrupt request by
IRR3) is enabled. When set to 1, OVR0 is masked.
10
IMR2
1
R/W
Remote Frame Request Interrupt Mask
When this bit is cleared to 0, OVR0 (interrupt request by
IRR2) is enabled. When set to 1, OVR0 is masked.
9
IMR1
1
R/W
Receive Message Interrupt Mask
When this bit is cleared to 0, RM1 (interrupt request by
IRR1) is enabled. When set to 1, RMI is masked.
8
⎯
0
R
Reserved
This bit is always read as 0. The write value should always
be 0.
7 to 5 ⎯
All 1
R
Reserved
These bits are always read as 1. The write value should
always be 1.
4
IMR12
1
R/W
Bus Operation Interrupt Mask
When this bit is cleared to 0, OVR0 (interrupt request by
IRR12) is enabled. When set to 1, OVR0 is masked.
3, 2
⎯
All 1
R
Reserved
These bits are always read as 1. The write value should
always be 1.
1
IMR9
1
R/W
Unread Interrupt Mask
When this bit is cleared to 0, OVR0 (interrupt request by
IRR9) is enabled. When set to 1, OVR0 is masked.
0
IMR8
1
R/W
Mailbox Empty Interrupt Mask
When this bit is cleared to 0, SLE0 (interrupt request by
IRR8) is enabled. When set to 1, SLE0 is masked.
Rev. 6.00 Sep. 24, 2009 Page 629 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.14 Receive Error Counter (REC)
REC is an 8-bit read-only register that functions as a counter indicating the number of receive
message errors on the CAN bus. The count value is stipulated in the CAN protocol.
18.3.15 Transmit Error Counter (TEC)
TEC is an 8-bit read-only register that functions as a counter indicating the number of transmit
message errors on the CAN bus. The count value is stipulated in the CAN protocol.
18.3.16 Unread Message Status Register (UMSR)
UMSR is a status register that indicates, for individual mailboxes, that a received message has
been overwritten by a new receive message before being read. When overwritten by a new
message, data in the unread receive message is lost.
Bit
Bit Name
Initial
Value
15
UMSR7
0
14
UMSR6
0
13
UMSR5
0
12
UMSR4
0
11
UMSR3
0
10
UMSR2
0
R/(W)* [Clearing condition]
R/(W)* Writing 1
9
UMSR1
0
R/(W)*
8
UMSR0
0
R/(W)*
7
UMSR15
0
R/(W)*
6
UMSR14
0
R/(W)*
5
UMSR13
0
R/(W)*
4
UMSR12
0
R/(W)*
3
UMSR11
0
R/(W)*
2
UMSR10
0
R/(W)*
1
UMSR9
0
R/(W)*
0
UMSR8
0
R/(W)*
Note:
*
R/W
Description
R/(W)* Indicates that a received massage has been overwritten by
R/(W)* a new message before being read.
R/(W)* [Setting condition]
R/(W)* When a new message is received before RXPR is cleared
Only 1 can be written to this bit for clearing the flag.
Rev. 6.00 Sep. 24, 2009 Page 630 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.17 Local Acceptance Filter Masks (LAFML, LAFMH)
LAFML and LAFMH individually set the identifier bits of the message to be stored in mailbox 0
as Don't Care. For details, see section 18.4.4, Massage Reception. The relationship between the
identifier bits and mask bits are shown in the following.
• LAFML
Bit
Bit Name Initial Value
R/W
Description
15
LAFML7
0
R/W
When this bit is set to 1, ID-7 of the receive message
identifier is not compared.
14
LAFML6
0
R/W
When this bit is set to 1, ID-6 of the receive message
identifier is not compared.
13
LAFML5
0
R/W
When this bit is set to 1, ID-5 of the receive message
identifier is not compared.
12
LAFML4
0
R/W
When this bit is set to 1, ID-4 of the receive message
identifier is not compared.
11
LAFML3
0
R/W
When this bit is set to 1, ID-3 of the receive message
identifier is not compared.
10
LAFML2
0
R/W
When this bit is set to 1, ID-2 of the receive message
identifier is not compared.
9
LAFML1
0
R/W
When this bit is set to 1, ID-1 of the receive message
identifier is not compared.
8
LAFML0
0
R/W
When this bit is set to 1, ID-0 of the receive message
identifier is not compared.
7
LAFML15 0
R/W
When this bit is set to 1, ID-15 of the receive
message identifier is not compared.
6
LAFML14 0
R/W
When this bit is set to 1, ID-14 of the receive
message identifier is not compared.
5
LAFML13 0
R/W
When this bit is set to 1, ID-13 of the receive
message identifier is not compared.
4
LAFML12 0
R/W
When this bit is set to 1, ID-12 of the receive
message identifier is not compared.
Rev. 6.00 Sep. 24, 2009 Page 631 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Bit
Bit Name Initial Value
R/W
Description
3
LAFML11 0
R/W
When this bit is set to 1, ID-11 of the receive
message identifier is not compared.
2
LAFML10 0
R/W
When this bit is set to 1, ID-10 of the receive
message identifier is not compared.
1
LAFML9
0
R/W
When this bit is set to 1, ID-9 of the receive
message identifier is not compared.
0
LAFML8
0
R/W
When this bit is set to 1, ID-8 of the receive
message identifier is not compared.
Bit
Bit Name Initial Value
R/W
Description
15
LAFMH7
0
R/W
When this bit is set to 1, ID-20 of the receive
message identifier is not compared.
14
LAFMH6
0
R/W
When this bit is set to 1, ID-19 of the receive
message identifier is not compared.
13
LAFMH5
0
R/W
When this bit is set to 1, ID-18 of the receive
message identifier is not compared.
All 0
R
Reserved
• LAFMH
12 to 10 ⎯
These bits are always read as 0. The write value
should always be 0.
9
LAFMH1
0
R/W
When this bit is set to 1, ID-17 of the receive
message identifier is not compared.
8
LAFMH0
0
R/W
When this bit is set to 1, ID-16 of the receive
message identifier is not compared.
7
LAFMH15 0
R/W
When this bit is set to 1, ID-28 of the receive
message identifier is not compared.
6
LAFMH14 0
R/W
When this bit is set to 1, ID-27 of the receive
message identifier is not compared.
5
LAFMH13 0
R/W
When this bit is set to 1, ID-26 of the receive
message identifier is not compared.
4
LAFMH12 0
R/W
When this bit is set to 1, ID-25 of the receive
message identifier is not compared.
3
LAFMH11 0
R/W
When this bit is set to 1, ID-24 of the receive
message identifier is not compared.
Rev. 6.00 Sep. 24, 2009 Page 632 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Bit
Bit Name
2
Initial Value
R/W
Description
LAFMH10 0
R/W
When this bit is set to 1, ID-23 of the receive
message identifier is not compared.
1
LAFMH9
0
R/W
When this bit is set to 1, ID-22 of the receive
message identifier is not compared.
0
LAFMH8
0
R/W
When this bit is set to 1, ID-21 of the receive
message identifier is not compared.
Rev. 6.00 Sep. 24, 2009 Page 633 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.3.18 Message Control (MC0 to MC15)
The message control register sets consist of eight 8-bit registers for one mailbox. The HCAN has
16 sets of these registers. Because message control registers are in RAM, their initial values after
power-on are undefined. Be sure to initialize them by writing 0 or 1. Figure 18.2 shows the
register names for each mailbox.
Mail box 0
MC0[1]
MC0[2]
MC0[3]
MC0[4]
MC0[5]
MC0[6]
MC0[7]
MC0[8]
Mail box 1
MC1[1]
MC1[2]
MC1[3]
MC1[4]
MC1[5]
MC1[6]
MC1[7]
MC1[8]
Mail box 2
MC2[1]
MC2[2]
MC2[3]
MC2[4]
MC2[5]
MC2[6]
MC2[7]
MC2[8]
Mail box 3
MC3[1]
MC3[2]
MC3[3]
MC3[4]
MC3[5]
MC3[6]
MC3[7]
MC3[8]
Mail box 15
MC15[1] MC15[2] MC15[3] MC15[4] MC15[5] MC15[6] MC15[7] MC15[8]
Figure 18.2 Message Control Register Configuration
The setting of message control registers are shown in the following. Figures 18.3 and 18.4 show
the correspondence between the identifiers and register bit names.
SOF
ID-28 ID-27
ID-18
RTR
IDE
R0
identifier
Figure 18.3 Standard Format
SOF
ID-28 ID-27
ID-18
Standard identifier
SRR
IDE
ID-17 ID-16
Extended identifier
Figure 18.4 Extended Format
Rev. 6.00 Sep. 24, 2009 Page 634 of 928
REJ09B0099-0600
ID-0
RTR
R1
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Register
Name
Bit
Bit Name
R/W
Description
MCx[1]
7 to 4
⎯
R/W
The initial value of these bits is undefined; they
must be initialized (by writing 0 or 1).
3 to 0
DLC3 to DLC0
R/W
Data Length Code
Set the data length of a data frame or the data
length requested in a remote frame within the
range of 0 to 8 bytes.
0000: 0 bytes
0001: 1 byte
0010: 2 bytes
0011: 3 bytes
0100: 4 bytes
0101: 5 bytes
0110: 6 bytes
0111: 7 bytes
1000: 8 bytes
:
:
1111: 8 bytes
MCx[2]
7 to 0
⎯
R/W
MCx[3]
7 to 0
⎯
R/W
MCx[4]
7 to 0
⎯
R/W
MCx[5]
7 to 5
ID-20 to ID-18
R/W
Sets ID-20 to ID-18 in the identifier.
4
RTR
R/W
Remote Transmission Request
The initial value of these bits is undefined; they
must be initialized (by writing 0 or 1).
Used to distinguish between data frames and
remote frames.
0: Data frame
1: Remote frame
3
IDE
R/W
Identifier Extension
Used to distinguish between the standard format
and extended format of data frames and remote
frames.
0: Standard format
1: Extended format
2
⎯
R/W
The initial value of this bit is undefined. It must be
initialized by writing 0 or 1.
1, 0
ID-17 to ID-16
R/W
Sets ID-17 and ID-16 in the identifier.
Rev. 6.00 Sep. 24, 2009 Page 635 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Register
Name
Bit
Bit Name
R/W
Description
MCx[6]
7 to 0
ID-28 to ID-21
R/W
Sets ID-28 to ID-21 in the identifier.
MCx[7]
7 to 0
ID-7 to ID-0
R/W
Sets ID-7 to ID-0 in the identifier.
MCx[8]
7 to 0
ID-15 to ID-8
R/W
Sets ID-15 to ID-8 in the identifier.
Note: x: Mailbox number
18.3.19 Message Data (MD0 to MD15)
The message data register sets consist of eight 8-bit registers for one mailbox. The HCAN has 16
sets of these registers. Because message data registers are in RAM, their initial values after poweron are undefined. Be sure to initialize them by writing 0 or 1. Figure 18.5 shows the register
names for each mailbox.
Mail box 0
MD0[1]
MD0[2]
MD0[3]
MD0[4]
MD0[5]
MD0[6]
MD0[7]
MD0[8]
Mail box 1
MD1[1]
MD1[2]
MD1[3]
MD1[4]
MD1[5]
MD1[6]
MD1[7]
MD1[8]
Mail box 2
MD2[1]
MD2[2]
MD2[3]
MD2[4]
MD2[5]
MD2[6]
MD2[7]
MD2[8]
Mail box 3
MD3[1]
MD3[2]
MD3[3]
MD3[4]
MD3[5]
MD3[6]
MD3[7]
MD3[8]
Mail box 15
MD15[1] MD15[2] MD15[3] MD15[4] MD15[5] MD15[6] MD15[7] MD15[8]
Figure 18.5 Message Data Configuration
Rev. 6.00 Sep. 24, 2009 Page 636 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.4
Operation
18.4.1
Hardware and Software Resets
The HCAN can be reset by a hardware reset or software reset.
• Hardware Reset
At power-on reset, or in hardware standby mode, software standby mode, watch mode, or
module stop mode, the HCAN is initialized by automatically setting the MCR reset request bit
(MCR0) in MCR and the reset state bit (GSR3) in GSR. At the same time, all internal
registers, except for message control and message data registers, are initialized by a hardware
reset.
• Software Reset
The HCAN can be reset by setting the MCR reset request bit (MCR0) in MCR via software. In
a software reset, the error counters (TEC and REC) are initialized, however other registers are
not. If the MCR0 bit is set while the CAN controller is performing a communication operation
(transmission or reception), the initialization state is not entered until message transfer has
been completed. The reset status bit (GSR3) in GSR is set on completion of initialization.
18.4.2
Initialization after Hardware Reset
After a hardware reset, the following initialization processing should be carried out:
1.
2.
3.
4.
5.
Clearing of IRR0 bit in the interrupt register (IRR)
Bit rate setting
Mailbox transmit/receive settings
Mailbox (RAM) initialization
Message transmission method setting
These initial settings must be made while the HCAN is in bit configuration mode. Configuration
mode is a state in which the GSR3 bit in GSR is set to 1 by a reset. Configuration mode is exited
by clearing the MCR0 bit in MCR to 0; when the MCR0 bit is cleared to 0, the HCAN
automatically clears the GSR3 bit in GSR. There is a delay between clearing the MCR0 bit and
clearing the GSR3 bit because the HCAN needs time to be internally reset, there is a delay
between clearing of the MCR0 bit and GSR3 bit. After the HCAN exits configuration mode, the
power-up sequence begins, and communication with the CAN bus is possible as soon as 11
consecutive recessive bits have been detected.
Rev. 6.00 Sep. 24, 2009 Page 637 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
IRR0 Clearing: The reset interrupt flag (IRR0) is always set after a power-on reset, recovery
from software standby mode and watch mode, or canceling module standby mode. As an HCAN
interrupt is initiated immediately when interrupts are enabled, IRR0 should be cleared.
Hardware reset
: Settings by user
: Processing by hardware
MCR0 = 1 (automatic)
IRR0 = 1 (automatic)
GSR3 = 1 (automatic)
Initialization of HCAN module
Bit configuration mode
Period in which BCR, MBCR, etc.,
are initialized
Clear IRR0
BCR setting
MBCR setting
Mailbox initialization
Message transmission method setting
MCR0 = 0
GSR3 = 0?
No
Yes
IMR setting (interrupt mask setting)
MBIMR setting (interrupt mask setting)
MC[x] setting (receive identifier setting)
LAFM setting (receive identifier mask setting)
GSR3 = 0 & 11
recessive bits received?
No
Yes
Can bus communication enabled
Figure 18.6 Hardware Reset Flowchart
Rev. 6.00 Sep. 24, 2009 Page 638 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
MCR0=1
: Setting by user
Bus idle?
No
: Processing by hardware
Y
GSR3=1 (automatic)
Initialization of REC and TEC only
BCR setting
MBCR setting
Mailbox (RAM) initialization
Message translation method
setting
OK?
Correction
No
Yes
GSR3=1?
No
Yes
MCR0=0
GSR3=0?
No
Yes
Correction
IMR setting
MBCR setting
MC[x] setting
LAFM setting
OK?
No
Yes
GSR3=0 &
recessive bits received?
No
Yes
CAN bus communication enabled
Figure 18.7 Software Reset Flowchart
Rev. 6.00 Sep. 24, 2009 Page 639 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Bit Rate and Bit Timing Settings: The bit rate and bit timing settings are made in the bit
configuration register (BCR). Settings should be made such that all CAN controllers connected to
the CAN bus have the same baud rate and bit width. The 1-bit time consists of the total of the
settable time quantum (TQ). Though BCR can always be written to, it should not be modified in
other than configuration mode.
1-bit time (8 to 25 time quanta)
SYNC_SEG
PRSEG
PHSEG1
PHSEG2
Time segment 1 (TSEG1)
Time segment 2
(TSEG2)
4 to 16 time quanta
2 to 8 time quanta
1 time quantaum
Figure 18.8 Detailed Description of One Bit
SYNC_SEG is a segment for establishing the synchronization of nodes on the CAN bus. Normal
bit edge transitions occur in this segment. PRSEG is a segment for compensating for the physical
delay between networks. PHSEG1 is a buffer segment for correcting phase drift (positive). This
segment is extended when synchronization (resynchronization) is established. PHSEG2 is a buffer
segment for correcting phase drift (negative). This segment is shortened when synchronization
(resynchronization) is established. Limits on the settable value (TSEG1, TSEG2, BRP, BSP, and
SJW) are shown in table 18.2.
Table 18.2 Limits for Settable Value
Name
Time segment 1
Abbreviation
TSEG1
Min. Value
3
B'0011*
2
Max. Value
B'1111
Time segment 2
TSEG2
B'001*
Baud rate prescaler
BRP
B'000000
Bit sample point
BSP
B'0
B'1
Re-synchronization jump width
SJW*1
B'00
B'11
Notes: 1. SJW is stipulated in the CAN specifications:
3 ≥ SJW ≥ 0
2. The minimum value of TSEG2 is stipulated in the CAN specifications:
TSEG2 ≥ SJW
3. The minimum value of TSEG1 is stipulated in the CAN specifications:
TSEG1 > TSEG2
Rev. 6.00 Sep. 24, 2009 Page 640 of 928
REJ09B0099-0600
B'111
B'111111
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Time quantum (TQ) is an integer multiple of the number of system clocks, and is determined by
the baud rate prescaler (BRP) as follows. fCLK is the system clock frequency.
TQ = 2 × (BRP setting + 1)/fCLK
The following formula is used to calculate the 1-bit time and bit rate.
1-bit time = TQ × (3 + TSEG1 + TSEG2)
Bit rate = 1/Bit time
= fCLK/{2 × (BRP setting + 1) × (3 + TSEG1 + TSEG2)}
Note: fCLK = φ (system clock)
BCR value is used for BRP, TSEG1, and TSEG2.
Example: With a system clock of 20 MHz, a BRP setting of B'000000, a TSEG1 setting of
B'0100, and a TSEG2 setting of B'011:
Bit rate = 20/{2 × (0 + 1) × (3 + 4 + 3)} = 1 Mbps
Rev. 6.00 Sep. 24, 2009 Page 641 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Table 18.3 Setting Range for TSEG1 and TSEG2 in BCR
TSEG2 (BCR[14:12])
001
010
011
100
101
110
111
2
3
4
5
6
7
8
TSEG1
0011
No
Yes
No
No
No
No
No
(BCR[11:8])
0100
Yes*
Yes
Yes
No
No
No
No
0101
Yes*
Yes
Yes
Yes
No
No
No
0110
Yes*
Yes
Yes
Yes
Yes
No
No
0111
Yes*
Yes
Yes
Yes
Yes
Yes
No
1000
Yes*
Yes
Yes
Yes
Yes
Yes
Yes
1001
Yes*
Yes
Yes
Yes
Yes
Yes
Yes
1010
Yes*
Yes
Yes
Yes
Yes
Yes
Yes
1011
Yes*
Yes
Yes
Yes
Yes
Yes
Yes
1100
Yes*
Yes
Yes
Yes
Yes
Yes
Yes
1101
Yes*
Yes
Yes
Yes
Yes
Yes
Yes
1110
Yes*
Yes
Yes
Yes
Yes
Yes
Yes
1111
Yes*
Yes
Yes
Yes
Yes
Yes
Yes
Note:
The time quantum value for TSEG1 and TSEG2 is the TSEG value + 1.
* When baud rate prescaler (BRP), BCR[13:8], is not B'000000 (2 × system clock), this
can be set.
Mailbox Transmit/Receive Settings: The HCAN has 16 mailboxes. Mailbox 0 is receive-only,
while mailboxes 1 to 15 can be set for transmission or reception. The Initial status of mailboxes 1
to 15 is for transmission. Mailbox transmit/receive settings are not initialized by a software reset.
Clearing a bit to 0 in the mailbox configuration register (MBCR) designates the corresponding
mailbox for transmission use, whereas a setting of 1 in MBCR designates the corresponding
mailbox for reception use. When setting mailboxes for reception, in order to improve message
reception efficiency, high-priority messages should be set in low-to-high mailbox order.
Mailbox (Message Control/Data) Initial Settings: Message control/data are held in RAM, and
so their initial values are undefined after power is supplied. Initial values must therefore be set in
all the mailboxes (by writing 0s or 1s).
Setting the Message Transmission Method: The following two kinds of message transmission
methods are available.
Rev. 6.00 Sep. 24, 2009 Page 642 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
• Transmission order determined by message identifier priority
• Transmission order determined by mailbox number priority
Either of the message transmission methods can be selected with the message transmission method
bit (MCR2) in the master control register (MCR): When messages are set to be transmitted
according to the message identifier priority, if several messages are designated as waiting for
transmission (TXPR = 1), the message with the highest priority in the message identifier is stored
in the transmit buffer. CAN bus arbitration is then carried out for the message stored in the
transmit buffer, and the message is transmitted when the transmission right is acquired. When the
TXPR bit is set, the highest-priority message is found and stored in the transmit buffer.
When messages are set to be transmitted according to the mailbox number priority, if several
messages are designated as waiting for transmission (TXPR = 1), messages are stored in the
transmit buffer in low-to-high mailbox order. CAN bus arbitration is then carried out for the
message stored in the transmit buffer, and the message is transmitted when the transmission right
is acquired.
18.4.3
Message Transmission
Messages are transmitted using mailboxes 1 to 15. The transmission procedure after initial settings
is described below, and a transmission flowchart is shown in figure 18.9.
Rev. 6.00 Sep. 24, 2009 Page 643 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Initialization (after hardware reset only)
Clear IRR0
BCR setting
MBCR setting
Mailbox initialization
Message transmission method setting
: Settings by user
: Processing by hardware
Interrupt settings
Transmit data setting
Arbitration field setting
Control field setting
Data field setting
Message transmission wait
TXPR setting
Bus idle?
No
Yes
Message transmission
GSR2 = 0 (during transmission only)
Transmission completed?
No
Yes
TXACK = 1
IRR8 = 1
IMR8 = 1?
Yes
No
Interrupt to CPU
Clear TXACK
Clear IRR8
End of transmission
Figure 18.9 Transmission Flowchart
CPU Interrupt Source Settings: The CPU interrupt source is set by the interrupt mask register
(IMR) and mailbox interrupt mask register (MBIMR). Transmission acknowledge and
transmission abort acknowledge interrupts can be generated for individual mailboxes in the
Rev. 6.00 Sep. 24, 2009 Page 644 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
mailbox interrupt mask register (MBIMR). Interrupt sources of the interrupt register (IRR) can be
masked by IMR.
Arbitration Field Setting: The arbitration field is set by message control registers MCx[5] to
MCx[8] in a transmit mailbox. For a standard format, an 11-bit identifier (ID-28 to ID-18) and the
RTR bit are set, and the IDE bit is cleared to 0. For an extended format, a 29-bit identifier (ID-28
to ID-0) and the RTR bit are set, and the IDE bit is set to 1.
Control Field Setting: In the control field, the byte length of the data to be transmitted is set
within the range of zero to eight bytes. The register to be set is the message control register
MCx[1] in a transmit mailbox.
Data Field Setting: In the data field, the data to be transmitted is set within the range zero to
eight. The registers to be set are the message data registers MDx[1] to MDx[8]. The byte length of
the data to be transmitted is determined by the data length code in the control field. Even if data
exceeding the value set in the control field is set in the data field, up to the byte length set in the
control field will actually be transmitted.
Message Transmission: If the corresponding mailbox transmit wait bit (TXPR1 to TXPR15) in
the transmit wait register (TXPR) is set to 1 after message control and message data registers have
been set, the message enters transmit wait state. If the message is transmitted error-free, the
corresponding acknowledge bit (TXACK1 to TXACK15) in the transmit acknowledge register
(TXACK) is set to 1, and the corresponding transmit wait bit (TXPR1 to TXPR15) in the transmit
wait register (TXPR) is automatically cleared to 0. Also, if the corresponding bit (MBIMR1 to
MBIMR15) in the mailbox interrupt mask register (MBIMR) and the mailbox empty interrupt bit
(IRR8) in the interrupt mask register (IMR) are both simultaneously set to enable interrupts,
interrupts may be sent to the CPU.
If transmission of a transmit message is aborted in the following cases, the message is
retransmitted automatically:
• CAN bus arbitration failure (failure to acquire the bus)
• Error during transmission (bit error, stuff error, CRC error, frame error, or ACK error)
Message Transmission Cancellation: Transmission cancellation can be specified for a message
stored in a mailbox as a transmit wait message. A transmit wait message is canceled by setting the
bit for the corresponding mailbox (TXCR1 to TXCR15) to 1 in the transmit cancel register
(TXCR). Clearing the transmit wait register (TXPR) does not cancel transmission. When
cancellation is executed, the transmit wait register (TXPR) is automatically reset, and the
corresponding bit is set to 1 in the abort acknowledge register (ABACK). An interrupt to the CPU
can be requested, and if the mailbox empty interrupt (IRR8) is enabled for the bits (MBIMR1 to
Rev. 6.00 Sep. 24, 2009 Page 645 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
MBIMR15) corresponding to the mailbox interrupt mask register (MBIMR) and interrupt mask
register (IMR), interrupts may be sent to the CPU.
However, a transmit wait message cannot be canceled at the following times:
• During internal arbitration or CAN bus arbitration
• During data frame or remote frame transmission
Figure 18.10 shows a flowchart for transmit message cancellation.
Message transmit wait TXPR setting
: Settings by user
: Processing by hardware
Set TXCR bit corresponding to
message to be canceled
No
Cancellation possible?
Yes
Message not sent
Clear TXCR, TXPR
ABACK = 1
IRR8 = 1
IMR8 = 1?
Completion of message transmission
TXACK = 1
Clear TXCR, TXPR
IRR8 = 1
Yes
No
Interrupt to CPU
Clear TXACK
Clear ABACK
Clear IRR8
End of transmission/transmission
cancellation
Figure 18.10 Transmit Message Cancellation Flowchart
Rev. 6.00 Sep. 24, 2009 Page 646 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.4.4
Message Reception
The reception procedure after initial settings is described below. A reception flowchart is shown in
Figure 18.11.
Rev. 6.00 Sep. 24, 2009 Page 647 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Initialization
: Settings by user
Clear IRR0
BCR setting
MBCR setting
Mailbox (RAM) initialization
: Processing by hardware
Interrupt settings
Receive data setting
Arbitration field setting
Local acceptance filter mask settings
Message reception
(Match of identifier
in mailbox?)
No
Yes
Yes
Same RXPR = 1?
Unread message
No
Data frame?
No
Yes
RXPR, RFPR = 1
IRR2 = 1, IRR1 = 1
RXPR, IRR1 = 1
Yes
IMR1 = 1?
IMR2 = 1?
No
No
Interrupt to CPU
Interrupt to CPU
Message control read
Message data read
Message control read
Message data read
Clear IRR1 by clearing RXPR
Clear IRR2, IRR1 by clearing RFPR, RXPR
Transmission of data frame corresponding
to remote frame
End of reception
Figure 18.11 Reception Flowchart
Rev. 6.00 Sep. 24, 2009 Page 648 of 928
REJ09B0099-0600
Yes
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
CPU Interrupt Source Settings: CPU interrupt source settings are made in the interrupt mask
register (IMR) and mailbox interrupt register (MBIMR). The message to be received is also
specified. Data frame and remote frame receive wait interrupt requests can be generated for
individual mailboxes in the MBIMR. Interrupt sources of the interrupt register (IRR) are enabled
by IMR.
Arbitration Field Setting: To receive a message, the message identifier must be set in advance in
the message control registers (MCx[1] to MCx[8]) for the receiving mailbox. When a message is
received, all the bits in the receive message identifier are compared with those in each message
control register identifier, and if a 100% match is found, the message is stored in the matching
mailbox. Mailbox 0 has a local acceptance filter mask (LAFM) that allows Don't Care settings to
be made. The LAFM setting can be made only for mailbox 0. By making the Don't Care setting
for all the bits in the receive message identifier, messages of multiple identifiers can be received.
Examples:
• When the identifier of mailbox 1 is 010_1010_1010 (standard format), only one kind of
message identifier can be received by mailbox 1:
Identifier 1:
010_1010_1010
• When the identifier of mailbox 0 is 010_1010_1010 (standard format) and the LAFM setting is
000_0000_0011 (0: Care, 1: Don't Care), a total of four kinds of message identifiers can be
received by mailbox 0:
Identifier 1:
010_1010_1000
Identifier 2:
010_1010_1001
Identifier 3:
010_1010_1010
Identifier 4:
010_1010_1011
Message Reception: When a message is received, a CRC check is performed automatically. If the
result of the CRC check is normal, ACK is transmitted in the ACK field irrespective of whether
the message can be received or not.
• Data frame reception
If the received message is confirmed to be error-free by the CRC check, the identifier in the
mailbox (and also LAFM in the case of mailbox 0 only) and the identifier of the receive
message, are compared. If a complete match is found, the message is stored in the mailbox.
The message identifier comparison is carried out on each mailbox in turn, starting with
mailbox 0 and ending with mailbox 15. If a complete match is found, the comparison ends at
that point, the message is stored in the matching mailbox, and the corresponding receive
complete bit (RXPR0 to RXPR15) is set in the receive complete register (RXPR). However,
when a mailbox 0 LAFM comparison is carried out, even if the identifier matches, the mailbox
Rev. 6.00 Sep. 24, 2009 Page 649 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
comparison sequence does not end at that point, but continues with mailbox 1 and then the
remaining mailboxes. It is therefore possible for a message matching mailbox 0 to be received
by another mailbox. Note that the same message cannot be stored in more than one of
mailboxes 1 to 15. On receiving a message, a CPU interrupt request may be generated
depending on the mailbox interrupt mask register (MBIMR) and interrupt mask register (IMR)
settings.
• Remote frame reception
Two kinds of messages—data frames and remote frames—can be stored in mailboxes. A
remote frame differs from a data frame in that the remote transmission request bit (RTR) in the
message control register and the data field are 0 bytes long. The data length to be returned in a
data frame must be stored in the data length code (DLC) in the control field.
When a remote frame (RTR = recessive) is received, the corresponding bit is set in the remote
request wait register (RFPR). If the corresponding bit (MBIMR0 to MBIMR15) in the mailbox
interrupt mask register (MBIMR) and the remote frame request interrupt mask (IRR2) in the
interrupt mask register (IMR) are set to the interrupt enable value at this time, an interrupt can
be sent to the CPU.
Unread Message Overwrite: If the receive message identifier matches the mailbox identifier, the
receive message is stored in the mailbox regardless of whether the mailbox contains an unread
message or not. If a message overwrite occurs, the corresponding bit (UMSR0 to UMSR15) is set
in the unread message register (UMSR). In overwriting an unread message, when a new message
is received before the corresponding bit in the receive complete register (RXPR) has been cleared,
the unread message register (UMSR) is set. If the unread interrupt flag (IRR9) in the interrupt
mask register (IMR) is set to the interrupt enable value at this time, an interrupt can be sent to the
CPU. Figure 18.12 shows a flowchart for unread message overwriting.
Rev. 6.00 Sep. 24, 2009 Page 650 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
: Settings by user
Unread message overwrite
: Processing by hardware
UMSR = 1
IRR9 = 1
IMR9 = 1?
Yes
No
Interrupt to CPU
Clear IRR9
Message control/message data read
End
Figure 18.12 Unread Message Overwrite Flowchart
18.4.5
HCAN Sleep Mode
The HCAN is provided with an HCAN sleep mode that places the HCAN module in the sleep
state in order to reduce current dissipation. Figure 18.13 shows a flowchart of the HCAN sleep
mode.
Rev. 6.00 Sep. 24, 2009 Page 651 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
MCR5 = 1
: Setting by user
: Processing by hardware
Bus idle?
No
Yes
Initialize TEC and REC
Bus operation?
No
Yes
*
IRR12 = 1
IMR12 = 1?
No
CPU interrupt
Yes
Sleep mode clearing method
MCR7 = 0?
No (automatic)
Yes (manual)
Clear sleep mode?
No
Yes
GSR3 = 1?
No
Yes
GSR3 = 1?
No
Yes
MCR5 = 0
MCR5 = 0
11 recessive bits?
No
Yes
CAN bus communication possible
Note: * Mailbox should not be accessed.
Figure 18.13 HCAN Sleep Mode Flowchart
HCAN sleep mode is entered by setting the HCAN sleep mode bit (MCR5) to 1 in the master
control register (MCR). If the CAN bus is operating, the transition to HCAN sleep mode is
delayed until the bus becomes idle.
Either of the following methods of clearing HCAN sleep mode can be selected:
Rev. 6.00 Sep. 24, 2009 Page 652 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
• Clearing by software
• Clearing by CAN bus operation
Eleven recessive bits must be received after HCAN sleep mode is cleared before CAN bus
communication is re-enabled.
Clearing by software: HCAN sleep mode is cleared by writing a 0 to MCR5 from the CPU.
Clearing by CAN bus operation: The cancellation method is selected by the MCR7 bit setting in
MCR. Clearing by CAN bus operation occurs automatically when the CAN bus performs an
operation and this change is detected. In this case, the first message is not stored in a mailbox;
messages will be received normally from the second message onward. When a change is detected
on the CAN bus in HCAN sleep mode, the bus operation interrupt flag (IRR12) is set in the
interrupt register (IRR). If the bus interrupt mask (IMR12) in the interrupt mask register (IMR) is
set to the interrupt enable value at this time, an interrupt can be sent to the CPU.
18.4.6
HCAN Halt Mode
The HCAN halt mode is provided to enable mailbox settings to be changed without performing an
HCAN hardware or software reset. Figure 18.14 shows a flowchart of the HCAN halt mode.
MCR1 = 1
Bus idle?
No
Yes
MBCR setting
MCR1 = 0
: Settings by user
CAN bus communication possible
: Processing by hardware
Figure 18.14 HCAN Halt Mode Flowchart
Rev. 6.00 Sep. 24, 2009 Page 653 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
HCAN halt mode is entered by setting the halt request bit (MCR1) to 1 in the master control
register (MCR). If the CAN bus is operating, the transition to HCAN halt mode is delayed until
the bus becomes idle.
HCAN halt mode is cleared by clearing MCR1 to 0.
18.5
Interrupts
Table 18.4 lists the HCAN interrupt sources. With the exception of the reset processing vector
(IRR0), these sources can be masked. Masking is implemented using the mailbox interrupt mask
register (MBIMR) and interrupt mask register (IMR). For details on the interrupt vector of each
interrupt source, see section 5, Interrupt Controller.
Table 18.4 HCAN Interrupt Sources
Interrupt
Flag
DTC
Activation
Error passive interrupt (TEC ≥ 128 or REC ≥ 128)
IRR5
Not possible
Bus off interrupt (TEC ≥ 256)
IRR6
Reset process interrupt by power-on reset
IRR0
Remote frame reception interrupt
IRR2
Error warning interrupt (TEC ≥ 96)
IRR3
Error warning interrupt (REC ≥ 96)
IRR4
Overload frame transmission interrupt
IRR7
Unread message overwrite interrupt
IRR9
Name
Description
ERS0/OVR0
CAN bus operation in HCAN sleep mode interrupt
IRR12
RM0
Mailbox 0 message reception interrupt
IRR1
Possible
RM1
Mailbox 1 to 15 message reception interrupt
IRR1
Not possible
SLE0
Message transmission/cancellation interrupt
IRR8
Rev. 6.00 Sep. 24, 2009 Page 654 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.6
DTC Interface
The DTC can be activated by the reception of a message in HCAN mailbox 0. When DTC transfer
ends after DTC activation has been set, the RXPR0 and RFPR0 flags are cleared automatically.
An interrupt request due to a receive interrupt from the HCAN cannot be sent to the CPU in this
case. Figure 18.15 shows a DTC transfer flowchart.
: Settings by user
DTC initialization
DTC enable register setting
DTC register information setting
: Processing by hardware
Message reception in HCAN’s
mailbox 0
DTC activation
End of DTC transfer?
No
Yes
RXPR and RFPR clearing
Transfer counter = 0
or DISEL = 1?
No
Yes
Interrupt to CPU
End
Figure 18.15 DTC Transfer Flowchart
Rev. 6.00 Sep. 24, 2009 Page 655 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.7
CAN Bus Interface
A bus transceiver IC is necessary to connect this LSI to a CAN bus. A Philips PCA82C250
transceiver IC is recommended. Any other product must be compatible with the PCA82C250.
Figure 18.16 shows a sample connection diagram.
124 Ω
This LSI
P1Vcc
P1Vcc
PCA82C250
RS
HRxD
RxD CANH
HTxD
TxD CANL
Vref
CAN bus
Vcc
GND
NC
124 Ω
Legend:
NC: No Connection
Figure 18.16 High-Speed Interface Using PCA82C250
18.8
Usage Notes
18.8.1
Module Stop Mode Setting
HCAN operation can be disabled or enabled using the module stop control register. The initial
setting is for HCAN operation to be halted. Register access is enabled by clearing module stop
mode. For details, see section 22, Power-Down Modes.
18.8.2
Reset
The HCAN is reset by a power-on reset or in hardware standby mode, software standby mode,
watch mode, or module stop mode. All the registers are initialized in a reset, however mailboxes
(message control (MCx[x])/message data (MDx[x])) are not. After power-on, mailboxes (message
control (MCx[x])/message data (MDx[x])) are initialized, and their values are undefined.
Therefore, mailbox initialization must always be carried out after a power-on reset or recovery
from hardware standby mode, software standby mode, watch mode, or module stop mode. The
reset interrupt flag (IRR0) is always set after a power-on reset or recovery from software standby
Rev. 6.00 Sep. 24, 2009 Page 656 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
mode, watch mode, or module stop mode. As this bit cannot be masked in the interrupt mask
register (IMR), if HCAN interrupt enabling is set in the interrupt controller without clearing the
flag, an HCAN interrupt will be initiated immediately. IRR0 should therefore be cleared during
initialization.
18.8.3
HCAN Sleep Mode
The bus operation interrupt flag (IRR12) in the interrupt register (IRR) is set by CAN bus
operation in HCAN sleep mode. Therefore, this flag is not used by the HCAN to indicate sleep
mode release. Note that the reset status bit (GSR3) in the general status register (GSR) is set in
sleep mode.
18.8.4
Interrupts
When the mailbox interrupt mask register (MBIMR) is set, the interrupt register (IRR8, 2, 1) is not
set by reception completion, transmission completion, or transmission cancellation for the set
mailboxes.
18.8.5
Error Counters
In the case of error active and error passive, REC and TEC normally count up and down. In the
bus-off state, 11-bit recessive sequences are counted (REC + 1) using REC. If REC reaches 96
during the count, IRR4 and GSR1 are set.
18.8.6
Register Access
Byte or word access can be used on all HCAN registers. Longword access cannot be used.
18.8.7
HCAN Medium-Speed Mode
In medium-speed mode, neither read nor write is possible for the HCAN registers.
18.8.8
Register Hold in Standby Modes and Watch Mode
All HCAN registers except the message control and message data are initialized in hardware
standby mode, software standby mode, watch mode, or module stop mode.
Rev. 6.00 Sep. 24, 2009 Page 657 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.8.9
Usage of Bit Change Instructions
Do not use bit change instructions to clear flags, because the status flags of HCAN is cleared by
writing 1. To clear a flag, use MOV instruction to write 1 to only the bits to be cleared.
18.8.10 HCAN TXCR Operation
1.
When the transmit wait cancel register (TXCR) is used to cancel a transmit wait message in a
transmit wait mailbox, the corresponding bit to TXCR and the transmit wait register (TXPR)
may not be cleared even if transmission is canceled. This occurs when the following
conditions are all satisfied.
• The HRxD pin is stacked to 1 because of a CAN bus error, etc.
• There is at least one mailbox waiting for transmission or being transmitted.
• The message transmission in a mailbox being transmitted is canceled by TXCR.
If this occurs, transmission is canceled. However, since TXPR and TXCR states are indicated
wrongly that a message is being cancelled, transmission cannot be restarted even if the stack
state of the HRxD pin is canceled and the CAN bus recovers the normal state. If there are at
least two transmission messages, a message which is not being transmitted is canceled and a
message being transmitted retains its state.
To avoid this, one of the following countermeasures must be executed.
• Transmission must not be canceled by TXCR. When transmission is normally completed after
the CAN bus has recovered, TXPR is cleared and the HCAN recovers the normal state.
• To cancel transmission, the corresponding bit to TXCR must be written to 1 continuously until
the bit becomes 0. TXPR and TXCR are cleared and the HCAN recovers the normal state.
2. When the bus-off state is entered while TXPR is set and the transmit wait state is entered, the
internal state machine does not operate even if TXCR is set during the bus-off state. Therefore
transmission cannot be canceled. The message can be canceled when one message is
transmitted or a transmission error occurs after the bus-off state is recovered. To clear a
message after the bus-off state is recovered, the following countermeasure must be executed.
• A transmit wait message must be cleared by resetting the HCAN during the bus-off period.
To reset the HCAN, the module stop bit (MSTPC2 in MSTPCRC) must be set or cleared. In
this case, the HCAN is entirely reset. Therefore the initial settings must be made again.
Rev. 6.00 Sep. 24, 2009 Page 658 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
18.8.11 HCAN Transmit Procedure
Phenomenon: When the first transmission is set, and then the next (second) transmission is set or
the first set transmission is canceled immediately before SOF is output under the following
conditions, the transmit message Identifier (hereafter ID) of being set may be damaged.
1. When transmission is performed while the bus is in the idle state.
2. When the second transmission is set or the set transmission is cancelled within maximum three
HCAN operating clocks including the sampling point immediately before the SOF output.
3. When two transmissions (TXPR and another TXPR are set) are set, not the first transmission
but the second transmission has priority. When the transmission is set and the set transmission
is cancelled (TXPR and TXCR are set), and then transmitting a message of the highest priority
is cancelled in the first transmission setting.
When TXPR and another TXPR are set, or TXPR and TXCR are set under the all above
conditions, the message ID of the highest priority, which is selected in the second transmission
setting or the set transmission cancellation, is damaged. That is, upper five bits of the message ID,
which is selected in the first transmission, is set in the upper five bits of the ID. After the upper
five bits of the transmit message ID selected in the first transmission setting is transmitted to the
CAN bus, the lower six bits of the transmit message ID selected in the second transmission setting
or the set transmission cancellation and transmit data (maximum eight bytes) are output to the
CAN bus. The CRC error is not occurred, since CRC transmits reconstructed transmit message
with ID.
Note that after the damaged transmit message is transmitted, the transmit message of the second
highest priority, which is selected in the second transmission setting or the set transmission
cancellation, is output. The message of the highest priority, which is selected in the second
transmission setting or the set transmission cancellation, is not output.
Rev. 6.00 Sep. 24, 2009 Page 659 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
2nd transmission setting
1st transmission or 1st transmission setting
cancellation
setting
Idle state
Transmission
SOF
Sampling point
immediately before SOF
Upper five bits of ID
Lower six bits of ID to EOF
Upper five bits of ID of the
Lower six bits of ID of message
transmit message selected
of the highest priority selected
in the 1st transmission setting in the 2nd transmission setting
and subsequent bits
Figure 18.17 HCAN Transmit Procedure
When the interval between two transmissions, or between transmission and transmission
cancellation is same or shorter than following, condition 2 described in above is satisfied and
consequently error may occur.
Table 18.5 Interval Limitation between TXPR and TXPR or between TXPR and TXCR
Baud Rate (bps)
Set Interval (μs)
1M
50
500 k
50
250 k
50
Interval (which is for preventing error) is changed depending on the following conditions.
•
•
•
•
•
•
•
The number of buffers (HCAN has 16 buffers)
Data transmission: Mailbox (hereafter MB) number order, ID priority order
HCAN operating clock
CAN bus baud rate
Bit timing (TSEG1, TSEG2)
The number of MBs transmitted to the first TXPR and second TXPR
The number of CPU accesses to MB in words or bytes after TXPR or TXCR set
Rev. 6.00 Sep. 24, 2009 Page 660 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Countermeasures: In order to prevent this error from happening, please take the countermeasures
shown below in software.
• Set transmission in one TXPR. After transmission of all transmit messages is completed, set
transmission again (mass transmission setting).
• Set interval to be longer than shown in table 18.5 between TXPR and another TXPR, or TXPR
and TXCR
• Transmit message in order of its priority
18.8.12 Canceling HCAN Software Reset or HCAN Sleep Mode
When canceling an HCAN software reset or HCAN sleep mode (MCR0 = 0 or MCR5 = 0), first
confirm that the reset status bit (GSR3) is set to 1.
18.8.13 Accessing Mailboxes in HCAN Sleep Mode
Mailboxes should not be accessed in HCAN sleep mode. If mailboxes are accessed in HCAN
sleep mode, the CPU may halt. When registers are accessed in HCAN sleep mode, the CPU does
not halt. Also, when mailboxes are accessed not in HCAN sleep mode, the CPU does not halt.
Rev. 6.00 Sep. 24, 2009 Page 661 of 928
REJ09B0099-0600
Section 18 Controller Area Network (HCAN) [H8S/2556 Group]
Rev. 6.00 Sep. 24, 2009 Page 662 of 928
REJ09B0099-0600
Section 19 RAM
Section 19 RAM
This LSI includes high-speed static RAM. The RAM is connected to the CPU by a 16-bit data bus,
enabling one-state access by the CPU to both byte data and word data.
The RAM can be enabled or disabled using the RAME bit in the system control register (SYSCR).
For details on SYSCR, see section 3.2.2, System Control Register (SYSCR).
RAM16K1A_000020020300
Rev. 6.00 Sep. 24, 2009 Page 663 of 928
REJ09B0099-0600
Section 19 RAM
Rev. 6.00 Sep. 24, 2009 Page 664 of 928
REJ09B0099-0600
Section 20 Flash Memory
Section 20 Flash Memory
This LSI has 512-kbyte (H8S/2556, H8S/2552, and H8S/2506) or 384-kbyte (H8S/2551 and
H8S/2505) of on-chip flash memory. Features of flash memory are shown below.
20.1
Features
• Two flash-memory MATs according to LSI initiation mode
The on-chip flash memory has two memory spaces in the same address space (hereafter
referred to as memory MATs). The mode setting in the initiation determines which memory
MAT is initiated first. The MAT can be switched by using the bank-switching method after
initiation.
⎯ The user memory MAT is initiated at a power-on reset in user mode:
512 kbytes (H8S/2556, H8S/2552, and H8S/2506)
384 kbytes (H8S/2551 and H8S/2505)
⎯ The user boot memory MAT is initiated at a power-on reset in user boot mode: 8 kbytes
• Three on-board programming modes and one off-board programming mode
⎯ Boot mode
This mode is a program mode that uses an on-chip SCI interface. The user MAT and user
boot MAT can be programmed. This mode can automatically adjust the bit rate between
host and this LSI.
⎯ User program mode
The user MAT can be programmed by using the optional interface.
⎯ User boot mode
The user boot program of the optional interface can be made and the user MAT can be
programmed.
• One off-board programming mode
⎯ Programmer mode
This mode uses the PROM programmer. The user MAT and user boot MAT can be
programmed.
• Programming/erasing interface by the download of on-chip program
This LSI has a dedicated programming/erasing program. After downloading this program to
the on-chip RAM, programming/erasing can be performed by setting the argument parameter.
The user branch is also supported.
Rev. 6.00 Sep. 24, 2009 Page 665 of 928
REJ09B0099-0600
Section 20 Flash Memory
User Branch*
Programming is carried out in 128-byte units through several steps such as applying
programming pulse and reading verify. Erasing is carried out in 1-divided-block unit through
several processing steps. Between these steps, a setting can be created to execute user process
routines. This setting is called "with user branch."
Note: * Not available in this LSI.
• Emulation function of flash memory by using the on-chip RAM
As flash memory is overlapped with part of the on-chip RAM, the flash memory programming
can be emulated in real time.
• Protect Mode
Software protect by register setting is provided to set the protect status of programming/erasing
flash memory
When an error is detected, the mode is changed to error protect mode to abort
programming/erasing processing.
• Programming/erasing time
The flash memory programming time is 3 ms (typ) in 128-byte simultaneous programming and
25 μs per byte. The erasing time is 1000 ms (typ) per 64-kbyte block.
• Number of programming
The number of flash memory programming can be minimum 100 times.
Rev. 6.00 Sep. 24, 2009 Page 666 of 928
REJ09B0099-0600
Section 20 Flash Memory
Block Diagram
Internal address bus
Internal data bus (16 bits)
FCCS
Module bus
20.1.1
FPCS
Memory MAT unit
FECS
User MAT: 512 kbytes
(H8S/2556, H8S/2552, H8S/2506)
FKEY
FMATS
384 kbytes
Control unit
(H8S/2551, H8S/2505)
FTDAR
User boot MAT: 8 kbytes
RAMER
FVACR
FVADR
Mode pin
Legend:
FCCS:
FPCS:
FECS:
FKEY:
FMATS:
FTDAR:
RAMER:
FVACR:
FVADR:
Flash memory
Operating
mode
Flash code control status register
Flash program code select register
Flash erase code select register
Flash key code register
Flash MAT select register
Flash transfer destination address register
RAM emulation register
Flash vector address control register
Flash vector address data register
Note: To read from or write to the above registers except RAMER, the FLSHE bit in the
system control register 2 (SYSCR2) must be set to 1. When FLSHE is 1, some
TPU control registers (H'FFFE80 to H'FFFEB1) cannot be accessed. The FLSHE
bit should be cleared before the TPU registers are accessed.
Figure 20.1 Block Diagram of Flash Memory
Rev. 6.00 Sep. 24, 2009 Page 667 of 928
REJ09B0099-0600
Section 20 Flash Memory
20.1.2
Operating Mode
When each mode pin is set in the reset state and reset start is performed, the microcomputer enters
each operating mode as shown in figure 20.2. For the setting of each pin, see table 20.1.
• Flash memory can be read in user mode, but cannot be programmed or erased.
• Flash memory can be read, programmed, or erased on the board only in user program mode,
user boot mode, and boot mode.
• Flash memory can be read, programmed, or erased by means of the PROM programmer in
programmer mode.
RES = 0
Programmer
Programmer mode setting
Reset state
=0
rm
e
Us
0
RE
S
Bo
S
es
od
g
RE
R
in
ett
RE
S=
=0
ot g
bo tin
er set
Us de
mo
ES
ot
mo
de
mode
=0
se
ttin
g
FLSHE = 0
User mode
FLSHE = 1
User program
mode
User boot
mode
RAM emulation is enabled
On-board programming mode
Figure 20.2 Mode Transition of Flash Memory
Rev. 6.00 Sep. 24, 2009 Page 668 of 928
REJ09B0099-0600
Boot mode
Section 20 Flash Memory
Table 20.1 MD Pin Setting and Operating Mode
Reset
state
Pin
RES
On-chip ROM
valid mode*1
User program
mode*2
User boot
mode
Boot mode
Programmer
mode
0
1
1
1
1
1
MD0*
0/1
0/1
0/1
1
0/1
0
MD1
0/1
1
1
0
1
0
MD2
0/1
1
1
0
0
0
3
Notes: 1
On-chip ROM valid mode indicates mode 6 and mode 7. For details, see section 3,
MCU Operating Modes.
2. To transit to User program mode, set FLSHE bit in SYSCR2 to 1.
3. In case of On-chip ROM valid mode, User program mode and Boot mode, when the
MD0 pin sets to 0, the mode will be Expanded mode, otherwise, when the pin sets to 1,
the mode will be Single chip mode. However, in case of User boot mode, there is no
Expanded mode.
Rev. 6.00 Sep. 24, 2009 Page 669 of 928
REJ09B0099-0600
Section 20 Flash Memory
20.1.3
Mode Comparison
The comparison table of programming and erasing related items about boot mode, user program
mode, user boot mode, and programmer mode is shown in table 20.2.
Table 20.2 Comparison of Programming Modes
Boot mode
User program
mode
Programmer
User boot mode mode
Programming/
erasing
environment
On-board
programming
On-board
programming
On-board
programming
Off-board
programming
Programming/
erasing enable
MAT
User MAT
User boot MAT
User MAT
User MAT
User MAT
User boot MAT
All erasure
(Automatic)
(Automatic)
×
1
Block division
erasure
*
Program data
transfer
From host via SCI
From optional
device via RAM
From optional
device via RAM
Via programmer
User branch
×
×
×
×
RAM emulation
×
×
×
Reset initiation
MAT
Embedded
program storage
MAT
User MAT
User boot MAT*
⎯
Transition to user
mode
Changing mode
setting and reset
Changing FLSHE
setting
Changing mode
setting and reset
⎯
2
Notes: 1. All-erasure is performed. After that, the specified block can be erased.
2. Firstly, the reset vector is fetched from the embedded program storage MAT. After the
flash memory related registers are checked, the reset vector is fetched from the user
boot MAT.
• The user boot MAT can be programmed or erased only in boot mode and programmer mode.
• The user MAT and user boot MAT are erased in boot mode. Then, the user MAT and user boot
MAT can be programmed by means of the command method. However, the contents of the
MAT cannot be read until this state.
Only user boot MAT is programmed and the user MAT is programmed in user boot mode or
only user MAT is programmed because user boot mode is not used.
• The boot operation of the optional interface can be performed by the mode pin setting different
from user program mode in user boot mode.
Rev. 6.00 Sep. 24, 2009 Page 670 of 928
REJ09B0099-0600
Section 20 Flash Memory
20.1.4
Flash MAT Configuration
This LSI’s flash memory is configured by the 512-kbyte (H8S/2556, H8S/2552, and H8S/2506) or
384-kbyte (H8S/2551 and H8S/2505) user MAT and 8-kbyte user boot MAT.
The start address is allocated to the same address in the user MAT and user boot MAT. Therefore,
when the program execution or data access is performed between two MATs, the MAT must be
switched by using FMATS register.
The user MAT or user boot MAT can be read in all modes. However, the user boot MAT can be
programmed only in boot mode and programmer mode.
<User Boot MAT>
<User MAT>
Address
H'000000
H8S/2556,
H8S/2552,
H8S/2506
H8S/2551,
H8S/2505
All products
Address
H'000000
Address
H'000000
8 kbytes
H'001FFF
384 kbytes
512 kbytes
H'05FFFF
H'07FFFF
Figure 20.3 Flash Memory Configuration
The size of the user MAT is different from that of the user boot MAT. An address which exceeds
the size of the 8-kbyte user boot MAT should not be accessed. If the attempt is made, data is read
as undefined value.
Rev. 6.00 Sep. 24, 2009 Page 671 of 928
REJ09B0099-0600
Section 20 Flash Memory
20.1.5
Block Division
As shown in figure 20.4, the user MAT of 512-kbyte flash memory is divided into 64 kbytes
(seven blocks), 32 kbytes (one block), and 4 kbytes (eight blocks). The user MAT of 384-kbyte
flash memory is divided into 64 kbytes (five blocks), 32 kbytes (one block), and 4 kbytes (eight
blocks). The user MAT can be erased in this divided-block units and the erase-block number of
EB0 to EB15 (512-kbyte flash memory) or EB0 to EB13 (384-kbyte flash memory) is specified
when erasing.
The RAM emulation can be performed in the eight blocks of 4 kbytes.
<User MAT>
H8S/2556,
H8S/2552,
H8S/2506
Address H'000000
4 kbytes × 8
H8S/2551,
H8S/2505
Erase block
EB0
to
*
Address H'000000
4 kbytes × 8
Address H'07FFFF
32 kbytes
EB8
64 kbytes
EB9
64 kbytes
EB10
64 kbytes
EB7
32 kbytes
EB8
64 kbytes
EB9
64 kbytes
EB10
EB11
64 kbytes
EB11
64 kbytes
EB12
64 kbytes
EB12
64 kbytes
EB13
64 kbytes
EB13
64 kbytes
EB14
64 kbytes
EB15
384 kbytes
512 kbytes
EB7
Address H'05FFFF
Note: The RAM emulation can be performed in the eight blocks of 4 kbytes.
Figure 20.4 Block Division of User MAT
Rev. 6.00 Sep. 24, 2009 Page 672 of 928
REJ09B0099-0600
Erase block
EB0
to
*
Section 20 Flash Memory
20.1.6
Programming/Erasing Interface
Programming/erasing is executed by downloading the on-chip program to the on-chip RAM and
specifying the program address/data and erase block by using the interface register/parameter.
The procedure program is made by the user in user program mode and user boot mode. An
overview of the procedure is given as follows. For details, see section 20.4.2, User Program Mode.
Start user procedure
program for programming/erasing.
Select on-chip program to be
downloaded and
specify the destination.
Download on-chip program
by setting FKEY and SCO bits.
Initialization execution
(downloaded program execution)
Programming (in 128-byte units)
or erasing (in one-block units)
(downloaded program execution)
No
Programming/erasing
completed?
Yes
End user procedure
program
Figure 20.5 Overview of User Procedure Program
1. Selection of on-chip program to be downloaded
This LSI has programming/erasing programs which can be downloaded to the on-chip RAM.
The on-chip program to be downloaded is selected by setting the corresponding bits in the
programming/erasing interface register. The address of the programming destination is
specified by the FTDAR.
2. Download of on-chip program
The on-chip program is automatically downloaded by setting the SCO bit in the flash key
register (FKEY) and the flash control register (FCCS) of the programming/erasing interface
register.
The flash memory is replaced to the embedded program storage area when downloading. Since
the flash memory cannot be read when programming/erasing, the procedure program, which is
Rev. 6.00 Sep. 24, 2009 Page 673 of 928
REJ09B0099-0600
Section 20 Flash Memory
working from download to completion of programming/erasing, must be executed in the space
other than the flash memory to be programmed/erased (for example, on-chip RAM).
Since the result of download is returned to the programming/erasing interface parameter,
whether the normal download is executed or not can be confirmed.
3. Initialization of programming/erasing
The operating frequency and user branch are set before execution of programming/erasing.
The user branch area should be outside programming-prohibited areas such as user MAT area
during programming process or on-chip program area. This setting is performed by using the
programming/erasing interface parameter.
4. Programming/erasing execution
To execute programming/erasing, it is necessary to enter user program mode by setting
FLSHE bit in SYSCR2 to 1.
The program data/programming destination address is specified in 128-byte units when
programming.
The block to be erased is specified in erase-block units when erasing.
These specifications are set by using the programming/erasing interface parameter and the onchip program is initiated. The on-chip program is executed by using the JSR or BSR
instruction and performing the subroutine call of the specified address in the on-chip RAM.
The execution result is returned to the programming/erasing interface parameter.
The area to be programmed must be erased in advance when programming flash memory. It is,
however, impossible to download at the same time the erasing program and the programming
program. Therefore, execute the above procedures of 1 to 4 in the order of erasing first and
programming next.
All interrupts are prohibited during programming and erasing. Interrupts must be masked
within the user system.
Access in the flash memory space during programming/erasing is not guaranteed. Accordingly,
when the interrupt vector or the interrupt handler is in the flash memory, interrupt processing
is not guaranteed. When NMI interrupt is inevitable during overprogramming/erasing system
such as in system error processing, set FVACR and FVADR to set the interrupt vector and the
interrupt processing routine in the on-chip RAM or the external space.
Rev. 6.00 Sep. 24, 2009 Page 674 of 928
REJ09B0099-0600
Section 20 Flash Memory
5. When programming/erasing is executed consecutively
When the processing is not ended by the 128-byte programming or one-block erasure, the
program address/data and erase-block number must be updated and consecutive
programming/erasing is required.
Since the downloaded on-chip program is left in the on-chip RAM after the processing,
download and initialization are not required when the same processing is executed
consecutively.
20.2
Pin Configuration
Table 20.3 shows the flash memory pin configuration.
Table 20.3 Pin Configuration
Pin Name
Abbreviation
Input/Output
Function
Reset
RES
Input
Reset
Mode 2
MD2
Input
Sets operating mode of this LSI
Mode 1
MD1
Input
Sets operating mode of this LSI
Mode 0
MD0
Input
Sets operating mode of this LSI
Transmit data
TxD0
Output
Serial transmit data output (used in boot
mode)
Receive data
RxD0
Input
Serial receive data input (used in boot mode)
Note: For the pin configuration in programmer mode, see section 20.9, Programmer Mode.
Rev. 6.00 Sep. 24, 2009 Page 675 of 928
REJ09B0099-0600
Section 20 Flash Memory
20.3
Register Descriptions
The registers/parameters which control flash memory are shown as follows. To access registers
other than RAMER that control flash memory, set the FLSHE bit in SYSCR2 to 1 in mode which
makes flash memory valid. When FLSHE is 1, some TPU control registers (H'FFFE80 to
H'FFFEB1) cannot be accessed. The FLSHE bit should be cleared before the TPU registers are
accessed.
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
Flash code control status register (FCCS)
Flash program code select register (FPCS)
Flash erase code select register (FECS)
Flash key code register (FKEY)
Flash MAT select register (FMATS)
Flash transfer destination address register (FTDAR)
System control register 2 (SYSCR2)
Flash pass and fail result (FPFR)
Download pass and fail result (DPFR)
Flash multipurpose address area (FMPAR)
Flash multipurpose data destination area (FMPDR)
Flash erase Block select (FEBS)
Flash program and erase frequency control (FPEFEQ)
Flash user branch address set parameter (FUBRA)
RAM emulation register (RAMER)
Flash vector address control register (FVACR)
Flash vector address data register R (FVADRR)
Flash vector address data register E (FVADRE)
Flash vector address data register H (FVADRH)
Flash vector address data register L (FVADRL)
There are several operating modes for accessing flash memory, for example, read mode/program
mode.
There are two memory MATs: user MAT and user boot MAT. The dedicated registers/parameters
are allocated for each operating mode and MAT selection. The correspondence of operating modes
and registers/parameters for use is shown in table 20.4.
Rev. 6.00 Sep. 24, 2009 Page 676 of 928
REJ09B0099-0600
Section 20 Flash Memory
Table 20.4 Register/Parameter and Target Mode
Initialization
Program
ming
Erasure
Read
RAM
Emulation
Programming/
FCCS
Erasing Interface FPCS
Register
FECS
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
FKEY
⎯
Download
FMATS
⎯
FTDAR
Programming/
DPFR
Erasing Interface FPFR
Parameter
FPEFEQ
RAM Emulation
⎯
⎯
1
1
*
⎯
2
*
*
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
FUBRA
⎯
⎯
⎯
⎯
⎯
FMPAR
⎯
⎯
⎯
⎯
⎯
FMPDR
⎯
⎯
⎯
⎯
⎯
FEBS
⎯
⎯
⎯
⎯
⎯
RAMER
⎯
⎯
⎯
⎯
⎯
Notes: 1. The setting is required when programming or erasing user MAT in user boot mode.
2. The setting may be required according to the combination of initiation mode and read
target MAT.
20.3.1
Programming/Erasing Interface Register
The programming/erasing interface registers are as described below. They are all 8-bit registers
that can be accessed in byte. Except for the FLER bit in FCCS, these registers are initialized at a
power-on reset, in hardware standby mode, in software standby mode, or in watch mode. The
FLER bit is not initialized in software standby mode or in watch mode.
Flash Code Control and Status Register (FCCS): FCCS is configured by bits which request the
monitor of error occurrence during programming or erasing flash memory and the download of
on-chip program.
Rev. 6.00 Sep. 24, 2009 Page 677 of 928
REJ09B0099-0600
Section 20 Flash Memory
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
1
R
Reserved
This bit is always read as 0. The write value should always
be 1.
6, 5
⎯
All 0
R
Reserved
These bits are always read as 0. The write value should
always be 0.
4
FLER
0
R
Flash Memory Error
Indicates an error occurs during programming and erasing
flash memory. When FLER is set to 1, flash memory enters
the error protection state. This bit is initialized at transition
to a power-on reset or hardware standby mode.
When FLER is set to 1, high voltage is applied to the
internal flash memory. To reduce the damage to flash
memory, the reset must be released after the reset period
of 100 μs which is longer than normal.
0: Flash memory operates normally
Programming/erasing protection for flash memory (error
protection) is invalid.
[Clearing condition] At a power-on reset or in hardware
standby mode
1: Indicates an error occurs during programming/erasing
flash memory.
Programming/erasing protection for flash memory (error
protection) is valid.
[Setting condition] See section 20.5.3, Error Protection
3 to 1 ⎯
All 0
R
Reserved
These bits are always read as 0. The write value should
always be 0.
Rev. 6.00 Sep. 24, 2009 Page 678 of 928
REJ09B0099-0600
Section 20 Flash Memory
Bit
Bit Name
Initial
Value
R/W
Description
0
SCO
0
(R)/W
Source Program Copy Operation
Requests the on-chip programming/erasing program to be
downloaded to the on-chip RAM.
When this bit is set to 1, the on-chip program which is
selected by FPCS/FECS is automatically downloaded in
the on-chip RAM specified by FTDAR.
In order to set this bit to 1, RAM emulation state must be
canceled, H'A5 must be written to FKEY, and this operation
must be executed in the on-chip RAM.
Four NOP instructions must be executed immediately after
setting this bit to 1.
Since this bit is cleared to 0 when download is completed,
this bit cannot be read as 1.
0: Download of the on-chip programming/erasing program
to the on-chip RAM is not executed
[Clear condition] When download is completed
1: Request that the on-chip programming/erasing program
is downloaded to the on-chip RAM is occurred
[Set conditions] When all of the following conditions are
satisfied and 1 is written to this bit
• H'A5 is written to FKEY
•
During execution in the on-chip RAM
•
Not in RAM emulation mode (RAMS in RAMER = 0)
Rev. 6.00 Sep. 24, 2009 Page 679 of 928
REJ09B0099-0600
Section 20 Flash Memory
Flash Program Code Select Register (FPCS): FPCS selects the on-chip programming program
to be downloaded.
Bit
Bit Name
7 to 1 ⎯
Initial
Value
R/W
Description
All 0
R
Reserved
These bits are always read as 0. The write value should
always be 0.
0
PPVS
0
R/W
Program Pulse Verify
Selects the programming program.
0: On-chip programming program is not selected
[Clear condition] When transfer is completed
1: On-chip programming program is selected
Flash Erase Code Select Register (FECS): FECS selects download of the on-chip erasing
program.
Bit
Bit Name
7 to 1 ⎯
Initial
Value
R/W
Description
All 0
R
Reserved
These bits are always read as 0. The write value should
always be 0.
0
EPVB
0
R/W
Erase Pulse Verify Block
Selects the erasing program.
0: On-chip erasing program is not selected
[Clear condition] When transfer is completed
1: On-chip erasing program is selected
Rev. 6.00 Sep. 24, 2009 Page 680 of 928
REJ09B0099-0600
Section 20 Flash Memory
Flash Key Code Register (FKEY): FKEY is a register for software protection that enables
download of on-chip program and programming/erasing of flash memory. Before setting the SCO
bit to 1 in order to download on-chip program or executing the downloaded programming/erasing
program, these processing cannot be executed if the key code is not written.
Bit
Bit Name
Initial
Value
R/W
Description
7
K7
0
R/W
Key Code
6
K6
0
R/W
5
K5
0
R/W
4
K4
0
R/W
Only when H'A5 is written, writing to the SCO bit is valid.
When the value other than H'A5 is written to FKEY, 1
cannot be written to the SCO bit. Therefore downloading to
the on-chip RAM cannot be executed.
3
K3
0
R/W
2
K2
0
R/W
1
K1
0
R/W
0
K0
0
R/W
Only when H'5A is written, programming/erasing can be
executed. Even if the on-chip programming/erasing
program is executed, the flash memory cannot be
programmed or erased when the value other than H'5A is
written to FKEY.
H'A5: Writing to the SCO bit is enabled (The SCO bit
cannot be set by the value other than H'A5.)
H'5A: Programming/erasing is enabled (The value other
than H'5A is in software protection state.)
H'00: Initial value
Rev. 6.00 Sep. 24, 2009 Page 681 of 928
REJ09B0099-0600
Section 20 Flash Memory
Flash MAT Select Register (FMATS): FMATS specifies whether user MAT or user boot MAT
is selected.
Bit
Bit Name
Initial
Value
R/W
Description
7
MS7
0/1*
R/W
MAT Select
6
MS6
0
R/W
5
MS5
0/1*
R/W
4
MS4
0
R/W
These bits are in user-MAT selection state when the value
other than H'AA is written and in user-boot-MAT selection
state when H'AA is written.
3
MS3
0/1*
R/W
2
MS2
0
R/W
1
MS1
0/1*
R/W
0
MS0
0
R/W
The MAT is switched by writing the value in FMATS.
When the MAT is switched, follow section 20.7, Switching
between User MAT and User Boot MAT. (The user boot
MAT cannot be programmed in user program mode if user
boot MAT is selected by FMATS. The user boot MAT must
be programmed in boot mode or in programmer mode.)
H'AA: The user boot MAT is selected (in user-MAT
selection state when the value of these bits are other
than H'AA)
Initial value when these bits are initiated in user boot
mode.
H'00: Initial value when these bits are initiated in a mode
except for user boot mode (in user-MAT selection
state)
[Programmable condition] These bits are in the execution
state in the on-chip RAM.
Note: Set to 1 when in user boot mode, otherwise set to 0.
Flash Transfer Destination Address Register (FTDAR): FTDAR is a register that specify the
address to download an on-chip program. This register must be specified before setting the SCO
bit in FCCS to 1.
Rev. 6.00 Sep. 24, 2009 Page 682 of 928
REJ09B0099-0600
Section 20 Flash Memory
Bit
Bit Name
Initial
Value
R/W
Description
7
TDER
0
R/W
Transfer Destination Address Setting Error
This bit is set to 1 when the address specified by bits TDA6
to TDA0, which is the start address to download an on-chip
program, is over the range. Whether or not the range
specified by bits TDA6 to TDA0 is within the range of H'00
to H'07 is determined when an on-chip program is
downloaded by setting the SCO bit in FCCS. Make sure
that this bit is cleared to 0 before setting the SCO bit to 1
and the value specified by TDA6 to TDA0 is within the
range of H'00 to H'07.
0: The value specified by bits TDA6 to TDA0 is within the
range.
1: The value specified by is TDA6 to TDA0 is over the
range (H'08 to H'FF) and the download is stopped.
6
TDA6
0
R/W
Transfer Destination Address
5
TDA5
0
R/W
4
TDA4
0
R/W
3
TDA3
0
R/W
Specifies the start address to download an on-chip
program. H'00 to H'07 can be specified meaning that the
start address in the on-chip RAM space can be specified in
units of 4 kbytes.
2
TDA2
0
R/W
1
TDA1
0
R/W
0
TDA0
0
R/W
H'00: H'FF9000 is specified as a start address to download
an on-chip program.
H'01: H'FFA000 is specified as a start address to download
an on-chip program.
H'02: H'FFB000 is specified as a start address to download
an on-chip program.
H'03: H'FFC000 is specified as a start address to download
an on-chip program.
H'04: H'FFD000 is specified as a start address to download
an on-chip program.
H'05: H'FFE000 is specified as a start address to download
an on-chip program.
H'06: H'FF8000 is specified as a start address to download
an on-chip program.
H'07: H'FF7000 is specified as a start address to download
an on-chip program.
H'08 to H'FF: Setting prohibited. Specifying this value sets
the TDRE bit to 1 and stops the download.
Rev. 6.00 Sep. 24, 2009 Page 683 of 928
REJ09B0099-0600
Section 20 Flash Memory
System Control Register 2 (SYSCR2): SYSCR2 controls register accesses.
Bit
Bit Name
Initial
Value
R/W
Description
7 to 4 ⎯
Undefined ⎯
Reserved
3
0
Flash memory control register enable
The write value should always be 0.
FLSHE
R/W
The access of the flash memory control register to the
CPU is controlled by writing 0. Setting 1 to FLSHE bit
enables reading/programming the flash memory control
register. When this bit is cleared to 0, the flash memory
control register is not selected. In this case, the content
of the flash memory control register is retained.
0: Flash control logic unit which controls H'FFFFA4 to
H'FFFFAF is disabled.
1: Flash control logic unit which controls H'FFFFA4 to
H'FFFFAF is enabled.
2
⎯
Undefined ⎯
Reserved
1, 0
⎯
All 0
Reserved
The write value should always be 0.
R/W
The write value should always be 0.
20.3.2
Programming/Erasing Interface Parameter
The programming/erasing interface parameter specifies the operating frequency, user branch
destination address, storage place for program data, programming destination address, and erase
block and exchanges the processing result for the downloaded on-chip program. This parameter
uses the general registers of the CPU (ER0 and ER1) or the on-chip RAM area. The initial value is
undefined at a power-on reset or in hardware standby mode.
When download, initialization, or on-chip program is executed, registers of the CPU except for
R0L are stored. The return value of the processing result is written in R0L. Since the stack area is
used for storing the registers except for R0L, the stack area must be saved at the processing start.
(A maximum size of a stack area to be used is 128 bytes.)
The programming/erasing interface parameter is used in the following four items.
1. Download control
2. Initialization before programming or erasing
Rev. 6.00 Sep. 24, 2009 Page 684 of 928
REJ09B0099-0600
Section 20 Flash Memory
3. Programming
4. Erasing
These items use different parameters. The correspondence table is shown in table 20.5. The
meaning of the bits in FPFR varies in each processing program: initialization, programming, or
erasure. For details, see descriptions of FPFR for each process.
Table 20.5 Parameters and Target Modes
Name of
Parameter
Abbrevia- Down
tion
Load
Initialization
Programming
Erasure
R/W
Initial
Value
Allocation
Download pass
and fail result
DPFR
⎯
⎯
⎯
R/W
Undefined
On-chip
RAM*
R/W
Undefined
R0L of
CPU
Flash pass and fail FPFR
result
⎯
FPEFEQ
Flash
programming/
erasing frequency
control
⎯
⎯
⎯
R/W
Undefined
ER0 of
CPU
Flash user branch FUBRA
address set
parameter
⎯
⎯
⎯
R/W
Undefined
ER1 of
CPU
Flash multipurpose address
area
FMPAR
⎯
⎯
⎯
R/W
Undefined
ER1 of
CPU
Flash multipurpose data
destination area
FMPDR
⎯
⎯
⎯
R/W
Undefined
ER0 of
CPU
Flash erase block
select
FEBS
⎯
⎯
R/W
Undefined
ER0 of
CPU
⎯
Note: A single byte of the start address to download an on-chip program, which is specified by
FTDAR.
(1)
Download Control
The on-chip program is automatically downloaded by setting the SCO bit to 1. The on-chip RAM
area to be downloaded is the 2-kbyte area starting from the address specified by FTDAR. For the
address map of the on-chip RAM, see figure 20.10.
Download control is set by the programming/erasing interface registers, and the DPFR parameter
indicates the return value.
Rev. 6.00 Sep. 24, 2009 Page 685 of 928
REJ09B0099-0600
Section 20 Flash Memory
(a)
Download pass/fail result parameter (DPFR: single byte of start address specified by
FTDAR)
This parameter indicates the return value of the download result. The value of this parameter can
be used to determine if downloading is executed or not. Since the confirmation whether the SCO
bit is set to 1 is difficult, the certain determination must be performed by writing the single byte of
the start address specified by FTDAR to the value other than the return value of download (for
example, H'FF) before the download start (before setting the SCO bit to 1).
Initial
Value
R/W
Description
7 to 3 ⎯
⎯
⎯
Reserved
2
⎯
R/W
Source Select Error Detect
Bit
Bit Name
Return 0
SS
Only one type for the on-chip program which can be
downloaded can be specified. When more than two types
of the program are selected, the program is not selected,
or the program is selected without mapping, error is
occurred.
0: Download program can be selected normally
1: Download error is occurred (multi-selection or program
which is not mapped is selected)
1
FK
⎯
R/W
Flash Key Register Error Detect (FK)
Returns the check result whether the value of FKEY
register is set to H'A5.
0: FKEY setting is normal (FKEY = H'A5)
1: Setting value of FKEY becomes error (FKEY = value
other than H'A5)
0
SF
⎯
R/W
Success/Fail
Returns the result whether download is ended normally or
not. The determination result whether program that is
downloaded to the on-chip RAM is read back and then
transferred to the on-chip RAM is returned.
0: Downloading on-chip program is ended normally (no
error)
1: Downloading on-chip program is ended abnormally
(error occurs)
Rev. 6.00 Sep. 24, 2009 Page 686 of 928
REJ09B0099-0600
Section 20 Flash Memory
(2)
Programming/Erasing Initialization
The on-chip programming/erasing program to be downloaded includes the initialization program.
The specified period pulse must be applied when programming or erasing. The specified pulse
width is made by the method in which wait loop is configured by the CPU instruction. The
operating frequency of the CPU must be set.
The initial program is set as a parameter of the programming/erasing program which has
downloaded these settings.
(a)
Flash programming/erasing frequency parameter (FPEFEQ: General register ER0 of CPU)
This parameter sets the operating frequency of the CPU.
For the settable range of operating frequency in this LSI, see section 24.4.2, Clock Timing.
Bit
Bit Name
Initial
Value
31 to 16 F31 to F16 ⎯
R/W
Description
R/W
Reserved
These bit should be cleared to 0.
15 to 0 F15 to F0
⎯
R/W
Frequency Set
Set the operating frequency of the CPU. The setting
value must be calculated as the following methods.
•
The operating frequency which is shown in MHz units
must be rounded in a number to three decimal places
and be shown in a number of two decimal places.
•
The value multiplied by 100 is converted to the binary
digit and is written to the FPEFEQ parameter (general
register ER0).
For example, when the operating frequency of the CPU is
25.000 MHz, the value is as follows.
•
The number to three decimal places of 25.000 is
rounded and the value is thus 25.00.
•
The formula that 25.00 × 100 = 2500 is converted to
the binary digit and B'0000,1001,1100,0100 (H'09C4)
is set to ER0.
Rev. 6.00 Sep. 24, 2009 Page 687 of 928
REJ09B0099-0600
Section 20 Flash Memory
(b) Flash user branch address setting parameter (FUBRA: General register ER1 of CPU)
This parameter sets the user branch destination. Set user program is executed in a specified unit
during programming/erasure.
Bit
Bit Name
31 to 0 UA31 to
UA0
Initial
Value
R/W
Description
⎯
R/W
User Branch Destination Address
When no user branch is required, set address 0
(H'00000000). The user branch destination should be the
RAM space or external bus space to which on-chip
program is not transferred. Be careful not to branch to the
area without execution codes, or runaway or destruction
of the on-chip program area or the stack area is caused.
In case of runaway, the value of flash memory is not
guaranteed.
During the processing in the user branch destination, do
not download or initialize the on-chip program or initiate
programming/erasing program. Programming/erasing at
the return from the user branch destination is not
guaranteed. In addition, do not modify the data prepared
to be programmed. Also during the processing in the user
branch destination, do not modify the
programming/erasing interface register or make transition
to RAM emulation mode. After the user branch
processing has completed, use the RTS instruction to
return to programming/erasing program.
Rev. 6.00 Sep. 24, 2009 Page 688 of 928
REJ09B0099-0600
Section 20 Flash Memory
(c)
Flash pass/fail parameter (FPFR: general register R0L of CPU)
This parameter indicates FPFR as the return value of the initialization result.
Bit
Bit Name
Initial
Value
R/W
Description
7 to 3
⎯
⎯
⎯
Reserved
Return 0
2
BR
⎯
R/W
User Branch Error Detect
Returns the check result whether the specified user
branch destination address is in the storage area for the
downloaded programming/erasing-related programs.
0: Setting of user branch address is normal
1: Setting of user branch address is abnormal
1
FQ
⎯
R/W
Frequency Error Detect
Returns the check result whether the specified operating
frequency of the CPU is in the range of the supported
operating frequency.
0: Setting of operating frequency is normal
1: Setting of operating frequency is abnormal
0
SF
⎯
R/W
Success/Fail
Indicates whether initialization is completed normally.
0: Initialization is ended normally (no error)
1: Initialization is ended abnormally (error occurs)
Rev. 6.00 Sep. 24, 2009 Page 689 of 928
REJ09B0099-0600
Section 20 Flash Memory
(3)
Programming Execution
When flash memory is programmed, the programming destination address on the user MAT and
the program data must be passed to the downloaded programming program.
1. The start address of the programming destination on the user MAT must be stored in a general
register ER1. This parameter is called as FMPAR (flash multipurpose address area parameter).
Since the program data is always in units of 128 bytes, the lower eight bits (A7 to A0) must be
H'00 or H'80 as the boundary of the programming start address on the user MAT.
2. The program data for the user MAT must be prepared in the consecutive area. The program
data must be in the consecutive space which can be accessed by using the MOV.B instruction
of the CPU and in other than the flash memory space.
When data to be programmed does not satisfy 128 bytes, the 128-byte program data must be
prepared by filling with the dummy code H'FF.
The start address of the area in which the prepared program data is stored must be stored in a
general register ER0. This parameter is called as FMPDR (flash multipurpose data destination
area parameter).
For details on the program processing procedure, see section 20.4.2, User Program Mode.
(a)
Flash multipurpose address area parameter (FMPAR: general register ER1 of CPU)
This parameter stores the start address of the programming destination on the user MAT.
When the address in the area other than flash memory space is set, an error occurs.
The start address of the programming destination must be at the 128-byte boundary. If this
boundary condition is not satisfied, an error occurs. The error occurrence is indicated by the WA
bit in FPFR.
Bit
Bit Name
31 to 0 MOA31 to
MOA0
Initial
Value
R/W
Description
⎯
R/W
Store the start address of the programming destination
on the user MAT. The consecutive 128-byte
programming is executed starting from the specified start
address of the user MAT. Therefore, the specified
programming start address becomes a 128-byte
boundary and MOA6 to MOA0 are always 0.
Rev. 6.00 Sep. 24, 2009 Page 690 of 928
REJ09B0099-0600
Section 20 Flash Memory
(b) Flash multipurpose data destination parameter (FMPDR: general register ER0 of CPU):
This parameter stores the start address in the area which stores the data to be programmed in the
user MAT. When the storage destination of the program data is in flash memory, an error occurs.
The error occurrence is indicated by the WD bit in FPFR.
Bit
Bit Name
Initial
Value
31 to 0 MOD31 to ⎯
MOD0
(c)
R/W
Description
R/W
Store the start address of the area which stores the
program data for the user MAT. The consecutive 128byte data is programmed to the user MAT starting from
the specified start address.
Flash pass/fail parameter (FPFR: general register R0L of CPU)
This parameter indicates the return value of the program processing result.
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
⎯
⎯
Reserved
Return 0.
6
MD
⎯
R/W
Programming Mode Related Setting Error Detect
Returns the check result that the error protection state is
not entered. For conditions to enter the error protection
state, see section 20.5.3, Error Protection.
0: FLER setting is normal (FLER = 0)
1: Programming cannot be performed (FLER = 1)
Rev. 6.00 Sep. 24, 2009 Page 691 of 928
REJ09B0099-0600
Section 20 Flash Memory
Bit
Bit Name
Initial
Value
R/W
Description
5
EE
⎯
R/W
Programming Execution Error Detect
1 is returned to this bit when the specified data could not
be written or some flash memory related registers are
rewritten at return from the user brunch processing
because the user MAT was not erased.
If FMATS is set to H'AA and the user boot MAT is
selected, an error occurs when programming is
performed. In this case, both the user MAT and user boot
MAT are not rewritten. Programming of the user boot
MAT should be performed in boot mode or programmer
mode.
0: Programming has ended normally
1: Programming has ended abnormally (programming
result is not guaranteed)
4
FK
⎯
R/W
Flash Key Register Error Detect
Returns the check result of the value of FKEY before the
start of the programming processing.
0: FKEY setting is normal (FKEY = H'5A)
1: FKEY setting is error (FKEY = value other than H'5A)
3
⎯
⎯
⎯
Reserved
Returns 0.
2
WD
⎯
R/W
Write Data Address Detect
When the following address is specified as the start
address of the storage destination of the program data,
an error occurs.
•
The address in the on-chip RAM where
programming/erasing program is downloaded
•
The address in the flash memory area
0: Setting of write data address is normal
1: Setting of write data address is abnormal
Rev. 6.00 Sep. 24, 2009 Page 692 of 928
REJ09B0099-0600
Section 20 Flash Memory
Bit
Bit Name
Initial
Value
R/W
Description
1
WA
⎯
R/W
Write Address Error Detect
When the following items are specified as the start
address of the programming destination, an error occurs.
•
When the programming destination address in the
area other than flash memory is specified
•
When the specified address is not 128-byte
boundary (that is, A6 to A0 are not 0)
0: Setting of programming destination address is normal
1: Setting of programming destination address is
abnormal
0
SF
⎯
R/W
Success/Fail
Indicates whether the program processing is ended
normally or not.
0: Programming is ended normally (no error)
1: Programming is ended abnormally (error occurs)
(4)
Erasure Execution
When flash memory is erased, the erase-block number on the user MAT must be passed to the
erasing program which is downloaded. This is set to the FEBS parameter (general register ER0).
One block is specified from the block number 0 to 15.
For details on the erasing processing procedure, see section 20.4.2, User Program Mode.
Rev. 6.00 Sep. 24, 2009 Page 693 of 928
REJ09B0099-0600
Section 20 Flash Memory
(a)
Flash erase block select parameter (FEBS: general register ER0 of CPU)
This parameter specifies the erase-block number. The several block numbers cannot be specified.
Bit
Bit Name
31 to 8 ⎯
Initial
Value
R/W
Description
⎯
⎯
Reserved
These bits should be cleared to 0.
7
EB7
⎯
R/W
Erase Block
6
EB6
⎯
R/W
5
EB5
⎯
R/W
4
EB4
⎯
R/W
3
EB3
⎯
R/W
Set the erase-block number in the range from 0 to 15. 0
corresponds to the EB0 block and 15 corresponds to the
EB15 block. An error occurs when the number other than
0 to 15 is set.
2
EB2
⎯
R/W
1
EB1
⎯
R/W
0
EB0
⎯
R/W
(b) Flash pass/fail parameter (FPFR: general register R0L of CPU)
This parameter returns value of the erasing processing result.
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
⎯
⎯
Reserved
Return 0.
6
MD
⎯
⎯
Erasure Mode Related Setting Error Detect
Returns the check result of whether the error protection
state is entered. For conditions to enter the error
protection state, see section 20.5.3, Error Protection.
0: FLER setting is normal (FLER = 0)
1: FLER = 1 and erasure cannot be performed
Rev. 6.00 Sep. 24, 2009 Page 694 of 928
REJ09B0099-0600
Section 20 Flash Memory
Bit
Bit Name
Initial
Value
R/W
Description
5
EE
⎯
R/W
Erasure Execution Error Detect
1 is returned to this bit when the user MAT could not be
erased or when flash-memory related register settings
are partially changed at the return from the user branch
processing. If FMATS is set to H'AA and the user boot
MAT is selected, an error occurs when erasure is
performed. In this case, both the user MAT and user boot
MAT are not erased. Erasing of the user boot MAT
should be performed in boot mode or programming
mode.
0: Erasure has ended normally
1: Erasure has ended abnormally (erasure result is not
guaranteed)
4
FK
⎯
R/W
Flash Key Register Error Detect
Returns the check result of FKEY value before start of
the erasing processing.
0: FKEY setting is normal (FKEY = H'5A)
1: FKEY setting is error (FKEY = value other than H'5A)
3
EB
⎯
R/W
Erase Block Select Error Detect
Returns the check result whether the specified eraseblock number is in the block range of the user MAT.
0: Setting of erase-block number is normal
1: Setting of erase-block number is abnormal
2, 1
⎯
⎯
⎯
Reserved
Return 0.
0
SF
⎯
R/W
Success/Fail
Indicates whether the erasing processing is ended
normally or not.
0: Erasure is ended normally (no error)
1: Erasure is ended abnormally (error occurs)
Rev. 6.00 Sep. 24, 2009 Page 695 of 928
REJ09B0099-0600
Section 20 Flash Memory
20.3.3
RAM Emulation Register (RAMER)
When the real-time programming of the user MAT is emulated, RAMER sets the area of the user
MAT which is overlapped with a part of the on-chip RAM. RAMER is initialized to H'00 at a
power-on reset or in hardware standby mode and is not initialized in software standby mode or in
watch mode. The RAMER setting must be executed in user mode or in user program mode.
For the division method of the user-MAT area, see table 20.6. In order to operate the emulation
function certainly, the target MAT of the RAM emulation must not be accessed immediately after
RAMER is programmed. If it is accessed, the normal access is not guaranteed.
Bit
Bit Name
Initial
Value
R/W
Description
7 to 5
⎯
All 0
R
Reserved
These bits are always read as 0. The write value should
always be 0.
4
⎯
0
R/W
Reserved
The write value should always be 0.
3
RAMS
⎯
R/W
RAM Select
Sets whether the user MAT is emulated or not. When
RAMS = 1, all blocks of the user boot MAT are in the
programming/erasing protection state.
0: RAM emulation function is invalid
All blocks of the user MAT are not in the
programming/erasing protection state
1: RAM emulation function is valid
All blocks of the user MAT are in the
programming/erasing protection state
2
RAM2
0
R/W
User MAT Area Select
1
RAM1
0
R/W
0
RAM0
0
R/W
These bits are used with bit 3 and select the user-MAT
area to be overlapped with the on-chip RAM. (See table
20.6.)
Rev. 6.00 Sep. 24, 2009 Page 696 of 928
REJ09B0099-0600
Section 20 Flash Memory
Table 20.6 Division of User MAT Area
RAM Area
Block Name
RAMS
RAM2
RAM1
RAM0
H'FFD000 to H'FFDFFF RAM area (4 kbytes) 0
*
*
*
H'000000 to H'000FFF
EB0 (4 kbytes)
1
0
0
0
H'001000 to H'001FFF
EB1 (4 kbytes)
1
0
0
1
H'002000 to H'002FFF
EB2 (4 kbytes)
1
0
1
0
H'003000 to H'003FFF
EB3 (4 kbytes)
1
0
1
1
H'004000 to H'004FFF
EB4 (4 kbytes)
1
1
0
0
H'005000 to H'005FFF
EB5 (4 kbytes)
1
1
0
1
H'006000 to H'006FFF
EB6 (4 kbytes)
1
1
1
0
H'007000 to H'007FFF
EB7 (4 kbytes)
1
1
1
1
Legend:
*: Don’t care
20.3.4
Flash Vector Address Control Register (FVACR)
FVACR modifies the space from which the vector table data of the NMI interrupts is read.
Normally the vector table data is read from the address spaces from H'00001C to H'00001F.
However, the vector table can be read from the internal I/O register (FVADRR to FVADRL) by
the FVACR setting. FVACR is initialized to H'00 at a power-on reset or in hardware standby
mode.
All interrupts including NMI must be prohibited in the programming/erasing processing or during
downloading on-chip program. When the NMI interrupt is necessary such as in the system error
processing, FVACR and FVADRR to FVADRL must be set and the interrupt exception
processing routine must be set in the on-chip RAM space or in the external space.
Bit
Bit Name
Initial
Value
R/W
Description
7
FVCHGE
0
R/W
Vector Switch Function Valid
Selects whether the function for modifying the space from
which the vector table data is read is valid or invalid. When
FVCHGE = 1, the vector table data can be read from the
internal I/O register (FVADRR to FVADRL).
0: Function for modifying the space from which the vector
table data is read is invalid (Initial value)
1: Function for modifying the space from which the vector
table data is read is valid
Rev. 6.00 Sep. 24, 2009 Page 697 of 928
REJ09B0099-0600
Section 20 Flash Memory
Bit
Bit Name
6 to 0 ⎯
Initial
Value
R/W
Description
All 0
R
Reserved
These bits are always read as 0. The write value should
always be 0.
20.3.5
Flash Vector Address Data Register (FVADR)
This is a register to store the vector data when the flash vector address control register (FVACR) is
used to enable the function to select the space where the vector table data is read. This register
consists of four 8-bit registers: FVADRR, FVADRE, FVADRH, and FVADRL. This register is
initialized to H'00000000 at a power-on reset or in hardware standby mode.
• FVADRR
Bit
Bit Name Initial Value R/W
31 to 24 ⎯
All 0
R/W
Description
Set the vector address.
• FVADRE
Bit
Bit Name Initial Value R/W
23 to 16 ⎯
All 0
Description
R/W
Set the vector address.
• FVADRH
Bit
Bit Name Initial Value
R/W
Description
15 to 8
⎯
R/W
Set the vector address.
All 0
• FVADRL
Bit
Bit Name Initial Value
R/W
Description
7 to 0
⎯
R/W
Set the vector address.
All 0
Rev. 6.00 Sep. 24, 2009 Page 698 of 928
REJ09B0099-0600
Section 20 Flash Memory
20.4
On-Board Programming Mode
When the pin is set in on-board programming mode and the reset start is executed, the on-board
programming state that can program/erase the on-chip flash memory is entered. On-board
programming mode has three operating modes: user program mode, user boot mode, and boot
mode.
For details of the pin setting for entering each mode, see table 20.1. For details of the state
transition of each mode for flash memory, see figure 20.2.
20.4.1
Boot Mode
Boot mode executes programming/erasing user MAT and user boot MAT by means of the control
command and program data transmitted from the host using the on-chip SCI. The tool for
transmitting the control command and program data must be prepared in the host. The SCI
communication mode is set to asynchronous mode. When reset start is executed after this LSI’s
pin is set in boot mode, the boot program in the microcomputer is initiated. After the SCI bit rate
is automatically adjusted, the communication with the host is executed by means of the control
command method.
The system configuration diagram in boot mode is shown in figure 20.6. For details on the pin
setting in boot mode, see table 20.1. The NMI and other interrupts are ignored in boot mode.
However, the NMI and other interrupts should be disabled in the user system.
This LSI
Control command,
analysis execution
software (on-chip)
Host
Boot
programming
tool and program
data
Control command, program data
RxD0
On-chip SCI_0
Reply response
Flash
memory
On-chip RAM
TxD0
Figure 20.6 System Configuration in Boot Mode
Rev. 6.00 Sep. 24, 2009 Page 699 of 928
REJ09B0099-0600
Section 20 Flash Memory
(1)
SCI Interface Setting by Host
When boot mode is initiated, this LSI measures the low period of asynchronous SCI-communication data (H'00), which is transmitted consecutively by the host. The SCI transmit/receive format
is set to 8-bit data, 1 stop bit, and no parity. This LSI calculates the bit rate of transmission by the
host by means of the measured low period and transmits the bit adjustment end sign (1 byte of
H'00) to the host. The host must confirm that this bit adjustment end sign (H'00) has been received
normally and transmits 1 byte of H'55 to this LSI. When reception is not executed normally, boot
mode is initiated again (reset) and the operation described above must be executed. The bit rate
between the host and this LSI is not matched by the bit rate of transmission by the host and system
clock frequency of this LSI. To operate the SCI normally, the transfer bit rate of the host must be
set to 9,600 bps or 19,200 bps.
The system clock frequency, which can automatically adjust the transfer bit rate of the host and
the bit rate of this LSI, is shown in table 20.7. Boot mode must be initiated in the range of this
system clock.
Start
bit
D0
D1
D2
D3
D4
D5
Measure low period (9 bits) (data is H'00)
D6
D7
Stop bit
High period of
at least 1 bit
Figure 20.7 Automatic-Bit-Rate Adjustment Operation of SCI
Table 20.7 System Clock Frequency for Automatic-Bit-Rate Adjustment by This LSI
Bit Rate of Host
System Clock Frequency
9,600 bps
10 to 26 MHz
19,200 bps
16 to 26 MHz
(2)
State Transition Diagram
The overview of the state transition diagram after boot mode is initiated is shown in figure 20.8.
1. Bit rate adjustment
After boot mode is initiated, the bit rate of the SCI interface is adjusted with that of the host.
2. Waiting for inquiry set command
For inquiries about user-MAT size and configuration, MAT start address, and support state,
the required information is transmitted to the host.
3. Automatic erasure of all user MAT and user boot MAT
Rev. 6.00 Sep. 24, 2009 Page 700 of 928
REJ09B0099-0600
Section 20 Flash Memory
After inquiries have finished, all user MAT and user boot MAT are automatically 
Similar pages