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
32
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.
H8SX/1665 Group,
H8SX/1665M Group
Hardware Manual
Renesas 32-Bit CISC Microcomputer
H8SX Family / H8SX/1600 Series
H8SX/1665
H8SX/1662
H8SX/1665M
H8SX/1662M
R5F61665
R5F61662
R5F61665M
R5F61662M
All information contained in these materials, including products and product
specifications, represents information on the product at the time of publication
and is subject to change by Renesas Electronics Corp. without notice. Please
review the latest information published by Renesas Electronics Corp. through
various means, including the Renesas Electronics Corp. website (http://www.
renesas.com).
Rev.2.00 2009.10
Rev. 2.00 Oct. 21, 2009 Page ii of xxxii
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. 2.00 Oct. 21, 2009 Page iii of xxxii
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 occur
due to the false recognition of the pin state as an input signal become possible. 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. 2.00 Oct. 21, 2009 Page iv of xxxii
How to Use This Manual
1. Objective and Target Users
This manual was written to explain the hardware functions and electrical characteristics of this
LSI to the target users, i.e. those who will be using this LSI in the design of application
systems. Target users are expected to understand the fundamentals of electrical circuits, logic
circuits, and microcomputers.
This manual is organized in the following items: an overview of the product, descriptions of
the CPU, system control functions, and peripheral functions, electrical characteristics of the
device, and usage notes.
When designing an application system that includes this LSI, take all points to note into
account. Points to note are given in their contexts and at the final part of each section, and
in the section giving usage notes.
The list of revisions is a summary of major points of revision or addition for earlier versions.
It does not cover all revised items. For details on the revised points, see the actual locations
in the manual.
The following documents have been prepared for the H8SX/1665 Group and the H8SX/1665M
Group. Before using any of the documents, please visit our web site to verify that you have the
most up-to-date available version of the document.
Document Type
Contents
Document Title
Document No.
Data Sheet
Overview of hardware and electrical ⎯
characteristics
⎯
Hardware Manual
Hardware specifications (pin
assignments, memory maps,
peripheral specifications, electrical
characteristics, and timing charts)
and descriptions of operation
H8SX/1665 Group,
H8SX/1665M Group
Hardware Manual
This manual
Software Manual
Detailed descriptions of the CPU
and instruction set
H8SX Family Software
Manual
REJ09B0102
Application Note
Examples of applications and
sample programs
The latest versions are available from our
web site.
Renesas Technical
Update
Preliminary report on the
specifications of a product,
document, etc.
Rev. 2.00 Oct. 21, 2009 Page v of xxxii
2. Description of Numbers and Symbols
Aspects of the notations for register names, bit names, numbers, and symbolic names in this
manual are explained below.
(1) Overall notation
In descriptions involving the names of bits and bit fields within this manual, the modules and
registers to which the bits belong may be clarified by giving the names in the forms
"module name"."register name"."bit name" or "register name"."bit name".
(2) Register notation
The style "register name"_"instance number" is used in cases where there is more than one
instance of the same function or similar functions.
[Example] CMCSR_0: Indicates the CMCSR register for the compare-match timer of channel 0.
(3) Number notation
Binary numbers are given as B'nnnn (B' may be omitted if the number is obviously binary),
hexadecimal numbers are given as H'nnnn or 0xnnnn, and decimal numbers are given as nnnn.
[Examples] Binary:
B'11 or 11
Hexadecimal: H'EFA0 or 0xEFA0
Decimal:
1234
(4) Notation for active-low
An overbar on the name indicates that a signal or pin is active-low.
[Example] WDTOVF
(4)
(2)
14.2.2 Compare Match Control/Status Register_0, _1 (CMCSR_0, CMCSR_1)
CMCSR indicates compare match generation, enables or disables interrupts, and selects the counter
input clock. Generation of a WDTOVF signal or interrupt initializes the TCNT value to 0.
14.3 Operation
14.3.1 Interval Count Operation
When an internal clock is selected with the CKS1 and CKS0 bits in CMCSR and the STR bit in
CMSTR is set to 1, CMCNT starts incrementing using the selected clock. When the values in
CMCNT and the compare match constant register (CMCOR) match, CMCNT is cleared to H'0000
and the CMF flag in CMCSR is set to 1. When the CKS1 and CKS0 bits are set to B'01 at this time,
a f/4 clock is selected.
Rev. 0.50, 10/04, page 416 of 914
(3)
Note: The bit names and sentences in the above figure are examples and have nothing to do
with the contents of this manual.
Rev. 2.00 Oct. 21, 2009 Page vi of xxxii
3. Description of Registers
Each register description includes a bit chart, illustrating the arrangement of bits, and a table of
bits, describing the meanings of the bit settings. The standard format and notation for bit charts
and tables are described below.
[Bit Chart]
Bit:
Initial value:
R/W:
15
14
⎯
⎯
13
12
11
ASID2 ASID1 ASID0
10
9
8
7
6
5
4
⎯
⎯
⎯
⎯
⎯
⎯
Q
3
2
1
ACMP2 ACMP1 ACMP0
0
IFE
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R
R
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
(1)
[Table of Bits]
Bit
(2)
(3)
(4)
(5)
Bit Name
−
−
Initial Value R/W
Description
0
0
R
R
Reserved
These bits are always read as 0.
13 to 11
ASID2 to
ASID0
All 0
R/W
Address Identifier
These bits enable or disable the pin function.
10
−
0
R
Reserved
This bit is always read as 0.
9
−
1
R
Reserved
This bit is always read as 1.
−
0
15
14
Note: The bit names and sentences in the above figure are examples, and have nothing to do with the contents of this
manual.
(1) Bit
Indicates the bit number or numbers.
In the case of a 32-bit register, the bits are arranged in order from 31 to 0. In the case
of a 16-bit register, the bits are arranged in order from 15 to 0.
(2) Bit name
Indicates the name of the bit or bit field.
When the number of bits has to be clearly indicated in the field, appropriate notation is
included (e.g., ASID[3:0]).
A reserved bit is indicated by "−".
Certain kinds of bits, such as those of timer counters, are not assigned bit names. In such
cases, the entry under Bit Name is blank.
(3) Initial value
Indicates the value of each bit immediately after a power-on reset, i.e., the initial value.
0: The initial value is 0
1: The initial value is 1
−: The initial value is undefined
(4) R/W
For each bit and bit field, this entry indicates whether the bit or field is readable or writable,
or both writing to and reading from the bit or field are impossible.
The notation is as follows:
R/W: The bit or field is readable and writable.
R/(W): The bit or field is readable and writable.
However, writing is only performed to flag clearing.
The bit or field is readable.
R:
"R" is indicated for all reserved bits. When writing to the register, write
the value under Initial Value in the bit chart to reserved bits or fields.
The bit or field is writable.
W:
(5) Description
Describes the function of the bit or field and specifies the values for writing.
Rev. 2.00 Oct. 21, 2009 Page vii of xxxii
4. Description of Abbreviations
The abbreviations used in this manual are listed below.
•
Abbreviations specific to this product
Abbreviation
Description
BSC
Bus controller
CPG
DTC
INTC
PPG
SCI
TMR
Clock pulse generator
Data transfer controller
Interrupt controller
Programmable pulse generator
Serial communications interface
8-bit timer
TPU
WDT
16-bit timer pulse unit
Watchdog timer
• Abbreviations other than those listed above
Abbreviation
Description
ACIA
Asynchronous communications interface adapter
bps
CRC
DMA
DMAC
GSM
Hi-Z
IEBus
I/O
IrDA
LSB
MSB
NC
PLL
Bits per second
Cyclic redundancy check
Direct memory access
Direct memory access controller
Global System for Mobile Communications
High impedance
Inter Equipment Bus (IEBus is a trademark of NEC Electronics Corporation.)
Input/output
Infrared Data Association
Least significant bit
Most significant bit
No connection
Phase-locked loop
PWM
SFR
SIM
UART
VCO
Pulse width modulation
Special function register
Subscriber Identity Module
Universal asynchronous receiver/transmitter
Voltage-controlled oscillator
All trademarks and registered trademarks are the property of their respective owners.
Rev. 2.00 Oct. 21, 2009 Page viii of xxxii
Contents
Section 1 Overview................................................................................................1
1.1
1.2
1.3
1.4
Features................................................................................................................................. 1
1.1.1
Applications .......................................................................................................... 1
1.1.2
Overview of Functions.......................................................................................... 2
List of Products................................................................................................................... 10
Block Diagram.................................................................................................................... 12
Pin Assignments ................................................................................................................. 13
1.4.1
Pin Assignments ................................................................................................. 13
1.4.2
Correspondence between Pin Configuration and Operating Modes ................... 15
1.4.3
Pin Functions ...................................................................................................... 21
Section 2 CPU......................................................................................................31
2.1
2.2
2.3
2.4
2.5
2.6
2.7
Features............................................................................................................................... 31
CPU Operating Modes........................................................................................................ 33
2.2.1
Normal Mode...................................................................................................... 33
2.2.2
Middle Mode....................................................................................................... 35
2.2.3
Advanced Mode.................................................................................................. 36
2.2.4
Maximum Mode ................................................................................................. 37
Instruction Fetch ................................................................................................................. 39
Address Space..................................................................................................................... 39
Registers ............................................................................................................................. 40
2.5.1
General Registers................................................................................................ 41
2.5.2
Program Counter (PC) ........................................................................................ 42
2.5.3
Condition-Code Register (CCR)......................................................................... 43
2.5.4
Extended Control Register (EXR) ...................................................................... 44
2.5.5
Vector Base Register (VBR)............................................................................... 45
2.5.6
Short Address Base Register (SBR).................................................................... 45
2.5.7
Multiply-Accumulate Register (MAC) ............................................................... 45
2.5.8
Initial Values of CPU Registers .......................................................................... 45
Data Formats....................................................................................................................... 46
2.6.1
General Register Data Formats ........................................................................... 46
2.6.2
Memory Data Formats ........................................................................................ 47
Instruction Set ..................................................................................................................... 48
2.7.1
Instructions and Addressing Modes.................................................................... 50
2.7.2
Table of Instructions Classified by Function ...................................................... 54
2.7.3
Basic Instruction Formats ................................................................................... 64
Rev. 2.00 Oct. 21, 2009 Page ix of xxxii
2.8
2.9
Addressing Modes and Effective Address Calculation....................................................... 65
2.8.1
Register Direct—Rn ........................................................................................... 65
2.8.2
Register Indirect—@ERn................................................................................... 66
2.8.3
Register Indirect with Displacement—@(d:2, ERn), @(d:16, ERn),
or @(d:32, ERn).................................................................................................. 66
2.8.4
Index Register Indirect with Displacement—@(d:16,RnL.B),
@(d:32,RnL.B), @(d:16,Rn.W), @(d:32,Rn.W), @(d:16,ERn.L),
or @(d:32,ERn.L) ............................................................................................... 66
2.8.5
Register Indirect with Post-Increment, Pre-Decrement, Pre-Increment,
or Post-Decrement—@ERn+, @−ERn, @+ERn, or @ERn−............................. 67
2.8.6
Absolute Address—@aa:8, @aa:16, @aa:24, or @aa:32................................... 68
2.8.7
Immediate—#xx ................................................................................................. 69
2.8.8
Program-Counter Relative—@(d:8, PC) or @(d:16, PC) .................................. 69
2.8.9
Program-Counter Relative with Index Register—@(RnL.B, PC),
@(Rn.W, PC), or @(ERn.L, PC) ........................................................................ 69
2.8.10
Memory Indirect—@@aa:8 ............................................................................... 70
2.8.11
Extended Memory Indirect—@@vec:7 ............................................................. 71
2.8.12
Effective Address Calculation ............................................................................ 71
2.8.13
MOVA Instruction.............................................................................................. 73
Processing States ................................................................................................................ 74
Section 3 MCU Operating Modes ....................................................................... 77
3.1
3.2
3.3
3.4
Operating Mode Selection .................................................................................................. 77
Register Descriptions.......................................................................................................... 79
3.2.1
Mode Control Register (MDCR) ........................................................................ 79
3.2.2
System Control Register (SYSCR)..................................................................... 81
Operating Mode Descriptions ............................................................................................. 83
3.3.1
Mode 1................................................................................................................ 83
3.3.2
Mode 2................................................................................................................ 83
3.3.3
Mode 3................................................................................................................ 83
3.3.4
Mode 4................................................................................................................ 83
3.3.5
Mode 5................................................................................................................ 84
3.3.6
Mode 6................................................................................................................ 84
3.3.7
Mode 7................................................................................................................ 84
3.3.8
Pin Functions ...................................................................................................... 85
Address Map....................................................................................................................... 85
3.4.1
Address Map....................................................................................................... 85
Rev. 2.00 Oct. 21, 2009 Page x of xxxii
Section 4 Resets ...................................................................................................91
4.1
4.2
4.3
4.4
4.5
4.6
4.7
4.8
4.9
Types of Resets................................................................................................................... 91
Input/Output Pin ................................................................................................................. 93
Register Descriptions.......................................................................................................... 94
4.3.1
Reset Status Register (RSTSR)........................................................................... 94
4.3.2
Reset Control/Status Register (RSTCSR)........................................................... 96
Pin Reset ............................................................................................................................. 97
Power-on Reset (POR) (H8SX/1665M Group) .................................................................. 97
Power Supply Monitoring Reset (H8SX/1665M Group).................................................... 98
Deep Software Standby Reset............................................................................................. 99
Watchdog Timer Reset ....................................................................................................... 99
Determination of Reset Generation Source....................................................................... 100
Section 5 Voltage Detection Circuit (LVD) ......................................................101
5.1
5.2
5.3
Features............................................................................................................................. 101
Register Descriptions........................................................................................................ 102
5.2.1
Voltage Detection Control Register (LVDCR)................................................. 102
5.2.2
Reset Status Register (RSTSR)......................................................................... 103
Voltage Detection Circuit ................................................................................................. 105
5.3.1
Voltage Monitoring Reset................................................................................. 105
5.3.2
Voltage Monitoring Interrupt............................................................................ 106
5.3.3
Release from Deep Software Standby Mode by the Voltage-Detection
Circuit ............................................................................................................... 108
5.3.4
Voltage Monitor................................................................................................ 108
Section 6 Exception Handling ...........................................................................109
6.1
6.2
6.3
6.4
6.5
6.6
Exception Handling Types and Priority............................................................................ 109
Exception Sources and Exception Handling Vector Table ............................................... 110
Reset ................................................................................................................................. 112
6.3.1
Reset Exception Handling................................................................................. 112
6.3.2
Interrupts after Reset......................................................................................... 113
6.3.3
On-Chip Peripheral Functions after Reset Release ........................................... 113
Traces................................................................................................................................ 115
Address Error.................................................................................................................... 116
6.5.1
Address Error Source........................................................................................ 116
6.5.2
Address Error Exception Handling ................................................................... 117
Interrupts........................................................................................................................... 119
6.6.1
Interrupt Sources............................................................................................... 119
6.6.2
Interrupt Exception Handling ........................................................................... 119
Rev. 2.00 Oct. 21, 2009 Page xi of xxxii
6.7
6.8
6.9
Instruction Exception Handling ........................................................................................ 120
6.7.1
Trap Instruction ................................................................................................ 120
6.7.2
Sleep Instruction Exception Handling .............................................................. 121
6.7.3
Exception Handling by Illegal Instruction ........................................................ 122
Stack Status after Exception Handling ............................................................................. 123
Usage Note ....................................................................................................................... 124
Section 7 Interrupt Controller............................................................................ 125
7.1
7.2
7.3
7.4
7.5
7.6
7.7
7.8
Features............................................................................................................................. 125
Input/Output Pins.............................................................................................................. 127
Register Descriptions........................................................................................................ 127
7.3.1
Interrupt Control Register (INTCR) ................................................................. 128
7.3.2
CPU Priority Control Register (CPUPCR) ....................................................... 129
7.3.3
Interrupt Priority Registers A to O, Q, and R
(IPRA to IPRO, IPRQ, and IPRR) .................................................................... 131
7.3.4
IRQ Enable Register (IER) ............................................................................... 133
7.3.5
IRQ Sense Control Registers H and L (ISCRH, ISCRL).................................. 134
7.3.6
IRQ Status Register (ISR)................................................................................. 140
7.3.7
Software Standby Release IRQ Enable Register (SSIER) ................................ 141
Interrupt Sources............................................................................................................... 143
7.4.1
External Interrupts ............................................................................................ 143
7.4.2
Internal Interrupts ............................................................................................. 144
Interrupt Exception Handling Vector Table...................................................................... 145
Interrupt Control Modes and Interrupt Operation............................................................. 152
7.6.1
Interrupt Control Mode 0.................................................................................. 152
7.6.2
Interrupt Control Mode 2.................................................................................. 154
7.6.3
Interrupt Exception Handling Sequence ........................................................... 156
7.6.4
Interrupt Response Times ................................................................................. 157
7.6.5
DTC and DMAC Activation by Interrupt ......................................................... 158
CPU Priority Control Function Over DTC, DMAC and EXDMAC ................................ 161
Usage Notes ...................................................................................................................... 164
7.8.1
Conflict between Interrupt Generation and Disabling ...................................... 164
7.8.2
Instructions that Disable Interrupts................................................................... 165
7.8.3
Times when Interrupts are Disabled ................................................................. 165
7.8.4
Interrupts during Execution of EEPMOV Instruction ...................................... 165
7.8.5
Interrupts during Execution of MOVMD and MOVSD Instructions................ 165
7.8.6
Interrupts of Peripheral Modules ...................................................................... 166
Rev. 2.00 Oct. 21, 2009 Page xii of xxxii
Section 8 User Break Controller (UBC) ............................................................167
8.1
8.2
8.3
8.4
8.5
Features............................................................................................................................. 167
Block Diagram.................................................................................................................. 168
Register Descriptions........................................................................................................ 169
8.3.1
Break Address Register n (BARA, BARB, BARC, BARD) ............................ 170
8.3.2
Break Address Mask Register n (BAMRA, BAMRB, BAMRC, BAMRD) .... 171
8.3.3
Break Control Register n (BRCRA, BRCRB, BRCRC, BRCRD) ................... 172
Operation .......................................................................................................................... 174
8.4.1
Setting of Break Control Conditions................................................................. 174
8.4.2
PC Break........................................................................................................... 174
8.4.3
Condition Match Flag ....................................................................................... 175
Usage Notes ...................................................................................................................... 176
Section 9 Bus Controller (BSC).........................................................................179
9.1
9.2
9.3
9.4
9.5
Features............................................................................................................................. 179
Register Descriptions........................................................................................................ 182
9.2.1
Bus Width Control Register (ABWCR)............................................................ 183
9.2.2
Access State Control Register (ASTCR) .......................................................... 184
9.2.3
Wait Control Registers A and B (WTCRA, WTCRB) ..................................... 185
9.2.4
Read Strobe Timing Control Register (RDNCR) ............................................. 190
9.2.5
CS Assertion Period Control Registers (CSACR) ............................................ 191
9.2.6
Idle Control Register (IDLCR) ......................................................................... 194
9.2.7
Bus Control Register 1 (BCR1) ........................................................................ 196
9.2.8
Bus Control Register 2 (BCR2) ........................................................................ 198
9.2.9
Endian Control Register (ENDIANCR)............................................................ 199
9.2.10
SRAM Mode Control Register (SRAMCR) ..................................................... 200
9.2.11
Burst ROM Interface Control Register (BROMCR)......................................... 201
9.2.12
Address/Data Multiplexed I/O Control Register (MPXCR) ............................. 203
9.2.13
DRAM Control Register (DRAMCR) .............................................................. 204
9.2.14
DRAM Access Control Register (DRACCR)................................................... 209
9.2.15
Synchronous DRAM Control Register (SDCR) ............................................... 210
9.2.16
Refresh Control Register (REFCR) .................................................................. 211
9.2.17
Refresh Timer Counter (RTCNT)..................................................................... 215
9.2.18
Refresh Time Constant Register (RTCOR) ...................................................... 215
Bus Configuration............................................................................................................. 216
Multi-Clock Function and Number of Access Cycles ...................................................... 217
External Bus...................................................................................................................... 221
9.5.1
Input/Output Pins.............................................................................................. 221
9.5.2
Area Division.................................................................................................... 225
Rev. 2.00 Oct. 21, 2009 Page xiii of xxxii
9.6
9.7
9.8
9.9
9.5.3
Chip Select Signals ........................................................................................... 226
9.5.4
External Bus Interface ...................................................................................... 227
9.5.5
Area and External Bus Interface ....................................................................... 232
9.5.6
Endian and Data Alignment.............................................................................. 237
Basic Bus Interface ........................................................................................................... 240
9.6.1
Data Bus ........................................................................................................... 240
9.6.2
I/O Pins Used for Basic Bus Interface .............................................................. 240
9.6.3
Basic Timing..................................................................................................... 241
9.6.4
Wait Control ..................................................................................................... 247
9.6.5
Read Strobe (RD) Timing................................................................................. 249
9.6.6
Extension of Chip Select (CS) Assertion Period............................................... 250
9.6.7
DACK and EDACK Signal Output Timing...................................................... 252
Byte Control SRAM Interface .......................................................................................... 253
9.7.1
Byte Control SRAM Space Setting................................................................... 253
9.7.2
Data Bus ........................................................................................................... 253
9.7.3
I/O Pins Used for Byte Control SRAM Interface ............................................. 254
9.7.4
Basic Timing..................................................................................................... 255
9.7.5
Wait Control ..................................................................................................... 257
9.7.6
Read Strobe (RD) ............................................................................................. 259
9.7.7
Extension of Chip Select (CS) Assertion Period............................................... 259
9.7.8
DACK and EDACK Signal Output Timing...................................................... 259
Burst ROM Interface ........................................................................................................ 261
9.8.1
Burst ROM Space Setting................................................................................. 261
9.8.2
Data Bus ........................................................................................................... 261
9.8.3
I/O Pins Used for Burst ROM Interface............................................................ 262
9.8.4
Basic Timing..................................................................................................... 263
9.8.5
Wait Control ..................................................................................................... 265
9.8.6
Read Strobe (RD) Timing................................................................................. 265
9.8.7
Extension of Chip Select (CS) Assertion Period............................................... 265
Address/Data Multiplexed I/O Interface........................................................................... 266
9.9.1
Address/Data Multiplexed I/O Space Setting ................................................... 266
9.9.2
Address/Data Multiplex.................................................................................... 266
9.9.3
Data Bus ........................................................................................................... 266
9.9.4
I/O Pins Used for Address/Data Multiplexed I/O Interface.............................. 267
9.9.5
Basic Timing..................................................................................................... 268
9.9.6
Address Cycle Control...................................................................................... 270
9.9.7
Wait Control ..................................................................................................... 271
9.9.8
Read Strobe (RD) Timing................................................................................. 271
9.9.9
Extension of Chip Select (CS) Assertion Period............................................... 273
9.9.10
DACK and EDACK Signal Output Timing...................................................... 275
Rev. 2.00 Oct. 21, 2009 Page xiv of xxxii
9.10
9.11
9.12
9.13
9.14
DRAM Interface ............................................................................................................... 276
9.10.1
Setting DRAM Space........................................................................................ 276
9.10.2
Address Multiplexing........................................................................................ 276
9.10.3
Data Bus............................................................................................................ 277
9.10.4
I/O Pins Used for DRAM Interface .................................................................. 277
9.10.5
Basic Timing..................................................................................................... 278
9.10.6
Controlling Column Address Output Cycle...................................................... 279
9.10.7
Controlling Row Address Output Cycle ........................................................... 280
9.10.8
Controlling Precharge Cycle............................................................................. 282
9.10.9
Wait Control ..................................................................................................... 283
9.10.10 Controlling Byte and Word Accesses ............................................................... 286
9.10.11 Burst Access Operation..................................................................................... 288
9.10.12 Refresh Control................................................................................................. 294
9.10.13 DRAM Interface and Single Address Transfer by DMAC and EXDMAC ...... 299
Synchronous DRAM Interface ......................................................................................... 302
9.11.1
Setting SDRAM space ...................................................................................... 302
9.11.2
Address Multiplexing........................................................................................ 303
9.11.3
Data Bus............................................................................................................ 303
9.11.4
I/O Pins Used for DRAM Interface .................................................................. 304
9.11.5
Basic Timing..................................................................................................... 305
9.11.6
CAS Latency Control........................................................................................ 307
9.11.7
Controlling Row Address Output Cycle ........................................................... 309
9.11.8
Controlling Precharge Cycle............................................................................. 311
9.11.9
Controlling Clock Suspend Insertion................................................................ 313
9.11.10 Controlling Write-Precharge Delay .................................................................. 314
9.11.11 Controlling Byte and Word Accesses ............................................................... 315
9.11.12 Fast-Page Access Operation ............................................................................. 317
9.11.13 Refresh Control................................................................................................. 323
9.11.14 Setting SDRAM Mode Register ....................................................................... 331
9.11.15 SDRAM Interface and Single Address Transfer by DMAC and EXDMAC .... 332
9.11.16 EXDMAC Cluster Transfer .............................................................................. 340
Idle Cycle.......................................................................................................................... 343
9.12.1
Operation .......................................................................................................... 343
9.12.2
Pin States in Idle Cycle ..................................................................................... 355
Bus Release....................................................................................................................... 356
9.13.1
Operation .......................................................................................................... 356
9.13.2
Pin States in External Bus Released State......................................................... 357
9.13.3
Transition Timing ............................................................................................. 358
Internal Bus....................................................................................................................... 360
9.14.1
Access to Internal Address Space ..................................................................... 360
Rev. 2.00 Oct. 21, 2009 Page xv of xxxii
9.15
9.16
9.17
9.18
Write Data Buffer Function .............................................................................................. 361
9.15.1
Write Data Buffer Function for External Data Bus .......................................... 361
9.15.2
Write Data Buffer Function for Peripheral Modules ........................................ 362
Bus Arbitration ................................................................................................................. 363
9.16.1
Operation .......................................................................................................... 363
9.16.2
Bus Transfer Timing......................................................................................... 364
Bus Controller Operation in Reset.................................................................................... 367
Usage Notes ...................................................................................................................... 367
Section 10 DMA Controller (DMAC)............................................................... 371
10.1
10.2
10.3
10.4
10.5
10.6
10.7
10.8
10.9
Features............................................................................................................................. 371
Input/Output Pins.............................................................................................................. 374
Register Descriptions........................................................................................................ 375
10.3.1
DMA Source Address Register (DSAR) .......................................................... 376
10.3.2
DMA Destination Address Register (DDAR) .................................................. 377
10.3.3
DMA Offset Register (DOFR).......................................................................... 378
10.3.4
DMA Transfer Count Register (DTCR) ........................................................... 379
10.3.5
DMA Block Size Register (DBSR) .................................................................. 380
10.3.6
DMA Mode Control Register (DMDR)............................................................ 381
10.3.7
DMA Address Control Register (DACR)......................................................... 390
10.3.8
DMA Module Request Select Register (DMRSR) ........................................... 396
Transfer Modes................................................................................................................. 397
Operations......................................................................................................................... 398
10.5.1
Address Modes ................................................................................................. 398
10.5.2
Transfer Modes................................................................................................. 402
10.5.3
Activation Sources............................................................................................ 407
10.5.4
Bus Access Modes ............................................................................................ 409
10.5.5
Extended Repeat Area Function ....................................................................... 411
10.5.6
Address Update Function using Offset ............................................................. 414
10.5.7
Register during DMA Transfer......................................................................... 418
10.5.8
Priority of Channels .......................................................................................... 423
10.5.9
DMA Basic Bus Cycle...................................................................................... 425
10.5.10 Bus Cycles in Dual Address Mode ................................................................... 426
10.5.11 Bus Cycles in Single Address Mode................................................................. 435
DMA Transfer End ........................................................................................................... 440
Relationship among DMAC and Other Bus Masters........................................................ 443
10.7.1
CPU Priority Control Function Over DMAC ................................................... 443
10.7.2
Bus Arbitration among DMAC and Other Bus Masters ................................... 444
Interrupt Sources............................................................................................................... 445
Usage Notes ...................................................................................................................... 448
Rev. 2.00 Oct. 21, 2009 Page xvi of xxxii
Section 11 EXDMA Controller (EXDMAC) ....................................................449
11.1
11.2
11.3
Features............................................................................................................................. 449
Input/Output Pins.............................................................................................................. 452
Registers Descriptions ...................................................................................................... 453
11.3.1
EXDMA Source Address Register (EDSAR)................................................... 455
11.3.2
EXDMA Destination Address Register (EDDAR)........................................... 456
11.3.3
EXDMA Offset Register (EDOFR).................................................................. 457
11.3.4
EXDMA Transfer Count Register (EDTCR).................................................... 458
11.3.5
EXDMA Block Size Register (EDBSR)........................................................... 459
11.3.6
EXDMA Mode Control Register (EDMDR) .................................................... 460
11.3.7
EXDMA Address Control Register (EDACR) ................................................. 469
11.3.8
Cluster Buffer Registers 0 to 7 (CLSBR0 to CLSBR7).................................... 475
11.4 Transfer Modes ................................................................................................................. 476
11.4.1
Ordinary Modes ................................................................................................ 476
11.4.2
Cluster Transfer Modes..................................................................................... 477
11.5 Mode Operation ................................................................................................................ 478
11.5.1
Address Modes ................................................................................................. 478
11.5.2
Transfer Modes ................................................................................................. 481
11.5.3
Activation Sources............................................................................................ 486
11.5.4
Bus Mode.......................................................................................................... 487
11.5.5
Extended Repeat Area Function ....................................................................... 488
11.5.6
Address Update Function Using Offset ............................................................ 491
11.5.7
Registers during EXDMA Transfer Operation ................................................. 495
11.5.8
Channel Priority Order...................................................................................... 500
11.5.9
Basic Bus Cycles .............................................................................................. 501
11.5.10 Bus Cycles in Dual Address Mode ................................................................... 502
11.5.11 Bus Cycles in Single Address Mode................................................................. 511
11.5.12 Operation Timing in Each Mode ...................................................................... 516
11.6 Operation in Cluster Transfer Mode ................................................................................. 527
11.6.1
Address Mode ................................................................................................... 527
11.6.2
Setting of Address Update Mode ...................................................................... 532
11.6.3
Caution for Combining with Extended Repeat Area Function ......................... 533
11.6.4
Bus Cycles in Cluster Transfer Dual Address Mode ........................................ 533
11.6.5
Operation Timing in Cluster Transfer Mode .................................................... 536
11.7 Ending EXDMA Transfer................................................................................................. 544
11.8 Relationship among EXDMAC and Other Bus Masters................................................... 547
11.8.1
CPU Priority Control Function Over EXDMAC .............................................. 547
11.8.2
Bus Arbitration with Another Bus Master ........................................................ 548
11.9 Interrupt Sources............................................................................................................... 549
11.10 Usage Notes ...................................................................................................................... 552
Rev. 2.00 Oct. 21, 2009 Page xvii of xxxii
Section 12 Data Transfer Controller (DTC)...................................................... 555
12.1
12.2
12.3
12.4
12.5
12.6
12.7
12.8
12.9
Features............................................................................................................................. 555
Register Descriptions........................................................................................................ 557
12.2.1
DTC Mode Register A (MRA) ......................................................................... 558
12.2.2
DTC Mode Register B (MRB).......................................................................... 559
12.2.3
DTC Source Address Register (SAR)............................................................... 560
12.2.4
DTC Destination Address Register (DAR)....................................................... 561
12.2.5
DTC Transfer Count Register A (CRA) ........................................................... 561
12.2.6
DTC Transfer Count Register B (CRB)............................................................ 562
12.2.7
DTC enable registers A to F (DTCERA to DTCERF) ..................................... 562
12.2.8
DTC Control Register (DTCCR) ...................................................................... 563
12.2.9
DTC Vector Base Register (DTCVBR)............................................................ 565
Activation Sources............................................................................................................ 565
Location of Transfer Information and DTC Vector Table................................................ 566
Operation .......................................................................................................................... 571
12.5.1
Bus Cycle Division ........................................................................................... 573
12.5.2
Transfer Information Read Skip Function ........................................................ 575
12.5.3
Transfer Information Writeback Skip Function................................................ 576
12.5.4
Normal Transfer Mode ..................................................................................... 576
12.5.5
Repeat Transfer Mode ...................................................................................... 577
12.5.6
Block Transfer Mode ........................................................................................ 579
12.5.7
Chain Transfer .................................................................................................. 580
12.5.8
Operation Timing.............................................................................................. 581
12.5.9
Number of DTC Execution Cycles ................................................................... 583
12.5.10 DTC Bus Release Timing ................................................................................. 584
12.5.11 DTC Priority Level Control to the CPU ........................................................... 584
DTC Activation by Interrupt............................................................................................. 585
Examples of Use of the DTC............................................................................................ 586
12.7.1
Normal Transfer Mode ..................................................................................... 586
12.7.2
Chain Transfer .................................................................................................. 586
12.7.3
Chain Transfer when Counter = 0..................................................................... 587
Interrupt Sources............................................................................................................... 589
Usage Notes ...................................................................................................................... 589
12.9.1
Module Stop State Setting ................................................................................ 589
12.9.2
On-Chip RAM .................................................................................................. 589
12.9.3
DMAC Transfer End Interrupt.......................................................................... 589
12.9.4
DTCE Bit Setting.............................................................................................. 589
12.9.5
Chain Transfer .................................................................................................. 590
12.9.6 Transfer Information Start Address, Source Address, and Destination
Address ............................................................................................................. 590
Rev. 2.00 Oct. 21, 2009 Page xviii of xxxii
12.9.7
12.9.8
12.9.9
Transfer Information Modification ................................................................... 590
Endian Format................................................................................................... 590
Points for Caution when Overwriting DTCER ................................................. 591
Section 13 I/O Ports ...........................................................................................593
13.1
13.2
13.3
Register Descriptions........................................................................................................ 601
13.1.1
Data Direction Register (PnDDR) (n = 1, 2, 3, 6, A to F, H to K, and M) ....... 602
13.1.2
Data Register (PnDR) (n = 1, 2, 3, 6, A to F, H to K, and M) .......................... 603
13.1.3
Port Register (PORTn) (n = 1, 2, 3, 5, 6, A to F, H to K, and M)..................... 603
13.1.4 Input Buffer Control Register (PnICR)
(n = 1, 2, 3, 5, 6, A to F, H to K, and M)........................................................... 604
13.1.5
Pull-Up MOS Control Register (PnPCR) (n = D to F, and H to K) .................. 605
13.1.6
Open-Drain Control Register (PnODR) (n = 2 and F) ...................................... 606
Output Buffer Control....................................................................................................... 607
13.2.1
Port 1................................................................................................................. 607
13.2.2
Port 2................................................................................................................. 611
13.2.3
Port 3................................................................................................................. 615
13.2.4
Port 5................................................................................................................. 619
13.2.5
Port 6................................................................................................................. 620
13.2.6
Port A................................................................................................................ 623
13.2.7
Port B ................................................................................................................ 627
13.2.8
Port C ................................................................................................................ 631
13.2.9
Port D................................................................................................................ 632
13.2.10 Port E ................................................................................................................ 632
13.2.11 Port F ................................................................................................................ 633
13.2.12 Port H................................................................................................................ 637
13.2.13 Port I ................................................................................................................. 638
13.2.14 Port J ................................................................................................................. 638
13.2.15 Port K................................................................................................................ 643
13.2.16 Port M ............................................................................................................... 647
Port Function Controller ................................................................................................... 659
13.3.1
Port Function Control Register 0 (PFCR0)....................................................... 659
13.3.2
Port Function Control Register 1 (PFCR1)....................................................... 660
13.3.3
Port Function Control Register 2 (PFCR2)....................................................... 661
13.3.4
Port Function Control Register 4 (PFCR4)....................................................... 663
13.3.5
Port Function Control Register 6 (PFCR6)....................................................... 665
13.3.6
Port Function Control Register 7 (PFCR7)....................................................... 666
13.3.7
Port Function Control Register 8 (PFCR8)....................................................... 667
13.3.8
Port Function Control Register 9 (PFCR9)....................................................... 668
13.3.9
Port Function Control Register A (PFCRA) ..................................................... 670
Rev. 2.00 Oct. 21, 2009 Page xix of xxxii
13.4
13.3.10 Port Function Control Register B (PFCRB) ..................................................... 672
13.3.11 Port Function Control Register C (PFCRC) ..................................................... 674
13.3.12 Port Function Control Register D (PFCRD) ..................................................... 675
Usage Notes ...................................................................................................................... 676
13.4.1
Notes on Input Buffer Control Register (ICR) Setting ..................................... 676
13.4.2
Notes on Port Function Control Register (PFCR) Settings............................... 676
Section 14 16-Bit Timer Pulse Unit (TPU) ....................................................... 677
14.1
14.2
14.3
Features............................................................................................................................. 677
Input/Output Pins.............................................................................................................. 684
Register Descriptions........................................................................................................ 686
14.3.1
Timer Control Register (TCR).......................................................................... 691
14.3.2
Timer Mode Register (TMDR)......................................................................... 696
14.3.3
Timer I/O Control Register (TIOR).................................................................. 698
14.3.4
Timer Interrupt Enable Register (TIER)........................................................... 716
14.3.5
Timer Status Register (TSR)............................................................................. 717
14.3.6
Timer Counter (TCNT)..................................................................................... 721
14.3.7
Timer General Register (TGR) ......................................................................... 721
14.3.8
Timer Start Register (TSTR) ............................................................................ 722
14.3.9
Timer Synchronous Register (TSYR)............................................................... 723
14.4 Operation .......................................................................................................................... 724
14.4.1
Basic Functions................................................................................................. 724
14.4.2
Synchronous Operation..................................................................................... 730
14.4.3
Buffer Operation............................................................................................... 732
14.4.4
Cascaded Operation .......................................................................................... 736
14.4.5
PWM Modes..................................................................................................... 738
14.4.6
Phase Counting Mode....................................................................................... 743
14.5 Interrupt Sources............................................................................................................... 750
14.6 DTC Activation ................................................................................................................ 752
14.7 DMAC Activation ............................................................................................................ 752
14.8 A/D Converter Activation................................................................................................. 752
14.9 Operation Timing.............................................................................................................. 753
14.9.1
Input/Output Timing ......................................................................................... 753
14.9.2
Interrupt Signal Timing .................................................................................... 757
14.10 Usage Notes ...................................................................................................................... 761
14.10.1 Module Stop Function Setting .......................................................................... 761
14.10.2 Input Clock Restrictions ................................................................................... 761
14.10.3 Caution on Cycle Setting .................................................................................. 762
14.10.4 Conflict between TCNT Write and Clear Operations....................................... 762
14.10.5 Conflict between TCNT Write and Increment Operations ............................... 763
Rev. 2.00 Oct. 21, 2009 Page xx of xxxii
14.10.6
14.10.7
14.10.8
14.10.9
14.10.10
14.10.11
14.10.12
14.10.13
14.10.14
14.10.15
Conflict between TGR Write and Compare Match........................................... 763
Conflict between Buffer Register Write and Compare Match .......................... 764
Conflict between TGR Read and Input Capture ............................................... 764
Conflict between TGR Write and Input Capture .............................................. 765
Conflict between Buffer Register Write and Input Capture.............................. 766
Conflict between Overflow/Underflow and Counter Clearing ......................... 767
Conflict between TCNT Write and Overflow/Underflow ................................ 767
Multiplexing of I/O Pins ................................................................................... 768
PPG1 Setting when TPU1 Pin is Used.............................................................. 768
Interrupts in the Module Stop State .................................................................. 768
Section 15 Programmable Pulse Generator (PPG) ............................................769
15.1
15.2
15.3
15.4
15.5
Features............................................................................................................................. 769
Input/Output Pins.............................................................................................................. 772
Register Descriptions........................................................................................................ 774
15.3.1
Next Data Enable Registers H, L (NDERH, NDERL) ..................................... 775
15.3.2
Output Data Registers H, L (PODRH, PODRL)............................................... 778
15.3.3
Next Data Registers H, L (NDRH, NDRL) ...................................................... 780
15.3.4
PPG Output Control Register (PCR) ................................................................ 785
15.3.5
PPG Output Mode Register (PMR) .................................................................. 787
Operation .......................................................................................................................... 791
15.4.1
Output Timing................................................................................................... 791
15.4.2
Sample Setup Procedure for Normal Pulse Output........................................... 792
15.4.3
Example of Normal Pulse Output (Example of 5-Phase Pulse Output)............ 794
15.4.4
Non-Overlapping Pulse Output......................................................................... 795
15.4.5
Sample Setup Procedure for Non-Overlapping Pulse Output ........................... 797
15.4.6 Example of Non-Overlapping Pulse Output
(Example of 4-Phase Complementary Non-Overlapping Pulse Output)........... 799
15.4.7
Inverted Pulse Output ....................................................................................... 801
15.4.8
Pulse Output Triggered by Input Capture ......................................................... 802
Usage Notes ...................................................................................................................... 803
15.5.1
Module Stop State Function.............................................................................. 803
15.5.2
Operation of Pulse Output Pins......................................................................... 803
15.5.3
TPU Setting when PPG1 is in Use.................................................................... 803
Section 16 8-Bit Timers (TMR).........................................................................805
16.1
16.2
16.3
Features............................................................................................................................. 805
Input/Output Pins.............................................................................................................. 810
Register Descriptions........................................................................................................ 811
16.3.1
Timer Counter (TCNT)..................................................................................... 813
Rev. 2.00 Oct. 21, 2009 Page xxi of xxxii
16.4
16.5
16.6
16.7
16.8
16.3.2
Time Constant Register A (TCORA)................................................................ 813
16.3.3
Time Constant Register B (TCORB) ................................................................ 814
16.3.4
Timer Control Register (TCR).......................................................................... 814
16.3.5
Timer Counter Control Register (TCCR) ......................................................... 816
16.3.6
Timer Control/Status Register (TCSR)............................................................. 821
Operation .......................................................................................................................... 826
16.4.1
Pulse Output...................................................................................................... 826
16.4.2
Reset Input ........................................................................................................ 827
Operation Timing.............................................................................................................. 828
16.5.1
TCNT Count Timing ........................................................................................ 828
16.5.2
Timing of CMFA and CMFB Setting at Compare Match ................................ 829
16.5.3
Timing of Timer Output at Compare Match..................................................... 829
16.5.4
Timing of Counter Clear by Compare Match ................................................... 830
16.5.5
Timing of TCNT External Reset....................................................................... 830
16.5.6
Timing of Overflow Flag (OVF) Setting .......................................................... 831
Operation with Cascaded Connection............................................................................... 832
16.6.1
16-Bit Counter Mode ........................................................................................ 832
16.6.2
Compare Match Count Mode............................................................................ 832
Interrupt Sources............................................................................................................... 833
16.7.1
Interrupt Sources and DTC Activation ............................................................. 833
16.7.2
A/D Converter Activation................................................................................. 834
Usage Notes ...................................................................................................................... 835
16.8.1
Notes on Setting Cycle ..................................................................................... 835
16.8.2
Conflict between TCNT Write and Counter Clear ........................................... 835
16.8.3
Conflict between TCNT Write and Increment.................................................. 836
16.8.4
Conflict between TCOR Write and Compare Match........................................ 836
16.8.5
Conflict between Compare Matches A and B................................................... 837
16.8.6
Switching of Internal Clocks and TCNT Operation ......................................... 837
16.8.7
Mode Setting with Cascaded Connection ......................................................... 839
16.8.8
Module Stop State Setting ................................................................................ 839
16.8.9
Interrupts in Module Stop State ........................................................................ 839
Section 17 32K Timer (TM32K)....................................................................... 841
17.1
17.2
17.3
Features............................................................................................................................. 841
Register Descriptions........................................................................................................ 842
17.2.1
Timer Control Register (TCR32K)................................................................... 842
17.2.2
Timer Counter (TCNT32K1, TCNT32K2, TCNT32K3).................................. 843
Operation .......................................................................................................................... 845
17.3.1
Basic Operation ................................................................................................ 845
17.3.2
EXCKSN=1 Operation ..................................................................................... 846
Rev. 2.00 Oct. 21, 2009 Page xxii of xxxii
17.4
17.5
17.3.3
EXCKSN=0 Operation ..................................................................................... 846
Interrupt Source ................................................................................................................ 848
Usage Notes ...................................................................................................................... 849
17.5.1
Changing Values of Bits EXCKSN, CKS1, and CKS0 .................................... 849
17.5.2
Note on Register Initialization .......................................................................... 849
17.5.3
Usage Notes on 32K Timer............................................................................... 849
Section 18 Watchdog Timer (WDT)..................................................................851
18.1
18.2
18.3
18.4
18.5
18.6
Features............................................................................................................................. 851
Input/Output Pin ............................................................................................................... 852
Register Descriptions........................................................................................................ 853
18.3.1
Timer Counter (TCNT)..................................................................................... 853
18.3.2
Timer Control/Status Register (TCSR)............................................................. 853
18.3.3
Reset Control/Status Register (RSTCSR)......................................................... 855
Operation .......................................................................................................................... 856
18.4.1
Watchdog Timer Mode ..................................................................................... 856
18.4.2
Interval Timer Mode ......................................................................................... 858
Interrupt Source ................................................................................................................ 858
Usage Notes ...................................................................................................................... 859
18.6.1
Notes on Register Access.................................................................................. 859
18.6.2
Conflict between Timer Counter (TCNT) Write and Increment....................... 860
18.6.3
Changing Values of Bits CKS2 to CKS0.......................................................... 860
18.6.4
Switching between Watchdog Timer Mode and Interval Timer Mode............. 860
18.6.5
Internal Reset in Watchdog Timer Mode.......................................................... 861
18.6.6
System Reset by WDTOVF Signal................................................................... 861
18.6.7
Transition to Watchdog Timer Mode or Software Standby Mode.................... 861
Section 19 Serial Communication Interface (SCI, IrDA, CRC)........................863
19.1
19.2
19.3
Features............................................................................................................................. 863
Input/Output Pins.............................................................................................................. 868
Register Descriptions........................................................................................................ 869
19.3.1
Receive Shift Register (RSR) ........................................................................... 871
19.3.2
Receive Data Register (RDR) ........................................................................... 871
19.3.3
Transmit Data Register (TDR).......................................................................... 872
19.3.4
Transmit Shift Register (TSR) .......................................................................... 872
19.3.5
Serial Mode Register (SMR) ............................................................................ 872
19.3.6
Serial Control Register (SCR)........................................................................... 876
19.3.7
Serial Status Register (SSR) ............................................................................. 881
19.3.8
Smart Card Mode Register (SCMR)................................................................. 890
19.3.9
Bit Rate Register (BRR) ................................................................................... 891
Rev. 2.00 Oct. 21, 2009 Page xxiii of xxxii
19.3.10 Serial Extended Mode Register (SEMR_2) ...................................................... 898
19.3.11 Serial Extended Mode Register 5 and 6 (SEMR_5 and SEMR_6)................... 900
19.3.12 IrDA Control Register (IrCR)........................................................................... 907
19.4 Operation in Asynchronous Mode .................................................................................... 908
19.4.1
Data Transfer Format........................................................................................ 909
19.4.2 Receive Data Sampling Timing and Reception Margin in Asynchronous
Mode ................................................................................................................. 910
19.4.3
Clock................................................................................................................. 911
19.4.4
SCI Initialization (Asynchronous Mode).......................................................... 912
19.4.5
Serial Data Transmission (Asynchronous Mode) ............................................. 913
19.4.6
Serial Data Reception (Asynchronous Mode) .................................................. 915
19.5 Multiprocessor Communication Function ........................................................................ 919
19.5.1
Multiprocessor Serial Data Transmission ......................................................... 921
19.5.2
Multiprocessor Serial Data Reception .............................................................. 922
19.6 Operation in Clocked Synchronous Mode (SCI_0, 1, 2, and 4 only)................................ 925
19.6.1
Clock................................................................................................................. 925
19.6.2
SCI Initialization (Clocked Synchronous Mode) (SCI_0, 1, 2, and 4 only) ..... 926
19.6.3 Serial Data Transmission (Clocked Synchronous Mode)
(SCI_0, 1, 2, and 4 only)................................................................................... 927
19.6.4 Serial Data Reception (Clocked Synchronous Mode)
(SCI_0, 1, 2, and 4 only)................................................................................... 929
19.6.5 Simultaneous Serial Data Transmission and Reception
(Clocked Synchronous Mode) (SCI_0, 1, 2, and 4 only) .................................. 930
19.7 Operation in Smart Card Interface Mode.......................................................................... 932
19.7.1
Sample Connection ........................................................................................... 932
19.7.2
Data Format (Except in Block Transfer Mode) ................................................ 933
19.7.3
Block Transfer Mode ........................................................................................ 934
19.7.4
Receive Data Sampling Timing and Reception Margin ................................... 935
19.7.5
Initialization...................................................................................................... 936
19.7.6
Data Transmission (Except in Block Transfer Mode) ...................................... 937
19.7.7
Serial Data Reception (Except in Block Transfer Mode) ................................. 940
19.7.8
Clock Output Control (Only SCI_0, 1, 2, and 4) .............................................. 941
19.8 IrDA Operation................................................................................................................. 943
19.9 Interrupt Sources............................................................................................................... 946
19.9.1
Interrupts in Normal Serial Communication Interface Mode ........................... 946
19.9.2
Interrupts in Smart Card Interface Mode .......................................................... 947
19.10 Usage Notes ...................................................................................................................... 949
19.10.1 Module Stop Function Setting .......................................................................... 949
19.10.2 Break Detection and Processing ....................................................................... 949
19.10.3 Mark State and Break Detection ....................................................................... 949
Rev. 2.00 Oct. 21, 2009 Page xxiv of xxxii
19.10.4 Receive Error Flags and Transmit Operations
(Clocked Synchronous Mode Only).................................................................. 949
19.10.5 Relation between Writing to TDR and TDRE Flag .......................................... 950
19.10.6 Restrictions on Using DTC or DMAC.............................................................. 950
19.10.7 SCI Operations during Power-Down State ....................................................... 951
19.11 CRC Operation Circuit ..................................................................................................... 954
19.11.1 Features............................................................................................................. 954
19.11.2 Register Descriptions ........................................................................................ 955
19.11.3 CRC Operation Circuit Operation..................................................................... 957
19.11.4 Note on CRC Operation Circuit........................................................................ 960
Section 20 USB Function Module (USB)..........................................................961
20.1
20.2
20.3
Features............................................................................................................................. 961
Input/Output Pins.............................................................................................................. 962
Register Descriptions........................................................................................................ 963
20.3.1
Interrupt Flag Register 0 (IFR0) ....................................................................... 964
20.3.2
Interrupt Flag Register 1 (IFR1) ....................................................................... 966
20.3.3
Interrupt Flag Register 2 (IFR2) ....................................................................... 967
20.3.4
Interrupt Select Register 0 (ISR0)..................................................................... 969
20.3.5
Interrupt Select Register 1 (ISR1)..................................................................... 970
20.3.6
Interrupt Select Register 2 (ISR2)..................................................................... 971
20.3.7
Interrupt Enable Register 0 (IER0) ................................................................... 972
20.3.8
Interrupt Enable Register 1 (IER1) ................................................................... 973
20.3.9
Interrupt Enable Register 2 (IER2) ................................................................... 973
20.3.10 EP0i Data Register (EPDR0i) ........................................................................... 974
20.3.11 EP0o Data Register (EPDR0o) ......................................................................... 975
20.3.12 EP0s Data Register (EPDR0s) .......................................................................... 975
20.3.13 EP1 Data Register (EPDR1) ............................................................................. 976
20.3.14 EP2 Data Register (EPDR2) ............................................................................. 976
20.3.15 EP3 Data Register (EPDR3) ............................................................................. 977
20.3.16 EP0o Receive Data Size Register (EPSZ0o) .................................................... 977
20.3.17 EP1 Receive Data Size Register (EPSZ1) ........................................................ 978
20.3.18 Trigger Register (TRG)..................................................................................... 978
20.3.19 Data Status Register (DASTS).......................................................................... 980
20.3.20 FIFO Clear Register (FCLR) ............................................................................ 981
20.3.21 DMA Transfer Setting Register (DMA) ........................................................... 982
20.3.22 Endpoint Stall Register (EPSTL)...................................................................... 985
20.3.23 Configuration Value Register (CVR) ............................................................... 986
20.3.24 Control Register (CTLR) .................................................................................. 986
20.3.25 Endpoint Information Register (EPIR) ............................................................. 988
Rev. 2.00 Oct. 21, 2009 Page xxv of xxxii
20.3.26 Transceiver Test Register 0 (TRNTREG0) ...................................................... 992
20.3.27 Transceiver Test Register 1 (TRNTREG1) ...................................................... 994
20.4 Interrupt Sources............................................................................................................... 996
20.5 Operation .......................................................................................................................... 998
20.5.1
Cable Connection.............................................................................................. 998
20.5.2
Cable Disconnection ......................................................................................... 999
20.5.3
Suspend and Resume Operations...................................................................... 999
20.5.4
Control Transfer.............................................................................................. 1007
20.5.5
EP1 Bulk-Out Transfer (Dual FIFOs)............................................................. 1013
20.5.6
EP2 Bulk-In Transfer (Dual FIFOs) ............................................................... 1014
20.5.7
EP3 Interrupt-In Transfer................................................................................ 1015
20.6 Processing of USB Standard Commands and Class/Vendor Commands ....................... 1016
20.6.1
Processing of Commands Transmitted by Control Transfer........................... 1016
20.7 Stall Operations .............................................................................................................. 1017
20.7.1
Overview ........................................................................................................ 1017
20.7.2
Forcible Stall by Application .......................................................................... 1017
20.7.3
Automatic Stall by USB Function Module ..................................................... 1019
20.8 DMA Transfer ................................................................................................................ 1020
20.8.1
Overview ........................................................................................................ 1020
20.8.2
DMA Transfer for Endpoint 1 ........................................................................ 1020
20.8.3
DMA Transfer for Endpoint 2 ........................................................................ 1021
20.9 Example of USB External Circuitry ............................................................................... 1022
20.10 Usage Notes .................................................................................................................... 1024
20.10.1 Receiving Setup Data...................................................................................... 1024
20.10.2 Clearing the FIFO ........................................................................................... 1024
20.10.3 Overreading and Overwriting the Data Registers ........................................... 1024
20.10.4 Assigning Interrupt Sources to EP0................................................................ 1025
20.10.5 Clearing the FIFO When DMA Transfer is Enabled ...................................... 1025
20.10.6 Notes on TR Interrupt ..................................................................................... 1025
20.10.7 Restrictions on Peripheral Module Clock (Pφ) Operating Frequency............. 1026
20.10.8 Notes on Deep Software Standby Mode when USB is Used.......................... 1026
Section 21 I2C Bus Interface 2 (IIC2).............................................................. 1027
21.1
21.2
21.3
Features........................................................................................................................... 1027
Input/Output Pins............................................................................................................ 1029
Register Descriptions...................................................................................................... 1030
21.3.1
I2C Bus Control Register A (ICCRA) ............................................................. 1031
21.3.2
I2C Bus Control Register B (ICCRB) ............................................................. 1032
21.3.3
I2C Bus Mode Register (ICMR)...................................................................... 1034
21.3.4
I2C Bus Interrupt Enable Register (ICIER)..................................................... 1035
Rev. 2.00 Oct. 21, 2009 Page xxvi of xxxii
21.4
21.5
21.6
21.7
21.3.5
I2C Bus Status Register (ICSR)....................................................................... 1038
21.3.6
Slave Address Register (SAR)........................................................................ 1041
21.3.7
I2C Bus Transmit Data Register (ICDRT)....................................................... 1042
21.3.8
I2C Bus Receive Data Register (ICDRR)........................................................ 1042
21.3.9
I2C Bus Shift Register (ICDRS)...................................................................... 1042
Operation ........................................................................................................................ 1043
21.4.1
I2C Bus Format................................................................................................ 1043
21.4.2
Master Transmit Operation ............................................................................. 1044
21.4.3
Master Receive Operation............................................................................... 1046
21.4.4
Slave Transmit Operation ............................................................................... 1048
21.4.5
Slave Receive Operation................................................................................. 1051
21.4.6
Noise Canceler................................................................................................ 1052
21.4.7
Example of Use............................................................................................... 1053
Interrupt Request............................................................................................................. 1057
Bit Synchronous Circuit.................................................................................................. 1058
Usage Notes .................................................................................................................... 1059
Section 22 A/D Converter................................................................................1061
22.1
22.2
22.3
22.4
22.5
22.6
22.7
Features........................................................................................................................... 1061
Input/Output Pins............................................................................................................ 1064
Register Descriptions...................................................................................................... 1065
22.3.1
A/D Data Registers A to H (ADDRA to ADDRH) ........................................ 1066
22.3.2
A/D Control/Status Register_0 (ADCSR_0) for Unit 0.................................. 1067
22.3.3
A/D Control/Status Register 1 (ADCSR_1) for Unit 1................................... 1070
22.3.4
A/D Control Register_0 (ADCR_0) for Unit 0............................................... 1072
22.3.5
A/D Control Register_1 (ADCR_1) for Unit 1............................................... 1074
22.3.6
A/D Mode Selection Register_0 (ADMOSEL_0) for Unit 0.......................... 1076
22.3.7
A/D Mode Selection Register_1 (ADMOSEL_1) for Unit 1.......................... 1077
22.3.8
A/D Sampling State Register_0 (ADSSTR_0) for Unit 0............................... 1078
22.3.9
A/D Sampling State Register_1 (ADSSTR_1) for Unit 1............................... 1079
Operation ........................................................................................................................ 1080
22.4.1
Single Mode.................................................................................................... 1080
22.4.2
Scan Mode ...................................................................................................... 1081
22.4.3
Input Sampling and A/D Conversion Time .................................................... 1085
22.4.4
Timing of External Trigger Input.................................................................... 1090
22.4.5
Setting the System Clock Mode...................................................................... 1091
Interrupt Source .............................................................................................................. 1092
A/D Conversion Accuracy Definitions ........................................................................... 1093
Usage Notes .................................................................................................................... 1095
22.7.1
Module Stop Function Setting ........................................................................ 1095
Rev. 2.00 Oct. 21, 2009 Page xxvii of xxxii
22.7.2
22.7.3
22.7.4
22.7.5
22.7.6
22.7.7
22.7.8
22.7.9
A/D Input Hold Function in Software Standby Mode .................................... 1095
Notes on Stopping the A/D Converter ............................................................ 1095
Notes in System Clock Mode ......................................................................... 1097
Permissible Signal Source Impedance ............................................................ 1098
Influences on Absolute Accuracy ................................................................... 1099
Setting Range of Analog Power Supply and Other Pins................................. 1099
Notes on Board Design ................................................................................... 1099
Notes on Noise Countermeasures ................................................................... 1100
Section 23 D/A Converter ............................................................................... 1103
23.1
23.2
23.3
23.4
23.5
Features........................................................................................................................... 1103
Input/Output Pins............................................................................................................ 1104
Register Descriptions...................................................................................................... 1104
23.3.1
D/A Data Registers 0 and 1 (DADR0, DADR1) ............................................ 1105
23.3.2
D/A Data Registers 0H and 1H (DADR0H and DADR1H) ........................... 1105
23.3.3
D/A Data Registers 0L and 1L (DADR0L and DADR1L)............................. 1106
23.3.4
D/A Data Register 01T (DADR01T) .............................................................. 1106
23.3.5
D/A Control Register 01 (DACR01) .............................................................. 1107
23.3.6
Usage as an 8-Bit D/A Converter ................................................................... 1108
Operation ........................................................................................................................ 1109
Usage Notes .................................................................................................................... 1111
23.5.1
Module Stop State Setting .............................................................................. 1111
23.5.2
D/A Output Hold Function in Software Standby Mode.................................. 1111
23.5.3
Notes on Deep Software Standby Mode ......................................................... 1111
23.5.4
Limitations on Emulators................................................................................ 1111
Section 24 RAM .............................................................................................. 1113
Section 25 Flash Memory................................................................................ 1115
25.1
25.2
25.3
25.4
25.5
25.6
25.7
Features........................................................................................................................... 1115
Mode Transition Diagram............................................................................................... 1117
Memory MAT Configuration ......................................................................................... 1119
Block Structure ............................................................................................................... 1120
25.4.1
Block Diagram of H8SX/1662........................................................................ 1120
25.4.2
Block Diagram of H8SX/1665........................................................................ 1121
Programming/Erasing Interface ...................................................................................... 1122
Input/Output Pins............................................................................................................ 1124
Register Descriptions...................................................................................................... 1125
25.7.1
Programming/Erasing Interface Registers ...................................................... 1127
25.7.2
Programming/Erasing Interface Parameters ................................................... 1134
Rev. 2.00 Oct. 21, 2009 Page xxviii of xxxii
25.8
25.9
25.10
25.11
25.12
25.13
25.14
25.7.3
RAM Emulation Register (RAMER).............................................................. 1146
On-Board Programming Mode ....................................................................................... 1147
25.8.1
Boot Mode ...................................................................................................... 1148
25.8.2
USB Boot Mode.............................................................................................. 1152
25.8.3
User Program Mode........................................................................................ 1156
25.8.4
User Boot Mode.............................................................................................. 1166
25.8.5
On-Chip Program and Storable Area for Program Data ................................. 1170
Protection........................................................................................................................ 1176
25.9.1
Hardware Protection ....................................................................................... 1176
25.9.2
Software Protection......................................................................................... 1177
25.9.3
Error Protection............................................................................................... 1177
Flash Memory Emulation Using RAM........................................................................... 1179
Switching between User MAT and User Boot MAT...................................................... 1182
Programmer Mode .......................................................................................................... 1183
Standard Serial Communications Interface Specifications for Boot Mode..................... 1183
Usage Notes .................................................................................................................... 1212
Section 26 Boundary Scan ...............................................................................1215
26.1
26.2
26.3
26.4
26.5
26.6
Features........................................................................................................................... 1215
Block Diagram of Boundary Scan Function ................................................................... 1216
Input/Output Pins............................................................................................................ 1216
Register Descriptions...................................................................................................... 1217
26.4.1
Instruction Register (JTIR) ............................................................................. 1218
26.4.2
Bypass Register (JTBPR) ............................................................................... 1219
26.4.3
Boundary Scan Register (JTBSR)................................................................... 1219
26.4.4
IDCODE Register (JTID) ............................................................................... 1225
Operations....................................................................................................................... 1226
26.5.1
TAP Controller ............................................................................................... 1226
26.5.2
Commands ...................................................................................................... 1227
Usage Notes .................................................................................................................... 1229
Section 27 Clock Pulse Generator ...................................................................1231
27.1
27.2
27.3
27.4
Register Description ....................................................................................................... 1233
27.1.1
System Clock Control Register (SCKCR) ...................................................... 1233
27.1.2
Subclock Control Register (SUBCKCR) ........................................................ 1235
Oscillator......................................................................................................................... 1237
27.2.1
Connecting Crystal Resonator ........................................................................ 1237
27.2.2
External Clock Input ....................................................................................... 1238
PLL Circuit ..................................................................................................................... 1239
Frequency Divider .......................................................................................................... 1239
Rev. 2.00 Oct. 21, 2009 Page xxix of xxxii
27.5
27.6
Subclock Oscillator......................................................................................................... 1239
27.5.1
Connecting 32.768 kHz Crystal Resonator..................................................... 1239
27.5.2
Handling of Pins when the Subclock is Not to be Used.................................. 1240
Usage Notes .................................................................................................................... 1241
27.6.1
Notes on Clock Pulse Generator ..................................................................... 1241
27.6.2
Notes on Resonator......................................................................................... 1242
27.6.3
Notes on Board Design ................................................................................... 1242
Section 28 Power-Down Modes...................................................................... 1245
28.1
28.2
28.3
28.4
28.5
28.6
28.7
28.8
Features........................................................................................................................... 1245
Register Descriptions...................................................................................................... 1249
28.2.1
Standby Control Register (SBYCR) ............................................................... 1250
28.2.2
Module Stop Control Registers A and B (MSTPCRA and MSTPCRB) ........ 1252
28.2.3
Module Stop Control Register C (MSTPCRC)............................................... 1255
28.2.4
Deep Standby Control Register (DPSBYCR)................................................. 1256
28.2.5
Deep Standby Wait Control Register (DPSWCR).......................................... 1258
28.2.6
Deep Standby Interrupt Enable Register (DPSIER) ....................................... 1260
28.2.7
Deep Standby Interrupt Flag Register (DPSIFR)............................................ 1262
28.2.8
Deep Standby Interrupt Edge Register (DPSIEGR) ....................................... 1264
28.2.9
Reset Status Register (RSTSR)....................................................................... 1265
28.2.10 Deep Standby Backup Register (DPSBKRn) ................................................. 1267
Multi-Clock Function ..................................................................................................... 1268
28.3.1
Switching of Main Clock Frequencies............................................................ 1268
28.3.2
Switching to Subclock .................................................................................... 1268
Module Stop State........................................................................................................... 1269
Sleep Mode ..................................................................................................................... 1270
28.5.1
Entry to Sleep Mode ....................................................................................... 1270
28.5.2
Exit from Sleep Mode..................................................................................... 1270
All-Module-Clock-Stop Mode........................................................................................ 1271
Software Standby Mode.................................................................................................. 1272
28.7.1
Entry to Software Standby Mode.................................................................... 1272
28.7.2
Exit from Software Standby Mode ................................................................. 1272
28.7.3 Setting Oscillation Settling Time after Exit from Software Standby
Mode ............................................................................................................... 1274
28.7.4
Software Standby Mode Application Example............................................... 1275
Deep Software Standby Mode ........................................................................................ 1276
28.8.1
Entry to Deep Software Standby Mode .......................................................... 1276
28.8.2
Exit from Deep Software Standby Mode........................................................ 1277
28.8.3
Pin State on Exit from Deep Software Standby Mode.................................... 1278
28.8.4
Bφ/SDRAMφ Operation after Exit from Deep Software Standby Mode........ 1279
Rev. 2.00 Oct. 21, 2009 Page xxx of xxxii
28.8.5
Setting Oscillation Settling Time after Exit from Deep Software Standby
Mode ............................................................................................................... 1280
28.8.6
Deep Software Standby Mode Application Example ..................................... 1281
28.8.7
Flowchart of Deep Software Standby Mode Operation .................................. 1285
28.9 Hardware Standby Mode ................................................................................................ 1287
28.9.1
Transition to Hardware Standby Mode ........................................................... 1287
28.9.2
Clearing Hardware Standby Mode.................................................................. 1287
28.9.3
Hardware Standby Mode Timing.................................................................... 1287
28.9.4
Timing Sequence at Power-On ....................................................................... 1288
28.10 Sleep Instruction Exception Handling ............................................................................ 1289
28.11 φ Clock Output Control................................................................................................... 1292
28.12 Usage Notes .................................................................................................................... 1293
28.12.1 I/O Port Status................................................................................................. 1293
28.12.2 Current Consumption during Oscillation Settling Standby Period ................. 1293
28.12.3 Module Stop State of EXDMAC, DMAC, or DTC ........................................ 1293
28.12.4 On-Chip Peripheral Module Interrupts ........................................................... 1293
28.12.5 Writing to MSTPCRA, MSTPCRB, and MSTPCRC ..................................... 1293
28.12.6 Control of Input Buffers by DIRQnE (n = 3 to 0)........................................... 1294
28.12.7 Conflict between a transition to deep standby mode and interrupts................ 1294
28.12.8 Bφ/SDRAMφ Output State ............................................................................. 1294
Section 29 List of Registers .............................................................................1295
29.1
29.2
29.3
Register Addresses (Address Order)............................................................................... 1296
Register Bits.................................................................................................................... 1315
Register States in Each Operating Mode ........................................................................ 1347
Section 30 Electrical Characteristics ...............................................................1367
30.1
30.2
30.3
30.4
30.5
30.6
30.7
30.8
Absolute Maximum Ratings ........................................................................................... 1367
DC Characteristics (H8SX/1665 Group) ........................................................................ 1368
DC Characteristics (H8SX/1665M Group)..................................................................... 1371
AC Characteristics .......................................................................................................... 1374
30.4.1
Clock Timing .................................................................................................. 1374
30.4.2
Control Signal Timing .................................................................................... 1378
30.4.3
Bus Timing ..................................................................................................... 1379
30.4.4
DMAC and EXDMAC Timing....................................................................... 1410
30.4.5
Timing of On-Chip Peripheral Modules ......................................................... 1414
USB Characteristics ........................................................................................................ 1421
A/D Conversion Characteristics ..................................................................................... 1423
D/A Conversion Characteristics ..................................................................................... 1425
Flash Memory Characteristics ........................................................................................ 1426
Rev. 2.00 Oct. 21, 2009 Page xxxi of xxxii
30.9
Power-On Reset Circuit and Voltage-Detection Circuit Characteristics
(H8SX/1665M Group).................................................................................................... 1427
Appendix ........................................................................................................... 1429
A.
B.
C.
D.
Port States in Each Pin State........................................................................................... 1429
Product Lineup................................................................................................................ 1435
Package Dimensions ....................................................................................................... 1436
Treatment of Unused Pins............................................................................................... 1438
Main Revisions and Additions in this Edition................................................... 1441
Index ................................................................................................................. 1447
Rev. 2.00 Oct. 21, 2009 Page xxxii of xxxii
Section 1 Overview
Section 1 Overview
1.1
Features
The core of each product in the H8SX/1665 Group and the H8SX/1665M Group of CISC
(complex instruction set computer) microcontrollers is an H8SX CPU, which has an internal 32bit architecture. The H8SX CPU provides upward-compatibility with the CPUs of other Renesas
Technology-original microcontrollers; H8/300, H8/300H, and H8S.
As peripheral functions, each LSI of the Group includes a DMA controller and an EXDMA
controller which enable high-speed data transfer, and a bus-state controller, which enables direct
connection to different kinds of memory. The LSI of the Group also includes serial
communications interfaces, A/D and D/A converters, and a multi-function timer that makes motor
control easy. Together, the modules realize low-cost configurations for end systems. The power
consumption of these modules is kept down dynamically by an on-chip power-management
function. The on-chip ROM is a flash memory (F-ZTATTM*) with a capacity of 512 Kbytes
(H8SX/1665 and H8SX/1665M), or 384 Kbytes (H8SX/1662 and H8SX/1662M).
Note: * F-ZTATTM is a trademark of Renesas Technology Corp.
1.1.1
Applications
Examples of the applications of this LSI include PC peripheral equipment, optical storage devices,
office automation equipment, and industrial equipment.
Rev. 2.00 Oct. 21, 2009 Page 1 of 1454
REJ09B0498-0200
Section 1 Overview
1.1.2
Overview of Functions
Table 1.1 lists the functions of this LSI in outline. Table 1.2 shows the comparison of support
functions in each group.
Table 1.1
Overview of Functions
Classification
Module/
Function
Description
Memory
ROM
•
ROM capacity: 512 Kbytes or 384 Kbytes
RAM
•
RAM capacity: 40 Kbytes
CPU
•
32-bit high-speed H8SX CPU (CISC type)
CPU
Upwardly compatible for H8/300, H8/300H, and H8S CPUs at
object level
•
General-register architecture (sixteen 16-bit general registers)
•
Eleven addressing modes
•
4-Gbyte address space
Program: 4 Gbytes available
Data: 4 Gbytes available
Operating
mode
•
87 basic instructions, classifiable as bit arithmetic and logic
instructions, multiply and divide instructions, bit manipulation
instructions, multiply-and-accumulate instructions, and others
•
Minimum instruction execution time: 20.0 ns (for an ADD
instruction while system clock Iφ = 50 MHz and
VCC = 3.0 to 3.6 V)
•
On-chip multiplier (16 × 16 → 32 bits)
•
Supports multiply-and-accumulate instructions
(16 × 16 + 42 → 42 bits)
•
Advanced mode
Normal, middle, or maximum mode is not supported.
Rev. 2.00 Oct. 21, 2009 Page 2 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
CPU
Module/
Function
Description
MCU
operating
mode
Mode 1: User boot mode
(selected by driving the MD2 and MD1 pins low and
driving the MD0 pin high)
Mode 2: Boot mode
(selected by driving the MD2 and MD0 pins low and
driving the MD1 pin high)
Mode 3: Boundary scan enabled single chip mode
(selected by driving the MD2 pin low and driving the MD1
and MD0 pins high)
Mode 4: On-chip ROM disabled external extended mode, 16-bit
bus (selected by driving the MD1 and MD0 pins low and
driving the MD2 pin high)
Mode 5: On-chip ROM disabled external extended mode, 8-bit bus
(selected by driving the MD1 pin low and driving the MD2
and MD0 pins high)
Mode 6: On-chip ROM enabled external extended mode
(selected by driving the MD0 pin low and driving the MD2
and MD1 pins high)
Mode 7: Single-chip mode (can be externally extended)
(selected by driving the MD2, MD1, and MD0 pins high)
•
Low power consumption state (transition driven by the SLEEP
instruction)
Power on reset (POR) *
•
At power-on or low power supply voltage, an internal reset
signal is generated
Voltage detection circuit
(LVD)*
•
At low power supply voltage, an internal reset and an interrupt
are generated.
Interrupt
(source)
•
13 external interrupt pins (NMI, and IRQ11 to IRQ0)
•
Internal interrupt sources
Interrupt
controller
(INTC)
H8SX/1665 Group: 122 pins
H8SX/1665M Group: 123 pins
•
Two interrupt control modes (specified by the interrupt control
register)
•
Eight priority orders specifiable (by setting the interrupt priority
register)
•
Independent vector addresses
Rev. 2.00 Oct. 21, 2009 Page 3 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
Module/
Function
Description
•
Break point can be set for four channels
•
Address break can be set for CPU instruction fetch cycles
Interrupt
(source)
Break
interrupt
(UBC)
DMA
EXDMA
•
controller
•
(EXDMAC)
•
DMA
controller
(DMAC)
Data
transfer
controller
(DTC)
External bus
extension
Bus
controller
(BSC)
Four-channel DMA transfer available
Two activation methods (auto-request and external request)
Four transfer modes (normal, repeat, block, and cluster
transfer)
•
Dual or single address mode selectable
•
Extended repeat area function
•
Four-channel DMA transfer available
•
Three activation methods (auto-request, on-chip module
interrupt, and external request)
•
Three transfer modes (normal, repeat, and block)
•
Dual or single address mode selectable
•
Extended repeat area function
•
Allows DMA transfer over 78 channels (number of DTC
activation sources)
•
Activated by interrupt sources (chain transfer enabled)
•
Three transfer modes (normal transfer, repeat transfer, block
transfer)
•
Short-address mode or full-address mode selectable
•
16-Mbyte external address space
•
The external address space can be divided into eight areas,
each of which is independently controllable
⎯ Chip-select signals (CS0 to CS7) can be output
⎯ Access in two or three states can be selected for each area
⎯ Program wait cycles can be inserted
⎯ The period of CS assertion can be extended
⎯ Idle cycles can be inserted
•
Bus arbitration function (arbitrates bus mastership among the
internal CPU, DMAC, EXDMAC, DTC, Refresh, and external
bus masters)
Rev. 2.00 Oct. 21, 2009 Page 4 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
External bus
extension
Clock
Module/
Function
Bus
controller
(BSC)
Description
Bus formats
•
External memory interfaces (for the connection of ROM, burst
ROM, SRAM, byte control SRAM, DRAM, and synchronous
DRAM)
•
Address/data bus format: Support for both separate and
multiplexed buses (8-bit access or 16-bit access)
•
Endian conversion function for connecting devices in littleendian format
Clock pulse •
generator
•
(CPG)
One clock generation circuit available
Separate clock signals are provided for each of functional
modules (detailed below) and each is independently specifiable
(multi-clock function)
⎯ System-intended data transfer modules, i.e. the CPU, runs
in synchronization with the system clock (Iφ): 8 to 50 MHz
⎯ Internal peripheral functions run in synchronization with the
peripheral module clock (Pφ): 8 to 35 MHz
⎯ Modules in the external space are supplied with the external
bus clock (Bφ): 8 to 50 MHz
•
Includes a PLL frequency multiplication circuit and frequency
divider, so the operating frequency is selectable
•
Five low-power-consumption modes: Sleep mode, all-moduleclock-stop mode, software standby mode, deep software
standby mode, and hardware standby mode
Rev. 2.00 Oct. 21, 2009 Page 5 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
A/D converter
Module/
Function
A/D
converter
(ADC)
Description
•
10-bit resolution × two units
•
Selectable input channel and unit configuration
Four channels × two units (units 0 and 1)
Eight channels × one unit (unit 0)
•
Sample and hold function included
•
Conversion time: 1.0 μs per channel (with peripheral module
clock (Pφ) at 25-MHz operation)
•
Two operating modes: single mode and scan mode
•
Three ways to start A/D conversion:
Unit 0: Software, timer (TPU (unit 0)/TMR (units 0 and 1))
trigger, and external trigger
Unit 1: Software, TMR (units 2 and 3) trigger, and external
trigger
•
Activation of DTC and DMAC by ADI interrupt:
Unit 0: DTC and DMAC can be activated by an ADI0 interrupt.
Unit 1: DMAC can be activated by an ADI1 interrupt.
D/A converter
D/A
converter
(DAC)
•
•
10-bit resolution × two output channels
Output voltage: 0 V to Vref, maximum conversion time: 10 μs
(with 20-pF load)
Timer
8-bit timer
(TMR)
•
•
8 bits × eight channels (can be used as 16 bits × four channels)
Select from among seven clock sources (six internal clocks and
one external clock)
Allows the output of pulse trains with a desired duty cycle or
PWM signals
•
Rev. 2.00 Oct. 21, 2009 Page 6 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
Timer
Module/
Function
Description
16-bit timer •
pulse unit
•
(TPU)
•
•
16 bits × 12 channels (unit0, unit1*)
Select from among eight counter-input clocks for each channel
Up to 16 pulse inputs and outputs
Counter clear operation, simultaneous writing to multiple timer
counters (TCNT), simultaneous clearing by compare match and
input capture possible, simultaneous input/output for registers
possible by counter synchronous operation, and up to 15-phase
PWM output possible by combination with synchronous
operation
• Buffered operation, cascaded operation (32 bits × two
channels), and phase counting mode (two-phase encoder
input) settable for each channel
• Input capture function supported
• Output compare function (by the output of compare match
waveform) supported
Note: * Pin function of unit 1 cannot be used in the external bus
extended mode.
•
Programmable pulse •
generator
(PPG)
•
1
2
32-bit* * pulse output
Four output groups, non-overlapping mode, and inverted output
can be set
Selectable output trigger signals; the PPG can operate in
conjunction with the data transfer controller (DTC) and the DMA
controller (DMAC)
Notes: 1. Pulse output pins PO31 to PO16 cannot be activated by
input capture.
2. Pulse of unit 1 cannot be output in external bus
extended mode.
Watchdog timer Watchdog •
timer (WDT)
•
32K timer
32K timer
(TM32K)
•
•
•
•
8 bits × one channels (selectable from eight counter input
clocks)
Switchable between watchdog timer mode and interval timer
mode
Eight counter clocks which divides the 32.768 kHz clock can be
selected
8 bits × 1 channel or 24 bits × 1 channel can be selected
Interrupts can be generated when the counter overflows.
Eight overflow cycles selectable (250 msec, 500 msec, 1 sec, 2
sec, 30 sec, 60 sec, about 23 days, and about 46 days)
Rev. 2.00 Oct. 21, 2009 Page 7 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
Serial interface
Module/
Function
Serial
communications
interface
(SCI)
Description
•
•
•
•
•
•
Smart card/SIM
•
Universal serial Universal
bus interface
serial bus
interface
(USB)
•
I2C bus interface I2C bus
interface 2
(IIC2)
•
•
•
•
•
Six channels (select asynchronous or clock synchronous serial
communications mode)
Full-duplex communications capability
Select the desired bit rate and LSB-first or MSB-first transfer
Input average transfer rate clock from TMR (SCI_5, SCI_6)
IrDA transmission and reception conformant with the IrDA
Specifications version 1.0
On-chip cyclic redundancy check (CRC) calculator for improved
reliability in data transfer
The SCI module supports a smart card (SIM) interface.
On-chip UDC (USB Device Controller) supporting USB 2.0 and
transceiver
Transfer speed: full-speed (12 Mbps)
Bulk transfer by DMA
Self-power mode and bus power mode selectable
Two channels
Bus can be directly driven (the SCL and SDA pins are NMOS
open drains).
I/O ports
•
•
•
•
•
Emulator
Full-spec emulator (E6000H)*
9 CMOS input-only pins
92 CMOS input/output pins
8 large-current drive pins (port 3)
40 pull-up resistors
16 open drains
On-chip emulator (E10A-USB)
Note:
Package
•
•
LQFP-144 package
LGA-145 package
Rev. 2.00 Oct. 21, 2009 Page 8 of 1454
REJ09B0498-0200
* E6000H of the H8SX/1668 Group can be used excluding
a part of function of A/D and D/A though the H8SX/1665
Group is not supporting E6000H. For details on functions
for which E6000H cannot be used, see section 22, A/D
Converter and section 23, D/A Converter.
Section 1 Overview
Classification
Module/
Function
Operating frequency/
Power supply voltage
Description
•
•
•
Operating peripheral
temperature (°C)
Note:
*
Table 1.2
Operating frequency: 8 to 50 MHz
Power supply voltage: Vcc = PLLVcc = DrVcc = 3.0 to 3.6 V,
AVcc = 3.0 to 3.6 V
Flash programming/erasure voltage: 3.0 to 3.6 V
•
Supply current: 50 mA typ (Vcc = PLLVcc = DrVcc = 3.0 V,
AVcc = 3.0 V, Iφ = Bφ = 50 MHz, Pφ = 25 MHz)
•
•
−20 to +75°C (regular specifications)
−40 to +85°C (wide-range specifications)
Supported only by the H8SX/1665M Group.
Comparison of Support Functions in the H8SX/1665 and H8SX/1665M Groups
Function
H8SX/1665 Group
H8SX/1665M Group
DMAC
O
O
DTC
O
O
PPG
O
O
UBC
O
O
SCI
O
O
IIC2
O
O
TMR
O
O
WDT
O
O
10-bit ADC
O
O
10-bit DAC
O
O
EXDMAC
O
O
SDRAM interface
O
O
32K timer
O
O
POR/LVD
⎯
O
LQFP-144
O
O
LGA-145
O
O
Package
Rev. 2.00 Oct. 21, 2009 Page 9 of 1454
REJ09B0498-0200
Section 1 Overview
1.2
List of Products
Table 1.3 is the list of products, and figure 1.1 shows how to read the product name code.
Table 1.3
List of Products
Group
Part No.
ROM
Capacity
RAM
Capacity
Package
Remarks
H8SX/1665
R5F61665N50FPV
512 Kbytes
40 Kbytes
LQFP-144
R5F61662N50FPV
384 Kbytes
40 Kbytes
LQFP-144
Regular
specifications
R5F61665N50LGV
512 Kbytes
40 Kbytes
LGA-145
R5F61662N50LGV
384 Kbytes
40 Kbytes
LGA-145
R5F61665D50FPV
512 Kbytes
40 Kbytes
LQFP-144
R5F61662D50FPV
384 Kbytes
40 Kbytes
LQFP-144
R5F61665D50LGV
512 Kbytes
40 Kbytes
LGA-145
R5F61662D50LGV
384 Kbytes
40 Kbytes
LGA-145
H8SX/1665M R5F61665MN50FPV 512 Kbytes
40 Kbytes
LQFP-144
R5F61662MN50FPV 384 Kbytes
40 Kbytes
LQFP-144
R5F61665MN50LGV 512 Kbytes
40 Kbytes
LGA-145
R5F61662MN50LGV 384 Kbytes
40 Kbytes
LGA-145
R5F61665MD50FPV 512 Kbytes
40 Kbytes
LQFP-144
R5F61662MD50FPV 384 Kbytes
40 Kbytes
LQFP-144
R5F61665MD50LGV 512 Kbytes
40 Kbytes
LGA-145
R5F61662MD50LGV 384 Kbytes
40 Kbytes
LGA-145
Rev. 2.00 Oct. 21, 2009 Page 10 of 1454
REJ09B0498-0200
Wide range
specifications
Regular
specifications
Wide range
specifications
Section 1 Overview
Part No.
R
5
F
61665N50
FP V
Indicates the Pb-free version.
Indicates the package.
FP: LQFP
LG: LGA
Indicates the product-specific number.
N: Regular specifications
D: Wide-range specifications
Indicates the type of ROM device.
F: On-chip flash memory
Product classification
Microcontroller
Indicates a Renesas semiconductor product.
Figure 1.1 How to Read the Product Name Code
• Small Package
Package
Package Code
LQFP-144
PLQP0144KA-A (FP-144LV)* 20.0 × 20.0 mm
0.50 mm
LGA-145
PTLG0145JB-A (TLP-145V)* 9.0 × 9.0 mm
0.65 mm
Note:
*
Body Size
Pin Pitch
Pb-free version
Rev. 2.00 Oct. 21, 2009 Page 11 of 1454
REJ09B0498-0200
Section 1 Overview
1.3
Block Diagram
TM32K
Port 1
WDT
Port 2
TMR × 2 channels
(unit 0)
Interrupt
controller
BSC
Internal system bus
ROM
H8SX
CPU
Internal peripheral bus
RAM
TMR × 2 channels
(unit 1)
Port 3
TMR × 2 channels
(unit 2)
Port 5
TMR × 2 channels
(unit 3)
Port 6
TPU × 6 channels
(unit 0)
Port A
TPU × 6 channels
(unit 1)
PPG × 16 channels
(unit 0)
PPG × 16 channels
(unit 1)
DMAC ×
4 channels
DTC
SCI × 6 channels
Port B
Port C
Port D/
port J*1
USB
IIC2 × 2 channels
10-bit AD × 4
channels (unit 0)
Internal system bus
Main clock
oscillator
EXDMAC ×
4 channels
Subclock
oscillator
POR/LVD*2
10-bit AD × 4
channels (unit 1)
10-bit DA ×
2 channels
Central processing unit
Data transfer controller
Bus controller
DMA controller
EXDMA controller
32K timer
Watchdog timer
TMR:
TPU:
PPG:
SCI:
USB:
IIC2:
POR/LVD*2:
Port F
Port H
Port I
Port M
External bus
[Legend]
CPU:
DTC:
BSC:
DMAC:
EXDMAC:
TM32K:
WDT:
Port E/
port K*1
8-bit timer
16-bit timer pulse unit
Programmable pulse generator
Serial communications interface
Universal serial bus interface
IIC bus interface 2
Power-on reset / Low voltage detection circuit
Notes: 1. In single-chip mode, the port D and port E functions can be used in the initial state.
Pin functions are selectable by setting the PCJKE bit in PFCRD. Ports D and E are enabled
when PCJKE = 0 (initial value) and ports J and K are enabled when PCJKE = 1. In external
extended mode, only ports D and E can be used.
2. Supported only by the H8SX/1665M Gruop.
Figure 1.2 Block Diagram
Rev. 2.00 Oct. 21, 2009 Page 12 of 1454
REJ09B0498-0200
PH7/D7
Vcc
PI0/D8
PI1/D9
PI2/D10
PI3/D11
Vss
PI4/D12
PI5/D13
PI6/D14
PI7/D15
P10/TxD2/DREQ0-A/IRQ0-A/EDREQ0-A
P11/RxD2/TEND0-A/IRQ1-A/ETEND0-A
P12/SCK2/DACK0-A/IRQ2-A/EDACK0-A
P13/ADTRG0-A/IRQ3-A/EDRAK0
Vss
OSC2
OSC1
RES
VCL
P14/TCLKA-B/TxD5/IrTxD/SDA1/DREQ1-A/IRQ4-A/EDREQ1-A
P15/TCLKB-B/RxD5/IrRxD/SCL1/TEND1-A/IRQ5-A/ETEND1-A
WDTOVF/TDO
Vss
XTAL
EXTAL
Vcc
P16/TCLKC-B/SDA0/DACK1-A/IRQ6-A/EDACK1-A
P17/TCLKD-B/SCL0/ADTRG1/IRQ7-A/EDRAK1
STBY
P35/PO13/TIOCA1/TIOCB1/TCLKC-A/DACK1-B/EDACK3
P36/PO14/TIOCA2/EDRAK2
Pin Assignments
P37/PO15/TIOCA2/TIOCB2/TCLKD-A/EDRAK3
1.4.1
P60/TMRI2/TxD4/DREQ2/IRQ8-B/EDREQ0-B
Pin Assignments
P61/TMCI2/RxD4/TEND2/IRQ9-B/ETEND0-B
1.4
Vss
Section 1 Overview
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
109
72
PH6/D6
PLLVcc
110
71
PH5/D5
P63/TMRI3/DREQ3/IRQ11-B/TMS/EDREQ1-B
111
70
PH4/D4
PLLVss
112
69
Vss
P64/TMCI3/TEND3/TDI/ETEND1-B
113
68
PH3/D3
P65/TMO3/DACK3/TCK/EDACK1-B
114
67
PH2/D2
MD0
115
66
PH1/D1
PC2/LUCAS/DQMLU
116
65
PH0/D0
PC3/LLCAS/DQMLL
117
64
Vcc
P50/AN0/IRQ0-B
118
63
P34/PO12/TIOCA1/TEND1-B/ETEND3
P51/AN1/IRQ1-B
119
62
P33/PO11/TIOCC0/TIOCD0/TCLKB-A/DREQ1-B/EDREQ3
P52/AN2/IRQ2-B
P62/TMO2/SCK4/DACK2/IRQ10-B/TRST/EDACK0-B
120
61
NMI
AVcc
121
60
P27/PO7/TIOCA5/TIOCB5
P53/AN3/IRQ3-B
122
59
P26/PO6/TIOCA5/TMO1/TxD1
AVss
123
58
P32/PO10/TIOCC0/TCLKA-A/DACK0-B/EDACK2
P54/AN4/IRQ4-B
124
57
P31/PO9/TIOCA0/TIOCB0/TEND0-B/ETEND2
Vref
125
56
P30/PO8/TIOCA0/DREQ0-B/EDREQ2
P55/AN5/IRQ5-B
126
55
P25/PO5/TIOCA4/TMCI1/RxD1
P56/AN6/DA0/IRQ6-B
127
54
P24/PO4/TIOCA4/TIOCB4/TMRI1/SCK1
P57/AN7/DA1/IRQ7-B
128
53
P23/PO3/TIOCC3/TIOCD3/IRQ11-A
MD1
129
52
P22/PO2/TIOCC3/TMO0/TxD0/IRQ10-A
PB4/CS4-B/WE
130
51
P21/PO1/TIOCA3/TMCI0/RxD0/IRQ9-A
PB5/CS5-D/OE/CKE
131
50
Vcc
PB6/CS6-D/(RD/WR-B)/ADTRG0-B
132
49
P20/PO0/TIOCA3/TIOCB3/TMRI0/SCK0/IRQ8-A
MD3
133
48
Vss
PA0/BREQO/BS-A
134
47
PA1/BACK/(RD/WR-A)
135
46
VBUS
PA2/BREQ/WAIT
136
45
DrVss
LQFP-144
(Top View)
MD_CLK
PA3/LLWR/LLB
137
44
PA4/LHWR/LUB
138
43
USD+
PA5/RD
139
42
DrVcc
PA6/AS/AH/BS-B
140
41
USD-
PM4
PB0/CS0/CS4-A/CS5-B
144
1
PD1/A1
Notes:
2.
PD3/A3
PD2/A2
PJ3/PO19/TIOCC6/TIOCD6/TCLKF
PJ2/PO18/TIOCC6/TCLKE
PD6/A6
PJ6/PO22/TIOCA8
PD4/A4
PD7/A7
PJ7/PO23/TIOCA8/TIOCB8/TCLKH
PJ4/PO20/TIOCA7
PE0/A8
PK0/PO24/TIOCA9
PD5/A5
PE1/A9
PK1/PO25/TIOCA9/TIOCB9
PJ5/PO21/TIOCA7/TIOCB7/TCLKG
PE2/A10
PK2/PO26/TIOCC9
Vss
PE3/A11
PK3/PO27/TIOCC9/TIOCD9
Vcc
PE4/A12
Vss
PE5/A13
PJ0/PO16/TIOCA6
PJ1/PO17/TIOCA6/TIOCB6
*1
PK4/PO28/TIOCA10
PK5/PO29/TIOCA10/TIOCB10
PK6/PO30/TIOCA11
*1
PK7/PO31/TIOCA11/TIOCB11
1.
PE6/A14
PE7/A15
PF0/A16
PF1/A17
PF2/A18
37
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
Vss
8
PF3/A19
7
PF4/A20
6
PF5/A21
5
PF6/A22
4
PF7/A23
3
PM2
2
PM1/RxD6
PD0/A0
PM0/TxD6
38
MD2
143
Vcc
Vcc
PB7/SDRAMφ
EMLE *2
Vss
PM3
39
PB3/CS3/CS7-A/CAS
40
142
PB2/CS2-A/CS6-A/RAS
141
PB1/CS1/CS2-B/CS5-A/CS6-B/CS7-B
Vss
PA7/Bφ
In single-chip mode ports D and E can be used (initial state). Pin functions are selectable by
setting the PCJKE bit in PFCRD. Ports D and E are enabled when PCJKE = 0 (initial value)
and ports J and K are enabled when PCJKE = 1. In external extended mode, only ports D
and E can be used.
This pin is an on-chip emulator enable pin. Drive this pin low for the connection in normal
operating mode.
The on-chip emulator function is enabled by driving this pin high. When the on-chip emulator
is in use, the P62, P63, P64, P65, and WDTOVF pins are dedicated pins for the on-chip emulator.
For details on a connection example with the E10A, see E10A Emulator User's Manual.
Figure 1.3 Pin Assignments (LQFP-144: H8SX/1665 Group and H8SX/1665M Group)
Rev. 2.00 Oct. 21, 2009 Page 13 of 1454
REJ09B0498-0200
Section 1 Overview
1
2
3
4
5
6
7
8
9
10
11
A
PB1
PA7
Vcc
PA4
PA1
PB6
P57
Vref
P50
P65
B
PB2
PB0
Vss
PA2
MD3
MD1
P54
AVcc
P52
PC3
P64
C
PB3
PB7
Vss
PA6
PA5
PB5
PB4
AVss
P51
PC2
D
MD2
PM1
PM0
Vcc
PA3
PA0
P56
P55
P53
E
PM2
PF5
PF6
PF7
NC*3
F
PF4
PF2
Vss
PF3
G
PF1
12
13
PLLVss PLLVcc
P61
A
P62
P60
B
P63
P36
P37
C
MD0
P35
Vss
STBY
D
P17
P16
XTAL
EXTAL
E
Vcc
P15
Vss
WDTOVF
F
P14
P13
Vss
RES
G
LGA-145
PE7
PE6
/PK6*1 /PK7*1
Vss
PE5
PE4
PE3
/PK5*1 /PK4*1 /PK3*1
PF0
VcL
P11
OSC1
OSC2
H
PE1
/PK1*1
PD7
/PJ7*1
PE2
/PK2*1
PI7
P10
P12
PI6
J
K
PD5
PE0
/PK0*1 /PJ5*1
PD4
/PJ4*1
PD6
/PJ6*1
L
PD3
/PJ3*1
Vss
M
PD2
/PJ2*1
PD1
/PJ1*1
DrVcc
N
PD0
/PJ0*1
PM3
1
2
H
J
Vcc
Notes: 1.
(Upper perspective view)
Vcc
P21
P25
P26
P34
PH2
PI4
PI5
Vss
K
MD_CLK
P24
P32
P33
NMI
PH1
PI2
PI3
PI1
L
USD-
Vss
P20
P23
P31
PH0
Vss
PH4
PH7
PI0
M
PM4
USD+
DrVss
P22
P30
P27
Vcc
PH3
PH5
PH6
Vcc
N
3
4
5
6
7
8
9
10
11
12
13
EMLE*2 VBUS
In single-chip mode ports D and E can be used (initial state). Pin functions are selectable by setting the
PCJKE bit in PFCRD. Ports D and E are enabled when PCJKE = 0 (initial value) and ports J and K are
enabled when PCJKE = 1. In external extended mode, only ports D and E can be used.
2.
This pin is an on-chip emulator enable pin. Drive this pin low for the connection in normal operating mode.
The on-chip emulator function is enabled by driving this pin high. When the on-chip emulator is in use, the
P62, P63, P64, P65, and WDTOVF pins are dedicated pins for the on-chip emulator. For details on a connection
example with the E10A, see E10A Emulator User's Manual.
3.
The NC (no-connection) pin should be left open.
Figure 1.4 Pin Assignments (LGA-145: H8SX/1665 Group and H8SX/1665M Group)
Rev. 2.00 Oct. 21, 2009 Page 14 of 1454
REJ09B0498-0200
Section 1 Overview
1.4.2
Correspondence between Pin Configuration and Operating Modes
Table 1.4
Pin Configuration in Each Operating Mode (H8SX/1665 Group and
H8SX/1665M Group)
Pin No.
Pin Name
LQFP- LGA144
145
Modes 1, 2, and 6
Modes 3 and 7
Modes 4 and 5
1
A1
PB1/CS1/CS2-B/CS5-A/CS6-B/ PB1/CS1/CS2-B/CS5-A/CS6-B/
PB1/CS1/CS2-B/CS5-A/
CS7-B
CS7-B
CS6-B/CS7-B
2
B1
PB2/CS2-A/CS6-A/RAS
PB2/CS2-A/CS6-A/RAS
PB2/CS2-A/CS6-A/RAS
3
C1
PB3/CS3/CS7-A/CAS
PB3/CS3/CS7-A/CAS
PB3/CS3/CS7-A/CAS
4
B3
Vss
Vss
Vss
5
C2
PB7/SDRAMφ
PB7/SDRAMφ
PB7/SDRAMφ
6
D4
Vcc
Vcc
Vcc
7
D1
MD2
MD2
MD2
8
D3
PM0/TxD6
PM0/TxD6
PM0/TxD6
9
D2
PM1/RxD6
PM1/RxD6
PM1/RxD6
10
E1
PM2
PM2
PM2
11
E4
PF7/A23
PF7/A23
PF7/A23
12
E3
PF6/A22
PF6/A22
PF6/A22
13
E2
PF5/A21
PF5/A21
PF5/A21
14
F1
PF4/A20
PF4/A20
A20
15
F4
PF3/A19
PF3/A19
A19
16
F3
Vss
Vss
Vss
17
F2
PF2/A18
PF2/A18
A18
18
G1
PF1/A17
PF1/A17
A17
19
H4
PF0/A16
PF0/A16
20
21
G3
G2
PE7/A15
PE6/A14
A16
1
PE7/A15 PK7/PO31/TIOCA11/TIOCB11*
1
PE6/A14 PK6/PO30/TIOCA11*
A15
A14
1
22
H1
PE5/A13
PE5/A13 PK5/PO29/TIOCA10/TIOCB10*
A13
23
G4
Vss
Vss
Vss
24
H2
PE4/A12
PE4/A12 PK4/PO28/TIOCA10*1
A12
25
J1
Vcc
Vcc
Vcc
Rev. 2.00 Oct. 21, 2009 Page 15 of 1454
REJ09B0498-0200
Section 1 Overview
Pin No.
Pin Name
LQFP- LGA144
145
Modes 1, 2, and 6
Modes 3 and 7
Modes 4 and 5
1
26
H3
PE3/A11
PE3/A11
PK3/PO27/TIOCC9/TIOCD9* A11
27
J4
PE2/A10
PE2/A10
PK2/PO26/TIOCC9*1
28
J2
PE1/A9
PE1/A9
PK1/PO25/TIOCA9/TIOCB9*1 A9
29
K1
PE0/A8
PE0/A8
PK0/PO24/TIOCA9*1
A8
30
J3
PD7/A7
PD7/A7
PJ7/PO23/TIOCA8/TIOCB8/
A7
A10
TCLKH*1
31
K4
PD6/A6
PD6/A6
32
L2
Vss
Vss
33
K2
PD5/A5
PD5/A5
PJ6/PO22/TIOCA8*1
A6
Vss
PJ5/PO21/TIOCA7/TIOCB7/
A5
TCLKG*1
34
K3
PD4/A4
PD4/A4
PJ4/PO20/TIOCA7*1
A4
35
L1
PD3/A3
PD3/A3
PJ3/PO19/TIOCC6/TIOCD6/
A3
TCLKF*1
36
37
M1
M2
PD2/A2
PD1/A1
PD2/A2
PD1/A1
PJ2/PO18/TIOCC6/TCLKE*1
A2
1
PJ1/PO17/TIOCA6/TIOCB6*
1
PJ0/PO16/TIOCA6*
A1
38
N1
PD0/A0
PD0/A0
A0
39
L3
EMLE
EMLE
EMLE
40
N2
PM3
PM3
PM3
41
N3
PM4
PM4
PM4
42
M3
DrVcc
DrVcc
DrVcc
43
N4
USD+
USD+
USD+
44
M4
USD-
USD-
USD-
45
N5
DrVss
DrVss
DrVss
46
L4
VBUS
VBUS
VBUS
47
L5
MD_CLK
MD_CLK
MD_CLK
48
M5
Vss
Vss
Vss
49
M6
P20/PO0/TIOCA3/TIOCB3/
P20/PO0/TIOCA3/TIOCB3/TMRI0/
P20/PO0/TIOCA3/TIOCB3/TMRI0/
TMRI0/SCK0/IRQ8-A
SCK0/IRQ8-A
SCK0/IRQ8-A
Vcc
Vcc
50
K5
Vcc
51
K6
P21/PO1/TIOCA3/TMCI0/RxD0/ P21/PO1/TIOCA3/TMCI0/RxD0/
IRQ9-A
Rev. 2.00 Oct. 21, 2009 Page 16 of 1454
REJ09B0498-0200
IRQ9-A
P21/PO1/TIOCA3/TMCI0/RxD0/
IRQ9-A
Section 1 Overview
Pin No.
Pin Name
LQFP- LGA144
145
52
N6
53
54
M7
L6
55
K7
56
N7
57
58
M8
L7
Modes 1, 2, and 6
Modes 3 and 7
Modes 4 and 5
P22/PO2/TIOCC3/TMO0/TxD0/ P22/PO2/TIOCC3/TMO0/TxD0/
P22/PO2/TIOCC3/TMO0/TxD0/
IRQ10-A
IRQ10-A
IRQ10-A
P23/PO3/TIOCC3/TIOCD3/
P23/PO3/TIOCC3/TIOCD3/
P23/PO3/TIOCC3/TIOCD3/
IRQ11-A
IRQ11-A
IRQ11-A
P24/PO4/TIOCA4/TIOCB4/
P24/PO4/TIOCA4/TIOCB4/TMRI1/
P24/PO4/TIOCA4/TIOCB4/TMRI1/
TMRI1/SCK1
SCK1
SCK1
P25/PO5/TIOCA4/TMCI1/RxD1 P25/PO5/TIOCA4/TMCI1/RxD1
P25/PO5/TIOCA4/TMCI1/RxD1
P30/PO8/TIOCA0/DREQ0-B/
P30/PO8/TIOCA0/DREQ0-B/
P30/PO8/TIOCA0/DREQ0-B/
EDREQ2
EDREQ2
EDREQ2
P31/PO9/TIOCA0/TIOCB0/
P31/PO9/TIOCA0/TIOCB0/
P31/PO9/TIOCA0/TIOCB0/
TEND0-B/ETEND2
TEND0-B/ETEND2
TEND0-B/ETEND2
P32/PO10/TIOCC0/
P32/PO10/TIOCC0/
P32/PO10/TIOCC0/
TCLKA-A/DACK0-B/EDACK2
TCLKA-A/DACK0-B/EDACK2
TCLKA-A/DACK0-B/EDACK2
59
K8
P26/PO6/TIOCA5/TMO1/TxD1
P26/PO6/TIOCA5/TMO1/TxD1
P26/PO6/TIOCA5/TMO1/TxD1
60
N8
P27/PO7/TIOCA5/TIOCB5
P27/PO7/TIOCA5/TIOCB5
P27/PO7/TIOCA5/TIOCB5
61
L9
NMI
NMI
NMI
62
L8
P33/PO11/TIOCC0/TIOCD0/
P33/PO11/TIOCC0/TIOCD0/
P33/PO11/TIOCC0/TIOCD0/
TCLKB-A/DREQ1-B/EDREQ3
TCLKB-A/DREQ1-B/EDREQ3
TCLKB-A/DREQ1-B/EDREQ3
63
K9
P34/PO12/TIOCA1/
P34/PO12/TIOCA1/TEND1-B/
P34/PO12/TIOCA1/
TEND1-B/ETEND3
ETEND3
TEND1-B/ETEND3
64
N9
Vcc
Vcc
Vcc
65
M9
PH0/D0
PH0/D0
D0
66
L10
PH1/D1
PH1/D1
D1
67
K10
PH2/D2
PH2/D2
D2
68
N10
PH3/D3
PH3/D3
D3
69
M10
Vss
Vss
Vss
70
M11
PH4/D4
PH4/D4
D4
71
N11
PH5/D5
PH5/D5
D5
72
N12
PH6/D6
PH6/D6
D6
73
M12
PH7/D7
PH7/D7
D7
74
N13
Vcc
Vcc
Vcc
75
M13
PI0/D8
PI0/D8
PI0/D8
Rev. 2.00 Oct. 21, 2009 Page 17 of 1454
REJ09B0498-0200
Section 1 Overview
Pin No.
Pin Name
LQFP- LGA144
145
Modes 1, 2, and 6
Modes 3 and 7
Modes 4 and 5
76
L13
PI1/D9
PI1/D9
PI1/D9
77
L11
PI2/D10
PI2/D10
PI2/D10
78
L12
PI3/D11
PI3/D11
PI3/D11
79
K13
Vss
Vss
Vss
80
K11
PI4/D12
PI4/D12
PI4/D12
81
K12
PI5/D13
PI5/D13
PI5/D13
82
J13
PI6/D14
PI6/D14
PI6/D14
83
J10
PI7/D15
PI7/D15
PI7/D15
84
J11
85
86
87
H11
J12
G11
P10/TxD2/DREQ0-A/
P10/TxD2/DREQ0-A/IRQ0-A/
P10/TxD2/DREQ0-A/
IRQ0-A/EDREQ0-A
EDREQ0-A
IRQ0-A/EDREQ0-A
P11/RxD2/TEND0-A/
P11/RxD2/TEND0-A/
P11/RxD2/TEND0-A/
IRQ1-A/ETEND0-A
IRQ1-A/ETEND0-A
IRQ1-A/ETEND0-A
P12/SCK2/DACK0-A/
P12/SCK2/DACK0-A/
P12/SCK2/DACK0-A/
IRQ2-A/EDACK0-A
IRQ2-A/EDACK0-A
IRQ2-A/EDACK0-A
P13/ADTRG0-A/
P13/ADTRG0-A/IRQ3-A/EDRAK0
P13/ADTRG0-A/IRQ3-A/EDRAK0
IRQ3-A/EDRAK0
88
G12
Vss
Vss
Vss
89
H13
OSC2
OSC2
OSC2
90
H12
OSC1
OSC1
OSC1
91
G13
RES
RES
RES
92
H10
VCL
VCL
VCL
93
G10
P14/TCLKA-B/TxD5/IrTxD/
P14/TCLKA-B/TxD5/IrTxD/SDA1/
P14/TCLKA-B/TxD5/IrTxD/SDA1/
SDA1/DREQ1-A/IRQ4-A/
DREQ1-A/IRQ4-A/EDREQ1-A
DREQ1-A/IRQ4-A/EDREQ1-A
EDREQ1-A
94
F11
P15/TCLKB-B/RxD5/IrRxD/SCL1/ P15/TCLKB-B/RxD5/IrRxD/SCL1/
P15/TCLKB-B/RxD5/IrRxD/SCL1/
TEND1-A/IRQ5-A/ETEND1-A
TEND1-A/IRQ5-A/ETEND1-A
TEND1-A/IRQ5-A/ETEND1-A
95
F13
WDTOVF
WDTOVF/TDO*2
WDTOVF
96
F12
Vss
Vss
Vss
97
E12
XTAL
XTAL
XTAL
98
E13
EXTAL
EXTAL
EXTAL
99
F10
Vcc
Vcc
Vcc
Rev. 2.00 Oct. 21, 2009 Page 18 of 1454
REJ09B0498-0200
Section 1 Overview
Pin No.
Pin Name
LQFP- LGA144
145
Modes 1, 2, and 6
Modes 3 and 7
Modes 4 and 5
100
E11
P16/TCLKC-B/SDA0
P16/TCLKC-B/SDA0/
P16/TCLKC-B/SDA0/
/DACK1-A/IRQ6-A/EDACK1-A
DACK1-A/IRQ6-A/EDACK1-A
DACK1-A/IRQ6-A/EDACK1-A
P17/TCLKD-B/SCL0/ADTRG1/
P17/TCLKD-B/SCL0/ADTRG1/
P17/TCLKD-B/SCL0/ADTRG1/
IRQ7-A/EDRAK1
IRQ7-A/EDRAK1
IRQ7-A/EDRAK1
101
E10
102
D13
STBY
STBY
STBY
103
D12
Vss
Vss
Vss
104
D11
P35/PO13/TIOCA1/TIOCB1/
105
C12
106
C13
107
108
109
B13
A13
B12
110
A12
111
C11
112
113
A11
B11
P35/PO13/TIOCA1/TIOCB1/
P35/PO13/TIOCA1/TIOCB1/
TCLKC-A/DACK1-B/EDACK3
TCLKC-A/DACK1-B/EDACK3
TCLKC-A/DACK1-B/EDACK3
P36/PO14/TIOCA2/EDRAK2
P36/PO14/TIOCA2/EDRAK2
P36/PO14/TIOCA2/EDRAK2
P37/PO15/TIOCA2/TIOCB2/
P37/PO15/TIOCA2/TIOCB2/
P37/PO15/TIOCA2/TIOCB2/
TCLKD-A/EDRAK3
TCLKD-A/EDRAK3
TCLKD-A/EDRAK3
P60/TMRI2/TxD4/DREQ2/
P60/TMRI2/TxD4/DREQ2/
P60/TMRI2/TxD4/DREQ2/
IRQ8-B/EDREQ0-B
IRQ8-B/EDREQ0-B
IRQ8-B/EDREQ0-B
P61/TMCI2/RxD4/TEND2/
P61/TMCI2/RxD4/TEND2/
P61/TMCI2/RxD4/TEND2/
IRQ9-B/ETEND0-B
IRQ9-B/ETEND0-B
IRQ9-B/ETEND0-B
P62/TMO2/SCK4/DACK2/
P62/TMO2/SCK4/DACK2/
P62/TMO2/SCK4/DACK2/
IRQ10-B/EDACK0-B
IRQ10-B/TRST*2/EDACK0-B
IRQ10-B/EDACK0-B
PLLVcc
PLLVcc
PLLVcc
P63/TMRI3/DREQ3/
P63/TMRI3/DREQ3/
P63/TMRI3/DREQ3/
IRQ11-B/EDREQ1-B
IRQ11-B/TMS*2/EDREQ1-B
IRQ11-B/EDREQ1-B
PLLVss
PLLVss
PLLVss
P64/TMCI3/TEND3/ETEND1-B
2
P64/TMCI3/TEND3/TDI* /ETEND1-B
2
P64/TMCI3/TEND3/ETEND1-B
114
A10
P65/TMO3/DACK3/EDACK1-B
P65/TMO3/DACK3/TCK* /EDACK1-B
P65/TMO3/DACK3/EDACK1-B
115
D10
MD0
MD0
MD0
116
C10
PC2/LUCAS/DQMLU
PC2/LUCAS/DQMLU
PC2/LUCAS/DQMLU
117
B10
PC3/LLCAS/DQMLL
PC3/LLCAS/DQMLL
PC3/LLCAS/DQMLL
118
A9
P50/AN0/IRQ0-B
P50/AN0/IRQ0-B
P50/AN0/IRQ0-B
119
C9
P51/AN1/IRQ1-B
P51/AN1/IRQ1-B
P51/AN1/IRQ1-B
120
B9
P52/AN2/IRQ2-B
P52/AN2/IRQ2-B
P52/AN2/IRQ2-B
121
B8
AVcc
AVcc
AVcc
122
D9
P53/AN3/IRQ3-B
P53/AN3/IRQ3-B
P53/AN3/IRQ3-B
123
C8
AVss
AVss
AVss
Rev. 2.00 Oct. 21, 2009 Page 19 of 1454
REJ09B0498-0200
Section 1 Overview
Pin No.
Pin Name
LQFP- LGA144
145
Modes 1, 2, and 6
Modes 3 and 7
Modes 4 and 5
124
B7
P54/AN4/IRQ4-B
P54/AN4/IRQ4-B
P54/AN4/IRQ4-B
125
A8
Vref
Vref
Vref
126
D8
P55/AN5/IRQ5-B
P55/AN5/IRQ5-B
P55/AN5/IRQ5-B
127
D7
P56/AN6/DA0/IRQ6-B
P56/AN6/DA0/IRQ6-B
P56/AN6/DA0/IRQ6-B
128
A7
P57/AN7/DA1/IRQ7-B
P57/AN7/DA1/IRQ7-B
P57/AN7/DA1/IRQ7-B
129
B6
MD1
MD1
MD1
130
C7
PB4/CS4-B/WE
PB4/CS4-B/WE
PB4/CS4-B/WE
131
C6
PB5/CS5-D/OE/CKE
PB5/CS5-D/OE/CKE
PB5/CS5-D/OE/CKE
132
A6
PB6/CS6-D/
PB6/CS6-D/(RD/WR-B)/ADTRG0-B
PB6/CS6-D/(RD/WR-B)/
ADTRG0-B
(RD/WR-B)/ADTRG0-B
133
B5
MD3
MD3
MD3
134
D6
PA0/BREQO/BS-A
PA0/BREQO/BS-A
PA0/BREQO/BS-A
135
A5
PA1/BACK/(RD/WR-A)
PA1/BACK/(RD/WR-A)
PA1/BACK/(RD/WR-A)
136
B4
PA2/BREQ/WAIT
PA2/BREQ/WAIT
PA2/BREQ/WAIT
137
D5
PA3/LLWR/LLB
PA3/LLWR/LLB
LLWR/LLB
138
A4
PA4/LHWR/LUB
PA4/LHWR/LUB
PA4/LHWR/LUB
139
C5
PA5/RD
PA5/RD
RD
140
C4
PA6/AS/AH/BS-B
PA6/AS/AH/BS-B
PA6/AS/AH/BS-B
141
C3
Vss
Vss
Vss
142
A2
PA7/Bφ
PA7/Bφ
PA7/Bφ
143
A3
Vcc
Vcc
Vcc
144
B2
PB0/CS0/CS4-A/CS5-B
PB0/CS0/CS4-A/CS5-B
PB0/CS0/CS4-A/CS5-B
⎯
E5
NC
NC
NC
Notes: 1. These pins can be used when the PCJKE bit in PFCRD is set to 1 in single-chip mode.
2. Pins TDO, TRST, TMS, and TCK are enabled in mode 3.
Rev. 2.00 Oct. 21, 2009 Page 20 of 1454
REJ09B0498-0200
Section 1 Overview
1.4.3
Pin Functions
Table 1.5
Pin Functions
Classification Pin Name
I/O
Description
Power supply
VCC
Input
Power supply pins. Connect them to the system power
supply.
VCL
Input
Connect this pin to VSS via a 0.1-μF capacitor (The capacitor
should be placed close to the pin).
VSS
Input
Ground pins. Connect them to the system power supply
(0 V).
PLLVCC
Input
Power supply pin for the PLL circuit. Connect them to the
system power supply.
PLLVSS
Input
Ground pin for the PLL circuit.
DrVCC
Input
Power supply pin for the on-chip USB transceiver. Connect
this pin to the system power supply.
DrVSS
Input
Ground pin for the on-chip USB transceiver.
XTAL
Input
EXTAL
Input
Pins for a crystal resonator. An external clock signal can be
input through the EXTAL pin. For an example of this
connection, see section 27, Clock Pulse Generator.
OSC1
Input
The 32.768 KH crystal resonator is connected to this pin.
OSC2
Input
The 32.768 KH crystal resonator is connected to this pin.
Bφ
Output
Outputs the system clock for external devices.
SDRAMφ
Output
When connecting the synchronous DRAM, connect it to the
CLK pin of synchronous DRAM. For details, see section 9,
Bus Controller (BSC).
MD3 to MD0
Input
Pins for setting the operating mode. The signal levels on
these pins must not be changed during operation.
MD_CLK
Input
This pin changes the multiplication ratio of the clock
oscillator. Do not change values on this pin during operation.
Input
Reset signal input pin. This LSI enters the reset state when
this signal goes low.
STBY
Input
This LSI enters hardware standby mode when this signal
goes low.
EMLE
Input
Input pin for the on-chip emulator enable signal. The signal
level should normally be fixed low.
Clock
Operating
mode control
System control RES
Rev. 2.00 Oct. 21, 2009 Page 21 of 1454
REJ09B0498-0200
Section 1 Overview
Classification Pin Name
I/O
Description
TRST
Input
TMS
Input
TDI
Input
On-chip emulator pins or boundary scan pins. When the
EMLE pin is driven high, these pins are dedicated for the onchip emulator. When the EMLE pin is driven low and to mode
3, these pins are dedicated for the boundary scan mode.
TCK
Input
TDO
Output
Address bus
A23 to A0
Output
Output pins for the address bits.
Data bus
D15 to D0
Input/
output
Input and output for the bidirectional data bus. These pins
also output addresses when accessing an address–data
multiplexed I/O interface space.
Bus control
BREQ
Input
External bus-master modules assert this signal to request
the bus.
BREQO
Output
Internal bus-master modules assert this signal to request
access to the external space via the bus in the external bus
released state.
BACK
Output
Bus acknowledge signal, which indicates that the bus has
been released.
On-chip
emulator
BS-A/BS-B
Output
Indicates the start of a bus cycle.
AS
Output
Strobe signal which indicates that the output address on the
address bus is valid in access to the basic bus interface or
byte control SRAM interface space.
AH
Output
This signal is used to hold the address when accessing the
address-data multiplexed I/O interface space.
RD
Output
Strobe signal which indicates that reading from the basic bus
interface space is in progress.
(RD/WR-A)/(RD/WR-B) Output
Indicates the direction (input or output) of the data bus.
LHWR
Output
Strobe signal which indicates that the higher-order byte (D15
to D8) is valid in access to the basic bus interface space.
LLWR
Output
Strobe signal which indicates that the lower-order byte (D7 to
D0) is valid in access to the basic bus interface space.
LUB
Output
Strobe signal which indicates that the higher-order byte (D15
to D8) is valid in access to the byte control SRAM interface
space.
LLB
Output
Strobe signal which indicates that the lower-order byte (D7 to
D0) is valid in access to the byte control SRAM interface
space.
Rev. 2.00 Oct. 21, 2009 Page 22 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
Pin Name
I/O
Description
Bus control
CS0
CS1
CS2-A/CS2-B
CS3
CS4-A/CS4-B
CS5-A/CS5-B/
CS5-D
CS6-A/CS6-B/
CS6-D
CS7-A/CS7-B
Output
Select signals for areas 0 to 7.
WAIT
Input
Requests wait cycles in access to the external space.
RAS
Output
•
Row address strobe signal for the DRAM when area 2
is specified as the DRAM interface space
•
Row address strobe signal for the synchronous DRAM
when area 2 is specified as the synchronous DRAM
interface space
CAS
Output
•
Column address strobe signal for the synchronous
DRAM when area 2 is specified as the synchronous
DRAM interface space
WE
Output
•
Write enable signal for the DRAM space
•
Synchronous DRAM write enable signal when area 2 is
specified as the synchronous DRAM interface space
•
Output enable signal for the DRAM interface space
•
Clock enable signal for the synchronous DRAM
interface space
OE/CKE
Output
LUCAS
Output
•
Upper column address strobe signal for the 16-bit
DRAM interface space
LLCAS
Output
•
Lower column address strobe signal for the 16-bit
DRAM interface space
•
Column address strobe signal for the 8-bit DRAM
interface space
DQMLU
Output
•
Upper data mask enable signal for the 16-bit
synchronous DRAM interface space
DQMLL
Output
•
Lower data mask enable signal for the 16-bit
synchronous DRAM interface space
•
Data mask enable signal for the 8-bit synchronous
DRAM interface space
Rev. 2.00 Oct. 21, 2009 Page 23 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
Pin Name
I/O
Description
Interrupt
NMI
Input
Non-maskable interrupt request signal. When this pin is not
in use, this signal must be fixed high.
IRQ11-A/IRQ11-B
IRQ10-A/IRQ10-B
IRQ9-A/IRQ9-B
IRQ8-A/IRQ8-B
IRQ7-A/IRQ7-B
IRQ6-A/IRQ6-B
IRQ5-A/IRQ5-B
IRQ4-A/IRQ4-B
IRQ3-A/IRQ3-B
IRQ2-A/IRQ2-B
IRQ1-A/IRQ1-B
IRQ0-A/IRQ0-B
Input
Maskable interrupt request signal.
DMA controller
(DMAC)
DREQ0-A/DREQ0-B Input
DREQ1-A/DREQ1-B
DREQ2
DREQ3
Requests DMAC activation.
DACK0-A/DACK0-B Output
DACK1-A/DACK1-B
DACK2
DACK3
DMAC single address-transfer acknowledge signal.
TEND0-A/TEND0-B
TEND1-A/TEND1-B
TEND2
TEND3
Indicates end of data transfer by the DMAC.
Output
Rev. 2.00 Oct. 21, 2009 Page 24 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
Pin Name
I/O
Description
EXDMA
controller
(EXDMAC)
EDREQ0-A/
EDREQ0-B
EDREQ1-A/
EDREQ1-B
EDREQ2
EDREQ3
Input
Requests EXDMAC activation.
EDACK0-A/
EDACK0-B
EDACK1-A/
EDACK1-B
EDACK2
EDACK3
Output
EXDMAC single address-transfer acknowledge signal.
ETEND0-A/
ETEND0-B
ETEND1-A/
ETEND1-B
ETEND2
ETEND3
Output
Indicates end of data transfer by the EXDMAC.
EDRAK0
EDRAK1
Output
Notification to external device of EXDMAC external request
acceptance and start of execution.
Input
Input pins for the external clock signals.
TIOCA0
TIOCB0
TIOCC0
TIOCD0
Input/
output
Signals for TGRA_0 to TGRD_0. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
TIOCA1
TIOCB1
Input/
output
Signals for TGRA_1 and TGRB_1. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
TIOCA2
TIOCB2
Input/
output
Signals for TGRA_2 and TGRB_2. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
TIOCA3
TIOCB3
TIOCC3
TIOCD3
Input/
output
Signals for TGRA_3 to TGRD_3. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
TIOCA4
TIOCB4
Input/
output
Signals for TGRA_4 and TGRB_4. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
16-bit timer
TCLKA-A/TCLKA-B
pulse unit (TPU) TCLKB-A/TCLKB-B
TCLKC-A/TCLKC-B
TCLKD-A/TCLKD-B
Rev. 2.00 Oct. 21, 2009 Page 25 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
Pin Name
I/O
Description
Input/
output
Signals for TGRA_5 and TGRB_5. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
TCLKE
TCLKF
TCLKG
TCLKH
Input
Input pins for external clock signals.
TIOCA6
TIOCB6
TIOCC6
TIOCD6
Input/
output
Signals for TGRA_6 to TGRB_6. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
TIOCA7
TIOCB7
Input/
output
Signals for TGRA_7 and TGRB_7. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
TIOCA8
TIOCB8
Input/
output
Signals for TGRA_8 and TGRB_8. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
TIOCA9
TIOCB9
TIOCC9
TIOCD9
Input/
output
Signals for TGRA_9 to TGRB_9. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
TIOCA10
TIOCB10
Input/
output
Signals for TGRA_10 and TGRB_10. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
TIOCA11
TIOCB11
Input/
output
Signals for TGRA_11 and TGRB_11. These pins are used as
input capture inputs, output compare outputs, or PWM
outputs.
PO31 to PO0
Output
Output pins for the pulse signals.
Output
Output pins for the compare match signals.
TMCI0 to TMCI3
Input
Input pins for the external clock signals that drive for the
counters.
TMRI0 to TMRI3
Input
Input pins for the counter-reset signals.
WDTOVF
Output
Output pin for the counter-overflow signal in watchdog-timer
mode.
16-bit timer
TIOCA5
pulse unit (TPU) TIOCB5
Programmable
pulse generator
(PPG)
8-bit timer (TMR) TMO0 to TMO3
Watchdog timer
(WDT)
Rev. 2.00 Oct. 21, 2009 Page 26 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
Pin Name
I/O
Description
Output
Output pins for data transmission.
RxD0
RxD1
RxD2
RxD4
RxD5
RxD6
Input
Input pins for data reception.
SCK0
SCK1
SCK2
SCK4
Input/
output
Input/output pins for clock signals.
IrTxD
Output
Output pin that outputs encoded data for IrDA.
Serial
TxD0
communications TxD1
interface (SCI)
TxD2
TxD4
TxD5
TxD6
SCI with IrDA
(SCI)
Input
Input pin that inputs encoded data for IrDA.
I C bus interface SCL0
2 (IIC2)
SCL1
IrRxD
Input/
output
Input/output pin for IIC clock. Bus can be directly driven by
the NMOS open drain output.
SDA0
SDA1
Input/
output
Input/output pin for IIC data. Bus can be directly driven by
the NMOS open drain output.
USD+
Input/
output
Input/output pin for USB data.
VBUS
Input
Input pin for detecting the connection/disconnection of the
USB cable.
AN7 to AN0
Input
Input pins for the analog signals to be processed by the A/D
converter.
ADTRG0-A/
ADTRG0-B
ADTRG1
Input
Input pins for the external trigger signal that starts A/D
conversion.
DA1, DA0
Output
Output pins for the analog signals from the D/A converter.
2
Universal serial
interface (USB)
A/D converter
D/A converter
USD-
Rev. 2.00 Oct. 21, 2009 Page 27 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
Pin Name
I/O
Description
A/D converter,
D/A converter
AVCC
Input
Analog power supply pin for the A/D and D/A converters.
When the A/D and D/A converters are not in use, connect
this pin to the system power supply.
AVSS
Input
Ground pin for the A/D and D/A converters. Connect this pin
to the system power supply (0 V).
Vref
Input
Reference power supply pin for the A/D and D/A converters.
When the A/D and D/A converters are not in use, connect
this pin to the system power supply.
P17 to P10
Input/
output
8-bit input/output pins.
P27 to P20
Input/
output
8-bit input/output pins.
P37 to P30
Input/
output
8-bit input/output pins.
P57 to P50
Input
8-bit input-only pins.
P65 to P60
Input/
output
6-bit input/output pins.
PA7
Input
Input-only pin.
PA6 to PA0
Input/
output
7-bit input/output pins.
PB7 to PB0
Input/
output
8-bit input/output pins.
PC3 to PC2
Input/
output
2-bit input/output pins.
PD7 to PD0
Input/
output
8-bit input/output pins.
PE7 to PE0
Input/
output
8-bit input/output pins.
PF7 to PF0
Input/
output
8-bit input/output pins.
PH7 to PH0
Input/
output
8-bit input/output pins.
PI7 to PI0
Input/
output
8-bit input/output pins.
PM4 to PM0
Input/
output
5-bit input/output pins.
I/O ports
Rev. 2.00 Oct. 21, 2009 Page 28 of 1454
REJ09B0498-0200
Section 1 Overview
Classification
Pin Name
I/O
Description
I/O ports
PJ7 to PJ0*
Input/
output
8-bit input/output pins.
PK7 to PK0*
Input/
output
8-bit input/output pins.
Note:
*
These pins can be used when the PCJKE bit in PFCRD is set to 1 in single-chip mode.
Rev. 2.00 Oct. 21, 2009 Page 29 of 1454
REJ09B0498-0200
Section 1 Overview
Rev. 2.00 Oct. 21, 2009 Page 30 of 1454
REJ09B0498-0200
Section 2 CPU
Section 2 CPU
The H8SX CPU is a high-speed CPU with an internal 32-bit architecture that is upward
compatible with the H8/300, H8/300H, and H8S CPUs.
The H8SX CPU has sixteen 16-bit general registers, can handle a 4-Gbyte linear address space,
and is ideal for a realtime control system.
2.1
Features
• Upward-compatible with H8/300, H8/300H, and H8S CPUs
⎯ Can execute object programs of these CPUs
• Sixteen 16-bit general registers
⎯ Also usable as sixteen 8-bit registers or eight 32-bit registers
• 87 basic instructions
⎯ 8/16/32-bit arithmetic and logic instructions
⎯ Multiply and divide instructions
⎯ Bit field transfer instructions
⎯ Powerful bit-manipulation instructions
⎯ Bit condition branch instructions
⎯ Multiply-and-accumulate instruction
• Eleven addressing modes
⎯ Register direct [Rn]
⎯ Register indirect [@ERn]
⎯ Register indirect with displacement [@(d:2,ERn), @(d:16,ERn), or @(d:32,ERn)]
⎯ Index register indirect with displacement [@(d:16,RnL.B), @(d:32,RnL.B),
@(d:16,Rn.W), @(d:32,Rn.W), @(d:16,ERn.L), or @(d:32,ERn.L)]
⎯ Register indirect with pre-/post-increment or pre-/post-decrement [@+ERn, @−ERn,
@ERn+, or @ERn−]
⎯ Absolute address [@aa:8, @aa:16, @aa:24, or @aa:32]
⎯ Immediate [#xx:3, #xx:4, #xx:8, #xx:16, or #xx:32]
⎯ Program-counter relative [@(d:8,PC) or @(d:16,PC)]
⎯ Program-counter relative with index register [@(RnL.B,PC), @(Rn.W,PC), or
@(ERn.L,PC)]
⎯ Memory indirect [@@aa:8]
⎯ Extended memory indirect [@@vec:7]
Rev. 2.00 Oct. 21, 2009 Page 31 of 1454
REJ09B0498-0200
Section 2 CPU
• Two base registers
⎯ Vector base register
⎯ Short address base register
• 4-Gbyte address space
⎯ Program: 4 Gbytes
⎯ Data:
4 Gbytes
• High-speed operation
⎯ All frequently-used instructions executed in one or two states
⎯ 8/16/32-bit register-register add/subtract: 1 state
⎯ 8 × 8-bit register-register multiply:
1 state (When the multiplier is available.)
⎯ 16 ÷ 8-bit register-register divide:
10 states (When the multiplier is available.)
⎯ 16 × 16-bit register-register multiply:
1 state (When the multiplier is available.)
⎯ 32 ÷ 16-bit register-register divide:
18 states (When the multiplier is available.)
⎯ 32 × 32-bit register-register multiply:
5 states (When the multiplier is available.)
⎯ 32 ÷ 32-bit register-register divide:
18 states (When the multiplier is available.)
• Four CPU operating modes
⎯ Normal mode
⎯ Middle mode
⎯ Advanced mode
⎯ Maximum mode
• Power-down modes
⎯ Transition is made by execution of SLEEP instruction
⎯ Choice of CPU operating clocks
Notes: 1. Advanced mode is only supported as the CPU operating mode of the H8SX/1665
Group and H8SX/1665M Group. Normal, middle, and maximum modes are not
supported.
2. The multiplier and divider are supported by the H8SX/1665 Group and H8SX/1665M
Group.
Rev. 2.00 Oct. 21, 2009 Page 32 of 1454
REJ09B0498-0200
Section 2 CPU
2.2
CPU Operating Modes
The H8SX CPU has four operating modes: normal, middle, advanced and maximum modes. These
modes can be selected by the mode pins of this LSI.
Maximum 64 kbytes for program
Normal mode
and data areas combined
Maximum 16-Mbyte program
Middle mode
area and 64-kbyte data area,
maximum 16 Mbytes for program
and data areas combined
CPU operating modes
Maximum 16-Mbyte program
Advanced mode
area and 4-Gbyte data area,
maximum 4 Gbytes for program
and data areas combined
Maximum mode
Maximum 4 Gbytes for program
and data areas combined
Figure 2.1 CPU Operating Modes
2.2.1
Normal Mode
The exception vector table and stack have the same structure as in the H8/300 CPU.
• Address Space
The maximum address space of 64 Kbytes can be accessed.
• 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 the extended register 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 Rn is referenced in the register indirect addressing mode with
pre-/post-increment or pre-/post-decrement 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.
Rev. 2.00 Oct. 21, 2009 Page 33 of 1454
REJ09B0498-0200
Section 2 CPU
• 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. The structure of the exception vector table is shown in
figure 2.2.
H'0000
H'0001
H'0002
H'0003
Reset exception vector
Exception
vector table
Reset exception vector
Figure 2.2 Exception Vector Table (Normal Mode)
The memory indirect (@@aa:8) and extended memory indirect (@@vec:7) addressing modes
are used in the JMP and JSR instructions. An 8-bit absolute address included in the instruction
code specifies a memory location. Execution branches to the contents of the memory location.
• Stack Structure
The stack structure of PC at a subroutine branch and that of PC and CCR at an exception
handling are shown in figure 2.3. The PC contents are saved or restored in 16-bit units.
SP
PC
(16 bits)
EXR*1
Reserved*1, *3
CCR
CCR*3
SP
(SP *2
)
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. Ignored on return.
Figure 2.3 Stack Structure (Normal Mode)
Rev. 2.00 Oct. 21, 2009 Page 34 of 1454
REJ09B0498-0200
Section 2 CPU
2.2.2
Middle Mode
The program area in middle mode is extended to 16 Mbytes as compared with that in normal
mode.
• Address Space
The maximum address space of 16 Mbytes can be accessed as a total of the program and data
areas. For individual areas, up to 16 Mbytes of the program area or up to 64 Kbytes of the data
area can be allocated.
• 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 the extended register En is used as a 16-bit register (in
other than the JMP and JSR instructions), it can contain any value even when the
corresponding general register Rn is used as an address register. (If the general register Rn is
referenced in the register indirect addressing mode with pre-/post-increment or pre-/postdecrement 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 and the upper eight bits are sign-extended.
• Exception Vector Table and Memory Indirect Branch Addresses
In middle mode, the top area starting at H'000000 is allocated to the exception vector table.
One branch address is stored per 32 bits. The upper eight bits are ignored and the lower 24 bits
are stored. The structure of the exception vector table is shown in figure 2.4.
The memory indirect (@@aa:8) and extended memory indirect (@@vec:7) addressing modes
are used in the JMP and JSR instructions. An 8-bit absolute address included in the instruction
code specifies a memory location. Execution branches to the contents of the memory location.
In middle mode, an operand is a 32-bit (longword) operand, providing a 32-bit branch address.
The upper eight bits are reserved and assumed to be H'00.
• Stack Structure
The stack structure of PC at a subroutine branch and that of PC and CCR at an exception
handling are shown in figure 2.5. The PC contents are saved or restored in 24-bit units.
Rev. 2.00 Oct. 21, 2009 Page 35 of 1454
REJ09B0498-0200
Section 2 CPU
2.2.3
Advanced Mode
The data area is extended to 4 Gbytes as compared with that in middle mode.
• Address Space
The maximum address space of 4 Gbytes can be linearly accessed. For individual areas, up to
16 Mbytes of the program area and up to 4 Gbytes of the data area can be allocated.
• 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 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. One branch address is stored per 32 bits. The upper eight bits are ignored and the lower
24 bits are stored. The structure of the exception vector table is shown in figure 2.4.
H'00000000
Reserved
H'00000001
H'00000002
Reset exception vector
H'00000003
H'00000004
Reserved
Exception vector table
H'00000005
H'00000006
H'00000007
Figure 2.4 Exception Vector Table (Middle and Advanced Modes)
The memory indirect (@@aa:8) and extended memory indirect (@@vec:7) addressing modes
are used in the JMP and JSR instructions. An 8-bit absolute address included in the instruction
code specifies a memory location. Execution branches to the contents of the memory location.
In advanced mode, an operand is a 32-bit (longword) operand, providing a 32-bit branch
address. The upper eight bits are reserved and assumed to be H'00.
Rev. 2.00 Oct. 21, 2009 Page 36 of 1454
REJ09B0498-0200
Section 2 CPU
• Stack Structure
The stack structure of PC at a subroutine branch and that of PC and CCR at an exception
handling are shown in figure 2.5. The PC contents are saved or restored in 24-bit units.
EXR*1
Reserved*1, *3
CCR
SP
Reserved
SP
PC
(24 bits)
(a) Subroutine Branch
2
(SP*
)
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 on return.
Figure 2.5 Stack Structure (Middle and Advanced Modes)
2.2.4
Maximum Mode
The program area is extended to 4 Gbytes as compared with that in advanced mode.
• Address Space
The maximum address space of 4 Gbytes can be linearly accessed.
• 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 or address registers.
• Instruction Set
All instructions and addressing modes can be used.
• Exception Vector Table and Memory Indirect Branch Addresses
In maximum mode, the top area starting at H'00000000 is allocated to the exception vector
table. One branch address is stored per 32 bits. The structure of the exception vector table is
shown in figure 2.6.
Rev. 2.00 Oct. 21, 2009 Page 37 of 1454
REJ09B0498-0200
Section 2 CPU
H'00000000
H'00000001
Reset exception vector
H'00000002
H'00000003
H'00000004
Exception vector table
H'00000005
H'00000006
H'00000007
Figure 2.6 Exception Vector Table (Maximum Modes)
The memory indirect (@@aa:8) and extended memory indirect (@@vec:7) addressing modes
are used in the JMP and JSR instructions. An 8-bit absolute address included in the instruction
code specifies a memory location. Execution branches to the contents of the memory location.
In maximum mode, an operand is a 32-bit (longword) operand, providing a 32-bit branch
address.
• Stack Structure
The stack structure of PC at a subroutine branch and that of PC and CCR at an exception
handling are shown in figure 2.7. The PC contents are saved or restored in 32-bit units. The
EXR contents are saved or restored regardless of whether or not EXR is in use.
SP
SP
PC
(32 bits)
EXR
CCR
PC
(32 bits)
(a) Subroutine Branch
(b) Exception Handling
Figure 2.7 Stack Structure (Maximum Mode)
Rev. 2.00 Oct. 21, 2009 Page 38 of 1454
REJ09B0498-0200
Section 2 CPU
2.3
Instruction Fetch
The H8SX CPU has two modes for instruction fetch: 16-bit and 32-bit modes. It is recommended
that the mode be set according to the bus width of the memory in which a program is stored. The
instruction-fetch mode setting does not affect operation other than instruction fetch such as data
accesses. Whether an instruction is fetched in 16- or 32-bit mode is selected by the FETCHMD bit
in SYSCR. For details, see section 3.2.2, System Control Register (SYSCR).
2.4
Address Space
Figure 2.8 shows a memory map of the H8SX CPU. The address space differs depending on the
CPU operating mode.
Normal mode
Middle mode
H'0000
H'000000
H'FFFF
H'007FFF
Program area
Data area
(64 kbytes)
Maximum mode
Advanced mode
H'00000000
H'00000000
Program area
(16 Mbytes)
Program area
(16 Mbytes)
Data area
(64 kbytes)
H'FF8000
H'FFFFFF
Program area
Data area
(4 Gbytes)
H'00FFFFFF
Data area
(4 Gbytes)
H'FFFFFFFF
H'FFFFFFFF
Figure 2.8 Memory Map
Rev. 2.00 Oct. 21, 2009 Page 39 of 1454
REJ09B0498-0200
Section 2 CPU
2.5
Registers
The H8SX CPU has the internal registers shown in figure 2.9. There are two types of registers:
general registers and control registers. The control registers are the 32-bit program counter (PC),
8-bit extended control register (EXR), 8-bit condition-code register (CCR), 32-bit vector base
register (VBR), 32-bit short address base register (SBR), and 64-bit multiply-accumulate register
(MAC).
General Registers and Extended Registers
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
31
0
PC
7 6 5 4 3 2 1 0
CCR
I UI H U N Z V C
EXR
T — — — — I2 I1 I0
7 6 5 4 3 2 1 0
31
12
0
(Reserved)
VBR
31
8
0
(Reserved)
SBR
63
41
MAC
32
MACH
Sign extension
MACL
[Legend]
SP:
PC:
CCR:
I:
UI:
H:
31
Stack pointer
Program counter
Condition-code register
Interrupt mask bit
User bit or interrupt mask bit
Half-carry flag
0
U:
N:
Z:
V:
C:
EXR:
User bit
Negative flag
Zero flag
Overflow flag
Carry flag
Extended control register
Figure 2.9 CPU Registers
Rev. 2.00 Oct. 21, 2009 Page 40 of 1454
REJ09B0498-0200
T:
I2 to I0:
VBR:
SBR:
MAC:
Trace bit
Interrupt mask bits
Vector base register
Short address base register
Multiply-accumulate register
Section 2 CPU
2.5.1
General Registers
The H8SX 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.10 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).
When the general registers are used as 16-bit registers, the ER registers are divided 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.
When the general registers are used as 8-bit registers, the R registers are divided 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 registers.
The general registers ER (ER0 to ER7), R (R0 to R7), and RL (R0L to R7L) are also used as index
registers. The size in the operand field determines which register is selected.
The usage of each register can be selected independently.
• Address registers
• 32-bit registers
• 32-bit index registers
General registers ER
(ER0 to ER7)
• 16-bit registers
General registers E
(E0 to E7)
• 8-bit registers
• 16-bit registers
• 16-bit index registers
General registers R
(R0 to R7)
General registers RH
(R0H to R7H)
• 8-bit registers
• 8-bit index registers
General registers RL
(R0L to R7L)
Figure 2.10 Usage of General Registers
Rev. 2.00 Oct. 21, 2009 Page 41 of 1454
REJ09B0498-0200
Section 2 CPU
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 branches. Figure 2.11 shows
the stack.
Free area
SP (ER7)
Stack area
Figure 2.11 Stack
2.5.2
Program Counter (PC)
PC is a 32-bit counter that indicates the address of the next instruction the CPU will execute. The
length of all CPU instructions is 16 bits (one word) or a multiple of 16 bits, so the least significant
bit is ignored. (When the instruction code is fetched, the least significant bit is regarded as 0.
Rev. 2.00 Oct. 21, 2009 Page 42 of 1454
REJ09B0498-0200
Section 2 CPU
2.5.3
Condition-Code Register (CCR)
CCR is an 8-bit register that contains internal CPU status information, including an interrupt mask
(I) and user (UI, U) bits 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 branch conditions for conditional branch (Bcc)
instructions.
Bit
Bit Name
Initial
Value
R/W
Description
7
I
1
R/W
Interrupt Mask Bit
Masks interrupts when set to 1. This bit is set to 1 at
the start of an exception handling.
6
UI
Undefined R/W
User Bit/Interrupt Mask Bit
Can be written to and read from by software using the
LDC, STC, ANDC, ORC, and XORC instructions.
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, this 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, this 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 to and read from 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 (regarded as
sign bit) of data.
Rev. 2.00 Oct. 21, 2009 Page 43 of 1454
REJ09B0498-0200
Section 2 CPU
Bit
Bit Name
Initial
Value
2
Z
Undefined R/W
R/W
Description
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 otherwise.
0
C
Undefined R/W
Carry Flag
Set to 1 when a carry occurs, and cleared to 0
otherwise. A carry has the following types:
•
Carry from the result of addition
•
Borrow from the result of subtraction
•
Carry from the result of shift or rotation
The carry flag is also used as a bit accumulator by bit
manipulation instructions.
2.5.4
Extended Control Register (EXR)
EXR is an 8-bit register that contains the trace bit (T) and three interrupt mask bits (I2 to I0).
Operations can be performed on the EXR bits by the LDC, STC, ANDC, ORC, and XORC
instructions.
For details, see section 6, Exception Handling.
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
R/W
Reserved
These bits are always read as 1.
2
I2
1
R/W
Interrupt Mask Bits
1
I1
1
R/W
These bits designate the interrupt mask level (0 to 7).
0
I0
1
R/W
Rev. 2.00 Oct. 21, 2009 Page 44 of 1454
REJ09B0498-0200
Section 2 CPU
2.5.5
Vector Base Register (VBR)
VBR is a 32-bit register in which the upper 20 bits are valid. The lower 12 bits of this register are
read as 0s. This register is a base address of the vector area for exception handlings other than a
reset and a CPU address error (extended memory indirect is also out of the target). The initial
value is H'00000000. The VBR contents are changed with the LDC and STC instructions.
2.5.6
Short Address Base Register (SBR)
SBR is a 32-bit register in which the upper 24 bits are valid. The lower eight bits are read as 0s. In
8-bit absolute address addressing mode (@aa:8), this register is used as the upper address. The
initial value is H'FFFFFF00. The SBR contents are changed with the LDC and STC instructions.
2.5.7
Multiply-Accumulate Register (MAC)
MAC is a 64-bit register that stores the results of multiply-and-accumulate operations. It consists
of two 32-bit registers denoted MACH and MACL. The lower 10 bits of MACH are valid; the
upper bits are sign extended. The MAC contents are changed with the MAC, CLRMAC, LDMAC,
and STMAC instructions.
2.5.8
Initial Values of CPU Registers
Reset exception handling loads the start address from the vector table into the PC, clears the T bit
in EXR to 0, and sets the I bits in CCR and EXR to 1. The general registers, MAC, and the other
bits in CCR are not initialized. In particular, the initial value of the stack pointer (ER7) is
undefined. The SP should therefore be initialized using an MOV.L instruction executed
immediately after a reset.
Rev. 2.00 Oct. 21, 2009 Page 45 of 1454
REJ09B0498-0200
Section 2 CPU
2.6
Data Formats
The H8SX 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.6.1
General Register Data Formats
Figure 2.12 shows the data formats in general registers.
1-bit data
RnH
0
7
7 6 5 4 3 2 1 0
Don't care
1-bit data
RnL
Don't care
7
0
7 6 5 4 3 2 1 0
4-bit BCD data
RnH
43
7
Upper
4-bit BCD data
RnL
Byte data
RnH
Byte data
RnL
0
Lower
Don’t care
43
7
0
Lower
0
7
Don't care
MSB
Word data
Upper
Don't care
LSB
7
Rn
0
Don't care
MSB
15
15
LSB
0
MSB
LSB
Longword data
ERn
31
MSB
0
MSB
En
Word data
16 15
En
[Legend]
ERn: General register ER
En:
General register E
Rn:
General register R
RnH: General register RH
0
Rn
RnL: General register RL
MSB: Most significant bit
LSB: Least significant bit
Figure 2.12 General Register Data Formats
Rev. 2.00 Oct. 21, 2009 Page 46 of 1454
REJ09B0498-0200
LSB
LSB
Section 2 CPU
2.6.2
Memory Data Formats
Figure 2.13 shows the data formats in memory.
The H8SX CPU can access word data and longword data which are stored at any addresses in
memory. When word data begins at an odd address or longword data begins at an address other
than a multiple of 4, a bus cycle is divided into two or more accesses. For example, when
longword data begins at an odd address, the bus cycle is divided into byte, word, and byte
accesses. In this case, these accesses are assumed to be individual bus cycles.
However, instructions to be fetched, word and longword data to be accessed during execution of
the stack manipulation, branch table manipulation, block transfer instructions, and MAC
instruction should be located to even addresses.
When SP (ER7) is used as an address register to access the stack, the operand size should be word
size or longword size.
Data Type
Data Format
Address
7
1-bit data
Address L
Byte data
Address L MSB
Word data
7
0
6
5
4
2
1
0
LSB
Address 2M MSB
Address 2M + 1
Longword data
3
LSB
Address 2N MSB
Address 2N + 1
Address 2N + 2
Address 2N + 3
LSB
Figure 2.13 Memory Data Formats
Rev. 2.00 Oct. 21, 2009 Page 47 of 1454
REJ09B0498-0200
Section 2 CPU
2.7
Instruction Set
The H8SX CPU has 87 types of instructions. The instructions are classified by function as shown
in table 2.1. The arithmetic operation, logic operation, shift, and bit manipulation instructions are
called operation instruction in this manual.
Table 2.1
Instruction Classification
Function
Instructions
Data transfer
Block transfer
Arithmetic
operations
Size
Types
MOV
B/W/L
6
MOVFPE, MOVTPE
B
POP, PUSH*1
W/L
LDM, STM
L
MOVA
B/W*
EEPMOV
B
MOVMD
B/W/L
MOVSD
B
2
ADD, ADDX, SUB, SUBX, CMP, NEG, INC, DEC
B/W/L
DAA, DAS
B
ADDS, SUBS
L
MULXU, DIVXU, MULXS, DIVXS
B/W
MULU, DIVU, MULS, DIVS
W/L
6
MULU/U* , MULS/U*
6
W/L
TAS
B
MAC*
—
LDMAC*6, STMAC*6
CLRMAC*
27
L
EXTU, EXTS
6
3
6
—
—
Logic operations
AND, OR, XOR, NOT
B/W/L
4
Shift
SHLL, SHLR, SHAL, SHAR, ROTL, ROTR, ROTXL, ROTXR B/W/L
8
Bit manipulation
BSET, BCLR, BNOT, BTST, BAND, BIAND, BOR, BIOR,
BXOR, BIXOR, BLD, BILD, BST, BIST
20
BSET/EQ, BSET/NE, BCLR/EQ, BCLR/NE, BSTZ, BISTZ
B
BFLD, BFST
B
Rev. 2.00 Oct. 21, 2009 Page 48 of 1454
REJ09B0498-0200
B
Section 2 CPU
Function
Branch
Instructions
BRA/BS, BRA/BC, BSR/BS, BSR/BC
4
System control
Size
B*
3
Bcc* , JMP, BSR, JSR, RTS
—
RTS/L
L*5
BRA/S
—
TRAPA, RTE, SLEEP, NOP
—
Types
9
10
5
RTE/L
L*
LDC, STC, ANDC, ORC, XORC
B/W/L
Total
87
[Legend]
B:
Byte size
W:
Word size
L:
Longword size
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. Size of data to be added with a displacement
3. Size of data to specify a branch condition
4. Bcc is the generic designation of a conditional branch instruction.
5. Size of general register to be restored
6. Only when the multiplier is available.
Rev. 2.00 Oct. 21, 2009 Page 49 of 1454
REJ09B0498-0200
Section 2 CPU
2.7.1
Instructions and Addressing Modes
Table 2.2 indicates the combinations of instructions and addressing modes that the H8SX CPU can
use.
Table 2.2
Combinations of Instructions and Addressing Modes (1)
Addressing Mode
Classification
Data
transfer
Instruction
Size
#xx
Rn
@(d,
RnL.B/
Rn.W/
@ERn @(d,ERn) ERn.L)
MOV
B/W/L
S
SD
SD
Arithmetic
operations
SD
SD
SD
B
S/D
MOVFPE,
MOVTPE
B
S/D
POP, PUSH
W/L
S/D
S/D*
2
LDM, STM
L
S/D
S/D*
2
B/W
S
MOVA*
Block
transfer
SD
@−ERn/
@ERn+/
@ERn−/
@aa:16/
@+ERn @aa:8 @aa:32 —
4
S/D
S/D*
S
S
S
S
1
S
EEPMOV
B
SD*
3
MOVMD
B/W/L
SD*
3
MOVSD
B
SD*
3
ADD, CMP
B
S
D
D
D
D
D
D
B
S
D
D
D
D
D
D
B
D
S
S
S
S
S
S
SD
SD
SD
SD
SD
SD
SD
SD
SD
SD
SD
B
SUB
D
W/L
S
B
S
D
D
D
D
D
B
S
D
D
D
D
D
D
B
D
S
S
S
S
S
S
SD
SD
SD
SD
SD
S
SD
SD
SD
SD
SD
SD
ADDX, SUBX B/W/L
S
SD
B/W/L
S
B/W/L
S
B
W/L
INC, DEC
B/W/L
SD
SD*
D
ADDS, SUBS L
D
DAA, DAS
B
D
MULXU,
DIVXU
B/W
S:4
SD
MULU, DIVU W/L
S:4
SD
Rev. 2.00 Oct. 21, 2009 Page 50 of 1454
REJ09B0498-0200
5
D
Section 2 CPU
Addressing Mode
@(d,
RnL.B/
Rn.W/
@ERn @(d,ERn) ERn.L)
@−ERn/
@ERn+/
@ERn−/
@aa:16/
@+ERn @aa:8 @aa:32 —
Classification
Instruction
Size
#xx
Rn
Arithmetic
operations
MULXS,
DIVXS
B/W
S:4
SD
MULS, DIVS
W/L
S:4
SD
NEG
B
D
D
D
D
D
W/L
D
D
D
D
D
D
EXTU, EXTS
W/L
D
D
D
D
D
D
TAS
B
MAC*
12
D
12
—
O
12
—
S
12
—
D
LDMAC*
Logic
operations
AND, OR, XOR B
S
D
D
D
D
D
D
B
D
S
S
S
S
S
S
SD
SD
SD
SD
SD
SD
SD
SD
SD
SD
SD
B
W/L
NOT
Shift
SHLL, SHLR
S
B
D
D
D
D
D
W/L
D
D
D
D
D
B
W/L*
5
B/W/L*
Bit
manipulation
D
—
CLRMAC*
STMAC*
D
7
D
D
D
D
D
D
D
D
D
D
D
D
D
D
D
D
D
SHAL, SHAR
ROTL, ROTR
ROTXL,
ROTXR
B
D
D
D
D
D
W/L
D
D
D
D
D
BSET, BCLR,
BNOT, BTST,
BSET/cc,
BCLR/cc
B
D
D
D
D
BAND, BIAND, B
BOR, BIOR,
BXOR, BIXOR,
BLD, BILD,
BST, BIST,
BSTZ, BISTZ
D
D
D
D
D
D
D
Rev. 2.00 Oct. 21, 2009 Page 51 of 1454
REJ09B0498-0200
Section 2 CPU
Addressing Mode
Rn
@(d,
RnL.B/
Rn.W/
@ERn @(d,ERn) ERn.L)
Bit
manipulation
BFLD
B
D
S
S
S
BFST
B
S
D
D
D
Branch
BRA/BS, BRA/BC*
8
B
S
S
S
BSR/BS, BSR/BC*
8
B
S
S
S
Classification
Instruction
System
control
Size
#xx
9
@−ERn/
@ERn+/
@ERn−/
@aa:16/
@+ERn @aa:8 @aa:32 —
10
S
11
D
LDC
(CCR, EXR)
B/W*
LDC
(VBR, SBR)
L
STC
(CCR, EXR)
B/W*
STC
(VBR, SBR)
L
ANDC, ORC,
XORC
B
SLEEP
—
O
NOP
—
O
S
S
S
S
S*
D
D
D*
S
9
D
D
S
[Legend]
d:
d:16 or d:32
S:
Can be specified as a source operand.
D:
Can be specified as a destination operand.
SD:
Can be specified as either a source or destination operand or both.
S/D:
Can be specified as either a source or destination operand.
S:4:
4-bit immediate data can be specified as a source operand.
Notes: 1. Only @aa:16 is available.
2. @ERn+ as a source operand and @−ERn as a destination operand
3. Specified by ER5 as a source address and ER6 as a destination address for data
transfer.
4. Size of data to be added with a displacement
5. Only @ERn− is available
6. When the number of bits to be shifted is 1, 2, 4, 8, or 16
7. When the number of bits to be shifted is specified by 5-bit immediate data or a general
register
8. Size of data to specify a branch condition
9. Byte when immediate or register direct, otherwise, word
10. Only @ERn+ is available
11. Only @−ERn is available
12. Only when the multiplier is available.
Rev. 2.00 Oct. 21, 2009 Page 52 of 1454
REJ09B0498-0200
Section 2 CPU
Table 2.2
Combinations of Instructions and Addressing Modes (2)
Addressing Mode
@(RnL.B/R
Classification
Instruction
Size
Branch
BRA/BS,
BRA/BC
—
O
BSR/BS,
BSR/BC
—
O
Bcc
—
O
BRA
—
O
BRA/S
—
O*
JMP
—
BSR
—
JSR
—
System
control
n.W/
@ERn
@(d,PC)
O
ERn.L, PC) @aa:24 @aa:32 @@ aa:8
@@vec:7
—
O
O
O
O
O
O
O
O
O
O
O
RTS, RTS/L
—
O
TRAPA
—
O
RTE, RTE/L
—
O
[Legend]
d:
d:8 or d:16
Note: * Only @(d:8, PC) is available.
Rev. 2.00 Oct. 21, 2009 Page 53 of 1454
REJ09B0498-0200
Section 2 CPU
2.7.2
Table of Instructions Classified by Function
Tables 2.4 to 2.11 summarize the instructions in each functional category. The notation used in
these tables is defined in table 2.3.
Table 2.3
Operation Notation
Operation Notation
Description
Rd
Rs
Rn
ERn
(EAd)
(EAs)
EXR
CCR
VBR
General register (destination)*
General register (source)*
General register*
General register (32-bit register)
Destination operand
Source operand
Extended control register
Condition-code register
Vector base register
SBR
N
Z
V
C
PC
SP
#IMM
disp
+
−
×
÷
∧
∨
⊕
→
Short address base register
N (negative) flag in CCR
Z (zero) flag in CCR
V (overflow) flag in CCR
C (carry) flag in CCR
Program counter
Stack pointer
Immediate data
Displacement
Addition
Subtraction
Multiplication
Division
Logical AND
Logical OR
Logical exclusive OR
Move
∼
:8/:16/:24/:32
Logical not (logical complement)
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).
Rev. 2.00 Oct. 21, 2009 Page 54 of 1454
REJ09B0498-0200
Section 2 CPU
Table 2.4
Data Transfer Instructions
Instruction
Size
Function
MOV
B/W/L
#IMM → (EAd), (EAs) → (EAd)
Transfers data between immediate data, general registers, and memory.
MOVFPE
B
(EAs) → Rd
MOVTPE
B
Rs → (EAs)
POP
W/L
@SP+ → Rn
Restores the data from the stack to a general register.
PUSH
W/L
Rn → @−SP
Saves general register contents on the stack.
LDM
L
@SP+ → Rn (register list)
Restores the data from the stack to multiple general registers. Two, three,
or four general registers which have serial register numbers can be
specified.
STM
L
Rn (register list) → @−SP
Saves the contents of multiple general registers on the stack. Two, three,
or four general registers which have serial register numbers can be
specified.
MOVA
B/W
EA → Rd
Zero-extends and shifts the contents of a specified general register or
memory data and adds them with a displacement. The result is stored in a
general register.
Rev. 2.00 Oct. 21, 2009 Page 55 of 1454
REJ09B0498-0200
Section 2 CPU
Table 2.5
Block Transfer Instructions
Instruction
Size
EEPMOV.B
EEPMOV.W
B
MOVMD.B
B
Function
Transfers a data block.
Transfers byte data which begins at a memory location specified by ER5
to a memory location specified by ER6. The number of byte data to be
transferred is specified by R4 or R4L.
Transfers a data block.
Transfers byte data which begins at a memory location specified by ER5
to a memory location specified by ER6. The number of byte data to be
transferred is specified by R4.
MOVMD.W
W
Transfers a data block.
Transfers word data which begins at a memory location specified by ER5
to a memory location specified by ER6. The number of word data to be
transferred is specified by R4.
MOVMD.L
L
Transfers a data block.
Transfers longword data which begins at a memory location specified by
ER5 to a memory location specified by ER6. The number of longword
data to be transferred is specified by R4.
MOVSD.B
B
Transfers a data block with zero data detection.
Transfers byte data which begins at a memory location specified by ER5
to a memory location specified by ER6. The number of byte data to be
transferred is specified by R4. When zero data is detected during transfer,
the transfer stops and execution branches to a specified address.
Rev. 2.00 Oct. 21, 2009 Page 56 of 1454
REJ09B0498-0200
Section 2 CPU
Table 2.6
Arithmetic Operation Instructions
Instruction
Size
Function
ADD
SUB
B/W/L
ADDX
SUBX
B/W/L
INC
DEC
B/W/L
ADDS
SUBS
DAA
DAS
L
MULXU
B/W
MULU
W/L
MULU/U*
L
MULXS
B/W
MULS
W/L
MULS/U*
L
DIVXU
B/W
(EAd) ± #IMM → (EAd), (EAd) ± (EAs) → (EAd)
Performs addition or subtraction on data between immediate data,
general registers, and memory. Immediate byte data cannot be
subtracted from byte data in a general register.
(EAd) ± #IMM ± C → (EAd), (EAd) ± (EAs) ± C → (EAd)
Performs addition or subtraction with carry on data between immediate
data, general registers, and memory. The addressing mode which
specifies a memory location can be specified as register indirect with
post-decrement or register indirect.
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.)
Rd ± 1 → Rd, Rd ± 2 → Rd, Rd ± 4 → Rd
Adds or subtracts the value 1, 2, or 4 to or from data in a general register.
Rd (decimal adjust) → Rd
Decimal-adjusts an addition or subtraction result in a general register by
referring to the CCR to produce 2-digit 4-bit BCD data.
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.
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.
Rd × Rs → Rd
Performs unsigned multiplication on data in two general registers (32 bits
× 32 bits → upper 32 bits).
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.
Rd × Rs → Rd
Performs signed multiplication on data in two general registers: either 16
bits × 16 bits → 16 bits, or 32 bits × 32 bits → 32 bits.
Rd × Rs → Rd
Performs signed multiplication on data in two general registers (32 bits ×
32 bits → upper 32 bits).
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.
B
Rev. 2.00 Oct. 21, 2009 Page 57 of 1454
REJ09B0498-0200
Section 2 CPU
Instruction
Size
Function
DIVU
W/L
DIVXS
B/W
DIVS
W/L
CMP
B/W/L
NEG
B/W/L
EXTU
W/L
EXTS
W/L
Rd ÷ Rs → Rd
Performs unsigned division on data in two general registers: either 16 bits
÷ 16 bits → 16-bit quotient, or 32 bits ÷ 32 bits → 32-bit quotient.
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 → 16-bit
quotient and 16-bit remainder.
Rd ÷ Rs → Rd
Performs signed division on data in two general registers: either 16 bits ÷
16 bits → 16-bit quotient, or 32 bits ÷ 32 bits → 32-bit quotient.
(EAd) − #IMM, (EAd) − (EAs)
Compares data between immediate data, general registers, and memory
and stores the result in CCR.
0 − (EAd) → (EAd)
Takes the two's complement (arithmetic complement) of data in a general
register or the contents of a memory location.
(EAd) (zero extension) → (EAd)
Performs zero-extension on the lower 8 or 16 bits of data in a general
register or memory to word or longword size.
The lower 8 bits to word or longword, or the lower 16 bits to longword can
be zero-extended.
(EAd) (sign extension) → (EAd)
Performs sign-extension on the lower 8 or 16 bits of data in a general
register or memory to word or longword size.
The lower 8 bits to word or longword, or the lower 16 bits to longword can
be sign-extended.
TAS
B
MAC*
—
CLRMAC*
—
LDMAC*
—
STMAC*
—
@ERd − 0, 1 → ( of @EAd)
Tests memory contents, and sets the most significant bit (bit 7) to 1.
(EAs) × (EAd) + MAC → MAC
Performs signed multiplication on memory contents and adds the result to
MAC.
0 → MAC
Clears MAC to zero.
Rs → MAC
Loads data from a general register to MAC.
MAC → Rd
Stores data from MAC to a general register.
Note: * Only when the multiplier is available.
Rev. 2.00 Oct. 21, 2009 Page 58 of 1454
REJ09B0498-0200
Section 2 CPU
Table 2.7
Logic Operation Instructions
Instruction
Size
Function
AND
B/W/L
(EAd) ∧ #IMM → (EAd), (EAd) ∧ (EAs) → (EAd)
Performs a logical AND operation on data between immediate data,
general registers, and memory.
OR
B/W/L
(EAd) ∨ #IMM → (EAd), (EAd) ∨ (EAs) → (EAd)
Performs a logical OR operation on data between immediate data,
general registers, and memory.
XOR
B/W/L
(EAd) ⊕ #IMM → (EAd), (EAd) ⊕ (EAs) → (EAd)
Performs a logical exclusive OR operation on data between immediate
data, general registers, and memory.
NOT
B/W/L
∼ (EAd) → (EAd)
Takes the one's complement of the contents of a general register or a
memory location.
Table 2.8
Shift Operation Instructions
Instruction
Size
Function
SHLL
B/W/L
(EAd) (shift) → (EAd)
SHLR
Performs a logical shift on the contents of a general register or a memory
location.
The contents of a general register or a memory location can be shifted by
1, 2, 4, 8, or 16 bits. The contents of a general register can be shifted by
any bits. In this case, the number of bits is specified by 5-bit immediate
data or the lower 5 bits of the contents of a general register.
SHAL
B/W/L
SHAR
(EAd) (shift) → (EAd)
Performs an arithmetic shift on the contents of a general register or a
memory location.
1-bit or 2-bit shift is possible.
ROTL
B/W/L
ROTR
(EAd) (rotate) → (EAd)
Rotates the contents of a general register or a memory location.
1-bit or 2-bit rotation is possible.
ROTXL
ROTXR
B/W/L
(EAd) (rotate) → (EAd)
Rotates the contents of a general register or a memory location with the
carry bit.
1-bit or 2-bit rotation is possible.
Rev. 2.00 Oct. 21, 2009 Page 59 of 1454
REJ09B0498-0200
Section 2 CPU
Table 2.9
Bit Manipulation Instructions
Instruction
Size
Function
BSET
B
BSET/cc
B
BCLR
B
1 → ( of )
Sets a specified bit in the contents of a general register or a memory
location to 1. The bit number is specified by 3-bit immediate data or the
lower three bits of a general register.
if cc, 1 → ( of )
If the specified condition is satisfied, this instruction sets a specified bit in
a memory location to 1. The bit number can be specified by 3-bit
immediate data, or by the lower three bits of a general register. The Z flag
status can be specified as a condition.
0 → ( of )
Clears a specified bit in the contents of a general register or a memory
location to 0. The bit number is specified by 3-bit immediate data or the
lower three bits of a general register.
BCLR/cc
B
BNOT
B
BTST
B
BAND
B
BIAND
B
BOR
B
if cc, 0 → ( of )
If the specified condition is satisfied, this instruction clears a specified bit
in a memory location to 0. The bit number can be specified by 3-bit
immediate data, or by the lower three bits of a general register. The Z flag
status can be specified as a condition.
∼ ( of ) → ( of )
Inverts a specified bit in the contents of a general register or a memory
location. The bit number is specified by 3-bit immediate data or the lower
three bits of a general register.
∼ ( of ) → Z
Tests a specified bit in the contents of a general register or a memory
location 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.
C ∧ ( of ) → C
ANDs the carry flag with a specified bit in the contents of a general
register or a memory location and stores the result in the carry flag. The
bit number is specified by 3-bit immediate data.
C ∧ [∼ ( of )] → C
ANDs the carry flag with the inverse of a specified bit in the contents of a
general register or a memory location and stores the result in the carry
flag. The bit number is specified by 3-bit immediate data.
C ∨ ( of ) → C
ORs the carry flag with a specified bit in the contents of a general register
or a memory location and stores the result in the carry flag. The bit
number is specified by 3-bit immediate data.
Rev. 2.00 Oct. 21, 2009 Page 60 of 1454
REJ09B0498-0200
Section 2 CPU
Instruction
Size
Function
BIOR
B
C ∨ [~ ( of )] → C
ORs the carry flag with the inverse of a specified bit in the contents of a
general register or a memory location and stores the result in the carry
flag. The bit number is specified by 3-bit immediate data.
BXOR
B
C ⊕ ( of ) → C
Exclusive-ORs the carry flag with a specified bit in the contents of a
general register or a memory location and stores the result in the carry
flag. The bit number is specified by 3-bit immediate data.
BIXOR
B
C ⊕ [~ ( of )] → C
Exclusive-ORs the carry flag with the inverse of a specified bit in the
contents of a general register or a memory location and stores the result
in the carry flag. The bit number is specified by 3-bit immediate data.
BLD
B
( of ) → C
Transfers a specified bit in the contents of a general register or a memory
location to the carry flag. The bit number is specified by 3-bit immediate
data.
BILD
B
~ ( of ) → C
Transfers the inverse of a specified bit in the contents of a general
register or a memory location to the carry flag. The bit number is specified
by 3-bit immediate data.
BST
B
C → ( of )
Transfers the carry flag value to a specified bit in the contents of a
general register or a memory location. The bit number is specified by 3-bit
immediate data.
BSTZ
B
Z → ( of )
Transfers the zero flag value to a specified bit in the contents of a
memory location. The bit number is specified by 3-bit immediate data.
BIST
B
∼ C → ( of )
Transfers the inverse of the carry flag value to a specified bit in the
contents of a general register or a memory location. The bit number is
specified by 3-bit immediate data.
Rev. 2.00 Oct. 21, 2009 Page 61 of 1454
REJ09B0498-0200
Section 2 CPU
Instruction
Size
Function
BISTZ
B
∼ Z → ( of )
Transfers the inverse of the zero flag value to a specified bit in the
contents of a memory location. The bit number is specified by 3-bit
immediate data.
BFLD
B
(EAs) (bit field) → Rd
Transfers a specified bit field in memory location contents to the lower bits
of a specified general register.
BFST
B
Rs → (EAd) (bit field)
Transfers the lower bits of a specified general register to a specified bit
field in memory location contents.
Table 2.10 Branch Instructions
Instruction
Size
Function
BRA/BS
B
Tests a specified bit in memory location contents. If the specified
condition is satisfied, execution branches to a specified address.
B
Tests a specified bit in memory location contents. If the specified
condition is satisfied, execution branches to a subroutine at a specified
address.
Bcc
—
Branches to a specified address if the specified condition is satisfied.
BRA/S
—
Branches unconditionally to a specified address after executing the next
instruction. The next instruction should be a 1-word instruction except for
the block transfer and branch instructions.
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.
RTS/L
—
Returns from a subroutine, restoring data from the stack to multiple
general registers.
BRA/BC
BSR/BS
BSR/BC
Rev. 2.00 Oct. 21, 2009 Page 62 of 1454
REJ09B0498-0200
Section 2 CPU
Table 2.11 System Control Instructions
Instruction
Size
Function
TRAPA
—
Starts trap-instruction exception handling.
RTE
—
Returns from an exception-handling routine.
RTE/L
—
Returns from an exception-handling routine, restoring data from the stack
to multiple general registers.
SLEEP
—
Causes a transition to a power-down state.
LDC
B/W
#IMM → CCR, (EAs) → CCR, #IMM → EXR, (EAs) → EXR
Loads immediate data or the contents of a general register or a memory
location 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.
L
Rs → VBR, Rs → SBR
Transfers the general register contents to VBR or SBR.
STC
B/W
CCR → (EAd), EXR → (EAd)
Transfers the contents of CCR or EXR 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.
L
VBR → Rd, SBR → Rd
Transfers the contents of VBR or SBR to a general register.
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 exclusive-ORs the CCR or EXR contents with immediate data.
NOP
—
PC + 2 → PC
Only increments the program counter.
Rev. 2.00 Oct. 21, 2009 Page 63 of 1454
REJ09B0498-0200
Section 2 CPU
2.7.3
Basic Instruction Formats
The H8SX CPU 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.14 shows examples of instruction formats.
(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.14 Instruction Formats
• Operation Field
Indicates the function of the instruction, and specifies the addressing mode and 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, 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 branch condition of Bcc instructions.
Rev. 2.00 Oct. 21, 2009 Page 64 of 1454
REJ09B0498-0200
Section 2 CPU
2.8
Addressing Modes and Effective Address Calculation
The H8SX CPU supports the 11 addressing modes listed in table 2.12. Each instruction uses a
subset of these addressing modes.
Bit manipulation instructions use register direct, register indirect, or 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.
Table 2.12 Addressing Modes
No. Addressing Mode
Symbol
1
Register direct
Rn
2
Register indirect
@ERn
3
Register indirect with displacement
@(d:2,ERn)/@(d:16,ERn)/@(d:32,ERn)
4
Index register indirect with displacement
@(d:16, RnL.B)/@(d:16,Rn.W)/@(d:16,ERn.L)
@(d:32, RnL.B)/@(d:32,Rn.W)/@(d:32,ERn.L)
5
Register indirect with post-increment
@ERn+
Register indirect with pre-decrement
@–ERn
Register indirect with pre-increment
@+ERn
Register indirect with post-decrement
@ERn–
6
Absolute address
@aa:8/@aa:16/@aa:24/@aa:32
7
Immediate
#xx:3/#xx:4/#xx:8/#xx:16/#xx:32
8
Program-counter relative
@(d:8,PC)/@(d:16,PC)
9
Program-counter relative with index register
@(RnL.B,PC)/@(Rn.W,PC)/@(ERn.L,PC)
10
Memory indirect
@@aa:8
11
Extended memory indirect
@@vec:7
2.8.1
Register Direct—Rn
The operand value is the contents of an 8-, 16-, or 32-bit general register which is specified by the
register field in the instruction code.
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.
Rev. 2.00 Oct. 21, 2009 Page 65 of 1454
REJ09B0498-0200
Section 2 CPU
2.8.2
Register Indirect—@ERn
The operand value is the contents of the memory location which is pointed to by the contents of an
address register (ERn). ERn is specified by the register field of the instruction code.
In advanced mode, if this addressing mode is used in a branch instruction, the lower 24 bits are
valid and the upper 8 bits are all assumed to be 0 (H'00).
2.8.3
Register Indirect with Displacement—@(d:2, ERn), @(d:16, ERn),
or @(d:32, ERn)
The operand value is the contents of a memory location which is pointed to by the sum of the
contents of an address register (ERn) and a 16- or 32-bit displacement. ERn is specified by the
register field of the instruction code. The displacement is included in the instruction code and the
16-bit displacement is sign-extended when added to ERn.
This addressing mode has a short format (@(d:2, ERn)). The short format can be used when the
displacement is 1, 2, or 3 and the operand is byte data, when the displacement is 2, 4, or 6 and the
operand is word data, or when the displacement is 4, 8, or 12 and the operand is longword data.
2.8.4
Index Register Indirect with Displacement—@(d:16,RnL.B), @(d:32,RnL.B),
@(d:16,Rn.W), @(d:32,Rn.W), @(d:16,ERn.L), or @(d:32,ERn.L)
The operand value is the contents of a memory location which is pointed to by the sum of the
following operation result and a 16- or 32-bit displacement: a specified bits of the contents of an
address register (RnL, Rn, ERn) specified by the register field in the instruction code are zeroextended to 32-bit data and multiplied by 1, 2, or 4. The displacement is included in the instruction
code and the 16-bit displacement is sign-extended when added to ERn. If the operand is byte data,
ERn is multiplied by 1. If the operand is word or longword data, ERn is multiplied by 2 or 4,
respectively.
Rev. 2.00 Oct. 21, 2009 Page 66 of 1454
REJ09B0498-0200
Section 2 CPU
2.8.5
Register Indirect with Post-Increment, Pre-Decrement, Pre-Increment,
or Post-Decrement—@ERn+, @−ERn, @+ERn, or @ERn−
• Register indirect with post-increment—@ERn+
The operand value is the contents of a memory location which is pointed to by the contents of
an address register (ERn). ERn is specified by the register field of the instruction code. After
the memory location 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 access, or
4 for longword access.
• Register indirect with pre-decrement—@−ERn
The operand value is the contents of a memory location which is pointed to by the following
operation result: the value 1, 2, or 4 is subtracted from the contents of an address register
(ERn). ERn is specified by the register field of the instruction code. After that, the operand
value is stored in the address register. The value subtracted is 1 for byte access, 2 for word
access, or 4 for longword access.
• Register indirect with pre-increment—@+ERn
The operand value is the contents of a memory location which is pointed to by the following
operation result: the value 1, 2, or 4 is added to the contents of an address register (ERn). ERn
is specified by the register field of the instruction code. After that, the operand value is stored
in the address register. The value added is 1 for byte access, 2 for word access, or 4 for
longword access.
• Register indirect with post-decrement—@ERn−
The operand value is the contents of a memory location which is pointed to by the contents of
an address register (ERn). ERn is specified by the register field of the instruction code. After
the memory location is accessed, 1, 2, or 4 is subtracted from the address register contents and
the remainder is stored in the address register. The value subtracted is 1 for byte access, 2 for
word access, or 4 for longword access.
using this addressing mode, data to be written is the contents of the general register after
calculating an effective address. If the same general register is specified in an instruction and two
effective addresses are calculated, the contents of the general register after the first calculation of
an effective address is used in the second calculation of an effective address.
Example 1:
MOV.W
R0, @ER0+
When ER0 before execution is H'12345678, H'567A is written at H'12345678.
Rev. 2.00 Oct. 21, 2009 Page 67 of 1454
REJ09B0498-0200
Section 2 CPU
Example 2:
MOV.B @ER0+, @ER0+
When ER0 before execution is H'00001000, H'00001000 is read and the contents are written at
H'00001001.
After execution, ER0 is H'00001002.
2.8.6
Absolute Address—@aa:8, @aa:16, @aa:24, or @aa:32
The operand value is the contents of a memory location which is pointed to by an absolute address
included in the instruction code.
There are 8-bit (@aa:8), 16-bit (@aa:16), 24-bit (@aa:24), and 32-bit (@aa:32) absolute
addresses.
To access the data area, the absolute address of 8 bits (@aa:8), 16 bits (@aa:16), or 32 bits
(@aa:32) is used. For an 8-bit absolute address, the upper 24 bits are specified by SBR. For a 16bit absolute address, the upper 16 bits are sign-extended. A 32-bit absolute address can access the
entire address space.
To access the program area, the absolute address of 24 bits (@aa:24) or 32 bits (@aa:32) is used.
For a 24-bit absolute address, the upper 8 bits are all assumed to be 0 (H'00).
Table 2.13 shows the accessible absolute address ranges.
Table 2.13 Absolute Address Access Ranges
Absolute
Address
Data area
Normal
Mode
Middle
Mode
Advanced
Mode
Maximum
Mode
8 bits
(@aa:8)
A consecutive 256-byte area (the upper address is set in SBR)
16 bits
(@aa:16)
H'0000 to
H'FFFF
H'000000 to
H'007FFF,
H'00000000 to H'00007FFF,
H'FFFF8000 to H'FFFFFFFF
32 bits
(@aa:32)
H'FF8000 to
H'FFFFFF
H'00000000 to H'FFFFFFFF
Program area 24 bits
(@aa:24)
H'000000 to
H'FFFFFF
H'00000000 to H'00FFFFFF
32 bits
(@aa:32)
Rev. 2.00 Oct. 21, 2009 Page 68 of 1454
REJ09B0498-0200
H'00000000 to
H'00FFFFFF
H'00000000 to
H'FFFFFFFF
Section 2 CPU
2.8.7
Immediate—#xx
The operand value is 8-bit (#xx:8), 16-bit (#xx:16), or 32-bit (#xx:32) data included in the
instruction code.
This addressing mode has short formats in which 3- or 4-bit immediate data can be used.
When the size of immediate data is less than that of the destination operand value (byte, word, or
longword) the immediate data is zero-extended.
The ADDS, SUBS, INC, and DEC instructions contain immediate data implicitly. Some bit
manipulation instructions contain 3-bit immediate data in the instruction code, for specifying a bit
number. The BFLD and BFST instructions contain 8-bit immediate data in the instruction code,
for specifying a bit field. The TRAPA instruction contains 2-bit immediate data in the instruction
code, for specifying a vector address.
2.8.8
Program-Counter Relative—@(d:8, PC) or @(d:16, PC)
This mode is used in the Bcc and BSR instructions. The operand value is a 32-bit branch address,
which is the sum of an 8- or 16-bit displacement in the instruction code and the 32-bit address of
the PC contents. The 8-bit or 16-bit displacement is sign-extended to 32 bits when added to the PC
contents. The PC contents 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. In advanced mode, only the lower 24 bits of this branch address
are valid; the upper 8 bits are all assumed to be 0 (H'00).
2.8.9
Program-Counter Relative with Index Register—@(RnL.B, PC), @(Rn.W, PC),
or @(ERn.L, PC)
This mode is used in the Bcc and BSR instructions. The operand value is a 32-bit branch address,
which is the sum of the following operation result and the 32-bit address of the PC contents: the
contents of an address register specified by the register field in the instruction code (RnL, Rn, or
ERn) is zero-extended and multiplied by 2. The PC contents to which the displacement is added is
the address of the first byte of the next instruction. In advanced mode, only the lower 24 bits of
this branch address are valid; the upper 8 bits are all assumed to be 0 (H'00).
Rev. 2.00 Oct. 21, 2009 Page 69 of 1454
REJ09B0498-0200
Section 2 CPU
2.8.10
Memory Indirect—@@aa:8
This mode can be used by the JMP and JSR instructions. The operand value is a branch address,
which is the contents of a memory location pointed to by an 8-bit absolute address in the
instruction code.
The upper bits of an 8-bit 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 other modes).
In normal mode, the memory location is pointed to by word-size data and the branch address is 16
bits long. In other modes, the memory location is pointed to by longword-size data. In middle or
advanced mode, the first byte of the longword-size data is assumed to be all 0 (H'00).
Note that the top part of the address range is also used as the exception handling vector area. A
vector address of an exception handling other than a reset or a CPU address error can be changed
by VBR.
Figure 2.15 shows an example of specification of a branch address using this addressing mode.
Specified
by @aa:8
Branch address
Specified
by @aa:8
Reserved
Branch address
(a) Normal Mode
(b) Advanced Mode
Figure 2.15 Branch Address Specification in Memory Indirect Mode
Rev. 2.00 Oct. 21, 2009 Page 70 of 1454
REJ09B0498-0200
Section 2 CPU
2.8.11
Extended Memory Indirect—@@vec:7
This mode can be used by the JMP and JSR instructions. The operand value is a branch address,
which is the contents of a memory location pointed to by the following operation result: the sum
of 7-bit data in the instruction code and the value of H'80 is multiplied by 2 or 4.
The address range to store a branch address is H'0100 to H'01FF in normal mode and H'000200 to
H'0003FF in other modes. In assembler notation, an address to store a branch address is specified.
In normal mode, the memory location is pointed to by word-size data and the branch address is 16
bits long. In other modes, the memory location is pointed to by longword-size data. In middle or
advanced mode, the first byte of the longword-size data is assumed to be all 0 (H'00).
2.8.12
Effective Address Calculation
Tables 2.14 and 2.15 show how effective addresses are calculated in each addressing mode. The
lower bits of the effective address are valid and the upper bits are ignored (zero extended or sign
extended) according to the CPU operating mode.
The valid bits in middle mode are as follows:
• The lower 16 bits of the effective address are valid and the upper 16 bits are sign-extended for
the transfer and operation instructions.
• The lower 24 bits of the effective address are valid and the upper eight bits are zero-extended
for the branch instructions.
Rev. 2.00 Oct. 21, 2009 Page 71 of 1454
REJ09B0498-0200
Section 2 CPU
Table 2.14 Effective Address Calculation for Transfer and Operation Instructions
No.
1
Addressing Mode and Instruction Format
Effective Address Calculation
Effective Address (EA)
Immediate
op
IMM
2
Register direct
3
Register indirect
op
rm
rn
31
0
31
0
31
0
31
0
31
0
31
0
31
0
31
0
0
31
0
0
31
0
0
31
0
General register contents
op
4
r
Register indirect with 16-bit displacement
31
0
General register contents
r
op
31
15
Register indirect with 32-bit displacement
+
0
disp
Sign extension
disp
31
0
General register contents
op
disp
5
Index register indirect with 16-bit displacement
r
op
disp
31
0
Zero extension
Contents of general register (RL, R, or ER) 1, 2, or 4
31
disp
r
op
15
0
Zero extension
Contents of general register (RL, R, or ER) 1, 2, or 4
0
disp
×
+
disp
31
0
General register contents
op
+
31
31
Register indirect with post-increment or post-decrement
×
0
disp
Sign extension
Index register indirect with 32-bit displacement
6
+
r
±
r
1, 2, or 4
Register indirect with pre-increment or pre-decrement
31
0
General register contents
±
r
op
1, 2, or 4
7
8-bit absolute address
31
op
aa
7
aa
SBR
16-bit absolute address
op
31
aa
15
aa
Sign extension
32-bit absolute address
op
31
aa
Rev. 2.00 Oct. 21, 2009 Page 72 of 1454
REJ09B0498-0200
aa
Section 2 CPU
Table 2.15 Effective Address Calculation for Branch Instructions
No.
1
Addressing Mode and Instruction Format
Register indirect
Effective Address Calculation
Effective Address (EA)
31
31
0
31
0
31
0
31
0
0
31
0
0
31
0
31
0
31
0
0
General register contents
r
op
2
Program-counter relative with 8-bit displacement
31
0
PC contents
31
op
7
Sign extension
disp
+
0
disp
Program-counter relative with 16-bit displacement
31
0
PC contents
31
op
disp
3
15
Program-counter relative with index register
disp
31
0
Zero extension
Contents of general register (RL, R, or ER)
op
+
0
Sign extension
r
2
×
+
0
31
PC contents
4
24-bit absolute address
Zero
31 extension 23
op
aa
aa
32-bit absolute address
op
31
aa
aa
5
Memory indirect
31
op
aa
0
7
aa
Zero extension
0
31
Memory contents
6
Extended memory indirect
31
op
vec
Zero extension
7
1
0
vec
2 or 4
31
×
0
31
0
Memory contents
2.8.13
MOVA Instruction
The MOVA instruction stores the effective address in a general register.
1. Firstly, data is obtained by the addressing mode shown in item 2 of table 2.14.
2. Next, the effective address is calculated using the obtained data as the index by the addressing
mode shown in item 5 of table 2.14. The obtained data is used instead of the general register.
The result is stored in a general register. For details, see H8SX Family Software Manual.
Rev. 2.00 Oct. 21, 2009 Page 73 of 1454
REJ09B0498-0200
Section 2 CPU
2.9
Processing States
The H8SX CPU has five main processing states: the reset state, exception-handling state, program
execution state, bus-released state, and program stop state. Figure 2.16 indicates the state
transitions.
• Reset state
In this state the CPU and internal peripheral modules are all initialized and stopped. 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 6, Exception Handling.
The reset state can also be entered by a watchdog timer overflow when available.
• Exception-handling state
The exception-handling state is a transient state that occurs when the CPU alters the normal
processing flow due to activation of an exception source, such as, a reset, trace, interrupt, or
trap instruction. The CPU fetches a start address (vector) from the exception handling vector
table and branches to that address. For further details, see section 6, Exception Handling.
• Program execution state
In this state the CPU executes program instructions in sequence.
• Bus-released state
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.
• Program stop 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 details,
see section 28, Power-Down Modes.
Rev. 2.00 Oct. 21, 2009 Page 74 of 1454
REJ09B0498-0200
Section 2 CPU
Reset state*
RES = high
Exception-handling
state
Request for exception
handling
Interrupt
request
End of exception
handling
Program execution
state
Note:
STBY = High,
RES = low
Bus-released state
Bus
request
Bus request
End of bus request
End of
bus request
Program stop state
SLEEP instruction
A transition to the reset state occurs whenever the STBY signal goes low.
* A transition to the reset state occurs when the RES signal goes low in all states
except hardware standby mode. A transition can also be made to the reset state
when the watchdog timer overflows.
Figure 2.16 State Transitions
Rev. 2.00 Oct. 21, 2009 Page 75 of 1454
REJ09B0498-0200
Section 2 CPU
Rev. 2.00 Oct. 21, 2009 Page 76 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
Section 3 MCU Operating Modes
3.1
Operating Mode Selection
This LSI has seven operating modes (modes 1, 2, 3, 4, 5, 6, and 7). The operating mode is selected
by the setting of mode pins MD2 to MD0. Enabling and disabling of the SDRAM interface can be
selected with the MD3 setting for each operating mode. Table 3.1 lists MCU operating mode
settings. Table 3.2 shows the SDRAM interface setting for each MCU operating mode
Table 3.1
MCU Operating Mode Settings
MCU
Operating
Mode
MD2
MD1
MD0
1
0
1
0
CPU
Operating
Mode
Advanced
mode
Address
Space
LSI Initiation
Mode
16 Mbytes User boot mode
External Data
Bus Width
On-Chip
ROM
Default Max.
Enabled
⎯
16 bits
Enabled
⎯
⎯
16 bits
2
0
1
0
Boot mode
3
0
1
1
Boundary scan
Enabled
enabled single-chip
mode
4
1
0
0
16 bits
16 bits
1
0
1
On-chip ROM
disabled extended
mode
Disabled
5
Disabled
8 bits
16 bits
6
1
1
0
On-chip ROM
enabled extended
mode
Enabled
8 bits
16 bits
7
1
1
1
Single-chip mode
Enabled
⎯
16 bits
Table 3.2
16 bits
SDRAM Interface Setting for each MCU Operating Mode
MD3
SDRAM Interface
0
Disabled
1
Enabled
In this LSI, an advanced mode as the CPU operating mode and a 16-Mbyte address space are
available. The initial external bus widths are eight or 16 bits. As the LSI initiation mode, the
external extended mode, on-chip ROM initiation mode, or single-chip initiation mode can be
selected.
Rev. 2.00 Oct. 21, 2009 Page 77 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
Modes 1 and 2 are the user boot mode and the boot mode, respectively, in which the flash memory
can be programmed and erased. For details on the user boot mode and boot mode, see section 25,
Flash Memory.
Mode 3 is the boundary scan function enabled single-chip mode. For details on the boundary scan
function, see section 26, Boundary Scan.
Mode 7 is a single-chip initiation mode. All I/O ports can be used as general input/output ports.
The external address space cannot be accessed in the initial state, but setting the EXPE bit in the
system control register (SYSCR) to 1 enables to use the external address space. After the external
address space is enabled, ports D, E, and F can be used as an address output bus and ports H and I
as a data bus by specifying the data direction register (DDR) for each port. When the external
address space is not in use, ports J and K can be used by setting the PCJKE bit in the port function
control register D (PFCRD) to 1.
Modes 4 to 6 are external extended modes, in which the external memory and devices can be
accessed. In the external extended modes, the external address space can be designated as 8-bit or
16-bit address space for each area by the bus controller after starting program execution.
If 16-bit address space is designated for any one area, it is called the 16-bit bus widths mode. If 8bit address space is designated for all areas, it is called the 8-bit bus width mode.
Rev. 2.00 Oct. 21, 2009 Page 78 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
3.2
Register Descriptions
The following registers are related to the operating mode setting.
• Mode control register (MDCR)
• System control register (SYSCR)
3.2.1
Mode Control Register (MDCR)
MDCR indicates the current operating mode. When MDCR is read from, the states of signals
MD3 to MD0 are latched. Latching is released by a reset.
Bit
15
14
13
12
11
10
9
8
MDS7
⎯
⎯
⎯
MDS3
MDS2
MDS1
MDS0
Initial Value Undefined*
1
0
1
Undefined*
Undefined*
Undefined*
Undefined*
R/W
R
R
R
R
R
R
R
R
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Initial Value Undefined*
1
0
1
Undefined*
Undefined*
Undefined*
Undefined*
R/W
R
R
R
R
R
R
R
R
Note: * Determined by pins MD3 to MD0.
Bit
Bit Name
Initial Value R/W
Descriptions
15
MDS7
Undefined*
This pin indicates a value set with the mode pin
(MD3)
R
When MDCR is read, the signal levels input on the
MD3 pin is latched into this bit. This latch is released
by a reset.
14
⎯
1
R
Reserved
13
⎯
0
R
These are read-only bits and cannot be modified.
12
⎯
1
R
Rev. 2.00 Oct. 21, 2009 Page 79 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
Bit
Bit Name
Initial Value R/W
Descriptions
11
MDS3
Undefined*
R
Mode Select 3 to 0
10
MDS2
Undefined*
R
9
MDS1
Undefined*
R
These bits indicate the operating mode selected by
the mode pins (MD2 to MD0) (see table 3.3).
8
MDS0
Undefined*
R
When MDCR is read, the signal levels input on pins
MD2 to MD0 are latched into these bits. These
latches are released by a reset.
7
⎯
Undefined*
R
Reserved
6
⎯
1
R
These are read-only bits and cannot be modified.
5
⎯
0
R
4
⎯
1
R
3
⎯
Undefined*
R
2
⎯
Undefined*
R
1
⎯
Undefined*
R
0
⎯
Undefined*
R
Note:
*
Table 3.3
Determined by pins MD3 to MD0.
Settings of Bits MDS3 to MDS0
Mode Pins
MDCR
MCU Operating
Mode
MD2
MD1
MD0
MDS3
MDS2
MDS1
MDS0
1
0
0
1
1
1
0
1
2
0
1
0
1
1
0
0
3
0
1
1
0
1
0
0
4
1
0
0
0
0
1
0
5
1
0
1
0
0
0
1
6
1
1
0
0
1
0
1
7
1
1
1
0
1
0
0
Rev. 2.00 Oct. 21, 2009 Page 80 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
3.2.2
System Control Register (SYSCR)
SYSCR controls MAC saturation operation, selects bus width mode for instruction fetch, sets
external bus mode, enables/disables the on-chip RAM, and selects the DTC address mode.
Bit
15
14
13
12
11
10
9
8
Bit Name
⎯
⎯
MACS
⎯
FETCHMD
⎯
EXPE
RAME
Initial Value
1
1
0
1
0
Undefined*
Undefined*
1
R/W
R/W
R/W
R/W
R/W
R
R/W
R/W
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
DTCMD
⎯
Initial Value
0
0
0
0
0
0
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Note: * The initial value depends on the startup mode.
Bit
Bit Name
Initial
Value
R/W
Descriptions
15
⎯
1
R/W
Reserved
14
⎯
1
R/W
These bits are always read as 1. The write value should
always be 1.
13
MACS
0
R/W
MAC Saturation Operation Control
Selects either saturation operation or non-saturation
operation for the MAC instruction.
0: MAC instruction is non-saturation operation
1: MAC instruction is saturation operation
12
⎯
1
R/W
Reserved
This bit is always read as 1. The write value should
always be 1.
11
FETCHMD 0
R/W
Instruction Fetch Mode Select
This LSI can prefetch an instruction in units of 16 bits or
32 bits. Select the bus width for instruction fetch
depending on the used memory for the storage of
programs.
0: 32-bit mode
1: 16-bit mode
Rev. 2.00 Oct. 21, 2009 Page 81 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
Bit
Bit Name
10
⎯
Initial
Value
1
Undefined*
R/W
Descriptions
R
Reserved
This bit is fixed at 1 in on-chip ROM enabled mode, and
0 in on-chip ROM disabled mode. This bit cannot be
changed.
9
EXPE
1
Undefined*
R/W
External Bus Mode Enable
Selects external bus mode. In external extended mode,
this bit is fixed 1 and cannot be changed. In single-chip
mode, the initial value of this bit is 0, and can be read
from or written to when PCKJE = 0. Do not write to this
2
bit when PCKJE = 1* .
When writing 0 to this bit after reading EXPE = 1, an
external bus cycle should not be executed.
The external bus cycle may be carried out in parallel
with the internal bus cycle depending on the setting of
the write data buffer function, refresh control function
and EXDMAC bus right release state and others.
0: External bus disabled
1: External bus enabled
8
RAME
1
R/W
RAM Enable
Enables or disables the on-chip RAM. This bit is
initialized when the reset state is released. Do not write
0 during access to the on-chip RAM.
0: On-chip RAM disabled
1: On-chip RAM enabled
7 to 2
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
1
DTCMD
1
R/W
DTC Mode Select
Selects DTC operating mode.
0: DTC is in full-address mode
1: DTC is in short address mode
0
⎯
1
R/W
Reserved
This bit is always read as 1. The write value should
always be 1.
Notes: 1. The initial value depends on the LSI initiation mode.
2. For details on the settings of the EXPE and PCJKE bits when the external address
space is in use, see section 13.3.12, Port Function Control Register D (PFCRD).
Rev. 2.00 Oct. 21, 2009 Page 82 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
3.3
Operating Mode Descriptions
3.3.1
Mode 1
This is the user boot mode for the flash memory. The LSI operates in the same way as in mode 7
except for programming and erasing of the flash memory. For details, see section 25, Flash
Memory.
3.3.2
Mode 2
This is the boot mode for the flash memory. The LSI operates in the same way as in mode 7
except for programming and erasing of the flash memory. For details, see section 25, Flash
Memory.
3.3.3
Mode 3
This is the boundary scan function enabled single-chip activation mode. The operation is the same
as mode 7 except for the boundary scan function. For details on the boundary scan function, see
section 26, Boundary Scan.
3.3.4
Mode 4
The CPU operating mode is advanced mode in which the address space is 16 Mbytes, and the onchip ROM is disabled.
The initial bus width mode immediately after a reset is 16 bits, with 16-bit access to all areas.
Ports D, E, and F function as an address bus, ports H and I function as a data bus, and parts of
ports A and B function as bus control signals. However, if all areas are designated as an 8-bit
access space by the bus controller, the bus mode switches to eight bits, and only port H functions
as a data bus.
Rev. 2.00 Oct. 21, 2009 Page 83 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
3.3.5
Mode 5
The CPU operating mode is advanced mode in which the address space is 16 Mbytes, and the onchip ROM is disabled.
The initial bus width mode immediately after a reset is eight bits, with 8-bit access to all areas.
Ports D, E, and F function as an address bus, port H functions as a data bus, and parts of ports A
and B function as bus control signals. However, if any area is designated as a 16-bit access space
by the bus controller, the bus width mode switches to 16 bits, and ports H and I function as a data
bus.
3.3.6
Mode 6
The CPU operating mode is advanced mode in which the address space is 16 Mbytes, and the onchip ROM is enabled.
The initial bus width mode immediately after a reset is eight bits, with 8-bit access to all areas.
Ports D, E, and F function as input ports, but they can be used as an address bus by specifying the
data direction register (DDR) for each port. For details, see section 13, I/O Ports. Port H functions
as a data bus, and parts of ports A and B function as bus control signals. However, if any area is
designated as a 16-bit access space by the bus controller, the bus width mode switches to 16 bits,
and ports H and I function as a data bus.
3.3.7
Mode 7
The CPU operating mode is advanced mode in which the address space is 16 Mbytes, and the onchip ROM is enabled.
All I/O ports can be used as general input/output ports. The external address space cannot be
accessed in the initial state, but setting the EXPE bit in the system control register (SYSCR) to 1
enables the external address space. After the external address space is enabled, ports D, E, and F
can be used as an address output bus and ports H and I as a data bus by specifying the data
direction register (DDR) for each port. When the external address space is not in use, ports J and
K can be used by setting the PCJKE bit in the port function control register D (PFCRD) to 1. For
details, see section 13, I/O Ports.
Rev. 2.00 Oct. 21, 2009 Page 84 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
3.3.8
Pin Functions
Table 3.4 shows the pin functions in each operating mode.
Table 3.4
Pin Functions in Each Operating Mode (Advanced Mode)
MCU
Port A
Port B
Port F
Operating
Mode
PA7
PA6-3
PA2-0
PB7-1 PB0
Port C
Port D
Port E
PF4-0
PF7-5
Port H
Port I
1
P*/C
P*/C
P*/C
P*/C
P*/C
P*/C
P*/A
P*/A
P*/A
P*/A
P*/D
P*/D
2
P*/C
P*/C
P*/C
P*/C
P*/C
P*/C
P*/A
P*/A
P*/A
P*/A
P*/D
P*/D
3
P*/C
P*/C
P*/C
P*/C
P*/C
P*/C
P*/A
P*/A
P*/A
P*/A
P*/D
P*/D
4
P/C*
P/C*
P*/C
P*/C
P/C*
P*/C
A
A
A
P*/A
D
P/D*
5
P/C*
P/C*
P*/C
P*/C
P/C*
P*/C
A
A
A
P*/A
D
P*/D
6
P/C*
P/C*
P*/C
P*/C
P*/C
P*/C
P*/A
P*/A
P*/A
P*/A
D
P*/D
7
P*/C
P*/C
P*/C
P*/C
P*/C
P*/C
P*/A
P*/A
P*/A
P*/A
P*/D
P*/D
[Legend]
P: I/O port
A: Address bus output
D: Data bus input/output
C: Control signals, clock input/output
*: Immediately after a reset
3.4
Address Map
3.4.1
Address Map
Figures 3.1 and 3.2 show the address map in each operating mode.
Rev. 2.00 Oct. 21, 2009 Page 85 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
Modes 1 and 2
User boot mode,
boot mode
(Advanced mode)
Modes 3 and 7
Boundary scan enabled single-chip mode,
single-chip mode
(Advanced mode)
H'000000
H'000000
On-chip ROM
H'080000
Access prohibited area
H'100000
Modes 4 and 5
On-chip ROM disabled
extended mode
(Advanced mode)
H'000000
On-chip ROM
H'080000
Access prohibited area
H'100000
External address space/
reserved area*1*3
External address space/
reserved area*1*3
H'FD9000
External address space
H'FD9000
H'FD9000
Access prohibited area
Access prohibited area
H'FDC000 External address space/
reserved area*1*3
H'FDC000 External address space/
reserved area*1*3
H'FDC000
H'FEC000
H'FEC000
H'FEC000
Reserved area*3
H'FF2000
H'FF2000
On-chip RAM*2
H'FFC000
H'FFEA00
H'FFFF20
On-chip I/O registers
H'FFFFFF
Notes:1.
2.
3.
4.
H'FF2000
On-chip RAM/
External address space*4
H'FFC000
H'FFEA00
On-chip I/O registers
H'FFFF00
H'FFFF20
H'FFFFFF
Reserved area*3
On-chip RAM/
External address space/
reserved area*1*3
On-chip I/O registers
External address space/
reserved area*1*3
External address space
External address space*4
H'FFC000
External address space/
reserved area*1*3
H'FFFF00
Reserved area*3
Access prohibited area
External address space/
reserved area*1*3
On-chip I/O registers
External address space
H'FFEA00
On-chip I/O registers
H'FFFF00
External address space
H'FFFF20
On-chip I/O registers
H'FFFFFF
This area is specified as the external address space when EXPE = 1 and the reserved area when EXPE = 0.
The on-chip RAM is used for flash memory programming. Do not clear the RAME bit in SYSCR to 0.
Do not access the reserved areas.
This area is specified as the external address space by clearing the RAME bit in SYSCR to 0.
Figure 3.1 Address Map in Each Operating Mode of H8SX/1665 and H8SX/1665M (1)
Rev. 2.00 Oct. 21, 2009 Page 86 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
MOde 6
On-chip ROM enabled
extended mode
(Advanced mode)
H'000000
On-chip ROM
H'080000
Access prohibited area
H'100000
External address space
H'FD9000
Access prohibited area
H'FDC000
External address space
H'FEC000
Reserved area*2
H'FF2000
On-chip RAM/
External address space*1
H'FFC000
External address space
H'FFEA00
On-chip I/O registers
H'FFFF00
External address space
H'FFFF20
On-chip I/O registers
H'FFFFFF
Notes: 1. This area is specified as the external address space by clearing the RAME bit in SYSCR to 0.
2. Do not access the reserved area.
Figure 3.1 Address Map in Each Operating Mode of H8SX/1665 and H8SX/1665M (2)
Rev. 2.00 Oct. 21, 2009 Page 87 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
Modes 1 and 2
User boot mode,
boot mode
(Advanced mode)
Modes 3 and 7
Boundary scan enabled single-chip mode,
single-chip mode
(Advanced mode)
H'000000
H'000000
On-chip ROM
H'060000
Access prohibited area
H'100000
Modes 4 and 5
On-chip ROM disabled
extended mode
(Advanced mode)
H'000000
On-chip ROM
H'060000
Access prohibited area
H'100000
External address space/
reserved area*1*3
External address space/
reserved area*1*3
H'FD9000
External address space
H'FD9000
H'FD9000
Access prohibited area
Access prohibited area
H'FDC000 External address space/
reserved area*1*3
H'FDC000 External address space/
reserved area*1*3
H'FDC000
H'FEC000
H'FEC000
H'FEC000
Reserved area*3
H'FF2000
H'FF2000
On-chip RAM*2
H'FFC000
H'FFEA00
H'FFFF20
On-chip I/O registers
H'FFFFFF
Notes:1.
2.
3.
4.
H'FF2000
On-chip RAM/
External address space*4
H'FFC000
H'FFEA00
On-chip I/O registers
H'FFFF00
H'FFFF20
H'FFFFFF
Reserved area*3
External address space*4
External address space/
reserved area*1*3
On-chip I/O registers
External address space/
reserved area*1*3
External address space
On-chip RAM/
H'FFC000
External address space/
reserved area*1*3
H'FFFF00
Reserved area*3
Access prohibited area
External address space/
reserved area*1*3
On-chip I/O registers
External address space
H'FFEA00
On-chip I/O registers
H'FFFF00
External address space
H'FFFF20
On-chip I/O registers
H'FFFFFF
This area is specified as the external address space when EXPE = 1 and the reserved area when EXPE = 0.
The on-chip RAM is used for flash memory programming. Do not clear the RAME bit in SYSCR to 0.
Do not access the reserved areas.
This area is specified as the external address space by clearing the RAME bit in SYSCR to 0.
Figure 3.2 Address Map in Each Operating Mode of H8SX/1662 and H8SX/1662M (1)
Rev. 2.00 Oct. 21, 2009 Page 88 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
MOde 6
On-chip ROM enabled
extended mode
(Advanced mode)
H'000000
On-chip ROM
H'060000
Access prohibited area
H'100000
External address space
H'FD9000
Access prohibited area
H'FDC000
External address space
H'FEC000
Reserved area*2
H'FF2000
On-chip RAM/
External address space*1
H'FFC000
External address space
H'FFEA00
On-chip I/O registers
H'FFFF00
External address space
H'FFFF20
On-chip I/O registers
H'FFFFFF
Notes: 1. This area is specified as the external address space by clearing the RAME bit in SYSCR to 0.
2. Do not access the reserved area.
Figure 3.2 Address Map in Each Operating Mode of H8SX/1662 and H8SX/1662M (2)
Rev. 2.00 Oct. 21, 2009 Page 89 of 1454
REJ09B0498-0200
Section 3 MCU Operating Modes
Rev. 2.00 Oct. 21, 2009 Page 90 of 1454
REJ09B0498-0200
Section 4 Resets
Section 4 Resets
4.1
Types of Resets
There are three types of resets: a pin reset, power-on reset*, voltage-monitoring reset*, deep
software standby reset, and watchdog timer reset. Table 4.1 shows the reset names and sources.
The internal state and pins are initialized by a reset. Figure 4.1 shows the reset targets to be
initialized.
When using power-on reset* and voltage monitoring reset*, RES pin must be fixed high.
Table 4.1
Reset Names And Sources
Reset Name
Source
Pin reset
Voltage input to the RES pin is driven low.
Power-on reset*
Vcc rises or lowers
Voltage-monitoring reset*
Vcc falls (voltage detection: Vdet)
Deep software standby reset
Deep software standby mode is canceled by an
interrupt.
Watchdog timer reset
The watchdog timer overflows.
Note:
*
Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 91 of 1454
REJ09B0498-0200
Section 4 Resets
Pin reset
RES
Power-on rest circuit registers*
(RSTSR.PORF)
Registers for voltage-monitoring*
Vcc
Power-on reset
circuit*
Voltage
detection circuit*
Deep software
standby reset
generation circuit
Watchdog
timer
Power-on reset
Voltage-monitoring
reset
RSTSR.LVDF
LVDCR.LVDE
LVDRI
Registers related to power-down mode
RSTSR.DPSRSTF
DPSBYCR, DPSWCR
DPSIER, DPSIFR
DPSIEGR, DPSBKRn
Deep software standby
reset
RSTCSR for WDT
Watchdog timer reset
Internal state other than above,
and pin states.
Note: * Supported only by the H8SX/1665M Group.
Figure 4.1 Block Diagram of Reset Circuit
Rev. 2.00 Oct. 21, 2009 Page 92 of 1454
REJ09B0498-0200
Section 4 Resets
Note that some registers are not initialized by any of the resets. The following describes the CPU
internal registers.
The PC, one of the CPU internal registers, is initialized by loading the start address from vector
addresses with the reset exception handling. At this time, the T bit in EXR is cleared to 0 and the I
bits in EXR and CCR are set to 1. The general registers, MAC, and other bits in CCR are not
initialized.
The initial value of the SP (ER7) is undefined. The SP should be initialized using the MOV.L
instruction immediately after a reset. For details, see section 2, CPU. For other registers that are
not initialized by a reset, see register descriptions in each section.
When a reset is canceled, the reset exception handling is started. For the reset exception handling,
see section 6.3, Reset.
4.2
Input/Output Pin
Table 4.2 shows the pin related to resets.
Table 4.2
Pin Configuration
Pin Name
Symbol
I/O
Function
Reset
RES
Input
Reset input
Rev. 2.00 Oct. 21, 2009 Page 93 of 1454
REJ09B0498-0200
Section 4 Resets
4.3
Register Descriptions
This LSI has the following registers for resets.
• Reset status register (RSTSR)
• Reset control/status register (RSTCSR)
4.3.1
Reset Status Register (RSTSR)
RSTSR indicates a source for generating an internal reset and voltage monitoring interrupt.
Bit
Bit name
Initial value:
R/W:
Notes:
Bit
7
1.
2.
3.
4.
5.
7
6
5
4
3
2
1
0
DPSRSTF
⎯
⎯
⎯
⎯
LVDF*2
⎯
PORF*2
0*3
0*3
R/W
R/W*5
0
0
0
0
0
0*3
R/(W)*1
R/W
R/W
R/W
R/W
R/W*4
Only 0 can be written to clear the flag.
Supported only by the H8SX/1665M Group.
Initial value is undefined in the H8SX/1665M Group.
Only 0 can be written to clear the flag in the H8SX/1665M Group.
Only read is possible in the H8SX/1665M Group.
Bit Name
DPSRSTF
Initial
Value
0
R/W
R/(W)*
Description
1
Deep Software Standby Reset Flag
Indicates that deep software standby mode is canceled
by an interrupt source specified with DPSIER or
DPSIEGR and an internal reset is generated.
[Setting condition]
When deep software standby mode is canceled by an
interrupt source.
[Clearing conditions]
6 to 3 ⎯
All 0
R/W
•
When this bit is read as 1 and then written by 0.
•
2
When a pin reset, power-on reset* or voltagemonitoring reset*2 is generated.
Reserved
These bits are always read as 0. The write value should
always be 0.
Rev. 2.00 Oct. 21, 2009 Page 94 of 1454
REJ09B0498-0200
Section 4 Resets
•
H8SX/1665 Group
Bit
Initial
Bit Name Value
R/W
Description
2 to 0
⎯
R/W
Reserved
All 0
These bits are always read as 0. The write value should
always be 0.
•
Bit
2
H8SX/1665M Group
Bit Name
LVDF
Initial
Value
R/W
Description
1
Undefined R/(W)* LVD Flag
This bit indicates that the voltage detection circuit has
detected a low voltage (Vcc at or below Vdet).
[Setting condition]
Vcc falling to or below Vdet
[Clearing condition]
•
•
1
—
Undefined R/W
After Vcc has exceeded Vdet and the specified
stabilization period has elapsed, writing 0 to the bit
after reading it as 1.
Generation of a pin reset or power-on reset.
Reserved
The write value should always be 0.
0
PORF
Undefined R
Power-on Reset Flag
This bit indicates that a power-on reset has been
generated.
[Setting condition]
Generation of a power-on reset
[Clearing condition]
Generation of a pin reset
Notes: 1. Only 0 can be written to clear the flag.
2. Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 95 of 1454
REJ09B0498-0200
Section 4 Resets
4.3.2
Reset Control/Status Register (RSTCSR)
RSTCSR controls an internal reset signal generated by the watchdog timer and selects the internal
reset signal type. RSTCSR is initialized to H’1F by a pin reset or a deep software standby reset,
but not by the internal reset signal generated by a WDT overflow.
7
6
5
4
3
2
1
0
WOVF
RSTE
⎯
⎯
⎯
⎯
⎯
⎯
0
0
0
1
1
1
1
1
R/(W)*
R/W
R/W
R
R
R
R
R
Bit
Bit name
Initial value:
R/W:
Note: * Only 0 can be written to clear the flag.
Bit
Bit Name
Initial
Value
R/W
7
WOVF
0
R/(W)*
Description
Watchdog Timer Overflow Flag
This bit is set when TCNT overflows in watchdog timer mode,
but not set in interval timer mode. Only 0 can be written to.
[Setting condition]
When TCNT overflows (H’FF → H’00) in watchdog timer
mode.
[Clearing condition]
When this bit is read as 1 and then written by 0.
6
RSTE
0
R/W
Reset Enable
Selects whether or not the LSI internal state is reset by a
TCNT overflow in watchdog timer mode.
0: Internal state is not reset when TCNT overflows. (Although
this LSI internal state is not reset, TCNT and TCSR of the
WDT are reset.)
1: Internal state is reset when TCNT overflows.
5
⎯
0
R/W
Reserved
Although this bit is readable/writable, operation is not affected
by this bit.
4 to 0 ⎯
1
R
Reserved
These are read-only bits but cannot be modified.
Note:
*
Only 0 can be written to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 96 of 1454
REJ09B0498-0200
Section 4 Resets
4.4
Pin Reset
This is a reset generated by the RES pin.
When the RES pin is driven low, all the processing in progress is aborted and the LSI enters a
reset state. In order to firmly reset the LSI, the STBY pin should be set to high and the RES pin
should be held low at least for 20 ms at a power-on. During operation, the RES pin should be held
low at least for 20 states.
4.5
Power-on Reset (POR) (H8SX/1665M Group)
This is an internal reset generated by the power-on reset circuit.
If RES is in the high-level state when power is supplied, a power-on reset is generated. After Vcc
has exceeded Vpor and the specified period (power-on reset time) has elapsed, the chip is released
from the power-on reset state. The power-on reset time is a period for stabilization of the external
power supply and the LSI circuit.
If RES is at the high-level when the power-supply voltage (Vcc) falls to or below Vpor, a poweron reset is generated. The chip is released after Vcc has risen above Vpor and the power-on reset
time has elapsed.
After a power-on reset has been generated, the PORF bit in RSTSR is set to 1. The PORF bit is in
a read-only register and is only initialized by a pin reset. Figure 4.2 shows the operation of a
power-on reset.
Rev. 2.00 Oct. 21, 2009 Page 97 of 1454
REJ09B0498-0200
Section 4 Resets
Vpor*1
External
power supply Vcc
Reset state
RES pin
Vcc
POR signal
("L" is valid)
Vcc
Reset state
V
Reset signal
Vcc
("L" is valid)
Pin reset and
OR signal for POR
V
V
tPOR*2
Set
tPOR*2
Set
Vcc
PORF
Notes: For details of the electrical characteristics, see section 30, Electrical Characteristics.
1. VPOR shows a level of power-on reset detection level.
2. TPOR shows a time for power-on reset.
Figure 4.2 Operation of a Power on Reset
4.6
Power Supply Monitoring Reset (H8SX/1665M Group)
This is an internal reset generated by the power-supply detection circuit.
When Vcc falls below Vdet in the state where the LVDE bit in LVDCR has been set to 1 and the
LVDRI bit has been cleared to 0, a voltage-monitoring reset is generated. When Vcc subsequently
rises above Vdet, release from the voltage-monitoring reset proceeds after a specified time has
elapsed.
For details of the voltage-monitoring reset, see section 5, Voltage Detection Circuit (LVD), and
section 30, Electrical Characteristics.
Rev. 2.00 Oct. 21, 2009 Page 98 of 1454
REJ09B0498-0200
Section 4 Resets
4.7
Deep Software Standby Reset
This is an internal reset generated when deep software standby mode is canceled by an interrupt.
When deep software standby mode is canceled, a deep software standby reset is generated, and
simultaneously, clock oscillation starts. After the time specified with DPSWCR has elapsed, the
deep software standby reset is canceled.
For details of the deep software standby reset, see section 28, Power-Down Modes.
4.8
Watchdog Timer Reset
This is an internal reset generated by the watchdog timer.
When the RSTE bit in RSTCSR is set to 1, a watchdog timer reset is generated by a TCNT
overflow. After a certain time, the watchdog timer reset is canceled.
For details of the watchdog timer reset, see section 18, Watchdog Timer (WDT).
Rev. 2.00 Oct. 21, 2009 Page 99 of 1454
REJ09B0498-0200
Section 4 Resets
4.9
Determination of Reset Generation Source
Reading RSTCSR, RSTSR, or LVDCR* of the voltage-detection circuit determines which reset
was used to execute the reset exception handling. Figure 4.2 shows an example of the flow to
identify a reset generation source.
Note
* Supported only by the H8SX/1665M Group.
Reset exception
handling
RSTCSR.RSTE=1
and RSTCSR.WOVF=1
Yes
No
RSTSR.
DPSRSTF=1
No
Yes
LVDCR.LVDE=1
& LVDCR.LCDRI=0
& RSTSR.LVDF=1
Yes
No
RSTSR.
PORF=1
No
Yes
Watchdog timer
reset
Note:
Deep software
standby reset
Voltage monitoring
reset*
Power-on reset*
Pin reset
* Supported only by the H8SX/1665M Group.
Figure 4.3 Example of Reset Generation Source Determination Flow
Rev. 2.00 Oct. 21, 2009 Page 100 of 1454
REJ09B0498-0200
Section 5 Voltage Detection Circuit (LVD)
Section 5 Voltage Detection Circuit (LVD)
The voltage detection circuit (LVD) is only supported by the H8SX/1665M Group.
This circuit is used to monitor Vcc. The LVD is capable of internally resetting the LSI when Vcc
falls and crosses the voltage detection level. An interrupt can also be generated.
5.1
•
Features
Voltage-detection circuit
Capable of detecting the power-supply voltage (Vcc) becoming less than or equal to Vdet.
Capable of generating an internal reset or interrupt when a low voltage is detected.
A block diagram of the voltage detection circuit is shown in figure 5.1.
Vcc
On-chip reference
voltage
(for sensing Vdet)
+
−
LVDMON
Power-supply
stabilization
time
generation
circuit
LVDF
LVDE
Reset /
interrupt
control
circuit
Voltage-monitoring
reset
Voltage-monitoring
interrupt
LVDRI
[Legend]
LVDE:
LVDRI:
LVDMON:
LVDF:
LVD enable
LVD reset / interrupt select
LVD monitor
LVD flag
Figure 5.1 Block Diagram of Voltage-Detection Circuit
Rev. 2.00 Oct. 21, 2009 Page 101 of 1454
REJ09B0498-0200
Section 5 Voltage Detection Circuit (LVD)
5.2
Register Descriptions
The registers of the voltage detection circuit are listed below.
•
•
Voltage detection control register (LVDCR)
Reset status register (RSTSR)
5.2.1
Voltage Detection Control Register (LVDCR)
The LVDCR controls the voltage-detection circuit.
LVDE, LVDRI, and LVDMON are initialized by a pin reset or power-on reset
Bit
Bit name
7
6
5
4
3
2
1
0
LVDE
LVDRI
—
LVDMON
—
—
—
—
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R
R/W
R/W
R/W
R/W
Initial value:
R/W:
Bit
Bit Name
Initial Value
R/W
Description
7
LVDE
0
R/W
LVD Enable
This bit enables or disables issuing of a reset or
interrupt by the voltage-detection circuit.
0: Disabled
1: Enabled
6
LVDRI
0
R/W
LVD Reset/Interrupt Select
This bit selects whether an internal reset or
interrupt is generated when the voltage detection
circuit detects a low voltage. When modifying the
LVDRI bit, ensure that low-voltage detection is in
the disabled state (the LVDE bit is cleared to 0).
0: A reset is generated when a voltage is
detected.
1: An interrupt is generated when a low voltage is
detected.
5
—
0
R/W
Reserved
This bit is always read as 0 and the write value
should always be 0.
Rev. 2.00 Oct. 21, 2009 Page 102 of 1454
REJ09B0498-0200
Section 5 Voltage Detection Circuit (LVD)
Bit
Bit Name
Initial Value
R/W
Description
4
LVDMON
0
R
LVD Monitor
This bit monitors the voltage level. This bit is valid
when the LVDE bit is 1 and read as 0 when the
LVDE bit is 0. Writing to this bit is ineffective.
0: Vcc must fall below Vdet.
1: Vcc must rise above Vdet.
3 to 0
—
0
R/W
Reserved
These bits are always read as 0 and the write
value should always be 0.
5.2.2
Reset Status Register (RSTSR)
RSTSR indicates the source of an internal reset or voltage monitoring interrupt.
Bit
Bit name
Initial value:
R/W:
Note:
*
7
6
5
4
3
2
1
0
DPSRSTF
—
—
—
—
LVDF
—
PORF
0
0
0
0
0
Undefined
Undefined
Undefined
R/(W)*
R/W
R/W
R/W
R/W
R/(W)*
R/W
R
To clear the flag, only 0 should be written to.
Bit
Bit Name
Initial Value
R/W
Description
7
DPSRSTF
0
R/W*
Deep Software Standby Reset Flag
This bit indicates release from deep software
standby mode due to the interrupt source
selected by DPSIER and DPSIEGR, and
generation of an internal reset.
[Setting condition]
Release from deep software standby mode due to
an interrupt source.
[Clearing condition]
•
•
Writing 0 to the bit after reading it as1.
Generation of a pin reset, power on reset, or
voltage monitoring reset.
Rev. 2.00 Oct. 21, 2009 Page 103 of 1454
REJ09B0498-0200
Section 5 Voltage Detection Circuit (LVD)
Bit
Bit Name
Initial Value
R/W
Description
6 to 3
—
All 0
R/W
Reserved
These bits are always read as 0 and the write
value should always be 0.
2
LVDF
Undefined
R/(W)*
LVD Flag
This bit indicates that the voltage detection circuit
has detected a low voltage (Vcc at or below
Vdet).
[Setting condition]
Vcc falling to or below Vdet.
[Clearing condition]
•
•
1
—
Undefined
R/W
After Vcc has exceeded Vdet and the
specified stabilization period has elapsed,
writing 0 to the bit after reading it as 1.
Generation of a pin reset or power-on reset.
Reserved
The write value should always be 0.
0
PORF
Undefined
R
Power-on Reset Flag
This bit indicates that a power-on reset has been
generated.
[Setting condition]
Generation of a power-on reset
[Clearing condition]
Generation of a pin reset
Note:
*
To clear the flag, only 0 should be written to.
Rev. 2.00 Oct. 21, 2009 Page 104 of 1454
REJ09B0498-0200
Section 5 Voltage Detection Circuit (LVD)
5.3
Voltage Detection Circuit
5.3.1
Voltage Monitoring Reset
Figure 5.2 shows the timing of a voltage monitoring reset by the voltage-detection circuit.
When Vcc falls below Vdet in the state where the LVDE bit in LVDCR has been set to 1 and the
LVDRI bit has been cleared to 0, the LVDF bit is set to 1 and the voltage-detection circuit
generates a voltage monitoring reset.
Next, after Vcc has risen above Vdet, release from the voltage-monitoring reset takes place after a
period for stabilization (tpor) has elapsed. The period for stabilization (tpor) is a time that is generated
by the voltage detection circuit in order to stabilize the Vcc and the internal circuit of the LSI.
When a voltage-monitoring reset is generated, the LVDF bit is set to 1.
For details, see section 30, Electrical Characteristics.
Vcc
Vdet
Vpor
↓Write 1
LVDE
↓Write 0
LVDRI
Stabilization time (tPOR)
Internal
reset signal
(Low)
Figure 5.2 Timing of the Voltage-Monitoring Reset
Rev. 2.00 Oct. 21, 2009 Page 105 of 1454
REJ09B0498-0200
Section 5 Voltage Detection Circuit (LVD)
5.3.2
Voltage Monitoring Interrupt
Figure 5.3 shows the timing of a voltage monitoring interrupt by the voltage-detection circuit.
When Vcc falls below the Vdet in a state where the LVDE and LVDRI bits in LVDCR are both
set to 1, the LVDF bit is set to 1 and a voltage monitoring interrupt is requested.
The voltage monitoring interrupt signal is internally connected to IRQ14-B, so the IRQ14F bit in
the ISR is set to 1 when the interrupt is generated.
As for the IRQ14 setting, set both the ITS14 bit in PFCRB and the IRQ14E bit in the IER to 1, and
the IRQ14SR and IRQ14SF bits in the ISCR to 01 (interrupt request on falling edge).
Figure 5.4 shows the procedure for setting the voltage-monitoring interrupt.
Vcc
Vdet
Vpor
↓Write 1
LVDE
↓Write 1
LVDRI
Stabilization time (tPOR)
Voltage-monitoring
signal
Set
LVDF
Voltage-monitoring
interrupt signal
(IRQ14)
Set
IRQ14F
Figure 5.3 Timing of the Voltage-Monitoring Interrupt
Rev. 2.00 Oct. 21, 2009 Page 106 of 1454
REJ09B0498-0200
Write 0 after
reading as 1
Section 5 Voltage Detection Circuit (LVD)
Start program
Voltage monitoring interrupt
(IRQ14) disabled
IER.IRQ14E = write 0
LVDCR.LVDRI = write 1
LVDCR.LVDE = write 1
Voltage detection and
IRQ register settings
PFCRB.ITS14 = write 1
ISCR setting
(IRQ14SR = 0, IRQ14SF = 1)
If the flag has been set to 1
before the voltage-monitoring
interrupt is enabled, clear it
by writing 0 after having read
it as 1.
ISR.IRQ14F = clear
LVDCR.
LVDMON = 1
Yes
No (Vcc low)
(Vcc high)
Processing
for lowered Vcc
Clear RSTSR.LVDF*
Voltage-monitoring interrupt
(IRQ14) enabled
IER.IRQ14E = write 1
Interrupt generation
when a low voltage is
detected
Processing for lowered Vcc
Note:
*
When the LVDF cannot be cleared despite Vcc being at a higher electrical potential than
Vdet (LVDMON = 1), the voltage-detection circuit is in the state of waiting for stabilization.
Clear the bit again after the stabilization time (tPOR) has elapsed.
Figure 5.4 Example of the Procedure for Setting the Voltage-Monitoring Interrupt
Rev. 2.00 Oct. 21, 2009 Page 107 of 1454
REJ09B0498-0200
Section 5 Voltage Detection Circuit (LVD)
5.3.3
Release from Deep Software Standby Mode by the Voltage-Detection Circuit
If the LVDE and LVDRI bits in LVDCR and the DLVDIE bit in DPSIER have all been set to 1
during a period in deep software standby mode, the voltage-detection circuit requests release from
deep software standby mode when Vcc falls to or below Vdet. This sets the DLVDIF bit in
DPSIFR to 1, thus producing release from the deep software standby mode. For the deep software
standby mode, see section 28, Power-Down Modes.
5.3.4
Voltage Monitor
The result of voltage detection by the voltage-detection circuit can be monitored by checking the
value of the LVDMON bit in LVDCR. When the LVDMON bit has been enabled by setting the
LVDE bit, 0 indicates that Vcc is at or below Vdet and 1 indicates that Vcc is above Vdet. This
bit should be read while the voltage-monitoring reset has been disabled by setting the LVDRI bit
to 1.
Before clearing the LVDF bit in RSTSR to 0, confirm that the LVDMON bit is set to 1 (indicating
that Vcc is above Vdet). When it is impossible to clear the LVDF bit despite the LVDMON bit
being 1, the voltage-detection circuit is in the state of waiting for stabilization. In such cases, clear
the bit again after the stabilization time (tpor) has elapsed.
Rev. 2.00 Oct. 21, 2009 Page 108 of 1454
REJ09B0498-0200
Section 6 Exception Handling
Section 6 Exception Handling
6.1
Exception Handling Types and Priority
As table 6.1 indicates, exception handling is caused by a reset, a trace, an address error, an
interrupt, a trap instruction, a sleep instruction, and an illegal instruction (general illegal
instruction or slot illegal instruction). Exception handling is prioritized as shown in table 6.1. If
two or more exceptions occur simultaneously, they are accepted and processed in order of priority.
Exception sources, the stack structure, and operation of the CPU vary depending on the interrupt
control mode. For details on the interrupt control mode, see section 7, Interrupt Controller.
Table 6.1
Exception Types and Priority
Priority
Exception Type
Exception Handling Start Timing
High
Reset
Exception handling starts at the timing of level change from
low to high on the RES pin, when deep software standby
mode is canceled, or when the watchdog timer overflows.
The CPU enters the reset state when the RES pin is low.
Illegal instruction
Exception handling starts when an undefined code is
executed.
Trace*1
Exception handling starts after execution of the current
instruction or exception handling, if the trace (T) bit in EXR
is set to 1.
Address error
After an address error has occurred, exception handling
starts on completion of instruction execution.
Interrupt
Exception handling starts after execution of the current
instruction or exception handling, if an interrupt request has
occurred.*2
Sleep instruction
Exception handling starts by execution of a sleep instruction
(SLEEP), if the SSBY bit in SBYCR is set to 0 and the
SLPIE bit in SBYCR is set to 1.
Trap instruction*3
Exception handling starts by execution of a trap instruction
(TRAPA).
Low
Notes: 1. Traces are enabled only in interrupt control mode 2. Trace exception handling is not
executed after execution of an RTE instruction.
2. Interrupt detection is not performed on completion of ANDC, ORC, XORC, or LDC
instruction execution, or on completion of reset exception handling.
3. Trap instruction exception handling requests and sleep instruction exception handling
requests are accepted at all times in program execution state.
Rev. 2.00 Oct. 21, 2009 Page 109 of 1454
REJ09B0498-0200
Section 6 Exception Handling
6.2
Exception Sources and Exception Handling Vector Table
Different vector table address offsets are assigned to different exception sources. The vector table
addresses are calculated from the contents of the vector base register (VBR) and vector table
address offset of the vector number. The start address of the exception service routine is fetched
from the exception handling vector table indicated by this vector table address.
Table 6.2 shows the correspondence between the exception sources and vector table address
offsets. Table 6.3 shows the calculation method of exception handling vector table addresses.
Table 6.2
Exception Handling Vector Table
Vector Table Address Offset*1
2
Advanced, Middle*2,
Maximum*2 Modes
Exception Source
Vector Number
Normal Mode*
Reset
0
H'0000 to H'0001
H'0000 to H'0003
Reserved for system use
1
H'0002 to H'0003
H'0004 to H'0007
2
H'0004 to H'0005
H'0008 to H'000B
3
H'0006 to H'0007
H'000C to H'000F
Illegal instruction
4
H'0008 to H'0009
H'0010 to H'0013
Trace
5
H'000A to H'000B
H'0014 to H'0017
Reserved for system use
6
H'000C to H'000D
H'0018 to H'001B
Interrupt (NMI)
7
H'000E to H'000F
H'001C to H'001F
(#0)
8
H'0010 to H'0011
H'0020 to H'0023
(#1)
9
H'0012 to H'0013
H'0024 to H'0027
(#2)
10
H'0014 to H'0015
H'0028 to H'002B
(#3)
11
H'0016 to H'0017
H'002C to H'002F
12
H'0018 to H'0019
H'0030 to H'0033
DMA address error*
13
H'001A to H'001B
H'0034 to H'0037
UBC break interrupt
14
H'001C to H'001D
H'0038 to H'003B
Reserved for system use
15
⏐
17
H'001E to H'001F
⏐
H'0022 to H'0023
H'003C to H'003F
⏐
H'0044 to H'0047
Sleep interrupt
18
H'0024 to H'0025
H'0048 to H'004B
Trap instruction
CPU address error
3
Rev. 2.00 Oct. 21, 2009 Page 110 of 1454
REJ09B0498-0200
Section 6 Exception Handling
Vector Table Address Offset*1
Exception Source
Vector Number
Normal Mode*
Advanced, Middle*2,
Maximum*2 Modes
Reserved for system use
19
⏐
23
H'0026 to H'0027
⏐
H'002E to H'002F
H'004C to H'004F
⏐
H'005C to H'005F
User area (not used)
24
⏐
63
H'0030 to H'0031
⏐
H'007E to H'007F
H'0060 to H'0063
⏐
H'00FC to H'00FF
External interrupt
IRQ0
64
H'0080 to H'0081
H'0100 to H'0103
IRQ1
65
H'0082 to H'0083
H'0104 to H'0107
IRQ2
66
H'0084 to H'0085
H'0108 to H'010B
IRQ3
67
H'0086 to H'0087
H'010C to H'010F
IRQ4
68
H'0088 to H'0089
H'0110 to H'0113
IRQ5
69
H'008A to H'008B
H'0114 to H'0117
IRQ6
70
H'008C to H'008D
H'0118 to H'011B
IRQ7
71
H'008E to H'008F
H'011C to H'011F
IRQ8
72
H'0090 to H'0091
H'0120 to H'0123
IRQ9
73
H'0092 to H'0093
H'0124 to H'0127
IRQ10
74
H'0094 to H'0095
H'0128 to H'012B
IRQ11
75
H'0096 to H'0097
H'012C to H'012F
Reserved for system use
76
⏐
79
H'0098 to H'0099
⏐
H'009E to H'009F
H'0130 to H'0133
⏐
H'013C to H'013F
Internal interrupt*4
80
⎜
255
H'00A0 to H'00A1
⎜
H'01FE to H'01FF
H'0140 to H'0143
⎜
H'03FC to H'03FF
Notes: 1.
2.
3.
4.
2
Lower 16 bits of the address.
Not available in this LSI.
A DMA address error is generated by the DTC, DMAC, and EXDMAC.
For details of internal interrupt vectors, see section 7.5, Interrupt Exception Handling
Vector Table.
Rev. 2.00 Oct. 21, 2009 Page 111 of 1454
REJ09B0498-0200
Section 6 Exception Handling
Table 6.3
Calculation Method of Exception Handling Vector Table Address
Exception Source
Calculation Method of Vector Table Address
Reset, CPU address error
Vector table address = (vector table address offset)
Other than above
Vector table address = VBR + (vector table address offset)
[Legend]
VBR: Vector base register
Vector table address offset: See table 6.2.
6.3
Reset
A reset has priority over any other exception. When the RES pin goes low, all processing halts and
this LSI enters the reset state. To ensure that this LSI is reset, hold the RES pin low for at least 20
ms with the STBY pin driven high when the power is turned on. When operation is in progress,
hold the RES pin low for at least 20 states.
The chip can be reset by the overflow that is generated in watchdog timer mode of the watchdog
timer. For details, see section 18, Watchdog Timer (WDT).
The chip can also be reset by the exit from deep software standby mode. For details, see section
28, Power-Down Modes.
A reset initializes the internal state of the CPU and the registers of the on-chip peripheral modules.
The interrupt control mode is 0 immediately after a reset.
6.3.1
Reset Exception Handling
When the RES 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, VBR is cleared to H'00000000, the T bit is cleared to 0 in EXR, and the I bits are
set to 1 in EXR and CCR.
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 6.1 and 6.2 show examples of the reset sequence.
Rev. 2.00 Oct. 21, 2009 Page 112 of 1454
REJ09B0498-0200
Section 6 Exception Handling
6.3.2
Interrupts after Reset
If an interrupt is accepted after a reset but 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).
6.3.3
On-Chip Peripheral Functions after Reset Release
After the reset state is released, MSTPCRA and MSTPCRB are initialized to H'0FFF and H'FFFF,
respectively, and all modules except the DTC, DMAC, and EXDMAC enter the module stop state.
Consequently, on-chip peripheral module registers cannot be read or written to. Register reading
and writing is enabled when the module stop state is canceled.
Vector
fetch
Internal
operation
First
instruction
prefetch
Iφ
RES
Internal
address bus
(1)
(3)
Internal read
signal
Internal write
signal
Internal data
bus
High
(2)
(4)
(1): Reset exception handling vector address (when reset, (1) = H'000000)
(2): Start address (contents of reset exception handling vector address)
(3) Start address ((3) = (2))
(4) First instruction in the exception handling routine
Figure 6.1 Reset Sequence (On-chip ROM Enabled Advanced Mode)
Rev. 2.00 Oct. 21, 2009 Page 113 of 1454
REJ09B0498-0200
Section 6 Exception Handling
Internal First instruction
operation
prefetch
Vector fetch
*
*
*
Bφ
RES
Address bus
(1)
(3)
(5)
RD
HWR, LWR
D15 to D0
High
(2)
(4)
(6)
(1)(3) Reset exception handling vector address (when reset, (1) = H'000000, (3) = H'000002)
(2)(4) Start address (contents of reset exception handling vector address)
(5) Start address ((5) = (2)(4))
(6) First instruction in the exception handling routine
Note: * Seven program wait cycles are inserted.
Figure 6.2 Reset Sequence
(16-Bit External Access in On-chip ROM Disabled Advanced Mode)
Rev. 2.00 Oct. 21, 2009 Page 114 of 1454
REJ09B0498-0200
Section 6 Exception Handling
6.4
Traces
Traces are enabled in interrupt control mode 2. Trace mode is not activated in interrupt control
mode 0, irrespective of the state of the T bit. Before changing interrupt control modes, the T bit
must be cleared. For details on interrupt control modes, see section 7, Interrupt Controller.
If the T bit in EXR is set to 1, trace mode is activated. In trace mode, a trace exception occurs on
completion of each instruction. Trace mode is not affected by interrupt masking by CCR. Table
6.4 shows the state of CCR and EXR after execution of trace exception handling. Trace mode is
canceled by clearing the T bit in EXR to 0 during the trace exception handling. However, 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.
Interrupts are accepted even within the trace exception handling routine.
Table 6.4
Status of CCR and EXR after Trace Exception Handling
CCR
Interrupt Control Mode
I
UI
EXR
T
0
Trace exception handling cannot be used.
2
1
⎯
0
I2 to I0
⎯
[Legend]
1:
Set to 1
0:
Cleared to 0
⎯:
Retains the previous value.
Rev. 2.00 Oct. 21, 2009 Page 115 of 1454
REJ09B0498-0200
Section 6 Exception Handling
6.5
Address Error
6.5.1
Address Error Source
Instruction fetch, stack operation, or data read/write shown in table 6.5 may cause an address
error.
Table 6.5
Bus Cycle and Address Error
Bus Cycle
Type
Bus Master
Description
Address Error
Instruction
fetch
CPU
Fetches instructions from even addresses
No (normal)
Fetches instructions from odd addresses
Occurs
Fetches instructions from areas other than on-chip No (normal)
peripheral module space*1
Fetches instructions from on-chip peripheral
module space*1
Occurs
Fetches instructions from external memory space Occurs
in single-chip mode
Stack
operation
CPU
Data read/write CPU
Fetches instructions from access prohibited
area.*2
Occurs
Accesses stack when the stack pointer value is
even address
No (normal)
Accesses stack when the stack pointer value is
odd address
Occurs
Accesses word data from even addresses
No (normal)
Accesses word data from odd addresses
No (normal)
Accesses external memory space in single-chip
mode
Occurs
2
Data read/write DTC or
DMAC
Accesses to access prohibited area*
Occurs
Accesses word data from even addresses
No (normal)
Accesses word data from odd addresses
No (normal)
Accesses external memory space in single-chip
mode
Occurs
2
Accesses to access prohibited area*
Rev. 2.00 Oct. 21, 2009 Page 116 of 1454
REJ09B0498-0200
Occurs
Section 6 Exception Handling
Bus Cycle
Type
Bus Master
Data read/write EXDMAC
Single address DMAC or
transfer
EXDMAC
Description
Address Error
Accesses word data from even addresses
No (normal)
Accesses word data from odd addresses
No (normal)
Accesses external memory space in single-chip
mode
Occurs
Accesses to access prohibited area*2
Occurs
Accesses external memory space
N0 (normal)
Accesses spaces other than external memory
space
Occurs
Address access space is the external memory
space for single address transfer
No (normal)
Address access space is not the external memory Occurs
space for single address transfer
Notes: 1. For on-chip peripheral module space, see section 9, Bus Controller (BSC).
2. For the access-prohibited area, refer to figure 3.1 in section 3.4, Address Map.
6.5.2
Address Error Exception Handling
When an address error occurs, address error exception handling starts after the bus cycle causing
the address error ends and current instruction execution completes. The address error exception
handling is as follows:
1. The contents of PC, CCR, and EXR are saved in the stack.
2. The interrupt mask bit is updated and the T bit is cleared to 0.
3. An exception handling vector table address corresponding to the address error is generated, the
start address of the exception service routine is loaded from the vector table to PC, and
program execution starts from that address.
Even though an address error occurs during a transition to an address error exception handling, the
address error is not accepted. This prevents an address error from occurring due to stacking for
exception handling, thereby preventing infinitive stacking.
If the SP contents are not a multiple of 2 when an address error exception handling occurs, the
stacked values (PC, CCR, and EXR) are undefined.
Rev. 2.00 Oct. 21, 2009 Page 117 of 1454
REJ09B0498-0200
Section 6 Exception Handling
When an address error occurs, the following is performed to halt the DTC, DMAC, and
EXDMAC.
•
•
•
•
The ERR bit of DTCCR in the DTC is set to 1.
The ERRF bit of DMDR_0 in the DMAC is set to 1.
The ERRF bit of EDMDR_0 in the EXDMAC is set to 1.
The DTE bits of DMDRs for all channels in the DMAC are cleared to 0 to forcibly terminate
transfer.
• The DTE bits of EDMDRs for all channels in the EXDMAC are cleared to 0 to forcibly
terminate transfer.
Table 6.6 shows the state of CCR and EXR after execution of the address error exception
handling.
Table 6.6
Status of CCR and EXR after Address Error Exception Handling
CCR
EXR
Interrupt Control Mode
I
UI
T
I2 to I0
0
1
⎯
⎯
⎯
2
1
⎯
0
7
[Legend]
1:
Set to 1
0:
Cleared to 0
⎯:
Retains the previous value.
Rev. 2.00 Oct. 21, 2009 Page 118 of 1454
REJ09B0498-0200
Section 6 Exception Handling
6.6
Interrupts
6.6.1
Interrupt Sources
Interrupt sources are NMI, IRQ0 to IRQ11, and on-chip peripheral modules, as shown in table 6.7.
Table 6.7
Interrupt Sources
Type
Source
Number of Sources
NMI
NMI pin (external input)
1
UBC break interrupt
UBC break controller (UBC)
1
IRQ0 to IRQ11
Pins IRQ0 to IRQ11 (external input)
12
Voltage-detection circuit*
Voltage-detection circuit (LVD)*
1
On-chip peripheral module 32K timer (TM32K)
DMA controller (DMAC)
8
EXDMA controller (EXDMAC)
8
Watchdog timer (WDT)
1
A/D converter
2
16-bit timer pulse unit (TPU)
52
8-bit timer (TMR)
16
Serial communications interface (SCI)
24
2
Note:
*
1
I C bus interface 2 (IIC2)
2
USB function module (USB)
5
Supported only by the H8SX/1665M Group.
Different vector numbers and vector table offsets are assigned to different interrupt sources. For
vector number and vector table offset, refer to table 7.2, Interrupt Sources, Vector Address
Offsets, and Interrupt Priority in section 7, Interrupt Controller.
6.6.2
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
multiple-interrupt control. The source to start interrupt exception handling and the vector address
differ depending on the product. For details, refer to section 7, Interrupt Controller.
Rev. 2.00 Oct. 21, 2009 Page 119 of 1454
REJ09B0498-0200
Section 6 Exception Handling
The interrupt exception handling is as follows:
1. The contents of PC, CCR, and EXR are saved in the stack.
2. The interrupt mask bit is updated and the T bit is cleared to 0.
3. An exception handling vector table address corresponding to the interrupt source is generated,
the start address of the exception service routine is loaded from the vector table to PC, and
program execution starts from that address.
6.7
Instruction Exception Handling
There are three instructions that cause exception handling: trap instruction, sleep instruction, and
illegal instruction.
6.7.1
Trap Instruction
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. The trap
instruction exception handling is as follows:
1. The contents of PC, CCR, and EXR are saved in the stack.
2. The interrupt mask bit is updated and the T bit is cleared to 0.
3. An exception handling vector table address corresponding to the vector number specified in
the TRAPA instruction is generated, the start address of the exception service routine is loaded
from the vector table to PC, and program execution starts from that address.
A start address is read from the vector table corresponding to a vector number from 0 to 3, as
specified in the instruction code.
Table 6.8 shows the state of CCR and EXR after execution of trap instruction exception handling.
Table 6.8
Status of CCR and EXR after Trap Instruction Exception Handling
CCR
EXR
Interrupt Control Mode
I
UI
T
I2 to I0
0
1
⎯
⎯
⎯
2
1
⎯
0
⎯
[Legend]
1:
Set to 1
0:
Cleared to 0
⎯:
Retains the previous value.
Rev. 2.00 Oct. 21, 2009 Page 120 of 1454
REJ09B0498-0200
Section 6 Exception Handling
6.7.2
Sleep Instruction Exception Handling
The sleep instruction exception handling starts when a sleep instruction is executed with the SSBY
bit in SBYCR set to 0 and the SLPIE bit in SBYCR set to 1. The sleep instruction exception
handling can always be executed in the program execution state. In the exception handling, the
CPU operates as follows.
1. The contents of PC, CCR, and EXR are saved in the stack.
2. The interrupt mask bit is updated and the T bit is cleared to 0.
3. An exception handling vector table address corresponding to the vector number specified in
the SLEEP instruction is generated, the start address of the exception service routine is loaded
from the vector table to PC, and program execution starts from that address.
Bus masters other than the CPU may gain the bus mastership after a sleep instruction has been
executed. In such cases the sleep instruction will be started when the transactions of a bus master
other than the CPU has been completed and the CPU has gained the bus mastership.
Table 6.9 shows the state of CCR and EXR after execution of sleep instruction exception
handling. For details, see section 28.10, Sleep Instruction Exception Handling.
Table 6.9
Status of CCR and EXR after Sleep Instruction Exception Handling
CCR
EXR
Interrupt Control Mode
I
UI
T
I2 to I0
0
1
⎯
⎯
⎯
2
1
⎯
0
7
[Legend]
1:
Set to 1
0:
Cleared to 0
⎯:
Retains the previous value.
Rev. 2.00 Oct. 21, 2009 Page 121 of 1454
REJ09B0498-0200
Section 6 Exception Handling
6.7.3
Exception Handling by Illegal Instruction
The illegal instructions are general illegal instructions and slot illegal instructions. The exception
handling by the general illegal instruction starts when an undefined code is executed. The
exception handling by the slot illegal instruction starts when a particular instruction (e.g. its code
length is two words or more, or it changes the PC contents) at a delay slot (immediately after a
delayed branch instruction) is executed. The exception handling by the general illegal instruction
and slot illegal instruction is always executable in the program execution state.
The exception handling is as follows:
1. The contents of PC, CCR, and EXR are saved in the stack.
2. The interrupt mask bit is updated and the T bit is cleared to 0.
3. An exception handling vector table address corresponding to the occurred exception is
generated, the start address of the exception service routine is loaded from the vector table to
PC, and program execution starts from that address.
Table 6.10 shows the state of CCR and EXR after execution of illegal instruction exception
handling.
Table 6.10 Status of CCR and EXR after Illegal Instruction Exception Handling
CCR
EXR
Interrupt Control Mode
I
UI
T
I2 to I0
0
1
⎯
⎯
⎯
2
1
⎯
0
⎯
[Legend]
1:
Set to 1
0:
Cleared to 0
⎯:
Retains the previous value.
Rev. 2.00 Oct. 21, 2009 Page 122 of 1454
REJ09B0498-0200
Section 6 Exception Handling
6.8
Stack Status after Exception Handling
Figure 6.3 shows the stack after completion of exception handling.
Advanced mode
SP
EXR
Reserved*
SP
CCR
PC (24 bits)
Interrupt control mode 0
CCR
PC (24 bits)
Interrupt control mode 2
Note: * Ignored on return.
Figure 6.3 Stack Status after Exception Handling
Rev. 2.00 Oct. 21, 2009 Page 123 of 1454
REJ09B0498-0200
Section 6 Exception Handling
6.9
Usage Note
When performing stack-manipulating access, this LSI assumes that the lowest address bit is 0. The
stack should always be accessed by a word transfer instruction or a 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)
Performing stack manipulation while SP is set to an odd value leads to an address error. Figure 6.4
shows an example of operation when the SP value is odd.
Address
CCR
SP
R1L
SP
H'FFFEFA
H'FFFEFB
PC
PC
H'FFFEFC
H'FFFEFD
H'FFFEFE
SP
H'FFFEFF
TRAPA instruction executed
SP set to H'FFFEFF
MOV.B R1L, @-ER7 executed
Data saved above SP
Contents of CCR lost
(Address error occurred)
[Legend]
CCR :
PC :
R1L :
SP :
Condition code register
Program counter
General register R1L
Stack pointer
Note: This diagram illustrates an example in which the interrupt control mode is 0, in advanced mode.
Figure 6.4 Operation when SP Value is Odd
Rev. 2.00 Oct. 21, 2009 Page 124 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Section 7 Interrupt Controller
7.1
Features
• Two interrupt control modes
Any of two interrupt control modes can be set by means of bits INTM1 and INTM0 in the
interrupt control register (INTCR).
• Priority can be assigned by the interrupt priority register (IPR)
IPR provides for setting interrupt priory. Eight levels can be set for each module for all
interrupts except for the interrupt requests listed below. The following eight interrupt requests
are given priority of 8, therefore they are accepted at all times.
⎯ NMI
⎯ Illegal instructions
⎯ Trace
⎯ Trap instructions
⎯ CPU address error
⎯ DMA address error (occurred in the DTC, DMAC and EXDMAC)
⎯ Sleep instruction
⎯ UBC break interrupt
• 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.
• Thirteen external interrupts
NMI is the highest-priority interrupt, and is accepted at all times. Rising edge or falling edge
detection can be selected for NMI. Falling edge, rising edge, or both edge detection, or level
sensing, can be selected for IRQ11 to IRQ0.
• DTC, DMAC control
DTC and DMAC can be activated by means of interrupts.
• CPU priority control function
The priority levels can be assigned to the CPU, DTC, DMAC and EXDMAC. The priority
level of the CPU can be automatically assigned on an exception generation. Priority can be
given to the CPU interrupt exception handling over that of the DTC, DMAC and EXDMAC
transfer.
Rev. 2.00 Oct. 21, 2009 Page 125 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
A block diagram of the interrupt controller is shown in figure 7.1.
CPU
INTM1, INTM0
INTCR
IPR
NMIEG
I
I2 to I0
NMI input
IRQ input unit
Internal interrupt
sources
WOVI to RESUME
CPU
vector
ISR
Priority
determination
ISCR
IER
EXR
CPU
interrupt request
NMI input unit
IRQ11 to 0 input
TM32K
IRQ15 input
LVD*
IRQ14 input
CCR
SSIER
DMAC
activation
permission
DMAC
DMAC priority
control
DMDR
Source selector
CPU priority
DTCER
DTCCR
CPUPCR
DTC priority
control
DTC priority
DTC
activation
request
DTC
DTC vector
Activation
request
clear signal
Interrupt controller
[Legend]
INTCR:
CPUPCR:
ISCR:
IER:
ISR:
Interrupt control register
CPU priority control register
IRQ sense control register
IRQ enable register
IRQ status register
SSIER:
IPR:
DTCER:
DTCCR:
Software standby release IRQ enable register
Interrupt priority register
DTC enable register
DTC control register
Note: * Supported only by the H8SX/1665M Group.
Figure 7.1 Block Diagram of Interrupt Controller
Rev. 2.00 Oct. 21, 2009 Page 126 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.2
Input/Output Pins
Table 7.1 shows the pin configuration of the interrupt controller.
Table 7.1
Pin Configuration
Name
I/O
Function
NMI
Input
Nonmaskable External Interrupt
Rising or falling edge can be selected.
IRQ11 to IRQ0
Input
Maskable External Interrupts
Rising, falling, or both edges, or level sensing, can be
independently selected.
7.3
Register Descriptions
The interrupt controller has the following registers.
• Interrupt control register (INTCR)
• CPU priority control register (CPUPCR)
• Interrupt priority registers A to O, Q, and R
(IPRA to IPRO, IPRQ, and IPRR)
• IRQ enable register (IER)
• IRQ sense control registers H and L (ISCRH, ISCRL)
• IRQ status register (ISR)
• Software standby release IRQ enable register (SSIER)
Rev. 2.00 Oct. 21, 2009 Page 127 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.3.1
Interrupt Control Register (INTCR)
INTCR selects the interrupt control mode, and the edge to detect NMI.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
INTM1
INTM0
NMIEG
⎯
⎯
⎯
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R/W
R/W
R/W
R
R
R
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
⎯
0
R
These are read-only bits and cannot be modified.
5
INTM1
0
R/W
Interrupt Control Select Mode 1 and 0
4
INTM0
0
R/W
These bits select either of two interrupt control modes for
the interrupt controller.
00: Interrupt control mode 0
Interrupts are controlled by I bit in CCR.
01: Setting prohibited.
10: Interrupt control mode 2
Interrupts are controlled by bits I2 to I0 in EXR, and
IPR.
11: Setting prohibited.
3
NMIEG
0
R/W
NMI Edge Select
Selects the input edge for the NMI pin.
0: Interrupt request generated at falling edge of NMI input
1: Interrupt request generated at rising edge of NMI input
2 to 0
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 128 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.3.2
CPU Priority Control Register (CPUPCR)
CPUPCR sets whether or not the CPU has priority over the DTC, DMAC and EXDMAC. The
interrupt exception handling by the CPU can be given priority over that of the DTC, DMAC and
EXDMAC transfer. The priority level of the DTC is set by bits DTCP2 to DTCP0 in CPUPCR.
The priority level of the DMAC and EXDMAC is set by the DMAC and EXDMAC control
register for each channel.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
CPUPCE
DTCP2
DTCP1
DTCP0
IPSETE
CPUP2
CPUP1
CPUP0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/(W)*
R/(W)*
R/(W)*
Note: * When the IPSETE bit is set to 1, the CPU priority is automatically updated, so these bits cannot be modified.
Bit
Bit Name
Initial
Value
R/W
Description
7
CPUPCE
0
R/W
CPU Priority Control Enable
Controls the CPU priority control function. Setting this bit
to 1 enables the CPU priority control over the DTC,
DMAC and EXDMAC.
0: CPU always has the lowest priority
1: CPU priority control enabled
6
DTCP2
0
R/W
DTC Priority Level 2 to 0
5
DTCP1
0
R/W
These bits set the DTC priority level.
4
DTCP0
0
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)
Rev. 2.00 Oct. 21, 2009 Page 129 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Bit
Bit Name
Initial
Value
R/W
Description
3
IPSETE
0
R/W
Interrupt Priority Set Enable
Controls the function which automatically assigns the
interrupt priority level of the CPU. Setting this bit to 1
automatically sets bits CPUP2 to CPUP0 by the CPU
interrupt mask bit (I bit in CCR or bits I2 to I0 in EXR).
0: Bits CPUP2 to CPUP0 are not updated automatically
1: The interrupt mask bit value is reflected in bits
CPUP2 to CPUP0
2
CPUP2
0
R/(W)*
CPU Priority Level 2 to 0
1
CPUP1
0
R/(W)*
0
CPUP0
0
R/(W)*
These bits set the CPU priority level. When the
CPUPCE is set to 1, the CPU priority control function
over the DTC, DMAC and EXDMAC becomes valid and
the priority of CPU processing is assigned in
accordance with the settings of bits CPUP2 to CPUP0.
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)
Note:
*
When the IPSETE bit is set to 1, the CPU priority is automatically updated, so these bits
cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 130 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.3.3
Interrupt Priority Registers A to O, Q, and R
(IPRA to IPRO, IPRQ, and IPRR)
IPR sets priory (levels 7 to 0) for interrupts other than NMI.
Setting a value in the range from B'000 to B'111 in the 3-bit groups of bits 14 to 12, 10 to 8, 6 to 4,
and 2 to 0 assigns a priority level to the corresponding interrupt. For the correspondence between
the interrupt sources and the IPR settings, see table 7.2.
Bit
15
14
13
12
11
10
9
8
Bit Name
⎯
IPR14
IPR13
IPR12
⎯
IPR10
IPR9
IPR8
Initial Value
0
1
1
1
0
1
1
1
R/W
R
R/W
R/W
R/W
R
R/W
R/W
R/W
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
IPR6
IPR5
IPR4
⎯
IPR2
IPR1
IPR0
Initial Value
0
1
1
1
0
1
1
1
R/W
R
R/W
R/W
R/W
R
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
15
⎯
0
R
14
13
12
IPR14
IPR13
IPR12
1
1
1
R/W
R/W
R/W
11
⎯
0
R
Reserved
This is a read-only bit and cannot be modified.
Sets the priority level of the corresponding interrupt
source.
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)
Reserved
This is a read-only bit and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 131 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Bit
Bit Name
Initial
Value
R/W
Description
10
9
8
IPR10
IPR9
IPR8
1
1
1
R/W
R/W
R/W
7
⎯
0
R
Sets the priority level of the corresponding interrupt
source.
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)
Reserved
This is a read-only bit and cannot be modified.
6
5
4
IPR6
IPR5
IPR4
1
1
1
R/W
R/W
R/W
3
⎯
0
R
Sets the priority level of the corresponding interrupt
source.
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)
Reserved
This is a read-only bit and cannot be modified.
2
IPR2
1
R/W
1
IPR1
1
R/W
Sets the priority level of the corresponding interrupt
source.
0
IPR0
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)
Rev. 2.00 Oct. 21, 2009 Page 132 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.3.4
IRQ Enable Register (IER)
IER enables interrupt requests IRQ15, IRQ14, and IRQ11 to IRQ0.
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Note: *
15
14
13
12
11
10
9
8
IRQ15E
IRQ14E*
⎯
⎯
IRQ11E
IRQ10E
IRQ9E
IRQ8E
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
IRQ7E
IRQ6E
IRQ5E
IRQ4E
IRQ3E
IRQ2E
IRQ1E
IRQ0E
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Supported only by the H8SX/1665M Group.
Bit
Bit Name
Initial
Value
R/W
Description
15
IRQ15E
0
R/W
14
IRQ14E*
0
R/W
13, 12
⎯
All 0
R/W
IRQ15 Enable
The IRQ15 interrupt request is enabled when this bit is
1. IRQ15 is internally connected to the 32KOVI interrupt
in the TM32K.
IRQ14 Enable
The IRQ14 interrupt request is enabled when this bit is
1. IRQ14 is internally connected to the voltagemonitoring interrupt in the LVD
Reserved
These bits are always read as 0. The write value should
always be 0.
11
IRQ11E
0
R/W
IRQ11 Enable
The IRQ11 interrupt request is enabled when this bit is
1.
10
IRQ10E
0
R/W
IRQ10 Enable
The IRQ10 interrupt request is enabled when this bit is
1.
9
IRQ9E
0
R/W
IRQ9 Enable
The IRQ9 interrupt request is enabled when this bit is 1.
8
IRQ8E
0
R/W
IRQ8 Enable
The IRQ8 interrupt request is enabled when this bit is 1.
Rev. 2.00 Oct. 21, 2009 Page 133 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
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
The IRQ5 interrupt request is enabled when this bit is 1.
4
IRQ4E
0
R/W
IRQ4 Enable
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
0
IRQ0E
0
R/W
IRQ0 Enable
The IRQ1 interrupt request is enabled when this bit is 1.
The IRQ0 interrupt request is enabled when this bit is 1.
Note:
7.3.5
*
Supported only by the H8SX/1665M Group.
IRQ Sense Control Registers H and L (ISCRH, ISCRL)
ISCRH and ISCRL select the source that generates an interrupt request from IRQ15, IRQ14, and
IRQ11 to IRQ0 input.
Upon changing the setting of ISCR, IRQnF (n = 0 to 11, 14, 15) in ISR is often set to 1
accidentally through an internal operation. In this case, an interrupt exception handling is executed
if an IRQn interrupt request is enabled. In order to prevent such an accidental interrupt from
occurring, the setting of ISCR should be changed while the IRQn interrupt is disabled, and then
the IRQnF in ISR should be cleared to 0.
Rev. 2.00 Oct. 21, 2009 Page 134 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
• ISCRH
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
15
14
13
12
11
10
9
8
IRQ15SR
IRQ15SF
IRQ14SR*
IRQ14SF*
⎯
⎯
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
IRQ11SR
IRQ11SF
IRQ10SR
IRQ10SF
IRQ9SR
IRQ9SF
IRQ8SR
IRQ8SF
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
IRQ7SR
IRQ7SF
IRQ6SR
IRQ6SF
IRQ5SR
IRQ5SF
IRQ4SR
IRQ4SF
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
IRQ3SR
IRQ3SF
IRQ2SR
IRQ2SF
IRQ1SR
IRQ1SF
IRQ0SR
IRQ0SF
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
• ISCRL
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Note: * Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 135 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
• ISCRH
Bit
Bit Name
Initial
Value
R/W
Description
15
IRQ15SR
0
R/W
14
IRQ15SF
0
R/W
IRQ15 Sense Control Rise
IRQ15 Sense Control Fall
IRQ15 is used as the 32KOVI interrupt in the TM32K.
Set falling edge interrupt request for use.
00: Initial setting
01: Interrupt request generated at falling edge of IRQ15
10: Setting prohibited
11: Setting prohibited
13
IRQ14SR*
0
R/W
IRQ14 Sense Control Rise
12
IRQ14SF*
0
R/W
IRQ14 Sense Control Fall
IRQ14 is used as the voltage monitoring interrupt in
LVD. Set falling edge interrupt request for use.
00: Initial value
01: Interrupt request generated at falling edge of IRQ14
input
10: Setting is prohibited
11: Setting is prohibited
11 to 8 ⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
7
IRQ11SR
0
R/W
6
IRQ11SF
0
R/W
IRQ11 Sense Control Rise
IRQ11 Sense Control Fall
00: Interrupt request generated by low level of IRQ11
01: Interrupt request generated at falling edge of IRQ11
10: Interrupt request generated at rising edge of IRQ11
11: Interrupt request generated at both falling and rising
edges of IRQ11
5
IRQ10SR
0
R/W
4
IRQ10SF
0
R/W
IRQ10 Sense Control Rise
IRQ10 Sense Control Fall
00: Interrupt request generated by low level of IRQ10
01: Interrupt request generated at falling edge of IRQ10
10: Interrupt request generated at rising edge of IRQ10
11: Interrupt request generated at both falling and rising
edges of IRQ10
Rev. 2.00 Oct. 21, 2009 Page 136 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Bit
Bit Name
Initial
Value
R/W
Description
3
IRQ9SR
0
R/W
2
IRQ9SF
0
R/W
IRQ9 Sense Control Rise
IRQ9 Sense Control Fall
00: Interrupt request generated by low level of IRQ9
01: Interrupt request generated at falling edge of IRQ9
10: Interrupt request generated at rising edge of IRQ9
11: Interrupt request generated at both falling and rising
edges of IRQ9
1
IRQ8SR
0
R/W
0
IRQ8SF
0
R/W
IRQ8 Sense Control Rise
IRQ8 Sense Control Fall
00: Interrupt request generated by low level of IRQ8
01: Interrupt request generated at falling edge of IRQ8
10: Interrupt request generated at rising edge of IRQ8
11: Interrupt request generated at both falling and rising
edges of IRQ8
Note:
*
Supported only by the H8SX/1665M.
Rev. 2.00 Oct. 21, 2009 Page 137 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
• ISCRL
Bit
Bit Name
Initial
Value
R/W
Description
15
IRQ7SR
0
R/W
14
IRQ7SF
0
R/W
IRQ7 Sense Control Rise
IRQ7 Sense Control Fall
00: Interrupt request generated by low level of IRQ7
01: Interrupt request generated at falling edge of IRQ7
10: Interrupt request generated at rising edge of IRQ7
11: Interrupt request generated at both falling and rising
edges of IRQ7
13
IRQ6SR
0
R/W
12
IRQ6SF
0
R/W
IRQ6 Sense Control Rise
IRQ6 Sense Control Fall
00: Interrupt request generated by low level of IRQ6
01: Interrupt request generated at falling edge of IRQ6
10: Interrupt request generated at rising edge of IRQ6
11: Interrupt request generated at both falling and rising
edges of IRQ6
11
IRQ5SR
0
R/W
10
IRQ5SF
0
R/W
IRQ5 Sense Control Rise
IRQ5 Sense Control Fall
00: Interrupt request generated by low level of IRQ5
01: Interrupt request generated at falling edge of IRQ5
10: Interrupt request generated at rising edge of IRQ5
11: Interrupt request generated at both falling and rising
edges of IRQ5
9
IRQ4SR
0
R/W
8
IRQ4SF
0
R/W
IRQ4 Sense Control Rise
IRQ4 Sense Control Fall
00: Interrupt request generated by low level of IRQ4
01: Interrupt request generated at falling edge of IRQ4
10: Interrupt request generated at rising edge of IRQ4
11: Interrupt request generated at both falling and rising
edges of IRQ4
7
IRQ3SR
0
R/W
6
IRQ3SF
0
R/W
IRQ3 Sense Control Rise
IRQ3 Sense Control Fall
00: Interrupt request generated by low level of IRQ3
01: Interrupt request generated at falling edge of IRQ3
10: Interrupt request generated at rising edge of IRQ3
11: Interrupt request generated at both falling and rising
edges of IRQ3
Rev. 2.00 Oct. 21, 2009 Page 138 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Bit
Bit Name
Initial
Value
R/W
Description
5
IRQ2SR
0
R/W
4
IRQ2SF
0
R/W
IRQ2 Sense Control Rise
IRQ2 Sense Control Fall
00: Interrupt request generated by low level of IRQ2
01: Interrupt request generated at falling edge of IRQ2
10: Interrupt request generated at rising edge of IRQ2
11: Interrupt request generated at both falling and rising
edges of IRQ2
3
IRQ1SR
0
R/W
2
IRQ1SF
0
R/W
IRQ1 Sense Control Rise
IRQ1 Sense Control Fall
00: Interrupt request generated by low level of IRQ1
01: Interrupt request generated at falling edge of IRQ1
10: Interrupt request generated at rising edge of IRQ1
11: Interrupt request generated at both falling and rising
edges of IRQ1
1
IRQ0SR
0
R/W
0
IRQ0SF
0
R/W
IRQ0 Sense Control Rise
IRQ0 Sense Control Fall
00: Interrupt request generated by low level of IRQ0
01: Interrupt request generated at falling edge of IRQ0
10: Interrupt request generated at rising edge of IRQ0
11: Interrupt request generated at both falling and rising
edges of IRQ0
Rev. 2.00 Oct. 21, 2009 Page 139 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.3.6
IRQ Status Register (ISR)
ISR is an IRQ15, IRQ14, and IRQ11 to IRQ0 interrupt request register.
Bit
Bit Name
15
14
13
12
11
10
9
8
IRQ15F
IRQ14F*2
⎯
⎯
IRQ11F
IRQ10F
IRQ9F
IRQ8F
0
0
0
0
0
0
0
0
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
7
6
5
4
3
2
1
0
IRQ7F
IRQ6F
IRQ5F
IRQ4F
IRQ3F
IRQ2F
IRQ1F
IRQ0F
0
0
0
0
0
0
0
0
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Notes: 1. Only 0 can be written, to clear the flag. The bit manipulation instructions or memory operation instructions should
be used to clear the flag.
2. Supported only by the H8SX/1665M Group.
Bit
15
Bit Name
IRQ15F
Initial
Value
0
R/W
Description
1
R/(W)*
[Setting condition]
•
When the interrupt selected by ISCR occurs
[Clearing conditions]
14
IRQ14F*2
0
R/(W)*1
•
Writing 0 after reading IRQ15F = 1
•
When IRQ15 interrupt exception handling is
executed while falling-edge sensing is selected
[Setting condition]
•
When the interrupt selected by ISCR occurs
[Clearing conditions]
13, 12
⎯
All 0
R/(W)*1
•
Writing 0 after reading IRQ14 = 1
•
When IRQ14 interrupt exception handling is
executed while falling-edge sensing is selected
Reserved
These bits are always read as 0. The write value should
always be 0.
Rev. 2.00 Oct. 21, 2009 Page 140 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Bit
Bit Name
11
IRQ11F
10
IRQ10F
Initial
Value
0
R/W
Description
1
[Setting condition]
1
•
1
[Clearing conditions]
1
•
Writing 0 after reading IRQnF = 1 (n = 11 to 0)
1
•
When interrupt exception handling is executed while
low-level sensing is selected and IRQn input is high
•
When IRQn interrupt exception handling is executed
while falling-, rising-, or both-edge sensing is
selected
•
When the DTC is activated by an IRQn interrupt,
and the DISEL bit in MRB of the DTC is cleared to 0
R/(W)*
R/(W)*
0
9
IRQ9F
0
R/(W)*
8
IRQ8F
0
R/(W)*
7
IRQ7F
R/(W)*
0
1
6
IRQ6F
0
R/(W)*
5
IRQ5F
0
R/(W)*
1
1
4
IRQ4F
0
R/(W)*
3
IRQ3F
0
R/(W)*
2
IRQ2F
0
R/(W)*
1
IRQ1F
0
R/(W)*
0
IRQ0F
0
R/(W)*
1
1
1
When the interrupt selected by ISCR occurs
1
Notes: 1. Only 0 can be written, to clear the flag.
2. Supported only by the H8SX/1665M Group.
7.3.7
Software Standby Release IRQ Enable Register (SSIER)
SSIER selects the IRQ interrupt used to leave software standby mode.
The IRQ interrupt used to leave software standby mode should not be set as the DTC activation
source.
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
15
14
13
12
11
10
9
8
SSI15
⎯
⎯
⎯
SSI11
SSI10
SSI9
SSI8
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
SSI7
SSI6
SSI5
SSI4
SSI3
SSI2
SSI1
SSI0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 141 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Bit
Bit Name
Initial
Value
R/W
Description
15
SSI15
0
R/W
Software Standby Release IRQ Setting
This bit selects the IRQ15 interrupt used to leave
software standby mode.
0: An IRQ15 request is not sampled in software standby
mode
1: When an IRQ15 request occurs in software standby
mode, this LSI leaves software standby mode after
the oscillation settling time has elapsed
14 to 12
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
11
SSI11
0
R/W
Software Standby Release IRQ Setting
10
SSI10
0
R/W
9
SSI9
0
R/W
These bits select the IRQn interrupt used to leave
software standby mode (n = 11 to 0).
8
SSI8
0
R/W
7
SSI7
0
R/W
6
SSI6
0
R/W
5
SSI5
0
R/W
4
SSI4
0
R/W
3
SSI3
0
R/W
2
SSI2
0
R/W
1
SSI1
0
R/W
0
SSI0
0
R/W
Rev. 2.00 Oct. 21, 2009 Page 142 of 1454
REJ09B0498-0200
0: An IRQn request is not sampled in software standby
mode
1: When an IRQn request occurs in software standby
mode, this LSI leaves software standby mode after
the oscillation settling time has elapsed
Section 7 Interrupt Controller
7.4
Interrupt Sources
7.4.1
External Interrupts
There are thirteen external interrupts: NMI and IRQ11 to IRQ0. These interrupts can be used to
leave software standby mode.
(1)
NMI Interrupts
Nonmaskable interrupt request (NMI) is the highest-priority interrupt, and is always accepted by
the CPU regardless of the interrupt control mode or the settings of the CPU interrupt mask bits.
The NMIEG bit in INTCR selects whether an interrupt is requested at the rising or falling edge on
the NMI pin.
When an NMI interrupt is generated, the interrupt controller determines that an error has occurred,
and performs the following procedure.
•
•
•
•
Sets the ERR bit of DTCCR in the DTC to 1.
Sets the ERRF bit of DMDR_0 in the DMAC to 1
Sets the ERRF bit of EDMDR_0 in EXDMAC to 1.
Clears the DTE bits of DMDRs for all channels in the DMAC to 0 to forcibly terminate
transfer.
• The DTE bits in EDMDR of all channels in EXDMAC are cleared to 0, and transfer is forcibly
terminated.
(2)
IRQn Interrupts
An IRQn interrupt is requested by a signal input on pins IRQ11 to IRQ0. IRQn (n = 11 to 0) 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, on pins IRQn.
• Enabling or disabling of interrupt requests IRQn can be selected by IER.
• The interrupt priority can be set by IPR.
• The status of interrupt requests IRQn is indicated in ISR. ISR flags can be cleared to 0 by
software. The bit manipulation instructions and memory operation instructions should be used
to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 143 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Detection of IRQn interrupts is enabled through the P1ICR, P2ICR, P5ICR, and P6ICR register
settings, and does not change regardless of the output setting. However, when a pin is used as an
external interrupt input pin, the pin must not be used as an I/O pin for another function by clearing
the corresponding DDR bit to 0.
A block diagram of interrupts IRQn is shown in figure 7.2.
Corresponding bit
in ICR
IRQnSF, IRQnSR
Input buffer
Edge/level
detection circuit
IRQnE
IRQnF
IRQn interrupt request
S
Q
R
IRQn input
Clear signal
[Legend]
n = 11 to 0
Figure 7.2 Block Diagram of Interrupts IRQn
When the IRQ sensing control in ISCR is set to a low level of signal IRQn, the level of IRQn
should be held low until an interrupt handling starts. Then set the corresponding input signal IRQn
to high in the interrupt handling routine and clear the IRQnF to 0. Interrupts may not be executed
when the corresponding input signal IRQn is set to high before the interrupt handling begins.
7.4.2
Internal Interrupts
The sources for internal interrupts from on-chip peripheral modules have the following features:
• For each on-chip peripheral module there are flags that indicate the interrupt request status,
and enable bits that enable or disable these interrupts. They can be controlled independently.
When the enable bit is set to 1, an interrupt request is issued to the interrupt controller.
• The interrupt priority can be set by means of IPR.
• The DTC and DMAC can be activated by a TPU, SCI, or other interrupt request.
• The priority levels of DTC and DMAC activation can be controlled by the DTC and DMAC
priority control functions.
Rev. 2.00 Oct. 21, 2009 Page 144 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.5
Interrupt Exception Handling Vector Table
Table 7.2 lists interrupt exception handling sources, vector address offsets, and interrupt priority.
In the default priority order, a lower vector number corresponds to a higher priority. When
interrupt control mode 2 is set, priority levels can be changed by setting the IPR contents. The
priority for interrupt sources allocated to the same level in IPR follows the default priority, that is,
they are fixed.
Table 7.2
Interrupt Sources, Vector Address Offsets, and Interrupt Priority
Vector Address Offset*
Vector
1
DTC
DMAC
Classification
Interrupt Source Number
Advanced Mode, Middle
Mode, Maximum Mode
IPR
Priority
Activation
Activation
External pin
NMI
7
H'001C
⎯
High
⎯
⎯
UBC
UBC break
14
H'0038
⎯
⎯
⎯
IRQ0
64
H'0100
IPRA14 to IPRA12
O
⎯
IRQ1
65
H'0104
IPRA10 to IPRA8
O
⎯
IRQ2
66
H'0108
IPRA6 to IPRA4
O
⎯
IRQ3
67
H'010C
IPRA2 to IPRA0
O
⎯
IRQ4
68
H'0110
IPRB14 to IPRB12
O
⎯
IRQ5
69
H'0114
IPRB10 to IPRB8
O
⎯
IRQ6
70
H'0118
IPRB6 to IPRB4
O
⎯
IRQ7
71
H'011C
IPRB2 to IPRB0
O
⎯
IRQ8
72
H'0120
IPRC14 to IPRC12
O
⎯
IRQ9
73
H'0124
IPRC10 to IPRC8
O
⎯
IRQ10
74
H'0128
IPRC6 to IPRC4
O
⎯
IRQ11
75
H'012C
IPRC2 to IPRC0
O
⎯
Reserved for
76
H'0130
⎯
⎯
⎯
77
H'0134
⎯
⎯
78
H'0138
IPRD6 to IPRD4
⎯
⎯
79
H'013C
IPRD2 to IPRD0
⎯
⎯
interrupt
External pin
⎯
system use
LVD*
2
Voltagemonitoring
interrupt (IRQ14)
TM32K
32KOVI (IRQ15)
Low
Rev. 2.00 Oct. 21, 2009 Page 145 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Vector Address Offset*
Vector
1
DTC
DMAC
Classification
Interrupt Source Number
Advanced Mode, Middle
Mode, Maximum Mode
IPR
Priority
Activation
Activation
⎯
Reserved for
80
H'0140
⎯
High
⎯
⎯
system use
WDT
WOVI
81
H'0144
IPRE10 to IPRE8
⎯
⎯
⎯
Reserved for
82
H'0148
⎯
⎯
⎯
CMI
83
H'014C
IPRE2 to IPRE0
⎯
⎯
Reserved for
84
H'0150
⎯
⎯
⎯
85
H'0154
⎯
⎯
system use
Refresh
controller
⎯
system use
A/D_0
ADI0
86
H'0158
IPRF10 to IPRF8
O
O
⎯
Reserved for
87
H'015C
⎯
⎯
⎯
TGI0A
88
H'0160
IPRF6 to IPRF4
O
O
TGI0B
89
H'0164
O
⎯
TGI0C
90
H'0168
O
⎯
TGI0D
91
H'016C
O
⎯
system use
TPU_0
TPU_1
TPU_2
TPU_3
⎯
⎯
O
O
H'0178
O
⎯
95
H'017C
⎯
⎯
TCI1U
96
H'0180
⎯
⎯
TGI2A
97
H'0184
O
O
TGI2B
98
H'0188
O
⎯
TCI2V
99
H'018C
⎯
⎯
TCI0V
92
H'0170
TGI1A
93
H'0174
TGI1B
94
TCI1V
IPRF2 to IPRF0
IPRG14 to IPRG12
⎯
⎯
O
O
H'0198
O
⎯
103
H'019C
O
⎯
TGI3D
104
H'01A0
O
⎯
TCI3V
105
H'01A4
⎯
⎯
TCI2U
100
H'0190
TGI3A
101
H'0194
TGI3B
102
TGI3C
Rev. 2.00 Oct. 21, 2009 Page 146 of 1454
REJ09B0498-0200
IPRG10 to IPRG8
Low
Section 7 Interrupt Controller
Vector Address Offset*
Vector
1
DTC
DMAC
Classification
Interrupt Source Number
Mode, Maximum Mode
IPR
Priority
Activation
Activation
TPU_4
TGI4A
106
H'01A8
IPRG6 to IPRG4
High
O
O
TGI4B
107
H'01AC
O
⎯
TCI4V
108
H'01B0
⎯
⎯
TCI4U
109
H'01B4
⎯
⎯
TGI5A
110
H'01B8
O
O
TGI5B
111
H'01BC
O
⎯
TCI5V
112
H'01C0
⎯
⎯
TCI5U
113
H'01C4
⎯
⎯
Reserved for
114
H'01C8
⎯
⎯
115
H'01CC
⎯
⎯
CMI0A
116
H'01D0
O
⎯
CMI0B
117
H'01D4
O
⎯
TPU_5
⎯
system use
TMR_0
TMR_1
TMR_2
TMR_3
DMAC
Advanced Mode, Middle
IPRG2 to IPRG0
⎯
IPRH14 to IPRH12
⎯
⎯
O
⎯
H'01E0
O
⎯
121
H'01E4
⎯
⎯
CMI2A
122
H'01E8
O
⎯
CMI2B
123
H'01EC
O
⎯
OV2I
124
H'01F0
⎯
⎯
CMI3A
125
H'01F4
O
⎯
CMI3B
126
H'01F8
O
⎯
OV3I
127
H'01FC
⎯
⎯
DMTEND0
128
H'0200
IPRI14 to IPRI12
O
⎯
DMTEND1
129
H'0204
IPRI10 to IPRI8
O
⎯
DMTEND2
130
H'0208
IPRI6 to IPRI4
O
⎯
DMTEND3
131
H'020C
IPRI2 to IPRI0
O
⎯
OV0I
118
H'01D8
CMI1A
119
H'01DC
CMI1B
120
OV1I
IPRH10 to IPRH8
IPRH6 to IPRH4
IPRH2 to IPRH0
Low
Rev. 2.00 Oct. 21, 2009 Page 147 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Vector Address Offset*
Vector
1
DTC
DMAC
Classification
Interrupt Source Number
Mode, Maximum Mode
IPR
Priority
Activation
Activation
EXDMAC
EXDMTEND0
132
H'0210
IPRJ14 to IPRJ12
High
O
⎯
EXDMTEND1
133
H'0214
IPRJ10 to IPRJ8
O
⎯
EXDMTEND2
134
H'0218
IPRJ6 to IPRJ4
O
⎯
EXDMTEND3
135
H'021C
IPRJ2 to IPRJ0
O
⎯
DMEEND0
136
H'0220
IPRK14 to IPRK12
O
⎯
DMEEND1
137
H'0224
O
⎯
DMEEND2
138
H'0228
O
⎯
DMEEND3
139
H'022C
O
⎯
EXDMEEND0
140
H'0230
O
⎯
EXDMEEND1
141
H'0234
O
⎯
EXDMEEND2
142
H'0238
O
⎯
EXDMEEND3
143
H'023C
O
⎯
DMAC
EXDMAC
SCI_0
SCI_1
SCI_2
⎯
Advanced Mode, Middle
IPRK10 to IPRK8
ERI0
144
H'0240
⎯
⎯
RXI0
145
H'0244
O
O
TXI0
146
H'0248
O
O
TEI0
147
H'024C
⎯
⎯
ERI1
148
H'0250
⎯
⎯
RXI1
149
H'0254
O
O
TXI1
150
H'0258
O
O
TEI1
151
H'025C
⎯
⎯
IPRK6 to IPRK4
IPRK2 to IPRK0
ERI2
152
H'0260
⎯
⎯
RXI2
153
H'0264
O
O
TXI2
154
H'0268
O
O
TEI2
155
H'026C
⎯
⎯
Reserved for
156
H'0270
⎯
⎯
157
H'0274
⎯
⎯
158
H'0278
⎯
⎯
159
H'027C
⎯
⎯
system use
Rev. 2.00 Oct. 21, 2009 Page 148 of 1454
REJ09B0498-0200
IPRL14 to IPRL12
⎯
Low
Section 7 Interrupt Controller
Vector Address Offset*
Vector
1
DTC
DMAC
Classification
Interrupt Source Number
Mode, Maximum Mode
IPR
Priority
Activation
Activation
SCI_4
ERI4
160
H'0280
IPRL6 to IPRL4
High
⎯
⎯
RXI4
161
H'0284
O
O
TXI4
162
H'0288
O
O
TEI4
163
H'028C
⎯
⎯
TGI6A
164
H'0290
O
O
TGI6B
165
H'0294
O
⎯
TGI6C
166
H'0298
O
⎯
TGI6D
167
H'029C
O
⎯
TCI6V
168
H'02A0
IPRM14 to IPRM12
⎯
⎯
TGI7A
169
H'02A4
IPRM10 to IPRM8
O
O
TGI7B
170
H'02A8
O
⎯
TGI7V
171
H'02AC
IPRM6 to IPRM4
⎯
⎯
⎯
⎯
IPRM2 to IPRM0
O
O
O
⎯
⎯
⎯
⎯
⎯
O
O
TPU_6
TPU_7
TPU_8
TPU_9
TPU_10
Advanced Mode, Middle
IPRL2 to IPRL0
TCI7U
172
H'02B0
TGI8A
173
H'02B4
TGI8B
174
H'02B8
TCI8V
175
H'02BC
TCI8U
176
H'02C0
TGI9A
177
H'02C4
TGI9B
178
H'02C8
O
⎯
TGI9C
179
H'02CC
O
⎯
TGI9D
180
H'02D0
O
⎯
TCI9V
181
H'02D4
IPRN6 to IPRN4
⎯
⎯
TGI10A
182
H'02D8
IPRN2 to IPRN0
O
O
TGI10B
183
H'02DC
O
⎯
Reserved for
184
H'02E0
⎯
⎯
185
H'02E4
⎯
⎯
TCI10V
186
H'02E8
O
⎯
TCI10U
187
H'02EC
⎯
⎯
IPRN14 to IPRN12
IPRN10 to IPRN8
⎯
system use
Reserved for
system use
IPRO14 to IPRO12
Low
Rev. 2.00 Oct. 21, 2009 Page 149 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Vector Address Offset*
Vector
1
Advanced Mode, Middle
Classification
Interrupt Source Number
Mode, Maximum Mode
IPR
TPU_11
TGI11A
188
H'02F0
IPRO10 to IPRO8
TGI11B
189
H'02F4
TCI11V
190
H'02F8
TCI11U
191
H'02FC
Reserved for
192
H'0300
⎯
system use
|
Priority
High
IPRO6 to IPRO4
⎯
|
215
H'035C
DTC
DMAC
Activation
Activation
O
O
O
⎯
⎯
⎯
⎯
⎯
⎯
⎯
|
|
⎯
⎯
⎯
⎯
IIC2_0
IICI0
216
H'0360
⎯
Reserved for
217
H'0364
⎯
⎯
IPRQ6 to IPRQ4
system use
IIC2_1
IICI1
218
H'0368
⎯
⎯
⎯
Reserved for
219
H'036C
⎯
⎯
RXI5
220
H'0370
⎯
O
TXI5
221
H'0374
⎯
O
ERI5
222
H'0378
⎯
⎯
system use
SCI_5
IPRQ2 to IPRQ0
⎯
⎯
⎯
O
H'0384
⎯
O
226
H'0388
⎯
⎯
227
H'038C
⎯
⎯
TMR_4
CMIA4 or CMIB4 228
H'0390
⎯
⎯
TMR_5
CMIA5 or CMIB5 229
H'0394
⎯
⎯
TMR_6
CMIA6 or CMIB6 230
H'0398
⎯
⎯
TMR_7
CMIA7 or CMIB7 231
H'039C
⎯
⎯
SCI_6
TEI5
223
H'037C
RXI6
224
H'0380
TXI6
225
ERI6
TEI6
IPRR14 to IPRR12
IPRR10 to IPRR8
Low
Rev. 2.00 Oct. 21, 2009 Page 150 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Vector Address Offset*
Vector
1
DTC
DMAC
Classification
Interrupt Source Number
Mode, Maximum Mode
IPR
Priority
Activation
Activation
USB
USBINTN0
232
H'03A0
IPRR6 to IPRR4
High
⎯
O
USBINTN1
233
H'03A4
⎯
O
USBINTN2
234
H'03A8
⎯
⎯
USBINTN3
235
H'03AC
⎯
⎯
Reserved for
236
H'03B0
⎯
⎯
⎯
Advanced Mode, Middle
IPRR2 to IPRR0
system use
A/D_1
ADI1
237
H'03B4
⎯
O
USB
resume
238
H'03B8
⎯
⎯
⎯
Reserved for
239
H'03BC
⎯
⎯
system use
|
255
⎯
|
H'03FC
Low
|
|
⎯
⎯
Notes: 1. Lower 16 bits of the start address.
2. Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 151 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.6
Interrupt Control Modes and Interrupt Operation
The interrupt controller has two interrupt control modes: interrupt control mode 0 and interrupt
control mode 2. Interrupt operations differ depending on the interrupt control mode. The interrupt
control mode is selected by INTCR. Table 7.3 shows the differences between interrupt control
mode 0 and interrupt control mode 2.
Table 7.3
Interrupt Control Modes
Interrupt
Control
Mode
Priority
Setting
Register
Interrupt
Mask Bit
0
Default
I
The priority levels of the interrupt sources are fixed
default settings.
The interrupts except for NMI is masked by the I bit.
2
IPR
I2 to I0
Eight priority levels can be set for interrupt sources
except for NMI with IPR.
8-level interrupt mask control is performed by bits I2 to I0.
7.6.1
Description
Interrupt Control Mode 0
In interrupt control mode 0, interrupt requests except for NMI are masked by the I bit in CCR of
the CPU. Figure 7.3 shows a flowchart of the interrupt acceptance operation in this case.
1. If an interrupt request occurs when the corresponding interrupt enable bit is set to 1, the
interrupt request is sent to the interrupt controller.
2. If the I bit in CCR is set to 1, NMI is accepted, and other interrupt requests are held pending. If
the I bit is cleared to 0, an interrupt request is accepted.
3. For multiple interrupt requests, the interrupt controller selects the interrupt request with the
highest priority, sends the request to the CPU, and holds other interrupt requests pending.
4. When the CPU accepts the interrupt request, it starts interrupt exception handling after
execution of the current instruction has been completed.
5. The PC and CCR contents are saved to the stack area during the interrupt exception handling.
The PC contents saved on the stack is 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.
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 in the
vector table.
Rev. 2.00 Oct. 21, 2009 Page 152 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Program execution state
No
Interrupt generated?
Yes
Yes
NMI
No
No
I=0
Pending
Yes
No
IRQ0
Yes
No
IRQ1
Yes
TEI4
Yes
Save PC and CCR
I←1
Read vector address
Branch to interrupt handling routine
Figure 7.3 Flowchart of Procedure Up to Interrupt Acceptance
in Interrupt Control Mode 0
Rev. 2.00 Oct. 21, 2009 Page 153 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.6.2
Interrupt Control Mode 2
In interrupt control mode 2, interrupt requests except for NMI are masked by comparing the
interrupt mask level (I2 to I0 bits) in EXR of the CPU and the IPR setting. There are eight levels
in mask control. Figure 7.4 shows a flowchart of the interrupt acceptance operation in this case.
1. If an interrupt request occurs when the corresponding interrupt enable bit is set to 1, an
interrupt request is sent to the interrupt controller.
2. For multiple interrupt requests, the interrupt controller selects the interrupt request with the
highest priority according to the IPR setting, and holds other interrupt requests pending. If
multiple interrupt requests have the same priority, an interrupt request is selected according to
the default setting shown in table 7.2.
3. Next, the priority of the selected interrupt request is compared with the interrupt mask level set
in EXR. When the interrupt request does not have priority over the mask level set, it is held
pending, and only an interrupt request with a priority over 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 contents are saved to the stack area during interrupt exception
handling. The PC saved on the stack is 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 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 in the
vector table.
Rev. 2.00 Oct. 21, 2009 Page 154 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Program execution state
No
Interrupt generated?
Yes
Yes
NMI
No
Level 7 interrupt?
No
No
Yes
Mask level 6
or below?
Yes
Level 6 interrupt?
No
Yes
Level 1 interrupt?
Mask level 5
or below?
No
No
Yes
Yes
Mask level 0?
No
Yes
Save PC, CCR, and EXR
Pending
Clear T bit to 0
Update mask level
Read vector address
Branch to interrupt handling routine
Figure 7.4 Flowchart of Procedure Up to Interrupt Acceptance
in Interrupt Control Mode 2
Rev. 2.00 Oct. 21, 2009 Page 155 of 1454
REJ09B0498-0200
REJ09B0498-0200
Rev. 2.00 Oct. 21, 2009 Page 156 of 1454
Figure 7.5 Interrupt Exception Handling
(1)
(2)
(4)
(3)
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
Iφ
Instruction
prefetch
(6) (8)
(9)
(10)
(11)
(12)
Internal
operation
(6)
(7)
(8)
(10)
(9)
Vector fetch
Internal
operation
(12)
(11)
Saved PC and saved CCR
Vector address
Start address of interrupt handling routine (vector address contents)
Start address of Interrupt handling routine ((11) = (10))
First instruction of interrupt handling routine
(5)
Stack
Instruction
prefetch
in interrupt
handling
routine
7.6.3
Interrupt level determination
Wait for end of instruction
Interrupt
acceptance
Section 7 Interrupt Controller
Interrupt Exception Handling Sequence
Figure 7.5 shows the interrupt exception handling sequence. The example is for the case where
interrupt control mode 0 is set in maximum mode, and the program area and stack area are in onchip memory.
Section 7 Interrupt Controller
7.6.4
Interrupt Response Times
Table 7.4 shows interrupt response times – the interval between generation of an interrupt request
and execution of the first instruction in the interrupt handling routine. The symbols for execution
states used in table 7.4 are explained in table 7.5.
This LSI is capable of fast word transfer to on-chip memory, so allocating the program area in onchip ROM and the stack area in on-chip RAM enables high-speed processing.
Table 7.4
Interrupt Response Times
5
Normal Mode*
Interrupt
Control
Mode 0
Execution State
Interrupt
Control
Mode 2
Advanced Mode
Interrupt
Control
Mode 0
Interrupt
Control
Mode 2
1
Interrupt priority determination*
3
Number of states until executing
2
instruction ends*
1 to 19 + 2·SI
PC, CCR, EXR stacking
6
SK to 2·SK*
2·SK
6
SK to 2·SK*
Vector fetch
Interrupt
Control
Mode 0
Interrupt
Control
Mode 2
2·SK
2·SK
11 to 31
11 to 31
Sh
Instruction fetch*
3
2·SI
4
Internal processing*
Total (using on-chip memory)
Notes: 1.
2.
3.
4.
5.
6.
2·SK
5
Maximum Mode*
2
10 to 31
11 to 31
10 to 31
11 to 31
Two states for an internal interrupt.
In the case of the MULXS or DIVXS instruction
Prefetch after interrupt acceptance or for an instruction in the interrupt handling routine.
Internal operation after interrupt acceptance or after vector fetch
Not available in this LSI.
When setting the SP value to 4n, the interrupt response time is SK; when setting to 4n +
2, the interrupt response time is 2·SK.
Rev. 2.00 Oct. 21, 2009 Page 157 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Table 7.5
Number of Execution States in Interrupt Handling Routine
Object of Access
External Device
8-Bit Bus
16-Bit Bus
Symbol
On-Chip
Memory
2-State
Access
3-State
Access
2-State
Access
3-State
Access
Vector fetch Sh
1
8
12 + 4m
4
6 + 2m
Instruction fetch SI
1
4
6 + 2m
2
3+m
Stack manipulation SK
1
8
12 + 4m
4
6 + 2m
[Legend]
m:
Number of wait cycles in an external device access.
7.6.5
DTC and DMAC Activation by Interrupt
The DTC and DMAC can be activated by an interrupt. In this case, the following options are
available:
•
•
•
•
Interrupt request to the CPU
Activation request to the DTC
Activation request to the DMAC
Combination of the above
For details on interrupt requests that can be used to activate the DTC and DMAC, see table 7.2,
section 10, DMA Controller (DMAC), and section 12, Data Transfer Controller (DTC).
Figure 7.6 shows a block diagram of the DTC, DMAC and interrupt controller.
Rev. 2.00 Oct. 21, 2009 Page 158 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
Select signal
DMRSR_0 to DMRSR_3
Control signal
Interrupt
request
On-chip
peripheral
module
Interrupt request
clear signal
DMAC activation request signal
DMAC
select
circuit
DMAC
Clear signal
DTCER
Clear signal
Select signal
Interrupt request
DTC activation request
vector number
DTC control
Clear signal
DTC/CPU
IRQ
interrupt
Interrupt
request
Interrupt request
clear signal
circuit
Clear
signal
DTC
select
CPU interrupt request
vector number
circuit
Priority
determination
I, I2 to I0
CPU
Interrupt controller
Figure 7.6 Block Diagram of DTC, DMAC, and Interrupt Controller
(1)
Selection of Interrupt Sources
The activation source for each DMAC channel is selected by DMRSR. The selected activation
source is input to the DMAC through the select circuit. When transfer by an on-chip module
interrupt is enabled (DTF1 = 1, DTF0 = 0, and DTE = 1 in DMDR) and the DTA bit in DMDR is
set to 1, the interrupt source selected for the DMAC activation source is controlled by the DMAC
and cannot be used as a DTC activation source or CPU interrupt source.
Interrupt sources that are not controlled by the DMAC are set for DTC activation sources or CPU
interrupt sources by the DTCE bit in DTCERA to DTCERF of the DTC.
Specifying the DISEL bit in MRB of the DTC generates an interrupt request to the CPU by
clearing the DTCE bit to 0 after the individual DTC data transfer.
Note that when the DTC performs a predetermined number of data transfers and the transfer
counter indicates 0, an interrupt request is made to the CPU by clearing the DTCE bit to 0 after the
DTC data transfer.
When the same interrupt source is set as both the DTC and DMAC activation source and CPU
interrupt source, the DTC and DMAC must be given priority over the CPU. If the IPSETE bit in
CPUPCR is set to 1, the priority is determined according to the IPR setting. Therefore, the CPUP
setting or the IPR setting corresponding to the interrupt source must be set to lower than or equal
to the DTCP and DMAP setting. If the CPU is given priority over the DTC or DMAC, the DTC or
DMAC may not be activated, and the data transfer may not be performed.
Rev. 2.00 Oct. 21, 2009 Page 159 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
(2)
Priority Determination
The DTC activation source is selected according to the default priority, and the selection is not
affected by its mask level or priority level. For respective priority levels, see table 12.1, Interrupt
Sources, DTC Vector Addresses, and Corresponding DTCEs.
(3)
Operation Order
If the same interrupt is selected as both the DTC activation source and CPU interrupt source, the
CPU interrupt exception handling is performed after the DTC data transfer. If the same interrupt is
selected as the DTC, DMAC or EXDMAC activation source or CPU interrupt source, respective
operations are performed independently.
Table 7.6 lists the selection of interrupt sources and interrupt source clear control by setting the
DTA bit in DMDR of the DMAC, the DTCE bit in DTCERA to DTCERF of the DTC, and the
DISEL bit in MRB of the DTC.
Table 7.6
Interrupt Source Selection and Clear Control
Setting
DMAC
DTC
Interrupt Source Selection/Clear Control
DTA
DTCE
DISEL
DMAC
DTC
CPU
0
0
*
O
X
√
1
0
O
√
X
1
O
O
√
*
√
X
X
1
*
[Legend]
√: The corresponding interrupt is used. The interrupt source is cleared.
(The interrupt source flag must be cleared in the CPU interrupt handling routine.)
O: The corresponding interrupt is used. The interrupt source is not cleared.
X: The corresponding interrupt is not available.
*: Don't care.
(4)
Usage Note
The interrupt sources of the SCI, and A/D converter are cleared according to the setting shown in
table 7.6, when the DTC or DMAC reads/writes the prescribed register.
To initiate multiple channels for the DTC and DMAC with the same interrupt, the same priority
(DTCP = DMAP) should be assigned.
Rev. 2.00 Oct. 21, 2009 Page 160 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.7
CPU Priority Control Function Over DTC, DMAC and EXDMAC
The interrupt controller has a function to control the priority among the DTC, DMAC, EXDMAC
and the CPU by assigning different priority levels to the DTC, DMAC, EXDMAC and CPU.
Since the priority level can automatically be assigned to the CPU on an interrupt occurrence, it is
possible to execute the CPU interrupt exception handling prior to the DTC, DMAC or EXDMAC
transfer.
The priority level of the CPU is assigned by bits CPUP2 to CPUP0 in CPUPCR. The priority level
of the DTC is assigned by bits DTCP2 to DTCP0 in CPUPCR. The priority level of the DMAC is
assigned by bits DMAP2 to DMAP0 in DMDR for each channel. The priority level of the
EXDMAC is assigned by the bits EDMAP2 to EDMAP0 in EXDMA mode control register 0 to 3
(EDMDR_0 to EDMDR_3) for each channel.
The priority control function over the DTC, DMAC and EXDMAC is enabled by setting the
CPUPCE bit in CPUPCR to 1. When the CPUPCE bit is 1, the DTC, DMAC and EXDMAC
activation sources are controlled according to the respective priority levels.
The DTC activation source is controlled according to the priority level of the CPU indicated by
bits CPUP2 to CPUP0 and the priority level of the DTC indicated by bits DTCP2 to DTCP0. If the
CPU has priority, the DTC activation source is held. The DTC is activated when the condition by
which the activation source is held is cancelled (CPUPCE = 1 and value of bits CPUP2 to CPUP0
is greater than that of bits DTCP2 to DTCP0). The priority level of the DTC is assigned by the
DTCP2 to DTCP0 bits regardless of the activation source.
For the DMAC, the priority level can be specified for each channel. The DMAC activation source
is controlled according to the priority level of each DMAC channel indicated by bits DMAP2 to
DMAP0 and the priority level of the CPU. If the CPU has priority, the DMAC activation source is
held. The DMAC is activated when the condition by which the activation source is held is
cancelled (CPUPCE = 1 and value of bits CPUP2 to CPUP0 is greater than that of bits DMAP2 to
DMAP0). If different priority levels are specified for channels, the channels of the higher priority
levels continue transfer and the activation sources for the channels of lower priority levels than
that of the CPU are held.
The EXDMAC priority level can be assigned in each channel. The EXDMAC activation source is
controlled by both the EXDMAC priority level, which is assigned by the bits EDMAP2 to
EDMAP0 in the corresponding channel, and the CPU priority level. If the CPU has priority, the
activation source for the corresponding channel is held. The activation source is re-enabled when
the condition that has held the activation source is cancelled (CPUPCE = 1 and the value of the
bits CPUP2 to CPUP0 is greater than that of the bits EDMAP2 to EDMAP0). When different
priority level is assigned for each channel, channels having higher priority than CPU continue
Rev. 2.00 Oct. 21, 2009 Page 161 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
transferring processing, while activation sources for channels with lower priority should only be
held.
There are two methods for assigning the priority level to the CPU by the IPSETE bit in CPUPCR.
Setting the IPSETE bit to 1 enables a function to automatically assign the value of the interrupt
mask bit of the CPU to the CPU priority level. Clearing the IPSETE bit to 0 disables the function
to automatically assign the priority level. Therefore, the priority level is assigned directly by
software rewriting bits CPUP2 to CPUP0. Even if the IPSETE bit is 1, the priority level of the
CPU is software assignable by rewriting the interrupt mask bit of the CPU (I bit in CCR or I2 to I0
bits in EXR).
The priority level which is automatically assigned when the IPSETE bit is 1 differs according to
the interrupt control mode.
In interrupt control mode 0, the I bit in CCR of the CPU is reflected in bit CPUP2. Bits CPUP1
and CPUP0 are fixed 0. In interrupt control mode 2, the values of bits I2 to I0 in EXR of the CPU
are reflected in bits CPUP2 to CPUP0.
Table 7.7 shows the CPU priority control.
Table 7.7
CPU Priority Control
Control Status
Interrupt
Control Interrupt
Mode
Priority
Interrupt
Mask Bit
0
Default
IPSETE in
CPUPCR CPUP2 to CPUP0
Updating of CPUP2
to CPUP0
I = any
0
B'111 to B'000
Enabled
I=0
1
B'000
Disabled
I=1
2
IPR setting
I2 to I0
Rev. 2.00 Oct. 21, 2009 Page 162 of 1454
REJ09B0498-0200
B'100
0
B'111 to B'000
Enabled
1
I2 to I0
Disabled
Section 7 Interrupt Controller
Table 7.8 shows a setting example of the priority control function over the DTC, DMAC, and
EXDMAC, and the transfer request control state. A priority level can be independently set to each
DMAC or EXDMAC channel, but the table only shows one channel for example. Transfer
through each DMAC or EXDMAC channel can be separately controlled by assigning different
priority levels for channels.
Table 7.8
Example of Priority Control Function Setting and Control State
Interrupt
Control CPUPCE in CPUP2 to
Mode
CPUPCR
CPUP0
Transfer Request Control State
DTCP2 to DMAP2 to EDMAP2 to
DTCP0
DMAP0
EDMAP0
DTC
DMAC
EXDMAC
0
2
0
Any
Any
Any
Any
Enabled Enabled
Enabled
1
B'000
B'000
B'000
B'000
Enabled Enabled
Enabled
B'100
B'000
B'000
B'000
Masked
Masked
Masked
B'100
B'000
B'011
B'100
Masked
Masked
Enabled
B'100
B'111
B'101
B'000
Enabled Enabled
Masked
B'000
B'111
B'101
B'000
Enabled Enabled
Enabled
0
Any
Any
Any
Any
Enabled Enabled
Enabled
1
B'000
B'000
B'000
B'000
Enabled Enabled
Enabled
B'000
B'011
B'101
B'110
Enabled Enabled
Enabled
B'011
B'011
B'101
B'110
Enabled Enabled
Enabled
B'100
B'011
B'101
B'110
Masked
Enabled
Enabled
B'101
B'011
B'101
B'110
Masked
Enabled
Enabled
B'110
B'011
B'101
B'110
Masked
Masked
Enabled
B'111
B'011
B'101
B'110
Masked
Masked
Masked
B'101
B'011
B'101
B'011
Masked
Enabled
Masked
B'101
B'110
B'101
B'011
Enabled Enabled
Masked
Rev. 2.00 Oct. 21, 2009 Page 163 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.8
Usage Notes
7.8.1
Conflict between Interrupt Generation and Disabling
When an interrupt enable bit is cleared to 0 to mask the interrupt, the masking becomes effective
after execution of the instruction.
When an interrupt enable bit is cleared to 0 by an instruction such as BCLR or MOV, 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 with priority
over that interrupt, interrupt exception handling will be executed for the interrupt with priority,
and another interrupt will be ignored. The same also applies when an interrupt source flag is
cleared to 0. Figure 7.7 shows an example in which the TCIEV bit in TIER of the TPU is cleared
to 0. The above conflict will not occur if an enable bit or interrupt source flag is cleared to 0 while
the interrupt is masked.
TIER_0 write cycle by CPU
TCIV exception handling
Pφ
Internal
address bus
TIER_0 address
Internal
write signal
TCIEV
TCFV
TCIV
interrupt signal
Figure 7.7 Conflict between Interrupt Generation and Disabling
Similarly, when an interrupt is requested immediately before the DTC enable bit is changed to
activate the DTC, DTC activation and the interrupt exception handling by the CPU are both
executed. When changing the DTC enable bit, make sure that an interrupt is not requested.
Rev. 2.00 Oct. 21, 2009 Page 164 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.8.2
Instructions that Disable Interrupts
Instructions that disable interrupts immediately after execution are LDC, ANDC, ORC, and
XORC. After any of these instructions is 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.
7.8.3
Times when Interrupts are Disabled
There are times when interrupt acceptance is disabled by the 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, and for a period of
writing to the registers of the interrupt controller.
7.8.4
Interrupts during Execution of EEPMOV Instruction
Interrupt operation differs between the EEPMOV.B and the EEPMOV.W instructions.
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 the end of the individual 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:
7.8.5
EEPMOV.W
MOV.W
R4,R4
BNE
L1
Interrupts during Execution of MOVMD and MOVSD Instructions
With the MOVMD or MOVSD instruction, if an interrupt request is issued during the transfer,
interrupt exception handling starts at the end of the individual transfer cycle. The PC value saved
on the stack in this case is the address of the MOVMD or MOVSD instruction. The transfer of the
remaining data is resumed after returning from the interrupt handling routine.
Rev. 2.00 Oct. 21, 2009 Page 165 of 1454
REJ09B0498-0200
Section 7 Interrupt Controller
7.8.6
Interrupts of Peripheral Modules
To clear an interrupt source flag by the CPU using an interrupt function of a peripheral module,
the flag must be read from after clearing within the interrupt processing routine. This makes the
request signal synchronized with the peripheral module clock. For details, refer to section 27.6.1,
Notes on Clock Pulse Generator.
Rev. 2.00 Oct. 21, 2009 Page 166 of 1454
REJ09B0498-0200
Section 8 User Break Controller (UBC)
Section 8 User Break Controller (UBC)
The user break controller (UBC) generates a UBC break interrupt request each time the state of
the program counter matches a specified break condition. The UBC break interrupt is a nonmaskable interrupt and is always accepted, regardless of the interrupt control mode and the state of
the interrupt mask bit of the CPU.
For each channel, the break control register (BRCR) and break address register (BAR) are used to
specify the break condition as a combination of address bits and type of bus cycle.
Four break conditions are independently specifiable on four channels, A to D.
8.1
Features
• Number of break channels: four (channels A, B, C, and D)
• Break comparison conditions (each channel)
⎯ Address
⎯ Bus master (CPU cycle)
⎯ Bus cycle (instruction execution (PC break))
• UBC break interrupt exception handling is executed immediately before execution of the
instruction fetched from the specified address (PC break).
• Module stop state can be set
Rev. 2.00 Oct. 21, 2009 Page 167 of 1454
REJ09B0498-0200
Section 8 User Break Controller (UBC)
8.2
Block Diagram
Instruction execution pointer
Mode control
Instruction
execution pointer
Break control
Internal bus (input side)
Internal bus (output side)
PC break control
Break
address
BARAH
BARAL
BARBH
BARBL
BARCH
BARCL
Condition
Address
match
comparator determination
BARDH
BARDL
C ch
BRCRC
Flag set control
Condition
Address
match
comparator determination
Break
control
B ch
BRCRA
Sequential control
A ch
A ch PC
Condition match
B ch PC
Condition match
Condition
Address
match
comparator determination
C ch PC
Condition match
D ch
D ch PC
Condition match
BRCRB
Condition
Address
match
comparator determination
BRCRD
CPU status
[Legend]
BARAH, BARAL:
BARBH, BARBL:
BARCH, BARCL:
BARDH, BARDL:
BRCRA:
BRCRB:
BRCRC:
BRCRD:
Break address register A
Break address register B
Break address register C
Break address register D
Break control register A
Break control register B
Break control register C
Break control register D
Figure 8.1 Block Diagram of UBC
Rev. 2.00 Oct. 21, 2009 Page 168 of 1454
REJ09B0498-0200
UBC break
interrupt request
Section 8 User Break Controller (UBC)
8.3
Register Descriptions
Table 8.1 lists the register configuration of the UBC.
Table 8.1
Register Configuration
Register Name
Abbreviation
R/W
Initial Value
Address
Access
Size
Break address register A
BARAH
R/W
H'0000
H'FFA00
16
BARAL
R/W
H'0000
H'FFA02
16
Break address mask register A
Break address register B
Break address mask register B
Break address register C
Break address mask register C
BAMRAH
R/W
H'0000
H'FFA04
16
BAMRAL
R/W
H'0000
H'FFA06
16
BARBH
R/W
H'0000
H'FFA08
16
BARBL
R/W
H'0000
H'FFA0A
16
BAMRBH
R/W
H'0000
H'FFA0C
16
BAMRBL
R/W
H'0000
H'FFA0E
16
BARCH
R/W
H'0000
H'FFA10
16
BARCL
R/W
H'0000
H'FFA12
16
BAMRCH
R/W
H'0000
H'FFA14
16
BAMRCL
R/W
H'0000
H'FFA16
16
BARDH
R/W
H'0000
H'FFA18
16
BARDL
R/W
H'0000
H'FFA1A
16
BAMRDH
R/W
H'0000
H'FFA1C
16
BAMRDL
R/W
H'0000
H'FFA1E
16
Break control register A
BRCRA
R/W
H'0000
H'FFA28
8/16
Break control register B
BRCRB
R/W
H'0000
H'FFA2C
8/16
Break control register C
BRCRC
R/W
H'0000
H'FFA30
8/16
Break control register D
BRCRD
R/W
H'0000
H'FFA34
8/16
Break address register D
Break address mask register D
Rev. 2.00 Oct. 21, 2009 Page 169 of 1454
REJ09B0498-0200
Section 8 User Break Controller (UBC)
8.3.1
Break Address Register n (BARA, BARB, BARC, BARD)
Each break address register n (BARn) consists of break address register nH (BARnH) and break
address register nL (BARnL). Together, BARnH and BARnL specify the address used as a break
condition on channel n of the UBC.
BARnH
Bit:
31
30
29
28
27
26
25
24
23
22
21
20
19
18
17
16
BARn31 BARn30 BARn29 BARn28 BARn27 BARn26 BARn25 BARn24 BARn23 BARn22 BARn21 BARn20 BARn19 BARn18 BARn17 BARn16
Initial Value:
R/W:
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
BARnL
Bit:
BARn15 BARn14 BARn13 BARn12 BARn11 BARn10
Initial Value:
R/W:
9
8
7
6
5
4
3
2
1
0
BARn9
BARn8
BARn7
BARn6
BARn5
BARn4
BARn3
BARn2
BARn1
BARn0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
• BARnH
Bit
Bit Name
31 to 16
BARn31 to
BARn16
Initial
Value
R/W
Description
All 0
R/W
Break Address n31 to 16
These bits hold the upper bit values (bits 31 to 16) for
the address break-condition on channel n.
[Legend]
n = Channels A to D
• BARnL
Bit
Bit Name
15 to 0
BARn15 to
BARn0
Initial
Value
R/W
Description
All 0
R/W
Break Address n15 to 0
[Legend]
n = Channels A to D
Rev. 2.00 Oct. 21, 2009 Page 170 of 1454
REJ09B0498-0200
These bits hold the lower bit values (bits 15 to 0) for
the address break-condition on channel n.
Section 8 User Break Controller (UBC)
8.3.2
Break Address Mask Register n (BAMRA, BAMRB, BAMRC, BAMRD)
Be sure to write H'FF00 0000 to break address mask register n (BAMRn). Operation is not
guaranteed if another value is written here.
BAMRnH
Bit:
31
30
29
28
27
26
25
24
23
22
21
20
19
18
17
16
BAMRn31 BAMRn30 BAMRn29 BAMRn28 BAMRn27 BAMRn26 BAMRn25 BAMRn24 BAMRn23 BAMRn22 BAMRn21 BAMRn20 BAMRn19 BAMRn18 BAMRn17 BAMRn16
Initial Value:
R/W:
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
BAMRnL
Bit:
BAMRn15 BAMRn14 BAMRn13 BAMRn12 BAMRn11 BAMRn10 BAMRn9 BAMRn8 BAMRn7 BAMRn6 BAMRn5 BAMRn4 BAMRn3 BAMRn2 BAMRn1 BAMRn0
Initial Value:
R/W:
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
• BAMRnH
Initial
Value
Bit
Bit Name
31 to 16
BAMRn31 to All 0
BAMRn16
R/W
Description
R/W
Break Address Mask n31 to 16
Be sure to write H'FF00 here before setting a break
condition in the break control register.
[Legend]
n = Channels A to D
• BAMRnL
Initial
Value
Bit
Bit Name
15 to 0
BAMRn15 to All 0
BAMRn0
R/W
Description
R/W
Break Address Mask n15 to 0
Be sure to write H'0000 here before setting a break
condition in the break control register.
[Legend]
n = Channels A to D
Rev. 2.00 Oct. 21, 2009 Page 171 of 1454
REJ09B0498-0200
Section 8 User Break Controller (UBC)
8.3.3
Break Control Register n (BRCRA, BRCRB, BRCRC, BRCRD)
BRCRA, BRCRB, BRCRC, and BRCRD are used to specify and control conditions for channels
A, B, C, and D of the UBC.
Bit:
Initial Value:
R/W:
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
−
−
CMFCPn
−
CPn2
CPn1
CPn0
−
−
−
IDn1
IDn0
RWn1
RWn0
−
−
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
[Legend]
n = Channels A to D
Bit
Bit Name
Initial
Value
R/W
Description
15
⎯
0
R/W
Reserved
14
⎯
0
R/W
These bits are always read as 0. The write value
should always be 0.
13
CMFCPn
0
R/W
Condition Match CPU Flag
UBC break source flag that indicates satisfaction of a
specified CPU bus cycle condition.
0: The CPU cycle condition for channel n break
requests has not been satisfied.
1: The CPU cycle condition for channel n break
requests has been satisfied.
12
⎯
0
R/W
Reserved
These bits are always read as 0. The write value
should always be 0.
11
CPn2
0
R/W
CPU Cycle Select
10
CPn1
0
R/W
9
CPn0
0
R/W
These bits select CPU cycles as the bus cycle break
condition for the given channel.
000: Break requests will not be generated.
001: The bus cycle break condition is CPU cycles.
01x: Setting prohibited
1xx: Setting prohibited
8
⎯
0
R/W
Reserved
7
⎯
0
R/W
6
⎯
0
R/W
These bits are always read as 0. The write value
should always be 0.
Rev. 2.00 Oct. 21, 2009 Page 172 of 1454
REJ09B0498-0200
Section 8 User Break Controller (UBC)
Bit
Bit Name
Initial
Value
R/W
Description
5
IDn1
0
R/W
Break Condition Select
4
IDn0
0
R/W
These bits select the PC break as the source of UBC
break interrupt requests for the given channel.
00: Break requests will not be generated.
01: UBC break condition is the PC break.
1x: Setting prohibited
3
RWn1
0
R/W
Read Select
2
RWn0
0
R/W
These bits select read cycles as the bus cycle break
condition for the given channel.
00: Break requests will not be generated.
01: The bus cycle break condition is read cycles.
1x: Setting prohibited
1
⎯
0
R/W
Reserved
0
⎯
0
R/W
These bits are always read as 0. The write value
should always be 0.
[Legend]
n = Channels A to D
Rev. 2.00 Oct. 21, 2009 Page 173 of 1454
REJ09B0498-0200
Section 8 User Break Controller (UBC)
8.4
Operation
The UBC does not detect condition matches in standby states (sleep mode, all module clock stop
mode, software standby mode, deep software standby, and hardware standby mode).
8.4.1
Setting of Break Control Conditions
1. The address condition for the break is set in break address register n (BARn). A mask for the
address is set in break address mask register n (BAMRn).
2. The bus and break conditions are set in break control register n (BRCRn). Bus conditions
consist of CPU cycle, PC break, and reading. Condition comparison is not performed when the
CPU cycle setting is CPn = B'000, the PC break setting is IDn = B'00, or the read setting is
RWn = B'00.
3. The condition match CPU flag (CMFCPn) is set in the event of a break condition match on the
corresponding channel. These flags are set when the break condition matches but are not
cleared when it no longer does. To confirm setting of the same flag again, read the flag once
from the break interrupt handling routine, and then write 0 to it (the flag is cleared by writing 0
to it after reading it as 1).
[Legend]
n = Channels A to D
8.4.2
PC Break
1. When specifying a PC break, specify the address as the first address of the required instruction.
If the address for a PC break condition is not the first address of an instruction, a break will
never be generated.
2. The break occurs after fetching and execution of the target instruction have been confirmed. In
cases of contention between a break before instruction execution and a user maskable interrupt,
priority is given to the break before instruction execution.
3. A break will not be generated even if a break before instruction execution is set in a delay slot.
4. The PC break condition is generated by specifying CPU cycles as the bus condition in break
control register n (BRCRn.CPn0 = 1), PC break as the break condition (IDn0 = 1), and read
cycles as the bus-cycle condition (RWn0 = 1).
[Legend]
n = Channels A to D
Rev. 2.00 Oct. 21, 2009 Page 174 of 1454
REJ09B0498-0200
Section 8 User Break Controller (UBC)
8.4.3
Condition Match Flag
Condition match flags are set when the break conditions match. The condition match flags of the
UBC are listed in table 8.2.
Table 8.2
List of Condition Match Flags
Register
Flag Bit
Source
BRCRA
CMFCPA (bit 13)
Indicates that the condition matches in the CPU cycle
for channel A
BRCRB
CMFCPB (bit 13)
Indicates that the condition matches in the CPU cycle
for channel B
BRCRC
CMFCPC (bit 13)
Indicates that the condition matches in the CPU cycle
for channel C
BRCRD
CMFCPD (bit 13)
Indicates that the condition matches in the CPU cycle
for channel D
Rev. 2.00 Oct. 21, 2009 Page 175 of 1454
REJ09B0498-0200
Section 8 User Break Controller (UBC)
8.5
Usage Notes
1. PC break usage note
⎯ Contention between a SLEEP instruction (to place the chip in the sleep state or on software
standby) and PC break
If a break before a PC break instruction is set for the instruction after a SLEEP instruction
and the SLEEP instruction is executed with the SSBY bit cleared to 0, break interrupt
exception handling is executed without sleep mode being entered. In this case, the
instruction after the SLEEP instruction is executed after the RTE instruction.
When the SSBY bit is set to 1, break interrupt exception handling is executed after the
oscillation settling time has elapsed subsequent to the transition to software standby mode.
When an interrupt is the canceling source, interrupt exception handling is executed after the
RTE instruction, and the instruction following the SLEEP instruction is then executed.
CLK
SLEEP
Software standby
Break interrupt
exception handling
(PC break source)
Interrupt
exception handling
(Cancelling source)
Cancelling source
Figure 8.2 Contention between SLEEP Instruction (Software Standby) and PC Break
2. Prohibition on Setting of PC Break
⎯ Setting of a UBC break interrupt for program within the UBC break interrupt handling
routine is prohibited.
3. The procedure for clearing a UBC flag bit (condition match flag) is shown below. A flag bit is
cleared by writing 0 to it after reading it as 1. As the register that contains the flag bits is
accessible in byte units, bit manipulation instructions can be used.
Rev. 2.00 Oct. 21, 2009 Page 176 of 1454
REJ09B0498-0200
Section 8 User Break Controller (UBC)
CKS
Register read
The value read as 1
is retained
Register write
Flag bit
Flag bit is set to 1
Flag bit is cleared to 0
Figure 8.3 Flag Bit Clearing Sequence (Condition Match Flag)
4. After setting break conditions for the UBC, an unexpected UBC break interrupt may occur
after the execution of an illegal instruction. This depends on the value of the program counter
and the internal bus cycle.
Rev. 2.00 Oct. 21, 2009 Page 177 of 1454
REJ09B0498-0200
Section 8 User Break Controller (UBC)
Rev. 2.00 Oct. 21, 2009 Page 178 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Section 9 Bus Controller (BSC)
This LSI has an on-chip bus controller (BSC) that manages the external address space divided into
eight areas.
The bus controller also has a bus arbitration function, and controls the operation of the internal bus
masters; CPU, DMAC, EXDMAC, and DTC.
9.1
Features
• Manages external address space in area units
Manages the external address space divided into eight areas
Chip select signals (CS0 to CS7) can be output for each area
Bus specifications can be set independently for each area
8-bit access or 16-bit access can be selected for each area
DRAM, synchronous DRAM, burst ROM, byte control SRAM, or address/data multiplexed
I/O interface can be set
An endian conversion function is provided to connect a device of little endian
• Basic bus interface
This interface can be connected to the SRAM and ROM
2-state access or 3-state access can be selected for each area
Program wait cycles can be inserted for each area
Wait cycles can be inserted by the WAIT pin.
Extension cycles can be inserted while CSn is asserted for each area (n = 0 to 7)
The negation timing of the read strobe signal (RD) can be modified
• Byte control SRAM interface
Byte control SRAM interface can be set for areas 0 to 7
The SRAM that has a byte control pin can be directly connected
• Burst ROM interface
Burst ROM interface can be set for areas 0 and 1
Burst ROM interface parameters can be set independently for areas 0 and 1
• Address/data multiplexed I/O interface
Address/data multiplexed I/O interface can be set for areas 3 to 7
Rev. 2.00 Oct. 21, 2009 Page 179 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
• DRAM interface
DRAM interface is available as area 2
Row/column address-multiplexed output (8, 9, 10, or 11 bits)
Two CAS signals control byte accesses for 16-bit data bus device
CAS assertion period can be extended by a program wait and a pin wait
Burst access can be performed in fast page mode
Tp cycle for ensuring a RAS precharge time can be inserted
CAS-before-RAS refresh (CBR refresh) and self refresh are selectable
• Synchronous DRAM interface
Synchronous DRAM interface is available as area 2
Row/column address-multiplexed output (8, 9, 10, or 11 bits)
DQM signals control byte access for 16-bit data bus device
Auto refresh and self refresh are selectable
CAS latency can be selected from 2 to 4
High-speed data transfer is available using EXDMAC cluster transfer
• Idle cycle insertion
Idle cycles can be inserted between external read accesses to different areas
Idle cycles can be inserted before the external write access after an external read access
Idle cycles can be inserted before the external read access after an external write access
Idle cycles can be inserted before the external access after a DMAC/EXDMAC single address
transfer (write access)
• Write buffer function
External write cycles and internal accesses can be executed in parallel
Write accesses to the on-chip peripheral module and on-chip memory accesses can be executed
in parallel
DMAC single address transfers and internal accesses can be executed in parallel
• External bus release function
• Bus arbitration function
Includes a bus arbiter that arbitrates bus mastership among the CPU, DMAC, EXDMAC,
DTC, refresh cycle, and external bus master
• EXDMAC external bus transfers and internal accesses can be executed in parallel.
• Multi-clock function
The internal peripheral functions can be operated in synchronization with the peripheral
module clock (Pφ). Accesses to the external address space can be operated in synchronization
with the external bus clock (Bφ).
• The bus start (BS) and read/write (RD/WR) signals can be output.
Rev. 2.00 Oct. 21, 2009 Page 180 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
A block diagram of the bus controller is shown in figure 9.1.
CPU address bus
DMAC address bus
DTC address bus
EXDMAC address bus
Internal bus
control signals
CPU bus acknowledge signal
DTC bus acknowledge signal
DMAC bus acknowledge signal
CPU bus request signal
DTC bus request signal
DMAC bus request signal
Address
selector
Area decoder
Internal bus
control unit
External bus
control unit
Internal
bus
arbiter
CS7 to CS0
External bus
control signals
WAIT
External bus
arbiter
EXDMAC bus acknowledge signal
EXDMAC bus request signal
BREQ
BACK
BREQO
Refresh timer
Control registers
Internal data bus
ABWCR
SRAMCR
ASTCR
BROMCR
WTCRA
MPXCR
WTCRB
DRAMCR
RDNCR
DRACCR
CSACR
SDCR
IDLCR
REFCR
BCR1
BCR2
RTCNT
RTCOR
ENDIANCR
[Legend]
Bus width control register
ABWCR:
Access state control register
ASTCR:
Wait control register A
WTCRA:
Wait control register B
WTCRB:
Read strobe timing control register
RDNCR:
CS assertion period control register
CSACR:
Idle control register
IDLCR:
Bus control register 1
BCR1:
Bus control register 2
BCR2:
ENDIANCR:Endian control register
SRAMCR: SRAM mode control register
BROMCR: Burst ROM interface control register
MPXCR: Address/data multiplexed I/O control register
DRAMCR: DRAM control register
DRACCR: DRAM access control register
SDCR:
Synchronous DRAM control register
REFCR: Refresh control register
RTCNT: Refresh timer counter
RTCOR: Refresh time constant register
Figure 9.1 Block Diagram of Bus Controller
Rev. 2.00 Oct. 21, 2009 Page 181 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2
Register Descriptions
The bus controller has the following registers.
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
Bus width control register (ABWCR)
Access state control register (ASTCR)
Wait control register A (WTCRA)
Wait control register B (WTCRB)
Read strobe timing control register (RDNCR)
CS assertion period control register (CSACR)
Idle control register (IDLCR)
Bus control register 1 (BCR1)
Bus control register 2 (BCR2)
Endian control register (ENDIANCR)
SRAM mode control register (SRAMCR)
Burst ROM interface control register (BROMCR)
Address/data multiplexed I/O control register (MPXCR)
DRAM control register (DRAMCR)
DRAM access control register (DRACCR)
Synchronous DRAM control register (SDCR)
Refresh control register (REFCR)
Refresh timer counter (RTCNT)
Refresh time constant register (RTCOR)
Rev. 2.00 Oct. 21, 2009 Page 182 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.1
Bus Width Control Register (ABWCR)
ABWCR specifies the data bus width for each area in the external address space.
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
15
14
13
12
11
10
9
8
ABWH7
ABWH6
ABWH5
ABWH4
ABWH3
ABWH2
ABWH1
ABWH0
1
1
1
1
1
1
1
1/0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
ABWL7
ABWL6
ABWL5
ABWL4
ABWL3
ABWL2
ABWL1
ABWL0
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Note: * Initial value at 16-bit bus initiation is H'FEFF, and that at 8-bit bus initiation is H'FFFF.
Bit
Bit Name
Initial
Value*1
R/W
Description
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
ABWH7
ABWH6
ABWH5
ABWH4
ABWH3
ABWH2
ABWH1
ABWL0
ABWL7
ABWL6
ABWL5
ABWL4
ABWL3
ABWL2
ABWL1
ABWL0
1
1
1
1
1
1
1
1/0
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Area 7 to 0 Bus Width Control
These bits select whether the corresponding area is to be
designated as 8-bit access space or 16-bit access space.
ABWHn ABWLn (n = 7 to 0)
×
0:
Setting prohibited
0
1:
Area n is designated as 16-bit
access space
1
1:
Area n is designated as 8-bit access
2
space*
[Legend]
×: Don't care
Notes: 1. Initial value at 16-bit bus initiation is H'FEFF, and that at 8-bit bus initiation is H'FFFF.
2. An address space specified as byte control SRAM interface must not be specified as 8bit access space.
Rev. 2.00 Oct. 21, 2009 Page 183 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.2
Access State Control Register (ASTCR)
ASTCR designates each area in the external address space as either 2-state access space or 3-state
access space and enables/disables wait cycle insertion.
Bit
15
14
13
12
11
10
9
8
AST7
AST6
AST5
AST4
AST3
AST2
AST1
AST0
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Bit Name
Initial Value
R/W
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit
Bit Name
Initial
Value
R/W
Description
15
AST7
1
R/W
Area 7 to 0 Access State Control
14
AST6
1
R/W
13
AST5
1
R/W
12
AST4
1
R/W
These bits select whether the corresponding area is to be
designated as 2-state access space or 3-state access
space. Wait cycle insertion is enabled or disabled at the
same time.
11
AST3
1
R/W
0: Area n is designated as 2-state access space
10
AST2
1
R/W
9
AST1
1
R/W
8
AST0
1
R/W
Wait cycle insertion in area n access is disabled
1: Area n is designated as 3-state access space
Wait cycle insertion in area n access is enabled
(n = 7 to 0)
7 to 0
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 184 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.3
Wait Control Registers A and B (WTCRA, WTCRB)
WTCRA and WTCRB select the number of program wait cycles for each area in the external
address space.
• WTCRA
Bit
15
14
13
12
11
10
9
8
Bit Name
⎯
W72
W71
W70
⎯
W62
W61
W60
Initial Value
0
1
1
1
0
1
1
1
R/W
R
R/W
R/W
R/W
R
R/W
R/W
R/W
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
W52
W51
W50
⎯
W42
W41
W40
Initial Value
0
1
1
1
0
1
1
1
R/W
R
R/W
R/W
R/W
R
R/W
R/W
R/W
Bit
15
14
13
12
11
10
9
8
Bit Name
⎯
W32
W31
W30
⎯
W22
W21
W20
Initial Value
0
1
1
1
0
1
1
1
R/W
R
R/W
R/W
R/W
R
R/W
R/W
R/W
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
W12
W11
W10
⎯
W02
W01
W00
• WTCRB
Initial Value
0
1
1
1
0
1
1
1
R/W
R
R/W
R/W
R/W
R
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 185 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
• WTCRA
Bit
Bit Name
Initial
Value
R/W
Description
15
⎯
0
R
Reserved
14
W72
1
R/W
Area 7 Wait Control 2 to 0
13
W71
1
R/W
12
W70
1
R/W
These bits select the number of program wait cycles
when accessing area 7 while bit AST7 in ASTCR is 1.
This is a read-only bit and cannot be modified.
000: Program wait cycle not inserted
001: 1 program wait cycle inserted
010: 2 program wait cycles inserted
011: 3 program wait cycles inserted
100: 4 program wait cycles inserted
101: 5 program wait cycles inserted
110: 6 program wait cycles inserted
111: 7 program wait cycles inserted
11
⎯
0
R
10
W62
1
R/W
Area 6 Wait Control 2 to 0
9
W61
1
R/W
8
W60
1
R/W
These bits select the number of program wait cycles
when accessing area 6 while bit AST6 in ASTCR is 1.
Reserved
This is a read-only bit and cannot be modified.
000: Program wait cycle not inserted
001: 1 program wait cycle inserted
010: 2 program wait cycles inserted
011: 3 program wait cycles inserted
100: 4 program wait cycles inserted
101: 5 program wait cycles inserted
110: 6 program wait cycles inserted
111: 7 program wait cycles inserted
7
⎯
0
R
Reserved
This is a read-only bit and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 186 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
6
W52
1
R/W
Area 5 Wait Control 2 to 0
5
W51
1
R/W
4
W50
1
R/W
These bits select the number of program wait cycles
when accessing area 5 while bit AST5 in ASTCR is 1.
000: Program cycle wait not inserted
001: 1 program wait cycle inserted
010: 2 program wait cycles inserted
011: 3 program wait cycles inserted
100: 4 program wait cycles inserted
101: 5 program wait cycles inserted
110: 6 program wait cycles inserted
111: 7 program wait cycles inserted
3
⎯
0
R
Reserved
This is a read-only bit and cannot be modified.
2
W42
1
R/W
Area 4 Wait Control 2 to 0
1
W41
1
R/W
0
W40
1
R/W
These bits select the number of program wait cycles
when accessing area 4 while bit AST4 in ASTCR is 1.
000: Program wait cycle not inserted
001: 1 program wait cycle inserted
010: 2 program wait cycles inserted
011: 3 program wait cycles inserted
100: 4 program wait cycles inserted
101: 5 program wait cycles inserted
110: 6 program wait cycles inserted
111: 7 program wait cycles inserted
• WTCRB
Bit
Bit Name
Initial
Value
R/W
Description
15
⎯
0
R
Reserved
This is a read-only bit and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 187 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
14
W32
1
R/W
Area 3 Wait Control 2 to 0
13
W31
1
R/W
12
W30
1
R/W
These bits select the number of program wait cycles
when accessing area 3 while bit AST3 in ASTCR is 1.
000: Program wait cycle not inserted
001: 1 program wait cycle inserted
010: 2 program wait cycles inserted
011: 3 program wait cycles inserted
100: 4 program wait cycles inserted
101: 5 program wait cycles inserted
110: 6 program wait cycles inserted
111: 7 program wait cycles inserted
11
⎯
0
R
Reserved
This is a read-only bit and cannot be modified.
10
W22
1
R/W
Area 2 Wait Control 2 to 0
9
W21
1
R/W
8
W20
1
R/W
These bits select the number of program wait cycles
when accessing area 2 while bit AST2 in ASTCR is 1.
When SDRAM is connected, the CAS latency is
specified. At this time, W22 is ignored. The CAS latency
can be specified even if the wait cycle insertion is
disabled by ASTCR.
Selection of number of program wait cycles:
000: Program wait cycle not inserted
001: 1 program wait cycle inserted
010: 2 program wait cycles inserted
011: 3 program wait cycles inserted
100: 4 program wait cycles inserted
101: 5 program wait cycles inserted
110: 6 program wait cycles inserted
111: 7 program wait cycles inserted
Setting of CAS latency (W22 is ignored.):
00: Setting prohibited
01: SDRAM with a CAS latency of 2 is connected.
10: SDRAM with a CAS latency of 3 is connected.
11: SDRAM with a CAS latency of 4 is connected.
Rev. 2.00 Oct. 21, 2009 Page 188 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
This is a read-only bit and cannot be modified.
6
W12
1
R/W
Area 1 Wait Control 2 to 0
5
W11
1
R/W
4
W10
1
R/W
These bits select the number of program wait cycles
when accessing area 1 while bit AST1 in ASTCR is 1.
000: Program wait cycle not inserted
001: 1 program wait cycle inserted
010: 2 program wait cycles inserted
011: 3 program wait cycles inserted
100: 4 program wait cycles inserted
101: 5 program wait cycles inserted
110: 6 program wait cycles inserted
111: 7 program wait cycles inserted
3
⎯
0
R
Reserved
This is a read-only bit and cannot be modified.
2
W02
1
R/W
Area 0 Wait Control 2 to 0
1
W01
1
R/W
0
W00
1
R/W
These bits select the number of program wait cycles
when accessing area 0 while bit AST0 in ASTCR is 1.
000: Program wait cycle not inserted
001: 1 program wait cycle inserted
010: 2 program wait cycles inserted
011: 3 program wait cycles inserted
100: 4 program wait cycles inserted
101: 5 program wait cycles inserted
110: 6 program wait cycles inserted
111: 7 program wait cycles inserted
Rev. 2.00 Oct. 21, 2009 Page 189 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.4
Read Strobe Timing Control Register (RDNCR)
RDNCR selects the negation timing of the read strobe signal (RD) when reading the external
address spaces specified as a basic bus interface or the address/data multiplexed I/O interface.
Bit
15
14
13
12
11
10
9
8
RDN7
RDN6
RDN5
RDN4
RDN3
RDN2
RDN1
RDN0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Bit Name
Initial Value
R/W
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit
Bit Name
Initial
Value
R/W
Description
15
RDN7
0
R/W
Read Strobe Timing Control
14
RDN6
0
R/W
13
RDN5
0
R/W
RDN7 to RDN0 set the negation timing of the read
strobe in a corresponding area read access.
12
RDN4
0
R/W
11
RDN3
0
R/W
10
RDN2
0
R/W
9
RDN1
0
R/W
8
RDN0
0
R/W
As shown in figure 9.2, the read strobe for an area for
which the RDNn bit is set to 1 is negated one halfcycle earlier than that for an area for which the RDNn
bit is cleared to 0. The read data setup and hold time
are also given one half-cycle earlier.
0: In an area n read access, the RD signal is negated
at the end of the read cycle
1: In an area n read access, the RD signal is negated
one half-cycle before the end of the read cycle
(n = 7 to 0)
7 to 0
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
Notes: 1. In an external address space which is specified as byte control SRAM interface, the
RDNCR setting is ignored and the same operation when RDNn = 1 is performed.
2. In an external address space which is specified as the burst ROM interface, the
RDNCR setting is ignored and the same operation when RDNn = 0 is performed during
read accesses by the CPU and EXDMAC cluster transfer.
Rev. 2.00 Oct. 21, 2009 Page 190 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bus cycle
T3
T2
T1
Bφ
RD
RDNn = 0
Data
RD
RDNn = 1
Data
(n = 7 to 0)
Figure 9.2 Read Strobe Negation Timing (Example of 3-State Access Space)
9.2.5
CS Assertion Period Control Registers (CSACR)
CSACR selects whether or not the assertion periods of the chip select signals (CSn) and address
signals for the basic bus, byte-control SRAM, burst ROM, and address/data multiplexed I/O
interface are to be extended. Extending the assertion period of the CSn and address signals allows
the setup time and hold time of read strobe (RD) and write strobe (LHWR/LLWR) to be assured
and to make the write data setup time and hold time for the write strobe become flexible.
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
15
14
13
12
11
10
9
8
CSXH7
CSXH6
CSXH5
CSXH4
CSXH3
CSXH2
CSXH1
CSXH0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
CSXT7
CSXT6
CSXT5
CSXT4
CSXT3
CSXT2
CSXT1
CSXT0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 191 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
15
CSXH7
0
R/W
CS and Address Signal Assertion Period Control 1
14
CSXH6
0
R/W
13
CSXH5
0
R/W
12
CSXH4
0
R/W
11
CSXH3
0
R/W
These bits specify whether or not the Th cycle is to be
inserted (see figure 9.3). When an area for which bit
CSXHn is set to 1 is accessed, one Th cycle, in which
the CSn and address signals are asserted, is inserted
before the normal access cycle.
10
CSXH2
0
R/W
9
CSXH1
0
R/W
8
CSXH0
0
R/W
7
CSXT7
0
R/W
CS and Address Signal Assertion Period Control 2
6
CSXT6
0
R/W
5
CSXT5
0
R/W
4
CSXT4
0
R/W
3
CSXT3
0
R/W
These bits specify whether or not the Tt cycle is to be
inserted (see figure 9.3). When an area for which bit
CSXTn is set to 1 is accessed, one Tt cycle, in which
the CSn and address signals are retained, is inserted
after the normal access cycle.
2
CSXT2
0
R/W
1
CSXT1
0
R/W
0
CSXT0
0
R/W
0: In access to area n, the CSn and address assertion
period (Th) is not extended
1: In access to area n, the CSn and address assertion
period (Th) is extended
(n = 7 to 0)
0: In access to area n, the CSn and address assertion
period (Tt) is not extended
1: In access to area n, the CSn and address assertion
period (Tt) is extended
(n = 7 to 0)
Note:
*
In burst ROM interface, the CSXTn settings are ignored during read accesses by the
CPU and EXDMAC cluster transfer.
Rev. 2.00 Oct. 21, 2009 Page 192 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bus cycle
Th
T1
T2
T3
Tt
Bφ
Address
CSn
AS
BS
RD/WR
RD
Read
Read data
Data bus
LHWR, LLWR
Write
Data bus
Write data
Figure 9.3 CS and Address Assertion Period Extension
(Example of Basic Bus Interface, 3-State Access Space, and RDNn = 0)
Rev. 2.00 Oct. 21, 2009 Page 193 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.6
Idle Control Register (IDLCR)
IDLCR specifies the idle cycle insertion conditions and the number of idle cycles.
Bit
Bit Name
15
14
13
12
11
10
9
8
IDLS3
IDLS2
IDLS1
IDLS0
IDLCB1
IDLCB0
IDLCA1
IDLCA0
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
IDLSEL7
IDLSEL6
IDLSEL5
IDLSEL4
IDLSEL3
IDLSEL2
IDLSEL1
IDLSEL0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial
Value
R/W
Description
15
IDLS3
1
R/W
Idle Cycle Insertion 3
Inserts an idle cycle between the bus cycles when the
DMAC or EXDMAC single address transfer (write cycle)
is followed by external access.
0: No idle cycle is inserted
1: An idle cycle is inserted
14
IDLS2
1
R/W
Idle Cycle Insertion 2
Inserts an idle cycle between the bus cycles when the
external write cycle is followed by external read cycle.
0: No idle cycle is inserted
1: An idle cycle is inserted
13
IDLS1
1
R/W
Idle Cycle Insertion 1
Inserts an idle cycle between the bus cycles when the
external read cycles of different areas continue.
0: No idle cycle is inserted
1: An idle cycle is inserted
Rev. 2.00 Oct. 21, 2009 Page 194 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
12
IDLS0
1
R/W
Idle Cycle Insertion 0
Inserts an idle cycle between the bus cycles when the
external read cycle is followed by external write cycle.
0: No idle cycle is inserted
1: An idle cycle is inserted
11
IDLCB1
1
R/W
Idle Cycle State Number Select B
10
IDLCB0
1
R/W
Specifies the number of idle cycles to be inserted for
the idle condition specified by IDLS1 and IDLS0.
00: No idle cycle is inserted
01: 2 idle cycles are inserted
00: 3 idle cycles are inserted
01: 4 idle cycles are inserted
9
IDLCA1
1
R/W
Idle Cycle State Number Select A
8
IDLCA0
1
R/W
Specifies the number of idle cycles to be inserted for
the idle condition specified by IDLS3 to IDLS0.
00: 1 idle cycle is inserted
01: 2 idle cycles are inserted
10: 3 idle cycles are inserted
11: 4 idle cycles are inserted
7
IDLSEL7
0
R/W
Idle Cycle Number Select
6
IDLSEL6
0
R/W
5
IDLSEL5
0
R/W
4
IDLSEL4
0
R/W
Specifies the number of idle cycles to be inserted for
each area for the idle insertion condition specified by
IDLS1 and IDLS0.
3
IDLSEL3
0
R/W
2
IDLSEL2
0
R/W
1
IDLSEL1
0
R/W
1: Number of idle cycles to be inserted for area n is
specified by IDLCB1 and IDLCB0.
0
IDLSEL0
0
R/W
(n = 7 to 0)
0: Number of idle cycles to be inserted for area n is
specified by IDLCA1 and IDLCA0.
Rev. 2.00 Oct. 21, 2009 Page 195 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.7
Bus Control Register 1 (BCR1)
BCR1 is used for selection of the external bus released state protocol, enabling/disabling of the
write data buffer function, and enabling/disabling of the WAIT pin input.
Bit
Bit Name
15
14
13
12
11
10
9
8
BRLE
BREQOE
⎯
⎯
⎯
⎯
WDBE
WAITE
0
0
0
0
0
0
0
0
R/W
R/W
R
R
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
DKC
EDKC
⎯
⎯
⎯
⎯
⎯
⎯
Initial Value
R/W
Bit
Bit Name
0
0
0
0
0
0
0
0
R/W
R/W
R
R
R
R
R
R
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Description
15
BRLE
0
R/W
External Bus Release Enable
Enables/disables external bus release.
0: External bus release disabled
BREQ, BACK, and BREQO pins can be used as
I/O ports
1: External bus release enabled*
For details, see section 13, I/O Ports.
14
BREQOE
0
R/W
BREQO Pin Enable
Controls outputting the bus request signal (BREQO)
to the external bus master in the external bus
released state when an internal bus master performs
an external address space access.
0: BREQO output disabled
BREQO pin can be used as I/O port
1: BREQO output enabled
13, 12
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
11, 10
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value
should always be 0.
Rev. 2.00 Oct. 21, 2009 Page 196 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial Value
R/W
Description
9
WDBE
0
R/W
Write Data Buffer Enable
The write data buffer function can be used for an
external write cycle and a DMAC single address
transfer cycle.
The changed setting may not affect an external
access immediately after the change.
0: Write data buffer function not used
1: Write data buffer function used
8
WAITE
0
R/W
WAIT Pin Enable
Selects enabling/disabling of wait input by the WAIT
pin. When area 2 is specified as the synchronous
DRAM space, the setting of this bit does not affect
the synchronous DRAM space access operation.
0: Wait input by WAIT pin disabled
WAIT pin can be used as I/O port
1: Wait input by WAIT pin enabled
For details, see section 13, I/O Ports.
7
DKC
0
R/W
DACK Control
Selects the timing of DMAC transfer acknowledge
signal assertion.
0: DACK signal is asserted at the Bφ falling edge
1: DACK signal is asserted at the Bφ rising edge
6
EDKC
0
R/W
EDACK Control
Controls the assertion timing of an acknowledge
signal for an EXDMAC transfer.
0: EDACK signal asserted at the falling edge of Bφ
1: EDACK signal asserted at the rising edge of Bφ
5 to 0
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
Note: When external bus release is enabled or input by the WAIT pin is enabled, make sure to set
the ICR bit to 1. For details, see section 13, I/O Ports.
Rev. 2.00 Oct. 21, 2009 Page 197 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.8
Bus Control Register 2 (BCR2)
BCR2 is used for bus arbitration control of the CPU, DMAC, EXDMAC, and DTC, and
enabling/disabling of the write data buffer function to the peripheral modules.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
EBCCS
IBCCS
⎯
⎯
⎯
PWDBE
Initial Value
0
0
0
0
0
0
1
0
R/W
R
R
R/W
R/W
R
R
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7, 6
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
5
EBCCS
0
R/W
External Bus Cycle Control Select
Selects the method for external bus arbitration.
0: Releases the bus depending on the priority
1: Executes the bus cycle alternatively when a conflict
occurs between a bus request by the EXDMAC,
external bus master or refresh bus and a request for
an external space access by the CPU, DMAC, or
DTC.
4
IBCCS
0
R/W
Internal Bus Cycle Control Select
Selects the internal bus arbiter function.
0: Releases the bus mastership according to the priority
1: Executes the bus cycles alternatively when a CPU
bus mastership request conflicts with a DMAC or
DTC bus mastership request
3, 2
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
1
⎯
1
R/W
Reserved
This bit is always read as 1. The write value should
always be 1.
0
PWDBE
0
R/W
Peripheral Module Write Data Buffer Enable
Specifies whether or not to use the write data buffer
function for the peripheral module write cycles.
0: Write data buffer function not used
1: Write data buffer function used
Rev. 2.00 Oct. 21, 2009 Page 198 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.9
Endian Control Register (ENDIANCR)
ENDIANCR selects the endian format for each area of the external address space. Though the data
format of this LSI is big endian, data can be transferred in the little endian format during external
address space access.
Note that the data format for the areas used as a program area or a stack area should be big endian.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
LE7
LE6
LE5
LE4
LE3
LE2
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R
R
Bit
Bit Name
Initial
Value
R/W
Description
7
LE7
0
R/W
Little Endian Select
6
LE6
0
R/W
Selects the endian for the corresponding area.
5
LE5
0
R/W
0: Data format of area n is specified as big endian
4
LE4
0
R/W
1: Data format of area n is specified as little endian
3
LE3
0
R/W
(n = 7 to 2)
2
LE2
0
R/W
1, 0
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 199 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.10
SRAM Mode Control Register (SRAMCR)
SRAMCR specifies the bus interface of each area in the external address space as a basic bus
interface or a byte control SRAM interface.
In areas specified as 8-bit access space by ABWCR, the SRAMCR setting is ignored and the byte
control SRAM interface cannot be specified.
Bit
15
14
13
12
11
10
9
8
BCSEL7
BCSEL6
BCSEL5
BCSEL4
BCSEL3
BCSEL2
BCSEL1
BCSEL0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Bit Name
Initial Value
R/W
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit
Bit Name
Initial
Value
R/W
Description
15
BCSEL7
0
R/W
Byte Control SRAM Interface Select
14
BCSEL6
0
R/W
Selects the bus interface for the corresponding area.
13
BCSEL5
0
R/W
12
BCSEL4
0
R/W
11
BCSEL3
0
R/W
When setting a bit to 1, the bus interface select bits in
BROMCR, DRAMCR and MPXCR must be cleared to
0.
10
BCSEL2
0
R/W
9
BCSEL1
0
R/W
8
BCSEL0
0
R/W
7 to 0
⎯
All 0
R
0: Area n is basic bus interface
1: Area n is byte control SRAM interface
(n = 7 to 0)
Reserved
These are read-only bits and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 200 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.11
Burst ROM Interface Control Register (BROMCR)
BROMCR specifies the burst ROM interface.
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
15
14
13
12
11
10
9
8
BSRM0
BSTS02
BSTS01
BSTS00
⎯
⎯
BSWD01
BSWD00
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R
R
R/W
R/W
7
6
5
4
3
2
1
0
BSRM1
BSTS12
BSTS11
BSTS10
⎯
⎯
BSWD11
BSWD10
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R
R
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
15
BSRM0
0
R/W
Area 0 Burst ROM Interface Select
Specifies the area 0 bus interface. To set this bit to 1,
clear bit BCSEL0 in SRAMCR to 0.
0: Basic bus interface or byte-control SRAM interface
1: Burst ROM interface
14
BSTS02
0
R/W
Area 0 Burst Cycle Select
13
BSTS01
0
R/W
Specifies the number of burst cycles of area 0
12
BSTS00
0
R/W
000: 1 cycle
001: 2 cycles
010: 3 cycles
011: 4 cycles
100: 5 cycles
101: 6 cycles
110: 7 cycles
111: 8 cycles
11, 10
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 201 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
9
BSWD01
0
R/W
Area 0 Burst Word Number Select
8
BSWD00
0
R/W
Selects the number of words in burst access to the area
0 burst ROM interface
00: Up to 4 words (8 bytes)
01: Up to 8 words (16 bytes)
10: Up to 16 words (32 bytes)
11: Up to 32 words (64 bytes)
7
BSRM1
0
R/W
Area 1 Burst ROM Interface Select
Specifies the area 1 bus interface as a basic interface
or a burst ROM interface. To set this bit to 1, clear bit
BCSEL1 in SRAMCR to 0.
0: Basic bus interface or byte-control SRAM interface
1: Burst ROM interface
6
BSTS12
0
R/W
Area 1 Burst Cycle Select
5
BSTS11
0
R/W
Specifies the number of cycles of area 1 burst cycle
4
BSTS10
0
R/W
000: 1 cycle
001: 2 cycles
010: 3 cycles
011: 4 cycles
100: 5 cycles
101: 6 cycles
110: 7 cycles
111: 8 cycles
3, 2
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
1
BSWD11
0
R/W
Area 1 Burst Word Number Select
0
BSWD10
0
R/W
Selects the number of words in burst access to the area
1 burst ROM interface
00: Up to 4 words (8 bytes)
01: Up to 8 words (16 bytes)
10: Up to 16 words (32 bytes)
11: Up to 32 words (64 bytes)
Rev. 2.00 Oct. 21, 2009 Page 202 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.12
Address/Data Multiplexed I/O Control Register (MPXCR)
MPXCR specifies the address/data multiplexed I/O interface.
Bit
15
14
13
12
11
10
9
8
MPXE7
MPXE6
MPXE5
MPXE4
MPXE3
⎯
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R
R
R
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
ADDEX
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R/W
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial
Value
R/W
Description
15
MPXE7
0
R/W
Address/Data Multiplexed I/O Interface Select
14
MPXE6
0
R/W
Specifies the bus interface for the corresponding area.
13
MPXE5
0
R/W
12
MPXE4
0
R/W
To set this bit to 1, clear the BCSELn bit in SRAMCR to
0.
11
MPXE3
0
R/W
0: Area n is specified as a basic interface or a byte
control SRAM interface.
1: Area n is specified as an address/data multiplexed
I/O interface
(n = 7 to 3)
10 to 1 ⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
0
ADDEX
0
R/W
Address Output Cycle Extension
Specifies whether a wait cycle is inserted for the
address output cycle of address/data multiplexed I/O
interface.
0: No wait cycle is inserted for the address output cycle
1: One wait cycle is inserted for the address output
cycle
Rev. 2.00 Oct. 21, 2009 Page 203 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.13
DRAM Control Register (DRAMCR)
DRAMCR specifies the DRAM/SDRAM interface. Rewrite this register while the
DRAM/SDRAM is not accessed.
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
15
14
13
12
11
10
9
8
DRAME
DTYPE
⎯
⎯
OEE
RAST
⎯
CAST
0
0
0
0
0
0
0
0
R/W
R/W
R
R
R/W
R/W
R
R/W
7
6
5
4
3
2
1
0
BE
RCDM
DDS
EDDS
⎯
⎯
MXC1
MXC0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
15
DRAME
0
R/W
Area 2 DRAM Interface Select
Selects whether or not area 2 is specified as the
DRAM/SDRAM interface. When this bit is set to 1,
select the type of DRAM to be used in area 2 with the
DTYPE bit. When this bit is set to 1, the BCSEL2 bit in
SRAMCR should be set to 0.
0: Basic bus interface or byte-control SRAM interface
1: DRAM/SDRAM interface
14
DTYPE
0
R/W
DRAM Select
Selects the type of DRAM to be used in area 2.
0: DRAM is used in area 2
1: SDRAM is used in area 2
13, 12
⎯
All 0
R
Reserved
The initial value should not be changed.
Rev. 2.00 Oct. 21, 2009 Page 204 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
11
OEE
0
R/W
OE Output Enable
The OE signal is output when DRAM with the EDO
page mode is connected, whereas the CKE signal is
output when SDRAM is connected.
0: OE/CKE signal output disabled (the OE/CKE pin can
be used as an I/O port)
1: OE/CKE signal enabled
10
RAST
0
R/W
RAS Assertion Timing Select
Selects whether the RAS signal is asserted at the rising
edge or falling edge of the Bφ signal in the Tr cycle
during a DRAM access. The relationship between this
bit and RAS assertion timing is shown in figure 9.4.
When SDRAM is used, the setting of this bit does not
affect operation.
0: RAS signal is asserted at the falling edge of the Bf
signal in the Tr cycle
1: RAS signal is asserted at the rising edge of the Bf
signal in the Tr cycle
9
⎯
0
R
Reserved
8
CAST
0
R/W
Column Address Output Cycle Count Select
The initial value should not be changed.
Selects whether the number of column address output
cycles is two or three during a DRAM access.
When SDRAM is used, the setting of this bit does not
affect operation.
0: Column address is output for two cycles
1: Column address is output for three cycles
7
BE
0
R/W
Burst Access Enable
Enables or disables a burst access to the
DRAM/SDRAM. The DRAM/SDRAM is accessed in
high-speed page mode. When DRAM with the EDO
page mode is used, connect the OE signal of this LSI to
the OE signal of DRAM.
0: DRAM/SDRAM is accessed with full access
1: DRAM/SDRAM is accessed in high-speed page
mode
Rev. 2.00 Oct. 21, 2009 Page 205 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
6
RCDM
0
R/W
RAS Down Mode
Selects the RAS signal state while a DRAM access is
halted when a basic bus interface area or an on-chip
I/O register is accessed: keep the RAS signal low (RAS
down mode) and high (RAS up mode).
This bit is effective when BE = 1. Clearing this bit to 0
with RCDM = 1 in RAS down mode cancels the RAS
down mode and the RAS signal goes high.
If the RAS down mode is selected for the SDRAM
interface, the READ/WRIT command is issued without
issuance of the ACTV command when the same row
address is accessed consecutively.
0: RAS up mode when the DRAM/SDRAM is accessed
1: RAS down mode when the DRAM/SDRAM is
accessed
5
DDS
0
R/W
DMAC Single Address Transfer Option
Selects whether a DMAC single address transfer
through the DRAM/SDRAM interface is enabled only in
full access mode or is also enabled in fast-page access
mode.
When clearing the BE bit to 0 to disable a burst access
to the DRAM/SDRAM interface, a DMAC single address
transfer is performed in full access mode regardless of
this bit.
This bit does not affect an external access by other bus
masters or a DMAC dual address transfer. Setting this
bit to 1 changes the DACK output timing.
0: DMAC single address transfer through the
DRAM/SDRAM is enabled only in full access mode
1: DMAC single address transfer through the
DRAM/SDRAM is also enabled in fast-page access
mode
Rev. 2.00 Oct. 21, 2009 Page 206 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
4
EDDS
0
R/W
EXDMAC Single Address Transfer Option
Selects whether an EXDMAC single address transfer
through the DRAM/SDRAM interface is enabled only in
full access mode or is also enabled in fast-page access
mode.
When clearing the BE bit to 0 to disable a burst access
to the DRAM/SDRAM interface, an EXDMAC single
address transfer is performed in full access mode
regardless of this bit.
This bit does not affect an external access by other bus
masters or an EXDMAC dual address transfer. Setting
this bit to 1 changes the EDACK output timing.
0: EXDMAC single address transfer through the
DRAM/SDRAM is enabled only in full access mode
1: EXDMAC single address transfer through the
DRAM/SDRAM is also enabled in fast-page access
mode
3
⎯
0
R
Reserved
2
⎯
0
R/W
The initial value should not be changed.
Rev. 2.00 Oct. 21, 2009 Page 207 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
1
MCX1
0
R/W
Multiplexed Address Bit Select
0
MCX0
0
R/W
Select the number of bits by which a row address
multiplexed with a column address is shifted to the
lower side. At the same time, these bits select row
address bits compared during a burst access to the
DRAM/SDRAM interface.
00: Shifted by 8 bits
A23 to A8 are compared for 8-bit access space
A23 to A9 are compared for 16-bit access space
01: Shifted by 9 bits
A23 to A9 are compared for 8-bit access space
A23 to A10 are compared for 16-bit access space
10: Shifted by 10 bits
A23 to A10 are compared for 8-bit access space
A23 to A11 are compared for 16-bit access space
11: Shifted by 11 bits
A23 to A11 are compared for 8-bit access space
A23 to A12 are compared for 16-bit access space
Bus cycle
Tp
Tr
Tc1
Tc2
Bφ
Address
Row address
Column address
RAS
(When RAST = 0)
RAS
(When RAST = 1)
LUCAS, LLCAS
Figure 9.4 RAS Assertion Timing (Column Address Output for 2 states
in Full Access Mode)
Rev. 2.00 Oct. 21, 2009 Page 208 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.14
DRAM Access Control Register (DRACCR)
DRACCR specifies the settings for the DRAM/SDRAM interface. Rewrite this register while the
DRAM/SDRAM is not accessed.
Bit
15
14
13
12
11
10
9
8
Bit Name
⎯
⎯
TPC1
TPC0
⎯
⎯
RCD1
RCD0
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R/W
R/W
R
R
R/W
R/W
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit
Bit Name
Initial
Value
R/W
15, 14
⎯
All 0
R
Description
Reserved
The initial value should not be changed.
13
TPC1
0
R/W
Precharge Cycle Control
12
TPC0
0
R/W
Select the number of RAS precharge cycles on a
normal access and a refresh cycle.
00: One cycle
01: Two cycles
10: Three cycles
11: Four cycles
11, 10
⎯
All 0
R
Reserved
The initial value should not be changed.
9
RCD1
0
R/W
RAS-CAS Wait Control
8
RCD0
0
R/W
Select the number of wait cycles inserted between RAS
and CAS cycles.
00: No wait cycle inserted
01: One wait cycle inserted
10: Two wait cycles inserted
11: Three wait cycles inserted
7 to 0
⎯
All 0
R
Reserved
The initial value should not be changed.
Rev. 2.00 Oct. 21, 2009 Page 209 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.15
Synchronous DRAM Control Register (SDCR)
SDCR specifies the settings for the SDRAM interface (when the DTYPE bit in DRAMCR is set
to 1). Rewrite this register while the SDRAM is not accessed. When the SDRAM interface is not
used, the initial value must not be changed.
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
15
14
13
12
11
10
9
8
MRSE
⎯
⎯
⎯
⎯
⎯
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R
R
R
R/W
R/W
R
R/W
7
6
5
4
3
2
1
0
CKSPE
⎯
⎯
⎯
⎯
⎯
⎯
TRWL
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R/W
Bit
Bit Name
Initial
Value
R/W
Description
15
MRSE
0
R/W
Mode Register Set Enable
Enables the setting in the SDRAM mode register. See
section 9.11.14, Setting SDRAM Mode Register.
0: Disables to set the SDRAM mode register
1: Enables to set the SDRAM mode register
14 to 12 ⎯
All 0
R
Reserved
These bits are always read as 0. The initial value
should not be changed.
11, 10
⎯
0
R/W
9
⎯
0
R
Reserved
8
⎯
0
R/W
The initial value should not be changed.
7
CKSPE
0
R/W
Clock Suspend Enable
Reserved
The initial value should not be changed.
Enables the clock suspend mode in which read data
output cycles are extended. Setting this bit to 1 extends
cycles in which read data is output from SDRAM.
0: Disables the clock suspend mode
1: Enables the clock suspend mode
Rev. 2.00 Oct. 21, 2009 Page 210 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
6 to 1
⎯
All 0
R
Reserved
0
TRWL
0
R/W
Write-Precharge Delay Control
The initial value should not be changed.
Specifies the time until the precharge command is
issued after the write command is issued to the
SDRAM. Setting this bit to 1 inserts one wait cycle after
the write command is issued.
0: No wait cycle inserted
1: One wait cycle inserted
9.2.16
Refresh Control Register (REFCR)
REFCR specifies the refresh type for the DRAM/SDRAM interface.
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
15
14
13
12
11
10
9
8
CMF
CMIE
RCW1
RCW0
⎯
RTCK2
RTCK1
RTCK0
0
0
0
0
0
0
0
0
R/(W)*
R/W
R/W
R/W
R
R/W
R/W
R/W
7
6
5
4
3
2
1
0
RFSHE
RLW2
RLW1
RLW0
SLFRF
TPCS2
TPCS1
TPCS0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Note: * Only 0 can be written to this bit, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 211 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
15
CMF
0
R/(W)* Compare Match Flag
Description
Indicates that the refresh timer counter (RTCNT) and
refresh timer constant register (RTCOR) match.
[Clearing conditions]
•
When 0 is written to this bit after this bit is read as 1
with RFSHE = 0
•
When CBR refresh is performed with RFSHE = 1
[Setting condition]
•
14
CMIE
0
R/W
When RTCNT matches RTCOR
Compare Match Interrupt Enable
Enables or disables an interrupt request (CMI) when the
CMF flag is set to 1.
This bit is effective when refresh control is not
performed (RFSHE = 0). When refresh control is
performed (RFSHE = 1), this bit is always cleared to 0.
This bit cannot be modified.
13 to 12 RCW1
0
R/W
CAS-RAS Wait Control
RCW0
0
R/W
Select the number of wait cycles inserted between the
CAS asserted cycle and CAS asserted cycle during
DRAM refresh.
When the SDRAM space is selected, these bits do not
affect operations although they can be read from or
written to.
00: No wait cycle inserted
01: One wait cycle inserted
10: Two wait cycles inserted
11: Three wait cycles inserted
11
⎯
0
R
Reserved
The initial value should not be changed.
Rev. 2.00 Oct. 21, 2009 Page 212 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
10
RTCK2
0
R/W
Refresh Counter Clock Select
9
RTCK1
0
R/W
8
RTCK0
0
R/W
Select the clock used to count up the refresh counter
from the seven internal clocks generated by dividing the
on-chip peripheral module clock (Pφ). When the clock is
selected, the refresh counter starts to count up.
000: Counting halted
001: Counts on Pφ/2
001: Counts on Pφ/8
001: Counts on Pφ/32
001: Counts on Pφ/128
001: Counts on Pφ/512
001: Counts on Pφ/2048
001: Counts on Pφ/4096
7
RFSHE
0
R/W
Refresh Control
Enables or disables refresh control. When refresh
control is disabled, the refresh timer can be used as the
interval timer.
In single-chip activation mode, the setting of this bit
should be made after setting the EXPE bit in SYSCR to
1. For SYSCR, see section 3, MCU Operating Modes.
0: Refresh control enabled
1: Refresh control disabled
6
RLW2
0
R/W
Refresh Cycle Wait Control
5
RLW1
0
R/W
4
RLW0
0
R/W
Select the number of wait cycles during a CAS before
RAS refresh cycle for the DRAM interface and an autorefresh cycle for the SDRAM interface.
000: No wait cycle inserted
001: One wait cycle inserted
010: Two wait cycles inserted
010: Three wait cycles inserted
010: Four wait cycles inserted
010: Five wait cycles inserted
010: Six wait cycles inserted
010: Seven wait cycles inserted
Rev. 2.00 Oct. 21, 2009 Page 213 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bit
Bit Name
Initial
Value
R/W
Description
3
SLFRF
0
R/W
Self-Refresh Enable
Selects the self-refresh mode for the DRAM/SDRAM
interface when a transition to the software standby
mode is made with this bit set to 1. To perform a refresh
cycle by setting the RFSHE bit is set to 1, this bit is
effective.
To perform a self-refresh cycle when the SDRAM
interface is selected, enable the CKE output by setting
the OEE bit in DRAMCR.
0: Disables self-refresh
1: Enables self-refresh
2
TPS2
0
R/W
Precharge Cycle Control during Self-Refresh
1
TPS1
0
R/W
0
TPS0
0
R/W
Selects the number of precharge cycles immediately
after a self-refresh cycle. The number of actual number
of precharge cycles is the sum of the numbers indicated
by these bits and bits TPC1 and TPC0.
000: No wait cycle inserted
001: One wait cycle inserted
010: Two wait cycles inserted
010: Three wait cycles inserted
010: Four wait cycles inserted
010: Five wait cycles inserted
010: Six wait cycles inserted
010: Seven wait cycles inserted
Note:
*
Only 0 can be written to this bit, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 214 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.2.17
Refresh Timer Counter (RTCNT)
RTCNT counts up on the internal clock selected by bits RTCK2 to RTCK0 in REFCR.
When the RTCNT value matches the RTCOR value (compare match), the CMF flag in REFCR is
set to 1 and RTCNT is initialized to H'00. At this time, when the RFSHE bit in REFCR is set to 1,
a refresh cycle is generated. When the RFSHE bit is cleared to 0 and the CMIE bit in REFCR is
set to 1, a compare match interrupt (CMI) is generated.
Bit
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
Initial Value
R/W
9.2.18
Refresh Time Constant Register (RTCOR)
RTCOR specifies intervals at which a compare match for RTCOR and RTCNT is generated.
The RTCOR value is always compared with the RTCNT value. When they match, the CMF flag
in REFCR is set to 1 and RTCNT is initialized to H'00.
Bit
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 215 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.3
Bus Configuration
Figure 9.5 shows the internal bus configuration of this LSI. The internal bus of this LSI consists of
the following three types.
• Internal system bus 1
A bus that connects the CPU, DTC, DMAC, on-chip RAM, on-chip ROM, internal peripheral
bus, and external access bus.
• Internal system bus 2
A bus that connects the EXDMAC and external access bus
• Internal peripheral bus
A bus that accesses registers in the bus controller, interrupt controller, DMAC, and EXDMAC,
and registers of peripheral modules such as SCI and timer.
• External access bus
A bus that accesses external devices via the external bus interface.
Iφ
synchronization
CPU
DTC
On-chip
RAM
On-chip
ROM
Internal system bus 1
Write data
buffer
Bus controller,
interrupt controller,
power-down controller
Internal peripheral bus
Pφ
synchronization
Internal system bus 2
DMAC
EXDMAC
Write data
buffer
External access bus
Bφ
synchronization
Peripheral
functions
Figure 9.5 Internal Bus Configuration
Rev. 2.00 Oct. 21, 2009 Page 216 of 1454
REJ09B0498-0200
External bus
interface
Section 9 Bus Controller (BSC)
9.4
Multi-Clock Function and Number of Access Cycles
The internal functions of this LSI operate synchronously with the system clock (Iφ), the peripheral
module clock (Pφ), or the external bus clock (Bφ). Table 9.1 shows the synchronization clock and
their corresponding functions.
Table 9.1
Synchronization Clocks and Their Corresponding Functions
Synchronization Clock
Function Name
Iφ
MCU operating mode
Interrupt controller
Bus controller
CPU
DTC
DMAC
EXDMAC
Internal memory
Clock pulse generator
Power down control
Pφ
I/O ports
TPU
PPG
TMR
WDT
SCI
A/D
D/A
IIC2
USB
Bφ
External bus interface
The frequency of each synchronization clock (Iφ, Pφ, and Bφ) is specified by the system clock
control register (SCKCR) independently. For further details, see section 27, Clock Pulse
Generator.
There will be cases when Pφ and Bφ are equal to Iφ and when Pφ and Bφ are different from Iφ
according to the SCKCR specifications. In any case, access cycles for internal peripheral functions
and external space is performed synchronously with Pφ and Bφ, respectively.
Rev. 2.00 Oct. 21, 2009 Page 217 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
For example, in an external address space access where the frequency rate of Iφ and Bφ is n : 1,
the operation is performed in synchronization with Bφ. In this case, external 2-state access space is
2n cycles and external 3-state access space is 3n cycles (no wait cycles is inserted) if the number
of access cycles is counted based on Iφ.
If the frequencies of Iφ, Pφ and Bφ are different, the start of bus cycle may not synchronize with
Pφ or Bφ according to the bus cycle initiation timing. In this case, clock synchronization cycle
(Tsy) is inserted at the beginning of each bus cycle.
For example, if an external address space access occurs when the frequency rate of Iφ and Bφ is
n : 1, 0 to n-1 cycles of Tsy may be inserted. If an internal peripheral module access occurs when
the frequency rate of Iφ and Pφ is m : 1, 0 to m-1 cycles of Tsy may be inserted.
Figure 9.6 shows the external 2-state access timing when the frequency rate of Iφ and Bφ is 4 : 1.
Figure 9.7 shows the external 3-state access timing when the frequency rate of Iφ and Bφ is 2 : 1.
Rev. 2.00 Oct. 21, 2009 Page 218 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Divided clock
synchronization
cycle
Tsy
T1
T2
Iφ
Bφ
Address
CSn
AS
RD
Read
D15 to D8
D7 to D0
LHWR
LLWR
Write
D15 to D8
D7 to D0
BS
RD/WR
Figure 9.6 System Clock: External Bus Clock = 4:1, External 2-State Access
Rev. 2.00 Oct. 21, 2009 Page 219 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Divided clock
synchronization
cycle
Tsy
T1
T2
T3
Iφ
Bφ
Address
CSn
AS
RD
Read
D15 to D8
D7 to D0
LHWR
LLWR
Write
D15 to D8
D7 to D0
BS
RD/WR
Figure 9.7 System Clock: External Bus Clock = 2:1, External 3-State Access
Rev. 2.00 Oct. 21, 2009 Page 220 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.5
External Bus
9.5.1
Input/Output Pins
Table 9.2 shows the pin configuration of the bus controller and table 9.3 shows the pin functions
on each interface.
Table 9.2
Pin Configuration
Name
Symbol
I/O
Function
Bus cycle start
BS
Output
Signal indicating that the bus cycle has started
Address strobe/
address hold
AS/AH
Output
•
Strobe signal indicating that the basic bus, byte control
SRAM, or burst ROM space is accessed and address
output on address bus is enabled
•
Signal to hold the address during access to the
address/data multiplexed I/O interface
Read strobe
RD
Output
Strobe signal indicating that the basic bus, byte control
SRAM, burst ROM, or address/data multiplexed I/O space
is being read
Read/write
RD/WR
Output
•
Signal indicating the input or output direction
•
Write enable signal of the SRAM during access to the
byte control SRAM space
Low-high write/
lower-upper byte
select
LHWR/LUB
Output
•
Strobe signal indicating that the basic bus, burst ROM,
or address/data multiplexed I/O space is written to,
and the upper byte (D15 to D8) of data bus is enabled
•
Strobe signal indicating that the byte control SRAM
space is accessed, and the upper byte (D15 to D8) of
data bus is enabled
Low-low write/
lower-lower byte
select
LLWR/LLB
Output
•
Strobe signal indicating that the basic bus, burst ROM,
or address/data multiplexed I/O space is written to,
and the lower byte (D7 to D0) of data bus is enabled
•
Strobe signal indicating that the byte control SRAM
space is accessed, and the lower byte (D7 to D0) of
data bus is enabled
Rev. 2.00 Oct. 21, 2009 Page 221 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Name
Symbol
I/O
Function
Chip select 0
CS0
Output
Strobe signal indicating that area 0 is selected
Chip select 1
CS1
Output
Strobe signal indicating that area 1 is selected
Chip select 2
CS2
Output
Strobe signal indicating that area 2 is selected
Chip select 3
CS3
Output
Strobe signal indicating that area 3 is selected
Chip select 4
CS4
Output
Strobe signal indicating that area 4 is selected
Chip select 5
CS5
Output
Strobe signal indicating that area 5 is selected
Chip select 6
CS6
Output
Strobe signal indicating that area 6 is selected
Chip select 7
CS7
Output
Strobe signal indicating that area 7 is selected
Row address strobe
RAS
Output
•
Row address strobe signal when area 2 is
specified as DRAM space
•
Row address strobe signal when area 2 is
specified as SDRAM space
Column address strobe
CAS
Output
Column address strobe signal when area 2 is
specified as SDRAM space
Write enable
WE
Output
•
Write enable signal for DRAM
•
Write enable signal when area 2 is specified as
SDRAM space
•
Lower-upper-column address strobe signal for 32bit DRAM
•
Upper-column address strobe signal for 16-bit
DRAM
•
Lower-upper-data mask enable signal for 32-bit
SDRAM
•
Upper-data mask enable signal for 16-bit SDRAM
•
Lower-lower-column address strobe signal for 32bit DRAM
•
Lower-column address strobe signal for 16-bit
DRAM
•
Column address strobe signal for 8-bit DRAM
•
Lower-lower-data mask enable signal for 32-bit
SDRAM
•
Lower-data mask enable signal for 16-bit SDRAM
•
Data mask enable signal for 8-bit SDRAM
Lower-upper-column address
strobe/lower-upper-data mask
enable
Lower-lower-column address
strobe/lower-lower-data mask
enable
LUCAS/
DQMLU
LLCAS/
DQMLL
Rev. 2.00 Oct. 21, 2009 Page 222 of 1454
REJ09B0498-0200
Output
Output
Section 9 Bus Controller (BSC)
Name
Symbol
I/O
Function
Output enable/clock enable
OE/CKE
Output
•
Output enable signal for DRAM
•
Clock enable signal for SDRAM
SDRAMφ
SDRAMφ
Output
SDRAM dedicated clock
Wait
WAIT
Input
Wait request signal when accessing external address
space
Bus request
BREQ
Input
Request signal for release of bus to external bus
master
Bus request acknowledge
BACK
Output
Acknowledge signal indicating that bus has been
released to external bus master
Bus request output
BREQO
Output
External bus request signal used when internal bus
master accesses external address space in the
external-bus released state
Data transfer acknowledge 3
(DMAC_3)
DACK3
Output
Data acknowledge signal for DMAC_3 single address
transfer
Data transfer acknowledge 2
(DMAC_2
DACK2
Output
Data acknowledge signal for DMAC_2 single address
transfer
Data transfer acknowledge 1
(DMAC_1)
DACK1
Output
Data acknowledge signal for DMAC_1 single address
transfer
Data transfer acknowledge 0
(DMAC_0)
DACK0
Output
Data acknowledge signal for DMAC_0 single address
transfer
Data transfer acknowledge 3
(EXDMAC_3)
EDACK3
Output
Data acknowledge signal for EXDMAC_3 single
address transfer
Data transfer acknowledge 2
(EXDMAC_2
EDACK2
Output
Data acknowledge signal for EXDMAC_2 single
address transfer
Data transfer acknowledge 1
(EXDMAC_1)
EDACK1
Output
Data acknowledge signal for EXDMAC_1 single
address transfer
Data transfer acknowledge 0
(EXDMAC_0)
EDACK0
Output
Data acknowledge signal for EXDMAC_0 single
address transfer
External bus clock
Bφ
Output
External bus clock
Rev. 2.00 Oct. 21, 2009 Page 223 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Table 9.3
Pin Name
Bφ
Pin Functions in Each Interface
16
Output
Basic
Bus
Initial State
Single
8
8
Chip 16
Output
Byte-Control
SRAM
Burst
ROM
Address/Data
Multiplexed I/O DRAM
SDRAM
16
16
8
16
8
16
8
16
8
⎯
O
O
O
O
O
O
O
O
O
O
O
O
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
CS0
Output
Output
⎯
O
O
O
O
O
⎯
⎯
⎯
⎯
⎯ ⎯
CS1
⎯
⎯
⎯
O
O
O
O
O
⎯
⎯
⎯
⎯
⎯ ⎯
CS2
⎯
⎯
⎯
O
O
O
⎯
⎯
⎯
⎯
O
O
O
CS3
⎯
⎯
⎯
O
O
O
⎯
⎯
O
O
⎯
⎯
⎯ ⎯
CS4
⎯
⎯
⎯
O
O
O
⎯
⎯
O
O
⎯
⎯
⎯ ⎯
CS5
⎯
⎯
⎯
O
O
O
⎯
⎯
O
O
⎯
⎯
⎯ ⎯
CS6
⎯
⎯
⎯
O
O
O
⎯
⎯
O
O
⎯
⎯
⎯ ⎯
CS7
⎯
⎯
⎯
O
O
O
⎯
⎯
O
O
⎯
⎯
⎯ ⎯
BS
⎯
⎯
⎯
O
O
O
O
O
O
O
O
O
O
O
RD/WR
⎯
⎯
⎯
O
O
O
O
O
O
O
O
O
O
O
Output
Output
⎯
O
O
O
O
O
⎯
⎯
⎯
⎯
⎯ ⎯
SDRAMφ
AS
(Output) (Output)
Remarks
Controlled by MD3
O
AH
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
O
⎯
⎯
⎯ ⎯
RD
Output
Output
⎯
O
O
O
O
O
O
O
O
O
⎯ ⎯
LHWR/LUB
Output
Output
⎯
O
⎯
O
O
⎯
O
⎯
⎯
⎯
⎯ ⎯
LLWR/LLB
Output
Output
⎯
O
O
O
O
O
O
O
⎯
⎯
⎯ ⎯
RAS
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
O
O
O
CAS
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
O
WE
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
O
O
O
LUCAS/DQMLU
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
⎯
O
⎯
LLCAS/DQMLL
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
O
O
O
OE
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
O
⎯ ⎯
Controlled by DRAME and OEE
CKE
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
Controlled by DRAME and OEE
WAIT
⎯
⎯
⎯
O
O
O
O
O
O
O
O
O
⎯ ⎯
[Legend]
O: Used as bus control signal.
⎯: Not used as bus control signal (I/O port as initial state).
Rev. 2.00 Oct. 21, 2009 Page 224 of 1454
REJ09B0498-0200
O
Controlled by WAITE
Section 9 Bus Controller (BSC)
9.5.2
Area Division
The bus controller divides the 16-Mbyte address space into eight areas, and performs bus control
for the external address space in area units. Chip select signals (CS0 to CS7) can be output for
each area.
Figure 9.8 shows an area division of the 16-Mbyte address space. For details on address map, see
section 3, MCU Operating Modes.
H'000000
Area 0
(2 Mbytes)
H'1FFFFF
H'200000
Area 1
(2 Mbytes)
H'3FFFFF
H'400000
Area 2
(8 Mbytes)
H'BFFFFF
H'C00000
Area 3
(2 Mbytes)
H'DFFFFF
H'E00000
Area 4
(1 Mbyte)
H'EFFFFF
H'F00000
Area 5
(1 Mbyte − 8 kbytes)
H'FFDFFF
H'FFE000
Area 6
H'FFFEFF (8 kbytes − 256 bytes)
H'FFFF00
Area 7
H'FFFFFF
(256 bytes)
16-Mbyte space
Figure 9.8 Address Space Area Division
Rev. 2.00 Oct. 21, 2009 Page 225 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.5.3
Chip Select Signals
This LSI can output chip select signals (CS0 to CS7) for areas 0 to 7. The signal outputs low when
the corresponding external address space area is accessed. Figure 9.9 shows an example of CSn (n
= 0 to 7) signal output timing.
Enabling or disabling of CSn signal output is set by the port function control register (PFCR). For
details, see section 13.3, Port Function Controller.
In on-chip ROM disabled extended mode, pin CS0 is placed in the output state after a reset. Pins
CS1 to CS7 are placed in the input state after a reset and so the corresponding PFCR bits should
be set to 1 when outputting signals CS1 to CS7.
In on-chip ROM enabled extended mode, pins CS0 to CS7 are all placed in the input state after a
reset and so the corresponding PFCR bits should be set to 1 when outputting signals CS0 to CS7.
The PFCR can specify multiple CS outputs for a pin. If multiple CSn outputs are specified for a
single pin by the PFCR, CS to be output are generated by mixing all the CS signals. In this case,
the settings for the external bus interface areas in which the CSn signals are output to a single pin
should be the same.
Figure 9.10 shows the signal output timing when the CS signals to be output to areas 5 and 7 are
output to the same pin.
Bus cycle
T1
T2
T3
Bφ
Address bus
External address of area n
CSn
Figure 9.9 CSn Signal Output Timing (n = 0 to 7)
Rev. 2.00 Oct. 21, 2009 Page 226 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Area 5 access
Area 6 access
Area 5 access
Area 6 access
Bφ
CS5
CS6
Output waveform
Address bus
Figure 9.10 Timing When CS Signal is Output to the Same Pin
9.5.4
External Bus Interface
The type of the external bus interfaces, bus width, endian format, number of access cycles, and
strobe assert/negate timings can be set for each area in the external address space. The bus width
and the number of access cycles for both on-chip memory and internal I/O registers are fixed, and
are not affected by the external bus settings.
(1)
Type of External Bus Interface
Six types of external bus interfaces are provided and can be selected in area units. Table 9.4 shows
each interface name, description, and area name to be set for each interface. Table 9.5 shows the
areas that can be specified for each interface. The initial state of each area is a basic bus interface.
Table 9.4
Interface Names and Area Names
Interface
Description
Area Name
Basic interface
Directly connected to ROM and
RAM
Basic bus space
Byte control SRAM interface
Directly connected to byte
SRAM with byte control pin
Byte control SRAM space
Burst ROM interface
Directly connected to the ROM
that allows page access
Burst ROM space
Address/data multiplexed I/O
interface
Directly connected to the
peripheral LSI that requires
address and data multiplexing
Address/data multiplexed I/O
space
Rev. 2.00 Oct. 21, 2009 Page 227 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Interface
Description
Area Name
DRAM interface
Directly connected to DRAM
DRAM space
Synchronous DRAM interface
Directly connected to
synchronous DRAM
Synchronous DRAM space
Table 9.5
Areas Specifiable for Each Interface
Areas
Interface
Related
Registers
0
1
2
3
4
5
6
7
Basic interface
SRAMCR
O
O
O
O
O
O
O
O
O
O
O
O
O
O
O
O
Byte control SRAM interface
Burst ROM interface
BROMCR
O
O
⎯
⎯
⎯
⎯
⎯
⎯
Address/data multiplexed I/O
interface
MPXCR
⎯
⎯
⎯
O
O
O
O
O
DRAM interface
DRAMCR
⎯
⎯
O
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
⎯
⎯
⎯
⎯
⎯
Synchronous DRAM interface
(2)
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. In addition, the bus width of address/data multiplexed I/O space is 8 bits
or 16 bits, and the bus width for the byte control SRAM space is 16 bits.
The initial state of the bus width is specified by the operating mode.
If all areas are designated as 8-bit access space, 8-bit bus mode is set; if any area is designated as
16-bit access space, 16-bit bus mode is set.
(3)
Endian Format
Though the endian format of this LSI is big endian, data can be converted into little endian format
when reading or writing to the external address space.
Areas 7 to 2 can be specified as either big endian or little endian format by the LE7 to LE2 bits in
ENDIANCR.
The initial state of each area is the big endian format.
Note that the data format for the areas used as a program area or a stack area should be big endian.
Rev. 2.00 Oct. 21, 2009 Page 228 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(4)
Number of Access Cycles
(a)
Basic Bus Interface
The number of access cycles in the basic bus interface can be specified as two or three cycles by
the ASTCR. An area specified as 2-state access is specified as 2-state access space; an area
specified as 3-state access is specified as 3-state access space.
For the 2-state access space, a wait cycle insertion is disabled. For the 3-state access space, a
program wait (0 to 7 cycles) specified by WTCRA and WTCRB or an external wait by WAIT can
be inserted.
Assertion period of the chip select signal can be extended by CSACR.
Number of access cycles in the basic bus interface
= number of basic cycles (2, 3) + number of program wait cycles (0 to 7)
+ number of CS extension cycles (0, 1, 2)
[+ number of external wait cycles by the WAIT pin]
(b)
Byte Control SRAM Interface
The number of access cycles in the byte control SRAM interface is the same as that in the basic
bus interface.
Number of access cycles in byte control SRAM interface
= number of basic cycles (2, 3) + number of program wait cycles (0 to 7)
+ number of CS extension cycles (0, 1, 2)
[+ number of external wait cycles by the WAIT pin]
(c)
Burst ROM Interface
The number of access cycles at full access in the burst ROM interface is the same as that in the
basic bus interface. The number of access cycles in the burst access can be specified as one to
eight cycles by the BSTS bit in BROMCR.
Number of access cycles in the burst ROM interface
= number of basic cycles (2, 3) + number of program wait cycles (0 to 7)
+ number of CS extension cycles (0, 1)
[+number of external wait cycles by the WAIT pin]
+ number of burst access cycles (1 to 8) × number of burst accesses (0 to 63)
Rev. 2.00 Oct. 21, 2009 Page 229 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(d)
Address/data multiplexed I/O interface
The number of access cycles in data cycle of the address/data multiplexed I/O interface is the
same as that in the basic bus interface. The number of access cycles in address cycle can be
specified as two or three cycles by the ADDEX bit in MPXCR.
Number of access cycles in the address/data multiplexed I/O interface
= number of address output cycles (2, 3) + number of data output cycles (2, 3)
+ number of program wait cycles (0 to 7)
+ number of CS extension cycles (0, 1, 2)
[+number of external wait cycles by the WAIT pin]
(e)
DRAM Interface
In the DRAM interface, the numbers of precharge cycles, row address output cycles, and column
address output cycles can be specified.
The number of precharge cycles can be specified as one to four cycles by bits TPC1 and TPC0 in
DRACCR. The number of row address output cycles can be specified as one to four cycles by bits
RCD1 and RCD0 in DRACCR. The number of column address output cycles can be specified as
two or three cycles by the CAST bit in DRAMCR. For the column address output cycle, program
wait (0 to 7 cycles) specified by WTCRB or external wait by WAIT can be inserted.
Number of access cycles in the DRAM interface
= number of precharge cycles (1 to 4) + number of row address output cycles (1 to 4)
+ number of column address output cycles (2 or 3)
+ number of program wait cycles (0 to 7)
[+number of external wait cycles by the WAIT pin]
(f)
SDRAM Interface
In the SDRAM interface, the numbers of precharge cycles, row address output cycles, and column
address output cycles, as well as clock suspend and write-precharge delay, can be specified by
DRACCR and WTCRB.
The number of precharge cycles can be specified as one to four cycles by bits TPC1 and TPC0 in
DRACCR. The number of row address output cycles can be specified as one to four cycles by bits
RCD1 and RCD0 in DRACCR. The number of column address output cycles during read access
can be specified as two to four cycles by bits W21 and W20 in WTCRB.
The cycles for clock suspend and write-precharge delay can be inserted by bits CKSPE and
TRWL in SDCR.
Rev. 2.00 Oct. 21, 2009 Page 230 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Number of access cycles in the SDRAM interface
= number of precharge cycles (1 to 4) + number of row address output cycles (1 to 4)
+ number of column address output cycles (read: 2 to 4, write: 2)
+ number of clock suspend cycles (only read: 0 or 1)
+ number of write precharge delay cycles (only write: 0 or 1)
Table 9.6 lists the number of access cycles for each interface.
Table 9.6
Number of Access Cycles
Basic bus interface
=
=
Byte-control SRAM interface
=
=
Burst ROM interface
=
=
Address/data multiplexed I/O
interface
DRAM
interface
Full access
Fast page
Refresh
Self-refresh
SDRAM
interface
Setting mode
register
Full access
(read)
Full access
(write)
Page access
(read)
Page access
(write)
Cluster transfer
(read)
=Tma
[2,3]
=Tma
[2,3]
=Tp
[1 to 4]
=
=TRp
[1 to 4]
=TRp
[1 to 4]
=
=
=
Th
[0,1]
Th
[0,1]
Th
[0,1]
Th
[0,1]
Th
[0,1]
Th
[0,1]
+Th
[0,1]
+Th
[0,1]
+Tr
[1]
+T1
[1]
+T1
[1]
+T1
[1]
+T1
[1]
+T1
[1]
+T1
[1]
+T1
[1]
+T1
[1]
+Trw
[0 to 3]
+TRrw
[0 to 3]
+TRrw
[0 to 3]
Tp
[1 to 4]
Tp
[1 to 4]
Tp
[1 to 4]
+TRr
[1]
+TRr
[1]
+Tr
[1]
+Tr
[1]
+Tr
[1]
=
=
=
Tp
[1 to 4]
+Tr
[1]
Tp
[1 to 4]
+Tr
[1]
TRp
[1 to 4]
TRp
[1 to 4]
+TRr
[1]
+TRr
[1]
=
Cluster transfer
(write)
=
=
Refresh
=
Self-refresh
=
+T2
[1]
+Tpw
+T2
[1]
[0 to 7]
+T2
[1]
+T2
+Tpw
[1]
[0 to 7]
+T2
[1]
+T2
+Tpw
[1]
[0 to 7]
+T2
[1]
+T2
+Tpw
[1]
[0 to 7]
+TC1
+Tpw
[1]
[0 to 7]
TC1
+Tpw
[1]
[0 to 7]
+TRc1
+TRcw
[1]
[0 to 7]
Software
+
standby mode
[1+s]
+Trw
+Tc1
[0 to 3]
[1]
+Trw
+Tc1
[0 to 3]
[1]
+Trw
+Tc1
[0 to 3]
[1]
Tc1
[1]
Tc1
[1]
+Trw
+Tc1
[0 to 3]
[1]
Tc1
[1]
+Trw
+Tc1
[0 to 3]
[1]
Tc1
[1]
+TRc1
+TRcw
[1]
[0 to 7]
Software
+
standby mode
[1+s]
+Ttw
[n]
+T3
[1]
+Ttw
[n]
+T3
[1]
+Ttw
[n]
+Ttw
[n]
+Ttw
[n]
+Ttw
[n]
+TRc2
[1]
+Tt
[0,1]
+Tt
[0,1]
+Tt
[0,1]
+Tt
[0,1]
[3 to 12+n]
[2 to 4]
[3 to 12+n]
+Tb
[(1 to 8) x m]
+Tb
[(1 to 8) x m]
+T3
[1]
+T3
[1]
+Tc2
[1]
+Tc2
[1]
+Tt
[0,1]
+Tt
[0,1]
+Tc3
[0,1]
+Tc3
[0,1]
+TRc3
[1]
+TRc4
[1]
[(2 to 3)+(1 to 8) x m]
[(2 to 11+n)+(1 to 8) x m]
[4 to 7]
[5 to 15+n]
[4 to 18+n]
[2 to 10+n]
[4 to 17]
+Tcl
[1 to 3]
+Tcl
[1 to 3]
+Tsp
[0,1]
+Tsp
[0,1]
+Tcl
+Tcb
[0 to 31] [1 to 3]
+Tcl
+Tcb
[0 to 31] [1 to 3]
+TRc2
[1]
+TRc2
[1]
[2 to 4]
+TRp
[0 to 7]
+Tc2
[1]
+Tc2
[1]
+Tc2
[1]
+Tc2
[1]
+Tc2
[1]
+Tc2
[1]
+Tc2
[1]
+Tc2
[1]
+Tc2
[1]
[5 to 18+s]
+Trwl
[0,1]
[4 to 11]
[5 to 14]
+Trwl
[0,1]
[4 to 11]
[3 to 6]
+Trwl
[0,1]
[2 to 3]
[5 to 44]
[3 to 36]
+Tcb
[0 to 31]
+Tcb
[0 to 31]
[4 to 41]
[2 to 33]
[4 to 14]
+TRc3
[1]
+TRp
[0 to 7]
[5 to 15+s]
[Legend]
Number enclosed by bracket: Number of access cycles
n: Pin wait (0 to ∞)
m: Number of burst accesses (0 to 63)
s: Time for a transition to or from software standby mode
Rev. 2.00 Oct. 21, 2009 Page 231 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(5)
Strobe Assert/Negate Timings
The assert and negate timings of the strobe signals can be modified as well as number of access
cycles.
•
•
•
•
Read strobe (RD) in the basic bus interface
Chip select assertion period extension cycles in the basic bus interface
Data transfer acknowledge (DACK3 to DACK0) output for DMAC single address transfers
Data transfer acknowledge (EDACK3 to EDACK0) output for EXDMAC single address
transfers
9.5.5
(1)
Area and External Bus Interface
Area 0
Area 0 includes on-chip ROM. All of area 0 is used as external address space in on-chip ROM
disabled extended mode, and the space excluding on-chip ROM is external address space in onchip ROM enabled extended mode.
When area 0 external address space is accessed, the CS0 signal can be output.
Either of the basic bus interface, byte control SRAM interface, or burst ROM interface can be
selected for area 0 by bit BSRM0 in BROMCR and bit BCSEL0 in SRAMCR. Table 9.7 shows
the external interface of area 0.
Table 9.7
Area 0 External Interface
Register Setting
Interface
BSRM0 of BROMCR
BCSEL0 of SRAMCR
Basic bus interface
0
0
Byte control SRAM interface
0
1
Burst ROM interface
1
0
Setting prohibited
1
1
Rev. 2.00 Oct. 21, 2009 Page 232 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(2)
Area 1
In externally extended mode, all of area 1 is external address space. In on-chip ROM enabled
extended mode, the space excluding on-chip ROM is external address space.
When area 1 external address space is accessed, the CS1 signal can be output.
Either of the basic bus interface, byte control SRAM, or burst ROM interface can be selected for
area 1 by bit BSRM1 in BROMCR and bit BCSEL1 in SRAMCR. Table 9.8 shows the external
interface of area 1.
Table 9.8
Area 1 External Interface
Register Setting
Interface
BSRM1 of BROMCR
BCSEL1 of SRAMCR
Basic bus interface
0
0
Byte control SRAM interface
0
1
Burst ROM interface
1
0
Setting prohibited
1
1
(3)
Area 2
In externally extended mode, all of area 2 is external address space.
When area 2 external address space is accessed, the CS2 signal can be output.
Either the basic bus interface, byte-control SRAM interface, DRAM interface, or SDRAM
interface can be selected for area 2 by the DRAME and DTYPE bits in DRAMCR and bit
BCSEL2 in SRAMCR. Table 9.9 shows the external interface of area 2.
Table 9.9
Area 2 External Interface
Register Setting
Interface
DRAME in
DRAMCR
DTYPE
in DRAMCR
BCSEL2 in
SRAMCR
Basic bus interface
0
Don't care
0
Byte-control SRAM interface
0
Don't care
1
DRAM interface
1
0
0
SDRAM interface
1
1
0
Setting prohibited
1
Don't care
1
Rev. 2.00 Oct. 21, 2009 Page 233 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(4)
Area 3
In externally extended mode, all of area 3 is external address space.
When area 3 external address space is accessed, the CS3 signal can be output.
Either of the basic bus interface, byte control SRAM interface, or address/data multiplexed I/O
interface can be selected for area 3 by bit MPXE3 in MPXCR and bit BCSEL3 in SRAMCR.
Table 9.10 shows the external interface of area 3.
Table 9.10 Area 3 External Interface
Register Setting
Interface
MPXE3 of MPXCR
BCSEL3 of SRAMCR
Basic bus interface
0
0
Byte control SRAM interface
0
1
Address/data multiplexed I/O
interface
1
0
Setting prohibited
1
1
(5)
Area 4
In externally extended mode, all of area 4 is external address space.
When area 4 external address space is accessed, the CS4 signal can be output.
Either of the basic bus interface, byte control SRAM interface, or address/data multiplexed I/O
interface can be selected for area 4 by bit MPXE4 in MPXCR and bit BCSEL4 in SRAMCR.
Table 9.11 shows the external interface of area 4.
Table 9.11 Area 4 External Interface
Register Setting
Interface
MPXE4 of MPXCR
BCSEL4 of SRAMCR
Basic bus interface
0
0
Byte control SRAM interface
0
1
Address/data multiplexed I/O
interface
1
0
Setting prohibited
1
1
Rev. 2.00 Oct. 21, 2009 Page 234 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(6)
Area 5
Area 5 includes the on-chip RAM and access prohibited spaces. In external extended mode, area
5, other than the on-chip RAM and access prohibited spaces, is external address space. Note that
the on-chip RAM is enabled when the RAME bit in SYSCR are set to 1. If the RAME bit in
SYSCR is cleared to 0, the on-chip RAM is disabled and the corresponding addresses are an
external address space. For details, see section 3, MCU Operating Modes.
When area 5 external address space is accessed, the CS5 signal can be output.
Either of the basic bus interface, byte control SRAM interface, or address/data multiplexed I/O
interface can be selected for area 5 by the MPXE5 bit in MPXCR and the BCSEL5 bit in
SRAMCR. Table 9.12 shows the external interface of area 5.
Table 9.12 Area 5 External Interface
Register Setting
Interface
MPXE5 of MPXCR
BCSEL5 of SRAMCR
Basic bus interface
0
0
Byte control SRAM interface
0
1
Address/data multiplexed I/O
interface
1
0
Setting prohibited
1
1
(7)
Area 6
Area 6 includes internal I/O registers. In external extended mode, area 6 other than on-chip I/O
register area is external address space.
When area 6 external address space is accessed, the CS6 signal can be output.
Either of the basic bus interface, byte control SRAM interface, or address/data multiplexed I/O
interface can be selected for area 6 by the MPXE6 bit in MPXCR and the BCSEL6 bit in
SRAMCR. Table 9.13 shows the external interface of area 6.
Rev. 2.00 Oct. 21, 2009 Page 235 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Table 9.13 Area 6 External Interface
Register Setting
Interface
MPXE6 of MPXCR
BCSEL6 of SRAMCR
Basic bus interface
0
0
Byte control SRAM interface
0
1
Address/data multiplexed I/O
interface
1
0
Setting prohibited
1
1
(8)
Area 7
Area 7 includes internal I/O registers. In external extended mode, area 7 other than internal I/O
register area is external address space.
When area 7 external address space is accessed, the CS7 signal can be output.
Either of the basic bus interface, byte control SRAM interface, or address/data multiplexed I/O
interface can be selected for area 7 by the MPXE7 bit in MPXCR and the BCSEL7 bit in
SRAMCR. Table 9.14 shows the external interface of area 7.
Table 9.14 Area 7 External Interface
Register Setting
Interface
MPXE7 of MPXCR
BCSEL7 of SRAMCR
Basic bus interface
0
0
Byte control SRAM interface
0
1
Address/data multiplexed I/O
interface
1
0
Setting prohibited
1
1
Rev. 2.00 Oct. 21, 2009 Page 236 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.5.6
Endian 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, and controls whether the upper byte 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), the data size, and endian format when
accessing external address space.
(1)
8-Bit Access Space
With the 8-bit access space, the lower byte data bus (D7 to D0) is always used for access. The
amount of data that can be accessed at one time is one byte: a word access is performed as two
byte accesses, and a longword access, as four byte accesses.
Figures 9.11 and 9.12 illustrate data alignment control for the 8-bit access space. Figure 9.11
shows the data alignment when the data endian format is specified as big endian. Figure 9.12
shows the data alignment when the data endian format is specified as little endian.
Strobe signal
LHWR/LUB
LLWR/LLB
RD
Data
Size
Access
Address
Byte
n
1
Word
n
2
Longword
n
Access
Count
4
Bus
Cycle
Data Size
D15
Data bus
D8 D7
D0
1st
Byte
7
0
1st
Byte
15
8
2nd
Byte
7
0
1st
Byte
31
24
2nd
Byte
23
16
3rd
Byte
15
8
4th
Byte
7
0
Figure 9.11 Access Sizes and Data Alignment Control for 8-Bit Access Space (Big Endian)
Rev. 2.00 Oct. 21, 2009 Page 237 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Strobe signal
LHWR/LUB
LLWR/LLB
RD
Data
Size
Byte
Word
Longword
Access
Address
n
n
n
Data bus
D8 D7
Access
Count
Bus
Cycle
1
1st
Byte
7
0
1st
Byte
7
0
2nd
Byte
15
8
1st
Byte
7
0
2nd
Byte
15
8
3rd
Byte
23
16
4th
Byte
31
24
Data Size
D15
D0
2
4
Figure 9.12 Access Sizes and Data Alignment Control for 8-Bit Access Space
(Little Endian)
(2)
16-Bit Access Space
With the 16-bit access space, the upper byte data bus (D15 to D8) and lower byte 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.
Figures 9.13 and 9.14 illustrate data alignment control for the 16-bit access space. Figure 9.13
shows the data alignment when the data endian format is specified as big endian. Figure 9.14
shows the data alignment when the data endian format is specified as little endian.
In big endian, byte access for an even address is performed by using the upper byte data bus and
byte access for an odd address is performed by using the lower byte data bus.
In little endian, byte access for an even address is performed by using the lower byte data bus, and
byte access for an odd address is performed by using the third byte data bus.
Rev. 2.00 Oct. 21, 2009 Page 238 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Strobe signal
LHWR/LUB
LLWR/LLB
RD
Access
Size
Byte
Word
Longword
Access
Address
Even
(2n)
Odd
(2n+1)
Even
(2n)
Odd
(2n+1)
Even
(2n)
Odd
(2n+1)
Access
Count
Bus
Cycle
Data Size
1
1st
Byte
1
1st
Byte
1
1st
Word
2
2
3
D15
Data bus
D8 D7
D0
0
7
15
7
0
8 7
0
15
8
1st
Byte
2nd
Byte
7
0
1st
Word
31
24 23
16
2nd
Word
15
8 7
0
1st
Byte
31
24
2nd
Word
23
16 15
8
3rd
Byte
7
0
Figure 9.13 Access Sizes and Data Alignment Control for 16-Bit Access Space (Big Endian)
Strobe signal
LHWR/LUB
LLWR/LLB
RD
Access
Size
Byte
Word
Longword
Access
Address
Even
(2n)
Odd
(2n+1)
Even
(2n)
Access
Count
Bus
Cycle
Data Size
1
1st
Byte
1
1st
1
1st
Odd
(2n+1)
2
Even
(2n)
2
Odd
(2n+1)
3
D15
Data bus
D8 D7
D0
7
0
Byte
7
0
Word
15
8 7
0
1st
Byte
7
2nd
Byte
1st
2nd
0
15
8
Word
15
8 7
0
Word
31
24 23
16
1st
Byte
7
2nd
Word
23
3rd
Byte
0
16 15
8
31
24
Figure 9.14 Access Sizes and Data Alignment Control for 16-Bit Access Space
(Little Endian)
Rev. 2.00 Oct. 21, 2009 Page 239 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.6
Basic Bus Interface
The basic bus interface can be connected directly to the ROM and SRAM. The bus specifications
can be specified by the ABWCR, ASTCR, WTCRA, WTCRB, RDNCR, CSACR, and
ENDIANCR.
9.6.1
Data Bus
Data sizes for the CPU and other internal bus masters are byte, word, and longword. The bus
controller has a data alignment function, and controls whether the upper byte data bus (D15 to D8)
or lower byte 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), the data size, and endian format when
accessing external address space. For details, see section 9.5.6, Endian and Data Alignment.
9.6.2
I/O Pins Used for Basic Bus Interface
Table 9.15 shows the pins used for basic bus interface.
Table 9.15 I/O Pins for Basic Bus Interface
Name
Symbol
Bus cycle start
BS
Output
Signal indicating that the bus cycle has started
Address strobe
AS*
Output
Strobe signal indicating that an address output on the
address bus is valid during access
Read strobe
RD
Output
Strobe signal indicating the read access
Read/write
RD/WR
Output
Signal indicating the data bus input or output
direction
Low-high write
LHWR
Output
Strobe signal indicating that the upper byte (D15 to
D8) is valid during write access
Low-low write
LLWR
Output
Strobe signal indicating that the lower byte (D7 to
D0) is valid during write access
Chip select 0 to 7
CS0 to CS7 Output
Strobe signal indicating that the area is selected
Wait
WAIT
Wait request signal used when an external address
space is accessed
Note:
*
I/O
Input
Function
When the address/data multiplexed I/O is selected, this pin only functions as the AH
output and does not function as the AS output.
Rev. 2.00 Oct. 21, 2009 Page 240 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.6.3
Basic Timing
This section describes the basic timing when the data is specified as big endian.
(1)
16-Bit 2-State Access Space
Figures 9.15 to 9.17 show the bus timing of 16-bit 2-state access space.
When accessing 16-bit access space, the upper byte data bus (D15 to D8) is used for even
addresses access, and the lower byte data bus (D7 to D0) is used for odd addresses. No wait cycles
can be inserted.
Bus cycle
T1
T2
Bφ
Address
CSn
AS
RD
Read
D15 to D8
Valid
D7 to D0
Invalid
LHWR
LLWR
High level
D15 to D8
Valid
D7 to D0
High-Z
Write
BS
RD/WR
DACK or EDACK
Notes: 1. n = 0 to 7
2. When RDNn = 0
3. When DKC and EDKC = 0
Figure 9.15 16-Bit 2-State Access Space Bus Timing (Byte Access for Even Address)
Rev. 2.00 Oct. 21, 2009 Page 241 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bus cycle
T2
T1
Bφ
Address
CSn
AS
RD
Read
D15 to D8
Invalid
D7 to D0
Valid
LHWR
Write
High level
LLWR
D15 to D8
D7 to D0
High-Z
Valid
BS
RD/WR
DACK or EDACK
Notes: 1. n = 0 to 7
2. When RDNn = 0
3. When DKC and EDKC = 0
Figure 9.16 16-Bit 2-State Access Space Bus Timing (Byte Access for Odd Address)
Rev. 2.00 Oct. 21, 2009 Page 242 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bus cycle
T2
T1
Bφ
Address
CSn
AS
RD
Read
D15 to D8
Valid
D7 to D0
Valid
LHWR
LLWR
Write
D15 to D8
Valid
D7 to D0
Valid
BS
RD/WR
DACK or EDACK
Notes: 1. n = 0 to 7
2. When RDNn = 0
3. When DKC and EDKC = 0
Figure 9.17 16-Bit 2-State Access Space Bus Timing (Word Access for Even Address)
Rev. 2.00 Oct. 21, 2009 Page 243 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(2)
16-Bit 3-State Access Space
Figures 9.18 to 9.20 show the bus timing of 16-bit 3-state access space.
When accessing 16-bit access space, the upper byte data bus (D15 to D8) is used for even
addresses, and the lower byte data bus (D7 to D0) is used for odd addresses. Wait cycles can be
inserted.
Bus cycle
T1
T2
T3
Bφ
Address
CSn
AS
RD
Read
D15 to D8
Valid
D7 to D0
Invalid
LHWR
LLWR
High level
Write
D15 to D8
Valid
D7 to D0
High-Z
BS
RD/WR
DACK or EDACK
Notes: 1. n = 0 to 7
2. When RDNn = 0
3. When DKC and EDKC = 0
Figure 9.18 16-Bit 3-State Access Space Bus Timing (Byte Access for Even Address)
Rev. 2.00 Oct. 21, 2009 Page 244 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bus cycle
T1
T2
T3
Bφ
Address
CSn
AS
RD
Read
D15 to D8
Invalid
D7 to D0
Valid
LHWR
High level
Write
LLWR
D15 to D8
D7 to D0
High-Z
Valid
BS
RD/WR
DACK or EDACK
Notes: 1. n = 0 to 7
2. When RDNn = 0
3. When DKC and EDKC = 0
Figure 9.19 16-Bit 3-State Access Space Bus Timing (Word Access for Odd Address)
Rev. 2.00 Oct. 21, 2009 Page 245 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bus cycle
T1
T2
T3
Bφ
Address
CSn
AS
RD
Read
D15 to D8
Valid
D7 to D0
Valid
LHWR
LLWR
Write
D15 to D8
Valid
D7 to D0
Valid
BS
RD/WR
DACK or EDACK
Notes: 1. n = 0 to 7
2. When RDNn = 0
3. When DKC and EDKC = 0
Figure 9.20 16-Bit 3-State Access Space Bus Timing (Word Access for Even Address)
Rev. 2.00 Oct. 21, 2009 Page 246 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.6.4
Wait Control
This LSI can extend the bus cycle by inserting wait cycles (Tw) when the external address space is
accessed. There are two ways of inserting wait cycles: program wait (Tpw) insertion and pin wait
(Ttw) insertion using the WAIT pin.
(1)
Program Wait Insertion
From 0 to 7 wait cycles can be inserted automatically between the T2 state and T3 state for 3-state
access space, according to the settings in WTCRA and WTCRB.
(2)
Pin Wait Insertion
For 3-state access space, when the WAITE bit in BCR1 is set to 1 and the corresponding ICR bit
is set to 1, wait input by means of the WAIT pin is enabled. When the external address space is
accessed in this state, a program wait (Tpw) is first inserted according to the WTCRA and
WTCRB settings. If the WAIT pin is low at the falling edge of Bφ in the last T2 or Tpw cycle,
another Ttw cycle is inserted until the WAIT pin is brought high. The pin wait insertion is
effective when the Tw cycles are inserted to seven cycles or more, or when the number of Tw
cycles to be inserted is changed according to the external devices. The WAITE bit is common to
all areas. For details on ICR, see section 13, I/O Ports.
Rev. 2.00 Oct. 21, 2009 Page 247 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Figure 9.21 shows an example of wait cycle insertion timing. After a reset, the 3-state access is
specified, the program wait is inserted for seven cycles, and the WAIT input is disabled.
T1
T2
Wait by
program
Wait by WAIT pin
wait
Tpw
Ttw
Ttw
T3
Bφ
WAIT
Address
CSn
AS
RD
Read
Read
data
Data bus
LHWR, LLWR
Write
Data bus
Write data
BS
RD/WR
Notes: 1. Upward arrows indicate the timing of WAIT pin sampling.
2. n = 0 to 7
3. When RDNn = 0
Figure 9.21 Example of Wait Cycle Insertion Timing
Rev. 2.00 Oct. 21, 2009 Page 248 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.6.5
Read Strobe (RD) Timing
The read strobe timing can be modified in area units by setting bits RDN7 to RDN0 in RDNCR to
1.
Note that the RD timing with respect to the DACK and EDACK rising edge will change if the
read strobe timing is modified by setting RDNn to 1 when the DMAC or the EXDMAC is used in
the single address mode.
Figure 9.22 shows an example of timing when the read strobe timing is changed in the basic bus 3state access space.
Bus cycle
T1
T3
T2
Bφ
Address bus
CSn
AS
RD
RDNn = 0
Data bus
RD
RDNn = 1
Data bus
BS
RD/WR
DACK or EDACK
Notes: 1. n = 0 to 7
2. When DKC and EDKC = 0
Figure 9.22 Example of Read Strobe Timing
Rev. 2.00 Oct. 21, 2009 Page 249 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.6.6
Extension of Chip Select (CS) Assertion Period
Some external I/O devices require a setup time and hold time between address and CS signals and
strobe signals such as RD, LHWR, and LLWR.
Settings can be made in CSACR to insert cycles in which only the CS, AS, and address signals are
asserted before and after a basic bus space access cycle. Extension of the CS assertion period can
be set in area units. With the CS assertion extension period in write access, the data setup and hold
times are less stringent since the write data is output to the data bus.
Figure 9.23 shows an example of the timing when the CS assertion period is extended in basic bus
3-state access space.
Both extension cycle Th inserted before the basic bus cycle and extension cycle Tt inserted after
the basic bus cycle, or only one of these, can be specified for individual areas. Insertion or noninsertion can be specified for the Th cycle with the upper eight bits (CSXH7 to CSXH0) in
CSACR, and for the Tt cycle with the lower eight bits (CSXT7 to CSXT0).
Rev. 2.00 Oct. 21, 2009 Page 250 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bus cycle
Th
T1
T2
T3
Tt
Bφ
Address
CSn
AS
RD
Read
Data bus
Read data
LHWR, LLWR
Write
Data bus
Write data
BS
RD/WR
DACK or EDACK
Notes: 1. n = 0 to 7
2. When DKC and EDKC = 0
Figure 9.23 Example of Timing when Chip Select Assertion Period is Extended
Rev. 2.00 Oct. 21, 2009 Page 251 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.6.7
DACK and EDACK Signal Output Timing
When the DMAC or EXDMAC transfers data in single address mode, the output timing of the
DACK and EDACK signals can be changed by the DKC and EDKC bits in BCR1.
Figure 9.24 shows the output timing of the DACK and EDACK signals. The DACK and EDACK
signals are asserted a half cycle earlier by setting the DKC or EDKC bits to 1.
Bus cycle
T1
T2
Bφ
Address bus
CSn
AS
RD
Read
Data bus
Read data
LHWR, LLWR
Write
Data bus
Write data
BS
RD/WR
DKC, EDKC = 0
DACK or
EDACK
DKC, EDKC = 1
Notes: 1. n = 7 to 0
2. RDNn = 0
Figure 9.24 DACK and EDACK Signal Output Timing
Rev. 2.00 Oct. 21, 2009 Page 252 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.7
Byte Control SRAM Interface
The byte control SRAM interface is a memory interface for outputting a byte select strobe during
a read or a write bus cycle. This interface has 16-bit data input/output pins and can be connected to
the SRAM that has the upper byte select and the lower byte select strobes such as UB and LB.
The operation of the byte control SRAM interface is the same as the basic bus interface except
that: the byte select strobes (LUB and LLB) are output from the write strobe output pins (LHWR
and LLWR), respectively; the read strobe (RD) negation timing is a half cycle earlier than that in
the case where RDNn = 0 in the basic bus interface regardless of the RDNCR settings; and the
RD/WR signal is used as write enable.
9.7.1
Byte Control SRAM Space Setting
Byte control SRAM interface can be specified for areas 0 to 7. Each area can be specified as byte
control SRAM interface by setting bits BCSELn (n = 0 to 7) in SRAMCR. For the area specified
as burst ROM interface or address/data multiplexed I/O interface, the SRAMCR setting is invalid
and byte control SRAM interface cannot be used.
9.7.2
Data Bus
The bus width of the byte control SRAM space can be specified as 16-bit byte control SRAM
space according to bits ABWHn and ABWLn (n = 0 to 7) in ABWCR. The area specified as 8-bit
access space cannot be specified as the byte control SRAM space.
For the 16-bit byte control SRAM space, data bus (D15 to D0) is valid.
Access size and data alignment are the same as the basic bus interface. For details, see section
9.5.6, Endian and Data Alignment.
Rev. 2.00 Oct. 21, 2009 Page 253 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.7.3
I/O Pins Used for Byte Control SRAM Interface
Table 9.16 shows the pins used for the byte control SRAM interface.
In the byte control SRAM interface, write strobe signals (LHWR and LLWR) are output from the
byte select strobes. The RD/WR signal is used as a write enable signal.
Table 9.16 I/O Pins for Byte Control SRAM Interface
Pin
When Byte Control
SRAM is Specified
AS/AH
Name
I/O
Function
AS
Address
strobe
Output
Strobe signal indicating that the address
output on the address bus is valid when a
basic bus interface space or byte control
SRAM space is accessed
CSn
CSn
Chip select
Output
Strobe signal indicating that area n is
selected
RD
RD
Read strobe
Output
Output enable for the SRAM when the byte
control SRAM space is accessed
RD/WR
RD/WR
Read/write
Output
Write enable signal for the SRAM when the
byte control SRAM space is accessed
LHWR/LUB
LUB
Lower-upper
byte select
Output
Upper byte select when the 16-bit byte
control SRAM space is accessed
LLWR/LLB
LLB
Lower-lower
byte select
Output
Lower byte select when the 16-bit byte
control SRAM space is accessed
WAIT
WAIT
Wait
Input
Wait request signal used when an external
address space is accessed
A23 to A0
A23 to A0
Address pin
Output
Address output pin
D15 to D0
D15 to D0
Data pin
Input/
output
Data input/output pin
Rev. 2.00 Oct. 21, 2009 Page 254 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.7.4
(1)
Basic Timing
2-State Access Space
Figure 9.25 shows the bus timing when the byte control SRAM space is specified as a 2-state
access space.
Data buses used for 16-bit access space is the same as those in basic bus interface. No wait cycles
can be inserted.
T1
Bus cycle
T2
Bφ
Address
CSn
AS
LUB
LLB
RD/WR
Read
RD
D15 to D8
Valid
D7 to D0
Valid
RD/WR
Write
High level
RD
D15 to D8
Valid
D7 to D0
Valid
BS
DACK or EDACK
Note: n = 0 to 7
Figure 9.25 16-Bit 2-State Access Space Bus Timing
Rev. 2.00 Oct. 21, 2009 Page 255 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(2)
3-State Access Space
Figure 9.26 shows the bus timing when the byte control SRAM space is specified as a 3-state
access space.
Data buses used for 16-bit access space is the same as those in the basic bus interface. Wait cycles
can be inserted.
T1
Bus cycle
T2
T3
Bφ
Address
CSn
AS
LUB
LLB
RD/WR
RD
Read
D15 to D8
Valid
D7 to D0
Valid
RD/WR
Write
RD
High level
D15 to D8
Valid
D7 to D0
Valid
BS
DACK or EDACK
Note: n = 0 to 7
Figure 9.26 16-Bit 3-State Access Space Bus Timing
Rev. 2.00 Oct. 21, 2009 Page 256 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.7.5
Wait Control
The bus cycle can be extended for the byte control SRAM interface by inserting wait cycles (Tw)
in the same way as the basic bus interface.
(1)
Program Wait Insertion
From 0 to 7 wait cycles can be inserted automatically between T2 cycle and T3 cycle for the 3state access space in area units, according to the settings in WTCRA and WTCRB.
(2)
Pin Wait Insertion
For 3-state access space, when the WAITE bit in BCR1 is set to 1, the corresponding DDR bit is
cleared to 0, and the ICR bit is set to 1, wait input by means of the WAIT pin is enabled. For
details on DDR and ICR, refer to section 13, I/O Ports.
Figure 9.27 shows an example of wait cycle insertion timing.
Rev. 2.00 Oct. 21, 2009 Page 257 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Wait by
program wait
T1
T2
Tpw
Wait by WAIT pin
Ttw
Ttw
Bφ
WAIT
Address
CSn
AS
LUB, LLB
RD/WR
Read
RD
Data bus
Read data
RD/WR
Write
RD
High level
Data bus
Write data
BS
DACK or EDACK
Notes: 1. Upward arrows indicate the timing of WAIT pin sampling.
2. n = 0 to 7
Figure 9.27 Example of Wait Cycle Insertion Timing
Rev. 2.00 Oct. 21, 2009 Page 258 of 1454
REJ09B0498-0200
T3
Section 9 Bus Controller (BSC)
9.7.6
Read Strobe (RD)
When the byte control SRAM space is specified, the RDNCR setting for the corresponding space
is invalid.
The read strobe negation timing is the same timing as when RDNn = 1 in the basic bus interface.
Note that the RD timing with respect to the DACK and EDACK rising edge becomes different.
9.7.7
Extension of Chip Select (CS) Assertion Period
In the byte control SRAM interface, the extension cycles can be inserted before and after the bus
cycle in the same way as the basic bus interface. For details, refer to section 9.6.6, Extension of
Chip Select (CS) Assertion Period.
9.7.8
DACK and EDACK Signal Output Timing
For DMAC or EXDMAC single address transfers, the DACK and EDACK signal assert timing
can be modified by using the DKC and EDKC bits in BCR1.
Figure 9.28 shows the DACK and EDACK signal output timing. Setting the DKC bit or the
EDKC bit to 1 asserts the DACK or EDACK signal a half cycle earlier.
Rev. 2.00 Oct. 21, 2009 Page 259 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bus cycle
T2
T1
Bφ
Address
CSn
AS
LUB
LLB
RD/WR
RD
Read
D15 to D8
Valid
D7 to D0
Valid
RD/WR
RD
High level
Write
D15 to D8
Valid
D7 to D0
Valid
BS
DACK or
EDACK
DKC, EDKC = 0
DKC, EDKC = 1
Figure 9.28 DACK Signal Output Timing
Rev. 2.00 Oct. 21, 2009 Page 260 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.8
Burst ROM Interface
In this LSI, external address space areas 0 and 1 can be designated as burst ROM space, and burst
ROM interfacing performed. The burst ROM interface enables ROM with page access capability
to be accessed at high speed.
Areas 1 and 0 can be designated as burst ROM space by means of bits BSRM1 and BSRM0 in
BROMCR. Consecutive burst accesses of up to 32 words can be performed, according to the
setting of bits BSWDn1 and BSWDn0 (n = 0, 1) in BROMCR. From one to eight cycles can be
selected for burst access.
Settings can be made independently for area 0 and area 1.
In the burst ROM interface, the burst access covers only read accesses by the CPU and EXDMAC
cluster transfer. Other accesses are performed with the similar method to the basic bus interface.
9.8.1
Burst ROM Space Setting
Burst ROM interface can be specified for areas 0 and 1. Areas 0 and 1 can be specified as burst
ROM space by setting bits BSRMn (n = 0, 1) in BROMCR.
9.8.2
Data Bus
The bus width of the burst ROM space can be specified as 8-bit or 16-bit burst ROM interface
space according to the ABWHn and ABWLn bits (n = 0, 1) in ABWCR.
For the 8-bit bus width, data bus (D7 to D0) is valid. For the 16-bit bus width, data bus (D15 to
D0) is valid.
Access size and data alignment are the same as the basic bus interface. For details, see section
9.5.6, Endian and Data Alignment.
Rev. 2.00 Oct. 21, 2009 Page 261 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.8.3
I/O Pins Used for Burst ROM Interface
Table 9.17 shows the pins used for the burst ROM interface.
Table 9.17 I/O Pins Used for Burst ROM Interface
Name
Symbol
I/O
Function
Bus cycle start
BS
Output
Signal indicating that the bus cycle has
started.
Address strobe
AS
Output
Strobe signal indicating that an address output on
the address bus is valid during access
Read strobe
RD
Output
Strobe signal indicating the read access
Read/write
RD/WR
Output
Signal indicating the data bus input or output
direction
Low-high write
LHWR
Output
Strobe signal indicating that the upper byte (D15 to
D8) is valid during write access
Low-low write
LLWR
Output
Strobe signal indicating that the lower byte (D7 to
D0) is valid during write access
Output
Strobe signal indicating that the area is selected
Input
Wait request signal used when an external address
space is accessed
Chip select 0 and 1 CS0, CS1
Wait
WAIT
Rev. 2.00 Oct. 21, 2009 Page 262 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.8.4
Basic Timing
The number of access cycles in the initial cycle (full access) on the burst ROM interface is
determined by the basic bus interface settings in ABWCR, ASTCR, WTCRA, WTCRB, and bits
CSXHn in CSACR (n = 0 to 7). When area 0 or area 1 designated as burst ROM space is read by
the CPU or EXDMAC cluster transfer, the settings in RDNCR and bits CSXTn in CSACR (n = 0
to 7) are ignored.
From one to eight cycles can be selected for the burst cycle, according to the settings of bits
BSTS02 to BSTS00 and BSTS12 to BSTS10 in BROMCR. Wait cycles cannot be inserted. In
addition, 4-word, 8-word, 16-word, or 32-word consecutive burst access can be performed
according to the settings of BSTS01, BSTS00, BSTS11, and BSTS10 bits in BROMCR.
The basic access timing for burst ROM space is shown in figures 9.29 and 9.30.
Burst access
Full access
T1
T2
T3
T1
T2
T1
T2
Bφ
Upper
address bus
Lower
address bus
CSn
AS
RD
Data bus
BS
RD/WR
Note: n = 1, 0
Figure 9.29 Example of Burst ROM Access Timing (ASTn = 1, Two Burst Cycles)
Rev. 2.00 Oct. 21, 2009 Page 263 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Burst access
Full access
T1
T2
T1
T1
Bφ
Upper address bus
Lower address bus
CSn
AS
RD
Data bus
BS
RD/WR
Note: n = 1, 0
Figure 9.30 Example of Burst ROM Access Timing (ASTn = 0, One Burst Cycle)
Rev. 2.00 Oct. 21, 2009 Page 264 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.8.5
Wait Control
As with the basic bus interface, either program wait insertion or pin wait insertion by the WAIT
pin can be used in the initial cycle (full access) on the burst ROM interface. See section 9.6.4,
Wait Control. Wait cycles cannot be inserted in a burst cycle.
9.8.6
Read Strobe (RD) Timing
When the burst ROM space is read by the CPU or EXDMAC cluster transfer, the RDNCR setting
for the corresponding space is invalid.
The read strobe negation timing is the same timing as when RDNn = 0 in the basic bus interface.
9.8.7
Extension of Chip Select (CS) Assertion Period
In the burst ROM interface, the extension cycles can be inserted in the same way as the basic bus
interface.
For the burst ROM space, the burst access can be enabled only in read access by the CPU or
EXDMAC cluster transfer. In this case, the setting of the corresponding CSXTn bit in CSACR is
ignored and an extension cycle can be inserted only before the full access cycle. Note that no
extension cycle can be inserted before or after the burst access cycles.
In accesses other than read accesses by the CPU and EXDMAC cluster transfer, the burst ROM
space is equivalent to the basic bus interface space. Accordingly, extension cycles can be inserted
before and after the burst access cycles.
Rev. 2.00 Oct. 21, 2009 Page 265 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.9
Address/Data Multiplexed I/O Interface
If areas 3 to 7 of external address space are specified as address/data multiplexed I/O space in this
LSI, the address/data multiplexed I/O interface can be performed. In the address/data multiplexed
I/O interface, peripheral LSIs that require the multiplexed address/data can be connected directly
to this LSI.
9.9.1
Address/Data Multiplexed I/O Space Setting
Address/data multiplexed I/O interface can be specified for areas 3 to 7. Each area can be
specified as the address/data multiplexed I/O space by setting bits MPXEn (n = 3 to 7) in
MPXCR.
9.9.2
Address/Data Multiplex
In the address/data multiplexed I/O space, data bus is multiplexed with address bus. Table 9.18
shows the relationship between the bus width and address output.
Table 9.18 Address/Data Multiplex
Data Pins
Bus Width
8 bits
16 bits
9.9.3
Cycle
PI7
PI6
PI5
PI4
PI3
PI2
PI1
PI0
PH7 PH6 PH5 PH4 PH3 PH2 PH1 PH0
Address
-
-
-
-
-
-
-
-
A7
A6
A5
A4
A3
A2
A1
A0
Data
-
-
-
-
-
-
-
-
D7
D6
D5
D4
D3
D2
D1
D0
Address
A15
A14
A13
A12
A11
A10
A9
A8
A7
A6
A5
A4
A3
A2
A1
A0
Data
D15 D14 D13 D12 D11 D10
D9
D8
D7
D6
D5
D4
D3
D2
D1
D0
Data Bus
The bus width of the address/data multiplexed I/O space can be specified for either 8-bit access
space or 16-bit access space by the ABWHn and ABWLn bits (n = 3 to 7) in ABWCR.
For the 8-bit access space, D7 to D0 are valid for both address and data. For 16-bit access space,
D15 to D0 are valid for both address and data. If the address/data multiplexed I/O space is
accessed, the corresponding address will be output to the address bus.
For details on access size and data alignment, see section 9.5.6, Endian and Data Alignment.
Rev. 2.00 Oct. 21, 2009 Page 266 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.9.4
I/O Pins Used for Address/Data Multiplexed I/O Interface
Table 9.19 shows the pins used for the address/data multiplexed I/O Interface.
Table 9.19 I/O Pins for Address/Data Multiplexed I/O Interface
Pin
When Byte
Control
SRAM is
Specified
Name
I/O
Function
CSn
CSn
Chip select
Output
Chip select (n = 3 to 7) when area n is specified as the
address/data multiplexed I/O space
AS/AH
AH*
Address hold
Output
Signal to hold an address when the address/data
multiplexed I/O space is specified
RD
RD
Read strobe
Output
Signal indicating that the address/data multiplexed I/O
space is being read
LHWR/LUB
LHWR
Low-high write Output
Strobe signal indicating that the upper byte (D15 to
D8) is valid when the address/data multiplexed I/O
space is written
LLWR/LLB
LLWR
Low-low write
Output
Strobe signal indicating that the lower byte (D7 to D0)
is valid when the address/data multiplexed I/O space is
written
D15 to D0
D15 to D0
Address/data
Input/
output
Address and data multiplexed pins for the
address/data multiplexed I/O space.
Only D7 to D0 are valid when the 8-bit space is
specified. D15 to D0 are valid when the 16-bit space is
specified.
A23 to A0
A23 to A0
Address
Output
Address output pin
WAIT
WAIT
Wait
Input
Wait request signal used when the external address
space is accessed
BS
BS
Bus cycle start Output
Signal to indicate the bus cycle start
RD/WR
RD/WR
Read/write
Signal indicating the data bus input or output direction
Note:
*
Output
The AH output is multiplexed with the AS output. At the timing that an area is specified
as address/data multiplexed I/O, this pin starts to function as the AH output meaning
that this pin cannot be used as the AS output. At this time, when other areas set to the
basic bus interface is accessed, this pin does not function as the AS output. Until an
area is specified as address/data multiplexed I/O, be aware that this pin functions as
the AS output.
Rev. 2.00 Oct. 21, 2009 Page 267 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.9.5
Basic Timing
The bus cycle in the address/data multiplexed I/O interface consists of an address cycle and a data
cycle. The data cycle is based on the basic bus interface timing specified by the ABWCR,
ASTCR, WTCRA, WTCRB, RDNCR, and CSACR.
Figures 9.31 and 9.32 show the basic access timings.
Address cycle
Tma1
Tma2
Data cycle
T1
T2
Bφ
Address bus
CSn
AH
RD
Read
D7 to D0
Address
Read data
LLWR
Write
D7 to D0
Address
Write data
BS
RD/WR
DACK or EDACK
Note: n = 3 to 7
Figure 9.31 8-Bit Access Space Access Timing (ABWHn = 1, ABWLn = 1)
Rev. 2.00 Oct. 21, 2009 Page 268 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Bus cycle
Data cycle
Address cycle
Tma1
Tma2
T1
T2
Bφ
Address bus
CSn
AH
RD
Read
D15 to D0
Address
Read data
LHWR
LLWR
Write
D15 to D0
Address
Write data
BS
RD/WR
DACK or EDACK
Note: n = 3 to 7
Figure 9.32 16-Bit Access Space Access Timing (ABWHn = 0, ABWLn = 1)
Rev. 2.00 Oct. 21, 2009 Page 269 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.9.6
Address Cycle Control
An extension cycle (Tmaw) can be inserted between Tma1 and Tma2 cycles to extend the AH
signal output period by setting the ADDEX bit in MPXCR. By inserting the Tmaw cycle, the
address setup for AH and the AH minimum pulse width can be assured.
Figure 9.33 shows the access timing when the address cycle is three cycles.
Data cycle
Address cycle
Tma1
Tmaw
Tma2
T1
T2
Bφ
Address bus
CSn
AH
RD
Read
D15 to D0
Address
Read data
LHWR
Write
LLWR
D15 to D0
Address
Write data
BS
RD/WR
DACK or EDACK
Note: n = 3 to 7
Figure 9.33 Access Timing of 3 Address Cycles (ADDEX = 1)
Rev. 2.00 Oct. 21, 2009 Page 270 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.9.7
Wait Control
In the data cycle of the address/data multiplexed I/O interface, program wait insertion and pin wait
insertion by the WAIT pin are enabled in the same way as in the basic bus interface. For details,
refer to section 9.6.4, Wait Control.
Wait control settings do not affect the address cycles.
9.9.8
Read Strobe (RD) Timing
In the address/data multiplexed I/O interface, the read strobe timing of data cycles can be modified
in the same way as in basic bus interface. For details, refer to section 9.6.5, Read Strobe (RD)
Timing.
Figure 9.34 shows an example when the read strobe timing is modified.
Rev. 2.00 Oct. 21, 2009 Page 271 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Address cycle
Tma1
Tma2
Data cycle
T1
T2
Bφ
Address bus
CSn
AH
RD
RDNn = 0
D15 to D0
Address
Read data
RD
RDNn = 1
D15 to D0
Address
BS
RD/WR
DACK or EDACK
Note: n = 3 to 7
Figure 9.34 Read Strobe Timing
Rev. 2.00 Oct. 21, 2009 Page 272 of 1454
REJ09B0498-0200
Read
data
Section 9 Bus Controller (BSC)
9.9.9
Extension of Chip Select (CS) Assertion Period
In the address/data multiplexed interface, the extension cycles can be inserted before and after the
bus cycle. For details, see section 9.6.6, Extension of Chip Select (CS) Assertion Period.
Figure 9.35 shows an example of the chip select (CS) assertion period extension timing.
Bus cycle
Data cycle
Address cycle
Tma1
Tma2
Th
T1
T2
Tt
Bφ
Address bus
CSn
AH
RD
Read
D15 to D0
Address
Read data
LHWR
Write
LLWR
D15 to D0
Address
Write data
BS
RD/WR
DACK or EDACK
Note: n = 3 to 7
Figure 9.35 Chip Select (CS) Assertion Period Extension Timing in Data Cycle
Rev. 2.00 Oct. 21, 2009 Page 273 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
When consecutively reading from the same area connected to a peripheral LSI whose data hold
time is long, data outputs from the peripheral LSI and this LSI may conflict. Inserting the chip
select assertion period extension cycle after the access cycle can avoid the data conflict.
Figure 9.36 shows an example of the operation. In the figure, both bus cycles A and B are read
access cycles to the address/data multiplexed I/O space. An example of the data conflict is shown
in (a), and an example of avoiding the data conflict by the CS assertion period extension cycle in
(b).
Bus cycle A
Bus cycle B
Bφ
Address bus
CS
AH
RD
Data bus
Data hold time is long.
Data conflict
(a) Without CS assertion period extension cycle (CSXTn = 0)
Bus cycle A
Bus cycle B
Bφ
Address bus
CS
AH
RD
Data bus
(b) With CS assertion period extension cycle (CSXTn = 1)
Figure 9.36 Consecutive Read Accesses to Same Area
(Address/Data Multiplexed I/O Space)
Rev. 2.00 Oct. 21, 2009 Page 274 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.9.10
DACK and EDACK Signal Output Timing
For DMAC or EXDMAC single address transfers, the DACK and EDACK signal assert timing
can be modified by using bits DKC and EDKC in BCR1.
Figure 9.37 shows the DACK and EDACK signal output timing. Setting the DKC bit or the
EDKC bit to 1 asserts the DACK or EDACK signal a half cycle earlier.
Address cycle
Tma1
Tma2
Data cycle
T1
T2
Bφ
Address bus
CSn
AH
RD
RDNn = 0
D15 to D0
Address
Read data
RD
RDNn = 1
D15 to D0
Address
Read
data
BS
RD/WR
DKC, EDKC = 0
DACK or
EDACK
DKC, EDKC = 1
Note: n = 3 to 7
Figure 9.37 DACK and EDACK Signal Output Timing
Rev. 2.00 Oct. 21, 2009 Page 275 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.10
DRAM Interface
In this LSI, area 2 in the external space can be used as the DRAM interface space. Up to 8 Mbytes
of DRAM is directly connected via the DRAM interface.
9.10.1
Setting DRAM Space
Area 2 can be specified as the DRAM space by the DRAME and DTYPE bits in DRAMCR.
Table 9.20 lists the relationship among the DRAME and DTYPE bits and area 2 interfaces.
The bus settings of the DRAM space such as bus width and wait cycle number depend on area 2
settings.
Table 9.20 Relationship Among DRAME and DTYPE and Area 2 Interfaces
DRAME
DTYPE
Area 2 Interface
0
×
Basic bus space (initial state)/byte-control SRAM space
1
0
DRAM space
1
1
SDRAM space
[Legend]
×: Don't care
9.10.2
Address Multiplexing
A Row address and a column address are multiplexed in the DRAM space. Select the number of
row address bits to be shifted with bits MXC1 and MXC0 in DRAMCR. Table 9.21 lists the
relationship among bits MXC1 and MXC0 and shifted bit number.
Table 9.21 Relationship Among MXC1 and MXC0 and Shifted Bit Count
DRAMCR
Shit Bit
MXC1 MXC0 Count
External Address Pin
Data Bus
Width
Address
A27 to A18
A17 A16 A15 A14 A13 A12 A11 A10
Row address
A23 to A18
A17
0
0
8 bits
8/16 bits
0
1
9 bits
8/16 bits
1
0
10 bits
8/16 bits
1
1
11 bits
8/16 bits
A2
A1
A0
A23 A22 A21 A20 A19 A18 A17 A16 A15 A14 A13 A12 A11 A10
A9
A8
Column address A23 to A18
A17 A16 A15 A14 A13 A12 A11 A10
Row address
A17
A23 to A18
Column address A23 to A18
Row address
A23 to A18
-
-
-
-
A17 A16 A15 A14 A13 A12 A11 A10
A17
Rev. 2.00 Oct. 21, 2009 Page 276 of 1454
-
-
-
A7
A6
A5
A6
A5
A4
A5
A4
A3
A4
A3
A3
A2
A2
A1
A0
A23 A22 A21 A20 A19 A18 A17 A16 A15 A14 A13 A12 A11 A10
Row address
A23 to A18
A8
A7
A6
A0
A9
A8
A7
A9
-
A9
A8
A1
A17 A16 A15 A14 A13 A12 A11 A10
A17
A9
A23 A22 A21 A20 A19 A18 A17 A16 A15 A14 A13 A12 A11 A10
Column address A23 to A18
Column address A23 to A18
REJ09B0498-0200
-
-
A9
A8
A7
A6
A5
A4
A3
A2
A1
A0
A23 A22 A21 A20 A19 A18 A17 A16 A15 A14 A13 A12 A11
A17 A16 A15 A14 A13 A12 A11 A10
A9
A8
A7
A6
A5
A4
A3
A2
A1
A0
Section 9 Bus Controller (BSC)
9.10.3
Data Bus
The data bus width of the DRAM space can be selected from 8 and 16 bits by bits ABWH2 and
ABWL2 in ABWCR. DRAM with 16-bit words can be connected directly to 16-bit bus width
space.
D7 to D0 are valid in 8-bit DRAM space, and D15 to D0 are valid in 16-bit DRAM space.
The data endian format can be selected by bit LE2 in ENDIANCR. For details on the access size
and alignment, see section 9.5.6, Endian and Data Alignment.
9.10.4
I/O Pins Used for DRAM Interface
Table 9.22 shows the pins used for the DRAM interface.
Table 9.22 I/O Pins for DRAM Interface
Pin
DRAM
Selected
Name
I/O
Function
WE
WE
Write enable
Output
Write enable signal for accessing the
DRAM interface
RAS
RAS
Row address
strobe
Output
Row address strobe when the DRAM
space is specified as area 2
LUCAS/
DQMLU
LUCAS
Lower-upper
Output
column address
strobe
LLCAS/
DQMLL
LLCAS
Lower-lower
Output
column address
strobe
•
Lower-upper column address strobe
when the 32-bit DRAM space is
accessed
•
Upper column address strobe when the
16-bit DRAM space is accessed
•
Lower-lower column address strobe
when the 32-bit DRAM space is
accessed
•
Lower column address strobe when the
16-bit DRAM space is accessed
OE
OE
Output enable
Output
Output enable signal when the DRAM
space is accessed
WAIT
WAIT
Wait
Input
Wait request signal used when an external
address space is accessed
A17 to A0
A17 to A0
Address pin
Output
Multiplexed address/data output pin
D15 to D0
D15 to D0
Data pin
Input/
output
Data input/output pin
Rev. 2.00 Oct. 21, 2009 Page 277 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.10.5
Basic Timing
Figure 9.38 shows a basic access timing of the DRAM space.
A basic bus cycle consists of four clock cycles: one precharge cycle (Tp), one row address output
cycle (Tr), and two column address output cycles (Tc1 and Tc2).
The RD signal is output to DRAM as an OE signal on a DRAM access. When DRAM with the
EDO page mode function is in use, connect the OE signal to the OE pin of the DRAM.
Tp
Tr
Tc1
Tc2
Bφ
Address bus
Row address
Column address
RAS
LUCAS
LLCAS
WE
Read
High
OE (RD)
Data bus
WE
Write
OE (RD)
High
Data bus
BS
RD/WR
Figure 9.38 DRAM Basic Access Timing (RAS = 0 and CAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 278 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.10.6
Controlling Column Address Output Cycle
The number of column address output cycles can be changed from two to three clock cycles by
setting the CAST bit in DRAMCR. Set the bit according to the DRAM to be used and the
frequency of this LSI so that the CAS pulse width can be optimal.
Figure 9.39 shows a timing example when the number of column address output cycles is set to
three clock cycles.
Tp
Tr
Tc1
Tc2
Tc3
Bφ
Address bus
Row address
Column address
RAS
LUCAS
LLCAS
WE
Read
High
OE (RD)
Data bus
WE
Write
OE (RD)
High
Data bus
BS
RD/WR
Figure 9.39 Access Timing Example of Column Address Output Cycles for 3 Clock Cycles
(RAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 279 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.10.7
Controlling Row Address Output Cycle
The RAS signal is driven low at the start of the Tr cycle by setting the RAST bit to 1. The row
address hold time to the falling edge of the RAS signal and the DRAM read access time are
changed. Set the bit according to the DRAM to be used and the frequency of this LSI so that
required performance can be obtained.
Figure 9.40 shows a timing example when the RAS signal is driven low at the start of the Tr cycle.
Tp
Tr
Tc1
Tc2
Bφ
Address bus
Row address
Column address
RAS
LUCAS
LLCAS
WE
Read
High
OE (RD)
Data bus
WE
Write
OE (RD)
High
Data bus
BS
RD/WR
Figure 9.40 Access Timing Example of RAS Signal Driven Low at Start of Tr Cycle
(CAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 280 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
To ensure the row address hold time or read access time, one to three of Trw cycles in which the
row address output is retained can be inserted between the Tr and Tc1 cycles. The RAS signal is
driven low in the Tr cycle and the column address is output in the Tc1 cycle. Set the bit according
to the DRAM to be used and the frequency of this LSI so that the row address hold time to the
rising edge of the RAS signal is ensured.
Figure 9.41 shows an access timing example when one Trw cycle is specified.
Tp
Tr
Trw
Tc1
Tc2
Bφ
Address bus
Row address
Column address
RAS
LUCAS
LLCAS
WE
Read
High
OE (RD)
Data bus
WE
Write
OE (RD)
High
Data bus
BS
RD/WR
Figure 9.41 Access Timing Example when One Trw Cycle is Specified (RAST=0, CAST=0)
Rev. 2.00 Oct. 21, 2009 Page 281 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.10.8
Controlling Precharge Cycle
The number of precharge cycles (Tp) can be selected from one to four clock cycles by bits TPC1
and TPC0 in DRACCR. Set the bit according to the DRAM to be used and the frequency of this
LSI so that the number of precharge cycle can be optimal.
Figure 9.42 shows an access timing example when two Tp cycles are specified.
The setting of bits TPC1 and TPC0 affect the Tp cycle of a refresh cycle.
Tp1
Tp2
Tr
Tc1
Tc2
Bφ
Address bus
Row address
Column address
RAS
LUCAS
LLCAS
WE
Read
High
OE (RD)
Data bus
WE
Write
OE (RD)
High
Data bus
BS
RD/WR
Figure 9.42 Access Timing Example of Two Precharge Cycles (RAST = 0 and CAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 282 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.10.9
Wait Control
There are two methods of inserting wait cycles during a DRAM access cycle: program wait
insertion and pin wait insertion using the WAIT pin.
Wait cycles are inserted to extend the CAS assertion period during a DRAM read cycle and to
ensure the write data setup time to the falling edge of the CAS signal during a DRAM write cycle.
(1)
Program Wait Insertion
When bit AST2 in ASTCR is set to 1, zero to seven of wait cycles can automatically be inserted
between the Tc1 and Tc2 cycles. The number of wait cycles is selected by bits W22 to W20 in
WTCRB.
(2)
Pin Wait Insertion
When the WAITE bit in BCR1 is set to 1, and the AST2 bit in ASTCR is set to 1, setting the ICR
bit for the corresponding pin to 1 enables wait input by the WAIT pin. When the DRAM space is
accessed in this state, a program wait (Tpw) is first inserted. If the WAIT pin is low at the rising
edge of Bφ in the last Tc1 or Tpw cycle, another Ttw cycle is inserted until the WAIT pin is driven
high. For details on ICR, see section 13, I/O Ports.
Figure 9.43 shows an example of wait cycle insertion timing for 2-cycle column address output.
Figure 9.44 shows an example of wait cycle insertion timing for 3-cycle column address output.
Rev. 2.00 Oct. 21, 2009 Page 283 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Wait by
program Wait by
wait WAIT pin
Tpw
Ttw
Tc2
Bφ
WAIT
Address bus
Row address
Column address
RAS
LUCAS, LLCAS
WE
Read
High
OE (RD)
Data bus
LUCAS, LLCAS
WE
Write
OE (RD)
High
Data bus
BS
RD/WR
Note:
Upward arrows indicate the timing of WAIT pin sampling.
Figure 9.43 Example of Wait Cycle Insertion Timing for 2-Cycle Column Address Output
Rev. 2.00 Oct. 21, 2009 Page 284 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Wait by
program Wait by
wait WAIT pin
Tpw
Ttw
Tc2
Tc3
Bφ
WAIT
Address bus
Row address
Column address
RAS
LUCAS, LLCAS
WE
High
Read
OE (RD)
Data bus
LUCAS, LLCAS
WE
Write
OE (RD)
High
Data bus
BS
RD/WR
Note:
Upward arrows indicate the timing of WAIT pin sampling.
Figure 9.44 Example of Wait Cycle Insertion Timing for 3-Cycle Column Address Output
Rev. 2.00 Oct. 21, 2009 Page 285 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.10.10 Controlling Byte and Word Accesses
When 16-bit bus DRAM is used, two CAS signals can be used to control byte and word accesses.
Figures 9.45 and 9.46 show control timing examples with use of two CAS signals (in big endian
format). Figure 9.47 shows an example of connection for control with two CAS signals.
Tp
Tr
Tc1
Tc2
Bφ
Address bus
Row address
Column address
RAS
LUCAS
LLCAS
WE
OE (RD)
High
D15 to D8
D7 to D0
BS
RD/WR
Figure 9.45 Timing Example of Byte Control with Use of Two CAS Signals
(Write Access with Lowest Bit of Address = B'0, RAST = 0, CAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 286 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tc2
Bφ
Address bus
Row address
Column address
RAS
LUCAS
LLCAS
WE
High
OE (RD)
D15 to D8
D7 to D0
BS
RD/WR
Figure 9.46 Timing Example of Word Control with Use of Two CAS Signals
(Read Access with Lowest Bit of Address = B'0, RAST = 0, CAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 287 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
This LSI
(Address shifted by 11 bits)
RAS
LUCAS
LLCAS
WE
RD (OE)
A11
A10
A9
A8
A7
A6
A5
A4
A3
A2
A1
D15 to D0
Two CAS signals used 64-Mbit DRAM
(4 Mwords × 16 bits)
11-bit column address
RAS
UCAS
LCAS
WE
OE
A10
A9 Row address input:
A10 to A0
A8 Column address input: A10 to A0
A7
A6
A5
A4
A3
A2
A1
A0
D15 to D0
Figure 9.47 Example of Connection for Control with Two CAS Signals
9.10.11 Burst Access Operation
Besides an accessing method in which this LSI outputs a row address every time it accesses the
DRAM (called full access or normal access), some DRAMs have a fast-page mode function in
which fast speed access can be achieved by modifying only a column address with the same row
address output (burst access) when consecutive accesses are made to the same row address.
The fast-page mode (burst access) can be specified when the BE bit in DRAMCR is set to one,
(1)
Burst Access (Fast-Page Mode) Operation Timing
Figures 9.48 and 9.49 show operation timing of the fast-page mode.
When access cycles to the DRAM space are continued and the row addresses of the consecutive
two cycles are the same, output cycles of the CAS and column address signals follow. The row
address bits to be compared are decided by bits MXC1 and MXC0 in DRAMCR.
Wait cycles can be inserted during a burst access. The method and timing of the wait insertion are
the same as that of full access mode. For details, see section 9.10.9, Wait Control.
Rev. 2.00 Oct. 21, 2009 Page 288 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tc2
Tc1
Tc2
Bφ
Address bus
Row address
Column address
Column address
RAS
LUCAS
LLCAS
WE
Read
OE (RD)
Data bus
WE
Write
OE (RD)
Data bus
BS
RD/WR
Figure 9.48 Operation Timing of Fast-Page Mode (RAST = 0, CAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 289 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tc2
Tc3
Tc1
Tc2
Tc3
Bφ
Address bus
Row address
Column address
Column address
RAS
LUCAS
LLCAS
WE
Read
High
OE (RD)
Data bus
WE
Write
OE (RD)
High
Data bus
BS
RD/WR
Figure 9.49 Operation Timing of Fast-Page Mode (RAST = 0, CAST = 1)
Rev. 2.00 Oct. 21, 2009 Page 290 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(2)
RAS Down Mode and RAS Up Mode
Even if the fast-page mode is selected, the DRAM space is not consecutively accessed and other
spaces may be accessed. The RAS signal can be held low during other space accesses. The fastpage mode access can be resumed (burst access) when the same row address in the DRAM space
is accessed.
(a)
RAS Down Mode
Set the RCDM and BE bits in DRAMCR to 1 to make a transition to the RAS down mode.
The RCDM bit is enabled only when the BE bit is set to 1.
The fast-page mode access (burst access) is resumed when the row addresses of the current cycle
and previous cycle are the same. While other spaces are accessed when the DRAM space access is
halted, the RAS signal must be low. Figure 9.50 shows a timing example of RAS down mode.
The RAS signal goes high under the following conditions.
•
•
•
•
•
When a refresh cycle is performed during RAS down mode
When a self-refresh is performed
When a transition to software standby mode is made
When the external bus requested by the BREQ signal is released
When either the RCDM or BE bit is cleared to 0
If a transition to the all-module clock-stop mode is made during RAS down mode, clocks are
stopped with the RAS signal driven low. To make a transition with the RAS signal driven high,
clear the RCDM bit to 0 before execution of the SLEEP instruction.
Clear the RCDM bit to 0 for write access to SCKCR to set the clock frequencies. For SCKCR, see
section 27, Clock Pulse Generator.
Rev. 2.00 Oct. 21, 2009 Page 291 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
DRAM space read
Tp
Tr
Tc1
Basic bus space read DRAM space read
Tc2
Tc1
Tc2
Tc1
Tc2
Bφ
Address bus
Row address
Column address
External address
Column address
RAS
LUCAS
LLCAS
WE
High
OE
RD
Data bus
BS
RD/WR
Figure 9.50 Timing Example of RAS Down Mode (RAST = 0, CAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 292 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(b)
RAS Up Mode
Set the BE bit in DRAMCR to 1 and clear the RCDM bit in DRAMCR to 0 to set the RAS up
mode.
Whenever a DRAM space access is halted and other spaces are accessed, the RAS signal is driven
high. Only when the DRAM space continues to be accessed, the fast-page mode access (burst
access) is performed.
Figure 9.51 shows a timing example of RAS up mode.
DRAM space read
Tp
Tr
Tc1
DRAM space read Basic bus space read
Tc2
Tc1
Tc2
T1
T2
Bφ
Address bus
Row address
Column address
Column address
External address
RAS
LUCAS
LLCAS
WE
High
RD
OE
Data bus
BS
RD/WR
Figure 9.51 Timing Example of RAS Up Mode (RAST = 0, CAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 293 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.10.12 Refresh Control
This LSI includes a DRAM refresh control function. The refresh method is the CAS before RAS
(CBR) refresh. Self-refresh cycles can be performed in software standby mode.
The refresh control function is enabled when area 2 is specified as the DRAM space by the
DRAME and DTYPE bits in DRAMCR.
(1)
CAS before RAS (CBR) Refresh Mode
Set the RFSHE bit in REFCR to 1 to select the CBR refresh mode.
A CBR refresh cycle is performed when the value set in RTCOR matches the RTCNT value
(compare match). RTCNT is an up-counter operated on the input clock specified by bits RTCK2
to RTCK0 in REFCR. RTCNT is initialized upon the compare match and restarts to count up with
H'00. Accordingly, a CBR refresh cycle is repeated at intervals specified by bits RTCK2 to
RTCK0 in RTCOR. Set the bits so that the required refresh intervals of the DRAM must be
satisfied.
Since setting bits RTCK2 to RTCK0 starts RTCNT to count up, set RTCNT and RTCOR before
setting bits RTCK2 to RTCK0. When changing RTCNT and RTCOR, the counting operation
should be halted. When changing bits RTCK2 to RTCK0, change them only after disabling
external access and bus release by the EXDMAC, and if the write data buffer function is in use,
disabling the write data buffer function and reading the external space.
The external space cannot be accessed in CBR refresh mode.
Figure 9.52 shows RTCNT operation, figure 9.53 shows compare match timing, and figure 9.54
shows CBR refresh timing. Table 9.23 lists the pin states during a CBR refresh cycle.
RTCNT
RTCOR
H'00
Refresh request
Figure 9.52 RTCNT Operation
Rev. 2.00 Oct. 21, 2009 Page 294 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Pφ
RTCNT
H'00
N
RTCOR
N
Refresh request
and CMF bit set signal
Figure 9.53 Compare Match Timing
TRp
TRr
TRc1
TRc2
Bφ
RAS
LUCAS
LLCAS
BS
RD/WR
High
High
Figure 9.54 CBR Refresh Timing
Rev. 2.00 Oct. 21, 2009 Page 295 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Table 9.23 Pin States during DRAM Refresh Cycle
Pin
State
A17 to A0
Hold the value of the previous bus cycle
D15 to D0
Hi-Z
RAS
Used for refresh control
LUCAS, LLCAS
Used for refresh control
WE
High
AS
High
RD
High
BS
High
RD/WR
High
The RAS signal can be delayed for one to three clock cycles by setting bits RCW1 and RCW0 in
REFCR. The pulse width of the RAS signal is changed by bits RLW2 to RLW0 in REFCR. The
settings of bits RCW1, RCW0, and RLW2 to RLW0 are effective only for a refresh cycle. The
precharge time set by bit TPC1 and TPC0 is effective for a refresh cycle.
Figure 9.55 shows timing for setting bits RCW1 and RCW0
TRp
TRrw
TRr
TRc1
TRc2
Bφ
RAS
LUCAS
LLCAS
BS
High
RD/WR
High
Figure 9.55 CBR Refresh Timing
(RCW1 = 0, RCW0 = 1, RLW2 = 0, RLW1 = 0, RLW0 = 0)
Rev. 2.00 Oct. 21, 2009 Page 296 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(2)
Self-Refresh Mode
Some DRAMs have a self-refresh mode (battery backup mode). The self-refresh mode is a kind of
standby mode and refresh timing and refresh address are controlled internally.
The self-refresh mode is selected by setting the RFSHE and SLFRF bits in REFCR to 1. The CAS
and RAS signals are output as shown in figure 9.56 by executing the SLEEP instruction. Then,
DRAM enters self-refresh mode.
When a CBR refresh is requested on a transition to the standby mode, the CBR refresh is first
performed and then the self-refresh mode is entered.
When the self-refresh mode is used, do not clear the OPE bit in SBYCR to 0.
For details, see section 28.2.1, Standby Control Register (SBYCR).
TRp
Software
standby
TRr
TRc3
TRc4
Bφ
RAS
LUCAS
LLCAS
WE
High
BS
High
RD/WR
High
Figure 9.56 Self-Refresh Timing
Rev. 2.00 Oct. 21, 2009 Page 297 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Some DRAMs having the self-refresh mode needs longer precharge time of the RAS signal
immediately after the self-refresh mode than that in normal operation. From one to seven of
precharge cycles immediately after a self-refresh cycle can be inserted. Precharging is also
performed according to bits TPC1 and TPC0 in DRACCR. Set the precharge time so that the
precharge time immediately after a self-refresh cycle is optimal.
Figure 9.57 shows a timing example when one precharge cycle is added.
Software standby
DRAM space write
TRc3
TRc4
TRp1
Tp
Tr
Tc1
Tc2
Bφ
Address bus
RAS
LUCAS
LLCAS
RD
High
OE
WE
Data bus
BS
High
RD/WR
High
Figure 9.57 Timing Example when 1 Precharge Cycle Added
Rev. 2.00 Oct. 21, 2009 Page 298 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(3)
Refresh and All-Module Clock Stop Mode
This LSI is entered in all-module clock stop mode by the following operation: Stop the clocks of
all on-chip peripheral modules by setting the ACSE bit in MSTPCR to 1 (MSTPCRA, MSTPCRB
= H'FFFFFFFF) or run only the 8-bit timer (MSTPCRA, MSTPCRB = H'F[C to F]FFFFFF), then
execute the SLEEP instruction to enter the sleep mode.
In all-module clock stop mode, clocks for the bus controller and I/O ports are stopped. Since the
clock for the bus controller is stopped, a CBR refresh cycle cannot be performed. When external
DRAM is used and the contents of the DRAM in sleep mode should be held, clear the ACSE bit in
MSTPCE to 0.
For details, see section 28.2.2, Module Stop Control Registers A and B (MSTPCRA and
MSTPCRB).
9.10.13 DRAM Interface and Single Address Transfer by DMAC and EXDMAC
When fast-page mode (BE = 1) is set for the DRAM space, either fast-page access or full access
can be selected, by the setting of bits DDS and EDDS in DRAMCR, for the single address transfer
by the DMAC or EXDMAC where the DRAM space is specified as the transfer source or
destination. At the same time, the output timings of the DACK, EDACK and BS signals are
changed. When BE = 0, full access to the DRAM space is performed by single address transfer
regardless of the setting of bits DDS and EDDS. However, the output timing of the DACK,
EDACK and BS signals can be changed by the setting of bits DDS and EDDS.
The assertion timing of the DACK and EDACK signal can be changed by bits DKC and EDKC in
BCR1.
Rev. 2.00 Oct. 21, 2009 Page 299 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(1)
When DDS = 1 or EDDS = 1
A fast-page access is performed regardless of the bus master, only according to the address. The
DACK and EDACK signals are asserted at the start of the Tc1 cycle.
Figure 9.58 shows the output timing example of the DACK and EDACK signals when DDS = 1 or
EDDS = 1.
Tp
Tr
Tc1
Tc2
Bφ
Address bus
Row address
Column address
RAS
LUCAS
LLCAS
WE
Read
High
OE (RD)
Data bus
WE
Write
OE (RD)
High
Data bus
DACK or
EDACK
DKC, EDKC = 0
DKC, EDKC = 1
BS
RD/WR
Figure 9.58 Output Timing Example of DACK and EDACK when DDS = 1 or EDDS = 1
(RAST = 0, CAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 300 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(2)
When DDS = 0 or EDDS = 0
Single address transfer by the DMAC or EXDMAC takes place as a full access (normal access).
The DACK and EDACK signals are asserted within the Tr cycle and the BS signal is also asserted
during the Tr cycle.
When the DRAM space is accessed with other than the single address transfer by the DMAC or
EXDMAC, a fast-page access is available.
Figure 9.59 shows an output timing example of the DACK and EDACK signals when DDS = 0 or
EDDS = 0.
Tp
Tr
Tc1
Tc2
Tc3
Bφ
Address bus
Row address
Column address
RAS
LUCAS
LLCAS
WE
Read
High
OE (RD)
Data bus
WE
Write
OE (RD)
High
Data bus
DACK or
EDACK
DKC, EDKC = 0
DKC, EDKC = 1
BS
RD/WR
Figure 9.59 Output Timing Example of DACK and EDACK when DDS = 0 or EDDS = 0
(RAST = 0, CAST = 1)
Rev. 2.00 Oct. 21, 2009 Page 301 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11
Synchronous DRAM Interface
In this LSI, area 2 in the external space can be used as the SDRAM interface space. Up to 8
Mbytes (64 Mbits) of DRAM is directly connected via the SDRAM interface. The CAS latency
with 2 to 4 is supported.
9.11.1
Setting SDRAM space
Area 2 can be specified as the SDRAM space by the DRAME and DTYPE bits in DRAMCR.
Table 9.24 lists the relationship among the DRAME and DTYPE bits and area 2 interfaces.
In the SDRAM space, pins PB2, PB3, and PB4 are used as the RAS, CAS, and WE signals. The
PB1 pin is used as the CS2 signal by the PFCR setting, and the PB5 pin is used as the CKE signal
by setting the OEE bit in DRAMCR to 1. The bus settings of the SDRAM space depend on area 2
settings. The pin wait and program wait for the SDRAM space are not available. For PFCR, see
section 13, I/O Ports.
An SDRAM command is designated by the combination of the RAS, CAS, and WE signals and
the precharge-sel command (Precharge-sel) output on the upper column address.
This LSI supports the following commands: the NOP, auto-refresh (REF), self-refresh (SELF), allbank-precharge (PALL), bank active (ACTV), read (READ), write (WRIT), and mode register
setting (MRS). Commands controlling a bank are not supported.
Table 9.24 Relationship among DRAME and DTYPE and Area 2 Interfaces
DRAME
DTYPE
Area 2 Interface
0
X
Basic bus space (initial state)/byte-control SRAM space
1
0
DRAM space
1
1
SDRAM space
[Legend]
X: Don't care
Rev. 2.00 Oct. 21, 2009 Page 302 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11.2
Address Multiplexing
A Row address and a column address are multiplexed in the SDRAM space. Select the number of
row address bits to be shifted with bits MXC1 and MXC0 in DRAMCR. The precharge set
command (Precharge-sel) is output on the upper column address. Table 9.25 lists the relationship
among bits MXC1 and MXC0 and shifted bit number.
Table 9.25 Relationship Among MXC1 and MXC0 and Shifted Bit Count
DRAMCR Shift Bit Data Bus
Address
MXC1 MXC0 Count Width
0
0
0
1
8 bits
9 bits
8 bits
Row address
External Address Pin
A23 to A18 A17 A16 A15 A14 A13 A12 A11 A10
A2
A1
A0
A23 to A18
-
-
A23 A22 A21 A20 A19 P/A18* A17 A16 A15 A14 A13 A12 A11 A10
A9
A8
1
A5
A4
A3
-
-
A23 A22 A21 A20 A19
A2
A1
A0
A23 to A18
-
-
A23 A22 A21 A20 P/A19* A18 A17 A16 A15 A14 A13 A12 A11 A10
A9
A8
Column address A23 to A18
-
-
A23 A22 A21 A20
8 bits
Row address
10 bits 8 bits
11 bits 8 bits
16 bits
Note:
A6
Row address
16 bits
1
A7
Column address A23 to A18
A10
A9
A9
-
-
A23 A22 A21 A20
A1
A0
Row address
-
-
A23 A22 A21 P/A20* A19 A18 A17 A16 A15 A14 A13 A12 A11 A10
A9
A23 A22 A21
A0
A5
A4
A3
Column address A23 to A18 A17
A6
A5
A4
A0
A7
A6
A5
A1
A8
A7
A6
A23 A22 A21 A20 P/A19* A18 A17 A16 A15 A14 A13 A12 A11 A10
A9
A8
A7
-
P
A9
A8
-
A23 to A18 A17
P
P
A23 to A18 A17
A4
A3
A3
A2
A2
-
-
A23 to A18
-
-
-
-
A23 A22 A21 P/A20* A19 A18 A17 A16 A15 A14 A13 A12 A11 A10
Column address A23 to A18
-
-
-
-
A23 A22 A21
Row address
A23 to A18
-
-
-
-
A23 A22 P/A21* A20 A19 A18 A17 A16 A15 A14 A13 A12 A11 A10
Column address A23 to A18
-
A23 A22
Column address A23 to A18 A17
0
A8
16 bits
16 bits
1
A9
Row address
P
A10
P
A9
A9
A8
A8
A7
A7
A6
A6
A5
A5
A4
A4
A3
A3
A2
A2
A1
A1
A0
-
-
-
A23 to A18 A17
-
-
-
-
A23 A22 P/A21* A20 A19 A18 A17 A16 A15 A14 A13 A12 A11
Column address A23 to A18 A17
-
-
-
-
A23 A10
Row address
A23 to A18 A17
-
-
-
-
A23 P/A22* A21 A20 A19 A18 A17 A16 A15 A14 A13 A12 A11
Column address A23 to A18 A17
-
-
-
-
A11
Row address
P
P
A10
P
A10
A9
A9
A9
A8
A8
A8
A7
A7
A7
A6
A6
A6
A5
A5
A5
A4
A4
A4
A3
A3
A3
A2
A2
A2
A1
A1
A1
A0
A0
A0
* When issuing the PALL command, precharge-sel = 1 is output and when issuing the ACTIV command, a corresponding address is output.
9.11.3
Data Bus
Either 8 or 16 bits can be selected as the data bus width of the SDRAM space by bits ABWH2 and
ABWL2 in ABWCR. SDRAM with 16-bit words can be connected directly to 16-bit bus width
space.
D7 to D0 are valid in 8-bit SDRAM space and D15 to D0 are valid in 16-bit SDRAM space.
The data endian format can be selected by bit LE2 in ENDIANCR. For details on the access size
and alignment, see section 9.5.6, Endian and Data Alignment.
Rev. 2.00 Oct. 21, 2009 Page 303 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11.4
I/O Pins Used for DRAM Interface
Table 9.26 shows the pins used for the SDRAM interface.
Since a CS pin functions as an input after a reset, set the bit in PFCR to 1 to output the CS signal.
For details, see section 13, I/O Ports.
To enable the SDRAM interface, select the appropriate MCU operating mode. For details, see
section 3, MCU Operating Modes.
Table 9.26 I/O Pins for SDRAM Interface
Pin
DRAM
Selected
RAS
Name
I/O
Function
RAS
Row address
strobe
Output
Row address strobe when the SDRAM
space is specified as area 2
CAS
CAS
Column address
strobe
Output
Column address strobe when the
SDRAM space is specified as area 2
WE
WE
Write enable
Output
Write enable signal for accessing the
SDRAM interface
OE/CKE
CKE
Clock enable
Output
Clock enable signal when the SDRAM
space is specified as area 2.
LLCAS/
DQMLU
DQMLU
Lower-upper data
mask enable
Output
Upper data mask enable when the 16bit SDRAM space is accessed
LLCAS/
DQMLL
DQMLL
Lower-lower data
mask enable
Output
•
Lower data mask enable when the
16-bit SDRAM space is accessed
•
Data mask enable when the 8-bit
SDRAM is accessed
A17 to A0
A17 to A0
Address pin
Output
Multiplexed row/column-address output
pin
D15 to D0
D15 to D0
Data pin
Input/
output
Data input/output pin
PB7
SDRAMφ
Clock
Output
SDRAM clock
CS2
CS
Chip select
Output
Strobe signal indicating that SDRAM is
selected
Rev. 2.00 Oct. 21, 2009 Page 304 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11.5
Basic Timing
Figures 9.60 and 9.61 show a basic access timing of the SDRAM space.
A basic read cycle consists of five clock cycles: one precharge cycle (Tp), one row address output
cycle (Tr), and three column address output cycles (Tc1, Tcl, and Tc2).
A basic write cycle consists of four clock cycles: one precharge cycle (Tp), one row address
output cycle (Tr), and two column address output cycles (Tc1 and Tc2).
When the SDRAM space is selected, the WAITE bit in BCR, the RAST and CAST bits in
DRAMCR, bits RCW1 and RCW0 in REFCR are ignored.
Tp
Tr
Tc1
Tcl
Tc2
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
READ
NOP
Figure 9.60 SDRAM Basic Read Access Timing (CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 305 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tc2
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
CKE
High
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
NOP
WRIT
Figure 9.61 SDRAM Basic Write Access Timing
Rev. 2.00 Oct. 21, 2009 Page 306 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11.6
CAS Latency Control
The CAS latency is controlled by bits W21 and W20 in WTCRB. Table 9.27 lists the setting and
CAS latency. CAS latency control cycles (Tcl) are inserted in a read cycle according to the W21
and W20 settings. WTCRB can be specified regardless of bit AST2 in ASTCR.
Figure 9.62 shows a timing example when SDRAM with a CAS latency of 3 is in use.
Bits W21 and W20 is initialized to B'11.
Table 9.27 CAS Latency Setting
W21
0
1
W20
Description
Number of CAS
Latency Cycles
0
Setting prohibited
⎯
1
SDRAM with CAS latency of 2 is in use
1
0
SDRAM with CAS latency of 3 is in use
2
1
SDRAM with CAS latency of 4 is in use
3
Rev. 2.00 Oct. 21, 2009 Page 307 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tcl1
Tcl2
Tc2
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
CKE
High
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
READ
NOP
Figure 9.62 Timing Example of CAS Latency (CAS Latency = 3)
Rev. 2.00 Oct. 21, 2009 Page 308 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11.7
Controlling Row Address Output Cycle
When the time between the ACTV command and the subsequent READ or WRIT command does
not meet a given specification, the Trw cycle in which the NOP command is output can be
inserted for one to three cycles between the Tr cycle in which the ACTV command is output and
the Tc1 cycle in which the column address is output. Set the bit according to the SDRAM to be
used and the frequency of this LSI so that the number of wait cycles can be optimal.
Figures 9.63 and 9.64 show a timing example when the one Trw cycle is inserted.
Tp
Tr
Trw
Tc1
Tcl
Tc2
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
NOP
READ
NOP
Figure 9.63 Read Timing Example of Row Address Output Retained for 1 Clock Cycle
(RCD1 = 0, RCD0 = 1, CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 309 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Trw
Tc1
Tc2
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
CKE
High
DQMUU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
NOP
NOP
WRIT
Figure 9.64 Write Timing Example of Row Address Output Retained for 1 Clock Cycle
(RCD1 = 0, RCD0 = 1)
Rev. 2.00 Oct. 21, 2009 Page 310 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11.8
Controlling Precharge Cycle
When the time between the PALL or PRE command and the subsequent ACTV or REF command
does not meet a given specification, the Tp cycles can be extended by one to four cycles by bits
TPC1 and TPC0 in DRACCR. Set the bit according to the SDRAM to be used and the frequency
of this LSI so that the number of Tp cycles can be optimal.
Figures 9.65 and 9.66 show a timing example when the two Tp cycles are inserted.
Bits TPC1 and TPC0 are effective for the Tp cycle in a refresh cycle.
Tp1
Tp2
Tr
Tc1
Tcl
Tc2
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
NOP
ACTV
READ
NOP
Figure 9.65 Read Timing Example of Two Precharge Cycles
(TPC1 = 0, TPC0 = 1, CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 311 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp1
Tp2
Tr
Tc1
Tc2
SDRAMφ
Address bus
Row address
Precharge-sel
Column address
Row address
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
NOP
ACTV
NOP
WRIT
Figure 9.66 Write Timing Example of Two Precharge Cycles (TPC1 = 0, TPC0 = 1)
Rev. 2.00 Oct. 21, 2009 Page 312 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11.9
Controlling Clock Suspend Insertion
When the SDRAM space is read, the read data settling cycle can be inserted for one cycle using
the clock suspend mode. To enter the clock suspend mode, set the CKSPE bit in SDCR and the
OEE bit in DRAMCR to 1and enable the CKE pin.
Figure 9.67 shows a read timing example when CKSPE = 1.
Tp
Tr
Tc1
Tcl
Tsp
Tc2
Tc1
Tcl
Tsp
Tc2
SDRAMφ
Address bus
Column address 1
Row address
Column address 2
Row
address
Precharge-sel
CS
RAS
CAS
WE
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
READ
NOP
READ
NOP
Figure 9.67 Read Timing Example when CKSPE = 1 (CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 313 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11.10 Controlling Write-Precharge Delay
In an SDRAM write cycle, a certain time is required until the write operation is completed inside
of the SDRAM. When the time between the WRIT command and the subsequent PALL command
does not meet a given specification, the Trwl cycle can be inserted for one cycle by the TRWL bit
in SDCR. Whether or not to insert the Trwl cycle depends on the SDRAM to be used and the
frequency of this LSI.
Figure 9.68 shows a timing example when one Trwl cycle is inserted.
Tp
Tr
Tc1
Tc2
Trwl
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
NOP
WRIT
NOP
Figure 9.68 Write Timing Example when Write-Precharge Delay Cycle Insertion
(TRWL = 1)
Rev. 2.00 Oct. 21, 2009 Page 314 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11.11 Controlling Byte and Word Accesses
When 16-bit bus SDRAM is used, byte and word accesses are performed through the control of
DQMLU and DQMLL.
Figures 9.69 and 9.70 show control timing examples of the DQM signals in the big endian format.
Figure 9.71 shows a connection example when the DQM signals are used for the byte and word
control.
Tp
Tr
Tc1
Tcl
Tc2
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
CKE
High
DQMLU
DQMLL
High
D15 to D8
D7 to D0
Hi-Z
BS
RD/WR
PALL
ACTV
READ
NOP
Figure 9.69 Control Timing Example of Byte Control by DQM in 16-Bit Access Space
(Read Access with Lowest Bit of Address = B'0)
Rev. 2.00 Oct. 21, 2009 Page 315 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tcl
Tc2
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
CKE
High
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
READ
NOP
Figure 9.70 Control Timing Example of Word Control by DQM in 16-Bit Access Space
(Read Access with Lowest Bit of Address = B'0, CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 316 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
64-Mbit synchronous DRAM
(1 Mwords × 16 bits × 4 banks)
10-bit column address
This LSI
(Address shifted by 8 bis)
RAS
CAS
WE
DQMLU
DQMLL
SDφ
RAS
CAS
WE
DQMU
DQML
CLK
OE/CKE
CKE
CS
A12
A11
A10
A9
A8
A7
A6
A5
A4
A3
A2
A1
D15 to D0
CS
Row address:
Column address:
Bank select address:
A11 to A0
A9 to A0
A11/A10
A11 (BA1)
A10 (BA0)
A9
A8
A7
A6
A5
A4
A3
A2
A1
A0
DQ15 to DQ0
Figure 9.71 Connection Example of DQM Byte/Word Control
9.11.12 Fast-Page Access Operation
Besides an accessing method in which this LSI outputs a row address every time it accesses the
SDRAM (called full access or normal access), some SDRAMs have a fast-page mode function in
which fast speed access can be achieved by modifying only a column address with the same row
address output when consecutive accesses are made to the same row address.
The fast-page mode can be used by setting the BE bit in DRAMCR to 1.
Rev. 2.00 Oct. 21, 2009 Page 317 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(1)
Fast-Page Mode Operation Timing
When access cycles to the SDRAM space are continued and the row addresses of the consecutive
two cycles are the same, a column address output cycle follows. The row address bits to be
compared are decided by bits MXC1 and MXC0 in DRAMCR.
A fast-page mode access is performed when the access data size exceeds the bus width of the
SDRAM and when consecutive accesses to the SDRAM are generated.
Figures 9.72 and 9.73 show longword access timing of the 16-bit bus SDRAM and word access
timing of the 8-bit bus SDRAM, respectively.
Tp
Tr
Tc1
Tc2
Tc1
Tc2
SDRAMφ
Address bus
Row address
Column address 1
Column address 2
Row
address
Precharge-sel
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
NOP
WRIT
NOP
WRIT
Figure 9.72 Longword Write Timing in 16-Bit Access Space (BE = 1, RCDM = 0)
Rev. 2.00 Oct. 21, 2009 Page 318 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tcl
Tc2
Tc1
Tcl
Tc2
SDRAMφ
Address bus
Column address 1
Row address
Column address 2
Row
address
Precharge-sel
CS
RAS
CAS
WE
High
CKE
DQMLL
D7 to D0
BS
RD/WR
PALL
ACTV
READ
NOP
READ
NOP
Figure 9.73 Word Read Timing in 8-Bit Access Space
(BE = 1, RCDM = 0, CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 319 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(2)
RAS Down Mode
Set the RCDM and BE bits in DRAMCR to 1 to make a transition to the RAS down mode. The
RCDM bit is enabled only when the BE bit is set to 1.
Even if the fast-page mode is selected, the DRAM space is not consecutively accessed and other
spaces may be accessed. The RAS signal can be held low during other space accesses. Similarly to
the DRAM RAS down mode, the READ or WRIT command can be issued without the ACTV
command. However, two DQM cycles are always inserted for a SDRAM read cycle.
Figures 9.74 and 9.75 show a timing example of RAS down mode.
The next cycle after one of the following conditions is satisfied is a full access cycle.
•
•
•
•
•
•
When a refresh cycle is performed during RAS down mode
When a self-refresh is performed
When a transition to software standby mode is made
When the external bus requested by the BREQ signal is released
When either the RCDM or BE bit is cleared to 0
When setting the SDRAM mode register
Some SDRAMs have a limitation on the time to hold each bank active. When such SDRAM is in
use, if the user program cannot control the time (such as software standby or sleep mode), select
the auto-refresh or self-refresh so that the given specification can be satisfied. If a refresh cycle is
not used, the user program must control the time.
Clear the RCDM bit to 0 for write access to SCKCR to set the clock frequencies. For SCKCR, see
section 27, Clock Pulse Generator.
(3)
RAS Up Mode
Clear the RCDM bit in DRAMCR to 0 to set the RAS up mode.
Whenever a SDRAM space access is halted and other spaces are accessed, the next cycle is the
PALL command cycle. Only when the SDRAM space continues to be accessed, the fast-page
mode access is performed.
Rev. 2.00 Oct. 21, 2009 Page 320 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
SDRAM space read
Tp
Tr
Tc1
Tcl
Tc2
External
space read
SDRAM space read
T1
Tc1
T2
Tcl
Tc2
SDRAMφ
Address bus
Row address
Column address 1
Row
address
Precharge-sel
External address
Column address 2
External address
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
READ
NOP
READ
NOP
Figure 9.74 Timing Example of RAS Down Mode (BE = 1, RCDM = 1, CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 321 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
SDRAM space read
Tp
Tr
Tc1
Tcl
Tc2
External
space read
SDRAM
space read
T1
Tc1
T2
Tc2
SDRAMφ
Address bus
Row address
Column address 1
Row
address
Precharge-sel
External address
Column address 2
External address
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
PALL
ACTV
READ
NOP
WRIT
Figure 9.75 Timing Example of RAS Down Mode (BE = 1, RCDM = 1, CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 322 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.11.13 Refresh Control
This LSI includes a DRAM refresh control function. The refresh method is the auto-refresh. Selfrefresh cycles can be performed in software standby mode.
The refresh control function is enabled when area 2 is specified as the SDRAM space by the
DRAME and DTYPE bits in DRAMCR.
(1)
Auto-Refresh Mode
Set the RFSHE bit in REFCR to 1 to select auto-refreshing.
An auto-refresh cycle is performed when the value set in RTCOR matches the RTCNT value
(compare match). RTCNT is an up-counter operated on the input clock specified bits RTCK2 to
RTCK0 in REFCR. RTCNT is initialized upon the compare match and restarts to count up with
H'00. Accordingly, an auto-refresh cycle is repeated at intervals specified by bits RTCK2 to
RTCK0 in RTCOR. Set the bits so that the required refresh intervals of the DRAM must be
satisfied.
Since setting bits RTCK2 to RTCK0 starts RTCNT to count up, set RTCNT and RTCOR before
setting bits RTCK2 to RTCK0. When changing RTCNT and RTCOR, the count operation should
be halted. When changing bits RTCK2 to RTCK0, change them only after disabling the external
access and external bus release by the EXDMAC, if the write data buffer function is in use,
disabling the write data buffer function and reading the external space.
The external space cannot be accessed during auto-refresh.
Figure 9.76 shows auto-refresh cycle timing.
The operation of refresh counter is same as that for the DRAM interface. For details, see section
9.10.12, Refresh Control.
Rev. 2.00 Oct. 21, 2009 Page 323 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
TRp
TRr
TRc1
TRc2
SDRAMφ
Address bus
Precharge-sel
CS
RAS
CAS
WE
CKE
High
BS
High
RD/WR
High
PALL
REF
NOP
Figure 9.76 Auto-Refresh Operation
Rev. 2.00 Oct. 21, 2009 Page 324 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
The time between the PALL or PRE command and the subsequent REF command can be changed
by wait cycle insertion. The number of wait cycles is selected from one to three cycles by bits
TPC1 and TPC0 in DRACCR. Set the bit according to the SDRAM to be used and the frequency
of this LSI so that the number of wait cycles can be optimal.
Figure 9.77 shows a timing example when the one wait cycles are inserted.
TRp1
TRp2
TRr
TRc1
TRc2
SDRAMφ
Address bus
Precharge-sel
CS
RAS
CAS
WE
CKE
High
BS
High
High
RD/WR
PALL
NOP
REF
NOP
Figure 9.77 Auto-Refresh Timing (TPC1 = 0, TPC0 = 1)
Rev. 2.00 Oct. 21, 2009 Page 325 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
When the time between the REF command and the subsequent ACTV command does not meet a
given specification, a wait cycle can be inserted for one to seven cycles during a refresh cycle by
bits RLW2 to RLW0 in REFCR. Set the bit according to the SDRAM to be used and the
frequency of this LSI so that the number of wait cycles can be optimal.
Figure 9.78 shows a timing example when the one wait cycle is inserted.
TRp
TRr
TRc1
TRcw
TRc2
SDRAMφ
Address bus
Precharge-sel
CS
RAS
CAS
WE
CKE
High
BS
High
RD/WR
High
PALL
REF
NOP
Figure 9.78 Auto-Refresh Timing (TPC1 = 0, TPC0 = 0, RLW2 = 0, RLW1 = 0, RLW0 = 1)
Rev. 2.00 Oct. 21, 2009 Page 326 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(2)
Self-Refresh Mode
Some SDRAMs have a self-refresh mode (battery backup mode). The self-refresh is a kind of
standby mode and refresh timing and refresh address are controlled internally.
(a) Self-Refresh in Software Standby Mode
The self-refresh is selected by setting the RFSHE and SLFRF bits in REFCR to 1. The SELFcommand is issued as shown in figure 9.79 by executing the SLEEP instruction to enter the
software standby mode.
When an auto-refresh is requested on a transition to the software standby mode, the auto-refresh is
first performed and then the self-refresh is entered.
When making a transition to the self-refresh, set the OEE bit in SBYCR to 1 and connect the CKE
pin.
When the self-refresh is used, do not clear the OPE bit in SBYCR to 0.
TRp
Software standby
TRr
TRc2
TRc3
SDRAMφ
Address bus
Precharge-sel
CS
RAS
CAS
WE
CKE
High
BS
High
RD/WR
PALL
SELF
NOP
Figure 9.79 Self-Refresh Timing in software standby mode
(TPC1 = 0, TPC0 = 0, RCW1 = 0, RCW0 = 0, RLW2 = 0, RLW1 = 0, RLW0 = 0)
Rev. 2.00 Oct. 21, 2009 Page 327 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Some DRAMs with the self-refresh have a given time between cancellation of the self-refresh
mode and the subsequent command issued cycle. From one to seven of precharge cycles
immediately after cancellation of the self-refresh mode can be inserted. Normal precharge is also
performed according to bits TPC1 and TPC0 in DRACCR. Set the precharge time including the
normal precharge so that the precharge time immediately after a self-refresh cycle is optimal.
Figure 9.80 shows a timing example when one precharge cycle is added.
Software
standby
SDRAM space write
TRc2
TRc3
TRp1
Tp
Tr
Tc1
Tc2
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
CKE
DQMLU, DQMLL
Data bus
BS
RD/WR
NOP
PALL
ACTV
NOP WRITE
Figure 9.80 Timing Example when 1 Precharge Cycle Added in the
Software Standby Mode (TPCS2 to TPCS0 = H'1, TPC1 = 0, TPC0 = 0)
Rev. 2.00 Oct. 21, 2009 Page 328 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(b) Self-Refresh in Deep Software Standby Mode
The chip passes through the software standby mode in transitions to deep software standby mode.
The states of pins in software standby mode are retained in the deep software standby mode.
Therefore, the transition to self-refreshing is possible in deep software standby mode as well as in
software standby mode.
In deep software standby mode, initiate the transition to the self-refresh after having set the
IOKEEP bit in DPSBYCR to 1 as well as making the setting in "(a) Self-Refresh in Software
Standby Mode ".
On exit from deep software standby mode, use the following procedure to cancel self-refresh. (See
figure 9.81).
1. In PBDDR/PBDR, set PB1 (CS2) as a high-level output and PB5 (CKE) as a low-level
output.
Since the setting of the IOKEEP bit ensures retention of pin state at this time, the existing
state of high-level output on CS2 and low-level output on is retained.
2. Set the PSTOP0 bit in SCKCR to1 and SDRAMφ as a high level output. Since the setting
of the IOKEEP bit continues to ensure retention of pin state, the existing state of highlevel output on SDRAMφ is retained.
3. Clear the IOKEEP bit in DPSBYCR.
This releases pin states from retention due to the setting of the IOKEEP bit, but the states
of pins CS2, CKE, and SDRAMφ as set in steps 1and 2 do not change.
4. In the synchronous DRAM-related control registers that were initialized by the internal
reset that accompanied the transition to deep software standby mode, remake the settings
to enable the synchronous DRAM interface. At this time, do not make settings in REFCR,
RTCNT, and RTCOR.
Once the synchronous DRAM interface has been enabled, the state of the CKE pin
changes from low-level output to high-level output.
5. Restart output of the SDRAMφ clock signal by clearing the PSTOP0 bit in SCKCR. This
restarts supply of SDRAMφ to the synchronous DRAM.
6. Set REFCR, RTCNT, and RTCOR and enable refreshing.
As the state of the CKE pin has been changed in the step 4, adjust the time between the
state of change of the CKE pin and the next cycle of auto-refreshing in this procedure
within the stipulated refreshing interval of the synchronous DRAM.
7. Resume access to the synchronous DRAM.
Pre-charging time after the termination of self-refresh will be secured by the timing of the
setting in step 6.
Rev. 2.00 Oct. 21, 2009 Page 329 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
For details on the software standby mode and deep software standby mode, see section 28,
Power-Down Modes.
TRp TRr
Deep software
standby mode
EXTAL
Internal reset
PSTOP0 IOKEEP
set
clear
PSTOP0
clear
SDRAMφ
Address bus
Precharge-sel
Port setting
PB1/CS2 = H output setting
PB5/CKE = L output setting
Register setting in SDRAM
(DRAMCR, etc.)
REFCR, RTCNT,
RTCOR
CS2
RAS
CAS
WE
CKE
Pin status saved with deep software
standby mode (IOKEEP=1)
Pin status depends on
I/O port register
Pin status in DRAM
interface
Figure 9.81 Self-Refresh Timing in Deep Software Standby Mode
(TPC1 = 0, TPC0 = 0, RCW1 = 0, RCW0 = 0, RLW2 = 0, RLW1 = 0, RLW0 = 0)
Rev. 2.00 Oct. 21, 2009 Page 330 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(3)
Refresh and All-Module Clock Stop Mode
This LSI is entered in all-module clock stop mode by the following operation: Stop the clocks of
all on-chip peripheral modules by setting the ACSE bit in MSTPCRA to 1 (MSTPCRA,
MSTPCRB = H'FFFFFFFF) or run only the 8-bit timer (MSTPCRA, MSTPCRB = H'F[C to
F]FFFFFF), then execute the SLEEP instruction to enter the sleep mode.
In all-module clock stop mode, clocks for the bus controller and I/O ports are stopped. Since the
clock for the bus controller is stopped, an auto-refresh cycle cannot be performed. When external
SDRAM is used and the contents of the SDRAM in sleep mode should be held, clear the ACSE bit
in MSTPCE to 0.
For details, see section 28.2.2, Module Stop Control Registers A and B (MSTPCRA and
MSTPCRB).
9.11.14 Setting SDRAM Mode Register
To use SDRAM, the mode register must be specified after a power-on reset.
Setting the MRSE bit in SDCR to 1 enables the SDRAM mode register setting. After this, write to
the SDRAM space in bytes.
When the value to be set in the SDRAM mode register is x, write to the following memory
location (address). The value of x is written to the SDRAM mode register.
• H'4000000/H'400000 + x for 8-bit bus SDRAM
• H'4000000/H'400000 + 2x for 16-bit bus SDRAM
The SDRAM mode register latches the address signals when the MRS command is issued.
This LSI does not support the burst read/burst write mode of SDRAM. When setting the SDRAM
mode register, use the burst read/single write mode and set the burst length to 1. Setting in the
SDRAM mode register must be consistent with that in the bus controller.
Rev. 2.00 Oct. 21, 2009 Page 331 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Figure 9.82 shows the timing of setting SDRAM mode register.
Tp
Tr
Tc1
Tc2
SDRAMφ
Address bus
Mode register setting
Mode register setting
Precharge-sel
CS
RAS
CAS
WE
CKE
High
BS
High
RD/WR
High
PALL
NOP
MRS
NOP
Figure 9.82 Timing of Setting SDRAM Mode Register
9.11.15 SDRAM Interface and Single Address Transfer by DMAC and EXDMAC
When fast-page mode (BE = 1) is set for the SDRAM space, either fast-page access or full access
can be selected, by the setting of bits DDS and EDDS in DRAMCR, for the single address transfer
by the DMAC or EXDMAC where the SDRAM space is specified as the transfer source or
destination. At the same time, the output timing of the DACK and EDACK and BS signals can be
changed. When BE = 0, a full access to the SDRAM space is performed with a single address
transfer regardless of the setting of bits DDS and EDDS. However, the output timing of the
DACK, EDACK and BS signals can be changed by the setting of bits DDS and EDDS.
The assertion timing of the DACK and EDACK signals can be changed by the bits DKC and
EDKC in BCR1.
The output timing of the DACK and EDACK signals can be independently set by the bits TRWL
and CKSPE in SDCR and bit DKC and EDKC in BCR1 regardless of the setting of bits DDS and
EDDS.
Rev. 2.00 Oct. 21, 2009 Page 332 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(1)
When DDS = 1 or EDDS = 1
A fast-page access is performed regardless of the bus master, only according to the address. The
DACK and EDACK signals are asserted within the Tc1 cycle in both read and write accesses.
Figures 9.83 and 9.84 show the output timing example of the DACK and EDACK signals when
DDS = 1 or EDDS = 1.
Tp
Tr
Tc1
Tc2
Tc1
Tc2
SDRAMφ
Address bus
Row address
Column address 1
Column address 2
Row
address
Precharge-sel
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
DACK or EDACK
PALL
ACTV
NOP
WRIT
NOP
WRIT
Figure 9.83 Output Timing Example of DACK and EDACK when DDS = 1 or EDDS = 1
(Write)
Rev. 2.00 Oct. 21, 2009 Page 333 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tcl
Tc2
Tc1
Tcl
Tc2
SDRAMφ
Address bus
Row address
Column address 1
Column address 2
Row
address
Precharge-sel
CS
RAS
CAS
WE
CKE
High
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
DACK or EDACK
PALL
ACTV
READ
NOP
READ
NOP
Figure 9.84 Output Timing Example of DACK and EDACK when DDS = 1 or EDDS = 1
(Read, CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 334 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(2)
When DDS = 0 or EDDS = 0
Single address transfer by the DMAC or EXDMAC takes place as a full access (normal access) to
the SDRAM space. The DACK and EDACK signals are asserted within the Tr cycle and the BS
signal is also asserted in the Tr cycle.
When the SDRAM space is accessed with other than the single address transfer by the DMAC or
EXDMAC, a fast-page access is available.
Figures 9.85 and 9.86 show an output timing example of the DACK and EDACK signals when
DDS = 0 or EDDS = 0.
Tp
Tr
Tc1
Tc2
SDRAMφ
Address bus
Row address
Column address
Row
address
Precharge-sel
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
DACK or EDACK
PALL
ACTV
NOP
WRIT
Figure 9.85 Output Timing Example of DACK and EDACK when DDS = 0 or EDDS = 0
(Write)
Rev. 2.00 Oct. 21, 2009 Page 335 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tcl
Tc2
SDRAMφ
Address bus
Row address
Cloumn address
Row
address
Precharge-sel
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
DACK or EDACK
PALL
ACTV
READ
NOP
Figure 9.86 Output Timing Example of DACK and EDACK when DDS = 0 or EDDS = 0
(Read, CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 336 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(3)
When TRWL = 1
When the SDRAM interface is written to, one Trwl cycle is inserted after the Tc2 cycle. The
DACK and EDACK signals stay asserted until the end of the Trwl cycle. The hold time of data
output from an external device can be extended by one cycle.
Figure 9.87 shows an output timing example of the DACK and EDACK signals when TRWL = 1
with DDS = 1, EDDS = 1, DKC = 0 and EDKC = 0.
Tp
Tr
Tc1
Tc2
Trwl
Tc1
Tc2
Trwl
SDRAMφ
Address bus
Row address
Precharge-sel
Row
address
Column address 1
Column address 2
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
DACK or EDACK
PALL ACTV NOP
WRIT
NOP
WRIT
NOP
Figure 9.87 Output Timing Example of DACK and EDACK when TRWL = 1 (Write)
Rev. 2.00 Oct. 21, 2009 Page 337 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(4)
When CKSPE = 1
When the SDRAM space is read, the read data settling cycle can be inserted for one cycle using
the clock suspend mode. To enter the clock suspend mode, set the OEE bit in DRAMCR to 1, and
connect the CKE pin.
Figure 9.88 shows an output timing example of the DACK and EDACK signals when CKSPE = 1
with DDS = 1, EDDS = 1, DKC = 0 and EDKC = 0.
Tp
Tr
Tc1
Tcl
Tsp
Tc2
Tc1
Tcl
Tsp
Tc2
SDRAMφ
Address bus
Row address
Precharge-sel
Row
address
Column address 1
Column address 2
CS
RAS
CAS
WE
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
DACK or EDACK
PALL ACTV READ
NOP
READ
NOP
Figure 9.88 Output Timing Example of DACK and EDACK when CKSPE = 1
(Read, CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 338 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(5)
When DKC = 1
With DKC = 1 or EDKC = 1, the DACK and EDACK signals are asserted a half cycle earlier
compared to the case when DKC = 0 or EDKC = 0.
In fast-page access, the DACK signal continues to be low. In this case, bus cycles can be
distinguished by the BS output timing.
Figure 9.89 shows an output timing example of the DACK and EDACK signals when DKC = 1 or
EDKC = 1, and DDS = 1 or EDDS = 1. Figure 9.90 shows an output timing example of the DACK
and EDACK signals when DKC = 1 or EDKC = 1, and DDS = 0 or EDDS = 0.
Tp
Tr
Tc1
Tc2
Tc1
Tc2
SDRAMφ
Address bus
Row address
Column address 1
Column address 2
Row
address
Precharge-sel
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
DACK or EDACK
PALL
ACTV
NOP
WRIT
NOP
WRIT
Figure 9.89 Output Timing Example of DACK and EDACK when DKC = 1 or EDKC = 1
and DDS = 1 or EDDS = 1 (Write)
Rev. 2.00 Oct. 21, 2009 Page 339 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tc2
SDRAMφ
Address bus
Row address
Cloumn address
Row
address
Precharge-sel
CS
RAS
CAS
WE
High
CKE
DQMLU
DQMLL
D15 to D8
D7 to D0
BS
RD/WR
DACK or EDACK
PALL
ACTV
NOP
WRIT
Figure 9.90 Output Timing Example of DACK and EDACK when DKC = 1 or EDKC = 1
and DDS = 0 or EDDS = 0 (Write)
9.11.16 EXDMAC Cluster Transfer
Using an EXDMAC cluster transfer mode, data can be read from or written to consecutively. For
details, see section 11, EXDMA Controller (EXDMAC).
Figures 9.91 and 9.92 show a read/write timing using a cluster transfer.
For 1-cycle read or write, set the BE bit in DRAMCR to 1, clear the TRWL bit in SDCR to 0, and
set the CAS latency to 2. During a read cycle, the clock suspend mode cannot be used.
Do not change the bus controller register settings during a cluster transfer.
Rev. 2.00 Oct. 21, 2009 Page 340 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
A refresh cycle is not executed during a consecutive cluster transfer even if a refresh request is
generated. Therefore, user program must control the time so that each bank should not be activated
over a given specification. The external bus is not released during a cluster transfer.
Tp
Tr
Tcb
Tcb
Tcb
Tcb
Tcb
Tc1
Tcl
Tc2
SDRAMφ
Address bus
Precharge-sel
Row
Cloumn 1 Cloumn 2 Cloumn 3 Cloumn 4 Cloumn 5
Cloumn 6
Row
CS
RAS
CAS
WE
High
CKE
DQMUU
DQMUL
DQMLU
DQMLL
D31 to D24
D23 to D16
D15 to D8
D7 to D0
BS
RD/WR
PALL ACTV
READ
NOP
Figure 9.91 Word-Size 6-Word Cluster Transfer
(Read, BE = 1, EDDS = 1, CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 341 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Tp
Tr
Tc1
Tc2
Tcb
Tcb
Tcb
Tcb
Tcb
SDRAMφ
Row
Address bus
Precharge-sel
Cloumn 1
Cloumn 2 Cloumn 3 Cloumn 4 Cloumn 5 Cloumn 6
Row
CS
RAS
CAS
WE
High
CKE
DQMUU
DQMUL
DQMLU
DQMLL
D31 to D24
D23 to D16
D15 to D8
D7 to D0
BS
RD/WR
PALL ACTV
NOP
WRIT
Figure 9.92 Word-Size 6-Word Cluster Transfer
(Write, BE = 1, EDDS = 1)
Rev. 2.00 Oct. 21, 2009 Page 342 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.12
Idle Cycle
In this LSI, idle cycles can be inserted between the consecutive external accesses. By inserting the
idle cycle, data conflicts between ROM read cycle whose output floating time is long and an
access cycle from/to high-speed memory or I/O interface can be prevented.
9.12.1
Operation
When this LSI consecutively accesses external address space, it can insert an idle cycle between
bus cycles in the following four cases. These conditions are determined by the sequence of read
and write and previously accessed area.
1.
2.
3.
4.
When read cycles of different areas in the external address space occur consecutively
When an external write cycle occurs immediately after an external read cycle
When an external read cycle occurs immediately after an external write cycle
When an external access occurs immediately after a DMAC or EXDMAC single address
transfer (write cycle)
Up to four idle cycles can be inserted under the conditions shown above. The number of idle
cycles to be inserted should be specified to prevent data conflicts between the output data from a
previously accessed device and data from a subsequently accessed device.
Under conditions 1 and 2, which are the conditions to insert idle cycles after read, the number of
idle cycles can be selected from setting A specified by bits IDLCA1 and IDLCA0 in IDLCR or
setting B specified by bits IDLCB1 and IDLCB0 in IDLCR: Setting A can be selected from one to
four cycles, and setting B can be selected from one or two to four cycles. Setting A or B can be
specified for each area by setting bits IDLSEL7 to IDLSEL0 in IDLCR. Note that bits IDLSEL7
to IDLSEL0 correspond to the previously accessed area of the consecutive accesses.
The number of idle cycles to be inserted under conditions 3 and 4, which are conditions to insert
idle cycles after write, can be determined by setting A as described above.
After the reset release, IDLCR is initialized to four idle cycle insertion under all conditions 1 to 4
shown above.
Table 9.28 shows the correspondence between conditions 1 to 4 and number of idle cycles to be
inserted for each area. Table 9.29 shows the correspondence between the number of idle cycles to
be inserted specified by settings A and B, and number of cycles to be inserted.
Rev. 2.00 Oct. 21, 2009 Page 343 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Table 9.28 Number of Idle Cycle Insertion Selection in Each Area
Bit Settings
IDLSn
Insertion Condition
n
Consecutive reads in different areas 1
Write after read
0
Read after write
2
Setting
IDLSELn
n = 0 to 7
Area of Previous Access
0
1
2
3
5
6
7
0
⎯
1
0
A
A
A
A
A
A
A
A
1
B
B
B
B
B
B
B
B
Invalid
0
⎯
1
0
A
A
A
A
A
A
A
A
1
B
B
B
B
B
B
B
B
0
Invalid
⎯
Invalid
1
External access after single address 3
transfer
4
0
A
⎯
Invalid
1
A
[Legend]
A: Number of idle cycle insertion A is selected.
B: Number of idle cycle insertion B is selected.
Invalid: No idle cycle is inserted for the corresponding condition.
Table 9.29 Number of Idle Cycles Inserted
Bit Settings
A
IDLCA1
IDLCA0
B
IDLCB1
IDLCB0
Number of Cycles
⎯
⎯
0
0
0
0
0
⎯
⎯
1
0
1
0
1
2
1
0
1
0
3
1
1
1
1
4
Rev. 2.00 Oct. 21, 2009 Page 344 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(1)
Consecutive Reads in Different Areas
If consecutive reads in different areas occur while bit IDLS1 in IDLCR is set to 1, idle cycles
specified by bits IDLCA1 and IDLCA0 when bit IDLSELn in IDLCR is cleared to 0, or bits
IDLCB1 and IDLCB0 when bit IDLSELn is set to 1 are inserted at the start of the second read
cycle (n = 0 to 7).
Figure 9.93 shows an example of the operation in this case. In this example, bus cycle A is a read
cycle for ROM with a long output floating time, and bus cycle B is a read cycle for SRAM, each
being located in a different area. In (a), an idle cycle is not inserted, and a conflict occurs in bus
cycle B between the read data from ROM and that from SRAM. In (b), an idle cycle is inserted,
and a data conflict is prevented.
Bus cycle B
Bus cycle A
T1
T2
T3
T1
T2
Bus cycle B
Bus cycle A
T1
T2
T3
Ti
T1
T2
Bφ
Address bus
CS (area A)
CS (area B)
RD
Data bus
Data conflict
Data hold
time is long.
(a) No idle cycle inserted
(IDLS1 = 0)
(b) Idle cycle inserted
(IDLS1 = 1, IDLSELn = 0, IDLCA1 = 0, IDLCA0 = 0)
Figure 9.93 Example of Idle Cycle Operation (Consecutive Reads in Different Areas)
Rev. 2.00 Oct. 21, 2009 Page 345 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(2)
Write after Read
If an external write occurs after an external read while bit IDLS0 in IDLCR is set to 1, idle cycles
specified by bits IDLCA1 and IDLCA0 when bit IDLSELn in IDLCR is cleared to 0 when
IDLSELn = 0, or bits IDLCB1 and IDLCB0 when IDLSELn is set to 1 are inserted at the start of
the write cycle (n = 0 to 7).
Figure 9.94 shows an example of the operation in this case. In this example, bus cycle A is a read
cycle for 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 conflict occurs in bus cycle B between the read data from ROM
and the CPU write data. In (b), an idle cycle is inserted, and a data conflict is prevented.
Bus cycle B
Bus cycle A
T1
T2
T3
T1
Bus cycle B
Bus cycle A
T1
T2
T2
T3
Ti
T1
T2
Bφ
Address bus
CS (area A)
CS (area B)
RD
LLWR
Data bus
Data hold
time is long.
(a) No idle cycle inserted
(IDLS0 = 0)
Data conflict
(b) Idle cycle inserted
(IDLS0 = 1, IDLSELn = 0, IDLCA1 = 0, IDLCA0 = 0)
Figure 9.94 Example of Idle Cycle Operation (Write after Read)
Rev. 2.00 Oct. 21, 2009 Page 346 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(3)
Read after Write
If an external read occurs after an external write while bit IDLS2 in IDLCR is set to 1, idle cycles
specified by bits IDLCA1 and IDLCA0 are inserted at the start of the read cycle (n = 0 to 7).
Figure 9.95 shows an example of the operation in this case. In this example, bus cycle A is a CPU
write cycle and bus cycle B is a read cycle from the SRAM. In (a), an idle cycle is not inserted,
and a conflict occurs in bus cycle B between the CPU write data and read data from an SRAM
device. In (b), an idle cycle is inserted, and a data conflict is prevented.
Bus cycle B
Bus cycle A
T1
T2
T3
T1
T2
Bus cycle B
Bus cycle A
T1
T2
T3
Ti
T1
T2
Bφ
Address bus
CS (area A)
CS (area B)
RD
LLWR
Data bus
Data conflict
Output floating
time is long.
(a) No idle cycle inserted
(IDLS2 = 0)
(b) Idle cycle inserted
(IDLS2 = 1, IDLCA1 = 0, IDLCA0 = 0)
Figure 9.95 Example of Idle Cycle Operation (Read after Write)
Rev. 2.00 Oct. 21, 2009 Page 347 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(4)
External Access after Single Address Transfer Write
If an external access occurs after a single address transfer write while bit IDLS3 in IDLCR is set
to 1, idle cycles specified by bits IDLCA1 and IDLCA0 are inserted at the start of the external
access (n = 0 to 7).
Figure 9.96 shows an example of the operation in this case. In this example, bus cycle A is a
single address transfer (write cycle) and bus cycle B is a CPU write cycle. In (a), an idle cycle is
not inserted, and a conflict occurs in bus cycle B between the external device write data and this
LSI write data. In (b), an idle cycle is inserted, and a data conflict is prevented.
Bus cycle B
Bus cycle A
T1
T2
T3
T1
T2
Bus cycle B
Bus cycle A
T1
T2
T3
Ti
T1
T2
Bφ
Address bus
CS (area A)
CS (area B)
LLWR
DACK
Data bus
Data conflict
Output floating
time is long.
(a) No idle cycle inserted
(IDLS3 = 0)
(b) Idle cycle inserted
(IDLS3 = 1, IDLCA1 = 0, IDLCA0 = 0)
Figure 9.96 Example of Idle Cycle Operation (Write after Single Address Transfer Write)
Rev. 2.00 Oct. 21, 2009 Page 348 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(5)
External NOP Cycles and Idle Cycles
A cycle in which an external space is not accessed due to internal operations is called an external
NOP cycle. Even when an external NOP cycle occurs between consecutive external bus cycles, an
idle cycle can be inserted. In this case, the number of external NOP cycles is included in the
number of idle cycles to be inserted.
Figure 9.97 shows an example of external NOP and idle cycle insertion.
No external access Idle cycle
(NOP)
(remaining)
Preceding bus cycle
T1
T2
Tpw
T3
Ti
Ti
Following bus cycle
T1
T2
Tpw
T3
Bφ
Address bus
CS (area A)
CS (area B)
RD
Data bus
Specified number of idle cycles or more
including no external access cycles (NOP)
(Condition: Number of idle cycles to be inserted when different reads continue: 4 cycles)
Figure 9.97 Idle Cycle Insertion Example
Rev. 2.00 Oct. 21, 2009 Page 349 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(6)
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 9.98. In this case, with the setting for no idle cycle insertion (a), there
may be a period of overlap between the RD signal in bus cycle A and the CS signal in bus cycle B.
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 indicated in (b) is set.
Bus cycle B
Bus cycle A
T1
T2
T3
T1
T2
Bus cycle B
Bus cycle A
T1
T2
T3
Ti
T1
T2
Bφ
Address bus
CS (area A)
CS (area B)
RD
Overlap time may occur between the
CS (area B) and RD
(a) No idle cycle inserted
(IDLS1 = 0)
(b) Idle cycle inserted
(IDLS1 = 1, IDLSELn = 0, IDLCA1 = 0, IDLCA0 = 0)
Figure 9.98 Relationship between Chip Select (CS) and Read (RD)
Rev. 2.00 Oct. 21, 2009 Page 350 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(7)
Idle Cycle for Accessing to DRAM/SDRAM Space
In the following read cycles, when the DRAM/SDRAM space is accessed in a full access, the Tp
and Tr cycles are also counted as idle cycles.
Figures 9.99 and 9.100 show timing examples of full accesses to the DRAM/SDRAM space when
four idle cycles are inserted.
When accessing the DRAM/SDRAM space, the Ti cycles are inserted so that the sum of the
numbers of Tp (precharge), Tr (row address output), and Ti cycles satisfies the specified number
of idle cycles. The Ti cycles are inserted before the column address output cycle.
While the SDRAM space is accessed in a full access, the CS2 signal is driven low even in an idle
cycle.
The idle cycle insertion is enabled even in a fast-page access in RAS down mode. The specified
number of idle cycles is inserted. Figure 9.101 shows a timing example of the idle cycle insertion
in RAS down mode.
External space read
T1
T2
T3
DRAM space read
Tp
Tr
Ti
Ti
Tc1
Tc2
Bφ
Address bus
RD
RAS
LLCAS
Data bus
Figure 9.99 Example of DRAM Full Access after External Read (CAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 351 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
External space (area A) read
T1
T2
T3
SDRAM space read
Tp
Tr
Ti
Ti
Tc1
Tcl
Tc2
SDRAMφ
Address bus
CS (area A)
CS (area 2)
RD
RAS
CAS
WE
DQMLL
Data bus
Figure 9.100 Example of SDRAM Full Access after External Read (CAS Latency = 2)
Rev. 2.00 Oct. 21, 2009 Page 352 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
DRAM space read
Tp
Tr
Tc1
External space read
Tc2
T1
T2
T3
DRAM space write
Ti
Tc1
Tc2
Bφ
Address bus
RD
RAS
UCAS, LCAS
Data bus
WR
Idle cycle
Figure 9.101 Example of Idle Cycles in RAS Down Mode (Write after Read)
Rev. 2.00 Oct. 21, 2009 Page 353 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Table 9.30 Idle Cycles in Mixed Accesses to Normal Space and DRAM/SDRAM Space
Previous
Access
IDLS
Next Access
3
Normal/DRAM/ Normal/DRAM/ ⎯
SDRAM space SDRAM space
⎯
read
read
IDLSEL
1
0
7 to 0
1
0
1
0
Idle Cycle
⎯
0
⎯
⎯
⎯
⎯
⎯
⎯
Disabled
⎯
1
⎯
0
0
0
⎯
⎯
1 cycle inserted
0
1
2 cycles inserted
1
0
3 cycles inserted
1
1
4 cycles inserted
⎯
⎯
Single address Normal/DRAM/ 0
write
SDRAM space
1
write
0
0 cycle inserted
0
1
2 cycles inserted
1
0
3 cycles inserted
1
1
4 cycles inserted
⎯
0
⎯
⎯
⎯
⎯
⎯
Disabled
⎯
⎯
1
0
0
0
⎯
⎯
1 cycle inserted
0
1
2 cycles inserted
1
0
3 cycles inserted
1
1
4 cycles inserted
0
0
0 cycle inserted
0
1
2 cycles inserted
1
0
3 cycles inserted
1
1
4 cycles inserted
0
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Disabled
1
⎯
⎯
⎯
0
0
⎯
⎯
1 cycle inserted
0
1
2 cycles inserted
1
0
3 cycles inserted
1
1
4 cycles inserted
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Disabled
⎯
⎯
⎯
⎯
0
0
⎯
⎯
1 cycle inserted
0
1
2 cycles inserted
1
0
3 cycles inserted
1
1
4 cycles inserted
Rev. 2.00 Oct. 21, 2009 Page 354 of 1454
REJ09B0498-0200
0
⎯
1
Normal/DRAM/ Normal/DRAM/ ⎯
SDRAM space SDRAM space
⎯
write
read
IDLCB
2
1
Normal/DRAM/ Normal/DRAM/ ⎯
SDRAM space SDRAM space
⎯
read
read
IDLCA
Section 9 Bus Controller (BSC)
9.12.2
Pin States in Idle Cycle
Table 9.31 shows the pin states in an idle cycle.
Table 9.31 Pin States in Idle Cycle
Pins
Pin State
A23 to A0
Contents of following bus cycle
D15 to D0
High impedance
CSn (n = 7 to 0)
High*1
LUCAS, LLCAS
High
DQMLU, DQMLL
High*2
AS
High
RD
High
BS
High
RD/WR
High*3
AH
low
LHWR, LLWR
High
LUB, LLB
High
CKE
High
OE
High
RAS
High/Low*4
CAS
High
WE
High
DACKn (n = 3 to 0)
High
EDACKn (n = 3 to 0)
High
Notes: 1.
2.
3.
4.
Low when accessing the SDRAM in full access cycle
Low when reading the SDRAM in full access cycle
Low when accessing or writing to the DRAM/SDRAM in full access cycle
The pin state varies depending on the DRAM space access/ area access other than the
DRAM space, or RAS up mode/RAS down mode. For details, see figures 9.98 and
9.100.
Rev. 2.00 Oct. 21, 2009 Page 355 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.13
Bus Release
This LSI can release the external bus in response to a bus request from an external device. In the
external bus released state, the internal bus masters other than the EXDMAC continue to operate
as long as there is no external access.
In addition, in the external bus released state, the BREQO signal can be driven low to output a bus
request externally.
9.13.1
Operation
In external extended mode, when the BRLE bit in BCR1 is set to 1, and the ICR bit for the
corresponding pin is set to 1, the bus can be released to the external. Driving the BREQ pin low
issues an external bus request to this LSI. When the BREQ pin is sampled, at the prescribed
timing, the BACK pin is driven low, and the address bus, data bus, and bus control signals are
placed in the high-impedance state, establishing the external bus released state. For ICR, see
section 13, I/O Ports.
In the external bus released state, the CPU, DTC, DMAC can access the internal space using the
internal bus. When any one of the CPU, DTC, DMAC, and EXDMAC attempts to accesses the
external address space, it temporarily defers initiation of the bus cycle, and waits for the bus
request from the external bus master to be canceled.
In the external bus released state, certain operations are suspended as follows until the bus request
from the external bus master is canceled:
• When a refresh is requested, refresh control is suspended.
• When the SLEEP instruction is executed to enter software standby mode or all-module clockstop mode, control for software standby mode or all-module clock-stop mode is suspended.
• When SCKCR is written to set the clock frequencies, changing of clock frequencies is
suspended. For SCKCR, see section 27, Clock Pulse Generator.
If the BREQOE bit in BCR1is set to 1, the BREQO pin can be driven low to request cancellation
of the bus request when any of the following requests are issued.
• When any one of the CPU, DTC, DMAC, and EXDMAC attempts to access the external
address space
• When a refresh is requested
• When a SLEEP instruction is executed to place the chip in software standby mode or allmodule-clock-stop mode
Rev. 2.00 Oct. 21, 2009 Page 356 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
• When SCKCR is written to set the clock frequencies
If an external bus release request, external access, and a refresh request occur simultaneously, the
order of priority is as follows:
Refresh > EXDMAC > External bus release > External access by CPU, DTC, and
DMAC
When the BREQ pin is driven high, the BACK pin is driven high at the prescribed timing and the
external bus released state is terminated.
9.13.2
Pin States in External Bus Released State
Table 9.32 shows pin states in the external bus released state.
Table 9.32 Pin States in Bus Released State
Pins
Pin State
A23 to A0
High impedance
D15 to D0
High impedance
BS
High impedance
CSn (n = 7 to 0)
High impedance
AS
High impedance
AH
High impedance
RD/WR
High impedance
LUCAS, LLCAS
High impedance
RD
High impedance
RAS
High impedance
CAS
High impedance
WE
High impedance
DQMLU, DQMLL
High impedance
CKE
High impedance
OE
High impedance
LUB, LLB
High impedance
LHWR, LLWR
High impedance
DACKn (n = 3 to 0)
High
EDACKn (n = 3 to 0)
High
Rev. 2.00 Oct. 21, 2009 Page 357 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.13.3
Transition Timing
Figures 9.102 and 9.103 show the timing of transition to the bus released state.
External space
access cycle
T1
CPU cycle
External bus released state
T2
Bφ
Hi-Z
Address bus
Hi-Z
Data bus
Hi-Z
CSn
Hi-Z
AS
Hi-Z
RD
Hi-Z
LHWR, LLWR
BREQ
BACK
BREQO
[1]
[2]
[3]
[4]
[7]
[5]
[8]
[6]
[1] A low level of the BREQ signal is sampled at the rising edge of the Bφ signal.
[2] The bus control signals are driven high at the end of the external space access cycle. It takes two cycles or
more after the low level of the BREQ signal is sampled.
[3] The BACK signal is driven low, releasing bus to the external bus master.
[4] The BREQ signal state sampling is continued in the external bus released state.
[5] A high level of the BREQ signal is sampled.
[6] The external bus released cycles are ended one cycle after the BREQ signal is driven high.
[7] When the external space is accessed by an internal bus master during external bus released while the BREQOE
bit is set to 1, the BREQO signal goes low.
[8] Normally the BREQO signal goes high at the rising edge of the BACK signal.
Figure 9.102 Bus Released State Transition Timing (SRAM Interface is Not Used)
Rev. 2.00 Oct. 21, 2009 Page 358 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
External
access cycle
T1
External bus released state
CPU cycle
T2
SDRAMφ
Hi-Z
Address bus
Hi-Z
Data bus
Hi-Z
Precharge-sel
CS2
Hi-Z
RAS
Hi-Z
CAS
Hi-Z
WE
Hi-Z
CKE
Hi-Z
DQMLU, DQMLL
Hi-Z
BREQ
BACK
BREQO
NOP
[1]
PALL NOP
[2]
[3]
[4]
NOP
[5]
[8]
[6]
[9]
[7]
[1] A low level of the BREQ signal is sampled at the rising edge of the Bφ signal.
[2] The PALL command is issued.
[3] The bus control signals are driven high at the end of the external access cycle. It takes two cycles or
more after the low level of the BREQ signal is sampled.
[4] The BACK signal is driven low, releasing bus to the external bus master.
[5] The BREQ signal state sampling is continued in the external bus released state.
[6] A high level of the BREQ signal is sampled.
[7] The BACK signal is driven high, ending external bus release cycle after one cycle.
[8] When the external space is accessed by an internal bus master or a refresh cycle is requested during external
bus released while the BREQOE bit is set to 1, the BREQO signal goes low.
[9] Normally the BREQO signal goes high at the rising edge of the BACK signal.
Figure 9.103 Bus Released State Transition Timing (SRAM Interface is Used)
Rev. 2.00 Oct. 21, 2009 Page 359 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.14
Internal Bus
9.14.1
Access to Internal Address Space
The internal address spaces of this LSI are the on-chip ROM space, on-chip RAM space, and
register space for the on-chip peripheral modules. The number of cycles necessary for access
differs according the space.
Table 9.33 shows the number of access cycles for each on-chip memory space.
Table 9.33 Number of Access Cycles for On-Chip Memory Spaces
Access Space
Access
On-chip ROM space
Read
One Iφ cycle
Write
Three Iφ cycles
Read
One Iφ cycle
Write
One Iφ cycle
On-chip RAM space
Number of Access Cycles
In access to the registers for on-chip peripheral modules, the number of access cycles differs
according to the register to be accessed. When the dividing ratio of the operating clock of a bus
master and that of a peripheral module is 1 : n, synchronization cycles using a clock divided by 0
to n-1 are inserted for register access in the same way as for external bus clock division.
Table 9.34 lists the number of access cycles for registers of on-chip peripheral modules.
Table 9.34 Number of Access Cycles for Registers of On-Chip Peripheral Modules
Number of Cycles
Module to be Accessed
Read
DMAC and EXDMAC registers
Two Iφ
MCU operating mode, clock pulse generator,
Two Iφ
power-down control registers, interrupt controller,
bus controller, and DTC registers
Write
Write Data Buffer Function
Disabled
Three Iφ
Disabled
I/O port registers of PFCR and WDT
Two Pφ
Three Pφ Disabled
I/O port registers other than PFCR and PORTM,
TPU, PPG0, TMR0, TMR1, SCI0 to SCI2, SCI4,
IIC2, A/D_0, and D/A registers
Two Pφ
Enabled
I/O port registers of PORTM, TMR2, TMR3,
USB, SCI5, SCI6, A/D_1, and PPG1 registers
Three Pφ
Enabled
Rev. 2.00 Oct. 21, 2009 Page 360 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.15
Write Data Buffer Function
9.15.1
Write Data Buffer Function for External Data Bus
This LSI has a write data buffer function for the external data bus. Using the write data buffer
function enables internal accesses in parallel with external writes or DMAC single address
transfers. The write data buffer function is made available by setting the WDBE bit to 1 in BCR1.
Figure 9.104 shows an example of the timing when the write data buffer function is used. When
this function is used, if an external address space write or a DMAC single address transfer
continues for two cycles or longer, and there is an internal access next, an external write only is
executed in the first two cycles. However, from the next cycle onward, internal accesses (on-chip
memory or internal I/O register read/write) and the external address space write rather than
waiting until it ends are executed in parallel.
On-chip memory read
Peripheral module read
External write cycle
Iφ
On-chip
memory 1
Internal
address bus
T1
On-chip
memory 2
T2
Peripheral module address
T3
Bφ
Address bus
Write to
external
space
External address
CSn
LHWR, LLWR
D15 to D0
Figure 9.104 Example of Timing when Write Data Buffer Function is Used
Rev. 2.00 Oct. 21, 2009 Page 361 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.15.2
Write Data Buffer Function for Peripheral Modules
This LSI has a write data buffer function for the peripheral module access. Using the write data
buffer function enables peripheral module writes and on-chip memory or external access to be
executed in parallel. The write data buffer function is made available by setting the PWDBE bit in
BCR2 to 1. For details on the on-chip peripheral module registers, see table 9.34, Number of
Access Cycles for Registers of On-Chip Peripheral Modules in section 9.14, Internal Bus.
Figure 9.105 shows an example of the timing when the write data buffer function is used. When
this function is used, if an internal I/O register write continues for two cycles or longer and then
there is an on-chip RAM, an on-chip ROM, or an external access, internal I/O register write only
is performed in the first two cycles. However, from the next cycle onward an internal memory or
an external access and internal I/O register write are executed in parallel rather than waiting until
it ends.
On-chip
memory
read
Peripheral module write
Iφ
Internal
address bus
Pφ
Internal I/O
address bus
Peripheral module address
Internal I/O
data bus
Figure 9.105 Example of Timing when Peripheral Module
Write Data Buffer Function is Used
Rev. 2.00 Oct. 21, 2009 Page 362 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.16
Bus Arbitration
This LSI has bus arbiters that arbitrate bus mastership operations (bus arbitration). This LSI
incorporates internal access and external access bus arbiters that can be used and controlled
independently. The internal bus arbiter handles the CPU, DTC, and DMAC accesses. The external
bus arbiter handles the external access by the CPU, DTC, DMAC, and EXDMAC, refresh, and
external bus release request (external bus master).
The bus arbiters determine priorities at the prescribed timing, and permit use of the bus by means
of the bus request acknowledge signal.
9.16.1
Operation
The bus arbiter detects the bus masters' bus request signals, and if the bus is requested, sends a bus
request acknowledge signal to the bus master. If there are bus requests from more than one bus
master, the bus request acknowledge signal is sent to the one with the highest priority. When a bus
master receives the bus request acknowledge signal, it takes possession of the bus until that signal
is canceled.
The priority of the internal bus arbitration:
DMAC > DTC > CPU
The priority of the external bus arbitration:
Refresh > EXDMAC > External bus release request > External access by the CPU, DTC, or
DMAC
If the DMAC or DTC accesses continue, the CPU can be given priority over the DMAC or DTC
to execute the bus cycles alternatively between them by setting the IBCCS bit in BCR2. In this
case, the priority between the DMAC and DTC does not change. If an external bus release request,
an EXDMAC access, and a refresh cycle request continue, an external bus access by the CPU,
DTC, and DMAC can be given priority to execute the bus cycles alternatively between them by
setting the EBCCS bit in BCR2. In this case, the priorities among the refresh, EXDMAC, and
external bus release request do not change.
An internal bus access by internal bus masters and an external bus access by an external bus
release request, a refresh cycle, or an EXDMAC access can be executed in parallel.
Rev. 2.00 Oct. 21, 2009 Page 363 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.16.2
Bus Transfer Timing
Even if a bus request is received from a bus master with a higher priority over that of the bus
master that has taken control of the bus and is currently operating, the bus is not necessarily
transferred immediately. There are specific timings at which each bus master can release the bus.
(1)
CPU
The CPU is the lowest-priority bus master, and if a bus request is received from the DTC or
DMAC, the bus arbiter transfers the bus to the bus master that issued the request. When the CPU
accesses the external space and a bus request is received from the EXDMAC, the external bus
arbiter transfer the bus to the EXDMAC.
The timing for transfer of the bus is at the end of the bus cycle. In sleep mode, the bus is
transferred synchronously with the clock.
Note, however, that the bus cannot be transferred in the following cases.
• The word or longword access is performed in some divisions.
• Stack handling is performed in multiple bus cycles.
• Transfer data read or write by memory transfer instructions, block transfer instructions, or TAS
instruction.
(In the block transfer instructions, the bus can be transferred in the write cycle and the
following transfer data read cycle.)
• From the target read to write in the bit manipulation instructions or memory operation
instructions.
(In an instruction that performs no write operation according to the instruction condition, up to
a cycle corresponding the write cycle)
(2)
DTC
The DTC sends the internal bus arbiter a request for the bus when an activation request is
generated. When the DTC accesses an external bus space, the DTC first takes control of the bus
from the internal bus arbiter and then requests a bus to the external bus arbiter.
Once the DTC takes control of the bus, the DTC continues the transfer processing cycles. If a bus
master whose priority is higher than the DTC requests the bus, the DTC transfers the bus to the
higher priority bus master. If the IBCCS bit in BCR2 is set to 1, the DTC transfers the bus to the
CPU.
Rev. 2.00 Oct. 21, 2009 Page 364 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Note, however, that the bus cannot be transferred in the following cases.
• During transfer information read
• During the first data transfer
• During transfer information write back
The DTC releases the bus when the consecutive transfer cycles completed.
(3)
DMAC
The DMAC sends the internal bus arbiter a request for the bus when an activation request is
generated. When the DMAC accesses an external bus space, the DMAC first takes control of the
bus from the internal bus arbiter and then requests a bus to the external bus arbiter.
After the DMAC takes control of the bus, it may continue the transfer processing cycles or release
the bus at the end of every bus cycle depending on the conditions.
The DMAC continues transfers without releasing the bus in the following case:
• Between the read cycle in the dual-address mode and the write cycle corresponding to the read
cycle
If no bus master of a higher priority than the DMAC requests the bus and the IBCCS bit in BCR2
is cleared to 0, the DMAC continues transfers without releasing the bus in the following cases:
• During 1-block transfers in the block transfer mode
• During transfers in the burst mode
In other cases, the DMAC transfers the bus at the end of the bus cycle.
(4)
EXDMAC
The EXDMAC sends the external bus arbiter a request for the bus when an activation request is
generated. If an internal bus master accesses the external space, the bus is passed to the EXDMAC
when the bus master can release the bus. Some EXDMAC transfers are continued once it takes
control of the bus. Some EXDMAC transfers are divided and it releases the bus for each transfer
cycle.
• Transfers are continued without bus release between a read cycle and the subsequent write
cycle in dual address mode
• Transfers are continued without bus release in cluster transfer mode
Rev. 2.00 Oct. 21, 2009 Page 365 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
• Transfers are continued without bus release when a bus master with priority over the DMAC is
not requesting the bus, the EBCCS bit in BCR2 is cleared to 0, and either the following
conditions are executed.
⎯ While one block of data is being transferred in block transfer mode
⎯ While data is being transferred in burst mode
A transfer other than the above is stopped and the bus is passed when the bus cycle is completed.
However, the EXDMAC takes control of the bus and EXDMAC transfers are continued when
multiple channels in the EXDMAC request the bus while other bus masters are not requesting the
bus.
(5)
External Bus Release
When the BREQ pin goes low and an external bus release request is issued while the BRLE bit in
BCR1 is set to 1 with the corresponding ICR bit set to 1, a bus request is sent to the bus arbiter.
External bus release can be performed on completion of an external bus cycle.
(6)
Refresh
When area 2 is specified as the DRAM space or SDRAM space with the RFSHE bit in REFCR set
to 1, RTCNT starts to count up. When the RTCOR value matches RTCNT, a bus request is sent to
the bus arbiter.
A refresh cycle is inserted on completion of the external bus cycle. A refresh cycle is not
consecutively inserted. Once a refresh cycle is inserted, the bus is passed to another bus master.
When the bus is passed, if there is no bus request from other bus masters, NOP cycles are inserted.
Rev. 2.00 Oct. 21, 2009 Page 366 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
9.17
Bus Controller Operation in Reset
In a reset, this LSI, including the bus controller, enters the reset state immediately, and any
executing bus cycle is aborted.
9.18
(1)
Usage Notes
Setting Registers
The BSC registers must be specified before accessing the external address space. In on-chip ROM
disabled mode, the BSC registers must be specified before accessing the external address space for
other than an instruction fetch access.
(2)
Mode Settings
The burst read-burst write mode of synchronous DRAM is not supported.
When setting the mode register of synchronous DRAM, the burst read-single write mode must be
selected and the burst length must be 1.
(3)
External Bus Release Function and All-Module-Clock-Stop Mode
In this LSI, if the ACSE bit in MSTPCRA is set to 1 and a SLEEP instruction is executed to enter
the sleep state after shutting off the clocks to all peripheral modules (MSTPCRA and MSTPCRB
= H'FFFFFFF) or allowing operation of the 8-bit timer module alone (MSTPCRA and MSTPCRB
= H'F[C to F]FFFFFF), the all-module-clock-stop mode is entered in which the clock for the bus
controller and I/O ports is also stopped. For details, see section 28, Power-Down Modes.
In this state, the external bus release function is halted. To use the external bus release function in
sleep mode, the ACSE bit in MSTPCRA must be cleared to 0. Conversely, if a SLEEP instruction
to place the chip in all-module-clock-stop mode is executed in the external bus released state, the
transition to all-module-clock-stop mode is deferred and performed until after the bus is
recovered.
(4)
External Bus Release Function and Software Standby Mode
In this LSI, internal bus master operation does not stop even while the bus is released, as long as
the program is running in on-chip ROM, etc., and no external access occurs. If a SLEEP
instruction to place the chip in software standby mode is executed while the external bus is
released, the transition to software standby mode is deferred and performed after the bus is
recovered.
Rev. 2.00 Oct. 21, 2009 Page 367 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Also, since clock oscillation halts in software standby mode, if the BREQ signal goes low in this
mode, indicating an external bus release request, the request cannot be answered until the chip has
recovered from the software standby mode.
Note that the BACK and BREQO pins are both in the high-impedance state in software standby
mode.
(5)
External Bus Release Function and CBR-Refresh or Auto-Refresh Cycle
The CBR refresh or auto-refresh cycle cannot be performed while the external bus is released.
When a CBR-refresh or an auto-refresh cycle is requested, the BREQO signal can be output by
setting the BREQOE bit in BCR1 to 1.
(6)
BREQO Output Timing
When the BREQOE bit is set to 1 and the BREQO signal is output, both the BREQO and BACK
signals may go low simultaneously.
This will occur if the next external access request occurs while internal bus arbitration is in
progress after the chip samples a low level of the BREQ signal.
(7)
Refresh Settings
In single-chip activation mode, the setting of the RFSHE bit in REFCR should be made after
setting the EXPE bit in SYSCR to 1. For SYSCR, see section 3, MCU Operating Modes.
(8)
Refresh Timer Settings
The setting of bits RTCK2 to RTCK0 in REFCR should be made after RTCNT and RTCOR have
been set. When changing RTCNT and RTCOR, the counter operation should be halted. When
changing bits RTCK2 to RTCK0, external access and external bus release by the EXDMAC
should be prohibited. The write data buffer function should be used after the write data buffer
function is disabled and the external space is read.
(9)
Switching Between Refresh Timer and Interval Timer
When changing the RFSHE bit in REFCR from 1 to 0, a refresh cycle may be inserted until the bit
change is reflected. After this, when using RTCNT as an interval timer, the compare match flag
(CMF) may be set to 1. Therefore, confirm the state before setting the CMIE bit to 1.
Rev. 2.00 Oct. 21, 2009 Page 368 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
(10) RAS Down Mode and Software Standby Mode for DRAM Interface
When making a transition to software standby mode with the OPE bit in SBYCR set to 0 without
using the self-refresh mode, the transition should be made in RAS up mode (RCDM = 0). When
RAS down mode (RCDM = 1) is used, execute the SLEEP instruction after setting the RCDM bit
to 0. RAS down mode should be set again after recovery from software standby mode. For
SBYCR, see section 28, Power-Down Modes.
(11) RAS Down Mode and Clock Frequencies Setting for DRAM/SDRAM
Write access to SCKCR for setting the clock frequencies should be performed in RAS up mode
(RCDM = 0). When RAS down mode (RCDM = 1) is used, set the RCDM bit to 0 before writing
to SCKCR. RAS down mode should be set again after clock frequencies are set. For SCKCR, see
section 27, Clock Pulse Generator.
(12) Cluster Transfer to SDRAM Space
Cluster transfer mode is available for the SDRAM with CAS latency of 2. When the SDRAM is
used in cluster transfer mode, the SDRAM with CAS latency of 2 should be used. In cluster
transfer mode, the write-precharge output delay function by the TRWL bit is not available. The
TRWL bit must be cleared to 0.
Rev. 2.00 Oct. 21, 2009 Page 369 of 1454
REJ09B0498-0200
Section 9 Bus Controller (BSC)
Rev. 2.00 Oct. 21, 2009 Page 370 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Section 10 DMA Controller (DMAC)
This LSI includes a 4-channel DMA controller (DMAC).
10.1
Features
• Maximum of 4-G byte address space can be accessed
• Byte, word, or longword can be set as data transfer unit
• Maximum of 4-G bytes (4,294,967,295 bytes) can be set as total transfer size
Supports free-running mode in which total transfer size setting is not needed
• DMAC activation methods are auto-request, on-chip module interrupt, and external request.
Auto request:
CPU activates (cycle stealing or burst access can be selected)
On-chip module interrupt: Interrupt requests from on-chip peripheral modules can be selected
as an activation source
External request:
Low level or falling edge detection of the DREQ signal can be
selected. External request is available for all four channels.
• Dual or single address mode can be selected as address mode
Dual address mode: Both source and destination are specified by addresses
Single address mode: Either source or destination is specified by the DACK signal and the
other is specified by address
• Normal, repeat, or block transfer can be selected as transfer mode
Normal transfer mode:
One byte, one word, or one longword data is transferred at a
single transfer request
Repeat transfer mode:
One byte, one word, or one longword data is transferred at a
single transfer request
Repeat size of data is transferred and then a transfer address
returns to the transfer start address
Up to 64K transfers (65,536 bytes/words/longwords) can be set as
repeat size
Block transfer mode:
One block data is transferred at a single transfer request
Up to 64K transfers (65,536 bytes/words/longwords) can be set as
block size
Rev. 2.00 Oct. 21, 2009 Page 371 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
• Extended repeat area function which repeats the addressees within a specified area using the
transfer address with the fixed upper bits (ring buffer transfer can be performed, as an
example) is available
One bit (two bytes) to 27 bits (128 Mbytes) for transfer source and destination can be set as
extended repeat areas
• Address update can be selected from fixed address, offset addition, and increment or
decrement by 1, 2, or 4
Address update by offset addition enables to transfer data at addresses which are not placed
continuously
• Word or longword data can be transferred to an address which is not aligned with the
respective boundary
Data is divided according to its address (byte or word) when it is transferred
• Two types of interrupts can be requested to the CPU
A transfer end interrupt is generated after the number of data specified by the transfer counter
is transferred. A transfer escape end interrupt is generated when the remaining total transfer
size is less than the transfer data size at a single transfer request, when the repeat size of data
transfer is completed, or when the extended repeat area overflows.
• Module stop state can be set.
Rev. 2.00 Oct. 21, 2009 Page 372 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
A block diagram of the DMAC is shown in figure 10.1.
Internal data bus
Internal address bus
External pins
DREQn
Data buffer
DACKn
TENDn
Interrupt signals
requested to the
CPU by each
channel
Internal activation sources
...
Controller
Address buffer
Operation unit
Operation unit
DOFR_n
DSAR_n
Internal activation
source detector
DMRSR_n
DDAR_n
DMDR_n
DTCR_n
DACR_n
DBSR_n
Module data bus
[Legend]
DSAR_n:
DDAR_n:
DOFR_n:
DTCR_n:
DBSR_n:
DMDR_n:
DACR_n:
DMRSR_n:
DMA source address register
DMA destination address register
DMA offset register
DMA transfer count register
DMA block size register
DMA mode control register
DMA address control register
DMA module request select register
DREQn: DMA transfer request
DACKn: DMA transfer acknowledge
TENDn: DMA transfer end
n = 0 to 3
Figure 10.1 Block Diagram of DMAC
Rev. 2.00 Oct. 21, 2009 Page 373 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.2
Input/Output Pins
Table 10.1 shows the pin configuration of the DMAC.
Table 10.1 Pin Configuration
Channel
Pin Name
Abbr.
I/O
Function
0
DMA transfer request 0
DREQ0
Input
Channel 0 external request
DMA transfer acknowledge 0
DACK0
Output
Channel 0 single address transfer
acknowledge
1
2
3
DMA transfer end 0
TEND0
Output
Channel 0 transfer end
DMA transfer request 1
DREQ1
Input
Channel 1 external request
DMA transfer acknowledge 1
DACK1
Output
Channel 1 single address transfer
acknowledge
DMA transfer end 1
TEND1
Output
Channel 1 transfer end
DMA transfer request 2
DREQ2
Input
Channel 2 external request
DMA transfer acknowledge 2
DACK2
Output
Channel 2 single address transfer
acknowledge
DMA transfer end 2
TEND2
Output
Channel 2 transfer end
DMA transfer request 3
DREQ3
Input
Channel 3 external request
DMA transfer acknowledge 3
DACK3
Output
Channel 3 single address transfer
acknowledge
DMA transfer end 3
TEND3
Output
Channel 3 transfer end
Rev. 2.00 Oct. 21, 2009 Page 374 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.3
Register Descriptions
The DMAC has the following registers.
Channel 0:
•
•
•
•
•
•
•
•
DMA source address register_0 (DSAR_0)
DMA destination address register_0 (DDAR_0)
DMA offset register_0 (DOFR_0)
DMA transfer count register_0 (DTCR_0)
DMA block size register_0 (DBSR_0)
DMA mode control register_0 (DMDR_0)
DMA address control register_0 (DACR_0)
DMA module request select register_0 (DMRSR_0)
Channel 1:
•
•
•
•
•
•
•
•
DMA source address register_1 (DSAR_1)
DMA destination address register_1 (DDAR_1)
DMA offset register_1 (DOFR_1)
DMA transfer count register_1 (DTCR_1)
DMA block size register_1 (DBSR_1)
DMA mode control register_1 (DMDR_1)
DMA address control register_1 (DACR_1)
DMA module request select register_1 (DMRSR_1)
Channel 2:
•
•
•
•
•
•
•
•
DMA source address register_2 (DSAR_2)
DMA destination address register_2 (DDAR_2)
DMA offset register_2 (DOFR_2)
DMA transfer count register_2 (DTCR_2)
DMA block size register_2 (DBSR_2)
DMA mode control register_2 (DMDR_2)
DMA address control register_2 (DACR_2)
DMA module request select register_2 (DMRSR_2)
Rev. 2.00 Oct. 21, 2009 Page 375 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Channel 3:
•
•
•
•
•
•
•
•
DMA source address register_3 (DSAR_3)
DMA destination address register_3 (DDAR_3)
DMA offset register_3 (DOFR_3)
DMA transfer count register_3 (DTCR_3)
DMA block size register_3 (DBSR_3)
DMA mode control register_3 (DMDR_3)
DMA address control register_3 (DACR_3)
DMA module request select register_3 (DMRSR_3)
10.3.1
DMA Source Address Register (DSAR)
DSAR is a 32-bit readable/writable register that specifies the transfer source address. DSAR
updates the transfer source address every time data is transferred. When DDAR is specified as the
destination address (the DIRS bit in DACR is 1) in single address mode, DSAR is ignored.
Although DSAR can always be read from by the CPU, it must be read from in longwords and
must not be written to while data for the channel is being transferred.
Bit
31
30
29
28
27
26
25
24
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 376 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.3.2
DMA Destination Address Register (DDAR)
DDAR is a 32-bit readable/writable register that specifies the transfer destination address. DDAR
updates the transfer destination address every time data is transferred. When DSAR is specified as
the source address (the DIRS bit in DACR is 0) in single address mode, DDAR is ignored.
Although DDAR can always be read from by the CPU, it must be read from in longwords and
must not be written to while data for the channel is being transferred.
Bit
31
30
29
28
27
26
25
24
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 377 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.3.3
DMA Offset Register (DOFR)
DOFR is a 32-bit readable/writable register that specifies the offset to update the source and
destination addresses. Although different values are specified for individual channels, the same
values must be specified for the source and destination sides of a single channel.
Bit
31
30
29
28
27
26
25
24
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 378 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.3.4
DMA Transfer Count Register (DTCR)
DTCR is a 32-bit readable/writable register that specifies the size of data to be transferred (total
transfer size).
To transfer 1-byte data in total, set H'00000001 in DTCR. When H'00000000 is set in this register,
it means that the total transfer size is not specified and data is transferred with the transfer counter
stopped (free running mode). When H'FFFFFFFF is set, the total transfer size is 4 Gbytes
(4,294,967,295), which is the maximum size. While data is being transferred, this register
indicates the remaining transfer size. The value corresponding to its data access size is subtracted
every time data is transferred (byte: −1, word: −2, and longword: −4).
Although DTCR can always be read from by the CPU, it must be read from in longwords and
must not be written to while data for the channel is being transferred.
Bit
31
30
29
28
27
26
25
24
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 379 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.3.5
DMA Block Size Register (DBSR)
DBSR specifies the repeat size or block size. DBSR is enabled in repeat transfer mode and block
transfer mode and is disabled in normal transfer mode.
31
30
29
28
27
26
25
24
BKSZH31
BKSZH30
BKSZH29
BKSZH28
BKSZH27
BKSZH26
BKSZH25
BKSZH24
Bit
Bit Name
Initial Value
R/W
0
0
0
0
R/W
R/W
R/W
R/W
22
21
20
19
18
17
16
BKSZH21
BKSZH20
BKSZH19
BKSZH18
BKSZH17
BKSZH16
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
BKSZ15
BKSZ14
BKSZ13
BKSZ12
BKSZ11
BKSZ10
BKSZ9
BKSZ8
Bit
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
BKSZ7
BKSZ6
BKSZ5
BKSZ4
BKSZ3
BKSZ2
BKSZ1
BKSZ0
Initial Value
R/W
Bit
0
R/W
BKSZH22
R/W
Bit Name
0
R/W
23
Initial Value
Bit Name
0
R/W
BKSZH23
Bit
Bit Name
0
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
Initial
Value
R/W
Description
31 to 16 BKSZH31 to All 0
BKSZH16
R/W
Specify the repeat size or block size.
15 to 0
R/W
BKSZ15 to
BKSZ0
All 0
When H'0001 is set, the repeat or block size is one byte,
one word, or one longword. When H'0000 is set, it
means the maximum value (refer to table 10.1). While
the DMA is in operation, the setting is fixed.
Rev. 2.00 Oct. 21, 2009 Page 380 of 1454
REJ09B0498-0200
Indicate the remaining repeat or block size while the
DMA is in operation. The value is decremented by 1
every time data is transferred. When the remaining size
becomes 0, the value of the BKSZH bits is loaded. Set
the same value as the BKSZH bits.
Section 10 DMA Controller (DMAC)
Table 10.2 Data Access Size, Valid Bits, and Settable Size
Mode
Data Access Size BKSZH Valid Bits BKSZ Valid Bits
Repeat transfer
Byte
and block transfer Word
31 to 16
15 to 0
1 to 65,536
2 to 131,072
Longword
10.3.6
Settable Size
(Byte)
4 to 262,144
DMA Mode Control Register (DMDR)
DMDR controls the DMAC operation.
• DMDR_0
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
31
30
29
28
27
26
25
24
DTE
DACKE
TENDE
⎯
DREQS
NRD
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R
R
23
22
21
20
19
18
17
16
ACT
⎯
⎯
⎯
ERRF
⎯
ESIF
DTIF
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R/(W)*
R
R/(W)*
R/(W)*
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Note: *
15
14
13
12
11
10
9
8
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R
R/W
R/W
7
6
5
4
3
2
1
0
DTF1
DTF0
DTA
⎯
⎯
DMAP2
DMAP1
DMAP0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R
R
R/W
R/W
R/W
Only 0 can be written to this bit after having been read as 1, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 381 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
• DMDR_1 to DMDR_3
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
31
30
29
28
27
26
25
24
DTE
DACKE
TENDE
⎯
DREQS
NRD
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R
R
23
22
21
20
19
18
17
16
ACT
⎯
⎯
⎯
⎯
⎯
ESIF
DTIF
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R/(W)*
R/(W)*
15
14
13
12
11
10
9
8
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Note: *
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R
R/W
R/W
7
6
5
4
3
2
1
0
DTF1
DTF0
DTA
⎯
⎯
DMAP2
DMAP1
DMAP0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R
R
R/W
R/W
R/W
Only 0 can be written to this bit after having been read as 1, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 382 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
Description
31
DTE
0
R/W
Data Transfer Enable
Enables/disables a data transfer for the corresponding
channel. When this bit is set to 1, it indicates that the
DMAC is in operation.
Setting this bit to 1 starts a transfer when the autorequest is selected. When the on-chip module interrupt
or external request is selected, a transfer request after
setting this bit to 1 starts the transfer. While data is
being transferred, clearing this bit to 0 stops the
transfer.
In block transfer mode, if writing 0 to this bit while data is
being transferred, this bit is cleared to 0 after the current
1-block size data transfer.
If an event which stops (sustains) a transfer occurs
externally, this bit is automatically cleared to 0 to stop
the transfer.
Operating modes and transfer methods must not be
changed while this bit is set to 1.
0: Disables a data transfer
1: Enables a data transfer (DMA is in operation)
[Clearing conditions]
•
When the specified total transfer size of transfers is
completed
•
When a transfer is stopped by an overflow interrupt
by a repeat size end
•
When a transfer is stopped by an overflow interrupt
by an extended repeat size end
•
When a transfer is stopped by a transfer size error
interrupt
•
When clearing this bit to 0 to stop a transfer
In block transfer mode, this bit changes after the current
block transfer.
•
When an address error or an NMI interrupt is
requested
•
In the reset state or hardware standby mode
Rev. 2.00 Oct. 21, 2009 Page 383 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
Description
30
DACKE
0
R/W
DACK Signal Output Enable
Enables/disables the DACK signal output in single
address mode. This bit is ignored in dual address mode.
0: Disables DACK signal output
1: Enables DACK signal output
29
TENDE
0
R/W
TEND Signal Output Enable
Enables/disables the TEND signal output.
0: Disables TEND signal output
1: Enables TEND signal output
28
⎯
0
R/W
Reserved
Initial value should not be changed.
27
DREQS
0
R/W
DREQ Select
Selects whether a low level or the falling edge of the
DREQ signal used in external request mode is detected.
0: Low level detection
1: Falling edge detection (the first transfer after a
transfer enabled is detected on a low level)
26
NRD
0
R/W
Next Request Delay
Selects the accepting timing of the next transfer request.
0: Starts accepting the next transfer request after
completion of the current transfer
1: Starts accepting the next transfer request one cycle
after completion of the current transfer
25, 24
⎯
All 0
R
Reserved
These bits are always read as 0 and cannot be
modified.
23
ACT
0
R
Active State
Indicates the operating state for the channel.
0: Waiting for a transfer request or a transfer disabled
state by clearing the DTE bit to 0
1: Active state
22 to 20 ⎯
All 0
R
Reserved
These bits are always read as 0 and cannot be
modified.
Rev. 2.00 Oct. 21, 2009 Page 384 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
19
ERRF
0
R/(W)* System Error Flag
Description
Indicates that an address error or an NMI interrupt has
been generated. This bit is available only in DMDR_0.
Setting this bit to 1 prohibits writing to the DTE bit for all
the channels. This bit is reserved in DMDR_1 to
DMDR_3. It is always read as 0 and cannot be modified.
0: An address error or an NMI interrupt has not been
generated
1: An address error or an NMI interrupt has been
generated
[Clearing condition]
•
When clearing to 0 after reading ERRF = 1
[Setting condition]
•
When an address error or an NMI interrupt has been
generated
However, when an address error or an NMI interrupt has
been generated in DMAC module stop mode, this bit is
not set to 1.
18
⎯
0
R
Reserved
This bit is always read as 0 and cannot be modified.
17
ESIF
0
R/(W)* Transfer Escape Interrupt Flag
Indicates that a transfer escape end interrupt has been
requested. A transfer escape end means that a transfer
is terminated before the transfer counter reaches 0.
0: A transfer escape end interrupt has not been
requested
1: A transfer escape end interrupt has been requested
[Clearing conditions]
•
When setting the DTE bit to 1
•
When clearing to 0 before reading ESIF = 1
[Setting conditions]
•
When a transfer size error interrupt is requested
•
When a repeat size end interrupt is requested
•
When a transfer end interrupt by an extended repeat
area overflow is requested
Rev. 2.00 Oct. 21, 2009 Page 385 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
16
DTIF
0
R/(W)* Data Transfer Interrupt Flag
Description
Indicates that a transfer end interrupt by the transfer
counter has been requested.
0: A transfer end interrupt by the transfer counter has
not been requested
1: A transfer end interrupt by the transfer counter has
been requested
[Clearing conditions]
•
When setting the DTE bit to 1
•
When clearing to 0 after reading DTIF = 1
[Setting condition]
•
When DTCR reaches 0 and the transfer is
completed
15
DTSZ1
0
R/W
Data Access Size 1 and 0
14
DTSZ0
0
R/W
Select the data access size for a transfer.
00: Byte size (eight bits)
01: Word size (16 bits)
10: Longword size (32 bits)
11: Setting prohibited
13
MDS1
0
R/W
Transfer Mode Select 1 and 0
12
MDS0
0
R/W
Select the transfer mode.
00: Normal transfer mode
01: Block transfer mode
10: Repeat transfer mode
11: Setting prohibited
Rev. 2.00 Oct. 21, 2009 Page 386 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
Description
11
TSEIE
0
R/W
Transfer Size Error Interrupt Enable
Enables/disables a transfer size error interrupt.
When the next transfer is requested while this bit is set
to 1 and the contents of the transfer counter is less than
the size of data to be transferred at a single transfer
request, the DTE bit is cleared to 0. At this time, the
ESIF bit is set to 1 to indicate that a transfer size error
interrupt has been requested.
The sources of a transfer size error are as follows:
•
In normal or repeat transfer mode, the total transfer
size set in DTCR is less than the data access size
•
In block transfer mode, the total transfer size set in
DTCR is less than the block size
0: Disables a transfer size error interrupt request
1: Enables a transfer size error interrupt request
10
⎯
0
R
Reserved
This bit is always read as 0 and cannot be modified.
9
ESIE
0
R/W
Transfer Escape Interrupt Enable
Enables/disables a transfer escape end interrupt
request. When the ESIF bit is set to 1 with this bit set to
1, a transfer escape end interrupt is requested to the
CPU or DTC. The transfer end interrupt request is
cleared by clearing this bit or the ESIF bit to 0.
0: Disables a transfer escape end interrupt
1: Enables a transfer escape end interrupt
8
DTIE
0
R/W
Data Transfer End Interrupt Enable
Enables/disables a transfer end interrupt request by the
transfer counter. When the DTIF bit is set to 1 with this
bit set to 1, a transfer end interrupt is requested to the
CPU or DTC. The transfer end interrupt request is
cleared by clearing this bit or the DTIF bit to 0.
0: Disables a transfer end interrupt
1: Enables a transfer end interrupt
Rev. 2.00 Oct. 21, 2009 Page 387 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
Description
7
DTF1
0
R/W
Data Transfer Factor 1 and 0
6
DTF0
0
R/W
Select a DMAC activation source. When the on-chip
peripheral module setting is selected, the interrupt
source should be selected by DMRSR. When the
external request setting is selected, the sampling
method should be selected by the DREQS bit.
00: Auto request (cycle stealing)
01: Auto request (burst access)
10: On-chip module interrupt
11: External request
5
DTA
0
R/W
Data Transfer Acknowledge
This bit is valid in DMA transfer by the on-chip module
interrupt source. This bit enables or disables to clear the
source flag selected by DMRSR.
0: To clear the source in DMA transfer is disabled.
Since the on-chip module interrupt source is not
cleared in DMA transfer, it should be cleared by the
CPU or DTC transfer.
1: To clear the source in DMA transfer is enabled.
Since the on-chip module interrupt source is cleared
in DMA transfer, it does not require an interrupt by the
CPU or DTC transfer.
4, 3
⎯
All 0
R
Reserved
These bits are always read as 0 and cannot be
modified.
Rev. 2.00 Oct. 21, 2009 Page 388 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
Description
2
DMAP2
0
R/W
DMA Priority Level 2 to 0
1
DMAP1
0
R/W
0
DMAP0
0
R/W
Select the priority level of the DMAC when using the
CPU priority control function over DMAC. When the
CPU has priority over the DMAC, the DMAC masks a
transfer request and waits for the timing when the CPU
priority becomes lower than the DMAC priority. The
priority levels can be set to the individual channels. This
bit is valid when the CPUPCE bit in CPUPCR is set to 1.
000: Priority level 0 (low)
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 (high)
Note:
*
Only 0 can be written to, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 389 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.3.7
DMA Address Control Register (DACR)
DACR specifies the operating mode and transfer method.
Bit
Bit Name
31
30
29
28
27
26
25
24
AMS
DIRS
⎯
⎯
⎯
RPTIE
ARS1
ARS0
0
0
0
0
0
0
0
0
R/W
R/W
R
R
R
R/W
R/W
R/W
Bit
23
22
21
20
19
18
17
16
Bit Name
⎯
⎯
SAT1
SAT0
⎯
⎯
DAT1
DAT0
Initial Value
R/W
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R/W
R/W
R
R
R/W
R/W
15
14
13
12
11
10
9
8
SARIE
⎯
⎯
SARA4
SARA3
SARA2
SARA1
SARA0
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R
R
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
DARIE
⎯
⎯
DARA4
DARA3
DARA2
DARA1
DARA0
0
0
0
0
0
0
0
0
R/W
R
R
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
31
AMS
0
R/W
Address Mode Select
Selects address mode from single or dual address
mode. In single address mode, the DACK pin is enabled
according to the DACKE bit.
0: Dual address mode
1: Single address mode
30
DIRS
0
R/W
Single Address Direction Select
Specifies the data transfer direction in single address
mode. This bit s ignored in dual address mode.
0: Specifies DSAR as source address
1: Specifies DDAR as destination address
29 to 27 ⎯
All 0
R
Reserved
These bits are always read as 0 and cannot be
modified.
Rev. 2.00 Oct. 21, 2009 Page 390 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
Description
26
RPTIE
0
R/W
25
24
ARS1
ARS0
0
0
R/W
R/W
23, 22
⎯
All 0
R
21
20
SAT1
SAT0
0
0
R/W
R/W
Repeat Size End Interrupt Enable
Enables/disables a repeat size end interrupt request.
In repeat transfer mode, when the next transfer is
requested after completion of a 1-repeat-size data
transfer while this bit is set to 1, the DTE bit in DMDR is
cleared to 0. At this time, the ESIF bit in DMDR is set to
1 to indicate that a repeat size end interrupt is
requested. Even when the repeat area is not specified
(ARS1 = 1 and ARS0 = 0), a repeat size end interrupt
after a 1-block data transfer can be requested.
In addition, in block transfer mode, when the next
transfer is requested after 1-block data transfer while
this bit is set to 1, the DTE bit in DMDR is cleared to 0.
At this time, the ESIF bit in DMDR is set to 1 to indicate
that a repeat size end interrupt is requested.
0: Disables a repeat size end interrupt
1: Enables a repeat size end interrupt
Area Select 1 and 0
Specify the block area or repeat area in block or repeat
transfer mode.
00: Specify the block area or repeat area on the source
address
01: Specify the block area or repeat area on the
destination address
10: Do not specify the block area or repeat area
11: Setting prohibited
Reserved
These bits are always read as 0 and cannot be
modified.
Source Address Update Mode 1 and 0
Select the update method of the source address
(DSAR). When DSAR is not specified as the transfer
source in single address mode, this bit is ignored.
00: Source address is fixed
01: Source address is updated by adding the offset
10: Source address is updated by adding 1, 2, or 4
according to the data access size
11: Source address is updated by subtracting 1, 2, or 4
according to the data access size
Rev. 2.00 Oct. 21, 2009 Page 391 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
Description
19, 18
⎯
All 0
R
Reserved
These bits are always read as 0 and cannot be
modified.
17
DAT1
0
R/W
Destination Address Update Mode 1 and 0
16
DAT0
0
R/W
Select the update method of the destination address
(DDAR). When DDAR is not specified as the transfer
destination in single address mode, this bit is ignored.
00: Destination address is fixed
01: Destination address is updated by adding the offset
10: Destination address is updated by adding 1, 2, or 4
according to the data access size
11: Destination address is updated by subtracting 1, 2,
or 4 according to the data access size
15
SARIE
0
R/W
Interrupt Enable for Source Address Extended Area
Overflow
Enables/disables an interrupt request for an extended
area overflow on the source address.
When an extended repeat area overflow on the source
address occurs while this bit is set to 1, the DTE bit in
DMDR is cleared to 0. At this time, the ESIF bit in
DMDR is set to 1 to indicate an interrupt by an extended
repeat area overflow on the source address is
requested.
When block transfer mode is used with the extended
repeat area function, an interrupt is requested after
completion of a 1-block size transfer. When setting the
DTE bit in DMDR of the channel for which a transfer has
been stopped to 1, the transfer is resumed from the
state when the transfer is stopped.
When the extended repeat area is not specified, this bit
is ignored.
0: Disables an interrupt request for an extended area
overflow on the source address
1: Enables an interrupt request for an extended area
overflow on the source address
14, 13
⎯
All 0
R
Reserved
These bits are always read as 0 and cannot be
modified.
Rev. 2.00 Oct. 21, 2009 Page 392 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
Description
12
SARA4
0
R/W
Source Address Extended Repeat Area
11
SARA3
0
R/W
10
SARA2
0
R/W
9
SARA1
0
R/W
8
SARA0
0
R/W
Specify the extended repeat area on the source address
(DSAR). With the extended repeat area, the specified
lower address bits are updated and the remaining upper
address bits are fixed. The extended repeat area size is
specified from four bytes to 128 Mbytes in units of byte
and a power of 2.
When the lower address is overflowed from the
extended repeat area by address update, the address
becomes the start address and the end address of the
area for address addition and subtraction, respectively.
When an overflow in the extended repeat area occurs
with the SARIE bit set to 1, an interrupt can be
requested. Table 10.3 shows the settings and areas of
the extended repeat area.
7
DARIE
0
R/W
Destination Address Extended Repeat Area Overflow
Interrupt Enable
Enables/disables an interrupt request for an extended
area overflow on the destination address.
When an extended repeat area overflow on the
destination address occurs while this bit is set to 1, the
DTE bit in DMDR is cleared to 0. At this time, the ESIF
bit in DMDR is set to 1 to indicate an interrupt by an
extended repeat area overflow on the destination
address is requested.
When block transfer mode is used with the extended
repeat area function, an interrupt is requested after
completion of a 1-block size transfer. When setting the
DTE bit in DMDR of the channel for which the transfer
has been stopped to 1, the transfer is resumed from the
state when the transfer is stopped.
When the extended repeat area is not specified, this bit
is ignored.
0: Disables an interrupt request for an extended area
overflow on the destination address
1: Enables an interrupt request for an extended area
overflow on the destination address
6, 5
⎯
All 0
R
Reserved
These bits are always read as 0 and cannot be
modified.
Rev. 2.00 Oct. 21, 2009 Page 393 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Bit
Bit Name
Initial
Value
R/W
Description
4
DARA4
0
R/W
Destination Address Extended Repeat Area
3
DARA3
0
R/W
2
DARA2
0
R/W
1
DARA1
0
R/W
0
DARA0
0
R/W
Specify the extended repeat area on the destination
address (DDAR). With the extended repeat area, the
specified lower address bits are updated and the
remaining upper address bits are fixed. The extended
repeat area size is specified from four bytes to 128
Mbytes in units of byte and a power of 2.
When the lower address is overflowed from the
extended repeat area by address update, the address
becomes the start address and the end address of the
area for address addition and subtraction, respectively.
When an overflow in the extended repeat area occurs
with the DARIE bit set to 1, an interrupt can be
requested. Table 10.3 shows the settings and areas of
the extended repeat area.
Rev. 2.00 Oct. 21, 2009 Page 394 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Table 10.3 Settings and Areas of Extended Repeat Area
SARA4 to
SARA0 or
DARA4 to
DARA0
Extended Repeat Area
00000
Not specified
00001
2 bytes specified as extended repeat area by the lower 1 bit of the address
00010
4 bytes specified as extended repeat area by the lower 2 bits of the address
00011
8 bytes specified as extended repeat area by the lower 3 bits of the address
00100
16 bytes specified as extended repeat area by the lower 4 bits of the address
00101
32 bytes specified as extended repeat area by the lower 5 bits of the address
00110
64 bytes specified as extended repeat area by the lower 6 bits of the address
00111
128 bytes specified as extended repeat area by the lower 7 bits of the address
01000
256 bytes specified as extended repeat area by the lower 8 bits of the address
01001
512 bytes specified as extended repeat area by the lower 9 bits of the address
01010
1 Kbyte specified as extended repeat area by the lower 10 bits of the address
01011
2 Kbytes specified as extended repeat area by the lower 11 bits of the address
01100
4 Kbytes specified as extended repeat area by the lower 12 bits of the address
01101
8 Kbytes specified as extended repeat area by the lower 13 bits of the address
01110
16 Kbytes specified as extended repeat area by the lower 14 bits of the address
01111
32 Kbytes specified as extended repeat area by the lower 15 bits of the address
10000
64 Kbytes specified as extended repeat area by the lower 16 bits of the address
10001
128 Kbytes specified as extended repeat area by the lower 17 bits of the address
10010
256 Kbytes specified as extended repeat area by the lower 18 bits of the address
10011
512 Kbytes specified as extended repeat area by the lower 19 bits of the address
10100
1 Mbyte specified as extended repeat area by the lower 20 bits of the address
10101
2 Mbytes specified as extended repeat area by the lower 21 bits of the address
10110
4 Mbytes specified as extended repeat area by the lower 22 bits of the address
10111
8 Mbytes specified as extended repeat area by the lower 23 bits of the address
11000
16 Mbytes specified as extended repeat area by the lower 24 bits of the address
11001
32 Mbytes specified as extended repeat area by the lower 25 bits of the address
11010
64 Mbytes specified as extended repeat area by the lower 26 bits of the address
11011
128 Mbytes specified as extended repeat area by the lower 27 bits of the address
111××
Setting prohibited
[Legend]
×: Don't care
Rev. 2.00 Oct. 21, 2009 Page 395 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.3.8
DMA Module Request Select Register (DMRSR)
DMRSR is an 8-bit readable/writable register that specifies the on-chip module interrupt source.
The vector number of the interrupt source is specified in eight bits. However, 0 is regarded as no
interrupt source. For the vector numbers of the interrupt sources, refer to table 10.5.
Bit
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
Initial Value
R/W
Rev. 2.00 Oct. 21, 2009 Page 396 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.4
Transfer Modes
Table 10.4 shows the DMAC transfer modes. The transfer modes can be specified to the
individual channels.
Table 10.4 Transfer Modes
Address Register
Address
Mode
Transfer mode
Dual
address
•
Normal transfer
•
Repeat transfer
•
Activation Source
Common Function
Source
Destination
•
•
DSAR
DDAR
On-chip module
interrupt
Total transfer
size: 1 to 4
Gbytes or not
specified
•
Offset addition
External request
•
Extended repeat
area function
DSAR/
DACK
DACK/
DDAR
Block transfer
Repeat or block size •
= 1 to 65,536 bytes,
1 to 65,536 words, or •
1 to 65,536
longwords
Single
address
Auto request
(activated by
CPU)
•
Instead of specifying the source or destination address
registers, data is directly transferred from/to the external
device using the DACK pin
•
The same settings as above are available other than address
register setting (e.g., above transfer modes can be specified)
•
One transfer can be performed in one bus cycle (the types of
transfer modes are the same as those of dual address modes)
When the auto request setting is selected as the activation source, the cycle stealing or burst access
can be selected. When the total transfer size is not specified (DTCR = H'00000000), the transfer
counter is stopped and the transfer is continued without the limitation of the transfer count.
Rev. 2.00 Oct. 21, 2009 Page 397 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.5
Operations
10.5.1
Address Modes
(1)
Dual Address Mode
In dual address mode, the transfer source address is specified in DSAR and the transfer destination
address is specified in DDAR. A transfer at a time is performed in two bus cycles (when the data
bus width is less than the data access size or the access address is not aligned with the boundary of
the data access size, the number of bus cycles are needed more than two because one bus cycle is
divided into multiple bus cycles).
In the first bus cycle, data at the transfer source address is read and in the next cycle, the read data
is written to the transfer destination address.
The read and write cycles are not separated. Other bus cycles (bus cycle by other bus masters,
refresh cycle, and external bus release cycle) are not generated between read and write cycles.
The TEND signal output is enabled or disabled by the TENDE bit in DMDR. The TEND signal is
output in two bus cycles. When an idle cycle is inserted before the bus cycle, the TEND signal is
also output in the idle cycle. The DACK signal is not output.
Figure 10.2 shows an example of the signal timing in dual address mode and figure 10.3 shows the
operation in dual address mode.
DMA read
cycle
DMA write
cycle
DSAR
DDAR
Bφ
Address bus
RD
WR
TEND
Figure 10.2 Example of Signal Timing in Dual Address Mode
Rev. 2.00 Oct. 21, 2009 Page 398 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Transfer
Address TA
Address TB
Address update setting is as follows:
Source address increment
Fixed destination address
Address BA
Figure 10.3 Operations in Dual Address Mode
(2)
Single Address Mode
In single address mode, data between an external device and an external memory is directly
transferred using the DACK pin instead of DSAR or DDAR. A transfer at a time is performed in
one bus cycle. In this mode, the data bus width must be the same as the data access size. For
details on the data bus width, see section 9, Bus Controller (BSC).
The DMAC accesses an external device as the transfer source or destination by outputting the
strobe signal (DACK) to the external device with DACK and accesses the other transfer target by
outputting the address. Accordingly, the DMA transfer is performed in one bus cycle. Figure 10.4
shows an example of a transfer between an external memory and an external device with the
DACK pin. In this example, the external device outputs data on the data bus and the data is written
to the external memory in the same bus cycle.
The transfer direction is decided by the DIRS bit in DACR which specifies an external device with
the DACK pin as the transfer source or destination. When DIRS = 0, data is transferred from an
external memory (DSAR) to an external device with the DACK pin. When DIRS = 1, data is
transferred from an external device with the DACK pin to an external memory (DDAR). The
settings of registers which are not used as the transfer source or destination are ignored.
The DACK signal output is enabled in single address mode by the DACKE bit in DMDR. The
DACK signal is low active.
The TEND signal output is enabled or disabled by the TENDE bit in DMDR. The TEND signal is
output in one bus cycle. When an idle cycle is inserted before the bus cycle, the TEND signal is
also output in the idle cycle.
Rev. 2.00 Oct. 21, 2009 Page 399 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Figure 10.5 shows an example of timing charts in single address mode and figure10.6 shows an
example of operation in single address mode.
External
address
bus
External
data
bus
LSI
External
memory
DMAC
Data flow
External device
with DACK
DACK
DREQ
Figure 10.4 Data Flow in Single Address Mode
Rev. 2.00 Oct. 21, 2009 Page 400 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Transfer from external memory to external device with DACK
DMA cycle
Bφ
Address bus
Address for external memory space
DSAR
RD
RD signal for external memory space
WR
High
DACK
Data output by external memory
Data bus
TEND
Transfer from external device with DACK to external memory
DMA cycle
Bφ
Address bus
RD
Address for external memory space
DDAR
High
WR
WR signal for external memory space
DACK
Data output by external device with DACK
Data bus
TEND
Figure 10.5 Example of Signal Timing in Single Address Mode
Address T
DACK
Transfer
Address B
Figure 10.6 Operations in Single Address Mode
Rev. 2.00 Oct. 21, 2009 Page 401 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.5.2
(1)
Transfer Modes
Normal Transfer Mode
In normal transfer mode, one data access size of data is transferred at a single transfer request. Up
to 4 Gbytes can be specified as a total transfer size by DTCR. DBSR is ignored in normal transfer
mode.
The TEND signal is output only in the last DMA transfer.
Figure 10.7 shows an example of the signal timing in normal transfer mode and figure 10.8 shows
the operation in normal transfer mode.
Auto request transfer in dual address mode:
Bus cycle
DMA transfer
cycle
Last DMA
transfer cycle
Read
Read
Write
Write
TEND
External request transfer in single address mode:
DREQ
Bus cycle
DMA
DMA
DACK
Figure 10.7 Example of Signal Timing in Normal Transfer Mode
Transfer
Address TA
Address TB
Total transfer
size (DTCR)
Address BA
Address BB
Figure 10.8 Operations in Normal Transfer Mode
Rev. 2.00 Oct. 21, 2009 Page 402 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(2)
Repeat Transfer Mode
In repeat transfer mode, one data access size of data is transferred at a single transfer request. Up
to 4 Gbytes can be specified as a total transfer size by DTCR. The repeat size can be specified in
DBSR up to 65536 × data access size.
The repeat area can be specified for the source or destination address side by bits ARS1 and ARS0
in DACR. The address specified as the repeat area returns to the transfer start address when the
repeat size of transfers is completed. This operation is repeated until the total transfer size
specified in DTCR is completed. When H'00000000 is specified in DTCR, it is regarded as the
free running mode and repeat transfer is continued until the DTE bit in DMDR is cleared to 0.
In addition, a DMA transfer can be stopped and a repeat size end interrupt can be requested to the
CPU or DTC when the repeat size of transfers is completed. When the next transfer is requested
after completion of a 1-repeat size data transfer while the RPTIE bit is set to 1, the DTE bit in
DMDR is cleared to 0 and the ESIF bit in DMDR is set to 1 to complete the transfer. At this time,
an interrupt is requested to the CPU or DTC when the ESIE bit in DMDR is set to 1.
The timing of the TEND signals is the same as in normal transfer mode.
Figure 10.9 shows the operation in repeat transfer mode while dual address mode is set.
When the repeat area is specified as neither source nor destination address side, the operation is
the same as the normal transfer mode operation shown in figure 10.8. In this case, a repeat size
end interrupt can also be requested to the CPU when the repeat size of transfers is completed.
Rev. 2.00 Oct. 21, 2009 Page 403 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Transfer
Address TA
Address TB
Repeat size =
BKSZH ×
data access size
Total transfer
size (DTCR)
Address BA
Operation when the repeat area is specified
to the source side
Address BB
Figure 10.9 Operations in Repeat Transfer Mode
(3)
Block Transfer Mode
In block transfer mode, one block size of data is transferred at a single transfer request. Up to 4
Gbytes can be specified as total transfer size by DTCR. The block size can be specified in DBSR
up to 64K × data access size.
While one block of data is being transferred, transfer requests from other channels are suspended.
When the transfer is completed, the bus is released to the other bus master.
The block area can be specified for the source or destination address side by bits ARS1 and ARS0
in DACR. The address specified as the block area returns to the transfer start address when the
block size of data is completed. When the block area is specified as neither source nor destination
address side, the operation continues without returning the address to the transfer start address. A
repeat size end interrupt can be requested.
The TEND signal is output every time 1-block data is transferred in the last DMA transfer cycle.
When an interrupt request by an extended repeat area overflow is used in block transfer mode,
settings should be selected carefully. For details, see section 10.5.5, Extended Repeat Area
Function.
Rev. 2.00 Oct. 21, 2009 Page 404 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Figure 10.10 shows an example of the DMA transfer timing in block transfer mode. The transfer
conditions are as follows:
• Address mode: single address mode
• Data access size: byte
• 1-block size: three bytes
The block transfer mode operations in single address mode and in dual address mode are shown in
figures 10.11 and 10.12, respectively.
DREQ
Transfer cycles for one block
Bus cycle
CPU
CPU
DMAC
DMAC
DMAC
CPU
No CPU cycle generated
TEND
Figure 10.10 Operations in Block Transfer Mode
Address T
Transfer
Block
BKSZH ×
data access size
DACK
Address B
Figure 10.11 Operation in Single Address Mode in Block Transfer Mode
(Block Area Specified)
Rev. 2.00 Oct. 21, 2009 Page 405 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Address TB
Address TA
Transfer
First block
First block
BKSZH ×
data access size
Second block
Second block
Total transfer
size (DTCR)
Nth block
Nth block
Address BB
Address BA
Figure 10.12 Operation in Dual Address Mode in Block Transfer Mode
(Block Area Not Specified)
Rev. 2.00 Oct. 21, 2009 Page 406 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.5.3
Activation Sources
The DMAC is activated by an auto request, an on-chip module interrupt, and an external request.
The activation source is specified by bits DTF1 and DTF0 in DMDR.
(1)
Activation by Auto Request
The auto request activation is used when a transfer request from an external device or an on-chip
peripheral module is not generated such as a transfer between memory and memory or between
memory and an on-chip peripheral module which does not request a transfer. A transfer request is
automatically generated inside the DMAC. In auto request activation, setting the DTE bit in
DMDR starts a transfer. The bus mode can be selected from cycle stealing and burst modes.
(2)
Activation by On-Chip Module Interrupt
An interrupt request from an on-chip peripheral module (on-chip peripheral module interrupt) is
used as a transfer request. When a DMA transfer is enabled (DTE = 1), the DMA transfer is
started by an on-chip module interrupt.
The activation source of the on-chip module interrupt is selected by the DMA module request
select register (DMRSR). The activation sources are specified to the individual channels. Table
10.5 is a list of on-chip module interrupts for the DMAC. The interrupt request selected as the
activation source can generate an interrupt request simultaneously to the CPU or DTC. For details,
refer to section 7, Interrupt Controller.
The DMAC receives interrupt requests by on-chip peripheral modules independent of the interrupt
controller. Therefore, the DMAC is not affected by priority given in the interrupt controller.
When the DMAC is activated while DTA = 1, the interrupt request flag is automatically cleared by
a DMA transfer. If multiple channels use a single transfer request as an activation source, when
the channel having priority is activated, the interrupt request flag is cleared. In this case, other
channels may not be activated because the transfer request is not held in the DMAC.
When the DMAC is activated while DTA = 0, the interrupt request flag is not cleared by the
DMAC and should be cleared by the CPU or DTC transfer.
When an activation source is selected while DTE = 0, the activation source does not request a
transfer to the DMAC. It requests an interrupt to the CPU or DTC.
In addition, make sure that an interrupt request flag as an on-chip module interrupt source is
cleared to 0 before writing 1 to the DTE bit.
Rev. 2.00 Oct. 21, 2009 Page 407 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Table 10.5 List of On-chip module interrupts to DMAC
On-Chip Module Interrupt Source
On-Chip
Module
DMRSR
(Vector
Number)
ADI0 (conversion end interrupt for A/D_0 converter unit 0)
A/D_0
86
TGI0A (TGI0A input capture/compare match)
TPU_0
88
TGI1A (TGI1A input capture/compare match)
TPU_1
93
TGI2A (TGI2A input capture/compare match)
TPU_2
97
TGI3A (TGI3A input capture/compare match)
TPU_3
101
TGI4A (TGI4A input capture/compare match)
TPU_4
106
TGI5A (TGI5A input capture/compare match)
TPU_5
110
RXI0 (receive data full interrupt for SCI channel 0)
SCI_0
145
TXI0 (transmit data empty interrupt for SCI channel 0)
SCI_0
146
RXI1 (receive data full interrupt for SCI channel 1)
SCI_1
149
TXI1 (transmit data empty interrupt for SCI channel 1)
SCI_1
150
RXI2 (receive data full interrupt for SCI channel 2)
SCI_2
153
TXI2 (transmit data empty interrupt for SCI channel 2)
SCI_2
154
RXI4 (receive data full interrupt for SCI channel 4)
SCI_4
161
TXI4 (transmit data empty interrupt for SCI channel 4)
SCI_4
162
TGI6A (TGI6A input capture/compare match)
TPU_6
164
TGI7A (TGI7A input capture/compare match)
TPU_7
169
TGI8A (TGI8A input capture/compare match)
TPU_8
173
TGI9A (TGI9A input capture/compare match)
TPU_9
177
TGI10A (TGI10A input capture/compare match)
TPU_10
182
TGI11A (TGI11A input capture/compare match)
TPU_11
188
RXI5 (receive data full interrupt for SCI channel 5)
SCI_5
220
TXI5 (transmit data empty interrupt for SCI channel 5)
SCI_5
221
RXI6 (receive data full interrupt for SCI channel 6)
SCI_6
224
TXI6 (transmit data empty interrupt for SCI channel 6)
SCI_6
225
USBINTN0 (EP1FIFO full interrupt)
USB
232
USBINTN1 (EP2FIFO empty interrupt)
USB
233
ADI1 (conversion end interrupt for A/D converter unit 1)
A/D_1
237
Rev. 2.00 Oct. 21, 2009 Page 408 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(3)
Activation by External Request
A transfer is started by a transfer request signal (DREQ) from an external device. When a DMA
transfer is enabled (DTE = 1), the DMA transfer is started by the DREQ assertion. When a DMA
transfer between on-chip peripheral modules is performed, select an activation source from the
auto request and on-chip module interrupt (the external request cannot be used).
A transfer request signal is input to the DREQ pin. The DREQ signal is detected on the falling
edge or low level. Whether the falling edge or low level detection is used is selected by the
DREQS bit in DMDR.
When an external request is selected as an activation source, clear the DDR bit to 0 and set the
ICR bit to 1 for the corresponding pin. For details, see section 13, I/O Ports.
10.5.4
Bus Access Modes
There are two types of bus access modes: cycle stealing and burst.
When an activation source is the auto request, the cycle stealing or burst mode is selected by bit
DTF0 in DMDR. When an activation source is the on-chip module interrupt or external request,
the cycle stealing mode is selected.
(1)
Cycle Stealing Mode
In cycle stealing mode, the DMAC releases the bus every time one unit of transfers (byte, word,
longword, or 1-block size) is completed. After that, when a transfer is requested, the DMAC
obtains the bus to transfer 1-unit data and then releases the bus on completion of the transfer. This
operation is continued until the transfer end condition is satisfied.
When a transfer is requested to another channel during a DMA transfer, the DMAC releases the
bus and then transfers data for the requested channel. For details on operations when a transfer is
requested to multiple channels, see section 10.5.8, Priority of Channels.
Rev. 2.00 Oct. 21, 2009 Page 409 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Figure 10.13 shows an example of timing in cycle stealing mode. The transfer conditions are as
follows:
• Address mode: Single address mode
• Sampling method of the DREQ signal: Low level detection
DREQ
Bus cycle
CPU
CPU
DMAC
CPU
DMAC
CPU
Bus released temporarily for the CPU
Figure 10.13 Example of Timing in Cycle Stealing Mode
(2)
Burst Access Mode
In burst mode, once it takes the bus, the DMAC continues a transfer without releasing the bus until
the transfer end condition is satisfied. Even if a transfer is requested from another channel having
priority, the transfer is not stopped once it is started. The DMAC releases the bus in the next cycle
after the transfer for the channel in burst mode is completed. This is similarly to operation in cycle
stealing mode. However, setting the IBCCS bit in IBCR of the bus controller makes the DMAC
release the bus to pass the bus to another bus master.
In block transfer mode, the burst mode setting is ignored (operation is the same as that in burst
mode during one block of transfers). The DMAC is always operated in cycle stealing mode.
Clearing the DTE bit in DMDR stops a DMA transfer. A transfer requested before the DTE bit is
cleared to 0 by the DMAC is executed. When an interrupt by a transfer size error, a repeat size
end, or an extended repeat area overflow occurs, the DTE bit is cleared to 0 and the transfer ends.
Figure 10.14 shows an example of timing in burst mode.
Bus cycle
CPU
CPU
DMAC
DMAC
DMAC
CPU
No CPU cycle generated
Figure 10.14 Example of Timing in Burst Mode
Rev. 2.00 Oct. 21, 2009 Page 410 of 1454
REJ09B0498-0200
CPU
Section 10 DMA Controller (DMAC)
10.5.5
Extended Repeat Area Function
The source and destination address sides can be specified as the extended repeat area. The contents
of the address register repeat addresses within the area specified as the extended repeat area. For
example, to use a ring buffer as the transfer target, the contents of the address register should
return to the start address of the buffer every time the contents reach the end address of the buffer
(overflow on the ring buffer address). This operation can automatically be performed using the
extended repeat area function of the DMAC.
The extended repeat areas can be specified independently to the source address register (DSAR)
and destination address register (DDAR).
The extended repeat area on the source address is specified by bits SARA4 to SARA0 in DACR.
The extended repeat area on the destination address is specified by bits DARA4 to DARA0 in
DACR. The extended repeat area sizes for each side can be specified independently.
A DMA transfer is stopped and an interrupt by an extended repeat area overflow can be requested
to the CPU when the contents of the address register reach the end address of the extended repeat
area. When an overflow on the extended repeat area set in DSAR occurs while the SARIE bit in
DACR is set to 1, the ESIF bit in DMDR is set to 1 and the DTE bit in DMDR is cleared to 0 to
stop the transfer. At this time, if the ESIE bit in DMDR is set to 1, an interrupt by an extended
repeat area overflow is requested to the CPU. When the DARIE bit in DACR is set to 1, an
overflow on the extended repeat area set in DDAR occurs, meaning that the destination side is a
target. During the interrupt handling, setting the DTE bit in DMDR resumes the transfer.
Rev. 2.00 Oct. 21, 2009 Page 411 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Figure 10.15 shows an example of the extended repeat area operation.
...
When the area represented by the lower three bits of DSAR (eight bytes)
is specified as the extended repeat area (SARA4 to SARA0 = B'00011)
External memory
Area specified
by DSAR
H'23FFFE
H'23FFFF
H'240000
H'240000
H'240001
H'240001
H'240002
H'240002
H'240003
H'240003
H'240004
H'240004
H'240005
H'240005
H'240006
H'240006
H'240007
H'240007
H'240008
Repeat
An interrupt request by extended repeat area
overflow can be generated.
...
H'240009
Figure 10.15 Example of Extended Repeat Area Operation
When an interrupt by an extended repeat area overflow is used in block transfer mode, the
following should be taken into consideration.
When a transfer is stopped by an interrupt by an extended repeat area overflow, the address
register must be set so that the block size is a power of 2 or the block size boundary is aligned with
the extended repeat area boundary. When an overflow on the extended repeat area occurs during a
transfer of one block, the interrupt by the overflow is suspended and the transfer overruns.
Rev. 2.00 Oct. 21, 2009 Page 412 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Figure 10.16 shows examples when the extended repeat area function is used in block transfer
mode.
...
When the are represented by the lower three bits (eight bytes) of DSAR are specified as the extended
repeat area (SARA4 to SARA0 = 3) and the block size in block transfer mode is specified to 5 (bits 23
to 16 in DTCR = 5).
External memory Area specified
1st block
2nd block
by DSAR
transfer
transfer
H'23FFFE
H'23FFFF
H'240000
H'240000
H'240000
H'240000
H'240001
H'240001
H'240001
H'240001
H'240002
H'240002
H'240002
H'240003
H'240003
H'240003
H'240004
H'240004
H'240004
H'240005
H'240005
H'240005
H'240006
H'240006
H'240006
H'240007
H'240007
H'240007
H'240008
Block transfer
continued
...
H'240009
Interrupt
request
generated
Figure 10.16 Example of Extended Repeat Area Function in Block Transfer Mode
Rev. 2.00 Oct. 21, 2009 Page 413 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.5.6
Address Update Function using Offset
The source and destination addresses are updated by fixing, increment/decrement by 1, 2, or 4, or
offset addition. When the offset addition is selected, the offset specified by the offset register
(DOFR) is added to the address every time the DMAC transfers the data access size of data. This
function realizes a data transfer where addresses are allocated to separated areas.
Figure 10.17 shows the address update method.
External memory
External memory
±0
External memory
±1, 2, or 4
+ offset
Address not
updated
(a) Address fixed
Data access size
added to or subtracted
from address (addresses
are continuous)
(b) Increment or decrement
by 1, 2, or 4
Offset is added to address
(addresses are not
continuous)
(c) Offset addition
Figure 10.17 Address Update Method
In item (a), Address fixed, the transfer source or destination address is not updated indicating the
same address.
In item (b), Increment or decrement by 1, 2, or 4, the transfer source or destination address is
incremented or decremented by the value according to the data access size at each transfer. Byte,
word, or longword can be specified as the data access size. The value of 1 for byte, 2 for word, and
4 for longword is used for updating the address. This operation realizes the data transfer placed in
consecutive areas.
In item (c), Offset addition, the address update does not depend on the data access size. The offset
specified by DOFR is added to the address every time the DMAC transfers data of the data access
size.
Rev. 2.00 Oct. 21, 2009 Page 414 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
The address is calculated by the offset set in DOFR and the contents of DSAR and DDAR.
Although the DMAC calculates only addition, an offset subtraction can be realized by setting the
negative value in DOFR. In this case, the negative value must be 2's complement.
(1)
Basic Transfer Using Offset
Figure 10.18 shows a basic operation of a transfer using the offset addition.
Data 1
Address A1
Transfer
Offset
Data 2
Data 1
Data 2
Data 3
Data 4
Data 5
:
Address B1
Address B2 = Address B1 + 4
Address B3 = Address B2 + 4
Address B4 = Address B3 + 4
Address B5 = Address B4 + 4
Address A2
= Address A1 + Offset
:
:
:
Offset
Data 3
Address A3
= Address A2 + Offset
Offset
Data 4
Transfer source:
Offset addition
Transfer destination: Increment by 4 (longword)
Address A4
= Address A3 + Offset
Offset
Data 5
Address A5
= Address A4 + Offset
Figure 10.18 Operation of Offset Addition
In figure 10.18, the offset addition is selected as the transfer source address update and increment
or decrement by 1, 2, or 4 is selected as the transfer destination address. The address update means
that data at the address which is away from the previous transfer source address by the offset is
read from. The data read from the address away from the previous address is written to the
consecutive area in the destination side.
Rev. 2.00 Oct. 21, 2009 Page 415 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(2)
XY Conversion Using Offset
Figure 10.19 shows the XY conversion using the offset addition in repeat transfer mode.
Data 1
Data 2
Data 3
Data 4
Data 5
Data 6
Data 7
Data 8
1st transfer
Offset
Offset
Offset
Data 1
Data 5
Data 9
Data 13
Data 2
Data 6
Data 10
Data 14
Data 3
Data 7
Data 11
Data 15
Data 4
Data 8
Data 12
Data 16
Data 9
Data 10
Data 11
Data 12
Data 13
Data 14
Data 15
Data 16
1st transfer
2nd transfer
Transfer
3rd transfer
4th transfer
2nd transfer Transfer source 3rd transfer
addresses
changed
by CPU
Data 1
Data 1
Data 5
Data 5
Address
initialized Data 9
Data 9
Address
initialized Data 13
Data 13
Data 2
Data 2
Data 6
Data 6
Data 10
Data 10
Data 14
Data 14
Data 3
Data 3
Data 7
Data 7
Data 11
Data 11
Data 15
Data 15
Data 4
Data 4
Data 8
Data 8
Interrupt
request
Data 12
Data 12
Interrupt
generated
request
Data 16
Data 16
generated
Data 1
Data 2
Data 5
Data 9
Data 6
Data 10
Data 3
Data 7
Data 11
Data 4
Data 8
Data 12
Data 13
Data 14
Data 15
Data 16
Transfer
Transfer source
addresses
changed
by CPU
Interrupt
request
generated
Data 1
Data 2
Data 3
Data 4
Data 5
Data 6
Data 7
Data 8
Data 9
Data 10
Data 11
Data 12
Data 13
Data 14
Data 15
Data 16
1st transfer
2nd transfer
3rd transfer
4th transfer
Figure 10.19 XY Conversion Operation Using Offset Addition in Repeat Transfer Mode
In figure 10.19, the source address side is specified to the repeat area by DACR and the offset
addition is selected. The offset value is set to 4 × data access size (when the data access size is
longword, H'00000010 is set in DOFR, as an example). The repeat size is set to 4 × data access
size (when the data access size is longword, the repeat size is set to 4 × 4 = 16 bytes, as an
example). The increment or decrement by 1, 2, or 4 is specified as the transfer destination address.
A repeat size end interrupt is requested when the RPTIE bit in DACR is set to 1 and the repeat
size of transfers is completed.
Rev. 2.00 Oct. 21, 2009 Page 416 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
When a transfer starts, the transfer source address is added to the offset every time data is
transferred. The transfer data is written to the destination continuous addresses. When data 4 is
transferred meaning that the repeat size of transfers is completed, the transfer source address
returns to the transfer start address (address of data 1 on the transfer source) and a repeat size end
interrupt is requested. While this interrupt stops the transfer temporarily, the contents of DSAR are
written to the address of data 5 by the CPU (when the data access size is longword, write the data
1 address + 4). When the DTE bit in DMDR is set to 1, the transfer is resumed from the state when
the transfer is stopped. Accordingly, operations are repeated and the transfer source data is
transposed to the destination area (XY conversion).
Figure 10.20 shows a flowchart of the XY conversion.
Start
Set address and transfer count
Set repeat transfer mode
Enable repeat escape interrupt
Set DTE bit to 1
Receives transfer request
Transfers data
Decrements transfer count
and repeat size
No
Transfer count = 0?
No
Yes
Repeat size = 0?
Yes
Initializes transfer source address
Generates repeat size end
interrupt request
Set transfer source address + 4
(Longword transfer)
End
: User operation
: DMAC operation
Figure 10.20 XY Conversion Flowchart Using Offset Addition in Repeat Transfer Mode
Rev. 2.00 Oct. 21, 2009 Page 417 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(3)
Offset Subtraction
When setting the negative value in DOFR, the offset value must be 2's complement. The 2's
complement is obtained by the following formula.
2's complement of offset = 1 + ~offset (~: bit inversion)
Example:
2's complement of H'0001FFFF
= H'FFFE0000 + H'00000001
= H'FFFE0001
The value of 2's complement can be obtained by the NEG.L instruction.
10.5.7
Register during DMA Transfer
The DMAC registers are updated by a DMA transfer. The value to be updated differs according to
the other settings and transfer state. The registers to be updated are DSAR, DDAR, DTCR, bits
BKSZH and BKSZ in DBSR, and the DTE, ACT, ERRF, ESIF, and DTIF bits in DMDR.
(1)
DMA Source Address Register
When the transfer source address set in DSAR is accessed, the contents of DSAR are output and
then are updated to the next address.
The increment or decrement can be specified by bits SAT1 and SAT0 in DACR. When SAT1 and
SAT0 = B'00, the address is fixed. When SAT1 and SAT0 = B'01, the address is added with the
offset. When SAT1 and SAT0 = B'10, the address is incremented. When SAT1 and SAT0 = B'11,
the address is decremented. The size of increment or decrement depends on the data access size.
The data access size is specified by bits DTSZ1 and DTSZ0 in DMDR. When DTSZ1 and DTSZ0
= B'00, the data access size is byte and the address is incremented or decremented by 1. When
DTSZ1 and DTSZ0 = B'01, the data access size is word and the address is incremented or
decremented by 2. When DTSZ1 and DTSZ0 = B'10, the data access size is longword and the
address is incremented or decremented by 4. Even if the access data size of the source address is
word or longword, when the source address is not aligned with the word or longword boundary,
the read bus cycle is divided into byte or word cycles. While data of one word or one longword is
being read, the size of increment or decrement is changing according to the actual data access size,
for example, +1 or +2 for byte or word data. After one word or one longword of data is read, the
address when the read cycle is started is incremented or decremented by the value according to
bits SAT1 and SAT0.
Rev. 2.00 Oct. 21, 2009 Page 418 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
In block or repeat transfer mode, when the block or repeat size of data transfers is completed while
the block or repeat area is specified to the source address side, the source address returns to the
transfer start address and is not affected by the address update.
When the extended repeat area is specified to the source address side, operation follows the
setting. The upper address bits are fixed and is not affected by the address update.
While data is being transferred, DSAR must be accessed in longwords. If the upper word and
lower word are read separately, incorrect data may be read from since the contents of DSAR
during the transfer may be updated regardless of the access by the CPU. Moreover, DSAR for the
channel being transferred must not be written to.
(2)
DMA Destination Address Register
When the transfer destination address set in DDAR is accessed, the contents of DDAR are output
and then are updated to the next address.
The increment or decrement can be specified by bits DAT1 and DAT0 in DACR. When DAT1
and DAT0 = B'00, the address is fixed. When DAT1 and DAT0 = B'01, the address is added with
the offset. When DAT1 and DAT0 = B'10, the address is incremented. When DAT1 and DAT0 =
B'11, the address is decremented. The incrementing or decrementing size depends on the data
access size.
The data access size is specified by bits DTSZ1 and DTSZ0 in DMDR. When DTSZ1 and DTSZ0
= B'00, the data access size is byte and the address is incremented or decremented by 1. When
DTSZ1 and DTSZ0 = B'01, the data access size is word and the address is incremented or
decremented by 2. When DTSZ1 and DTSZ0 = B'10, the data access size is longword and the
address is incremented or decremented by 4. Even if the access data size of the destination address
is word or longword, when the destination address is not aligned with the word or longword
boundary, the write bus cycle is divided into byte and word cycles. While one word or one
longword of data is being written, the incrementing or decrementing size is changing according to
the actual data access size, for example, +1 or +2 for byte or word data. After the one word or one
longword of data is written, the address when the write cycle is started is incremented or
decremented by the value according to bits SAT1 and SAT0.
In block or repeat transfer mode, when the block or repeat size of data transfers is completed while
the block or repeat area is specified to the destination address side, the destination address returns
to the transfer start address and is not affected by the address update.
When the extended repeat area is specified to the destination address side, operation follows the
setting. The upper address bits are fixed and is not affected by the address update.
Rev. 2.00 Oct. 21, 2009 Page 419 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
While data is being transferred, DDAR must be accessed in longwords. If the upper word and
lower word are read separately, incorrect data may be read from since the contents of DDAR
during the transfer may be updated regardless of the access by the CPU. Moreover, DDAR for the
channel being transferred must not be written to.
(3)
DMA Transfer Count Register (DTCR)
A DMA transfer decrements the contents of DTCR by the transferred bytes. When byte data is
transferred, DTCR is decremented by 1. When word data is transferred, DTCR is decremented by
2. When longword data is transferred, DTCR is decremented by 4. However, when DTCR = 0, the
contents of DTCR are not changed since the number of transfers is not counted.
While data is being transferred, all the bits of DTCR may be changed. DTCR must be accessed in
longwords. If the upper word and lower word are read separately, incorrect data may be read from
since the contents of DTCR during the transfer may be updated regardless of the access by the
CPU. Moreover, DTCR for the channel being transferred must not be written to.
When a conflict occurs between the address update by DMA transfer and write access by the CPU,
the CPU has priority. When a conflict occurs between change from 1, 2, or 4 to 0 in DTCR and
write access by the CPU (other than 0), the CPU has priority in writing to DTCR. However, the
transfer is stopped.
(4)
DMA Block Size Register (DBSR)
DBSR is enabled in block or repeat transfer mode. Bits 31 to 16 in DBSR function as BKSZH and
bits 15 to 0 in DBSR function as BKSZ. The BKSZH bits (16 bits) store the block size and repeat
size and its value is not changed. The BKSZ bits (16 bits) function as a counter for the block size
and repeat size and its value is decremented every transfer by 1. When the BKSZ value is to
change from 1 to 0 by a DMA transfer, 0 is not stored but the BKSZH value is loaded into the
BKSZ bits.
Since the upper 16 bits of DBSR are not updated, DBSR can be accessed in words.
DBSR for the channel being transferred must not be written to.
Rev. 2.00 Oct. 21, 2009 Page 420 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(5)
DTE Bit in DMDR
Although the DTE bit in DMDR enables or disables data transfer by the CPU write access, it is
automatically cleared to 0 according to the DMA transfer state by the DMAC.
The conditions for clearing the DTE bit by the DMAC are as follows:
•
•
•
•
•
•
•
•
•
When the total size of transfers is completed
When a transfer is completed by a transfer size error interrupt
When a transfer is completed by a repeat size end interrupt
When a transfer is completed by an extended repeat area overflow interrupt
When a transfer is stopped by an NMI interrupt
When a transfer is stopped by and address error
Reset state
Hardware standby mode
When a transfer is stopped by writing 0 to the DTE bit
Writing to the registers for the channels when the corresponding DTE bit is set to 1 is prohibited
(except for the DTE bit). When changing the register settings after writing 0 to the DTE bit,
confirm that the DTE bit has been cleared to 0.
Figure 10.21 show the procedure for changing the register settings for the channel being
transferred.
Changing register settings
of channel during operation
[1] Write 0 to the DTE bit in DMDR.
[2] Read the DTE bit.
Write 0 to DTE bit
[1]
Read DTE bit
[2]
[3] Confirm that DTE = 0. DTE = 1
indicates that DMA is transferring.
[4] Write the desired values to the
registers.
[3]
DTE = 0?
No
Yes
Change register settings
[4]
End of changing
register settings
Figure 10.21 Procedure for Changing Register Setting For Channel being Transferred
Rev. 2.00 Oct. 21, 2009 Page 421 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(6)
ACT Bit in DMDR
The ACT bit in DMDR indicates whether the DMAC is in the idle or active state. When DTE = 0
or DTE = 1 and the DMAC is waiting for a transfer request, the ACT bit is 0. Otherwise (the
DMAC is in the active state), the ACT bit is 1. When individual transfers are stopped by writing 0
and the transfer is not completed, the ACT bit retains 1.
In block transfer mode, even if individual transfers are stopped by writing 0 to the DTE bit, the 1block size of transfers is not stopped. The ACT bit retains 1 from writing 0 to the DTE bit to
completion of a 1-block size transfer.
In burst mode, up to three times of DMA transfer are performed from the cycle in which the DTE
bit is written to 0. The ACT bit retains 1 from writing 0 to the DTE bit to completion of DMA
transfer.
(7)
ERRF Bit in DMDR
When an address error or an NMI interrupt occur, the DMAC clears the DTE bits for all the
channels to stop a transfer. In addition, it sets the ERRF bit in DMDR_0 to 1 to indicate that an
address error or an NMI interrupt has occurred regardless of whether or not the DMAC is in
operation.
However, when the DMAC is in the module stop state, the ERRF bit is not set to 1 for address
errors or the NMI.
(8)
ESIF Bit in DMDR
When an interrupt by a transfer size error, a repeat size end, or an extended repeat area overflow is
requested, the ESIF bit in DMDR is set to 1. When both the ESIF and ESIE bits are set to 1, a
transfer escape interrupt is requested to the CPU or DTC.
The ESIF bit is set to 1 when the ACT bit in DMDR is cleared to 0 to stop a transfer after the bus
cycle of the interrupt source is completed.
The ESIF bit is automatically cleared to 0 and a transfer request is cleared if the transfer is
resumed by setting the DTE bit to 1 during interrupt handling.
For details on interrupts, see section 10.8, Interrupt Sources.
Rev. 2.00 Oct. 21, 2009 Page 422 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(9)
DTIF Bit in DMDR
The DTIF bit in DMDR is set to 1 after the total transfer size of transfers is completed. When both
the DTIF and DTIE bits in DMDR are set to 1, a transfer end interrupt by the transfer counter is
requested to the CPU or DTC.
The DTIF bit is set to 1 when the ACT bit in DMDR is cleared to 0 to stop a transfer after the bus
cycle is completed.
The DTIF bit is automatically cleared to 0 and a transfer request is cleared if the transfer is
resumed by setting the DTE bit to 1 during interrupt handling.
For details on interrupts, see section 10.8, Interrupt Sources.
10.5.8
Priority of Channels
The channels of the DMAC are given following priority levels: channel 0 > channel 1 >
channel 2 > channel3. Table 10.6 shows the priority levels among the DMAC channels.
Table 10.6 Priority among DMAC Channels
Channel
Priority
Channel 0
High
Channel 1
Channel 2
Channel 3
Low
The channel having highest priority other than the channel being transferred is selected when a
transfer is requested from other channels. The selected channel starts the transfer after the channel
being transferred releases the bus. At this time, when a bus master other than the DMAC requests
the bus, the cycle for the bus master is inserted.
In a burst transfer or a block transfer, channels are not switched.
Rev. 2.00 Oct. 21, 2009 Page 423 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Figure 10.22 shows a transfer example when multiple transfer requests from channels 0 to 2.
Channel 1 transfer
Channel 0 transfer
Channel 2 transfer
Bφ
Address bus
DMAC
operation
Channel 0
Wait
Channel 0
Channel 1
Channel 2
Bus
released
Channel 1
Channel 0
Channel 1
Bus
released
Channel 2
Request cleared
Request cleared
Request Selected
retained
Request Not
Request
retained selected retained
Selected
Request cleared
Figure 10.22 Example of Timing for Channel Priority
Rev. 2.00 Oct. 21, 2009 Page 424 of 1454
REJ09B0498-0200
Channel 2
Wait
Section 10 DMA Controller (DMAC)
10.5.9
DMA Basic Bus Cycle
Figure 10.23 shows an example of signal timing of a basic bus cycle. In figure 10.23, data is
transferred in words from the 16-bit 2-state access space to the 8-bit 3-state access space. When
the bus mastership is passed from the DMAC to the CPU, data is read from the source address and
it is written to the destination address. The bus is not released between the read and write cycles
by other bus requests. DMAC bus cycles follow the bus controller settings.
DMAC cycle (one word transfer)
CPU cycle
T1
T2
T1
T2
T3
T1
CPU cycle
T2
T3
Bφ
Source address
Destination address
Address bus
RD
LHWR
High
LLWR
Figure 10.23 Example of Bus Timing of DMA Transfer
Rev. 2.00 Oct. 21, 2009 Page 425 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.5.10 Bus Cycles in Dual Address Mode
(1)
Normal Transfer Mode (Cycle Stealing Mode)
In cycle stealing mode, the bus is released every time one transfer size of data (one byte, one
word, or one longword) is completed. One bus cycle or more by the CPU or DTC are executed in
the bus released cycles.
In figure 10.24, the TEND signal output is enabled and data is transferred in words from the
external 16-bit 2-state access space to the external 16-bit 2-state access space in normal transfer
mode by cycle stealing.
DMA read
cycle
DMA read
cycle
DMA write
cycle
DMA write
cycle
DMA read
cycle
DMA write
cycle
Bφ
Address bus
RD
LHWR, LLWR
TEND
Bus
released
Bus
released
Bus
released
Last transfer cycle
Bus
released
Figure 10.24 Example of Transfer in Normal Transfer Mode by Cycle Stealing
In figures 10.25 and 10.26, the TEND signal output is enabled and data is transferred in longwords
from the external 16-bit 2-state access space to the 16-bit 2-state access space in normal transfer
mode by cycle stealing.
In figure 10.25, the transfer source (DSAR) is not aligned with a longword boundary and the
transfer destination (DDAR) is aligned with a longword boundary.
In figure 10.26, the transfer source (DSAR) is aligned with a longword boundary and the transfer
destination (DDAR) is not aligned with a longword boundary.
Rev. 2.00 Oct. 21, 2009 Page 426 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
DMA byte
read cycle
DMA word
read cycle
DMA byte
read cycle
DMA word
write cycle
DMA word
write cycle
DMA byte
read cycle
DMA word
read cycle
DMA byte
read cycle
DMA word
write cycle
DMA word
write cycle
4m + 1
4m + 2
4m + 4
4n
4n +2
4m + 5
4m + 6
4m + 8
4n + 4
4n + 6
Bφ
Address
bus
RD
LHWR
LLWR
TEND
Last transfer cycle
Bus
released
Bus
released
Bus
released
m and n are integers.
Figure 10.25 Example of Transfer in Normal Transfer Mode by Cycle Stealing
(Transfer Source DSAR = Odd Address and Source Address Increment)
DMA word
read cycle
DMA word
read cycle
DMA byte
write cycle
DMA word
write cycle
DMA byte
write cycle
DMA word
read cycle
DMA word
read cycle
DMA byte
write cycle
DMA word
write cycle
DMA byte
write cycle
4m + 2
4n + 5
4n + 6
4n + 8
4m + 4
4m + 6
4n + 1
4n + 2
4n + 4
Bφ
Address
bus
4m
RD
LHWR
LLWR
TEND
Bus
released
Bus
released
Last transfer cycle
Bus
released
m and n are integers.
Figure 10.26 Example of Transfer in Normal Transfer Mode by Cycle Stealing
(Transfer Destination DDAR = Odd Address and Destination Address Decrement)
Rev. 2.00 Oct. 21, 2009 Page 427 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(2)
Normal Transfer Mode (Burst Mode)
In burst mode, one byte, one word, or one longword of data continues to be transferred until the
transfer end condition is satisfied.
When a burst transfer starts, a transfer request from a channel having priority is suspended until
the burst transfer is completed.
In figure 10.27, the TEND signal output is enabled and data is transferred in words from the
external 16-bit 2-state access space to the external 16-bit 2-state access space in normal transfer
mode by burst access.
DMA read cycle DMA write cycle
DMA read cycle
DMA write cycle DMA read cycle
DMA write cycle
Bφ
Address bus
RD
LHWR, LLWR
TEND
Last transfer cycle
Bus
released
Burst transfer
Figure 10.27 Example of Transfer in Normal Transfer Mode by Burst Access
Rev. 2.00 Oct. 21, 2009 Page 428 of 1454
REJ09B0498-0200
Bus
released
Section 10 DMA Controller (DMAC)
(3)
Block Transfer Mode
In block transfer mode, the bus is released every time a 1-block size of transfers at a single transfer
request is completed.
In figure 10.28, the TEND signal output is enabled and data is transferred in words from the
external 16-bit 2-state access space to the external 16-bit 2-state access space in block transfer
mode.
DMA read
cycle
DMA write
cycle
DMA read
cycle
DMA write
cycle
DMA read
cycle
DMA write
cycle
DMA read
cycle
DMA write
cycle
Bφ
Address bus
RD
LHWR, LLWR
TEND
Bus
released
Block transfer
Bus
released
Last block transfer cycle
Bus
released
Figure 10.28 Example of Transfer in Block Transfer Mode
Rev. 2.00 Oct. 21, 2009 Page 429 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(4)
Activation Timing by DREQ Falling Edge
Figure 10.29 shows an example of normal transfer mode activated by the DREQ signal falling
edge.
The DREQ signal is sampled every cycle from the next rising edge of the Bφ signal immediately
after the DTE bit write cycle.
When a low level of the DREQ signal is detected while a transfer request by the DREQ signal is
enabled, a transfer request is held in the DMAC. When the DMAC is activated, the transfer
request is cleared and starts detecting a high level of the DREQ signal for falling edge detection. If
a high level of the DREQ signal has been detected until completion of the DMA write cycle,
receiving the next transfer request resumes and then a low level of the DREQ signal is detected.
This operation is repeated until the transfer is completed.
DMA read
cycle
Bus released
DMA write
cycle
DMA read
cycle
Bus released
DMA write
cycle
Bus released
Bφ
DREQ
Address bus
DMA
operation
Transfer source Transfer destination
Read
Wait
Read
Wait
Duration of transfer
request disabled
Request
Channel
Write
Transfer source Transfer destination
Request
[2]
Wait
Duration of transfer
request disabled
Min. of 3 cycles
Min. of 3 cycles
[1]
Write
[3]
[4]
[5]
Transfer request enable resumed
[6]
[7]
Transfer request enable resumed
After DMA transfer request is enabled, a low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer
request is held.
[2][5] The DMAC is activated and the transfer request is cleared.
[3][6] A DMA cycle is started and sampling the DREQ signal at the rising edge of the Bφ signal is started to detect a high level of the
DREQ signal.
[4][7] When a high level of the DREQ signal has been detected, transfer request enable is resumed after completion of the write cycle.
(A low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer request is held. This is the same as [1].)
[1]
Figure 10.29 Example of Transfer in Normal Transfer Mode Activated
by DREQ Falling Edge
Rev. 2.00 Oct. 21, 2009 Page 430 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Figure 10.30 shows an example of block transfer mode activated by the DREQ signal falling edge.
The DREQ signal is sampled every cycle from the next rising edge of the Bφ signal immediately
after the DTE bit write cycle.
When a low level of the DREQ signal is detected while a transfer request by the DREQ signal is
enabled, a transfer request is held in the DMAC. When the DMAC is activated, the transfer
request is cleared and starts detecting a high level of the DREQ signal for falling edge detection. If
a high level of the DREQ signal has been detected until completion of the DMA write cycle,
receiving the next transfer request resumes and then a low level of the DREQ signal is detected.
This operation is repeated until the transfer is completed.
1-block transfer
1-block transfer
DMA read
cycle
Bus released
DMA write
cycle
DMA read
cycle
Bus released
DMA write
cycle
Bus released
Bφ
DREQ
Address bus
DMA
operation
Channel
Transfer source Transfer destination
Read
Wait
Write
Read
Wait
Duration of transfer
request disabled
Request
Transfer source Transfer destination
[2]
Wait
Duration of transfer
request disabled
Request
Min. of 3 cycles
Min. of 3 cycles
[1]
Write
[3]
[4]
[5]
[6]
Transfer request enable resumed
[7]
Transfer request enable resumed
After DMA transfer request is enabled, a low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer
request is held.
[2][5] The DMAC is activated and the transfer request is cleared.
[3][6] A DMA cycle is started and sampling the DREQ signal at the rising edge of the Bφ signal is started to detect a high level of the
DREQ signal.
[4][7] When a high level of the DREQ signal has been detected, transfer request enable is resumed after completion of the write cycle.
(A low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer request is held. This is the same as [1].)
[1]
Figure 10.30 Example of Transfer in Block Transfer Mode Activated
by DREQ Falling Edge
Rev. 2.00 Oct. 21, 2009 Page 431 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(5)
Activation Timing by DREQ Level
Figure 10.31 shows an example of normal transfer mode activated by the DREQ signal low level.
The DREQ signal is sampled every cycle from the next rising edge of the Bφ signal immediately
after the DTE bit write cycle.
When a low level of the DREQ signal is detected while a transfer request by the DREQ signal is
enabled, a transfer request is held in the DMAC. When the DMAC is activated, the transfer
request is cleared. Receiving the next transfer request resumes after completion of the write cycle
and then a low level of the DREQ signal is detected. This operation is repeated until the transfer is
completed.
Bus released
DMA read
cycle
DMA write
cycle
Transfer
source
Transfer
destination
DMA read
cycle
Bus released
DMA write
cycle
Bus released
Bφ
DREQ
Address bus
DMA
operation
Channel
Wait
Read
Write
Wait
Duration of transfer
request disabled
Request
Transfer
source
Read
Request
[2]
Write
Wait
Duration of transfer
request disabled
Min. of 3 cycles
Min. of 3 cycles
[1]
Transfer
destination
[3]
[4]
[5]
Transfer request enable resumed
[6]
[7]
Transfer request enable resumed
After DMA transfer request is enabled, a low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer
request is held.
[2][5] The DMAC is activated and the transfer request is cleared.
[3][6] A DMA cycle is started.
[4][7] Transfer request enable is resumed after completion of the write cycle.
(A low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer request is held. This is the same as [1].)
[1]
Figure 10.31 Example of Transfer in Normal Transfer Mode Activated
by DREQ Low Level
Rev. 2.00 Oct. 21, 2009 Page 432 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Figure 10.32 shows an example of block transfer mode activated by the DREQ signal low level.
The DREQ signal is sampled every cycle from the next rising edge of the Bφ signal immediately
after the DTE bit write cycle.
When a low level of the DREQ signal is detected while a transfer request by the DREQ signal is
enabled, a transfer request is held in the DMAC. When the DMAC is activated, the transfer
request is cleared. Receiving the next transfer request resumes after completion of the write cycle
and then a low level of the DREQ signal is detected. This operation is repeated until the transfer is
completed.
1-block transfer
1-block transfer
DMA read
cycle
Bus released
DMA write
cycle
DMA write
cycle
DMA read
cycle
Bus released
Bus released
Bφ
DREQ
Transfer
source
Address bus
DMA
operation
Channel
Wait
Read
Request
Transfer
destination
Transfer
source
Wait
Write
Read
Duration of transfer
request disabled
[1]
[2]
Write
Wait
Duration of transfer
request disabled
Request
Min. of 3 cycles
Transfer
destination
Min. of 3 cycles
[3]
[4]
[5]
[6]
Transfer request enable resumed
[7]
Transfer request enable resumed
After DMA transfer request is enabled, a low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer
request is held.
[2][5] The DMAC is activated and the transfer request is cleared.
[3][6] A DMA cycle is started.
[4][7] Transfer request enable is resumed after completion of the write cycle.
(A low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer request is held. This is the same as [1].)
[1]
Figure 10.32 Example of Transfer in Block Transfer Mode Activated
by DREQ Low Level
Rev. 2.00 Oct. 21, 2009 Page 433 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Activation Timing by DREQ Low Level with NRD = 1
(6)
When the NRD bit in DMDR is set to 1, the timing of receiving the next transfer request is
delayed for one cycle.
Figure 10.33 shows an example of normal transfer mode activated by the DREQ signal low level
with NRD = 1.
The DREQ signal is sampled every cycle from the next rising edge of the Bφ signal immediately
after the DTE bit write cycle.
When a low level of the DREQ signal is detected while a transfer request by the DREQ signal is
enabled, a transfer request is held in the DMAC. When the DMAC is activated, the transfer
request is cleared. Receiving the next transfer request resumes after completion of the write cycle
and then a low level of the DREQ signal is detected. This operation is repeated until the transfer is
completed.
DMA read
cycle
Bus released
DMA write
cycle
DMA read
cycle
Bus released
DMA write
cycle
Bus released
Bφ
DREQ
Transfer
source
Address bus
Channel
Request
Duration of transfer
request disabled
Transfer
destination
Transfer
source
Duration of transfer request
disabled which is extended
by NRD
Request
Min. of 3 cycles
[1]
[2]
Transfer
destination
Duration of transfer
request disabled
Duration of transfer request
disabled which is extended
by NRD
Min. of 3 cycles
[3]
[4]
[5]
Transfer request enable resumed
[6]
[7]
Transfer request enable resumed
After DMA transfer request is enabled, a low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer
request is held.
[2][5] The DMAC is activated and the transfer request is cleared.
[3][6] A DMA cycle is started.
[4][7] Transfer request enable is resumed one cycle after completion of the write cycle.
(A low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer request is held. This is the same as [1].)
[1]
Figure 10.33 Example of Transfer in Normal Transfer Mode Activated
by DREQ Low Level with NRD = 1
Rev. 2.00 Oct. 21, 2009 Page 434 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.5.11 Bus Cycles in Single Address Mode
(1)
Single Address Mode (Read and Cycle Stealing)
In single address mode, one byte, one word, or one longword of data is transferred at a single
transfer request and after the transfer the bus is released temporarily. One bus cycle or more by the
CPU or DTC are executed in the bus released cycles.
In figure 10.34, the TEND signal output is enabled and data is transferred in bytes from the
external 8-bit 2-state access space to the external device in single address mode (read).
DMA read
cycle
DMA read
cycle
DMA read
cycle
DMA read
cycle
Bφ
Address bus
RD
DACK
TEND
Bus
released
Bus
released
Bus
released
Bus
Last transfer Bus
released
released
cycle
Figure 10.34 Example of Transfer in Single Address Mode (Byte Read)
Rev. 2.00 Oct. 21, 2009 Page 435 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(2)
Single Address Mode (Write and Cycle Stealing)
In single address mode, data of one byte, one word, or one longword is transferred at a single
transfer request and after the transfer the bus is released temporarily. One bus cycle or more by the
CPU or DTC are executed in the bus released cycles.
In figure 10.35, the TEND signal output is enabled and data is transferred in bytes from the
external 8-bit 2-state access space to the external device in single address mode (write).
DMA write
cycle
DMA write
cycle
DMA write
cycle
DMA write
cycle
Bφ
Address bus
LLWR
DACK
TEND
Bus
released
Bus
released
Bus
released
Last transfer Bus
Bus
cycle released
released
Figure 10.35 Example of Transfer in Single Address Mode (Byte Write)
Rev. 2.00 Oct. 21, 2009 Page 436 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Activation Timing by DREQ Falling Edge
(3)
Figure 10.36 shows an example of single address mode activated by the DREQ signal falling edge.
The DREQ signal is sampled every cycle from the next rising edge of the Bφ signal immediately
after the DTE bit write cycle.
When a low level of the DREQ signal is detected while a transfer request by the DREQ signal is
enabled, a transfer request is held in the DMAC. When the DMAC is activated, the transfer
request is cleared and starts detecting a high level of the DREQ signal for falling edge detection. If
a high level of the DREQ signal has been detected until completion of the single cycle, receiving
the next transfer request resumes and then a low level of the DREQ signal is detected. This
operation is repeated until the transfer is completed.
Bus
released
DMA single
cycle
Bus
released
DMA single
cycle
Bus
released
Bφ
DREQ
Transfer source/
Transfer destination
Transfer source/
Transfer destination
Address bus
DACK
DMA
operation
Channel
Single
Wait
Request
Single
Wait
Duration of transfer
request disabled
[1]
[2]
Duration of transfer
request disabled
Request
Min. of 3 cycles
Wait
Min. of 3 cycles
[3]
[4]
Transfer request
enable resumed
[5]
[6]
[7]
Transfer request
enable resumed
After DMA transfer request is enabled, a low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer
request is held.
[2][5] The DMAC is activated and the transfer request is cleared.
[3][6] A DMA cycle is started and sampling the DREQ signal at the rising edge of the Bφ signal is started to detect a high level of the
DREQ signal.
[4][7] When a high level of the DREQ signal has been detected, transfer enable is resumed after completion of the write cycle.
(A low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer request is held. This is the same as [1].)
[1]
Figure 10.36 Example of Transfer in Single Address Mode Activated
by DREQ Falling Edge
Rev. 2.00 Oct. 21, 2009 Page 437 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Activation Timing by DREQ Low Level
(4)
Figure 10.37 shows an example of normal transfer mode activated by the DREQ signal low level.
The DREQ signal is sampled every cycle from the next rising edge of the Bφ signal immediately
after the DTE bit write cycle.
When a low level of the DREQ signal is detected while a transfer request by the DREQ signal is
enabled, a transfer request is held in the DMAC. When the DMAC is activated, the transfer
request is cleared. Receiving the next transfer request resumes after completion of the single cycle
and then a low level of the DREQ signal is detected. This operation is repeated until the transfer is
completed.
Bus
released
DMA single
cycle
Bus
released
DMA single
cycle
Bus
released
Bφ
DREQ
Transfer source/
Transfer destination
Address bus
Transfer source/
Transfer destination
DACK
DMA
Wait
operation
Single
Request
Channel
Single
Wait
Duration of transfer
request disabled
[1]
[2]
Duration of transfer
request disabled
Request
Min. of 3 cycles
Wait
Min. of 3 cycles
[3]
[4]
Transfer request
enable resumed
[5]
[6]
[7]
Transfer request
enable resumed
After DMA transfer request is enabled, a low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer
request is held.
[2][5] The DMAC is activated and the transfer request is cleared.
[3][6] A DMA cycle is started.
[4][7] Transfer request enable is resumed after completion of the single cycle.
(A low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer request is held. This is the same as [1].)
[1]
Figure 10.37 Example of Transfer in Single Address Mode Activated
by DREQ Low Level
Rev. 2.00 Oct. 21, 2009 Page 438 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Activation Timing by DREQ Low Level with NRD = 1
(5)
When the NRD bit in DMDR is set to 1, the timing of receiving the next transfer request is
delayed for one cycle.
Figure 10.38 shows an example of single address mode activated by the DREQ signal low level
with NRD = 1.
The DREQ signal is sampled every cycle from the next rising edge of the Bφ signal immediately
after the DTE bit write cycle.
When a low level of the DREQ signal is detected while a transfer request by the DREQ signal is
enabled, a transfer request is held in the DMAC. When the DMAC is activated, the transfer
request is cleared. Receiving the next transfer request resumes after one cycle of the transfer
request duration inserted by NRD = 1 on completion of the single cycle and then a low level of the
DREQ signal is detected. This operation is repeated until the transfer is completed.
DMA single
cycle
Bus
released
DMA single
cycle
Bus
released
Bus
released
Bφ
DREQ
Channel
Transfer source/
Transfer destination
Transfer source/
Transfer destination
Address bus
Request
Min. of 3 cycles
[1]
[2]
Duration of transfer request
disabled which is extended
by NRD
Duration of transfer
request disabled
Duration of transfer request
disabled which is extended
by NRD
Duration of transfer
Request
request disabled
Min. of 3 cycles
[3]
[4]
[5]
Transfer request
enable resumed
[6]
[7]
Transfer request
enable resumed
After DMA transfer request is enabled, a low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer
request is held.
[2][5] The DMAC is activated and the transfer request is cleared.
[3][6] A DMA cycle is started.
[4][7] Transfer request enable is resumed one cycle after completion of the single cycle.
(A low level of the DREQ signal is detected at the rising edge of the Bφ signal and a transfer request is held. This is the same as [1].)
[1]
Figure 10.38 Example of Transfer in Single Address Mode Activated
by DREQ Low Level with NRD = 1
Rev. 2.00 Oct. 21, 2009 Page 439 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.6
DMA Transfer End
Operations on completion of a transfer differ according to the transfer end condition. DMA
transfer completion is indicated that the DTE and ACT bits in DMDR are changed from 1 to 0.
(1)
Transfer End by DTCR Change from 1, 2, or 4, to 0
When DTCR is changed from 1, 2, or 4 to 0, a DMA transfer for the channel is completed. The
DTE bit in DMDR is cleared to 0 and the DTIF bit in DMDR is set to 1. At this time, when the
DTIE bit in DMDR is set to 1, a transfer end interrupt by the transfer counter is requested. When
the DTCR value is 0 before the transfer, the transfer is not stopped.
(2)
Transfer End by Transfer Size Error Interrupt
When the following conditions are satisfied while the TSEIE bit in DMDR is set to 1, a transfer
size error occurs and a DMA transfer is terminated. At this time, the DTE bit in DMDR is cleared
to 0 and the ESIF bit in DMDR is set to 1.
• In normal transfer mode and repeat transfer mode, when the next transfer is requested while a
transfer is disabled due to the DTCR value less than the data access size
• In block transfer mode, when the next transfer is requested while a transfer is disabled due to
the DTCR value less than the block size
When the TSEIE bit in DMDR is cleared to 0, data is transferred until the DTCR value reaches 0.
A transfer size error is not generated. Operation in each transfer mode is shown below.
• In normal transfer mode and repeat transfer mode, when the DTCR value is less than the data
access size, data is transferred in bytes
• In block transfer mode, when the DTCR value is less than the block size, the specified size of
data in DTCR is transferred instead of transferring the block size of data. The transfer is
performed in bytes.
Rev. 2.00 Oct. 21, 2009 Page 440 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(3)
Transfer End by Repeat Size End Interrupt
In repeat transfer mode, when the next transfer is requested after completion of a 1-repeat size data
transfer while the RPTIE bit in DACR is set to 1, a repeat size end interrupt is requested. When
the interrupt is requested to complete DMA transfer, the DTE bit in DMDR is cleared to 0 and the
ESIF bit in DMDR is set to 1. Under this condition, setting the DTE bit to 1 resumes the transfer.
In block transfer mode, when the next transfer is requested after completion of a 1-block size data
transfer, a repeat size end interrupt can be requested.
(4)
Transfer End by Interrupt on Extended Repeat Area Overflow
When an overflow on the extended repeat area occurs while the extended repeat area is specified
and the SARIE or DARIE bit in DACR is set to 1, an interrupt by an extended repeat area
overflow is requested. When the interrupt is requested, the DMA transfer is terminated, the DTE
bit in DMDR is cleared to 0, and the ESIF bit in DMDR is set to 1.
In dual address mode, even if an interrupt by an extended repeat area overflow occurs during a
read cycle, the following write cycle is performed.
In block transfer mode, even if an interrupt by an extended repeat area overflow occurs during a 1block transfer, the remaining data is transferred. The transfer is not terminated by an extended
repeat area overflow interrupt unless the current transfer is complete.
(5)
Transfer End by Clearing DTE Bit in DMDR
When the DTE bit in DMDR is cleared to 0 by the CPU, a transfer is completed after the current
DMA cycle and a DMA cycle in which the transfer request is accepted are completed.
In block transfer mode, a DMA transfer is completed after 1-block data is transferred.
Rev. 2.00 Oct. 21, 2009 Page 441 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
(6)
Transfer End by NMI Interrupt
When an NMI interrupt is requested, the DTE bits for all the channels are cleared to 0 and the
ERRF bit in DMDR_0 is set to 1. When an NMI interrupt is requested during a DMA transfer, the
transfer is forced to stop. To perform DMA transfer after an NMI interrupt is requested, clear the
ERRF bit to 0 and then set the DTE bits for the channels to 1.
The transfer end timings after an NMI interrupt is requested are shown below.
(a)
Normal Transfer Mode and Repeat Transfer Mode
In dual address mode, a DMA transfer is completed after completion of the write cycle for one
transfer unit.
In single address mode, a DMA transfer is completed after completion of the bus cycle for one
transfer unit.
(b)
Block Transfer Mode
A DMA transfer is forced to stop. Since a 1-block size of transfers is not completed, operation is
not guaranteed.
In dual address mode, the write cycle corresponding to the read cycle is performed. This is similar
in normal transfer mode.
(7)
Transfer End by Address Error
When an address error occurs, the DTE bits for all the channels are cleared to 0 and the ERRF bit
in DMDR_0 is set to 1. When an address error occurs during a DMA transfer, the transfer is
forced to stop. To perform a DMA transfer after an address error occurs, clear the ERRF bit to 0
and then set the DTE bits for the channels.
The transfer end timing after an address error is the same as that after an NMI interrupt.
(8)
Transfer End by Hardware Standby Mode or Reset
The DMAC is initialized by a reset and a transition to the hardware standby mode. A DMA
transfer is not guaranteed.
Rev. 2.00 Oct. 21, 2009 Page 442 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.7
Relationship among DMAC and Other Bus Masters
10.7.1
CPU Priority Control Function Over DMAC
The CPU priority control function over DMAC can be used according to the CPU priority control
register (CPUPCR) setting. For details, see section 7.7, CPU Priority Control Function Over DTC,
DMAC and EXDMAC.
The priority level of the DMAC is specified by bits DMAP2 to DMAP0 and can be specified for
each channel.
The priority level of the CPU is specified by bits CPUP2 to CPUP0. The value of bits CPUP2 to
CPUP0 is updated according to the exception handling priority.
If the CPU priority control is enabled by the CPUPCE bit in CPUPCR, when the CPU has priority
over the DMAC, a transfer request for the corresponding channel is masked and the transfer is not
activated. When another channel has priority over or the same as the CPU, a transfer request is
received regardless of the priority between channels and the transfer is activated.
The transfer request masked by the CPU priority control function is suspended. When the transfer
channel is given priority over the CPU by changing priority levels of the CPU or channel, the
transfer request is received and the transfer is resumed. Writing 0 to the DTE bit clears the
suspended transfer request.
When the CPUPCE bit is cleared to 0, it is regarded as the lowest priority.
Rev. 2.00 Oct. 21, 2009 Page 443 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.7.2
Bus Arbitration among DMAC and Other Bus Masters
When DMA transfer cycles are consecutively performed, bus cycles of other bus masters may be
inserted between the transfer cycles. The DMAC can release the bus temporarily to pass the bus to
other bus masters.
The consecutive DMA transfer cycles may not be divided according to the transfer mode settings
to achieve high-speed access.
The read and write cycles of a DMA transfer are not separated. Refreshing, EXDMAC cycle,
external bus release, and on-chip bus master (CPU or DTC) cycles are not inserted between the
read and write cycles of a DMA transfer.
In block transfer mode and an auto request transfer by burst access, bus cycles of the DMA
transfer are consecutively performed. For this duration, since the DMAC has priority over the
CPU and DTC, accesses to the external space is suspended (the IBCCS bit in the bus control
register 2 (BCR2) is cleared to 0).
When the bus is passed to another channel or an auto request transfer by cycle stealing, bus cycles
of the DMAC and on-chip bus master are performed alternatively.
When the arbitration function among the DMAC and on-chip bus masters is enabled by setting the
IBCCS bit in BCR2, the bus is used alternatively except the bus cycles which are not separated.
For details, see section 9, Bus Controller (BSC).
A conflict may occur between external space access of the refresh cycle and EXDMAC cycle, or
external bus release cycle. Even if a burst or block transfer is performed by the DMAC, the
transfer is stopped temporarily and a cycle of the refresh or EXDMAC or external bus release is
inserted by the BSC according to the external bus priority (when the CPU external access and the
DTC external access do not have priority over a DMAC transfer, the transfers are not operated
until the DMAC releases the bus).
In dual address mode, the DMAC releases the external bus after the external space write cycle.
Since the read and write cycles are not separated, the bus is not released.
An internal space (on-chip memory and internal I/O registers) access of the DMAC and the refresh
cycle, or EXDMAC cycle, or an external bus release cycle may be performed at the same time.
Rev. 2.00 Oct. 21, 2009 Page 444 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.8
Interrupt Sources
The DMAC interrupt sources are a transfer end interrupt by the transfer counter and a transfer
escape end interrupt which is generated when a transfer is terminated before the transfer counter
reaches 0. Table 10.7 shows interrupt sources and priority.
Table 10.7 Interrupt Sources and Priority
Abbr.
Interrupt Sources
Priority
DMTEND0
Transfer end interrupt by channel 0 transfer counter
High
DMTEND1
Transfer end interrupt by channel 1 transfer counter
DMTEND2
Transfer end interrupt by channel 2 transfer counter
DMTEND3
Transfer end interrupt by channel 3 transfer counter
DMEEND0
Interrupt by channel 0 transfer size error
Interrupt by channel 0 repeat size end
Interrupt by channel 0 extended repeat area overflow on source address
Interrupt by channel 0 extended repeat area overflow on destination address
DMEEND1
Interrupt by channel 1 transfer size error
Interrupt by channel 1 repeat size end
Interrupt by channel 1 extended repeat area overflow on source address
Interrupt by channel 1 extended repeat area overflow on destination address
DMEEND2
Interrupt by channel 2 transfer size error
Interrupt by channel 2 repeat size end
Interrupt by channel 2 extended repeat area overflow on source address
Interrupt by channel 2 extended repeat area overflow on destination address
DMEEND3
Interrupt by channel 3 transfer size error
Interrupt by channel 3 repeat size end
Interrupt by channel 3 extended repeat area overflow on source address
Interrupt by channel 3 extended repeat area overflow on destination address
Low
Each interrupt is enabled or disabled by the DTIE and ESIE bits in DMDR for the corresponding
channel. A DMTEND interrupt is generated by the combination of the DTIF and DTIE bits in
DMDR. A DMEEND interrupt is generated by the combination of the ESIF and ESIE bits in
DMDR. The DMEEND interrupt sources are not distinguished. The priority among channels is
decided by the interrupt controller and it is shown in table 10.7. For details, see section 7, Interrupt
Controller.
Rev. 2.00 Oct. 21, 2009 Page 445 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
Each interrupt source is specified by the interrupt enable bit in the register for the corresponding
channel. A transfer end interrupt by the transfer counter, a transfer size error interrupt, a repeat
size end interrupt, an interrupt by an extended repeat area overflow on the source address, and an
interrupt by an extended repeat area overflow on the destination address are enabled or disabled by
the DTIE bit in DMDR, the TSEIE bit in DMDR, the RPTIE bit in DACR, SARIE bit in DACR,
and the DARIE bit in DACR, respectively.
A transfer end interrupt by the transfer counter is generated when the DTIF bit in DMDR is set to
1. The DTIF bit is set to 1 when DTCR becomes 0 by a transfer while the DTIE bit in DMDR is
set to 1.
An interrupt other than the transfer end interrupt by the transfer counter is generated when the
ESIF bit in DMDR is set to 1. The ESIF bit is set to 1 when the conditions are satisfied by a
transfer while the enable bit is set to 1.
A transfer size error interrupt is generated when the next transfer cannot be performed because the
DTCR value is less than the data access size, meaning that the data access size of transfers cannot
be performed. In block transfer mode, the block size is compared with the DTCR value for
transfer error decision.
A repeat size end interrupt is generated when the next transfer is requested after completion of the
repeat size of transfers in repeat transfer mode. Even when the repeat area is not specified in the
address register, the transfer can be stopped periodically according to the repeat size. At this time,
when a transfer end interrupt by the transfer counter is generated, the ESIF bit is set to 1.
An interrupt by an extended repeat area overflow on the source and destination addresses is
generated when the address exceeds the extended repeat area (overflow). At this time, when a
transfer end interrupt by the transfer counter, the ESIF bit is set to 1.
Figure 10.39 is a block diagram of interrupts and interrupt flags. To clear an interrupt, clear the
DTIF or ESIF bit in DMDR to 0 in the interrupt handling routine or continue the transfer by
setting the DTE bit in DMDR after setting the register. Figure 10.40 shows procedure to resume
the transfer by clearing an interrupt.
Rev. 2.00 Oct. 21, 2009 Page 446 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
TSIE bit
DTIE bit
DMAC is activated in
transfer size error state
Transfer end
interrupt
DTIF bit
RPTIE bit
[Setting condition]
When DTCR becomes 0
and transfer ends
DMAC is activated
after BKSZ bits are
changed from 1 to 0
SARIE bit
ESIE bit
Extended repeat area
overflow occurs in
source address
Transfer escape
end interrupt
ESIF bit
DARIE bit
Setting condition is satisfied
Extended repeat area
overflow occurs in
destination address
Figure 10.39 Interrupt and Interrupt Sources
Transfer end interrupt
handling routine
Transfer resumed after
interrupt handling routine
Consecutive transfer
processing
Registers are specified
[1]
DTIF and ESIF bits are
cleared to 0
[4]
DTE bit is set to 1
[2]
Interrupt handling routine
ends
[5]
Interrupt handling routine
ends (RTE instruction
executed)
[3]
Registers are specified
[6]
DTE bit is set to 1
[7]
Transfer resume
processing end
Transfer resume
processing end
[1] Specify the values in the registers such as transfer counter and address register.
[2] Set the DTE bit in DMDR to 1 to resume DMA operation. Setting the DTE bit to 1 automatically clears the DTIF or
ESIF bit in DMDR to 0 and an interrupt source is cleared.
[3] End the interrupt handling routine by the RTE instruction.
[4] Read that the DTIF or the ESIF bit in DMDR = 1 and then write 0 to the bit.
[5] Complete the interrupt handling routine and clear the interrupt mask.
[6] Specify the values in the registers such as transfer counter and address register.
[7] Set the DTE bit to 1 to resume DMA operation.
Figure 10.40 Procedure Example of Resuming Transfer by Clearing Interrupt Source
Rev. 2.00 Oct. 21, 2009 Page 447 of 1454
REJ09B0498-0200
Section 10 DMA Controller (DMAC)
10.9
Usage Notes
1. DMAC Register Access During Operation
Except for clearing the DTE bit in DMDR, the settings for channels being transferred
(including waiting state) must not be changed. The register settings must be changed during
the transfer prohibited state.
2. Settings of Module Stop Function
The DMAC operation can be enabled or disabled by the module stop control register. The
DMAC is enabled by the initial value.
Setting bit MSTPA13 in MSTPCRA stops the clock supplied to the DMAC and the DMAC
enters the module stop state. However, when a transfer for a channel is enabled or when an
interrupt is being requested, bit MSTPA13 cannot be set to 1. Clear the DTE bit to 0, clear the
DTIF or DTIE bit in DMDR to 0, and then set bit MSTPA13.
When the clock is stopped, the DMAC registers cannot be accessed. However, the following
register settings are valid in the module stop state. Disable them before entering the module
stop state, if necessary.
⎯ TENDE bit in DMDR is 1 (the TEND signal output enabled)
⎯ DACKE bit in DMDR is 1 (the DACK signal output enabled)
3. Activation by DREQ Falling Edge
The DREQ falling edge detection is synchronized with the DMAC internal operation.
A. Activation request waiting state: Waiting for detecting the DREQ low level. A transition to
2. is made.
B. Transfer waiting state: Waiting for a DMAC transfer. A transition to 3. is made.
C. Transfer prohibited state: Waiting for detecting the DREQ high level. A transition to 1. is
made.
After a DMAC transfer enabled, a transition to 1. is made. Therefore, the DREQ signal is
sampled by low level detection at the first activation after a DMAC transfer enabled.
4. Acceptation of Activation Source
At the beginning of an activation source reception, a low level is detected regardless of the
setting of DREQ falling edge or low level detection. Therefore, if the DREQ signal is driven
low before setting DMDR, the low level is received as a transfer request.
When the DMAC is activated, clear the DREQ signal of the previous transfer.
Rev. 2.00 Oct. 21, 2009 Page 448 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Section 11 EXDMA Controller (EXDMAC)
This LSI has an on-chip four-channel external bus transfer DMA controller (EXDMAC). The
EXDMAC can carry out high-speed data transfer, in place of the CPU, to and from external
devices and external memory. Also, the EXDMAC allows external bus transfer in parallel with the
internal CPU operation when there is no external bus request from a controller other than the
EXDMAC.
11.1
Features
• Up to 4-Gbyte address space accessible
• Selection of byte, word, or longword transfer data length
• Total transfer size of up to 4 Gbytes (4,294,967,295 bytes)
Selection of free-running mode (with no total transfer size specified)
• Selection of auto-requests or external requests for activating the EXDMAC
Auto-request: Activation from the CPU (Cycle steal mode or burst mode can be selected.)
External request: Low level sensing or falling edge sensing for the EDREQ signal can be
selected.
All of four channels can accept external requests.
• Selection of dual address mode or single address mode
Dual address mode: Both the transfer source and destination addresses are specified to transfer
data.
Single address mode: The EDACK signal is used to access the transfer source or destination
peripheral device and the address of the other device is specified to transfer data.
• Normal, repeat, block, or cluster transfer (only for the EXDMAC) can be selected as transfer
mode
Normal transfer mode: One byte, one word, or one longword data is transferred at a single
transfer request
Repeat transfer mode: One byte, one word, or one longword data is transferred at a single
transfer request
Repeat size of data is transferred and then a transfer address returns to
the transfer start address
Up to 64-Kbyte transfers can be set as repeat size (65,536
bytes/words/longwords)
Block transfer mode: One block data is transferred at a single transfer request
Up to 64-Kbyte data can be set as block size (65,536
bytes/words/longwords)
Rev. 2.00 Oct. 21, 2009 Page 449 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
•
•
•
•
•
•
•
Cluster transfer mode: One cluster data is transferred at a single transfer request
Up to 32-byte data can be set as cluster size
Selection of extended repeat area function (to transfer data such as ring buffer data by fixing
the upper bit value in the transfer address register and repeating the address values in a
specified range)
For the extended repeat area, 1 bit (2 bytes) to 27 bits (128 Mbytes) can be set independently
for the transfer source or destination.
Selection of address update methods: Increment/decrement by 1, 2 or 4, fixed, or offset
addition
When offset addition is used to update addresses, the mid-addresses can be skipped during data
transfer.
Transfer of word or longword data to addresses beyond each data boundary
Data can be divided into an optimal data size (byte or word) according to addresses when
transferring data.
Two kinds of interrupts requested to the CPU
Transfer end interrupt: Requested after the number of data set by the transfer counter has been
completely transferred
Transfer escape end interrupt: Requested when the remaining transfer size is smaller than the
size set for a single transfer request, after a repeat-size transfer is completed, or when an
extended repeat area overflow occurs.
Acceptance of a transfer request can be reported to an external device via the EDRAK pin
(only for the EXDMAC).
Operation of EXDMAC, connected to a dedicated bus, in parallel with a bus master such as the
CPU, DTC, or DMAC (only for the EXDMAC).
Module stop state can be set.
Rev. 2.00 Oct. 21, 2009 Page 450 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Figure 11.1 shows a block diagram of the EXDMAC.
Internal data bus
Internal address bus
External pins
EDREQn
Data buffer
EDACKn
ETENDn
EDRAKn
Control unit
CLSBR0
Address buffer
Interrupt request
signals to CPU
for individual channels
CLSBR1
Processor
CLSBR2
Processor
EDOFR_n
.
.
.
EDSAR_n
CLSBR7
EDDAR_n
EDMDR_n
EDTCR_n
EDACR_n
EDBSR_n
Module data bus
[Legend]
EDSAR_n:
EDDAR_n:
EDOFR_n:
EDTCR_n:
EDBSR_n:
EDMDR_n:
EDACR_n:
CLSBR0 to CLSBR7:
EXDMA source address register
EXDMA destination address register
EXDMA offset register
EXDMA transfer count register
EXDMA block size register
EXDMA mode control register
EXDMA address control register
Cluster buffer registers 0 to 7
EDREQn:
EDACKn:
ETENDn:
EDRAKn:
(n: 0 to 3)
EXDMA transfer request
EXDMA transfer acknowledge
EXDMA transfer end
EDREQ acceptance acknowledge
Figure 11.1 Block Diagram of EXDMAC
Rev. 2.00 Oct. 21, 2009 Page 451 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.2
Input/Output Pins
Table 11.1 shows the EXDMAC pin configuration.
Table 11.1 Pin Configuration
Channel
Name
Abbr.
I/O
Function
0
EXDMA transfer request 0
EDREQ0
Input
Channel 0 external request
EXDMA transfer
acknowledge 0
EDACK0
Output
Channel 0 single address transfer
acknowledge
EXDMA transfer end 0
ETEND0
Output
Channel 0 transfer end
EDREQ0 acceptance
acknowledge
EDRAK0
Output
Notification to external device of
channel 0 external request
acceptance and start of execution
EXDMA transfer request 1
EDREQ1
Input
Channel 1 external request
EXDMA transfer
acknowledge 1
EDACK1
Output
Channel 1 single address transfer
acknowledge
EXDMA transfer end 1
ETEND1
Output
Channel 1 transfer end
EDREQ1 acceptance
acknowledge
EDRAK1
Output
Notification to external device of
channel 1 external request
acceptance and start of execution
EXDMA transfer request 2
EDREQ2
Input
Channel 2 external request
EXDMA transfer
acknowledge 2
EDACK2
Output
Channel 2 single address transfer
acknowledge
EXDMA transfer end 2
ETEND2
Output
Channel 2 transfer end
EDREQ2 acceptance
acknowledge
EDRAK2
Output
Notification to external device of
channel 2 external request
acceptance and start of execution
EXDMA transfer request 3
EDREQ3
Input
Channel 3 external request
EXDMA transfer
acknowledge 3
EDACK3
Output
Channel 3 single address transfer
acknowledge
EXDMA transfer end 3
ETEND3
Output
Channel 3 transfer end
EDREQ3 acceptance
acknowledge
EDRAK3
Output
Notification to external device of
channel 3 external request
acceptance and start of execution
1
2
3
Rev. 2.00 Oct. 21, 2009 Page 452 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.3
Registers Descriptions
The EXDMAC has the following registers.
Channel 0
•
•
•
•
•
•
•
EXDMA source address register_0 (EDSAR_0)
EXDMA destination address register_0 (EDDAR_0)
EXDMA offset register_0 (EDOFR_0)
EXDMA transfer count register_0 (EDTCR_0)
EXDMA block size register_0 (EDBSR_0)
EXDMA mode control register_0 (EDMDR_0)
EXDMA address control register_0 (EDACR_0)
Channel 1
•
•
•
•
•
•
•
EXDMA source address register_1 (EDSAR_1)
EXDMA destination address register_1 (EDDAR_1)
EXDMA offset register_1 (EDOFR_1)
EXDMA transfer count register_1 (EDTCR_1)
EXDMA block size register_1 (EDBSR_1)
EXDMA mode control register_1 (EDMDR_1)
EXDMA address control register_1 (EDACR_1)
Channel 2
•
•
•
•
•
•
•
EXDMA source address register_2 (EDSAR_2)
EXDMA destination address register_2 (EDDAR_2)
EXDMA offset register_2 (EDOFR_2)
EXDMA transfer count register_2 (EDTCR_2)
EXDMA block size register_2 (EDBSR_2)
EXDMA mode control register_2 (EDMDR_2)
EXDMA address control register_2 (EDACR_2)
Rev. 2.00 Oct. 21, 2009 Page 453 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Channel 3
•
•
•
•
•
•
•
EXDMA source address register_3 (EDSAR_3)
EXDMA destination address register_3 (EDDAR_3)
EXDMA offset register_3 (EDOFR_3)
EXDMA transfer count register_3 (EDTCR_3)
EXDMA block size register_3 (EDBSR_3)
EXDMA mode control register_3 (EDMDR_3)
EXDMA address control register_3 (EDACR_3)
Common register
• Cluster buffer registers 0 to 7 (CLSBR0 to CLSBR7)
Rev. 2.00 Oct. 21, 2009 Page 454 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.3.1
EXDMA Source Address Register (EDSAR)
EDSAR is a 32-bit readable/writable register that specifies the transfer source address. An address
update function is provided that updates the register contents to the next transfer source address
each time transfer processing is performed. In single address mode, the EDSAR value is ignored
when the address specified by EDDAR is transferred as a destination address (DIRS = 1 in
EDACR).
EDSAR can be read at all times by the CPU. When reading EDSAR for a channel on which
EXDMA transfer processing is in progress, a longword-size read must be executed. Do not write
to EDSAR for a channel on which EXDMA transfer is in progress.
Bit
31
30
29
28
27
26
25
24
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 455 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.3.2
EXDMA Destination Address Register (EDDAR)
EDDAR is a 32-bit readable/writable register that specifies the transfer destination address. An
address update function is provided that updates the register contents to the next transfer
destination address each time transfer processing is performed. In single address mode, the
EDDAR value is ignored when the address specified by EDSAR is transferred as a source address
(DIRS = 0 in EDACR).
EDDAR can be read at all times by the CPU. When reading EDDAR for a channel on which
EXDMA transfer processing is in progress, a longword-size read must be executed. Do not write
to EDDAR for a channel on which EXDMA transfer is in progress.
Bit
31
30
29
28
27
26
25
24
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 456 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.3.3
EXDMA Offset Register (EDOFR)
EDOFR is a 32-bit readable/writable register that sets the offset value when offset addition is
selected for updating source or destination addresses. This register can be set independently for
each channel, but the same offset value must be used for the source and destination addresses on
the same channel.
Bit
31
30
29
28
27
26
25
24
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 457 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.3.4
EXDMA Transfer Count Register (EDTCR)
EDTCR is a 32-bit readable/writable register that specifies the size of data to be transferred (total
transfer size).
When EDTCR is set to H'00000001, the total transfer size is 1 byte. When EDTCR is set to
H'00000000, the total transfer size is not specified and the transfer counter is halted (free-running
mode). In this case, no transfer end interrupt by the transfer counter is generated. When EDTCR is
set to H'FFFFFFFF, up to 4 Gbytes (4,294,967,295 bytes) of the total transfer size is set. When the
EXDMA is active, EDTCR indicates the remaining transfer size. The value according to the data
access size (byte: −1, word: −2, longword: −4) is decremented each time of a data transfer.
EDTCR can be read at all times by the CPU. When reading EDTCR for a channel on which
EXDMA transfer processing is in progress, a longword-size read must be executed. Do not write
to EDTCR for a channel on which EXDMA transfer is in progress.
Bit
31
30
29
28
27
26
25
24
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 458 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.3.5
EXDMA Block Size Register (EDBSR)
EDBSR sets the repeat size, block size, or cluster size. EDBSR is enabled in repeat transfer, block
transfer, and cluster transfer modes. EDBSR is disabled in normal transfer mode.
When BKSZH and BKSZ are set to H'0001 in cluster transfer mode (dual address mode), the
EXDMAC operates in block transfer mode (dual address mode).
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
31
30
29
28
27
26
25
24
BKSZH31
BKSZH30
BKSZH29
BKSZH28
BKSZH27
BKSZH26
BKSZH25
BKSZH24
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
BKSZH23
BKSZH22
BKSZH21
BKSZH20
BKSZH19
BKSZH18
BKSZH17
BKSZH16
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
BKSZ15
BKSZ14
BKSZ13
BKSZ12
BKSZ11
BKSZ10
BKSZ9
BKSZ8
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
BKSZ7
BKSZ6
BKSZ5
BKSZ4
BKSZ3
BKSZ2
BKSZ1
BKSZ0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
31 to 16
BKSZH31
to
BKSZH16
15 to 0
Initial
value
R/W
Description
All 0
R/W
Sets the repeat size, block size, or cluster size.
BKSZ15 to All 0
BKSZ0
When these bits are set to H'0001, one byte-, one
word-, or one longword-size is set. When these bits are
set to H'0000, the maximum values are set (see table
11.2). These bits are always fixed during an EXDMA
operation.
R/W
In an EXDMA operation, the remaining repeat size,
block size, or cluster size is indicated. The value is
decremented by one each time of a data transfer. When
the remaining size becomes zero, the BKSZH value is
loaded. Set the same initial value as for the BKSZH bit
when writing.
Rev. 2.00 Oct. 21, 2009 Page 459 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Table 11.2 Data Access Size, Enable Bit, and Allowable Size
Mode
Data
BKSZH
Access Size enable bit
BKSZ
enable bit
Allowable size (in bytes)
Repeat transfer mode
Byte
15 to 0
1 to 65,536
Block transfer mode
Word
2 to 131,072
Longword
4 to 262,144
Cluster transfer mode
11.3.6
31 to 16
Byte
20 to 16
4 to 0
1 to 32
Word
19 to 16
3 to 0
2 to 32
Longword
18 to 16
2 to 0
4 to 32
EXDMA Mode Control Register (EDMDR)
EDMDR controls EXDMAC operations.
• EDMDR_0
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
31
30
29
28
27
26
25
24
DTE
EDACKE
ETENDE
EDRAKE
EDREQS
NRD
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R
R
23
22
21
20
19
18
17
16
ACT
⎯
⎯
⎯
ERRF
⎯
ESIF
DTIF
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R/(W)*
R
R/(W)*
R/(W)*
15
14
13
12
11
10
9
8
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Note: *
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R
R/W
R/W
7
6
5
4
3
2
1
0
DTF1
DTF0
⎯
⎯
⎯
DMAP2
DMAP1
DMAP0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R
R
R/W
R/W
R/W
Only 0 can be written to this bit after having been read as 1, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 460 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
• EDMDR_1 to EDMDR_3
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
31
30
29
28
27
26
25
24
DTE
EDACKE
ETENDE
EDRAKE
DREQS
NRD
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R
R
23
22
21
20
19
18
17
16
ACT
⎯
⎯
⎯
⎯
⎯
ESIF
DTIF
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R/(W)*
R/(W)*
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Note: *
15
14
13
12
11
10
9
8
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R
R/W
R/W
7
6
5
4
3
2
1
0
DTF1
DTF0
⎯
⎯
⎯
EDMAP2
EDMAP1
EDMAP0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R
R
R/W
R/W
R/W
Only 0 can be written to this bit after having been read as 1, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 461 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
31
DTE
0
R/W
Data Transfer Enable
Enables or disables data transfer on the corresponding
channel. When this bit is set to 1, this indicates that an
EXDMA operation is in progress.
When auto-request mode is specified, transfer
processing begins when this bit is set to 1. With
external requests, transfer processing begins when a
transfer request is issued after this bit has been set to
1. When this bit is cleared to 0 during an EXDMA
operation, transfer is halted.
If this bit is cleared to 0 during an EXDMA operation in
block transfer mode, this bit is cleared to 0 on
completion of the currently executing one-block
transfer. When this bit is cleared to 0 during an EXDMA
operation in cluster transfer mode, this bit is cleared to
0 on completion of the currently executing one-cluster
transfer.
If an external source that ends (aborts) transfer occurs,
this bit is automatically cleared to 0 and transfer is
terminated.
Do not change the operating mode, transfer method, or
other parameters while this bit is set to 1.
0: Data transfer disabled
1: Data transfer enabled (during an EXDMA operation)
[Clearing conditions]
•
•
•
•
•
•
•
Rev. 2.00 Oct. 21, 2009 Page 462 of 1454
REJ09B0498-0200
When transfer of the total transfer size specified
ends
When operation is halted by a repeat size end
interrupt
When operation is halted by an extended repeat
area overflow interrupt
When operation is halted by a transfer size error
interrupt
When 0 is written to terminate transfer
In block transfer mode, the value written is effective
after one-block transfer ends.
In cluster transfer mode, the value written is
effective after one-cluster transfer ends.
When an address error or NMI interrupt occurs
Reset, hardware standby mode
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
30
EDACKE
0
R/W
EDACK Pin Output Enable
In single address mode, enables or disables output
from the EDACK pin. In dual address mode, the
specification by this bit is ignored.
0: EDACK pin output disabled
1: EDACK pin output enabled
29
ETENDE
0
R/W
ETEND Pin Output Enable
Enables or disables output from the ETEND pin.
0: ETEND pin output disabled
1: ETEND pin output enabled
28
EDRAKE
0
R/W
EDRAK Pin Output Enable
Enables or disables output from the EDRAK pin.
0: EDRAK pin output disabled
1: EDRAK pin output enabled
27
EDREQS
0
R/W
EDREQ Select
Selects whether a low level or the falling edge of the
EDREQ signal used in external request mode is
detected.
0: Low-level detection
1: Falling edge detection (the first transfer is detected
on a low level after a transfer is enabled.)
26
NRD
0
R/W
Next Request Delay
Selects the timing of the next transfer request to be
accepted.
0: Next transfer request starts to be accepted after
transfer of the bus cycle in progress ends.
1: Next transfer request starts to be accepted after one
cycle of Bφ from the completion of the bus cycle in
progress.
25, 24
⎯
All 0
R
Reserved
They are always read as 0 and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 463 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
23
ACT
0
R
Active State
Indicates the operation state of the corresponding
channel.
0: Transfer request wait state or transfer disabled state
(DTE = 0)
1: Active state
22 to 20
⎯
All 0
R
Reserved
They are always read as 0 and cannot be modified.
19
ERRF
0
R/(W)*
System Error Flag
Flag that indicates the occurrence of an address error
or NMI interrupt. This bit is only enabled in EDMDR_0.
When this bit is set to 1, write to the DTE bit for all
channels is disabled. This bit is reserved in EDMDR_1
to EDMDR_3. They are always read as 0 and cannot
be modified.
0: Address error or NMI interrupt is not generated
1: Address error or NMI interrupt is generated
[Clearing condition]
•
Writing 0 to ERRF after reading ERRF = 1
[Setting condition]
•
When an address error or NMI interrupt occurred
However, when an address error or an NMI interrupt
has been generated in EXDMAC module stop mode,
this bit is not set to 1.
18
⎯
0
R
Reserved
They are always read as 0 and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 464 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
17
ESIF
0
R/(W)*
Transfer Escape Interrupt Flag
Flag indicating that a transfer escape end interrupt
request has occurred before the transfer counter
becomes 0 and transfer escape has ended.
0: Transfer escape end interrupt request is not
generated
1: Transfer escape end interrupt request is generated
[Clearing conditions]
•
Writing 1 to the DTE bit
•
Writing 0 to ESIF while reading ESIF = 1
[Setting conditions]
16
DTIF
0
R/(W)*
•
Transfer size error interrupt request is generated
•
Repeat size end interrupt request is generated
•
Extended repeat area overflow end interrupt request
is generated
Data Transfer Interrupt Flag
Flag indicating that a transfer end interrupt request has
occurred by the transfer counter.
0: Transfer end interrupt request is not generated by
the transfer counter
1: Transfer end interrupt request is generated by the
transfer counter
[Clearing conditions]
•
Writing 1 to the DTE bit
•
Writing 0 to DTIF while reading DTIF = 1
[Setting condition]
•
When EDTCR becomes 0 and transfer has ended
15
DTSZ1
0
R/W
Data Access Size 1 and 0
14
DTSZ0
0
R/W
Selects the data access size.
00: Byte-size (8 bits)
01: Word-size (16 bits)
10: Longword-size (32 bits)
11: Setting prohibited
Rev. 2.00 Oct. 21, 2009 Page 465 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
13
MDS1
0
R/W
Transfer Mode Select 1 and 0
12
MDS0
0
R/W
Selects the transfer mode.
00: Normal transfer mode
01: Block transfer mode
10: Repeat transfer mode
11: Cluster transfer mode
11
TSEIE
0
R/W
Transfer Size Error Interrupt Enable
Enables or disables a transfer size error interrupt
request.
When this bit is set to 1 and the transfer counter value
becomes smaller than the data access size for one
transfer request by EXDMAC transfer, the DTE bit is
cleared to 0 by the next transfer request. At the same
time, the ESIF bit is set to 1 to indicate that a transfer
size error interrupt request is generated.
When cluster transfer read/write address mode is
specified, this bit should be set to 1.
Transfer size error interrupt request occurs in the
following conditions:
•
In normal transfer and repeat transfer modes, the
total transfer size set in EDTCR is smaller than the
data access size
•
In block transfer mode, the total transfer size set in
EDTCR is smaller than the block size
•
In cluster transfer mode, the total transfer size set in
EDTCR is smaller than the cluster size
0: Transfer size error interrupt request disabled
1: Transfer size error interrupt request enabled
10
⎯
0
R
Reserved
They are always read as 0 and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 466 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
9
ESIE
0
R/W
Transfer Escape Interrupt Enable
Enables or disables a transfer escape end interrupt
request occurred during EXDMA transfer. When this bit
is set to 1, and the ESIF bit is set to 1, a transfer
escape end interrupt is requested to the CPU or DTC.
The transfer escape end interrupt request is canceled
by clearing this bit or the ESIF bit to 0.
0: Transfer escape interrupt request disabled
1: Transfer escape interrupt request enabled
8
DTIE
0
R/W
Data Transfer Interrupt Enable
Enables or disables a transfer end interrupt request by
the transfer counter. When this bit is set to 1 and the
DTIF bit is set to 1, a transfer end interrupt is requested
to the CPU or DTC. The transfer end interrupt request
is canceled by clearing this bit or the DTIF bit to 0.
0: Transfer end interrupt request disabled
1: Transfer end interrupt request enabled
7
DTF1
0
R/W
Data Transfer Factor 1 and 0
6
DTF0
0
R/W
Selects a source to activate EXDMAC. For external
requests, a sampling method is selected by the
EDREQS bit.
00: Auto-request (cycle steal mode)
01: Auto-request (burst mode)
10: Setting prohibited
11: External request
5
⎯
0
R/W
Reserved
The initial value should not be changed.
Rev. 2.00 Oct. 21, 2009 Page 467 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
4, 3
⎯
All 0
R
Reserved
They are always read as 0 and cannot be modified.
2
EDMAP2
0
R/W
EXDMA Priority Levels 2 to 0
1
EDMAP1
0
R/W
0
EDMAP0
0
R/W
Selects the EXDMAC priority level when using the CPU
priority control function over DTC and EXDMAC. When
the EXDMAC priority level is lower than the CPU
priority level, EXDMAC masks the acceptance of
transfer source and waits until the CPU priority level
becomes low. The priority level can be set
independently for each channel. This bit is enabled
when the CPUPCE bit in CPUPCR is 1.
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)
Note:
*
Only 0 can be written to these bits after 1 is read to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 468 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.3.7
EXDMA Address Control Register (EDACR)
EDACR sets the operating modes and transfer methods.
Bit
Bit Name
31
30
29
28
27
26
25
24
AMS
DIRS
⎯
⎯
⎯
RPTIE
ARS1
ARS0
0
0
0
0
0
0
0
0
R/W
R/W
R
R
R
R/W
R/W
R/W
Bit
23
22
21
20
19
18
17
16
Bit Name
⎯
⎯
SAT1
SAT0
⎯
⎯
DAT1
DAT0
Initial Value
R/W
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R/W
R/W
R
R
R/W
R/W
15
14
13
12
11
10
9
8
SARIE
⎯
⎯
SARA4
SARA3
SARA2
SARA1
SARA0
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R
R
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
DARIE
⎯
⎯
DARA4
DARA3
DARA2
DARA1
DARA0
0
0
0
0
0
0
0
0
R/W
R
R
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
value
R/W
Description
31
AMS
0
R/W
Address Mode Select
Selects single address mode or dual address mode.
When single address mode is selected, EDACK pin is
valid due to the EDACKE bit setting in EDMDR.
0: Dual address mode
1: Single address mode
30
DIRS
0
R/W
Single Address Direction Select
Specifies the data transfer direction in single address
mode. In dual address mode, the specification by this
bit is ignored.
In cluster transfer mode, the internal cluster buffer will
be the source or destination in place of the external
device with DACK.
0: EDSAR transferred as a source address
1: EDDAR transferred as a destination address
Rev. 2.00 Oct. 21, 2009 Page 469 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
29 to 27
⎯
All 0
R
Reserved
They are always read as 0 and cannot be modified.
26
RPTIE
0
R/W
Repeat Size End Interrupt Enable
Enables or disables a repeat size end interrupt request.
When this bit is set to 1 and the next transfer source is
generated at the end of a repeat-size transfer in repeat
transfer mode, the DTE bit in EDMDR is cleared to 0. At
the same time, the ESIF bit in EDMDR is set to 1 to
indicate that a repeat size end interrupt is requested.
Even if the repeat area is not specified (ARS1, ARS0 =
B'10), the repeat size end interrupt can be requested at
the end of a repeat-size transfer.
When this bit is set to 1 and the next transfer source is
generated at the end of a block- or cluster-size transfer
in block transfer or cluster transfer mode, the DTE bit in
EDMDR is cleared to 0. At the same time, the ESIF bit
in EDMDR is set to 1 to indicate that the repeat size
end interrupt is requested.
0: Repeat size end interrupt request disabled
1: Repeat size end interrupt request enabled
25
ARS1
0
R/W
Area Select 1 and 0
24
ARS0
0
R/W
Select the block area or repeat area in block transfer,
repeat transfer or cluster transfer mode.
00: Block area/repeat area on the source address side
01: Block area/repeat area on the destination address
side
10: Block area/repeat area not specified
11: Setting prohibited
23, 22
⎯
All 0
R
Reserved
They are always read as 0 and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 470 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
21
SAT1
0
R/W
Source Address Update Mode 1 and 0
20
SAT0
0
R/W
These bits specify incrementing/decrementing of the
transfer source address (EDSAR). When the transfer
source is not specified in EDSAR in single address
mode, the specification by these bits is ignored.
00: Fixed
01: Offset added
10: Incremented (+1, +2, or +4 according to the data
access size)
11: Decremented (−1, −2, or −4 according to the data
access size)
19, 18
⎯
All 0
R
Reserved
They are always read as 0 and cannot be modified.
17
DAT1
0
R/W
Destination Address Update Mode 1 and 0
16
DAT0
0
R/W
These bits specify incrementing/decrementing of the
transfer destination address (EDDAR). When the
transfer source is not specified in EDDAR in single
address mode, the specification by these bits is
ignored.
00: Fixed
01: Offset added
10: Incremented (+1, +2, or +4 according to the data
access size)
11: Decremented (−1, −2, or −4 according to the data
access size)
Rev. 2.00 Oct. 21, 2009 Page 471 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
15
SARIE
0
R/W
Source Address Extended Repeat Area Overflow
Interrupt Enable
Enables or disables the source address extended
repeat area overflow interrupt request.
When this bit is set to 1, in the event of source address
extended repeat area overflow, the DTE bit is cleared to
0 in EDMDR. At the same time, the ESIF bit is set to 1
in EDMDR to indicate that the source address extended
repeat area overflow interrupt is requested.
When used together with block transfer mode, an
interrupt is requested at the end of a block-size transfer.
If the DTE bit is set to 1 in EDMDR for the channel on
which transfer is terminated by an interrupt, transfer can
be resumed from the state in which it ended.
If a source address extended repeat area is not
designated, the specification by this bit is ignored.
0: Source address extended repeat area overflow
interrupt request disabled
1: Source address extended repeat area overflow
interrupt request enabled
14, 13
⎯
All 0
R
Reserved
They are always read as 0 and cannot be modified.
12
SARA4
0
R/W
Source Address Extended Repeat Area
11
SARA3
0
R/W
10
SARA2
0
R/W
9
SARA1
0
R/W
8
SARA0
0
R/W
These bits specify the source address (EDSAR)
extended repeat area. The extended repeat area
function updates the specified lower address bits,
leaving the remaining upper address bits always the
same. An extended repeat area size of 4 bytes to 128
Mbytes can be specified. The setting interval is a
power-of-two number of bytes.
When extended repeat area overflow results from
incrementing or decrementing an address, the lower
address is the start address of the extended repeat
area in the case of address incrementing, or the last
address of the extended repeat area in the case of
address decrementing.
If SARIE bit is set to 1, an interrupt can be requested
when an extended repeat area overflow occurs.
Table 11.3 shows the settings and ranges of the
extended repeat area.
Rev. 2.00 Oct. 21, 2009 Page 472 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bit
Bit Name
Initial
value
R/W
Description
7
DARIE
0
R/W
Destination Address Extended Repeat Area Overflow
Interrupt Enable
Enables or disables a destination address extended
repeat area overflow interrupt request.
When this bit is set to 1, in the event of destination
address extended repeat area overflow, the DTE bit in
EDMDR is cleared to 0. At the same time, the ESIF bit
in EDMDR is set to 1 to indicate that a destination
address extended repeat area overflow interrupt is
requested.
When used together with block transfer mode, an
interrupt is requested at the end of a block-size transfer.
If DTE bit is set to 1 in EDMDR for the channel on
which transfer is terminated by an interrupt, transfer can
be resumed from the state in which it ended. If a
destination address extended repeat area is not
designated, the specification by this bit is ignored.
0: Destination address extended repeat area overflow
interrupt request disabled
1: Destination address extended repeat area overflow
interrupt request enabled
6, 5
⎯
All 0
R
Reserved
They are always read as 0 and cannot be modified.
4
DARA4
0
R/W
Destination Address Extended Repeat Area
3
DARA3
0
R/W
2
DARA2
0
R/W
These bits specify the destination address (EDDAR)
extended repeat area.
1
DARA1
0
R/W
0
DARA0
0
R/W
The extended repeat area function updates the
specified lower address bits, leaving the remaining
upper address bits always the same. An extended
repeat area size of 4 bytes to 128 Mbytes can be
specified. The setting interval is a power-of-two number
of bytes.
When extended repeat area overflow results from
incrementing or decrementing an address, the lower
address is the start address of the extended repeat
area in the case of address incrementing, or the last
address of the extended repeat area in the case of
address decrementing.
If the DARIE bit is set to 1, an interrupt can be
requested when an extended repeat area overflow
occurs.
Table 11.3 shows the settings and ranges of the
extended repeat area.
Rev. 2.00 Oct. 21, 2009 Page 473 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Table 11.3 Settings and Ranges of Extended Repeat Area
Value of SARA4 to SARA0/
DARA4 to DARA0
Range of Extended Repeat Area
00000
Not designated as extended repeat area
00001
Lower 1 bit (2-byte area) designated as extended repeat area
00010
Lower 2 bit (4-byte area) designated as extended repeat area
00011
Lower 3 bit (8-byte area) designated as extended repeat area
00100
Lower 4 bit (16-byte area) designated as extended repeat area
00101
Lower 5 bit (32-byte area) designated as extended repeat area
00110
Lower 6 bit (64-byte area) designated as extended repeat area
00111
Lower 7 bit (128-byte area) designated as extended repeat area
01000
Lower 8 bit (256-byte area) designated as extended repeat area
01001
Lower 9 bit (512-byte area) designated as extended repeat area
01010
Lower 10 bit (1-Kbyte area) designated as extended repeat area
01011
Lower 11 bit (2-Kbyte area) designated as extended repeat area
01100
Lower 12 bit (4-Kbyte area) designated as extended repeat area
01101
Lower 13 bit (8-Kbyte area) designated as extended repeat area
01110
Lower 14 bit (16-Kbyte area) designated as extended repeat area
01111
Lower 15 bit (32-Kbyte area) designated as extended repeat area
10000
Lower 16 bit (64-Kbyte area) designated as extended repeat area
10001
Lower 17 bit (128-Kbyte area) designated as extended repeat area
10010
Lower 18 bit (256-Kbyte area) designated as extended repeat area
10011
Lower 19 bit (512-Kbyte area) designated as extended repeat area
10100
Lower 20 bit (1-Mbyte area) designated as extended repeat area
10101
Lower 21 bit (2-Mbyte area) designated as extended repeat area
10110
Lower 22 bit (4-Mbyte area) designated as extended repeat area
10111
Lower 23 bit (8-Mbyte area) designated as extended repeat area
11000
Lower 24 bit (16-Mbyte area) designated as extended repeat area
11001
Lower 25 bit (32-Mbyte area) designated as extended repeat area
11010
Lower 26 bit (64-Mbyte area) designated as extended repeat area
11011
Lower 27 bit (128-Mbyte area) designated as extended repeat area
111XX
Setting prohibited
[Legend] X: Don't care
Rev. 2.00 Oct. 21, 2009 Page 474 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.3.8
Cluster Buffer Registers 0 to 7 (CLSBR0 to CLSBR7)
CLSBR0 to CLSBR7 are 32-bit readable/writable registers that store the transfer data. The transfer
data is stored in order from CLSBR0 to CLSBR7 in cluster transfer mode. The data stored in
cluster transfer mode or by the CPU write operation is held until the next cluster transfer or CPU
write operation is performed.
When reading the data stored in cluster transfer mode by the CPU, check the completion of cluster
transfer and then perform only a cluster-size read specified for the cluster transfer. Data with
another size is undefined.
In cluster transfer mode, the same CLSBR is used for all channels. When the CPU write operation
to CLSBR conflicts with cluster transfer, the contents of transferred data are not guaranteed. When
cluster transfer read/write address mode is specified and if another channel is set for cluster
transfer, the transferred data may be overwritten.
Bit
31
30
29
28
27
26
25
24
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Rev. 2.00 Oct. 21, 2009 Page 475 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.4
Transfer Modes
11.4.1
Ordinary Modes
The ordinary modes of EXDMAC are summarized in table 11.4. The transfer mode can be set
independently for each channel.
Table 11.4 Ordinary Modes
Address
Mode
Dual
address
mode
Address Register
Transfer Mode
Activation Source
Common Function
Source
Destination
•
•
•
EDSAR
EDDAR
Direct data transfer to/from external devices using EDACK pin
EDSAR/
EDACK/
instead of source or destination address register
EDACK
EDDAR
Normal transfer
•
•
•
External request
Block transfer
mode
Total transfer size:
1 to 4 Gbytes,
CPU)
Repeat transfer
mode
Auto-request
(activated by the
mode
or no specification
•
Offset addition
•
Extended repeat
area function
(Repeat size/
block size
= 1 to 65,536 bytes/
word/longword)
Single
address
mode
•
•
Above transfer mode can be specified in addition to address
register setting
•
One transfer possible in one bus cycle
(Transfer mode variations are the same as in dual address mode.)
When the activation source is an auto-request, cycle steal mode or burst mode can be selected.
When the total transfer size is not specified (EDTCR = H'00000000), the transfer counter is halted
and the transfer count is not restricted, allowing continuous transfer.
Rev. 2.00 Oct. 21, 2009 Page 476 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.4.2
Cluster Transfer Modes
Table 11.5 shows cluster transfer modes. Cluster transfer mode can be set independently for each
channel. The cluster buffer is common to all channels.
Table 11.5 Cluster Transfer Mode
Cluster
Buffer
Function
Address Mode
Activation Source
Common Function
Transfer
Source
Cluster transfer
•
•
EDSAR
Read from
the transfer
source and
written to
the transfer
destination
EDDAR
EDSAR
Read from
the transfer
source
⎯
⎯
Written to
the transfer
destination
EDDAR
Dual address mode
•
Auto-request
One access size
the CPU)
(byte/word/longword)
to 32 bytes
External
request
•
specification
Read address mode
Cluster transfer
Total transfer size
1 to 4 Gbytes, or no
Cluster transfer
(DIRS = 0)
Cluster size
(activated by
•
Offset addition
•
Extended repeat
Write address mode
area function
Transfer
Destination
(DIRS = 1)
In cluster transfer mode, the specified cluster size is transferred in response to a single transfer
request. The cluster size can be from one access size (byte, word, or longword) to 32 bytes. Within
a cluster, a cluster-size transfer is performed in burst transfer mode. With a cluster-size access in
cluster transfer mode (dual address mode), block transfer mode (dual address mode) is used.
With auto-requests, cycle steal mode is set.
Rev. 2.00 Oct. 21, 2009 Page 477 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.5
Mode Operation
11.5.1
Address Modes
(1)
Dual Address Mode
In dual address mode, the transfer source address is set in EDSAR, and the transfer destination
address is set in EDDAR. One transfer operation is executed in two bus cycles. (When the data
bus width is smaller than the data access size or when the address to be accessed is not at the data
boundary of the data access size, the bus cycle is divided, resulting more than two bus cycles.)
In a transfer operation, the data on the transfer source address is read in the first bus cycle, and is
written to the transfer destination address in the next bus cycle.
These consecutive read and write cycles are indivisible: another bus cycle (external access by
another bus master, refresh cycle, or external bus release cycle) does not occur between these two
cycles.
ETEND pin output can be enabled or disabled by means of the ETENDE bit in EDMDR. ETEND
is output for two consecutive bus cycles. When an idle cycle is inserted before the bus cycle, the
ETEND signal is also output in the idle cycle. The EDACK signal is not output.
Figure 11.2 shows an example of the timing in dual address mode and figure 11.3 shows the dual
address mode operation.
EXDMA read
cycle
EXDMA write
cycle
EDSAR
EDDAR
Bφ
Address bus
RD
WR
ETEND
Figure 11.2 Example of Timing in Dual Address Mode
Rev. 2.00 Oct. 21, 2009 Page 478 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Address TB
Transfer
Address TA
Address BA
Address update setting
The source address incremented
The destination adderss is fixed
Figure 11.3 Dual Address Mode Operation
(2)
Single Address Mode
In single address mode, the EDACK pin is used instead of EDSAR or EDDAR to transfer data
directly between an external device and external memory. One transfer operation is executed in
one bus cycle.
In this mode, the data bus width must be the same as the data access size. For details on the data
bus width, see section 9, Bus Controller (BSC).
In this mode, the EXDMAC accesses the transfer source or transfer destination external device by
outputting the strobe signal (EDACK) for the external device with DACK, and at the same time
accesses the other external device in the transfer by outputting an address. In this way, EXDMA
transfer can be executed in one bus cycle. In the example of transfer between external memory and
an external device with DACK shown in figure 11.4, data is output to the data bus by the external
device and written to external memory in the same bus cycle.
The transfer direction, that is whether the external device with DACK is the transfer source or
transfer destination, can be specified with the DIRS bit in EDACR. Transfer is performed from the
external memory (EDSAR) to the external device with DACK when DIRS = 0, and from the
external device with DACK to the external memory (EDDAR) when DIRS = 1. The setting in the
source or destination address register not used in the transfer is ignored.
The EDACK pin output is valid by the setting of EDACKE bit in EDMDR when single address
mode is selected. The EDACK pin output is active-low.
ETEND pin output can be enabled or disabled by means of the ETENDE bit in EDMDR. ETEND
is output for one bus cycle. When an idle cycle is inserted before the bus cycle, the ETEND signal
is also output in the idle cycle.
Figure 11.5 shows an example of the timing in single address mode and figure 11.6 shows the
single address mode operation.
Rev. 2.00 Oct. 21, 2009 Page 479 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
External
address bus
External
data bus
LSI
External
memory
EXDMAC
Data flow
External device
with DACK
EDACK
EDREQ
Figure 11.4 Data Flow in Single Address Mode
Transfer from external memory to external device with DACK
EXDMA cycle
Bφ
Address bus
EDSAR
RD
Address for external memory space
RD signal to external memory space
WR
High
EDACK
Data output by external memory
Data bus
ETEND
Transfer from external device with DACK to external memory
EXDMA cycle
Bφ
Address bus
RD
EDDAR
Address for external memory space
High
WR
WR signal to external memory space
EDACK
Data bus
Data output from external device with DACK
ETEND
Figure 11.5 Example of Timing in Single Address Mode
Rev. 2.00 Oct. 21, 2009 Page 480 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Address T
EDACK
Transfer
Address B
Figure 11.6 Single Address Mode Operation
11.5.2
(1)
Transfer Modes
Normal Transfer Mode
In normal transfer mode, transfer of one data access size unit is processed in response to one
transfer request. The total transfer size of up to 4 Gbytes can be set by EDTCR. EDBSR is invalid
in normal transfer mode.
The ETEND signal is output only for the last EXDMA transfer. The EDRAK signal is output each
time a transfer request is accepted and transfer processing is started.
Figure 11.7 shows examples of transfer timing in normal transfer mode and figure 11.8 shows the
normal transfer mode operation in dual address mode.
Transfer conditions: Dual address mode, auto-request mode
EXDMA transfer
cycle
Bus cycle
Read
Write
Last EXDMA
transfer cycle
Read
Write
ETEND
Transfer conditions: Single address mode, external request mode
EDREQ
EDRAK
Bus cycle
EXDMA
EXDMA
EDACK
Figure 11.7 Examples of Timing in Normal Transfer Mode
Rev. 2.00 Oct. 21, 2009 Page 481 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Transfer
Address TA
Address TB
Total transfer
size (EDTCR)
Address BA
Address BB
Figure 11.8 Normal Transfer Mode Operation
(2)
Repeat Transfer Mode
In repeat transfer mode, transfer of one data access size unit is processed in response to one
transfer request. The total transfer size of up to 4 Gbytes can be set by EDTCR. The repeat size of
up to 64 Kbytes × data access size can be set by EDBSR.
The ARS1 and ARS0 bits in EDACR specify the repeat area on the source address or destination
address side. The address specified for the repeat area is restored to the transfer start address at the
end of a repeat-size transfer. This operation continues until transfer of total transfer size set in
EDTCR ends. EDTCR specified with H'00000000 is assumed as free-running mode and the repeat
transfer continues until the DTE bit in EDMDR is cleared to 0.
At the end of a repeat-size transfer, the EXDMA transfer is halted temporarily and a repeat size
end interrupt is requested to the CPU or DTC. When the RPTIE bit in EDACR is set to 1 and the
next transfer request is generated at the end of a repeat-size transfer, the ESIF bit in EDMDR is set
to 1 and the DTE bit in EDMDR is cleared to 0 to terminate the transfer. At this time, an interrupt
is requested to the CPU or DTC when the ESIE bit in EDMDR is set to 1.
The timing of EXDMA transfer including the ETEND or EDRAK output is the same as for
normal transfer mode.
Figure 11.9 shows the repeat transfer mode operation in dual address mode.
The operation without specifying a repeat area on the source or destination address side is the
same as for the normal transfer mode operation shown in figure 11.8. In this case, a repeat size end
interrupt can also be generated at the end of a repeat-size transfer.
Rev. 2.00 Oct. 21, 2009 Page 482 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Address TA
Transfer
Address TB
Repeat size
(BKSZH ×
data access size)
Total transfer
size (EDTCR)
Address BA
Operation with the repeat area
specified on the source address side
Address BB
Figure 11.9 Repeat Transfer Mode Operation
(3)
Block Transfer Mode
In block transfer mode, transfer of one block size unit is processed in response to one transfer
request. The total transfer size of up to 4 Gbytes can be set by EDTCR. The block size of up to 64
Kbytes × data access size can be set by EDBSR.
A transfer request from another channel is held pending during one block transfer. When oneblock transfer is completed, the bus mastership is released for another bus master.
A block area can be specified by the ARS1 or ARS0 bit in EDACR on the source or destination
address side. The address specified for the block area is restored to the transfer start address each
time one-block transfer completes. When no repeat area is specified on the source and destination
address sides, the address is not restored to the transfer start address and the operation proceeds to
the next sequence. A repeat size end interrupt can be generated.
The ETEND signal is output for each block transfer in the EXDMA transfer cycle in which the
block ends. The EDRAK signal is output once for one transfer request (for transfer of one block).
Caution is required when setting the extended repeat area overflow interrupt in block transfer
mode. For details, see section 11.5.5, Extended Repeat Area Function.
Rev. 2.00 Oct. 21, 2009 Page 483 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Figure 11.10 shows an example of EXDMA transfer timing in block transfer mode. The transfer
conditions are as follows:
Address mode: Single address mode
Data access size: In bytes
One block size: 3 bytes
Figure 11.11 shows the block transfer mode operation in single address mode and figure 11.12
shows the block transfer mode operation in dual address mode.
EDREQ
EDRAK
Bus cycle
One-block transfer cycle
CPU
CPU
EXDMAC
EXDMAC
EXDMAC
CPU
CPU cycle not generated
ETEND
Figure 11.10 Example of Block Transfer Mode
Address T
Block
Transfer
EDACK
BKSZH ×
data access size
Address B
Figure 11.11 Block Transfer Mode Operation in Single Address Mode
(with Block Area Specified)
Rev. 2.00 Oct. 21, 2009 Page 484 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Address TA
First block
Address TB
Transfer
First block
BKSZH ×
data access size
Second block
Second block
Total transfer
size (EDTCR)
Nth block
Nth block
Address BB
Address BA
Figure 11.12 Block Transfer Mode Operation in Dual Address Mode (without Block Area
Specified)
Rev. 2.00 Oct. 21, 2009 Page 485 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.5.3
Activation Sources
The EXDMAC is activated by an auto request or an external request. This activation source is
selected by the DTF1 or DTF0 bit in EDMDR.
(1)
Activation by Auto-Request
The transfer request signal is automatically generated in EXDMAC with auto-request activation
when no transfer request signal is generated from external or peripheral modules, incase of
transfer among memory or between memory and peripheral modules that cannot generate the
transfer request signal. The transfer starts when the DTE bit in EDMDR is set to 1 with autorequest activation. The bus mode can be selected from cycle steal mode and burst mode with autorequest activation.
(2)
Activation by External Request
Transfer is started by the transfer request signal (EDREQ) from the external device for activation
by an external request. When the EXDMA transfer is enabled (DTE = 1), the EXDMA transfer
starts by EDREQ input.
The transfer request signal is accepted by the EDREQ pin. The EDREQS bit in EDMDR selects
whether the EDREQ is detected by falling edge sensing or low level sensing.
When the EDRAKE bit in EDMDR is set to 1, the signal notifying transfer request acceptance is
output from the EDRAK pin. The EDRAK signal is accepted for one external request and is
output when transfer processing starts.
When specifying an external request as an activation source, set the DDR bit to 0 and the ICR bit
to 1 on the corresponding pin in advance. For details, see section 13, I/O Ports.
Rev. 2.00 Oct. 21, 2009 Page 486 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.5.4
Bus Mode
There are two bus modes: cycle steal mode and burst mode.
For auto-request activation, either cycle steal mode or burst mode can be selected by the DTF0 bit
in EDMDR. When the activation source is an external request, cycle steal mode is used.
(1)
Cycle Steal Mode
In cycle steal mode, the EXDMAC releases the bus mastership at the end of each transfer of a
transfer unit (byte, word, longword, one block size, or one cluster size). If there is a subsequent
transfer request, the EXDMAC takes back the bus mastership, performs another transfer-unit
transfer, and then releases the bus mastership again at the end of the transfer. This procedure is
repeated until the transfer end condition is satisfied.
If a transfer request occurs in another channel during EXDMA transfer, the bus mastership is
temporarily released for another bus master, then transfer is performed on the channel for which
the transfer request was issued. For details on the operation when there are transfer requests for a
number of channels, see section 11.5.8, Channel Priority Order.
Figure 11.13 shows an example of the timing in cycle steal mode. The transfer conditions are as
follows:
• Address mode: Single address mode
• Sampling method on the EDREQ pin: Low level sensing
• CPU internal bus master is operating in external space
EDREQ
EDRAK
Bus cycle
CPU
CPU
EXDMAC
CPU
EXDMAC
CPU
Bus mastership returned temporarily to CPU
Figure 11.13 Example of Timing in Cycle Steal Mode
Rev. 2.00 Oct. 21, 2009 Page 487 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(2)
Burst Mode
In burst mode, once the EXDMAC acquires the bus mastership, it continues transferring data,
without releasing the bus mastership, until the transfer end condition is satisfied. In burst mode,
once transfer is started it is not interrupted even if there is a transfer request for another channel
with higher priority. When the burst mode channel finishes its transfer, it releases the bus
mastership in the next cycle in the same way as in cycle steal mode. However, when the EBCCS
bit in BCR2 of the bus controller is set to 1, the EXDMAC can temporarily release the bus
mastership for another bus master when an external access request is generated from another bus
master.
In block transfer mode and cluster transfer mode, the setting of burst mode is invalid (one-block or
one-cluster transfer is processed in the same way as in burst mode). The EXDMAC always
operates in cycle steal mode.
When the DTE bit is cleared to 0 in EDMDR, EXDMA transfer is halted. However, EXDMA
transfer is executed for all transfer requests generated within the EXDMAC until the DTE bit is
cleared to 0. If a transfer size error interrupt, a repeat size end interrupt, or extended repeat area
overflow interrupt is generated, the DTE bit is cleared to 0 and transfer is terminated.
Figure 11.14 shows an example of the timing in burst mode.
Bus cycle
CPU
CPU
EXDMAC
EXDMAC
EXDMAC
CPU
CPU
CPU cycle not generated
Figure 11.14 Example of Timing in Burst Mode
11.5.5
Extended Repeat Area Function
The EXDMAC has a function for designating an extended repeat area for source addresses and/or
destination addresses. When an extended repeat area is designated, the address register values
repeat within the range specified as the extended repeat area. Normally, when a ring buffer is
involved in a transfer, an operation is required to restore the address register value to the buffer
start address each time the address register value becomes the last address in the buffer (i.e. when
ring buffer address overflow occurs). However, if the extended repeat area function is used, the
operation that restores the address register value to the buffer start address is processed
automatically within the EXDMAC.
The extended repeat area function can be set independently for the source address register
(EDSAR) and the destination address register (EDDAR).
Rev. 2.00 Oct. 21, 2009 Page 488 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
The source address extended repeat area is specified by bits SARA4 to SARA0 in EDACR, and
the destination address extended repeat area by bits DARA4 to DARA0 in EDACR. The size of
each extended repeat area can be specified independently.
When the address register value is the last address in the extended repeat area and extended repeat
area overflow occurs, EXDMA transfer can be temporarily halted and an extended repeat area
overflow interrupt request can be generated for the CPU. If the SARIE bit in EDACR is set to 1,
and the EDSAR extended repeat area overflows, the ESIF bit is set to 1 and the DTE bit cleared to
0 in EDMDR, and transfer is terminated. If the ESIE bit is set to 1 in EDMDR, an extended repeat
area overflow interrupt is requested to the CPU. If the DARIE bit in EDACR is set to 1, the above
applies to the destination address register. If the DTE bit in EDMDR is set to 1 during interrupt
generation, transfer is resumed.
Figure 11.15 illustrates the operation of the extended repeat area function.
When lower 3 bits (8-byte area) of EDSAR are designated
as extended repeat area (SARA4 to SARA0 = B'00011)
...
External memory
Range of
EDSAR values
H'240000
H'240001
H'240002
H'240003
H'240004
H'240005
H'240006
H'240007
Repeat
Extended repeat area overflow
interrupt can be requested
...
H'23FFFE
H'23FFFF
H'240000
H'240001
H'240002
H'240003
H'240004
H'240005
H'240006
H'240007
H'240008
H'240009
Figure 11.15 Example of Extended Repeat Area Function Operation
Rev. 2.00 Oct. 21, 2009 Page 489 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Caution is required when the extended repeat area overflow interrupt is used together with block
transfer mode. If transfer is always terminated when extended repeat area overflow occurs in block
transfer mode, the block size must be a power of two, or alternatively, the address register value
must be set so that the end of a block coincides with the end of the extended repeat area range. If
extended repeat area overflow occurs during a block-size transfer in block transfer mode, the
extended repeat area overflow interrupt request is held pending until the end of the block, and
transfer overrun will occur.
The same caution is required when the extended repeat area overflow interrupt is used together
with cluster transfer mode.
Figure 11.16 shows an example in which block transfer mode is used together with the extended
repeat area function.
External memory
Range of
EDSAR values
H'23FFFE
H'23FFFF
H'240000
H'240001
H'240002
H'240003
H'240004
H'240005
H'240006
H'240007
H'240008
H'240009
H'240000
H'240001
H'240002
H'240003
H'240004
H'240005
H'240006
H'240007
First block
transfer
H'240000
H'240001
H'240002
H'240003
H'240004
Second block
transfer
H'240000
H'240001
H'240005
H'240006
H'240007
Interrupt
requested
Block transfer in progress
...
...
When lower 3 bits (8-byte area) of EDSAR are designated as extended repeat area (SARA4 to
SARA0 = 3), and block size of 5 (bits 23 to 16 in EDTCR = 5) is set in block transfer mode.
Figure 11.16 Example of Extended Repeat Area Function Operation in Block Transfer
Mode
Rev. 2.00 Oct. 21, 2009 Page 490 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.5.6
Address Update Function Using Offset
There are the following update methods for transfer destination and source addresses: Fixed,
increment/decrement by 1, 2 or 4, and offset addition. With the offset addition method, the offset
specified by the offset register (EDOFR) is added each time the EXDMAC performs a dataaccess-size transfer. This function allows the mid-addresses being skipped during data transfer.
Figure 11.17 shows the address update methods.
External memory
External memory
±0
External memory
±1, 2, or 4
+ Offset
Address not
updated
Value, that corresponds
to data access size,
incremented, decremented
to/from the address
(Successive addresses)
Offset value added to the address
(Insuccessive addresses)
(a) Fixed
(b) Increment/decrement
by 1, 2 or 4
(c) Offset addition
Figure 11.17 Address Update Method
For the fixed method (a), the same address is always indicated without the transfer destination or
source address being updated.
For the method of increment/decrement by 1, 2 or 4 (b), the value corresponding to the data access
size is incremented or decremented to or from the transfer destination or source address each time
the data is transferred. A byte, word, or longword can be specified for the data access size. The
value used for increment or decrement of an address is 1 for a byte-size , 2 for a word-size , and 4
for a longword-size transfer. This function allows continuous address transfer of EXDMAC.
Rev. 2.00 Oct. 21, 2009 Page 491 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
For the offset addition method (c), address operation is not performed based on the data access
size. The EXDMAC adds the value set by EDOFR to the transfer destination or source address for
each time the data is transferred.
The EXDMAC sets the offset value in EDOFR and operates using EDSAR or EDDAR. The
EXDMAC can only add the offset value, but subtraction of the offset value is also possible by
setting a negative value in EDOFR. Specify a twos complement for a negative offset value.
(1)
Basic transfer using offset
Figure 11.18 shows the basic operation of transfer using an offset.
Data 1
Address A1
Transfer
Offset value
Data 2
Data 1
Data 2
Data 3
Data 4
Data 5
:
Address B1
Address B2 = Address B1 + 4
Address B3 = Address B2 + 4
Address B4 = Address B3 + 4
Address B5 = Address B4 + 4
Address A2
= Address A1 + Offset
:
:
:
Offset value
Data 3
Address A3
= Address A2 + Offset
Data 4
Address A4
= Address A3 + Offset
Offset value
Offset value
Data 5
Address A5
= Address A4 + Offset
Transfer source:
Offset added
Transfer destination: Incremented by 4
(with a longword-size selected)
Figure 11.18 Address Update Function Using Offset
Rev. 2.00 Oct. 21, 2009 Page 492 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
In figure 11.18, the offset addition method is set for updating the transfer source address, and the
method of increment/decrement 1, 2 or 4 is set for updating the transfer destination address. For
updating the second and subsequent transfer source addresses, the data of the address for which
the offset value is added to the previous transfer address is read. This data is written to the
successive area on the transfer destination.
(2)
Example of XY conversion using offset
Figure 11.19 shows the XY conversion by combining the repeat transfer mode and offset
addition.
Data 1
Data 2
Data 3
Data 4
Data 5 Data 9 Data 13
Data 6 Data 10 Data 14
Data 7 Data 11 Data 15
Data 8 Data 12 Data 16
1st transfer
Transfer
First cycle
Second cycle
Third cycle
First cycle
Data 1
Data 5
Data 9
Data 13
Data 2 Data 3
Data 6 Data 7
Data 10 Data 11
Data 14 Data 15
Data 4
Data 8
Data 12
Data 16
2nd transfer Transfer source 3rd transfer
address
overwritten
by CPU
Offset value
Offset value
Offset value
Data 1
Data 5
Data 9
Data 13
Data 2
Data 6
Data 10
Data 14
Data 3
Data 7
Data 11
Data 15
Data 4
Data 8
Data 12
Data 16
Address
restored
Interrupt
requested
Data 1
Data 5
Data 9
Data 13
Data 2
Data 6
Data 10
Data 14
Data 3
Data 7
Data 11
Data 15
Data 4
Data 8
Data 12
Data 16
Address
restored
Interrupt
requested
Data 1
Data 5
Data 9
Data 13
Data 2
Data 6
Data 10
Data 14
Data 3
Data 7
Data 11
Data 15
Data 4
Data 8
Data 12
Data 16
Transfer
Transfer source
address
overwritten
by CPU
Interrupt
requested
Data 1
Data 2
Data 3
Data 4
Data 5
Data 6
Data 7
Data 8
Data 9
Data 10
Data 11
Data 12
Data 13
Data 14
Data 15
Data 16
First cycle
Second cycle
Third cycle
Fourth cycle
Figure 11.19 XY Conversion by Combining Repeat Transfer Mode and Offset Addition
In figure 11.19, the source address side is set as a repeat area in EDACR and the offset addition is
set in EDACR. The offset value is the address that corresponds to 4 × data access size (example:
for a longword-size transfer, H'00000010 is specified in EDOFR). The repeat size is 4 × data
access size (example: for a longword-size transfer, 4 × 4 = 16 bytes are specified as a repeat size).
The increment by 1, 2 or 4 is set for the transfer destination. The RPTIE bit in EDACR is set to 1
to generate a repeat size end interrupt request at the end of a repeat-size transfer.
Rev. 2.00 Oct. 21, 2009 Page 493 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
When transfer starts, the offset value is added to the transfer source address and the data is
transferred. The data is aligned in the order of transfer in the transfer destination. After up to data
4 is transferred, the EXDMAC assumes that a repeat-size transfer completed, and restores the
transfer source address to the transfer start address (address of transfer source data 1). At the same
time, a repeat size end interrupt is requested. This interrupt request aborts the transfer temporarily.
Overwrite the EDSAR value to the data 5 address by accessing the I/O register via the CPU. (For
longword transfer, add 4 to the address of data 1.) When the DTE bit in EDMDR is set to 1,
transfer is resumed from the state in which the transfer is aborted. The transfer source data is XYconverted and transferred to the transfer destination by repeating the above processing.
Figure 11.20 shows the XY conversion flow.
Start
Set address and transfer count
Set repeat transfer mode
Enable repeat cancel interrupt
Set DTE bit to 1
Transfer request accepted
No
Data transfer
Repeat size = 0
Yes
Transfer counter and
repeat size decremented
Transfer source address restored
End of repeat size
Interrupt requested
No
Transfer count = 0
Yes
Set transfer source address + 4
(For longword transfer)
End
: User side
:EXDMAC side
Figure 11.20 Flow of XY Conversion Combining Repeat Transfer Mode and Offset
Addition
Rev. 2.00 Oct. 21, 2009 Page 494 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(3)
Offset subtraction specification
To set a negative value in EDOFR, specify a twos complement as an offset value. A twos
complement is derived by the following expression:
[Twos complement expression for negative offset value] = −[offset value] + 1 (−: bit reverse)
Example: Twos complement expression of H'0001FFFF
= H'FFFE0000 + H'00000001
= H'FFFE0001
A twos complement can be derived by the NEG.L instruction of the CPU.
11.5.7
Registers during EXDMA Transfer Operation
EXDMAC register values are updated as EXDMA transfer processing is performed. The updated
values depend on various settings and the transfer status. The following registers and bits are
updated: EDSAR, EDDAR, EDTCR, bits BKSZH and BKSZ in EDBSR, and bits DTE, ACT,
ERRF, ESIF and DTIF in EDMDR.
(1)
EXDMA Source Address Register (EDSAR)
When the EDSAR address is accessed as the transfer source, the EDSAR value is output, and then
EDSAR is updated with the address to be accessed next.
Bits SAT1 and SAT0 in EDACR specify incrementing or decrementing. The address is fixed
when SAT1 and SAT0 = B′00, incremented by offset register value when SAT1 and SAT0 =
B′01, incremented when SAT1 and SAT0 = B′10, and decremented when SAT1 and SAT0 =
B′11. (The increment or decrement value is determined by the data access size.)
The DTSZ1 and DTSZ0 bits in EDMDR set the data access size. When DTSZ1 and DTSZ0 =
B′00, the data is byte-size and the address is incremented or decremented by 1. When DTSZ1 and
DTSZ0 = B′01, the data is word-size and the address is incremented or decremented by 2. When
DTSZ1and DTSZ0 = B′10, the data is longword-size and the address is incremented or
decremented by 4. When a word-size or longword-size is specified but the source address is not at
the word or longword boundary, the data is divided into bytes or words for reading. When a word
or longword is divided for reading, the address is incremented or decremented by 1 or 2 according
to an actual byte-or word-size read. After a word-size or longword-size read, the address is
incremented or decremented to or from the read start address according to the setting of SAT1 and
SAT0.
Rev. 2.00 Oct. 21, 2009 Page 495 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
When a block area (repeat area) is set for the source address in block transfer mode (or repeat
transfer mode), the source address is restored to the transfer start address at the end of block-size
(repeat-size) transfer and is not affected by address updating.
When an extended repeat area is set for the source address, the operation conforms to that setting.
The upper addresses set for the extended repeat area is fixed, and is not affected by address
updating.
When EDSAR is read during a transfer operation, a longword access must be used. During a
transfer operation, EDSAR may be updated without regard to accesses from the CPU, and the
correct values may not be read if the upper and lower words are read separately. Do not write to
EDSAR for a channel on which a transfer operation is in progress.
(2)
EXDMA Destination Address Register (EDDAR)
When the EDDAR address is accessed as the transfer destination, the EDDAR value is output, and
then EDDAR is updated with the address to be accessed next.
Bits DAT1 and DAT0 in EDACR specify incrementing or decrementing. The address is fixed
when DAT1 and DAT0 = B′00, incremented by offset register value when DAT1 and DAT0 =
B′01, incremented when DAT1 and DAT0 = B′10, and decremented when DAT1 and DAT0 =
B′11. (The increment or decrement value is determined by the data access size.)
The DTSZ1 and DTSZ0 bits in EDMDR set the data access size. When DTSZ1 and DTSZ0 =
B′00, the data is byte-size and the address is incremented or decremented by 1. When DTSZ1 and
DTSZ0 = B′01, the data is word-size and the address is incremented or decremented by 2. When
DTSZ1 and DTSZ0 = B′10, the data is longword-size and the address is incremented or
decremented by 4. When a word-size or longword-size is specified but the destination address is
not at the word or longword boundary, the data is divided into bytes or words for writing. When a
word or a longword is divided for writing, the address is incremented or decremented by 1 or 2
according to an actual byte- or word-size written. After a word-size or longword-size write, the
address is incremented or decremented to or from the write start address according to the setting of
SAT1 and SAT0.
When a block area (repeat area) is set for the destination address in block transfer mode (or repeat
transfer mode), the destination address is restored to the transfer start address at the end of blocksize (repeat-size) transfer and is not affected by address updating.
When an extended repeat area is set for the destination address, the operation conforms to that
setting. The upper addresses set for the extended repeat area is fixed, and is not affected by
address updating.
Rev. 2.00 Oct. 21, 2009 Page 496 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
When EDDAR is read during a transfer operation, a longword access must be used. During a
transfer operation, EDDAR may be updated without regard to accesses from the CPU, and the
correct values may not be read if the upper and lower words are read separately. Do not write to
EDDAR for a channel on which a transfer operation is in progress.
(3)
EXDMA Transfer Count Register (EDTCR)
When an EXDMA transfer is performed, the value in EDTCR is decremented by the number of
bytes transferred. When a byte is transferred, the value is decremented by 1; when a word is
transferred, the value is decremented by 2; when a longword is transferred, the value is
decremented by 4. However, when the EDTCR value is 0, transfers are not counted and the
EDTCR value does not change.
All of the bits of EDTCR may change, so when EDTCR is read by the CPU during EXDMA
transfer, a longword access must be used. During a transfer operation, EDTCR may be updated
without regard to accesses from the CPU, and the correct values may not be read if the upper and
lower words are read separately. Do not write to EDTCR for a channel on which a transfer
operation is in progress.
If there is conflict between an address update associated with EXDMA transfer and a write by the
CPU, the CPU write has priority.
In the event of conflict between an EDTCR update from 1, 2, or 4 to 0 and a write (of a nonzero
value) by the CPU, the CPU write value has priority as the EDTCR value, but transfer is
terminated.
(4)
EXDMA Block Size Register (EDBSR)
EDBSR is valid in block transfer or repeat transfer mode. EDBSR31 and EDBSR16 are used as
BKSZH and EDBSR15 and EDBSR0 for BKSZ. The 16 bits of BKSZH holds a block size and
repeat size and their values do not change. The 16 bits of BKSZ functions as a block size or repeat
size counter, the value of which is decremented by 1 when one data transfer is performed. When
the BKSZ value is determined as 0 during EXDMA transfer, the EXDMAC does not store 0 in
BKSZ and stores the BKSZH value.
The upper 16 bits of EDBSR is never updated, allowing a word-size access.
Do not write to EDBSR for a channel on which a transfer operation is in progress.
Rev. 2.00 Oct. 21, 2009 Page 497 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(5)
DTE Bit in EDMDR
The DTE bit in EDMDR is written to by the CPU to control enabling and disabling of data
transfer, but may be cleared to 0 automatically by the EXDMAC due to the EXDMA transfer
status.
Conditions for DTE bit clearing by the EXDMAC include the following:
• When the specified total transfer size is completely transferred
• A transfer size error interrupt is requested, and transfer ends
• A repeat size end interrupt is requested, and transfer ends
• When an extended repeat area overflow interrupt is requested, and transfer ends
• When an NMI interrupt is generated, and transfer halts
• When an address error is generated, and transfer halts
• A reset
• Hardware standby mode
• When 0 is written to the DTE bit, and transfer halts
Writes (except to the DTE bit) are prohibited to registers of a channel for which the DTE bit is set
to 1. When changing register settings after a 0-write to the DTE bit, it is necessary to confirm that
the DTE bit has been cleared to 0.
Figure 11.21 shows the procedure for changing register settings in an operating channel.
Changing register settings
in operating channel
Write 0 to DTE bit
[1]
Read DTE bit
[2]
DTE bit = 0
No
[1] Write 0 to the DTE bit in EDMDR
[2] Read DTE bit.
[3] Confirm that DTE bit = 0. If DTE bit = 1,
this indicates that EXDMA transfer is in progress.
[4] Write the required set values to the registers.
[3]
Yes
Change register settings
[4]
Register setting
changes completed
Figure 11.21 Procedure for Changing Register Settings in Operating Channel
Rev. 2.00 Oct. 21, 2009 Page 498 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(6)
ACT bit in EDMDR
The ACT bit in EDMDR indicates whether the EXDMAC is in standby or active state. When DTE
= 0 and DTE = 1 (transfer request wait status) are specified, the ACT bit is set to 0. In another case
(EXDMAC in the active state), the ACT bit is set to 1. The ACT bit is held to 1 during EXDMA
transfer even if 0 is written to the DTE bit to halt transfer.
In block transfer mode, a block-size transfer is not halted even if 0 is written to the DTE bit to halt
transfer. The ACT bit is held to 1 until a block-size transfer completes after 0 is written to the
DTE bit.
In burst mode, transfer is halted after up to three times of EXDMA transfers are performed since
the bus cycle in which 0 is written to the DTE bit has been processed. The ACT bit is held to 1
between termination of the last EXDMA cycle and 0-write in the DTE bit.
(7)
ERRF bit in EDMDR
This bit specifies termination of transfer by EXDMAC clearing the DTE bit to 0 for all channels if
an address error or NMI interrupt is generated. The EXDMAC also sets 1 to the ERRF bit of
EDMDR_0 regardless of the EXDMAC operation to indicate that an address error or NMI
interrupt is generated. However, when an address error or an NMI interrupt has been generated in
EXDMAC module stop mode, the ERRF bit is not set to 1.
(8)
ESIF bit in EDMDR
The ESIF bit in EDMDR is set to 1 when a transfer size interrupt, repeat size end interrupt, or an
extended repeat area overflow interrupt is requested. When the ESIF bit is set to 1 and the ESIE
bit in EDMDR is set to 1, a transfer escape interrupt is requested to the CPU or DTC.
The timing that the ESIF bit is set to 1 is when the EXDMA transfer bus cycle (the source of an
interrupt request) terminates, the ACT bit in EDMDR is set to 0, and transfer is terminated.
When the DTE bit is set to 1 to resume transfer during interrupt processing, the ESIF bit is
automatically cleared to 0 to cancel the interrupt request.
For details on interrupts, see section 11.9, Interrupt Sources.
Rev. 2.00 Oct. 21, 2009 Page 499 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(9)
DTIF bit in EDMDR
The DTIF bit in EDMDR is set to 1 after the data of total transfer size is transferred completely by
EXDMA transfer. When the DTIF bit is set to 1 and the DTIE bit in EDMDR is set to 1, a transfer
end interrupt by the transfer counter is requested to the CPU or DTC.
The timing that the DTIF bit is set to 1 is when the EXDMA transfer bus cycle is terminated, the
ACT bit in EDMDR is set to 0, and the transfer is terminated.
When the DTE bit is set to 1 to resume transfer during interrupt processing, the DTIF bit is
automatically cleared to 0 to cancel the interrupt request.
For details on interrupts, see section 11.9, Interrupt Sources.
11.5.8
Channel Priority Order
The priority order of the EXDMAC channels is: channel 0 > channel 1 > channel 2 > channel 3.
Table 11.6 shows the EXDMAC channel priority order.
Table 11.6 EXDMAC Channel Priority Order
Channel
Channel Priority
Channel 0
High
Channel 1
Channel 2
Channel 3
Low
If transfer requests occur simultaneously for a number of channels, the highest-priority channel
according to the priority order is selected for transfer. Transfer starts after the channel in progress
releases the bus. If a bus request is issued from another bus master other than EXDMAC during a
transfer operation, another bus master cycle is initiated.
Channels are not switched during burst transfer, a block-size transfer in block transfer mode or a
cluster-size transfer in cluster transfer mode.
Figure 11.22 shows an example of the transfer timing when transfer requests occur simultaneously
for channels 0, 1, and 2.
Rev. 2.00 Oct. 21, 2009 Page 500 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Channel 1 transfer
Channel 0 transfer
Channel 2 transfer
Bφ
Address bus
Channel 0
Idle
EXDMAC
control
Channel 0
Request cleared
Channel 1
Request Selected
held
Channel 2
Request Not
Request
held
selected held
Idle
Channel 2
Channel 1
Channel 0
Channel 2
Channel 1
Request cleared
Selected
Request cleared
Figure 11.22 Example of Channel Priority Timing
11.5.9
Basic Bus Cycles
An example of the basic bus cycle timing is shown in figure 11.23. In this example, word-size
transfer is performed from 16-bit, 2-state access space to 8-bit, 3-state access space. When the bus
mastership is transferred from the CPU to the EXDMAC, a source address read and destination
address write are performed. The bus is not released in response to another bus request, etc.,
between these read and write operations. As like CPU cycles, EXDMAC cycles conform to the
bus controller settings.
CPU cycle
EXDMAC cycle (one word transfer)
T1
T2
T1
T2
T3
T1
T2
CPU cycle
T3
Bφ
Source address
Destination address
Address bus
RD
LHWR
High
LLWR
Figure 11.23 Example of EXDMA Transfer Bus Timing
Rev. 2.00 Oct. 21, 2009 Page 501 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.5.10 Bus Cycles in Dual Address Mode
(1)
Normal Transfer Mode (Cycle Steal Mode)
In cycle steal mode, the bus is released after one byte, word, or longword has been transferred.
While the bus is released, one CPU, DMAC, or DTC bus cycle is initiated.
Figure 11.24 shows an example of transfer when ETEND output is enabled, and word-size, normal
transfer mode (cycle steal mode) is performed from external 16-bit, 2-state access space to
external 16-bit, 2-state access space.
EXDMA read EXDMA write
EXDMA read EXDMA write
EXDMA read EXDMA write
Bφ
Address bus
RD
LHWR, LLWR
ETEND
Bus
release
Bus
release
Bus
release
Last transfer cycle
Bus
release
Figure 11.24 Example of Normal Transfer Mode (Cycle Steal Mode) Transfer
Figures 11.25 and 11.26 show examples of transfer when ETEND output is enabled, and
longword-size, normal transfer mode (cycle steal mode) is performed from external 16-bit, 2-state
access space to external 16-bit, 2-state access space.
In figure 11.25, the transfer source (SAR) address is not at a longword boundary and the transfer
destination (DAR) address is at the longword boundary.
In figure 11.26, the transfer source (SAR) address is at the longword boundary and the transfer
destination (DAR) address is not at the longword boundary.
Rev. 2.00 Oct. 21, 2009 Page 502 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
EXDMA byte EXDMA word EXDMA byte EXDMA word EXDMA word
read cycle
read cycle
read cycle
write cycle
write cycle
EXDMA byte EXDMA word EXDMA byte EXDMA word EXDMA word
read cycle
read cycle
read cycle
write cycle
write cycle
Bφ
Address
bus
4m + 1
4m + 2
4m + 4
4n
4n + 2
4m + 5
4m + 6
4m + 8
4n + 4
4n + 6
RD
LHWR
LLWR
TEND
Bus
released
Bus
released
Last transfer cycle
Bus
released
m and n are integers.
Figure 11.25 Example of Normal Transfer Mode (Cycle Steal Mode) Transfer
(Transfer Source EDSAR = Odd Address, Source Address Incremented)
EXDMA word EXDMA word EXDMA byte EXDMA word EXDMA byte
read cycle
read cycle
write cycle
write cycle
write cycle
EXDMA word EXDMA word EXDMA byte EXDMA word EXDMA byte
read cycle
read cycle
write cycle
write cycle
write cycle
Bφ
Address
bus
4m
4m + 2
4n + 5
4n + 6
4n + 8
4m + 4
4m + 6
4n + 1
4n + 2
4n + 4
RD
LHWR
LLWR
ETEND
Bus
released
Bus
released
Last transfer cycle
Bus
released
m and n are integers.
Figure 11.26 Example of Normal Transfer Mode (Cycle Steal Mode) Transfer
(Transfer Destination EDDAR = Odd Address, Destination Address Decremented)
Rev. 2.00 Oct. 21, 2009 Page 503 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(2)
Normal Transfer Mode (Burst Mode)
In burst mode, one-byte, one-word, or one-longword transfer is executed continuously until the
transfer end condition is satisfied.
Once burst transfer starts, requests from other channels, even of higher priority, are held pending
until burst transfer ends.
Figure 11.27 shows an example of transfer when ETEND output is enabled, and word-size, normal
transfer mode (burst mode) is performed from external 16-bit, 2-state access space to external 16bit, 2-state access space.
EXDMA read EXDMA write
EXDMA read
EXDMA write EXDMA read
EXDMA write
Bφ
Address bus
RD
LHWR, LLWR
ETEND
Last transfer cycle Bus
release
Bus
release
Burst transfer
Figure 11.27 Example of Normal Transfer Mode (Burst Mode) Transfer
Rev. 2.00 Oct. 21, 2009 Page 504 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(3)
Block Transfer Mode
In block transfer mode, one block is transferred in response to one transfer request, and after the
transfer, the bus is released.
Figure 11.28 shows an example of transfer when ETEND output is enabled, and word-size, block
transfer mode is performed from external 16-bit, 2-state access space to external 16-bit, 2-state
access space.
EXDMA
read
EXDMA
write
EXDMA
read
EXDMA
write
EXDMA
read
EXDMA
write
EXDMA
read
EXDMA
write
Bφ
Address
bus
RD
LHWR,
LLWR
ETEND
Bus
release
Block transfer
Bus
release
Last block transfer cycle
Bus
release
Figure 11.28 Example of Block Transfer Mode Transfer
Rev. 2.00 Oct. 21, 2009 Page 505 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(4)
EDREQ Pin Falling Edge Activation Timing
Figure 11.29 shows an example of normal transfer mode transfer activated by the EDREQ pin
falling edge.
EDREQ pin sampling is performed in each cycle starting at the next rise of Bφ after the end of the
DTE bit write cycle.
When a low level is sampled at the EDREQ pin while acceptance of a transfer request via the
EDREQ pin is possible, the request is held within the EXDMAC. Then when activation is initiated
within the EXDMAC, the request is cleared, and EDREQ pin high level sampling for edge sensing
is started. If EDREQ pin high level sampling is completed by the end of the EXDMA write cycle,
acceptance resumes after the end of the write cycle, and EDREQ pin low level sampling is
performed again. This sequence of operations is repeated until the end of the transfer.
Bus release
EXDMA read
EXDMA write
Bus release
EXDMA read EXDMA write
Bus release
Bφ
EDREQ
Transfer
source
Address bus
EXDMA
control
Read
Idle
Request
Channel
Transfer
destination
Transfer
source
Write
Request clearance period
Request
[2]
Write
Idle
Request clearance period
Minimum 3 cycles
Minimum 3 cycles
[1]
Read
Idle
Transfer
destination
[3]
[4]
[5]
Acceptance resumed
[6]
[7]
Acceptance resumed
[1] Acceptance after transfer enabling; EDREQ pin low level is sampled at rise of Bφ, and request is held.
[2], [5] Request is cleared at end of next bus cycle, and activation is started in EXDMAC.
[3], [6] EXDMA cycle starts; EDREQ pin high level sampling is started at rise of Bφ.
[4], [7] When EDREQ pin high level has been sampled, acceptance is resumed after completion of write cycle.
(As in [1], EDREQ pin low level is sampled at rise of Bφ, and request is held.)
Figure 11.29 Example of Normal Transfer Mode Transfer Activated
by EDREQ Pin Falling Edge
Rev. 2.00 Oct. 21, 2009 Page 506 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Figure 11.30 shows an example of block transfer mode transfer activated by the EDREQ pin
falling edge.
EDREQ pin sampling is performed in each cycle starting at the next rise of Bφ after the end of the
DTE bit write cycle.
When a low level is sampled at the EDREQ pin while acceptance of a transfer request via the
EDREQ pin is possible, the request is held within the EXDMAC. Then when activation is initiated
within the EXDMAC, the request is cleared, and EDREQ pin high level sampling for edge sensing
is started. If EDREQ pin high level sampling is completed by the end of the EXDMA write cycle,
acceptance resumes after the end of the write cycle, and EDREQ pin low level sampling is
performed again. This sequence of operations is repeated until the end of the transfer.
One block transfer
One block transfer
EXDMA
read
Bus release
EXDMA
write
Bus release
EXDMA
read
EXDMA
write
Transfer
source
Transfer
destination
Bus release
Bφ
EDREQ
Transfer
source
Address bus
EXDMA
control
Channel
Idle
Request
Read
Transfer
destination
Request clearance period
[2]
Write
Idle
Request clearance period
Request
Minimum 3 cycles
[1]
Read
Idle
Write
Minimum 3 cycles
[3]
[4]
[5]
[6]
Acceptance resumed
[7]
Acceptance resumed
[1] Acceptance after transfer enabling; EDREQ pin low level is sampled at rise of Bφ, and request is held.
[2], [5] Request is cleared at end of next bus cycle, and activation is started in EXDMAC.
[3], [6] EXDMA cycle starts; EDREQ pin high level sampling is started at rise of Bφ.
[4], [7] When EDREQ pin high level has been sampled, acceptance is resumed after completion of write cycle.
(As in [1], EDREQ pin low level is sampled at rise of Bf, and request is held.)
Figure 11.30 Example of Block Transfer Mode Transfer Activated
by EDREQ Pin Falling Edge
Rev. 2.00 Oct. 21, 2009 Page 507 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(5)
EDREQ Pin Low Level Activation Timing
Figure 11.31 shows an example of normal transfer mode transfer activated by the EDREQ pin low
level.
EDREQ pin sampling is performed in each cycle starting at the next rise of Bφ after the end of the
DTE bit write cycle.
When a low level is sampled at the EDREQ pin while acceptance of a transfer request via the
EDREQ pin is possible, the request is held within the EXDMAC. Then when activation is initiated
within the EXDMAC, the request is cleared. After the end of the write cycle, acceptance resumes
and EDREQ pin low level sampling is performed again. This sequence of operations is repeated
until the end of the transfer.
Bus release
EXDMA read EXDMA write
Bus release
EXDMA read
EXDMA write
Transfer
source
Transfer
destination
Bus release
Bφ
EDREQ
Address
bus
Transfer
source
EXDMA
control
Channel
Idle
Read
Request
Transfer
destination
Write
Duration of transfer
request disabled
[2]
Write
Idle
Duration of transfer
request disabled
Request
Minimum 3 cycles
[1]
Read
Idle
Minimum 3 cycles
[3]
[4]
[5]
Transfer request enable resumed
[6]
[7]
Transfer request enable resumed
[1] Acceptance after transfer enabling; EDREQ pin low level is sampled at rise of Bφ, and request is held.
[2], [5] Request is cleared at end of next bus cycle, and activation is started in EXDMAC.
[3], [6] EXDMA cycle starts.
[4], [7] Acceptance is resumed after completion of write cycle.
(As in [1], EDREQ pin low level is sampled at rise of Bφ, and request is held.)
Figure 11.31 Example of Normal Transfer Mode Transfer Activated
by EDREQ Pin Low Level
Rev. 2.00 Oct. 21, 2009 Page 508 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Figure 11.32 shows an example of block transfer mode transfer activated by the EDREQ pin low
level.
EDREQ pin sampling is performed in each cycle starting at the next rise of Bφ after the end of the
DTE bit write cycle.
When a low level is sampled at the EDREQ pin while acceptance of a transfer request via the
EDREQ pin is possible, the request is held within the EXDMAC. Then when activation is initiated
within the EXDMAC, the request is cleared. After the end of the write cycle, acceptance resumes
and EDREQ pin low level sampling is performed again. This sequence of operations is repeated
until the end of the transfer.
One block transfer
One block transfer
EXDMA read EXDMA write
Bus release
Bus release
EXDMA read
EXDMA write
Transfer
source
Transfer
destination
Bus release
Bφ
EDREQ
Transfer
source
Address bus
EXDMA
control
Channel
Idle
Read
Request
Transfer
destination
Write
Request clearance period
[2]
Idle
Write
Request clearance period
Request
Minimum 3 cycles
[1]
Read
Idle
Minimum 3 cycles
[3]
[4]
[5]
Acceptance resumed
[6]
[7]
Acceptance resumed
[1] Acceptance after transfer enabling; EDREQ pin low level is sampled at rise of Bφ, and request is held.
[2], [5] Request is cleared at end of next bus cycle, and activation is started in EXDMAC.
[3], [6] EXDMA cycle starts.
[4], [7] Acceptance is resumed after completion of write cycle.
(As in [1], EDREQ pin low level is sampled at rise of Bφ, and request is held.)
Figure 11.32 Example of Block Transfer Mode Transfer Activated
by EDREQ Pin Low Level
Rev. 2.00 Oct. 21, 2009 Page 509 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(6)
EDREQ Pin Low Level Activation Timing with NRD = 1 Specified
When the NRD bit is set to 1 in EDMDR, the acceptance timing of the next transfer request can be
delayed one cycle later.
Figure 11.33 shows an example of normal transfer mode transfer activated by the EDREQ pin low
level with NRD = 1 specified.
EDREQ pin sampling is performed in each cycle starting at the next rise of Bφ after the end of the
DTE bit write cycle.
When a low level is sampled at the EDREQ pin while acceptance of a transfer request via the
EDREQ pin is possible, the request is held within the EXDMAC. Then when activation is initiated
within the EXDMAC, the request is cleared. After the end of the write cycle, acceptance resumes
when one cycle of the request clearance period specified by NRD = 1 expires and EDREQ pin low
level sampling is performed again. This sequence of operations is repeated until the end of the
transfer.
EXDMA read EXDMA write
Bus release
EXDMA read EXDMA write
Bus release
Bus release
Bφ
EDREQ
Address
bus
Channel
Transfer
source
Transfer
destination
Transfer
source
Transfer
destination
Extended request
clearance period
specified by NRD
Request
Request clearance period
Minimum 3 cycles
[1]
[2]
Request
Request clearance period
Extended request
clearance period
specified by NRD
Minimum 3 cycles
[3]
[4]
[5]
Acceptance resumed
[6]
[7]
Acceptance resumed
[1] Acceptance after transfer enabling; EDREQ pin low level is sampled at rise of Bφ, and request is held.
[2], [5] Request is cleared at end of next bus cycle, and activation is started in EXDMAC.
[3], [6] EXDMA cycle starts.
[4], [7] Acceptance is resumed after completion of write cycle plus one cycle.
(As in [1], EDREQ pin low level is sampled at rise of Bφ, and request is held.)
Figure 11.33 Example of Normal Transfer Mode Transfer Activated
by EDREQ Pin Low Level with NRD = 1 Specified
Rev. 2.00 Oct. 21, 2009 Page 510 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.5.11 Bus Cycles in Single Address Mode
(1)
Single Address Mode (Read in Cycle Steal Mode)
In single address mode, the bus is released after one byte, word, or longword has been transferred
in response to one transfer request. While the bus is released, one or more CPU, DMAC, or DTC
bus cycles are initiated.
Figure 11.34 shows an example of transfer when ETEND output is enabled, and byte-size, single
address mode transfer (read) is performed from external 8-bit, 2-state access space to an external
device.
EXDMA read
EXDMA read
EXDMA read
EXDMA read
Bφ
Address bus
RD
EDACK
ETEND
Bus
released
Bus
release
Bus
release
Bus
Last transfer Bus
release
release
cycle
Figure 11.34 Example of Single Address Mode (Byte Read) Transfer
Rev. 2.00 Oct. 21, 2009 Page 511 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(2)
Single Address Mode (Write in Cycle Steal Mode)
In single address mode, the bus is released after one byte, word, or longword has been transferred
in response to one transfer request. While the bus is released, one or more CPU, DMAC, or DTC
bus cycles are initiated.
Figure 11.35 shows an example of transfer when ETEND output is enabled, and byte-size, single
address mode transfer (write) is performed from an external device to external 8-bit, 2-state access
space.
EXDMA write
EXDMA write
EXDMA write
EXDMA write
Bφ
Address bus
LLWR
EDACK
ETEND
Bus
release
Bus
release
Bus
release
Bus
release
Last transfer Bus
release
cycle
Figure 11.35 Example of Single Address Mode (Byte Write) Transfer
Rev. 2.00 Oct. 21, 2009 Page 512 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(3)
EDREQ Pin Falling Edge Activation Timing
Figure 11.36 shows an example of single address mode transfer activated by the EDREQ pin
falling edge.
EDREQ pin sampling is performed in each cycle starting at the next rise of Bφ after the end of the
DTE bit write cycle.
When a low level is sampled at the EDREQ pin while acceptance of a transfer request via the
EDREQ pin is possible, the request is held within the EXDMAC. Then when activation is initiated
within the EXDMAC, the request is cleared, and EDREQ pin high level sampling for edge sensing
is started. If EDREQ pin high level sampling is completed by the end of the EXDMA single cycle,
acceptance resumes after the end of the single cycle, and EDREQ pin low level sampling is
performed again. This sequence of operations is repeated until the end of the transfer.
Bus
release
Bus
release
EXDMA single
Bus
EXDMA single release
Bφ
EDREQ
Transfer source/
Transfer destination
Transfer source/
Transfer destination
Address bus
EDACK
EXDMA control
Single
Idle
Request
Channel
Single
Idle
Request clearance period
Request
Minimum 3 cycles
[1]
[2]
Idle
Request clearance period
Minimum 3 cycles
[3]
[4]
[5]
Acceptance resumed
[6]
[7]
Acceptance resumed
[1] Acceptance after transfer enabling; EDREQ pin low level is sampled at rise of Bφ, and request is held.
[2], [5] Request is cleared at end of next bus cycle, and activation is started in EXDMAC.
[3], [6] EXDMA cycle starts; EDREQ pin high level sampling is started at rise of Bφ.
[4], [7] When EDREQ pin high level has been sampled, acceptance is resumed after completion of write cycle.
(As in [1], EDREQ pin low level is sampled at rise of Bφ, and request is held.)
Figure 11.36 Example of Single Address Mode Transfer Activated
by EDREQ Pin Falling Edge
Rev. 2.00 Oct. 21, 2009 Page 513 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(4)
EDREQ Pin Low Level Activation Timing
Figure 11.37 shows an example of single address mode transfer activated by the EDREQ pin low
level.
EDREQ pin sampling is performed in each cycle starting at the next rise of Bφ after the end of the
DTE bit write cycle.
When a low level is sampled at the EDREQ pin while acceptance of a transfer request via the
EDREQ pin is possible, the request is held within the EXDMAC. Then when activation is initiated
within the EXDMAC, the request is cleared. After the end of the single cycle, acceptance resumes
and EDREQ pin low level sampling is performed again. This sequence of operations is repeated
until the end of the transfer.
Bus
release
Bus
release
EXDMA single
EXDMA single
Bus
release
Bφ
EDREQ
Transfer source/
Transfer destination
Address bus
Transfer source/
Transfer destination
EDACK
EXDMA control Idle
Single
Request clearance period
Request
Channel
Minimum 3 cycles
[1]
Single
Idle
[2]
Idle
Request clearance period
Request
Minimum 3 cycles
[3]
[4]
[5]
Acceptance resumed
[6]
[7]
Acceptance resumed
[1] Acceptance after transfer enabling; EDREQ pin low level is sampled at rise of Bφ, and request is held.
[2], [5] Request is cleared at end of next bus cycle, and activation is started in EXDMAC.
[3], [6] EXDMA cycle starts.
[4], [7] Acceptance is resumed after completion of single cycle.
(As in [1], EDREQ pin low level is sampled at rise of Bφ, and request is held.)
Figure 11.37 Example of Single Address Mode Transfer Activated
by EDREQ Pin Low Level
Rev. 2.00 Oct. 21, 2009 Page 514 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(5)
EDREQ Pin Low Level Activation Timing with NRD = 1 Specified
When the NRD bit is set to 1 in EDMDR, the acceptance timing of the next transfer request can be
delayed one cycle later.
Figure 11.38 shows an example of single address mode transfer activated by the EDREQ pin low
level with NRD = 1 specified.
EDREQ pin sampling is performed in each cycle starting at the next rise of Bφ after the end of the
DTE bit write cycle.
When a low level is sampled at the EDREQ pin while acceptance of a transfer request via the
EDREQ pin is possible, the request is held within the EXDMAC. Then when activation is initiated
within the EXDMAC, the request is cleared. After the end of the single cycle, acceptance resumes
when one cycle of the request clearance period specified by NRD = 1 expires and EDREQ pin low
level sampling is performed again. This sequence of operations is repeated until the end of the
transfer.
Bus
release
Bus
release
EXDMA single
EXDMA single
Bus
release
Bφ
EDREQ
Transfer source/
Transfer destination
Transfer source/
Transfer destination
Address bus
Extended request clearance
period specified by NRD
Channel
Request
Request clearance period
Request
Minimum 3 cycles
[1]
[2]
Extended request clearance
period specified by NRD
Request clearance period
Minimum 3 cycles
[3]
[4]
[5]
Acceptance resumed
[6]
[7]
Acceptance resumed
[1] Acceptance after transfer enabling; EDREQ pin low level is sampled at rise of Bφ, and request is held.
[2], [5] Request is cleared at end of next bus cycle, and activation is started in EXDMAC.
[3], [6] EXDMA cycle starts.
[4], [7] Acceptance is resumed after completion of write cycle plus one cycle.
(As in [1], EDREQ pin low level is sampled at rise of Bφ, and request is held.)
Figure 11.38 Example of Single Address Mode Transfer Activated
by EDREQ Pin Low Level with NRD = 1 Specified
Rev. 2.00 Oct. 21, 2009 Page 515 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.5.12 Operation Timing in Each Mode
This section describes examples of operation timing in each mode. The CPU external bus cycle is
shown as an example of conflict with another bus master.
(1)
Auto-Request/Normal Transfer Mode/Cycle Steal Mode
With auto-request (in cycle steal mode), when the DTE bit is set to 1 in EDMDR, an EXDMA
transfer cycle is started a minimum of three cycles later. If there is a transfer request for another
channel of higher priority, the transfer request by the original channel is held pending, and transfer
is performed on the higher-priority channel from the next transfer. Transfer on the original channel
is resumed on completion of the higher-priority channel transfer.
Figures 11.39 and 11.40 show operation timing examples for various conditions.
3 cycles
3 cycles
3 cycles
Bφ
Last transfer cycle
Bus cycle
Bus release
CPU operation
EXDMA
read
EXDMA
write
DTE 1
write
Bus
release
EXDMA
read
EXDMA
write
Bus
release
EXDMA
read
EXDMA
write
Bus
release
Internal bus space cycles
ETEND
DTE bit
0
1
Figure 11.39 Auto-Request/Normal Transfer Mode/Cycle Steal Mode
(No Conflict/Dual Address Mode)
Rev. 2.00 Oct. 21, 2009 Page 516 of 1454
REJ09B0498-0200
0
Section 11 EXDMA Controller (EXDMAC)
Bφ
One bus cycle
CPU cycle
Bus cycle
CPU operation
External
space
EXDMA single
transfer cycle
Last transfer cycle
EXDMA single
transfer cycle
CPU cycle
External space
CPU cycle
EXDMA single
transfer cycle
External space
CPU cycle
External space
EDACK
ETEND
Figure 11.40 Auto-Request/Normal Transfer Mode/Cycle Steal Mode
(CPU Cycles/Single Address Mode)
(2)
Auto-Request/Normal Transfer Mode/Burst Mode
With auto-request (in burst mode), when the DTE bit is set to 1 in EDMDR, an EXDMA transfer
cycle is started a minimum of three cycles later. Once transfer is started, it continues (as a burst)
until the transfer end condition is satisfied. Transfer requests for other channels are held pending
until the end of transfer on the current channel.
Figures 11.41 to 11.43 show operation timing examples for various conditions.
Bφ
Last transfer cycle
Bus cycle
CPU operation
CPU cycle
CPU cycle
External
space
External
space
EXDMAC
read
EXDMAC
write
EXDMAC
read
EXDMAC
write
Repeated
EXDMAC
read
EXDMAC
write
CPU cycle
External space
ETEND
DTE bit
1
0
Figure 11.41 Auto-Request/Normal Transfer Mode/Burst Mode
(CPU Cycles/Dual Address Mode)
Rev. 2.00 Oct. 21, 2009 Page 517 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bφ
Last transfer cycle
Bus cycle
Bus release
EXDMAC single
transfer cycle
EXDMAC single
transfer cycle
EXDMAC single
transfer cycle
EXDMAC cycle of
another channel
Bus
release
EDACK of
current channel
ETEND of
current channel
Transfer request of
another channel
EDREQ
Figure 11.42 Auto-Request/Normal Transfer Mode/Burst Mode
(Conflict with Another Channel/Single Address Mode)
Bus cycle
EXDMA
CPU operation Internal space
EXDMA
CPU
External space
EXDMA
CPU
External space
EXDMA
EXDMA
Internal space
Figure 11.43 External Bus Master Cycle Steal Function (Auto-Request/Normal Transfer
Mode/Burst Mode with CPU Cycles/Single Address Mode/EBCCS = 1)
(3)
External Request/Normal Transfer Mode/Cycle Steal Mode
In external request mode, an EXDMA transfer cycle is started a minimum of three cycles after a
transfer request is accepted. The next transfer request is accepted after the end of a one-transferunit EXDMA cycle. For external bus space CPU cycles, at least one bus cycle is generated before
the next EXDMA cycle.
If a transfer request is generated for another channel, an EXDMA cycle for the other channel is
generated before the next EXDMA cycle.
The EDREQ pin sensing timing is different for low level sensing and falling edge sensing. The
same applies to transfer request acceptance and transfer start timing.
Rev. 2.00 Oct. 21, 2009 Page 518 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Figures 11.44 to 11.47 show operation timing examples for various conditions.
Bφ
EDREQ
EDRAK
3 cycles
Bus cycle
Bus release
EXDMA
read
EXDMA
write
Last transfer cycle
Bus release
EXDMA
read
EXDMA
write
Bus release
ETEND
0
1
DTE bit
Figure 11.44 External Request/Normal Transfer Mode/Cycle Steal Mode
(No Conflict/Dual Address Mode/Low Level Sensing)
Bφ
EDREQ
EDRAK
One bus cycle
Bus cycle
CPU operation
CPU cycle
CPU cycle
External
space
External
space
EXDMAC single
transfer cycle
CPU cycle
External space
Last transfer cycle
EXDMAC single
transfer cycle
CPU cycle
External space
EDACK
ETEND
Figure 11.45 External Request/Normal Transfer Mode/Cycle Steal Mode
(CPU Cycles/Single Address Mode/Low Level Sensing)
Rev. 2.00 Oct. 21, 2009 Page 519 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Bφ
EDREQ
EDRAK
EDREQ
acceptance
internal
processing
state
Start of transfer by
Start of transfer by
Start of high level sensing internal edge
Start of high level sensing
internal edge
confirmation
confirmation
Bus release
CPU
operation
EXDMAC single
transfer cycle
Bus release
EXDMAC single
transfer cycle
Start of transfer by
internal edge
Start of high level sensing
confirmation
Bus release
EXDMAC single
transfer cycle
EDACK
Figure 11.46 External Request/Normal Transfer Mode/Cycle Steal Mode (No
Conflict/Single Address Mode/Falling Edge Sensing)
Bφ
EDREQ of
current channel
EDRAK of
current channel
3 cycles
Bus cycle
EXDMAC
transfer cycle
Bus release
EXDMA
read
EXDMA
write
Transfer cycles of another channel
EXDMA
read
EDREQ of
another channel
EDRAK of
another channel
Figure 11.47 External Request/Normal Transfer Mode/Cycle Steal Mode
(Conflict with Another Channel/Dual Address Mode/Low Level Sensing)
Rev. 2.00 Oct. 21, 2009 Page 520 of 1454
REJ09B0498-0200
EXDMA
write
Section 11 EXDMA Controller (EXDMAC)
(4)
External Request/Block Transfer Mode/Cycle Steal Mode
In block transfer mode, transfer of one block is performed continuously in the same way as in
burst mode. The timing of the start of the next block transfer is the same as in normal transfer
mode.
If a transfer request is generated for another channel, an EXDMA cycle for the other channel is
generated before the next block transfer.
The EDREQ pin sensing timing is different for low level sensing and falling edge sensing. The
same applies to transfer request acceptance and transfer start timing.
Figures 11.48 to 11.52 show operation timing examples for various conditions.
Rev. 2.00 Oct. 21, 2009 Page 521 of 1454
REJ09B0498-0200
REJ09B0498-0200
Rev. 2.00 Oct. 21, 2009 Page 522 of 1454
DTE bit
ETEND
Bus cycle
EDRAK
EDREQ
Bφ
Bus release
EXDMA
read
EXDMA
write
1
EXDMA
read
EXDMA
write
One block size transfer period
Repeated
EXDMA
read
EXDMA
write
End of block
Bus release
3 cycles
EXDMA
read
EXDMA
write
Repeated
EXDMA
read
0
Bus release
EXDMA
write
Last transfer cycle
Last block
Section 11 EXDMA Controller (EXDMAC)
Figure 11.48 External Request/Block Transfer Mode/Cycle Steal Mode
(No Conflict/Dual Address Mode/Low Level Sensing)
ETEND
EDACK
Bus cycle
EDRAK
EDREQ
Bφ
Bus release
EXDMA single
transfer cycle
EXDMA single
transfer cycle
One block size transfer period
Repeated
EXDMA single
transfer cycle
End of block
Bus release
3 cycles
EXDMA single
transfer cycle
Repeated
EXDMA single
transfer cycle
Last transfer cycle
Last block
Bus
release
Section 11 EXDMA Controller (EXDMAC)
Figure 11.49 External Request/Block Transfer Mode/Cycle Steal Mode
(No Conflict/Single Address Mode/Falling Edge Sensing)
Rev. 2.00 Oct. 21, 2009 Page 523 of 1454
REJ09B0498-0200
REJ09B0498-0200
Rev. 2.00 Oct. 21, 2009 Page 524 of 1454
ETEND
EDACK
External
space
CPU
operation
External
space
CPU cycle
Bus cycle CPU cycle
EDRAK
EDREQ
Bφ
EXDMA single
transfer cycle
External
space
Repeated
EXDMA single
transfer cycle
End of block
One block size transfer period
CPU cycle
Bus cycle
EXDMA single
transfer cycle
External
space
Repeated
EXDMA single
transfer cycle
Last block
One block size transfer period
CPU cycle
Section 11 EXDMA Controller (EXDMAC)
Figure 11.50 External Request/Block Transfer Mode/Cycle Steal Mode
(CPU Cycles/Single Address Mode/Low Level Sensing)
EDRAK of
another channel
EDREQ of
another channel
ETEND
Bus cycle
EDRAK
EDREQ
Bφ
Bus release
EXDMA
read
EXDMA
write
Repeated
EXDMA
read
EXDMA
write
End of block
One block size transfer period
EXDMA cycle of another channel
EXDMA
read
EXDMA
write
Repeated
EXDMA
read
EXDMA
write
Last block
One block size transfer period
Section 11 EXDMA Controller (EXDMAC)
Figure 11.51 External Request/Block Transfer Mode/Cycle Steal Mode
(Conflict with Another Channel/Dual Address Mode/Low Level Sensing)
Rev. 2.00 Oct. 21, 2009 Page 525 of 1454
REJ09B0498-0200
REJ09B0498-0200
Rev. 2.00 Oct. 21, 2009 Page 526 of 1454
ETEND
EDACK
CPU
operation
Bus
cycle
EDRAK
EDREQ
Bφ
External
space
CPU
cycle
External
space
CPU cycle
EXDMA single
transfer cycle
External
space
Repeated
EXDMA single
transfer cycle
End of block
One block size transfer period
CPU cycle
Bus cycle
EXDMA single
transfer cycle
External
space
Repeated
EXDMA single
transfer cycle
Last block
One block size transfer period
CPU
cycle
Section 11 EXDMA Controller (EXDMAC)
Figure 11.52 External Request/Block Transfer Mode/Cycle Steal Mode
(CPU Cycles/EBCCS = 1/Single Address Mode/Low Level Sensing)
Section 11 EXDMA Controller (EXDMAC)
11.6
Operation in Cluster Transfer Mode
In cluster transfer mode, transfer is performed by the consecutive read and write operations of 1 to
32 bytes using the cluster buffer. A part of the cluster transfer mode function differs from the
ordinary transfer mode functions (normal transfer, repeat transfer, and block transfer modes).
11.6.1
(1)
Address Mode
Cluster Transfer Dual Address Mode (AMS = 0)
In this mode, both the transfer source and destination addresses are specified for transfer in the
EXDMAC internal registers. The transfer source address is set in the source address register
(EDSAR), and the transfer destination address is set in the destination address register (EDDAR).
The transfer is processed by performing the consecutive read of a cluster-size from the transfer
source address and then the consecutive write of that data to the transfer destination address. One
data access size to 32 bytes can be specified as a cluster size. When one data access size is
specified as a cluster size, block transfer mode (dual address mode) is used.
The cycles in a cluster-size transfer are indivisible: another bus cycle (external access by another
bus master, refresh cycle, or external bus release cycle) does not occur in a cluster-size transfer.
ETEND pin output can be enabled or disabled by means of the ETENDE bit in EDMDR. ETEND
is output for the last write cycle. The EDACK signal is not output.
Figure 11.53 shows the data flow in the cluster transfer mode (dual address mode), figure 11.54
shows an example of the timing in cluster transfer dual address mode, and figure 11.55 shows the
cluster transfer dual address mode operation.
LSI
Transfer source: External memory
Transfer destination: External device
EDDAR acces
EDSAR access
Read Read
Read
Write Write
Read
Write
Write
Cluster buffer
One cluster size
One cluster size
Consecutive
read
Consecutive
write
Figure 11.53 Data Flow in Cluster Transfer Dual Address Mode
Rev. 2.00 Oct. 21, 2009 Page 527 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
EXDMA write cycle
EXDMA read cycle
Bφ
Address bus
EDSAR
EDSAR
EDSAR
EDDAR
EDDAR
EDDAR
RD
WR
ETEND
Figure 11.54 Timing in Cluster Transfer Dual Address Mode
Address TA
First cluster
Transfer
Address TB
First cluster
Cluster size:
BKSZH ×
Data accsess size
Second cluster
Second cluster
Nth cluster
Nth cluster
Address BA
Address BB
Figure 11.55 Cluster Transfer Dual Address Mode Operation
When a word or longword is specified as a data access size but the source or destination address is
not at the word or longword boundary, use the appropriate data access size for efficient data
transfer.
In an example shown in figure 11.56, a longword-size transfer is performed with 4-longword
specified as a cluster size in the cluster transfer dual address mode from the lower two bits of B'11
to B'10.
Rev. 2.00 Oct. 21, 2009 Page 528 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
The cluster size is decremented regardless of the read or write operation in the consecutive write
sequences.
Transfer source memory
Cluster buffer
Transfer destination memory
LSB
MSB
CLSBR0
1
2
CLSBR1
2
3
CLSBR2
3
4
CLSBR3
4
Byte 1
H'AA0000
H'AA0004
Long Word 2
H'AA0008
Long Word 3
H'AA000C
Long Word 4
H'AA0010
Word 5
5
H'BB0000
6
Byte 6
Long Word
H'BB0008
Long Word
H'BB000C
H'BB0010
CLSBR4
Word
H'BB0004
Long Word
Word
CLSBR5
CLSBR6
CLSBR7
Figure 11.56 Odd Address Transfer
(2)
Cluster Transfer Read Address Mode (AMS = 1, DIRS = 0)
In this mode, the transfer source address is specified in the source address register (EDSAR) and
data is read from the transfer source and transferred to the cluster buffer. In this mode, the TSEIE
bit in the mode control register (EDMDR) must be set to 1.
Two data access size to 32 bytes can be specified as a cluster size for the consecutive read
operation.
The cycles in a cluster-size transfer are indivisible: another bus cycle (external access by another
bus master, refresh cycle, or external bus release cycle) does not occur in a cluster-size transfer.
ETEND pin output can be enabled or disabled by means of the ETENDE bit in EDMDR. ETEND
is output for the last read cycle. When an idle cycle is inserted before the last read cycle, the
ETEND signal is also output in the idle cycle.
In this mode, the EDACKE bit in EDMDR must be set to 0 to disable the EDACK pin output.
Figure 11.57 shows the data flow in the cluster transfer read address mode (from the external
memory to the cluster buffer), and figure 11.58 shows an example of the timing in cluster transfer
read address mode.
Rev. 2.00 Oct. 21, 2009 Page 529 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
LSI
Address bus
Cluster buffer
EDSAR access
Transfer source
external memory
External data bus
CPU
Register read
Figure 11.57 Data Flow in Cluster Transfer Read Address Mode (
from External Memory to Cluster Buffer)
EXDMA read cycle
Bφ
Address bus
EDSAR
EDSAR
EDSAR
RD
High
WR
ETEND
Figure 11.58 Timing in Cluster Transfer Read Address Mode
(from External Memory to Cluster Buffer)
Rev. 2.00 Oct. 21, 2009 Page 530 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(3)
Cluster Transfer Write Address Mode (AMS = 1, DIRS = 1)
In this mode, the transfer destination address is specified in the destination address register
(EDDAR) and data in the cluster butter is written to the transfer destination. In this mode, the
TSEIE bit in the mode control register (EDMDR) must be set to 1.
One data access size to 32 bytes can be specified as a cluster size for the consecutive write
operation. When one data access size is specified as a cluster size, the cluster transfer write
address mode is used.
The cycles in a cluster-size transfer are indivisible: another bus cycle (external access by another
bus master, refresh cycle, or external bus release cycle) does not occur in a cluster-size transfer.
ETEND pin output can be enabled or disabled by means of the ETENDE bit in EDMDR. ETEND
is output for the last write cycle. When an idle cycle is inserted before the last write cycle, the
ETEND signal is also output in the idle cycle.
In this mode, the EDACKE bit in EDMCR must be set to 0 to disable the EDACK pin output.
Figure 11.59 shows the data flow in the cluster transfer write address mode (from the cluster
buffer to the external memory), and figure 11.60 shows an example of the timing in cluster
transfer write address mode.
LSI
Address bus
Cluster buffer
EDDAR access
External data bus
Transfer
destination
external
memory
When initializing an area by the specified data, write the specified data from cluster buffer 0 into a register
sequentially. Then, specify the buffer size written in the register as a cluster size and the area to be initialized
as DAR, and then execute transfer in this mode.
Figure 11.59 Data Flow in Cluster Transfer Write Address Mode
(from Cluster Buffer to External Memory)
Rev. 2.00 Oct. 21, 2009 Page 531 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
EXDMA write cycle
Bφ
EDDAR
Address bus
RD
EDDAR
EDDAR
High
WR
ETEND
Figure 11.60 Timing in Cluster Transfer Write Address Mode
(from Cluster Buffer to External Memory)
11.6.2
Setting of Address Update Mode
The cluster transfer mode transfer is restricted by the address update mode function. There are the
following four address update methods: increment, decrement, fixed, and offset addition.
When the address increment method is specified and if the specified address is not at the address
boundary for the data access size (odd address for a word-size transfer, address beyond the 4n
boundary for a longword-size transfer), the bus cycle is divided for transfer until the address
becomes at the address boundary. When the address matches the boundary, transfer is processed in
units of data access sizes. At the end of transfer, the bus cycle is divided again to transfer the
remaining data in cluster transfer mode.
With address decrement, fixed, or offset addition method, specify the address, that matches the
address boundary for the data access size, in EDSAR and EDDAR. When specifying the address,
that is not at the address boundary for the data access size, in EDSAR and EDDAR, fix the lower
bit to 0 (lower one bit for a word-size transfer, and lower two bits for a longword-size transfer) in
the address register so that the transfer is processed in units of data access sizes. The block transfer
mode must be used for transfer of data by dividing the bus cycle according to the address
boundary.
When the EDTCR value is smaller than the cluster size, a transfer size error occurs. In this case,
when the TSEIE bit in EDMDR is cleared to 0, the cluster transfer mode is switched to the block
transfer mode to process the remaining data. With the decrement, fixed, or offset addition method,
transfer is performed without fixing the lower bit to 0.
Rev. 2.00 Oct. 21, 2009 Page 532 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.6.3
Caution for Combining with Extended Repeat Area Function
As with the block transfer mode, the address register value must be set in cluster transfer mode, so
that the end of the cluster size coincides with the end of the extended repeat area range.
When an extended repeat area overflow occurs during a cluster-size transfer in the cluster transfer
mode, the extended repeat area overflow interrupt request is held pending until the end of a
cluster-size transfer, and transfer overrun will occur.
11.6.4
(1)
Bus Cycles in Cluster Transfer Dual Address Mode
Cluster transfer mode
In cluster transfer mode, a cluster-size transfer is processed in response to one transfer request.
In an example shown in figure 11.61, the ETEND pin output is enabled, and word-size transfer is
performed with 4-byte cluster size in cluster transfer mode from the external 16-bit, 2-state access
space to the external 16-bit, 2-state access space.
EXDMA read
EXDMA write
Bus
release
EXDMA read
EXDMA write
Bφ
Address bus
RD
LHWR,
LLWR
ETEND
Figure 11.61 Example of Cluster Transfer Mode Transfer
Rev. 2.00 Oct. 21, 2009 Page 533 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(2)
EDREQ Pin Falling Edge Activation Timing
Figure 11.62 shows an example of cluster transfer mode transfer activated by the EDREQ pin
falling edge.
EDREQ pin sampling is performed in each cycle starting at the next rise of Bφ after the end of the
DTE bit write cycle.
When a low level is sampled at the EDREQ pin while acceptance of a transfer request via the
EDREQ pin is possible, the request is held within the EXDMAC. Then when activation is initiated
within the EXDMAC, the request is cleared, and EDREQ pin high level sampling for edge sensing
is started. If EDREQ pin high level sampling is completed by the end of the last cluster write
cycle, acceptance resumes after the end of the write cycle, and EDREQ pin low level sampling is
performed again. This sequence of operations is repeated until the end of the transfer.
One cluster transfer
Bus release
One cluster transfer
Bus release
Bφ
EDREQ
Address bus
Transfer source
EXDMA control
Channel
Consecutive read
Request
[1]
[1]
[2] [5]
[3] [6]
[4] [7]
Minimum 3 cycles
[2]
Transfer destination
Consecutive read
Consecutive write
Request clearance period
[3]
Transfer source
Request
[4]
Minimum 3 cycles
[5]
Transfer destination
Consecutive write
Request clearance period
[6]
Acceptance after transfer enabling; EDREQ pin low level is sampled at rise of Bφ, and request is held.
Request is cleared at end of next bus cycle, and activation is started in EXDMAC.
EXDMA cycle starts; EDREQ pin high level sampling is started at rise of Bφ.
When EDREQ pin high level has been sampled, acceptance is resumed after completion of write cycle.
(As in [1], EDREQ pin low level is sampled at rise of Bφ, and request is held.)
Figure 11.62 Example of Cluster Transfer Mode Transfer Activated
by EDREQ Pin Falling Edge
Rev. 2.00 Oct. 21, 2009 Page 534 of 1454
REJ09B0498-0200
[7]
Section 11 EXDMA Controller (EXDMAC)
(3)
EDREQ Pin Low Level Activation Timing
Figure 11.63 shows an example of cluster transfer mode transfer activated by the EDREQ pin low
level.
EDREQ pin sampling is performed in each cycle starting at the next rise of Bφ after the end of the
DTE bit write cycle.
When a low level is sampled at the EDREQ pin while acceptance of a transfer request via the
EDREQ pin is possible, the request is held within the EXDMAC. Then when activation is initiated
within the EXDMAC, the request is cleared. At the end of the last cluster write cycle, acceptance
resumes and EDREQ pin low level sampling is performed again. This sequence of operations is
repeated until the end of the transfer.
When NRD bit = 0 in EDMDR, acceptance resumes at the end of the last cluster write cycle and
EDREQ pin low level sampling is performed again. This sequence of operations is repeated until
the end of the transfer.
When NRD bit = 1 in EDMDR, acceptance resumes after one cycle from the end of the last cluster
write cycle, and EDREQ pin low level sampling is performed again. This sequence of operations
is repeated until the end of the transfer.
Bus release
One cluster transfer
Bus release
One cluster transfer
Bφ
EDREQ
Address bus
Transfer source
EXDMA control
Consecutive read
Channel
Request
Transfer destination
Consecutive write
Consecutive read
Request
Request clearance period
Minimum 3 cycles
[1]
[1]
[2] [5]
[3] [6]
[4] [7]
[2]
Transfer source
Transfer destination
Consecutive write
Request clearance period
Minimum 3 cycles
[3]
[4]
[5]
[6]
[7]
Acceptance after transfer enabling; EDREQ pin low level is sampled at rise of Bφ, and request is held.
Request is cleared at the end of next bus cycle, and activation is started in EXDMAC.
EXDMA cycle stars.
Acceptance is resumed after completion of wite cycle.
(As in [1], EDREQ pin low level is sampled at rise of Bφ, and request is held.)
Figure 11.63 Example of Cluster Transfer Mode Transfer Activated
by EDREQ Pin Low Level
Rev. 2.00 Oct. 21, 2009 Page 535 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.6.5
Operation Timing in Cluster Transfer Mode
This section describes examples of operation timing in cluster transfer mode. The CPU external
bus cycle is shown as an example of conflict with another bus master.
(1)
Auto-Request/Cluster Transfer Mode/Cycle Steal Mode
With auto-request (in cycle steal mode), when the DTE bit is set to 1 in EDMDR, a continuous
EXDMA transfer cycle is started a minimum of three cycles later. If there is a transfer request for
another channel of higher priority, the transfer request by the original channel is held pending, and
transfer is performed on the higher-priority channel from the next transfer. Transfer on the original
channel is resumed on completion of the higher-priority channel transfer.
The cluster transfer mode (read address mode and write address mode) can not be used with the
cluster transfer mode (dual address mode) among more than one channel at the same time. When
using the cluster transfer mode (read address mode and write address mode), do not set the cluster
transfer mode for another channel.
Figures 11.64 to 11.66 show operation timing examples for various conditions.
Rev. 2.00 Oct. 21, 2009 Page 536 of 1454
REJ09B0498-0200
DTE bit
ETEND
CPU operation
Bus cycle
Bφ
0
DTE
= 1 write
Consecutive
EXDMA write
One cluster transfer
Consecutive
EXDMA read
Internal bus space cycles
Bus release
3 cycles
Bus release
3 cycles
1
Consecutive
EXDMA read
Consecutive
EXDMA write
One cluster transfer
Bus release
3 cycles
Consecutive
EXDMA read
Consecutive
EXDMA write
Last cluster cycle
0
Section 11 EXDMA Controller (EXDMAC)
Figure 11.64 Auto-Request/Cluster Transfer Mode/Cycle Steal Mode
(No Confict/Dual Address Mode)
Rev. 2.00 Oct. 21, 2009 Page 537 of 1454
REJ09B0498-0200
Rev. 2.00 Oct. 21, 2009 Page 538 of 1454
REJ09B0498-0200
DTE bit
ETEND
CPU operation
Bus cycle
Bφ
External space
CPU cycle
0
DTE = 1 write
CPU cycle
Consecutive
EXDMA write
External space
Consecutive
EXDMA read
One cluster transfer
CPU cycle
1
External space
Consecutive
EXDMA write
One cluster transfer
Consecutive
EXDMA read
CPU cycle
External space
Consecutive
EXDMA write
Last cluster cycle
Consecutive
EXDMA read
0
Section 11 EXDMA Controller (EXDMAC)
Figure 11.65 Auto-Request/Cluster Transfer Mode/Cycle Steal Mode
(CPU Cycles/Dual Address Mode)
Transfer
request from
another
channel
(EDREQ)
Bus cycle
Bφ
Consecutive
EXDMA read
Consecutive
EXDMA write
One cluster transfer
Bus release
Consecutive
EXDMA read
Consecutive
EXDMA write
One cluster transfer
EXDMA single transfer cycle of
another channel with higher priority
Consecutive
EXDMA read
Consecutive
EXDMA write
Last cluster transfer
Section 11 EXDMA Controller (EXDMAC)
Figure 11.66 Auto-Request/Cluster Transfer Mode/Cycle Steal Mode
(Conflict with Another Channel/Dual Address Mode)
Rev. 2.00 Oct. 21, 2009 Page 539 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(2)
External Request/Cluster Transfer Mode/Cycle Steal Mode
With external requests, a cluster-size transfer is performed continuously. The start timing of the
next cluster transfer is the same as for normal transfer mode.
If a transfer request is generated for another channel, an EXDMA cycle for the other channel is
generated before the next cluster transfer.
The cluster transfer mode (read address mode and write address mode) can not be used with the
cluster transfer mode (dual address mode) among more than one channel at the same time. When
using the cluster transfer mode (read address mode and write address mode), do not set the cluster
transfer mode for another channel.
The EDREQ pin sensing timing is different for low level sensing and falling edge sensing. The
same applies to transfer request acceptance and transfer start timing.
Figures 11.67 to 11.69 show operation timing examples for various conditions.
Rev. 2.00 Oct. 21, 2009 Page 540 of 1454
REJ09B0498-0200
DTE bit
ETEND
Bus cycle
EDRAK
EDREQ
Bφ
Bus release
EXDMA read
1
EXDMA read
EXDMA write
EXDMA write
One cluster transfer
Consecutive read
Consecutive write
Bus release
3 cycles
EXDMA read
EXDMA read
Consecutive read
EXDMA write
EXDMA write
Last cluster
Consecutive write
0
Section 11 EXDMA Controller (EXDMAC)
Figure 11.67 External Request/Cluster Transfer Mode/Cycle Steal Mode
(No Conflict/Dual Address Mode/Low Level Sensing)
Rev. 2.00 Oct. 21, 2009 Page 541 of 1454
REJ09B0498-0200
CPU cycle
External space
EXDMA write
EXDMA read
External space
External space
CPU operation
Bus cycle
EDRAK
EDREQ
Bφ
CPU cycle
CPU cycle
EXDMA read
One cluster size transfer period
EXDMA write
CPU cycle
CPU cycle
Section 11 EXDMA Controller (EXDMAC)
Figure 11.68 External Request/Cluster Transfer Mode/Cycle Steal Mode
(CPU Cycles/Dual Address Mode/Low Level Sensing)
Rev. 2.00 Oct. 21, 2009 Page 542 of 1454
REJ09B0498-0200
EDRAK of
another channel
EDREQ of
another channel
ETEND
Bus cycle
EDRAK
EDREQ
Bφ
CPU cycle
CPU cycle
Consecutive
EXDMA read
Consecutive
EXDMA write
One cluster size transfer period
EXDMA cycle of
another channel
Consecutive
EXDMA read
Consecutive
EXDMA write
One cluster size transfer period
(Last cluster transfer)
Section 11 EXDMA Controller (EXDMAC)
Figure 11.69 External Request/Cluster Transfer Mode/Cycle Steal Mode
(Conflict with Another Channel/Dual Address Mode/Low Level Sensing)
Rev. 2.00 Oct. 21, 2009 Page 543 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.7
Ending EXDMA Transfer
The operation for ending EXDMA transfer depends on the transfer end conditions. When
EXDMA transfer ends, the DTE bit and the ACT bit in EDMDR change from 1 to 0, indicating
that EXDMA transfer has ended.
(1)
Transfer End by EDTCR Change from 1, 2, or 4 to 0
When the value of EDTCR changes from 1, 2, or 4 to 0, EXDMA transfer ends on the
corresponding channel. The DTE bit in EDMDR is cleared to 0, and the DTIF bit in EDMDR is
set to 1. If the DTIE bit in EDMDR is set to 1 at this time, a transfer end interrupt request is
generated by the transfer counter. EXDMA transfer does not end if the EDTCR value has been 0
since before the start of transfer.
(2)
Transfer End by Transfer Size Error Interrupt
When the following conditions are satisfied while the TSEIE bit in EDMDR is set to 1, a transfer
size error occurs and an EXDMA transfer is terminated. At this time, the DTE bit in EDMDR is
cleared to 0 and the ESIF bit in EDMDR is set to 1.
• In normal transfer mode and repeat transfer mode, when the next transfer is requested while a
transfer is disabled due to the EDTCR value less than the data access size.
• In block transfer mode, when the next transfer is requested while a transfer is disabled due to
the EDTCR value less than the block size.
• In cluster transfer mode, when the next transfer is requested while a transfer is disabled due to
the EDTCR value less than the cluster size.
When the TSEIE bit in EDMDR is cleared to 0, data is transferred until the EDTCR value reaches
0. A transfer size error is not generated. Operation in each transfer mode is described below.
• In normal transfer mode and repeat mode, when the EDTCR value is less than the data access
size, data is transferred in bytes.
• In block transfer mode, when the EDTCR value is less than the block size, the specified size of
data in EDTCR is transferred instead of transferring the block size of data. When the EDTCR
value is less than the data access size, data is transferred in bytes.
• In cluster transfer mode, when the EDTCR value is less than the cluster size, the specified size
of data in EDTCR is transferred instead of transferring the cluster size of data. When the
EDTCR value is less than the data access size, data is transferred in bytes.
Rev. 2.00 Oct. 21, 2009 Page 544 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(3)
Transfer End by Repeat Size End Interrupt
In repeat transfer mode, when the RPTIE bit in EDACR is set to 1 and the next transfer request is
generated on completion of a repeat-size transfer, a repeat size end interrupt request is generated.
The interrupt request terminates EXDMA transfer, the DTE bit in EDMDR is cleared to 0, and the
ESIF bit in EDMDR is set to 1 at the same time. If the DTE bit is set to 1 in this state, transfer
resumes.
In block transfer or cluster transfer mode, a repeat size end interrupt request can be generated. In
block transfer mode, if the next transfer request is generated at the end of a block-size transfer, a
repeat size end interrupt request is generated. In cluster transfer mode, if the next transfer request
is generated at the end of a cluster-size transfer, a repeat size end interrupt request is generated.
(4)
Transfer End by Extended Repeat Area Overflow Interrupt
If an address overflows the extended repeat area when an extended repeat area specification has
been made and the SARIE or DARIE bit in EDACR is set to 1, an extended repeat area overflow
interrupt is requested. The interrupt request terminates EXDMA transfer, the DTE bit in EDMDR
is cleared to 0, and the ESIF bit in EDMDR is set to 1 at the same time.
In dual address mode, if an extended repeat area overflow interrupt is requested during a read
cycle, the following write cycle processing is still executed.
In block transfer mode, if an extended repeat area overflow interrupt is requested during transfer
of a block, transfer continues to the end of the block. Transfer end by means of an extended repeat
area overflow interrupt occurs between block-size transfers.
In cluster transfer mode, if an extended repeat area overflow interrupt is requested during transfer
of a cluster, transfer continues to the end of the cluster. Transfer end by means of an extended
repeat area overflow interrupt occurs between cluster-size transfers.
(5)
Transfer End by 0-Write to DTE Bit in EDMDR
When 0 is written to the DTE bit in EDMDR by the CPU, etc., transfer ends after completion of
the EXDMA cycle in which transfer is in progress or a transfer request was accepted.
In block transfer mode, EXDMA transfer ends after completion of one-block-size transfer in
progress.
In cluster transfer mode, EXDMA transfer ends after completion of one-cluster-size transfer in
progress.
Rev. 2.00 Oct. 21, 2009 Page 545 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(6)
Transfer End by NMI Interrupt
If an NMI interrupt occurs, the EXDMAC clears the DTE bit to 0 in all channels and sets the
ERRF bit in EDMDR_0 to 1. EXDMA transfer is aborted when an NMI interrupt is generated
during EXDMA transfer. To perform EXDMA transfer after an NMI interrupt occurs, clear the
ERRF bit to 0 and then set the DTE bit to 1 in all channels.
The following explains the transfer end timing in each mode after an NMI interrupt is detected.
(a)
Normal transfer mode and repeat transfer mode
In dual address mode, EXDMA transfer ends at the end of the EXDMA transfer write cycle in
units of transfers.
In single address mode, EXDMA transfer ends at the end of the EXDMA transfer bus cycle in
units of transfers.
(b)
Block transfer mode
A block size EXDMA transfer is aborted. A block size transfer is not correctly executed, thus
matching between the actual transfer and the transfer request is not guaranteed.
In dual address mode, a write cycle corresponding to a read cycle is executed as well as in the
normal transfer mode.
(c)
Cluster transfer mode
A cluster size EXDMA transfer is aborted. If transfer is aborted in a read cycle, the read data is not
guaranteed. If transfer is aborted in a write cycle, the data not transferred is not guaranteed.
Matching between the transfer counter and the address register is not guaranteed since the transfer
processing cannot be controlled.
(7)
Transfer End by Address Error
If an address error occurs, the EXDMAC clears the DTE bit to 0 in all channels, and set the ERRF
bit in EDMDR_0 to 1. An address error during EXDMA transfer forcibly terminates the transfer.
To perform EXDMA transfer after an address error occurs, clear the ERRF bit to 0 and then set
the DTE bit to 1 in each channel.
The transfer end timing after address error detection is the same as for the one when an NMI
interrupt occurs.
Rev. 2.00 Oct. 21, 2009 Page 546 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
(8)
Transfer End by Hardware Standby Mode and Reset Input
The EXDMAC is initialized in hardware standby mode and by a reset. EXDMA transfer is not
guaranteed in these cases.
11.8
Relationship among EXDMAC and Other Bus Masters
11.8.1
CPU Priority Control Function Over EXDMAC
The EXDMAC priority level control function can be used for the CPU by setting the CPU priority
control register (CPUPCR). For details, see section 7.7, CPU Priority Control Function Over DTC,
DMAC and EXDMAC.
The EXDMAC priority level can be set independently for each channel by the EDMAP2 to
EDMAP0 bits in EDMDR.
The CPU priority level, which corresponds to the priority level of exception handling, can be set
by updating the values of the CPUP2 to CPUP0 bits in CPUPCR with the interrupt mask bit
values.
When the CPUPCE bit in CPUPCR is set to 1 to enable the CPU priority level control and the
EXDMAC priority level is lower than the CPU priority level, the transfer request of the
corresponding channel is masked and the channel activation is disabled. When the priority level of
another channel is the same or higher than the CPU priority level, the transfer request for another
channel is accepted and transfer is enabled regardless of the priority levels of channels.
The CPU priority level control function holds pending the transfer source, which masked the
transfer request. When the CPU priority level becomes lower than the channel priority level by
updating one of them, the transfer request is accepted and transfer starts. The transfer request held
pending is cleared by writing 0 to the DTE bit.
When the CPUPCE bit is cleared to 0, the lowest CPU priority level is assumed.
Rev. 2.00 Oct. 21, 2009 Page 547 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.8.2
Bus Arbitration with Another Bus Master
A cycle of another bus master may (or not) be inserted among consecutive EXDMA transfer bus
cycles. The EXDMAC bus mastership can be set so that it is released and transferred to another
bus master.
Some of the consecutive EXDMA transfer bus cycles may be indivisible due to the transfer mode
specification, may be consecutive bus cycles for high-speed access due to the transfer mode
specification, or may be consecutive bus cycles because another bus master does not request the
bus mastership.
These consecutive EXDMA read and write cycles are indivisible: refresh cycle, external bus
release cycle, or external space access cycle by internal bus master (CPU, DTC, DMAC) does not
occur between a read cycle and a write cycle.
In cluster transfer mode, the transfer cycle in one cluster is indivisible.
In block transfer mode and auto-request burst mode, the EXDMA transfer bus cycles continues. In
this period, the bus priority level of the internal bus master is lower than the EXDMAC so that the
external space access is held pending (when EBCCS = 0 in the bus control register 2 (BCR2)).
When switching to another channel, or in the auto-request cycle steal mode, the EXDMA transfer
cycles and internal bus master cycles are alternatively executed. When the internal bus master is
not issuing an external space access cycle, the EXDMA transfer bus cycles are continuously
executed in the allowable range.
When the EBCCS bit in BCR2 is set to 1 to enable the arbitration function between the EXDMAC
and the internal bus master, the bus mastership is released, except for indivisible bus cycles, and
transferred between the EXDMAC and the internal bus master alternatively. For details, see
section 9, Bus Controller (BSC).
Rev. 2.00 Oct. 21, 2009 Page 548 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.9
Interrupt Sources
EXDMAC interrupt sources are a transfer end by the transfer counter, and an escape end interrupt
which is caused by the transfer counter not becoming 0. Table 11.7 shows the interrupt sources
and their priority order.
Table 11.7 Interrupt Sources and Priority Order
Interrupt
Interrupt Source
Interrupt
Priority
EXDMTEND0
Transfer end indicated by channel 0 transfer counter
High
EXDMTEND1
Transfer end indicated by channel 1 transfer counter
EXDMTEND2
Transfer end indicated by channel 2 transfer counter
EXDMTEND3
Transfer end indicated by channel 3 transfer counter
EXDMEEND0
Channel 0 transfer size error
Channel 0 repeat size end
Channel 0 source address extended repeat area overflow
Channel 0 destination address extended repeat area overflow
EXDMEEND1
Channel 1 transfer size error
Channel 1 repeat size end
Channel 1 source address extended repeat area overflow
Channel 1 destination address extended repeat area overflow
EXDMEEND2
Channel 2 transfer size error
Channel 2 repeat size end
Channel 2 source address extended repeat area overflow
Channel 2 destination address extended repeat area overflow
EXDMEEND3
Channel 3 transfer size error
Channel 3 repeat size end
Channel 3 source address extended repeat area overflow
Channel 3 destination address extended repeat area overflow
Low
Interrupt source can be enabled or disabled by setting the DTIE and ESIE bits in EDMDR for the
relevant channels. The DTIE bit can be combined with the DTIF bit in EDMDR to generate an
EXDMTEND interrupt. The ESIE bit can be combined with the ESIF bit in EDMDR to generate
an EXDMEEND interrupt. Interrupt sources in EXDMEEND are not identified as common
interrupts. The interrupt priority order among channels is determined by the interrupt controller as
shown in table 11.7. For detains see section 7, Interrupt Controller.
Rev. 2.00 Oct. 21, 2009 Page 549 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Interrupt source settings are made individually with the interrupt enable bits in the registers for the
relevant channels. The transfer counter's transfer end interrupt is enabled or disabled by means of
the DTIE bit in EDMDR, the transfer size error interrupt by means of the TSEIE bit in EDMDR,
the repeat size end interrupt by means of the RPTIE bit in EDACR, the source address extended
repeat area overflow interrupt by means of the SARIE bit in EDACR, and the destination address
extended repeat area overflow interrupt by means of the DARIE bit in EDACR.
The transfer end interrupt by the transfer counter occurs when the DTIE bit in EDMDR is set to 1,
the EDTCR becomes 0 by transfer, and then the DTIF bit in EDMDR is set to 1.
Interrupts other than the transfer end interrupt by the transfer counter occurs when the
corresponding interrupt enable bit is set to 1, the condition for that interrupt is satisfied, and then
the ESIF bit in EDMDR is set to 1.
The transfer size error interrupt occurs when the EDTCR value is smaller than the data access size
and a data-access-size transfer for one request cannot be performed for a transfer request. In block
transfer mode, the block size is compared to the EDTCR value to determine a transfer size error.
In cluster transfer mode, the cluster size is compared to the EDTCR value to determine a transfer
size error.
The repeat size end interrupt occurs when the next transfer request is generated after the end of a
repeat size transfer in repeat transfer mode. When the repeat area is not set in the address register,
transfer can be aborted periodically based on the set repeat size value. If the transfer end interrupt
by the transfer counter occurs at the same time, the ESIF bit is set to 1.
The source/destination address extended repeat area overflow interrupt occurs when the addresses
overflow the specified extended repeat area. If the transfer end interrupt by the transfer counter
occurs at the same time, the ESIF bit is set to 1.
Figure 11.70 shows the block diagram of various interrupts and their interrupt flags. The transfer
end interrupt can be cleared either by clearing the DTIF or ESIF bit to 0 in EDMDR within the
interrupt handling routine, or by re-setting the address registers and then setting the DTE bit to 1
in EDMDR to perform transfer continuation processing. An example of the procedure for clearing
the transfer end interrupt and restarting transfer is shown in figure 11.71.
Rev. 2.00 Oct. 21, 2009 Page 550 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
TSEIE bit
DTIE bit
Activation source occurred
in the transfer size error state
DTIF bit
RPTIE bit
Transfer
end interrupt
Condition to set DTIF bit to 1: DTCR
is set to 0 and transfer ends.
Activation source occurred
after BKSZ changed from 1 to 0
SARIE bit
ESIE bit
Source address extended
repeat area overflow occurred
ESIF bit
Transfer escape
end interrupt
Condition to set ESIF bit to 1
DARIE bit
Destination address extended
repeat area overflow occurred
Figure 11.70 Interrupts and Interrupt Sources
Transfer end interrupt of
exception handling routine
Transfer restart after end of
interrupt handling routine
Transfer continuation processing
Change register settings
[1]
Write 1 to DTE bit
[2]
End of interrupt handling routine
(RTE instruction execution)
[3]
Clear DTIF or ESIF bit to 0
[4]
End of interrupt handling routine
[5]
Change register settings
[6]
Write 1 to DTE bit
[7]
End of transfer restart processing
End of transfer restart processing
[1] Write set values to the registers
(transfer counter, address registers, etc.)
[2] Write 1 to the DTE bit in EDMDR to restart
EXDMA operation. When 1 is written to
the DTE bit, the DTIF or ESIF bit in EDMDR is
automatically cleared to 0 and the interrupt
source is cleared.
[3] The interrupt handling routine is
ended with an RTE instruction, etc.
[4] Write 0 to the DTIF or ESIF bit
in EDMDR by first reading 1 from it.
[5] After the interrupt handling routine is
ended with an RTE instruction, etc.,
interrupt masking is cleared.
[6] Write set values to the registers
(transfer counter, address registers, etc.).
[7] Write 1 to the DTE bit in EDMDR
to restart EXDMA operation.
Figure 11.71 Procedure for Clearing Transfer End Interrupt and Restarting Transfer
Rev. 2.00 Oct. 21, 2009 Page 551 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
11.10
Usage Notes
1. EXDMAC Register Access during Operation
Except for clearing the DTE bit to 0 in EDMDR, settings should not be changed for a channel
in operation (including the transfer standby state). Transfer must be disabled before changing a
setting for an operational channel.
2. Module Stop State
The EXDMAC operation can be enabled or disabled by the module stop control register. The
initial value is "enabled".
When the MSTPA14 bit is set to 1 in MSTPCRA, the EXDMAC clock stops and the
EXDMAC enters the module stop state. However, 1 cannot be written to the MSTPA14 bit
when any of the EXDMAC's channels is enabled for transfer, or when an interrupt is being
requested. Before setting the MSTPA14 bit, first clear the DTE bit in EDMDR to 0, then clear
the DTIF or DTIE bit in EDMDR to 0.
When the EXDMAC clock stops, EXDMAC registers can no longer be accessed. The
following EXDMAC register settings remain valid in the module stop state, and so should be
disabled, if necessary, before making the module stop transition.
• ETENDE = 1 in EDMDR (ETEND pin enable)
• EDRAKE = 1 in EDMDR (EDRAK pin enable)
• EDACKE = 1 in EDMDR (EDACK pin enable)
3. EDREQ Pin Falling Edge Activation
Falling edge sensing on the EDREQ pin is performed in synchronization with EXDMAC
internal operations, as indicated below.
1. Activation request standby state: Waits for low level sensing on EDREQ pin, then goes to
[2].
2. Transfer standby state: Waits for EXDMAC data transfer to become possible, then goes to
[3].
3. Activation request disabled state: Waits for high level sensing on EDREQ pin, then goes to
[1].
After EXDMAC transfer is enabled, the EXDMAC goes to state [1], so low level sensing is
used for the initial activation after transfer is enabled.
Rev. 2.00 Oct. 21, 2009 Page 552 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
4. Activation Source Acceptance
At the start of activation source acceptance, low level sensing is used for both falling edge
sensing and low level sensing on the EDREQ. Therefore, a request is accepted in the case of a
low level at the EDREQ pin that occurs before execution of the EDMDR write for setting the
transfer-enabled state.
At EXDMAC activation, low level on the EDREQ pin must not remain at the end of the
previous transfer.
5. Conflict in Cluster Transfer
In cluster transfer mode, the same cluster buffer is used for all channels. When more than one
cluster transfer conflicts, the cluster buffer register holds the value of the last cluster transfer.
When the transfer between the transfer source/destination and the cluster buffer conflicts with
another cluster transfer, the transferred data in the cluster buffer may be overwritten by another
channel cluster transfer. Therefore, in the cluster transfer mode (single address mode), do not
set the cluster transfer mode for any other channels.
6. Cluster Transfer Mode and Endian
In cluster transfer mode, only a transfer to the areas in the big endian format is supported.
When cluster transfer mode is specified, do not specify the areas in the little endian format for
EDSAR and EDDAR. For details on the endian, see section 9, Bus Controller (BSC).
Rev. 2.00 Oct. 21, 2009 Page 553 of 1454
REJ09B0498-0200
Section 11 EXDMA Controller (EXDMAC)
Rev. 2.00 Oct. 21, 2009 Page 554 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Section 12 Data Transfer Controller (DTC)
This LSI includes a data transfer controller (DTC). The DTC can be activated to transfer data by
an interrupt request.
12.1
Features
• Transfer possible over any number of channels:
Multiple data transfer enabled for one activation source (chain transfer)
Chain transfer specifiable after data transfer (when the counter is 0)
• Three transfer modes
Normal/repeat/block transfer modes selectable
Transfer source and destination addresses can be selected from increment/decrement/fixed
• Short address mode or full address mode selectable
⎯ Short address mode
Transfer information is located on a 3-longword boundary
The transfer source and destination addresses can be specified by 24 bits to select a 16Mbyte address space directly
⎯ Full address mode
Transfer information is located on a 4-longword boundary
The transfer source and destination addresses can be specified by 32 bits to select a 4Gbyte address space directly
• Size of data for data transfer can be specified as byte, word, or longword
The bus cycle is divided if an odd address is specified for a word or longword transfer.
The bus cycle is divided if address 4n + 2 is specified for a longword transfer.
• A CPU interrupt can be requested for the interrupt that activated the DTC
A CPU interrupt can be requested after one data transfer completion
A CPU interrupt can be requested after the specified data transfer completion
• Read skip of the transfer information specifiable
• Writeback skip executed for the fixed transfer source and destination addresses
• Module stop state specifiable
Rev. 2.00 Oct. 21, 2009 Page 555 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Figure 12.1 shows a block diagram of the DTC. The DTC transfer information can be allocated to
the data area*. When the transfer information is allocated to the on-chip RAM, a 32-bit bus
connects the DTC to the on-chip RAM, enabling 32-bit/1-state reading and writing of the DTC
transfer information.
Note: * When the transfer information is stored in the on-chip RAM, the RAME bit in SYSCR
must be set to 1.
DTC
Interrupt controller
On-chip
ROM
MRA
On-chip
peripheral
module
DTC activation request
vector number
Register
control
SAR
DAR
CRA
Activation
control
8
CPU interrupt request
Interrupt source clear
request
External bus
Bus interface
External device
(memory mapped)
Bus controller
REQ
DTCVBR
ACK
[Legend]
DTC mode registers A, B
DTC source address register
DTC destination address register
DTC transfer count registers A, B
DTC enable registers A to F
DTC control register
DTC vector base register
Figure 12.1 Block Diagram of DTC
Rev. 2.00 Oct. 21, 2009 Page 556 of 1454
REJ09B0498-0200
CRB
Interrupt
control
External
memory
MRA, MRB:
SAR:
DAR:
CRA, CRB:
DTCERA to DTCERF:
DTCCR:
DTCVBR:
MRB
DTC internal bus
Peripheral bus
On-chip
RAM
DTCCR
Internal bus (32 bits)
DTCERA
to DTCERF
Section 12 Data Transfer Controller (DTC)
12.2
Register Descriptions
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 MRA, MRB, SAR, DAR, CRA, and CRB cannot be directly accessed by the
CPU. The contents of these registers are stored in the data area as transfer information. When a
DTC activation request occurs, the DTC reads a start address of transfer information that is stored
in the data area according to the vector address, reads the transfer information, and transfers data.
After the data transfer, it writes a set of updated transfer information back to the data area.
• DTC enable registers A to F (DTCERA to DTCERF)
• DTC control register (DTCCR)
• DTC vector base register (DTCVBR)
Rev. 2.00 Oct. 21, 2009 Page 557 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.2.1
DTC Mode Register A (MRA)
MRA selects DTC operating mode. MRA cannot be accessed directly by the CPU.
Bit
7
6
5
4
3
2
1
0
MD1
MD0
Sz1
Sz0
SM1
SM0
⎯
⎯
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
R/W
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial
Value
7
MD1
Undefined ⎯
DTC Mode 1 and 0
6
MD0
Undefined ⎯
Specify DTC transfer mode.
Description
00: Normal mode
01: Repeat mode
10: Block transfer mode
11: Setting prohibited
5
Sz1
Undefined ⎯
DTC Data Transfer Size 1 and 0
4
Sz0
Undefined ⎯
Specify the size of data to be transferred.
00: Byte-size transfer
01: Word-size transfer
10: Longword-size transfer
11: Setting prohibited
3
SM1
Undefined ⎯
Source Address Mode 1 and 0
2
SM0
Undefined ⎯
Specify an SAR operation after a data transfer.
0x: SAR is fixed
(SAR writeback is skipped)
10: SAR is incremented after a transfer
(by +1 when Sz1 and Sz0 = B'00; by +2 when Sz1
and Sz0 = B'01; by +4 when Sz1 and Sz0 = B'10)
11: SAR is decremented after a transfer
(by –1 when Sz1 and Sz0 = B'00; by –2 when Sz1
and Sz0 = B'01; by –4 when Sz1 and Sz0 = B'10)
1, 0
⎯
Undefined ⎯
Reserved
The write value should always be 0.
[Legend]
x: Don't care
Rev. 2.00 Oct. 21, 2009 Page 558 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.2.2
DTC Mode Register B (MRB)
MRB selects DTC operating mode. MRB cannot be accessed directly by the CPU.
Bit
7
6
5
4
3
2
1
0
CHNE
CHNS
DISEL
DTS
DM1
DM0
⎯
⎯
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
R/W
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial
Value
7
CHNE
Undefined ⎯
Description
DTC Chain Transfer Enable
Specifies the chain transfer. For details, see section
12.5.7, Chain Transfer. The chain transfer condition is
selected by the CHNS bit.
0: Disables the chain transfer
1: Enables the chain transfer
6
CHNS
Undefined ⎯
DTC Chain Transfer Select
Specifies the chain transfer condition. If the following
transfer is a chain transfer, the completion check of the
specified transfer count is not performed and activation
source flag or DTCER is not cleared.
0: Chain transfer every time
1: Chain transfer only when transfer counter = 0
5
DISEL
Undefined ⎯
DTC Interrupt Select
When this bit is set to 1, a CPU interrupt request is
generated every time after a data transfer ends. When
this bit is set to 0, a CPU interrupt request is only
generated when the specified number of data transfer
ends.
4
DTS
Undefined ⎯
DTC Transfer Mode Select
Specifies either the source or destination as repeat or
block area during repeat or block transfer mode.
0: Specifies the destination as repeat or block area
1: Specifies the source as repeat or block area
Rev. 2.00 Oct. 21, 2009 Page 559 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Bit
Bit Name
Initial
Value
3
DM1
Undefined ⎯
Destination Address Mode 1 and 0
2
DM0
Undefined ⎯
Specify a DAR operation after a data transfer.
R/W
Description
0X: DAR is fixed
(DAR writeback is skipped)
10: DAR is incremented after a transfer
(by +1 when Sz1 and Sz0 = B'00; by +2 when Sz1
and Sz0 = B'01; by +4 when Sz1 and Sz0 = B'10)
11: SAR is decremented after a transfer
(by –1 when Sz1 and Sz0 = B'00; by –2 when Sz1
and Sz0 = B'01; by –4 when Sz1 and Sz0 = B'10)
1, 0
⎯
Undefined ⎯
Reserved
The write value should always be 0.
[Legend]
x: Don't care
12.2.3
DTC Source Address Register (SAR)
SAR is a 32-bit register that designates the source address of data to be transferred by the DTC.
In full address mode, 32 bits of SAR are valid. In short address mode, the lower 24 bits of SAR is
valid and bits 31 to 24 are ignored. At this time, the upper eight bits are filled with the value of
bit 23.
If a word or longword access is performed while an odd address is specified in SAR or if a
longword access is performed while address 4n + 2 is specified in SAR, the bus cycle is divided
into multiple cycles to transfer data. For details, see section 12.5.1, Bus Cycle Division.
SAR cannot be accessed directly from the CPU.
Rev. 2.00 Oct. 21, 2009 Page 560 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.2.4
DTC Destination Address Register (DAR)
DAR is a 32-bit register that designates the destination address of data to be transferred by the
DTC.
In full address mode, 32 bits of DAR are valid. In short address mode, the lower 24 bits of DAR is
valid and bits 31 to 24 are ignored. At this time, the upper eight bits are filled with the value of
bit 23.
If a word or longword access is performed while an odd address is specified in DAR or if a
longword access is performed while address 4n + 2 is specified in DAR, the bus cycle is divided
into multiple cycles to transfer data. For details, see section 12.5.1, Bus Cycle Division.
DAR cannot be accessed directly from the CPU.
12.2.5
DTC Transfer Count Register A (CRA)
CRA is a 16-bit register that designates the number of times data is to be transferred by the DTC.
In normal transfer mode, CRA functions as a 16-bit transfer counter (1 to 65,536). It is
decremented by 1 every time data is transferred, and bit DTCEn (n = 15 to 0) corresponding to the
activation source is cleared and then an interrupt is requested to the CPU when the count reaches
H'0000. The transfer count is 1 when CRA = H'0001, 65,535 when CRA = H'FFFF, and 65,536
when CRA = H'0000.
In repeat transfer mode, CRA is divided into two parts: the upper eight bits (CRAH) and the lower
eight bits (CRAL). CRAH holds the number of transfers while CRAL functions as an 8-bit
transfer counter (1 to 256). CRAL is decremented by 1 every time data is transferred, and the
contents of CRAH are sent to CRAL when the count reaches H'00. The transfer count is 1 when
CRAH = CRAL = H'01, 255 when CRAH = CRAL = H'FF, and 256 when CRAH = CRAL =
H'00.
In block transfer mode, CRA is divided into two parts: the upper eight bits (CRAH) and the lower
eight bits (CRAL). CRAH holds the block size while CRAL functions as an 8-bit block-size
counter (1 to 256 for byte, word, or longword). CRAL is decremented by 1 every time a byte
(word or longword) data is transferred, and the contents of CRAH are sent to CRAL when the
count reaches H'00. The block size is 1 byte (word or longword) when CRAH = CRAL =H'01,
255 bytes (words or longwords) when CRAH = CRAL = H'FF, and 256 bytes (words or
longwords) when CRAH = CRAL =H'00.
CRA cannot be accessed directly from the CPU.
Rev. 2.00 Oct. 21, 2009 Page 561 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.2.6
DTC Transfer Count Register B (CRB)
CRB is a 16-bit register that designates the number of times data is to be transferred by the DTC in
block transfer mode. It functions as a 16-bit transfer counter (1 to 65,536) that is decremented by 1
every time data is transferred, and bit DTCEn (n = 15 to 0) corresponding to the activation source
is cleared and then an interrupt is requested to the CPU when the count reaches H'0000. The
transfer count is 1 when CRB = H'0001, 65,535 when CRB = H'FFFF, and 65,536 when CRB =
H'0000.
CRB is not available in normal and repeat modes and cannot be accessed directly by the CPU.
12.2.7
DTC enable registers A to F (DTCERA to DTCERF)
DTCER, which is comprised of eight registers, DTCERA to DTCERF, is a register that specifies
DTC activation interrupt sources. The correspondence between interrupt sources and DTCE bits is
shown in table 12.1. Use bit manipulation instructions such as BSET and BCLR to read or write a
DTCE bit. If all interrupts are masked, multiple activation sources can be set at one time (only at
the initial setting) by writing data after executing a dummy read on the relevant register.
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
15
14
13
12
11
10
9
8
DTCE15
DTCE14
DTCE13
DTCE12
DTCE11
DTCE10
DTCE9
DTCE8
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
DTCE7
DTCE6
DTCE5
DTCE4
DTCE3
DTCE2
DTCE1
DTCE0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 562 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Bit
Bit Name
Initial
Value
R/W
Description
15
DTCE15
0
R/W
DTC Activation Enable 15 to 0
14
DTCE14
0
R/W
13
DTCE13
0
R/W
Setting this bit to 1 specifies a relevant interrupt source to
a DTC activation source.
12
DTCE12
0
R/W
[Clearing conditions]
11
DTCE11
0
R/W
•
When writing 0 to the bit to be cleared after reading 1
•
When the DISEL bit is 1 and the data transfer has
ended
•
When the specified number of transfers have ended
10
DTCE10
0
R/W
9
DTCE9
0
R/W
8
DTCE8
0
R/W
7
DTCE7
0
R/W
6
DTCE6
0
R/W
5
DTCE5
0
R/W
4
DTCE4
0
R/W
3
DTCE3
0
R/W
2
DTCE2
0
R/W
1
DTCE1
0
R/W
0
DTCE0
0
R/W
12.2.8
DTC Control Register (DTCCR)
These bits are not cleared when the DISEL bit is 0 and
the specified number of transfers have not ended
DTCCR specifies transfer information read skip.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
RRS
RCHNE
⎯
⎯
ERR
Initial Value
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R
R
R/(W)*
R/W
Note: * Only 0 can be written to clear the flag.
Bit
Bit Name
Initial
Value
R/W
Description
7 to 5
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
Rev. 2.00 Oct. 21, 2009 Page 563 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Bit
Bit Name
Initial
Value
R/W
Description
4
RRS
0
R/W
DTC Transfer Information Read Skip Enable
Controls the vector address read and transfer
information read. A DTC vector number is always
compared with the vector number for the previous
activation. If the vector numbers match and this bit is
set to 1, the DTC data transfer is started without
reading a vector address and transfer information. If the
previous DTC activation is a chain transfer, the vector
address read and transfer information read are always
performed.
0: Transfer read skip is not performed.
1: Transfer read skip is performed when the vector
numbers match.
3
RCHNE
0
R/W
Chain Transfer Enable After DTC Repeat Transfer
Enables/disables the chain transfer while transfer
counter (CRAL) is 0 in repeat transfer mode.
In repeat transfer mode, the CRAH value is written to
CRAL when CRAL is 0. Accordingly, chain transfer may
not occur when CRAL is 0. If this bit is set to 1, the
chain transfer is enabled when CRAH is written to
CRAL.
0: Disables the chain transfer after repeat transfer
1: Enables the chain transfer after repeat transfer
⎯
2, 1
All 0
R
Reserved
These are read-only bits and cannot be modified.
0
ERR
0
R/(W)* Transfer Stop Flag
Indicates that an address error or an NMI interrupt
occurs. If an address error or an NMI interrupt occurs,
the DTC stops.
0: No interrupt occurs
1: An interrupt occurs
[Clearing condition]
•
Note:
*
When writing 0 after reading 1
Only 0 can be written to clear this flag.
Rev. 2.00 Oct. 21, 2009 Page 564 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.2.9
DTC Vector Base Register (DTCVBR)
DTCVBR is a 32-bit register that specifies the base address for vector table address calculation.
Bits 31 to 28 and bits 11 to 0 are fixed 0 and cannot be written to. The initial value of DTCVBR is
H'00000000.
Bit
31
30
29
28
27
26
25
24
23
22
21
20
19
18
17
16
Bit Name
Initial Value
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
12.3
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R
R
R
R
R
R
R
R
R
R
R
R
Activation Sources
The DTC is activated by an interrupt request. The interrupt source is selected by DTCER. A DTC
activation source can be selected by setting the corresponding bit in DTCER; the CPU interrupt
source can be selected by clearing the corresponding bit in DTCER. At the end of a data transfer
(or the last consecutive transfer in the case of chain transfer), the activation source interrupt flag or
corresponding DTCER bit is cleared.
Rev. 2.00 Oct. 21, 2009 Page 565 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.4
Location of Transfer Information and DTC Vector Table
Locate the transfer information in the data area. The start address of transfer information should be
located at the address that is a multiple of four (4n). Otherwise, the lower two bits are ignored
during access ([1:0] = B'00.) Transfer information can be located in either short address mode
(three longwords) or full address mode (four longwords). The DTCMD bit in SYSCR specifies
either short address mode (DTCMD = 1) or full address mode (DTCMD = 0). For details, see
section 3.2.2, System Control Register (SYSCR). Transfer information located in the data area is
shown in figure 12.2
The DTC reads the start address of transfer information from the vector table according to the
activation source, and then reads the transfer information from the start address. Figure 12.3 shows
correspondences between the DTC vector address and transfer information.
Transfer information
in short address mode
Transfer information
in full address mode
Lower addresses
Start
address
0
MRA
MRB
Chain
transfer
CRA
1
2
Lower addresses
Start
address
3
SAR
DAR
CRB
MRA
SAR
MRB
DAR
CRA
CRB
Transfer information
for one transfer
(3 longwords)
Transfer information
for the 2nd transfer
in chain transfer
(3 longwords)
0
1
2
MRA MRB
3
Reserved
(0 write)
SAR
Chain
transfer
DAR
CRA
CRB
MRA MRB
Reserved
(0 write)
SAR
DAR
4 bytes
CRA
CRB
4 bytes
Figure 12.2 Transfer Information on Data Area
Rev. 2.00 Oct. 21, 2009 Page 566 of 1454
REJ09B0498-0200
Transfer
information
for one transfer
(4 longwords)
Transfer
information
for the 2nd
transfer
in chain transfer
(4 longwords)
Section 12 Data Transfer Controller (DTC)
Upper: DTCVBR
Lower: H'400 + vector number × 4
DTC vector
address
+4
Vector table
Transfer information (1)
Transfer information (1)
start address
Transfer information (2)
start address
+4n
Transfer information (2)
:
:
:
Transfer information (n)
start address
:
:
:
4 bytes
Transfer information (n)
Figure 12.3 Correspondence between DTC Vector Address and Transfer Information
Rev. 2.00 Oct. 21, 2009 Page 567 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Table 12.1 shows correspondence between the DTC activation source and vector address.
Table 12.1 Interrupt Sources, DTC Vector Addresses, and Corresponding DTCEs
Origin of
Activation
Activation Source Source
Vector
Number
DTC Vector
Address Offset
DTCE*
Priority
External pin
IRQ0
64
H'500
DTCEA15
High
IRQ1
65
H'504
DTCEA14
IRQ2
66
H'508
DTCEA13
IRQ3
67
H'50C
DTCEA12
IRQ4
68
H'510
DTCEA11
IRQ5
69
H'514
DTCEA10
IRQ6
70
H'518
DTCEA9
IRQ7
71
H'51C
DTCEA8
IRQ8
72
H'520
DTCEA7
IRQ9
73
H'524
DTCEA6
IRQ10
74
H'528
DTCEA5
IRQ11
75
H'52C
DTCEA4
A/D_0
ADI0 (A/D_0
conversion
end)
86
H'558
DTCEB15
TPU_0
TGI0A
88
H'560
DTCEB13
TGI0B
89
H'564
DTCEB12
TGI0C
90
H'568
DTCEB11
TGI0D
91
H'56C
DTCEB10
TGI1A
93
H'574
DTCEB9
TGI1B
94
H'578
DTCEB8
TGI2A
97
H'584
DTCEB7
TGI2B
98
H'588
DTCEB6
TPU_1
TPU_2
Rev. 2.00 Oct. 21, 2009 Page 568 of 1454
REJ09B0498-0200
Low
Section 12 Data Transfer Controller (DTC)
Origin of
Activation Source
Activation
Source
Vector
Number
DTC Vector
Address Offset
DTCE*
Priority
TPU_3
TGI3A
101
H'594
DTCEB5
High
TGI3B
102
H'598
DTCEB4
TGI3C
103
H'59C
DTCEB3
TGI3D
104
H'5A0
DTCEB2
TPU_4
TPU_5
TMR_0
TMR_1
TMR_2
TMR_3
DMAC
EXDMAC
DMAC
EXDMAC
TGI4A
106
H'5A8
DTCEB1
TGI4B
107
H'5AC
DTCEB0
TGI5A
110
H'5B8
DTCEC15
TGI5B
111
H'5BC
DTCEC14
CMI0A
116
H'5D0
DTCEC13
CMI0B
117
H'5D4
DTCEC12
CMI1A
119
H'5DC
DTCEC11
CMI1B
120
H'5E0
DTCEC10
CMI2A
122
H'5E8
DTCEC9
CMI2B
123
H'5EC
DTCEC8
CMI3A
125
H'5F4
DTCEC7
CMI3B
126
H'5F8
DTCEC6
DMTEND0
128
H'600
DTCEC5
DMTEND1
129
H'604
DTCEC4
DMTEND2
130
H'608
DTCEC3
DMTEND3
131
H'60C
DTCEC2
EXDMTEND0 132
H'610
DTCEC1
EXDMTEND1 133
H'614
DTCEC0
EXDMTEND2 134
H'618
DTCEC15
EXDMTEND3 135
H'61C
DTCEC14
DMEEND0
136
H'620
DTCED13
DMEEND1
137
H'624
DTCED12
DMEEND2
138
H'628
DTCED11
DMEEND3
139
H'62C
DTCED10
EXDMEEND0 140
H'630
DTCECD9
EXDMEEND1 141
H'634
DTCECD8
EXDMEEND2 142
H'638
DTCED7
EXDMEEND3 143
H'63C
DTCED6
Low
Rev. 2.00 Oct. 21, 2009 Page 569 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Origin of
Activation Source
Activation
Source
Vector
Number
DTC Vector
Address Offset
DTCE*
Priority
SCI_0
RXI0
145
H'644
DTCED5
High
TXI0
146
H'648
DTCED4
RXI1
149
H'654
DTCED3
TXI1
150
H'658
DTCED2
SCI_1
SCI_2
SCI_4
TPU_6
TPU_7
TPU_8
TPU_9
TPU_10
TPU_11
Note:
*
RXI2
153
H'664
DTCED1
TXI2
154
H'668
DTCED0
RXI4
161
H'684
DTCEE13
TXI4
162
H'688
DTCEE12
TGI6A
164
H'690
DTCEE11
TGI6B
165
H'694
DTCEE10
TGI6C
166
H'698
DTCEE9
TGI6D
167
H'69C
DTCEE8
TGI7A
169
H'6A4
DTCEE7
TGI7B
170
H'6A8
DTCEE6
TGI8A
173
H'6B4
DTCEE5
TGI8B
174
H'6B8
DTCEE4
TGI9A
177
H'6C4
DTCEE3
TGI9B
178
H'6C8
DTCEE2
TGI9C
179
H'6CC
DTCEE1
TGI9D
180
H'6D0
DTCEE0
TGI10A
182
H'6D8
DTCEF15
TGI10B
183
H'6DC
DTCEF14
TGI10V
186
H'6E8
DTCEF11
TGI11A
188
H'6F0
DTCEF10
TGI11B
189
H'6F4
DTCEF9
Low
The DTCE bits with no corresponding interrupt are reserved, and the write value should
always be 0. To leave software standby mode or all-module-clock-stop mode with an
interrupt, write 0 to the corresponding DTCE bit.
Rev. 2.00 Oct. 21, 2009 Page 570 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.5
Operation
The DTC stores transfer information in the data area. When activated, the DTC reads transfer
information that is stored in the data area and transfers data on the basis of that transfer
information. After the data transfer, it writes updated transfer information back to the data area.
Since transfer information is in the data area, it is possible to transfer data over any required
number of channels. There are three transfer modes: normal, repeat, and block.
The DTC specifies the source address and destination address in SAR and DAR, respectively.
After a transfer, SAR and DAR are incremented, decremented, or fixed independently.
Table 12.2 shows the DTC transfer modes.
Table 12.2 DTC Transfer Modes
Transfer
Mode
Size of Data Transferred at
One Transfer Request
Memory Address Increment or
Decrement
Transfer
Count
Normal
1 byte/word/longword
Incremented/decremented by 1, 2, or 4, 1 to 65536
or fixed
Repeat*1
1 byte/word/longword
Incremented/decremented by 1, 2, or 4, 1 to 256*3
or fixed
Block*2
Block size specified by CRAH (1 Incremented/decremented by 1, 2, or 4, 1 to 65536
to 256 bytes/words/longwords) or fixed
Notes: 1. Either source or destination is specified to repeat area.
2. Either source or destination is specified to block area.
3. After transfer of the specified transfer count, initial state is recovered to continue the
operation.
Setting the CHNE bit in MRB to 1 makes it possible to perform a number of transfers with a
single activation (chain transfer). Setting the CHNS bit in MRB to 1 can also be made to have
chain transfer performed only when the transfer counter value is 0.
Figure 12.4 shows a flowchart of DTC operation, and table 12.3 summarizes the chain transfer
conditions (combinations for performing the second and third transfers are omitted).
Rev. 2.00 Oct. 21, 2009 Page 571 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Start
Match &
RRS = 1
Vector number
comparison
Not match | RRS = 0
Read DTC vector
Next transfer
Read transfer
information
Transfer data
Update transfer
information
Update the start address
of transfer information
Write transfer information
CHNE = 1
Yes
No
Transfer counter = 0
or DISEL = 1
Yes
No
CHNS = 0
Yes
No
Transfer counter = 0
Yes
No
DISEL = 1
Yes
No
Clear activation
source flag
Clear DTCER/request an interrupt
to the CPU
End
Figure 12.4 Flowchart of DTC Operation
Rev. 2.00 Oct. 21, 2009 Page 572 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Table 12.3 Chain Transfer Conditions
1st Transfer
2nd Transfer
Transfer
CHNE CHNS DISEL Counter*1
0
⎯
0
Transfer
CHNE CHNS DISEL Counter*1 DTC Transfer
0
Not 0
⎯
⎯
⎯
⎯
Ends at 1st transfer
⎯
0
0*
2
⎯
⎯
⎯
⎯
Ends at 1st transfer
0
⎯
1
⎯
⎯
⎯
⎯
Interrupt request to CPU
1
0
⎯
⎯
0
⎯
0
Not 0
Ends at 2nd transfer
0
⎯
0
0*
2
Ends at 2nd transfer
0
⎯
1
⎯
Interrupt request to CPU
⎯
⎯
⎯
Ends at 1st transfer
0
⎯
0
Not 0
Ends at 2nd transfer
0
⎯
0
0*2
Ends at 2nd transfer
0
⎯
1
⎯
⎯
⎯
1
1
1
1
0
1
⎯
1
1
Not 0
2
0*
Not 0
Interrupt request to CPU
⎯
Ends at 1st transfer
Interrupt request to CPU
Notes: 1. CRA in normal mode transfer, CRAL in repeat transfer mode, or CRB in block transfer
mode
2. When the contents of the CRAH is written to the CRAL in repeat transfer mode
12.5.1
Bus Cycle Division
When the transfer data size is word and the SAR and DAR values are not a multiple of 2, the bus
cycle is divided and the transfer data is read from or written to in bytes. Similarly, when the
transfer data size is longword and the SAR and DAR values are not a multiple of 4, the bus cycle
is divided and the transfer data is read from or written to in words.
Table 12.4 shows the relationship among, SAR, DAR, transfer data size, bus cycle divisions, and
access data size. Figure 12.5 shows the bus cycle division example.
Table 12.4 Number of Bus Cycle Divisions and Access Size
Specified Data Size
SAR and DAR Values Byte (B)
Word (W)
Longword (LW)
Address 4n
1 (B)
1 (W)
1 (LW)
Address 2n + 1
1 (B)
2 (B-B)
3 (B-W-B)
Address 4n + 2
1 (B)
1 (W)
2 (W-W)
Rev. 2.00 Oct. 21, 2009 Page 573 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
[Example 1: When an odd address and even address are specified in SAR and DAR, respectively, and when the data size of transfer is specified as word]
Clock
DTC activation
request
DTC request
W
R
Address
B
Vector read
B
W
Transfer information Data transfer Transfer information
read
write
[Example 2: When an odd address and address 4n are specified in SAR and DAR, respectively, and when the data size of transfer is specified as longword]
Clock
DTC activation
request
DTC request
R
Address
B
Vector read
Transfer information
read
W
W
B
Data transfer
L
Transfer information
write
[Example 3: When address 4n + 2 and address 4n are specified in SAR and DAR, respectively, and when the data size of transfer is specified as longword]
Clock
DTC activation
request
DTC request
W
R
Address
W
Vector read
W
L
Transfer information Data transfer Transfer information
read
write
Figure 12.5 Bus Cycle Division Example
Rev. 2.00 Oct. 21, 2009 Page 574 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.5.2
Transfer Information Read Skip Function
By setting the RRS bit of DTCCR, the vector address read and transfer information read can be
skipped. The current DTC vector number is always compared with the vector number of previous
activation. If the vector numbers match when RRS = 1, a DTC data transfer is performed without
reading the vector address and transfer information. If the previous activation is a chain transfer,
the vector address read and transfer information read are always performed. Figure 12.6 shows the
transfer information read skip timing.
To modify the vector table and transfer information, temporarily clear the RRS bit to 0, modify the
vector table and transfer information, and then set the RRS bit to 1 again. When the RRS bit is
cleared to 0, the stored vector number is deleted, and the updated vector table and transfer
information are read at the next activation.
Clock
DTC activation (1)
request
(2)
DTC request
Transfer
information
read skip
Address
R
Vector read
R
W
Transfer information Data Transfer information
read
transfer
write
W
Data Transfer information
transfer
write
Note: Transfer information read is skipped when the activation sources of (1) and (2) (vector numbers) are the same while RRS = 1.
Figure 12.6 Transfer Information Read Skip Timing
Rev. 2.00 Oct. 21, 2009 Page 575 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.5.3
Transfer Information Writeback Skip Function
By specifying bit SM1 in MRA and bit DM1 in MRB to the fixed address mode, a part of transfer
information will not be written back. This function is performed regardless of short or full address
mode. Table 12.5 shows the transfer information writeback skip condition and writeback skipped
registers. Note that the CRA and CRB are always written back regardless of the short or full
address mode. In addition in full address mode, the writeback of the MRA and MRB are always
skipped.
Table 12.5 Transfer Information Writeback Skip Condition and Writeback Skipped
Registers
SM1
DM1
SAR
DAR
0
0
Skipped
Skipped
0
1
Skipped
Written back
1
0
Written back
Skipped
1
1
Written back
Written back
12.5.4
Normal Transfer Mode
In normal transfer mode, one operation transfers one byte, one word, or one longword of data.
From 1 to 65,536 transfers can be specified. The transfer source and destination addresses can be
specified as incremented, decremented, or fixed. When the specified number of transfers ends, an
interrupt can be requested to the CPU.
Table 12.6 lists the register function in normal transfer mode. Figure 12.7 shows the memory map
in normal transfer mode.
Table 12.6 Register Function in Normal Transfer Mode
Register
Function
Written Back Value
SAR
Source address
Incremented/decremented/fixed*
DAR
Destination address
Incremented/decremented/fixed*
CRA
Transfer count A
CRA − 1
CRB
Transfer count B
Not updated
Note:
*
Transfer information writeback is skipped.
Rev. 2.00 Oct. 21, 2009 Page 576 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Transfer source data area
Transfer destination data area
SAR
DAR
Transfer
Figure 12.7 Memory Map in Normal Transfer Mode
12.5.5
Repeat Transfer Mode
In repeat transfer mode, one operation transfers one byte, one word, or one longword of data. By
the DTS bit in MRB, either the source or destination can be specified as a repeat area. From 1 to
256 transfers can be specified. When the specified number of transfers ends, the transfer counter
and address register specified as the repeat area is restored to the initial state, and transfer is
repeated. The other address register is then incremented, decremented, or left fixed. In repeat
transfer mode, the transfer counter (CRAL) is updated to the value specified in CRAH when
CRAL becomes H'00. Thus the transfer counter value does not reach H'00, and therefore a CPU
interrupt cannot be requested when DISEL = 0.
Table 12.7 lists the register function in repeat transfer mode. Figure 12.8 shows the memory map
in repeat transfer mode.
Rev. 2.00 Oct. 21, 2009 Page 577 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Table 12.7 Register Function in Repeat Transfer Mode
Written Back Value
Register Function
CRAL is not 1
SAR
Incremented/decremented/fixed DTS =0: Incremented/
*
decremented/fixed*
Source address
CRAL is 1
DTS = 1: SAR initial value
DAR
Destination address Incremented/decremented/fixed DTS = 0: DAR initial value
*
DTS =1: Incremented/
decremented/fixed*
CRAH
Transfer count
storage
CRAH
CRAH
CRAL
Transfer count A
CRAL − 1
CRAH
CRB
Transfer count B
Not updated
Not updated
Note:
*
Transfer information writeback is skipped.
Transfer source data area
(specified as repeat area)
Transfer destination data area
SAR
DAR
Transfer
Figure 12.8 Memory Map in Repeat Transfer Mode
(When Transfer Source is Specified as Repeat Area)
Rev. 2.00 Oct. 21, 2009 Page 578 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.5.6
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 by the DTS bit in MRB.
The block size is 1 to 256 bytes (1 to 256 words, or 1 to 256 longwords). When the transfer of one
block ends, the block size counter (CRAL) and address register (SAR when DTS = 1 or DAR
when DTS = 0) specified as the block area is restored to the initial state. The other address register
is then incremented, decremented, or left fixed. From 1 to 65,536 transfers can be specified. When
the specified number of transfers ends, an interrupt is requested to the CPU.
Table 12.8 lists the register function in block transfer mode. Figure 12.9 shows the memory map
in block transfer mode.
Table 12.8 Register Function in Block Transfer Mode
Register Function
Written Back Value
SAR
DTS =0: Incremented/decremented/fixed*
Source address
DTS = 1: SAR initial value
DAR
Destination address
DTS = 0: DAR initial value
DTS =1: Incremented/decremented/fixed*
CRAH
Block size storage
CRAH
CRAL
Block size counter
CRAH
CRB
Block transfer counter
CRB − 1
Note:
*
Transfer information writeback is skipped.
Transfer source data area
SAR
1st block
:
:
Transfer destination data area
(specified as block area)
Transfer
Block area
DAR
Nth block
Figure 12.9 Memory Map in Block Transfer Mode
(When Transfer Destination is Specified as Block Area)
Rev. 2.00 Oct. 21, 2009 Page 579 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.5.7
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. Setting the CHNE and CHNS bits in MRB
set to 1 enables a chain transfer only when the transfer counter reaches 0. SAR, DAR, CRA, CRB,
MRA, and MRB, which define data transfers, can be set independently. Figure 12.10 shows the
chain transfer operation.
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 the DISEL bit to 1, and the interrupt source
flag for the activation source and DTCER are not affected.
In repeat transfer mode, setting the RCHNE bit in DTCCR and the CHNE and CHNS bits in MRB
to 1 enables a chain transfer after transfer with transfer counter = 1 has been completed.
Data area
Transfer source data (1)
Vector table
Transfer information
stored in user area
Transfer destination data (1)
DTC vector
address
Transfer information
start address
Transfer information
CHNE = 1
Transfer information
CHNE = 0
Transfer source data (2)
Transfer destination data (2)
Figure 12.10 Operation of Chain Transfer
Rev. 2.00 Oct. 21, 2009 Page 580 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.5.8
Operation Timing
Figures 12.11 to 12.14 show the DTC operation timings.
Clock
DTC activation
request
DTC request
Address
R
Vector read
Transfer
information
read
W
Data transfer
Transfer
information
write
Figure 12.11 DTC Operation Timing
(Example of Short Address Mode in Normal Transfer Mode or Repeat Transfer Mode)
Clock
DTC activation
request
DTC request
R
Address
Vector read
Transfer
information
read
W
R
Data transfer
W
Transfer
information
write
Figure 12.12 DTC Operation Timing
(Example of Short Address Mode in Block Transfer Mode with Block Size of 2)
Rev. 2.00 Oct. 21, 2009 Page 581 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Clock
DTC activation
request
DTC request
Address
R
Vector
read
Transfer
information
read
W
R
Data
transfer
Transfer
information
write
Transfer
information
read
W
Data
transfer
Transfer
information
write
Figure 12.13 DTC Operation Timing (Example of Short Address Mode in Chain Transfer)
Clock
DTC activation
request
DTC request
Address
R
Vector read
Transfer information
read
W
Data Transfer information
transfer
write
Figure 12.14 DTC Operation Timing
(Example of Full Address Mode in Normal Transfer Mode or Repeat Transfer Mode)
Rev. 2.00 Oct. 21, 2009 Page 582 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.5.9
Number of DTC Execution Cycles
Table 12.9 shows the execution status for a single DTC data transfer, and table 12.10 shows the
number of cycles required for each execution.
Table 12.9 DTC Execution Status
Mode
Vector
Read
I
Transfer
Information
Read
J
Transfer
Information
Write
L
Data Read
L
Internal
Operation
N
Data Write
M
Normal 1
0*1
4*2
3*3
0*1
3*2.3 2*4 1*5
3*6
2*7
1
3*6
2*7
1
1
0*1
Repeat 1
0*1
4*2
3*3
0*1
3*2.3 2*4 1*5
3*6
2*7
1
3*6
2*7
1
1
0*1
Block 1
transfer
0*1
4*2
3*3
0*1
3*2.3 2*4 1*5
3•P*
2•P* 1•P 3•P* 2•P* 1•P 1
0*1
6
7
6
7
[Legend]
P: Block size (CRAH and CRAL value)
Note: 1. When transfer information read is skipped
2. In full address mode operation
3. In short address mode operation
4. When the SAR or DAR is in fixed mode
5. When the SAR and DAR are in fixed mode
6. When a longword is transferred while an odd address is specified in the address
register
7. When a word is transferred while an odd address is specified in the address register or
when a longword is transferred while address 4n + 2 is specified
Rev. 2.00 Oct. 21, 2009 Page 583 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Table 12.10 Number of Cycles Required for Each Execution State
On-Chip On-Chip
On-Chip I/O
Registers
Object to be Accessed
RAM
ROM
Bus width
32
32
8
16
32
Access cycles
1
1
2
2
2
2
3
2
3
Execution Vector read SI
1
1
⎯
⎯
⎯
8
12 + 4m
4
6 + 2m
Transfer information read SJ 1
1
⎯
⎯
⎯
8
12 + 4m
4
6 + 2m
Transfer information write Sk 1
1
⎯
⎯
⎯
8
12 + 4m
4
6 + 2m
Byte data read SL
1
1
2
2
2
2
3+m
2
3+m
Word data read SL
1
1
4
2
2
4
4 + 2m
2
3+m
Longword data read SL
1
1
8
4
2
8
12 + 4m
4
6 + 2m
Byte data write SM
1
1
2
2
2
2
3+m
2
3+m
Word data write SM
1
1
4
2
2
4
4 + 2m
2
3+m
Longword data write SM
1
1
8
4
2
8
12 + 4m
4
6 + 2m
status
Internal operation SN
External Devices
8
16
1
[Legend]
m: Number of wait cycles 0 to 7 (For details, see section 9, Bus Controller (BSC).)
The number of execution cycles is calculated from the formula below. Note that Σ means the sum
of all transfers activated by one activation event (the number in which the CHNE bit is set to 1,
plus 1).
Number of execution cycles = I • SI + Σ (J • SJ + K • SK + L • SL + M • SM) + N • SN
12.5.10 DTC Bus Release Timing
The DTC requests the bus mastership to the bus arbiter when an activation request occurs. The
DTC releases the bus after a vector read, transfer information read, a single data transfer, or
transfer information writeback. The DTC does not release the bus during transfer information
read, single data transfer, or transfer information writeback.
12.5.11 DTC Priority Level Control to the CPU
The priority of the DTC activation sources over the CPU can be controlled by the CPU priority
level specified by bits CPUP2 to CPUP0 in CPUPCR and the DTC priority level specified by bits
DTCP2 to DTCP0. For details, see section 7, Interrupt Controller.
Rev. 2.00 Oct. 21, 2009 Page 584 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.6
DTC Activation by Interrupt
The procedure for using the DTC with interrupt activation is shown in figure 12.15.
DTC activation by interrupt
Clear RRS bit in DTCCR to 0
[1]
Set transfer information
(MRA, MRB, SAR, DAR,
CRA, CRB)
[2]
Set starts address of transfer
information in DTC vector table
[3]
Set RRS bit in DTCCR to 1
[4]
[1] Clearing the RRS bit in DTCCR to 0 clears the read skip flag
of transfer information. Read skip is not performed when the
DTC is activated after clearing the RRS bit. When updating
transfer information, the RRS bit must be cleared.
[2] Set the MRA, MRB, SAR, DAR, CRA, and CRB transfer
information in the data area. For details on setting transfer
information, see section 12.2, Register Descriptions. For details
on location of transfer information, see section 12.4, Location of
Transfer Information and DTC Vector Table.
[3] Set the start address of the transfer information in the DTC
vector table. For details on setting DTC vector table, see section
12.4, Location of Transfer Information and DTC Vector Table.
Set corresponding bit in
DTCER to 1
[5]
Set enable bit of interrupt
request for activation source
to 1
[6]
[4] Setting the RRS bit to 1 performs a read skip of second time or
later transfer information when the DTC is activated consecutively by the same interrupt source. Setting the RRS bit to 1 is
always allowed. However, the value set during transfer will be
valid from the next transfer.
[5] Set the bit in DTCER corresponding to the DTC activation
interrupt source to 1. For the correspondence of interrupts and
DTCER, refer to table 12.1. The bit in DTCER may be set to 1 on
the second or later transfer. In this case, setting the bit is not
needed.
Interrupt request generated
[6] 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. For details on the
settings of the interrupt enable bits, see the corresponding
descriptions of the corresponding module.
DTC activated
Determine
clearing method of
activation source
Clear corresponding
bit in DTCER
Clear
activation
source
[7]
[7] After the end of one data transfer, the DTC clears the activation
source flag or clears the corresponding bit in DTCER and
requests an interrupt to the CPU. The operation after transfer
depends on the transfer information. For details, see section
12.2, Register Descriptions and figure 12.4.
Corresponding bit in DTCER
cleared or CPU interrupt
requested
Transfer end
Figure 12.15 DTC with Interrupt Activation
Rev. 2.00 Oct. 21, 2009 Page 585 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.7
Examples of Use of the DTC
12.7.1
Normal Transfer Mode
An example is shown in which the DTC is used to receive 128 bytes of data via the SCI.
1. Set MRA to fixed source address (SM1 = SM0 = 0), incrementing destination address (DM1 =
1, DM0 = 0), normal transfer mode (MD1 = MD0 = 0), and byte size (Sz1 = Sz0 = 0). The
DTS bit can have any value. Set MRB for one data transfer by one interrupt (CHNE = 0,
DISEL = 0). Set the RDR address of the SCI in SAR, the start address of the RAM area where
the data will be received in DAR, and 128 (H'0080) in CRA. CRB can be set to any value.
2. Set the start address of the transfer information for an RXI interrupt at the DTC vector address.
3. Set the corresponding bit in DTCER to 1.
4. Set the SCI to the appropriate receive mode. Set the RIE bit in SCR to 1 to enable the receive
end (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.
5. Each time reception of one byte of data ends 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.
6. When CRA becomes 0 after the 128 data transfers have ended, the RDRF flag is held at 1, the
DTCE bit is cleared to 0, and an RXI interrupt request is sent to the CPU. Termination
processing should be performed in the interrupt handling routine.
12.7.2
Chain Transfer
An example of DTC chain transfer is shown in which pulse output is performed using the PPG.
Chain transfer can be used to perform pulse output data transfer and PPG output trigger cycle
updating. Repeat mode transfer to the PPG's NDR is performed in the first half of the chain
transfer, and normal mode transfer to the TPU's TGR in the second half. This is because clearing
of the activation source and interrupt generation at the end of the specified number of transfers are
restricted to the second half of the chain transfer (transfer when CHNE = 0).
Rev. 2.00 Oct. 21, 2009 Page 586 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
1. Perform settings for transfer to the PPG's NDR. Set MRA to source address incrementing
(SM1 = 1, SM0 = 0), fixed destination address (DM1 = DM0 = 0), repeat mode (MD1 = 0,
MD0 = 1), and word size (Sz1 = 0, Sz0 = 1). Set the source side as a repeat area (DTS = 1). Set
MRB to chain transfer mode (CHNE = 1, CHNS = 0, DISEL = 0). Set the data table start
address in SAR, the NDRH address in DAR, and the data table size in CRAH and CRAL.
CRB can be set to any value.
2. Perform settings for transfer to the TPU's TGR. Set MRA to source address incrementing
(SM1 = 1, SM0 = 0), fixed destination address (DM1 = DM0 = 0), normal mode (MD1 = MD0
= 0), and word size (Sz1 = 0, Sz0 = 1). Set the data table start address in SAR, the TGRA
address in DAR, and the data table size in CRA. CRB can be set to any value.
3. Locate the TPU transfer information consecutively after the NDR transfer information.
4. Set the start address of the NDR transfer information to the DTC vector address.
5. Set the bit corresponding to the TGIA interrupt in DTCER to 1.
6. Set TGRA as an output compare register (output disabled) with TIOR, and enable the TGIA
interrupt with TIER.
7. Set the initial output value in PODR, and the next output value in NDR. Set bits in DDR and
NDER for which output is to be performed to 1. Using PCR, select the TPU compare match to
be used as the output trigger.
8. Set the CST bit in TSTR to 1, and start the TCNT count operation.
9. Each time a TGRA compare match occurs, the next output value is transferred to NDR and the
set value of the next output trigger period is transferred to TGRA. The activation source TGFA
flag is cleared.
10. When the specified number of transfers are completed (the TPU transfer CRA value is 0), the
TGFA flag is held at 1, the DTCE bit is cleared to 0, and a TGIA interrupt request is sent to the
CPU. Termination processing should be performed in the interrupt handling routine.
12.7.3
Chain Transfer when Counter = 0
By executing a second data transfer and performing re-setting of the first data transfer only when
the counter value is 0, it is possible to perform 256 or more repeat transfers.
An example is shown in which a 128-Kbyte input buffer is configured. The input buffer is
assumed to have been set to start at lower address H'0000. Figure 12.16 shows the chain transfer
when the counter value is 0.
Rev. 2.00 Oct. 21, 2009 Page 587 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
1. For the first transfer, set the normal transfer mode for input data. Set the fixed transfer source
address, CRA = H'0000 (65,536 times), CHNE = 1, CHNS = 1, and DISEL = 0.
2. Prepare the upper 8-bit addresses of the start addresses for 65,536-transfer units for the first
data transfer in a separate area (in ROM, etc.). For example, if the input buffer is configured at
addresses H'200000 to H'21FFFF, prepare H'21 and H'20.
3. For the second transfer, set repeat transfer mode (with the source side as the repeat area) for resetting the transfer destination address for the first data transfer. Use the upper eight bits of
DAR in the first transfer information area as the transfer destination. Set CHNE = DISEL = 0.
If the above input buffer is specified as H'200000 to H'21FFFF, set the transfer counter to 2.
4. Execute the first data transfer 65536 times by means of interrupts. When the transfer counter
for the first data transfer reaches 0, the second data transfer is started. Set the upper eight bits
of the transfer source address for the first data transfer to H'21. The lower 16 bits of the
transfer destination address of the first data transfer and the transfer counter are H'0000.
5. Next, execute the first data transfer the 65536 times specified for the first data transfer by
means of interrupts. When the transfer counter for the first data transfer reaches 0, the second
data transfer is started. Set the upper eight bits of the transfer source address for the first data
transfer to H'20. The lower 16 bits of the transfer destination address of the first data transfer
and the transfer counter are H'0000.
6. Steps 4 and 5 are repeated endlessly. As repeat mode is specified for the second data transfer,
no interrupt request is sent to the CPU.
Input circuit
Transfer information
located on the on-chip memory
Input buffer
1st data transfer
information
Chain transfer
(counter = 0)
2nd data transfer
information
Upper 8 bits of DAR
Figure 12.16 Chain Transfer when Counter = 0
Rev. 2.00 Oct. 21, 2009 Page 588 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.8
Interrupt Sources
An interrupt request is issued to the CPU when the DTC finishes 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 priority level control in the interrupt controller.
12.9
Usage Notes
12.9.1
Module Stop State Setting
Operation of the DTC can be disabled or enabled using the module stop control register. The
initial setting is for operation of the DTC to be enabled. Register access is disabled by setting the
module stop state. The module stop state cannot be set while the DTC is activated. For details,
refer to section 28, Power-Down Modes.
12.9.2
On-Chip RAM
Transfer information can be located in on-chip RAM. In this case, the RAME bit in SYSCR must
not be cleared to 0.
12.9.3
DMAC Transfer End Interrupt
When the DTC is activated by a DMAC transfer end interrupt, the DTE bit of DMDR is not
controlled by the DTC but its value is modified with the write data regardless of the transfer
counter value and DISEL bit setting. Accordingly, even if the DTC transfer counter value
becomes 0, no interrupt request may be sent to the CPU in some cases.
When the DTC is activated by a DMAC transfer end interrupt, even if DISEL=0, an automatic
clearing of the relevant activation source flag is not automatically cleared by the DTC. Therefore,
write 1 to the DTE bit by the DTC transfer and clear the activation source flag to 0.
12.9.4
DTCE Bit Setting
For DTCE bit setting, use bit manipulation instructions such as BSET and BCLR. If all interrupts
are disabled, multiple activation sources can be set at one time (only at the initial setting) by
writing data after executing a dummy read on the relevant register.
Rev. 2.00 Oct. 21, 2009 Page 589 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.9.5
Chain Transfer
When chain transfer is used, clearing of the activation source or DTCER is performed when the
last of the chain of data transfers is executed. At this time, SCI and A/D converter
interrupt/activation sources, are cleared when the DTC reads or writes to the relevant register.
Therefore, when the DTC is activated by an interrupt or activation source, if a read/write of the
relevant register is not included in the last chained data transfer, the interrupt or activation source
will be retained.
12.9.6
Transfer Information Start Address, Source Address, and Destination Address
The transfer information start address to be specified in the vector table should be address 4n. If an
address other than address 4n is specified, the lower 2 bits of the address are regarded as 0s.
The source and destination addresses specified in SAR and DAR, respectively, will be transferred
in the divided bus cycles depending on the address and data size.
12.9.7
Transfer Information Modification
When IBCCS = 1 and the DMAC is used, clear the IBCCS bit to 0 and then set to 1 again before
modifying the DTC transfer information in the CPU exception handling routine initiated by a DTC
transfer end interrupt.
12.9.8
Endian Format
The DTC supports big and little endian formats. The endian formats used when transfer
information is written to and when transfer information is read from by the DTC must be the
same.
Rev. 2.00 Oct. 21, 2009 Page 590 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
12.9.9
Points for Caution when Overwriting DTCER
When overwriting of the DTC-transfer enable register (DTCER) and the generation of an interrupt
that is a source for DTC activation are in competition, activation of the DTC and interrupt
exception processing by the CPU will both proceed at the same time. Depending on the conditions
at this time, doubling of interrupts may occur. If there is a possibility of competition between
overwriting of the DTCER and generation of an interrupt that is a source for DTC activation,
proceed with overwriting of the DTCER according to the relevant procedure given below.
In the case of
interrupt-control mode 0
In the case of
interrupt-control mode 2
Back-up the value of the CCR.
Back-up the value of the EXR.
Set the interrupt-mask bit to 1
(corresponding bit = 1 in the CCR).
Set the interrupt-request masking level to 7
(in the EXR, I2, I1, I0 = b'111).
Overwrite the DTCER.
Overwrite the DTCER.
Interrupts are
masked
Dummy-read the DTCER.
Dummy-read the DTCER.
Restore the original value of the
interrupt-mask bit.
Restore the original value of the
interrupt-request masking level.
END
END
Figure 12.17 Example of Procedures for Overwriting the DTCER
Rev. 2.00 Oct. 21, 2009 Page 591 of 1454
REJ09B0498-0200
Section 12 Data Transfer Controller (DTC)
Rev. 2.00 Oct. 21, 2009 Page 592 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Section 13 I/O Ports
Table 13.1 summarizes the port functions. The pins of each port also have other functions such as
input/output pins of on-chip peripheral modules or external interrupt input pins. Each I/O port
includes a data direction register (DDR) that controls input/output, a data register (DR) that stores
output data, a port register (PORT) used to read the pin states, and an input buffer control register
(ICR) that controls input buffer on/off. Port 5 does not have a DR or a DDR register.
Ports D to F, H to K have internal input pull-up MOSs and a pull-up MOS control register (PCR)
that controls the on/off state of the input pull-up MOSs.
Ports 2 and F include an open-drain control register (ODR) that controls on/off of the output
buffer PMOSs.
All of the I/O ports can drive a single TTL load and capacitive loads up to 30 pF. All of the I/O
ports can drive Darlington transistors when functioning as output ports.
Port 2, 3, J and K are Schmitt-trigger input. Schmitt-trigger inputs for other ports are enabled
when used as the IRQ, TPU, TMR, or IIC2 input.
Table 13.1 Port Functions
Function
SchmittTrigger
1
Input*
Input
Pull-up
MOS
Function
I/O
Input
Output
Port 1 General I/O port
7
also functioning
as interrupt inputs,
SCI I/Os, DMAC
6
I/Os, EXDMAC
I/Os, A/D
converter inputs,
5
TPU inputs, and
IIC2 I/Os
P17/SCL0
IRQ7-A/
TCLKD-B/
ADTRG1
EDRAK1
IRQ7-A,
⎯
TCLKD-B,
SCL0
P16/SDA0
IRQ6-A/
TCLKC-B
DACK1-A/
EDACK1-A
IRQ6-A,
TCLKC-B,
SDA0
P15/SCL1
IRQ5-A/
TCLKB-B/
RxD5/
IrRxD
TEND1-A/
ETEND1-A
IRQ5-A,
TCLKB-B,
SCL1
4
P14/SDA1
DREQ1-A/
IRQ4-A/
TCLKA-B/
EDREQ1-A
TxD5/
IrTxD
IRQ4-A,
TCLKA-B,
SDA1
3
P13
ADTRG0-A/ EDRAK0
IRQ3-A
Port
Description
Bit
OpenDrain
Output
Function
⎯
IRQ3-A
Rev. 2.00 Oct. 21, 2009 Page 593 of 1454
REJ09B0498-0200
Section 13 I/O Ports
SchmittTrigger
1
Input *
Input
Pull-up
MOS
Function
OpenDrain
Output
Function
⎯
⎯
⎯
O
Function
Port
Description
Bit
I/O
Input
Output
2
P12/SCK2
IRQ2-A
DACK0-A/
EDACK0-A
IRQ2-A
P11
RxD2/
IRQ1-A
TEND0-A/
ETEND0-A
IRQ1-A
P10
DREQ0-A/
IRQ0-A/
EDREQ0-A
TxD2
IRQ0-A
Port 2 General I/O port
7
also functioning
as interrupt inputs,
PPG outputs, TPU
6
I/Os, TMR I/Os,
and SCI I/Os
5
P27/
TIOCB5
TIOCA5
PO7
P27,
TIOCB5,
TIOCA5
P26/
TIOCA5
⎯
PO6/TMO1/ All input
TxD1
functions
P25/
TIOCA4
TMCI1/
RxD1
PO5
P25,
TIOCA4,
TMCI1
4
P24/
TIOCB4/
SCK1
TIOCA4/
TMRI1
PO4
P24,
TIOCB4,
TIOCA4,
TMRI1
3
P23/
TIOCD3
IRQ11-A/
TIOCC3
PO3
P23,
TIOCD3,
IRQ11-A
2
P22/
TIOCC3
IRQ10-A
PO2/TMO0/ All input
TxD0
functions
1
P21/
TIOCA3
TMCI0/
RxD0/
IRQ9-A
PO1
P21,
IRQ9-A,
TIOCA3,
TMCI0
0
P20/
TIOCB3/
SCK0
TIOCA3/
TMRI0/
IRQ8-A
PO0
P20,
IRQ8-A,
TIOCB3,
TIOCA3,
TMRI0
Port 1 General I/O port
also functioning
as interrupt inputs, 1
SCI I/Os, DMAC
I/Os, EDMAC
0
I/Os, A/D
converter inputs,
TPU inputs, and
IIC2 I/Os
Rev. 2.00 Oct. 21, 2009 Page 594 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Function
Bit
I/O
Input
Output
SchmittTrigger
1
Input *
7
P37/
TIOCB2
TIOCA2/
TCLKD-A
PO15/
EDRAK3
All input
functions
6
P36/
TIOCA2
⎯
PO14/
EDRAK2
All input
functions
5
P35/
TIOCB1
TIOCA1/
TCLKC-A
PO13/
DACK1-B/
EDACK3
All input
functions
4
P34/
TIOCA1
⎯
PO12/
TEND1-B/
ETEND3
All input
functions
3
P33/
TIOCD0
TIOCC0/
TCLKB-A/
DREQ1-B/
EDREQ3
PO11
P33,
TIOCD0,
TIOCC0,
TCLKB-A
2
P32/
TIOCC0
TCLKA-A
PO10/
DACK0-B/
EDACK2
All input
functions
1
P31/
TIOCB0
TIOCA0
PO9/
TEND0-B/
ETEND2
All input
functions
0
P30/
TIOCA0
DREQ0-B/
EDREQ2
PO8
P30,
TIOCA0
Port 5 General input port 7
also functioning
as interrupt inputs,
6
A/D converter
inputs, and D/A
converter outputs 5
⎯
P57/AN7/
IRQ7-B
DA1
IRQ7-B
⎯
P56/AN6/
IRQ6-B
DA0
IRQ6-B
⎯
P55/AN5/
IRQ5-B
⎯
IRQ5-B
4
⎯
P54/AN4/
IRQ4-B
⎯
IRQ4-B
3
⎯
P53/AN3/
IRQ3-B
⎯
IRQ3-B
2
⎯
P52/AN2/
IRQ2-B
⎯
IRQ2-B
1
⎯
P51/AN1/
IRQ1-B
⎯
IRQ1-B
0
⎯
P50/AN0/
IRQ0-B
⎯
IRQ0-B
Port
Description
Port 3 General I/O port
also functioning
as PPG outputs,
DMAC I/Os, TPU
I/Os and
EXDMAC I/O
Input
Pull-up
MOS
Function
OpenDrain
Output
Function
⎯
⎯
⎯
⎯
Rev. 2.00 Oct. 21, 2009 Page 595 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Function
Port
Description
Port 6 General I/O port
also functioning
as SCI inputs,
DMAC I/Os,
H-UDI inputs,
interrupt inputs
and EXDMAC I/O
Port A General I/O port
also functioning
as system clock
output and bus
control I/Os
Bit
I/O
Input
Output
SchmittTrigger
1
Input*
7
⎯
⎯
⎯
⎯
6
⎯
⎯
⎯
⎯
5
P65
TCK
TMO3/
EDACK1-B
TCK
4
P64
TMCI3/TDI
TEND3/
ETEND1-B
TMCI3,
TDI
3
P63
TMRI3/
DREQ3/
IRQ11-B/
TMS/
EDREQ1-B
⎯
TMRI3,
IRQ11-B,
TMS
2
P62/SCK4
IRQ10-B/
TRST
TMO2/
DACK2/
EDACK0-B
IRQ10-B,
TRST
1
P61
TMCI2/
RxD4/
IRQ9-B
TEND2/
ETEND0-B
TMCI2,
IRQ9-B
0
P60
TMRI2/
DREQ2/
IRQ8-B/
EDREQ0-B
TxD4
TMRI2,
IRQ8-B
7
⎯
PA7
Bφ
⎯
6
PA6
⎯
AS/AH/
BS-B
5
PA5
⎯
RD
4
PA4
⎯
LHWR/LUB
3
PA3
⎯
LLWR/LLB
2
PA2
BREQ/
WAIT
⎯
1
PA1
⎯
BACK/
(RD/WR-A)
0
PA0
⎯
BREQO/
BS-A
Rev. 2.00 Oct. 21, 2009 Page 596 of 1454
REJ09B0498-0200
Input
Pull-up
MOS
Function
OpenDrain
Output
Function
⎯
⎯
⎯
⎯
Section 13 I/O Ports
Function
Port
Description
Port B General I/O port
also functioning
as A/D converter
inputs and bus
control outputs
Port C General I/O port
also functioning
as bus control
I/Os and A/D
converter inputs
Input
Pull-up
MOS
Function
OpenDrain
Output
Function
Bit
I/O
Input
Output
SchmittTrigger
1
Input*
7
PB7
⎯
SDφ
⎯
⎯
⎯
6
PB6
ADTRG0-B
CS6-D
(RD/WR-B)
5
PB5
⎯
CS5-D/
OE/CKE
4
PB4
⎯
CS4-B/WE
3
PB3
⎯
CS3/
CS7-A/
CAS
2
PB2
⎯
CS2-A/
CS6-A/
RAS
1
PB1
⎯
CS1/
CS2-B/
CS5-A/
CS6-B/
CS7-B
0
PB0
⎯
CS0/
CS4-A/
CS5-B
7
⎯
⎯
⎯
⎯
⎯
⎯
6
⎯
⎯
⎯
5
⎯
⎯
⎯
4
⎯
⎯
⎯
3
PC3
⎯
LLCAS/
DQMLL
2
PC2
⎯
LUCAS/
DQMLU
1
⎯
⎯
⎯
0
⎯
⎯
⎯
Rev. 2.00 Oct. 21, 2009 Page 597 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Function
Input
Pull-up
MOS
Function
OpenDrain
Output
Function
Port
Description
Bit
I/O
Input
Output
SchmittTrigger
1
Input*
Port
3
D*
General I/O port
also functioning
as address
outputs
7
PD7
⎯
A7
⎯
O
⎯
6
PD6
⎯
A6
5
PD5
⎯
A5
4
PD4
⎯
A4
3
PD3
⎯
A3
2
PD2
⎯
A2
1
PD1
⎯
A1
0
PD0
⎯
A0
7
PE7
⎯
A15
⎯
O
⎯
6
PE6
⎯
A14
5
PE5
⎯
A13
4
PE4
⎯
A12
3
PE3
⎯
A11
2
PE2
⎯
A10
1
PE1
⎯
A9
0
PE0
⎯
A8
7
PF7
⎯
A23
⎯
O
O
6
PF6
⎯
A22
5
PF5
⎯
A21
4
PF4
⎯
A20
3
PF3
⎯
A19
2
PF2
⎯
A18
1
PF1
⎯
A17
0
PF0
⎯
A16
Port
3
E*
General I/O port
also functioning
as address
outputs
Port F General I/O port
also functioning
as address
outputs
Rev. 2.00 Oct. 21, 2009 Page 598 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Input
Output
Input
Schmitt Pull-up
-Trigger MOS
1
Input*
Function
PH7/D7*
2
⎯
⎯
⎯
O
⎯
PH6/D6*
2
⎯
⎯
PH5/D5*
2
⎯
⎯
PH4/D4*
2
⎯
⎯
PH3/D3*
2
⎯
⎯
PH2/D2*
2
⎯
⎯
PH1/D1*
2
⎯
⎯
PH0/D0*
2
⎯
⎯
2
⎯
⎯
⎯
O
⎯
2
⎯
⎯
2
⎯
⎯
2
⎯
⎯
2
⎯
⎯
2
All input
function
O
⎯
Function
Port
Description
Bit
Port H General I/O port 7
also functioning
6
as bi-directional
5
data bus
4
3
2
1
0
Port I
General I/O port 7
also functioning
6
as bi-directional
5
data bus
4
3
I/O
PI7/D15*
PI6/D14*
PI5/D13*
PI4/D12*
PI3/D11*
⎯
⎯
2
⎯
⎯
2
PI0/D8*
⎯
⎯
PJ7/TIOCB8
TIOCA8/
TCLKH
PO23
PJ6/TIOCA8
⎯
PO22
PJ5/TIOCB7
TIOCA7/
TCLKG
PO21
4
PJ4/TIOCA7
⎯
PO20
3
PJ3/TIOCD6
TIOCC6/
TCLKF
PO19
2
PJ2/TIOCC6
TCLKE
PO18
1
PJ1/TIOCB6
TIOCA6
PO17
0
PJ0/TIOCA6
⎯
PO16
2
1
0
4
Port J* General I/O port 7
also functioning
as PPG and
6
TPU I/O
5
PI2/D10*
PI1/D9*
OpenDrain
Output
Function
Rev. 2.00 Oct. 21, 2009 Page 599 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Function
Port
4
Port K*
Port M
Description
Bit
I/O
Input
Output
General I/O
port also
functioning as
PPG and TPU
I/O
7
PK7/TIOCB11
TIOCA11
PO31
6
PK6/TIOCA11
⎯
PO30
5
PK5/TIOCB10
TIOCA10
PO29
4
PK4/TIOCA10
⎯
PO28
3
PK3/TIOCD9
TIOCC9
PO27
2
PK2/TIOCC9
⎯
PO26
1
PK1/TIOCB9
TIOCA9
PO25
0
PK0/TIOCA9
⎯
PO24
7
⎯
⎯
⎯
6
⎯
⎯
⎯
5
⎯
⎯
⎯
4
PM4
⎯
⎯
3
PM3
⎯
⎯
2
PM2
⎯
⎯
1
PM1
RxD6
⎯
0
PM0
⎯
TxD6
General I/O
port also
functioning as
SCI I/Os
Notes: 1.
2.
3.
4.
Input
Schmitt Pull-up
-Trigger MOS
1
Input*
Function
OpenDrain
Output
Function
All input
function
O
⎯
⎯
⎯
⎯
Pins without Schmitt-trigger input have CMOS input functions.
Addresses are also output when accessing to the address/data multiplexed I/O space.
Pins are disabled when PCJKE = 1.
Pins are disabled when PCJKE = 0.
Rev. 2.00 Oct. 21, 2009 Page 600 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.1
Register Descriptions
Table 13.2 lists each port registers.
Table 13.2 Register Configuration in Each Port
Registers
Port
Number of
Pins
DDR
DR
PORT
ICR
PCR
ODR
Port 1
8
O
O
O
O
⎯
⎯
Port 2
8
O
O
O
O
⎯
O
Port 3
8
O
O
O
O
⎯
⎯
8
⎯
⎯
O
O
⎯
⎯
Port 6*
6
O
O
O
O
⎯
⎯
Port A
8
O
O
O
O
⎯
⎯
Port 5
4
8
O
O
O
O
⎯
⎯
Port C*
1
2
O
O
O
O
⎯
⎯
Port D*
2
8
O
O
O
O
O
⎯
Port E*
2
8
O
O
O
O
O
⎯
Port F
8
O
O
O
O
O
O
Port H
8
O
O
O
O
O
⎯
Port B
Port I
8
O
O
O
O
O
⎯
Port J*3
8
O
O
O
O
O
⎯
8
O
O
O
O
O
⎯
5
O
O
O
O
⎯
⎯
3
Port K*
5
Port M*
[Legend]
O:
Register exists
⎯:
No register exists
Notes: 1. Bits 2 and 3 are valid and the other bits are reserved for port C registers. The write
value should be the same as the initial value.
2. Do not access when PCJKE = 1.
3. Do not access when PCJKE = 0.
4. The lower six bits are valid and the upper two bits are reserved for port 6 registers. The
write value should be the same as the initial value.
5. The lower five bits are valid and the upper three bits are reserved for port M registers.
The write value should be the same as the initial value.
Rev. 2.00 Oct. 21, 2009 Page 601 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.1.1
Data Direction Register (PnDDR) (n = 1, 2, 3, 6, A to F, H to K, and M)
DDR is an 8-bit write-only register that specifies the port input or output for each bit. A read from
the DDR is invalid and DDR is always read as an undefined value.
When the general I/O port function is selected, the corresponding pin functions as an output port
by setting the corresponding DDR bit to 1; the corresponding pin functions as an input port by
clearing the corresponding DDR bit to 0.
The initial DDR values are shown in table 13.3.
7
6
5
4
3
2
1
0
Pn7DDR
Pn6DDR
Pn5DDR
Pn4DDR
Pn3DDR
Pn2DDR
Pn1DDR
Pn0DDR
Initial Value
0
0
0
0
0
0
0
0
R/W
W
W
W
W
W
W
W
W
Bit
Bit Name
Notes: The lower six bits are valid and the upper two bits are reserved for port 6 registers.
The lower five bits are valid and the upper three bits are reserved for port M registers.
Bits 2 and 3 are valid and the other bits are reserved for port C registers.
Registers of ports J and K cannot be accessed when PCJKE = 0.
Registers of ports D and E cannot be accessed when PCJKE = 1.
Table 13.3 Startup Mode and Initial Value
Startup Mode
Port
External Extended Mode
Single-Chip Mode
Port A
H'80
H'00
Other ports
H'00
H'00
Rev. 2.00 Oct. 21, 2009 Page 602 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.1.2
Data Register (PnDR) (n = 1, 2, 3, 6, A to F, H to K, and M)
DR is an 8-bit readable/writable register that stores the output data of the pins to be used as the
general output port.
The initial value of DR is H'00.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
Pn7DR
Pn6DR
Pn5DR
Pn4DR
Pn3DR
Pn2DR
Pn1DR
Pn0DR
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Notes: The lower six bits are valid and the upper two bits are reserved for port 6 registers.
The lower five bits are valid and the upper three bits are reserved for port M registers.
Bits 2 and 3 are valid and the other bits are reserved for port C registers.
Registers of ports J and K cannot be accessed when PCJKE = 0.
Registers of ports D and E cannot be accessed when PCJKE =1.
13.1.3
Port Register (PORTn) (n = 1, 2, 3, 5, 6, A to F, H to K, and M)
PORT is an 8-bit read-only register that reflects the port pin state. A write to PORT is invalid.
When PORT is read, the DR bits that correspond to the respective DDR bits set to 1 are read and
the status of each pin whose corresponding DDR bit is cleared to 0 is also read regardless of the
ICR value.
The initial value of PORT is undefined and is determined based on the port pin state.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
Pn7
Pn6
Pn5
Pn4
Pn3
Pn2
Pn1
Pn0
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
R
R
R
R
R
R
R
R
Notes: The lower six bits are valid and the upper two bits are reserved for port 6 registers.
The lower five bits are valid and the upper three bits are reserved for port M registers.
Bits 2 and 3 are valid and the other bits are reserved for port C registers.
Registers of ports J and K cannot be accessed when PCJKE = 0.
Registers of ports D and E cannot be accessed when PCJKE = 1.
Rev. 2.00 Oct. 21, 2009 Page 603 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.1.4
Input Buffer Control Register (PnICR) (n = 1, 2, 3, 5, 6, A to F, H to K, and M)
ICR is an 8-bit readable/writable register that controls the port input buffers.
For bits in ICR set to 1, the input buffers of the corresponding pins are valid. For bits in ICR
cleared to 0, the input buffers of the corresponding pins are invalid and the input signals are fixed
high.
When the pin functions as an input for the peripheral modules, the corresponding bits should be
set to 1. The initial value should be written to a bit whose corresponding pin is not used as an input
or is used as an analog input/output pin.
When PORT is read, the pin state is always read regardless of the ICR value. When the ICR value
is cleared to 0 at this time, the read pin state is not reflected in a corresponding on-chip peripheral
module.
If ICR is modified, an internal edge may occur depending on the pin state. Accordingly, ICR
should be modified when the corresponding input pins are not used. For example, an IRQ input,
modify ICR while the corresponding interrupt is disabled, clear the IRQF flag in ISR of the
interrupt controller to 0, and then enable the corresponding interrupt. If an edge occurs after the
ICR setting, the edge should be cancelled.
The initial value of ICR is H'00.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
Pn7ICR
Pn6ICR
Pn5ICR
Pn4ICR
Pn3ICR
Pn2ICR
Pn1ICR
Pn0ICR
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Notes: The lower six bits are valid and the upper two bits are reserved for port 6 registers.
The lower five bits are valid and the upper three bits are reserved for port M registers.
Bits 2 and 3 are valid and the other bits are reserved for port C registers.
Registers of ports J and K cannot be accessed when PCJKE = 0.
Registers of ports D and E cannot be accessed when PCJKE = 1.
Rev. 2.00 Oct. 21, 2009 Page 604 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.1.5
Pull-Up MOS Control Register (PnPCR) (n = D to F, and H to K)
PCR is an 8-bit readable/writable register that controls on/off of the port input pull-up MOS.
If a bit in PCR is set to 1 while the pin is in input state, the input pull-up MOS corresponding to
the bit in PCR is turned on. Table 13.4 shows the input pull-up MOS state.
The initial value of PCR is H'00.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
Pn7PCR
Pn6PCR
Pn5PCR
Pn4PCR
Pn3PCR
Pn2PCR
Pn1PCR
Pn0PCR
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Table 13.4 Input Pull-Up MOS State
Port
Pin State
Reset
Hardware
Software
Standby Mode Standby Mode
Other
Operation
Port D
Address output
OFF
OFF
OFF
OFF
Port E
Port F
Port H
Port I
Port J
Port output
OFF
OFF
OFF
OFF
Port input
OFF
OFF
ON/OFF
ON/OFF
Address output
OFF
OFF
OFF
OFF
Port output
OFF
OFF
OFF
OFF
Port input
OFF
OFF
ON/OFF
ON/OFF
Address output
OFF
OFF
OFF
OFF
Port output
OFF
OFF
OFF
OFF
Port input
OFF
OFF
ON/OFF
ON/OFF
Data input/output
OFF
OFF
OFF
OFF
Port output
OFF
OFF
OFF
OFF
Port input
OFF
OFF
ON/OFF
ON/OFF
Data input/output
OFF
OFF
OFF
OFF
Port output
OFF
OFF
OFF
OFF
Port input
OFF
OFF
ON/OFF
ON/OFF
Peripheral module output
OFF
OFF
OFF
OFF
Port output
OFF
OFF
OFF
OFF
Port input
OFF
OFF
ON/OFF
ON/OFF
Rev. 2.00 Oct. 21, 2009 Page 605 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Port
Pin State
Reset
Hardware
Software
Standby Mode Standby Mode
Other
Operation
Port K
Peripheral module output
OFF
OFF
OFF
OFF
Port output
OFF
OFF
OFF
OFF
Port input
OFF
OFF
ON/OFF
ON/OFF
[Legend]
OFF:
ON/OFF:
13.1.6
The input pull-up MOS is always off.
If PCR is set to 1, the input pull-up MOS is on; if PCR is cleared to 0, the input pull-up
MOS is off.
Open-Drain Control Register (PnODR) (n = 2 and F)
ODR is an 8-bit readable/writable register that selects the open-drain output function.
If a bit in ODR is set to 1, the pin corresponding to that bit in ODR functions as an NMOS opendrain output. If a bit in ODR is cleared to 0, the pin corresponding to that bit in ODR functions as
a CMOS output.
The initial value of ODR is H'00.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
Pn7ODR
Pn6ODR
Pn5ODR
Pn4ODR
Pn3ODR
Pn2ODR
Pn1ODR
Pn0ODR
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 606 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.2
Output Buffer Control
This section describes the output priority of each pin.
The name of each peripheral module pin is followed by "_OE". This (for example: TIOCA4_OE)
indicates whether the output of the corresponding function is valid (1) or if another setting is
specified (0). Table 13.5 lists each port output signal's valid setting. For details on the
corresponding output signals, see the register description of each peripheral module. If the name
of each peripheral module pin is followed by A or B, the pin function can be modified by the port
function control register (PFCR). For details, see section 13.3, Port Function Controller.
For a pin whose initial value changes according to the activation mode, "Initial value E" indicates
the initial value when the LSI is started up in external extended mode and "Initial value S"
indicates the initial value when the LSI is started in single-chip mode.
13.2.1
(1)
Port 1
P17/IRQ7-A/TCLKD-B/SCL0/EDRAK1 /ADTRG1
The pin function is switched as shown below according to the combination of the EXDMAC and
IIC2 register settings and the P17DDR bit setting.
Setting
Module Name
Pin Function
EXDMAC
IIC2
I/O Port
EDRAK1_OE
SCL0_OE
P17DDR
EXDMAC
EDRAK1 output
1
⎯
⎯
IIC2
SCL0 input/output
0
1
⎯
I/O port
P17 output
0
0
1
P17 input
(initial value)
0
0
0
Rev. 2.00 Oct. 21, 2009 Page 607 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(2)
P16/DACK1-A/IRQ6-A/TCLKC-B/SDA0/EDACK1-A
The pin function is switched as shown below according to the combination of the EXDMAC,
DMAC, and IIC2 register settings and P16DDR bit setting.
Setting
EXDMAC
DMAC
IIC2
I/O Port
Module Name
Pin Function
EDACK1A_OE
DACK1A_OE
SDA0_OE P16DDR
EXDMAC
EDACK1-A output
1
⎯
⎯
—
DMAC
DACK1-A output
0
1
⎯
—
IIC2
SDA0 input/output
0
0
1
⎯
I/O port
P16 output
0
0
0
1
P16 input
(initial value)
0
0
0
0
(3)
P15/RxD5/IrRxD/TEND1-A/ETEND1-A/IRQ5-A/TCLKB-B/SCL1
The pin function is switched as shown below according to the combination of the EXDMAC,
DMAC, and IIC2 register settings and the P15DDR bit setting.
Setting
EXDMAC
Module
Name
Pin Function
EXDMAC ETEND1-A output
DMAC
ETEND1A_OE TEND1A_OE
IIC2
I/O Port
SCL1_OE
P15DDR
1
⎯
—
—
DMAC
TEND1-A output
0
1
⎯
—
IIC2
SCL1 input/output
0
0
1
⎯
I/O port
P15 output
0
0
0
1
P15 input
(initial value)
0
0
0
0
Rev. 2.00 Oct. 21, 2009 Page 608 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(4)
P14/TxD5/IrTxD/DREQ1-A/EDREQ1-A/IRQ4-A/TCLKA-B/SDA1
The pin function is switched as shown below according to the combination of the SCI, IrDA, and
IIC2 register settings and the P14DDR bit setting.
Setting
SCI
IrDA
IIC2
I/O Port
Module Name
Pin Function
TxD5_OE
IrTxD_OE
SDA1_OE
P14DDR
SCI
TxD5 output
1
—
—
—
IrDA
IrTxD output
0
1
—
—
IIC2
SDA1 input/output
0
0
1
—
I/O port
P14 output
0
0
0
1
P14 input
(initial value)
0
0
0
0
(5)
P13/ADTRG0-A/IRQ3-A/EDRAK0
The pin function is switched as shown below according to the register setting of EXDMAC and
the P13DDR bit setting.
Setting
EXDMAC
I/O Port
Module Name
Pin Function
EDRAK0_OE
P13DDR
EXDMAC
EDRAK0 output
1
—
I/O port
P13 output
0
1
P13 input
(initial value)
0
0
Rev. 2.00 Oct. 21, 2009 Page 609 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(6)
P12/SCK2/DACK0-A/IRQ2-A/EDACK0-A
The pin function is switched as shown below according to the combination of the EXDMAC,
DMAC and SCI register settings and the P12DDR bit setting.
Setting
EXDMAC
DMAC
SCI
I/O Port
SCK2_OE
P12DDR
Module
Name
Pin Function
EXDMAC
EDACK0-A output 1
⎯
⎯
⎯
DMAC
DACK0-A output
1
⎯
⎯
EDACK0A_OE DACK0A_OE
0
SCI
SCK2 output
0
0
1
⎯
I/O port
P12 output
0
0
0
1
P12 input
(initial value)
0
0
0
0
(7)
P11/RxD2/TEND0-A/IRQ1-A/ETEND0-A
The pin function is switched as shown below according to the combination of the EXDMAC and
DMAC register settings and the P11DDR bit setting.
Setting
EXDMAC
DMAC
I/O Port
ETEND0A_OE
TEND0A_OE
P11DDR
Module Name
Pin Function
EXDMAC
ETEND0-A output
1
⎯
⎯
DMAC
TEND0-A output
0
1
⎯
I/O port
P11 output
0
0
1
P11 input
(initial value)
0
0
0
Rev. 2.00 Oct. 21, 2009 Page 610 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(8)
P10/TxD2/DREQ0-A/IRQ0-A/EDREQ0-A
The pin function is switched as shown below according to the combination of the SCI register
setting and P10DDR bit setting.
Setting
SCI
I/O Port
Module Name
Pin Function
TxD2_OE
P10DDR
SCI
TxD2 output
1
⎯
I/O port
P10 output
0
1
P10 input
(initial value)
0
0
13.2.2
(1)
Port 2
P27/PO7/TIOCA5/TIOCB5
The pin function is switched as shown below according to the combination of the TPU and PPG
register settings, and the P27DDR bit setting.
Setting
TPU
PPG
I/O Port
Module Name
Pin Function
TIOCB5_OE
PO7_OE
P27DDR
TPU
TIOCB5 output
1
—
—
PPG
PO7 output
0
1
—
P27 output
0
0
1
P27 input
(initial value)
0
0
0
I/O port
Rev. 2.00 Oct. 21, 2009 Page 611 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(2)
P26/PO6/TIOCA5/TMO1/TxD1/IRQ14-A
The pin function is switched as shown below according to the combination of the TPU, TMR,
SCI, and PPG register settings and the P26DDR bit setting.
Setting
TPU
TMR
SCI
PPG
I/O Port
TxD1_OE
PO6_OE
P26DDR
Module Name
Pin Function
TIOCA5_OE TMO1_OE
TPU
TIOCA5 output
1
⎯
⎯
⎯
⎯
TMR
TMO1 output
0
1
⎯
⎯
⎯
SCI
TxD1 output
0
0
1
⎯
⎯
PPG
PO6 output
0
0
0
1
⎯
P26 output
0
0
0
0
1
P26 input
(initial value)
0
0
0
0
0
I/O port
(3)
P25/PO5/TIOCA4/TMCI1/RxD1/IRQ13-A
The pin function is switched as shown below according to the combination of the TPU and PPG
register settings, and the P25DDR bit setting.
Setting
TPU
PPG
I/O Port
Module Name
Pin Function
TIOCA4_OE
PO5_OE
P25DDR
TPU
TIOCA4 output
1
⎯
⎯
PPG
PO5 output
0
1
⎯
I/O port
P25 output
0
0
1
P25 input
(initial value)
0
0
0
Rev. 2.00 Oct. 21, 2009 Page 612 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(4)
P24/PO4/TIOCA4/TIOCB4/TMRI1/SCK1/IRQ12-A
The pin function is switched as shown below according to the combination of the TPU, SCI, and
PPG register settings and the P24DDR bit setting.
Setting
TPU
SCI
PPG
I/O Port
PO4_OE
P24DDR
Module Name
Pin Function
TIOCB4_OE SCK1_OE
TPU
TIOCB4 output
1
⎯
⎯
⎯
SCI
SCK1 output
0
1
⎯
⎯
PPG
PO4 output
0
0
1
⎯
I/O port
P24 output
0
0
0
1
P24 input
(initial value)
0
0
0
0
(5)
P23/PO3/TIOCC3/TIOCD3/IRQ11-A
The pin function is switched as shown below according to the combination of the TPU and PPG
register settings, and the P23DDR bit setting.
Setting
TPU
PPG
I/O Port
Module Name
Pin Function
TIOCD3_OE
PO3_OE
P23DDR
TPU
TIOCD3 output
1
—
—
PPG
PO3 output
0
1
—
P23 output
0
0
1
P23 input
(initial value)
0
0
0
I/O port
Rev. 2.00 Oct. 21, 2009 Page 613 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(6)
P22 /PO2/TIOCC3/TMO0/TxD0/IRQ10-A
The pin function is switched as shown below according to the combination of the TPU, TMR,
SCI, and PPG register settings and the P22DDR bit setting.
Setting
TPU
TMR
SCI
PPG
I/O Port
Module Name
Pin Function
TIOCC3_OE
TMO0_OE TxD0_OE
PO2_OE
P22DDR
TPU
TIOCC3 output
1
⎯
⎯
⎯
⎯
TMR
TMO0 output
0
1
⎯
⎯
⎯
SCI
TxD0 output
0
0
1
⎯
⎯
PPG
PO2 output
0
0
0
1
⎯
P22 output
0
0
0
0
1
P22 input
(initial value)
0
0
0
0
0
I/O port
(7)
P21/PO1/TIOCA3/TMCI0/RxD0/IRQ9-A
The pin function is switched as shown below according to the combination of the TPU and PPG
register settings, and the P21DDR bit setting.
Setting
TPU
PPG
I/O Port
Module Name
Pin Function
TIOCA3_OE
PO1_OE
P21DDR
TPU
TIOCA3 output
1
⎯
⎯
PPG
PO1 output
0
1
⎯
I/O port
P21 output
0
0
1
P21 input
(initial value)
0
0
0
Rev. 2.00 Oct. 21, 2009 Page 614 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(8)
P20/PO0/TIOCA3/TIOCB3/TMRI0/SCK0/IRQ8-A
The pin function is switched as shown below according to the combination of the TPU, PPG, and
SCI, and PPG register settings and the P20DDR bit setting.
Setting
TPU
SCI
PPG
I/O Port
PO0_OE
P20DDR
Module Name
Pin Function
TIOCB3_OE SCK0_OE
TPU
TIOCB3 output
1
⎯
⎯
⎯
SCI
SCK0 output
0
1
⎯
⎯
PPG
PO0 output
0
0
1
⎯
I/O port
P20 output
0
0
0
1
P20 input
(initial value)
0
0
0
0
13.2.3
(1)
Port 3
P37/PO15/TIOCA2/TIOCB2/TCLKD-A/EDRAK3
The pin function is switched as shown below according to the combination of the EXDMAC, TPU
and PPG register settings and the P37DDR bit setting.
Setting
EXDMAC
TPU
PPG
I/O Port
Pin Function
EDRAK3_OE
TIOCB2_OE
PO15_OE
P37DDR
EXDMAC
EDRAK3 output
1
—
—
—
TPU
TIOCB2 output
0
1
—
—
PPG
PO15 output
0
0
1
—
I/O port
P37 output
0
0
0
1
P37 input
(initial value)
0
0
0
0
Module Name
Rev. 2.00 Oct. 21, 2009 Page 615 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(2)
P36/PO14/TIOCA2/EDRAK2
The pin function is switched as shown below according to the combination of the EXDMAC, TPU
and PPG register settings and the P36DDR bit setting.
Setting
EXDMAC
TPU
PPG
I/O Port
Module Name
Pin Function
EDRAK2_OE
TIOCA2_OE
PO14_OE
P36DDR
EXDMAC
EDRAK2 output
1
—
—
—
TPU
TIOCA2 output
0
1
—
—
PPG
PO14 output
0
0
1
—
I/O port
P36 output
0
0
0
1
P36 input
(initial value)
0
0
0
0
(3)
P35/PO13/TIOCA1/TIOCB1/TCLKC-A/DACK1-B/EDACK3
The pin function is switched as shown below according to the combination of the EXDMAC,
DMAC, TPU, and PPG register settings and the P35DDR bit setting.
Setting
EXDMAC
DMAC
TPU
PPG
I/O Port
EDACK3_OE
DACK1B_OE TIOCB1_OE PO13_OE P35DDR
Module
Name
Pin Function
EXDMAC
EDACK3 output 1
⎯
⎯
⎯
⎯
DMAC
DACK1-B
output
0
1
⎯
⎯
⎯
TPU
TIOCB1 output
0
0
1
⎯
⎯
PPG
PO13 output
0
0
0
1
⎯
I/O port
P35 output
0
0
0
0
1
P35 input
(initial value)
0
0
0
0
0
Rev. 2.00 Oct. 21, 2009 Page 616 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(4)
P34/PO12/TIOCA1/TEND1-B/ETEND3
The pin function is switched as shown below according to the combination of the EXDMAC,
DMAC, TPU, and PPG register settings and the P34DDR bit setting.
Setting
EXDMAC
DMAC
ETEND3_OE
TEND1B_OE TIOCA1_OE PO12_OE
P34DDR
ETEND3 output 1
⎯
⎯
⎯
⎯
DMAC
TEND1-B output 0
1
⎯
⎯
⎯
TPU
TIOCA1 output
0
0
1
⎯
⎯
PPG
PO12 output
0
0
0
1
⎯
P34 output
0
0
0
0
1
P34 input
(initial value)
0
0
0
0
0
Module
Name
Pin Function
EXDMAC
I/O port
(5)
TPU
PPG
I/O Port
P33/PO11/TIOCC0/TIOCD0/TCLKB-A/DREQ1-B/EDREQ3
The pin function is switched as shown below according to the combination of the TPU and PPG
register settings, and the P33DDR bit setting.
Setting
TPU
PPG
I/O Port
Module Name
Pin Function
TIOCD0_OE
PO11_OE
P33DDR
TPU
TIOCD0 output
1
—
—
PPG
PO11 output
0
1
—
I/O port
P33 output
0
0
1
P33 input
(initial value)
0
0
0
Rev. 2.00 Oct. 21, 2009 Page 617 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(6)
P32/PO10/TIOCC0/TCLKA-A/DACK0-B/EDACK2
The pin function is switched as shown below according to the combination of the EXDMAC,
DMAC, TPU, and PPG register settings and the P32DDR bit setting.
Setting
EXDMAC
DMAC
TPU
PPG
I/O Port
Pin Function
EDACK2_OE
DACK0B_OE
TIOCC0_OE
PO10_OE
P32DDR
EXDMAC
EDACK2 output
1
⎯
⎯
⎯
⎯
DMAC
DACK0-B output 0
1
⎯
⎯
⎯
TPU
TIOCC0 output
0
0
1
⎯
⎯
PPG
PO10 output
0
0
0
1
⎯
I/O port
P32 output
0
0
0
0
1
P32 input
(initial value)
0
0
0
0
0
Module
Name
(7)
P31/PO9/TIOCA0/TIOCB0/TEND0-B/ETEND2
The pin function is switched as shown below according to the combination of the EXDMAC,
DMAC, TPU, and PPG register settings and the P31DDR bit setting.
Setting
EXDMAC
DMAC
TPU
PPG
I/O Port
Module Name
Pin Function
ETEND2_OE
TEND0B_OE
TIOCB0_OE PO9_OE
P31DDR
EXDMAC
ETEND2 output
1
⎯
⎯
⎯
⎯
DMAC
TEND0-B output
0
1
⎯
⎯
⎯
TPU
TIOCB0 output
0
0
1
⎯
⎯
PPG
PO9 output
0
0
0
1
⎯
I/O port
P31 output
0
0
0
0
1
P31 input
(initial value)
0
0
0
0
0
Rev. 2.00 Oct. 21, 2009 Page 618 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(8)
P30/PO8/TIOCA0/DREQ0-B/EDREQ2
The pin function is switched as shown below according to the combination of the TPU and PPG
register settings, and the P33DDR bit setting.
Setting
TPU
PPG
I/O Port
Module Name
Pin Function
TIOCA0_OE
PO8_OE
P30DDR
TPU
TIOCA0 output
1
⎯
⎯
PPG
PO8 output
0
1
⎯
I/O port
P30 output
0
0
1
P30 input
(initial value)
0
0
0
13.2.4
(1)
Port 5
P57/AN7/DA1/IRQ7-B
Module Name
Pin Function
D/A converter
DA1 output
(2)
P56/AN6/DA0/IRQ6-B
Module Name
Pin Function
D/A converter
DA0 output
Rev. 2.00 Oct. 21, 2009 Page 619 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.2.5
(1)
Port 6
P65/TMO3/ DACK3 /EDACK1-B/TCK
The pin function is switched as shown below according to the combination of the EXDMAC,
DMAC and TMR register settings and P65DDR bit setting.
Setting
MCU
Operation
Mode
Module Name
Pin Function
EXDMAC
EDACK1-B output Except for
boundary
DACK3 output
scan
TMO3 output
enabled
P65 output
mode*
DMAC
TMR
I/O port
P65 input
(initial value)
Note:
(2)
*
EXDMAC
DMAC
EDACK1B_OE DACK3_OE
TMR
I/O Port
TMO3_OE
P65DDR
1
⎯
⎯
⎯
0
1
⎯
⎯
0
0
1
⎯
0
0
0
1
0
0
0
0
These pins are boundary scan dedicated input pins during boundary scan enabled
mode.
P64/TMCI3/TEND3/ETEND1-B/TDI
The pin function is switched as shown below according to the combination of the EXDMAC and
DMAC register settings and P64DDR bit setting.
Setting
MCU
Operation
Mode
EXDMAC
DMAC
ETEND1B_OE
I/O Port
Module Name
Pin Function
TEND3_OE
P64DDR
EXDMAC
ETEND1-B output Except for
1
boundary
scan
TEND3 output
0
enabled mode*
P64 output
0
⎯
⎯
1
⎯
0
1
P64 input
(initial value)
0
0
DMAC
I/O port
Note:
*
0
These pins are boundary scan dedicated input pins during boundary scan enabled
mode.
Rev. 2.00 Oct. 21, 2009 Page 620 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(3)
P63/TMRI3/DREQ3/EDREQ1-B/IRQ11-B/TMS
The pin function is switched as shown below according to the P63DDR bit setting.
Setting
I/O Port
Module Name
Pin Function
MCU Operation Mode
P63DDR
I/O port
P63 output
Except for boundary scan
enabled mode*
1
P63 input
(initial value)
Note:
(4)
*
0
These pins are boundary scan dedicated input pins during boundary scan enabled
mode.
P62/TMO2/SCK4/DACK2/EDACK0-B/IRQ10-B/TRST
The pin function is switched as shown below according to the combination of the EXDMAC,
DMAC, TMR, and SCI register settings and P62DDR bit setting.
Setting
Module
Name
Pin Function
EXDMAC EDACK0-B
output
MCU
Operation
Mode
EXDMAC
DMAC
TMR
SCI
I/O Port
EDACK0B_OE DACK2_OE TMO2_OE SCK4_OE P62DDR
⎯
⎯
⎯
⎯
1
⎯
⎯
⎯
0
1
⎯
⎯
DMAC
DACK2 output
TMR
TMO2 output
Except for
1
boundary
scan enabled 0
mode*
0
SCI
SCK4 output
0
0
0
1
⎯
I/O port
P62 output
0
0
0
0
1
P62 input
(initial value)
0
0
0
0
0
Note:
*
These pins are boundary scan dedicated input pins during boundary scan enabled
mode.
Rev. 2.00 Oct. 21, 2009 Page 621 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(5)
P61/TMCI2/RxD4/TEND2/ETEND0-B/IRQ9-B
The pin function is switched as shown below according to the combination of the EXDMAC and
DMAC register settings and P61DDR bit setting.
Setting
Module
Name
EXDMAC
EXDMAC
DMAC
I/O Port
Pin Function
ETEND0B_OE
TEND2_OE
P61DDR
ETEND0-B
output
1
⎯
⎯
DMAC
TEND2 output
0
1
⎯
I/O port
P61 output
0
0
1
P61 input
(initial value)
0
0
0
(6)
P60/TMRI2/TxD4/DREQ2/EDREQ0-B/IRQ8-B
The pin function is switched as shown below according to the combination of the SCI register
setting and P60DDR bit setting.
Setting
SCI
I/O Port
Module Name
Pin Function
TxD4_OE
P60DDR
SCI
TxD4 output
1
⎯
I/O port
P60 output
0
1
P60 input
(initial value)
0
0
Rev. 2.00 Oct. 21, 2009 Page 622 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.2.6
(1)
Port A
PA7/Bφ
The pin function is switched as shown below according to the PA7DDR bit setting.
Setting
I/O Port
Module Name
Pin Function
PA7DDR
I/O port
Bφ output
(initial value E)
PA7 input
(initial value S)
1
[Legend]
Initial value E:
Initial value S:
(2)
0
Initial value in external extended mode
Initial value in single-chip mode
PA6/AS/AH/BS-B
The pin function is switched as shown below according to the combination of operating mode,
EXPE bit, bus controller register, the port function control register (PFCR), and the PA6DDR bit
settings.
Setting
Bus
Controller
I/O Port
Module Name
Pin Function
AH_OE
BSB_OE
AS_OE
PA6DDR
Bus controller
AH output*
BS-B output*
AS output*
(initial value E)
PA6 output
PA6 input
(initial value S)
1
0
0
⎯
1
0
⎯
⎯
1
⎯
⎯
⎯
0
0
0
0
0
0
1
0
I/O port
[Legend]
Initial value E:
Initial value in external extended mode
Initial value S:
Initial value in single-chip mode
Note: * Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 623 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(3)
PA5/RD
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, and the PA5DDR bit settings.
Setting
MCU Operating Mode
I/O Port
Module Name
Pin Function
EXPE
PA5DDR
Bus controller
RD output*
(Initial value E)
1
⎯
I/O port
PA5 output
0
1
PA5 input
(initial value S)
0
0
[Legend]
Initial value E:
Initial value in external extended mode
Initial value S:
Initial value in single-chip mode
Note: * Valid in external extended mode (EXPE = 1)
(4)
PA4/LHWR/LUB
The pin function is switched as shown below according to the combination of operating mode,
EXPE bit, bus controller register, the port function control register (PFCR), and the PA4DDR bit
settings.
Setting
Bus Controller
I/O Port
Module Name
Pin Function
LUB_OE*
Bus controller
LUB output*1
1
⎯
⎯
LHWR output*
(initial value E)
⎯
1
⎯
PA4 output
0
0
1
PA4 input
(initial value S)
0
0
0
1
I/O port
2
LHWR_OE*
2
PA4DDR
[Legend]
Initial value E:
Initial value in external extended mode
Initial value S:
Initial value in single-chip mode
Notes: 1. Valid in external extended mode (EXPE = 1)
2. When the byte control SRAM space is accessed while the byte control SRAM space is
specified or while LHWROE = 1, this pin functions as the LUB output; otherwise, the
LHWR output.
Rev. 2.00 Oct. 21, 2009 Page 624 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(5)
PA3/LLWR/LLB
The pin function is switched as shown below according to the combination of operating mode,
EXPE bit, bus controller register, and the PA3DDR bit settings.
Setting
Bus Controller
I/O Port
Module Name
Pin Function
LLB_OE*
LLWR_OE*
PA3DDR
Bus controller
LLB output*1
1
⎯
⎯
LLWR output*
(initial value E)
⎯
1
⎯
PA3 output
0
0
1
PA3 input
(initial value S)
0
0
0
2
1
I/O port
2
[Legend]
Initial value E:
Initial value in external extended mode
Initial value S:
Initial value in single-chip mode
Notes: 1. Valid in external extended mode (EXPE = 1)
2. If the byte control SRAM space is accessed, this pin functions as the LLB output;
otherwise, the LLWR.
(6)
PA2/BREQ/WAIT
The pin function is switched as shown below according to the combination of the bus controller
register setting and the PA2DDR bit setting.
Setting
Bus Controller
I/O Port
Module Name
Pin Function
BCR_BRLE
BCR_WAITE
PA2DDR
Bus controller
BREQ input
1
⎯
⎯
WAIT input
0
1
⎯
PA2 output
0
0
1
PA2 input
(initial value)
0
0
0
I/O port
Rev. 2.00 Oct. 21, 2009 Page 625 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(7)
PA1/BACK/(RD/WR-A)
The pin function is switched as shown below according to the combination of operating mode,
EXPE bit, bus controller register, the port function control register (PFCR), and the PA1DDR bit
settings.
Setting
Bus Controller
I/O Port
Module Name
Pin Function
BACK_OE
Byte control
SRAM
Selection
Bus controller
BACK output *
1
⎯
⎯
⎯
1
⎯
⎯
RD/WR-A output * 0
I/O port
Note:
(8)
*
(RD/WR-A)_OE PA1DDR
0
0
1
⎯
PA1 output
0
0
0
1
PA1 input
(initial value)
0
0
0
0
Valid in external extended mode (EXPE = 1)
PA0/BREQO/BS-A
The pin function is switched as shown below according to the combination of operating mode,
EXPE bit, bus controller register, the port function control register (PFCR), and the PA0DDR bit
settings.
Setting
I/O Port
Bus Controller
I/O Port
Module Name
Pin Function
BS-A_OE
BREQO_OE
PA0DDR
Bus controller
BS-A output*
1
⎯
⎯
BREQO output*
0
1
⎯
PA0 output
0
0
1
PA0 input
(initial value)
0
0
0
I/O port
Note:
*
Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 626 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.2.7
(1)
Port B
PB7/SDφ
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PB7DDR bit settings.
Setting
MCU Operating Mode
I/O Port
Module Name
Pin Function
SDRAM Mode
PB7DDR
Clock pulse
generator
SDφ output*
1
⎯
I/O port
PB7 output
0
1
PB7 input
(initial value)
0
0
Note:
(2)
*
Valid in SDRAM mode
PB6/CS6-D/(RD/WR-B)/ADTRG0-B
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, bus controller register, port function control register (PFCR), and the PB6DDR bit
settings.
Setting
I/O Port
Byte control
SRAM
Selection
Module Name
Pin Function
Bus controller
RD/WR-B output* 1
I/O port
Note:
*
(RD/WR)-B_OE
CS6D_OE
PB6DDR
⎯
⎯
⎯
0
1
⎯
⎯
CS6-D output*
0
0
1
⎯
PB6 output
0
0
0
1
PB6 input
(initial value)
0
0
0
0
Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 627 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(3)
PB5/CS5-D/OE/CKE
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the bus controller register, the port function control register (PFCR), and the PB5DDR
bit settings.
Setting
I/O Port
Module Name
Pin Function
CKE_OE
OE_OE
CS5D_OE
PB5DDR
Bus controller
CKE output*
1
⎯
⎯
⎯
OE output*
0
1
⎯
⎯
CS5-D output*
0
0
1
⎯
PB5 output
0
0
0
1
PB5 input
(initial value)
0
0
0
0
I/O port
Note:
(4)
*
Valid in external extended mode (EXPE = 1)
PB4/CS4-B/WE
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the bus controller register, the port function control register (PFCR), and the PB4DDR
bit settings.
Setting
Bus Controller
I/O Port
Module Name
Pin Function
WE_OE
CS4B_OE
PB4DDR
Bus controller
WE output*
1
⎯
⎯
I/O port
Note:
*
CS4-B output*
0
1
⎯
PB4 output
0
0
1
PB4 input
(initial value)
0
0
0
Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 628 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(5)
PB3/CS3/CS7-A/CAS
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the bus controller register, the port function control register (PFCR), and the PB3DDR
bit settings.
Setting
Bus Controller
I/O Port
Module Name
Pin Function
CAS_OE
CS3_OE
CS7A_OE
PB3DDR
Bus controller
CAS output*
1
⎯
⎯
⎯
CS3 output*
0
1
⎯
⎯
CS7-A output*
0
⎯
1
⎯
PB3 output
0
0
0
1
PB3 input
(initial value)
0
0
0
0
I/O port
Note:
(6)
*
Valid in external extended mode (EXPE = 1)
PB2/CS2-A/CS6-A/RAS
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the bus controller register, the port function control register (PFCR), and the PB2DDR
bit settings.
Setting
Bus Controller
I/O Port
Module Name
Pin Function
RAS_OE
CS2A_OE
CS6A_OE
PB2DDR
Bus controller
RAS output*
1
⎯
⎯
⎯
CS2-A output*
0
1
⎯
⎯
CS6-A output*
0
⎯
1
⎯
PB2 output
0
0
0
1
PB2 input
(initial value)
0
0
0
0
I/O port
Note:
*
Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 629 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(7)
PB1/CS1/CS2-B/CS5-A/CS6-B/CS7-B
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PB1DDR bit settings.
Setting
I/O Port
Module Name
Pin Function
CS1_OE
CS2B_OE
CS5A_OE
CS6B_OE
CS7B_OE
PB1DDR
Bus controller
CS1 output*
1
⎯
⎯
⎯
⎯
⎯
CS2-B output*
⎯
1
⎯
⎯
⎯
⎯
CS5-A output*
⎯
⎯
1
⎯
⎯
⎯
CS6-B output*
⎯
⎯
⎯
1
⎯
⎯
I/O port
Note:
(8)
*
CS7-B output*
⎯
⎯
⎯
⎯
1
⎯
PB1 output
0
0
0
0
0
1
PB1 input
(initial value)
0
0
0
0
0
0
Valid in external extended mode (EXPE = 1)
PB0/CS0/CS4-A/CS5-B
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PB0DDR bit settings.
Setting
I/O Port
Module Name
Pin Function
CS0_OE
CS4A_OE
CS5B_OE
PB0DDR
Bus controller
CS0 output
(initial value E)
1
⎯
⎯
⎯
CS4-A output
⎯
1
⎯
⎯
CS5-B output
⎯
⎯
1
⎯
PB0 output
0
0
0
1
PB0 input
(initial value S)
0
0
0
0
I/O port
[Legend]
Initial value E:
Initial value S:
Initial value in on-chip ROM disabled external extended mode
Initial value in other modes
Rev. 2.00 Oct. 21, 2009 Page 630 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.2.8
(1)
Port C
PC3/LLCAS/DQMLL
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the bus controller register, and the PC3DDR bit settings.
Setting
Bus Controller
I/O Port
Module Name
Pin Function
LLCAS_OE
DQMLL_OE
PC3DDR
Bus controller
LLCAS output*
1
⎯
⎯
DQMLL output*
⎯
1
⎯
PC3 output
0
0
1
PC3 input
(initial value)
0
0
0
I/O port
Note:
(2)
*
Valid in external extended mode (EXPE = 1)
PC2/LUCAS/DQMLU
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the bus controller register, and the PC2DDR bit settings.
Setting
Bus Controller
I/O Port
Module Name
Pin Function
LUCAS_OE
DQMLU_OE
PC2DDR
Bus controller
LUCAS output*
1
⎯
⎯
DQMLU output*
⎯
1
⎯
PC2 output
0
0
1
PC2 input
(initial value)
0
0
0
I/O port
Note:
*
Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 631 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.2.9
Port D
The pin function of port D can be switched with that of port J according to the combination of
operating mode, the EXPE bit, and the PCJKE bit settings. The pin function of port D can be
switched according to the PCJKE bit setting in the single-chip mode (EXPE = 0). However, do not
change the setting of the PCJKE bit in external extended mode. For details, see section 13.3.12,
Port Function Control Register D (PFCRD).
(1)
PD7/A7, PD6/A6, PD5/A5, PD4/A4, PD3/A3, PD2/A2, PD1/A1, PD0/A0
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, and the PDnDDR bit settings.
Setting
I/O Port
Module Name
Pin Function
MCU Operating Mode
PDnDDR
Bus controller
Address output
On-chip ROM disabled extended mode
On-chip ROM enabled extended mode
⎯
1
I/O port
PDn output
PDn input
(initial value)
Single-chip mode*
Modes other than on-chip ROM
disabled extended mode
1
0
[Legend]
n:
0 to 7
Note: * Address output is enabled by setting PDnDDR = 1 in external extended mode
(EXPE = 1)
13.2.10 Port E
The pin function of port E can be switched with that of port K according to the combination of
operating mode, the EXPE bit, and the PCJKE bit settings. The pin function of port E can be
switched according to the PCJKE bit setting in the single-chip mode (EXPE = 0). However, do not
change the setting of the PCJKE bit in external extended mode. For details, see section 13.3.12,
Port Function Control Register D (PFCRD).
Rev. 2.00 Oct. 21, 2009 Page 632 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(1)
PE7/A15, PE6/A14, PE5/A13, PE4/A12, PE3/A11, PE2/A10, PE1/A9, PE0/A8
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, and the PEnDDR bit settings.
Setting
I/O Port
Module Name
Pin Function
MCU Operating Mode
PEnDDR
Bus controller
Address output
On-chip ROM disabled extended mode
On-chip ROM enabled extended mode
⎯
1
I/O port
PEn output
PEn input
(initial value)
Single-chip mode*
Modes other than on-chip ROM
disabled extended mode
1
0
[Legend]
n:
0 to 7
Note: * Address output is enabled by setting PDnDDR = 1 in external extended mode
(EXPE = 1)
13.2.11 Port F
(1)
PF7/A23
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PF7DDR bit settings.
Setting
I/O Port
Module Name
Pin Function
A23_OE
PF7DDR
Bus controller
A23 output*
1
⎯
I/O port
PF7 output
0
1
PF7 input
(initial value)
0
0
Note:
*
Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 633 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(2)
PF6/A22
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PF6DDR bit settings.
Setting
I/O Port
Module Name
Pin Function
A22_OE
PF6DDR
Bus controller
A22 output*
1
⎯
I/O port
PF6 output
0
1
PF6 input
(initial value)
0
0
Note:
(3)
*
Valid in external extended mode (EXPE = 1)
PF5/A21
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PF5DDR bit settings.
Setting
I/O Port
Module Name
Pin Function
A21_OE
PF5DDR
Bus controller
A21 output*
1
⎯
I/O port
PF5 output
0
1
PF5 input
(initial value)
0
0
Note:
*
Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 634 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(4)
PF4/A20
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PF4DDR bit settings.
Setting
MCU
Operating Mode
I/O Port
Module Name
Pin Function
A20_OE
PF4DDR
On-chip ROM
disabled extended
mode
Bus controller
A20 output
⎯
⎯
Modes other than
on-chip ROM
disabled extended
mode
Bus controller
A20 output*
1
⎯
I/O port
PF4 output
0
1
PF4 input
(initial value)
0
0
Note:
(5)
*
Valid in external extended mode (EXPE = 1)
PF3/A19
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PF3DDR bit settings.
Setting
MCU
Operating Mode
I/O Port
Module Name
Pin Function
A19_OE
PF3DDR
On-chip ROM
disabled extended
mode
Bus controller
A19 output
⎯
⎯
Modes other than
on-chip ROM
disabled extended
mode
Bus controller
A19 output*
1
⎯
I/O port
PF3 output
0
1
PF3 input
(initial value)
0
0
Note:
*
Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 635 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(6)
PF2/A18
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PF2DDR bit settings.
Setting
MCU
Operating Mode
I/O Port
Module Name
Pin Function
A18_OE
PF2DDR
On-chip ROM
disabled extended
mode
Bus controller
A18 output
⎯
⎯
Modes other than
on-chip ROM
disabled extended
mode
Bus controller
A18 output*
1
⎯
I/O port
PF2 output
0
1
PF2 input
(initial value)
0
0
Note:
(7)
*
Valid in external extended mode (EXPE = 1)
PF1/A17
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PF1DDR bit settings.
Setting
MCU
Operating Mode
I/O Port
Module Name
Pin Function
A17_OE
PF1DDR
On-chip ROM
disabled extended
mode
Bus controller
A17 output
⎯
⎯
Modes other than
on-chip ROM
disabled extended
mode
Bus controller
A17 output*
1
⎯
I/O port
PF1 output
0
1
PF1 input
(initial value)
0
0
Note:
*
Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 636 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(8)
PF0/A16
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, the port function control register (PFCR), and the PF0DDR bit settings.
Setting
MCU
Operating Mode
I/O Port
Module Name
Pin Function
A16_OE
PF0DDR
On-chip ROM
disabled extended
mode
Bus controller
A16 output
⎯
⎯
Modes other than
on-chip ROM
disabled extended
mode
Bus controller
A16 output*
1
⎯
I/O port
PF0 output
0
1
PF0 input
(initial value)
0
0
Note:
*
Valid in external extended mode (EXPE = 1)
13.2.12 Port H
(1)
PH7/D7, PH6/D6, PH5/D5, PH4/D4, PH3/D3, PH2/D2, PH1/D1, PH0/D0
The pin function is switched as shown below according to the combination of operating mode, the
EXPE bit, and the PHnDDR bit settings.
Setting
MCU Operating Mode
I/O Port
Module Name
Pin Function
EXPE
PHnDDR
Bus controller
Data I/O*
(initial value E)
1
⎯
I/O port
PHn output
0
1
PHn input
(initial value S)
0
0
[Legend]
Initial value E:
Initial value in external extended mode
Initial value S:
Initial value in single-chip mode
n:
0 to 7
Note: * Valid in external extended mode (EXPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 637 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.2.13 Port I
(1)
PI7/D15, PI6/D14, PI5/D13, PI4/D12, PI3/D11, PI2/D10, PI1/D9, PI0/D8
The pin function is switched as shown below according to the combination of operating mode, bus
mode, the EXPE bit, and the PInDDR bit settings.
Setting
Bus Controller
I/O Port
Module Name
Pin Function
16-Bit Bus Mode
PInDDR
Bus controller
Data I/O*
(initial value E)
PIn output
PIn input
(initial value S)
1
⎯
0
0
1
0
I/O port
[Legend]
Initial value E:
Initial value in external extended mode
Initial value S:
Initial value in single-chip mode
n:
0 to 7
Note: * Valid in external extended mode (EXPE = 1)
13.2.14 Port J
The pin function of port J can be switched with that of port D according to the combination of
operating mode, the EXPE bit, and the PCJKE bit settings. The pin function of port J can be
switched according to the PCJKE bit setting in the single-chip mode (EXPE = 0). However, do not
change the setting of the PCJKE bit in external extended mode. For details, see section 13.3.12,
Port Function Control Register D (PFCRD).
Rev. 2.00 Oct. 21, 2009 Page 638 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(1)
PJ7/TIOCA8/TIOCB8/TCLKH/PO23
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PJ7DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO23_OE
TIOCB8_OE
PJ7DDR
PPG
PO23 output*
1
⎯
⎯
TPU
TIOCB8 output*
0
1
⎯
I/O port
PJ7 output*
0
0
1
PJ7 input*
0
0
0
Note:
(2)
*
Valid when PCJKE = 1.
PJ6/TIOCA8/PO22
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PJ6DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO22_OE
TIOCA8_OE
PJ6DDR
PPG
PO22 output*
1
⎯
⎯
TPU
TIOCA8 output*
0
1
⎯
I/O port
PJ6 output*
0
0
1
PJ6 input*
0
0
0
Note:
*
Valid when PCJKE = 1.
Rev. 2.00 Oct. 21, 2009 Page 639 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(3)
PJ5/TIOCA7/TIOCB7/TCLKG/PO21
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PJ5DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO21_OE
TIOCB7_OE
PJ5DDR
PPG
PO21 output*
1
⎯
⎯
TPU
TIOCB7 output*
0
1
⎯
I/O port
PJ5 output*
0
0
1
PJ5 input*
0
0
0
Note:
(4)
*
Valid when PCJKE = 1.
PJ4/TIOCA7/PO20
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PJ4DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO20_OE
TIOCA7_OE
PJ4DDR
PPG
PO20 output*
1
⎯
⎯
TPU
TIOCA7 output*
0
1
⎯
I/O port
PJ4 output*
0
0
1
PJ4 input*
0
0
0
Note:
*
Valid when PCJKE = 1.
Rev. 2.00 Oct. 21, 2009 Page 640 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(5)
PJ3/PO19/TIOCC6/TIOCD6/TCLKF
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PJ3DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO19_OE
TIOCD6_OE
PJ3DDR
PPG
PO19 output*
1
⎯
⎯
TPU
TIOCD6 output*
0
1
⎯
I/O port
PJ3 output*
0
0
1
PJ3 input*
0
0
0
Note:
(6)
*
Valid when PCJKE = 1.
PJ2/PO18/TIOCC6/TCLKE
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PJ2DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO18_OE
TIOCC6_OE
PJ2DDR
PPG
PO18 output*
1
⎯
⎯
TPU
TIOCC6 output*
0
1
⎯
I/O port
PJ2 output*
0
0
1
PJ2 input*
0
0
0
Note:
*
Valid when PCJKE = 1.
Rev. 2.00 Oct. 21, 2009 Page 641 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(7)
PJ1/PO17/TIOCA6/TIOCB6
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PJ1DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO17_OE
TIOCB6_OE
PJ1DDR
PPG
PO17 output*
1
⎯
⎯
TPU
TIOCB6 output*
0
1
⎯
I/O port
PJ1 output*
0
0
1
PJ1 input*
0
0
0
Note:
(8)
*
Valid when PCJKE = 1.
PJ0/PO16/TIOCA6
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PJ0DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO16_OE
TIOCA6_OE
PJ0DDR
PPG
PO16 output*
1
⎯
⎯
TPU
TIOCA6 output*
0
1
⎯
I/O port
PJ0 output*
0
0
1
PJ0 input*
0
0
0
Note:
*
Valid when PCJKE = 1.
Rev. 2.00 Oct. 21, 2009 Page 642 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.2.15 Port K
The pin function of port K can be switched with that of port E according to the combination of
operating mode, the EXPE bit, and the PCJKE bit settings. The pin function of port K can be
switched according to the PCJKE bit setting in the single-chip mode (EXPE = 0). However, do not
change the setting of the PCJKE bit in external extended mode. For details, see section 13.3.12,
Port Function Control Register D (PFCRD).
(1)
PK7/PO31/TIOCA11/TIOCB11
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PK7DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO31_OE
TIOCB11_OE
PK7DDR
PPG
PO31 output*
1
⎯
⎯
TPU
TIOCB11 output*
0
1
⎯
I/O port
PK7 output*
0
0
1
PK7 input*
0
0
0
Note:
(2)
*
Valid when PCJKE = 1.
PK6/PO30/TIOCA11
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PK6DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO30_OE
TIOCA11_OE
PK6DDR
PPG
PO30 output*
1
⎯
⎯
TPU
TIOCA11 output*
0
1
⎯
I/O port
PK6 output*
0
0
1
PK6 input*
0
0
0
Note:
*
Valid when PCJKE = 1.
Rev. 2.00 Oct. 21, 2009 Page 643 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(3)
PK5/PO29/TIOCA10/TIOCB10
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PK5DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO29_OE
TIOCB10_OE
PK5DDR
PPG
PO29 output*
1
⎯
⎯
TPU
TIOCB10 output*
0
1
⎯
I/O port
PK5 output*
0
0
1
PK5 input*
0
0
0
Note:
(4)
*
Valid when PCJKE = 1.
PK4/PO28/TIOCA10
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PK4DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO28_OE
TIOCA10_OE
PK4DDR
PPG
PO28 output*
1
⎯
⎯
TPU
TIOCA10 output*
0
1
⎯
I/O port
PK4 output*
0
0
1
PK4 input*
0
0
0
Note:
*
Valid when PCJKE = 1.
Rev. 2.00 Oct. 21, 2009 Page 644 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(5)
PK3/PO27/TIOCC9/TIOCD9
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PK3DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO27_OE
TIOCD9_OE
PK3DDR
PPG
PO27 output*
1
⎯
⎯
TPU
TIOCD9 output*
0
1
⎯
I/O port
PK3 output*
0
0
1
PK3 input*
0
0
0
Note:
(6)
*
Valid when PCJKE = 1.
PK2/PO26/TIOCC9
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PK2DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO26_OE
TIOCC9_OE
PK2DDR
PPG
PO26 output*
1
⎯
⎯
TPU
TIOCC9 output*
0
1
⎯
I/O port
PK2 output*
0
0
1
PK2 input*
0
0
0
Note:
*
Valid when PCJKE = 1.
Rev. 2.00 Oct. 21, 2009 Page 645 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(7)
PK1/PO25/TIOCA9/TIOCB9
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PK1DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO25_OE
TIOCB9_OE
PK1DDR
PPG
PO25 output*
1
⎯
⎯
TPU
TIOCB9 output*
0
1
⎯
I/O port
PK1 output*
0
0
1
PK1 input*
0
0
0
Note:
(8)
*
Valid when PCJKE = 1.
PK0/PO24/TIOCA9
The pin function is switched as shown below according to the combination of register setting of
PPG and TPU, setting of the port function control register (PFCR), and the PK0DDR bit settings.
Setting
PPG
TPU
I/O Port
Module Name
Pin Function
PO24_OE
TIOCA9_OE
PK0DDR
PPG
PO24 output*
1
⎯
⎯
TPU
TIOCA9 output*
0
1
⎯
I/O port
PK0 output*
0
0
1
PK0 input*
0
0
0
Note:
*
Valid when PCJKE = 1.
Rev. 2.00 Oct. 21, 2009 Page 646 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.2.16 Port M
(1)
PM4
The pin function is switched as shown below according to the combination of the USB register
setting and PM4DDR bit setting.
Setting
USB
I/O Port
PULLUP_E
PM4DDR
Module Name
Pin Function
USB
PULLUP control output 1
—
I/O port
PM4 output
0
1
PM4 input
(initial value)
0
0
(2)
PM3
The pin function is switched as shown below according to the combination of the PM3DDR bit
setting.
Setting
I/O Port
Module Name
Pin Function
PM3DDR
I/O port
PM3 output
PM3 input
(initial value)
1
0
(3)
PM2
The pin function is switched as shown below according to the combination of the PM2DDR bit
setting.
Setting
I/O Port
Module Name
Pin Function
PM2DDR
I/O port
PM2 output
1
PM2 input
(initial value)
0
Rev. 2.00 Oct. 21, 2009 Page 647 of 1454
REJ09B0498-0200
Section 13 I/O Ports
(4)
PM1/RxD6
The pin function is switched as shown below according to the combination of the PM1DDR bit
setting.
Setting
I/O Port
Module Name
Pin Function
PM1DDR
I/O port
PM1 output
1
PM1 input
(initial value)
0
(5)
PM0/TxD6
The pin function is switched as shown below according to the combination of the SCI register
setting and PM0DDR bit setting.
Setting
SCI
I/O Port
Module Name
Pin Function
TxD6_OE
PM0DDR
SCI
TxD6 output
1
—
I/O port
PM0 output
0
1
PM0 input
(initial value)
0
0
Rev. 2.00 Oct. 21, 2009 Page 648 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Table 13.5 Available Output Signals and Settings in Each Port
Port
P1
7
6
Output
Specification
Signal Name
Output
Signal
Name
EDRAK1_OE
EDRAK1
SCL0_OE
SCL0
Signal Selection Register
Settings
Peripheral Module Settings
PFCR8.EDMAS1[A,B] =
00
SYSCR.EXPE = 1,
EDMDR_1.EDRAKE = 1
ICCRA.ICE = 1
EDACK1A_OE EDACK1
PFCR8.EDMAS1[A,B] =
00
SYSCR.EXPE = 1, EDACR_1.AMS = 1,
EDMDR_1.EDACKE = 1
DACK1A_OE
DACK1
PFCR7.DMAS1[A,B] = 00
DMAC.DACR_1.AMS = 1,
DMDR_1.DACKE = 1
SDA0_OE
SDA0
ICCRA.ICE = 1
ETEND1A_OE ETEND1
PFCR8.EDMAS1[A,B] =
00
SYSCR.EXPE = 1,
EDMDR_1.ETENDE = 1
TEND1A_OE
TEND1
PFCR7.DMAS1[A,B] = 00
DMDR_1.TENDE = 1
SCL1_OE
SCL1
ICCRA.ICE = 1
TxD5_OE
TxD5
SCR.TE = 1, IrCR.IrE = 0
IrTxD_OE
IrTxD
SCR.TE = 1, IrCR.IrE = 1
SDA1_OE
SDA1
ICCRA.ICE = 1
3
EDRAK0_OE
EDRAK0
PFCR8.EDMAS0[A,B] =
00
SYSCR.EXPE = 1,
EDMDR_0.EDRAKE = 1
2
EDACK0A_OE EDACK0
PFCR8.EDMAS0[A,B] =
00
SYSCR.EXPE = 1, EDACR_0.AMS = 1,
EDMDR_0.EDACKE = 1
DACK0A_OE
DACK0
PFCR7.DMAS0[A,B] = 00
DMAC.DACR_0.AMS = 1,
DMDR_0.DACKE = 1
SCK2_OE
SCK2
5
4
1
0
When SCMR.SMIF = 1:
SCR.TE = 1 or SCR.RE = 1 while
SMR.GM = 0, SCR.CKE [1, 0] = 01 or
while SMR.GM = 1
When SCMR.SMIF = 0:
SCR.TE = 1 or SCR.RE = 1 while
SMR.C/A = 0, SCR.CKE [1, 0] = 01 or
while SMR.C/A = 1, SCR.CKE 1 = 0
ETEND0A_OE ETEND0
PFCR8.EDMAS0[A,B] =
00
SYSCR.EXPE = 1,
EDMDR_0.ETENDE = 1
TEND0A_OE
TEND0
PFCR7.DMAS0[A,B] = 00
DMDR_0.TENDE = 1
TxD2_OE
TxD2
SCR.TE = 1
Rev. 2.00 Oct. 21, 2009 Page 649 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Port
P2
7
6
5
4
3
2
Output
Specification
Signal Name
Output
Signal
Name
TIOCB5_OE
TIOCB5
TPU.TIOR_5.IOB3 = 0,
TPU.TIOR_5.IOB[1,0] = 01/10/11
PO7_OE
PO7
NDERL.NDER7 = 1
TIOCA5_OE
TIOCA5
TPU.TIOR_5.IOA3 = 0,
TPU.TIOR_5.IOA[1,0] = 01/10/11
TMO1_OE
TMO1
TMR.TCSR_1.OS3,2 = 01/10/11 or
TMR.TCSR_1.OS[1,0] = 01/10/11
Signal Selection
Register Settings
Peripheral Module Settings
TxD1_OE
TxD1
SCR.TE = 1
PO6_OE
PO6
NDERL.NDER6 = 1
TIOCA4_OE
TIOCA4
TPU.TIOR_4.IOA3 = 0,
TPU.TIOR_4.IOA[1,0] = 01/10/11
PO5_OE
PO5
NDERL.NDER5 = 1
TIOCB4_OE
TIOCB4
TPU.TIOR_4.IOB3 = 0,
TPU.TIOR_4.IOB[1,0] = 01/10/11
SCK1_OE
SCK1
When SCMR.SMIF = 1:
SCR.TE = 1 or SCR.RE = 1 while
SMR.GM = 0, SCR.CKE [1, 0] = 01 or while
SMR.GM = 1
When SCMR.SMIF = 0:
SCR.TE = 1 or SCR.RE = 1 while
SMR.C/A = 0, SCR.CKE [1, 0] = 01 or while
SMR.C/A = 1, SCR.CKE 1 = 0
PO4_OE
PO4
NDERL.NDER4 = 1
TIOCD3_OE
TIOCD3
TPU.TMDR.BFB = 0,
TPU.TIORL_3.IOD3 = 0,
TPU.TIORL_3.IOD[1,0] = 01/10/11
PO3_OE
PO3
NDERL.NDER3 = 1
TIOCC3_OE
TIOCC3
TPU.TMDR.BFA = 0,
TPU.TIORL_3.IOC3 = 0,
TPU.TIORL_3.IOD[1,0] = 01/10/11
TMO0_OE
TMO0
TMR.TCSR_0.OS[3,2] = 01/10/11 or
TMR.TCSR_0.OS[1,0] = 01/10/11
TxD0_OE
TxD0
SCR.TE = 1
PO2_OE
PO2
NDERL.NDER2 = 1
Rev. 2.00 Oct. 21, 2009 Page 650 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Port
P2
1
0
P3
7
6
5
Output
Specification
Signal Name
Output
Signal
Name
TIOCA3_OE
TIOCA3
TPU.TIORH_3.IOA3 = 0,
TPU.TIORH_3.IOA[1,0] = 01/10/11
PO1_OE
PO1
NDERL.NDER1 = 1
TIOCB3_OE
TIOCB3
TPU.TIORH_3.IOB3 = 0,
TPU.TIORH_3.IOB[1,0] = 01/10/11
SCK0_OE
SCK0
When SCMR.SMIF = 1:
SCR.TE = 1 or SCR.RE = 1 while
SMR.GM = 0, SCR.CKE [1, 0] = 01 or while
SMR.GM = 1
When SCMR.SMIF = 0:
SCR.TE = 1 or SCR.RE = 1 while
SMR.C/A = 0, SCR.CKE [1, 0] = 01 or while
SMR.C/A = 1, SCR.CKE 1 = 0
PO0_OE
PO0
NDERL.NDER0 = 1
EDRAK3_OE
EDRAK3
TIOCB2_OE
TIOCB2
TPU.TIOR_2.IOB3 = 0,
TPU.TIOR_2.IOB[1,0] = 01/10/11
PO15_OE
PO15
NDERH.NDER15 = 1
EDRAK2_OE
EDRAK2
TIOCA2_OE
TIOCA2
TPU.TIOR_2.IOA3 = 0,
TPU.TIOR_2.IOA[1,0] = 01/10/11
PO14_OE
PO14
NDERH.NDER14 = 1
EDACK3_OE
EDACK3
PFCR8.EDMAS3[A,B]
= 00
DACK1B_OE
DACK1
PFCR7.DMAS1[A,B] = DMAC.DACR.AMS = 1,
01
DMDR_1.DACKE = 1
TIOCB1_OE
TIOCB1
TPU.TIOR_1.IOB3 = 0,
TPU.TIOR_1.IOB[1,0] = 01/10/11
PO13_OE
PO13
NDERH.NDER13 = 1
Signal Selection
Register Settings
PFCR8.EDMAS3[A,B]
= 00
PFCR8.EDMAS2[A,B]
= 00
Peripheral Module Settings
SYSCR.EXPE = 1, EDMDR_3.EDRAKE = 1
SYSCR.EXPE = 1, EDMDR_2.EDRAKE = 1
SYSCR.EXPE = 1, EDACR_3.AMS = 1,
EDMDR_3.EDACKE = 1
Rev. 2.00 Oct. 21, 2009 Page 651 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Port
P3
4
3
2
1
0
P6
5
Output
Specification
Signal Name
Output
Signal
Name
ETEND3_OE
ETEND3
PFCR8.EDMAS3[A,B]
= 00
TEND1B_OE
TEND1
PFCR7.DMAS1[A,B] = DMDR_1.TENDE = 1
01
TIOCA1_OE
TIOCA1
TPU.TIOR_1.IOA3 = 0,
TPU.TIOR_1.IOA[1,0] = 01/10/11
PO12_OE
PO12
NDERH.NDER12 = 1
TIOCD0_OE
TIOCD0
TPU.TMDR.BFB = 0,
TPU.TIORL_0.IOD3 = 0,
TPU.TIORL_0.IOD[1,0] = 01/10/11
PO11_OE
PO11
NDERH.NDER11 = 1
EDACK2_OE
EDACK2
PFCR8.EDMAS2[A,B]
= 00
DACK0B_OE
DACK0
PFCR7.DMAS0[A,B] = DMAC.DACR.AMS = 1,
01
DMDR_0.DACKE = 1
TIOCC0_OE
TIOCC0
TPU.TMDR.BFA = 0,
TPU.TIORL_0.IOC3 = 0,
TPU.TIORL_0.IOD[1,0] = 01/10/11
PO10_OE
PO10
NDERH.NDER10 = 1
ETEND2_OE
ETEND2
PFCR8.EDMAS2[A,B]
= 00
TEND0B_OE
TEND0
PFCR7.DMAS0[A,B] = DMDR_0.TENDE = 1
01
TIOCB0_OE
TIOCB0
TPU.TIORH_0.IOB3 = 0,
TPU.TIORH_0.IOB[1,0] = 01/10/11
PO9_OE
PO9
NDERH.NDER9 = 1
TIOCA0_OE
TIOCA0
TPU.TIORH_0.IOA3 = 0,
TPU.TIORH_0.IOA[1,0] = 01/10/11
PO8_OE
PO8
NDERH.NDER8 = 1
Signal Selection
Register Settings
Peripheral Module Settings
SYSCR.EXPE = 1, EDMDR_3.ETENDE = 1
SYSCR.EXPE = 1, EDACR_2.AMS = 1,
EDMDR_2.EDACKE = 1
SYSCR.EXPE = 1, EDMDR_2.ETENDE = 1
EDACK1B_OE EDACK1
PFCR8.EDMAS1[A,B]
= 01
DACK3_OE
DACK3
PFCR7.DMAS3[A,B] = DMAC.DACR_3.AMS = 1,
01
DMDR_3.DACKE = 1
TMO3_OE
TMO3
Rev. 2.00 Oct. 21, 2009 Page 652 of 1454
REJ09B0498-0200
SYSCR.EXPE = 1, EDACR_1.AMS = 1,
EDMDR_1.EDACKE = 1
TMR.TCSR_3.OS[3,2] = 01/10/11 or
TMR.TCSR_3.OS[1,0] = 01/10/11
Section 13 I/O Ports
Output
Specification
Signal Name
Port
P6
4
2
Signal Selection
Register Settings
Peripheral Module Settings
ETEND1B_OE ETEND1
PFCR8.EDMAS1[A,B]
= 01
TEND3_OE
PFCR7.DMAS3[A,B] = DMDR_3.TENDE = 1
01
TEND3
SYSCR.EXPE = 1, EDMDR_1.ETENDE = 1
EDACK0B_OE EDACK0
PFCR8.EDMAS0[A,B]
= 01
DACK2_OE
DACK2
PFCR7.DMAS2[A,B] = DMAC.DACR_2.AMS = 1, DMDR_2.DACKE
01
=1
TMO2_OE
TMO2
TMR.TCSR_2.OS[3,2] = 01/10/11 or
TMR.TCSR_2.OS[1,0] = 01/10/11
SCK4_OE
SCK4
When SCMR.SMIF = 1:
SCR.TE = 1 or SCR.RE = 1 while
SMR.GM = 0, SCR.CKE [1, 0] = 01 or while
SMR.GM = 1
When SCMR.SMIF = 0:
SCR.TE = 1 or SCR.RE = 1 while
SMR.C/A = 0, SCR.CKE [1, 0] = 01 or while
SMR.C/A = 1, SCR.CKE 1 = 0
SYSCR.EXPE = 1, EDACR_0.AMS = 1,
EDMDR_0.EDACKE = 1
ETEND0B_OE ETEND0
PFCR8.EDMAS0[A,B]
= 01
TEND2_OE
TEND2
PFCR7.DMAS2[A,B] = DMDR_2.TENDE = 1
01
0
TxD4_OE
TxD4
SCR.TE = 1
7
Bφ_OE
Bφ
PADDR.PA7DDR = 1, SCKCR.PSTOP1 = 0
6
AH_OE
AH
SYSCR.EXPE = 1,
MPXCR.MPXEn (n = 7 to 3) = 1
BSB_OE
BS
1
PA
Output
Signal
Name
PFCR2.BSS = 1
SYSCR.EXPE = 1, EDMDR_0.ETENDE = 1
SYSCR.EXPE = 1, PFCR2.BSE = 1
AS_OE
AS
SYSCR.EXPE = 1, PFCR2.ASOE = 1
5
RD_OE
RD
SYSCR.EXPE = 1
4
LUB_OE
LUB
SYSCR.EXPE = 1, PFCR6.LHWROE = 1 or
SRAMCR.BCSELn = 1
LHWR_OE
LHWR
SYSCR.EXPE = 1, PFCR6.LHWROE = 1
LLB_OE
LLB
SYSCR.EXPE = 1, SRAMCR.BCSELn = 1
LLWR_OE
LLWR
SYSCR.EXPE = 1
3
Rev. 2.00 Oct. 21, 2009 Page 653 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Output
Specification
Signal Name
Output
Signal
Name
BACK_OE
BACK
(RD/WRA)_OE
RD/WR
PFCR2.RDWRS = 0
SYSCR.EXPE = 1, PFCR2.RDWRE = 1 or
SRAMCR.BCSELn = 1
BSA_OE
BS
PFCR2.BSS = 0
SYSCR.EXPE = 1, PFCR2.BSE = 1
BREQO_OE
BREQO
SYSCR.EXPE = 1, BCR1.BRLE = 1,
BCR1.BREQOE = 1
7
SDRAMφ_OE
SDRAMφ
MDCR.MDS7 = 1
6
(RD/WR)-B_OE
RD/WR
PFCR2.RDWRS = 1
SYSCR.EXPE=1, PFCR2.RDWRE = 1 or
ASRAMCR.BCSELn = 1
CS6D_OE
CS6
PFCR1.CS6S[A,B] =
11
SYSCR.EXPE = 1, PFCR0.CS6E = 1
CKE_OE
CKE
SYSCR.EXPE = 1, DRAMCR.DRAME = 1,
DRAMCR.DTYPE = 1, DRAMCR.OEE = 1
OE_OE
OE
SYSCR.EXPE = 1, DRAMCR.DRAME = 1,
DRAMCR.DTYPE = 0, DRAMCR.OEE = 1
CS5D_OE
CS5
WE_OE
WE
CS4B_OE
CS4
CAS_OE
CAS
SYSCR.EXPE = 1, DRAMCR.DRAME = 1,
DRAMCR.DTYPE = 1
CS3_OE
CS3
SYSCR.EXPE = 1, PFCR0.CS3E = 1
CS7A_OE
CS7
RAS_OE
RAS
CS2A_OE
CS2
PFCR2.CS2S = 0
SYSCR.EXPE = 1, PFCR0.CS2E = 1
CS6A_OE
CS6
PFCR1.CS6S[A,B] =
00
SYSCR.EXPE = 1, PFCR0.CS6E = 1
Port
PA
1
0
PB
5
4
3
2
Signal Selection
Register Settings
SYSCR.EXPE = 1,BCR1.BRLE = 1
PFCR1.CS5S[A,B] =
11
SYSCR.EXPE = 1, PFCR0.CS5E = 1
SYSCR.EXPE = 1, DRAMCR.DRAME = 1
PFCR1.CS4S[A,B] =
01
PFCR1.CS7S[A,B] =
00
SYSCR.EXPE = 1, PFCR0.CS4E = 1
SYSCR.EXPE = 1, PFCR0.CS7E = 1
SYSCR.EXPE = 1, DRAMCR.DRAME = 1
Rev. 2.00 Oct. 21, 2009 Page 654 of 1454
REJ09B0498-0200
Peripheral Module Settings
Section 13 I/O Ports
Output
Specification
Signal Name
Output
Signal
Name
CS1_OE
CS1
CS2B_OE
CS2
PFCR2.CS2S = 1
SYSCR.EXPE = 1, PFCR0.CS2E = 1
CS5A_OE
CS5
PFCR1.CS5S[A,B] =
00
SYSCR.EXPE = 1, PFCR0.CS5E = 1
CS6B_OE
CS6
PFCR1.CS6S[A,B] =
01
SYSCR.EXPE = 1, PFCR0.CS6E = 1
CS7B_OE
CS7
PFCR1.CS7S[A,B] =
01
SYSCR.EXPE = 1, PFCR0.CS7E = 1
CS0_OE
CS0
CS4A_OE
CS4
PFCR1.CS4S[A,B] =
00
SYSCR.EXPE = 1, PFCR0.CS4E = 1
CS5B_OE
CS5
PFCR1.CS5S[A,B] =
01
SYSCR.EXPE = 1, PFCR0.CS5E = 1
LLCAS_OE
LLCAS
SYSCR.EXPE = 1, DRAMCR.DRAME = 1,
DRAMCR.DTYPE = 0
DQMLL_OE
DQMLL
SYSCR.EXPE = 1, DRAMCR.DRAME = 1,
DRAMCR.DTYPE = 1
LUCAS_OE
LUCAS
SYSCR.EXPE = 1,
ABWCR.[ABWH2,ABWL2] = x0/01,
DRAMCR.DRAME = 1,
DRAMCR.DTYPE = 0
DQMLU_OE
DQMLU
SYSCR.EXPE = 1,
ABWCR.[ABWH2,ABWL2] = x0/01,
DRAMCR.DRAME = 1,
DRAMCR.DTYPE = 1
7
A7_OE
A7
SYSCR.EXPE = 1, PDDDR.PD7DDR = 1
6
A6_OE
A6
SYSCR.EXPE = 1, PDDDR.PD6DDR = 1
5
A5_OE
A5
SYSCR.EXPE = 1, PDDDR.PD5DDR = 1
4
A4_OE
A4
SYSCR.EXPE = 1, PDDDR.PD4DDR = 1
3
A3_OE
A3
SYSCR.EXPE = 1, PDDDR.PD3DDR = 1
2
A2_OE
A2
SYSCR.EXPE = 1, PDDDR.PD2DDR = 1
1
A1_OE
A1
SYSCR.EXPE = 1, PDDDR.PD1DDR = 1
0
A0_OE
A0
SYSCR.EXPE = 1, PDDDR.PD0DDR = 1
Port
PB
1
0
PC
3
2
PD
Signal Selection
Register Settings
Peripheral Module Settings
SYSCR.EXPE = 1, PFCR0.CS1E = 1
SYSCR.EXPE = 1, PFCR0.CS0E = 1
Rev. 2.00 Oct. 21, 2009 Page 655 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Output
Specification
Signal Name
Output
Signal
Name
7
A15_OE
A15
SYSCR.EXPE = 1, PEDDR.PE7DDR = 1
6
A14_OE
A14
SYSCR.EXPE = 1, PEDDR.PE6DDR = 1
5
A13_OE
A13
SYSCR.EXPE = 1, PEDDR.PE5DDR = 1
4
A12_OE
A12
SYSCR.EXPE = 1, PEDDR.PE4DDR = 1
3
A11_OE
A11
SYSCR.EXPE = 1, PEDDR.PE3DDR = 1
2
A10_OE
A10
SYSCR.EXPE = 1, PEDDR.PE2DDR = 1
1
A9_OE
A9
SYSCR.EXPE = 1, PEDDR.PE1DDR = 1
0
A8_OE
A8
SYSCR.EXPE = 1, PEDDR.PE0DDR = 1
7
A23_OE
A23
SYSCR.EXPE = 1, PFCR4.A23E = 1
6
A22_OE
A22
SYSCR.EXPE = 1, PFCR4.A22E = 1
5
A21_OE
A21
SYSCR.EXPE = 1, PFCR4.A21E = 1
4
A20_OE
A20
SYSCR.EXPE = 1, PFCR4.A20E = 1
3
A19_OE
A19
SYSCR.EXPE = 1, PFCR4.A19E = 1
2
A18_OE
A18
SYSCR.EXPE = 1, PFCR4.A18E = 1
1
A17_OE
A17
SYSCR.EXPE = 1, PFCR4.A17E = 1
Port
PE
PF
PH
PI
Signal Selection
Register Settings
Peripheral Module Settings
0
A16_OE
A16
SYSCR.EXPE = 1, PFCR4.A16E = 1
7
D7_E
D7
SYSCR.EXPE = 1
6
D6_E
D6
SYSCR.EXPE = 1
5
D5_E
D5
SYSCR.EXPE = 1
4
D4_E
D4
SYSCR.EXPE = 1
3
D3_E
D3
SYSCR.EXPE = 1
2
D2_E
D2
SYSCR.EXPE = 1
1
D1_E
D1
SYSCR.EXPE = 1
0
D0_E
D0
SYSCR.EXPE = 1
7
D15_E
D15
SYSCR.EXPE = 1, ABWCR.ABW[H,L]n = 01
6
D14_E
D14
SYSCR.EXPE = 1, ABWCR.ABW[H,L]n = 01
5
D13_E
D13
SYSCR.EXPE = 1, ABWCR.ABW[H,L]n = 01
4
D12_E
D12
SYSCR.EXPE = 1, ABWCR.ABW[H,L]n = 01
3
D11_E
D11
SYSCR.EXPE = 1, ABWCR.ABW[H,L]n = 01
2
D10_E
D10
SYSCR.EXPE = 1, ABWCR.ABW[H,L]n = 01
1
D9_E
D9
SYSCR.EXPE = 1, ABWCR.ABW[H,L]n = 01
0
D8_E
D8
SYSCR.EXPE = 1, ABWCR.ABW[H,L]n = 01
Rev. 2.00 Oct. 21, 2009 Page 656 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Port
PJ
7
6
5
4
3
Output
Specification
Signal Name
Output
Signal
Name
TIOCB8_OE
TIOCB8
TPU.TIOR_8.IOB3 = 0,
TPU.TIOR_8.IOB[1,0] = 01/10/11
PO 23_OE
PO23
NDERL_1.NDER23 = 1
TIOCA8_OE
TIOCA8
TPU.TIOR_8.IOA3 = 0,
TPU.TIOR_8.IOA[1,0] = 01/10/11
PO 22_OE
PO22
NDERL_1.NDER22 = 1
TIOCB7_OE
TIOCB7
TPU.TIOR_7.IOB3 = 0,
TPU.TIOR_7.IOB[1,0] = 01/10/11
PO 21_OE
PO21
NDERL_1.NDER21 = 1
TIOCA7_OE
TIOCA7
TPU.TIOR_7.IOA3 = 0,
TPU.TIOR_7.IOA[1,0] = 01/10/11
PO 20_OE
PO20
NDERL_1.NDER20 = 1
TIOCD6_OE
TIOCD6
TPU.TMDR_6.BFB = 0,
TPU.TIORL_6.IOD3 = 0
Signal Selection
Register Settings
Peripheral Module Settings
TPU.TIORL_6.IOD[1,0] = 01/10/11
2
PO 19_OE
PO19
NDERL_1.NDER19 = 1
TIOCC6_OE
TIOCC6
TPU.TMDR_6.BFA = 0,
TPU.TIORL_6.IOC3 = 0
PO 18_OE
PO18
NDERL_1.NDER18 = 1
TIOCB6_OE
TIOCB6
TPU.TIORH_6.IOB3 = 0,
TPU.TIORH_6.IOB[1,0] = 01/10/11
PO 17_OE
PO17
NDERL_1.NDER17 = 1
TIOCA6_OE
TIOCA6
TPU.TIORH_6.IOA3 = 0,
TPU.TIORH_6.IOA[1,0] = 01/10/11
PO 16_OE
PO16
NDERL_1.NDER16 = 1
TPU.TIORL_6.IOC[1,0] = 01/10/11
1
0
Rev. 2.00 Oct. 21, 2009 Page 657 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Output
Output
Specification Signal
Signal Name Name
Port
PK
7
6
5
4
3
Signal Selection
Register Settings
Peripheral Module Settings
TIOCB11_OE
TIOCB11
TPU.TIOR_11.IOB3 = 0,
TPU.TIOR_11.IOB[1,0] = 01/10/11
PO31_OE
PO31
NDERH_1.NDER31 = 1
TIOCA11_OE
TIOCA11
TPU.TIOR_11.IOA3 = 0,
TPU.TIOR_11.IOA[1,0] = 01/10/11
PO30_OE
PO30
NDERH_1.NDER30 = 1
TIOCB10_OE
TIOCB10
TPU.TIOR_10.IOB3 = 0,
TPU.TIOR_10.IOB[1,0] = 01/10/11
PO29_OE
PO29
NDERH_1.NDER29 = 1
TIOCA10_OE
TIOCA10
TPU.TIOR_10.IOA3 = 0,
TPU.TIOR_10.IOA[1,0] = 01/10/11
PO28_OE
PO28
NDERH_1.NDER28 = 1
TIOCD9_OE
TIOCD9
TPU.TMDR_9.BFB = 0,
TPU.TIORL_9.IOD3 = 0
TPU.TIORL_9.IOD[1,0] = 01/10/11
PO27_OE
PO27
NDERH_1.NDER27 = 1
TIOCC9_OE
TIOCC9
TPU.TMDR_9.BFA = 0,
TPU.TIORL_9.IOC3 = 0
PO26_OE
PO26
NDERH_1.NDER26 = 1
TIOCB9_OE
TIOCB9
TPU.TIORH_9.IOB3 = 0,
TPU.TIORH_9.IOB[1,0] = 01/10/11
PO25_OE
PO25
NDERH_1.NDER25 = 1
TIOCA9_OE
TIOCA9
TPU.TIORH_9.IOA3 = 0,
TPU.TIORH_9.IOA[1,0] = 01/10/11
PO24_OE
PO24
NDERH_1.NDER24 = 1
4
—
—
—
—
3
—
—
—
—
2
—
—
—
—
1
—
—
—
—
0
TxD6_OE
TxD6
2
TPU.TIORL_9.IOC[1,0] = 01/10/11
1
0
PM
Rev. 2.00 Oct. 21, 2009 Page 658 of 1454
REJ09B0498-0200
SCR.TE = 1
Section 13 I/O Ports
13.3
Port Function Controller
The port function controller controls the I/O ports.
The port function controller incorporates the following registers.
•
•
•
•
•
•
•
•
•
•
•
•
Port function control register 0 (PFCR0)
Port function control register 1 (PFCR1)
Port function control register 2 (PFCR2)
Port function control register 4 (PFCR4)
Port function control register 6 (PFCR6)
Port function control register 7 (PFCR7)
Port function control register 8 (PFCR8)
Port function control register 9 (PFCR9)
Port function control register A (PFCRA)
Port function control register B (PFCRB)
Port function control register C (PFCRC)
Port function control register D (PFCRD)
13.3.1
Port Function Control Register 0 (PFCR0)
PFCR0 enables/disables the CS output.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
CS7E
CS6E
CS5E
CS4E
CS3E
CS2E
CS1E
CS0E
0
0
0
0
0
0
0
Undefined*
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Note: * 1 in external extended mode; 0 in other modes.
Rev. 2.00 Oct. 21, 2009 Page 659 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Bit
Bit Name
Initial
Value
R/W
Description
7
CS7E
0
R/W
6
5
4
3
2
1
0
CS6E
CS5E
CS4E
CS3E
CS2E
CS1E
CS0E
0
0
0
0
0
0
Undefined*
R/W
R/W
R/W
R/W
R/W
R/W
R/W
CS7 to CS0 Enable
These bits enable/disable the corresponding CSn
output.
0: Pin functions as I/O port
1: Pin functions as CSn output pin
(n = 7 to 0)
Note:
1 in external extended mode, 0 in other modes.
*
13.3.2
Port Function Control Register 1 (PFCR1)
PFCR1 selects the CS output pins.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
CS7SA
CS7SB
CS6SA
CS6SB
CS5SA
CS5SB
CS4SA
CS4SB
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
CS7SA*
0
R/W
CS7 Output Pin Select
6
CS7SB*
0
R/W
Selects the output pin for CS7 when CS7 output is
enabled (CS7E = 1)
00: Specifies pin PB3 as CS7-A output
01: Specifies pin PB1 as CS7-B output
10: Setting prohibited
11: Setting prohibited
5
CS6SA*
0
R/W
CS6 Output Pin Select
4
CS6SB*
0
R/W
Selects the output pin for CS6 when CS6 output is
enabled (CS6E = 1)
00: Specifies pin PB2 as CS6-A output
01: Specifies pin PB1 as CS6-B output
10: Setting prohibited
11: Specifies pin PB6 as CS6-D output
Rev. 2.00 Oct. 21, 2009 Page 660 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Bit
Bit Name
Initial
Value
R/W
Description
3
CS5SA*
0
R/W
CS5 Output Pin Select
2
CS5SB*
0
R/W
Selects the output pin for CS5 when CS5 output is
enabled (CS5E = 1)
00: Specifies pin PB1 as CS5-A output
01: Specifies pin PB0 as CS5-B output
10: Setting prohibited
11: Specifies pin PB5 as CS5-D output
1
CS4SA*
0
R/W
CS4 Output Pin Select
0
CS4SB*
0
R/W
Selects the output pin for CS4 when CS4 output is
enabled (CS4E = 1)
00: Specifies pin PB0 as CS4-A output
01: Specifies pin PB4 as CS4-B output
10: Setting prohibited
11: Setting prohibited
Note:
If multiple CS outputs are specified to a single pin according to the CSn output pin
select bits (n = 4 to 7), multiple CS signals are output from the pin. For details, see
section 9.5.3, Chip Select Signals.
*
13.3.3
Port Function Control Register 2 (PFCR2)
PFCR2 selects the CS output pin, enables/disables bus control I/O, and selects the bus control I/O
pins.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
CS2S
BSS
BSE
RDWRS
RDWRE
ASOE
⎯
Initial Value
0
0
0
0
0
0
1
0
R/W
R
R/W
R/W
R/W
R/W
R/W
R/W
R
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
This bit is always read as 0. The write value should
always be 0.
Rev. 2.00 Oct. 21, 2009 Page 661 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Bit
6
Bit Name
CS2S*
1
Initial
Value
R/W
Description
0
R/W
CS2 Output Pin Select
Selects the output pin for CS2 when CS2 output is
enabled (CS2E = 1)
0: Specifies pin PB2 as CS2-A output pin
1: Specifies pin PB1 as CS2-B output pin
5
BSS
0
R/W
BS Output Pin Select
Selects the BS output pin
0: Specifies pin PA0 as BS-A output pin
1: Specifies pin PA6 as BS-B output pin
4
BSE
0
R/W
BS Output Enable
Enables/disables the BS output
0: Disables the BS output
1: Enables the BS output
3
RDWRS*2
0
R/W
RD/WR Output Pin Select
Selects the output pin for RD/WR
0: Specifies pin PA1 as RD/WR-A output pin
1: Specifies pin PB6 as RD/WR-B output pin
2
2
RDWRE*
0
R/W
RD/WR Output Enable
Enables/disables the RD/WR output
0: Disables the RD/WR output
1: Enables the RD/WR output
1
ASOE
1
R/W
AS Output Enable
Enables/disables the AS output
0: Specifies pin PA6 as I/O port
1: Specifies pin PA6 as AS output pin
0
⎯
0
R
Reserved
This bit is always read as 0. The write value should
always be 0.
Notes: 1. If multiple CS outputs are specified to a single pin according to the CSn output pin
select bit (n = 2), multiple CS signals are output from the pin. For details, see section
9.5.3, Chip Select Signals.
2. If an area is specified as a byte control SDRAM space, the pin functions as RD/WR
output regardless of the RDWRE bit value.
Rev. 2.00 Oct. 21, 2009 Page 662 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.3.4
Port Function Control Register 4 (PFCR4)
PFCR4 enables/disables the address output.
Bit
Bit Name
7
6
5
4
3
2
1
0
A23E
A22E
A21E
A20E
A19E
A18E
A17E
A16E
Initial Value
R/W
0
0
0
0/1*
0/1*
0/1*
0/1*
0/1*
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
A23E
0
R/W
Address A23 Enable
Enables/disables the address output (A23)
0: Disables the A23 output
1: Enables the A23 output
6
A22E
0
R/W
Address A22 Enable
Enables/disables the address output (A22)
0: Disables the A22 output
1: Enables the A22 output
5
A21E
0
R/W
Address A21 Enable
Enables/disables the address output (A21)
0: Disables the A21 output
1: Enables the A21 output
4
A20E
0/1*
R/W
Address A20 Enable
Enables/disables the address output (A20)
0: Disables the A20 output
1: Enables the A20 output
3
A19E
0/1*
R/W
Address A19 Enable
Enables/disables the address output (A19)
0: Disables the A19 output
1: Enables the A19 output
Rev. 2.00 Oct. 21, 2009 Page 663 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Bit
Bit Name
Initial
Value
R/W
Description
2
A18E
0/1*
R/W
Address A18 Enable
Enables/disables the address output (A18)
0: Disables the A18 output
1: Enables the A18 output
1
A17E
0/1*
R/W
Address A17 Enable
Enables/disables the address output (A17)
0: Disables the A17 output
1: Enables the A17 output
0
A16E
0/1*
R/W
Address A16 Enable
Enables/disables the address output (A16)
0: Disables the A16 output
1: Enables the A16 output
Note:
*
The initial value changes depending on the operating mode. 1 in on-chip ROM disabled
mode and 0 in on-chip ROM enabled mode.
Rev. 2.00 Oct. 21, 2009 Page 664 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.3.5
Port Function Control Register 6 (PFCR6)
PFCR6 selects the TPU clock input pin.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
LHWROE
⎯
⎯
TCLKS
⎯
⎯
ADTRG0S
Initial Value
R/W
1
1
1
0
0
0
0
0
R/W
R/W
R/W
R
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
1
R/W
Reserved
This bit is always read as 1. The write value should
always be 1.
6
LHWROE
1
R/W
LHWR Output Enable
Enables/disables LHWR output (valid in external
extended mode).
0: Specifies pin PA4 as I/O port
1: Specifies pin PA4 as LHWR output pin
5
⎯
1
R/W
Reserved
This bit is always read as 1. The write value should
always be 1.
4
⎯
0
R
Reserved
3
TCLKS
0
R/W
TPU External Clock Input Pin Select
This is a read-only bit and cannot be modified.
Selects the TPU external clock input pins.
0: Specifies pins P32, P33, P35, and P37 as external
clock input pins.
1: Specifies pins P14 to P17 as external clock input
pins.
2, 1
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
0
ADTRG0S 0
R/W
ADTRG0S Input Pin Select
Selects the external trigger input pins of A/D converter.
0: Specifies pin P13 as ADTRG0-A input pin.
1: Specifies pin PB6 as ADTRG0-B input pin.
Rev. 2.00 Oct. 21, 2009 Page 665 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.3.6
Port Function Control Register 7 (PFCR7)
PFCR7 selects the DMAC I/O pins (DREQ, DACK, and TEND).
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
DMAS3A
DMAS3B
DMAS2A
DMAS2B
DMAS1A
DMAS1B
DMAS0A
DMAS0B
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
DMAS3A
0
R/W
DMAC control pin select
6
DMAS3B
0
R/W
Selects the I/O port to control DMAC_3.
00: DMAC_3 control pins are disabled.
01: Specifies pins P63 to P65 as DMAC control pins
10: Setting prohibited
11: Setting prohibited
5
DMAS2A
0
R/W
DMAC control pin select
4
DMAS2B
0
R/W
Selects the I/O port to control DMAC_2.
00: DMAC_2 control pins are disabled.
01: Specifies pins P60 to P62 as DMAC control pins
10: Setting prohibited
11: Setting prohibited
3
DMAS1A
0
R/W
DMAC control pin select
2
DMAS1B
0
R/W
Selects the I/O port to control DMAC_1.
00: Specifies pins P14 to P16 as DMAC control pins
01: Specifies pins P33 to P35 as DMAC control pins
10: Setting prohibited
11: Setting prohibited
1
DMAS0A
0
R/W
DMAC control pin select
0
DMAS0B
0
R/W
Selects the I/O port to control DMAC_0.
00: Specifies pins P10 to P12 as DMAC control pins
01: Specifies pins P30 to P32 as DMAC control pins
10: Setting prohibited
11: Setting prohibited
Rev. 2.00 Oct. 21, 2009 Page 666 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.3.7
Port Function Control Register 8 (PFCR8)
PFCR8 selects the EXDMAC I/O pins (EDREQ, EDACK, ETEND and EDRAK).
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
EDMAS3A
EDMAS3B
EDMAS2A
EDMAS2B
EDMAS1A
EDMAS1B
EDMAS0A
EDMAS0B
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
7
6
Initial
Value
R/W
Description
EDMAS3A 0
R/W
EXDMAC Control Pin Select
EDMAS3B 0
R/W
Select the I/O port to control EXDMAC_3.
00: Specify pins P33 to P35 and P37 as EXDMAC control
pin
01: Setting prohibited
10: Setting prohibited
11: Setting prohibited
5
EDMAS2A 0
R/W
EXDMAC Control Pin Select
4
EDMAS2B 0
R/W
Select the I/O port to control EXDMAC_2.
00: Specify pins P30 to P32 and P36as EXDMAC control
pin
01: Setting prohibited
10: Setting prohibited
11: Setting prohibited
3
EDMAS1A 0
R/W
EXDMAC Control Pin Select
2
EDMAS1B 0
R/W
Select the I/O port to control EXDMAC_1.
00: Specify pins P14 to P17 as EXDMAC control pin
01: Specify pins P63 to P65 as EXDMAC control pin
10: Setting prohibited
11: Setting prohibited
Rev. 2.00 Oct. 21, 2009 Page 667 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Bit
Bit Name
1
0
Initial
Value
R/W
Description
EDMAS0A 0
R/W
EXDMAC Control Pin Select
EDMAS0B 0
R/W
Select the I/O port to control EXDMAC_0.
00: Specify pins P10 to P13 as EXDMAC control pin
01: Specify pins P60 to P62 as EXDMAC control pin
10: Setting prohibited
11: Setting prohibited
13.3.8
Port Function Control Register 9 (PFCR9)
PFCR9 selects the multiple functions for the TPU I/O pins.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
TPUMS5
TPUMS4
TPUMS3A
TPUMS3B
TPUMS2
TPUMS1
TPUMS0A
TPUMS0B
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
TPUMS5
0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA5 function
0: Specifies pin P26 as output compare output and input
capture
1: Specifies P27 as input capture input and P26 as
output compare
6
TPUMS4
0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA4 function
0: Specifies P25 as output compare output and input
capture
1: Specifies P24 as input capture input and P25 as
output compare
Rev. 2.00 Oct. 21, 2009 Page 668 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Initial
Value
Bit
Bit Name
5
TPUMS3A 0
R/W
Description
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA3 function
0: Specifies P21 as output compare output and input
capture
1: Specifies P20 as input capture input and P21 as
output compare
4
TPUMS3B 0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCC3 function
0: Specifies P22 as output compare output and input
capture
1: Specifies P23 as input capture input and P22 as
output compare
3
TPUMS2
0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA2 function
0: Specifies P36 as output compare output and input
capture
1: Specifies P37 as input capture input and P36 as
output compare
2
TPUMS1
0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA1 function
0: Specifies P34 as output compare output and input
capture
1: Specifies P35 as input capture input and P34 as
output compare
1
TPUMS0A 0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA0 function
0: Specifies P30 as output compare output and input
capture
1: Specifies P31 as input capture input and P30 as
output compare
0
TPUMS0B 0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCC0 function
0: Specifies P32 as output compare output and input
capture
1: Specifies P33 as input capture input and P32 as
output compare
Rev. 2.00 Oct. 21, 2009 Page 669 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.3.9
Port Function Control Register A (PFCRA)
PFCRA selects the multiple functions for the TPU I/O pins.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
TPUMS11
TPUMS10
TPUMS9A
TPUMS9B
TPUMS8
TPUMS7
TPUMS6A
TPUM6B
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Initial
Value
Bit
Bit Name
7
TPUMS11 0
R/W
R/W
Description
TPU I/O Pin Multiplex Function Select
Selects TIOCA11 function.
0: Specifies pin PK6 as output compare output and input
capture
1: Specifies PK7 as input capture input and PK6 as
output compare
6
TPUMS10 0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA10 function.
0: Specifies PK4 as output compare output and input
capture
1: Specifies PK5 as input capture input and PK4 as
output compare
5
TPUMS9A 0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA9 function.
0: Specifies PK0 as output compare output and input
capture
1: Specifies PK1 as input capture input and PK0 as
output compare
4
TPUMS9B 0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCC9 function.
0: Specifies PK2 as output compare output and input
capture
1: Specifies PK3 as input capture input and PK2 as
output compare
Rev. 2.00 Oct. 21, 2009 Page 670 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Bit
Bit Name
Initial
Value
R/W
Description
3
TPUMS8
0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA8 function.
0: Specifies PJ6 as output compare output and input
capture
1: Specifies PJ7 as input capture input and PJ6 as output
compare
2
TPUMS7
0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA7 function.
0: Specifies PJ4 as output compare output and input
capture
1: Specifies PJ5 as input capture input and PJ4 as output
compare
1
TPUMS6A 0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCA6 function.
0: Specifies PJ0 as output compare output and input
capture
1: Specifies PJ1 as input capture input and PJ0 as output
compare
0
TPUMS6B 0
R/W
TPU I/O Pin Multiplex Function Select
Selects TIOCC6 function.
0: Specifies PJ2 as output compare output and input
capture
1: Specifies PJ3 as input capture input and PJ2 as output
compare
Rev. 2.00 Oct. 21, 2009 Page 671 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.3.10 Port Function Control Register B (PFCRB)
PFCRB selects the LVD interrupt*, and the input pins for IRQ11 to IRQ8.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
ITS14*
⎯
⎯
ITS11
ITS10
ITS9
ITS8
Initial Value
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Note:
* Supported only by the H8SX/1665M Group.
• H8SX/1665 Group
Bit
Bit Name
Initial
Value
R/W
Description
7 to 4
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
• H8SX/1665M Group
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R/W
Reserved
This bit is always read as 0. The write value should
always be 0.
6
ITS14
0
R/W
LVD Interrupt Select
This bit allows or prohibits LVD interrupt.
0: Prohibits LVD interrupt
1: Allows LVD interrupt
5, 4
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
3
ITS11
0
R/W
IRQ11 Pin Select
Selects an input pin for IRQ11.
0: Selects pin P23 as IRQ11-A input
1: Selects pin P63 as IRQ11-B input
Rev. 2.00 Oct. 21, 2009 Page 672 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Bit
Bit Name
Initial
Value
R/W
Description
2
ITS10
0
R/W
IRQ10 Pin Select
Selects an input pin for IRQ10.
0: Selects pin P22 as IRQ10-A input
1: Selects pin P62 as IRQ10-B input
1
ITS9
0
R/W
IRQ9 Pin Select
Selects an input pin for IRQ9.
0: Selects pin P21 as IRQ9-A input
1: Selects pin P61 as IRQ9-B input
0
ITS8
0
R/W
IRQ8 Pin Select
Selects an input pin for IRQ8.
0: Selects pin P20 as IRQ8-A input
1: Selects pin P60 as IRQ8-B input
Rev. 2.00 Oct. 21, 2009 Page 673 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.3.11 Port Function Control Register C (PFCRC)
PFCRC selects input pins for IRQ7 to IRQ0.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
ITS7
ITS6
ITS5
ITS4
ITS3
ITS2
ITS1
ITS0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
ITS7
0
R/W
IRQ7 Pin Select
Selects an input pin for IRQ7.
0: Selects pin P17 as IRQ7-A input
1: Selects pin P57 as IRQ7-B input
6
ITS6
0
R/W
IRQ6 Pin Select
Selects an input pin for IRQ6.
0: Selects pin P16 as IRQ6-A input
1: Selects pin P56 as IRQ6-B input
5
ITS5
0
R/W
IRQ5 Pin Select
Selects an input pin for IRQ5.
0: Selects pin P15 as IRQ5-A input
1: Selects pin P55 as IRQ5-B input
4
ITS4
0
R/W
IRQ4 Pin Select
Selects an input pin for IRQ4.
0: Selects pin P14 as IRQ4-A input
1: Selects pin P54 as IRQ4-B input
3
ITS3
0
R/W
IRQ3 Pin Select
Selects an input pin for IRQ3.
0: Selects pin P13 as IRQ3-A input
1: Selects pin P53 as IRQ3-B input
Rev. 2.00 Oct. 21, 2009 Page 674 of 1454
REJ09B0498-0200
Section 13 I/O Ports
Bit
Bit Name
Initial
Value
R/W
Description
2
ITS2
0
R/W
IRQ2 Pin Select
Selects an input pin for IRQ2.
0: Selects pin P12 as IRQ2-A input
1: Selects pin P52 as IRQ2-B input
1
ITS1
0
R/W
IRQ1 Pin Select
Selects an input pin for IRQ1.
0: Selects pin P11 as IRQ1-A input
1: Selects pin P51 as IRQ1-B input
0
ITS0
0
R/W
IRQ0 Pin Select
Selects an input pin for IRQ0.
0: Selects pin P10 as IRQ0-A input
1: Selects pin P50 as IRQ0-B input
13.3.12 Port Function Control Register D (PFCRD)
PFCRD enables/disables the pin functions of ports J and K.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
PCJKE*
⎯
⎯
⎯
⎯
⎯
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
PCJKE*
0
R/W
Ports J and K Enable
Enables/disables ports J and K.
0: Ports J and K are disabled
1: Ports J and K are enabled
⎯
6 to 0
0
R/W
Reserved
These bits are always read as 0 and cannot be
modified. The initial values should not be changed.
Note:
*
This bit is valid during single-chip mode. The initial value should not be changed except
for the single-chip mode.
Rev. 2.00 Oct. 21, 2009 Page 675 of 1454
REJ09B0498-0200
Section 13 I/O Ports
13.4
Usage Notes
13.4.1
Notes on Input Buffer Control Register (ICR) Setting
1. When the ICR setting is changed, the LSI may malfunction due to an edge occurred internally
according to the pin state. Before changing the ICR setting, fix the pin state high or disable the
input function corresponding to the pin by the on-chip peripheral module settings.
2. If an input is enabled by setting ICR while multiple input functions are assigned to the pin, the
pin state is reflected in all the inputs. Care must be taken for each module settings for unused
input functions.
3. When a pin is used as an output, data to be output from the pin will be latched as the pin state
if the input function corresponding to the pin is enabled. To use the pin as an output, disable
the input function for the pin by setting ICR.
13.4.2
Notes on Port Function Control Register (PFCR) Settings
1. Port function controller controls the I/O port.
Before enabling a port function, select the input/output destination.
2. When changing input pins, this LSI may malfunction due to the internal edge generated by the
pin level difference before and after the change.
• To change input pins, the following procedure must be performed.
A. Disable the input function by the corresponding on-chip peripheral module settings
B. Select another input pin by PFCR
C. Enable its input function by the corresponding on-chip peripheral module settings
3. If a pin function has both a select bit that modifies the input/output destination and an enable
bit that enables the pin function, first specify the input/output destination by the selection bit
and then enable the pin function by the enable bit.
4. Modifying of the PCJKE bit should be done in the initial setting right after activation. Set other
bits after setting the PCJKE bit.
5. Do not change the PCJKE bit setting once it is set.
Rev. 2.00 Oct. 21, 2009 Page 676 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Section 14 16-Bit Timer Pulse Unit (TPU)
This LSI has two on-chip 16-bit timer pulse units (TPU), unit 0 and unit 1, each comprises six
channels. Therefore, this LSI includes twelve channels.
Functions of unit 0 and unit 1 are shown in table 14.1 and table 14.2 respectively. Block diagrams
of unit 0 and unit 1 are shown in figure 14.1 and figure 14.2 respectively.
This section explains unit 0. This explanation is common to unit 1.
14.1
Features
• Maximum 16-pulse input/output
• Selection of eight 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 operations:
• Multiple timer counters (TCNT) can be written to simultaneously
• Simultaneous clearing by compare match and input capture possible
• Simultaneous input/output for registers possible by counter synchronous operation
• Maximum of 15-phase PWM output possible by 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
• Programmable pulse generator (PPG) output trigger can be generated
• Conversion start trigger for the A/D converter can be generated (unit 0 only)
• Module stop state can be set
Rev. 2.00 Oct. 21, 2009 Page 677 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.1 TPU (Unit 0) Functions
Item
Channel 0 Channel 1 Channel 2 Channel 3 Channel 4 Channel 5
Count clock
Pφ/1
Pφ/4
Pφ/16
Pφ/64
TCLKA
TCLKB
TCLKC
TCLKD
Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/256
TCLKA
TCLKB
Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/1024
TCLKA
TCLKB
TCLKC
Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/256
Pφ/1024
Pφ/4096
TCLKA
Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/1024
TCLKA
TCLKC
Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/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
O
O
O
O
O
O
O
O
O
O
O
O
O
O
O
O
O
O
Input capture function O
O
O
O
O
O
Synchronous
operation
O
O
O
O
O
O
PWM mode
O
O
O
O
O
O
Phase counting mode ⎯
O
O
⎯
O
O
Buffer operation
O
⎯
⎯
O
⎯
⎯
DTC activation
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
Rev. 2.00 Oct. 21, 2009 Page 678 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Item
Channel 0 Channel 1 Channel 2 Channel 3 Channel 4 Channel 5
DMAC activation
TGRA_0
compare
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
A/D conversion start
trigger
TGRA_0
compare
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
PPG trigger
TGRA_0/
TGRB_0
compare
match or
input
capture
TGRA_1/
TGRB_1
compare
match or
input
capture
TGRA_2/
TGRB_2
compare
match or
input
capture
TGRA_3/
TGRB_3
compare
match or
input
capture
⎯
⎯
Interrupt sources
5 sources
4 sources
4 sources
5 sources
4 sources
4 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
Overflow
Overflow
Underflow
Underflow
Compare
match or
input
capture 0C
Compare
match or
input
capture 3C
Compare
match or
input
capture 0D
Compare
match or
input
capture 3D
Overflow
Overflow
Overflow
Underflow
Underflow
Overflow
[Legend]
O: Possible
⎯: Not possible
Rev. 2.00 Oct. 21, 2009 Page 679 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.2 TPU (Unit 1) Functions
Item
Channel 6
Channel 7
Channel 8
Channel 9
Channel 10 Channel 11
Count clock
Pφ/1
Pφ/4
Pφ/16
Pφ/64
TCLKE
TCLKF
TCLKG
TCLKH
Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/256
TCLKE
TCLKF
Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/1024
TCLKE
TCLKF
TCLKG
Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/256
Pφ/1024
Pφ/4096
TCLKE
Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/1024
TCLKE
TCLKG
Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/256
TCLKE
TCLKG
TCLKH
General registers
(TGR)
TGRA_6
TGRB_6
TGRA_7
TGRB_7
TGRA_8
TGRB_8
TGRA_9
TGRB_9
TGRA_10
TGRB_10
TGRA_11
TGRB_11
General registers/
buffer registers
TGRC_6
TGRD_6
⎯
⎯
TGRC_9
TGRD_9
⎯
⎯
I/O pins
TIOCA6
TIOCB6
TIOCC6
TIOCD6
TIOCA7
TIOCB7
TIOCA8
TIOCB8
TIOCA9
TIOCB9
TIOCC9
TIOCD9
TIOCA10
TIOCB10
TIOCA11
TIOCB11
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
O
O
O
O
O
O
O
O
O
O
O
O
O
O
O
O
O
O
Input capture function O
O
O
O
O
O
Synchronous
operation
O
O
O
O
O
O
PWM mode
O
O
O
O
O
O
Phase counting mode ⎯
O
O
⎯
O
O
Buffer operation
O
⎯
⎯
O
⎯
⎯
DTC activation
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
Rev. 2.00 Oct. 21, 2009 Page 680 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Item
Channel 6
Channel 7
Channel 8
Channel 9
Channel 10 Channel 11
DMAC activation
TGRA_6
compare
match or
input
capture
TGRA_7
compare
match or
input
capture
TGRA_8
compare
match or
input
capture
TGRA_9
compare
match or
input
capture
TGRA_10
compare
match or
input
capture
TGRA_11
compare
match or
input
capture
A/D conversion start
trigger
⎯
⎯
⎯
⎯
⎯
⎯
PPG trigger
TGRA_6/
TGRB_6
compare
match
TGRA_7/
TGRB_7
compare
match
TGRA_8/
TGRB_8
compare
match
TGRA_9/
TGRB_9
compare
match
⎯
⎯
Interrupt sources
5 sources
4 sources
4 sources
5 sources
4 sources
4 sources
Compare
match or
input
capture 6A
Compare
match or
input
capture 7A
Compare
match or
input
capture 8A
Compare
match or
input
capture 9A
Compare
match or
input
capture 6B
Compare
match or
input
capture 7B
Compare
match or
input
capture 8B
Compare
match or
input
capture
10A
Compare
match or
Compare
input
match or
capture 9B input
Compare capture
10B
match or
Compare
match or
input
capture
11A
Compare
match or
input
capture 6C
input
capture 9C
Compare
match or
input
capture 6D
Overflow
Compare
match or
input
capture
11B
Compare
match or
input
capture 9D
Overflow
Overflow
Underflow
Underflow
Overflow
Overflow
Overflow
Underflow
Underflow
[Legend]
O: Possible
⎯: Not possible
Rev. 2.00 Oct. 21, 2009 Page 681 of 1454
REJ09B0498-0200
TGRD
TGRB
TGRC
TGRB
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
A/D conversion start request signal
TGRD
TGRB
TGRB
TGRB
PPG output trigger signal
TGRC
TCNT
TCNT
TGRA
TCNT
TGRA
Bus interface
TGRB
TCNT
TCNT
TGRA
TCNT
TGRA
Module data bus
TGRA
TSR
TSR
TIER
TIER
TSR
TIOR
TIORH TIORL
TIER:
TSR:
TGR (A, B, C, D):
TCNT:
TGRA
TSR
TIER
TSR
TSTR TSYR
TIER
TSR
TIER
TIOR
TIOR
TIOR
TIER
TMDR
TIORH TIORL
TCR
TMDR
Channel 4
TCR
TMDR
Channel 5
TCR
Control logic
TMDR
TCR
TMDR
Channel 1
Channel 0
TCR
Common
Timer start register
Timer synchronous register
Timer control register
Timer mode register
Timer I/O control registers (H, L)
TMDR
Channel 2
[Legend]
TSTR:
TSYR:
TCR:
TMDR:
TIOR (H, L):
Control logic for channels 0 to 2
Input/output pins
TIOCA0
Channel 0:
TIOCB0
TIOCC0
TIOCD0
TIOCA1
Channel 1:
TIOCB1
TIOCA2
Channel 2:
TIOCB2
TCR
Clock input
Internal clock: Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/256
Pφ/1024
Pφ/4096
External clock: TCLKA
TCLKB
TCLKC
TCLKD
Control logic for channels 3 to 5
Input/output pins
Channel 3:
TIOCA3
TIOCB3
TIOCC3
TIOCD3
Channel 4:
TIOCA4
TIOCB4
Channel 5:
TIOCA5
TIOCB5
Channel 3
Section 14 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
Timer interrupt enable register
Timer status register
Timer general registers (A, B, C, D)
Timer counter
Figure 14.1 Block Diagram of TPU (Unit 0)
Rev. 2.00 Oct. 21, 2009 Page 682 of 1454
REJ09B0498-0200
TGRD
TGRB
TGRC
TGRB
Interrupt request signals
Channel 9: TGI9A
TGI9B
TGI9C
TGI9D
TCI9V
Channel 10: TGI10A
TGI10B
TCI10V
TCI10U
Channel 11: TGI11A
TGI11B
TCI11V
TCI11U
Internal data bus
TGRD
TGRB
TGRB
TGRB
PPG output trigger signal
TGRC
TCNT
TCNT
TGRA
TCNT
TGRA
Bus interface
TGRB
TCNT
TCNT
TGRA
TCNT
TGRA
Module data bus
TGRA
TSR
TSR
TIER
TIER
TSR
TIOR
TIORH TIORL
TIER:
TSR:
TGR (A, B, C, D):
TCNT:
TGRA
TSR
TIER
TSR
TSTRB TSYRB
TIER
TSR
TIER
TIOR
TIOR
Control logic
TIOR
TIER
TMDR
TIORH TIORL
TCR
TMDR
Channel 10
TCR
TMDR
Channel 11
TCR
TMDR
TCR
TMDR
Channel 7
Channel 6
TCR
Common
Timer start register
Timer synchronous register
Timer control register
Timer mode register
Timer I/O control registers (H, L)
TMDR
Channel 8
[Legend]
TSTRB:
TSYRB:
TCR:
TMDR:
TIOR (H, L):
Control logic for channels 6 to 8
Input/output pins
TIOCA6
Channel 6:
TIOCB6
TIOCC6
TIOCD6
TIOCA7
Channel 7:
TIOCB7
TIOCA8
Channel 8:
TIOCB8
TCR
Clock input
Internal clock: Pφ/1
Pφ/4
Pφ/16
Pφ/64
Pφ/256
Pφ/1024
Pφ/4096
External clock: TCLKE
TCLKF
TCLKG
TCLKH
Control logic for channels 9 to 11
Input/output pins
Channel 9:
TIOCA9
TIOCB9
TIOCC9
TIOCD9
Channel 10: TIOCA10
TIOCB10
Channel 11: TIOCA11
TIOCB11
Channel 9
Section 14 16-Bit Timer Pulse Unit (TPU)
Interrupt request signals
Channel 6: TGI6A
TGI6B
TGI6C
TGI6D
TCI6V
Channel 7: TGI7A
TGI7B
TCI7V
TCI7U
Channel 8: TGI8A
TGI8B
TCI8V
TCI8U
Timer interrupt enable register
Timer status register
Timer general registers (A, B, C, D)
Timer counter
Figure 14.2 Block Diagram of TPU (Unit 1)
Rev. 2.00 Oct. 21, 2009 Page 683 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.2
Input/Output Pins
Table 14.3 shows TPU pin configurations.
Table 14.3 Pin Configuration
Unit
Channel
Symbol
I/O
Function
0
All
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)
0
1
2
3
4
5
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
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
Rev. 2.00 Oct. 21, 2009 Page 684 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Unit
Channel
Symbol
I/O
Function
1
All
TCLKE
Input
External clock E input pin
(Channel 7 and 11 phase counting mode A phase input)
TCLKF
Input
External clock F input pin
(Channel 7 and 11 phase counting mode B phase input)
TCLKG
Input
External clock G input pin
(Channel 8 and 10 phase counting mode A phase input)
TCLKH
Input
External clock H input pin
(Channel 8 and 10 phase counting mode B phase input)
6
7
8
9
10
11
TIOCA6
I/O
TGRA_6 input capture input/output compare output/PWM output pin
TIOCB6
I/O
TGRB_6 input capture input/output compare output/PWM output pin
TIOCC6
I/O
TGRC_6 input capture input/output compare output/PWM output pin
TIOCD6
I/O
TGRD_6 input capture input/output compare output/PWM output pin
TIOCA7
I/O
TGRA_7 input capture input/output compare output/PWM output pin
TIOCB7
I/O
TGRB_7 input capture input/output compare output/PWM output pin
TIOCA8
I/O
TGRA_8 input capture input/output compare output/PWM output pin
TIOCB8
I/O
TGRB_8 input capture input/output compare output/PWM output pin
TIOCA9
I/O
TGRA_9 input capture input/output compare output/PWM output pin
TIOCB9
I/O
TGRB_9 input capture input/output compare output/PWM output pin
TIOCC9
I/O
TGRC_9 input capture input/output compare output/PWM output pin
TIOCD9
I/O
TGRD_9 input capture input/output compare output/PWM output pin
TIOCA10
I/O
TGRA_10 input capture input/output compare output/PWM output pin
TIOCB10
I/O
TGRB_10 input capture input/output compare output/PWM output pin
TIOCA11
I/O
TGRA_11 input capture input/output compare output/PWM output pin
TIOCB11
I/O
TGRB_11 input capture input/output compare output/PWM output pin
Rev. 2.00 Oct. 21, 2009 Page 685 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.3
Register Descriptions
The TPU has the following registers in each channel.
Registers in the unit 0 and unit 1 have the same functions except for the bit 7 in TIER, namely, the
TTGE bit in unit 0 and a reserved bit in unit 1. This section gives explanations regarding unit 0.
Unit 0:
• 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. 2.00 Oct. 21, 2009 Page 686 of 1454
REJ09B0498-0200
Section 14 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. 2.00 Oct. 21, 2009 Page 687 of 1454
REJ09B0498-0200
Section 14 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 synchronous register (TSYR)
Unit 1:
• Channel 6:
⎯ Timer control register_6 (TCR_6)
⎯ Timer mode register_6 (TMDR_6)
⎯ Timer I/O control register H_6 (TIORH_6)
⎯ Timer I/O control register L_6 (TIORL_6)
⎯ Timer interrupt enable register_6 (TIER_6)
⎯ Timer status register_6 (TSR_6)
⎯ Timer counter_6 (TCNT_6)
⎯ Timer general register A_6 (TGRA_6)
⎯ Timer general register B_6 (TGRB_6)
⎯ Timer general register C_6 (TGRC_6)
⎯ Timer general register D_6 (TGRD_6)
Rev. 2.00 Oct. 21, 2009 Page 688 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
• Channel 7:
⎯ Timer control register_7 (TCR_7)
⎯ Timer mode register_7 (TMDR_7)
⎯ Timer I/O control register _7 (TIOR_7)
⎯ Timer interrupt enable register_7 (TIER_7)
⎯ Timer status register_7 (TSR_7)
⎯ Timer counter_7 (TCNT_7)
⎯ Timer general register A_7 (TGRA_7)
⎯ Timer general register B_7 (TGRB_7)
• Channel 8:
⎯ Timer control register_8 (TCR_8)
⎯ Timer mode register_8 (TMDR_8)
⎯ Timer I/O control register_8 (TIOR_8)
⎯ Timer interrupt enable register_8 (TIER_8)
⎯ Timer status register_8 (TSR_8)
⎯ Timer counter_8 (TCNT_8)
⎯ Timer general register A_8 (TGRA_8)
⎯ Timer general register B_8 (TGRB_8)
• Channel 9:
⎯ Timer control register_9 (TCR_9)
⎯ Timer mode register_9 (TMDR_9)
⎯ Timer I/O control register H_9 (TIORH_9)
⎯ Timer I/O control register L_9 (TIORL_9)
⎯ Timer interrupt enable register_9 (TIER_9)
⎯ Timer status register_9 (TSR_9)
⎯ Timer counter_9 (TCNT_9)
⎯ Timer general register A_9 (TGRA_9)
⎯ Timer general register B_9 (TGRB_9)
⎯ Timer general register C_9 (TGRC_9)
⎯ Timer general register D_9 (TGRD_9)
Rev. 2.00 Oct. 21, 2009 Page 689 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
• Channel 10:
⎯ Timer control register_10 (TCR_10)
⎯ Timer mode register_10 (TMDR_10)
⎯ Timer I/O control register _10 (TIOR_10)
⎯ Timer interrupt enable register_10 (TIER_10)
⎯ Timer status register_10 (TSR_10)
⎯ Timer counter_10 (TCNT_10)
⎯ Timer general register A_10 (TGRA_10)
⎯ Timer general register B_10 (TGRB_10)
• Channel 11:
⎯ Timer control register_11 (TCR_11)
⎯ Timer mode register_11 (TMDR_11)
⎯ Timer I/O control register_11 (TIOR_11)
⎯ Timer interrupt enable register_11 (TIER_11)
⎯ Timer status register_11 (TSR_11)
⎯ Timer counter_11 (TCNT_11)
⎯ Timer general register A_11 (TGRA_11)
⎯ Timer general register B_11 (TGRB_11)
• Common Registers:
⎯ Timer start register (TSTRB)
⎯ Timer synchronous register (TSYRB)
Rev. 2.00 Oct. 21, 2009 Page 690 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.3.1
Timer Control Register (TCR)
TCR controls the TCNT operation for each channel. The TPU has a total of six TCR registers, one
for each channel. TCR register settings should be made only while TCNT operation is stopped.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
CCLR2
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
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 14.4 and 14.5 for details.
4
CKEG1
0
R/W
Clock Edge 1 and 0
3
CKEG0
0
R/W
These bits select the input clock edge. For details, see
table 14.6. When the input clock is counted using both
edges, the input clock period is halved (e.g. Pφ/4 both
edges = Pφ/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 Pφ/4
or slower. This setting is ignored if the input clock is Pφ/1,
or when overflow/underflow of another channel is
selected.
2
TPSC2
0
R/W
Timer 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 14.7 to 14.12 for details. To select the external
clock as the clock source, the DDR bit and ICR bit for the
corresponding pin should be set to 0 and 1, respectively.
For details, see section 13, I/O Ports.
Rev. 2.00 Oct. 21, 2009 Page 691 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.4 CCLR2 to CCLR0 (Channels 0 and 3)
Channel
Bit 7
CCLR2
Bit 6
CCLR1
Bit 5
CCLR0
Description
0, 3
0
0
0
TCNT clearing disabled
0
0
1
TCNT cleared by TGRA compare match/input
capture
0
1
0
TCNT cleared by TGRB compare match/input
capture
0
1
1
TCNT cleared by counter clearing for another
channel performing synchronous clearing/
synchronous operation*1
1
0
0
TCNT clearing disabled
1
0
1
TCNT cleared by TGRC compare match/input
capture*2
1
1
0
TCNT cleared by TGRD compare match/input
capture*2
1
1
1
TCNT cleared by counter clearing for another
channel performing synchronous clearing/
synchronous operation*1
Notes: 1. Synchronous operation is selected 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 14.5 CCLR2 to CCLR0 (Channels 1, 2, 4, and 5)
Channel
Bit 7
Bit 6
Reserved*2 CCLR1
Bit 5
CCLR0
Description
1, 2, 4, 5
0
0
0
TCNT clearing disabled
0
0
1
TCNT cleared by TGRA compare match/input
capture
0
1
0
TCNT cleared by TGRB compare match/input
capture
0
1
1
TCNT cleared by counter clearing for another
channel performing synchronous clearing/
synchronous operation*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. 2.00 Oct. 21, 2009 Page 692 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.6 Input Clock Edge Selection
Clock Edge Selection
Input Clock
CKEG1
CKEG0
Internal Clock
External Clock
0
0
Counted at falling edge
Counted at rising edge
0
1
Counted at rising edge
Counted at falling edge
1
x
Counted at both edges
Counted at both edges
[Legend]
x:
Don't care
Table 14.7 TPSC2 to TPSC0 (Channel 0)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
0
0
0
0
Internal clock: counts on Pφ/1
0
0
1
Internal clock: counts on Pφ/4
0
1
0
Internal clock: counts on Pφ/16
0
1
1
Internal clock: counts on Pφ/64
1
0
0
External clock: counts on TCLKA pin input
1
0
1
External clock: counts on TCLKB pin input
1
1
0
External clock: counts on TCLKC pin input
1
1
1
External clock: counts on TCLKD pin input
Table 14.8 TPSC2 to TPSC0 (Channel 1)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
1
0
0
0
Internal clock: counts on Pφ/1
0
0
1
Internal clock: counts on Pφ/4
0
1
0
Internal clock: counts on Pφ/16
0
1
1
Internal clock: counts on Pφ/64
1
0
0
External clock: counts on TCLKA pin input
1
0
1
External clock: counts on TCLKB pin input
1
1
0
Internal clock: counts on Pφ/256
1
1
1
Counts on TCNT2 overflow/underflow
Note: This setting is ignored when channel 1 is in phase counting mode.
Rev. 2.00 Oct. 21, 2009 Page 693 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.9 TPSC2 to TPSC0 (Channel 2)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
2
0
0
0
Internal clock: counts on Pφ/1
0
0
1
Internal clock: counts on Pφ/4
0
1
0
Internal clock: counts on Pφ/16
0
1
1
Internal clock: counts on Pφ/64
1
0
0
External clock: counts on TCLKA pin input
1
0
1
External clock: counts on TCLKB pin input
1
1
0
External clock: counts on TCLKC pin input
1
1
1
Internal clock: counts on Pφ/1024
Note: This setting is ignored when channel 2 is in phase counting mode.
Table 14.10 TPSC2 to TPSC0 (Channel 3)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
3
0
0
0
Internal clock: counts on Pφ/1
0
0
1
Internal clock: counts on Pφ/4
0
1
0
Internal clock: counts on Pφ/16
0
1
1
Internal clock: counts on Pφ/64
1
0
0
External clock: counts on TCLKA pin input
1
0
1
Internal clock: counts on Pφ/1024
1
1
0
Internal clock: counts on Pφ/256
1
1
1
Internal clock: counts on Pφ/4096
Rev. 2.00 Oct. 21, 2009 Page 694 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.11 TPSC2 to TPSC0 (Channel 4)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
4
0
0
0
Internal clock: counts on Pφ/1
0
0
1
Internal clock: counts on Pφ/4
0
1
0
Internal clock: counts on Pφ/16
0
1
1
Internal clock: counts on Pφ/64
1
0
0
External clock: counts on TCLKA pin input
1
0
1
External clock: counts on TCLKC pin input
1
1
0
Internal clock: counts on Pφ/1024
1
1
1
Counts on TCNT5 overflow/underflow
Note: This setting is ignored when channel 4 is in phase counting mode.
Table 14.12 TPSC2 to TPSC0 (Channel 5)
Channel
Bit 2
TPSC2
Bit 1
TPSC1
Bit 0
TPSC0
Description
5
0
0
0
Internal clock: counts on Pφ/1
0
0
1
Internal clock: counts on Pφ/4
0
1
0
Internal clock: counts on Pφ/16
0
1
1
Internal clock: counts on Pφ/64
1
0
0
External clock: counts on TCLKA pin input
1
0
1
External clock: counts on TCLKC pin input
1
1
0
Internal clock: counts on Pφ/256
1
1
1
External clock: counts on TCLKD pin input
Note: This setting is ignored when channel 5 is in phase counting mode.
Rev. 2.00 Oct. 21, 2009 Page 695 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.3.2
Timer Mode Register (TMDR)
TMDR sets the operating mode for each channel. The TPU has six TMDR registers, one for each
channel. TMDR register settings should be made only while TCNT operation is stopped.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
BFB
BFA
MD3
MD2
MD1
MD0
Initial Value
1
1
0
0
0
0
0
0
R/W
⎯
⎯
R/W
R/W
R/W
R/W
R/W
R/W
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 normally operate, 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 used together for buffer operation
4
BFA
0
R/W
Buffer Operation A
Specifies whether TGRA is to normally operate, 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 used together for buffer operation
3
MD3
0
R/W
Modes 3 to 0
2
MD2
0
R/W
Set the timer operating mode.
1
MD1
0
R/W
0
MD0
0
R/W
MD3 is a reserved bit. The write value should always be
0. See table 14.13 for details.
Rev. 2.00 Oct. 21, 2009 Page 696 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.13 MD3 to MD0
Bit 3
MD3*1
Bit 2
MD2*2
Bit 1
MD1
Bit 0
MD0
Description
0
0
0
0
Normal operation
0
0
0
1
Reserved
0
0
1
0
PWM mode 1
0
0
1
1
PWM mode 2
0
1
0
0
Phase counting mode 1
0
1
0
1
Phase counting mode 2
0
1
1
0
Phase counting mode 3
0
1
1
1
Phase counting mode 4
1
x
x
x
⎯
[Legend]
x:
Don't care
Notes: 1. MD3 is a reserved bit. The write value should always be 0.
2. Phase counting mode cannot be set for channels 0 and 3. In this case, 0 should always
be written to MD2.
Rev. 2.00 Oct. 21, 2009 Page 697 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.3.3
Timer I/O Control Register (TIOR)
TIOR controls TGR. 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 since 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.
To designate the input capture pin in TIOR, the DDR bit and ICR bit for the corresponding pin
should be set to 0 and 1, respectively. For details, see section 13, I/O Ports.
• TIORH_0, TIOR_1, TIOR_2, TIORH_3, TIOR_4, TIOR_5
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
• TIORL_0, TORL_3
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
IOD3
IOD2
IOD1
IOD0
IOC3
IOC2
IOC1
IOC0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 698 of 1454
REJ09B0498-0200
Section 14 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
Specify the function of TGRB.
5
IOB1
0
R/W
4
IOB0
0
R/W
For details, see tables 14.14, 14.16 to 14.18, 14.20 and
14.21.
3
IOA3
0
R/W
I/O Control A3 to A0
2
IOA2
0
R/W
Specify the function of TGRA.
1
IOA1
0
R/W
0
IOA0
0
R/W
For details, see tables 14.22, 14.24 to 14.26, 14.28, and
14.29.
• 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
Specify the function of TGRD.
5
IOD1
0
R/W
For details, see tables 14.15, and 14.19.
4
IOD0
0
R/W
3
IOC3
0
R/W
I/O Control C3 to C0
2
IOC2
0
R/W
Specify the function of TGRC.
1
IOC1
0
R/W
For details, see tables 14.23, and 14.27.
0
IOC0
0
R/W
Rev. 2.00 Oct. 21, 2009 Page 699 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.14 TIORH_0
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_0
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCB0 Pin Function*2
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
Input
capture
register
1
Capture input source is TIOCB0 pin
Input capture at rising edge
Capture input source is TIOCB0 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCB0 pin
Input capture at both edges
1
1
x
x
Capture input source is channel 1/count clock
1
Input capture at TCNT_1 count-up/count-down*
[Legend]
x:
Don't care
Notes: 1. When bits TPSC2 to TPSC0 in TCR_1 are set to B'000 and Pφ/1 is used as the
TCNT_1 count clock, this setting is invalid and input capture is not generated.
2. In PWM mode 1, the IOB3 to IOB0 settings control output of the TIOCA0 pin functions.
Rev. 2.00 Oct. 21, 2009 Page 700 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.15 TIORL_0
Description
Bit 7
IOD3
Bit 6
IOD2
Bit 5
IOD1
Bit 4
IOD0
TGRD_0
Function
0
0
0
0
0
0
0
1
Output
compare
register*2
TIOCD0 Pin Function*3
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
1
Input
capture
register*2
Capture input source is TIOCD0 pin
Input capture at rising edge
Capture input source is TIOCD0 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCD0 pin
Input capture at both edges
1
1
x
x
Capture input source is channel 1/count clock
1
Input capture at TCNT_1 count-up/count-down*
[Legend]
x:
Don't care
Notes: 1. When bits TPSC2 to TPSC0 in TCR_1 are set to B'000 and Pφ/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.
3. In PWM mode 1, the IOD3 to IOD0 settings control output of the TIOCC0 pin functions.
Rev. 2.00 Oct. 21, 2009 Page 701 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.16 TIOR_1
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_1
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCB1 Pin Function*
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
Input
capture
register
1
Capture input source is TIOCB1 pin
Input capture at rising edge
Capture input source is TIOCB1 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCB1 pin
Input capture at both edges
1
1
x
x
TGRC_0 compare match/input capture
Input capture at generation of TGRC_0 compare
match/input capture
[Legend]
x:
Don't care
Note: In PWM mode 1, the IOB3 to IOB0 settings control output of the TIOCA1 pin functions.
Rev. 2.00 Oct. 21, 2009 Page 702 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.17 TIOR_2
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_2
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCB2 Pin Function*
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
x
x
0
0
0
1
Input
capture
register
Capture input source is TIOCB2 pin
Input capture at rising edge
Capture input source is TIOCB2 pin
Input capture at falling edge
1
x
1
x
Capture input source is TIOCB2 pin
Input capture at both edges
[Legend]
x:
Don't care
Note: In PWM mode 1, the IOB3 to IOB0 settings control output of the TIOCA2 pin functions.
Rev. 2.00 Oct. 21, 2009 Page 703 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.18 TIORH_3
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_3
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCB3 Pin Function*2
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
Input
capture
register
1
Capture input source is TIOCB3 pin
Input capture at rising edge
Capture input source is TIOCB3 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCB3 pin
Input capture at both edges
1
1
x
x
Capture input source is channel 4/count clock
1
Input capture at TCNT_4 count-up/count-down*
[Legend]
x:
Don't care
Notes: 1. When bits TPSC2 to TPSC0 in TCR_4 are set to B'000 and Pφ/1 is used as the
TCNT_4 count clock, this setting is invalid and input capture is not generated.
2. In PWM mode 1, the IOB3 to IOB0 settings control output of the TIOCA3 pin functions.
Rev. 2.00 Oct. 21, 2009 Page 704 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.19 TIORL_3
Description
Bit 7
IOD3
Bit 6
IOD2
Bit 5
IOD1
Bit 4
IOD0
TGRD_3
Function
0
0
0
0
0
0
0
1
Output
compare
register*2
TIOCD3 Pin Function*3
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
1
Input
capture
register*2
Capture input source is TIOCD3 pin
Input capture at rising edge
Capture input source is TIOCD3 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCD3 pin
Input capture at both edges
1
1
x
x
Capture input source is channel 4/count clock
1
Input capture at TCNT_4 count-up/count-down*
[Legend]
x:
Don't care
Notes: 1. When bits TPSC2 to TPSC0 in TCR_4 are set to B'000 and Pφ/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.
3. In PWM mode 1, the IOD3 to IOD0 settings control output of the TIOCC3 pin functions.
Rev. 2.00 Oct. 21, 2009 Page 705 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.20 TIOR_4
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_4
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCB4 Pin Function*
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
Input
capture
register
1
Capture input source is TIOCB4 pin
Input capture at rising edge
Capture input source is TIOCB4 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCB4 pin
Input capture at both edges
1
1
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
Note: * In PWM mode 1, the IOB3 to IOB0 settings control output of the TIOCA4 pin functions.
Rev. 2.00 Oct. 21, 2009 Page 706 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.21 TIOR_5
Description
Bit 7
IOB3
Bit 6
IOB2
Bit 5
IOB1
Bit 4
IOB0
TGRB_5
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCB5 Pin Function*
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
x
x
0
0
0
1
Input
capture
register
Capture input source is TIOCB5 pin
Input capture at rising edge
Capture input source is TIOCB5 pin
Input capture at falling edge
1
x
1
x
Capture input source is TIOCB5 pin
Input capture at both edges
[Legend]
x:
Don't care
Note: * In PWM mode 1, the IOB3 to IOB0 settings control output of the TIOCA5 pin functions.
Rev. 2.00 Oct. 21, 2009 Page 707 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.22 TIORH_0
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_0
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCA0 Pin Function
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
Input
capture
register
1
Capture input source is TIOCA0 pin
Input capture at rising edge
Capture input source is TIOCA0 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCA0 pin
Input capture at both edges
1
1
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 bits TPSC2 to TPSC0 in TCR_1 are set to B'000 and Pφ/1 is used as the
count clock of TCNT_1, this setting is invalid and input capture is not generated.
Rev. 2.00 Oct. 21, 2009 Page 708 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.23 TIORL_0
Description
Bit 3
IOC3
Bit 2
IOC2
Bit 1
IOC1
Bit 0
IOC0
TGRC_0
Function
0
0
0
0
0
0
0
1
Output
compare
register*2
TIOCC0 Pin Function
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
1
Input
capture
register*2
Capture input source is TIOCC0 pin
Input capture at rising edge
Capture input source is TIOCC0 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCC0 pin
Input capture at both edges
1
1
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
Note: 1. When the bits TPSC2 to TPSC0 in TCR_1 are set to B'000 and Pφ/1 is used as the
count clock of TCNT_1, this setting is invalid and input capture is not generated.
2. 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. 2.00 Oct. 21, 2009 Page 709 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.24 TIOR_1
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_1
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCA1 Pin Function
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
Input
capture
register
1
Capture input source is TIOCA1 pin
Input capture at rising edge
Capture input source is TIOCA1 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCA1 pin
Input capture at both edges
1
1
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. 2.00 Oct. 21, 2009 Page 710 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.25 TIOR_2
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_2
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCA2 Pin Function
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
x
x
0
0
0
1
Input
capture
register
Capture input source is TIOCA2 pin
Input capture at rising edge
Capture input source is TIOCA2 pin
Input capture at falling edge
1
x
1
x
Capture input source is TIOCA2 pin
Input capture at both edges
[Legend]
x:
Don't care
Rev. 2.00 Oct. 21, 2009 Page 711 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.26 TIORH_3
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_3
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCA3 Pin Function
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
Input
capture
register
1
Capture input source is TIOCA3 pin
Input capture at rising edge
Capture input source is TIOCA3 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCA3 pin
Input capture at both edges
1
1
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 bits TPSC2 to TPSC0 in TCR_4 are set to B'000 and Pφ/1 is used as the
count clock of TCNT_4, this setting is invalid and input capture is not generated.
Rev. 2.00 Oct. 21, 2009 Page 712 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.27 TIORL_3
Description
Bit 3
IOC3
Bit 2
IOC2
Bit 1
IOC1
Bit 0
IOC0
TGRC_3
Function
0
0
0
0
0
0
0
1
Output
compare
register*2
TIOCC3 Pin Function
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
1
Input
capture
register*2
Capture input source is TIOCC3 pin
Input capture at rising edge
Capture input source is TIOCC3 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCC3 pin
Input capture at both edges
1
1
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
Note: 1. When the bits TPSC2 to TPSC0 in TCR_4 are set to B'000 and Pφ/1 is used as the
count clock of TCNT_4, this setting is invalid and input capture is not generated.
2. 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. 2.00 Oct. 21, 2009 Page 713 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.28 TIOR_4
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_4
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCA4 Pin Function
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
0
0
0
0
0
Input
capture
register
1
Capture input source is TIOCA4 pin
Input capture at rising edge
Capture input source is TIOCA4 pin
Input capture at falling edge
1
0
1
x
Capture input source is TIOCA4 pin
Input capture at both edges
1
1
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. 2.00 Oct. 21, 2009 Page 714 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.29 TIOR_5
Description
Bit 3
IOA3
Bit 2
IOA2
Bit 1
IOA1
Bit 0
IOA0
TGRA_5
Function
0
0
0
0
0
0
0
1
Output
compare
register
TIOCA5 Pin Function
Output disabled
Initial output is 0 output
0 output at compare match
0
0
1
0
0
0
1
1
Initial output is 0 output
1 output at compare match
Initial output is 0 output
Toggle output at compare match
0
1
0
0
Output disabled
0
1
0
1
Initial output is 1 output
0 output at compare match
0
1
1
0
Initial output is 1 output
1 output at compare match
0
1
1
1
Initial output is 1 output
Toggle output at compare match
1
1
x
x
0
0
0
1
Input
capture
register
Input capture source is TIOCA5 pin
Input capture at rising edge
Input capture source is TIOCA5 pin
Input capture at falling edge
1
x
1
x
Input capture source is TIOCA5 pin
Input capture at both edges
[Legend]
x:
Don't care
Rev. 2.00 Oct. 21, 2009 Page 715 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.3.4
Timer Interrupt Enable Register (TIER)
TIER controls enabling or disabling of interrupt requests for each channel. The TPU has six TIER
registers, one for each channel.
Bit
Bit Name
7
6
5
4
3
2
1
0
TTGE*
⎯
TCIEU
TCIEV
TGIED
TGIEC
TGIEB
TGIEA
0
1
0
0
0
0
0
0
R/W
⎯
R/W
R/W
R/W
R/W
R/W
R/W
Initial Value
R/W
Note: *
Bit 7 in TIER of unit 1 is a reserved bit.
This bit is always read as 0 and the initial value should not be changed.
Bit
Bit Name
Initial
value
R/W
7
TTGE*
0
R/W
Description
A/D Conversion Start Request Enable
Enables/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/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/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
Rev. 2.00 Oct. 21, 2009 Page 716 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Bit
Bit Name
Initial
value
R/W
Description
3
TGIED
0
R/W
TGR Interrupt Enable D
Enables/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
2
TGIEC
0
R/W
TGR Interrupt Enable C
Enables/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/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/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
Note:
The bit 7 in TIER of unit 1 is a reserved bit. This bit is always read as 0 and the initial
value should not be changed.
*
14.3.5
Timer Status Register (TSR)
TSR indicates the status of each channel. The TPU has six TSR registers, one for each channel.
Bit
7
6
5
4
3
2
1
0
TCFD
⎯
TCFU
TCFV
TGFD
TGFC
TGFB
TGFA
Initial Value
1
1
0
0
0
0
0
0
R/W
R
⎯
R/(W)*
R/(W)*
R/(W)*
R/(W)*
R/(W)*
R/(W)*
Bit Name
Note: * Only 0 can be written to bits 5 to 0, to clear flags.
Rev. 2.00 Oct. 21, 2009 Page 717 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
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
⎯
5
TCFU
0
R/(W)* Underflow Flag
Reserved
This bit is always read as 1 and cannot be modified.
Status flag that indicates that a TCNT underflow has occurred
when channels 1, 2, 4, and 5 are set to phase counting mode.
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 a 0 is written to TCFU after reading TCFU = 1
(When the CPU is used to clear this flag by writing 0 while the
corresponding interrupt is enabled, be sure to read the flag
after writing 0 to it.)
4
TCFV
0
R/(W)* Overflow Flag
Status flag that indicates that a TCNT overflow has occurred.
[Setting condition]
When the TCNT value overflows (changes from H'FFFF to
H'0000)
[Clearing condition]
When a 0 is written to TCFV after reading TCFV = 1
(When the CPU is used to clear this flag by writing 0 while the
corresponding interrupt is enabled, be sure to read the flag
after writing 0 to it.)
Rev. 2.00 Oct. 21, 2009 Page 718 of 1454
REJ09B0498-0200
Section 14 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.
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 while TGRD is functioning as
output compare register
•
When TCNT value is transferred to TGRD by input
capture signal while TGRD is functioning as input
capture register
[Clearing conditions]
•
When DTC is activated by a TGID interrupt while the
DISEL bit in MRB of DTC is 0
•
When 0 is written to TGFD after reading TGFD = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
2
TGFC
0
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.
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 while TGRC is functioning as
output compare register
•
When TCNT value is transferred to TGRC by input
capture signal while TGRC is functioning as input
capture register
[Clearing conditions]
•
When DTC is activated by a TGIC interrupt while the
DISEL bit in MRB of DTC is 0
•
When 0 is written to TGFC after reading TGFC = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
Rev. 2.00 Oct. 21, 2009 Page 719 of 1454
REJ09B0498-0200
Section 14 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.
[Setting conditions]
•
When TCNT = TGRB while TGRB is functioning as
output compare register
•
When TCNT value is transferred to TGRB by input
capture signal while TGRB is functioning as input
capture register
[Clearing conditions]
•
When DTC is activated by a TGIB interrupt while the
DISEL bit in MRB of DTC is 0
•
When 0 is written to TGFB after reading TGFB = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
0
TGFA
0
R/(W)* Input Capture/Output Compare Flag A
Status flag that indicates the occurrence of TGRA input
capture or compare match.
[Setting conditions]
•
When TCNT = TGRA while TGRA is functioning as
output compare register
•
When TCNT value is transferred to TGRA by input
capture signal while TGRA is functioning as input
capture register
[Clearing conditions]
•
When DTC is activated by a TGIA interrupt while the
DISEL bit in MRB of DTC is 0
•
When DMAC is activated by a TGIA interrupt while
the DTA bit in DMDR of DMAC is 1
•
When 0 is written to TGFA after reading TGFA = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
Note:
*
Only 0 can be written to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 720 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.3.6
Timer Counter (TCNT)
TCNT is a 16-bit readable/writable counter. The TPU has six TCNT counters, one for each
channel.
TCNT is initialized to H'0000 by a reset or in hardware standby mode.
TCNT cannot be accessed in 8-bit units. TCNT must always be accessed in 16-bit units.
Bit
15
14
13
12
11
10
9
8
Bit Name
Initial Value
R/W
Bit
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
Initial Value
R/W
14.3.7
Timer General Register (TGR)
TGR is a 16-bit readable/writable register with a dual function as output compare and 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 in 16-bit units. TGR and buffer register combinations during buffer operations
are TGRA−TGRC and TGRB−TGRD.
Bit
15
14
13
12
11
10
9
8
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 721 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.3.8
Timer Start Register (TSTR)
TSTR starts or stops operation 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
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
CST5
CST4
CST3
CST2
CST1
CST0
Initial Value
0
0
0
0
0
0
0
0
R/W
⎯
⎯
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
value
R/W
Description
7, 6
⎯
All 0
⎯
Reserved
The write value should always be 0.
5
CST5
0
R/W
Counter Start 5 to 0
4
CST4
0
R/W
These bits select operation or stoppage for 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_5 to TCNT_0 count operation is stopped
1: TCNT_5 to TCNT_0 performs count operation
Rev. 2.00 Oct. 21, 2009 Page 722 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.3.9
Timer Synchronous Register (TSYR)
TSYR selects independent operation or synchronous operation for the TCNT counters of channels
0 to 5. A channel performs synchronous operation when the corresponding bit in TSYR is set to 1.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
SYNC5
SYNC4
SYNC3
SYNC2
SYNC1
SYNC0
Initial Value
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
value
R/W
Description
7, 6
⎯
All 0
R/W
Reserved
The write value should always be 0.
5
SYNC5
0
R/W
Timer Synchronization 5 to 0
4
SYNC4
0
R/W
3
SYNC3
0
R/W
These bits select whether operation is independent of or
synchronized with other channels.
2
SYNC2
0
R/W
1
SYNC1
0
R/W
0
SYNC0
0
R/W
When synchronous operation is selected, synchronous
presetting of multiple channels, and synchronous clearing
through 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 bits CCLR2 to
CCLR0 in TCR.
0: TCNT_5 to TCNT_0 operate independently (TCNT
presetting/clearing is unrelated to other channels)
1: TCNT_5 to TCNT_0 perform synchronous operation
(TCNT synchronous presetting/synchronous clearing is
possible)
Rev. 2.00 Oct. 21, 2009 Page 723 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.4
Operation
14.4.1
Basic Functions
Each channel has a TCNT and TGR register. TCNT performs up-counting, and is also capable of
free-running operation, periodic counting, and external event counting.
Each TGR can be used as an input capture register or output compare register.
(1)
Counter Operation
When one of bits CST0 to CST5 is set to 1 in TSTR, the TCNT counter for the corresponding
channel starts counting. TCNT can operate as a free-running counter, periodic counter, and so on.
(a)
Example of count operation setting procedure
Figure 14.3 shows an example of the count operation setting procedure.
[1] Select the counter clock with bits
TPSC2 to TPSC0 in TCR. At the
same time, select the input clock edge
with bits CKEG1 and CKEG0 in TCR.
Operation selection
Select counter clock
[1]
Periodic counter
Select counter clearing source
[2] For periodic counter operation, select
the TGR to be used as the TCNT
clearing source with bits CCLR2 to
CCLR0 in TCR.
Free-running counter
[3] Designate the TGR selected in [2] as
an output compare register by means
of TIOR.
[2]
[4] Set the periodic counter cycle in the
TGR selected in [2].
Select output compare register
[3]
Set period
[4]
Start count
[5]
[5] Set the CST bit in TSTR to 1 to start
the counter operation.
Start count
[5]
Figure 14.3 Example of Counter Operation Setting Procedure
Rev. 2.00 Oct. 21, 2009 Page 724 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(b)
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 up-count
operation as a free-running counter. When TCNT overflows (changes 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 14.4 illustrates free-running counter operation.
TCNT value
H'FFFF
H'0000
Time
CST bit
TCFV
Figure 14.4 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 bits
CCLR2 to CCLR0 in TCR. After the settings have been made, TCNT starts count-up 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.
Rev. 2.00 Oct. 21, 2009 Page 725 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Figure 14.5 illustrates periodic counter operation.
TCNT value
Counter cleared by TGR
compare match
TGR
H'0000
Time
CST bit
Flag cleared by software or
DTC activation
TGF
Figure 14.5 Periodic Counter Operation
(2)
Waveform Output by Compare Match
The TPU can perform 0, 1, or toggle output from the corresponding output pin using a compare
match.
(a)
Example of setting procedure for waveform output by compare match
Figure 14.6 shows an example of the setting procedure for waveform output by a compare match.
Output selection
Select waveform output mode
[1]
Set output timing
[2]
[1] Select initial value from 0-output or 1-output,
and compare match output value from 0-output,
1-output, or toggle-output, by means of TIOR.
The set initial value is output on the TIOC pin
until the first compare match occurs.
Start count
[3]
[2] Set the timing for compare match generation in
TGR.
[3] Set the CST bit in TSTR to 1 to start the count
operation.
Figure 14.6 Example of Setting Procedure for Waveform Output by Compare Match
Rev. 2.00 Oct. 21, 2009 Page 726 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(b)
Examples of waveform output operation
Figure 14.7 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 so that 1 is output by compare match A, and 0 is output by compare match B. When the set
level and the pin level match, the pin level does not change.
TCNT value
H'FFFF
TGRA
TGRB
Time
H'0000
No change
No change
TIOCA
1-output
TIOCB
No change
No change
0-output
Figure 14.7 Example of 0-Output/1-Output Operation
Figure 14.8 shows an example of toggle output.
In this example, TCNT has been designated as a periodic counter (with counter clearing performed
by compare match B), and settings have been made so that 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
TIOCB
Toggle-output
TIOCA
Toggle-output
Figure 14.8 Example of Toggle Output Operation
Rev. 2.00 Oct. 21, 2009 Page 727 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(3)
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 detection 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, Pφ/1 should not be selected as the counter input clock used for input
capture input. Input capture will not be generated if Pφ/1 is selected.
(a)
Example of setting procedure for input capture operation
Figure 14.9 shows an example of the setting procedure for input capture operation.
Input selection
Select input capture input
[1]
Start count
[2]
[1] Designate TGR as an input capture register by
means of TIOR, and select the input capture source
and input signal edge (rising edge, falling
edge, or both edges).
[2] Set the CST bit in TSTR to 1 to start the count
operation.
Figure 14.9 Example of Setting Procedure for Input Capture Operation
Rev. 2.00 Oct. 21, 2009 Page 728 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(b)
Example of input capture operation
Figure 14.10 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, 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.
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 14.10 Example of Input Capture Operation
Rev. 2.00 Oct. 21, 2009 Page 729 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.4.2
Synchronous Operation
In synchronous operation, the values in multiple TCNT counters can be rewritten simultaneously
(synchronous presetting). Also, multiple TCNT counters can be cleared simultaneously
(synchronous clearing) by making the appropriate setting in TCR.
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.
(1)
Example of Synchronous Operation Setting Procedure
Figure 14.11 shows an example of the synchronous operation setting procedure.
Synchronous operation
selection
Set synchronous
operation
[1]
Synchronous presetting
Set TCNT
Synchronous clearing
[2]
Clearing
source generation
channel?
No
Yes
Select counter
clearing source
[3]
Set synchronous
counter clearing
[4]
Start count
[5]
Start count
[5]
[1] Set the SYNC bits in TSYR corresponding to the channels to be designated for synchronous operation to 1.
[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 bits CCLR2 to CCLR0 in TCR to specify TCNT clearing by input capture/output compare, etc.
[4] Use bits CCLR2 to CCLR0 in TCR to designate synchronous clearing for the counter clearing source.
[5] Set the CST bits in TSTR for the relevant channels to 1, to start the count operation.
Figure 14.11 Example of Synchronous Operation Setting Procedure
Rev. 2.00 Oct. 21, 2009 Page 730 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(2)
Example of Synchronous Operation
Figure 14.12 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 on PWM modes, see section 14.4.5, PWM Modes.
Synchronous clearing by TGRB_0 compare match
TCNT_0 to TCNT_2 values
TGRB_0
TGRB_1
TGRA_0
TGRB_2
TGRA_1
TGRA_2
Time
H'0000
TIOCA_0
TIOCA_1
TIOCA_2
Figure 14.12 Example of Synchronous Operation
Rev. 2.00 Oct. 21, 2009 Page 731 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.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 a compare match register.
Table 14.30 shows the register combinations used in buffer operation.
Table 14.30 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.
This operation is illustrated in figure 14.13.
Compare match signal
Buffer register
Timer general
register
Comparator
Figure 14.13 Compare Match Buffer Operation
Rev. 2.00 Oct. 21, 2009 Page 732 of 1454
REJ09B0498-0200
TCNT
Section 14 16-Bit Timer Pulse Unit (TPU)
• 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 TGR is transferred to the buffer register.
This operation is illustrated in figure 14.14.
Input capture
signal
Timer general
register
Buffer register
TCNT
Figure 14.14 Input Capture Buffer Operation
(1)
Example of Buffer Operation Setting Procedure
Figure 14.15 shows an example of the buffer operation setting procedure.
Buffer operation
[1] Designate TGR as an input capture register or
output compare register by means of TIOR.
Select TGR function
[1]
Set buffer operation
[2]
[2] Designate TGR for buffer operation with bits
BFA and BFB in TMDR.
Start count
[3]
[3] Set the CST bit in TSTR to 1 to start the count
operation.
Figure 14.15 Example of Buffer Operation Setting Procedure
Rev. 2.00 Oct. 21, 2009 Page 733 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(2)
Examples of Buffer Operation
(a)
When TGR is an output compare register
Figure 14.16 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 compare match A occurs.
For details on PWM modes, see section 14.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 14.16 Example of Buffer Operation (1)
Rev. 2.00 Oct. 21, 2009 Page 734 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(b)
When TGR is an input capture register
Figure 14.17 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 occurrence of
input capture A, the value previously stored in TGRA is simultaneously transferred to TGRC.
TCNT value
H'0F07
H'09FB
H'0532
H'0000
Time
TIOCA
TGRA
TGRC
H'0532
H'0F07
H'09FB
H'0532
H'0F07
Figure 14.17 Example of Buffer Operation (2)
Rev. 2.00 Oct. 21, 2009 Page 735 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.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 at overflow/underflow of
TCNT_2 (TCNT_5) as set in bits TPSC2 to TPSC0 in TCR.
Underflow occurs only when the lower 16-bit TCNT is in phase-counting mode.
Table 14.31 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 counter operates independently in phase counting mode.
Table 14.31 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
(1)
Example of Cascaded Operation Setting Procedure
Figure 14.18 shows an example of the setting procedure for cascaded operation.
[1] Set bits TPSC2 to TPSC0 in the channel 1
(channel 4) TCR to B'1111 to select TCNT_2
(TCNT_5) overflow/underflow counting.
Cascaded operation
Set cascading
[1]
Start count
[2]
[2] Set the CST bit in TSTR for the upper and lower
channels to 1 to start the count operation.
Figure 14.18 Cascaded Operation Setting Procedure
Rev. 2.00 Oct. 21, 2009 Page 736 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(2)
Examples of Cascaded Operation
Figure 14.19 illustrates the operation when counting upon TCNT_2 overflow/underflow has been
set for TCNT_1, TGRA_1 and TGRA_2 have been designated as input capture registers, and the
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'0000
H'0001
TIOCA1,
TIOCA2
TGRA_1
H'03A2
TGRA_2
H'0000
Figure 14.19 Example of Cascaded Operation (1)
Figure 14.20 illustrates the operation when counting upon TCNT_2 overflow/underflow has been
set for TCNT_1, and phase counting mode has been designated for channel 2.
TCNT_1 is incremented by TCNT_2 overflow and decremented by TCNT_2 underflow.
TCLKC
TCLKD
TCNT_2
TCNT_1
FFFD
FFFE
0000
FFFF
0000
0001
0002
0001
0000
0001
FFFF
0000
Figure 14.20 Example of Cascaded Operation (2)
Rev. 2.00 Oct. 21, 2009 Page 737 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.4.5
PWM Modes
In PWM mode, PWM waveforms are output from the output pins. 0-, 1-, or toggle-output can be
selected as the output level in response to compare match of each TGR.
Settings of TGR registers can output a PWM waveform in the range of 0% to 100% duty cycle.
Designating TGR compare match as the counter clearing source enables the cycle 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.
1. PWM mode 1
PWM output is generated from the TIOCA and TIOCC pins by pairing TGRA with TGRB and
TGRC with TGRD. The outputs specified by bits IOA3 to IOA0 and IOC3 to IOC0 in TIOR
are output from the TIOCA and TIOCC pins at compare matches A and C, respectively. The
outputs specified by bits IOB3 to IOB0 and IOD3 to IOD0 in TIOR are output at compare
matches B and D, respectively. 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.
2. PWM mode 2
PWM output is generated using one TGR as the cycle register and the others as duty cycle
registers. The output specified in TIOR is performed by means of compare matches. Upon
counter clearing by a synchronous 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 cycle registers are identical, the
output value does not change when a compare match occurs.
In PWM mode 2, a maximum 15-phase PWM output is possible by combined use with
synchronous operation.
The correspondence between PWM output pins and registers is shown in table 14.32.
Rev. 2.00 Oct. 21, 2009 Page 738 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Table 14.32 PWM Output Registers and Output Pins
Output Pins
Channel
Registers
PWM Mode 1
0
TGRA_0
TIOCA0
TGRB_0
TGRC_0
TGRA_1
TIOCC0
TGRA_2
TIOCA1
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
TIOCD0
TGRB_1
2
TIOCA0
TIOCB0
TGRD_0
1
PWM Mode 2
TIOCA4
TIOCB4
TIOCA5
TIOCA5
TIOCB5
Note: In PWM mode 2, PWM output is not possible for the TGR register in which the cycle is set.
Rev. 2.00 Oct. 21, 2009 Page 739 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(1)
Example of PWM Mode Setting Procedure
Figure 14.21 shows an example of the PWM mode setting procedure.
[1] Select the counter clock with bits TPSC2 to
PWM mode
TPSC0 in TCR. At the same time, select the
input clock edge with bits CKEG1 and CKEG0 in
Select counter clock
[1]
Select counter clearing source
[2]
Select waveform output level
[3]
Set TGR
[4]
TCR.
[2] Use bits CCLR2 to CCLR0 in TCR to select the
TGR to be used as the TCNT clearing source.
[3] Use TIOR to designate TGR as an output
compare register, and select the initial value and
output value.
[4] Set the cycle in TGR selected in [2], and set the
duty in the other TGRs.
Set PWM mode
[5]
Start count
[6]
[5] Select the PWM mode with bits MD3 to MD0 in
TMDR.
[6] Set the CST bit in TSTR to 1 to start the count
operation.
Figure 14.21 Example of PWM Mode Setting Procedure
(2)
Examples of PWM Mode Operation
Figure 14.22 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 cycle, and the value set in TGRB register as the
duty cycle.
Rev. 2.00 Oct. 21, 2009 Page 740 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
TCNT value
TGRA
Counter cleared by
TGRA compare match
TGRB
H'0000
Time
TIOCA
Figure 14.22 Example of PWM Mode Operation (1)
Figure 14.23 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), to output 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 as
the duty cycle.
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 14.23 Example of PWM Mode Operation (2)
Rev. 2.00 Oct. 21, 2009 Page 741 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Figure 14.24 shows examples of PWM waveform output with 0% duty cycle and 100% duty cycle
in PWM mode.
TCNT value
TGRB changed
TGRA
TGRB
TGRB changed
TGRB
changed
H'0000
Time
0% duty
TIOCA
Output does not change when compare matches in cycle register
and duty register occur simultaneously
TCNT value
TGRB changed
TGRA
TGRB changed
TGRB changed
TGRB
H'0000
Time
100% duty
TIOCA
Output does not change when compare matches in cycle register
and duty register occur simultaneously
TCNT value
TGRB changed
TGRA
TGRB changed
TGRB
TGRB changed
Time
H'0000
100% duty
TIOCA
0% duty
Figure 14.24 Example of PWM Mode Operation (3)
Rev. 2.00 Oct. 21, 2009 Page 742 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.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 bits TPSC2 to TPSC0 and bits
CKEG1 and CKEG0 in TCR. However, the functions of bits CCLR1 and CCLR0 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.
When overflow occurs while TCNT is counting up, the TCFV flag in TSR is set; when underflow
occurs while TCNT is counting down, the TCFU flag is set.
The TCFD bit in TSR is the count direction flag. Reading the TCFD flag provides an indication of
whether TCNT is counting up or down.
Table 14.33 shows the correspondence between external clock pins and channels.
Table 14.33 Clock Input Pins in Phase Counting Mode
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
Rev. 2.00 Oct. 21, 2009 Page 743 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(1)
Example of Phase Counting Mode Setting Procedure
Figure 14.25 shows an example of the phase counting mode setting procedure.
Phase counting mode
Select phase counting mode
[1]
Start count
[2]
[1] Select phase counting mode with bits MD3 to
MD0 in TMDR.
[2] Set the CST bit in TSTR to 1 to start the count
operation.
Figure 14.25 Example of Phase Counting Mode Setting Procedure
Rev. 2.00 Oct. 21, 2009 Page 744 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(2)
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.
(a)
Phase counting mode 1
Figure 14.26 shows an example of phase counting mode 1 operation, and table 14.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 14.26 Example of Phase Counting Mode 1 Operation
Table 14.34 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
Low level
High level
High level
Down-count
Low level
High level
Low level
[Legend]
: Rising edge
: Falling edge
Rev. 2.00 Oct. 21, 2009 Page 745 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(b)
Phase counting mode 2
Figure 14.27 shows an example of phase counting mode 2 operation, and table 14.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
Up-count
Down-count
Time
Figure 14.27 Example of Phase Counting Mode 2 Operation
Table 14.35 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)
Operation
High level
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
High level
Don't care
Low level
Down-count
[Legend]
: Rising edge
: Falling edge
Rev. 2.00 Oct. 21, 2009 Page 746 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(c)
Phase counting mode 3
Figure 14.28 shows an example of phase counting mode 3 operation, and table 14.36 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 14.28 Example of Phase Counting Mode 3 Operation
Table 14.36 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. 2.00 Oct. 21, 2009 Page 747 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(d)
Phase counting mode 4
Figure 14.29 shows an example of phase counting mode 4 operation, and table 14.37 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 14.29 Example of Phase Counting Mode 4 Operation
Table 14.37 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
Up-count
High level
Low level
Low level
Don't care
High level
High level
Down-count
Low level
High level
Low level
[Legend]
: Rising edge
: Falling edge
Rev. 2.00 Oct. 21, 2009 Page 748 of 1454
REJ09B0498-0200
Don't care
Section 14 16-Bit Timer Pulse Unit (TPU)
(3)
Phase Counting Mode Application Example
Figure 14.30 shows an example in which phase counting mode is designated for channel 1, and
channel 1 is coupled with channel 0 to input servo motor 2-phase encoder pulses in order to detect
the 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 cycle and
position control cycle. 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 width of 2-phase encoder 4-multiplication pulses is detected.
TGRA_1 and TGRB_1 for channel 1 are designated for input capture, channel 0 TGRA_0 and
TGRC_0 compare matches are selected as the input capture source, and the up/down-counter
values for the control cycles are stored.
This procedure enables accurate position/speed detection to be achieved.
Channel 1
TCLKA
TCLKB
Edge
detection
circuit
TCNT_1
TGRA_1
(speed cycle capture)
TGRB_1
(position cycle capture)
TCNT_0
TGRA_0
(speed control cycle)
+
-
TGRC_0
(position control cycle)
+
-
TGRB_0 (pulse width capture)
TGRD_0 (buffer operation)
Channel 0
Figure 14.30 Phase Counting Mode Application Example
Rev. 2.00 Oct. 21, 2009 Page 749 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.5
Interrupt Sources
There are three kinds of TPU interrupt sources: TGR input capture/compare match, TCNT
overflow, and TCNT underflow. Each interrupt source has its own status flag and enable/disable
bit, allowing 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 priority levels can be changed by the interrupt controller, but the priority within a
channel is fixed. For details, see section 7, Interrupt Controller.
Table 14.38 lists the TPU interrupt sources.
Table 14.38 TPU Interrupts
Channel
Name
Interrupt Source
Interrupt
Flag
DTC
Activation
DMAC
Activation
0
TGI0A
TGRA_0 input capture/compare match
TGFA_0
Possible
Possible
TGI0B
TGRB_0 input capture/compare match
TGFB_0
Possible
Not possible
TGI0C
TGRC_0 input capture/compare match
TGFC_0
Possible
Not possible
TGI0D
TGRD_0 input capture/compare match
TGFD_0
Possible
Not possible
TCI0V
TCNT_0 overflow
TCFV_0
Not possible
Not possible
TGI1A
TGRA_1 input capture/compare match
TGFA_1
Possible
Possible
1
2
TGI1B
TGRB_1 input capture/compare match
TGFB_1
Possible
Not possible
TCI1V
TCNT_1 overflow
TCFV_1
Not possible
Not possible
TCI1U
TCNT_1 underflow
TCFU_1
Not possible
Not possible
TGI2A
TGRA_2 input capture/compare match
TGFA_2
Possible
Possible
TGI2B
TGRB_2 input capture/compare match
TGFB_2
Possible
Not possible
TCI2V
TCNT_2 overflow
TCFV_2
Not possible
Not possible
TCI2U
TCNT_2 underflow
TCFU_2
Not possible
Not possible
Rev. 2.00 Oct. 21, 2009 Page 750 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
Channel
Name
Interrupt Source
Interrupt
Flag
DTC
Activation
DMAC
Activation
3
TGI3A
TGRA_3 input capture/compare match
TGFA_3
Possible
Possible
TGI3B
TGRB_3 input capture/compare match
TGFB_3
Possible
Not possible
TGI3C
TGRC_3 input capture/compare match
TGFC_3
Possible
Not possible
TGI3D
TGRD_3 input capture/compare match
TGFD_3
Possible
Not possible
TCI3V
TCNT_3 overflow
TCFV_3
Not possible
Not possible
TGI4A
TGRA_4 input capture/compare match
TGFA_4
Possible
Possible
TGI4B
TGRB_4 input capture/compare match
TGFB_4
Possible
Not possible
TCI4V
TCNT_4 overflow
TCFV_4
Not possible
Not possible
TCI4U
TCNT_4 underflow
TCFU_4
Not possible
Not possible
TGI5A
TGRA_5 input capture/compare match
TGFA_5
Possible
Possible
TGI5B
TGRB_5 input capture/compare match
TGFB_5
Possible
Not possible
TCI5V
TCNT_5 overflow
TCFV_5
Not possible
Not possible
TCI5U
TCNT_5 underflow
TCFU_5
Not possible
Not possible
4
5
Note: This table shows the initial state immediately after a reset. The relative channel priority
levels can be changed by the interrupt controller.
(1)
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 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.
(2)
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 a 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.
(3)
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 a 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.
Rev. 2.00 Oct. 21, 2009 Page 751 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.6
DTC Activation
The DTC can be activated by the TGR input capture/compare match interrupt for a channel. For
details, see section 12, Data Transfer Controller (DTC).
A total of 24 TPU input capture/compare match interrupts can be used as DTC activation sources,
four each for channels 0, 3, 6, and 9, and two each for channels 1, 2, 4, and 5.
14.7
DMAC Activation
The DMAC can be activated by the TGRA input capture/compare match interrupt for a channel.
For details, see section 10, DMA Controller (DMAC).
In TPU, one in each channel, totally six TGRA input capture/compare match interrupts can be
used as DMAC activation sources.
14.8
A/D Converter Activation
Concerning the unit 0 in TPU, the TGRA input capture/compare match for each channel can
activate the A/D converter. (However, the A/D converter cannot be activated in unit 1.)
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 start 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 started.
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. 2.00 Oct. 21, 2009 Page 752 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.9
Operation Timing
14.9.1
Input/Output Timing
(1)
TCNT Count Timing
Figure 14.31 shows TCNT count timing in internal clock operation, and figure 14.32 shows TCNT
count timing in external clock operation.
Pφ
Internal clock
Falling edge
Rising edge
Falling edge
TCNT input
clock
N−1
TCNT
N+1
N
N+2
Figure 14.31 Count Timing in Internal Clock Operation
Pφ
External clock
Falling edge
Rising edge
Falling edge
TCNT input
clock
TCNT
N−1
N
N+1
N+2
Figure 14.32 Count Timing in External Clock Operation
Rev. 2.00 Oct. 21, 2009 Page 753 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(2)
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 (TIOC pin).
After a match between TCNT and TGR, the compare match signal is not generated until the
TCNT input clock is generated.
Figure 14.33 shows output compare output timing.
Pφ
TCNT input
clock
TCNT
N
TGR
N
N+1
Compare match
signal
TIOC pin
Figure 14.33 Output Compare Output Timing
(3)
Input Capture Signal Timing
Figure 14.34 shows input capture signal timing.
Pφ
Input capture
input
Input capture
signal
TCNT
N
N+2
N+1
N
TGR
Figure 14.34 Input Capture Input Signal Timing
Rev. 2.00 Oct. 21, 2009 Page 754 of 1454
REJ09B0498-0200
N+2
Section 14 16-Bit Timer Pulse Unit (TPU)
(4)
Timing for Counter Clearing by Compare Match/Input Capture
Figure 14.35 shows the timing when counter clearing by compare match occurrence is specified,
and figure 14.36 shows the timing when counter clearing by input capture occurrence is specified.
Pφ
Compare match
signal
Counter clear
signal
TCNT
N
TGR
N
H'0000
Figure 14.35 Counter Clear Timing (Compare Match)
Pφ
Input capture
signal
Counter clear
signal
TCNT
TGR
N
H'0000
N
Figure 14.36 Counter Clear Timing (Input Capture)
Rev. 2.00 Oct. 21, 2009 Page 755 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(5)
Buffer Operation Timing
Figures 14.37 and 14.38 show the timings in buffer operation.
Pφ
TCNT
n
n+1
TGRA, TGRB
n
N
TGRC, TGRD
N
Compare match
signal
Figure 14.37 Buffer Operation Timing (Compare Match)
Pφ
Input capture
signal
TCNT
N
TGRA, TGRB
n
TGRC, TGRD
N+1
N
N+1
n
N
Figure 14.38 Buffer Operation Timing (Input Capture)
Rev. 2.00 Oct. 21, 2009 Page 756 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.9.2
(1)
Interrupt Signal Timing
TGF Flag Setting Timing in Case of Compare Match
Figure 14.39 shows the timing for setting of the TGF flag in TSR by compare match occurrence,
and the TGI interrupt request signal timing.
Pφ
TCNT input
clock
TCNT
N
TGR
N
N+1
Compare match
signal
TGF flag
TGI interrupt
Figure 14.39 TGI Interrupt Timing (Compare Match)
(2)
TGF Flag Setting Timing in Case of Input Capture
Figure 14.40 shows the timing for setting of the TGF flag in TSR by input capture occurrence, and
the TGI interrupt request signal timing.
Pφ
Input capture
signal
N
TCNT
TGR
N
TGF flag
TGI interrupt
Figure 14.40 TGI Interrupt Timing (Input Capture)
Rev. 2.00 Oct. 21, 2009 Page 757 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(3)
TCFV Flag/TCFU Flag Setting Timing
Figure 14.41 shows the timing for setting of the TCFV flag in TSR by overflow occurrence, and
the TCIV interrupt request signal timing.
Figure 14.42 shows the timing for setting of the TCFU flag in TSR by underflow occurrence, and
the TCIU interrupt request signal timing.
Pφ
TCNT input
clock
TCNT
(overflow)
H'0000
H'FFFF
Overflow signal
TCFV flag
TCIV interrupt
Figure 14.41 TCIV Interrupt Setting Timing
Pφ
TCNT input
clock
TCNT
(underflow)
H'0000
H'FFFF
Underflow signal
TCFU flag
TCIU interrupt
Figure 14.42 TCIU Interrupt Setting Timing
Rev. 2.00 Oct. 21, 2009 Page 758 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
(4)
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 or
DMAC is activated, the flag is cleared automatically. Figure 14.43 shows the timing for status flag
clearing by the CPU, and figures 14.44 and 14.45 show the timing for status flag clearing by the
DTC or DMAC.
TSR write cycle
T1
T2
Pφ
TSR address
Address
Write
Status flag
Interrupt request
signal
Figure 14.43 Timing for Status Flag Clearing by CPU
The status flag and interrupt request signal are cleared in synchronization with Pφ after the DTC or
DMAC transfer has started, as shown in figure 14.44. If conflict occurs for clearing the status flag
and interrupt request signal due to activation of multiple DTC or DMAC transfers, it will take up
to five clock cycles (Pφ) for clearing them, as shown in figure 14.45. The next transfer request is
masked for a longer period of either a period until the current transfer ends or a period for five
clock cycles (Pφ) from the beginning of the transfer. Note that in the DTC transfer, the status flag
may be cleared during outputting the destination address.
Rev. 2.00 Oct. 21, 2009 Page 759 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
DTC/DMAC
read cycle
T1
T2
DTC/DMAC
write cycle
T1
T2
Source
address
Destination
address
Pφ
Address
Status flag
Period in which the next transfer request is masked
Interrupt request
signal
Figure 14.44 Timing for Status Flag Clearing by DTC/DMAC Activation (1)
DTC/DMAC
read cycle
DTC/DMAC
write cycle
Pφ
Address
Source address
Destination address
Period in which the next transfer request is masked
Status flag
Interrupt request
signal
Period of flag clearing
Period of interrupt request signal clearing
Figure 14.45 Timing for Status Flag Clearing by DTC/DMAC Activation (2)
Rev. 2.00 Oct. 21, 2009 Page 760 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.10
Usage Notes
14.10.1 Module Stop Function Setting
Operation of the TPU can be disabled or enabled using the module stop control register. The initial
setting is for operation of the TPU to be halted. Register access is enabled by clearing module stop
state. For details, see section 28, Power-Down Modes.
14.10.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 with a
narrower pulse width.
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 14.46 shows the input clock
conditions in phase counting mode.
Phase
Phase
difference
difference
Overlap
Overlap
Pulse width
Pulse width
TCLKA
(TCLKC)
TCLKB
(TCLKD)
Pulse width
Pulse width
Note: Phase difference, Overlap ≥ 1.5 states
Pulse width ≥ 2.5 states
Figure 14.46 Phase Difference, Overlap, and Pulse Width in Phase Counting Mode
Rev. 2.00 Oct. 21, 2009 Page 761 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.10.3 Caution on Cycle Setting
When counter clearing by 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=
Pφ
(N + 1)
f:
Counter frequency
Pφ: Operating frequency
N: TGR set value
14.10.4 Conflict between TCNT Write and Clear Operations
If the counter clearing signal is generated in the T2 state of a TCNT write cycle, TCNT clearing
takes precedence and the TCNT write is not performed. Figure 14.47 shows the timing in this
case.
TCNT write cycle
T1
T2
Pφ
Address
TCNT address
Write
Counter clear
signal
TCNT
N
H'0000
Figure 14.47 Conflict between TCNT Write and Clear Operations
Rev. 2.00 Oct. 21, 2009 Page 762 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.10.5 Conflict 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 14.48 shows the timing in this case.
TCNT write cycle
T2
T1
Pφ
Address
TCNT address
Write
TCNT input
clock
TCNT
N
M
TCNT write data
Figure 14.48 Conflict between TCNT Write and Increment Operations
14.10.6 Conflict 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 disabled. A compare match also does not occur when the same
value as before is written.
Figure 14.49 shows the timing in this case.
TGR write cycle
T1
T2
Pφ
Address
TGR address
Write
Compare match
signal
TCNT
TGR
Disabled
N
N
N+1
M
TGR write data
Figure 14.49 Conflict between TGR Write and Compare Match
Rev. 2.00 Oct. 21, 2009 Page 763 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.10.7 Conflict between Buffer Register Write and Compare Match
If a compare match occurs in the T2 state of a TGR write cycle, the data transferred to TGR by the
buffer operation will be the write data.
Figure 14.50 shows the timing in this case.
TGR write cycle
T1
T2
Pφ
Buffer register
address
Address
Write
Data written to buffer register
Compare match
signal
M
N
Buffer register
TGR
M
Figure 14.50 Conflict between Buffer Register Write and Compare Match
14.10.8 Conflict between TGR Read and Input Capture
If the input capture signal is generated in the T1 state of a TGR read cycle, the data that is read
will be the data after input capture transfer.
Figure 14.51 shows the timing in this case.
TGR read cycle
T2
T1
Pφ
Address
TGR address
Read
Input capture
signal
TGR
X
Internal data
bus
M
M
Figure 14.51 Conflict between TGR Read and Input Capture
Rev. 2.00 Oct. 21, 2009 Page 764 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.10.9 Conflict between TGR Write and Input Capture
If the 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 14.52 shows the timing in this case.
TGR write cycle
T2
T1
Pφ
Address
TGR address
Write
Input capture
signal
TCNT
TGR
M
M
Figure 14.52 Conflict between TGR Write and Input Capture
Rev. 2.00 Oct. 21, 2009 Page 765 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.10.10 Conflict between Buffer Register Write and Input Capture
If the 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 14.53 shows the timing in this case.
Buffer register write cycle
T2
T1
Pφ
Buffer register
address
Address
Write
Input capture
signal
N
TCNT
TGR
Buffer register
M
N
M
Figure 14.53 Conflict between Buffer Register Write and Input Capture
Rev. 2.00 Oct. 21, 2009 Page 766 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.10.11 Conflict 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 14.54 shows the operation timing when a TGR compare match is specified as the clearing
source, and H'FFFF is set in TGR.
Pφ
TCNT input
clock
TCNT
H'FFFF
H'0000
Counter clear
signal
TGF flag
TCFV flag
Disabled
Figure 14.54 Conflict between Overflow and Counter Clearing
14.10.12 Conflict between TCNT Write and Overflow/Underflow
If an overflow/underflow occurs due to increment/decrement in the T2 state of a TCNT write
cycle, the TCNT write takes precedence and the TCFV/TCFU flag in TSR is not set.
Figure 14.55 shows the operation timing when there is conflict between TCNT write and
overflow.
TGR write cycle
T2
T1
Pφ
Address
TCNT address
Write
TCNT
TCNT write data
H'FFFF
M
TCFV flag
Figure 14.55 Conflict between TCNT Write and Overflow
Rev. 2.00 Oct. 21, 2009 Page 767 of 1454
REJ09B0498-0200
Section 14 16-Bit Timer Pulse Unit (TPU)
14.10.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.
14.10.14 PPG1 Setting when TPU1 Pin is Used
When the TPU1 pin is used, the NDER bit of the PPG1 pin multiplexed with the TPU1 pin should
be cleared to halt the output. For details, see section 13, I/O Ports.
14.10.15 Interrupts in the Module Stop State
If module stop state is entered when an interrupt has been requested, it will not be possible to clear
the CPU interrupt source, or the DTC or DMAC activation sources. Interrupts should therefore be
disabled before entering module stop state.
Rev. 2.00 Oct. 21, 2009 Page 768 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
Section 15 Programmable Pulse Generator (PPG)
The programmable pulse generator (PPG) provides pulse outputs by using the 16-bit timer pulse
unit (TPU) as a time base. The PPG pulse outputs are divided into 4-bit groups (groups 7 to 0) that
can operate both simultaneously and independently. Figures 15.1 and 15.2 show a block diagram
of the PPG. Table 15.1 shows a list of PPG functions.
15.1
•
•
•
•
•
•
•
Features
32-bit output data
Four output groups
Selectable output trigger signals
Non-overlapping mode
Can operate together with the data transfer controller (DTC) and DMA controller (DMAC)
Inverted output can be set
Module stop state specifiable
Table 15.1 List of PPG Functions
Function
PPG output trigger
TPU0
TPU1
PPG0
PPG1
Compare match
Possible
Not possible
Input capture
Possible
Not possible
Compare match
Not possible
Possible
Input capture
Not possible
Not possible
Possible
Possible
DTC
Possible
Possible
DMAC
Possible
Possible
Possible
Possible
Non-overlapping mode
Output data transfer
Inverted output
Rev. 2.00 Oct. 21, 2009 Page 769 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
Compare match signals
Control logic
PO15
PO14
PO13
PO12
PO11
PO10
PO9
PO8
PO7
PO6
PO5
PO4
PO3
PO2
PO1
PO0
[Legend]
PMR:
PCR:
NDERH:
NDERL:
NDERH
NDERL
PMR
PCR
Pulse output
pins, group 3
PODRH
NDRH
PODRL
NDRL
Pulse output
pins, group 2
Pulse output
pins, group 1
Pulse output
pins, group 0
PPG output mode register
PPG output control register
Next data enable register H
Next data enable register L
NDRH:
NDRL:
PODRH:
PODRL:
Next data register H
Next data register L
Output data register H
Output data register L
Figure 15.1 Block Diagram of PPG (Unit 0)
Rev. 2.00 Oct. 21, 2009 Page 770 of 1454
REJ09B0498-0200
Internal
data bus
Section 15 Programmable Pulse Generator (PPG)
Compare match signals
Control logic
PO31
PO30
PO29
PO28
PO27
PO26
PO25
PO24
PO23
PO22
PO21
PO20
PO19
PO18
PO17
PO16
[Legend]
PMR_1:
PCR_1:
NDERH_1:
NDERL_1:
NDERH_1
NDERL_1
PMR_1
PCR_1
Pulse output
pins, group 7
PODRH_1
NDRH_1
PODRL_1
NDRL_1
Pulse output
pins, group 6
Internal
data bus
Pulse output
pins, group 5
Pulse output
pins, group 4
PPG output mode register_1
PPG output control register_1
Next data enable register H_1
Next data enable register L_1
NDRH_1:
NDRL_1:
PODRH_1:
PODRL_1:
Next data register H_1
Next data register L_1
Output data register H_1
Output data register L_1
Figure 15.2 Block Diagram of PPG (Unit 1)
Rev. 2.00 Oct. 21, 2009 Page 771 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.2
Input/Output Pins
Table 15.2 shows the PPG pin configuration.
Table 15.2 Pin Configuration
Unit
Pin Name
I/O
Function
0
PO0
Output
Group 0 pulse output
PO1
Output
PO2
Output
PO3
Output
PO4
Output
PO5
Output
PO6
Output
PO7
Output
PO8
Output
PO9
Output
PO10
Output
PO11
Output
PO12
Output
PO13
Output
PO14
Output
PO15
Output
Rev. 2.00 Oct. 21, 2009 Page 772 of 1454
REJ09B0498-0200
Group 1 pulse output
Group 2 pulse output
Group 3 pulse output
Section 15 Programmable Pulse Generator (PPG)
Unit
Pin Name
I/O
Function
1
PO16
Output
Group 4 pulse output
PO17
Output
PO18
Output
PO19
Output
PO20
Output
PO21
Output
PO22
Output
PO23
Output
PO24
Output
PO25
Output
PO26
Output
PO27
Output
PO28
Output
PO29
Output
PO30
Output
PO31
Output
Group 5 pulse output
Group 6 pulse output
Group 7 pulse output
Rev. 2.00 Oct. 21, 2009 Page 773 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.3
Register Descriptions
The PPG has the following registers.
Unit 0:
•
•
•
•
•
•
•
•
Next data enable register H (NDERH)
Next data enable register L (NDERL)
Output data register H (PODRH)
Output data register L (PODRL)
Next data register H (NDRH)
Next data register L (NDRL)
PPG output control register (PCR)
PPG output mode register (PMR)
Unit 1:
•
•
•
•
•
•
•
•
Next data enable register H_1 (NDERH_1)
Next data enable register L_1 (NDERL_1)
Output data register H_1 (PODRH_1)
Output data register L_1 (PODRL_1)
Next data register H_1 (NDRH_1)
Next data register L_1 (NDRL_1)
PPG output control register_1 (PCR_1)
PPG output mode register_1 (PMR_1)
Rev. 2.00 Oct. 21, 2009 Page 774 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.3.1
Next Data Enable Registers H, L (NDERH, NDERL)
NDERH and NDERL enable/disable pulse output on a bit-by-bit basis.
• NDERH
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
NDER15
NDER14
NDER13
NDER12
NDER11
NDER10
NDER9
NDER8
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
NDER7
NDER6
NDER5
NDER4
NDER3
NDER2
NDER1
NDER0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
• NDERL
Bit
Bit Name
Initial Value
R/W
Rev. 2.00 Oct. 21, 2009 Page 775 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• NDERH
Bit
Bit Name
Initial
Value
R/W
Description
7
NDER15
0
R/W
Next Data Enable 15 to 8
6
NDER14
0
R/W
5
NDER13
0
R/W
4
NDER12
0
R/W
When a bit is set to 1, the value in the corresponding
NDRH bit is transferred to the PODRH bit by the selected
output trigger. Values are not transferred from NDRH to
PODRH for cleared bits.
3
NDER11
0
R/W
2
NDER10
0
R/W
1
NDER9
0
R/W
0
NDER8
0
R/W
• NDERL
Bit
Bit Name
Initial
Value
R/W
Description
7
NDER7
0
R/W
Next Data Enable 7 to 0
6
NDER6
0
R/W
5
NDER5
0
R/W
4
NDER4
0
R/W
When a bit is set to 1, the value in the corresponding
NDRL bit is transferred to the PODRL bit by the selected
output trigger. Values are not transferred from NDRL to
PODRL for cleared bits.
3
NDER3
0
R/W
2
NDER2
0
R/W
1
NDER1
0
R/W
0
NDER0
0
R/W
Rev. 2.00 Oct. 21, 2009 Page 776 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• NDERH_1
Bit
Bit Name
Initial
Value
R/W
Description
7
NDER31
0
R/W
Next Data Enable 31 to 24
6
NDER30
0
R/W
5
NDER29
0
R/W
4
NDER28
0
R/W
When a bit is set to 1, the value in the corresponding
NDRH_1 bit is transferred to the PODRH_1 bit by the
selected output trigger. Values are not transferred from
NDRH_1 to PODRH_1 for cleared bits.
3
NDER27
0
R/W
2
NDER26
0
R/W
1
NDER25
0
R/W
0
NDER24
0
R/W
• NDERL_1
Bit
Bit Name
Initial
Value
R/W
Description
7
NDER23
0
R/W
Next Data Enable 23 to 16
6
NDER22
0
R/W
5
NDER21
0
R/W
4
NDER20
0
R/W
When a bit is set to 1, the value in the corresponding
NDRL_1 bit is transferred to the PODRL_1 bit by the
selected output trigger. Values are not transferred from
NDRL_1 to PODRL_1 for cleared bits.
3
NDER19
0
R/W
2
NDER18
0
R/W
1
NDER17
0
R/W
0
NDER16
0
R/W
Rev. 2.00 Oct. 21, 2009 Page 777 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.3.2
Output Data Registers H, L (PODRH, PODRL)
PODRH and PODRL store output data for use in pulse output. A bit that has been set for pulse
output by NDER is read-only and cannot be modified.
• PODRH
7
6
5
4
3
2
1
0
POD15
POD14
POD13
POD12
POD11
POD10
POD9
POD8
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
POD7
POD6
POD5
POD4
POD3
POD2
POD1
POD0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial Value
R/W
• PODRL
Bit
Bit Name
Initial Value
R/W
• PODRH
Bit
Bit Name
Initial
Value
R/W
Description
7
POD15
0
R/W
Output Data Register 15 to 8
6
POD14
0
R/W
5
POD13
0
R/W
4
POD12
0
R/W
3
POD11
0
R/W
For bits which have been set to pulse output by NDERH,
the output trigger transfers NDRH values to this register
during PPG operation. While NDERH is set to 1, the CPU
cannot write to this register. While NDERH is cleared, the
initial output value of the pulse can be set.
2
POD10
0
R/W
1
POD9
0
R/W
0
POD8
0
R/W
Rev. 2.00 Oct. 21, 2009 Page 778 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• PODRL
Bit
Bit Name
Initial
Value
R/W
Description
7
POD7
0
R/W
Output Data Register 7 to 0
6
POD6
0
R/W
5
POD5
0
R/W
4
POD4
0
R/W
3
POD3
0
R/W
For bits which have been set to pulse output by NDERL,
the output trigger transfers NDRL values to this register
during PPG operation. While NDERL is set to 1, the CPU
cannot write to this register. While NDERL is cleared, the
initial output value of the pulse can be set.
2
POD2
0
R/W
1
POD1
0
R/W
0
POD0
0
R/W
• PODRH_1
Bit
Bit Name
Initial
Value
R/W
Description
7
POD31
0
R/W
Output Data Register 31 to 24
6
POD30
0
R/W
5
POD29
0
R/W
4
POD28
0
R/W
3
POD27
0
R/W
2
POD26
0
R/W
For bits which have been set to pulse output by
NDERH_1, the output trigger transfers NDRH_1 values to
this register during PPG operation. While NDERH_1 is
set to 1, the CPU cannot write to this register. While
NDERH_1 is cleared, the initial output value of the pulse
can be set.
1
POD25
0
R/W
0
POD24
0
R/W
Rev. 2.00 Oct. 21, 2009 Page 779 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• PODRL_1
Bit
Bit Name
Initial
Value
R/W
Description
7
POD23
0
R/W
Output Data Register 23 to 16
6
POD22
0
R/W
5
POD21
0
R/W
4
POD20
0
R/W
3
POD19
0
R/W
2
POD18
0
R/W
For bits which have been set to pulse output by
NDERL_1, the output trigger transfers NDRL_1 values to
this register during PPG operation. While NDERL_1 is set
to 1, the CPU cannot write to this register. While
NDERL_1 is cleared, the initial output value of the pulse
can be set.
1
POD17
0
R/W
0
POD16
0
R/W
15.3.3
Next Data Registers H, L (NDRH, NDRL)
NDRH and NDRL store the next data for pulse output. The NDR addresses differ depending on
whether pulse output groups have the same output trigger or different output triggers.
• NDRH
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
NDR15
NDR14
NDR13
NDR12
NDR11
NDR10
NDR9
NDR8
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
NDR7
NDR6
NDR5
NDR4
NDR3
NDR2
NDR1
NDR0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
• NDRL
Bit
Bit Name
Initial Value
R/W
Rev. 2.00 Oct. 21, 2009 Page 780 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• NDRH
If pulse output groups 2 and 3 have the same output trigger, all eight bits are mapped to the
same address and can be accessed at one time, as shown below.
Bit
Bit Name
Initial
Value
R/W
Description
7
NDR15
0
R/W
Next Data Register 15 to 8
6
NDR14
0
R/W
5
NDR13
0
R/W
4
NDR12
0
R/W
The register contents are transferred to the
corresponding PODRH bits by the output trigger specified
with PCR.
3
NDR11
0
R/W
2
NDR10
0
R/W
1
NDR9
0
R/W
0
NDR8
0
R/W
If pulse output groups 2 and 3 have different output triggers, the upper four bits and lower four
bits are mapped to different addresses as shown below.
Bit
Bit Name
Initial
Value
R/W
Description
7
NDR15
0
R/W
Next Data Register 15 to 12
6
NDR14
0
R/W
5
NDR13
0
R/W
4
NDR12
0
R/W
The register contents are transferred to the
corresponding PODRH bits by the output trigger specified
with PCR.
3 to 0
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
Bit
Bit Name
Initial
Value
R/W
Description
7 to 4
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
3
NDR11
0
R/W
Next Data Register 11 to 8
2
NDR10
0
R/W
1
NDR9
0
R/W
0
NDR8
0
R/W
The register contents are transferred to the
corresponding PODRH bits by the output trigger specified
with PCR.
Rev. 2.00 Oct. 21, 2009 Page 781 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• NDRL
If pulse output groups 0 and 1 have the same output trigger, all eight bits are mapped to the
same address and can be accessed at one time, as shown below.
Bit
Bit Name
Initial
Value
R/W
Description
7
NDR7
0
R/W
Next Data Register 7 to 0
6
NDR6
0
R/W
5
NDR5
0
R/W
4
NDR4
0
R/W
The register contents are transferred to the
corresponding PODRL bits by the output trigger specified
with PCR.
3
NDR3
0
R/W
2
NDR2
0
R/W
1
NDR1
0
R/W
0
NDR0
0
R/W
If pulse output groups 0 and 1 have different output triggers, the upper four bits and lower four
bits are mapped to different addresses as shown below.
Bit
Bit Name
Initial
Value
R/W
Description
7
NDR7
0
R/W
Next Data Register 7 to 4
6
NDR6
0
R/W
5
NDR5
0
R/W
4
NDR4
0
R/W
The register contents are transferred to the
corresponding PODRL bits by the output trigger specified
with PCR.
3 to 0
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
Bit
Bit Name
Initial
Value
R/W
Description
7 to 4
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
3
NDR3
0
R/W
Next Data Register 3 to 0
2
NDR2
0
R/W
1
NDR1
0
R/W
0
NDR0
0
R/W
The register contents are transferred to the
corresponding PODRL bits by the output trigger specified
with PCR.
Rev. 2.00 Oct. 21, 2009 Page 782 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• NDRH_1
If pulse output groups 6 and 7 have the same output trigger, all eight bits are mapped to the
same address and can be accessed at one time, as shown below.
Bit
Bit Name
Initial
Value
R/W
Description
7
NDR31
0
R/W
Next Data Register 31 to 24
6
NDR30
0
R/W
5
NDR29
0
R/W
4
NDR28
0
R/W
The register contents are transferred to the
corresponding PODRH_1 bits by the output trigger
specified with PCR_1.
3
NDR27
0
R/W
2
NDR26
0
R/W
1
NDR25
0
R/W
0
NDR24
0
R/W
If pulse output groups 6 and 7 have different output triggers, the upper four bits and lower four
bits are mapped to different addresses as shown below.
Bit
Bit Name
Initial
Value
R/W
Description
7
NDR31
0
R/W
Next Data Register 31 to 28
6
NDR30
0
R/W
5
NDR29
0
R/W
4
NDR28
0
R/W
The register contents are transferred to the
corresponding PODRH_1 bits by the output trigger
specified with PCR_1.
3 to 0
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
Bit
Bit Name
Initial
Value
R/W
Description
7 to 4
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
3
NDR27
0
R/W
Next Data Register 27 to 24
2
NDR26
0
R/W
1
NDR25
0
R/W
0
NDR24
0
R/W
The register contents are transferred to the
corresponding PODRH_1 bits by the output trigger
specified with PCR_1.
Rev. 2.00 Oct. 21, 2009 Page 783 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• NDRL_1
If pulse output groups 4 and 5 have the same output trigger, all eight bits are mapped to the
same address and can be accessed at one time, as shown below.
Bit
Bit Name
Initial
Value
R/W
Description
7
NDR23
0
R/W
Next Data Register 23 to 16
6
NDR22
0
R/W
5
NDR21
0
R/W
4
NDR20
0
R/W
The register contents are transferred to the
corresponding PODRL_1 bits by the output trigger
specified with PCR_1.
3
NDR19
0
R/W
2
NDR18
0
R/W
1
NDR17
0
R/W
0
NDR16
0
R/W
If pulse output groups 4 and 5 have different output triggers, the upper four bits and lower four
bits are mapped to different addresses as shown below.
Bit
Bit Name
Initial
Value
R/W
Description
7
NDR23
0
R/W
Next Data Register 23 to 20
6
NDR22
0
R/W
5
NDR21
0
R/W
4
NDR20
0
R/W
The register contents are transferred to the
corresponding PODRL_1 bits by the output trigger
specified with PCR_1.
3 to 0
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
Bit
Bit Name
Initial
Value
R/W
Description
7 to 4
⎯
All 1
⎯
Reserved
These bits are always read as 1 and cannot be modified.
3
NDR19
0
R/W
Next Data Register 19 to 16
2
NDR18
0
R/W
1
NDR17
0
R/W
0
NDR16
0
R/W
The register contents are transferred to the
corresponding PODRL_1 bits by the output trigger
specified with PCR_1.
Rev. 2.00 Oct. 21, 2009 Page 784 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.3.4
PPG Output Control Register (PCR)
PCR selects output trigger signals on a group-by-group basis. For details on output trigger
selection, refer to section 15.3.5, PPG Output Mode Register (PMR).
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
G3CMS1
G3CMS0
G2CMS1
G2CMS0
G1CMS1
G1CMS0
G0CMS1
G0CMS0
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
G3CMS1
1
R/W
Group 3 Compare Match Select 1 and 0
6
G3CMS0
1
R/W
These bits select output trigger of pulse output group 3.
00: Compare match in TPU channel 0
01: Compare match in TPU channel 1
10: Compare match in TPU channel 2
11: Compare match in TPU channel 3
5
G2CMS1
1
R/W
Group 2 Compare Match Select 1 and 0
4
G2CMS0
1
R/W
These bits select output trigger of pulse output group 2.
00: Compare match in TPU channel 0
01: Compare match in TPU channel 1
10: Compare match in TPU channel 2
11: Compare match in TPU channel 3
3
G1CMS1
1
R/W
Group 1 Compare Match Select 1 and 0
2
G1CMS0
1
R/W
These bits select output trigger of pulse output group 1.
00: Compare match in TPU channel 0
01: Compare match in TPU channel 1
10: Compare match in TPU channel 2
11: Compare match in TPU channel 3
1
G0CMS1
1
R/W
Group 0 Compare Match Select 1 and 0
0
G0CMS0
1
R/W
These bits select output trigger of pulse output group 0.
00: Compare match in TPU channel 0
01: Compare match in TPU channel 1
10: Compare match in TPU channel 2
11: Compare match in TPU channel 3
Rev. 2.00 Oct. 21, 2009 Page 785 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• PCR_1
Bit
Bit Name
Initial
Value
R/W
Description
7
G3CMS1
1
R/W
Group 7 Compare Match Select 1 and 0
6
G3CMS0
1
R/W
These bits select output trigger of pulse output group 7.
00: Compare match in TPU channel 6
01: Compare match in TPU channel 7
10: Compare match in TPU channel 8
11: Compare match in TPU channel 9
5
G2CMS1
1
R/W
Group 6 Compare Match Select 1 and 0
4
G2CMS0
1
R/W
These bits select output trigger of pulse output group 6.
00: Compare match in TPU channel 6
01: Compare match in TPU channel 7
10: Compare match in TPU channel 8
11: Compare match in TPU channel 9
3
G1CMS1
1
R/W
Group 5 Compare Match Select 1 and 0
2
G1CMS0
1
R/W
These bits select output trigger of pulse output group 5.
00: Compare match in TPU channel 6
01: Compare match in TPU channel 7
10: Compare match in TPU channel 8
11: Compare match in TPU channel 9
1
G0CMS1
1
R/W
Group 4 Compare Match Select 1 and 0
0
G0CMS0
1
R/W
These bits select output trigger of pulse output group 4.
00: Compare match in TPU channel 6
01: Compare match in TPU channel 7
10: Compare match in TPU channel 8
11: Compare match in TPU channel 9
Rev. 2.00 Oct. 21, 2009 Page 786 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.3.5
PPG Output Mode Register (PMR)
PMR selects the pulse output mode of the PPG for each group. If inverted output is selected, a
low-level pulse is output when PODRH is 1 and a high-level pulse is output when PODRH is 0. If
non-overlapping operation is selected, PPG updates its output values at compare match A or B of
the TPU that becomes the output trigger. For details, refer to section 15.4.4, Non-Overlapping
Pulse Output.
7
6
5
4
3
2
1
0
G3INV
G2INV
G1INV
G0INV
G3NOV
G2NOV
G1NOV
G0NOV
1
1
1
1
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
G3INV
1
R/W
Group 3 Inversion
Selects direct output or inverted output for pulse output
group 3.
0: Inverted output
1: Direct output
6
G2INV
1
R/W
Group 2 Inversion
Selects direct output or inverted output for pulse output
group 2.
0: Inverted output
1: Direct output
5
G1INV
1
R/W
Group 1 Inversion
Selects direct output or inverted output for pulse output
group 1.
0: Inverted output
1: Direct output
4
G0INV
1
R/W
Group 0 Inversion
Selects direct output or inverted output for pulse output
group 0.
0: Inverted output
1: Direct output
Rev. 2.00 Oct. 21, 2009 Page 787 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
Bit
Bit Name
Initial
Value
R/W
Description
3
G3NOV
0
R/W
Group 3 Non-Overlap
Selects normal or non-overlapping operation for pulse
output group 3.
0: Normal operation (output values updated at compare
match A in the selected TPU channel)
1: Non-overlapping operation (output values updated at
compare match A or B in the selected TPU channel)
2
G2NOV
0
R/W
Group 2 Non-Overlap
Selects normal or non-overlapping operation for pulse
output group 2.
0: Normal operation (output values updated at compare
match A in the selected TPU channel)
1: Non-overlapping operation (output values updated at
compare match A or B in the selected TPU channel)
1
G1NOV
0
R/W
Group 1 Non-Overlap
Selects normal or non-overlapping operation for pulse
output group 1.
0: Normal operation (output values updated at compare
match A in the selected TPU channel)
1: Non-overlapping operation (output values updated at
compare match A or B in the selected TPU channel)
0
G0NOV
0
R/W
Group 0 Non-Overlap
Selects normal or non-overlapping operation for pulse
output group 0.
0: Normal operation (output values updated at compare
match A in the selected TPU channel)
1: Non-overlapping operation (output values updated at
compare match A or B in the selected TPU channel)
Rev. 2.00 Oct. 21, 2009 Page 788 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• PMR_1
Bit
Bit Name
Initial
Value
R/W
Description
7
G3INV
1
R/W
Group 7 Inversion
Selects direct output or inverted output for pulse output
group 7.
0: Inverted output
1: Direct output
6
G2INV
1
R/W
Group 6 Inversion
Selects direct output or inverted output for pulse output
group 6.
0: Inverted output
1: Direct output
5
G1INV
1
R/W
Group 5 Inversion
Selects direct output or inverted output for pulse output
group 5.
0: Inverted output
1: Direct output
4
G0INV
1
R/W
Group 4 Inversion
Selects direct output or inverted output for pulse output
group 4.
0: Inverted output
1: Direct output
Rev. 2.00 Oct. 21, 2009 Page 789 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
Bit
Bit Name
Initial
Value
R/W
Description
3
G3NOV
0
R/W
Group 7 Non-Overlap
Selects normal or non-overlapping operation for pulse
output group 7.
0: Normal operation (output values updated by compare
match A on the selected TPU channel)
1: Non-overlapping operation (output values updated by
compare match A or B on the selected TPU channel)
2
G2NOV
0
R/W
Group 6 Non-Overlap
Selects normal or non-overlapping operation for pulse
output group 6.
0: Normal operation (output values updated by compare
match A on the selected TPU channel)
1: Non-overlapping operation (output values updated by
compare match A or B on the selected TPU channel)
1
G1NOV
0
R/W
Group 5 Non-Overlap
Selects normal or non-overlapping operation for pulse
output group 5.
0: Normal operation (output values updated by compare
match A on the selected TPU channel)
1: Non-overlapping operation (output values updated by
compare match A or B on the selected TPU channel)
0
G0NOV
0
R/W
Group 4 Non-Overlap
Selects normal or non-overlapping operation for pulse
output group 4.
0: Normal operation (output values updated by compare
match A on the selected TPU channel)
1: Non-overlapping operation (output values updated by
compare match A or B on the selected TPU channel)
Rev. 2.00 Oct. 21, 2009 Page 790 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.4
Operation
Figure 15.3 shows a schematic diagram of the PPG. PPG pulse output is enabled when the
corresponding bits in NDER are set to 1. An initial output value is determined by its
corresponding PODR initial setting. When the compare match event specified by PCR occurs, the
corresponding NDR bit contents are transferred to PODR to update the output values. Sequential
output of data of up to 16 bits is possible by writing new output data to NDR before the next
compare match.
NDER
Q
Output trigger signal
C
Q PODR D
Q NDR D
Internal data bus
Pulse output pin
Normal output/inverted output
Figure 15.3 Schematic Diagram of PPG
15.4.1
Output Timing
If pulse output is enabled, the NDR contents are transferred to PODR and output when the
specified compare match event occurs. Figure 15.4 shows the timing of these operations for the
case of normal output in groups 2 and 3, triggered by compare match A.
Pφ
N
TCNT
TGRA
N+1
N
Compare match
A signal
n
NDRH
PODRH
PO8 to PO15
m
n
m
n
Figure 15.4 Timing of Transfer and Output of NDR Contents (Example)
Rev. 2.00 Oct. 21, 2009 Page 791 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.4.2
Sample Setup Procedure for Normal Pulse Output
Figures 15.5 and 15.6 show a sample procedure for setting up normal pulse output.
• Sample Setup Procedure for PPG0
Normal PPG output
Select TGR functions
[1]
Set TGRA value
[2]
Set counting operation
[3]
Select interrupt request
[4]
Set initial output data
[5]
Enable pulse output
[6]
Select output trigger
[7]
Set next pulse
output data
[8]
Start counter
[9]
[1]
Set TIOR in TPU0 to make TGRA an
output compare register (with output
disabled).
[2]
Set the PPG output trigger cycle.
[3]
Select the counter clock source with bits
TPSC2 to TPSC0 in TCR. Select the
counter clear source with bits CCLR1 and
CCLR0.
[4]
Enable the TGIA interrupt in TIER. The
DTC or DMAC can also be set up to
transfer data to NDR.
[5]
Set the initial output values in PODR.
[6]
Set the bits in NDER for the pins to be
used for pulse output to 1.
[7]
Select the TPU compare match event to
be used as the output trigger in PCR.
[8]
Set the next pulse output values in NDR.
[9]
Set the CST bit in TSTR to 1 to start the
TCNT counter.
TPU0 setup
PPG0 setup
TPU0 setup
[10] At each TGIA interrupt, set the next
Compare match?
No
Yes
Set next pulse
output data
[10]
Figure 15.5 Setup Procedure for Normal Pulse Output (PPG0)
Rev. 2.00 Oct. 21, 2009 Page 792 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• Sample Setup Procedure for PPG1
Normal PPG output
Select TGR functions
[1]
Set TGRA value
[2]
Set counting operation
[3]
Select interrupt request
[4]
Set initial output data
[5]
[1]
Set TIOR in TPU1 to make TGRA an
output compare register (toggle output).
[2]
Set the PPG output trigger cycle.
[3]
Select the counter clock source with bits
TPSC2 to TPSC0 in TCR. Select the
counter clear source with bits CCLR1 and
CCLR0.
[4]
Enable the TGIA interrupt in TIER. The
DTC or DMAC can also be set up to
transfer data to NDR.
[5]
Set the initial output values in PODR.
[6]
Set the bits in NDER for the pins to be
used for pulse output to 1.
[7]
Select the TPU compare match event to
be used as the output trigger in PCR.
[8]
Set the next pulse output values in NDR.
[9]
Set the CST bit in TSTR to 1 to start the
TCNT counter.
TPU1 setup
Enable pulse output
[6]
Select output trigger
[7]
Set next pulse
output data
[8]
Start counter
[9]
PPG1 setup
TPU1 setup
Compare match?
[10] At each TGIA interrupt, set the next
output values in NDR.
No
Yes
Set next pulse
output data
[10]
Figure 15.6 Setup Procedure for Normal Pulse Output (PPG1)
Rev. 2.00 Oct. 21, 2009 Page 793 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.4.3
Example of Normal Pulse Output (Example of 5-Phase Pulse Output)
Figure 15.7 shows an example in which pulse output is used for cyclic 5-phase pulse output.
TCNT
TCNT value
Compare match
TGRA
H'0000
Time
80
NDRH
PODRH
00
C0
80
40
C0
60
40
20
60
30
20
10
30
18
10
08
18
88
08
80
88
C0
80
40
C0
PO15
PO14
PO13
PO12
PO11
Figure 15.7 Normal Pulse Output Example (5-Phase Pulse Output)
1. Set up TGRA in TPU which is used as the output trigger to be an output compare register. Set
a cycle in TGRA so the counter will be cleared by compare match A. Set the TGIEA bit in
TIER to 1 to enable the compare match/input capture A (TGIA) interrupt.
2. Write H'F8 to NDERH, and set bits G3CMS1, G3CMS0, G2CMS1, and G2CMS0 in PCR to
select compare match in the TPU channel set up in the previous step to be the output trigger.
Write output data H'80 in NDRH.
3. The timer counter in the TPU channel starts. When compare match A occurs, the NDRH
contents are transferred to PODRH and output. The TGIA interrupt handling routine writes the
next output data (H'C0) in NDRH.
4. 5-phase pulse output (one or two phases active at a time) can be obtained subsequently by
writing H'40, H'60, H'20, H'30, H'10, H'18, H'08, H'88... at successive TGIA interrupts.
If the DTC or DMAC is set for activation by the TGIA interrupt, pulse output can be obtained
without imposing a load on the CPU.
Rev. 2.00 Oct. 21, 2009 Page 794 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.4.4
Non-Overlapping Pulse Output
During non-overlapping operation, transfer from NDR to PODR is performed as follows:
• At compare match A, the NDR bits are always transferred to PODR.
• At compare match B, the NDR bits are transferred only if their value is 0. The NDR bits are
not transferred if their value is 1.
Figure 15.8 illustrates the non-overlapping pulse output operation.
NDER
Q
Compare match A
Compare match B
Pulse
output
pin
C
Q PODR D
Q NDR D
Internal data bus
Normal output/inverted output
Figure 15.8 Non-Overlapping Pulse Output
Therefore, 0 data can be transferred ahead of 1 data by making compare match B occur before
compare match A.
The NDR contents should not be altered during the interval from compare match B to compare
match A (the non-overlapping margin).
This can be accomplished by having the TGIA interrupt handling routine write the next data in
NDR, or by having the TGIA interrupt activate the DTC or DMAC. Note, however, that the next
data must be written before the next compare match B occurs.
Rev. 2.00 Oct. 21, 2009 Page 795 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
Figure 15.9 shows the timing of this operation.
Compare match A
Compare match B
Write to NDR
Write to NDR
NDR
PODR
0 output
0/1 output
Write to NDR
Do not write here
to NDR here
0 output 0/1 output
Do not write
to NDR here
Write to NDR
here
Figure 15.9 Non-Overlapping Operation and NDR Write Timing
Rev. 2.00 Oct. 21, 2009 Page 796 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.4.5
Sample Setup Procedure for Non-Overlapping Pulse Output
Figures 15.10 and 15.11 show a sample procedure for setting up non-overlapping pulse output.
• Sample Setup Procedure for PPG0
Non-overlapping
pulse output
Select TGR functions
[1]
Set TGR values
[2]
Set counting operation
[3]
Select interrupt request
[4]
Set initial output data
[5]
Enable pulse output
[6]
TPU0 setup
PPG0 setup
TPU0 setup
[1]
Set TIOR in TPU0 to make TGRA and
TGRB output compare registers (with
output disabled).
[2]
Set the pulse output trigger cycle in
TGRB and the non-overlapping margin
in TGRA.
[3]
Select the counter clock source with bits
TPSC2 to TPSC0 in TCR. Select the
counter clear source with bits CCLR1
and CCLR0.
[4]
Enable the TGIA interrupt in TIER. The
DTC or DMAC can also be set up to
transfer data to NDR.
[5]
Set the initial output values in PODR.
[6]
Set the bits in NDER for the pins to be
used for pulse output to 1.
[7]
Select the TPU compare match event to
be used as the pulse output trigger in
PCR.
Select output trigger
[7]
Set non-overlapping groups
[8]
Set next pulse
output data
[9]
[8]
In PMR, select the groups that will
operate in non-overlapping mode.
Start counter
[10]
[9]
Set the next pulse output values in NDR.
Compare match A?
No
[11] At each TGIA interrupt, set the next
output values in NDR.
Yes
Set next pulse
output data
[10] Set the CST bit in TSTR to 1 to start the
TCNT counter.
[11]
Figure 15.10 Setup Procedure for Non-Overlapping Pulse Output (PPG0)
Rev. 2.00 Oct. 21, 2009 Page 797 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
• Sample Setup Procedure for PPG1
Non-overlapping
pulse output
TPU1 setup
Set TIOR in TPU1 to make TGRA and
TGRB output compare registers (toggle
output).
[2]
Set the pulse output trigger cycle in
TGRB and the non-overlapping margin
in TGRA.
[3]
Select the counter clock source with bits
TPSC2 to TPSC0 in TCR. Select the
counter clear source with bits CCLR1
and CCLR0.
[4]
Enable the TGIA interrupt in TIER. The
DTC or DMAC can also be set up to
transfer data to NDR.
[5]
Set the initial output values in PODR.
[6]
Set the bits in NDER for the pins to be
used for pulse output to 1.
[7]
Select the TPU compare match event to
be used as the pulse output trigger in
PCR.
Select TGR functions
[1]
Set TGR values
[2]
Set counting operation
[3]
Select interrupt request
[4]
Set initial output data
[5]
Enable pulse output
[6]
Select output trigger
[7]
Set non-overlapping groups
[8]
Set next pulse
output data
[9]
[8]
In PMR, select the groups that will
operate in non-overlapping mode.
Start counter
[10]
[9]
Set the next pulse output values in NDR.
TPU1 setup
PPG1 setup
[1]
Compare match A?
No
[11] At each TGIA interrupt, set the next
output values in NDR.
Yes
Set next pulse
output data
[10] Set the CST bit in TSTR to 1 to start the
TCNT counter.
[11]
Figure 15.11 Setup Procedure for Non-Overlapping Pulse Output (PPG1)
Rev. 2.00 Oct. 21, 2009 Page 798 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.4.6
Example of Non-Overlapping Pulse Output (Example of 4-Phase Complementary
Non-Overlapping Pulse Output)
Figure 15.12 shows an example in which pulse output is used for 4-phase complementary nonoverlapping pulse output.
TCNT value
TGRB
TCNT
TGRA
H'0000
NDRH
PODRH
Time
65
95
00
95
59
05
65
56
41
59
95
50
56
65
14
95
05
65
Non-overlapping margin
PO15
PO14
PO13
PO12
PO11
PO10
PO9
PO8
Figure 15.12 Non-Overlapping Pulse Output Example (4-Phase Complementary)
Rev. 2.00 Oct. 21, 2009 Page 799 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
1. Set up the TPU channel to be used as the output trigger channel so that TGRA and TGRB are
output compare registers. Set the cycle in TGRB and the non-overlapping margin in TGRA,
and set the counter to be cleared by compare match B. Set the TGIEA bit in TIER to 1 to
enable the TGIA interrupt.
2. Write H'FF to NDERH, and set bits G3CMS1, G3CMS0, G2CMS1, and G2CMS0 in PCR to
select compare match in the TPU channel set up in the previous step to be the output trigger.
Set bits G3NOV and G2NOV in PMR to 1 to select non-overlapping pulse output.
Write output data H'95 to NDRH.
3. The timer counter in the TPU channel starts. When a compare match with TGRB occurs,
outputs change from 1 to 0. When a compare match with TGRA occurs, outputs change from 0
to 1 (the change from 0 to 1 is delayed by the value set in TGRA).
The TGIA interrupt handling routine writes the next output data (H'65) to NDRH.
4. 4-phase complementary non-overlapping pulse output can be obtained subsequently by writing
H'59, H'56, H'95... at successive TGIA interrupts.
If the DTC or DMAC is set for activation by a TGIA interrupt, pulse can be output without
imposing a load on the CPU.
Rev. 2.00 Oct. 21, 2009 Page 800 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.4.7
Inverted Pulse Output
If the G3INV, G2INV, G1INV, and G0INV bits in PMR are cleared to 0, values that are the
inverse of the PODR contents can be output.
Figure 15.13 shows the outputs when the G3INV and G2INV bits are cleared to 0, in addition to
the settings of figure 15.12.
TCNT value
TGRB
TCNT
TGRA
H'0000
NDRH
PODRL
Time
65
95
00
95
59
05
65
56
41
59
95
50
56
65
14
95
05
65
PO15
PO14
PO13
PO12
PO11
PO10
PO9
PO8
Figure 15.13 Inverted Pulse Output (Example)
Rev. 2.00 Oct. 21, 2009 Page 801 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.4.8
Pulse Output Triggered by Input Capture
Pulse output of PPG0 can be triggered by TPU0 input capture as well as by compare match. If
TGRA functions as an input capture register in the TPU0 channel selected by PCR, pulse output
will be triggered by the input capture signal.
Figure 15.14 shows the timing of this output.
PPG1 cannot be used to trigger pulse output by input capturer.
Pφ
TIOC pin
Input capture
signal
NDR
N
PODR
M
PO
M
N
N
Figure 15.14 Pulse Output Triggered by Input Capture (Example)
Rev. 2.00 Oct. 21, 2009 Page 802 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
15.5
Usage Notes
15.5.1
Module Stop State Function
PPG operation can be disabled or enabled using the module stop control register. The initial value
is for PPG operation to be halted. Register access is enabled by clearing the module stop state. For
details, refer to section 28, Power-Down Modes.
15.5.2
Operation of Pulse Output Pins
Pins PO0 to PO15 are also used for other peripheral functions such as the TPU. When output by
another peripheral function is enabled, the corresponding pins cannot be used for pulse output.
Note, however, that data transfer from NDR bits to PODR bits takes place, regardless of the usage
of the pins.
Pin functions should be changed only under conditions in which the output trigger event will not
occur.
15.5.3
TPU Setting when PPG1 is in Use
When using PPG1, output toggling on compare-matches must be specified in the TIOR register of
the TPU that acts as the activation source and output must be selected as the PPG1 function.
Rev. 2.00 Oct. 21, 2009 Page 803 of 1454
REJ09B0498-0200
Section 15 Programmable Pulse Generator (PPG)
Rev. 2.00 Oct. 21, 2009 Page 804 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Section 16 8-Bit Timers (TMR)
This LSI has four units (unit 0 to unit 3) of an on-chip 8-bit timer module that comprise two 8-bit
counter channels, totaling eight channels. The 8-bit timer module can be used to count external
events and also be used as a multifunction timer in a variety of applications, such as generation of
counter reset, interrupt requests, and pulse output with a desired duty cycle using a compare-match
signal with two registers.
Figures 16.1 to 16.4 show block diagrams of the 8-bit timer module (unit 0 to unit 3).
This section describes unit 0 (channels 0 and 1) and unit 2 (channels 4 and 5), both of which have
the same functions. Unit 2 and unit 3 can generate baud rate clock for SCI and have the same
functions.
16.1
Features
• Selection of seven clock sources
The counters can be driven by one of six internal clock signals (Pφ/2, Pφ/8, Pφ/32, Pφ/64,
Pφ/1024, or Pφ/8192) or an external clock input (only internal clock available in units 2 and 3:
Pφ, Pφ/2, Pφ/8, Pφ/32, Pφ/64, Pφ/1024, and Pφ/8192).
• 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. (This is
available only in unit 0 and unit 1.)
• Timer output control by a combination of two compare match signals
The timer output signal in each channel is controlled by a combination of two independent
compare match signals, enabling the timer to output pulses with a desired duty cycle or PWM
output.
• Cascading of two channels
Operation as a 16-bit timer is possible, using TMR_0 for the upper 8 bits and TMR_1 for the
lower 8 bits (16-bit count mode).
TMR_1 can be used to count TMR_0 compare matches (compare match count mode).
• Three interrupt sources
Compare match A, compare match B, and overflow interrupts can be requested independently.
(This is available only in unit 0 and unit 1.)
• Generation of trigger to start A/D converter conversion (available in unit 0 to unit 3).
• Capable of generating baud rate clock for SCI_5 and SCI_6. (This is available only in unit 2
and unit 3). For details, see section 19, Serial Communication Interface (SCI, IrDA, CRC).
• Module stop state specifiable
Rev. 2.00 Oct. 21, 2009 Page 805 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Internal clocks
Pφ/2
Pφ/8
Pφ/32
Pφ/64
Pφ/1024
Pφ/8192
Counter clock 1
Counter clock 0
External clocks
TMCI0
TMCI1
Clock select
TCORA_0
Overflow 1
Overflow 0
TMO0
TMO1
Counter clear 0
Counter clear 1
Compare match B1
Compare match B0
Comparator A_1
TCNT_0
TCNT_1
Comparator B_0
Comparator B_1
TCORB_0
TCORB_1
TCSR_0
TCSR_1
TCR_0
TCR_1
TCCR_0
TCCR_1
Channel 0
(TMR_0)
Channel 1
(TMR_1)
Control logic
TMRI0
TMRI1
A/D
conversion
start request
signal*
CMIA0
CMIA1
CMIB0
CMIB1
OVI0
OVI1
Interrupt signals
[Legend]
TCORA_0:
TCNT_0:
TCORB_0:
TCSR_0:
TCR_0:
TCCR_0:
Time constant register A_0
Timer counter_0
Time constant register B_0
Timer control/status register_0
Timer control register_0
Timer counter control register_0
TCORA_1:
TCNT_1:
TCORB_1:
TCSR_1:
TCR_1:
TCCR_1:
Time constant register A_1
Timer counter_1
Time constant register B_1
Timer control/status register_1
Timer control register_1
Timer counter control register_1
Note: * For the corresponding A/D converter channels, see section 22, A/D Converter.
Figure 16.1 Block Diagram of 8-Bit Timer Module (Unit 0)
Rev. 2.00 Oct. 21, 2009 Page 806 of 1454
REJ09B0498-0200
Internal bus
Compare match A1
Compare match A0 Comparator A_0
TCORA_1
Section 16 8-Bit Timers (TMR)
Internal clocks
Pφ/2
Pφ/8
Pφ/32
Pφ/64
Pφ/1024
Pφ/8192
Counter clock 3
Counter clock 2
External clocks
Clock select
TCORA_2
Compare match A3
Compare match A2 Comparator A_2
Overflow 3
Overflow 2
TMO2
TMO3
TMRI2
TMRI3
Counter clear 2
Counter clear 3
Compare match B3
Compare match B2
TCORA_3
Comparator A_3
TCNT_2
TCNT_3
Comparator B_2
Comparator B_3
TCORB_2
TCORB_3
TCSR_2
TCSR_3
TCR_2
TCR_3
TCCR_2
TCCR_3
Channel 2
(TMR_2)
Channel 3
(TMR_3)
Internal bus
TMCI2
TMCI3
Control logic
A/D
conversion
start request
signal*
CMIA2
CMIA3
CMIB2
CMIB3
OVI2
OVI3
Interrupt signals
[Legend]
TCORA_2: Time constant register A_2
TCORA_3: Time constant register A_3
Timer counter_2
TCNT_2:
Timer counter_3
TCNT_3:
TCORB_2: Time constant register B_2
TCORB_3: Time constant register B_3
Timer control/status register_2
TCSR_2:
Timer control/status register_3
TCSR_3:
Timer control register_2
TCR_2:
Timer control register_3
TCR_3:
Timer counter control register_2
TCCR_2:
Timer counter control register_3
TCCR_3:
Note: * For the corresponding A/D converter channels, see section 22, A/D Converter.
Figure 16.2 Block Diagram of 8-Bit Timer Module (Unit 1)
Rev. 2.00 Oct. 21, 2009 Page 807 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Internal clocks
Pφ
Pφ/2
Pφ/8
Pφ/32
Pφ/64
Pφ/1024
Pφ/8192
Counter clock 5
Counter clock 4
Clock select
TCORA_4
Overflow 5
Overflow 4
Counter clear 4
Counter clear5
Compare match B5
Compare match B4
To SCI_5
TMO4
TMO5
Comparator A_5
TCNT_4
TCNT_5
Comparator B_4
Comparator B_5
TCORB_4
TCORB_5
TCSR_4
TCSR_5
TCR_4
TCR_5
TCCR_4
TCCR_5
Channel 4
(TMR_4)
Channel 5
(TMR_5)
Control logic
A/D
conversion
start request
signal*
CMIA4
CMIB4
CMIA5
CMIB5
CMI4
CMI5
Interrupt signals
[Legend]
TCORA_4:
TCNT_4:
TCORB_4:
TCSR_4:
TCR_4:
TCCR_4:
Time constant register A_4
Timer counter_4
Time constant register B_4
Timer control/status register_4
Timer control register_4
Timer counter control register_4
TCORA_5:
TCNT_5:
TCORB_5:
TCSR_5:
TCR_5:
TCCR_5:
Time constant register A_5
Timer counter_5
Time constant register B_5
Timer control/status register_5
Timer control register_5
Timer counter control register_5
Note: * For the corresponding A/D converter channels, see section 22, A/D Converter.
Figure 16.3 Block Diagram of 8-Bit Timer Module (Unit 2)
Rev. 2.00 Oct. 21, 2009 Page 808 of 1454
REJ09B0498-0200
Internal bus
Compare match A5
Compare match A4 Comparator A_4
TCORA_5
Section 16 8-Bit Timers (TMR)
Internal clocks
Pφ
Pφ/2
Pφ/8
Pφ/32
Pφ/64
Pφ/1024
Pφ/8192
Counter clock 7
Counter clock 6
Clock select
Compare match A7
Compare match A6 Comparator A_6
Overflow 7
Overflow 6
Counter clear 6
Counter clear 7
Compare match B7
Compare match B6
To SCI_6
TMO6
TMO7
TCORA_7
Comparator A_7
TCNT_6
TCNT_7
Comparator B_6
Comparator B_7
TCORB_6
TCORB_7
TCSR_6
TCSR_7
TCR_6
TCR_7
Internal bus
TCORA_6
Control logic
A/D
conversion
start request
signal*
TCCR_6
TCCR_7
Channel 6
(TMR_6)
Channel 7
(TMR_7)
CMIA6
CMIB6
CMIA7
CMIB7
CMI6
CMI7
Interrupt signals
[Legend]
TCORA_6: Time constant register A_6
TCORA_7: Time constant register A_7
TCNT_6:
Timer counter_6
TCNT_7:
Timer counter_7
TCORB_6: Time constant register B_6
TCORB_7: Time constant register B_7
TCSR_6:
Timer control/status register_6
TCSR_7:
Timer control/status register_7
TCR_6:
Timer control register_6
TCR_7:
Timer control register_7
TCCR_6:
Timer counter control register_6
TCCR_7:
Timer counter control register_7
Note: * For the corresponding A/D converter channels, see section 22, A/D Converter.
Figure 16.4 Block Diagram of 8-Bit Timer Module (Unit 3)
Rev. 2.00 Oct. 21, 2009 Page 809 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.2
Input/Output Pins
Table 16.1 shows the pin configuration of the TMR.
Table 16.1 Pin Configuration
Unit
Channel Name
Symbol
I/O
0
0
Timer output pin
TMO0
Output Outputs compare match
Timer clock input pin
TMCI0
Input
Inputs external clock for counter
Timer reset input pin
TMRI0
Input
Inputs external reset to counter
Timer output pin
TMO1
Output Outputs compare match
Timer clock input pin
TMCI1
Input
Inputs external clock for counter
Timer reset input pin
TMRI1
Input
Inputs external reset to counter
Timer output pin
TMO2
Output Outputs compare match
Timer clock input pin
TMCI2
Input
Inputs external clock for counter
Timer reset input pin
TMRI2
Input
Inputs external reset to counter
Timer output pin
TMO3
Output Outputs compare match
Timer clock input pin
TMCI3
Input
Inputs external clock for counter
Timer reset input pin
TMRI3
Input
Inputs external reset to counter
⎯
⎯
⎯
⎯
1
1
2
3
2
4
5
3
6
7
Rev. 2.00 Oct. 21, 2009 Page 810 of 1454
REJ09B0498-0200
Function
Section 16 8-Bit Timers (TMR)
16.3
Register Descriptions
The TMR has the following registers.
Unit 0:
• Channel 0 (TMR_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 counter control register_0 (TCCR_0)
⎯ Timer control/status register_0 (TCSR_0)
• Channel 1 (TMR_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 counter control register_1 (TCCR_1)
⎯ Timer control/status register_1 (TCSR_1)
Unit 1:
• Channel 2 (TMR_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 counter control register_2 (TCCR_2)
⎯ Timer control/status register_2 (TCSR_2)
• Channel 3 (TMR_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 counter control register_3 (TCCR_3)
⎯ Timer control/status register_3 (TCSR_3)
Rev. 2.00 Oct. 21, 2009 Page 811 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Unit 2:
• Channel 4 (TMR_4):
⎯ Timer counter_4 (TCNT_4)
⎯ Time constant register A_4 (TCORA_4)
⎯ Time constant register B_4 (TCORB_4)
⎯ Timer control register_4 (TCR_4)
⎯ Timer counter control register_4 (TCCR_4)
⎯ Timer control/status register_4 (TCSR_4)
• Channel 5 (TMR_5):
⎯ Timer counter_5 (TCNT_5)
⎯ Time constant register A_5 (TCORA_5)
⎯ Time constant register B_5 (TCORB_5)
⎯ Timer control register_5 (TCR_5)
⎯ Timer counter control register_5 (TCCR_5)
⎯ Timer control/status register_5 (TCSR_5)
Unit 3:
• Channel 6 (TMR_6):
⎯ Timer counter_6 (TCNT_6)
⎯ Time constant register A_6 (TCORA_6)
⎯ Time constant register B_6 (TCORB_6)
⎯ Timer control register_6 (TCR_6)
⎯ Timer counter control register_6 (TCCR_6)
⎯ Timer control/status register_6 (TCSR_6)
• Channel 7 (TMR_7):
⎯ Timer counter_7 (TCNT_7)
⎯ Time constant register A_7 (TCORA_7)
⎯ Time constant register B_7 (TCORB_7)
⎯ Timer control register_7 (TCR_7)
⎯ Timer counter control register_7 (TCCR_7)
⎯ Timer control/status register_7 (TCSR_7)
Rev. 2.00 Oct. 21, 2009 Page 812 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.3.1
Timer Counter (TCNT)
TCNT is an 8-bit readable/writable up-counter. TCNT_0 and TCNT_1 comprise a single 16-bit
register so they can be accessed together by a word transfer instruction. Bits CKS2 to CKS0 in
TCR and bits ICKS1 and ICKS0 in TCCR are used to select a clock. TCNT can be cleared by an
external reset input signal, compare match A signal, or compare match B signal. Which signal to
be used for clearing is selected by bits CCLR1 and CCLR0 in TCR. When TCNT overflows from
H'FF to H'00, bit OVF in TCSR is set to 1. TCNT is initialized to H'00.
Bit
7
6
5
TCNT_0
4
3
2
1
0
7
6
5
TCNT_1
4
3
2
1
0
Bit Name
Initial Value
R/W
16.3.2
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Time Constant Register A (TCORA)
TCORA is an 8-bit readable/writable register. TCORA_0 and TCORA_1 comprise a single 16-bit
register so they can be accessed together by a word transfer instruction. The value in TCORA is
continually compared with the value in TCNT. When a match is detected, the corresponding
CMFA flag in TCSR is set to 1. 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 this compare
match signal (compare match A) and the settings of bits OS1 and OS0 in TCSR. TCORA is
initialized to H'FF.
Bit
TCORA_0
4
3
7
6
5
1
1
1
1
R/W
R/W
R/W
R/W
TCORA_1
4
3
2
1
0
7
6
5
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
2
1
0
1
1
1
1
R/W
R/W
R/W
R/W
Bit Name
Initial Value
R/W
Rev. 2.00 Oct. 21, 2009 Page 813 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.3.3
Time Constant Register B (TCORB)
TCORB is an 8-bit readable/writable register. TCORB_0 and TCORB_1 comprise a single 16-bit
register so they can be accessed together by a word transfer instruction. TCORB is continually
compared with the value in TCNT. When a match is detected, the corresponding CMFB flag in
TCSR is set to 1. 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 this compare match signal
(compare match B) and the settings of bits OS3 and OS2 in TCSR. TCORB is initialized to H'FF.
Bit
7
6
TCORB_0
4
3
5
2
1
0
7
6
TCORB_1
4
3
5
2
1
0
Bit Name
Initial Value
R/W
16.3.4
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Timer Control Register (TCR)
TCR selects the TCNT clock source and the condition for clearing TCNT, and enables/disables
interrupt requests.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
CMIEB
CMIEA
OVIE
CCLR1
CCLR0
CKS2
CKS1
CKS0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
CMIEB
0
R/W
Compare Match Interrupt Enable B
Selects whether CMFB interrupt requests (CMIB) are
enabled or disabled when the CMFB flag in TCSR is set
2
to 1. *
0: CMFB interrupt requests (CMIB) are disabled
1: CMFB interrupt requests (CMIB) are enabled
Rev. 2.00 Oct. 21, 2009 Page 814 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Bit
Bit Name
Initial
Value
R/W
Description
6
CMIEA
0
R/W
Compare Match Interrupt Enable A
Selects whether CMFA interrupt requests (CMIA) are
enabled or disabled when the CMFA flag in TCSR is set
2
to 1. *
0: CMFA interrupt requests (CMIA) are disabled
1: CMFA interrupt requests (CMIA) are enabled
5
OVIE
0
R/W
Timer Overflow Interrupt Enable*3
Selects whether OVF interrupt requests (OVI) are
enabled or disabled when the OVF flag in TCSR is set to
1.
0: OVF interrupt requests (OVI) are disabled
1: OVF interrupt requests (OVI) are enabled
4
CCLR1
0
R/W
Counter Clear 1 and 0*1
3
CCLR0
0
R/W
These bits select the method by which TCNT is cleared.
00: Clearing is disabled
01: Cleared by compare match A
10: Cleared by compare match B
11: Cleared at rising edge (TMRIS in TCCR is cleared to
0) of the external reset input or when the external
3
reset input is high (TMRIS in TCCR is set to 1) *
1
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 input to TCNT and count
condition. See table 16.2.
Notes: 1. To use an external reset or external clock, the DDR and ICR bits in the corresponding
pin should be set to 0 and 1, respectively. For details, see section 13, I/O Ports.
2. In unit 2 and unit 3, one interrupt signal is used for CMIEB or CMIEA. For details, see
section 16.7, Interrupt Sources.
3. Available only in unit 0 and unit 1.
Rev. 2.00 Oct. 21, 2009 Page 815 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.3.5
Timer Counter Control Register (TCCR)
TCCR selects the TCNT internal clock source and controls external reset input.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
TMRIS
⎯
ICKS1
ICKS0
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R/W
R
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7 to 4
⎯
All 0
R
Reserved
These bits are always read as 0. It should not be set to 0.
3
TMRIS
0
R/W
Timer Reset Input Select*
Selects an external reset input when the CCLR1 and
CCLR0 bits in TCR are B'11.
0: Cleared at rising edge of the external reset
1: Cleared when the external reset is high
2
⎯
0
R
1
ICKS1
0
R/W
Internal Clock Select 1 and 0
0
ICKS0
0
R/W
These bits in combination with bits CKS2 to CKS0 in TCR
select the internal clock. See table 16.2.
Reserved
This bit is always read as 0. It should not be set to 0.
Note:
*
Available only in unit 0 and unit 1. The write value should always be 0 in unit 2 and unit
3.
Rev. 2.00 Oct. 21, 2009 Page 816 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Table 16.2 Clock Input to TCNT and Count Condition (Unit 0)
TCR
TCCR
Channel
Bit 2
CKS2
Bit 1 Bit 0 Bit 1 Bit 0
CKS1 CKS0 ICKS1 ICKS0 Description
TMR_0
0
0
0
⎯
⎯
Clock input prohibited
0
0
1
0
0
Uses internal clock. Counts at rising edge of Pφ/8.
0
1
Uses internal clock. Counts at rising edge of Pφ/2.
1
0
Uses internal clock. Counts at falling edge of Pφ/8.
1
1
Uses internal clock. Counts at falling edge of Pφ/2.
0
0
Uses internal clock. Counts at rising edge of Pφ/64.
0
1
Uses internal clock. Counts at rising edge of Pφ/32.
1
0
Uses internal clock. Counts at falling edge of Pφ/64.
1
1
Uses internal clock. Counts at falling edge of Pφ/32.
0
0
Uses internal clock. Counts at rising edge of Pφ/8192.
0
1
Uses internal clock. Counts at rising edge of Pφ/1024.
1
0
Uses internal clock. Counts at falling edge of Pφ/8192.
1
1
Uses internal clock. Counts at falling edge of Pφ/1024.
⎯
⎯
Counts at TCNT_1 overflow signal* .
0
0
TMR_1
1
0
1
1
1
0
0
0
0
0
⎯
⎯
Clock input prohibited
0
0
1
0
0
Uses internal clock. Counts at rising edge of Pφ/8.
0
1
Uses internal clock. Counts at rising edge of Pφ/2.
1
0
Uses internal clock. Counts at falling edge of Pφ/8.
1
1
Uses internal clock. Counts at falling edge of Pφ/2.
0
0
Uses internal clock. Counts at rising edge of Pφ/64.
0
1
Uses internal clock. Counts at rising edge of Pφ/32.
1
0
Uses internal clock. Counts at falling edge of Pφ/64.
1
1
Uses internal clock. Counts at falling edge of Pφ/32.
0
0
Uses internal clock. Counts at rising edge of Pφ/8192.
0
1
Uses internal clock. Counts at rising edge of Pφ/1024.
1
0
Uses internal clock. Counts at falling edge of Pφ/8192.
1
1
Uses internal clock. Counts at falling edge of Pφ/1024.
0
0
All
1
1
1
0
1
1
0
0
⎯
⎯
Counts at TCNT_0 compare match A* .
1
0
1
⎯
⎯
Uses external clock. Counts at rising edge* .
1
1
0
⎯
⎯
Uses external clock. Counts at falling edge* .
1
1
1
⎯
⎯
Uses external clock. Counts at both rising and falling
2
edges* .
1
2
2
Notes: 1. If the clock input of channel 0 is the TCNT_1 overflow signal and that of channel 1 is the
TCNT_0 compare match signal, no incrementing clock is generated. Do not use this
setting.
2. To use the external clock, the DDR and ICR bits in the corresponding pin should be set
to 0 and 1, respectively. For details, see section 13, I/O Ports.
Rev. 2.00 Oct. 21, 2009 Page 817 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Table 16.3 Clock Input to TCNT and Count Condition (Unit 1)
TCR
TCCR
Channel
Bit 2
CKS2
Bit 1 Bit 0 Bit 1 Bit 0
CKS1 CKS0 ICKS1 ICKS0 Description
TMR_2
0
0
0
⎯
⎯
Clock input prohibited
0
0
1
0
0
Uses internal clock. Counts at rising edge of Pφ/8.
0
1
Uses internal clock. Counts at rising edge of Pφ/2.
1
0
Uses internal clock. Counts at falling edge of Pφ/8.
1
1
Uses internal clock. Counts at falling edge of Pφ/2.
0
0
Uses internal clock. Counts at rising edge of Pφ/64.
0
1
Uses internal clock. Counts at rising edge of Pφ/32.
1
0
Uses internal clock. Counts at falling edge of Pφ/64.
1
1
Uses internal clock. Counts at falling edge of Pφ/32.
0
0
Uses internal clock. Counts at rising edge of Pφ/8192.
0
1
Uses internal clock. Counts at rising edge of Pφ/1024.
1
0
Uses internal clock. Counts at falling edge of Pφ/8192.
1
1
Uses internal clock. Counts at falling edge of Pφ/1024.
⎯
⎯
Counts at TCNT_3 overflow signal* .
0
0
TMR_3
1
0
1
1
1
0
0
0
0
0
⎯
⎯
Clock input prohibited
0
0
1
0
0
Uses internal clock. Counts at rising edge of Pφ/8.
0
1
Uses internal clock. Counts at rising edge of Pφ/2.
1
0
Uses internal clock. Counts at falling edge of Pφ/8.
1
1
Uses internal clock. Counts at falling edge of Pφ/2.
0
0
Uses internal clock. Counts at rising edge of Pφ/64.
0
1
Uses internal clock. Counts at rising edge of Pφ/32.
1
0
Uses internal clock. Counts at falling edge of Pφ/64.
1
1
Uses internal clock. Counts at falling edge of Pφ/32.
0
0
Uses internal clock. Counts at rising edge of Pφ/8192.
0
1
Uses internal clock. Counts at rising edge of Pφ/1024.
1
0
Uses internal clock. Counts at falling edge of Pφ/8192.
1
1
Uses internal clock. Counts at falling edge of Pφ/1024.
0
0
All
1
1
1
0
1
1
0
0
⎯
⎯
Counts at TCNT_2 compare match A* .
1
0
1
⎯
⎯
Uses external clock. Counts at rising edge* .
1
1
0
⎯
⎯
Uses external clock. Counts at falling edge* .
1
1
1
⎯
⎯
Uses external clock. Counts at both rising and falling
2
edges* .
1
2
2
Notes: 1. If the clock input of channel 2 is the TCNT_3 overflow signal and that of channel 3 is the
TCNT_2 compare match signal, no incrementing clock is generated. Do not use this
setting.
2. To use the external clock, the DDR and ICR bits in the corresponding pin should be set
to 0 and 1, respectively. For details, see section 13, I/O Ports.
Rev. 2.00 Oct. 21, 2009 Page 818 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Table 16.4 Clock Input to TCNT and Count Condition (Unit 2)
TCR
TCCR
Channel
Bit 2
CKS2
Bit 1 Bit 0 Bit 1 Bit 0
CKS1 CKS0 ICKS1 ICKS0 Description
TMR_4
0
0
0
⎯
⎯
Clock input prohibited
0
0
1
0
0
Uses internal clock. Counts at rising edge of Pφ/8.
0
1
Uses internal clock. Counts at rising edge of Pφ/2.
1
0
Uses internal clock. Counts at falling edge of Pφ/8.
1
1
Uses internal clock. Counts at falling edge of Pφ/2.
0
0
Uses internal clock. Counts at rising edge of Pφ/64.
0
1
Uses internal clock. Counts at rising edge of Pφ/32.
1
0
Uses internal clock. Counts at falling edge of Pφ/64.
1
1
Uses internal clock. Counts at falling edge of Pφ/32.
0
0
Uses internal clock. Counts at rising edge of Pφ/8192.
0
1
Uses internal clock. Counts at rising edge of Pφ/1024.
1
0
Uses internal clock. Counts at rising edge of Pφ.
1
1
Uses internal clock. Counts at falling edge of Pφ/1024.
0
0
TMR_5
*
1
0
0
⎯
⎯
Counts at TCNT_5 overflow signal*.
0
0
0
⎯
⎯
Clock input prohibited
0
0
1
0
0
Uses internal clock. Counts at rising edge of Pφ/8.
0
1
Uses internal clock. Counts at rising edge of Pφ/2.
1
0
Uses internal clock. Counts at falling edge of Pφ/8.
1
1
Uses internal clock. Counts at falling edge of Pφ/2.
0
0
Uses internal clock. Counts at rising edge of Pφ/64.
0
1
Uses internal clock. Counts at rising edge of Pφ/32.
1
0
Uses internal clock. Counts at falling edge of Pφ/64.
1
1
Uses internal clock. Counts at falling edge of Pφ/32.
0
0
Uses internal clock. Counts at rising edge of Pφ/8192.
0
1
Uses internal clock. Counts at rising edge of Pφ/1024.
1
0
Uses internal clock. Counts at rising edge of Pφ.
1
1
Uses internal clock. Counts at falling edge of Pφ/1024.
0
Note:
1
0
1
0
All
1
1
1
0
1
1
0
0
⎯
⎯
Counts at TCNT_4 compare match A*.
1
0
1
⎯
⎯
Setting prohibited
1
1
0
⎯
⎯
Setting prohibited
1
1
1
⎯
⎯
Setting prohibited
If the clock input of channel 4 is the TCNT_5 overflow signal and that of channel 5 is the
TCNT_4 compare match signal, no incrementing clock is generated. Do not use this
setting.
Rev. 2.00 Oct. 21, 2009 Page 819 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Table 16.5 Clock Input to TCNT and Count Condition (Unit 3)
TCR
TCCR
Channel
Bit 2
CKS2
Bit 1 Bit 0 Bit 1 Bit 0
CKS1 CKS0 ICKS1 ICKS0 Description
TMR_6
0
0
0
⎯
⎯
Clock input prohibited
0
0
1
0
0
Uses internal clock. Counts at rising edge of Pφ/8.
0
1
Uses internal clock. Counts at rising edge of Pφ/2.
1
0
Uses internal clock. Counts at falling edge of Pφ/8.
1
1
Uses internal clock. Counts at falling edge of Pφ/2.
0
0
Uses internal clock. Counts at rising edge of Pφ/64.
0
1
Uses internal clock. Counts at rising edge of Pφ/32.
1
0
Uses internal clock. Counts at falling edge of Pφ/64.
1
1
Uses internal clock. Counts at falling edge of Pφ/32.
0
0
Uses internal clock. Counts at rising edge of Pφ/8192.
0
1
Uses internal clock. Counts at rising edge of Pφ/1024.
1
0
Uses internal clock. Counts at rising edge of Pφ.
1
1
Uses internal clock. Counts at falling edge of Pφ/1024.
0
0
TMR_7
*
1
0
0
⎯
⎯
Counts at TCNT_7 overflow signal*.
0
0
0
⎯
⎯
Clock input prohibited
0
0
1
0
0
Uses internal clock. Counts at rising edge of Pφ/8.
0
1
Uses internal clock. Counts at rising edge of Pφ/2.
1
0
Uses internal clock. Counts at falling edge of Pφ/8.
1
1
Uses internal clock. Counts at falling edge of Pφ/2.
0
0
Uses internal clock. Counts at rising edge of Pφ/64.
0
1
Uses internal clock. Counts at rising edge of Pφ/32.
1
0
Uses internal clock. Counts at falling edge of Pφ/64.
1
1
Uses internal clock. Counts at falling edge of Pφ/32.
0
0
Uses internal clock. Counts at rising edge of Pφ/8192.
0
1
Uses internal clock. Counts at rising edge of Pφ/1024.
1
0
Uses internal clock. Counts at rising edge of Pφ.
1
1
Uses internal clock. Counts at falling edge of Pφ/1024.
0
Note:
1
0
1
0
All
1
1
1
0
1
1
0
0
⎯
⎯
Counts at TCNT_6 compare match A*.
1
0
1
⎯
⎯
Setting prohibited
1
1
0
⎯
⎯
Setting prohibited
1
1
1
⎯
⎯
Setting prohibited
If the clock input of channel 6 is the TCNT_7 overflow signal and that of channel 7 is the
TCNT_6 compare match signal, no incrementing clock is generated. Do not use this
setting.
Rev. 2.00 Oct. 21, 2009 Page 820 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.3.6
Timer Control/Status Register (TCSR)
TCSR displays status flags, and controls compare match output.
• TCSR_0
Bit
Bit Name
7
6
5
4
3
2
1
0
CMFB
CMFA
OVF
ADTE
OS3
OS2
OS1
OS0
0
0
0
0
0
0
0
0
R/(W)*
R/(W)*
R/(W)*
R/W
R/W
R/W
R/W
R/W
Initial Value
R/W
• TCSR_1
7
6
5
4
3
2
1
0
CMFB
CMFA
OVF
⎯
OS3
OS2
OS1
OS0
0
0
0
1
0
0
0
0
R/(W)*
R/(W)*
R/(W)*
R
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial Value
R/W
Note: * Only 0 can be written to this bit, to clear the flag.
• TCSR_0, TCSR4
Bit
7
Bit Name
CMFB
Initial
Value
0
R/W
Description
1
R/(W)* Compare Match Flag B
[Setting condition]
•
When TCNT matches TCORB
[Clearing conditions]
•
When writing 0 after reading CMFB = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
•
When the DTC is activated by a CMIB interrupt while
the DISEL bit in MRB of the DTC is 0*3
Rev. 2.00 Oct. 21, 2009 Page 821 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Bit
6
Bit Name
CMFA
Initial
Value
0
R/W
Description
1
R/(W)* Compare Match Flag A
[Setting condition]
•
When TCNT matches TCORA
[Clearing conditions]
•
When writing 0 after reading CMFA = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
•
5
OVF
0
When the DTC is activated by a CMIA interrupt while
the DISEL bit in MRB in the DTC is 0*3
R/(W)*1 Timer Overflow Flag
[Setting condition]
When TCNT overflows from H'FF to H'00
[Clearing condition]
When writing 0 after reading OVF = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
4
ADTE
0
R/W
A/D Trigger Enable*3
Selects enabling or disabling of 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
3
OS3
0
R/W
Output Select 3 and 2*2
2
OS2
0
R/W
These bits select a method of TMO pin output when
compare match B of TCORB and TCNT occurs.
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. 2.00 Oct. 21, 2009 Page 822 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Bit
Bit Name
Initial
Value
R/W
Description
1
OS1
0
R/W
Output Select 1 and 0*2
0
OS0
0
R/W
These bits select a method of TMO pin output when
compare match A of TCORA and TCNT occurs.
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)
Notes: 1. Only 0 can be written to bits 7 to 5, to clear these flags.
2. Timer output is disabled when bits OS3 to OS0 are all 0. Timer output is 0 until the first
compare match occurs after a reset.
3. For the corresponding A/D converter channels, see section 22, A/D Converter.
• TCSR_1, TCSR_5
Bit
7
Bit Name
CMFB
Initial
Value
0
R/W
Description
1
R/(W)* Compare Match Flag B
[Setting condition]
•
When TCNT matches TCORB
[Clearing conditions]
•
When writing 0 after reading CMFB = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
•
When the DTC is activated by a CMIB interrupt while
the DISEL bit in MRB of the DTC is 0*3
Rev. 2.00 Oct. 21, 2009 Page 823 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Bit
6
Bit Name
CMFA
Initial
Value
0
R/W
Description
1
R/(W)* Compare Match Flag A
[Setting condition]
•
When TCNT matches TCORA
[Clearing conditions]
•
When writing 0 after reading CMFA = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
•
5
OVF
0
When the DTC is activated by a CMIA interrupt while
the DISEL bit in MRB of the DTC is 0*3
R/(W)*1 Timer Overflow Flag
[Setting condition]
When TCNT overflows from H'FF to H'00
[Clearing condition]
Cleared by reading OVF when OVF = 1, then writing 0 to
OVF
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
4
⎯
1
R
3
OS3
0
R/W
Output Select 3 and 2*2
2
OS2
0
R/W
These bits select a method of TMO pin output when
compare match B of TCORB and TCNT occurs.
Reserved
This bit is always read as 1 and cannot be modified.
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. 2.00 Oct. 21, 2009 Page 824 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Bit
Bit Name
Initial
Value
R/W
Description
1
OS1
0
R/W
Output Select 1 and 0*2
0
OS0
0
R/W
These bits select a method of TMO pin output when
compare match A of TCORA and TCNT occurs.
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)
Notes: 1. Only 0 can be written to bits 7 to 5, to clear these flags.
2. Timer output is disabled when bits OS3 to OS0 are all 0. Timer output is 0 until the first
compare match occurs after a reset.
3. Available only in unit 0 and unit 1.
Rev. 2.00 Oct. 21, 2009 Page 825 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.4
Operation
16.4.1
Pulse Output
Figure 16.5 shows an example of the 8-bit timer being used to generate a pulse output with a
desired duty cycle. The control bits are set as follows:
1. Clear the bit CCLR1 in TCR to 0 and set the bit CCLR0 in TCR to 1 so that TCNT is cleared
at a TCORA compare match.
2. Set the bits OS3 to OS0 in TCSR to B'0110, causing the output to change to 1 at a TCORA
compare match and to 0 at a TCORB compare match.
With these settings, the 8-bit timer provides pulses output at a cycle determined by TCORA with a
pulse width determined by TCORB. No software intervention is required. The timer output is 0
until the first compare match occurs after a reset.
TCNT
H'FF
Counter clear
TCORA
TCORB
H'00
TMO
Figure 16.5 Example of Pulse Output
Rev. 2.00 Oct. 21, 2009 Page 826 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.4.2
Reset Input
Figure 16.6 shows an example of the 8-bit timer being used to generate a pulse which is output
after a desired delay time from a TMRI input. The control bits are set as follows:
1. Set both bits CCLR1 and CCLR0 in TCR to 1 and set the TMRIS bit in TCCR to 1 so that
TCNT is cleared at the high level input of the TMRI signal.
2. In TCSR, set bits OS3 to OS0 to B'0110, causing the output to change to 1 at a TCORA
compare match and to 0 at a TCORB compare match.
With these settings, the 8-bit timer provides pulses output at a desired delay time from a TMRI
input determined by TCORA and with a pulse width determined by TCORB and TCORA.
TCORB
TCORA
TCNT
H'00
TMRI
TMO
Figure 16.6 Example of Reset Input
Rev. 2.00 Oct. 21, 2009 Page 827 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.5
Operation Timing
16.5.1
TCNT Count Timing
Figure 16.7 shows the TCNT count timing for internal clock input. Figure 16.8 shows the TCNT
count timing for external clock input. Note that the external clock pulse width must be at least 1.5
states for increment at a single edge, and at least 2.5 states for increment at both edges. The
counter will not increment correctly if the pulse width is less than these values.
Pφ
Internal clock
TCNT input
clock
TCNT
N–1
N
N+1
Figure 16.7 Count Timing for Internal Clock Input
Pφ
External clock
input pin
TCNT input
clock
TCNT
N–1
N
Figure 16.8 Count Timing for External Clock Input
Rev. 2.00 Oct. 21, 2009 Page 828 of 1454
REJ09B0498-0200
N+1
Section 16 8-Bit Timers (TMR)
16.5.2
Timing of CMFA and CMFB Setting at Compare Match
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 the TCOR and TCNT
values match, the compare match signal is not generated until the next TCNT clock input. Figure
16.9 shows this timing.
Pφ
TCNT
N
TCOR
N
N+1
Compare match
signal
CMF
Figure 16.9 Timing of CMF Setting at Compare Match
16.5.3
Timing of Timer Output at Compare Match
When a compare match signal is generated, the timer output changes as specified by the bits OS3
to OS0 in TCSR. Figure 16.10 shows the timing when the timer output is toggled by the compare
match A signal.
Pφ
Compare match A
signal
Timer output pin
Figure 16.10 Timing of Toggled Timer Output at Compare Match A
Rev. 2.00 Oct. 21, 2009 Page 829 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.5.4
Timing of Counter Clear by Compare Match
TCNT is cleared when compare match A or B occurs, depending on the settings of the bits
CCLR1 and CCLR0 in TCR. Figure 16.11 shows the timing of this operation.
Pφ
Compare match
signal
N
TCNT
H'00
Figure 16.11 Timing of Counter Clear by Compare Match
16.5.5
Timing of TCNT External Reset*
TCNT is cleared at the rising edge or high level of an external reset input, depending on the
settings of bits CCLR1 and CCLR0 in TCR. The clear pulse width must be at least 2 states. Figure
16.12 and figure 16.13 shows the timing of this operation.
Note: * Clearing by an external reset is available only in units 0 and 1.
Pφ
External reset
input pin
Clear signal
TCNT
N–1
N
H'00
Figure 16.12 Timing of Clearance by External Reset (Rising Edge)
Rev. 2.00 Oct. 21, 2009 Page 830 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Pφ
External reset
input pin
Clear signal
N–1
TCNT
N
H'00
Figure 16.13 Timing of Clearance by External Reset (High Level)
16.5.6
Timing of Overflow Flag (OVF) Setting
The OVF bit in TCSR is set to 1 when TCNT overflows (changes from H'FF to H'00). Figure
16.14 shows the timing of this operation.
Pφ
TCNT
H'FF
H'00
Overflow signal
OVF
Figure 16.14 Timing of OVF Setting
Rev. 2.00 Oct. 21, 2009 Page 831 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.6
Operation with Cascaded Connection
If the bits CKS2 to CKS0 in either TCR_0 or TCR_1 are set to B'100, the 8-bit timers of the two
channels are cascaded. With this configuration, a single 16-bit timer could be used (16-bit counter
mode) or compare matches of the 8-bit channel 0 could be counted by the timer of channel 1
(compare match count mode).
16.6.1
16-Bit Counter Mode
When the bits CKS2 to CKS0 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.
(1)
Setting of Compare Match Flags
• The CMF flag in TCSR_0 is set to 1 when a 16-bit compare match event occurs.
• The CMF flag in TCSR_1 is set to 1 when a lower 8-bit compare match event occurs.
(2)
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 compare match event
occurs. The 16-bit counter (TCNT0 and TCNT1 together) is cleared even if counter clear by
the TMRI0 pin has been set.
• The settings of the CCLR1 and CCLR0 bits in TCR_1 are ignored. The lower 8 bits cannot be
cleared independently.
(3)
Pin Output
• Control of output from the TMO0 pin by the bits OS3 to OS0 in TCSR_0 is in accordance with
the 16-bit compare match conditions.
• Control of output from the TMO1 pin by the bits OS3 to OS0 in TCSR_1 is in accordance with
the lower 8-bit compare match conditions.
16.6.2
Compare Match Count Mode
When the bits CKS2 to CKS0 in TCR_1 are set to 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 clear are in accordance with
the settings for each channel.
Rev. 2.00 Oct. 21, 2009 Page 832 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.7
Interrupt Sources
16.7.1
Interrupt Sources and DTC Activation
• Interrupt in unit 0 and unit 1
There are three interrupt sources for the 8-bit timer (TMR_0 or TMR_1): CMIA, CMIB, and OVI.
Their interrupt sources and priorities are shown in table 16.6. Each interrupt source is enabled or
disabled by the corresponding interrupt enable bit in TCR or TCSR, and independent interrupt
requests are sent for each to the interrupt controller. It is also possible to activate the DTC by
means of CMIA and CMIB interrupts (This is available in unit 0 and unit 1 only).
Table 16.6 8-Bit Timer (TMR_0 or TMR_1) Interrupt Sources (in Unit 0 and Unit 1)
Signal
Name
Name
Interrupt Source
CMIA0
CMIA0
CMIB0
Interrupt
Flag
DTC
Activation
Priority
TCORA_0 compare match CMFA
Possible
High
CMIB0
TCORB_0 compare match CMFB
Possible
OVI0
OVI0
TCNT_0 overflow
CMIA1
CMIA1
TCORA_1 compare match CMFA
Possible
CMIB1
CMIB1
TCORB_1 compare match CMFB
Possible
OVI1
OVI1
TCNT_1 overflow
Not possible Low
OVF
OVF
Not possible Low
High
• Interrupt in unit 2 and unit 3
There are two interrupt sources for the 8-bit timer (TMR_4 or TMR_5): CMIA, CMIB. The
interrupt signal is CMI only. The interrupt sources are shown in table 16.7. When enabling or
disabling is set by the interrupt enable bit in TCR or TCSR, and when either CMIA or CMIB
interrupt source is generated, CMI is sent to the interrupt controller. To verify which interrupt
source is generated, confirm by checking each flag in TCSR. No overflow-related interrupt signal
exists. DTC cannot be activated by this interrupt.
Rev. 2.00 Oct. 21, 2009 Page 833 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Table 16.7 8-Bit Timer (TMR_4 or TMR_5) Interrupt Sources (in Unit 2 and Unit 3)
Signal
Name
Name
Interrupt Source
Interrupt
Flag
DTC
Activation
Priority
CMI4
CMIA4
TCORA_4 compare match
CMFA
Not possible
⎯
CMIB4
TCORB_4 compare match
CMFB
CMIA5
TCORA_5 compare match
CMFA
Not possible
⎯
CMIB5
TCORB_5 compare match
CMFB
CMI5
16.7.2
A/D Converter Activation
The A/D converter can be activated by a compare match A for the even channels of each TMR
unit. *
If the ADTE bit in TCSR is set to 1 when the CMFA flag in TCSR is set to 1 by the occurrence of
a 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.
Note: * For the corresponding A/D converter channels, see section 22, A/D Converter.
Rev. 2.00 Oct. 21, 2009 Page 834 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.8
Usage Notes
16.8.1
Notes on Setting Cycle
If the compare match is selected for counter clear, TCNT is cleared at the last state in the cycle in
which the values of TCNT and TCOR match. TCNT updates the counter value at this last state.
Therefore, the counter frequency is obtained by the following formula.
f = φ / (N + 1 )
f: Counter frequency
φ: Operating frequency
N: TCOR value
16.8.2
Conflict between TCNT Write and Counter Clear
If a counter clear signal is generated during the T2 state of a TCNT write cycle, the clear takes
priority and the write is not performed as shown in figure 16.15.
TCNT write cycle by CPU
T1
T2
Pφ
Address
TCNT address
Internal write signal
Counter clear signal
TCNT
N
H'00
Figure 16.15 Conflict between TCNT Write and Clear
Rev. 2.00 Oct. 21, 2009 Page 835 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.8.3
Conflict between TCNT Write and Increment
If a TCNT input clock pulse is generated during the T2 state of a TCNT write cycle, the write takes
priority and the counter is not incremented as shown in figure 16.16.
TCNT write cycle by CPU
T1
T2
Pφ
Address
TCNT address
Internal write signal
TCNT input clock
TCNT
N
M
Counter write data
Figure 16.16 Conflict between TCNT Write and Increment
16.8.4
Conflict between TCOR Write and Compare Match
If a compare match event occurs during the T2 state of a TCOR write cycle, the TCOR write takes
priority and the compare match signal is inhibited as shown in figure 16.17.
TCOR write cycle by CPU
T1
T2
Pφ
Address
TCOR address
Internal write signal
TCNT
N
TCOR
N
N+1
M
TCOR write data
Compare match signal
Inhibited
Figure 16.17 Conflict between TCOR Write and Compare Match
Rev. 2.00 Oct. 21, 2009 Page 836 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.8.5
Conflict between Compare Matches A and B
If compare match events A and B occur at the same time, the 8-bit timer operates in accordance
with the priorities for the output statuses set for compare match A and compare match B, as shown
in table 16.8.
Table 16.8 Timer Output Priorities
Output Setting
Priority
Toggle output
High
1-output
0-output
No change
16.8.6
Low
Switching of Internal Clocks and TCNT Operation
TCNT may be incremented erroneously depending on when the internal clock is switched. Table
16.9 shows the relationship between the timing at which the internal clock is switched (by writing
to the bits CKS1 and CKS0) and the TCNT operation.
When the TCNT clock is generated from an internal clock, the rising or falling edge of the internal
clock pulse are always monitored. Table 16.9 assumes that the falling edge is selected. If the
signal levels of the clocks before and after switching change from high to low as shown in item 3,
the change is considered as the falling edge. Therefore, a TCNT clock pulse is generated and
TCNT is incremented. This is similar to when the rising edge is selected.
The erroneous increment of TCNT can also happen when switching between rising and falling
edges of the internal clock, and when switching between internal and external clocks.
Rev. 2.00 Oct. 21, 2009 Page 837 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Table 16.9 Switching of Internal Clock and TCNT Operation
No.
1
Timing to Change CKS1
and CKS0 Bits
TCNT Clock Operation
1
Switching from low to low*
Clock before
switchover
Clock after
switchover
TCNT input
clock
TCNT
N+1
N
CKS bits changed
2
Switching from low to high*
2
Clock before
switchover
Clock after
switchover
TCNT input
clock
TCNT
N
N+1
N+2
CKS bits changed
3
Switching from high to low*3
Clock before
switchover
Clock after
switchover
*4
TCNT input
clock
TCNT
N
N+1
N+2
CKS bits changed
4
Switching from high to high
Clock before
switchover
Clock after
switchover
TCNT input
clock
TCNT
N
N+1
N+2
CKS bits changed
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 because the change of the signal levels is considered as a falling edge;
TCNT is incremented.
Rev. 2.00 Oct. 21, 2009 Page 838 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
16.8.7
Mode Setting with Cascaded Connection
If 16-bit counter mode and compare match count mode are specified at the same time, input clocks
for TCNT_0 and TCNT_1 are not generated, and the counter stops. Do not specify 16-bit counter
mode and compare match count mode simultaneously.
16.8.8
Module Stop State Setting
Operation of the TMR can be disabled or enabled using the module stop control register. The
initial setting is for operation of the TMR to be halted. Register access is enabled by clearing the
module stop state. For details, see section 28, Power-Down Modes.
16.8.9
Interrupts in Module Stop State
If the module stop state 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 the module stop state.
Rev. 2.00 Oct. 21, 2009 Page 839 of 1454
REJ09B0498-0200
Section 16 8-Bit Timers (TMR)
Rev. 2.00 Oct. 21, 2009 Page 840 of 1454
REJ09B0498-0200
Section 17 32K Timer (TM32K)
Section 17 32K Timer (TM32K)
The 32K timer (TM32K) is a 24-bit timer. Either 8- or 24- counter operation is selectable. It
generates a 32K timer interrupt every time the interrupt period of the counter elapses. Figure 17.1
shows a block diagram of the TM32K.
17.1
Features
• A 32K timer interrupt (32KOVI) is generated at the overflow interval for the counter.
• Eight interrupt overflow cycles of 250 ms, 500 ms, 1 s, 2 s, 30 s, 60 s, approx. 22.7 days, and
approx. 45.5 days settable.
• Counter operational except in hardware standby mode or the reset state.
• Canceling software standby mode and deep software standby mode is possible.
Counter
TCNT32K1 (8 bits)
Subclock (SUBCK)
(32.768kHz)
TCNT32K2 (8 bits)
EXCKSN
TME
CKS1/0
TCNT32K3 (8 bits)
TCR32K
Bus
32KOVI
(Interrupt request
signal)
Clock divider
Internally
divided
SUBCK/32
clock
SUBCK/64
SUBCK/128
SUBCK/256
SUBCK/16384
SUBCK/32768
Bus interface
Module bus
TK32K
[Legend]
TCR32K:
Timer control register
TCNT32K 1 to 3: Timer counter
Figure 17.1 Block Diagram of TM32K
Rev. 2.00 Oct. 21, 2009 Page 841 of 1454
REJ09B0498-0200
Section 17 32K Timer (TM32K)
17.2
Register Descriptions
The TM32K has the following registers.
• Timer control register (TCR32K)
• Timer counter (TCNT32K1, TCNT32K2, TCNT32K3)
17.2.1
Timer Control Register (TCR32K)
TCR32K enables the timer, stops the subclock oscillator, and selects the clock source to be input
to TCNT32K. Change values of the bits when TME=0.
Bit
BIt Name
Initial Value
R/W
7
6
5
4
3
2
1
0
EXCKSN
⎯
TME
⎯
⎯
OSC32STP
CKS1
CKS0
1
1
0
1
1
0
0
0
R/W
R
R/W
R
R
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
1
0
EXCKSN
CKS1
CKS0
1
0
0
R/W
R/W
R/W
Extended Clock Select and Clock Select 1, 0
These bits select the internally divided clock source to be
input to TCNT32K. The interrupt cycle for SUBCK =
32.768 kHz is indicated in parentheses.
When EXCKSN = 1:
00: Clock SUBCK/32 (cycle: 250 ms)
01: Clock SUBCK/64 (cycle: 500 ms)
10: Clock SUBCK/128 (cycle: 1 s)
11: Clock SUBCK/256 (cycle: 2 s)
When EXCKSN = 0:
00: Clock SUBCK/16384 (cycle: 30 s)
01: Clock SUBCK/32768 (cycle: 60 s)
10: Clock SUBCK/16384 (cycle: approx. 22.7 days)
11: Clock SUBCK/32768 (cycle: approx. 45.5 days)
6
⎯
1
R
Reserved
This bit is always read as 1 and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 842 of 1454
REJ09B0498-0200
Section 17 32K Timer (TM32K)
Bit
Bit Name
Initial
Value
R/W
Description
5
TME
0
R/W
Timer Enable
When this bit is set to 1, TCNT32K starts counting. When
this bit is cleared, TCNT32K stops counting and is
initialized to H'00_00_00.
⎯
4, 3
All 1
R
Reserved
These bits are always read as 1 and cannot be modified.
2
OSC32STP* 0
R/W
Subclock Oscillator Stop
0
R/W
0: Starts the subclock oscillator
1: Stops the subclock oscillator
Note:
*
17.2.2
When the CK32K bit in SUBCKCR is 1, 1 cannot be written to this bit.
Timer Counter (TCNT32K1, TCNT32K2, TCNT32K3)
The timer counter is a 24-bit counter for which either 8- or 24-bit operation is selectable.
Allocation to the registers of the timer counter differs according to the setting of the EXCKSN bit
in TCR32K.
(1)
EXCKSN = 1 (Initial State)
The timer counter operates as an 8-bit counter. Only TCNT32K1 is used and TCNT32K2 and
TCNT32K3 become reserved registers. Clearing the TME bit in the timer control register
(TCR32K) initializes TCNT32K1 to H'00.
• TCNT32K1
Bit
Bit Name
7
6
5
4
3
2
1
0
TCNT7
TCNT6
TCNT5
TCNT4
TCNT3
TCNT2
TCNT1
TCNT0
Initial value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
• TCNT32K2
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Initial value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Rev. 2.00 Oct. 21, 2009 Page 843 of 1454
REJ09B0498-0200
Section 17 32K Timer (TM32K)
• TCNT32K3
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Initial value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
(2)
EXCKSN = 0 (Counter-Extended Mode)
The timer counter operates as a 24-bit counter. TCNT32K1, TCNT32K2, and TCNT32K3 are
employed for this purpose. Be sure to read from TCNT32K1 when reading the timer counter.
• TCNT32K1
Bit
Bit Name
7
6
5
4
3
2
1
0
TCNT23
TCNT22
TCNT21
TCNT20
TCNT19
TCNT18
TCNT17
TCNT16
Initial value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
7
6
5
4
3
2
1
0
• TCNT32K2
Bit
Bit Name
TCNT15
TCNT14
TCNT13
TCNT12
TCNT11
TCNT10
TCNT9
TCNT8
Initial value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
7
6
5
4
3
2
1
0
• TCNT32K3
Bit
Bit Name
TCNT7
TCNT6
TCNT5
TCNT4
TCNT3
TCNT2
TCNT1
TCNT0
Initial value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Note: A correct value cannot be read if the counter is read while the subclock oscillator is not in
operation (OSC32STP = 1).
Rev. 2.00 Oct. 21, 2009 Page 844 of 1454
REJ09B0498-0200
Section 17 32K Timer (TM32K)
17.3
Operation
17.3.1
Basic Operation
Either 8-bit or 24-bit counter operation can be selected for the timer counter.
Setting 1 to the TME bit in TCR32K starts the count-up operation.
A 32K timer interrupt (32KOVI) is generated by the interrupt cycle. Table 17.1 shows
relationships between the timer counter operations according to the setting of bits EXCKSN,
CKS1, and CKS0 in TCR32K and the interrupt cycles.
Table 17.1 Relationships between Counter Operations and 32KOVI Cycles
Division
Ratio
Setting
Selected Counter
Interrupt Cycles
Counter value
Internally
TCNT TCNT TCNT when interrupt
EXCKSN CKS1 CKS2 Divided CLK 32K1 32K2 32K3 generates
32KOVI Cycle
1
0
0
SUBCK/32
√
−
−
1
0
1
SUBCK/64
√
−
−
500 ms
1
1
0
SUBCK/128
√
−
−
1s
1
1
1
SUBCK/256
√
−
−
2s
0
0
0
SUBCK/16384 √
√
√
0
0
1
SUBCK/32768 √
√
√
0
1
0
SUBCK/16384 √
√
√
0
1
1
SUBCK/32768 √
√
√
√ : in use
TCNT32K1=H'FF
TCNT32K3=H'3B
250 ms
30 s
60 s
TCNT32K1 to 3
=H'FFF3B
Approx. 22.7
days
Approx. 45.5
days
− : not in use
Rev. 2.00 Oct. 21, 2009 Page 845 of 1454
REJ09B0498-0200
Section 17 32K Timer (TM32K)
17.3.2
EXCKSN=1 Operation
When the EXCKSN bit in TCR32K is 1, the timer counter operates as an 8-bit counter.
Every time the value in TCNT32K1 reaches H'FF, a 32KOVI interrupt is generated. By setting the
CKS1 and CKS0 bits in TCR32K, intervals of 250ms, 500ms, 1s, and 2s between interrupts are
selectable.
TCNT32K value
Overflow
H'FF
Overflow
Overflow
Overflow
H'00
Time
TME = 1
32KOVI
32KOVI
32KOVI
32KOVI
32KOVI
32KOVI: 32K timer interrupt
3 clocks of 32Kφ
Figure 17.2 Operation of 32K Timer when EXCKSN = 1
17.3.3
EXCKSN=0 Operation
When the EXCKSN bit in TCR32K is 0, the timer counter operates as a 24-bit counter. The lowerorder 8-bits are TCNT32K3, which operates as a free-running up-counter that counts from H'00 to
H'3B. The higher-order 16-bits in TCNT32K1 and TCNT32K2 act as an up-counter that counts
the number of times TCNT32K3=H'3B. Generation of the 32KOVI interrupt either for all values
with TCNT32K3=H'3B or when TCNT32K1 to TCNT32K3=H'FFFF3B can be selected by the
setting of the CKS1 bit. This setting in combination with the setting of the CKS0 bit can be used
to se the interrupt interval to 30s, 60s. approx. 22.7 days, or approx. 45.5 days
When the EXCKSN bit is 0, the CKS1 bit can be changed while the timer counter is operating
because the TME bit is 1. This allows variation of the 32KOV1 interrupt interval while the timer
counter is in operation. When the value of the CKS1 bit is from 0 to 1, the higher-order 16-bit
counter (TCNT32K1, TCNT32K2) resumes counting after being initialized to H'00_00.
Rev. 2.00 Oct. 21, 2009 Page 846 of 1454
REJ09B0498-0200
Section 17 32K Timer (TM32K)
To avert contention between initialization of the up-counter due to the changed value of the bit
and counting operation, change the CKS1 bit from 0 to 1 within the 32KOVI interrupt routine.
Timing of the operation of changing the CKS1 bit when EXCKSN=0 is shown in figure 17.3.
Note that generation of the 32KOVI interrupt will fail once if there is a conflict between the
timing with which the CKS1 bit is changed from 1 to 0 and the value of TCNT32K3 becomes
H'3B. This is shown in figure 17.4.
TCNT32K1, TCNT32K2
H'FFFF
H'0003
H'0002
H'0001
H'0002
H'0002
H'0001
H'0001
H'0000
TCNT32K3
H'3B
Time
H'00
32KOVI
TME = 1
CKS = 0
3 cycles of the SUBCK clock width
CKS1
Operate in interrupt handling routine
Figure 17.3 Operation of Changing the CKS1 bit when EXCKSN = 0
Rev. 2.00 Oct. 21, 2009 Page 847 of 1454
REJ09B0498-0200
Section 17 32K Timer (TM32K)
Subclock
(SUBCK)
Internally
divided clock
Timer conter
H'3A
H'3B
H'00
H'01
TCNT32K3 = H'3B
CKS1 setting
Internal CKS1
32KOVI
32KOVI does not generate.
Figure 17.4 Conflict between the CKS1 bit being Changed from 1 to 0 and the 32KOVI
17.4
Interrupt Source
At the interrupt interval, the 32K timer generates a 32K timer-overflow interrupt (32KOVI) that
lasts for three cycles of the subclock. Since 32KOVI is internally connected to IRQ15, the IRQ15F
bit is set to 1 when an interrupt is generated. For the IRQ15 setting, select an interrupt request
generated at the falling edge with ISCR. For details, see section 7, Interrupt Controller.
The 32K timer operates in both software-standby and deep-software standby modes. Through
generation of the 32K timer interrupt, the timer can provide the trigger for release from software
standby and deep-software-standby modes. For details, see section 28, Power-Down Modes.
Table 17.2 TM32K Interrupt Source
Name
Interrupt Source
Software Standby Deep Software
Interrupt Flag DTC Activation Mode Reset
Standby reset
32KOVI TCNT32K interrupt IRQ15F
DT32KIF
Rev. 2.00 Oct. 21, 2009 Page 848 of 1454
REJ09B0498-0200
Impossible
Possible
Impossible
Impossible
Impossible
Possible
Section 17 32K Timer (TM32K)
17.5
Usage Notes
17.5.1
Changing Values of Bits EXCKSN, CKS1, and CKS0
If bits EXCKSN, CKS1, and CKS0 in TCR32K are written to while the TM32K is operating,
errors could occur in the incrementation. The TM32K must be stopped (the TME bit is set to 0)
before the values of bits EXCKSN, CKS1, and CKS0 are changed.
Note that when the EXCKSN bit is 0, the CKS1 bit can be changed even though the TME bit is 1
(see section 17.3.3, EXCKSN=0 Operation).
17.5.2
Note on Register Initialization
TCR32K, TCNT32K1, TCNT32K2, and TCNT32K3 of the 32K timer are initialized in hardware
standby mode or in the pin reset state. A reset from the watchdog timer or deep-software-standby
reset does not initialize these registers.
17.5.3
Usage Notes on 32K Timer
• The 32K timer does not operate when the OSC32STP bit is set to 1. Always set the
OSC32STP bit to 0 when starting the 32K timer.
• When the OSC32STP bit has been changed from 1 to 0, allow enough time to ensure settling
of the oscillation by the subclock oscillator.
• Before stopping the TM32K, clear the TME bit to 0 for one clock (30 μs) or longer by the 32
subclock.
• When switching between subclock and main clock operation, wait for 500 μs or more (until
the timer counter is updated next time) before reading the timer counter.
Rev. 2.00 Oct. 21, 2009 Page 849 of 1454
REJ09B0498-0200
Section 17 32K Timer (TM32K)
Rev. 2.00 Oct. 21, 2009 Page 850 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
Section 18 Watchdog Timer (WDT)
The watchdog timer (WDT) is an 8-bit timer that outputs an overflow signal (WDTOVF) if a
system crash prevents the CPU from writing to the timer counter, thus allowing it to overflow. At
the same time, the WDT can also generate an internal reset signal.
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.
Figure 18.1 shows a block diagram of the WDT.
18.1
Features
• Selectable from eight counter input clocks
• Switchable between watchdog timer mode and interval timer mode
⎯ In watchdog timer mode
If the counter overflows, the WDT outputs WDTOVF. It is possible to select whether or
not the entire LSI is reset at the same time.
⎯ In interval timer mode
If the counter overflows, the WDT generates an interval timer interrupt (WOVI).
Rev. 2.00 Oct. 21, 2009 Page 851 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
Clock
WDTOVF
Internal reset signal*
Clock
select
Reset
control
RSTCSR
TCNT
Pφ/2
Pφ/64
Pφ/128
Pφ/512
Pφ/2048
Pφ/8192
Pφ/32768
Pφ/131072
Internal clocks
TCSR
Module bus
Bus
interface
Internal bus
Overflow
Interrupt
control
WOVI
(interrupt request
signal)
WDT
[Legend]
Timer control/status register
TCSR:
Timer counter
TCNT:
RSTCSR: Reset control/status register
Note: * An internal reset signal can be generated by the RSTCSR setting.
Figure 18.1 Block Diagram of WDT
18.2
Input/Output Pin
Table 18.1 shows the WDT pin configuration.
Table 18.1 Pin Configuration
Name
Symbol
I/O
Function
Watchdog timer overflow*
WDTOVF
Output
Outputs a counter overflow signal in
watchdog timer mode
Note:
*
In boundary scan valid mode, counter overflow signal output cannot be used.
Rev. 2.00 Oct. 21, 2009 Page 852 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
18.3
Register Descriptions
The WDT has the following three registers. To prevent accidental overwriting, TCSR, TCNT, and
RSTCSR have to be written to in a method different from normal registers. For details, see section
18.6.1, Notes on Register Access.
• Timer counter (TCNT)
• Timer control/status register (TCSR)
• Reset control/status register (RSTCSR)
18.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.
Bit
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
Initial Value
R/W
18.3.2
Timer Control/Status Register (TCSR)
TCSR selects the clock source to be input to TCNT, and the timer mode.
Bit
Bit Name
Initial Value
R/W
Note:
7
6
5
4
3
2
1
0
OVF
WT/IT
TME
⎯
⎯
CKS2
CKS1
CKS0
0
0
0
1
1
0
0
0
R/(W)*
R/W
R/W
R
R
R/W
R/W
R/W
* Only 0 can be written to this bit, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 853 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
Bit
Bit Name
Initial
Value
7
OVF
0
6
WT/IT
0
5
TME
0
4, 3
⎯
All 1
R
Reserved
These are read-only bits and cannot be modified.
2
1
0
CKS2
CKS1
CKS0
0
0
0
R/W
R/W
R/W
Clock Select 2 to 0
Select the clock source to be input to TCNT. The overflow
cycle for Pφ = 20 MHz is indicated in parentheses.
000: Clock Pφ/2 (cycle: 25.6 μs)
001: Clock Pφ/64 (cycle: 819.2 μs)
010: Clock Pφ/128 (cycle: 1.6 ms)
011: Clock Pφ/512 (cycle: 6.6 ms)
100: Clock Pφ/2048 (cycle: 26.2 ms)
101: Clock Pφ/8192 (cycle: 104.9 ms)
110: Clock Pφ/32768 (cycle: 419.4 ms)
111: Clock Pφ/131072 (cycle: 1.68 s)
Note:
*
R/W
Description
R/(W)* Overflow Flag
Indicates that TCNT has overflowed in interval timer
mode. Only 0 can be written to this bit, to clear the flag.
[Setting condition]
When TCNT overflows in interval timer mode (changes
from H'FF to H'00)
When internal reset request generation is selected in
watchdog timer mode, OVF is cleared automatically by
the internal reset.
[Clearing condition]
Cleared by reading TCSR when OVF = 1, then writing 0
to OVF
(When the CPU is used to clear this flag while the
corresponding interrupt is enabled, be sure to read the
flag after writing 0 to it.)
R/W
Timer Mode Select
Selects whether the WDT is used as a watchdog timer or
interval timer.
0: Interval timer mode
When TCNT overflows, an interval timer interrupt
(WOVI) is requested.
1: Watchdog timer mode
When TCNT overflows, the WDTOVF signal is output.
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.
Only 0 can be written to this bit, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 854 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
18.3.3
Reset Control/Status Register (RSTCSR)
RSTCSR controls the generation of the internal reset signal when TCNT overflows, and selects
the type of internal reset signal. RSTCSR is initialized to H'1F by a reset signal from the RES pin,
but not by the WDT internal reset signal caused by WDT overflows.
7
6
5
4
3
2
1
0
WOVF
RSTE
⎯
⎯
⎯
⎯
⎯
⎯
0
0
0
1
1
1
1
1
R/(W)*
R/W
R/W
R
R
R
R
R
Bit
Bit Name
Initial Value
R/W
Note: * Only 0 can be written to this bit, to clear the flag.
Bit
Bit Name
Initial
Value
R/W
7
WOVF
0
R/(W)* Watchdog Timer 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.
[Setting condition]
When TCNT overflows (changed from H'FF to H'00) in
watchdog timer mode
[Clearing condition]
Reading RSTCSR when WOVF = 1, and then writing 0 to
WOVF
6
RSTE
0
R/W
Reset Enable
Specifies whether or not this LSI is internally reset if
TCNT overflows during watchdog timer operation.
0: LSI is not reset even if TCNT overflows (Though this
LSI is not reset, TCNT and TCSR in WDT are reset)
1: LSI is reset if TCNT overflows
⎯
5
0
R/W
Reserved
Although this bit is readable/writable, reading from or
writing to this bit does not affect operation.
⎯
4 to 0
All 1
R
Reserved
These are read-only bits and cannot be modified.
Note:
*
Only 0 can be written to this bit, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 855 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
18.4
Operation
18.4.1
Watchdog Timer Mode
To use the WDT in watchdog timer mode, set both the WT/IT and TME bits in TCSR to 1.
During watchdog timer operation, if TCNT overflows without being rewritten because of a system
crash or other error, the WDTOVF signal is output. This ensures that TCNT does not overflow
while the system is operating normally. Software must prevent TCNT overflows by rewriting the
TCNT value (normally H'00 is written) before overflow occurs. This WDTOVF signal can be used
to reset the LSI internally in watchdog timer mode.
If TCNT overflows when the RSTE bit in RSTCSR is set to 1, a signal that resets this LSI
internally is generated at the same time as the WDTOVF signal. If a reset caused by a signal input
to the RES pin occurs at the same time as a reset caused by a WDT overflow, the RES pin reset
has priority and the WOVF bit in RSTCSR is cleared to 0.
The WDTOVF signal is output for 133 cycles of Pφ when RSTE = 1 in RSTCSR, and for 130
cycles of Pφ when RSTE = 0 in RSTCSR. The internal reset signal is output for 519 cycles of Pφ.
When RSTE = 1, an internal reset signal is generated. Since the system clock control register
(SCKCR) is initialized, the multiplication ratio of Pφ becomes the initial value.
When RSTE = 0, an internal reset signal is not generated. Neither SCKCR nor the multiplication
ratio of Pφ is changed.
When TCNT overflows in watchdog timer mode, the WOVF bit in RSTCSR is set to 1. If TCNT
overflows when the RSTE bit in RSTCSR is set to 1, an internal reset signal is generated for the
entire LSI.
Rev. 2.00 Oct. 21, 2009 Page 856 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
TCNT value
Overflow
H'FF
Time
H'00
WT/IT = 1
TME = 1
H'00 written
to TCNT
WOVF = 1
WDTOVF and
internal reset are
generated
WT/IT = 1 H'00 written
TME = 1 to TCNT
WDTOVF signal
133 states*2
Internal reset signal*1
519 states
Notes: 1. If TCNT overflows when the RSTE bit is set to 1, an internal reset signal is generated.
2. 130 states when the RSTE bit is cleared to 0.
Figure 18.2 Operation in Watchdog Timer Mode
Rev. 2.00 Oct. 21, 2009 Page 857 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
18.4.2
Interval Timer Mode
To use the WDT as an interval timer, set the WT/IT bit to 0 and the TME bit to 1 in TCSR.
When the WDT is used as an interval timer, an interval timer interrupt (WOVI) is generated each
time the TCNT overflows. Therefore, an interrupt can be generated at intervals.
When the TCNT overflows in interval timer mode, an interval timer interrupt (WOVI) is requested
at the same time the OVF bit in the TCSR is set to 1.
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
Figure 18.3 Operation in Interval Timer Mode
18.5
Interrupt Source
During interval timer mode operation, an overflow generates an interval timer interrupt (WOVI).
The interval timer interrupt is requested whenever the OVF flag is set to 1 in TCSR. The OVF flag
must be cleared to 0 in the interrupt handling routine.
Table 18.2 WDT Interrupt Source
Name
Interrupt Source
Interrupt Flag
DTC Activation
WOVI
TCNT overflow
OVF
Impossible
Rev. 2.00 Oct. 21, 2009 Page 858 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
18.6
Usage Notes
18.6.1
Notes on Register Access
The watchdog timer's TCNT, TCSR, and RSTCSR registers differ from other registers in being
more difficult to write to. The procedures for writing to and reading these registers are given
below.
(1)
Writing to TCNT, TCSR, and RSTCSR
TCNT and TCSR must be written to by a word transfer instruction. They cannot be written to by a
byte transfer instruction.
For writing, TCNT and TCSR are assigned to the same address. Accordingly, perform data
transfer as shown in figure 18.4. The transfer instruction writes the lower byte data to TCNT or
TCSR.
To write to RSTCSR, execute a word transfer instruction for address H'FFA6. A byte transfer
instruction cannot be used to write to RSTCSR.
The method of writing 0 to the WOVF bit in RSTCSR differs from that of writing to the RSTE bit
in RSTCSR. Perform data transfer as shown in figure 18.4.
At data transfer, the transfer instruction clears the WOVF bit to 0, but has no effect on the RSTE
bit. To write to the RSTE bit, perform data transfer as shown in figure 18.4. In this case, the
transfer instruction writes the value in bit 6 of the lower byte to the RSTE bit, but has no effect on
the WOVF bit.
TCNT write or writing to the RSTE bit in RSTCSR:
15
Address: H'FFA4 (TCNT)
H'FFA6 (RSTCSR)
8
7
H'5A
0
Write data
TCSR write:
Address: H'FFA4 (TCSR)
15
Writing 0 to the WOVF bit in RSTCSR:
15
Address: H'FFA6 (RSTCSR)
8
7
H'A5
8
H'A5
0
Write data
7
0
H'00
Figure 18.4 Writing to TCNT, TCSR, and RSTCSR
Rev. 2.00 Oct. 21, 2009 Page 859 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
(2)
Reading from TCNT, TCSR, and RSTCSR
These registers can be read from in the same way as other registers. For reading, TCSR is assigned
to address H'FFA4, TCNT to address H'FFA5, and RSTCSR to address H'FFA7.
18.6.2
Conflict between Timer Counter (TCNT) Write and Increment
If a TCNT clock pulse is generated during the T2 cycle of a TCNT write cycle, the write takes
priority and the timer counter is not incremented. Figure 18.5 shows this operation.
TCNT write cycle
T1
T2
Pφ
Address
Internal write signal
TCNT input clock
TCNT
N
M
Counter write data
Figure 18.5 Conflict between TCNT Write and Increment
18.6.3
Changing Values of Bits CKS2 to CKS0
If bits CKS2 to CKS0 in TCSR are written to while the WDT is operating, errors could occur in
the incrementation. The watchdog timer must be stopped (by clearing the TME bit to 0) before the
values of bits CKS2 to CKS0 are changed.
18.6.4
Switching between Watchdog Timer Mode and Interval Timer Mode
If the timer mode is switched from watchdog timer mode to interval timer mode while the WDT is
operating, errors could occur in the incrementation. The watchdog timer must be stopped (by
clearing the TME bit to 0) before switching the timer mode.
Rev. 2.00 Oct. 21, 2009 Page 860 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
18.6.5
Internal Reset in Watchdog Timer Mode
This LSI is not reset internally if TCNT overflows while the RSTE bit is cleared to 0 during
watchdog timer mode operation, but TCNT and TCSR of the WDT are reset.
TCNT, TCSR, and RSTCR cannot be written to while the WDTOVF signal is low. Also note that
a read of the WOVF flag is not recognized during this period. To clear the WOVF flag, therefore,
read TCSR after the WDTOVF signal goes high, then write 0 to the WOVF flag.
18.6.6
System Reset by WDTOVF Signal
If the WDTOVF signal is input to the RES pin, this LSI will not be initialized correctly. Make
sure that the WDTOVF signal is not input logically to the RES pin. To reset the entire system by
means of the WDTOVF signal, use a circuit like that shown in figure 18.6.
This LSI
Reset input
Reset signal to entire system
RES
WDTOVF
Figure 18.6 Circuit for System Reset by WDTOVF Signal (Example)
18.6.7
Transition to Watchdog Timer Mode or Software Standby Mode
When the WDT operates in watchdog timer mode, a transition to software standby mode is not
made even when the SLEEP instruction is executed when the SSBY bit in SBYCR is set to 1.
Instead, a transition to sleep mode is made.
To transit to software standby mode, the SLEEP instruction must be executed after halting the
WDT (clearing the TME bit to 0).
When the WDT operates in interval timer mode, a transition to software standby mode is made
through execution of the SLEEP instruction when the SSBY bit in SBYCR is set to 1.
Rev. 2.00 Oct. 21, 2009 Page 861 of 1454
REJ09B0498-0200
Section 18 Watchdog Timer (WDT)
Rev. 2.00 Oct. 21, 2009 Page 862 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Section 19 Serial Communication Interface
(SCI, IrDA, CRC)
This LSI has six independent serial communication interface (SCI) channels. The SCI can handle
both asynchronous and clocked synchronous serial communication. Asynchronous serial data
communication can be carried out with standard asynchronous communication chips such as a
Universal Asynchronous Receiver/Transmitter (UART) or Asynchronous Communication
Interface Adapter (ACIA). A function is also provided for serial communication between
processors (multiprocessor communication function). The SCI also supports the smart card (IC
card) interface supporting ISO/IEC 7816-3 (Identification Card) as an extended asynchronous
communication mode. SCI_5 enables transmitting and receiving IrDA communication waveform
based on the IrDA Specifications version 1.0. This LSI incorporates the on-chip CRC (Cyclic
Redundancy Check) computing unit that realizes high reliability of high-speed data transfer. Since
the CRC computing unit is not connected to SCI, operation is executed by writing data to
registers.
Figure 19.1 shows a block diagram of the SCI_0 to SCI_4. Figure 19.2 shows a block diagram of
the SCI_5 and SCI_6.
19.1
Features
• Choice of asynchronous or clocked synchronous serial communication mode
• Full-duplex communication capability
The transmitter and receiver are mutually independent, enabling transmission and reception to
be executed simultaneously. Double-buffering is used 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
The external clock can be selected as a transfer clock source (except for the smart card
interface).
• Choice of LSB-first or MSB-first transfer (except in the case of asynchronous mode 7-bit data)
• Four interrupt sources
The interrupt sources are transmit-end, transmit-data-empty, receive-data-full, and receive
error. The transmit-data-empty and receive-data-full interrupt sources can activate the DTC or
DMAC.
• Module stop state specifiable
Rev. 2.00 Oct. 21, 2009 Page 863 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Asynchronous Mode (SCI_0, 1, 2, 4, 5, and 6):
•
•
•
•
•
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
Break detection: Break can be detected by reading the RxD pin level directly in case of a
framing error
• Enables average transfer rate clock input from TMR (SCI_5, SCI_6)
• Average transfer rate generator (SCI_2)
10.667-MHz operation: 115.192 kbps or 460.784 kbps can be selected
16-MHz operation: 115.192 kbps, 460.784 kbps, or 720 kbps can be selected
32-MHz operation: 720 kbps
• Average transfer rate generator (SCI_5, SCI_6)
8-MHz operation: 460.784 kbps can be selected
10.667-MHz operation: 115.152 kbps or 460.606 kbps can be selected
12-MHz operation: 230.263 kbps or 460.526 kbps can be selected
16-MHz operation: 115.196 kbps, 460.784 kbps, 720 kbps, or 921.569 kbps can be selected
24-MHz operation: 115.132 kbps, 460.526 kbps, 720 kbps, or 921.053 kbps can be selected
32-MHz operation: 720 kbps can be selected
Clocked Synchronous Mode (SCI_0, 1, 2, and 4):
• Data length: 8 bits
• Receive error detection: Overrun errors
Smart Card Interface:
• An error signal can be automatically transmitted on detection of a parity error during reception
• Data can be automatically re-transmitted on receiving an error signal during transmission
• Both direct convention and inverse convention are supported
Rev. 2.00 Oct. 21, 2009 Page 864 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Table 19.1 lists the functions of each channel.
Table 19.1 Function List of SCI Channels
SCI_0, 1, 4
SCI_2
SCI_5, SCI_6
Clocked synchronous mode
O
O
—
Asynchronous mode
O
O
O
TMR clock input
—
—
O
Pφ = 8 MHz
—
—
460.784 kbps
Pφ = 10.667
MHz
—
460.784 kbps
460.606 kbps
115.192 kbps
115.152 kbps
Pφ = 12 MHz
—
—
460.526 kbps
When average
transfer rate
generator is used
230.263 kbps
Pφ = 16 MHz
—
720 kbps
921.569 kbps
460 784kbps
720 kbps
115.192 kbps
460.784 kbps
115.196 kbps
Pφ = 24 MHz
—
—
921.053 kbps
720 kbps
460.526 kbps
115.132 kbps
Pφ = 32 MHz
—
720 kbps
720 kbps
Rev. 2.00 Oct. 21, 2009 Page 865 of 1454
REJ09B0498-0200
Bus interface
Moduel data bus
RDR
RxD
SCMR
SSR
SCR
SMR
SEMR
TDR
RSR
TSR
BRR
Pφ
Baud rate
generator
Pφ / 4
Pφ / 16
Transmission/
reception control
TxD
Parity generation
Internal data bus
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Pφ / 64
Clock
Parity check
External clock
SCK
TEI
TXI
RXI
ERI
[Legend]
RSR:
RDR:
TSR:
TDR:
SMR:
Receive shift register
Receive data register
Transmit shift register
Transmit data register
Serial mode register
SCR:
SSR:
SCMR:
BRR:
SEMR:
Serial control register
Serial status register
Smart card mode register
Bit rate register
Serial extended mode register (available only for SCL_2)
Figure 19.1 Block Diagram of SCI_0, 1, 2, and 4
Rev. 2.00 Oct. 21, 2009 Page 866 of 1454
REJ09B0498-0200
Avarage transfer rate
generator (SCL_2)
At 10.667-MHz
operation:
115.192 kbps
460.784 kbps
At 16-MHz operation
115.192 kbps
460.784 kbps
720 kbps
At 32-MHz operation
720 kbps
Bus interface
Module data bus
RDR
SCMR
TDR
Internal data bus
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
BRR
SSR
SCR
RxD0
RSR
TSR
IrCR*
Pφ
Baud rate
generator
Pφ/4
Pφ/16
Transmission/
reception control
TxD0
Parity generation
Pφ/64
Clock
Parity check
TEI
TXI
RXI
ERI
Note: * SCL_5 only.
[Legend]
RSR:
Receive shift register
RDR: Receive data register
TSR:
Transmit shift register
TDR:
Transmit data register
SMR: Serial mode register
SCR:
Serial control register
SSR:
Serial status register
SCMR: Smart card mode register
BRR:
Bit rate register
SEMR: Serial extended mode register
IrCR:
IrDA control register (available only for SCI_5)
Average transfer rate
generator
At 8-MHz operation:
460.784 kbps
At 10.667-MHz operation:
115.152 kbps
460.606 kbps
At 12-MHz operation:
230.263 kbps
460.526 kbps
At 16-MHz operation:
115.196 kbps
460.784 kbps
720 kbps,
921.569 kbps
At 24-MHz operation:
115.132 kbps
460.526 kbps
720 kbps
921.053 kbps
At 32-MHz operation:
720 kbps
TMO4, 6
TMO5, 7
TMR
Figure 19.2 Block Diagram of SCI_5 and SCI_6
Rev. 2.00 Oct. 21, 2009 Page 867 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.2
Input/Output Pins
Table 19.2 lists the pin configuration of the SCI.
Table 19.2 Pin Configuration
Channel
Pin Name*
I/O
Function
0
SCK0
I/O
Channel 0 clock input/output
RxD0
Input
Channel 0 receive data input
TxD0
Output
Channel 0 transmit data output
SCK1
I/O
Channel 1 clock input/output
1
2
4
5
6
Note:
*
RxD1
Input
Channel 1 receive data input
TxD1
Output
Channel 1 transmit data output
SCK2
I/O
Channel 2 clock input/output
RxD2
Input
Channel 2 receive data input
TxD2
Output
Channel 2 transmit data output
SCK4
I/O
Channel 4 clock input/output
RxD4
Input
Channel 4 receive data input
TxD4
Output
Channel 4 transmit data output
RxD5/IrRxD
Input
Channel 5 receive data input
TxD5/IrTxD
Output
Channel 5 transmit data output
RxD6
Input
Channel 6 receive data input
TxD6
Output
Channel 6 transmit data output
Pin names SCK, RxD, and TxD are used in the text for all channels, omitting the
channel designation.
Rev. 2.00 Oct. 21, 2009 Page 868 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.3
Register Descriptions
The SCI has the following registers. Some bits in the serial mode register (SMR), serial status
register (SSR), and serial control register (SCR) have different functions in different
modes⎯normal serial communication interface mode and smart card interface mode; therefore,
the bits are described separately for each mode in the corresponding register sections.
Channel 0:
•
•
•
•
•
•
•
•
•
Receive shift register_0 (RSR_0)
Transmit shift register_0 (TSR_0)
Receive data register_0 (RDR_0)
Transmit data register_0 (TDR_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)
Transmit shift register_1 (TSR_1)
Receive data register_1 (RDR_1)
Transmit data register_1 (TDR_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)
Rev. 2.00 Oct. 21, 2009 Page 869 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Channel 2:
•
•
•
•
•
•
•
•
•
•
Receive shift register_2 (RSR_2)
Transmit shift register_2 (TSR_2)
Receive data register_2 (RDR_2)
Transmit data register_2 (TDR_2)
Serial mode register_2 (SMR_2)
Serial control register_2 (SCR_2)
Serial status register_2 (SSR_2)
Smart card mode register_2 (SCMR_2)
Bit rate register_2 (BRR_2)
Serial extended mode register_2 (SEMR_2)
Channel 4:
•
•
•
•
•
•
•
•
•
Receive shift register_4 (RSR_4)
Transmit shift register_4 (TSR_4)
Receive data register_4 (RDR_4)
Transmit data register_4 (TDR_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)
Channel 5:
•
•
•
•
•
•
•
•
•
•
•
Receive shift register_5 (RSR_5)
Transmit shift register_5 (TSR_5)
Receive data register_5 (RDR_5)
Transmit data register_5 (TDR_5)
Serial mode register_5 (SMR_5)
Serial control register_5 (SCR_5)
Serial status register_5 (SSR_5)
Smart card mode register_5 (SCMR_5)
Bit rate register_5 (BRR_5)
Serial extended mode register_5 (SEMR_5)
IrDA control register_5 (IrCR)
Rev. 2.00 Oct. 21, 2009 Page 870 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Channel 6:
•
•
•
•
•
•
•
•
•
•
Receive shift register_6 (RSR_6)
Transmit shift register_6 (TSR_6)
Receive data register_6 (RDR_6)
Transmit data register_6 (TDR_6)
Serial mode register_6 (SMR_6)
Serial control register_6 (SCR_6)
Serial status register_6 (SSR_6)
Smart card mode register_6 (SCMR_6)
Bit rate register_6 (BRR_6)
Serial extended mode register_6 (SEMR_6)
19.3.1
Receive Shift Register (RSR)
RSR is a shift register which is used to receive serial data input from the RxD pin and converts it
into parallel data. When one frame of data has been received, it is transferred to RDR
automatically. RSR cannot be directly accessed by the CPU.
19.3.2
Receive Data Register (RDR)
RDR is an 8-bit register that stores receive data. When the SCI has received one frame of serial
data, it transfers the received serial data from RSR to RDR where it is stored. This allows RSR to
receive the next data. Since RSR and RDR function as a double buffer in this way, continuous
receive operations can be performed. After confirming that the RDRF bit in SSR is set to 1, read
RDR only once. RDR cannot be written to by the CPU.
Bit
7
6
5
4
3
2
1
0
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit Name
Rev. 2.00 Oct. 21, 2009 Page 871 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.3.3
Transmit Data Register (TDR)
TDR is an 8-bit register that stores transmit data. When the SCI detects that TSR is empty, it
transfers the transmit data written in TDR to TSR and starts transmission. The double-buffered
structures of TDR and TSR enable continuous serial transmission. If the next transmit data has
already been written to TDR when one frame of data is transmitted, the SCI transfers the written
data to TSR to continue transmission. Although TDR can be read from or written to by the CPU at
all times, to achieve reliable serial transmission, write transmit data to TDR for only once after
confirming that the TDRE bit in SSR is set to 1.
Bit
7
6
5
4
3
2
1
0
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
Initial Value
R/W
19.3.4
Transmit Shift Register (TSR)
TSR is a shift register that transmits serial data. To perform serial data transmission, the SCI first
automatically transfers transmit data from TDR to TSR, and then sends the data to the TxD pin.
TSR cannot be directly accessed by the CPU.
19.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 bits in SMR have different functions in normal mode and smart card interface mode.
• When SMIF in SCMR = 0
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
C/A
CHR
PE
O/E
STOP
MP
CKS1
CKS0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
• When SMIF in SCMR = 1
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
GM
BLK
PE
O/E
BCP1
BCP0
CKS1
CKS0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 872 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit Functions in Normal Serial Communication Interface Mode (When SMIF in SCMR = 0):
Bit
Bit Name
Initial
Value
R/W
Description
7
C/A
0
R/W
Communication Mode
0: Asynchronous mode
1: Clocked synchronous mode*
6
CHR
0
R/W
Character Length (valid 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) in 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 (valid 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 (valid only when the PE bit is 1 in
asynchronous mode)
0: Selects even parity.
1: Selects odd parity.
3
STOP
0
R/W
Stop Bit Length (valid 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 frame.
2
MP
0
R/W
Multiprocessor Mode (valid only in asynchronous mode)
When this bit is set to 1, the multiprocessor function is
enabled. The PE bit and O/E bit settings are invalid in
multiprocessor mode.
Rev. 2.00 Oct. 21, 2009 Page 873 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
1
CKS1
0
R/W
Clock Select 1, 0
0
CKS0
0
R/W
These bits select the clock source for the baud rate
generator.
00: Pφ clock (n = 0)
01: Pφ/4 clock (n = 1)
10: Pφ/16 clock (n = 2)
11: Pφ/64 clock (n = 3)
For the relation between the settings of these bits and the
baud rate, see section 19.3.9, Bit Rate Register (BRR). n
is the decimal display of the value of n in BRR (see
section 19.3.9, Bit Rate Register (BRR)).
Note:
*
Available in SCI_0, 1, 2, and 4 only. Setting is prohibited in SCI_5 and SCI_6.
Bit Functions in Smart Card Interface Mode (When SMIF in SCMR = 1):
Bit
Bit Name
Initial
Value
R/W
Description
7
GM
0
R/W
GSM 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 sections 19.7.6, Data
Transmission (Except in Block Transfer Mode) and
19.7.8, Clock Output Control (Only SCI_0, 1, 2, and 4).
6
BLK
0
R/W
Setting this bit to 1 allows block transfer mode operation.
For details, see section 19.7.3, Block Transfer Mode.
5
PE
0
R/W
Parity Enable (valid 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. Set this bit to 1 in smart card interface mode.
4
O/E
0
R/W
Parity Mode (valid only when the PE bit is 1 in
asynchronous mode)
0: Selects even parity
1: Selects odd parity
For details on the usage of this bit in smart card interface
mode, see section 19.7.2, Data Format (Except in Block
Transfer Mode).
Rev. 2.00 Oct. 21, 2009 Page 874 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
3
BCP1
0
R/W
Base clock Pulse 1, 0
2
BCP0
0
R/W
These bits select the number of base clock cycles in a 1bit data transfer time in smart card interface mode.
00: 32 clock cycles (S = 32)
01: 64 clock cycles (S = 64)
10: 372 clock cycles (S = 372)
11: 256 clock cycles (S = 256)
For details, see section 19.7.4, Receive Data Sampling
Timing and Reception Margin. S is described in section
19.3.9, Bit Rate Register (BRR).
1
CKS1
0
R/W
Clock Select 1, 0
0
CKS0
0
R/W
These bits select the clock source for the baud rate
generator.
00: Pφ clock (n = 0)
01: Pφ/4 clock (n = 1)
10: Pφ/16 clock (n = 2)
11: Pφ/64 clock (n = 3)
For the relation between the settings of these bits and the
baud rate, see section 19.3.9, Bit Rate Register (BRR). n
is the decimal display of the value of n in BRR (see
section 19.3.9, Bit Rate Register (BRR)).
Note:
etu (Elementary Time Unit): 1-bit transfer time
Rev. 2.00 Oct. 21, 2009 Page 875 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.3.6
Serial Control Register (SCR)
SCR is a register that enables/disables the following SCI transfer operations and interrupt requests,
and selects the transfer clock source. For details on interrupt requests, see section 19.9, Interrupt
Sources. Some bits in SCR have different functions in normal mode and smart card interface
mode.
• When SMIF in SCMR = 0
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
• When SMIF in SCMR = 1
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Functions in Normal Serial Communication Interface Mode (When SMIF in SCMR = 0):
Bit
Bit Name
Initial
Value
R/W
Description
7
TIE
0
R/W
Transmit Interrupt Enable
When this bit is set to 1, a TXI interrupt request is
enabled.
A TXI interrupt request can be cancelled by reading 1
from the TDRE flag and then clearing the flag to 0, or by
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 requests can be cancelled by
reading 1 from the RDRF, FER, PER, or ORER flag and
then clearing the flag to 0, or by clearing the RIE bit to 0.
Rev. 2.00 Oct. 21, 2009 Page 876 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
5
TE
0
R/W
Transmit Enable
When this bit is set to 1, transmission is enabled. Under
this condition, serial transmission is started by writing
transmit data to TDR, and clearing the TDRE flag in SSR
to 0. Note that SMR should be set prior to setting the TE
bit to 1 in order to designate the transmission format.
If transmission is halted by clearing this bit to 0, the
TDRE flag in SSR is fixed to 1.
4
RE
0
R/W
Receive Enable
When this bit is set to 1, reception is enabled. Under this
condition, serial reception is started by detecting the start
bit in asynchronous mode or the synchronous clock input
in clocked synchronous mode. Note that SMR should be
set prior to setting the RE bit to 1 in order to designate
the reception format.
Even if reception is halted by clearing this bit to 0, the
RDRF, FER, PER, and ORER flags are not affected and
the previous value is retained.
3
MPIE
0
R/W
Multiprocessor Interrupt Enable (valid 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 disabled.
On receiving data in which the multiprocessor bit is 1, this
bit is automatically cleared and normal reception is
resumed. For details, see section 19.5, Multiprocessor
Communication Function.
When receive data including MPB = 0 in SSR is being
received, transfer of the received data from RSR to RDR,
detection of reception errors, and the settings of RDRF,
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 automatically cleared to
0, and RXI and ERI interrupt requests (in the case where
the TIE and RIE bits in SCR are set to 1) and setting of
the FER and ORER flags are enabled.
Rev. 2.00 Oct. 21, 2009 Page 877 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
2
TEIE
0
R/W
Transmit End Interrupt Enable
When this bit is set to 1, a TEI interrupt request is
enabled. A TEI interrupt request can be cancelled by
reading 1 from the TDRE flag and then clearing the flag
to 0 in order to clear the TEND flag to 0, or by clearing
the TEIE bit to 0.
1
CKE1
0
R/W
Clock Enable 1, 0 (for SCI_0, 1, and 4)
0
CKE0
0
R/W
These bits select the clock source and SCK pin function.
•
Asynchronous mode
00: On-chip baud rate generator
The SCK pin functions as I/O port.
01: On-chip baud rate generator
The clock with the same frequency as the bit rate is
output from the SCK pin.
1X: External clock
The clock with a frequency 16 times the bit rate
should be input from the SCK pin.
•
Clocked synchronous mode
0X: Internal clock
The SCK pin functions as the clock output pin.
1X: External clock
The SCK pin functions as the clock input pin.
Rev. 2.00 Oct. 21, 2009 Page 878 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
1
CKE1
0
R/W
Clock Enable 1, 0 (for SCI_2)
0
CKE0
0
R/W
These bits select the clock source and SCK pin function.
•
Asynchronous mode
00: On-chip baud rate generator
The SCK pin functions as I/O port.
01: On-chip baud rate generator
The clock with the same frequency as the bit rate is
output from the SCK pin.
1X: External clock or average transfer rate generator
When an external clock is used, the clock with a
frequency 16 times the bit rate should be input from
the SCK pin.
When an average transfer rate generator is used.
•
Clocked synchronous mode
0X: Internal clock
The SCK pin functions as the clock output pin.
1X: External clock
The SCK pin functions as the clock input pin.
1
CKE1
0
R/W
Clock Enable 1, 0 (for SCI_5 and SCI_6)
0
CKE0
0
R/W
These bits select the clock source.
•
Asynchronous mode
00: On-chip baud rate generator
1X: TMR clock input or average transfer rate generator
When an average transfer rate generator is used.
When TMR clock input is used.
•
Clocked synchronous mode
Not available
[Legend]
X:
Don't care
Rev. 2.00 Oct. 21, 2009 Page 879 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit Functions in Smart Card Interface Mode (When SMIF in SCMR = 1):
Bit
Bit Name
Initial
Value
R/W
Description
7
TIE
0
R/W
Transmit Interrupt Enable
When this bit is set to 1,a TXI interrupt request is
enabled.
A TXI interrupt request can be cancelled by reading 1
from the TDRE flag and then clearing the flag to 0, or by
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 requests can be cancelled by
reading 1 from the RDRF, FER, PER, or ORER flag and
then clearing the flag to 0, or by clearing the RIE bit to 0.
5
TE
0
R/W
Transmit Enable
When this bit is set to 1, transmission is enabled. Under
this condition, serial transmission is started by writing
transmit data to TDR, and clearing the TDRE flag in SSR
to 0. Note that SMR should be set prior to setting the TE
bit to 1 in order to designate the transmission format.
If transmission is halted by clearing this bit to 0, the
TDRE flag in SSR is fixed 1.
4
RE
0
R/W
Receive Enable
When this bit is set to 1, reception is enabled. Under this
condition, serial reception is started by detecting the start
bit in asynchronous mode or the synchronous clock input
in clocked synchronous mode. Note that SMR should be
set prior to setting the RE bit to 1 in order to designate
the reception format.
Even if reception is halted by clearing this bit to 0, the
RDRF, FER, PER, and ORER flags are not affected and
the previous value is retained.
3
MPIE
0
R/W
Multiprocessor Interrupt Enable (valid only when the MP
bit in SMR is 1 in asynchronous mode)
Write 0 to this bit in smart card interface mode.
2
TEIE
0
R/W
Transmit End Interrupt Enable
Write 0 to this bit in smart card interface mode.
Rev. 2.00 Oct. 21, 2009 Page 880 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
1
CKE1
0
R/W
Clock Enable 1, 0*
0
CKE0
0
R/W
These bits control the clock output from the SCK pin. In
GSM mode, clock output can be dynamically switched.
For details, see section 19.7.8, Clock Output Control
(Only SCI_0, 1, 2, and 4).
•
When GM in SMR = 0
00: Output disabled (SCK pin functions as I/O port.) *
01: Clock output
1X: Reserved
•
When GM in SMR = 1
00: Output fixed low
01: Clock output
10: Output fixed high
11: Clock output
Note:
No SCK pins exist in SCI_5 and SCI_6.
*
19.3.7
Serial Status Register (SSR)
SSR is a register containing status flags of the SCI and multiprocessor bits for transfer. TDRE,
RDRF, ORER, PER, and FER can only be cleared. Some bits in SSR have different functions in
normal mode and smart card interface mode.
• When SMIF in SCMR = 0
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
TDRE
RDRF
ORER
FER
PER
TEND
MPB
MPBT
1
0
0
0
0
1
0
0
R/(W)*
R/(W)*
R/(W)*
R/(W)*
R/(W)*
R
R
R/W
Note: * Only 0 can be written, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 881 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
• When SMIF in SCMR = 1
7
6
5
4
3
2
1
0
TDRE
RDRF
ORER
ERS
PER
TEND
MPB
MPBT
1
0
0
0
0
1
0
0
R/(W)*
R/(W)*
R/(W)*
R/(W)*
R/(W)*
R
R
R/W
Bit
Bit Name
Initial Value
R/W
Note: * Only 0 can be written, to clear the flag.
Bit Functions in Normal Serial Communication Interface Mode (When SMIF in SCMR = 0):
Bit
Bit Name
Initial
Value
R/W
7
TDRE
1
R/(W)* Transmit Data Register Empty
Description
Indicates whether TDR contains transmit data.
[Setting conditions]
•
When the TE bit in SCR is 0
•
When data is transferred from TDR to TSR
[Clearing conditions]
•
When 0 is written to TDRE after reading TDRE = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
•
Rev. 2.00 Oct. 21, 2009 Page 882 of 1454
REJ09B0498-0200
When a TXI interrupt request is issued allowing
DMAC or DTC to write data to TDR
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
6
RDRF
0
R/(W)* Receive Data Register Full
Description
Indicates whether receive 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 CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
•
When an RXI interrupt request is issued allowing
DMAC or DTC to read data from RDR
The RDRF flag is not affected and retains its previous
value when the RE bit in SCR is cleared to 0.
Note that when the next serial reception is completed
while the RDRF flag is being set to 1, an overrun error
occurs and the received data is lost.
5
ORER
0
R/(W)* Overrun Error
Indicates that an overrun error has occurred during
reception and the reception ends abnormally.
[Setting condition]
•
When the next serial reception is completed while
RDRF = 1
In RDR, receive data prior to an overrun error
occurrence is retained, but data received after the
overrun error occurrence is lost. When the ORER flag
is set to 1, subsequent serial reception cannot be
performed. Note that, in clocked synchronous mode,
serial transmission also cannot continue.
[Clearing condition]
•
When 0 is written to ORER after reading ORER = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
Even when the RE bit in SCR is cleared, the ORER
flag is not affected and retains its previous value.
Rev. 2.00 Oct. 21, 2009 Page 883 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
4
FER
0
R/(W)* Framing Error
Description
Indicates that a framing error has occurred during
reception in asynchronous mode and the reception ends
abnormally.
[Setting condition]
•
When the stop bit is 0
In 2-stop-bit mode, only the first stop bit is checked
whether it is 1 but the second stop bit is not checked.
Note that receive data when the framing error occurs
is transferred to RDR, however, the RDRF flag is not
set. In addition, when the FER flag is being set to 1,
the subsequent serial reception cannot be performed.
In clocked synchronous mode, serial transmission
also cannot continue.
[Clearing condition]
•
When 0 is written to FER after reading FER = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
Even when the RE bit in SCR is cleared, the FER flag
is not affected and retains its previous value.
Rev. 2.00 Oct. 21, 2009 Page 884 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
3
PER
0
R/(W)* Parity Error
Description
Indicates that a parity error has occurred during reception
in asynchronous mode and the reception ends
abnormally.
[Setting condition]
•
When a parity error is detected during reception
Receive data when the parity error occurs is
transferred to RDR, however, the RDRF flag is not
set. Note that when the PER flag is being set to 1, the
subsequent serial reception cannot be performed. In
clocked synchronous mode, serial transmission also
cannot continue.
[Clearing condition]
•
When 0 is written to PER after reading PER = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
Even when the RE bit in SCR is cleared, the PER bit
is not affected and retains its previous value.
2
TEND
1
R
Transmit End
[Setting conditions]
•
When the TE bit in SCR is 0
•
When TDRE = 1 at transmission of the last bit of a
transmit character
[Clearing conditions]
1
MPB
0
R
•
When 0 is written to TDRE after reading TDRE = 1
•
When a TXI interrupt request is issued allowing
DMAC or DTC to write data to TDR
Multiprocessor Bit
Stores the multiprocessor bit value in the receive frame.
When the RE bit in SCR is cleared to 0 its previous state
is retained.
0
MPBT
0
R/W
Multiprocessor Bit Transfer
Sets the multiprocessor bit value to be added to the
transmit frame.
Note:
*
Only 0 can be written, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 885 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit Functions in Smart Card Interface Mode (When SMIF in SCMR = 1):
Bit
Bit Name
Initial
Value
R/W
7
TDRE
1
R/(W)* Transmit Data Register Empty
Description
Indicates whether TDR contains transmit data.
[Setting conditions]
•
When the TE bit in SCR is 0
•
When data is transferred from TDR to TSR
[Clearing conditions]
•
When 0 is written to TDRE after reading TDRE = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
•
6
RDRF
0
When a TXI interrupt request is issued allowing
DMAC or DTC to write data to TDR
R/(W)* Receive Data Register Full
Indicates whether receive 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 CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
•
When an RXI interrupt request is issued allowing
DMAC or DTC to read data from RDR
The RDRF flag is not affected and retains its previous
value even when the RE bit in SCR is cleared to 0.
Note that when the next reception is completed while the
RDRF flag is being set to 1, an overrun error occurs and
the received data is lost.
Rev. 2.00 Oct. 21, 2009 Page 886 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
5
ORER
0
R/(W)* Overrun Error
Description
Indicates that an overrun error has occurred during
reception and the reception ends abnormally.
[Setting condition]
•
When the next serial reception is completed while
RDRF = 1
In RDR, the receive data prior to an overrun error
occurrence is retained, but data received following the
overrun error occurrence is lost. When the ORER flag
is set to 1, subsequent serial reception cannot be
performed. Note that, in clocked synchronous mode,
serial transmission also cannot continue.
[Clearing condition]
•
When 0 is written to ORER after reading ORER = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
Even when the RE bit in SCR is cleared, the ORER
flag is not affected and retains its previous value.
4
ERS
0
R/(W)* Error Signal Status
[Setting condition]
•
When a low error signal is sampled
[Clearing condition]
•
When 0 is written to ERS after reading ERS = 1
Rev. 2.00 Oct. 21, 2009 Page 887 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
3
PER
0
R/(W)* Parity Error
Description
Indicates that a parity error has occurred during reception
in asynchronous mode and the reception ends
abnormally.
[Setting condition]
•
When a parity error is detected during reception
Receive data when the parity error occurs is
transferred to RDR, however, the RDRF flag is not
set. Note that when the PER flag is being set to 1, the
subsequent serial reception cannot be performed. In
clocked synchronous mode, serial transmission also
cannot continue.
[Clearing condition]
•
When 0 is written to PER after reading PER = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
Even when the RE bit in SCR is cleared, the PER flag
is not affected and retains its previous value.
Rev. 2.00 Oct. 21, 2009 Page 888 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
2
TEND
1
R
Transmit End
This bit is set to 1 when no error signal is sent from the
receiving side and the next transmit data is ready to be
transferred to TDR.
[Setting conditions]
•
When both the TE and ERS bits in SCR are 0
•
When ERS = 0 and TDRE = 1 after a specified time
passed after completion of 1-byte data transfer. The
set timing depends on the register setting as follows:
When GM = 0 and BLK = 0, 2.5 etu after transmission
start
When GM = 0 and BLK = 1, 1.5 etu after transmission
start
When GM = 1 and BLK = 0, 1.0 etu after transmission
start
When GM = 1 and BLK = 1, 1.0 etu after transmission
start
[Clearing conditions]
1
MPB
0
R
•
When 0 is written to TEND after reading TEND = 1
•
When a TXI interrupt request is issued allowing
DMAC or DTC to write the next data to TDR
Multiprocessor Bit
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.
Note:
*
Only 0 can be written, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 889 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.3.8
Smart Card Mode Register (SCMR)
SCMR selects smart card interface mode and its format.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
SDIR
SINV
⎯
SMIF
Initial Value
1
1
1
1
0
0
1
0
R/W
⎯
⎯
⎯
⎯
R/W
R/W
⎯
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7 to 4
⎯
All 1
⎯
Reserved
These bits are always read as 1.
3
SDIR
0
R/W
Smart Card Data Transfer Direction
Selects the serial/parallel conversion format.
0: Transfer with LSB-first
1: Transfer with MSB-first
This bit is valid only when the 8-bit data format is used for
transmission/reception; when the 7-bit data format is
used, data is always transmitted/received with LSB-first.
2
SINV
0
R/W
Smart Card Data Invert
Inverts the transmit/receive data logic level. This 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.
0
SMIF
0
R/W
Smart Card Interface Mode Select
When this bit is set to 1, smart card interface mode is
selected.
0: Normal asynchronous or clocked synchronous mode
1: Smart card interface mode
Rev. 2.00 Oct. 21, 2009 Page 890 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.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 19.3 shows
the relationships between the N setting in BRR and bit rate B for normal asynchronous mode and
clocked synchronous mode, and smart card interface mode. The initial value of BRR is H'FF, and
it can be read from or written to by the CPU at all times.
Table 19.3 Relationships between N Setting in BRR and Bit Rate B
Mode
ABCS Bit Bit Rate
Asynchronous
mode
0
N=
Pφ × 106
64 × 2
1
N=
N=
N=
2n – 1
2n + 1
Pφ × 106
Error (%) = {
B × 64 × 2
−1
×B
2n – 1
– 1 } × 100
× (N + 1)
Pφ × 106
Error (%) = {
B × 32 × 2
2n – 1
– 1 } × 100
× (N + 1)
−1
×B
Pφ × 106
S×2
[Legend]
B:
N:
Pφ:
n and S:
2n – 1
−1
×B
Pφ × 106
8×2
Smart card interface mode
2n – 1
Pφ × 106
32 × 2
Clocked synchronous mode
Error
−1
×B
Pφ × 106
Error (%) = {
B×S×2
2n + 1
– 1 } × 100
× (N + 1)
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 table.
SMR Setting
SMR Setting
CKS1
CKS0
n
BCP1
BCP0
S
0
0
0
0
0
32
0
1
1
0
1
64
1
0
2
1
0
372
1
1
3
1
1
256
Rev. 2.00 Oct. 21, 2009 Page 891 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Table 19.4 shows sample N settings in BRR in normal asynchronous mode. Table 19.5 shows the
maximum bit rate settable for each operating frequency. Tables 19.7 and 19.9 show sample N
settings in BRR in clocked synchronous mode and smart card interface mode, respectively. In
smart card interface mode, the number of base clock cycles S in a 1-bit data transfer time can be
selected. For details, see section 19.7.4, Receive Data Sampling Timing and Reception Margin.
Tables 19.6 and 19.8 show the maximum bit rates with external clock input.
When the ABCS bit in the serial extended mode register_2, 5, and 6 (SEMR_2, 5, and 6) of
SCI_2, 5, and 6 are set to 1 in asynchronous mode, the bit rate is two times that of shown in table
19.4.
Table 19.4 Examples of BRR Settings for Various Bit Rates (Asynchronous Mode) (1)
Operating Frequency Pφ (MHz)
8
9.8304
10
12
Bit Rate
(bit/s)
n
N
Error
(%)
n
N
Error
(%)
110
2
141
0.03
2
174
–0.26
2
177
–0.25
2
212
0.03
150
2
103
0.16
2
127
0.00
2
129
0.16
2
155
0.16
300
1
207
0.16
1
255
0.00
2
64
0.16
2
77
0.16
600
1
103
0.16
1
127
0.00
1
129
0.16
1
155
0.16
1200
0
207
0.16
0
255
0.00
1
64
0.16
1
77
0.16
2400
0
103
0.16
0
127
0.00
0
129
0.16
0
155
0.16
4800
0
51
0.16
0
63
0.00
0
64
0.16
0
77
0.16
9600
0
25
0.16
0
31
0.00
0
32
–1.36
0
38
0.16
19200
0
12
0.16
0
15
0.00
0
15
1.73
0
19
–2.34
31250
0
7
0.00
0
9
–1.70
0
9
0.00
0
11
0.00
38400
⎯
⎯
⎯
0
7
0.00
0
7
1.73
0
9
–2.34
Rev. 2.00 Oct. 21, 2009 Page 892 of 1454
REJ09B0498-0200
n
N
Error
(%)
n
N
Error
(%)
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Operating Frequency Pφ (MHz)
12.288
14
14.7456
Error
(%)
16
Error
(%)
Bit Rate
(bit/s)
n
N
Error
(%)
n
N
Error
(%)
110
2
217
0.08
2
248
–0.17
3
64
0.70
3
70
0.03
150
2
159
0.00
2
181
0.16
2
191
0.00
2
207
0.16
300
2
79
0.00
2
90
0.16
2
95
0.00
2
103
0.16
600
1
159
0.00
1
181
0.16
1
191
0.00
1
207
0.16
1200
1
79
0.00
1
90
0.16
1
95
0.00
1
103
0.16
2400
0
159
0.00
0
181
0.16
0
191
0.00
0
207
0.16
4800
0
79
0.00
0
90
0.16
0
95
0.00
0
103
0.16
9600
0
39
0.00
0
45
–0.93
0
47
0.00
0
51
0.16
19200
0
19
0.00
0
22
–0.93
0
23
0.00
0
25
0.16
31250
0
11
2.40
0
13
0.00
0
14
–1.70
0
15
0.00
38400
0
9
0.00
⎯
⎯
⎯
0
11
0.00
0
12
0.16
n
N
n
N
Note: In SCI_2, 5, and 6, this is an example when the ABCS bit in SEMR_2, 5, and 6 is 0.
When the ABCS bit is set to 1, the bit rate is two times.
Table 19.4 Examples of BRR Settings for Various Bit Rates (Asynchronous Mode) (2)
Operating Frequency Pφ (MHz)
17.2032
18
19.6608
20
Bit Rate
(bit/s)
n
N
Error
(%)
n
N
Error
(%)
n
N
Error
(%)
n
N
Error
(%)
110
3
75
0.48
3
79
–0.12
3
86
0.31
3
88
–0.25
150
2
223
0.00
2
233
0.16
2
255
0.00
3
64
0.16
300
2
111
0.00
2
116
0.16
2
127
0.00
2
129
0.16
600
1
223
0.00
1
233
0.16
1
255
0.00
2
64
0.16
1200
1
111
0.00
1
116
0.16
1
127
0.00
1
129
0.16
2400
0
223
0.00
0
233
0.16
0
255
0.00
1
64
0.16
4800
0
111
0.00
0
116
0.16
0
127
0.00
0
129
0.16
9600
0
55
0.00
0
58
–0.69
0
63
0.00
0
64
0.16
19200
0
27
0.00
0
28
1.02
0
31
0.00
0
32
–1.36
31250
0
16
1.20
0
17
0.00
0
19
–1.70
0
19
0.00
38400
0
13
0.00
0
14
–2.34
0
15
0.00
0
15
1.73
Rev. 2.00 Oct. 21, 2009 Page 893 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Operating Frequency Pφ (MHz)
25
30
33
35
Bit Rate
(bit/s)
n
N
Error
(%)
n
N
Error
(%)
n
N
Error
(%)
n
N
Error
(%)
110
3
110
–0.02
3
132
0.13
3
145
0.33
3
154
0.23
150
3
80
0.47
3
97
–0.35
3
106
0.39
3
113
–0.06
300
2
162
–0.15
2
194
0.16
2
214
–0.07
2
227
–0.06
600
2
80
0.47
2
97
–0.35
2
106
0.39
2
113
–0.06
1200
1
162
–0.15
1
194
0.16
1
214
–0.07
1
227
–0.06
2400
1
80
0.47
1
97
–0.35
1
106
0.39
1
113
–0.06
4800
0
162
–0.15
0
194
0.16
0
214
–0.07
0
227
–0.06
9600
0
80
0.47
0
97
–0.35
0
106
0.39
0
113
–0.06
19200
0
40
–0.76
0
48
–0.35
0
53
–0.54
0
56
–0.06
31250
0
24
0.00
0
29
0
0
32
0
0
34
0.00
38400
0
19
1.73
0
23
1.73
0
26
–0.54
0
27
1.73
Note: In SCI_2, 5, and 6, this is an example when the ABCS bit in SEMR_2, 5, and 6 is 0.
When the ABCS bit is set to 1, the bit rate is two times.
Table 19.5 Maximum Bit Rate for Each Operating Frequency (Asynchronous Mode)
Pφ (MHz)
Maximum
Bit Rate
(bit/s)
Pφ (MHz)
Maximum
Bit Rate
(bit/s)
n
N
n
N
8
250000
0
0
17.2032
537600
0
0
9.8304
307200
0
0
18
562500
0
0
10
312500
0
0
19.6608
614400
0
0
12
375000
0
0
20
625000
0
0
12.288
384000
0
0
25
781250
0
0
14
437500
0
0
30
937500
0
0
14.7456
460800
0
0
33
1031250
0
0
16
500000
0
0
35
1093750
0
0
Rev. 2.00 Oct. 21, 2009 Page 894 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Table 19.6 Maximum Bit Rate with External Clock Input (Asynchronous Mode)
Pφ (MHz)
External Input
Clock (MHz)
Maximum Bit
Rate (bit/s)
Pφ (MHz)
External Input
Clock (MHz)
Maximum Bit
Rate (bit/s)
8
2.0000
125000
17.2032
4.3008
268800
9.8304
2.4576
153600
18
4.5000
281250
10
2.5000
156250
19.6608
4.9152
307200
12
3.0000
187500
20
5.0000
312500
12.288
3.0720
192000
25
6.2500
390625
14
3.5000
218750
30
7.5000
468750
14.7456
3.6864
230400
33
8.2500
515625
16
4.0000
250000
35
8.7500
546875
Note: In SCI_2, this is an example when the ABCS bit in SEMR_2 is 0.
When the ABCS bit is set to 1, the bit rate is two times.
Rev. 2.00 Oct. 21, 2009 Page 895 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Table 19.7 BRR Settings for Various Bit Rates (Clocked Synchronous Mode)*2
Operating Frequency Pφ (MHz)
Bit Rate
(bit/s)
8
10
n
N
n
3
124 —
16
N
n
N
—
3
249
20
n
N
25
30
N
33
n
N
35
n
N
n
n
N
3
233
3
97
3
116 3
128 3
136
155 2
187 2
205 2
218
110
250
500
2
249 —
—
3
124 —
—
1k
2
124 —
—
2
249 —
—
2.5k
1
199 1
249 2
99
124 2
2
5k
1
99
1
124 1
199 1
249 2
77
2
102 2
108
10k
0
199 0
249 1
99
1
124 1
155 1
187 1
205 1
218
25k
0
79
0
99
0
159 0
199 0
249 1
74
82
87
50k
0
39
0
49
0
79
0
99
0
124 0
149 0
164 0
174
100k
0
19
0
24
0
39
0
49
0
62
0
74
0
82
0
87
250k
0
7
0
9
0
15
0
19
0
24
0
29
0
32
0
34
500k
0
3
0
4
0
7
0
9
—
—
0
14
—
—
—
—
1M
0
1
0
3
0
4
—
—
—
—
—
—
—
—
2.5M
0
0*
1
5M
2
93
1
1
0
1
—
—
0
2
—
—
—
—
0
0*1
—
—
—
—
—
—
—
—
[Legend]
Space: Setting prohibited.
⎯:
Can be set, but there will be error.
Notes: 1. Continuous transmission or reception is not possible.
2. No clocked synchronous mode exists in SCI_5 and SCI_6.
Table 19.8 Maximum Bit Rate with External Clock Input (Clocked Synchronous Mode)*
Pφ (MHz)
External Input
Clock (MHz)
Maximum Bit
Rate (bit/s)
Pφ (MHz)
External Input
Clock (MHz)
Maximum Bit
Rate (bit/s)
8
1.3333
1333333.3
20
3.3333
3333333.3
10
1.6667
1666666.7
25
4.1667
4166666.7
12
2.0000
2000000.0
30
5.0000
5000000.0
14
2.3333
2333333.3
33
5.5000
5500000.0
16
2.6667
2666666.7
35
5.8336
5833625.0
3.0000
3000000.0
18
Note
*
No clocked synchronous mode exists in SCI_5 and SCI_6.
Rev. 2.00 Oct. 21, 2009 Page 896 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Table 19.9 BRR Settings for Various Bit Rates (Smart Card Interface Mode, n = 0, S =
372)
Operating Frequency Pφ (MHz)
7.1424
Bit Rate
10.00
10.7136
13.00
(bit/sec)
n
N
Error (%) n
N
Error (%) n
N
Error (%) n
N
Error (%)
9600
0
0
0.00
1
30
1
25
1
8.99
0
0
0
Operating Frequency Pφ (MHz)
14.2848
Bit Rate
16.00
18.00
20.00
(bit/sec)
n
N
Error (%) n
N
Error (%) n
N
Error (%) n
N
Error (%)
9600
0
1
0.00
1
12.01
2
15.99
2
6.66
0
0
0
Operating Frequency Pφ (MHz)
25.00
Bit Rate
30.00
33.00
35.00
(bit/sec)
n
N
Error (%) n
N
Error (%) n
N
Error (%) n
N
Error (%)
9600
0
3
12.49
3
5.01
4
7.59
4
1.99
0
0
0
Table 19.10 Maximum Bit Rate for Each Operating Frequency (Smart Card Interface
Mode, S = 372)
Pφ (MHz)
Maximum Bit
Rate (bit/s)
n
N
Pφ (MHz)
Maximum Bit
Rate (bit/s)
n
N
7.1424
9600
0
0
18.00
24194
0
0
10.00
13441
0
0
20.00
26882
0
0
10.7136
14400
0
0
25.00
33602
0
0
13.00
17473
0
0
30.00
40323
0
0
14.2848
19200
0
0
33.00
44355
0
0
16.00
21505
0
0
35.00
47043
0
0
Rev. 2.00 Oct. 21, 2009 Page 897 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.3.10 Serial Extended Mode Register (SEMR_2)
SEMR_2 selects the clock source in asynchronous mode of SCI_2. The base clock is
automatically specified when the average transfer rate operation is selected.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
ABCS
ACS2
ACS1
ACS0
Undefined
Undefined
Undefined
Undefined
0
0
0
0
R
R
R
R
R/W
R/W
R/W
R/W
R/W
Initial Value
R/W
Bit
Bit Name
Initial
Value
7 to 4
⎯
Undefined R
Description
Reserved
These bits are always read as undefined and cannot be
modified.
3
ABCS
0
R/W
Asynchronous Mode Base clock Select (valid only in
asynchronous mode)
Selects the base clock for a 1-bit period.
0: The base clock has a frequency 16 times the transfer
rate
1: The base clock has a frequency 8 times the transfer
rate
Rev. 2.00 Oct. 21, 2009 Page 898 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
2
ACS2
0
R/W
1
ACS1
0
R/W
Asynchronous Mode Clock Source Select (valid when
CKE1 = 1 in asynchronous mode)
0
ACS0
0
R/W
These bits select the clock source for the average
transfer rate function. When the average transfer rate
function is enabled, the base clock is automatically
specified regardless of the ABCS bit value.
000: External clock input
001: 115.192 kbps of average transfer rate specific to
Pφ = 10.667 MHz is selected (operated using the
base clock with a frequency 16 times the transfer
rate)
010: 460.784 kbps of average transfer rate specific to
Pφ = 10.667 MHz is selected (operated using the
base clock with a frequency 8 times the transfer
rate)
011: 720 kbps of average transfer rate specific to Pφ =
32 MHz is selected (operated using the base clock
with a frequency 16 times the transfer rate)
100: Setting prohibited
101: 115.192 kbps of average transfer rate specific to
Pφ = 16 MHz is selected (operated using the base
clock with a frequency 16 times the transfer rate)
110: 460.784 kbps of average transfer rate specific to
Pφ = 16 MHz is selected (operated using the base
clock with a frequency 16 times the transfer rate)
111: 720 kbps of average transfer rate specific to Pφ =
16 MHz is selected (operated using the base clock
with a frequency 8 times the transfer rate)
The average transfer rate only supports operating
frequencies of 10.667 MHz, 16 MHz, and 32 MHz.
Rev. 2.00 Oct. 21, 2009 Page 899 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.3.11 Serial Extended Mode Register 5 and 6 (SEMR_5 and SEMR_6)
SEMR_5 and SEMR_6 select the clock source in asynchronous mode of SCI_5 and SCI_6. The
base clock is automatically specified when the average transfer rate operation is selected. TMO
output in TMR unit 2 and unit 3 can also be set as the serial transfer base clock. Figure 19.3
describes the examples of base clock features when the average transfer rate operation is selected.
Figure 19.4 describes the examples of base clock features when the TMO output in TMR is
selected.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
ABCS
ACS3
ACS2
ACS1
ACS0
Undefined
Undefined
Undefined
0
0
0
0
0
R
R
R
R/W
R/W
R/W
R/W
R/W
R/W
Initial Value
R/W
Bit
Bit Name
Initial
Value
7 to 5
⎯
Undefined R
4
ABCS
0
R/W
3
2
1
0
ACS3
ACS2
ACS1
ACS0
0
0
0
0
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 900 of 1454
REJ09B0498-0200
Description
Reserved
These bits are always read as undefined and cannot be
modified.
Asynchronous Mode Base Clock Select (valid only in
asynchronous mode)
Selects the base clock for a 1-bit period.
0: The base clock has a frequency 16 times the transfer
rate
1: The base clock has a frequency 8 times the transfer
rate
Asynchronous Mode Clock Source Select
These bits select the clock source for the average
transfer rate function in the asynchronous mode. When
the average transfer rate function is enabled, the base
clock is automatically specified regardless of the ABCS
bit value. The average transfer rate only corresponds to
8MHz, 10.667MHz, 12MHz, 16MHz, 24MHz, and
32MHz. No other clock is available. Setting of ACS3 to
ACS0 must be done in the asynchronous mode (the
C/A bit in SMR = 0) and the external clock input mode
(the CKE bit I SCR = 1). The setting examples are in
figures 19.3 and 19.4.
(Each number in the four-digit number below
corresponds to the value in the bits ACS3 to ACS0 from
left to right respectively.)
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
3
2
1
0
ACS3
ACS2
ACS1
ACS0
0
0
0
0
R/W
R/W
R/W
R/W
0000: Average transfer rate generator is not used.
0001: 115.152 kbps of average transfer rate specific to
Pφ = 10.667 MHz is selected (operated using the
base clock with a frequency 16 times the transfer
rate)
0010: 460.606 kbps of average transfer rate specific to
Pφ = 10.667 MHz is selected (operated using the
base clock with a frequency 8 times the transfer
rate)
0011: 921.569 kbps of average transfer rate specific to
Pφ = 16 MHz is selected or 460.784 kbps of
average transfer rate specific to Pφ = 8MHz is
selected (operated using the base clock with a
frequency 8 times the transfer rate)
0100: TMR clock input
This setting allows the TMR compare match output
to be used as the base clock. The table below
shows the correspondence between the SCI
channels and the compare match output.
SCI Channel
SCI_5
SCI_6
Compare Match
TMR Unit Output
Unit 2
TMO4, TMO5
Unit 3
TMO6, TMO7
0101: 115.196 kbps of average transfer rate specific to
Pφ = 16 MHz is selected (operated using the base
clock with a frequency 16 times the transfer rate)
0110: 460.784 kbps of average transfer rate specific to
Pφ = 16 MHz is selected (operated using the base
clock with a frequency 16 times the transfer rate)
0111: 720 kbps of average transfer rate specific to Pφ =
16 MHz is selected (operated using the base clock
with a frequency 8 times the transfer rate)
Rev. 2.00 Oct. 21, 2009 Page 901 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
3
2
1
0
ACS3
ACS2
ACS1
ACS0
0
0
0
0
R/W
R/W
R/W
R/W
1000: 115.132 kbps of average transfer rate specific to
Pφ = 24 MHz is selected (operated using the base
clock with a frequency 16 times the transfer rate)
1001: 460.526 kbps of average transfer rate specific to
Pφ = 24 MHz is selected or 230.263 kbps of
average transfer rate specific to Pφ = 12MHz is
selected (operated using the base clock with a
frequency 16 times the transfer rate)
1010: 720 kbps of average transfer rate specific to Pφ =
24 MHz is selected (operated using the base clock
with a frequency 8 times the transfer rate)
1011: 921.053 kbps of average transfer rate specific to
Pφ = 24 MHz is selected or 460.526 kbps of
average transfer rate specific to Pφ = 12MHz is
selected (operated using the base clock with a
frequency 8 times the transfer rate)
1100: 720 kbps of average transfer rate specific to Pφ =
32 MHz is selected (operated using the base clock
with a frequency 16 times the transfer rate)
1101: Reserved (setting prohibited)
111x: Reserved (setting prohibited)
Rev. 2.00 Oct. 21, 2009 Page 902 of 1454
REJ09B0498-0200
1.8424 MHz
4 5
6 7
8 9
10 11 12
15 16
3.6848 MHz
4 5
6 7
8
Average transfer rate = 3.6848 MHz/8 = 460.606 kbps
Average error with 460.6 kbps = -0.043%
1 bit = Base clock × 8*
1 2 3
5.333 MHz
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 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 1 2 3 4
Note: * The length of one bit varies according to the base clock synchronization.
Base clock
10.667 MHz/2 = 5.333 MHz
5.333 MHz × (38/55)
= 3.6848 MHz
(Average)
13 14
Average transfer rate = 1.8424 MHz/16 = 115.152 kbps
Average error with 115.2 kbps = -0.043%
1 bit = Base clock × 16*
1 2 3
2.667 MHz
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 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 1 2 3 4
Base clock with 460.606-kbps average transfer rate (ACS3 to 0 = B'0010)
Base clock
10.667 MHz/4= 2.667 MHz
2.667 MHz × (38/55)
= 1.8424 MHz
(Average)
Base clock with 115.152-kbps average transfer rate (ACS3 to 0 = B'0001)
When φ = 10.667 MHz
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Figure 19.3 Examples of Base Clock when Average Transfer Rate Is Selected (1)
Rev. 2.00 Oct. 21, 2009 Page 903 of 1454
REJ09B0498-0200
REJ09B0498-0200
Average transfer rate = 1.8431 MHz/16 = 115.196 kbps
Average error with 115.2 kbps = -0.004%
1.8431 MHz
1 2 3 4 5 6 7 8 9 10 11 12
13 14 15 16
1 bit = Base clock × 16*
2 MHz
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 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 1 2 3 4 5 6 7 8
Rev. 2.00 Oct. 21, 2009 Page 904 of 1454
Average transfer rate = 5.76 MHz/8 = 720 kbps
Average error with 720 kbps = ±0%
5.76 MHz
1 2 3
4 5
6 7 8
1 bit = Base clock × 8*
8 MHz
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 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
Average transfer rate = 7.3725 MHz/8 = 921.569 kbps
Average error with 921.6 kbps = -0.003%
1 bit = Base clock × 8*
7.3725 MHz
1 2 3 4 5 6 7 8
8 MHz
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 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 1 2 3 4 5 6 7 8
Note: * The length of one bit varies according to the base clock synchronization.
Base clock
16 MHz/2 = 8 MHz
8 MHz × (47/51)
= 7.3725 MHz
(Average)
Base clock with 921.569-kbps average transfer rate (ACS3 to 0 = B'0011)
Base clock
16 MHz/2 = 8 MHz
8 MHz × (18/25)
= 5.76 MHz
(Average)
Base clock with 720-kbps average transfer rate (ACS3 to 0 = B'0111)
Average transfer rate = 7.3725 MHz/16 = 460.784 kbps
Average error with 460.8 kbps = -0.004%
Base clock with 460.784-kbps average transfer rate (ACS3 to 0 = B'0110)
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 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 1 2 3 4 5 6 7 8
Base clock
8 MHz
16 MHz/2 = 8 MHz
8 MHz × (47/51)
7.3725 MHz
1 2 3 4 5 6 7 8 9 10 11 12
13 14 15 16
= 7.3725 MHz
(Average)
1 bit = Base clock × 16*
Base clock
16 MHz/8 = 2 MHz
2 MHz × (47/51)
= 1.8431 MHz
(Average)
Base clock with 115.196-kbps average transfer rate (ACS3 to 0 = B'0101)
When φ = 16 MHz
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Figure 19.3 Examples of Base Clock when Average Transfer Rate Is Selected (2)
6 7
8 9
1 bit = Base clock × 16*
1.8421 MHz
2 3
4 5
3 MHz
10 11
12
Average transfer rate =1.8421 MHz/16 = 115.132 kbps
Average error with 115.2 kbps = -0.059%
1
13 14
15 16
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 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 1 2
6 7
8 9
1 bit = Base clock × 16*
7.3684 MHz
2 3
4 5
Average transfer rate = 5.76 MHz/8= 720 kbps
Average error with 720 kbps = ±0%
1 bit = Base clock × 8*
5.76 MHz
12 MHz
13 14
15 16
1
8
Average transfer rate = 7.3684 MHz/8= 921.053 kbps
Average error with 921.6 kbps = -0.059%
7.3684 MHz
2 3
4 5
6 7
1 bit = Base clock × 8*
12 MHz
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 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 1 2
Note: * The length of one bit varies according to the base clock synchronization.
Base clock
24 MHz/2 = 12 MHz
12 MHz × (35/57)
= 7.3684 MHz
(Average)
12
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 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
Base clock with 921.053-kbps average transfer rate (ACS3 to 0 = B'1011)
Base clock
24 MHz/2 = 12 MHz
12 MHz × (12/25)
= 5.76 MHz
(Average)
10 11
Average transfer rate = 7.3684 MHz/16 = 460.526 kbps
Average error with 921.6 kbps = -0.059%
1
12 MHz
Base clock with 720-kbps average transfer rate (ACS3 to 0 = B'1010)
Base clock
24 MHz/2 = 12 MHz
12 MHz × (35/57)
= 7.3684 MHz
(Average)
Base clock with 460.526-kbps average transfer rate (ACS3 to 0 = B'1001)
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 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 1 2
Base clock
24 MHz/8 = 3 MHz
3 MHz × (35/57)
= 1.8421 MHz
(average)
Base clock with 115.132-kbps average transfer rate (ACS3 to 0 = B'1000)
When φ = 24 MHz
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Figure 19.3 Examples of Base Clock when Average Transfer Rate Is Selected (3)
Rev. 2.00 Oct. 21, 2009 Page 905 of 1454
REJ09B0498-0200
REJ09B0498-0200
Rev. 2.00 Oct. 21, 2009 Page 906 of 1454
SCK5
Base clock
= 4 MHz ´ 3/4
= 3 MHz (Average)
Clock enable
TMO5 output
Base clock
TMO4 output
= 4 MHz
3
3
3
4
4
1
1
1 bit = Base clock × 16
2
4 MHz
3 MHz
2
2
5
2
2
6
3
3
4
7
1
1
Average transfer rate = 3 MHz/16 = 187.5 kbps
1
1
1
8
2
2
9
3
3
4
10
1
1
11
2
2
12
3
3
4
13
1
1
14
2
2
15
3
3
4
1
1
16
TMR and SCI Settings:
TMR (Unit 2)
· TCR_4 = H'09 (TCNT4 cleared by TCORA_4 compare match, TCNT4 incremented at rising edge of Pφ/2)
· TCCR_4 = H'01
TMO5
· TCR_5 = H'0C (TCNT5 cleared by TCORA_5 compare match, TCNT5 incremented by TCNT_4 compare match A)
TMO4
· TCCR_5 = H'00
· TCSR_4 = H'09 (0 output on TCORA_4 compare match, 1 output on TCORB_4 compare match)
· TCSR_5 = H'09 (0 output on TCORA_5 compare match, 1 output on TCORB_5 compare match)
· TCNT_4 = TCNT_5 = 0
· TCORA_4 = H'03, TCORB_4 = H'01
· TCORA_5 = H'03, TCORB_5 = H'00
· SEMR_5 = H'04
When SCI_6 is used, set TMO6 as a base clock and TMO7 as a clock enable.
Example when TMR clock input is used in SCI_5
187.5-kbps average transfer rate is generated by TMR when φ = 32 MHz
(1) TMO4 is set as a base clock and generates 4 MHz.
(2) TMO5 is set as TCNT_4 compare match count and generates a clock enable multiplied by 3/4.
The average transfer rate will be 3 MHz/16 = 187.5 kbps.
1
2
2
2
3
3
4
Base clock
Clock enable
3
1
1
4
2
2
5
3
3
4
SCK5
SCI_5
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Figure 19.4 Example of Average Transfer Rate Setting when TMR Clock Is Input
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.3.12 IrDA Control Register (IrCR)
IrCR selects the function of SCI_5.
7
6
5
4
3
2
1
0
IrE
IrCKS2
IrCKS1
IrCKS0
IrTxINV
IrRxINV
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
⎯
⎯
Bit
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
IrE
0
R/W
IrDA Enable*
Sets the SCI_5 I/O to normal SCI or IrDA.
0: TxD5/IrTxD and RxD5/IrRxD pins operate as
TxD5 and RxD5.
1: TxD5/IrTxD and RxD5/IrRxD pins are operate as
IrTxD and IrRxD.
6
IrCK2
0
R/W
IrDA Clock Select 2 to 0
5
IrCK1
0
R/W
4
IrCK0
0
R/W
Sets the pulse width of high state at encoding the IrTxD
output pulse when the IrDA function is enabled.
000: Pulse-width = B × 3/16 (Bit rate × 3/16)
001: Pulse-width = Pφ/2
010: Pulse-width = Pφ/4
011: Pulse-width = Pφ/8
100: Pulse-width = Pφ/16
101: Pulse-width = Pφ/32
110: Pulse-width = Pφ/64
111: Pulse-width = Pφ/128
3
IrTxINV
0
R/W
IrTx Data Invert
This bit specifies the inversion of the logic level in IrTxD
output. When inversion is done, the pulse width of high
state specified by the bits 6 to 4 becomes the pulse
width in low state.
0: Outputs the transmission data as it is as IrTxD output
1: Outputs the inverted transmission data as IrTxD
output
Rev. 2.00 Oct. 21, 2009 Page 907 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
2
IrRxINV
0
R/W
IrRx Data Invert
This bit specifies the inversion of the logic level in IrRxD
output. When inversion is done, the pulse width of high
state specified by the bits 6 to 4 becomes the pulse
width in low state.
0: Uses the IrRxD input data as it is as receive data.
1: Uses the inverted IrRxD input data as receive data.
⎯
1, 0
All 0
—
Reserved
These bits are always read as 0. It should not be set to
0.
Note:
19.4
*
The IrDA function should be used when the ABCS bit in SEMR_5 is set to 0 and the
ACS3 to ACS0 bits in SEMR_5 are set to B'0000.
Operation in Asynchronous Mode
Figure 19.5 shows the general format for asynchronous serial communication. One frame consists
of a start bit (low level), transmit/receive data, a parity bit, and stop bits (high level). In
asynchronous serial communication, the communication line is usually held in the mark state
(high level). The SCI monitors the communication 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 transmission and reception.
1
Serial
data
LSB
0
D0
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 19.5 Data Format in Asynchronous Communication
(Example with 8-Bit Data, Parity, Two Stop Bits)
Rev. 2.00 Oct. 21, 2009 Page 908 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.4.1
Data Transfer Format
Table 19.11 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 19.5, Multiprocessor Communication Function.
Table 19.11 Serial Transfer Formats (Asynchronous Mode)
SMR Settings
2
Serial Transfer Format and Frame Length
3
4
5
6
7
8
9 10 11
CHR
PE
MP
STOP
1
12
0
0
0
0
S
8-bit data
STOP
0
0
0
1
S
8-bit data
STOP STOP
0
1
0
0
S
8-bit data
P
STOP
0
1
0
1
S
8-bit data
P
STOP STOP
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
STOP STOP
0
–
1
0
S
8-bit data
MPB STOP
0
–
1
1
S
8-bit data
MPB STOP STOP
1
–
1
0
S
7-bit data
MPB STOP
1
–
1
1
S
7-bit data
MPB STOP STOP
[Legend]
S:
Start bit
STOP: Stop bit
P:
Parity bit
MPB: Multiprocessor bit
Rev. 2.00 Oct. 21, 2009 Page 909 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.4.2
Receive Data Sampling Timing and Reception Margin in Asynchronous Mode
In asynchronous mode, the SCI operates on a base clock with a frequency of 16 times* the bit rate.
In reception, the SCI samples the falling edge of the start bit using the base clock, and performs
internal synchronization. Since receive data is sampled at the rising edge of the 8th pulse* of the
base clock, data is latched at the middle of each bit, as shown in figure 19.6. Thus the reception
margin in asynchronous mode is determined by formula (1) below.
M = | (0.5 –
1
) – (L – 0.5) F – | D – 0.5 | (1 + F ) | × 100
2N
N
[%]
... Formula (1)
[Legend]
M: Reception margin
N: Ratio of bit rate to clock (When ABCS = 0, N = 16. When ABCS = 1, N = 8.)
D: Duty cycle of clock (D = 0.5 to 1.0)
L: Frame length (L = 9 to 12)
F: Absolute value of clock frequency deviation
Assuming values of F = 0 and D = 0.5 in formula (1), the reception margin is determined by the
formula below.
M = ( 0.5 –
1
) × 100
2 × 16
[%] = 46.875%
However, this is only the computed value, and a margin of 20% to 30% should be allowed 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 19.6 Receive Data Sampling Timing in Asynchronous Mode
Note: * This is an example when the ABCS bit in SEMR_2, 5, and 6 is 0. When the ABCS bit
is 1, a frequency of 8 times the bit rate is used as a base clock and receive data is
sampled at the rising edge of the 4th pulse of the base clock.
Rev. 2.00 Oct. 21, 2009 Page 910 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.4.3
Clock
Either an internal clock generated by the on-chip baud rate generator or an external clock input to
the SCK pin can be selected as the SCI's transfer clock, according to the setting of the C/A bit in
SMR and the CKE1 and CKE0 bits in SCR. When an external clock is input to the SCK pin, the
clock frequency should be 16 times the bit rate (when ABCS = 0) and 8 times the bit rate (when
ABCS = 1).
In addition, when an external clock is specified, the average transfer rate or the base clock of
TMR_4 to TMR_7 can be selected by the ACS3 to ACS0 bits in SEMR_5 and SEMR_6.
When the SCI is operated on an internal clock, the clock can be output from the SCK pin. 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 19.7.
SCK
TxD
0
D0
D1
D2
D3
D4
D5
D6
D7
0/1
1
1
1 frame
Figure 19.7 Phase Relation between Output Clock and Transmit Data
(Asynchronous Mode)
Rev. 2.00 Oct. 21, 2009 Page 911 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.4.4
SCI Initialization (Asynchronous Mode)
Before transmitting and receiving data, first clear the TE and RE bits in SCR to 0, then initialize
the SCI as described in a sample flowchart in figure 19.8 When the operating mode, transfer
format, etc., is changed, the TE and RE bits must be cleared to 0 before making the change. 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 RDRF, PER, FER, and ORER flags, or RDR. When the external clock is used in
asynchronous mode, the clock must be supplied even during initialization.
Start initialization
[1]
Set the bit in ICR for the corresponding
pin when receiving data or using an
external clock.
[2]
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 corresponding bit in ICR to 1
[1]
Set CKE1 and CKE0 bits in SCR
(TE and RE bits are 0)
[2]
Set data transfer format in
SMR and SCMR
[3]
Set value in BRR
[4]
When the clock output is selected in
asynchronous mode, the clock is output
immediately after SCR settings are
made.
[3]
Set the data transfer format in SMR and
SCMR.
[4]
Write a value corresponding to the bit
rate to BRR. This step is not necessary
if an external clock is used.
[5]
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 or RE bit in
SCR to 1, and set RIE, TIE, TEIE,
and MPIE bits
[5]
Figure 19.8 Sample SCI Initialization Flowchart
Rev. 2.00 Oct. 21, 2009 Page 912 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.4.5
Serial Data Transmission (Asynchronous Mode)
Figure 19.9 shows an example of the operation for transmission in asynchronous mode. In
transmission, the SCI operates as described below.
1. The SCI monitors the TDRE flag in SSR, and if it is cleared to 0, 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 TXI interrupt request is generated.
Because the TXI interrupt processing routine writes the next transmit data to TDR before
transmission of the current transmit data has finished, continuous transmission can be enabled.
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 next transmit 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.
Figure 19.10 shows a sample flowchart for transmission in asynchronous mode.
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
request generated TDRE flag cleared to 0 in
TXI interrupt processing
routine
1 frame
TXI interrupt
request generated
TEI interrupt
request generated
Figure 19.9 Example of Operation for Transmission in Asynchronous Mode
(Example with 8-Bit Data, Parity, One Stop Bit)
Rev. 2.00 Oct. 21, 2009 Page 913 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
[1]
Initialization
Start transmission
[2]
Read TDRE flag in SSR
TDRE = 1
[2] SCI state 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
Yes
[3] Serial transmission continuation
procedure:
Write transmit data to TDR
and clear TDRE flag in SSR to 0
All data transmitted?
No
Yes
[3]
Read TEND flag in SSR
TEND = 1
No
Yes
Break output
Yes
[1] SCI initialization:
The TxD pin is automatically
designated as the transmit data
output pin. After the TE bit is set to
1, a 1 is output for a frame, and
transmission is enabled.
No
[4]
To continue serial transmission,
read 1 from the TDRE flag to
confirm that writing is possible,
then write data to TDR, and clear
the TDRE flag to 0. However, the
TDRE flag is checked and cleared
automatically when the DMAC or
DTC is initiated by a transmit data
empty interrupt (TXI) request and
writes data to TDR.
[4] Break output at the end of serial
transmission:
To output a break in serial
transmission, set DDR for the port
corresponding to the TxD pin to 1,
clear DR to 0, then clear the TE bit
in SCR to 0.
Clear DR to 0 and
set DDR to 1
Clear TE bit in SCR to 0
Figure 19.10 Example of Serial Transmission Flowchart
Rev. 2.00 Oct. 21, 2009 Page 914 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.4.6
Serial Data Reception (Asynchronous Mode)
Figure 19.11 shows an example of the operation for reception in asynchronous mode. In serial
reception, the SCI operates as described below.
1. The SCI monitors the communication line, and if a start bit is detected, performs internal
synchronization, stores receive data in RSR, and checks the parity bit and stop bit.
2. If an overrun error (when reception of the next data is completed while the RDRF flag in SSR
is still set to 1) occurs, 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 (when the stop bit is 0) is detected, 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 finishes 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. Because the RXI interrupt processing routine reads the receive data transferred to
RDR before reception of the next receive data has finished, continuous reception can be
enabled.
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 processing routine
ERI interrupt request
generated by framing
error
1 frame
Figure 19.11 Example of SCI Operation for Reception
(Example with 8-Bit Data, Parity, One Stop Bit)
Rev. 2.00 Oct. 21, 2009 Page 915 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Table 19.12 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 19.12 shows a sample
flowchart for serial data reception.
Table 19.12 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. 2.00 Oct. 21, 2009 Page 916 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
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
PER ∨ FER ∨ ORER = 1
that the ORER, PER, and FER flags are
[3]
all cleared to 0. Reception cannot be
No
resumed if any of these flags are set to
Error processing
1. In the case of a framing error, a
(Continued on next page) break can be detected by reading the
value of the input port corresponding to
[4]
Read RDRF flag in SSR
the RxD pin.
Read ORER, PER, and
FER flags in SSR
No
[4] SCI state check and receive data read:
Read SSR and check that RDRF = 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.
RDRF = 1
Yes
Read receive data in RDR, and
clear RDRF flag in SSR to 0
No
All data received?
Yes
Clear RE bit in SCR to 0
[5]
[5] Serial reception continuation procedure:
To continue serial reception, before the
stop bit for the current frame is
received, read the RDRF flag and RDR,
and clear the RDRF flag to 0.
However, the RDRF flag is cleared
automatically when the DMAC or DTC
is initiated by an RXI interrupt and
reads data from RDR.
Figure 19.12 Sample Serial Reception Flowchart (1)
Rev. 2.00 Oct. 21, 2009 Page 917 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
[3]
Error processing
No
ORER = 1
Yes
Overrun error processing
No
FER = 1
Yes
Break?
Yes
No
Framing error processing
No
Clear RE bit in SCR to 0
PER = 1
Yes
Parity error processing
Clear ORER, PER, and
FER flags in SSR to 0
Figure 19.12 Sample Serial Reception Flowchart (2)
Rev. 2.00 Oct. 21, 2009 Page 918 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.5
Multiprocessor Communication Function
Use of the multiprocessor communication function enables data transfer to be performed among a
number of processors sharing communication lines by means of asynchronous serial
communication using the multiprocessor format, in which a multiprocessor bit is added to the
transfer data. When multiprocessor communication is carried out, each receiving station is
addressed by a unique ID code. The serial communication cycle consists of two component cycles:
an ID transmission cycle which specifies the receiving station, and a data transmission cycle for
the specified receiving station. 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, and if the multiprocessor bit is 0, the cycle is a data transmission cycle. Figure
19.13 shows an example of inter-processor communication using the multiprocessor format. The
transmitting station first sends data which includes the ID code of the receiving station and a
multiprocessor bit set to 1. It then transmits transmit data added with a multiprocessor bit cleared
to 0. The receiving station skips data until data with a 1 multiprocessor bit is sent. 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 ID does 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 in SSR to 1 are prohibited until data with a 1 multiprocessor bit is
received. On reception of a receive character with a 1 multiprocessor bit, the MPBR 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 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. 2.00 Oct. 21, 2009 Page 919 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Transmitting
station
Communication line
Receiving
station A
Receiving
station B
Receiving
station C
Receiving
station D
(ID = 01)
(ID = 02)
(ID = 03)
(ID = 04)
Serial
data
H'01
H'AA
(MPB = 1)
(MPB = 0)
ID transmission cycle = Data transmission cycle =
Data transmission to
receiving station
receiving station specified by ID
specification
[Legend]
MPB: Multiprocessor bit
Figure 19.13 Example of Communication Using Multiprocessor Format
(Transmission of Data H'AA to Receiving Station A)
Rev. 2.00 Oct. 21, 2009 Page 920 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.5.1
Multiprocessor Serial Data Transmission
Figure 19.14 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.
Initialization
[1]
Start transmission
[2]
Read TDRE flag in SSR
TDRE = 1
[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
Yes
Write transmit data to TDR and
set MPBT bit in SSR
Clear TDRE flag to 0
All data transmitted?
No
[3]
Yes
Read TEND flag in SSR
TEND = 1
No
Yes
Break output?
No
[1] SCI initialization:
The TxD pin is automatically
designated as the transmit data
output pin. After the TE bit is set
to 1, a 1 is output for one frame,
and transmission is enabled.
[4]
[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.
However, the TDRE flag is
checked and cleared
automatically when the DMAC or
DTC is initiated by a transmit
data empty interrupt (TXI)
request and writes data to TDR.
[4] Break output at the end of serial
transmission:
To output a break in serial
transmission, set DDR for the
port to 1, clear DR to 0, and then
clear the TE bit in SCR to 0.
Yes
Clear DR to 0 and set DDR to 1
Clear TE bit in SCR to 0
Figure 19.14 Sample Multiprocessor Serial Transmission Flowchart
Rev. 2.00 Oct. 21, 2009 Page 921 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.5.2
Multiprocessor Serial Data Reception
Figure 19.16 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
19.15 shows an example of SCI operation for multiprocessor format reception.
1
Start
bit
0
Data (ID1)
MPB
D0
D1
D7
1
Stop
bit
Start
bit
1
0
Data (Data 1)
D0
D1
Stop
MPB bit
D7
0
1
1 Idle state
(mark 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
processing 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
Start
bit
0
Data (ID2)
D0
D1
Stop
MPB bit
D7
1
1
Start
bit
0
Data (Data 2)
D0
D1
D7
Stop
MPB bit
0
1
1 Idle state
(mark state)
MPIE
RDRF
RDR
value
ID1
MPIE = 0
Data 2
ID2
RXI interrupt
request
(multiprocessor
interrupt)
generated
RDR data read and
RDRF flag cleared
to 0 in RXI interrupt
processing routine
Matches this station's ID,
so reception continues, and
data is received in RXI
interrupt processing routine
MPIE bit set to 1
again
(b) Data matches station's ID
Figure 19.15 Example of SCI Operation for Reception
(Example with 8-Bit Data, Multiprocessor Bit, One Stop Bit)
Rev. 2.00 Oct. 21, 2009 Page 922 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
[1] SCI initialization:
The RxD pin is automatically designated
as the receive data input pin.
[1]
Initialization
Start reception
Set MPIE bit in SCR to 1
[2] ID reception cycle:
Set the MPIE bit in SCR to 1.
[2]
[3] SCI state 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
[3]
Read RDRF flag in SSR
No
RDRF = 1
[4] SCI state 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
No
[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 both 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.
This station’s ID?
Yes
Read ORER and FER flags in SSR
FER ∨ ORER = 1
Yes
No
Read RDRF flag in SSR
RDRF = 1
[4]
No
Yes
Read receive data in RDR
No
All data received?
Yes
Clear RE bit in SCR to 0
[5]
Error processing
(Continued on
next page)
Figure 19.16 Sample Multiprocessor Serial Reception Flowchart (1)
Rev. 2.00 Oct. 21, 2009 Page 923 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
[5]
No
Error processing
ORER = 1
Yes
Overrun error processing
No
FER = 1
Yes
Break?
Yes
No
Framing error processing
Clear RE bit in SCR to 0
Clear ORER, PER, and
FER flags in SSR to 0
Figure 19.16 Sample Multiprocessor Serial Reception Flowchart (2)
Rev. 2.00 Oct. 21, 2009 Page 924 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.6
Operation in Clocked Synchronous Mode (SCI_0, 1, 2, and 4 only)
Figure 19.17 shows the general format for clocked synchronous communication. In clocked
synchronous mode, data is transmitted or received in synchronization with clock pulses. One
character in transfer data consists of 8-bit data. In data transmission, the SCI outputs data from one
falling edge of the synchronization clock to the next. In data reception, the SCI receives data in
synchronization with the rising edge of the synchronization clock. After 8-bit data is output, the
transmission line holds the MSB output state. In clocked synchronous mode, no parity bit or
multiprocessor bit is added. Inside the SCI, the transmitter and receiver are independent units,
enabling full-duplex communication by use of a common clock. Both the transmitter and the
receiver also have a double-buffered structure, so that the next transmit data can be written during
transmission or the previous receive data can be read during reception, enabling continuous data
transfer. (Setting is prohibited in SCI_5 and SCI_6.)
One unit of transfer data (character or frame)
*
*
Synchronization
clock
MSB
LSB
Bit 0
Serial data
Bit 1
Bit 2
Bit 3
Bit 4
Don't care
Bit 5
Bit 6
Bit 7
Don't care
Note: * Holds a high level except during continuous transfer.
Figure 19.17 Data Format in Clocked Synchronous Communication (LSB-First)
19.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 the CKE1
and CKE0 bits in SCR. When the SCI is operated on an internal clock, the synchronization clock
is output from the SCK pin. Eight synchronization clock pulses are output in the transfer of one
character, and when no transfer is performed the clock is fixed high. Note that in the case of
reception only, the synchronization clock is output until an overrun error occurs or until the RE bit
is cleared to 0. (Setting is prohibited in SCI_5 and SCI_6.)
Rev. 2.00 Oct. 21, 2009 Page 925 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.6.2
SCI Initialization (Clocked Synchronous Mode) (SCI_0, 1, 2, and 4 only)
Before transmitting and receiving data, first clear the TE and RE bits in SCR to 0, then initialize
the SCI as described in a sample flowchart in figure 19.18. When the operating mode, transfer
format, etc., is changed, the TE and RE bits must be cleared to 0 before making the change. When
the TE bit is cleared to 0, the TDRE flag is set to 1. However, clearing the RE bit to 0 does not
initialize the RDRF, PER, FER, and ORER flags, or RDR.
Start initialization
[1]
Clear TE and RE bits in SCR to 0
Set the bit in ICR for the corresponding
pin when receiving data or using an
external clock.
Set corresponding bit in ICR to 1
[1]
Set CKE1 and CKE0 bits in SCR
(TE and RE bits are 0)
[2] Set the clock selection in SCR. Be sure
to clear bits RIE, TIE, TEIE, and MPIE,
and bits TE and RE, to 0.
[2]
[3] Set the data transfer format in SMR and
SCMR.
Set data transfer format in
SMR and SCMR
[3]
Set value in BRR
[4]
Wait
1-bit interval elapsed?
No
[4] Write a value corresponding to the bit
rate to BRR. This step is not necessary
if an external clock is used.
[5] 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 or RE bit in SCR to 1, and
set RIE, TIE, TEIE, and MPIE bits
[5]
Note: In simultaneous transmit and receive operations, the TE and RE bits should both
be cleared to 0 or set to 1 simultaneously.
Figure 19.18 Sample SCI Initialization Flowchart
Rev. 2.00 Oct. 21, 2009 Page 926 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.6.3
Serial Data Transmission (Clocked Synchronous Mode) (SCI_0, 1, 2, and 4 only)
Figure 19.19 shows an example of the operation for transmission in clocked synchronous mode. In
transmission, the SCI operates as described below.
1. The SCI monitors the TDRE flag in SSR, and if it is 0, 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 TXI interrupt request is generated.
Because the TXI interrupt processing routine writes the next transmit data to TDR before
transmission of the current transmit data has finished, continuous transmission can be enabled.
3. 8-bit data is sent from the TxD pin synchronized with the output clock when clock output
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 last bit.
5. If the TDRE flag is cleared to 0, the next transmit 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 TxD pin retains 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.
Figure 19.20 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 to clear the receive error flags to 0 before starting transmission. Note that clearing the
RE bit to 0 does not clear the receive error flags.
Rev. 2.00 Oct. 21, 2009 Page 927 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
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
processing routine
TXI interrupt
request generated
TEI interrupt request
generated
1 frame
Figure 19.19 Example of Operation for Transmission in Clocked Synchronous Mode
Initialization
[1]
Start transmission
Read TDRE flag in SSR
TDRE = 1
[2]
No
Yes
Write transmit data to TDR and
clear TDRE flag in SSR to 0
All data transmitted
No
Yes
[3]
[1] SCI initialization:
The TxD pin is automatically
designated as the transmit data output
pin.
[2] SCI state 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. However, the TDRE
flag is checked and cleared
automatically when the DMAC or
DTC is initiated by a transmit data
empty interrupt (TXI) request and
writes data to TDR.
Read TEND flag in SSR
TEND = 1
No
Yes
Clear TE bit in SCR to 0
Figure 19.20 Sample Serial Transmission Flowchart
Rev. 2.00 Oct. 21, 2009 Page 928 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.6.4
Serial Data Reception (Clocked Synchronous Mode) (SCI_0, 1, 2, and 4 only)
Figure 19.21 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 in synchronization with a synchronization clock input
or output, starts receiving data, and stores the receive data in RSR.
2. If an overrun error (when reception of the next data is completed while the RDRF flag in SSR
is still set to 1) occurs, 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 reception finishes 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. Because the RXI interrupt processing routine reads the receive data transferred to
RDR before reception of the next receive data has finished, continuous reception can be
enabled.
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
processing routine
RXI interrupt
request generated
ERI interrupt request
generated by overrun
error
1 frame
Figure 19.21 Example of Operation for Reception in Clocked Synchronous Mode
Transfer 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 19.22 shows a sample flowchart
for serial data reception.
Rev. 2.00 Oct. 21, 2009 Page 929 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Initialization
[1]
Start reception
[2]
Read ORER flag in SSR
Yes
ORER = 1
No
[3]
Error processing
[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.
Reception cannot be resumed if the
ORER flag is set to 1.
(Continued below) [4] SCI state check and receive data
read:
[4]
Read SSR and check that the RDRF
flag is set to 1, then read the receive
RDRF = 1
data in RDR and clear the RDRF flag
to 0. Transition of the RDRF flag from
Yes
0 to 1 can also be identified by an RXI
interrupt.
Read receive data in RDR and
clear RDRF flag in SSR to 0
[5] Serial reception continuation
Read RDRF flag in SSR
No
No
All data received
Yes
Clear RE bit in SCR to 0
[3]
Error processing
[5]
procedure:
To continue serial reception, before
the MSB (bit 7) of the current frame is
received, reading the RDRF flag,
reading RDR, and clearing the RDRF
flag to 0 should be finished. However,
the RDRF flag is cleared automatically
when the DMAC or DTC is initiated by
a receive data full interrupt (RXI) and
reads data from RDR.
Overrun error processing
Clear ORER flag in SSR to 0
Figure 19.22 Sample Serial Reception Flowchart
19.6.5
Simultaneous Serial Data Transmission and Reception (Clocked Synchronous
Mode) (SCI_0, 1, 2, and 4 only)
Figure 19.23 shows a sample flowchart for simultaneous serial transmit and receive operations.
After initializing the SCI, 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 the TE bit to 0. Then simultaneously set both the TE and RE bits 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 the RE bit to 0. Then after checking that
the RDRF bit and receive error flags (ORER, FER, and PER) are cleared to 0, simultaneously set
both the TE and RE bits to 1 with a single instruction.
Rev. 2.00 Oct. 21, 2009 Page 930 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
[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.
[1]
Initialization
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
Read ORER flag in SSR
ORER = 1
No
Read RDRF flag in SSR
No
RDRF = 1
Yes
[3]
Error processing
[4]
[2] SCI state 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.
[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. Reception cannot be resumed if
the ORER flag is set to 1.
[4] SCI state 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 transmission/reception
continuation procedure:
To continue serial transmission/
Read receive data in RDR, and
reception, before the MSB (bit 7) of
clear RDRF flag in SSR to 0
the current frame is received, finish
reading the RDRF flag, reading
RDR, and clearing the RDRF flag to
No
0. Also, before the MSB (bit 7) of
[5]
All data received?
the current frame is transmitted,
read 1 from the TDRE flag to
Yes
confirm that writing is possible.
Then write data to TDR and clear
the TDRE flag to 0.
Clear TE and RE bits in SCR to 0
However, the TDRE flag is checked
and cleared automatically when the
DMAC or DTC is initiated by a
transmit data empty interrupt (TXI)
request and writes data to TDR.
Similarly, the RDRF flag is cleared
Note: When switching from transmit or receive operation to
automatically when the DMAC or
simultaneous transmit and receive operations, first clear
DTC is initiated by a receive data
the TE bit and RE bit to 0, then set both these bits to 1
full interrupt (RXI) and reads data
simultaneously.
from RDR.
Yes
Figure 19.23 Sample Flowchart of Simultaneous Serial Transmission and Reception
Rev. 2.00 Oct. 21, 2009 Page 931 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.7
Operation in Smart Card Interface Mode
The SCI supports the smart card interface, supporting the ISO/IEC 7816-3 (Identification Card)
standard, as an extended serial communication interface function. Smart card interface mode can
be selected using the appropriate register.
19.7.1
Sample Connection
Figure 19.24 shows a sample connection between the smart card and this LSI. As in the figure,
since this LSI communicates with the smart card using a single transmission line, interconnect the
TxD and RxD pins and pull up the data transmission line to VCC using a resistor. Setting the RE
and TE bits to 1 with the smart card not connected enables closed transmission/reception allowing
self diagnosis. To supply the smart card with the clock pulses generated by the SCI, input the SCK
pin output to the CLK pin of the smart card. A reset signal can be supplied via the output port of
this LSI. (In SCI_5 and SCI-6, the clock generated in SCI cannot be provided to smart cards.)
VCC
TxD
RxD
SCK
Rx (port)
This LSI
Data line
Clock line
Reset line
I/O
CLK
RST
IC card
Main unit of the device
to be connected
Figure 19.24 Pin Connection for Smart Card Interface
Rev. 2.00 Oct. 21, 2009 Page 932 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.7.2
Data Format (Except in Block Transfer Mode)
Figure 19.25 shows the data transfer formats in smart card interface mode.
• One frame contains 8-bit data and a parity bit in asynchronous mode.
• During transmission, at least 2 etu (elementary time unit: time required for transferring one bit)
is secured as a guard time after the end of the parity bit before the start of the next frame.
• If a parity error is detected during reception, a low error signal is output for 1 etu after 10.5 etu
has passed from the start bit.
• If an error signal is sampled during transmission, the same data is automatically re-transmitted
after at least 2 etu.
In normal transmission/reception
Ds
D0
D1
D2
D3
D4
D5
D6
D7
Dp
D7
Dp
Output from the transmitting station
When a parity error is generated
Ds
D0
D1
D2
D3
D4
D5
D6
DE
Output from the transmitting station
[Legend]
Ds:
D0 to D7:
Dp:
DE:
Output from
the receiving station
Start bit
Data bits
Parity bit
Error signal
Figure 19.25 Data Formats in Normal Smart Card Interface Mode
For communication with the smart cards of the direct convention and inverse convention types,
follow the procedure below.
(Z)
A
Z
Z
A
Z
Z
Z
A
A
Z
Ds
D0
D1
D2
D3
D4
D5
D6
D7
Dp
(Z) state
Figure 19.26 Direct Convention (SDIR = SINV = O/E = 0)
Rev. 2.00 Oct. 21, 2009 Page 933 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
For the direct convention type, logic levels 1 and 0 correspond to states Z and A, respectively, and
data is transferred with LSB-first as the start character, as shown in figure 19.26. Therefore, data
in the start character in the figure is H'3B. When using the direct convention type, write 0 to both
the SDIR and SINV bits in SCMR. Write 0 to the O/E bit in SMR in order to use even parity,
which is prescribed by the smart card standard.
(Z)
A
Z
Z
A
A
A
A
A
A
Z
Ds
D7
D6
D5
D4
D3
D2
D1
D0
Dp
(Z) state
Figure 19.27 Inverse Convention (SDIR = SINV = O/E = 1)
For the inverse convention type, logic levels 1 and 0 correspond to states A and Z, respectively
and data is transferred with MSB-first as the start character, as shown in figure 19.27. Therefore,
data in the start character in the figure is H'3F. When using the inverse convention type, write 1 to
both the SDIR and SINV bits in SCMR. The parity bit is logic level 0 to produce even parity,
which is prescribed by the smart card standard, and corresponds to state Z. Since the SNIV bit of
this LSI only inverts data bits D7 to D0, write 1 to the O/E bit in SMR to invert the parity bit in
both transmission and reception.
19.7.3
Block Transfer Mode
Block transfer mode is different from normal smart card interface mode in the following respects.
• Even if a parity error is detected during reception, no error signal is output. Since the PER bit
in SSR is set by error detection, clear the PER bit before receiving the parity bit of the next
frame.
• During transmission, at least 1 etu is secured as a guard time after the end of the parity bit
before the start of the next frame.
• Since the same data is not re-transmitted during transmission, the TEND flag is set 11.5 etu
after transmission start.
• Although the ERS flag in block transfer mode displays the error signal status as in normal
smart card interface mode, the flag is always read as 0 because no error signal is transferred.
Rev. 2.00 Oct. 21, 2009 Page 934 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.7.4
Receive Data Sampling Timing and Reception Margin
Only the internal clock generated by the on-chip baud rate generator can be used as a transfer
clock in smart card interface mode. In this mode, the SCI can operate on a base clock with a
frequency of 32, 64, 372, or 256 times the bit rate according to the BCP1 and BCP0 bit settings
(the frequency is always 16 times the bit rate in normal asynchronous mode). At reception, the
falling edge of the start bit is sampled using the base clock in order to perform internal
synchronization. Receive data is sampled on the 16th, 32nd, 186th and 128th rising edges of the
base clock so that it can be latched at the middle of each bit as shown in figure 19.28. The
reception margin here is determined by the following formula.
M = | (0.5 –
1
) – (L – 0.5) F – | D – 0.5 | (1 + F ) | × 100%
2N
N
[Legend]
M: Reception margin (%)
N: Ratio of bit rate to clock (N = 32, 64, 372, 256)
D: Duty cycle of clock (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 is
determined by the formula below.
M=
( 0.5 –
1
) × 100% = 49.866%
2 × 372
372 clock cycles
186 clock
cycles
0
185
371 0
185
371 0
Internal
basic clock
Receive data
(RxD)
Start bit
D0
D1
Synchronization
sampling timing
Data sampling
timing
Figure 19.28 Receive Data Sampling Timing in Smart Card Interface Mode
(When Clock Frequency is 372 Times the Bit Rate)
Rev. 2.00 Oct. 21, 2009 Page 935 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.7.5
Initialization
Before transmitting and receiving data, initialize the SCI using the following procedure.
Initialization is also necessary before switching from transmission to reception and vice versa.
1.
2.
3.
4.
5.
6.
7.
8.
Clear the TE and RE bits in SCR to 0.
Set the ICR bit of the corresponding pin to 1.
Clear the error flags ERS, PER, and ORER in SSR to 0.
Set the GM, BLK, O/E, BCP1, BCP0, CKS1, and CKS0 bits in SMR appropriately. Also set
the PE bit to 1.
Set the SMIF, SDIR, and SINV bits in SCMR appropriately. When the DDR corresponding to
the TxD pin is cleared to 0, the TxD and RxD pins are changed from port pins to SCI pins,
placing the pins into high impedance state.
Set the value corresponding to the bit rate in BRR.
Set the CKE1 and CKE0 bits in SCR appropriately. Clear the TIE, RIE, TE, RE, MPIE, and
TEIE bits to 0 simultaneously.
When the CKE0 bit is set to 1, the SCK pin is allowed to output clock pulses.
Set the TIE, RIE, TE, and RE bits in SCR appropriately after waiting for at least a 1-bit
interval. Setting the TE and RE bits to 1 simultaneously is prohibited except for self diagnosis.
To switch from reception to transmission, first verify that reception has completed, then initialize
the SCI. At the end of initialization, RE and TE should be set to 0 and 1, respectively. Reception
completion can be verified by reading the RDRF, PER, or ORER flag. To switch from
transmission to reception, first verify that transmission has completed, then initialize the SCI. At
the end of initialization, TE and RE should be set to 0 and 1, respectively. Transmission
completion can be verified by reading the TEND flag.
Rev. 2.00 Oct. 21, 2009 Page 936 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.7.6
Data Transmission (Except in Block Transfer Mode)
Data transmission in smart card interface mode (except in block transfer mode) is different from
that in normal serial communication interface mode in that an error signal is sampled and data can
be re-transmitted. Figure 19.29 shows the data re-transfer operation during transmission.
1. If an error signal from the receiving end is sampled after one frame of data has been
transmitted, the ERS bit in SSR is set to 1. Here, an ERI interrupt request is generated if the
RIE bit in SCR is set to 1. Clear the ERS bit to 0 before the next parity bit is sampled.
2. For the frame in which an error signal is received, the TEND bit in SSR is not set to 1. Data is
re-transferred from TDR to TSR allowing automatic data retransmission.
3. If no error signal is returned from the receiving end, the ERS bit in SSR is not set to 1.
4. In this case, one frame of data is determined to have been transmitted including re-transfer, and
the TEND bit in SSR is set to 1. Here, a TXI interrupt request is generated if the TIE bit in
SCR is set to 1. Writing transmit data to TDR starts transmission of the next data.
Figure 19.31 shows a sample flowchart for transmission. All the processing steps are
automatically performed using a TXI interrupt request to activate the DTC or DMAC. In
transmission, the TEND and TDRE flags in SSR are simultaneously set to 1, thus generating a
TXI interrupt request if the TIE bit in SCR has been set to 1. This activates the DTC or DMAC by
a TXI request thus allowing transfer of transmit data if the TXI interrupt request is specified as a
source of DTC or DMAC activation beforehand. The TDRE and TEND flags are automatically
cleared to 0 at data transfer by the DTC or DMAC. If an error occurs, the SCI automatically retransmits the same data. During re-transmission, TEND remains as 0, thus not activating the DTC
or DMAC. Therefore, the SCI and DTC or DMAC automatically transmit the specified number of
bytes, including re-transmission in the case of error occurrence. However, the ERS flag is not
automatically cleared; the ERS flag must be cleared by previously setting the RIE bit to 1 to
enable an ERI interrupt request to be generated at error occurrence.
When transmitting/receiving data using the DTC or DMAC, be sure to set and enable the DTC or
DMAC prior to making SCI settings. For DTC or DMAC settings, see section 12, Data Transfer
Controller (DTC) and section 10, DMA Controller (DMAC).
Rev. 2.00 Oct. 21, 2009 Page 937 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
(n + 1) th
transfer frame
Retransfer 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 from TDR to TSR
Transfer from TDR to TSR
Transfer from TDR to TSR
TEND
[2]
[4]
FER/ERS
[1]
[3]
Figure 19.29 Data Re-Transfer Operation in SCI Transmission Mode
Note that the TEND flag is set in different timings depending on the GM bit setting in SMR.
Figure 19.30 shows the TEND flag set timing.
Ds
I/O data
D0
D1
D2
D3
D4
D5
D6
D7
Dp
DE
Guard time
TXI
(TEND interrupt)
12.5 etu
GM = 0
11.0 etu
GM = 1
[Legend]
Ds:
D0 to D7:
Dp:
DE:
Start bit
Data bits
Parity bit
Error signal
Figure 19.30 TEND Flag Set Timing during Transmission
Rev. 2.00 Oct. 21, 2009 Page 938 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
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 in SCR to 0
End
Figure 19.31 Sample Transmission Flowchart
Rev. 2.00 Oct. 21, 2009 Page 939 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.7.7
Serial Data Reception (Except in Block Transfer Mode)
Data reception in smart card interface mode is similar to that in normal serial communication
interface mode. Figure 19.32 shows the data re-transfer operation during reception.
1. If a parity error is detected in receive data, the PER bit in SSR is set to 1. Here, an ERI
interrupt request is generated if the RIE bit in SCR is set to 1. Clear the PER bit to 0 before the
next parity bit is sampled.
2. For the frame in which a parity error is detected, the RDRF bit in SSR is not set to 1.
3. If no parity error is detected, the PER bit in SSR is not set to 1.
4. In this case, data is determined to have been received successfully, and the RDRF bit in SSR is
set to 1. Here, an RXI interrupt request is generated if the RIE bit in SCR is set to 1.
Figure 19.33 shows a sample flowchart for reception. All the processing steps are automatically
performed using an RXI interrupt request to activate the DTC or DMAC. In reception, setting the
RIE bit to 1 allows an RXI interrupt request to be generated when the RDRF flag is set to 1. This
activates the DTC or DMAC by an RXI request thus allowing transfer of receive data if the RXI
interrupt request is specified as a source of DTC or DMAC activation beforehand. The RDRF flag
is automatically cleared to 0 at data transfer by the DTC or DMAC. If an error occurs during
reception, i.e., either the ORER or PER flag is set to 1, a transmit/receive error interrupt (ERI)
request is generated and the error flag must be cleared. If an error occurs, the DTC or DMAC is
not activated and receive data is skipped, therefore, the number of bytes of receive data specified
in the DTC or DMAC is transferred. Even if a parity error occurs and the PER bit is set to 1 in
reception, receive data is transferred to RDR, thus allowing the data to be read.
Note: For operations in block transfer mode, see section 19.4, Operation in Asynchronous Mode.
(n + 1) th
transfer frame
Retransfer 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
RDRF
[2]
[4]
[1]
[3]
PER
Figure 19.32 Data Re-Transfer Operation in SCI Reception Mode
Rev. 2.00 Oct. 21, 2009 Page 940 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Start
Initialization
Start reception
ORER = 0
and PER = 0?
No
Yes
No
Error processing
RDRF = 1?
Yes
Read data from RDR and
clear RDRF flag in SSR to 0
No
All data received?
Yes
Clear RE bit in SCR to 0
Figure 19.33 Sample Reception Flowchart
19.7.8
Clock Output Control (Only SCI_0, 1, 2, and 4)
Clock output can be fixed using the CKE1 and CKE0 bits in SCR when the GM bit in SMR is set
to 1. Specifically, the minimum width of a clock pulse can be specified.
Figure 19.34 shows an example of clock output fixing timing when the CKE0 bit is controlled
with GM = 1 and CKE1 = 0.
CKE0
SCK
Given pulse width
Given pulse width
Figure 19.34 Clock Output Fixing Timing
Rev. 2.00 Oct. 21, 2009 Page 941 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
At power-on and transitions to/from software standby mode, use the following procedure to secure
the appropriate clock duty cycle.
• At power-on
To secure the appropriate clock duty cycle simultaneously with power-on, use the following
procedure.
1. Initially, port input is enabled in the high-impedance state. To fix the potential level, use a
pull-up or pull-down resistor.
2. Fix the SCK pin to the specified output using the CKE1 bit in SCR.
3. Set SMR and SCMR to enable smart card interface mode.
Set the CKE0 bit in SCR to 1 to start clock output.
• At mode switching
a) At transition 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 values for the output fixed state in software standby mode. (SCI_0, 1, 2, and
4 only)
2. Write 0 to the TE and RE bits in SCR to stop transmission/reception. Simultaneously,
set the CKE1 bit to the value for the output fixed state in software standby mode.
3. Write 0 to the CKE0 bit in SCR to stop the clock.
4. Wait for one cycle of the serial clock. In the mean time, the clock output is fixed to the
specified level with the duty cycle retained.
5. Make the transition to software standby mode.
b) At transition from software standby mode to smart card interface mode
1. Clear software standby mode.
2. Write 1 to the CKE0 bit in SCR to start clock output. A clock signal with the
appropriate duty cycle is then generated.
Software
standby
Normal operation
[1] [2] [3]
[4] [5]
Normal operation
[6]
[7]
Figure 19.35 Clock Stop and Restart Procedure
Rev. 2.00 Oct. 21, 2009 Page 942 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.8
IrDA Operation
If the IrDA function is enabled using the IrE bit in IrCR, the TxD5 and RxD5 pins in SCI_5 are
allowed to encode and decode the waveform based on the IrDA Specifications version 1.0
(function as the IrTxD and IrRxD pins)*. Connecting these pins to the infrared data transceiver
achieves infrared data communication based on the system defined by the IrDA Specifications
version 1.0.
In the system defined by the IrDA Specifications version 1.0, communication is started at a
transfer rate of 9600 bps, which can be modified later as required. Since the IrDA interface
provided by this LSI does not incorporate the capability of automatic modification of the transfer
rate, the transfer rate must be modified through programming.
Figure 19.36 is the IrDA block diagram.
IrDA
TxD5/IrTxD
Pulse encoder
RxD5/IrRxD
Pulse decoder
SCI5
TxD
RxD
IrCR
Figure 19.36 IrDA Block Diagram
Note: * The IrDA function should be used when the ABCS bit in SEMR_5 is set to 0 and the
ACS3 to ACS0 bits in SEMR_5 are set to B'0000.
Rev. 2.00 Oct. 21, 2009 Page 943 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
(1)
Transmission
During transmission, the output signals from the SCI (UART frames) are converted to IR frames
using the IrDA interface (see figure 19.37).
For serial data of level 0, a high-level pulse having a width of 3/16 of the bit rate (1-bit interval) is
output (initial setting). The high-level pulse can be selected using the IrCKS2 to IrCKS0 bits in
IrCR.
The high-level pulse width is defined to be 1.41 μs at minimum and (3/16 + 2.5%) × bit rate or
(3/16 × bit rate) +1.08 μs at maximum. For example, when the frequency of system clock φ is 20
MHz, a high-level pulse width of 1.6 µs can be specified because it is the smallest value in the
range greater than 1.41 µs.
For serial data of level 1, no pulses are output.
UART frame
Data
Start
bit
0
1
0
1
0
0
Stop
bit
1
Transmission
1
0
1
Reception
IR frame
Data
Start
bit
0
1
0
Bit
cycle
1
0
0
Stop
bit
1
1
0
1
Pulse width is 1.6 μs to
3/16 bit cycle
Figure 19.37 IrDA Transmission and Reception
(2)
Reception
During reception, IR frames are converted to UART frames using the IrDA interface before
inputting to SCI. 0 is output when the high level pulse is detected while 1 is output when no pulse
is detected during one bit period. Note that a pulse shorter than the minimum pulse width of 1.41
μs is also regarded as a 0 signal.
Rev. 2.00 Oct. 21, 2009 Page 944 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
(3)
High-Level Pulse Width Selection
Table 19.13 shows possible settings for bits IrCKS2 to IrCKS0 (minimum pulse width), and this
LSI's operating frequencies and bit rates, for making the pulse width shorter than 3/16 times the bit
rate in transmission.
Table 19.13 IrCKS2 to IrCKS0 Bit Settings
Bit Rate (bps) (Upper Row)/Bit Interval × 3/16 (µs) (Lower Row)
Operating
Frequency
Pφ (MHz)
2400
9600
19200
38400
57600
115200
78.13
19.53
9.77
4.88
3.26
1.63
7.3728
100
100
100
100
100
100
8
100
100
100
100
100
100
9.8304
100
100
100
100
100
100
10
100
100
100
100
100
100
12
101
101
101
101
101
101
12.288
101
101
101
101
101
101
14
101
101
101
101
101
101
14.7456
101
101
101
101
101
101
16
101
101
101
101
101
101
17.2032
101
101
101
101
101
101
18
101
101
101
101
101
101
19.6608
101
101
101
101
101
101
20
101
101
101
101
101
101
25
110
110
110
110
110
110
30
110
110
110
110
110
110
33
110
110
110
110
110
110
35
110
110
110
110
110
110
Rev. 2.00 Oct. 21, 2009 Page 945 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.9
Interrupt Sources
19.9.1
Interrupts in Normal Serial Communication Interface Mode
Table 19.14 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 request can activate the
DTC or DMAC to allow data transfer. The TDRE flag is automatically cleared to 0 at data transfer
by the DTC or DMAC.
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 can
activate the DTC or DMAC to allow data transfer. The RDRF flag is automatically cleared to 0 at
data transfer by the DTC or DMAC.
A TEI interrupt is requested when the TEND flag is set to 1 while 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, note that if the TDRE and TEND flags are cleared to 0 simultaneously by
the TXI interrupt processing routine, the SCI cannot branch to the TEI interrupt processing routine
later.
Note that the priority order for interrupts is different between the group of SCI_0, 1, 2, and 4 and
the group of SCI_5 and SCI_6.
Table 19.14 SCI Interrupt Sources (SCI_0, 1, 2, and 4)
Name
Interrupt Source
Interrupt Flag
DTC Activation
DMAC Activation
Priority
ERI
Receive error
ORER, FER, or PER
Not possible
Not possible
High
RXI
Receive data full
RDRF
Possible
Possible
TXI
Transmit data empty TDRE
Possible
Possible
TEI
Transmit end
Not possible
Not possible
TEND
Rev. 2.00 Oct. 21, 2009 Page 946 of 1454
REJ09B0498-0200
Low
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Table 19.15 SCI Interrupt Sources (SCI_5 and SCI_6)
Name
Interrupt Source
Interrupt Flag
RXI
Receive data full
RDRF
TXI
Transmit data empty TDRE
ERI
Receive error
ORER, FER, or PER
Not possible
Not possible
TEI
Transmit end
TEND
Not possible
Not possible
19.9.2
DTC Activation
DMAC Activation
Priority
Not possible
Possible
High
Not possible
Possible
Low
Interrupts in Smart Card Interface Mode
Table 19.16 shows the interrupt sources in smart card interface mode. A transmit end (TEI)
interrupt request cannot be used in this mode.
Note that the priority order for interrupts is different between the group of SCI_0, 1, 2, and 4 and
the group of SCI_5 and SCI_6.
Table 19.16 SCI Interrupt Sources (SCI_0, 1, 2, and 4)
Name
Interrupt Source
ERI
Interrupt Flag
DTC Activation
DMAC Activation
Priority
Receive error or error ORER, PER, or ERS
signal detection
Not possible
Not possible
High
RXI
Receive data full
RDRF
Possible
Possible
TXI
Transmit data empty
TEND
Possible
Possible
Low
Table 19.17 SCI Interrupt Sources (SCI_5 and SCI_6)
Name
Interrupt Source
Interrupt Flag
DTC Activation
DMAC Activation
Priority
RXI
Receive data full
RDRF
Not possible
Possible
High
TXI
Transmit data empty
TDRE
Not possible
Possible
ERI
Receive error or error ORER, PER, or ERS
signal detection
Not possible
Not possible
Low
Rev. 2.00 Oct. 21, 2009 Page 947 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Data transmission/reception using the DTC or DMAC is also possible in smart card interface
mode, similar to in the normal SCI mode. In transmission, the TEND and TDRE flags in SSR are
simultaneously set to 1, thus generating a TXI interrupt. This activates the DTC or DMAC by a
TXI request thus allowing transfer of transmit data if the TXI request is specified as a source of
DTC or DMAC activation beforehand. The TDRE and TEND flags are automatically cleared to 0
at data transfer by the DTC or DMAC. If an error occurs, the SCI automatically re-transmits the
same data. During re-transmission, the TEND flag remains as 0, thus not activating the DTC or
DMAC. Therefore, the SCI and DTC or DMAC automatically transmit the specified number of
bytes, including re-transmission in the case of error occurrence. However, the ERS flag in SSR,
which is set at error occurrence, is not automatically cleared; the ERS flag must be cleared by
previously setting the RIE bit in SCR to 1 to enable an ERI interrupt request to be generated at
error occurrence.
When transmitting/receiving data using the DTC or DMAC, be sure to set and enable the DTC or
DMAC prior to making SCI settings. For DTC or DMAC settings, see section 12, Data Transfer
Controller (DTC) and section 10, DMA Controller (DMAC).
In reception, an RXI interrupt request is generated when the RDRF flag in SSR is set to 1. This
activates the DTC or DMAC by an RXI request thus allowing transfer of receive data if the RXI
request is specified as a source of DTC or DMAC activation beforehand. The RDRF flag is
automatically cleared to 0 at data transfer by the DTC or DMAC. If an error occurs, the RDRF
flag is not set but the error flag is set. Therefore, the DTC or DMAC is not activated and an ERI
interrupt request is issued to the CPU instead; the error flag must be cleared.
Rev. 2.00 Oct. 21, 2009 Page 948 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.10
Usage Notes
19.10.1 Module Stop Function Setting
Operation of the SCI can be disabled or enabled using the module stop control register. The initial
setting is for operation of the SCI to be halted. Register access is enabled by clearing the module
stop state. For details, see section 28, Power-Down Modes.
19.10.2 Break Detection and Processing
When framing error 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, and so the FER flag is set, and the
PER flag may also be set. Note that, since the SCI continues the receive operation even after
receiving a break, even if the FER flag is cleared to 0, it will be set to 1 again.
19.10.3 Mark State and Break Detection
When the TE bit is 0, the TxD pin is used as an I/O port whose direction (input or output) and
level are determined by DR and 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 in mark
state (the state of 1) until TE is set to 1, set both DDR and DR to 1. Since the TE bit 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 DDR to 1 and DR to 0, and then clear the TE bit to 0. When the
TE bit 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.
19.10.4 Receive Error Flags and Transmit Operations (Clocked Synchronous Mode Only)
Transmission cannot be started when a receive error flag (ORER, FER, or RER) 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 the receive error flags cannot be cleared to 0 even if the RE bit is
cleared to 0.
Rev. 2.00 Oct. 21, 2009 Page 949 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.10.5 Relation between Writing to TDR and TDRE Flag
The TDRE flag in SSR is a status flag which indicates that transmit data has been transferred from
TDR to TSR. When the SCI transfers data from TDR to TSR, the TDRE flag is set to 1.
Data can be written to TDR irrespective of the TDRE flag status. However, if new data is written
to TDR when the TDRE flag is 0, that is, when the previous data has not been transferred to TSR
yet, the previous data in TDR is lost. Be sure to write transmit data to TDR after verifying that the
TDRE flag is set to 1.
19.10.6 Restrictions on Using DTC or DMAC
• When the external clock source is used as a synchronization clock, update TDR by the DMAC
or DTC and wait for at least five Pφ clock cycles before allowing the transmit clock to be
input. If the transmit clock is input within four clock cycles after TDR modification, the SCI
may malfunction (see figure 19.38).
• When using the DMAC or DTC to read RDR, be sure to set the receive end interrupt (RXI) as
the DTC or DMAC activation source.
SCK
t
TDRE
LSB
Serial data
D0
D1
D2
D3
D4
D5
D6
D7
Note: When external clock is supplied, t must be more than four clock cycles.
Figure 19.38 Sample Transmission using DTC in Clocked Synchronous Mode
• The DTC is not activated by the RXI or TXI request by SCI_5 or SCI6.
Rev. 2.00 Oct. 21, 2009 Page 950 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.10.7 SCI Operations during Power-Down State
Transmission: Before specifying the module stop state or making a transition to software standby
mode, stop the transmit operations (TE = TIE = TEIE = 0). TSR, TDR, and SSR are reset. The
states of the output pins in the module stop state or in software standby mode depend on the port
settings, and the pins output a high-level signal after cancellation. If the transition is made during
data transmission, the data being transmitted will be undefined.
To transmit data in the same transmission mode after cancellation of the power-down state, set the
TE bit to 1, read SSR, write to TDR, clear TDRE in this order, and then start transmission. To
transmit data in a different transmission mode, initialize the SCI first.
Figure 19.39 shows a sample flowchart for transition to software standby mode during
transmission. Figures 19.40 and 19.41 show the port pin states during transition to software
standby mode.
Before specifying the module stop state or making a transition to software standby mode from the
transmission mode using DTC transfer, stop all transmit operations (TE = TIE = TEIE = 0).
Setting the TE and TIE bits to 1 after cancellation sets the TXI flag to start transmission using the
DTC.
Reception: Before specifying the module stop state or making a transition to software standby
mode, stop the receive operations (RE = 0). RSR, RDR, and SSR are reset. If transition is made
during data reception, the data being received will be invalid.
To receive data in the same reception mode after cancellation of the power-down state, set the RE
bit to 1, and then start reception. To receive data in a different reception mode, initialize the SCI
first.
For using the IrDA function, set the IrE bit in addition to setting the RE bit.
Figure 19.42 shows a sample flowchart for mode transition during reception.
Rev. 2.00 Oct. 21, 2009 Page 951 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Transmission
No
All data transmitted?
[1]
[1] Data being transmitted is lost
halfway. Data can be normally
transmitted from the CPU by
setting the TE bit to 1, reading
SSR, writing to TDR, and
clearing the TDRE bit to 0 after
clearing software standby mode;
however, if the DTC has been
activated, the data remaining in
the DTC will be transmitted when
both the TE and TIE bits are set
to 1.
Yes
Read TEND flag in SSR
No
TEND = 1
Yes
TE = 0
[2]
Make transition to
software standby mode
[2] Clear the TIE and TEIE bits to 0
when they are 1.
[3]
[3] Setting of the module stop state
is included.
Cancel software standby mode
No
Change operating mode?
Yes
Initialization
TE = 1
Start transmission
Figure 19.39 Sample Flowchart for Software Standby Mode Transition during
Transmission
Transmission start
Transition to
Software standby
Transmission end software standby mode canceled
mode
TE bit
SCK*
output pin
TxD
output pin
Port
input/output
Port
input/output
High output
Port
Start
SCI TxD output
Stop
Port input/output
High output
Port
Note: * Not output in SCI_5, 6.
Figure 19.40 Port Pin States during Software Standby Mode Transition
(Internal Clock, Asynchronous Transmission)
Rev. 2.00 Oct. 21, 2009 Page 952 of 1454
REJ09B0498-0200
SCI
TxD output
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Transmission start
Transmission end
Transition to
Software standby
software standby mode canceled
mode
TE bit
SCK
output pin
TxD
output pin
Port
input/output
Port
input/output
Marking output
Last TxD bit retained
SCI TxD output
Port
Port input/output
High output*
SCI
TxD output
Port
Note: * Initialized in software standby mode
Figure 19.41 Port Pin States during Software Standby Mode Transition
(Internal Clock, Clocked Synchronous Transmission)
(Setting is Prohibited in SCI_5 and SCI_6)
Reception
Read RDRF flag in SSR
RDRF = 1
No
[1]
[1] Data being received will be invalid.
Yes
Read receive data in RDR
[2] Setting of the module stop state is included.
RE = 0
Make transition to
software standby mode
[2]
Cancel software standby mode
Change operating mode?
No
Yes
Initialization
RE = 1
Start reception
Figure 19.42 Sample Flowchart for Software Standby Mode Transition during Reception
Rev. 2.00 Oct. 21, 2009 Page 953 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.11
CRC Operation Circuit
The cyclic redundancy check (CRC) operation circuit detects errors in data blocks.
19.11.1 Features
The features of the CRC operation circuit are listed below.
•
•
•
•
CRC code generated for any desired data length in an 8-bit unit
CRC operation executed on eight bits in parallel
One of three generating polynomials selectable
CRC code generation for LSB-first or MSB-first communication selectable
Figure 19.43 shows a block diagram of the CRC operation circuit.
Internal bus
CRCCR
CRCDIR
Control
signal
CRC code
generation
circuit
CRCDOR
[Legend]
CRCCR: CRC control register
CRCDIR: CRC data input register
CRCDOR: CRC data output register
Figure 19.43 Block Diagram of CRC Operation Circuit
Rev. 2.00 Oct. 21, 2009 Page 954 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.11.2 Register Descriptions
The CRC operation circuit has the following registers.
• CRC control register (CRCCR)
• CRC data input register (CRCDIR)
• CRC data output register (CRCDOR)
(1)
CRC Control Register (CRCCR)
CRCCR initializes the CRC operation circuit, switches the operation mode, and selects the
generating polynomial.
Bit
Bit Name
7
6
5
4
3
2
1
0
DORCLR
⎯
⎯
⎯
⎯
LMS
G1
G0
Initial Value
0
0
0
0
0
0
0
0
R/W
W
R
R
R
R
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
DORCLR
0
W
CRCDOR Clear
Setting this bit to 1 clears CRCDOR to H'0000.
6 to 3
—
All 0
R
Reserved
The initial value should not be changed.
2
LMS
0
R/W
CRC Operation Switch
Selects CRC code generation for LSB-first or MSB-first
communication.
0: Performs CRC operation for LSB-first
communication. The lower byte (bits 7 to 0) is first
transmitted when CRCDOR contents (CRC code)
are divided into two bytes to be transmitted in two
parts.
1: Performs CRC operation for MSB-first
communication. The upper byte (bits 15 to 8) is first
transmitted when CRCDOR contents (CRC code)
are divided into two bytes to be transmitted in two
parts.
Rev. 2.00 Oct. 21, 2009 Page 955 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
Bit
Bit Name
Initial
Value
R/W
Description
1
G1
0
R/W
CRC Generating Polynomial Select:
0
G0
0
R/W
Selects the polynomial.
00: Reserved
8
2
01: X + X + X + 1
16
15
2
10: X + X + X + 1
16
12
5
11: X + X + X + 1
(2)
CRC Data Input Register (CRCDIR)
CRCDIR is an 8-bit readable/writable register, to which the bytes to be CRC-operated are written.
The result is obtained in CRCDOR.
Bit
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
Initial Value
R/W
(3)
CRC Data Output Register (CRCDOR)
CRCDOR is a 16-bit readable/writable register that contains the result of CRC operation when the
bytes to be CRC-operated are written to CRCDIR after CRCDOR is cleared. When the CRC
operation result is additionally written to the bytes to which CRC operation is to be performed, the
CRC operation result will be H'0000 if the data contains no CRC error. When bits 1 and 0 in
CRCCR (G1 and G0 bits) are set to 0 and 1, respectively, the lower byte of this register contains
the result.
Bit
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial Value
R/W
Rev. 2.00 Oct. 21, 2009 Page 956 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.11.3 CRC Operation Circuit Operation
The CRC operation circuit generates a CRC code for LSB-first/MSB-first communications. An
example in which a CRC code for hexadecimal data H'F0 is generated using the X16 + X12 + X5 + 1
polynomial with the G1 and G0 bits in CRCCR set to B'11 is shown below.
1. Write H'83 to CRCCR
7
CRCCR
0
1
2. Write H'F0 to CRCDIR
7
0
0
0
0
0
CRCDIR
1 1
1
1
0
1
1
0
0 0
CRC code generation
CRCDOR clearing
0
7
0
0
7
CRCDORH
0
0
0
0
0
0
0 0
CRCDORH
1
1
1
1
0
1
1 1
CRCDORL
0
0
0
0
0
0
0 0
CRCDORL
1
0
0
0
1
1
1 1
3. Read from CRCDOR
CRC code = H'F78F
4. Serial transmission (LSB first)
Data
CRC code
7
1
1
1
1
0
1
1
F
0
7
1
1
0
7
0
0
1
1
8
1
0
7
1
1
0
1
F
1
1
0
0
F
0
0
Output
0
Figure 19.44 LSB-First Data Transmission
1. Write H'87 to CRCCR
7
CRCCR
1
0
2. Write H'F0 to CRCDIR
7
0
0
0
0
CRCDIR
1 1
1
1
CRCDOR clearing
0
7
1
1
0
1
0
0
0
0
CRC code generation
0
7
CRCDORH
0
0
0
0
0
0
0 0
CRCDORH
1
1
1
0
1
1
1
1
CRCDORL
0
0
0
0
0
0
0 0
CRCDORL
0
0
0
1
1
1
1
1
3. Read from CRCDOR
CRC code = H'EF1F
4. Serial transmission (MSB first)
CRC code
Data
7
Output
1
1
1
F
1
0
0
0
0
0
7
0
1
1
1
E
0
1
1
1
0
7
1
0
F
0
0
0
1
1
1
1
1
1
F
Figure 19.45 MSB-First Data Transmission
Rev. 2.00 Oct. 21, 2009 Page 957 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
1. Serial reception (LSB first)
Data
CRC code
7
1
1
1
1
0
1
1
F
0
7
1
1
0
7
0
0
8
2. Write H'83 to CRCCR
1
1
1
7
1
1
F
1
1
0
0
F
0
0
0
0
0
7
0
0
0
1
3. Write H'F0 to CRCDIR
7
CRCCR
1
0
0
0
0
0
1
1
CRCDIR
1
0
1
1
1
CRCDOR clearing
0
CRC code generation
0
7
0
0
7
CRCDORH
0
0
0
0
0
0
0
0
CRCDORH
1
1
1
1
0
1
1
1
CRCDORL
0
0
0
0
0
0
0
0
CRCDORL
1
0
0
0
1
1
1
1
1
0
1
1
1
4. Write H'8F to CRCDIR
5. Write H'F7 to CRCDIR
7
CRCDIR
1
7
0
0
0
0
1
1
1
1
CRCDIR
1
0
1
1
CRC code generation
CRC code generation
0
7
0
7
CRCDORH
0
0
0
0
0
0
0
0
CRCDORH
0
0
0
0
0
0
0
0
CRCDORL
1
1
1
1
0
1
1
1
CRCDORL
0
0
0
0
0
0
0
0
6. Read from CRCDOR
CRC code = H'0000 → No error
Figure 19.46 LSB-First Data Reception
Rev. 2.00 Oct. 21, 2009 Page 958 of 1454
REJ09B0498-0200
Input
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
1. Serial reception (MSB first)
Data
CRC code
7
Input
1
1
1
1
0
0
0
F
0
7
0
1
0
2. Write H'83 to CRCCR
1
1
0
1
1
E
0
7
1
0
0
0
F
0
1
1
1
0
0
0
1
1
1
CRCDIR
1
1
1
0
0
0
0
CRC code generation
0
0
7
CRCDORH
0
0
0
0
0
0
0
0
CRCDORH
1
1
1
0
1
1
1
1
CRCDORL
0
0
0
0
0
0
0
0
CRCDORL
0
0
0
1
1
1
1
1
1
1
1
1
1
4. Write H'EF to CRCDIR
5. Write H'1F to CRCDIR
7
1
7
0
1
1
0
1
CRCDOR clearing
7
CRCDIR
1
1
F
7
0
0
1
3. Write H'F0 to CRCDIR
7
CRCCR
1
1
0
1
1
1
1
CRCDIR
0
0
0
0
CRC code generation
CRC code generation
0
7
0
7
CRCDORH
0
0
0
1
1
1
1
1
CRCDORH
0
0
0
0
0
0
0
0
CRCDORL
0
0
0
0
0
0
0
0
CRCDORL
0
0
0
0
0
0
0
0
6. Read from CRCDOR
CRC code = H'0000 → No error
Figure 19.47 MSB-First Data Reception
Rev. 2.00 Oct. 21, 2009 Page 959 of 1454
REJ09B0498-0200
Section 19 Serial Communication Interface (SCI, IrDA, CRC)
19.11.4 Note on CRC Operation Circuit
Note that the sequence to transmit the CRC code differs between LSB-first transmission and
MSB-first transmission.
1. CRC code generation
After specifying the operation method, write data to CRCDIR in the sequence of (1) → (2) → (3) → (4).
7
0
(1) → (2) → (3) → (4)
CRCDIR
CRC code generation
0
7
CRCDORH
(5)
CRCDORL
(6)
2. Transmission data
(i) LSB-first transmission
CRC code
7
07
07
(6)
(5)
07
(4)
07
07
(3)
(2)
0
Output
(1)
(ii) MSB-first transmission
CRC code
7
Output
07
(1)
07
(2)
07
(3)
0 7
(4)
07
(5)
0
(6)
Figure 19.48 LSB-First and MSB-First Transmit Data
Rev. 2.00 Oct. 21, 2009 Page 960 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Section 20 USB Function Module (USB)
This LSI incorporates a USB function module (USB).
20.1
Features
• The UDC (USB device controller) conforming to USB2.0 and transceiver process USB
protocol automatically.
Automatic processing of USB standard commands for endpoint 0 (some commands and
class/vendor commands require decoding and processing by firmware)
• Transfer speed: Supports full-speed (12 Mbps)
• Endpoint configuration:
Endpoint
Name
Endpoint 0
Maximum
FIFO Buffer
Abbreviation Transfer Type Packet Size Capacity (Byte)
DMA Transfer
EP0s
Setup
8
8
—
EP0i
Control-in
8
8
—
EP0o
Control-out
8
8
—
Endpoint 1
EP1
Bulk-out
64
128
Possible
Endpoint 2
EP2
Bulk-in
64
128
Possible
Endpoint 3
EP3
Interrupt-in
8
8
—
Configuration1-Interface0-AlternateSetting0
EndPoint1
EndPoint2
EndPoint3
• Interrupt requests: Generates various interrupt signals necessary for USB
transmission/reception
• Power mode: Self power mode or bus power mode can be selected by the power mode bit
(PWMD) in the control register (CTLR).
Rev. 2.00 Oct. 21, 2009 Page 961 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Figure 20.1 shows the block diagram of the USB.
Peripheral bus
USB function module
Status and
control registers
Interrupt requests
D+
UDC
Transceiver
FIFO
Clock for USB
(48 MHz)
[Legend]
UDC: USB device controller
Figure 20.1 Block Diagram of USB
20.2
Input/Output Pins
Table 20.1 shows the USB pin configuration.
Table 20.1 Pin Configuration
Pin Name
I/O
Function
VBUS
Input
USB cable connection monitor pin
USD+
I/O
USB data I/O pin
USD-
I/O
USB data I/O pin
DrVcc
Input
Power supply pin for USB on-chip transceiver
DrVss
Input
Ground pin for USB on-chip transceiver
Rev. 2.00 Oct. 21, 2009 Page 962 of 1454
REJ09B0498-0200
D-
Section 20 USB Function Module (USB)
20.3
Register Descriptions
The USB has following registers. For the information on the addresses of these registers and the
state of the register in each processing condition, see section 29, List of Registers.
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
Interrupt flag register 0 (IFR0)
Interrupt flag register 1 (IFR1)
Interrupt flag register 2 (IFR2)
Interrupt select register 0 (ISR0)
Interrupt select register 1 (ISR1)
Interrupt select register 2 (ISR2)
Interrupt enable register 0 (IER0)
Interrupt enable register 1 (IER1)
Interrupt enable register 2 (IER2)
EP0i data register (EPDR0i)
EP0o data register (EPDR0o)
EP0s data register (EPDR0s)
EP1 data register (EPDR1)
EP2 data register (EPDR2)
EP3 data register (EPDR3)
EP0o receive data size register (EPSZ0o)
EP1 receive data size register (EPSZ1)
Trigger register (TRG)
Data status register (DASTS)
FIFO clear register (FCLR)
DMA transfer setting register (DMA)
Endpoint stall register (EPSTL)
Configuration value register (CVR)
Control register (CTLR)
Endpoint information register (EPIR)
Transceiver test register 0 (TRNTREG0)
Transceiver test register 1 (TRNTREG1)
Rev. 2.00 Oct. 21, 2009 Page 963 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.1
Interrupt Flag Register 0 (IFR0)
IFR0, together with interrupt flag registers 1and 2 (IFR1and IFR2), indicates interrupt status
information required by the application. When an interrupt source is generated, the corresponding
bit is set to 1. And then this bit, in combination with interrupt enable register 0 (IER0), generates
an interrupt request to the CPU. To clear, write 0 to the bit to be cleared and 1 to the other bits.
However, since EP1FULL and EP2EMPTY are status bits, these bits cannot be cleared.
Bit
Bit Name
7
6
5
BRST
EP1 FULL
EP2 TR
Initial Value
R/W
4
3
EP2 EMPTY SETUP TS
2
1
0
EP0o TS
EP0i TR
EP0i TS
0
0
0
1
0
0
0
0
R/W
R
R/W
R
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
BRST
0
R/W
Bus Reset
This bit is set to 1 when a bus reset signal is detected on
the USB bus.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
6
EP1 FULL
0
R
EP1 FIFO Full
This bit is set when endpoint 1 receives one packet of
data successfully from the host, and holds a value of 1
as long as there is valid data in the FIFO buffer.
This is a status bit, and cannot be cleared.
5
EP2 TR
0
R/W
EP2 Transfer Request
This bit is set if there is no valid transmit data in the FIFO
buffer when an IN token for endpoint 2 is received from
the host. A NACK handshake is returned to the host until
data is written to the FIFO buffer and packet
transmission is enabled.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
Rev. 2.00 Oct. 21, 2009 Page 964 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Bit
Bit Name
Initial
Value
R/W
Description
4
EP2 EMPTY
1
R
EP2 FIFO Empty
This bit is set when at least one of the dual endpoint 2
transmit FIFO buffers is ready for transmit data to be
written.
This is a status bit, and cannot be cleared.
3
SETUP TS
0
R/W
Setup Command Receive Complete
This bit is set to 1 when endpoint 0 receives successfully
a setup command requiring decoding on the application
side, and returns an ACK handshake to the host.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
2
EP0o TS
0
R/W
EP0o Receive Complete
This bit is set to 1 when endpoint 0 receives data from
the host successfully, stores the data in the FIFO buffer,
and returns an ACK handshake to the host.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
1
EP0i TR
0
R/W
EP0i Transfer Request
This bit is set if there is no valid transmit data in the
FIFO buffer when an IN token for endpoint 0 is received
from the host. A NACK handshake is returned to the
host until data is written to the FIFO buffer and packet
transmission is enabled.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
0
EP0i TS
0
R/W
EP0i Transmit Complete
This bit is set when data is transmitted to the host from
endpoint 0 and an ACK handshake is returned.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
Rev. 2.00 Oct. 21, 2009 Page 965 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.2
Interrupt Flag Register 1 (IFR1)
IFR1, together with interrupt flag registers 0 and 2 (IFR0 and IFR2), indicates interrupt status
information required by the application. When an interrupt source is generated, the corresponding
bit is set to 1. And then this bit, in combination with interrupt enable register 1 (IER1), generates
an interrupt request to the CPU. To clear, write 0 to the bit to be cleared and 1 to the other bits.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
VBUS MN
EP3 TR
EP3 TS
VBUSF
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
—
0
R
5
—
0
R
These bits are always read as 0. The write value
should always be 0.
4
—
0
R
3
VBUS MN
0
R
This is a status bit which monitors the state of the
VBUS pin.
This bit reflects the state of the VBUS pin and
generates no interrupt request. This bit is always 0
when the PULLUP_E bit in DMA is 0.
2
EP3 TR
0
R/W
EP3 Transfer Request
This bit is set if there is no valid transmit data in the
FIFO buffer when an IN token for endpoint 3 is
received from the host. A NACK handshake is returned
to the host until data is written to the FIFO buffer and
packet transmission is enabled.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
1
EP3 TS
0
R/W
EP3 Transmit Complete
This bit is set when data is transmitted to the host from
endpoint 3 and an ACK handshake is returned.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
Rev. 2.00 Oct. 21, 2009 Page 966 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Bit
Bit Name
Initial
Value
R/W
Description
0
VBUSF
0
R/W
USB Disconnection Detection
When the function is connected to the USB bus or
disconnected from it, this bit is set to 1. The VBUS pin
of this module is used for detecting connection or
disconnection.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
20.3.3
Interrupt Flag Register 2 (IFR2)
IFR2, together with interrupt flag registers 0 and 1 (IFR0 and IFR1), indicates interrupt status
information required by the application. When an interrupt source is generated, the corresponding
bit is set to 1. And then this bit, in combination with interrupt enable register 2 (IER2), generates
an interrupt request to the CPU. To clear, write 0 to the bit to be cleared and 1 to the other bits.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
SURSS
SURSF
CFDN
⎯
SETC
SETI
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R/W
R/W
R
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
—
0
R
Reserved
6
—
0
R
These bits are always read as 0. The write value
should always be 0.
5
SURSS
0
R
Suspend/Resume Status
This is a status bit that describes bus state.
0: Normal state
1: Suspended state
This bit is a status bit and generates no interrupt
request.
Rev. 2.00 Oct. 21, 2009 Page 967 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Bit
Bit Name
Initial
Value
R/W
Description
4
SURSF
0
R/W
Suspend/Resume Detection
This bit is set to 1 when the state changed from normal
to suspended state or vice versa. The corresponding
interrupt output is RESUME, USBINTN2, and
USBINTN3.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
3
CFDN
0
R/W
End Point Information Load End
This bit is set to 1 when writing data in the endpoint
information register to the EPIR register ends (load
end). This module starts the USB operation after the
endpoint information is completely set.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
2
—
0
R
Reserved
This bit is always read as 0. The write value should
always be 0.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
1
SETC
0
R/W
Set_Configuration Command Detection
When the Set_Configuration command is detected, this
bit is set to 1.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
0
SETI
0
R/W
Set_Interface Command Detection
When the Set_Interface command is detected, this bit
is set to 1.
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure to
read the flag after writing 0 to it.)
Rev. 2.00 Oct. 21, 2009 Page 968 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.4
Interrupt Select Register 0 (ISR0)
ISR0 selects the vector numbers of the interrupt requests indicated in interrupt flag register 0
(IFR0). If the USB issues an interrupt request to the INTC when a bit in ISR0 is cleared to 0, the
interrupt corresponding to the bit will be USBINTN2. If the USB issues an interrupt request to the
INTC when a bit in ISR0 is set to 1, the corresponding interrupt will be USBINTN3.
Bit
Bit Name
Initial Value
R/W
7
6
5
BRST
EP1 FULL
EP2 TR
4
3
EP2 EMPTY SETUP TS
2
1
0
EP0o TS
EP0i TR
EP0i TS
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
BRST
0
R/W
Bus Reset
6
EP1 FULL
0
R/W
EP1 FIFO Full
5
EP2 TR
0
R/W
EP2 Transfer Request
4
EP2 EMPTY 0
R/W
EP2 FIFO Empty
3
SETUP TS
0
R/W
Setup Command Receive Complete
2
EP0o TS
0
R/W
EP0o Receive Complete
1
EP0i TR
0
R/W
EP0i Transfer Request
0
EP0i TS
0
R/W
EP0i Transmission Complete
Rev. 2.00 Oct. 21, 2009 Page 969 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.5
Interrupt Select Register 1 (ISR1)
ISR1 selects the vector numbers of the interrupt requests indicated in interrupt flag register 1
(IFR1). If the USB issues an interrupt request to the INTC when a bit in ISR1 is cleared to 0, the
interrupt corresponding to the bit will be USBINTN2. If the USB issues an interrupt request to the
INTC when a bit in ISR1 is set to 1, the corresponding interrupt will be USBINTN3.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
EP3 TR
EP3 TS
VBUSF
Initial Value
0
0
0
0
0
1
1
1
R/W
R
R
R
R
R
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
⎯
0
R
5
⎯
0
R
These bits are always read as 0. The write value
should always be 0.
4
⎯
0
R
3
⎯
0
R
2
EP3 TR
1
R/W
EP3 Transfer Request
1
EP3 TS
1
R/W
EP3 Transmission Complete
0
VBUSF
1
R/W
USB Bus Connect
Rev. 2.00 Oct. 21, 2009 Page 970 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.6
Interrupt Select Register 2 (ISR2)
ISR2 selects the vector numbers of the interrupt requests indicated in interrupt flag register 2
(IFR2). If the USB issues an interrupt request to the INTC when a bit in ISR2 is cleared to 0, the
interrupt corresponding to the bit will be USBINTN2. If the USB issues an interrupt request to the
INTC when a bit in ISR2 is set to 1, the corresponding interrupt will be USBINTN3.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
SURSE
CFDN
⎯
SETCE
SETIE
Initial Value
0
0
0
1
1
1
1
1
R/W
R
R
R
R/W
R/W
R
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
⎯
0
R
5
⎯
0
R
These bits are always read as 0. The write value
should always be 0.
4
SURSE
1
R/W
Suspend/Resume Detection
3
CFDN
1
R/W
End Point Information Load End
2
⎯
1
R
Reserved
This bit is always read as 1. The write value should
always be 1.
1
SETCE
1
R/W
Set_Configuration Command Detection
0
SETIE
1
R/W
Set_Interface Command Detection
Rev. 2.00 Oct. 21, 2009 Page 971 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.7
Interrupt Enable Register 0 (IER0)
IER0 enables the interrupt requests of interrupt flag register 0 (IFR0). When an interrupt flag is set
to 1 while the corresponding bit of each interrupt is set to 1, an interrupt request is sent to the
CPU. The interrupt vector number is determined by the contents of interrupt select register 0
(ISR0).
Bit
Bit Name
7
6
5
BRST
EP1 FULL
EP2 TR
Initial Value
R/W
4
3
EP2 EMPTY SETUP TS
2
1
0
EP0o TS
EP0i TR
EP0i TS
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
BRST
0
R/W
Bus Reset
6
EP1 FULL
0
R/W
EP1 FIFO Full
5
EP2 TR
0
R/W
EP2 Transfer Request
4
EP2 EMPTY
0
R/W
EP2 FIFO Empty
3
SETUP TS
0
R/W
Setup Command Receive Complete
2
EP0o TS
0
R/W
EP0o Receive Complete
1
EP0i TR
0
R/W
EP0i Transfer Request
0
EP0i TS
0
R/W
EP0i Transmission Complete
Rev. 2.00 Oct. 21, 2009 Page 972 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.8
Interrupt Enable Register 1 (IER1)
IER1 enables the interrupt requests of interrupt flag register 1 (IFR1). When an interrupt flag is set
to 1 while the corresponding bit of each interrupt is set to 1, an interrupt request is sent to the
CPU. The interrupt vector number is determined by the contents of interrupt select register 1
(ISR1).
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
EP3 TR
EP3 TS
VBUSF
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
⎯
0
R
5
⎯
0
R
These bits are always read as 0. The write value
should always be 0.
4
⎯
0
R
3
⎯
0
R
2
EP3 TR
0
R/W
EP3 Transfer Request
1
EP3 TS
0
R/W
EP3 Transmission Complete
0
VBUSF
0
R/W
USB Bus Connect
20.3.9
Interrupt Enable Register 2 (IER2)
IER2 enables the interrupt requests of interrupt flag register 2 (IFR2). When an interrupt flag is set
to 1 while the corresponding bit of each interrupt is set to 1, an interrupt request is sent to the
CPU. The interrupt vector number is determined by the contents of interrupt select register 2
(ISR2).
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
SSRSME
⎯
⎯
SURSE
CFDN
⎯
SETCE
SETIE
0
0
0
0
0
0
0
0
R/W
R
R
R/W
R/W
R
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 973 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Bit
Bit Name
Initial
Value
R/W
Description
7
SSRSME
0
R/W
Resume Detection for Software Standby Cancel
For the details of the operation, see section 20.5.3,
Suspend and Resume Operations.
6, 5
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value
should always be 0.
4
SURSE
0
R/W
Suspend/Resume Detection
For the details of the operation, see section 20.5.3,
Suspend and Resume Operations.
3
CFDN
0
R/W
End Point Information Load End
2
⎯
0
R
Reserved
This bit is always read as 0. The write value should
always be 0.
1
SETCE
0
R/W
Set_Configuration Command Detection
0
SETIE
0
R/W
Set_Interface Command Detection
20.3.10 EP0i Data Register (EPDR0i)
EPDR0i is an 8-byte transmit FIFO buffer for endpoint 0. EPDR0i holds one packet of transmit
data for control-in. Transmit data is fixed by writing one packet of data and setting EP0iPKTE in
the trigger register. When an ACK handshake is returned from the host after the data has been
transmitted, EP0iTS in interrupt flag register 0 is set. This FIFO buffer can be initialized by means
of EP0iCLR in the FCLR register.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
D7
D6
D5
D4
D3
D2
D1
D0
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
W
W
W
W
W
W
W
W
R/W
Description
Bit
Bit Name
Initial
Value
7 to 0
D7 to D0
Undefined W
Rev. 2.00 Oct. 21, 2009 Page 974 of 1454
REJ09B0498-0200
Data register for control-in transfer
Section 20 USB Function Module (USB)
20.3.11 EP0o Data Register (EPDR0o)
EPDR0o is an 8-byte receive FIFO buffer for endpoint 0. EPDR0o holds endpoint 0 receive data
other than setup commands. When data is received successfully, EP0oTS in interrupt flag register
0 is set, and the number of receive bytes is indicated in the EP0o receive data size register. After
the data has been read, setting EP0oRDFN in the trigger register enables the next packet to be
received. This FIFO buffer can be initialized by means of BP0oCLR in the FCLR register.
Bit
Bit Name
7
6
5
4
3
2
1
0
D7
D6
D5
D4
D3
D2
D1
D0
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit
Bit Name
Initial
Value
R/W
Description
7 to 0
D7 to D0
All 0
R
Data register for control-out transfer
20.3.12 EP0s Data Register (EPDR0s)
EPDR0s is an 8-byte FIFO buffer specifically for receiving endpoint 0 setup commands. Only the
setup command to be processed by the application is received. When command data is received
successfully, the SETUPTS bit in interrupt flag register 0 is set.
As a latest setup command must be received in high priority, if data is left in this buffer, it will be
overwritten with new data. If reception of the next command is started while the current command
is being read, command reception has priority, the read by the application is forcibly stopped, and
the read data is invalid.
Bit
7
6
5
4
3
2
1
0
D7
D6
D5
D4
D3
D2
D1
D0
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit Name
Bit
Bit Name
Initial
Value
R/W
Description
7 to 0
D7 to D0
All 0
R
Data register for storing the setup command at the
control-out transfer
Rev. 2.00 Oct. 21, 2009 Page 975 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.13 EP1 Data Register (EPDR1)
EPDR1 is a 128-byte receive FIFO buffer for endpoint 1. EPDR1 has a dual-buffer configuration,
and has a capacity of twice the maximum packet size. When one packet of data is received
successfully, EP1FULL in interrupt flag register 0 is set, and the number of receive bytes is
indicated in the EP1 receive data size register. After the data has been read, the buffer that was
read is enabled to receive data again by writing 1 to the EP1RDFN bit in the trigger register. The
receive data in this FIFO buffer can be transferred by DMA. This FIFO buffer can be initialized
by means of EP1CLR in the FCLR register.
Bit
Bit Name
7
6
5
4
3
2
1
0
D7
D6
D5
D4
D3
D2
D1
D0
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit
Bit Name
Initial
Value
R/W
Description
7 to 0
D7 to D0
All 0
R
Data register for endpoint 1 transfer
20.3.14 EP2 Data Register (EPDR2)
EPDR2 is a 128-byte transmit FIFO buffer for endpoint 2. EPDR2 has a dual-buffer configuration,
and has a capacity of twice the maximum packet size. When transmit data is written to this FIFO
buffer and EP2PKTE in the trigger register is set, one packet of transmit data is fixed, and the
dual-FIFO buffer is switched over. The transmit data for this FIFO buffer can be transferred by
DMA. This FIFO buffer can be initialized by means of EP2CLR in the FCLR register.
Bit
7
Bit Name
Initial Value
R/W
6
5
4
3
2
1
0
D7
D6
D5
D4
D3
D2
D1
D0
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
W
W
W
W
W
W
W
W
R/W
Bit
Bit Name
Initial
Value
7 to 0
D7 to D0
Undefined W
Rev. 2.00 Oct. 21, 2009 Page 976 of 1454
REJ09B0498-0200
Description
Data register for endpoint 2 transfer
Section 20 USB Function Module (USB)
20.3.15 EP3 Data Register (EPDR3)
EPDR3 is an 8-byte transmit FIFO buffer for endpoint 3. EPDR3 holds one packet of transmit data
for the interrupt transfer of endpoint 3. Transmit data is fixed by writing one packet of data and
setting EP3PKTE in the trigger register. When an ACK handshake is returned from the host after
one packet of data has been transmitted successfully, EP3TS in interrupt flag register 0 is set. This
FIFO buffer can be initialized by means of EP3CLR in the FCLR register.
Bit
7
6
5
4
3
2
1
0
D7
D6
D5
D4
D3
D2
D1
D0
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
W
W
W
W
W
W
W
W
R/W
Bit Name
Initial Value
R/W
Bit
Bit Name
Initial
Value
7 to 0
D7 to D0
Undefined W
Description
Data register for endpoint 3 transfer
20.3.16 EP0o Receive Data Size Register (EPSZ0o)
EPSZ0o indicates the number of bytes received at endpoint 0 from the host.
Bit
7
6
5
4
3
2
1
0
Bit Name
—
—
—
—
—
—
—
—
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit
Bit Name
Initial
Value
R/W
Description
7 to 0
—
All 0
R
Number of receive data for endpoint 0
Rev. 2.00 Oct. 21, 2009 Page 977 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.17 EP1 Receive Data Size Register (EPSZ1)
EPSZ1 is a receive data size resister for endpoint 1. EPSZ1 indicates the number of bytes received
from the host. The FIFO for endpoint 1 has a dual-buffer configuration. The size of the received
data indicated by this register is the size of the currently selected side (can be read by CPU).
Bit
7
6
5
4
3
2
1
0
Bit Name
—
—
—
—
—
—
—
—
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit
Bit Name
Initial
Value
R/W
Description
7 to 0
—
All 0
R
Number of received bytes for endpoint 1
20.3.18 Trigger Register (TRG)
TRG generates one-shot triggers to control the transfer sequence for each endpoint.
Bit
6
5
4
3
2
1
0
⎯
EP3 PKTE
EP1 RDFN
EP2 PKTE
⎯
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
⎯
W
W
W
⎯
W
W
W
Bit Name
Initial Value
7
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
Undefined
⎯
Reserved
EP0s RDFN EP0o RDFN EP0i PKTE
The write value should always be 0.
6
EP3 PKTE
Undefined
W
EP3 Packet Enable
After one packet of data has been written to the
endpoint 3 transmit FIFO buffer, the transmit data is
fixed by writing 1 to this bit.
Rev. 2.00 Oct. 21, 2009 Page 978 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Bit
Bit Name
Initial
Value
R/W
Description
5
EP1 RDFN
Undefined
W
EP1 Read Complete
Write 1 to this bit after one packet of data has been
read from the endpoint 1 FIFO buffer. The endpoint 1
receive FIFO buffer has a dual-buffer configuration.
Writing 1 to this bit initializes the FIFO that was read,
enabling the next packet to be received.
4
EP2 PKTE
Undefined
W
EP2 Packet Enable
After one packet of data has been written to the
endpoint 2 transmit FIFO buffer, the transmit data is
fixed by writing 1 to this bit.
3
⎯
Undefined
⎯
Reserved
The write value should always be 0.
2
EP0s RDFN Undefined
W
EP0s Read Complete
Write 1 to this bit after data for the EP0s command
FIFO has been read. Writing 1 to this bit enables
transfer of data in the following data stage. A NACK
handshake is returned in response to transfer
requests from the host in the data stage until 1 is
written to this bit.
1
EP0o RDFN Undefined
W
EP0o Read Complete
Writing 1 to this bit after one packet of data has been
read from the endpoint 0 transmit FIFO buffer
initializes the FIFO buffer, enabling the next packet to
be received.
0
EP0i PKTE
Undefined
W
EP0i Packet Enable
After one packet of data has been written to the
endpoint 0 transmit FIFO buffer, the transmit data is
fixed by writing 1 to this bit.
Rev. 2.00 Oct. 21, 2009 Page 979 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.19 Data Status Register (DASTS)
DASTS indicates whether the transmit FIFO buffers contain valid data. A bit is set when data is
written to the corresponding FIFO buffer and the packet enable state is set, and cleared when all
data has been transmitted to the host.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
EP3 DE
EP2 DE
⎯
⎯
⎯
EP0i DE
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
⎯
0
R
These bits are always read as 0. The write value
should always be 0.
5
EP3 DE
0
R
EP3 Data Present
This bit is set when the endpoint 3 FIFO buffer
contains valid data.
4
EP2 DE
0
R
EP2 Data Present
This bit is set when the endpoint 2 FIFO buffer
contains valid data.
3
⎯
0
R
Reserved
2
⎯
0
R
These bits are always read as 0.
1
⎯
0
R
0
EP0i DE
0
R
EP0i Data Present
This bit is set when the endpoint 0 FIFO buffer
contains valid data.
Rev. 2.00 Oct. 21, 2009 Page 980 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.20 FIFO Clear Register (FCLR)
FCLR is a register to initialize the FIFO buffers for each endpoint. Writing 1 to a bit clears all the
data in the corresponding FIFO buffer. Note that the corresponding interrupt flag is not cleared.
Do not clear a FIFO buffer during transfer.
Bit
7
5
4
3
2
1
0
⎯
EP3 CLR
EP1 CLR
EP2 CLR
⎯
⎯
EP0o CLR
EP0i CLR
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
⎯
W
W
W
⎯
⎯
W
W
Bit Name
Initial Value
6
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
Undefined
⎯
Reserved
The write value should always be 0.
6
EP3 CLR
Undefined
W
EP3 Clear
Writing 1 to this bit initializes the endpoint 3 transmit
FIFO buffer.
5
EP1 CLR
Undefined
W
EP1 Clear
Writing 1 to this bit initializes both sides of the
endpoint 1 receive FIFO buffer.
4
EP2 CLR
Undefined
W
EP2 Clear
Writing 1 to this bit initializes both sides of the
endpoint 2 transmit FIFO buffer.
3
⎯
2
⎯
1
EP0o CLR
Undefined
Undefined
⎯
Reserved
⎯
The write value should always be 0.
W
EP0o Clear
Writing 1 to this bit initializes the endpoint 0 receive
FIFO buffer.
0
EP0i CLR
Undefined
W
EP0i Clear
Writing 1 to this bit initializes the endpoint 0 transmit
FIFO buffer.
Rev. 2.00 Oct. 21, 2009 Page 981 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.21 DMA Transfer Setting Register (DMA)
DMA transfer can be carried out between the endpoint 1 and 2 data registers and memory by
means of the on-chip direct memory access controller (DMAC). Dual address transfer is
performed in bytes. To start DMA transfer, DMAC settings must be made in addition to the
settings in this register.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
PULLUP_E
EP2DMAE
EP1DMAE
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
⎯
0
R
5
⎯
0
R
These bits are always read as 0. The write value
should always be 0.
4
⎯
0
R
3
⎯
0
R
2
PULLUP_E 0
R/W
PULLUP Enable
This pin performs the pull-up control for the D+ pin,
with using PM4 as the pull-up control pin.
0: D+ is not pulled up.
1: D+ is pulled up.
Rev. 2.00 Oct. 21, 2009 Page 982 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Bit
Bit Name
Initial
Value
R/W
Description
1
EP2DMAE
0
R/W
Endpoint 2 DMA Transfer Enable
When this bit is set, DMA transfer is enabled from
memory to the endpoint 2 transmit FIFO buffer. If
there is at least one byte of open space in the FIFO
buffer, a DMAC start interrupt signal (USBINTN1) is
asserted. In DMA transfer, when 64 bytes are written
to the FIFO buffer the EP2 packet enable bit is set
automatically, allowing 64 bytes of data to be
transferred, and if there is still space in the other side
of the two FIFOs, the DMAC start interrupt signal
(USBINTN1) is asserted again. However, if the size of
the data packet to be transmitted is less than 64
bytes, the EP2 packet enable bit is not set
automatically, and so should be set by the CPU with a
DMA transfer end interrupt.
As EP2-related interrupt requests to the CPU are not
automatically masked, interrupt requests should be
masked as necessary in the interrupt enable register.
•
Operating procedure
1. Write of 1 to the EP2 DMAE bit in DMAR
2. Set the DMAC to activate through USBINTN1
3. Transfer count setting in the DMAC
4. DMAC activation
5. DMA transfer
6. DMA transfer end interrupt generated
See section 20.8.3, DMA Transfer for Endpoint 2.
Rev. 2.00 Oct. 21, 2009 Page 983 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Bit
Bit Name
Initial
Value
R/W
Description
0
EP1DMAE
0
R/W
Endpoint 1 DMA Transfer Enable
When this bit is set, a DMAC start interrupt signal
(USBINTN0) is asserted and DMA transfer is enabled
from the endpoint 1 receive FIFO buffer to memory. If
there is at least one byte of receive data in the FIFO
buffer, the DMAC start interrupt signal (USBINTN0) is
asserted. In DMA transfer, when all the received data
is read, EP1 is automatically read and the completion
trigger operates.
EP1-related interrupt requests to the CPU are not
automatically masked.
•
Operating procedure:
1. Write of 1 to the EP1 DMAE bit in DMA
2. Set the DMAC to activate through USBINTN0
3. Transfer count setting in the DMAC
4. DMAC activation
5. DMA transfer
6. DMA transfer end interrupt generated
See section 20.8.2, DMA Transfer for Endpoint 1.
Rev. 2.00 Oct. 21, 2009 Page 984 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.22 Endpoint Stall Register (EPSTL)
The bits in EPSTL are used to forcibly stall the endpoints on the application side. While a bit is set
to 1, the corresponding endpoint returns a stall handshake to the host. The stall bit for endpoint 0
is cleared automatically on reception of 8-byte command data for which decoding is performed by
the function and the EP0 STL bit is cleared. When the SETUPTS flag in the IFR0 register is set to
1, writing 1 to the EP0 STL bit is ignored. For detailed operation, see section 20.7, Stall
Operations.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
EP3STL
EP2STL
EP1STL
EP0STL
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
⎯
0
R
5
⎯
0
R
These bits are always read as 0. The write value
should always be 0.
4
⎯
0
R
3
EP3STL
0
R/W
EP3 Stall
When this bit is set to 1, endpoint 3 is placed in the
stall state.
2
EP2STL
0
R/W
EP2 Stall
When this bit is set to 1, endpoint 2 is placed in the
stall state.
1
EP1STL
0
R/W
EP1 Stall
When this bit is set to 1, endpoint 1 is placed in the
stall state.
0
EP0STL
0
R/W
EP0 Stall
When this bit is set to 1, endpoint 0 is placed in the
stall state.
Rev. 2.00 Oct. 21, 2009 Page 985 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.23 Configuration Value Register (CVR)
This register stores the Configuration, Interface, or Alternate set value when the Set Configuration
or Set Interface command from the host is correctly received.
Bit
7
6
5
4
3
2
1
0
CNFV1
CNFV0
INTV1
INTV0
⎯
ALTV2
ALTV1
ALTV0
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
Bit Name
Bit
Bit Name
Initial
Value
R/W
Description
7
CNFV1
All 0
R
6
CNFV0
These bits store Configuration Setting value when
they receive Set Configuration command. CNFV is
updated when the SETC bit in IFR2 is set to 1.
5
INTV1
All 0
R
4
INTV0
These bits store Interface Setting value when they
receive Set Interface command. INTV is updated
when the SETI bit in IFR2 is set to 1.
3
⎯
0
R
Reserved
This bit is always read as 0. The write value should
always be 0.
2
ALTV2
0
R
1
ALTV1
0
R
0
ALTV0
0
R
These bits store Alternate Setting value when they
receive Set Interface command. ALTV2 to ALTV0 are
updated when the SETI bit in IFR2 is set to 1.
20.3.24 Control Register (CTLR)
This register sets functions for bits ASCE, PWMD, RSME, and, PWUPS.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
RWUPS
RSME
PWMD
ASCE
⎯
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R/W
R/W
R/W
R
Rev. 2.00 Oct. 21, 2009 Page 986 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
⎯
0
R
5
⎯
0
R
These bits are always read as 0. The write value
should always be 0.
4
RWUPS
0
R
Remote Wakeup Status
This status bit indicates remote wakeup command
from USB host is enabled or disabled.
This bit is set to 0 when remote wakeup command
from UBM host is disabled by
Device_Remote_Wakeup due to Set Feature or Clear
Feature request. This bit is set to 1 when remote
wakeup command is enabled.
3
RSME
0
R/W
Resume Enable
This bit releases the suspend state (or executes
remote wakeup). When RSME is set to 1, resume
request starts. If RSME is once set to 1, clear this bit
to 0 again afterwards. In this case, the value 1 set to
RSME must be kept for at least one clock period of
12-MHz clock.
2
PWMD
0
R/W
Bus Power Mode
This bit specifies the USB power mode. When PWMD
is set to 0, the self-power mode is selected for this
module. When set to 1, the bus-power mode is
selected.
1
ASCE
0
R/W
Automatic Stall Clear Enable
Setting the ASCE bit to 1 automatically clears the stall
setting bit (the EPxSTL (x = 1, 2, or 3) bit in EPSTLR0
or EPSTR1) of the end point that has returned the
stall handshake to the host. The automatic stall clear
enable is common to the all end points. Thus the
individual control of the end point is not possible.
When the ASCE bit is set to 0, the stall setting bit is
not automatically cleared. This bit must be released
by the users. To enable this bit, make sure that the
ASCE bit should be set to 1 before the EPxSTL (x = 1,
2, or 3) bit in EPSTL is set to 1.
0
—
0
R
Reserved
This bit is always read as 0. The write value should
always be 0.
Rev. 2.00 Oct. 21, 2009 Page 987 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.25 Endpoint Information Register (EPIR)
This register sets the information for each endpoint. Each endpoint needs five bytes to store the
information. Writing data should be done in sequence starting at logical endpoint 0. Do not write
data of more than 50 bytes (five bytes multiplied by ten endpoints) to this register. The
information should be written to this register only once at reset and no data should be written after
that. Description of writing data for one endpoint is shown below.
Although this register consists of one register to which data is written sequentially for one address,
the write data for the endpoint 0 is described as EPIR00 to EPIR05 (EPIR endpoint number in
write order) to make the explanation understood easier. Write should start at EPIR00.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
D7
D6
D5
D4
D3
D2
D1
D0
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
Undefined
W
W
W
W
W
W
W
W
• EPIR00
Bit
Bit Name
Initial
Value
R/W
7 to 4
D7 to D4
Undefined
W
Description
Endpoint Number
[Enable setting range]
0 to 3
3, 2
D3, D2
Undefined
W
Endpoint Configuration Number
[Enable setting range]
0 or 1
1, 0
D1, D0
Undefined
W
Endpoint Interface Number
[Enable setting range]
0 to 3
Rev. 2.00 Oct. 21, 2009 Page 988 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
• EPIR01
Bit
Bit Name
Initial
Value
R/W
Description
7, 6
D7, D6
Undefined
W
Endpoint Alternate Number
[Possible setting range]
0 or 1
5, 4
D5, D4
Undefined
W
Endpoint Transmission
[Possible setting range]
0: Control
1: Setting prohibited
2: Bulk
3: Interrupt
3
D3
Undefined
W
Endpoint Transmission Direction
[Possible setting range]
0: Out
1: In
2 to 0
D2 to D0
Undefined
W
Reserved
[Possible setting range]
Fixed to 0.
• EPIR02
Bit
Bit Name
Initial
Value
R/W
7 to 1
D7 to D1
Undefined
W
Description
Endpoint Maximum Packet Size
[Possible setting range]
0 to 64
0
D0
Undefined
W
Reserved
[Possible setting range]
Fixed to 0.
• EPIR03
Bit
Bit Name
Initial
Value
R/W
7 to 0
D7 to D0
Undefined
W
Description
Reserved
[Possible setting range]
Fixed to 0.
Rev. 2.00 Oct. 21, 2009 Page 989 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
• EPIR04
Bit
Bit Name
Initial
Value
R/W
Description
7 to 0
D7 to D0
Undefined
W
Endpoint FIFO Number
[Possible setting range]
0 to 3
The endpoint number is the endpoint number the USB host uses. The endpoint FIFO number
corresponds to the endpoint number described in this manual. Thus data transfer between the USB
host and the endpoint FIFO can be enabled by putting the endpoint number and the endpoint FIFO
number in one-to-one correspondence. Note that the setting value is subject to a limitation
described below.
Since each endpoint FIFO number is optimized by the exclusive software that corresponds to the
transfer system, direction, and the maximum packet size, make sure to set the endpoint FIFO
number to the data described in table 20.2.
1. The endpoint FIFO number 1 cannot designate other than the maximum packet size of 64
bytes, bulk transfer method, and out transfer direction.
2. endpoint number 0 and the endpoint FIFO number must have one-on one relationship.
3. The maximum packet size for the endpoint FIFO number 0 is 8 bytes only.
4. The endpoint FIFO number 0 can specify only the maximum packet size and the data for the
rest should be all 0.
5. The maximum packet size for the endpoint FIFO numbers 1 and 2 is limited to 64 bytes.
6. The maximum packet size for the endpoint FIFO numbers 3 is limited to 8 bytes.
7. The maximum number of endpoint information setting is ten.
8. Up to ten endpoint information setting should be made.
9. Write 0 to the endpoints not in use.
Table 20.2 shows the example of limitations for the maximum packet size, the transfer method,
and the transfer direction.
Table 20.2 Example of Limitations for Setting Values
Endpoint FIFO Number
Maximum Packet Size
Transfer Method
Transfer Direction
0
1
2
3
8 bytes
64 bytes
64 bytes
8 bytes
Control
Bulk
Bulk
Interrupt
⎯
Out
In
In
Rev. 2.00 Oct. 21, 2009 Page 990 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Table 20.3 shows a specific example of setting.
Table 20.3 Example of Setting
Endpoint
Number Conf.
Int.
Alt.
Transfer
Method
Transfer
Direction
Maximum
Packet Size
Endpoint
FIFO Number
0
⎯
⎯
⎯
Control
In/Out
8 bytes
0
1
1
0
0
Bulk
Out
64 bytes
1
2
1
0
0
Bulk
In
64 bytes
2
3
1
0
0
Interrupt
In
8 bytes
3
⎯
1
1
0
⎯
⎯
⎯
⎯
⎯
1
1
1
⎯
⎯
⎯
⎯
N
EPIR[N]0
EPIR[N]1
EPIR[N]2
EPIR[N]3
EPIR[N]4
0
00
00
10
00
00
1
14
20
80
00
01
2
24
28
80
00
02
3
34
38
10
00
03
4
00
00
00
00
00
5
00
00
00
00
00
6
00
00
00
00
00
7
00
00
00
00
00
8
00
00
00
00
00
9
00
00
00
00
00
Configuration
Interface
Alternate
Setting
Endpoint
Number
Endpoint
FIFO Number
Attribute
⎯
⎯
⎯
0
0
Control
1
0
0
1
1
BulkOut
2
2
BulkIn
3
3
InterruptIn
Rev. 2.00 Oct. 21, 2009 Page 991 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.26
Transceiver Test Register 0 (TRNTREG0)
TRNTREG0 controls the on-chip transceiver output signals. Setting the PTSTE bit to 1 specifies
the transceiver output signals (USD+ and USD-) arbitrarily. Table 20.4 shows the relationship
between TRNTREG0 setting and pin output.
Bit
Bit Name
7
6
5
4
3
2
1
0
PTSTE
⎯
⎯
⎯
SUSPEND
txenl
txse0
txdata
0
0
0
0
0
0
0
0
R/W
R
R
R
R/W
R/W
R/W
R/W
Initial Value
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
PTSTE
0
R/W
Pin Test Enable
Enables the test control for the on-chip transceiver
output pins (USD+ and USD-).
6 to 4
⎯
All 0
R
Reserved
These bits are always read as 0. The write value
should always be 0.
3
SUSPEND
0
R/W
On-Chip Transceiver Output Signal Setting
2
txenl
0
R/W
1
txse0
0
R/W
SUSPEND: Sets the (SUSPEND) signal of the on-chip
transceiver.
0
txdata
0
R/W
txenl:
Sets the output enable (txenl) signal of the
on-chip transceiver.
txse0:
Sets the Signal-ended 0 (txse0) signal of
the on-chip transceiver.
txdata:
Sets the (txdata) signal of the on-chip
transceiver.
Rev. 2.00 Oct. 21, 2009 Page 992 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Table 20.4 Relationship between TRNTREG0 Setting and Pin Output
Pin Input
Register Setting
Pin Output
VBUS
PTSTE
txenl
txse0
txdata
USD+
USD-
0
X
X
X
X
Hi-Z
Hi-Z
1
0
X
X
X
⎯
⎯
1
1
0
0
0
0
1
1
1
0
0
1
1
0
1
1
0
1
x
0
0
1
1
1
X
X
Hi-Z
Hi-Z
[Legend]
X:
Don't care.
⎯:
Cannot be controlled. Indicates state in normal operation according to the USB operation
and port settings.
Rev. 2.00 Oct. 21, 2009 Page 993 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.3.27 Transceiver Test Register 1 (TRNTREG1)
TRNTREG1 is a test register that can monitor the on-chip transceiver input signal.
Setting bits PTSTE and txenl in TRNTREG0 to 1 enables monitoring the on-chip transceiver input
signal. Table 20.5 shows the relationship between pin input and TRNTREG1 monitoring value.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
xver_data
dpls
dmns
Initial Value
0
0
0
0
0
⎯*
⎯*
⎯*
R/W
R
R
R
R
R
R
R
R
Bit
Bit Name
Initial
Value
R/W
Description
7 to 3
⎯
All 0
R
Reserved
These bits are always read as 0. The write value should
always be 0.
2
xver_data
⎯*
R
On-Chip Transceiver Input Signal Monitor
1
dpls
⎯*
R
0
dmns
⎯*
R
xver_data: Monitors the differential input level
(xver_data) signal of the on-chip
transceiver.
Note:
*
dpls:
Monitors the USD+ (dpls) signal of the onchip transceiver.
dmns:
Monitors the USD- (dmns) signal of the onchip transceiver.
Determined by the state of pins, VBUS, USD+, and USD-
Rev. 2.00 Oct. 21, 2009 Page 994 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Table 20.5 Relationship between Pin Input and TRNTREG1 Monitoring Value
Register Setting
TRNTREG1
Monitoring Value
Pin Input
PTSTE
SUSPEND
VBUS
USD+
USD-
xver_data dpls
dmns Remarks
0
X
X
X
X
0
0
0
Cannot be monitored
when PTSTE = 0
1
0
1
0
0
X
0
0
1
0
1
0
1
0
0
1
Can be monitored
when PTSTE = 1
1
0
1
1
0
1
1
0
1
0
1
1
1
X
1
1
1
1
1
0
0
0
0
0
1
1
1
0
1
0
0
1
1
1
1
1
0
0
1
0
1
1
1
1
1
0
1
1
1
X
0
X
X
0
1
1
Can be monitored
when VBUS = 0
[Legend]
X:
Don't care.
Rev. 2.00 Oct. 21, 2009 Page 995 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.4
Interrupt Sources
This module has five interrupt signals. Table 20.6 shows the interrupt sources and their
corresponding interrupt request signals. The USBINTN interrupt signals are activated at low level.
The USBINTN interrupt requests can only be detected at low level (specified as level sensitive).
Table 20.6 Interrupt Sources
Description
Interrupt
Request
Signal
EP0i_TS*
EP0i transfer
complete
USBINTN2 or ×
USBINTN3
×
1
EP0i_TR*
EP0i transfer
request
USBINTN2 or ×
USBINTN3
×
2
EP0o_TS*
EP0o receive
complete
USBINTN2 or ×
USBINTN3
×
3
SETUP_TS*
Setup command
receive complete
USBINTN2 or ×
USBINTN3
×
EP2_EMPTY
EP2 FIFO empty
USBINTN2 or ×
USBINTN3
USBINTN1
EP2_TR
EP2 transfer
request
USBINTN2 or ×
USBINTN3
×
Register
Bit
IFR0
0
4
Transfer
Mode
Interrupt
Source
Control
transfer
(EP0)
Bulk_in
transfer
(EP2)
5
IFR1
DTC
Activation
DMAC
Activation
6
Bulk_out
transfer
(EP1)
EP1_FULL
EP1 FIFO Full
USBINTN2 or ×
USBINTN3
USBINTN0
7
Status
BRST
Bus reset
USBINTN2 or ×
USBINTN3
×
0
Status
VBUSF
USB
disconnection
detection
USBINTN2 or ×
USBINTN3
×
1
EP3 transfer
complete
USBINTN2 or ×
USBINTN3
×
2
Interrupt_in EP3_TS
transfer
(EP3)
EP3_TR
EP3 transfer
request
USBINTN2 or ×
USBINTN3
×
3
Status
VBUSMN
VBUS connection
status
—
×
×
4
—
Reserved
—
—
—
—
5
6
7
Rev. 2.00 Oct. 21, 2009 Page 996 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
Register
Bit
Transfer
Mode
IFR2
0
Status
1
Description
Interrupt
Request
Signal
SETI
Set_Interface
command detection
USBINTN2 or ×
USBINTN3
×
SETC
Set_Configuration
command detection
USBINTN2 or ×
USBINTN3
×
—
Interrupt
Source
DTC
DMAC
Activation Activation
2
—
Reserved
⎯
—
3
Status
CFDN
Endpoint information
load end
USBINTN2 or ×
USBINTN3
×
4
SURSF
Suspend/resume
detection
USBINTN2,
×
USBINTN3, or
RESUME
×
5
SURSS
Suspend/resume
status
—
×
×
Reserved
—
—
—
—
6
—
—
7
Note:
*
EP0 interrupts must be assigned to the same interrupt request signal.
• USBINTN0 signal
DMAC start interrupt signal only EP1. See section 20.8, DMA Transfer.
• USBINTN1 signal
DMAC start interrupt signal only EP2. See section 20.8, DMA Transfer.
• USBINTN2 signal
The USBINTN2 signal requests interrupt sources for which the corresponding bits in interrupt
select registers 0 to 2 (ISR0 to ISR2) are cleared to 0. The USBINTN2 is driven low if a
corresponding bit in the interrupt flag register is set to 1.
• USBINTN3 signal
The USBINTN3 signal requests interrupt sources for which the corresponding bits in interrupt
select registers 0 to 2 (ISR0 to ISR2) are cleared to 0. The USBINTN3 is driven low if a
corresponding bit in the interrupt flag register is set to 1.
• RESUME signal
The RESUME signal is a resume interrupt signal for canceling software standby mode and
deep software standby mode. The RESUME signal is driven low at the transition to the resume
state for canceling software standby mode and deep software standby mode.
Rev. 2.00 Oct. 21, 2009 Page 997 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.5
Operation
20.5.1
Cable Connection
USB function
Application
Cable disconnected
VBUS pin = 0 V
UDC core reset
USB module interrupt
setting
As soon as preparations are
completed, enable D+ pull-up
in general output port
USB cable connection
No
Initial
settings
General output port
D+ pull-up enabled?
Yes
Interrupt request
IFR1.VBUSF = 1
USB bus connection interrupt
Firmware preparations for
start of USB communication
UDC core reset release
Bus reset reception
IFR0.BRST = 1
Bus reset interrupt
Clear VBUSF flag
(IFR1.VBUSF)
Interrupt request
Wait for setup command
reception complete interrupt
Clear bus reset flag
(IFR0.BRST)
Clear FIFOs
(EP0, EP1, EP2, EP3)
Wait for setup command
reception complete interrupt
Figure 20.2 Cable Connection Operation
The above flowchart shows the operation in the case of in section 20.9, Example of USB External
Circuitry.
In applications that do not require USB cable connection to be detected, processing by the USB
bus connection interrupt is not necessary. Preparations should be made with the bus-reset
interrupt.
Rev. 2.00 Oct. 21, 2009 Page 998 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.5.2
Cable Disconnection
USB function
Application
Cable connected
VBUS pin = 1
USB cable disconnection
VBUS pin = 0
UDC core reset
End
Figure 20.3 Cable Disconnection Operation
The above flowchart shows the operation in section 20.9, Example of USB External Circuitry.
20.5.3
(1)
Suspend and Resume Operations
Suspend Operation
If the USB bus enters the suspend state from the non-suspend state, perform the operation as
shown in figure 20.4.
Rev. 2.00 Oct. 21, 2009 Page 999 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
USB function
Application
Clear SURSF in IFR2 to 0
USB cable connected
Check if SURSS in IFR2
is set to 1
Bus idle of 3 ms or
more occurs
Suspend/resume
interrupt occurs
(IFR2/SURSF = 1)
RESUME
Remote
wakeup enabled?
(CTLR/RWUPS = 1?)
No
Yes
Check remote-wakeup
function disabled
Check remote-wakeup
function enabled
System needs to
enter power-down
mode?
No
Yes
Need to enter
software standby
mode?
No
Yes
Need to enter deep
software standby
mode?
Yes
No
1
Clear SURSE in IER2 to 0
Set STS5 to STS0 in SBYCR
2
Set SSRSME in IER2 to 0
Clear RAMCUT in
DPSTBYCR to 0
Clear SURSE in IER2 to 0
Set SURSE in IER2 to 1
Set SSRSME in IER2 to 1
Clear SSRSME in IER2 to 0
Enter software
standby mode
USB module stop
Set WTSTS5 to WTSTS0 1
in DPSBWCR
Clear DUSBIF in
DPSIFR to 0
Set DUSBIE in DPSIER to 1
Enter deep software
standby mode
Wait for suspend/
resume interrupt
Notes:
1.
2.
For details, see section 28, Power-Down Modes.
When the USB enters deep software standby mode, the sources to cancel software standby mode may be conflicted.
In this figure, the operation to cancel software standby mode is not performed. For details, see section 28.12, Usage Notes.
Figure 20.4 Suspend Operation
Rev. 2.00 Oct. 21, 2009 Page 1000 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(2)
Resume Operation from Up-Stream
If the USB bus enters the non-suspend state from the suspend state by resume signal output from
up-stream, perform the operation as shown in figure 20.5.
Application
USB function
USB cable connected
USB bus in suspend state
Resume interrupts is
requested from the
up-stream.
Suspend/resume
interrupt occurs.
(IFR2/SURSF = 1)
RESUME
Yes
Deep software
standby mode ?
No
Yes
Cancel deep software
standby mode
No
Cancel software
standby mode
No
Oscillation stabilization
time has passed?
No
Oscillation stabilization
time has passed?
Yes
Yes
Execute reset
exception handling
Software standby
mode ?
*
USB module
stopped?
No
Yes
Start USB operating
clock oscillation
Cancel USB module stop
Cancel USB module stop
Clear SURSF in IFR2 to 0
Clear SURSF in IFR2 to 0
Check if SURSS in IFR2 is
cleared to 0
Check if SURSS in IFR2 is
cleared to 0
Set SURSE in IER2 to 1
Set SURSE in IER2 to 1
Clear SSRSME in IER2 to 0
Clear SSRSME in IER2 to 0
Clear DUSBIF in
DPSIFR to 0
Clear DUSBIE in
DPSIER to 0
USB communications
can be resumed
Note:
*
Return to normal state
For details, see section 28.8, Deep Software Standby Mode.
Figure 20.5 Resume Operation from Up-Stream
Rev. 2.00 Oct. 21, 2009 Page 1001 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(3)
Transition from Suspend State to Software Standby Mode and Canceling Software
Standby Mode
If the USB bus enters from the suspend state to software standby mode, perform the operation as
shown in figure 20.6. When canceling software standby mode, ensure enough time for the system
clock oscillation to be settled.
Canceling software standby mode
Transition from suspend state to
software standby mode
(1)
Detect that USB bus is in suspend state
(8)
Detect that USB bus is in resume state
(2)
Set SURSF in IFR2 to 1
(9)
RESUME interrupt
(3)
USBINTN interrupt
(4)
(5)
Cancel software standby mode
(10) Wait for system clock oscillation to be settled
Clear SURSF in IFR2 to 0
Check if SURSS in IFR2 is set to 1
(11)
Clear SURSF in IFR2 to 0
Check if SURSS in IFR2 is cleared to 0
(12)
Set SURSE in IER2 to 1
Clear SSRSME in IER2 to 0
Clear SURSE in IER2 to 0
Set SSRSME in IER2 to 1
(6)
Shift to software standby mode
(execute SLEEP instruction)
(7)
Stop all clocks of LSI
USB communications can be resumed
through USB registers
Denotation of figures
: Operation by firmware setting
: Automatic operation by LSI hardware
Figure 20.6 Flow of Transition to and Canceling Software Standby Mode
Rev. 2.00 Oct. 21, 2009 Page 1002 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(1)
USB bus state
(8)
Normal
Resume → normal
Suspend
(3)
USBINTN interrupt
SURSF
(2)
(11)
(4)
(4)
SURSS
SSRSME = 1
(11)
(5)
(12)
RESUME interrupt
Software standby
(9)
(10)
(6)
Oscillator
(7)
USB dedicated clock
(cku)
Module clock (pφ)
(7)
Software standby
Oscillation
settling time
Figure 20.7 Timing of Transition to and Canceling Software Standby Mode
Rev. 2.00 Oct. 21, 2009 Page 1003 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(4)
Transition from Suspend State to Deep Software Standby Mode and Canceling Deep
Software Standby Mode
If the USB bus enters from the suspend state to deep software standby mode, perform the
operation as shown in figure 20.8. When canceling deep software standby mode, ensure enough
time for the system clock oscillation to be settled.
Canceling deep software standby mode
Transition from suspend state to
deep software standby mode
(1)
Detect that USB bus is in suspend state
(8)
Detect that USB bus is in resume state
(2)
Set SURSF in IFR2 to 1
(9)
RESUME interrupt
(3)
USBINTN interrupt
(4)
(5)
Clear SURSF in IFR2 to 0
Check if SURSS in IFR2 is set to 1
Clear SURSE in IER2 to 0
Clear SSRSME in IER2 to 0*
Clear DUSBIF in DPSIFR to 0
Set DUSBIE in DPSIER to 1
Cancel deep software standby mode
(10) Wait for system clock oscillation to be settled
(11)
(12)
(13)
(6)
Execute reset sequence
Cancel module stop
Clear SURSF in IFR2 to 0
Check if SURSS in IFR2 is cleared to 0
Shift to deep software standby mode
(execute SLEEP instruction)
Stop all clocks of LSI
(7)
(14)
Set SURSE in IER2 to 1
Set SSRSME in IER2 to 0
Clear DUSBIF in DPSIFR to 0
Clear DUSBIE in DPSIER to 0
USB communications can be resumed
through USB registers
Denotation of figures
: Operation by firmware setting
: Automatic operation by LSI hardware
Note:
*
When the USB enters deep software standby mode, the sources to cancel software standby mode may be conflicted.
In this figure, the operation to cancel software standby mode is not performed. For details, see section 28.12, Usage Notes.
Figure 20.8 Flow of Transition to and Canceling Deep Software Standby Mode
Rev. 2.00 Oct. 21, 2009 Page 1004 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(8)
(1)
Normal
Resume → normal
Suspend
USB bus state
(3)
USBINTN interrupt
SURSF
(2)
(4)
(13)
(4)
(13)
SURSS
DUSBIF
(5)
(14)
(5)
(14)
DUSBIE
RESUME interrupt
(9)
Deep software standby
(6)
(10)
(7)
Oscillator
(7)
USB dedicated clock
(cku)
(11)
Internal reset
USB module stop
(MSTPC11)
Module clock (pφ)
(6)
(12)
(7)
Deep software standby
Oscillation Module
stop
settling
period
time
Figure 20.9 Timing of Transition to and Canceling Deep Software Standby Mode
Rev. 2.00 Oct. 21, 2009 Page 1005 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(5)
Remote-Wakeup Operation
If the USB bus enters the non-suspend (resume) state from the suspend state by the remotewakeup signal output from this function, perform the operation as shown in figure 20.10.
USB function
Application
USB cable connected
USB bus in suspend state
Remote
wakeup enabled?
(CTLR/RWUPS = 1?)
No
Yes
Bus wakeup source
generated
Yes
Software standby
mode ?
Cancel software
standby mode
Oscillation
stabilization time
has passed?
Wait for resume
from up-stream
No
No
Yes
USB module
stopped?
Yes
Start USB operating
clock oscillation
Resume output signal
Suspend/resume
interrupt occurs.
(IFR2/SURSF = 1)
Cancel USB module stop
Remote wakeup execution
(CTLR/RSME= 1)
RESUME
Clear SURSF in IFR2 to 0
Check if SURSS in IFR2 is
cleared to 0
Return to normal state
Figure 20.10 Remote-Wakeup
Rev. 2.00 Oct. 21, 2009 Page 1006 of 1454
REJ09B0498-0200
No
Section 20 USB Function Module (USB)
20.5.4
Control Transfer
Control transfer consists of three stages: setup, data (not always included), and status (figure
20.11). The data stage comprises a number of bus transactions. Operation flowcharts for each
stage are shown below.
Setup stage
Control-in
Control-out
No data
Data stage
SETUP(0)
IN(1)
IN(0)
DATA0
DATA1
DATA0
SETUP(0)
OUT(1)
OUT(0)
DATA0
DATA1
DATA0
Status stage
...
...
IN(0/1)
OUT(1)
DATA0/1
DATA1
OUT(0/1)
IN(1)
DATA0/1
DATA1
SETUP(0)
IN(1)
DATA0
DATA1
Figure 20.11 Transfer Stages in Control Transfer
Rev. 2.00 Oct. 21, 2009 Page 1007 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(1)
Setup Stage
Application
USB function
SETUP token reception
Receive 8-byte command
data in EP0s
Command
to be processed by
application?
No
Automatic
processing by
this module
Yes
Set setup command
reception complete flag
(IFR0.SETUP TS = 1)
Interrupt request
To data stage
Clear SETUP TS flag
(IFR0.SETUP TS = 0)
Clear EP0i FIFO (FCLR.EP0iCLR = 1)
Clear EP0o FIFO (FCLR.EP0oCLR = 1)
Read 8-byte data from EP0s
Decode command data
Determine data stage direction*1
Write 1 to EP0s read complete bit
(TRG.EP0s RDFN = 1)
*2
To control-in
data stage
To control-out
data stage
Notes: 1. In the setup stage, the application analyzes command data from the host requiring processing by
the application, and determines the subsequent processing (for example, data stage direction, etc.).
2. When the transfer direction is control-out, the EP0i transfer request interrupt required in the status
stage should be enabled here. When the transfer direction is control-in, this interrupt is not required
and should be disabled.
Figure 20.12 Setup Stage Operation
Rev. 2.00 Oct. 21, 2009 Page 1008 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(2)
Data Stage (Control-In)
USB function
Application
IN token reception
From setup stage
1 written
to TRG.EP0s
RDFN?
No
NACK
Yes
Valid data
in EP0i FIFO?
Write data to EP0i
data register (EPDR0i)
No
Write 1 to EP0i packet
enable bit
(TRG.EP0i PKTE = 1)
NACK
Yes
Data transmission to host
ACK
Set EP0i transmission
complete flag
(IFR0.EP0i TS = 1)
Interrupt
request
Clear EP0i transmission
complete flag
(IFR0.EP0i TS = 0)
Write data to EP0i
data register (EPDR0i)
Write 1 to EP0i packet
enable bit
(TRG.EP0i PKTE = 1)
Figure 20.13 Data Stage (Control-In) Operation
The application first analyzes command data from the host in the setup stage, and determines the
subsequent data stage direction. If the result of command data analysis is that the data stage is intransfer, one packet of data to be sent to the host is written to the FIFO. If there is more data to be
sent, this data is written to the FIFO after the data written first has been sent to the host (EP0iTS
bit in IFR0 = 1).
The end of the data stage is identified when the host transmits an OUT token and the status stage
is entered.
Note: If the size of the data transmitted by the function is smaller than the data size requested by
the host, the function indicates the end of the data stage by returning to the host a packet
shorter than the maximum packet size. If the size of the data transmitted by the function is
an integral multiple of the maximum packet size, the function indicates the end of the data
stage by transmitting a zero-length packet.
Rev. 2.00 Oct. 21, 2009 Page 1009 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(3)
Data Stage (Control-Out)
USB function
Application
OUT token reception
1 written
to TRG.EP0s
RDFN?
No
NACK
Yes
Data reception from host
ACK
Set EP0o reception
complete flag
(IFR0.EP0o TS = 1)
Interrupt request
Read data from EP0o
receive data size register
(EPSZ0o)
OUT token reception
1 written
to TRG.EP0o
RDFN?
Clear EP0o reception
complete flag
(IFR0.EP0o TS = 0)
No
NACK
Read data from EP0o
data register (EPDR0o)
Yes
Write 1 to EP0o read
complete bit
(TRG.EP0o RDFN = 1)
Figure 20.14 Data Stage (Control-Out) Operation
The application first analyzes command data from the host in the setup stage, and determines the
subsequent data stage direction. If the result of command data analysis is that the data stage is outtransfer, the application waits for data from the host, and after data is received (EP0oTS bit in
IFR0 = 1), reads data from the FIFO. Next, the application writes 1 to the EP0o read complete bit,
empties the receive FIFO, and waits for reception of the next data.
The end of the data stage is identified when the host transmits an IN token and the status stage is
entered.
Rev. 2.00 Oct. 21, 2009 Page 1010 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(4)
Status Stage (Control-In)
USB function
Application
OUT token reception
0-byte reception from host
ACK
Set EP0o reception
complete flag
(IFR0.EP0o TS = 1)
End of control transfer
Interrupt request
Clear EP0o reception
complete flag
(IFR0.EP0o TS = 0)
Write 1 to EP0o read
complete bit
(TRG.EP0o RDFN = 1)
End of control transfer
Figure 20.15 Status Stage (Control-In) Operation
The control-in status stage starts with an OUT token from the host. The application receives 0byte data from the host, and ends control transfer.
Rev. 2.00 Oct. 21, 2009 Page 1011 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(5)
Status Stage (Control-Out)
USB function
Application
IN token reception
Valid data
in EP0i FIFO?
Interrupt request
No
NACK
Clear EP0i transfer
request flag
(IFR0.EP0i TR = 0)
Yes
Write 1 to EP0i packet
enable bit
(TRG.EP0i PKTE = 1)
0-byte transmission to host
ACK
Set EP0i transmission
complete flag
(IFR0.EP0i TS = 1)
End of control transfer
Interrupt request
Clear EP0i transmission
complete flag
(IFR0.EP0i TS = 0)
End of control transfer
Figure 20.16 Status Stage (Control-Out) Operation
The control-out status stage starts with an IN token from the host. When an IN-token is received at
the start of the status stage, there is not yet any data in the EP0i FIFO, and so an EP0i transfer
request interrupt is generated. The application recognizes from this interrupt that the status stage
has started. Next, in order to transmit 0-byte data to the host, 1 is written to the EP0i packet enable
bit but no data is written to the EP0i FIFO. As a result, the next IN token causes 0-byte data to be
transmitted to the host, and control transfer ends.
After the application has finished all processing relating to the data stage, 1 should be written to
the EP0i packet enable bit.
Rev. 2.00 Oct. 21, 2009 Page 1012 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.5.5
EP1 Bulk-Out Transfer (Dual FIFOs)
USB function
Application
OUT token reception
Space
in EP1 FIFO?
No
NACK
Yes
Data reception from host
Read EP1 receive data
size register (EPSZ1)
ACK
Set EP1 FIFO full status
(IFR0.EP1 FULL = 1)
Interrupt
request
Read data from EP1
data register (EPDR1)
Write 1 to EP1 read
complete bit
(TRG.EP1 RDFN = 1)
Both
EP1 FIFOs empty?
No Interrupt request
Yes
Clear EP1 FIFO full status
(IFR0.EP1 FULL = 0)
Figure 20.17 EP1 Bulk-Out Transfer Operation
EP1 has two 64-byte FIFOs, but the user can receive data and read receive data without being
aware of this dual-FIFO configuration.
When one FIFO is full after reception is completed, the EP1FULL bit in IFR0 is set. After the first
receive operation into one of the FIFOs when both FIFOs are empty, the other FIFO is empty, and
so the next packet can be received immediately. When both FIFOs are full, NACK is returned to
the host automatically. When reading of the receive data is completed following data reception, 1
is written to the EP1RDFN bit in TRG. This operation empties the FIFO that has just been read,
and makes it ready to receive the next packet.
Rev. 2.00 Oct. 21, 2009 Page 1013 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.5.6
EP2 Bulk-In Transfer (Dual FIFOs)
USB function
Application
IN token reception
Valid data
in EP2 FIFO?
No
Interrupt request
NACK
Clear EP2 transfer
request flag
(IFR0.EP2 TR = 0)
Yes
Enable EP2 FIFO
empty interrupt
(IER0.EP2 EMPTY = 1)
Data transmission to host
ACK
Space
in EP2 FIFO?
Yes
Set EP2
empty status
(IFR0.EP2
EMPTY = 1)
Interrupt
request
IFR0.EP2 EMPTY
interrupt
No
Clear EP2 empty status
(IFR0.EP2 EMPTY = 0)
Write one packet of data
to EP2 data register
(EPDR2)
Write 1 to EP2 packet
enable bit
(TRG.EP2 PKTE = 1)
Figure 20.18 EP2 Bulk-In Transfer Operation
EP2 has two 64-byte FIFOs, but the user can transmit data and write transmit data without being
aware of this dual-FIFO configuration. However, one data write is performed for one FIFO. For
example, even if both FIFOs are empty, it is not possible to perform EP2PKTE at one time after
consecutively writing 128 bytes of data. EP2PKTE must be performed for each 64-byte write.
When performing bulk-in transfer, as there is no valid data in the FIFOs on reception of the first
IN token, an EP2TR bit interrupt in IFR0 is requested. With this interrupt, 1 is written to the
EP2EMPTY bit in IER0, and the EP2 FIFO empty interrupt is enabled. At first, both EP2 FIFOs
are empty, and so an EP2 FIFO empty interrupt is generated immediately.
Rev. 2.00 Oct. 21, 2009 Page 1014 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
The data to be transmitted is written to the data register using this interrupt. After the first transmit
data write for one FIFO, the other FIFO is empty, and so the next transmit data can be written to
the other FIFO immediately. When both FIFOs are full, EP2 EMPTY is cleared to 0. If at least one
FIFO is empty, the EP2EMPTY bit in IFR0 is set to 1. When ACK is returned from the host after
data transmission is completed, the FIFO used in the data transmission becomes empty. If the
other FIFO contains valid transmit data at this time, transmission can be continued.
When transmission of all data has been completed, write 0 to the EP2EMPTY bit in IER0 and
disable interrupt requests.
20.5.7
EP3 Interrupt-In Transfer
USB function
Application
Is there data
for transmission
to host?
No
Yes
IN token reception
Write data to EP3 data
register (EPDR3)
Valid data
in EP3FIFO?
No
NACK
Yes
Write 1 to EP3 packet
enable bit
(TRG.EP3 PKTE = 1)
Data transmission to host
ACK
Set EP3 transmission
complete flag
(IFR1.EP3 TS = 1)
Interrupt request
Clear EP3 transmission
complete flag
(IFR1.EP3 TS = 0)
Is there data
for transmission
to host?
No
Yes
Write data to EP3 data
register (EPDR3)
Write 1 to EP3 packet
enable bit
(TRG.EP3 PKTE = 1)
Note: This flowchart shows just one example of interrupt transfer processing. Other possibilities include an
operation flow in which, if there is data to be transferred, the EP3 DE bit in the data status register is
referenced to confirm that the FIFO is empty, and then data is written to the FIFO.
Figure 20.19 Operation of EP3 Interrupt-In Transfer
Rev. 2.00 Oct. 21, 2009 Page 1015 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.6
Processing of USB Standard Commands and Class/Vendor
Commands
20.6.1
Processing of Commands Transmitted by Control Transfer
A command transmitted from the host by control transfer may require decoding and execution of
command processing on the application side. Whether command decoding is required on the
application side is indicated in table 20.7 below.
Table 20.7 Command Decoding on Application Side
Decoding not Necessary on Application Side
Decoding Necessary on Application Side
Clear Feature
Get Descriptor
Get Configuration
Class/Vendor command
Get Interface
Set Descriptor
Get Status
Sync Frame
Set Address
Set Configuration
Set Feature
Set Interface
If decoding is not necessary on the application side, command decoding and data stage and status
stage processing are performed automatically. No processing is necessary by the user. An interrupt
is not generated in this case.
If decoding is necessary on the application side, this module stores the command in the EP0s
FIFO. After reception is completed successfully, the IFR0/SETUP TS flag is set and an interrupt
request is generated. In the interrupt routine, eight bytes of data must be read from the EP0s data
register (EPDR0s) and decoded by firmware. The necessary data stage and status stage processing
should then be carried out according to the result of the decoding operation.
Rev. 2.00 Oct. 21, 2009 Page 1016 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.7
Stall Operations
20.7.1
Overview
This section describes stall operations in this module. There are two cases in which the USB
function module stall function is used:
• When the application forcibly stalls an endpoint for some reason
• When a stall is performed automatically within the USB function module due to a USB
specification violation
The USB function module has internal status bits that hold the status (stall or non-stall) of each
endpoint. When a transaction is sent from the host, the module references these internal status bits
and determines whether to return a stall to the host. These bits cannot be cleared by the
application; they must be cleared with a Clear Feature command from the host.
However, the internal status bit for EP0 is automatically cleared only when the setup command is
received.
20.7.2
Forcible Stall by Application
The application uses the EPSTL register to issue a stall request for the USB function module.
When the application wishes to stall a specific endpoint, it sets the corresponding bit in EPSTL (11 in figure 20.20). The internal status bits are not changed at this time. When a transaction is sent
from the host for the endpoint for which the EPSTL bit was set, the USB function module
references the internal status bit, and if this is not set, references the corresponding bit in EPSTL
(1-2 in figure 20.20). If the corresponding bit in EPSTL is set, the USB function module sets the
internal status bit and returns a stall handshake to the host (1-3 in figure 20.20). If the
corresponding bit in EPSTL is not set, the internal status bit is not changed and the transaction is
accepted.
Once an internal status bit is set, it remains set until cleared by a Clear Feature command from the
host, without regard to the EPSTL register. Even after a bit is cleared by the Clear Feature
command (3-1 in figure 20.20), the USB function module continues to return a stall handshake
while the bit in EPSTL is set, since the internal status bit is set each time a transaction is executed
for the corresponding endpoint (1-2 in figure 20.20). To clear a stall, therefore, it is necessary for
the corresponding bit in EPSTL to be cleared by the application, and also for the internal status bit
to be cleared with a Clear Feature command (2-1, 2-2, and 2-3 in figure 20.20).
Rev. 2.00 Oct. 21, 2009 Page 1017 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
(1) Transition from normal operation to stall
(1-1)
USB
EPSTL
0→1
Internal status bit
0
1. 1 written to EPSTL
by application
(1-2)
Reference
Transaction request
EPSTL
1
Internal status bit
0
(1-3)
Stall
STALL handshake
EPSTL
1
Internal status bit
0→1
1. IN/OUT token
received from host
2. EPSTL referenced
1. 1 set in EPSTL
2. Internal status bit
set to 1
3. Transmission of
STALL handshake
To (2-1) or (3-1)
(2) When Clear Feature is sent after EPSTL is cleared
(2-1)
Transaction request
1. EPSTL cleared to 0
by application
2. IN/OUT token
received from host
3. Internal status bit
already set to 1
4. EPSTL not
referenced
5. Internal status bit
not changed
Internal status bit
1
EPSTL
1→0
Internal status bit
1
EPSTL
0
1. Transmission of
STALL handshake
Internal status bit
1→0
EPSTL
0
1. Internal status bit
cleared to 0
(2-2)
STALL handshake
(2-3)
Clear Feature command
Normal status restored
(3) When Clear Feature is sent before EPSTL is cleared to 0
(3-1)
Clear Feature command
EPSTL
1
Internal status bit
1→0
To (1-2)
Figure 20.20 Forcible Stall by Application
Rev. 2.00 Oct. 21, 2009 Page 1018 of 1454
REJ09B0498-0200
1. Internal status bit
cleared to 0
2. EPSTL not changed
Section 20 USB Function Module (USB)
20.7.3
Automatic Stall by USB Function Module
When a stall setting is made with the Set Feature command, or in the event of a USB specification
violation, the USB function module automatically sets the internal status bit for the relevant
endpoint without regard to the EPSTL register, and returns a stall handshake (1-1 in figure 20.21).
Once an internal status bit is set, it remains set until cleared by a Clear Feature command from the
host, without regard to the EPSTL register. After a bit is cleared by the Clear Feature command,
EPSTL is referenced (3-1 in figure 20.21). The USB function module continues to return a stall
handshake while the internal status bit is set, since the internal status bit is set even if a transaction
is executed for the corresponding endpoint (2-1 and 2-2 in figure 20.21). To clear a stall, therefore,
the internal status bit must be cleared with a Clear Feature command (3-1 in figure 20.21). If set
by the application, EPSTL should also be cleared (2-1 in figure 20.21).
(1) Transition from normal operation to stall
(1-1)
STALL handshake
Internal status bit
0→1
EPSTL
0
To (2-1) or (3-1)
1. In case of USB
specification
violation, etc., USB
function module
stalls endpoint
automatically
(2) When transaction is performed when internal status bit is set, and Clear Feature is sent
(2-1)
Transaction request
Internal status bit
1
EPSTL
0
Internal status bit
1
EPSTL
0
1. EPSTL cleared to 0
by application
2. IN/OUT token
received from host
3. Internal status bit
already set to 1
4. EPSTL not
referenced
5. Internal status bit
not changed
(2-2)
STALL handshake
1. Transmission of
STALL handshake
Stall status maintained
(3) When Clear Feature is sent before transaction is performed
(3-1)
Clear Feature command
Internal status bit
1→0
EPSTL
0
1. Internal status bit
cleared to 0
2. EPSTL not changed
Normal status restored
Figure 20.21 Automatic Stall by USB Function Module
Rev. 2.00 Oct. 21, 2009 Page 1019 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.8
DMA Transfer
20.8.1
Overview
DMA transfer can be performed for endpoints 1 and 2 in this module. Note that word or longword
data cannot be transferred.
When endpoint 1 holds at least one byte of valid receive data, a DMA request for endpoint 1 is
generated. When endpoint 2 holds no valid data, a DMA request for endpoint 2 is generated.
If the DMA transfer is enabled by setting the EP1DMAE bit in the DMA transfer setting register
to 1, zero-length data reception at endpoint 1 is ignored. When the DMA transfer is enabled, the
RDFN bit for EP1 and PKTE bit for EP2 do not need to be set to 1 in TRG (note that the PKTE bit
must be set to 1 when the transfer data is less than the maximum number of bytes). When all the
data received at EP1 is read, the FIFO automatically enters the EMPTY state. When the maximum
number of bytes (64 bytes) are written to the EP2 FIFO, the FIFO automatically enters the FULL
state, and the data in the FIFO can be transmitted (see figures 20.22 and 20.23).
20.8.2
DMA Transfer for Endpoint 1
When the data received at EP1 is transferred by the DMA, the USB function module automatically
performs the same processing as writing 1 to the RDFN bit in TRG if the currently selected FIFO
becomes empty. Accordingly, in DMA transfer, do not write 1 to the RDFN bit for EPI in TRG. If
the user writes 1 to the RDFN bit in DMA transfer, correct operation cannot be guaranteed.
Figure 20.22 shows an example of receiving 150 bytes of data from the host. In this case, internal
processing which is the same as writing 1 to the RDFN bit in TRG is automatically performed
three times. This internal processing is performed when the currently selected data FIFO becomes
empty. Accordingly, this processing is automatically performed both when 64-byte data is sent
and when data less than 64 bytes is sent.
64 bytes
64 bytes
RDFN
(Automatically
performed)
22 bytes
RDFN
RDFN
(Automatically (Automatically
performed)
performed)
Figure 20.22 RDFN Bit Operation for EP1
Rev. 2.00 Oct. 21, 2009 Page 1020 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.8.3
DMA Transfer for Endpoint 2
When the transmit data at EP2 is transferred by the DMAC, the USB function module
automatically performs the same processing as writing 1 to the PKTE bit in TRG if the currently
selected FIFO (64 bytes) becomes full. Accordingly, to transfer data of a multiple of 64 bytes, the
user need not write 1 to the PKTE bit. To transfer data of less than 64 bytes, the user must write 1
to the PKTE bit using the DMA transfer end interrupt of the on-chip DMAC. If the user writes 1
to the PKTE bit when the maximum number of bytes (64 bytes) are transferred, correct operation
cannot be guaranteed.
Figure 20.23 shows an example for transmitting 150 bytes of data to the host. In this case, internal
processing which is the same as writing 1 to the PKTE bit in TRG is automatically performed
twice. This internal processing is performed when the currently selected data FIFO becomes full.
Accordingly, this processing is automatically performed only when 64-byte data is sent.
When the last 22 bytes are sent, the internal processing for writing 1 to the PKTE bit is not
performed, and the user must write 1 to the PKTE bit by software. In this case, the application has
no more data to transfer but the USB function module continues to output DMA requests for EP2
as long as the FIFO has an empty space. When all data has been transferred, write 0 to the
EP2DMAE bit in DMAR to cancel DMA requests for EP2.
64 bytes
64 bytes
PKTE
(Automatically
performed)
22 bytes
PKTE is
PKTE
(Automatically not performed
performed)
Execute by DMA transfer
end interrupt (user)
Figure 20.23 PKTE Bit Operation for EP2
Rev. 2.00 Oct. 21, 2009 Page 1021 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.9
Example of USB External Circuitry
1. USB Transceiver
This module supports the on-chip transceiver only, not the external transceiver.
2. D+ Pull-Up Control
The general output port (PM4) is used for D+ pull-up control pin. The PM4 pin is driven high
by the PULLUP_E bit of DMA when the USB cable VBUS is connected.
Thus, USB host/hub connection notification (D+ pill-up) is enabled.
3. Detection of USB Cable Connection/Disconnection
As USB states, etc., are managed by hardware in this module, a VBUS signal that recognizes
connection/disconnection is necessary. The power supply signal (VBUS) in the USB cable is
used for this purpose. However, if the cable is connected to the USB host/hub when the
function (system installing this LSI) power is off, a voltage (5 V) will be applied from the USB
host/hub. Therefore, an IC (such as an HD74LV1G08A or 2G08A) that allows voltage
application when the system power is off should be connected externally.
USB
Vcc
PULLUP_E
On-chip transceiver
Vcc
(3.3 V)
PM4
VBUS*3
DrVcc
(3.3 V)
USD+
USD-
DrVss
Vss
Vcc
(3.3 V)
Regulator*1
Vcc
*2
1.5 kΩ
External pull-up
control circuit
supporting full-speed
Notes:
VBUS
(5 V)
D+
D-
GND
USB connector
1. Reduce voltage to the operating voltage Vcc (3.3 V) of this LSI.
2. To protect this LSI from being damaged, use the IC (such as HD74LV-A Series) which can
be applied voltage even when the system power is turned off.
3. Prevent noise from the VBUS pin while the USB is performing communication.
Figure 20.24 Example of Circuitry in Bus Power Mode
Rev. 2.00 Oct. 21, 2009 Page 1022 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
USB
Vcc
PULLUP_E
On-chip transceiver
Vcc
(3.3 V)
PM4
VBUS*2
DrVcc
(3.3 V)
USD+
USD-
DrVss
Vss
3.3 V
Vcc
*1
Vcc
*1
1.5 kΩ
External pull-up
control circuit
supporting full-speed
VBUS
(5 V)
D+
D-
GND
USB connector
Notes:
1. To protect this LSI from being damaged, use the IC (such as HD74LV-A Series) which can
be applied voltage even when the system power is turned off.
2. Prevent noise from the VBUS pin while the USB is performing communication.
Figure 20.25 Example of Circuitry in Self Power Mode
Rev. 2.00 Oct. 21, 2009 Page 1023 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.10
Usage Notes
20.10.1 Receiving Setup Data
Note the following for EPDR0s that receives 8-byte setup data:
1. As a latest setup command must be received in high priority, the write from the USB bus takes
priority over the read from the CPU. If the next setup command reception is started while the
CPU is reading data after the data is received, the read from the CPU is forcibly terminated.
Therefore, the data read after reception is started becomes invalid.
2. EPDR0s must always be read in 8-byte units. If the read is terminated at a midpoint, the data
received at the next setup cannot be read correctly.
20.10.2 Clearing the FIFO
If a USB cable is disconnected during data transfer, the data being received or transmitted may
remain in the FIFO. When disconnecting a USB cable, clear the FIFO.
While a FIFO is transferring data, it must not be cleared.
20.10.3 Overreading and Overwriting the Data Registers
Note the following when reading or writing to a data register of this module.
(1)
Receive data registers
The receive data registers must not be read exceeding the valid amount of receive data, that is, the
number of bytes indicated by the receive data size register. Even for EPDR1 which has double
FIFO buffers, the maximum data to be read at one time is 64 bytes. After the data is read from the
current valid FIFO buffer, be sure to write 1 to EP1RDFN in TRG, which switches the valid
buffer, updates the receive data size to the new number of bytes, and enables the next data to be
received.
(2)
Transmit data registers
The transmit data registers must not be written to exceeding the maximum packet size. Even for
EPDR2 which has double FIFO buffers, write data within the maximum packet size at one time.
After the data is written, write 1 to PKTE in TRG to switch the valid buffer and enable the next
data to be written. Data must not be continuously written to the two FIFO buffers.
Rev. 2.00 Oct. 21, 2009 Page 1024 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.10.4 Assigning Interrupt Sources to EP0
The EP0-related interrupt sources indicated by the interrupt source bits (bits 0 to 3) in IFR0 must
be assigned to the same interrupt signal with ISR0. The other interrupt sources have no limitations.
20.10.5 Clearing the FIFO When DMA Transfer is Enabled
The endpoint 1 data register (EPDR1) cannot be cleared when DMA transfer for endpoint 1 is
enabled (EP1 DMAE in DMAR = 1). Cancel DMA transfer before clearing the register.
20.10.6 Notes on TR Interrupt
Note the following when using the transfer request interrupt (TR interrupt) for IN transfer to EP0i,
EP2, or EP3.
The TR interrupt flag is set if the FIFO for the target EP has no data when the IN token is sent
from the USB host. However, at the timing shown in figure 20.26, multiple TR interrupts occur
successively. Take appropriate measures against malfunction in such a case.
Note: This module determines whether to return NAKC if the FIFO of the target EP has no data
when receiving the IN token, but the TR interrupt flag is set after a NAKC handshake is
sent. If the next IN token is sent before PKTE of TRG is written to, the TR interrupt flag is
set again.
TR interrupt routine
TR interrupt routine
Clear
Writes
TRG.
TR flag transmit data PKTE
CPU
Host
IN token
IN token
USB
Determines whether
to return NACK
NACK
Determines whether
to return NACK
NACK
Sets TR flag
IN token
Transmits data
Sets TR flag
(Sets the flag again)
ACK
Figure 20.26 TR Interrupt Flag Set Timing
Rev. 2.00 Oct. 21, 2009 Page 1025 of 1454
REJ09B0498-0200
Section 20 USB Function Module (USB)
20.10.7 Restrictions on Peripheral Module Clock (Pφ) Operating Frequency
Specify the peripheral module clock (Pφ) for the USB at 14 MHz or more. To set the USB
dedicated clock (cku) at 48 MHz, specify the peripheral module clock (Pφ) as shown in table 20.8.
Operation cannot be guaranteed if any frequency other than in the following table is specified.
Table 20.8 Selection of Peripheral Clock (Pφ) when USB is Connected
MD_CLK
EXTAL Input Clock
Frequency
USB Dedicated Clock
(cku: 48 MHz)
Pφ
0
12 MHz
EXTAL × 4
EXTAL × 2 (24 MHz)
1
16 MHz
EXTAL × 3
EXTAL × 1 (16 MHz)
EXTAL × 2 (32 MHz)
20.10.8 Notes on Deep Software Standby Mode when USB is Used
1. Unlike software standby mode, deep standby software mode is canceled from the reset state.
For details, see section 28.8, Deep Software Standby Mode.
2. If the RAMCUT bit is set to 1 when the USB enters deep software standby mode, the register
states of the USB cannot be retained. When USB is used, set the RAMCUT bit to 1, and then,
make the USB enter deep software standby mode.
3. Set the USB module stop (MSTPC11) bit to 0 after canceling deep software standby mode.
4. If the DUSBIE bit is set to 0 when the USB enters deep software standby mode, software
standby mode cannot be canceled through USB RESUME interrupt. Set the DUSBIE bit to 1,
and then, make the USB enter deep software standby mode.
Rev. 2.00 Oct. 21, 2009 Page 1026 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Section 21 I2C Bus Interface 2 (IIC2)
This LSI has a two-channel I2C bus interface.
The I2C bus interface conforms to and provides a subset of the Philips I2C bus (inter-IC bus)
interface functions. The register configuration that controls the I2C bus differs partly from the
Philips configuration, however.
Figure 21.1 shows the block diagram of the I2C bus interface 2.
Figure 21.2 shows an example of I/O pin connections to external circuits.
21.1
Features
• 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.
• 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 or reception is not yet possible, drive the SCL signal 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
• Direct bus drive
Two pins, the SCL and SDA pins function as NMOS open-drain outputs.
• Module stop state can be set.
Rev. 2.00 Oct. 21, 2009 Page 1027 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Transfer clock
generator
SCL
Transmission/
reception
control circuit
Output
control
ICCRA
ICCRB
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
ICEIR
Interrupt
generator
[Legend]
ICCRA:
ICCRB:
ICMR:
ICSR:
ICIER:
ICDRT:
ICDRR:
ICDRS:
SAR:
I2C bus control register A
I2C bus control register B
I2C mode register
I2C status register
I2C interrupt enable register
I2C transmit data register
I2C receive data register
I2C bus shift register
Slave address register
Figure 21.1 Block Diagram of I2C Bus Interface 2
Rev. 2.00 Oct. 21, 2009 Page 1028 of 1454
REJ09B0498-0200
Interrupt request
2
Section 21 I C Bus Interface 2 (IIC2)
Vcc
SCL in
Vcc
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 21.2 Connections to the External Circuit by the I/O Pins
21.2
Input/Output Pins
Table 21.1 shows the pin configuration of the I2C bus interface 2.
Table 21.1 Pin Configuration of the I2C Bus Interface 2
Channel
Abbreviation
I/O
Function
0
SCL0
I/O
Channel 0 serial clock I/O pin
SDA0
I/O
Channel 0 serial data I/O pin
1
SCL1
I/O
Channel 1 serial clock I/O pin
SDA1
I/O
Channel 1 serial data I/O pin
Note: The pin symbols are represented as SCL and SDA; channel numbers are omitted in this
manual.
Rev. 2.00 Oct. 21, 2009 Page 1029 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.3
Register Descriptions
The I2C bus interface 2 has the following registers.
Channel 0:
•
•
•
•
•
•
•
•
•
I2C bus control register A_0 (ICCRA_0)
I2C bus control register B_0 (ICCRB_0)
I2C bus mode register_0 (ICMR_0)
I2C bus interrupt enable register_0 (ICIER_0)
I2C bus status register_0 (ICSR_0)
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 A_1 (ICCRA_1)
I2C bus control register B_1 (ICCRB_1)
I2C bus mode register_1 (ICMR_1)
I2C bus interrupt enable register_1 (ICIER_1)
I2C bus status register_1 (ICSR_1)
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)
Rev. 2.00 Oct. 21, 2009 Page 1030 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.3.1
I2C Bus Control Register A (ICCRA)
ICCRA enables or disables I2C bus interface, controls transmission or reception, and selects
master or slave mode, transmission or reception, and transfer clock frequency in master mode.
Bit
Bit Name
7
6
5
4
3
2
1
0
ICE
RCVD
MST
TRS
CKS3
CKS2
CKS1
CKS0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Initial Value
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
ICE
0
R/W
I2C Bus Interface Enable
0: This module is halted
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 operation when
TRS is 0 and 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
When arbitration is lost in master mode, 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.
Operating modes are described below according to
MST and TRS combination.
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
These bits are valid only in master mode. Make
setting according to the required transfer rate. For
details on the transfer rate, see table 21.2.
Rev. 2.00 Oct. 21, 2009 Page 1031 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Table 21.2 Transfer Rate
Bit 3
Bit 2
Bit 1
Bit 0
Transfer Rate
CKS3 CKS2 CKS1 CKS0 Clock
Pφ =
8 MHz
0
0
0
1
1
0
1
1
0
0
1
1
0
1
21.3.2
Pφ =
10 MHz
Pφ =
20 MHz
Pφ =
25 MHz
Pφ =
33 MHz
Pφ =
35 MHz
0
Pφ/28
286 kHz 357 kHz 714 kHz 893 kHz 1179 kHz 1250 kHz
1
Pφ/40
200 kHz 250 kHz 500 kHz 625 kHz 825 kHz 875 kHz
0
Pφ/48
167 kHz 208 kHz 417 kHz 521 kHz 688 kHz 729 kHz
1
Pφ/64
125 kHz 156 kHz 313 kHz 391 kHz 516 kHz 546 kHz
0
Pφ/168 47.6 kHz 59.5 kHz 119 kHz 149 kHz 196 kHz 208 kHz
1
Pφ/100 80.0 kHz 100 kHz 200 kHz 250 kHz 330 kHz 350 kHz
0
Pφ/112 71.4 kHz 89.3 kHz 179 kHz 223 kHz 295 kHz 312 kHz
1
Pφ/128 62.5 kHz 78.1 kHz 156 kHz 195 kHz 258 kHz 273 kHz
0
Pφ/56
143 kHz 179 kHz 357 kHz 446 kHz 589 kHz 625 kHz
1
Pφ/80
100 kHz 125 kHz 250 kHz 313 kHz 413 kHz 437 kHz
0
Pφ/96
83.3 kHz 104 kHz 208 kHz 260 kHz 344 kHz 364 kHz
1
Pφ/128 62.5 kHz 78.1 kHz 156 kHz 195 kHz 258 kHz 273 kHz
0
Pφ/336 23.8 kHz 29.8 kHz 59.5 kHz 74.4 kHz 98.2 kHz 104 kHz
1
Pφ/200 40.0 kHz 50.0 kHz 100 kHz 125 kHz 165 kHz 175 kHz
0
Pφ/224 35.7 kHz 44.6 kHz 89.3 kHz 112 kHz 147 kHz 156 kHz
1
Pφ/256 31.3 kHz 39.1 kHz 78.1 kHz 97.7 kHz 129 kHz 136 kHz
I2C Bus Control Register B (ICCRB)
ICCRB issues start/stop condition, manipulates the SDA pin, monitors the SCL pin, and controls
reset in the I2C control module.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
BBSY
SCP
SDAO
⎯
SCLO
⎯
IICRST
⎯
0
1
1
1
1
1
0
1
R/W
R/W
R
R/W
R
⎯
R/W
⎯
Rev. 2.00 Oct. 21, 2009 Page 1032 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Bit
Initial
Bit Name Value
R/W
Description
7
BBSY
R/W
Bus Busy
0
This bit indicates whether the I2C bus is occupied or
released and to issue start and stop conditions in master
mode. 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 SDA = high, assuming that
the stop condition has been issued. Follow this procedure
also when re-transmitting a start condition. To issue a
start or stop condition, use the MOV instruction.
6
SCP
1
R/W
Start/Stop Condition Issue
This bit controls the issuance of start or stop condition in
master mode.
To issue a start condition, write 1 to BBSY and 0 to SCP.
A re-transmit start condition is issued in the same way. To
issue a stop condition, write 0 to BBSY and 0 to SCP.
This bit is always read as 1. If 1 is written, the data is not
stored.
5
SDAO
1
R
This bit monitors the output level of SDA.
0: When reading, the SDA pin outputs a low level
1: When reading the SDA pin outputs a high level
4
⎯
1
R/W
Reserved
The write value should always be 1.
3
SCLO
1
R
This bit monitors the SCL output level.
When reading and SCLO is 1, the SCL pin outputs a high
level. When reading and SCLO is 0, the SCL pin outputs
a low level.
2
⎯
1
⎯
Reserved
This bit is always read as 1.
1
IICRST
0
R/W
IIC Control Module Reset
2
This bit reset the IIC control module except the I C
registers. If hang-up occurs because of communication
failure during I2C operation, by setting this bit to 1, the I2C
control module can be reset without setting ports and
initializing the registers.
0
⎯
1
⎯
Reserved
This bit is always read as 1.
Rev. 2.00 Oct. 21, 2009 Page 1033 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.3.3
I2C Bus Mode Register (ICMR)
ICMR selects MSB first or LSB first, controls the master mode wait and selects the number of
transfer bits.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
WAIT
⎯
⎯
BCWP
BC2
BC1
BC0
Initial Value
0
0
1
1
1
0
0
0
R/W
R/W
⎯
⎯
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R/W
Reserved
The write value should always be 0.
6
WAIT
0
R/W
Wait Insertion
This bit selects whether to insert a wait after data
transfer except for the acknowledge bit. When this bit is
set to 1, after the falling of the clock for the last data bit,
the low period is extended for two transfer clocks.
When this bit is cleared to 0, data and the acknowledge
bit are transferred consecutively with no waits inserted.
The setting of this bit is invalid in slave mode.
5
⎯
1
⎯
Reserved
4
⎯
1
⎯
These bits are always read as 1.
3
BCWP
1
R/W
BC Write Protect
This bit controls the modification of the BC2 to BC0
bits. When modifying, this bit should be cleared to 0
and the MOV instruction should be used.
0: When writing, the values of BC2 to BC0 are set
1: When reading, 1 is always read
When writing, the settings of BC2 to BC0 are invalid.
Rev. 2.00 Oct. 21, 2009 Page 1034 of 1454
REJ09B0498-0200
2
Section 21 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. The settings of these bits should be made during
intervals between transfer frames. When setting these
bits to a value other than 000, the setting should be
made while the SCL line is low. The value return to 000
automatically at the end of a data transfer including the
acknowledge bit.
000: 9
001: 2
010: 3
011: 4
100: 5
101: 6
110: 7
111: 8
21.3.4
I2C Bus Interrupt Enable Register (ICIER)
ICIER enables or disables interrupt sources and the acknowledge bits, sets the acknowledge bits to
be transferred, and confirms the acknowledge bit to be received.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
TIE
TEIE
RIE
NAKIE
STIE
ACKE
ACKBR
ACKBT
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R
R/W
Rev. 2.00 Oct. 21, 2009 Page 1035 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Bit
Initial
Bit Name Value
R/W
Description
7
TIE
R/W
Transmit Interrupt Enable
0
When the TDRE bit in ICSR is set to 1, this bit enables
or disables the transmit data empty interrupt (TXI)
request.
0: Transmit data empty interrupt (TXI) request is
disabled
1: Transmit data empty interrupt (TXI) request is
enabled
6
TEIE
0
R/W
Transmit End Interrupt Enable
This bit enables or disables the transmit end interrupt
(TEI) request at the rising of the ninth clock while the
TDRE bit in ICSR is set to 1. The TEI request can be
canceled by clearing the TEND bit or the TEIE bit to 0.
0: Transmit end interrupt (TEI) request is disabled
1: Transmit end interrupt (TEI) request is enabled
5
RIE
0
R/W
Receive Interrupt Enable
This bit enables or disables the receive full interrupt
(RXI) request when receive data is transferred from
ICDRS to ICDRR and the RDRF bit in ICSR is set to 1.
The RXI request can be canceled by clearing the
RDRF or RIE bit to 0.
0: Receive data full interrupt (RXI) request is disabled
1: Receive data full interrupt (RXI) request is enabled
4
NAKIE
0
R/W
NACK Receive Interrupt Enable
This bit enables or disables the NACK receive interrupt
(NAKI) request when the NACKF and AL bits in ICSR
are set to 1. The NAKI request can be canceled by
clearing the NACKF or AL bit, or the NAKIE bit to 0.
0: NACK receive interrupt (NAKI) request is disabled
1: NACK receive interrupt (NAKI) request is enabled
Rev. 2.00 Oct. 21, 2009 Page 1036 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Bit
Initial
Bit Name Value
R/W
Description
3
STIE
R/W
Stop Condition Detection Interrupt Enable
0
0: Stop condition detection interrupt (STPI) request is
disabled.
1: Stop condition detection interrupt (STPI) request is
enabled.
2
ACKE
0
R/W
Acknowledge Bit Decision Select
0: The value of the acknowledge bit is ignored and
continuous transfer is performed.
1: If the acknowledge bit is 1, continuous transfer is
suspended.
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. 2.00 Oct. 21, 2009 Page 1037 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.3.5
I2C Bus Status Register (ICSR)
ICSR confirms the interrupt request flags and status.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
TDRE
TEND
RDRF
NACKF
STOP
AL
AAS
ADZ
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
TDRE
0
R/W
Transmit Data Register Empty
[Setting conditions]
•
When data is transferred from ICDRT to ICDRS
and ICDRT becomes empty
•
When the TRS bits are set
•
When the start (re-transmit included) condition has
been issued
•
When switched from reception to transmission in
slave mode
[Clearing conditions]
•
When 0 is written to this bit after reading TDRE = 1
(When the CPU is used to clear this flag by writing
0 while the corresponding interrupt is enabled, be
sure to read the flag after writing 0 to it.)
•
6
TEND
0
R/W
When data is written to ICDRT
Transmit End
[Setting condition]
•
When the ninth clock of SCL rises while the TDRE
flag is 1
[Clearing conditions]
•
When 0 is written to this bit after reading TEND = 1
(When the CPU is used to clear this flag by writing
0 while the corresponding interrupt is enabled, be
sure to read the flag after writing 0 to it.)
•
Rev. 2.00 Oct. 21, 2009 Page 1038 of 1454
REJ09B0498-0200
When data is written to ICDRT
2
Section 21 I C Bus Interface 2 (IIC2)
Bit
Bit Name
Initial
Value
R/W
Description
5
RDRF
0
R/W
Receive Data Register Full
[Setting condition]
•
When receive data is transferred from ICDRS to
ICDRR
[Clearing conditions]
•
When 0 is written to this bit after reading RDRF = 1
(When the CPU is used to clear this flag by writing
0 while the corresponding interrupt is enabled, be
sure to read the flag after writing 0 to it.)
•
4
NACKF
0
R/W
When data is read from ICDRR
No Acknowledge Detection Flag
[Setting condition]
•
When no acknowledge is detected from the receive
device in transmission while the ACKE bit in ICIER
is set to 1
[Clearing condition]
•
When 0 is written to this bit after reading NACKF =
1
(When the CPU is used to clear this flag by writing
0 while the corresponding interrupt is enabled, be
sure to read the flag after writing 0 to it.)
3
STOP
0
R/W
Stop Condition Detection Flag
[Setting condition]
•
When a stop condition is detected after frame
transfer
[Clearing condition]
•
When 0 is written to this bit after reading STOP = 1
(When the CPU is used to clear this flag by writing
0 while the corresponding interrupt is enabled, be
sure to read the flag after writing 0 to it.)
Rev. 2.00 Oct. 21, 2009 Page 1039 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Bit
Bit Name
Initial
Value
R/W
Description
2
AL
0
R/W
Arbitration Lost Flag
This flag indicates that arbitration was lost in master
mode.
When two or more master devices attempt to seize the
bus at nearly the same time, the I2C bus monitors
SDA, and 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]
•
When the internal SDA and the SDA pin level
disagree at the rising of SCL in master transmit
mode
•
When the SDA pin outputs a high level in master
mode while a start condition is detected
[Clearing condition]
•
When 0 is written to this bit after reading AL = 1
(When the CPU is used to clear this flag by writing
0 while the corresponding interrupt is enabled, be
sure to read the flag after writing 0 to it.)
1
AAS
0
R/W
Slave Address Recognition Flag
In slave receive mode, this flag is set to 1 when 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]
•
Rev. 2.00 Oct. 21, 2009 Page 1040 of 1454
REJ09B0498-0200
When 0 is written to this bit after reading AAS = 1
2
Section 21 I C Bus Interface 2 (IIC2)
Bit
Bit Name
Initial
Value
R/W
Description
0
ADZ
0
R/W
General Call Address Recognition Flag
This bit is valid in slave receive mode.
[Setting condition]
•
When the general call address is detected in slave
receive mode
[Clearing condition]
•
21.3.6
When 0 is written to this bit after reading ADZ = 1
Slave Address Register (SAR)
SAR is sets the slave address. In slave mode, if the upper 7 bits of SAR match the upper 7 bits of
the first frame received after a start condition, the LSI operates as the slave device.
Bit
Bit Name
Initial Value
R/W
Bit
7 to 1
0
7
6
5
4
3
2
1
0
SVA6
SVA5
SVA4
SVA3
SVA2
SVA1
SVA0
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Initial
Bit Name Value
SVA6 to
SVA0
0
⎯
0
R/W
Description
R/W
Slave Address 6 to 0
These bits set a unique address differing from the
2
addresses of other slave devices connected to the I C
bus.
R/W
Reserved
Although this bit is readable/writable, only 0 should be
written to.
Rev. 2.00 Oct. 21, 2009 Page 1041 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.3.7
I2C Bus Transmit Data Register (ICDRT)
ICDRT is an 8-bit readable/writable register that stores the transmit data. When ICDRT detects a
space in the I2C bus shift register, it transfers the transmit data which has been written to ICDRT
to ICDRS and starts transmitting data. If the next data is written to ICDRT during transmitting
data to ICDRS, continuous transmission is possible.
Bit
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
21.3.8
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
I2C Bus Receive Data Register (ICDRR)
ICDRR is an 8-bit read-only register that stores the receive data. When one byte of data has been
received, ICDRR transfers the receive data from ICDRS to ICDRR and the next data can be
received. ICDRR is a receive-only register; therefore, this register cannot be written to by the
CPU.
Bit
7
6
5
4
3
2
1
0
Initial Value
1
1
1
1
1
1
1
1
R/W
R
R
R
R
R
R
R
R
Bit Name
21.3.9
I2C Bus Shift Register (ICDRS)
ICDRS is an 8-bit register that is used to transmit/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 one by of data is received. This register cannot be read from or
written to by the CPU.
Bit
7
6
5
4
3
2
1
0
Initial Value
0
0
0
0
0
0
0
0
R/W
−
−
−
−
−
−
−
−
Bit Name
Rev. 2.00 Oct. 21, 2009 Page 1042 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.4
Operation
21.4.1
I2C Bus Format
Figure 21.3 shows the I2C bus formats. Figure 21.4 shows the I2C bus timing. The first frame
following a start condition always consists of 8 bits.
(a) I2C bus format
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)
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 21.3 I2C Bus Formats
SDA
SCL
S
1-7
8
9
SLA
R/W
A
1-7
DATA
8
9
A
1-7
DATA
8
9
A
P
Figure 21.4 I2C Bus Timing
[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 low.
DATA: Transferred data
P:
Stop condition. The master device drives SDA from low to high while SCL is high.
Rev. 2.00 Oct. 21, 2009 Page 1043 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.4.2
Master Transmit Operation
In I2C bus format master transmit mode, the master device outputs the transmit clock and transmit
data, and the slave device return an acknowledge signal. Figures 21.5 and 21.6 show the operating
timings in master transmit mode. The transmission procedure and operations in master transmit
mode are described below.
1. Set the ICR bit in the corresponding register to 1. Set the ICE bit in ICCRA to 1. Set the WAIT
bit in ICMR and the CKS3 to CKS0 bits in ICCRA to 1. (initial setting)
2. Read the BSSY flag in ICCRB to confirm that the bus is free. Set the MST and TRS bits in
ICCRA to select master transmit mode. Then, write 1 to BBSY and 0 to SCP using the MOV
instruction. (The start condition is issued.) This generates the start condition.
3. After confirming that TDRE in ICSR has been set, write the transmit data (the first byte shows
the slave address and R/W) to ICDRT. After this, when TDRE is automatically cleared to 0,
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 rising of the ninth transmit clock pulse. Read the ACKBR bit in ICIER to confirm that
the slave device has been selected. Then, write the second byte data to ICDRT. When ACKBR
is 1, the slave device has not been acknowledged, so issue a stop condition. To issue the stop
condition, write 0 to BBSY and SCP using the MOV instruction. SCL is fixed to a low level
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 is 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. 2.00 Oct. 21, 2009 Page 1044 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
SCL
(Master output)
1
SDA
(Master output)
Bit 7
2
3
4
Bit 6
Bit 5
Bit 4
5
6
7
Bit 3
Bit 2
8
Bit 1
9
1
Bit 0
Bit 7
2
Bit 6
R/W
Slave address
SDA
(Slave output)
A
TDRE
TEND
ICDRT
Address + R/W
ICDRS
User
processing
Data 1
Data 1
Address + R/W
[2] Instruction of
start condition
issuance
Data 2
[4] Write data to ICDRT (second byte)
[3] Write data to ICDRT (first byte)
[5] Write data to ICDRT (third byte)
Figure 21.5 Master Transmit Mode Operation Timing 1
SCL
(Master output)
9
SDA
(Master output)
SDA
(Slave output)
1
Bit 7
2
3
4
Bit 6
Bit 5
Bit 4
A
5
6
7
Bit 3
Bit 2
Bit 1
8
9
Bit 0
A/A
TDRE
TEND
ICDRT
Data n
ICDRS
User
processing
Data n
[5] Write data to ICDRT
[6] Issue stop condition. Clear TEND.
[7] Set slave receive mode
Figure 21.6 Master Transmit Mode Operation Timing 2
Rev. 2.00 Oct. 21, 2009 Page 1045 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.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. Figures 21.7 and 21.8 show the operation timings in
master receive mode. 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 ICCRA to 0 to switch from master
transmit mode to master receive mode. Then, clear the TDRE bit to 0.
2. When ICDDR is read (dummy read), reception is started, the receive clock pulse is output, and
data is received, in synchronization with the internal clock. The master mode outputs the level
specified by the ACKBT in ICIER to SDA, at the ninth receive clock pulse.
3. After the reception of the first frame data is completed, the RDRF bit in ICSR is set to 1 at the
rising of the ninth receive clock pulse. At this time, the received data is read by reading
ICDRR. At the same time, RDRF is cleared.
4. The continuous reception is performed by reading ICDRR and clearing RDRF to 0 every time
RDRF is set. If the eighth receive clock pulse falls after reading ICDRR by other processing
while RDRF is 1, SCL is fixed to a low level until ICDRR is read.
5. If the next frame is the last receive data, set the RCVD bit in ICCRA 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 the rising of the ninth receive clock pulse, the stop condition
is issued.
7. When the STOP bit in ICSR is set to 1, read ICDRR and clear RCVD to 0.
8. The operation returns to the slave receive mode.
Rev. 2.00 Oct. 21, 2009 Page 1046 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Master transmit mode
SCL
(Master output)
Master receive mode
9
1
2
3
4
5
6
7
8
9
SDA
(Master output)
SDA
(Slave output)
1
A
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
[1] Clear TEND and
TRS, then TDRE
[2] Read ICDRR (dummy read)
[3] Read ICDRR
Figure 21.7 Master Receive Mode Operation Timing 1
Rev. 2.00 Oct. 21, 2009 Page 1047 of 1454
REJ09B0498-0200
2
Section 21 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-1
ICDRR
User
processing
Data n
Data n-1
[5] Set RCVD then read ICDRR
Data n
[6] Issue stop condition
[7] Read ICDRR and clear RCVD
[8] Set slave receive mode
Figure 21.8 Master Receive Mode Operation Timing 2
21.4.4
Slave Transmit Operation
In slave transmit mode, the slave device outputs the transmit data, and the master device outputs
the receive clock pulse and returns an acknowledge signal. Figures 21.9 and 21.10 show the
operation timings in slave transmit mode. The transmission procedure and operations in slave
transmit mode are described below.
1. Set the ICR bit in the corresponding register to 1, then set the ICE bit in ICCRA to 1. Set the
WAIT in ICMR and CKS3 to CKS0 in ICCRA(initial setting). Set the MST and TRS bits in
ICCRA to select slave receive mode, and wait until the slave address matches.
2. When the slave address matches in the first frame following the detection of the start
condition, the slave device outputs the level specified by ACKBT in ICIER to SDA, at the
rising of the ninth clock pulse. At this time, if the eighth bit data (R/W) is 1, TRS in ICCRA
and TDRE in ICSR are set to 1, and the mode changes to slave transmit mode automatically.
The continuous transmission is performed by writing the transmit data to ICDRT every time
TDRE is set.
3. If TDRE is set after writing the 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 end processing, and read ICDRR (dummy read) to release SCL.
5. Clear TDRE.
Rev. 2.00 Oct. 21, 2009 Page 1048 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Slave receive mode
SCL
(Master output)
Slave transmit mode
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
ICDRT
Data 1
ICDRS
Data 2
Data 1
Data 3
Data 2
ICDRR
User
processing
[2] Write data (data 1)
to ICDRT
[2] Write data (data 2)
to ICDRT
[2] Write data (data 3)
to ICDRT
Figure 21.9 Slave Transmit Mode Operation Timing 1
Rev. 2.00 Oct. 21, 2009 Page 1049 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Slave transmit mode
SCL
(Master output)
9
SDA
(Master output)
A
1
2
3
4
5
6
7
8
Slave receive mode
9
A/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] Clear TRS and
read ICDRR (dummy read)
Figure 21.10 Slave Transmit Mode Operation Timing 2
Rev. 2.00 Oct. 21, 2009 Page 1050 of 1454
REJ09B0498-0200
[5] Clear TDRE
2
Section 21 I C Bus Interface 2 (IIC2)
21.4.5
Slave Receive Operation
In slave receive mode, the master device outputs the transmit clock and the transmit data, and the
slave device returns an acknowledge signal. Figures 21.11 and 21.12 show the operation timings
in slave receive mode. The reception procedure and operations in slave receive mode are described
below.
1. Set the ICR bit in the corresponding register to 1. Then, set the ICE bit in ICCRA to 1. Set the
WAIT bit in ICMR or CKS3 to CKS0 in ICCRA (initial setting). Set the MST and TRS bits in
ICCRA 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 address outputs the level specified by ACKBT in ICIER to SDA, at the rising of the
ninth clock pulse. At the same time, RDRF in ICSR is set to read ICDRR (dummy read).
(Since the read data shows the slave address and R/W, it is not used).
3. Read ICDRR every time RDRF is set. If the eighth clock pulse falls while RDRF is 1, SCL is
fixed to a low level until ICDRR is read. The change of the acknowledge (ACKBT) setting
before reading ICDRR to be returned to the master device is reflected in 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
Data 2
ICDRR
User
processing
Data 1
[2] Read ICDRR (dummy read)
[2] Read ICDRR
Figure 21.11 Slave Receive Mode Operation Timing 1
Rev. 2.00 Oct. 21, 2009 Page 1051 of 1454
REJ09B0498-0200
2
Section 21 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 1
Data 2
ICDRR
Data 1
User
processing
[3] Set ACKBT
[3] Read ICDRR
[4] Read ICDRR
Figure 21.12 Slave Receive Mode Operation Timing 2
21.4.6
Noise Canceler
The logic levels at the SCL and SDA pins are routed through the noise cancelers before being
latched internally. Figure 21.13 shows a block diagram of the noise canceler circuit.
The noise canceler consists of two cascaded latches and a match detector. The signal input to SCL
(or SDA) 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.
Sampling clock
SCL input
or
SDA input
Sampling
clock
C
C
Q
D
Latch
D
Q
Latch
Compare
match
detection
circuit
System clock period
Sampling clock
Figure 21.13 Block Diagram of Noise Canceler
Rev. 2.00 Oct. 21, 2009 Page 1052 of 1454
REJ09B0498-0200
Internal SCL
or
internal SDA
2
Section 21 I C Bus Interface 2 (IIC2)
21.4.7
Example of Use
Sample flowcharts in respective modes that use the I2C bus interface are shown in figures 21.14 to
21.17.
Start
Initial settings
Read BBSY in ICCRB
[1]
No
[1]
Detect the state of the SCL and SDA lines
[2]
Set to master transmit mode
BBSY = 0?
Yes
Set MST = 1 and
TRS = 1 in ICCRA
[2]
[3]
Issue the start condition
Write BBSY = 1
and SCP = 0
[3]
[4]
Set the transmit data for the first byte (slave address + R/W)
Write the transmit
data in ICDRT
[4]
[5]
Wait for 1 byte of data to be transmitted
[6]
Detect the acknowledge bit, transferred from the specified slave device
[7]
Set the transmit data for the second and subsequent data (except for the
last byte)
[8]
Wait for ICDRT empty
[9]
Set the last byte of transmit data
Read TEND in ISCR
[5]
No
TEND = 1?
Yes
Read ACKBR in ICIER
[6]
ACKBR = 0?
No
Yes
Transmit
mode?
Yes
No
Write the transmit data to ICDRT
Master receive mode
[7]
[10] Wait for the completion of transmission of the last byte
Read TDRE in ICSR
[8]
[11] Clear the TEND flag
TDRE = 1?
[12] Clear the STOP flag
Yes
No
Last byte?
Yes
[9]
Write the transmit data to ICDRT
[14] Wait for the creation of the stop condition
Read TEND in ICSR
No
[13] Issue the stop condition
[10]
[15] Set to slave receive mode. Clear TDRE.
TEND = 1?
Yes
Clear TEND in ICSR
[11]
Clear STOP in ICSR
[12]
Write BBSY = 0
and SCP = 0
[13]
Read STOP in ICSR
No
[14]
STOP = 1?
Yes
Set MST = 0
and TRS = 0 in ICCRA
[15]
Clear TRDE in ICSR
End
Figure 21.14 Sample Flowchart of Master Transmit Mode
Rev. 2.00 Oct. 21, 2009 Page 1053 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Master receive mode
Clear TEND in ICSR
Set TRS = 0 (ICCRA)
[1]
Clear TDRE in ICSR
Set ACKBT = 0 (ICIER)
[2]
Dummy read ICDRR
[3]
Dummy read ICSR
No
[1]
Clear TEND, set to master receive mode, then clear TDRE*1*2
[2]
Set acknowledge to the transmitting device*1*2
[3]
Dummy read ICDRR*1*2
[4]
Wait for 1 byte of data to be received*2
[5]
Check if (last receive -1)*2
[6]
Read the receive data*2
[7]
Set acknowledge of the last byte. Disable continuous reception
(RCVD = 1).*2
[8]
Read receive data of (last byte -1).*2
[9]
Wait for the last byte to be received
[4]
RDRF = 1?
Yes
Last
receive -1?
Yes
[5]
No
Read ICDRR
[6]
[10] Clear the STOP flag
Set ACKBT = 1 (ICIER)
[7]
Set RCVD = 1 (ICCRA)
Read ICDRR
[12] Wait for the creation of stop condition
[8]
[13] Read the receive data of the last byte
[14] Clear RCVD to 0
Read RDRF in ICSR
[9]
No
[11] Issue the stop condition
RDRF = 1?
[15] Set to slave receive mode
Yes
Clear STOP in ICSR
[10]
Write BBSY = 0 and
SCP = 0
[11]
Read STOP in ICSR
[12]
No
STOP = 1?
Yes
Read ICDRR
[13]
Set RCVD = 0 (ICCRA)
[14]
Set MST = 0 (ICCRA)
[15]
End
Note: 1.
2.
Do not generate an interrupt during steps [1] to [3].
For one-byte reception, steps [2] to [6] do not need to be executed. After step [1], execute step [7].
In step [8], read ICDRR (dummy read).
Figure 21.15 Sample Flowchart for Master Receive Mode
Rev. 2.00 Oct. 21, 2009 Page 1054 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Slave transmit mode
Clear AAS in ICSR
[1]
Write the transmit data
to ICDRT
[2]
[2] Set the transmit data for ICDRT (except the last byte).
[3] Wait for ICDRT empty.
[4] Set the last byte of transmit data.
Read TRD in ICSR
No
[3]
[5] Wait for the last byte of data to be transmitted.
TDRE = 1?
[6] Clear the TEND flag.
Yes
No
[1] Clear the AAS flag.
[7] Set to slave receive mode.
Last byte?
Yes
Write the transmit data
to ICDRT
[4]
[8] Dummy read ICDRR to free the SCL line.
[9] Clear the TDRE flag.
Read TEND in ICSR
No
[5]
TEND = 1?
Yes
Clear TEND in ICSR
[6]
Set TRS = 0 (ICCRA)
[7]
Dummy read ICDRR
[8]
Clear TDRE in ICSR
[9]
End
Figure 21.16 Sample Flowchart for Slave Transmit Mode
Rev. 2.00 Oct. 21, 2009 Page 1055 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
Slave receive mode
Clear AAS in ICSR
[1]
Set ACKBT = 0 in ICIER
[2]
Dummy read ICDRR
[3]
[1] Clear the AAS flag.*
[2] Set the acknowledge for the transmit device.*
[3] Dummy read ICDRR*
[4] Wait for 1 byte of data to be received*
Read RDRF in ICSR
[5] Detect (last reception -1)*
No
[4]
[6] Read the receive data.*
RDRF = 1?
[7] Set the acknowledge for the last byte.*
Yes
The last
reception -1?
Yes
No
Read ICDRR
[5]
[8] Read the receive data of (last byte -1).*
[9] Wait for the reception of the last byte to be completed.
[6]
[10] Read the last byte of receive data.
Set ACKBT = 1 in ICIER
[7]
Read ICDRR
[8]
Read RDRF in ICSR
No
[9]
RDRF = 1?
Yes
Read ICDRR
[10]
End
Note: * For one-byte reception, steps [2] to [6] do not need to be executed. After step [1], execute step [7].
In step [8], read ICDRR (dummy read).
Figure 21.17 Sample Flowchart for Slave Receive Mode
Rev. 2.00 Oct. 21, 2009 Page 1056 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.5
Interrupt Request
There are six interrupt requests in this module; transmit data empty, transmit end, receive data full,
NACK detection, STOP recognition, and arbitration lost. Table 21.3 shows the contents of each
interrupt request.
Table 21.3 Interrupt Requests
Interrupt Request
Abbreviation
Interrupt Condition
Transmit Data Empty
TXI
(TDRE = 1) ⋅ (TIE = 1)
Transmit End
TEI
(TEND = 1) ⋅ (TEIE = 1)
Receive Data Full
RXI
(RDRF = 1) ⋅ (RIE = 1)
Stop Recognition
STPI
(STOP = 1) ⋅ (STIE = 1)
NACK Detection
NAKI
{(NACKF = 1) + (AL = 1)} ⋅ (NAKIE = 1)
Arbitration Lost
When one of the interrupt conditions in table 21.3 is 1 and the I bit in CCR is 0, the CPU executes
interrupt exception handling. Clear the interrupt sources during interrupt exception handling. Note
that the TDRE and TEND bits are automatically cleared to 0 by writing data to ICDRT, and the
RDRF bit is cleared to 0 by reading ICDRR. In particular, the TDRE bit can be set again at the
same time as data are for transmission written to ICDRT, and 1 extra byte can be transmitted if the
TDRE is again cleared to 0.
Rev. 2.00 Oct. 21, 2009 Page 1057 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.6
Bit Synchronous Circuit
This module has a possibility that the high-level period is shortened in the two states described
below.
In master mode,
• When SCL is driven low by the slave device
• When the rising speed of SCL is lowered by the load on the SCL line (load capacitance or
pull-up resistance)
Therefore, this module monitors SCL and communicates bit by bit in synchronization.
Figure 21.18 shows the timing of the bit synchronous circuit, and table 21.4 shows the time when
SCL output changes from low to Hi-Z and the period which SCL is monitored.
SCL monitor timing
reference clock
VIH
SCL
Internal SCL
Figure 21.18 Timing of the Bit Synchronous Circuit
Table 21.4 Time for Monitoring SCL
CKS3
CKS2
Time for Monitoring SCL
0
0
7.5 tcyc
1
19.5 tcyc
0
17.5 tcyc
1
41.5 tcyc
1
Rev. 2.00 Oct. 21, 2009 Page 1058 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
21.7
Usage Notes
1. 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 B (ICCRB).
If a stop or a repeated start condition is issued at 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 21.6, Bit Synchronous
Circuit, because of the load on the SCL bus (load capacitance or pull-up resistance).
⎯ The bit synchronous circuit is activated because a slave device holds the SCL bus low
during the eighth clock.
2. 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 eighth clock, the high level period of the ninth clock may be
shorter than a given period.
3. Restriction in transfer rate setting value in multi-master mode
When the transfer rate of I2C transfer of this LSI is slower than that of other master, the SCL
signal the width of which is unexpected may be output. To avoid this phenomenon, set a
transfer rate of 1/1.8 or more of the fastest rate of other master to the transfer rate of I2C
transfer rate. For example, if the fastest rate of other masters is 400 kbps, the I2C transfer rate
of this LSI should be 223 kbps (= 400/1.8) or more.
4. Restriction in bit manipulation when the MST and TRS bits are set in multi-master mode
When the MST and TRS bits are set to master slave mode by manipulating these bits
sequentially, the conflict state occurs as follows according to the timing that arbitration is lost;
The AL bit in ICSR is set to 0, and set to master mode (MST = 1, TRS = 1). There are the
following methods to avoid this phenomenon.
• In multi-master mode, set the MST and TRS bits by MOV instruction.
• When arbitration is lost, confirm that the MST and TRS bits are set to 0. If these bits are
set to other than 0, set these bits to 0.
5. Notes on master receive mode
In master receive mode, the RDRF bit is set to 0 at the eighth rising clock, the SCL signal is
pulled to “Low” state. When ICDRR is read near at the eighth falling clock, the SCL signal
level is released and the ninth clock is output by fixing the eighth clock of receive data to
“Low” state. Reading ICDRR is not required. As a result, the failure to receive data occurs.
There are the following methods to avoid this phenomenon.
• In master receive mode, read ICDRR by the eighth rising clock.
Rev. 2.00 Oct. 21, 2009 Page 1059 of 1454
REJ09B0498-0200
2
Section 21 I C Bus Interface 2 (IIC2)
•
In master receive mode, set the RCVD bit to 1 and process the bit by the communication
of every one byte.
6. Setting of the module stop function
Operation of the IIC2 can be disabled or enabled using the module stop control register. The
initial setting is for operation of the IIC2 to be halted. Register access is enabled by clearing
module stop state. For details, see section 28, Power-Down Modes.
Rev. 2.00 Oct. 21, 2009 Page 1060 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Section 22 A/D Converter
This LSI includes two units (units 0 and 1) of successive approximation type 10-bit A/D
converter. The A/D converter unit 0 allows up to eight analog input channels to be selected while
the A/D converter unit 1 allows up to four analog input channels to be selected.
Figures 22.1 and 22.2 show block diagrams of the A/D converter units 0 and 1, respectively.
22.1
Features
• 10-bit resolution
• Eight or four input channels (total eight input channels for the two units)
Four channels x two units (for unit 0 and unit 1)
Eight channels x one unit (for unit 0)
• Conversion time: 2.7 μs per channel (in peripheral clock mode)
1.0 μs per channel (in system clock mode*3)
• Two kinds of operating modes
⎯ Single mode: Single-channel A/D conversion
⎯ Scan mode: Continuous A/D conversion on 1 to 4 channels, or 1 to 8 channels*1
• Eight data registers for the A/D converter unit 0 and four data registers for unit 1 (total eight
data registers for the two units)
Results of A/D conversion are held in a 16-bit data register for each channel.
• Sample and hold functionality
• Three types of conversion start
Conversion can be started by software, a conversion start trigger by the 16-bit timer pulse unit
(TPU)*1 or 8-bit timer (TMR)*2, or an external trigger signal.
• Function of starting units simultaneously
A/D conversion for multiple units can be started by external trigger (ADTRG0).
• Interrupt source
A/D conversion end interrupt (ADI) request can be generated.
• Module stop state specifiable
Notes: 1. Only supported in the A/D converter unit 0.
2. For unit 0, A/D conversion can be started by a conversion start trigger by the TMR
units 0 and 1, whereas for unit 1, A/D conversion can be started by a conversion start
trigger by the TMR units 2 and 3.
Rev. 2.00 Oct. 21, 2009 Page 1061 of 1454
REJ09B0498-0200
Section 22 A/D Converter
3. The full-spec emulator (E6000H) should not be used, but the on-chip emulator (E10AUSB) is usable.
Internal
data bus
AVSS
Bus interface
ADMOSEL_0
ADSSTR_0
ADCR_0
ADCSR_0
ADDRH_0
ADDRG_0
ADDRF_0
ADDRE_0
ADDRD_0
ADDRC_0
10-bit D/A
ADDRB_0
Vref
ADDRA_0
AVCC
Successive approximation
register
Module data bus
AN0
+
AN1
AN2
AN4
AN5
–
Multiplexer
AN3
AN6
Comparator
Control circuit
Sample-andhold circuit
AN7
ADI0 interrupt
signal
ADTRG0
Conversion start
trigger from the
TPU or TMR (units 0, 1)
Synchronization
circuit
[Legend]
ADCR_0:
ADCSR_0:
ADSSTR_0:
ADMOSEL_0:
ADDRA_0:
ADDRB_0:
ADDRC_0:
A/D control register_0
A/D control/status register_0
A/D sampling state register_0
A/D mode select register_0
A/D data register A_0
A/D data register B_0
A/D data register C_0
ADDRD_0:
ADDRE_0:
ADDRF_0:
ADDRG_0:
ADDRH_0:
A/D data register D_0
A/D data register E_0
A/D data register F_0
A/D data register G_0
A/D data register H_0
Figure 22.1 Block Diagram of A/D Converter Unit 0 (AD_0)
Rev. 2.00 Oct. 21, 2009 Page 1062 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Internal
data bus
AVSS
AN4
ADMOSEL_1
ADSSTR_1
ADCR_1
ADCSR_1
ADDRH_1
ADDRG_1
ADDRF_1
ADDRE_1
ADDRD_1
ADDRC_1
ADDRB_1
10-bit D/A
ADDRA_1
Vref
Successive approximation
register
AVCC
Bus interface
Module data bus
+
AN6
Multiplexer
–
AN5
Comparator
Control circuit
Sample-andhold circuit
AN7
ADI1 interrupt
signal
ADTRG1
ADTRG0
[Legend]
ADCR_1:
ADCSR_1:
ADSSTR_1:
ADMOSEL_1:
ADDRA_1:
ADDRB_1:
ADDRC_1:
Conversion start
trigger from the
TMR (units 2, 3)
Synchronization
circuit
A/D control register_1
A/D control/status register_1
A/D sampling state register_1
A/D mode select register_1
A/D data register A_1
A/D data register B_1
A/D data register C_1
ADDRD_1:
ADDRE_1:
ADDRF_1:
ADDRG_1:
ADDRH_1:
A/D data register D_1
A/D data register E_1
A/D data register F_1
A/D data register G_1
A/D data register H_1
Figure 22.2 Block Diagram of A/D Converter Unit 1 (AD_1)
Rev. 2.00 Oct. 21, 2009 Page 1063 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.2
Input/Output Pins
Table 22.1 shows the pin configuration of the A/D converter.
Table 22.1 Pin Configuration
Unit
Abbr.
Pin Name
Symbol
I/O
Function
0
AD_0
Analog input pin 0
AN0
Input
Analog inputs
Analog input pin 1
AN1
Input
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
A/D external trigger
input pin 0
ADTRG0
Input
External trigger input for
starting A/D conversion*
Analog input pin 4
AN4
Input
Analog inputs
Analog input pin 5
AN5
Input
Analog input pin 6
AN6
Input
Analog input pin 7
AN7
Input
A/D external trigger
input pin 0
ADTRG0
Input
External trigger input pin for
starting A/D conversion*
A/D external trigger
input pin 1
ADTRG1
Input
External trigger input pin for
starting A/D conversion*
Analog power supply pin
AVCC
Input
Analog block power supply
Analog ground pin
AVSS
Input
Analog block ground
Reference voltage pin
Vref
Input
A/D conversion reference
voltage
1
AD_1
Common
Note:
*
Selectable by setting of the TRGS1, TRGS0, and EXTRGS bits in ADCR.
Rev. 2.00 Oct. 21, 2009 Page 1064 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.3
Register Descriptions
The A/D converter has the following registers.
Unit 0 (A/D_0) registers:
•
•
•
•
•
•
•
•
•
•
•
•
A/D data register A_0 (ADDRA_0)
A/D data register B_0 (ADDRB_0)
A/D data register C_0 (ADDRC_0)
A/D data register D_0 (ADDRD_0)
A/D data register E_0 (ADDRE_0)
A/D data register F_0 (ADDRF_0)
A/D data register G_0 (ADDRG_0)
A/D data register H_0 (ADDRH_0)
A/D control/status register_0 (ADCSR_0)
A/D control register_0 (ADCR_0)
A/D mode selection register_0 (ADMOSEL_0)
A/D sampling state register_0 (ADSSTR_0)
Unit 1 (A/D_1) registers:
•
•
•
•
•
•
•
•
•
•
•
•
A/D data register A_1 (ADDRA_1)
A/D data register B_1 (ADDRB_1)
A/D data register C_1 (ADDRC_1)
A/D data register D_1 (ADDRD_1)
A/D data register E_1 (ADDRE_1)
A/D data register F_1 (ADDRF_1)
A/D data register G_1 (ADDRG_1)
A/D data register H_1 (ADDRH_1)
A/D control/status register_1 (ADCSR_1)
A/D control register_1 (ADCR_1)
A/D mode selection register_1 (ADMOSEL_1)
A/D sampling state register_1 (ADSSTR_1)
Rev. 2.00 Oct. 21, 2009 Page 1065 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.3.1
A/D Data Registers A to H (ADDRA to ADDRH)
There are eight 16-bit read-only ADDR registers, ADDRA to ADDRH, used to store the results of
A/D conversion. The ADDR registers, which store a conversion result for each channel, are shown
in table 22.2.
The converted 10-bit data is stored in bits 15 to 6. The lower 6-bit data is always read as 0.
The data bus between the CPU and the A/D converter has a 16-bit width. The data can be read
directly from the CPU. ADDR must not be accessed in 8-bit units and must be accessed in 16-bit
units.
Bit
15
14
13
12
11
10
9
8
7
6
Initial Value
0
0
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R
R
R
Bit Name
5
4
3
2
1
0
⎯
⎯
⎯
⎯
⎯
⎯
0
0
0
0
0
0
R
R
R
R
R
R
Table 22.2 Analog Input Channels and Corresponding ADDR Registers
Analog
Input
Channel
Unit 0
Unit 1*
AN0
ADDRA_0 (Unit 0)
⎯
AN1
ADDRB_0 (Unit 0)
⎯
AN2
ADDRC_0 (Unit 0)
⎯
AN3
ADDRD_0 (Unit 0)
AN4
A/D Data Register Storing Conversion Result
2
⎯
1
ADDRE_1 (Unit 1)*1
1
ADDRF_1 (Unit 1)*1
ADDRE_0 (Unit 0)*
AN5
ADDRF_0 (Unit 0)*
AN6
ADDRG_0 (Unit 0)*1
ADDRG_1 (Unit 1)*1
AN7
ADDRH_0 (Unit 0)*1
ADDRH_1 (Unit 1)*1
Notes: 1. A/D conversion should not be performed on the same channel by multiple units.
2. The ADDRA_1 to ADDRD_1 registers for unit 1 are not used.
Rev. 2.00 Oct. 21, 2009 Page 1066 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.3.2
A/D Control/Status Register_0 (ADCSR_0) for Unit 0
ADCSR controls A/D conversion operations.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
ADF
ADIE
ADST
EXCKS
CH3
CH2
CH1
CH0
0
0
0
0
0
0
0
0
R/W
R/W*2
R/W
R/W
R/W
R/W
R/(W)*1
R/W
Notes: 1. Only 0 can be written to this bit to clear the flag.
2. The full-spec emulator (E6000H) should not be used, but the on-chip emulator (E10AUSB) is usable.
Bit
7
Bit Name
ADF
Initial
Value
0
R/W
Description
1
R/(W)* A/D End Flag
A status flag that indicates the end of A/D conversion.
[Setting conditions]
•
Completion of A/D conversion in single mode
•
Completion of A/D conversion on all specified
channels in scan mode
[Clearing conditions]
•
Writing of 0 after reading ADF = 1
(When the CPU is used to clear this flag by writing 0
while the corresponding interrupt is enabled, be sure
to read the flag after writing 0 to it.)
•
6
ADIE
0
R/W
Reading from ADDR after activation of the DMAC or
DTC by an ADI interrupt
A/D Interrupt Enable
Setting this bit to 1 enables ADI interrupts by ADF.
Rev. 2.00 Oct. 21, 2009 Page 1067 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Bit
Bit Name
Initial
Value
R/W
Description
5
ADST
0
R/W
A/D Start
Clearing this bit to 0 stops A/D conversion, and the A/D
converter enters wait state.
Setting this bit to 1 starts A/D conversion. In single mode,
this bit is cleared to 0 automatically when A/D conversion
on the specified channel ends. In scan mode, A/D
conversion continues sequentially on the specified
channels until this bit is cleared to 0 by software, a reset,
or hardware standby mode. In addition, when the
ADSTCLR bit in ADCR is 1, the ADST bit is automatically
cleared to 0 upon completion of A/D conversion for all of
the selected channels to stop A/D conversion.
The ADST bit is automatically cleared at a different time
from that of setting the ADF bit. The ADST bit is cleared
before setting the ADF bit.
4
EXCKS*2
0
R/W
Extended Clock Selection
Sets the A/D conversion time in accord with bits CKS1
and CKS0 in ADCR and the ICKSEL bit in ADMOSEL.
For details, see section 22.3.4, A/D Control Register_0
(ADCR_0) for Unit 0. Write to the EXCKS bit at the same
time as bits CKS1 and CKS0 in ADCR.
Rev. 2.00 Oct. 21, 2009 Page 1068 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Bit
Bit Name
Initial
Value
R/W
Description
3
2
1
0
CH3
CH2
CH1
CH0
0
0
0
0
R/W
R/W
R/W
R/W
Channel Select 3 to 0
Selects analog input together with bits SCANE and
SCANS in ADCR.
• When SCANE = 0 and SCANS = x
0000: AN0
0001: AN1
0010: AN2
0011: AN3
0100: AN4
0101: AN5
0110: AN6
0111: AN7
1xxx: Setting prohibited
• When SCANE = 1 and SCANS = 0
0000: AN0
0001: AN0 and AN1
0010: AN0 to AN2
0011: AN0 to AN3
0100: AN4
0101: AN4 and AN5
0110: AN4 to AN6
0111: AN4 to AN7
1xxx: Setting prohibited
• When SCANE = 1 and SCANS = 1
0000: AN0
0001: AN0 and AN1
0010: AN0 to AN2
0011: AN0 to AN3
0100: AN0 to AN4
0101: AN0 to AN5
0110: AN0 to AN6
0111: AN0 to AN7
1xxx: Setting prohibited
[Legend]
x:
Don't care
Notes: 1. Only 0 can be written to this bit, to clear the flag.
2. The full-spec emulator (E6000H) should not be used, but the on-chip emulator (E10AUSB) is usable.
Rev. 2.00 Oct. 21, 2009 Page 1069 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.3.3
A/D Control/Status Register 1 (ADCSR_1) for Unit 1
ADCSR controls A/D conversion operations.
Bit
Bit Name
7
6
5
4
3
2
1
0
ADF
ADIE
ADST
EXCKS
CH3
CH2
CH1
CH0
0
0
0
0
0
0
0
0
R/(W)*
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Initial Value
R/W
Note: * Only 0 can be written to this bit, to clear the flag.
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]
•
•
Completion of A/D conversion in single mode
Completion of A/D conversion on all specified channels in
scan mode
[Clearing conditions]
•
•
6
ADIE
0
R/W
5
ADST
0
R/W
Writing of 0 after reading ADF = 1
(When the CPU is used to clear this flag by writing 0 while
the corresponding interrupt is enabled, be sure to read the
flag after writing 0 to it.)
Reading from ADDR after activation of the DMAC or DTC by
an ADI interrupt
A/D Interrupt Enable
Setting this bit to 1 enables ADI interrupts by ADF.
A/D Start
Clearing this bit to 0 stops A/D conversion, and the A/D
converter enters wait state.
Setting this bit to 1 starts A/D conversion. In single mode, this bit
is cleared to 0 automatically when A/D conversion on the
specified channel ends. In scan mode, A/D conversion
continues sequentially on the specified channels until this bit is
cleared to 0 by software, a reset, or hardware standby mode. In
addition, when the ADSTCLR bit in ADCR is 1, the ADST bit is
automatically cleared to 0 upon completion of A/D conversion for
all of the selected channels to stop A/D conversion.
The ADST bit is automatically cleared at a different time from
that of setting the ADF bit. The ADST bit is cleared before
setting the ADF bit.
Rev. 2.00 Oct. 21, 2009 Page 1070 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Bit
Bit Name
Initial
Value
R/W
Description
4
EXCKS
0
R/W
Extended Clock Selection
Sets the A/D conversion time in accord with bits CKS1 and
CKS0 in ADCR and the ICKSEL bit in ADMOSEL. For details,
see section 22.3.5, A/D Control Register_1 (ADCR_1) for Unit 1.
Write to the EXCKS bit at the same time as bits CKS1 and
CKS0 in ADCR.
3
2
1
0
CH3
CH2
CH1
CH0
0
0
0
0
R/W
R/W
R/W
R/W
Channel Select 3 to 0
Selects analog input together with bits SCANE and SCANS in
ADCR.
• When SCANE = 0 and SCANS = x
00xx: Setting prohibited
0100: AN4
0101: AN5
0110: AN6
0111: AN7
1xxx: Setting prohibited
• When SCANE = 1 and SCANS = 0
00xx: Setting prohibited
0100: AN4
0101: AN4 and AN5
0110: AN4 to AN6
0111: AN4 to AN7
1xxx: Setting prohibited
• When SCANE = 1 and SCANS = 1
xxxx: Setting prohibited
[Legend]
x:
Don't care
Note: * Only 0 can be written to this bit, to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 1071 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.3.4
A/D Control Register_0 (ADCR_0) for Unit 0
ADCR enables A/D conversion to be started by an external trigger input.
Bit
Bit Name
7
6
5
4
3
2
1
0
TRGS1
TRGS0
SCANE
SCANS
CKS1
CKS0
-
EXTRGS
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Bit Name
Initial
Value R/W Description
7
TRGS1
0
R/W Timer Trigger Select 1 and 0, Extended Trigger Select
6
TRGS0
0
0
EXTRGS
0
R/W These bits select enabling or disabling of the start of A/D conversion
R/W by a trigger signal.
000: Disables starting of A/D conversion by external trigger
010: A/D conversion is started by conversion trigger from TPU
(unit 0)
100: A/D conversion is started by conversion trigger from TMR
(units 0 and 1)
110: A/D conversion is started by the ADTRG0 signal*
1
001: External trigger is invalid
011: Setting prohibited
101: Setting prohibited
111: A/D conversion is started by the ADTRG0 signal*1 (starts units
simultaneously)
5
SCANE
0
R/W Scan Mode
4
SCANS
0
R/W These bits select the A/D conversion operating mode.
0x: Single mode
10: Scan mode. A/D conversion is performed continuously for
channels 1 to 4.
11: Scan mode. A/D conversion is performed continuously for
channels 1 to 8.
Rev. 2.00 Oct. 21, 2009 Page 1072 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Bit Bit Name
Initial
Value R/W Description
3
CKS1
0
R/W Clock Select 1 and 0
2
CKS0
0
R/W In conjunction with the EXCKS*2 bit in ADCSR and the ICKSEL*3 bit
in ADMOSEL, these bits set the A/D conversion time.
Make settings for the A/D conversion time while the ADST bit in
ADCSR is 0, and then set the mode of A/D conversion.
Furthermore, for transitions to software standby mode and modulestop mode, set these bits to b'11 beforehand.
2
3
EXCKS* , ICKSEL* , CKS1, CKS0
0000: A/D conversion time = 528 states*4 (max.)
0001: A/D conversion time = 268 states*4 (max.)
4
0010: A/D conversion time = 138 states* (max.)
0011: A/D conversion time = 73 states*4 (max.)
01xx: Prohibited setting
1000: A/D conversion time = 336 states*4 (max.)
1001: A/D conversion time = 172 states*4 (max.)
1010: A/D conversion time = 90 states*4 (max.)
1011: A/D conversion time = 49 states*4 (max.)
11xx: A/D conversion time = 34 states*4*5 (max.)
This setting applies when Pφ = Iφ/2*6.
1
ADSTCLR*2 0
R/W A/D Start Clear
Enables or disables automatic clearing of the ADST bit in scan
mode.
0: The ADST bit is not automatically cleared to 0 in scan mode.
1: The ADST bit is cleared to 0 upon completion of A/D conversion
for all of the selected channels in scan mode.
[Legend]
x:
Don't care
Notes: 1. To set A/D conversion to start by the ADTRG pin, the DDR bit and ICR bit for the
corresponding pin should be set to 0 and 1, respectively. For details, see section 13, I/O
Ports.
2. The full-spec emulator (E6000H) should not be used, but the on-chip emulator (E10AUSB) is usable.
3. ICKSEL = 1: The full-spec emulator (E6000H) should not be used, but the on-chip
emulator (E10A-USB) is usable.
4. Cycles of Pφ
5. Set the number of "states" (clock cycles) for sampling to 25 (ADSSTR_0 = D'25).
6. When Pφ = Iφ, Iφ/4, or Iφ/8, settings of the form 11xx are prohibited.
Rev. 2.00 Oct. 21, 2009 Page 1073 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.3.5
A/D Control Register_1 (ADCR_1) for Unit 1
ADCR enables A/D conversion to be started by an external trigger input.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
TRGS1
TRGS0
SCANE
SCANS
CKS1
CKS0
ADSTCLR
EXTRGS
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Initial
Bit Bit Name Value R/W Description
7
TRGS1
0
R/W Timer Trigger Select 1 and 0, Extended Trigger Select
6
TRGS0
0
0
EXTRGS
0
R/W These bits select enabling or disabling of the start of A/D conversion
R/W by a trigger signal.
000: Disables starting of A/D conversion by external trigger
010: Setting prohibited
100: Setting prohibited
110: A/D conversion is started by the ADTRG1 signal*
1
001: Setting prohibited
011: External trigger is invalid
101: A/D conversion is started by conversion trigger from TMR (units
2 and 3)
111: A/D conversion is started by the ADTRG0 signal*1 (starts units
simultaneously)
5
SCANE
0
R/W Scan Mode
4
SCANS
0
R/W These bits select the A/D conversion operating mode.
0x: Single mode
10: Scan mode. A/D conversion is performed continuously for
channels 1 to 4.
11: Setting prohibited
Rev. 2.00 Oct. 21, 2009 Page 1074 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Initial
Bit Bit Name Value R/W Description
3
CKS1
0
R/W Clock Select 1 and 0
2
CKS1
0
2
R/W In conjunction with the EXCKS bit in ADCSR and the ICKSEL* bit in
ADMOSEL, these bits set the A/D conversion time.
Make settings for the A/D conversion time while the ADST bit in
ADCSR is 0, and then set the mode of A/D conversion. Furthermore,
for transitions to software standby mode and module-stop mode, set
these bits to b'11 beforehand.
EXCKS*2, ICKSEL, CKS1, CKS0
3
0000: A/D conversion time = 528 states* (max.)
3
0001: A/D conversion time = 268 states* (max.)
3
0010: A/D conversion time = 138 states* (max.)
3
0011: A/D conversion time = 73 states* (max.)
01xx: Prohibited setting
3
1000: A/D conversion time = 336 states* (max.)
3
1001: A/D conversion time = 172 states* (max.)
3
1010: A/D conversion time = 90 states* (max.)
3
1011: A/D conversion time = 49 states* (max.)
3
4
11xx: A/D conversion time = 34 states* * (max.)
This setting applies when Pφ = Iφ/2*5.
1
ADSTCLR 0
R/W A/D Start Clear
Enables or disables automatic clearing of the ADST bit in scan mode.
0: The ADST bit is not automatically cleared to 0 in scan mode.
1: The ADST bit is cleared to 0 upon completion of A/D conversion for
all of the selected channels in scan mode.
[Legend]
x:
Don't care
Notes: 1. To set A/D conversion to start by the ADTRG pin, the DDR bit and ICR bit for the
corresponding pin should be set to 0 and 1, respectively. For details, see section 13, I/O
Ports.
2. Access to the full-spec emulator (E6000H) is prohibited but the on-chip emulator (E10AUSB) is usable.
3. Cycles of Pφ
4. Set the number of "states" (clock cycles) for sampling to 25 (ADSSTR_1 = D'25).
5. When Pφ = Iφ, Iφ/4, or Iφ/8, settings of the form 11xx are prohibited.
Rev. 2.00 Oct. 21, 2009 Page 1075 of 1454
REJ09B0498-0200
Section 22 A/D Converter
A/D Mode Selection Register_0 (ADMOSEL_0*1) for Unit 0
22.3.6
ADMOSEL*1 is used to select the system clock mode.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
ICKSEL
⎯
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
⎯
0
R
5
⎯
0
R
These bits are always read as 0. The write value should
always be 0.
4
⎯
0
R
3
⎯
0
R
2
⎯
0
R
0
R/W
1
1
ICKSEL*
System Clock Mode Selection
This bit is used to select the system clock mode.
0: Peripheral clock mode
1: System clock mode*
2
For details, see section 22.4.5, Setting the System Clock
Mode.
0
⎯
0
R/W
Reserved
This bit is always read as 0. The write value should always
be 0.
Notes: 1. The full-spec emulator (E6000H) should not be used, but the on-chip emulator (E10AUSB) is usable.
2. In system clock mode, operate all units with the system clock.
Rev. 2.00 Oct. 21, 2009 Page 1076 of 1454
REJ09B0498-0200
Section 22 A/D Converter
A/D Mode Selection Register_1 (ADMOSEL_1*1) for Unit 1
22.3.7
ADMOSEL*1 is used to select the system clock mode.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
ICKSEL
⎯
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R
Reserved
6
⎯
0
R
5
⎯
0
R
These bits are always read as 0. The write value should
always be 0.
4
⎯
0
R
3
⎯
0
R
2
⎯
0
R
0
R/W
1
1
ICKSEL*
System Clock Mode Selection
This bit is used to select the system clock mode.
0: Peripheral clock mode
2
1: System clock mode*
For details, see section 22.4.5, Setting the System Clock
Mode.
0
⎯
0
R/W
Reserved
This bit is always read as 0. The write value should always
be 0.
Notes: 1. Access to the full-spec emulator (E6000H) is prohibited but the on-chip emulator (E10AUSB) is usable.
2. In system clock mode, operate all units with the system clock.
Rev. 2.00 Oct. 21, 2009 Page 1077 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.3.8
A/D Sampling State Register_0 (ADSSTR_0*) for Unit 0
ADSSTR* is used to set the sampling period for the analog input as a number of states (clock
cycles).
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
SMP7
SMP6
SMP5
SMP4
SMP3
SMP2
SMP1
SMP0
0
0
0
0
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
SMP7
0
R/W
•
6
SMP6
0
R/W
5
SMP5
0
R/W
4
SMP4
0
R/W
If ICKSEL = 0, set these bits to H'0F.
3
SMP3
1
R/W
If ICKSEL = 1, set these bits to H'19.
2
SMP2
1
R/W
1
SMP1
1
R/W
0
SMP0
1
R/W
Note:
*
When EXCKS = 0
Set these bits to H'0F.
•
When EXCKS = 1
The full-spec emulator (E6000H) should not be used, but the on-chip emulator (E10AUSB) is usable.
Rev. 2.00 Oct. 21, 2009 Page 1078 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.3.9
A/D Sampling State Register_1 (ADSSTR_1*) for Unit 1
ADSSTR* is used to set the sampling period for the analog input as a number of states (clock
cycles).
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
SMP7
SMP6
SMP5
SMP4
SMP3
SMP2
SMP1
SMP0
0
0
0
0
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
7
SMP7
0
R/W
•
6
SMP6
0
R/W
5
SMP5
0
R/W
4
SMP4
0
R/W
If ICKSEL = 0, set these bits to H'0F.
3
SMP3
1
R/W
If ICKSEL = 1, set these bits to H'19.
2
SMP2
1
R/W
1
SMP1
1
R/W
0
SMP0
1
R/W
Note:
*
When EXCKS = 0
Set these bits to H'0F.
•
When EXCKS = 1
Access to the full-spec emulator (E6000H) is prohibited but the on-chip emulator (E10AUSB) is usable.
Rev. 2.00 Oct. 21, 2009 Page 1079 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.4
Operation
The A/D converter has two operating modes: single mode and scan mode. First select the clock for
A/D conversion (ADCLK). When changing the operating mode or analog input channel, to
prevent incorrect operation, first clear the ADST bit in ADCSR to 0. The ADST bit can be set to 1
at the same time as the operating mode or analog input channel is changed.
22.4.1
Single Mode
In single mode, A/D conversion is to be performed only once on the analog input of the specified
single channel.
1. A/D conversion for the selected channel is started when the ADST bit in ADCSR is set to 1 by
software, TPU*1, TMR*2, or an external trigger input.
2. When A/D conversion is completed, the A/D conversion result is transferred to the
corresponding A/D data register of the channel.
3. When A/D conversion is completed, 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 at 1 during A/D conversion, and is automatically cleared to 0 when
A/D conversion ends. The A/D converter enters wait state. If the ADST bit is cleared to 0
during A/D conversion, A/D conversion stops and the A/D converter enters a wait state.
Notes: 1. Only possible in unit 0.
2. As conversion start trigger, units 0 and 1 of TMR, and units 2 and 3 of TMR are
available in unit 0, and unit 1, respectively.
Rev. 2.00 Oct. 21, 2009 Page 1080 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Set*
ADIE
Set*
ADST
Set*
A/D conversion start
Clear*
Clear*
ADF
Channel 0 (AN0)
operation state
Channel 1 (AN1)
operation state
Waiting for conversion
Waiting for
conversion
A/D conversion 1
Channel 2 (AN2)
operation state
Waiting for conversion
Channel 3 (AN3)
operation state
Waiting for conversion
Waiting for conversion
A/D conversion 2
Waiting for conversion
ADDRA
Reading A/D conversion result
A/D conversion result 1
ADDRB
Reading A/D conversion result
A/D conversion result 2
ADDRC
ADDRD
Note: * ↓ indicates the timing of instruction execution by software.
Figure 22.3 Example of A/D Converter Operation (Single Mode, Channel 1 Selected)
22.4.2
Scan Mode
In scan mode, A/D conversion is to be performed sequentially on the analog inputs of the specified
channels up to four or eight*1 channels. Two types of scan mode are provided, that is, continuous
scan mode where A/D conversion is repeatedly performed and one-cycle scan mode*3 where A/D
conversion is performed for the specified channels for one cycle.
Rev. 2.00 Oct. 21, 2009 Page 1081 of 1454
REJ09B0498-0200
Section 22 A/D Converter
(1)
Continuous Scan Mode
1. When the ADST bit in ADCSR is set to 1 by software, TPU*1, TMR*2, or an external trigger
input, A/D conversion starts on the first channel in the specified channel group. Consecutive
A/D conversion*1 on a maximum of four channels (SCANE and SCANS = B'10) or on a
maximum of eight channels (SCANE and SCANS = B'11) can be selected. When consecutive
A/D conversion is performed on four channels, A/D conversion starts on AN0 when CH3 and
CH2 of unit 0 = B'00, on AN4 when CH3 and CH2 of units 0 and 1 = B'01. When consecutive
A/D conversion*1 is performed on eight channels, A/D conversion starts on AN0 when CH3 =
B'0.
2. When A/D conversion for each channel is completed, the A/D conversion result is sequentially
transferred to the corresponding ADDR of each channel.
3. When A/D conversion of all selected channels is completed, 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. A/D conversion of
the first channel in the group starts again.
4. The ADST bit is not cleared automatically, and 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 wait state. If the ADST bit is later set to 1, A/D conversion starts again from
the first channel in the group.
Notes: 1. Only possible in unit 0.
2. As conversion start trigger, units 0 and 1 of TMR, and units 2 and 3 of TMR are
available in unit 0, and unit 1, respectively.
3. Unit 0: The full-spec emulator (E6000H) should not be used, but the on-chip emulator
(E10A-USB) is usable.
Rev. 2.00 Oct. 21, 2009 Page 1082 of 1454
REJ09B0498-0200
Section 22 A/D Converter
A/D conversion consecutive execution
Clear*1
Set*1
ADST
Clear*1
ADF
Channel 0 (AN0)
operation state
Waiting for
conversion
A/D
conversion 1
Channel 1 (AN1)
operation state
Waiting for conversion
Channel 2 (AN2)
operation state
Waiting for conversion
Channel 3 (AN3)
operation state
Waiting for conversion
A/D conversion time
Waiting for conversion
A/D
conversion 2
A/D
conversion 4
Waiting for conversion
A/D
conversion 3
Waiting for conversion
A/D
conversion 5
Waiting for
conversion
*2
Waiting for conversion
Transfer
ADDRA
A/D conversion result 1
ADDRB
A/D conversion result 4
A/D conversion result 2
ADDRC
A/D conversion result 3
ADDRD
Notes: 1. ↓ indicates the timing of instruction execution by software.
2. Data being converted is ignored.
Figure 22.4 Example of A/D Conversion
(Continuous Scan Mode, Three Channels (AN0 to AN2) Selected)
(2)
One-Cycle Scan Mode*
1. Set the ADSTCLR bit in ADCR to 1.
2. When the ADST bit in ADCSR is set to 1 by software, TPU, TMR (units 2 and 3), or an
external trigger input, A/D conversion starts on the first channel in the specified channel group.
Consecutive A/D conversion on a maximum of four channels (SCANE and SCANS = B'10)
can be selected. For unit 1, A/D conversion starts on AN4 when CH3 and CH2 = B'01.
3. When A/D conversion for each channel is completed, the A/D conversion result is sequentially
transferred to the corresponding ADDR of each channel.
4. When A/D conversion of all selected channels is completed, 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.
5. The ADST bit is automatically cleared when A/D conversion is completed for all of the
channels that have been selected. A/D conversion stops and the A/D converter enters a wait
state.
Rev. 2.00 Oct. 21, 2009 Page 1083 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Note: * For unit 0, the full-spec emulator (E6000H) should not be used, but the on-chip
emulator (E10A-USB) is usable.
A/D conversion one-cycle execution
Set *
ADST
Clear*
ADF
A/D conversion time
Channel 4 (AN4) Waiting for conversion
operation state
Channel 5 (AN5)
operation state
Waiting for conversion
Channel 6 (AN6)
operation state
Waiting for conversion
A/D conversion 1
Waiting for conversion
A/D conversion 2
Waiting for conversion
Waiting for conversion
A/D conversion 3
Channel 7 (AN7)
operation state
Waiting for conversion
Transfer
ADDRE
A/D conversion result 1
ADDRF
A/D conversion result 2
ADDRG
A/D conversion result 3
ADDRH
Note: ↓ indicates the timing of instruction execution by software.
Figure 22.5 Example of A/D Conversion
(One-Cycle Scan Mode, Three Channels (AN4 to AN6) Selected)
Rev. 2.00 Oct. 21, 2009 Page 1084 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.4.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) passes after the ADST bit in ADCSR is set to
1, then starts A/D conversion. Figure 22.6 shows the periods of A/D conversion. Tables 22.3 to
22.5 show the timing of A/D conversion.
As shown in figure 22.6, the A/D conversion time (tCONV) includes the A/D conversion start delay
time (tD) and the input sampling time (tSPL). The length of tD varies depending on the timing of the
write access to ADCSR. Total conversion times therefore vary within the ranges indicated in
tables 22.3 to 22.5.
In scan mode, the values given in tables 22.3 to 22.5 apply to the first conversion time. The values
given in table 22.6 apply to the second and subsequent rounds of conversion. In either case, the
CKS1 and CKS0 bits in ADCR, the ICKSEL*1 bit in ADMOSEL, and the EXCKS*2 bit in
ADCSR should be set so that the conversion time is within the ranges indicated by the A/D
conversion characteristics.
Notes: 1. Unit 0: The full-spec emulator (E6000H) should not be used, but the on-chip emulator
(E10A-USB) is usable.
Unit 1: Access to the full-spec emulator (E6000H) is prohibited but the on-chip
emulator (E10A-USB) is usable.
2. Unit 0: The full-spec emulator (E6000H) should not be used, but the on-chip emulator
(E10A-USB) is usable.
Rev. 2.00 Oct. 21, 2009 Page 1085 of 1454
REJ09B0498-0200
Section 22 A/D Converter
(1)
Pφ
Address
(2)
Write signal
Input sampling
timing
ADF
tD
tSPL
tCONV
[Legend]
(1):
ADCSR write cycle
(2):
ADCSR address
tD:
A/D conversion start delay time
tSPL: Input sampling time
tCONV: A/D conversion time
Figure 22.6 Periods of A/D Conversion
Table 22.3 Characteristics of A/D Conversion (Unit 0: when EXCKS* = 0, ICKSEL = 0,
and ADSSTR* = H'0F) (1)
CKS1 = 0
CKS0 = 0
CKS1 = 1
CKS0 = 1
CKS0 = 0
CKS0 = 1
Item
Symbol
Typ.
Max.
Typ.
Max.
A/D conversion start
tD
3
⎯
14
3
⎯
10
3
⎯
8
3
⎯
7
Input sampling time
tSPL
⎯
312
⎯
⎯
156
⎯
⎯
78
⎯
⎯
39
⎯
A/D conversion time
tCONV
517
⎯
528
261
⎯
268
133
⎯
138
69
⎯
73
Min.
Min.
Min.
Typ.
Max.
Min.
Typ.
Max.
delay time
Notes: Values in the table are numbers of states.
* The full-spec emulator (E6000H) should not be used, but the on-chip emulator (E10AUSB) is usable.
Rev. 2.00 Oct. 21, 2009 Page 1086 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Table 22.3 Characteristics of A/D Conversion (Unit 0: when EXCKS* = 1, ICKSEL = 0,
and ADSSTR* = H'0F) (2)
CKS1 = 0
CKS0 = 0
Item
Symbol
A/D conversion start
tD
Input sampling time
A/D conversion time
Min.
CKS1 = 1
CKS0 = 1
Typ.
Max.
3
⎯
14
tSPL
⎯
120
tCONV
325
⎯
Min.
CKS0 = 0
Min.
Typ.
CKS0 = 1
Typ.
Max.
Max.
Min.
Typ.
Max.
3
⎯
10
3
⎯
8
3
⎯
7
⎯
⎯
60
⎯
⎯
30
⎯
⎯
15
⎯
336
165
⎯
172
85
⎯
90
45
⎯
49
delay time
Notes: Values in the table are numbers of states.
* The full-spec emulator (E6000H) should not be used, but the on-chip emulator (E10AUSB) is usable.
Table 22.4 Characteristics of A/D Conversion (Unit 1: when EXCKS = 0, ICKSEL = 0, and
ADSSTR* = H'0F) (1)
CKS1 = 0
CKS0 = 0
Item
Symbol
A/D conversion start
tD
Input sampling time
A/D conversion time
Min.
CKS1 = 1
CKS0 = 1
Typ.
Max.
4
⎯
14
tSPL
⎯
312
tCONV
518
⎯
Min.
CKS0 = 0
Min.
Typ.
CKS0 = 1
Typ.
Max.
Max.
Min.
Typ.
Max.
4
⎯
10
4
⎯
8
4
⎯
7
⎯
⎯
156
⎯
⎯
78
⎯
⎯
39
⎯
528
262
⎯
268
134
⎯
138
70
⎯
73
delay time
Notes: Values in the table are numbers of states.
* Access to the full-spec emulator (E6000H) is prohibited but the on-chip emulator (E10AUSB) is usable.
Rev. 2.00 Oct. 21, 2009 Page 1087 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Table 22.4 Characteristics of A/D Conversion (Unit 1: when EXCKS = 1, ICKSEL = 0, and
ADSSTR* = H'0F) (2)
CKS1 = 0
CKS0 = 0
Item
Symbol
A/D conversion start
tD
Input sampling time
A/D conversion time
Min.
CKS1 = 1
CKS0 = 1
Typ.
Max.
4
⎯
14
tSPL
⎯
120
tCONV
326
⎯
Min.
CKS0 = 0
Min.
Typ.
CKS0 = 1
Typ.
Max.
Max.
Min.
Typ.
Max.
4
⎯
10
4
⎯
8
4
⎯
7
⎯
⎯
60
⎯
⎯
30
⎯
⎯
15
⎯
336
166
⎯
172
86
⎯
90
46
⎯
49
delay time
Notes: Values in the table are numbers of states.
* Access to the full-spec emulator (E6000H) is prohibited but the on-chip emulator (E10AUSB) is usable.
Table 22.5 Characteristics of A/D Conversion (When EXCKS*1 = 1, ICKSEL*1 = 0, and
ADSSTR*2 = H'19)
Iφ:Pφ = 1:1/2
Unit 0
Item
Symbol
A/D conversion start delay time
Unit 1
Min.
Typ.
Max.
Min.
Typ.
Max.
tD
2.5
⎯
6.5
3.5
⎯
6.5
Input sampling time
tSPL
⎯
12.5
⎯
⎯
12.5
⎯
A/D conversion time
tCONV
30
⎯
34
31
⎯
34
Notes: Values in the table are numbers of states (cycles of Pφ). Make the sampling setting 25
(ADSSRT = D'25).
1. Unit 0: The full-spec emulator (E6000H) should not be used, but the on-chip emulator
(E10A-USB) is usable.
2. Unit 0: The full-spec emulator (E6000H) should not be used, but the on-chip emulator
(E10A-USB) is usable.
Unit 1: Access to the full-spec emulator (E6000H) is prohibited but the on-chip emulator
(E10A-USB) is usable.
Rev. 2.00 Oct. 21, 2009 Page 1088 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Table 22.6 Period of A/D Conversion (Scan Mode) (Units 0 and 1)
EXCKS*3
ICKSEL
CKS1
CKS0
Conversion Time in States (Cycles of Pφ)
0
0
0
0
512 (fixed)
1
256 (fixed)
0
128 (fixed)
1
64 (fixed)
1
1* *
⎯
⎯
Setting prohibited
0
0
0
320*1
1
160*1
0
80*1
1
40*
⎯
25*2
3
1
4
1
3
4
1* *
⎯
1
Notes: 1. Make the sampling setting15 (ADSSRT = D'15).
2. When Pφ = Iφ/2, make the sampling setting 25 (ADSSRT = D'25).
3. Unit 0: The full-spec emulator (E6000H) should not be used, but the on-chip emulator
(E10A-USB) is usable.
4. Unit 1: Access to the full-spec emulator (E6000H) is prohibited but the on-chip emulator
(E10A-USB) is usable.
Rev. 2.00 Oct. 21, 2009 Page 1089 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.4.4
Timing of External Trigger Input
A/D conversion can be externally triggered. For unit 0, an external trigger is input from the
ADTRG0 pin when the TRGS1, TRGS0, and EXTRGS bits are set to B'110 in ADCR_0. For unit
1, an external trigger is input from the ADTRG1 pin when the TRGS1, TRGS0, and EXTRGS bits
are set to B'110 in ADCR_1. A/D conversion starts when the ADST bit in ADCSR is set to 1 on
the falling edge of the ADTRG pin. Other operations, in both single and scan modes, are the same
as when the ADST bit has been set to 1 by software. Figure 22.7 shows the timing.
Also, A/D conversion for multiple units can be externally triggered (multiple units can start
simultaneously). For units 0 and 1, an external trigger is input from the ADTRG0 pin when the
TRGS1, TRGS0, and EXTRGS bits are set to B'111 in ADCR_0 and ADCR_1. A/D conversion
starts when the ADST bit in ADCSR is set to 1 on the falling edge of the ADTRG0 pin. The
timing is different from the one when multiple units do not start simultaneously. Figure 22.8
shows the timing.
Pφ
ADTRG
Internal trigger
signal
ADST
A/D conversion
Figure 22.7 External Trigger Input Timing (TRGS1, TRGS0, and EXTRGS ≠ B'111)
Rev. 2.00 Oct. 21, 2009 Page 1090 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Pφ
ADTRG0
Internal trigger
signal
ADST
A/D conversion
Figure 22.8 External Trigger Input Timing when Multiple Units Start Simultaneously
(TRSG1, TRGS0, and EXTRGS = B'111)
22.4.5
Setting the System Clock Mode
In system clock mode, set Iφ = 50 MHz, Pφ = Iφ/2, and make the sampling setting 25. A/D
conversion*1 with a conversion time of 1 µs per channel is possible. For information on controlling
the frequency of the system clock relative to the input clock, see section 27, Clock Pulse
Generator.
When the ADST bit is cleared to 0, start A/D conversion following the procedures shown below.
1. Set Pφ = Iφ/2.
2. Release the A/D converter from the module-stopped state.
3. Set the EXCKS*2 bit in ADCSR to 1 (making setting of the number of states for sampling in
ADSSTR*2*3 effective).
4. Set*2*3 the ICKSEL bit in ADMODSEL*2*3 to 1 (selecting system clock mode).
5. Write H'19 to ADSSTR*2*3 (setting the number of states for sampling to 25).
6. Start A/D conversion (set the ADST bit to 1 or have the trigger signal initiate conversion).
Notes: 1. The full-spec emulator (E6000H) should not be used, but the on-chip emulator (E10AUSB) is usable.
2. For unit 0, the full-spec emulator (E6000H) should not be used, but the on-chip
emulator (E10A-USB) is usable.
3. For unit 1, access to the full-spec emulator (E6000H) is prohibited, but the on-chip
emulator (E10A-USB) is usable.
Rev. 2.00 Oct. 21, 2009 Page 1091 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.5
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 when the ADF bit in ADCSR is set to 1 after A/D conversion is
completed enables ADI interrupt requests. The data transfer controller (DTC)* and DMA
controller (DMAC) can be activated by an ADI interrupt. Having the converted data read by the
DTC* or DMAC in response to an ADI interrupt enables continuous conversion to be achieved
without imposing a load on software.
Note: * Only possible in unit 0.
Table 22.7 A/D Converter Interrupt Source
Name
Interrupt Source
Interrupt Flag
DTC Activation
DMAC Activation
ADI
A/D conversion end
ADF
Possible*
Possible
Note:
*
Only possible in unit 0.
Rev. 2.00 Oct. 21, 2009 Page 1092 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.6
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 22.9).
• 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 22.10).
• 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 22.10).
• Nonlinearity error
The error with respect to the ideal A/D conversion characteristic between the zero voltage and
the full-scale voltage. Does not include the offset error, full-scale error, or quantization error
(see figure 22.10).
• Absolute accuracy
The deviation between the digital value and the analog input value. Includes the offset error,
full-scale error, quantization error, and nonlinearity error.
Rev. 2.00 Oct. 21, 2009 Page 1093 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Digital output
Ideal A/D conversion
characteristic
1111111111
1111111110
1111111101
1111111100
0000000011
0000000010
Quantization error
0000000001
0000000000
1
2
1024 1024
1022 1023
1024 1024
FS
Analog
input voltage
Figure 22.9 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 22.10 A/D Conversion Accuracy Definitions
Rev. 2.00 Oct. 21, 2009 Page 1094 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.7
Usage Notes
22.7.1
Module Stop Function 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 the module stop state. Set the CKS1 and CKS2 bits to 1 and clear the ADST, TRGS1,
TRGS0, and EXTRGS bits all to 0 to disable A/D conversion when entering module stop state
after operation of the A/D converter. After that, set the module stop control register after executing
a dummy read from ADCSR. For details, see section 28, Power-Down Modes.
22.7.2
A/D Input Hold Function in Software Standby Mode
When this LSI enters software standby mode with A/D conversion enabled, the analog inputs are
retained, and the analog power supply current is equal to as during A/D conversion. If the analog
power supply current needs to be reduced in software standby mode, set the CKS1 and CKS2 bits
to 1 and clear the ADST, TRGS1, TRGS0, and EXTRGS bits all to 0 to disable A/D conversion.
After that, enter software standby mode after executing a dummy read from ADCSR.
22.7.3
Notes on Stopping the A/D Converter
When the A/D start bit (ADST) is cleared during A/D conversion by software, A/D conversion
results may be stored incorrectly (ADDR), or when A/D conversion restarts, the interrupt flag may
be misset.
To avoid these events, follow the steps below.
(1)
In Single Mode or Scan Mode (One-Cycle Scan Mode)
As the ADST bit is automatically cleared when A/D conversion is completed, do not clear the bit
during A/D conversion.
(2)
In Scan Mode (Continuous Scan Mode)
• When the A/D Converter is Activated by Software
Do not clear the ADST bit during A/D conversion. To stop A/D conversion, rewrite the
SCANE bit to change modes from scan mode to single mode. By rewriting the SCANE bit, the
A/D converter is stopped without clearing the ADST bit by software.
Rev. 2.00 Oct. 21, 2009 Page 1095 of 1454
REJ09B0498-0200
Section 22 A/D Converter
However, after rewriting the SCANE bit, it may take up to 1.5-channel A/D conversion time to
stop A/D conversion and set the A/D end flag (ADF) to 1. Moreover, the ADDR value after
A/D conversion is completed should not be used.
For details of settings, see figure 22.11.
Start
Switch to single mode
(Unit 0: ADCR_0_SCANE = 0)
(Unit 1: ADCR_1_SCANE = 0)
ADST is automatically cleared
after A/D conversion is completed
No
ADF = 1?
Yes
End
Hardware processing
Figure 22.11 Stopping Continuous Scan Mode Activated by Software
• When the A/D Converter is Activated by an External Trigger
Do not clear the ADST bit during A/D conversion. To stop A/D conversion, disable external
triggers and then rewrite the SCANE bit to change modes from scan mode to single mode.
This stops A/D conversion without clearing the ADST bit by software.
However, after rewriting the SCANE bit, it may take up to 1.5-channel A/D conversion time to
stop A/D conversion and set the A/D end flag (ADF) to 1. Moreover, the ADDR value after
A/D conversion is completed should not be used.
For details of settings, see figure 22.12.
Rev. 2.00 Oct. 21, 2009 Page 1096 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Start
External trigger stopped?
Yes
No
Disable external trigger input
Unit 0 (ADCR_0_TRGS1, TRGS0, EXTRGS) = 001
Unit 1 (ADCR_1_TRGS1, TRGS0, EXTRGS) = 011
Switch to single mode
(Unit 0: ADCR_0_SCANE = 0)
(Unit 1: ADCR_1_SCANE = 0)
ADST is automatically cleared
after A/D conversion is completed
No
ADF = 1?
Yes
End
Hardware processing
Figure 22.12 Stopping Continuous Scan Mode Activated by External Trigger
22.7.4
Notes in System Clock Mode
1. For board design, see section 22.7.8, Notes on Board Design.
2. In system clock mode, operate all units with the system clock (Iφ). The system clock and the
peripheral module clock should not be used together.
Rev. 2.00 Oct. 21, 2009 Page 1097 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.7.5
Permissible Signal Source Impedance
This LSI's analog input is designed so that the conversion accuracy is guaranteed for an input
signal for which the signal source impedance is 5 kΩ or less when EXCKS*1 = 0 and ICKSEL = 0
or 1 kΩ or less when EXCKS*1 = 1 and ICKSEL = 0, or when ICKSEL = 1*1*2. 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 the permissible signal source
impedance, charging may be insufficient and it may not be possible to guarantee the A/D
conversion accuracy. However, if a large capacitance is provided externally for conversion in
single mode, the input load will essentially comprise only the internal input resistance of 10 kΩ,
and the signal source impedance is ignored. However, since 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 22.13). When converting a high-speed analog signal or
conversion in scan mode, a low-impedance buffer should be inserted.
Notes: 1. Unit 0: The full-spec emulator (E6000H) should not be used, but the on-chip emulator
(E10A-USB) is usable.
2. Unit 1: Access to the full-spec emulator (E6000H) is prohibited, but the on-chip
emulator (E10A-USB) is usable.
Sensor output impedance
EXCKS = 0, ICKSEL = 0 : R ≤ 5 kΩ
EXCKS = 1, ICKSEL = 0 : 1 kΩ or less
ICKSEL = 1 : 1 kΩ or less
This LSI
Equivalent circuit of the A/D converter
10 kΩ
Sensor input
Low-pass
filter
C ≤ 0.1 μF
Cin =
15 pF
Figure 22.13 Example of Analog Input Circuit
Rev. 2.00 Oct. 21, 2009 Page 1098 of 1454
REJ09B0498-0200
20 pF
Section 22 A/D Converter
22.7.6
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, acting as antennas.
22.7.7
Setting Range of Analog Power Supply and Other Pins
If the conditions shown below are not met, the reliability of the LSI 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 ≤ VAN ≤ Vref.
• Relation between AVCC, AVSS and VCC, VSS
As the relationship between AVCC, AVSS and VCC, VSS, set AVCC = Vcc ± 0.3 V and AVSS = VSS.
If the A/D converter is not used, set AVCC = VCC and AVSS = VSS.
• Vref setting range
The reference voltage at the Vref pin should be set in the range Vref ≤ AVCC.
22.7.8
Notes on Board Design
In board design, follow the notes below.
1. 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. Moreover,
digital circuitry must be isolated from the analog reference power supply pin (Vref), analog
power supply pin (AVCC), and analog ground pin (AVSS) by shielding the analog input pins
(AN0 to AN7) with the analog ground pin (AVSS).
2. Lines should be connected with the analog reference power supply pin (AVCC), analog power
supply pin (Vref), and analog ground pin (AVSS) with low impedance as possible.
3. The analog ground pin (AVSS) should be connected at one point to a stable ground (VSS) on the
board.
Rev. 2.00 Oct. 21, 2009 Page 1099 of 1454
REJ09B0498-0200
Section 22 A/D Converter
22.7.9
Notes on Noise Countermeasures
A protection circuit connected to prevent damage due to an abnormal voltage such as an excessive
surge at the analog input pins (AN0 to AN7) should be connected to AVCC and AVSS as shown in
figure 22.14. Also, the bypass capacitors connected to AVCC and Vref and the filter capacitor
connected to the AN0 to AN7 pins must be connected to AVSS. The bypass capacitors between
AVCC and AVSS, or Vref and AVSS should be placed as close to pins as possible.
If a filter capacitor is connected, the input currents at the AN0 to AN7 pins 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 the circuit constants.
AVCC
Vref
100 Ω
Rin* 2
*1
AN0 to AN7
*1
0.1 µF
AVSS
Notes:
Values are reference values.
1.
10 µF
0.01 µF
2. Rin: Input impedance
Figure 22.14 Example of Analog Input Protection Circuit
Rev. 2.00 Oct. 21, 2009 Page 1100 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Table 22.8 Analog Pin Specifications
Item
Max.
Unit
⎯
20
pF
EXCKS = 0, ICKSEL = 0
⎯
5
kΩ
EXCKS = 1, ICKSEL = 0
⎯
1
ICKSEL = 1
⎯
1
Analog input capacitance
Permissible signal source impedance
Min.
10 kW
AN0 to AN7
To A/D converter
20 pF
Note: Values are reference values.
Figure 22.15 Analog Input Pin Equivalent Circuit
Rev. 2.00 Oct. 21, 2009 Page 1101 of 1454
REJ09B0498-0200
Section 22 A/D Converter
Rev. 2.00 Oct. 21, 2009 Page 1102 of 1454
REJ09B0498-0200
Section 23 D/A Converter
Section 23 D/A Converter
23.1
8-bit or 10-bit resolution
Two output channels
Maximum conversion time of 10 µs (with 20 pF load)
Output voltage of 0 V to Vref
D/A output hold function in software standby mode
Module stop state specifiable
Internal data
bus
Bus interface
AVcc
DADR0H
AVss
10-bit D/A
Vref
DADR0L
DADR1H
DA0
DADR1L
DA1
Module data bus
•
•
•
•
•
•
Features
DADR01T
Control circuit
[Legend]
DADR0H/L:
DADR1H/L:
DADR01T:
DACR01:
DACR01
D/A data register 0 H/L
D/A data register 1 H/L
D/A data register 01T
D/A control register 01
Figure 23.1 Block Diagram of the 10-Bit D/A Converter
Rev. 2.00 Oct. 21, 2009 Page 1103 of 1454
REJ09B0498-0200
Section 23 D/A Converter
23.2
Input/Output Pins
Table 23.1 shows the pin configuration of the D/A converter.
Table 23.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
Reference voltage pin
Vref
Input
D/A conversion reference voltage
Analog output pin 0
DA0
Output
Channel 0 analog output
Analog output pin 1
DA1
Output
Channel 1 analog output
23.3
Register Descriptions
The D/A converter has the following registers.
•
•
•
•
•
•
D/A data register 0H (DADR0H)
D/A data register 0L (DADR0L)
D/A data register 1H (DADR1H)
D/A data register 1L (DADR1L)
D/A data register 01T (DADR01T)
D/A control register 01 (DACR01)
Rev. 2.00 Oct. 21, 2009 Page 1104 of 1454
REJ09B0498-0200
Section 23 D/A Converter
23.3.1
D/A Data Registers 0 and 1 (DADR0, DADR1)
A D/A data register, DADR, is internally a 10-bit register that holds data to be D/A converted.
When analog output is enabled, the value held by DADR is converted and output on the analogoutput pins. In the memory map, each DADR is configured of two registers, DADRnH and
DADRnL (n = 0, 1).
The eight higher-order bits of the corresponding DADR are stored in DADR0H or DADR1H.
DADR0H and DADR1H are directly readable and writable registers.
The two lower-order bits of the DADR are stored in DADR0L or DADR1L. DADR0L and
DADR1L are non-readable registers. Writing is accomplished by transferring values from the
temporary register, DADR01T.
When the value in a DADR is to be updated, the new lower-order two bits of the value must
previously have been written to DADR01T. The corresponding DADR is actually updated at the
same time as a new value is written to DADR0H or DADR1H. The eight higher-order bits are
reflected as written in DADR0H or DADR1H, while the two lower-order bits are updated by
transfer from DADR01T to DADR0L or DADR1L.
23.3.2
D/A Data Registers 0H and 1H (DADR0H and DADR1H)
DADR0H and DADR1H are 8-bit readable/writable registers. When a value is written to
DADR0H or DADR1H, the corresponding bits of DADR01T are simultaneously transferred to
DADR0L or DADR1L.
Bit
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 1105 of 1454
REJ09B0498-0200
Section 23 D/A Converter
23.3.3
D/A Data Registers 0L and 1L (DADR0L and DADR1L)
Registers DADR0L and DADR1L are for storing the two lower-order bits of the ten-bit value for
D/A conversion held by the corresponding DADR. DADR0L and DADR1L are non-readable
registers. Writing is accomplished by transferring values from the temporary register, DADR01T.
When writing proceeds, the value must have been set beforehand in DADR01T.
Transfer from DADR01T to DADR0L proceeds when a value is written to DADR0H.
Transfer from DADR01T to DADR1L proceeds when a value is written to DADR1H.
7
Bit
6
Bit Name
5
4
3
2
1
0
⎯
⎯
⎯
⎯
⎯
⎯
Initial Value
0
0
⎯
⎯
⎯
⎯
⎯
⎯
R/W
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
23.3.4
D/A Data Register 01T (DADR01T)
DADR01T is an 8-bit temporary register that is used to transfer data to DADR0L and DADR1L.
Writing is only valid for bits 7 and 6. Values written to bits 5 to 0 are ignored. In reading, the most
recent setting (of bits 7 and 6) and the values for the two lower-order bits held in DADR0L and
DADR1L can be read. The value for the two lower-order bits of DADR1 can be read in bits 5 and
4. The value for the two lower-order bits of DADR0 can be read in bits 3 and 2.
Bits 1 and 0 are reserved. In reading, these bits are read as 1.
Bits 7 and 6 of DADR01T are used to store the two lower-order bits of a 10-bit value for D/A
conversion.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
DADT1
DADT0
DAD1L1
DAD1L0
DAD0L1
DAD0L0
⎯
⎯
0
0
0
0
0
0
1
1
R/W
R/W
R
R
R
R
R
R
Rev. 2.00 Oct. 21, 2009 Page 1106 of 1454
REJ09B0498-0200
Section 23 D/A Converter
23.3.5
D/A Control Register 01 (DACR01)
DACR01 controls the operation of the D/A converter.
7
6
5
4
3
2
1
0
DAOE1
DAOE0
DAE
⎯
⎯
⎯
⎯
⎯
0
0
0
1
1
1
1
1
R/W
R/W
R/W
R
R
R
R
R
Bit
Bit Name
Initial Value
R/W
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 of channel 1 (DA1) is disabled
1: D/A conversion of channel 1 is enabled. Analog output
of channel 1 (DA1) is enabled.
6
DAOE0
0
R/W
D/A Output Enable 0
Controls D/A conversion and analog output.
0: Analog output of channel 0 (DA0) is disabled
1: D/A conversion of channel 0 is enabled. Analog output
of channel 0 (DA0) is enabled.
5
DAE
0
R/W
D/A Enable
Used together with the DAOE0 and DAOE1 bits to control
D/A conversion. When this bit is cleared to 0, D/A
conversion is controlled independently for channels 0 and
1. When this bit is set to 1, D/A conversion for channels 0
and 1 is controlled together.
Output of conversion results is always controlled by the
DAOE0 and DAOE1 bits. For details, see table 23.2,
Control of D/A Conversion.
4 to 0
⎯
All 1
R
Reserved
These are read-only bits and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 1107 of 1454
REJ09B0498-0200
Section 23 D/A Converter
Table 23.2 Control of D/A Conversion
Bit 5
DAE
Bit 7
DAOE1
Bit 6
DAOE0
Description
0
0
0
D/A conversion is disabled.
1
D/A conversion of channel 0 is enabled and D/A conversion
of channel 1 is disabled.
Analog output of channel 0 (DA0) is enabled and analog
output of channel 1 (DA1) is disabled.
1
0
D/A conversion of channel 0 is disabled and D/A conversion
of channel 1 is enabled.
Analog output of channel 0 (DA0) is disabled and analog
output of channel 1 (DA1) is enabled.
1
D/A conversion of channels 0 and 1 is enabled.
Analog output of channels 0 and 1 (DA0 and DA1) is
enabled.
1
0
0
D/A conversion of channels 0 and 1 is enabled.
Analog output of channels 0 and 1 (DA0 and DA1) is
disabled.
1
D/A conversion of channels 0 and 1 is enabled.
Analog output of channel 0 (DA0) is enabled and analog
output of channel 1 (DA1) is disabled.
1
0
D/A conversion of channels 0 and 1 is enabled.
Analog output of channel 0 (DA0) is disabled and analog
output of channel 1 (DA1) is enabled.
1
D/A conversion of channels 0 and 1 is enabled.
Analog output of channels 0 and 1 (DA0 and DA1) is
enabled.
23.3.6
Usage as an 8-Bit D/A Converter
In advance of usage as an 8-bit D/A converter, fix the lower-order two bits to 0 by clearing the
DADT1 and DADT0 bits in DADR01T to 0. By clearing these bits in DADR01T to 0 in advance,
the D/A converter is made to function by simply setting DADR0H or DADR1H. That is, D/A
conversion of the eight higher-order bits proceeds when the two lower-order bits remain fixed to
0.
Rev. 2.00 Oct. 21, 2009 Page 1108 of 1454
REJ09B0498-0200
Section 23 D/A Converter
23.4
Operation
The D/A converter includes D/A conversion circuits for two channels, each of which can operate
independently. When the DAOE bit in DACR01 is set to 1, D/A conversion is enabled and the
conversion result is output.
An operation example of D/A conversion on channel 0 is shown below. Figure 23.2 shows the
timing of this operation.
1. Write the conversion data to DADR0.
2. Set the DAOE0 bit in DACR01 to 1 to start D/A conversion. The conversion result is output
from the analog output pin DA0 after the conversion time tDCONV has elapsed. The conversion
result continues to be output until DADR0 is written to again or the DAOE0 bit is cleared to 0.
Output values are expressed by the following formulae.
• Formula for 8-bit conversion
Contents of DADR
x Vref
256
• Formula for 10-bit conversion
Contents of DADR
x Vref
1024
3. If DADR0 is written to again, the conversion is immediately started. The conversion result is
output after the conversion time tDCONV has elapsed.
4. If the DAOE0 bit is cleared to 0, analog output is disabled.
Rev. 2.00 Oct. 21, 2009 Page 1109 of 1454
REJ09B0498-0200
Section 23 D/A Converter
DADR0
write cycle
DACR01
write cycle
DADR0
write cycle
DACR01
write cycle
Pφ
Address
Conversion data 1
DADR0
Conversion data 2
DAOE0
DA0
High-impedance state
[Legend]
tDCONV: D/A conversion time
Conversion
result 2
Conversion
result 1
tDCONV
tDCONV
Figure 23.2 Example of D/A Converter Operation
Rev. 2.00 Oct. 21, 2009 Page 1110 of 1454
REJ09B0498-0200
Section 23 D/A Converter
23.5
Usage Notes
23.5.1
Module Stop State Setting
Operation of the D/A converter can be disabled or enabled using the module stop control register.
The initial setting is for operation of the D/A converter to be halted. Register access is enabled by
clearing the module stop state. For details, refer to section 28, Power-Down Modes.
23.5.2
D/A Output Hold Function in Software Standby Mode
When this LSI makes a transition to software standby mode with D/A conversion enabled, the
D/A outputs are retained, and the flow of current from the analog power supply remains the same
as during D/A conversion. If the analog power-supply current has to be reduced in software
standby mode, clear the DAOE0, DAOE1, and DAE bits to 0 to disable D/A conversion.
23.5.3
Notes on Deep Software Standby Mode
When this LSI makes a transition to deep software standby mode with D/A conversion enabled,
the D/A outputs enter high-impedance state.
23.5.4
Limitations on Emulators
The limitations described below apply to emulation of the 10-bit D/A converter.
In emulation with the full-spec emulator (E6000H), the resolution of the analog output becomes
eight bits, and the precision of D/A conversion is not guaranteed. Furthermore, when DADR01T is
read, the values in emulation differ from those for the actual product. Thus, as a precondition for
emulation with the full-spec emulator (E6000H), do not read DADR01T.
No particular limitations apply to emulation with the on-chip emulator (E10A-USB).
The above notes are summarized in table 23.3 below.
Rev. 2.00 Oct. 21, 2009 Page 1111 of 1454
REJ09B0498-0200
Section 23 D/A Converter
Table 23.3 Limitations on Emulators
Detail of Operation
Operation of the Actual
Subject to the Limitation Product
Operation with Operation with the
the E10A-USB E6000H
Writing to DADR01T
Setting of the two lowerAs at left
order bits of a 10-bit value
for D/A conversion
Even if writing is
executed, the value
written will be ignored.
Reading DADR01T
Ability to read the two
As at left
lower-order bits of a 10-bit
value for D/A conversion
Reading is not possible.
Values read out are not
defined.
Analog output: resolution
10 bits
As at left
8 bits (two lower-order
bits are ignored)
Analog output: precision
D/A precision is
guaranteed
As at left
D/A precision is not
guaranteed
Rev. 2.00 Oct. 21, 2009 Page 1112 of 1454
REJ09B0498-0200
Section 24 RAM
Section 24 RAM
This LSI has a high-speed static RAM. The RAM is connected to the CPU by a 32-bit data bus,
enabling one-state access by the CPU to all byte data, word data, and longword data.
The RAM can be enabled or disabled by means of the RAME bit in the system control register
(SYSCR). For details on SYSCR, refer to section 3.2.2, System Control Register (SYSCR).
The RAM size is 40 Kbytes in the H8SX/1665, H8SX/1665M, H8SX/1662, and H8SX/1662M.
Product Classification
Flash memory version
H8SX/1662
RAM Size
RAM Addresses
40 Kbytes
H'FF2000 to H'FFBFFF
H8SX/1665
H8SX/1662M
H8SX/1665M
Rev. 2.00 Oct. 21, 2009 Page 1113 of 1454
REJ09B0498-0200
Section 24 RAM
Rev. 2.00 Oct. 21, 2009 Page 1114 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Section 25 Flash Memory
The flash memory has the following features. Figure 25.1 is a block diagram of the flash memory.
25.1
Features
• ROM size
Product Classification
H8SX/1662
R5F61662
ROM Size
ROM Address
384 Kbytes
H'000000 to H'05FFFF
(modes 1, 2, 3, 6, and 7)
512 Kbytes
H'000000 to H'07FFFF
(modes 1, 2, 3, 6, and 7)
R5F61662M
H8SX/1665
R5F61665
R5F61665M
• Two memory MATs
The start addresses of two memory spaces (memory MATs) are allocated to the same address.
The mode setting in the initiation determines which memory MAT is initiated first. The
memory MATs can be switched by using the bank-switching method after initiation.
⎯ User MAT initiated at a reset in user mode: 384 Kbytes/512 Kbytes
⎯ User boot MAT is initiated at reset in user boot mode: 16 Kbytes
• Programming/erasing interface by the download of on-chip program
This LSI has a programming/erasing program. After downloading this program to the on-chip
RAM, programming/erasure can be performed by setting the parameters.
• Programming/erasing time
Programming time: 1 ms (typ.) for 128-byte simultaneous programming
Erasing time: 600 ms (typ.) per 1 block (64 Kbytes)
• Number of programming
The number of programming can be up to 100 times at the minimum. (1 to 100 times are
guaranteed.)
• Three on-board programming modes
SCI Boot mode: Using the on-chip SCI_4, the user MAT and user boot MAT can be
programmed/erased. In SCI boot mode, the bit rate between the host and this LSI can be
adjusted automatically.
USB boot mode: Using the on-chip USB, the user MAT can be programmed/erased.
User program mode: Using a desired interface, the user MAT can be programmed/erased.
User boot mode: Using a desired interface, the user boot program can be made and the user
MAT can be programmed/erased.
Rev. 2.00 Oct. 21, 2009 Page 1115 of 1454
REJ09B0498-0200
Section 25 Flash Memory
• Off-board programming mode
Programmer mode: Using a PROM programmer, the user MAT and user boot MAT can be
programmed/erased.
• Programming/erasing protection
Protection against programming/erasure of the flash memory can be set by hardware
protection, software protection, or error protection.
• Flash memory emulation function using the on-chip RAM
Realtime emulation of the flash memory programming can be performed by overlaying parts
of the flash memory (user MAT) area and the on-chip RAM.
Internal address bus
Internal data bus (32 bits)
FCCS
FPCS
Memory MAT unit
Module bus
FECS
FKEY
User MAT: 384 Kbytes
(H8SX/1662)
512 Kbytes
(H8SX/1665)
Control unit
FMATS
User boot MAT: 16 Kbytes
FTDAR
RAMER
Flash memory
Mode pins
[Legend]
FCCS:
FPCS:
FECS:
FKEY:
FMATS:
FTDAR:
RAMER:
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
Figure 25.1 Block Diagram of Flash Memory
Rev. 2.00 Oct. 21, 2009 Page 1116 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.2
Mode Transition Diagram
When the mode pins are set in the reset state and reset start is performed, this LSI enters each
operating mode as shown in figure 25.2. Although the flash memory can be read in user mode, it
cannot be programmed or erased. The flash memory can be programmed or erased in boot mode,
user program mode, user boot mode, and programmer mode. The differences between boot mode,
user program mode, user boot mode, and programmer mode are shown in table 25.1.
RES = 0
RES = 0
Programmer
ROM disabled mode
Reset state
ROM disabled mode
setting
se
U
RES
rm
RE
Ib
oo
S
tm
=0
od
SC
g
=0
ttin
e
es
S
RE
=0
ot g
bo tin
er set
Us de
mo
S
RE
Programmer mode setting
od
es
=0
ett
ing
US
mode
RE
Bb
oot
S=
mo
de
0
set
ting
*2
User mode
*1
User program
mode
User boot
mode
SCI boot mode
USB boot mode
RAM emulation can be
available
On-board programming mode
Notes: * In this LSI, the user program mode is defined as the period from the timing when a program
concerning programming and erasure is started in user mode to the timing when the program is
completed.
1. Programming and erasure is started.
2. Programing and erasure is completed.
Figure 25.2 Mode Transition of Flash Memory
Rev. 2.00 Oct. 21, 2009 Page 1117 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Table 25.1 Differences between Boot Mode, User Program Mode, User Boot Mode, and
Programmer Mode
Item
Programming/
erasing
environment
SCI Boot
Mode
Boot Mode
User Program User Boot
Mode
Mode
Programmer
Mode
On-board
programming
On-board
programming
On-board
programming
On-board
programming
Off-board
programming
•
•
•
•
User MAT
•
User boot
MAT
Programming/ •
erasing enable
MAT
User MAT
User MAT
User MAT
User MAT
Programming/ Command
erasing control
Command
Programming/
erasing
interface
Programming/
erasing
interface
Command
All erasure
O (Automatic)
O
O
O (Automatic)
O
O
×
O (Automatic)
1
1
Block division
erasure
O*
O*
Program data
transfer
From host via
SCI
From host via
USB
From desired From desired Via
device via RAM device via RAM programmer
RAM emulation ×
×
O
O
×
Reset initiation Embedded
MAT
program
storage area
Embedded
program
storage area
User MAT
User boot
MAT*2
⎯
Transition to
user mode
Changing
Changing
Completing
mode and reset mode and reset Programming/
3
erasure*
Changing
⎯
mode and reset
Notes: 1. All-erasure is performed. After that, the specified block can be erased.
2. First, the reset vector is fetched from the embedded program storage area. After the
flash memory related registers are checked, the reset vector is fetched from the user
boot MAT.
3. In this LSI, the user programming mode is defined as the period from the timing when a
program concerning programming and erasure is started to the timing when the
program is completed. For details on a program concerning programming and erasure,
see section 25.8.3, User Program Mode.
Rev. 2.00 Oct. 21, 2009 Page 1118 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.3
Memory MAT Configuration
The memory MATs of flash memory in this LSI consists of the 384-Kbyte/512-Kbyte user MAT
and 16-Kbyte user boot MAT. The start addresses of the user MAT and user boot MAT are
allocated to the same address. Therefore, when the program execution or data access is performed
between the two memory MATs, the memory MATs must be switched by the flash MAT select
register (FMATS).
The user MAT or user boot MAT can be read in all modes. However, the user boot MAT can be
programmed or erased only in boot mode and programmer mode.
The size of the user MAT is different from that of the user boot MAT. Addresses which exceed
the size of the 16-Kbyte user boot MAT should not be accessed. If an attempt is made, data is read
as an undefined value.
User MAT
User boot MAT
H'000000
H'000000
16 Kbytes
H'003FFF
512 Kbytes*1
H'07FFFF*2
Notes: 1. 384 Kbytes in the H8SX/1662.
2. H'05FFFF in the H8SX/1662.
Figure 25.3 Memory MAT Configuration (H8SX/1665)
Rev. 2.00 Oct. 21, 2009 Page 1119 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.4
Block Structure
25.4.1
Block Diagram of H8SX/1662
Figure 25.4 (1) shows the block structure of the 384-Kbyte user MAT. The heavy-line frames
indicate the erase blocks. The thin-line frames indicate the programming units and the values
inside the frames stand for the addresses. The user MAT is divided into five 64-Kbyte blocks, one
32-Kbyte block, and eight 4-Kbyte blocks. The user MAT can be erased in these divided block
units. Programming is done in 128-byte units starting from where the lower address is H'00 or
H'80. RAM emulation can be performed in the eight 4-Kbyte blocks.
EB0
Erase unit: 4 Kbytes
EB1
Erase unit: 4 Kbytes
EB2
Erase unit: 4 Kbytes
EB3
Erase unit: 4 Kbytes
EB4
Erase unit: 4 Kbytes
EB5
Erase unit: 4 Kbytes
EB6
Erase unit: 4 Kbytes
EB7
Erase unit: 4 Kbytes
EB8
Erase unit: 32 Kbytes
EB9
Erase unit: 64 Kbytes
EB10
EB13
Erase unit: 64 Kbytes
H'000000 H'000001 H'000002
←Programming unit: 128 bytes→
H'00007F
H'000F80 H'000F81 H'000F82
H'001000 H'001001 H'001002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'000FFF
H'00107F
H'001F80 H'001F81 H'001F82
H'002000 H'002001 H'002002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'001FFF
H'00207F
H'002F80 H'002F81 H'002F82
H'003000 H'003001 H'003002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'002FFF
H'00307F
H'003F80 H'003F81 H'003F82
H'004000 H'004001 H'004002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'003FFF
H'004F80 H'004F81 H'004F82
H'005000 H'005001 H'005002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'004FFF
H'00507F
H'005F80 H'005F81 H'005F82
H'006000 H'006001 H'006002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'005FFF
H'006F80 H'006F81 H'006F82
H'007000 H'007001 H'007002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'006FFF
H'00707F
H'007F80 H'007F81 H'007F82
H'008000 H'008001 H'008002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'007FFF
H'00807F
H'00FF80 H'00FF81 H'00FF82
H'010000 H'010001 H'010002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'00FFFF
H'01007F
H'01FF80 H'01FF81 H'01FF82
H'020000 H'020001 H'020002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'01FFFF
H'02007F
– – – – – – – – – – –
H'04FF80 H'04FF81 H'04FF82
H'050000 H'050001 H'050002 ←Programming unit: 128 bytes→
H'05007F
H'05FF80 H'05FF81 H'05FF82
– – – – – – – – – – –
Figure 25.4 (1) User MAT Block Structure of H8SX/1662
Rev. 2.00 Oct. 21, 2009 Page 1120 of 1454
REJ09B0498-0200
H'00407F
H'00607F
H'05FFFF
Section 25 Flash Memory
25.4.2
Block Diagram of H8SX/1665
Figure 25.4 (2) shows the block structure of the 512-Kbyte user MAT. The heavy-line frames
indicate the erase blocks. The thin-line frames indicate the programming units and the values
inside the frames stand for the addresses. The user MAT is divided into seven 64-Kbyte blocks,
one 32-Kbyte block, and eight 4-Kbyte blocks. The user MAT can be erased in these divided
block units. Programming is done in 128-byte units starting from where the lower address is H'00
or H'80. RAM emulation can be performed in the eight 4-Kbyte blocks.
EB0
Erase unit: 4 Kbytes
EB1
Erase unit: 4 Kbytes
EB2
Erase unit: 4 Kbytes
EB3
Erase unit: 4 Kbytes
EB4
Erase unit: 4 Kbytes
EB5
Erase unit: 4 Kbytes
EB6
Erase unit: 4 Kbytes
EB7
Erase unit: 4 Kbytes
EB8
Erase unit: 32 Kbytes
EB9
Erase unit: 64 Kbytes
EB10
EB15
Erase unit: 64 Kbytes
H'000000 H'000001 H'000002
←Programming unit: 128 bytes→
H'00007F
H'000F80 H'000F81 H'000F82
H'001000 H'001001 H'001002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'000FFF
H'00107F
H'001F80 H'001F81 H'001F82
H'002000 H'002001 H'002002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'001FFF
H'00207F
H'002F80 H'002F81 H'002F82
H'003000 H'003001 H'003002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'002FFF
H'00307F
H'003F80 H'003F81 H'003F82
H'004000 H'004001 H'004002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'003FFF
H'004F80 H'004F81 H'004F82
H'005000 H'005001 H'005002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'004FFF
H'00507F
H'005F80 H'005F81 H'005F82
H'006000 H'006001 H'006002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'005FFF
H'006F80 H'006F81 H'006F82
H'007000 H'007001 H'007002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'006FFF
H'00707F
H'007F80 H'007F81 H'007F82
H'008000 H'008001 H'008002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'007FFF
H'00807F
H'00FF80 H'00FF81 H'00FF82
H'010000 H'010001 H'010002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'00FFFF
H'01007F
H'01FF80 H'01FF81 H'01FF82
H'020000 H'020001 H'020002
– – – – – – – – – – –
←Programming unit: 128 bytes→
H'01FFFF
H'02007F
– – – – – – – – – – –
H'06FF80 H'06FF81 H'06FF82
H'070000 H'070001 H'070002 ←Programming unit: 128 bytes→
H'07007F
H'07FF80 H'07FF81 H'07FF82
– – – – – – – – – – –
H'00407F
H'00607F
H'07FFFF
Figure 25.4 (2) User MAT Block Structure of H8SX/1665
Rev. 2.00 Oct. 21, 2009 Page 1121 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.5
Programming/Erasing Interface
Programming/erasure of the flash memory is done by downloading an on-chip programming/
erasing program to the on-chip RAM and specifying the start address of the programming
destination, the program data, and the erase block number using the programming/erasing
interface registers and programming/erasing interface parameters.
The procedure program for user program mode and user boot mode is made by the user. Figure
25.5 shows the procedure for creating the procedure program. For details, see section 25.8.3, User
Program Mode.
Start procedure program for
programming/erasing
Select on-chip program
to be downloaded and
specify destination
Download on-chip program
by setting VBR, FKEY, and
SCO bit in FCCS
Execute initialization
(downloaded program execution)
Programming (in 128-byte units)
or erasing (in 1-block units)
(downloaded program execution)
Programming/erasing
completed?
No
Yes
End procedure program
Figure 25.5 Procedure for Creating 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 the programming/erasing interface registers. The
start address of the on-chip RAM where an on-chip program is downloaded is specified by the
flash transfer destination address register (FTDAR).
Rev. 2.00 Oct. 21, 2009 Page 1122 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(2)
Download of On-Chip Program
The on-chip program is automatically downloaded by setting the flash key code register (FKEY)
and the SCO bit in the flash code control/status register (FCCS) after initializing the vector base
register (VBR). The memory MAT is replaced with the embedded program storage area during
download. Since the memory MAT cannot be read during programming/erasing, the procedure
program must be executed in a space other than the flash memory (for example, on-chip RAM).
Since the download result is returned to the programming/erasing interface parameter, whether
download is normally executed or not can be confirmed. The VBR contents can be changed after
completion of download.
(3)
Initialization of Programming/Erasure
A pulse with the specified period 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.
Accordingly, the operating frequency of the CPU needs to be set before programming/erasure. The
operating frequency of the CPU is set by the programming/erasing interface parameter.
(4)
Execution of Programming/Erasure
The start address of the programming destination and the program data are specified in 128-byte
units when programming. The block to be erased is specified with the erase block number in
erase-block units when erasing. Specifications of the start address of the programming destination,
program data, and erase block number are performed by the programming/erasing interface
parameters, and the on-chip program is initiated. The on-chip program is executed by using the
JSR or BSR instruction and executing 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. All
interrupts are disabled during programming/erasure.
(5)
When Programming/Erasure is Executed Consecutively
When processing does not end by 128-byte programming or 1-block erasure, consecutive
programming/erasure can be realized by updating the start address of the programming destination
and program data, or the erase block number. Since the downloaded on-chip program is left in the
on-chip RAM even after programming/erasure completes, download and initialization are not
required when the same processing is executed consecutively.
Rev. 2.00 Oct. 21, 2009 Page 1123 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.6
Input/Output Pins
The flash memory is controlled through the input/output pins shown in table 25.2.
Table 25.2 Pin Configuration
Abbreviation
I/O
Function
RES
Input
Reset
EMLE
Input
On-chip emulator enable pin
(EMLE = 0 for flash memory programming/erasure)
MD3 to MD0
Input
Set operating mode of this LSI
PM2
Input
SCI boot mode/USB boot mode setting (for boot mode
setting by MD3 to MD0)
TxD4
Output
Serial transmit data output (used in SCI boot mode)
RxD4
Input
Serial receive data input (used in SCI boot mode)
USD+, USD−
I/O
USB data I/O (used in USB boot mode)
VBUS
Input
USB cable connection/disconnection detect (used in
USB boot mode)
PM3
Input
USB bus power mode/self power mode setting (used
in USB boot mode)
PM4
Output
D+ pull-up control (used in USB boot mode)
Rev. 2.00 Oct. 21, 2009 Page 1124 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.7
Register Descriptions
The flash memory has the following registers.
Programming/Erasing Interface Registers:
•
•
•
•
•
•
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)
Programming/Erasing Interface Parameters:
•
•
•
•
•
•
Download pass and fail result parameter (DPFR)
Flash pass and fail result parameter (FPFR)
Flash program/erase frequency parameter (FPEFEQ)
Flash multipurpose address area parameter (FMPAR)
Flash multipurpose data destination area parameter (FMPDR)
Flash erase block select parameter (FEBS)
• RAM emulation register (RAMER)
There are several operating modes for accessing the flash memory. Respective operating modes,
registers, and parameters are assigned to the user MAT and user boot MAT. The correspondence
between operating modes and registers/parameters for use is shown in table 25.3.
Rev. 2.00 Oct. 21, 2009 Page 1125 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Table 25.3 Registers/Parameters and Target Modes
Download
Initialization
Programming
Erasure
Read
RAM
Emulation
FCCS
O
⎯
⎯
⎯
⎯
⎯
FPCS
O
⎯
⎯
⎯
⎯
⎯
FECS
O
⎯
⎯
⎯
⎯
⎯
FKEY
O
⎯
O
FMATS
⎯
⎯
O*
FTDAR
O
⎯
⎯
DPFR
O
⎯
FPFR
⎯
O
FPEFEQ ⎯
O
FMPAR
⎯
FMPDR
Register/Parameter
Programming/
erasing interface
registers
Programming/
erasing interface
parameters
RAM emulation
⎯
O
1
1
⎯
2
⎯
O*
O*
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
O
⎯
⎯
⎯
⎯
⎯
⎯
⎯
O
⎯
⎯
⎯
⎯
⎯
O
⎯
⎯
⎯
FEBS
⎯
⎯
⎯
O
⎯
⎯
RAMER
⎯
⎯
⎯
⎯
⎯
O
Notes: 1. The setting is required when programming or erasing the user MAT in user boot mode.
2. The setting may be required according to the combination of initiation mode and read
target memory MAT.
Rev. 2.00 Oct. 21, 2009 Page 1126 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.7.1
Programming/Erasing Interface Registers
The programming/erasing interface registers are 8-bit registers that can be accessed only in bytes.
These registers are initialized by a reset.
(1)
Flash Code Control/Status Register (FCCS)
FCCS monitors errors during programming/erasing the flash memory and requests the on-chip
program to be downloaded to the on-chip RAM.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
FLER
⎯
⎯
⎯
SCO
Initial Value
1
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
(R)/W*
Note:
*
This is a write-only bit. This bit is always read as 0.
Bit
Initial
Bit Name Value
R/W
Description
7
⎯
1
R
Reserved
6
⎯
0
R
These are read-only bits and cannot be modified.
5
⎯
0
R
Rev. 2.00 Oct. 21, 2009 Page 1127 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Bit
Initial
Bit Name Value
R/W
Description
4
FLER
R
Flash Memory Error
0
Indicates that an error has occurred during programming
or erasing the flash memory. When this bit is set to 1,
the flash memory enters the error protection state.
When this bit is set to 1, high voltage is applied to the
internal flash memory. To reduce the damage to the
flash memory, the reset must be released after the reset
input period (period of RES = 0) of at least 100 μs.
0: Flash memory operates normally (Error protection is
invalid)
[Clearing condition]
•
At a reset
1: An error occurs during programming/erasing flash
memory (Error protection is valid)
[Setting conditions]
3 to 1
⎯
All 0
R
•
When an interrupt, such as NMI, occurs during
programming/erasure.
•
When the flash memory is read during
programming/erasure (including a vector read and
an instruction fetch).
•
When the SLEEP instruction is executed during
programming/erasure (including software standby
mode).
•
When a bus master other than the CPU, such as the
DMAC and DTC, obtains bus mastership during
programming/erasure.
Reserved
These are read-only bits and cannot be modified.
Rev. 2.00 Oct. 21, 2009 Page 1128 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Bit
Initial
Bit Name Value
R/W
Description
0
SCO
(R)/W*
Source Program Copy Operation
0
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 or
FECS is automatically downloaded in the on-chip RAM
area specified by FTDAR.
In order to set this bit to 1, the RAM emulation mode
must be canceled, H'A5 must be written to FKEY, and
this operation must be executed in the on-chip RAM.
Dummy read of FCCS must be executed twice
immediately after setting this bit to 1. All interrupts must
be disabled during download. This bit is cleared to 0
when download is completed.
During program download initiated with this bit,
particular processing which accompanies bankswitching of the program storage area is executed.
Before a download request, initialize the VBR contents
to H'00000000. After download is completed, the VBR
contents can be changed.
0: Download of the programming/erasing program is not
requested.
[Clearing condition]
•
When download is completed
1: Download of the programming/erasing program is
requested.
[Setting conditions] (When all of the following conditions
are satisfied)
Note:
*
•
Not in RAM emulation mode (the RAMS bit in
RAMER is cleared to 0)
•
H'A5 is written to FKEY
•
Setting of this bit is executed in the on-chip RAM
This is a write-only bit. This bit is always read as 0.
Rev. 2.00 Oct. 21, 2009 Page 1129 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(2)
Flash Program Code Select Register (FPCS)
FPCS selects the programming program to be downloaded.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PPVS
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R/W
Bit
Initial
Bit Name Value
R/W
Description
7 to 1
⎯
All 0
R
Reserved
These are read-only bits and cannot be modified.
0
PPVS
0
R/W
Program Pulse Verify
Selects the programming program to be downloaded.
0: Programming program is not selected.
[Clearing condition]
When transfer is completed
1: Programming program is selected.
(3)
Flash Erase Code Select Register (FECS)
FECS selects the erasing program to be downloaded.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
EPVB
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R
R
R
R/W
Bit
Initial
Bit Name Value
R/W
Description
7 to 1
⎯
All 0
R
0
EPVB
0
R/W
Reserved
These are read-only bits and cannot be modified.
Erase Pulse Verify Block
Selects the erasing program to be downloaded.
0: Erasing program is not selected.
[Clearing condition]
When transfer is completed
1: Erasing program is selected.
Rev. 2.00 Oct. 21, 2009 Page 1130 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(4)
Flash Key Code Register (FKEY)
FKEY is a register for software protection that enables to download the on-chip program and
perform programming/erasure of the flash memory.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
K7
K6
K5
K4
K3
K2
K1
K0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Initial
Bit Name 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
3
K3
0
R/W
When H'A5 is written to FKEY, writing to the SCO bit in
FCCS is enabled. When a value other than H'A5 is
written, the SCO bit cannot be set to 1. Therefore, the
on-chip program cannot be downloaded to the on-chip
RAM.
2
K2
0
R/W
1
K1
0
R/W
0
K0
0
R/W
Only when H'5A is written can programming/erasure of
the flash memory be executed. When a value other than
H'5A is written, even if the programming/erasing
program is executed, programming/erasure cannot be
performed.
H'A5: Writing to the SCO bit is enabled. (The SCO bit
cannot be set to 1 when FKEY is a value other
than H'A5.)
H'5A: Programming/erasure of the flash memory is
enabled. (When FKEY is a value other than H'A5,
the software protection state is entered.)
H'00: Initial value
Rev. 2.00 Oct. 21, 2009 Page 1131 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(5)
Flash MAT Select Register (FMATS)
FMATS selects the user MAT or user boot MAT. Writing to FMATS should be done when a
program in the on-chip RAM is being executed.
7
6
5
4
3
2
1
0
Bit Name
MS7
MS6
MS5
MS4
MS3
MS2
MS1
MS0
Initial Value
0/1*
0
0/1*
0
0/1*
0
0/1*
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Note: * This bit is set to 1 in user boot mode, otherwise cleared to 0.
Bit
Initial
Bit Name Value
R/W
Description
7
MS7
0/1*
R/W
MAT Select
6
MS6
0
R/W
5
MS5
0/1*
R/W
The memory MATs can be switched by writing a value
to FMATS.
4
MS4
0
R/W
3
MS3
0/1*
R/W
2
MS2
0
R/W
1
MS1
0/1*
R/W
0
MS0
0
R/W
When H'AA is written to FMATS, the user boot MAT is
selected. When a value other than H'AA is written, the
user MAT is selected. Switch the MATs following the
memory MAT switching procedure in section 25.11,
Switching between User MAT and User Boot MAT. The
user boot MAT cannot be selected by FMATS in user
programming mode. The user boot MAT can be
selected in boot mode or programmer mode.
H'AA: The user boot MAT is selected. (The user MAT is
selected when FMATS is a value other than
H'AA.)
(Initial value when initiated in user boot mode.)
H'00: The user MAT is selected.
(Initial value when initiated in a mode except for
user boot mode.)
Note:
*
This bit is set to 1 in user boot mode, otherwise cleared to 0.
Rev. 2.00 Oct. 21, 2009 Page 1132 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(6)
Flash Transfer Destination Address Register (FTDAR)
FTDAR specifies the start address of the on-chip RAM at which to download an on-chip program.
FTDAR must be set before setting the SCO bit in FCCS to 1.
Bit
Bit Name
Initial Value
R/W
7
6
5
4
3
2
1
0
TDER
TDA6
TDA5
TDA4
TDA3
TDA2
TDA1
TDA0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Initial
Bit Name Value
R/W
Description
7
TDER
R/W
Transfer Destination Address Setting Error
0
This bit is set to 1 when an error has occurred in setting
the start address specified by bits TDA6 to TDA0.
A start address error is determined by whether the value
set in bits TDA6 to TDA0 is within the range of H'00 to
H'02 when download is executed by setting the SCO bit
in FCCS to 1. Make sure that this bit is cleared to 0
before setting the SCO bit to 1 and the value specified
by bits TDA6 to TDA0 should be within the range of
H'00 to H'02.
0: The value specified by bits TDA6 to TDA0 is within
the range.
1: The value specified by bits TDA6 to TDA0 is between
H'03 and H'FF and download has 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 on-chip RAM start address of the
download destination. A value between H'00 and H'02,
and up to 4 Kbytes can be specified as the start address
of the on-chip RAM.
2
TDA2
0
R/W
H'00: H'FF9000 is specified as the start address.
1
TDA1
0
R/W
H'01: H'FFA000 is specified as the start address.
0
TDA0
0
R/W
H'02: H'FFB000 is specified as the start address.
H'03 to H'7F: Setting prohibited.
(Specifying a value from H'03 to H'7F sets
the TDER bit to 1 and stops download of
the on-chip program.)
Rev. 2.00 Oct. 21, 2009 Page 1133 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.7.2
Programming/Erasing Interface Parameters
The programming/erasing interface parameters specify the operating frequency, storage place for
program data, start address of programming destination, and erase block number, and exchanges
the execution result. These parameters use the general registers of the CPU (ER0 and ER1) or the
on-chip RAM area. The initial values of programming/erasing interface parameters are undefined
at a reset or a transition to software standby mode.
Since registers of the CPU except for ER0 and ER1 are saved in the stack area during download of
an on-chip program, initialization, programming, or erasing, allocate the stack area before
performing these operations (the maximum stack size is 128 bytes). The return value of the
processing result is written in R0. The programming/erasing interface parameters are used in
download control, initialization before programming or erasing, programming, and erasing. Table
25.4 shows the usable parameters and target modes. The meaning of the bits in the flash pass and
fail result parameter (FPFR) varies in initialization, programming, and erasure.
Table 25.4 Parameters and Target Modes
Parameter
Download
Initialization
Programming
Erasure
R/W
Initial
Value
Allocation
DPFR
O
⎯
⎯
⎯
R/W
Undefined
On-chip RAM*
FPFR
O
O
O
O
R/W
Undefined
R0L of CPU
FPEFEQ
⎯
O
⎯
⎯
R/W
Undefined
ER0 of CPU
FMPAR
⎯
⎯
O
⎯
R/W
Undefined
ER1 of CPU
FMPDR
⎯
⎯
O
⎯
R/W
Undefined
ER0 of CPU
FEBS
⎯
⎯
⎯
O
R/W
Undefined
ER0 of CPU
Note:
(a)
*
A single byte of the start address of the on-chip RAM specified by FTDAR
Download Control
The on-chip program is automatically downloaded by setting the SCO bit in FCCS to 1. The onchip RAM area to download the on-chip program is the 4-Kbyte area starting from the start
address specified by FTDAR. Download is set by the programming/erasing interface registers, and
the download pass and fail result parameter (DPFR) indicates the return value.
Rev. 2.00 Oct. 21, 2009 Page 1134 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(b)
Initialization before Programming/Erasure
The on-chip program includes the initialization program. A pulse with the specified period 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. Accordingly, the operating frequency of the
CPU must be set. The initial program is set as a parameter of the programming/erasing program
which has been downloaded to perform these settings.
(c)
Programming
When the flash memory is programmed, the start address of the programming destination on the
user MAT and the program data must be passed to the programming program.
The start address of the programming destination on the user MAT must be stored in general
register ER1. This parameter is called the flash multipurpose address area parameter (FMPAR).
The program data is always in 128-byte units. When the program data does not satisfy 128 bytes,
128-byte program data is prepared by filling the dummy code (H'FF). The boundary of the start
address of the programming destination on the user MAT is aligned at an address where the lower
eight bits (A7 to A0) are H'00 or H'80.
The program data for the user MAT must be prepared in consecutive areas. The program data
must be in a consecutive space which can be accessed using the MOV.B instruction of the CPU
and is not in the flash memory space.
The start address of the area that stores the data to be written in the user MAT must be set in
general register ER0. This parameter is called the flash multipurpose data destination area
parameter (FMPDR).
For details on the programming procedure, see section 25.8.3, User Program Mode.
(d)
Erasure
When the flash memory is erased, the erase block number on the user MAT must be passed to the
erasing program which is downloaded.
The erase block number on the user MAT must be set in general register ER0. This parameter is
called the flash erase block select parameter (FEBS).
One block is selected from the block numbers of 0 to 19 as the erase block number.
For details on the erasing procedure, see section 25.8.3, User Program Mode.
Rev. 2.00 Oct. 21, 2009 Page 1135 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(2)
Download Pass and Fail Result Parameter (DPFR: Single Byte of Start Address in OnChip RAM Specified by FTDAR)
DPFR indicates the return value of the download result. The DPFR value is used to determine the
download result.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
SS
FK
SF
Bit
Initial
Bit Name Value
R/W
Description
7 to 3
⎯
⎯
Unused
⎯
These bits return 0.
2
SS
⎯
R/W
Source Select Error Detect
Only one type can be specified for the on-chip program
which can be downloaded. When the program to be
downloaded is not selected, more than two types of
programs are selected, or a program which is not
mapped is selected, an error occurs.
0: Download program selection is normal
1: Download program selection is abnormal
1
FK
⎯
R/W
Flash Key Register Error Detect
Checks the FKEY value (H'A5) and returns the result.
0: FKEY setting is normal (H'A5)
1: FKEY setting is abnormal (value other than H'A5)
0
SF
⎯
R/W
Success/Fail
Returns the download result. Reads back the program
downloaded to the on-chip RAM and determines
whether it has been transferred to the on-chip RAM.
0: Download of the program has ended normally (no
error)
1: Download of the program has ended abnormally
(error occurs)
Rev. 2.00 Oct. 21, 2009 Page 1136 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(3)
Flash Pass and Fail Parameter (FPFR: General Register R0L of CPU)
FPFR indicates the return values of the initialization, programming, and erasure results. The
meaning of the bits in FPFR varies depending on the processing.
(a)
Initialization before Programming/Erasure
FPFR indicates the return value of the initialization result.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
FQ
SF
Bit
Initial
Bit Name Value
R/W
Description
7 to 2
⎯
⎯
Unused
⎯
These bits return 0.
1
FQ
⎯
R/W
Frequency Error Detect
Compares the specified CPU operating frequency with
the operating frequencies supported by this LSI, and
returns the result.
0: Setting of operating frequency is normal
1: Setting of operating frequency is abnormal
0
SF
⎯
R/W
Success/Fail
Returns the initialization result.
0: Initialization has ended normally (no error)
1: Initialization has ended abnormally (error occurs)
Rev. 2.00 Oct. 21, 2009 Page 1137 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(b)
Programming
FPFR indicates the return value of the programming result.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
MD
EE
FK
⎯
WD
WA
SF
Bit
Initial
Bit Name Value
R/W
Description
7
⎯
⎯
Unused
⎯
Returns 0.
6
MD
⎯
R/W
Programming Mode Related Setting Error Detect
Detects the error protection state and returns the result.
When the error protection state is entered, this bit is set
to 1. Whether the error protection state is entered or not
can be confirmed with the FLER bit in FCCS. For
conditions to enter the error protection state see section
25.9.3, Error Protection.
0: Normal operation (FLER = 0)
1: Error protection state, and programming cannot be
performed (FLER = 1)
5
EE
⎯
R/W
Programming Execution Error Detect
Writes 1 to this bit when the specified data could not be
written because the user MAT was not erased. If this bit
is set to 1, there is a high possibility that the user MAT
has been written to partially. In this case, after removing
the error factor, erase the user MAT. 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 have not been written to.
Programming 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)
Rev. 2.00 Oct. 21, 2009 Page 1138 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Bit
Initial
Bit Name Value
4
FK
⎯
R/W
Description
R/W
Flash Key Register Error Detect
Checks the FKEY value (H'5A) before programming
starts, and returns the result.
0: FKEY setting is normal (H'5A)
1: FKEY setting is abnormal (value other than H'5A)
3
⎯
⎯
⎯
Unused
Returns 0.
2
WD
⎯
R/W
Write Data Address Detect
When an address not in the flash memory area is
specified as the start address of the storage destination
for the program data, an error occurs.
0: Setting of the start address of the storage destination
for the program data is normal
1: Setting of the start address of the storage destination
for the program data is abnormal
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.
•
An area other than flash memory
•
The specified address is not aligned with the 128byte boundary (lower eight bits of the address are
other than H'00 and H'80)
0: Setting of the start address of the programming
destination is normal
1: Setting of the start address of the programming
destination is abnormal
0
SF
⎯
R/W
Success/Fail
Returns the programming result.
0: Programming has ended normally (no error)
1: Programming has ended abnormally (error occurs)
Rev. 2.00 Oct. 21, 2009 Page 1139 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(c)
Erasure
FPFR indicates the return value of the erasure result.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
MD
EE
FK
EB
⎯
⎯
SF
Bit
Initial
Bit Name Value
R/W
Description
7
⎯
⎯
Unused
⎯
Returns 0.
6
MD
⎯
R/W
Erasure Mode Related Setting Error Detect
Detects the error protection state and returns the result.
When the error protection state is entered, this bit is set
to 1. Whether the error protection state is entered or not
can be confirmed with the FLER bit in FCCS. For
conditions to enter the error protection state, see section
25.9.3, Error Protection.
0: Normal operation (FLER = 0)
1: Error protection state, and programming cannot be
performed (FLER = 1)
5
EE
⎯
R/W
Erasure Execution Error Detect
Returns 1 when the user MAT could not be erased or
when the flash memory related register settings are
partially changed. If this bit is set to 1, there is a high
possibility that the user MAT has been erased partially.
In this case, after removing the error factor, erase the
user MAT. 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 have not been erased. Erasing of the user
boot MAT should be performed in boot mode or
programmer mode.
0: Erasure has ended normally
1: Erasure has ended abnormally
Rev. 2.00 Oct. 21, 2009 Page 1140 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Bit
Initial
Bit Name Value
4
FK
⎯
R/W
Description
R/W
Flash Key Register Error Detect
Checks the FKEY value (H'5A) before erasure starts,
and returns the result.
0: FKEY setting is normal (H'5A)
1: FKEY setting is abnormal (value other than H'5A)
3
⎯
EB
R/W
Erase Block Select Error Detect
Checks whether the specified erase block number is in
the block range of the user MAT, and returns the result.
0: Setting of erase block number is normal
1: Setting of erase block number is abnormal
2, 1
⎯
⎯
⎯
Unused
0
SF
⎯
R/W
Success/Fail
These bits return 0.
Indicates the erasure result.
0: Erasure has ended normally (no error)
1: Erasure has ended abnormally (error occurs)
(4)
Flash Program/Erase Frequency Parameter (FPEFEQ: General Register ER0 of CPU)
FPEFEQ sets the operating frequency of the CPU. The operating frequency available in this LSI
ranges from 8 MHz to 50 MHz.
Bit
31
30
29
28
27
26
25
24
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Bit
23
22
21
20
19
18
17
16
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Bit
15
14
13
12
11
10
9
8
F15
F14
F13
F12
F11
F10
F9
F8
Bit Name
Bit
Bit Name
7
6
5
4
3
2
1
0
F7
F6
F5
F4
F3
F2
F1
F0
Rev. 2.00 Oct. 21, 2009 Page 1141 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Bit
Initial
Bit Name Value
31 to 16 ⎯
⎯
R/W
Description
⎯
Unused
These bits should be cleared to 0.
15 to 0
F15 to F0 ⎯
R/W
Frequency Set
These bits set the operating frequency of the CPU.
When the PLL multiplication function is used, set the
multiplied frequency. The setting value must be
calculated as follows:
1. The operating frequency shown in MHz units must
be rounded in a number of three decimal places and
be shown in a number of two decimal places.
2. The value multiplied by 100 is converted to the
binary digit and is written to FPEFEQ (general
register ER0).
For example, when the operating frequency of the CPU
is 35.000 MHz, the value is as follows:
1. The number of three decimal places of 35.000 is
rounded.
2. The formula of 35.00 × 100 = 3500 is converted to
the binary digit and B'0000 1101 1010 1100
(H'0DAC) is set to ER0.
Rev. 2.00 Oct. 21, 2009 Page 1142 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(5)
Flash Multipurpose Address Area Parameter (FMPAR: General Register ER1 of CPU)
FMPAR stores the start address of the programming destination on the user MAT.
When an address in an area other than the flash memory is set, or the start address of the
programming destination is not aligned with the 128-byte boundary, an error occurs. The error
occurrence is indicated by the WA bit in FPFR.
Bit
Bit Name
Bit
Bit Name
Bit
Bit Name
Bit
Bit Name
Bit
31 to 0
31
30
29
28
27
26
25
24
MOA31
MOA30
MOA29
MOA28
MOA27
MOA26
MOA25
MOA24
23
22
21
20
19
18
17
16
MOA23
MOA22
MOA21
MOA20
MOA19
MOA18
MOA17
MOA16
15
14
13
12
11
10
9
8
MOA15
MOA14
MOA13
MOA12
MOA11
MOA10
MOA9
MOA8
7
6
5
4
3
2
1
0
MOA7
MOA6
MOA5
MOA4
MOA3
MOA2
MOA1
MOA0
Initial
Bit Name Value
MOA31 to ⎯
MOA0
R/W
Description
R/W
These bits store the start address of the programming
destination on the user MAT. Consecutive 128-byte
programming is executed starting from the specified
start address of the user MAT. Therefore, the specified
start address of the programming destination becomes a
128-byte boundary, and MOA6 to MOA0 are always
cleared to 0.
Rev. 2.00 Oct. 21, 2009 Page 1143 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(6)
Flash Multipurpose Data Destination Parameter (FMPDR: General Register ER0 of
CPU)
FMPDR stores the start address in the area that stores the data to be programmed in the user MAT.
When the storage destination for the program data is in flash memory, an error occurs. The error
occurrence is indicated by the WD bit in FPFR.
Bit
Bit Name
31
30
29
28
27
26
25
24
MOD31
MOD30
MOD29
MOD28
MOD27
MOD26
MOD25
MOD24
Bit
Bit Name
23
22
21
20
19
18
17
16
MOD23
MOD22
MOD21
MOD20
MOD19
MOD18
MOD17
MOD16
Bit
Bit Name
15
14
13
12
11
10
9
8
MOD15
MOD14
MOD13
MOD12
MOD11
MOD10
MOD9
MOD8
Bit
Bit Name
Bit
31 to 0
7
6
5
4
3
2
1
0
MOD7
MOD6
MOD5
MOD4
MOD3
MOD2
MOD1
MOD0
Initial
Bit Name Value
MOD31 to ⎯
MODA0
R/W
Description
R/W
These bits store the start address of the area which
stores the program data for the user MAT. Consecutive
128-byte data is programmed to the user MAT starting
from the specified start address.
Rev. 2.00 Oct. 21, 2009 Page 1144 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(7)
Flash Erase Block Select Parameter (FEBS: General Register ER0 of CPU)
• H8SX/1662
FEBS specifies the erase block number. Settable values range from 0 to 13 (H'0000 to
H'000D). A value of 0 corresponds to block EB0 and a value of 13 corresponds to block EB13.
An error occurs when a value over the range (from 0 to 13) is set.
• H8SX/1665
FEBS specifies the erase block number. Settable values range from 0 to 15 (H'0000 to
H'000F). A value of 0 corresponds to block EB0 and a value of 15 corresponds to block EB15.
An error occurs when a value over the range (from 0 to 15) is set.
Bit
31
30
29
28
27
26
25
24
Bit Name
Initial Value
R/W
Bit
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
23
22
21
20
19
18
17
16
Bit Name
Initial Value
R/W
Bit
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
9
8
Bit Name
Initial Value
R/W
Bit
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
Bit Name
Initial Value
R/W
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 1145 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.7.3
RAM Emulation Register (RAMER)
RAMER specifies the user MAT area overlaid with part of the on-chip RAM (H'FFA000 to
H'FFAFFF) when performing emulation of programming the user MAT. RAMER should be set in
user mode or user program mode. To ensure dependable emulation, the memory MAT to be
emulated must not be accessed immediately after changing the RAMER contents. When accessed
at such a timing, correct operation is not guaranteed.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
RAMS
RAM2
RAM1
RAM0
Initial Value
0
0
0
0
0
0
0
0
R/W
R
R
R
R
R/W
R/W
R/W
R/W
Bit
Initial
Bit Name Value
R/W
7 to 4
⎯
R
0
Description
Reserved
These are read-only bits and cannot be modified.
3
RAMS
0
R/W
RAM Select
Selects the function which emulates the flash memory
using the on-chip RAM.
0: Disables RAM emulation function
1: Enables RAM emulation function (all blocks of the
user MAT are protected against programming and
erasing)
2
RAM2
0
R/W
Flash Memory Area Select
1
RAM1
0
R/W
0
RAM0
0
R/W
These bits select the user MAT area overlaid with the
on-chip RAM when RAMS = 1. The following areas
correspond to the 4-Kbyte erase blocks.
000: H'000000 to H'000FFF (EB0)
001: H'001000 to H'001FFF (EB1)
010: H'002000 to H'002FFF (EB2)
011: H'003000 to H'003FFF (EB3)
100: H'004000 to H'004FFF (EB4)
101: H'005000 to H'005FFF (EB5)
110: H'006000 to H'006FFF (EB6)
111: H'007000 to H'007FFF (EB7)
Rev. 2.00 Oct. 21, 2009 Page 1146 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.8
On-Board Programming Mode
When the EMLE pin is set to low level, the mode pins (MD0, MD1, MD2, and MD3) are set to
on-board programming mode and the reset start is executed, a transition is made to on-board
programming mode in which the on-chip flash memory can be programmed/erased. On-board
programming mode has three operating modes: SCI boot mode by PM2 setting, user boot mode,
and user program mode, according to PM2 setting.
Table 25.5 shows the pin setting for each operating mode. For details on the state transition of
each operating mode for flash memory, see figure 25.2.
Table 25.5 On-Board Programming Mode Setting
Mode Setting
EMLE
MD3
MD2
MD1
MD0
PM2
User boot mode
0
0
0
0
1
⎯
SCI boot mode
0
0
0
1
0
0
USB boot mode
0
0
0
1
0
1
User program
mode
0
0
1
1
0
⎯
0
0
1
1
1
⎯
Rev. 2.00 Oct. 21, 2009 Page 1147 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.8.1
Boot Mode
SCI Boot mode executes programming/erasure of the user MAT or user boot MAT by means of
the control command and program data transmitted from the externally connected host via the onchip SCI_4.
In SCI boot mode, the tool for transmitting the control command and program data, and the
program data must be prepared in the host. The serial communications mode is set to
asynchronous mode. The system configuration in boot mode is shown in figure 25.6. Interrupts are
ignored in SCI boot mode. Configure the user system so that interrupts do not occur.
This LSI
Host
Programming
tool and program
data
PM2
MD3 to MD0
Software for
analyzing
control
commands
(on-chip)
Flash
memory
RxD4
SCI_4
TxD4
On-chip
RAM
Control command,
program data
Response
Figure 25.6 System Configuration in Boot Mode
Rev. 2.00 Oct. 21, 2009 Page 1148 of 1454
REJ09B0498-0200
0
0010
Section 25 Flash Memory
(1)
Serial Interface Setting by Host
The SCI_4 is set to asynchronous mode, and the serial transmit/receive format is set to 8-bit data,
one stop bit, and no parity.
When a transition to SCI boot mode is made, the boot program embedded in this LSI is initiated.
When the boot program is initiated, this LSI measures the low period of asynchronous serial
communication data (H'00) transmitted consecutively by the host, calculates the bit rate, and
adjusts the bit rate of the SCI_4 to match that of the host.
When bit rate adjustment is completed, this LSI transmits 1 byte of H'00 to the host as the bit
adjustment end sign. When the host receives this bit adjustment end sign normally, it transmits 1
byte of H'55 to this LSI. When reception is not executed normally, initiate boot mode again. The
bit rate may not be adjusted within the allowable range depending on the combination of the bit
rate of the host and the system clock frequency of this LSI. Therefore, the transfer bit rate of the
host and the system clock frequency of this LSI must be as shown in table 25.6.
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 25.7 Automatic-Bit-Rate Adjustment Operation
Table 25.6 System Clock Frequency for Automatic-Bit-Rate Adjustment
Bit Rate of Host
System Clock Frequency of This LSI
9,600 bps
8 to 18 MHz
19,200 bps
8 to 18 MHz
Rev. 2.00 Oct. 21, 2009 Page 1149 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(2)
State Transition Diagram
The state transition after SCI boot mode is initiated is shown in figure 25.8.
Boot mode initiation
(reset by boot mode)
(Bit rate adjustment)
H'00, ..., H'00 reception
H'00 transmission
(adjustment completed)
Bit rate adjustment
H'55
2.
Inquiry command reception
Wait for inquiry
setting command
Inquiry command response
3.
4.
Processing of
inquiry setting
command
All user MAT and
user boot MAT erasure
Read/check command
reception
Wait for
programming/erasing
command
(Programming
completion)
1.
tion
recep
Processing of
read/check command
Command response
(Erasure
completion)
(Erasure selection command reception)
(Erasure selection command
reception)
(Erase-block specification)
Wait for erase-block
data
(Program data transmission)
Wait for program data
Figure 25.8 SCI Boot Mode State Transition Diagram
Rev. 2.00 Oct. 21, 2009 Page 1150 of 1454
REJ09B0498-0200
Section 25 Flash Memory
1. After SCI boot mode is initiated, the bit rate of the SCI_4 is adjusted with that of the host.
2. Inquiry information about the size, configuration, start address, and support status of the user
MAT is transmitted to the host.
3. After inquiries have finished, all user MAT and user boot MAT are automatically erased.
4. When the program preparation notice is received, the state of waiting for program data is
entered. The start address of the programming destination and program data must be
transmitted after the programming command is transmitted. When programming is finished,
the start address of the programming destination must be set to H'FFFFFFFF and transmitted.
Then the state of waiting for program data is returned to the state of waiting for
programming/erasing command. When the erasure preparation notice is received, the state of
waiting for erase block data is entered. The erase block number must be transmitted after the
erasing command is transmitted. When the erasure is finished, the erase block number must be
set to H'FF and transmitted. Then the state of waiting for erase block data is returned to the
state of waiting for programming/erasing command. Erasure must be executed when the
specified block is programmed without a reset start after programming is executed in SCI boot
mode. When programming can be executed by only one operation, all blocks are erased before
entering the state of waiting for programming/erasing command or another command. Thus, in
this case, the erasing operation is not required. The commands other than the
programming/erasing command perform sum check, blank check (erasure check), and memory
read of the user MAT/user boot MAT and acquisition of current status information.
Memory read of the user MAT/user boot MAT can only read the data programmed after all user
MAT/user boot MAT has automatically been erased. No other data can be read.
Rev. 2.00 Oct. 21, 2009 Page 1151 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.8.2
USB Boot Mode
USB boot mode executes programming/erasing of the user MAT by means of the control
command and program data transmitted from the externally connected host via the USB.
In USB boot mode, the tool for transmitting the control command and program data, and the
program data must be prepared in the host. The system configuration in USB boot mode is shown
in figure 25.9. Interrupts are ignored in USB boot mode. Configure the user system so that
interrupts do not occur.
Host or
self-power HUB
This LSI
PM2
MD3 to MD0
PM4
Software for
analyzing
control
commands
(on-chip)
1
0010
Flash
memory
1.5 kΩ
Programming tool
and program data
Rs
USB+
Rs
USBUSB
Data transmission/
reception
On-chip
RAM
VBUS
PM3
Figure 25.9 System Configuration in USB Boot Mode
Rev. 2.00 Oct. 21, 2009 Page 1152 of 1454
REJ09B0498-0200
0: Self power setting
1: Bus power setting
Section 25 Flash Memory
(1)
Features
• Bus power mode and self power mode are selectable.
• The PM4 pin supports the D+ pull-up control connection.
• For enumeration information, refer to table 25.7.
Table 25.7 Enumeration Information
USB standard
Ver.2.0 (Full speed)
Transfer mode
Transfer mode Control (in, out), Bulk (in, out)
Maximum power consumption
For self power mode (PM3 = 0)
100 mA
For bus power mode (PM3 = 1)
500 mA
Endpoint configuration
EP0 Control (in out) 8 bytes
Configuration 1
InterfaceNumber0
AlternateSetting0
EP1 Bulk (out) 64 bytes
EP2 Bulk (in) 64 bytes
Rev. 2.00 Oct. 21, 2009 Page 1153 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(2)
State Transition Diagram
The state transition after USB boot mode is initiated is shown in figure 25.10.
Boot mode initiation
(reset by boot mode)
1.
Enumeration
H'55
n
eptio
rec
Inquiry command reception
2.
Wait for inquiry
setting command
Processing of inquiry
setting command
Inquiry command response
3.
4.
All user MAT erasure
Read/check command reception
Wait for inquiry
programming/erasing
command
Processing of
read/check command
Command response
(Er
com asure
sur
s
ma
e co
nd electio
mp
rec
letio
ept n
n)
ion
)
(Era
(Programming
completion)
(Program selection
command reception)
(Erase-block specification)
Wait for inquiry
programming/erasing
command
(Program data transmission)
Wait for inquiry
programming/erasing
command
Figure 25.10 USB Boot Mode State Transition Diagram
1. After a transition to the USB boot mode is made, the boot program embedded in this LSI is
initialized. This LSI performs enumeration to the host after the USB boot program is
initialized.
2. Inquiry information about the size, configuration, start address, and support status of the user
MAT is transmitted to the host.
3. After inquiries have finished, all user MAT are automatically erased.
Rev. 2.00 Oct. 21, 2009 Page 1154 of 1454
REJ09B0498-0200
Section 25 Flash Memory
4.
(3)
After all user MAT are automatically erased, the state of waiting for
programming/erasing command is entered. When the programming command is received,
the state shifts to the state of waiting for programming data. The same applies to erasing.
In addition to the commands for programming/erasing, there are commands for
performing sum check, blank check (erasure check), and memory read of the user MAT,
and acquiring the current status information.
Notes on USB Boot Mode Execution
• The clock of 48 MHz needs to be supplied to the USB module. Set the external clock
frequency and clock pulse generator so as to supply 48 MHz as the clock for the USB (cku).
For details, refer to section 27, Clock Pulse Generator.
• Use the PM4 pin for the D+ pull-up control connection.
• For the stable supply of the power during the flash memory programming and erasing, the
cable should not be connected via the bus powered HUB.
• If the bus powered HUB is disconnected during the flash memory programming and erasing,
permanent damage to the LSI may result.
• If the USB bus in the bus power mode enters the suspend mode, this does not make the
transition to the software standby mode in the power-down state.
Rev. 2.00 Oct. 21, 2009 Page 1155 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.8.3
User Program Mode
Programming/erasure of the user MAT is executed by downloading an on-chip program. The user
boot MAT cannot be programmed/erased in user program mode. The programming/erasing flow is
shown in figure 25.11.
Since high voltage is applied to the internal flash memory during programming/erasure, a
transition to the reset state or hardware standby mode must not be made during
programming/erasure. A transition to the reset state or hardware standby mode during
programming/erasure may damage the flash memory. If a reset is input, the reset must be released
after the reset input period (period of RES = 0) of at least 100 μs.
Programming/erasing
start
When programming,
program data is prepared
Programming/erasing
procedure program is
transferred to the on-chip
RAM and executed
1. Exit RAM emulation mode beforehand. Download is not allowed
in emulation mode.
2. When the program data is adjusted in emulation mode, select
the download destination specified by FTDAR carefully. Make
sure that the download area does not overlap the emulation
area.
3. Programming/erasing is executed only in the on-chip RAM.
4. After programming/erasing is finished, protect the flash memory
by the hardware protection.
Programming/erasing
end
Figure 25.11 Programming/Erasing Flow
Rev. 2.00 Oct. 21, 2009 Page 1156 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(1)
On-Chip RAM Address Map when Programming/Erasure is Executed
Parts of the procedure program that is made by the user, like download request,
programming/erasure procedure, and decision of the result, must be executed in the on-chip RAM.
Since the on-chip program to be downloaded is embedded in the on-chip RAM, make sure the onchip program and procedure program do not overlap. Figure 25.12 shows the area of the on-chip
program to be downloaded.
DPFR
(Return value: 1 byte)
FTDAR setting
System use area
(15 bytes)
Area to be
downloaded
(size: 4 kbytes)
Unusable area during
programming/erasing
Programming/erasing
program entry
FTDAR setting + 16 bytes
Initialization program
entry
FTDAR setting + 32 bytes
Initialization +
programming program
or
Initialization +
erasing program
RAM emulation area or
area that can be used
by user
Area that can be used
by user
FTDAR setting + 4 kbytes
H'FFBFFF
Figure 25.12 RAM Map when Programming/Erasure is Executed
Rev. 2.00 Oct. 21, 2009 Page 1157 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(2)
Programming Procedure in User Program Mode
Start programming
procedure program
1
Select on-chip program
to be downloaded and
specify download
destination by FTDAR
1.
Disable interrupts and bus
master operation
other than CPU
9.
Set FKEY to H'5A
10.
Set FKEY to H'A5
2.
Set SCO to 1 after initializing
VBR and execute download
3.
Set parameters to ER1
and ER0
(FMPAR and FMPDR)
11.
Clear FKEY to 0
4.
Programming
JSR FTDAR setting + 16
12.
5.
DPFR = 0?
Yes
No
Download error processing
Initialization
Set the FPEFEQ
parameter
6.
Initialization
JSR FTDAR setting + 32
FPFR = 0?
Yes
Programming
Download
The procedures for download of the on-chip program, initialization, and programming are shown
in figure 25.13.
FPFR = 0?
Yes
No
13.
No
Clear FKEY and
programming
error processing
Required data
programming is
completed?
Yes
8.
No
Clear FKEY to 0
Initialization error processing
1
End programming
procedure program
Figure 25.13 Programming Procedure in User Program Mode
Rev. 2.00 Oct. 21, 2009 Page 1158 of 1454
REJ09B0498-0200
14.
7.
15.
Section 25 Flash Memory
The procedure program must be executed in an area other than the flash memory to be
programmed. Setting the SCO bit in FCCS to 1 to request download must be executed in the onchip RAM. The area that can be executed in the steps of the procedure program (on-chip RAM,
user MAT, and external space) is shown in section 25.8.5, On-Chip Program and Storable Area for
Program Data. The following description assumes that the area to be programmed on the user
MAT is erased and that program data is prepared in the consecutive area.
The program data for one programming operation is always 128 bytes. When the program data
exceeds 128 bytes, the start address of the programming destination and program data parameters
are updated in 128-byte units and programming is repeated. When the program data is less than
128 bytes, invalid data is filled to prepare 128-byte program data. If the invalid data to be added is
H'FF, the program processing time can be shortened.
1. Select the on-chip program to be downloaded and the download destination. When the PPVS
bit in FPCS is set to 1, the programming program is selected. Several programming/erasing
programs cannot be selected at one time. If several programs are selected, a download error is
returned to the SS bit in the DPFR parameter. The on-chip RAM start address of the download
destination is specified by FTDAR.
2. Write H'A5 in FKEY. If H'A5 is not written to FKEY, the SCO bit in FCCS cannot be set to 1
to request download of the on-chip program.
3. After initializing VBR to H'00000000, set the SCO bit to 1 to execute download. To set the
SCO bit to 1, all of the following conditions must be satisfied.
⎯ RAM emulation mode has been canceled.
⎯ H'A5 is written to FKEY.
⎯ Setting the SCO bit is executed in the on-chip RAM.
When the SCO bit is set to 1, download is started automatically. Since the SCO bit is cleared
to 0 when the procedure program is resumed, the SCO bit cannot be confirmed to be 1 in the
procedure program. The download result can be confirmed by the return value of the DPFR
parameter. To prevent incorrect decision, before setting the SCO bit to 1, set one byte of the
on-chip RAM start address specified by FTDAR, which becomes the DPFR parameter, to a
value other than the return value (e.g. H'FF). Since particular processing that is accompanied
by bank switching as described below is performed when download is executed, initialize the
VBR contents to H'00000000. Dummy read of FCCS must be performed twice immediately
after the SCO bit is set to 1.
⎯ The user-MAT space is switched to the on-chip program storage area.
⎯ After the program to be downloaded and the on-chip RAM start address specified by
FTDAR are checked, they are transferred to the on-chip RAM.
⎯ FPCS, FECS, and the SCO bit in FCCS are cleared to 0.
Rev. 2.00 Oct. 21, 2009 Page 1159 of 1454
REJ09B0498-0200
Section 25 Flash Memory
⎯ The return value is set in the DPFR parameter.
⎯ After the on-chip program storage area is returned to the user-MAT space, the procedure
program is resumed. After that, VBR can be set again.
⎯ The values of general registers of the CPU are held.
⎯ During download, no interrupts can be accepted. However, since the interrupt requests are
held, when the procedure program is resumed, the interrupts are requested.
⎯ To hold a level-detection interrupt request, the interrupt must continue to be input until the
download is completed.
⎯ Allocate a stack area of 128 bytes at the maximum in the on-chip RAM before setting the
SCO bit to 1.
⎯ If access to the flash memory is requested by the DMAC or DTC during download, the
operation cannot be guaranteed. Make sure that an access request by the DMAC or DTC is
not generated.
4. FKEY is cleared to H'00 for protection.
5. The download result must be confirmed by the value of the DPFR parameter. Check the value
of the DPFR parameter (one byte of start address of the download destination specified by
FTDAR). If the value of the DPFR parameter is H'00, download has been performed normally.
If the value is not H'00, the source that caused download to fail can be investigated by the
description below.
⎯ If the value of the DPFR parameter is the same as that before downloading, the setting of
the start address of the download destination in FTDAR may be abnormal. In this case,
confirm the setting of the TDER bit in FTDAR.
⎯ If the value of the DPFR parameter is different from that before downloading, check the SS
bit or FK bit in the DPFR parameter to confirm the download program selection and FKEY
setting, respectively.
6. The operating frequency of the CPU is set in the FPEFEQ parameter for initialization. The
settable operating frequency of the FPEFEQ parameter ranges from 8 to 50 MHz. When the
frequency is set otherwise, an error is returned to the FPFR parameter of the initialization
program and initialization is not performed. For details on setting the frequency, see section
25.7.2 (3), Flash Program/Erase Frequency Parameter (FPEFEQ: General Register ER0 of
CPU).
Rev. 2.00 Oct. 21, 2009 Page 1160 of 1454
REJ09B0498-0200
Section 25 Flash Memory
7. Initialization is executed. The initialization program is downloaded together with the
programming program to the on-chip RAM. The entry point of the initialization program is at
the address which is 32 bytes after #DLTOP (start address of the download destination
specified by FTDAR). Call the subroutine to execute initialization by using the following
steps.
MOV.L #DLTOP+32,ER2
; Set entry address to ER2
JSR
; Call initialization routine
@ER2
NOP
⎯ The general registers other than ER0 and ER1 are held in the initialization program.
⎯ R0L is a return value of the FPFR parameter.
⎯ Since the stack area is used in the initialization program, a stack area of 128 bytes at the
maximum must be allocated in RAM.
⎯ Interrupts can be accepted during execution of the initialization program. Make sure the
program storage area and stack area in the on-chip RAM and register values are not
overwritten.
8. The return value in the initialization program, the FPFR parameter is determined.
9. All interrupts and the use of a bus master other than the CPU are disabled during
programming/erasure. The specified voltage is applied for the specified time when
programming or erasing. If interrupts occur or the bus mastership is moved to other than the
CPU during programming/erasure, causing a voltage exceeding the specifications to be
applied, the flash memory may be damaged. Therefore, interrupts are disabled by setting bit 7
(I bit) in the condition code register (CCR) to B'1 in interrupt control mode 0 and by setting
bits 2 to 0 (I2 to I0 bits) in the extend register (EXR) to B'111 in interrupt control mode 2.
Accordingly, interrupts other than NMI are held and not executed. Configure the user system
so that NMI interrupts do not occur. The interrupts that are held must be executed after all
programming completes. When the bus mastership is moved to other than the CPU, such as to
the DMAC or DTC, the error protection state is entered. Therefore, make sure the DMAC does
not acquire the bus.
10. FKEY must be set to H'5A and the user MAT must be prepared for programming.
11. The parameters required for programming are set. The start address of the programming
destination on the user MAT (FMPAR parameter) is set in general register ER1. The start
address of the program data storage area (FMPDR parameter) is set in general register ER0.
⎯ Example of FMPAR parameter setting: When an address other than one in the user MAT
area is specified for the start address of the programming destination, even if the
programming program is executed, programming is not executed and an error is returned to
the FPFR parameter. Since the program data for one programming operation is 128 bytes,
the lower eight bits of the address must be H'00 or H'80 to be aligned with the 128-byte
boundary.
Rev. 2.00 Oct. 21, 2009 Page 1161 of 1454
REJ09B0498-0200
Section 25 Flash Memory
⎯ Example of FMPDR parameter setting: When the storage destination for the program data
is flash memory, even if the programming routine is executed, programming is not
executed and an error is returned to the FPFR parameter. In this case, the program data
must be transferred to the on-chip RAM and then programming must be executed.
12. Programming is executed. The entry point of the programming program is at the address which
is 16 bytes after #DLTOP (start address of the download destination specified by FTDAR).
Call the subroutine to execute programming by using the following steps.
MOV.L
#DLTOP+16,ER2
; Set entry address to ER2
JSR
@ER2
; Call programming routine
NOP
⎯ The general registers other than ER0 and ER1 are held in the programming program.
⎯ R0L is a return value of the FPFR parameter.
⎯ Since the stack area is used in the programming program, a stack area of 128 bytes at the
maximum must be allocated in RAM.
13. The return value in the programming program, the FPFR parameter is determined.
14. Determine whether programming of the necessary data has finished. If more than 128 bytes of
data are to be programmed, update the FMPAR and FMPDR parameters in 128-byte units, and
repeat steps 11 to 14. Increment the programming destination address by 128 bytes and update
the programming data pointer correctly. If an address which has already been programmed is
written to again, not only will a programming error occur, but also flash memory will be
damaged.
15. After programming finishes, clear FKEY and specify software protection. If this LSI is
restarted by a reset immediately after programming has finished, secure the reset input period
(period of RES = 0) of at least 100 μs.
Rev. 2.00 Oct. 21, 2009 Page 1162 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(3)
Erasing Procedure in User Program Mode
The procedures for download of the on-chip program, initialization, and erasing are shown in
figure 25.14.
Start erasing procedure
program
1
1.
Set FKEY to H'A5
Set FKEY to H'5A
Set SCO to 1 after initializing
VBR and execute download
Set FEBS parameter
2.
Erasing
JSR FTDAR setting + 16
3.
Clear FKEY to 0
DPFR = 0?
Yes
Yes
Download error processing
No
Initialization
JSR FTDAR setting + 32
4.
FPFR = 0?
No
Set the FPEFEQ
parameter
Initialization
Disable interrupts and
bus master operation
other than CPU
Erasing
Download
Select on-chip program
to be downloaded and
specify download
destination by FTDAR
No
Clear FKEY and erasing
error processing
Required block
erasing is
completed?
Yes
Clear FKEY to 0
FPFR = 0 ?
Yes
No
Initialization error processing
5.
6.
End erasing
procedure program
1
Figure 25.14 Erasing Procedure in User Program Mode
Rev. 2.00 Oct. 21, 2009 Page 1163 of 1454
REJ09B0498-0200
Section 25 Flash Memory
The procedure program must be executed in an area other than the user MAT to be erased. Setting
the SCO bit in FCCS to 1 to request download must be executed in the on-chip RAM. The area
that can be executed in the steps of the procedure program (on-chip RAM, user MAT, and external
space) is shown in section 25.8.5, On-Chip Program and Storable Area for Program Data. For the
downloaded on-chip program area, see figure 25.12.
One erasure processing erases one block. For details on block divisions, refer to figure 25.4. To
erase two or more blocks, update the erase block number and repeat the erasing processing for
each block.
1. Select the on-chip program to be downloaded and the download destination. When the EPVB
bit in FECS is set to 1, the programming program is selected. Several programming/erasing
programs cannot be selected at one time. If several programs are selected, a download error is
returned to the SS bit in the DPFR parameter. The on-chip RAM start address of the download
destination is specified by FTDAR.
For the procedures to be carried out after setting FKEY, see section 25.8.3 (2), Programming
Procedure in User Program Mode.
2. Set the FEBS parameter necessary for erasure. Set the erase block number (FEBS parameter)
of the user MAT in general register ER0. If a value other than an erase block number of the
user MAT is set, no block is erased even though the erasing program is executed, and an error
is returned to the FPFR parameter.
3. Erasure is executed. Similar to as in programming, the entry point of the erasing program is at
the address which is 16 bytes after #DLTOP (start address of the download destination
specified by FTDAR). Call the subroutine to execute erasure by using the following steps.
MOV.L #DLTOP+16, ER2
; Set entry address to ER2
JSR
; Call erasing routine
@ER2
NOP
•
•
•
The general registers other than ER0 and ER1 are held in the erasing program.
R0L is a return value of the FPFR parameter.
Since the stack area is used in the erasing program, a stack area of 128 bytes at the
maximum must be allocated in RAM.
4. The return value in the erasing program, the FPFR parameter is determined.
5. Determine whether erasure of the necessary blocks has finished. If more than one block is to
be erased, update the FEBS parameter and repeat steps 2 to 5.
6. After erasure completes, clear FKEY and specify software protection. If this LSI is restarted by
a reset immediately after erasure has finished, secure the reset input period (period of RES = 0)
of at least 100 μs.
Rev. 2.00 Oct. 21, 2009 Page 1164 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(4)
Procedure of Erasing, Programming, and RAM Emulation in User Program Mode
By changing the on-chip RAM start address of the download destination in FTDAR, the erasing
program and programming program can be downloaded to separate on-chip RAM areas.
Figure 25.15 shows a repeating procedure of erasing, programming, and RAM emulation.
1
Set FTDAR to H'00
(specify download
destination to H'FF9000)
Download erasing program
download
Programming program
Initialize erasing program
Set FTDAR to H'02
(specify download
destination H'FFB000)
Emulation/Erasing/Programming
download
Erasing program
Start procedure
program
Make a transition to RAM
emulation mode and tuning
parameters in on-chip RAM
Exit emulation mode
Erase relevant block
(execute erasing program)
Set FMPDR to H'FFA000
and program relevant block
(execute programming
program)
Download programming
program
Confirm operation
Initialize programming
program
End ?
No
Yes
1
End procedure
program
Figure 25.15 Repeating Procedure of Erasing, Programming,
and RAM Emulation in User Program Mode
Rev. 2.00 Oct. 21, 2009 Page 1165 of 1454
REJ09B0498-0200
Section 25 Flash Memory
In figure 25.15, since RAM emulation is performed, the erasing/programming program is
downloaded to avoid the 4-Kbyte on-chip RAM area (H'FFA000 to H'FFAFFF). Download and
initialization are performed only once at the beginning. Note the following when executing the
procedure program.
• Be careful not to overwrite data in the on-chip RAM with overlay settings. In addition to the
programming program area, erasing program area, and RAM emulation area, areas for the
procedure programs, work area, and stack area are reserved in the on-chip RAM. Do not make
settings that will overwrite data in these areas.
• Be sure to initialize both the programming program and erasing program. When the FPEFEQ
parameter is initialized, also initialize both the erasing program and programming program.
Initialization must be executed for both entry addresses: #DLTOP (start address of download
destination for erasing program) + 32 bytes, and #DLTOP (start address of download
destination for programming program) + 32 bytes.
25.8.4
User Boot Mode
Branching to a programming/erasing program prepared by the user enables user boot mode which
is a user-arbitrary boot mode to be used.
Only the user MAT can be programmed/erased in user boot mode. Programming/erasure of the
user boot MAT is only enabled in boot mode or programmer mode.
(1)
Initiation in User Boot Mode
When the reset start is executed with the mode pins set to user boot mode, the built-in check
routine runs and checks the user MAT and user boot MAT states. While the check routine is
running, NMI and all other interrupts cannot be accepted. Next, processing starts from the
execution start address of the reset vector in the user boot MAT. At this point, the user boot MAT
is selected (FMATS = H'AA) as the execution memory MAT.
Rev. 2.00 Oct. 21, 2009 Page 1166 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(2)
User MAT Programming in User Boot Mode
Figure 25.16 shows the procedure for programming the user MAT in user boot mode.
The difference between the programming procedures in user program mode and user boot mode is
the memory MAT switching as shown in figure 25.16. For programming the user MAT in user
boot mode, additional processing made by setting FMATS is required: switching from the user
boot MAT to the user MAT, and switching back to the user boot MAT after programming
completes.
Start programming
procedure program
1
Select on-chip program
to be downloaded and
specify download
destination by FTDAR
Set FMATS to value other than
H'AA to select user MAT
MAT
switchover
Set FKEY to H'A5
Set FKEY to H'A5
Set parameter to ER0 and
ER1 (FMPAR and FMPDR)
Yes
No
Download error processing
Programming
JSR FTDAR setting + 16
Programming
User-MAT selection state
Clear FKEY to 0
DPFR = 0 ?
FPFR = 0 ?
Yes
No
No
Clear FKEY and programming
error processing
Required data
programming is
completed?
Set the FPEFEQ parameter
Yes
Initialization
User-boot-MAT selection state
Download
Set SCO to 1 after initializing
VBR and execute download
Initialization
JSR FTDAR setting + 32
Clear FKEY to 0
FPFR = 0 ?
Yes
No
Initialization error processing
Set FMATS to H'AA to
select user boot MAT
Disable interrupts
and bus master operation
other than CPU
User-boot-MAT
selection state
1
MAT
switchover
End programming
procedure program
Note: The MAT must be switched by FMATS to perform the programming error processing in the user boot MAT.
Figure 25.16 Procedure for Programming User MAT in User Boot Mode
Rev. 2.00 Oct. 21, 2009 Page 1167 of 1454
REJ09B0498-0200
Section 25 Flash Memory
In user boot mode, though the user boot MAT can be seen in the flash memory space, the user
MAT is hidden in the background. Therefore, the user MAT and user boot MAT are switched
while the user MAT is being programmed. Because the user boot MAT is hidden while the user
MAT is being programmed, the procedure program must be executed in an area other than flash
memory. After programming completes, switch the memory MATs again to return to the first
state.
Memory MAT switching is enabled by setting FMATS. However note that access to a memory
MAT is not allowed until memory MAT switching is completed. During memory MAT switching,
the LSI is in an unstable state, e.g. if an interrupt occurs, from which memory MAT the interrupt
vector is read is undetermined. Perform memory MAT switching in accordance with the
description in section 25.11, Switching between User MAT and User Boot MAT.
Except for memory MAT switching, the programming procedure is the same as that in user
program mode.
The area that can be executed in the steps of the procedure program (on-chip RAM, user MAT,
and external space) is shown in section 25.8.5, On-Chip Program and Storable Area for Program
Data.
Rev. 2.00 Oct. 21, 2009 Page 1168 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(3)
User MAT Erasing in User Boot Mode
Figure 25.17 shows the procedure for erasing the user MAT in user boot mode.
The difference between the erasing procedures in user program mode and user boot mode is the
memory MAT switching as shown in figure 25.17. For erasing the user MAT in user boot mode,
additional processing made by setting FMATS is required: switching from the user boot MAT to
the user MAT, and switching back to the user boot MAT after erasing completes.
Start erasing
procedure program
1
Select on-chip program
to be downloaded and
specify download
destination by FTDAR
Set FMATS to value other
than H'AA to select user MAT
MAT
switchover
Set FKEY to H'A5
Set FKEY to H'A5
No
Download error processing
Set the FPEFEQ parameter
Initialization
JSR FTDAR setting + 32
FPFR = 0 ?
Yes
No
No
Clear FKEY and erasing
error processing
Required
block erasing is
completed?
Yes
FPFR = 0 ?
No
Yes
Erasing
JSR FTDAR setting + 16
Erasing
Yes
User-MAT selection state
Download
Set FEBS parameter
Clear FKEY to 0
DPFR = 0 ?
Initialization
User-boot-MAT selection state
Set SCO to 1 after initializing
VBR and execute download
Clear FKEY to 0
Initialization error processing
Set FMATS to H'AA to
select user boot MAT
Disable interrupts
and bus master operation
other than CPU
User-boot-MAT
selection state
MAT
switchover
End erasing
procedure program
1
Note:
The MAT must be switched by FMATS to perform the erasing error processing in the user boot MAT.
Figure 25.17 Procedure for Erasing User MAT in User Boot Mode
Rev. 2.00 Oct. 21, 2009 Page 1169 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Memory MAT switching is enabled by setting FMATS. However note that access to a memory
MAT is not allowed until memory MAT switching is completed. During memory MAT switching,
the LSI is in an unstable state, e.g. if an interrupt occurs, from which memory MAT the interrupt
vector is read is undetermined. Perform memory MAT switching in accordance with the
description in section 25.11, Switching between User MAT and User Boot MAT.
Except for memory MAT switching, the erasing procedure is the same as that in user program
mode.
The area that can be executed in the steps of the procedure program (on-chip RAM, user MAT,
and external space) is shown in section 25.8.5, On-Chip Program and Storable Area for Program
Data.
25.8.5
On-Chip Program and Storable Area for Program Data
In the descriptions in this manual, the on-chip programs and program data storage areas are
assumed to be in the on-chip RAM. However, they can be executed from part of the flash memory
which is not to be programmed or erased as long as the following conditions are satisfied.
1. The on-chip program is downloaded to and executed in the on-chip RAM specified by
FTDAR. Therefore, this on-chip RAM area is not available for use.
2. Since the on-chip program uses a stack area, allocate 128 bytes at the maximum as a stack
area.
3. Download requested by setting the SCO bit in FCCS to 1 should be executed from the on-chip
RAM because it will require switching of the memory MATs.
4. In an operating mode in which the external address space is not accessible, such as single-chip
mode, the required procedure programs, NMI handling vector table, and NMI handling routine
should be transferred to the on-chip RAM before programming/erasure starts (download result
is determined).
5. The flash memory is not accessible during programming/erasure. Programming/erasure is
executed by the program downloaded to the on-chip RAM. Therefore, the procedure program
that initiates operation, the NMI handling vector table, and the NMI handling routine should be
stored in the on-chip RAM other than the flash memory.
6. After programming/erasure starts, access to the flash memory should be inhibited until FKEY
is cleared. The reset input state (period of RES = 0) must be set to at least 100 μs when the
operating mode is changed and the reset start executed on completion of programming/erasure.
Transitions to the reset state are inhibited during programming/erasure. When the reset signal
is input, a reset input state (period of RES = 0) of at least 100 μs is needed before the reset
signal is released.
Rev. 2.00 Oct. 21, 2009 Page 1170 of 1454
REJ09B0498-0200
Section 25 Flash Memory
7. Switching of the memory MATs by FMATS should be needed when programming/erasure of
the user MAT is operated in user boot mode. The program which switches the memory MATs
should be executed from the on-chip RAM. For details, see section 25.11, Switching between
User MAT and User Boot MAT. Make sure you know which memory MAT is currently
selected when switching them.
8. When the program data storage area is within the flash memory area, an error will occur even
when the data stored is normal program data. Therefore, the data should be transferred to the
on-chip RAM to place the address that the FMPDR parameter indicates in an area other than
the flash memory.
In consideration of these conditions, the areas in which the program data can be stored and
executed are determined by the combination of the processing contents, operating mode, and bank
structure of the memory MATs, as shown in tables 25.8 to 25.12.
Table 25.8 Executable Memory MAT
Operating Mode
Processing Contents
User Program Mode
User Boot Mode*
Programming
See table 25.9
See table 25.11
Erasing
See table 25.10
See table 25.12
Note:
*
Programming/Erasure is possible to the user MAT.
Rev. 2.00 Oct. 21, 2009 Page 1171 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Table 25.9 Usable Area for Programming in User Program Mode
Storable/Executable Area
Selected MAT
Item
On-Chip RAM
User MAT
Embedded
Program
User MAT Storage MAT
Storage area for program data
O
×*
⎯
Operation for selecting on-chip
program to be downloaded
O
O
O
O
Operation for writing H'A5 to FKEY
O
O
Execution of writing 1 to SCO bit in
FCCS (download)
O
×
Operation for clearing FKEY
O
O
O
Decision of download result
O
O
O
Operation for download error
O
O
O
Operation for setting initialization
parameter
O
O
O
Execution of initialization
O
×
O
Decision of initialization result
O
O
O
Operation for initialization error
O
O
O
NMI handling routine
O
×
O
Operation for disabling interrupts
O
O
O
Operation for writing H'5A to FKEY
O
O
O
Operation for setting programming
parameter
O
×
O
Execution of programming
O
×
O
Decision of programming result
O
×
O
Operation for programming error
O
×
O
Operation for clearing FKEY
O
×
O
Note:
*
⎯
O
Transferring the program data to the on-chip RAM beforehand enables this area to be
used.
Rev. 2.00 Oct. 21, 2009 Page 1172 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Table 25.10 Usable Area for Erasure in User Program Mode
Storable/Executable Area
Selected MAT
Item
On-Chip RAM
User MAT
Embedded
Program
User MAT Storage MAT
Operation for selecting on-chip
program to be downloaded
O
O
O
Operation for writing H'A5 to FKEY
O
O
O
Execution of writing 1 to SCO bit in
FCCS (download)
O
×
Operation for clearing FKEY
O
O
O
Decision of download result
O
O
O
Operation for download error
O
O
O
Operation for setting initialization
parameter
O
O
O
Execution of initialization
O
×
O
Decision of initialization result
O
O
O
Operation for initialization error
O
O
O
NMI handling routine
O
×
O
Operation for disabling interrupts
O
O
O
Operation for writing H'5A to FKEY
O
O
O
Operation for setting erasure
parameter
O
×
O
Execution of erasure
O
×
O
Decision of erasure result
O
×
O
Operation for erasure error
O
×
O
Operation for clearing FKEY
O
×
O
O
Rev. 2.00 Oct. 21, 2009 Page 1173 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Table 25.11 Usable Area for Programming in User Boot Mode
Storable/Executable Area
Selected MAT
Item
On-Chip
RAM
User Boot
MAT
User
MAT
User
Boot
MAT
Embedded
Program
Storage MAT
Storage area for program data
O
×*1
⎯
⎯
⎯
Operation for selecting on-chip
program to be downloaded
O
O
O
O
Operation for writing H'A5 to FKEY
O
O
Execution of writing 1 to SCO bit in
FCCS (download)
O
×
Operation for clearing FKEY
O
O
O
Decision of download result
O
O
O
Operation for download error
O
O
O
Operation for setting initialization
parameter
O
O
O
Execution of initialization
O
×
O
Decision of initialization result
O
O
O
Operation for initialization error
O
O
O
NMI handling routine
O
×
O
Operation for disabling interrupts
O
O
O
Switching memory MATs by FMATS O
×
O
Operation for writing H'5A to FKEY
O
×
O
Operation for setting programming
parameter
O
×
O
Execution of programming
O
×
O
Decision of programming result
O
×
Operation for programming error
O
×*
Operation for clearing FKEY
O
×
Switching memory MATs by FMATS O
×
O
O
2
O
O
O
Notes: 1. Transferring the program data to the on-chip RAM beforehand enables this area to be
used.
2. Switching memory MATs by FMATS by a program in the on-chip RAM enables this
area to be used.
Rev. 2.00 Oct. 21, 2009 Page 1174 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Table 25.12 Usable Area for Erasure in User Boot Mode
Storable/Executable Area
Selected MAT
User Boot
MAT
Operation for selecting on-chip
program to be downloaded
O
O
O
Operation for writing H'A5 to FKEY
O
O
O
Execution of writing 1 to SCO bit in
FCCS (download)
O
×
Operation for clearing FKEY
O
O
O
Decision of download result
O
O
O
Operation for download error
O
O
O
Operation for setting initialization
parameter
O
O
O
Execution of initialization
O
×
O
Decision of initialization result
O
O
O
Operation for initialization error
O
O
O
NMI handling routine
O
×
O
Operation for disabling interrupts
O
O
O
Switching memory MATs by FMATS O
×
O
Operation for writing H'5A to FKEY
O
×
O
Operation for setting erasure
parameter
O
×
O
Execution of erasure
O
×
O
Decision of erasure result
O
×
O
Operation for erasure error
O
×*
O
Operation for clearing FKEY
O
×
O
Switching memory MATs by FMATS O
×
O
Item
User
MAT
User
Boot
MAT
On-Chip
RAM
Embedded
Program
Storage MAT
O
Note: Switching memory MATs by FMATS by a program in the on-chip RAM enables this area to
be used.
Rev. 2.00 Oct. 21, 2009 Page 1175 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.9
Protection
There are three types of protection against the flash memory programming/erasure: hardware
protection, software protection, and error protection.
25.9.1
Hardware Protection
Programming and erasure of the flash memory is forcibly disabled or suspended by hardware
protection. In this state, download of an on-chip program and initialization are possible. However,
programming or erasure of the user MAT cannot be performed even if the programming/erasing
program is initiated, and the error in programming/erasure is indicated by the FPFR parameter.
Table 25.13 Hardware Protection
Function to be Protected
Item
Description
Download
Programming/
Erasing
Reset protection
•
The programming/erasing interface
registers are initialized in the reset
state (including a reset by the WDT)
and the programming/erasing
protection state is entered.
O
O
•
The reset state will not be entered by
a reset using the RES pin unless the
RES pin is held low until oscillation has
settled after a power is initially
supplied. In the case of a reset during
operation, hold the RES pin low for the
RES pulse width given in the AC
characteristics. If a reset is input during
programming or erasure, data in the
flash memory is not guaranteed. In this
case, execute erasure and then
execute programming again.
Rev. 2.00 Oct. 21, 2009 Page 1176 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.9.2
Software Protection
The software protection protects the flash memory against programming/erasure by disabling
download of the programming/erasing program, using the key code, and by the RAMER setting.
Table 25.14 Software Protection
Function to be Protected
Item
Description
Download
Programming/
Erasing
Protection The programming/erasing protection state is
O
by SCO bit entered when the SCO bit in FCCS is cleared to 0
to disable download of the programming/erasing
programs.
O
Protection
by FKEY
The programming/erasing protection state is
entered because download and
programming/erasure are disabled unless the
required key code is written in FKEY.
O
O
Emulation
protection
The programming/erasing protection state is
O
entered when the RAMS bit in the RAM emulation
register (RAMER) is set to 1.
O
25.9.3
Error Protection
Error protection is a mechanism for aborting programming or erasure when a CPU runaway
occurs or operations not according to the programming/erasing procedures are detected during
programming/erasure of the flash memory. Aborting programming or erasure in such cases
prevents damage to the flash memory due to excessive programming or erasing.
If an error occurs during programming/erasure of the flash memory, the FLER bit in FCCS is set
to 1 and the error protection state is entered.
• When an interrupt request, such as NMI, occurs during programming/erasure.
• When the flash memory is read from during programming/erasure (including a vector read or
an instruction fetch).
• When a SLEEP instruction is executed (including software-standby mode) during
programming/erasure.
• When a bus master other than the CPU, such as the DMAC and DTC, obtains bus mastership
during programming/erasure.
Rev. 2.00 Oct. 21, 2009 Page 1177 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Error protection is canceled by a reset. Note that the reset should be released after the reset input
period of at least 100μs has passed. Since high voltages are applied during programming/erasure
of the flash memory, some voltage may remain after the error protection state has been entered.
For this reason, it is necessary to reduce the risk of damaging the flash memory by extending the
reset input period so that the charge is released.
The state-transition diagram in figure 25.18 shows transitions to and from the error protection
state.
Programming/erasing
mode
Reset
(hardware protection)
RES = 0
Read disabled
Programming/erasing enabled
FLER = 0
Er
ror
oc
oft
S=
cu
(S
RE
rre
d
wa
re
sta
nd
Error occurrence
Error-protection mode
Read enabled
Programming/erasing disabled
FLER = 1
0
Read disabled
Programming/erasing disabled
FLER = 0
RES = 0
by
Programming/erasing interface
register is in its initial state.
)
Software standby mode
Cancel
software standby mode
Error-protection mode
(software standby)
Read disabled
Programming/erasing disabled
FLER = 1
Programming/erasing interface
register is in its initial state.
Figure 25.18 Transitions to Error Protection State
Rev. 2.00 Oct. 21, 2009 Page 1178 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.10
Flash Memory Emulation Using RAM
For realtime emulation of the data written to the flash memory using the on-chip RAM, the onchip RAM area can be overlaid with several flash memory blocks (user MAT) using the RAM
emulation register (RAMER).
The overlaid area can be accessed from both the user MAT area specified by RAMER and the
overlaid RAM area. The emulation can be performed in user mode and user program mode.
Figure 25.19 shows an example of emulating realtime programming of the user MAT.
Emulation program start
Set RAMER
Write tuning data to overlaid
RAM area
Execute application program
No
Tuning OK?
Yes
Cancel setting in RAMER
Program emulation block
in user MAT
Emulation program end
Figure 25.19 RAM Emulation Flow
Rev. 2.00 Oct. 21, 2009 Page 1179 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Figure 25.20 shows an example of overlaying flash memory block area EB0.
This area can be accessed via
both the on-chip RAM and flash
memory area.
H'00000
EB0
H'01000
EB1
H'02000
EB2
H'03000
EB3
H'04000
EB4
H'05000
EB5
H'06000
EB6
H'07000
H'FF6000
EB7
H'08000
H'FFA000
H'FFAFFF
Flash memory
user MAT
EB8 to EB15*1
H'7FFFF*2
Notes:
On-chip RAM
H'FFBFFF
1.
2.
EB8 to EB13 in the H8SX/1662.
H'05FFFF in the H8SX/1662.
Figure 25.20 Address Map of Overlaid RAM Area (H8SX/1665)
The flash memory area that can be emulated is the one area selected by bits RAM2 to RAM0 in
RAMER from among the eight blocks, EB0 to EB7, of the user MAT.
To overlay a part of the on-chip RAM with block EB0 for realtime emulation, set the RAMS bit in
RAMER to 1 and bits RAM2 to RAM0 to B'000.
For programming/erasing the user MAT, the procedure programs including a download program
of the on-chip program must be executed. At this time, the download area should be specified so
that the overlaid RAM area is not overwritten by downloading the on-chip program. Since the area
in which the tuned data is stored is overlaid with the download area when FTDAR = H'01, the
tuned data must be saved in an unused area beforehand.
Rev. 2.00 Oct. 21, 2009 Page 1180 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Figure 25.21 shows an example of the procedure to program the tuned data in block EB0 of the
user MAT.
H'00000
H'01000
EB0
(1) Exit RAM emulation mode.
EB1
(2) Transfer user-created programming/erasing procedure program.
H'02000
EB2
(3) Download the on-chip programming/erasing program to the area
H'03000
EB3
H'04000
H'05000
H'06000
H'07000
specified by FTDAR. FTDAR setting should avoid the tuned data area.
(4) Program after erasing, if necessary.
EB4
EB5
EB6
EB7
H'08000
Download area
EB8 to EB15*1
Tuned data area
Area for programming/
erasing program etc.
H'7FFFF*2
Notes:
Flash memory
user MAT
1.
2.
Specified by FTDAR
H'FFA000
H'FFAFFF
H'FFB000
H'FFBFFF
EB8 to EB13 in the H8SX/1662.
H'05FFFF in the H8SX/1662.
Figure 25.21 Programming Tuned Data (H8SX/1665)
1. After tuning program data is completed, clear the RAMS bit in RAMER to 0 to cancel the
overlaid RAM.
2. Transfer the user-created procedure program to the on-chip RAM.
3. Start the procedure program and download the on-chip program to the on-chip RAM. The start
address of the download destination should be specified by FTDAR so that the tuned data area
does not overlay the download area.
4. When block EB0 of the user MAT has not been erased, the programming program must be
downloaded after block EB0 is erased. Specify the tuned data saved in the FMPAR and
FMPDR parameters and then execute programming.
Note: Setting the RAMS bit to 1 makes all the blocks of the user MAT enter the
programming/erasing protection state (emulation protection state) regardless of the setting
of the RAM2 to RAM0 bits. Under this condition, the on-chip program cannot be
downloaded. When data is to be actually programmed and erased, clear the RAMS bit
to 0.
Rev. 2.00 Oct. 21, 2009 Page 1181 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.11
Switching between User MAT and User Boot MAT
It is possible to switch between the user MAT and user boot MAT. However, the following
procedure is required because the start addresses of these MATs are allocated to the same address.
Switching to the user boot MAT disables programming and erasing. Programming of the user boot
MAT should take place in boot mode or programmer mode.
1. Memory MAT switching by FMATS should always be executed from the on-chip RAM.
2. When accessing the memory MAT immediately after switching the memory MATs by
FMATS from the on-chip RAM, similarly execute the NOP instruction in the on-chip RAM
for eight times (this prevents access to the flash memory during memory MAT switching).
3. If an interrupt request has occurred during memory MAT switching, there is no guarantee of
which memory MAT is accessed. Always mask the maskable interrupts before switching
memory MATs. In addition, configure the system so that NMI interrupts do not occur during
memory MAT switching.
4. After the memory MATs have been switched, take care because the interrupt vector table will
also have been switched. If interrupt processing is to be the same before and after memory
MAT switching, transfer the interrupt processing routines to the on-chip RAM and specify
VBR to place the interrupt vector table in the on-chip RAM.
5. The size of the user MAT is different from that of the user boot MAT. Addresses which exceed
the size of the 16-Kbyte user boot MAT should not be accessed. If an attempt is made, data is
read as an undefined value.
Procedure for
switching to
user boot MAT
Procedure for
switching to
user MAT
Procedure for switching to the user boot MAT
1. Inhibit interrupts (mask).
2. Write H'AA to FMATS.
3. Before access to the user boot MAT, execute the NOP instruction for eight times.
Procedure for switching to the user MAT
1. Inhibit interrupts (mask).
2. Write other than H'AA to FMATS.
3. Before access to the user MAT, execute the NOP instruction for eight times.
Figure 25.22 Switching between User MAT and User Boot MAT
Rev. 2.00 Oct. 21, 2009 Page 1182 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.12
Programmer Mode
Along with its on-board programming mode, this LSI also has a programmer mode as a further
mode for the writing and erasing of programs and data. In programmer mode, a general-purpose
PROM programmer that supports the device types shown in table 25.15 can be used to write
programs to the on-chip ROM without any limitation.
Table 25.15 Device Types Supported in Programmer Mode
Target Memory MAT
Product Classification ROM Size
Device Type
User MAT
H8SX/1662
384 Kbytes
FZTAT512V3A
H8SX/1665
512 Kbytes
H8SX/1662
16 Kbytes
User boot MAT
FZTATUSBT16V3A
H8SX/1665
25.13
Standard Serial Communications Interface Specifications for Boot
Mode
The boot program initiated in boot mode performs serial communications using the host and onchip SCI_4. The serial communications interface specifications are shown below.
The boot program has three states.
1. Bit-rate-adjustment state
In this state, the boot program adjusts the bit rate to achieve serial communications with the
host. Initiating boot mode enables starting of the boot program and entry to the bit-rateadjustment state. The program receives the command from the host to adjust the bit rate. After
adjusting the bit rate, the program enters the inquiry/selection state.
2. Inquiry/selection state
In this state, the boot program responds to inquiry commands from the host. The device name,
clock mode, and bit rate are selected. After selection of these settings, the program is made to
enter the programming/erasing state by the command for a transition to the
programming/erasing state. The program transfers the libraries required for erasure to the onchip RAM and erases the user MATs and user boot MATs before the transition.
Rev. 2.00 Oct. 21, 2009 Page 1183 of 1454
REJ09B0498-0200
Section 25 Flash Memory
3. Programming/erasing state
Programming and erasure by the boot program take place in this state. The boot program is
made to transfer the programming/erasing programs to the on-chip RAM by commands from
the host. Sum checks and blank checks are executed by sending these commands from the
host.
These boot program states are shown in figure 25.23.
Reset
Bit-rate-adjustment
state
Inquiry/response
wait
Response
Inquiry
Operations for
inquiry and selection
Transition to
programming/erasing
Operations for
response
Operations for erasing
user MATs and user
boot MATs
Programming/erasing
wait
Programming
Erasing
Operations for
programming
Checking
Operations for
erasing
Operations for
checking
Figure 25.23 Boot Program States
Rev. 2.00 Oct. 21, 2009 Page 1184 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(1)
Bit-Rate-Adjustment State
The bit rate is calculated by measuring the period of transfer of a low-level byte (H'00) from the
host. The bit rate can be changed by the command for a new bit rate selection. After the bit rate
has been adjusted, the boot program enters the inquiry and selection state. The bit-rate-adjustment
sequence is shown in figure 25.24.
Host
Boot program
H'00 (30 times maximum)
Measuring the
1-bit length
H'00 (completion of adjustment)
H'55
H'E6 (boot response)
(H'FF (error))
Figure 25.24 Bit-Rate-Adjustment Sequence
(2)
Communications Protocol
After adjustment of the bit rate, the protocol for serial communications between the host and the
boot program is as shown below.
1. One-byte commands and one-byte responses
These one-byte commands and one-byte responses consist of the inquiries and the ACK for
successful completion.
2. n-byte commands or n-byte responses
These commands and responses are comprised of n bytes of data. These are selections and
responses to inquiries.
The program data size is not included under this heading because it is determined in another
command.
3. Error response
The error response is a response to inquiries. It consists of an error response and an error code
and comes two bytes.
4. Programming of 128 bytes
The size is not specified in commands. The size of n is indicated in response to the
programming unit inquiry.
Rev. 2.00 Oct. 21, 2009 Page 1185 of 1454
REJ09B0498-0200
Section 25 Flash Memory
5. Memory read response
This response consists of four bytes of data.
One-byte command
or one-byte response
Command or response
n-byte Command or
n-byte response
Data
Size
Checksum
Command or response
Error response
Error code
Error response
128-byte programming
Address
Data (n bytes)
Command
Memory read
response
Size
Checksum
Data
Response
Checksum
Figure 25.25 Communication Protocol Format
• Command (one byte): Commands including inquiries, selection, programming, erasing, and
checking
• Response (one byte): Response to an inquiry
• Size (one byte): The amount of data for transmission excluding the command, amount of data,
and checksum
• Checksum (one byte): The checksum is calculated so that the total of all values from the
command byte to the SUM byte becomes H'00.
• Data (n bytes): Detailed data of a command or response
• Error response (one byte): Error response to a command
• Error code (one byte): Type of the error
• Address (four bytes): Address for programming
• Data (n bytes): Data to be programmed (the size is indicated in the response to the
programming unit inquiry.)
• Size (four bytes): Four-byte response to a memory read
Rev. 2.00 Oct. 21, 2009 Page 1186 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(3)
Inquiry and Selection States
The boot program returns information from the flash memory in response to the host's inquiry
commands and sets the device code, clock mode, and bit rate in response to the host's selection
command.
Table 25.16 lists the inquiry and selection commands.
Table 25.16 Inquiry and Selection Commands
Command
Command Name
Description
H'20
Supported device inquiry
Inquiry regarding device codes
H'10
Device selection
Selection of device code
H'21
Clock mode inquiry
Inquiry regarding numbers of clock modes
and values of each mode
H'11
Clock mode selection
Indication of the selected clock mode
H'22
Multiplication ratio inquiry
Inquiry regarding the number of frequencymultiplied clock types, the number of
multiplication ratios, and the values of each
multiple
H'23
Operating clock frequency inquiry
Inquiry regarding the maximum and minimum
values of the main clock and peripheral clocks
H'24
User boot MAT information inquiry
Inquiry regarding the number of user boot
MATs and the start and last addresses of
each MAT
H'25
User MAT information inquiry
Inquiry regarding the a number of user MATs
and the start and last addresses of each MAT
H'26
Block for erasing information Inquiry Inquiry regarding the number of blocks and
the start and last addresses of each block
H'27
Programming unit inquiry
Inquiry regarding the unit of program data
H'3F
New bit rate selection
Selection of new bit rate
H'40
Transition to programming/erasing
state
Erasing of user MAT and user boot MAT, and
entry to programming/erasing state
H'4F
Boot program status inquiry
Inquiry into the operated status of the boot
program
Rev. 2.00 Oct. 21, 2009 Page 1187 of 1454
REJ09B0498-0200
Section 25 Flash Memory
The selection commands, which are device selection (H'10), clock mode selection (H'11), and new
bit rate selection (H'3F), should be sent from the host in that order. When two or more selection
commands are sent at once, the last command will be valid.
All of these commands, except for the boot program status inquiry command (H'4F), will be valid
until the boot program receives the programming/erasing transition (H'40). The host can choose
the needed commands and make inquiries while the above commands are being transmitted. H'4F
is valid even after the boot program has received H'40.
(a)
Supported Device Inquiry
The boot program will return the device codes of supported devices and the product code in
response to the supported device inquiry.
Command
H'20
• Command, H'20, (one byte): Inquiry regarding supported devices
Response
H'30
Size
Number of devices
Number of
characters
Device code
Product name
···
SUM
• Response, H'30, (one byte): Response to the supported device inquiry
• Size (one byte): Number of bytes to be transmitted, excluding the command, size, and
checksum, that is, the amount of data contributes by the number of devices, characters, device
codes and product names
• Number of devices (one byte): The number of device types supported by the boot program
• Number of characters (one byte): The number of characters in the device codes and boot
program's name
• Device code (four bytes): ASCII code of the supporting product
• Product name (n bytes): Type name of the boot program in ASCII-coded characters
• SUM (one byte): Checksum
The checksum is calculated so that the total number of all values from the command byte to
the SUM byte becomes H'00.
Rev. 2.00 Oct. 21, 2009 Page 1188 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(b)
Device Selection
The boot program will set the supported device to the specified device code. The program will
return the selected device code in response to the inquiry after this setting has been made.
Command
H'10
Size
Device code
SUM
• Command, H'10, (one byte): Device selection
• Size (one byte): Amount of device-code data
This is fixed at 4.
• Device code (four bytes): Device code (ASCII code) returned in response to the supported
device inquiry
• SUM (one byte): Checksum
Response
H'06
• Response, H'06, (one byte): Response to the device selection command
ACK will be returned when the device code matches.
Error response
H'90
ERROR
• Error response, H'90, (one byte): Error response to the device selection command
ERROR
: (one byte): Error code
H'11: Sum check error
H'21: Device code error, that is, the device code does not match
(c)
Clock Mode Inquiry
The boot program will return the supported clock modes in response to the clock mode inquiry.
Command
H'21
• Command, H'21, (one byte): Inquiry regarding clock mode
Response
H'31
Size
Mode
···
SUM
• Response, H'31, (one byte): Response to the clock-mode inquiry
• Size (one byte): Amount of data that represents the modes
• Mode (two bytes): Values of the supported clock modes (i.e. H'01 means clock mode 1.)
H’00: MD_CLK = 0 (8 to18 MHz input)
H’01: MD_CLK = 1 (16 MHz input)
• SUM (one byte): Checksum
Rev. 2.00 Oct. 21, 2009 Page 1189 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(d)
Clock Mode Selection
The boot program will set the specified clock mode. The program will return the selected clockmode information after this setting has been made.
The clock-mode selection command should be sent after the device-selection commands.
Command
•
•
•
•
H'11
Size
Mode
SUM
Command, H'11, (one byte): Selection of clock mode
Size (one byte): Amount of data that represents the modes
Mode (one byte): A clock mode returned in reply to the supported clock mode inquiry.
SUM (one byte): Checksum
Response
H'06
• Response, H'06, (one byte): Response to the clock mode selection command
ACK will be returned when the clock mode matches.
Error Response
H'91
ERROR
• Error response, H'91, (one byte) : Error response to the clock mode selection command
• ERROR
: (one byte): Error code
H'11: Checksum error
H'22: Clock mode error, that is, the clock mode does not match.
Rev. 2.00 Oct. 21, 2009 Page 1190 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(e)
Multiplication Ratio Inquiry
The boot program will return the supported multiplication and division ratios.
Command
H'22
• Command, H'22, (one byte): Inquiry regarding multiplication ratio
Response
H'32
Size
Number
of types
of
multipli
cation
Number of
multiplication ratios
Multiplication ratio
···
···
SUM
• Response, H'32, (one byte): Response to the multiplication ratio inquiry
• Size (one byte): The amount of data that represents the number of types of multiplication, the
number of multiplication ratios, and the multiplication ratios
• Number of types of multiplication (one byte): The number of types of multiplication to which
the device can be set
(e.g. when there are two multiplied clock types, which are the main and peripheral clocks, the
number of types will be H'02.)
• Number of multiplication ratios (one byte): The number of types of multiplication ratios for
each type
(e.g. the number of multiplication ratios to which the main clock can be set and the peripheral
clock can be set.)
• Multiplication ratio (one byte)
Multiplication ratio: The value of the multiplication ratio (e.g. when the clock-frequency
multiplier is four, the value of multiplication ratio will be H'04.)
Division ratio: The inverse of the division ratio, i.e. a negative number (e.g. when the clock is
divided by two, the value of division ratio will be H'FE. H'FE = [-2]
The number of multiplication ratios returned is the same as the number of multiplication ratios
and as many groups of data are returned as there are types of multiplication.
• SUM (one byte): Checksum
Rev. 2.00 Oct. 21, 2009 Page 1191 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(f)
Operating Clock Frequency Inquiry
The boot program will return the number of operating clock frequencies, and the maximum and
minimum values.
Command
H'23
• Command, H'23, (one byte): Inquiry regarding operating clock frequencies
Response
H'33
Size
Minimum value of
operating clock frequency
Number of operating
clock frequencies
Maximum value of operating clock
frequency
···
SUM
• Response, H'33, (one byte): Response to operating clock frequency inquiry
• Size (one byte): The number of bytes that represents the minimum values, maximum values,
and the number of frequencies.
• Number of operating clock frequencies (one byte): The number of supported operating clock
frequency types
(e.g. when there are two operating clock frequency types, which are the main and peripheral
clocks, the number of types will be H'02.)
• Minimum value of operating clock frequency (two bytes): The minimum value of the
multiplied or divided clock frequency.
The minimum and maximum values of the operating clock frequency represent the values in
MHz, valid to the hundredths place of MHz, and multiplied by 100. (e.g. when the value is
17.00 MHz, it will be 2000, which is H'07D0.)
• Maximum value (two bytes): Maximum value among the multiplied or divided clock
frequencies.
There are as many pairs of minimum and maximum values as there are operating clock
frequencies.
• SUM (one byte): Checksum
Rev. 2.00 Oct. 21, 2009 Page 1192 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(g)
User Boot MAT Information Inquiry
The boot program will return the number of user boot MATs and their addresses.
Command
H'24
• Command, H'24, (one byte): Inquiry regarding user boot MAT information
Response
H'34
Size
Number of areas
Area-start address
Area-last address
···
SUM
• Response, H'34, (one byte): Response to user boot MAT information inquiry
• Size (one byte): The number of bytes that represents the number of areas, area-start addresses,
and area-last address
• Number of Areas (one byte): The number of consecutive user boot MAT areas
When user boot MAT areas are consecutive, the number of areas returned is H'01.
• Area-start address (four byte): Start address of the area
• Area-last address (four byte): Last address of the area
There are as many groups of data representing the start and last addresses as there are areas.
• SUM (one byte): Checksum
(h)
User MAT Information Inquiry
The boot program will return the number of user MATs and their addresses.
Command
H'25
• Command, H'25, (one byte): Inquiry regarding user MAT information
Response
H'35
Size
Number of areas
Start address area
Last address area
···
SUM
• Response, H'35, (one byte): Response to the user MAT information inquiry
• Size (one byte): The number of bytes that represents the number of areas, area-start address
and area-last address
• Number of areas (one byte): The number of consecutive user MAT areas
When the user MAT areas are consecutive, the number of areas is H'01.
• Area-start address (four bytes): Start address of the area
Rev. 2.00 Oct. 21, 2009 Page 1193 of 1454
REJ09B0498-0200
Section 25 Flash Memory
• Area-last address (four bytes): Last address of the area
There are as many groups of data representing the start and last addresses as there are areas.
• SUM (one byte): Checksum
(i)
Erased Block Information Inquiry
The boot program will return the number of erased blocks and their addresses.
Command
H'26
• Command, H'26, (two bytes): Inquiry regarding erased block information
Response
H'36
Size
Number of blocks
Block start address
Block last address
···
SUM
• Response, H'36, (one byte): Response to the number of erased blocks and addresses
• Size (three bytes): The number of bytes that represents the number of blocks, block-start
addresses, and block-last addresses.
• Number of blocks (one byte): The number of erased blocks
• Block start address (four bytes): Start address of a block
• Block last Address (four bytes): Last address of a block
There are as many groups of data representing the start and last addresses as there are areas.
• SUM (one byte): Checksum
(j)
Programming Unit Inquiry
The boot program will return the programming unit used to program data.
Command
H'27
• Command, H'27, (one byte): Inquiry regarding programming unit
Response
H'37
Size
Programming unit
SUM
• Response, H'37, (one byte): Response to programming unit inquiry
• Size (one byte): The number of bytes that indicate the programming unit, which is fixed to 2
• Programming unit (two bytes): A unit for programming
This is the unit for reception of programming.
• SUM (one byte): Checksum
Rev. 2.00 Oct. 21, 2009 Page 1194 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(k)
New Bit-Rate Selection
The boot program will set a new bit rate and return the new bit rate.
This selection should be sent after sending the clock mode selection command.
Command
H'3F
Size
Bit rate
Number of types of
multiplication
Multiplication
ratio 1
Multiplication
ratio 2
Input frequency
SUM
• Command, H'3F, (one byte): Selection of new bit rate
• Size (one byte): The number of bytes that represents the bit rate, input frequency, number of
types of multiplication, and multiplication ratio
• Bit rate (two bytes): New bit rate
One hundredth of the value (e.g. when the value is 19200 bps, it will be 192, which is H'00C0.)
• Input frequency (two bytes): Frequency of the clock input to the boot program
This is valid to the hundredths place and represents the value in MHz multiplied by 100. (E.g.
when the value is 20.00 MHz, it will be 2000, which is H'07D0.)
• Number of types of multiplication (one byte): The number of multiplication to which the
device can be set.
• Multiplication ratio 1 (one byte) : The value of multiplication or division ratios for the main
operating frequency
Multiplication ratio (one byte): The value of the multiplication ratio (e.g. when the clock
frequency is multiplied by four, the multiplication ratio will be H'04.)
Division ratio: The inverse of the division ratio, as a negative number (e.g. when the clock
frequency is divided by two, the value of division ratio will be H'FE. H'FE = D'-2)
• Multiplication ratio 2 (one byte): The value of multiplication or division ratios for the
peripheral frequency
Multiplication ratio (one byte): The value of the multiplication ratio (e.g. when the clock
frequency is multiplied by four, the multiplication ratio will be H'04.)
(Division ratio: The inverse of the division ratio, as a negative number (E.g. when the clock is
divided by two, the value of division ratio will be H'FE. H'FE = D'-2)
• SUM (one byte): Checksum
Response
H'06
• Response, H'06, (one byte): Response to selection of a new bit rate
When it is possible to set the bit rate, the response will be ACK.
Rev. 2.00 Oct. 21, 2009 Page 1195 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Error Response
H'BF
ERROR
• Error response, H'BF, (one byte): Error response to selection of new bit rate
• ERROR: (one byte): Error code
H'11: Sum checking error
H'24: Bit-rate selection error
The rate is not available.
H'25: Error in input frequency
This input frequency is not within the specified range.
H'26: Multiplication-ratio error
The ratio does not match an available ratio.
H'27: Operating frequency error
The frequency is not within the specified range.
(4)
Receive Data Check
The methods for checking of receive data are listed below.
1. Input frequency
The received value of the input frequency is checked to ensure that it is within the range of
minimum to maximum frequencies which matches the clock modes of the specified device.
When the value is out of this range, an input-frequency error is generated.
2. Multiplication ratio
The received value of the multiplication ratio or division ratio is checked to ensure that it
matches the clock modes of the specified device. When the value is out of this range, an inputfrequency error is generated.
3. Operating frequency error
Operating frequency is calculated from the received value of the input frequency and the
multiplication or division ratio. The input frequency is input to the LSI and the LSI is operated
at the operating frequency. The expression is given below.
Operating frequency = Input frequency × Multiplication ratio, or
Operating frequency = Input frequency ÷ Division ratio
The calculated operating frequency should be checked to ensure that it is within the range of
minimum to maximum frequencies which are available with the clock modes of the specified
device. When it is out of this range, an operating frequency error is generated.
Rev. 2.00 Oct. 21, 2009 Page 1196 of 1454
REJ09B0498-0200
Section 25 Flash Memory
4. Bit rate
To facilitate error checking, the value (n) of clock select (CKS) in the serial mode register
(SMR), and the value (N) in the bit rate register (BRR), which are found from the peripheral
operating clock frequency (φ) and bit rate (B), are used to calculate the error rate to ensure that
it is less than 4%. If the error is more than 4%, a bit rate error is generated. The error is
calculated using the following expression:
Error (%) = {[
φ × 106
(N + 1) × B × 64 × 2(2×n − 1)
] − 1} × 100
When the new bit rate is selectable, the rate will be set in the register after sending ACK in
response. The host will send an ACK with the new bit rate for confirmation and the boot program
will response with that rate.
Confirmation
H'06
• Confirmation, H'06, (one byte): Confirmation of a new bit rate
Response
H'06
• Response, H'06, (one byte): Response to confirmation of a new bit rate
The sequence of new bit-rate selection is shown in figure 25.26.
Boot program
Host
Setting a new bit rate
H'06 (ACK)
Waiting for one-bit period
at the specified bit rate
Setting a new bit rate
Setting a new bit rate
H'06 (ACK) with the new bit rate
H'06 (ACK) with the new bit rate
Figure 25.26 New Bit-Rate Selection Sequence
Rev. 2.00 Oct. 21, 2009 Page 1197 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(5)
Transition to Programming/Erasing State
The boot program will transfer the erasing program, and erase the user MATs and user boot MATs
in that order. On completion of this erasure, ACK will be returned and will enter the
programming/erasing state.
The host should select the device code, clock mode, and new bit rate with device selection, clockmode selection, and new bit-rate selection commands, and then send the command for the
transition to programming/erasing state. These procedures should be carried out before sending of
the programming selection command or program data.
Command
H'40
• Command, H'40, (one byte): Transition to programming/erasing state
Response
H'06
• Response, H'06, (one byte): Response to transition to programming/erasing state
The boot program will send ACK when the user MAT and user boot MAT have been erased
by the transferred erasing program.
Error Response
H'C0
H'51
• Error response, H'C0, (one byte): Error response for user boot MAT blank check
• Error code, H'51, (one byte): Erasing error
An error occurred and erasure was not completed.
(6)
Command Error
A command error will occur when a command is undefined, the order of commands is incorrect,
or a command is unacceptable. Issuing a clock-mode selection command before a device selection
or an inquiry command after the transition to programming/erasing state command, are examples.
Error Response
H'80
H'xx
• Error response, H'80, (one byte): Command error
• Command, H'xx, (one byte): Received command
Rev. 2.00 Oct. 21, 2009 Page 1198 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(7)
Command Order
The order for commands in the inquiry selection state is shown below.
1. A supported device inquiry (H'20) should be made to inquire about the supported devices.
2. The device should be selected from among those described by the returned information and set
with a device-selection (H'10) command.
3. A clock-mode inquiry (H'21) should be made to inquire about the supported clock modes.
4. The clock mode should be selected from among those described by the returned information
and set.
5. After selection of the device and clock mode, inquiries for other required information should
be made, such as the multiplication-ratio inquiry (H'22) or operating frequency inquiry (H'23),
which are needed for a new bit-rate selection.
6. A new bit rate should be selected with the new bit-rate selection (H'3F) command, according
to the returned information on multiplication ratios and operating frequencies.
7. After selection of the device and clock mode, the information of the user boot MAT and user
MAT should be made to inquire about the user boot MATs information inquiry (H'24), user
MATs information inquiry (H'25), erased block information inquiry (H'26), and programming
unit inquiry (H'27).
8. After making inquiries and selecting a new bit rate, issue the transition to
programming/erasing state command (H'40). The boot program will then enter the
programming/erasing state.
Rev. 2.00 Oct. 21, 2009 Page 1199 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(8)
Programming/Erasing State
A programming selection command makes the boot program select the programming method, a
128-byte programming command makes it program the memory with data, and an erasing
selection command and block erasing command make it erase the block. Table 25.17 lists the
programming/erasing commands.
Table 25.17 Programming/Erasing Commands
Command
Command Name
H'42
User boot MAT programming selection Transfers the user boot MAT programming
program
H'43
User MAT programming selection
Transfers the user MAT programming
program
H'50
128-byte programming
Programs 128 bytes of data
H'48
Erasing selection
Transfers the erasing program
H'58
Block erasing
Erases a block of data
H'52
Memory read
Reads the contents of memory
H'4A
User boot MAT sum check
Checks the checksum of the user boot MAT
H'4B
User MAT sum check
Checks the checksum of the user MAT
H'4C
User boot MAT blank check
Checks the blank data of the user boot MAT
H'4D
User MAT blank check
Checks the blank data of the user MAT
H'4F
Boot program status inquiry
Inquires into the boot program's status
Rev. 2.00 Oct. 21, 2009 Page 1200 of 1454
REJ09B0498-0200
Description
Section 25 Flash Memory
• Programming
Programming is executed by the programming selection and 128-byte programming
commands.
Firstly, the host should send the programming selection command and select the programming
method and programming MATs. There are two programming selection commands, and
selection is according to the area and method for programming.
1. User boot MAT programming selection
2. User MAT programming selection
After issuing the programming selection command, the host should send the 128-byte
programming command. The 128-byte programming command that follows the selection
command represents the data programmed according to the method specified by the selection
command. When more than 128-byte data is programmed, 128-byte commands should
repeatedly be executed. Sending a 128-byte programming command with H'FFFFFFFF as the
address will stop the programming. On completion of programming, the boot program will
wait for selection of programming or erasing.
Where the sequence of programming operations that is executed includes programming with
another method or of another MAT, the procedure must be repeated from the programming
selection command.
The sequence for the programming selection and 128-byte programming commands is shown
in figure 25.27.
Boot program
Host
Programming selection (H'42, H'43)
Transfer of the
programming
program
ACK
128-byte programming (address, data)
Repeat
Programming
ACK
128-byte programming (H'FFFFFFFF)
ACK
Figure 25.27 Programming Sequence
Rev. 2.00 Oct. 21, 2009 Page 1201 of 1454
REJ09B0498-0200
Section 25 Flash Memory
• Erasure
Erasure is executed by the erasure selection and block erasure commands.
Firstly, erasure is selected by the erasure selection command and the boot program then erases
the specified block. The command should be repeatedly executed if two or more blocks are to
be erased. Sending a block erasure command from the host with the block number H'FF will
stop the erasure operating. On completion of erasing, the boot program will wait for selection
of programming or erasing.
The sequence for the erasure selection and block erasure commands is shown in figure 25.28.
Host
Boot program
Preparation for erasure (H'48)
Transfer of erasure
program
ACK
Erasure (Erasure block number)
Repeat
Erasure
ACK
Erasure (H'FF)
ACK
Figure 25.28 Erasure Sequence
Rev. 2.00 Oct. 21, 2009 Page 1202 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(a)
User Boot MAT Programming Selection
The boot program will transfer a programming program. The data is programmed to the user boot
MATs by the transferred programming program.
Command
H'42
• Command, H'42, (one byte): User boot MAT programming selection
Response
H'06
• Response, H'06, (one byte): Response to user boot MAT programming selection
When the programming program has been transferred, the boot program will return ACK.
Error Response
H'C2
ERROR
• Error response : H'C2 (1 byte): Error response to user boot MAT programming selection
• ERROR : (1 byte): Error code
H'54: Selection processing error (transfer error occurs and processing is not completed)
(b)
User MAT Programming Selection
The boot program will transfer a program for user MAT programming selection. The data is
programmed to the user MATs by the transferred program for programming.
Command
H'43
• Command, H'43, (one byte): User MAT programming selection
Response
H'06
• Response, H'06, (one byte): Response to user MAT programming selection
When the programming program has been transferred, the boot program will return ACK.
Error Response
H'C3
ERROR
• Error response : H'C3 (1 byte): Error response to user MAT programming selection
• ERROR : (1 byte): Error code
H'54: Selection processing error (transfer error occurs and processing is not completed)
Rev. 2.00 Oct. 21, 2009 Page 1203 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(c)
128-Byte Programming
The boot program will use the programming program transferred by the programming selection to
program the user boot MATs or user MATs in response to 128-byte programming.
Command
H'50
Address
Data
···
···
SUM
• Command, H'50, (one byte): 128-byte programming
• Programming Address (four bytes): Start address for programming
Multiple of the size specified in response to the programming unit inquiry
(i.e. H'00, H'01, H'00, H'00 : H'01000000)
• Program data (128 bytes): Data to be programmed
The size is specified in the response to the programming unit inquiry.
• SUM (one byte): Checksum
Response
H'06
• Response, H'06, (one byte): Response to 128-byte programming
On completion of programming, the boot program will return ACK.
Error Response
H'D0
ERROR
• Error response, H'D0, (one byte): Error response for 128-byte programming
• ERROR: (one byte): Error code
H'11: Checksum Error
H'2A: Address error
The address is not in the specified MAT.
H'53: Programming error
A programming error has occurred and programming cannot be continued.
The specified address should match the unit for programming of data. For example, when the
programming is in 128-byte units, the lower eight bits of the address should be H'00 or H'80.
When there are less than 128 bytes of data to be programmed, the host should fill the rest with
H'FF.
Sending the 128-byte programming command with the address of H'FFFFFFFF will stop the
programming operation. The boot program will interpret this as the end of the programming and
wait for selection of programming or erasing.
Rev. 2.00 Oct. 21, 2009 Page 1204 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Command
H'50
Address
SUM
• Command, H'50, (one byte): 128-byte programming
• Programming Address (four bytes): End code is H'FF, H'FF, H'FF, H'FF.
• SUM (one byte): Checksum
Response
H'06
• Response, H'06, (one byte): Response to 128-byte programming
On completion of programming, the boot program will return ACK.
Error Response
H'D0
ERROR
• Error Response, H'D0, (one byte): Error response for 128-byte programming
• ERROR: (one byte): Error code
H'11: Checksum error
H'53: Programming error
An error has occurred in programming and programming cannot be continued.
(d)
Erasure Selection
The boot program will transfer the erasure program. User MAT data is erased by the transferred
erasure program.
Command
H'48
• Command, H'48, (one byte): Erasure selection
Response
H'06
• Response, H'06, (one byte): Response for erasure selection
After the erasure program has been transferred, the boot program will return ACK.
Error Response
H'C8
ERROR
• Error Response, H'C8, (one byte): Error response to erasure selection
• ERROR: (one byte): Error code
H'54: Selection processing error (transfer error occurs and processing is not completed)
Rev. 2.00 Oct. 21, 2009 Page 1205 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(e)
Block Erasure
The boot program will erase the contents of the specified block.
Command
H'58
Size
Block number
SUM
• Command, H'58, (one byte): Erasure
• Size (one byte): The number of bytes that represents the erase block number
This is fixed to 1.
• Block number (one byte): Number of the block to be erased
• SUM (one byte): Checksum
Response
H'06
• Response, H'06, (one byte): Response to Erasure
After erasure has been completed, the boot program will return ACK.
Error Response
H'D8
ERROR
• Error Response, H'D8, (one byte): Response to Erasure
• ERROR (one byte): Error code
H'11: Sum check error
H'29: Block number error
Block number is incorrect.
H'51: Erasure error
An error has occurred during erasure.
On receiving block number H'FF, the boot program will stop erasure and wait for a selection
command.
Command
H'58
Size
Block number
SUM
• Command, H'58, (one byte): Erasure
• Size, (one byte): The number of bytes that represents the block number
This is fixed to 1.
• Block number (one byte): H'FF
Stop code for erasure
• SUM (one byte): Checksum
Response
H'06
• Response, H'06, (one byte): Response to end of erasure (ACK)
When erasure is to be performed after the block number H'FF has been sent, the procedure
should be executed from the erasure selection command.
Rev. 2.00 Oct. 21, 2009 Page 1206 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(f)
Memory Read
The boot program will return the data in the specified address.
Command
H'52
Size
Area
Read size
Read address
SUM
• Command: H'52 (1 byte): Memory read
• Size (1 byte): Amount of data that represents the area, read address, and read size (fixed at 9)
• Area (1 byte)
H'00: User boot MAT
H'01: User MAT
An address error occurs when the area setting is incorrect.
• Read address (4 bytes): Start address to be read from
• Read size (4 bytes): Size of data to be read
• SUM (1 byte): Checksum
Response
H'52
Read size
Data
···
SUM
•
•
•
•
Response: H'52 (1 byte): Response to memory read
Read size (4 bytes): Size of data to be read
Data (n bytes): Data for the read size from the read address
SUM (1 byte): Checksum
Error Response
H'D2
ERROR
• Error response: H'D2 (1 byte): Error response to memory read
• ERROR: (1 byte): Error code
H'11: Sum check error
H'2A: Address error
The read address is not in the MAT.
H'2B: Size error
The read size exceeds the MAT.
Rev. 2.00 Oct. 21, 2009 Page 1207 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(g)
User Boot MAT Sum Check
The boot program will return the byte-by-byte total of the contents of the bytes of the user-boot
program, as a four-byte value.
Command
H'4A
• Command, H'4A, (one byte): Sum check for user-boot program
Response
H'5A
Size
Checksum of user boot program
SUM
• Response, H'5A, (one byte): Response to the sum check of user-boot program
• Size (one byte): The number of bytes that represents the checksum
This is fixed to 4.
• Checksum of user boot program (four bytes): Checksum of user boot MATs
The total of the data is obtained in byte units.
• SUM (one byte): Sum check for data being transmitted
(h)
User MAT Sum Check
The boot program will return the byte-by-byte total of the contents of the bytes of the user
program.
Command
H'4B
• Command, H'4B, (one byte): Sum check for user program
Response
H'5B
Size
Checksum of user program
SUM
• Response, H'5B, (one byte): Response to the sum check of the user program
• Size (one byte): The number of bytes that represents the checksum
This is fixed to 4.
• Checksum of user boot program (four bytes): Checksum of user MATs
The total of the data is obtained in byte units.
• SUM (one byte): Sum check for data being transmitted
Rev. 2.00 Oct. 21, 2009 Page 1208 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(i)
User Boot MAT Blank Check
The boot program will check whether or not all user boot MATs are blank and return the result.
Command
H'4C
• Command, H'4C, (one byte): Blank check for user boot MAT
Response
H'06
• Response, H'06, (one byte): Response to the blank check of user boot MAT
If all user MATs are blank (H'FF), the boot program will return ACK.
Error Response
H'CC
H'52
• Error Response, H'CC, (one byte): Response to blank check for user boot MAT
• Error Code, H'52, (one byte): Erasure has not been completed.
(j)
User MAT Blank Check
The boot program will check whether or not all user MATs are blank and return the result.
Command
H'4D
• Command, H'4D, (one byte): Blank check for user MATs
Response
H'06
• Response, H'06, (one byte): Response to the blank check for user MATs
If the contents of all user MATs are blank (H'FF), the boot program will return ACK.
Error Response
H'CD
H'52
• Error Response, H'CD, (one byte): Error response to the blank check of user MATs.
• Error code, H'52, (one byte): Erasure has not been completed.
Rev. 2.00 Oct. 21, 2009 Page 1209 of 1454
REJ09B0498-0200
Section 25 Flash Memory
(k)
Boot Program State Inquiry
The boot program will return indications of its present state and error condition. This inquiry can
be made in the inquiry/selection state or the programming/erasing state.
Command
H'4F
• Command, H'4F, (one byte): Inquiry regarding boot program's state
Response
•
•
•
•
H'5F
Size
Status
ERROR
SUM
Response, H'5F, (one byte): Response to boot program state inquiry
Size (one byte): The number of bytes. This is fixed to 2.
Status (one byte): State of the boot program
ERROR (one byte): Error status
ERROR = 0 indicates normal operation.
ERROR = 1 indicates error has occurred.
• SUM (one byte): Sum check
Table 25.18 Status Code
Code
Description
H'11
Device selection wait
H'12
Clock mode selection wait
H'13
Bit rate selection wait
H'1F
Programming/erasing state transition wait (bit rate selection is completed)
H'31
Programming state for erasure
H'3F
Programming/erasing selection wait (erasure is completed)
H'4F
Program data receive wait
H'5F
Erase block specification wait (erasure is completed)
Rev. 2.00 Oct. 21, 2009 Page 1210 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Table 25.19 Error Code
Code
Description
H'00
No error
H'11
Sum check error
H'12
Program size error
H'21
Device code mismatch error
H'22
Clock mode mismatch error
H'24
Bit rate selection error
H'25
Input frequency error
H'26
Multiplication ratio error
H'27
Operating frequency error
H'29
Block number error
H'2A
Address error
H'2B
Data length error
H'51
Erasure error
H'52
Erasure incomplete error
H'53
Programming error
H'54
Selection processing error
H'80
Command error
H'FF
Bit-rate-adjustment confirmation error
Rev. 2.00 Oct. 21, 2009 Page 1211 of 1454
REJ09B0498-0200
Section 25 Flash Memory
25.14
Usage Notes
1. The initial state of the product at its shipment is in the erased state. For the product whose
revision of erasing is undefined, we recommend to execute automatic erasure for checking the
initial state (erased state) and compensating.
2. For the PROM programmer suitable for programmer mode in this LSI and its program version,
refer to the instruction manual of the socket adapter.
3. If the socket, socket adapter, or product index of the PROM programmer do not match the
specifications, too much current flows and the product may be damaged.
4. Use a PROM programmer that supports the device with 1-Mbyte on-chip flash memory and
3.3-V programming voltage. Use only the specified socket adapter.
5. Do not turn off the Vcc power supply nor remove the chip from the PROM programmer during
programming/erasure in which a high voltage is applied to the flash memory. Doing so may
damage the flash memory permanently. If a reset is input, the reset must be released after the
reset input period of at least 100ms.
6. The flash memory is not accessible until FKEY is cleared after programming/erasure starts. If
the operating mode is changed and this LSI is restarted by a reset immediately after
programming/erasure has finished, secure the reset input period (period of RES = 0) of at least
100μs. Transition to the reset state during programming/erasure is inhibited. If a reset is input,
the reset must be released after the reset input period of at least 100μs.
7. At powering on the Vcc power supply, fix the RES pin to low and set the flash memory to
hardware protection state. This power-on procedure must also be satisfied at a power-off and
power-on caused by a power failure and other factors.
8. In on-board programming mode or programmer mode, programming of the 128-byte
programming-unit block must be performed only once. Perform programming in the state
where the programming-unit block is fully erased.
9. When the chip is to be reprogrammed with the programmer after execution of programming or
erasure in on-board programming mode, it is recommended that automatic programming be
performed after execution of automatic erasure.
10. To program the flash memory, the program data and program must be allocated to addresses
which are higher than those of the external interrupt vector table and H'FF must be written to
all the system reserved areas in the exception handling vector table.
11. The programming program that includes the initialization routine and the erasing program that
includes the initialization routine are each 4 Kbytes or less. Accordingly, when the CPU clock
frequency is 35 MHz, the download for each program takes approximately 60 μs at the
maximum.
Rev. 2.00 Oct. 21, 2009 Page 1212 of 1454
REJ09B0498-0200
Section 25 Flash Memory
12. A programming/erasing program for the flash memory used in a conventional F-ZTAT H8,
H8S microcomputer which does not support download of the on-chip program by setting the
SCO bit in FCCS to 1 cannot run in this LSI. Be sure to download the on-chip program to
execute programming/erasure of the flash memory in this F-ZTAT H8SX microcomputer.
13. Unlike a conventional F-ZTAT H8 or H8S microcomputers, measures against a program crash
are not taken by WDT while programming/erasing and downloading a programming/erasing
program. When needed, measures should be taken by user. A periodic interrupt generated by
the WDT can be used as the measures, as an example. In this case, the interrupt generation
period should take into consideration time to program/erase the flash memory.
14. When downloading the programming/erasing program, do not clear the SCO bit in FCCS to 0
immediately after setting it to 1. Otherwise, download cannot be performed normally.
Immediately after executing the instruction to set the SCO bit to 1, dummy read of the FCCS
must be executed twice.
15. The contents of general registers ER0 and ER1 are not saved during download of an on-chip
program, initialization, programming, or erasure. When needed, save the general registers
before a download request or before execution of initialization, programming, or erasure using
the procedure program.
Rev. 2.00 Oct. 21, 2009 Page 1213 of 1454
REJ09B0498-0200
Section 25 Flash Memory
Rev. 2.00 Oct. 21, 2009 Page 1214 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
Section 26 Boundary Scan
This LSI has boundary scan function, which is a serial I/O interface based on the JTAG (Joint Test
Action Group, IEEE Std.1149.1 and IEEE Standard Test Access Port and Boundary-Scan
Architecture).
26.1
Features
• Boundary scan valid single chip mode when the EMLE pin= 0 in MCU operating mode 3
• P62, P63, P64, P65, and WDTOVF are pins only for boundary scan when boundary scan is
valid
• Six test modes:
BYPASS mode
EXTEST mode
SAMPLE/PRELOAD mode
CLAMP mode
HIGHZ mode
IDCODE mode
Rev. 2.00 Oct. 21, 2009 Page 1215 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
26.2
Block Diagram of Boundary Scan Function
Figure 26.1 shows the block diagram of the boundary scan function.
TDO
Shift register
JTBPR
JTBSR
TDI
JTIR
JTDIR
MUX
TCK
TAP controller
TMS
Decoder
TRST
[Legend]
JTBPR:
JTBSR:
JTIR:
JTDIR:
Bypass register
Boundary scan register
Instruction register
ID register
Figure 26.1 Block Diagram of Boundary Scan Function
26.3
Input/Output Pins
Table 26.1 shows the I/O pins used in the boundary scan function.
Table 26.1 Pin Configuration
Pin Name
I/O
Description
TCK
Input
Test clock input pin
Clock signal for boundary scan. Input the clock the duty cycle of which is 50
percent when boundary scan function is used.
TMS
Input
Test mode select pin
TDI
Input
Test data input pin
TDO
Output
Test data output pin
TRST
Input
Test reset input pin
Rev. 2.00 Oct. 21, 2009 Page 1216 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
26.4
Register Descriptions
Boundary scan has the following four registers. These registers cannot be accessed from the CPU.
•
•
•
•
Introduction register (JTIR)
Bypass register (JTBPR)
Boundary scan register (JTBSR)
IDCODE register (JTIDR)
Instructions can be input to the instruction register (JTIR) via the test data input pin (TDI) by
serial transfer. The bypass register (JTBPR), which is a 1-bit register, is connected between the
TDI and TDO pins in BYPASS mode. The boundary scan register (JTBSR), which is a JTBSR-bit
register (see table 26.4), is connected between the TDI and TDO pins when test data are being
shifted in. None of the registers is accessible from the CPU.
Table 26.2 shows the availability of serial transfer for the registers.
Table 26.2 Serial Transfers for Registers
Register Abbreviation
Serial Input
Serial Output
JTIR
Available
Not available
JTBPR
Available
Available
JTBSR
Available
Available
JTID
Not available
Available
Rev. 2.00 Oct. 21, 2009 Page 1217 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
26.4.1
Instruction Register (JTIR)
JTIR is a 16-bit register. JTAG instructions can be transferred to JTIR by serial input from the
TDI pin. JTIR is initialized when the TRST signal is low level, when the TAP controller is in the
Test-Logic-Reset state, and when this LSI is placed in hardware standby mode. JTIR is not
initialized by a reset or entry to software standby mode. Instructions must be serially transferred in
4-bit units. When an instruction with more than 4 bits is being transferred, the last four bits of the
serial data are stored in JTIR.
Bit
Bit Name
15
14
13
12
11
10
9
8
TS3
TS2
TS1
TS0
⎯
⎯
⎯
⎯
Initial Value
0
0
0
0
0
0
0
0
R/W
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Initial Value
0
0
0
0
0
0
0
0
R/W
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
Bit
Bit Name
15 to 12 TS[3:0]
Initial
Value
R/W
Descriptions
All 0
R/W
Test Bit Set
All 0
R
Specify an instruction as shown in table 26.3.
11 to 0
⎯
Reserved
These bits are always read as 0. The write value should
always 0.
Rev. 2.00 Oct. 21, 2009 Page 1218 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
Table 26.3 Boundary Scan Instructions
TS3
TS2
TS1
TS0
Instruction
0
0
0
0
EXTEST
0
0
0
1
IDCODE (initial value)
0
0
1
0
CLAMP
0
0
1
1
HIGHZ
0
1
0
0
SAMPLE/PRELOAD
0
1
0
1
Reserved
0
1
1
0
Reserved
0
1
1
1
Reserved
1
0
0
0
Reserved
1
0
0
1
Reserved
1
0
1
0
Reserved
1
0
1
1
Reserved
1
1
0
0
Reserved
1
1
0
1
Reserved
1
1
1
0
Reserved
1
1
1
1
BYPASS
26.4.2
Bypass Register (JTBPR)
JTBPR is a 1-bit register and is connected between the TDI and TDO pins when JTIR is set to
BYPASS mode. JTBPR cannot be read from or written to by the CPU.
26.4.3
Boundary Scan Register (JTBSR)
JTBSR is a shift register to control the external input and output pins of this LSI and is distributed
across the pads. The initial values are undefined. JTBSR cannot be accessed by the CPU. The
EXTEST, SAMPLE/PRELOAD, CLAMP, and HIGHZ instructions are issued to apply JTBSR in
boundary-scan testing conformant to the JTAG standard.
Table 26.4 shows the correspondence between the JTBSR bits and the pins of this LSI.
Rev. 2.00 Oct. 21, 2009 Page 1219 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
Table 26.4 Relationship between Pins and JTBSR Bits
From TDI
Pin No
Pin No
LQFP-144 LGA-145
Pin Name Input/Output
3
PB3
5
C1
C2
PB7
Bit Name
LQFP-144 LGA-145
Pin Name Input/Output
15
PF3
Input
295
Input
262
Output enable
294
Output enable
261
Output
293
Output
260
Input
292
Input
259
17
F4
Bit Name
F2
PF2
Output enable
291
Output enable
258
Output
290
Output
257
Input
256
7
D1
MD2
Input
289
8
D3
PM0
Input
288
Output enable
255
Output enable
287
Output
254
Output
286
Input
253
9
10
11
12
13
14
D2
E1
E4
E3
E2
F1
PM1
PM2
PF7
PF6
PF5
PF4
19
G1
H4
PF1
PF0
Input
284
Output enable
252
Output enable
283
Output
251
Output
282
Input
250
Input
280
Output enable
249
Output enable
279
Output
248
Output
278
Input
247
20
21
G3
G2
PE7
PE6
Input
274
Output enable
246
Output enable
273
Output
245
Output
272
Input
244
Input
271
Output enable
243
Output enable
270
Output
242
Output
269
Input
241
22
24
H1
H2
PE5
PE4
Input
268
Output enable
240
Output enable
267
Output
239
Output
266
Input
238
Input
265
Output enable
237
Output enable
264
Output
236
Output
263
Rev. 2.00 Oct. 21, 2009 Page 1220 of 1454
REJ09B0498-0200
18
26
H3
PE3
Section 26 Boundary Scan
Pin No
Pin No
LQFP-144 LGA-145
Pin Name Input/Output
Bit Name
LQFP-144 LGA-145
Pin Name Input/Output
Bit Name
27
PE2
Input
235
38
PD0
Input
205
Output enable
234
Output enable
204
Output
233
Output
203
28
29
30
31
33
34
35
36
37
J4
J2
K1
J3
K4
K2
K3
L1
M1
M2
PE1
PE0
PD7
PD6
PD5
PD4
PD3
PD2
PD1
40
N1
Input
232
Input
201
Output enable
231
Output enable
200
Output
230
Output
199
Input
229
Input
197
Output enable
228
Output enable
196
Output
227
Output
195
Input
226
46
L4
VBUS
Input
194
Output enable
225
47
L5
MD_CLK
Input
193
Output
224
49
M6
P20
Input
183
Input
223
Output enable
182
Output enable
222
Output
181
Output
221
Input
180
41
51
N2
N3
K6
PM3
PM4
P21
Input
220
Output enable
179
Output enable
219
Output
178
Output
218
Input
177
Input
217
Output enable
176
Output enable
216
Output
175
Output
215
Input
174
52
53
N6
M7
P22
P23
Input
214
Output enable
173
Output enable
213
Output
172
Output
212
Input
171
Input
211
Output enable
170
Output enable
210
Output
169
Output
209
Input
168
54
55
L6
K7
P24
P25
Input
208
Output enable
167
Output enable
207
Output
166
Output
206
Rev. 2.00 Oct. 21, 2009 Page 1221 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
Pin No
Pin No
LQFP-144 LGA-145
Pin Name Input/Output
Bit Name
LQFP-144 LGA-145
Pin Name Input/Output
Bit Name
56
P30
Input
165
68
PH3
Input
134
Output enable
164
Output enable
133
Output
163
Output
132
57
58
59
60
N7
M8
L7
K8
N8
P31
P32
P26
P27
73
N10
Input
162
Input
131
Output enable
161
Output enable
130
Output
160
Output
129
Input
159
Input
128
Output enable
158
Output enable
127
Output
126
Input
125
70
M12
M11
PH7
PH4
Output
157
Input
156
Output enable
155
Output enable
124
Output
154
Output
123
Input
153
Input
122
71
72
N11
N12
PH5
PH6
Output enable
152
Output enable
121
Output
151
Output
120
Input
119
61
L9
NMI
Input
150
62
L8
P33
Input
149
Output enable
118
Output enable
148
Output
117
Output
147
Input
116
63
65
66
67
K9
M9
L10
K10
P34
PH0
PH1
PH2
77
L13
L11
PI1
PI2
Input
146
Output enable
115
Output enable
145
Output
114
Output
144
Input
113
Input
143
Output enable
112
Output enable
142
Output
111
Output
141
Input
110
78
75
L12
M13
PI3
PI0
Input
140
Output enable
109
Output enable
139
Output
108
Output
138
Input
107
Input
137
Output enable
106
Output enable
136
Output
105
Output
135
Rev. 2.00 Oct. 21, 2009 Page 1222 of 1454
REJ09B0498-0200
76
80
K11
PI4
Section 26 Boundary Scan
Pin No
Pin No
LQFP-144 LGA-145
Pin Name Input/Output
Bit Name
LQFP-144 LGA-145
Pin Name Input/Output
Bit Name
81
PI5
Input
104
101
P17
Input
68
Output enable
103
Output enable
67
Output
102
Output
66
83
82
84
85
86
87
93
94
100
K12
J10
J13
J11
H11
J12
G11
G10
F11
E11
PI7
PI6
P10
P11
P12
P13
P14
P15
P16
105
E10
Input
101
Input
65
Output enable
100
Output enable
64
Output
99
Output
63
Input
98
Input
62
Output enable
97
Output enable
61
Output
96
Output
60
Input
95
Input
59
Output enable
94
Output enable
58
Output
93
Output
57
Input
92
Input
56
104
107
106
C12
D11
B13
C13
P36
P35
P60
P37
Output enable
91
Output enable
55
Output
90
Output
54
Input
89
Input
53
Output enable
88
Output enable
52
Output
87
Output
51
108
A13
P61
Input
86
115
D10
MD0
Input
50
Output enable
85
116
C10
PC2
Input
49
Output
84
Output enable
48
Input
77
Output
47
Output enable
76
Input
46
Output
75
Output enable
45
117
B10
PC3
Input
74
Output
44
Output enable
73
129
B6
MD1
Input
43
Output
72
130
C7
PB4
Input
42
Input
71
Output enable
41
Output enable
70
Output
40
Output
69
Rev. 2.00 Oct. 21, 2009 Page 1223 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
Pin No
Pin No
LQFP-144 LGA-145
Pin Name Input/Output
Bit Name
LQFP-144 LGA-145
Pin Name Input/Output
Bit Name
131
PB5
Input
39
139
PA5
Input
17
Output enable
38
Output enable
16
Output
37
Output
15
132
C6
A6
PB6
140
C5
Input
36
Input
14
Output enable
35
Output enable
13
Output
34
Output
12
Input
11
B5
MD3
Input
33
134
D6
PA0
Input
32
Output enable
10
Output enable
31
Output
9
136
137
138
A5
B4
D5
A4
PA1
PA2
PA3
PA4
30
Input
8
Input
29
Output enable
7
Output enable
28
Output
6
Output
27
Input
5
Input
26
Output enable
4
Output enable
25
Output
3
1
2
B2
PA7
Output
A1
PB1
24
Input
2
Input
23
Output enable
1
Output enable
22
Output
0
Output
21
Input
20
Output enable
19
Output
18
to TDO
B1
PB0
Output
Rev. 2.00 Oct. 21, 2009 Page 1224 of 1454
REJ09B0498-0200
144
A2
PA6
133
135
142
C4
PB2
Section 26 Boundary Scan
26.4.4
IDCODE Register (JTID)
JTID is a 32-bit register. JTID data is output from the TDO pin when the IDCODE instruction has
been executed. Data cannot be written to JTID from the TDI pin.
Bit
31
Initial Value
R/W
Bit
Initial Value
Bit
29
28
27
26
25
24
23
22
21
20
19
18
17
16
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
15
14
13
12
11
10
DID15 DID14 DID13 DID12 DID11 DID10
Bit Name
R/W
30
DID31 DID30 DID29 DID28 DID27 DID26 DID25 DID24 DID23 DID22 DID21 DID20 DID19 DID18 DID17 DID16
Bit Name
9
8
7
6
5
4
3
2
1
0
DID9
DID8
DID7
DID6
DID5
DID4
DID3
DID2
DID1
DID0
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
31 to 0 DID31 to
DID0
Initial Value R/W
Descriptions
H'0807F447 ⎯
JTID is a register the value showing the decide IDCODE
is fixed.
Rev. 2.00 Oct. 21, 2009 Page 1225 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
26.5
Operations
The boundary scan functionality is valid when the EMLE pin is set t o 0 and this LSI is in MCU
operation mode 3.
26.5.1
TAP Controller
Figure 26.2 shows the state transition diagram of the TAP controller.
1
Test -logic-reset
0
Run-test/idle
0
1
1
1
Select-DR
Select-IR
0
0
1
1
Capture-DR
Capture-IR
0
0
Shift-DR
0
Shift-IR
0
1
1
1
1
Exit1-DR
Exit1-IR
0
0
Pause-DR
1
0
Pause-IR
1
0
0
Exit2-DR
Exit2-IR
1
1
Update-DR
Update-IR
1
1
0
0
Figure 26.2 State Transitions of the TAP Controller
Rev. 2.00 Oct. 21, 2009 Page 1226 of 1454
REJ09B0498-0200
0
Section 26 Boundary Scan
26.5.2
Commands
BYPASS (Instruction Code: B'1111): The BYPASS instruction is an instruction that drives the
bypass register (JTBPR). This instruction shortens the shift path, facilitating the transfer of serial
data to other LSIs on a printed-circuit board at higher speeds. While this instruction is being
executed, the test circuit has no effect on the system circuits.
The bypass register (JTBPR) is connected between the TDI and TDO pins. Bypass operation is
initiated from shift-DR operation. The TDO is at 0 in the first clock cycle in the shift-DR state; in
the subsequent clock cycles, the TDI signal is output on the TDO pin.
EXTEST (Instruction Code: B'0000): The EXTEST instruction is used to test external circuits
when this LSI is installed on the printed circuit board. If this instruction is executed, output pins
are used to output test data (specified by the SAMPLE/PRELOAD instruction) from the boundary
scan register to the print circuit board, and input pins are used to input test result.
SAMPLE/PRELOAD (Instruction Code: B'0100): The SAMPLE/PRELOAD instruction is
used to input data from the LSI internal circuits to the boundary scan register, output data from
scan path, and reload the data to the scan path. While this instruction is executed, input signals are
directly input to the LSI and output signals are also directly output to the external circuits. The LSI
system circuit is not affected by this function.
In SAMPLE operation, the boundary scan register latches the snap shot of data transferred from
input pins to internal circuit or data transferred from internal circuit to output pins. The latched
data is read from the scan path. The scan register latches the snap data at the rising edge of the
TCK in Capture-DR state. The scan register latches snap shot without affecting the LSI normal
operation.
In PRELOAD operation, initial value is written from the scan path to the parallel output latch of
the boundary scan register prior to the EXTEST instruction execution. If the EXTEST is executed
without executing this PRELOAD operation, undefined values are output from the beginning to
the end (transfer to the output latch) of the EXTEST sequence. (In EXTEST instruction, output
parallel latches are always output to the output pins.)
IDCODE (Instruction Code: B'0001): When the IDCODE instruction is selected, IDCODE
register value is output to the TDO in Shift-DR state of the TAP controller. In this case, IDCODE
register value is output from the LSB. During this instruction execution, test circuit does not affect
the system circuit. INSTR is initialized by the IDCODE instruction in Test-Logic-Reset state of
the TAP controller.
Rev. 2.00 Oct. 21, 2009 Page 1227 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
CLAMP (Instruction Code: B'0010): When the CLAMP instruction is selected, output pins
output the boundary scan register value which was specified by the SAMPLE/PRELOAD
instruction in advance. While the CLAMP instruction is selected, the status of boundary scan
register is maintained regardless of the TAP controller state. BYPASS is connected between TDI
and TDO, the same operation as BYPASS instruction can be achieved.
This instruction connects the bypass register (JTBPR) between the TDI and TDO pins, leading to
the same operation as when BYPASS mode has been selected.
HIGHZ (Instruction Code: B'0011): When the HIGHZ instruction is selected, all output pins
enter high-impedance state. While the HIGHZ instruction is selected, the status of boundary scan
register is maintained regardless of the state of the TAP controller.
BYPASS is connected between TDI and TDO pins, leading to the same operation as when the
BYPASS instruction has been selected.
Rev. 2.00 Oct. 21, 2009 Page 1228 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
26.6
Usage Notes
1. In serial transfer, data are input or output in LSB order (see figure 26.3).
From TDI pin
JTIR and JTIDR
Bit 31
Bit 30
Shift
register
.
.
.
.
.
.
Serial data
input/output
in LSB order
Bit 1
Bit 0
To TDO pin
Notes: Serial data output from JTIR to TDO is not possible.
Serial data input from TDI to JTIDR is not possible.
Figure 26.3 Serial Data Input/Output
2. If a pin with open-drain function is SAMPLEed while its open-drain function is enabled and
while the corresponding OUT register is set to 1, the corresponding Control register is cleared
to 0 (the pin status is Hi-Z). If the pin is SAMPLEed while the corresponding OUT register is
cleared to 0, the corresponding Control register is 1 (the pin status is 0)
3. Pins of the boundary scan (TCK, TDI, TMS, and TRST) have to be pulled up by pull-up
resistors.
4. Power supply pins (Vcc, VcL, Vss, AVcc, AVss, Vref, PLLVcc, PLLVss, DrVcc, and DrVss)
cannot be boundary-scanned.
5. Clock pins (EXTAL and XTAL) cannot be boundary-scanned.
6. Reset and standby signals (RES and STBY) cannot be boundary-scanned.
7. Boundary scan pins (TCK, TMS, TRST, TDI, and TDO) cannot be boundary-scanned.
8. The boundary scan function is not available when this LSI is in the following states.
(1) Reset state
(2) Hardware standby mode, software standby mode, and deep software standby mode
Rev. 2.00 Oct. 21, 2009 Page 1229 of 1454
REJ09B0498-0200
Section 26 Boundary Scan
Rev. 2.00 Oct. 21, 2009 Page 1230 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
Section 27 Clock Pulse Generator
This LSI has an on-chip clock pulse generator (CPG) that generates the system clock (Iφ),
peripheral module clock (Pφ), external bus clock (Bφ), 32K timer clock (SUBCK), and USB clock
(cku).
The clock pulse generator consists of a main clock oscillator, frequency divider, PLL (phaselocked loop) circuit, subclock oscillator, waveform generation circuit, and selector. Figure 27.1 is
a block diagram of the clock pulse generator.
The frequency divider, PLL circuit, and selector can change the clock frequency. Software
changes the frequency through the setting of the system clock control register (SCKCR) and
subclock control register (SUBCKCR).
This LSI supports five clocks: a system clock provided to the CPU and bus masters, a peripheral
module clock provided to the peripheral modules, an external bus clock provided to the external
bus, a 32K timer clock, and a USB clock provided to the USB module. Frequencies of the
peripheral module clock, the external bus clock, and the system clock can be set independently,
although the peripheral module clock and the external bus clock operate with the frequency lower
than the system clock frequency.
The system clock, peripheral module clock, and external bus clock can be uniformly set to the
32.768 kHz subclock.
The USB module requires the 48-MHz clock. Set the external clock frequency and the MD_CLK
pin so that the USB clock (cku) frequency becomes 48 MHz.
Note that the MD_CLK pin setting also changes the frequencies of the peripheral module clock,
the external bus clock, and the system clock.
Rev. 2.00 Oct. 21, 2009 Page 1231 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
SCKCR
SUBCKCR
ICK2 to ICK0
CK32K
cks
Selector
System clock (Iφ)
(to the CPU and
bus masters)
SCKCR
MD_CLK
SUBCKCR
XTAL
Main clock
oscillator
Divider
PLL circuit
PCK2 to PCK0
CK32K
EXTAL × 4 (2)*
× 2 (1)
× 1 (1/2)
× 1/2 (setting prohibited)
ckm
Selector
EXTAL
Peripheral module
clock (Pφ)
(to peripheral modules)
SCKCR
SUBCKCR
BCK2 to BCK0
CK32K
ckb
Selector
OSC1
Waveform
generation
circuit
Subclock
oscillator
OSC2
External bus clock (Bφ)
(to the Bφ and SDφ pins)
Subclock
32K timer clock (SUBCK)
(to TM32K)
EXTAL × 4 (3)
cku
USB clock (cku)
(to USB)
Note: * Values in parentheses are setting values when MD_CLK = 1.
Figure 27.1 Block Diagram of Clock Pulse Generator
Table 27.1 Selection of Clock Pulse Generator
MD_CLK
EXTAL Input
Clock Frequencies
Iφ/Pφ/Bφ
USB Clock (cku)
0
8 MHz to 18 MHz
EXTAL ×4, ×2, ×1, ×1/2
EXTAL ×4
1
16 MHz
EXTAL ×2, ×1, ×1/2
EXTAL ×3
Rev. 2.00 Oct. 21, 2009 Page 1232 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
27.1
Register Description
The clock pulse generator has the following registers.
• System clock control register (SCKCR)
• Subclock control register (SUBCKCR)
27.1.1
System Clock Control Register (SCKCR)
SCKCR controls Bφ output control and frequencies of the system, peripheral module, and external
bus clocks.
Bit
15
14
13
12
11
10
9
8
PSTOP1
PSTOP0
⎯
⎯
⎯
ICK2
ICK1
ICK0
0
0
0
0
0
0
1
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
PCK2
PCK1
PCK0
⎯
BCK2
BCK1
BCK0
Initial Value
0
0
1
0
0
0
1
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit Name
Initial Value
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Description
15
PSTOP1
0
R/W
Bφ Clock Output Enable
Controls φ output on PA7.
•
Normal operation
0: φ output
1: Fixed high
14
PSTOP0
0
R/W
φ Clock Output Enable
Controls φ output (SDφ) on PB7.
•
Normal operation
0: φ output
1: Fixed high
Rev. 2.00 Oct. 21, 2009 Page 1233 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
Bit
Bit Name
13 to 11 ⎯
Initial
Value
R/W
Description
All 0
R/W
Reserved
Although these bits are readable/writable, only 0 should
be written to.
10
ICK2
0
R/W
System Clock (Iφ) Select
9
ICK1
1
R/W
8
ICK0
0
R/W
These bits select the frequency of the system clock
provided to the CPU, EXDMAC, DMAC, and DTC. The
ratio to the input clock is as follows:
ICK (2:0) MD_CLK = 0
MD_CLK = 1
000:
×4
×2
001:
×2
×1
010:
×1
× 1/2
011:
× 1/2
Setting prohibited
1XX:
Setting prohibited
The frequencies of the peripheral module clock and
external bus clock change to the same frequency as the
system clock if the frequency of the system clock is
lower than that of the two clocks.
7
⎯
0
R/W
Reserved
Although this bit is readable/writable, only 0 should be
written to.
6
PCK2
0
R/W
Peripheral Module Clock (Pφ) Select
5
PCK1
1
R/W
4
PCK0
0
R/W
These bits select the frequency of the peripheral
module clock. The ratio to the input clock is as follows:
PCK (2:0) MD_CLK = 0
MD_CLK = 1
000:
×4
×2
001:
×2
×1
010:
×1
× 1/2
× 1/2
Setting prohibited
011:
1XX:
Setting prohibited
The frequency of the peripheral module clock should be
lower than that of the system clock. Though these bits
can be set so as to make the frequency of the
peripheral module clock higher than that of the system
clock, the clocks will have the same frequency in reality.
Rev. 2.00 Oct. 21, 2009 Page 1234 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
Bit
Bit Name
Initial
Value
R/W
Description
3
⎯
0
R/W
Reserved
Although this bit is readable/writable, only 0 should be
written to.
2
BCK2
0
R/W
External Bus Clock (Bφ) Select
1
BCK1
1
R/W
0
BCK0
0
R/W
These bits select the frequency of the external bus
clock. The ratio to the input clock is as follows:
BCK (2:0) MD_CLK = 0
MD_CLK = 1
000:
×4
×2
001:
×2
×1
010:
×1
× 1/2
× 1/2
Setting prohibited
011:
1XX:
Setting prohibited
The frequency of the external bus clock should be lower
than that of the system clock. Though these bits can be
set so as to make the frequency of the external bus
clock higher than that of the system clock, the clocks
will have the same frequency in reality.
Note:
X: Don't care
27.1.2
Subclock Control Register (SUBCKCR)
SUBCKCR stops the main clock oscillator, selects the operating clock of the system clock, and
selects the operating clock after a transition from software standby mode.
Bit
7
6
5
4
3
2
1
0
Bit Name
⎯
⎯
⎯
⎯
⎯
EXSTP
WAKE32K
CK32K
Initial Value
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 1235 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
Bit
Bit Name
Initial
Value
R/W
Description
7
⎯
0
R/W
Reserved
6
⎯
0
R/W
5
⎯
0
R/W
These bits are always read as 0. The write value should
always be 0.
4
⎯
0
R/W
3
⎯
0
R/W
2
EXSTP
0
R/W
Main Clock Oscillation Stop
0: The main clock oscillator and PLL remain active
during subclock operation, but are stopped in
standby mode.
1: The main clock oscillator and PLL are stopped during
subclock operation.
1
WAKE32K
0
R/W
Wakeup Clock Select
Selects the operating clock for use as the system clock
after the transition from the subclock operation in
software standby mode has been initiated by an
interrupt.
0: On leaving software standby mode, the main clock is
the operating clock.
1: On leaving software standby mode, the subclock is
the operating clock. This setting is valid when bit 0
(CK32K) is set to 1.
0
CK32K
0
R/W
Subclock Select
0: The system clock (Iφ), peripheral module clock (Pφ),
and external bus clock (Bφ) operate on the main
clock.
1: The system clock (Iφ), peripheral module clock (Pφ),
and external bus clock (Bφ) operate on the subclock.
When the OSC32STP bit in TCR32K is 1, 1 cannot be
written to this bit. This bit is cleared to 0 when clearing
software standby mode while the value of WAKE32K
is 0. Dummy read of this bit must be performed twice
immediately after this bit is written to.
Rev. 2.00 Oct. 21, 2009 Page 1236 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
27.2
Oscillator
Clock pulses can be supplied by connecting a crystal resonator, or by input of an external clock.
27.2.1
Connecting Crystal Resonator
A crystal resonator can be connected as the example in figure 27.2. Select the damping resistance
Rd according to table 27.2. An AT-cut parallel-resonance type should be used.
When providing the clock from the crystal resonator, the frequency should be in the range of 8 to
18 MHz.
CL1
EXTAL
XTAL
Rd
CL2
CL1 = CL2 = 10 pF to 22 pF
Figure 27.2 Connection of Crystal Resonator (Example)
Table 27.2 Damping Resistance Value
Frequency (MHz)
8
12
16
18
Rd (Ω)
200
0
0
0
Figure 27.3 shows an equivalent circuit of the crystal resonator. Use a crystal resonator that has
the characteristics shown in table 27.3.
CL
L
Rs
XTAL
EXTAL
C0
AT-cut parallel-resonance type
Figure 27.3 Crystal Resonator Equivalent Circuit
Rev. 2.00 Oct. 21, 2009 Page 1237 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
Table 27.3 Crystal Resonator Characteristics
Frequency (MHz)
8
12
RS Max. (Ω)
80
60
C0 Max. (pF)
27.2.2
16
18
50
40
7
External Clock Input
An external clock signal can be input as the examples in figure 27.4. When the XTAL pin is left
open, make the parasitic capacitance less than 10 pF. When the counter clock is input to the XTAL
pin, put the external clock in high level during standby mode.
EXTAL
External clock input
XTAL
Open
(a) XTAL pin left open
EXTAL
External clock input
XTAL
(b) Counter clock input on XTAL pin
Figure 27.4 External Clock Input (Examples)
tEXH
tEXL
Vcc × 0.5
EXTAL
tEXr
tEXf
Figure 27.5 External Clock Input Timing
Rev. 2.00 Oct. 21, 2009 Page 1238 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
27.3
PLL Circuit
The PLL circuit has the function of multiplying the frequency of the clock from the oscillator by a
factor of 4. The frequency multiplication rate is fixed. The phase difference is controlled so that
the timing of the rising edge of the internal clock is the same as that of the EXTAL pin signal.
27.4
Frequency Divider
The frequency divider divides the PLL clock to generate a 1/2, 1/4, or 1/8 clock. After the bits
ICK2 to ICK0, PCK 2 to PCK0, and BCK2 to BCK0 are updated, this LSI operates with the
updated frequency.
27.5
Subclock Oscillator
27.5.1
Connecting 32.768 kHz Crystal Resonator
To supply a clock to the subclock oscillator, connect a 32.768-kHz crystal resonator, as shown in
figure 27.6. The usage notes given in section 27.6.3, Notes on Board Design, apply to the
connection of this crystal resonator.
C1
OSC1
C2
OSC2
C1 = C2 = 15 pF (typ.)
Note: C1 and C2 are reference values that include the floating
capacitance of the board.
Figure 27.6 Connection Example of 32.768-kHz Crystal Resonator
Rev. 2.00 Oct. 21, 2009 Page 1239 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
Figure 27.7 shows an equivalent circuit for the 32.768-kHz crystal resonator.
Cs
Ls
Rs
OSC1
OSC2
Co
Co = 1.5 pF (typ.)
Rs = 14 kΩ (typ.)
fw = 32.768 kHz
Figure 27.7 Equivalent Circuit for 32.768-kHz Crystal Resonator
27.5.2
Handling of Pins when the Subclock is Not to be Used
If the subclock is not required, connect the OSC1 pin to Vss and leave the OSC2 pin open, as
shown in figure 27.8.
OSC1
OSC2
Open
Figure 27.8 Pin Handling when Subclock is not Used
Rev. 2.00 Oct. 21, 2009 Page 1240 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
27.6
Usage Notes
27.6.1
Notes on Clock Pulse Generator
1. The following points should be noted since the frequency of φ (Iφ: system clock, Pφ:
peripheral module clock, Bφ: external bus clock) supplied to each module changes according
to the setting of SCKCR.
Select a clock division ratio that is within the operation guaranteed range of clock cycle time
tcyc shown in the AC timing of electrical characteristics.
Since If min = 8MHz, Pf min = 8MHz, Bf min = 8MHz,
I f max = 50 MHz, P f max = 35 MHz, and Bf max = 50 MHz,
the frequencies should satisfy the conditions 8 MHz £ If £ 50 MHz, 8 MHz £ Pf £ 35 MHz,
and 8 MHz £ Bf £ 50 MHz.
2. All the on-chip peripheral modules (except for the EXDMAC, DMAC, and DTC) operate on
the Pφ. Note therefore that the time processing of modules such as a timer and SCI differs
before and after changing the clock division ratio.
In addition, wait time for clearing software standby mode differs by changing the clock
division ratio. For details, see section 28.7.3, Setting Oscillation Settling Time after Exit from
Software Standby Mode.
3. The relationship among the system clock, peripheral module clock, and external bus clock is Iφ
≥ Pφ and Iφ ≥ Bφ. In addition, the system clock setting has the highest priority. Accordingly,
Pφ or Bφ may have the frequency set by bits ICK2 to ICK0 regardless of the settings of bits
PCK2 to PCK0 or BCK2 to BCK0.f
4. Note that the frequency of φ will be changed in the middle of a bus cycle when setting SCKCR
or SUBCKCR while executing the external bus cycle with the write-data-buffer function and
EXDMAC.
5. Figure 27.9 shows the clock modification timing. After a value is written to SCKCR, this LSI
waits for the current bus cycle to complete. After the current bus cycle completes, each clock
frequency will be modified within one cycle (worst case) of the external input clock φ.
Rev. 2.00 Oct. 21, 2009 Page 1241 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
One cycle (worst case)
after the bus cycle completion
External
clock
Iφ
Bus master
CPU
CPU
Operating clock
specified in SCKCR
CPU
Operating clock changed
Figure 27.9 Clock Modification Timing
27.6.2
Notes on Resonator
Since various characteristics related to the resonator are closely linked to the user's board design,
thorough evaluation is necessary on the user's part, using the resonator connection examples
shown in this section as a reference. As the parameters for the resonator will depend on the
floating capacitance of the resonator and the mounting circuit, the parameters should be
determined in consultation with the resonator manufacturer. The design must ensure that a voltage
exceeding the maximum rating is not applied to the resonator pin.
27.6.3
Notes on Board Design
When using the crystal resonator, place the crystal resonator and its load capacitors as close to the
XTAL and EXTAL pins as possible. Other signal lines should be routed away from the oscillation
circuit as shown in figure 27.10 to prevent induction from interfering with correct oscillation.
Inhibited
Signal A Signal B
This LSI
CL2
XTAL
EXTAL
CL1
Figure 27.10 Note on Board Design for Oscillation Circuit
Rev. 2.00 Oct. 21, 2009 Page 1242 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
Figure 27.11 shows the external circuitry recommended for the PLL circuit. Separate PLLVcc and
PLLVss from the other Vcc and Vss lines at the board power supply source, and be sure to insert
bypass capacitors CPB and CB close to the pins.
Rp: 100 Ω
PLLVCC
CPB: 0.1 µF*
PLLVSS
VCC
CB: 0.1 µF*
VSS
Note: * CB and CPB are laminated ceramic capacitors.
Figure 27.11 Recommended External Circuitry for PLL Circuit
Rev. 2.00 Oct. 21, 2009 Page 1243 of 1454
REJ09B0498-0200
Section 27 Clock Pulse Generator
Rev. 2.00 Oct. 21, 2009 Page 1244 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Section 28 Power-Down Modes
Functions for reduced power consumption by this LSI include a multi-clock function, module stop
function, and a function for transition to power-down mode.
28.1
Features
• Multi-clock function
The frequency division ratio is settable independently for the system clock, peripheral module
clock, and external bus clock.
All of the system clock, peripheral module clock, and external bus clock can be switched to
32.768-kHz subclock.
• Module stop function
The functions for each peripheral module can be stopped to make a transition to a power-down
mode.
• Transition function to power-down mode
Transition to a power-down mode is possible to stop the CPU, peripheral modules, and
oscillator.
• Five power-down modes
Sleep mode
All-module-clock-stop mode
Software standby mode
Deep software standby mode
Hardware standby mode
Table 28.1 shows conditions to shift to a power-down mode, states of the CPU and peripheral
modules, and clearing method for each mode. After the reset state, since this LSI operates in
normal program execution state, the modules, other than the DMAC, DTC, and EXDMAC are
stopped.
Rev. 2.00 Oct. 21, 2009 Page 1245 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Table 28.1 States of Operation
State of
Operation
Sleep Mode
All-ModuleClock-Stop
Mode
Deep
Software
Standby
Software
Standby Mode Mode
Transition
condition
Control register Control register Control register Control
+ instruction
+ instruction
+ instruction
register +
instruction
Cancellation
method
Interrupt
Oscillator
Operating
Interrupt*2
Interrupt*8
Operating
9
Subclock
oscillator
Operating*
Operating*
CPU
Stopped
(retained)
Pin input
Interrupt*8
Stopped
9
Hardware
Standby
Mode
Stopped
9
Stopped
9
Operating*
Operating*
Stopped
Stopped
(retained)
Stopped
(retained)
Stopped
(undefined)
Stopped
(undefined)
On-chip RAMs Operating
4 (H'FF2000 to (retained)
H'FF3FFF)
Stopped
(retained)
Stopped
(retained)
Stopped
(undefined)
Stopped
(undefined)
On-chip RAMs
3 to 0
(H'FF4000 to
H'FFBFFF)
Operating
(retained)
Stopped
(retained)
Stopped
(retained)
Stopped
(retained/
undefined)*5
Stopped
(undefined)
Universal Serial Operating
Bus interface
Stopped
(retained)
Stopped
(retained)
Stopped
(retained/
undefined)*5
Stopped
(undefined)
Watchdog timer Operating
Operating
Stopped
(retained)
Stopped
(undefined)
Stopped
(undefined)
8-bit timer
(unit 0/1)
Operating
Operating*4
Stopped
(retained)
Stopped
(undefined)
Stopped
(undefined)
32K timer
Operating
Operating
Operating
Operating
Stopped
Voltage
detection
circuit*10
Operating
Operating
Operating
Operating
Stopped
Power-on reset Operating
10
circuit*
Operating
Operating
Operating
Stopped
Other
peripheral
modules
Operating
Stopped*1
Stopped*1
Stopped*7
(undefined)
Stopped*3
(undefined)
I/O ports
Operating
Retained
Retained*6
Stopped*6
(undefined)
Hi-Z
Rev. 2.00 Oct. 21, 2009 Page 1246 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Notes: "Stopped (retained)" in the table means that the internal values are retained and internal
operations are suspended.
"Stopped (undefined)" in the table means that the internal values are undefined and the
power supply for internal operations is turned off.
1. SCI enters the reset state, and other peripheral modules retain their states.
2. External interrupt and some internal interrupts (8-bit timer, watchdog timer, and 32K
timer).
3. All peripheral modules enter the reset state.
4. "Functioning" or "Stopped" is selectable through the setting of bits MSTPA9 and
MSTPA8 in MSTPCRA.
5. "Retained" or "undefined" of the contents of RAM is selected by the setting of the bits
RAMCUT2 to RAMCUT0 in DPSBYCR.
6. Retention or high-impedance for the address bus and bus-control signals (CS0 to CS7,
AS, RD, HWR, and LWR) is selected by the setting of the OPE bit in SBYCR.
7. Some peripheral modules enter a state where the register values are retained.
8. An external interrupt, 32K timer interrupt, or USB suspend/resume interrupt.
9. Start/stop can be selected by setting the OSC32STP bit in TCR32K.
11
10. External interrupt and voltage monitoring interrupt* .
11. Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1247 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
RES pin = Low
STBY pin = Low
STBY pin = High
RES pin = Low
Reset state
Hardware
standby mode
RES pin = High
Main clock operation
(CK32K = 0)
(DPSBY = 0
and no interrupt
is generated)
*3
SLEEP instruction
SLEEP instruction*3
(SSBY =1)
Interrupt*2
Sleep mode
All interrupts
ruction* 3
Interrupt*1
(DPSBY = 1
and no interrupt
is generated*5)
Software
standby mode
SSBY = 0
Program execution state
SLEEP inst
Program halted state
Deep software
standby mode
SSBY = 0, ACSE = 1
MSTPCR = H'F[C-F]FFFFFF
All-module-clockstop mode
Interrupt*4
CK32K = 0
Internal reset state
WAKE32K = 0
and Interrupt*2
CK32K = 1
Interrupt*4
Subclock operation
(CK32K = 1)
Program halted state
Deep software
standby mode
SLEEP instruction
SLEEP instruction
(DPSBY = 1
and no interrupt
is generated*5)
Software
standby mode
(DPSBY = 0
SSBY = 0
and no interrupt
is generated)
Sleep mode
(SSBY =1)
WAKE32K = 1
and Interrupt*2
Program execution state
SLEEP in
struction
All interrupts
SSBY = 0, ACSE = 1
MSTPCR = H'F[C-F]FFFFFF
Interrupt*1
All-module-clockstop mode
[Legend]
Transition after exception handling
Notes: 1. NMI, IRQ0 to IRQ11, 8-bit timer interrupt, watchdog timer interrupt, 32K timer interrupt, and voltage monitoring interrupt*6.
Note that the 8-bit timer interrupt is valid when the MSTPCRA9 or MSTPCRA8 bit is cleared to 0.
2. NMI, IRQ0 to IRQ11, 32K timer interrupt, USB suspend/resume interrupt, and voltage monitoring interrupt*6.
Note that IRQ is valid only when the corresponding bit in SSIER is set to 1.
3. The SLPIE bit is cleared to 0.
4. NMI, IRQ0-A to IRQ3-A, 32K timer interrupts, USB suspend/resume interrupts, and voltage monitoring interrupt*6.
Note that IRQ, 32K timer, and voltage monitoring interrupt*6 are valid only when the corresponding bit in DPSIER is set to 1.
5. If a conflict between a transition to deep software standby mode and generation of software standby mode
clearing source occurs, a mode transition may be made from software standby mode to program execution state
through execution of interrupt exception handling. In this case, a transition to deep software standby mode is not
made. For details, refer to section 28.12, Usage Notes.
6. Supported only by the H8SX/1665M Group.
Note:
From any state, a transition to hardware standby mode occurs when STBY is driven low.
From any state except hardware standby mode, a transition to the reset state occurs when RES is driven low.
Figure 28.1 Mode Transitions
Rev. 2.00 Oct. 21, 2009 Page 1248 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.2
Register Descriptions
The registers related to the power-down modes are shown below. For details on the system clock
control register (SCKCR), refer to section 27.1.1, System Clock Control Register (SCKCR).
•
•
•
•
•
•
•
•
•
•
•
Standby control register (SBYCR)
Module stop control register A (MSTPCRA)
Module stop control register B (MSTPCRB)
Module stop control register C (MSTPCRC)
Deep standby control register (DPSBYCR)
Deep standby wait control register (DPSWCR)
Deep standby interrupt enable register (DPSIER)
Deep standby interrupt flag register (DPSIFR)
Deep standby interrupt edge register (DPSIEGR)
Reset status register (RSTSR)
Deep standby backup register n (DPSBKRn) (n = 15 to 0)
Rev. 2.00 Oct. 21, 2009 Page 1249 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.2.1
Standby Control Register (SBYCR)
SBYCR controls software standby mode.
15
14
13
12
11
10
9
8
SSBY
OPE
⎯
STS4
STS3
STS2
STS1
STS0
0
1
0
0
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit name
Initial value:
R/W:
Bit
Bit name
7
6
5
4
3
2
1
0
SLPIE
⎯
⎯
⎯
⎯
⎯
⎯
⎯
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Initial value:
R/W:
Bit
Bit Name
Initial
Value
R/W
Description
15
SSBY
0
R/W
14
OPE
1
R/W
Software Standby
Specifies the transition mode after executing the SLEEP
instruction
0: Shifts to sleep mode after the SLEEP instruction is
executed
1: Shifts to software standby mode after the SLEEP
instruction is executed
This bit does not change when clearing the software
standby mode by using interrupts and shifting to normal
operation. For clearing, write 0 to this bit. When the WDT
is used in watchdog timer mode, the setting of this bit is
disabled. In this case, a transition is always made to
sleep mode or all-module-clock-stop mode after the
SLEEP instruction is executed. When the SLPIE bit is set
to 1, this bit should be cleared to 0.
Output Port Enable
Specifies whether the output of the address bus and bus
control signals (CS0 to CS7, AS, RD, HWR, and LWR) is
retained or these lines are set to the high-Z state in
software standby mode or deep software standby mode.
0: In software standby mode or deep software standby
mode, address bus and bus control signal lines are
high-impedance.
1: In software standby mode or deep software standby
mode, output states of address bus and bus control
signals are retained.
Rev. 2.00 Oct. 21, 2009 Page 1250 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Bit
Bit Name
Initial
Value
R/W
Description
13
⎯
0
R/W
Reserved
This bit is always read as 0. The write value should
always be 0.
12
STS4
0
R/W
Standby Timer Select 4 to 0
11
STS3
1
R/W
10
STS2
1
R/W
9
STS1
1
R/W
8
STS0
1
R/W
These bits select the time the MCU waits for the clock to
settle when software standby mode is cleared by an
interrupt or when a transition is made from subclock
operation to main clock operation. With a crystal
resonator, refer to table 28.2 and make a selection
according to the operating frequency so that the standby
time is at least equal to the oscillation settling time. With
an external clock, a PLL circuit settling time is necessary.
Refer to table 28.2 to set the standby time.
While oscillation is being settled, the timer is counted on
the Pφ clock frequency. Careful consideration is required
in multi-clock mode.
00000: Reserved
00001: Reserved
00010: Reserved
00011: Reserved
00100: Reserved
00101: Standby time = 64 states
00110: Standby time = 512 states
00111: Standby time = 1024 states
01000: Standby time = 2048 states
01001: Standby time = 4096 states
01010: Standby time = 16384 states
01011: Standby time = 32768 states
01100: Standby time = 65536 states
01101: Standby time = 131072 states
01110: Standby time = 262144 states
01111: Standby time = 524288 states
1xxxx: Reserved
Rev. 2.00 Oct. 21, 2009 Page 1251 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Bit
Bit Name
Initial
Value
R/W
Description
7
SLPIE
0
R/W
Sleep Instruction Exception Handling Enable
Selects whether a sleep interrupt is generated or a
transition to power-down mode is made when a SLEEP
instruction is executed.
0: A transition to power-down mode is made when a
SLEEP instruction is executed.
1: A sleep instruction exception handling is generated
when a SLEEP instruction is executed.
Even after a sleep instruction exception handling is
executed, this bit remains set to 1. For clearing, write 0 to
this bit.
6 to 0
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
[Legend]
x: Don't care
Note: With the F-ZTAT version, the flash memory settling time must be reserved.
28.2.2
Module Stop Control Registers A and B (MSTPCRA and MSTPCRB)
MSTPCRA and MSTPCRB control module stop state. Setting a bit to 1 makes the corresponding
module enter module stop state, while clearing the bit to 0 clears module stop state.
• MSTPCRA
Bit
Bit name
Initial value:
R/W:
Bit
Bit name
Initial value:
R/W:
15
14
13
12
11
10
9
8
ACSE
MSTPA14
MSTPA13
MSTPA12
MSTPA11
MSTPA10
MSTPA9
MSTPA8
0
0
0
0
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
MSTPA7
MSTPA6
MSTPA5
MSTPA4
MSTPA3
MSTPA2
MSTPA1
MSTPA0
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 1252 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
• MSTPCRB
15
14
13
12
11
10
9
8
MSTPB15
MSTPB14
MSTPB13
MSTPB12
MSTPB11
MSTPB10
MSTPB9
MSTPB8
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
MSTPB7
MSTPB6
MSTPB5
MSTPB4
MSTPB3
MSTPB2
MSTPB1
MSTPB0
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit name
Initial value:
R/W:
Bit
Bit name
Initial value:
R/W:
• MSTPCRA
Bit
Bit Name
Initial
Value
R/W
Module
15
ACSE
0
R/W
All-Module-Clock-Stop Mode Enable
Enables/disables all-module-clock-stop state for reducing
current consumption by stopping the bus controller and
I/O ports operations when the CPU executes the SLEEP
instruction after module stop state has been set for all the
on-chip peripheral modules controlled by MSTPCR.
0: All-module-clock-stop mode disabled
1: All-module-clock-stop mode enabled
14
MSTPA14 0
R/W
EXDMA controller (EXDMAC)
13
MSTPA13 0
R/W
DMA controller (DMAC)
12
MSTPA12 0
R/W
Data transfer controller (DTC)
11
MSTPA11 1
R/W
Reserved
10
MSTPA10 1
R/W
These bits are always read as 1. The write value should
always be 1.
9
MSTPA9
1
R/W
8-bit timer (TMR_3 and TMR_2)
8
MSTPA8
1
R/W
8-bit timer (TMR_1 and TMR_0)
7
MSTPA7
1
R/W
Reserved
6
MSTPA6
1
R/W
These bits are always read as 1. The write value should
always be 1.
Rev. 2.00 Oct. 21, 2009 Page 1253 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Bit
Bit Name
Initial
Value
R/W
Module
5
MSTPA5
1
R/W
D/A converter (channels 1 and 0)
4
MSTPA4
1
R/W
Reserved
This bit is always read as 1. The write value should
always be 1.
3
MSTPA3
1
R/W
A/D converter (unit 0)
2
MSTPA2
1
R/W
Reserved
This bit is always read as 1. The write value should
always be 1.
1
MSTPA1
1
R/W
16-bit timer pulse unit (TPU channels 11 to 6)
0
MSTPA0
1
R/W
16-bit timer pulse unit (TPU channels 5 to 0)
Initial
Value
R/W
Module
• MSTPCRB
Bit
Bit Name
15
MSTPB15 1
R/W
Programmable pulse generator (PPG_0: PO15 to PO0)
14
MSTPB14 1
R/W
Reserved
13
MSTPB13 1
R/W
These bits are always read as 1. The write value should
always be 1.
12
MSTPB12 1
R/W
Serial communications interface_4 (SCI_4)
11
MSTPB11 1
R/W
Reserved
This bit is always read as 1. The write value should
always be 1.
10
MSTPB10 1
R/W
Serial communications interface_2 (SCI_2)
9
MSTPB9
1
R/W
Serial communications interface_1 (SCI_1)
8
MSTPB8
1
R/W
Serial communications interface_0 (SCI_0)
7
MSTPB7
1
R/W
I2C bus interface 2_1 (IIC2_1)
6
MSTPB6
1
R/W
I2C bus interface 2_0 (IIC2_0)
5
MSTPB5
1
R/W
User break controller (UBC)
4
MSTPB4
1
R/W
Reserved
3
MSTPB3
1
R/W
2
MSTPB2
1
R/W
These bits are always read as 1. The write value should
always be 1.
1
MSTPB1
1
R/W
0
MSTPB0
1
R/W
Rev. 2.00 Oct. 21, 2009 Page 1254 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.2.3
Module Stop Control Register C (MSTPCRC)
When bits MSTPC5 to MSTPC0 are set to 1, the corresponding on-chip RAM stops. Do not set
the corresponding MSTPC5 to MSTPC0 bits to 1 while accessing the on-chip RAM. Do not
access the on-chip RAM while bits MSTPC5 to MSTPC0 are set to 1.
The serial communications interfaces, 8-bit timers, Universal Serial Bus interface (USB), CRC
calculator, 10-bit A/D converter, and programmable pulse generator (PPG: PO31 to PO16) are
placed in the module stop state by using the MSTPC15 and MSTPC14, MSTPC13 and MSTPC12,
MSTPC11, MSTPC10, MSTPC9, and MSTPC8 bits, respectively.
Bit
Bit name
15
14
13
12
11
10
9
8
MSTPC15
MSTPC14
MSTPC13
MSTPC12
MSTPC11
MSTPC10
MSTPC9
MSTPC8
1
1
1
1
1
1
1
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
7
6
5
4
3
2
1
0
MSTPC7
MSTPC6
MSTPC5
MSTPC4
MSTPC3
MSTPC2
MSTPC1
MSTPC0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Initial value:
R/W:
Bit
Bit name
Initial value:
R/W:
Bit
Bit Name
Initial
Value
R/W
Module
15
MSTPC15
1
R/W
Serial communications interface_5 (SCI_5), (IrDA)
14
MSTPC14
1
R/W
Serial communications interface_6 (SCI_6)
13
MSTPC13
1
R/W
8-bit timer (TMR_4, TMR_5)
12
MSTPC12
1
R/W
8-bit timer (TMR_6, TMR_7)
11
MSTPC11
1
R/W
Universal Serial Bus interface (USB)
10
MSTPC10
1
R/W
Cyclic redundancy check calculator
9
MSTPC9
1
R/W
A/D converter (unit 1)
8
MSTPC8
1
R/W
Programmable pulse generator (PPG_1: PO31 to PO16)
Rev. 2.00 Oct. 21, 2009 Page 1255 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Bit
Bit Name
Initial
Value
R/W
Module
7
MSTPC7
0
R/W
Reserved
6
MSTPC6
0
R/W
Always set the MSTPC7 and MSTPC6 bits to the same value.
5
MSTPC5
0
R/W
On-chip RAM 4 (H'FF2000 to H'FF3FFF)
4
MSTPC4
0
R/W
Always set the MSTPC5 and MSTPC4 bits to the same value.
3
MSTPC3
0
R/W
On-chip RAM_3, 2 (H'FF4000 to H'FF7FFF)
2
MSTPC2
0
R/W
Always set the MSTPC3 and MSTPC2 bits to the same value.
1
MSTPC1
0
R/W
On-chip RAM_1, 0 (H'FF8000 to H'FFBFFF)
0
MSTPC0
0
R/W
Always set the MSTPC1 and MSTPC0 bits to the same
value.
28.2.4
Deep Standby Control Register (DPSBYCR)
DPSBYCR controls deep software standby mode.
DPSBYCR is not initialized by the internal reset signal upon exit from deep software standby
mode.
Bit
Bit name
Initial value:
R/W:
7
6
5
4
3
2
1
0
DPSBY
IOKEEP
RAMCUT2
RAMCUT1
⎯
⎯
⎯
RAMCUT0
0
0
0
0
0
0
0
1
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 1256 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Bit
Bit Name
Initial
Value
R/W
Module
7
DPSBY
0
R/W
Deep Software Standby
When the SSBY bit in SBYCR has been set to 1, executing
the SLEEP instruction causes a transition to software
standby mode. At this time, if there is no source to clear
software standby mode and this bit is set to 1, a transition
to deep software standby mode is made.
SSBY
DPSBY
Entry to
0
x
Enters sleep mode after
execution of a SLEEP
instruction.
1
0
Enters software standby mode
after execution of a SLEEP
instruction.
1
1
Enters deep software standby
mode after execution of a
SLEEP instruction.
When deep software standby mode is canceled due to an
interrupt, this bit remains at 1. Write a 0 here to clear it.
Setting of this bit has no effect when the WDT is used in
watchdog timer mode. In this case, executing the SLEEP
instruction always initiates entry to sleep mode or allmodule-clock-stop mode. Be sure to clear this bit to 0 when
setting the SLPIE bit to 1.
6
IOKEEP
0
R/W
I/O Port Retention
In deep software standby mode, the ports retain the states
that were held in software standby mode. This bit specifies
whether or not the state that has been held in deep
software standby mode is retained after exit from deep
software standby mode.
IOKEEP
Pin State
0
The retained port states are released
simultaneously with exit from deep
software standby mode.
1
The retained port states are released
when a 0 is written to this bit following exit
from deep software standby mode.
In operation in external extended mode, however, the
address bus, bus control signals (CS0, AS, RD, HWR, and
LWR), and data bus are set to the initial state upon exit
from deep software standby mode.
Rev. 2.00 Oct. 21, 2009 Page 1257 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Initial
Value
Bit
Bit Name
5
RAMCUT2 0
R/W
Module
R/W
On-chip RAM Power Off 2
RAMCUT 2, 1, and 0 control the internal power supply to
the on-chip RAM and USB in deep software standby mode.
For details, see descriptions of the RAMCUT0 bit.
4
RAMCUT1 0
R/W
On-chip RAM Power Off 1
RAMCUT 2, 1, and 0 control the internal power supply to
the on-chip RAM and USB in deep software standby mode.
For details, see descriptions of the RAMCUT0 bit.
3 to 1
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
0
RAMCUT0 1
R/W
On-chip RAM Power Off 0
RAMCUT 2, 1, and 0 control the internal power supply to
the on-chip RAM and USB in deep software standby mode.
RAMCUT 2 to 0
000: Power is supplied to the on-chip RAM and USB.
111: Power is not supplied to the on-chip RAM and USB.
Settings other than above are prohibited.
28.2.5
Deep Standby Wait Control Register (DPSWCR)
DPSWCR selects the time for which the MCU waits until the clock settles when deep software
standby mode is canceled by an interrupt.
DPSWCR is not initialized by the internal reset signal upon exit from deep software standby
mode.
Bit
7
6
5
4
3
2
1
0
Bit name
⎯
⎯
WTSTS5
WTSTS4
WTSTS3
WTSTS2
WTSTS1
WTSTS0
Initial value:
R/W:
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Rev. 2.00 Oct. 21, 2009 Page 1258 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Bit
Bit Name
Initial
Value
R/W
Module
7, 6
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
5 to 0
WTSTS
[5:0]
0
R/W
Deep Software Standby Wait Time Setting
These bits select the time for which the MCU waits until
the clock settles when deep software standby mode is
canceled by an interrupt.
When using a crystal resonator, see table 28.3 and
select the wait time greater than the oscillation settling
time for each operating frequency. When using an
external clock, settling time for the PLL circuit should be
considered. See table 28.3 to select the wait time.
During the oscillation settling period, counting is
performed with the clock frequency input to the EXTAL.
000000: Reserved
000001: Reserved
000010: Reserved
000011: Reserved
000100: Reserved
000101: Wait time = 64 states
000110: Wait time = 512 states
000111: Wait time = 1024 states
001000: Wait time = 2048 states
001001: Wait time = 4096 states
001010: Wait time = 16384 states
001011: Wait time = 32768 states
001100: Wait time = 65536 states
001101: Wait time = 131072 states
001110: Wait time = 262144 states
001111: Wait time = 524288 states
01xxxx: Reserved
[Legend]
x: Don't care
Rev. 2.00 Oct. 21, 2009 Page 1259 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.2.6
Deep Standby Interrupt Enable Register (DPSIER)
DPSIER enables or disables interrupts to clear deep software standby mode.
DPSIER is not initialized by the internal reset signal upon exit from deep software standby mode.
Bit
7
6
5
4
3
2
1
0
Bit name
⎯
DUSBIE
DT32KIE
DLVDIE*
DIRQ3E
DIRQ2E
DIRQ1E
DIRQ0E
Initial value:
R/W:
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Note: * Supported only by the H8SX/1665M Group.
Bit
Bit Name
Initial
Value
R/W
Module
7
⎯
0
R/W
Reserved
This bit is always read as 0. The write value should always be
0.
6
DUSBIE
0
R/W
USB Suspend/Resume Interrupt Enable
Enables/disables exit from deep software standby mode by the
USB suspend/resume interrupt signal.
0: Disables exit from deep software standby mode by the USB
suspend/resume interrupt signal.
1: Enables exit from deep software standby mode by the USB
suspend/resume interrupt signal.
5
DT32KIE
0
R/W
32K Timer Interrupt Enable
Enables/disables exit from deep software standby mode by the
32K timer interrupt signal.
0: Disables exit from deep software standby mode by the 32K
timer interrupt signal.
1: Enables exit from deep software standby mode by the 32K
timer interrupt signal.
Rev. 2.00 Oct. 21, 2009 Page 1260 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Bit
Bit Name
Initial
Value
R/W
Module
4
DLVDIE*
0
R/W
LVD Interrupt Enable
Enables or disables exit from deep software standby mode by
voltage monitoring interrupt signal.
0: Disables exit from deep software standby mode by voltage
monitoring interrupt signal.
1: Enables exit from deep software standby mode by voltage
monitoring interrupt signal.
3
DIRQ3E
0
R/W
IRQ3 Interrupt Enable
Enables or disables exit from deep software standby mode by
IRQ3-A.
0: Disables exit from deep software standby mode by IRQ3-A.
1: Enables exit from deep software standby mode by IRQ3-A.
2
DIRQ2E
0
R/W
IRQ2 Interrupt Enable
Enables or disables exit from deep software standby mode by
IRQ2-A.
0: Disables exit from deep software standby mode by IRQ2-A.
1: Enables exit from deep software standby mode by IRQ2-A.
1
DIRQ1E
0
R/W
IRQ1 Interrupt Enable
Enables or disables exit from deep software standby mode by
IRQ1-A.
0: Disables exit from deep software standby mode by IRQ1-A.
1: Enables exit from deep software standby mode by IRQ1-A.
0
DIRQ0E
0
R/W
IRQ0 Interrupt Enable
Enables or disables exit from deep software standby mode by
IRQ0-A.
0: Disables exit from deep software standby mode by IRQ0-A.
1: Enables exit from deep software standby mode by IRQ0-A.
Note:
*
Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1261 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.2.7
Deep Standby Interrupt Flag Register (DPSIFR)
DPSIFR is used to request an exit from deep software standby mode. When the interrupt specified
in DPSIEGR is generated, the applicable bit in DPSIFR is set to 1. The bit is set to 1 even when an
interrupt is generated in the modes other than deep software standby. Therefore, a transition to
deep software standby should be made after this register bits are cleared to 0.
DPSIFR is not initialized by the internal reset signal upon exit from deep software standby mode.
Bit name
5
4
3
2
1
0
DNMIF
DUSBIF
DT32KIF
DLVDIF*2
DIRQ3F
DIRQ2F
DIRQ1F
DIRQ0F
0
0
0
0
0
0
0
0
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
R/(W)*1
Initial value:
R/W:
6
7
Bit
Notes: 1. Only 0 can be written to clear the flag.
2. Supported only by the H8SX/1665M Group.
Bit
7
Bit Name
DNMIF
Initial
Value
0
R/W
Module
1
R/(W)* NMI Flag
[Setting condition]
NMI input specified in DPSIEGR is generated.
[Clearing condition]
Writing a 0 to this bit after reading it as 1.
6
DUSBIF
0
1
R/(W)* USB Suspend/Resume Interrupt Flag
[Setting condition]
When the USB suspend/resume interrupt occurs.
[Clearing condition]
Writing a 0 to this bit after reading it as 1.
5
DT32KIF
0
1
R/(W)* 32K Timer Interrupt Flag
[Setting condition]
When the 32K timer interrupt occurs.
[Clearing condition]
Writing a 0 to this bit after reading it as 1.
Rev. 2.00 Oct. 21, 2009 Page 1262 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Bit
4
Bit Name
2
DLVDIF*
Initial
Value
0
R/W
Module
1
R/(W)* LVD Interrupt Flag
[Setting condition]
Voltage monitoring interrupt is generated.
[Clearing condition]
Writing a 0 to this bit after reading it as 1.
3
DIRQ3F
0
1
R/(W)* IRQ3 Interrupt Flag
[Setting condition]
IRQ3-A input specified in DPSIEGR is generated.
[Clearing condition]
Writing a 0 to this bit after reading it as 1.
2
DIRQ2F
0
1
R/(W)* IRQ2 Interrupt Flag
[Setting condition]
IRQ2-A input specified in DPSIEGR is generated.
[Clearing condition]
Writing a 0 to this bit after reading it as 1.
1
DIRQ1F
0
1
R/(W)* IRQ1 Interrupt Flag
[Setting condition]
IRQ1-A input specified in DPSIEGR is generated.
[Clearing condition]
Writing a 0 to this bit after reading it as 1.
0
DIRQ0F
0
1
R/(W)* IRQ0 Interrupt Flag
[Setting condition]
IRQ0-A input specified in DPSIEGR is generated.
[Clearing condition]
Writing a 0 to this bit after reading it as 1.
Notes: 1. Only 0 can be written to clear the flag.
2. Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1263 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.2.8
Deep Standby Interrupt Edge Register (DPSIEGR)
DPSIEGR selects the rising or falling edge to clear deep software standby mode.
DPSIEGR is not initialized by the internal reset signal upon exit from deep software standby
mode.
Bit
Bit name
Initial value:
R/W:
7
6
5
4
3
2
1
0
DNMIEG
⎯
⎯
⎯
DIRQ3EG
DIRQ2EG
DIRQ1EG
DIRQ0EG
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
Bit
Bit Name
Initial
Value
R/W
Module
7
DNMIEG
0
R/W
NMI Edge Select
Selects the active edge for NMI pin input.
0: The interrupt request is generated by a falling edge.
1: The interrupt request is generated by a rising edge.
6 to 4
⎯
All 0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
3
DIRQ3EG 0
R/W
IRQ3 Interrupt Edge Select
Selects the active edge for IRQ3-A pin input.
0: The interrupt request is generated by a falling edge.
1: The interrupt request is generated by a rising edge.
2
DIRQ2EG 0
R/W
IRQ2 Interrupt Edge Select
Selects the active edge for IRQ2-A pin input.
0: The interrupt request is generated by a falling edge.
1: The interrupt request is generated by a rising edge.
1
DIRQ1EG 0
R/W
IRQ1 Interrupt Edge Select
Selects the active edge for IRQ1-A pin input.
0: The interrupt request is generated by a falling edge.
1: The interrupt request is generated by a rising edge.
Rev. 2.00 Oct. 21, 2009 Page 1264 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Initial
Value
Bit
Bit Name
0
DIRQ0EG 0
R/W
Module
R/W
IRQ0 Interrupt Edge Select
Selects the active edge for IRQ0-A pin input.
0: The interrupt request is generated by a falling edge.
1: The interrupt request is generated by a rising edge.
28.2.9
Reset Status Register (RSTSR)
The DPSRSTF bit in RSTSR indicates that deep software standby mode has been canceled by an
interrupt.
RSTSR is not initialized by the internal reset signal upon exit from deep software standby mode.
Bit
Bit name
Initial value:
R/W:
Notes: 1.
2.
3.
4.
5.
7
6
5
4
3
2
1
0
DPSRSTF
⎯
⎯
⎯
⎯
LVDF*2
⎯
PORF*2
0
0
0
0
0
0*3
0*3
0*3
R/(W)*1
R/W
R/W
R/W
R/W
R/(W)*4
R/W
R/W*5
Only 0 can be written to clear the flag.
Supported only by the H8SX/1665M Group.
Initial value is undefined in the H8SX/1665M Group.
Only 0 can be written to clear the flag in the H8SX/1665M Group.
Readable only in the H8SX/1665M Group.
Initial
Value
Bit
Bit Name
7
DPSRSTF 0
R/W
Module
R/(W)* Deep Software Standby Reset Flag
Indicates that deep software standby mode has been
canceled by an interrupt source specified in DPSIER or
DPSIEGR and an internal reset is generated.
[Setting condition]
Deep software standby mode is canceled by an interrupt
source.
[Clearing condition]
Writing a 0 to this bit after reading it as 1.
Rev. 2.00 Oct. 21, 2009 Page 1265 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Bit
Bit Name
Initial
Value
R/W
Module
6 to 3
⎯
0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
• H8SX/1665 Group
Bit
Bit Name
Initial
Value
R/W
Module
2 to 0
⎯
0
R/W
Reserved
These bits are always read as 0. The write value should
always be 0.
• H8SX/1665M Group
Bit
Bit Name
Initial
Value
2
LVDF
Undefined R/(W)* LVD Flag
R/W
Module
This bit indicates that the voltage-detection circuit has
detected a low voltage (Vcc at or below Vdet).
For details, see section 5, Voltage Detection Circuit
(LVD).
⎯
1
Undefined R/W
Reserved
The write value should always be 0.
0
PORF
Undefined R
Power-on reset flag
Indicates the Power-on reset is generated.
For details, see section 4, Resets.
Note:
*
Only 0 can be written to clear the flag.
Rev. 2.00 Oct. 21, 2009 Page 1266 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.2.10 Deep Standby Backup Register (DPSBKRn)
DPSBKRn (n = 15 to 0) is a 16-bit readable/writable register to store data during deep software
standby mode.
Although data in on-chip RAM is not retained in deep software standby mode, data in this register
is retained.
DPSBKRn (n = 15 to 0) is not initialized by the internal reset signal upon exit from deep software
standby mode.
Bit
Bit name
Initial value:
R/W:
7
6
5
4
3
2
1
0
BKUPn7
BKUPn6
BKUPn5
BKUPn4
BKUPn3
BKUPn2
BKUPn1
BKUPn0
0
0
0
0
0
0
0
0
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
n: 15 to 0
Rev. 2.00 Oct. 21, 2009 Page 1267 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.3
Multi-Clock Function
28.3.1
Switching of Main Clock Frequencies
When bits ICK2 to ICK0, PCK2 to PCK0, and BCK2 to BCK0 in SCKCR are set, the clock
frequency is changed at the end of the bus cycle. The CPU and bus masters operate on the
operating clock specified by bits ICK2 to ICK0. The peripheral modules operate on the operating
clock specified by bits PCK2 to PCK0. The external bus operates on the operating clock specified
by bits BCK2 to BCK0.
Even if the frequencies specified by bits PCK2 to PCK0 and BCK2 to BCK0 are higher than the
frequency specified by bits ICK2 to ICK0, the specified values are not reflected in the peripheral
module and external bus clocks. The peripheral module and external bus clocks are restricted to
the operating clock specified by bits ICK2 to ICK0.
28.3.2
Switching to Subclock
When the CK32K bit in SUBCKCR is set to 1, a transition from the main clock operation to the
subclock operation is made at the end of the bus cycle regardless of the SCKCR setting. In the
subclock operation, the CPU, bus masters, peripheral modules, and all external buses operate on
the 32.768-kHz subclock.
When the CK32K bit in SUBCKCR is set to 0 in the subclock operation, a transition to the main
clock operation is made at the end of the bus cycle. Since a transition from the subclock operation
to the main clock operation is made via software standby mode, the oscillation settling time of the
main clock must elapse. Set the oscillation settling time of the main clock with bits STS4 to STS0
in SBYCR.
The main clock oscillator can be operated or stopped by the EXSTP bit in SUBCKCR in the
subclock operation. When a transition is made from the subclock operation to the main clock
operation with the main clock oscillator operating, the wait for the oscillation settling time of the
main clock oscillator is not necessary. A transition to the main clock operation can be made in the
minimum setting time with the setting of bits STS4 to STS0 in SBYCR.
In the same way as in the main clock operation, if a SLEEP instruction is executed in the subclock
operation while the SSBY bit in SBYCR is set to 1, this LSI enters software standby mode. When
a transition is made to software standby mode in the subclock operation, the operating clock of the
system clock after clearing of software standby mode can be selected with the WAKE32K bit in
SUBCKCR. This LSI is placed in the subclock operation if the WAKE32K bit is 1, or placed in
the main clock operation if the WAKE32K bit is 0.
Rev. 2.00 Oct. 21, 2009 Page 1268 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.4
Module Stop State
Module stop functionality can be set for individual on-chip peripheral modules.
When the corresponding MSTP bit in MSTPCRA, MSTPCRB, or MSTPCRC is set to 1, module
operation stops at the end of the bus cycle and a transition is made to a module stop state. The
CPU continues operating independently.
When the corresponding MSTP bit is cleared to 0, a module stop state is cleared and the module
starts operating at the end of the bus cycle. In a module stop state, the internal states of modules
other than the SCI are retained.
After the reset state is cleared, all modules other than the EXDMAC, DMAC, and DTC and onchip RAM are placed in a module stop state.
The registers of the module for which the module stop state is selected cannot be read from or
written to.
Rev. 2.00 Oct. 21, 2009 Page 1269 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.5
Sleep Mode
28.5.1
Entry to Sleep Mode
When the SLEEP instruction is executed when the SSBY bit in SBYCR is 0, the CPU enters sleep
mode. In sleep mode, CPU operation stops but the contents of the CPU's internal registers are
retained. Other peripheral functions do not stop.
28.5.2
Exit from Sleep Mode
Sleep mode is exited by any interrupt, signals on the RES or STBY pin, and a reset caused by a
watchdog timer overflow, a voltage monitoring reset*, or a power-on reset*.
• Exit from sleep mode by interrupt
When an interrupt occurs, sleep mode is exited and interrupt exception processing starts. Sleep
mode is not exited if the interrupt is disabled, or interrupts other than NMI are masked by the
CPU.
• Exit from sleep mode by RES pin
Setting the RES pin level low selects the reset state. After the stipulated reset input duration,
driving the RES pin high makes the CPU start the reset exception processing.
• Exit from sleep mode by STBY pin
When the STBY pin level is driven low, a transition is made to hardware standby mode.
• Exit from sleep mode by reset caused by watchdog timer overflow
Sleep mode is exited by an internal reset caused by a watchdog timer overflow.
• Exit from voltage monitoring reset*
Sleep mode is exited by a voltage monitoring reset of the voltage detection circuit.
• Exit from power-on reset*
Sleep mode is exited by a power-on reset.
Note: * Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1270 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.6
All-Module-Clock-Stop Mode
When the ACSE bit is set to 1 and all modules controlled by MSTPCRA and MSTPCRB are
stopped (MSTPCRA, MSTPCRB = H'FFFFFFFF), or all modules except for the 8-bit timer (units
0 and 1) are stopped (MSTPCRA, MSTPCRB = H'F[C to F]FFFFFF), executing a SLEEP
instruction with the SSBY bit in SBYCR cleared to 0 will cause all modules (except for the 8-bit
timer*1, watchdog timer, 32K timer, power-on reset circuit*2, and voltage detection circuit*2), the
bus controller, and the I/O ports to stop operating, and to make a transition to all-module-clockstop mode at the end of the bus cycle.
When power consumption should be reduced ever more in all-module-clock-stop mode, stop
modules controlled by MSTPCRC (MSTPCRC[15:8] = H'FFFF).
All-module-clock-stop mode is cleared by an external interrupt (NMI or IRQ0 to IRQ11 pins),
RES pin input, or an internal interrupt (8-bit timer*1, watchdog timer, 32K timer, or voltagedetection circuit*2), and the CPU returns to the normal program execution state via the exception
handling state. All-module-clock-stop mode is not cleared if interrupts are disabled, if interrupts
other than NMI are masked on the CPU side, or if the relevant interrupt is designated as a DTC
activation source.
When the STBY pin is driven low, a transition is made to hardware standby mode.
Notes: 1. Operation or halting of the 8-bit timer can be selected by bits MSTPA9 and MSTPA8
in MSTPCRA.
2. Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1271 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.7
Software Standby Mode
28.7.1
Entry to Software Standby Mode
If a SLEEP instruction is executed when the SSBY bit in SBYCR is set to 1 and the DPSBY bit in
DPSBYCR is cleared to 0, software standby mode is entered. In this mode, the CPU, on-chip
peripheral functions, and oscillator all stop. However, the contents of the CPU's internal registers,
on-chip RAM data, and the states of on-chip peripheral functions other than the SCI, and the states
of the I/O ports, are retained. Whether the address bus and bus control signals are placed in the
high-impedance state or retain the output state can be specified by the OPE bit in SBYCR. In this
mode the oscillator stops, allowing power consumption to be significantly reduced.
If the WDT is used in watchdog timer mode, it is impossible to make a transition to software
standby mode. The WDT should be stopped before the SLEEP instruction execution.
28.7.2
Exit from Software Standby Mode
Software standby mode is cleared by an external interrupt (NMI, or IRQ0 to IRQ11*1) or internal
interrupt (32K timer, voltage detection interrupt*2, or USB suspend/resume), voltage-detection
reset*2, power-on reset*2, or by means of the RES pin or STBY pin.
1. Exit from software standby mode by interrupt
When an NMI, IRQ0 to IRQ11*1, 32K-timer, or USB suspend/resume interrupt request signal
is input, clock oscillation starts, and after the elapse of the time set in bits STS4 to STS0 in
SBYCR, stable clocks are supplied to the entire LSI, software standby mode is cleared, and
interrupt exception handling is started.
When clearing software standby mode with an IRQ0 to IRQ11*1 interrupt, set the
corresponding enable bit to 1 and ensure that no interrupt with a higher priority than interrupts
IRQ0 to IRQ11*1 is generated. Software standby mode cannot be cleared if the interrupt has
been masked on the CPU side or has been designated as a DTC activation source.
2. Exit from voltage monitoring reset*2
When a voltage monitoring reset is generated by the fall of power-voltage, software standby
mode is cleared and a clock oscillation starts. At the same time, a clock signal is supplied
throughout the LSI. After that, if power voltage rises, the voltage detection reset is released.
Thereafter, CPU starts the reset exception handling.
Rev. 2.00 Oct. 21, 2009 Page 1272 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
3. Exit from power-on reset*3
When a power-on reset is generated by the fall of power voltage, software standby mode is
released. After that, if power voltage rises, the clock oscillation starts and the power-on reset is
released while the clock oscillation stabilization time is well kept. Thereafter CPU starts the
reset exception handling.
4. Exit from software standby mode by RES pin
When the RES pin is driven low, clock oscillation is started. At the same time as clock
oscillation starts, clocks are supplied to the entire LSI. Note that the RES pin must be held low
until clock oscillation settles. When the RES pin goes high, the CPU begins reset exception
handling.
5. Exit from software standby mode by STBY pin
When the STBY pin is driven low, a transition is made to hardware standby mode.
Notes: 1. By setting the SSIn bit in SSIER to 1, IRQ0 to IRQ11 can be used as a software
standby mode clearing source.
2. Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1273 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.7.3
Setting Oscillation Settling Time after Exit from Software Standby Mode
Bits STS4 to STS0 in SBYCR should be set as described below.
1. Using a crystal resonator
Set bits STS4 to STS0 so that the standby time is at least equal to the oscillation settling time.
Table 28.2 shows the standby times for operating frequencies and settings of bits STS4 to
STS0.
2. Using an external clock
A PLL circuit settling time is necessary. Refer to table 28.2 to set the standby time.
Table 28.2 Oscillation Settling Time Setting
Standby
STS4 STS3 STS2 STS1 STS0 Time
35
0
0
0
0
1
1
0
1
1
0
0
1
1
0
1
1
0
0
0
Pφ* (MHz)
25
20
13
10
8
Unit
μs
0
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
1
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
0
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
1
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
0
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
1
64
1.8
2.6
3.2
4.9
6.4
8.0
0
512
14.6
20.5
25.6
39.4
51.2
64.0
1
1024
29.3
41.0
51.2
78.8
102.4
128.0
0
2048
58.5
81.9
102.4
157.5
204.8
256.0
1
4096
0.12
0.16
0.20
0.32
0.41
0.51
0
16384
0.47
0.66
0.82
1.26
1.64
2.05
1
32768
0.94
1.31
1.64
2.52
3.28
4.10
0
65536
1.87
2.62
3.28
5.04
6.55
8.19
1
131072
3.74
5.24
6.55
10.08
13.11
16.38
0
262144
7.49
10.49
13.11
20.16
26.21
32.77
1
524288
14.98
20.97
26.21
40.33
52.43
65.54
0
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
ms
[Legend]
: Recommended setting when external clock is in use
: Recommended setting when crystal oscillator is in use
Note: * Pφ is the output from the peripheral module frequency divider. The oscillation settling
time, which includes a period where the oscillation by an oscillator is not stable,
depends on the resonator characteristics. The above figures are for reference.
Rev. 2.00 Oct. 21, 2009 Page 1274 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.7.4
Software Standby Mode Application Example
Figure 28.2 shows an example in which a transition is made to software standby mode at the
falling edge on the NMI pin, and software standby mode is cleared at the rising edge on the NMI
pin.
In this example, an NMI interrupt is accepted with the NMIEG bit in INTCR cleared to 0 (falling
edge specification), then the NMIEG bit is set to 1 (rising edge specification), the SSBY bit is set
to 1, and a SLEEP instruction is executed, causing a transition to software standby mode.
Software standby mode is then cleared at the rising edge on the NMI pin.
Oscillator
Iφ
NMI
NMIEG
SSBY
NMI exception
handling
NMIEG = 1
SSBY = 1
SLEEP instruction
Software standby mode
(power-down mode)
NMI exception
handling
Oscillation
settling time
tOSC2
Figure 28.2 Software Standby Mode Application Example
Rev. 2.00 Oct. 21, 2009 Page 1275 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.8
Deep Software Standby Mode
28.8.1
Entry to Deep Software Standby Mode
If a SLEEP instruction is executed when the SSBY bit in SBYCR has been set to 1, a transition to
software standby mode is made. In this state, if the CPSBY bit in DPSBYCR is set to 1, a
transition to deep software standby mode is made.
If a software standby mode clearing source (an NMI, IRQ0 to IRQ11, 32K timer, voltagemonitoring interrupt requests*, or USB suspend/resume) occurs when a transition to software
standby mode is made, software standby mode will be cleared regardless of the DPSBY bit
setting, and the interrupt exception handling starts after the oscillation settling time for software
standby mode specified by the bits STS4 to STS0 in SBYCR has elapsed.
When both of the SSBY bit in SBYCR and the CPSBY bit in DPSBYCR are set to 1 and no
software standby mode clearing source occurs, a transition to deep software standby mode will be
made immediately after software standby mode is entered.
In deep software standby mode, the CPU, on-chip peripheral functions (except for the USB and
32K timer), on-chip RAM 4, and oscillator functionality are all stopped. In addition, the internal
power supply to these modules stops, resulting in a significant reduction in power consumption.
At this time, the contents of all the registers of the CPU, on-chip peripheral functions (except for
the USB and 32K timer), and on-chip RAM 4 become undefined.
Contents of the on-chip RAMs 3 to 0 and USB registers can be retained when all the bits
RAMCUT2 to RAMCUT0 in DPSBYCR have been cleared to 0. If these bits are set to all 1, the
internal power supply to the on-chip RAMs 3 to 0 and USB stops and the power consumption is
further reduced. At this time, the contents of the on-chip RAMs 3 to 0 and USB registers become
undefined.
The 32K timer, voltage detection circuit*, and power-on reset circuit* can be operated in deep
software standby mode.
The I/O ports can be retained in the same state as in software standby mode.
Note: * Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1276 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.8.2
Exit from Deep Software Standby Mode
Exit from deep software standby mode is initiated by signals on the external interrupt pins (NMI
and IRQ0-A to IRQ3-A), internal interrupt signals (32K timer, voltage-monitoring interrupt*, and
USB suspend/resume), voltage-monitoring interrupt reset*, power-on reset*, RES pin, or STBY
pin.
1. Exit from deep software standby mode by external interrupt pins or internal interrupt signals
Deep software standby mode is canceled when any of the DNMIF, DIRQnF (n = 3 to 0),
DT32KIF, DLVDIF*, and DUSBIF bits in DPSIFR is set to 1. The DNMIF or DIRQnF (n = 3
to 0) bit is set to 1 when a specified edge is generated in the NMI or IRQ0-A to IRQ3-A pins,
that has been enabled by the DIRQnE (n = 3 to 0) bit in DPSIER. The rising or falling edge of
the signals can be specified with DPSIEGR. The DT32KIF bit is set to 1 when a 32K timer
interrupt occurs. The DLVDIF bit is set to 1when a voltage-monitoring interrupt occurs. The
DUSBIF bit is set to 1 when a USB suspend/resume interrupt occurs.
When deep software standby mode clearing source is generated, internal power supply starts
simultaneously with the start of clock oscillation, and internal reset signal is generated for the
entire LSI. Once the time specified by the WTSTS5 to WTSTS0 bits in DPSWCR has elapsed,
a stable clock signal is being supplied throughout the LSI and the internal reset is cleared.
Deep software standby mode is canceled on clearing of the internal reset, and then the reset
exception handling starts.
When deep software standby mode is canceled by an external interrupt pin or internal interrupt
signal, the DPSRSTF bit in RSTSR is set to 1.
2. Exit from deep software standby mode by a voltage-monitoring reset*
When a voltage monitoring reset is generated by the power-supply voltage falling, the LSI is
released from deep software standby mode and internal power supply starts simultaneously
with the start of clock oscillation. At the same time, a clock signal is supplied throughout the
LSI. When the power-supply voltage has risen sufficiently, the LSI is released from the
voltage-detection reset state after the clock oscillation stabilization time has been secured. The
CPU then starts reset-exception handling.
3. Exit from power-on reset*
When a power-on reset is generated by the power-supply voltage falling, the LSI is released
from deep software standby mode. If the power-supply voltage then rises sufficiently, clock
oscillation starts and the LSI is released from the power-on reset state after the clock
oscillation stabilization time has been secured. As soon as the clock oscillation starts, the clock
signal is provided to the LSI. After that, the CPU starts reset-exception handling.
Rev. 2.00 Oct. 21, 2009 Page 1277 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
4. Exit from deep software standby mode by the signal on the RES pin
Clock oscillation and internal power supply start as soon as the signal on the RES pin is driven
low. At the same time, clock signals are supplied to the LSI. In this case, the RES pin has to be
held low until the clock oscillation has become stable. Once the signal on the RES pin is
driven high, the CPU starts reset exception handling.
5. Exit from deep software standby mode by the signal on the STBY pin
When the STBY pin is driven low, a transition is made to hardware standby mode.
Note: * Supported only by the H8SX/1665M Group.
28.8.3
Pin State on Exit from Deep Software Standby Mode
In deep software standby mode, the ports retain the states that were held during software standby
mode. The internal of the LSI is initialized by an internal reset caused by deep software standby
mode, and the reset exception handling starts as soon as deep software standby mode is canceled.
The following shows the port states at this time.
(1)
Pins for address bus, bus control and data bus
Pins for the address bus, bus control signals (CS0, AS, HWR, and LWR), and data bus operate
depending on the CPU.
(2)
Pins other than address bus, bus control and data bus pins
Whether the ports are initialized or retain the states that were held during software standby mode
can be selected by the IOKEEP bit.
• When IOKEEP = 0
Ports are initialized by an internal reset caused by deep software standby mode.
• When IOKEEP = 1
The port states that were held in deep software standby mode are retained regardless of the LSI
internal state though the internal of the LSI is initialized by an internal reset caused by deep
software standby mode. At this time, the port states that were held in software standby mode
are retained even if settings of I/O ports or peripheral modules are set. Subsequently, the
retained port states are released when the IOKEEP bit is cleared to 0 and operation is
performed according to the internal settings.
The IOKEEP bit is not initialized by an internal reset caused by canceling deep software
standby mode.
Rev. 2.00 Oct. 21, 2009 Page 1278 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.8.4
Bφ/SDRAMφ Operation after Exit from Deep Software Standby Mode
When the IOKEEP bit is 0, Bφ/SDRAMφ output is undefined for a maximum of one cycle
immediately after exit from deep software standby mode. At this time, the output state cannot be
guaranteed. Even when the IOKEEP bit is set to 1, Bφ/SDRAMφ output is undefined for a
maximum of one cycle immediately after the IOKEEP bit is cleared to 0 after deep software
standby mode was canceled, and the output state cannot be guaranteed
However, clock can be normally output by canceling deep software standby mode with the
IOKEEP bit set to 1 and then controlling the Bφ/SDRAMφ οutput with the IOKEEP and PSTOP1
bits. Following procedure takes Bφ for example. (See figure 28.3)
1. Change the value of the PSTOP1 bit from 0 to 1 to fix the Bφ output at the high level (given
that the Bφ output was already fixed high).
2. Clear the IOKEEP bit to 0 to end retention of the Bφ state.
3. Clear the PSTOP1 bit to 0 to enable Bφ output.
In case of the SDRAMφ, clock can be normally output by controlling the PSTOP0 bit instead of
the PSTOP1 bit in the same way as the procedure above mentioned. For the port state when the
IOKEEP bit is set to 1, see section 28.8.3, Pin State on Exit from Deep Software Standby Mode.
Deep software standby mode
Oscillator
NMI
Internal reset
Iφ
(1) Bφ output cannot be guaranteed.
When IOKEEP = 0
Clock is undefined
Bφ
IOKEEP
cleared
When IOKEEP = 1
PSTOP1 IOKEEP PSTOP1
set
cleared cleared
(2) The procedure to guarantee Bφ output is used.
Bφ
(IOKEEP=1)
When IOKEEP = 1, the clock can be normally output
by using the PSTOP1 bit.
Figure 28.3 Bφ Operation after Exit from Deep Software Standby Mode
Rev. 2.00 Oct. 21, 2009 Page 1279 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.8.5
Setting Oscillation Settling Time after Exit from Deep Software Standby Mode
The WTSTS5 to WTSTS0 bits in DPSWCR should be set as follows:
1. Using a crystal resonator
Specify the WTSTS5 to WTSTS0 bits so that the standby time is at least equal to the
oscillation settling time. Table 28.3 shows EXTAL input clock frequencies and the standby
time according to WTSTS5 to WTSTS0 settings.
2. Using an external clock
The PLL circuit settling time should be considered. See table 28.3 to set the standby time.
Table 28.3 Oscillation Settling Time Settings
EXTAL Input Clock Frequency* (MHz)
WT
STS5
WT
STS4
WT
STS3
WT
STS2
WT
STS1
0
0
0
0
0
1
1
0
1
1
0
0
1
1
0
1
1
0
0
0
WT
STS0
Standby
Time
18
16
12
10
8
Unit
μs
0
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
1
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
0
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
1
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
0
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
1
64
3.6
4.0
4.6
5.3
6.4
8.0
0
512
28.4
32.0
36.6
42.7
51.2
64.0
1
1024
56.9
64.0
73.1
85.3
102.4
128.0
0
2048
113.8
128.0
146.3
170.7
204.8
256.0
1
4096
0.23
0.26
0.29
0.34
0.41
0.51
0
16384
0.91
1.02
1.17
1.37
1.64
2.05
1
32768
1.82
2.05
2.34
2.73
3.28
4.10
0
65536
3.64
4.10
4.68
5.46
6.55
8.19
1
131072
7.28
8.19
9.36
10.92
13.11
16.38
0
262144
14.56
16.38
18.72
21.85
26.21
32.77
1
524288
29.13
32.77
37.45
43.69
52.43
65.54
0
Reserved
⎯
⎯
⎯
⎯
⎯
⎯
[Legend]
: Recommended setting when external clock is in use
: Recommended setting when crystal oscillator is in use
Rev. 2.00 Oct. 21, 2009 Page 1280 of 1454
REJ09B0498-0200
14
ms
Section 28 Power-Down Modes
Note:
*
28.8.6
(1)
The oscillation settling time, which includes a period where the oscillation by an
oscillator is not stable, depends on the resonator characteristics.
The above figures are for reference.
Deep Software Standby Mode Application Example
Transition to and Exit from Deep Software Standby Mode
Figure 28.4 shows an example where the transition to deep software standby mode is initiated by a
falling edge on the NMI pin and exit from deep software standby mode is initiated by a rising edge
on the NMI pin.
In this example, falling-edge sensing of NMI interrupts has been specified by clearing the NMIEG
bit in INTCR to 0 (not shown). After an NMI interrupt has been sensed, rising-edge sensing is
specified by setting the DNMIEG bit to 1, the SSBY and DPSBY bits are set to 1, and the
transition to deep software standby mode is triggered by execution of a SLEEP instruction.
After that, deep software standby mode is canceled at the rising edge on the NMI pin.
Rev. 2.00 Oct. 21, 2009 Page 1281 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Oscillator
Iφ
NMI
NMI interrupt
Becomes invalid
by an internal reset
Set
Set
DNMI interrupt
DNMIEG bit
Set
DPSBY bit
Set
IOKEEP bit
Set
I/O port
Operated
Cleared
Cleared
Operated
Retained
DPSRSTF flag
Cleared
Internal reset
Deep software
NMI exception
standby mode
handling
(power-down mode)
DNMIEG = 1
SSBY = 1
DPSBY = 1 SLEEP
instruction
Oscillation
settling time
Reset
exception
handling
Figure 28.4 Deep Software Standby Mode Application Example (IOKEEP = 1)
Rev. 2.00 Oct. 21, 2009 Page 1282 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
(2)
Deep Software Standby Mode in External Extended Mode (IOKEEP = 1)
Figure 28.5 shows an example of operations in deep standby mode when the IOKEEP and OPE
bits are set to 1 in external extended mode.
In this example, deep software standby mode is entered with the IOKEEP and OPE bits set to 1,
and then exited at the rising edge of the NMI pin. In external expansion mode, while the IOKEEP
bit is set to 1, retention of the states of pins for the address bus, bus-control signals (CS0, AS, RD,
HWR, and LWR), data bus is released after the oscillation settling time has elapsed. For other
pins, including the Bφ output pin, retention is released when the IOKEEP bit is cleared to 0, and
then they are set according to the I/O port or peripheral module settings.
Oscillator
Iφ
NMI
Internal reset
Started from h'00000
Address
Operated
Bus control
Data
Retained
Operated
Retained
Operated
Retained
Operated
PSTOP1 PSTOP1
set
cleared
Retained
Bφ
IOKEEP cleared
I/O other than
above
Operated
Operated
Retained
Oscillation
settling time
Program
execution state
Deep software standby mode
SLEEP
(power-down mode)
instruction
Reset
exception
handling
Program
execution state
Figure 28.5 Example of Deep Software Standby Mode Operation in
External Extended Mode (IOKEEP = OPE = 1)
Rev. 2.00 Oct. 21, 2009 Page 1283 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
(3)
Deep Software Standby Mode in External Extended Mode (IOKEEP = 0)
Figure 28.6 shows an example of operations in deep software standby mode with the IOKEEP bit
is set to 1 and the OPE bit is cleared to 0 in external extended mode. When the IOKEEP bit is
cleared to 0, retention of the states of pins including the address bus, bus-control signals (CS0, AS,
RD, HWR, and LWR), data bus, and other pins including Bφ output is released after the
oscillation settling time has elapsed.
Oscillator
Iφ
NMI
Internal reset
Started from h'00000
Address
Retained
Operated
Bus control
Data
Operated
Retained
Retained
Operated
Operated
Retained
Bφ
I/O other than
above
Retained
Operated
Operated
Oscillation
settling time
Program
execution state
Deep software standby mode
(power-down mode)
SLEEP
instruction
Reset
exception
handling
Program
execution state
Figure 28.6 Example of Deep Software Standby Mode Operation in
External Extended Mode (IOKEEP = OPE = 0)
Rev. 2.00 Oct. 21, 2009 Page 1284 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.8.7
Flowchart of Deep Software Standby Mode Operation
Figure 28.7 shows an example of flowchart of deep software standby mode operation. In this
example, reading the DPSRSTF bit determines whether a reset was generated by the RES pin or
exit from deep software standby mode, after the reset exception handling was performed.
When a reset was caused by the RES pin, deep software standby mode is entered after required
register settings.
When a reset was caused by exit from deep software standby mode, the IOKEEP bit is cleared
after the I/O ports setting. When the IOKEEP bit is cleared, the setting to avoid instability in Bφ
output is also set.
Rev. 2.00 Oct. 21, 2009 Page 1285 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
Clear a reset by RES
Reset exception handling
Program start
RSTSR.
DPSRSTF = 0
No
Yes
Set DPSWCR.WTSTS5-0
Set
SBYCR.SSBY to 1
DPSBYCR.DPSBY to 1
DPSBYCR.RAMCUT2-0
Set oscillation setting time
Select deep software
standby mode
Identify deep software
standby mode clearing
source (1)
Set PnDDR,PnDR
Set pin state after clearing
IOKEEP to 0
Set SCKCR.PSTOP1 to 1
Set PnDDR,PnDR
Set SBYCR.OPE
Read DPSIFR
Set pin state in deep
software standby mode
and after exit from deep
software standby mode
Set DPSBYCR.IOKEEP to 0
Set SCKCR.PSTOP1 to 0
Releases pin states that were
retained during deep software
standby mode
Start Bφ output
Set DPSBYCR.IOKEEP to 1
Set DPSIEGR
Set DPSIER
Set deep software
standby mode clearing
interrupt
Execute a program
corresponding to the
clearing source that
was identified in (1)
Clear DPSIFR
Execute SLEEP instruction
Deep software
standby mode
An interrupt is generated
by exit from deep software
standby mode.
Figure 28.7 Flowchart of Deep Software Standby Mode Operation
Rev. 2.00 Oct. 21, 2009 Page 1286 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.9
Hardware Standby Mode
28.9.1
Transition to Hardware Standby Mode
When the STBY pin is driven low, a transition is made to hardware standby mode from any mode.
In hardware standby mode, all functions enter the reset state and stop operation, resulting in a
significant reduction in power consumption. Data in the on-chip RAM is not retained because the
internal power supply to the on-chip RAM stops. I/O ports are set to the high-impedance state.
Do not change the states of mode pins (MD3 to MD0) while this LSI is in hardware standby mode.
28.9.2
Clearing Hardware Standby Mode
Hardware standby mode is cleared by means of the STBY pin and the RES pin. When the STBY
pin is driven high while the RES pin is low, the reset state is entered and clock oscillation is
started. Ensure that the RES pin is held low until clock oscillation settles (for details on the
oscillation settling time, refer to table 28.2). When the RES pin is subsequently driven high, a
transition is made to the program execution state via the reset exception handling state.
28.9.3
Hardware Standby Mode Timing
Figure 28.8 shows an example of hardware standby mode timing.
When the STBY pin is driven low after the RES pin has been driven low, a transition is made to
hardware standby mode. Hardware standby mode is cleared by driving the STBY pin high,
waiting for the oscillation settling time, then changing the RES pin from low to high.
Oscillator
RES
STBY
Oscillation
settling time
Reset exception
handling
Figure 28.8 Hardware Standby Mode Timing
Rev. 2.00 Oct. 21, 2009 Page 1287 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.9.4
Timing Sequence at Power-On
Figure 28.9 shows the timing sequence at power-on.
At power-on, the RES pin must be driven low with the STBY pin driven high for a given time in
order to clear the reset state.
To enter hardware standby mode immediately after power-on, drive the STBY pin low after
exiting the reset state.
For details on clearing hardware standby mode, see section 28.9.3, Hardware Standby Mode
Timing.
In a power-on reset*, power on while driving the STBY or RES pin to a high-level.
Note: * Supported only by the H8SX/1665M Group.
1 Power supply
RES
2 Reset state
STBY
3 Hardware standby mode
Figure 28.9 Timing Sequence at Power-On
Rev. 2.00 Oct. 21, 2009 Page 1288 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.10
Sleep Instruction Exception Handling
A sleep instruction exception handling is generated by executing a SLEEP instruction. The sleep
instruction exception handling is always accepted in the program execution state.
When the SLPIE bit is set to 0, sleep-instruction exception handling does not follow execution of
the SLEEP instruction. In this case, the CPU is placed in the power-down state. After exit from the
power-down state has been initiated by an exception, the CPU starts handling of the exception.
When the SLPIE bit is set to 1, sleep-instruction exception handling follows execution of the
SLEEP instruction. The CPU immediately starts sleep-instruction exception handling, which
blocks the transition to the power-down state is prevented by.
When a SLEEP instruction is executed while the SLPIE bit is cleared to 0, a transition is made to
the power-down state. Exit from the power-down state is initiated by an exit-initiating interrupt
source (see figure 28.10).
When an interrupt that causes exit from the power-down state is generated immediately before the
execution of a SLEEP instruction, exception handling for the interrupt starts. On return from the
exception service routine, the SLEEP instruction is executed to enter the power-down state. In this
case, exit from the power-down state will not take place until the next time an exit-initiating
interrupt is generated (see figure 28.11).
As stated above, setting the SLPIE bit to 1 causes sleep-instruction exception handling to follow
the execution of the SLEEP instruction. If this setting is made in the exception service routine for
an interrupt that initiates exit from the power-down state, handling of the sleep-instruction
exception due to the execution of a SLEEP instruction will proceed even if the interrupt was
generated immediately beforehand (see figure 28.12). Consequently, the CPU will execute the
instruction that follows the SLEEP instruction, after handling of the sleep-instruction exception
and exception service routine, and will not enter the power-down state.
Thus, when the SLPIE bit is set to 1 to enable the sleep exception handling, clear the SSBY bit in
SBYCR to 0.
Rev. 2.00 Oct. 21, 2009 Page 1289 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
SLPIE = 0
Instruction before SLEEP instruction
SLEEP instruction executed (SLPIE = 0)
Power-down
state
Canceling factor
interrupt
Transition by interrupt
exception handling
Yes
No
Interrupt handling routine
RTE instruction executed
Instruction after SLEEP instruction
Figure 28.10 When an Interrupt that Initiates Exit from the Power-Down State
is Generated after SLEEP Instruction Execution
SLPIE = 0
Instruction before SLEEP instruction
Yes
Canceling factor
interrupt
No
Transition by interrupt exception handling
Interrupt handling routine
RTE instruction executed
SLEEP instruction executed (SLPIE = 0)
Return from the powerdown state after the next
canceling factor interrupt
is generated
Power-down state
Canceling factor
interrupt
Yes
Transition by interrupt exception handling
No
Interrupt handling routine
RTE instruction executed
Instruction after SLEEP instruction
Figure 28.11 When an Interrupt that Initiates Exit from the Power-Down State
is Generated before SLEEP Instruction Execution
(Sleep-Instruction Exception Handling does not Proceed)
Rev. 2.00 Oct. 21, 2009 Page 1290 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
SLPIE = 0
Instruction before SLEEP instruction
Yes
Canceling factor
interrupt
No
Transition by interrupt
exception handling
Interrupt handling routine
SLPIE = 1
SSBY = 0
RTE instruction executed
SLEEP instruction executed (SLPIE = 1)
Transition by interrupt exception handling
Sleep instruction
exceotion handling
Vector Number 18
Exception service routine
RTE instruction executed
Instruction after SLEEP instruction
Figure 28.12 When an Interrupt that Initiates Exit from the Power-Down State
is Generated before SLEEP Instruction Execution
(Sleep Instruction Exception Handling Proceeds)
Rev. 2.00 Oct. 21, 2009 Page 1291 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.11
φ Clock Output Control
Output of the φ clock (Bφ/SDφ) can be controlled by bits PSTOP1 and PSTOP0 in SCKCR, and
DDR for the corresponding port. Bits PSTOP1 control the Bφ clock output on the PA7 pin. Bit
PSTOP0 controls the SDφ clock output on the PB7 pin. When bit PSTOP1 is set to 1, the Bφ clock
output stops at the end of the bus cycle and goes high. In the same way, bit PSTOP0 drives the
SDφ clock output on the PB7 pin high. When DDR for the PA7 pin is cleared to 0, the Bφ clock
output is disabled and the pin becomes an input port. When the SDRAM interface is disabled, the
PB7 pin can be used as I/O port.
Tables 28.4 and 28.5 show the states of the φ pin in each processing state.
Table 28.4 φ Pin (PA7) State in Each Processing State
AllRegister Setting Value
Normal
Module-
Operating
Sleep
Clock-Stop
Mode
Mode
Mode
Hi-Z
Software
Deep Software
Standby Mode
Standby Mode
Standby
IOKEEP = 1
Mode
Hi-Z
Hi-Z
Hi-Z
High
High
Hi-Z
High
Hi-Z
DDR
PSTOP1
0
x
Hi-Z
Hi-Z
Hi-Z
Hi-Z
1
0
Bφ output
Bφ output Bφ output
High
High
1
1
High
High
High
High
High
High
Hardware
OPE = 0
OPE = 1
IOKEEP = 0
[Legend]
x = Don't care
Table 28.5 φ Pin (PB7) State in Each Processing State (When SDRAM Interface is
Enabled)
AllRegister Setting Value
Normal
Module-
Operating
Sleep
Clock-Stop
PSTOP0
Mode
Mode
Mode
0
SDφ output
SDφ
Software
Deep Software
Standby Mode
Standby Mode
Hardware
Standby
OPE = 1
IOKEEP = 0
IOKEEP = 1
Mode
SDφ output High
High
High
High
Hi-Z
High
High
High
High
Hi-Z
OPE = 0
output
1
High
High
Rev. 2.00 Oct. 21, 2009 Page 1292 of 1454
REJ09B0498-0200
High
Section 28 Power-Down Modes
28.12
Usage Notes
28.12.1 I/O Port Status
In software standby mode or deep software standby mode, the I/O port states are retained.
Therefore, there is no reduction in current drawn due to output currents when high-level signals
are being output.
28.12.2 Current Consumption during Oscillation Settling Standby Period
Current consumption increases during the oscillation settling standby period.
28.12.3 Module Stop State of EXDMAC, DMAC, or DTC
Depending on the operating state of the EXDMAC, DMAC, and DTC, bits MSTPA14,
MSTPA13, and MSTPA12 may not be set to 1, respectively. The module stop state setting for the
EXDMAC, DMAC, or DTC should be carried out only when the EXDMAC, DMAC, or DTC is
not activated.
For details, refer to section 10, DMA Controller (DMAC), section 11, EXDMA Controller
(EXDMAC), and section 12, Data Transfer Controller (DTC).
28.12.4 On-Chip Peripheral Module Interrupts
Relevant interrupt operations cannot be performed in a module stop state. Consequently, if the
module stop state is entered when an interrupt has been requested, it will not be possible to clear
the CPU interrupt source or the DMAC or DTC activation source. Interrupts should therefore be
disabled before entering a module stop state.
28.12.5 Writing to MSTPCRA, MSTPCRB, and MSTPCRC
MSTPCRA, MSTPCRB, and MSTPCRC should only be written to by the CPU.
Rev. 2.00 Oct. 21, 2009 Page 1293 of 1454
REJ09B0498-0200
Section 28 Power-Down Modes
28.12.6 Control of Input Buffers by DIRQnE (n = 3 to 0)
When the input buffers for the P10/IRQ0-A to P13/IRQ3-A pins are enabled by setting the
DIRQnE bits (n = 3 to 0) in DSPIER to 1, the PnICR settings corresponding to these pins are
invalid. Therefore, note that external inputs to these pins, of which states are reflected on the
DIRQnF bits, are also input to the interrupt controller, peripheral modules and I/O ports, after the
DIRQnE bits (n = 3 to 0) are set to 1.
28.12.7 Conflict between a transition to deep standby mode and interrupts
If a conflict among the transition to deep software standby mode and generation of software
standby mode clearing source occurs, a transition to deep software standby mode is not made but
the software standby mode clearing sequence is executed. In this case, an interrupt exception
handling for the input interrupt starts after the oscillation settling time for software standby mode
(set by the STS4 to STS0 bits in SBYCR) has elapsed.
Note that if a conflict between a deep software standby mode transition and NMI interrupt occurs,
the NMI interrupt exception handling routine is required.
If a conflict among a deep software standby mode transition, the IRQ0 to IRQ11 interrupts, 32K
timer interrupt, and voltage-monitoring interrupt* occurs, a transition to deep software standby
mode can be made without executing the interrupt execution handling by clearing the SSIn bits in
SSIER to 0 beforehand.
Note: * Supported only by the H8SX/1665M Group
28.12.8 Bφ/SDRAMφ Output State
Bφ/SDRAMφ output is undefined for a maximum of one cycle immediately after deep software
standby mode is canceled with the IOKEEP bit cleared to 0 or immediately after the IOKEEP bit
is cleared after cancellation of deep software standby mode with the IOKEEP bit set to 1.
However, Bφ/SDRAMφ can be normally output by setting the IOKEEP, PSTOP1, and PSTP0 bits
to 1. For details, see section 28.8.4, Bφ/SDRAMφ Operation after Exit from Deep Software
Standby Mode.
Rev. 2.00 Oct. 21, 2009 Page 1294 of 1454
REJ09B0498-0200
Section 29 List of Registers
Section 29 List of Registers
The register list gives information on the on-chip I/O register addresses, how the register bits are
configured, and the register states in each operating mode. The information is given as shown
below.
1.
•
•
•
Register addresses (address order)
Registers are listed from the lower allocation addresses.
Registers are classified according to functional modules.
The number of Access Cycles indicates the number of states based on the specified reference
clock. For details, refer to section 9.5.4, External Bus Interface.
• Among the internal I/O register area, addresses not listed in the list of registers are undefined
or reserved addresses. Undefined and reserved addresses cannot be accessed. Do not access
these addresses; otherwise, the operation when accessing these bits and subsequent operations
cannot be guaranteed.
2.
•
•
•
Register bits
Bit configurations of the registers are listed in the same order as the register addresses.
Reserved bits are indicated by ⎯ in the bit name column.
Space in the bit name field indicates that the entire register is allocated to either the counter or
data.
• For the registers of 16 or 32 bits, the MSB is listed first.
• Byte configuration description order is subject to big endian.
3. Register states in each operating mode
• Register states are listed in the same order as the register addresses.
• For the initialized state of each bit, refer to the register description in the corresponding
section.
• The register states shown here are for the basic operating modes. If there is a specific reset for
an on-chip peripheral module, refer to the section on that on-chip peripheral module.
Rev. 2.00 Oct. 21, 2009 Page 1295 of 1454
REJ09B0498-0200
Section 29 List of Registers
29.1
Register Addresses (Address Order)
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Timer control register_4
TCR_4
8
H'FEA40
TMR_4
16
3Pφ/3Pφ
Timer control register_5
TCR_5
8
H'FEA41
TMR_5
16
3Pφ/3Pφ
Timer control/status register_4
TCSR_4
8
H'FEA42
TMR_4
16
3Pφ/3Pφ
Timer control/status register_5
TCSR_5
8
H'FEA43
TMR_5
16
3Pφ/3Pφ
Time constant registerA_4
TCORA_4
8
H'FEA44
TMR_4
16
3Pφ/3Pφ
Time constant registerA_5
TCORA_5
8
H'FEA45
TMR_5
16
3Pφ/3Pφ
Time constant registerB_4
TCORB_4
8
H'FEA46
TMR_4
16
3Pφ/3Pφ
Time constant registerB_5
TCORB_5
8
H'FEA47
TMR_5
16
3Pφ/3Pφ
Timer counter_4
TCNT_4
8
H'FEA48
TMR_4
16
3Pφ/3Pφ
Timer counter_5
TCNT_5
8
H'FEA49
TMR_5
16
3Pφ/3Pφ
Timer counter control register_4
TCCR_4
8
H'FEA4A
TMR_4
16
3Pφ/3Pφ
Timer counter control register_5
TCCR_5
8
H'FEA4B
TMR_5
16
3Pφ/3Pφ
CRC control register
CRCCR
8
H'FEA4C
CRC
16
3Pφ/3Pφ
CRC data input register
CRCDIR
8
H'FEA4D
CRC
16
3Pφ/3Pφ
CRC data output register
CRCDOR
16
H'FEA4E
CRC
16
3Pφ/3Pφ
Timer control register_6
TCR_6
8
H'FEA50
TMR_6
16
3Pφ/3Pφ
Timer control register_7
TCR_7
8
H'FEA51
TMR_7
16
3Pφ/3Pφ
Timer control/status register_6
TCSR_6
8
H'FEA52
TMR_6
16
3Pφ/3Pφ
Timer control/status register_7
TCSR_7
8
H'FEA53
TMR_7
16
3Pφ/3Pφ
Time constant registerA_6
TCORA_6
8
H'FEA54
TMR_6
16
3Pφ/3Pφ
Time constant registerA_7
TCORA_7
8
H'FEA55
TMR_7
16
3Pφ/3Pφ
Time constant registerB_6
TCORB_6
8
H'FEA56
TMR_6
16
3Pφ/3Pφ
Time constant registerB_7
TCORB_7
8
H'FEA57
TMR_7
16
3Pφ/3Pφ
Timer counter_6
TCNT_6
8
H'FEA58
TMR_6
16
3Pφ/3Pφ
Timer counter_7
TCNT_7
8
H'FEA59
TMR_7
16
3Pφ/3Pφ
Timer counter control register_6
TCCR_6
8
H'FEA5A
TMR_6
16
3Pφ/3Pφ
Timer counter control register_7
TCCR_7
8
H'FEA5B
TMR_7
16
3Pφ/3Pφ
A/D data register A_1
ADDRA_1
16
H'FEA80
A/D_1
16
3Pφ/3Pφ
A/D data register B_1
ADDRB_1
16
H'FEA82
A/D_1
16
3Pφ/3Pφ
Rev. 2.00 Oct. 21, 2009 Page 1296 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
A/D data register C_1
ADDRC_1
16
H'FEA84
A/D_1
16
3Pφ/3Pφ
A/D data register D_1
ADDRD_1
16
H'FEA86
A/D_1
16
3Pφ/3Pφ
A/D data register E_1
ADDRE_1
16
H'FEA90
A/D_1
16
3Pφ/3Pφ
A/D data register F_1
ADDRF_1
16
H'FEA92
A/D_1
16
3Pφ/3Pφ
A/D data register G_1
ADDRG_1
16
H'FEA94
A/D_1
16
3Pφ/3Pφ
A/D data register H_1
ADDRH_1
16
H'FEA96
A/D_1
16
3Pφ/3Pφ
A/D control/status register_1
ADCSR_1
8
H'FEAA0
A/D_1
16
3Pφ/3Pφ
A/D control register_1
ADCR_1
8
H'FEAA1
A/D_1
16
3Pφ/3Pφ
A/D mode selection register_1
ADMOSEL_1
8
H'FEAA2
A/D_1
16
3Pφ/3Pφ
A/D sampling state register_1
ADSSTR_1
8
H'FEAAB
A/D_1
16
3Pφ/3Pφ
Interrupt flag register 0
IFR0
8
H'FEE00
USB
8
3Pφ/3Pφ
Interrupt flag register 1
IFR1
8
H'FEE01
USB
8
3Pφ/3Pφ
Interrupt flag register 2
IFR2
8
H'FEE02
USB
8
3Pφ/3Pφ
Interrupt enable register 0
IER0
8
H'FEE04
USB
8
3Pφ/3Pφ
Interrupt enable register 1
IER1
8
H'FEE05
USB
8
3Pφ/3Pφ
Interrupt enable register 2
IER2
8
H'FEE06
USB
8
3Pφ/3Pφ
Interrupt select register 0
ISR0
8
H'FEE08
USB
8
3Pφ/3Pφ
Interrupt select register 1
ISR1
8
H'FEE09
USB
8
3Pφ/3Pφ
Interrupt select register 2
ISR2
8
H'FEE0A
USB
8
3Pφ/3Pφ
EP0i data register
EPDR0i
8
H'FEE0C
USB
8
3Pφ/3Pφ
EP0o data register
EPDR0o
8
H'FEE0D
USB
8
3Pφ/3Pφ
EP0s data register
EPDR0s
8
H'FEE0E
USB
8
3Pφ/3Pφ
EP1 data register
EPDR1
8
H'FEE10
USB
8
3Pφ/3Pφ
EP2 data register
EPDR2
8
H'FEE14
USB
8
3Pφ/3Pφ
EP3 data register
EPDR3
8
H'FEE18
USB
8
3Pφ/3Pφ
EP0o receive data size register
EPSZ0o
8
H'FEE24
USB
8
3Pφ/3Pφ
EP1 receive data size register
EPSZ1
8
H'FEE25
USB
8
3Pφ/3Pφ
Data status register
DASTS
8
H'FEE27
USB
8
3Pφ/3Pφ
FIFO clear register
FCLR
8
H'FEE28
USB
8
3Pφ/3Pφ
End point store register
EPSTL
8
H'FEE2A
USB
8
3Pφ/3Pφ
Trigger register
TRG
8
H'FEE2C
USB
8
3Pφ/3Pφ
Rev. 2.00 Oct. 21, 2009 Page 1297 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
DMA transfer setting register
DMA
8
H'FEE2D
USB
8
3Pφ/3Pφ
Configuration value register
CVR
8
H'FEE2E
USB
8
3Pφ/3Pφ
Control register
CTLR
8
H'FEE2F
USB
8
3Pφ/3Pφ
End point information register
EPIR
8
H'FEE32
USB
8
3Pφ/3Pφ
Transceiver test register 0
TRNTREG0
8
H'FEE44
USB
8
3Pφ/3Pφ
Transceiver test register 1
TRNTREG1
8
H'FEE45
USB
8
3Pφ/3Pφ
Port M data direction register
PMDDR
8
H'FEE50
I/O port
8
3Pφ/3Pφ
Port M data register
PMDR
8
H'FEE51
I/O port
8
3Pφ/3Pφ
Port M register
PORTM
8
H'FEE52
I/O port
8
3Pφ/3Pφ
Port M input buffer control register
PMICR
8
H'FEE53
I/O port
8
3Pφ/3Pφ
Serial mode register_5
SMR_5
8
H'FF600
SCI_5
8
3Pφ/3Pφ
Bit rate register_5
BRR_5
8
H'FF601
SCI_5
8
3Pφ/3Pφ
Serial control register_5
SCR_5
8
H'FF602
SCI_5
8
3Pφ/3Pφ
Transmit data register_5
TDR_5
8
H'FF603
SCI_5
8
3Pφ/3Pφ
Serial status register_5
SSR_5
8
H'FF604
SCI_5
8
3Pφ/3Pφ
Receive data register_5
RDR_5
8
H'FF605
SCI_5
8
3Pφ/3Pφ
Smart card mode register_5
SCMR_5
8
H'FF606
SCI_5
8
3Pφ/3Pφ
Serial extended mode register_5
SEMR_5
8
H'FF608
SCI_5
8
3Pφ/3Pφ
IrDA control register
IrCR
8
H'FF60C
SCI_5
8
3Pφ/3Pφ
Serial mode register_6
SMR_6
8
H'FF610
SCI_6
8
3Pφ/3Pφ
Bit rate register_6
BRR_6
8
H'FF611
SCI_6
8
3Pφ/3Pφ
Serial control register_6
SCR_6
8
H'FF612
SCI_6
8
3Pφ/3Pφ
Transmit data register_6
TDR_6
8
H'FF613
SCI_6
8
3Pφ/3Pφ
Serial status register_6
SSR_6
8
H'FF614
SCI_6
8
3Pφ/3Pφ
Receive data register_6
RDR_6
8
H'FF615
SCI_6
8
3Pφ/3Pφ
Smart card mode register_6
SCMR_6
8
H'FF616
SCI_6
8
3Pφ/3Pφ
Serial extended mode register_6
SEMR_6
8
H'FF618
SCI_6
8
3Pφ/3Pφ
PPG output control register_1
PCR_1
8
H'FF636
PPG_1
8
3Pφ/3Pφ
PPG output mode register_1
PMR_1
8
H'FF637
PPG_1
8
3Pφ/3Pφ
Next data enable register H_1
NDERH_1
8
H'FF638
PPG_1
8
3Pφ/3Pφ
Next data enable register L_1
NDERL_1
8
H'FF639
PPG_1
8
3Pφ/3Pφ
Rev. 2.00 Oct. 21, 2009 Page 1298 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Output data register H_1
PODRH_1
8
H'FF63A
PPG_1
8
3Pφ/3Pφ
Output data register L_1
PODRL_1
8
H'FF63B
PPG_1
8
3Pφ/3Pφ
1
Next data register H_1*
NDRH_1
8
H'FF63C
PPG_1
8
3Pφ/3Pφ
Next data register L_1*1
NDRL_1
8
H'FF63D
PPG_1
8
3Pφ/3Pφ
Next data register H_1*1
NDRH_1
8
H'FF63E
PPG_1
8
3Pφ/3Pφ
Next data register L_1*
NDRL_1
8
H'FF63F
PPG_1
8
3Pφ/3Pφ
Break address register AH
BARAH
16
H'FFA00
UBC
16
2Iφ/2Iφ
Break address register AL
BARAL
16
H'FFA02
UBC
16
2Iφ/2Iφ
Break address mask register AH
BAMRAH
16
H'FFA04
UBC
16
2Iφ/2Iφ
Break address mask register AL
BAMRAL
16
H'FFA06
UBC
16
2Iφ/2Iφ
1
Break address register BH
BARBH
16
H'FFA08
UBC
16
2Iφ/2Iφ
Break address register BL
BARBL
16
H'FFA0A
UBC
16
2Iφ/2Iφ
Break address mask register BH
BAMRBH
16
H'FFA0C
UBC
16
2Iφ/2Iφ
Break address mask register BL
BAMRBL
16
H'FFA0E
UBC
16
2Iφ/2Iφ
Break address register CH
BARCH
16
H'FFA10
UBC
16
2Iφ/2Iφ
Break address register CL
BARCL
16
H'FFA12
UBC
16
2Iφ/2Iφ
Break address mask register CH
BAMRCH
16
H'FFA14
UBC
16
2Iφ/2Iφ
Break address mask register CL
BAMRCL
16
H'FFA16
UBC
16
2Iφ/2Iφ
Break address register DH
BARDH
16
H'FFA18
UBC
16
2Iφ/2Iφ
Break address register DL
BARDL
16
H'FFA1A
UBC
16
2Iφ/2Iφ
Break address mask register DH
BAMRDH
16
H'FFA1C
UBC
16
2Iφ/2Iφ
Break address mask register DL
BAMRDL
16
H'FFA1E
UBC
16
2Iφ/2Iφ
Break control register A
BRCRA
16
H'FFA28
UBC
16
2Iφ/2Iφ
Break control register B
BRCRB
16
H'FFA2C
UBC
16
2Iφ/2Iφ
Break control register C
BRCRC
16
H'FFA30
UBC
16
2Iφ/2Iφ
Break control register D
BRCRD
16
H'FFA34
UBC
16
2Iφ/2Iφ
Timer control register
TCR32K
8
H'FFABC
TM32K
8
2Pφ/2Pφ
Timer counter 1
TCNT32K1
8
H'FFABD
TM32K
8
2Pφ/2Pφ
Timer counter 2
TCNT32K2
8
H'FFABE
TM32K
8
2Pφ/2Pφ
Timer counter 3
TCNT32K3
8
H'FFABF
TM32K
8
2Pφ/2Pφ
A/D sampling state register_0
ADSSTR_0
8
H'FFADB
A/D_0
16
2Pφ/2Pφ
Rev. 2.00 Oct. 21, 2009 Page 1299 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Timer start register
TSTRB
8
H'FFB00
TPU (unit 1)
16
2Pφ/2Pφ
Timer synchronous register
TSYRB
8
H'FFB01
TPU (unit 1)
16
2Pφ/2Pφ
Timer control register_6
TCR_6
8
H'FFB10
TPU_6
16
2Pφ/2Pφ
Timer mode register_6
TMDR_6
8
H'FFB11
TPU_6
16
2Pφ/2Pφ
Timer I/O control register H_6
TIORH_6
8
H'FFB12
TPU_6
16
2Pφ/2Pφ
Timer I/O control register L_6
TIORL_6
8
H'FFB13
TPU_6
16
2Pφ/2Pφ
Timer interrupt enable register_6
TIER_6
8
H'FFB14
TPU_6
16
2Pφ/2Pφ
Timer status register_6
TSR_6
8
H'FFB15
TPU_6
16
2Pφ/2Pφ
Timer counter_6
TCNT_6
16
H'FFB16
TPU_6
16
2Pφ/2Pφ
Timer general register A_6
TGRA_6
16
H'FFB18
TPU_6
16
2Pφ/2Pφ
Timer general register B_6
TGRB_6
16
H'FFB1A
TPU_6
16
2Pφ/2Pφ
Timer general register C_6
TGRC_6
16
H'FFB1C
TPU_6
16
2Pφ/2Pφ
Timer general register D_6
TGRD_6
16
H'FFB1E
TPU_6
16
2Pφ/2Pφ
Timer control register_7
TCR_7
8
H'FFB20
TPU_7
16
2Pφ/2Pφ
Timer mode register_7
TMDR_7
8
H'FFB21
TPU_7
16
2Pφ/2Pφ
Timer I/O control register_7
TIOR_7
8
H'FFB22
TPU_7
16
2Pφ/2Pφ
Timer interrupt enable register_7
TIER_7
8
H'FFB24
TPU_7
16
2Pφ/2Pφ
Timer status register_7
TSR_7
8
H'FFB25
TPU_7
16
2Pφ/2Pφ
Timer counter_7
TCNT_7
16
H'FFB26
TPU_7
16
2Pφ/2Pφ
Timer general register A_7
TGRA_7
16
H'FFB28
TPU_7
16
2Pφ/2Pφ
Timer general register B_7
TGRB_7
16
H'FFB2A
TPU_7
16
2Pφ/2Pφ
Timer control register_8
TCR_8
8
H'FFB30
TPU_8
16
2Pφ/2Pφ
Timer mode register_8
TMDR_8
8
H'FFB31
TPU_8
16
2Pφ/2Pφ
Timer I/O control register_8
TIOR_8
8
H'FFB32
TPU_8
16
2Pφ/2Pφ
Timer interrupt enable register_8
TIER_8
8
H'FFB34
TPU_8
16
2Pφ/2Pφ
Timer status register_8
TSR_8
8
H'FFB35
TPU_8
16
2Pφ/2Pφ
Timer counter_8
TCNT_8
16
H'FFB36
TPU_8
16
2Pφ/2Pφ
Timer general register A_8
TGRA_8
16
H'FFB38
TPU_8
16
2Pφ/2Pφ
Timer general register B_8
TGRB_8
16
H'FFB3A
TPU_8
16
2Pφ/2Pφ
Timer control register_9
TCR_9
8
H'FFB40
TPU_9
16
2Pφ/2Pφ
Timer mode register_9
TMDR_9
8
H'FFB41
TPU_9
16
2Pφ/2Pφ
Rev. 2.00 Oct. 21, 2009 Page 1300 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Timer I/O control register H_9
TIORH_9
8
H'FFB42
TPU_9
16
2Pφ/2Pφ
Timer I/O control register L_9
TIORL_9
8
H'FFB43
TPU_9
16
2Pφ/2Pφ
Timer interrupt enable register_9
TIER_9
8
H'FFB44
TPU_9
16
2Pφ/2Pφ
Timer status register_9
TSR_9
8
H'FFB45
TPU_9
16
2Pφ/2Pφ
Timer counter_9
TCNT_9
16
H'FFB46
TPU_9
16
2Pφ/2Pφ
Timer general register A_9
TGRA_9
16
H'FFB48
TPU_9
16
2Pφ/2Pφ
Timer general register B_9
TGRB_9
16
H'FFB4A
TPU_9
16
2Pφ/2Pφ
Timer general register C_9
TGRC_9
16
H'FFB4C
TPU_9
16
2Pφ/2Pφ
Timer general register D_9
TGRD_9
16
H'FFB4E
TPU_9
16
2Pφ/2Pφ
Timer control register_10
TCR_10
8
H'FFB50
TPU_10
16
2Pφ/2Pφ
Timer mode register_10
TMDR_10
8
H'FFB51
TPU_10
16
2Pφ/2Pφ
Timer I/O control register_10
TIOR_10
8
H'FFB52
TPU_10
16
2Pφ/2Pφ
Timer interrupt enable register_10
TIER_10
8
H'FFB54
TPU_10
16
2Pφ/2Pφ
Timer status register_10
TSR_10
8
H'FFB55
TPU_10
16
2Pφ/2Pφ
Timer counter_10
TCNT_10
16
H'FFB56
TPU_10
16
2Pφ/2Pφ
Timer general register A_10
TGRA_10
16
H'FFB58
TPU_10
16
2Pφ/2Pφ
Timer general register B_10
TGRB_10
16
H'FFB5A
TPU_10
16
2Pφ/2Pφ
Timer control register_11
TCR_11
8
H'FFB60
TPU_11
16
2Pφ/2Pφ
Timer mode register_11
TMDR_11
8
H'FFB61
TPU_11
16
2Pφ/2Pφ
Timer I/O control register_11
TIOR_11
8
H'FFB62
TPU_11
16
2Pφ/2Pφ
Timer interrupt enable register_11
TIER_11
8
H'FFB64
TPU_11
16
2Pφ/2Pφ
Timer status register_11
TSR_11
8
H'FFB65
TPU_11
16
2Pφ/2Pφ
Timer counter_11
TCNT_11
16
H'FFB66
TPU_11
16
2Pφ/2Pφ
Timer general register A_11
TGRA_11
16
H'FFB68
TPU_11
16
2Pφ/2Pφ
Timer general register B_11
TGRB_11
16
H'FFB6A
TPU_11
16
2Pφ/2Pφ
Port 1 data direction register
P1DDR
8
H'FFB80
I/O port
8
2Pφ/2Pφ
Port 2 data direction register
P2DDR
8
H'FFB81
I/O port
8
2Pφ/2Pφ
Port 3 data direction register
P3DDR
8
H'FFB82
I/O port
8
2Pφ/2Pφ
Port 6 data direction register
P6DDR
8
H'FFB85
I/O port
8
2Pφ/2Pφ
Port A data direction register
PADDR
8
H'FFB89
I/O port
8
2Pφ/2Pφ
Port B data direction register
PBDDR
8
H'FFB8A
I/O port
8
2Pφ/2Pφ
Rev. 2.00 Oct. 21, 2009 Page 1301 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Port C data direction register
PCDDR
8
H'FFB8B
I/O port
8
2Pφ/2Pφ
Port D data direction register
PDDDR
8
H'FFB8C
I/O port
8
2Pφ/2Pφ
Port E data direction register
PEDDR
8
H'FFB8D
I/O port
8
2Pφ/2Pφ
Port F data direction register
PFDDR
8
H'FFB8E
I/O port
8
2Pφ/2Pφ
Port 1 input buffer control register
P1ICR
8
H'FFB90
I/O port
8
2Pφ/2Pφ
Port 2 input buffer control register
P2ICR
8
H'FFB91
I/O port
8
2Pφ/2Pφ
Port 3 input buffer control register
P3ICR
8
H'FFB92
I/O port
8
2Pφ/2Pφ
Port 5 input buffer control register
P5ICR
8
H'FFB94
I/O port
8
2Pφ/2Pφ
Port 6 input buffer control register
P6ICR
8
H'FFB95
I/O port
8
2Pφ/2Pφ
Port A input buffer control register
PAICR
8
H'FFB99
I/O port
8
2Pφ/2Pφ
Port B input buffer control register
PBICR
8
H'FFB9A
I/O port
8
2Pφ/2Pφ
Port C input buffer control register
PCICR
8
H'FFB9B
I/O port
8
2Pφ/2Pφ
Port D input buffer control register
PDICR
8
H'FFB9C
I/O port
8
2Pφ/2Pφ
Port E input buffer control register
PEICR
8
H'FFB9D
I/O port
8
2Pφ/2Pφ
Port F input buffer control register
PFICR
8
H'FFB9E
I/O port
8
2Pφ/2Pφ
Port H register
PORTH
8
H'FFBA0
I/O port
8
2Pφ/2Pφ
Port I register
PORTI
8
H'FFBA1
I/O port
8
2Pφ/2Pφ
Port J register
PORTJ
8
H'FFBA2
I/O port
8
2Pφ/2Pφ
Port K register
PORTK
8
H'FFBA3
I/O port
8
2Pφ/2Pφ
Port H data register
PHDR
8
H'FFBA4
I/O port
8
2Pφ/2Pφ
Port I data register
PIDR
8
H'FFBA5
I/O port
8
2Pφ/2Pφ
Port J data register
PJDR
8
H'FFBA6
I/O port
8
2Pφ/2Pφ
Port K data register
PKDR
8
H'FFBA7
I/O port
8
2Pφ/2Pφ
Port H data direction register
PHDDR
8
H'FFBA8
I/O port
8
2Pφ/2Pφ
Port I data direction register
PIDDR
8
H'FFBA9
I/O port
8
2Pφ/2Pφ
Port J data direction register
PJDDR
8
H'FFBAA
I/O port
8
2Pφ/2Pφ
Port K data direction register
PKDDR
8
H'FFBAB
I/O port
8
2Pφ/2Pφ
Port H input buffer control register
PHICR
8
H'FFBAC
I/O port
8
2Pφ/2Pφ
Port I input buffer control register
PIICR
8
H'FFBAD
I/O port
8
2Pφ/2Pφ
Port J input buffer control register
PJICR
8
H'FFBAE
I/O port
8
2Pφ/2Pφ
Port K input buffer control register
PKICR
8
H'FFBAF
I/O port
8
2Pφ/2Pφ
Rev. 2.00 Oct. 21, 2009 Page 1302 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Port D pull-up MOS control register
PDPCR
8
H'FFBB4
I/O port
8
2Pφ/2Pφ
Port E pull-up MOS control register
PEPCR
8
H'FFBB5
I/O port
8
2Pφ/2Pφ
Port F pull-up MOS control register
PFPCR
8
H'FFBB6
I/O port
8
2Pφ/2Pφ
Port H pull-up MOS control register
PHPCR
8
H'FFBB8
I/O port
8
2Pφ/2Pφ
Port I pull-up MOS control register
PIPCR
8
H'FFBB9
I/O port
8
2Pφ/2Pφ
Port J pull-up MOS control register
PJPCR
8
H'FFBBA
I/O port
8
2Pφ/2Pφ
Port K pull-up MOS control register
PKPCR
8
H'FFBBB
I/O port
8
2Pφ/2Pφ
Port 2 open-drain control register
P2ODR
8
H'FFBBC
I/O port
8
2Pφ/2Pφ
Port F open-drain control register
PFODR
8
H'FFBBD
I/O port
8
2Pφ/2Pφ
Port function control register 0
PFCR0
8
H'FFBC0
I/O port
8
2Pφ/3Pφ
Port function control register 1
PFCR1
8
H'FFBC1
I/O port
8
2Pφ/3Pφ
Port function control register 2
PFCR2
8
H'FFBC2
I/O port
8
2Pφ/3Pφ
Port function control register 4
PFCR4
8
H'FFBC4
I/O port
8
2Pφ/3Pφ
Port function control register 6
PFCR6
8
H'FFBC6
I/O port
8
2Pφ/3Pφ
Port function control register 7
PFCR7
8
H'FFBC7
I/O port
8
2Pφ/3Pφ
Port function control register 8
PFCR8
8
H'FFBC8
I/O port
8
2Pφ/3Pφ
Port function control register 9
PFCR9
8
H'FFBC9
I/O port
8
2Pφ/3Pφ
Port function control register A
PFCRA
8
H'FFBCA
I/O port
8
2Pφ/3Pφ
Port function control register B
PFCRB
8
H'FFBCB
I/O port
8
2Pφ/3Pφ
Port function control register C
PFCRC
8
H'FFBCC
I/O port
8
2Pφ/3Pφ
Port function control register D
PFCRD
8
H'FFBCD
I/O port
8
2Pφ/3Pφ
Software standby release IRQ enable register SSIER
16
H'FFBCE
INTC
8
2Pφ/3Pφ
Deep standby backup register 0
DPSBKR0
8
H'FFBF0
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 1
DPSBKR1
8
H'FFBF1
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 2
DPSBKR2
8
H'FFBF2
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 3
DPSBKR3
8
H'FFBF3
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 4
DPSBKR4
8
H'FFBF4
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 5
DPSBKR5
8
H'FFBF5
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 6
DPSBKR6
8
H'FFBF6
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 7
DPSBKR7
8
H'FFBF7
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 8
DPSBKR8
8
H'FFBF8
SYSTEM
8
2Iφ/3Iφ
Rev. 2.00 Oct. 21, 2009 Page 1303 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Deep standby backup register 9
DPSBKR9
8
H'FFBF9
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 10
DPSBKR10
8
H'FFBFA
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 11
DPSBKR11
8
H'FFBFB
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 12
DPSBKR12
8
H'FFBFC
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 13
DPSBKR13
8
H'FFBFD
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 14
DPSBKR14
8
H'FFBFE
SYSTEM
8
2Iφ/3Iφ
Deep standby backup register 15
DPSBKR15
8
H'FFBFF
SYSTEM
8
2Iφ/3Iφ
DMA source address register_0
DSAR_0
32
H'FFC00
DMAC_0
16
2Iφ/2Iφ
DMA destination address register_0
DDAR_0
32
H'FFC04
DMAC_0
16
2Iφ/2Iφ
DMA offset register_0
DOFR_0
32
H'FFC08
DMAC_0
16
2Iφ/2Iφ
DMA transfer count register_0
DTCR_0
32
H'FFC0C
DMAC_0
16
2Iφ/2Iφ
DMA block size register_0
DBSR_0
32
H'FFC10
DMAC_0
16
2Iφ/2Iφ
DMA mode control register_0
DMDR_0
32
H'FFC14
DMAC_0
16
2Iφ/2Iφ
DMA address control register_0
DACR_0
32
H'FFC18
DMAC_0
16
2Iφ/2Iφ
DMA source address register_1
DSAR_1
32
H'FFC20
DMAC_1
16
2Iφ/2Iφ
DMA destination address register_1
DDAR_1
32
H'FFC24
DMAC_1
16
2Iφ/2Iφ
DMA offset register_1
DOFR_1
32
H'FFC28
DMAC_1
16
2Iφ/2Iφ
DMA transfer count register_1
DTCR_1
32
H'FFC2C
DMAC_1
16
2Iφ/2Iφ
DMA block size register_1
DBSR_1
32
H'FFC30
DMAC_1
16
2Iφ/2Iφ
DMA mode control register_1
DMDR_1
32
H'FFC34
DMAC_1
16
2Iφ/2Iφ
DMA address control register_1
DACR_1
32
H'FFC38
DMAC_1
16
2Iφ/2Iφ
DMA source address register_2
DSAR_2
32
H'FFC40
DMAC_2
16
2Iφ/2Iφ
DMA destination address register_2
DDAR_2
32
H'FFC44
DMAC_2
16
2Iφ/2Iφ
DMA offset register_2
DOFR_2
32
H'FFC48
DMAC_2
16
2Iφ/2Iφ
DMA transfer count register_2
DTCR_2
32
H'FFC4C
DMAC_2
16
2Iφ/2Iφ
DMA block size register_2
DBSR_2
32
H'FFC50
DMAC_2
16
2Iφ/2Iφ
DMA mode control register_2
DMDR_2
32
H'FFC54
DMAC_2
16
2Iφ/2Iφ
DMA address control register_2
DACR_2
32
H'FFC58
DMAC_2
16
2Iφ/2Iφ
DMA source address register_3
DSAR_3
32
H'FFC60
DMAC_3
16
2Iφ/2Iφ
DMA destination address register_3
DDAR_3
32
H'FFC64
DMAC_3
16
2Iφ/2Iφ
DMA offset register_3
DOFR_3
32
H'FFC68
DMAC_3
16
2Iφ/2Iφ
Rev. 2.00 Oct. 21, 2009 Page 1304 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
DMA transfer count register_3
DTCR_3
32
H'FFC6C
DMAC_3
16
2Iφ/2Iφ
DMA block size register_3
DBSR_3
32
H'FFC70
DMAC_3
16
2Iφ/2Iφ
DMA mode control register_3
DMDR_3
32
H'FFC74
DMAC_3
16
2Iφ/2Iφ
DMA address control register_3
DACR_3
32
H'FFC78
DMAC_3
16
2Iφ/2Iφ
EXDMA source address register_0
EDSAR_0
32
H'FFC80
EXDMAC_0
16
2Iφ/2Iφ
EXDMA destination address register_0
EDDAR_0
32
H'FFC84
EXDMAC_0
16
2Iφ/2Iφ
EXDMA offset register_0
EDOFR_0
32
H'FFC88
EXDMAC_0
16
2Iφ/2Iφ
EXDMA transfer count register_0
EDTCR_0
32
H'FFC8C
EXDMAC_0
16
2Iφ/2Iφ
EXDMA block size register_0
EDBSR_0
32
H'FFC90
EXDMAC_0
16
2Iφ/2Iφ
EXDMA mode control regisrer_0
EDMDR_0
32
H'FFC94
EXDMAC_0
16
2Iφ/2Iφ
EXDMA address control register_0
EDACR_0
32
H'FFC98
EXDMAC_0
16
2Iφ/2Iφ
EXDMA source address register_1
EDSAR_1
32
H'FFCA0
EXDMAC_1
16
2Iφ/2Iφ
EXDMA destination address register_1
EDDAR_1
32
H'FFCA4
EXDMAC_1
16
2Iφ/2Iφ
EXDMA offset register_1
EDOFR_1
32
H'FFCA8
EXDMAC_1
16
2Iφ/2Iφ
EXDMA transfer count register_1
EDTCR_1
32
H'FFCAC
EXDMAC_1
16
2Iφ/2Iφ
EXDMA block size register_1
EDBSR_1
32
H'FFCB0
EXDMAC_1
16
2Iφ/2Iφ
EXDMA mode control register_1
EDMDR_1
32
H'FFCB4
EXDMAC_1
16
2Iφ/2Iφ
EXDMA address control register_1
EDACR_1
32
H'FFCB8
EXDMAC_1
16
2Iφ/2Iφ
EXDMA source address register_2
EDSAR_2
32
H'FFCC0
EXDMAC_2
16
2Iφ/2Iφ
EXDMA destination address register_2
EDDAR_2
32
H'FFCC4
EXDMAC_2
16
2Iφ/2Iφ
EXDMA offset register_2
EDOFR_2
32
H'FFCC8
EXDMAC_2
16
2Iφ/2Iφ
EXDMA transfer count register_2
EDTCR_2
32
H'FFCCC
EXDMAC_2
16
2Iφ/2Iφ
EXDMA block size register_2
EDBSR_2
32
H'FFCD0
EXDMAC_2
16
2Iφ/2Iφ
EXDMA mode control register_2
EDMDR_2
32
H'FFCD4
EXDMAC_2
16
2Iφ/2Iφ
EXDMA address control register_2
EDACR_2
32
H'FFCD8
EXDMAC_2
16
2Iφ/2Iφ
EXDMA source address register_3
EDSAR_3
32
H'FFCE0
EXDMAC_3
16
2Iφ/2Iφ
EXDMA destination address register_3
EDDAR_3
32
H'FFCE4
EXDMAC_3
16
2Iφ/2Iφ
EXDMA offset register_3
EDOFR_3
32
H'FFCE8
EXDMAC_3
16
2Iφ/2Iφ
EXDMA transfer count register_3
EDTCR_3
32
H'FFCEC
EXDMAC_3
16
2Iφ/2Iφ
EXDMA block size register_3
EDBSR_3
32
H'FFCF0
EXDMAC_3
16
2Iφ/2Iφ
EXDMA mode control register_3
EDMDR_3
32
H'FFCF4
EXDMAC_3
16
2Iφ/2Iφ
Rev. 2.00 Oct. 21, 2009 Page 1305 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
EXDMA address control register_3
EDACR_3
32
H'FFCF8
EXDMAC_3
16
2Iφ/2Iφ
Cluster buffer register 0
CLSBR0
32
H'FFD00
EXDMAC
16
2Iφ/2Iφ
Cluster buffer register 1
CLSBR1
32
H'FFD04
EXDMAC
16
2Iφ/2Iφ
Cluster buffer register 2
CLSBR2
32
H'FFD08
EXDMAC
16
2Iφ/2Iφ
Cluster buffer register 3
CLSBR3
32
H'FFD0C
EXDMAC
16
2Iφ/2Iφ
Cluster buffer register 4
CLSBR4
32
H'FFD10
EXDMAC
16
2Iφ/2Iφ
Cluster buffer register 5
CLSBR5
32
H'FFD14
EXDMAC
16
2Iφ/2Iφ
Cluster buffer register 6
CLSBR6
32
H'FFD18
EXDMAC
16
2Iφ/2Iφ
Cluster buffer register 7
CLSBR7
32
H'FFD1C
EXDMAC
16
2Iφ/2Iφ
DMA module request select register_0
DMRSR_0
8
H'FFD20
DMAC_0
16
2Iφ/2Iφ
DMA module request select register_1
DMRSR_1
8
H'FFD21
DMAC_1
16
2Iφ/2Iφ
DMA module request select register_2
DMRSR_2
8
H'FFD22
DMAC_2
16
2Iφ/2Iφ
DMA module request select register_3
DMRSR_3
8
H'FFD23
DMAC_3
16
2Iφ/2Iφ
Interrupt priority register A
IPRA
16
H'FFD40
INTC
16
2Iφ/3Iφ
Interrupt priority register B
IPRB
16
H'FFD42
INTC
16
2Iφ/3Iφ
Interrupt priority register C
IPRC
16
H'FFD44
INTC
16
2Iφ/3Iφ
Interrupt priority register D
IPRD
16
H'FFD46
INTC
16
2Iφ/3Iφ
Interrupt priority register E
IPRE
16
H'FFD48
INTC
16
2Iφ/3Iφ
Interrupt priority register F
IPRF
16
H'FFD4A
INTC
16
2Iφ/3Iφ
Interrupt priority register G
IPRG
16
H'FFD4C
INTC
16
2Iφ/3Iφ
Interrupt priority register H
IPRH
16
H'FFD4E
INTC
16
2Iφ/3Iφ
Interrupt priority register I
IPRI
16
H'FFD50
INTC
16
2Iφ/3Iφ
Interrupt priority register J
IPRJ
16
H'FFD52
INTC
16
2Iφ/3Iφ
Interrupt priority register K
IPRK
16
H'FFD54
INTC
16
2Iφ/3Iφ
Interrupt priority register L
IPRL
16
H'FFD56
INTC
16
2Iφ/3Iφ
Interrupt priority register M
IPRM
16
H'FFD58
INTC
16
2Iφ/3Iφ
Interrupt priority register N
IPRN
16
H'FFD5A
INTC
16
2Iφ/3Iφ
Interrupt priority register O
IPRO
16
H'FFD5C
INTC
16
2Iφ/3Iφ
Interrupt priority register Q
IPRQ
16
H'FFD60
INTC
16
2Iφ/3Iφ
Interrupt priority register R
IPRR
16
H'FFD62
INTC
16
2Iφ/3Iφ
IRQ sense control register H
ISCRH
16
H'FFD68
INTC
16
2Iφ/3Iφ
Rev. 2.00 Oct. 21, 2009 Page 1306 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
IRQ sense control register L
ISCRL
16
H'FFD6A
INTC
16
2Iφ/3Iφ
DTC vector base register
DTCVBR
32
H'FFD80
BSC
16
2Iφ/3Iφ
Bus width control register
ABWCR
16
H'FFD84
BSC
16
2Iφ/3Iφ
Access state control register
ASTCR
16
H'FFD86
BSC
16
2Iφ/3Iφ
Wait control register A
WTCRA
16
H'FFD88
BSC
16
2Iφ/3Iφ
Wait control register B
WTCRB
16
H'FFD8A
BSC
16
2Iφ/3Iφ
Read strobe timing control register
RDNCR
16
H'FFD8C
BSC
16
2Iφ/3Iφ
CS assertion period control register
CSACR
16
H'FFD8E
BSC
16
2Iφ/3Iφ
Idle control register
IDLCR
16
H'FFD90
BSC
16
2Iφ/3Iφ
Bus control register 1
BCR1
16
H'FFD92
BSC
16
2Iφ/3Iφ
Bus control register 2
BCR2
8
H'FFD94
BSC
16
2Iφ/3Iφ
Endian control register
ENDIANCR
8
H'FFD95
BSC
16
2Iφ/3Iφ
SRAM mode control register
SRAMCR
16
H'FFD98
BSC
16
2Iφ/3Iφ
Burst ROM interface control register
BROMCR
16
H'FFD9A
BSC
16
2Iφ/3Iφ
Address/data multiplexed I/O control register
MPXCR
16
H'FFD9C
BSC
16
2Iφ/3Iφ
DRAM control register
DRAMCR
16
H'FFDA0
BSC
16
2Iφ/3Iφ
DRAM access control register
DRACCR
16
H'FFDA2
BSC
16
2Iφ/3Iφ
Synchronous DRAM control register
SDCR
16
H'FFDA4
BSC
16
2Iφ/3Iφ
Refresh control register
REFCR
16
H'FFDA6
BSC
16
2Iφ/3Iφ
Refresh timer counter
RTCNT
8
H'FFDA8
BSC
16
2Iφ/3Iφ
Refresh time constant register
RTCOR
8
H'FFDA9
BSC
16
2Iφ/3Iφ
RAM emulation register
RAMER
8
H'FFD9E
BSC
16
2Iφ/3Iφ
Mode control register
MDCR
16
H'FFDC0
SYSTEM
16
2Iφ/3Iφ
System control register
SYSCR
16
H'FFDC2
SYSTEM
16
2Iφ/3Iφ
System clock control register
SCKCR
16
H'FFDC4
SYSTEM
16
2Iφ/3Iφ
Standby control register
SBYCR
16
H'FFDC6
SYSTEM
16
2Iφ/3Iφ
Module stop control register A
MSTPCRA
16
H'FFDC8
SYSTEM
16
2Iφ/3Iφ
Module stop control register B
MSTPCRB
16
H'FFDCA
SYSTEM
16
2Iφ/3Iφ
Module stop control register C
MSTPCRC
16
H'FFDCC
SYSTEM
16
2Iφ/3Iφ
Subclock control register
SUBCKCR
8
H'FFDCF
SYSTEM
16
2Iφ/3Iφ
Flash code control/status register
FCCS
8
H'FFDE8
FLASH
16
2Iφ/2Iφ
Rev. 2.00 Oct. 21, 2009 Page 1307 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Flash program code select register
FPCS
8
H'FFDE9
FLASH
16
2Iφ/2Iφ
Flash erase code select register
FECS
8
H'FFDEA
FLASH
16
2Iφ/2Iφ
Flash key code register
FKEY
8
H'FFDEC
FLASH
16
2Iφ/2Iφ
Flash MAT select register
FMATS
8
H'FFDED
FLASH
16
2Iφ/2Iφ
Flash transfer destination address register
FTDAR
8
H'FFDEE
FLASH
16
2Iφ/2Iφ
Deep standby control register
DPSBYCR
8
H'FFE70
SYSTEM
8
2Iφ/3Iφ
Deep standby wait control register
DPSWCR
8
H'FFE71
SYSTEM
8
2Iφ/3Iφ
Deep standby interrupt enable register
DPSIER
8
H'FFE72
SYSTEM
8
2Iφ/3Iφ
Deep standby interrupt flag register
DPSIFR
8
H'FFE73
SYSTEM
8
2Iφ/3Iφ
Deep standby interrupt edge register
DPSIEGR
8
H'FFE74
SYSTEM
8
2Iφ/3Iφ
Reset status register
RSTSR
8
H'FFE75
SYSTEM
8
2Iφ/3Iφ
Low voltage detection control register*2
LVDCR
8
H'FFE78
SYSTEM
8
2Iφ/3Iφ
Serial extended mode register_2
SEMR_2
8
H'FFE84
SCI_2
8
2Pφ/2Pφ
Serial mode register_4
SMR_4
8
H'FFE90
SCI_4
8
2Pφ/2Pφ
Bit rate register_4
BRR_4
8
H'FFE91
SCI_4
8
2Pφ/2Pφ
Serial control register_4
SCR_4
8
H'FFE92
SCI_4
8
2Pφ/2Pφ
Transmit data register_4
TDR_4
8
H'FFE93
SCI_4
8
2Pφ/2Pφ
Serial status register_4
SSR_4
8
H'FFE94
SCI_4
8
2Pφ/2Pφ
Receive data register_4
RDR_4
8
H'FFE95
SCI_4
8
2Pφ/2Pφ
Smart card mode register_4
SCMR_4
8
H'FFE96
SCI_4
8
2Pφ/2Pφ
2
ICCRA_0
8
H'FFEB0
IIC2_0
8
2Pφ/2Pφ
2
ICCRB_0
8
H'FFEB1
IIC2_0
8
2Pφ/2Pφ
2
ICMR_0
8
H'FFEB2
IIC2_0
8
2Pφ/2Pφ
2
ICIER_0
8
H'FFEB3
IIC2_0
8
2Pφ/2Pφ
2
I C bus status register_0
ICSR_0
8
H'FFEB4
IIC2_0
8
2Pφ/2Pφ
Slave address register_0
SAR_0
8
H'FFEB5
IIC2_0
8
2Pφ/2Pφ
I C bus control register A_0
I C bus control register B_0
I C bus mode register_0
I C bus interrupt enable register_0
2
I C bus transmit data register_0
ICDRT_0
8
H'FFEB6
IIC2_0
8
2Pφ/2Pφ
I2C bus receive data register_0
ICDRR_0
8
H'FFEB7
IIC2_0
8
2Pφ/2Pφ
I2C bus control register A_1
ICCRA_1
8
H'FFEB8
IIC2_1
8
2Pφ/2Pφ
2
ICCRB_1
8
H'FFEB9
IIC2_1
8
2Pφ/2Pφ
2
ICMR_1
8
H'FFEBA
IIC2_1
8
2Pφ/2Pφ
I C bus control register B_1
I C bus mode register_1
Rev. 2.00 Oct. 21, 2009 Page 1308 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
2
ICIER_1
8
H'FFEBB
IIC2_1
8
2Pφ/2Pφ
2
I C bus status register_1
ICSR_1
8
H'FFEBC
IIC2_1
8
2Pφ/2Pφ
Slave address register_1
SAR_1
8
H'FFEBD
IIC2_1
8
2Pφ/2Pφ
I2C bus transmit data register_1
ICDRT_1
8
H'FFEBE
IIC2_1
8
2Pφ/2Pφ
I C bus receive data register_1
ICDRR_1
8
H'FFEBF
IIC2_1
8
2Pφ/2Pφ
Timer control register_2
TCR_2
8
H'FFEC0
TMR_2
16
2Pφ/2Pφ
Timer control register_3
TCR_3
8
H'FFEC1
TMR_3
16
2Pφ/2Pφ
Timer control/status register_2
TCSR_2
8
H'FFEC2
TMR_2
16
2Pφ/2Pφ
Timer control/status register_3
TCSR_3
8
H'FFEC3
TMR_3
16
2Pφ/2Pφ
Time constant register A_2
TCORA_2
8
H'FFEC4
TMR_2
16
2Pφ/2Pφ
Time constant register A_3
TCORA_3
8
H'FFEC5
TMR_3
16
2Pφ/2Pφ
Time constant register B_2
TCORB_2
8
H'FFEC6
TMR_2
16
2Pφ/2Pφ
Time constant register B_3
TCORB_3
8
H'FFEC7
TMR_3
16
2Pφ/2Pφ
Timer counter_2
TCNT_2
8
H'FFEC8
TMR_2
16
2Pφ/2Pφ
Timer counter_3
TCNT_3
8
H'FFEC9
TMR_3
16
2Pφ/2Pφ
Timer counter control register_2
TCCR_2
8
H'FFECA
TMR_2
16
2Pφ/2Pφ
Timer counter control register_3
TCCR_3
8
H'FFECB
TMR_3
16
2Pφ/2Pφ
Timer control register_4
TCR_4
8
H'FFEE0
TPU_4
16
2Pφ/2Pφ
Timer mode register_4
TMDR_4
8
H'FFEE1
TPU_4
16
2Pφ/2Pφ
Timer I/O control register_4
TIOR_4
8
H'FFEE2
TPU_4
16
2Pφ/2Pφ
Timer interrupt enable register_4
TIER_4
8
H'FFEE4
TPU_4
16
2Pφ/2Pφ
Timer status register_4
TSR_4
8
H'FFEE5
TPU_4
16
2Pφ/2Pφ
Timer counter_4
TCNT_4
16
H'FFEE6
TPU_4
16
2Pφ/2Pφ
Timer general register A_4
TGRA_4
16
H'FFEE8
TPU_4
16
2Pφ/2Pφ
Timer general register B_4
TGRB_4
16
H'FFEEA
TPU_4
16
2Pφ/2Pφ
Timer control register_5
TCR_5
8
H'FFEF0
TPU_5
16
2Pφ/2Pφ
Timer mode register_5
TMDR_5
8
H'FFEF1
TPU_5
16
2Pφ/2Pφ
Timer I/O control register_5
TIOR_5
8
H'FFEF2
TPU_5
16
2Pφ/2Pφ
Timer interrupt enable register_5
TIER_5
8
H'FFEF4
TPU_5
16
2Pφ/2Pφ
Timer status register_5
TSR_5
8
H'FFEF5
TPU_5
16
2Pφ/2Pφ
Timer counter_5
TCNT_5
16
H'FFEF6
TPU_5
16
2Pφ/2Pφ
Register Name
I C bus interrupt enable register_1
2
Rev. 2.00 Oct. 21, 2009 Page 1309 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Timer general register A_5
TGRA_5
16
H'FFEF8
TPU_5
16
2Pφ/2Pφ
Timer general register B_5
TGRB_5
16
H'FFEFA
TPU_5
16
2Pφ/2Pφ
DTC enable register A
DTCERA
16
H'FFF20
INTC
16
2Iφ/3Iφ
DTC enable register B
DTCERB
16
H'FFF22
INTC
16
2Iφ/3Iφ
DTC enable register C
DTCERC
16
H'FFF24
INTC
16
2Iφ/3Iφ
DTC enable register D
DTCERD
16
H'FFF26
INTC
16
2Iφ/3Iφ
DTC enable register E
DTCERE
16
H'FFF28
INTC
16
2Iφ/3Iφ
DTC enable register F
DTCERF
16
H'FFF2A
INTC
16
2Iφ/3Iφ
DTC control register
DTCCR
8
H'FFF30
INTC
16
2Iφ/3Iφ
Interrupt control register
INTCR
8
H'FFF32
INTC
16
2Iφ/3Iφ
CPU priority control register
CPUPCR
8
H'FFF33
INTC
16
2Iφ/3Iφ
IRQ enable register
IER
16
H'FFF34
INTC
16
2Iφ/3Iφ
IRQ status register
ISR
16
H'FFF36
INTC
16
2Iφ/3Iφ
Port 1 register
PORT1
8
H'FFF40
I/O port
8
2Pφ/-
Port 2 register
PORT2
8
H'FFF41
I/O port
8
2Pφ/-
Port 3 register
PORT3
8
H'FFF42
I/O port
8
2Pφ/-
Port 5 register
PORT5
8
H'FFF44
I/O port
8
2Pφ/-
Port 6 register
PORT6
8
H'FFF45
I/O port
8
2Pφ/-
Port A register
PORTA
8
H'FFF49
I/O port
8
2Pφ/-
Port B register
PORTB
8
H'FFF4A
I/O port
8
2Pφ/-
Port C register
PORTC
8
H'FFF4B
I/O port
8
2Pφ/-
Port D register
PORTD
8
H'FFF4C
I/O port
8
2Pφ/-
Port E register
PORTE
8
H'FFF4D
I/O port
8
2Pφ/-
Port F register
PORTF
8
H'FFF4E
I/O port
8
2Pφ/-
Port 1 data register
P1DR
8
H'FFF50
I/O port
8
2Pφ/2Pφ
Port 2 data register
P2DR
8
H'FFF51
I/O port
8
2Pφ/2Pφ
Port 3 data register
P3DR
8
H'FFF52
I/O port
8
2Pφ/2Pφ
Port 6 data register
P6DR
8
H'FFF55
I/O port
8
2Pφ/2Pφ
Port A data register
PADR
8
H'FFF59
I/O port
8
2Pφ/2Pφ
Port B data register
PBDR
8
H'FFF5A
I/O port
8
2Pφ/2Pφ
Port C data register
PCDR
8
H'FFF5B
I/O port
8
2Pφ/2Pφ
Rev. 2.00 Oct. 21, 2009 Page 1310 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Port D data register
PDDR
8
H'FFF5C
I/O port
8
2Pφ/2Pφ
Port E data register
PEDR
8
H'FFF5D
I/O port
8
2Pφ/2Pφ
Port F data register
PFDR
8
H'FFF5E
I/O port
8
2Pφ/2Pφ
Serial mode register_2
SMR_2
8
H'FFF60
SCI_2
8
2Pφ/2Pφ
Bit rate register_2
BRR_2
8
H'FFF61
SCI_2
8
2Pφ/2Pφ
Serial control register_2
SCR_2
8
H'FFF62
SCI_2
8
2Pφ/2Pφ
Transmit data register_2
TDR_2
8
H'FFF63
SCI_2
8
2Pφ/2Pφ
Serial status register_2
SSR_2
8
H'FFF64
SCI_2
8
2Pφ/2Pφ
Receive data register_2
RDR_2
8
H'FFF65
SCI_2
8
2Pφ/2Pφ
Smart card mode register_2
SCMR_2
8
H'FFF66
SCI_2
8
2Pφ/2Pφ
D/A data register 0H
DADR0H
8
H'FFF68
D/A
8
2Pφ/2Pφ
D/A data register 1H
DADR1H
8
H'FFF69
D/A
8
2Pφ/2Pφ
D/A control register 01
DACR01
8
H'FFF6A
D/A
8
2Pφ/2Pφ
D/A data register 01T
DADR01T
8
H'FFF6B
D/A
8
2Pφ/2Pφ
PPG output control register
PCR
8
H'FFF76
PPG_0
8
2Pφ/2Pφ
PPG output mode register
PMR
8
H'FFF77
PPG_0
8
2Pφ/2Pφ
Next data enable register H
NDERH
8
H'FFF78
PPG_0
8
2Pφ/2Pφ
Next data enable register L
NDERL
8
H'FFF79
PPG_0
8
2Pφ/2Pφ
Output data register H
PODRH
8
H'FFF7A
PPG_0
8
2Pφ/2Pφ
Output data register L
PODRL
8
H'FFF7B
PPG_0
8
2Pφ/2Pφ
NDRH
8
H'FFF7C
PPG_0
8
2Pφ/2Pφ
NDRL
8
H'FFF7D
PPG_0
8
2Pφ/2Pφ
NDRH
8
H'FFF7E
PPG_0
8
2Pφ/2Pφ
Next data register L*
NDRL
8
H'FFF7F
PPG_0
8
2Pφ/2Pφ
Serial mode register_0
SMR_0
8
H'FFF80
SCI_0
8
2Pφ/2Pφ
Bit rate register_0
BRR_0
8
H'FFF81
SCI_0
8
2Pφ/2Pφ
1
Next data register H*
1
Next data register L*
1
Next data register H*
1
Serial control register_0
SCR_0
8
H'FFF82
SCI_0
8
2Pφ/2Pφ
Transmit data register_0
TDR_0
8
H'FFF83
SCI_0
8
2Pφ/2Pφ
Serial status register_0
SSR_0
8
H'FFF84
SCI_0
8
2Pφ/2Pφ
Receive data register_0
RDR_0
8
H'FFF85
SCI_0
8
2Pφ/2Pφ
Smart card mode register_0
SCMR_0
8
H'FFF86
SCI_0
8
2Pφ/2Pφ
Rev. 2.00 Oct. 21, 2009 Page 1311 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Serial mode register_1
SMR_1
8
H'FFF88
SCI_1
8
2Pφ/2Pφ
Bit rate register_1
BRR_1
8
H'FFF89
SCI_1
8
2Pφ/2Pφ
Serial control register_1
SCR_1
8
H'FFF8A
SCI_1
8
2Pφ/2Pφ
Transmit data register_1
TDR_1
8
H'FFF8B
SCI_1
8
2Pφ/2Pφ
Serial status register_1
SSR_1
8
H'FFF8C
SCI_1
8
2Pφ/2Pφ
Receive data register_1
RDR_1
8
H'FFF8D
SCI_1
8
2Pφ/2Pφ
Smart card mode register_1
SCMR_1
8
H'FFF8E
SCI_1
8
2Pφ/2Pφ
A/D data register A_0
ADDRA_0
16
H'FFF90
A/D_0
16
2Pφ/2Pφ
A/D data register B_0
ADDRB_0
16
H'FFF92
A/D_0
16
2Pφ/2Pφ
A/D data register C_0
ADDRC_0
16
H'FFF94
A/D_0
16
2Pφ/2Pφ
A/D data register D_0
ADDRD_0
16
H'FFF96
A/D_0
16
2Pφ/2Pφ
A/D data register E_0
ADDRE_0
16
H'FFF98
A/D_0
16
2Pφ/2Pφ
A/D data register F_0
ADDRF_0
16
H'FFF9A
A/D_0
16
2Pφ/2Pφ
A/D data register G_0
ADDRG_0
16
H'FFF9C
A/D_0
16
2Pφ/2Pφ
A/D data register H_0
ADDRH_0
16
H'FFF9E
A/D_0
16
2Pφ/2Pφ
A/D control/status register_0
ADCSR_0
8
H'FFFA0
A/D_0
16
2Pφ/2Pφ
A/D control register_0
ADCR_0
8
H'FFFA1
A/D_0
16
2Pφ/2Pφ
A/D mode selection register_0
ADMOSEL_0
8
H'FFFA2
A/D_0
16
2Pφ/2Pφ
Timer control/status register
TCSR
8
H'FFFA4
WDT
16
2Pφ/3Pφ
Timer counter
TCNT
8
H'FFFA5
WDT
16
2Pφ/3Pφ
Reset control/status register
RSTCSR
8
H'FFFA7
WDT
16
2Pφ/3Pφ
Timer control register_0
TCR_0
8
H'FFFB0
TMR_0
16
2Pφ/2Pφ
Timer control register_1
TCR_1
8
H'FFFB1
TMR_1
16
2Pφ/2Pφ
Timer control/status register_0
TCSR_0
8
H'FFFB2
TMR_0
16
2Pφ/2Pφ
Timer control/status register_1
TCSR_1
8
H'FFFB3
TMR_1
16
2Pφ/2Pφ
Time constant register A_0
TCORA_0
8
H'FFFB4
TMR_0
16
2Pφ/2Pφ
Time constant register A_1
TCORA_1
8
H'FFFB5
TMR_1
16
2Pφ/2Pφ
Time constant register B_0
TCORB_0
8
H'FFFB6
TMR_0
16
2Pφ/2Pφ
Time constant register B_1
TCORB_1
8
H'FFFB7
TMR_1
16
2Pφ/2Pφ
Timer counter_0
TCNT_0
8
H'FFFB8
TMR_0
16
2Pφ/2Pφ
Timer counter_1
TCNT_1
8
H'FFFB9
TMR_1
16
2Pφ/2Pφ
Rev. 2.00 Oct. 21, 2009 Page 1312 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Timer counter control register_0
TCCR_0
8
H'FFFBA
TMR_0
16
2Pφ/2Pφ
Timer counter control register_1
TCCR_1
8
H'FFFBB
TMR_1
16
2Pφ/2Pφ
Timer start register
TSTR
8
H'FFFBC
TPU
16
2Pφ/2Pφ
Timer synchronous register
TSYR
8
H'FFFBD
TPU
16
2Pφ/2Pφ
Timer control register_0
TCR_0
8
H'FFFC0
TPU_0
16
2Pφ/2Pφ
Timer mode register_0
TMDR_0
8
H'FFFC1
TPU_0
16
2Pφ/2Pφ
Timer I/O control register H_0
TIORH_0
8
H'FFFC2
TPU_0
16
2Pφ/2Pφ
Timer I/O control register L_0
TIORL_0
8
H'FFFC3
TPU_0
16
2Pφ/2Pφ
Timer interrupt enable register_0
TIER_0
8
H'FFFC4
TPU_0
16
2Pφ/2Pφ
Timer status register_0
TSR_0
8
H'FFFC5
TPU_0
16
2Pφ/2Pφ
Timer counter_0
TCNT_0
16
H'FFFC6
TPU_0
16
2Pφ/2Pφ
Timer general register A_0
TGRA_0
16
H'FFFC8
TPU_0
16
2Pφ/2Pφ
Timer general register B_0
TGRB_0
16
H'FFFCA
TPU_0
16
2Pφ/2Pφ
Timer general register C_0
TGRC_0
16
H'FFFCC
TPU_0
16
2Pφ/2Pφ
Timer general register D_0
TGRD_0
16
H'FFFCE
TPU_0
16
2Pφ/2Pφ
Timer control register_1
TCR_1
8
H'FFFD0
TPU_1
16
2Pφ/2Pφ
Timer mode register_1
TMDR_1
8
H'FFFD1
TPU_1
16
2Pφ/2Pφ
Timer I/O control register_1
TIOR_1
8
H'FFFD2
TPU_1
16
2Pφ/2Pφ
Timer interrupt enable register_1
TIER_1
8
H'FFFD4
TPU_1
16
2Pφ/2Pφ
Timer status register_1
TSR_1
8
H'FFFD5
TPU_1
16
2Pφ/2Pφ
Timer counter_1
TCNT_1
16
H'FFFD6
TPU_1
16
2Pφ/2Pφ
Timer general register A_1
TGRA_1
16
H'FFFD8
TPU_1
16
2Pφ/2Pφ
Timer general register B_1
TGRB_1
16
H'FFFDA
TPU_1
16
2Pφ/2Pφ
Timer control register_2
TCR_2
8
H'FFFE0
TPU_2
16
2Pφ/2Pφ
Timer mode register_2
TMDR_2
8
H'FFFE1
TPU_2
16
2Pφ/2Pφ
Timer I/O control register_2
TIOR_2
8
H'FFFE2
TPU_2
16
2Pφ/2Pφ
Timer interrupt enable register_2
TIER_2
8
H'FFFE4
TPU_2
16
2Pφ/2Pφ
Timer status register_2
TSR_2
8
H'FFFE5
TPU_2
16
2Pφ/2Pφ
Timer counter_2
TCNT_2
16
H'FFFE6
TPU_2
16
2Pφ/2Pφ
Timer general register A_2
TGRA_2
16
H'FFFE8
TPU_2
16
2Pφ/2Pφ
Timer general register B_2
TGRB_2
16
H'FFFEA
TPU_2
16
2Pφ/2Pφ
Rev. 2.00 Oct. 21, 2009 Page 1313 of 1454
REJ09B0498-0200
Section 29 List of Registers
Access
Number
Data
Cycles
Register Name
Abbreviation
of Bits
Address
Module
Width
(Read/Write)
Timer control register_3
TCR_3
8
H'FFFF0
TPU_3
16
2Pφ/2Pφ
Timer mode register_3
TMDR_3
8
H'FFFF1
TPU_3
16
2Pφ/2Pφ
Timer I/O control register H_3
TIORH_3
8
H'FFFF2
TPU_3
16
2Pφ/2Pφ
Timer I/O control register L_3
TIORL_3
8
H'FFFF3
TPU_3
16
2Pφ/2Pφ
Timer interrupt enable register_3
TIER_3
8
H'FFFF4
TPU_3
16
2Pφ/2Pφ
Timer status register_3
TSR_3
8
H'FFFF5
TPU_3
16
2Pφ/2Pφ
Timer counter_3
TCNT_3
16
H'FFFF6
TPU_3
16
2Pφ/2Pφ
Timer general register A_3
TGRA_3
16
H'FFFF8
TPU_3
16
2Pφ/2Pφ
Timer general register B_3
TGRB_3
16
H'FFFFA
TPU_3
16
2Pφ/2Pφ
Timer general register C_3
TGRC_3
16
H'FFFFC
TPU_3
16
2Pφ/2Pφ
Timer general register D_3
TGRD_3
16
H'FFFFE
TPU_3
16
2Pφ/2Pφ
Notes: 1. When the same output trigger is specified for pulse output groups 2 and 3 by the PCR
setting, the NDRH address is H'FFF7C. When different output triggers are specified, the
NDRH addresses for pulse output groups 2 and 3 are H'FFF7E and H'FFF7C,
respectively. Similarly, when the same output trigger is specified for pulse output groups
0 and 1 by the PCR setting, the NDRL address is H'FFF7D. When different output
triggers are specified, the NDRL addresses for pulse output groups 0 and 1 are
H'FFF7F and H'FFF7D, respectively.
When the same output trigger is specified for pulse output groups 6 and 7 by the PCR
setting, the NDRH address is H'FF63C. When different output triggers are specified, the
NDRH addresses for pulse output groups 6 and 7 are H'FF63E and H'FF63C,
respectively.
When the same output trigger is specified for pulse output groups 4 and 5 by the PCR
setting, the NDRL address is H'FF63D. When different output triggers are specified, the
NDRL addresses for pulse output groups 4 and 5 are H'FF63F and H'FF63D,
respectively.
2. Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1314 of 1454
REJ09B0498-0200
Section 29 List of Registers
29.2
Register Bits
Register addresses and bit names of the on-chip peripheral modules are described below.
Each line covers eight bits, and 16-bit and 32-bit registers are shown as 2 or 4 lines, respectively.
Register
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
Bit
Bit
Bit
Bit
25/17/9/1
24/16/8/0
Module
TCR_4
CMIEB
CMIEA
OVIE
CCLR1
CCLR0
CKS2
CKS1
CKS0
TMR_4
TCR_5
CMIEB
CMIEA
OVIE
CCLR1
CCLR0
CKS2
CKS1
CKS0
TMR_5
TCSR_4
CMFB
CMFA
OVF
ADTE
OS3
OS2
OS1
OS0
TMR_4
TCSR_5
CMFB
CMFA
OVF
⎯
OS3
OS2
OS1
OS0
TMR_5
TCORA_4
TMR_4
TCORA_5
TMR_5
TCORB_4
TMR_4
TCORB_5
TMR_5
TCNT_4
TMR_4
TCNT_5
TMR_5
TCCR_4
⎯
⎯
⎯
⎯
TMRIS
⎯
ICKS1
ICKS0
TMR_4
TCCR_5
⎯
⎯
⎯
⎯
TMRIS
⎯
ICKS1
ICKS0
TMR_5
CRCCR
DORCLR
⎯
⎯
⎯
⎯
LMS
G1
G0
CRC
TCR_6
CMIEB
CMIEA
OVIE
CCLR1
CCLR0
CKS2
CKS1
CKS0
TMR_6
TCR_7
CMIEB
CMIEA
OVIE
CCLR1
CCLR0
CKS2
CKS1
CKS0
TMR_7
TCSR_6
CMFB
CMFA
OVF
ADTE
OS3
OS2
OS1
OS0
TMR_6
TCSR_7
CMFB
CMFA
OVF
⎯
OS3
OS2
OS1
OS0
TMR_7
CRCDIR
CRCDOR
TCORA_6
TMR_6
TCORA_7
TMR_7
TCORB_6
TMR_6
TCORB_7
TMR_7
TCNT_6
TMR_6
TCNT_7
TMR_7
Rev. 2.00 Oct. 21, 2009 Page 1315 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
Module
TCCR_6
⎯
⎯
⎯
⎯
TMRIS
⎯
ICKS1
ICKS0
TMR_6
TCCR_7
⎯
⎯
⎯
⎯
TMRIS
⎯
ICKS1
ICKS0
TMR_7
ADDRA_1
A/D_1
ADDRB_1
ADDRC_1
ADDRD_1
ADDRE_1
ADDRF_1
ADDRG_1
ADDRH_1
ADCSR_1
ADF
ADIE
ADST
EXCKS
CH3
CH2
CH1
ADCR_1
TRGS1
TRGS0
SCANE
SCANS
CKS1
CKS0
ADSTCLR EXTRGS
ADMOSEL_1 ⎯
⎯
⎯
⎯
⎯
⎯
ICKSEL
⎯
ADSSTR_1
SMP7
SMP6
SMP5
SMP4
SMP3
SMP2
SMP1
SMP0
IFR0
BRST
EP1 FULL EP2 TR
EP2 EMPTY SETUP TS EP0o TS
EP0i TR
EP0i TS
IFR1
⎯
⎯
⎯
⎯
VBUS MN EP3 TR
EP3 TS
VBUSF
IFR2
⎯
⎯
SURSS
SURSF
CFDN
SETC
SETI
IER0
BRST
EP1 FULL EP2 TR
EP2 EMPTY SETUP TS EP0o TS
EP0i TR
EP0i TS
IER1
⎯
⎯
⎯
⎯
⎯
EP3 TR
EP3 TS
VBUSF
IER2
SSRSME
⎯
⎯
SURSE
CFDN
⎯
SETCE
SETIE
ISR0
BRST
EP1 FULL EP2 TR
EP2
SETUP TS EP0o TS
EP0i TR
EP0i TS
EMPTY
Rev. 2.00 Oct. 21, 2009 Page 1316 of 1454
REJ09B0498-0200
⎯
CH0
USB
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
Module
USB
ISR1
⎯
⎯
⎯
⎯
⎯
EP3 TR
EP3 TS
VBUSF
ISR2
⎯
⎯
⎯
SURSE
CFDN
⎯
SETCE
SETIE
EPDR0i
D7
D6
D5
D4
D3
D2
D1
D0
EPDR0o
D7
D6
D5
D4
D3
D2
D1
D0
EPDR0s
D7
D6
D5
D4
D3
D2
D1
D0
EPDR1
D7
D6
D5
D4
D3
D2
D1
D0
EPDR2
D7
D6
D5
D4
D3
D2
D1
D0
EPDR3
D7
D6
D5
D4
D3
D2
D1
D0
EPSZ0o
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
EPSZ1
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
DASTS
⎯
⎯
EP3 DE
EP2 DE
⎯
⎯
⎯
EP0i DE
FCLR
⎯
EP3 CLR
EP1 CLR
EP2 CLR
⎯
⎯
EP0o CLR EP0i CLR
EPSTL
⎯
⎯
⎯
⎯
EP3STL
EP2STL
EP1STL
TRG
⎯
EP3 PKTE EP1 RDFN
EP2 PKTE ⎯
EP0s RDFN
EP0o RDFN EP0i PKTE
DMA
⎯
⎯
⎯
⎯
⎯
PULLUP_E EP2DMAE EP1DMAE
CVR
CNFV1
CNFV0
INTV1
INTV0
⎯
ALTV2
ALTV1
ALTV0
CTLR
⎯
⎯
⎯
RWUPS
RSME
RWMD
ASCE
⎯
EPIR
D7
D6
D5
D4
D3
D2
D1
D0
TRNTREG0
PTSTE
⎯
⎯
⎯
SUSPEND txenl
txse0
txdata
TRNTREG1
⎯
⎯
⎯
⎯
⎯
xver_data
dpls
dmns
PMDDR
⎯
⎯
⎯
PM4DDR
PM3DDR
PM2DDR
PM1DDR
PM0DDR
PMDR
⎯
⎯
⎯
PM4DR
PM3DR
PM2DR
PM1DR
PM0DR
PORTM
⎯
⎯
⎯
PM4
PM3
PM2
PM1
PM0
⎯
⎯
⎯
PM4ICR
PM3ICR
PM2ICR
PM1ICR
PM0ICR
C/A
CHR
PE
O/E
STOP
MP
CKS1
CKS0
(GM)
(BLK)
(PE)
(O/E)
(BCP1)
(BCP0)
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
PMICR
1
SMR_5*
EP0STL
I/O port
SCI_5
BRR_5
SCR_5*1
TDR_5
Rev. 2.00 Oct. 21, 2009 Page 1317 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
1
SSR_5*
TDRE
RDRF
ORER
FER
Bit
Bit
25/17/9/1
24/16/8/0
Module
SCI_5
PER
TEND
MPB
MPBT
(ERS)
RDR_5
SCMR_5
⎯
⎯
⎯
⎯
SDIR
SINV
⎯
SMIF
SEMR_5
⎯
⎯
⎯
ABCS
ACS3
ACS2
ACS1
ACS0
IrCR
IrE
IrCKS2
IrCKS1
IrCKS0
IrTxINV
IrRxINV
⎯
⎯
C/A
CHR
PE
O/E
STOP
MP
CKS1
CKS0
(GM)
(BLK)
(PE)
(O/E)
(BCP1)
(BCP0)
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
TDRE
RDRF
ORER
FER
PER
TEND
MPB
MPBT
1
SMR_6*
SCI_6
BRR_6
SCR_6*1
TDR_6
SSR_6*1
(ERS)
RDR_6
SCMR_6
⎯
⎯
⎯
⎯
SDIR
SINV
⎯
SMIF
SEMR_6
⎯
⎯
⎯
ABCS
ACS3
ACS2
ACS1
ACS0
PCR_1
G3CMS1
G3CMS0
G2CMS1
G2CMS0
G1CMS1
G1CMS0
G0CMS1
G0CMS0
PMR_1
G3INV
G2INV
G1INV
G0INV
G3NOV
G2NOV
G1NOV
G0NOV
NDERH_1
NDER31
NDER30
NDER29
NDER28
NDER27
NDER26
NDER25
NDER24
NDERL_1
NDER23
NDER22
NDER21
NDER20
NDER19
NDER18
NDER17
NDER16
PODRH_1
POD31
POD30
POD29
POD28
POD27
POD26
POD25
POD24
PODRL_1
POD23
POD22
POD21
POD20
POD19
POD18
POD17
POD16
NDRH_1*
NDR31
NDR30
NDR29
NDR28
NDR27
NDR26
NDR25
NDR24
2
NDR23
NDR22
NDR21
NDR20
NDR19
NDR18
NDR17
NDR16
NDRH_1*
⎯
⎯
⎯
⎯
NDR27
NDR26
NDR25
NDR24
2
⎯
⎯
⎯
⎯
NDR19
NDR18
NDR17
NDR16
2
NDRL_1*
2
NDRL_1*
Rev. 2.00 Oct. 21, 2009 Page 1318 of 1454
REJ09B0498-0200
PPG_1
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
BARAH
BARAL
BAMRAH
BAMRAL
BARBH
BARBL
BAMRBH
BAMRBL
BARCH
BARCL
BAMRCH
BAMRCL
BARDH
BARDL
BRCRA
Bit
Bit
25/17/9/1
24/16/8/0
Module
UBC
BARA31
BARA30
BARA29
BARA28
BARA27
BARA26
BARA25
BARA24
BARA23
BARA22
BARA21
BARA20
BARA19
BARA18
BARA17
BARA16
BARA15
BARA14
BARA13
BARA12
BARA11
BARA10
BARA9
BARA8
BARA7
BARA6
BARA5
BARA4
BARA3
BARA2
BARA1
BARA0
BAMRA31 BAMRA30 BAMRA29 BAMRA28 BAMRA27 BAMRA26
BAMRA25 BAMRA24
BAMRA23 BAMRA22 BAMRA21 BAMRA20 BAMRA19 BAMRA18
BAMRA17 BAMRA16
BAMRA15 BAMRA14 BAMRA13 BAMRA12 BAMRA11 BAMRA10
BAMRA9
BAMRA8
BAMRA7
BAMRA6
BAMRA5
BAMRA4
BAMRA3
BAMRA2
BAMRA1
BAMRA0
BARB31
BARB30
BARB29
BARB28
BARB27
BARB26
BARB25
BARB24
BARB23
BARB22
BARB21
BARB20
BARB19
BARB18
BARB17
BARB16
BARB15
BARB14
BARB13
BARB12
BARB11
BARB10
BARB9
BARB8
BARB7
BARB6
BARB5
BARB4
BARB3
BARB2
BARB1
BARB0
BAMRB31 BAMRB30 BAMRB29 BAMRB28 BAMRB27 BAMRB26
BAMRB25 BAMRB24
BAMRB23 BAMRB22 BAMRB21 BAMRB20 BAMRB19 BAMRB18
BAMRB17 BAMRB16
BAMRB15 BAMRB14 BAMRB13 BAMRB12 BAMRB11 BAMRB10
BAMRB9
BAMRB8
BAMRB7
BAMRB6
BAMRB5
BAMRB4
BAMRB3
BAMRB2
BAMRB1
BAMRB0
BARC31
BARC30
BARC29
BARC28
BARC27
BARC26
BARC25
BARC24
BARC23
BARC22
BARC21
BARC20
BARC19
BARC18
BARC17
BARC16
BARC15
BARC14
BARC13
BARC12
BARC11
BARC10
BARC9
BARC8
BARC7
BARC6
BARC5
BARC4
BARC3
BARC2
BARC1
BARC0
BAMRC31 BAMRC30 BAMRC29 BAMRC28 BAMRC27 BAMRC26
BAMRC25 BAMRC24
BAMRC23 BAMRC22 BAMRC21 BAMRC20 BAMRC19 BAMRC18
BAMRC17 BAMRC16
BAMRC15 BAMRC14 BAMRC13 BAMRC12 BAMRC11 BAMRC10
BAMRC9
BAMRC8
BAMRC7
BAMRC6
BAMRC5
BAMRC4
BAMRC3
BAMRC2
BAMRC1
BAMRC0
BARD31
BARD30
BARD29
BARD28
BARD27
BARD26
BARD25
BARD24
BARD23
BARD22
BARD21
BARD20
BARD19
BARD18
BARD17
BARD16
BARD15
BARD14
BARD13
BARD12
BARD11
BARD10
BARD9
BARD8
BARD7
BARD6
BARD5
BARD4
BARD3
BARD2
BARD1
BARD0
⎯
⎯
CMFCPA
⎯
CPA2
CPA1
CPA0
⎯
⎯
⎯
IDA1
IDA0
RWA1
RWA0
⎯
⎯
Rev. 2.00 Oct. 21, 2009 Page 1319 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
BRCRB
BRCRC
Bit
Bit
25/17/9/1
24/16/8/0
Module
UBC
⎯
⎯
CMFCPB
⎯
CPB2
CPB1
CPB0
⎯
⎯
⎯
IDB1
IDB0
RWB1
RWB0
⎯
⎯
⎯
⎯
CMFCPC
⎯
CPC2
CPC1
CPC0
⎯
⎯
⎯
IDC1
IDC0
RWC1
RWC0
⎯
⎯
⎯
⎯
CMFCPD
⎯
CPD2
CPD1
CPD0
⎯
⎯
⎯
IDD1
IDD0
RWD1
RWD0
⎯
⎯
EXCKSN
⎯
TME
⎯
⎯
OSC32STP CKS1
CKS0
TM32K
ADSSTR_0
SMP7
SMP6
SMP5
SMP4
SMP3
SMP2
SMP1
SMP0
A/D_0
TSTRB
⎯
⎯
CST5
CST4
CST3
CST2
CST1
CST0
TPU
TSYRB
⎯
⎯
SYNC5
SYNC4
SYNC3
SYNC2
SYNC1
SYNC0
TCR_6
CCLR2
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_6
⎯
⎯
BFB
BFA
MD3
MD2
MD1
MD0
TIORH_6
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIORL_6
IOD3
IOD2
IOD1
IOD0
IOC3
IOC2
IOC1
IOC0
TIER_6
⎯
⎯
⎯
TCIEV
TGIED
TGIEC
TGIEB
TGIEA
TSR_6
⎯
⎯
⎯
TCFV
TGFD
TGFC
TGFB
TGFA
BRCRD
TCR32K
TCNT32K1
TCNT32K2
TCNT32K3
TCNT_6
TGRA_6
TGRB_6
TGRC_6
TGRD_6
Rev. 2.00 Oct. 21, 2009 Page 1320 of 1454
REJ09B0498-0200
(unit 1)
TPU_6
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
Module
TPU_7
TCR_7
⎯
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_7
⎯
⎯
⎯
⎯
MD3
MD2
MD1
MD0
TIOR_7
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIER_7
⎯
⎯
TCIEU
TCIEV
⎯
⎯
TGIEB
TGIEA
TSR_7
TCFD
⎯
TCFU
TCFV
⎯
⎯
TGFB
TGFA
TCR_8
⎯
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_8
⎯
⎯
⎯
⎯
MD3
MD2
MD1
MD0
TIOR_8
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIER_8
⎯
⎯
TCIEU
TCIEV
⎯
⎯
TGIEB
TGIEA
TSR_8
TCFD
⎯
TCFU
TCFV
⎯
⎯
TGFB
TGFA
TCR_9
CCLR2
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_9
⎯
⎯
BFB
BFA
MD3
MD2
MD1
MD0
TIORH_9
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIORL_9
IOD3
IOD2
IOD1
IOD0
IOC3
IOC2
IOC1
IOC0
TIER_9
⎯
⎯
⎯
TCIEV
TGIED
TGIEC
TGIEB
TGIEA
TSR_9
⎯
⎯
⎯
TCFV
TGFD
TGFC
TGFB
TGFA
TCNT_7
TGRA_7
TGRB_7
TPU_8
TCNT_8
TGRA_8
TGRB_8
TPU_9
TCNT_9
Rev. 2.00 Oct. 21, 2009 Page 1321 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
Module
TPU_9
TGRA_9
TGRB_9
TGRC_9
TGRD_9
TCR_10
⎯
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_10
⎯
⎯
⎯
⎯
MD3
MD2
MD1
MD0
TIOR_10
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIER_10
⎯
⎯
TCIEU
TCIEV
⎯
⎯
TGIEB
TGIEA
TSR_10
TCFD
⎯
TCFU
TCFV
⎯
⎯
TGFB
TGFA
TCR_11
⎯
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_11
⎯
⎯
⎯
⎯
MD3
MD2
MD1
MD0
TIOR_11
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIER_11
⎯
⎯
TCIEU
TCIEV
⎯
⎯
TGIEB
TGIEA
TSR_11
TCFD
⎯
TCFU
TCFV
⎯
⎯
TGFB
TGFA
TPU_10
TCNT_10
TGRA_10
TGRB_10
TCNT_11
TGRA_11
TGRB_11
Rev. 2.00 Oct. 21, 2009 Page 1322 of 1454
REJ09B0498-0200
TPU_11
Section 29 List of Registers
Register
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
Bit
Bit
Bit
Bit
25/17/9/1
24/16/8/0
Module
P1DDR
P17DDR
P16DDR
P15DDR
P14DDR
P13DDR
P12DDR
P11DDR
P10DDR
I/O port
P2DDR
P27DDR
P26DDR
P25DDR
P24DDR
P23DDR
P22DDR
P21DDR
P20DDR
P3DDR
P37DDR
P36DDR
P35DDR
P34DDR
P33DDR
P32DDR
P31DDR
P30DDR
P6DDR
⎯
⎯
P65DDR
P64DDR
P63DDR
P62DDR
P61DDR
P60DDR
PADDR
PA7DDR
PA6DDR
PA5DDR
PA4DDR
PA3DDR
PA2DDR
PA1DDR
PA0DDR
PBDDR
PB7DDR
PB6DDR
PB5DDR
PB4DDR
PB3DDR
PB2DDR
PB1DDR
PB0DDR
PCDDR
⎯
⎯
⎯
⎯
PC3DDR
PC2DDR
⎯
⎯
PDDDR
PD7DDR
PD6DDR
PD5DDR
PD4DDR
PD3DDR
PD2DDR
PD1DDR
PD0DDR
PEDDR
PE7DDR
PE6DDR
PE5DDR
PE4DDR
PE3DDR
PE2DDR
PE1DDR
PE0DDR
PFDDR
PF7DDR
PF6DDR
PF5DDR
PF4DDR
PF3DDR
PF2DDR
PF1DDR
PF0DDR
P1ICR
P17ICR
P16ICR
P15ICR
P14ICR
P13ICR
P12ICR
P11ICR
P10ICR
P2ICR
P27ICR
P26ICR
P25ICR
P24ICR
P23ICR
P22ICR
P21ICR
P20ICR
P3ICR
P37ICR
P36ICR
P35ICR
P34ICR
P33ICR
P32ICR
P31ICR
P30ICR
P5ICR
P57ICR
P56ICR
P55ICR
P54ICR
P53ICR
P52ICR
P51ICR
P50ICR
P6ICR
⎯
⎯
P65ICR
P64ICR
P63ICR
P62ICR
P61ICR
P60ICR
PAICR
PA7ICR
PA6ICR
PA5ICR
PA4ICR
PA3ICR
PA2ICR
PA1ICR
PA0ICR
PBICR
PB7ICR
PB6ICR
PB5ICR
PB4ICR
PB3ICR
PB2ICR
PB1ICR
PB0ICR
PCICR
⎯
⎯
⎯
⎯
PC3ICR
PC2ICR
⎯
⎯
PDICR
PD7ICR
PD6ICR
PD5ICR
PD4ICR
PD3ICR
PD2ICR
PD1ICR
PD0ICR
PEICR
PE7ICR
PE6ICR
PE5ICR
PE4ICR
PE3ICR
PE2ICR
PE1ICR
PE0ICR
PFICR
PF7ICR
PF6ICR
PF5ICR
PF4ICR
PF3ICR
PF2ICR
PF1ICR
PF0ICR
PORTH
PH7
PH6
PH5
PH4
PH3
PH2
PH1
PH0
PORTI
PI7
PI6
PI5
PI4
PI3
PI2
PI1
PI0
PORTJ
PJ7
PJ6
PJ5
PJ4
PJ3
PJ2
PJ1
PJ0
PORTK
PK7
PK6
PK5
PK4
PK3
PK2
PK1
PK0
PHDR
PH7DR
PH6DR
PH5DR
PH4DR
PH3DR
PH2DR
PH1DR
PH0DR
PIDR
PI7DR
PI6DR
PI5DR
PI4DR
PI3DR
PI2DR
PI1DR
PI0DR
PJDR
PJ7DR
PJ6DR
PJ5DR
PJ4DR
PJ3DR
PJ2DR
PJ1DR
PJ0DR
PKDR
PK7DR
PK6DR
PK5DR
PK4DR
PK3DR
PK2DR
PK1DR
PK0DR
PHDDR
PH7DDR
PH6DDR
PH5DDR
PH4DDR
PH3DDR
PH2DDR
PH1DDR
PH0DDR
Rev. 2.00 Oct. 21, 2009 Page 1323 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
Bit
25/17/9/1
24/16/8/0
Module
PIDDR
PI7DDR
PI6DDR
PI5DDR
PI4DDR
PI3DDR
PI2DDR
PI1DDR
PI0DDR
I/O port
PJDDR
PJ7DDR
PJ6DDR
PJ5DDR
PJ4DDR
PJ3DDR
PJ2DDR
PJ1DDR
PJ0DDR
PKDDR
PK7DDR
PK6DDR
PK5DDR
PK4DDR
PK3DDR
PK2DDR
PK1DDR
PK0DDR
PHICR
PH7ICR
PH6ICR
PH5ICR
PH4ICR
PH3ICR
PH2ICR
PH1ICR
PH0ICR
PIICR
PI7ICR
PI6ICR
PI5ICR
PI4ICR
PI3ICR
PI2ICR
PI1ICR
PI0ICR
PJICR
PJ7ICR
PJ6ICR
PJ5ICR
PJ4ICR
PJ3ICR
PJ2ICR
PJ1ICR
PJ0ICR
PKICR
PK7ICR
PK6ICR
PK5ICR
PK4ICR
PK3ICR
PK2ICR
PK1ICR
PK0ICR
PDPCR
PD7PCR
PD6PCR
PD5PCR
PD4PCR
PD3PCR
PD2PCR
PD1PCR
PD0PCR
PEPCR
PE7PCR
PE6PCR
PE5PCR
PE4PCR
PE3PCR
PE2PCR
PE1PCR
PE0PCR
PFPCR
PF7PCR
PF6PCR
PF5PCR
PF4PCR
PF3PCR
PF2PCR
PF1PCR
PF0PCR
PHPCR
PH7PCR
PH6PCR
PH5PCR
PH4PCR
PH3PCR
PH2PCR
PH1PCR
PH0PCR
PIPCR
PI7PCR
PI6PCR
PI5PCR
PI4PCR
PI3PCR
PI2PCR
PI1PCR
PI0PCR
PJPCR
PJ7PCR
PJ6PCR
PJ5PCR
PJ4PCR
PJ3PCR
PJ2PCR
PJ1PCR
PJ0PCR
PKPCR
PK7PCR
PK6PCR
PK5PCR
PK4PCR
PK3PCR
PK2PCR
PK1PCR
PK0PCR
P2ODR
P27ODR
P26ODR
P25ODR
P24ODR
P23ODR
P22ODR
P21ODR
P20ODR
PFODR
PF7ODR
PF6ODR
PF5ODR
PF4ODR
PF3ODR
PF2ODR
PF1ODR
PF0ODR
PFCR0
CS7E
CS6E
CS5E
CS4E
CS3E
CS2E
CS1E
CS0E
PFCR1
CS7SA
CS7SB
CS6SA
CS6SB
CS5SA
CS5SB
CS4SA
CS4SB
PFCR2
⎯
CS2S
BSS
BSE
RDWRS
RDWRE
ASOE
⎯
PFCR4
A23E
A22E
A21E
A20E
A19E
A18E
A17E
A16E
PFCR6
⎯
LHWROE
⎯
⎯
TCLKS
⎯
⎯
⎯
PFCR7
DMAS3A
DMAS3B
DMAS2A
DMAS2B
DMAS1A
DMAS1B
DMAS0A
DMAS0B
PFCR8
⎯
⎯
⎯
⎯
EDMAS1A EDMAS1B
PFCR9
TPUMS5
TPUMS4
TPUMS3A TPUMS3B TPUMS2
TPUMS1
TPUMS0A TPUMS0B
PFCRA
TPUMS11 TPUMS10 TPUMS9A TPUMS9B TPUMS8
TPUMS7
TPUMS6A TPUMS6B
PFCRB
⎯
⎯
⎯
⎯
ITS11
ITS10
ITS9
ITS8
PFCRC
ITS7
ITS6
ITS5
ITS4
ITS3
ITS2
ITS1
ITS0
PFCRD
PCJKE
⎯
⎯
⎯
⎯
⎯
⎯
⎯
SSIER
SSI15
⎯
⎯
⎯
SSI11
SSI10
SSI9
SSI8
SSI7
SSI6
SSI5
SSI4
SSI3
SSI2
SSI1
SSI0
Rev. 2.00 Oct. 21, 2009 Page 1324 of 1454
REJ09B0498-0200
Bit
Bit
Bit
EDMAS0A EDMAS0B
INTC
Section 29 List of Registers
Register
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
25/17/9/1
24/16/8/0
Module
DPSBKR0
DKUP07
DKUP06
DKUP05
DKUP04
DKUP03
DKUP02
DKUP01
DKUP00
SYSTEM
DPSBKR1
DKUP17
DKUP16
DKUP15
DKUP14
DKUP13
DKUP12
DKUP11
DKUP10
DPSBKR2
DKUP27
DKUP26
DKUP25
DKUP24
DKUP23
DKUP22
DKUP21
DKUP20
DPSBKR3
DKUP37
DKUP36
DKUP35
DKUP34
DKUP33
DKUP32
DKUP31
DKUP30
DPSBKR4
DKUP47
DKUP46
DKUP45
DKUP44
DKUP43
DKUP42
DKUP41
DKUP40
DPSBKR5
DKUP57
DKUP56
DKUP55
DKUP54
DKUP53
DKUP52
DKUP51
DKUP50
DPSBKR6
DKUP67
DKUP66
DKUP65
DKUP64
DKUP63
DKUP62
DKUP61
DKUP60
DPSBKR7
DKUP77
DKUP76
DKUP75
DKUP74
DKUP73
DKUP72
DKUP71
DKUP70
DPSBKR8
DKUP87
DKUP86
DKUP85
DKUP84
DKUP83
DKUP82
DKUP81
DKUP80
DPSBKR9
DKUP97
DKUP96
DKUP95
DKUP94
DKUP93
DKUP92
DKUP91
DKUP90
DPSBKR10
DKUP107 DKUP106 DKUP105
DKUP104
DKUP103
DKUP102
DKUP101 DKUP100
DPSBKR11
DKUP117 DKUP116 DKUP115
DKUP114
DKUP113
DKUP112
DKUP111 DKUP110
DPSBKR12
DKUP127 DKUP126 DKUP125
DKUP124
DKUP123
DKUP122
DKUP121 DKUP120
DPSBKR13
DKUP137 DKUP136 DKUP135
DKUP134
DKUP133
DKUP132
DKUP131 DKUP130
DPSBKR14
DKUP147 DKUP146 DKUP145
DKUP144
DKUP143
DKUP142
DKUP141 DKUP140
DPSBKR15
DKUP157 DKUP156 DKUP155
DKUP154
DKUP153
DKUP152
DKUP151 DKUP150
DSAR_0
Bit
Bit
Bit
Bit
Bit
Bit
DMAC_0
DDAR_0
DOFR_0
Rev. 2.00 Oct. 21, 2009 Page 1325 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
DTCR_0
DBSR_0
DMDR_0
DACR_0
Module
DMAC_0
BKSZH31 BKSZH30 BKSZH29
BKSZH28
BKSZH27
BKSZH26
BKSZH25 BKSZH24
BKSZH23 BKSZH22 BKSZH21
BKSZH20
BKSZH19
BKSZH18
BKSZH17 BKSZH16
BKSZ15
BKSZ14
BKSZ13
BKSZ12
BKSZ11
BKSZ10
BKSZ9
BKSZ8
BKSZ7
BKSZ6
BKSZ5
BKSZ4
BKSZ3
BKSZ2
BKSZ1
BKSZ0
DTE
DACKE
TENDE
⎯
DREQS
NRD
⎯
⎯
ACT
⎯
⎯
⎯
⎯
⎯
ESIF
DTIF
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
DTF1
DTF0
DTA
⎯
⎯
DMAP2
DMAP1
DMAP0
AMS
DIRS
⎯
⎯
⎯
RPTIE
ARS1
ARS0
⎯
⎯
SAT1
SAT0
⎯
⎯
DAT1
DAT0
SARIE
⎯
⎯
SARA4
SARA3
SARA2
SARA1
SARA0
DARIE
⎯
⎯
DARA4
DARA3
DARA2
DARA1
DARA0
DSAR_1
DDAR_1
DOFR_1
Rev. 2.00 Oct. 21, 2009 Page 1326 of 1454
REJ09B0498-0200
DMAC_1
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
DTCR_1
DBSR_1
DMDR_1
DACR_1
DSAR_2
Module
DMAC_1
BKSZH31 BKSZH30 BKSZH29
BKSZH28
BKSZH27
BKSZH26
BKSZH25 BKSZH24
BKSZH23 BKSZH22 BKSZH21
BKSZH20
BKSZH19
BKSZH18
BKSZH17 BKSZH16
BKSZ15
BKSZ14
BKSZ13
BKSZ12
BKSZ11
BKSZ10
BKSZ9
BKSZ8
BKSZ7
BKSZ6
BKSZ5
BKSZ4
BKSZ3
BKSZ2
BKSZ1
BKSZ0
DTE
DACKE
TENDE
⎯
DREQS
NRD
⎯
⎯
ACT
⎯
⎯
⎯
⎯
⎯
ESIF
DTIF
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
DTF1
DTF0
DTA
⎯
⎯
DMAP2
DMAP1
DMAP0
AMS
DIRS
⎯
⎯
⎯
RPTIE
ARS1
ARS0
⎯
⎯
SAT1
SAT0
⎯
⎯
DAT1
DAT0
SARIE
⎯
⎯
SARA4
SARA3
SARA2
SARA1
SARA0
DARIE
⎯
⎯
DARA4
DARA3
DARA2
DARA1
DARA0
DMAC_2
DDAR_2
DOFR_2
Rev. 2.00 Oct. 21, 2009 Page 1327 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
DTCR_2
DBSR_2
DMDR_2
DACR_2
Module
DMAC_2
BKSZH31 BKSZH30 BKSZH29
BKSZH28
BKSZH27
BKSZH26
BKSZH25 BKSZH24
BKSZH23 BKSZH22 BKSZH21
BKSZH20
BKSZH19
BKSZH18
BKSZH17 BKSZH16
BKSZ15
BKSZ14
BKSZ13
BKSZ12
BKSZ11
BKSZ10
BKSZ9
BKSZ8
BKSZ7
BKSZ6
BKSZ5
BKSZ4
BKSZ3
BKSZ2
BKSZ1
BKSZ0
DTE
DACKE
TENDE
⎯
DREQS
NRD
⎯
⎯
ACT
⎯
⎯
⎯
⎯
⎯
ESIF
DTIF
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
DTF1
DTF0
DTA
⎯
⎯
DMAP2
DMAP1
DMAP0
AMS
DIRS
⎯
⎯
⎯
RPTIE
ARS1
ARS0
⎯
⎯
SAT1
SAT0
⎯
⎯
DAT1
DAT0
SARIE
⎯
⎯
SARA4
SARA3
SARA2
SARA1
SARA0
DARIE
⎯
⎯
DARA4
DARA3
DARA2
DARA1
DARA0
DSAR_3
DDAR_3
DOFR_3
Rev. 2.00 Oct. 21, 2009 Page 1328 of 1454
REJ09B0498-0200
DMAC_3
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
DTCR_3
DBSR_3
DMDR_3
DACR_3
EDSAR_0
Module
DMAC_3
BKSZH31 BKSZH30 BKSZH29
BKSZH28
BKSZH27
BKSZH26
BKSZH25 BKSZH24
BKSZH23 BKSZH22 BKSZH21
BKSZH20
BKSZH19
BKSZH18
BKSZH17 BKSZH16
BKSZ15
BKSZ14
BKSZ13
BKSZ12
BKSZ11
BKSZ10
BKSZ9
BKSZ8
BKSZ7
BKSZ6
BKSZ5
BKSZ4
BKSZ3
BKSZ2
BKSZ1
BKSZ0
DTE
DACKE
TENDE
⎯
DREQS
NRD
⎯
⎯
ACT
⎯
⎯
⎯
⎯
⎯
ESIF
DTIF
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
DTF1
DTF0
DTA
⎯
⎯
DMAP2
DMAP1
DMAP0
AMS
DIRS
⎯
⎯
⎯
RPTIE
ARS1
ARS0
⎯
⎯
SAT1
SAT0
⎯
⎯
DAT1
DAT0
SARIE
⎯
⎯
SARA4
SARA3
SARA2
SARA1
SARA0
DARIE
⎯
⎯
DARA4
DARA3
DARA2
DARA1
DARA0
EXDMAC_0
EDDAR_0
EDOFR_0
Rev. 2.00 Oct. 21, 2009 Page 1329 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
EDTCR_0
EDBSR_0
EDMDR_0
EDACR_0
Module
EXDMAC_0
BKSZH31 BKSZH30 BKSZH29
BKSZH28
BKSZH27
BKSZH26
BKSZH25 BKSZH24
BKSZH23 BKSZH22 BKSZH21
BKSZH20
BKSZH19
BKSZH18
BKSZH17 BKSZH16
BKSZ15
BKSZ14
BKSZ13
BKSZ12
BKSZ11
BKSZ10
BKSZ9
BKSZ8
BKSZ7
BKSZ6
BKSZ5
BKSZ4
BKSZ3
BKSZ2
BKSZ1
BKSZ0
DTE
EDACKE
ETENDE
EDRAKE
EDREQS
NRD
⎯
⎯
ACT
⎯
⎯
⎯
ERRF
⎯
ESIF
DTIF
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
DTF1
DTF0
⎯
⎯
⎯
EDMAP2
DEMAP1
EDMAP0
AMS
DIRS
⎯
⎯
⎯
RPTIE
ARS1
ARS0
⎯
⎯
SAT1
SAT0
⎯
⎯
DAT1
DAT0
SARIE
⎯
⎯
SARA4
SARA3
SARA2
SARA1
SARA0
DARIE
⎯
⎯
DARA4
DARA3
DARA2
DARA1
DARA0
EDSAR_1
EDDAR_1
EDOFR_1
Rev. 2.00 Oct. 21, 2009 Page 1330 of 1454
REJ09B0498-0200
EXDMAC_1
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
EDTCR_1
EDBSR_1
EDMDR_1
EDACR_1
EDSAR_2
Module
EXDMAC_1
BKSZH31 BKSZH30 BKSZH29
BKSZH28
BKSZH27
BKSZH26
BKSZH25 BKSZH24
BKSZH23 BKSZH22 BKSZH21
BKSZH20
BKSZH19
BKSZH18
BKSZH17 BKSZH16
BKSZ15
BKSZ14
BKSZ13
BKSZ12
BKSZ11
BKSZ10
BKSZ9
BKSZ8
BKSZ7
BKSZ6
BKSZ5
BKSZ4
BKSZ3
BKSZ2
BKSZ1
BKSZ0
DTE
EDACKE
ETENDE
EDRAKE
EDREQS
NRD
⎯
⎯
ACT
⎯
⎯
⎯
⎯
⎯
ESIF
DTIF
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
DTF1
DTF0
⎯
⎯
⎯
EDMAP2
DEMAP1
EDMAP0
AMS
DIRS
⎯
⎯
⎯
RPTIE
ARS1
ARS0
⎯
⎯
SAT1
SAT0
⎯
⎯
DAT1
DAT0
SARIE
⎯
⎯
SARA4
SARA3
SARA2
SARA1
SARA0
DARIE
⎯
⎯
DARA4
DARA3
DARA2
DARA1
DARA0
EXDMAC_2
EDDAR_2
EDOFR_2
Rev. 2.00 Oct. 21, 2009 Page 1331 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
EDTCR_2
EDBSR_2
EDMDR_2
EDACR_2
Module
EXDMAC_2
BKSZH31 BKSZH30 BKSZH29
BKSZH28
BKSZH27
BKSZH26
BKSZH25 BKSZH24
BKSZH23 BKSZH22 BKSZH21
BKSZH20
BKSZH19
BKSZH18
BKSZH17 BKSZH16
BKSZ15
BKSZ14
BKSZ13
BKSZ12
BKSZ11
BKSZ10
BKSZ9
BKSZ8
BKSZ7
BKSZ6
BKSZ5
BKSZ4
BKSZ3
BKSZ2
BKSZ1
BKSZ0
DTE
EDACKE
ETENDE
EDRAKE
EDREQS
NRD
⎯
⎯
ACT
⎯
⎯
⎯
⎯
⎯
ESIF
DTIF
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
DTF1
DTF0
⎯
⎯
⎯
EDMAP2
DEMAP1
EDMAP0
AMS
DIRS
⎯
⎯
⎯
RPTIE
ARS1
ARS0
⎯
⎯
SAT1
SAT0
⎯
⎯
DAT1
DAT0
SARIE
⎯
⎯
SARA4
SARA3
SARA2
SARA1
SARA0
DARIE
⎯
⎯
DARA4
DARA3
DARA2
DARA1
DARA0
EDSAR_3
EDDAR_3
EDOFR_3
Rev. 2.00 Oct. 21, 2009 Page 1332 of 1454
REJ09B0498-0200
EXDMAC_3
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
EDTCR_3
EDBSR_3
EDMDR_3
EDACR_3
CLSBR0
Module
EXDMAC_3
BKSZH31 BKSZH30 BKSZH29
BKSZH28
BKSZH27
BKSZH26
BKSZH25 BKSZH24
BKSZH23 BKSZH22 BKSZH21
BKSZH20
BKSZH19
BKSZH18
BKSZH17 BKSZH16
BKSZ15
BKSZ14
BKSZ13
BKSZ12
BKSZ11
BKSZ10
BKSZ9
BKSZ8
BKSZ7
BKSZ6
BKSZ5
BKSZ4
BKSZ3
BKSZ2
BKSZ1
BKSZ0
DTE
EDACKE
ETENDE
EDRAKE
EDREQS
NRD
⎯
⎯
ACT
⎯
⎯
⎯
⎯
⎯
ESIF
DTIF
DTSZ1
DTSZ0
MDS1
MDS0
TSEIE
⎯
ESIE
DTIE
DTF1
DTF0
⎯
⎯
⎯
EDMAP2
DEMAP1
EDMAP0
AMS
DIRS
⎯
⎯
⎯
RPTIE
ARS1
ARS0
⎯
⎯
SAT1
SAT0
⎯
⎯
DAT1
DAT0
SARIE
⎯
⎯
SARA4
SARA3
SARA2
SARA1
SARA0
DARIE
⎯
⎯
DARA4
DARA3
DARA2
DARA1
DARA0
EXDMAC
CLSBR1
CLSBR2
Rev. 2.00 Oct. 21, 2009 Page 1333 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
Module
EXDMAC
CLSBR3
CLSBR4
CLSBR5
CLSBR6
CLSBR7
DMRSR_0
DMAC_0
DMRSR_1
DMAC_1
DMRSR_2
DMAC_2
DMRSR_3
DMAC_3
IPRA
IPRB
IPRC
⎯
IPRA14
IPRA13
IPRA12
⎯
IPRA10
IPRA9
IPRA8
⎯
IPRA6
IPRA5
IPRA4
⎯
IPRA2
IPRA1
IPRA0
⎯
IPRB14
IPRB13
IPRB12
⎯
IPRB10
IPRB9
IPRB8
⎯
IPRB6
IPRB5
IPRB4
⎯
IPRB2
IPRB1
IPRB0
⎯
IPRC14
IPRC13
IPRC12
⎯
IPRC10
IPRC9
IPRC8
⎯
IPRC6
IPRC5
IPRC4
⎯
IPRC2
IPRC1
IPRC0
Rev. 2.00 Oct. 21, 2009 Page 1334 of 1454
REJ09B0498-0200
INTC
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
IPRD
IPRE
IPRF
IPRG
IPRH
IPRI
IPRJ
IPRK
IPRL
IPRM
IPRN
IPRO
IPRQ
IPRR
ISCRH
Bit
Bit
25/17/9/1
24/16/8/0
Module
INTC
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
IPRD2
IPRD1
IPRD0
⎯
⎯
⎯
⎯
⎯
IPRE10
IPRE9
IPRE8
⎯
⎯
⎯
⎯
⎯
IPRE2
IPRE1
IPRE0
⎯
⎯
⎯
⎯
⎯
IPRF10
IPRF9
IPRF8
⎯
IPRF6
IPRF5
IPRF4
⎯
IPRF2
IPRF1
IPRF0
⎯
IPRG14
IPRG13
IPRG12
⎯
IPRG10
IPRG9
IPRG8
⎯
IPRG6
IPRG5
IPRG4
⎯
IPRG2
IPRG1
IPRG0
⎯
IPRH14
IPRH13
IPRH12
⎯
IPRH10
IPRH9
IPRH8
⎯
IPRH6
IPRH5
IPRH4
⎯
IPRH2
IPRH1
IPRH0
⎯
IPRI14
IPRI13
IPRI12
⎯
IPRI10
IPRI9
IPRI8
⎯
IPRI6
IPRI5
IPRI4
⎯
IPRI2
IPRI1
IPRI0
⎯
IPRIJ4
IPRJ13
IPRJ12
⎯
IPRJ10
IPRJ9
IPRJ8
⎯
IPRJ6
IPRJ5
IPRJ4
⎯
IPRJ2
IPRJ1
IPRJ0
⎯
IPRK14
IPRK13
IPRK12
⎯
IPRK10
IPRK9
IPRK8
⎯
IPRK6
IPRK5
IPRK4
⎯
IPRK2
IPRK1
IPRK0
⎯
IPRL14
IPRL13
IPRL12
⎯
⎯
⎯
⎯
⎯
IPRL6
IPRL5
IPRL4
⎯
IPRL2
IPRL1
IPRL0
⎯
IPRM14
IPRM13
IPRM12
⎯
IPRM10
IPRM9
IPRM8
⎯
IPRM6
IPRM5
IPRM4
⎯
IPRM2
IPRM1
IPRM0
⎯
IPRN14
IPRN13
IPRN12
⎯
IPRN10
IPRN9
IPRN8
⎯
IPRN6
IPRN5
IPRN4
⎯
IPRN2
IPRN1
IPRN0
⎯
IPRO14
IPRO13
IPRO12
⎯
IPRO10
IPRO9
IPRO8
⎯
IPRO6
IPRO5
IPRO4
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
IPRQ6
IPRQ5
IPRQ4
⎯
IPRQ2
IPRQ1
IPRQ0
⎯
IPRR14
IPRR13
IPRR12
⎯
IPRR10
IPRR9
IPRR8
⎯
IPRR6
IPRR5
IPRR4
⎯
IPRR2
IPRR1
IPRR0
IRQ15SR
IRQ15SF
⎯
⎯
⎯
⎯
⎯
⎯
IRQ11SR
IRQ11SF
IRQ10SR
IRQ10SF
IRQ9SR
IRQ9SF
IRQ8SR
IRQ8SF
Rev. 2.00 Oct. 21, 2009 Page 1335 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
Bit
Bit
Bit
Bit
25/17/9/1
24/16/8/0
Module
ISCRL
INTC
IRQ7SR
IRQ7SF
IRQ6SR
IRQ6SF
IRQ5SR
IRQ5SF
IRQ4SR
IRQ4SF
IRQ3SR
IRQ3SF
IRQ2SR
IRQ2SF
IRQ1SR
IRQ1SF
IRQ0SR
IRQ0SF
BSC
DTCVBR
ABWCR
ABWH7
ABWH6
ABWH5
ABWH4
ABWH3
ABWH2
ABWH1
ABWH0
ABWL7
ABWL6
ABWL5
ABWL4
ABWL3
ABWL2
ABWL1
ABWL0
AST7
AST6
AST5
AST4
AST3
AST2
AST1
AST0
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
W72
W71
W70
⎯
W62
W61
W60
⎯
W52
W51
W50
⎯
W42
W41
W40
⎯
W32
W31
W30
⎯
W22
W21
W20
⎯
W12
W11
W10
⎯
W02
W01
W00
RDN7
RDN6
RDN5
RDN4
RDN3
RDN2
RDN1
RDN0
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
CSXH7
CSXH6
CSXH5
CSXH4
CSXH3
CSXH2
CSXH1
CSXH0
CSXT7
CSXT6
CSXT5
CSXT4
CSXT3
CSXT2
CSXT1
CSXT0
IDLS3
IDLS2
IDLS1
IDLS0
IDLCB1
IDLCB0
IDLCA1
IDLCA0
IDLSEL7
IDLSEL6
IDLSEL5
IDLSEL4
IDLSEL3
IDLSEL2
IDLSEL1
IDLSEL0
BRLE
BREQOE
⎯
⎯
⎯
⎯
WDBE
WAITE
DKC
⎯
⎯
⎯
⎯
⎯
⎯
⎯
BCR2
⎯
⎯
EBCCS
IBCCS
⎯
⎯
⎯
PWDBE
ENDIANCR
LE7
LE6
LE5
LE4
LE3
LE2
⎯
⎯
SRAMCR
BCSEL7
BCSEL6
BCSEL5
BCSEL4
BCSEL3
BCSEL2
BCSEL1
BCSEL0
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
BSRM0
BSTS02
BSTS01
BSTS00
⎯
⎯
BSWD01
BSWD00
BSRM1
BSTS12
BSTS11
BSTS10
⎯
⎯
BSWD11
BSWD10
MPXE7
MPXE6
MPXE5
MPXE4
MPXE3
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
ADDEX
ASTCR
WTCRA
WTCRB
RDNCR
CSACR
IDLCR
BCR1
BROMCR
MPXCR
Rev. 2.00 Oct. 21, 2009 Page 1336 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
Module
BSC
DRAME
DTYPE
⎯
⎯
OEE
RAST
⎯
CAST
BE
RCDM
DDS
EDDS
⎯
⎯
MXC1
MXC0
⎯
⎯
TPC1
TPC0
⎯
⎯
RCD1
RCD0
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
MRSE
⎯
⎯
⎯
⎯
⎯
⎯
⎯
CKSPE
⎯
⎯
⎯
⎯
⎯
⎯
TRWL
CMF
CMIE
RCW1
RCW0
⎯
RTCK2
RTCK1
RTCK0
RFSHE
RLW2
RLW1
RLW0
SLFRF
TPCS2
TPCS1
TPCS0
RAMER
⎯
⎯
⎯
⎯
RAMS
RAM2
RAM1
RAM0
MDCR
MDS7
⎯
⎯
⎯
MDS3
MDS2
MDS1
MDS0
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
MACS
⎯
FETCHMD ⎯
EXPE
RAME
⎯
⎯
⎯
⎯
⎯
⎯
DTCMD
⎯
PSTOP1
PSTOP0
⎯
⎯
⎯
ICK2
ICK1
ICK0
⎯
PCK2
PCK1
PCK0
⎯
BCK2
BCK1
BCK0
SSBY
OPE
⎯
STS4
STS3
STS2
STS1
STS0
SLPIE
⎯
⎯
⎯
⎯
⎯
⎯
⎯
ACSE
MSTPA14 MSTPA13 MSTPA12 MSTPA11 MSTPA10
MSTPA9
MSTPA8
MSTPA7
MSTPA6
MSTPA1
MSTPA0
MSTPB15 MSTPB14 MSTPB13 MSTPB12 MSTPB11 MSTPB10
MSTPB9
MSTPB8
MSTPB7
MSTPB1
MSTPB0
MSTPC15 MSTPC14 MSTPC13 MSTPC12 MSTPC11 MSTPC10
MSTPC9
MSTPC8
MSTPC7
MSTPC6
MSTPC5
MSTPC4
MSTPC3
MSTPC2
MSTPC1
MSTPC0
⎯
⎯
⎯
⎯
⎯
EXSTP
WAKE32K CK32K
DRAMCR
DRACCR
SDCR
REFCR
RTCNT
RTCOR
SYSCR
SCKCR
SBYCR
MSTPCRA
MSTPCRB
MSTPCRC
SUBCKCR
MSTPB6
MSTPA5
MSTPB5
MSTPA4
MSTPB4
MSTPA3
MSTPB3
MSTPA2
MSTPB2
SYSTEM
Rev. 2.00 Oct. 21, 2009 Page 1337 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
Module
FLASH
FCCS
⎯
⎯
⎯
FLER
⎯
⎯
⎯
SCO
FPCS
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PPVS
FECS
⎯
⎯
⎯
⎯
⎯
⎯
⎯
EPVB
FKEY
K7
K6
K5
K4
K3
K2
K1
K0
FMATS
MS7
MS6
MS5
MS4
MS3
MS2
MS1
MS0
FTDAR
TDER
TDA6
TDA5
TDA4
TDA3
TDA2
TDA1
TDA0
DPSBYCR
DPSBY
IOKEEP
RAMCUT2 RAMCUT1 ⎯
⎯
⎯
RAMCUT0 SYSTEM
DPSWCR
⎯
⎯
WTSTS5
WTSTS4
WTSTS3
WTSTS2
WTSTS1
WTSTS0
DPSIER
⎯
DUSBIE
DT32KIE
DLVDIE
DIRQ3E
DIRQ2E
DIRQ1E
DIRQ0E
DPSIFR
DNMIF
DUSBIF
DT32KIF
DLVDIF
DIRQ3F
DIRQ2F
DIRQ1F
DIRQ0F
DPSIEGR
DNMIEG
⎯
⎯
⎯
DIRQ3EG
DIRQ2EG
DIRQ1EG DIRQ0EG
RSTSR
DPSRSTF ⎯
⎯
⎯
⎯
LVDF
⎯
PORF
LVDCR*
LVDE
LVDRI
⎯
LVDMON
⎯
⎯
⎯
⎯
SEMR_2
⎯
⎯
⎯
⎯
ABCS
ACS2
ACS1
ACS0
SCI_2
CKS1
CKS0
SCI_4
3
1
SMR_4*
C/A
CHR
PE
O/E
STOP
MP
(GM)
(BLK)
(PE)
(O/E)
(BCP1)
(BCP0)
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
TDRE
RDRF
ORER
FER
PER
TEND
MPB
MPBT
BRR_4
SCR_4*1
TDR_4
SSR_4*1
(ERS)
RDR_4
SCMR_4
⎯
⎯
⎯
⎯
SDIR
SINV
⎯
SMIF
ICCRA_0
ICE
RCVD
MST
TRS
CKS3
CKS2
CKS1
CKS0
ICCRB_0
BBSY
SCP
SDAO
⎯
SCLO
⎯
IICRST
⎯
ICMR_0
⎯
WAIT
⎯
⎯
BCWP
BC2
BC1
BC0
ICIER_0
TIE
TEIE
RIE
NAKIE
STIE
ACKE
ACKBR
ACKBT
ICSR_0
TDRE
TEND
RDRF
NACKF
STOP
AL
AAS
ADZ
SAR_0
SVA6
SVA5
SVA4
SVA3
SVA2
SVA1
SVA0
⎯
ICDRT_0
ICDRR_0
Rev. 2.00 Oct. 21, 2009 Page 1338 of 1454
REJ09B0498-0200
IIC2_0
Section 29 List of Registers
Register
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
Bit
Bit
Bit
Bit
25/17/9/1
24/16/8/0
Module
ICCRA_1
ICE
RCVD
MST
TRS
CKS3
CKS2
CKS1
CKS0
IIC2_1
ICCRB_1
BBSY
SCP
SDAO
⎯
SCLO
⎯
IICRST
⎯
ICMR_1
⎯
WAIT
⎯
⎯
BCWP
BC2
BC1
BC0
ICIER_1
TIE
TEIE
RIE
NAKIE
STIE
ACKE
ACKBR
ACKBT
ICSR_1
TDRE
TEND
RDRF
NACKF
STOP
AL
AAS
ADZ
SAR_1
SVA6
SVA5
SVA4
SVA3
SVA2
SVA1
SVA0
⎯
TCR_2
CMIEB
CMIEA
OVIE
CCLR1
CCLR0
CKS2
CKS1
CKS0
TMR_2
TCR_3
CMIEB
CMIEA
OVIE
CCLR1
CCLR0
CKS2
CKS1
CKS0
TMR_3
TCSR_2
CMFB
CMFA
OVF
ADTE
OS3
OS2
OS1
OS0
TMR_2
TCSR_3
CMFB
CMFA
OVF
⎯
OS3
OS2
OS1
OS0
TMR_3
ICDRT_1
ICDRR_1
TCORA_2
TMR_2
TCORA_3
TMR_3
TCORB_2
TMR_2
TCORB_3
TMR_3
TCNT_2
TMR_2
TCNT_3
TMR_3
TCCR_2
⎯
⎯
⎯
⎯
TMRIS
⎯
ICKS1
ICKS0
TMR_2
TCCR_3
⎯
⎯
⎯
⎯
TMRIS
⎯
ICKS1
ICKS0
TMR_3
TCR_4
⎯
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TPU_4
TMDR_4
⎯
⎯
⎯
⎯
MD3
MD2
MD1
MD0
TIOR_4
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIER_4
TTGE
⎯
TCIEU
TCIEV
⎯
⎯
TGIEB
TGIEA
TSR_4
TCFD
⎯
TCFU
TCFV
⎯
⎯
TGFB
TGFA
TCNT_4
TGRA_4
Rev. 2.00 Oct. 21, 2009 Page 1339 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
TGRB_4
Module
TPU_4
TCR_5
⎯
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_5
⎯
⎯
⎯
⎯
MD3
MD2
MD1
MD0
TIOR_5
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIER_5
TTGE
⎯
TCIEU
TCIEV
⎯
⎯
TGIEB
TGIEA
TSR_5
TCFD
⎯
TCFU
TCFV
⎯
⎯
TGFB
TGFA
DTCEA15 DTCEA14 DTCEA13
DTCEA12
DTCEA11
DTCEA10
DTCEA9
DTCEA8
DTCEA7
DTCEA5
DTCEA4
⎯
⎯
⎯
⎯
DTCEB15 ⎯
DTCEB13
DTCEB12
DTCEB11
DTCEB10
DTCEB9
DTCEB8
DTCEB7
DTCEB5
DTCEB4
DTCEB3
DTCEB2
DTCEB1
DTCEB0
DTCEC15 DTCEC14 DTCEC13 DTCEC12 DTCEC11
DTCEC10
DTCEC9
DTCEC8
DTCEC7
DTCEC2
DTCEC1
DTCEC0
DTCED15 DTCED14 DTCED13 DTCED12 DTCED11
DTCED10
DTCED9
DTCED8
DTCED7
DTCED6
DTCED5
DTCED4
DTCED3
DTCED2
DTCED1
DTCED0
⎯
⎯
DTCEE13
DTCEE12
DTCEE11
DTCEE10
DTCEE9
DTCEE8
DTCEE7
DTCEE6
DTCEE5
DTCEE4
DTCEE3
DTCEE2
DTCEE1
DTCEE0
DTCEF15 DTCEF14 ⎯
⎯
DTCEF11
DTCEF10
DTCEF9
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
DTCCR
⎯
⎯
⎯
RRS
RCHNE
⎯
⎯
ERR
INTCR
⎯
⎯
INTM1
INTM0
NMIEG
⎯
⎯
⎯
CPUPCR
CPUPCE
DTCP2
DTCP1
DTCP0
IPSETE
CPUP2
CPUP1
CPUP0
IER
IRQ15E
⎯
⎯
⎯
IRQ11E
IRQ10E
IRQ9E
IRQ8E
IRQ7E
IRQ6E
IRQ5E
IRQ4E
IRQ3E
IRQ2E
IRQ1E
IRQ0E
TPU_5
TCNT_5
TGRA_5
TGRB_5
DTCERA
DTCERB
DTCERC
DTCERD
DTCERE
DTCERF
DTCEA6
DTCEB6
DTCEC6
DTCEC5
Rev. 2.00 Oct. 21, 2009 Page 1340 of 1454
REJ09B0498-0200
DTCEC4
DTCEC3
INTC
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
Module
INTC
IRQ15F
⎯
⎯
⎯
IRQ11F
IRQ10F
IRQ9F
IRQ8F
IRQ7F
IRQ6F
IRQ5F
IRQ4F
IRQ3F
IRQ2F
IRQ1F
IRQ0F
PORT1
P17
P16
P15
P14
P13
P12
P11
P10
PORT2
P27
P26
P25
P24
P23
P22
P21
P20
PORT3
P37
P36
P35
P34
P33
P32
P31
P30
PORT5
P57
P56
P55
P54
P53
P52
P51
P50
PORT6
⎯
⎯
P65
P64
P63
P62
P61
P60
PORTA
PA7
PA6
PA5
PA4
PA3
PA2
PA1
PA0
PORTB
PB7
PB6
PB5
PB4
PB3
PB2
PB1
PB0
PORTC
⎯
⎯
⎯
⎯
PC3
PC2
⎯
⎯
PORTD
PD7
PD6
PD5
PD4
PD3
PD2
PD1
PD0
PORTE
PE7
PE6
PE5
PE4
PE3
PE2
PE1
PE0
PORTF
PF7
PF6
PF5
PF4
PF3
PF2
PF1
PF0
P1DR
P17DR
P16DR
P15DR
P14DR
P13DR
P12DR
P11DR
P10DR
P2DR
P27DR
P26DR
P25DR
P24DR
P23DR
P22DR
P21DR
P20DR
P3DR
P37DR
P36DR
P35DR
P34DR
P33DR
P32DR
P31DR
P30DR
P6DR
⎯
⎯
P65DR
P64DR
P63DR
P62DR
P61DR
P60DR
PADR
PA7DR
PA6DR
PA5DR
PA4DR
PA3DR
PA2DR
PA1DR
PA0DR
PBDR
PB7DR
PB6DR
PB5DR
PB4DR
PB3DR
PB2DR
PB1DR
PB0DR
PCDR
⎯
⎯
⎯
⎯
PC3DR
PC2DR
⎯
⎯
PDDR
PD7DR
PD6DR
PD5DR
PD4DR
PD3DR
PD2DR
PD1DR
PD0DR
PEDR
PE7DR
PE6DR
PE5DR
PE4DR
PE3DR
PE2DR
PE1DR
PE0DR
PFDR
PF7DR
PF6DR
PF5DR
PF4DR
PF3DR
PF2DR
PF1DR
PF0DR
ISR
I/O port
Rev. 2.00 Oct. 21, 2009 Page 1341 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
1
SMR_2*
Bit
Bit
25/17/9/1
24/16/8/0
Module
CKS1
CKS0
SCI_2
C/A
CHR
PE
O/E
STOP
MP
(GM)
(BLK)
(PE)
(O/E)
(BCP1)
(BCP0)
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
TDRE
RDRF
ORER
FER
PER
TEND
MPB
MPBT
SDIR
SINV
⎯
SMIF
BRR_2
SCR_2*1
TDR_2
SSR_2*1
(ERS)
RDR_2
SCMR_2
⎯
⎯
⎯
⎯
DADR0H
D/A
DADR1H
DACR01
DAOE1
DAOE0
DAE
⎯
⎯
⎯
⎯
⎯
DADR01T
DADT1
DADT0
DAD1L1
DAD1L0
DAD0L1
DAD0L0
⎯
⎯
PCR
G3CMS1
G3CMS0
G2CMS1
G2CMS0
G1CMS1
G1CMS0
G0CMS1
G0CMS0
PMR
G3INV
G2INV
G1INV
G0INV
G3NOV
G2NOV
G1NOV
G0NOV
NDERH
NDER15
NDER14
NDER13
NDER12
NDER11
NDER10
NDER9
NDER8
NDERL
NDER7
NDER6
NDER5
NDER4
NDER3
NDER2
NDER1
NDER0
PODRH
POD15
POD14
POD13
POD12
POD11
POD10
POD9
POD8
PODRL
POD7
POD6
POD5
POD4
POD3
POD2
POD1
POD0
NDR15
NDR14
NDR13
NDR12
NDR11
NDR10
NDR9
NDR8
NDRL*
NDR7
NDR6
NDR5
NDR4
NDR3
NDR2
NDR1
NDR0
NDRH*2
⎯
⎯
⎯
⎯
NDR11
NDR10
NDR9
NDR8
⎯
⎯
⎯
⎯
NDR3
NDR2
NDR1
NDR0
CKS1
CKS0
CKE1
CKE0
NDRH*
2
2
NDRL*2
1
SMR_0*
C/A
CHR
PE
O/E
STOP
MP
(GM)
(BLK)
(PE)
(O/E)
(BCP1)
(BCP0)
TIE
RIE
TE
RE
MPIE
TEIE
BRR_0
SCR_0*1
TDR_0
Rev. 2.00 Oct. 21, 2009 Page 1342 of 1454
REJ09B0498-0200
PPG_0
SCI_0
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
1
SSR_0*
TDRE
RDRF
ORER
FER
Bit
Bit
25/17/9/1
24/16/8/0
Module
SCI_0
PER
TEND
MPB
MPBT
(ERS)
RDR_0
SCMR_0
1
SMR_1*
⎯
⎯
⎯
⎯
SDIR
SINV
⎯
SMIF
CKS1
CKS0
C/A
CHR
PE
O/E
STOP
MP
(GM)
(BLK)
(PE)
(O/E)
(BCP1)
(BCP0)
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
TDRE
RDRF
ORER
FER
PER
TEND
MPB
MPBT
SDIR
SINV
⎯
SMIF
SCI_1
BRR_1
SCR_1*1
TDR_1
SSR_1*1
(ERS)
RDR_1
SCMR_1
ADDRA_0
⎯
⎯
⎯
⎯
A/D_0
ADDRB_0
ADDRC_0
ADDRD_0
ADDRE_0
ADDRF_0
ADDRG_0
ADDRH_0
Rev. 2.00 Oct. 21, 2009 Page 1343 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
Module
A/D_0
ADCSR_0
ADF
ADIE
ADST
⎯
CH3
CH2
CH1
CH0
ADCR_0
TRGS1
TRGS0
SCANE
SCANS
CKS1
CKS0
⎯
EXTRGS
ADMOSEL_0 ⎯
⎯
⎯
⎯
⎯
⎯
ICKSEL
⎯
TCSR
OVF
WT/IT
TME
⎯
⎯
CKS2
CKS1
CKS0
RSTCSR
WOVF
RSTE
⎯
⎯
⎯
⎯
⎯
⎯
TCR_0
CMIEB
CMIEA
OVIE
CCLR1
CCLR0
CKS2
CKS1
CKS0
TMR_0
TCR_1
CMIEB
CMIEA
OVIE
CCLR1
CCLR0
CKS2
CKS1
CKS0
TMR_1
TCSR_0
CMFB
CMFA
OVF
ADTE
OS3
OS2
OS1
OS0
TMR_0
TCSR_1
CMFB
CMFA
OVF
⎯
OS3
OS2
OS1
OS0
TMR_1
WDT
TCNT
TCORA_0
TMR_0
TCORA_1
TMR_1
TCORB_0
TMR_0
TCORB_1
TMR_1
TCNT_0
TMR_0
TCNT_1
TMR_1
TCCR_0
⎯
⎯
⎯
⎯
TMRIS
⎯
ICKS1
ICKS0
TMR_0
TCCR_1
⎯
⎯
⎯
⎯
TMRIS
⎯
ICKS1
ICKS0
TMR_1
TSTR
⎯
⎯
CST5
CST4
CST3
CST2
CST1
CST0
TPU
TSYR
⎯
⎯
SYNC5
SYNC4
SYNC3
SYNC2
SYNC1
SYNC0
TCR_0
CCLR2
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_0
⎯
⎯
BFB
BFA
MD3
MD2
MD1
MD0
TIORH_0
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIORL_0
IOD3
IOD2
IOD1
IOD0
IOC3
IOC2
IOC1
IOC0
TIER_0
TTGE
⎯
⎯
TCIEV
TGIED
TGIEC
TGIEB
TGIEA
TSR_0
⎯
⎯
⎯
TCFV
TGFD
TGFC
TGFB
TGFA
Rev. 2.00 Oct. 21, 2009 Page 1344 of 1454
REJ09B0498-0200
TPU_0
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
TCNT_0
Module
TPU_0
TGRA_0
TGRB_0
TGRC_0
TGRD_0
TCR_1
⎯
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_1
⎯
⎯
⎯
⎯
MD3
MD2
MD1
MD0
TIOR_1
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIER_1
TTGE
⎯
TCIEU
TCIEV
⎯
⎯
TGIEB
TGIEA
TSR_1
TCFD
⎯
TCFU
TCFV
⎯
⎯
TGFB
TGFA
TCR_2
⎯
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_2
⎯
⎯
⎯
⎯
MD3
MD2
MD1
MD0
TIOR_2
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIER_2
TTGE
⎯
TCIEU
TCIEV
⎯
⎯
TGIEB
TGIEA
TSR_2
TCFD
⎯
TCFU
TCFV
⎯
⎯
TGFB
TGFA
TPU_1
TCNT_1
TGRA_1
TGRB_1
TPU_2
TCNT_2
TGRA_2
Rev. 2.00 Oct. 21, 2009 Page 1345 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation 31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2
Bit
Bit
25/17/9/1
24/16/8/0
TGRB_2
Module
TPU_2
TCR_3
CCLR2
CCLR1
CCLR0
CKEG1
CKEG0
TPSC2
TPSC1
TPSC0
TMDR_3
⎯
⎯
BFB
BFA
MD3
MD2
MD1
MD0
TIORH_3
IOB3
IOB2
IOB1
IOB0
IOA3
IOA2
IOA1
IOA0
TIORL_3
IOD3
IOD2
IOD1
IOD0
IOC3
IOC2
IOC1
IOC0
TIER_3
TTGE
⎯
⎯
TCIEV
TGIED
TGIEC
TGIEB
TGIEA
TSR_3
⎯
⎯
⎯
TCFV
TGFD
TGFC
TGFB
TGFA
TPU_3
TCNT_3
TGRA_3
TGRB_3
TGRC_3
TGRD_3
Notes: 1. Parts of the bit functions differ in normal mode and the smart card interface.
2. When the same output trigger is specified for pulse output groups 2 and 3 by the PCR
setting, the NDRH address is H'FFF7C. When different output triggers are specified, the
NDRH addresses for pulse output groups 2 and 3 are H'FFF7E and H'FFF7C,
respectively. Similarly, when the same output trigger is specified for pulse output groups
0 and 1 by the PCR setting, the NDRL address is H'FFF7D. When different output
triggers are specified, the NDRL addresses for pulse output groups 0 and 1 are
H'FFF7F and H'FFF7D, respectively.
When the same output trigger is specified for pulse output groups 6 and 7 by the PCR
setting, the NDRH address is H'FF63C. When different output triggers are specified, the
NDRH addresses for pulse output groups 6 and 7 are H'FF63E and H'FF63C,
respectively.
When the same output trigger is specified for pulse output groups 4 and 5 by the PCR
setting, the NDRL address is H'FF63D. When different output triggers are specified, the
NDRL addresses for pulse output groups 4 and 5 are H'FF63F and H'FF63D,
respectively.
3. Supported only by the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1346 of 1454
REJ09B0498-0200
Section 29 List of Registers
29.3
Register States in Each Operating Mode
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
TCORA_5
Initialized
⎯
⎯
⎯
TCORB_4
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
TMR_4
Initialized*
1
Initialized
TMR_5
Initialized*
1
Initialized
TMR_4
Initialized*
1
Initialized
TMR_5
Initialized*
1
Initialized
TMR_4
⎯
Initialized*
1
Initialized
TMR_5
⎯
⎯
Initialized*
1
Initialized
TMR_4
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_5
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_4
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_5
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_4
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_5
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
CRC
CRCDIR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
CRCDOR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_6
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_7
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_6
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_7
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_6
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_7
TCORB_6
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_6
TCORB_7
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_7
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_6
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_7
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_6
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_7
TCR_4
TCR_5
TCSR_4
TCSR_5
TCORA_4
TCORB_5
TCNT_4
TCNT_5
TCCR_4
TCCR_5
CRCCR
TCR_6
TCR_7
TCSR_6
TCSR_7
TCORA_6
TCORA_7
TCNT_6
TCNT_7
TCCR_6
TCCR_7
Standby
Rev. 2.00 Oct. 21, 2009 Page 1347 of 1454
REJ09B0498-0200
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
ADDRD_1
Initialized
⎯
⎯
⎯
ADDRE_1
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
A/D_1
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ADSSTR_1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
IFR0
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
ISR1
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
ISR2
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
EPSZ0o
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
EPSZ1
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
ADDRA_1
ADDRB_1
ADDRC_1
ADDRF_1
ADDRG_1
ADDRH_1
ADCSR_1
ADCR_1
ADMOSEL_1
IFR1
IFR2
IER0
IER1
IER2
ISR0
EPDR0i
EPDR0o
EPDR0s
EPDR1
EPDR2
EPDR3
DASTS
Rev. 2.00 Oct. 21, 2009 Page 1348 of 1454
REJ09B0498-0200
Standby
USB
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
DMA
Initialized
⎯
⎯
⎯
CVR
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
2
Initialized
USB
Initialized*
2
Initialized
Initialized*
2
Initialized
⎯
Initialized*
2
Initialized
⎯
⎯
Initialized*
2
Initialized
⎯
⎯
⎯
Initialized*
2
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
2
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PMDR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PORTM
⎯
⎯
⎯
⎯
⎯
⎯
PMICR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
Initialized*
1
Initialized
Initialized
⎯
Initialized*
1
Initialized
Initialized
Initialized
⎯
Initialized
Initialized
Initialized*
1
Initialized
SCMR_5
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
SEMR_5
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
Initialized*
1
Initialized
Initialized
⎯
Initialized*
1
Initialized
Initialized
FCLR
EPSTL
TRG
CTLR
EPIR
TRNTREG0
TRNTREG1
PMDDR
SMR_5
BRR_5
SCR_5
TDR_5
SSR_5
RDR_5
IrCR
SMR_6
BRR_6
SCR_6
TDR_6
SSR_6
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Standby
⎯
RDR_6
Initialized
Initialized
⎯
Initialized
Initialized
Initialized*
1
SCMR_6
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
SEMR_6
I/O port
SCI_5
SCI_6
Rev. 2.00 Oct. 21, 2009 Page 1349 of 1454
REJ09B0498-0200
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
NDERL_1
Initialized
⎯
⎯
⎯
PODRH_1
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
PCR_1
PMR_1
NDERH_1
PODRL_1
NDRH_1
NDRL_1
BARAH
BARAL
BAMRAH
BAMRAL
BARBH
BARBL
BAMRBH
BAMRBL
BARCH
BARCL
BAMRCH
BAMRCL
BARDH
BARDL
BAMRDH
BAMRDL
BRCRA
BRCRB
BRCRC
BRCRD
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
PPG_1
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Rev. 2.00 Oct. 21, 2009 Page 1350 of 1454
REJ09B0498-0200
Standby
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
UBC
Section 29 List of Registers
Software
All-ModuleClock-Stop Standby
Deep Software
Reset
Module
Stop State Sleep
Standby
Hardware
Standby
Module
TCR32K
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
TM32K
TCNT32K1
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
TCNT32K2
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
TCNT32K3
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
ADSSTR_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
A/D_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TPU
(unit 1)
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TIER_6
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TSR_6
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMDR_7
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TIOR_7
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMDR_8
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TIOR_8
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Register
Abbreviation
TSTRB
TSYRB
TCR_6
TMDR_6
TIORH_6
TIORL_6
TCNT_6
TGRA_6
TGRB_6
TGRC_6
TGRD_6
TCR_7
TIER_7
TSR_7
TCNT_7
TGRA_7
TGRB_7
TCR_8
TIER_8
TPU_6
TPU_7
TPU_8
Rev. 2.00 Oct. 21, 2009 Page 1351 of 1454
REJ09B0498-0200
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
TGRB_8
Initialized
⎯
⎯
⎯
TCR_9
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
TPU_8
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TGRA_9
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TGRB_9
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TSR_10
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TCNT_10
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TSR_11
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TCNT_11
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TSR_8
TCNT_8
TGRA_8
TMDR_9
TIORH_9
TIORL_9
TIER_9
TSR_9
TCNT_9
TGRC_9
TGRD_9
TCR_10
TMDR_10
TIOR_10
TIER_10
TGRA_10
TGRB_10
TCR_11
TMDR_11
TIOR_11
TIER_11
Rev. 2.00 Oct. 21, 2009 Page 1352 of 1454
REJ09B0498-0200
Standby
TPU_9
TPU_10
TPU_11
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
P2DDR
Initialized
⎯
⎯
⎯
P3DDR
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
TPU_11
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PFDDR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
P1ICR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PCICR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PDICR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PFICR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PORTH
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORTI
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORTJ
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORTK
⎯
⎯
⎯
⎯
⎯
⎯
PHDR
Initialized
⎯
⎯
⎯
⎯
PIDR
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
TGRA_11
TGRB_11
P1DDR
P6DDR
PADDR
PBDDR
PCDDR
PDDDR
PEDDR
P2ICR
P3ICR
P5ICR
P6ICR
PAICR
PBICR
PEICR
PJDR
Standby
I/O port
⎯
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Rev. 2.00 Oct. 21, 2009 Page 1353 of 1454
REJ09B0498-0200
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
PJDDR
Initialized
⎯
⎯
⎯
PKDDR
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
I/O port
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PFPCR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PHPCR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PFCR1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PFCR2
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PKDR
PHDDR
PIDDR
PHICR
PIICR
PJICR
PKICR
PDPCR
PEPCR
PIPCR
PJPCR
PKPCR
P2ODR
PFODR
PFCR0
PFCR4
PFCR6
PFCR7
PFCR8
PFCR9
Rev. 2.00 Oct. 21, 2009 Page 1354 of 1454
REJ09B0498-0200
Standby
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
PFCRD
Initialized
⎯
⎯
⎯
SSIER
Initialized
⎯
⎯
DPSBKR0
Initialized
⎯
DPSBKR1
Initialized
DPSBKR2
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
I/O port
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
INTC
⎯
⎯
⎯
⎯
Initialized
SYSTEM
⎯
⎯
⎯
⎯
⎯
Initialized
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR3
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR4
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR5
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR6
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR7
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR8
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR9
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR10
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR11
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR12
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR13
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR14
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSBKR15
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
PFCRA
PFCRB
PFCRC
DSAR_0
DDAR_0
DOFR_0
DTCR_0
DBSR_0
DMDR_0
DACR_0
Standby
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
DMAC_0
Rev. 2.00 Oct. 21, 2009 Page 1355 of 1454
REJ09B0498-0200
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
DTCR_1
Initialized
⎯
⎯
⎯
DBSR_1
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
DMAC_1
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
DBSR_2
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
DMDR_2
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
DMDR_3
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
DACR_3
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
DSAR_1
DDAR_1
DOFR_1
DMDR_1
DACR_1
DSAR_2
DDAR_2
DOFR_2
DTCR_2
DACR_2
DSAR_3
DDAR_3
DOFR_3
DTCR_3
DBSR_3
EDSAR_0
EDDAR_0
EDOFR_0
EDTCR_0
EDBSR_0
EDMDR_0
EDACR_0
Rev. 2.00 Oct. 21, 2009 Page 1356 of 1454
REJ09B0498-0200
Standby
DMAC_2
DMAC_3
EXDMAC_0
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
EDTCR_1
Initialized
⎯
⎯
⎯
EDBSR_1
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
EXDMAC_1
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
EDBSR_2
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
EDMDR_2
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
EDMDR_3
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
EDACR_3
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
CLSBR0
⎯
⎯
⎯
⎯
⎯
⎯
⎯
CLSBR1
⎯
⎯
⎯
⎯
⎯
⎯
⎯
CLSBR2
⎯
⎯
⎯
⎯
⎯
⎯
⎯
CLSBR3
⎯
⎯
⎯
⎯
⎯
⎯
⎯
CLSBR4
⎯
⎯
⎯
⎯
⎯
⎯
⎯
CLSBR5
⎯
⎯
⎯
⎯
⎯
⎯
⎯
CLSBR6
⎯
⎯
⎯
⎯
⎯
⎯
⎯
CLSBR7
⎯
⎯
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
EDSAR_1
EDDAR_1
EDOFR_1
EDMDR_1
EDACR_1
EDSAR_2
EDDAR_2
EDOFR_2
EDTCR_2
EDACR_2
EDSAR_3
EDDAR_3
EDOFR_3
EDTCR_3
EDBSR_3
DMRSR_0
Standby
Initialized*
EXDMAC_2
EXDMAC_3
EXDMAC
⎯
1
Initialized
DMAC_0
Rev. 2.00 Oct. 21, 2009 Page 1357 of 1454
REJ09B0498-0200
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
IPRC
Initialized
⎯
⎯
⎯
IPRD
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
DMAC_1
Initialized*
1
Initialized
DMAC_2
Initialized*
1
Initialized
DMAC_3
Initialized*
1
Initialized
INTC
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
IPRK
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
IPRL
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ISCRL
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
DTCVBR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
DMRSR_1
DMRSR_2
DMRSR_3
IPRA
IPRB
IPRE
IPRF
IPRG
IPRH
IPRI
IPRJ
IPRM
IPRN
IPRO
IPRQ
IPRR
ISCRH
ABWCR
ASTCR
WTCRA
WTCRB
RDNCR
CSACR
IDLCR
Rev. 2.00 Oct. 21, 2009 Page 1358 of 1454
REJ09B0498-0200
Standby
BSC
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
SRAMCR
Initialized
⎯
⎯
⎯
BROMCR
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
BSC
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
RTCOR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
RAMER
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
MSTPCRC
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
SUBCKCR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
BCR1
BCR2
ENDIANCR
MPXCR
DRAMCR
DRACCR
SDCR
REFCR
RTCNT
MDCR
SYSCR
SCKCR
SBYCR
MSTPCRA
MSTPCRB
FCCS
FPCS
FECS
FKEY
FMATS
FTDAR
Standby
SYSTEM
FLASH
Rev. 2.00 Oct. 21, 2009 Page 1359 of 1454
REJ09B0498-0200
Section 29 List of Registers
Software
All-ModuleClock-Stop Standby
Deep Software
Reset
Module
Stop State Sleep
Standby
Hardware
Standby
Module
DPSBYCR
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
SYSTEM
DPSWCR
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSIER
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSIFR
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
DPSIEGR
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
RSTSR
Initialized
⎯
⎯
⎯
⎯
⎯
Initialized
Register
Abbreviation
⎯
⎯
⎯
⎯
⎯
SEMR_2
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
SCI_2
SMR_4
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
SCI_4
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
Initialized*
1
Initialized
Initialized
⎯
Initialized*
1
Initialized
Initialized
Initialized
⎯
Initialized
Initialized
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ICCRA_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ICCRB_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ICCRA_1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ICCRB_1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
LVDCR*
3
BRR_4
SCR_4
TDR_4
SSR_4
RDR_4
SCMR_4
ICMR_0
ICIER_0
ICSR_0
SAR_0
ICDRT_0
ICDRR_0
ICMR_1
ICIER_1
ICSR_1
SAR_1
ICDRT_1
Initialized*
Initialized
Initialized
4
Rev. 2.00 Oct. 21, 2009 Page 1360 of 1454
REJ09B0498-0200
Initialized
Initialized
Initialized
Initialized
Initialized
IIC2_0
IIC2_1
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
TCSR_2
Initialized
⎯
⎯
⎯
TCSR_3
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
IIC2_1
Initialized*
1
Initialized
TMR_2
Initialized*
1
Initialized
TMR_3
⎯
Initialized*
1
Initialized
TMR_2
⎯
⎯
Initialized*
1
Initialized
TMR_3
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_2
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_3
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_2
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_3
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_2
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_3
TCCR_2
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_2
TCCR_3
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_3
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TPU_4
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TGRA_4
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TGRB_4
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TGRA_5
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TGRB_5
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ICDRR_1
TCR_2
TCR_3
TCORA_2
TCORA_3
TCORB_2
TCORB_3
TCNT_2
TCNT_3
TCR_4
TMDR_4
TIOR_4
TIER_4
TSR_4
TCNT_4
TCR_5
TMDR_5
TIOR_5
TIER_5
TSR_5
TCNT_5
Standby
TPU_5
Rev. 2.00 Oct. 21, 2009 Page 1361 of 1454
REJ09B0498-0200
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
DTCERD
Initialized
⎯
⎯
⎯
DTCERE
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
INTC
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ISR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
PORT1
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORT2
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORT3
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORT5
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORT6
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORTA
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORTB
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORTC
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORTD
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORTE
⎯
⎯
⎯
⎯
⎯
⎯
⎯
PORTF
⎯
⎯
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
PBDR
Initialized
⎯
⎯
⎯
PCDR
Initialized
⎯
⎯
Initialized
⎯
⎯
DTCERA
DTCERB
DTCERC
DTCERF
DTCCR
INTCR
CPUPCR
IER
P1DR
P2DR
P3DR
P6DR
PADR
PDDR
Rev. 2.00 Oct. 21, 2009 Page 1362 of 1454
REJ09B0498-0200
Standby
⎯
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
I/O port
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
BRR_2
Initialized
⎯
⎯
⎯
SCR_2
Initialized
⎯
⎯
⎯
Initialized
⎯
Initialized
⎯
Initialized
Initialized
⎯
Initialized
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
DACR01
Initialized
⎯
⎯
⎯
DADR01T
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
I/O port
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
NDRH
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
NDRL
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
Initialized*
1
Initialized
Initialized
⎯
Initialized*
1
Initialized
PEDR
PFDR
SMR_2
TDR_2
SSR_2
RDR_2
SCMR_2
DADR0H
DADR1H
PCR
PMR
NDERH
NDERL
PODRH
PODRL
SMR_0
BRR_0
SCR_0
TDR_0
SSR_0
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Initialized
Standby
SCI_2
D/A
PPG
SCI_0
Rev. 2.00 Oct. 21, 2009 Page 1363 of 1454
REJ09B0498-0200
Section 29 List of Registers
Register
Abbreviation
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
SCI_0
Initialized*
1
Initialized
Initialized*
1
Initialized
Initialized
Standby
Initialized
Initialized
⎯
Initialized
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
BRR_1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
SCR_1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
Initialized*
1
Initialized
Initialized
⎯
Initialized*
1
Initialized
Initialized
Initialized
⎯
Initialized
Initialized
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ADDRC_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ADDRD_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
ADMOSEL_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TCSR
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_1
TCORA_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_0
TCORA_1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMR_0
RDR_0
SCMR_0
SMR_1
TDR_1
SSR_1
RDR_1
SCMR_1
ADDRA_0
ADDRB_0
ADDRE_0
ADDRF_0
ADDRG_0
ADDRH_0
ADCSR_0
ADCR_0
TCNT
RSTCSR
TCR_0
TCR_1
TCSR_0
TCSR_1
TCORB_0
Initialized
Initialized
Rev. 2.00 Oct. 21, 2009 Page 1364 of 1454
REJ09B0498-0200
Initialized
Initialized
Initialized
Initialized
SCI_1
A/D_0
WDT
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
TCCR_0
Initialized
⎯
⎯
⎯
TCCR_1
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
TMR_1
Initialized*
1
Initialized
TMR_0
Initialized*
1
Initialized
TMR_1
⎯
Initialized*
1
Initialized
TMR_0
⎯
⎯
Initialized*
1
Initialized
TMR_1
⎯
⎯
⎯
Initialized*
1
Initialized
TPU
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TIER_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TSR_0
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TMDR_1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TIOR_1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TCORB_1
TCNT_0
TCNT_1
TSTR
TSYR
TCR_0
TMDR_0
TIORH_0
TIORL_0
TCNT_0
TGRA_0
TGRB_0
TGRC_0
TGRD_0
TCR_1
TIER_1
TSR_1
TCNT_1
TGRA_1
TGRB_1
Standby
TPU_0
TPU_1
Rev. 2.00 Oct. 21, 2009 Page 1365 of 1454
REJ09B0498-0200
Section 29 List of Registers
Reset
Module
Stop State Sleep
Software
All-ModuleClock-Stop Standby
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
Initialized
⎯
⎯
⎯
⎯
TIER_2
Initialized
⎯
⎯
⎯
TSR_2
Initialized
⎯
⎯
Initialized
⎯
Initialized
Register
Abbreviation
Deep Software
Hardware
Standby
Module
Initialized*
1
Initialized
TPU_2
Initialized*
1
Initialized
Initialized*
1
Initialized
⎯
Initialized*
1
Initialized
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
Initialized*
1
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TIORL_3
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TIER_3
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
Initialized
⎯
⎯
⎯
⎯
Initialized*
1
Initialized
TCR_2
TMDR_2
TIOR_2
TCNT_2
TGRA_2
TGRB_2
TCR_3
TMDR_3
TIORH_3
TSR_3
TCNT_3
TGRA_3
TGRB_3
TGRC_3
TGRD_3
Standby
TPU_3
Notes: 1. Not initialized in deep software standby mode but initialized when deep software
standby mode is released by the internal reset.
2. These registers are initialized when all the RAMCUT2 to RAMCUT0 bits in DPSBYCR
are set to 1, and not initialized when these bits are set to 0.
3. Supported only by the H8SX/1665M Group.
4. LVDCR is initialized by a pin reset or power-on reset not by a voltage-monitoring reset,
deep software standby reset, or watchdog timer reset.
Rev. 2.00 Oct. 21, 2009 Page 1366 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Section 30 Electrical Characteristics
30.1
Absolute Maximum Ratings
Table 30.1 Absolute Maximum Ratings
Item
Symbol
Value
Unit
Power supply voltage
VCC
–0.3 to +4.6
V
PLLVCC
DrVCC
Input voltage (except for port 5)
Vin
–0.3 to VCC +0.3
V
Input voltage (port 5)
Vin
–0.3 to AVCC +0.3
V
Reference power supply voltage
Vref
–0.3 to AVCC +0.3
V
Analog power supply voltage
AVCC
–0.3 to +4.6
V
Analog input voltage
VAN
–0.3 to AVCC +0.3
V
Operating temperature
Topr
Regular specifications:
–20 to +75*
°C
Wide-range specifications:
–40 to +85*
Storage temperature
Tstg
–55 to +125
°C
Caution: Permanent damage to the LSI may result if absolute maximum ratings are exceeded.
Note: * The operating temperature range during programming/erasing of the flash memory is
0°C to +75°C for regular specifications and 0°C to +85°C for wide-range specifications.
Rev. 2.00 Oct. 21, 2009 Page 1367 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
30.2
DC Characteristics (H8SX/1665 Group)
Table 30.2 DC Characteristics
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V*1,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Schmitt
IRQ input pin,
trigger input TPU input pin,
voltage
TMR input pin,
port 2, port 3
port J, port K
IRQ0-B to
Symbol
VT
–
VT
+
+
VT – VT
VT–
IRQ7-B input pin VT+
–
Min.
Typ.
Max.
Test
Unit Conditions
VCC × 0.2
⎯
⎯
V
⎯
⎯
VCC × 0.7
V
VCC × 0.06
⎯
⎯
V
AVCC × 0.2
⎯
⎯
V
⎯
+
–
VT – VT AVCC × 0.06
Input high
voltage
(except
Schmitt
trigger input
pin)
Input low
voltage
(except
Schmitt
trigger input
pin)
AVCC × 0.7 V
⎯
V
V
MD, RES, STBY, VIH
EMLE, NMI
VCC × 0.9
⎯
VCC + 0.3
EXTAL
VCC × 0.7
⎯
VCC + 0.3
Port 5
AVCC × 0.7
⎯
AVCC + 0.3
MD, RES, STBY, VIL
EMLE
–0.3
⎯
VCC × 0.1
EXTAL, NMI
–0.3
⎯
VCC × 0.2
Other input pins
–0.3
⎯
VCC × 0.2
VCC – 0.5
⎯
⎯
VCC – 1.0
⎯
⎯
⎯
⎯
0.4
⎯
⎯
1.0
Other input pins
Output high All output pins
voltage
VOH
Output low
voltage
VOL
Input
leakage
current
⎯
⎯
All output pins
Port 3
RES
⎯
⎯
10.0
MD, STBY,
EMLE, NMI
⎯
⎯
1.0
Port 5
⎯
⎯
1.0
|Iin|
Rev. 2.00 Oct. 21, 2009 Page 1368 of 1454
REJ09B0498-0200
V
V
IOH = –200 μA
IOH = –1 mA
V
IOL = 1.6 mA
IOL = 10 mA
μA
Vin = 0.5 to
VCC – 0.5 V
Vin = 0.5 to
AVCC – 0.5 V
Section 30 Electrical Characteristics
Test
Symbol Min. Typ. Max. Unit Conditions
Item
Three-state
Ports 1, 2, 3, 6,
leakage current A to F, H, I, J, K, M
(off state)
| ITSI|
⎯
⎯
1.0
μA
Vin = 0.5 to
VCC – 0.5 V
Input pull-up
MOS current
–Ip
10
⎯
300
μA
VCC = 3.0 to
3.6 V
Ports D to F, H, I
Vin = 0 V
Input
capacitance
Supply current
*2
⎯
⎯
15
pF
Vin = 0 V
f = 1 MHz
Ta = 25°C
⎯
50
85
mA
f = 50 MHz
Sleep mode
⎯
48
60
Subclock operation
⎯
5
10
32.768-kHz
crystal
resonator is
used.
Standby Software standby mode
mode
⎯
0.15
1.1
Ta ≤ 50°C
⎯
⎯
3.5
50°C < Ta
⎯
20
60
⎯
⎯
200
50°C < Ta
⎯
3
8
Ta ≤ 50°C
⎯
⎯
26
All input pins
Cin
Normal operation
ICC*
3
9
16
⎯
⎯
41
Hardware standby mode
⎯
2
7
Ta ≤ 50°C
⎯
⎯
25
50°C < Ta
⎯
23
30
mA
⎯
2.0
3.5
mA
⎯
0.5
1.5
μA
⎯
0.8
1.5
mA
⎯
0.5
1.5
μA
2.5
⎯
⎯
V
⎯
0.8
V
All-module-clock-stop mode*
Reference
power supply
current
During A/D and D/A conversion
AICC
Standby for A/D and D/A conversion
During A/D and D/A conversion
AICC
Standby for A/D and D/A conversion
RAM standby voltage
5
Vcc start voltage*
Ta ≤ 50°C
⎯
4
Analog power
supply current
μA
Deep
RAM ,USB
6
software retained*
standby
RAM, TM32K
mode
USB halted
power
supply TM32K
halted operation
VRAM
VccSTART ⎯
50°C < Ta
Rev. 2.00 Oct. 21, 2009 Page 1369 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Test
Symbol Min. Typ. Max. Unit Conditions
Item
5
Vcc rising gradient*
SVCC
⎯
⎯
20
ms/V
Notes: 1. When the A/D and D/A converters are not used, the AVCC, Vref, and AVSS pins should not
be open. Connect the AVCC and Vref pins to VCC, and the AVSS pin to VSS.
2. Supply current values are for VIH = Vcc and VIL = 0 V with all output pins unloaded and all
input pull-up MOS in the off state.
3. ICC depends on f as follows:
ICCmax = 30 (mA) + 1.1 (mA/MHz) × f (normal operation)
ICCmax = 35 (mA) + 0.5 (mA/MHz) × f (sleep mode)
4. The values are for reference.
5. This can be applied at power-on.
6. The value when TM 32K halted.
Table 30.3 Permissible Output Currents
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V*,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Symbol
Min.
Typ.
Max.
Unit
Permissible output low
current (per pin)
Output pins except
port 3
IOL
⎯
⎯
2.0
mA
Permissible output low
current (per pin)
Port 3
IOL
⎯
⎯
10
mA
Permissible output low
current (total)
Total of all output
pins
ΣIOL
⎯
⎯
80
mA
Permissible output high
current (per pin)
All output pins
–IOH
⎯
⎯
2.0
mA
Permissible output high
current (total)
Total of all output
pins
Σ–IOH
⎯
⎯
40
mA
Caution:
Note: *
To protect the LSI's reliability, do not exceed the output current values in table 30.3.
When the A/D and D/A converters are not used, the AVCC, Vref, and AVSS pins should not
be open. Connect the AVCC and Vref pins to VCC, and the AVSS pin to VSS.
Rev. 2.00 Oct. 21, 2009 Page 1370 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
30.3
DC Characteristics (H8SX/1665M Group)
Table 30.4 DC Characteristics
Conditions: VCC = PLLVCC = DrVCC = 2.95 V to 3.6 V, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V*1,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Schmitt
IRQ input pin,
trigger input TPU input pin,
voltage
TMR input pin,
port 2, port 3
port J, port K
Symbol
VT
–
VT
+
+
VT – VT
VT–
IRQ0-B to
IRQ7-B input pin
VT+
–
Min.
Typ.
Max.
Test
Unit Conditions
VCC × 0.2
⎯
⎯
V
⎯
⎯
VCC × 0.7
V
VCC × 0.06
⎯
⎯
V
AVCC × 0.2
⎯
⎯
V
⎯
⎯
AVCC × 0.7 V
⎯
⎯
V
V
+
–
VT – VT AVCC × 0.06
Input high
voltage
(except
Schmitt
trigger input
pin)
MD, RES, STBY, VIH
EMLE, NMI
VCC × 0.9
⎯
VCC + 0.3
EXTAL
VCC × 0.7
⎯
VCC + 0.3
Port 5
AVCC × 0.7
⎯
AVCC + 0.3
Input low
voltage
(except
Schmitt
trigger input
pin)
MD, RES, STBY, VIL
EMLE
–0.3
⎯
VCC × 0.1
EXTAL, NMI
–0.3
⎯
VCC × 0.2
Other input pins
–0.3
⎯
VCC × 0.2
VCC – 0.5
⎯
⎯
VCC – 1.0
⎯
⎯
⎯
⎯
0.4
⎯
⎯
1.0
Other input pins
Output high All output pins
voltage
VOH
Output low
voltage
All output pins
VOL
Input
leakage
current
RES
Port 3
⎯
⎯
10.0
MD, STBY,
EMLE, NMI
⎯
⎯
1.0
Port 5
⎯
⎯
1.0
|Iin|
V
V
IOH = –200 μA
IOH = –1 mA
V
IOL = 1.6 mA
IOL = 10 mA
μA
Vin = 0.5 to
VCC – 0.5 V
Vin = 0.5 to
AVCC – 0.5 V
Rev. 2.00 Oct. 21, 2009 Page 1371 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Test
Symbol Min. Typ. Max. Unit Conditions
Item
Three-state
Ports 1, 2, 3, 6,
leakage current A to F, H, I, J, K, M
(off state)
| ITSI|
⎯
⎯
1.0
μA
Vin = 0.5 to
VCC – 0.5 V
Input pull-up
MOS current
–Ip
10
⎯
300
μA
VCC = 3.0 to
3.6 V
Ports D to F, H, I
Vin = 0 V
Input
capacitance
Supply current
*2
⎯
⎯
15
pF
Vin = 0 V
f = 1 MHz
Ta = 25°C
⎯
50
85
mA
f = 50 MHz
Sleep mode
⎯
48
60
Subclock operation
⎯
5
10
32.768-kHz
crystal
resonator is
used.
Standby Software standby mode
mode
⎯
0.15
1.1
Ta ≤ 50°C
⎯
⎯
3.5
50°C < Ta
⎯
24
67
⎯
⎯
200
50°C < Ta
⎯
23
35
Ta ≤ 50°C
⎯
⎯
60
All input pins
Cin
Normal operation
ICC*
3
29
43
⎯
⎯
75
Hardware standby mode
⎯
2
7
Ta ≤ 50°C
⎯
⎯
25
50°C < Ta
⎯
23
30
mA
AICC
⎯
2.0
3.5
mA
⎯
0.5
1.5
μA
AICC
⎯
0.8
1.5
mA
⎯
0.5
1.5
μA
2.5
⎯
⎯
V
⎯
0.8
V
All-module-clock-stop mode*
Reference
power supply
current
During A/D and D/A conversion
Standby for A/D and D/A conversion
During A/D and D/A conversion
Standby for A/D and D/A conversion
RAM standby voltage
5
Vcc start voltage*
Rev. 2.00 Oct. 21, 2009 Page 1372 of 1454
REJ09B0498-0200
Ta ≤ 50°C
⎯
4
Analog power
supply current
μA
Deep
RAM ,USB
6
software retained*
standby
RAM, TM32K
mode
USB halted
power
supply TM32K
halted operation
VRAM
VccSTART ⎯
50°C < Ta
Section 30 Electrical Characteristics
Test
Symbol Min. Typ. Max. Unit Conditions
Item
5
Vcc rising gradient*
SVCC
⎯
⎯
20
ms/V
Notes: 1. When the A/D and D/A converters are not used, the AVCC, Vref, and AVSS pins should not
be open. Connect the AVCC and Vref pins to VCC, and the AVSS pin to VSS.
2. Supply current values are for VIH = Vcc and VIL = 0 V with all output pins unloaded and all
input pull-up MOS in the off state.
3. ICC depends on f as follows:
ICCmax = 30 (mA) + 1.1 (mA/MHz) × f (normal operation)
ICCmax = 35 (mA) + 0.5 (mA/MHz) × f (sleep mode)
4. The values are for reference.
5. This can be applied at power-on.
6. The value when TM 32K halted.
Table 30.5 Permissible Output Currents
Conditions: VCC = PLLVCC = DrVCC = 2.95 V to 3.6 V, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V*,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Symbol
Min.
Typ.
Max.
Unit
Permissible output low
current (per pin)
Output pins except
port 3
IOL
⎯
⎯
2.0
mA
Permissible output low
current (per pin)
Port 3
IOL
⎯
⎯
10
mA
Permissible output low
current (total)
Total of all output
pins
ΣIOL
⎯
⎯
80
mA
Permissible output high
current (per pin)
All output pins
–IOH
⎯
⎯
2.0
mA
Permissible output high
current (total)
Total of all output
pins
Σ–IOH
⎯
⎯
40
mA
Caution:
Note: *
To protect the LSI's reliability, do not exceed the output current values in table 30.5.
When the A/D and D/A converters are not used, the AVCC, Vref, and AVSS pins should not
be open. Connect the AVCC and Vref pins to VCC, and the AVSS pin to VSS
Rev. 2.00 Oct. 21, 2009 Page 1373 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
30.4
AC Characteristics
3V
RL
LSI output pin
C
C = 30 pF
RL = 2.4 kΩ
RH = 12 kΩ
Input/output timing measurement level:
1.5 V (Vcc = 3.0 V to 3.6 V*)
RH
Note: * Vcc = 2.95 V to 3.60 V in the H8SX/1665M Group.
Figure 30.1 Output Load Circuit
30.4.1
Clock Timing
Table 30.6 Clock Timing
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Iφ = 8 MHz to 50 MHz,
Bφ = 8 MHz to 50 MHz, Pφ = 8 MHz to 35 MHz,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Symbol
Min.
Max.
Unit.
Test Conditions
Clock cycle time
tcyc
20
125
ns
Figure 30.2
Clock high pulse width
tCH
5
⎯
ns
Clock low pulse width
tCL
5
⎯
ns
Clock rising time
tCr
⎯
5
ns
Clock falling time
tCf
⎯
5
ns
Oscillation settling time after reset
(crystal)
tOSC1
10
⎯
ms
Figure 30.4
Oscillation settling time after
leaving software standby mode
(crystal)
tOSC2
10
⎯
ms
Figure 30.3
Rev. 2.00 Oct. 21, 2009 Page 1374 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Item
Symbol
Min.
Max.
Unit.
Test Conditions
1
⎯
ms
Figure 30.4
tEXL
27.7
⎯
ns
Figure 30.5
External clock input high pulse width tEXH
27.7
⎯
ns
External clock rising time
tEXr
⎯
5
ns
External clock falling time
tEXf
⎯
5
ns
Subclock oscillation settling time
tOSC3
2
⎯
s
Subclock oscillator oscillation
frequency
fSUB
32.768
32.768
kHz
Subclock cycle time
tSUB
30.5
30.5
μs
External clock output delay settling tDEXT
time
External clock input low pulse width
Note:
*
VCC = PLLVCC = DrVCC = 2.95 V to 3.60 V in the H8SX/1665M Group.
tcyc
tCH
tCf
Bφ
tCL
tCr
Figure 30.2 External Bus Clock Timing
Rev. 2.00 Oct. 21, 2009 Page 1375 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Oscillator
Iφ
NMI
NMIEG
SSBY
NMI exception handling
NMI exception
handling
NMIEG = 1
SSBY = 1
Software standby mode
(power-down mode)
SLEEP
instruction
Oscillation
settling time
tOSC2
Figure 30.3 Oscillation Settling Timing after Software Standby Mode
EXTAL
tDEXT
tDEXT
VCC
STBY
tOSC1
tOSC1
RES
Iφ
Figure 30.4 Oscillation Settling Timing
Rev. 2.00 Oct. 21, 2009 Page 1376 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
tEXH
tEXL
EXTAL
Vcc × 0.5
tEXr
tEXf
Figure 30.5 External Input Clock Timing
Rev. 2.00 Oct. 21, 2009 Page 1377 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
30.4.2
Control Signal Timing
Table 30.7 Control Signal Timing
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Iφ = 8 MHz to 50 MHz,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Symbol
Min.
Max.
Unit
Test Conditions
RES setup time
tRESS
200
⎯
ns
Figure 30.6
RES pulse width
tRESW
20
⎯
tcyc
NMI setup time
tNMIS
150
⎯
ns
NMI hold time
tNMIH
10
⎯
ns
NMI pulse width (after leaving
software standby mode)
tNMIW
200
⎯
ns
IRQ setup time
tIRQS
150
⎯
ns
IRQ hold time
tIRQH
10
⎯
ns
IRQ pulse width (after leaving
software standby mode)
tIRQW
200
⎯
ns
Note:
*
VCC = PLLVCC = DrVCC = 2.95 V to 3.60 V in the H8SX/1665M Group.
Iφ
tRESS
tRESS
RES
tRESW
Figure 30.6 Reset Input Timing
Rev. 2.00 Oct. 21, 2009 Page 1378 of 1454
REJ09B0498-0200
Figure 30.7
Section 30 Electrical Characteristics
Iφ
tNMIS
tNMIH
NMI
tNMIW
tIRQW
IRQi*
(i = 0 to 11)
tIRQS
tIRQH
IRQ*
(edge input)
tIRQS
IRQ*
(level input)
Note: * SSIER must be set to cancel software standby mode.
Figure 30.7 Interrupt Input Timing
30.4.3
Bus Timing
Table 30.8 Bus Timing (1)
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to
AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Bφ = 8 MHz to 50 MHz,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Symbol
Min.
Max.
Unit
Address delay time
tAD
⎯
15
ns
Address setup time 1
tAS1
0.5 × tcyc – 8
⎯
ns
Address setup time 2
tAS2
1.0 × tcyc – 8
⎯
ns
Address setup time 3
tAS3
1.5 × tcyc – 8
⎯
ns
Address setup time 4
tAS4
2.0 × tcyc – 8
⎯
ns
Address hold time 1
tAH1
0.5 × tcyc – 8
⎯
ns
Address hold time 2
tAH2
1.0 × tcyc – 8
⎯
ns
Address hold time 3
tAH3
1.5 × tcyc – 8
⎯
ns
Test
Conditions
Figures 30.8 to
30.36
Rev. 2.00 Oct. 21, 2009 Page 1379 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Item
Symbol
Min.
Max.
Unit
CS delay time 1
tCSD1
⎯
15
ns
AS delay time
tASD
⎯
15
ns
RD delay time 1
tRSD1
⎯
15
ns
RD delay time 2
tRSD2
⎯
15
ns
Read data setup time 1
tRDS1
15
⎯
ns
Read data setup time 2
tRDS2
15
⎯
ns
Read data hold time 1
tRDH1
0
⎯
ns
Read data hold time 2
tRDH2
0
⎯
ns
Read data access time 2
tAC2
⎯
1.5 × tcyc – 20 ns
Read data access time 4
tAC4
⎯
2.5 × tcyc – 20 ns
Read data access time 5
tAC5
⎯
1.0 × tcyc – 20 ns
Read data access time 6
tAC6
⎯
2.0 × tcyc – 20 ns
Read data access time
(from address) 1
tAA1
⎯
1.0 × tcyc – 20 ns
Read data access time
(from address) 2
tAA2
⎯
1.5 × tcyc – 20 ns
Read data access time
(from address) 3
tAA3
⎯
2.0 × tcyc – 20 ns
Read data access time
(from address) 4
tAA4
⎯
2.5 × tcyc – 20 ns
Read data access time
(from address) 5
tAA5
⎯
3.0 × tcyc – 20 ns
Note:
*
VCC = PLLVCC = DrVCC = 2.95 V to 3.6 V in the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1380 of 1454
REJ09B0498-0200
Test
Conditions
Figures 30.8 to
30.36
Section 30 Electrical Characteristics
Table 30.8 Bus Timing (2)
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Bφ = 8 MHz to 50 MHz,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Symbol
Min.
Max.
Unit
WR delay time 1
tWRD1
⎯
15
ns
WR delay time 2
tWRD2
⎯
15
ns
WR pulse width 1
tWSW1
1.0 × tcyc – 13 ⎯
ns
WR pulse width 2
tWSW2
1.5 × tcyc – 13 ⎯
ns
Write data delay time
tWDD
⎯
20
ns
Write data setup time 1
tWDS1
0.5 × tcyc – 13 ⎯
ns
Write data setup time 2
tWDS2
1.0 × tcyc – 13 ⎯
ns
Write data setup time 3
tWDS3
1.5 × tcyc – 13 ⎯
ns
Write data hold time 1
tWDH1
0.5 × tcyc – 8
⎯
ns
Write data hold time 3
Byte control delay time
tWDH3
tUBD
1.5 × tcyc – 8
⎯
⎯
15
ns
ns
Byte control pulse width 1
Byte control pulse width 2
Multiplexed address delay time 1
tUBW1
tUBW2
tMAD1
⎯
⎯
⎯
1.0 × tcyc – 15 ns
2.0 × tcyc – 15 ns
15
ns
Multiplexed address hold time
tMAH
1.0 × tcyc – 15 ⎯
ns
Multiplexed address setup time 1
tMAS1
0.5 × tcyc – 15 ⎯
ns
Multiplexed address setup time 2
tMAS2
1.5 × tcyc – 15 ⎯
ns
Address hold delay time
tAHD
⎯
15
ns
Address hold pulse width 1
tAHW1
1.0 × tcyc – 15 ⎯
ns
Address hold pulse width 2
WAIT setup time
WAIT hold time
BREQ setup time
tAHW2
tWTS
tWTH
tBREQS
2.0 × tcyc – 15
15
5.0
20
⎯
⎯
⎯
⎯
ns
ns
ns
ns
BACK delay time
tBACD
⎯
15
ns
Bus floating time
BREQO delay time
BS delay time
tBZD
tBRQOD
tBSD
⎯
⎯
1.0
30
15
15
ns
ns
ns
RD/WR delay time
tRWD
⎯
15
ns
Note:
*
Test
Conditions
Figures 30.8 to
30.36
Figures 30.13,
30.14
Figure 30.13
Figure 30.14
Figures 30.17,
30.18
Figures 30.10,
30.18
Figure 30.35
Figure 30.36
Figures 30.8,
30.9, 30.11 to
30.14
VCC = PLLVCC = DrVCC = 2.95 V to 3.6 V in the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1381 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Table 30.8 Bus Timing (3)
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Bφ = 8 MHz to 50 MHz,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Symbol
Min.
Max.
CS delay time 2
CS delay time 3
Read data access time 1
tCSD3
tCSD4
⎯
⎯
15
15
tAC1
⎯
ns
ns
1.0 × tcyc – 20 ns
Read data access time 3
tAC3
⎯
2.0 × tcyc – 20 ns
Read data access time 7
tAC7
⎯
4.0 × tcyc – 20 ns
Read data access time 8
tAC8
⎯
3.0 × tcyc – 20 ns
Write data hold time 2
tWDH2
1.0 × tcyc – 8
⎯
ns
Read command setup time 1
tRCS1
1.5 × tcyc – 10 ⎯
ns
Read command setup time 2
tRCS2
2.0 × tcyc – 10 ⎯
ns
Read command hold time
tRCH
0.5 × tcyc – 10 ⎯
ns
Write command setup time 1
tWCS1
0.5 × tcyc – 10 ⎯
ns
tWCS2
1.0 × tcyc – 10 ⎯
ns
Write command hold time 1
tWCH1
0.5 × tcyc – 10 ⎯
ns
Write command hold time 2
tWCH2
1.0 × tcyc – 10 ⎯
ns
CAS delay time 1
tCASD1
⎯
15
ns
CAS delay time 2
tCASD2
⎯
15
ns
CAS setup time 1
tCSR1
0.5 × tcyc – 10 ⎯
ns
CAS setup time 2
tCSR2
1.5 × tcyc – 10 ⎯
ns
CAS pulse width 1
tCASW1
1.0 × tcyc – 15 ⎯
ns
CAS pulse width 2
tCASW2
1.5 × tcyc – 15 ⎯
ns
CAS precharge time 1
tCPW1
1.0 × tcyc – 15 ⎯
ns
CAS precharge time 2
tCPW2
1.5 × tcyc – 15 ⎯
ns
OE delay time 1
tOED1
⎯
15
ns
OE delay time 2
tOED2
⎯
15
ns
Precharge time 1
tPCH1
1.0 × tcyc – 20 ⎯
ns
Precharge time 2
tPCH2
1.5 × tcyc – 20 ⎯
ns
Write command setup time 2
Rev. 2.00 Oct. 21, 2009 Page 1382 of 1454
REJ09B0498-0200
Unit
Test
Conditions
Figures 30.19
to 30.28
Section 30 Electrical Characteristics
Unit
Test
Conditions
2.5 × tcyc – 20 ⎯
ns
Figure 30.28
tRPS2
3.0 × tcyc – 20 ⎯
ns
Figure 30.27
Address delay time 2
tAD2
1
15
ns
CS delay time 4
tCSD4
1
15
ns
Figures 30.29
to 30.34
DQM delay time
tDQMD
1
15
ns
CKE delay time
tCKED
1
15
ns
Item
Symbol
Min.
Precharge time 1 for self-refresh
tRPS1
Precharge time 2 for self refresh
Note:
*
Max.
VCC = PLLVCC = DrVCC = 2.95 V to 3.6 V in the H8SX/1665M Group.
Table 30.8 Bus Timing (4)
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Bφ = 8 MHz to 50 MHz,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Symbol
Min.
Max.
Unit
Read data setup time 3
tRDS3
12
⎯
ns
Read data hold time 3
tRDH3
0
⎯
ns
Read data setup time 4
tRDS4
12
⎯
ns
Read data hold time 4
tRDH4
0
⎯
ns
Write data delay time 2
tWDD2
⎯
15
ns
Write data hold time 4
tWDH4
1
⎯
ns
Note:
*
Test
Conditions
Figures 30.29
to 30.34
VCC = PLLVCC = DrVCC = 2.95 V to 3.6 V in the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1383 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
T1
T2
Bφ
tAD
A23 to A0
tCSD1
CS7 to CS0
tAS1
tASD
tASD
AS
tBSD
tBSD
BS
RD/WR
Read
(RDNn = 1)
tAH1
tRWD
tRWD
tAS1
tRSD1
tRSD1
RD
tAC5
tRDS1 tRDH1
tAA2
D15 to D0
RD/WR
tRWD
tAS1
tRWD
tRSD1
tRSD2
RD
Read
(RDNn = 0)
tAC2
tAA3
D15 to D0
tRDS2 tRDH2
tRWD
tRWD
RD/WR
tAS1
Write
tWRD2 tWRD2
tAH1
LHWR, LLWR
tWDD
D15 to D0
(write)
(DKC = 0) DACK0 to DACK3
tWSW1
tDACD1
tDACD2
tWDH1
tDACD2
tDACD2
(DKC = 1) DACK0 to DACK3
Figure 30.8 Basic Bus Timing: Two-State Access
Rev. 2.00 Oct. 21, 2009 Page 1384 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
T1
Bφ
T2
T3
tAD
A23 to A0
tCSD1
CS7 to CS0
tAS1
tASD
AS
tASD
tAH1
tBSD
tBSD
BS
tRWD
tRWD
RD/WR
tAS1
Read
(RDNn = 1)
tRSD1
tRSD1
RD
tRDS1 tRDH1
tAC6
tAA4
D15 to D0
tRWD
tRWD
RD/WR
tAS1
Read
(RDNn = 0)
tRSD1
tRSD2
RD
tRDS2
tAC4
tRDH2
tAA5
D15 to D0
tRWD
tRWD
RD/WR
tAS2
Write
LHWR, LLWR
(DKC = 0) DACK0 to DACK3
tWRD2
tAH1
tWDS1
tWDD
D15 to D0
(write)
tWRD1
tWSW2
tWDH1
tDACD1
tDACD2
tDACD2
tDACD2
(DKC = 1) DACK0 to DACK3
Figure 30.9 Basic Bus Timing: Three-State Access
Rev. 2.00 Oct. 21, 2009 Page 1385 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
T1
T2
Tw
T3
Bφ
A23 to A0
CS7 to CS0
AS
BS
RD/WR
Read
(RDNn = 1)
RD
D15 to D0
RD/WR
Read
(RDNn = 0)
RD
D15 to D0
RD/WR
LHWR, LLWR
Write
D15 to D0
tWTS tWTH
tWTS tWTH
WAIT
Figure 30.10 Basic Bus Timing: Three-State Access, One Wait
Rev. 2.00 Oct. 21, 2009 Page 1386 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Th
T1
T2
Tt
Bφ
tAD
A23 to A0
tCSD1
CS7 to CS0
tAS1
tASD
tAH1
tASD
AS
tBSD
tBSD
BS
tRWD
tRWD
RD/WR
tAS3
Read
(RDNn = 1)
tAH3
tRSD1 tRSD1
RD
tAC5
tRDS1 tRDH1
D15 to D0
tRWD
tRWD
RD/WR
tAS3
Read
(RDNn = 0)
tRSD1
tAH2
tRSD2
RD
tAC2
tRDS2 tRDH2
D15 to D0
tRWD
tRWD
RD/WR
tAS3
Write
tWRD2 tWRD2
tAH3
LHWR, LLWR
tWDD
tWDS2
tWSW1
tWDH3
D15 to D0
(write)
tDACD1
tDACD2
(DKC = 0) DACK0 to DACK3
tDACD2
tDACD2
(DKC = 1) DACK0 to DACK3
Figure 30.11 Basic Bus Timing: Two-State Access (CS Assertion Period Extended)
Rev. 2.00 Oct. 21, 2009 Page 1387 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Th
T1
T2
T3
Tt
Bφ
tAD
A23 to A0
tCSD1
CS7 to CS0
tAS1
tASD
tAH1
tASD
AS
tBSD
tBSD
BS
tRWD
tRWD
RD/WR
tAS3
Read
(RDNn = 1)
tRSD1
tAH3
tRSD1
RD
tRDS1 tRDH1
tAC6
D15 to D0
tRWD
tRWD
RD/WR
tAS3
Read
(RDNn = 0)
tRSD1
tAH2
tRSD2
RD
tRDS2 tRDH2
tAC4
D15 to D0
tRWD
tRWD
RD/WR
tAS4
Write
tWRD2
LHWR, LLWR
tAH3
tWRD1
tWDS3
tWDD
tWSW2
tWDH3
D15 to D0
(write)
tDACD1
tDACD2
(DKC = 0) DACK0 to DACK3
tDACD2
tDACD2
(DKC = 1) DACK0 to DACK3
Figure 30.12 Basic Bus Timing: Three-State Access (CS Assertion Period Extended)
Rev. 2.00 Oct. 21, 2009 Page 1388 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
T1
T2
Bφ
tAD
A23 to A0
tCSD1
CS7 to CS0
tAS1
tASD
tASD
AS
tBSD
tAH1
tBSD
BS
tRWD
tRWD
RD/WR
tAS1
Read
tRSD1
tRSD1
RD
tAC5
tRDS1 tRDH1
tAA2
D15 to D0
tAC5
tUBD
tUBD
LUB, LLB
tAS1
tUBW1
tAH1
tRWD
tRWD
RD/WR
Write
RD
High
tWDD
tWDH1
D15 to D0
(write)
Figure 30.13 Byte Control SRAM: Two-State Read/Write Access
Rev. 2.00 Oct. 21, 2009 Page 1389 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
T1
T2
T3
Bφ
tAD
A23 to A0
tCSD1
CS7 to CS0
tAS1
tASD
tASD
tAH1
AS
tBSD
tBSD
BS
tRWD
tRWD
RD/WR
tAS1
tRSD1
tRSD1
Read
RD
tAC6
tRDS1 tRDH1
tAA4
D15 to D0
tAC6
tUBD
LUB, LLB
tUBD
tAS1
tAH1
tUBW2
tRWD
tRWD
RD/WR
Write
RD
High
tWDD
tWDH1
D15 to D0
(write)
Figure 30.14 Byte Control SRAM: Three-State Read/Write Access
Rev. 2.00 Oct. 21, 2009 Page 1390 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
T1
T2
T1
T1
Bφ
A23 to A6, A0
tAD
A5 to A1
CS7 to CS0
AS
BS
RD/WR
tRSD2
Read
RD
tAA1 tRDS2 tRDH2
D15 to D0
LHWR, LLWR
High
Figure 30.15 Burst ROM Access Timing: One-State Burst Access
Rev. 2.00 Oct. 21, 2009 Page 1391 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
T1
T2
T3
T1
T2
Bφ
A23 to A6, A0
tAD
A5 to A1
CS7 to CS0
tAH1
tAS1
tASD
AS
tASD
BS
RD/WR
tRSD2
Read
RD
tAA3
D15 to D0
LHWR, LLWR
High
Figure 30.16 Burst ROM Access Timing: Two-State Burst Access
Rev. 2.00 Oct. 21, 2009 Page 1392 of 1454
REJ09B0498-0200
tRDS2 tRDH2
Section 30 Electrical Characteristics
Tma1
Tma2
T1
T2
Bφ
tAD
A23 to A0
CS7 to CS0
tAHD
tAHD
AH (AS)
tAHW1
RD/WR
Read
RD
tMAD1
tMAS1
tMAH
tRDS2
tRDH2
D15 to D0
RD/WR
tWSW1
Write
LHWR, LLWR
tMAS1
tMAD1
tMAH
tWDD
tWDH1
D15 to D0
BS
DKC = 0
DACK3 to DACK0
DKC = 1
Figure 30.17 Address/Data Multiplexed Access Timing (No Wait)
(Basic, Four-State Access)
Rev. 2.00 Oct. 21, 2009 Page 1393 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tma1
Tmaw
Tma2
T2
T1
Tpw
Ttw
T3
Bφ
tAD
A23 to A0
CS7 to CS0
tAHD
tAHD
AH (AS)
tAHW2
RD/WR
Read
RD
tMAS2
tMAH
tMAD1
tRDS2
tRDH2
D15 to D0
RD/WR
Write
LHWR, LLWR
tMAS2
tMAD1
tMAH
tWDH1
tWDS1
D15 to D0
tWDD
tWTS tWTH tWTS tWTH
WAIT
Figure 30.18 Address/Data Multiplexed Access Timing (Wait Control)
(Address Cycle Program Wait × 1 + Data Cycle Program Wait × 1 +
Data Cycle Pin Wait × 1)
Rev. 2.00 Oct. 21, 2009 Page 1394 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tc1
Tc2
Bφ
tAD
tAD
A23 to A0
tAS3
RAS
tCSD3
tAH1
tCSD2
tPCH2
tCASW1
LUCAS, LLCAS
tAC1
tBSD
tBSD
BS
tRWD
tRWD
RD/WR
tOED1
tOED1
OE, RD
Read
WE
tAA3
tRDS2 tRDH2
tAC4
D15 to D0
tRWD
tRWD
RD/WR
OE, RD
tWRD2
Write
tWCS1 tWCH1
tWRD2
WE
tWDD
tWDS1
tWDH2
D15 to D0
AS
tDACD1
tDACD2
(DKC = 0) DACK3 to DACK0
tDACD2
tDACD2
(DKC = 1) DACK3 to DACK0
Note:
Timming of DACK when DDS = 0 and EDDS = 0
Timming of RAS when RAST = 0
Figure 30.19 DRAM Access Timing: Two-State Access
Rev. 2.00 Oct. 21, 2009 Page 1395 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tc1
Tpw
Ttw
Tc2
Bφ
A23 to A0
RAS
BS
RD/WR
LUCAS, LLCAS
Read
OE, RD
WE
D15 to D0
RD/WR
LUCAS, LLCAS
Write
OE, RD
WE
D15 to D0
AS
tWTS
tWTH
tWTS tWTH
WAIT
(DKC = 0) DACK3 to DACK0
(DKC = 1) DACK3 to DACK0
Note:
Timming of DACK when DDS = 0 and EDDS = 0
Timming of RAS when RAST = 0
Tcw is a wait cycle inserted by the programmable wait
Tcwp is a wait cycle inserted by the pin wait
Figure 30.20 DRAM Access Timing: Two-State Access, One Wait
Rev. 2.00 Oct. 21, 2009 Page 1396 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tc1
Tc2
Tc1
Tc2
Bφ
A23 to A0
RAS
tCPW1
LUCAS, LLCAS
BS
RD/WR
OE, RD
Read
WE
tAC3
D15 to D0
RD/WR
OE, RD
Write
tRCH
WE
tRCS1
D15 to D0
AS
tDACD1
tDACD2
(DKC = 0) DACK3 to DACK0
tDACD2
(DKC = 1) DACK3 to DACK0
Note:
Timming of DACK when DDS = 0 and EDDS = 0
Timming of RAS when RAST = 0
Figure 30.21 DRAM Access Timing: Two-State Burst Access
Rev. 2.00 Oct. 21, 2009 Page 1397 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tc1
Tc2
Tc3
Bφ
tAD
tAD
A23 to A0
tAS2
tCSD3
tAH2
tCSD2
RAS
tPCH1
tCASW2
LUCAS, LLCAS
tBSD
tAC2
tBSD
BS
tRWD
tRWD
RD/WR
tOED2
Read
tOED1
OE, RD
WE
tAA5
tRDS2 tRDH2
tAC7
D15 to D0
tRWD
tRWD
RD/WR
OE, RD
tWRD2
Write
tWCS2
tWCH2
tWRD2
WE
tWDD
tWDS2
tWDH3
D15 to D0
AS
tDACD2
tDACD1
(DKC = 0) DACK3 to DACK0
tDACD2
tDACD2
(DKC = 1) DACK3 to DACK0
Note:
Timming of DACK when DDS = 0 and EDDS = 0
Timming of RAS when RAST = 1
Figure 30.22 DRAM Access Timing: Three-State Access (RAST = 1)
Rev. 2.00 Oct. 21, 2009 Page 1398 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tc1
Tpw
Ttw
Tc2
Tc3
Bφ
A23 to A0
RAS
BS
RD/WR
LUCAS, LLCAS
Read
OE, RD
WE
D15 to D0
RD/WR
LUCAS, LLCAS
Write
OE, RD
WE
D15 to D0
tWTS
tWTH
tWTS tWTH
WAIT
(DKC = 0) DACK3 to DACK0
(DKC = 1) DACK3 to DACK0
Note:
Timming of DACK when DDS = 0 and EDDS = 0
Timming of RAS when RAST = 0
Tcw is a wait cycle inserted by the programmable wait
Tcwp is a wait cycle inserted by the pin wait
Figure 30.23 DRAM Access Timing: Three-State Access, One Wait
Rev. 2.00 Oct. 21, 2009 Page 1399 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tc1
Tc2
Tc3
Tc1
Tc2
Bφ
A23 to A0
RAS
tCPW2
LUCAS, LLCAS
BS
RD/WR
OE, RD
Read
WE
tAC8
D15 to D0
RD/WR
OE, RD
tRCH
Write
WE
tRCS2
D15 to D0
AS
(DKC = 0) DACK3 to DACK0
(DKC = 1) DACK3 to DACK0
Note:
Timming of DACK when DDS = 1 and EDDS = 1
Timming of RAS when RAST = 1
Figure 30.24 DRAM Access Timing: Three-State Burst Access
Rev. 2.00 Oct. 21, 2009 Page 1400 of 1454
REJ09B0498-0200
Tc3
Section 30 Electrical Characteristics
TRp
TRc1
TRr
TRc2
Bφ
tCSD1
tCSD2
RAS
tCSR1
tCASD1
tCASD1
LUCAS, LLCAS
OE
Figure 30.25 CAS Before RAS Refresh Timing
TRp
TRrw
TRr
TRc1
TRcw
TRc2
Bφ
tCSD1
tCSD2
RAS
tCSR2
tCASD1
tCASD1
LUCAS, LLCAS
OE
Figure 30.26 CAS Before RAS Refresh Timing (Wait Cycle Inserted)
Self refresh
TRp
TRr
TRc3
DRAM access
TRc4
Tp
Tr
Bφ
tCSD2
tCSD2
RAS
tRPS2
tCASD1
tCASD1
LUCAS, LLCAS
OE
Figure 30.27 Self-Refresh Timing (After Leaving Software Standby: RAST = 0)
Rev. 2.00 Oct. 21, 2009 Page 1401 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
TRp
TRr
TRc3
Self-refresh
TRc4
DRAM access
Tp
Tr
Bφ
tCSD2
tCSD2
RAS
tCASD1
tCASD1
tRPS1
LUCAS, LLCAS
OE
Figure 30.28 Self-Refresh Timing (After Leaving Software Standby: RAST = 1)
Rev. 2.00 Oct. 21, 2009 Page 1402 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tc1
Tcl
Tc2
SDRAMφ
tAD2
Address bus
Precharge-sel
tCSD4
CS
tBSD
tBSD
BS
tCSD4
tCSD4
RAS
tCSD4
tCSD4
CAS
Read
tCSD4
tCSD4
WE
CKE
tDQMD
tDQMD
DQMLU, DQMLL
tRDS3
tRDH3
Data bus
PALL
ACTV
READ
NOP
NOP
Figure 30.29 Synchronous DRAM Basic Read Access Timing (CAS Latency 2)
Rev. 2.00 Oct. 21, 2009 Page 1403 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tc1
Tc2
SDRAMφ
tAD2
Address bus
Precharge-sel
tCSD4
CS
tBSD
tBSD
BS
tCSD4
tCSD4
RAS
tCSD4
tCSD4
tCSD4
tCSD4
CAS
tCSD4
tCSD4
WE
Wirte
CKE
tDQMD
tDQMD
DQMLU, DQMLL
tWDD
tWDH4
Data bus
PALL
ACTV
NOP
WRIT
Figure 30.30 Synchronous DRAM Basic Write Access Timing (CAS Latency 2)
Rev. 2.00 Oct. 21, 2009 Page 1404 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tc1
Tcl
Tsp
Tc2
SDRAMφ
Address bus
Precharge-sel
BS
RAS
CAS
WE
tCKED
tCKED
CKE
DQMLU, DQMLL
Data bus
DACK
DKC = 0
DKC = 1
Figure 30.31 Extended Read Data Cycle (CAS Latency 2)
Rev. 2.00 Oct. 21, 2009 Page 1405 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tcb
Tcb
Tcb
Tc1
Tcl
Tc2
SDRAMφ
Address bus
Low
Precharge-sel
Column 1
Column 2
Column 3
Column 4
Low
CS
RAS
CAS
WE
CKE
DQMLU, DQMLL
tRDH4
tRDS4
Data bus
BS
RD/WR
PALL
ACTV
READ
NOP
NOP
Figure 30.32 Synchronous DRAM Cluster Transfer Access Timing (Read)
Rev. 2.00 Oct. 21, 2009 Page 1406 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Tp
Tr
Tc1
Tc2
Tcb
Tcb
Tcb
Column 2
Column 3
Column 4
SDRAMφ
Address bus
Low
Precharge-sel
Column 1
Low
CS
RAS
CAS
WE
CKE
DQMLU, DQMLL
tWDD
tWDD2
tWDH4
Data bus
BS
RD/WR
PALL
ACTV
NOP
WRIT
Figure 30.33 Synchronous DRAM Cluster Transfer Access Timing (Write)
Rev. 2.00 Oct. 21, 2009 Page 1407 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
TRp
TRr
Software
standby
TRc2
TRc3
SDRAMφ
Address bus
Precharge-sel
CS
RAS
CAS
WE
tCKED
CKE
Figure 30.34 Synchronous DRAM Self-Refresh Timing
Rev. 2.00 Oct. 21, 2009 Page 1408 of 1454
REJ09B0498-0200
tCKED
Section 30 Electrical Characteristics
Bφ
tBREQS
tBREQS
BREQ
tBACD
tBACD
BACK
tBZD
tBZD
A23 to A0
CS7 to CS0
D15 to D0
AS, RD,
LHWR, LLWR
Figure 30.35 External Bus Release Timing
Rev. 2.00 Oct. 21, 2009 Page 1409 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Bφ
BACK
tBRQOD
tBRQOD
BREQO
Figure 30.36 External Bus Request Output Timing
30.4.4
DMAC and EXDMAC Timing
Table 30.9 DMAC and EXDMAC Timing
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Bφ = 8 MHz to 50 MHz,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Symbol
Min.
Max.
Unit
Test Conditions
DREQ setup time
tDRQS
20
⎯
ns
Figure 30.37
DREQ hold time
tDRQH
5
⎯
ns
TEND delay time
tTED
⎯
15
ns
Figure 30.38
DACK delay time 1
tDACD1
⎯
15
ns
Figure 30.39
DACK delay time 2
tDACD2
⎯
15
ns
Figure 30.40
EDREQ setup time
tDRQS
20
⎯
ns
Figure 30.37
EDREQ hold time
tDRQH
5
⎯
ns
ETEND delay time
tTED
⎯
15
ns
Figure 30.38
EDACK delay time 1
tDACD1
⎯
15
ns
Figure 30.39
EDACK delay time 2
tDACD2
⎯
15
ns
Figure 30.40
EDRAK delay time
tEDRKD
⎯
15
ns
Figure 30.41
Note:
*
VCC = PLLVCC = DrVCC = 2.95 V to 3.60 V in the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1410 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Bφ
tDRQS
tDRQH
DREQ0 to DREQ3
tEDRQS tEDRQH
EDREQ0 to EDREQ3
Figure 30.37 DMAC/EXDMAC, DREQ and EDREQ Input Timing
T1
T2
T3
Bφ
tTED
tTED
tETED
tETED
TEND0 to TEND3
ETEND0 to ETEND3
Figure 30.38 DMAC/EXDMAC, TEND and ETEND Output Timing
Rev. 2.00 Oct. 21, 2009 Page 1411 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
T1
T2
Bφ
A23 to A0
CS7 to CS0
AS
RD
(Read)
D15 to D0
(Read)
LHWR, LLWR
(Write)
D15 to D0
(Write)
tDACD1
tDACD2
(DKC = 0) DACK0 to DACK3
tDACD2
tDACD2
(DKC = 1) DACK0 to DACK3
tEDACD1
tEDACD2
(EDKC = 0) EDACK0 to EDACK3
tEDACD2
tEDACD2
(EDKC = 1) EDACK0 to EDACK3
BS
RD/WR
Figure 30.39 DMAC/EXDMAC Single Address Transfer Timing (2-state access)
Rev. 2.00 Oct. 21, 2009 Page 1412 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
T1
T2
T3
Bφ
A23 to A0
CS7 to CS0
AS
RD
(Read)
D15 to D0
(Read)
LHWR, LLWR
(Write)
D15 to D0
(Write)
tDACD1
tDACD2
(DKC = 0) DACK0 to DACK3
tDACD2
tDACD2
(DKC = 1) DACK0 to DACK3
tEDACD1
tEDACD2
(EDKC = 0) EDACK0 to EDACK3
tEDACD2
tEDACD2
(EDKC = 1) EDACK0 to EDACK3
BS
RD/WR
Figure 30.40 DMAC/EXDMAC Single Address Transfer Timing (3-state access)
Rev. 2.00 Oct. 21, 2009 Page 1413 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Bφ
tEDRKD
tEDRKD
EDRAK0 to EDRAK3
Figure 30.41 EXDMAC, EDRAK Timing
30.4.5
Timing of On-Chip Peripheral Modules
Table 30.10 Timing of On-Chip Peripheral Modules
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*2, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Pφ = 8 MHz to 35 MHz,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Symbol
Min.
Max.
Unit
Test Conditions
tPWD
⎯
40
ns
Figure 30.42
Input data setup time
tPRS
25
⎯
ns
Input data hold time
tPRH
25
⎯
ns
Timer output delay time
tTOCD
⎯
40
ns
Timer input setup time
tTICS
25
⎯
ns
Timer clock input setup time
tTCKS
25
⎯
ns
Single-edge
setting
tTCKWH
1.5
⎯
tcyc
Both-edge
setting
tTCKWL
2.5
⎯
tcyc
tPOD
⎯
40
ns
I/O ports Output data delay time
TPU
Timer clock
pulse width
PPG
Pulse output delay time
Rev. 2.00 Oct. 21, 2009 Page 1414 of 1454
REJ09B0498-0200
Figure 30.43
Figure 30.44
Figure 30.45
Section 30 Electrical Characteristics
Item
8-bit
timer
Symbol
Min.
Max.
Unit
Test Conditions
Timer output delay time
tTMOD
⎯
40
ns
Figure 30.46
Timer reset input setup time
tTMRS
25
⎯
ns
Figure 30.47
Timer clock input setup time
tTMCS
25
⎯
ns
Figure 30.48
Timer clock
pulse width
Single-edge
setting
tTMCWH
1.5
⎯
tcyc
Both-edge
setting
tTMCWL
2.5
⎯
tcyc
WDT
Overflow output delay time
tWOVD
⎯
40
ns
Figure 30.49
SCI
Input clock
cycle
tScyc
4
⎯
tcyc
Figure 30.50
6
⎯
Asynchronous
Clocked
synchronous
Input clock pulse width
tSCKW
0.4
0.6
tScyc
Input clock rise time
tSCKr
⎯
1.5
tcyc
Input clock fall time
tSCKf
⎯
1.5
tcyc
Transmit data delay time
tTXD
⎯
40
ns
Receive data setup time
(clocked synchronous)
tRXS
40
⎯
ns
Receive data hold time
(clocked synchronous)
tRXH
40
⎯
ns
A/D
Trigger input setup time
converter
tTRGS
30
⎯
ns
Figure 30.52
IIC2
SCL input cycle time
tSCL
12 tcyc +
600
⎯
ns
Figure 30.53
SCL input high pulse width
tSCLH
3 tcyc +
300
⎯
ns
SCL input low pulse width
tSCLL
5 tcyc +
300
⎯
ns
SCL, SDA input falling time
tSf
⎯
300
ns
SCL, SDA input spike pulse
removal time
tSP
⎯
1 tcyc
ns
SDA input bus free time
tBUF
5 tcyc
⎯
ns
Start condition input hold time tSTAH
3 tcyc
⎯
ns
Retransmit start condition
input setup time
3 tcyc
⎯
ns
tSTAS
Figure 30.51
Rev. 2.00 Oct. 21, 2009 Page 1415 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Item
IIC2
Symbol
Min.
Stop condition input setup
time
tSTOS
Data input setup time
tSDAS
Data input hold time
SCL, SDA capacitive load
Max.
Unit
Test Conditions
1 tcyc + 20 ⎯
ns
Figure 30.53
0
⎯
ns
tSDAH
0
⎯
ns
Cb
⎯
400
pF
tSf
⎯
300
ns
tTCKcyc
50*1
⎯
ns
tTCKH
20
⎯
ns
tTCKL
20
⎯
ns
TCK clock rising time
tTCKr
⎯
5
ns
TCK clock falling time
tTCKf
⎯
5
ns
TRST pulse width
tTRSTW
20
⎯
Tcyc
Figure 30.55
TMS setup time
tTMSS
20
⎯
ns
Figure 30.56
TMS hold time
tTMSH
20
⎯
ns
TDI setup time
tTDIS
20
⎯
ns
TDI hold time
tTDIH
20
⎯
ns
TDI data delay time
tTDOD
⎯
23
ns
SCL, SDA falling time
Boundary TCK clock cycle time
scan
TCK clock high level pulse
width
TCK clock low level pulse
width
Notes: 1. tTCKcyc ≥ tTCKcyc
2. VCC = PLLVCC = DrVCC = 2.95 V to 3.60 V in the H8SX/1665M Group.
T1
T2
Pφ
tPRS tPRH
Ports 1 to 3, 5, 6,
A, to F, H, I, M, J, K (read)
tPWD
Ports 1 to 3, 6,
A to F, H, I,M, J, K (write)
Figure 30.42 I/O Port Input/Output Timing
Rev. 2.00 Oct. 21, 2009 Page 1416 of 1454
REJ09B0498-0200
Figure 30.54
Section 30 Electrical Characteristics
Pφ
tTOCD
Output compare
output*1
tTICS
Input capture
input*2
Notes: 1.
2.
TIOCA0 to TIOCA11, TIOCB0 to TIOCB11, TIOCC0, TIOCC3, TIOCC6, TIOCC9,
TIOCD0, TIOCD3, TIOCD6, TIOCD9
TIOCA0 to TIOCA5, TIOCB0 to TIOCB5, TIOCC0, TIOCC3, TIOCD0, TIOCD3
Figure 30.43 TPU Input/Output Timing
Pφ
tTCKS
tTCKS
TCLKA to TCLKD
tTCKWH
tTCKWL
Figure 30.44 TPU Clock Input Timing
Pφ
tPOD
PO31 to PO0
Figure 30.45 PPG Output Timing
Pφ
tTMOD
TMO0 to TMO3
Figure 30.46 8-Bit Timer Output Timing
Rev. 2.00 Oct. 21, 2009 Page 1417 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Pφ
tTMRS
TMRI0 to TMRI3
Figure 30.47 8-Bit Timer Reset Input Timing
Pφ
tTMCS
tTMCS
TMCI0 to TMCI3
tTMCWL
tTMCWH
Figure 30.48 8-Bit Timer Clock Input Timing
Pφ
tWOVD
tWOVD
WDTOVF
Figure 30.49 WDT Output Timing
tSCKW
tSCKr
tSCKf
SCK0 to SCK2, SCK4
tScyc
Figure 30.50 SCK Clock Input Timing
SCK0 to SCK2,
SCK4
TxD0 to TxD2,
TxD4
(transmit data)
tTXD
tRXS tRXH
RxD0 to RxD2,
RxD4
(receive data)
Figure 30.51 SCI Input/Output Timing: Clocked Synchronous Mode
Rev. 2.00 Oct. 21, 2009 Page 1418 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Pφ
tTRGS
ADRTG0,
ADTRG1
Figure 30.52 A/D Converter External Trigger Input Timing
VIH
SDA0
to
SDA1
VIL
tBUF
tSTAH
tSCLH
tSTAS
tSP
tSTOS
SCL0
to
SCL1
P*
S*
tSf
Sr*
tSCLL
tSr
tSCL
Note:
P*
tSDAS
tSDAH
S, P, and Sr represent the following conditions:
S: Start condition
P: Stop condition
Sr: Retransmit start condition
Figure 30.53 I2C Bus Interface2 Input/Output Timing (Option)
tTCKcyc
tTCKH
TCK
tTCKf
tTCKL
tTCKr
Figure 30.54 Boundary Scan TCK Timing
Rev. 2.00 Oct. 21, 2009 Page 1419 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
TCK
RES
TRST
tTRSTW
Figure 30.55 Boundary Scan TRST Timing
TCK
tTMSS tTMSH
TMS
tTDIS tTDIH
TDI
tTDOD
TDO
Figure 30.56 Boundary Scan Input/Output Timing
Rev. 2.00 Oct. 21, 2009 Page 1420 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
30.5
USB Characteristics
Table 30.11 USB Characteristics when On-Chip USB Transceiver is Used
(USD+, USD− pin characteristics)
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, VSS = PLLVSS = DrVSS = AVSS = 0 V,
CKU = 48 MHz, Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Input
Output
Note:
*
Symbol Min.
Max.
Unit
Test Conditions
Input high voltage
VIH
2.0
⎯
V
Input low voltage
VIL
⎯
0.8
V
Differential input
sensitivity
VDI
0.2
⎯
V
Differential common
mode range
VCM
0.8
2.5
V
Output high voltage
VOH
2.8
⎯
V
IOH = −200 μA
Output low voltage
VOL
⎯
0.3
V
IOL = 2 mA
Crossover voltage
VCRS
1.3
2.0
V
Rising time
tR
4
20
ns
Falling time
tF
4
20
ns
Ratio of rising time to
falling time
tRFM
90
111.11
%
(TR/TF)
Output resistance
ZDRV
28
44
Ω
Including
RS = 22Ω
Figure 30.57
Figure 30.58
⏐(D+) − (D−)⏐
VCC = PLLVCC = DrVCC = 2.95 V to 3.60 V in the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1421 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Rise time
USD+, USD-
Fall time
90%
VCRS
90%
10%
10%
tF
tR
Differential
data lines
Figure 30.57 Data Signal Timing
USD+
RS = 22 Ω
Test point
CL = 50 pF
USD-
RS = 22 Ω
Test point
CL = 50 pF
Figure 30.58 Load Condition
Rev. 2.00 Oct. 21, 2009 Page 1422 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
30.6
A/D Conversion Characteristics
Table 30.12 A/D Conversion Characteristics in Peripheral Clock Mode (ICKSEL = 0)
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Pφ = 8 MHz to 35 MHz,
When all units operate in ICKSEL = 0,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Min.
Typ.
Max.
Unit
Resolution
10
10
10
Bit
Conversion time
2.7
⎯
⎯
μs
Analog input capacitance
⎯
⎯
20
pF
Permissible signal
source impedance
EXCKS = 0
⎯
⎯
5
kΩ
EXCKS = 1
⎯
⎯
1
kΩ
Nonlinearity error
⎯
⎯
±3.5
LSB
Offset error
⎯
⎯
±3.5
LSB
Full-scale error
⎯
⎯
±3.5
LSB
Quantization error
⎯
±0.5
⎯
LSB
Absolute accuracy
⎯
⎯
±4.0
LSB
Note:
*
VCC = PLLVCC = DrVCC = 2.95 V to 3.60 V in the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1423 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
Table 30.13 A/D Conversion Characteristics in System Clock Mode (ICKSEL = 1)
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Iφ = 50 MHz,
Pφ = 25 MHz, When other units operate in ICKSEL = 1,
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Min.
Typ.
Max.
Unit
Resolution
10
10
10
Bit
Conversion time
1.0
⎯
⎯
μs
Analog input capacitance
⎯
⎯
20
pF
Permissible signal source impedance
⎯
⎯
1
kΩ
Nonlinearity error
⎯
⎯
±7.5
LSB
Offset error
⎯
⎯
±7.5
LSB
Full-scale error
⎯
⎯
±7.5
LSB
Quantization error
⎯
±0.5
⎯
LSB
Absolute accuracy
⎯
⎯
±8.0
LSB
Note:
*
VCC = PLLVCC = DrVCC = 2.95 V to 3.60 V in the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1424 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
30.7
D/A Conversion Characteristics
Table 30.14 8-Bit D/A Conversion Characteristics
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to
AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Pφ = 8 MHz to 35 MHz,
DADT[1:0] = b'00 (used as 8-bit D/A converter),
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Min.
Typ.
Max.
Unit
Resolution
8
8
8
Bit
Conversion time
⎯
⎯
10
μs
20-pF capacitive load
Absolute accuracy
⎯
±2.0
±3.0
LSB
2-MΩ resistive load
⎯
⎯
±2.0
LSB
4-MΩ resistive load
Note:
*
Test Conditions
VCC = PLLVCC = DrVCC = 2.95 V to 3.60 V in the H8SX/1665M Group.
Table 30.15 10-Bit D/A Conversion Characteristics
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to
AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V, Pφ = 8 MHz to 35 MHz,
DADT[1:0] = Don't care (used as 10-bit D/A converter),
Ta = –20°C to +75°C (regular specifications),
Ta = –40°C to +85°C (wide-range specifications)
Item
Min.
Typ.
Max.
Unit
Resolution
10
10
10
Bit
Conversion time
⎯
⎯
10
μs
20-pF capacitive load
Absolute accuracy
⎯
±2.0
±3.0
LSB
16-MΩ resistive load
Note:
*
Test Conditions
VCC = PLLVCC = DrVCC = 2.95 V to 3.60 V in the H8SX/1665M Group.
Rev. 2.00 Oct. 21, 2009 Page 1425 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
30.8
Flash Memory Characteristics
Table 30.16 Flash Memory Characteristics
Conditions: VCC = PLLVCC = DrVCC = 3.0 V to 3.6 V*5, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0 V,
Operating temperature range during programming/erasing:
Operating temperature range: Ta = 0°C to +75°C (regular specifications),
Ta = 0°C to +85°C (wide-range specifications)
Operating voltage range: VCC = PLLVCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V,
Vref = 3.0 V to AVCC, VSS = PLLVSS = DrVSS = AVSS = 0V
Item
Programming time*1, *2, *4
1,
2,
4
Erasure time* * *
Programming time
(total)*1, *2, *4
Erasure time (total)*1, *2, *4
Symbol
Min.
Typ.
Max.
Unit
tP
⎯
1
10
ms/128 bytes
tE
⎯
40
130
ms/4-Kbyte
block
⎯
300
800
ms/32-Kbyte
block
⎯
600
1500
ms/64-Kbyte
block
⎯
3.4
9
H8SX/1662,
H8SX/1662M
s/384 Kbytes
⎯
4.5
12
H8SX/1665,
H8SX/1665M
s/512 Kbytes
⎯
3.4
9
H8SX/1662,
H8SX/1662M
s/384 Kbytes
⎯
4.5
12
H8SX/1665,
H8SX/1665M
s/512 Kbytes
ΣtP
ΣtE
Rev. 2.00 Oct. 21, 2009 Page 1426 of 1454
REJ09B0498-0200
Test
Conditions
Ta = 25°C,
for all 0s
Ta = 25°C
Section 30 Electrical Characteristics
Test
Conditions
Item
Symbol
Min.
Typ.
Max.
Unit
Programming, Erasure
time (total)*1, *2, *4
ΣtPE
⎯
6.8
18
H8SX/1662,
H8SX/1662M
s/384 Kbytes
⎯
9.0
24
H8SX/1665,
H8SX/1665M
s/512 Kbytes
NWEC
100*3
⎯
⎯
times
TDRP
10
⎯
⎯
years
Overwrite count
4
Data save time*
Ta = 25°C
Notes: 1. Programming time and erase time depend on data in the flash memory.
2. Programming time and erase time do not include time for data transfer.
3. All the characteristics after programming are guaranteed within this value (guaranteed
value is from 1 to Min. value).
4. Characteristics when programming is performed within the Min. value
5. VCC = PLLVCC = DrVCC = 2.95 V to 3.60 V in the H8SX/1665M Group.
30.9
Power-On Reset Circuit and Voltage-Detection Circuit
Characteristics (H8SX/1665M Group)
Table 30.17 Power-On Reset Circuit and Voltage-Detection Circuit Characteristics
Conditions: VCC = PLLVCC, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC,
VSS = PLLVSS = AVSS = 0 V,
Ta = – 20°C to +75°C (regular specifications),
Ta = – 40°C to +85°C (wide-range specifications)
Typ.
Max.
Unit
Test
Conditions
3.00
3.10
3.20
V
Figure 30.60
VPOR
2.48
2.58
2.68
Internal reset time
tPOR
20
35
50
ms
Figure 30.59
Power-off time*
tVOFF
200
⎯
⎯
μs
Figure 30.60
Item
Symbol Min.
Voltage detection Voltage detection Vdet
level
circuit (LVD)
Power-on reset
(POR)
Note:
*
Figure 30.59
Power-off time (tVOFF) is the time over which Vcc is lower than minimum value of the
voltage-detection level of the POR and LVD.
Rev. 2.00 Oct. 21, 2009 Page 1427 of 1454
REJ09B0498-0200
Section 30 Electrical Characteristics
tVOFF
VPOR
VCC
Internal reset signal
("L" is enabled)
tPOR
tPOR
Figure 30.59 Power-On Reset Timing
tVOFF
VCC
Vdet
Internal reset signal
("L" is enabled)
tPOR
Figure 30.60 Voltage Detection Circuit Timing
Rev. 2.00 Oct. 21, 2009 Page 1428 of 1454
REJ09B0498-0200
Appendix
Appendix
A.
Port States in Each Pin State
Table A.1
Port States in Each Pin State
Deep Software
Standby Mode
IOKEEP = 1/0
MCU
Operating
Port Name Mode
Reset
Hardware
Standby
Mode
OPE = 1
Port 1
All
Hi-Z
Hi-Z
Port 2
All
Hi-Z
Port 3
All
Hi-Z
P55 to P50
All
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
P56/
AN6/
DA0/
IRQ6-B
All
Hi-Z
Hi-Z
Hi-Z
Hi-Z
[DAOE0 = 1]
[DAOE0 = 1]
Keep
Keep
[DAOE0 = 0]
[DAOE0 = 0]
Hi-Z
Hi-Z
[DAOE1 = 1]
[DAOE1 = 1]
Keep
Keep
[DAOE1 = 0]
[DAOE1 = 0]
Hi-Z
Hi-Z
P57/
AN7/
DA1/
IRQ7-B
All
Hi-Z
OPE = 0
OPE = 1
OPE = 0
Bus
Released
State
Keep
Keep
Keep
Keep
Keep
Hi-Z
Keep
Keep
Keep
Keep
Keep
Hi-Z
Keep
Keep
Keep
Keep
Keep
Hi-Z
Hi-Z
Software Standby Mode
Hi-Z
Hi-Z
Keep
Keep
P65 to P60
All
Hi-Z
Hi-Z
Keep
Keep
Keep
PA0/
BREQO/
BS-A
All
Hi-Z
Hi-Z
[BREQO
output]
[BREQO
output]
[BREQO
output]
[BREQO
output]
[BREQO
output]
Hi-Z
Hi-Z
Hi-Z
Hi-Z
BREQO
[BS output]
[BS output]
[BS output]
[BS output]
[BS output]
Keep
Hi-Z
Keep
Hi-Z
Hi-Z
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
[BACK
output]
[BACK
output]
[BACK
output]
[BACK
output]
[BACK
output]
Hi-Z
Hi-Z
Hi-Z
Hi-Z
BACK
[RD/WR
output]
[RD/WR
output]
[RD/WR
output]
[RD/WR
output]
[RD/WR
output]
Keep
Hi-Z
Keep
Hi-Z
Hi-Z
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Keep
PA1/
All
BACK/
(RD/WR-A)
Hi-Z
Hi-Z
Keep
Keep
Keep
[Other than
above]
Keep
Rev. 2.00 Oct. 21, 2009 Page 1429 of 1454
REJ09B0498-0200
Appendix
Port
Name
PA2/
BREQ/
WAIT
PA3/
LLWR/
LLB
PA4/
LHWR/
LUB
PA5/RD
PA6/
AS/
AH/
BS-B
MCU
Operating
Mode
Reset
Deep Software
Standby Mode
Hardware
IOKEEP = 1/0
Standby
Mode
OPE = 1
OPE = 0
All
Hi-Z
Hi-Z
Software Standby Mode
OPE = 1
OPE = 0
Bus
Released
State
[BREQ input] [BREQ input] [BREQ input] [BREQ input] [BREQ
input]
Hi-Z
Hi-Z
Hi-Z
Hi-Z
[WAIT input] [WAIT input] [WAIT input]
[WAIT input]
Hi-Z (BREQ)
Hi-Z
Hi-Z
Hi-Z
Hi-Z
[WAIT input]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Hi-Z (WAIT)
Keep
Keep
Keep
Keep
Single-chip
mode
(EXPE = 0)
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
External
extended
mode
(EXPE = 1)
H
Hi-Z
H
Hi-Z
H
Hi-Z
Hi-Z
Single-chip
mode
(EXPE = 0)
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
External
extended
mode
(EXPE = 1)
H
Hi-Z
[LHWR, LUB [LHWR, LUB [LHWR, LUB
output]
output]
output]
[LHWR, LUB
output]
[LHWR, LUB
output]
H
Hi-Z
H
Hi-Z
Hi-Z
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Keep
Single-chip
mode
(EXPE = 0)
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
External
extended
mode
(EXPE = 1)
H
Hi-Z
H
Hi-Z
H
Hi-Z
Hi-Z
Single-chip
mode
(EXPE = 0)
Hi-Z
Hi-Z
[AS, BS
output]
[AS, AH, BS [AS, BS
output]
output]
[AS, AH, BS
output]
[AS, AH, BS
output]
H
Hi-Z
H
Hi-Z
Hi-Z
External
extended
mode
(EXPE = 1)
H
Hi-Z
[AH output]
[Other than
above]
[AH output]
[Other than
above]
[Other than
above]
Keep
[Other than
above]
Keep
Keep
L
[Other than
above]
Keep
Rev. 2.00 Oct. 21, 2009 Page 1430 of 1454
REJ09B0498-0200
L
Keep
Appendix
Port
Name
MCU
Operating
Mode
Deep Software
Standby Mode
Hardware
IOKEEP = 1/0
Standby
Reset Mode
OPE = 1
OPE = 0
Single-chip
mode
(EXPE = 0)
Hi-Z
External
extended
mode
(EXPE = 1)
Clock Hi-Z
output
Single-chip
mode
(EXPE = 0)
Hi-Z
External
extended
mode
(EXPE = 1)
H
PB1/
CS1/
CS2-B/
CS5-A/
CS6-B/
CS7-B
All
Hi-Z
PB2/
CS2-A/
CS6-A/ RAS
All
PA7/Bφ
PB0/
CS0/
CS4-A/
CS5-B
PB3/
CS3/
CS7-A/CAS
PB4/
CS4-B/WE
PB5/
CS5-B/OE
All
All
All
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
OPE = 1
OPE = 0
Bus
Released
State
[Clock
output]
[Clock
output]
[Clock
output]
[Clock
output]
[Clock
output]
H
H
H
H
Clock output
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Keep
[CS output]
[CS output]
[CS output]
[CS output]
[CS output]
H
Hi-Z
H
Hi-Z
Hi-Z
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Keep
Software Standby Mode
[CS output]
[CS output]
[CS output]
[CS output]
[CS output]
H
Hi-Z
H
Hi-Z
Hi-Z
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Keep
[CS, RAS
output]
[CS, RAS
output]
[CS, RAS
output]
[CS, RAS
output]
[CS, RAS
output]
H
Hi-Z
H
Hi-Z
Hi-Z
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Keep
[CS, CAS
output]
[CS, CAS
output]
[CS, CAS
output]
[CS, CAS
output]
[CS, CAS
output]
H
Hi-Z
H
Hi-Z
Hi-Z
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Keep
[CS, WE
output]
[CS, WE
output]
[CS, WE
output]
[CS, WE
output]
[CS, WE
output]
H
Hi-Z
H
Hi-Z
Hi-Z
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Keep
[CS, OE
output]
[CS, OE
output]
[CS, OE
output]
[CS, OE
output]
[CS, OE
output]
H
Hi-Z
H
Hi-Z
Hi-Z
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Keep
Rev. 2.00 Oct. 21, 2009 Page 1431 of 1454
REJ09B0498-0200
Appendix
Port
Name
PB6/
CS6-D/
(RD/WR-B)/
ADTRG0-B
PB7/SDφ
PC2 to PC3
MCU
Operating
Mode
Deep Software
Standby Mode
Hardware
IOKEEP = 1/0
Standby
Reset Mode
OPE = 1
OPE = 0
All
Hi-Z
Hi-Z
OPE = 1
OPE = 0
Bus
Released
State
[CS output]
[CS output]
[CS output]
[CS output]
[CS output]
H
Hi-Z
H
Hi-Z
Hi-Z
[RD/ WR-B
output]
[RD/ WR-B
output]
[RD/ WR-B
output]
[RD/ WR-B
output]
[Other than
above]
Keep
Hi-Z
Keep
Hi-Z
Keep
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Software Standby Mode
SDRAM
mode
SDφ Hi-Z
output
[SDφ output] [SDφ output] [SDφ output] [SDφ output] [SDφ output]
SDφ output
H
H
H
H
Other than
SDRAM
mode
H
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
[Other than
above]
Keep
Keep
Keep
Keep
Keep
All
Hi-Z
Hi-Z
Hi-Z
Rev. 2.00 Oct. 21, 2009 Page 1432 of 1454
REJ09B0498-0200
Keep
Keep
Appendix
Reset
OPE = 1 OPE = 0
Bus
Released
State
External extended
mode
(EXPE = 1)
L
Hi-Z
Keep
Hi-Z
Keep
Hi-Z
Hi-Z
ROM enabled
extended mode
Hi-Z
Hi-Z
Keep
[Address output]
Keep
Hi-Z
[Address
output]
[Address
output]
[Other than above]
Hi-Z
Hi-Z
Keep
[Other than [Other than
above]
above]
MCU Operating
Mode
Port D
PF3 to
PF0
PF7 to
PF4
Software Standby
Mode
Hardware
Standby
Mode
OPE = 1 OPE = 0
Port
Name
Port E
Deep Software
Standby Mode
IOKEEP = 1/0
Keep
Keep
Single-chip mode
(EXPE = 0)
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
External extended
mode
(EXPE = 1)
L
Hi-Z
Keep
Hi-Z
Keep
Hi-Z
Hi-Z
ROM enabled
extended mode
Hi-Z
Hi-Z
Keep
[Address output]
Keep
Hi-Z
[Address
output]
[Address
output]
[Other than above]
Hi-Z
Hi-Z
Keep
[Other than [Other than
above]
above]
Keep
Keep
Single-chip mode
(EXPE = 0)
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
External extended
mode
(EXPE = 1)
L
Hi-Z
Keep
Hi-Z
Keep
Hi-Z
Hi-Z
ROM enabled
extended mode
Hi-Z
Hi-Z
Keep
[Address output]
Keep
Hi-Z
[Address
output]
[Address
output]
[Other than above]
Hi-Z
Hi-Z
Keep
[Other than [Other than
above]
above]
Single-chip mode
(EXPE = 0)
Hi-Z
Hi-Z
Keep
External extended
mode
(EXPE = 1)
Hi-Z
Hi-Z
Keep
Single-chip mode
(EXPE = 0)
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
Keep
Keep
[Address output]
Keep
Hi-Z
[Address
output]
[Address
output]
[Other than above]
Hi-Z
Hi-Z
Keep
[Other than [Other than
above]
above]
Keep
Keep
Keep
Keep
Keep
Keep
Rev. 2.00 Oct. 21, 2009 Page 1433 of 1454
REJ09B0498-0200
Appendix
Bus
Released
Software Standby Mode State
Reset
Hardware
Standby
Mode
OPE = 1
OPE = 0
OPE = 1
OPE = 0
Single-chip mode
(EXPE = 0)
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
External extended
mode
(EXPE = 1)
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Single-chip mode
(EXPE = 0)
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
8-bit Hi-Z
bus
mode
Hi-Z
Keep
Keep
Keep
Keep
Keep
16-bit Hi-Z
bus
mode
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Port
Name
MCU Operating
Mode
Port H
Port I
Deep Software
Standby Mode
IOKEEP = 1/0
External
extended
mode
(EXPE = 1)
Port J
Hi-Z
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
Port K
Hi-Z
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
Port M
Hi-Z
Hi-Z
Hi-Z
Keep
Keep
Keep
Keep
Keep
[Legend]
H:
High-level output
L:
Low-level output
Keep: Input pins become high-impedance, output pins retain their state.
Hi-Z: High impedance
Rev. 2.00 Oct. 21, 2009 Page 1434 of 1454
REJ09B0498-0200
Appendix
B.
Product Lineup
Product Classification Part No.
Marking
Package (Package Code)
H8SX/1662
R5F61662FPV
PLQP0144KA-A (FP-144LV)*
R5F61662LGV
PTLG0145JB-A (TLP-145V)*
R5F61665FPV
PLQP0144KA-A (FP-144LV)*
R5F61665LGV
PTLG0145JB-A (TLP-145V)*
R5F61662MFPV
PLQP0144KA-A (FP-144LV)*
R5F61662MLGV
PTLG0145JB-A (TLP-145V)*
R5F61665MFPV
PLQP0144KA-A (FP-144LV)*
R5F61665MLGV
PTLG0145JB-A (TLP-145V)*
H8SX/1665
H8SX/1662M
H8SX/1665M
Note:
*
R5F61662
R5F61665
R5F61662M
R5F61665M
Pb-free version
Rev. 2.00 Oct. 21, 2009 Page 1435 of 1454
REJ09B0498-0200
144
1
ZD
e
Index mark
y
D
HD
*3
bp
36
73
x
37
72
F
E
*2
109
108
*1
Previous Code
144P6Q-A / FP-144L / FP-144LV
ZE
RENESAS Code
PLQP0144KA-A
HE
REJ09B0498-0200
c1
Detail F
Terminal cross section
b1
bp
MASS[Typ.]
1.2g
A
Rev. 2.00 Oct. 21, 2009 Page 1436 of 1454
A2
L
c
L1
Figure C.1 Package Dimensions (FP-144LV)
e
x
y
ZD
ZE
L
L1
D
E
A2
HD
HE
A
A1
bp
b1
c
c1
Reference
Symbol
Min Nom Max
19.9 20.0 20.1
19.9 20.0 20.1
1.4
21.8 22.0 22.2
21.8 22.0 22.2
1.7
0.05 0.1 0.15
0.17 0.22 0.27
0.20
0.09 0.145 0.20
0.125
8°
0°
0.5
0.08
0.10
1.25
1.25
0.35 0.5 0.65
1.0
Dimension in Millimeters
NOTE)
1. DIMENSIONS "*1" AND "*2"
DO NOT INCLUDE MOLD FLASH.
2. DIMENSION "*3" DOES NOT
INCLUDE TRIM OFFSET.
C.
A1
JEITA Package Code
P-LQFP144-20x20-0.50
Appendix
Package Dimensions
For the package dimensions, data in the Renesas IC Package General Catalog has priority.
c
Appendix
JEITA Package Code
P-TFLGA145-9x9-0.65
RENESAS Code
PTLG0145JB-A
Previous Code
-
MASS[Typ.]
0.15g
D
w S B
E
w S A
x4
v
y1 S
A
S
y S
e
A
ZD
e
N
M
L
K
J
B
H
G
F
E
D
ZE
C
B
Reference
Symbol
Dimension in Millimeters
Min
9.0
E
9.0
1
2
3
4
5
6
7
φb
8
9 10 11 12 13
0.15
w
0.20
A
1.2
A1
b
0.65
0.30
0.35
0.40
0.08
x
φxn S A B
Max
v
e
A
Nom
D
y
0.1
y1
0.20
SD
SE
ZD
0.6
ZE
0.6
Figure C.2 Package Dimensions (TLP-145V)
Rev. 2.00 Oct. 21, 2009 Page 1437 of 1454
REJ09B0498-0200
Appendix
D.
Treatment of Unused Pins
The treatments of unused pins are listed in table D.1
Table D.1
Treatment of Unused Pins
Pin Name
Mode 4
Mode 5
Mode 6
RES
(Always used as a reset pin)
STBY
•
Connect this pin to Vcc via a pull-up resistor
EMLE
•
Connect this pin to Vss via a pull-down resistor
MD_CLK
(Always used as mode pins)
MD3 to MD0
(Always used as mode pins)
Modes 3, 7
NMI
•
EXTAL
(Always used as a clock pin)
XTAL
•
Leave this pin open
OSC1
•
Connect this pin to Vss via a pull-down resistor
OSC2
•
Leave this pin open
WDTOVF
•
Leave this pin open
USD+
•
Leave this pin open
USD−
•
Leave this pin open
VBUS
•
Leave this pin open
Port 1
•
Connect these pins to Vcc via a pull-up resistor or to Vss via a pull-down
resistor, respectively
•
Connect these pins to AVcc via a pull-up resistor or to AVss via a pull-down
resistor, respectively
Port 2
Connect this pin to Vcc via a pull-up resistor
Port 3
Port 6
PA2 to PA0
PB7 to PB1
Port C
PF7 to PF5
Port J
Port K
Port M
Port 5
Rev. 2.00 Oct. 21, 2009 Page 1438 of 1454
REJ09B0498-0200
Appendix
Pin Name
Mode 4
PA7
•
This pin is left open in the initial state for the Bφ output. •
PA6
•
This pin is left open in the initial state for the AS output.
PA5
•
This pin is left open in the initial state for the RD output.
PA4
•
This pin is left open in the initial state for the LHWR
output.
PA3
•
This pin is left open in the initial state for the LLWR
output.
PB0
•
This pin is left open in the initial
state for the CS0 output.
Port D
•
These pins are left open in the
initial state for the address output.
Port E
Mode 5
Mode 6
Modes 3,7
Connect these
pins to VCC via a
pull-up resistor or
to VSS via a pulldown resistor,
respectively
PF4 to PF0
Port H
(Used as a data bus)
Port I
(Used as
a data bus)
Vref
•
•
Connect these pins to VCC via a
pull-up resistor or to VSS via a pulldown resistor, respectively, in the
initial state for the general input.
Connect this pin to AVcc
Notes: 1. Do not change the initial value (input-buffer disabled) of PnICR, where n corresponds to
an unused pin.
2. When the pin function is changed from its initial state, use a pull-up or pull-down
resistor as needed.
Rev. 2.00 Oct. 21, 2009 Page 1439 of 1454
REJ09B0498-0200
Appendix
Rev. 2.00 Oct. 21, 2009 Page 1440 of 1454
REJ09B0498-0200
Main Revisions and Additions in this Edition
Common revised items due to the version upgrade from Rev.1.00 to Rev.2.00
Item
Page Revision (See Manual for Details)
All
⎯
Group name added: H8SX/1665M Group
Accordingly, descriptions related to the H8SX/1665M Group also
added.
All
⎯
Descriptions related to power-on reset (POR) and voltage
detection circuit (LVD) added
Rev. 2.00 Oct. 21, 2009 Page 1441 of 1454
REJ09B0498-0200
Item
Page Revision (See Manual for Details)
All
⎯
Amended
Section, table, and figure numbers were amended due to the
addition of the section 5.
Structure of the Rev. 2.00
1. Overview
2. CPU
3. MCU Operating Modes
4. Resets
5. Voltage Detection Circuit (LVD)
6. Exception Handling
7. Interrupt Controller
8. User Break Controller (UBC)
9. Bus Controller (BSC)
10. DMA Controller (DMAC)
11. EXDMA Controller (EXDMAC)
12. Data Transfer Controller (DTC)
13. I/O Ports
14. 16-Bit Timer Pulse Unit (TPU)
15. Programmable Pulse Generator (PPG)
16. 8-Bit Timers (TMR)
17. 32K Timer (TM32K)
18. Watchdog Timer (WDT)
19. Serial Communication Interface (SCI, IrDA, CRC)
20. USB Function Module (USB)
21. I2C Bus Interface 2 (IIC2)
22. A/D Converter
23. D/A Converter
24. RAM
25. Flash Memory
26. Boundary Scan
27. Clock Pulse Generator
28. Power-Down Modes
29. List of Registers
30. Electrical Characteristics
Appendix
Rev. 2.00 Oct. 21, 2009 Page 1442 of 1454
REJ09B0498-0200
Item
Page Revision (See Manual for Details)
Section 1 Overview
7
Amended
1.1 Features
Module/
Classification
1.1.2 Overview of
Functions
32K timer
Description
32K timer
•
Eight counter clocks which divides the
32.768 kHz clock can be selected
•
8 bits × 1 channel or 24 bits × 1 channel can
be selected
•
Interrupts can be generated when the
counter overflows.
•
Eight overflow cycles selectable (250 msec,
500 msec, 1 sec, 2 sec, 30 sec, 60 sec,
about 23 days, and about 46 days)
(TM32K)
Table 1.1 Overview of
Functions
Section 7 Interrupt
Controller
Function
145
Amended
Vector Address
7.5 Interrupt Exception
Handling Vector Table
Offset*
1
Advanced
Table 7.2 Interrupt
Sources, Vector Address
Offsets, and Interrupt
Priority
Mode, Middle
Classifi Interrupt
Vector
Mode,
cation
Source
Number
Maximum Mode IPR
⎯
Reserved for
76
H'0130
system use
LVD*
2
Voltage-
77
H'0134
78
H'0138
monitoring
⎯
DTC
DMAC
Priority
Activation
Activation
High
⎯
⎯
⎯
⎯
⎯
⎯
⎯
⎯
IPRD6 to
IPRD4
interrupt
(IRQ14)
TM32K
32KOVI
(IRQ15)
Section 13 I/O Ports
13.1 Register
Descriptions
Table 13.2 Register
Configuration in Each
Port
601
79
H'013C
IPRD2 to
IPRD0
Low
Notes added
Notes: 1. Bits 2 and 3 are valid and the other bits are reserved
for port C registers. The write value should be the
same as the initial value.
2. Do not access when PCJKE = 1.
3. Do not access when PCJKE = 0.
4. The lower six bits are valid and the upper two bits
are reserved for port 6 registers. The write value
should be the same as the initial value.
5. The lower five bits are valid and the upper three bits
are reserved for port M registers. The write value
should be the same as the initial value.
Rev. 2.00 Oct. 21, 2009 Page 1443 of 1454
REJ09B0498-0200
Item
Page Revision (See Manual for Details)
Section 22 A/D
Converter
1082 Note amended
22.4 Operation
22.4.2 Scan Mode
(1) Continuous Scan Mode
…
Notes: 1. Only possible in unit 0.
2. As conversion start trigger, units 0 and 1 of TMR, and
units 2 and 3 of TMR are available in unit 0, and unit
1, respectively.
3. Unit 0: The full-spec emulator (E6000H) should not be
used, but the on-chip emulator (E10A-USB) is usable.
22.4.3 Input Sampling
and A/D Conversion
Time
1086 The following tables replaced
to
Table 22.3 Characteristics of A/D Conversion (Unit 0: when
1088 EXCKS* = 0, ICKSEL = 0, and ADSSTR* = H'0F) (1)
Table 22.3 Characteristics of A/D Conversion (Unit 0: when
EXCKS* = 1, ICKSEL = 0, and ADSSTR* = H'0F) (2)
Table 22.4 Characteristics of A/D Conversion (Unit 1: when
EXCKS = 0, ICKSEL = 0, and ADSSTR* = H'0F) (1)
Table 22.4 Characteristics of A/D Conversion (Unit 1: when
EXCKS = 1, ICKSEL = 0, and ADSSTR* = H'0F) (2)
1
Table 22.5 Characteristics of A/D Conversion (When EXCKS* =
1
2
1, ICKSEL* = 0, and ADSSTR* = H'19)
Table 22.6 Period of A/D 1089 Note deleted
Conversion (Scan Mode)
Notes: 1. Make the sampling setting15 (ADSSRT = D'15).
(Units 0 and 1)
2. When Pφ = Iφ/2, make the sampling setting 25
(ADSSRT = D'25).
3. Unit 0: The full-spec emulator (E6000H) should not be
used, but the on-chip emulator (E10A-USB) is usable.
4. Unit 0: The full-spec emulator (E6000H) should not be
used, but the on-chip emulator (E10A-USB) is usable.
Unit 1: Access to the full-spec emulator (E6000H) is
prohibited but the on-chip emulator (E10A-USB) is
usable.
Rev. 2.00 Oct. 21, 2009 Page 1444 of 1454
REJ09B0498-0200
Item
Page Revision (See Manual for Details)
22.7 Usage Notes
1098 Note deleted
22.7.5 Permissible
Signal Source
Impedance
Notes: 1. Unit 0: The full-spec emulator (E6000H) should not
be used, but the on-chip emulator (E10A-USB) is
usable.
2. Unit 0: The full-spec emulator (E6000H) should not
be used, but the on-chip emulator (E10A-USB) is
usable.
Unit 1: Access to the full-spec emulator (E6000H) is
prohibited, but the on-chip emulator (E10A-USB) is
usable.
Section 29 List of
Registers
29.2 Register Bits
1338 Added
Register
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Abbreviation
31/23/15/7
30/22/14/6
29/21/13/5
28/20/12/4
27/19/11/3
26/18/10/2
25/17/9/1
24/16/8/0
Module
DPSIER
⎯
DUSBIE
DT32KIE
DLVDIE
DIRQ3E
DIRQ2E
DIRQ1E
DIRQ0E
SYSTEM
DPSIFR
DNMIF
DUSBIF
DT32KIF
DLVDIF
DIRQ3F
DIRQ2F
DIRQ1F
DIRQ0F
DPSIEGR
DNMIEG
⎯
⎯
⎯
DIRQ3EG
DIRQ2EG
DIRQ1EG
DIRQ0EG
RSTSR
DPSRSTF
⎯
⎯
⎯
⎯
LVDF
⎯
PORF
LVDE
LVDRI
⎯
LVDMON
⎯
⎯
⎯
⎯
3
LVDCR*
Appendix
D. Treatment of Unused
Pins
1438 Amended
Pin Name
Mode 4
OSC1
•
Mode 5
Mode 6
Modes 3, 7
Connect this pin to Vss via a pull-down resistor
Table D.1 Treatment of
Unused Pins
Rev. 2.00 Oct. 21, 2009 Page 1445 of 1454
REJ09B0498-0200
Rev. 2.00 Oct. 21, 2009 Page 1446 of 1454
REJ09B0498-0200
Index
Numerics
B
0 output/1 output..................................... 727
0-output/1-output .................................... 727
16-bit access space.................................. 238
16-bit counter mode................................ 832
16-bit timer pulse unit (TPU) ................. 677
32K timer (TM32K) ............................... 841
8-bit access space.................................... 237
8-bit timers (TMR) ................................. 805
Bφ clock output control......................... 1292
Basic bus interface .......................... 229, 240
Big endian ............................................... 228
Bit rate..................................................... 891
Bit synchronous circuit ......................... 1058
Block structure ...................................... 1120
Block transfer mode ................ 404, 483, 579
Boot mode................................... 1117, 1148
Boundary scan commands .................... 1219
Buffer operation ...................................... 732
Bulk-in transfer ..................................... 1014
Bulk-out transfer ................................... 1013
Burst access mode................................... 410
Burst mode.............................................. 488
Burst ROM interface....................... 229, 261
Bus access modes.................................... 409
Bus arbitration......................................... 363
Bus configuration.................................... 216
Bus controller (BSC)............................... 179
Bus cycle division ................................... 573
Bus mode ................................................ 487
Bus release .............................................. 356
Bus width ................................................ 228
Bus-released state...................................... 74
Byte control SRAM interface ......... 229, 253
A
A/D conversion accuracy...................... 1093
Absolute accuracy................................. 1093
Acknowledge ........................................ 1043
Address error .......................................... 116
Address map ............................................. 85
Address mode ......................................... 527
Address modes................................ 398, 478
Address/data multiplexed I/O
interface .......................................... 230, 266
All-module-clock-stop mode ...... 1246, 1271
Area 0 ..................................................... 232
Area 1 ..................................................... 233
Area 2 ..................................................... 233
Area 3 ..................................................... 234
Area 4 ..................................................... 234
Area 5 ..................................................... 235
Area 6 ..................................................... 235
Area 7 ..................................................... 236
Area division........................................... 225
Asynchronous mode ............................... 908
AT-cut parallel-resonance type............. 1237
Available output signal and settings in
each port ................................................. 649
Average transfer rate generator............... 864
C
Cascaded connection............................... 832
Cascaded operation ................................. 736
Chain transfer.......................................... 580
Chip select signals................................... 226
Clock pulse generator ........................... 1231
Clock synchronization cycle (Tsy).......... 218
Clocked synchronous mode .................... 925
Rev. 2.00 Oct. 21, 2009 Page 1447 of 1454
REJ09B0498-0200
Cluster transfer dual address mode......... 527
Cluster transfer modes ............................ 477
Cluster transfer read address mode......... 529
Cluster transfer write address mode ....... 531
Communications protocol..................... 1185
Compare match A................................... 829
Compare match B ................................... 830
Compare match count mode ................... 832
Compare match signal ............................ 829
Control transfer..................................... 1007
Counter operation ................................... 724
CPU priority control function over DTC
and DMAC ............................................. 161
CRC operation circuit............................. 954
Crystal resonator................................... 1237
Cycle steal mode..................................... 487
Cycle stealing mode................................ 409
D
D/A converter ....................................... 1103
Data direction register ............................ 602
Data register............................................ 603
Data stage ............................................. 1009
Data transfer controller (DTC) ............... 555
Direct convention ................................... 933
DMA controller (DMAC)....................... 371
Double-buffered structure....................... 908
Download pass/fail result parameter..... 1136
DRAM interface ..................................... 276
DRAM Interface ..................................... 230
DTC vector address ................................ 568
DTC vector address offset ...... 568, 569, 570
Dual address mode.......................... 398, 478
E
Endian and data alignment ..................... 237
Endian format ......................................... 228
Error protection .................................... 1177
Rev. 2.00 Oct. 21, 2009 Page 1448 of 1454
REJ09B0498-0200
Error signal ............................................. 933
Exception handling ................................. 109
Exception-handling state........................... 74
EXDMA controller (EXDMAC) ............ 449
Extended repeat area ............................... 395
Extended repeat area function......... 411, 488
Extension of chip select (CS) assertion
period ...................................................... 250
External access bus ................................. 216
External bus ............................................ 221
External bus clock (Bφ) ................ 217, 1231
External bus interface ............................. 227
External clock ....................................... 1238
External interrupts................................... 143
F
Flash erase block select parameter........ 1145
Flash memory ....................................... 1115
Flash multipurpose address area
parameter .............................................. 1143
Flash multipurpose data destination
parameter .............................................. 1144
Flash pass and fail parameter ................ 1137
Flash program/erase frequency
parameter .................................... 1141, 1160
Free-running count operation.................. 725
Frequency divider ....................... 1231, 1239
Full address mode ................................... 566
Full-scale error...................................... 1093
G
General illegal instructions ..................... 122
H
Hardware protection ............................. 1176
Hardware standby mode ............. 1246, 1287
I
I/O ports.................................................. 593
I2C bus format....................................... 1043
I2C bus interface2 (IIC2) ...................... 1027
ID code ................................................... 919
Idle cycle ................................................ 343
Illegal instruction.................................... 122
Input buffer control register.................... 604
Input capture function............................. 728
Internal interrupts ................................... 144
Internal peripheral bus ............................ 216
Internal system bus ................................. 216
Interrupt .................................................. 119
Interrupt control mode 0 ......................... 152
Interrupt control mode 2 ......................... 154
Interrupt controller.................................. 125
Interrupt exception handling sequence ... 156
Interrupt exception handling vector
table ........................................................ 145
Interrupt response times.......................... 157
Interrupt sources ..................................... 143
Interrupt sources and vector address
offsets ..................................................... 145
Interrupt-in transfer............................... 1015
Interval timer .......................................... 858
Interval timer mode................................. 858
Inverse convention.................................. 934
IRQn interrupts ....................................... 143
J
JTAG interface ..................................... 1061
L
Little endian............................................ 228
M
Mark state ....................................... 908, 949
Master receive mode ............................. 1046
Master transmit mode ........................... 1044
MCU operating modes .............................. 77
Memory MAT configuration ................ 1119
Mode 2 ...................................................... 83
Mode 4 ...................................................... 83
Mode 5 ...................................................... 84
Mode 6 ...................................................... 84
Mode 7 ...................................................... 84
Mode pin ................................................... 77
Multi-clock mode.................................. 1268
Multiprocessor bit ................................... 919
Multiprocessor communication
function ................................................... 919
N
NMI interrupt.......................................... 143
Noise canceler....................................... 1052
Nonlinearity error.................................. 1093
Non-overlapping pulse output................. 795
Normal transfer mode ............................. 576
Normal transfer mode ..................... 402, 481
Number of access cycles ......................... 229
O
Offset addition ........................................ 414
Offset addition method ........................... 491
Offset error............................................ 1093
On-board programming ........................ 1147
On-board programming mode............... 1115
On-chip baud rate generator.................... 911
On-chip ROM disabled extended mode .... 77
On-chip ROM enabled extended mode..... 77
Open-drain control register ..................... 606
Oscillator............................................... 1237
Output buffer control .............................. 607
Output trigger.......................................... 794
Overflow ......................................... 831, 856
Rev. 2.00 Oct. 21, 2009 Page 1449 of 1454
REJ09B0498-0200
P
Package dimensions.................... 1436, 1438
Parity bit ................................................. 908
Periodic count operation......................... 725
Peripheral module clock (Pφ) ....... 217, 1231
Phase counting mode .............................. 743
Pin assignments ........................................ 13
Pin functions............................................. 21
PLL circuit.................................. 1231, 1239
Port function controller........................... 659
Port register ............................................ 603
Power-down modes .............................. 1245
Procedure program ............................... 1170
Processing states ....................................... 74
Product lineup....................................... 1435
Program execution state............................ 74
Program stop state .................................... 74
Programmable pulse generator (PPG) .... 769
Programmer mode ...................... 1117, 1183
Programming/erasing interface............. 1122
Programming/erasing interface
parameters............................................. 1134
Programming/erasing interface
register .................................................. 1127
Protection.............................................. 1176
Pull-up MOS control register.................. 605
PWM modes ........................................... 738
Q
Quantization error................................. 1093
R
RAM..................................................... 1113
Read strobe (RD) timing......................... 249
Register addresses ................................... 1296
Register Bits ........................................... 1315
Register configuration in each port......... 601
Rev. 2.00 Oct. 21, 2009 Page 1450 of 1454
REJ09B0498-0200
Registers
ABWCR.............................................. 183
ADCSR ............................................. 1067
ASTCR ............................................... 184
BCR1 .................................................. 196
BCR2 .................................................. 198
BROMCR ........................................... 201
BRR .................................................... 891
CCR ...................................................... 43
CLSBR................................................ 475
CPUPCR ............................................. 129
CRA .................................................... 561
CRB .................................................... 562
CRCCR ............................................... 955
CRCDIR ............................................. 956
CRCDOR............................................ 956
CSACR ............................................... 191
CTLR .................................................. 986
CVR .................................................... 986
DACR ................................................. 390
DACR01 ........................................... 1107
DADR01T......................................... 1106
DADR0H .......................................... 1105
DADR0L........................................... 1106
DADR1H .......................................... 1105
DADR1L........................................... 1106
DAR.................................................... 561
DASTS................................................ 980
DBSR.................................................. 380
DDAR ................................................. 377
DDR.................................................... 602
DMA ................................................... 982
DMDR ................................................ 381
DMRSR .............................................. 396
DOFR.................................................. 378
DPFR ................................................ 1136
DR....................................................... 603
DRACCR............................................ 209
DRAMCR ........................................... 204
DSAR.................................................. 376
DTCCR............................................... 563
DTCER ............................................... 562
DTCR ................................................. 379
DTCVBR............................................ 565
EDACR............................................... 469
EDBSR ............................................... 459
EDDAR .............................................. 456
EDMDR.............................................. 460
EDOFR ............................................... 457
EDSAR ............................................... 455
EDTCR ............................................... 458
ENDIANCR........................................ 199
EPDR.................................................. 976
EPDR0i............................................... 974
EPDR0o.............................................. 975
EPDR0s .............................................. 975
EPIR ................................................... 988
EPSTL ................................................ 985
EPSZ0o............................................... 977
EPSZ1................................................. 978
EXR ...................................................... 44
FCCS ................................................ 1127
FCLR .................................................. 981
FEBS................................................. 1145
FECS................................................. 1130
FKEY................................................ 1131
FMATS............................................. 1132
FMPAR............................................. 1143
FMPDR............................................. 1144
FPCS................................................. 1130
FPEFEQ.................................. 1141, 1160
FPFR................................................. 1137
FTDAR ............................................. 1133
General registers ................................... 41
ICCRA.............................................. 1031
ICCRB .............................................. 1032
ICDRR.............................................. 1042
ICDRS .............................................. 1042
ICDRT .............................................. 1042
ICIER................................................ 1035
ICMR ................................................ 1034
ICR...................................................... 604
ICSR.................................................. 1038
IDLCR ................................................ 194
IER...................................................... 133
IER (USB)........................................... 972
IFR (USB)........................................... 964
INTCR ................................................ 128
IPR ...................................................... 131
IrCR .................................................... 907
ISCRH................................................. 134
ISCRL ................................................. 134
ISR ...................................................... 140
ISR (USB)........................................... 969
LVDCR............................................... 102
MAC ..................................................... 45
MDCR................................................... 79
MPXCR .............................................. 203
MRA ................................................... 558
MRB.................................................... 559
MSTPCRA........................................ 1252
MSTPCRB ........................................ 1252
MSTPCRC ........................................ 1255
NDERH............................................... 775
NDERL ............................................... 775
NDRH ................................................. 780
NDRL.................................................. 780
ODR.................................................... 606
PC ......................................................... 42
PCR..................................................... 785
PCR (I/O port)..................................... 605
PFCR0................................................. 659
PFCR1................................................. 660
PFCR2................................................. 661
PFCR4................................................. 663
PFCR6................................................. 665
PFCR7......................................... 666, 667
PFCR9................................................. 668
PFCRB ........................................ 670, 672
PFCRC ........................................ 674, 675
Rev. 2.00 Oct. 21, 2009 Page 1451 of 1454
REJ09B0498-0200
PMR.................................................... 787
PODRH .............................................. 778
PODRL ............................................... 778
PORT.................................................. 603
RAMER............................................ 1146
RDNCR .............................................. 190
RDR.................................................... 871
REFCR ............................................... 211
RSR .................................................... 871
RSTCSR ............................................. 855
RSTSR................................................ 103
RTCNT ............................................... 215
RTCOR............................................... 215
SAR .......................................... 560, 1041
SBR ...................................................... 45
SBYCR............................................. 1250
SCKCR............................................. 1233
SCMR................................................. 890
SCR .................................................... 876
SDBPR ............................................. 1219
SDBSR ............................................. 1219
SDCR.................................................. 210
SDID................................................. 1225
SEMR ................................................. 898
SMR.................................................... 872
SRAMCR ........................................... 200
SSIER ................................................. 141
SSR..................................................... 881
SYSCR ................................................. 81
TCCR.................................................. 816
TCNT.................................................. 721
TCNT (TMR) ..................................... 813
TCNT (WDT)..................................... 853
TCORA .............................................. 813
TCORB............................................... 814
TCR .................................................... 691
TCR (TMR) ........................................ 814
TCR32K ............................................. 842
TCSR (TMR)...................................... 821
TCSR (WDT) ..................................... 853
Rev. 2.00 Oct. 21, 2009 Page 1452 of 1454
REJ09B0498-0200
TDR .................................................... 872
TGR .................................................... 721
TIER ................................................... 716
TIOR ................................................... 698
TMDR................................................. 696
TRG .................................................... 978
TRNTREG .......................................... 992
TSR ............................................. 717, 872
TSTR................................................... 722
TSYR .................................................. 723
VBR ...................................................... 45
WTCRA.............................................. 185
WTCRB .............................................. 185
Repeat transfer mode .............. 403, 482, 577
Reset ....................................................... 112
Reset state ................................................. 74
Resolution ............................................. 1093
S
Sample-and-hold circuit........................ 1085
Scan mode............................................. 1081
SDRAM interface ................................... 230
Serial communication interface (SCI)..... 863
Setup stage ............................................ 1008
Short address mode ................................. 566
Single address mode ....................... 399, 479
Single mode .......................................... 1080
Slave receive mode ............................... 1051
Slave transmit mode.............................. 1048
Sleep instruction exception handling ...... 121
Sleep mode.................................. 1246, 1270
Slot illegal instructions ........................... 122
Smart card interface ................................ 932
Software protection............................... 1177
Software standby mode............... 1246, 1272
Space state .............................................. 908
Stack status after exception handling...... 123
Stall operations ..................................... 1017
Standard serial communication interface
specifications for boot mode................. 1183
Start bit ................................................... 908
State transition of TAP controller......... 1226
State transitions......................................... 75
Status stage ........................................... 1011
Stop bit.................................................... 908
Strobe assert/negate timing..................... 232
Synchronous clearing.............................. 730
Synchronous DRAM interface................ 302
Synchronous operation ........................... 730
Synchronous presetting........................... 730
System clock (Iφ).......................... 217, 1231
U
USB function module ............................. 961
USB standard commands ...................... 1016
User boot MAT ..................................... 1119
User boot mode ........................... 1117, 1166
User break controller (UBC)................... 167
User MAT ............................................. 1119
User program mode..................... 1117, 1156
V
Vector table address................................ 110
Vector table address offset...................... 110
Voltage Detection Circuit (LVD)............ 101
T
TAP controller ...................................... 1226
Toggle output.......................................... 727
Trace exception handling........................ 115
Transfer information............................... 566
Transfer information read skip
function................................................... 575
Transfer information writeback skip
function................................................... 576
Transfer modes ............................... 402, 481
Transmit/receive data.............................. 908
Trap instruction exception handling ....... 120
W
Wait control ............................................ 247
Watchdog timer (WDT) .......................... 851
Watchdog timer mode............................. 856
Waveform output by compare match...... 726
Write data buffer function....................... 361
Write data buffer function for external
data bus ................................................... 361
Write data buffer function for peripheral
modules................................................... 362
Rev. 2.00 Oct. 21, 2009 Page 1453 of 1454
REJ09B0498-0200
Rev. 2.00 Oct. 21, 2009 Page 1454 of 1454
REJ09B0498-0200
Renesas 32-Bit CISC Microcomputer
Hardware Manual
H8SX/1665 Group, H8SX/1665M Group
Publication Date: Rev.1.00, Mar. 25, 2009
Rev.2.00, Oct. 21, 2009
Published by:
Sales Strategic Planning Div.
Renesas Technology Corp.
Edited by:
Customer Support Department
Global Strategic Communication Div.
Renesas Solutions Corp.
© 2009. Renesas Technology Corp., All rights reserved. Printed in Japan.
Sales Strategic Planning Div.
Nippon Bldg., 2-6-2, Ohte-machi, Chiyoda-ku, Tokyo 100-0004, Japan
RENESAS SALES OFFICES
http://www.renesas.com
Refer to "http://www.renesas.com/en/network" for the latest and detailed information.
Renesas Technology America, Inc.
450 Holger Way, San Jose, CA 95134-1368, U.S.A
Tel: (408) 382-7500, Fax: (408) 382-7501
Renesas Technology Europe Limited
Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K.
Tel: (1628) 585-100, Fax: (1628) 585-900
Renesas Technology (Shanghai) Co., Ltd.
Unit 204, 205, AZIACenter, No.1233 Lujiazui Ring Rd, Pudong District, Shanghai, China 200120
Tel: (21) 5877-1818, Fax: (21) 6887-7858/7898
Renesas Technology Hong Kong Ltd.
7th Floor, North Tower, World Finance Centre, Harbour City, Canton Road, Tsimshatsui, Kowloon, Hong Kong
Tel: 2265-6688, Fax: 2377-3473
Renesas Technology Taiwan Co., Ltd.
10th Floor, No.99, Fushing North Road, Taipei, Taiwan
Tel: (2) 2715-2888, Fax: (2) 3518-3399
Renesas Technology Singapore Pte. Ltd.
1 Harbour Front Avenue, #06-10, Keppel Bay Tower, Singapore 098632
Tel: 6213-0200, Fax: 6278-8001
Renesas Technology Korea Co., Ltd.
Kukje Center Bldg. 18th Fl., 191, 2-ka, Hangang-ro, Yongsan-ku, Seoul 140-702, Korea
Tel: (2) 796-3115, Fax: (2) 796-2145
Renesas Technology Malaysia Sdn. Bhd
Unit 906, Block B, Menara Amcorp, Amcorp Trade Centre, No.18, Jln Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia
Tel: 7955-9390, Fax: 7955-9510
Colophon 6.2
H8SX/1665 Group, H8SX/1665M Group
Hardware Manual
1753, Shimonumabe, Nakahara-ku, Kawasaki-shi, Kanagawa 211-8668 Japan
REJ09B0498-0200