# **S3FN41F**

## **External Interrupt**

Revision 1.00 August 2012

# **Application Note**

SAMSUNG ELECTRONICS RESERVES THE RIGHT TO CHANGE PRODUCTS, INFORMATION AND SPECIFICATIONS WITHOUT NOTICE.

Products and specifications discussed herein are for reference purposes only, All information discussed herein is provided on an "AS IS" basis, without warranties of any kind.

This document and all information discussed herein remain the sole and exclusive property of Samsung Electronics. No license of any patent, copyright, mask work, trademark or any other intellectual property right is granted by one party to the other party under this document, by implication, estoppel or otherwise.

Samsung products are not intended for use in life support, critical care, medical, safety equipment, or similar applications where product failure could result in loss of life or personal or physical harm, or any military or defense application, or any governmental procurement to which special terms or provisions may apply.

For updates or additional information about Samsung products, contact your nearest Samsung office.

All brand names, trademarks and registered trademarks belong to their respective owners.

© 2012 Samsung Electronics Co., Ltd. All rights reserved.



## **Important Notice**

Samsung Electronics Co. Ltd. ("Samsung") reserves the right to make changes to the information in this publication at any time without prior notice. All information provided is for reference purpose only. Samsung assumes no responsibility for possible errors or omissions, or for any consequences resulting from the use of the information contained herein.

This publication on its own does not convey any license, either express or implied, relating to any Samsung and/or third-party products, under the intellectual property rights of Samsung and/or any third parties.

Samsung makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does Samsung assume any liability arising out of the application or use of any product or circuit and specifically disclaims any and all liability, including without limitation any consequential or incidental damages.

Customers are responsible for their own products and applications. "Typical" parameters can and do vary in different applications. All operating parameters, including "Typicals" must be validated for each customer application by the customer's technical experts.

Samsung products are not designed, intended, or authorized for use in applications intended to support or sustain life, or for any other application in which the failure of the Samsung product could reasonably be expected to create a situation where personal injury or death may occur. Customers acknowledge and agree that they are solely responsible to meet all other legal and regulatory requirements regarding their applications using Samsung products notwithstanding

Copyright © 2012 Samsung Electronics Co., Ltd.

Samsung Electronics Co., Ltd. San #24 Nongseo-Dong, Giheung-Gu Yongin-City, Gyeonggi-Do, Korea 446-711

Contact Us: como.jin@samsung.com

Home Page: <a href="http://www.samsungsemi.com">http://www.samsungsemi.com</a>

any information provided in this publication. Customer shall indemnify and hold Samsung and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, expenses, and reasonable attorney fees arising out of, either directly or indirectly, any claim (including but not limited to personal injury or death) that may be associated with such unintended, unauthorized and/or illegal use.

WARNING No part of this publication may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, electric or mechanical, by photocopying, recording, or otherwise, without the prior written consent of Samsung. This publication is intended for use by designated recipients only. This publication contains confidential information (including trade secrets) of Samsung protected by Competition Law, Trade Secrets Protection Act and other related laws, and therefore may not be, in part or in whole, directly or indirectly publicized, distributed, photocopied or used (including in a posting on the Internet where unspecified access is possible) by any unauthorized third party. Samsung reserves its right to take any and all measures both in equity and law available to it and claim full damages against any party that misappropriates Samsung's trade secrets and/or confidential information.

警告 本文件仅向经韩国三星电子株式会社授权的人员提供,其内容含有商业秘密保护相关法规规定并受其保护的三星电子株式会社商业秘密,任何直接或间接非法向第三人披露、传播、复制或允许第三人使用该文件全部或部分内容的行为(包括在互联网等公开媒介刊登该商业秘密而可能导致不特定第三人获取相关信息的行为)皆为法律严格禁止。此等违法行为一经发现,三星电子株式会社有权根据相关法规对其采取法律措施,包括但不限于提出损害赔偿请求。



## **Trademarks**

All brand names, trademarks and registered trademarks belong to their respective owners.

- Exynos, Exynos4210, FlexOneNAND, and OneNAND are trademarks of Samsung Electronics.
- ARM, Jazelle, TrustZone, and Thumb are registered trademarks of ARM Limited.
- Cortex, ETM, ETB, Coresight, ISA, and Neon are trademarks of ARM Limited.
- Java is a trademark of Sun Microsystems, Inc.
- SD is a registered trademark of Toshiba Corporation.
- MMC and eMMC are trademarks of MultiMediaCard Association.
- JTAG is a registered trademark of JTAG Technologies, Inc.
- Synopsys is a registered trademark of Synopsys, Inc.
- I2S is a trademark of Phillips Electronics.
- I2C is a trademark of Phillips Semiconductor Corp.
- MIPI and Slimbus are registered trademarks of the Mobile Industry Processor Interface (MIPI) Alliance.

All other trademarks used in this publication are the property of their respective owners.



## **Chip Handling Guide**

#### **Precaution against Electrostatic Discharge**

When using semiconductor devices, ensure that the environment is protected against static electricity:

- 1. Wear antistatic clothes and use earth band.
- 2. All objects that are in direct contact with devices must be made up of materials that do not produce static electricity.
- 3. Ensure that the equipment and work table are earthed.
- 4. Use ionizer to remove electron charge.

#### Contamination

Do not use semiconductor products in an environment exposed to dust or dirt adhesion.

#### Temperature/Humidity

Semiconductor devices are sensitive to:

- Environment
- Temperature
- Humidity

High temperature or humidity deteriorates the characteristics of semiconductor devices. Therefore, do not store or use semiconductor devices in such conditions.

#### **Mechanical Shock**

Do not to apply excessive mechanical shock or force on semiconductor devices.

## Chemical

Do not expose semiconductor devices to chemicals because exposure to chemicals leads to reactions that deteriorate the characteristics of the devices.

## **Light Protection**

In non- Epoxy Molding Compound (EMC) package, do not expose semiconductor IC to bright light. Exposure to bright light causes malfunctioning of the devices. However, a few special products that utilize light or with security functions are exempted from this guide.

## Radioactive, Cosmic and X-ray

Radioactive substances, cosmic ray, or X-ray may influence semiconductor devices. These substances or rays may cause a soft error during a device operation. Therefore, ensure to shield the semiconductor devices under environment that may be exposed to radioactive substances, cosmic ray, or X-ray.

## **EMS (Electromagnetic Susceptibility)**

Strong electromagnetic wave or magnetic field may affect the characteristic of semiconductor devices during the operation under insufficient PCB circuit design for Electromagnetic Susceptibility (EMS).



## **Revision History**

| Revision No. | Date            | Description | Author(s)    |
|--------------|-----------------|-------------|--------------|
| 1.00         | August 08, 2012 | Creation    | Younghee Jin |



## **Table of Contents**

| 1 INTRODUCTION                       | 10 |
|--------------------------------------|----|
| 1.1 Overview                         | 10 |
| 1.2 General Description              | 10 |
| 1.3 Reference                        | 10 |
| 2 EXTERNAL INTERRUPT                 | 11 |
| 2.1 EXI Pin Configuration            | 11 |
| 2.2 External Interrupt Mapping       | 12 |
| 2.3 External Interrupt Enable        | 15 |
| 2.4 External Interrupt Handler       | 17 |
| 2.5 External Interrupt Configuration | 18 |
| 3 EXAMPLE                            | 20 |
| 3.1 Hardware                         | 20 |
| 2.2 Coffware                         | 22 |



# **List of Figures**

| Figure<br>Number | Title                                     | Page<br>Number |
|------------------|-------------------------------------------|----------------|
| - Tunibei        |                                           | Number         |
| Figure 1         | Mapping between WSRCx (WIx) and EXIn      | 14             |
| Figure 2         | WIO Interrupt and WSIO Vector             | 15             |
| Figure 3         | WIx Interrupt and WSIx Vector             | 16             |
| Figure 4         | Flow Chart for External Interrupt         |                |
| Figure 5         | Block Diagram of S3FN41F Evaluation Board | 20             |
| Figure 6         | Board Condition for Example               | 21             |
|                  | The Execution Message Through UART        |                |



