3/106
TABLE OF CONTENTS
ST52F510/F513/F514
1 GENERAL DESCRIPTION .... . . .. .... ... .. . . .. .. . . . ... ... .. . . .. ... 7
1.1 Introduction . . . . . . . . . . .... . . . . .. . . . . . . . . . . . . . ... ... . ... ... . ... .. . . ... .. . .... . . .7
1.2 Functional Description . . .... . . .. .. .. .. . . . . . . . ... .... .... ... . ... .. . . . . . . . . . . . . . . .8
1.2.1 Memory Programming Mode . . . . . . . . . . . . . . . . . .... . . . .... .... .. . . . . . . . . . . . . . . 8
1.2.2 Working Mode. .... ... . . . . . . . . ... .. . . ... . ... .. . . . . .... . . . ... .. .. . . . . . ... . . 8
1.3 Pin Description . . . . . . . .... . . . . .. . . . . . . . . . . . . . ... ... . ... ... . ... .. . . ... .. . .... . .15
2 INTERNAL ARCHITECTURE. . . . . . . . . . . . . .... . ... . . .... ... .. . . .. .. 16
2.1 Control Unit and Data Processing Unit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .... . .16
2.1.1 Program Counter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .... . . . ... .. .. . . . . . ... . 17
2.1.2 Flags. . . . . . . . . . . .... . . . . .. . . . . . . . . . . . . . ... ... . ... ... . ... .. . . ... .. . .... . 17
2.2 Arithmetic Logic Unit . . . . . . . . . . . . . . . . . . . . . . . . . . . . .... . . . .... . . . . .. . . . . . . . . . . . . . .18
2.3 Register Description . . . . .... . . .. .. .. .. . . . . . . . ... .... .... ... . ... .. . . . . . . . . . . . . . .19
3 ADDRESSING SPACES. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .... . ... 20
3.1 Memory Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .... . . . .... . . . ... . . . . ... .. .. . . .20
3.2 Register File . . . . . . . . . .... .... .. . . . . . . . . .... . ... ... . ... .. .. .. . . . . . ... .. . .... . .20
3.3 Program/Data Memory . . . . . . . . . . . . . . . . . . . . . . . . . . .... . . . .... .... .. . . . . . . . . . . . . . .20
3.4 System and User Stacks.... . . . . .. . . . . . . . . .... . ... ... . ... ... . . . . . . . . ... .. . .... . .22
3.5 Input Registers . . . . . . . . .... . . .. .. .. .. . . . . . . . ... .... .... ... . ... .. . . . . . . . . . . . . . .23
3.6 Output registers . . . . . . .... .... .. . . . . . . . . .... . ... ... . ... .. .. .. . . . . . ... .. . .... . .23
3.7 Configuration Registers & Option Bytes . . . . . . . .... . . . ... . . . . . . . . . . . . . . . .... . ... ... .23
4 MEMORY PROGRAMMING . . . . . . . . . . . . . .... .. . . ... . . . .... ... .. . . . 30
4.1 Program/Data Memory Organization . . . . . . . . . . . . . . . .... .... ... . ... .. . . . . . . . . . . . . . .30
4.2 Memory Programming . . . . . . . . . . . . . . . . . . . . . . ... . . . . . . . . . ... .. .. ... .. .. .. . . . . ...31
4.2.1 Programming Mode start . . . . . . . . . . . . . . . . . . . . . . . . . . . .... . . . ... .. .. . . . . . ... . 31
4.2.2 Fast Programming procedure. . . . . . . . . . . . . . . . . .... . . . .... .... .. . . . . . . . . . . . . . 32
4.2.3 Random data writing. . . . . . . . . . . . . . . . . . . . . . . . .... .... ... . ... .. . . . . . . . . . . . . . 32
4.2.4 Option Bytes Programming. . . . . . . . . . . . . . . . . . . .... . . . . ... .... .. . . . . . . . . . . . . . 33
4.3 Memory Verify. .... .... ... . . . . . . . . ... .. . . ... . ... .. . . . . .... . . . ... .. .. . . . . . ... . .34
4.3.1 Fast read procedure . . . .... .. . . . . . . . . .... . ... ... . . . . . . . . . . . . . . . ... .. . .... . 34
4.3.2 Random data reading . . .... .. . .... .. . .... . ... .. .. .. . . . . . . . . . . . . ... .. . . ... . 35
4.4 Memory Lock . .... .... ... . ... .. .. ... .. . . ... . ... .. .. .. . .... ... . . . . . . . ... .. . ...35
4.5 ID Code. . . . . . .... . . . .... .... .. . .... .. . .... . ... .. .. .. . . . . . . . . . . . . ... .. . .... . .36
4.6 Error cases . .... .. . .... .. . .... . ... .. . . . . .... .... .. . . . . . . . . . . . . . ... ... . . . . . . . .36
4.7 In-Situ Programming (ISP) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .... . . . ... .. .. . . . . . ... . .37
4.8 In-Application Programming (IAP) . . . . . . . . . . .... . ... ... . ... ... . . . . . . . . ... .. . .... . .37
4.8.1 Single byte write . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .... . . . ... .. .. . . . . . ... . 37
4.8.2 Block write . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .... . . . .... . . . . .. . . . . . . . . . . . . . 37
4.8.3 Memory Corruption Prevention. . . . . . . . . . . . . . . . . . . . . . . .... . . . ... .. .. . . . . . ... . 37
4.8.4 Option Bytes . . . . . . . . . . . . . . . . . . . . . . . . . . ... . . . . . . . . . ... .. .. ... .. .. .. . . . . . . 38
4.8.5 Input Register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .... . . . .... .... .. . . . . . . . . . . . . . 38
TABLE OF
CONTENTS