⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 params.c

📁 linux 2.6.19 kernel source code before patching
💻 C
📖 第 1 页 / 共 2 页
字号:
/* sysfs output in /sys/modules/XYZ/parameters/ */extern struct kernel_param __start___param[], __stop___param[];#define MAX_KBUILD_MODNAME KOBJ_NAME_LENstruct param_attribute{	struct module_attribute mattr;	struct kernel_param *param;};struct module_param_attrs{	struct attribute_group grp;	struct param_attribute attrs[0];};#ifdef CONFIG_SYSFS#define to_param_attr(n) container_of(n, struct param_attribute, mattr);static ssize_t param_attr_show(struct module_attribute *mattr,			       struct module *mod, char *buf){	int count;	struct param_attribute *attribute = to_param_attr(mattr);	if (!attribute->param->get)		return -EPERM;	count = attribute->param->get(buf, attribute->param);	if (count > 0) {		strcat(buf, "\n");		++count;	}	return count;}/* sysfs always hands a nul-terminated string in buf.  We rely on that. */static ssize_t param_attr_store(struct module_attribute *mattr,				struct module *owner,				const char *buf, size_t len){ 	int err;	struct param_attribute *attribute = to_param_attr(mattr);	if (!attribute->param->set)		return -EPERM;	err = attribute->param->set(buf, attribute->param);	if (!err)		return len;	return err;}#endif#ifdef CONFIG_MODULES#define __modinit#else#define __modinit __init#endif#ifdef CONFIG_SYSFS/* * param_sysfs_setup - setup sysfs support for one module or KBUILD_MODNAME * @mk: struct module_kobject (contains parent kobject) * @kparam: array of struct kernel_param, the actual parameter definitions * @num_params: number of entries in array * @name_skip: offset where the parameter name start in kparam[].name. Needed for built-in "modules" * * Create a kobject for a (per-module) group of parameters, and create files * in sysfs. A pointer to the param_kobject is returned on success, * NULL if there's no parameter to export, or other ERR_PTR(err). */static __modinit struct module_param_attrs *param_sysfs_setup(struct module_kobject *mk,		  struct kernel_param *kparam,		  unsigned int num_params,		  unsigned int name_skip){	struct module_param_attrs *mp;	unsigned int valid_attrs = 0;	unsigned int i, size[2];	struct param_attribute *pattr;	struct attribute **gattr;	int err;	for (i=0; i<num_params; i++) {		if (kparam[i].perm)			valid_attrs++;	}	if (!valid_attrs)		return NULL;	size[0] = ALIGN(sizeof(*mp) +			valid_attrs * sizeof(mp->attrs[0]),			sizeof(mp->grp.attrs[0]));	size[1] = (valid_attrs + 1) * sizeof(mp->grp.attrs[0]);	mp = kmalloc(size[0] + size[1], GFP_KERNEL);	if (!mp)		return ERR_PTR(-ENOMEM);	mp->grp.name = "parameters";	mp->grp.attrs = (void *)mp + size[0];	pattr = &mp->attrs[0];	gattr = &mp->grp.attrs[0];	for (i = 0; i < num_params; i++) {		struct kernel_param *kp = &kparam[i];		if (kp->perm) {			pattr->param = kp;			pattr->mattr.show = param_attr_show;			pattr->mattr.store = param_attr_store;			pattr->mattr.attr.name = (char *)&kp->name[name_skip];			pattr->mattr.attr.owner = mk->mod;			pattr->mattr.attr.mode = kp->perm;			*(gattr++) = &(pattr++)->mattr.attr;		}	}	*gattr = NULL;	if ((err = sysfs_create_group(&mk->kobj, &mp->grp))) {		kfree(mp);		return ERR_PTR(err);	}	return mp;}#ifdef CONFIG_MODULES/* * module_param_sysfs_setup - setup sysfs support for one module * @mod: module * @kparam: module parameters (array) * @num_params: number of module parameters * * Adds sysfs entries for module parameters, and creates a link from * /sys/module/[mod->name]/parameters to /sys/parameters/[mod->name]/ */int module_param_sysfs_setup(struct module *mod,			     struct kernel_param *kparam,			     unsigned int num_params){	struct module_param_attrs *mp;	mp = param_sysfs_setup(&mod->mkobj, kparam, num_params, 0);	if (IS_ERR(mp))		return PTR_ERR(mp);	mod->param_attrs = mp;	return 0;}/* * module_param_sysfs_remove - remove sysfs support for one module * @mod: module * * Remove sysfs entries for module parameters and the corresponding * kobject. */void module_param_sysfs_remove(struct module *mod){	if (mod->param_attrs) {		sysfs_remove_group(&mod->mkobj.kobj,				   &mod->param_attrs->grp);		/* We are positive that no one is using any param		 * attrs at this point.  Deallocate immediately. */		kfree(mod->param_attrs);		mod->param_attrs = NULL;	}}#endif/* * kernel_param_sysfs_setup - wrapper for built-in params support */static void __init kernel_param_sysfs_setup(const char *name,					    struct kernel_param *kparam,					    unsigned int num_params,					    unsigned int name_skip){	struct module_kobject *mk;	int ret;	mk = kzalloc(sizeof(struct module_kobject), GFP_KERNEL);	BUG_ON(!mk);	mk->mod = THIS_MODULE;	kobj_set_kset_s(mk, module_subsys);	kobject_set_name(&mk->kobj, name);	kobject_init(&mk->kobj);	ret = kobject_add(&mk->kobj);	BUG_ON(ret < 0);	param_sysfs_setup(mk, kparam, num_params, name_skip);	kobject_uevent(&mk->kobj, KOBJ_ADD);}/* * param_sysfs_builtin - add contents in /sys/parameters for built-in modules * * Add module_parameters to sysfs for "modules" built into the kernel. * * The "module" name (KBUILD_MODNAME) is stored before a dot, the * "parameter" name is stored behind a dot in kernel_param->name. So, * extract the "module" name for all built-in kernel_param-eters, * and for all who have the same, call kernel_param_sysfs_setup. */static void __init param_sysfs_builtin(void){	struct kernel_param *kp, *kp_begin = NULL;	unsigned int i, name_len, count = 0;	char modname[MAX_KBUILD_MODNAME + 1] = "";	for (i=0; i < __stop___param - __start___param; i++) {		char *dot;		kp = &__start___param[i];		/* We do not handle args without periods. */		dot = memchr(kp->name, '.', MAX_KBUILD_MODNAME);		if (!dot) {			DEBUGP("couldn't find period in %s\n", kp->name);			continue;		}		name_len = dot - kp->name; 		/* new kbuild_modname? */		if (strlen(modname) != name_len		    || strncmp(modname, kp->name, name_len) != 0) {			/* add a new kobject for previous kernel_params. */			if (count)				kernel_param_sysfs_setup(modname,							 kp_begin,							 count,							 strlen(modname)+1);			strncpy(modname, kp->name, name_len);			modname[name_len] = '\0';			count = 0;			kp_begin = kp;		}		count++;	}	/* last kernel_params need to be registered as well */	if (count)		kernel_param_sysfs_setup(modname, kp_begin, count,					 strlen(modname)+1);}/* module-related sysfs stuff */#define to_module_attr(n) container_of(n, struct module_attribute, attr);#define to_module_kobject(n) container_of(n, struct module_kobject, kobj);static ssize_t module_attr_show(struct kobject *kobj,				struct attribute *attr,				char *buf){	struct module_attribute *attribute;	struct module_kobject *mk;	int ret;	attribute = to_module_attr(attr);	mk = to_module_kobject(kobj);	if (!attribute->show)		return -EIO;	ret = attribute->show(attribute, mk->mod, buf);	return ret;}static ssize_t module_attr_store(struct kobject *kobj,				struct attribute *attr,				const char *buf, size_t len){	struct module_attribute *attribute;	struct module_kobject *mk;	int ret;	attribute = to_module_attr(attr);	mk = to_module_kobject(kobj);	if (!attribute->store)		return -EIO;	ret = attribute->store(attribute, mk->mod, buf, len);	return ret;}static struct sysfs_ops module_sysfs_ops = {	.show = module_attr_show,	.store = module_attr_store,};static struct kobj_type module_ktype;static int uevent_filter(struct kset *kset, struct kobject *kobj){	struct kobj_type *ktype = get_ktype(kobj);	if (ktype == &module_ktype)		return 1;	return 0;}static struct kset_uevent_ops module_uevent_ops = {	.filter = uevent_filter,};decl_subsys(module, &module_ktype, &module_uevent_ops);int module_sysfs_initialized;static struct kobj_type module_ktype = {	.sysfs_ops =	&module_sysfs_ops,};/* * param_sysfs_init - wrapper for built-in params support */static int __init param_sysfs_init(void){	int ret;	ret = subsystem_register(&module_subsys);	if (ret < 0) {		printk(KERN_WARNING "%s (%d): subsystem_register error: %d\n",			__FILE__, __LINE__, ret);		return ret;	}	module_sysfs_initialized = 1;	param_sysfs_builtin();	return 0;}subsys_initcall(param_sysfs_init);#else#if 0static struct sysfs_ops module_sysfs_ops = {	.show = NULL,	.store = NULL,};#endif#endifEXPORT_SYMBOL(param_set_byte);EXPORT_SYMBOL(param_get_byte);EXPORT_SYMBOL(param_set_short);EXPORT_SYMBOL(param_get_short);EXPORT_SYMBOL(param_set_ushort);EXPORT_SYMBOL(param_get_ushort);EXPORT_SYMBOL(param_set_int);EXPORT_SYMBOL(param_get_int);EXPORT_SYMBOL(param_set_uint);EXPORT_SYMBOL(param_get_uint);EXPORT_SYMBOL(param_set_long);EXPORT_SYMBOL(param_get_long);EXPORT_SYMBOL(param_set_ulong);EXPORT_SYMBOL(param_get_ulong);EXPORT_SYMBOL(param_set_charp);EXPORT_SYMBOL(param_get_charp);EXPORT_SYMBOL(param_set_bool);EXPORT_SYMBOL(param_get_bool);EXPORT_SYMBOL(param_set_invbool);EXPORT_SYMBOL(param_get_invbool);EXPORT_SYMBOL(param_array_set);EXPORT_SYMBOL(param_array_get);EXPORT_SYMBOL(param_set_copystring);EXPORT_SYMBOL(param_get_string);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -