色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 用C語言和ARM匯編語言設(shè)置SDRAM的慣用方法

          用C語言和ARM匯編語言設(shè)置SDRAM的慣用方法

          作者: 時間:2016-11-10 來源:網(wǎng)絡(luò) 收藏
          用C語言設(shè)置SDRAM的慣用方法

          /* SDRAM regisers */

          本文引用地址:http://cafeforensic.com/article/201611/317091.htm

          #defineMEM_CTL_BASE0x48000000// BWSCON的地址

          #defineSDRAM_BASE0x30000000// SDRAM的起始地址

          /* SDRAM 13個寄存器的值*/

          /*定義了一個數(shù)組,把13個寄存器的設(shè)置值存到一個數(shù)組里面*/

          unsignedlongconstmem_cfg_val[]={//注意unsignedlongconst的含義…

          0x22111110,//BWSCON

          0x00000700,//BANKCON0

          0x00000700,//BANKCON1

          0x00000700,//BANKCON2

          0x00000700,//BANKCON3

          0x00000700,//BANKCON4

          0x00000700,//BANKCON5

          0x00018005,//BANKCON6

          0x00018005,//BANKCON7

          0x008e07a3,//REFRESH

          0x000000b2,//BANKSIZE

          0x00000030,//MRSRB6

          0x00000030,//MRSRB7

          };

          /*設(shè)置控制SDRAM的13個寄存器*/

          /* for循環(huán)總共13次,剛好對13個寄存器賦值完畢*/

          void memsetup()

          {

          inti = 0;

          unsignedlong*p = (unsignedlong *)MEM_CTL_BASE;

          for(; i < 13; i++)

          p[i] = mem_cfg_val[i];

          }

          ARM匯編語言設(shè)置SDRAM的慣用方法

          @******************************************************************************

          @ File:head.s

          @功能:設(shè)置SDRAM,將程序復(fù)制到SDRAM,然后跳到SDRAM繼續(xù)執(zhí)行

          @******************************************************************************

          .equMEM_CTL_BASE,0x48000000

          .equSDRAM_BASE,0x30000000

          .text

          .global _start

          _start:

          bldisable_watch_dog

          blmemsetup

          blcopy_steppingstone_to_sdram

          ldrpc,=set_sp@跳到SDRAM中繼續(xù)執(zhí)行

          halt_loop:

          bhalt_loop

          memsetup:

          @ initialize the static memory

          @ set memory control registers

          movr1,#MEM_CTL_BASE

          adrlr2,mem_cfg_val@ adrl用于搬運地址

          movr3, #0x0@給r3清零(自己加上的一條指令)

          addr3,r1, #52@ 52 == 4*13

          1:

          ldrr4,[r2], #4

          strr4,[r1], #4

          cmpr1,r3

          bne1b@每次遞增4個字節(jié),共循環(huán)13次(設(shè)置13個寄存器)

          movpc,lr



          評論


          技術(shù)專區(qū)

          關(guān)閉