# Old Company Name in Catalogs and Other Documents

On April 1<sup>st</sup>, 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: <a href="http://www.renesas.com">http://www.renesas.com</a>

April 1<sup>st</sup>, 2010 Renesas Electronics Corporation

Issued by: Renesas Electronics Corporation (<a href="http://www.renesas.com">http://www.renesas.com</a>)

Send any inquiries to http://www.renesas.com/inquiry.



#### Notice

- 1. 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.
- 3. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part.
- 4. 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.
- 5. 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.
- 6. 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.
- 7. 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": 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; anti-crime 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.
- 8. 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.
- 9. 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.
- 10. 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.
- 11. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written consent of Renesas Electronics
- 12. 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 majority-owned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.



# SH7206 Group

# Example of Transferring Data to an On-Chip Module Using the DMAC

#### Introduction

This application note describes an example of data transfer to an on-chip module using the direct memory access controller (DMAC) in the SH7206.

# **Target Device**

SH7206

#### **Contents**

| 1. | Overview                          | 2    |
|----|-----------------------------------|------|
| 2. | Description of Sample Application | 3    |
| 3. | Sample Program Listing            | 9    |
| 4. | Reference Documents               | . 15 |
| 5. | Website                           | . 15 |



#### 1. Overview

# 1.1 Specifications

- Using the DMAC channel 1, data is transferred from external memory to the transmit FIFO data register (SCFTDR) of the serial communication interface with FIFO (SCIF channel 0), and thus character strings are sent.
- The transmit-FIFO-data-empty transfer request (a request from on-chip peripheral module) of the SCIF is used as the DMA transfer request.

#### 1.2 MCU Functions Used

- Direct memory access controller (DMAC channel 1)
- Serial communication interface with FIFO (SCIF channel 0)

## 1.3 Conditions for Application

• MCU: SH7206 (R5S72060)

• Operating frequency: Internal clock: 200 MHz

Bus clock: 66.67 MHz Peripheral clock: 33.33 MHz

• C compiler: SuperH RISC Engine Family C/C++ Compiler Package: version 9.00

(from Renesas Technology Corp.)

• Compiler options: Default setting of HEW (-cpu = sh2a -debug -gbr = auto -global\_volatile = 0

-opt\_range = all -infinite\_loop = 0 -del\_vacant\_loop = 0

-struct alloc = 1)

## 1.4 Related Application Note

- The operation of the sample program in this application note was confirmed with the configuration specified in the application note "Example of SH7206 Initial Configuration". Please refer to that note in combination with this one.
- Details on SCIF UART transmission are described in the SH7206 application note "Example Settings for UART Transmission by the SCIF".



# 2. Description of Sample Application

This sample application applies the direct memory access controller (DMAC) to transfer of data from external memory to the SCIF in response to an on-chip peripheral module request.

## 2.1 Summary of MCU Functions Used

When DMA transfer requests are generated, the DMAC initiates transfer in accordance with the priority levels assigned to its channels, and terminates the transfer when the transfer-end conditions are satisfied. There are three transfer request modes: auto request, external request and on-chip peripheral module request. Either burst mode or cycle-steal mode can be selected as the bus mode.

Table 1 summarizes the features of the DMAC. Figure 1 is a schematic view of the DMAC.

Table 1 Summary of the DMAC

| Item                                                    | Function                                                                                      |
|---------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| Number of channels                                      | 8 (CH0 to CH7)                                                                                |
|                                                         | Of these, four channels CH0 to CH3 can receive external requests.                             |
| Address space                                           | 4 Gbytes                                                                                      |
| Transfer data sizes                                     | Byte, word (2 bytes), longword (4 bytes), and 16 bytes (longword $\times$ 4)                  |
| Maximum transfer count                                  | 16,777,216 (24 bits)                                                                          |
| Address modes                                           | Single-address mode and dual-address mode                                                     |
| Transfer requests                                       | Auto request, external request, and on-chip peripheral module request                         |
|                                                         | (SCIF: 8 sources, IIC3: 2 sources, ADC: 2 sources, MTU2: 5 sources, CMT: 2 sources)           |
| Bus modes                                               | Cycle-steal mode and burst mode                                                               |
| Channel priority                                        | Fixed mode and round-robin mode                                                               |
| Interrupt request                                       | An interrupt is requested to the CPU upon completion of half- or full-data transfer.          |
| External request detection                              | Detection of low or high level of the DREQ input, or rising or falling edge of the DREQ input |
| Transfer request acknowledge signal/transfer end signal | Selectable active levels of DACK and TEND signals                                             |

Note: For details on the DMAC, refer to section 9, Direct Memory Access Controller, of the SH7206 Group Hardware Manual.

REJ05B0664-0100 September 2005 Page 3 of 17



Figure 1 Schematic View of the DMAC

REJ05B0664-0100 September 2005 Page 4 of 17



#### 2.2 Procedure for Setting the MCU Modules

This section describes the initial setting procedure for data transfer from memory to the on-chip peripheral module by the DMAC in response to a transfer request form an on-chip peripheral module. Figure 2 shows an example flow of making initial settings of the DMAC. For details on the settings of individual registers, refer to the SH7206 Group Hardware Manual.



Figure 2 Example Flow for Initial Settings of the DMAC



# 2.3 Operation of Sample Program

In the sample program, channel 1 of the DMAC is activated in response to a transmit-FIFO-data-empty transfer request (on-chip peripheral module request) from the SCIF, and data are transferred from external memory to the transmit FIFO data register (SCFTDR) of the SCIF channel 0. The data written to the SCFTDR register is transmitted in UART mode.

Figure 3 illustrates the timing of the sample program operation.



Figure 3 Timing of Sample Program Operation

REJ05B0664-0100 September 2005 Page 6 of 17



# 2.4 Register Settings and Processing Sequence of Sample Program

In the sample program, character string data stored in external memory is transferred to the transmit FIFO data register (SCFTDR) of the SCIF channel 0 by DMA transfer. The data is then transmitted in UART mode.

The register settings of the sample program are shown in table 2, macro definitions used in the sample program is listed in table 3, and processing flow of the sample program is shown in figure 4.

Table 2 Register Settings in the Sample Program

| Register Name                              | Address    | Setting                                  | Description                                                                                       |
|--------------------------------------------|------------|------------------------------------------|---------------------------------------------------------------------------------------------------|
| Standby control register 2 (STBCR2)        | H'FFFE0018 | H'00                                     | MSTP8 = 0: The DMAC runs.                                                                         |
| DMA channel control register_1 (CHCR_1)    | H'FFFE101C | H'00000000                               | DE = 0: DMA transfer is disabled.                                                                 |
|                                            |            | H'00001800                               | TC = 1: Transfer once in response to each DMA request.                                            |
|                                            |            |                                          | RLD = 0: Reload function is disabled.                                                             |
|                                            |            |                                          | DM = B'00: Destination address is fixed.                                                          |
|                                            |            |                                          | SM = B'01: Source address is incremented.                                                         |
|                                            |            |                                          | RS = B'1000: Extension resource selector                                                          |
|                                            |            |                                          | TB = 0: Cycle-steal mode                                                                          |
|                                            |            |                                          | TS = B'00: Byte transfer                                                                          |
|                                            |            |                                          | IE = 0: Interrupt requests are disabled.                                                          |
|                                            |            | H'00001801                               | DE = 1: DMA transfer is enabled                                                                   |
| DMA source address register_1 (SAR_1)      | H'FFFE1010 | Address of character string data         | Transfer source start address: Start address of character strings stored in external memory.      |
| DMA destination address register_1 (DAR_1) | H'FFFE1014 | H'FFFE800C                               | Transfer destination start address: Address of the SCIF transmit FIFO data register_1 (SCFTDR_1). |
| DMA transfer count register_1 (DMATCR_1)   | H'FFFE1014 | Number of bytes in character string data | Transfer count: Number of bytes in the character string data                                      |
| DMA extension                              | H'FFFE1300 | H'0081                                   | MID = B'100000                                                                                    |
| resource selector<br>(DMARS0)              |            |                                          | RID = B'01: A transmit-FIFO-data-empty transfer request of SCIF_0 is specified.                   |
| DMA operation register (DMAOR)             | H'FFFE1200 | H'0001                                   | DME = 1: DMA transfer is enabled on all channels.                                                 |

Table 3 Macro Definitions Used in the Sample Program

| <b>Macro Definition</b> | Setting | Description                            |
|-------------------------|---------|----------------------------------------|
| DMA_SIZE_BYTE           | H'0000  | Byte transfer                          |
| DMA_SIZE_WORD           | H'0001  | Word transfer                          |
| DMA_SIZE_LONG           | H'0002  | Longword transfer                      |
| DMA_SIZE_LONGx4         | H'0003  | 16-byte transfer                       |
| DMA_INT_DISABLE         | H'0000  | DMA transfer end interrupt is not used |
| DMA_INT_ENABLE          | H'0010  | DMA transfer end interrupt is used     |

REJ05B0664-0100 September 2005 Page 7 of 17



Figure 4 Processing Flow of the Sample Program



# 3. Sample Program Listing

1. Sample Program Listing: main.c (1)

```
3
        System Name: SH7206 Sample Program
       File Name : main.c
       Version : 1.00.00
       Contents : DMAC sample program
 6
      Model : M3A-HS60
CPU : SH7206
 9
       Compiler : SHC9.0.00
10
11
       Note
                 : Sample program for transferring data from the SCIF by DMAC1
12
13
                   <Caution>
14
                   This sample program is for reference
15
                   and its operation is not guaranteed.
16
                   Customers should use this sample program for technical reference
17
                   in software development.
18
19
       COPYRIGHT (C) 2004 RENESAS TECHNOLOGY CORP. ALL RIGHTS RESERVED
20
       AND RENESAS SOLUTIONS CORP. ALL RIGHTS RESERVED
2.1
22
   * history : 2004.10.28 ver.1.00.00
   2.3
24
   #include <string.h>
25 #include "iodefine.h"
                                         /* iodefine.h is automatically created by HEW
2.6
   /* ==== Macro declarations ==== */
28 /* ==== DMAC setting ==== */
29 #define DMA SIZE BYTE 0x0000u
   #define DMA_SIZE_WORD 0x0001u
#define DMA_SIZE_LONG 0x0002u
30
31
32 #define DMA SIZE LONGx4 0x0003u
32 #define DMA_SIZE_LONGA:
33 #define DMA_INT_DISABLE 0x0000u
34 #define DMA_INT_ENABLE 0x0010u
35 #define DMA_INT (DMA_INT_ENABLE >> 4u)
36
37
    /* ==== Prototype declarations ==== */
38 void main(void);
39 void io init dmal (void *src, void *dst, size t size, unsigned int mode);
40 void io_dma1_stop (void);
41
   void io_init_scif0(int);
43 /* ==== Type declaration ==== */
44
    /* SCIF baud rate setting */
45 typedef struct {
     unsigned char scbrr;
46
47
       unsigned short scsmr;
48 } SH7206 BAUD SET;
   /* ---- Values for baud rate specification ---- */
50
51
   enum{
52
     CBR 1200,
5.3
       CBR 2400,
        CBR 4800,
       CBR 9600,
55
56
       CBR 19200,
       CBR_31250,
CBR_38400,
57
58
59
       CBR 57600,
       CBR_115200
60
61 };
```



#### 2. Sample Program Listing: main.c (2)

```
/* ==== Table of register setting values ==== */
64 static SH7206 BAUD SET scif baud[] = {
      {214, 1}, /* 1200bps (-0.07%) */
{106, 1}, /* 2400bps (0.39%) */
{214, 0}, /* 4800bps (-0.07%) */
{106, 0}, /* 9600bps (0.39%) */
{53, 0}, /* 19200bps (-0.54%) */
65
66
68
                      /* 19200bps (-0.54%) */
69
       { 53, 0},
                      /* 31250bps ( 0.00%) */
       { 32, 0},
70
                      /* 38400bps (-0.54%) */
71
       { 26, 0},
                      /* 57600bps (-0.54%) */
       { 17, 0},
                      /*115200bps (-0.54%) */
73
       { 8, 0}
74
    };
75
76
    /* Character string to be transmitted */
    const signed char data[] = "SCIF request DMAC Sample Software SH7206.\r\n";
78
    79
   * ID
80
81
    ^{\star} Module summary: Main function of the sample program (UART transmission with use of DMAC)
82
    * Include : #include <string.h>
83
    * Declaration : void main(void)
8.5
    *-----
    * Functional description:
88
                 : The character string data stored in external memory is DMA transferred
89
                  : to the SCIF transmit FIFO data register. The DMAC is activated
90
                  : by an SCIF transmit interrupt request.
91
    * Argument : None
92
93
    * Return value : None
    *-----
9.5
    98 void main(void)
99 {
        /* ==== Enabling DMAC initialization/transfer ===== */
100
101
       io init dmal(data, (void *)&SCIFO.SCFTDR.BYTE ,sizeof(data),
102
       DMA SIZE BYTE | DMA INT DISABLE);
                   /* On-chip peripheral module request (SCIF transmit interrupt request) */
103
104
                    /* Data transfer from external memory to SCIF transmit
                    /* FIFO data register
                                                                                   * /
105
106
        /* ==== Initialization of SCIF0/enabling transmission ==== */
107
       io_init_scif0(CBR 115200);
108
109
                    /* Communication mode: UART mode
                    /* Bit rate: 115.2 kbps
110
111
                    /* TXI interrupt is generated when data in transmit FIFO is one byte
112
113
        /* ==== Disabling DMA transfer ==== */
       io dmal stop();
114
115
116
       while(1){
         /* End of program */
117
118
119
120 }
```

#### 3. Sample Program Listing: main.c (3)

```
121
122
    * ID
    * Module summary: Initial settings for DMA transfer
123
124
    * Include : #include "iodefine.h"
126
127
    * Declaration : io init dmal(void *src, void *dst, size t size, int mode)
    *-----
128
    * Functional description:
129
                 : Transfers 'size'-byte data from source address 'src' to destination
130
                  : address 'dst' by the DMAC. The transfer is triggered by a request from
131
                  : SCIFO. Transfer size and use of interrupt are specified in 'mode'.
132
    *-----
133
    * Arguments : void *src : Source address

* : void *dst : Destination ad
134
                  135
136
                  : unsigned int mode : Transfer mode; following modes are specified by
137
                                      logical OR.
138
139
                 :
:
                          DMA SIZE BYTE(0x0000) Byte transfer
                          DMA_SIZE_WORD(0x0001) Word transfer
DMA_SIZE_LONG(0x0002) Longword transfer
140
141
                          DMA SIZE LONGx4(0x0003) 16-byte transfer
142
                  :
                      DMA_INT_DISABLE(0x0000) DMA transfer-end interrupt is not used.

DMA_INT_ENABLE(0x0010) DMA transfer-end interrupt is used.
143
144
145
    * Return valu : None
146
147
    ^{\star} Note \, : Correct operation cannot be guaranteed if the transfer data size
148
149
                   : does not agree with alignment of source and destination addresses.
150
                  : When an interrupt is used, the corresponding interrupt routine must be
151
    prepared.
    152
    void io init dmal(void *src, void *dst, size t size, unsigned int mode)
153
154
155
       unsigned int ts:
156
       unsigned long ie;
157
158
       ts = mode \& 0x3u;
159
       ie = (mode & 0x00f0u ) >> 4u;
160
161
        /* ==== Setting standby control register 2 (STBCR2) ==== */
162
       CPG.STBCR2.BIT.MSTP8 = 0x0;
                                            /* Cancel DMAC module stop mode
163
        /* ---- Setting DMA channel control register ---- */
                                             /* Disable DMA transfer
165
       DMAC.CHCR1.BIT.DE = Oul;
166
167
        /* ---- Setting DMA source address register ---- */
168
       DMAC.SAR1.LONG = (unsigned long)src;
169
        /\star ---- Setting DMA reload source address register ---- \star/
170
171
        DMAC.RSAR1.LONG = (unsigned long) src;
172
        /\star ---- Setting DMA destination address register ---- \star/
173
174
        DMAC.DAR1.LONG = (unsigned long)dst;
175
176
        /* ---- Setting DMA reload destination address register ---- */
177
        DMAC.RDAR1.LONG = (unsigned long)dst;
```



#### 5. Sample Program Listing: main.c (4)

```
178
        /* ---- Setting DMA transfer count register ---- */
179
        /* ---- Setting DMA reload transfer count register ---- */
180
181
        if(ts != DMA SIZE LONGx4) {
            DMAC.DMATCR1.LONG = size >> ts;
                                             /* Set the number of transfers
182
            DMAC.RDMATCR1.LONG = size >> ts;
183
184
185
        else{
186
            DMAC.DMATCR1.LONG = size >> 4u;
                                              /* Set the number of transfers (1/16)
            DMAC.RDMATCR1.LONG = size >> 4u;
187
188
189
190
        /* ---- Setting DMA channel control register ---- */
191
        DMAC.CHCR1.LONG = 0x00001800ul | (mode << 3u) | (ie << 2u) ;
192
         /*
               bit31 : TC DMATCR transfer: 0----- Transfer once
193
194
               bit30-29: reserve 0
               bit28 : RLD OFF : 0----- Disable reload function
195
196
               bit27-24: reserve 0
               bit23 : DO over run0 : 0----- Unused
197
198
               bit22
                       : TL TEND low active : 0----- Unused
              bit21-20: reserve 0
199
               bit19 : HE :0----- Unused
200
201
               bit18
                      : HIE :0----- Unused
               bit17 : AM :0----- Unused
202
203
               bit16 : AL :0----- Unused
               bit15-14: DM1 :0 DM0:0----- Fix destination address
               bit13-12: SM1 :0 SM0:1----- Increment source address
205
206
              bit11-8 : RS : auto request : B'1000--- DMA extension resource selector
               bit7 : DL : DREQ level : 0 ----- Unused
207
208
               bit6
                      : DS : DREQ select : 0 Low level- Unused
               bit5 : TB :cycle :0----- Cycle steal mode
209
               bit4-3 : TS : transfer size: B'00----- Byte transfer
210
               bit2 : IE : interrupt enable: 0----- Disable interrupt bit1 : TE : transfer end: 0
211
212
213
               bit0 : DE : DMA enable bit: 0---- Disable DMA transfer
214
       /* ---- Setting DMA extension resource selector 0 ---- */
215
216
      DMAC.DMARSO.BIT.CH1MID = 0x20;
                                            /* MID = SCIF0 */
       DMAC.DMARS0.BIT.CH1RID = 0 \times 01;
                                               /* RID = Transmission
217
218
219
       /* ---- Setting DMA operation register ---- */
220
       DMAC.DMAOR.WORD &= 0xfff9u;
                                               /* Clear AE, NMIF bits
                                                                                      * /
221
222
       if(DMAC.DMAOR.BIT.DME == 0ul){
                                              /* Enable DMA transfer on all channels
223
           DMAC.DMAOR.BIT.DME = 1ul;
224
225
226
        /* ---- DMA transfer execution ---- */
                                                /* Enable DMA transfer
        DMAC.CHCR1.BIT.DE = 1ul;
                                                                                      * /
227
228
229 }
230
```

# 5. Sample Program Listing: main.c (5)

```
231
  * ID
232
  * Module summary: Stopping DMAC
233
 *-----
234
 * Include : #include "iodefine.h"
236
237
  * Declaration : void io dma1 stop(void)
238 *-----
240
  * Argument : None
241
242 *-----
  * Return value : None
243
244
  *-----
245
  246
247
  void io dma1 stop(void)
248 {
249
   /* Detecting end of transfer */
250
   while(DMAC.CHCR1.BIT.TE == Oul){
                                         */
251
                     /* Wait until the TE bit is set
252
253
254
    /* ---- Stopping DMA transfer ---- */
255
   DMAC.CHCR1.BIT.DE = Oul;
                     /* Disable DMA1 transfer
256 }
257
```

#### 6. Sample Program Listing: main.c (6)

```
259 * ID
260 * Module summary: Initial setting of SCIFO as an asynchronous (UART) transmit module
261 *-----
262 * Include : #include "iodefine.h"
263 *-----
264 * Declaration : void io init scif0(int bps)
265 *-----
266 * Functional description: Initializes SCIF0
        : Asynchronous (UART)/ 8 \ \mathrm{bits} / No parity/ 1 \ \mathrm{stop} bit/ RTS/CTS disabled
268 *
                : Baud rate is specified by argument bps
269 *-----
270 * Argument : int bps : Value for baud rate specification
271 *-----
272 * Return value : None
273 *-----
274 * Notes : The baud rate setting values given in this program are those when 275 * : the peripheral module clock (Pf) frequency is 33 MHz. If a different 276 * : clock is used, the baud rate setting values must be changed.
278 void io init scif0(int bps)
     /* ==== Power-down mode cancellation ==== */
/* ---- Setting Standby control register 4 (STBCR4) ---- */
280
281
282
      CPG.STBCR4.BIT.MSTP47 = 0;
                                           /* Start clock supply to SCIF0
283
284
      /* ==== SCIFO initialization ==== */
     /* ---- Setting serial control register (SCSCRi) ---- */
285
286
      SCIF0.SCSCR.WORD = 0x0000;
                                          /* Stop transmission/reception by SCIF0
287
      /* ---- Setting FIFO control register (SCFCRi) ---- */
288
289
      SCIF0.SCFCR.BIT.TFRST = 1;
                                           /* Reset transmit FIFO
290
291
       /* ---- Setting serial control register (SCSCRi) ---- */
     SCIF0.SCSCR.BIT.CKE = 0x0;
                                           /* B'00: Internal clock
292
293
294
      /* ---- Setting serial mode register (SCSMRi) ---- */
      SCIF0.SCSMR.WORD = scif baud[bps].scsmr;
295
296
                                  /* Communication mode 0: Asynchronous mode
                                  /* Character length 0: 8-bit data
/* Parity enable 0: Disable addition and check
297
                                  /* Parity enable 0: Disable addition and che /* Parity mode 0: Even parity
298
299
                                  /* Stop bit length 0: 1 stop bit
300
301
                                  /* Clock select : Table value
302
303
      /* ---- Setting bit rate register (SCBRRi) ---- */
304
      SCIF0.SCBRR.BYTE = scif baud[bps].scbrr;
305
      /* ---- Setting FIFO control register (SCFCRi) ---- */
      SCIFO.SCFCR.WORD = 0x0030; /* Transmit FIFO data count trigger:
307
                                 /* Number of data bytes = 0
/* Modem control enable : Disabled
308
309
                                 /* Transmit FIFO data register reset : Disabled
310
311
                                 /* Loopback test
312
     /* ==== Setting pin function controller (PFC) ==== */
313
314
      PORT.PACRL1.BIT.PA1MD = 1; /* Enable TxD0 pin (PACRL1)
315
316
      /* ---- Setting serial control register (SCSCRi) ---- */
     SCIFO.SCSCR.BIT.TIE = 1; /* Enable SCIFO transmit interrupt SCIFO.SCSCR.BIT.TE = 1; /* Enable SCIFO transmission
317
318
      SCIFO.SCSCR.BIT.TE = 1;
319
320 }
321 /* End of File */
```



#### 4. Reference Documents

- SH-2A SH2A-FPU Software Manual (Rev.3.00) (Download the latest edition from the website of Renesas Technology Corp.)
- SH7206 Group Hardware Manual (Rev. 1.00) (Download the latest edition from the website of Renesas Technology Corp.)

#### 5. Website

 Website of Renesas Technology Corp. http://www.renesas.com/

# Transferring Data to an On-Chip Module Using DMAC

# **Revision Record**

| Rev. | Date      | Page | Summary              |
|------|-----------|------|----------------------|
| 1.00 | Sep.05.05 | _    | First edition issued |
|      |           |      |                      |
|      |           |      |                      |
|      |           |      |                      |
|      |           |      |                      |



#### Keep safety first in your circuit designs!

 Renesas Technology Corp. puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage.
 Remember to give due consideration to safety when making your circuit designs, with appropriate measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of nonflammable material or (iii) prevention against any malfunction or mishap.

# Notes regarding these materials

- 1. These materials are intended as a reference to assist our customers in the selection of the Renesas Technology Corp. product best suited to the customer's application; they do not convey any license under any intellectual property rights, or any other rights, belonging to Renesas Technology Corp. or a third party.
- 2. Renesas Technology Corp. assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts, programs, algorithms, or circuit application examples contained in these materials.
- 3. All information contained in these materials, including product data, diagrams, charts, programs and algorithms represents information on products at the time of publication of these materials, and are subject to change by Renesas Technology Corp. without notice due to product improvements or other reasons. It is therefore recommended that customers contact Renesas Technology Corp. or an authorized Renesas Technology Corp. product distributor for the latest product information before purchasing a product listed herein.
  - The information described here may contain technical inaccuracies or typographical errors. Renesas Technology Corp. assumes no responsibility for any damage, liability, or other loss rising from these inaccuracies or errors.
  - Please also pay attention to information published by Renesas Technology Corp. by various means, including the Renesas Technology Corp. Semiconductor home page (http://www.renesas.com).
- 4. When using any or all of the information contained in these materials, including product data, diagrams, charts, programs, and algorithms, please be sure to evaluate all information as a total system before making a final decision on the applicability of the information and products. Renesas Technology Corp. assumes no responsibility for any damage, liability or other loss resulting from the information contained herein.
- 5. Renesas Technology Corp. semiconductors are not designed or manufactured for use in a device or system that is used under circumstances in which human life is potentially at stake. Please contact Renesas Technology Corp. or an authorized Renesas Technology Corp. product distributor when considering the use of a product contained herein for any specific purposes, such as apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea repeater use.
- 6. The prior written approval of Renesas Technology Corp. is necessary to reprint or reproduce in whole or in part these materials.
- 7. If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the approved destination.
  - Any diversion or reexport contrary to the export control laws and regulations of Japan and/or the country of destination is prohibited.
- 8. Please contact Renesas Technology Corp. for further details on these materials or the products contained therein.

REJ05B0664-0100 September 2005 Page 17 of 17