OdevAttribute: Add support for integer attributes
Add a couple of new functions for dealing with storing integer values into OdevAttributes. Signed-off-by: Hans de Goede <hdegoede@redhat.com> Reviewed-by: Dave Airlie <airlied@redhat.com> Reviewed-by: Peter Hutterer <peter.hutterer@who-t.net>
This commit is contained in:
parent
350559dcdc
commit
bc9d17fb56
|
@ -172,6 +172,26 @@ config_odev_add_attribute(struct OdevAttributes *attribs, int attrib,
|
||||||
oa->attrib_id = attrib;
|
oa->attrib_id = attrib;
|
||||||
free(oa->attrib_name);
|
free(oa->attrib_name);
|
||||||
oa->attrib_name = strdup(attrib_name);
|
oa->attrib_name = strdup(attrib_name);
|
||||||
|
oa->attrib_type = ODEV_ATTRIB_STRING;
|
||||||
|
xorg_list_append(&oa->member, &attribs->list);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
Bool
|
||||||
|
config_odev_add_int_attribute(struct OdevAttributes *attribs, int attrib,
|
||||||
|
int attrib_value)
|
||||||
|
{
|
||||||
|
struct OdevAttribute *oa;
|
||||||
|
|
||||||
|
oa = config_odev_find_attribute(attribs, attrib);
|
||||||
|
if (!oa)
|
||||||
|
oa = calloc(1, sizeof(struct OdevAttribute));
|
||||||
|
if (!oa)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
oa->attrib_id = attrib;
|
||||||
|
oa->attrib_value = attrib_value;
|
||||||
|
oa->attrib_type = ODEV_ATTRIB_INT;
|
||||||
xorg_list_append(&oa->member, &attribs->list);
|
xorg_list_append(&oa->member, &attribs->list);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -185,9 +205,32 @@ config_odev_get_attribute(struct OdevAttributes *attribs, int attrib_id)
|
||||||
if (!oa)
|
if (!oa)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
if (oa->attrib_type != ODEV_ATTRIB_STRING) {
|
||||||
|
LogMessage(X_ERROR, "Error %s called for non string attrib %d\n",
|
||||||
|
__func__, attrib_id);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
return oa->attrib_name;
|
return oa->attrib_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
config_odev_get_int_attribute(struct OdevAttributes *attribs, int attrib_id, int def)
|
||||||
|
{
|
||||||
|
struct OdevAttribute *oa;
|
||||||
|
|
||||||
|
oa = config_odev_find_attribute(attribs, attrib_id);
|
||||||
|
if (!oa)
|
||||||
|
return def;
|
||||||
|
|
||||||
|
if (oa->attrib_type != ODEV_ATTRIB_INT) {
|
||||||
|
LogMessage(X_ERROR, "Error %s called for non integer attrib %d\n",
|
||||||
|
__func__, attrib_id);
|
||||||
|
return def;
|
||||||
|
}
|
||||||
|
|
||||||
|
return oa->attrib_value;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
config_odev_free_attributes(struct OdevAttributes *attribs)
|
config_odev_free_attributes(struct OdevAttributes *attribs)
|
||||||
{
|
{
|
||||||
|
|
|
@ -89,6 +89,12 @@ xf86_add_platform_device_attrib(int index, int attrib_id, char *attrib_name)
|
||||||
return config_odev_add_attribute(device->attribs, attrib_id, attrib_name);
|
return config_odev_add_attribute(device->attribs, attrib_id, attrib_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Bool
|
||||||
|
xf86_add_platform_device_int_attrib(int index, int attrib_id, int attrib_value)
|
||||||
|
{
|
||||||
|
return config_odev_add_int_attribute(xf86_platform_devices[index].attribs, attrib_id, attrib_value);
|
||||||
|
}
|
||||||
|
|
||||||
char *
|
char *
|
||||||
xf86_get_platform_attrib(int index, int attrib_id)
|
xf86_get_platform_attrib(int index, int attrib_id)
|
||||||
{
|
{
|
||||||
|
@ -101,6 +107,18 @@ xf86_get_platform_device_attrib(struct xf86_platform_device *device, int attrib_
|
||||||
return config_odev_get_attribute(device->attribs, attrib_id);
|
return config_odev_get_attribute(device->attribs, attrib_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
xf86_get_platform_int_attrib(int index, int attrib_id, int def)
|
||||||
|
{
|
||||||
|
return config_odev_get_int_attribute(xf86_platform_devices[index].attribs, attrib_id, def);
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
xf86_get_platform_device_int_attrib(struct xf86_platform_device *device, int attrib_id, int def)
|
||||||
|
{
|
||||||
|
return config_odev_get_int_attribute(device->attribs, attrib_id, def);
|
||||||
|
}
|
||||||
|
|
||||||
Bool
|
Bool
|
||||||
xf86_get_platform_device_unowned(int index)
|
xf86_get_platform_device_unowned(int index)
|
||||||
{
|
{
|
||||||
|
|
|
@ -41,12 +41,16 @@ extern int xf86_num_platform_devices;
|
||||||
extern char *
|
extern char *
|
||||||
xf86_get_platform_attrib(int index, int attrib_id);
|
xf86_get_platform_attrib(int index, int attrib_id);
|
||||||
extern int
|
extern int
|
||||||
|
xf86_get_platform_int_attrib(int index, int attrib_id, int def);
|
||||||
|
extern int
|
||||||
xf86_add_platform_device(struct OdevAttributes *attribs);
|
xf86_add_platform_device(struct OdevAttributes *attribs);
|
||||||
extern int
|
extern int
|
||||||
xf86_remove_platform_device(int dev_index);
|
xf86_remove_platform_device(int dev_index);
|
||||||
extern Bool
|
extern Bool
|
||||||
xf86_add_platform_device_attrib(int index, int attrib_id, char *attrib_str);
|
xf86_add_platform_device_attrib(int index, int attrib_id, char *attrib_str);
|
||||||
extern Bool
|
extern Bool
|
||||||
|
xf86_add_platform_device_int_attrib(int index, int attrib_id, int attrib_value);
|
||||||
|
extern Bool
|
||||||
xf86_get_platform_device_unowned(int index);
|
xf86_get_platform_device_unowned(int index);
|
||||||
|
|
||||||
extern int
|
extern int
|
||||||
|
@ -56,6 +60,8 @@ xf86platformRemoveDevice(int index);
|
||||||
|
|
||||||
extern _X_EXPORT char *
|
extern _X_EXPORT char *
|
||||||
xf86_get_platform_device_attrib(struct xf86_platform_device *device, int attrib_id);
|
xf86_get_platform_device_attrib(struct xf86_platform_device *device, int attrib_id);
|
||||||
|
extern _X_EXPORT int
|
||||||
|
xf86_get_platform_device_int_attrib(struct xf86_platform_device *device, int attrib_id, int def);
|
||||||
extern _X_EXPORT Bool
|
extern _X_EXPORT Bool
|
||||||
xf86PlatformDeviceCheckBusID(struct xf86_platform_device *device, const char *busid);
|
xf86PlatformDeviceCheckBusID(struct xf86_platform_device *device, const char *busid);
|
||||||
|
|
||||||
|
|
|
@ -32,10 +32,16 @@ extern _X_EXPORT void config_pre_init(void);
|
||||||
extern _X_EXPORT void config_init(void);
|
extern _X_EXPORT void config_init(void);
|
||||||
extern _X_EXPORT void config_fini(void);
|
extern _X_EXPORT void config_fini(void);
|
||||||
|
|
||||||
|
enum { ODEV_ATTRIB_STRING, ODEV_ATTRIB_INT };
|
||||||
|
|
||||||
struct OdevAttribute {
|
struct OdevAttribute {
|
||||||
struct xorg_list member;
|
struct xorg_list member;
|
||||||
int attrib_id;
|
int attrib_id;
|
||||||
char *attrib_name;
|
union {
|
||||||
|
char *attrib_name;
|
||||||
|
int attrib_value;
|
||||||
|
};
|
||||||
|
int attrib_type;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct OdevAttributes {
|
struct OdevAttributes {
|
||||||
|
@ -56,6 +62,14 @@ config_odev_add_attribute(struct OdevAttributes *attribs, int attrib,
|
||||||
char *
|
char *
|
||||||
config_odev_get_attribute(struct OdevAttributes *attribs, int attrib_id);
|
config_odev_get_attribute(struct OdevAttributes *attribs, int attrib_id);
|
||||||
|
|
||||||
|
Bool
|
||||||
|
config_odev_add_int_attribute(struct OdevAttributes *attribs, int attrib,
|
||||||
|
int attrib_value);
|
||||||
|
|
||||||
|
int
|
||||||
|
config_odev_get_int_attribute(struct OdevAttributes *attribs, int attrib,
|
||||||
|
int def);
|
||||||
|
|
||||||
void
|
void
|
||||||
config_odev_free_attributes(struct OdevAttributes *attribs);
|
config_odev_free_attributes(struct OdevAttributes *attribs);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue