⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sysinit.lst

📁 Cortex-M4+example
💻 LST
📖 第 1 页 / 共 3 页
字号:
###############################################################################
#                                                                             #
# IAR ANSI C/C++ Compiler V6.10.1.52143/W32 for ARM     16/Apr/2011  20:57:48 #
# Copyright 1999-2010 IAR Systems AB.                                         #
#                                                                             #
#    Cpu mode     =  thumb                                                    #
#    Endian       =  little                                                   #
#    Source file  =  E:\Project\15_K60\03_Software\02_My                      #
#                    program\K60_IAR\03_uart_int\src\Sources\C\Frame_C\sysini #
#                    t.c                                                      #
#    Command line =  "E:\Project\15_K60\03_Software\02_My                     #
#                    program\K60_IAR\03_uart_int\src\Sources\C\Frame_C\sysini #
#                    t.c" -D IAR -D TWR_K60N512 -lCN                          #
#                    "E:\Project\15_K60\03_Software\02_My                     #
#                    program\K60_IAR\03_uart_int\bin\Ram\List\" -lB           #
#                    "E:\Project\15_K60\03_Software\02_My                     #
#                    program\K60_IAR\03_uart_int\bin\Ram\List\" -o            #
#                    "E:\Project\15_K60\03_Software\02_My                     #
#                    program\K60_IAR\03_uart_int\bin\Ram\Obj\" --no_cse       #
#                    --no_unroll --no_inline --no_code_motion --no_tbaa       #
#                    --no_clustering --no_scheduling --debug --endian=little  #
#                    --cpu=Cortex-M4 -e --fpu=None --dlib_config              #
#                    D:\iar\arm\INC\c\DLib_Config_Normal.h -I                 #
#                    "E:\Project\15_K60\03_Software\02_My                     #
#                    program\K60_IAR\03_uart_int\src\Sources\H\" -I           #
#                    "E:\Project\15_K60\03_Software\02_My                     #
#                    program\K60_IAR\03_uart_int\src\Sources\H\Component_H\"  #
#                    -I "E:\Project\15_K60\03_Software\02_My                  #
#                    program\K60_IAR\03_uart_int\src\Sources\H\Frame_H\" -Ol  #
#                    --use_c++_inline                                         #
#    List file    =  E:\Project\15_K60\03_Software\02_My                      #
#                    program\K60_IAR\03_uart_int\bin\Ram\List\sysinit.lst     #
#    Object file  =  E:\Project\15_K60\03_Software\02_My                      #
#                    program\K60_IAR\03_uart_int\bin\Ram\Obj\sysinit.o        #
#                                                                             #
#                                                                             #
###############################################################################

E:\Project\15_K60\03_Software\02_My program\K60_IAR\03_uart_int\src\Sources\C\Frame_C\sysinit.c
      1          //-------------------------------------------------------------------------*
      2          // 文件名:sysinit.c                                                        *
      3          // 说  明: 系统配置文件                                                    *
      4          //-------------------------------------------------------------------------*
      5          
      6          #include "sysinit.h"	//头文件
      7          
      8          //全局变量声明

   \                                 In section .bss, align 4
      9          int core_clk_khz;
   \                     core_clk_khz:
   \   00000000                      DS8 4

   \                                 In section .bss, align 4
     10          int core_clk_mhz;
   \                     core_clk_mhz:
   \   00000000                      DS8 4

   \                                 In section .bss, align 4
     11          int periph_clk_khz;
   \                     periph_clk_khz:
   \   00000000                      DS8 4
     12          
     13          //-------------------------------------------------------------------------*
     14          //函数名: sysinit                                                          *
     15          //功  能: 系统设置                                                         * 
     16          //参  数: 无						  	           *	
     17          //返  回: 无                                                               *
     18          //说  明: 无                                                               *
     19          //-------------------------------------------------------------------------*

   \                                 In section .text, align 2, keep-with-next
     20          void sysinit (void)
     21          {
   \                     sysinit:
   \   00000000   80B5               PUSH     {R7,LR}
     22              //使能IO端口时钟    
     23              SIM_SCGC5 |= (SIM_SCGC5_PORTA_MASK
     24                                        | SIM_SCGC5_PORTB_MASK
     25                                        | SIM_SCGC5_PORTC_MASK
     26                                        | SIM_SCGC5_PORTD_MASK
     27                                        | SIM_SCGC5_PORTE_MASK );
   \   00000002   ....               LDR.N    R0,??DataTable3  ;; 0x40048038
   \   00000004   0068               LDR      R0,[R0, #+0]
   \   00000006   50F47850           ORRS     R0,R0,#0x3E00
   \   0000000A   ....               LDR.N    R1,??DataTable3  ;; 0x40048038
   \   0000000C   0860               STR      R0,[R1, #+0]
     28          
     29              //开启系统时钟
     30              core_clk_mhz = pll_init(CORE_CLK_MHZ, REF_CLK);
   \   0000000E   0321               MOVS     R1,#+3
   \   00000010   0220               MOVS     R0,#+2
   \   00000012   ........           BL       pll_init
   \   00000016   ....               LDR.N    R1,??DataTable3_1
   \   00000018   0860               STR      R0,[R1, #+0]
     31              //通过pll_init函数的返回值来计算内核时钟和外设时钟
     32              core_clk_khz = core_clk_mhz * 1000;
   \   0000001A   ....               LDR.N    R0,??DataTable3_1
   \   0000001C   0068               LDR      R0,[R0, #+0]
   \   0000001E   4FF47A71           MOV      R1,#+1000
   \   00000022   4843               MULS     R0,R1,R0
   \   00000024   ....               LDR.N    R1,??DataTable3_2
   \   00000026   0860               STR      R0,[R1, #+0]
     33              periph_clk_khz = core_clk_khz / (((SIM_CLKDIV1 & SIM_CLKDIV1_OUTDIV2_MASK) >> 24)+ 1);
   \   00000028   ....               LDR.N    R0,??DataTable3_2
   \   0000002A   0068               LDR      R0,[R0, #+0]
   \   0000002C   ....               LDR.N    R1,??DataTable3_3  ;; 0x40048044
   \   0000002E   0968               LDR      R1,[R1, #+0]
   \   00000030   C1F30361           UBFX     R1,R1,#+24,#+4
   \   00000034   491C               ADDS     R1,R1,#+1
   \   00000036   B0FBF1F0           UDIV     R0,R0,R1
   \   0000003A   ....               LDR.N    R1,??DataTable3_4
   \   0000003C   0860               STR      R0,[R1, #+0]
     34              //使能跟踪时钟,用于调试
     35              trace_clk_init();	
   \   0000003E   ........           BL       trace_clk_init
     36              //FlexBus时钟初始化
     37              fb_clk_init();
   \   00000042   ........           BL       fb_clk_init
     38          
     39          }
   \   00000046   01BD               POP      {R0,PC}          ;; return
     40          
     41          //-------------------------------------------------------------------------*
     42          //函数名: trace_clk_init                                                   *
     43          //功  能: 跟踪时钟初始化                                                   * 
     44          //参  数: 无							  	   *	
     45          //返  回: 无                                                               *
     46          //说  明: 用于调试                                                         *
     47          //-------------------------------------------------------------------------*

   \                                 In section .text, align 2, keep-with-next
     48          void trace_clk_init(void)
     49          {
     50              //设置跟踪时钟为内核时钟
     51              SIM_SOPT2 |= SIM_SOPT2_TRACECLKSEL_MASK;	
   \                     trace_clk_init:
   \   00000000   ....               LDR.N    R0,??DataTable3_5  ;; 0x40048004
   \   00000002   0068               LDR      R0,[R0, #+0]
   \   00000004   50F48050           ORRS     R0,R0,#0x1000
   \   00000008   ....               LDR.N    R1,??DataTable3_5  ;; 0x40048004
   \   0000000A   0860               STR      R0,[R1, #+0]
     52              //在PTA6引脚上使能TRACE_CLKOU功能
     53              PORTA_PCR6 = ( PORT_PCR_MUX(0x7));
   \   0000000C   ....               LDR.N    R0,??DataTable3_6  ;; 0x40049018
   \   0000000E   4FF4E061           MOV      R1,#+1792
   \   00000012   0160               STR      R1,[R0, #+0]
     54          }
   \   00000014   7047               BX       LR               ;; return
     55          
     56          //-------------------------------------------------------------------------*
     57          //函数名: fb_clk_init                                                      *
     58          //功  能: FlexBus时钟初始化                                                * 
     59          //参  数: 无								   *	
     60          //返  回: 无                                                               *
     61          //说  明:                                                                  *
     62          //-------------------------------------------------------------------------*

   \                                 In section .text, align 2, keep-with-next
     63          void fb_clk_init(void)
     64          {
     65              //使能FlexBus模块时钟
     66              SIM_SCGC7 |= SIM_SCGC7_FLEXBUS_MASK;
   \                     fb_clk_init:
   \   00000000   ....               LDR.N    R0,??DataTable3_7  ;; 0x40048040
   \   00000002   0068               LDR      R0,[R0, #+0]
   \   00000004   50F00100           ORRS     R0,R0,#0x1
   \   00000008   ....               LDR.N    R1,??DataTable3_7  ;; 0x40048040
   \   0000000A   0860               STR      R0,[R1, #+0]
     67              //在PTA6引脚上使能FB_CLKOUT功能
     68              PORTC_PCR3 = ( PORT_PCR_MUX(0x5));
   \   0000000C   ....               LDR.N    R0,??DataTable3_8  ;; 0x4004b00c
   \   0000000E   4FF4A061           MOV      R1,#+1280
   \   00000012   0160               STR      R1,[R0, #+0]
     69          }
   \   00000014   7047               BX       LR               ;; return
     70          
     71          //-------------------------------------------------------------------------*
     72          //函数名: pll_init                                                         *
     73          //功  能: pll初始化                                                        * 
     74          //参  数: clk_option:时钟选项						   * 
     75          //		  crystal_val:时钟值                                       *	
     76          //返  回: 时钟频率值                                                       *
     77          //说  明:                                                                  *
     78          //-------------------------------------------------------------------------*

   \                                 In section .text, align 2, keep-with-next
     79          unsigned char pll_init(unsigned char clk_option, unsigned char crystal_val)
     80          {
   \                     pll_init:
   \   00000000   80B5               PUSH     {R7,LR}
   \   00000002   0A00               MOVS     R2,R1
     81              unsigned char pll_freq;
     82              
     83              if (clk_option > 3) {return 0;}   //如果没有选择可用的选项则返回0
   \   00000004   C0B2               UXTB     R0,R0            ;; ZeroExt  R0,R0,#+24,#+24
   \   00000006   0428               CMP      R0,#+4
   \   00000008   01D3               BCC.N    ??pll_init_0
   \   0000000A   0020               MOVS     R0,#+0
   \   0000000C   72E0               B.N      ??pll_init_1
     84              if (crystal_val > 15) {return 1;} // 如果如果可用的晶体选项不可用则返回1
   \                     ??pll_init_0:

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -