‘壹’ linux 内核ddr3驱动在哪个文件
Flash全名叫做Flash Memory,属于非易失性存储设备(Non-volatile Memory Device),与此相对应的是易失性存储设备(Volatile Memory Device)。关于什么是非易失性/易失性,从名字中就可以看出,非易失性就是不容易丢失,数据存储在这类设备中,即...
‘贰’ 请问各位大神,做linux驱动移植时,内核没有的一些外设的驱动源码一般是去哪里找呢
linux内核源码,能支持的驱动已经是很丰富的了。
如果没有具体型号的外设驱动,那么,就参考linux内核已有的驱动源码,来修改。
比如:网卡驱动
A板卡,网络芯片是DM9000,在linux-x.x.x/drivers/net目录下有dm9000.c驱动;
现在要做网络芯片是CS8900,没有驱动,就可以参考DM9000驱动,
对照芯片手册,修改驱动,编译通过,调试等。
‘叁’ arm linux dts怎么配置ddr3
FDT是ARM Linux最新的设备驱动程序信息表,使用FDT的内核,就不用像过去的内核那样,一个板子加一个mach的C文件,所有的设备信息可以记录在一个树状信息文件里面。 目前这方面资料比较少,我以AM335x处理器为例概括一下FDT的使用: FDT仅仅是一个信息的目录和参数表,要使用某个功能内核中还必须有相应的驱动程序代码 FDT的源文件位置在:arch/arm/boot/dts,例如,TI的Beagle bone black,源文件是arch/arm/boot/dts/am335x_boneblack.dts FDT在make ARCH=arm的时候就会自动生成,也可用make ARCH=arm dtbs来生成,例如TI的Beagle bone black生成的文件是arch/arm/boot/dts/am335x_boneblack.dtb,这是一个二进制文件 要想新增你自定义的FDT,请修改arch/arm/boot/dts/Makefile,并在相应的Kconfig中增加config选项,例如
‘肆’ 如何从linux内核上预留DDR物理内
luther@gliethttp:~$ vim /proc/iomem
00100000-5bf0ffff : System RAM
00100000-00575553 : Kernel code
00575554-0078d307 : Kernel data
0081a000-008a809f : Kernel bss
可以看到kernel code和data,bss使用的ram就是我们的系统内存,
luther@gliethttp:~$ dmesg也可以看到物理内存的情况
BIOS-provided physical RAM map:
[ 0.000000] BIOS-e820: 0000000000000000 - 000000000009dc00 (usable)
[ 0.000000] BIOS-e820: 000000000009dc00 - 00000000000a0000 (reserved)
[ 0.000000] BIOS-e820: 00000000000d2000 - 0000000000100000 (reserved)
[ 0.000000] BIOS-e820: 0000000000100000 - 000000005bf10000 (usable)
[ 0.000000] BIOS-e820: 000000005bf10000 - 000000005bf19000 (ACPI data)
[ 0.000000] BIOS-e820: 000000005bf19000 - 000000005bf80000 (ACPI NVS)
[ 0.000000] BIOS-e820: 000000005bf80000 - 0000000060000000 (reserved)
[ 0.000000] BIOS-e820: 00000000e0000000 - 00000000f0000000 (reserved)
[ 0.000000] BIOS-e820: 00000000fec00000 - 00000000fec10000 (reserved)
[ 0.000000] BIOS-e820: 00000000fee00000 - 00000000fee01000 (reserved)
[ 0.000000] BIOS-e820: 00000000fff80000 - 0000000100000000 (reserved)
luther@gliethttp:~$ vim /proc/meminfo
MemTotal: 1478540 kB
MemFree: 868544 kB
Buffers: 31084 kB
Cached: 321672 kB
SwapCached: 0 kB
luther@gliethttp:~$ sudo vim /boot/grub/grub.cfg
原来的
linux /boot/vmlinuz-2.6.31-14-generic root=UUID=9a04b75d-22f4-4100-a8b0-a07ef00ead04 ro quiet splash
新改的
linux /boot/vmlinuz-2.6.31-14-generic root=UUID=9a04b75d-22f4-4100-a8b0-a07ef00ead04 ro quiet splash mem=1442M
修改之后dmesg将多出如下一行提示:
[ 0.000000] user-defined physical RAM map:
[ 0.000000] user: 0000000000000000 - 000000000009dc00 (usable)
[ 0.000000] user: 000000000009dc00 - 00000000000a0000 (reserved)
[ 0.000000] user: 00000000000d2000 - 0000000000100000 (reserved)
[ 0.000000] user: 0000000000100000 - 000000005a200000 (usable)
[ 0.000000] user: 000000005bf10000 - 000000005bf19000 (ACPI data)
[ 0.000000] user: 000000005bf19000 - 000000005bf80000 (ACPI NVS)
[ 0.000000] user: 000000005bf80000 - 0000000060000000 (reserved)
[ 0.000000] user: 00000000e0000000 - 00000000f0000000 (reserved)
[ 0.000000] user: 00000000fec00000 - 00000000fec10000 (reserved)
[ 0.000000] user: 00000000fee00000 - 00000000fee01000 (reserved)
[ 0.000000] user: 00000000fff80000 - 0000000100000000 (reserved)
之前
[ 0.000000] 583MB HIGHMEM available.
之后
[ 0.000000] 554MB HIGHMEM available.
这样000000005a200000 - 000000005bf10000之间的29M物理内存就被预留出来供我们的DMA使用了[luther.gliethttp]
==================================================
=====第1步=============================================================================
[root@localhost ~]# cat /proc/meminfo
MemTotal: 1026124 kB
[root@localhost ~]# cat /proc/iomem
00000000-0009efff : System RAM
00000000-00000000 : Crash kernel
0009f000-0009ffff : reserved
000a0000-000bffff : Video RAM area
000c0000-000c7fff : Video ROM
000d4000-000d4fff : Adapter ROM
000f0000-000fffff : System ROM
00100000-3f6effff : System RAM // 内存首尾地址,我们将从0x3f6effff结尾开始往前保留300M空间
00400000-006081dd : Kernel code
006081de-006e19bb : Kernel data
3f6f0000-3f6f2fff : ACPI Non-volatile Storage
3f6f3000-3f6fffff : ACPI Tables
40000000-400003ff : 0000:00:1f.1
f0000000-f7ffffff : 0000:00:02.0
f8000000-f8ffffff : PCI Bus #01
f8000000-f87fffff : 0000:01:04.0
f8000000-f87fffff : ceopen_dmp
f8800000-f880ffff : 0000:01:04.0
f8800000-f880ffff : ceopen_dmp
f8810000-f88100ff : 0000:01:03.0
f8810000-f88100ff : 8139too
f8811000-f88111ff : 0000:01:04.0
f8811000-f88111ff : ceopen_dmp
f9000000-f93fffff : 0000:00:00.0
f9400000-f947ffff : 0000:00:02.0
f9480000-f94803ff : 0000:00:1d.7
f9480000-f94803ff : ehci_hcd
f9481000-f94811ff : 0000:00:1f.5
f9481000-f94811ff : Intel ICH5
f9482000-f94820ff : 0000:00:1f.5
f9482000-f94820ff : Intel ICH5
fec00000-ffffffff : reserved
=====第2步=============================================================================
向cmdline加入mem和reserved启动参数
hex(0x3f6f0000-300*1024*1024)等于0x2caf0000,这里表示从0x3f6effff结尾开始往前保留300M空间
hex(300*1024*1024)等于0x12c00000
[root@localhost ~]# vim /boot/grub/menu.lst
kernel /boot/vmlinuz-2.6.18-53.el5 ro root=LABEL=/ rhgb quiet mem=0x2caf0000 reserve=0x2caf0000,0x12c00000
即保留0x2caf0000开始的300*1024*1024字节内存
kernel/resource.c|820| __setup("reserve=", reserve_setup);
2.6.30.4内核cmdline常用命令行参数与相应处理函数
[root@localhost ~]# cat /proc/meminfo
MemTotal: 721324 kB
[root@localhost ~]# cat /proc/iomem
00000000-0009efff : System RAM
00000000-00000000 : Crash kernel
0009f000-0009ffff : reserved
000a0000-000bffff : Video RAM area
000c0000-000c7fff : Video ROM
000d4000-000d4fff : Adapter ROM
000f0000-000fffff : System ROM
00100000-2caeffff : System RAM
00400000-006081dd : Kernel code
006081de-006e19bb : Kernel data
2caf0000-3f6effff : reserved // 这就是我们保留出来的内存了,和上面的内存结构一致[luther.gliethttp]
3f6f0000-3f6f03ff : 0000:00:1f.1
f0000000-f7ffffff : 0000:00:02.0
f8000000-f8ffffff : PCI Bus #01
f8000000-f87fffff : 0000:01:04.0
f8800000-f880ffff : 0000:01:04.0
f8810000-f88100ff : 0000:01:03.0
f8810000-f88100ff : 8139too
f8811000-f88111ff : 0000:01:04.0
f9000000-f93fffff : 0000:00:00.0
f9400000-f947ffff : 0000:00:02.0
f9480000-f94803ff : 0000:00:1d.7
f9480000-f94803ff : ehci_hcd
f9481000-f94811ff : 0000:00:1f.5
f9481000-f94811ff : Intel ICH5
f9482000-f94820ff : 0000:00:1f.5
f9482000-f94820ff : Intel ICH5
=====第3步=============================================================================
虽然预留了300M空间,但是ioremap_nocache不能映射全部的300M空间,不知道为什么,可能和
系统自身有关系,下面是具体的映射代码,因为已经将region做了reserved申请命名,所以
我们也就不需要再使用request_mem_region(pdma, dma_size, "gliethttp_dma_area")来获得region了.
const dma_addr_t pdma = 0x2caf0000;
const size_t dma_size = (280*1024*1024);
kdma = ioremap_nocache(pdma, dma_size);
if (kdma == NULL)
return -ENOMEM;
其 实2G内存也没有问题,mem=1.6G,然后ko驱动使用mmap将1.6G-2G之间的内存物理地址直接映射给user空间,这样user空间就可以 直接向1.6G-2G物理内存写入数据了,然后PCI直接通过寄存器配置,向1.6G-2G的物理地址读取数据,这样透过ko驱动将user和pci建立 了直连,当然了,因为内核线性地址为3G-4G只有1G的内存可以被映射,所以2G内存的另外1G内存就属于高端内存了,所以内核ko驱动不能映射 1.6G-2G的内存到内核线性地址空间,但是可以通过kmap短暂的映射来使用[luther.gliethttp]
static void __init early_mem(char **p)
{
static int usermem __initdata = 0;
unsigned long size, start;
if (usermem == 0) {
usermem = 1;
meminfo.nr_banks = 0;
}
start = PHYS_OFFSET;
size = memparse(*p, p);
if (**p == '@')
start = memparse(*p + 1, p);
arm_add_memory(start, size);
}
__early_param("mem=", early_mem);
以下转自:http://hi..com/linuxbestbest/blog/item/9bc8dbdb72127763d0164e9c.html
有时,内核不能识别你的全部内存(RAM)。你可以用 cat /proc/meminfo 命令来校验。
查看一下所显示的数量是否与你所知的系统内存相同。如果不同,在 /boot/grub/grub.conf 文件中添加以下一行:
mem=xxM
把 xx 替换成你拥有的内存数量(以 MB 为单位)。
在 /boot/grub/grub.conf 文件中,以上的例子与下面相似:,
#NOTICE: You have a /boot partition. This means that
# all kernel paths are relative to /boot/
default=0
timeout=30
splashimage=(hd0,0)/grub/splash.xpm.gz
title Red Hat Linux (2.4.20-2.47.1)
root (hd0,0)
kernel /vmlinuz-2.4.20-2.47.1 ro root=/dev/hda3 mem=128M
当你重新引导后,grub.conf 文件中的改变将会反映在你的系统中。
或者,你可以在 /etc/lilo.conf 文件中添加以下一行:
append="mem=xxM"
注意,append 命令在 GRUB 和 LILO 中都可用。
把 xx 替换成你拥有的内存数量(以 MB 为单位)。切记,每映像后补的行会完全覆写全局后补的行。把这行添加到每映像描述中可能值得一试。
在 /etc/lilo.conf 文件中,以上的例子与下面相似:
boot=/dev/sda
map=/boot/map
install=/boot/boot.b
prompt
timeout=50
image=/boot/vmlinuz-2.4.20-2.47.1
label=linux
root=/dev/sda1
initrd=/boot/initrd-2.4.20-2.47.1.img
read-only
append="mem=128M"
记住在改变了 /etc/lilo.conf 文件后运行 /sbin/lilo -v 命令。
请注意,在 GRUB 或 LILO 中指定所用标签(映像)时传递这一选项可以获得同样的效果。
当你已载入 GRUB 引导屏幕后,键入 e 来编辑。你所选定的引导标签的配置文件中的项目列表就会在你面前出现。
选择开头为 kernel 的行,然后键入 e 来编辑这一引导项目。
在 kernel 行的末尾,添加:
mem=xxM
或
append=xxM
这里的 xx 与你系统的内存数量相同。
按 [Enter] 键来退出编辑模式。
回到 GRUB 屏幕后,键入 b 来用你的新内存指数引导。
在图形化的 LILO 屏幕上,按 [Ctrl]-[x] 退回到 boot: 提示。接下来,在 boot: 提示下输入:
linux mem=xxM
请记住将 xx 替换成你系统的内存数量。按 [Enter] 键来引导。
http://blog.sina.com.cn/s/blog_677570ff0100l1ng.html
http://www.kerneltravel.net/jiaoliu/map.htm
‘伍’ Linux驱动源码怎么和硬件联系
如题,本人安装了REDHAT LINUX,但不知道有哪些硬件的驱动程序没有安装,我如何才能查看这些没有安装驱动程序的硬件呢
‘陆’ 驱动开发必须使用开发板厂家提供的Linux源码吗
驱动开发环境
要进行linux驱动开发我们首先要有linux内核的源码树,并且这个linux内核的源码树要和开发板中的内核源码树要一直;
比如说我们开发板中用的是linux kernel内核版本为2.6.35.7,在我们ubuntu虚拟机上必须要有同样版本的源码树,
我们再编译好驱动的的时候,使用modinfo XXX命令会打印出一个版本号,这个版本号是与使用的源码树版本有关,如果开发板中源码树中版本与
modinfo的版本信息不一致使无法安装驱动的;
我们开发板必须设置好nfs挂载;这些在根文件系统一章有详细的介绍;
‘柒’ 移植linux到am335x的时候如何配置ddr3驱动
TI的LCD控制器驱动是非常完善的,共通的地方已经由驱动封装好了,与按键一样,我们可以通过DTS配置完成LCD的显示。下面,我们来讨论下使用DTS方式配置内核完成LCD驱动的思路。(1)初步分析由于TQ335x使用的芯片是AM335x,故仍然可以参考am335
‘捌’ linux的启动的哪个环节中进行了ddr的配置
.开机启动时自动运行程序Linux加载后, 它将初始化硬件和设备驱动, 然后运行第一个进程init。init根据配置文件继续引导过程,启动其它进程。通常情况下,修改放置在 /etc/rc或 /etc/rc.d 或 /etc/rc?.d 目录下的脚本文件,可以使init自动启动其它程序。例如:编辑 /etc/rc.d/rc.local 文件,在文件最末加上一行"xinit"或"startx",可以在开机启动后直接进入X-Window。2.登录时自动运行程序用户登录时,bash首先自动执行系统管理员建立的全局登录script :/ect/profile。
‘玖’ 如何编译一个linux下的驱动模块
linux下编译运行驱动
嵌入式linux下设备驱动的运行和linux x86 pc下运行设备驱动是类似的,由于手头没有嵌入式linux设备,先在vmware上的linux上学习驱动开发。
按照如下方法就可以成功编译出hello world模块驱动。
1、首先确定本机linux版本
怎么查看Linux的内核kernel版本?
'uname'是Linux/unix系统中用来查看系统信息的命令,适用于所有Linux发行版。配合使用'uname'参数可以查看当前服务器内核运行的各个状态。
#uname -a
Linux whh 3.5.0-19-generic #30-Ubuntu SMPTue Nov 13 17:49:53 UTC 2012 i686 i686 i686 GNU/Linux
只打印内核版本,以及主要和次要版本:
#uname -r
3.5.0-19-generic
要打印系统的体系架构类型,即的机器是32位还是64位,使用:
#uname -p
i686
/proc/version 文件也包含系统内核信息:
# cat /proc/version
Linux version 3.5.0-19-generic(buildd@aatxe) (gcc version 4.7.2 (Ubuntu/Linaro 4.7.2-2ubuntu1) ) #30-UbuntuSMP Tue Nov 13 17:49:53 UTC 2012
发现自己的机器linux版本是:3.5.0-19-generic
2、下载机器内核对应linux源码
到下面网站可以下载各个版本linux源码https://www.kernel.org/
如我的机器3.5.0版本源码下载地址为:https://www.kernel.org/pub/linux/kernel/v3.x/linux-3.5.tar.bz2
下载完后,找一个路径解压,如我解压到/linux-3.5/
然后很重要的一步是:执行命令uname -r,可以看到Ubuntu的版本信息是3.5.0-19-generic
。进入linux源码目录,编辑Makefile,将EXTRAVERSION = 修改为EXTRAVERSION= -19-generic。
这些都是要配置源码的版本号与系统版本号,如果源码版本号和系统版本号不一致,在加载模块的时候会出现如下错误:insmod: error inserting 'hello.ko': -1 Invalid mole format。
原因很明确:编译时用的hello.ko的kenerl 不是我的pc的kenerl版本。
执行命令cp /boot/config-3.5.0-19-generic ./config,覆盖原有配置文件。
进入linux源码目录,执行make menuconfig配置内核,执行make编译内核。
3、写一个最简单的linux驱动代码hello.c
/*======================================================================
Asimple kernel mole: "hello world"
======================================================================*/
#include <linux/init.h>
#include <linux/mole.h>
MODULE_LICENSE("zeroboundaryBSD/GPL");
static int hello_init(void)
{
printk(KERN_INFO"Hello World enter\n");
return0;
}
static void hello_exit(void)
{
printk(KERN_INFO"Hello World exit\n ");
}
mole_init(hello_init);
mole_exit(hello_exit);
MODULE_AUTHOR("zeroboundary");
MODULE_DESCRIPTION("A simple HelloWorld Mole");
MODULE_ALIAS("a simplestmole");
4、写一个Makefile对源码进行编译
KERN_DIR = /linux-3.5
all:
make-C $(KERN_DIR) M=`pwd` moles
clean:
make-C $(KERN_DIR) M=`pwd` clean
obj-m += hello.o
5、模块加载卸载测试
insmod hello.ko
rmmod hello.ko
然后dmesg|tail就可以看见结果了
最后,再次编译驱动程序hello.c得到hello.ko。执行insmod ./hello.ko,即可正确insert模块。
使用insmod hello.ko 将该Mole加入内核中。在这里需要注意的是要用 su 命令切换到root用户,否则会显示如下的错误:insmod: error inserting 'hello.ko': -1 Operation not permitted
内核模块版本信息的命令为modinfo hello.ko
通过lsmod命令可以查看驱动是否成功加载到内核中
通过insmod命令加载刚编译成功的time.ko模块后,似乎系统没有反应,也没看到打印信息。而事实上,内核模块的打印信息一般不会打印在终端上。驱动的打印都在内核日志中,我们可以使用dmesg命令查看内核日志信息。dmesg|tail
可能还会遇到这种问题insmod: error inserting 'hello.ko': -1 Invalid mole format
用dmesg|tail查看内核日志详细错误
disagrees about version of symbolmole_layout,详细看这里。
http://www.ibm.com/developerworks/cn/linux/l-cn-kernelmoles/index.html
在X86上我的办法是:
make -C/usr/src/linux-headers-3.5.0-19-generic SUBDIRS=$PWD moles