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

📄 hdaps.c

📁 linux 内核源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
	},};/* * hdaps_calibrate - Set our "resting" values.  Callers must hold hdaps_mtx. */static void hdaps_calibrate(void){	__hdaps_read_pair(HDAPS_PORT_XPOS, HDAPS_PORT_YPOS, &rest_x, &rest_y);}static void hdaps_mousedev_poll(struct input_polled_dev *dev){	struct input_dev *input_dev = dev->input;	int x, y;	mutex_lock(&hdaps_mtx);	if (__hdaps_read_pair(HDAPS_PORT_XPOS, HDAPS_PORT_YPOS, &x, &y))		goto out;	input_report_abs(input_dev, ABS_X, x - rest_x);	input_report_abs(input_dev, ABS_Y, y - rest_y);	input_sync(input_dev);out:	mutex_unlock(&hdaps_mtx);}/* Sysfs Files */static ssize_t hdaps_position_show(struct device *dev,				   struct device_attribute *attr, char *buf){	int ret, x, y;	ret = hdaps_read_pair(HDAPS_PORT_XPOS, HDAPS_PORT_YPOS, &x, &y);	if (ret)		return ret;	return sprintf(buf, "(%d,%d)\n", x, y);}static ssize_t hdaps_variance_show(struct device *dev,				   struct device_attribute *attr, char *buf){	int ret, x, y;	ret = hdaps_read_pair(HDAPS_PORT_XVAR, HDAPS_PORT_YVAR, &x, &y);	if (ret)		return ret;	return sprintf(buf, "(%d,%d)\n", x, y);}static ssize_t hdaps_temp1_show(struct device *dev,				struct device_attribute *attr, char *buf){	u8 temp;	int ret;	ret = hdaps_readb_one(HDAPS_PORT_TEMP1, &temp);	if (ret < 0)		return ret;	return sprintf(buf, "%u\n", temp);}static ssize_t hdaps_temp2_show(struct device *dev,				struct device_attribute *attr, char *buf){	u8 temp;	int ret;	ret = hdaps_readb_one(HDAPS_PORT_TEMP2, &temp);	if (ret < 0)		return ret;	return sprintf(buf, "%u\n", temp);}static ssize_t hdaps_keyboard_activity_show(struct device *dev,					    struct device_attribute *attr,					    char *buf){	return sprintf(buf, "%u\n", KEYBD_ISSET(km_activity));}static ssize_t hdaps_mouse_activity_show(struct device *dev,					 struct device_attribute *attr,					 char *buf){	return sprintf(buf, "%u\n", MOUSE_ISSET(km_activity));}static ssize_t hdaps_calibrate_show(struct device *dev,				    struct device_attribute *attr, char *buf){	return sprintf(buf, "(%d,%d)\n", rest_x, rest_y);}static ssize_t hdaps_calibrate_store(struct device *dev,				     struct device_attribute *attr,				     const char *buf, size_t count){	mutex_lock(&hdaps_mtx);	hdaps_calibrate();	mutex_unlock(&hdaps_mtx);	return count;}static ssize_t hdaps_invert_show(struct device *dev,				 struct device_attribute *attr, char *buf){	return sprintf(buf, "%u\n", hdaps_invert);}static ssize_t hdaps_invert_store(struct device *dev,				  struct device_attribute *attr,				  const char *buf, size_t count){	int invert;	if (sscanf(buf, "%d", &invert) != 1 || (invert != 1 && invert != 0))		return -EINVAL;	hdaps_invert = invert;	hdaps_calibrate();	return count;}static DEVICE_ATTR(position, 0444, hdaps_position_show, NULL);static DEVICE_ATTR(variance, 0444, hdaps_variance_show, NULL);static DEVICE_ATTR(temp1, 0444, hdaps_temp1_show, NULL);static DEVICE_ATTR(temp2, 0444, hdaps_temp2_show, NULL);static DEVICE_ATTR(keyboard_activity, 0444, hdaps_keyboard_activity_show, NULL);static DEVICE_ATTR(mouse_activity, 0444, hdaps_mouse_activity_show, NULL);static DEVICE_ATTR(calibrate, 0644, hdaps_calibrate_show,hdaps_calibrate_store);static DEVICE_ATTR(invert, 0644, hdaps_invert_show, hdaps_invert_store);static struct attribute *hdaps_attributes[] = {	&dev_attr_position.attr,	&dev_attr_variance.attr,	&dev_attr_temp1.attr,	&dev_attr_temp2.attr,	&dev_attr_keyboard_activity.attr,	&dev_attr_mouse_activity.attr,	&dev_attr_calibrate.attr,	&dev_attr_invert.attr,	NULL,};static struct attribute_group hdaps_attribute_group = {	.attrs = hdaps_attributes,};/* Module stuff *//* hdaps_dmi_match - found a match.  return one, short-circuiting the hunt. */static int __init hdaps_dmi_match(const struct dmi_system_id *id){	printk(KERN_INFO "hdaps: %s detected.\n", id->ident);	return 1;}/* hdaps_dmi_match_invert - found an inverted match. */static int __init hdaps_dmi_match_invert(const struct dmi_system_id *id){	hdaps_invert = 1;	printk(KERN_INFO "hdaps: inverting axis readings.\n");	return hdaps_dmi_match(id);}#define HDAPS_DMI_MATCH_NORMAL(vendor, model) {		\	.ident = vendor " " model,			\	.callback = hdaps_dmi_match,			\	.matches = {					\		DMI_MATCH(DMI_BOARD_VENDOR, vendor),	\		DMI_MATCH(DMI_PRODUCT_VERSION, model)	\	}						\}#define HDAPS_DMI_MATCH_INVERT(vendor, model) {		\	.ident = vendor " " model,			\	.callback = hdaps_dmi_match_invert,		\	.matches = {					\		DMI_MATCH(DMI_BOARD_VENDOR, vendor),	\		DMI_MATCH(DMI_PRODUCT_VERSION, model)	\	}						\}/* Note that HDAPS_DMI_MATCH_NORMAL("ThinkPad T42") would match   "ThinkPad T42p", so the order of the entries matters.   If your ThinkPad is not recognized, please update to latest   BIOS. This is especially the case for some R52 ThinkPads. */static struct dmi_system_id __initdata hdaps_whitelist[] = {	HDAPS_DMI_MATCH_INVERT("IBM", "ThinkPad R50p"),	HDAPS_DMI_MATCH_NORMAL("IBM", "ThinkPad R50"),	HDAPS_DMI_MATCH_NORMAL("IBM", "ThinkPad R51"),	HDAPS_DMI_MATCH_NORMAL("IBM", "ThinkPad R52"),	HDAPS_DMI_MATCH_INVERT("IBM", "ThinkPad T41p"),	HDAPS_DMI_MATCH_NORMAL("IBM", "ThinkPad T41"),	HDAPS_DMI_MATCH_INVERT("IBM", "ThinkPad T42p"),	HDAPS_DMI_MATCH_NORMAL("IBM", "ThinkPad T42"),	HDAPS_DMI_MATCH_NORMAL("IBM", "ThinkPad T43"),	HDAPS_DMI_MATCH_INVERT("LENOVO", "ThinkPad T60"),	HDAPS_DMI_MATCH_NORMAL("IBM", "ThinkPad X40"),	HDAPS_DMI_MATCH_NORMAL("IBM", "ThinkPad X41"),	HDAPS_DMI_MATCH_INVERT("LENOVO", "ThinkPad X60"),	HDAPS_DMI_MATCH_NORMAL("IBM", "ThinkPad Z60m"),	{ .ident = NULL }};static int __init hdaps_init(void){	struct input_dev *idev;	int ret;	if (!dmi_check_system(hdaps_whitelist)) {		printk(KERN_WARNING "hdaps: supported laptop not found!\n");		ret = -ENODEV;		goto out;	}	if (!request_region(HDAPS_LOW_PORT, HDAPS_NR_PORTS, "hdaps")) {		ret = -ENXIO;		goto out;	}	ret = platform_driver_register(&hdaps_driver);	if (ret)		goto out_region;	pdev = platform_device_register_simple("hdaps", -1, NULL, 0);	if (IS_ERR(pdev)) {		ret = PTR_ERR(pdev);		goto out_driver;	}	ret = sysfs_create_group(&pdev->dev.kobj, &hdaps_attribute_group);	if (ret)		goto out_device;	hdaps_idev = input_allocate_polled_device();	if (!hdaps_idev) {		ret = -ENOMEM;		goto out_group;	}	hdaps_idev->poll = hdaps_mousedev_poll;	hdaps_idev->poll_interval = HDAPS_POLL_INTERVAL;	/* initial calibrate for the input device */	hdaps_calibrate();	/* initialize the input class */	idev = hdaps_idev->input;	idev->name = "hdaps";	idev->dev.parent = &pdev->dev;	idev->evbit[0] = BIT_MASK(EV_ABS);	input_set_abs_params(idev, ABS_X,			-256, 256, HDAPS_INPUT_FUZZ, HDAPS_INPUT_FLAT);	input_set_abs_params(idev, ABS_Y,			-256, 256, HDAPS_INPUT_FUZZ, HDAPS_INPUT_FLAT);	ret = input_register_polled_device(hdaps_idev);	if (ret)		goto out_idev;	printk(KERN_INFO "hdaps: driver successfully loaded.\n");	return 0;out_idev:	input_free_polled_device(hdaps_idev);out_group:	sysfs_remove_group(&pdev->dev.kobj, &hdaps_attribute_group);out_device:	platform_device_unregister(pdev);out_driver:	platform_driver_unregister(&hdaps_driver);out_region:	release_region(HDAPS_LOW_PORT, HDAPS_NR_PORTS);out:	printk(KERN_WARNING "hdaps: driver init failed (ret=%d)!\n", ret);	return ret;}static void __exit hdaps_exit(void){	input_unregister_polled_device(hdaps_idev);	input_free_polled_device(hdaps_idev);	sysfs_remove_group(&pdev->dev.kobj, &hdaps_attribute_group);	platform_device_unregister(pdev);	platform_driver_unregister(&hdaps_driver);	release_region(HDAPS_LOW_PORT, HDAPS_NR_PORTS);	printk(KERN_INFO "hdaps: driver unloaded.\n");}module_init(hdaps_init);module_exit(hdaps_exit);module_param_named(invert, hdaps_invert, bool, 0);MODULE_PARM_DESC(invert, "invert data along each axis");MODULE_AUTHOR("Robert Love");MODULE_DESCRIPTION("IBM Hard Drive Active Protection System (HDAPS) driver");MODULE_LICENSE("GPL v2");

⌨️ 快捷键说明

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