移植2期驱动到 Linux3.4.2内核

本文详细记录了将DM9000C网卡、LED、按键等驱动移植到Linux3.4.2内核的过程,包括分析错误、修改代码、编译内核模块和测试。此外,还涉及LCD显示、输入系统、块设备和虚拟网卡的移植。通过解决头文件、宏定义和函数不匹配等问题,成功实现了设备在新内核下的正常工作。
摘要由CSDN通过智能技术生成

移植2期驱动到 Linux3.4.2内核

移植:
1、编译
2、解决错误
2.1、头文件不对:去掉或改名
2.2、宏不对:改名使用新宏
2.3、有些函数没有了:改名使用新函数

1、移植DM9000C网卡

1.1、尝试挂载NFS

set machid 7cF //mini2440支持网卡
mount -t nfs -o nolock,vers=2 192.168.2.16:/work/nfs_root/first_fs /mnt

1.2、分析错误

mini2440支持网卡,可以挂载成功,但是smdk2440无法挂载成功
mach-mini2440.c中支持dm9000.c的平台设备,所以它能够使用网卡;smdk2440中没有支持
mini2440已经支持了自带的dm9000,其入口函数是:

platform_driver_register(&dm9000_driver);
    platform_driver dm9000_driver = {
         dm9000_probe
            platform_device mini2440_device_eth
                    platform_device *mini2440_devices[]
                        platform_add_devices(mini2440_devices, ARRAY_SIZE(mini2440_devices));
                        数组mini2440_devices[]被注册到内核里面了
我们使用的mach-smdk2440里面没有 
/* DM9000AEP 10/100 ethernet controller */
    static struct resource mini2440_dm9k_resource[] = {
        [0] = {
            .start = MACH_MINI2440_DM9K_BASE,
            .end   = MACH_MINI2440_DM9K_BASE + 3,
            .flags = IORESOURCE_MEM
        },
        [1] = {
            .start = MACH_MINI2440_DM9K_BASE + 4,
            .end   = MACH_MINI2440_DM9K_BASE + 7,
            .flags = IORESOURCE_MEM
        },
        [2] = {
            .start = IRQ_EINT7,
            .end   = IRQ_EINT7,
            .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE,
        }
    };
    /*
     * The DM9000 has no eeprom, and it's MAC address is set by
     * the bootloader before starting the kernel.
     */
    static struct dm9000_plat_data mini2440_dm9k_pdata = {
        .flags        = (DM9000_PLATF_16BITONLY | DM9000_PLATF_NO_EEPROM),
};

    static struct platform_device mini2440_device_eth = {
        .name        = "dm9000",
        .id        = -1,
        .num_resources    = ARRAY_SIZE(mini2440_dm9k_resource),
        .resource    = mini2440_dm9k_resource,
        .dev        = {
            .platform_data    = &mini2440_dm9k_pdata,
        },
};

1.3、修改代码

所以在mach-smdk2440.c里面添加:
#include <linux/dm9000.h>
。。。
在这里插入图片描述
在这里插入图片描述
解决串口乱码arch\arm\mach-s3c24xx\mach-smdk2440.c
s3c24xx_init_clocks(16934400);
改为
s3c24xx_init_clocks(12000000);

编译内核:
make uImage
cp arch/arm/boot/uImage /work/nfs_root/uImage_net

uboot:
nfs 32000000 192.168.2.16:/work/nfs_root/uImage_net
set machid 16a
bootm 32000000

进入文件系统:
ifconfig eth0 192.168.2.66
mount -t nfs -o nolock,vers=2 192.168.2.16:/work/nfs_root/fs_mini_mdev_new /mnt

把之前的DM9000C驱动程序放到服务器上,
修改里面的Makefile:
在这里插入图片描述
make
修改错误:dm9dev9000c.c中
去掉头文件:
在这里插入图片描述
包含头文件:
在这里插入图片描述
修改语法:
在这里插入图片描述
去掉函数SET_MODULE_OWNER:
在这里插入图片描述
修改私有成员使用类型:
在这里插入图片描述
改为:
在这里插入图片描述
修改网卡操作结构体dm9k_netdev_ops
在这里插入图片描述
在dmfe_probe1函数中:
在这里插入图片描述
去掉自带的dm9000_hash_table
在这里插入图片描述
使用内核的
在这里插入图片描述
17th_dm9000c$目录,把dm9dev9000c.c放入内核目录,编译进内核:
make
cp dm9dev9000c.c /work/system/linux-3.4.2/drivers/net/ethernet/davicom/
vi /work/system/linux-3.4.2/drivers/net/ethernet/davicom/Makefile
在这里插入图片描述
cd /work/system/linux-3.4.2
make uImage
cp arch/arm/boot/uImage /work/nfs_root/uImage_net_new

1.4、重启单板,启动内核

nfs 30000000 192.168.2.16:/work/nfs_root/uImage_net_new; bootm 30000000
ifconfig eth0 192.168.2.66
ifconfig
ping 192.168.2.16 -c 3
在这里插入图片描述
mount -t nfs -o nolock,vers=2 192.168.2.16:/work/nfs_root/fs_mini_mdev_new /mnt

使用NFS启动内核:
reboot
set bootargs console=ttySAC0,115200 root=/dev/nfs nfsroot=192.168.2.16:/work/nfs_root/fs_mini_mdev_new ip=192.168.2.55:192.168.2.16:192.168.2.1:255.255.255.0::eth0:off

nfs 30000000 192.168.2.16:/work/nfs_root/uImage_net_new; bootm 30000000

2、移植LED和按键

2.1、01_first_drv

修改Makefile:
在这里插入图片描述
添加/删除头文件:
在这里插入图片描述
修改添加/删除类下面的设备所用函数:
在这里插入图片描述
编译:
make
arm-linux-gcc -o firstdrvtest firstdrvtest.c
cp first_drv.ko firstdrvtest /work/nfs_root/fs_mini_mdev_new/

实验:
/ # insmod first_drv.ko
/ # ./firstdrvtest on
/ # ./firstdrvtest off
/ # rmmod first_drv

rmmod出现问题:
使用rmmod会出现 rmmod : chdir(/lib/modules): No such file or directory ?
现在内核模块在插入卸载时都会要转到 “/lib/modules/内核版本号/ ” 目录里。所以只要建立这个目录就行了。
在单板上执行:
mkdir -p /lib/modules/$(uname -r)

rmmod first_drv:即可卸载成功

2.2、02_second_drv

修改Makefile:
在这里插入图片描述
添加修改头文件:
在这里插入图片描述
修改创建设备的函数:
在这里插入图片描述
修改删除设备的函数
在这里插入图片描述
编译:
make
arm-linux-gcc -o seconddrvtest seconddrvtest.c
cp second_drv.ko firstdrvtest /work/nfs_root/fs_mini_mdev_new/

实验:
/ # insmod second_drv.ko
/ # ./seconddrvtest
/ # rmmod second_drv

2.3、03_third_drv

修改Makefile:
在这里插入图片描述
修改头文件:
在这里插入图片描述
修改宏S3C2410_GPxx为S3C2410_GPx(x):
在这里插入图片描述
修改触发方式的宏:
在这里插入图片描述
修改入口函数中的函数名称:
在这里插入图片描述
修改出口函数中卸载设备的函数:
在这里插入图片描述
编译:
make
arm-linux-gcc -o firstdrvtest firstdrvtest.c
cp first_drv.ko firstdrvtest /work/nfs_root/fs_mini_mdev_new/

实验:
/ # insmod third_drv.ko
/ # ./thirddrvtest
/ # rmmod third_drv

2.4、04_forth_drv

修改Makefile:
在这里插入图片描述
修改头文件:
在这里插入图片描述
修改宏S3C2410_GPxx为S3C2410_GPx(x):
在这里插入图片描述
修改触发方式的宏:
在这里插入图片描述
修改入口函数中的函数名称:
在这里插入图片描述
修改出口函数中卸载设备的函数:
在这里插入图片描述
编译:
make
arm-linux-gcc -o forthdrvtest forthdrvtest.c
cp forth_drv.ko forthdrvtest/work/nfs_root/fs_mini_mdev_new/

实验:
/ # insmod forth_drv.ko
/ # ./forthdrvtest
/ # rmmod forth_drv

2.5、05_fifth_drv

修改Makefile:
在这里插入图片描述
修改头文件:
在这里插入图片描述
修改宏S3C2410_GPxx为S3C2410_GPx(x):
在这里插入图片描述
修改触发方式的宏:
在这里插入图片描述
修改入口函数中的函数名称:
在这里插入图片描述
修改出口函数中卸载设备的函数:
在这里插入图片描述

编译:
make
arm-linux-gcc -o fifthdrvtest fifthdrvtest.c
cp fifth_drv.ko fifthdrvtest/work/nfs_root/fs_mini_mdev_new/

实验:
/ # insmod fifth_drv.ko
/ # ./fifthdrvtest
/ # rmmod fifth_drv

2.6、06_sixth_drv

修改Makefile:
在这里插入图片描述
修改头文件:
在这里插入图片描述
修改宏S3C2410_GPxx为S3C2410_GPx(x):
在这里插入图片描述
修改触发方式的宏:
在这里插入图片描述
修改互斥锁的定义和初始化:
在这里插入图片描述
在入口函数中初始化:
在这里插入图片描述
修改入口函数中的函数名称:
在这里插入图片描述
修改出口函数中卸载设备的函数:
在这里插入图片描述
编译:
make
arm-linux-gcc -o sixthdrvtest sixthdrvtest.c
cp sixth_drv.ko sixthdrvtest/work/nfs_root/fs_mini_mdev_new/

实验:
/ # insmod sixth_drv.ko
/ # ./sixthdrvtest
/ # rmmod sixth_drv

2.7、07_buttons_all

修改Makefile:
在这里插入图片描述
修改头文件:
在这里插入图片描述
修改宏S3C2410_GPxx为S3C2410_GPx(x):
在这里插入图片描述
修改触发方式的宏:
在这里插入图片描述
修改互斥锁的定义和初始化:
在这里插入图片描述
在入口函数中初始化:
在这里插入图片描述
修改入口函数中的函数名称:
在这里插入图片描述
修改出口函数中卸载设备的函数:
在这里插入图片描述
编译:
make
arm-linux-gcc -o buttons_test buttons_test.c
cp buttons_test /work/nfs_root/fs_mini_mdev_new/

实验:
/ # insmod buttons.ko
/ # ./buttons_test
/ # rmmod buttons

2.8、20th_chrdev_another

修改Makefile:
在这里插入图片描述
修改头文件:
在这里插入图片描述
修改函数名:
在这里插入图片描述
编译:
make
arm-linux-gcc -o hello_test hello_test.c
cp *.ko hello_test /work/nfs_root/fs_mini_mdev_new/

测试:
insmod hello.ko
ls dev/hello*
./hello_test /dev/hello0
./hello_test /dev/hello1
./hello_test /dev/hello2
./hello_test /dev/hello3

3、移植LCD及输入系统

3.1、10_lcd

修改Makefile:
在这里插入图片描述
只留下最后一个完整的驱动程序:
在这里插入图片描述
修改头文件:
在这里插入图片描述
make
cp lcd.ko /work/nfs_root/fs_mini_mdev_new/

编译内核去掉原来的lcd驱动程序:

cd /work/system/linux-3.4.2
make menuconfig
	Device Drivers  --->
		Graphics support  --->
			<*> Support for frame buffer devices  --->
				<M>   S3C2410 LCD framebuffer support	 
cp arch/arm/boot/uImage /work/nfs_root/uImage_nolcd

编译模块:
make modules
cp drivers/video/cfb*.ko /work/nfs_root/fs_mini_mdev_new/

编译fb_test测试程序:
cd /work/hardware/4_zdy_graduate/04_transplant/fb_test/
make
cp fb_test /work/nfs_root/fs_mini_mdev_new

测试:
单板:nfs 30000000 192.168.2.16:/work/nfs_root/uImage_nolcd; bootm 30000000
insmod cfbcopyarea.ko
insmod cfbimgblt.ko
insmod cfbfillrect.ko
insmod lcd.ko
./fb_test /dev/fb0 // 可以在LCD上看图案,串口也会显示一些信息
在这里插入图片描述
echo hello > /dev/tty1 // 可以在LCD上看见hello
cat lcd.ko > /dev/fb0 // 花屏

3.2、08_buttons_input

修改Makefile:
在这里插入图片描述
修改头文件:
在这里插入图片描述
修改GPIO引脚引用方式:
在这里插入图片描述
修改触边沿发方式的宏:
在这里插入图片描述
装载:
单板:nfs 30000000 192.168.2.16:/work/nfs_root/uImage_nolcd; bootm 30000000
insmod cfbcopyarea.ko
insmod cfbimgblt.ko
insmod cfbfillrect.ko
insmod lcd.ko
insmod buttons.ko

测试:
cat dev/tty1 //LCD和串口都会显示;EINT0-2表示l和s;按键EINT11便是Enter
在这里插入图片描述
vi etc/inittab //修改
在这里插入图片描述
reboot
nfs 30000000 192.168.2.16:/work/nfs_root/uImage_nolcd; bootm 30000000
insmod cfbcopyarea.ko
insmod cfbimgblt.ko
insmod cfbfillrect.ko
insmod lcd.ko
insmod buttons.ko
在LCD上使用按键输入ls和Enter即可看到信息:
在这里插入图片描述

3.3、09_led_bus_drv_dev

修改Makefile:
在这里插入图片描述
修改函数名:
在这里插入图片描述
编译:
make
arm-linux-gcc -o led_test led_test.c
cp *.ko led_test /work/nfs_root/fs_mini_mdev_new/

测试:
insmod led_drv.ko
insmod led_dev.ko
./led_test on
./led_test off

3.4、11_ts

修改Makefile:
在这里插入图片描述
修改头文件:
在这里插入图片描述
编译TS驱动:
make
cp s3c_ts.ko /work/nfs_root/fs_mini_mdev_new/

编译配置内核:
make menuconfig
cp arch/arm/boot/uImage /work/nfs_root/uImage_nots
Device Drivers->Input device support->Event interface && Event debugging
在这里插入图片描述
make uImage
cp arch/arm/boot/uImage /work/nfs_root/uImage_nots

编译tslib:
tar xzf tslib-1.4.tar.gz
cd tslib
./autogen.sh

mkdir tmp
echo “ac_cv_func_malloc_0_nonnull=yes” >arm-linux.cache
./configure --host=arm-linux --cache-file=arm-linux.cache --prefix=$(pwd)/tmp
sudo chmod +w /usr/local/arm/4.3.2/arm-none-linux-gnueabi/libc/usr/include/linux/input.h
sudo vi /usr/local/arm/4.3.2/arm-none-linux-gnueabi/libc/usr/include/linux/input.h
在这里插入图片描述
cd /work/hardware/4_zdy_graduate/04_transplant/11_ts/tslib/tslib
make clean
make
make install

安装tslib:
cd tmp
cp * -rf /work/nfs_root/fs_mini_mdev_new/

使用tslib:
若使用08_buttons_input 中的insmod buttons.ko则要vi etc/inittab;添加tty1::askfirst:-/bin/sh
单板:nfs 30000000 192.168.2.16:/work/nfs_root/uImage_nots; bootm 30000000
insmod cfbcopyarea.ko
insmod cfbimgblt.ko
insmod cfbfillrect.ko
insmod lcd.ko
//insmod buttons.ko //这为08_buttons_input 中的insmod buttons.ko
insmod s3c_ts.ko

配置环境:
1.
修改 /etc/ts.conf第1行(去掉#号和第一个空格):
vi /etc/ts.conf
#module_raw input
改为:
module_raw input

2.
若使用了08_buttons_input 中的insmod buttons.ko则要vi etc/inittab;添加tty1::askfirst:-/bin/sh,配置环境时选择tevent1:
export TSLIB_TSDEVICE=/dev/event0
export TSLIB_CALIBFILE=/etc/pointercal
export TSLIB_CONFFILE=/etc/ts.conf
export TSLIB_PLUGINDIR=/lib/ts
export TSLIB_CONSOLEDEVICE=none
export TSLIB_FBDEVICE=/dev/fb0

运行测试:
ts_calibrate
ts_test

3.5、12_usb

修改Makefile:
在这里插入图片描述
修改函数名:
在这里插入图片描述
编译:
cd /work/hardware/4_zdy_graduate/04_transplant/12_usb/
make
cp usbmouse_as_key.ko /work/nfs_root/fs_mini_mdev_new/

装载驱动:
insmod usbmouse_as_key.ko
ls dev/event*
//只有dev/event0 dev/event1
插入鼠标:
ls dev/event*
//就会出现dev/event0 dev/event1 dev/event2

按鼠标左键:LCD上显示l
按鼠标右键:LCD上显示s
按鼠标滚轮:相当于输入Enter,LCD就会显示目录里的内容

4、移植块设备和虚拟网卡

4.1、13_ramblock

修改Makefile:
在这里插入图片描述
修改函数名:
在这里插入图片描述
编译:
make
cp ramblock.ko /work/nfs_root/fs_mini_mdev_new/

测试:

insmod ramblock.ko

mkdosfs /dev/ramblock
mount -t vfat /dev/ramblock /mnt
mkdir /mnt/zdy
umount /mnt
mount -t vfat /dev/ramblock /mnt
ls /mnt
umount	

mkdosfs /dev/ramblock
fdisk /dev/ramblock
m
n
p
1
1
16
n
p
2
Enter
Enter
w
ls /dev/ramblock*

4.2、14_nand

修改Makefile:
在这里插入图片描述
修改函数名:
在这里插入图片描述
编译:
make
cp s3c_nand.ko /work/nfs_root/fs_mini_mdev_new/

配置内核:

make menuconfig
Device Drivers  --->
	<*> Memory Technology Device (MTD) support  --->
		<*>   NAND Device Support  --->  
			< >   NAND Flash support for Samsung S3C SoCs
make uImage
cp arch/arm/boot/uImage /work/nfs_root/uImage_nonand
单板:nfs 30000000 192.168.2.16:/work/nfs_root/uImage_nonand; bootm 30000000

测试:
insmod s3c_nand.ko
mount -t yaffs /dev/mtdblock3 /mnt
ls mnt/

4.3、15_nor

修改Makefile:
在这里插入图片描述
修改函数名:
在这里插入图片描述
编译:
make
cp s3c_nor.ko /work/nfs_root/fs_mini_mdev_new/

单板设置为nor启动:
nfs 30000000 192.168.2.16:/work/nfs_root/uImage_nonand; bootm 30000000

测试:
insmod s3c_nor.ko
ls dev/mtd*

4.4、16th_virt_net

修改Makefile:
在这里插入图片描述
修改函数名:
在这里插入图片描述
重新编写发包函数:
在这里插入图片描述
编译:
make
cp virt_net.ko /work/nfs_root/fs_mini_mdev_new/

测试:
insmod virt_net.ko
ifconfig vnet0 3.3.3.3
ifconfig
ping 3.3.3.3 -c 3
ping 3.3.3.4 -c 3

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

「已注销」

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值