2010-05-16 19:59:07 -07:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include "config.h"
|
|
|
|
#endif
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-05-22 00:04:00 -07:00
|
|
|
#include <Eeze.h>
|
2010-05-16 19:59:07 -07:00
|
|
|
#include "eeze_udev_private.h"
|
2010-05-14 00:36:43 -07:00
|
|
|
|
2010-05-13 03:49:17 -07:00
|
|
|
/**
|
2010-10-15 20:57:54 -07:00
|
|
|
* @addtogroup syspath Syspath
|
2010-05-13 03:49:17 -07:00
|
|
|
*
|
2011-01-05 10:46:32 -08:00
|
|
|
* These are functions which interact with the syspath (/sys/$PATH) of
|
2010-05-22 14:44:26 -07:00
|
|
|
* a device.
|
2011-01-05 10:46:32 -08:00
|
|
|
*
|
2010-05-22 14:44:26 -07:00
|
|
|
* @ingroup udev
|
2010-10-15 20:57:54 -07:00
|
|
|
*
|
|
|
|
* @{
|
2010-05-13 03:49:17 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Find the root device of a device from its syspath.
|
|
|
|
*
|
|
|
|
* @param syspath The syspath of a device, with or without "/sys/"
|
|
|
|
* @return The syspath of the parent device
|
2010-05-21 18:55:14 -07:00
|
|
|
*
|
2010-05-22 22:03:17 -07:00
|
|
|
* Return a stringshared syspath (/sys/$syspath) for the parent device.
|
2010-05-13 03:49:17 -07:00
|
|
|
*/
|
|
|
|
EAPI const char *
|
2010-05-16 19:59:07 -07:00
|
|
|
eeze_udev_syspath_get_parent(const char *syspath)
|
2010-05-13 03:49:17 -07:00
|
|
|
{
|
2010-05-21 18:55:14 -07:00
|
|
|
_udev_device *device, *parent;
|
2010-05-13 14:21:12 -07:00
|
|
|
const char *ret;
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-05-21 18:55:14 -07:00
|
|
|
if (!syspath)
|
|
|
|
return NULL;
|
|
|
|
|
2010-10-12 19:53:38 -07:00
|
|
|
if (!(device = _new_device(syspath)))
|
|
|
|
return NULL;
|
2010-05-13 03:49:17 -07:00
|
|
|
parent = udev_device_get_parent(device);
|
2010-10-21 11:50:09 -07:00
|
|
|
ret = eina_stringshare_add(udev_device_get_syspath(parent));
|
2010-05-13 03:49:17 -07:00
|
|
|
udev_device_unref(device);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-05-16 19:59:07 -07:00
|
|
|
* Returns a list of all parent device syspaths for @p syspath.
|
2010-05-13 03:49:17 -07:00
|
|
|
*
|
2010-05-16 19:59:07 -07:00
|
|
|
* @param syspath The device to find parents of
|
2010-05-22 22:03:17 -07:00
|
|
|
* @return A stringshared list of the parent devices of @p syspath
|
2010-05-13 03:49:17 -07:00
|
|
|
*/
|
|
|
|
EAPI Eina_List *
|
2010-05-16 19:59:07 -07:00
|
|
|
eeze_udev_syspath_get_parents(const char *syspath)
|
2010-05-13 03:49:17 -07:00
|
|
|
{
|
2010-05-21 18:55:14 -07:00
|
|
|
_udev_device *child, *parent, *device;
|
2010-05-16 19:59:07 -07:00
|
|
|
const char *path;
|
|
|
|
Eina_List *devlist = NULL;
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-05-21 18:55:14 -07:00
|
|
|
if (!syspath)
|
|
|
|
return NULL;
|
|
|
|
|
2010-10-12 19:53:38 -07:00
|
|
|
if (!(device = _new_device(syspath)))
|
|
|
|
return NULL;
|
2010-05-21 18:55:14 -07:00
|
|
|
|
2010-05-16 19:59:07 -07:00
|
|
|
if (!(parent = udev_device_get_parent(device)))
|
|
|
|
return NULL;
|
2010-05-21 18:55:14 -07:00
|
|
|
|
|
|
|
for (; parent; child = parent, parent = udev_device_get_parent(child))
|
|
|
|
{
|
|
|
|
path = udev_device_get_syspath(parent);
|
|
|
|
devlist = eina_list_append(devlist, eina_stringshare_add(path));
|
|
|
|
}
|
|
|
|
|
|
|
|
udev_device_unref(device);
|
|
|
|
return devlist;
|
2010-05-13 03:49:17 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the /dev/ path from the /sys/ path.
|
|
|
|
*
|
|
|
|
* @param syspath The /sys/ path with or without the /sys/
|
2010-05-22 22:03:17 -07:00
|
|
|
* @return A stringshared char* with the /dev/ path or NULL on failure
|
2010-05-21 18:55:14 -07:00
|
|
|
*
|
2010-05-13 03:49:17 -07:00
|
|
|
* Takes /sys/$PATH and turns it into the corresponding "/dev/x/y".
|
|
|
|
*/
|
|
|
|
EAPI const char *
|
2010-05-13 22:21:52 -07:00
|
|
|
eeze_udev_syspath_get_devpath(const char *syspath)
|
2010-05-13 03:49:17 -07:00
|
|
|
{
|
2010-05-21 18:55:14 -07:00
|
|
|
_udev_device *device;
|
|
|
|
const char *name = NULL;
|
|
|
|
|
|
|
|
if (!syspath)
|
|
|
|
return NULL;
|
|
|
|
|
2010-10-12 19:53:38 -07:00
|
|
|
if (!(device = _new_device(syspath)))
|
|
|
|
return NULL;
|
2010-05-21 18:55:14 -07:00
|
|
|
|
2010-10-21 11:50:09 -07:00
|
|
|
if (!(name = udev_device_get_devnode(device)))
|
2010-05-21 18:55:14 -07:00
|
|
|
return NULL;
|
|
|
|
|
|
|
|
name = eina_stringshare_add(name);
|
|
|
|
udev_device_unref(device);
|
|
|
|
return name;
|
2010-05-13 03:49:17 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the subsystem of a device from the /sys/ path.
|
|
|
|
*
|
|
|
|
* @param syspath The /sys/ path with or without the /sys/
|
2010-05-22 22:03:17 -07:00
|
|
|
* @return A stringshared char* with the subsystem of the device or NULL on failure
|
2010-05-21 18:55:14 -07:00
|
|
|
*
|
2010-05-13 03:49:17 -07:00
|
|
|
* Takes /sys/$PATH and returns the corresponding device subsystem,
|
|
|
|
* such as "input" for keyboards/mice.
|
|
|
|
*/
|
|
|
|
EAPI const char *
|
2010-05-13 22:21:52 -07:00
|
|
|
eeze_udev_syspath_get_subsystem(const char *syspath)
|
2010-05-13 03:49:17 -07:00
|
|
|
{
|
2010-05-21 18:55:14 -07:00
|
|
|
_udev_device *device;
|
|
|
|
const char *subsystem;
|
|
|
|
|
|
|
|
if (!syspath)
|
|
|
|
return NULL;
|
|
|
|
|
2010-10-12 19:53:38 -07:00
|
|
|
if (!(device = _new_device(syspath)))
|
|
|
|
return NULL;
|
|
|
|
subsystem = eina_stringshare_add(udev_device_get_property_value(device, "SUBSYSTEM"));
|
2010-05-21 18:55:14 -07:00
|
|
|
udev_device_unref(device);
|
|
|
|
return subsystem;
|
2010-05-13 03:49:17 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the property value of a device from the /sys/ path.
|
|
|
|
*
|
|
|
|
* @param syspath The /sys/ path with or without the /sys/
|
|
|
|
* @param property The property to get; full list of these is a FIXME
|
2010-05-22 22:03:17 -07:00
|
|
|
* @return A stringshared char* with the property or NULL on failure
|
2010-05-13 03:49:17 -07:00
|
|
|
*/
|
|
|
|
EAPI const char *
|
2011-01-05 10:46:32 -08:00
|
|
|
eeze_udev_syspath_get_property(const char *syspath,
|
|
|
|
const char *property)
|
2010-05-13 03:49:17 -07:00
|
|
|
{
|
2010-05-21 18:55:14 -07:00
|
|
|
_udev_device *device;
|
|
|
|
const char *value = NULL, *test;
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-05-21 18:55:14 -07:00
|
|
|
if (!syspath || !property)
|
|
|
|
return NULL;
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-10-12 19:53:38 -07:00
|
|
|
if (!(device = _new_device(syspath)))
|
|
|
|
return NULL;
|
2010-05-21 18:55:14 -07:00
|
|
|
if ((test = udev_device_get_property_value(device, property)))
|
|
|
|
value = eina_stringshare_add(test);
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-05-21 18:55:14 -07:00
|
|
|
udev_device_unref(device);
|
|
|
|
return value;
|
2010-05-13 03:49:17 -07:00
|
|
|
}
|
|
|
|
|
2010-05-20 00:30:41 -07:00
|
|
|
/**
|
|
|
|
* Get the sysattr value of a device from the /sys/ path.
|
|
|
|
*
|
|
|
|
* @param syspath The /sys/ path with or without the /sys/
|
|
|
|
* @param sysattr The sysattr to get; full list of these is a FIXME
|
2010-05-22 22:03:17 -07:00
|
|
|
* @return A stringshared char* with the sysattr or NULL on failure
|
2010-05-20 00:30:41 -07:00
|
|
|
*/
|
|
|
|
EAPI const char *
|
2011-01-05 10:46:32 -08:00
|
|
|
eeze_udev_syspath_get_sysattr(const char *syspath,
|
|
|
|
const char *sysattr)
|
2010-05-20 00:30:41 -07:00
|
|
|
{
|
2010-05-21 18:55:14 -07:00
|
|
|
_udev_device *device;
|
|
|
|
const char *value = NULL, *test;
|
2010-05-20 00:30:41 -07:00
|
|
|
|
2010-05-21 18:55:14 -07:00
|
|
|
if (!syspath || !sysattr)
|
|
|
|
return NULL;
|
2010-05-20 00:30:41 -07:00
|
|
|
|
2010-10-12 19:53:38 -07:00
|
|
|
if (!(device = _new_device(syspath)))
|
|
|
|
return NULL;
|
2010-05-21 18:55:14 -07:00
|
|
|
|
|
|
|
if ((test = udev_device_get_sysattr_value(device, sysattr)))
|
|
|
|
value = eina_stringshare_add(test);
|
2010-05-20 00:30:41 -07:00
|
|
|
|
2010-05-21 18:55:14 -07:00
|
|
|
udev_device_unref(device);
|
|
|
|
return value;
|
2010-05-20 00:30:41 -07:00
|
|
|
}
|
|
|
|
|
2010-05-13 03:49:17 -07:00
|
|
|
/**
|
|
|
|
* Checks whether the device is a mouse.
|
|
|
|
*
|
2010-05-16 19:59:07 -07:00
|
|
|
* @param syspath The /sys/ path with or without the /sys/
|
2010-05-13 03:49:17 -07:00
|
|
|
* @return If true, the device is a mouse
|
|
|
|
*/
|
|
|
|
EAPI Eina_Bool
|
2010-05-13 22:21:52 -07:00
|
|
|
eeze_udev_syspath_is_mouse(const char *syspath)
|
2010-05-13 03:49:17 -07:00
|
|
|
{
|
2010-10-15 21:18:26 -07:00
|
|
|
_udev_device *device = NULL;
|
|
|
|
Eina_Bool mouse = EINA_FALSE;
|
2010-05-21 18:55:14 -07:00
|
|
|
const char *test = NULL;
|
|
|
|
|
|
|
|
if (!syspath)
|
2010-10-12 19:53:38 -07:00
|
|
|
return EINA_FALSE;
|
2010-05-21 18:55:14 -07:00
|
|
|
|
2010-10-12 19:53:38 -07:00
|
|
|
if (!(device = _new_device(syspath)))
|
|
|
|
return EINA_FALSE;
|
2010-05-14 00:36:43 -07:00
|
|
|
#ifdef OLD_UDEV_RRRRRRRRRRRRRR
|
2010-05-21 18:55:14 -07:00
|
|
|
mouse = _walk_parents_test_attr(device, "bInterfaceProtocol", "02");
|
|
|
|
|
|
|
|
if (!mouse)
|
|
|
|
{
|
|
|
|
test = udev_device_get_property_value(device, "ID_CLASS");
|
|
|
|
|
|
|
|
if ((test) && (!strcmp(test, "mouse")))
|
2010-10-15 21:18:26 -07:00
|
|
|
mouse = EINA_TRUE;
|
2010-05-21 18:55:14 -07:00
|
|
|
}
|
|
|
|
|
2010-05-14 00:36:43 -07:00
|
|
|
#else
|
2010-05-21 18:55:14 -07:00
|
|
|
test = udev_device_get_property_value(device, "ID_INPUT_MOUSE");
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-10-15 21:18:26 -07:00
|
|
|
if (test && (test[0] == '1'))
|
|
|
|
mouse = EINA_TRUE;
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-05-21 18:55:14 -07:00
|
|
|
#endif
|
|
|
|
udev_device_unref(device);
|
|
|
|
return mouse;
|
2010-05-13 03:49:17 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks whether the device is a keyboard.
|
|
|
|
*
|
2010-05-16 19:59:07 -07:00
|
|
|
* @param syspath The /sys/ path with or without the /sys/
|
2010-05-13 03:49:17 -07:00
|
|
|
* @return If true, the device is a keyboard
|
|
|
|
*/
|
|
|
|
EAPI Eina_Bool
|
2010-05-13 22:21:52 -07:00
|
|
|
eeze_udev_syspath_is_kbd(const char *syspath)
|
2010-05-13 03:49:17 -07:00
|
|
|
{
|
2010-10-15 21:18:26 -07:00
|
|
|
_udev_device *device = NULL;
|
|
|
|
Eina_Bool kbd = EINA_FALSE;
|
2010-05-21 18:55:14 -07:00
|
|
|
const char *test = NULL;
|
|
|
|
|
|
|
|
if (!syspath)
|
2010-10-15 21:18:26 -07:00
|
|
|
return EINA_FALSE;
|
2010-05-21 18:55:14 -07:00
|
|
|
|
2010-10-12 19:53:38 -07:00
|
|
|
if (!(device = _new_device(syspath)))
|
|
|
|
return EINA_FALSE;
|
2010-05-14 00:36:43 -07:00
|
|
|
#ifdef OLD_UDEV_RRRRRRRRRRRRRR
|
2010-05-21 18:55:14 -07:00
|
|
|
kbd = _walk_parents_test_attr(device, "bInterfaceProtocol", "01");
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-05-21 18:55:14 -07:00
|
|
|
if (!kbd)
|
|
|
|
{
|
|
|
|
test = udev_device_get_property_value(device, "ID_CLASS");
|
|
|
|
|
|
|
|
if ((test) && (!strcmp(test, "kbd")))
|
2010-10-15 21:18:26 -07:00
|
|
|
kbd = EINA_TRUE;
|
2010-05-21 18:55:14 -07:00
|
|
|
}
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-05-21 18:55:14 -07:00
|
|
|
#else
|
|
|
|
test = udev_device_get_property_value(device, "ID_INPUT_KEYBOARD");
|
|
|
|
|
2010-10-15 21:18:26 -07:00
|
|
|
if (test && (test[0] == '1'))
|
|
|
|
kbd = EINA_TRUE;
|
2010-05-21 18:55:14 -07:00
|
|
|
|
|
|
|
#endif
|
|
|
|
udev_device_unref(device);
|
|
|
|
return kbd;
|
2010-05-13 03:49:17 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks whether the device is a touchpad.
|
|
|
|
*
|
2010-05-16 19:59:07 -07:00
|
|
|
* @param syspath The /sys/ path with or without the /sys/
|
2010-05-13 03:49:17 -07:00
|
|
|
* @return If true, the device is a touchpad
|
|
|
|
*/
|
|
|
|
EAPI Eina_Bool
|
2010-05-13 22:21:52 -07:00
|
|
|
eeze_udev_syspath_is_touchpad(const char *syspath)
|
2010-05-13 03:49:17 -07:00
|
|
|
{
|
2010-10-15 21:18:26 -07:00
|
|
|
_udev_device *device = NULL;
|
|
|
|
Eina_Bool touchpad = EINA_FALSE;
|
2010-05-21 18:55:14 -07:00
|
|
|
|
|
|
|
if (!syspath)
|
2010-10-15 21:18:26 -07:00
|
|
|
return EINA_FALSE;
|
2010-05-21 18:55:14 -07:00
|
|
|
|
2010-10-12 19:53:38 -07:00
|
|
|
if (!(device = _new_device(syspath)))
|
|
|
|
return EINA_FALSE;
|
2010-05-14 00:36:43 -07:00
|
|
|
#ifdef OLD_UDEV_RRRRRRRRRRRRRR
|
2010-05-21 18:55:14 -07:00
|
|
|
touchpad = _walk_parents_test_attr(device, "resolution", NULL);
|
2010-05-14 00:36:43 -07:00
|
|
|
#else
|
2010-05-21 18:55:14 -07:00
|
|
|
const char *test;
|
|
|
|
test = udev_device_get_property_value(device, "ID_INPUT_TOUCHPAD");
|
2010-05-13 03:49:17 -07:00
|
|
|
|
2010-10-15 21:18:26 -07:00
|
|
|
if (test && (test[0] == '1'))
|
|
|
|
touchpad = EINA_TRUE;
|
2010-05-21 18:55:14 -07:00
|
|
|
|
|
|
|
#endif
|
|
|
|
udev_device_unref(device);
|
|
|
|
return touchpad;
|
2010-05-13 03:49:17 -07:00
|
|
|
}
|
2010-05-22 14:44:26 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the syspath of a device from the /dev/ path.
|
|
|
|
*
|
|
|
|
* @param devpath The /dev/ path of the device
|
2010-05-22 22:03:17 -07:00
|
|
|
* @return A stringshared char* which corresponds to the /sys/ path of the device or NULL on failure
|
2010-05-22 14:44:26 -07:00
|
|
|
*
|
|
|
|
* Takes "/dev/path" and returns the corresponding /sys/ path (without the "/sys/")
|
|
|
|
*/
|
|
|
|
EAPI const char *
|
|
|
|
eeze_udev_devpath_get_syspath(const char *devpath)
|
|
|
|
{
|
|
|
|
_udev_enumerate *en;
|
|
|
|
_udev_list_entry *devs, *cur;
|
2010-10-16 13:03:36 -07:00
|
|
|
const char *ret = NULL;
|
2010-05-22 14:44:26 -07:00
|
|
|
|
|
|
|
if (!devpath)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
en = udev_enumerate_new((udev));
|
|
|
|
|
|
|
|
if (!en)
|
|
|
|
return NULL;
|
|
|
|
|
2010-10-16 12:59:43 -07:00
|
|
|
udev_enumerate_add_match_property(en, "DEVNAME", devpath);
|
2010-05-22 14:44:26 -07:00
|
|
|
udev_enumerate_scan_devices(en);
|
|
|
|
devs = udev_enumerate_get_list_entry(en);
|
|
|
|
udev_list_entry_foreach(cur, devs)
|
|
|
|
{
|
2010-10-16 13:03:36 -07:00
|
|
|
ret = eina_stringshare_add(udev_list_entry_get_name(cur));
|
2011-01-05 10:46:32 -08:00
|
|
|
break; /*just in case there's more than one somehow */
|
2010-05-22 14:44:26 -07:00
|
|
|
}
|
|
|
|
udev_enumerate_unref(en);
|
|
|
|
return ret;
|
|
|
|
}
|
2010-10-15 20:57:54 -07:00
|
|
|
|
|
|
|
/** @} */
|