## **List of Tables**

| Table   | Title                                                 | Page   |
|---------|-------------------------------------------------------|--------|
| Number  |                                                       | Number |
| Table 1 | External Interrupt Pins                               | 11     |
| Table 2 | CM_WCR0 (from WSRC0 to WSRC3)                         | 12     |
|         | CM_WCR1 (from WSRC4 to WSRC7)                         |        |
| Table 4 | External Interrupt/Wake-Up Sources and Pin Assignment | 13     |



# **List of Examples**

| Example<br>Number | Title                                              | Page<br>Number |
|-------------------|----------------------------------------------------|----------------|
| Example 1         | External Interrupt Handler                         | 17             |
| Example 2         | I/O Configuration Function                         | 22             |
|                   | EXI10 (WI0) and EXI0 (WI1) Interrupt Configuration |                |



1

## Introduction

## 1.1 Overview

This document describes about the external interrupt of S3FN41F. It includes the configuration to use the external interrupt and the example.

## 1.2 General Description

S3FN41F has 16 external interrupt pins (EXI0 to EXI15). The maximum number of external interrupt to enable at the same time is eight.

- 16 external interrupt pins (EXI0 to EXI15)
- Selectable external interrupts (up-to eight)
- Support falling/rising edge
- Interrupt enable/disable control

The external interrupt can be used to execute any specific operation or wakeup from low power mode when the external event is detected. The signal to trigger external event should be asserted through EXI (External Interrupt Pin). Refer to chapter 26.5 External Interrupt Input Characteristics in S3FN41F user's manual for the detailed condition of external event signal.

## 1.3 Reference

You can download the related document and example code from Samsung web site. http://www.samsung.com/global/business/semiconductor/product/microcontroller/detail?productId=6784&iaId=804

- S3FN41F User's Manual
- S3FN41F Board Manual
- External Interrupt Example (Software)



# 2 External Interrupt

## 2.1 EXI Pin Configuration

As you can see, a pin can be defined as one function pin among maximum 4 functions. If you want to use the external interrupt, input pins for external event signal should be configured as EXI function by IOCONF register before enabling each external interrupt. You can set the target function, external interrupt, using the mode registers (IOCONF\_MLR0/1, IOCONF\_MHR0/1).

- EXI0 pin configuration
   IOCONF\_MLR0 ← 01'b << 30 (Write 01'b into IO0\_15\_FSEL field to assign as F1 function)</li>
- EXI11 pin configuration
   IOCONF\_MLR0 ← 10'b << 12 (Write 10'b into IO0\_6\_FSEL field to assign as F2 function)</li>
- EXI8 pin configuration IOCONF\_MHR1 ← 11'b << 6 (Write 11'b into IO1\_19\_FSEL field to assign as F3 function)

