微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 2440裸机学习心得(上)

2440裸机学习心得(上)

时间:11-29 来源:互联网 点击:
哎,以前总想裸机加系统一齐学,学着学着发现好混乱,D驱动~~然后又重新斋跑2440的裸机。以下系少少心得,记录下学习过程。

里面有三个地方还没弄好:1、 硬盘的文件系统 FAT部分(后面有空补补)

2、 NORFLASH中的读写有点问题

3、 USB主机中对U盘的UFI命令

有什么问题欢迎一起交流。以下是部分心得:

LED

GPXCON中每两位控制一个引脚:00输入,01输出,10特殊功能

初始化 rGPBCON , rGPBUP ,rGPBDAT三个寄存器

关于ADS配置的解释:

在Target Settings中的Post-linker中选择ARM fromELF,因为我们需要把ELF文件格式转化为下载到flash中所必须的二进制文件。

在Language Settings中的所有语言的Target下的Architecture or Processor,选择ARM920T,因为s3c2440是ARM920T内核。

在ARM Linker中的Output中的RO Base填写0x30000000,因为在开发板上SDRAM是从0x30000000地址开始。在Layout中的Object/Symbol中填写2440init.o,它是启动文件的目标文件,在Section中填写Init,它是在启动文件中我们所定义的入口代码段的名称。

外部中断

我们要打开某一中断的屏蔽,这样才能响应该中断,相对应的寄存器为INTMSK;

还要设置外部中断的触发方式,如低电平、高电平、上升沿、下降沿等,相对应的寄存器为EXTINTn。

另外由于EINT4到EINT7共用一个中断向量,EINT8到EINT23也共用一个中断向量,而INTMSK只负责总的中断向量的屏蔽,要具体打开某一具体的中断屏蔽,还需要设置EINTMASK。

有一些中断是共用一个中断向量的,而一个中断向量只能有一个中断执行函数,因此具体是哪个外部中断,还需要EINTPEND或rINTOFFSET来判断

使用__irq这个关键词来定义中断处理函数,这样系统会为我们自动保存一些必要的变量,并能够在中断处理函数执行完后正确地返回

这种形式:void __irq key(); pISR_EINT0=(int)key;

定时器使用

主要配置:外部时钟源→通过寄存器MPLLCON得到FCLK→再通过寄存器CLKdivN得到HCLK和PCLK->再得到定时器的工作频率

PWM定时器使用:

蜂鸣器=GPB0=TOUT0=定时器0

蜂鸣器高电平响,低电平不响

关键是设置寄存器TCNTBn和TCMPBn,前者可以确定一个计数周期的时间长度,而后者可以确定方波的占空比

定时器中断使用:

不需要配置TCMPBn,只需TCNTBn,TCNTBn*1/定时器的工作频率=定时的时间

但要记住中断要:

void __irq timer0_sever();

pISR_TIMER0=(int)timer0_sever;

rINTMSK =~BIT_TIMER0;

Uart

主要配置以下寄存器:

UBRdivn,UCONn,UTRSTATn

收发寄存器: UTXHn,URXHn

注意几点:

1.对于s3c2440来说,接收数据是被动的,发送数据是主动的,因此一般来说,接收数据用中断方式,发送数据用查询方式较好;

2.在中断方式下,当接收到数据时,尽管可能该数据无用,但也一定要读取它,否则下次再接收数据时,不会再引起中断,因为接收数据缓存器被上次接收到的数据所霸占,只要没有读取它,它就永远在那里;

3.由于UART中断涉及到SUBSRCPND寄存器,因此在中断处理程序中不仅要清SRCPND寄存器,还要清SUBSRCPND寄存器,它们的顺序一定是先清SUBSRCPND寄存器,再清SRCPND寄存器,否则就会引起一个中断两次响应的问题。因为是否中断由SRCPND寄存器决定,而SRCPND寄存器的相关状态位由SUBSRCPND寄存器决定

简单的串口控制台:1.键盘输入数据后在控制台上进行回显

recv_data = uart_getc();

return recv_data;

2.让接收的字符组成命令data_buf[i] = uart0_scanf();

if(data_buf[i] == )

3回车——命令判断、退格——删除字符、判断命令后进入相应分支进行处理

else if(data_buf[i] == )

if(!(no_system_strcmp("read iic",cmd_buf)))

LCD(4.3寸,480*272)

在2440中时钟设置是FCLK:HCLK:PCLK=400:100:50

注意两点:

1时序,参数的设置

VCLK是像素时钟信号。VCLK=HCLK÷[(CLKVAL+1)×2]

例如,HCLK的频率为100MHz,要想驱动像素时钟信号为6.4MHz的LCD屏,则通过上式计算CLKVAL值

在s3c2440中,所有的这些信号(VSPW、VFPD、VBPD、LINEVAL、HBPD、HFPD、HSPW和HOZVAL)都是实际值减1的结果。这些值是通过寄存器LCDCON2、LCDCON3和LCDCON4来配置

行频(HSF)和场频(VSF):

HSF=VCLK÷[(HSPW+1)+(HSPD+1)+(HFPD+1)+(HOZVAL+1)]

=7.1÷408=17.5kHz

VSF=HSF÷[(VSPW+1)+(VBPD+1)+(VFPD+1)+(LINEVAL+1)]

=17.5÷270=64.8Hz

2、显示缓存区

一般我们是通过定义一个与屏幕尺寸大小相同的二维数组来开辟该空间的,这样控制屏幕内容会方便一些,如当屏幕

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top