Welcome to **E-XFL.COM** What is "Embedded - Microcontrollers"? "Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications. Applications of "<u>Embedded - Microcontrollers</u>" | urchase URL | https://www.e-xfl.com/product-detail/infineon-technologies/mb90387spmt-gs-254e1 | |---------------------------|---------------------------------------------------------------------------------| | Supplier Device Package | 48-LQFP (7x7) | | ackage / Case | 48-LQFP | | ounting Type | Surface Mount | | perating Temperature | -40°C ~ 105°C (TA) | | Scillator Type | External | | Oata Converters | A/D 8x8/10b | | oltage - Supply (Vcc/Vdd) | 3.5V ~ 5.5V | | AM Size | 2K x 8 | | EPROM Size | - | | rogram Memory Type | Mask ROM | | rogram Memory Size | 64KB (64K x 8) | | umber of I/O | 36 | | ripherals | POR, WDT | | onnectivity | CANbus, SCI, UART/USART | | peed | 16MHz | | ore Size | 16-Bit | | Core Processor | F <sup>2</sup> MC-16LX | | roduct Status | Obsolete | | etails | | # 16-bit Microcontrollers F2MC-16LX MB90385 Series MB90385 series devices are general-purpose high-performance 16-bit micro controllers designed for process control of consumer products, which require high-speed real-time processing. The devices of this series have the built-in full-CAN interface. The system, inheriting the architecture of F<sup>2</sup>MC family, employs additional instruction ready for high-level languages, expanded addressing mode, enhanced multiply-divide instructions, and enriched bit-processing instructions. Furthermore, employment of 32-bit accumulator achieves processing of long-word data (32 bits). The peripheral resources of MB90385 series include the following: 8/10-bit A/D converter, UART (SCI), 8/16-bit PPG timer, 16-bit input-output timer (16-bit free-run timer, input capture 0, 1, 2, 3 (ICU)), and CAN controller. #### **Features** #### Clock - Built-in PLL clock frequency multiplication circuit - Selection of machine clocks (PLL clocks) is allowed among frequency division by two on oscillation clock, and multiplication of 1 to 4 times of oscillation clock (for 4-MHz oscillation clock, 4 MHz to 16 MHz). - Operation by sub-clock (8.192 kHz) is allowed. (MB90387, MB90F387) - Minimum execution time of instruction: 62.5 ns (when operating with 4-MHz oscillation clock, and 4-time multiplied PLL clock). ## 16 Mbyte CPU memory Space ■ 24-bit internal addressing #### Instruction System Best Suited to Controller - Wide choice of data types (bit, byte, word, and long word) - Wide choice of addressing modes (23 types) - Enhanced multiply-divide instructions and RETI instructions - Enhanced high-precision computing with 32-bit accumulator # Instruction System Compatible with High-level Language (C language) and Multitask - Employing system stack pointer - Enhanced various pointer indirect instructions - Barrel shift instructions #### **Increased Processing Speed** ■ 4-byte instruction queue # Powerful Interrupt Function with 8 Levels and 34 Factors #### **Automatic Data Transfer Function Independent of CPU** ■ Expanded intelligent I/O service function (EI² OS): Maximum of 16 channels #### Low Power Consumption (standby) Mode ■ Sleep mode (a mode that halts CPU operating clock) - Time-base timer mode (a mode that operates oscillation clock, sub clock, time-base timer and watch timer only) - Watch mode (a mode that operates sub clock and watch timer only) - Stop mode (a mode that stops oscillation clock and sub clock) - CPU blocking operation mode #### **Process** ■ CMOS technology #### I/O Port ■ General-purpose input/output port (CMOS output): MB90387, MB90F387: 34 ports (including 4 high-current output ports) MB90387S, MB90F387S: 36 ports (including 4 high-current output ports) #### Timer - Time-base timer, watch timer, watchdog timer: 1 channel - 8/16-bit PPG timer: 8-bit x 4 channels, or 16-bit x 2 channels - 16-bit reload timer: 2 channels - 16-bit input/output timer - 16-bit free run timer: 1 channel - □ 16-bit input capture: (ICU): 4 channels Interrupt request is issued upon latching a count value of 16-bit free run timer by detection of an edge on pin input. #### **CAN Controller: 1 channel** - Compliant with Ver2.0A and Ver2.0B CAN specifications - 8 built-in message buffers - Transmission rate of 10 kbps to 1 Mbps (by 16 MHz machine clock) - CAN wake-up ### **UART (SCI): 1 channel** - Equipped with full-duplex double buffer - Clock-asynchronous or clock-synchronous serial transmission is available. # DTP/External Interrupt: 4 channels, CAN wakeup: 1channel ■ Module for activation of expanded intelligent I/O service (El²OS), and generation of external interrupt. #### **Delay Interrupt Generator Module** ■ Generates interrupt request for task switching. #### 8/10-bit A/D Converter: 8 channels - Resolution is selectable between 8-bit and 10-bit. - Activation by external trigger input is allowed. - Conversion time: 6.125 µs (at 16 MHz machine clock, including sampling time) # **Program Patch Function** ■ Address matching detection for 2 address pointers. Document Number: 002-07765 Rev. \*A Page 2 of 81 | Address | Register<br>Abbreviation | Register | Read/<br>Write | Resource | Initial Value | | | | | |--------------------------|--------------------------|-----------------------------------------------|----------------|----------------|-------------------------------------------------|--|--|--|--| | 003D0Dн | | (Reserved area) * | | | | | | | | | 003D0Ен | TIER | Send completion interrupt permission register | R/W | CAN controller | 0000000В | | | | | | 003D0Fн | | (Reserv | ed area) * | • | | | | | | | 003D10н,<br>003D11н | AMSR | Acceptance mask selection register | R/W | CAN controller | XXXXXXX <sub>B</sub> ,<br>XXXXXXXX <sub>B</sub> | | | | | | 003D12н,<br>003D13н | (Reserved area) * | | | | | | | | | | 003D14н<br>to<br>003D17н | AMR0 | Acceptance mask register 0 | R/W | CAN controller | XXXXXXXXB<br>to<br>XXXXXXXXB | | | | | | 003D18н<br>to<br>003D1Вн | AMR1 | Acceptance mask register 1 | R/W | | XXXXXXXXB<br>to<br>XXXXXXXXB | | | | | | 003D1Сн<br>to<br>003DFFн | (Reserved area) * | | | | | | | | | | 003E00н<br>to<br>003EFFн | (Reserved area) * | | | | | | | | | | 003FF0н<br>to<br>003FFFн | | (Reserved area) * | | | | | | | | #### Initial values: - 0: Initial value of this bit is "0." - 1: Initial value of this bit is "1." - X: Initial value of this bit is undefined. Document Number: 002-07765 Rev. \*A Page 20 of 81 <sup>\*: &</sup>quot;Reserved area" should not be written anything. Result of reading from "Reserved area" is undefined. # Port 1 Pins Block Diagram (single-chip mode) ### Port 1 Registers (single-chip mode) - Port 1 registers include port 1 data register (PDR1) and port 1 direction register (DDR1). - The bits configuring the register correspond to port 1 pins on a one-to-one basis. # Relation between Port 1 Registers and Pins | Port Name | Bits of Register and Corresponding Pins | | | | | | | | | |-----------|-------------------------------------------------|-----|-----|-----|-----|------|-----|-----|-----| | Port 1 | PDR1, DDR1 bit7 bit6 bit5 bit4 bit3 bit2 bit1 b | | | | | bit0 | | | | | | Corresponding pins | P17 | P16 | P15 | P14 | P13 | P12 | P11 | P10 | # Port 5 Pins Block Diagram # **Port 5 Registers** - Port 5 registers include port 5 data register (PDR5), port 5 direction register (DDR5), and analog input permission register (ADER). - Analog input permission register (ADER) allows or disallows input of analog signal to the analog input pin. - The bits configuring the register correspond to port 5 pins on a one-to-one basis. # Relation between Port 5 Registers and Pins | Port Name | Bits of Register and Corresponding Pins | | | | | | | | | |-----------|-----------------------------------------|------|------|------|------|------|------|------|------| | Port 5 | PDR5, DDR5 | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | | ADER | ADE7 | ADE6 | ADE5 | ADE4 | ADE3 | ADE2 | ADE1 | ADE0 | | | Corresponding pins | P57 | P56 | P55 | P54 | P53 | P52 | P51 | P50 | #### 12.5 16-bit Reload Timer The 16-bit reload timer has the following functions: - Count clock is selectable among 3 internal clocks and external event clock. - Activation trigger is selectable between software trigger and external trigger. - Generation of CPU interrupt is allowed upon occurrence of underflow on 16-bit timer register. Available as an interval timer using the interrupt function. - When underflow of 16-bit timer register (TMR) occurs, one of two reload modes is selectable between one-shot mode that halts counting operation of TMR, and reload mode that reloads 16-bit reload register value to TMR, continuing TMR counting operation. - The 16-bit reload timer is ready for expanded intelligent I/O service (El<sup>2</sup>OS). - MB90385 series device has 2 channels of built-in 16-bit reload timer. # **Operation Mode of 16-bit Reload Timer** | Count Clock | Activation Trigger | Operation upon Underflow | |---------------------|------------------------------------|----------------------------| | Internal clock mode | Software trigger, external trigger | One-shot mode, reload mode | | Event count mode | Software trigger | One-shot mode, reload mode | #### **Internal Clock Mode** - The 16-bit reload timer is set to internal clock mode, by setting count clock selection bit (TMCSR: CSL1, CSL0) to "00<sub>B</sub>", "01<sub>B</sub>", "10<sub>B</sub>". - In the internal clock mode, the counter decrements in synchronization with the internal clock. - Three types of count clock cycles are selectable by count clock selection bit (TMCSR: CSL1, CSL0) in timer control status register. - Edge detection of software trigger or external trigger is specified as an activation trigger. Document Number: 002-07765 Rev. \*A Page 35 of 81 # 8/16-bit PPG Timer 0 Block Diagram ### 12.11 UART Outline UART is a general-purpose serial data communication interface for synchronous and asynchronous communication using external devices. - Provided with bi-directional communication function for both clock-synchronous and clock-asynchronous modes. - Provided with master/slave communication function (multi-processor mode). (Only master side is available.) - Interrupt request is generated upon completion of reception, completion of transmission and detection of reception error. - Ready for expanded intelligent service, El<sup>2</sup>OS. Table 12-3. UART Functions | | Description | |--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Data buffer | Full-duplex double buffer | | Transmission mode | Clock synchronous (No start/stop bit, no parity bit) Clock asynchronous (start-stop synchronous) | | Baud rate | Built-in special-purpose baud-rate generator. Setting is selectable among 8 values. Input of external values is allowed. Use of clock from external timer (16-bit reload timer 0) is allowed. | | Data length | 7 bits (only asynchronous normal mode)<br>8 bits | | Signaling system | Non Return to Zero (NRZ) system | | Reception error detection | Framing error Overrun error Parity error (not detectable in operation mode 1 (multi-processor mode)) | | Interrupt request | Receive interrupt (reception completed, reception error detected) Transmission interrupt (transmission completed) Ready for expanded intelligent I/O service (El²OS) in both transmission and reception | | Master/slave communication function (asynchronous, multi-processor mode) | Communication between 1 (master) and n (slaves) are available (usable as master only). | Note: Start/stop bit is not added upon clock-synchronous transmission. Data only is transmitted. Table 12-4. UART Operation Modes | | Operation Mode | Data L | -ength | Synchronization | Stop Bit Length | | |----------------|---------------------------------|----------------|----------------|-----------------|--------------------|--| | Operation Mode | | With Parity | Without Parity | Synchronization | Stop Bit Length | | | 0 | Asynchronous mode (normal mode) | 7-bit or 8-bit | | Asynchronous | 1- bit or 2-bit *2 | | | 1 | Multi processor mode | 8+1*1 – | | Asynchronous | | | | 2 | Synchronous mode | 8 | _ | Synchronous | No | | <sup>-:</sup> Disallowed Document Number: 002-07765 Rev. \*A Page 47 of 81 <sup>1: &</sup>quot;+1" is an address/data selection bit used for communication control (bit 11 of SCR1 register: A/D). <sup>2:</sup> Only 1 bit is detected as a stop bit on data reception. ### 12.13 Address Matching Detection Function Outline The address matching detection function checks if an address of an instruction to be processed next to a currently-processed instruction is identical with an address specified in the detection address register. If the addresses match with each other, an instruction to be processed next in program is forcibly replaced with INT9 instruction, and process branches to the interrupt process program. Using INT9 interrupt, this function is available for correcting program by batch processing. ## **Address Matching Detection Function Outline** - An address of an instruction to be processed next to a currently-processed instruction of the program is always retained in an address latch via internal data bus. By the address matching detection function, the address value retained in the address latch is always compared with an address specified in detection address setting register. If the compared address values match with each other, an instruction to be processed next by CPU is forcibly replaced with INT9 instruction, and an interrupt process program is executed. - Two detection address setting registers are provided (PADR0 and PADR1), and each register is provided with interrupt permission bit. Generation of interrupt, which is caused by address matching between the address retained in address latch and the address specified in address setting register, is permitted and prohibited on a register-by-register basis. Address Matching Detection Function Block Diagram - Address latch - Retains address value output to internal data bus. - Address detection control register (PACSR) Specifies if interrupt is permitted or prohibited when addresses match with each other. - Detection address setting (PADR0, PADR1) Specifies addresses to be compared with values in address latch. # 12.14 ROM Mirror Function Selection Module Outline The ROM mirror function selection module sets the data in ROM assigned to FF bank so that the data is read by access to 00 bank. # **ROM Mirror Function Selection Module Block Diagram** # FF Bank Access by ROM Mirror Function #### 12.15 512 Kbit Flash Memory Outline The following three methods are provided for data writing and deleting on Flash memory: - 1. Parallel writer - 2. Serial special-purpose writer - 3. Writing/deleting by program execution This section describes "3. Writing/deleting by program execution." #### 512 Kbit Flash Memory Outline The 512 Kbit Flash memory is allocated on FF<sub>H</sub> bank of CPU memory map. Using the function of Flash memory interface circuit, the memory allows read access and program access from CPU. Writing/deleting on Flash memory is performed by instruction from CPU via Flash memory interface. Because rewriting is allowed on mounted memory, modifying program and data is performed efficiently. #### Features of 512 Kbit Flash Memory - 128 K words x 8 bits/64 K words x 16 bits (16 K + 8 K + 8 K + 32 K) sector configuration - Automatic program algorithm (Embedded Algorithm: Similar to MBM29LV200.) - Built-in deletion pause/deletion resume function - Detection of completed writing/deleting by data polling and toggle bits. - Detection of completed writing/deleting by CPU interrupt. - Deletion is allowed on a sector-by-sector basis (sectors are combined freely). - Number of writing/deleting operations (minimum): 10,000 times - Sector protection - Expanded sector protection - Temporaly sector unprotection Note: A function of reading manufacture code and device code is not provided. These codes are not accessible by command either. #### Flash Memory Writing/Deleting - Writing and reading data is not allowed simultaneously on the Flash memory. - Data writing and deleting on the Flash memory is performed by the processes as follows: Make a copy of program on Flash memory onto RAM. Then, execute the program copied on the RAM. ### List of Registers and Reset Values in Flash Memory Flash memory control status register (FMCS) bit 7 6 5 4 3 2 1 0 0 0 0 0 0 0 0 ×: Undefined ### **Sector Configuration** For access from CPU, SA0 to SA3 are allocated in FF bank register. Document Number: 002-07765 Rev. \*A Page 53 of 81 # 13.2 Recommended Operating Conditions (Vss = AVss = 0.0V) | Parameter | Symbol | Value | | | Unit | Remarks | |-----------------------|--------|-------|-----|------|------|---------------------------------| | raiailletei | Symbol | Min | Тур | Max | Onne | Remarks | | Power supply voltage | Vcc | 3.5 | 5.0 | 5.5 | V | Under normal operation | | | | 3.0 | _ | 5.5 | | Retain status of stop operation | | | AVcc | 4.0 | _ | 5.5 | V | *2 | | Smoothing capacitor | Cs | 0.1 | _ | 1.0 | μF | *1 | | Operating temperature | Та | -40 | - | +105 | °C | | <sup>\*1:</sup> Use a ceramic capacitor, or a capacitor of similar frequency characteristics. On the Vcc pin, use a bypass capacitor that has a larger capacity than that of Cs. Refer to the following figure for connection of smoothing capacitor Cs. \*2: AVcc is a voltage at which accuracy is guaranteed. AVcc should not exceed Vcc. WARNING: The recommended operating conditions are required in order to ensure the normal operation of the semiconductor device. All of the device's electrical characteristics are warranted when the device is operated within these ranges. Always use semiconductor devices within their recommended operating condition ranges. Operation outside these ranges may adversely affect reliability and could result in device failure. No warranty is made with respect to uses, operating conditions, or combinations not represented on the data sheet. Users considering application outside the listed conditions are advised to contact their representatives beforehand. Document Number: 002-07765 Rev. \*A Page 57 of 81 # (Continued) $$Linear\ error\ of\ digital\ output\ N = \frac{V_{NT} - \{1\ LSB \times\ (N-1) + V_{OT}\}}{1\ LSB} [LSB]$$ $Differential \ linear \ error \ of \ digital \ output \ N = \frac{V \ (_{N \ + \ 1}) \ _{T} - V_{NT}}{1 \ LSB} - 1 LSB \ [LSB]$ $$1 LSB = \frac{V_{FST} - V_{OT}}{1022}[V]$$ Voт: Voltage at which digital output transits from "000н" to "001н." VFST: Voltage at which digital output transits from "3FEH" to "3FFH." # 14. Example Characteristics # MB90F387 (Continued) (Continued) # 17. Major Changes Spansion Publication Number: DS07-13717-5E | Page | Section | Change Results | |------|-----------------------|------------------------------------------------------------------------------------------------------------------------| | 4 | | Changed the number of channel of 8/16 bit PPG timer. or one 16-bit channel → or two 16-bit channels | | 13 | | Changed the direction of arrow of TIN0, TIN1 signals of 16-bit reload timer. right arrow (output) → left arrow (input) | | 67 | 4. AC Characteristics | Changed the value of Serial clock. Serial clock "H" pulse width: 4tcp→2tcp Serial clock "L" pulse width: 4tcp→2tcp | NOTE: Please see "Document History" about later revised information. Document Number: 002-07765 Rev. \*A Page 79 of 81 # **Document History** | | Document Title: MB90387/387S/F387/F387S, MB90V495G, 16-bit Microcontrollers F <sup>2</sup> MC-16LX MB90385 Series Document Number:002-07765 | | | | | | | | |--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|--|--|--|--| | Revision ECN Orig. of Change Submission Date Description of Change | | | | | | | | | | ** | _ | AKIH | IH 12/19/2008 Migrated to Cypress and assigned document number 002-07765. No change to document contents or format. | | | | | | | *A | 6059071 | SSAS | 02/05/2018 | Updated to Cypress template Package: FPT-48P-M26> LQA048 | | | | | Document Number: 002-07765 Rev. \*A Page 80 of 81 # Sales, Solutions, and Legal Information #### Worldwide Sales and Design Support Cypress maintains a worldwide network of offices, solution centers, manufacturer's representatives, and distributors. To find the office closest to you, visit us at Cypress Locations. #### **Products** Arm® Cortex® Microcontrollers cypress.com/arm Automotive cypress.com/automotive Clocks & Buffers cypress.com/clocks Interface cypress.com/interface Internet of Things cypress.com/iot Memory cypress.com/memory Microcontrollers cypress.com/mcu **PSoC** cypress.com/psoc Power Management ICs cypress.com/pmic Touch Sensing cypress.com/touch **USB** Controllers cypress.com/usb Wireless Connectivity cypress.com/wireless #### **PSoC® Solutions** PSoC 1 | PSoC 3 | PSoC 4 | PSoC 5LP | PSoC 6 MCU #### **Cypress Developer Community** Community | Projects | Video | Blogs | Training | Components # **Technical Support** cypress.com/support © Cypress Semiconductor Corporation, 2004-2018. This document is the property of Cypress Semiconductor Corporation and its subsidiaries, including Spansion LLC ("Cypress"). This document, including any software or firmware included or referenced in this document ("Software"), is owned by Cypress under the intellectual property laws and treaties of the United States and other countries worldwide. Cypress reserves all rights under such laws and treaties and does not, except as specifically stated in this paragraph, grant any license under its patents, copyrights, trademarks, or other intellectual property rights. If the Software is not accompanied by a license agreement and you do not otherwise have a written agreement with Cypress governing the use of the Software, then Cypress hereby grants you a personal, non-exclusive, nontransferable license (without the right to sublicense) (1) under its copyright rights in the Software (a) for Software provided in source code form, to modify and reproduce the Software solely for use with Cypress hardware products, only internally within your organization, and (b) to distribute the Software in binary code form externally to end users (either directly or indirectly through resellers and distributors), solely for use on Cypress hardware product units, and (2) under those claims of Cypress's patents that are infringed by the Software (as provided by Cypress, unmodified) to make, use, distribute, and import the Software solely for use with Cypress hardware products. Any other use, reproduction, modification, translation, or compilation of the Software is prohibited. TO THE EXTENT PERMITTED BY APPLICABLE LAW, CYPRESS MAKES NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS DOCUMENT OR ANY SOFTWARE OR ACCOMPANYING HARDWARE, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. No computing device can be absolutely secure. Therefore, despite security measures implemented in Cypress hardware or software products, Cypress does not assume any liability arising out of any security breach, such as unauthorized access to or use of a Cypress product. In addition, the products described in these materials may contain design defects or errors known as errata which may cause the product to deviate from published specifications. To the extent permitted by applicable law, Cypress reserves the right to make changes to this document without further notice. Cypress does not assume any information provided in this document, including any sample design information or programming code, is provided only for reference purposes. It is the responsibility of the user of this document to properly design, program, and test the functionality and safety of any application made of this information and any resulting product. Cypress products are not designed, intended, or authorized for use as critical components in systems designed or intended for the operation of weapons, weapons systems, nuclear installations, life-support devices or systems, other medical devices or systems (including resuscitation equipment and surgical implants), pollution control or hazardous substances management, or other uses where the failure of the device or system could cause personal injury, death, or property damage ("Unintended Uses"). A critical component is any component of a device or system whose failure to perform can be reasonably expected to cause the failure of the device or system, or to affect its safety or effectiveness. Cypress is not liable, in whole or in part, and you shall indemnify and hold Cypress harmless from and against all claims, Cypress, the Cypress logo, Spansion, the Spansion logo, and combinations thereof, WICED, PSoC, CapSense, EZ-USB, F-RAM, and Traveo are trademarks or registered trademarks of Cypress in the United States and other countries. For a more complete list of Cypress trademarks, visit cypress.com. Other names and brands may be claimed as property of their respective owners. Document Number: 002-07765 Rev. \*A Revised February 5, 2018 Page 81 of 81