IO Group 0/1 **Function Number** F0 F1 F2 F3 01'b 11'b Pin Number IO0x.y FSEL[1:0] 00'b 10'b IO0.6\_FSEL[1:0] P0\_6 **PWMOFF** EXI11 **ADTRG** 13 P0 7 VLCD1 18 IO0.7\_FSEL[1:0] SSPRX0 EXI12 19 IO0.8 FSEL[1:0] P0 8 SSPTX0 VLCD2 EXI13 22 IO0.11\_FSEL[1:0] TPWM2 COM<sub>0</sub> EXI14 P0\_11 23 IO0.12 FSEL[1:0] P0 12 TCAP2 COM<sub>1</sub> EXI15 24 IO0.13\_FSEL[1:0] TCLK2 COM<sub>2</sub> TPWM2 P0\_13 25 IO0.14\_FSEL[1:0] P0 14 COP COM3 TPWM3 COM4 SEG0 PWM0 26 IO0.15\_FSEL[1:0] P0 15 EXI0 27 IO0.16\_FSEL[1:0] P0 16 EXI1 COM5 SEG1 PWM1 EXI2 TCLK5 35 IO0.24\_FSEL[1:0] P0\_24 SEG9 TCLK6 EXI3 38 IO0.27\_FSEL[1:0] P0 27 SEG12 39 IO0.28\_FSEL[1:0] P0\_28 TCAP6 SEG13 EXI4 SEG18 53 P1\_1 **USARTRX0** EXI5 IO1.1\_FSEL[1:0] IO1.2\_FSEL[1:0] 54 P1\_2 **USARTTX0** SEG19 EXI6 70 AIN9 EXI7 IO1.18\_FSEL[1:0] P1\_18 COP8 71 AIN10 COP4 EXI8 IO1.19\_FSEL[1:0] P1\_19 72 IO1.20\_FSEL[1:0] P1\_20 EXI9 OP0 P TPWM7 74 IO1.22\_FSEL[1:0] EXI10 OP0\_O TPWM1 P1\_22

Table 1 External Interrupt Pins

## 2.2 External Interrupt Mapping

If you choose which external interrupt you use, you should register target external interrupt to CM\_WCR0 or CM\_WCR1 (Wakeup Control Register 0 or 1). You can register up-to eight sources from WSRC0 to WSRC7.

Table 2 CM\_WCR0 (from WSRC0 to WSRC3)

| 31   | 30    | 29   | 28 | 27 | 26    | 25 | 24 | 23   | 22    | 21   | 20 | 19 | 18    | 17 | 16 | 15   | 14    | 13   | 12 | 11 | 10    | 9 | 8 | 7    | 6     | 5    | 4 | 3 | 2     | 1 | 0 |
|------|-------|------|----|----|-------|----|----|------|-------|------|----|----|-------|----|----|------|-------|------|----|----|-------|---|---|------|-------|------|---|---|-------|---|---|
| WEN3 | EDGE3 | RSVD |    |    | WSRC3 |    |    | WEN2 | EDGE2 | RSVD |    |    | WSRC2 |    |    | WEN1 | EDGE1 | RSVD |    |    | WSRC1 |   |   | WENO | EDGE0 | RSVD |   |   | WSRCO |   |   |

Table 3 CM\_WCR1 (from WSRC4 to WSRC7)

| 31   | 30    | 29   | 28 | 27 | 26    | 25 | 24 | 23   | 22    | 21   | 20 | 19 | 18    | 17 | 16 | 15   | 14    | 13   | 12 | 11 | 10    | 9 | 8 | 7    | 6     | 5    | 4 | 3 | 2     | 1 | 0 |
|------|-------|------|----|----|-------|----|----|------|-------|------|----|----|-------|----|----|------|-------|------|----|----|-------|---|---|------|-------|------|---|---|-------|---|---|
| WEN7 | EDGE7 | RSVD |    |    | WSRC7 |    |    | 9NEM | EDGE6 | RSVD |    |    | WSRC6 |    |    | MEN5 | EDGE5 | RSVD |    |    | WSRC5 |   |   | WEN4 | EDGE4 | RSVD |   |   | WSRC4 |   |   |

To enroll target external interrupt, you should fill out three fields in CM\_WCR0/1 (Wakeup Control Register).

| Name  | Description                                                                                                                            |  |  |  |  |  |  |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| WSRCx | External Interrupt/Wake-Up Source Selection Field                                                                                      |  |  |  |  |  |  |  |  |
| WSRCX | Refer to the below table.                                                                                                              |  |  |  |  |  |  |  |  |
|       | Edge Type Selection Bit                                                                                                                |  |  |  |  |  |  |  |  |
| EDGEx | 0 = Rising edge trigger selected (for external event or interrupt) 1 = Falling edge trigger selected (for external event or interrupt) |  |  |  |  |  |  |  |  |
|       | External Interrupt/Wake-Up Enable/Disable Control Bit                                                                                  |  |  |  |  |  |  |  |  |
| WENx  | 0 = The edge trigger selected by EDGEx bit disable 1 = The edge trigger selected by EDGEx bit enable                                   |  |  |  |  |  |  |  |  |

