工具/软件:
您好、
我们正在使用 am62x 和 Processor SDK 09.02.01.10开发器件。
是否有办法监测 eQEP 发出的事件(例如 COUNTER_EVENT_OVERFLOW、COUNTER_EVENT_UNDERFLOW)?
根据下一页、这可以通过使用 COUNTER_ADD_WATCH_IOCTL 来实现。
https://docs.kernel.org/driver-api/generic-counter.html#userspace
当我尝试在 linux-ti-staging 中使用 tools/counter/counter_example.c 获取溢出事件时、内核无法读取该事件并显示以下消息。
"无法处理虚拟地址0000000000000010处的内核 NULL 指针解除引用"
如果您有任何建议或想法、请告诉我。
附加了 counter_example.c 的源代码。
// SPDX-License-Identifier: GPL-2.0-only /* Counter - example userspace application * * The userspace application opens /dev/counter0, configures the * COUNTER_EVENT_INDEX event channel 0 to gather Count 0 count and Count * 1 count, and prints out the data as it becomes available on the * character device node. * * Copyright (C) 2021 William Breathitt Gray */ #include <errno.h> #include <fcntl.h> #include <linux/counter.h> #include <stdio.h> #include <string.h> #include <sys/ioctl.h> #include <unistd.h> #include <poll.h> static struct counter_watch watches[1] = { { /* Component data: Count 0 count */ .component.type = COUNTER_COMPONENT_COUNT, .component.scope = COUNTER_SCOPE_COUNT, .component.parent = 0, /* Event type: overflow */ .event = COUNTER_EVENT_OVERFLOW, /* Device event channel 0 */ .channel = 0, }, }; int main(void) { int fd; int ret; int i; struct counter_event event_data[1]; fd = open("/dev/counter0", O_RDWR); if (fd == -1) { perror("Unable to open /dev/counter0"); return 1; } for (i = 0; i < 1; i++) { ret = ioctl(fd, COUNTER_ADD_WATCH_IOCTL, watches + i); if (ret == -1) { fprintf(stderr, "Error adding watches[%d]: %s\n", i, strerror(errno)); return 1; } } ret = ioctl(fd, COUNTER_ENABLE_EVENTS_IOCTL); if (ret == -1) { perror("Error enabling events"); return 1; } struct pollfd fds = { .fd = fd, .events = POLLIN, }; for (;;) { printf("polling\n"); int ret = poll(&fds, 1, -1); if (ret >= 1) { printf("read start\n"); ret = read(fd, event_data, sizeof(event_data)); printf("read end\n"); if (ret == -1) { perror("Failed to read event data"); return 1; } if (ret != sizeof(event_data)) { fprintf(stderr, "Failed to read event data\n"); return -EIO; } printf("Timestamp 0: %llu\tCount 0: %llu\n" "Error Message 0: %s\n", event_data[0].timestamp, event_data[0].value, strerror(event_data[0].status)); } else { perror("poll()"); close(fd); return -1; } } return 0; }
此致、
Takayuki