
必须包含 <linux/init.h>
module_init(your_init_func)
module_exit(your_exit_func)
老版本:int init_module(void)
void cleanup_module(voi)
2.4中两种都可以用,对如后面的入口函数不必要显示包含任何头文件。
2、 GPL
MODULE_LICENSE("Dual BSD/GPL")
老版本:MODULE_LICENSE("GPL")
3、 模块参数
必须显式包含<linux/moduleparam.h>
module_param(name, type, perm)
module_param_named(name, value, type, perm)
参数定义
module_param_string(name, string, len, perm)
module_param_array(name, type, num, perm)
老版本:MODULE_PARM(variable,type)
MODULE_PARM_DESC(variable,type)
4、 模块别名
MODULE_ALIAS("alias-name")
这是新增的,在老版本中需在/etc/modules.conf配置,现在在代码中就可以实现。
5、 模块计数
int try_module_get(&module)
module_put()
老版本:MOD_INC_USE_COUNT 和 MOD_DEC_USE_COUNT
6、 符号导出
只有显示的导出符号才能被其他 模块使用,默认不导出所有的符号,不必使用EXPORT_NO
_SYMBOLS
老板本:默认导出所有的符号,除非使用EXPORT_NO_SYMBOLS
7、 内核版本检查
需要在多个文件中包含<linux/module.h>时,不必定义__NO_VERSION__
老版本:在多个文件中包含<linux/module.h>时,除在主文件外的其他文件中必须定义_
_NO_VERSION__,防止版本重复定义。
8、 设备号
kdev_t被废除不可用,新的dev_t拓展到了32位,12位主设备号,20位次设备号。
unsigned int iminor(struct inode *inode)
unsigned int imajor(struct inode *inode)
老版本:8位主设备号,8位次设备号
int MAJOR(kdev_t dev)
int MINOR(kdev_t dev)
9、 内存分配头文件变更
所有的内存分配函数包含在头文件<linux/slab.h>,而原来的<linux/malloc.h>不存在
老版本:内存分配函数包含在头文件<linux/malloc.h>
10、 结构体的初试化
gcc开始采用ANSI C的struct结构体的初始化形式:
static struct some_structure = {
.field1 = value,
.field2 = value,
..
}
老版本:非标准的初试化形式
static struct some_structure = {
field1: value,
field2: value,
..
}
11、 用户模式帮助器
int call_usermodehelper(char *path, char **argv, char **envp,
int wait)
新增wait参数
12、 request_module()
request_module("foo-device-%d", number)
老版本:
char module_name[32]
printf(module_name, "foo-device-%d", number)
request_module(module_name)
13、 dev_t引发的字符设备的变化
1、取主次设备号为
unsigned iminor(struct inode *inode)
unsigned imajor(struct inode *inode)
2、老的register_chrdev()用法没变,保持向后兼容,但不能访问设备号大于256的设备
。
3、新的接口为
a)注册字符设备范围
int register_chrdev_region(dev_t from, unsigned count, char *name)
b)动态申请主设备号
int alloc_chrdev_region(dev_t *dev, unsigned baseminor, unsigned count, char
*name)
看了这两个函数郁闷吧^_^!怎么和file_operations结构联系起来啊?别急!
c)包含 <linux/cdev.h>,利用struct cdev和file_operations连接
struct cdev *cdev_alloc(void)
void cdev_init(struct cdev *cdev, struct file_operations *fops)
int cdev_add(struct cdev *cdev, dev_t dev, unsigned count)
(分别为,申请cdev结构,和fops连接,将设备加入到系统中!好复杂啊!)
d)void cdev_del(struct cdev *cdev)
只有在cdev_add执行成功才可运行。
e)辅助函数
kobject_put(&cdev->kobj)
struct kobject *cdev_get(struct cdev *cdev)
void cdev_put(struct cdev *cdev)
这一部分变化和新增的/sys/dev有一定的关联。
14、 新增对/proc的访问 *** 作
<linux/seq_file.h>
以前的/proc中只能得到string, seq_file *** 作能得到如long等多种数据。
相关函数:
static struct seq_operations 必须实现这个类似file_operations得数据中得各个成
员函数。
seq_printf();
int seq_putc(struct seq_file *m, char c)
int seq_puts(struct seq_file *m, const char *s)
int seq_escape(struct seq_file *m, const char *s, const char *esc)
int seq_path(struct seq_file *m, struct vfsmount *mnt,
struct dentry *dentry, char *esc)
seq_open(file, &ct_seq_ops)
等等
15、 底层内存分配
1、<linux/malloc.h>头文件改为<linux/slab.h>
2、分配标志GFP_BUFFER被取消,取而代之的是GFP_NOIO 和 GFP_NOFS
3、新增__GFP_REPEAT,__GFP_NOFAIL,__GFP_NORETRY分配标志
4、页面分配函数alloc_pages(),get_free_page()被包含在<linux/gfp.h>中
5、对NUMA系统新增了几个函数:
a) struct page *alloc_pages_node(int node_id,
unsigned int gfp_mask,
unsigned int order)
b) void free_hot_page(struct page *page)
c) void free_cold_page(struct page *page)
6、 新增Memory pools
<linux/mempool.h>
mempool_t *mempool_create(int min_nr,
mempool_alloc_t *alloc_fn,
mempool_free_t *free_fn,
void *pool_data)
void *mempool_alloc(mempool_t *pool, int gfp_mask)
void mempool_free(void *element, mempool_t *pool)
int mempool_resize(mempool_t *pool, int new_min_nr, int gfp_mask)
16、 per-CPU变量
get_cpu_var()
put_cpu_var()
void *alloc_percpu(type)
void free_percpu(const void *)
per_cpu_ptr(void *ptr, int cpu)
get_cpu_ptr(ptr)
put_cpu_ptr(ptr)
老版本使用
DEFINE_PER_CPU(type, name)
EXPORT_PER_CPU_SYMBOL(name)
EXPORT_PER_CPU_SYMBOL_GPL(name)
DECLARE_PER_CPU(type, name)
DEFINE_PER_CPU(int, mypcint)
2.6内核采用了可剥夺得调度方式这些宏都不安全。
17、 内核时间变化
1、现在的各个平台的HZ为
Alpha: 1024/1200ARM : 100/128/200/1000CRIS: 100i386: 1000IA-64:
1024M68K: 100M68K-nommu: 50-1000MIPS: 100/128/1000MIPS64: 100
PA-RISC: 100/1000PowerPC32: 100PowerPC64: 1000S/390: 100SPARC32:
100SPARC64: 100SuperH: 100/1000UML: 100v850: 24-100x86-64: 1000.
2、由于HZ的变化,原来的jiffies计数器很快就溢出了,引入了新的计数器jiffies_64
3、#include <linux/jiffies.h>
u64 my_time = get_jiffies_64()
4、新的时间结构增加了纳秒成员变量
struct timespec current_kernel_time(void)
5、他的timer函数没变,新增
void add_timer_on(struct timer_list *timer, int cpu)
6、新增纳秒级延时函数
ndelay();
7、POSIX clocks 参考kernel/posix-timers.c
18、 工作队列(workqueue)
1、任务队列(task queue )接口函数都被取消,新增了workqueue接口函数
struct workqueue_struct *create_workqueue(const char *name)
DECLARE_WORK(name, void (*function)(void *), void *data)
INIT_WORK(struct work_struct *work,
void (*function)(void *), void *data)
PREPARE_WORK(struct work_struct *work,
void (*function)(void *), void *data)
2、申明struct work_struct结构
int queue_work(struct workqueue_struct *queue,
struct work_struct *work)
int queue_delayed_work(struct workqueue_struct *queue,
struct work_struct *work,
unsigned long delay)
int cancel_delayed_work(struct work_struct *work)
void flush_workqueue(struct workqueue_struct *queue)
void destroy_workqueue(struct workqueue_struct *queue)
int schedule_work(struct work_struct *work)
int schedule_delayed_work(struct work_struct *work, unsigned long
delay)
19、 新增创建VFS的"libfs"
libfs给创建一个新的文件系统提供了大量的API.
主要是对struct file_system_type的实现。
参考源代码:
drivers/hotplug/pci_hotplug_core.c
drivers/usb/core/inode.c
drivers/oprofile/oprofilefs.c
fs/ramfs/inode.c
fs/nfsd/nfsctl.c (simple_fill_super() example)
Linux6.0中文环境不错内核2.4.18只有 KDE2.2.2为什么要升级内核 正如它的名字的字面意义,Linux的内核承担着Linux *** 作系统 的最为核心的任务,是其它程序和硬件等运行过程中的仲裁者:它要管理所有进程的内存,保证它们都能 平等得到处理器的时隙。此外,它还提供程序和硬件之间的接口等功能。 通常,更新的内核会支持更多的硬件,具备更好的进程管理能力,运行速度更快、更稳定,并且一般会修复老版本中发现的许多漏洞等,经常性地选择升级更新的系统内核是Linux使用者的必要 *** 作内容。 一般,内核的版本序列号使用三个数字表示,如2.4.8,版本号越高表示功能越强。 版本号分为两个系列:一种是产品系列,以偶数命名,例如,1.2.x、2.0.x、2.2.x等, 运行稳定,已经经过较为周密的测试;另外一种是开发测试系列,以奇数命名,用以进行最新功能的测试,不建议初学者和生产过程中使用。 本文的后面部分将分别以内核2.0.34到2.4.8的升级过程介绍内核升级用到的步骤、概念、注意事项以及可以参考的更多文档,文中出现的斜体字是直接输入的命令。 内核的配置与编译 Linux当前支持的CPU类型包括x86、ARM、DEC Alpha、SUN Sparc、M68000、MIPS、PowerPC等,应该说上述类型已经包括绝大多数用户使用的CPU型号。在安装与配置过程中,Linux会自动识别这些型号。 通常要运行的第一个命令是:#cd /usr/src/linuxmake mrproper。确保源代码目录下没有不正确的.o文件以及文件的互相依赖。 接下来的内核配置过程比较烦琐,但是配置的适当与否与日后Linux的运行直接相关,有必要了解一下一些主要的且经常用到的选项的设置。 配置内核可以根据需要与爱好使用下面命令中的一个: #make config (基于文本的最为传统的配置界面) #make menuconfig (基于文本选单的配置界面) #make xconfig (基于图形窗口模式的配置界面) #make oldconfig (如果只想在原来内核配置的基础上修改一些小地方,会省去不少麻烦) 进行配置时,大部分选项可以使用其缺省值,只有小部分需要根据用户不同的需要选择。例如,如果需要内核支持DOS分区的文件系统,则要在文件系统部分选择FAT或DOS系统支持;系统如果配有网卡、PCMCIA卡等,需要在网络配置中选择相应卡的类型。 选择相应的配置时,有三种选择,它们分别代表的含义如下: “Y”- 将该功能编译进内核 “N”- 不将该功能编译进内核 “M”- 将该功能编译成可以在需要时动态插入到内核中的模块。 将与核心其它部分关系较远且不经常使用的部分功能代码编译成为可加载模块,有利于减小内核的长度,减小内核消耗的内存,简化该功能相应的环境改变时对内核的影响。许多功能都可以这样处理,例如像上面提到的网卡的支持、对FAT等文件系统的支持。 配置完内核,接下来需要对内核源代码文件的依赖性和完整性进行检验,并且进行编译,此时要保证系统所使用的gcc版本在gcc-2.7.2以上: #make dep (确保关键文件在正确的位置) #make clean (确保所有有关文件都处于最新版本状态) #make zImage (编译压缩形式的内核) 在需要内核支持较多的外设和功能时,内核可能变得很大,此时可以编译大内核: #make bzImage 编译的时间与机器的硬件条件及内核的配置等因素有关,以笔者的64MB内存的赛扬300为例,编译内核一次大致需要20多分钟。所获得的内核的位置在/usr/src/linux/arch/i386/boot目录下,当然这里假设用户的CPU是x86型的。 如果选择了可加载模块,编译完内核后,要对选择的模块进行编译: #make module (编译选择的模块) #make module-install (将编译后的模块转移到系统标准位置) 模块在系统中的标准目录位于/lib/modules/x.y.z,后面的x.y.z是版本号,为安全起见,在运行#make modules-install之前最好对/lib/modules进行备份。模块通常是带有扩展名.o的文件,使用命令#lsmod可以对当前内核的模块进行列表。 软件 下载与解包 选择相对快速并且具有权威性的站点下载最新的内核源代码包,例如条件允许的话可以到下面的站点下载: ftp://sunsite.unc.edu/pub/linux/kernel 国内Linux用户可以到下面的站点下载: http://studio.openunix.org http://www.clinuxworld.com 注意,如果升级版本的跨度很大,并且预计会配置外部模块时,还要下载最新的模块工具modules-x.y.z.tar.gz。 Linux系统的核心代码存放于目录/usr/src/linux,实际上,该目录是一个链接,指向当前所用的核心版本的目录,例如如果当前使用的版本是2.0.34,则该核心的实际目录应该是: /usr/src/linux-2.0.34。而新下载的内核中的目录是linux,这样,直接在/usr/src下解包会导致原来的内核目录被覆盖。所以稳妥的做法是,首先删除链接linux,然后解包、更名、重新链接。 在解包前要确认在/usr/src目录下没有叫linux的目录,或者不再想保留该目录。 另外,随着Linux内核功能的增强及对更多外设的支持,文件包也越变越大,当前最新的稳定版2.4.8内核压缩包的大小约为14MB,但实际上解压缩及编译等环节,要求/usr/src目录所在的分区的空闲空间大于60MB字节。 启用新内核 将编译好的新内核拷贝到系统目录/boot下,例如 #cp /usr/src/linux/arch/i386/boot/zImage /boot/zImage-2.4.8 然后,编辑系统引导配置文件/etc/lilo.conf,仿照原有选项添入新内核选项,给它起一个明显好记的标签(label),记住此时最好保留原有内核以及相应的选项,这样不用害怕升级失败而机器启动不了,至少还可以使用旧的内核引导自己的计算机。保存编辑后退出,此时要记住运行命令:#lilo,更新系统引导映象,这样对lilo.conf的修改才能起作用。 重启机器后,在LILO的提示符下按“Tab”键,则应该看到加入的新内核选项。 对于当前国内进行汉化后的Linux版本,由于其中的几个主要版本是在内核中进行,例如冲浪平台的Xteam Linux、蓝点Bluepoint Linux等,所以使用这些发行版本的用户如果按照上面的步骤进行内核升级则会导致汉化失败、系统运行不稳定等后果。用户需要等待厂家发行新内核的汉化包,然后到厂家指定的下载站点下载,按照其中的说明进行升级。 Linux系统最低配置:CPU:2113700MHz
内存:5261384MB
硬盘:41026GB剩余空间
显卡:800x600以上分辨率。
Linux是一套免费使用和自由传播的类1653Unix *** 作系统,是一个基于POSIX和Unix的多用户、多任务、支持多线程和多CPU的 *** 作系统。它能运行主要的Unix工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络 *** 作系统。
https://imgcdn.idongde.com/qa/2020/06/28/14/1593326438419354
扩展资料:
Linux主要特性:
1、完全免费
Linux是一款免费的 *** 作系统,用户可以通过网络或其他途径免费获得,并可以任意修改其源代码。这是其他的 *** 作系统所做不到的。正是由于这一点,来自全世界的无数程序员参与了Linux的修改、编写工作,程序员可以根据自己的兴趣和灵感对其进行改变,这让Linux吸收了无数程序员的精华,不断壮大。
2、多用户、多任务
Linux支持多用户,各个用户对于自己的文件设备有自己特殊的权利,保证了各用户之间互不影响。多任务则是现在电脑最主要的一个特点,Linux可以使多个程序同时并独立地运行。
3、良好的界面
Linux同时具有字符界面和图形界面。在字符界面用户可以通过键盘输入相应的指令来进行 *** 作。它同时也提供了类似Windows图形界面的X-Window系统,用户可以使用鼠标对其进行 *** 作。在X-Window环境中就和在Windows中相似,可以说是一个Linux版的Windows。
4、支持多种平台
Linux可以运行在多种硬件平台上,如具有x86、680x0、SPARC、Alpha等处理器的平台。此外Linux还是一种嵌入式 *** 作系统,可以运行在掌上电脑、机顶盒或游戏机上。2001年1月份发布的Linux2.4版内核已经能够完全支持Intel64位芯片架构。同时Linux也支持多处理器技术。多个处理器同时工作,使系统性能大大提高。
参考资料来源:百度百科-linux
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)