**NOTE:** x = 0, 1, 2, 3, 4, 5, 6, or 7



WSRCx field should have one among 16 external interrupts. The corresponding value is included in the below table.

- When mapping EXI0 onto WSRC7 WSRC7[4:0] of CM\_WCR1 ← 00000'b (Write 00000'b into WSRC7 field )
- When mapping EXI15 onto WSRC0 WSRC0[4:0] of CM\_WCR0 ← 01111'b (Write 01111'b into WSRC0 filed)
- When mapping EXI8 onto WSRC4 WSRC4[4:0] of CM\_WCR1 ← 01000'b (Write 01000'b into WSRC4 field)

Table 4 External Interrupt/Wake-Up Sources and Pin Assignment

| WSRCx[4:0] | External Interrupt | Pin Information          |
|------------|--------------------|--------------------------|
| 00000      | EXI0               | P0.15/EXI0/COM_SEG0/PWM0 |
| 00001      | EXI1               | P0.16/EXI1/COM_SEG1/PWM1 |
| 00010      | EXI2               | P0.24/TCLK5/SEG9/EXI2    |
| 00011      | EXI3               | P0.27/TCLK6/SEG12/EXI3   |
| 00100      | EXI4               | P0.28/TCAP6/SEG13/EXI4   |
| 00101      | EXI5               | P1.1/USARTRX0/SEG18/EXI5 |
| 00110      | EXI6               | P1.2/USARTTX0/SEG19/EXI6 |
| 00111      | EXI7               | P1.18/AIN9/–/EXI7        |
| 01000      | EXI8               | P1.19/AIN10/–/EXI8       |
| 01001      | EXI9               | P1.20/EXI9/OP0_P/TPWM7   |
| 01010      | EXI10              | P1.22/EXI10/OP0_O/TPWM1  |
| 01011      | EXI11              | P0.6/PWMOFF/EXI11/ADTRG  |
| 01100      | EXI12              | P0.7/MISO0/VLCD1/EXI12   |
| 01101      | EXI13              | P0.8/MOSI0/VLCD2/EXI13   |
| 01110      | EXI14              | P0.11/TPWM2/COM0/EXI14   |
| 01111      | EXI15              | P0.12/TCAP2/COM1/EXI15   |



The external interrupt number (EXIn) doesn't have relation with the wakeup source number (WSRCx). WSRC0 can have something among 16 external interrupts (from EXI0 to EXI15). And the interrupt of WSRCx becomes WIx. In other words, the interrupt of WSRC0 (WSRC1/WSRC2/WSRC3/WSRC4/WSRC5/WSRC6/WSRC7) is WI0 (WI1/WI2/WI3/WI4/WI5/WI6/WI7).



Figure 1 Mapping between WSRCx (WIx) and EXIn

## 2.3 External Interrupt Enable

If the mapping between EXIn and WSCRx is completed, let's think WIx as the same name of EXIn. WIx is one-to-on correspondent with WSCRx.

- EXIn: n = 0, 1, 2, ..., 14, or 15
- WSCRx, WIx: x = 0, 1, 2, 3, 4, 5, 6, or 7

You can enable or disable WIx interrupt (EXIn interrupt) using CM\_WIMSCR register. To use the interrupt, also you should enable the interrupt vector for the corresponding interrupt source. WI0 interrupt has the separated vector (WSI0, the IRQ number is 6.) Other WIx interrupts have the common shared vector (WSIx, the IRQ number is 31). So when you enable WI0 interrupt, WSI0 (IRQ6) should be enabled. Other WIx interrupts should be enabled with WSIx (IRQ31) interrupt vector together.

See the below figures. That shows the relation between registers for the control interrupt and each interrupt vector control register.

