
打开终端
最简单的方法是输入setup命令
还有一个比较麻烦的方法
ifconfig(这个单词的全称是interface config)打个比方,IP地址为192.168.1.1 掩码24位,那么命令如下
ifconfig 192.168.1.1 255.255.255.0(这条命令不用重启服务,但是再次开机上次修改的IP又还原了,简单来说就是临时修改IP地址。)
还有一个方法,是编辑文本
vi /etc/sysconfig/network-spicrt/ifcfg-eth0~3
↓ ↓
试试TAB键,单词不记得了,乱打的 这个是0~3号设备网卡,如果0不行就换1或2或3
这个命令进入后,你找到“dhcp”这一行,DHCP是自动获取IP的意思
把DHCP改为static,然后输入回车进入下一行,输入IPADDR=192.168.1.1(IP地址)
再按下回车,输入NETMASK=255.255.255.0(子网掩码)
再按下回车输入GETWAY=192.168.1.10(把网关改为192.168.1.1)
输入完了之后exit命令退出来
然后输入 service network restart
就可以完成了
在编写linux内核模块的时候,有时候我们需要调用一只内核模块里面的函数,然而如果是在不同目录下面编译生成的内核模块,此时A模块去调用B模块的函数时候会出现函数未定义,无法调用的情况。那么以前我是在同一个目录下面,先后写两个makefile,然后编译生成两个不同的内核模块,这种方式可以正常实现A模块调用B模块里面的函数,不过非常麻烦。本博文将会针对这种情况提出一种可以同时生成多个内核模块,不要再次编译的方面,下面贴出源码:内核模块cal.ko:
#include <linux/module.h>
#include <linux/init.h>
MODULE_LICENSE("GPL")
int add(int a, int b) {
return a+b
}
int sub(int a, int b) {
return a-b
}
static int sym_init() {
return 0
}
static int sym_exit() {
return 0
}
module_init(sym_init)
module_exit(sym_exit)
EXPORT_SYMBOL(add)
EXPORT_SYMBOL(sub)
内核模块hello.ko
#include <linux/module.h>
#include <linux/init.h>
MODULE_LICENSE("GPL")
MODULE_AUTHOR("David Xie")
MODULE_DESCRIPTION("Hello World Module")
MODULE_ALIAS("a simplest module")
static int age = 10
module_param(age, int, S_IRUGO)//allow all user to use this param
int add(int a, int b)
int sub(int a, int b)
static int hello_init(void)
{
printk("<0>"" Hello World! age = %d\n", add(10, 20))//调用内核模块cal.ko里面的add函数
return 0
}
static void hello_exit(void)
{
printk("<0>""hello exit %d\n", sub(30,10))//调用内核模块cal.ko里面的sub函数
}
module_init(hello_init)
module_exit(hello_exit)
可以生成多个内核模块的makefile
ifneq ($(KERNELRELEASE),)
obj-m := cal.o hello.o
cal-objs := operator.o
hello-objs := main.o
else
KDIR := /lib/modules/2.6.32-21-generic/build
all:
make -C $(KDIR) M=$(PWD) modules
clean:
rm -f *.ko *.o *.mod.o *.mod.c *.symvers *.order
endif
此时在当前目录执行make就会产生cal.ko和hello.ko两个内核模块
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)