adc_keys_poll 怎么传参的
时间: 2024-01-15 18:04:55 浏览: 33
`adc_keys_poll` 函数是由内核调用的,内核在调用 `adc_keys_poll` 函数时会传递一些参数给它。具体来说,`adc_keys_poll` 函数的原型如下:
```c
static int adc_keys_poll(struct input_polled_dev *dev, struct input_polled_dev *poll_dev)
```
其中,`dev` 是指向输入设备的指针,`poll_dev` 是指向轮询设备的指针。这两个参数都是由内核传递给 `adc_keys_poll` 函数的。在 `adc_keys_poll` 函数内部,可以使用这些参数来访问输入设备和轮询设备的数据,以及进行数据处理、状态检测等操作。
相关问题
poll_dev->poll = adc_keys_poll;这行当中的adc_keys_poll函数怎么被调用的
`adc_keys_poll` 函数是一个轮询函数,用于检测输入设备的状态。在注册输入设备时,`poll_dev->poll` 成员被设置为 `adc_keys_poll` 函数的指针,这意味着当输入设备被轮询时,会调用 `adc_keys_poll` 函数来检测输入设备的状态。
具体来说,当输入设备被轮询时,内核会调用 `adc_keys_poll` 函数。该函数会读取输入设备的状态信息,比如按键是否按下等,然后将这些信息存储在输入设备的缓冲区中。如果输入设备的状态发生变化,`adc_keys_poll` 函数会将变化的状态信息放入输入设备的缓冲区,并返回一个值,这个值会告诉内核输入设备的状态是否发生变化。内核会根据这个返回值来判断是否需要唤醒等待输入设备状态的进程。
static void adc_keys_poll(struct input_polled_dev *dev) { struct adc_keys_state *st = dev->private; int i, value, ret; u32 diff, closest = 0xffffffff; int keycode = 0; ret = iio_read_channel_processed(st->channel, &value); if (unlikely(ret < 0)) { /* Forcibly release key if any was pressed */ value = st->keyup_voltage; } else { for (i = 0; i < st->num_keys; i++) { diff = abs(st->map[i].voltage - value); if (diff < closest) { closest = diff; keycode = st->map[i].keycode; } } } if (abs(st->keyup_voltage - value) < closest) keycode = 0; if (st->last_key && st->last_key != keycode) input_report_key(dev->input, st->last_key, 0); if (keycode) input_report_key(dev->input, keycode, 1); input_sync(dev->input); st->last_key = keycode; }每一行代码解析
这段代码实现了一个ADC按键输入设备的轮询函数。下面对每行代码进行解析:
```c
static void adc_keys_poll(struct input_polled_dev *dev) {
```
定义了一个名为adc_keys_poll的静态函数,该函数的参数是一个指向input_polled_dev结构体的指针dev,表示一个轮询设备。
```c
struct adc_keys_state *st = dev->private;
```
定义了一个名为st的指针,指向dev的private成员变量,该成员变量是一个指向adc_keys_state结构体的指针,表示ADC按键输入设备的状态。
```c
int i, value, ret;
u32 diff, closest = 0xffffffff;
int keycode = 0;
```
定义了一些变量,包括循环计数器i、读取的ADC值value、函数返回值ret、ADC值与按键电压差距的最小值closest、对应的按键键值keycode。
```c
ret = iio_read_channel_processed(st->channel, &value);
```
从ADC通道中读取处理后的值,并将其存储在value中。函数返回值ret表示读取是否成功。
```c
if (unlikely(ret < 0)) {
/* Forcibly release key if any was pressed */
value = st->keyup_voltage;
} else {
for (i = 0; i < st->num_keys; i++) {
diff = abs(st->map[i].voltage - value);
if (diff < closest) {
closest = diff;
keycode = st->map[i].keycode;
}
}
}
```
如果读取失败(ret<0),则将键值设为keyup_voltage,否则通过比较ADC值与按键电压之间的差距来确定最接近的键值。遍历所有键值,找到最接近的键值,并将其存储在keycode中。
```c
if (abs(st->keyup_voltage - value) < closest)
keycode = 0;
```
如果keyup_voltage与value之间的差距比最接近的键值还要小,则说明键值已经被释放,将键值设为0。
```c
if (st->last_key && st->last_key != keycode)
input_report_key(dev->input, st->last_key, 0);
```
如果上一个键值存在且与当前键值不同,则释放上一个键值。input_report_key函数用于向输入子系统报告按键事件。
```c
if (keycode)
input_report_key(dev->input, keycode, 1);
```
如果当前键值存在,则报告按下事件。
```c
input_sync(dev->input);
st->last_key = keycode;
```
将输入事件同步到输入子系统,并将当前键值存储在last_key中,以便下一次轮询时使用。
相关推荐
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)