Initial netbsd support
This commit is contained in:
parent
1990f9b034
commit
4ad48cb305
7 changed files with 84 additions and 4 deletions
|
@ -9,6 +9,9 @@
|
|||
#include <sys/sysmacros.h>
|
||||
#elif defined(__FreeBSD__)
|
||||
#include <dev/evdev/input.h>
|
||||
#elif defined(__NetBSD__)
|
||||
#include <stdlib.h>
|
||||
#include <sys/stat.h>
|
||||
#else
|
||||
#error Unsupported platform
|
||||
#endif
|
||||
|
@ -17,6 +20,7 @@
|
|||
|
||||
#define STRLEN(s) ((sizeof(s) / sizeof(s[0])) - 1)
|
||||
|
||||
#if defined(__linux__) || defined(__FreeBSD__)
|
||||
int path_is_evdev(const char *path) {
|
||||
static const char prefix[] = "/dev/input/event";
|
||||
static const size_t prefixlen = STRLEN(prefix);
|
||||
|
@ -26,9 +30,28 @@ int path_is_evdev(const char *path) {
|
|||
int evdev_revoke(int fd) {
|
||||
return ioctl(fd, EVIOCREVOKE, NULL);
|
||||
}
|
||||
#endif
|
||||
|
||||
#if defined(__linux__)
|
||||
int dev_is_evdev(dev_t device) {
|
||||
return major(device) == INPUT_MAJOR;
|
||||
}
|
||||
#elif defined(__NetBSD__)
|
||||
int dev_is_evdev(dev_t device) {
|
||||
return major(device) == getdevmajor("wskbd", S_IFCHR) ||
|
||||
major(device) == getdevmajor("wsmouse", S_IFCHR) ||
|
||||
major(device) == getdevmajor("wsmux", S_IFCHR);
|
||||
}
|
||||
int path_is_evdev(const char *path) {
|
||||
const char *wskbd = "/dev/wskbd";
|
||||
const char *wsmouse = "/dev/wsmouse";
|
||||
const char *wsmux = "/dev/wsmux";
|
||||
return strncmp(path, wskbd, STRLEN(wskbd)) == 0 ||
|
||||
strncmp(path, wsmouse, STRLEN(wsmouse)) == 0 ||
|
||||
strncmp(path, wsmux, STRLEN(wsmouse)) == 0;
|
||||
}
|
||||
int evdev_revoke(int fd) {
|
||||
(void)fd;
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue