input_set_capability
时间: 2023-04-23 21:01:26 浏览: 223
input_set_capability是一个Linux内核函数,用于设置输入设备的能力(capability)。它可以设置输入设备的各种能力,如键盘的按键数量、鼠标的滚轮数量等。这个函数通常在输入设备的驱动程序中被调用,以便在系统中正确地配置输入设备。
相关问题
static const struct mmc_driver_api mmc_acts_driver_api = { .get_capability = mmc_acts_get_capability, .set_clock = mmc_acts_set_clock, .set_bus_width = mmc_acts_set_bus_width, .send_cmd = mmc_acts_send_cmd, .set_sdio_irq_callback = mmc_acts_set_sdio_irq_cbk, .enable_sdio_irq = mmc_acts_enable_sdio_irq, }; 请分析一下这段代码
这段代码定义了一个名为 `mmc_acts_driver_api` 的结构体变量,其类型为 `struct mmc_driver_api`。结构体中包含了一些函数指针成员,用于操作 mmc(多媒体卡)设备驱动的接口。
具体来说,这些函数指针的作用如下:
- `get_capability`:用于获取 mmc 设备的能力信息。
- `set_clock`:用于设置 mmc 设备的时钟频率。
- `set_bus_width`:用于设置 mmc 设备的总线宽度。
- `send_cmd`:用于发送命令给 mmc 设备。
另外还有两个函数指针成员:
- `set_sdio_irq_callback`:用于设置 SDIO(Secure Digital Input/Output)中断回调函数。
- `enable_sdio_irq`:用于使能 SDIO 中断。
这段代码中的函数指针成员的值是对应的函数名,表示这些函数将被调用来实现相应的功能。在这个例子中,这些函数的具体实现需要在其他地方定义。
linux adc_keys_probe函数分析
adc_keys_probe函数是Linux内核中与ADC按键相关的设备树探测函数。在设备树中,如果有ADC按键的相关信息(如所使用的ADC控制器、引脚等),Linux内核会自动调用该函数进行探测。
其主要功能包括:
1. 读取设备树中ADC按键节点的相关信息,如所用ADC控制器和引脚号;
2. 根据以上信息初始化ADC控制器,并将其与对应的GPIO引脚进行绑定;
3. 注册Linux输入子系统的按键输入设备,并将其与初始化好的ADC控制器进行关联。
下面是该函数的代码实现:
static int adc_keys_probe(struct platform_device *pdev)
{
struct device *dev = &pdev->dev;
struct adc_keys_platform_data *pdata = dev_get_platdata(dev);
const char *adc_name = pdata ? pdata->adc_name : NULL;
struct input_dev *input_dev;
struct adc_keys *keys;
int ret, i;
if (!adc_name) {
dev_err(dev, "no ADC controller specified in platform data\n");
return -EINVAL;
}
input_dev = devm_input_allocate_device(dev);
if (!input_dev)
return -ENOMEM;
keys = devm_kzalloc(dev, sizeof(*keys), GFP_KERNEL);
if (!keys)
return -ENOMEM;
platform_set_drvdata(pdev, keys);
keys->input = input_dev;
keys->adc = devm_iio_channel_get(&pdev->dev, "iio");
if (IS_ERR(keys->adc)) {
dev_err(dev, "failed to get ADC channel\n");
ret = PTR_ERR(keys->adc);
goto err_free_mem;
}
input_dev->name = pdev->name;
input_dev->phys = "keys/input0";
input_dev->id.bustype = BUS_HOST;
input_dev->id.vendor = 0x0001;
input_dev->id.product = 0x0001;
input_dev->id.version = 0x0100;
input_set_capability(input_dev, EV_KEY, KEY_POWER);
input_set_capability(input_dev, EV_KEY, KEY_VOLUMEUP);
input_set_capability(input_dev, EV_KEY, KEY_VOLUMEDOWN);
keys->min_val = pdata ? pdata->min_val : ADC_KEYS_DEFAULT_MAX;
keys->max_val = pdata ? pdata->max_val : ADC_KEYS_DEFAULT_MIN;
ret = input_register_device(input_dev);
if (ret) {
dev_err(dev, "failed to register input device\n");
goto err_free_mem;
}
ret = adc_keys_init_dev(keys, adc_name);
if (ret) {
dev_err(dev, "failed to init ADC controller\n");
goto err_free_dev;
}
for (i = 0; i < ARRAY_SIZE(keys->keymap); i++) {
ret = input_register_keycode(input_dev, keys->keymap[i].type,
keys->keymap[i].code, NULL);
if (ret) {
dev_err(dev, "failed to register input keycode\n");
goto err_free_dev;
}
}
ret = adc_keys_set_timer_interval(keys);
if (ret)
dev_warn(dev, "Failed to initialize the polling timer\n");
dev_info(dev, "registered ADC keys input device\n");
return 0;
err_free_dev:
input_unregister_device(input_dev);
err_free_mem:
return ret;
}
该函数通过dev_get_platdata函数读取设备树节点的平台数据信息,获取相关参数。接下来,分别进行输入子系统的相关初始化、iio_channel获取、ADC控制器的初始化、按键注册及关联操作,最终成功时输出相关信息并返回0,失败则进行相应的错误处理操作。