Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs. With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas. We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry! # Contact us Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China # life.augmented # STM32F103xF STM32F103xG XL-density performance line ARM®-based 32-bit MCU with 768 KB to 1 MB Flash, USB, CAN, 17 timers, 3 ADCs, 13 com. interfaces Datasheet - production data # **Features** - Core: ARM<sup>®</sup> 32-bit Cortex<sup>®</sup>-M3 CPU with MPU - 72 MHz maximum frequency, 1.25 DMIPS/MHz (Dhrystone 2.1) performance at 0 wait state memory access - Single-cycle multiplication and hardware division - Memories - 768 Kbytes to 1 Mbyte of Flash memory - 96 Kbytes of SRAM - Flexible static memory controller with 4 Chip Select. Supports Compact Flash, SRAM, PSRAM, NOR and NAND memories - LCD parallel interface, 8080/6800 modes - · Clock, reset and supply management - 2.0 to 3.6 V application supply and I/Os - POR, PDR, and programmable voltage detector (PVD) - 4-to-16 MHz crystal oscillator - Internal 8 MHz factory-trimmed RC - Internal 40 kHz RC with calibration - 32 kHz oscillator for RTC with calibration - Low power - Sleep, Stop and Standby modes - V<sub>BAT</sub> supply for RTC and backup registers - 3 × 12-bit, 1 μs A/D converters (up to 21 channels) - Conversion range: 0 to 3.6 V - Triple-sample and hold capability - Temperature sensor - 2 × 12-bit D/A converters - DMA: 12-channel DMA controller - Supported peripherals: timers, ADCs, DAC, SDIO, I<sup>2</sup>Ss, SPIs, I<sup>2</sup>Cs and USARTs - Debug mode LFBGA144 10 × 10 mm - Serial wire debug (SWD) & JTAG interfaces - Cortex<sup>®</sup>-M3 Embedded Trace Macrocell™ - Up to 112 fast I/O ports - 51/80/112 I/Os, all mappable on 16 external interrupt vectors and almost all 5 V-tolerant - Up to 17 timers - Up to ten 16-bit timers, each with up to 4 IC/OC/PWM or pulse counter and quadrature (incremental) encoder input - 2 × 16-bit motor control PWM timers with dead-time generation and emergency stop - 2 × watchdog timers (Independent and Window) - SysTick timer: a 24-bit downcounter - 2 × 16-bit basic timers to drive the DAC - Up to 13 communication interfaces - Up to $2 \times I^2C$ interfaces (SMBus/PMBus) - Up to 5 USARTs (ISO 7816 interface, LIN, IrDA capability, modem control) - Up to 3 SPIs (18 Mbit/s), 2 with I<sup>2</sup>S interface multiplexed - CAN interface (2.0B Active) - USB 2.0 full speed interface - SDIO interface - CRC calculation unit, 96-bit unique ID - ECOPACK<sup>®</sup> packages Table 1. Device summary | Reference | Part number | |-------------|-------------------------------------| | STM32F103xF | STM32F103RF STM32F103VF STM32F103ZF | | STM32F103xG | STM32F103RG STM32F103VG STM32F103ZG | # **Contents** | 1 | Intro | duction | l | 9 | |---|-------|----------|-----------------------------------------------------------------|---------| | 2 | Desc | cription | | 10 | | | 2.1 | Device | overview | 11 | | | 2.2 | Full co | mpatibility throughout the family | 14 | | | 2.3 | Overvi | ew | 15 | | | | 2.3.1 | ARM® Cortex®-M3 core with embedded Flash and SRAM | | | | | 2.3.2 | Memory protection unit | 15 | | | | 2.3.3 | Embedded Flash memory | 15 | | | | 2.3.4 | CRC (cyclic redundancy check) calculation unit | 15 | | | | 2.3.5 | Embedded SRAM | 16 | | | | 2.3.6 | FSMC (flexible static memory controller) | 16 | | | | 2.3.7 | LCD parallel interface | 16 | | | | 2.3.8 | Nested vectored interrupt controller (NVIC) | 16 | | | | 2.3.9 | External interrupt/event controller (EXTI) | 16 | | | | 2.3.10 | Clocks and startup | 17 | | | | 2.3.11 | Boot modes | 17 | | | | 2.3.12 | Power supply schemes | 17 | | | | 2.3.13 | Power supply supervisor | 17 | | | | 2.3.14 | Voltage regulator | 18 | | | | 2.3.15 | Low-power modes | 18 | | | | 2.3.16 | DMA | 18 | | | | 2.3.17 | RTC (real-time clock) and backup registers | 19 | | | | 2.3.18 | Timers and watchdogs | 19 | | | | 2.3.19 | I <sup>2</sup> C bus | 21 | | | | 2.3.20 | Universal synchronous/asynchronous receiver transmitters (USART | s) . 21 | | | | 2.3.21 | Serial peripheral interface (SPI) | 22 | | | | 2.3.22 | Inter-integrated sound (I <sup>2</sup> S) | 22 | | | | 2.3.23 | SDIO | 22 | | | | 2.3.24 | Controller area network (CAN) | 22 | | | | 2.3.25 | Universal serial bus (USB) | 22 | | | | 2.3.26 | GPIOs (general-purpose inputs/outputs) | 22 | | | | 2.3.27 | ADC (analog to digital converter) | 23 | | | | 2.3.28 | DAC (digital-to-analog converter) | 23 | | | | 2.3.29 | Temperature sensor | 24 | |---|------|-----------|--------------------------------------------------------|-------| | | | 2.3.30 | Serial wire JTAG debug port (SWJ-DP) | 24 | | | | 2.3.31 | Embedded Trace Macrocell™ | 24 | | 3 | Pino | uts and | pin descriptions | . 25 | | 4 | Mem | ory ma | oping | . 38 | | 5 | Elec | trical ch | aracteristics | . 40 | | | 5.1 | Paramo | eter conditions | . 40 | | | | 5.1.1 | Minimum and maximum values | 40 | | | | 5.1.2 | Typical values | 40 | | | | 5.1.3 | Typical curves | 40 | | | | 5.1.4 | Loading capacitor | 40 | | | | 5.1.5 | Pin input voltage | 40 | | | | 5.1.6 | Power supply scheme | 41 | | | | 5.1.7 | Current consumption measurement | 42 | | | 5.2 | Absolu | te maximum ratings | . 43 | | | 5.3 | Operat | ing conditions | . 44 | | | | 5.3.1 | General operating conditions | 44 | | | | 5.3.2 | Operating conditions at power-up / power-down | 45 | | | | 5.3.3 | Embedded reset and power control block characteristics | 45 | | | | 5.3.4 | Embedded reference voltage | 46 | | | | 5.3.5 | Supply current characteristics | 46 | | | | 5.3.6 | External clock source characteristics | 57 | | | | 5.3.7 | Internal clock source characteristics | 63 | | | | 5.3.8 | PLL characteristics | 65 | | | | 5.3.9 | Memory characteristics | 65 | | | | 5.3.10 | FSMC characteristics | 67 | | | | 5.3.11 | EMC characteristics | 88 | | | | 5.3.12 | Absolute maximum ratings (electrical sensitivity) | 89 | | | | 5.3.13 | I/O current injection characteristics | 90 | | | | 5.3.14 | I/O port characteristics | 91 | | | | 5.3.15 | NRST pin characteristics | 96 | | | | 5.3.16 | TIM timer characteristics | 97 | | | | 5.3.17 | Communications interfaces | 98 | | | | 5.3.18 | CAN (controller area network) interface | . 108 | | | | 5.3.19 | 12-bit ADC characteristics | 108 | |---|------|----------|-----------------------------------------|-----| | | | 5.3.20 | DAC electrical specifications | 113 | | | | 5.3.21 | Temperature sensor characteristics | 115 | | 6 | Pack | age inf | ormation | 116 | | | 6.1 | LFBGA | A144 package information | 117 | | | 6.2 | LQFP1 | 144 package information | 119 | | | 6.3 | LQFP1 | 100 package information | 123 | | | 6.4 | LQFP6 | 64 package information | 126 | | | 6.5 | Therm | al characteristics | 129 | | | | 6.5.1 | Reference document | 129 | | | | 6.5.2 | Selecting the product temperature range | 130 | | 7 | Part | numbei | ring | 132 | | 8 | Revi | sion his | story | 133 | # List of tables | Table 1. | Device summary | | |------------|---------------------------------------------------------------------------|------| | Table 2. | STM32F103xF and STM32F103xG features and peripheral counts | | | Table 3. | STM32F103xx family | | | Table 4. | STM32F103xF and STM32F103xG timer feature comparison | | | Table 5. | STM32F103xF and STM32F103xG pin definitions | | | Table 6. | FSMC pin definition | . 36 | | Table 7. | Voltage characteristics | . 43 | | Table 8. | Current characteristics | . 43 | | Table 9. | Thermal characteristics | . 44 | | Table 10. | General operating conditions | . 44 | | Table 11. | Operating conditions at power-up / power-down | . 45 | | Table 12. | Embedded reset and power control block characteristics | . 45 | | Table 13. | Embedded internal reference voltage | | | Table 14. | Maximum current consumption in Run mode, code with data processing | | | | running from Flash | . 47 | | Table 15. | Maximum current consumption in Run mode, code with data processing | | | | running from RAM | . 47 | | Table 16. | Maximum current consumption in Sleep mode, code running from Flash or RAM | | | Table 17. | Typical and maximum current consumptions in Stop and Standby modes | | | Table 18. | Typical current consumption in Run mode, code with data processing | | | | running from Flash | 53 | | Table 19. | Typical current consumption in Sleep mode, code running from Flash or | | | . 45.6 | RAM | 54 | | Table 20. | Peripheral current consumption | | | Table 21. | High-speed external user clock characteristics | | | Table 22. | Low-speed external user clock characteristics | | | Table 23. | HSE 4-16 MHz oscillator characteristics. | | | Table 24. | LSE oscillator characteristics (f <sub>LSE</sub> = 32.768 kHz) | | | Table 25. | HSI oscillator characteristics. | | | Table 26. | LSI oscillator characteristics | | | Table 27. | Low-power mode wakeup timings | | | Table 28. | PLL characteristics | | | Table 29. | Flash memory characteristics | | | Table 30. | Flash memory endurance and data retention | | | Table 31. | Asynchronous non-multiplexed SRAM/PSRAM/NOR read timings | | | Table 32. | Asynchronous non-multiplexed SRAM/PSRAM/NOR write timings | | | Table 33. | Asynchronous multiplexed read timings | | | Table 34. | Asynchronous multiplexed PSRAM/NOR read timings | | | Table 35. | Asynchronous multiplexed PSRAM/NOR write timings | | | Table 36. | Synchronous multiplexed NOR/PSRAM read timings | | | Table 30. | Synchronous multiplexed PSRAM write timings | | | Table 37. | Synchronous non-multiplexed NOR/PSRAM read timings | | | Table 36. | | | | Table 39. | Synchronous non-multiplexed PSRAM write timings | . 10 | | 1 abie 40. | | റ | | Table 44 | attribute/common space | | | Table 41. | | | | Table 42. | Switching characteristics for NAND Flash read cycles | | | Table 43. | Switching characteristics for NAND Flash write cycles | . 0/ | # List of tables | Table 44. | EMS characteristics | 88 | |-----------|--------------------------------------------------------------------------|-----| | Table 45. | EMI characteristics | 89 | | Table 46. | ESD absolute maximum ratings | 89 | | Table 47. | Electrical sensitivities | 90 | | Table 48. | I/O current injection susceptibility | 90 | | Table 49. | I/O static characteristics | 91 | | Table 50. | Output voltage characteristics | 93 | | Table 51. | I/O AC characteristics | 95 | | Table 52. | NRST pin characteristics | 96 | | Table 53. | TIMx characteristics | 97 | | Table 54. | I <sup>2</sup> C characteristics | | | Table 55. | SCL frequency (f <sub>PCLK1</sub> = 36 MHz.,V <sub>DD I2C</sub> = 3.3 V) | 99 | | Table 56. | SPI characteristics | | | Table 57. | I <sup>2</sup> S characteristics | 103 | | Table 58. | SD / MMC characteristics | 105 | | Table 59. | USB startup time | 106 | | Table 60. | USB DC electrical characteristics | 107 | | Table 61. | USB: full-speed electrical characteristics | 107 | | Table 62. | ADC characteristics | | | Table 63. | R <sub>AIN</sub> max for f <sub>ADC</sub> = 14 MHz | 109 | | Table 64. | ADC accuracy - limited test conditions | 109 | | Table 65. | ADC accuracy | 110 | | Table 66. | DAC characteristics | 113 | | Table 67. | TS characteristics | 115 | | Table 68. | LFBGA144 – 144-ball low profile fine pitch ball grid array, 10 x 10 mm, | | | | 0.8 mm pitch, package mechanical data | 117 | | Table 69. | LQFP144 - 144-pin, 20 x 20 mm low-profile quad flat package | | | | mechanical data | 120 | | Table 70. | LQPF100 – 14 x 14 mm 100-pin low-profile quad flat package | | | | mechanical data | | | Table 71. | LQFP64 – 10 x 10 mm 64 pin low-profile quad flat package mechanical data | 126 | | Table 72. | Package thermal characteristics | | | Table 73. | STM32F103xF and STM32F103xG ordering information scheme | 132 | # **List of figures** | Figure 1. | STM32F103xF and STM32F103xG performance line block diagram | 12 | |--------------|------------------------------------------------------------------------------------------------------------------|----| | Figure 2. | Clock tree | | | Figure 3. | STM32F103xF/G BGA144 ballout | | | Figure 4. | STM32F103xF/G performance line LQFP144 pinout | 26 | | Figure 5. | STM32F103xF/G performance line LQFP100 pinout | 27 | | Figure 6. | STM32F103xF/G performance line LQFP64 pinout | 28 | | Figure 7. | Memory map | 39 | | Figure 8. | Pin loading conditions | 40 | | Figure 9. | Pin input voltage | 40 | | Figure 10. | Power supply scheme | 41 | | Figure 11. | Current consumption measurement scheme | 42 | | Figure 12. | Typical current consumption in Run mode versus frequency (at 3.6 V) - | | | | code with data processing running from RAM, peripherals enabled | 48 | | Figure 13. | Typical current consumption in Run mode versus frequency (at 3.6 V)- | | | | code with data processing running from RAM, peripherals disabled | 48 | | Figure 14. | Typical current consumption on V <sub>BAT</sub> with RTC on vs. temperature at different V <sub>BAT</sub> values | | | Figure 15. | Typical current consumption in Stop mode with regulator in run mode | 50 | | rigure ro. | versus temperature at different V <sub>DD</sub> values | 51 | | Figure 16. | Typical current consumption in Stop mode with regulator in low-power | | | rigure ro. | mode versus temperature at different V <sub>DD</sub> values | 52 | | Figure 17. | Typical current consumption in Standby mode versus temperature at | 02 | | i iguio iri. | different V <sub>DD</sub> values | 52 | | Figure 18. | High-speed external clock source AC timing diagram | | | Figure 19. | Low-speed external clock source AC timing diagram | | | Figure 20. | Typical application with an 8 MHz crystal | | | Figure 21. | Typical application with a 32.768 kHz crystal | | | Figure 22. | Asynchronous non-multiplexed SRAM/PSRAM/NOR read waveforms | | | Figure 23. | Asynchronous non-multiplexed SRAM/PSRAM/NOR write waveforms | | | Figure 24. | Asynchronous multiplexed PSRAM/NOR read waveforms. | | | Figure 25. | Asynchronous multiplexed PSRAM/NOR write waveforms | | | Figure 26. | Synchronous multiplexed NOR/PSRAM read timings | | | Figure 27. | Synchronous multiplexed PSRAM write timings | | | Figure 28. | Synchronous non-multiplexed NOR/PSRAM read timings | | | Figure 29. | Synchronous non-multiplexed PSRAM write timings | | | Figure 30. | PC Card/CompactFlash controller waveforms for common memory read access | | | Figure 31. | PC Card/CompactFlash controller waveforms for common memory write access | | | Figure 32. | PC Card/CompactFlash controller waveforms for attribute memory read | 00 | | rigure oz. | access | 81 | | Figure 33. | PC Card/CompactFlash controller waveforms for attribute memory write | | | i iguic oo. | access | 82 | | Figure 34. | PC Card/CompactFlash controller waveforms for I/O space read access | | | Figure 35. | PC Card/CompactFlash controller waveforms for I/O space write access | | | Figure 36. | NAND controller waveforms for read access | | | Figure 30. | NAND controller waveforms for write access | | | Figure 37. | NAND controller waveforms for common memory read access | | | Figure 30. | NAND controller waveforms for common memory write access | | | Figure 39. | Standard I/O input characteristics - CMOS port | | | i igui e 40. | Otandara no input characteristics - civido port | 52 | | Figure 41. | Standard I/O input characteristics - TTL port | 92 | |------------|----------------------------------------------------------------------------------------------|-----| | Figure 42. | 5 V tolerant I/O input characteristics - CMOS port | | | Figure 43. | 5 V tolerant I/O input characteristics - TTL port | | | Figure 44. | I/O AC characteristics definition | | | Figure 45. | Recommended NRST pin protection | 97 | | Figure 46. | I <sup>2</sup> C bus AC waveforms and measurement circuit | 99 | | Figure 47. | SPI timing diagram - slave mode and CPHA = 0 | 101 | | Figure 48. | SPI timing diagram - slave mode and CPHA = 1 <sup>(1)</sup> | 101 | | Figure 49. | SPI timing diagram - master mode <sup>(1)</sup> | 102 | | Figure 50. | I <sup>2</sup> S slave timing diagram (Philips protocol) <sup>(1)</sup> | 104 | | Figure 51. | I <sup>2</sup> S master timing diagram (Philips protocol) <sup>(1)</sup> | 104 | | Figure 52. | SDIO high-speed mode | 105 | | Figure 53. | SD default mode | 105 | | Figure 54. | USB timings: definition of data signal rise and fall time | 107 | | Figure 55. | ADC accuracy characteristics | | | Figure 56. | Typical connection diagram using the ADC | 111 | | Figure 57. | Power supply and reference decoupling (V <sub>REF+</sub> not connected to V <sub>DDA</sub> ) | 111 | | Figure 58. | Power supply and reference decoupling (V <sub>REF+</sub> connected to V <sub>DDA</sub> ) | 112 | | Figure 59. | 12-bit buffered /non-buffered DAC | 115 | | Figure 60. | LFBGA144 – 144-ball low profile fine pitch ball grid array, 10 x 10 mm, | | | | 0.8 mm pitch, package outline | | | Figure 61. | LFBGA144 marking example (package top view) | | | Figure 62. | LQFP144 - 144-pin, 20 x 20 mm low-profile quad flat package outline | 119 | | Figure 63. | LQFP144 - 144-pin,20 x 20 mm low-profile quad flat package | | | | recommended footprint | | | Figure 64. | LQFP144 marking example (package top view) | | | Figure 65. | LFP100 – 14 x 14 mm 100 pin low-profile quad flat package outline | | | Figure 66. | LQFP100 recommended footprint | | | Figure 67. | LQFP100 marking example (package top view) | | | Figure 68. | LFP64 – 10 x 10 mm 64 pin low-profile quad flat package outline | | | Figure 69. | LQFP64 - 64-pin, 10 x 10 mm low-profile quad flat recommended footprint | 127 | | Figure 70. | LQFP64 marking example (package top view) | 128 | | Figure 71 | LOEP100 Pa may ve T. | 131 | # 1 Introduction This datasheet provides the ordering information and mechanical device characteristics of the STM32F103xF and STM32F103xG XL-density performance line microcontrollers. For more details on the whole STMicroelectronics STM32F103xF/G family, please refer to Section 2.2: Full compatibility throughout the family. The XL-density STM32F103xF/G datasheet should be read in conjunction with the STM32F10xxx reference manual. For information on programming, erasing and protection of the internal Flash memory please refer to the *STM32F10xxx Flash programming manual*. The reference and Flash programming manuals are both available from the STMicroelectronics website *www.st.com*. For information on the Cortex<sup>®</sup>-M3 core please refer to the Cortex<sup>®</sup>-M3 Technical Reference Manual, available from the *www.arm.com* website at the following address: *http://infocenter.arm.com*. # 2 Description The STM32F103xF and STM32F103xG performance line family incorporates the high-performance ARM® Cortex®-M3 32-bit RISC core operating at a 72 MHz frequency, high-speed embedded memories (Flash memory up to 1 Mbyte and SRAM up to 96 Kbytes), and an extensive range of enhanced I/Os and peripherals connected to two APB buses. All devices offer three 12-bit ADCs, ten general-purpose 16-bit timers plus two PWM timers, as well as standard and advanced communication interfaces: up to two I<sup>2</sup>Cs, three SPIs, two I<sup>2</sup>Ss, one SDIO, five USARTs, an USB and a CAN. The STM32F103xF/G XL-density performance line family operates in the -40 to +105 °C temperature range, from a 2.0 to 3.6 V power supply. A comprehensive set of power-saving mode allows the design of low-power applications. These features make the STM32F103xF/G high-density performance line microcontroller family suitable for a wide range of applications such as motor drives, application control, medical and handheld equipment, PC and gaming peripherals, GPS platforms, industrial applications, PLCs, inverters, printers, scanners, alarm systems and video intercom. # 2.1 Device overview The STM32F103xF/G XL-density performance line family offers devices in four different package types: from 64 pins to 144 pins. Depending on the device chosen, different sets of peripherals are included, the description below gives an overview of the complete range of peripherals proposed in this family. Figure 1 shows the general block diagram of the device family. Table 2. STM32F103xF and STM32F103xG features and peripheral counts | F | Peripherals | STM32 | F103Rx | STM32I | =103Vx | STM32F103Zx | | | |------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|------------------|-------------|--------|--| | Flash me | emory | 768 KB | 1 MB | 768 KB | 1 MB | 768 KB | 1 MB | | | SRAM ir | n Kbytes | 9 | 6 | 90 | 6 | 90 | 6 | | | FSMC | | N | lo | Yes | s <sup>(1)</sup> | Υe | es | | | | General-purpose | 10 | | | | | | | | Timers | Advanced-control | | | 2 | | | | | | | Basic | | | 2 | | | | | | | SPI(I <sup>2</sup> S) <sup>(2)</sup> | | | 3(2 | 2) | | | | | | I <sup>2</sup> C | 2 | | | | | | | | Comm | USART | 5 | | | | | | | | Commi | USB | 1 | | | | | | | | | CAN | 1 | | | | | | | | | SDIO | 1 | | | | | | | | GPIOs | | 51 80 | | 0 | 112 | | | | | 12-bit Al<br>Number | OC<br>of channels | 3<br>16<br>3 | | 3<br>21 | | | | | | 12-bit DAN | AC<br>of channels | 2<br>2 | | | | | | | | CPU free | quency | 72 MHz | | | | | | | | Operatin | g voltage | 2.0 to 3.6 V | | | | | | | | Operating temperatures | | Ambient temperatures: -40 to +85 °C /-40 to +105 °C (see <i>Table 10</i> ) Junction temperature: -40 to + 125 °C (see <i>Table 10</i> ) | | | | | | | | Package | • | LQF | P64 | LQFF | P100 | LQFP144, | BGA144 | | <sup>1.</sup> For the LQFP100 package, only FSMC Bank1 and Bank2 are available. Bank1 can only support a multiplexed NOR/PSRAM memory using the NE1 Chip Select. Bank2 can only support a 16- or 8-bit NAND Flash memory using the NCE2 Chip Select. The interrupt line cannot be used since Port G is not available in this package. The SPI2 and SPI3 interfaces give the flexibility to work in an exclusive way in either the SPI mode or the I<sup>2</sup>S audio mode. Figure 1. STM32F103xF and STM32F103xG performance line block diagram 57/ <sup>1.</sup> $T_A = -40$ °C to +85 °C (suffix 6, see *Table 73*) or -40 °C to +105 °C (suffix 7, see *Table 73*), junction temperature up to 105 °C or 125 °C, respectively. <sup>2.</sup> AF = alternate function on I/O port pin.9 Figure 2. Clock tree - When the HSI is used as a PLL clock input, the maximum system clock frequency that can be achieved is 64 MHz. - 2. For the USB function to be available, both HSE and PLL must be enabled, with the USBCLK at 48 MHz. - 3. To have an ADC conversion time of 1 $\mu$ s, APB2 must be at 14 MHz, 28 MHz or 56 MHz. # 2.2 Full compatibility throughout the family The STM32F103xF/G is a complete family whose members are fully pin-to-pin, software and feature compatible. In the reference manual, the STM32F103x4 and STM32F103x6 are identified as low-density devices, the STM32F103x8 and STM32F103xB are referred to as medium-density devices, the STM32F103xF, STM32F103xD and STM32F103xG are referred to as high-density devices and the STM32F103xF and STM32F103xG are called XL-density devices. Low-density, high-density and XL-density devices are an extension of the STM32F103x8/B medium-density devices, they are specified in the STM32F103x4/6, STM32F103xC/D/E and STM32F103xF/G datasheets, respectively. Low-density devices feature lower Flash memory and RAM capacities, less timers and peripherals. High-density devices have higher Flash memory and RAM capacities, and additional peripherals like SDIO, FSMC, I<sup>2</sup>S and DAC. XL-density devices bring even more Flash and RAM memory, and extra features, namely an MPU, a greater number of timers and a dual bank Flash structure while remaining fully compatible with the other members of the family. The STM32F103x4, STM32F103x6, STM32F103xF, STM32F103xD, STM32F103xG, STM32F103xF and STM32F103xG are a drop-in replacement for the STM32F103x8/B devices, allowing the user to try different memory densities and providing a greater degree of freedom during the development cycle. Moreover, the STM32F103xx performance line family is fully compatible with all existing STM32F101xx access line and STM32F102xx USB access line devices. | | Low-density devices | | Medium-density devices | | High-density devices | | | XL-density devices | | | |--------|-------------------------------------------------------------------------------------------------------------|-------------------------------|----------------------------------------------------------------------------------|------------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--| | Pinout | 16 KB<br>Flash | 32 KB<br>Flash <sup>(1)</sup> | 64 KB<br>Flash | 128 KB<br>Flash | 256 KB<br>Flash | 384 KB<br>Flash | 512 KB<br>Flash | 768 KB Flash | 1 MB Flash | | | | 6 KB<br>RAM | 10 KB<br>RAM | 20 KB<br>RAM | 20 KB<br>RAM | 48 or<br>64 KB <sup>(2)</sup><br>RAM | 64 KB<br>RAM | 64 KB<br>RAM | 96 KB RAM | 96 KB RAM | | | 144 | | | | | 5 × USAR | Гs | | 5 × USARTs | | | | 100 | | | | | 4 × 16-bit timers,<br>2 × basic timers | | | 10 × 16-bit timers,<br>2 × basic timers<br>3 × SPIs, 2 × I <sup>2</sup> Ss, 2 × I <sup>2</sup> Cs<br>USB, CAN, 2 × PWM timers<br>3 × ADCs, 2 × DACs, 1 ×<br>SDIO, Cortex-M3 with MPU<br>FSMC (100- and 144-pin<br>packages <sup>(4)</sup> ), dual bank Flash<br>memory | | | | 64 | 2 × USARTs<br>2 × 16-bit timers<br>1 × SPI, 1 × I <sup>2</sup> C,<br>USB, CAN,<br>1 × PWM timer<br>2 × ADCs | | 3 × USART<br>3 × 16-bit ti<br>2 × SPIs, 2<br>USB, CAN,<br>1 × PWM ti<br>2 × ADCs | mers<br>× I <sup>2</sup> Cs, | 3 × SPIs, 2<br>USB, CAN<br>3 × ADCs,<br>1 × SDIO<br>FSMC (10 | 3 × SPIs, 2 × I <sup>2</sup> Ss, 2 × I2Cs<br>USB, CAN, 2 × PWM timers<br>3 × ADCs, 2 × DACs,<br>1 × SDIO<br>FSMC (100- and 144-pin<br>packages <sup>(3)</sup> ) | | | | | | 48 | | | | | | | | • | | | | 36 | | | | | _ | | | | | | Table 3. STM32F103xx family - For orderable part numbers that do not show the A internal code after the temperature range code (6 or 7), the reference datasheet for electrical characteristics is that of the STM32F103x8/B medium-density devices. - 2. 64 KB RAM for 256 KB Flash are available on devices delivered in CSP packages only. - 3. Ports F and G are not available in devices delivered in 100-pin packages. - 4. Ports F and G are not available in devices delivered in 100-pin packages. # 2.3 Overview # 2.3.1 ARM® Cortex®-M3 core with embedded Flash and SRAM The ARM Cortex<sup>®</sup>-M3 processor is the latest generation of ARM processors for embedded systems. It has been developed to provide a low-cost platform that meets the needs of MCU implementation, with a reduced pin count and low-power consumption, while delivering outstanding computational performance and an advanced system response to interrupts. The ARM Cortex<sup>®</sup>-M3 32-bit RISC processor features exceptional code-efficiency, delivering the high-performance expected from an ARM core in the memory size usually associated with 8- and 16-bit devices. With its embedded ARM core, STM32F103xF and STM32F103xG performance line family is compatible with all ARM tools and software. Figure 1 shows the general block diagram of the device family. # 2.3.2 Memory protection unit The memory protection unit (MPU) is used to separate the processing of tasks from the data protection. The MPU can manage up to 8 protection areas that can all be further divided up into 8 subareas. The protection area sizes are between 32 bytes and the whole 4 gigabytes of addressable memory. The memory protection unit is especially helpful for applications where some critical or certified code has to be protected against the misbehavior of other tasks. It is usually managed by an RTOS (real-time operating system). If a program accesses a memory location that is prohibited by the MPU, the RTOS can detect it and take action. In an RTOS environment, the kernel can dynamically update the MPU area setting, based on the process to be executed. The MPU is optional and can be bypassed for applications that do not need it. # 2.3.3 Embedded Flash memory 768 Kbytes to 1 Mbyte of embedded Flash are available for storing programs and data. The Flash memory is organized as two banks. The first bank has a size of 512 Kbytes. The second bank is either 256 or 512 Kbytes depending on the device. This gives the device the capability of writing to one bank while executing code from the other bank (read-while-write capability). # 2.3.4 CRC (cyclic redundancy check) calculation unit The CRC (cyclic redundancy check) calculation unit is used to get a CRC code from a 32-bit data word and a fixed generator polynomial. Among other applications, CRC-based techniques are used to verify data transmission or storage integrity. In the scope of the EN/IEC 60335-1 standard, they offer a means of verifying the Flash memory integrity. The CRC calculation unit helps compute a signature of the software during runtime, to be compared with a reference signature generated at link-time and stored at a given memory location. #### 2.3.5 Embedded SRAM 96 Kbytes of embedded SRAM accessed (read/write) at CPU clock speed with 0 wait states. # 2.3.6 FSMC (flexible static memory controller) The FSMC is embedded in the STM32F103xF and STM32F103xG performance line family. It has four Chip Select outputs supporting the following modes: PC Card/Compact Flash, SRAM, PSRAM, NOR and NAND. Functionality overview: - The three FSMC interrupt lines are ORed in order to be connected to the NVIC - Write FIFO - Code execution from external memory except for NAND Flash and PC Card - The targeted frequency, f<sub>CLK</sub>, is HCLK/2, so external access is at 36 MHz when HCLK is at 72 MHz and external access is at 24 MHz when HCLK is at 48 MHz # 2.3.7 LCD parallel interface The FSMC can be configured to interface seamlessly with most graphic LCD controllers. It supports the Intel 8080 and Motorola 6800 modes, and is flexible enough to adapt to specific LCD interfaces. This LCD parallel interface capability makes it easy to build cost-effective graphic applications using LCD modules with embedded controllers or high-performance solutions using external controllers with dedicated acceleration. # 2.3.8 Nested vectored interrupt controller (NVIC) The STM32F103xF and STM32F103xG performance line embeds a nested vectored interrupt controller able to handle up to 60 maskable interrupt channels (not including the 16 interrupt lines of Cortex<sup>®</sup>-M3) and 16 priority levels. - Closely coupled NVIC gives low latency interrupt processing - Interrupt entry vector table address passed directly to the core - Closely coupled NVIC core interface - Allows early processing of interrupts - Processing of late arriving higher priority interrupts - Support for tail-chaining - Processor state automatically saved - Interrupt entry restored on interrupt exit with no instruction overhead This hardware block provides flexible interrupt management features with minimal interrupt latency. # 2.3.9 External interrupt/event controller (EXTI) The external interrupt/event controller consists of 19 edge detector lines used to generate interrupt/event requests. Each line can be independently configured to select the trigger event (rising edge, falling edge, both) and can be masked independently. A pending register maintains the status of the interrupt requests. The EXTI can detect an external line with a pulse width shorter than the Internal APB2 clock period. Up to 112 GPIOs can be connected to the 16 external interrupt lines. # 2.3.10 Clocks and startup System clock selection is performed on startup, however the internal RC 8 MHz oscillator is selected as default CPU clock on reset. An external 4-16 MHz clock can be selected, in which case it is monitored for failure. If failure is detected, the system automatically switches back to the internal RC oscillator. A software interrupt is generated if enabled. Similarly, full interrupt management of the PLL clock entry is available when necessary (for example with failure of an indirectly used external oscillator). Several prescalers allow the configuration of the AHB frequency, the high speed APB (APB2) and the low speed APB (APB1) domains. The maximum frequency of the AHB and the high speed APB domains is 72 MHz. The maximum allowed frequency of the low speed APB domain is 36 MHz. See *Figure 2* for details on the clock tree. # 2.3.11 Boot modes At startup, boot pins are used to select one of three boot options: - Boot from user Flash: you have an option to boot from any of two memory banks. By default, boot from Flash memory bank 1 is selected. You can choose to boot from Flash memory bank 2 by setting a bit in the option bytes. - Boot from system memory - Boot from embedded SRAM The boot loader is located in system memory. It is used to reprogram the Flash memory by using USART1. # 2.3.12 Power supply schemes - V<sub>DD</sub> = 2.0 to 3.6 V: external power supply for I/Os and the internal regulator. Provided externally through V<sub>DD</sub> pins. - V<sub>SSA</sub>, V<sub>DDA</sub> = 2.0 to 3.6 V: external analog power supplies for ADC, DAC, Reset blocks, RCs and PLL (minimum voltage to be applied to VDDA is 2.4 V when the ADC or DAC is used). V<sub>DDA</sub> and V<sub>SSA</sub> must be connected to V<sub>DD</sub> and V<sub>SS</sub>, respectively. - V<sub>BAT</sub> = 1.8 to 3.6 V: power supply for RTC, external clock 32 kHz oscillator and backup registers (through power switch) when V<sub>DD</sub> is not present. For more details on how to connect power pins, refer to Figure 10: Power supply scheme. # 2.3.13 Power supply supervisor The device has an integrated power-on reset (POR)/power-down reset (PDR) circuitry. It is always active, and ensures proper operation starting from/down to 2 V. The device remains in reset mode when $V_{DD}$ is below a specified threshold, $V_{POR/PDR}$ , without the need for an external reset circuit. The device features an embedded programmable voltage detector (PVD) that monitors the $V_{DD}/V_{DDA}$ power supply and compares it to the $V_{PVD}$ threshold. An interrupt can be generated when $V_{DD}/V_{DDA}$ drops below the $V_{PVD}$ threshold and/or when $V_{DD}/V_{DDA}$ is higher than the $V_{PVD}$ threshold. The interrupt service routine can then generate a warning message and/or put the MCU into a safe state. The PVD is enabled by software. Refer to Table 12: Embedded reset and power control block characteristics for the values of $V_{POR/PDR}$ and $V_{PVD}$ . # 2.3.14 Voltage regulator The regulator has three operation modes: main (MR), low-power (LPR) and power down. - MR is used in the nominal regulation mode (Run) - LPR is used in the Stop modes. - Power down is used in Standby mode: the regulator output is in high impedance: the kernel circuitry is powered down, inducing zero consumption (but the contents of the registers and SRAM are lost) This regulator is always enabled after reset. It is disabled in Standby mode. # 2.3.15 Low-power modes The STM32F103xF and STM32F103xG performance line supports three low-power modes to achieve the best compromise between low-power consumption, short startup time and available wakeup sources: #### Sleep mode In Sleep mode, only the CPU is stopped. All peripherals continue to operate and can wake up the CPU when an interrupt/event occurs. #### Stop mode Stop mode achieves the lowest power consumption while retaining the content of SRAM and registers. All clocks in the 1.8 V domain are stopped, the PLL, the HSI RC and the HSE crystal oscillators are disabled. The voltage regulator can also be put either in normal or in low-power mode. The device can be woken up from Stop mode by any of the EXTI line. The EXTI line source can be one of the 16 external lines, the PVD output, the RTC alarm or the USB wakeup. # • Standby mode The Standby mode is used to achieve the lowest power consumption. The internal voltage regulator is switched off so that the entire 1.8 V domain is powered off. The PLL, the HSI RC and the HSE crystal oscillators are also switched off. After entering Standby mode, SRAM and register contents are lost except for registers in the Backup domain and Standby circuitry. The device exits Standby mode when an external reset (NRST pin), an IWDG reset, a rising edge on the WKUP pin, or an RTC alarm occurs. Note: The RTC, the IWDG, and the corresponding clock sources are not stopped by entering Stop or Standby mode. #### 2.3.16 DMA The flexible 12-channel general-purpose DMAs (7 channels for DMA1 and 5 channels for DMA2) are able to manage memory-to-memory, peripheral-to-memory and memory-to-peripheral transfers. The two DMA controllers support circular buffer management, removing the need for user code intervention when the controller reaches the end of the buffer. Each channel is connected to dedicated hardware DMA requests, with support for software trigger on each channel. Configuration is made by software and transfer sizes between source and destination are independent. 57/ The DMA can be used with the main peripherals: SPI, I<sup>2</sup>C, USART, general-purpose, basic and advanced-control timers TIMx, DAC, I<sup>2</sup>S, SDIO and ADC. # 2.3.17 RTC (real-time clock) and backup registers The RTC and the backup registers are supplied through a switch that takes power either on $V_{DD}$ supply when present or through the $V_{BAT}$ pin. The backup registers are forty-two 16-bit registers used to store 84 bytes of user application data when $V_{DD}$ power is not present. They are not reset by a system or power reset, and they are not reset when the device wakes up from the Standby mode. The real-time clock provides a set of continuously running counters which can be used with suitable software to provide a clock calendar function, and provides an alarm interrupt and a periodic interrupt. It is clocked by a 32.768 kHz external crystal, resonator or oscillator, the internal low-power RC oscillator or the high-speed external clock divided by 128. The internal low-speed RC has a typical frequency of 40 kHz. The RTC can be calibrated using an external 512 Hz output to compensate for any natural quartz deviation. The RTC features a 32-bit programmable counter for long term measurement using the Compare register to generate an alarm. A 20-bit prescaler is used for the time base clock and is by default configured to generate a time base of 1 second from a clock at 32.768 kHz. # 2.3.18 Timers and watchdogs The XL-density STM32F103xF/G performance line devices include up to two advanced-control timers, up to ten general-purpose timers, two basic timers, two watchdog timers and a SysTick timer. *Table 4* compares the features of the advanced-control, general-purpose and basic timers. | Timer | Counter resolution | Counter type | Prescaler factor | DMA request generation | Capture/compare channels | Complementary outputs | | | | |------------------------------|--------------------|-------------------------|---------------------------------|------------------------|--------------------------|-----------------------|--|--|--| | TIM1, TIM8 | 16-bit | Up,<br>down,<br>up/down | Any integer between 1 and 65536 | Yes | 4 | Yes | | | | | TIM2, TIM3,<br>TIM4, TIM5 | 16-bit | Up,<br>down,<br>up/down | Any integer between 1 and 65536 | Yes | 4 | No | | | | | TIM9, TIM12 | 16-bit | Up | Any integer between 1 and 65536 | No | 2 | No | | | | | TIM10, TIM11<br>TIM13, TIM14 | 16-bit | Up | Any integer between 1 and 65536 | No | 1 | No | | | | | TIM6, TIM7 | 16-bit | Up | Any integer between 1 and 65536 | Yes | 0 | No | | | | Table 4. STM32F103xF and STM32F103xG timer feature comparison # Advanced-control timers (TIM1 and TIM8) The two advanced-control timers (TIM1 and TIM8) can each be seen as a three-phase PWM multiplexed on 6 channels. They have complementary PWM outputs with programmable inserted dead-times. They can also be seen as a complete general-purpose timer. The 4 independent channels can be used for: - Input capture - Output compare - PWM generation (edge or center-aligned modes) - One-pulse mode output If configured as a standard 16-bit timer, it has the same features as the TIMx timer. If configured as the 16-bit PWM generator, it has full modulation capability (0-100%). In debug mode, the advanced-control timer counter can be frozen and the PWM outputs disabled to turn off any power switch driven by these outputs. Many features are shared with those of the general-purpose TIM timers which have the same architecture. The advanced-control timer can therefore work together with the TIM timers via the Timer Link feature for synchronization or event chaining. #### **General-purpose timers (TIMx)** There are 10 synchronizable general-purpose timers embedded in the STM32F103xF and STM32F103xG performance line devices (see *Table 4* for differences). #### • TIM2, TIM3, TIM4, TIM5 There are up to 4 synchronizable general-purpose timers (TIM2, TIM3, TIM4 and TIM5) embedded in the STM32F103xF and STM32F103xG access line devices. These timers are based on a 16-bit auto-reload up/down counter, a 16-bit prescaler and feature 4 independent channels each for input capture/output compare, PWM or one-pulse mode output. This gives up to 16 input captures / output compares / PWMs on the largest packages. Their counter can be frozen in debug mode. Any of the general-purpose timers can be used to generate PWM outputs. They all have independent DMA request generation. These timers are capable of handling quadrature (incremental) encoder signals and the digital outputs from 1 to 3 hall-effect sensors. #### TIM10, TIM11 and TIM9 These timers are based on a 16-bit auto-reload upcounter and a 16-bit prescaler. TIM10 and TIM11 feature one independent channel, whereas TIM9 has two independent channels for input capture/output compare, PWM or one-pulse mode output. They can be synchronized with the TIM2, TIM3, TIM4, TIM5 full-featured general-purpose timers. They can also be used as simple time bases. #### • TIM13, TIM14 and TIM12 These timers are based on a 16-bit auto-reload upcounter and a 16-bit prescaler. TIM13 and TIM14 feature one independent channel, whereas TIM12 has two independent channels for input capture/output compare, PWM or one-pulse mode output. They can be synchronized with the TIM2, TIM3, TIM4, TIM5 full-featured general-purpose timers. They can also be used as simple time bases. #### Basic timers TIM6 and TIM7 These timers are mainly used for DAC trigger generation. They can also be used as a generic 16-bit time base. #### Independent watchdog The independent watchdog is based on a 12-bit downcounter and 8-bit prescaler. It is clocked from an independent 40 kHz internal RC and as it operates independently from the main clock, it can operate in Stop and Standby modes. It can be used either as a watchdog to reset the device when a problem occurs, or as a free running timer for application timeout management. It is hardware or software configurable through the option bytes. The counter can be frozen in debug mode. # Window watchdog The window watchdog is based on a 7-bit downcounter that can be set as free running. It can be used as a watchdog to reset the device when a problem occurs. It is clocked from the main clock. It has an early warning interrupt capability and the counter can be frozen in debug mode. # SysTick timer This timer is dedicated to real-time operating systems, but could also be used as a standard down counter. It features: - A 24-bit down counter - Autoreload capability - Maskable system interrupt generation when the counter reaches 0. - Programmable clock source #### 2.3.19 I<sup>2</sup>C bus Up to two I<sup>2</sup>C bus interfaces can operate in multimaster and slave modes. They can support standard and fast modes. They support 7/10-bit addressing mode and 7-bit dual addressing mode (as slave). A hardware CRC generation/verification is embedded. They can be served by DMA and they support SMBus 2.0/PMBus. # 2.3.20 Universal synchronous/asynchronous receiver transmitters (USARTs) The STM32F103xF and STM32F103xG performance line embeds three universal synchronous/asynchronous receiver transmitters (USART1, USART2 and USART3) and two universal asynchronous receiver transmitters (UART4 and UART5). These five interfaces provide asynchronous communication, IrDA SIR ENDEC support, multiprocessor communication mode, single-wire half-duplex communication mode and have LIN Master/Slave capability. The USART1 interface is able to communicate at speeds of up to 4.5 Mbit/s. The other available interfaces communicate at up to 2.25 Mbit/s. USART1, USART2 and USART3 also provide hardware management of the CTS and RTS signals, Smart Card mode (ISO 7816 compliant) and SPI-like communication capability. All interfaces can be served by the DMA controller except for UART5. # 2.3.21 Serial peripheral interface (SPI) Up to three SPIs are able to communicate up to 18 Mbits/s in slave and master modes in full-duplex and simplex communication modes. The 3-bit prescaler gives 8 master mode frequencies and the frame is configurable to 8 bits or 16 bits. The hardware CRC generation/verification supports basic SD Card/MMC modes. All SPIs can be served by the DMA controller. # 2.3.22 Inter-integrated sound (I<sup>2</sup>S) Two standard I<sup>2</sup>S interfaces (multiplexed with SPI2 and SPI3) are available, that can be operated in master or slave mode. These interfaces can be configured to operate with 16/32 bit resolution, as input or output channels. Audio sampling frequencies from 8 kHz up to 48 kHz are supported. When either or both of the I<sup>2</sup>S interfaces is/are configured in master mode, the master clock can be output to the external DAC/CODEC at 256 times the sampling frequency. #### 2.3.23 SDIO An SD/SDIO/MMC host interface is available, that supports MultiMediaCard System Specification Version 4.2 in three different databus modes: 1-bit (default), 4-bit and 8-bit. The interface allows data transfer at up to 48 MHz in 8-bit mode, and is compliant with SD Memory Card Specifications Version 2.0. The SDIO Card Specification Version 2.0 is also supported with two different databus modes: 1-bit (default) and 4-bit. The current version supports only one SD/SDIO/MMC4.2 card at any one time and a stack of MMC4.1 or previous. In addition to SD/SDIO/MMC, this interface is also fully compliant with the CE-ATA digital protocol Rev1.1. #### 2.3.24 Controller area network (CAN) The CAN is compliant with specifications 2.0A and B (active) with a bit rate up to 1 Mbit/s. It can receive and transmit standard frames with 11-bit identifiers as well as extended frames with 29-bit identifiers. It has three transmit mailboxes, two receive FIFOs with 3 stages and 14 scalable filter banks. # 2.3.25 Universal serial bus (USB) The STM32F103xF and STM32F103xG performance line embed a USB device peripheral compatible with the USB full-speed 12 Mbs. The USB interface implements a full-speed (12 Mbit/s) function interface. It has software-configurable endpoint setting and suspend/resume support. The dedicated 48 MHz clock is generated from the internal main PLL (the clock source must use a HSE crystal oscillator). # 2.3.26 GPIOs (general-purpose inputs/outputs) Each of the GPIO pins can be configured by software as output (push-pull or open-drain), as input (with or without pull-up or pull-down) or as peripheral alternate function. Most of the GPIO pins are shared with digital or analog alternate functions. All GPIOs are high current-capable. The I/Os alternate function configuration can be locked if needed following a specific sequence in order to avoid spurious writing to the I/Os registers. # 2.3.27 ADC (analog to digital converter) Three 12-bit analog-to-digital converters are embedded into STM32F103xF and STM32F103xG performance line devices and each ADC shares up to 21 external channels, performing conversions in single-shot or scan modes. In scan mode, automatic conversion is performed on a selected group of analog inputs. Additional logic functions embedded in the ADC interface allow: - Simultaneous sample and hold - Interleaved sample and hold - Single shunt The ADC can be served by the DMA controller. An analog watchdog feature allows very precise monitoring of the converted voltage of one, some or all selected channels. An interrupt is generated when the converted voltage is outside the programmed thresholds. The events generated by the general-purpose timers (TIMx) and the advanced-control timers (TIM1 and TIM8) can be internally connected to the ADC start trigger and injection trigger, respectively, to allow the application to synchronize A/D conversion and timers. # 2.3.28 DAC (digital-to-analog converter) The two 12-bit buffered DAC channels can be used to convert two digital signals into two analog voltage signal outputs. The chosen design structure is composed of integrated resistor strings and an amplifier in inverting configuration. This dual digital Interface supports the following features: - two DAC converters: one for each output channel - 8-bit or 12-bit monotonic output - left or right data alignment in 12-bit mode - synchronized update capability - noise-wave generation - triangular-wave generation - dual DAC channel independent or simultaneous conversions - DMA capability for each channel - external triggers for conversion - input voltage reference V<sub>RFF+</sub> Eight DAC trigger inputs are used in the STM32F103xF and STM32F103xG performance line family. The DAC channels are triggered through the timer update outputs that are also connected to different DMA channels. # 2.3.29 Temperature sensor The temperature sensor has to generate a voltage that varies linearly with temperature. The conversion range is between 2 V < $V_{DDA}$ < 3.6 V. The temperature sensor is internally connected to the ADC1\_IN16 input channel which is used to convert the sensor output voltage into a digital value. # 2.3.30 Serial wire JTAG debug port (SWJ-DP) The ARM SWJ-DP Interface is embedded, and is a combined JTAG and serial wire debug port that enables either a serial wire debug or a JTAG probe to be connected to the target. The JTAG TMS and TCK pins are shared respectively with SWDIO and SWCLK and a specific sequence on the TMS pin is used to switch between JTAG-DP and SW-DP. # 2.3.31 Embedded Trace Macrocell™ The ARM® Embedded Trace Macrocell provides a greater visibility of the instruction and data flow inside the CPU core by streaming compressed data at a very high rate from the STM32F10xxx through a small number of ETM pins to an external hardware trace port analyzer (TPA) device. The TPA is connected to a host computer using USB, Ethernet, or any other high-speed channel. Real-time instruction and data flow activity can be recorded and then formatted for display on the host computer running debugger software. TPA hardware is commercially available from common development tool vendors. It operates with third party debugger software tools. # 3 Pinouts and pin descriptions Figure 3. STM32F103xF/G BGA144 ballout 1. The above figure shows the package top view.