- WI0 Interrupt → WSI0 Interrupt Vector (IRQ6)
- WI1/2/3/4/5/6/7 Interrupt → WSIx Interrupt Vector (IRQ31)



Figure 2 WI0 Interrupt and WSI0 Vector





Figure 3 WIx Interrupt and WSIx Vector

## 2.4 External Interrupt Handler

In external interrupt handler, you should clear the pending interrupt as like other interrupt handler. It can be done by writing "1" into each interrupt bit of CM\_WICR register. Also additional operation can be added by your system application. The below table is one of the simple example.

## **Example 1** External Interrupt Handler

```
void CSP WSIOHandler(void)
      CSP CM SET WICR (CM0, CM WIO); /* Clear WIO interrupt pending bit */
void CSP_WSIxHandler(void)
      isr flag = CSP CM GET WMISR (CM0);
      if((isr flag & CM WI1) == CM WI1)
                                              CSP CM SET WICR(CM0, CM WI1);
                                           CSP_CM_SET_WICR(CM0, CM_WI2);
CSP_CM_SET_WICR(CM0, CM_WI3);
      if((isr_flag & CM_WI2) == CM_WI2)
      if((isr_flag & CM_WI3) == CM_WI3)
      if((isr flag & CM WI4) == CM WI4)
                                            CSP CM SET WICR(CM0, CM WI4);
      if((isr flag & CM WI5) == CM WI5)
                                             CSP CM SET WICR(CM0, CM WI5);
      if((isr flag & CM WI6) == CM WI6)
                                              CSP CM SET WICR(CM0, CM WI6);
      if((isr flag & CM WI7) == CM WI7)
                                              CSP CM SET WICR(CM0, CM WI7);
```



## 2.5 External Interrupt Configuration

The below figure includes the register information to control when you want to use the external interrupt. And it shows the overall flow from the configuration to pending clear.



Figure 4 Flow Chart for External Interrupt



You can find the detailed description about each register from S3FN41F user's manual and ARM's manual.

- Refer to chapter 14. I/O Configuration of S3FN41F user's manual
  - IOCONF\_MLR0/1
  - IOCONF\_MHR0/1
- Refer to chapter 6. Clock & Power Manager of S3FN41F user's manual
  - CM\_WCR0/1
  - CM\_WIMSCR
  - CM\_WICR
  - CM\_WMISR
  - CM\_WRISR
- Refer to chapter ARMv6-M Architecture Reference Manual
  - NVIC\_ISER



# 3 Example

This section provides the external interrupt example using the S3FN41F evaluation board.

## 3.1 Hardware

This example needs POWER, H/L Gen, LED, and Wakeup Source parts basically. Also if you want to watch the display through UART, include USART2 part.



Figure 5 Block Diagram of S3FN41F Evaluation Board



Each part should be controlled according to the following guide.

- H/L Gen part
  - Connect between WAKEUP and L in J62
- Wakeup Source part
  - Connect between WAKEUP and EXI0 in J61
  - Connect between WAKEUP and EXI10 in J61
- 4 x LED part
  - Connect J63 jumpers
- USART2
  - Connect between P1.8\_RX and UART in J53
  - Connect between P1.9\_TX and UART in J54
  - Connect to PC comport through P3 (Baud-rate 19200bps)



Figure 6 Board Condition for Example



## 3.2 Software

This example uses EXI0 and EXI10 pin. EXI10 interrupt is remapped to WI0 interrupt by writing EXI10 value to WSRC0. EXI0 interrupt is remapped to WI1 interrupt by writing EXI0 value to WSRC1. Simply it can be described as like this.

- P1.22 → EXI10 → WSRC0 → WI0 → WSI0
- P0.15 → EXI0 → WSRC1 → WI1 → WSIx

## **Example 2** I/O Configuration Function

