目的: 在LCD上显示一个英文字母和一个中文。<从字母和汉字的点阵里面取出它的数据,然后搬到LCD上面去>
原理:在内存中划出一块空间(FrameBuffer或显存),工作的时候LCD控制器会从FrameBuffer中取出若干字节的数据(若干字节的数据代表一个像素),发到LCD显示屏上
回顾:以前我们在LCD驱动中测试,显示hello字符:echo hello > /dev/tty1
(对于/dev/tty说明点我跳转), 显然在lcd上显示一个字符,肯定有它的点阵。echo hello
只输入了hello
的ascii码,那么怎么根据这个ascii码怎么得到它的点阵。->推测在内核中肯定含有英文字母的点阵。
①显示英文字符’A’
Linux3.4.2: SI -> <font.c> 8x16
(选这个和16*16的中文点阵高度匹配)
描绘一下字母’A’:16字节((8 x 16bit / 8))每一个英文字母用16字节表示;对于英文字符非常简单,直接给出一个数组,搜索一下A的点阵0x41:
②显示中文字符
中文字符点阵在HZK里面,每个占据((16 x 16bit / 8)) = 32字节;存储详情点我跳转
以’中’为例:D6(区码) D0(位码)
区:表示哪一块
位:一块里面的哪一个
D6 - A1
就可以得到哪一块;D0 - A1
表示这一块里面的哪一个为了兼容英文字符,并不是从0开始而是从A1开始
③根据上面原理来写代码:
show_font.c:里面注释已经很详细 了
注释:编写show_font.c时候遇到的一个小问题,标注一下
error: invalid use of undefined type ‘struct fb_var_screeninfo’
这个结构体我们需要包含一个头文件
fb.h
,看一下我们的交叉编译工具链有没有fb.h
有的,那么证明linux3.4.2下肯定有fb.h,如图:
那我们直接包含进show_font.c中就可以解决。
- 编译show_font.c:arm-linux-gcc -o show_font show_font.c
④ 在开发板中的文件系统上挂载ubnubtu的文件夹。
mount -t nfs -o nolock 192.168.2.3:/work/nfs_root/smxk /mnt
⑤把程序拷贝到我们的网络文件系统中:
cp HZK16 show_font /work/nfs_root/smxk
—————>
⑥ 测试:
Ⅰ、配置内核:我们内核里面没有加入LCD的支持,配置、修改内核支持把lcd.c编译进去(代码在上面)。<关于lcd.c驱动编写点我跳转>
cp /mnt/hgfs/czg/smxk/002*/lcd.c drivers/video/
Ⅱ、使用新内核启动
vim drivers/video/Makefile
/2410 把原来的lcd驱动给注释掉 -> lcd.o
make menuconfig : 配置内核把LCD给包含进去
Device Drivers -> Graphics support ->Support for frame buffer devices
–>Y> s3c2410 LCD framebuffer support (以前是作为模块,现在输入Y编译进内核里面去)
EXIT保存make uImage
编译完成后 把内核拷贝到网络文件系统中去:
cp arch/arm/boot/uImage /work/nfs_root/smxk
使用新内核来启动:
nfs 32000000 192.168.2.3:/work/nfs_root/smxk/uImage; bootm 32000000
注释:
启动过程后发现根文件系统的DM9000网卡没有:
解决:换成毕业班视频的uboot:u-boot_new.bin
然后set set machid 7CF
进而nfs 32000000 192.168.2.3:/work/nfs_root/smxk/uImage; bootm 32000000