日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀].equMEM_CTL_BASE,0x48000000.equSDRAM_BASE,0x30000000.text.global _start_start:bldisable_watch_dog@關(guān)閉WATCHDOG,否則CPU會(huì)不斷重啟blmemsetup@設(shè)置存儲(chǔ)控制器blcopy_steppingstone_to_sdram@賦值代碼到SDRAM中

.equMEM_CTL_BASE,0x48000000
.equSDRAM_BASE,0x30000000

.text
.global _start
_start:
bldisable_watch_dog@關(guān)閉WATCHDOG,否則CPU會(huì)不斷重啟
blmemsetup@設(shè)置存儲(chǔ)控制器
blcopy_steppingstone_to_sdram@賦值代碼到SDRAM中
ldrpc,=on_sdram@跳到SDRAM中繼續(xù)執(zhí)行
on_sdram:
ldrsp,=0x34000000@設(shè)置棧
blmain
halt_loop:
bhalt_loop

disable_watch_dog:
@往WATCHDOG寄存器寫(xiě)0
movr1,#0x53000000
movr2,#0x0
strr2,[r1]
movpc,lr@返回

copy_steppingstone_to_sdram:
@講STEPPINGSTONE的4KB數(shù)據(jù)全部復(fù)制到SDARM中。
@Steppingstone起始地址為0x00000000,SDRAM中的起始地址為0x30000000

movr1,#0
ldrr2,=SDRAM_BASE
movr3,#1024*4

1:
ldrr4,[r1],#4@從steppingstone讀取4字節(jié)數(shù)據(jù),并讓源地址加4
ldrr4,[r1],#4@將此4字節(jié)的數(shù)據(jù)復(fù)制到SDRAM中,并讓目地地址加4
cmpr1,r3@判斷是否完成:源地址等于Steppingstone的末地址
bne1b@若沒(méi)有復(fù)制完,繼續(xù)
movpc,lr@返回

memsetup:
@設(shè)置存儲(chǔ)控制器以便使用SDRAM等外設(shè)

movr1,#MEM_CTL_BASE@存儲(chǔ)控制器的13個(gè)寄存器的開(kāi)始地
adrlr2, mem_cfg_val@ 這13個(gè)值的起始存儲(chǔ)地址
addr3,r1,#52@13*4=52
1:
ldrr4,[r2],#4@讀取設(shè)置值,并讓R2加4
strr4,[r1],#4@將此值寫(xiě)入寄存器,并讓r1加4
cmpr1,r3@判斷是否設(shè)置完所有13個(gè)寄存器
bne1b@若沒(méi)有寫(xiě)完,繼續(xù)
movpc,lr@返回
.align 4
mem_cfg_val:
@存儲(chǔ)控制器13個(gè)寄存器的設(shè)置值
.long0x22011110@BWSCON
.long 0x00000700@BANKCON0
.long 0x00000700@BANKCON1
.long0x00000700@BANKCON2
.long0x00000700@BANKCON3
.long0x00000700@BANKCON4
.long 0x00000700@BANKCON5
.long0x00018005@BANKCON6
.long0x00018005@BANKCON7
.long0x008c07a3@REFRESH
.long0x000000b1@BANKSIZE
.long0x00000030@MRSRB6
.long0x00000030@MRSRB7

#define GPFCON(*(volatile unsigned long *)0x56000050)
#define GPFDAT(*(volatile unsigned long *)0x56000054)

#define GPF4_OUT(1<<(2*4))
#define GPF5_OUT(1<<(2*5))
#define GPF6_OUT(1<<(2*6))

void Delay(volatile unsigned long dly)
{
for(;dly>0;dly--);
}

int main()
{
unsigned long i=0;

GPFCON=GPF4_OUT|GPF5_OUT|GPF6_OUT;

while(1)
{
Delay(10000);
GPFDAT=(~(i<<4));
if(++i==8)
i=0;
}
return 0;
}
sdram.bin:head.S leds.c
arm-linux-gcc -c -o head.o head.S
arm-linux-gcc -c -o leds.o leds.c
arm-linux-ld -Ttext 0x30000000 head.o leds.o -o sdram_elf
arm-linux-objcopy -O binary -S sdram_elf sdram.bin
arm-linux-objdump -D -m arm sdram_elf > sdram.dis
clean:
rm -f sdram.dis sdram.bin sdram_elf *.o

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關(guān)閉