(一)LED点灯调试
FL2440电路总共有4个LED0,LED1,LED2,LED3,分别接到板子GPB5,GPB6,GPB8,GPB10引脚。通过设置三个寄存器GPBCON(0x56000010),GPBDAT(0x56000014),GPBUP(0x56000018),控制GPB[10:0]引脚可控LED的亮灭。
控制LED亮灭有三步:
1,设置GPB5,GPB6,GPB8,GPB10为输出工作方式,即GPBCON [21:20] = 01 GPBCON [17:16] = 01,GPBCON [13:12] = 01,GPBCON [11:10] = 01
2,GPBUP置0000 0101 0110 0000 即GPB5,GPB6,GPB8,GPB10皆禁止使能上拉
3,设置GPBDAT寄存器,低电平LED亮
例子:
#define GPBCON 0x56000010/*设置GPB5,GPB6,GPB8,GPB10工作方式*/
#define GPBDAT 0x56000014 /*输出端口,控制LED亮灭*/
#define GPBUP 0x56000018 /*禁止使能上拉*/
ldr r0, =GPBCON /*Set GPIO5, GPIO6, GPIO8, GPIO10 as GPIO OUTPUT mode */
ldr r1, [r0]
ldr r1, =0x00295550
str r1, [r0]
ldr r0, =GPBUP /*Set bit 5,6,8,10, disable pullup resister*/
ldr r1, [r0]
orr r1, r1, #0x0560 /*0000 0101 0110 0000 */
str r1, [r0]
ldr r2, =GPBDAT
ldr r3, [r2]
orr r3, r3, #0x0540 /*Set bit 6,8,10 as high level and bit 5 as low, Turn On LED0*/
str r3, [r2]
以下附上部分原理图,具体参考s3c2440的datasheet,以及fl2440电路原理图
(二)u-boot加载地址
基于FL2440板子,配有64M的SDRAM,并且挂载到nGCS6(0x3000 0000),所以64M的SDRAM
寻址范围:0x3000 0000 – 0x3400 0000。
在我修改 u-boot-2010.09/board/lingyun/ly2440/config.mk文件如下:
# (C) Copyright 2002 # Gary Jennejohn, DENX Software Engineering,# David Mueller, ELSOFT AG, # # SAMSUNG SMDK2410 board with S3C2410X (ARM920T) cpu # # see http://www.samsung.com/ for more information on SAMSUNG # # # SMDK2410 has 1 bank of 64 MB DRAM # # 3000'0000 to 3400'0000 # # Linux-Kernel is expected to be at 3000'8000, entry 3000'8000 # optionally with a ramdisk at 3080'0000 # # we load ourself to 33F8'0000 # # download area is 3300'0000 TEXT_BASE = 0x33F80000
总结:
1,Linux系统自启过程中,u-boot默认加载到 0x33f8 0000运行, Linux-Kernel则默认加载到0x3000 8000运行。
2,用J-TAG调试阶段,u-boot临时下载到0x33f8 0000运行。
3,在移植阶段,需把u-boot和Linux-Kernel烧写到NANDFLASH,但是不能直接烧写。所以先TFTP下载到内存,
再由内存下载到NANDFLASH,因此临时下载到0x3000 8000地址,并且不会覆盖已经运行的u-boot(通过J-TAG
下载到地址0x33f8 0000运行,由0x3000 8000到0x33f8 0000 为15M空间,本次u-boot和Linux-Kernel大小都小于15M)
4,总之,移植过程J-TAG下载阶段借用0x33f8 0000地址下载;TFTP下载阶段借用0x3000 8000地址下载。
也可以用其他地址临时烧写,但是必须保证不能冲突,覆盖已经运行的u-boot。