```
void CSP_IOFunctionConfigure(eGROUPy iogroup,U8_T port, U8_T function)
      U32 T temp = 0;
      U8_T new_port =0;
      if(iogroup == GROUP0 )
              if(port <16)
              {
                       temp = CSP IOCONF GET MLR0(IOCONF0) & (~(IOCONF FSEL MASK <<(2*port)));
                       CSP_IOCONF_SET_MLR0(IOCONF0, temp|(function << (2*port )));</pre>
              }
              else
               {
                       new port= port-16;
                       temp = CSP_IOCONF_GET_MHR0(IOCONF0) & (~(IOCONF_FSEL_MASK <<(2*new_port)));</pre>
                       CSP_IOCONF_SET_MHR0(IOCONF0, temp|(function << (2* new_port )));</pre>
      if(iogroup == GROUP1 )
              if(port <16)
              {
                       temp = CSP IOCONF GET MLR1(IOCONF0) & (~(IOCONF FSEL MASK <<(2*port)));
                       CSP_IOCONF_SET_MLR1(IOCONF0, temp|(function << (2*port )));</pre>
              }
              else
               {
                       new port= port-16;
                       \texttt{temp} = \texttt{CSP IOCONF GET MHR1(IOCONF0)} \& ( (\texttt{OCONF FSEL MASK} << (2*\texttt{new port)}));
                       CSP IOCONF SET MHR1(IOCONF0, temp|(function << (2* new port )));
              }
      }
```



#### Example 3 EXI10 (WI0) and EXI0 (WI1) Interrupt Configuration

```
/* External interrupt configuration - EXI10 */
CSP IOFunctionConfigure(GROUP1, 22, IOCONF F1);
                                                      //P1.22 is defined as EXI10 (Function 1)
source0 = CM WSRC0(CM WSRC EXIO)|CM EDGE0|CM WEN0;
                                                      //WSRC0 setting value
CSP CM SET WCR0 (CM0, source0);
                                                      //WIO interrupt is configured as EXI10 interrupt
CSP CM SET WICR(CM0, CM WIO);
                                                      //Clear WIO interrupt status
CSP CM SET WIMSCR (CM0, CM WIO);
                                                       //Enable WIO interrupt
                                                       //Enable WSI0 interrupt vector for WI0 interrupt
CSP NVIC SET ISER(NVICO, 0, NVIC INT6);
/* External interrupt configuration - EXIO */
CSP IOFunctionConfigure (GROUPO, 15, IOCONF F1);
                                                       //P0.15 is defined as EXIO (Function 1)
source1 = CM WSRC1(CM WSRC EXI10)|CM EDGE1|CM WEN1;
                                                      //WSRC1 setting value
CSP CM SET WCR0 (CM0, CSP CM GET WCR0 (CM0) | source1);
                                                       //WI1 interrupt is configured as EXIO interrupt.
CSP CM SET WICR(CM0,CM WI1);
                                                       //Clear WI1 interrupt status
CSP_CM_SET_WIMSCR(CM0,CSP_CM_GET_WIMSCR(CM0)|CM_WII); //Enable WII interrupt
CSP NVIC SET ISER(NVICO, 0, NVIC INT31);
                                                       //Enable WSIx interrupt vector for WI1 interrupt
```

If the external interrupt configuration is completed, the external interrupt can occur by the signal to be asserted through EXIO or EXI10 pin. In this example, WI1 and WI0 interrupts occur at the same time because event signal triggered by SW17 is connected with both EXIO and EXI10. But the WI0 interrupt handler will be served first. The reason is that the default priority of WI0 interrupt vector (WSIO = IRQ6) is higher than WI1 interrupt vector (WSIx = IRQ31).

Let's execute this example. After reset, the configuration is done. If that is completed, you can see the message to be displayed until (a). At this time, four LEDs turn on. If there is no SW17's push, there will be no change any more. Because the microcontroller is waiting for the external interrupt trigger signal. Let's push the switch button of SW17. You can see the result to be done by the external interrupt handler. That is (b) and (c). These are sent while microcontroller serves each interrupt handler operation. If you see all message as like the below, this example execution is finished. To notify the end, all LEDs will blink.



Figure 7 The Execution Message Through UART

